/* ============================================================
   ORTHRUS — Aurora design system · shared stylesheet
   ============================================================ */
:root{
  --bg:#090A0F; --bg-2:#0D0E15; --bg-3:#12141D;
  --card:#13151D; --card-2:#181B25;
  --ink:#F1F0F6; --ink-2:#AEACBE; --muted:#74738A;
  --line:#1F2230; --line-2:#2B2F40;
  --acc:#7C6CFF; --acc-2:#9C8FFF; --green:#5BD6A4; --bad:#E0857B;
  --acc-soft:rgba(124,108,255,.10); --acc-glow:rgba(124,108,255,.30);
  --sh-xl:0 20px 48px -20px rgba(0,0,0,.78), 0 50px 110px -56px rgba(0,0,0,.6);
  --sh-md:0 12px 30px -16px rgba(0,0,0,.62);
  --hi:inset 0 1px 0 rgba(255,255,255,.045);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:'Mona Sans',system-ui,sans-serif;
  font-size:16px;line-height:1.55;letter-spacing:-.006em;-webkit-font-smoothing:antialiased;overflow-x:hidden}
::selection{background:var(--acc);color:#fff}
a{color:inherit;text-decoration:none}
svg{display:block}
img{max-width:100%}

/* atmosphere */
.atmos{position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(52% 38% at 50% -6%,rgba(124,108,255,.20),transparent 70%),
    radial-gradient(36% 32% at 94% 14%,rgba(86,214,230,.08),transparent 72%),
    radial-gradient(42% 38% at 3% 62%,rgba(124,108,255,.10),transparent 74%),
    radial-gradient(44% 36% at 80% 95%,rgba(124,108,255,.085),transparent 74%)}
.grain{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.032;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.shell{position:relative;z-index:2}
.wrap{max-width:1260px;margin:0 auto;padding:0 48px}
.mono{font-family:'JetBrains Mono',monospace}

/* type */
.acc{color:var(--acc-2);font-style:italic;font-weight:250}
h1,h2,h3{font-weight:400;letter-spacing:-.04em;line-height:1.05}
.lede{font-size:clamp(15px,1.15vw,17px);color:var(--ink-2);font-weight:300;line-height:1.62}

/* buttons — squared */
.btn{display:inline-flex;align-items:center;justify-content:center;font-family:'Mona Sans',sans-serif;
  font-weight:500;font-size:14.5px;padding:14px 26px;cursor:pointer;border:1px solid transparent;
  transition:.18s ease;letter-spacing:-.005em}
.btn--primary{background:linear-gradient(180deg,var(--acc-2),var(--acc));color:#0B0B14;
  box-shadow:0 10px 26px -12px var(--acc-glow),var(--hi)}
.btn--primary:hover{box-shadow:0 0 34px -4px var(--acc-glow),0 10px 26px -10px var(--acc-glow),var(--hi)}
.btn--ghost{background:rgba(255,255,255,.015);color:var(--ink);border-color:var(--line-2)}
.btn--ghost:hover{background:var(--bg-3);border-color:var(--ink-2)}
.btn--full{width:100%;padding:15px 26px}

/* haatch lockup — squared */
.haatch-lockup{display:inline-flex;align-items:center;gap:13px;padding:9px 16px;
  border:1px solid var(--line-2);background:rgba(19,21,29,.6)}
.haatch-lockup .bk{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--muted);font-weight:500}
.haatch-lockup .sep{width:1px;height:13px;background:var(--line-2)}
.haatch-lockup .hl{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:14px;color:var(--ink)}
.haatch-lockup a.hl{transition:color .16s}
.haatch-lockup a.hl:hover{color:var(--acc-2)}
.haatch-mark{width:15px;height:15px;color:var(--acc-2);flex-shrink:0}

/* nav */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;background:rgba(9,10,15,.74);
  backdrop-filter:blur(18px) saturate(170%);-webkit-backdrop-filter:blur(18px) saturate(170%);
  border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;justify-content:space-between;padding-top:15px;padding-bottom:15px}
.logo{font-weight:400;font-size:21px;letter-spacing:-.02em;color:var(--ink)}
.nav-r{display:flex;align-items:center;gap:30px}
.nav-links{display:flex;gap:26px}
.nav-links a{font-size:14px;color:var(--ink-2);transition:color .2s;padding-bottom:2px}
.nav-links a:hover{color:var(--ink)}
.nav-links a.active{color:var(--ink);border-bottom:1px solid var(--acc)}
.nav .btn{padding:11px 20px;font-size:14px}
.nav-cta{display:none}
.nav-toggle{display:none;width:40px;height:40px;align-items:center;justify-content:center;
  background:transparent;border:1px solid var(--line-2);cursor:pointer;flex-shrink:0}
.nav-toggle i{position:relative;width:16px;height:1.6px;background:var(--ink);transition:.2s}
.nav-toggle i::before,.nav-toggle i::after{content:"";position:absolute;left:0;width:16px;height:1.6px;
  background:var(--ink);transition:.2s}
.nav-toggle i::before{top:-5px}.nav-toggle i::after{top:5px}
.nav.open .nav-toggle i{background:transparent}
.nav.open .nav-toggle i::before{top:0;transform:rotate(45deg)}
.nav.open .nav-toggle i::after{top:0;transform:rotate(-45deg)}

/* back-to-top (mobile + tablet) */
.to-top{position:fixed;right:18px;bottom:18px;z-index:60;width:46px;height:46px;
  display:none;align-items:center;justify-content:center;
  background:rgba(13,14,21,.88);border:1px solid var(--line-2);color:var(--acc-2);
  backdrop-filter:blur(12px);box-shadow:var(--sh-md);cursor:pointer;
  opacity:0;transform:translateY(10px);transition:opacity .25s ease,transform .25s ease}
.to-top svg{width:18px;height:18px}
.to-top.show{opacity:1;transform:translateY(0)}

/* section + diptych */
.sec{position:relative;padding:118px 0;scroll-margin-top:72px}
.sec.hero{padding-top:150px}
.sec+.sec{border-top:1px solid var(--line)}
.diptych{display:grid;grid-template-columns:1fr 1px 1.05fr;gap:62px;align-items:start}
.diptych.center{align-items:center}
.dvline{align-self:stretch;background:linear-gradient(180deg,transparent,var(--line-2) 8%,var(--line-2) 92%,transparent)}
.dp-l,.dp-r{min-width:0}
.sec:not(.hero) .dp-l.sticky{position:sticky;top:104px;align-self:start}
.dp-l h2{font-size:clamp(29px,3vw,44px);margin-bottom:18px}
.dp-l .lede{max-width:42ch}
.dp-l .dp-cta{margin-top:26px}

/* home hero */
.hero-h1{font-size:clamp(42px,4.5vw,66px);letter-spacing:-.045em;line-height:1.04;margin-bottom:22px}
.hero .lede{margin-bottom:30px;max-width:44ch}
.hero-cta{display:flex;align-items:center;gap:16px 20px;flex-wrap:wrap;margin-bottom:0}

/* inner page hero */
.page-hero h1{font-size:clamp(38px,4.2vw,60px);letter-spacing:-.045em;line-height:1.05;margin-bottom:20px}
.page-hero .lede{margin-bottom:28px;max-width:46ch}

/* snapshot facts card */
.snapshot{background:linear-gradient(168deg,var(--card-2),var(--card));border:1px solid var(--line-2);
  box-shadow:var(--sh-xl),var(--hi)}
.snap-hd{display:flex;align-items:center;justify-content:space-between;padding:15px 24px;
  border-bottom:1px solid var(--line);background:rgba(0,0,0,.22)}
.snap-hd .ttl{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--ink)}
.snap-row{display:flex;align-items:baseline;gap:16px;padding:19px 24px;border-bottom:1px solid var(--line)}
.snap-row:last-child{border-bottom:0}
.snap-v{font-weight:300;font-size:27px;letter-spacing:-.04em;color:#fff;flex-shrink:0;min-width:118px}
.snap-l{font-size:13px;color:var(--ink-2);font-weight:300;line-height:1.5}

/* tag */
.tag{display:inline-flex;align-items:center;gap:7px;font-family:'JetBrains Mono',monospace;
  font-size:10px;letter-spacing:.08em;font-weight:500;padding:5px 9px;text-transform:uppercase;
  background:var(--acc-soft);color:var(--acc-2);border:1px solid var(--line-2)}
.tag::before{content:"";width:5px;height:5px;background:var(--acc);box-shadow:0 0 7px var(--acc)}

/* calculator — squared */
.calc{background:linear-gradient(168deg,var(--card-2),var(--card));border:1px solid var(--line-2);
  box-shadow:var(--sh-xl),var(--hi)}
.calc-hd{display:flex;align-items:center;justify-content:space-between;padding:15px 24px;
  border-bottom:1px solid var(--line);background:rgba(0,0,0,.22)}
.calc-hd .ttl{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--ink)}
.calc-bd{padding:26px 24px 24px}
.ctl-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:13px}
.ctl-l{font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--muted)}
.ctl-v{font-weight:300;font-size:31px;letter-spacing:-.04em}
.slider{-webkit-appearance:none;appearance:none;width:100%;height:30px;background:transparent;
  outline:none;cursor:pointer;touch-action:none}
.slider::-webkit-slider-runnable-track{height:5px;
  background:linear-gradient(90deg,var(--acc) var(--p,25%),var(--bg-3) var(--p,25%))}
.slider::-moz-range-track{height:5px;background:var(--bg-3)}
.slider::-moz-range-progress{height:5px;background:var(--acc)}
.slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;margin-top:-6.5px;
  background:#fff;border:0;cursor:pointer;box-shadow:0 0 0 4px rgba(124,108,255,.22),0 0 14px var(--acc-glow)}
.slider::-moz-range-thumb{width:17px;height:17px;background:#fff;border:0;cursor:pointer;
  box-shadow:0 0 0 4px rgba(124,108,255,.22),0 0 14px var(--acc-glow)}
.ends{display:flex;justify-content:space-between;font-family:'JetBrains Mono',monospace;
  font-size:10px;color:var(--muted);margin:10px 0 24px}
.seg-l{font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--muted);margin-bottom:11px}
.seg{display:grid;grid-template-columns:1fr 1fr 1fr;background:var(--bg-2);
  border:1px solid var(--line);margin-bottom:24px}
.seg button{padding:12px 6px;border:0;background:transparent;font-family:'Mona Sans',sans-serif;
  font-weight:500;font-size:13.5px;color:var(--ink-2);cursor:pointer;transition:.16s;
  border-right:1px solid var(--line)}
.seg button:last-child{border-right:0}
.seg button:hover{color:var(--ink)}
.seg button.on{background:rgba(124,108,255,.08);color:var(--ink);
  box-shadow:inset 0 0 0 1px var(--acc),var(--hi)}
.result{border-top:1px solid var(--line);padding-top:22px}
.r-main{border:1px solid var(--line-2);border-left:2px solid var(--acc);padding:18px 20px;
  background:linear-gradient(150deg,rgba(124,108,255,.14),rgba(124,108,255,.03));margin-bottom:11px}
.r-label{font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--acc-2);font-weight:500;margin-bottom:6px}
.r-big{font-weight:300;font-size:48px;letter-spacing:-.045em;line-height:1;color:#fff;
  text-shadow:0 0 26px var(--acc-glow)}
.r-sub{font-size:12.5px;color:var(--ink-2);margin-top:8px}
.r-sub b{color:var(--ink);font-weight:500}
.timing{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}
.t-cell{border:1px solid var(--line);padding:14px 15px;background:var(--bg-2)}
.t-amt{font-weight:400;font-size:22px;letter-spacing:-.03em;margin-bottom:4px}
.t-when{font-size:12px;color:var(--ink);font-weight:500}
.t-tag{font-family:'JetBrains Mono',monospace;font-size:9.5px;letter-spacing:.07em;
  text-transform:uppercase;color:var(--muted);margin-top:3px}
.calc-foot{font-size:11.5px;color:var(--muted);text-align:left;margin:13px 0 16px;line-height:1.5}

/* steps — squared cards */
.steps{display:flex;flex-direction:column}
.step{display:flex;gap:20px;align-items:flex-start;padding:22px 24px;
  background:linear-gradient(165deg,var(--card-2),var(--card));border:1px solid var(--line);
  box-shadow:var(--sh-md),var(--hi);transition:.18s}
.step+.step{margin-top:-1px}
.step:hover{border-color:var(--line-2);background:linear-gradient(165deg,#1c2030,var(--card-2))}
.step-n{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:34px;height:34px;
  border:1px solid var(--line-2);background:var(--bg-2);font-family:'JetBrains Mono',monospace;
  font-weight:500;font-size:12.5px;color:var(--acc-2)}
.step h3{font-size:17px;letter-spacing:-.025em;margin-bottom:6px}
.step p{font-size:13.5px;color:var(--ink-2);font-weight:300}
.step .step-tag{display:inline-block;margin-top:9px;font-family:'JetBrains Mono',monospace;
  font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}

/* contrast — With Orthrus made distinct */
.cmp-set{display:flex;flex-direction:column;gap:14px}
.cmp{position:relative;border:1px solid var(--line);padding:26px 28px;
  background:linear-gradient(165deg,var(--card-2),var(--card))}
.cmp-l{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.15em;
  text-transform:uppercase;color:var(--muted);margin-bottom:9px}
.cmp-n{font-weight:250;font-size:clamp(34px,3.6vw,46px);letter-spacing:-.045em;line-height:1;
  color:var(--ink-2);margin-bottom:9px}
.cmp p{font-size:13px;color:var(--ink-2);font-weight:300}
.cmp.good{border:1px solid var(--acc);border-top-width:2px;
  background:linear-gradient(150deg,rgba(124,108,255,.16),rgba(124,108,255,.045));overflow:hidden}
.cmp.good::before{content:"";position:absolute;width:280px;height:280px;right:-130px;top:-130px;
  background:radial-gradient(circle,var(--acc-glow),transparent 62%)}
.cmp.good>*{position:relative}
.cmp.good .cmp-l{color:var(--acc-2)}
.cmp.good .cmp-n{color:#fff;text-shadow:0 0 30px var(--acc-glow)}
.cmp.good p{color:var(--ink)}

/* who — squared cards */
.who{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--line)}
.who.one{grid-template-columns:1fr}
.who-c{position:relative;padding:24px 24px;background:linear-gradient(165deg,var(--card-2),var(--card));
  border-right:1px solid var(--line);border-bottom:1px solid var(--line);transition:.18s}
.who-c:nth-child(2n){border-right:0}
.who-c:nth-last-child(-n+2){border-bottom:0}
.who.one .who-c{border-right:0}
.who.one .who-c:last-child{border-bottom:0}
.who-c:hover{background:linear-gradient(165deg,#1c2030,var(--card-2))}
.who-c .t{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.07em;
  color:var(--acc-2);display:block;margin-bottom:11px}
.who-c h3{font-size:16.5px;letter-spacing:-.025em;margin-bottom:8px}
.who-c p{font-size:12.5px;color:var(--ink-2);font-weight:300}
.who-c .who-tag{display:block;margin-top:11px;font-family:'JetBrains Mono',monospace;
  font-size:10px;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);line-height:1.6}

/* doors — home routing cards */
.doors{display:flex;flex-direction:column;gap:14px}
.door{display:block;position:relative;padding:26px 28px;border:1px solid var(--line);
  background:linear-gradient(165deg,var(--card-2),var(--card));transition:.18s}
.door:hover{border-color:var(--acc);background:linear-gradient(165deg,#1c2030,var(--card-2))}
.door-l{font-family:'JetBrains Mono',monospace;font-size:21px;font-weight:500;letter-spacing:.03em;
  text-transform:uppercase;color:var(--acc-2);margin-bottom:7px;line-height:1.12}
.door h3{font-size:14px;font-weight:400;letter-spacing:-.01em;margin-bottom:13px;color:var(--ink-2)}
.door p{font-size:13.5px;color:var(--ink-2);font-weight:300;margin-bottom:12px}
.door-who{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.05em;
  text-transform:uppercase;color:var(--muted);line-height:1.6}
.door-go{position:absolute;top:26px;right:28px;color:var(--acc-2);font-size:18px;transition:.18s}
.door:hover .door-go{transform:translateX(3px)}

/* checklist — eligibility */
.checklist{display:flex;flex-direction:column;border:1px solid var(--line)}
.check-item{display:flex;gap:15px;align-items:flex-start;padding:18px 22px;
  border-bottom:1px solid var(--line);background:linear-gradient(165deg,var(--card-2),var(--card))}
.check-item:last-child{border-bottom:0}
.check-mk{flex-shrink:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;
  border:1px solid var(--line-2);margin-top:1px}
.check-mk svg{width:11px;height:11px}
.check-item.yes .check-mk{border-color:var(--acc);color:var(--acc-2)}
.check-item.no .check-mk{color:var(--muted)}
.check-tx{font-size:13.5px;color:var(--ink);font-weight:300}
.check-tx b{font-weight:500;color:var(--ink)}
.check-item.no .check-tx{color:var(--ink-2)}

/* matrix — full rate grid */
.matrix{border:1px solid var(--line-2);overflow:hidden}
.mx-row{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;border-bottom:1px solid var(--line)}
.mx-row:last-child{border-bottom:0}
.mx-row.head{background:rgba(0,0,0,.22)}
.mx-cell{padding:17px 18px;border-right:1px solid var(--line)}
.mx-cell:last-child{border-right:0}
.mx-row.head .mx-cell{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--muted)}
.mx-tier{font-weight:300;font-size:15px;color:var(--ink);letter-spacing:-.02em}
.mx-rate{font-weight:300;font-size:20px;letter-spacing:-.03em;color:var(--ink)}
.mx-rate.lead{color:var(--acc-2)}

/* pricing — ruled rate list */
.rate-list{border-top:1px solid var(--line-2)}
.rate-row{display:grid;grid-template-columns:34px 1fr auto;gap:14px;align-items:baseline;
  padding:24px 4px;border-bottom:1px solid var(--line-2);transition:.16s}
.rate-row:hover{background:linear-gradient(90deg,var(--acc-soft),transparent);padding-left:14px}
.rate-ix{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--muted);letter-spacing:.12em}
.rate-range{font-weight:300;font-size:clamp(19px,1.7vw,24px);letter-spacing:-.025em;color:var(--ink)}
.rate-pct{font-style:italic;font-weight:300;font-size:clamp(20px,1.8vw,26px);letter-spacing:-.02em;
  color:var(--acc-2)}
.rate-foot{display:flex;align-items:flex-start;gap:14px;margin-top:20px}
.rate-foot .rl{width:26px;height:1px;background:var(--acc);flex-shrink:0;margin-top:8px}
.rate-foot .tx{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.04em;
  color:var(--muted);line-height:1.7}
.rate-foot .tx a{color:var(--acc-2);border-bottom:1px solid var(--line-2);padding-bottom:1px}
.rate-foot .tx a:hover{border-color:var(--acc)}

/* faq — accordion */
.faq{border-top:1px solid var(--line-2)}
.qa{border-bottom:1px solid var(--line-2)}
.qa summary{list-style:none;cursor:pointer;display:grid;grid-template-columns:32px 1fr 18px;
  gap:16px;align-items:center;padding:21px 4px;transition:.16s}
.qa summary::-webkit-details-marker{display:none}
.qa summary:hover{padding-left:10px}
.qn{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--muted);letter-spacing:.1em;transition:.16s}
.qq{font-size:16.5px;color:var(--ink);font-weight:400;letter-spacing:-.022em}
.qa-mk{position:relative;width:14px;height:14px;justify-self:end}
.qa-mk::before,.qa-mk::after{content:"";position:absolute;background:var(--acc-2);transition:.22s ease}
.qa-mk::before{left:0;right:0;top:6.25px;height:1.5px}
.qa-mk::after{top:0;bottom:0;left:6.25px;width:1.5px}
.qa[open] .qa-mk::after{transform:scaleY(0)}
.qa[open] .qn{color:var(--acc-2)}
.qa[open] summary{padding-bottom:4px}
.qa-body{padding:0 18px 24px 48px}
.qa-body p{font-size:13.5px;color:var(--ink-2);font-weight:300;line-height:1.62}

/* prose — about */
.prose p{font-size:15.5px;color:var(--ink-2);font-weight:300;line-height:1.7;margin-bottom:16px;max-width:62ch}
.prose p:last-child{margin-bottom:0}
.prose p b,.prose p strong{color:var(--ink);font-weight:500}
.prose .acc{font-weight:250}

/* legal pages */
.legal{max-width:800px}
.legal .updated{font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.legal-sec{padding:30px 0;border-top:1px solid var(--line)}
.legal-sec h2{font-size:21px;letter-spacing:-.03em;margin-bottom:14px;font-weight:400}
.legal-sec h2 .ln{font-family:'JetBrains Mono',monospace;font-size:13px;color:var(--acc-2);
  margin-right:11px}
.legal-sec h3{font-size:15px;color:var(--ink);font-weight:500;margin:18px 0 7px;letter-spacing:-.01em}
.legal-sec p{font-size:14.5px;color:var(--ink-2);font-weight:300;line-height:1.72;margin-bottom:12px}
.legal-sec p:last-child{margin-bottom:0}
.legal-sec p b{color:var(--ink);font-weight:500}
.legal-sec ul{list-style:none;margin:8px 0 14px}
.legal-sec li{position:relative;padding-left:20px;font-size:14.5px;color:var(--ink-2);
  font-weight:300;line-height:1.7;margin-bottom:7px}
.legal-sec li:last-child{margin-bottom:0}
.legal-sec li::before{content:"";position:absolute;left:2px;top:10px;width:7px;height:1px;
  background:var(--acc)}
.legal-sec a{color:var(--acc-2);border-bottom:1px solid var(--line-2)}
.legal-sec a:hover{border-color:var(--acc)}

/* worked example — money breakdown panel */
.worked{border:1px solid var(--line-2);background:linear-gradient(168deg,var(--card-2),var(--card));
  box-shadow:var(--sh-xl),var(--hi)}
.worked-hd{display:flex;align-items:center;justify-content:space-between;padding:15px 22px;
  border-bottom:1px solid var(--line);background:rgba(0,0,0,.22)}
.worked-hd .ttl{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--ink)}
.worked-r{display:flex;justify-content:space-between;align-items:baseline;gap:18px;
  padding:15px 22px;border-bottom:1px solid var(--line)}
.worked-r .wl{font-size:13.5px;color:var(--ink-2);font-weight:300;line-height:1.5}
.worked-r .wl .wsub{display:block;color:var(--muted);font-size:11.5px;margin-top:2px}
.worked-r .wv{font-family:'JetBrains Mono',monospace;font-size:15px;color:var(--ink);white-space:nowrap}
.worked-r.lead .wv{color:#fff;font-size:16px}
.worked-r.out{background:linear-gradient(150deg,rgba(124,108,255,.16),rgba(124,108,255,.045));
  border-bottom:0;border-top:1px solid var(--line-2);padding:17px 22px}
.worked-r.out .wl{color:var(--ink);font-weight:400}
.worked-r.out .wv{color:#fff;font-size:20px;text-shadow:0 0 22px var(--acc-glow)}
.worked-note{font-size:11.5px;color:var(--muted);font-weight:300;line-height:1.6;
  padding:14px 22px;border-top:1px solid var(--line)}

/* hero visual — cash-flow ledger (for-businesses) */
.ledger{padding:26px 24px 22px}
.ledger-cap{display:flex;align-items:baseline;gap:8px;font-family:'JetBrains Mono',monospace;
  font-size:10px;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-2);margin-bottom:5px}
.ledger-cap .sub{color:var(--muted);letter-spacing:.03em}
.ledger-row{display:flex;justify-content:space-between;align-items:baseline;gap:14px;padding:10px 0}
.ledger-row .lr-l{position:relative;padding-left:16px;font-size:13.5px;color:var(--ink);font-weight:300}
.ledger-row .lr-l::before{content:"";position:absolute;left:0;top:7px;width:5px;height:5px;
  background:var(--muted)}
.ledger-row .lr-t{font-family:'JetBrains Mono',monospace;font-size:9.5px;letter-spacing:.07em;
  text-transform:uppercase;color:var(--muted);white-space:nowrap}
.ledger-row.late .lr-l{color:#fff}
.ledger-row.late .lr-l::before{background:var(--ink-2)}
.ledger-row.late .lr-t{color:var(--ink)}
.ledger-gap{display:flex;align-items:center;gap:10px;margin:14px 0 16px}
.ledger-gap::before,.ledger-gap::after{content:"";flex:1;height:1px;
  background:repeating-linear-gradient(90deg,var(--line-2) 0 4px,transparent 4px 9px)}
.ledger-gap span{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--muted)}
.ledger-foot{display:flex;align-items:center;gap:11px;padding:15px 24px;
  border-top:1px solid var(--line);background:linear-gradient(150deg,rgba(124,108,255,.13),transparent)}
.ledger-foot .lf-dot{flex-shrink:0;width:7px;height:7px;background:var(--acc);
  box-shadow:0 0 10px var(--acc)}
.ledger-foot .lf-tx{font-size:12.5px;color:var(--ink-2);font-weight:300}
.ledger-foot .lf-tx b{color:#fff;font-weight:500}

/* hero visual — invoice journey (for-individuals) */
.journey{padding:26px 24px 24px}
.jstep{display:flex;gap:15px;position:relative;padding-bottom:20px}
.jstep:last-child{padding-bottom:0}
.jstep::before{content:"";position:absolute;left:6.5px;top:15px;bottom:-9px;width:1px;
  background:var(--line-2)}
.jstep:last-child::before{display:none}
.jdot{position:relative;z-index:1;flex-shrink:0;width:14px;height:14px;margin-top:1px;
  border-radius:50%;background:var(--bg-2);border:1.5px solid var(--line-2)}
.jstep.hi .jdot{background:var(--acc);border-color:var(--acc);
  box-shadow:0 0 0 4px rgba(124,108,255,.16),0 0 14px var(--acc-glow)}
.jtx{display:flex;flex-direction:column;gap:3px}
.jt{font-size:14.5px;font-weight:400;letter-spacing:-.02em;color:var(--ink-2)}
.jstep.hi .jt{color:#fff}
.js{font-size:12.5px;font-weight:300;color:var(--muted);line-height:1.5}
.jstep.hi .js{color:var(--acc-2)}

/* fact rows — about / generic */
.facts{display:flex;flex-direction:column;border:1px solid var(--line)}
.fact{display:grid;grid-template-columns:auto 1fr;gap:20px;padding:17px 22px;
  border-bottom:1px solid var(--line);background:linear-gradient(165deg,var(--card-2),var(--card))}
.fact:last-child{border-bottom:0}
.fact dt{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--muted);padding-top:3px}
.fact dd{font-size:14px;color:var(--ink);font-weight:300}

/* form */
.form{display:flex;flex-direction:column}
.field{margin-bottom:18px}
.field label{display:block;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.field input,.field select,.field textarea{width:100%;font-family:'Mona Sans',sans-serif;
  font-size:14.5px;color:var(--ink);background:var(--bg-2);border:1px solid var(--line-2);
  padding:12px 14px;transition:.16s;letter-spacing:-.005em}
.field textarea{resize:vertical;min-height:92px;line-height:1.55}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--acc);
  box-shadow:0 0 0 3px rgba(124,108,255,.14)}
.field input::placeholder,.field textarea::placeholder{color:var(--muted)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.choice{display:grid;grid-template-columns:1fr 1fr;background:var(--bg-2);border:1px solid var(--line-2)}
.choice button{padding:13px 8px;border:0;background:transparent;font-family:'Mona Sans',sans-serif;
  font-weight:500;font-size:13.5px;color:var(--ink-2);cursor:pointer;transition:.16s;
  border-right:1px solid var(--line-2)}
.choice button:last-child{border-right:0}
.choice button:hover{color:var(--ink)}
.choice button.on{background:rgba(124,108,255,.08);color:var(--ink);
  box-shadow:inset 0 0 0 1px var(--acc),var(--hi)}
.form-note{font-size:11.5px;color:var(--muted);line-height:1.55;margin-top:14px}
.form-err{font-size:12.5px;color:var(--bad);line-height:1.5;margin-top:6px;
  border-left:2px solid var(--bad);padding-left:12px}
.field input.bad,.field select.bad,.field textarea.bad{border-color:var(--bad);
  box-shadow:0 0 0 3px rgba(224,133,123,.14)}
.field select:required:invalid{color:var(--muted)}
.form-done{display:none;border:1px solid var(--acc);border-top-width:2px;
  background:linear-gradient(150deg,rgba(124,108,255,.16),rgba(124,108,255,.045));
  padding:30px 28px;text-align:center}
.form-done h3{font-size:21px;margin-bottom:10px;letter-spacing:-.03em}
.form-done p{font-size:13.5px;color:var(--ink);font-weight:300}
.form.sent{display:none}
.form-done.show{display:block}

/* cta — divided closing block */
.cta{position:relative;border-top:1px solid var(--line);padding:130px 0;text-align:center;overflow:hidden}
.cta::before{content:"";position:absolute;left:50%;top:48%;transform:translate(-50%,-50%);
  width:900px;height:440px;background:radial-gradient(ellipse,var(--acc-glow),transparent 66%)}
.cta-in{position:relative;max-width:660px;margin:0 auto}
.cta-k{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--acc-2);font-weight:500}
.cta h2{font-size:clamp(32px,4.1vw,54px);margin:18px auto 16px;letter-spacing:-.04em}
.cta .lede{margin:0 auto 30px;font-size:17px;max-width:52ch}

/* footer */
footer{border-top:1px solid var(--line);background:var(--bg-2);padding:56px 0 30px;position:relative;z-index:2}
.foot-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:44px;
  padding-bottom:34px;border-bottom:1px solid var(--line)}
.foot-brand .logo{display:block;margin-bottom:18px}
.foot-brand .haatch-lockup{display:inline-flex;margin-bottom:16px}
.foot-brand .fb-note{font-size:12px;color:var(--muted);font-weight:300;line-height:1.6;max-width:34ch}
footer h4{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.15em;
  text-transform:uppercase;color:var(--ink);margin-bottom:15px;font-weight:500}
footer ul{list-style:none}footer li{margin-bottom:10px}
footer li a{font-size:13px;color:var(--ink-2);font-weight:300}
footer li a:hover{color:var(--acc-2)}
.foot-base{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;padding-top:24px}
.foot-base span{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--muted);letter-spacing:.05em}

/* motion */
@keyframes rise{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}
.load{opacity:0;animation:rise .9s cubic-bezier(.2,.7,.2,1) forwards}
.rv{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease}
.rv.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.load,.rv{opacity:1;transform:none;animation:none;transition:none}}

/* ============ responsive ============ */
@media(max-width:1100px){
  .wrap{padding:0 34px}
  .sec{padding:98px 0}
  .diptych{gap:46px}
}
@media(max-width:1024px){ .to-top{display:flex} }
@media(max-width:860px){
  .nav-links{position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;
    background:var(--bg-2);border-bottom:1px solid var(--line);padding:6px 0;display:none}
  .nav.open .nav-links{display:flex}
  .nav-links a{padding:13px 34px;font-size:15px;border-bottom:0}
  .nav-links a.active{border-bottom:0;color:var(--acc-2)}
  .nav-toggle{display:flex}
}
@media(max-width:900px){
  .sec{padding:74px 0}
  .sec.hero{padding-top:120px}
  .diptych{grid-template-columns:1fr;gap:34px}
  .diptych.center{align-items:start}
  .dvline{display:none}
  .sec:not(.hero) .dp-l.sticky{position:static;top:auto}
  .who{grid-template-columns:1fr}
  .who-c{border-right:0}
  .who-c:nth-last-child(2){border-bottom:1px solid var(--line)}
  .foot-grid{grid-template-columns:1fr 1fr;gap:32px 26px}
  .timing{grid-template-columns:1fr}
  .cta{padding:88px 0}
}
/* rate matrix → stacked cards on tablet + mobile (each tier reads as one card) */
@media(max-width:860px){
  .matrix{border:0;overflow:visible}
  .mx-row{display:block;border:1px solid var(--line-2);margin-bottom:14px}
  .mx-row:last-child{margin-bottom:0}
  .mx-row.head{display:none}
  .mx-cell{border-right:0;padding:0}
  .mx-cell:first-child{background:var(--card-2);border-bottom:1px solid var(--line-2);
    padding:14px 18px}
  .mx-cell:first-child[data-l]::before{content:attr(data-l);display:block;
    font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.14em;
    text-transform:uppercase;color:var(--muted);margin-bottom:5px}
  .mx-cell:first-child .mx-tier{font-size:18px;color:#fff}
  .mx-cell:not(:first-child){display:flex;align-items:baseline;justify-content:space-between;
    gap:14px;padding:13px 18px;border-bottom:1px solid var(--line)}
  .mx-cell:last-child{border-bottom:0}
  .mx-cell:not(:first-child)[data-l]::before{content:attr(data-l);
    font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.1em;
    text-transform:uppercase;color:var(--ink-2)}
  .mx-rate{font-size:17px}
}
@media(max-width:600px){
  .wrap{padding:0 26px}
  .sec{padding:58px 0}
  .sec.hero{padding-top:108px}
  .nav-in{padding-top:13px;padding-bottom:13px}
  .nav-links a{padding:13px 26px}
  .step{padding:20px 20px}
  .cmp{padding:22px 22px}
  .rate-row{grid-template-columns:26px 1fr auto;gap:10px}
  .qa summary{grid-template-columns:30px 1fr 16px;gap:12px}
  .qa-body{padding:0 4px 22px 4px}
  .field-row{grid-template-columns:1fr}
  .snap-row{flex-wrap:wrap;gap:4px;padding-left:18px;padding-right:18px}
  .snap-v{min-width:0}
  .cta{padding:70px 0}
  .to-top{right:14px;bottom:14px}
  /* calculator — compact, and a bigger touch target for the slider */
  .calc-hd{padding:13px 16px}
  .calc-bd{padding:18px 16px}
  .ctl-top{margin-bottom:9px}
  .ctl-v{font-size:25px}
  .slider{height:46px}
  .slider::-webkit-slider-thumb{width:28px;height:28px;margin-top:-11.5px}
  .slider::-moz-range-thumb{width:26px;height:26px}
  .ends{margin:6px 0 13px}
  .seg-l{margin-bottom:8px}
  .seg{margin-bottom:14px}
  .seg button{padding:11px 4px}
  .result{padding-top:14px}
  .r-main{padding:14px 15px}
  .r-big{font-size:36px}
  .r-sub{margin-top:6px}
  .timing{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:11px}
  .t-cell{padding:11px 12px}
  .t-amt{font-size:18px}
  .calc-foot{margin:9px 0 12px}
}
@media(max-width:380px){ .foot-grid{grid-template-columns:1fr} }
