/* ============================================================================
   New Century Labs — design system v2 · "The Requisition"
   Editorial lab-document aesthetic: warm paper, ink, one orange accent,
   hairline rules, mono micro-labels, tabular figures, asymmetric grid.
   No gradient blobs. No card grids. No teal.
   ========================================================================== */

/* ---- Tokens ------------------------------------------------------------- */
:root{
  --paper:#fdfcfc;
  --paper-deep:#f6f4f0;      /* warm section tint */
  --ink:#111110;
  --ink-soft:#3a3835;
  --muted:#6b655d;           /* ≥4.5:1 on paper */
  --faint:#8f887e;           /* large text / decorative only */
  --rule:#e3dfd8;            /* hairlines */
  --rule-dark:#111110;
  --orange:#e33d00;          /* accent, AA on paper for large text */
  --orange-ink:#c33400;      /* accent for small text, ≥4.5:1 */
  --blue:#0435c8;            /* links + focus, ≥4.5:1 */
  --ok:#1f7a33;
  --err:#b3261e;
  --serif:'Fraunces',Georgia,'Times New Roman',serif;
  --sans:'Inter',system-ui,-apple-system,'Segoe UI',Arial,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,'SF Mono',Menlo,Consolas,monospace;
  --measure:62ch;
  --shell:1180px;
  --gut:clamp(20px,4.5vw,56px);
  --s1:8px;--s2:14px;--s3:22px;--s4:34px;--s5:52px;--s6:76px;--s7:104px;
  --ease-out-strong:cubic-bezier(0.23,1,0.32,1);
  --ease-in-out-strong:cubic-bezier(0.77,0,0.175,1);
  interpolate-size:allow-keywords;
}

/* ---- Base --------------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:82px;-webkit-tap-highlight-color:transparent}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  background:var(--paper);color:var(--ink);
  font:400 16px/1.65 var(--sans);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
::selection{background:var(--ink);color:var(--paper)}
img,svg,video{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
p a,li a,.link{color:var(--blue);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}
p a:hover,li a:hover,.link:hover{text-decoration-thickness:2px}
button{font:inherit;cursor:pointer;background:none;border:0;color:inherit}
:focus-visible{outline:2px solid var(--blue);outline-offset:3px;border-radius:2px}
main{display:block}
.skip{position:absolute;left:-9999px;top:0;background:var(--ink);color:var(--paper);padding:10px 18px;z-index:200;font-family:var(--mono);font-size:12px}
.skip:focus{left:0}
[hidden]{display:none !important}

/* ---- Type scale ---------------------------------------------------------- */
h1,h2,h3,.display{font-family:var(--serif);font-weight:550;letter-spacing:-.01em;color:var(--ink);text-wrap:balance}
h1{font-size:clamp(40px,6.2vw,76px);line-height:1.02;font-variation-settings:'opsz' 90}
h2{font-size:clamp(28px,3.6vw,44px);line-height:1.08;font-variation-settings:'opsz' 60}
h3{font-size:clamp(20px,2.2vw,26px);line-height:1.25;font-variation-settings:'opsz' 30}
.lede{font-size:clamp(16px,1.5vw,18.5px);line-height:1.6;color:var(--ink-soft);max-width:var(--measure);text-wrap:pretty}
.prose{max-width:var(--measure)}
.prose p,.prose ul,.prose ol{margin-bottom:1em;color:var(--ink-soft);font-size:15px;text-wrap:pretty}
.prose ul,.prose ol{padding-left:1.2em}
.prose h2{margin:1.6em 0 .5em}.prose h3{margin:1.4em 0 .4em}
.prose strong{color:var(--ink)}
.small{font-size:13.5px;color:var(--muted)}

/* Mono micro-label — the specimen-tag motif. Used sparingly, not per-section. */
.tag{font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.tag--accent{color:var(--orange-ink)}
.num{font-variant-numeric:tabular-nums lining-nums}

/* ---- Layout primitives --------------------------------------------------- */
.shell{max-width:var(--shell);margin-inline:auto;padding-inline:var(--gut)}
.section{padding-block:var(--s7)}
.section--tight{padding-block:var(--s6)}
.section--tint{background:var(--paper-deep)}
.rule{border:0;border-top:1px solid var(--rule)}
.rule--dark{border-top-color:var(--rule-dark)}
/* Editorial split: label column + content column */
.split{display:grid;gap:var(--s4);grid-template-columns:1fr}
@media (min-width:860px){.split{grid-template-columns:minmax(180px,280px) minmax(0,1fr);gap:var(--s5)}}
.split>.split-label{padding-top:6px}

/* ---- Header -------------------------------------------------------------- */
.hdr{position:sticky;top:0;z-index:100;background:color-mix(in srgb,var(--paper) 92%,transparent);backdrop-filter:blur(8px);border-bottom:1px solid var(--rule);transition:border-color .3s ease}
.hdr.scrolled{border-bottom-color:var(--rule-dark)}
.hdr-in{display:flex;align-items:center;gap:26px;min-height:66px}
.brand{display:flex;align-items:baseline;gap:10px;font-family:var(--serif);font-weight:620;font-size:19px;letter-spacing:-.01em}
.brand .brand-mark{width:15px;height:15px;background:var(--orange);display:inline-block;transform:translateY(1px)}
.brand .brand-est{font-family:var(--mono);font-size:10px;letter-spacing:.12em;color:var(--muted);font-weight:400}
.nav{display:none;align-items:center;gap:4px;margin-left:auto}
.nav a,.nav .nav-btn{font-size:14.5px;color:var(--ink-soft);padding:8px 12px;border-radius:4px}
.nav a:hover,.nav .nav-btn:hover{color:var(--ink);background:var(--paper-deep)}
.nav a[aria-current="page"]{color:var(--ink);text-decoration:underline;text-underline-offset:6px;text-decoration-color:var(--orange)}
/* CTA inside the nav: the .btn treatment must WIN the .nav a specificity fight —
   paper text on ink (default) and white on orange (hover), never ink-on-ink. */
.nav a.btn{color:var(--paper);background:var(--ink);border-radius:0}
.nav a.btn:hover{color:#fff;background:var(--orange-ink);border-color:var(--orange-ink)}
.nav a.btn[aria-current="page"]{text-decoration:none;color:var(--paper)}
.m-nav a.btn{color:var(--paper);background:var(--ink);border-bottom:0}
.m-nav a.btn:hover{color:#fff;background:var(--orange-ink)}
@media (min-width:980px){.nav{display:flex}.menu-t{display:none}}
/* Who-it's-for dropdown */
.nav-dd{position:relative}
.nav-dd>button{display:flex;align-items:center;gap:6px}
.nav-dd>button::after{content:"";width:7px;height:7px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:rotate(45deg) translateY(-2px);transition:transform .15s}
.nav-dd>button[aria-expanded="true"]::after{transform:rotate(-135deg) translateY(-2px)}
.dd-panel{position:absolute;top:calc(100% + 10px);left:0;min-width:280px;background:var(--paper);border:1px solid var(--rule);box-shadow:0 12px 40px rgba(17,17,16,.10);padding:10px;opacity:0;visibility:hidden;transform:translateY(-6px) scale(.97);transform-origin:top left;transition:opacity 120ms ease-out,transform 120ms ease-out,visibility 0s linear 120ms}
.nav-dd>button[aria-expanded="true"]+.dd-panel{opacity:1;visibility:visible;transform:none;transition:opacity 180ms var(--ease-out-strong),transform 180ms var(--ease-out-strong),visibility 0s}
@media (prefers-reduced-motion:reduce){.dd-panel{transform:none}}
.dd-panel a{display:block;padding:10px 12px;font-size:14.5px;color:var(--ink-soft)}
.dd-panel a:hover{background:var(--paper-deep);color:var(--ink)}
.dd-panel a small{display:block;font-size:12px;color:var(--muted)}
/* Mobile menu */
.menu-t{margin-left:auto;font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;padding:10px 4px}
.m-nav{display:grid;grid-template-rows:0fr;border-top:1px solid var(--rule);background:var(--paper);padding:0 var(--gut);transition:grid-template-rows 250ms var(--ease-out-strong),padding 250ms var(--ease-out-strong)}
.m-nav>div{overflow:hidden;min-height:0}
.m-nav.open{grid-template-rows:1fr;padding:10px var(--gut) 26px}
@media (prefers-reduced-motion:reduce){.m-nav{transition:none}}
.m-nav a{display:block;padding:13px 2px;font-size:17px;border-bottom:1px solid var(--rule);color:var(--ink)}
.m-nav .m-group{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);padding:20px 2px 6px}
.m-nav .m-cta{margin-top:18px;border:0}

/* ---- Buttons -------------------------------------------------------------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;font-weight:600;font-size:15px;line-height:1;padding:15px 26px;border:1px solid var(--ink);background:var(--ink);color:var(--paper);transition:background-color 150ms ease,color 150ms ease,border-color 150ms ease,transform 160ms var(--ease-out-strong);text-decoration:none}
.btn:hover{background:var(--orange-ink);border-color:var(--orange-ink);color:#fff}
.btn--ghost{background:transparent;color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.btn--lg{padding:18px 34px;font-size:16px}
.btn[aria-busy="true"]{opacity:.65;pointer-events:none}
.btn-arrow{display:inline-block;transition:transform .18s}
.btn:hover .btn-arrow{transform:translateX(3px)}
@media (prefers-reduced-motion:reduce){.btn,.btn-arrow{transition:none}}

/* ---- Hero ------------------------------------------------------------------ */
.hero{padding-block:clamp(56px,9vw,120px) var(--s6)}
.hero-grid{display:grid;gap:var(--s5);grid-template-columns:1fr}
@media (min-width:960px){.hero-grid{grid-template-columns:minmax(0,7.2fr) minmax(0,4.8fr);align-items:end}}
.hero h1 .accent{color:var(--orange)}
.hero .lede{margin-top:var(--s3)}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:var(--s4);align-items:center}
.hero-fine{margin-top:var(--s2);font-size:13px;color:var(--muted)}

/* Fact ledger — the hero's right column: ruled rows of verifiable facts */
.ledger{border-top:2px solid var(--rule-dark)}
.ledger-row{display:flex;justify-content:space-between;align-items:baseline;gap:16px;padding:14px 0;border-bottom:1px solid var(--rule)}
.ledger-row dt{font-size:13.5px;color:var(--muted)}
.ledger-row dd{font-family:var(--serif);font-weight:550;font-size:clamp(20px,2vw,26px);letter-spacing:-.01em;white-space:nowrap}
.ledger-row dd .unit{font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--muted);margin-left:6px;text-transform:uppercase}

/* ---- Index table (workflow / spec rows) ------------------------------------ */
.index-rows{border-top:2px solid var(--rule-dark)}
.index-row{display:grid;grid-template-columns:56px minmax(0,1fr);gap:18px;padding:26px 0;border-bottom:1px solid var(--rule)}
@media (min-width:860px){.index-row{grid-template-columns:72px minmax(220px,300px) minmax(0,1fr);gap:32px}}
.index-row .ix{font-family:var(--mono);font-size:12px;color:var(--faint);padding-top:7px}
.index-row h3{margin:0}
.index-row p{color:var(--ink-soft);max-width:56ch;font-size:15px}
@media (max-width:859px){.index-row p{grid-column:2}}

/* Link-rows (segment directory) */
.dir{border-top:2px solid var(--rule-dark)}
.dir a{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:baseline;gap:18px;padding:20px 2px;border-bottom:1px solid var(--rule);position:relative;transition:transform .2s var(--ease-out-strong)}
.dir a::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,var(--paper-deep),transparent);opacity:0;transition:opacity .2s ease;pointer-events:none}
@media (hover:hover) and (pointer:fine){.dir a:hover{transform:translateX(12px)}.dir a:hover::before{opacity:1}}
@media (prefers-reduced-motion:reduce){.dir a{transition:none}}
.dir .dir-name{font-family:var(--serif);font-weight:550;font-size:clamp(19px,2vw,24px)}
.dir .dir-note{font-size:13.5px;color:var(--muted);grid-column:1}
.dir .dir-go{font-family:var(--mono);font-size:12px;color:var(--muted)}
.dir a:hover .dir-go{color:var(--orange-ink)}

/* ---- Tables ------------------------------------------------------------------ */
.tbl-wrap{overflow-x:auto;border:1px solid var(--rule)}
table.tbl{width:100%;border-collapse:collapse;font-size:14.5px}
.tbl th{font-family:var(--mono);font-size:10.5px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);text-align:left;padding:12px 16px;background:var(--paper-deep);border-bottom:1px solid var(--rule)}
.tbl td{padding:13px 16px;border-bottom:1px solid var(--rule);vertical-align:top}
.tbl tr:last-child td{border-bottom:0}
.tbl .r{text-align:right;font-variant-numeric:tabular-nums}
.tbl .strike{color:var(--faint);text-decoration:line-through}

/* ---- Forms --------------------------------------------------------------------- */
.field{margin-bottom:var(--s3)}
.field label{display:block;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.field input,.field select,.field textarea{width:100%;font:inherit;font-size:16px;color:var(--ink);background:#fff;border:1px solid var(--rule);padding:13px 14px;border-radius:0}
.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid var(--blue);outline-offset:0;border-color:var(--blue)}
.field .hint{font-size:12.5px;color:var(--muted);margin-top:6px}
.form-error{color:var(--err);font-size:14px;margin:10px 0;font-weight:500}
.form-ok{color:var(--ok);font-size:14px;margin:10px 0;font-weight:500}

/* ---- FAQ (native details) --------------------------------------------------------- */
.faq{border-top:2px solid var(--rule-dark)}
.faq details{border-bottom:1px solid var(--rule)}
.faq summary{display:flex;justify-content:space-between;align-items:baseline;gap:18px;padding:20px 2px;cursor:pointer;font-family:var(--serif);font-weight:550;font-size:clamp(17px,1.8vw,21px);list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--mono);font-size:18px;color:var(--muted);flex:none;transition:transform 200ms var(--ease-out-strong)}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details::details-content{block-size:0;overflow:clip;transition:block-size 240ms var(--ease-out-strong),content-visibility 240ms allow-discrete}
.faq details[open]::details-content{block-size:auto}
@media (prefers-reduced-motion:reduce){.faq details::details-content{transition:none}.faq summary::after{transition:none}}
.faq .faq-a{padding:0 2px 20px;color:var(--ink-soft);max-width:var(--measure);font-size:14.5px}

/* ---- Quote / proof ------------------------------------------------------------------ */
.pull{font-family:var(--serif);font-weight:500;font-size:clamp(22px,3vw,34px);line-height:1.3;letter-spacing:-.01em;max-width:24em}
.pull .q{color:var(--orange)}

/* ---- Access panels (gate / review / pricing) ----------------------------------------- */
.panel{border:1px solid var(--rule);background:#fff;padding:clamp(26px,4vw,44px);max-width:640px}
.panel--wide{max-width:none}
.panel .tag{margin-bottom:14px;display:block}
.status-line{display:flex;gap:10px;align-items:center;font-family:var(--mono);font-size:12.5px;color:var(--muted);padding:8px 0}
.status-line .dot{width:8px;height:8px;border-radius:50%;background:var(--rule);flex:none}
.status-line.on .dot{background:var(--ok)}
.spin{width:16px;height:16px;border:2px solid var(--rule);border-top-color:var(--ink);border-radius:50%;animation:spin .8s linear infinite;flex:none}
@keyframes spin{to{transform:rotate(360deg)}}
@media (prefers-reduced-motion:reduce){.spin{animation-duration:2.4s}}

/* ---- Calculator ------------------------------------------------------------------------ */
.calc{display:grid;gap:var(--s4);grid-template-columns:1fr}
@media (min-width:900px){.calc{grid-template-columns:minmax(0,1fr) minmax(280px,360px)}}
.calc-out{border:1px solid var(--rule-dark);padding:26px;background:var(--paper-deep)}
.calc-out .big{font-family:var(--serif);font-weight:620;font-size:clamp(34px,4vw,52px);letter-spacing:-.02em;line-height:1}
.range-row{margin-bottom:var(--s3)}
.range-row .rr-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}
.range-row output{font-family:var(--mono);font-size:14px;font-weight:500}
input[type=range]{width:100%;accent-color:var(--orange);height:28px}

/* ---- CTA band ----------------------------------------------------------------------------- */
.cta-band{background:var(--ink);color:var(--paper);padding-block:var(--s6)}
.cta-band h2{color:var(--paper)}
.cta-band .lede{color:#c9c4bc}
.cta-band .btn{background:var(--orange-ink);border-color:var(--orange-ink);color:#fff}
.cta-band .btn:hover{background:var(--paper);border-color:var(--paper);color:var(--ink)}
.cta-band .tag{color:#9b958c}

/* ---- Footer ---------------------------------------------------------------------------------- */
.ftr{border-top:2px solid var(--rule-dark);padding:var(--s5) 0 var(--s4);font-size:14px}
.ftr-grid{display:grid;gap:var(--s4);grid-template-columns:1fr 1fr}
@media (min-width:860px){.ftr-grid{grid-template-columns:2fr 1fr 1fr 1fr}}
.ftr h4{font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.13em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.ftr li{list-style:none;margin-bottom:9px}
.ftr a{color:var(--ink-soft)}
.ftr a:hover{color:var(--ink);text-decoration:underline;text-underline-offset:3px}
.ftr-brand p{color:var(--muted);max-width:34ch;margin-top:10px}
.ftr-legal{display:flex;flex-wrap:wrap;gap:8px 22px;justify-content:space-between;border-top:1px solid var(--rule);margin-top:var(--s5);padding-top:var(--s3);color:var(--muted);font-size:12.5px}

/* ---- Notice / flag ------------------------------------------------------------------------------ */
.note{border-top:2px solid var(--rule-dark);padding:14px 0 0;color:var(--muted);font-size:13.5px;max-width:var(--measure)}

/* ---- Entrance motion (progressive, reduced-motion-safe) ------------------------------------------ */
@media (prefers-reduced-motion:no-preference){
  .rise{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s var(--ease-out-strong)}
  .rise.in{opacity:1;transform:none}
  @supports (animation-timeline:view()){ /* no-JS fallback stays visible */ }
}
.rise{opacity:1}
@media (prefers-reduced-motion:no-preference){.js .rise{opacity:0}.js .rise.in{opacity:1}}

/* ---- Print --------------------------------------------------------------------------------------- */
@media print{.hdr,.ftr,.cta-band,.menu-t{display:none}body{font-size:12pt}
  .rise,.rise-group>*,.diagram [data-pop],.figure.rise,.hero-choreo>*,.ledger-row{opacity:1 !important;transform:none !important;clip-path:none !important;animation:none !important}}

/* ============================================================================
   v2.1 — visual & motion system (video hero, figures, diagrams, choreography)
   ========================================================================== */

/* ---- Cinematic hero with background video ------------------------------- */
.hero--video{position:relative;overflow:hidden;padding-block:clamp(72px,11vw,150px) clamp(56px,8vw,110px)}
.hero-media{position:absolute;inset:0;z-index:0;pointer-events:none}
.hero-media video{width:100%;height:100%;object-fit:cover;object-position:center}
/* paper scrim: keeps ink text AA-readable over footage, integrates video with the brand */
.hero-media::after{content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(253,252,252,.96) 0%,rgba(253,252,252,.88) 44%,rgba(253,252,252,.55) 74%,rgba(253,252,252,.32) 100%)}
@media (max-width:759px){.hero-media::after{background:linear-gradient(180deg,rgba(253,252,252,.95) 0%,rgba(253,252,252,.82) 55%,rgba(253,252,252,.55) 100%)}}
.hero--video>.shell{position:relative;z-index:1}
.hero--video .ledger{background:color-mix(in srgb,var(--paper) 82%,transparent);backdrop-filter:blur(3px);padding:0 18px 4px;border-left:1px solid var(--rule)}

/* ---- Editorial figures ---------------------------------------------------- */
.figure{border:1px solid var(--rule);background:#fff;padding:10px}
.figure img{width:100%;height:auto;display:block;filter:saturate(.92) contrast(1.02)}
.figure figcaption{display:flex;justify-content:space-between;gap:12px;padding:10px 4px 2px;font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.figure--plain{border:0;background:none;padding:0}
.media-split{display:grid;gap:var(--s4);grid-template-columns:1fr;align-items:center}
@media (min-width:900px){.media-split{grid-template-columns:minmax(0,6fr) minmax(0,5.4fr);gap:var(--s5)}
  .media-split--flip>.media-split-fig{order:-1}}

/* ---- Process diagrams (inline SVG, line-draw on reveal) ------------------- */
.diagram{border:1px solid var(--rule);background:#fff;padding:clamp(16px,3vw,30px)}
.diagram svg{width:100%;height:auto}
.diagram .d-line{stroke:var(--ink);stroke-width:1.5;fill:none}
.diagram .d-accent{stroke:var(--orange);stroke-width:2;fill:none}
.diagram .d-node{fill:#fff;stroke:var(--ink);stroke-width:1.5}
.diagram .d-node--accent{fill:var(--orange);stroke:var(--orange)}
.diagram .d-label{font-family:var(--mono);font-size:10px;letter-spacing:.06em;fill:var(--muted);text-transform:uppercase}
.diagram .d-title{font-family:var(--sans);font-size:13px;font-weight:600;fill:var(--ink)}
.diagram .d-soft{stroke:var(--rule);stroke-width:1;fill:none}
.diagram .d-x{stroke:var(--err);stroke-width:1.6}
@media (prefers-reduced-motion:no-preference){
  .js .diagram [data-draw]{stroke-dasharray:var(--len,600);stroke-dashoffset:var(--len,600)}
  .js .diagram.in [data-draw]{animation:draw 1.4s cubic-bezier(.6,0,.2,1) forwards}
  .js .diagram.in [data-draw="2"]{animation-delay:.35s}
  .js .diagram.in [data-draw="3"]{animation-delay:.7s}
  @keyframes draw{to{stroke-dashoffset:0}}
  .js .diagram [data-pop]{opacity:0;transform:translateY(6px)}
  .js .diagram.in [data-pop]{transition:opacity .5s ease,transform .5s ease;opacity:1;transform:none}
  .js .diagram.in [data-pop="2"]{transition-delay:.4s}
  .js .diagram.in [data-pop="3"]{transition-delay:.8s}
  .js .diagram.in [data-pop="4"]{transition-delay:1.15s}
}

/* ---- Motion choreography --------------------------------------------------- */
@media (prefers-reduced-motion:no-preference){
  /* staggered children: apply .rise-group to a container */
  .js .rise-group>*{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s var(--ease-out-strong)}
  .js .rise-group.in>*{opacity:1;transform:none}
  .js .rise-group.in>*:nth-child(2){transition-delay:.06s}
  .js .rise-group.in>*:nth-child(3){transition-delay:.12s}
  .js .rise-group.in>*:nth-child(4){transition-delay:.18s}
  .js .rise-group.in>*:nth-child(5){transition-delay:.24s}
  .js .rise-group.in>*:nth-child(6){transition-delay:.30s}
  /* hero entrance choreography (page load, not scroll) */
  .js .hero-choreo>*{opacity:0;transform:translateY(16px);animation:heroIn .6s var(--ease-out-strong) forwards}
  .js .hero-choreo>*:nth-child(2){animation-delay:.08s}
  .js .hero-choreo>*:nth-child(3){animation-delay:.16s}
  .js .hero-choreo>*:nth-child(4){animation-delay:.24s}
  @keyframes heroIn{to{opacity:1;transform:none}}
  .js .hero--video .ledger{border-top-color:transparent;position:relative}
  .js .hero--video .ledger::before{content:"";position:absolute;top:-2px;left:0;right:0;height:2px;background:var(--rule-dark);transform:scaleX(0);transform-origin:left;animation:ruleIn .7s var(--ease-in-out-strong) .35s forwards}
  @keyframes ruleIn{to{transform:scaleX(1)}}
  .js .hero--video .ledger-row{opacity:0;transform:translateY(12px);animation:heroIn .6s var(--ease-out-strong) forwards}
  .js .hero--video .ledger-row:nth-child(1){animation-delay:.35s}
  .js .hero--video .ledger-row:nth-child(2){animation-delay:.43s}
  .js .hero--video .ledger-row:nth-child(3){animation-delay:.51s}
  .js .hero--video .ledger-row:nth-child(4){animation-delay:.59s}
  /* animated rules: draw in from left when revealed */
  .js .rule-draw{transform-origin:left center;transform:scaleX(0);transition:transform .9s cubic-bezier(.6,0,.2,1)}
  .js .rule-draw.in{transform:scaleX(1)}
  /* button press feedback */
  .btn:active{transform:scale(.97)}
  /* ledger dd count-up handled by JS (.count) */
}

/* ---- Pricing "what's the catch" visual ------------------------------------- */
.catch-grid{display:grid;gap:var(--s4);grid-template-columns:1fr}
@media (min-width:900px){.catch-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}}
.catch-card{border-top:2px solid var(--rule-dark);padding-top:18px}
.catch-card .tag{display:block;margin-bottom:10px}
.catch-card h3{font-size:19px;margin-bottom:8px}
.catch-card p{font-size:15px;color:var(--ink-soft);max-width:44ch}

@media (min-width:900px) and (prefers-reduced-motion:no-preference){.js .hero-media video{transform:scale(1.06)}}

/* video fallback: with reduced motion or no JS, sources don't load — show poster */
.hero-media img.poster{width:100%;height:100%;object-fit:cover}

/* ---- v2.2 brand: "Three Bars — Center Led" (approved 2026-07-03) ----------
   Logo-scoped colors per the approved spec: NCL Navy #0B1D33 · NCL Orange #F47A20.
   Site accent tokens are unchanged pending a palette-unification decision. */
.brand{gap:12px;align-items:center}
.brand-bars{flex:none;display:block}
.brand-stack{display:flex;flex-direction:column;font:700 10.5px/1.18 var(--sans);letter-spacing:.15em;color:#0B1D33}
.brand-stack .labs{color:var(--orange-ink)}
.ftr .brand-stack{font-size:11px}


/* ---- v2.3 · Emil pass: figure entrances, photo integration, quotes, links ---- */
.nav a,.nav .nav-btn,.dd-panel a,.ftr a{transition:background-color 150ms ease,color 150ms ease}
@media (prefers-reduced-motion:no-preference){
  .js .figure.rise{transform:none;clip-path:inset(0 0 100% 0);transition:clip-path .9s var(--ease-in-out-strong),opacity .5s ease}
  .js .figure.rise img{transform:scale(1.05);transition:transform 1.1s var(--ease-out-strong)}
  .js .figure.rise.in{clip-path:inset(0 0 0 0)}
  .js .figure.rise.in img{transform:none}
}
/* Photographs sit IN the layout, not in white boxes: no frame, warm tint,
   asymmetric bleed toward the nearest viewport edge, mono margin-note caption. */
.figure--photo{border:0;background:none;padding:0}
.figure--photo img{filter:saturate(.85) contrast(1.03) sepia(.05)}
.figure--photo figcaption{padding:12px 0 0;border-top:1px solid var(--rule);margin-top:0}
@media (min-width:900px){
  .media-split-fig.figure--photo{margin-right:min(calc(-1 * var(--gut)), calc((var(--shell) - 100vw) / 2))}
  .media-split--flip .media-split-fig.figure--photo{margin-right:0;margin-left:min(calc(-1 * var(--gut)), calc((var(--shell) - 100vw) / 2))}
  .media-split-fig.figure--photo figcaption{margin-right:max(var(--gut), calc((100vw - var(--shell)) / 2))}
}
.figure--band{border:0;background:none;padding:0;position:relative;margin-inline:min(calc(-1 * var(--gut)), calc((var(--shell) - 100vw) / 2))}
.figure--band img{filter:saturate(.85) contrast(1.03) sepia(.05);aspect-ratio:21/8;object-fit:cover;width:100%}
.figure--band figcaption{position:absolute;left:max(var(--gut), calc((100vw - var(--shell)) / 2));bottom:14px;background:var(--paper);padding:8px 14px;border:0}
/* Testimonials: compact 3-up, quieter type */
.quotes{display:grid;gap:26px;grid-template-columns:1fr;border-top:2px solid var(--rule-dark);padding-top:30px}
@media (min-width:900px){.quotes{grid-template-columns:1fr 1fr 1fr;gap:38px}}
.quotes blockquote{margin:0}
.quotes .qmark{font-family:var(--serif);font-size:30px;line-height:1;color:var(--orange);display:block;margin-bottom:10px}
.quotes p{font-family:var(--serif);font-weight:500;font-size:16px;line-height:1.55;color:var(--ink);text-wrap:pretty}
.quotes footer{margin-top:12px}


/* ---- v2.3b · impeccable pass ---- */
/* rules that draw where structure appears (requisition being ruled) */
@media (prefers-reduced-motion:no-preference){
  .js .index-rows.rise-group,.js .dir.rise-group,.js .quotes.rise-group{border-top-color:transparent;position:relative}
  .js :is(.index-rows,.dir,.quotes).rise-group::before{content:"";position:absolute;top:-2px;left:0;right:0;height:2px;background:var(--rule-dark);transform:scaleX(0);transform-origin:left;transition:transform .8s var(--ease-in-out-strong)}
  .js :is(.index-rows,.dir,.quotes).rise-group.in::before{transform:scaleX(1)}
  .figure--photo img,.figure--band img{will-change:transform}
  @media (hover:hover){.figure--photo:hover img{transform:scale(1.02);transition:transform .8s var(--ease-out-strong)}}
}
/* mobile hero: numbers before fine print; eyebrow holds one line */
@media (max-width:759px){
  .hero-grid{display:flex;flex-direction:column}
  .hero--video .hero-fine{order:5;margin-top:var(--s3)}
  .hero--video .tag--accent{font-size:10px;letter-spacing:.08em}
}
/* gate: redacted preview beside the form */
.gate-wrap{display:grid;gap:26px;grid-template-columns:1fr}
@media (min-width:960px){.gate-wrap{grid-template-columns:minmax(0,520px) minmax(0,1fr);align-items:start}}
.sheet-preview{border:1px solid var(--rule);background:#fff;padding:18px 20px;position:relative}
.sheet-preview table{width:100%;border-collapse:collapse;font-size:13.5px}
.sheet-preview th{font:500 10px var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--muted);text-align:left;padding:8px 6px;border-bottom:1px solid var(--rule)}
.sheet-preview td{padding:9px 6px;border-bottom:1px solid var(--rule);color:var(--ink-soft)}
.sheet-preview td.red{filter:blur(5px);user-select:none;color:var(--muted);text-align:right}
.sheet-preview .sp-note{font:500 10px var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--orange-ink);margin-top:12px}

/* ---- v2.3c fixes ---- */
/* data graphics (the US map) must not get the warm photo tint — it reads faded */
.figure--data img{filter:contrast(1.12) saturate(1.15)}
/* scroll-linked drift on photographs (progressive; supported browsers only) */
@media (prefers-reduced-motion:no-preference){
  @supports (animation-timeline: view()){
    .figure--band img{animation:drift linear both;animation-timeline:view();animation-range:entry 0% exit 100%;scale:1.08}
    .media-split-fig.figure--photo img{animation:driftS linear both;animation-timeline:view();animation-range:entry 0% exit 100%}
    @keyframes drift{from{translate:0 -3.5%}to{translate:0 3.5%}}
    @keyframes driftS{from{translate:0 -2%}to{translate:0 2%}}
  }
}
/* "What's the catch" visual: constrained + cropped above the specimen-cup row */
.catch-fig{max-width:840px;margin-inline:0}
.catch-fig img{aspect-ratio:21/9;object-fit:cover;object-position:50% 10%}

#ncl-pricing-h:focus,#ncl-pricing-h:focus-visible{outline:none}

/* ---- v2.4 · hero recomposition + segment hero imagery ---- */
.hero--video{padding-block:clamp(48px,7.5vw,104px) clamp(48px,7vw,96px)}
/* stat band below the hero (v1-style) — full video stays visible */
.stat-band{border-bottom:1px solid var(--rule)}
.stat-band .ledger{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:2px solid var(--rule-dark)}
.stat-band .ledger-row{display:block;padding:22px 18px 20px;border-bottom:0;border-right:1px solid var(--rule)}
.stat-band .ledger-row:last-child{border-right:0}
.stat-band .ledger-row dt{margin-bottom:6px}
.stat-band .ledger-row dd{white-space:normal}
@media (max-width:759px){.stat-band .ledger{grid-template-columns:1fr 1fr}.stat-band .ledger-row:nth-child(2){border-right:0}.stat-band .ledger-row:nth-child(-n+2){border-bottom:1px solid var(--rule)}}
/* segment hero: text left, photograph right (bleeds to the viewport edge) */
.hero-grid--seg{display:grid;gap:var(--s5);grid-template-columns:1fr;align-items:center}
@media (min-width:960px){.hero-grid--seg{grid-template-columns:minmax(0,6.4fr) minmax(0,5.2fr)}}
.hero-fig{border:0;background:none;padding:0;margin:0}
.hero-fig img{filter:saturate(.85) contrast(1.03) sepia(.05);width:100%;height:auto}
@media (min-width:960px){
  .hero-fig{margin-right:min(calc(-1 * var(--gut)), calc((var(--shell) - 100vw) / 2))}
  .hero-fig img{aspect-ratio:5/4;object-fit:cover}
}

/* ---- consumer banner (ported from v1; v2 tokens) ---- */
.ncb-bar{position:relative;z-index:110;background:var(--paper-deep);border-bottom:1px solid var(--rule)}
.ncb-inner{display:grid;align-items:center;column-gap:14px;row-gap:3px;max-width:var(--shell);margin:0 auto;padding:0 var(--gut);min-height:44px;grid-template-columns:auto 1fr auto auto;grid-template-areas:"headline body cta close"}
.ncb-headline{grid-area:headline;margin:0;font:600 13px var(--sans);color:var(--ink);white-space:nowrap}
.ncb-body{grid-area:body;margin:0;font:400 12.5px/1.4 var(--sans);color:var(--muted);text-wrap:pretty}
.ncb-cta{grid-area:cta;display:inline-flex;align-items:center;gap:5px;white-space:nowrap;font:500 13px var(--sans);color:var(--blue);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}
.ncb-cta:hover .ncb-arrow{transform:translateX(2px)}
.ncb-arrow{display:inline-block;transition:transform .18s ease}
.ncb-close{grid-area:close;display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;color:var(--muted);border-radius:50%}
.ncb-close:hover{color:var(--ink)}
@media (max-width:1059px){.ncb-inner{grid-template-columns:1fr auto;padding-block:8px;grid-template-areas:"headline close" "body cta"}.ncb-cta{justify-self:end}}
@media (max-width:640px){.ncb-inner{grid-template-areas:"headline close" "body body" "cta cta"}.ncb-cta{justify-self:start;padding:4px 0}}
@media (prefers-reduced-motion:reduce){.ncb-arrow{transition:none}}
