/* Buttons */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  border-radius: var(--radius-pill);
  padding: 0.85rem 1.75rem;
  font-weight: 600;
  font-size: var(--text-base);
  line-height: 1.2;
  min-height: 44px;
  min-width: 44px;
  border: 1px solid transparent;
  transition: background var(--transition-fast), color var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast);
  position: relative;
}

.btn .btn-subtext {
  display: block;
  font-size: max(0.75rem, var(--text-xs));
  opacity: 0.8;
  font-weight: 500;
}

.btn:hover {
  transform: translateY(-1px);
}

.btn--primary {
  background: var(--primary-600);
  color: var(--on-primary);
  box-shadow: var(--shadow-sm);
}

.btn--primary:hover {
  background: var(--primary-700);
  color: var(--on-primary);
  box-shadow: var(--shadow-md);
}

.btn--primary:active {
  background: var(--primary-800);
  color: var(--on-primary);
  transform: translateY(1px);
}

.btn--secondary {
  background: var(--primary-50);
  color: var(--primary-600);
  border-color: var(--primary-200);
}

.btn--secondary:hover {
  background: var(--primary-100);
  color: var(--primary-700);
  border-color: var(--primary-300);
}

.btn--secondary:active {
  background: var(--primary-200);
  color: var(--primary-800);
  transform: translateY(1px);
}

.btn--ghost {
  background: transparent;
  color: var(--primary-600);
  border-color: var(--primary-300);
}

.btn--ghost:hover {
  background: var(--primary-50);
  color: var(--primary-700);
  border-color: var(--primary-400);
}

.btn--ghost:active {
  background: var(--primary-100);
  color: var(--primary-800);
  transform: translateY(1px);
}

.btn--large {
  padding: 1rem 2.25rem;
  font-size: var(--text-lg);
}

.btn--small {
  padding: 0.45rem 1rem;
  font-size: var(--text-sm);
}
