:root{
  --blue:#1D80D6;
  --blue-deep:#0D4F8B;
  --orange:#F5A200;
  --navy:#0D1E33;
  --white:#FFFFFF;
  --surface:#F4F8FD;
  --muted:#7AAFD4;
  --line: rgba(13,30,51,.08);
  --grad: linear-gradient(135deg,#1D80D6 0%,#0D4F8B 100%);
  --ease: cubic-bezier(.2,.7,.1,1);
}
*,*::before,*::after{box-sizing:border-box}
*{margin:0;padding:0}
html{background:var(--white)}
body{
  margin:0;
  padding:0;
  width:100%;
  overflow-x:hidden;
  background:var(--white);
  color:var(--navy);
  font-family:'Space Grotesk',sans-serif;
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
::selection{background:var(--orange);color:var(--navy)}

/* ---------- Layout ---------- */
.main-container{
  width:100%;
  max-width:1400px;
  margin:0 auto;
  padding-left:24px;
  padding-right:24px;
  box-sizing:border-box;
}
section{position:relative}
.eyebrow{font-family:'Space Mono',monospace;font-weight:700;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--blue)}
.display{font-family:'Barlow Semi Condensed',sans-serif;font-weight:800;letter-spacing:-.025em;line-height:.95}
.syne{font-family:'Syne',sans-serif;font-weight:800;letter-spacing:-.03em;line-height:.9}
.mono{font-family:'Space Mono',monospace}

/* ---------- Dot grid ---------- */
.dotgrid{position:absolute;inset:0;pointer-events:none;background-image:radial-gradient(rgba(13,30,51,.12) 1px,transparent 1px);background-size:22px 22px;mask-image:radial-gradient(ellipse at center, black 40%, transparent 75%)}
.dotgrid.dark{background-image:radial-gradient(rgba(255,255,255,.10) 1px,transparent 1px)}

/* ---------- Cursor ---------- */
.cursor{position:fixed;top:0;left:0;width:10px;height:10px;border-radius:50%;background:var(--orange);pointer-events:none;mix-blend-mode:multiply;transform:translate(-50%,-50%);transition:width .25s var(--ease),height .25s var(--ease),background .2s;z-index:9999}
.cursor.lg{width:54px;height:54px;background:rgba(245,162,0,.25)}
@media (hover:none){.cursor{display:none}}

/* ---------- Nav ---------- */
nav.top{position:fixed;top:0;left:0;right:0;z-index:50;backdrop-filter:saturate(140%) blur(14px);background:rgba(255,255,255,.7);border-bottom:1px solid transparent;transition:border-color .3s var(--ease),background .3s var(--ease)}
nav.top.scrolled{border-color:var(--line);background:rgba(255,255,255,.85)}
.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  width:100%;
  max-width:1400px;
  margin:0 auto;
  padding:14px 24px;
  box-sizing:border-box;
}
.nav-cta{display:flex;gap:10px;align-items:center}
@media (max-width:760px){.nav-cta .pill.ghost{display:none}}

/* Nav dropdown */
.nav ul li.has-dropdown{position:relative}
.nav ul li.has-dropdown > a{display:inline-flex;align-items:center;gap:5px}
.nav ul li.has-dropdown > a::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 .25s var(--ease)}
.nav ul li.has-dropdown:hover > a::after,.nav ul li.has-dropdown:focus-within > a::after{transform:rotate(225deg) translateY(-2px)}
.nav-submenu{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(8px);background:var(--white);border:1px solid var(--line);border-radius:18px;padding:10px;display:flex;flex-direction:column;gap:2px;min-width:320px;box-shadow:0 20px 50px -16px rgba(13,30,51,.18);opacity:0;visibility:hidden;transition:opacity .25s var(--ease),visibility .25s var(--ease),transform .3s var(--ease);list-style:none;margin-top:18px;z-index:60}
.nav-submenu::before{content:"";position:absolute;top:-18px;left:0;right:0;height:18px}
.nav ul li.has-dropdown:hover .nav-submenu,.nav ul li.has-dropdown:focus-within .nav-submenu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.nav-submenu li{display:block}
.nav-submenu a{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:12px;font-size:14.5px;color:var(--navy);opacity:1;transition:background .2s,color .2s}
.nav-submenu a:hover{background:var(--surface);color:var(--blue)}
.nav-submenu a .sub-num{font-family:'Space Mono',monospace;font-size:10px;letter-spacing:.18em;color:var(--muted);min-width:22px;font-weight:700}
.nav-submenu a:hover .sub-num{color:var(--orange)}
.nav-submenu a .sub-arrow{margin-left:auto;font-size:14px;color:var(--muted);transition:transform .25s var(--ease),color .25s}
.nav-submenu a:hover .sub-arrow{color:var(--blue);transform:translateX(3px)}
.logo{display:flex;align-items:center;gap:10px;font-family:'Space Grotesk',sans-serif;font-weight:700;letter-spacing:-.01em;font-size:20px}
.logo img{width:32px;height:32px}
.nav .logo img,.ft-grid .logo img{width:56px;height:56px}
.nav .logo span,.ft-grid .logo span{display:none}
.nav ul{display:flex;gap:32px;list-style:none}
.nav ul a{font-size:14px;font-weight:500;color:var(--navy);opacity:.75;transition:opacity .2s}
.nav ul a:hover,.nav ul a.active{opacity:1}
.nav ul a.active{color:var(--blue)}
.pill{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;border-radius:100px;background:var(--orange);color:var(--navy);font-weight:600;font-size:14px;border:none;cursor:pointer;transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.pill:hover{transform:translateY(-2px);box-shadow:0 12px 28px -10px rgba(245,162,0,.6)}
.pill.ghost{background:transparent;color:var(--navy);border:1px solid var(--line)}
.pill.ghost:hover{box-shadow:none;border-color:var(--navy)}
.pill .arrow{display:inline-block;transition:transform .3s var(--ease)}
.pill:hover .arrow{transform:translateX(4px)}
@media (max-width:760px){.nav ul{display:none}}

/* ---------- Hero ---------- */
.hero{min-height:100vh;display:flex;align-items:center;padding:130px 0 70px;overflow:hidden;position:relative}
.hero .grid{display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:center}
@media (max-width:980px){.hero .grid{grid-template-columns:1fr;gap:40px}}
.hero h1{font-size:clamp(48px,7vw,108px)}
.hero h1 .accent{color:var(--blue)}
.hero h1 .dot{display:inline-block;width:.18em;height:.18em;border-radius:50%;background:var(--orange);vertical-align:.05em;margin:0 .04em;transform:translateY(-.02em)}
.hero p.lead{margin-top:28px;max-width:520px;font-size:18px;color:#3a4a63}
.hero .cta{display:flex;gap:14px;margin-top:36px;flex-wrap:wrap}
.hero .meta{display:flex;gap:28px;margin-top:54px;padding-top:28px;border-top:1px solid var(--line)}
.hero .meta div{font-size:13px;color:var(--navy);opacity:.7}
.hero .meta strong{display:block;font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--blue);margin-bottom:6px;opacity:1}

.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.1s}.reveal.d2{transition-delay:.2s}.reveal.d3{transition-delay:.3s}.reveal.d4{transition-delay:.4s}.reveal.d5{transition-delay:.5s}

/* ---------- Hero visual ---------- */
.visual{position:relative;aspect-ratio:1/1;width:100%;max-width:460px;margin:0 auto}
.ring{position:absolute;inset:0;border-radius:50%;border:1.5px solid rgba(29,128,214,.18)}
.ring.r2{inset:8%}
.ring.r3{inset:18%}
.ring.r4{inset:28%}
.ring.spin{animation:spin 28s linear infinite}
.ring.spin.rev{animation-direction:reverse;animation-duration:42s}
@keyframes spin{to{transform:rotate(360deg)}}
.ring .tick{position:absolute;width:6px;height:6px;border-radius:50%;background:var(--blue);top:-3px;left:50%;margin-left:-3px}
.ring .tick.b{background:var(--muted)}
.core{position:absolute;inset:36%;background:var(--grad);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 30px 80px -30px rgba(29,128,214,.55)}
.core::before{content:"";position:absolute;inset:-14px;border-radius:50%;border:1px solid rgba(29,128,214,.25)}
.core img{width:62%;height:auto;filter:brightness(0) invert(1)}
.pulse-dot{position:absolute;width:18px;height:18px;border-radius:50%;background:var(--orange);box-shadow:0 0 0 0 rgba(245,162,0,.55);animation:pulse 2.4s var(--ease) infinite}
.pulse-dot.outer{top:78%;left:78%;transform:translate(-50%,-50%)}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(245,162,0,.55)}70%{box-shadow:0 0 0 26px rgba(245,162,0,0)}100%{box-shadow:0 0 0 0 rgba(245,162,0,0)}}

.float-card{position:absolute;background:var(--white);border:1px solid var(--line);border-radius:14px;padding:12px 16px;box-shadow:0 18px 46px -22px rgba(13,30,51,.25);font-family:'Space Mono',monospace;font-size:12px;letter-spacing:.04em;color:var(--navy);display:flex;align-items:center;gap:10px;animation:float 6s var(--ease) infinite}
.float-card .led{width:8px;height:8px;border-radius:50%;background:var(--orange);box-shadow:0 0 8px var(--orange)}
.float-card.fc1{top:6%;left:0%;animation-delay:-2s}
.float-card.fc2{bottom:8%;left:4%;animation-delay:-4s}
.float-card.fc3{top:18%;right:0%}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

/* ---------- Marquee ---------- */
.marquee{padding:28px 0;border-block:1px solid var(--line);background:var(--surface);overflow:hidden;white-space:nowrap}
.marquee-track{display:inline-flex;gap:48px;animation:scroll 40s linear infinite;font-family:'Space Mono',monospace;font-weight:700;font-size:14px;letter-spacing:.22em;text-transform:uppercase;color:var(--navy)}
.marquee-track span{display:inline-flex;align-items:center;gap:48px}
.marquee-track span::after{content:"";width:6px;height:6px;border-radius:50%;background:var(--orange)}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- Section base ---------- */
.sect{padding:120px 0}
@media (max-width:980px){.sect{padding:80px 0}}
.sect-head{display:flex;align-items:flex-end;justify-content:space-between;gap:40px;margin-bottom:64px;flex-wrap:wrap}
.sect-head h2{font-size:clamp(40px,5.2vw,72px);max-width:780px}
.sect-head p{max-width:420px;color:#3a4a63;font-size:17px}

/* ---------- Integrations strip ---------- */
.integrations{padding:60px 0;border-bottom:1px solid var(--line)}
.integrations .label{text-align:center;font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--blue);margin-bottom:28px}
.int-track{overflow:hidden;mask-image:linear-gradient(to right, transparent, black 10%, black 90%, transparent)}
.int-row{display:inline-flex;gap:64px;align-items:center;animation:scroll 38s linear infinite;white-space:nowrap}
.int-row span{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:22px;color:var(--navy);opacity:.55;letter-spacing:-.01em;transition:opacity .3s}
.int-row span:hover{opacity:1}
.int-row em{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--muted);font-style:normal}

/* ---------- Capabilities switcher ---------- */
.switcher{display:grid;grid-template-columns:.85fr 1.15fr;gap:64px;align-items:stretch;min-height:540px}
@media (max-width:980px){.switcher{grid-template-columns:1fr;gap:32px}}
.sw-list{display:flex;flex-direction:column;border-top:1px solid var(--line)}
.sw-item{position:relative;display:flex;gap:18px;padding:22px 0;border-bottom:1px solid var(--line);cursor:pointer;transition:padding .35s var(--ease)}
.sw-item .sw-num{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.2em;color:var(--muted);min-width:36px;padding-top:8px;transition:color .3s}
.sw-item .sw-body{flex:1}
.sw-item .sw-title{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:24px;letter-spacing:-.01em;color:var(--navy);transition:color .3s,transform .35s var(--ease)}
.sw-item .sw-desc{max-height:0;overflow:hidden;color:#3a4a63;font-size:15.5px;transition:max-height .55s var(--ease),margin-top .35s var(--ease),opacity .35s var(--ease);opacity:0}
.sw-item .sw-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.sw-item .sw-tag{font-family:'Space Mono',monospace;font-size:11px;padding:5px 10px;border:1px solid var(--line);border-radius:100px;color:var(--navy);opacity:.7}
.sw-item .sw-bar{position:absolute;left:0;right:0;bottom:-1px;height:1px;background:var(--orange);transform:scaleX(0);transform-origin:left;transition:transform .55s var(--ease)}
.sw-item.active{padding:28px 0 30px}
.sw-item.active .sw-num{color:var(--orange)}
.sw-item.active .sw-title{color:var(--blue);transform:translateX(4px)}
.sw-item.active .sw-desc{max-height:200px;margin-top:14px;opacity:1}
.sw-item.active .sw-bar{transform:scaleX(1)}
.sw-item:hover .sw-num{color:var(--blue)}

.sw-stage{position:relative;border-radius:24px;background:var(--surface);overflow:hidden;border:1px solid var(--line)}
.sw-stage::before{content:"";position:absolute;inset:auto -30% -70% auto;width:560px;height:560px;border-radius:50%;border:60px solid rgba(29,128,214,.06)}
.sw-stage .sw-hint{position:absolute;top:24px;left:28px;font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--blue);z-index:2;display:flex;align-items:center;gap:8px}
.sw-stage .sw-hint::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--orange);box-shadow:0 0 8px var(--orange)}
.sw-frame{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;opacity:0;transform:translateY(20px) scale(.98);transition:opacity .55s var(--ease),transform .55s var(--ease);pointer-events:none}
.sw-frame.active{opacity:1;transform:none;pointer-events:auto}

/* Stage visuals */
.mock{position:relative;width:80%;max-width:460px;background:#fff;border-radius:14px;border:1px solid var(--line);box-shadow:0 26px 60px -30px rgba(13,30,51,.25);font-family:'Space Mono',monospace;font-size:12px;color:var(--navy)}
.mock .mh{display:flex;gap:6px;padding:10px 14px;border-bottom:1px solid var(--line)}
.mock .mh i{width:8px;height:8px;border-radius:50%;background:var(--line);font-style:normal;display:block}
.mock .mh i.dot{background:var(--orange)}
.mock .mb{padding:18px}

/* WORKFLOW mock */
.wf-graph{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.wf-node{padding:10px 12px;border:1px solid var(--line);border-radius:10px;background:var(--white);font-size:11px;display:flex;align-items:center;gap:8px}
.wf-node .led{width:6px;height:6px;border-radius:50%;background:var(--blue);animation:blink 2s infinite}
.wf-node.ok .led{background:var(--orange)}
.wf-arrow{flex:1;height:1px;background:repeating-linear-gradient(90deg,var(--muted) 0 4px,transparent 4px 8px);min-width:14px}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.35}}

/* CONTENT mock */
.feed{display:flex;flex-direction:column;gap:10px}
.feed .post{display:flex;gap:10px;padding:10px;border:1px solid var(--line);border-radius:10px;background:var(--white)}
.feed .post .av{width:28px;height:28px;border-radius:50%;background:var(--grad);flex-shrink:0}
.feed .post .ln{height:6px;background:var(--surface);border-radius:3px;margin-bottom:4px}
.feed .post .ln.s{width:55%}
.feed .post .ln.t{width:80%}
.feed .post .meta{font-size:10px;color:var(--muted);margin-top:6px;letter-spacing:.1em}

/* ACCOUNTING mock */
.ledger{display:flex;flex-direction:column;gap:1px;background:var(--line)}
.ledger .row{display:grid;grid-template-columns:1.5fr .8fr .6fr;gap:8px;padding:9px 12px;background:#fff;font-size:11px;align-items:center}
.ledger .row.h{background:var(--surface);font-weight:700;color:var(--blue);letter-spacing:.1em;font-size:10px;text-transform:uppercase}
.ledger .row .pill-s{display:inline-block;padding:2px 8px;border-radius:100px;font-size:10px;background:rgba(245,162,0,.15);color:#a06a00}
.ledger .row .pill-s.ok{background:rgba(29,128,214,.12);color:var(--blue)}

/* SALES mock */
.pipe{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.pipe .col{background:var(--surface);border-radius:8px;padding:8px}
.pipe .col h6{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--blue);margin-bottom:8px}
.pipe .lead{padding:8px;background:#fff;border:1px solid var(--line);border-radius:6px;margin-bottom:6px;font-size:11px}
.pipe .lead em{font-style:normal;display:block;color:var(--muted);font-size:10px;margin-top:2px;letter-spacing:.05em}

/* INTEGRATIONS mock */
.hub{position:relative;width:100%;height:280px}
.hub .center{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:74px;height:74px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;color:#fff;font-family:'Space Grotesk';font-weight:700;font-size:13px;box-shadow:0 18px 40px -16px rgba(29,128,214,.6)}
.hub .node{position:absolute;padding:8px 12px;border:1px solid var(--line);border-radius:100px;background:#fff;font-size:11px;display:flex;align-items:center;gap:6px;box-shadow:0 8px 20px -12px rgba(13,30,51,.18)}
.hub .node .led{width:6px;height:6px;border-radius:50%;background:var(--blue)}
.hub .n1{top:10%;left:5%}
.hub .n2{top:5%;right:8%}
.hub .n3{bottom:18%;left:0}
.hub .n4{bottom:8%;right:4%}
.hub .n5{top:55%;left:8%}
.hub svg.lines{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}
.hub svg.lines path{stroke:var(--muted);stroke-width:1;fill:none;stroke-dasharray:3 4;animation:dash 18s linear infinite}
@keyframes dash{to{stroke-dashoffset:-200}}

/* ---------- Numbers ---------- */
.stats{background:var(--navy);color:#fff;padding:120px 0;position:relative;overflow:hidden}
.stats::before{content:"";position:absolute;width:900px;height:900px;border-radius:50%;border:1px solid rgba(255,255,255,.06);right:-300px;top:-300px}
.stats::after{content:"";position:absolute;width:600px;height:600px;border-radius:50%;border:1px solid rgba(255,255,255,.06);left:-200px;bottom:-300px}
.stats .main-container{position:relative;z-index:1}
.stats h2{font-size:clamp(40px,5vw,68px);max-width:780px}
.stats h2 .accent{color:var(--orange)}
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;margin-top:80px;padding-top:60px;border-top:1px solid rgba(255,255,255,.1)}
@media (max-width:880px){.stats-grid{grid-template-columns:1fr}}
.stat{position:relative}
.stat .label{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}
.stat .num{font-family:'Barlow Semi Condensed',sans-serif;font-weight:800;font-size:clamp(86px,11vw,170px);line-height:.92;letter-spacing:-.04em;margin-top:18px;color:#fff;display:flex;align-items:baseline;gap:14px;flex-wrap:wrap}
.stat .num small{font-size:.22em;color:var(--orange);font-family:'Space Mono',monospace;font-weight:700;letter-spacing:.18em;text-transform:uppercase;align-self:flex-end;padding-bottom:18px}
.stat .desc{margin-top:20px;color:rgba(255,255,255,.7);max-width:30ch;font-size:14.5px;padding-top:20px;border-top:1px solid rgba(255,255,255,.1)}

/* ---------- Process timeline (horizontal v2) ---------- */
.timeline{position:relative;margin-top:80px}
.timeline-rail{position:absolute;top:42px;left:14%;right:14%;height:2px;background:repeating-linear-gradient(90deg,var(--muted) 0 5px,transparent 5px 11px);opacity:.4;z-index:1}
.timeline-rail::after{content:"";position:absolute;left:0;top:-1px;height:4px;background:var(--orange);width:0;border-radius:2px;transition:width 1.4s var(--ease)}
.timeline.in .timeline-rail::after{width:100%}
.tl-grid{position:relative;display:grid;grid-template-columns:repeat(3,1fr);gap:40px;z-index:2}
@media (max-width:880px){.tl-grid{grid-template-columns:1fr;gap:48px}.timeline-rail{display:none}}

.tl-step{position:relative;text-align:center;padding:0 16px}
@media (max-width:880px){.tl-step{text-align:left;padding:0}}

.tl-badge{position:relative;width:84px;height:84px;border-radius:50%;background:var(--white);border:1.5px solid var(--line);display:flex;align-items:center;justify-content:center;font-family:'Barlow Semi Condensed',sans-serif;font-weight:800;font-size:34px;letter-spacing:-.02em;color:var(--blue);margin:0 auto 28px;transition:transform .45s var(--ease),background .35s var(--ease),color .35s var(--ease),border-color .35s var(--ease),box-shadow .45s var(--ease)}
@media (max-width:880px){.tl-badge{margin:0 0 22px 0}}
.tl-badge::before{content:"";position:absolute;inset:-8px;border:1px solid var(--blue);border-radius:50%;opacity:.18;transition:opacity .4s var(--ease),inset .4s var(--ease)}
.tl-step:hover .tl-badge{transform:translateY(-4px) scale(1.03);background:var(--blue);color:#fff;border-color:var(--blue);box-shadow:0 18px 36px -16px rgba(29,128,214,.55)}
.tl-step:hover .tl-badge::before{opacity:.35;inset:-14px}

.tl-time{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);display:inline-flex;align-items:center;gap:8px}
.tl-time::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--orange)}
.tl-step h4{margin-top:14px;font-family:'Barlow Semi Condensed',sans-serif;font-weight:800;letter-spacing:-.022em;font-size:clamp(30px,3vw,40px);line-height:1;color:var(--navy);transition:color .35s var(--ease)}
.tl-step:hover h4{color:var(--blue)}
.tl-step p{margin-top:16px;color:#3a4a63;font-size:15.5px;max-width:34ch;margin-left:auto;margin-right:auto;line-height:1.6}
@media (max-width:880px){.tl-step p{margin-left:0;margin-right:0}}
.tl-key{margin-top:20px;display:inline-block;font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.06em;padding:7px 14px;border:1px solid var(--line);border-radius:100px;color:var(--navy);background:var(--surface)}

/* ---------- Cases (horizontal scroll posters) ---------- */
.case-stage{position:relative;margin-top:36px}
.case-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px;gap:24px;flex-wrap:wrap}
.case-progress{display:flex;align-items:center;gap:16px;font-family:'Space Mono',monospace;font-size:13px;letter-spacing:.2em;color:var(--navy)}
.cp-curr{color:var(--blue);font-weight:700}
.cp-rail{position:relative;width:200px;height:1px;background:var(--line)}
.cp-fill{position:absolute;left:0;top:-1px;height:3px;background:var(--orange);width:25%;transition:width .55s var(--ease);border-radius:2px}
.cp-total{opacity:.6}
.case-nav{display:flex;gap:10px}
.case-nav button{width:46px;height:46px;border-radius:50%;border:1px solid var(--line);background:var(--white);color:var(--navy);font-size:18px;cursor:pointer;transition:border-color .25s,color .25s,background .25s,transform .25s var(--ease);display:flex;align-items:center;justify-content:center}
.case-nav button:hover:not(:disabled){border-color:var(--blue);color:var(--blue);background:var(--surface)}
.case-nav button:active{transform:scale(.92)}
.case-nav button:disabled{opacity:.3;cursor:not-allowed}
.case-rail{overflow:hidden;margin:0;border-radius:26px}
.case-track{display:flex;gap:24px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding:0;scrollbar-width:none;cursor:grab}
.case-track:active{cursor:grabbing}
.case-track::-webkit-scrollbar{display:none}
.case-poster{flex:0 0 100%;scroll-snap-align:start;position:relative;overflow:hidden;padding:50px;min-height:460px;display:grid;grid-template-columns:1.25fr 1fr;gap:48px;color:#fff;transition:transform .55s var(--ease);user-select:none}
@media (max-width:880px){.case-poster{grid-template-columns:1fr;padding:34px 28px;min-height:auto;gap:28px}}
.case-poster.a{background:linear-gradient(135deg,#0D1E33 0%,#1a3a5e 100%)}
.case-poster.b{background:var(--surface);color:var(--navy);border:1px solid var(--line)}
.case-poster.c{background:var(--navy)}
.case-poster.d{background:linear-gradient(135deg,#1D80D6 0%,#0D4F8B 100%)}
.case-poster::after{content:"";position:absolute;width:560px;height:560px;border-radius:50%;border:1px solid currentColor;opacity:.1;right:-200px;bottom:-200px;pointer-events:none}
.case-poster::before{content:"";position:absolute;width:340px;height:340px;border-radius:50%;border:1px solid currentColor;opacity:.06;left:-140px;top:-140px;pointer-events:none}
.cp-left{position:relative;z-index:1;display:flex;flex-direction:column}
.cp-num{font-family:'Space Mono',monospace;font-size:13px;letter-spacing:.22em;color:var(--orange)}
.case-poster.b .cp-num{color:var(--blue)}
.cp-sector{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;opacity:.75;margin-top:10px}
.cp-title{margin-top:28px;font-family:'Barlow Semi Condensed',sans-serif;font-weight:800;letter-spacing:-.025em;font-size:clamp(34px,3.6vw,52px);line-height:1;max-width:20ch}
.cp-meta{margin-top:auto;display:flex;gap:36px;flex-wrap:wrap;padding-top:32px;border-top:1px solid rgba(255,255,255,.18)}
.case-poster.b .cp-meta{border-color:var(--line)}
.cp-meta .item h6{font-family:'Space Mono',monospace;font-size:10px;letter-spacing:.22em;text-transform:uppercase;opacity:.6;font-weight:700}
.cp-meta .item p{margin-top:6px;font-size:14.5px;font-family:'Space Grotesk',sans-serif}
.cp-right{position:relative;z-index:1;display:flex;flex-direction:column;justify-content:center;align-items:flex-end;text-align:right}
@media (max-width:880px){.cp-right{align-items:flex-start;text-align:left}}
.cp-big{font-family:'Barlow Semi Condensed',sans-serif;font-weight:800;font-size:clamp(110px,14vw,200px);line-height:.82;letter-spacing:-.05em;color:var(--orange)}
.case-poster.b .cp-big{color:var(--blue)}
.cp-big.text{font-size:clamp(56px,7vw,110px)}
.cp-big-label{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.2em;text-transform:uppercase;max-width:20ch;opacity:.75;margin-top:18px;line-height:1.5}

/* ---------- Sectors ---------- */
.sectors{padding:120px 0;background:var(--white);position:relative;overflow:hidden}
.sectors .ring-bg{position:absolute;width:780px;height:780px;border-radius:50%;border:1px solid var(--line);right:-280px;top:50%;transform:translateY(-50%);pointer-events:none}
.sectors .ring-bg.b{width:520px;height:520px;left:-220px;top:30%;right:auto}
.sect-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:60px;border-top:1px solid var(--line);border-left:1px solid var(--line)}
@media (max-width:980px){.sect-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:540px){.sect-grid{grid-template-columns:1fr}}
.sect-cell{position:relative;padding:36px 24px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--white);transition:background .35s var(--ease),transform .35s var(--ease);overflow:hidden;cursor:default;min-height:170px;display:flex;flex-direction:column;justify-content:flex-end}
.sect-cell::before{content:"";position:absolute;left:0;right:0;top:0;height:2px;background:var(--orange);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.sect-cell:hover{background:var(--surface)}
.sect-cell:hover::before{transform:scaleX(1)}
.sect-cell .sc-num{position:absolute;top:18px;right:20px;font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.18em;color:var(--muted);transition:color .35s,transform .4s var(--ease)}
.sect-cell:hover .sc-num{color:var(--orange)}
.sect-cell .sc-icon{width:44px;height:44px;border-radius:12px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;margin-bottom:18px;transition:border-color .35s,background .35s}
.sect-cell:hover .sc-icon{border-color:var(--blue);background:var(--surface)}
.sect-cell .sc-icon svg{width:22px;height:22px;stroke:var(--blue);fill:none;stroke-width:1.6}
.sect-cell h5{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:18px;letter-spacing:-.005em;color:var(--navy);transition:transform .35s var(--ease)}
.sect-cell:hover h5{transform:translateX(4px)}

/* ---------- Blog (shared between home + blog page) ---------- */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:30px}
@media (max-width:980px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:660px){.blog-grid{grid-template-columns:1fr}}

.post-card{position:relative;background:var(--white);border:1px solid var(--line);border-radius:22px;overflow:hidden;display:flex;flex-direction:column;transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .4s var(--ease);text-decoration:none;color:var(--navy);min-height:440px}
.post-card:hover{transform:translateY(-6px);box-shadow:0 30px 60px -30px rgba(13,30,51,.22);border-color:transparent}
.post-card .pc-media{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--grad)}
.post-card .pc-media img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease);display:block}
.post-card:hover .pc-media img{transform:scale(1.05)}
.post-card .pc-media::after{content:"";position:absolute;inset:0;background:linear-gradient(to top, rgba(13,30,51,.4) 0%, transparent 40%);opacity:0;transition:opacity .4s var(--ease)}
.post-card:hover .pc-media::after{opacity:1}
.post-card .pc-category{position:absolute;top:14px;left:14px;z-index:2;background:var(--white);color:var(--blue);font-family:'Space Mono',monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;padding:6px 12px;border-radius:100px;font-weight:700;box-shadow:0 4px 12px -4px rgba(13,30,51,.15);max-width:75%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.post-card .pc-body{padding:24px 24px 26px;display:flex;flex-direction:column;flex:1}
.post-card .pc-date{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:8px}
.post-card .pc-date::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--orange)}
.post-card h4{margin-top:12px;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:20px;line-height:1.25;letter-spacing:-.01em;color:var(--navy);transition:color .35s var(--ease);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.post-card:hover h4{color:var(--blue)}
.post-card p{margin-top:12px;color:#3a4a63;font-size:14.5px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.post-card .pc-more{margin-top:auto;padding-top:22px;display:inline-flex;align-items:center;gap:8px;font-family:'Space Grotesk',sans-serif;font-weight:600;color:var(--navy);font-size:14px;transition:color .3s var(--ease)}
.post-card .pc-more .arrow{transition:transform .3s var(--ease)}
.post-card:hover .pc-more{color:var(--blue)}
.post-card:hover .pc-more .arrow{transform:translateX(6px)}

.post-skeleton{background:var(--surface);border-color:var(--line);min-height:440px;animation:skeleton 1.4s ease-in-out infinite alternate}
@keyframes skeleton{from{opacity:.6}to{opacity:1}}
.post-skeleton .pc-media{background:linear-gradient(110deg,var(--surface) 30%,#eaf1fa 50%,var(--surface) 70%);background-size:200% 100%;animation:shimmer 1.6s linear infinite}
@keyframes shimmer{from{background-position:200% 0}to{background-position:-200% 0}}

.blog-cta{margin-top:48px;display:flex;justify-content:center}
.blog-empty{padding:60px 0;text-align:center;color:var(--muted);font-family:'Space Mono',monospace;font-size:13px;letter-spacing:.15em;text-transform:uppercase;grid-column:1/-1}

/* ---------- Blog page specific ---------- */
.blog-page-header{padding:160px 0 30px;background:var(--white);position:relative;overflow:hidden}
.blog-page-header .eyebrow{display:inline-flex;align-items:center;gap:10px}
.blog-page-header .eyebrow::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--orange)}
.blog-page-header h1{margin-top:18px;font-family:'Barlow Semi Condensed',sans-serif;font-weight:800;letter-spacing:-.025em;line-height:.95;font-size:clamp(56px,8vw,128px)}
.blog-page-header h1 .accent{color:var(--blue)}
.blog-page-header .lead{margin-top:28px;max-width:580px;font-size:18px;color:#3a4a63}
.blog-page-header .meta-row{margin-top:36px;padding-top:24px;border-top:1px solid var(--line);display:flex;gap:32px;flex-wrap:wrap;font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.blog-page-header .meta-row strong{color:var(--blue);font-weight:700}

.blog-page-body{padding:60px 0 100px;background:var(--white)}

/* ---------- Calculator ---------- */
.calculator{padding:120px 0;background:var(--surface);position:relative;overflow:hidden}
.calculator::before{content:"";position:absolute;width:780px;height:780px;border-radius:50%;border:1px solid var(--line);left:-280px;top:50%;transform:translateY(-50%);pointer-events:none;opacity:.5}
.calculator::after{content:"";position:absolute;width:520px;height:520px;border-radius:50%;border:1px solid var(--line);right:-180px;bottom:-180px;pointer-events:none;opacity:.5}
.calculator .main-container{position:relative;z-index:1}

.calc-layout{display:grid;grid-template-columns:.95fr 1.05fr;gap:48px;margin-top:24px;background:var(--white);border:1px solid var(--line);border-radius:28px;overflow:hidden}
@media (max-width:980px){.calc-layout{grid-template-columns:1fr;gap:0}}

.calc-inputs{padding:48px 44px;border-right:1px solid var(--line)}
@media (max-width:980px){.calc-inputs{border-right:none;border-bottom:1px solid var(--line);padding:36px 28px}}
.calc-intro-eyebrow{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--blue);display:flex;align-items:center;gap:10px;margin-bottom:32px}
.calc-intro-eyebrow::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--orange)}

.calc-field{margin-bottom:36px}
.calc-field:last-child{margin-bottom:0}
.calc-field .top-row{display:flex;justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:14px}
.calc-field label{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:15px;color:var(--navy);line-height:1.3;max-width:32ch}
.calc-field .value{font-family:'Barlow Semi Condensed',sans-serif;font-weight:800;font-size:34px;line-height:1;letter-spacing:-.02em;color:var(--blue);flex-shrink:0}
.calc-field .value small{font-family:'Space Mono',monospace;font-size:11px;font-weight:700;letter-spacing:.18em;color:var(--muted);text-transform:uppercase;margin-left:4px}

.calc-slider{-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:100px;background:var(--surface);outline:none;cursor:pointer}
.calc-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:24px;height:24px;border-radius:50%;background:var(--orange);cursor:grab;border:3px solid var(--white);box-shadow:0 4px 12px -2px rgba(245,162,0,.5),0 0 0 1px var(--orange);transition:transform .2s var(--ease)}
.calc-slider::-webkit-slider-thumb:hover{transform:scale(1.12)}
.calc-slider::-webkit-slider-thumb:active{cursor:grabbing;transform:scale(1.18)}
.calc-slider::-moz-range-thumb{width:24px;height:24px;border-radius:50%;background:var(--orange);cursor:grab;border:3px solid var(--white);box-shadow:0 4px 12px -2px rgba(245,162,0,.5),0 0 0 1px var(--orange)}
.calc-slider::-webkit-slider-runnable-track{background:linear-gradient(to right, var(--blue) 0%, var(--blue) var(--p,30%), var(--surface) var(--p,30%), var(--surface) 100%);height:6px;border-radius:100px;border:1px solid var(--line)}
.calc-slider::-moz-range-track{background:var(--surface);height:6px;border-radius:100px;border:1px solid var(--line)}
.calc-slider::-moz-range-progress{background:var(--blue);height:6px;border-radius:100px}

.calc-output{padding:48px 44px;background:var(--navy);color:#fff;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}
@media (max-width:980px){.calc-output{padding:36px 28px}}
.calc-output::before{content:"";position:absolute;width:500px;height:500px;border-radius:50%;border:1px solid rgba(255,255,255,.06);right:-200px;top:-200px;pointer-events:none}

.calc-result-eyebrow{position:relative;z-index:1;font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--orange);display:flex;align-items:center;gap:10px;margin-bottom:8px}
.calc-result-eyebrow::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--orange);animation:pulse-sm 2s infinite}
@keyframes pulse-sm{0%,100%{opacity:1}50%{opacity:.4}}
.calc-result-title{position:relative;z-index:1;font-family:'Barlow Semi Condensed',sans-serif;font-weight:800;letter-spacing:-.022em;font-size:clamp(22px,2.4vw,28px);line-height:1.1;color:#fff;margin-bottom:32px;max-width:24ch}

.calc-stats-row{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:18px;padding-bottom:24px;border-bottom:1px solid rgba(255,255,255,.12)}
.calc-stat-block .label{font-family:'Space Mono',monospace;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.6)}
.calc-stat-block .num{font-family:'Barlow Semi Condensed',sans-serif;font-weight:800;font-size:clamp(34px,3.6vw,46px);line-height:1;letter-spacing:-.03em;color:#fff;margin-top:8px}
.calc-stat-block .sub{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.12em;color:rgba(255,255,255,.5);margin-top:6px}

.calc-savings{position:relative;z-index:1;margin-top:24px;padding-top:8px}
.calc-savings .label{font-family:'Space Grotesk',sans-serif;font-size:14px;color:rgba(255,255,255,.7);max-width:42ch;line-height:1.5}
.calc-savings .label strong{color:var(--orange);font-weight:600}
.calc-big-num{margin-top:20px;display:flex;align-items:baseline;gap:18px;flex-wrap:wrap}
.calc-big-num .main{font-family:'Barlow Semi Condensed',sans-serif;font-weight:800;font-size:clamp(56px,7vw,90px);line-height:.9;letter-spacing:-.04em;color:var(--orange)}
.calc-big-num .unit{font-family:'Space Mono',monospace;font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.7);font-weight:700}
.calc-big-num .sub-num{font-family:'Barlow Semi Condensed',sans-serif;font-weight:600;font-size:18px;color:rgba(255,255,255,.85)}

.calc-cta{position:relative;z-index:1;margin-top:32px;display:flex;flex-direction:column;gap:14px}
.calc-cta .pill{align-self:flex-start;background:var(--orange);color:var(--navy)}
.calc-disclaimer{position:relative;z-index:1;margin-top:18px;font-family:'Space Mono',monospace;font-size:10px;letter-spacing:.06em;color:rgba(255,255,255,.45);line-height:1.5}

/* ---------- FAQ ---------- */
.faq{padding:120px 0;background:var(--white);position:relative}
.faq .faq-layout{display:grid;grid-template-columns:.85fr 1.15fr;gap:80px;align-items:start}
@media (max-width:980px){.faq .faq-layout{grid-template-columns:1fr;gap:48px}}
.faq .faq-intro h2{font-size:clamp(40px,5vw,68px);line-height:.95}
.faq .faq-intro p{margin-top:24px;color:#3a4a63;font-size:17px;max-width:38ch}
.faq .faq-intro .helper{margin-top:36px;padding:24px;border:1px solid var(--line);border-radius:18px;background:var(--surface)}
.faq .faq-intro .helper .label{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--blue);display:flex;align-items:center;gap:10px}
.faq .faq-intro .helper .label::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--orange)}
.faq .faq-intro .helper p{margin-top:12px;font-size:15px;max-width:none}
.faq .faq-intro .helper a{display:inline-flex;align-items:center;gap:8px;margin-top:14px;font-weight:600;color:var(--blue)}
.faq .faq-intro .helper a .arrow{transition:transform .3s var(--ease)}
.faq .faq-intro .helper a:hover .arrow{transform:translateX(6px)}

.faq-list{display:flex;flex-direction:column;border-top:1px solid var(--line)}
.faq-item{position:relative;border-bottom:1px solid var(--line)}
.faq-item .faq-q{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:26px 8px 26px 0;cursor:pointer;width:100%;background:none;border:none;text-align:left;font-family:inherit;color:var(--navy);transition:padding .35s var(--ease)}
.faq-item .faq-q:hover{padding-left:8px}
.faq-item .faq-q .q-text{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:clamp(17px,1.4vw,20px);letter-spacing:-.005em;color:var(--navy);line-height:1.3;transition:color .3s var(--ease)}
.faq-item .faq-q:hover .q-text,.faq-item.open .faq-q .q-text{color:var(--blue)}
.faq-item .faq-icon{flex-shrink:0;width:36px;height:36px;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;position:relative;transition:border-color .3s var(--ease),background .3s var(--ease)}
.faq-item .faq-icon::before,.faq-item .faq-icon::after{content:"";position:absolute;background:var(--navy);transition:background .3s var(--ease),transform .35s var(--ease)}
.faq-item .faq-icon::before{width:12px;height:1.5px}
.faq-item .faq-icon::after{width:1.5px;height:12px}
.faq-item.open .faq-icon{border-color:var(--orange);background:var(--orange)}
.faq-item.open .faq-icon::before,.faq-item.open .faq-icon::after{background:var(--navy)}
.faq-item.open .faq-icon::after{transform:rotate(90deg);opacity:0}
.faq-item .faq-a{max-height:0;overflow:hidden;transition:max-height .55s var(--ease)}
.faq-item.open .faq-a{max-height:500px}
.faq-item .faq-a-inner{padding:0 60px 28px 0;color:#3a4a63;font-size:16px;line-height:1.7;max-width:62ch}

/* ---------- Post page (article) ---------- */
.post-hero{padding:140px 0 50px;background:var(--white);position:relative;overflow:hidden}
.post-hero .post-back{display:inline-flex;align-items:center;gap:8px;font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);transition:color .25s;margin-bottom:36px}
.post-hero .post-back:hover{color:var(--blue)}
.post-hero .post-back .arrow{display:inline-block;transition:transform .3s var(--ease)}
.post-hero .post-back:hover .arrow{transform:translateX(-4px)}
.post-hero .post-cat{display:inline-flex;align-items:center;gap:10px;font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--blue);font-weight:700}
.post-hero .post-cat::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--orange)}
.post-hero h1{margin-top:18px;font-family:'Barlow Semi Condensed',sans-serif;font-weight:800;letter-spacing:-.025em;line-height:1;font-size:clamp(40px,5.8vw,84px);max-width:20ch;color:var(--navy)}
.post-hero .post-meta{margin-top:28px;display:flex;gap:24px;flex-wrap:wrap;font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.post-hero .post-meta strong{color:var(--blue);font-weight:700}
.post-hero .post-image{margin-top:50px;border-radius:24px;overflow:hidden;aspect-ratio:16/8;background:var(--surface);position:relative}
.post-hero .post-image img{width:100%;height:100%;object-fit:cover;display:block}
@media (max-width:760px){.post-hero{padding:120px 0 30px}.post-hero .post-image{margin-top:32px;border-radius:18px;aspect-ratio:4/3}}

.post-body{padding:60px 0 100px;background:var(--white)}
.post-body .prose{max-width:740px;margin:0 auto;font-size:18px;line-height:1.75;color:#2a3a4f}
.post-body .prose > *:first-child{margin-top:0}
.post-body .prose p{margin:0 0 24px;font-family:'Space Grotesk',sans-serif;font-weight:400}
.post-body .prose p strong{color:var(--navy);font-weight:700}
.post-body .prose p:first-of-type{font-size:21px;color:var(--navy);font-weight:500;line-height:1.6}
.post-body .prose h2{font-family:'Barlow Semi Condensed',sans-serif;font-weight:800;letter-spacing:-.022em;font-size:clamp(28px,3.4vw,40px);line-height:1.1;color:var(--navy);margin:56px 0 20px;padding-top:12px;position:relative}
.post-body .prose h2::before{content:"";position:absolute;left:0;top:0;width:48px;height:2px;background:var(--orange)}
.post-body .prose h3{font-family:'Space Grotesk',sans-serif;font-weight:700;letter-spacing:-.01em;font-size:clamp(20px,2.4vw,26px);line-height:1.25;color:var(--navy);margin:38px 0 14px}
.post-body .prose h1{display:none}
.post-body .prose ul,.post-body .prose ol{margin:0 0 28px;padding-left:24px}
.post-body .prose li{margin-bottom:10px}
.post-body .prose li strong{color:var(--navy)}
.post-body .prose a{color:var(--blue);border-bottom:1px solid rgba(29,128,214,.25);transition:border-color .2s,color .2s}
.post-body .prose a:hover{color:var(--blue-deep);border-bottom-color:var(--blue)}
.post-body .prose blockquote{margin:32px 0;padding:24px 28px;border-left:3px solid var(--orange);background:var(--surface);border-radius:0 12px 12px 0;font-style:italic;color:var(--navy)}
.post-body .prose code{background:var(--surface);padding:2px 6px;border-radius:4px;font-family:'Space Mono',monospace;font-size:.9em;color:var(--blue)}
.post-body .prose img{margin:32px 0;border-radius:14px;width:100%;height:auto}

.post-end{max-width:740px;margin:64px auto 0;padding-top:40px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px;font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.post-end .share{display:flex;gap:10px}
.post-end .share a{width:38px;height:38px;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--navy);transition:border-color .25s,color .25s,background .25s}
.post-end .share a:hover{border-color:var(--blue);color:var(--blue);background:var(--surface)}
.post-end .share svg{width:14px;height:14px;fill:currentColor}

.post-related{padding:80px 0 100px;background:var(--surface)}
.post-related h3{font-family:'Barlow Semi Condensed',sans-serif;font-weight:800;letter-spacing:-.022em;font-size:clamp(28px,3vw,40px);line-height:1;color:var(--navy);margin-bottom:36px}

.post-loading{padding:200px 0;text-align:center;color:var(--muted);font-family:'Space Mono',monospace;font-size:13px;letter-spacing:.18em;text-transform:uppercase}
.post-404{padding:200px 0;text-align:center}
.post-404 h1{font-family:'Barlow Semi Condensed',sans-serif;font-weight:800;letter-spacing:-.025em;font-size:clamp(48px,6vw,84px);line-height:1;color:var(--navy)}
.post-404 p{margin:24px auto 36px;max-width:480px;color:#3a4a63}

/* ---------- CTA ---------- */
.cta-block{position:relative;margin:120px 0;border-radius:32px;background:var(--navy);color:#fff;padding:100px 60px;text-align:center;overflow:hidden}
@media (max-width:760px){.cta-block{margin:80px 0;padding:60px 28px;border-radius:24px}}
.cta-block::before,.cta-block::after{content:"";position:absolute;border-radius:50%;border:1px solid rgba(255,255,255,.08)}
.cta-block::before{width:680px;height:680px;left:-220px;top:-220px}
.cta-block::after{width:520px;height:520px;right:-160px;bottom:-200px}
.cta-block h2{position:relative;z-index:1;font-family:'Barlow Semi Condensed',sans-serif;font-weight:800;letter-spacing:-.025em;font-size:clamp(40px,5.5vw,76px);line-height:.95;max-width:18ch;margin-left:auto;margin-right:auto}
.cta-block h2 .accent{color:var(--orange)}
.cta-block p{position:relative;z-index:1;max-width:560px;margin:24px auto 36px;color:rgba(255,255,255,.75);font-size:17px}
.cta-block .cta{position:relative;z-index:1;display:inline-flex;gap:14px;flex-wrap:wrap;justify-content:center}
.cta-block .pill.ghost{color:#fff;border-color:rgba(255,255,255,.2)}
.cta-block .pill.ghost:hover{border-color:#fff}

/* ---------- Contact modal ---------- */
.modal-overlay{position:fixed;inset:0;z-index:200;background:rgba(13,30,51,.55);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;visibility:hidden;transition:opacity .35s var(--ease),visibility .35s var(--ease)}
.modal-overlay.open{opacity:1;visibility:visible}
body.modal-open{overflow:hidden}
.modal-panel{position:relative;background:var(--white);border-radius:24px;max-width:580px;width:100%;max-height:90vh;overflow-y:auto;padding:48px 44px;box-shadow:0 40px 100px -30px rgba(13,30,51,.4);transform:translateY(24px) scale(.97);transition:transform .45s var(--ease);scrollbar-width:thin}
.modal-overlay.open .modal-panel{transform:translateY(0) scale(1)}
@media (max-width:560px){.modal-panel{padding:34px 24px;border-radius:18px}}
.modal-close{position:absolute;top:18px;right:18px;width:38px;height:38px;border-radius:50%;border:1px solid var(--line);background:var(--white);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;color:var(--navy);line-height:1;transition:border-color .25s,color .25s,transform .25s var(--ease)}
.modal-close:hover{border-color:var(--navy);transform:rotate(90deg)}

.modal-header{margin-bottom:32px}
.modal-header .eyebrow{display:inline-flex;align-items:center;gap:10px}
.modal-header .eyebrow::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--orange)}
.modal-header h3{margin-top:14px;font-family:'Barlow Semi Condensed',sans-serif;font-weight:800;letter-spacing:-.022em;font-size:clamp(32px,3.4vw,42px);line-height:1;color:var(--navy)}
.modal-header p{margin-top:14px;color:#3a4a63;font-size:15.5px;max-width:42ch}

.modal-form{display:flex;flex-direction:column;gap:22px}
.modal-form .field{display:flex;flex-direction:column;gap:8px}
.modal-form label{display:flex;align-items:center;gap:8px;font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--navy);font-weight:700}
.modal-form label .req{color:var(--orange);font-size:14px}
.modal-form label .opt{color:var(--muted);font-weight:400;letter-spacing:.06em;text-transform:none;font-size:11px}
.modal-form input,.modal-form textarea,.modal-form select{width:100%;padding:14px 16px;border:1px solid var(--line);border-radius:12px;background:var(--surface);font-family:'Space Grotesk',sans-serif;font-size:15px;color:var(--navy);transition:border-color .25s,background .25s,box-shadow .25s;font-weight:500}
.modal-form input:focus,.modal-form textarea:focus,.modal-form select:focus{outline:none;border-color:var(--blue);background:var(--white);box-shadow:0 0 0 4px rgba(29,128,214,.1)}
.modal-form input:invalid:not(:placeholder-shown),.modal-form textarea:invalid:not(:placeholder-shown){border-color:#e15a5a}
.modal-form textarea{resize:vertical;min-height:96px;font-family:'Space Grotesk',sans-serif}
.modal-form select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230D1E33' stroke-width='2'%3e%3cpath d='M6 9l6 6 6-6'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 14px center;background-size:18px;padding-right:42px;cursor:pointer}
.modal-submit{align-self:flex-start;margin-top:8px;padding:14px 28px;font-size:14.5px}

.modal-success{text-align:center;padding:20px 0;display:none}
.modal-success.show{display:block;animation:fadeUp .5s var(--ease)}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.modal-success .success-icon{width:64px;height:64px;border-radius:50%;background:var(--orange);color:var(--navy);display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:700;margin:0 auto 24px}
.modal-success h3{font-family:'Barlow Semi Condensed',sans-serif;font-weight:800;letter-spacing:-.022em;font-size:42px;line-height:1;color:var(--navy)}
.modal-success p{margin-top:14px;color:#3a4a63;font-size:16px;max-width:32ch;margin-left:auto;margin-right:auto}

/* ---------- Product page (visual v2) ---------- */
.ph-mock-wrap{position:relative;display:flex;align-items:center;justify-content:center;min-height:440px;padding:32px;background:linear-gradient(135deg, var(--surface) 0%, #e8f1fa 100%);border-radius:24px;overflow:hidden;border:1px solid var(--line)}
.ph-mock-wrap::before{content:"";position:absolute;width:400px;height:400px;border-radius:50%;border:1px solid var(--line);right:-160px;top:-160px;opacity:.5}
.ph-mock-wrap::after{content:"";position:absolute;width:280px;height:280px;border-radius:50%;border:1px solid var(--line);left:-120px;bottom:-120px;opacity:.5}
.ph-mock-wrap .mock-hint{position:absolute;top:18px;left:22px;font-family:'Space Mono',monospace;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--blue);display:flex;align-items:center;gap:8px;z-index:3}
.ph-mock-wrap .mock-hint::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--orange);box-shadow:0 0 8px var(--orange);animation:pulse-sm 2s infinite}

/* Pipeline horizontal animated */
.ph-flow-section{padding:100px 0;background:var(--white);position:relative;overflow:hidden}
.ph-flow-section h2{font-family:'Barlow Semi Condensed',sans-serif;font-weight:800;letter-spacing:-.025em;font-size:clamp(36px,4.6vw,64px);line-height:.95;color:var(--navy);max-width:18ch;margin-bottom:60px}

.flow-pipeline{position:relative;display:flex;align-items:center;justify-content:space-between;gap:0;padding:40px 0;flex-wrap:wrap}
.flow-pipeline::before{content:"";position:absolute;top:50%;left:6%;right:6%;height:2px;background:repeating-linear-gradient(90deg,var(--muted) 0 6px,transparent 6px 12px);opacity:.4;z-index:1}
.flow-pipeline.in::before{background:var(--orange);animation:flowFill 2.5s var(--ease) forwards;background:repeating-linear-gradient(90deg,var(--muted) 0 6px,transparent 6px 12px)}
.flow-pipeline.in::after{content:"";position:absolute;top:50%;left:6%;height:3px;width:0;background:var(--orange);border-radius:2px;animation:flowFill 1.8s var(--ease) forwards}
@keyframes flowFill{to{width:88%}}

.flow-node{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:14px;flex:1;min-width:0}
.flow-node .node-circle{width:70px;height:70px;border-radius:50%;background:var(--white);border:2px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:26px;transition:transform .4s var(--ease),border-color .4s var(--ease),box-shadow .4s var(--ease);position:relative}
.flow-node .node-circle::before{content:"";position:absolute;inset:-6px;border-radius:50%;border:1px solid var(--blue);opacity:0;transition:opacity .35s var(--ease),inset .35s var(--ease)}
.flow-pipeline.in .flow-node:nth-child(1) .node-circle{animation:popNode .5s var(--ease) .1s both}
.flow-pipeline.in .flow-node:nth-child(2) .node-circle{animation:popNode .5s var(--ease) .5s both}
.flow-pipeline.in .flow-node:nth-child(3) .node-circle{animation:popNode .5s var(--ease) .9s both}
.flow-pipeline.in .flow-node:nth-child(4) .node-circle{animation:popNode .5s var(--ease) 1.3s both}
.flow-pipeline.in .flow-node:nth-child(5) .node-circle{animation:popNode .5s var(--ease) 1.7s both}
@keyframes popNode{0%{transform:scale(.6);opacity:0;border-color:var(--line);background:var(--white)}60%{transform:scale(1.1);border-color:var(--orange);background:var(--orange);color:var(--navy)}100%{transform:scale(1);border-color:var(--blue);background:var(--white);opacity:1}}
.flow-node:hover .node-circle{transform:scale(1.08);border-color:var(--blue);box-shadow:0 12px 28px -10px rgba(29,128,214,.4)}
.flow-node:hover .node-circle::before{opacity:.4;inset:-12px}
.flow-node .node-label{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.12em;color:var(--navy);text-align:center;max-width:14ch;line-height:1.3;font-weight:500}

@media (max-width:880px){
  .flow-pipeline{flex-direction:column;gap:14px}
  .flow-pipeline::before,.flow-pipeline::after{display:none}
  .flow-node{flex-direction:row;justify-content:flex-start;width:100%;gap:18px}
  .flow-node .node-circle{width:56px;height:56px;font-size:22px;flex-shrink:0}
  .flow-node .node-label{text-align:left;max-width:none;font-size:13px}
}

/* Antes vs Ahora split */
.ph-vs-section{padding:100px 0;background:var(--surface);position:relative;overflow:hidden}
.ph-vs-section h2{font-family:'Barlow Semi Condensed',sans-serif;font-weight:800;letter-spacing:-.025em;font-size:clamp(36px,4.6vw,64px);line-height:.95;color:var(--navy);max-width:18ch;margin-bottom:60px}
.vs-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;position:relative}
@media (max-width:760px){.vs-grid{grid-template-columns:1fr}}
.vs-grid::before{content:"";position:absolute;left:50%;top:60px;bottom:60px;width:1px;background:repeating-linear-gradient(to bottom,var(--line) 0 6px,transparent 6px 12px)}
@media (max-width:760px){.vs-grid::before{display:none}}

.vs-card{padding:38px 32px;border-radius:22px;position:relative;overflow:hidden;transition:transform .45s var(--ease)}
.vs-card.before{background:var(--white);border:1px solid var(--line)}
.vs-card.after{background:var(--navy);color:#fff}
.vs-card:hover{transform:translateY(-4px)}
.vs-card .vs-label{display:inline-flex;align-items:center;gap:10px;font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:700;margin-bottom:24px}
.vs-card.before .vs-label{color:#e15a5a}
.vs-card.before .vs-label::before{content:"";width:8px;height:8px;border-radius:50%;background:#e15a5a}
.vs-card.after .vs-label{color:var(--orange)}
.vs-card.after .vs-label::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--orange);box-shadow:0 0 8px var(--orange)}
.vs-card h3{font-family:'Barlow Semi Condensed',sans-serif;font-weight:800;letter-spacing:-.022em;font-size:clamp(28px,3vw,38px);line-height:1.05;margin-bottom:28px}
.vs-card.before h3{color:var(--navy)}
.vs-card.after h3{color:#fff}
.vs-card ul{list-style:none;display:flex;flex-direction:column;gap:14px}
.vs-card ul li{display:flex;align-items:flex-start;gap:14px;padding:14px 16px;border-radius:12px;font-size:14.5px;line-height:1.5;transition:transform .3s var(--ease),background .3s var(--ease)}
.vs-card.before ul li{background:var(--surface);color:var(--navy)}
.vs-card.before ul li:hover{transform:translateX(4px);background:rgba(225,90,90,.06)}
.vs-card.after ul li{background:rgba(255,255,255,.05);color:rgba(255,255,255,.92)}
.vs-card.after ul li:hover{transform:translateX(4px);background:rgba(245,162,0,.1)}
.vs-card ul li .ico{flex-shrink:0;font-size:20px;line-height:1}

/* System screens (mock UI tabs) */
.ph-screens{padding:100px 0;background:var(--white);position:relative;overflow:hidden}
.ph-screens h2{font-family:'Barlow Semi Condensed',sans-serif;font-weight:800;letter-spacing:-.025em;font-size:clamp(36px,4.6vw,64px);line-height:.95;color:var(--navy);max-width:18ch;margin-bottom:48px}

/* Stack visual diagram */
.ph-stack-section{padding:100px 0;background:var(--navy);color:#fff;position:relative;overflow:hidden}
.ph-stack-section::before{content:"";position:absolute;width:700px;height:700px;border-radius:50%;border:1px solid rgba(255,255,255,.06);left:50%;top:50%;transform:translate(-50%,-50%);pointer-events:none}
.ph-stack-section::after{content:"";position:absolute;width:480px;height:480px;border-radius:50%;border:1px solid rgba(255,255,255,.05);left:50%;top:50%;transform:translate(-50%,-50%);pointer-events:none}
.ph-stack-section .main-container{position:relative;z-index:1}
.ph-stack-section .stack-eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--orange);font-weight:700;margin-bottom:18px}
.ph-stack-section .stack-eyebrow::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--orange)}
.ph-stack-section h2{font-family:'Barlow Semi Condensed',sans-serif;font-weight:800;letter-spacing:-.025em;font-size:clamp(36px,4.6vw,64px);line-height:.95;color:#fff;max-width:18ch;margin-bottom:60px}

.stack-cloud{position:relative;height:420px;display:flex;align-items:center;justify-content:center;flex-wrap:wrap}
.stack-cloud .stack-center{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:130px;height:130px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;color:#fff;font-family:'Barlow Semi Condensed',sans-serif;font-weight:800;font-size:22px;letter-spacing:-.02em;box-shadow:0 30px 60px -20px rgba(29,128,214,.6);z-index:3}
.stack-cloud .stack-center::before{content:"";position:absolute;inset:-12px;border:1px solid rgba(29,128,214,.5);border-radius:50%;animation:spin 24s linear infinite}
.stack-cloud .stack-center::after{content:"";position:absolute;inset:-26px;border:1px dashed rgba(29,128,214,.25);border-radius:50%;animation:spin 36s linear infinite reverse}

.stack-cloud .stack-orbit{position:absolute;border-radius:50%;border:1px solid rgba(255,255,255,.06);pointer-events:none}
.stack-cloud .stack-orbit.o1{width:340px;height:340px}
.stack-cloud .stack-orbit.o2{width:480px;height:480px}

.stack-cloud .stack-badge{position:absolute;padding:12px 18px;background:rgba(255,255,255,.06);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.12);border-radius:100px;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:14px;color:#fff;display:flex;align-items:center;gap:8px;transition:transform .35s var(--ease),background .35s var(--ease),border-color .35s var(--ease);z-index:2;animation:floatY 6s var(--ease) infinite;cursor:default}
.stack-cloud .stack-badge::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--orange);box-shadow:0 0 8px var(--orange)}
.stack-cloud .stack-badge:hover{transform:scale(1.08);background:rgba(245,162,0,.12);border-color:var(--orange)}
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

/* Stack mobile fallback */
@media (max-width:760px){
  .stack-cloud{height:auto;flex-direction:column;gap:10px;padding:20px 0}
  .stack-cloud .stack-center{position:relative;left:auto;top:auto;transform:none;margin-bottom:20px}
  .stack-cloud .stack-orbit{display:none}
  .stack-cloud .stack-badge{position:relative !important;left:auto !important;top:auto !important;right:auto !important;bottom:auto !important;animation:none}
}

/* Hero refined */
.product-hero{padding:160px 0 80px;background:var(--white);position:relative;overflow:hidden}
.product-hero::before{content:"";position:absolute;width:780px;height:780px;border-radius:50%;border:1px solid var(--line);right:-360px;top:-200px;opacity:.5;pointer-events:none}
.product-hero .ph-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;position:relative;z-index:1}
@media (max-width:980px){.product-hero .ph-grid{grid-template-columns:1fr;gap:40px}}
.product-hero .ph-eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--blue);font-weight:700}
.product-hero .ph-eyebrow::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--orange)}
.product-hero h1{margin-top:20px;font-family:'Barlow Semi Condensed',sans-serif;font-weight:800;letter-spacing:-.025em;line-height:.95;font-size:clamp(48px,6.5vw,96px);color:var(--navy)}
.product-hero h1 .accent{color:var(--blue)}
.product-hero .ph-tagline{margin-top:24px;font-family:'Space Grotesk',sans-serif;font-weight:500;font-size:clamp(18px,1.4vw,22px);line-height:1.4;color:var(--navy);max-width:32ch}
.product-hero .ph-cta{margin-top:36px;display:flex;gap:14px;flex-wrap:wrap}

/* Old sections (keep but unused: problem-list, solution-list, deliverables-grid) */
.product-hero{padding:160px 0 80px;background:var(--white);position:relative;overflow:hidden}
.product-hero::before{content:"";position:absolute;width:780px;height:780px;border-radius:50%;border:1px solid var(--line);right:-360px;top:-200px;opacity:.5;pointer-events:none}
.product-hero .ph-grid{display:grid;grid-template-columns:1fr .9fr;gap:60px;align-items:center;position:relative;z-index:1}
@media (max-width:980px){.product-hero .ph-grid{grid-template-columns:1fr;gap:40px}}
.product-hero .ph-eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--blue);font-weight:700}
.product-hero .ph-eyebrow::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--orange)}
.product-hero h1{margin-top:20px;font-family:'Barlow Semi Condensed',sans-serif;font-weight:800;letter-spacing:-.025em;line-height:.95;font-size:clamp(48px,7vw,108px);color:var(--navy)}
.product-hero h1 .accent{color:var(--blue)}
.product-hero .ph-tagline{margin-top:24px;font-family:'Space Grotesk',sans-serif;font-weight:500;font-size:clamp(20px,1.8vw,24px);line-height:1.35;color:var(--navy);max-width:32ch}
.product-hero .ph-lead{margin-top:24px;font-size:17px;color:#3a4a63;max-width:54ch;line-height:1.6}
.product-hero .ph-cta{margin-top:36px;display:flex;gap:14px;flex-wrap:wrap}

.product-hero .ph-side{position:relative;background:var(--surface);border-radius:24px;border:1px solid var(--line);padding:36px 32px;display:flex;flex-direction:column;gap:14px}
.product-hero .ph-side .label{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--blue);display:flex;align-items:center;gap:10px}
.product-hero .ph-side .label::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--orange)}
.product-hero .ph-side h3{font-family:'Barlow Semi Condensed',sans-serif;font-weight:800;letter-spacing:-.022em;font-size:32px;line-height:1.05;color:var(--navy)}
.product-hero .ph-side ul{list-style:none;margin-top:10px;display:flex;flex-direction:column;gap:11px}
.product-hero .ph-side ul li{display:flex;align-items:flex-start;gap:12px;font-size:14.5px;color:var(--navy);line-height:1.45}
.product-hero .ph-side ul li::before{content:"";width:18px;height:18px;flex-shrink:0;border-radius:50%;background:var(--white);border:1px solid var(--line);position:relative;margin-top:2px;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23F5A200' stroke-width='3'%3e%3cpath d='M5 12l5 5L20 7'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:center;background-size:12px}

.product-section{padding:100px 0;background:var(--white)}
.product-section.alt{background:var(--surface)}
.product-section.dark{background:var(--navy);color:#fff;position:relative;overflow:hidden}
.product-section.dark::before{content:"";position:absolute;width:600px;height:600px;border-radius:50%;border:1px solid rgba(255,255,255,.06);left:-260px;top:-200px;pointer-events:none}
.product-section .ps-eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--blue);font-weight:700;margin-bottom:18px}
.product-section .ps-eyebrow::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--orange)}
.product-section.dark .ps-eyebrow{color:var(--orange)}
.product-section h2{font-family:'Barlow Semi Condensed',sans-serif;font-weight:800;letter-spacing:-.025em;font-size:clamp(36px,4.6vw,64px);line-height:.95;color:var(--navy);max-width:18ch}
.product-section.dark h2{color:#fff}

.problem-list{margin-top:48px;display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
@media (max-width:760px){.problem-list{grid-template-columns:1fr}}
.problem-list li{list-style:none;padding:22px 24px;background:var(--white);border:1px solid var(--line);border-radius:16px;font-size:15.5px;line-height:1.55;color:var(--navy);position:relative;padding-left:54px}
.product-section.alt .problem-list li{background:var(--white)}
.problem-list li::before{content:"×";position:absolute;left:20px;top:18px;width:22px;height:22px;border-radius:50%;background:rgba(225,90,90,.12);color:#e15a5a;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px;line-height:1}

.solution-list{margin-top:48px;display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
@media (max-width:760px){.solution-list{grid-template-columns:1fr}}
.solution-list .sol{padding:32px 28px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:18px;transition:transform .45s var(--ease),background .35s var(--ease),border-color .35s var(--ease)}
.solution-list .sol:hover{transform:translateY(-4px);background:rgba(29,128,214,.08);border-color:rgba(29,128,214,.35)}
.solution-list .sol .ico{width:38px;height:38px;border-radius:10px;background:var(--orange);color:var(--navy);display:flex;align-items:center;justify-content:center;font-family:'Space Mono',monospace;font-size:14px;font-weight:700;margin-bottom:18px}
.solution-list .sol h4{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:19px;line-height:1.25;color:#fff;letter-spacing:-.01em}
.solution-list .sol p{margin-top:10px;font-size:14.5px;line-height:1.55;color:rgba(255,255,255,.7)}

.deliverables-grid{margin-top:48px;display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:start}
@media (max-width:980px){.deliverables-grid{grid-template-columns:1fr;gap:36px}}
.deliverables-grid .deliv-list{list-style:none;display:flex;flex-direction:column;gap:14px}
.deliverables-grid .deliv-list li{display:flex;align-items:flex-start;gap:14px;padding:18px 20px;background:var(--white);border:1px solid var(--line);border-radius:14px;font-size:16px;color:var(--navy);line-height:1.45;font-weight:500;transition:border-color .25s,transform .25s var(--ease)}
.deliverables-grid .deliv-list li:hover{border-color:var(--blue);transform:translateX(4px)}
.deliverables-grid .deliv-list li::before{content:"→";color:var(--orange);font-weight:700;flex-shrink:0;font-size:18px}

.stack-box{padding:36px 32px;background:var(--white);border:1px solid var(--line);border-radius:20px}
.stack-box .stack-label{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--blue);margin-bottom:18px;display:flex;align-items:center;gap:10px}
.stack-box .stack-label::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--orange)}
.stack-box .stack-tags{display:flex;flex-wrap:wrap;gap:10px}
.stack-box .stack-tags span{padding:8px 14px;background:var(--surface);border:1px solid var(--line);border-radius:100px;font-family:'Space Mono',monospace;font-size:12px;color:var(--navy);font-weight:500}

.product-case{padding:80px 0;background:var(--navy);color:#fff;position:relative;overflow:hidden}
.product-case::before{content:"";position:absolute;width:560px;height:560px;border-radius:50%;border:1px solid rgba(255,255,255,.06);right:-200px;bottom:-200px;pointer-events:none}
.product-case .case-grid{display:grid;grid-template-columns:.7fr 1fr;gap:60px;align-items:center;position:relative;z-index:1}
@media (max-width:880px){.product-case .case-grid{grid-template-columns:1fr;gap:36px}}
.product-case .pc-sector{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--orange);font-weight:700;display:flex;align-items:center;gap:10px;margin-bottom:14px}
.product-case .pc-sector::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--orange)}
.product-case .pc-metric{font-family:'Barlow Semi Condensed',sans-serif;font-weight:800;font-size:clamp(80px,10vw,150px);line-height:.85;letter-spacing:-.04em;color:var(--orange)}
.product-case .pc-metric-label{margin-top:14px;font-family:'Space Mono',monospace;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.7)}
.product-case h3{font-family:'Barlow Semi Condensed',sans-serif;font-weight:800;letter-spacing:-.022em;font-size:clamp(28px,3.4vw,42px);line-height:1.05;color:#fff;margin-bottom:18px}
.product-case p{color:rgba(255,255,255,.78);font-size:16px;line-height:1.65}

.product-cta-bottom{padding:120px 0;background:var(--white);text-align:center}
.product-cta-bottom h2{font-family:'Barlow Semi Condensed',sans-serif;font-weight:800;letter-spacing:-.025em;font-size:clamp(40px,5.6vw,80px);line-height:.95;max-width:18ch;margin:0 auto;color:var(--navy)}
.product-cta-bottom h2 .accent{color:var(--blue)}
.product-cta-bottom p{margin:24px auto 36px;max-width:50ch;color:#3a4a63;font-size:17px}
.product-cta-bottom .cta-row{display:inline-flex;gap:14px;flex-wrap:wrap;justify-content:center}

.related-products{padding:80px 0;background:var(--surface)}
.related-products h3{font-family:'Barlow Semi Condensed',sans-serif;font-weight:800;letter-spacing:-.022em;font-size:clamp(28px,3vw,40px);line-height:1;color:var(--navy);margin-bottom:36px}
.related-products .rp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
@media (max-width:880px){.related-products .rp-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:540px){.related-products .rp-grid{grid-template-columns:1fr}}
.related-products .rp-card{display:flex;flex-direction:column;justify-content:space-between;padding:24px;background:var(--white);border:1px solid var(--line);border-radius:18px;text-decoration:none;color:var(--navy);min-height:170px;transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s var(--ease)}
.related-products .rp-card:hover{transform:translateY(-3px);box-shadow:0 18px 36px -16px rgba(13,30,51,.15);border-color:transparent}
.related-products .rp-card .rp-num{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.22em;color:var(--muted)}
.related-products .rp-card:hover .rp-num{color:var(--orange)}
.related-products .rp-card h4{margin-top:14px;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:16px;line-height:1.3;letter-spacing:-.005em}
.related-products .rp-card .rp-arrow{margin-top:18px;display:inline-flex;align-items:center;gap:6px;font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--blue)}
.related-products .rp-card:hover .rp-arrow{color:var(--blue)}

/* ---------- Chat widget (Alma) ---------- */
.chat-launcher{position:fixed;bottom:24px;right:24px;z-index:150;width:62px;height:62px;border-radius:50%;background:var(--grad);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 18px 40px -12px rgba(29,128,214,.55),0 4px 12px -2px rgba(29,128,214,.4);transition:transform .35s var(--ease),box-shadow .35s var(--ease)}
.chat-launcher:hover{transform:translateY(-3px) scale(1.04);box-shadow:0 24px 50px -14px rgba(29,128,214,.65)}
.chat-launcher::after{content:"";position:absolute;top:6px;right:6px;width:14px;height:14px;border-radius:50%;background:var(--orange);border:2.5px solid var(--white);box-shadow:0 0 0 0 rgba(245,162,0,.55);animation:pulse-chat 2.4s infinite}
@keyframes pulse-chat{0%{box-shadow:0 0 0 0 rgba(245,162,0,.55)}70%{box-shadow:0 0 0 12px rgba(245,162,0,0)}100%{box-shadow:0 0 0 0 rgba(245,162,0,0)}}
.chat-launcher svg{width:26px;height:26px}
.chat-launcher .close-x{display:none}
body.chat-open .chat-launcher .chat-icon{display:none}
body.chat-open .chat-launcher .close-x{display:block}
body.chat-open .chat-launcher::after{display:none}

.chat-panel{position:fixed;bottom:100px;right:24px;z-index:149;width:min(400px, calc(100vw - 48px));height:min(620px, calc(100vh - 130px));background:var(--white);border-radius:24px;box-shadow:0 30px 80px -20px rgba(13,30,51,.35),0 12px 32px -8px rgba(13,30,51,.18);display:flex;flex-direction:column;overflow:hidden;opacity:0;visibility:hidden;transform:translateY(20px) scale(.96);transform-origin:bottom right;transition:opacity .3s var(--ease),visibility .3s var(--ease),transform .35s var(--ease);border:1px solid var(--line)}
.chat-panel.open{opacity:1;visibility:visible;transform:none}
@media (max-width:560px){.chat-panel{right:12px;left:12px;width:auto;bottom:88px;height:calc(100vh - 110px);border-radius:18px}.chat-launcher{bottom:18px;right:18px;width:56px;height:56px}}

.chat-header{padding:20px 22px;background:var(--navy);color:#fff;display:flex;align-items:center;gap:14px;position:relative}
.chat-header .alma-avatar{width:44px;height:44px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;color:#fff;font-family:'Barlow Semi Condensed',sans-serif;font-weight:800;font-size:22px;letter-spacing:-.02em;flex-shrink:0;position:relative}
.chat-header .alma-avatar::after{content:"";position:absolute;bottom:-1px;right:-1px;width:12px;height:12px;border-radius:50%;background:#3fcf6c;border:2px solid var(--navy)}
.chat-header .info{flex:1;min-width:0}
.chat-header .info .name{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:16px;line-height:1.2}
.chat-header .info .status{font-family:'Space Mono',monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-top:3px;display:flex;align-items:center;gap:6px}
.chat-header .info .status::before{content:"";width:5px;height:5px;border-radius:50%;background:#3fcf6c}

.chat-messages{flex:1;overflow-y:auto;padding:22px;display:flex;flex-direction:column;gap:14px;background:var(--surface);scrollbar-width:thin;scrollbar-color:var(--line) transparent}
.chat-messages::-webkit-scrollbar{width:6px}
.chat-messages::-webkit-scrollbar-thumb{background:var(--line);border-radius:100px}

.msg{max-width:88%;animation:msgIn .35s var(--ease)}
@keyframes msgIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.msg.bot{align-self:flex-start}
.msg.user{align-self:flex-end}
.msg .bubble{padding:12px 16px;border-radius:18px;font-size:14.5px;line-height:1.5;color:var(--navy);white-space:pre-wrap;word-wrap:break-word}
.msg.bot .bubble{background:var(--white);border:1px solid var(--line);border-bottom-left-radius:6px}
.msg.user .bubble{background:var(--navy);color:#fff;border-bottom-right-radius:6px}
.msg .bubble strong{font-weight:700;color:var(--navy)}
.msg.user .bubble strong{color:#fff}
.msg .bubble a{color:var(--blue);border-bottom:1px solid rgba(29,128,214,.3)}

.msg.typing .bubble{display:inline-flex;gap:5px;padding:14px 16px}
.msg.typing .bubble span{width:7px;height:7px;border-radius:50%;background:var(--muted);animation:typing 1.2s infinite}
.msg.typing .bubble span:nth-child(2){animation-delay:.15s}
.msg.typing .bubble span:nth-child(3){animation-delay:.3s}
@keyframes typing{0%,60%,100%{transform:translateY(0);opacity:.4}30%{transform:translateY(-5px);opacity:1}}

.chat-suggestions{padding:0 22px 14px;display:flex;flex-wrap:wrap;gap:8px;background:var(--surface);border-top:1px dashed var(--line)}
.chat-suggestions.gone{display:none}
.chat-suggestions .label{width:100%;font-family:'Space Mono',monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);padding:14px 0 4px}
.chat-chip{font-family:'Space Grotesk',sans-serif;font-size:13px;padding:8px 14px;border:1px solid var(--line);border-radius:100px;background:var(--white);color:var(--navy);cursor:pointer;transition:border-color .25s,color .25s,background .25s,transform .25s var(--ease)}
.chat-chip:hover{border-color:var(--blue);color:var(--blue);transform:translateY(-1px)}

.chat-input-row{padding:14px 14px 14px 18px;display:flex;align-items:center;gap:10px;border-top:1px solid var(--line);background:var(--white)}
.chat-input{flex:1;border:none;outline:none;font-family:'Space Grotesk',sans-serif;font-size:14.5px;color:var(--navy);background:transparent;padding:8px 0}
.chat-input::placeholder{color:var(--muted)}
.chat-send{flex-shrink:0;width:38px;height:38px;border-radius:50%;border:none;background:var(--orange);color:var(--navy);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s var(--ease),background .2s,opacity .2s}
.chat-send:hover:not(:disabled){transform:scale(1.06)}
.chat-send:disabled{opacity:.4;cursor:not-allowed;background:var(--line)}
.chat-send svg{width:16px;height:16px;fill:currentColor}

.chat-disclaimer{padding:10px 22px 14px;background:var(--white);font-family:'Space Mono',monospace;font-size:9.5px;letter-spacing:.04em;color:var(--muted);text-align:center;line-height:1.5;border-top:1px solid var(--line)}

/* ---------- Footer ---------- */
footer{padding:80px 0 40px;border-top:1px solid var(--line);background:var(--white)}
.ft-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px}
@media (max-width:880px){.ft-grid{grid-template-columns:1fr 1fr;gap:36px}}
@media (max-width:540px){.ft-grid{grid-template-columns:1fr}}
.ft-grid h6{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--blue);margin-bottom:18px}
.ft-grid ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.ft-grid ul a{font-size:14.5px;color:var(--navy);opacity:.78;transition:opacity .2s,color .2s}
.ft-grid ul a:hover{opacity:1;color:var(--blue)}
.ft-grid p{font-size:14.5px;color:#3a4a63;max-width:34ch;margin-top:14px}
.ft-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px;margin-top:60px;padding-top:28px;border-top:1px solid var(--line)}
.ft-bottom .legal{display:flex;gap:22px;flex-wrap:wrap}
.ft-bottom .legal a{font-size:13px;color:var(--navy);opacity:.6;transition:opacity .2s}
.ft-bottom .legal a:hover{opacity:1}
.ft-bottom small{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;opacity:.55}
.ft-social{display:flex;gap:10px;margin-top:18px}
.ft-social a{width:36px;height:36px;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--navy);transition:border-color .25s,color .25s,background .25s}
.ft-social a:hover{border-color:var(--blue);color:var(--blue);background:var(--surface)}
.ft-social svg{width:16px;height:16px;fill:currentColor}
