
:root{
  --teal-900:#0c3a3e;
  --teal-700:#15585e;
  --teal-500:#1f8a8f;
  --teal-100:#dcefef;
  --teal-50:#f1f8f8;
  --gold-500:#c9a85c;
  --gold-300:#e3c98a;
  --cream:#f7f3ec;
  --ink-900:#0e1718;
  --ink-700:#3a4a4c;
  --ink-500:#6a7878;
  --ink-300:#b9c2c2;
  --line:#e6ece9;
  --bg:#fbfaf6;
  --white:#fff;
  --good:#1f8a8f;
  --warn:#c98a14;
  --alert:#c9544a;
  --shadow-sm:0 1px 2px rgba(12,58,62,.06), 0 1px 3px rgba(12,58,62,.04);
  --shadow-md:0 8px 24px rgba(12,58,62,.08), 0 2px 6px rgba(12,58,62,.04);
  --shadow-lg:0 24px 60px rgba(12,58,62,.12);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  color:var(--ink-900);
  background:var(--bg);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  display:flex;flex-direction:column;min-height:100vh;
}
button{font-family:inherit;cursor:pointer;border:none;background:none}
a{color:var(--teal-700);text-decoration:none}
input,textarea{font-family:inherit;font-size:1rem;color:var(--ink-900)}
h1,h2,h3{font-family:'Fraunces',Georgia,serif;font-weight:500;letter-spacing:-0.01em;line-height:1.15;color:var(--ink-900)}

/* ===== Top bar ===== */
.topbar{
  background:#fff;border-bottom:1px solid var(--line);
  padding:14px 0;position:sticky;top:0;z-index:30;
  backdrop-filter:saturate(140%) blur(8px);background:rgba(251,250,246,.92);
}
.topbar-inner{
  max-width:780px;margin:0 auto;padding:0 24px;
  display:flex;align-items:center;justify-content:space-between;gap:14px;
}
.brand{display:flex;align-items:center;gap:14px;font-family:'Fraunces',serif;font-size:1.1rem;color:var(--teal-900);font-weight:500;text-decoration:none}
.brand-logo{height:42px;width:auto;display:block}
.brand-loc{
  display:none;font-family:'Inter',sans-serif;font-size:.6rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--ink-500);font-weight:600;
  padding-left:14px;border-left:1px solid var(--line);
}
@media (min-width:600px){.brand-loc{display:inline-block}}
.brand-mark{
  width:34px;height:34px;border-radius:50%;
  background:linear-gradient(135deg,var(--teal-700),var(--teal-500));
  display:grid;place-items:center;color:#fff;
  box-shadow:inset 0 -2px 6px rgba(0,0,0,.15);
}
.brand small{display:block;font-family:'Inter',sans-serif;font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-500);margin-top:-2px;font-weight:600}
.exit-link{
  font-size:.8rem;color:var(--ink-500);display:inline-flex;align-items:center;gap:6px;
  padding:6px 12px;border-radius:8px;transition:all .2s;
}
.exit-link:hover{background:var(--cream);color:var(--ink-900)}

/* ===== Progress ===== */
.progress-wrap{
  max-width:780px;margin:0 auto;padding:18px 24px 0;width:100%;
}
.progress-meta{
  display:flex;justify-content:space-between;align-items:center;
  font-size:.78rem;letter-spacing:.06em;color:var(--ink-500);
  text-transform:uppercase;font-weight:600;margin-bottom:10px;
}
.progress-meta .privacy{display:inline-flex;align-items:center;gap:6px;color:var(--teal-700)}
.progress-meta .privacy svg{width:13px;height:13px}
.progress-bar{
  height:5px;background:var(--teal-100);border-radius:99px;overflow:hidden;
}
.progress-fill{
  height:100%;background:linear-gradient(90deg,var(--teal-500),var(--teal-700));
  border-radius:99px;width:0;transition:width .4s cubic-bezier(.22,.61,.36,1);
}

/* ===== Slides ===== */
main{flex:1;display:flex;align-items:center;width:100%;padding:30px 0 40px}
.stage{
  max-width:780px;margin:0 auto;padding:0 24px;width:100%;
}
.slide{display:none;animation:slideIn .35s cubic-bezier(.22,.61,.36,1)}
.slide.active{display:block}
@keyframes slideIn{
  from{opacity:0;transform:translateY(12px)}
  to{opacity:1;transform:translateY(0)}
}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;font-size:.72rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--teal-700);
  font-weight:600;margin-bottom:12px;
}
.eyebrow::before{content:'';width:24px;height:1px;background:var(--gold-500)}
.q-title{
  font-size:clamp(1.5rem,3.3vw,2.2rem);
  margin-bottom:12px;font-weight:500;color:var(--ink-900);
}
.q-help{color:var(--ink-500);font-size:.95rem;margin-bottom:30px;max-width:580px}

/* ===== Options ===== */
.options{display:grid;gap:10px;margin-bottom:30px}
.opt{
  display:flex;align-items:center;gap:14px;
  padding:18px 22px;background:#fff;border:1.5px solid var(--line);
  border-radius:14px;cursor:pointer;text-align:left;
  transition:all .18s;width:100%;font-size:.98rem;color:var(--ink-900);
}
.opt:hover{border-color:var(--teal-500);background:var(--teal-50)}
.opt.selected{
  border-color:var(--teal-700);background:var(--teal-900);color:#fff;
  box-shadow:var(--shadow-md);
}
.opt.selected .opt-key{background:var(--gold-500);color:var(--ink-900);border-color:var(--gold-500)}
.opt.selected .opt-sub{color:#9bbcbe}
.opt-key{
  width:30px;height:30px;border-radius:8px;background:var(--bg);
  border:1.5px solid var(--line);display:grid;place-items:center;
  font-size:.78rem;font-weight:700;color:var(--ink-500);flex-shrink:0;
  transition:all .18s;
}
.opt-body{flex:1}
.opt-label{display:block;font-weight:500;line-height:1.3}
.opt-sub{display:block;font-size:.82rem;color:var(--ink-500);margin-top:2px}
.opt-check{
  width:22px;height:22px;border-radius:50%;border:1.5px solid var(--ink-300);
  display:grid;place-items:center;flex-shrink:0;transition:all .18s;
}
.opt.selected .opt-check{background:var(--gold-500);border-color:var(--gold-500)}
.opt-check svg{width:12px;height:12px;color:var(--ink-900);opacity:0;transition:opacity .15s}
.opt.selected .opt-check svg{opacity:1}

/* Multi-select hint */
.multi-hint{
  font-size:.78rem;color:var(--ink-500);margin-bottom:14px;
  display:inline-flex;align-items:center;gap:6px;
}
.multi-hint svg{width:14px;height:14px;color:var(--teal-500)}

/* Text inputs */
.text-input,.text-area{
  width:100%;padding:16px 18px;border:1.5px solid var(--line);
  border-radius:12px;background:#fff;transition:all .18s;color:var(--ink-900);
}
.text-input:focus,.text-area:focus{outline:none;border-color:var(--teal-500);box-shadow:0 0 0 3px rgba(31,138,143,.12)}
.text-area{resize:vertical;min-height:90px;font-size:.95rem;line-height:1.5;font-family:inherit}
.form-row{display:grid;gap:14px;grid-template-columns:1fr 1fr;margin-bottom:24px}
@media (max-width:540px){.form-row{grid-template-columns:1fr}}
.field-lbl{display:block;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-500);font-weight:600;margin-bottom:6px}

/* ===== Nav ===== */
.nav-row{
  display:flex;justify-content:space-between;align-items:center;gap:14px;
  padding-top:18px;border-top:1px solid var(--line);margin-top:10px;
}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:13px 26px;border-radius:99px;font-weight:600;font-size:.92rem;
  transition:all .2s;border:1.5px solid transparent;cursor:pointer;
  font-family:'Inter',sans-serif;
}
.btn-primary{background:var(--teal-700);color:#fff}
.btn-primary:hover{background:var(--teal-900);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn-primary:disabled{background:var(--ink-300);cursor:not-allowed;transform:none;box-shadow:none}
.btn-ghost{background:transparent;color:var(--ink-500);padding:10px 18px}
.btn-ghost:hover{background:var(--cream);color:var(--ink-900)}
.btn-gold{background:var(--gold-500);color:var(--ink-900)}
.btn-gold:hover{background:var(--gold-300);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn-light{background:#fff;color:var(--teal-900);border:1.5px solid var(--line)}
.btn-light:hover{border-color:var(--teal-500);background:var(--teal-50)}
.kbd{
  display:inline-flex;align-items:center;gap:2px;font-size:.66rem;
  padding:2px 6px;border-radius:5px;background:rgba(255,255,255,.18);
  color:rgba(255,255,255,.8);font-weight:600;letter-spacing:.04em;
  border:1px solid rgba(255,255,255,.18);margin-left:4px;
}
.btn-ghost .kbd{background:#f0eee8;color:var(--ink-500);border-color:var(--line)}

/* ===== Welcome slide ===== */
.welcome-icon{
  width:72px;height:72px;border-radius:20px;
  background:linear-gradient(135deg,var(--teal-700),var(--teal-500));
  display:grid;place-items:center;color:#fff;margin-bottom:24px;
  box-shadow:var(--shadow-md);
}
.welcome-icon svg{width:36px;height:36px}
.welcome-meta{
  display:flex;flex-wrap:wrap;gap:20px;margin:24px 0 30px;
  padding:18px;background:#fff;border-radius:14px;border:1px solid var(--line);
}
.welcome-meta .item{display:flex;align-items:center;gap:10px;font-size:.88rem;color:var(--ink-700)}
.welcome-meta .item svg{width:18px;height:18px;color:var(--teal-500);flex-shrink:0}
.disclaimer{
  background:#fff5db;border:1px solid var(--gold-300);
  padding:14px 16px;border-radius:12px;font-size:.84rem;color:#5e4a14;
  display:flex;gap:10px;align-items:flex-start;line-height:1.5;
}
.disclaimer svg{width:18px;height:18px;flex-shrink:0;color:var(--gold-500);margin-top:2px}


/* ===== Big choice cards (for_who) ===== */
.choice-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:8px 0 24px}
@media (max-width:600px){.choice-grid{grid-template-columns:1fr}}
.choice-card{
  display:flex;flex-direction:column;gap:10px;align-items:flex-start;
  text-align:left;padding:28px 24px;border-radius:18px;background:#fff;
  border:1.5px solid var(--line);cursor:pointer;transition:all .18s;
  font-family:inherit;color:var(--ink-900);min-height:170px;
}
.choice-card:hover{border-color:var(--teal-500);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.choice-card.selected{border-color:var(--teal-700);background:var(--teal-50);box-shadow:var(--shadow-md)}
.choice-card .ic{
  width:46px;height:46px;border-radius:12px;background:linear-gradient(135deg,var(--teal-700),var(--teal-500));
  display:grid;place-items:center;color:#fff;margin-bottom:4px;
}
.choice-card .ic svg{width:24px;height:24px}
.choice-card .ct{
  font-family:'Fraunces',serif;font-size:1.25rem;font-weight:500;color:var(--ink-900);
}
.choice-card .cd{font-size:.88rem;color:var(--ink-700);line-height:1.5}

/* Partner-mode info banner */
.partner-banner{
  display:none;align-items:flex-start;gap:10px;
  background:#eff7f5;border:1px solid var(--teal-100);border-left:3px solid var(--teal-500);
  padding:10px 14px;border-radius:10px;margin:14px 0 0;
  font-size:.83rem;color:var(--teal-900);line-height:1.5;
}
body[data-assessor="partner"] .partner-banner{display:flex}
.partner-banner svg{width:16px;height:16px;flex-shrink:0;color:var(--teal-700);margin-top:2px}
body[data-assessor="partner"] .self-only{display:none}
body[data-assessor="self"] .partner-only{display:none}

/* Thanks-slide PDF download + sync status */
.thanks-card{
  background:#fff;border:1px solid var(--line);border-radius:18px;
  padding:22px 24px;margin:18px auto 22px;max-width:520px;text-align:left;
  display:flex;gap:16px;align-items:flex-start;box-shadow:var(--shadow-sm);
}
.thanks-card .ic{
  width:42px;height:42px;border-radius:10px;background:var(--teal-50);
  display:grid;place-items:center;color:var(--teal-700);flex-shrink:0;
}
.thanks-card h4{font-family:'Fraunces',serif;font-size:1.05rem;font-weight:500;margin-bottom:4px;color:var(--ink-900)}
.thanks-card p{font-size:.87rem;color:var(--ink-700);line-height:1.5;margin-bottom:10px}
.thanks-card a.btn{padding:9px 18px;font-size:.85rem}
.sync-row{
  display:flex;gap:10px;align-items:center;justify-content:center;
  font-size:.78rem;color:var(--ink-500);margin:6px auto 18px;font-weight:500;
}
.sync-row .dot{width:8px;height:8px;border-radius:50%;background:var(--ink-300);transition:background .3s}
.sync-row.success .dot{background:var(--good)}
.sync-row.error .dot{background:var(--alert)}
.sync-row.pending .dot{background:var(--warn);animation:pulse 1.4s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.5}50%{opacity:1}}

/* ===== Results ===== */
.dual-results{
  display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:22px;
}
@media (max-width:780px){.dual-results{grid-template-columns:1fr;gap:16px}}
.result-card{
  background:#fff;border-radius:22px;padding:36px;border:1px solid var(--line);
  box-shadow:var(--shadow-md);margin-bottom:24px;
}
.result-card.mini{
  padding:24px;margin-bottom:0;display:flex;flex-direction:column;
}
.result-card.mini .rc-header{margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--line)}
.result-card.mini .rc-module{
  font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--teal-700);font-weight:700;
  display:inline-block;margin-bottom:6px;
}
.result-card.mini .rc-header h3{font-family:'Fraunces',serif;font-size:1.3rem;font-weight:500}
.result-card.mini .rc-body{
  display:flex;gap:18px;align-items:center;margin-bottom:18px;
}
.result-card.mini .rc-text{flex:1;min-width:0}
.result-card.mini .rc-text h4{font-family:'Fraunces',serif;font-size:1.1rem;font-weight:500;margin:4px 0 6px;line-height:1.25}
.result-card.mini .rc-text p{font-size:.85rem;color:var(--ink-700);line-height:1.5}
.result-card.mini .next-steps{padding:16px;margin-top:auto}
.result-card.mini .next-steps li{font-size:.85rem;padding:5px 0}
.score-ring.small{width:96px;height:96px;flex-shrink:0;margin:0}
.score-ring.small .score{font-size:1.7rem}
.score-ring.small .score small{font-size:.6rem;margin-top:2px}
.combined-cta{
  background:linear-gradient(135deg,var(--teal-900),var(--teal-700));
  border-radius:22px;padding:32px;color:#fff;margin-bottom:24px;
  display:grid;grid-template-columns:1fr auto;gap:22px;align-items:center;
}
.combined-cta h3{color:#fff;font-family:'Fraunces',serif;font-weight:500;font-size:1.25rem;margin-bottom:6px}
.combined-cta p{color:#cfdedf;font-size:.9rem;margin:0}
.combined-cta .result-cta{flex-direction:column;gap:8px}
.combined-cta .btn-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.25)}
.combined-cta .btn-light:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.5)}
@media (max-width:680px){
  .combined-cta{grid-template-columns:1fr;text-align:left}
  .combined-cta .result-cta{flex-direction:row;flex-wrap:wrap}
}
.score-ring{
  position:relative;width:160px;height:160px;margin:0 auto 20px;
}
.score-ring svg{width:100%;height:100%;transform:rotate(-90deg)}
.score-ring .bg{fill:none;stroke:var(--teal-100);stroke-width:10}
.score-ring .fg{fill:none;stroke:var(--teal-700);stroke-width:10;stroke-linecap:round;transition:stroke-dashoffset 1s cubic-bezier(.22,.61,.36,1),stroke 0.5s}
.score-ring .score{
  position:absolute;inset:0;display:grid;place-items:center;
  font-family:'Fraunces',serif;font-size:2.6rem;color:var(--ink-900);font-weight:500;line-height:1;
}
.score-ring .score small{display:block;font-family:'Inter',sans-serif;font-size:.7rem;letter-spacing:.1em;color:var(--ink-500);font-weight:600;text-transform:uppercase;margin-top:6px}
.result-tag{
  display:inline-block;padding:6px 14px;border-radius:99px;
  font-size:.74rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  margin-bottom:10px;
}
.result-tag.none{background:#dcf0e6;color:#1e6b4e}
.result-tag.mild{background:#dcefef;color:var(--teal-700)}
.result-tag.mod{background:#fff5db;color:#8a6a14}
.result-tag.severe{background:#fbe6e3;color:#9c3a31}
.result-card h2{font-size:1.7rem;margin-bottom:10px}
.result-card .what{color:var(--ink-700);margin-bottom:22px}
.result-card .next-steps{
  background:var(--teal-50);border-radius:14px;padding:22px;margin-bottom:22px;
}
.result-card .next-steps h4{
  font-family:'Inter',sans-serif;font-size:.75rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--teal-700);font-weight:700;margin-bottom:12px;
}
.result-card .next-steps ul{list-style:none;padding:0}
.result-card .next-steps li{
  padding:8px 0;display:flex;gap:10px;align-items:flex-start;font-size:.93rem;color:var(--ink-700);
}
.result-card .next-steps li::before{content:'✓';color:var(--teal-500);font-weight:700;flex-shrink:0}
.result-cta{display:flex;gap:10px;flex-wrap:wrap}
.summary-block{
  background:var(--cream);border-radius:14px;padding:22px;font-size:.88rem;
  border:1px solid var(--gold-300);
}
.summary-block h4{
  font-family:'Inter',sans-serif;font-size:.75rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--ink-700);font-weight:700;margin-bottom:12px;
}
.summary-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media (max-width:540px){.summary-grid{grid-template-columns:1fr}}
.summary-grid .lbl{font-size:.78rem;color:var(--ink-500);display:block;margin-bottom:2px}
.summary-grid .val{color:var(--ink-900);font-weight:500}
.confidence{
  margin-top:24px;text-align:center;font-size:.82rem;color:var(--ink-500);
  display:flex;align-items:center;justify-content:center;gap:6px;
}
.confidence svg{width:14px;height:14px;color:var(--teal-500)}

/* ===== Footer ===== */
footer{
  text-align:center;padding:20px 24px;font-size:.78rem;color:var(--ink-500);
  border-top:1px solid var(--line);background:#fff;
}
footer a{color:var(--ink-500)}
footer a:hover{color:var(--teal-700)}

/* Hidden slides for completed form */
.thanks-icon{
  width:80px;height:80px;border-radius:50%;background:var(--teal-50);
  display:grid;place-items:center;margin:0 auto 24px;
}
.thanks-icon svg{width:42px;height:42px;color:var(--teal-700)}

/* a11y focus */
.opt:focus-visible,.btn:focus-visible,.text-input:focus-visible,.text-area:focus-visible{
  outline:3px solid var(--gold-300);outline-offset:2px;
}

.skip-link{position:absolute;left:-9999px;top:0;z-index:10000;background:#0c3a3e;color:#fff;padding:10px 16px;border-radius:0 0 8px 0;font-weight:600;text-decoration:none}
.skip-link:focus{left:0}
