/* Controls — buttons/inputs read theme radius + density tokens. */

.btn {
  --btn-bg: var(--surface-2);
  --btn-fg: var(--ink-high);
  --btn-br: var(--line-mid);
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  padding: calc(0.75rem * var(--theme-density)) calc(1.25rem * var(--theme-density));
  font-family: var(--ff-theme-body);
  font-size: var(--fs-sm);
  font-weight: 580;
  letter-spacing: 0.01em;
  color: var(--btn-fg);
  background: var(--btn-bg);
  border: var(--theme-border-width) solid var(--btn-br);
  border-radius: var(--theme-radius-btn);
  cursor: pointer;
  user-select: none;
  white-space: nowrap;
  transition: transform var(--dur-snap) var(--ease-spring),
              box-shadow var(--dur-fast) var(--ease-out-soft),
              background var(--dur-fast) var(--ease-out-soft),
              border-color var(--dur-fast) var(--ease-out-soft),
              border-radius var(--dur-base) var(--ease-out-soft),
              color var(--dur-fast) var(--ease-out-soft);
  will-change: transform;
}
.btn:hover { transform: translateY(-1px); box-shadow: var(--shadow-md); }
.btn:active { transform: translateY(0); box-shadow: var(--shadow-sm); }
.btn[disabled], .btn[aria-disabled="true"] { opacity: 0.5; cursor: not-allowed; transform: none; box-shadow: none; }
.btn > i, .btn > svg { width: 16px; height: 16px; flex-shrink: 0; }

.btn--primary {
  --btn-bg: var(--color-primary);
  --btn-fg: var(--surface-void);
  --btn-br: transparent;
  font-weight: 660;
  box-shadow: var(--shadow-md), inset 0 1px 0 rgba(255,255,255,0.22);
}
.btn--primary:hover { box-shadow: var(--shadow-lift), inset 0 1px 0 rgba(255,255,255,0.28); }

.btn--accent {
  --btn-bg: var(--color-accent);
  --btn-fg: var(--surface-void);
  --btn-br: transparent;
  font-weight: 660;
}

.btn--ghost { --btn-bg: transparent; --btn-br: var(--line-mid); }
.btn--ghost:hover { --btn-bg: var(--surface-2); --btn-br: var(--line-strong); }

.btn--quiet { --btn-bg: transparent; --btn-br: transparent; color: var(--ink-mid); }
.btn--quiet:hover { color: var(--ink-high); --btn-bg: var(--surface-2); }

.btn--outline { --btn-bg: transparent; --btn-br: var(--color-primary); color: var(--color-primary); }
.btn--outline:hover { --btn-bg: color-mix(in oklab, var(--color-primary) 10%, transparent); }

.btn--danger { --btn-bg: var(--brand-rose); --btn-fg: #fff; --btn-br: transparent; }

.btn--icon {
  width: 40px; height: 40px; padding: 0;
  border-radius: var(--theme-radius-btn);
}
.btn--sm { padding: calc(0.45rem * var(--theme-density)) calc(0.9rem * var(--theme-density)); font-size: var(--fs-xs); }
.btn--lg { padding: calc(0.95rem * var(--theme-density)) calc(1.75rem * var(--theme-density)); font-size: var(--fs-md); }
.btn--block { display: flex; width: 100%; }

.btn-row { display: inline-flex; flex-wrap: wrap; gap: var(--sp-3); }

/* Form fields */
.field { display: flex; flex-direction: column; gap: var(--sp-2); }
.field > label,
.field__label {
  font-size: var(--fs-2xs);
  font-family: var(--ff-theme-mono);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-low);
  font-weight: 500;
}
.field__hint  { font-size: var(--fs-xs); color: var(--ink-low); margin-top: var(--sp-1); }
.field__error { font-size: var(--fs-xs); color: var(--brand-rose); margin-top: var(--sp-1); }

.input, .textarea, .select {
  width: 100%;
  padding: calc(0.75rem * var(--theme-density)) calc(1rem * var(--theme-density));
  font-family: var(--ff-theme-body);
  font-size: var(--fs-md);
  color: var(--ink-high);
  background: var(--surface-inset);
  border: var(--theme-border-width) solid var(--line-mid);
  border-radius: var(--theme-radius-input);
  box-shadow: var(--shadow-inner);
  transition: border-color var(--dur-fast) var(--ease-out-soft),
              box-shadow var(--dur-fast) var(--ease-out-soft),
              background var(--dur-fast) var(--ease-out-soft),
              border-radius var(--dur-base) var(--ease-out-soft);
}
.input::placeholder, .textarea::placeholder { color: var(--ink-whisper); }
.input:hover, .textarea:hover, .select:hover { border-color: var(--line-strong); }
.input:focus, .textarea:focus, .select:focus {
  outline: 0;
  border-color: color-mix(in oklab, var(--color-primary) 60%, var(--line-strong));
  box-shadow: var(--shadow-inner), var(--focus-ring);
  background: var(--surface-2);
}
.textarea { min-height: 120px; resize: vertical; line-height: var(--lh-body); }

.select {
  appearance: none;
  background-image: linear-gradient(45deg, transparent 50%, var(--ink-low) 50%),
                    linear-gradient(135deg, var(--ink-low) 50%, transparent 50%);
  background-position: calc(100% - 18px) 50%, calc(100% - 13px) 50%;
  background-size: 5px 5px, 5px 5px;
  background-repeat: no-repeat;
  padding-right: 2.5rem;
}

.switch {
  --switch-w: 44px; --switch-h: 24px;
  position: relative;
  display: inline-flex; align-items: center;
  width: var(--switch-w); height: var(--switch-h);
  background: var(--surface-inset);
  border: var(--theme-border-width) solid var(--line-mid);
  border-radius: var(--theme-radius-pill);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out-soft), border-color var(--dur-fast) var(--ease-out-soft);
}
.switch::after {
  content: "";
  position: absolute;
  left: 2px; top: 50%;
  width: calc(var(--switch-h) - 6px);
  height: calc(var(--switch-h) - 6px);
  border-radius: 50%;
  background: var(--ink-high);
  box-shadow: var(--shadow-sm);
  transform: translateY(-50%);
  transition: left var(--dur-base) var(--ease-spring), background var(--dur-fast) var(--ease-out-soft);
}
.switch[aria-pressed="true"] { background: var(--color-primary); border-color: transparent; }
.switch[aria-pressed="true"]::after { left: calc(100% - var(--switch-h) + 2px); background: var(--surface-void); }

/* Modal */
.modal {
  position: fixed; inset: 0;
  display: grid; place-items: center;
  padding: var(--sp-5);
  z-index: var(--z-modal);
  background: color-mix(in oklab, var(--surface-void) 60%, transparent);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  animation: fade-in var(--dur-base) var(--ease-out-soft);
}
.modal[hidden] { display: none; }
.modal__panel {
  width: 100%;
  max-width: 560px;
  background: var(--surface-1);
  border: var(--theme-border-width) solid var(--line-mid);
  border-radius: var(--theme-radius-card);
  padding: var(--sp-7);
  box-shadow: var(--shadow-dialog), var(--shadow-inner);
  animation: modal-rise var(--dur-base) var(--ease-out-expo);
}
@keyframes modal-rise {
  from { opacity: 0; transform: translateY(16px) scale(0.98); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* Contact modal (lead funnel) — JS-driven via .active toggle */
.modal-overlay {
  display: none;
  position: fixed; inset: 0;
  z-index: var(--z-modal);
  background: color-mix(in oklab, var(--surface-void) 70%, transparent);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  padding: var(--sp-5);
  overflow-y: auto;
}
.modal-overlay.active {
  display: grid;
  place-items: center;
  animation: fade-in var(--dur-base) var(--ease-out-soft);
}
.modal-container {
  position: relative;
  width: 100%;
  max-width: 560px;
  background: var(--surface-1);
  border: var(--theme-border-width) solid var(--line-mid);
  border-radius: var(--theme-radius-card);
  padding: var(--sp-7);
  box-shadow: var(--shadow-dialog), var(--shadow-inner);
  animation: modal-rise var(--dur-base) var(--ease-out-expo);
}
.modal-close {
  position: absolute;
  top: var(--sp-3);
  right: var(--sp-4);
  background: transparent;
  border: 0;
  font-size: 28px;
  line-height: 1;
  color: var(--ink-mid);
  cursor: pointer;
  padding: var(--sp-1) var(--sp-2);
  border-radius: var(--theme-radius-control);
  transition: background var(--dur-fast) var(--ease-out-soft), color var(--dur-fast) var(--ease-out-soft);
}
.modal-close:hover { background: var(--surface-2); color: var(--ink-high); }
.modal-header { margin-bottom: var(--sp-5); }
.modal-header h2 { margin: 0 0 var(--sp-1); font-size: var(--fs-xl); color: var(--ink-high); }
.modal-header p { margin: 0; color: var(--ink-mid); font-size: var(--fs-sm); }
.modal-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-4);
}
@media (max-width: 480px) { .modal-row { grid-template-columns: 1fr; } }
.modal-field { display: flex; flex-direction: column; gap: var(--sp-2); margin-bottom: var(--sp-4); }
.modal-field label { font-size: var(--fs-sm); font-weight: 500; color: var(--ink-high); }
.modal-field input,
.modal-field textarea {
  width: 100%;
  padding: var(--sp-3) var(--sp-4);
  background: var(--surface-2);
  border: var(--theme-border-width) solid var(--line-mid);
  border-radius: var(--theme-radius-control);
  color: var(--ink-high);
  font: inherit;
  transition: border-color var(--dur-fast) var(--ease-out-soft), box-shadow var(--dur-fast) var(--ease-out-soft);
}
.modal-field input:focus,
.modal-field textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--color-primary) 25%, transparent);
}
.modal-field textarea { resize: vertical; min-height: 80px; }
.modal-field input.invalid,
.modal-field textarea.invalid { border-color: var(--color-danger, #ef4444); }
.field-error {
  font-size: var(--fs-xs);
  color: var(--color-danger, #ef4444);
  min-height: 1em;
}
.modal-submit {
  width: 100%;
  padding: var(--sp-4);
  background: var(--color-primary);
  color: var(--surface-void);
  border: 0;
  border-radius: var(--theme-radius-control);
  font: inherit;
  font-weight: 600;
  cursor: pointer;
  transition: opacity var(--dur-fast) var(--ease-out-soft), transform var(--dur-fast) var(--ease-out-soft);
}
.modal-submit:hover:not(:disabled) { opacity: 0.9; }
.modal-submit:active:not(:disabled) { transform: scale(0.98); }
.modal-submit:disabled { opacity: 0.6; cursor: not-allowed; }
.modal-success {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-4);
  background: color-mix(in oklab, #22c55e 12%, var(--surface-2));
  border: var(--theme-border-width) solid color-mix(in oklab, #22c55e 35%, var(--line-mid));
  border-radius: var(--theme-radius-control);
  color: var(--ink-high);
}
.modal-success p { margin: 0; }
.modal-error {
  margin-top: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  background: color-mix(in oklab, var(--color-danger, #ef4444) 12%, var(--surface-2));
  border: var(--theme-border-width) solid color-mix(in oklab, var(--color-danger, #ef4444) 35%, var(--line-mid));
  border-radius: var(--theme-radius-control);
  color: var(--ink-high);
  font-size: var(--fs-sm);
}

/* Toast stack */
.toast-stack {
  position: fixed;
  top: calc(env(safe-area-inset-top) + var(--sp-5));
  right: var(--sp-5);
  display: flex; flex-direction: column; gap: var(--sp-3);
  z-index: var(--z-toast);
  max-width: 420px;
  pointer-events: none;
}
.toast {
  background: var(--surface-2);
  border: var(--theme-border-width) solid var(--line-mid);
  border-radius: var(--theme-radius-card);
  padding: var(--sp-4) var(--sp-5);
  box-shadow: var(--shadow-lift), var(--shadow-inner);
  pointer-events: auto;
  animation: toast-in var(--dur-base) var(--ease-out-expo) both;
  display: flex; align-items: flex-start; gap: var(--sp-3);
  font-size: var(--fs-sm);
  color: var(--ink-high);
}
.toast > i { width: 18px; height: 18px; flex-shrink: 0; margin-top: 2px; color: var(--color-primary); }
.toast--success { border-color: color-mix(in oklab, var(--brand-leaf) 35%, var(--line-mid)); }
.toast--success > i { color: var(--brand-leaf); }
.toast--warn    { border-color: color-mix(in oklab, var(--brand-amber) 35%, var(--line-mid)); }
.toast--warn > i { color: var(--brand-amber); }
.toast--danger  { border-color: color-mix(in oklab, var(--brand-rose) 35%, var(--line-mid)); }
.toast--danger > i { color: var(--brand-rose); }
@keyframes toast-in  { from { opacity: 0; transform: translateX(20px) scale(0.97); } to { opacity: 1; transform: translateX(0) scale(1); } }
@keyframes toast-out { to { opacity: 0; transform: translateX(20px) scale(0.97); } }
.toast--leaving { animation: toast-out var(--dur-fast) var(--ease-in-out) forwards; }
