/* ============================================================
   Workflow Prodigy. Marketing site stylesheet.
   Design tokens, layout primitives, and components.
   Single source of truth for every page.
   ============================================================ */

/* ===== Tokens ===== */
:root{
  --bg:#0a0e1a; --bg-2:#0f1424; --panel:#131a2c; --panel-2:#1a2236; --panel-3:#212a40;
  --line:#2a3450; --line-2:#1f2840;
  --ink:#ffffff; --ink-2:#c9d1e2; --ink-3:#8a93ad; --ink-4:#5a6585;
  --brand:#3874ff; --brand-2:rgba(56,116,255,.18); --brand-3:rgba(56,116,255,.08);
  --amber:#f5a623; --amber-2:rgba(245,166,35,.18);
  --good:#28d17c; --good-2:rgba(40,209,124,.18);
  --info:#38bdf8; --info-2:rgba(56,189,248,.18);
  /* "violet" intentionally aliased to info. We use blue, cyan, green, and amber
     accents only. No purple. The token name is retained for backwards
     compatibility with class names like .feature.violet so we do not have to
     rewrite markup. */
  --violet:#38bdf8; --violet-2:rgba(56,189,248,.18);
  --rose:#f5a623; --rose-2:rgba(245,166,35,.18);
  --shadow:0 8px 24px -8px rgba(0,0,0,.65),0 2px 4px rgba(0,0,0,.25);
  --shadow-lg:0 24px 48px -16px rgba(0,0,0,.8);
  --r-sm:4px; --r:6px; --r-lg:10px; --r-xl:14px;
}
html[data-theme="light"]{
  --bg:#f4f6fb; --bg-2:#ffffff; --panel:#ffffff; --panel-2:#f0f3f9; --panel-3:#e3e8f1;
  --line:#d6dcea; --line-2:#e3e8f1;
  --ink:#14213d; --ink-2:#2c3a5e; --ink-3:#5b6884; --ink-4:#8a93ad;
  --shadow:0 8px 24px -8px rgba(20,33,61,.18),0 2px 4px rgba(20,33,61,.06);
  --shadow-lg:0 24px 48px -16px rgba(20,33,61,.22);
}
html[data-theme="light"] body{color:var(--ink-2)}

/* ===== Reset + base ===== */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;color:var(--ink-2);background:var(--bg);font-size:14px;line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
button{font:inherit}
a{color:var(--brand);text-decoration:none}
a:hover{color:var(--ink)}
img,svg{max-width:100%;display:block}
:focus-visible{outline:2px solid var(--brand);outline-offset:2px;border-radius:var(--r-sm)}
hr{border:0;border-top:1px solid var(--line);margin:24px 0}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--brand);color:#fff;padding:8px 12px;border-radius:var(--r-sm);z-index:100;font-weight:600}
.skip-link:focus{left:12px;top:12px}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
.wrap-narrow{max-width:820px;margin:0 auto;padding:0 24px}

/* Reduced motion. */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
}

/* ===== Brand lockup ===== */
.brand{display:inline-flex;align-items:center;gap:10px;text-decoration:none}
.brand:hover{text-decoration:none}
.brand-icon{width:34px;height:34px;border-radius:8px;display:block;flex:none;box-shadow:0 4px 14px rgba(56,116,255,.35);object-fit:cover;background:var(--bg-2)}
img.brand-icon{display:block}
.preview-side .lockup .lockup-mark{width:22px;height:22px;border-radius:5px;display:block}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-text b{color:var(--ink);font-weight:700;font-size:15px;letter-spacing:-.01em;white-space:nowrap}
.brand-text small{color:var(--ink-3);font-family:'JetBrains Mono',ui-monospace,monospace;font-size:9.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;margin-top:3px;white-space:nowrap}

/* ===== Nav ===== */
.site-nav{position:sticky;top:0;z-index:50;background:rgba(15,20,36,.82);backdrop-filter:saturate(140%) blur(10px);-webkit-backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--line)}
html[data-theme="light"] .site-nav{background:rgba(255,255,255,.85)}
.site-nav .row{height:60px;display:flex;align-items:center;gap:18px}
.site-nav .links{display:flex;align-items:center;gap:4px;margin-left:14px}
.site-nav .links a{color:var(--ink-3);font-size:13px;font-weight:500;padding:6px 10px;border-radius:var(--r-sm);white-space:nowrap}
.site-nav .links a:hover,.site-nav .links a[aria-current="page"]{color:var(--ink);background:var(--panel)}
.site-nav .right{margin-left:auto;display:flex;align-items:center;gap:8px}
@media (max-width:1180px){.brand-text small{display:none}.site-nav .row{gap:12px}.site-nav .links{gap:2px}.site-nav .links a{padding:6px 8px}}
@media (max-width:1024px){.site-nav .links{display:none}}
@media (max-width:760px){.site-nav .right .btn-talk{display:none}}
@media (max-width:520px){.brand-text{display:none}.site-nav .right .btn.ghost{display:none}.site-nav .row{height:54px;gap:8px}}

/* Mobile drawer toggle (hidden until <=1024px). */
.nav-toggle{display:none;width:34px;height:34px;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-sm);color:var(--ink-2);cursor:pointer;align-items:center;justify-content:center;flex:none}
.nav-toggle svg{width:18px;height:18px}
.nav-toggle:hover{background:var(--panel-2);color:var(--ink)}
@media (max-width:1024px){.nav-toggle{display:inline-flex}}
.nav-drawer{display:none;border-top:1px solid var(--line);background:var(--bg-2)}
.nav-drawer.open{display:block}
.nav-drawer .wrap{display:flex;flex-direction:column;gap:2px;padding-top:12px;padding-bottom:16px}
.nav-drawer a{color:var(--ink-2);font-size:14px;font-weight:500;padding:9px 12px;border-radius:var(--r-sm)}
.nav-drawer a:hover,.nav-drawer a[aria-current="page"]{background:var(--panel);color:var(--ink)}
.nav-drawer h5{margin:12px 0 4px;color:var(--ink-3);font-family:'JetBrains Mono',ui-monospace,monospace;font-size:10.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase}

/* ===== Buttons ===== */
.btn{height:36px;padding:0 14px;border-radius:var(--r-sm);border:1px solid var(--line);background:var(--panel);color:var(--ink-2);font-size:13px;font-weight:600;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;text-decoration:none;font-family:inherit;transition:background .15s ease,color .15s ease,border-color .15s ease,transform .1s ease,box-shadow .15s ease}
.btn:hover{background:var(--panel-2);color:var(--ink)}
.btn.primary{background:var(--brand);color:#fff;border-color:var(--brand);box-shadow:0 4px 14px rgba(56,116,255,.35)}
.btn.primary:hover{background:#2a5dd8;border-color:#2a5dd8;color:#fff;transform:translateY(-1px);box-shadow:0 8px 20px rgba(56,116,255,.45)}
.btn.lg{height:44px;padding:0 20px;font-size:14px}
.btn.ghost{background:transparent;border-color:transparent;color:var(--ink-2)}
.btn.ghost:hover{background:var(--panel);color:var(--ink)}
.btn .arrow{transition:transform .15s ease}
.btn:hover .arrow{transform:translateX(3px)}

/* ===== Theme toggle ===== */
.theme-toggle{width:32px;height:32px;padding:0;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-sm);color:var(--ink-2);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.theme-toggle:hover{background:var(--panel-2);color:var(--ink)}
.theme-toggle svg{display:block;width:16px;height:16px}
.theme-toggle .icon-sun{display:none}
.theme-toggle .icon-moon{display:block}
html[data-theme="dark"] .theme-toggle .icon-sun{display:block}
html[data-theme="dark"] .theme-toggle .icon-moon{display:none}

/* ===== Eyebrow ===== */
.eyebrow{color:var(--ink-3);font-family:'JetBrains Mono',ui-monospace,monospace;font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;display:inline-flex;align-items:center;gap:6px}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--brand);box-shadow:0 0 0 2px rgba(56,116,255,.18)}
.eyebrow.violet{color:var(--violet)}.eyebrow.violet .dot{background:var(--violet);box-shadow:0 0 0 2px rgba(56,189,248,.18)}
.eyebrow.good{color:var(--good)}.eyebrow.good .dot{background:var(--good);box-shadow:0 0 0 2px rgba(40,209,124,.18)}
.eyebrow.amber{color:var(--amber)}.eyebrow.amber .dot{background:var(--amber);box-shadow:0 0 0 2px rgba(245,166,35,.18)}
.eyebrow.info{color:var(--info)}.eyebrow.info .dot{background:var(--info);box-shadow:0 0 0 2px rgba(56,189,248,.18)}

/* ===== Section ===== */
section{padding:72px 0;border-bottom:1px solid var(--line)}
section.compact{padding:48px 0}
section.tight{padding:36px 0}
@media (max-width:760px){section{padding:48px 0}section.compact{padding:32px 0}.section-head{margin-bottom:28px}.section-head h2{font-size:24px}.cta-banner{padding:32px 22px}.cta-banner h2{font-size:22px}}
.section-head{max-width:720px;margin:0 0 36px}
.section-head.center{margin:0 auto 40px;text-align:center}
.section-head h2{color:var(--ink);font-size:30px;font-weight:800;letter-spacing:-.025em;margin:8px 0 10px;line-height:1.1}
.section-head p{color:var(--ink-3);font-size:15px;margin:0;line-height:1.6}

/* ===== Breadcrumbs ===== */
.crumbs{padding:14px 0;border-bottom:1px solid var(--line);background:var(--bg-2)}
.crumbs ol{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:6px;align-items:center;font-family:'JetBrains Mono',ui-monospace,monospace;font-size:10.5px;letter-spacing:.06em;text-transform:uppercase}
.crumbs li{color:var(--ink-3)}
.crumbs li a{color:var(--ink-3)}
.crumbs li a:hover{color:var(--ink)}
.crumbs li[aria-current="page"]{color:var(--ink)}
.crumbs li+li::before{content:"/";margin-right:6px;color:var(--ink-4)}

/* ===== HERO. Homepage. ===== */
.hero{position:relative;padding:64px 0 80px;border-bottom:1px solid var(--line);overflow:hidden;background:radial-gradient(900px 480px at 85% -10%, rgba(56,189,248,.16), transparent 60%),radial-gradient(900px 480px at -10% 5%, rgba(56,116,255,.20), transparent 60%),var(--bg)}
.hero::before{content:"";position:absolute;inset:0;background:linear-gradient(transparent 95%,rgba(255,255,255,.04) 95%) 0 0/100% 56px,linear-gradient(90deg,transparent 95%,rgba(255,255,255,.04) 95%) 0 0/56px 100%;pointer-events:none}
html[data-theme="light"] .hero::before{background:linear-gradient(transparent 95%,rgba(11,18,32,.04) 95%) 0 0/100% 56px,linear-gradient(90deg,transparent 95%,rgba(11,18,32,.04) 95%) 0 0/56px 100%}
.hero-grid{position:relative;display:grid;grid-template-columns:1.05fr 1fr;gap:48px;align-items:center}
.hero-fg .eyebrow{margin-bottom:14px}
.hero-fg h1{color:var(--ink);font-size:clamp(34px,4.4vw,56px);font-weight:800;line-height:1.04;letter-spacing:-.025em;margin:0 0 16px}
.hero-fg h1 .accent{color:var(--brand)}
.hero-fg p.lede{color:var(--ink-2);font-size:17px;line-height:1.55;margin:0 0 24px;max-width:540px}
.hero-fg .cta{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.hero-fg .micro{margin-top:18px;color:var(--ink-3);font-family:'JetBrains Mono',ui-monospace,monospace;font-size:11px;letter-spacing:.04em;text-transform:uppercase;display:flex;flex-wrap:wrap;align-items:center;gap:8px}
.hero-fg .micro .sep{color:var(--ink-4)}
.hero-fg .micro b{color:var(--ink);font-weight:700}

/* ===== HERO. Child page. ===== */
.page-hero{position:relative;padding:52px 0 44px;border-bottom:1px solid var(--line);overflow:hidden;background:radial-gradient(900px 380px at 85% -10%, rgba(56,189,248,.14), transparent 60%),radial-gradient(900px 380px at -10% 5%, rgba(56,116,255,.18), transparent 60%),var(--bg)}
.page-hero::before{content:"";position:absolute;inset:0;background:linear-gradient(transparent 95%,rgba(255,255,255,.04) 95%) 0 0/100% 56px,linear-gradient(90deg,transparent 95%,rgba(255,255,255,.04) 95%) 0 0/56px 100%;pointer-events:none}
html[data-theme="light"] .page-hero::before{background:linear-gradient(transparent 95%,rgba(11,18,32,.04) 95%) 0 0/100% 56px,linear-gradient(90deg,transparent 95%,rgba(11,18,32,.04) 95%) 0 0/56px 100%}
.page-hero h1{color:var(--ink);font-size:clamp(30px,3.4vw,44px);font-weight:800;line-height:1.06;letter-spacing:-.025em;margin:12px 0 14px}
.page-hero h1 .accent{color:var(--brand)}
.page-hero p.lede{color:var(--ink-2);font-size:16px;line-height:1.55;margin:0 0 20px;max-width:680px}
.page-hero .cta{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.page-hero .meta{margin-top:16px;color:var(--ink-3);font-family:'JetBrains Mono',ui-monospace,monospace;font-size:11px;letter-spacing:.04em;text-transform:uppercase;display:flex;flex-wrap:wrap;align-items:center;gap:10px}
.page-hero .meta .sep{color:var(--ink-4)}

/* ===== Product preview frame (homepage hero). ===== */
.preview{position:relative;border-radius:12px;overflow:hidden;background:linear-gradient(180deg,var(--panel) 0%,var(--bg-2) 100%);border:1px solid var(--line);box-shadow:var(--shadow-lg)}
.preview-bar{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--line);background:var(--bg-2)}
.preview-bar .dots{display:flex;gap:6px}
.preview-bar .dots i{width:10px;height:10px;border-radius:50%;display:inline-block}
.preview-bar .dots i:nth-child(1){background:#ef4444}.preview-bar .dots i:nth-child(2){background:#f5a623}.preview-bar .dots i:nth-child(3){background:#28d17c}
.preview-bar .url{flex:1;background:var(--panel);border:1px solid var(--line);border-radius:4px;padding:5px 10px;font-family:'JetBrains Mono',ui-monospace,monospace;font-size:11px;color:var(--ink-3);text-align:center}
.preview-body{display:grid;grid-template-columns:148px 1fr;min-height:380px}
.preview-side{background:var(--bg-2);border-right:1px solid var(--line);padding:14px 10px;display:flex;flex-direction:column;gap:3px}
.preview-side .lockup{display:flex;align-items:center;gap:8px;padding:6px 8px 14px;border-bottom:1px solid var(--line);margin-bottom:6px}
.preview-side .lockup span{color:var(--ink);font-weight:700;font-size:12px}
.preview-side a{display:flex;align-items:center;gap:8px;padding:6px 9px;border-radius:4px;color:var(--ink-3);font-size:12px;font-weight:500;text-decoration:none}
.preview-side a svg{width:13px;height:13px;flex:none}
.preview-side a:hover{background:var(--panel);color:var(--ink)}
.preview-side a.active{background:var(--brand-2);color:var(--brand);box-shadow:inset 0 0 0 1px rgba(56,116,255,.3)}
.preview-main{padding:18px}
.preview-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.preview-h h5{margin:0;color:var(--ink);font-size:13px;font-weight:700}
.preview-h .pill{font-family:'JetBrains Mono',ui-monospace,monospace;font-size:9.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);background:var(--panel);padding:3px 8px;border-radius:3px;border:1px solid var(--line)}
.preview-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}
.preview-stats .s{background:var(--panel);border:1px solid var(--line);border-radius:6px;padding:10px;position:relative;overflow:hidden}
.preview-stats .s::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--brand)}
.preview-stats .s.good::before{background:var(--good)}
.preview-stats .s.violet::before{background:var(--violet)}
.preview-stats .s .l{font-family:'JetBrains Mono',ui-monospace,monospace;font-size:8.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3)}
.preview-stats .s svg{display:block;width:100%;height:32px;margin-top:6px}
.preview-rows{background:var(--panel);border:1px solid var(--line);border-radius:6px;padding:10px}
.preview-rows .row{display:grid;grid-template-columns:1fr auto;gap:10px;padding:6px 4px;font-family:'JetBrains Mono',ui-monospace,monospace;font-size:10px;align-items:center;border-bottom:1px solid var(--line)}
.preview-rows .row:last-child{border-bottom:0}
.preview-rows .row.h{color:var(--ink-3);font-size:8.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase}
.preview-rows .row .lbl{color:var(--ink);font-weight:600;display:flex;align-items:center;gap:8px}
.preview-rows .row .lbl::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--brand)}
.preview-rows .row.good .lbl::before{background:var(--good)}.preview-rows .row.violet .lbl::before{background:var(--violet)}.preview-rows .row.amber .lbl::before{background:var(--amber)}
.preview-rows .row .v{color:var(--ink-3);font-weight:700;letter-spacing:.04em;text-transform:uppercase;font-size:9.5px}

/* Floating accent toast on the preview */
.toast{position:absolute;left:-18px;bottom:54px;background:var(--bg-2);border:1px solid var(--line);border-radius:6px;padding:10px 14px;display:flex;gap:10px;align-items:center;box-shadow:var(--shadow);animation:toast-float 6s ease-in-out infinite}
.toast .ic{width:28px;height:28px;border-radius:6px;background:var(--good-2);color:var(--good);display:grid;place-items:center;font-family:'JetBrains Mono',ui-monospace,monospace;font-weight:800;font-size:11px;letter-spacing:.04em;flex:none}
.toast .body{font-size:11.5px;color:var(--ink-2);line-height:1.4}
.toast .body b{color:var(--ink);font-weight:700}
.toast .body .lbl{font-family:'JetBrains Mono',ui-monospace,monospace;font-size:8.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);display:block;margin-bottom:1px}
@keyframes toast-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@media (prefers-reduced-motion:reduce){.toast{animation:none}}

@media (max-width:960px){
  .hero{padding:48px 0 56px}
  .hero-grid{grid-template-columns:1fr;gap:36px}
  .preview-side{display:none}
  .preview-body{grid-template-columns:1fr}
  .toast{left:auto;right:-18px;bottom:30px}
}
@media (max-width:760px){
  .hero{padding:36px 0 44px}
  .hero-fg h1{font-size:34px;line-height:1.06}
  .hero-fg p.lede{font-size:15.5px}
  .hero-fg .cta{flex-direction:column;align-items:stretch}
  .hero-fg .cta .btn{justify-content:center;width:100%}
  .hero-fg .micro{gap:6px;font-size:10.5px}
  .preview-stats{grid-template-columns:1fr}
  .cta-row{justify-content:stretch}
  .page-hero{padding:36px 0 32px}
  .page-hero .cta{flex-direction:column;align-items:stretch}
  .page-hero .cta .btn{justify-content:center;width:100%}
}
@media (max-width:480px){
  .hero-fg h1{font-size:32px}
  .preview-bar .url{font-size:10px}
  .preview-rows .row{grid-template-columns:1fr auto}
}
@media (max-width:520px){.toast{display:none}}

/* ===== Steps ===== */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.step{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:20px;position:relative;overflow:hidden}
.step::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--brand),transparent);opacity:.85}
.step .n{font-family:'JetBrains Mono',ui-monospace,monospace;font-size:26px;font-weight:800;color:var(--brand);letter-spacing:-.02em;line-height:1}
.step h3{color:var(--ink);font-size:16px;font-weight:700;margin:12px 0 6px;letter-spacing:-.01em}
.step p{color:var(--ink-3);font-size:13.5px;line-height:1.6;margin:0}
@media (max-width:760px){.steps{grid-template-columns:1fr}}

/* ===== Features ===== */
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.feature{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:20px;position:relative;overflow:hidden;transition:border-color .15s ease,transform .15s ease;text-decoration:none;color:inherit;display:block}
.feature:hover{border-color:rgba(56,116,255,.4);transform:translateY(-2px);text-decoration:none;color:inherit}
.feature .ic{width:40px;height:40px;border-radius:var(--r-sm);background:var(--brand-2);color:var(--brand);display:grid;place-items:center;margin-bottom:14px;font-family:'JetBrains Mono',ui-monospace,monospace;font-weight:800;font-size:13px;letter-spacing:.04em}
.feature .ic svg{width:22px;height:22px;display:block}
.feature.amber .ic{background:var(--amber-2);color:var(--amber)}
.feature.good .ic{background:var(--good-2);color:var(--good)}
.feature.violet .ic{background:var(--violet-2);color:var(--violet)}
.feature.info .ic{background:var(--info-2);color:var(--info)}
.feature.rose .ic{background:var(--rose-2);color:var(--rose)}
.feature h3{color:var(--ink);font-size:15px;font-weight:700;letter-spacing:-.01em;margin:0 0 6px}
.feature p{color:var(--ink-3);font-size:13.5px;line-height:1.6;margin:0}
.feature .more{display:inline-flex;align-items:center;gap:6px;margin-top:10px;color:var(--brand);font-family:'JetBrains Mono',ui-monospace,monospace;font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}
.feature.amber .more{color:var(--amber)}.feature.good .more{color:var(--good)}.feature.violet .more{color:var(--violet)}.feature.info .more{color:var(--info)}.feature.rose .more{color:var(--rose)}
@media (max-width:920px){.feature-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.feature-grid{grid-template-columns:1fr}}

/* ===== Engineering cards ===== */
.eng-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:8px}
.eng-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:22px;position:relative;overflow:hidden;transition:border-color .15s ease,transform .15s ease;text-decoration:none;color:inherit;display:block}
.eng-card:hover{border-color:rgba(56,116,255,.4);transform:translateY(-2px);text-decoration:none;color:inherit}
.eng-card::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--brand),var(--info));opacity:.85}
.eng-card.b::before{background:linear-gradient(90deg,var(--brand),var(--info))}
.eng-card.c::before{background:linear-gradient(90deg,var(--good),var(--info))}
.eng-card .badge{display:inline-block;font-family:'JetBrains Mono',ui-monospace,monospace;font-size:9.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--brand);background:var(--brand-2);padding:3px 7px;border-radius:3px;margin-bottom:12px}
.eng-card.b .badge{color:var(--info);background:var(--info-2)}
.eng-card.c .badge{color:var(--good);background:var(--good-2)}
.eng-card h3{color:var(--ink);font-size:17px;font-weight:700;letter-spacing:-.01em;margin:0 0 8px}
.eng-card p{color:var(--ink-3);font-size:13.5px;line-height:1.6;margin:0 0 12px}
.eng-card ul{list-style:none;padding:0;margin:0;display:grid;gap:5px}
.eng-card ul li{color:var(--ink-2);font-size:13px;display:flex;align-items:flex-start;gap:8px}
.eng-card ul li::before{content:"";flex:none;width:5px;height:5px;border-radius:50%;background:var(--brand);margin-top:7px}
.eng-card.b ul li::before{background:var(--info)}
.eng-card.c ul li::before{background:var(--good)}
.eng-card .more{display:inline-flex;align-items:center;gap:6px;margin-top:12px;color:var(--brand);font-family:'JetBrains Mono',ui-monospace,monospace;font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}
.eng-card.b .more{color:var(--info)}.eng-card.c .more{color:var(--good)}
@media (max-width:920px){.eng-grid{grid-template-columns:repeat(2,1fr);gap:14px}}
@media (max-width:680px){.eng-grid{grid-template-columns:1fr}}

/* ===== Two-column "feature + visual" ===== */
.split{display:grid;grid-template-columns:1.05fr 1fr;gap:40px;align-items:center}
.split.reverse{grid-template-columns:1fr 1.05fr}
.split.reverse .split-fg{order:2}
.split-fg h2{color:var(--ink);font-size:26px;font-weight:800;letter-spacing:-.02em;line-height:1.12;margin:6px 0 12px}
.split-fg p.lede{color:var(--ink-2);font-size:15.5px;line-height:1.6;margin:0 0 16px}
.split-fg ul.checks{list-style:none;padding:0;margin:0 0 20px;display:grid;gap:7px}
.split-fg ul.checks li{color:var(--ink-2);font-size:14px;display:flex;gap:10px;align-items:flex-start;line-height:1.5}
.split-fg ul.checks li::before{content:"";flex:none;width:18px;height:18px;border-radius:50%;background:var(--good-2);color:var(--good);display:inline-grid;place-items:center;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2328d17c' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");background-size:11px;background-position:center;background-repeat:no-repeat;margin-top:2px}
.split-art{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);padding:18px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.split-art::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--brand),var(--info))}
@media (max-width:880px){.split{grid-template-columns:1fr;gap:28px}.split.reverse .split-fg{order:0}}

/* ===== Mock cards (data widgets used inside .split-art) ===== */
.mock-card{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r);padding:14px;margin-bottom:12px}
.mock-card:last-child{margin-bottom:0}
.mock-card h6{margin:0 0 8px;font-size:11px;font-family:'JetBrains Mono',ui-monospace,monospace;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);display:flex;align-items:center;gap:8px}
.mock-card h6 .tag{padding:2px 6px;border-radius:3px;font-size:9.5px;background:var(--brand-2);color:var(--brand)}
.mock-card h6 .tag.good{background:var(--good-2);color:var(--good)}
.mock-card h6 .tag.violet{background:var(--violet-2);color:var(--violet)}
.mock-card h6 .tag.amber{background:var(--amber-2);color:var(--amber)}
.mock-list{display:grid;gap:8px}
.mock-row{display:grid;grid-template-columns:1fr auto;gap:10px;padding:8px 10px;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-sm);font-size:12.5px}
.mock-row .l{color:var(--ink);font-weight:600;display:flex;align-items:center;gap:8px}
.mock-row .l::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--brand)}
.mock-row.good .l::before{background:var(--good)}
.mock-row.violet .l::before{background:var(--violet)}
.mock-row.amber .l::before{background:var(--amber)}
.mock-row .r{color:var(--ink-3);font-family:'JetBrains Mono',ui-monospace,monospace;font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}

/* ===== FAQ accordion ===== */
.faq{display:grid;gap:8px;max-width:840px;margin:0 auto}
.faq details{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:0;overflow:hidden}
.faq details[open]{border-color:rgba(56,116,255,.35)}
.faq summary{cursor:pointer;list-style:none;padding:14px 18px;font-weight:600;color:var(--ink);font-size:14.5px;display:flex;justify-content:space-between;align-items:center;gap:18px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:'JetBrains Mono',ui-monospace,monospace;font-size:17px;font-weight:700;color:var(--brand);transition:transform .15s ease;flex:none}
.faq details[open] summary::after{content:"\2212"}
.faq .answer{padding:0 18px 16px;color:var(--ink-3);font-size:14px;line-height:1.65}
.faq .answer p{margin:0 0 10px}
.faq .answer p:last-child{margin:0}
.faq .answer ul{margin:0;padding-left:20px}
.faq .answer ul li{margin-bottom:4px}

/* ===== Long-form prose. Used on legal pages and articles. ===== */
.prose{max-width:780px;margin:0 auto;color:var(--ink-2);font-size:15px;line-height:1.7}
.prose h1{color:var(--ink);font-size:30px;font-weight:800;letter-spacing:-.02em;line-height:1.1;margin:0 0 6px}
.prose h2{color:var(--ink);font-size:20px;font-weight:700;letter-spacing:-.01em;margin:28px 0 10px}
.prose h3{color:var(--ink);font-size:16px;font-weight:700;margin:20px 0 6px}
.prose p{margin:0 0 12px}
.prose ul,.prose ol{margin:0 0 14px;padding-left:22px}
.prose li{margin-bottom:5px}
.prose code{font-family:'JetBrains Mono',ui-monospace,monospace;font-size:13px;background:var(--panel);padding:2px 6px;border-radius:3px;border:1px solid var(--line);color:var(--ink-2)}
.prose strong{color:var(--ink)}
.prose .meta{font-family:'JetBrains Mono',ui-monospace,monospace;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);margin-bottom:24px}
.prose .toc{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:18px 22px;margin:8px 0 32px}
.prose .toc h4{margin:0 0 8px;color:var(--ink-3);font-family:'JetBrains Mono',ui-monospace,monospace;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase}
.prose .toc ol{margin:0;padding-left:18px}
.prose .toc li{margin-bottom:4px;font-size:14.5px}

/* ===== CTA banner ===== */
.cta-banner{background:radial-gradient(900px 320px at 80% 0%,rgba(56,189,248,.18),transparent 60%),radial-gradient(900px 320px at 0% 100%,rgba(56,116,255,.22),transparent 60%),var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);padding:44px 40px;text-align:center;box-shadow:var(--shadow-lg)}
.cta-banner h2{color:var(--ink);font-size:26px;font-weight:800;letter-spacing:-.02em;margin:12px 0 8px}
.cta-banner p{color:var(--ink-3);max-width:520px;margin:0 auto 22px;font-size:14.5px}
.cta-banner .cta{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}

/* ===== Footer ===== */
.site-foot{background:var(--bg-2);padding:44px 0 28px;color:var(--ink-3);font-size:13px;border-top:1px solid var(--line)}
.site-foot .grid{display:grid;grid-template-columns:1.6fr 1.2fr 1fr;gap:32px;margin-bottom:28px}
.site-foot h4{color:var(--ink);font-family:'JetBrains Mono',ui-monospace,monospace;font-size:10.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;margin:0 0 12px}
.site-foot ul{list-style:none;padding:0;margin:0}
.site-foot li{margin-bottom:7px}
.site-foot a{color:var(--ink-3)}
.site-foot a:hover{color:var(--ink)}
.site-foot .brand{margin-bottom:12px}
.site-foot p.tagline{margin:0;line-height:1.6;max-width:340px;color:var(--ink-3)}
.site-foot .legal{border-top:1px solid var(--line);padding-top:18px;display:flex;align-items:center;gap:14px;font-family:'JetBrains Mono',ui-monospace,monospace;font-size:10.5px;color:var(--ink-4);letter-spacing:.04em;flex-wrap:wrap}
.site-foot .legal .right{margin-left:auto}
@media (max-width:760px){.site-foot .grid{grid-template-columns:1fr 1fr;gap:24px}.site-foot .legal{font-size:10px}}
@media (max-width:480px){.site-foot .grid{grid-template-columns:1fr}.site-foot .legal{flex-direction:column;align-items:flex-start;gap:6px}.site-foot .legal .right{margin-left:0}}

/* ===== Section foot CTA row ===== */
.section-foot{margin-top:24px;display:flex;gap:10px;flex-wrap:wrap;align-items:center;justify-content:flex-start}
.section-foot .btn:not(.primary){color:var(--ink-2)}
@media (max-width:480px){.section-foot{flex-direction:column;align-items:stretch}.section-foot .btn{width:100%;justify-content:center}}

/* ===== Compare table (used on platform/security and pricing-style pages). ===== */
.compare{width:100%;border-collapse:separate;border-spacing:0;background:var(--panel);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;font-size:13.5px}
.compare th,.compare td{padding:11px 16px;text-align:left;border-bottom:1px solid var(--line);vertical-align:top;line-height:1.55}
.compare thead th{background:var(--bg-2);color:var(--ink-3);font-family:'JetBrains Mono',ui-monospace,monospace;font-size:10.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase}
.compare tbody th{color:var(--ink);font-weight:700}
.compare tr:last-child th,.compare tr:last-child td{border-bottom:0}
.compare .yes{color:var(--good);font-weight:700}
.compare .no{color:var(--ink-4)}

/* ===== Tag pill list ===== */
.tags{display:flex;flex-wrap:wrap;gap:6px;margin:8px 0 0}
.tags span{display:inline-block;font-family:'JetBrains Mono',ui-monospace,monospace;font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);background:var(--panel-2);border:1px solid var(--line);padding:4px 8px;border-radius:3px}

/* ===== Form ===== */
.form-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:22px;box-shadow:var(--shadow)}
.form-row{display:grid;gap:12px;margin-bottom:12px}
.form-row.two{grid-template-columns:1fr 1fr}
@media (max-width:600px){.form-row.two{grid-template-columns:1fr}}
.form-row label{display:flex;flex-direction:column;gap:6px;color:var(--ink-2);font-size:13px;font-weight:600}
.form-row label .sub{color:var(--ink-3);font-weight:500;font-size:12px}
.form-row input[type="text"],.form-row input[type="email"],.form-row input[type="tel"],.form-row select,.form-row textarea{width:100%;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-sm);padding:11px 14px;color:var(--ink);font-family:inherit;font-size:14px;line-height:1.5;transition:border-color .15s ease,box-shadow .15s ease}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-2)}
.form-row textarea{resize:vertical;min-height:120px}
.form-row .err{color:#ef4444;font-size:12px;font-weight:500;display:none}
.form-foot{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:8px}
.form-foot .note{color:var(--ink-3);font-size:12px;line-height:1.5}

/* ===== 404 / error layout ===== */
.error-shell{display:grid;place-items:center;min-height:60vh;text-align:center;padding:48px 24px}
.error-shell .code{font-family:'JetBrains Mono',ui-monospace,monospace;font-size:64px;font-weight:800;color:var(--brand);letter-spacing:-.03em;line-height:1;margin-bottom:14px}
.error-shell h1{color:var(--ink);font-size:32px;font-weight:800;letter-spacing:-.02em;margin:0 0 12px}
.error-shell p{color:var(--ink-3);font-size:16px;max-width:520px;margin:0 auto 26px}
.error-shell .cta{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}

/* ===== Print ===== */
@media print{
  .site-nav,.site-foot,.cta-banner,.theme-toggle,.skip-link{display:none}
  body{background:#fff;color:#000}
  a{color:#000;text-decoration:underline}
}


/* ============================================================
   Visual upgrades: marquee, lifecycle ribbon, stat counters,
   before/after, scroll reveals, section seams, day timeline.
   ============================================================ */

/* ===== Section seams ===== */
section{position:relative}
section::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:1px;background:linear-gradient(90deg,transparent 0%,var(--brand-2) 30%,var(--info-2) 70%,transparent 100%);opacity:.6;pointer-events:none}
.site-foot::before{content:"";position:absolute;left:0;right:0;top:0;height:1px;background:linear-gradient(90deg,transparent 0%,var(--brand-2) 30%,var(--info-2) 70%,transparent 100%);opacity:.6}
.site-foot{position:relative}

/* ===== Hero preview pulse ===== */
.preview-stats .s::after{content:"";position:absolute;top:6px;right:8px;width:6px;height:6px;border-radius:50%;background:var(--brand);box-shadow:0 0 0 0 var(--brand-2);animation:pulse 2.4s ease-out infinite}
.preview-stats .s.good::after{background:var(--good);box-shadow:0 0 0 0 var(--good-2);animation-delay:.6s}
.preview-stats .s.violet::after{background:var(--info);box-shadow:0 0 0 0 var(--info-2);animation-delay:1.2s}
@keyframes pulse{0%{box-shadow:0 0 0 0 currentColor;opacity:1}70%{box-shadow:0 0 0 8px transparent;opacity:.4}100%{box-shadow:0 0 0 0 transparent;opacity:1}}
@media (prefers-reduced-motion:reduce){.preview-stats .s::after{animation:none}}

/* Hero preview rows: simulate a state change on the first row. */
.preview-rows .row.good .v::before{content:"";display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--good);margin-right:5px;animation:blink 2s ease-out;animation-iteration-count:3;vertical-align:middle}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
@media (prefers-reduced-motion:reduce){.preview-rows .row.good .v::before{animation:none}}

/* ===== Integrations strip (under hero) ===== */
.integ-strip{padding:24px 0;border-bottom:1px solid var(--line);background:var(--bg-2);position:relative;overflow:hidden}
.integ-strip .row{display:flex;align-items:center;gap:36px;flex-wrap:wrap;justify-content:center}
.integ-strip .label{color:var(--ink-3);font-family:'JetBrains Mono',ui-monospace,monospace;font-size:10.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;display:inline-flex;align-items:center;gap:8px;flex:none}
.integ-strip .label::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--good);box-shadow:0 0 0 2px var(--good-2)}
.integ-strip .logos{display:flex;align-items:center;gap:32px;flex-wrap:wrap;justify-content:center;color:var(--ink-2);font-weight:700;font-size:14.5px;letter-spacing:-.01em}
.integ-strip .logos span{display:inline-flex;align-items:center;gap:8px;color:var(--ink-2);transition:color .15s ease}
.integ-strip .logos span:hover{color:var(--ink)}
.integ-strip .logos .dot{width:4px;height:4px;border-radius:50%;background:var(--ink-4)}
@media (max-width:760px){.integ-strip .row{gap:18px}.integ-strip .logos{gap:18px;font-size:13.5px}.integ-strip .logos .dot{display:none}}

/* ===== Lifecycle ribbon ===== */
.lifecycle{position:relative;padding:8px 0 4px}
.lifecycle .ribbon{display:grid;grid-template-columns:repeat(6,1fr);gap:0;position:relative;z-index:1}
.lifecycle .node{position:relative;background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:18px 14px 16px;transition:transform .15s ease,border-color .15s ease}
.lifecycle .node:hover{transform:translateY(-2px);border-color:rgba(56,116,255,.4)}
.lifecycle .node + .node{margin-left:-1px}
.lifecycle .node:first-child{border-top-right-radius:0;border-bottom-right-radius:0}
.lifecycle .node:last-child{border-top-left-radius:0;border-bottom-left-radius:0}
.lifecycle .node:not(:first-child):not(:last-child){border-radius:0}
.lifecycle .node::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--brand);opacity:.2;transition:opacity .25s ease,background .25s ease}
.lifecycle .node[data-stage="01"]::before{background:var(--brand)}
.lifecycle .node[data-stage="02"]::before{background:var(--info)}
.lifecycle .node[data-stage="03"]::before{background:var(--info)}
.lifecycle .node[data-stage="04"]::before{background:var(--good)}
.lifecycle .node[data-stage="05"]::before{background:var(--good)}
.lifecycle .node[data-stage="06"]::before{background:var(--amber)}
.lifecycle .node.lit::before{opacity:1}
.lifecycle .node .stage{font-family:'JetBrains Mono',ui-monospace,monospace;font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);margin-bottom:8px}
.lifecycle .node h4{margin:0 0 4px;color:var(--ink);font-size:14.5px;font-weight:700;letter-spacing:-.01em}
.lifecycle .node p{margin:0;color:var(--ink-3);font-size:12.5px;line-height:1.5}
.lifecycle .node .pill{display:inline-flex;align-items:center;gap:5px;margin-top:10px;padding:2px 7px;background:var(--brand-2);color:var(--brand);border-radius:3px;font-family:'JetBrains Mono',ui-monospace,monospace;font-size:9.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.lifecycle .node[data-stage="04"] .pill,
.lifecycle .node[data-stage="05"] .pill{background:var(--good-2);color:var(--good)}
.lifecycle .node[data-stage="06"] .pill{background:var(--amber-2);color:var(--amber)}
@media (max-width:1024px){.lifecycle .ribbon{grid-template-columns:repeat(3,1fr)}.lifecycle .node{margin-left:0!important;border-radius:var(--r)!important;border:1px solid var(--line)!important}}
@media (max-width:560px){.lifecycle .ribbon{grid-template-columns:repeat(2,1fr);gap:8px}}

/* ===== Stat counter row ===== */
.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);padding:32px 28px;position:relative;overflow:hidden;text-align:left}
.stat::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--brand),var(--info));opacity:.85}
.stat:nth-child(2)::before{background:linear-gradient(90deg,var(--good),var(--info))}
.stat:nth-child(3)::before{background:linear-gradient(90deg,var(--amber),var(--brand))}
.stat .v{font-family:'JetBrains Mono',ui-monospace,monospace;color:var(--ink);font-size:56px;font-weight:800;letter-spacing:-.04em;line-height:1;margin-bottom:8px;display:flex;align-items:baseline;gap:6px}
.stat .v small{font-size:18px;color:var(--ink-3);font-weight:700;letter-spacing:0;margin-left:4px}
.stat .l{color:var(--ink-2);font-size:14px;font-weight:600;line-height:1.4;margin-bottom:4px}
.stat .l b{color:var(--ink);font-weight:700}
.stat .sub{color:var(--ink-3);font-family:'JetBrains Mono',ui-monospace,monospace;font-size:10.5px;letter-spacing:.06em;text-transform:uppercase}
@media (max-width:760px){.stat-row{grid-template-columns:1fr}.stat{padding:24px 22px}.stat .v{font-size:44px}}

/* ===== Before / After comparison ===== */
.compare-row{display:grid;grid-template-columns:1fr auto 1fr;gap:24px;align-items:stretch}
.compare-col{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:22px;position:relative;overflow:hidden}
.compare-col.before{background:repeating-linear-gradient(135deg,var(--panel) 0 12px,var(--panel-2) 12px 13px)}
.compare-col.before .head{color:var(--ink-3)}
.compare-col.after{box-shadow:var(--shadow);border-color:rgba(56,116,255,.4)}
.compare-col.after::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--brand),var(--info));opacity:.95}
.compare-col .head{display:flex;align-items:center;justify-content:space-between;font-family:'JetBrains Mono',ui-monospace,monospace;font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;margin-bottom:16px}
.compare-col .head .tag{padding:3px 8px;border-radius:3px;background:var(--panel-2);color:var(--ink-3);border:1px solid var(--line)}
.compare-col.after .head .tag{background:var(--brand-2);color:var(--brand);border-color:rgba(56,116,255,.35)}
.compare-list{display:grid;gap:10px}
.compare-list li{list-style:none;display:flex;align-items:center;gap:10px;color:var(--ink-2);font-size:13.5px;padding:10px 12px;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-sm)}
.compare-list li .icon{flex:none;width:22px;height:22px;border-radius:4px;display:grid;place-items:center;font-family:'JetBrains Mono',ui-monospace,monospace;font-size:9.5px;font-weight:800;letter-spacing:.04em;background:var(--panel-2);color:var(--ink-3);border:1px solid var(--line)}
.compare-col.after .compare-list li .icon{background:var(--brand-2);color:var(--brand);border-color:rgba(56,116,255,.35)}
.compare-col.before .compare-list li{text-decoration:line-through;color:var(--ink-3);text-decoration-color:rgba(255,80,80,.35);text-decoration-thickness:1.5px}
.compare-arrow{display:flex;align-items:center;justify-content:center;color:var(--ink-3);font-size:32px;font-weight:300;line-height:1;flex:none;align-self:center}
.compare-arrow svg{width:24px;height:24px;color:var(--brand)}
@media (max-width:760px){.compare-row{grid-template-columns:1fr;gap:14px}.compare-arrow{transform:rotate(90deg)}}

/* ===== A day timeline (used on /how-it-works) ===== */
.day{position:relative;padding:14px 0}
.day::before{content:"";position:absolute;left:50%;top:0;bottom:0;width:2px;transform:translateX(-50%);background:linear-gradient(180deg,var(--brand) 0%,var(--info) 50%,var(--good) 100%);opacity:.7}
.day .moment{position:relative;display:grid;grid-template-columns:1fr auto 1fr;gap:24px;margin-bottom:24px;align-items:center}
.day .moment:last-child{margin-bottom:0}
.day .moment .clock{background:var(--panel);border:1px solid var(--line);border-radius:50%;width:62px;height:62px;display:grid;place-items:center;font-family:'JetBrains Mono',ui-monospace,monospace;font-size:13px;font-weight:800;color:var(--ink);box-shadow:var(--shadow);justify-self:center;z-index:1}
.day .moment .card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:16px 18px;position:relative}
.day .moment .card::before{content:"";position:absolute;top:0;left:0;height:100%;width:2px;background:var(--brand);border-radius:var(--r) 0 0 var(--r)}
.day .moment.good .card::before{background:var(--good)}
.day .moment.violet .card::before{background:var(--info)}
.day .moment.amber .card::before{background:var(--amber)}
.day .moment.left .card{grid-column:1}
.day .moment.right .card{grid-column:3}
.day .moment.left > :nth-child(3){visibility:hidden}
.day .moment.right > :nth-child(1){visibility:hidden}
.day .moment .card .who{font-family:'JetBrains Mono',ui-monospace,monospace;font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);margin-bottom:6px}
.day .moment .card h4{margin:0 0 6px;font-size:15px;font-weight:700;color:var(--ink);letter-spacing:-.01em}
.day .moment .card p{margin:0;font-size:13.5px;color:var(--ink-3);line-height:1.55}
@media (max-width:760px){.day::before{left:30px}.day .moment{grid-template-columns:60px 1fr;gap:16px}.day .moment .clock{justify-self:start;width:54px;height:54px;font-size:12px}.day .moment .card{grid-column:2!important}.day .moment.left > :nth-child(3),.day .moment.right > :nth-child(1){display:none}}

/* ===== Reveal-on-scroll ===== */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .55s ease-out,transform .55s ease-out;will-change:opacity,transform}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1!important;transform:none!important;transition:none!important}}

/* Stagger children of revealed grids. */
.reveal.stagger.in > *{animation:rise .5s ease-out both}
.reveal.stagger.in > *:nth-child(1){animation-delay:0ms}
.reveal.stagger.in > *:nth-child(2){animation-delay:60ms}
.reveal.stagger.in > *:nth-child(3){animation-delay:120ms}
.reveal.stagger.in > *:nth-child(4){animation-delay:180ms}
.reveal.stagger.in > *:nth-child(5){animation-delay:240ms}
.reveal.stagger.in > *:nth-child(6){animation-delay:300ms}
.reveal.stagger.in > *:nth-child(7){animation-delay:360ms}
@keyframes rise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){.reveal.stagger.in > *{animation:none!important}}

/* ===== Section preheader (used above big section heads) ===== */
.preheader{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.preheader::before{content:"";flex:none;width:24px;height:1px;background:var(--brand)}


/* ===== Trust band (used between Before/After and About on home) ===== */
.trustband{padding:36px 0;border-bottom:1px solid var(--line);background:var(--bg-2)}
.trustband .row{display:grid;grid-template-columns:1.1fr 1.4fr;gap:36px;align-items:center}
.trustband .quote{position:relative;background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:22px 24px;box-shadow:var(--shadow)}
.trustband .quote::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--brand),var(--info));opacity:.85}
.trustband .quote p{margin:0;color:var(--ink);font-size:16px;font-weight:600;line-height:1.5;letter-spacing:-.005em}
.trustband .quote .eyebrow{margin-bottom:10px}
.trustband .signals{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.trustband .signal{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:16px 18px;position:relative}
.trustband .signal::before{content:"";position:absolute;top:0;left:0;bottom:0;width:2px;background:var(--brand);border-radius:var(--r) 0 0 var(--r)}
.trustband .signal.good::before{background:var(--good)}
.trustband .signal.amber::before{background:var(--amber)}
.trustband .signal h6{margin:0 0 4px;color:var(--ink);font-size:14px;font-weight:700;letter-spacing:-.005em}
.trustband .signal p{margin:0;color:var(--ink-3);font-size:13px;line-height:1.5}
@media (max-width:880px){.trustband .row{grid-template-columns:1fr;gap:22px}.trustband .signals{grid-template-columns:1fr}}
