/* Inside the Intelligence Layer — bespoke per-section visuals (v2)
 * One visual identity per intelligence layer. Tokens from ../colors_and_type.css.
 * Reveal animations gate on `.section.in`. */

/* shared canvas frame helpers */
.cv-frame{border:1px solid var(--liq-surface-hairline);border-radius:var(--liq-radius-lg);overflow:hidden;background:var(--liq-surface-canvas);box-shadow:var(--liq-elevation-2);}
.cv-eye{margin-bottom:14px;}
.cv-svg{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;overflow:visible;z-index:0;}
.cv-svg .cl{opacity:0;animation:clfade .5s var(--ease) forwards;animation-delay:var(--d);}
@keyframes clfade{to{opacity:1;}}

/* ====================================================================
 * 01 · MARKET & VALUATION — evidence converging (investigative)
 * ==================================================================== */
.ev{position:relative;display:grid;grid-template-columns:1fr 360px;}
.ev-sources{padding:22px;display:flex;flex-direction:column;gap:10px;border-right:1px solid var(--liq-surface-hairline);background:var(--liq-surface-inset);position:relative;z-index:1;}
.ev-item{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;border-radius:var(--liq-radius-sm);background:var(--liq-surface-raised);border:1px solid var(--liq-surface-hairline);
  opacity:0;transform:translateX(-12px);transition:opacity .5s var(--ease),transform .5s var(--ease),border-color .4s var(--ease),box-shadow .4s var(--ease);transition-delay:calc(var(--i)*.08s);}
.ev-copy{flex:1;min-width:0;}
.section.in .ev-item{opacity:1;transform:none;}
.ev-item.anchored{border-color:var(--liq-confidence-400);box-shadow:0 0 0 1px var(--liq-confidence-400),0 0 14px var(--liq-confidence-glow);}
.ev-ic{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;background:var(--liq-surface-canvas);border:1px solid var(--liq-surface-focal);flex-shrink:0;}
.ev-ic svg{width:15px;height:15px;color:var(--liq-text-tertiary);transition:color .4s var(--ease);}
.ev-item.anchored .ev-ic{border-color:var(--liq-confidence-400);}
.ev-item.anchored .ev-ic svg{color:var(--liq-confidence-200);}
.ev-l{font-size:13px;color:var(--liq-text-primary);}
.ev-d{display:block;font-size:11px;color:var(--liq-text-tertiary);margin-top:2px;line-height:1.3;}
.ev-m{margin-left:auto;font-family:var(--mono);font-size:10px;color:var(--liq-text-tertiary);white-space:normal;text-align:right;flex-shrink:0;max-width:42%;line-height:1.3;}

/* broker/lender output rows — allow long platform-style labels to wrap */
.wrow{align-items:flex-start;}
.wrow-val{white-space:normal;text-align:right;line-height:1.3;max-width:54%;flex-shrink:0;}
.wrow-label{word-break:break-word;}
.wf-sub{line-height:1.45;word-break:break-word;}
.wf-lab{line-height:1.35;}
.ev-verdict{padding:26px 24px;display:flex;flex-direction:column;justify-content:center;gap:0;position:relative;z-index:1;background:linear-gradient(180deg,var(--liq-surface-canvas),var(--liq-surface-raised));}
.ev-block{padding-bottom:20px;}
.ev-block + .ev-block{border-top:1px solid var(--liq-surface-hairline);padding-top:20px;}
.ev-block .lab{font-family:var(--mono);font-size:9.5px;letter-spacing:0.12em;text-transform:uppercase;color:var(--liq-text-quaternary);margin-bottom:6px;line-height:1.4;}
.ev-block .ev-band{height:7px;border-radius:4px;background:var(--liq-surface-inset);position:relative;overflow:hidden;margin:14px 0 8px;}
.ev-block .ev-band > i{position:absolute;top:0;bottom:0;left:0;width:74%;border-radius:4px;background:linear-gradient(90deg,var(--liq-confidence-600),var(--liq-confidence-200));}
.ev-block .ev-conf{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--liq-text-tertiary);}
.ev-verdict .lab{font-family:var(--mono);font-size:9.5px;letter-spacing:0.12em;text-transform:uppercase;color:var(--liq-text-quaternary);margin-bottom:6px;line-height:1.4;}
.ev-range{font-family:var(--mono);font-size:20px;font-weight:600;color:var(--liq-text-primary);font-variant-numeric:tabular-nums;letter-spacing:-0.01em;
  opacity:0;transform:translateY(6px);transition:opacity .6s var(--ease) .9s,transform .6s var(--ease) .9s;}
.section.in .ev-range{opacity:1;transform:none;}
.ev-band{height:7px;border-radius:4px;background:var(--liq-surface-inset);position:relative;overflow:hidden;margin:14px 0 8px;}
.ev-band > i{position:absolute;top:0;bottom:0;left:0;width:0;border-radius:4px;background:linear-gradient(90deg,var(--liq-confidence-600),var(--liq-confidence-200));transition:width 1.1s var(--ease-compute) 1s;}
.section.in .ev-band > i{width:74%;}
.ev-conf{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--liq-text-tertiary);}

/* ====================================================================
 * 02 · FINANCIAL DECISION ENGINE — balance sheet assembling (computational)
 * ==================================================================== */
.lg{display:grid;grid-template-columns:0.85fr 1.15fr;gap:24px;align-items:start;}
.lg-inputs{display:flex;flex-direction:column;gap:8px;}
.lg-chip{display:flex;align-items:center;gap:11px;padding:11px 13px;border-radius:var(--liq-radius-sm);background:var(--liq-surface-raised);border:1px solid var(--liq-surface-hairline);
  font-size:12.5px;color:var(--liq-text-secondary);opacity:0;transform:translateX(-10px);transition:opacity .45s var(--ease),transform .45s var(--ease);transition-delay:calc(var(--i)*.07s);}
.section.in .lg-chip{opacity:1;transform:none;}
.lg-chip svg{width:14px;height:14px;color:var(--liq-text-tertiary);flex-shrink:0;}
.lg-chip .pip{margin-left:auto;width:5px;height:5px;border-radius:50%;background:var(--liq-surface-focal);}
.section.in .lg-chip .pip{animation:lgpip .5s var(--ease) forwards;animation-delay:calc(.6s + var(--i)*.12s);}
@keyframes lgpip{to{background:var(--liq-gold-300);box-shadow:0 0 8px var(--liq-gold-glow);}}
.lg-model{border:1px solid var(--liq-surface-focal);border-radius:var(--liq-radius-md);background:var(--liq-surface-inset);overflow:hidden;box-shadow:var(--liq-elevation-2);}
.lg-model-head{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;border-bottom:2px solid var(--liq-gold-400);background:var(--liq-surface-canvas);}
.lg-model-head .t{font-size:12.5px;font-weight:600;color:var(--liq-text-primary);}
.lg-model-head .s{font-family:var(--mono);font-size:8.5px;letter-spacing:0.1em;text-transform:uppercase;color:var(--liq-gold-300);}
.lg-rows{padding:6px 18px 14px;}
.lg-row{display:flex;align-items:flex-start;justify-content:space-between;padding:11px 0;border-bottom:1px dashed var(--liq-surface-focal);
  opacity:0;transform:translateY(8px);transition:opacity .5s var(--ease),transform .5s var(--ease);transition-delay:calc(.5s + var(--i)*.13s);}
.section.in .lg-row{opacity:1;transform:none;}
.lg-row:last-child{border-bottom:none;}
.lg-row .l{flex:1;min-width:0;font-size:12.5px;color:var(--liq-text-tertiary);line-height:1.35;padding-right:10px;}
.lg-row .v{flex-shrink:0;font-family:var(--mono);font-size:15px;font-weight:600;color:var(--liq-text-primary);font-variant-numeric:tabular-nums;text-align:right;}
.lg-row .v.pass{color:var(--liq-pass-200);}
.lg-seal{display:flex;align-items:center;gap:8px;padding:13px 18px;border-top:2px double var(--liq-gold-400);background:var(--liq-surface-canvas);
  font-family:var(--mono);font-size:10px;letter-spacing:0.04em;color:var(--liq-gold-200);}
.lg-seal svg{width:13px;height:13px;}

/* ====================================================================
 * 03 · STRESS RESILIENCE — live deal under worsening conditions
 * ==================================================================== */
.st{position:relative;}
.st-track{position:relative;display:flex;justify-content:space-between;margin:4px 6px 30px;padding-top:26px;}
.st-track::before{content:"";position:absolute;left:0;right:0;top:32px;height:2px;background:var(--liq-surface-hairline);}
.st-track .st-prog{position:absolute;left:0;top:32px;height:2px;background:linear-gradient(90deg,var(--liq-pass-400),var(--liq-caution-400),var(--liq-risk-400));transition:width .6s var(--ease-compute);width:0;}
.st-tick{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:8px;flex:1;}
.st-dot{width:12px;height:12px;border-radius:50%;background:var(--liq-surface-overlay);border:1.5px solid var(--liq-surface-focal);transition:all .3s var(--ease);}
.st-tick.past .st-dot{background:var(--liq-text-tertiary);border-color:var(--liq-text-tertiary);}
.st-tick.cur .st-dot{transform:scale(1.35);}
.st-tick.cur.c-pass .st-dot{background:var(--liq-pass-400);border-color:var(--liq-pass-200);box-shadow:0 0 0 4px var(--liq-pass-glow);}
.st-tick.cur.c-cau .st-dot{background:var(--liq-caution-400);border-color:var(--liq-caution-200);box-shadow:0 0 0 4px var(--liq-caution-glow);}
.st-tick.cur.c-risk .st-dot{background:var(--liq-risk-400);border-color:var(--liq-risk-200);box-shadow:0 0 0 4px var(--liq-risk-glow);}
.st-tlab{font-family:var(--mono);font-size:9px;letter-spacing:0.04em;color:var(--liq-text-quaternary);text-align:center;max-width:14ch;line-height:1.3;transition:color .3s var(--ease);}
.st-tick.cur .st-tlab{color:var(--liq-text-primary);}
.st-readouts{display:grid;grid-template-columns:1fr 1.4fr 1fr;gap:16px;}
.st-ro{border:1px solid var(--liq-surface-hairline);border-radius:var(--liq-radius-md);background:var(--liq-surface-raised);padding:16px 18px;}
.st-ro .lab{font-family:var(--mono);font-size:9px;letter-spacing:0.1em;text-transform:uppercase;color:var(--liq-text-quaternary);margin-bottom:10px;}
.st-ro .big{font-family:var(--mono);font-size:26px;font-weight:600;color:var(--liq-text-primary);font-variant-numeric:tabular-nums;letter-spacing:-0.02em;line-height:1.15;transition:color .35s var(--ease);}
.st-ro .big.pass{color:var(--liq-pass-200);}.st-ro .big.cau{color:var(--liq-caution-200);}.st-ro .big.risk{color:var(--liq-risk-200);}
.st-ro .unit{display:inline-block;font-size:11px;color:var(--liq-text-tertiary);margin-left:3px;line-height:1.2;vertical-align:baseline;}
.st-vector .vt{flex:1;min-width:0;line-height:1.4;}
.st-meter{height:9px;border-radius:5px;background:var(--liq-surface-inset);overflow:hidden;margin-top:14px;}
.st-meter > i{display:block;height:100%;border-radius:5px;width:96%;transition:width .55s var(--ease-compute),background .35s var(--ease);background:var(--liq-pass-400);}
.st-vector{margin-top:16px;display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--liq-radius-md);
  border:1px solid var(--liq-surface-hairline);background:var(--liq-surface-canvas);transition:all .35s var(--ease);}
.st-vector svg{width:16px;height:16px;color:var(--liq-text-quaternary);transition:color .35s var(--ease);flex-shrink:0;}
.st-vector .vt{font-size:12.5px;color:var(--liq-text-tertiary);transition:color .35s var(--ease);}
.st-vector.alarm{border-color:var(--liq-caution-400);background:var(--liq-caution-glow);}
.st-vector.alarm svg,.st-vector.alarm .vt{color:var(--liq-caution-200);}
.st-vector.fail{border-color:var(--liq-risk-400);background:var(--liq-risk-glow);}
.st-vector.fail svg,.st-vector.fail .vt{color:var(--liq-risk-200);}

/* ====================================================================
 * 04 · EXIT VIABILITY — two competing journeys (route planning)
 * ==================================================================== */
.rt{display:flex;flex-direction:column;gap:16px;}
.rt-lane{position:relative;border:1px solid var(--liq-surface-hairline);border-radius:var(--liq-radius-md);background:var(--liq-surface-canvas);
  display:grid;grid-template-columns:160px 1fr 132px;gap:20px;align-items:center;padding:18px 20px;overflow:hidden;
  opacity:0;transform:translateY(12px);transition:opacity .6s var(--ease),transform .6s var(--ease);transition-delay:calc(var(--i)*.18s);}
.section.in .rt-lane{opacity:1;transform:none;}
.rt-lane::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;}
.rt-lane.pass::before{background:var(--liq-pass-400);}
.rt-lane.cau::before{background:var(--liq-caution-400);}
.rt-head{display:flex;align-items:center;gap:11px;}
.rt-head .ic{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:var(--liq-surface-raised);border:1px solid var(--liq-surface-focal);flex-shrink:0;}
.rt-head .ic svg{width:17px;height:17px;}
.rt-lane.pass .rt-head .ic{border-color:var(--liq-pass-400);}.rt-lane.pass .rt-head .ic svg{color:var(--liq-pass-200);}
.rt-lane.cau .rt-head .ic{border-color:var(--liq-caution-400);}.rt-lane.cau .rt-head .ic svg{color:var(--liq-caution-200);}
.rt-head .nm{font-size:14.5px;font-weight:600;color:var(--liq-text-primary);}
.rt-head .tag{font-family:var(--mono);font-size:9px;letter-spacing:0.06em;text-transform:uppercase;color:var(--liq-text-quaternary);}
.rt-stops{display:flex;align-items:center;position:relative;}
.rt-stops::before{content:"";position:absolute;left:6px;right:6px;top:11px;height:1.5px;background:var(--liq-surface-hairline);}
.rt-stop{position:relative;z-index:1;flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;}
.rt-stop .node{width:11px;height:11px;border-radius:50%;background:var(--liq-surface-overlay);border:1.5px solid var(--liq-surface-focal);}
.rt-lane.pass .rt-stop .node{border-color:var(--liq-pass-400);}
.rt-lane.cau .rt-stop .node{border-color:var(--liq-caution-400);}
.rt-stop .sl{font-size:9.5px;color:var(--liq-text-quaternary);max-width:13ch;line-height:1.25;}
.rt-stop .sv{font-family:var(--mono);font-size:12px;font-weight:600;color:var(--liq-text-primary);font-variant-numeric:tabular-nums;}
.rt-stop .sv.pass{color:var(--liq-pass-200);}.rt-stop .sv.cau{color:var(--liq-caution-200);}
.rt-packet{position:absolute;top:8px;left:0;width:7px;height:7px;border-radius:50%;z-index:2;opacity:0;}
.rt-lane.pass .rt-packet{background:var(--liq-pass-200);box-shadow:0 0 8px var(--liq-pass-glow);}
.rt-lane.cau .rt-packet{background:var(--liq-caution-200);box-shadow:0 0 8px var(--liq-caution-glow);}
.section.in .rt-packet{animation:rtrun 2.6s var(--ease-compute) infinite;animation-delay:calc(.6s + var(--i)*.3s);}
@keyframes rtrun{0%{opacity:0;left:2%;}12%{opacity:1;}88%{opacity:1;}100%{opacity:0;left:98%;}}
.rt-verdict{text-align:right;}
.rt-verdict .vw{font-size:13px;font-weight:600;}
.rt-lane.pass .rt-verdict .vw{color:var(--liq-pass-200);}
.rt-lane.cau .rt-verdict .vw{color:var(--liq-caution-200);}
.rt-verdict .vh{font-family:var(--mono);font-size:22px;font-weight:600;color:var(--liq-text-primary);font-variant-numeric:tabular-nums;letter-spacing:-0.01em;margin-top:2px;}

/* ====================================================================
 * 05 · PLACEMENT & PRODUCT FIT — institutional matrix
 * ==================================================================== */
.mx{position:relative;}
.mx-grid{display:grid;border:1px solid var(--liq-surface-hairline);border-radius:var(--liq-radius-lg);overflow:hidden;background:var(--liq-surface-hairline);gap:1px;}
.mx-cell{background:var(--liq-surface-canvas);padding:13px 12px;display:flex;align-items:center;}
.mx-cell.head{background:var(--liq-surface-raised);justify-content:center;}
.mx-cell.head .pl{font-family:var(--mono);font-size:9.5px;letter-spacing:0.06em;text-transform:uppercase;color:var(--liq-text-tertiary);text-align:center;}
.mx-cell.corner{background:var(--liq-surface-raised);}
.mx-cell.rowlab{background:var(--liq-surface-inset);}
.mx-cell.rowlab .cl{font-size:12px;color:var(--liq-text-secondary);}
.mx-fit{justify-content:center;}
.mx-mark{width:100%;max-width:46px;height:24px;border-radius:var(--liq-radius-xs);display:grid;place-items:center;font-family:var(--mono);font-size:8.5px;letter-spacing:0.04em;text-transform:uppercase;
  opacity:0;transform:scale(.6);transition:opacity .4s var(--ease),transform .4s var(--liq-ease-spring);transition-delay:calc(var(--i)*.035s);}
.section.in .mx-mark{opacity:1;transform:none;}
.mx-mark.within{background:var(--liq-pass-glow);color:var(--liq-pass-200);border:1px solid var(--liq-pass-400);}
.mx-mark.near{background:var(--liq-caution-glow);color:var(--liq-caution-200);border:1px solid var(--liq-caution-400);}
.mx-mark.outside{background:var(--liq-risk-glow);color:var(--liq-risk-200);border:1px solid var(--liq-surface-hairline);opacity:.5;}
.section.in .mx-mark.outside{opacity:.55;}
.mx-legend{display:flex;gap:18px;margin-top:16px;flex-wrap:wrap;}
.mx-legend span{display:flex;align-items:center;gap:7px;font-family:var(--mono);font-size:9.5px;letter-spacing:0.06em;text-transform:uppercase;color:var(--liq-text-tertiary);}
.mx-legend i{width:12px;height:12px;border-radius:3px;}
.mx-legend i.within{background:var(--liq-pass-glow);border:1px solid var(--liq-pass-400);}
.mx-legend i.near{background:var(--liq-caution-glow);border:1px solid var(--liq-caution-400);}
.mx-legend i.outside{background:var(--liq-risk-glow);border:1px solid var(--liq-surface-hairline);}

/* ====================================================================
 * 06 · PRE-UNDERWRITING — investigation board (credit committee briefing)
 * ==================================================================== */
.bd{position:relative;display:grid;grid-template-columns:208px 1fr 1fr;gap:20px;align-items:start;}
.bd-col-eye{margin-bottom:12px;}
.bd-pins{display:flex;flex-direction:column;gap:9px;position:relative;z-index:1;}
.bd-pin{position:relative;display:flex;align-items:flex-start;gap:10px;padding:11px 13px;border-radius:var(--liq-radius-sm);background:var(--liq-surface-raised);border:1px solid var(--liq-surface-hairline);
  flex-wrap:wrap;row-gap:4px;
  opacity:0;transform:translateX(-10px) rotate(-.4deg);transition:opacity .45s var(--ease),transform .45s var(--ease);transition-delay:calc(var(--i)*.08s);}
.section.in .bd-pin{opacity:1;transform:none;}
.bd-pin::before{content:"";position:absolute;top:-4px;left:50%;transform:translateX(-50%);width:6px;height:6px;border-radius:50%;background:var(--liq-gold-400);box-shadow:0 0 6px var(--liq-gold-glow);}
.bd-pin svg{width:14px;height:14px;color:var(--liq-text-tertiary);flex-shrink:0;}
.bd-pin .pl{font-size:12.5px;color:var(--liq-text-primary);}
.bd-pin .pl{flex:1;min-width:0;line-height:1.3;}
.bd-pin .pn{margin-left:0;flex:1 1 100%;padding-left:24px;font-family:var(--mono);font-size:9px;color:var(--liq-text-tertiary);white-space:normal;line-height:1.3;max-width:none;}
.bd-panel{border:1px solid var(--liq-surface-hairline);border-radius:var(--liq-radius-md);background:var(--liq-surface-canvas);padding:16px 18px;position:relative;z-index:1;}
.bd-panel .ph{font-family:var(--mono);font-size:9px;letter-spacing:0.12em;text-transform:uppercase;color:var(--liq-text-quaternary);margin-bottom:12px;display:flex;align-items:center;gap:7px;}
.bd-panel .ph svg{width:13px;height:13px;}
.bd-line{display:flex;align-items:flex-start;gap:9px;padding:9px 0;border-bottom:1px solid rgba(30,37,49,0.55);
  opacity:0;transform:translateY(6px);transition:opacity .45s var(--ease),transform .45s var(--ease);transition-delay:calc(.4s + var(--i)*.1s);}
.section.in .bd-line{opacity:1;transform:none;}
.bd-line:last-child{border-bottom:none;}
.bd-line .dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;margin-top:5px;}
.bd-line .dot.pass{background:var(--liq-pass-200);}.bd-line .dot.cau{background:var(--liq-caution-200);}.bd-line .dot.risk{background:var(--liq-risk-200);}
.bd-line .lx{font-size:12.5px;color:var(--liq-text-secondary);line-height:1.4;}
.bd-line .tag{font-family:var(--mono);font-size:8px;letter-spacing:0.08em;text-transform:uppercase;color:var(--liq-text-quaternary);display:block;margin-bottom:2px;}

/* ====================================================================
 * 07 · DEAL VIABILITY — composite (no score stands alone)
 * ==================================================================== */
.cp{position:relative;display:grid;grid-template-columns:1fr 200px 1.1fr;gap:0;align-items:center;
  border:1px solid var(--liq-surface-hairline);border-radius:var(--liq-radius-lg);overflow:visible;background:var(--liq-surface-canvas);padding:26px 24px;box-shadow:var(--liq-elevation-2);}
.cp-sources{display:flex;flex-direction:column;gap:8px;position:relative;z-index:1;}
.cp-src{display:flex;align-items:flex-start;gap:10px;padding:9px 12px;border-radius:var(--liq-radius-sm);background:var(--liq-surface-raised);border:1px solid var(--liq-surface-hairline);font-size:11.5px;color:var(--liq-text-tertiary);
  opacity:0;transform:translateX(-10px);transition:opacity .45s var(--ease),transform .45s var(--ease),border-color .4s var(--ease);transition-delay:calc(var(--i)*.08s);}
.cp-src > span:last-child{flex:1;min-width:0;line-height:1.35;}
.section.in .cp-src{opacity:1;transform:none;}
.cp-src.fired{border-color:var(--liq-confidence-400);}
.cp-src .n{width:16px;font-family:var(--mono);font-size:9px;color:var(--liq-text-quaternary);}
.cp-src svg{width:14px;height:14px;color:var(--liq-text-quaternary);transition:color .4s var(--ease);}
.cp-src.fired svg{color:var(--liq-confidence-200);}
.cp-mid{display:flex;flex-direction:column;align-items:center;gap:10px;position:relative;z-index:1;}
.cp-core{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;background:var(--liq-surface-raised);border:1px solid var(--liq-gold-400);box-shadow:0 0 0 5px var(--liq-gold-glow),0 0 26px var(--liq-gold-glow);}
.cp-core svg{width:26px;height:26px;color:var(--liq-gold-200);}
.cp-mid .cap{font-family:var(--mono);font-size:9px;letter-spacing:0.1em;text-transform:uppercase;color:var(--liq-gold-300);}
.cp-scores{display:flex;flex-direction:column;gap:9px;position:relative;z-index:1;}
.cp-score{padding:13px 15px;border-radius:var(--liq-radius-md);background:var(--liq-surface-raised);border:1px solid var(--liq-surface-hairline);
  opacity:0;transform:translateX(10px);transition:opacity .5s var(--ease),transform .5s var(--ease),border-color .4s var(--ease),box-shadow .4s var(--ease);transition-delay:calc(.5s + var(--i)*.18s);}
.section.in .cp-score{opacity:1;transform:none;}
.cp-score.lit{border-color:var(--liq-gold-400);box-shadow:0 0 0 1px var(--liq-gold-400),0 0 14px var(--liq-gold-glow);}
.cp-score .lab{font-family:var(--mono);font-size:9px;letter-spacing:0.1em;text-transform:uppercase;color:var(--liq-text-quaternary);margin-bottom:6px;}
.cp-score .v{font-family:var(--mono);font-size:22px;font-weight:600;color:var(--liq-text-primary);font-variant-numeric:tabular-nums;}
.cp-score .v.pass{color:var(--liq-pass-200);}.cp-score .v.conf{color:var(--liq-confidence-200);}
.cp-score .from{margin-top:7px;font-size:10px;color:var(--liq-text-tertiary);line-height:1.4;word-break:break-word;}

/* ====================================================================
 * 08 · EVIDENCE & READINESS — readiness improving
 * ==================================================================== */
.rd{display:grid;grid-template-columns:1.25fr 1fr;gap:24px;align-items:stretch;}
.rd-climb{position:relative;border:1px solid var(--liq-surface-hairline);border-radius:var(--liq-radius-lg);background:var(--liq-surface-canvas);padding:20px 20px 16px;box-shadow:var(--liq-elevation-2);display:flex;flex-direction:column;}
.rd-bars{flex:1;display:grid;grid-template-columns:repeat(4,1fr);gap:14px;align-items:end;min-height:188px;margin-top:8px;}
.rd-bar{display:flex;flex-direction:column;align-items:center;gap:0;height:100%;justify-content:flex-end;}
.rd-bar .col{width:100%;border-radius:var(--liq-radius-sm) var(--liq-radius-sm) 0 0;height:0;transition:height .9s var(--ease-compute);transition-delay:calc(.3s + var(--i)*.22s);position:relative;display:flex;align-items:flex-start;justify-content:center;}
.section.in .rd-bar .col{height:var(--h);}
.rd-bar .col .pct{font-family:var(--mono);font-size:13px;font-weight:600;color:var(--liq-text-primary);margin-top:-22px;font-variant-numeric:tabular-nums;}
.rd-bar .col.risk{background:linear-gradient(180deg,var(--liq-risk-400),var(--liq-risk-600));}
.rd-bar .col.cau{background:linear-gradient(180deg,var(--liq-caution-400),var(--liq-caution-600));}
.rd-bar .col.pass{background:linear-gradient(180deg,var(--liq-pass-400),var(--liq-pass-600));}
.rd-bar .stg{font-size:10px;color:var(--liq-text-tertiary);text-align:center;margin-top:10px;line-height:1.3;max-width:15ch;}
.rd-bar .cmp{font-family:var(--mono);font-size:9px;color:var(--liq-text-quaternary);margin-top:4px;}
.rd-register{border:1px solid var(--liq-surface-hairline);border-radius:var(--liq-radius-lg);background:var(--liq-surface-raised);overflow:hidden;}
.rd-reg-head{padding:13px 16px;border-bottom:1px solid var(--liq-surface-hairline);font-family:var(--mono);font-size:9px;letter-spacing:0.12em;text-transform:uppercase;color:var(--liq-text-quaternary);background:var(--liq-surface-canvas);}
.rd-reg-row{display:flex;align-items:center;gap:10px;padding:11px 16px;border-bottom:1px solid rgba(30,37,49,0.55);
  opacity:0;transform:translateX(8px);transition:opacity .45s var(--ease),transform .45s var(--ease);transition-delay:calc(.4s + var(--i)*.1s);}
.section.in .rd-reg-row{opacity:1;transform:none;}
.rd-reg-row:last-child{border-bottom:none;}
.rd-reg-row .dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;}
.rd-reg-row .dot.pass{background:var(--liq-pass-200);}.rd-reg-row .dot.cau{background:var(--liq-caution-200);}.rd-reg-row .dot.risk{background:var(--liq-risk-200);}
.rd-reg-row .rl{font-size:12.5px;color:var(--liq-text-secondary);}
.rd-reg-row .rs{margin-left:auto;font-family:var(--mono);font-size:9px;letter-spacing:0.06em;text-transform:uppercase;color:var(--liq-text-tertiary);}

/* ====================================================================
 * 09 · PIPELINE ANALYTICS — upload → engine → analyst queue
 * ==================================================================== */
.pl-flow{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:18px;}
.pl-flow .step{display:flex;align-items:center;gap:8px;}
.pl-flow .step .b{font-family:var(--mono);font-size:9px;letter-spacing:0.06em;text-transform:uppercase;color:var(--liq-text-tertiary);
  padding:6px 11px;border-radius:var(--liq-radius-sm);background:var(--liq-surface-raised);border:1px solid var(--liq-surface-hairline);white-space:nowrap;
  opacity:0;transform:translateY(6px);transition:opacity .4s var(--ease),transform .4s var(--ease);transition-delay:calc(var(--i)*.1s);}
.section.in .pl-flow .step .b{opacity:1;transform:none;}
.pl-flow .step.eng .b{border-color:var(--liq-gold-400);color:var(--liq-gold-200);}
.pl-flow .arr{color:var(--liq-text-quaternary);display:flex;}
.pl-flow .arr svg{width:13px;height:13px;}
.pl-grid{display:grid;grid-template-columns:1fr 188px 1.2fr;gap:18px;align-items:stretch;
  border:1px solid var(--liq-surface-hairline);border-radius:var(--liq-radius-lg);background:var(--liq-surface-canvas);padding:20px;box-shadow:var(--liq-elevation-2);}
.pl-zone{display:flex;flex-direction:column;}
.pl-ztitle{font-family:var(--mono);font-size:9px;letter-spacing:0.1em;text-transform:uppercase;color:var(--liq-text-quaternary);margin-bottom:12px;line-height:1.4;max-width:100%;}
.pl-deal span{flex:1;min-width:0;line-height:1.35;word-break:break-word;}
.pl-intake{border:1.5px dashed var(--liq-surface-focal);border-radius:var(--liq-radius-md);background:var(--liq-surface-inset);padding:14px;display:flex;flex-direction:column;gap:7px;flex:1;}
.pl-deal{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:10px;color:var(--liq-text-tertiary);padding:7px 9px;border-radius:var(--liq-radius-xs);background:var(--liq-surface-raised);border:1px solid var(--liq-surface-hairline);
  opacity:0;transform:translateY(6px);transition:opacity .4s var(--ease),transform .4s var(--ease);transition-delay:calc(var(--i)*.06s);}
.section.in .pl-deal{opacity:1;transform:none;}
.pl-deal svg{width:13px;height:13px;color:var(--liq-text-quaternary);flex-shrink:0;}
.pl-engine{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:11px;text-align:center;}
.pl-engine .core{width:50px;height:50px;border-radius:var(--liq-radius-md);display:grid;place-items:center;background:var(--liq-surface-raised);border:1px solid var(--liq-gold-400);box-shadow:0 0 0 4px var(--liq-gold-glow),0 0 22px var(--liq-gold-glow);}
.pl-engine .core svg{width:24px;height:24px;color:var(--liq-gold-200);}
.pl-engine .el{font-family:var(--mono);font-size:9px;letter-spacing:0.08em;text-transform:uppercase;color:var(--liq-gold-300);}
.pl-engine .es{font-family:var(--mono);font-size:9px;color:var(--liq-text-quaternary);}
.pl-engine .feedline{width:1px;flex:1;min-height:14px;background:linear-gradient(180deg,transparent,var(--liq-gold-400),transparent);}
.pl-queue{border:1px solid var(--liq-surface-hairline);border-radius:var(--liq-radius-md);background:var(--liq-surface-raised);overflow:hidden;flex:1;}
.pl-q-row{display:grid;grid-template-columns:auto 1fr auto auto;gap:10px;align-items:center;padding:10px 13px;border-bottom:1px solid rgba(30,37,49,0.55);
  opacity:0;transform:translateX(10px);transition:opacity .45s var(--ease),transform .45s var(--ease);transition-delay:calc(.5s + var(--i)*.12s);}
.section.in .pl-q-row{opacity:1;transform:none;}
.pl-q-row:last-child{border-bottom:none;}
.pl-q-rank{font-family:var(--mono);font-size:9px;color:var(--liq-text-quaternary);width:16px;}
.pl-q-id{font-family:var(--mono);font-size:11px;color:var(--liq-text-primary);}
.pl-q-band{font-family:var(--mono);font-size:8px;letter-spacing:0.06em;text-transform:uppercase;padding:2px 7px;border-radius:var(--liq-radius-xs);}
.pl-q-band.pass{background:var(--liq-pass-glow);color:var(--liq-pass-200);}
.pl-q-band.conf{background:var(--liq-confidence-glow);color:var(--liq-confidence-200);}
.pl-q-band.cau{background:var(--liq-caution-glow);color:var(--liq-caution-200);}
.pl-q-band.risk{background:var(--liq-risk-glow);color:var(--liq-risk-200);}
.pl-q-score{font-family:var(--mono);font-size:13px;font-weight:600;font-variant-numeric:tabular-nums;width:26px;text-align:right;}
.pl-q-score.pass{color:var(--liq-pass-200);}.pl-q-score.conf{color:var(--liq-confidence-200);}.pl-q-score.cau{color:var(--liq-caution-200);}.pl-q-score.risk{color:var(--liq-risk-200);}

/* ====================================================================
 * 10 · AUDIT & REPLAY — immutable ledger (institutional record)
 * ==================================================================== */
.ll{border:1px solid var(--liq-surface-hairline);border-radius:var(--liq-radius-lg);background:var(--liq-surface-inset);overflow:hidden;box-shadow:var(--liq-elevation-2);}
.ll-head{display:flex;align-items:center;gap:9px;padding:14px 20px;border-bottom:1px solid var(--liq-surface-hairline);background:var(--liq-surface-canvas);}
.ll-head svg{width:14px;height:14px;color:var(--liq-gold-300);}
.ll-head .t{font-size:12.5px;font-weight:600;color:var(--liq-text-primary);}
.ll-head .s{margin-left:auto;font-family:var(--mono);font-size:9px;letter-spacing:0.08em;text-transform:uppercase;color:var(--liq-pass-200);display:flex;align-items:center;gap:6px;}
.ll-head .s .d{width:5px;height:5px;border-radius:50%;background:var(--liq-pass-200);}
.ll-rows{padding:6px 0;}
.ll-row{display:grid;grid-template-columns:78px 24px 1fr auto;gap:12px;align-items:center;padding:12px 20px;border-bottom:1px dotted var(--liq-surface-focal);
  opacity:0;transform:translateY(6px);transition:opacity .5s var(--ease),transform .5s var(--ease);transition-delay:calc(var(--i)*.16s);}
.section.in .ll-row{opacity:1;transform:none;}
.ll-row:last-child{border-bottom:none;}
.ll-time{font-family:var(--mono);font-size:11px;color:var(--liq-text-tertiary);font-variant-numeric:tabular-nums;}
.ll-rail{display:flex;justify-content:center;}
.ll-rail .d{width:9px;height:9px;border-radius:50%;background:var(--liq-surface-overlay);border:1.5px solid var(--liq-gold-400);}
.section.in .ll-row .ll-rail .d{background:var(--liq-gold-400);transition:background .4s var(--ease);transition-delay:calc(.3s + var(--i)*.16s);}
.ll-mid{display:flex;align-items:center;gap:10px;}
.ll-mid svg{width:14px;height:14px;color:var(--liq-text-tertiary);flex-shrink:0;}
.ll-mid .lx{font-size:12.5px;color:var(--liq-text-primary);}
.ll-hash{display:flex;align-items:center;gap:7px;font-family:var(--mono);font-size:10px;color:var(--liq-text-quaternary);}
.ll-hash .seal{color:var(--liq-pass-200);display:flex;}
.ll-hash .seal svg{width:12px;height:12px;}

/* Desktop layout — natural word breaks, grid shrink safety */
@media (min-width:1024px){
  .wrow-label,.wf-sub,.cp-score .from{word-break:normal;overflow-wrap:break-word;}
  .ev{grid-template-columns:minmax(0,1fr) minmax(300px,360px);}
  .bd,.cp,.pl-grid,.rt-lane{min-width:0;}
  .bd > *,.cp > *,.pl-grid > *,.ev > *,.st-readouts > *{min-width:0;}
}

/* ====================================================================
 * Mobile — stack fixed multi-column layouts (preserve all content)
 * ==================================================================== */
@media (max-width:820px){
  .lg{grid-template-columns:1fr;gap:16px;}
  .st-readouts{grid-template-columns:1fr;gap:12px;}
  .rd{grid-template-columns:1fr;gap:16px;}
  .wf-versus{grid-template-columns:1fr;gap:10px;}
  .wf-versus .vbar{display:none;}
}

@media (max-width:760px){
  /* 01 · Market & Valuation */
  .ev{grid-template-columns:1fr;}
  .ev-sources{border-right:none;border-bottom:1px solid var(--liq-surface-hairline);}
  .ev-m{max-width:none;text-align:left;margin-left:0;}

  /* 05 · Placement matrix — scroll contained inside wrapper (no page overflow) */
  .mx{
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    width:100%;
    max-width:100%;
    min-width:0;
    box-sizing:border-box;
    contain:inline-size;
  }
  .mx-grid{min-width:520px;width:max-content;max-width:none;}

  /* 07 · Deal Viability */
  .cp{grid-template-columns:1fr;gap:18px;padding:20px 16px;}

  /* 08 · Evidence & Readiness */
  .rd-bars{min-height:160px;gap:10px;}

  /* 09 · Pipeline Analytics */
  .pl-grid{grid-template-columns:1fr;gap:16px;padding:16px;}
  .pl-flow{gap:6px;}
  .pl-q-row{grid-template-columns:auto 1fr auto;gap:8px;}
  .pl-q-band{font-size:7px;padding:2px 5px;}

  /* 10 · Audit & Replay */
  .ll-row{grid-template-columns:56px 20px 1fr;gap:8px;padding:10px 14px;}
  .ll-hash{grid-column:1 / -1;padding-left:28px;flex-wrap:wrap;gap:4px;}
}

@media (max-width:640px){
  .ev-sources,.ev-verdict{padding:18px 16px;}
  .rt-lane{padding:14px;}
  .bd-panel{padding:14px 16px;}
  .cp{padding:16px 14px;}
  .pl-grid{padding:14px;}
  .rd-bars{min-height:140px;}
  .pl-flow{align-items:flex-start;}
  .ll-row{grid-template-columns:48px 16px 1fr;gap:6px;}
  .ll-hash{font-size:9px;}
}

/* ============================================================
   MOBILE IA RECONSTRUCTION — Sec 03 Stress, Sec 04 Exit, Sec 06 Board
   Visual first, supporting card/panel after — never overlay on mobile.
   ============================================================ */

/* 03 · STRESS RESILIENCE (#sec-03 · .st)
   Main visual: .st-track → supporting cards: .st-readouts, .st-vector */
@media (max-width:820px){
  .section[data-type="stress"] .st{
    display:flex;
    flex-direction:column;
    gap:0;
  }
  .section[data-type="stress"] .st-track{
    order:1;
    flex-direction:column !important;
    align-items:flex-start !important;
    flex-wrap:nowrap !important;
    justify-content:flex-start !important;
    gap:0 !important;
    padding-top:0 !important;
    padding-left:20px !important;
    margin-bottom:20px !important;
    border-left:2px solid var(--liq-surface-hairline) !important;
    position:static !important;
  }
  .section[data-type="stress"] .st-track::before,
  .section[data-type="stress"] .st-track .st-prog{display:none !important;}
  .section[data-type="stress"] .st-tick{
    width:100% !important;
    min-width:0 !important;
    flex:none !important;
    flex-direction:row !important;
    align-items:center !important;
    gap:10px !important;
    padding:10px 0 !important;
    border-bottom:1px solid var(--liq-surface-hairline) !important;
  }
  .section[data-type="stress"] .st-tick:last-child{border-bottom:none !important;}
  .section[data-type="stress"] .st-tlab{
    max-width:none !important;
    font-size:10px !important;
    text-align:left !important;
  }
  .section[data-type="stress"] .st-readouts{
    order:2;
    position:static !important;
    margin-top:0;
  }
  .section[data-type="stress"] .st-vector{
    order:3;
    position:static !important;
    transform:none !important;
  }
}

/* 04 · EXIT VIABILITY (#sec-04 · .rt-lane)
   Main visual: .rt-stops → supporting card: .rt-verdict */
@media (max-width:820px){
  .section[data-type="routes"] .rt-lane{
    display:flex !important;
    flex-direction:column !important;
    align-items:stretch !important;
    grid-template-columns:unset !important;
    gap:14px;
    padding:16px;
  }
  .section[data-type="routes"] .rt-head{order:1;}
  .section[data-type="routes"] .rt-stops{
    order:2;
    position:static !important;
    flex-direction:column !important;
    align-items:flex-start !important;
    flex-wrap:nowrap !important;
    gap:0 !important;
    border-left:2px solid var(--liq-surface-hairline) !important;
    padding-left:16px !important;
    width:100%;
  }
  .section[data-type="routes"] .rt-stops::before{display:none !important;}
  .section[data-type="routes"] .rt-packet{display:none !important;}
  .section[data-type="routes"] .rt-stop{
    width:100% !important;
    flex-direction:row !important;
    align-items:center !important;
    gap:10px !important;
    text-align:left !important;
    padding:8px 0 !important;
    border-bottom:1px solid var(--liq-surface-hairline) !important;
  }
  .section[data-type="routes"] .rt-stop:last-child{border-bottom:none !important;}
  .section[data-type="routes"] .rt-stop .sl{
    max-width:none !important;
    text-align:left !important;
  }
  .section[data-type="routes"] .rt-verdict{
    order:3;
    position:static !important;
    transform:none !important;
    margin-top:4px;
    padding-top:14px;
    border-top:1px solid var(--liq-surface-hairline);
    text-align:left;
    width:100%;
  }
}

/* 06 · PRE-UNDERWRITING (#sec-06 · .bd)
   Main visual: .bd-pins → supporting panels: .bd-panel */
@media (max-width:820px){
  .section[data-type="board"] .bd{
    display:flex !important;
    flex-direction:column !important;
    align-items:stretch !important;
    grid-template-columns:unset !important;
    gap:16px;
  }
  .section[data-type="board"] .bd-svg{display:none !important;}
  .section[data-type="board"] .bd > div:nth-child(2){order:1;}
  .section[data-type="board"] .bd-panel{
    order:2;
    position:static !important;
    transform:none !important;
    z-index:auto !important;
    width:100%;
  }
  .section[data-type="board"] .bd-panel + .bd-panel{order:3;}
  .section[data-type="board"] .bd-pins{
    position:static !important;
    z-index:auto !important;
  }
}

/* 05 · PRODUCT FIT — matrix scroll containment (inherits 760px .mx rules) */
@media (max-width:640px){
  .section[data-type="matrix"] .mx,
  .section:has(.mx) .mx{
    width:100%;
    max-width:100%;
    min-width:0;
  }
}

/* 07 · DEAL VIABILITY — centre core (engine node) above sources
   and scores in the single-column stacked layout */
@media (max-width:640px){
  .cp{
    grid-template-columns:1fr !important;
    grid-template-rows:auto auto auto !important;
    gap:16px !important;
  }
  .cp-mid{order:1;}
  .cp-sources{order:2;}
  .cp-scores{order:3;}
}

/* ============================================================
   MOBILE OUTCOME BOXES — section "Why this matters" text only
   ============================================================ */
@media (max-width:820px){
  .outcome {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
    height: auto;
    max-height: none;
    overflow: visible;
    align-items: flex-start;
  }

  .outcome > div {
    flex: 1;
    min-width: 0;
    max-width: 100%;
    box-sizing: border-box;
    height: auto;
    max-height: none;
    overflow: visible;
    align-items: flex-start;
  }

  .outcome p,
  .outcome .lab,
  .outcome .boundary,
  .outcome .boundary span {
    white-space: normal;
    text-overflow: clip;
    overflow: visible;
    overflow-wrap: break-word;
    word-break: break-word;
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
  }

  .outcome .boundary {
    align-items: flex-start;
  }

  .outcome .boundary span {
    flex: 1;
  }
}
