/* ============================================================
   Calmistry · Stress Origins — pastel instrument
   Design tokens shared with the Calmistry brand (Fraunces / IBM Plex),
   warmed toward soft saturated pink for the empathetic module.
   Animations use transform/opacity only (GPU-friendly).
   ============================================================ */
:root{
  --bg:#fdf2f6;
  --bg-2:#fbe7ef;
  --panel:#ffffff;
  --panel-2:#fff6fa;
  --ink:#3a2231;
  --ink-2:#6d4c5d;
  --muted:#a98a99;
  --line:rgba(90,40,70,.10);
  --line-2:rgba(90,40,70,.16);

  --rose:#ff7eb6;
  --rose-deep:#ef5a9b;
  --coral:#ff9a8b;
  --lilac:#c79bf0;
  --mint:#9be7d4;
  --grad:linear-gradient(112deg,#ff9a8b 0%,#ff7eb6 48%,#c79bf0 100%);
  --grad-soft:linear-gradient(112deg,#ffe1da,#ffe0ee 52%,#efe2fb);
  --rose-wash:color-mix(in srgb,var(--rose) 12%,transparent);
  --lilac-wash:color-mix(in srgb,var(--lilac) 12%,transparent);

  --shadow:0 24px 60px -30px rgba(180,60,120,.40);
  --shadow-sm:0 12px 34px -20px rgba(180,60,120,.34);
  --shadow-pop:0 30px 80px -34px rgba(180,60,120,.5);

  --r-lg:22px; --r-md:16px; --r-sm:11px;
  --ff-disp:"Fraunces",Georgia,serif;
  --ff-body:"IBM Plex Sans",system-ui,sans-serif;
  --ff-mono:"IBM Plex Mono",ui-monospace,monospace;
  --ease:cubic-bezier(.22,.7,.2,1);
  --maxw:680px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--ff-body);color:var(--ink-2);background:var(--bg);line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;min-height:100vh;overflow-x:hidden}
::selection{background:var(--rose);color:#fff}
button{font-family:inherit;cursor:pointer}
:focus-visible{outline:2.5px solid var(--rose-deep);outline-offset:3px;border-radius:8px}

/* ── animated soft-blob background ──────────────────────────── */
.bgfx{position:fixed;inset:0;z-index:-2;overflow:hidden;pointer-events:none;
  background:radial-gradient(120% 80% at 50% -10%,#fff,transparent 60%),var(--bg)}
.blob{position:absolute;border-radius:50%;filter:blur(60px);opacity:.55;will-change:transform}
.blob.b1{width:46vw;height:46vw;left:-12vw;top:-8vw;background:radial-gradient(circle,#ffc2dd,transparent 70%);animation:drift1 22s var(--ease) infinite alternate}
.blob.b2{width:40vw;height:40vw;right:-10vw;top:6vw;background:radial-gradient(circle,#e6cdfb,transparent 70%);animation:drift2 26s var(--ease) infinite alternate}
.blob.b3{width:38vw;height:38vw;left:24vw;bottom:-16vw;background:radial-gradient(circle,#ffd9c9,transparent 70%);animation:drift3 30s var(--ease) infinite alternate}
@keyframes drift1{to{transform:translate3d(6vw,4vw,0) scale(1.12)}}
@keyframes drift2{to{transform:translate3d(-5vw,5vw,0) scale(1.08)}}
@keyframes drift3{to{transform:translate3d(4vw,-5vw,0) scale(1.14)}}
@media (prefers-reduced-motion:reduce){.blob{animation:none}}

/* ── shell ──────────────────────────────────────────────────── */
#app{max-width:var(--maxw);margin:0 auto;padding:clamp(20px,5vw,52px) clamp(18px,5vw,28px) 80px;
  min-height:100vh;display:flex;flex-direction:column}
.brand{display:flex;align-items:center;gap:.55em;font-family:var(--ff-disp);font-weight:600;font-size:1.18rem;color:var(--ink)}
.brand .mark{width:26px;height:26px;border-radius:8px;background:var(--grad);box-shadow:var(--shadow-sm);flex:0 0 auto}
.brand .mod{font-family:var(--ff-mono);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--rose-deep);
  border:1px solid var(--line-2);border-radius:99px;padding:.35em .7em;margin-left:.2em}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:clamp(22px,5vw,40px)}

.kicker{font-family:var(--ff-mono);font-size:.68rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;
  color:var(--rose-deep);display:inline-flex;align-items:center;gap:.7em}
.kicker::before{content:"";width:20px;height:2px;border-radius:2px;background:var(--grad)}
.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}

/* progress */
.progress{display:flex;align-items:center;gap:12px;margin-bottom:26px}
.progress .track{flex:1;height:7px;border-radius:99px;background:color-mix(in srgb,var(--rose) 16%,#fff);overflow:hidden}
.progress .track i{display:block;height:100%;width:0;background:var(--grad);border-radius:99px;
  transition:width .55s var(--ease)}
.progress .count{font-family:var(--ff-mono);font-size:.72rem;letter-spacing:.05em;color:var(--muted);flex:0 0 auto;min-width:48px;text-align:right}

/* ── cards / panels ─────────────────────────────────────────── */
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);
  box-shadow:var(--shadow);padding:clamp(24px,5vw,40px)}

.stage{flex:1;display:flex;flex-direction:column;justify-content:center}
.scene{will-change:transform,opacity}

/* intro */
.intro h1{font-family:var(--ff-disp);font-weight:500;font-size:clamp(2.2rem,7vw,3.4rem);line-height:1.04;
  letter-spacing:-.015em;color:var(--ink);margin:.5em 0 .35em;max-width:14ch}
.intro .lead{font-size:clamp(1.04rem,2.4vw,1.18rem);color:var(--ink-2);max-width:46ch;margin-bottom:1.6em}
.intro .lead em{font-style:italic;color:var(--rose-deep)}
.field{margin:1.4em 0 1.7em}
.field label{display:block;font-family:var(--ff-mono);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--muted);margin-bottom:.7em}
.meta-row{display:flex;flex-wrap:wrap;gap:.6em 1.4em;font-family:var(--ff-mono);font-size:.72rem;color:var(--muted);margin-top:1.4em}
.meta-row b{color:var(--rose-deep)}

/* question */
.q-narrator{font-family:var(--ff-disp);font-style:italic;font-size:.98rem;color:var(--muted);margin-bottom:.5em;min-height:1.5em}
.q-prompt{font-family:var(--ff-disp);font-weight:500;font-size:clamp(1.35rem,3.6vw,1.95rem);line-height:1.18;
  letter-spacing:-.01em;color:var(--ink);margin-bottom:1.25em;max-width:24ch}
.options{display:flex;flex-direction:column;gap:12px}
.opt{display:flex;align-items:center;gap:14px;text-align:left;width:100%;
  background:var(--panel-2);border:1.5px solid var(--line);border-radius:var(--r-md);
  padding:16px 18px;font-size:1.02rem;color:var(--ink);line-height:1.4;
  transition:transform .18s var(--ease),border-color .18s,box-shadow .25s,background .18s}
.opt .dot{flex:0 0 auto;width:26px;height:26px;border-radius:50%;border:2px solid var(--line-2);
  display:grid;place-items:center;transition:.2s;color:#fff;font-size:.8rem}
.opt:hover{transform:translateY(-2px);border-color:var(--rose);box-shadow:var(--shadow-sm);background:#fff}
.opt:hover .dot{border-color:var(--rose)}
.opt.sel{border-color:transparent;background:var(--rose-wash);box-shadow:0 0 0 2px var(--rose) inset}
.opt.sel .dot{background:var(--grad);border-color:transparent}
.opt .key{font-family:var(--ff-mono);font-size:.66rem;color:var(--muted);margin-left:auto;flex:0 0 auto}

/* binary forced-choice cards (larger, calmer than 4-option) */
.opt.binary{align-items:flex-start;padding:20px 22px;font-size:1.08rem;line-height:1.45;gap:16px}
.opt.binary .txt{flex:1}
.opt.binary .pick{flex:0 0 auto;width:30px;height:30px;border-radius:50%;display:grid;place-items:center;
  color:var(--rose-deep);background:var(--rose-wash);font-size:.9rem;transition:.2s}
.opt.binary:hover .pick{background:var(--grad);color:#fff;transform:translateX(2px)}
.phase-tag{font-family:var(--ff-mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.detour-intro h2{font-family:var(--ff-disp);font-weight:500;font-size:clamp(1.4rem,3.4vw,1.9rem);color:var(--ink);margin:.3em 0 1em;line-height:1.2}

.nav-row{display:flex;align-items:center;justify-content:space-between;margin-top:1.6em;gap:12px}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.55em;font-family:var(--ff-mono);font-size:.8rem;font-weight:500;
  letter-spacing:.03em;padding:.95em 1.5em;border-radius:13px;border:1.5px solid transparent;
  transition:transform .18s var(--ease),box-shadow .25s,border-color .2s,opacity .2s,background .2s}
.btn-primary{background:var(--grad);color:#fff;box-shadow:0 14px 30px -14px var(--rose-deep)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 20px 42px -14px var(--rose-deep)}
.btn-ghost{background:#fff;color:var(--ink);border-color:var(--line-2);box-shadow:var(--shadow-sm)}
.btn-ghost:hover{transform:translateY(-2px);border-color:var(--rose)}
.btn[disabled]{opacity:.4;pointer-events:none}
.btn .arr{transition:transform .2s}.btn:hover .arr{transform:translateX(3px)}
.btn-text{background:none;border:0;color:var(--muted);font-family:var(--ff-mono);font-size:.74rem;letter-spacing:.04em}
.btn-text:hover{color:var(--rose-deep)}

/* ── loader ─────────────────────────────────────────────────── */
.loader{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:22px;padding:40px 0}
.loader .ring{width:74px;height:74px}
.loader .ring circle{fill:none;stroke-width:7;stroke-linecap:round}
.loader .ring .bg{stroke:color-mix(in srgb,var(--rose) 18%,#fff)}
.loader .ring .fg{stroke:url(#lg);stroke-dasharray:160;stroke-dashoffset:120;
  transform-origin:center;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.loader .say{font-family:var(--ff-disp);font-style:italic;font-size:1.15rem;color:var(--ink);max-width:24ch}
.loader .sub{font-family:var(--ff-mono);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}

/* ── result ─────────────────────────────────────────────────── */
.result .reg{font-family:var(--ff-mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--rose-deep)}
.result h2{font-family:var(--ff-disp);font-weight:500;font-size:clamp(2rem,6vw,3rem);line-height:1.06;
  letter-spacing:-.02em;color:var(--ink);margin:.3em 0 .1em}
.result .conf-row{display:flex;align-items:center;gap:18px;margin:1.2em 0 1.4em}
.conf-ring{width:84px;height:84px;flex:0 0 auto}
.conf-ring circle{fill:none;stroke-width:9}
.conf-ring .bg{stroke:color-mix(in srgb,var(--rose) 16%,#fff)}
.conf-ring .fg{stroke:url(#lg2);stroke-linecap:round;transform:rotate(-90deg);transform-origin:center;
  transition:stroke-dashoffset 1.1s var(--ease)}
.conf-ring text{font-family:var(--ff-mono);font-size:20px;fill:var(--ink);font-weight:500}
.conf-copy .lab{font-family:var(--ff-mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.conf-copy p{font-size:.96rem;color:var(--ink-2);max-width:30ch}

.read{font-size:1.06rem;color:var(--ink-2);margin:0 0 1em;max-width:50ch}
.read .em{font-style:italic;color:var(--rose-deep)}
.family-line{font-family:var(--ff-mono);font-size:.78rem;letter-spacing:.02em;color:var(--muted);margin:.1em 0 0}
.family-line b{color:var(--rose-deep);font-weight:500}
.reframe,.cost{font-size:1rem;color:var(--ink-2);margin:.2em 0 1em;max-width:50ch}
.reframe b,.cost b{font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;color:var(--rose-deep)}
.cost b{color:var(--warn-deep,#bd6a44)}

/* evidence meter */
.evidence{display:flex;align-items:center;gap:10px;margin:0 0 1.4em;flex-wrap:wrap}
.ev-lab{font-family:var(--ff-mono);font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.ev-dots{display:inline-flex;gap:5px}
.ev-dots i{width:9px;height:9px;border-radius:50%;background:color-mix(in srgb,var(--rose) 18%,#fff);display:inline-block;transition:.3s}
.ev-dots i.on{background:var(--grad)}
.ev-num{font-family:var(--ff-mono);font-size:.66rem;color:var(--muted)}

/* configuration line */
.config-line{display:flex;flex-direction:column;gap:.35em;border:1px solid var(--line);border-radius:var(--r-md);
  background:var(--panel-2);padding:14px 16px;margin:1.2em 0}
.config-line .t{font-family:var(--ff-mono);font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.config-line .v{font-family:var(--ff-disp);font-size:1.08rem;color:var(--ink);line-height:1.35}

.chip.mint{color:#2c9a82;background:color-mix(in srgb,var(--mint) 26%,transparent)}

/* normalization blindspot callout */
.norm-callout{display:flex;gap:12px;align-items:flex-start;border-left:3px solid var(--warn-deep,#bd6a44);
  background:color-mix(in srgb,var(--coral) 12%,transparent);border-radius:0 10px 10px 0;padding:13px 16px;margin:1.2em 0}
.norm-callout .nc-tag{font-family:var(--ff-mono);font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--warn-deep,#bd6a44);flex:0 0 auto;margin-top:.25em}
.norm-callout p{font-size:.98rem;color:var(--ink-2)}

.aphorism{font-family:var(--ff-disp);font-style:italic;font-size:1.12rem;color:var(--ink);margin:1.4em 0 .2em;
  padding-left:.9em;border-left:2px solid var(--rose)}

.facets{display:grid;gap:14px;margin:1.4em 0}
.facet{border:1px solid var(--line);border-radius:var(--r-md);background:var(--panel-2);padding:14px 16px}
.facet .t{font-family:var(--ff-mono);font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:.35em}
.facet .v{font-family:var(--ff-disp);font-size:1.12rem;color:var(--ink)}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:.5em}
.chip{font-family:var(--ff-mono);font-size:.72rem;letter-spacing:.02em;color:var(--rose-deep);
  background:var(--rose-wash);border:1px solid var(--line);border-radius:99px;padding:.45em .85em}
.chip.lilac{color:#8a5fc0;background:var(--lilac-wash)}

.precision-prompt{margin-top:1.6em;padding:18px 20px;border:1.5px dashed var(--line-2);border-radius:var(--r-md);
  background:var(--panel-2);display:flex;flex-direction:column;gap:12px}
.precision-prompt p{font-size:.98rem;color:var(--ink-2)}

.cta-row{display:flex;flex-wrap:wrap;gap:12px;margin-top:1.8em}
.note{margin-top:1.3em;font-family:var(--ff-disp);font-style:italic;color:var(--muted);font-size:1rem}

.toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(20px);opacity:0;
  background:var(--ink);color:#fff;font-family:var(--ff-mono);font-size:.76rem;padding:.8em 1.2em;border-radius:12px;
  box-shadow:var(--shadow-pop);transition:.3s var(--ease);z-index:99;pointer-events:none;max-width:90vw}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}

/* select2 pastel skin */
.select2-container--default .select2-selection--multiple{border:1.5px solid var(--line-2)!important;border-radius:var(--r-md)!important;
  background:var(--panel-2)!important;min-height:52px;padding:4px 6px}
.select2-container--default.select2-container--focus .select2-selection--multiple{border-color:var(--rose)!important;box-shadow:var(--shadow-sm)}
.select2-container--default .select2-selection--multiple .select2-selection__choice{background:var(--grad)!important;border:0!important;
  color:#fff!important;border-radius:99px!important;padding:4px 12px!important;font-size:.84rem;margin:4px}
.select2-container--default .select2-selection__choice__remove{color:#fff!important;margin-right:6px!important;border:0!important}
.select2-dropdown{border:1px solid var(--line-2)!important;border-radius:var(--r-md)!important;box-shadow:var(--shadow)!important;overflow:hidden}
.select2-container--default .select2-results__option--highlighted[aria-selected]{background:var(--rose)!important}
.select2-search--dropdown .select2-search__field{border-radius:9px!important;border:1px solid var(--line-2)!important}

/* ── landing (compact, fits one viewport) ───────────────────── */
.land{min-height:calc(100vh - 72px);display:flex;align-items:center;justify-content:center;padding:8px 0 32px}
.land-inner{max-width:620px;text-align:center;width:100%}
.land .kicker{justify-content:center}
.land h1{font-family:var(--ff-disp);font-weight:500;font-size:clamp(2.1rem,6vw,3.3rem);line-height:1.04;
  letter-spacing:-.015em;color:var(--ink);margin:.5em auto .35em;max-width:15ch}
.land-lead{font-size:clamp(1rem,2.1vw,1.16rem);color:var(--ink-2);max-width:52ch;margin:0 auto 1.4em;line-height:1.55}
.land-steps{display:flex;align-items:center;justify-content:center;gap:.6em;flex-wrap:wrap;margin-bottom:1.5em}
.lstep{font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.02em;color:var(--ink-2);background:var(--panel);
  border:1px solid var(--line);border-radius:99px;padding:.5em .9em;box-shadow:var(--shadow-sm)}
.lstep b{color:var(--rose-deep);margin-right:.45em}
.ldot{color:var(--muted);font-family:var(--ff-mono)}
.land-field{max-width:420px;margin:0 auto 1.3em;text-align:left}
.land-field label{display:block;font-family:var(--ff-mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted);margin-bottom:.6em}
.land-field label span{text-transform:none;letter-spacing:0}
.land-cta{margin-bottom:1.1em}
.land-meta{display:flex;align-items:center;justify-content:center;gap:.5em 1.3em;flex-wrap:wrap;
  font-family:var(--ff-mono);font-size:.71rem;color:var(--muted)}
.land-meta b{color:var(--rose-deep)}
@media(max-width:520px){.land-steps{display:none}}

/* ── result height compaction ───────────────────────────────── */
.result h2{margin:.2em 0 .05em}
.result .conf-row{margin:1em 0 1em}
.result .evidence{margin:0 0 1.1em}
.result .read{margin:0 0 .8em}
.result .reframe,.result .cost{margin:.15em 0 .8em}
.result .config-line{margin:1em 0 .9em;padding:12px 14px}
.result .aphorism{margin:1.1em 0 .2em}
.result .cta-row{margin-top:1.3em}

@media (prefers-reduced-motion:reduce){*{animation-duration:.001ms!important;transition-duration:.08s!important}}
