/* ══════════════════════════════════════════════════════════════
   Coach do Concurseiro — Botões
   ══════════════════════════════════════════════════════════════ */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 0.5625rem var(--space-5);
  border-radius: var(--radius-md);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  line-height: 1.25;
  text-decoration: none;
  cursor: pointer;
  border: 1.5px solid transparent;
  transition:
    background var(--transition-fast),
    color var(--transition-fast),
    border-color var(--transition-fast),
    box-shadow var(--transition-fast),
    transform var(--transition-fast);
  white-space: nowrap;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
}

.btn:hover { text-decoration: none; }

.btn:active { transform: scale(0.97); }

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

/* ── Variantes ───────────────────────────────────────────────── */

/* Primary */
.btn-primary {
  background: var(--clr-primary);
  color: var(--clr-text-inverse);
  border-color: var(--clr-primary);
}
.btn-primary:hover {
  background: var(--clr-primary-dark);
  border-color: var(--clr-primary-dark);
  box-shadow: var(--shadow-primary);
}

/* Secondary */
.btn-secondary {
  background: var(--clr-secondary);
  color: var(--clr-text-inverse);
  border-color: var(--clr-secondary);
}
.btn-secondary:hover {
  background: #162366;
  border-color: #162366;
}

/* Accent */
.btn-accent {
  background: var(--clr-accent);
  color: var(--clr-text);
  border-color: var(--clr-accent);
  font-weight: var(--weight-semi);
}
.btn-accent:hover {
  background: var(--clr-accent-dark);
  border-color: var(--clr-accent-dark);
}

/* Outline */
.btn-outline {
  background: transparent;
  color: var(--clr-primary);
  border-color: var(--clr-primary);
}
.btn-outline:hover {
  background: var(--clr-primary-light);
}

/* Ghost */
.btn-ghost {
  background: transparent;
  color: var(--clr-text-secondary);
  border-color: transparent;
}
.btn-ghost:hover {
  background: var(--clr-surface-2);
  color: var(--clr-text);
}

/* Danger */
.btn-danger {
  background: var(--clr-error);
  color: #fff;
  border-color: var(--clr-error);
}
.btn-danger:hover {
  background: #b91c1c;
  border-color: #b91c1c;
}

/* Danger outline */
.btn-danger-outline {
  background: transparent;
  color: var(--clr-error);
  border-color: var(--clr-error);
}
.btn-danger-outline:hover {
  background: var(--clr-error-bg);
}

/* Success */
.btn-success {
  background: var(--clr-success);
  color: #fff;
  border-color: var(--clr-success);
}
.btn-success:hover { background: #15803d; }

/* Light */
.btn-light {
  background: var(--clr-surface-2);
  color: var(--clr-text);
  border-color: var(--clr-border);
}
.btn-light:hover {
  background: var(--clr-border);
}

/* ── Tamanhos ─────────────────────────────────────────────────── */
.btn-xs {
  padding: 0.25rem 0.625rem;
  font-size: var(--text-xs);
  border-radius: var(--radius-sm);
  gap: var(--space-1);
}

.btn-sm {
  padding: 0.4rem 0.875rem;
  font-size: var(--text-sm);
}

.btn-lg {
  padding: 0.75rem var(--space-8);
  font-size: var(--text-md);
  border-radius: var(--radius-lg);
}

.btn-xl {
  padding: 0.9375rem var(--space-10);
  font-size: var(--text-lg);
  font-weight: var(--weight-semi);
  border-radius: var(--radius-lg);
}

/* ── Largura Total ────────────────────────────────────────────── */
.btn-block {
  width: 100%;
  justify-content: center;
}

/* ── Botão apenas ícone ───────────────────────────────────────── */
.btn-icon {
  padding: 0.5rem;
  border-radius: var(--radius-md);
  width: 36px;
  height: 36px;
}

.btn-icon.btn-sm { width: 30px; height: 30px; padding: 0.3rem; }
.btn-icon.btn-lg { width: 44px; height: 44px; padding: 0.625rem; }

/* ── Loading state ────────────────────────────────────────────── */
.btn.loading {
  position: relative;
  pointer-events: none;
  color: transparent;
}

.btn.loading::after {
  content: '';
  position: absolute;
  width: 16px; height: 16px;
  border: 2px solid rgba(255,255,255,0.3);
  border-top-color: #fff;
  border-radius: 50%;
  animation: spin 0.7s linear infinite;
}

.btn-outline.loading::after,
.btn-ghost.loading::after,
.btn-light.loading::after {
  border-color: rgba(0,0,0,0.15);
  border-top-color: var(--clr-primary);
}

/* ── Grupo de botões ──────────────────────────────────────────── */
.btn-group {
  display: inline-flex;
  gap: 0;
}

.btn-group .btn { border-radius: 0; }
.btn-group .btn:first-child { border-radius: var(--radius-md) 0 0 var(--radius-md); }
.btn-group .btn:last-child  { border-radius: 0 var(--radius-md) var(--radius-md) 0; }
.btn-group .btn + .btn      { margin-left: -1.5px; }
