/* _solutions.css - the homepage design system, extracted for the 10 Solutions pages.
   Ported from index.html's inline CSS (2026-07-02). Nav + footer stay in _chrome.css,
   which loads AFTER this file so its chrome rules win ties. Per-page unique section
   styles live inline on each page and may only use the tokens defined here. */

/* ---------- tokens + reset ---------- */
:root{
  --bg:#fcfcfd; --card:#ffffff; --text:#161820; --muted:#586072; --line:#e6e9ef; --line-soft:#eef1f5;
  --teal:#0e7c86; --teal-deep:#0a5f68; --teal-bright:#3aa6ae; --teal-pale:#8ad6d4;
  --on-teal:#f1fbfb; --on-teal-dim:#bfe4e4;
  --teal-tint:color-mix(in oklab, var(--teal), white 92%);
  --bric:'Bricolage Grotesque',system-ui,sans-serif;
  --display:'Sora','Bricolage Grotesque',sans-serif;
  --mono:'Space Grotesk',sans-serif;
  --shadow-card:0 1px 2px rgb(20 24 32/.04), 0 8px 24px rgb(20 24 32/.06);
  --shadow-float:0 30px 80px -28px rgb(8 40 44/.55);
  --shadow-pop:0 18px 44px -20px rgb(8 40 44/.25), 0 2px 8px -4px rgb(8 40 44/.08);
  --ok:#1e7a4d; --warn:#8a6300; --danger:#b23b33; --bg-side:#f4f6f9;
  --accent-text:#0b656f; /* consumed by _chrome.css (mega-nav "all" link); undefined elsewhere */
}
*{box-sizing:border-box;margin:0;padding:0}
/* teal canvas: overscroll bounce above the hero (and below the footer) shows brand
   teal instead of the white the light body would otherwise propagate there */
html{scroll-behavior:smooth;background:var(--teal)}
body{font-family:var(--bric);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.5}
h1,h2{font-family:var(--display)}
a{text-decoration:none;color:inherit}
.wrap{width:min(100% - 40px, 1200px);margin-inline:auto}
.imp{font-family:var(--display);font-weight:800;font-style:normal;letter-spacing:-.02em}

/* teal scrollbar */
html{scrollbar-width:thin;scrollbar-color:var(--teal) var(--bg)}
::-webkit-scrollbar{width:13px;height:13px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--teal);border-radius:999px;border:3px solid var(--bg)}
::-webkit-scrollbar-thumb:hover{background:var(--teal-deep)}

/* ---------- buttons ---------- */
.btn{font-family:var(--bric);font-weight:650;cursor:pointer;border:1px solid transparent;display:inline-flex;align-items:center;gap:8px;border-radius:10px;transition:transform .15s ease, background .15s ease, box-shadow .15s ease}
.btn:active{transform:translateY(1px)}
.btn-teal{background:var(--teal);color:#fff;padding:9px 17px;font-size:14px}
.btn-teal:hover{background:var(--teal-deep);box-shadow:0 8px 22px -8px rgb(14 124 134/.6)}
.btn-ghost-d{border-color:var(--line);color:var(--text);background:var(--card);padding:9px 16px;font-size:14px}
.btn-ghost-d:hover{border-color:#cfd5df;background:#fff}
.btn-lg{padding:13px 26px;font-size:15px}
.link-teal{color:var(--teal);font-weight:650}

/* ---------- hero (teal gradient band, homepage treatment) ---------- */
.hero{position:relative;overflow:hidden;color:var(--on-teal);padding-top:88px;
  min-height:100vh;min-height:min(100svh,1100px);
  display:flex;flex-direction:column;justify-content:center;
  background:
    radial-gradient(120% 130% at 92% 4%, rgba(138,214,212,.28), transparent 52%),
    radial-gradient(90% 130% at -5% 105%, rgba(10,95,104,.6), transparent 60%),
    linear-gradient(152deg, var(--teal) 0%, var(--teal-deep) 100%);background-color:var(--teal-deep);}
.hero::after{content:"";position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:48px 48px;mask-image:radial-gradient(85% 80% at 75% 25%,#000,transparent 78%);opacity:.3}
/* .hero--sub kept as a page hook only: sub-page heroes fill the viewport like the
   homepage (operator rule 2026-07-03); the base .hero min-height governs all pages. */
.hero--sub{min-height:100vh;min-height:min(100svh,1100px)}
.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,64px);align-items:center;
  padding-block:clamp(14px,2vw,28px) clamp(48px,6vw,84px)}
h1.head{font-weight:800;letter-spacing:-.035em;line-height:1.01;font-size:clamp(30px,4.2vw,53px);text-wrap:balance}
h1.head em{font-style:normal;color:var(--teal-pale)}
.hero p.sub{margin-top:22px;max-width:46ch;font-size:clamp(16px,1.4vw,19px);color:var(--on-teal-dim);line-height:1.55}
.hero .ctas{display:flex;flex-wrap:wrap;gap:13px;margin-top:32px}
.btn-light{background:var(--on-teal);color:var(--teal-deep);padding:13px 22px;font-size:15px;font-weight:700}
.btn-light:hover{background:#fff;box-shadow:0 12px 30px -10px rgb(0 0 0/.3)}
.btn-onteal{background:rgba(255,255,255,.07);color:var(--on-teal);border-color:rgba(255,255,255,.28);padding:13px 20px;font-size:15px}
.btn-onteal:hover{background:rgba(255,255,255,.13)}
.trust{margin-top:30px;font-size:13.5px;color:var(--on-teal-dim)}
@keyframes dotpulse{0%{box-shadow:0 0 0 0 rgba(138,214,212,.55)}70%{box-shadow:0 0 0 8px rgba(138,214,212,0)}100%{box-shadow:0 0 0 0 rgba(138,214,212,0)}}
/* on-teal hero chips: compact in-hero index/link row for text-led full-viewport heroes */
.hchips{display:flex;flex-wrap:wrap;gap:9px;margin-top:30px}
.hchip{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.24);border-radius:999px;
  padding:8px 15px;font-size:13px;font-weight:650;color:var(--on-teal);transition:background .2s,border-color .2s}
.hchip:hover{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.4)}
.hchip .k{font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.05em;color:var(--on-teal-dim)}
/* scroll cue pinned to the hero's bottom edge (short text-only heroes) */
.scue{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);z-index:1;color:var(--on-teal-dim);pointer-events:none}
.scue svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;display:block}
@media (prefers-reduced-motion:no-preference){.scue svg{animation:scuebob 2.4s ease-in-out infinite}}
@keyframes scuebob{0%,100%{transform:translateY(0)}50%{transform:translateY(7px)}}

/* ---------- product mockup (light card floating on teal) ---------- */
.mock{background:var(--card);border-radius:16px;box-shadow:var(--shadow-float);overflow:hidden;color:var(--text);border:1px solid rgba(255,255,255,.5)}
.mock--light{border-color:var(--line);box-shadow:var(--shadow-pop)}
.mock-bar{display:flex;align-items:center;gap:7px;padding:11px 14px;border-bottom:1px solid var(--line-soft);background:#fafbfc}
.mock-bar i{width:11px;height:11px;border-radius:50%;background:#e2e6ec;display:flex;align-items:center;justify-content:center;font-style:normal;font-size:8px;line-height:1;font-weight:700;color:rgba(0,0,0,.5)}
.mock-bar .url{margin-left:8px;font-family:var(--mono);font-size:10.5px;color:var(--muted)}
/* shared 1:1 app shell (mirrors the real app's base.html: sidebar > topbar > content) */
.osh{display:grid;grid-template-columns:146px minmax(0,1fr);background:var(--bg);color:var(--text);text-align:left}
.osh-side{background:var(--bg-side);border-right:1px solid var(--line-soft);padding:10px 8px 12px;display:flex;flex-direction:column;gap:2px;min-width:0}
.osh-brand{display:flex;align-items:center;gap:6px;font-weight:800;font-size:11.5px;letter-spacing:-.01em;padding:1px 7px 9px}
.osh-brand svg{width:14px;height:14px;flex-shrink:0}
.osh-item{display:flex;align-items:center;gap:7px;padding:5px 8px;border-radius:7px;font-size:10.8px;font-weight:550;color:var(--muted);white-space:nowrap}
.osh-item svg{width:11.5px;height:11.5px;stroke:currentColor;fill:none;flex-shrink:0}
.osh-item.on{background:#e7eef0;color:var(--teal-deep);font-weight:700}
.osh-count{margin-left:auto;font-family:var(--mono);font-size:8.5px;font-weight:700;background:var(--teal);color:#fff;border-radius:999px;padding:1px 5px}
.osh-chev{margin-left:auto;opacity:.5}
.osh-sec{font-family:var(--mono);font-size:8.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:#8b93a3;padding:9px 8px 3px}
.osh-main{display:flex;flex-direction:column;min-width:0}
.osh-top{display:flex;align-items:center;gap:8px;padding:8px 13px;border-bottom:1px solid var(--line-soft);background:var(--card)}
.osh-top h4,.osh-top .osh-name{font-size:12px;font-weight:700;letter-spacing:-.01em}
.osh-av{margin-left:auto;width:20px;height:20px;border-radius:50%;background:var(--teal);color:#fff;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.osh-body{flex:1;min-width:0;padding:11px;background:var(--bg)}
.osh-card{background:var(--card);border:1px solid var(--line-soft);border-radius:10px;overflow:hidden;display:flex;flex-direction:column;min-width:0}
.osh-card-h{display:flex;align-items:center;gap:6px;padding:8px 11px;border-bottom:1px solid var(--line-soft);font-size:11px;font-weight:700}
.osh-card-h svg{width:12px;height:12px;stroke:var(--teal);fill:none;flex-shrink:0}
@media (max-width:520px){.osh{grid-template-columns:1fr}.osh-side{display:none}}
/* approvals rows + stat tiles */
.apr-row{display:flex;align-items:center;gap:8px;padding:8px 11px;border-bottom:1px solid var(--line-soft)}
.apr-tx{min-width:0}
.apr-t{font-size:10.5px;font-weight:650;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.apr-d{font-size:9.4px;color:var(--muted);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.apr-btn{margin-left:auto;flex-shrink:0;font-size:9.4px;font-weight:700;color:#fff;background:var(--teal);border-radius:6px;padding:4px 8px}
.apr-btn.ghost{background:#fff;color:var(--text);border:1px solid var(--line)}
.apr-act{padding:2px 11px 6px}
.apr-act .al{display:flex;align-items:center;gap:7px;font-size:9.7px;color:var(--muted);padding:5px 0;border-bottom:1px solid var(--line-soft)}
.apr-act .al:last-child{border-bottom:none}
.apr-act .al i{width:5px;height:5px;border-radius:50%;background:var(--teal-pale);flex-shrink:0}
.apr-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:9px 11px;margin-top:auto;border-top:1px solid var(--line-soft)}
.apr-stat .k{font-family:var(--mono);font-size:14px;font-weight:700;color:var(--teal-deep)}
.apr-stat .l{font-size:9.2px;color:var(--muted);margin-top:1px;white-space:nowrap}

/* ---------- chat surface ---------- */
.chat{display:flex;flex-direction:column;background:var(--card)}
.chat-head{display:flex;align-items:center;gap:10px;padding:13px 16px;border-bottom:1px solid var(--line-soft)}
.chat-mk{width:30px;height:30px;border-radius:9px;background:var(--teal-tint);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.chat-mk svg{width:18px;height:18px}
.chat-id{display:flex;flex-direction:column;font-weight:700;font-size:13.5px;color:var(--text);line-height:1.3}
.chat-on{display:inline-flex;align-items:center;gap:5px;font-weight:500;font-size:11px;color:var(--muted)}
.chat-on .dot{width:6px;height:6px;border-radius:50%;background:#28c840;animation:dotpulse 2.2s ease-out infinite}
.chat-msgs{display:flex;flex-direction:column;gap:10px;padding:16px;min-height:216px;background:linear-gradient(#fbfcfd,#f6f9fb)}
.cm{display:flex;max-width:86%}
.cm-a{align-self:flex-start}
.cm-u{align-self:flex-end}
.cm-b{font-size:12.5px;line-height:1.5;padding:9px 12px;border-radius:14px}
.cm-a .cm-b{background:#fff;border:1px solid var(--line-soft);color:var(--text);border-bottom-left-radius:5px}
.cm-u .cm-b{background:var(--teal);color:#fff;border-bottom-right-radius:5px}
.cm-run{display:flex;align-items:center;gap:6px;margin:8px 0;font-family:var(--mono);font-size:10px;font-weight:600;color:var(--teal-deep);background:var(--teal-tint);padding:5px 9px;border-radius:8px;letter-spacing:.01em}
.cm-run.amber{color:#9a5b00;background:#fff5e3}
.cm-run .rd{width:6px;height:6px;border-radius:50%;background:#28c840;flex-shrink:0}
.cm-run.amber .rd{background:#f2a900}
.chat-bar{display:flex;align-items:center;gap:10px;margin:13px 16px 16px;padding:7px 7px 7px 14px;border:1px solid var(--line);border-radius:999px;background:#fff}
.cb-t{flex:1;font-size:12.5px;color:var(--muted)}
.cb-send{width:30px;height:30px;border-radius:50%;background:var(--teal);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}

/* ---------- shared sections ---------- */
.sec{padding:clamp(40px,5vw,68px) 0;position:relative}
.sec-head{max-width:680px;margin:0 auto clamp(34px,5vw,52px);text-align:center}
.sec h2{font-size:clamp(28px,3.5vw,44px);font-weight:800;letter-spacing:-.025em;line-height:1.07;color:var(--text);text-wrap:balance}
.sec h2 em{font-style:normal;color:var(--teal)}
.sec-sub{margin-top:18px;font-size:clamp(15.5px,1.25vw,18px);color:var(--muted);line-height:1.6}
.sec-cta{margin-top:clamp(34px,5vw,46px);text-align:center}
/* teal band variant */
.sec.space{background:radial-gradient(120% 130% at 82% -4%,rgba(138,214,212,.22),transparent 55%),linear-gradient(168deg,var(--teal-deep) 0%,var(--teal) 56%,var(--teal-deep) 100%);overflow:hidden}
.sec.space h2{color:#fff}
.sec.space h2 em{color:var(--teal-pale)}
.sec.space .sec-sub{color:#d7eeef}

/* ---------- how-it-works rail (numbered beats, earned by real sequences) ---------- */
.hiw{display:grid;grid-template-columns:1fr 40px 1fr 40px 1fr;align-items:start;max-width:1020px;margin:clamp(30px,4vw,48px) auto 0}
.hiw-step{padding:6px clamp(6px,1.4vw,18px)}
.hiw-step .n{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:10px;background:color-mix(in oklab,var(--teal),transparent 90%);color:var(--teal);font-family:var(--mono);font-weight:700;font-size:14px;margin-bottom:14px}
.hiw-step h3{font-size:18px;font-weight:750;letter-spacing:-.015em;color:var(--text);margin-bottom:9px}
.hiw-step p{font-size:14px;color:var(--muted);line-height:1.6;max-width:34ch}
.hiw-arrow{display:flex;align-items:center;justify-content:center;height:32px;margin-top:6px;color:color-mix(in oklab,var(--teal),transparent 55%)}
.hiw-arrow svg{width:19px;height:19px}
.hiw-foot{text-align:center;margin-top:clamp(26px,3.4vw,36px);font-size:14px;color:var(--muted)}
.hiw-foot a{color:var(--teal);font-weight:650}
@media (max-width:760px){.hiw{grid-template-columns:1fr;max-width:440px}.hiw-step{padding:6px 4px}.hiw-arrow{height:34px;margin:8px 0;transform:rotate(90deg)}}

/* ---------- pillar row + autonomy widgets ---------- */
.leash{max-width:1020px;margin:clamp(30px,4vw,48px) auto 0}
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.8vw,36px)}
.pillar{text-align:left;padding:6px clamp(6px,1.4vw,18px)}
.pillar h3{font-size:18px;font-weight:750;letter-spacing:-.015em;color:var(--text);margin:0 0 8px;display:flex;align-items:center;gap:11px}
.pillar h3 svg{width:21px;height:21px;stroke:var(--teal);fill:none;flex-shrink:0}
.pillar p{font-size:14px;color:var(--muted);line-height:1.6;max-width:34ch}
.agents-mock{box-shadow:var(--shadow-pop);border:1px solid var(--line);border-radius:14px;max-width:620px;margin:clamp(28px,3.8vw,42px) auto 0}
.agents-mock .dm-h{font-size:13.5px;padding:12px 16px}
.agents-mock .dm-row{padding:12px 16px;gap:10px}
.agents-mock .dm-av{width:26px;height:26px;font-size:10px}
.agents-mock .dm-t{font-size:13px}
.agents-mock .dm-d{font-size:11px}
.agents-mock .dm-tgl{font-size:11.5px;padding:12px 16px}
.agents-mock .dm-btn{font-size:11px;padding:6px 12px}
.dm-seg{display:inline-flex;border:1px solid var(--line);border-radius:8px;overflow:hidden;margin-left:auto;flex-shrink:0}
.dm-seg span{font-size:10px;font-weight:650;padding:4px 9px;color:var(--muted);border-left:1px solid var(--line)}
.dm-seg span:first-child{border-left:none}
.dm-seg span.on{background:var(--teal);color:#fff}
@media (max-width:760px){.pillars{grid-template-columns:1fr;max-width:440px;margin:0 auto}.pillar{padding:6px 4px}}
@media (max-width:440px){.dm-seg span{padding:4px 6px;font-size:9px}}

/* ---------- module-demo widget kit ---------- */
.dm-wrap{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,1fr);gap:10px;align-items:start}
.dm-full{grid-column:1/-1}
.dm-h{display:flex;align-items:center;gap:6px;padding:8px 11px;border-bottom:1px solid var(--line-soft);font-size:11px;font-weight:700}
.dm-h .dm-chip{margin-left:auto}
.dm-row{display:flex;align-items:center;gap:8px;padding:8px 11px;border-bottom:1px solid var(--line-soft);transition:background .25s ease}
.dm-row:last-child{border-bottom:none}
.dm-row.sel{background:var(--teal-tint)}
.dm-av{width:20px;height:20px;border-radius:50%;background:#e2e9ee;color:#5a6473;font-size:8.5px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.dm-t{font-size:10.6px;font-weight:650;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dm-d{font-size:9.4px;color:var(--muted);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dm-chip{margin-left:auto;flex-shrink:0;font-family:var(--mono);font-size:8.6px;font-weight:700;padding:2px 7px;border-radius:999px;background:#eef1f5;color:var(--muted);transition:background .25s,color .25s;white-space:nowrap}
.dm-chip.ok{background:var(--teal-tint);color:var(--teal-deep)}
.dm-chip.amb{background:#fff5e3;color:#9a5b00}
.dm-chip.hi{background:color-mix(in oklab,var(--danger),white 88%);color:var(--danger)}
.dm-btn{display:inline-flex;align-items:center;gap:5px;font-size:9.8px;font-weight:700;color:#fff;background:var(--teal);border-radius:7px;padding:5px 10px;flex-shrink:0;transition:transform .12s ease,background .2s,border-color .2s,color .2s}
.dm-btn.ghost{background:#fff;color:var(--text);border:1px solid var(--line)}
.dm-btn.sel{background:var(--teal-tint);color:var(--teal-deep);border-color:var(--teal)}
.dm-btn.pressed{transform:scale(.95)}
.dm-hide{opacity:0;transform:translateY(6px);transition:opacity .35s ease,transform .35s ease}
.dm-hide.show{opacity:1;transform:none}
.dm-gone{display:none}
.dm-body{padding:9px 11px;font-size:10.2px;color:var(--muted);line-height:1.55}
.dm-body b{color:var(--text);font-weight:650}
.dm-chiprow{display:flex;gap:5px;flex-wrap:wrap;padding:9px 11px 0}
.dm-tgl{display:flex;align-items:center;gap:7px;font-size:9.7px;font-weight:650;color:var(--muted);padding:8px 11px;border-top:1px solid var(--line-soft)}
.dm-sw{width:26px;height:15px;border-radius:999px;background:#d7dde4;position:relative;transition:background .2s;flex-shrink:0;margin-left:auto}
.dm-sw::after{content:"";position:absolute;top:2px;left:2px;width:11px;height:11px;border-radius:50%;background:#fff;box-shadow:0 1px 2px rgba(0,0,0,.25);transition:transform .2s}
.dm-sw.on{background:var(--teal)}
.dm-sw.on::after{transform:translateX(11px)}
.dm-prog{height:5px;border-radius:999px;background:#eef1f5;overflow:hidden;flex:1}
.dm-prog b{display:block;height:100%;width:0;background:var(--teal);border-radius:999px;transition:width 1.1s cubic-bezier(.2,.7,.2,1)}
.dm-prog.run b{width:100%}
.dm-note{font-size:9.4px;color:var(--muted);padding:8px 11px;border-top:1px solid var(--line-soft);display:flex;gap:6px;align-items:center}
.dm-note svg{width:11px;height:11px;stroke:var(--teal);fill:none;flex-shrink:0}
@media (max-width:640px){.dm-wrap{grid-template-columns:1fr}}

/* ---------- workflow node chain (CSS-only reuse; beats are page-authored) ---------- */
.wf-canvas{max-width:1080px;margin:0 auto;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-card);
  background-color:#fbfcfd;background-image:radial-gradient(color-mix(in oklab,var(--text),transparent 92%) 1px,transparent 1px);background-size:20px 20px;
  padding:clamp(20px,3.2vw,34px) clamp(16px,2.6vw,28px)}
.wf-chain{display:flex;flex-direction:row;align-items:stretch;justify-content:center;gap:0}
.wf-conn{flex:0 0 32px;display:flex;align-items:center;position:relative}
.wf-conn::before{content:"";height:2px;width:100%;background:var(--line);border-radius:2px;transition:background .3s ease}
.wf-conn.done::before{background:var(--teal-pale)}
.wf-conn .wdot{position:absolute;left:0;top:50%;width:7px;height:7px;border-radius:50%;background:var(--teal);transform:translate(-4px,-50%);opacity:0;box-shadow:0 0 8px 1px rgba(14,124,134,.45)}
.wf-conn.act .wdot{animation:wtravel .5s cubic-bezier(.3,.6,.4,1) forwards}
@keyframes wtravel{0%{opacity:1;transform:translate(-4px,-50%)}100%{opacity:0;transform:translate(29px,-50%)}}
.wf-node{flex:1 1 0;min-width:0;display:flex;flex-direction:column;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:13px 15px;box-shadow:var(--shadow-card);transition:border-color .3s ease,box-shadow .3s ease,background .3s ease,transform .3s ease}
.wf-node.act{border-color:var(--teal);transform:translateY(-2px);box-shadow:0 10px 24px -12px rgba(14,124,134,.45)}
.wf-node.wait{border-color:#f2cf8a;background:#fffdf6}
.wf-node.done{border-color:var(--teal-pale);background:color-mix(in oklab,var(--teal),white 96.5%)}
.wf-node-trig,.wf-node-out,.wf-node-trig.done,.wf-node-out.done{background:var(--teal-tint);border-color:var(--teal-pale)}
.wf-node-top{display:flex;align-items:center;gap:6px;margin-bottom:8px;flex-wrap:wrap}
.wf-node-sys{font-family:var(--mono);font-size:10px;font-weight:700;color:var(--teal);text-transform:uppercase;letter-spacing:.05em}
.wf-when{font-family:var(--mono);font-size:10px;font-weight:700;color:#fff;background:var(--teal);text-transform:uppercase;letter-spacing:.05em;padding:2px 7px;border-radius:5px}
.wf-badge{font-family:var(--mono);font-size:9.5px;font-weight:700;padding:2px 6px;border-radius:5px;letter-spacing:.03em;text-transform:uppercase;margin-left:auto}
.wf-badge.b-auto{background:#fff;color:var(--teal-deep);border:1px solid var(--teal-pale)}
.wf-badge.b-appr{background:#fff5e3;color:#9a5b00}
.wf-node-label{font-size:12.5px;font-weight:600;color:var(--text);line-height:1.4;overflow-wrap:break-word}
.wf-status{font-size:10.5px;font-weight:650;margin-top:8px;display:none;align-items:center;gap:6px}
.wf-node.wait .wf-status,.wf-node.done .wf-status{display:flex}
.wf-node.wait .wf-status{color:#9a5b00}
.wf-node.done .wf-status{color:var(--teal-deep)}
.wf-status .wsd{width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}
.wf-node.wait .wf-status .wsd{animation:dotpulse 1.4s ease-out infinite}
@media (max-width:880px){
  .wf-chain{flex-direction:column;max-width:520px;margin:0 auto}
  .wf-node{flex:0 0 auto}
  .wf-conn{flex:0 0 26px;justify-content:center}
  .wf-conn::before{width:2px;height:100%;margin:0 auto}
  .wf-conn .wdot{left:50%;top:0;transform:translate(-50%,-3px)}
  .wf-conn.act .wdot{animation:wtravelv .5s cubic-bezier(.3,.6,.4,1) forwards}
}
@keyframes wtravelv{0%{opacity:1;transform:translate(-50%,-3px)}100%{opacity:0;transform:translate(-50%,23px)}}

/* ---------- quote card ---------- */
.quote{border:1px solid var(--line);background:var(--card);border-radius:18px;padding:20px;box-shadow:var(--shadow-card)}
.stars{display:flex;gap:2px;margin-bottom:12px}
.stars svg{width:15px;height:15px;fill:#e0a82e}
.quote blockquote{font-size:14px;color:var(--text);line-height:1.55;margin-bottom:16px}
.quote .who{display:flex;align-items:center;gap:11px}
.avatar{width:36px;height:36px;border-radius:50%;background:var(--teal);color:#fff;font-weight:700;font-size:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.who .nm{font-weight:650;font-size:14px}
.who .rl{font-size:12px;color:var(--muted)}
/* single centered quote (solutions pages use one on-segment quote, not a strip) */
.quote-wrap{max-width:620px;margin:clamp(28px,4vw,44px) auto 0}
.quote-wrap .quote{padding:clamp(22px,3vw,30px)}
.quote-wrap .quote blockquote{font-size:clamp(15px,1.3vw,17px)}
.quote-note{text-align:center;font-size:12.5px;color:var(--muted);margin-top:14px}
.sec.space .quote-note{color:#d7eeef}

/* ---------- compare grid ---------- */
.cmp-wrap{max-width:1000px;margin:0 auto;overflow-x:auto}
.cmp{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:var(--card);min-width:680px;box-shadow:var(--shadow-pop)}
.cmp-head,.cmp-row{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr}
.cmp-head>div{padding:15px 16px;font-size:13.5px;font-weight:700;color:var(--muted)}
.cmp-head .cmp-orbit-h{color:var(--teal-deep);background:var(--teal-tint)}
.cmp-row{border-top:1px solid var(--line-soft)}
.cmp-row>div{padding:13px 16px;font-size:13.5px;color:var(--text)}
.cmp-attr{font-weight:650}
.cmp-orbit{color:var(--teal-deep);font-weight:650;background:var(--teal-tint)}
.cmp-lbl{display:none}

/* ---------- pricing-fit strip (static; interaction lives on pricing.html) ---------- */
.mbs{max-width:760px;margin:clamp(30px,4vw,44px) auto 0;background:var(--card);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-pop);overflow:hidden}
.mbs-rows{padding:clamp(16px,2.2vw,22px)}
.mbs-base{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 14px;border:1px solid var(--teal-pale);background:var(--teal-tint);border-radius:12px}
.mbs-base .b-nm{font-size:13.5px;font-weight:700;color:var(--text)}
.mbs-base .b-nm span{display:block;font-size:11.5px;font-weight:500;color:var(--muted);margin-top:2px}
.mbs-base .b-pr{font-family:var(--mono);font-weight:700;color:var(--teal-deep);font-size:14.5px;white-space:nowrap}
.mbs-mod{display:flex;align-items:center;justify-content:space-between;gap:8px;border:1px solid var(--line);border-radius:11px;padding:11px 13px;margin-top:9px;background:#fff}
.mbs-mod .m-nm{font-size:13.5px;font-weight:650;color:var(--text);display:flex;align-items:center;gap:9px}
.mbs-mod .m-nm span{display:block;font-size:11.5px;font-weight:500;color:var(--muted)}
.mbs-check{width:17px;height:17px;border-radius:5px;background:var(--teal);flex-shrink:0;display:flex;align-items:center;justify-content:center;color:#fff}
.mbs-check svg{width:11px;height:11px;stroke:currentColor;fill:none;stroke-width:3}
.mbs-mod .m-pr{font-family:var(--mono);font-size:12.5px;font-weight:600;color:var(--teal-deep);white-space:nowrap}
.mbs-tot{display:flex;align-items:baseline;justify-content:space-between;gap:10px;padding:16px 14px 2px}
.mbs-tot .lab{font-size:13px;font-weight:600;color:var(--muted)}
.mbs-tot .val{font-family:var(--display);font-weight:800;font-size:clamp(26px,3vw,34px);letter-spacing:-.02em;color:var(--text)}
.mbs-tot .val span{font-family:var(--bric);font-size:14px;color:var(--muted);font-weight:500;letter-spacing:0}
.mbs-fine{font-size:11.5px;color:var(--muted);line-height:1.55;padding:2px 14px 0}
.mbs-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:15px clamp(16px,2.2vw,22px);border-top:1px solid var(--line-soft);background:#fbfcfd}
.mbs-foot .link-teal{display:inline-flex;align-items:center;gap:6px;font-size:14px}
.sec.space .mbs{box-shadow:var(--shadow-float)}

/* ---------- faq accordion (chrome.js-owned toggle) ---------- */
.faq-wrap{max-width:760px;margin:0 auto}
.faq-item{border:1px solid var(--line);border-radius:14px;background:var(--card);margin-bottom:12px;overflow:hidden;box-shadow:var(--shadow-card)}
.faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:16px;padding:18px 22px;cursor:pointer;font-weight:700;font-size:16px;color:var(--text);text-align:left;background:none;border:none;font-family:inherit;letter-spacing:-.01em}
.faq-ic{transition:transform .3s ease;stroke:var(--teal);fill:none;flex-shrink:0;width:20px;height:20px}
.faq-item.open .faq-ic{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-item.open .faq-a{max-height:360px}
.faq-a p{padding:0 22px 20px;color:var(--muted);line-height:1.6;font-size:14.5px}

/* ---------- cta band + orbital + shooters ---------- */
.cta-band{position:relative;overflow:hidden;border-radius:26px;padding:clamp(32px,4.2vw,52px) clamp(40px,6vw,76px);color:var(--on-teal);background:radial-gradient(120% 140% at 88% 6%,rgba(138,214,212,.25),transparent 55%),linear-gradient(150deg,var(--teal),var(--teal-deep));max-width:1100px;margin:0 auto}
.cta-band h2{color:#fff;font-size:clamp(30px,3.9vw,46px);font-weight:800;letter-spacing:-.03em;line-height:1.06;max-width:16ch}
.cta-lead{color:var(--on-teal-dim);font-size:clamp(16px,1.4vw,19px);line-height:1.6;max-width:48ch;margin-top:20px}
.cta-band .btns{display:flex;flex-wrap:wrap;gap:13px;margin-top:32px}
.cta-fine{margin-top:26px;font-size:13px;color:var(--on-teal-dim)}
.cta-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.06fr .94fr;gap:clamp(24px,4.5vw,64px);align-items:center}
.cta-content{position:relative;z-index:2}
.cta-orbit{position:relative;width:min(392px,100%);aspect-ratio:1;margin:0 auto;pointer-events:none;transform:rotate(-8deg)}
.o-ring{position:absolute;top:50%;left:50%;border-radius:50%;aspect-ratio:1;transform:translate(-50%,-50%) rotateX(66deg);box-shadow:0 0 18px rgba(138,214,212,.06)}
.o-ring.r1{width:29.5%;border:1px solid rgba(255,255,255,.27)}.o-ring.r2{width:50%;border:1px solid rgba(255,255,255,.22)}.o-ring.r3{width:70.5%;border:1px solid rgba(255,255,255,.18)}.o-ring.r4{width:91%;border:1px solid rgba(255,255,255,.14)}
.o-planet{position:absolute;top:50%;left:50%;border-radius:50%;transform:translate(-50%,-50%) translate(var(--ox,0px),var(--oy,0px));
  background:radial-gradient(circle at 32% 28%,#ffffff 0%,#d5f4f2 13%,#7fccce 40%,#2f8f96 70%,#123f45 100%);
  box-shadow:inset -5px -6px 10px rgba(4,30,34,.62),inset 2px 3px 6px rgba(255,255,255,.5),0 0 16px 3px rgba(138,214,212,.4)}
.o-planet::after{content:"";position:absolute;inset:-2px;border-radius:50%;background:radial-gradient(circle at 34% 30%,rgba(255,255,255,.22),transparent 55%)}
.o-planet.op1{width:16px;height:16px}
.o-planet.op2{width:13px;height:13px;background:radial-gradient(circle at 32% 28%,#fff 0%,#ffedc2 16%,#f2c56b 45%,#c08b2e 74%,#5c3e0e 100%);
  box-shadow:inset -4px -5px 8px rgba(60,38,6,.55),inset 2px 2px 5px rgba(255,255,255,.55),0 0 14px 3px rgba(242,197,107,.45)}
.o-planet.op3{width:30px;height:30px;background:radial-gradient(circle at 30% 26%,#ffffff 0%,#e4f9f8 12%,#8fd6d6 38%,#3a9aa2 68%,#123c44 100%)}
.o-planet.op3::before{content:"";position:absolute;left:50%;top:50%;width:185%;height:60%;transform:translate(-50%,-50%) rotate(-22deg);border-radius:50%;
  border:2px solid rgba(214,242,242,.5);border-top-color:rgba(214,242,242,.16);box-shadow:0 0 8px rgba(138,214,212,.3)}
.o-planet.op4{width:10px;height:10px;background:radial-gradient(circle at 32% 28%,#fff 0%,#f4fdfc 18%,#c3ebe9 48%,#6fb5ba 78%,#2d666d 100%)}
.o-sun{position:absolute;top:50%;left:50%;width:56px;height:56px;border-radius:50%;transform:translate(-50%,-50%);z-index:2;
  background:radial-gradient(circle at 36% 32%,#ffffff 0%,#eafffe 20%,#9fe3e0 46%,#46b3ba 78%,#1e7d86 100%);
  box-shadow:0 0 44px 12px rgba(138,214,212,.5),0 0 96px 34px rgba(138,214,212,.16),inset -4px -6px 12px rgba(8,70,78,.35)}
.o-sun::after{content:"";position:absolute;inset:-15px;border-radius:50%;background:radial-gradient(circle,rgba(138,214,212,.32),transparent 70%);animation:o-pulse 7s ease-in-out infinite}
@keyframes o-pulse{0%,100%{transform:scale(1);opacity:.55}50%{transform:scale(1.18);opacity:.2}}
.cta-band .shooter{position:absolute;width:140px;height:2px;border-radius:2px;opacity:0;z-index:1;pointer-events:none;
  background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.28) 45%,rgba(255,255,255,.78) 82%,#fff 100%);filter:drop-shadow(0 0 7px rgba(255,255,255,.7))}
.cta-band .shooter::after{content:"";position:absolute;right:-2px;top:50%;width:6px;height:6px;border-radius:50%;transform:translateY(-50%);background:#fff;box-shadow:0 0 16px 5px rgba(255,255,255,.9),0 0 4px 2px #eafcfb}
.cta-band .s1{top:8%;left:10%;animation:shoot 12s linear 2s infinite}
.cta-band .s2{top:-4%;left:50%;animation:shoot 16s linear 8.5s infinite}
@keyframes shoot{
  0%{opacity:0;transform:translate(0,0) rotate(27deg)}
  0.8%{opacity:1}
  5%{opacity:0;transform:translate(420px,214px) rotate(27deg)}
  100%{opacity:0;transform:translate(420px,214px) rotate(27deg)}
}
@media (max-width:820px){
  .cta-grid{grid-template-columns:1fr;gap:34px}
  .cta-orbit{width:min(340px,100%)} /* 86vw ignored the band's padding and inflated the 1fr track, clipping the text column at the band edge */
}

/* ---------- solutions-page shared scaffolding ---------- */
/* signature section stage + captions */
.sig-stage{max-width:900px;margin:clamp(30px,4vw,46px) auto 0}
.sig-cap{text-align:center;margin-top:18px;font-size:13.5px;color:var(--muted)}
.sec.space .sig-cap{color:#fff} /* 13.5px body on mid-band teal needs the full 4.5:1; #d7eeef only clears 4.09 */
.sig-num{font-family:var(--mono)} /* SigPlayer-owned readouts; never class="counter" (main.js owns that) */
/* two-column text + mock row */
.tm{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);align-items:center;max-width:1080px;margin:clamp(30px,4vw,48px) auto 0}
.tm+.tm{margin-top:clamp(40px,6vw,72px)}
.tm h3{font-family:var(--display);font-size:clamp(21px,2.2vw,27px);font-weight:800;letter-spacing:-.02em;line-height:1.15;color:var(--text);margin-bottom:12px;text-wrap:balance}
.tm h3 em{font-style:normal;color:var(--teal)}
.tm>div>p{font-size:15px;color:var(--muted);line-height:1.65;max-width:46ch}
.tm ul{list-style:none;margin-top:14px;display:flex;flex-direction:column;gap:9px}
.tm li{display:flex;gap:9px;font-size:14px;color:var(--muted);line-height:1.55}
.tm li svg{width:15px;height:15px;stroke:var(--teal);fill:none;flex-shrink:0;margin-top:2.5px}
.tm.rev .tm-mock{order:-1}
@media (max-width:820px){.tm{grid-template-columns:1fr;gap:26px}.tm.rev .tm-mock{order:0}}
/* before/after split card */
.ba{display:grid;grid-template-columns:1fr 1fr;max-width:1000px;margin:clamp(30px,4vw,48px) auto 0;border:1px solid var(--line);border-radius:18px;background:var(--card);box-shadow:var(--shadow-card);overflow:hidden}
.ba-col{padding:clamp(20px,3vw,30px);min-width:0}
.ba-col+.ba-col{border-left:1px solid var(--line-soft)}
.ba-col h3{font-family:var(--mono);font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:#8b93a3;margin-bottom:14px}
.ba-col.now h3{color:var(--teal-deep)}
.ba-li{display:flex;gap:9px;align-items:flex-start;padding:9px 0;font-size:14px;line-height:1.5;color:var(--text);border-bottom:1px solid var(--line-soft)}
.ba-li:last-child{border-bottom:none}
.ba-col.old .ba-li{color:#8b93a3}
.ba-li svg{width:15px;height:15px;flex-shrink:0;margin-top:2.5px;stroke:currentColor;fill:none}
.ba-col.now .ba-li svg{stroke:var(--teal)}
.ba-li .sw{position:relative}
.ba-li .sw::after{content:"";position:absolute;left:0;right:0;top:52%;height:1.5px;background:#aab2c0;transform:scaleX(0);transform-origin:left;transition:transform .55s cubic-bezier(.2,.7,.2,1)}
.ba.swept .ba-li .sw::after{transform:scaleX(1)}
.ba.swept .ba-li:nth-child(3) .sw::after{transition-delay:.12s}
.ba.swept .ba-li:nth-child(4) .sw::after{transition-delay:.24s}
.ba.swept .ba-li:nth-child(5) .sw::after{transition-delay:.36s}
@media (max-width:720px){.ba{grid-template-columns:1fr}.ba-col+.ba-col{border-left:none;border-top:1px solid var(--line-soft)}}
/* quiet two-column hairline checklist */
.chk{display:grid;grid-template-columns:1fr 1fr;gap:0 clamp(28px,4vw,56px);max-width:920px;margin:clamp(28px,4vw,44px) auto 0}
.chk-li{display:flex;gap:12px;align-items:flex-start;padding:15px 2px;border-bottom:1px solid var(--line-soft);font-size:14.5px;line-height:1.55;color:var(--text)}
.chk-li svg{width:17px;height:17px;stroke:var(--teal);fill:none;flex-shrink:0;margin-top:3px}
.chk-li b{font-weight:650}
.chk-li .d{color:var(--muted);display:block;font-size:13px;margin-top:2px}
@media (max-width:720px){.chk{grid-template-columns:1fr}}
/* deep-feature ledger group (round 3): system name + availability chip above a .chk grid */
.fg{max-width:920px;margin:clamp(26px,3.5vw,40px) auto 0}
.fg-h{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;padding-bottom:8px;border-bottom:2px solid var(--line)}
.fg-h .nm{font-weight:750;font-size:16px;letter-spacing:-.01em}
.fg-h .d{font-size:12.5px;color:var(--muted)}
.fg .chk{margin-top:2px}
.pf-card .fg-h{margin-bottom:14px}

/* sidebar micro-tag (Free / Soon chips on .osh-item rows) */
.osh-tag{margin-left:auto;font-family:var(--mono);font-size:8.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;background:var(--teal-tint);color:var(--teal-deep);border-radius:5px;padding:2px 6px}
.osh-tag.soon{background:var(--bg-side);color:#8b93a3;border:1px dashed var(--line)}

/* whole-platform retrofit scaffold (.pf-*): three layout variants, static, reveal-rise only */
.pf{max-width:1040px;margin:clamp(28px,4vw,44px) auto 0}
.pf-chip{display:inline-flex;align-items:center;font-family:var(--mono);font-size:9.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;border-radius:6px;padding:3px 8px;background:var(--teal-tint);color:var(--teal-deep);white-space:nowrap}
.pf-chip.soon{background:var(--bg-side);color:var(--muted);border:1px dashed var(--line)}
.pf-chip.gate{background:#fff5e3;color:#9a5b00}
/* variant A: module rail + spine bar */
.pf-rail{display:grid;grid-template-columns:1.45fr 1fr 1fr;gap:14px}
.pf-rail.two{grid-template-columns:1.45fr 1fr}
.pf-rail.even{grid-template-columns:repeat(3,1fr)}
.pf-tile{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px;box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:7px}
.pf-tile .pf-top{display:flex;align-items:baseline;justify-content:space-between;gap:10px}
.pf-tile .nm{font-weight:750;font-size:15px;letter-spacing:-.01em}
.pf-tile .pr{font-family:var(--mono);font-size:11px;font-weight:600;color:var(--muted);white-space:nowrap}
.pf-tile p{font-size:12.5px;color:var(--muted);line-height:1.55;margin:0}
.pf-tile.feat{background:color-mix(in oklab,var(--teal),white 96.5%);border-color:var(--teal-pale)}
.pf-spine{display:flex;flex-wrap:wrap;gap:8px 20px;align-items:baseline;margin-top:18px;padding-top:15px;border-top:1px solid var(--line-soft);font-size:12.5px;color:var(--muted)}
.pf-spine .lbl{font-family:var(--mono);font-size:9.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--teal-deep)}
.pf-spine b{color:var(--text);font-weight:650}
/* variant C: chain ledger card */
.pf-card{background:var(--card);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-card);padding:clamp(18px,3vw,26px);max-width:960px;margin:clamp(28px,4vw,44px) auto 0}
.pf-chain{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.pf-chain .stepc{display:inline-flex;align-items:center;gap:7px;background:var(--bg-side);border:1px solid var(--line);border-radius:999px;padding:7px 13px;font-size:12px;font-weight:650}
.pf-chain .arr{color:var(--teal);flex-shrink:0}
.pf-chain .arr svg{width:14px;height:14px;display:block;stroke:currentColor;fill:none}
.pf-cols{display:grid;grid-template-columns:1fr 1fr;gap:0 clamp(24px,4vw,48px);margin-top:18px;padding-top:15px;border-top:1px solid var(--line-soft)}
.pf-col-h{font-family:var(--mono);font-size:9.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);padding-bottom:6px}
.pf-li{display:flex;justify-content:space-between;align-items:baseline;gap:12px;padding:8px 0;border-top:1px solid var(--line-soft);font-size:13px}
.pf-li b{font-weight:650}
.pf-li .pr{font-family:var(--mono);font-size:11px;color:var(--muted);white-space:nowrap}
.reveal-on [data-rv] .pf-bchip{opacity:0;transform:translateY(4px);transition:opacity .5s ease .45s,transform .5s ease .45s}
.reveal-on [data-rv].rv-in .pf-bchip{opacity:1;transform:none}
@media (max-width:860px){.pf-rail,.pf-rail.two,.pf-rail.even{grid-template-columns:1fr}}
@media (max-width:640px){.pf-cols{grid-template-columns:1fr}.pf-li .pr{white-space:normal;text-align:right}}
@media (prefers-reduced-motion:reduce){.reveal-on [data-rv] .pf-bchip{transition:none}}

/* ---------- hero entrance + scroll reveal + skip link ---------- */
@media (prefers-reduced-motion:no-preference){
  .hero-grid>div>*{animation:rise .7s cubic-bezier(.2,.7,.2,1) both}
  .hero-grid .mock{animation:floatin .9s cubic-bezier(.2,.7,.2,1) both}
  h1.head{animation-delay:.04s}.hero p.sub{animation-delay:.1s}.hero .ctas{animation-delay:.16s}.hero .trust{animation-delay:.22s}
  @keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
  @keyframes floatin{from{opacity:0;transform:translateY(22px) scale(.98)}to{opacity:1;transform:none}}
}
@media (max-width:880px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .mock{max-width:520px}
}
@media (max-width:460px){
  .hero .ctas{flex-direction:column;align-items:stretch}
  .hero .ctas .btn{justify-content:center}
}
.reveal-on [data-rv]{opacity:0;transform:translateY(16px);transition:opacity .55s cubic-bezier(.2,.7,.2,1),transform .55s cubic-bezier(.2,.7,.2,1)}
.reveal-on [data-rv].rv-in{opacity:1;transform:none}
.skip-link{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-link:focus{position:fixed;top:10px;left:12px;z-index:300;width:auto;height:auto;clip:auto;margin:0;padding:10px 16px;background:var(--teal);color:#fff;border-radius:999px;font-weight:650;text-decoration:none}

/* ---------- reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  .dm-hide{opacity:1;transform:none;transition:none}
  .dm-prog b{transition:none}
  .o-sun::after,.cta-band .shooter{animation:none}
  .cta-band .shooter{display:none}
  .reveal-on [data-rv]{opacity:1!important;transform:none!important;transition:none!important}
  .chat-on .dot,.wf-node.wait .wf-status .wsd{animation:none}
  .ba-li .sw::after{transition:none}
  .faq-a{transition:none}
  .faq-ic{transition:none}
}
