/* onboard · hellojade wizard
   Token-only stylesheet. Every value resolves through a CSS custom property
   declared in /static/design/theme/_global.css or
   /static/design/theme/hellojade/tokens.{light,dark}.css. */

:root {
  --radius: var(--radius-md);
  --motion-dur: var(--motion-dur-base);
  --motion-ease: var(--motion-ease-standard);
  --type-display: "Inter Tight", system-ui, sans-serif;
  --type-body:    "Inter Tight", system-ui, sans-serif;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  background: var(--color-bg);
  color: var(--color-fg);
  font-family: var(--type-body);
  font-size: var(--type-scale-md);
  line-height: var(--line-height-normal);
  min-height: 100%;
}

body {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

a { color: var(--color-primary); }
a:hover { color: var(--color-primary-hover); }

/* -------------------------------------------------------------- Shell */

wizard-shell {
  display: block;
  flex: 1;
}

.wz-wrap {
  display: grid;
  grid-template-columns: 1fr;
  max-width: 720px;
  margin: 0 auto;
  padding: var(--space-7) var(--space-5);
  gap: var(--space-7);
}

.wz-header {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  justify-content: space-between;
}

.wz-brand {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-weight: var(--font-weight-semibold);
  font-size: var(--type-scale-lg);
  letter-spacing: var(--letter-tight);
  color: var(--color-fg);
}
.wz-brand img { display: block; width: 28px; height: 28px; }

.wz-progress-wrap {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.wz-progress {
  appearance: none;
  width: 100%;
  height: 6px;
  border: none;
  background: var(--color-surface-hover);
  border-radius: var(--radius-pill);
  overflow: hidden;
}
.wz-progress::-webkit-progress-bar {
  background: var(--color-surface-hover);
  border-radius: var(--radius-pill);
}
.wz-progress::-webkit-progress-value {
  background: var(--color-primary);
  border-radius: var(--radius-pill);
  transition: width var(--motion-dur-slow) var(--motion-ease);
}
.wz-progress::-moz-progress-bar {
  background: var(--color-primary);
}

.wz-step-label {
  font-size: var(--type-scale-xs);
  letter-spacing: var(--letter-wider);
  text-transform: uppercase;
  font-weight: var(--font-weight-semibold);
  color: var(--color-fg-subtle);
}

/* -------------------------------------------------------------- Card */

.wz-card {
  background: var(--color-surface);
  border: var(--border-1) solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-7) var(--space-6) var(--space-5);
  box-shadow: var(--shadow-md);
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  min-height: 360px;
}

.wz-question-prompt {
  font-family: var(--type-display);
  font-size: var(--type-scale-2xl);
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--letter-tight);
  line-height: var(--line-height-snug);
  color: var(--color-fg);
  margin: 0;
}

.wz-question-doc {
  color: var(--color-fg-muted);
  font-size: var(--type-scale-md);
  line-height: var(--line-height-normal);
  margin: 0;
}

.wz-question {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.wz-required-dot {
  color: var(--color-accent);
  margin-left: var(--space-1);
}

/* -------------------------------------------------------------- Buttons */

.wz-actions {
  display: flex;
  justify-content: space-between;
  gap: var(--space-3);
  margin-top: auto;
  padding-top: var(--space-4);
  border-top: var(--border-1) solid var(--color-border);
}

.wz-btn {
  font-family: var(--type-body);
  font-size: var(--type-scale-md);
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--letter-tight);
  padding: var(--space-3) var(--space-5);
  border-radius: var(--radius-md);
  border: var(--border-1) solid transparent;
  cursor: pointer;
  transition:
    background var(--motion-dur) var(--motion-ease),
    border-color var(--motion-dur) var(--motion-ease),
    color var(--motion-dur) var(--motion-ease),
    transform var(--motion-dur-fast) var(--motion-ease);
}
.wz-btn:active { transform: translateY(1px); }
.wz-btn:focus-visible {
  outline: var(--border-3) solid color-mix(in srgb, var(--color-focus-ring) 30%, transparent);
  outline-offset: 2px;
}

.wz-btn-primary {
  background: var(--color-primary);
  color: var(--color-primary-fg);
}
.wz-btn-primary:hover { background: var(--color-primary-hover); }
.wz-btn-primary:disabled {
  background: var(--color-fg-subtle);
  color: var(--color-surface);
  cursor: not-allowed;
}

.wz-btn-ghost {
  background: transparent;
  color: var(--color-fg-muted);
  border-color: var(--color-border);
}
.wz-btn-ghost:hover {
  background: var(--color-surface-hover);
  color: var(--color-fg);
}

/* -------------------------------------------------------------- Inputs */

.wz-question input[type="text"],
.wz-question input[type="email"],
.wz-question input[type="url"],
.wz-question input[type="tel"],
.wz-question input[type="number"],
.wz-question input[type="date"],
.wz-question input[type="time"],
.wz-question select,
.wz-question textarea {
  font-family: var(--type-body);
  font-size: var(--type-scale-md);
  color: var(--color-fg);
  background: var(--color-bg);
  border: var(--border-1) solid var(--color-border-strong);
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-3);
  width: 100%;
  outline: none;
  transition:
    border-color var(--motion-dur) var(--motion-ease),
    box-shadow   var(--motion-dur) var(--motion-ease);
}
.wz-question textarea { min-height: 96px; resize: vertical; }

.wz-question input:focus,
.wz-question select:focus,
.wz-question textarea:focus {
  border-color: var(--color-focus-ring);
  box-shadow: 0 0 0 var(--border-3)
    color-mix(in srgb, var(--color-focus-ring) 30%, transparent);
}

.wz-question input:user-invalid,
.wz-question select:user-invalid,
.wz-question textarea:user-invalid {
  border-color: var(--color-danger);
}

.wz-helper {
  font-size: var(--type-scale-xs);
  color: var(--color-fg-subtle);
}
.wz-helper-error {
  color: var(--color-danger);
  font-weight: var(--font-weight-medium);
}

/* Chips for multi-value lists. */
.wz-chips {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  padding: var(--space-2) 0 0;
}
.wz-chip {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-1) var(--space-2);
  border: var(--border-1) solid var(--color-border-strong);
  background: var(--color-surface-hover);
  border-radius: var(--radius-pill);
  font-size: var(--type-scale-xs);
}
.wz-chip button {
  appearance: none;
  border: none;
  background: transparent;
  color: var(--color-fg-muted);
  cursor: pointer;
  font-size: var(--type-scale-md);
  line-height: 1;
}

/* Pill-style radio/checkbox groups. */
.wz-options {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}
.wz-option {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  border: var(--border-1) solid var(--color-border-strong);
  border-radius: var(--radius-pill);
  cursor: pointer;
  transition: all var(--motion-dur) var(--motion-ease);
  font-size: var(--type-scale-sm);
  background: var(--color-bg);
}
.wz-option:hover {
  border-color: var(--color-fg-muted);
}
.wz-option input { position: absolute; opacity: 0; pointer-events: none; }
.wz-option:has(input:checked) {
  border-color: var(--color-primary);
  color: var(--color-primary);
  background: color-mix(in srgb, var(--color-primary) 8%, var(--color-bg));
}

/* -------------------------------------------------------------- Done */

.wz-done {
  text-align: center;
}
.wz-done h1 {
  font-family: var(--type-display);
  letter-spacing: var(--letter-tight);
}
.wz-done pre {
  text-align: left;
  background: var(--color-surface-hover);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  font-size: var(--type-scale-xs);
  max-height: 320px;
  overflow: auto;
}

/* -------------------------------------------------------------- View transitions */

@media (prefers-reduced-motion: no-preference) {
  ::view-transition-old(wizard-card),
  ::view-transition-new(wizard-card) {
    animation-duration: var(--motion-dur-slow);
    animation-timing-function: var(--motion-ease);
  }
  .wz-card { view-transition-name: wizard-card; }
}

/* Small screens — collapse padding. */
@container (max-width: 480px) {
  .wz-wrap { padding: var(--space-4); gap: var(--space-4); }
  .wz-card { padding: var(--space-5) var(--space-4); }
}
