/* ============================================================
   Button — shared button styles
   ============================================================ */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-6);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  line-height: 1;
  border-radius: var(--radius-full);
  border: none;
  cursor: pointer;
  transition:
    background-color var(--duration-fast) var(--ease-out),
    transform var(--duration-fast) var(--ease-spring),
    box-shadow var(--duration-fast) var(--ease-out);
  -webkit-tap-highlight-color: transparent;
  user-select: none;
}

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

/* Primary — gold brand */
.btn--primary {
  background-color: var(--brand-gold);
  color: var(--color-navy-900);
}

.btn--primary:hover {
  box-shadow: var(--shadow-md);
}

/* Secondary — outlined */
.btn--secondary {
  background-color: transparent;
  color: var(--text-primary);
  border: 1px solid var(--border-default);
}

.btn--secondary:hover {
  background-color: var(--surface-secondary);
}

/* Ghost — no border, subtle */
.btn--ghost {
  background-color: transparent;
  color: var(--text-secondary);
}

.btn--ghost:hover {
  color: var(--text-primary);
  background-color: var(--surface-secondary);
}

/* Icon-only button */
.btn--icon {
  padding: var(--space-2);
  border-radius: var(--radius-lg);
  background: none;
  color: var(--text-secondary);
}

.btn--icon:hover {
  color: var(--text-primary);
  background-color: var(--surface-secondary);
}

/* Small variant */
.btn--sm {
  padding: var(--space-2) var(--space-4);
  font-size: var(--text-xs);
}

/* Full width */
.btn--block {
  width: 100%;
}

/* Disabled */
.btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none;
}
