.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  min-height: 40px;
  padding: 10px 20px;
  border: 1px solid transparent;
  border-radius: var(--radius-md);
  font-size: var(--text-body);
  font-weight: 600;
  line-height: 1;
  transition: background var(--transition-base), border-color var(--transition-base), color var(--transition-base), box-shadow var(--transition-base), transform var(--transition-base);
}

.btn--primary {
  background: var(--gradient-cta-shine);
  color: var(--text-on-brand);
  box-shadow: var(--shadow-cta);
}

.btn--primary:hover {
  color: var(--text-on-brand);
  box-shadow: 0 6px 16px rgba(10, 37, 64, 0.35);
  transform: translateY(-1px);
}

.btn--primary:active {
  transform: translateY(0);
}

.btn--primary:focus-visible {
  outline: none;
  box-shadow: var(--shadow-cta), var(--shadow-focus);
}

.btn--secondary {
  border-color: var(--border-strong);
  border-width: 1.5px;
  background: var(--bg-surface);
  color: var(--brand-navy-700);
}

.btn--secondary:hover {
  border-color: var(--brand-navy-700);
  background: var(--brand-navy-50);
  color: var(--brand-navy-700);
}

.btn--ghost {
  background: transparent;
  color: var(--text-tertiary);
  font-weight: 500;
}

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

.btn--danger {
  background: var(--color-danger-500);
  color: var(--text-on-brand);
}

.btn--danger:hover {
  background: var(--color-danger-700);
  color: var(--text-on-brand);
}

.btn--sm {
  min-height: 34px;
  padding: 8px 14px;
  font-size: var(--text-caption);
}

.btn--lg {
  min-height: 48px;
  padding: 14px 28px;
  font-size: var(--text-body-lg);
}

.btn--disabled,
.btn:disabled {
  border-color: var(--gray-300);
  background: var(--gray-300);
  color: var(--gray-500);
  pointer-events: none;
}

.btn__icon {
  display: inline-flex;
  font-size: var(--icon-sm);
  line-height: 1;
}

.icon-btn {
  display: inline-grid;
  width: 40px;
  height: 40px;
  place-items: center;
  border-radius: var(--radius-md);
  color: var(--text-tertiary);
  transition: background var(--transition-fast), color var(--transition-fast);
}

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

.icon-btn--sm {
  width: 32px;
  height: 32px;
}
