/* Copyright (c) 2026 MergeGuide, Inc. All rights reserved. */
/* SPDX-License-Identifier: Proprietary */
/* DEV-2280 — shared stylesheet, externalized verbatim from
   mergeguide-website-mockup-v2-hybrid-2026-06-03.html (the locked visual reference). */
:root{
  --navy:#0a1020; --navy2:#0e1830; --nav:#0b1322;
  --paper:#ffffff; --paper2:#f3f7fd; --paper3:#eaf1fb;
  --ink:#0f1c3f; --body:#44526e; --muted:#7a89a6; --muted-d:#9fb0cf;
  --blue:#2f6fed; --blue-d:#1d4fb0; --cyan:#22d3ee; --cyan-d:#0e9fbb;
  --line-l:#e3eaf5; --line-d:#1d2b48;
  --grad:linear-gradient(92deg,#2f6fed,#22d3ee);
  --mono:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  --sans:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --maxw:1140px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--paper);color:var(--body);font-family:var(--sans);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{color:var(--ink);line-height:1.14;margin:0;letter-spacing:-0.022em}
h1{font-size:clamp(2.1rem,4.6vw,3.5rem);font-weight:800}
h2{font-size:clamp(1.6rem,3vw,2.3rem);font-weight:780}
h3{font-size:1.17rem;font-weight:720}
p{margin:0 0 1rem}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.grad-t{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.eyebrow{font-family:var(--mono);font-size:.72rem;letter-spacing:.17em;text-transform:uppercase;color:var(--cyan-d);font-weight:600}
.eyebrow.on-dark{color:var(--cyan)}
.muted{color:var(--muted)}
.center{text-align:center}
.btn{display:inline-flex;align-items:center;gap:.5rem;font-weight:680;font-size:.95rem;padding:.74rem 1.3rem;border-radius:9px;border:1px solid transparent;cursor:pointer;transition:.16s}
.btn-primary{background:var(--grad);color:#04211d;border:none;box-shadow:0 6px 22px rgba(34,211,238,.22)}
.btn-primary:hover{filter:brightness(1.06);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line-l)}
.btn-ghost:hover{border-color:var(--blue);color:var(--blue)}
.btn-ghost.on-dark{color:#fff;border-color:#2a3a5c}
.btn-ghost.on-dark:hover{border-color:var(--cyan);color:var(--cyan)}
.section{padding:86px 0}
.section.alt{background:var(--paper2)}
.section.tint{background:linear-gradient(180deg,var(--paper3),var(--paper2))}
.lead{font-size:1.16rem;color:var(--body);max-width:680px}

/* reveal motion (no-JS safe) */
.js .reveal{opacity:0;transform:translateY(16px)}
.js .reveal.in{opacity:1;transform:none;transition:opacity .6s ease,transform .6s ease}

/* topbar */
.topbar{background:#070c18;color:var(--muted-d);text-align:center;padding:7px 16px;font-size:.78rem;font-family:var(--mono);border-bottom:1px solid var(--line-d)}
.topbar b{color:#cdd9f0;font-weight:600}

/* nav (persistent dark navy) */
header.nav{position:sticky;top:0;z-index:50;background:rgba(11,19,34,.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--line-d)}
.nav-inner{display:flex;align-items:center;gap:26px;height:66px;max-width:var(--maxw);margin:0 auto;padding:0 24px}
.brand{display:flex;align-items:center;gap:9px;font-weight:800;font-size:1.16rem;letter-spacing:-0.02em;color:#fff}
.brand .glyph{width:22px;height:22px;display:block}
.brand .g{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.nav-links{display:flex;align-items:center;gap:22px;margin-left:6px}
.nav-links a,.nav-links button.navitem{color:#c4d0e6;font-size:.92rem;font-weight:550;background:none;border:none;cursor:pointer;font-family:inherit;padding:0;display:inline-flex;align-items:center;gap:5px}
.nav-links a:hover,.nav-links button.navitem:hover{color:#fff}
.nav-cta{margin-left:auto;display:flex;align-items:center;gap:16px}
.nav-cta a.login{font-size:.9rem;color:#c4d0e6}
.nav-cta a.login:hover{color:#fff}
.caret{width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid currentColor;opacity:.7}
.has-drop{position:relative}
.drop{position:absolute;top:calc(100% + 14px);left:-18px;background:var(--nav);border:1px solid var(--line-d);border-radius:12px;padding:10px;width:344px;box-shadow:0 26px 60px rgba(0,0,0,.55);opacity:0;visibility:hidden;transform:translateY(-6px);transition:.16s}
.has-drop:hover .drop,.has-drop:focus-within .drop{opacity:1;visibility:visible;transform:translateY(0)}
.drop a{display:block;padding:10px 12px;border-radius:8px}
.drop a:hover{background:#10203c}
.drop a .dt{color:#fff;font-weight:650;font-size:.92rem;display:flex;align-items:center;gap:9px}
.drop a .dd{color:var(--muted);font-size:.79rem;margin-top:2px}
.drop .ic{font-family:var(--mono);font-size:.66rem;color:var(--cyan);border:1px solid var(--line-d);border-radius:5px;padding:2px 6px;min-width:42px;text-align:center}

/* hero (dark) */
.hero{position:relative;background:radial-gradient(900px 420px at 15% -10%,rgba(34,211,238,.16),transparent 60%),radial-gradient(700px 500px at 90% 0%,rgba(47,111,237,.18),transparent 55%),linear-gradient(180deg,#0a1020,#0b1424);overflow:hidden;border-bottom:1px solid var(--line-d)}
.hero::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.05) 1px,transparent 1px);background-size:26px 26px;opacity:.5;pointer-events:none}
.glow{position:absolute;width:520px;height:520px;left:-120px;top:-160px;background:radial-gradient(circle,rgba(34,211,238,.18),transparent 65%);filter:blur(8px);animation:drift 14s ease-in-out infinite alternate;pointer-events:none}
@keyframes drift{from{transform:translate(0,0)}to{transform:translate(80px,60px)}}
.hero-inner{position:relative;padding:78px 0 72px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:46px;align-items:center}
.hero h1{color:#fff}
.hero p.sub{font-size:1.2rem;margin:22px 0 28px;color:var(--muted-d);max-width:560px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-sub2{margin-top:22px;font-size:.84rem;color:var(--muted);font-family:var(--mono)}
.term{background:#070d1a;border:1px solid #1d3a55;border-radius:14px;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.5),0 0 0 1px rgba(34,211,238,.08);font-family:var(--mono);font-size:.81rem}
.term-bar{display:flex;align-items:center;gap:7px;padding:11px 14px;background:#0a1322;border-bottom:1px solid #16263e}
.term-bar i{width:11px;height:11px;border-radius:50%;background:#2a3a5c}
.term-bar span{margin-left:8px;color:var(--muted);font-size:.73rem}
.term-body{padding:16px 16px 18px;line-height:1.78}
.term-body .ln{opacity:0;animation:lnin .35s forwards}
.js .term-body .ln{opacity:0}
.term-body:not(.js-staggered) .ln{opacity:1}
@keyframes lnin{to{opacity:1}}
.term .c{color:var(--muted)} .term .ok{color:var(--cyan)} .term .b{color:#5b9bff} .term .ink{color:#dfe8f7} .term .warn{color:#f5b544}
.ccaret{display:inline-block;width:7px;height:13px;background:var(--cyan);vertical-align:-2px;animation:blink 1.1s step-end infinite;margin-left:2px}
@keyframes blink{50%{opacity:0}}
.tag-prevent{display:inline-block;margin-top:10px;font-size:.7rem;color:#04211d;background:var(--grad);padding:2px 9px;border-radius:20px;font-weight:700;letter-spacing:.03em}

.stack-strip{display:flex;flex-wrap:wrap;gap:10px 13px;justify-content:center;margin-top:46px}
.chip{font-family:var(--mono);font-size:.78rem;color:var(--muted-d);border:1px solid #1d2b48;background:rgba(255,255,255,.02);padding:7px 13px;border-radius:30px}
.chip b{color:var(--cyan)}
.chip.light{color:var(--body);border-color:var(--line-l);background:#fff}
.chip.light b{color:var(--blue)}

/* generic light pieces */
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.grid2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.card{background:#fff;border:1px solid var(--line-l);border-radius:15px;padding:26px;box-shadow:0 1px 2px rgba(15,28,63,.03)}
.card h3{margin:13px 0 8px}
.card p{font-size:.96rem;margin:0;color:var(--body)}
.ic-badge{width:42px;height:42px;border-radius:11px;background:linear-gradient(135deg,rgba(47,111,237,.12),rgba(34,211,238,.14));border:1px solid rgba(34,211,238,.28);display:flex;align-items:center;justify-content:center;font-family:var(--mono);color:var(--blue-d);font-weight:800}

.origin{background:linear-gradient(135deg,#0b1424,#0e1d38);border:1px solid var(--line-d);border-radius:20px;padding:48px;color:var(--muted-d);position:relative;overflow:hidden}
.origin::after{content:"";position:absolute;width:360px;height:360px;right:-120px;bottom:-160px;background:radial-gradient(circle,rgba(34,211,238,.13),transparent 65%);pointer-events:none}
.origin h2{color:#fff;margin-bottom:14px}
.origin .pull{font-size:1.3rem;color:#fff;font-weight:650;border-left:3px solid var(--cyan);padding-left:18px;margin:22px 0;max-width:780px}
.origin p{position:relative}

.ladder{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:8px}
.rung{background:#fff;border:1px solid var(--line-l);border-radius:13px;padding:20px;position:relative;overflow:hidden}
.rung::before{content:"";position:absolute;left:0;top:0;height:3px;width:100%;background:var(--grad);opacity:.0}
.rung.r1::before{opacity:1;width:25%}.rung.r2::before{opacity:1;width:50%}.rung.r3::before{opacity:1;width:75%}.rung.r4::before{opacity:1;width:100%}
.rung .lvl{font-family:var(--mono);font-size:.71rem;color:var(--blue-d);letter-spacing:.06em}
.rung .when{font-size:1.5rem;font-weight:800;color:var(--ink);margin:9px 0 2px}
.rung .lbl{font-size:.85rem;color:var(--body)}
.rung .cost{margin-top:12px;font-family:var(--mono);font-size:.73rem;color:var(--cyan-d)}

.sol-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.sol-card{background:#fff;border:1px solid var(--line-l);border-radius:15px;padding:24px;cursor:pointer;transition:.16s;display:block;text-align:left;box-shadow:0 1px 2px rgba(15,28,63,.03)}
.sol-card:hover{border-color:var(--cyan);transform:translateY(-3px);box-shadow:0 14px 34px rgba(34,211,238,.12)}
.sol-card .ic{font-family:var(--mono);color:var(--blue-d);font-size:.74rem;border:1px solid var(--line-l);border-radius:6px;padding:3px 8px;display:inline-block;background:var(--paper2)}
.sol-card h3{margin:14px 0 7px;font-size:1.07rem}
.sol-card p{font-size:.9rem;margin:0;color:var(--body)}
.sol-card .go{margin-top:14px;font-size:.82rem;color:var(--blue);font-weight:680}

.fw-band{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin:8px 0 22px}
.fw{font-weight:720;color:var(--ink);border:1px solid var(--line-l);background:#fff;border-radius:11px;padding:14px 20px;font-size:.95rem;min-width:120px;text-align:center;box-shadow:0 1px 2px rgba(15,28,63,.03)}
.fw small{display:block;color:var(--muted);font-weight:500;font-size:.71rem;font-family:var(--mono);margin-top:3px}
.fw.more{border-style:dashed;color:var(--muted);box-shadow:none;background:transparent}

table.cmp{width:100%;border-collapse:collapse;font-size:.9rem;margin-top:10px;background:#fff;border:1px solid var(--line-l);border-radius:14px;overflow:hidden}
table.cmp th,table.cmp td{text-align:left;padding:13px 15px;border-bottom:1px solid var(--line-l)}
table.cmp thead th{font-family:var(--mono);font-size:.72rem;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);font-weight:600;background:var(--paper2)}
table.cmp thead th.mg{color:var(--blue-d)}
table.cmp tbody tr:last-child td{border-bottom:none}
table.cmp td.mgcell{background:rgba(47,111,237,.05)}
table.cmp .yes{color:var(--blue-d);font-weight:700}
table.cmp .yes .ck{display:inline-block;width:15px;height:15px;border-radius:50%;background:var(--grad);color:#04211d;font-size:.62rem;text-align:center;line-height:15px;margin-right:6px;font-weight:900}
table.cmp .no{color:var(--muted)}

.aud{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.aud ul{list-style:none;padding:0;margin:14px 0 0}
.aud li{position:relative;padding-left:22px;margin-bottom:9px;font-size:.9rem;color:var(--body)}
.aud li::before{content:"›";position:absolute;left:4px;color:var(--blue);font-weight:800}

.ctaband{background:radial-gradient(700px 300px at 50% 0%,rgba(34,211,238,.16),transparent 60%),linear-gradient(135deg,#0b1424,#0d1c36);border:1px solid var(--line-d);border-radius:20px;padding:54px;text-align:center;position:relative;overflow:hidden}
.ctaband h2{color:#fff}
.ctaband .lead{color:var(--muted-d)}

footer{background:#070c18;border-top:1px solid var(--line-d);padding:54px 0 34px;font-size:.86rem;color:var(--muted-d)}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:28px}
footer h4{font-size:.73rem;font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:12px}
footer a{display:block;color:var(--muted-d);margin-bottom:8px}
footer a:hover{color:var(--cyan)}
.foot-bottom{display:flex;justify-content:space-between;border-top:1px solid var(--line-d);margin-top:34px;padding-top:18px;color:var(--muted);font-size:.78rem;flex-wrap:wrap;gap:8px}
.foot-bottom a{display:inline;margin-bottom:0}

.view{display:none}.view.active{display:block}
.page-hero{padding:64px 0 44px;background:linear-gradient(180deg,var(--paper3),#fff);border-bottom:1px solid var(--line-l)}
.back{font-family:var(--mono);font-size:.8rem;color:var(--blue);cursor:pointer;display:inline-block;margin-bottom:16px}
.cap-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}

.mock-flag{position:fixed;bottom:14px;right:14px;z-index:99;background:#f5b544;color:#2a1c02;font-family:var(--mono);font-size:.7rem;font-weight:700;padding:6px 11px;border-radius:20px;box-shadow:0 6px 20px rgba(0,0,0,.3)}

/* animated merge glyph */
.brand .mark{display:inline-flex}
.brand .glyph{width:22px;height:22px;display:block;overflow:visible}
.gl-s{stroke:#22d3ee;stroke-width:2.4;fill:none}
.gl-s1{stroke-dasharray:11;stroke-dashoffset:11;animation:gldraw .5s ease .05s forwards}
.gl-s2{stroke-dasharray:11;stroke-dashoffset:11;animation:gldraw .5s ease .2s forwards}
.gl-s3{stroke-dasharray:9;stroke-dashoffset:9;animation:gldraw .4s ease .45s forwards}
@keyframes gldraw{to{stroke-dashoffset:0}}
.gl-node{fill:#22d3ee;animation:glnode 3.4s ease-in-out 1.1s infinite}
@keyframes glnode{0%,50%{r:1.6}60%{r:3.1}72%{r:1.6}100%{r:1.6}}
.gl-dot{fill:#8ef2ff;opacity:0}
.gl-dotA{animation:gldotA 3.4s ease-in-out 1.1s infinite}
.gl-dotB{animation:gldotB 3.4s ease-in-out 1.1s infinite}
@keyframes gldotA{0%{cx:4;cy:5;opacity:0}5%{opacity:1}28%{cx:12;cy:12}50%{cx:20;cy:12;opacity:1}58%{opacity:0}100%{cx:20;cy:12;opacity:0}}
@keyframes gldotB{0%{cx:4;cy:19;opacity:0}5%{opacity:1}28%{cx:12;cy:12}50%{cx:20;cy:12;opacity:1}58%{opacity:0}100%{cx:20;cy:12;opacity:0}}

/* diagrams */
.diagram-panel{background:#fff;border:1px solid var(--line-l);border-radius:16px;padding:24px 22px;box-shadow:0 1px 2px rgba(15,28,63,.03)}
.venn-wrap{max-width:540px;margin:0 auto}
.legend{display:flex;flex-wrap:wrap;gap:16px;justify-content:center;margin-top:14px;font-size:.85rem;color:var(--body)}
.legend .sw{display:inline-flex;align-items:center;gap:8px}
.legend .ln{width:20px;display:inline-block}
.rcurve{stroke-dasharray:780;stroke-dashoffset:780;animation:rdraw 1.7s ease .3s forwards}
@keyframes rdraw{to{stroke-dashoffset:0}}
@media (prefers-reduced-motion: reduce){
  .gl-s,.gl-node,.gl-dot,.rcurve,.glow,.term-body .ln{animation:none!important}
  .gl-s,.rcurve{stroke-dashoffset:0!important}
  .term-body .ln{opacity:1!important}
  .scene{transition:none!important;transform:none!important}
}

/* product reel */
.reel{background:#070d1a;border:1px solid #1d3a55;border-radius:14px;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.5),0 0 0 1px rgba(34,211,238,.08)}
.reel-top{display:flex;align-items:center;gap:7px;padding:11px 14px;background:#0a1322;border-bottom:1px solid #16263e;font-family:var(--mono)}
.reel-top .rdot{width:11px;height:11px;border-radius:50%;background:#2a3a5c}
.reel-title{margin-left:8px;color:var(--muted);font-size:.73rem}
.reel-stage{position:relative;height:312px}
.scene{position:absolute;inset:0;opacity:0;transform:translateY(12px) scale(.994);transition:opacity .8s ease,transform .8s cubic-bezier(.22,.61,.36,1);padding:14px 15px;font-family:var(--mono);font-size:.77rem;overflow:hidden;pointer-events:none}
.scene.active{opacity:1;transform:none;pointer-events:auto}
.reel-cap{padding:11px 14px;border-top:1px solid #16263e;display:flex;align-items:center;gap:12px;background:#0a1322}
.reel-dots{display:flex;gap:6px}
.reel-dots .rd{width:7px;height:7px;border-radius:50%;background:#2a3a5c;transition:.25s}
.reel-dots .rd.on{background:#22d3ee;width:18px;border-radius:4px}
.reel-label{font-family:var(--sans);font-size:.8rem;color:var(--muted-d);line-height:1.3}
/* scene: IDE */
.ide{display:grid;grid-template-columns:120px 1fr;gap:10px;height:100%}
.ide-rail{background:#0a1322;border:1px solid #16263e;border-radius:8px;padding:9px}
.rail-h{font-size:.58rem;color:var(--muted);letter-spacing:.07em;margin-bottom:7px}
.rail-i{font-size:.63rem;color:var(--muted-d);padding:4px 5px;border-radius:4px;margin-bottom:3px;border-left:2px solid #2a3a5c;line-height:1.25}
.rail-i.warn{border-left-color:#f5b544;color:#f3d6a3;background:rgba(245,181,68,.06)}
.ide-code{position:relative;background:#0a1120;border:1px solid #16263e;border-radius:8px;padding:10px 11px;overflow:hidden}
.cl{white-space:nowrap;color:#9fb0cf;line-height:1.78;font-size:.72rem}
.cl .ln{color:#3a4a66;margin-right:9px}
.cl .kw{color:#5b9bff}.cl .str{color:#22d3ee}.cl .fn{color:#7fe3c0}
.cl.bad{background:rgba(245,181,68,.09);border-bottom:2px dashed #f5b544;border-radius:2px}
.diag{position:absolute;left:11px;right:11px;bottom:12px;background:#0e1b30;border:1px solid #2c4a66;border-radius:7px;padding:9px 11px;box-shadow:0 12px 26px rgba(0,0,0,.55)}
.s-ide.active .diag{animation:diagin .5s ease both}
.diag b{color:#ffd9a0;display:block;font-size:.71rem}
.diag span{color:var(--muted-d);font-size:.63rem;display:block;margin-top:3px}
.diag i{color:#7fe3c0;font-style:normal;font-size:.63rem;display:block;margin-top:4px}
@keyframes diagin{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
/* scene: PR */
.pr{height:100%;display:flex;flex-direction:column;gap:9px}
.pr-h{color:var(--muted-d);font-size:.69rem;margin-bottom:1px}
.pr-row{background:#0a1322;border:1px solid #16263e;border-radius:8px;padding:10px 12px;color:#dfe8f7;font-size:.72rem;display:flex;align-items:center;gap:8px}
.pr-row.ok{border-color:#1f6f6b;color:#7ef0d8}
.pr-row .ck{width:16px;height:16px;border-radius:50%;background:var(--grad);color:#04211d;font-size:.62rem;font-weight:900;display:inline-flex;align-items:center;justify-content:center}
.pr-sub{color:var(--muted);font-size:.64rem;padding-left:2px}
.ev{background:#0a1322;border:1px solid #16263e;border-radius:8px;padding:12px;margin-top:2px}
.ev-h{color:#7ef0d8;font-size:.67rem;margin-bottom:9px;display:flex;align-items:center;gap:7px}
.ev-row{display:flex;justify-content:space-between;font-size:.66rem;color:var(--muted-d);padding:3px 0;border-bottom:1px solid #11203a}
.ev-row:last-child{border-bottom:none}
.ev-row b{color:#fff}
/* scene: dashboard */
.dash{height:100%;display:flex;flex-direction:column;gap:11px}
.kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:9px}
.kpi{background:#0a1322;border:1px solid #16263e;border-radius:8px;padding:11px}
.kpi span{display:block;color:var(--muted);font-size:.58rem}
.kpi b{color:#fff;font-size:1.45rem;font-weight:800;font-family:var(--sans)}
.cov{background:#0a1322;border:1px solid #16263e;border-radius:8px;padding:13px;display:flex;flex-direction:column;gap:11px}
.cov-r{display:grid;grid-template-columns:100px 1fr 42px;align-items:center;gap:11px;font-size:.65rem;color:var(--muted-d)}
.bar{height:7px;background:#16263e;border-radius:6px;overflow:hidden}
.bar i{display:block;height:100%;background:linear-gradient(90deg,#2f6fed,#22d3ee);width:0}
.s-dash.active .bar i{width:100%;transition:width 1.1s ease .15s}
.cov-r b{color:#22d3ee;text-align:right}
/* scene: merge */
.mrg{height:100%;display:flex;flex-direction:column;gap:11px;justify-content:center}
.mrg-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:9px}
.mrg-stats div{background:#0a1322;border:1px solid #16263e;border-radius:8px;padding:11px;text-align:center}
.mrg-stats b{display:block;color:#22d3ee;font-size:1.5rem;font-weight:800;font-family:var(--sans)}
.mrg-stats span{color:var(--muted);font-size:.59rem}
.mrg-calc{background:#0a1322;border:1px solid #16263e;border-radius:8px;padding:15px;text-align:center}
.mrg-calc .calc{font-family:var(--sans);font-size:1.55rem;font-weight:800;color:#fff;margin:5px 0}
.mrg-calc .from{color:var(--muted-d)}.mrg-calc .to{color:#22d3ee}.mrg-calc .arrow{color:#2f6fed;margin:0 9px}
.mrg-calc .lbl,.mrg-calc .save{color:var(--muted);font-size:.63rem;display:block}
.mrg-calc .save{color:#7ef0d8;margin-top:3px}

/* pricing */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:stretch}
.pcard{background:#fff;border:1px solid var(--line-l);border-radius:16px;padding:28px 24px;display:flex;flex-direction:column;box-shadow:0 1px 2px rgba(15,28,63,.03)}
.pcard.feat{border:2px solid var(--blue);box-shadow:0 18px 44px rgba(47,111,237,.14);position:relative}
.pcard .badge{position:absolute;top:-12px;left:24px;background:var(--grad);color:#04211d;font-size:.64rem;font-weight:800;padding:3px 11px;border-radius:20px;font-family:var(--mono)}
.pcard .pname{font-weight:800;color:var(--ink);font-size:1.18rem}
.pcard .psub{color:var(--muted);font-size:.85rem;margin-top:3px;min-height:40px}
.pcard .price{margin:14px 0 2px;font-size:2.1rem;font-weight:800;color:var(--ink);letter-spacing:-.02em}
.pcard .price small{font-size:.88rem;color:var(--muted);font-weight:500}
.pcard .pnote{font-size:.76rem;color:var(--muted);margin-bottom:18px;font-family:var(--mono);min-height:16px}
.pcard ul{list-style:none;padding:0;margin:0 0 22px;flex:1}
.pcard li{position:relative;padding-left:24px;margin-bottom:10px;font-size:.9rem;color:var(--body)}
.pcard li::before{content:"\2713";position:absolute;left:1px;color:var(--blue);font-weight:800}
.pcard .btn{width:100%;justify-content:center}
.nogate{text-align:center;color:var(--muted);font-size:.88rem;margin-top:26px}

/* contact form */
.cform{max-width:560px;margin:0 auto;background:#fff;border:1px solid var(--line-l);border-radius:16px;padding:28px;box-shadow:0 1px 2px rgba(15,28,63,.03)}
.cform .frow{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cform label{display:block;font-size:.82rem;color:var(--ink);font-weight:600;margin:13px 0 5px}
.cform input,.cform textarea,.cform select{width:100%;padding:11px 13px;border:1px solid var(--line-l);border-radius:9px;font-family:inherit;font-size:.92rem;background:var(--paper2);color:var(--ink)}
.cform input:focus,.cform textarea:focus,.cform select:focus{outline:none;border-color:var(--blue);background:#fff}
.cform textarea{min-height:110px;resize:vertical}
.cform .btn{margin-top:20px;width:100%;justify-content:center}

/* faq */
.faq{max-width:780px;margin:0 auto}
.faq details{border-bottom:1px solid var(--line-l);padding:16px 2px}
.faq summary{cursor:pointer;font-weight:700;color:var(--ink);font-size:1.02rem;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--blue);font-weight:800;font-size:1.25rem;line-height:1}
.faq details[open] summary::after{content:"\2013"}
.faq p{margin:11px 0 0;color:var(--body);font-size:.95rem}

/* enlarged hero reel + higher-fidelity scenes */
.hero-grid{grid-template-columns:1fr;gap:42px}
.hero-grid > .reel{max-width:1040px;width:100%;margin:8px auto 0}
.reel-stage{height:474px}
.reel-top{padding:13px 17px}
.reel-cap{padding:13px 17px}
.scene{font-size:.92rem;padding:24px 28px}
.s-ide .ide{grid-template-columns:214px 1fr;gap:16px}
.s-ide .rail-h{font-size:.7rem;margin-bottom:9px}
.s-ide .rail-i{font-size:.78rem;padding:7px 9px;margin-bottom:4px}
.s-ide .ide-code{padding:14px 16px}
.s-ide .cl{font-size:.92rem;line-height:2}
.s-ide .diag{padding:14px 17px}
.s-ide .diag b{font-size:.92rem}
.s-ide .diag span{font-size:.78rem;margin-top:5px}
.s-ide .diag i{font-size:.78rem;margin-top:6px}
.s-mcp .term-body{font-size:.98rem;line-height:2.1;padding:24px 28px}
.s-pr .pr{gap:12px}
.s-pr .pr-h{font-size:.84rem}
.s-pr .pr-row{font-size:.92rem;padding:14px 17px}
.s-pr .pr-row .ck{width:19px;height:19px;font-size:.72rem}
.s-pr .pr-sub{font-size:.78rem}
.s-pr .ev{padding:17px}
.s-pr .ev-h{font-size:.84rem;margin-bottom:11px}
.s-pr .ev-row{font-size:.84rem;padding:7px 0}

/* product app shell (dashboard + PolicyMerge scenes) */
.s-dash,.s-merge{padding:0}
.ashell{display:grid;grid-template-columns:170px 1fr;height:100%}
.aside{background:#0a1322;border-right:1px solid #16263e;padding:16px 12px;display:flex;flex-direction:column;gap:1px}
.aside .org{display:flex;align-items:center;gap:8px;color:#fff;font-weight:800;font-size:.88rem;margin-bottom:6px}
.aside .org svg{width:18px;height:18px}
.aside .org .g{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.aside .orgsw{color:var(--muted);font-size:.66rem;background:#0e1d33;border:1px solid #16263e;border-radius:6px;padding:6px 8px;margin-bottom:12px}
.aside .navi{padding:7px 9px;border-radius:6px;color:var(--muted-d);font-size:.76rem}
.aside .navi.on{background:rgba(34,211,238,.13);color:#7ef0d8;font-weight:600}
.aside .sec{color:#3a4a66;font-size:.58rem;letter-spacing:.09em;margin:13px 0 4px;padding-left:9px}
.apanel{padding:22px 24px;overflow:hidden;display:flex;flex-direction:column;gap:16px}
.apanel .ptitle{color:#fff;font-weight:800;font-size:1.08rem;font-family:var(--sans)}
.s-dash .kpis{gap:13px}
.s-dash .kpi{padding:13px 15px}
.s-dash .kpi span{font-size:.72rem}
.s-dash .kpi b{font-size:2.25rem}
.s-dash .cov{padding:16px}
.s-dash .cov-r{grid-template-columns:128px 1fr 54px;font-size:.8rem;gap:13px}
.s-dash .bar{height:9px}
.s-merge .mrg-stats{gap:13px}
.s-merge .mrg-stats b{font-size:2.45rem}
.s-merge .mrg-stats span{font-size:.72rem}
.s-merge .mrg-calc{padding:18px}
.s-merge .mrg-calc .calc{font-size:2.1rem}
@media(max-width:880px){
  .reel-stage{height:auto;min-height:420px}
  .s-ide .ide{grid-template-columns:1fr}
  .ashell{grid-template-columns:1fr}
  .aside{flex-direction:row;flex-wrap:wrap;gap:6px;border-right:none;border-bottom:1px solid #16263e}
  .aside .sec,.aside .orgsw{display:none}
}

/* centered hero copy above the full-width reel */
.hero-grid > div:first-child{text-align:center;max-width:840px;margin:0 auto}
.hero-grid > div:first-child .hero-cta{justify-content:center}
.hero-grid > div:first-child .sub{margin-left:auto;margin-right:auto}

/* evidence artifact scene */
.evd{height:100%;display:flex;flex-direction:column;gap:14px}
.evd-head{display:flex;align-items:center;gap:10px;color:#fff;font-weight:800;font-size:1.08rem;font-family:var(--sans)}
.evd-head svg{width:19px;height:19px}
.evd-head .x{margin-left:auto;color:var(--muted);font-weight:400}
.evd-cols{display:grid;grid-template-columns:0.82fr 1.18fr;gap:18px;flex:1;min-height:0}
.evd-meta{display:grid;grid-template-columns:1fr 1fr;gap:13px 16px;align-content:start}
.evd-meta .m span{display:block;color:var(--muted);font-size:.72rem;margin-bottom:2px}
.evd-meta .m b{color:#fff;font-weight:600;font-size:.8rem;font-family:var(--mono);word-break:break-all}
.pass-pill{display:inline-block;background:#2f6fed;color:#fff;border-radius:20px;padding:2px 13px;font-size:.74rem;font-weight:700;font-family:var(--sans)}
.evd-json{background:#0c1730;border:1px solid #1d2b48;border-radius:9px;overflow:hidden;display:flex;flex-direction:column;min-height:0}
.json-h{display:flex;align-items:center;justify-content:space-between;padding:9px 13px;background:#0a1322;border-bottom:1px solid #16263e;color:var(--muted-d);font-size:.72rem}
.json-b{padding:11px 14px;overflow:hidden;font-family:var(--mono);font-size:.71rem;line-height:1.62;color:#8893b3;white-space:pre}
.json-b .k{color:#cbd5f0}
.json-b .s{color:#9fb3ef}
.json-b .n{color:#7ad0e6}

/* MCP agent transcript (brighter) */
.mcp{height:100%;font-family:var(--mono);font-size:1rem;line-height:1.92;color:#dbe4f5;overflow:hidden;display:flex;flex-direction:column;justify-content:center}
.mcp .b{margin:0 0 5px;color:#eef3fc}
.mcp .b::before{content:"● ";color:#5ff0d8}
.mcp .tool{color:#95abcc;margin:-2px 0 5px;padding-left:18px}
.mcp .tool::before{content:"⎿ ";color:#6aa6ff}
.mcp .ok{color:#5ff0d8;font-weight:600}
.mcp .tk{color:#6aa6ff}
.mcp .rule{color:#f5b544}
.mcp .hd{color:#ffffff;font-weight:700;margin:9px 0 3px}
.mcp .li{color:#cdd9f0;padding-left:16px;margin:0 0 3px}
.mcp .li::before{content:"– ";color:#6aa6ff}
.mcp .dim{color:#8294b6;margin-top:9px}
.s-mcp .mcpln{opacity:0}
.s-mcp.active .mcpln{animation:mcpline .45s ease forwards;animation-delay:var(--d,0s)}
@keyframes mcpline{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:none}}
/* Sankey */
.pm-svg{width:100%;display:block}
.mrg-line{color:#cdd9f0;font-size:.85rem;text-align:center;margin-top:4px}
.mrg-line b{color:#fff}
.s-merge .lk{stroke-dasharray:1;stroke-dashoffset:1}
.s-merge.active .lk{animation:lkdraw 1.4s ease forwards}
@keyframes lkdraw{to{stroke-dashoffset:0}}
.s-merge .pmSweepRect{width:0}
.s-merge.active .pmSweepRect{animation:pmsweep 1.2s ease .8s forwards}
@keyframes pmsweep{to{width:305px}}
@media (prefers-reduced-motion: reduce){
  .s-merge .lk{stroke-dashoffset:0}
  .s-merge .pmSweepRect{width:305px}
  .s-merge.active .lk,.s-merge.active .pmSweepRect{animation:none}
  .s-mcp .mcpln{opacity:1!important;animation:none!important}
}

@media(max-width:880px){
  .hero-grid,.grid3,.grid2,.ladder,.sol-grid,.aud,.foot-grid,.cap-grid{grid-template-columns:1fr}
  .nav-links{display:none}
}
