:root{
  --font-body:'Barlow',sans-serif;
  --font-display:'Barlow Condensed',sans-serif;
  --font-mono:'Share Tech Mono',monospace;
  --font-min:15px;
  --font-nav:12px;
  --font-footer-col:13px;
  --font-footer-btm:11px;
  --black:#edf1f7;
  --panel:#ffffff;
  --panel2:#ffffff;
  --panel3:#f8fbff;
  --border:#cfd8e6;
  --border2:#bfcadd;
  --blue:#1D4485;
  --blue-mid:#2d5ba8;
  --blue-dim:#152f5c;
  --blue-glow:rgba(29,68,133,.12);
  --white:#0c1522;
  --muted:#5a6b7c;
  --nav-link:#3d5066;
  --text:#283848;
  --green:#27cc70;
  --amber:#f5a623;
  --page-pad:52px;
  --space-xs:8px;
  --space-sm:16px;
  --space-md:24px;
  --space-lg:32px;
  --space-xl:40px;
  --space-2xl:48px;
  --hero-pad-top:120px;
  --hero-pad-bottom:40px;
  --hero-gap:clamp(var(--space-lg),4vw,var(--space-2xl));
  --section-pad-y:104px;
}
@media (max-width:1024px){
  :root{--page-pad:28px;--hero-pad-top:96px;--section-pad-y:72px}
}
@media (max-width:480px){
  :root{--page-pad:18px;--hero-pad-top:80px;--section-pad-y:56px}
}

/* â”€â”€ THEME: light â”€â”€ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
/* Single page scroll: only overflow-x locked; do not set overflow-y on html+body (that often creates double scrollbars) */
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;font-family:var(--font-body);color-scheme:light;overflow-x:hidden}
body{background:var(--black);color:var(--text);font-family:var(--font-body);font-size:16px;line-height:1.65;overflow-x:hidden}
html:has(#site-nav-toggle:checked),body:has(#site-nav-toggle:checked){overflow:hidden}

/* Below .site-nav (200) so fixed mobile drawer/scrim are not covered */
body::after{content:'';position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.025'/%3E%3C/svg%3E");pointer-events:none;z-index:199;opacity:.15}

.grid-bg{position:absolute;inset:0;background:none;pointer-events:none}
.code-body{color:#1a2d40}
.c-cmt{color:#5c6e82}
#site-nav-toggle:checked~.site-nav-panel{
  box-shadow:-8px 0 32px rgba(15,35,55,.12)
}
/* â”€â”€ NAV â”€â”€ */
.site-nav{position:fixed;top:0;left:0;right:0;z-index:200;min-height:0;height:auto;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:var(--space-xs) var(--page-pad);background:rgba(255,255,255,.94);backdrop-filter:blur(14px);border-bottom:1px solid var(--border)}
.nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0;z-index:260;position:relative}
.nav-logo-img{display:block;height:56px;width:auto;max-width:min(440px,82vw);object-fit:contain;object-position:left center;transition:filter .25s ease}
.site-nav-cb{position:absolute;opacity:0;width:0;height:0;pointer-events:none;appearance:none}
.site-nav-burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;padding:10px;margin:0 -6px 0 auto;border:1px solid var(--border2);background:var(--panel2);border-radius:4px;cursor:pointer;z-index:260;position:relative;flex-shrink:0}
.site-nav-burger span{display:block;height:2px;background:var(--white);border-radius:1px;transition:transform .2s,opacity .2s}
#site-nav-toggle:checked~.site-nav-burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
#site-nav-toggle:checked~.site-nav-burger span:nth-child(2){opacity:0}
#site-nav-toggle:checked~.site-nav-burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.site-nav-scrim{display:none}
.site-nav-panel{display:flex;align-items:center;gap:32px;flex:1;justify-content:flex-end;min-width:0}
.site-nav-panel ul{display:flex;gap:clamp(16px,3vw,32px);list-style:none;flex-wrap:wrap;justify-content:flex-end;margin:0;padding:0}
.site-nav-panel ul a{color:var(--nav-link);text-decoration:none;font-size:var(--font-nav);font-weight:500;letter-spacing:.08em;text-transform:uppercase;transition:color .2s}
.site-nav-panel ul a:hover{color:var(--blue-mid)}
.site-nav-panel ul a[aria-current="page"],.site-nav-panel ul a.is-active{color:var(--blue);position:relative}
.site-nav-panel ul a[aria-current="page"]::after,.site-nav-panel ul a.is-active::after{
  content:'';
  position:absolute;
  left:0;
  right:0;
  bottom:-30px; /* sit on nav bottom line */
  height:3px;
  background:var(--blue-mid);
  border-radius:2px;
}
.nav-right{display:flex;gap:12px;align-items:center;flex-shrink:0}
.site-nav .btn-sm{font-size:var(--font-nav)}
@media (max-width:900px){
  /* backdrop-filter creates a containing block; fixed drawer would match nav bar height only */
  .site-nav{backdrop-filter:none;-webkit-backdrop-filter:none;background:rgba(255,255,255,.98)}
  .site-nav-burger{display:flex}
  .site-nav-scrim{display:block;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:240;opacity:0;visibility:hidden;transition:opacity .25s,visibility .25s;cursor:pointer}
  #site-nav-toggle:checked~.site-nav-scrim{opacity:1;visibility:visible}
  .site-nav-panel{
    position:fixed;top:0;right:0;bottom:0;width:min(100%,340px);max-width:100%;
    flex-direction:column;align-items:stretch;justify-content:flex-start;
    padding:calc(56px + var(--space-md)) var(--space-md) var(--space-md);
    background:var(--panel);border-left:1px solid var(--border);
    box-shadow:-8px 0 32px rgba(0,0,0,.4);
    transform:translateX(100%);transition:transform .28s ease;z-index:250;gap:var(--space-md);
    overflow:hidden;
    -webkit-overflow-scrolling:touch
  }
  #site-nav-toggle:checked~.site-nav-panel{
    transform:translateX(0);
    overflow-y:auto;
    overflow-x:hidden
  }
  .site-nav-panel ul{flex-direction:column;flex-wrap:nowrap;align-items:stretch;gap:0;border-top:1px solid var(--border);padding-top:var(--space-sm)}
  .site-nav-panel ul li{border-bottom:1px solid var(--border)}
  .site-nav-panel ul a{display:block;padding:14px 8px;font-size:var(--font-nav)}
  .site-nav-panel ul a[aria-current="page"]::after,.site-nav-panel ul a.is-active::after{
    left:8px;
    right:8px;
    bottom:6px;
    height:2px;
  }
  .nav-right{margin-top:auto;padding-top:var(--space-md);border-top:1px solid var(--border);flex-direction:column;align-items:stretch}
  .nav-right .btn{text-align:center;width:100%}
}
@media (max-width:380px){
  .site-nav-panel{width:100%;border-left:none}
}

/* BUTTONS */
.btn{display:inline-block;text-decoration:none;cursor:pointer;border:none;font-family:var(--font-display);font-weight:700;letter-spacing:.09em;text-transform:uppercase;transition:all .2s}
.btn-sm{font-size:var(--font-min);padding:8px 22px;clip-path:polygon(7px 0%,100% 0%,calc(100% - 7px) 100%,0% 100%)}
.btn-lg{font-size:16px;padding:15px 44px;clip-path:polygon(12px 0%,100% 0%,calc(100% - 12px) 100%,0% 100%)}
.btn-blue{background:var(--blue);color:#fff}
.btn-blue:hover{background:var(--blue-mid);transform:translateY(-2px);box-shadow:0 8px 28px rgba(29,68,133,.28)}
.btn-outline{background:transparent;color:var(--text);border:1px solid var(--border2)}
.btn-outline:hover{border-color:var(--blue-mid);color:var(--blue-mid)}

/* â”€â”€ HERO â”€â”€ */
/* Do not set overflow-x/y on .hero: overflow-x:hidden + overflow-y:visible computes to overflow-y:auto (CSS spec) and creates a second scrollbar. */
.hero{position:relative;min-height:100vh;display:block;padding:var(--hero-pad-top) var(--page-pad) var(--hero-pad-bottom);overflow:visible}
.hero .grid-bg{mask-image:radial-gradient(ellipse 120% 80% at 50% 40%,black 30%,transparent 100%);z-index:0}
.hero-glow{
  position:absolute;
  top:-180px;
  right:-160px;
  width:700px;
  height:700px;
  background:radial-gradient(circle, rgba(29, 68, 133, .09) 0%, transparent 68%);
  pointer-events:none;
  z-index:0;
}
.hero-glow2{
  position:absolute;
  bottom:-100px;
  left:-120px;
  width:500px;
  height:500px;
  pointer-events:none;
  z-index:0;
  background:radial-gradient(circle,rgba(45,91,168,.05) 0%,transparent 68%);
}
.hero-inner{position:relative;z-index:1;max-width:1280px;width:100%;margin:0 auto;display:grid;grid-template-columns:minmax(0,0.95fr) minmax(300px,1.2fr);gap:var(--hero-gap);align-items:start;overflow:visible}
.hero-copy{min-width:0}
.hero-visual{position:relative;min-height:min(580px,62vh);display:flex;align-items:stretch;justify-content:center;align-self:start;margin-top:0;overflow:visible}
.proof-row--hero-full{grid-column:1/-1;width:100%;margin-top:var(--hero-gap)}
.proof-row--hero-full .proof-item{flex:1;min-width:0;text-align:center}
/* No overflow/contain clip — lets the soft glow bleed past the box so edges stay round, not a hard vertical cut */
.hero-canvas-banner{--hc-grid:rgba(29,68,133,0.08);width:100%;max-width:min(760px,100%);min-height:min(560px,58vh);background:transparent;border-radius:0;overflow:visible;position:relative;border:none}
/* Large circular wash behind the diagram: round feather, heavy blur (not clipped to a rectangle) */
.hero-canvas-banner::before{
  content:'';
  position:absolute;
  left:50%;
  top:50%;
  width:min(160vw,980px);
  height:min(160vw,980px);
  max-width:none;
  transform:translate(-50%,-50%) translateZ(0);
  border-radius:50%;
  pointer-events:none;
  z-index:0;
  background:radial-gradient(circle at 50% 50%,rgba(255,255,255,.94) 0%,rgba(255,255,255,.5) 32%,rgba(255,255,255,.14) 58%,rgba(255,255,255,0) 76%);
  filter:blur(44px);
  will-change:filter;
}
.hero-canvas-grid{position:absolute;inset:0;background-image:linear-gradient(var(--hc-grid) 1px,transparent 1px),linear-gradient(90deg,var(--hc-grid) 1px,transparent 1px);background-size:38px 38px;pointer-events:none;z-index:0;opacity:0}
.hero-canvas-wrap{position:absolute;inset:0;width:100%;height:100%;z-index:1}
.hero-canvas-wrap canvas{display:block;width:100%;height:100%;background:transparent}
.hero-canvas-tooltip{position:absolute;pointer-events:none;background:rgba(255,255,255,.98);border:0.5px solid rgba(29,68,133,.35);border-radius:8px;padding:8px 12px;font-size:12px;color:#1D4485;max-width:min(280px,90vw);line-height:1.5;z-index:20;opacity:0;transition:opacity 0.18s;box-shadow:0 4px 24px rgba(15,35,55,.12);font-family:var(--font-body)}
.hero-canvas-tooltip.visible{opacity:1}
.hero-canvas-tooltip strong{display:block;color:#152f5c;font-weight:600;font-size:12px;margin-bottom:3px}
.hero-ai-wrap{position:relative;z-index:1;width:100%;overflow:visible;animation:aiFloat 10s ease-in-out infinite;will-change:transform}
@keyframes aiFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@media (max-width:1024px){
  .nav-logo-img{height:clamp(44px,10vw,56px)}
  .site-nav{padding:8px var(--page-pad)}
  .hero-inner{grid-template-columns:1fr;text-align:center}
  .hero-copy .chip{margin-left:auto;margin-right:auto}
  .hero-lead{margin-left:auto;margin-right:auto}
  .hero-ctas{justify-content:center}
  .proof-row{flex-wrap:wrap;justify-content:center}
  .hero-visual{min-height:min(420px,52vh);margin-top:8px}
  .hero-visual{flex-direction:column}
  .hero-ai-wrap{order:1}
  .proof-row--hero-full{margin-top:var(--space-xl)}
  .proof-row--hero-full .proof-item{text-align:center}
}
@media (prefers-reduced-motion:reduce){
  .hero-ai-wrap{animation:none}
  .chip-dot{animation:none}
  .fu{animation:none!important;opacity:1!important;transform:none!important}
  .marquee-track{animation:none}
}

.chip{display:inline-flex;align-items:center;gap:var(--space-xs);font-family:var(--font-mono);font-size:var(--font-min);color:var(--blue-mid);letter-spacing:.18em;text-transform:uppercase;padding:6px 14px;border:1px solid rgba(29,68,133,.28);background:rgba(29,68,133,.06);margin-bottom:var(--space-md)}
.chip-dot{width:6px;height:6px;border-radius:50%;background:var(--blue-mid);animation:blink 2.2s infinite}
@keyframes blink{0%,100%{opacity:1}55%{opacity:.3}}

.hero h1{font-family:var(--font-display);font-size:clamp(58px,7.5vw,106px);font-weight:900;line-height:.9;letter-spacing:-.01em;text-transform:uppercase;color:var(--white);margin-bottom:var(--space-lg)}
.hero h1 .a{color:var(--blue-mid)}
.hero h1 .d{color:var(--muted);font-weight:400}
.hero-lead{max-width:600px;font-size:18px;font-weight:300;color:var(--text);line-height:1.75;margin-bottom:var(--space-lg)}
.hero-lead strong{color:var(--white);font-weight:500}
.hero-ctas{display:flex;gap:var(--space-sm);flex-wrap:wrap;align-items:center;margin-bottom:0}

.proof-row{display:flex;gap:0;border:1px solid var(--border);background:#fff}
.proof-item{padding:var(--space-md) var(--space-lg);border-right:1px solid var(--border);background:#fff}
.proof-item:last-child{border-right:none}
.proof-num{font-family:var(--font-display);font-size:38px;font-weight:900;color:var(--blue-mid);line-height:1;margin-bottom:4px}
.proof-lbl{font-size:var(--font-min);font-weight:500;text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}

/* â”€â”€ STATS BAR â”€â”€ */
.stats{display:flex;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--panel)}
.stat{flex:1;padding:28px 44px;border-right:1px solid var(--border)}
.stat:last-child{border-right:none}
.stat-n{font-family:var(--font-display);font-size:42px;font-weight:900;color:var(--blue-mid);line-height:1;margin-bottom:4px}
.stat-l{font-size:var(--font-min);font-weight:500;text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}

/* â”€â”€ SECTIONS â”€â”€ */
section{position:relative;padding:var(--section-pad-y) var(--page-pad);z-index:1}
.wrap{max-width:1280px;margin:0 auto;width:100%;box-sizing:border-box}
.sec-tag{font-family:var(--font-mono);font-size:var(--font-min);color:var(--blue-mid);letter-spacing:.2em;text-transform:uppercase;display:flex;align-items:center;gap:10px;margin-bottom:14px}
.sec-tag::after{content:'';flex:0 0 36px;height:1px;background:var(--blue-mid);opacity:.6}
.sec-h{font-family:var(--font-display);font-size:clamp(38px,4.5vw,60px);font-weight:900;text-transform:uppercase;color:var(--white);line-height:.95;margin-bottom:18px}
.sec-h span{color:var(--blue-mid)}
.sec-sub{font-size:17px;color:var(--muted);line-height:1.75;max-width:560px}

/* â”€â”€ WHY AI â”€â”€ */
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);border:1px solid var(--border);margin-top:64px}
.why-card{background:var(--panel2);padding:40px 44px;position:relative;transition:background .25s}
.why-card::before{content:'';position:absolute;top:0;left:0;width:0;height:3px;background:var(--blue-mid);transition:width .4s}
.why-card:hover{background:var(--panel3)}
.why-card:hover::before{width:100%}
.why-num{font-family:var(--font-display);font-size:52px;font-weight:900;color:var(--blue-mid);opacity:.12;line-height:1;margin-bottom:14px}
.why-title{font-family:var(--font-display);font-size:22px;font-weight:700;text-transform:uppercase;color:var(--white);letter-spacing:.04em;margin-bottom:10px}
.why-desc{font-size:var(--font-min);color:var(--muted);line-height:1.7}

/* â”€â”€ SERVICES â”€â”€ */
.services-section{background:var(--panel);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.services-hdr{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:end;margin-bottom:60px}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border)}
.svc-card{background:var(--panel2);padding:32px 28px;position:relative;transition:background .2s;overflow:hidden}
.svc-card::before{content:'';position:absolute;top:0;left:0;width:0;height:3px;background:var(--blue-mid);transition:width .35s}
.svc-card:hover{background:var(--panel3)}
.svc-card:hover::before{width:100%}
.svc-icon{width:40px;height:40px;margin-bottom:18px;color:var(--blue-mid);opacity:.8}
.svc-icon svg{width:100%;height:100%}
.svc-title{font-family:var(--font-display);font-size:19px;font-weight:700;text-transform:uppercase;color:var(--white);letter-spacing:.04em;margin-bottom:10px}
.svc-desc{font-size:var(--font-min);color:var(--muted);line-height:1.65}

/* â”€â”€ AI TOOLS â”€â”€ */
.tools-layout{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start;margin-top:64px}
.tools-list{display:flex;flex-direction:column;gap:2px;background:var(--border);border:1px solid var(--border)}
.tool-row{display:flex;align-items:flex-start;gap:20px;padding:24px 28px;background:var(--panel2);transition:background .2s;position:relative}
.tool-row::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--blue-mid);transform:scaleY(0);transition:transform .3s}
.tool-row:hover{background:var(--panel3)}
.tool-row:hover::before{transform:scaleY(1)}
.tool-badge{flex-shrink:0;min-width:48px;min-height:48px;width:48px;height:48px;background:rgba(29,68,133,.12);border:1px solid rgba(29,68,133,.32);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:var(--font-min);font-weight:700;color:var(--blue-mid);letter-spacing:.04em;clip-path:polygon(6px 0%,100% 0%,calc(100% - 6px) 100%,0% 100%)}
.tool-name{font-family:var(--font-display);font-size:18px;font-weight:700;text-transform:uppercase;color:var(--white);letter-spacing:.04em;margin-bottom:4px}
.tool-desc{font-size:var(--font-min);color:var(--muted);line-height:1.6}

/* CODE WINDOW */
.code-window{background:var(--panel);border:1px solid var(--border);overflow:hidden}
.code-topbar{display:flex;align-items:center;gap:7px;padding:10px 16px;background:var(--panel2);border-bottom:1px solid var(--border)}
.cdot{width:9px;height:9px;border-radius:50%}
.cdot-r{background:#e05c4a;opacity:.75}
.cdot-y{background:var(--amber);opacity:.75}
.cdot-g{background:var(--green);opacity:.75}
.code-title{font-family:var(--font-mono);font-size:var(--font-min);color:var(--muted);letter-spacing:.08em;margin:0 auto}
.code-body{padding:22px 22px;font-family:var(--font-mono);font-size:var(--font-min);line-height:1.85;color:#c9d8e8}
.c-kw{color:#79b8ff}
.c-fn{color:#b392f0}
.c-str{color:#9ecbff}
.c-cmt{color:#3a4e60;font-style:italic}
.c-acc{color:#1D4485}
.c-ok{color:var(--green)}

/* â”€â”€ HOW IT WORKS â”€â”€ */
.how-section{background:var(--panel);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.steps-row{display:grid;grid-template-columns:repeat(4,1fr);margin-top:64px;position:relative;isolation:isolate}
.steps-row::before{content:'';position:absolute;top:27px;left:28px;right:28px;height:2px;background:var(--border);z-index:0}
.steps-track{position:absolute;top:27px;left:28px;width:75%;height:2px;background:linear-gradient(to right,var(--blue),var(--blue-mid));z-index:0}
.step{padding:0 20px 0 0;position:relative;z-index:1}
.step-dot{position:relative;z-index:2;width:54px;height:54px;border:1px solid var(--border2);background:var(--panel2);display:flex;align-items:center;justify-content:center;margin-bottom:26px;clip-path:polygon(12px 0%,100% 0%,calc(100% - 12px) 100%,0% 100%);transition:all .2s}
.step.active .step-dot{
  border-color:var(--blue-mid);
  background:var(--panel3);
  box-shadow:inset 0 0 0 1px rgba(29,68,133,.22)
}
.step-n{font-family:var(--font-display);font-size:20px;font-weight:800;color:var(--muted)}
.step.active .step-n{color:var(--blue-mid)}
.step-title{font-family:var(--font-display);font-size:17px;font-weight:700;text-transform:uppercase;color:var(--white);letter-spacing:.04em;margin-bottom:10px}
.step-desc{font-size:var(--font-min);color:var(--muted);line-height:1.65}

/* â”€â”€ INDUSTRIES â”€â”€ */
.ind-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border);margin-top:60px}
.ind-card{background:var(--panel2);padding:30px 32px;display:flex;align-items:flex-start;gap:16px;transition:background .2s;position:relative}
.ind-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--blue-mid);transform:scaleX(0);transition:transform .3s;transform-origin:left}
.ind-card:hover{background:var(--panel3)}
.ind-card:hover::after{transform:scaleX(1)}
.ind-emoji{font-size:22px;flex-shrink:0;margin-top:2px}
.ind-title{font-family:var(--font-display);font-size:17px;font-weight:700;text-transform:uppercase;color:var(--white);letter-spacing:.04em;margin-bottom:6px}
.ind-desc{font-size:var(--font-min);color:var(--muted);line-height:1.6}

/* â”€â”€ MARQUEE â”€â”€ */
.marquee-wrap{position:relative;z-index:1;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--panel);padding:16px 0;overflow:hidden}
.marquee-track{display:flex;gap:56px;animation:ticker 30s linear infinite;white-space:nowrap}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.m-item{display:flex;align-items:center;gap:9px;font-family:var(--font-mono);font-size:var(--font-min);color:var(--muted);letter-spacing:.14em;text-transform:uppercase;flex-shrink:0}
.m-dot{width:4px;height:4px;border-radius:50%;background:var(--blue-mid);opacity:.6}

/* â”€â”€ CTA â”€â”€ */
.cta-section{text-align:center;padding:var(--section-pad-y) var(--page-pad);border-top:1px solid var(--border);position:relative;overflow:hidden}
.cta-glow{position:absolute;top:-80px;left:50%;transform:translateX(-50%);width:700px;height:400px;background:radial-gradient(ellipse,rgba(29,68,133,.09) 0%,transparent 68%);pointer-events:none}
.cta-section .sec-tag{justify-content:center}
.cta-section .sec-tag::after{display:none}
.cta-section .sec-h{margin:0 auto 18px}
.cta-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-bottom:44px}
.contact-strip{display:flex;justify-content:center;gap:40px;flex-wrap:wrap}
.c-item{display:flex;align-items:center;gap:9px;font-size:var(--font-min);color:var(--muted)}
.c-item a{color:var(--text);text-decoration:none;transition:color .2s}
.c-item a:hover{color:var(--blue-mid)}
.c-item svg{opacity:.45;flex-shrink:0}

/* â”€â”€ FOOTER â”€â”€ */
footer{background:var(--black);border-top:1px solid var(--border);padding:var(--page-pad)}
.footer-inner{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;gap:56px;margin-bottom:44px}
.footer-brand .nav-logo{display:inline-flex;margin-bottom:4px}
.footer-brand .nav-logo-img{height:40px;max-width:280px}
.footer-brand p{font-size:var(--font-min);color:var(--muted);line-height:1.75;margin-top:14px;max-width:265px}
.fc h5{font-family:var(--font-display);font-size:var(--font-footer-col);font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--white);margin-bottom:16px}
.fc ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.fc ul a{color:var(--muted);text-decoration:none;font-size:var(--font-footer-col);transition:color .2s}
.fc ul a:hover{color:var(--blue-mid)}
.footer-btm{max-width:1280px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--border);padding-top:24px;flex-wrap:wrap;gap:12px}
.footer-btm p{font-family:var(--font-mono);font-size:var(--font-footer-btm);color:var(--muted);letter-spacing:.07em}
.footer-btm a{color:var(--muted);text-decoration:none}
.footer-btm a:hover{color:var(--blue-mid)}

@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.fu{opacity:0;animation:fadeUp .75s cubic-bezier(0.22,1,0.36,1) forwards}
.d1{animation-delay:.08s}.d15{animation-delay:.12s}.d2{animation-delay:.18s}.d25{animation-delay:.22s}.d3{animation-delay:.28s}.d4{animation-delay:.36s}.d5{animation-delay:.44s}.d6{animation-delay:.52s}.d7{animation-delay:.6s}.d8{animation-delay:.68s}

/* ── ABOUT PAGE ── */
.site-nav-panel ul a[aria-current="page"]{color:var(--blue)}
.page-hero{
  position:relative;
  isolation:isolate;
  /* Match section + .wrap: horizontal pad on section, not inside .wrap (avoids double inset vs other sections). */
  padding:calc(72px + var(--hero-pad-top)) var(--page-pad) var(--section-pad-y);
  overflow:visible;
  min-height:0
}
.page-hero .grid-bg{z-index:0;mask-image:radial-gradient(ellipse 100% 70% at 50% 20%,black 35%,transparent 100%)}
.page-hero .hero-glow,.page-hero .hero-glow2{z-index:0}
.page-hero>.wrap{
  position:relative;
  z-index:1;
  max-width:1280px;
  margin:0 auto;
  width:100%;
  padding-left:0;
  padding-right:0;
  box-sizing:border-box
}
.page-hero .about-lead{max-width:min(68rem,100%)}
.contact-page-hero .about-lead{max-width:min(44rem,100%);margin-bottom:0}
.page-hero-copy{min-width:0}
.page-hero-copy a{color:var(--blue-mid);text-decoration:none}
.page-hero-copy a:hover{text-decoration:underline}
/* Case study detail: mirror hero top spacing (below nav) with hero bottom + section top combined */
.page-hero:has(+ .case-detail-section){
  padding-bottom:calc(var(--hero-pad-top) - var(--space-md));
}
.page-hero:has(+ .case-detail-section) + .case-detail-section{
  padding-top:var(--space-md);
}
.page-hero:has(+ .case-detail-section) .case-detail-tags{margin-top:var(--space-sm)}
/* Match case-studies: panel band + borders separate hero from body content */
.about-top-split{
  background:var(--panel);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border)
}
.about-top-split-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:clamp(36px,5vw,64px);
  align-items:start
}
.about-top-split-col{min-width:0}
.about-top-split-col--mission{
  border-left:1px solid var(--border);
  padding-left:clamp(28px,4vw,52px)
}
.about-top-split .page-hero-copy .about-lead{max-width:none}
.about-top-split-col--mission .about-block{margin-top:var(--space-md)}
.about-top-split-col--mission .about-block p{color:var(--muted)}
.about-top-split-cta{margin-top:var(--space-xl)}
.page-hero-intro--contact{margin-bottom:clamp(32px,5vw,48px)}
@media (max-width:900px){
  .about-top-split-grid{grid-template-columns:1fr;gap:var(--space-xl)}
  .about-top-split-col--mission{
    border-left:none;
    padding-left:0;
    border-top:1px solid var(--border);
    padding-top:var(--space-xl);
    margin-top:var(--space-md)
  }
}

.about-lead{font-size:18px;line-height:1.75;color:var(--text);max-width:760px;margin-bottom:var(--space-md)}
.about-lead.emph{font-style:italic;color:var(--white);font-weight:500;margin-top:var(--space-lg)}
.about-block{margin-top:var(--space-xl)}
.about-block p{font-size:16px;color:var(--muted);line-height:1.75;margin-bottom:var(--space-md)}
.about-block p:last-child{margin-bottom:0}
.about-h2{font-family:var(--font-display);font-size:clamp(28px,3.5vw,40px);font-weight:800;text-transform:uppercase;color:var(--white);letter-spacing:.04em;margin-bottom:var(--space-md)}
.offer-list{display:grid;grid-template-columns:repeat(2,1fr);gap:10px 40px;margin-top:var(--space-lg);list-style:none;border:1px solid var(--border);background:var(--panel2);padding:28px 32px}
.offer-list li{position:relative;padding-left:20px;color:var(--text);font-size:var(--font-min)}
.offer-list li::before{content:'';position:absolute;left:0;top:0.55em;width:6px;height:6px;background:var(--blue-mid);clip-path:polygon(2px 0,100% 0,calc(100% - 2px) 100%,0 100%)}
.testimonial-card{background:var(--panel2);border:1px solid var(--border);padding:32px 36px;margin-top:var(--space-lg);max-width:760px}
.testimonial-card p{font-size:17px;line-height:1.7;color:var(--text);margin-bottom:var(--space-md)}
.testimonial-card cite{font-style:normal;font-family:var(--font-display);font-weight:700;font-size:var(--font-min);color:var(--white);letter-spacing:.04em;text-transform:uppercase}
.testimonial-card cite span{display:block;font-size:var(--font-min);color:var(--muted);font-weight:500;margin-top:6px;text-transform:none;letter-spacing:0}
.about-stats-wrap{
  width:100%;
  margin-top:48px;
  box-sizing:border-box
}
.about-stats{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1px;
  width:100%;
  margin:0;
  background:var(--border);
  border:1px solid var(--border)
}
.about-stat{background:var(--panel2);padding:clamp(20px,3vw,32px) clamp(14px,2.5vw,28px);text-align:center}
.about-stat .n{font-family:var(--font-display);font-size:clamp(22px,2.8vw,30px);font-weight:900;color:var(--blue-mid);line-height:1.15;margin-bottom:6px}
.about-stat .l{font-size:var(--font-min);text-transform:uppercase;letter-spacing:.1em;color:var(--muted);line-height:1.35}
@media (max-width:900px){.about-stats{grid-template-columns:repeat(2,1fr)}}
@media (max-width:768px){.offer-list{grid-template-columns:1fr}}

/* CONTACT PAGE */
.contact-address-section{
  margin-top:var(--space-xl);
  padding-top:var(--space-xl);
  border-top:1px solid var(--border);
  width:100%;
}
.contact-address-section .contact-address-tag{margin-bottom:var(--space-md)}
.mailbox-label{display:block;font-size:var(--font-min);font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin-bottom:var(--space-xs)}
.mailbox-row--inline{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-sm) var(--space-xl)}
.mailbox-row--inline .mailbox-label{margin-bottom:0;flex-shrink:0}
.contact-form-card>.sec-tag{margin-bottom:var(--space-sm)}
.contact-top-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:var(--hero-gap);align-items:start}
.contact-top-main{min-width:0}
.contact-top-main .sec-h{margin-bottom:var(--space-lg)}
.contact-top-main .sec-tag{margin-bottom:var(--space-md)}
.contact-form-aside{min-width:0}
.contact-form-card{
  background:var(--panel2);border:1px solid var(--border);padding:28px 32px;
  display:flex;flex-direction:column;gap:var(--space-md)
}
.contact-form-card .contact-form-heading{
  font-family:var(--font-display);font-size:clamp(22px,2.5vw,28px);font-weight:800;text-transform:uppercase;letter-spacing:.04em;color:var(--white);margin:0 0 var(--space-xs);line-height:1.15
}
.contact-form-card .contact-form-sub{font-size:var(--font-min);color:var(--muted);line-height:1.65;margin:0 0 var(--space-sm)}
.contact-form-wrap{width:100%;margin:0}
.form-note{font-size:var(--font-min);color:var(--muted);margin-bottom:var(--space-md);line-height:1.6}
.contact-form label{display:block;margin-bottom:0;font-size:var(--font-min);color:var(--text)}
.contact-form>*+*{margin-top:var(--space-md)}
.contact-form .req{color:var(--blue-mid)}
.contact-form .contact-form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md);align-items:start}
@media (max-width:520px){
  .contact-form .contact-form-row{grid-template-columns:1fr}
}
.contact-form input,.contact-form textarea,.contact-form select{width:100%;padding:12px 14px;margin-top:6px;background:var(--panel);border:1px solid var(--border2);color:var(--text);font-family:var(--font-body);font-size:var(--font-min);border-radius:4px}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{outline:none;border-color:var(--blue-mid)}
.contact-form textarea{min-height:140px;resize:vertical;line-height:1.6}
.contact-form .btn{width:100%;text-align:center}
.contact-form .btn:disabled{opacity:.65;cursor:not-allowed;transform:none;pointer-events:none}
.contact-form .btn:disabled:hover{background:var(--blue);box-shadow:none}
.contact-form-msg{
  font-size:var(--font-min);
  line-height:1.5;
  margin-bottom:var(--space-md);
  padding:var(--space-sm) var(--space-md);
  border-radius:4px;
}
.contact-form-msg--success{
  background:rgba(39,204,112,.12);
  border:1px solid rgba(39,204,112,.35);
  color:#146632;
}
.contact-form-msg--error{
  background:rgba(192,57,43,.08);
  border:1px solid rgba(192,57,43,.28);
  color:#8f2418;
}

.contact-offices{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);border:1px solid var(--border);margin-top:0;max-width:920px}
.contact-offices.contact-offices--inline{max-width:none;width:100%}
.contact-office{background:var(--panel2);padding:28px 32px}
.contact-office h3{font-family:var(--font-display);font-size:var(--font-min);font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--blue-mid);margin-bottom:var(--space-md)}
.contact-office p,.contact-office address{font-size:var(--font-min);color:var(--text);line-height:1.75;font-style:normal;margin-bottom:var(--space-sm)}
.contact-office p:last-child{margin-bottom:0}
.contact-office a{color:var(--blue-mid);text-decoration:none}
.contact-office a:hover{text-decoration:underline}
.mailbox-row{margin-top:var(--space-xl);padding:var(--space-md) var(--space-lg);border:1px solid var(--border);background:var(--panel2);max-width:920px}
.mailbox-row--inline{margin-top:var(--space-lg);max-width:none}
.mailbox-row a{font-size:17px;font-weight:500;color:var(--blue-mid);text-decoration:none}
.mailbox-row a:hover{text-decoration:underline}
@media (max-width:1024px){
  .contact-top-grid{grid-template-columns:1fr;gap:var(--space-2xl)}
}
@media (max-width:640px){
  .contact-offices--inline.contact-offices{grid-template-columns:1fr}
}
@media (max-width:768px){
  .contact-offices{grid-template-columns:1fr}
  .contact-form-card{padding:var(--space-md) var(--space-lg)}
  .mailbox-row--inline{flex-direction:column;align-items:flex-start;gap:var(--space-xs)}
}
.about-split-section .about-split-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:var(--hero-gap);
  align-items:start
}
.about-split-col{min-width:0}
.about-split-col .sec-tag{margin-bottom:var(--space-md)}
.about-split-col .sec-h{margin-bottom:var(--space-md)}
.about-split-sub{margin-bottom:var(--space-lg);max-width:none}
.about-split-section .offer-list{margin-top:var(--space-lg)}
.about-split-section .offer-list--split{grid-template-columns:1fr 1fr}
@media (max-width:520px){
  .about-split-section .offer-list--split{grid-template-columns:1fr}
}
.about-split-section .about-form-card-wrap{max-width:none;width:100%;margin-top:var(--space-lg)}
.about-split-section .form-note a{color:var(--blue-mid);text-decoration:none}
.about-split-section .form-note a:hover{text-decoration:underline}
@media (max-width:900px){
  .about-split-section .about-split-grid{grid-template-columns:1fr;gap:var(--space-2xl)}
  .about-split-section .offer-list--split{grid-template-columns:1fr}
}

/* CASE STUDIES PAGE */
.case-studies-section{background:var(--panel);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.case-filter-wrap{margin-bottom:var(--space-xl)}
.case-filter-label{font-family:var(--font-mono);font-size:12px;color:var(--muted);letter-spacing:.14em;text-transform:uppercase;margin-bottom:var(--space-sm);display:block}
.case-filter-bar{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.case-filter-btn{
  font-family:var(--font-body);font-size:12px;font-weight:500;padding:8px 16px;border:1px solid var(--border2);background:var(--panel2);color:var(--text);
  cursor:pointer;border-radius:4px;transition:background .2s,border-color .2s,color .2s
}
.case-filter-btn:hover{border-color:var(--blue-mid);color:var(--blue-mid)}
.case-filter-btn[aria-pressed="true"]{background:rgba(29,68,133,.14);border-color:rgba(29,68,133,.45);color:var(--white)}
.case-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1px;background:var(--border);border:1px solid var(--border)}
.case-card{
  display:flex;flex-direction:column;height:100%;
  background:var(--panel2);padding:28px 26px;position:relative;transition:background .2s;min-height:0
}
.case-card::before{content:'';position:absolute;top:0;left:0;width:0;height:3px;background:var(--blue-mid);transition:width .35s}
.case-card:hover{background:var(--panel3)}
.case-card:hover::before{width:100%}
.case-card[hidden]{display:none!important}
.case-card-title{
  font-family:var(--font-display);font-size:18px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--white);line-height:1.25;margin-bottom:12px
}
.case-card-desc{font-size:var(--font-min);color:var(--text);line-height:1.65;margin:0;opacity:.95;flex:1 1 auto}
.case-card-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:16px}
.case-card-tags span{
  font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;padding:4px 10px;border:1px solid var(--border);background:var(--panel);color:var(--muted);border-radius:3px
}
.case-empty-msg{font-size:var(--font-min);color:var(--muted);padding:var(--space-xl);text-align:center;grid-column:1/-1;display:none}
.case-empty-msg.is-visible{display:block}
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.case-card-title a{color:inherit;text-decoration:none;transition:color .2s}
.case-card-title a:hover{color:var(--blue-mid)}
.case-card-more{margin-top:auto;padding-top:var(--space-md)}
.case-card-link{
  font-size:var(--font-min);font-weight:700;font-family:var(--font-display);letter-spacing:.06em;text-transform:uppercase;
  color:var(--blue-mid);text-decoration:none;display:inline-flex;align-items:center;gap:6px
}
.case-card-link:hover{color:var(--blue);text-decoration:underline}

/* CASE STUDY DETAIL */
.case-detail-back{
  display:inline-block;font-size:var(--font-min);font-weight:600;color:var(--blue-mid);text-decoration:none;margin-bottom:var(--space-md);letter-spacing:.04em
}
.case-detail-back:hover{text-decoration:underline}
.case-detail-section{
  background:var(--panel);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:clamp(24px,4vw,44px) 0 var(--section-pad-y);
}
.case-detail-inner{max-width:1280px;margin:0 auto;padding:0 var(--page-pad)}
.case-detail-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:var(--space-md)}
.case-detail-tags span{
  font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;padding:4px 10px;border:1px solid var(--border);background:var(--panel2);color:var(--muted);border-radius:3px
}
.case-detail-prose{padding-bottom:var(--space-lg)}
/* Consistent inset above first line (e.g. “Customer Profile”) on all case study bodies */
.case-detail-prose.case-detail-legacy{padding-top:clamp(var(--space-md),2.5vw,var(--space-xl))}
.case-detail-prose h2{
  font-family:var(--font-display);font-size:clamp(20px,2.8vw,26px);font-weight:800;text-transform:uppercase;color:var(--white);letter-spacing:.04em;
  margin:var(--space-xl) 0 var(--space-md);line-height:1.15
}
.case-detail-prose h2:first-child{margin-top:0}
.case-detail-prose p{font-size:var(--font-min);color:var(--text);line-height:1.75;margin:0 0 var(--space-md)}
.case-detail-prose ul{margin:0 0 var(--space-md) 1.25rem;padding:0;font-size:var(--font-min);color:var(--text);line-height:1.65}
.case-detail-prose li{margin-bottom:var(--space-xs)}

/* Legacy portfolio HTML (verbatim from global-infonet.com Elementor) */
.case-detail-legacy{overflow-wrap:anywhere;font-size:var(--font-min);color:var(--text);line-height:1.75}
.case-detail-prose.case-detail-legacy img{display:none}
.case-detail-legacy h3{
  font-family:var(--font-display);font-size:clamp(20px,2.6vw,24px);font-weight:800;text-transform:none;letter-spacing:0;
  color:var(--white);margin:var(--space-xl) 0 var(--space-md);line-height:1.2
}
.case-detail-legacy h4,
.case-detail-legacy .case_studies_sub_head{
  font-family:var(--font-display);font-size:clamp(16px,2vw,19px);font-weight:700;text-transform:none;letter-spacing:.02em;
  color:var(--blue-mid);margin:var(--space-md) 0 var(--space-sm);line-height:1.25
}
.case-detail-legacy p,
.case-detail-legacy .case_studies_desc{margin:0 0 var(--space-md);text-align:left}
.case-detail-legacy em{font-style:italic;color:var(--text)}
.case-detail-legacy ul,
.case-detail-legacy ol{margin:0 0 var(--space-md) 1.25rem;padding:0}
.case-detail-legacy ul.list_case_studies,
.case-detail-legacy ul.list_basic{list-style:square}
.case-detail-legacy li{margin-bottom:var(--space-xs)}
.case-detail-legacy a{color:var(--blue-mid);text-decoration:underline;text-underline-offset:2px}
.case-detail-legacy a:hover{color:var(--blue)}
.case-detail-legacy .row{margin:0 0 var(--space-sm)}
.case-detail-legacy .col-md-12{width:100%;padding:0}
/* Global `section { padding: … }` also targets Elementor-export <section> blocks and adds ~--section-pad-y above the first line of copy */
.case-detail-legacy section{padding:0}
.case-detail-legacy > section + section{margin-top:var(--space-xl)}
/* Pull first heading up against section padding (Elementor + plain imports) */
.case-detail-legacy > h4:first-child{margin-top:0}
.case-detail-legacy .elementor-widget-text-editor:first-child .elementor-text-editor > h4:first-child,
.case-detail-legacy .elementor-widget-text-editor:first-child h4:first-child{margin-top:0}
/* Collapse spacer heading blocks left over from WordPress */
.case-detail-legacy h1.elementor-heading-title.elementor-size-large:empty{display:none}
.case-detail-legacy h3:empty{display:none}
.case-detail-legacy h4:empty{display:none}
/* h4 used as vertical spacer: only <br> children (not :empty in the DOM) */
.case-detail-legacy h4:has(> br:first-child):not(:has(> *:not(br))){
  display:none;
  margin:0!important;
  padding:0!important;
  height:0;
  overflow:hidden;
  border:0;
}
/* h4 spacer: sole child is <em> with no nested elements (e.g. <em>&nbsp;</em> — not :empty in DOM) */
.case-detail-legacy h4:has(> em:only-child):not(:has(> em *)){
  display:none;
  margin:0!important;
  padding:0!important;
  height:0;
  overflow:hidden;
  border:0;
}

/* SERVICES PAGE */
.services-detail-section{background:var(--panel);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.services-page-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:1px;
  background:var(--border);
  border:1px solid var(--border)
}
@media (min-width:640px){
  .services-page-grid{grid-template-columns:repeat(2,1fr)}
}
@media (min-width:1100px){
  .services-page-grid{grid-template-columns:repeat(3,1fr)}
}
.service-page-card{
  background:var(--panel2);
  padding:clamp(26px,4vw,36px) clamp(22px,3vw,32px);
  position:relative;
  display:flex;
  flex-direction:column;
  min-height:100%;
  min-width:0;
  transition:background .2s;
  overflow:hidden;
  scroll-margin-top:calc(56px + var(--space-md))
}
.service-page-card::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  width:0;
  height:3px;
  background:var(--blue-mid);
  transition:width .35s
}
.service-page-card:hover{background:var(--panel3)}
.service-page-card:hover::before{width:100%}
.service-page-card .svc-icon{margin-bottom:16px}
.service-page-card .svc-title{margin-bottom:12px}
.service-page-lead{
  font-size:var(--font-min);
  color:var(--text);
  line-height:1.7;
  margin:0 0 var(--space-md)
}
.service-page-list{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  flex-direction:column;
  gap:10px;
  flex:1 1 auto
}
.service-page-list li{
  font-size:var(--font-min);
  color:var(--muted);
  line-height:1.55;
  padding-left:18px;
  position:relative
}
.service-page-list li::before{
  content:'';
  position:absolute;
  left:0;
  top:0.55em;
  width:6px;
  height:6px;
  background:var(--blue-mid);
  clip-path:polygon(2px 0,100% 0,calc(100% - 2px) 100%,0 100%)
}
.service-page-foot{
  margin-top:var(--space-lg);
  padding-top:var(--space-md);
  border-top:1px solid var(--border);
  font-size:var(--font-min);
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.08em
}
.service-page-foot a{color:var(--blue-mid);text-decoration:none}
.service-page-foot a:hover{text-decoration:underline}

/* Responsive layout (home + about) */
.hero{min-height:min(100vh,1200px)}
@media (max-width:1024px){
  .hero{min-height:0}
  .sec-sub{max-width:100%}
}
.stats{flex-wrap:wrap}
@media (max-width:768px){
  .stats{flex-direction:column}
  .stat{flex:none;border-right:none;border-bottom:1px solid var(--border);padding:22px var(--space-md)}
  .stat:last-child{border-bottom:none}
}
.why-grid{grid-template-columns:1fr}
@media (min-width:769px){
  .why-grid{grid-template-columns:1fr 1fr}
}
.services-hdr{grid-template-columns:1fr}
@media (min-width:901px){
  .services-hdr{grid-template-columns:1fr 1fr}
}
.svc-grid{grid-template-columns:1fr}
@media (min-width:600px){
  .svc-grid{grid-template-columns:repeat(2,1fr)}
}
@media (min-width:1000px){
  .svc-grid{grid-template-columns:repeat(3,1fr)}
}
.tools-layout{grid-template-columns:1fr}
@media (min-width:1025px){
  .tools-layout{grid-template-columns:1fr 1fr}
}
@media (max-width:1099px){
  .steps-row{grid-template-columns:1fr;gap:28px}
  .steps-row::before,.steps-track{display:none}
  .step{padding:0}
}
@media (min-width:640px) and (max-width:1099px){
  .steps-row{grid-template-columns:repeat(2,1fr)}
}
.ind-grid{grid-template-columns:1fr}
@media (min-width:640px){
  .ind-grid{grid-template-columns:repeat(2,1fr)}
}
@media (min-width:1000px){
  .ind-grid{grid-template-columns:repeat(3,1fr)}
}
.footer-inner{grid-template-columns:1fr;gap:40px}
@media (min-width:561px){
  .footer-inner{grid-template-columns:repeat(2,1fr)}
}
@media (min-width:900px){
  .footer-inner{grid-template-columns:2.2fr 1fr 1fr 1fr;gap:56px}
}
.proof-row{flex-wrap:wrap}
@media (max-width:640px){
  .proof-row{flex-direction:column}
  .proof-item{border-right:none;border-bottom:1px solid var(--border)}
  .proof-item:last-child{border-bottom:none}
}
@media (max-width:480px){
  .btn-lg{font-size:var(--font-min);padding:14px 28px}
  .hero-ctas{flex-direction:column;align-items:stretch}
  .hero-ctas .btn{text-align:center}
  .cta-section{padding:var(--section-pad-y) var(--page-pad)}
  .cta-btns{flex-direction:column;align-items:center}
  .cta-btns .btn{max-width:100%;width:100%;max-width:360px}
  .contact-strip{flex-direction:column;align-items:center;gap:20px}
  .chip{font-size:var(--font-min);padding:6px 12px;letter-spacing:.14em}
}
.code-body{overflow-x:auto;-webkit-overflow-scrolling:touch}
@media (max-width:768px){
  .why-card,.svc-card{padding:28px 22px}
  .tool-row{padding:20px 18px}
  .ind-card{padding:24px 20px}
  .testimonial-card{padding:24px 22px}
  .page-hero{padding-top:calc(56px + var(--hero-pad-top))}
  .about-stat .n{font-size:clamp(18px,5vw,26px)}
}

/* ── BLOG (list + article) ── */
.blog-list-section{background:var(--panel);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.blog-feature-banner{
  display:grid;
  grid-template-columns:minmax(0,3fr) minmax(0,7fr);
  gap:0;
  margin-top:0;
  border:1px solid var(--border);
  background:var(--panel2);
  min-height:min(320px,70vw);
  align-items:stretch;
  overflow:hidden;
}
.blog-feature-main{
  padding:clamp(24px,4vw,40px) clamp(22px,3.5vw,36px);
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:var(--space-md);
  min-width:0;
  background:var(--panel);
  border-right:1px solid var(--border);
}
.blog-feature-title{
  font-family:var(--font-display);
  font-size:clamp(17px,2.1vw,22px);
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.04em;
  line-height:1.2;
  margin:0;
}
.blog-feature-title a{color:var(--white);text-decoration:none;transition:color .2s}
.blog-feature-title a:hover{color:var(--blue-mid)}
.blog-feature-desc{
  font-size:var(--font-min);
  color:var(--muted);
  line-height:1.65;
  margin:0;
}
.blog-feature-tags{display:flex;flex-wrap:wrap;gap:6px}
.blog-feature-tags span{
  font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;
  padding:4px 10px;border:1px solid var(--border);background:var(--panel2);color:var(--muted);border-radius:3px
}
.blog-feature-cta{margin:0;margin-top:auto;padding-top:4px}
.blog-feature-cta-link{
  font-family:var(--font-display);
  font-size:var(--font-min);
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--blue-mid);
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  gap:6px;
}
.blog-feature-cta-link:hover{color:var(--blue);text-decoration:underline}
.blog-feature-visual{
  position:relative;
  background:linear-gradient(145deg,#dce4ee 0%,#c9d4e3 45%,#dfe8f2 100%);
  min-height:220px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:clamp(16px,3vw,32px);
  overflow:hidden;
}
.blog-feature-poster{
  margin:0;
  padding:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:0.02em;
  text-align:center;
  line-height:0.88;
  transform:translateZ(0);
}
.blog-feature-poster-line{
  display:block;
  font-family:var(--font-display);
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:-0.02em;
  color:var(--blue);
  opacity:.18;
  font-size:clamp(42px,9vw,min(7.5vw,120px));
  white-space:nowrap;
  user-select:none;
  pointer-events:none;
}
@media (max-width:720px){
  .blog-feature-banner{grid-template-columns:1fr;border-right:none}
  .blog-feature-main{border-right:none;border-bottom:1px solid var(--border)}
  .blog-feature-poster-line{font-size:clamp(36px,14vw,72px)}
}
.blog-article-hero{
  position:relative;
  text-align:center;
  padding:clamp(28px,5vw,48px) var(--page-pad) clamp(36px,6vw,56px);
  background:linear-gradient(165deg,var(--blue-dim) 0%,#0a1628 100%);
  color:var(--black);
  overflow:hidden;
}
.blog-article-hero::before{
  content:'';
  position:absolute;
  inset:0;
  background:repeating-linear-gradient(-45deg,transparent,transparent 40px,rgba(255,255,255,.02) 40px,rgba(255,255,255,.02) 41px);
  pointer-events:none;
}
.blog-article-hero-inner{position:relative;z-index:1;max-width:720px;margin:0 auto}
.blog-article-tag{
  display:inline-block;
  font-family:var(--font-mono);
  font-size:11px;
  font-weight:600;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--green);
  border:1px solid rgba(39,204,112,.45);
  padding:6px 14px;
  border-radius:2px;
  margin-bottom:var(--space-lg);
}
.blog-article-hero h1{
  font-family:var(--font-display);
  font-size:clamp(26px,4.2vw,48px);
  font-weight:900;
  line-height:1.12;
  text-transform:none;
  letter-spacing:-.02em;
  color:var(--black);
  margin:0 0 var(--space-md);
}
.blog-article-sub{
  font-size:17px;
  color:rgba(237,241,247,.72);
  max-width:560px;
  margin:0 auto var(--space-lg);
  font-style:italic;
  font-weight:300;
  line-height:1.65;
}
.blog-article-meta{
  font-size:13px;
  color:rgba(237,241,247,.45);
  letter-spacing:.06em;
  margin:0;
}
.blog-article-wrap{
  max-width:1280px;
  margin:0 auto;
  padding:0 var(--page-pad) var(--section-pad-y);
}
.blog-prose{font-size:16.5px;color:var(--text);line-height:1.8}
.blog-prose>p{margin:0 0 20px}
.blog-prose .blog-lead{
  font-size:18px;
  font-weight:400;
  font-style:italic;
  color:var(--text);
  line-height:1.7;
  border-left:3px solid var(--blue-mid);
  padding:var(--space-lg) var(--space-lg);
  margin:clamp(32px,5vw,48px) 0 var(--space-xl);
  background:rgba(29,68,133,.06);
  border-radius:0 6px 6px 0;
}
.blog-prose h2{
  font-family:var(--font-display);
  font-size:clamp(22px,2.8vw,28px);
  font-weight:800;
  text-transform:none;
  letter-spacing:.02em;
  color:var(--white);
  margin:var(--space-2xl) 0 var(--space-md);
  line-height:1.25;
}
.blog-prose em{color:inherit}
.blog-callout{
  background:var(--blue-dim);
  color:rgba(237,241,247,.92);
  border-radius:8px;
  padding:var(--space-lg) var(--space-xl);
  margin:var(--space-xl) 0;
  border:1px solid rgba(29,68,133,.5);
}
.blog-callout p{color:rgba(237,241,247,.88);font-size:15.5px;margin:0;line-height:1.75}
.blog-callout strong{color:var(--green);font-weight:600}
.blog-role-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(160px,1fr));
  gap:12px;
  margin:var(--space-xl) 0;
}
.blog-role-card{
  background:var(--panel2);
  border:1px solid var(--border);
  border-radius:8px;
  padding:var(--space-md);
  text-align:center;
}
.blog-role-icon{font-size:24px;margin-bottom:8px}
.blog-role-title{
  font-family:var(--font-display);
  font-size:14px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.04em;
  color:var(--white);
  margin-bottom:4px;
}
.blog-role-note{font-size:12px;color:var(--muted);font-style:italic;line-height:1.45}
.blog-stat-strip{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1px;
  background:var(--border);
  border-radius:8px;
  overflow:hidden;
  margin:var(--space-xl) 0;
  border:1px solid var(--border);
}
.blog-stat-cell{background:var(--panel3);padding:20px;text-align:center}
.blog-stat-num{
  font-family:var(--font-display);
  font-size:clamp(26px,4vw,32px);
  font-weight:900;
  color:var(--blue-mid);
  display:block;
  line-height:1;
  margin-bottom:6px;
}
.blog-stat-label{font-size:12px;color:var(--muted);letter-spacing:.05em;line-height:1.35}
.blog-prose blockquote.blog-quote{
  font-family:var(--font-display);
  font-size:clamp(18px,2.5vw,22px);
  font-style:italic;
  font-weight:500;
  color:var(--white);
  border-top:2px solid var(--blue-mid);
  border-bottom:2px solid var(--blue-mid);
  padding:var(--space-lg) var(--space-sm);
  margin:var(--space-2xl) 0;
  text-align:center;
  line-height:1.5;
}
.blog-warning-box{
  background:rgba(245,166,35,.08);
  border:1px solid rgba(245,166,35,.35);
  border-left:4px solid var(--amber);
  border-radius:6px;
  padding:20px var(--space-lg);
  margin:var(--space-xl) 0;
}
.blog-warning-label{
  font-size:11px;
  font-weight:600;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:#b8730a;
  margin-bottom:8px;
}
.blog-warning-box p{font-size:15px;color:var(--text);margin:0;line-height:1.65}
.blog-closing{
  background:var(--blue-dim);
  color:rgba(237,241,247,.88);
  border-radius:10px;
  padding:clamp(28px,4vw,40px) clamp(24px,4vw,36px);
  margin-top:var(--space-2xl);
  text-align:center;
  border:1px solid rgba(29,68,133,.45);
}
.blog-closing h2{
  color:var(--green);
  font-size:clamp(20px,2.5vw,24px);
  margin:0 0 var(--space-md);
}
.blog-closing p{color:rgba(237,241,247,.75);font-size:15.5px;max-width:500px;margin:0 auto;line-height:1.7}
.blog-prose hr{border:none;border-top:1px solid var(--border);margin:var(--space-xl) 0}
@media (max-width:520px){
  .blog-stat-strip{grid-template-columns:1fr}
  .blog-stat-cell{padding:16px}
  .blog-role-grid{grid-template-columns:1fr 1fr}
}
.page-hero:has(+ .blog-article-band){
  padding-bottom:calc(var(--hero-pad-top) - var(--space-md));
}
.page-hero:has(+ .blog-article-band) + .blog-article-band{padding-top:var(--space-md)}
.blog-article-band{
  background:var(--panel);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.blog-page-title.sec-h{text-transform:none;letter-spacing:-.02em;line-height:1.12;font-size:clamp(28px,4vw,52px)}
.blog-page-hero-lead{font-style:italic;color:var(--muted);max-width:560px;margin-bottom:var(--space-md)!important}
.blog-page-meta{font-size:13px;color:var(--muted);letter-spacing:.06em;margin:0;line-height:1.6}

/* ── Privacy policy (legal doc) ── */
.privacy-doc-band{
  background:var(--panel);
  border-top:1px solid var(--border);
  padding-bottom:var(--section-pad-y);
}
.doc-layout{
  display:grid;
  grid-template-columns:minmax(0,220px) minmax(0,1fr);
  gap:0;
  max-width:1280px;
  margin:0 auto;
  padding:0 var(--page-pad);
  box-sizing:border-box;
}
.privacy-toc{
  padding:clamp(28px,4vw,44px) 0;
  position:sticky;
  top:72px;
  align-self:start;
  max-height:calc(100vh - 80px);
  overflow-y:auto;
}
.privacy-toc-label{
  font-family:var(--font-mono);
  font-size:10px;
  color:var(--muted);
  letter-spacing:.2em;
  text-transform:uppercase;
  margin-bottom:var(--space-md);
  padding-bottom:10px;
  border-bottom:1px solid var(--border);
}
.privacy-toc ul{list-style:none;display:flex;flex-direction:column;gap:2px;margin:0;padding:0}
.privacy-toc ul a{
  display:flex;
  align-items:center;
  gap:9px;
  font-size:13px;
  color:var(--muted);
  text-decoration:none;
  padding:7px 0 7px 12px;
  letter-spacing:.02em;
  transition:color .2s,border-color .2s;
  border-left:2px solid transparent;
}
.privacy-toc ul a:hover{color:var(--blue-mid);border-left-color:var(--blue-mid)}
.privacy-toc-num{font-family:var(--font-mono);font-size:10px;opacity:.55}
.privacy-doc-content{
  padding:clamp(28px,4vw,44px) 0 clamp(28px,4vw,44px) clamp(24px,4vw,52px);
  border-left:1px solid var(--border);
  min-width:0;
}
.privacy-doc-section{margin-bottom:clamp(40px,5vw,56px);scroll-margin-top:96px}
.privacy-doc-section:last-child{margin-bottom:0}
.privacy-doc-h2{
  font-family:var(--font-display);
  font-size:clamp(22px,2.8vw,30px);
  font-weight:800;
  text-transform:uppercase;
  color:var(--white);
  line-height:1.15;
  margin-bottom:var(--space-md);
  letter-spacing:.02em;
}
.privacy-doc-h2 span{color:var(--blue-mid)}
.privacy-doc-section > .sec-tag{margin-bottom:12px}
.privacy-doc-section .sec-tag::after{flex:0 0 28px}
.privacy-doc-content p{
  font-size:var(--font-min);
  color:var(--text);
  line-height:1.78;
  margin:0 0 14px;
}
.privacy-doc-content p:last-child{margin-bottom:0}
.privacy-doc-p-mt{margin-top:20px!important}
.privacy-doc-strong{color:var(--white);font-weight:600}
.privacy-doc-list{
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:8px;
  margin:14px 0;
  padding:0;
}
.privacy-doc-list li{
  display:flex;
  align-items:flex-start;
  gap:12px;
  font-size:var(--font-min);
  color:var(--text);
  line-height:1.65;
}
.privacy-doc-list li::before{
  content:'';
  flex-shrink:0;
  margin-top:9px;
  width:5px;
  height:5px;
  background:var(--blue-mid);
  clip-path:polygon(50% 0%,100% 50%,50% 100%,0% 50%);
  opacity:.75;
}
.privacy-info-box{
  background:var(--panel2);
  border:1px solid var(--border);
  border-left:3px solid var(--blue-mid);
  padding:20px 24px;
  margin:24px 0;
}
.privacy-info-box p{font-size:14px;color:var(--muted);margin:0;line-height:1.65}
.privacy-info-box strong{color:var(--text);font-weight:600}
.privacy-data-table{
  width:100%;
  border-collapse:collapse;
  margin:24px 0;
  font-size:13.5px;
}
.privacy-data-table th{
  font-family:var(--font-display);
  font-size:12px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.1em;
  color:var(--muted);
  text-align:left;
  padding:10px 16px;
  border-bottom:1px solid var(--border);
  border-top:1px solid var(--border);
  background:var(--panel2);
}
.privacy-data-table td{
  padding:12px 16px;
  border-bottom:1px solid var(--border);
  color:var(--text);
  vertical-align:top;
  line-height:1.6;
}
.privacy-data-table td:first-child{color:var(--white);font-weight:500;white-space:nowrap}
.privacy-data-table tr:last-child td{border-bottom:none}
.privacy-data-table tbody tr:hover td{background:rgba(29,68,133,.04)}
.privacy-doc-divider{height:1px;background:var(--border);margin:clamp(36px,5vw,52px) 0}
.privacy-doc-content a{color:var(--blue-mid);text-decoration:none}
.privacy-doc-content a:hover{text-decoration:underline}
.privacy-contact-callout{
  background:var(--panel2);
  border:1px solid var(--border);
  padding:28px 32px;
  display:flex;
  align-items:flex-start;
  gap:20px;
  margin-top:var(--space-md);
}
.privacy-callout-icon{
  flex-shrink:0;
  width:40px;
  height:40px;
  background:rgba(29,68,133,.1);
  border:1px solid rgba(29,68,133,.28);
  display:flex;
  align-items:center;
  justify-content:center;
  clip-path:polygon(6px 0%,100% 0%,calc(100% - 6px) 100%,0% 100%);
}
.privacy-contact-callout h4{
  font-family:var(--font-display);
  font-size:16px;
  font-weight:700;
  text-transform:uppercase;
  color:var(--white);
  letter-spacing:.06em;
  margin-bottom:6px;
}
.privacy-contact-callout p{font-size:13.5px;color:var(--muted);margin:0;line-height:1.65}
@media (max-width:900px){
  .doc-layout{grid-template-columns:1fr;padding:0 var(--page-pad)}
  .privacy-toc{display:none}
  .privacy-doc-content{padding:var(--space-lg) 0;border-left:none}
}
