/* ===========================================
   BUTTON COMPONENT
   =========================================== */

/* Selector combinado: .button (nuevo) y .btn (legacy) */
:is(.button, .btn) {
  /* === Configuration === */
  --button-padding: 0.625em 1em;
  --button-gap: 0.5em;
  --button-bg: var(--bg-tertiary);
  --button-color: var(--text-primary);
  --button-hover-bg: var(--bg-elevated);
  --button-hover-color: var(--text-primary);
  --button-border-width: 1px;
  --button-border-style: solid;
  --button-border-color: var(--border-subtle);
  --button-radius: var(--radius-md);
  --button-font-weight: 600;
  --button-font-size: 0.875rem;

  /* === Layout === */
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--button-gap);
  padding: var(--button-padding);

  /* === Colors === */
  background: var(--button-bg);
  color: var(--button-color);

  /* === Border === */
  border-width: var(--button-border-width);
  border-style: var(--button-border-style);
  border-color: var(--button-border-color);
  border-radius: var(--button-radius);

  /* === Typography === */
  font-family: inherit;
  font-weight: var(--button-font-weight);
  font-size: var(--button-font-size);
  line-height: 1.1;
  text-decoration: none;
  white-space: nowrap;

  /* === Interactive === */
  cursor: pointer;
  transition:
    background-color 0.2s ease,
    border-color 0.2s ease,
    box-shadow 0.2s ease,
    transform 0.2s ease;
}

/* Icon sizing - scales with font */
:is(.button, .btn) svg {
  height: 1.2em;
  width: auto;
  flex-shrink: 0;
}

/* === Interactive States === */

:is(.button, .btn):hover {
  background: var(--button-hover-bg);
  color: var(--button-hover-color);
  border-color: var(--button-hover-border, var(--button-border-color));
}

:is(.button, .btn):focus-visible {
  outline: 2px solid var(--brand);
  outline-offset: 2px;
}

:is(.button, .btn):active {
  transform: scale(0.98);
}

:is(.button, .btn):disabled,
:is(.button, .btn)[aria-disabled="true"] {
  opacity: 0.5;
  cursor: not-allowed;
  pointer-events: none;
}

/* === VARIANTS via data attributes === */

/* Primary - main action button with subtle glow */
.button[data-variant="primary"] {
  --button-bg: var(--brand);
  --button-color: var(--bg-primary);
  --button-hover-bg: var(--brand-dark);
  --button-hover-color: var(--bg-primary);
  --button-border-color: transparent;
  box-shadow: 0 2px 8px rgba(57, 229, 166, 0.25);
}

.button[data-variant="primary"]:hover {
  box-shadow: 0 4px 12px rgba(57, 229, 166, 0.35);
  transform: translateY(-1px);
}

.button[data-variant="primary"]:active {
  transform: translateY(0) scale(0.98);
}

/* Secondary (default, explicit) */
.button[data-variant="secondary"] {
  --button-bg: var(--bg-tertiary);
  --button-color: var(--text-primary);
  --button-border-color: var(--border-subtle);
  --button-hover-bg: var(--bg-elevated);
  --button-hover-border: var(--border-default);
}

/* Ghost/Text */
.button[data-variant="ghost"] {
  --button-bg: transparent;
  --button-color: var(--text-secondary);
  --button-border-color: transparent;
  --button-hover-bg: var(--bg-tertiary);
  --button-hover-color: var(--text-primary);
}

/* Ghost Danger - transparent button with danger color */
:is(.button, .btn)[data-variant="ghost"][data-type="danger"] {
  --button-color: var(--state-danger);
  --button-hover-bg: color-mix(in srgb, var(--state-danger) 10%, transparent);
  --button-hover-color: var(--state-danger);
}

/* Secondary Danger - neutral by default, danger on hover */
:is(.button, .btn)[data-variant="secondary"][data-type="danger"] {
  --button-hover-bg: color-mix(in srgb, var(--state-danger) 10%, transparent);
  --button-hover-border: var(--state-danger);
  --button-hover-color: var(--state-danger);
}

/* Icon-only button - compact square button */
:is(.button, .btn)[data-icon-only] {
  --button-padding: 0;
  --button-radius: var(--radius-sm);
  --button-icon-size: 1.75rem;
  flex: 0 0 auto;
  width: var(--button-icon-size);
  height: var(--button-icon-size);
}

:is(.button, .btn)[data-icon-only][data-size="sm"] {
  --button-icon-size: 1.5rem;
  --button-padding: 0;
}

:is(.button, .btn)[data-icon-only][data-size="lg"] {
  --button-icon-size: 2.25rem;
  --button-padding: 0;
}

/* Danger */
.button[data-variant="danger"] {
  --button-bg: var(--state-danger);
  --button-color: white;
  --button-border-color: var(--state-danger-dark, #dc2626);
  --button-hover-bg: var(--state-danger-dark, #dc2626);
  --button-hover-color: white;
}

.button[data-variant="danger"]:hover {
  box-shadow: 0 4px 12px var(--state-danger-light);
}

/* === SIZES via data attributes === */

.button[data-size="sm"] {
  --button-padding: 0.5em 0.75em;
  --button-font-size: 0.8125rem;
}

.button[data-size="lg"] {
  --button-padding: 0.875em 1.5em;
  --button-font-size: 1rem;
}

/* === WIDTH modifiers === */

.button[data-width="full"] {
  width: 100%;
}

/* === LEGACY CLASS VARIANTS === */
/* .btn-* clases funcionan igual que data-variant */

.btn-primary {
  --button-bg: var(--brand);
  --button-color: var(--bg-primary);
  --button-hover-bg: var(--brand-dark);
  --button-hover-color: var(--bg-primary);
  --button-border-color: transparent;
  box-shadow: 0 2px 8px rgba(57, 229, 166, 0.25);
}

.btn-primary:hover {
  box-shadow: 0 4px 12px rgba(57, 229, 166, 0.35);
  transform: translateY(-1px);
}

.btn-secondary {
  --button-bg: var(--bg-tertiary);
  --button-color: var(--text-primary);
  --button-border-color: var(--border-subtle);
  --button-hover-bg: var(--bg-elevated);
}

.btn-danger {
  --button-bg: var(--state-danger);
  --button-color: white;
  --button-border-color: var(--state-danger-dark);
  --button-hover-bg: var(--state-danger-dark);
}

.btn-text {
  --button-bg: transparent;
  --button-color: var(--text-tertiary);
  --button-border-color: transparent;
  --button-hover-color: var(--text-secondary);
}

.btn-sm {
  --button-padding: 0.5em 0.75em;
  --button-font-size: 0.8125rem;
}

.btn-lg {
  --button-padding: 0.875em 1.5em;
  --button-font-size: 1rem;
}
