/* vessel-quiz-engine — quiz styles
 *
 * Restrained editorial. thevessel.io palette: cream/parchment background,
 * dark ink text, single warm-gold accent. No photo backgrounds, no chat
 * bubbles, no fancy cards. Mirror DM Diagnostic's mechanical restraint with
 * a Vessel palette swap.
 *
 * Type: Cormorant Garamond for headings + emphasis, Roboto for body.
 */

/* === Quiz landing === */

.quiz-landing {
  max-width: 38rem;
  margin: 0 auto;
  padding: 8rem 1.5rem 6rem;
  text-align: center;
}
.quiz-landing__eyebrow {
  display: inline-block;
  font-size: 12px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--vessel-gold-deep);
  margin-bottom: 2rem;
  font-weight: 600;
}
.quiz-landing__title {
  font-family: var(--vessel-serif);
  font-weight: 500;
  font-size: clamp(2.6rem, 6vw, 4.2rem);
  line-height: 1.05;
  letter-spacing: -0.015em;
  margin: 0 0 1.5rem;
  color: var(--vessel-ink);
}
.quiz-landing__lede {
  font-family: var(--vessel-serif);
  font-style: italic;
  font-size: clamp(1.3rem, 2.4vw, 1.55rem);
  line-height: 1.5;
  color: var(--vessel-ink-soft);
  margin: 0 0 3rem;
}
.quiz-landing__meta {
  font-size: 13px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--vessel-ink-mute);
  margin: 0 0 3rem;
}
.quiz-landing__meta-dot { margin: 0 0.7rem; color: var(--vessel-gold); }
.quiz-landing__cta {
  display: inline-block;
  background: var(--vessel-gold);
  color: var(--vessel-midnight);
  padding: 1.05rem 3.25rem;
  border: 0;
  font-weight: 500;
  letter-spacing: 0.06em;
  font-size: 15px;
  text-transform: uppercase;
  transition: background 200ms ease;
  cursor: pointer;
}
.quiz-landing__cta:hover {
  background: var(--vessel-gold-deep);
  color: var(--vessel-midnight);
}
.quiz-landing__quiet {
  font-size: 13px;
  color: var(--vessel-ink-mute);
  font-style: italic;
  font-family: var(--vessel-serif);
  margin: 1.5rem 0 0;
}

/* === Quiz SPA layout === */

.quiz-body {
  margin: 0;
  background: var(--vessel-bg);
  min-height: 100vh;
  color: var(--vessel-ink);
}
.quiz-mini-header {
  position: sticky;
  top: 0;
  z-index: 5;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 64px;
  padding: 0 1.5rem;
  background: rgba(14, 12, 10, 0.88);
  backdrop-filter: saturate(140%) blur(8px);
  border-bottom: 1px solid var(--vessel-line);
}
.quiz-mini-header__brand img {
  display: block;
  height: 16px;
  width: auto;
}
.quiz-mini-header__exit {
  font-size: 13px;
  color: var(--vessel-ink-mute);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.quiz-mini-header__exit:hover { color: var(--vessel-ink); }

.quiz-progress {
  display: flex;
  gap: 0.7rem;
  font-size: 18px;
  color: var(--vessel-ink-mute);
  user-select: none;
  font-family: var(--vessel-serif);
}
.quiz-progress__phase { transition: color 600ms ease; opacity: 0.45; }
.quiz-progress__phase.is-active { color: var(--vessel-gold); opacity: 1; }

.quiz-stage {
  min-height: calc(100vh - 64px);
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 4.5rem 1.5rem 5rem;
}
/* Centered states (arrival, interlude, settling, analyzing, error) get vertical centering */
.quiz-card.quiz-arrival,
.quiz-card.quiz-interlude,
.quiz-card.quiz-settling,
.quiz-card.quiz-analyzing,
.quiz-card.quiz-error { align-self: center; }

.quiz-card {
  width: 100%;
  max-width: 44rem;
  text-align: left;
  padding: 2rem 1.75rem 2.25rem;
  background: var(--vessel-bg-soft);
  border: 1px solid var(--vessel-line);
  border-radius: 8px;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 380ms ease, transform 380ms ease;
}
@media (min-width: 720px) {
  .quiz-card { padding: 3rem 3rem 3.25rem; }
}
.quiz-card.quiz-arrival,
.quiz-card.quiz-interlude,
.quiz-card.quiz-settling,
.quiz-card.quiz-analyzing,
.quiz-card.quiz-error {
  background: transparent;
  border: 0;
  text-align: center;
}
.quiz-card.is-entering { opacity: 1; transform: translateY(0); }

.quiz-eyebrow {
  display: block;
  font-size: 12px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--vessel-gold-deep);
  margin-bottom: 1.5rem;
  font-weight: 700;
}

/* Cybershaman setup line above each question. Pulled from questions.json's
   shamanIntro field. Sits between the section eyebrow and the question
   text — softens the cold open. */
.quiz-shaman-intro {
  font-family: var(--vessel-serif);
  font-style: italic;
  font-size: 1.18rem;
  line-height: 1.55;
  color: var(--vessel-ink-soft);
  margin: 0 0 1.5rem;
  max-width: 34rem;
}

.quiz-question {
  font-family: var(--vessel-serif);
  font-weight: 500;
  font-size: clamp(1.85rem, 3.6vw, 2.4rem);
  line-height: 1.15;
  letter-spacing: -0.01em;
  color: var(--vessel-ink);
  margin: 0 0 1.25rem;
  max-width: 34rem;
}
.quiz-subtext {
  font-family: var(--vessel-serif);
  font-style: italic;
  font-size: 1.05rem;
  line-height: 1.5;
  color: var(--vessel-ink-soft);
  margin: 0 0 2.75rem;
  max-width: 32rem;
}

/* === Options === */

.quiz-options {
  display: grid;
  gap: 0.65rem;
  margin-top: 2.25rem;
}
.quiz-option {
  display: block;
  width: 100%;
  background: var(--vessel-bg-card);
  border: 1px solid var(--vessel-line);
  border-radius: 3px;
  padding: 1.25rem 1.5rem;
  font-family: var(--vessel-sans);
  font-size: 17px;
  line-height: 1.45;
  color: var(--vessel-ink);
  cursor: pointer;
  text-align: left;
  transition: border-color 160ms ease, background 160ms ease, color 160ms ease, transform 160ms ease;
}
.quiz-option:hover, .quiz-option:focus-visible {
  border-color: var(--vessel-gold-deep);
  background: rgba(236, 228, 213, 0.06);
  outline: none;
  transform: translateX(2px);
}
.quiz-option.is-selected {
  border-color: var(--vessel-gold);
  background: rgba(201, 168, 106, 0.12);
  color: var(--vessel-ink);
  transform: translateX(2px);
}

/* === Image-tile options (involve.me-style) === */
.quiz-options--tiles {
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  margin-top: 0;
}
.quiz-option--tile {
  padding: 0;
  text-align: left;
  overflow: hidden;
  background: var(--vessel-bg-card);
  border: 1px solid var(--vessel-line);
  border-radius: 6px;
  display: flex;
  flex-direction: column;
  transition: border-color 160ms ease, transform 200ms ease, box-shadow 200ms ease, background 160ms ease, color 160ms ease;
  box-shadow: 0 1px 2px rgba(26, 22, 16, 0.04);
}
.quiz-option--tile:hover,
.quiz-option--tile:focus-visible {
  transform: translateY(-2px);
  border-color: var(--vessel-gold-deep);
  box-shadow: 0 8px 24px rgba(26, 22, 16, 0.10);
  background: var(--vessel-bg-card);
  outline: none;
}
.quiz-option--tile.is-selected {
  border-color: var(--vessel-gold);
  background: rgba(201, 168, 106, 0.12);
  color: var(--vessel-ink);
  transform: translateY(-2px);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.45), 0 0 0 1px rgba(201, 168, 106, 0.35);
}
.quiz-option--tile.is-selected .quiz-option__caption { color: var(--vessel-ink); }

.quiz-option__img {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  background: rgba(236, 228, 213, 0.06);
  filter: saturate(0.85) contrast(0.96);
  transition: filter 200ms ease;
}
.quiz-option--tile:hover .quiz-option__img,
.quiz-option--tile:focus-visible .quiz-option__img { filter: saturate(1.05) contrast(1); }
.quiz-option--tile.is-selected .quiz-option__img { filter: saturate(0.65) brightness(0.85); }

.quiz-option__caption {
  display: block;
  padding: 1.1rem 1.4rem 1.25rem;
  font-family: var(--vessel-sans);
  font-size: 16px;
  line-height: 1.45;
  font-weight: 400;
  color: var(--vessel-ink);
}

@media (max-width: 640px) {
  .quiz-options--tiles { grid-template-columns: 1fr; gap: 1rem; }
  .quiz-option__img { aspect-ratio: 16 / 9; }
  .quiz-option__caption { padding: 1rem 1.25rem 1.1rem; font-size: 15px; }
  .quiz-question { font-size: 1.7rem; }
  .quiz-subtext { font-size: 1rem; margin-bottom: 2rem; }
  .quiz-stage { padding: 3rem 1.25rem 4rem; }
}

/* === Open text === */

.quiz-textarea-wrap { margin-top: 2rem; }
.quiz-textarea {
  width: 100%;
  min-height: 180px;
  border: 1px solid var(--vessel-line);
  border-radius: 4px;
  background: var(--vessel-bg-card);
  padding: 1.15rem 1.25rem;
  font-family: var(--vessel-serif);
  font-size: 1.2rem;
  line-height: 1.55;
  color: var(--vessel-ink);
  resize: vertical;
  transition: border-color 180ms ease;
}
.quiz-textarea:focus {
  outline: none;
  border-color: var(--vessel-gold);
}
.quiz-textarea::placeholder {
  color: var(--vessel-ink-mute);
  font-style: italic;
}
.quiz-skip-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 1rem;
  font-size: 13px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--vessel-ink-mute);
}
.quiz-skip-link {
  background: none;
  border: 0;
  cursor: pointer;
  color: var(--vessel-ink-mute);
  font-size: 13px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-decoration: underline;
  font-family: var(--vessel-sans);
  padding: 0;
}
.quiz-skip-link:hover { color: var(--vessel-ink); }

.quiz-cta-row {
  display: flex;
  justify-content: flex-end;
  margin-top: 1.5rem;
}
.quiz-cta {
  background: var(--vessel-gold);
  color: var(--vessel-midnight);
  padding: 0.9rem 2.5rem;
  border: 0;
  border-radius: 4px;
  font-weight: 500;
  font-size: 14px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 180ms ease;
  font-family: var(--vessel-sans);
}
.quiz-cta:hover { background: var(--vessel-gold-deep); }
.quiz-cta:disabled {
  background: var(--vessel-line);
  color: var(--vessel-ink-mute);
  cursor: not-allowed;
}

/* === Arrival === */

.quiz-arrival { text-align: center; max-width: 32rem; }
.quiz-arrival__title {
  font-family: var(--vessel-serif);
  font-weight: 500;
  font-size: clamp(2.2rem, 5vw, 3rem);
  line-height: 1.15;
  letter-spacing: -0.01em;
  color: var(--vessel-ink);
  margin: 0 0 0.75rem;
}
.quiz-arrival__sub {
  font-family: var(--vessel-serif);
  font-style: italic;
  font-size: 1.15rem;
  line-height: 1.5;
  color: var(--vessel-ink-soft);
  margin: 0 0 2rem;
}
.quiz-arrival__intro {
  font-family: var(--vessel-serif);
  font-size: 1.05rem;
  line-height: 1.55;
  color: var(--vessel-ink-soft);
  max-width: 28rem;
  margin: 0 auto 2.5rem;
}

/* === Section interlude === */

.quiz-interlude { text-align: center; max-width: 32rem; }
.quiz-interlude__line {
  font-family: var(--vessel-serif);
  font-style: italic;
  font-size: clamp(1.4rem, 3vw, 1.85rem);
  color: var(--vessel-ink-soft);
  margin: 0;
  line-height: 1.45;
}

/* === Settling === */

.quiz-settling { text-align: center; max-width: 30rem; }
.quiz-settling__line {
  font-family: var(--vessel-serif);
  font-style: italic;
  font-size: clamp(1.4rem, 3vw, 1.8rem);
  color: var(--vessel-ink);
  margin: 0 0 0.6rem;
  line-height: 1.4;
}
.quiz-settling__sub {
  font-family: var(--vessel-serif);
  font-size: 0.95rem;
  font-style: italic;
  color: var(--vessel-ink-mute);
  margin: 0 0 2rem;
}
.quiz-settling__pulse {
  width: 10px; height: 10px;
  border-radius: 50%;
  background: var(--vessel-gold);
  margin: 0 auto;
  animation: vessel-pulse 1.6s ease-in-out infinite;
}
@keyframes vessel-pulse {
  0%, 100% { transform: scale(0.85); opacity: 0.5; }
  50% { transform: scale(1.15); opacity: 1; }
}

/* === Analyzing-responses momentum stage === */

.quiz-analyzing { text-align: center; max-width: 34rem; }
.quiz-analyzing__eyebrow {
  display: block;
  font-family: var(--vessel-sans);
  text-transform: uppercase;
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  color: var(--vessel-gold);
  margin: 0 0 0.6rem;
}
.quiz-analyzing__line {
  font-family: var(--vessel-serif);
  font-style: italic;
  font-size: clamp(1.4rem, 3vw, 1.8rem);
  color: var(--vessel-ink);
  margin: 0 0 0.6rem;
  line-height: 1.4;
}
.quiz-analyzing__sub {
  font-family: var(--vessel-serif);
  font-size: 0.95rem;
  font-style: italic;
  color: var(--vessel-ink-mute);
  margin: 0 0 2rem;
}
.quiz-analyzing__pulse {
  width: 10px; height: 10px;
  border-radius: 50%;
  background: var(--vessel-gold);
  margin: 0 auto 2rem;
  animation: vessel-pulse 1.6s ease-in-out infinite;
}
.quiz-analyzing__steps {
  list-style: none;
  margin: 0 auto;
  padding: 0;
  text-align: left;
  max-width: 24rem;
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}
.quiz-analyzing__step {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  font-family: var(--vessel-sans);
  font-size: 0.94rem;
  color: var(--vessel-ink-mute);
  opacity: 0.45;
  transition: opacity 380ms ease, color 380ms ease;
}
.quiz-analyzing__step[data-state="done"] {
  opacity: 1;
  color: var(--vessel-ink);
}
.quiz-analyzing__check {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px; height: 18px;
  border-radius: 50%;
  border: 1.5px solid var(--vessel-line);
  background: transparent;
  flex: 0 0 18px;
  position: relative;
  transition: border-color 380ms ease, background 380ms ease;
}
.quiz-analyzing__step[data-state="done"] .quiz-analyzing__check {
  border-color: var(--vessel-gold);
  background: var(--vessel-gold);
}
.quiz-analyzing__step[data-state="done"] .quiz-analyzing__check::after {
  content: "";
  position: absolute;
  left: 5px; top: 2px;
  width: 4px; height: 8px;
  border-right: 1.8px solid var(--vessel-bg);
  border-bottom: 1.8px solid var(--vessel-bg);
  transform: rotate(45deg);
}

.quiz-error { text-align: center; max-width: 30rem; }
.quiz-error__line {
  font-family: var(--vessel-serif);
  font-size: 1.3rem;
  color: var(--vessel-ink);
  margin: 0 0 0.5rem;
}
.quiz-error__sub {
  color: var(--vessel-ink-soft);
  margin: 0 0 1.5rem;
}

/* === Result / offer === */

.result {
  max-width: 38rem;
  margin: 0 auto;
  padding: 4rem 1.5rem 4rem;
}
.result__eyebrow {
  display: block;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--vessel-gold-deep);
  margin-bottom: 1rem;
  font-weight: 600;
  text-align: center;
}
.result__hero {
  border-top: 1px solid var(--vessel-line);
  border-bottom: 1px solid var(--vessel-line);
  padding: 2.5rem 0;
  margin: 0 0 3.5rem;
}
.result__dispatch-body {
  font-family: var(--vessel-serif);
  font-size: clamp(1.2rem, 2.5vw, 1.4rem);
  font-style: italic;
  line-height: 1.6;
  color: var(--vessel-ink);
  margin: 0 0 1rem;
}
.result__dispatch-body:last-child { margin-bottom: 0; }
.result__dispatch-loading {
  text-align: center;
  padding: 1rem 0;
}
.result__dispatch-flame {
  width: 10px; height: 10px;
  border-radius: 50%;
  background: var(--vessel-gold);
  margin: 0 auto 1rem;
  animation: vessel-pulse 1.6s ease-in-out infinite;
}
.result__dispatch-loading-line {
  font-family: var(--vessel-serif);
  font-style: italic;
  color: var(--vessel-ink-soft);
  margin: 0;
}
.result__dispatch-error {
  font-family: var(--vessel-serif);
  font-style: italic;
  color: var(--vessel-ink-soft);
  margin: 0;
  text-align: center;
}
/* When the deepen-pre answer triggers a regen, ghost the dispatch out
   briefly to telegraph that it's being rewritten. */
.result__dispatch--rewriting {
  opacity: 0.45;
  transition: opacity 220ms ease;
  filter: blur(0.4px);
}

/* === Pre-paywall deepening block (single body-location question) === */
.result__deepen-pre {
  max-width: 36rem;
  margin: 0 auto 3.5rem;
  padding: 1.5rem 1.5rem 1.6rem;
  border: 1px solid var(--vessel-line);
  border-radius: 8px;
  background: var(--vessel-bg-soft);
  text-align: left;
}
.result__deepen-pre .result__eyebrow {
  margin: 0 0 0.6rem;
}
.result__deepen-pre-q {
  font-family: var(--vessel-serif);
  font-size: 1.3rem;
  line-height: 1.35;
  color: var(--vessel-ink);
  margin: 0 0 0.4rem;
  font-weight: 500;
}
.result__deepen-pre-sub {
  font-family: var(--vessel-serif);
  font-style: italic;
  font-size: 0.98rem;
  line-height: 1.5;
  color: var(--vessel-ink-mute);
  margin: 0 0 1rem;
}
.result__deepen-pre-form {
  display: flex;
  gap: 0.5rem;
  margin: 0 0 0.6rem;
}
.result__deepen-pre-input {
  flex: 1;
  min-width: 0;
  border: 1px solid var(--vessel-line);
  border-radius: 4px;
  background: var(--vessel-bg-card);
  padding: 0.85rem 1rem;
  font-family: var(--vessel-sans);
  font-size: 15px;
  color: var(--vessel-ink);
  transition: border-color 180ms ease;
}
.result__deepen-pre-input:focus {
  outline: none;
  border-color: var(--vessel-gold-deep);
}
.result__deepen-pre-input::placeholder {
  color: var(--vessel-ink-mute);
  font-style: italic;
}
.result__deepen-pre-btn {
  background: var(--vessel-gold);
  color: var(--vessel-midnight);
  border: 0;
  border-radius: 4px;
  padding: 0.85rem 1.25rem;
  font-family: var(--vessel-sans);
  font-weight: 500;
  font-size: 13px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 180ms ease;
  white-space: nowrap;
}
.result__deepen-pre-btn:hover { background: var(--vessel-gold-deep); }
.result__deepen-pre-btn:disabled {
  background: var(--vessel-ink-mute);
  cursor: not-allowed;
}
.result__deepen-pre-note {
  margin: 0;
  font-family: var(--vessel-serif);
  font-style: italic;
  font-size: 12.5px;
  color: var(--vessel-ink-mute);
}
.result__deepen-pre[data-state="done"] {
  text-align: left;
  background: var(--vessel-bg-card);
}
.result__deepen-pre-done {
  margin: 0;
  font-family: var(--vessel-sans);
  font-size: 0.95rem;
  line-height: 1.55;
  color: var(--vessel-ink-soft);
}
.result__deepen-pre-done strong {
  color: var(--vessel-gold);
  font-weight: 600;
}
@media (max-width: 640px) {
  .result__deepen-pre { padding: 1.25rem 1.1rem 1.3rem; }
  .result__deepen-pre-form { flex-direction: column; gap: 0.6rem; }
  .result__deepen-pre-btn { padding: 1rem 1.25rem; }
}

.result__archetype { margin: 0 0 3.5rem; text-align: center; }
.result__name {
  font-family: var(--vessel-serif);
  font-weight: 500;
  font-size: clamp(2.6rem, 6vw, 3.6rem);
  line-height: 1.05;
  letter-spacing: -0.015em;
  margin: 0 0 0.75rem;
}
.result__tagline {
  font-family: var(--vessel-serif);
  font-style: italic;
  font-size: 1.3rem;
  line-height: 1.4;
  color: var(--vessel-ink-soft);
  margin: 0 0 1.5rem;
}
.result__combination {
  font-family: var(--vessel-sans);
  font-size: 0.9rem;
  color: var(--vessel-ink-mute);
  margin: 0 0 2.5rem;
  letter-spacing: 0.04em;
}
.result__divider {
  width: 40px;
  height: 1px;
  background: var(--vessel-gold);
  margin: 0 auto 2rem;
}
.result__long {
  font-family: var(--vessel-serif);
  font-size: 1.18rem;
  line-height: 1.65;
  color: var(--vessel-ink);
  margin: 0 0 2.5rem;
  text-align: left;
}
.result__cards {
  display: grid;
  gap: 1.5rem;
  margin: 0 0 3.5rem;
  text-align: left;
}
.result__card { padding: 0; border: 0; background: transparent; }
.result__card-h {
  font-family: var(--vessel-sans);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--vessel-gold-deep);
  margin: 0 0 0.5rem;
  font-weight: 600;
}
.result__card p {
  margin: 0;
  font-size: 16px;
  line-height: 1.6;
  color: var(--vessel-ink-soft);
}

/* === Offer === */

.result__offer {
  border-top: 1px solid var(--vessel-line);
  padding: 3rem 0 0;
  margin: 0 0 2rem;
  text-align: center;
}
.result__offer-h {
  font-family: var(--vessel-serif);
  font-weight: 500;
  font-size: clamp(1.9rem, 4.5vw, 2.5rem);
  line-height: 1.15;
  margin: 0 0 1rem;
}
.result__offer-lede {
  font-family: var(--vessel-serif);
  font-size: 1.15rem;
  line-height: 1.55;
  color: var(--vessel-ink-soft);
  margin: 0 0 2rem;
}
.result__offer-list {
  list-style: none;
  padding: 0;
  margin: 0 0 2.5rem;
  display: grid;
  gap: 0.85rem;
  text-align: left;
}
.result__offer-list li {
  font-size: 16px;
  line-height: 1.55;
  color: var(--vessel-ink);
  padding-left: 1.5rem;
  position: relative;
}
.result__offer-list li::before {
  content: '·';
  position: absolute;
  left: 0;
  top: 0;
  color: var(--vessel-gold);
  font-size: 1.4rem;
  line-height: 1;
  font-weight: 700;
}
.result__offer-list strong {
  font-weight: 600;
  color: var(--vessel-ink);
}

.result__price-row {
  display: flex;
  justify-content: center;
  align-items: baseline;
  gap: 0.85rem;
  margin: 0 0 1.5rem;
}
.result__price {
  font-family: var(--vessel-serif);
  font-size: 2.5rem;
  font-weight: 500;
  color: var(--vessel-ink);
}
.result__price-note {
  font-size: 13px;
  color: var(--vessel-ink-mute);
  font-style: italic;
  font-family: var(--vessel-serif);
}
.result__offer-cta {
  display: block;
  width: 100%;
  background: var(--vessel-gold);
  color: var(--vessel-midnight);
  padding: 1.05rem 1.5rem;
  border: 0;
  border-radius: 4px;
  font-weight: 500;
  font-size: 15px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 200ms ease;
  box-shadow: 0 0 0 1px rgba(201, 168, 106, 0.25), 0 8px 24px rgba(201, 168, 106, 0.18);
}
.result__offer-cta:hover { background: var(--vessel-gold-deep); }
.result__offer-cta:disabled {
  background: var(--vessel-line);
  color: var(--vessel-ink-mute);
  cursor: not-allowed;
}
.result__offer-coming {
  margin: 0.85rem 0 0;
  font-size: 13px;
  font-style: italic;
  color: var(--vessel-ink-mute);
  font-family: var(--vessel-serif);
}

/* Prominent guarantee block on the offer card. Matched to .capture__guarantee
   on the email-gate page. Risk reversal is the lever, so this is visible
   and unmissable rather than fine-print. */
.result__guarantee {
  margin: 1.25rem 0 0;
  display: flex;
  align-items: flex-start;
  gap: 0.85rem;
  padding: 0.95rem 1.05rem;
  border: 1px solid var(--vessel-line);
  border-radius: 6px;
  background: var(--vessel-bg);
  text-align: left;
}
.result__guarantee-mark {
  color: var(--vessel-gold);
  font-size: 1.2rem;
  line-height: 1;
  flex: 0 0 auto;
  margin-top: 0.1rem;
}
.result__guarantee-h {
  margin: 0 0 0.2rem;
  font-family: var(--vessel-sans);
  font-weight: 600;
  font-size: 0.92rem;
  color: var(--vessel-ink);
  letter-spacing: 0.01em;
}
.result__guarantee-p {
  margin: 0;
  font-family: var(--vessel-sans);
  font-size: 0.83rem;
  line-height: 1.5;
  color: var(--vessel-ink-mute);
}
.result__guarantee-p a {
  color: var(--vessel-ink-soft);
  text-decoration: underline;
}

.result__email-form { display: block; }
.result__email-label {
  display: block;
  font-family: var(--vessel-serif);
  font-style: italic;
  font-size: 1.1rem;
  text-align: center;
  margin: 0 0 1rem;
  color: var(--vessel-ink);
}
.result__email-row {
  display: flex;
  gap: 0.5rem;
  align-items: stretch;
}
.result__email-input {
  flex: 1;
  border: 1px solid var(--vessel-line);
  border-radius: 4px;
  padding: 0.85rem 1rem;
  font-family: var(--vessel-sans);
  font-size: 16px;
  background: var(--vessel-bg-card);
  color: var(--vessel-ink);
}
.result__email-input:focus {
  outline: none;
  border-color: var(--vessel-gold);
}
.result__email-cta {
  background: var(--vessel-gold);
  color: var(--vessel-midnight);
  border: 0;
  border-radius: 4px;
  padding: 0.85rem 1.5rem;
  font-weight: 500;
  font-size: 13px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 200ms ease;
  font-family: var(--vessel-sans);
}
.result__email-cta:hover { background: var(--vessel-gold-deep); }
.result__email-cta:disabled {
  background: var(--vessel-ink-mute);
  cursor: not-allowed;
}
.result__email-quiet {
  margin: 0.75rem 0 0;
  text-align: center;
  font-size: 13px;
  font-style: italic;
  color: var(--vessel-ink-mute);
  font-family: var(--vessel-serif);
}

.result__trust {
  margin: 1.5rem 0 0;
  text-align: center;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--vessel-ink-mute);
}

.result__back-line { text-align: center; margin-top: 2.5rem; }
.result__back {
  display: inline-block;
  font-size: 13px;
  color: var(--vessel-ink-mute);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.result__back:hover { color: var(--vessel-ink); }

@media (max-width: 720px) {
  .result__email-row { flex-direction: column; }
  .result__email-cta { width: 100%; }
}

@media print {
  .vessel-header, .vessel-footer, .result__offer, .result__back-line, .quiz-mini-header { display: none; }
  body { background: #fff; }
}

/* === Voice test page === */

.voice-test {
  max-width: 36rem;
  margin: 0 auto;
  padding: 5rem 1.5rem 4rem;
}
.voice-test__eyebrow {
  display: inline-block;
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--vessel-ink-mute);
  margin-bottom: 1.25rem;
}
.voice-test__title {
  font-family: var(--vessel-serif);
  font-weight: 500;
  font-size: clamp(2.2rem, 5vw, 3rem);
  line-height: 1.1;
  margin: 0 0 0.85rem;
}
.voice-test__lede {
  font-family: var(--vessel-serif);
  font-style: italic;
  font-size: 1.15rem;
  line-height: 1.5;
  color: var(--vessel-ink-soft);
  margin: 0 0 1.75rem;
}
.voice-test__sample-script {
  border-left: 2px solid var(--vessel-gold);
  padding: 0.5rem 0 0.5rem 1.25rem;
  margin: 0 0 2.5rem;
}
.voice-test__sample-script p {
  font-family: var(--vessel-serif);
  font-style: italic;
  font-size: 1.05rem;
  line-height: 1.55;
  color: var(--vessel-ink-soft);
  margin: 0;
}
.voice-test__list {
  list-style: none;
  margin: 0 0 2rem;
  padding: 0;
  display: grid;
  gap: 1.25rem;
}
.voice-test__item {
  border-top: 1px solid var(--vessel-line);
  padding: 1.25rem 0 0;
}
.voice-test__item h2 {
  font-family: var(--vessel-serif);
  font-weight: 500;
  font-size: 1.3rem;
  margin: 0 0 0.4rem;
  color: var(--vessel-ink);
}
.voice-test__desc {
  font-size: 14px;
  line-height: 1.5;
  color: var(--vessel-ink-soft);
  margin: 0 0 0.85rem;
}
.voice-test__desc em { font-style: italic; color: var(--vessel-gold-deep); }
.voice-test__item audio { width: 100%; height: 36px; }
.voice-test__quiet {
  font-size: 13px;
  font-style: italic;
  font-family: var(--vessel-serif);
  color: var(--vessel-ink-mute);
  text-align: center;
  margin: 0;
}

/* === Capture page (email gate between submit and result) === */

.capture {
  max-width: 32rem;
  margin: 0 auto;
  padding: 6rem 1.5rem 5rem;
  text-align: center;
}
.capture__inner { }
.capture__pulse {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--vessel-gold);
  margin: 0 auto 2rem;
  animation: vessel-pulse 1.6s ease-in-out infinite;
  box-shadow: 0 0 18px rgba(201, 164, 90, 0.35);
}
.capture__eyebrow {
  display: block;
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--vessel-gold-deep);
  margin-bottom: 1rem;
  font-weight: 700;
}
.capture__title {
  font-family: var(--vessel-serif);
  font-weight: 500;
  font-size: clamp(2rem, 4.4vw, 2.8rem);
  line-height: 1.1;
  letter-spacing: -0.01em;
  margin: 0 0 0.85rem;
  color: var(--vessel-ink);
}
.capture__lede {
  font-family: var(--vessel-serif);
  font-style: italic;
  font-size: 1.25rem;
  line-height: 1.5;
  color: var(--vessel-ink-soft);
  margin: 0 0 2.5rem;
}
.capture__form {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  max-width: 22rem;
  margin: 0 auto;
}
.capture__label {
  display: block;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--vessel-ink-mute);
  margin-bottom: 0.25rem;
  text-align: left;
  font-weight: 600;
}
.capture__label:not(:first-of-type) {
  margin-top: 0.5rem;
}
.capture__label-optional {
  font-family: var(--vessel-serif);
  font-style: italic;
  font-size: 12px;
  letter-spacing: 0;
  text-transform: none;
  color: var(--vessel-ink-mute);
  margin-left: 0.4rem;
  font-weight: 400;
}
.capture__input {
  width: 100%;
  border: 1px solid var(--vessel-line);
  border-radius: 4px;
  background: var(--vessel-bg-card);
  padding: 1rem 1.1rem;
  font-family: var(--vessel-sans);
  font-size: 17px;
  color: var(--vessel-ink);
  transition: border-color 180ms ease;
  text-align: left;
}
.capture__input:focus {
  outline: none;
  border-color: var(--vessel-gold-deep);
}
.capture__cta {
  background: var(--vessel-gold);
  color: var(--vessel-midnight);
  border: 0;
  border-radius: 4px;
  padding: 1.05rem 1.5rem;
  font-weight: 500;
  font-size: 14px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 180ms ease;
  font-family: var(--vessel-sans);
}
.capture__cta:hover { background: var(--vessel-gold-deep); }
.capture__cta:disabled {
  background: var(--vessel-ink-mute);
  cursor: not-allowed;
}
.capture__quiet {
  margin: 0.5rem 0 0;
  text-align: center;
  font-size: 13px;
  font-style: italic;
  color: var(--vessel-ink-mute);
  font-family: var(--vessel-serif);
}

/* Haiku pre-teaser block. Shown above the email form. Has three states:
   loading (shimmer placeholders), ready (the rendered text), fallback
   (static fallback string). The shimmers fade out when ready/fallback.
   The text fades in. */
.capture__teaser {
  min-height: 5.5rem;
  margin: 0 auto 2.5rem;
  max-width: 30rem;
  font-family: var(--vessel-serif);
  font-style: italic;
  font-size: 1.18rem;
  line-height: 1.55;
  color: var(--vessel-ink);
  letter-spacing: 0.003em;
  transition: opacity 380ms ease;
  position: relative;
}
.capture__teaser[data-state="loading"] {
  color: transparent;
}
.capture__teaser[data-state="ready"],
.capture__teaser[data-state="fallback"] {
  animation: capture-teaser-in 480ms ease both;
}
.capture__teaser[data-state="ready"] .capture__teaser-shimmer,
.capture__teaser[data-state="fallback"] .capture__teaser-shimmer {
  display: none;
}
.capture__teaser-shimmer {
  display: block;
  height: 0.95rem;
  margin: 0.55rem auto;
  border-radius: 2px;
  background: linear-gradient(90deg, rgba(236, 228, 213, 0.06) 0%, rgba(236, 228, 213, 0.14) 50%, rgba(236, 228, 213, 0.06) 100%);
  background-size: 200% 100%;
  animation: capture-teaser-shimmer 1.6s ease-in-out infinite;
}
.capture__teaser-shimmer:nth-child(1) { width: 92%; }
.capture__teaser-shimmer:nth-child(2) { width: 78%; }
.capture__teaser-shimmer:nth-child(3) { width: 58%; }
@keyframes capture-teaser-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}
@keyframes capture-teaser-in {
  0%   { opacity: 0; transform: translateY(4px); }
  100% { opacity: 1; transform: translateY(0); }
}

/* Subtitle right under the capture title. Quiet, italic. */
.capture__sub {
  font-family: var(--vessel-serif);
  font-style: italic;
  font-size: 1.15rem;
  line-height: 1.5;
  color: var(--vessel-ink-soft);
  margin: 0 0 2rem;
}

/* Visually-hidden label for screen readers. The email field has a placeholder
   that doubles as the visible label since we want the form to feel light. */
.capture__label--visually-hidden {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* One-line trust microcopy directly under the CTA. Replaces the old
   three-item .capture__trust list. */
.capture__microtrust {
  margin: 0.75rem 0 0;
  text-align: center;
  font-family: var(--vessel-sans);
  font-size: 12px;
  color: var(--vessel-ink-mute);
  letter-spacing: 0.02em;
}

/* Prominent money-back guarantee block. Goes BELOW the CTA and ABOVE the
   teaser. Risk reversal language matched to the result/offer page block. */
.capture__guarantee {
  margin: 2rem auto 1.75rem;
  max-width: 28rem;
  display: flex;
  align-items: flex-start;
  gap: 0.9rem;
  padding: 1rem 1.1rem;
  border: 1px solid var(--vessel-line);
  border-radius: 6px;
  background: var(--vessel-bg-card);
  text-align: left;
}
.capture__guarantee-mark {
  color: var(--vessel-gold);
  font-size: 1.25rem;
  line-height: 1;
  flex: 0 0 auto;
  margin-top: 0.1rem;
}
.capture__guarantee-body { flex: 1; min-width: 0; }
.capture__guarantee-h {
  margin: 0 0 0.25rem;
  font-family: var(--vessel-sans);
  font-weight: 600;
  font-size: 0.95rem;
  color: var(--vessel-ink);
  letter-spacing: 0.01em;
}
.capture__guarantee-p {
  margin: 0;
  font-family: var(--vessel-sans);
  font-size: 0.86rem;
  line-height: 1.5;
  color: var(--vessel-ink-mute);
}
.capture__guarantee-p a {
  color: var(--vessel-ink-soft);
  text-decoration: underline;
}

/* Small eyebrow above the teaser shimmer block (now positioned below the
   form, so it needs a label so the user understands what's loading). */
.capture__teaser-eyebrow {
  font-family: var(--vessel-sans);
  text-transform: uppercase;
  font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--vessel-ink-mute);
  margin: 0 0 0.85rem;
  font-weight: 500;
}
.capture__teaser[data-state="ready"] .capture__teaser-eyebrow,
.capture__teaser[data-state="fallback"] .capture__teaser-eyebrow {
  /* Keep the eyebrow visible after the teaser loads — it's framing the
     teaser text as "preview" so the value-prop reads right. */
  color: var(--vessel-ink-mute);
}

@media (max-width: 640px) {
  .capture { padding: 4rem 1.25rem 3rem; }
  .capture__title { font-size: 1.85rem; }
  .capture__sub { font-size: 1.05rem; margin-bottom: 1.5rem; }
  .capture__lede { font-size: 1.15rem; margin-bottom: 2rem; }
  .capture__teaser { font-size: 1.08rem; min-height: 5rem; }
  .capture__guarantee { padding: 0.85rem 0.95rem; gap: 0.7rem; }
  .capture__guarantee-p { font-size: 0.82rem; }
}

/* === Post-paywall deepening page === */
.deepen {
  max-width: 38rem;
  margin: 0 auto;
  padding: 4.5rem 1.5rem 5rem;
  position: relative;
}
.deepen__inner { position: relative; }
.deepen__skip {
  display: block;
  margin: 0 0 2.5rem auto;
  background: transparent;
  border: 1px solid var(--vessel-line);
  color: var(--vessel-ink-mute);
  padding: 0.55rem 0.9rem;
  border-radius: 4px;
  font-family: var(--vessel-sans);
  font-size: 12px;
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: color 180ms ease, border-color 180ms ease;
}
.deepen__skip:hover { color: var(--vessel-ink); border-color: var(--vessel-ink-mute); }
.deepen__eyebrow {
  display: block;
  font-family: var(--vessel-sans);
  text-transform: uppercase;
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  color: var(--vessel-gold);
  margin: 0 0 0.85rem;
}
.deepen__title {
  font-family: var(--vessel-serif);
  font-weight: 500;
  font-size: clamp(2rem, 4.4vw, 2.6rem);
  line-height: 1.15;
  letter-spacing: -0.01em;
  margin: 0 0 1.25rem;
  color: var(--vessel-ink);
}
.deepen__lede {
  font-family: var(--vessel-serif);
  font-style: italic;
  font-size: 1.05rem;
  line-height: 1.55;
  color: var(--vessel-ink-soft);
  margin: 0 0 1rem;
}
.deepen__form {
  display: flex;
  flex-direction: column;
  gap: 1.6rem;
  margin: 2.5rem 0 0;
}
.deepen__group {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}
.deepen__q {
  font-family: var(--vessel-serif);
  font-size: 1.12rem;
  line-height: 1.4;
  color: var(--vessel-ink);
  font-weight: 500;
}
.deepen__hint {
  font-family: var(--vessel-sans);
  font-size: 12.5px;
  font-style: italic;
  color: var(--vessel-ink-mute);
  margin-bottom: 0.2rem;
}
.deepen__input,
.deepen__textarea {
  width: 100%;
  border: 1px solid var(--vessel-line);
  border-radius: 4px;
  background: var(--vessel-bg-card);
  padding: 0.9rem 1rem;
  font-family: var(--vessel-sans);
  font-size: 15px;
  color: var(--vessel-ink);
  transition: border-color 180ms ease;
}
.deepen__textarea {
  resize: vertical;
  min-height: 5.5rem;
  line-height: 1.55;
}
.deepen__input:focus,
.deepen__textarea:focus {
  outline: none;
  border-color: var(--vessel-gold-deep);
}
.deepen__input::placeholder,
.deepen__textarea::placeholder {
  color: var(--vessel-ink-mute);
  font-style: italic;
}
.deepen__actions {
  display: flex;
  flex-direction: column;
  gap: 0.7rem;
  margin-top: 1.25rem;
}
.deepen__cta {
  background: var(--vessel-gold);
  color: var(--vessel-midnight);
  border: 0;
  border-radius: 4px;
  padding: 1.05rem 1.5rem;
  font-family: var(--vessel-sans);
  font-weight: 500;
  font-size: 14px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 180ms ease;
}
.deepen__cta:hover { background: var(--vessel-gold-deep); }
.deepen__skip-bottom {
  background: transparent;
  border: 0;
  color: var(--vessel-ink-mute);
  font-family: var(--vessel-serif);
  font-style: italic;
  font-size: 0.95rem;
  cursor: pointer;
  padding: 0.5rem;
  transition: color 180ms ease;
}
.deepen__skip-bottom:hover { color: var(--vessel-ink); }
.deepen__note {
  margin: 1.25rem 0 0;
  font-family: var(--vessel-serif);
  font-style: italic;
  font-size: 12.5px;
  text-align: center;
  color: var(--vessel-ink-mute);
}

/* The "Cybershaman is composing" state shown after submit/skip. */
.deepen__sending {
  text-align: center;
  padding: 3rem 0;
}
.deepen__flame {
  width: 14px; height: 14px;
  border-radius: 50%;
  background: var(--vessel-gold);
  margin: 0 auto 1.5rem;
  animation: vessel-pulse 1.6s ease-in-out infinite;
  box-shadow: 0 0 22px rgba(201, 164, 90, 0.35);
}
.deepen__sending-line {
  font-family: var(--vessel-serif);
  font-style: italic;
  font-size: clamp(1.3rem, 3vw, 1.6rem);
  color: var(--vessel-ink);
  margin: 0 0 0.6rem;
}
.deepen__sending-sub {
  font-family: var(--vessel-serif);
  font-style: italic;
  font-size: 1rem;
  color: var(--vessel-ink-soft);
  margin: 0;
}

@media (max-width: 640px) {
  .deepen { padding: 3.5rem 1.25rem 4rem; }
  .deepen__title { font-size: 1.85rem; }
  .deepen__skip { margin-bottom: 2rem; font-size: 11px; }
}
