/* =============================================================
   KLARHEIT Quiz-Funnel — /pilot
   Lädt NACH tokens.css + home.css (Richtung A · Calm).
   Nutzt Theme-Vars: --ink --ink-2 --ink-3 --rule --surface --soft
                     --page-bg --rc --rb --k-mint --k-mint-deep
   ============================================================= */

.proto{min-height:100vh;display:flex;flex-direction:column;}
.page{flex:1;display:flex;flex-direction:column;min-height:100vh;}

/* ---------- SHARED MOTION ---------- */
.qf-fade{animation:qfFade .5s var(--ease-out) both;}
@keyframes qfFade{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:none;}}
.proto[data-motion="off"] .qf-fade{animation:none;}
@media (prefers-reduced-motion: reduce){.qf-fade{animation:none;}}

/* ---------- TOP: NAV ---------- */
.qf-nav{position:sticky;top:0;z-index:40;
  background:color-mix(in srgb,var(--page-bg) 88%,transparent);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--rule);}
.qf-nav-bar{display:flex;align-items:center;justify-content:space-between;padding:15px 22px;}
.qf-logo{height:18px;width:auto;display:block;}
.qf-close{width:36px;height:36px;border-radius:50%;border:none;background:transparent;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:background .15s;text-decoration:none;}
.qf-close:hover{background:rgba(0,0,0,0.06);}
.qf-close svg{width:18px;height:18px;stroke:var(--ink);stroke-width:1.7;fill:none;}

/* ---------- PROGRESS ---------- */
.qf-prog{padding:20px 26px 0;}
.qf-prog-lab{display:flex;justify-content:space-between;align-items:baseline;gap:14px;
  font-size:11.5px;letter-spacing:0.12em;text-transform:uppercase;font-weight:500;color:var(--ink-3);}
.qf-prog-lab b{color:var(--ink);font-weight:500;}
.qf-prog-lab span:first-child{flex-shrink:0;}
.qf-prog-dim{letter-spacing:0.04em;flex-shrink:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:right;}
.qf-track{height:3px;border-radius:999px;background:var(--rule);margin-top:11px;overflow:hidden;}
.qf-fill{height:100%;border-radius:999px;background:var(--k-mint-deep);
  transition:width .55s var(--ease-out);}

/* =============================================================
   LANDING
   ============================================================= */
.qf-land{flex:1;display:flex;flex-direction:column;}
.qf-land-visual{display:none;}
.qf-land-hero{padding:52px 26px 40px;text-align:center;}
.qf-eyebrow{font-size:11.5px;letter-spacing:0.2em;text-transform:uppercase;font-weight:500;
  color:var(--ink-3);display:inline-flex;align-items:center;gap:10px;}
.qf-eyebrow::before,.qf-eyebrow::after{content:"";width:18px;height:1px;background:currentColor;opacity:0.5;}
.qf-h1{font-size:clamp(33px,9.2vw,44px);font-weight:300;letter-spacing:-0.025em;line-height:1.08;
  margin:22px 0 0;text-wrap:balance;}
.qf-h1 .mk{background:linear-gradient(transparent 56%,var(--k-mint) 56%);padding:0 2px;}
.qf-sub{font-size:17px;line-height:1.58;color:var(--ink-2);margin:20px auto 0;max-width:32ch;}
.qf-bullets{display:flex;justify-content:center;flex-wrap:wrap;gap:8px 10px;margin-top:26px;}
.qf-bullet{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:500;color:var(--ink-2);
  padding:8px 14px;border:1px solid var(--rule);border-radius:999px;background:var(--surface);}
.qf-bullet svg{width:14px;height:14px;stroke:var(--k-mint-deep);stroke-width:2.2;fill:none;}
.qf-cta-wrap{margin-top:30px;display:flex;flex-direction:column;align-items:center;gap:16px;}
.qf-cta-wrap .btn{width:100%;max-width:320px;font-size:17px;padding:18px 28px;}
.qf-closer{font-size:14.5px;font-style:italic;color:var(--ink-3);max-width:30ch;}
.qf-rating{display:inline-flex;align-items:center;gap:9px;font-size:13px;color:var(--ink-3);}
.qf-rating .stars{color:var(--k-mint-deep);letter-spacing:1.5px;font-size:13px;}
.qf-rating b{color:var(--ink-2);font-weight:500;}

.qf-trust{margin-top:8px;padding:26px 22px 40px;border-top:1px solid var(--rule);}
.qf-trust-lab{text-align:center;font-size:10.5px;letter-spacing:0.2em;text-transform:uppercase;
  font-weight:500;color:var(--ink-3);}
.qf-press{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:14px 22px;margin-top:16px;}
.qf-press img{height:17px;width:auto;display:block;opacity:0.5;filter:grayscale(1);}
.qf-testis{display:flex;flex-direction:column;gap:12px;margin-top:26px;}
.qf-testi{padding:18px 20px;border:1px solid var(--rule);border-radius:var(--rc);background:var(--surface);
  box-shadow:var(--card-shadow);}
.qf-testi .stars{color:var(--k-mint-deep);letter-spacing:1.5px;font-size:12.5px;}
.qf-testi p{font-size:15px;line-height:1.5;color:var(--ink);margin:9px 0 0;letter-spacing:-0.005em;}
.qf-testi .who{margin-top:11px;font-size:12.5px;color:var(--ink-2);}
.qf-testi .who b{color:var(--ink);font-weight:500;}
.qf-testi .who .vf{color:var(--k-mint-deep);}

/* =============================================================
   QUIZ STEP
   ============================================================= */
.qf-main{flex:1;padding:34px 26px 56px;display:flex;flex-direction:column;}
.qf-step{flex:1;display:flex;flex-direction:column;}
.qf-q{font-size:clamp(26px,7vw,33px);font-weight:300;letter-spacing:-0.02em;line-height:1.16;
  max-width:19ch;margin:0;text-wrap:pretty;}
.qf-q-sub{font-size:14.5px;color:var(--ink-3);margin-top:12px;line-height:1.5;}

/* — Skala — */
.qf-scale{margin-top:42px;}
.qf-scale-dots{display:flex;align-items:center;justify-content:space-between;position:relative;}
.qf-scale-dots::before{content:"";position:absolute;left:7%;right:7%;top:50%;height:1.5px;
  background:var(--rule);z-index:0;}
.qf-dot{position:relative;z-index:1;width:clamp(46px,13vw,58px);height:clamp(46px,13vw,58px);border-radius:50%;
  border:1.5px solid var(--rule);background:var(--surface);cursor:pointer;
  font-family:inherit;font-size:17px;font-weight:500;color:var(--ink-3);
  display:flex;align-items:center;justify-content:center;
  transition:transform .18s var(--ease-out),border-color .15s,background .15s,color .15s,box-shadow .15s;}
.qf-dot:hover{border-color:var(--ink-3);color:var(--ink);}
.qf-dot.sel{background:var(--k-mint);border-color:var(--k-mint-deep);color:#06160F;
  transform:scale(1.12);box-shadow:0 6px 18px rgba(91,219,159,0.35);}
.qf-scale-ends{display:flex;justify-content:space-between;margin-top:16px;gap:18px;}
.qf-scale-ends span{font-size:13px;line-height:1.35;color:var(--ink-2);max-width:42%;}
.qf-scale-ends span:last-child{text-align:right;}

/* — Single Choice — */
.qf-choices{display:flex;flex-direction:column;gap:11px;margin-top:34px;}
.qf-choice{display:flex;align-items:center;gap:15px;width:100%;text-align:left;
  padding:18px 18px;border:1.5px solid var(--rule);border-radius:14px;background:var(--surface);
  font-family:inherit;font-size:16px;line-height:1.4;color:var(--ink);cursor:pointer;
  transition:border-color .15s,background .15s,transform .14s var(--ease-out);}
.qf-choice:hover{border-color:var(--ink-3);}
.qf-choice:active{transform:scale(0.99);}
.qf-choice .dot{width:21px;height:21px;border-radius:50%;border:1.5px solid var(--rule);
  flex-shrink:0;position:relative;background:var(--surface);transition:border-color .15s;}
.qf-choice:hover .dot{border-color:var(--ink-3);}
.qf-choice.sel{border-color:var(--k-mint-deep);background:#F4FBF7;}
.qf-choice.sel .dot{border-color:var(--k-mint-deep);}
.qf-choice.sel .dot::after{content:"";position:absolute;inset:4px;border-radius:50%;background:var(--k-mint-deep);}

/* — Freitext — */
.qf-textarea{width:100%;margin-top:30px;min-height:130px;resize:vertical;
  padding:18px;border:1.5px solid var(--rule);border-radius:14px;background:var(--surface);
  font-family:inherit;font-size:16px;line-height:1.5;color:var(--ink);}
.qf-textarea::placeholder{color:var(--ink-3);}
.qf-textarea:focus{outline:none;border-color:var(--k-mint-deep);}

/* — Footer-Aktionen — */
.qf-actions{margin-top:auto;padding-top:30px;display:flex;flex-direction:column;gap:14px;}
.qf-actions .btn{font-size:16px;padding:17px 28px;}
.qf-back{display:inline-flex;align-items:center;gap:7px;align-self:flex-start;
  font-size:13.5px;color:var(--ink-3);background:none;border:none;cursor:pointer;font-family:inherit;
  text-decoration:underline;text-underline-offset:3px;padding:4px 0;}
.qf-back:hover{color:var(--ink);}
.qf-back svg{width:14px;height:14px;stroke:currentColor;stroke-width:1.8;fill:none;}
.qf-skip{font-size:13.5px;color:var(--ink-3);background:none;border:none;cursor:pointer;font-family:inherit;
  text-decoration:underline;text-underline-offset:3px;padding:6px 0;align-self:center;}
.qf-skip:hover{color:var(--ink);}

/* =============================================================
   GATE
   ============================================================= */
.qf-gate{flex:1;padding:46px 26px 56px;display:flex;flex-direction:column;}
.qf-gate .qf-eyebrow{color:var(--k-mint-deep);}
.qf-gate-h{font-size:clamp(30px,8vw,38px);font-weight:300;letter-spacing:-0.02em;line-height:1.1;margin:20px 0 0;}
.qf-gate-sub{font-size:16px;line-height:1.55;color:var(--ink-2);margin:16px 0 0;max-width:34ch;}
.qf-teaser{margin-top:28px;border-radius:var(--rc);border:1px solid var(--rule);background:var(--surface);
  box-shadow:var(--card-shadow);padding:24px;display:flex;align-items:center;gap:20px;}
.qf-teaser-num{font-size:54px;font-weight:300;letter-spacing:-0.03em;line-height:1;color:var(--ink);
  position:relative;filter:blur(7px);user-select:none;font-variant-numeric:tabular-nums;}
.qf-teaser-num::after{content:"";position:absolute;inset:0;}
.qf-teaser-meta{flex:1;}
.qf-teaser-lab{font-size:11px;letter-spacing:0.16em;text-transform:uppercase;font-weight:500;color:var(--ink-3);}
.qf-teaser-note{font-size:13.5px;color:var(--ink-2);margin-top:6px;line-height:1.4;}
.qf-teaser-lock{width:22px;height:22px;stroke:var(--k-mint-deep);stroke-width:1.8;fill:none;flex-shrink:0;}
.qf-form{margin-top:26px;display:flex;flex-direction:column;gap:13px;}
.qf-field{display:flex;flex-direction:column;gap:7px;}
.qf-field label{font-size:12px;letter-spacing:0.08em;text-transform:uppercase;font-weight:500;color:var(--ink-3);}
.qf-field input{padding:16px 16px;border:1.5px solid var(--rule);border-radius:13px;background:var(--surface);
  font-family:inherit;font-size:16px;color:var(--ink);transition:border-color .15s;}
.qf-field input::placeholder{color:var(--ink-3);}
.qf-field input:focus{outline:none;border-color:var(--k-mint-deep);}
.qf-consent{display:flex;align-items:flex-start;gap:11px;margin-top:4px;cursor:pointer;}
.qf-consent input{appearance:none;width:21px;height:21px;flex-shrink:0;margin-top:1px;
  border:1.5px solid var(--rule);border-radius:6px;background:var(--surface);cursor:pointer;
  position:relative;transition:border-color .15s,background .15s;}
.qf-consent input:checked{background:var(--k-mint);border-color:var(--k-mint-deep);}
.qf-consent input:checked::after{content:"";position:absolute;left:6.5px;top:2.5px;width:5px;height:10px;
  border:solid #06160F;border-width:0 2px 2px 0;transform:rotate(45deg);}
.qf-consent span{font-size:13px;line-height:1.45;color:var(--ink-2);}
.qf-gate .qf-form .btn{margin-top:8px;font-size:17px;padding:18px 28px;}
.qf-gate-micro{font-size:12px;color:var(--ink-3);text-align:center;margin-top:14px;line-height:1.5;}

/* =============================================================
   RESULT — shared bits
   ============================================================= */
.qf-result{flex:1;padding:40px 26px 52px;}
.qf-rs-continue{margin-top:36px;}
.qf-rs-continue .btn{width:100%;font-size:17px;padding:18px 28px;}
.qf-rs-restart{display:block;margin:16px auto 0;font-size:13px;color:var(--ink-3);background:none;border:none;
  cursor:pointer;font-family:inherit;text-decoration:underline;text-underline-offset:3px;}
.qf-rs-restart:hover{color:var(--ink);}

/* Dimension bars (shared base) */
.qf-dims{display:flex;flex-direction:column;}
.qf-dim{padding:18px 0;border-top:1px solid var(--rule);}
.qf-dim-top{display:flex;align-items:baseline;justify-content:space-between;gap:12px;}
.qf-dim-name{font-size:16px;font-weight:500;color:var(--ink);letter-spacing:-0.005em;}
.qf-dim-val{font-size:15px;font-weight:500;color:var(--ink);font-variant-numeric:tabular-nums;}
.qf-dim-track{height:6px;border-radius:999px;background:var(--rule);margin-top:11px;overflow:hidden;}
.qf-dim-bar{height:100%;border-radius:999px;background:var(--k-mint-deep);width:0;
  transition:width .9s var(--ease-out);}
.qf-dim-bar.weak{background:#E0A93B;}
.qf-dim-blurb{font-size:13.5px;color:var(--ink-2);line-height:1.45;margin-top:10px;}
.qf-dim-flag{display:inline-block;margin-left:8px;font-size:10px;letter-spacing:0.1em;text-transform:uppercase;
  font-weight:600;color:#9A6E12;background:#FBEFD3;padding:3px 8px;border-radius:999px;vertical-align:middle;}

/* Mirror line (shared) */
.qf-mirror-lead{font-size:11.5px;letter-spacing:0.18em;text-transform:uppercase;font-weight:500;color:var(--ink-3);}

/* ---------- DIRECTION: COCKPIT (gauge instrument) ---------- */
.qf-result[data-layout="cockpit"] .lay-letter,
.qf-result[data-layout="cockpit"] .lay-report{display:none;}
.qf-gauge-wrap{text-align:center;}
.qf-gauge{position:relative;width:208px;height:208px;margin:8px auto 0;}
.qf-gauge svg{width:100%;height:100%;transform:rotate(-90deg);}
.qf-gauge .track{fill:none;stroke:var(--rule);stroke-width:12;}
.qf-gauge .prog{fill:none;stroke:var(--k-mint-deep);stroke-width:12;stroke-linecap:round;
  transition:stroke-dashoffset 1.2s var(--ease-out);}
.qf-gauge-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;}
.qf-gauge-num{font-size:60px;font-weight:300;letter-spacing:-0.03em;line-height:1;color:var(--ink);font-variant-numeric:tabular-nums;}
.qf-gauge-of{font-size:13px;color:var(--ink-3);margin-top:4px;letter-spacing:0.08em;}
.qf-tier-eyebrow{margin-top:24px;font-size:11.5px;letter-spacing:0.2em;text-transform:uppercase;font-weight:500;color:var(--k-mint-deep);}
.qf-tier-name{font-size:clamp(30px,8vw,40px);font-weight:300;letter-spacing:-0.02em;line-height:1.06;margin-top:10px;}
.qf-tier-line{font-size:16px;line-height:1.55;color:var(--ink-2);margin:14px auto 0;max-width:32ch;}
.qf-arch-card{margin-top:30px;text-align:left;border-radius:var(--rc);border:1px solid var(--rule);
  background:var(--surface);box-shadow:var(--card-shadow);overflow:hidden;}
.qf-arch-card .arch-top{padding:22px 22px 20px;background:var(--soft);}
.qf-arch-lab{font-size:11px;letter-spacing:0.18em;text-transform:uppercase;font-weight:500;color:#0a3d2a;}
.qf-arch-name{font-size:28px;font-weight:300;letter-spacing:-0.02em;line-height:1.05;margin-top:8px;color:var(--ink);}
.qf-arch-line{font-size:15.5px;line-height:1.5;color:var(--ink);margin-top:10px;font-style:italic;}
.qf-arch-body{padding:20px 22px;font-size:14.5px;line-height:1.62;color:var(--ink-2);}
.qf-mirror{margin-top:24px;padding:22px 24px;border-radius:var(--rc);background:#15140F;color:#F1EEE6;text-align:left;}
.qf-mirror .qf-mirror-lead{color:#8E887A;}
.qf-mirror q{display:block;font-size:21px;font-weight:300;line-height:1.32;letter-spacing:-0.01em;margin-top:12px;quotes:none;}
.qf-mirror q::before{content:"„";}.qf-mirror q::after{content:"\201C";}
.qf-dims-head{margin-top:34px;text-align:left;font-size:11.5px;letter-spacing:0.18em;text-transform:uppercase;font-weight:500;color:var(--ink-3);}
.qf-result[data-layout="cockpit"] .qf-dims{margin-top:6px;text-align:left;}

/* ---------- DIRECTION: BRIEF (editorial letter) ---------- */
.qf-result[data-layout="letter"] .lay-cockpit,
.qf-result[data-layout="letter"] .lay-report{display:none;}
.qf-result[data-layout="letter"]{padding-top:30px;}
.qf-letter-eyebrow{font-size:11.5px;letter-spacing:0.2em;text-transform:uppercase;font-weight:500;color:var(--ink-3);
  display:inline-flex;align-items:center;gap:10px;}
.qf-letter-eyebrow::before{content:"";width:18px;height:1px;background:currentColor;opacity:0.5;}
.qf-letter-arch{font-size:clamp(40px,12vw,58px);font-weight:300;letter-spacing:-0.035em;line-height:0.98;margin-top:18px;}
.qf-letter-line{font-size:19px;line-height:1.45;color:var(--ink);margin-top:18px;font-style:italic;max-width:24ch;}
.qf-letter-body{font-size:16px;line-height:1.7;color:var(--ink-2);margin-top:20px;max-width:36ch;}
.qf-letter-mirror{margin-top:34px;padding:28px 0;border-top:1px solid var(--ink);border-bottom:1px solid var(--ink);}
.qf-letter-mirror .qf-mirror-lead{color:var(--ink-3);}
.qf-letter-mirror q{display:block;font-size:clamp(24px,6.5vw,30px);font-weight:300;line-height:1.22;
  letter-spacing:-0.02em;margin-top:14px;quotes:none;text-wrap:pretty;}
.qf-letter-mirror q::before{content:"„";}.qf-letter-mirror q::after{content:"\201C";}
.qf-letter-stat{margin-top:34px;display:flex;align-items:baseline;gap:14px;}
.qf-letter-stat .n{font-size:46px;font-weight:300;letter-spacing:-0.03em;line-height:1;font-variant-numeric:tabular-nums;}
.qf-letter-stat .meta{font-size:14px;line-height:1.4;color:var(--ink-2);}
.qf-letter-stat .meta b{color:var(--ink);font-weight:500;display:block;font-size:15px;letter-spacing:0.02em;text-transform:uppercase;}
.qf-result[data-layout="letter"] .qf-dims{margin-top:28px;}
.qf-result[data-layout="letter"] .qf-dim-track{display:none;}
.qf-result[data-layout="letter"] .qf-dim{display:flex;align-items:baseline;justify-content:space-between;gap:14px;padding:15px 0;}
.qf-result[data-layout="letter"] .qf-dim-blurb{margin-top:4px;flex:1;}
.qf-result[data-layout="letter"] .qf-dim-top{flex-direction:column;align-items:flex-start;gap:4px;min-width:42%;}

/* ---------- DIRECTION: REPORT (scorecard) ---------- */
.qf-result[data-layout="report"] .lay-cockpit,
.qf-result[data-layout="report"] .lay-letter{display:none;}
.qf-result[data-layout="report"]{padding:0 0 52px;}
.qf-report-band{background:#15140F;color:#F1EEE6;padding:34px 26px 30px;}
.qf-report-band .lab{font-size:11px;letter-spacing:0.2em;text-transform:uppercase;font-weight:500;color:#8E887A;}
.qf-report-idx{display:flex;align-items:baseline;gap:10px;margin-top:14px;}
.qf-report-idx .n{font-size:64px;font-weight:300;letter-spacing:-0.03em;line-height:0.9;font-variant-numeric:tabular-nums;}
.qf-report-idx .of{font-size:15px;color:rgba(241,238,230,0.55);}
.qf-report-tier{margin-top:16px;font-size:22px;font-weight:500;letter-spacing:-0.01em;}
.qf-report-tier .pill{display:inline-block;margin-left:8px;font-size:11px;letter-spacing:0.08em;text-transform:uppercase;
  font-weight:600;color:#06160F;background:var(--k-mint);padding:4px 9px;border-radius:999px;vertical-align:middle;}
.qf-report-tierline{font-size:14.5px;line-height:1.55;color:rgba(241,238,230,0.72);margin-top:12px;max-width:36ch;}
.qf-report-body{padding:30px 26px 0;}
.qf-report-sec{font-size:11.5px;letter-spacing:0.18em;text-transform:uppercase;font-weight:500;color:var(--ink-3);margin:0 0 4px;}
.qf-result[data-layout="report"] .qf-dims{margin-top:0;}
.qf-report-arch{margin-top:30px;padding:22px;border-radius:var(--rc);border:1px solid var(--rule);background:var(--surface);}
.qf-report-arch .qf-arch-lab{color:var(--ink-3);}
.qf-report-arch .nm{font-size:24px;font-weight:300;letter-spacing:-0.02em;margin-top:8px;color:var(--ink);}
.qf-report-arch .ln{font-size:15px;font-style:italic;color:var(--ink);margin-top:9px;line-height:1.45;}
.qf-report-arch .bd{font-size:14px;line-height:1.6;color:var(--ink-2);margin-top:12px;}
.qf-report-mirror{margin-top:24px;padding:20px 22px;border-left:3px solid var(--k-mint-deep);background:var(--soft);border-radius:0 var(--rc) var(--rc) 0;}
.qf-report-mirror .qf-mirror-lead{color:#0a3d2a;}
.qf-report-mirror q{display:block;font-size:18px;font-weight:400;line-height:1.4;margin-top:9px;color:var(--ink);quotes:none;}
.qf-report-mirror q::before{content:"„";}.qf-report-mirror q::after{content:"\201C";}
.qf-result[data-layout="report"] .qf-rs-continue{padding:0 26px;}

/* =============================================================
   COACHING-INTERESSE
   ============================================================= */
.qf-coach{flex:1;padding:46px 26px 56px;display:flex;flex-direction:column;}
.qf-coach .qf-eyebrow{color:var(--k-mint-deep);}
.qf-coach-h{font-size:clamp(28px,7.5vw,36px);font-weight:300;letter-spacing:-0.02em;line-height:1.1;
  margin:20px 0 0;max-width:20ch;}
.qf-coach-sub{font-size:15.5px;line-height:1.55;color:var(--ink-2);margin:16px 0 0;max-width:34ch;}
.qf-coach-opts{display:flex;flex-direction:column;gap:11px;margin-top:32px;}
.qf-coach-opt{display:flex;align-items:center;justify-content:space-between;gap:14px;width:100%;text-align:left;
  padding:19px 20px;border:1.5px solid var(--rule);border-radius:14px;background:var(--surface);
  font-family:inherit;font-size:16.5px;color:var(--ink);cursor:pointer;
  transition:border-color .15s,background .15s,transform .14s var(--ease-out);}
.qf-coach-opt:hover{border-color:var(--ink-3);}
.qf-coach-opt:active{transform:scale(0.99);}
.qf-coach-opt.sel{border-color:var(--k-mint-deep);background:#F4FBF7;}
.qf-coach-opt .arr{width:18px;height:18px;stroke:var(--ink-3);stroke-width:1.8;fill:none;flex-shrink:0;transition:transform .18s var(--ease-out),stroke .15s;}
.qf-coach-opt:hover .arr{transform:translateX(3px);stroke:var(--ink);}
.qf-coach-open{margin-top:8px;overflow:hidden;max-height:0;opacity:0;
  transition:max-height .5s var(--ease-out),opacity .4s var(--ease-out),margin-top .4s var(--ease-out);}
.qf-coach-open.show{max-height:440px;opacity:1;margin-top:24px;}
.qf-coach-open-h{font-size:18px;font-weight:500;color:var(--ink);letter-spacing:-0.005em;}
.qf-coach-open-sub{font-size:13.5px;color:var(--ink-3);margin-top:7px;line-height:1.45;}
.qf-coach .qf-actions{margin-top:32px;}

/* =============================================================
   BRIDGE-OFFER
   ============================================================= */
.qf-bridge{flex:1;padding:46px 26px 56px;}
.qf-bridge .qf-eyebrow{color:var(--k-mint-deep);}
.qf-bridge-h{font-size:clamp(28px,7.5vw,36px);font-weight:300;letter-spacing:-0.02em;line-height:1.1;
  margin:20px 0 0;max-width:18ch;}
.qf-bridge-sub{font-size:16px;line-height:1.58;color:var(--ink-2);margin:16px 0 0;max-width:34ch;}
.qf-coachnote{margin-top:24px;display:flex;gap:13px;padding:18px 20px;border-radius:var(--rc);
  background:var(--soft);border:1px solid color-mix(in srgb,var(--k-mint-deep) 30%,transparent);}
.qf-coachnote svg{width:20px;height:20px;stroke:#0a3d2a;stroke-width:1.8;fill:none;flex-shrink:0;margin-top:1px;}
.qf-coachnote p{font-size:14px;line-height:1.5;color:#0a3d2a;margin:0;}
.qf-prod{margin-top:26px;border-radius:var(--rc);overflow:hidden;border:1px solid var(--rule);
  background:var(--surface);box-shadow:var(--card-shadow);}
.qf-prod-media{position:relative;}
.qf-prod-media img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;background:var(--soft);}
.qf-prod-badge{position:absolute;top:14px;left:14px;font-size:10px;letter-spacing:0.07em;text-transform:uppercase;
  font-weight:600;background:var(--k-mint);color:#06160F;padding:5px 11px;border-radius:999px;}
.qf-prod-meta{padding:24px 22px;}
.qf-prod-name{font-size:26px;font-weight:300;letter-spacing:-0.02em;line-height:1.05;}
.qf-prod-line{font-size:16px;color:var(--ink-2);margin-top:8px;}
.qf-prod-why{margin-top:16px;font-size:14.5px;line-height:1.6;color:var(--ink-2);}
.qf-prod-priceline{display:flex;align-items:center;gap:12px;margin-top:18px;flex-wrap:wrap;}
.qf-prod-price{font-size:22px;font-weight:500;letter-spacing:-0.01em;}
.qf-prod-rating{display:inline-flex;align-items:center;gap:7px;font-size:13px;color:var(--ink-2);}
.qf-prod-rating .stars{color:var(--k-mint-deep);letter-spacing:1.5px;font-size:13px;}
.qf-prod-cta{margin-top:20px;}
.qf-prod-cta .btn{width:100%;font-size:17px;padding:17px 28px;}
.qf-bridge-micro{font-size:12px;color:var(--ink-3);text-align:center;margin-top:14px;}
.qf-bridge-restart{display:block;margin:18px auto 0;font-size:13px;color:var(--ink-3);background:none;border:none;
  cursor:pointer;font-family:inherit;text-decoration:underline;text-underline-offset:3px;}
.qf-bridge-restart:hover{color:var(--ink);}
