/* ============================================================
   LAGARY — lagary.com · 2026 redesign
   Design language from the Lagary Company Brochure 2026:
   · Space Grotesk (display) · IBM Plex Sans (body) · IBM Plex Mono (labels)
   · ink / blue / sky palette · navy radial covers · editorial hairlines
   ============================================================ */

:root{
  --ink:#091627;
  --ink2:#2c3a52;
  --muted:#6b7a93;
  --faint:#9aa8bf;
  --blue:#1957e6;
  --blue-d:#0e3aa8;
  --blue-l:#4c8dff;
  --sky:#eaf1ff;
  --sky2:#f4f8ff;
  --line:#dbe3f0;
  --line-d:#c3cfe2;
  --paper:#ffffff;
  --navy:#0d1b56;
  --navy-2:#2645cc;
  --green:#46d39a;
  --green-d:#1aa46a;
  --amber:#ffb454;

  --font-display:"Space Grotesk",sans-serif;
  --font-body:"IBM Plex Sans",system-ui,sans-serif;
  --font-mono:"IBM Plex Mono",monospace;

  --container:1200px;
  --pad-x:clamp(20px,4vw,44px);
  --header-h:74px;

  /* liquid glass (Vadik Matveev recipe) */
  --c-glass:#bbbbbc;
  --c-light:#fff;
  --c-dark:#000;
  --glass-reflex-light:1;
  --glass-reflex-dark:1;
  --saturation:150%;
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  background:var(--paper);
  font-family:var(--font-body);
  color:var(--ink2);
  font-size:16px;
  line-height:1.62;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
/* dark-hero pages: the page background continues the hero gradient, so it reads as
   one piece with the hero through the iOS safe-area / overscroll */
body.has-dark-hero{background:radial-gradient(120% 90% at 78% 8%,var(--navy-2) 0%,var(--navy) 58%) var(--navy);}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
ul{list-style:none;}
button{font:inherit;border:0;background:none;cursor:pointer;}
::selection{background:var(--blue);color:#fff;}

h1,h2,h3,h4{
  font-family:var(--font-display);
  color:var(--ink);
  font-weight:600;
  line-height:1.06;
  letter-spacing:-.02em;
}

.container{max-width:var(--container);margin:0 auto;padding-left:var(--pad-x);padding-right:var(--pad-x);}

/* ------------------------------------------------------------
   Editorial primitives (brochure language)
   ------------------------------------------------------------ */
.kicker{
  font-family:var(--font-mono);
  font-size:11.5px;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--blue);
  font-weight:500;
  display:flex;
  align-items:center;
  gap:12px;
}
.kicker .n{color:var(--faint);}

/* running head — the brochure's page header strip */
.runhead{
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-family:var(--font-mono);
  font-size:10px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--faint);
  padding-bottom:13px;
  border-bottom:1px solid var(--line);
  margin-bottom:clamp(36px,5vw,60px);
}
.runhead .wm{display:flex;align-items:center;gap:8px;color:var(--ink);font-weight:600;}
.runhead .wm i{display:inline-block;width:5px;height:5px;background:var(--blue);border-radius:50%;}
.dark-sec .runhead{border-color:rgba(255,255,255,.16);color:rgba(255,255,255,.5);}
.dark-sec .runhead .wm{color:#fff;}

.sec{padding:clamp(64px,8vw,112px) 0;}
.sec-title{font-size:clamp(28px,3.6vw,42px);margin-top:14px;max-width:24ch;}
.sec-lead{font-size:clamp(16px,1.5vw,18px);line-height:1.65;color:var(--ink2);margin-top:16px;max-width:64ch;}
.sec-lead b{color:var(--ink);}
.center .sec-title,.center .sec-lead{margin-left:auto;margin-right:auto;}
.center{text-align:center;}
.center .kicker{justify-content:center;}

.bg-sky{background:var(--sky2);}
.bg-white-sky{ background:linear-gradient(180deg,#eef2f9 0%,#fff 260px); }
.bg-full-white{background:var(--paper);}
.rule-top{border-top:1px solid var(--line);}

/* dark navy sections (brochure covers) */
.dark-sec{
  background:radial-gradient(120% 90% at 78% 8%,var(--navy-2) 0%,var(--navy) 58%);
  color:#fff;
  position:relative;
}
.dark-sec.alt{background:radial-gradient(120% 90% at 22% 90%,var(--navy-2) 0%,var(--navy) 58%);}
.dark-sec h1,.dark-sec h2,.dark-sec h3{color:#fff;}
.dark-sec .sec-lead{color:rgba(255,255,255,.8);}
.dark-sec .kicker{color:var(--blue-l);}
.dark-sec .kicker .n{color:rgba(255,255,255,.4);}

/* crosshair ticks */
.tick{position:absolute;width:12px;height:12px;pointer-events:none;}
.tick:before,.tick:after{content:"";position:absolute;background:rgba(255,255,255,.32);}
.tick:before{left:0;top:5.5px;width:12px;height:1px;}
.tick:after{left:5.5px;top:0;width:1px;height:12px;}
.tick.tl{left:24px;top:24px;}
.tick.br{right:24px;bottom:24px;}
.hero-card .tick.tl{top:calc(var(--header-h) + 18px);}

/* ------------------------------------------------------------
   Buttons
   ------------------------------------------------------------ */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  font-family:var(--font-mono);
  font-size:11.5px;
  font-weight:600;
  letter-spacing:.06em;
  text-transform:uppercase;
  padding:15px 24px;
  border-radius:100px;
  transition:all .22s ease;
  white-space:nowrap;
  cursor:pointer;
}
.btn .ar{transition:transform .22s ease;}
.btn:hover .ar{transform:translateX(4px);}
/* primary — deep brand-blue with subtle depth */
.btn-primary{
  border:0;
  color:#fff;
  background:linear-gradient(180deg, var(--blue) 0%, var(--blue-d) 115%);
}
.btn-primary:hover{
  color:#fff;
  transform:translateY(-1px);
  background:linear-gradient(180deg, color-mix(in srgb, var(--blue) 88%, var(--blue-l)) 0%, var(--blue) 115%);
}
/* secondary — context-aware clear glass */
.btn-ghost,.btn-light{
  border:0;
  color:var(--ink);
  background:color-mix(in srgb, #fff 55%, transparent);
  backdrop-filter:blur(10px) saturate(140%);
  -webkit-backdrop-filter:blur(10px) saturate(140%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.85),
    inset 0 0 0 1px rgba(9,22,39,.14),
    0 4px 14px rgba(9,22,39,.08);
}
.btn-ghost:hover,.btn-light:hover{
  color:var(--ink);
  transform:translateY(-1px);
  background:color-mix(in srgb, #fff 72%, transparent);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    inset 0 0 0 1px rgba(9,22,39,.1),
    0 8px 20px rgba(9,22,39,.12);
}
.dark-sec .btn-ghost,.btn-ghost.on-dark,.dark-sec .btn-light{
  color:#fff;
  background:color-mix(in srgb, #fff 18%, transparent);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.55),
    inset 0 0 0 1px rgba(255,255,255,.46),
    inset 0 -7px 12px -8px rgba(0,0,0,.42),
    0 6px 18px rgba(0,0,0,.25);
}
.dark-sec .btn-ghost:hover,.btn-ghost.on-dark:hover,.dark-sec .btn-light:hover{
  color:#fff;
  transform:translateY(-1px);
  background:color-mix(in srgb, #fff 20%, transparent);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.6),
    inset 0 0 0 1px rgba(255,255,255,.32),
    inset 0 -7px 12px -8px rgba(0,0,0,.34),
    0 10px 24px rgba(0,0,0,.3);
}
.btn:active{transform:translateY(0) scale(.985);}

/* ------------------------------------------------------------
   Header
   ------------------------------------------------------------ */
.site-header{
  position:fixed;
  top:0;left:0;right:0;
  z-index:100;
  background:transparent;
  pointer-events:none;
}
.site-header .container{
  pointer-events:auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:26px;
  height:var(--header-h);
  max-width:1320px;
  border:1px solid transparent;
  border-radius:100px;
  background:transparent;
  transition:
    max-width .38s cubic-bezier(.2,.65,.25,1),
    height .3s ease,
    margin .3s ease,
    padding .3s ease,
    border-radius .3s ease,
    background .3s ease,
    border-color .3s ease,
    box-shadow .3s ease;
}
/* scrolled: compact floating glass capsule, centered */
.site-header.scrolled .container{
  position:relative;
  margin-top:12px;
  height:62px;
  max-width:1060px;
  padding-left:24px;
  padding-right:14px;
  border-radius:100px;
  background:rgba(255,255,255,.66);
  backdrop-filter:blur(26px) saturate(140%);
  -webkit-backdrop-filter:blur(26px) saturate(140%);
  border-color:rgba(195,207,226,.55);
  box-shadow:0 4px 30px rgba(0,0,0,.1);
}
.site-header.scrolled .logo img{height:18px;}
/* top shine line, inset to follow the pill curve */
.site-header.scrolled .container::before{
  content:"";position:absolute;top:0;left:38px;right:38px;height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.8),transparent);
}
/* still over a dark section → darker, heavier glass (readability) */
.site-header.scrolled.over-dark .container{
  background:rgba(40,61,158,.66);
  backdrop-filter:blur(30px) saturate(155%);
  -webkit-backdrop-filter:blur(30px) saturate(155%);
  border-color:rgba(255,255,255,.18);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 8px 30px rgba(5,12,40,.3);
}
/* nav CTA steps back to outline while a solid hero CTA is on screen (dark zones) */
.site-header.over-dark .header-cta .btn-primary{
  background:rgba(255,255,255,.05);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.5);
  color:#fff;
}
.site-header.over-dark .header-cta .btn-primary:hover{
  background:rgba(255,255,255,.12);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.7);
  transform:none;
}
.site-header .logo img{height:20px;width:auto;transition:filter .25s ease;}
body.has-dark-hero .site-header:not(.scrolled) .logo img,
.site-header.over-dark .logo img{filter:brightness(0) invert(1);}

.main-nav{display:flex;align-items:center;gap:clamp(16px,2vw,30px);margin-left:auto;}
.main-nav>li{position:relative;}
.main-nav a.nav-link{
  font-family:var(--font-mono);
  font-size:11px;
  font-weight:700;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--muted);
  transition:color .2s ease;
  padding:8px 0;
  display:inline-flex;
  align-items:center;
  gap:7px;
}
.main-nav a.nav-link:hover{color:var(--blue);}
.main-nav a.nav-link.active{color:var(--ink);}
body.has-dark-hero .site-header:not(.scrolled) .main-nav a.nav-link,
.site-header.over-dark .main-nav a.nav-link{color:rgba(255,255,255,.88);}
body.has-dark-hero .site-header:not(.scrolled) .main-nav a.nav-link:hover,
body.has-dark-hero .site-header:not(.scrolled) .main-nav a.nav-link.active,
.site-header.over-dark .main-nav a.nav-link:hover,
.site-header.over-dark .main-nav a.nav-link.active{color:#fff;}
body.has-dark-hero .site-header:not(.scrolled) .main-nav a.nav-link.active,
.site-header.over-dark .main-nav a.nav-link.active{text-shadow:0 0 14px rgba(76,141,255,.5);}
body.has-dark-hero .site-header:not(.scrolled) .btn-ghost,
.site-header.over-dark .btn-ghost{border-color:rgba(255,255,255,.45);color:#fff;}
body.has-dark-hero .site-header:not(.scrolled) .btn-ghost:hover,
.site-header.over-dark .btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.08);color:#fff;}

.caret{display:inline-block;width:7px;height:7px;border-right:1.4px solid currentColor;border-bottom:1.4px solid currentColor;transform:rotate(45deg) translateY(-2px);}

/* products dropdown */
.dropdown{
  position:absolute;
  top:calc(100% + 20px);
  left:50%;
  transform:translate(-50%,8px);
  background:rgba(255,255,255,.97);
  border:1px solid rgba(195,207,226,.55);
  border-radius:20px;
  box-shadow:0 24px 60px rgba(9,22,39,.14);
  padding:10px;
  width:560px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:2px;
  opacity:0;
  visibility:hidden;
  transition:opacity .2s ease,transform .2s ease,visibility .2s ease;
}
/* invisible hover bridge over the gap so the menu stays open while the
   pointer travels from the nav link down to the dropdown */
.dropdown::before{
  content:"";
  position:absolute;
  left:0;right:0;
  top:-26px;
  height:26px;
}
.main-nav li:hover .dropdown,
.main-nav li:focus-within .dropdown{opacity:1;visibility:visible;transform:translate(-50%,0);}
.dropdown a{
  display:flex;align-items:center;gap:12px;
  padding:11px 12px;border-radius:12px;
  transition:background .18s ease;
}
.dropdown a:hover{background:var(--sky2);}
.dropdown .pb{
  width:38px;height:38px;border-radius:20px;background:var(--sky);border:1px solid var(--line);flex:0 0 auto;
  display:flex;align-items:center;justify-content:center;
}
.dropdown .pb img,.dropdown .pb svg{width:20px;height:20px;display:block;}
.dropdown .pn{font-family:var(--font-display);font-weight:600;font-size:14.5px;color:var(--ink);letter-spacing:-.01em;line-height:1.2;}
.dropdown .pr{font-family:var(--font-mono);font-size:9px;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);margin-top:2px;}
/* dropdown over dark sections — match the dark capsule */
.site-header.over-dark .dropdown{
  background:rgba(40,61,158,.97);
  -webkit-backdrop-filter:blur(30px) saturate(155%);
  backdrop-filter:blur(30px) saturate(155%);
  border-color:rgba(255,255,255,.18);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 24px 60px rgba(5,12,40,.4);
}
.site-header.over-dark .dropdown a:hover{background:rgba(255,255,255,.08);}
.site-header.over-dark .dropdown .pn{color:#fff;}
.site-header.over-dark .dropdown .pr{color:rgba(255,255,255,.66);}
.site-header.over-dark .dropdown .pb{background:rgba(255,255,255,.92);border-color:transparent;}

.header-cta{display:flex;align-items:center;gap:clamp(14px,1.8vw,26px);}
.header-cta .btn{padding:11px 18px;font-size:10.5px;}
/* flat header link (like nav items) */
.hdr-link{
  font-family:var(--font-mono);
  font-size:11px;
  font-weight:700;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--muted);
  padding:8px 0;
  transition:color .2s ease;
}
.hdr-link:hover{color:var(--blue);}
body.has-dark-hero .site-header:not(.scrolled) .hdr-link,
.site-header.over-dark .hdr-link{color:rgba(255,255,255,.88);}
body.has-dark-hero .site-header:not(.scrolled) .hdr-link:hover,
.site-header.over-dark .hdr-link:hover{color:#fff;}

/* hamburger */
.nav-toggle{display:none;flex-direction:column;gap:5px;padding:8px;z-index:130;}
.nav-toggle span{display:block;width:24px;height:1.6px;background:var(--ink);transition:all .28s ease;}
body.has-dark-hero .site-header:not(.scrolled) .nav-toggle span,
.site-header.over-dark .nav-toggle span{background:#fff;}
body.nav-open .nav-toggle span{background:#fff!important;}
body.nav-open .nav-toggle span:nth-child(1){transform:translateY(6.6px) rotate(45deg);}
body.nav-open .nav-toggle span:nth-child(2){opacity:0;}
body.nav-open .nav-toggle span:nth-child(3){transform:translateY(-6.6px) rotate(-45deg);}

/* mobile menu */
.mobile-menu{
  position:fixed;inset:0;z-index:120;
  background:radial-gradient(120% 90% at 78% 8%,var(--navy-2) 0%,var(--navy) 58%);
  display:flex;flex-direction:column;justify-content:center;
  padding:90px clamp(28px,8vw,64px) 40px;
  opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease;
  overflow-y:auto;
}
body.nav-open .mobile-menu{opacity:1;visibility:visible;}
body.nav-open{overflow:hidden;}
.mobile-menu .mm-kicker{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.3em;text-transform:uppercase;color:var(--blue-l);margin-bottom:22px;}
.mobile-menu a.mm-link{
  font-family:var(--font-display);
  font-size:clamp(24px,6vw,34px);
  font-weight:600;
  color:#fff;
  letter-spacing:-.02em;
  padding:11px 0;
  border-bottom:1px solid rgba(255,255,255,.12);
  display:flex;align-items:baseline;gap:14px;
}
.mobile-menu a.mm-link .idx{font-family:var(--font-mono);font-size:10.5px;color:var(--blue-l);letter-spacing:.1em;}
.mobile-menu .mm-products{display:grid;grid-template-columns:1fr 1fr;gap:4px 18px;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.12);}
.mobile-menu .mm-products a{font-family:var(--font-display);font-size:15.5px;font-weight:500;color:rgba(255,255,255,.85);padding:7px 0;}
.mobile-menu .mm-foot{margin-top:30px;font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.5);display:flex;flex-direction:column;gap:8px;}
/* menu open: lift the hamburger (now a plain X) above the overlay and drop the white
   bar + logo, so the close control is a bare X exactly where the hamburger was */
body.nav-open .site-header{z-index:130;}
body.nav-open .site-header .container{background:transparent;border-color:transparent;box-shadow:none;}
body.nav-open .site-header .logo{opacity:0;pointer-events:none;}

/* ------------------------------------------------------------
   Page head (interior pages)
   ------------------------------------------------------------ */
.page-head{
  padding:calc(var(--header-h) + clamp(40px,6vw,72px)) 0 clamp(34px,4.5vw,52px);
  border-bottom:1px solid var(--line);
  background:linear-gradient(180deg,var(--sky2),#fff 80%);
}
.crumbs{
  font-family:var(--font-mono);
  font-size:10.5px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--faint);
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:10px;
  margin-bottom:clamp(22px,3.5vw,38px);
}
.crumbs a{color:var(--muted);transition:color .2s;}
.crumbs a:hover{color:var(--blue);}
.crumbs .sep{color:var(--line-d);}
.crumbs .here{color:var(--ink);font-weight:600;}
.page-head h1{font-size:clamp(36px,5vw,58px);letter-spacing:-.03em;margin-top:14px;max-width:22ch;}
.page-head .tagline{
  font-family:var(--font-display);font-weight:500;
  font-size:clamp(17px,1.9vw,22px);color:var(--ink2);
  margin-top:14px;letter-spacing:-.01em;max-width:40ch;line-height:1.3;
}
.page-head-row{display:flex;align-items:flex-end;justify-content:space-between;gap:28px;flex-wrap:wrap;}
.page-head-row .btn{margin-bottom:6px;}

/* ------------------------------------------------------------
   Hero card (homepage) — animated, motion-sites style
   ------------------------------------------------------------ */
.hero-wrap{padding:0;background:var(--navy);}
.hero-card{
  position:relative;
  width:100%;
  border-radius:0;
  background:var(--navy);
  color:#fff;
  overflow:hidden;
  isolation:isolate;
  display:flex;
  flex-direction:column;
  /* true fullscreen — header overlays the hero */
  min-height:100svh;
}
.hero-card .hc-inner{
  flex:1;
  display:flex;
  flex-direction:column;
  padding:calc(var(--header-h) + clamp(16px,3vh,38px)) 0 0;
  position:relative;z-index:3;
}
.hc-inner>.container{flex:1;display:flex;flex-direction:column;width:100%;}
.hc-inner .hero-grid{flex:1;}

/* ambient aurora blobs */
.hc-aurora{position:absolute;border-radius:50%;pointer-events:none;z-index:1;filter:blur(70px);}
.hc-aurora.a1{
  width:46vw;height:46vw;max-width:760px;max-height:760px;
  right:2%;top:7%;
  background:radial-gradient(circle,rgba(46,108,255,.72) 0%,rgba(46,108,255,0) 62%);
}
.hc-aurora.a2{
  width:40vw;height:40vw;max-width:640px;max-height:640px;
  left:-14%;bottom:-30%;
  background:radial-gradient(circle,rgba(25,87,230,.42) 0%,rgba(25,87,230,0) 62%);
}
/* faint technical grid */
.hc-grid{
  position:absolute;inset:-20px;z-index:1;pointer-events:none;
  transform:translate(var(--gx,0px),var(--gy,0px));
  will-change:transform;
  background-image:
    linear-gradient(rgba(255,255,255,.045) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.045) 1px,transparent 1px);
  background-size:54px 54px;
  -webkit-mask-image:radial-gradient(110% 85% at 72% 8%,#000 22%,transparent 72%);
  mask-image:radial-gradient(110% 85% at 72% 8%,#000 22%,transparent 72%);
}
/* flight path */
.hero-card .arc{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:2;}
.hero-card .arc .fp{stroke-dasharray:4 8;}
/* traveling dot — HTML element so it stays a perfect circle */
.fp-dot{
  position:absolute;left:0;top:0;
  width:9px;height:9px;margin:-4.5px 0 0 -4.5px;
  border-radius:50%;
  background:var(--blue-l);
  box-shadow:0 0 0 6px rgba(76,141,255,.16),0 0 16px rgba(76,141,255,.55);
  z-index:2;pointer-events:none;
  opacity:0;transition:opacity .4s ease;
  will-change:transform;
}

.hero-grid{
  display:grid;
  grid-template-columns:minmax(0,.96fr) minmax(0,1.04fr);
  gap:clamp(28px,4.5vw,58px);
  align-items:stretch;
  position:relative;
}
.hero-left{
  display:flex;
  flex-direction:column;
  max-width:600px;
  padding-bottom:clamp(24px,4.5vh,52px);
  position:relative;
  z-index:4;
}
/* proportional spacers — bias the content block slightly above center */
.hero-left .hsp{flex:1 1 0;min-height:10px;}
.hero-left .hsp.t{flex-grow:.55;}
.hero-left .hsp.b{flex-grow:1.25;}
.hero-eyebrow{
  display:flex;
  align-items:center;
  gap:11px;
  font-family:var(--font-mono);
  font-size:18px;
  font-weight:600;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:rgba(255,255,255,.85);
  margin-bottom:10px;
}
.hero-eyebrow #welcome{min-height:1em;}
.tw-caret{
  width:9px;height:17px;background:var(--blue-l);flex:0 0 auto;margin-left:-3px;
  animation:twblink 1s steps(1) infinite;
}
@keyframes twblink{50%{opacity:0;}}
.hero-card h1{
  color:#fff;
  font-size:clamp(38px,4.55vw,68px);
  font-weight:700;
  line-height:.96;
  letter-spacing:-.025em;
  text-transform:uppercase;
  margin-top:0;
}
.hero-card h1 .hl>span{white-space:nowrap;}
.hero-card h1 em{font-style:normal;color:var(--blue-l);}
/* line-mask staggered reveal */
.hl{display:block;overflow:hidden;padding-bottom:.06em;margin-bottom:-.06em;}
.hl>span{display:inline-block;will-change:transform;}
@media (prefers-reduced-motion:no-preference){
  .hl>span{transform:translateY(115%);animation:lineUp .95s cubic-bezier(.2,.65,.25,1) forwards;}
  .hl:nth-child(1)>span{animation-delay:.12s;}
  .hl:nth-child(2)>span{animation-delay:.24s;}
  .hl:nth-child(3)>span{animation-delay:.36s;}
}
@keyframes lineUp{to{transform:none;}}

.hero-desc{
  margin-top:24px;
  max-width:42ch;
  color:rgba(255,255,255,.76);
  font-size:15px;
  line-height:1.7;
  text-shadow: 0 1px 2px rgba(8,18,42,.5);
}
.hero-desc b{color:#fff;font-weight:600;}
.hero-ctas{display:flex;flex-wrap:wrap;align-items:center;gap:clamp(16px,2vw,24px);margin-top:30px;}
/* badge next to the CTA (Vanguard-style) */
.hero-badge{display:flex;align-items:center;gap:13px;}
.hero-badge .hb-ic{
  width:42px;height:42px;border:1px solid rgba(255,255,255,.32);border-radius:50%;
  display:flex;align-items:center;justify-content:center;flex:0 0 auto;
}
.hero-badge .hb-ic svg{width:19px;height:19px;}
.hero-badge .hb-tx{
  font-family:var(--font-mono);font-size:8.5px;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;
  color:rgba(255,255,255,.75);line-height:1.75;
}
/* compact stats row, bottom of the left column */
.hero-mini-stats{
  display:flex;
  justify-content:space-between;
  gap:0;
  padding-top:clamp(16px,2.2vh,26px);
}
.hero-mini-stats .ms{padding-right:clamp(8px,1vw,16px);}
.hero-mini-stats .ms:last-child{padding-right:0;}
.hero-mini-stats .ms+.ms{border-left:1px solid rgba(255,255,255,.16);padding-left:clamp(8px,1vw,16px);}
.hero-mini-stats .ms .v{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(26px,2.7vw,38px);color:#fff;letter-spacing:-.02em;line-height:1;
}
.hero-note{
  font-family:var(--font-mono);
  font-size:8px;
  letter-spacing:.08em;
  color:rgba(255,255,255,.35);
  margin-top:12px;
  line-height:1.6;
  text-align:right;
}
.hero-mini-stats .ms .l{
  font-family:var(--font-mono);font-size:8px;font-weight:600;
  letter-spacing:.1em;text-transform:uppercase;
  color:rgba(255,255,255,.86);text-shadow:0 1px 2px rgba(8,18,42,.5);margin-top:8px;line-height:1.6;white-space:nowrap;
}

/* live status chip */
.hero-live{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--font-mono);font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.75);
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.05);
  border-radius:100px;padding:8px 14px;margin-bottom:22px;
}
.hero-live i{
  width:7px;height:7px;border-radius:50%;background:var(--green);flex:0 0 auto;
  box-shadow:0 0 0 0 rgba(70,211,154,.5);
  animation:pulse 2.2s ease-out infinite;
}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(70,211,154,.5);}
  70%{box-shadow:0 0 0 9px rgba(70,211,154,0);}
  100%{box-shadow:0 0 0 0 rgba(70,211,154,0);}
}

/* trust row under the CTAs */
.hero-trust{
  display:flex;align-items:center;flex-wrap:wrap;gap:10px 18px;
  margin-top:28px;
}
.hero-trust .tl{
  font-family:var(--font-mono);font-size:9px;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.85);
  text-shadow: 0 1px 2px rgba(8,18,42,.5);
  line-height:28px;white-space:nowrap;
}
.hero-trust img{
  height:28px;width:auto;object-fit:contain;display:block;
  filter:brightness(0) invert(1);opacity:.55;transition:opacity .25s ease;
}
.ht-marquee:hover img{opacity:.85;}
.hero-trust img:hover{opacity:1;}
.hero-trust .more{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.1em;color:rgba(255,255,255,.55);white-space:nowrap;}
/* compact sliding strip inside the trust row */
.ht-marquee{
  flex:1;
  min-width:220px;
  max-width:520px;
  overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);
}
.ht-track{
  display:flex;
  align-items:center;
  gap:44px;
  width:max-content;
  padding-left:44px;
}
@media (prefers-reduced-motion:no-preference){
  .ht-track{animation:lmscroll 34s linear infinite;}
  .ht-marquee:hover .ht-track{animation-play-state:paused;}
}
/* reduced motion: a calm, static row of the first five */
@media (prefers-reduced-motion:reduce){
  .ht-track{animation:none;padding-left:0;}
  .ht-track img:nth-child(n+6){display:none;}
}

/* device — entrance handled by .reveal, ambient float + parallax inside */
.hero-visual{position:relative;display:flex;align-items:center;justify-content:center;z-index:3;}
.hv-par{will-change:transform;}
.hv-float{position:relative;}
.hero-visual img.device{
  width:min(700px,128%);
  max-width:none;
  filter:drop-shadow(0 28px 34px rgba(3,10,28,.42));
}
@media (max-width:1320px){
  .hero-visual img.device{width:min(620px,114%);}
}
@media (prefers-reduced-motion:no-preference){
  .hv-float{animation:float 7.5s ease-in-out infinite;}
}
@keyframes float{
  0%,100%{transform:translateY(0) rotate(0deg);}
  50%{transform:translateY(-13px) rotate(.4deg);}
}
/* floating glass cards */
/* liquid-glass cards on the dark hero (Vadik Matveev recipe, dark reflexes) */
.gcard{
  --glass-reflex-light:.45;
  --glass-reflex-dark:2;
  position:absolute;z-index:4;
  border-radius:20px;
  background-color:color-mix(in srgb, var(--c-glass) 14%, transparent);
  backdrop-filter:blur(8px) saturate(var(--saturation));
  -webkit-backdrop-filter:blur(8px) saturate(var(--saturation));
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--c-light) calc(var(--glass-reflex-light) * 10%), transparent),
    inset 1.8px 3px 0px -2px color-mix(in srgb, var(--c-light) calc(var(--glass-reflex-light) * 90%), transparent),
    inset -2px -2px 0px -2px color-mix(in srgb, var(--c-light) calc(var(--glass-reflex-light) * 80%), transparent),
    inset -3px -8px 1px -6px color-mix(in srgb, var(--c-light) calc(var(--glass-reflex-light) * 60%), transparent),
    inset -0.3px -1px 4px 0px color-mix(in srgb, var(--c-dark) calc(var(--glass-reflex-dark) * 12%), transparent),
    inset -1.5px 2.5px 0px -2px color-mix(in srgb, var(--c-dark) calc(var(--glass-reflex-dark) * 20%), transparent),
    inset 0px 3px 4px -2px color-mix(in srgb, var(--c-dark) calc(var(--glass-reflex-dark) * 20%), transparent),
    inset 2px -6.5px 1px -4px color-mix(in srgb, var(--c-dark) calc(var(--glass-reflex-dark) * 10%), transparent),
    0px 1px 5px 0px color-mix(in srgb, var(--c-dark) calc(var(--glass-reflex-dark) * 10%), transparent),
    0px 6px 16px 0px color-mix(in srgb, var(--c-dark) calc(var(--glass-reflex-dark) * 8%), transparent);
  padding:13px 16px;
  max-width:200px;
}
.gcard .gk{font-family:var(--font-mono);font-size:8.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--blue-l);}
.gcard .gv{font-family:var(--font-display);font-weight:600;font-size:16.5px;color:#fff;margin-top:5px;letter-spacing:-.015em;line-height:1.15;}
.gcard .gv.good{color:#5fe0a8;}
.gcard .gd{font-family:var(--font-mono);font-size:7.8px;letter-spacing:.07em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-top:6px;line-height:1.5;}
.gcard.g1{left:-5%;top:11%;}
.gcard.g2{right:-4%;bottom:9%;}
@media (prefers-reduced-motion:no-preference){
  .gcard.g1{animation:gdrift1 6.4s ease-in-out .6s infinite;}
  .gcard.g2{animation:gdrift2 8.2s ease-in-out .2s infinite;}
}
@keyframes gdrift1{
  0%,100%{transform:translateY(0) rotate(0deg);}
  50%{transform:translateY(-14px) rotate(-1.2deg);}
}
@keyframes gdrift2{
  0%,100%{transform:translateY(0) rotate(0deg);}
  50%{transform:translateY(-10px) rotate(1deg);}
}
.hero-stats{
  margin-top:clamp(48px,7vh,84px);
  border-top:1px solid rgba(255,255,255,.16);
  display:grid;
  grid-template-columns:repeat(3,1fr);
}
.hero-stats .hs{padding:30px 30px 38px 40px;border-right:1px solid rgba(255,255,255,.12);}
.hero-stats .hs:first-child{padding-left:0;}
.hero-stats .hs:last-child{border-right:0;padding-right:0;}
.hero-stats .hv{font-family:var(--font-display);font-weight:600;font-size:clamp(24px,2.8vw,34px);color:#fff;letter-spacing:-.02em;line-height:1;}
.hero-stats .hl{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-top:11px;line-height:1.5;}

/* ------------------------------------------------------------
   Logo marquee (under hero)
   ------------------------------------------------------------ */
.logo-marquee{
  background:linear-gradient(180deg,#eef2f9 0%,#fff 100%);
  padding:clamp(20px,5vw,20px) 0 6px;
  overflow:hidden;
  position:relative;
}
.logo-marquee:before,.logo-marquee:after{
  content:"";position:absolute;top:0;bottom:0;width:clamp(60px,12vw,200px);z-index:2;pointer-events:none;
}
.logo-marquee:before{left:0;background:linear-gradient(90deg,#fff,rgba(255,255,255,0));}
.logo-marquee:after{right:0;background:linear-gradient(-90deg,#fff,rgba(255,255,255,0));}
.lm-track{
  display:flex;
  align-items:center;
  gap:clamp(56px,7vw,104px);
  width:max-content;
  padding-left:clamp(56px,7vw,104px);
}
@media (prefers-reduced-motion:no-preference){
  .lm-track{animation:lmscroll 38s linear infinite;}
  .logo-marquee:hover .lm-track{animation-play-state:paused;}
}
@keyframes lmscroll{to{transform:translateX(-50%);}}
.lm-track img{
  height:30px;width:auto;max-width:150px;object-fit:contain;
  filter:grayscale(1);
  opacity:.55;
  transition:opacity .25s ease,filter .25s ease;
}
.lm-track img:hover{filter:none;opacity:1;}

/* ------------------------------------------------------------
   Feature split (image + copy)
   ------------------------------------------------------------ */
.split{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:clamp(34px,5vw,72px);
  align-items:center;
}
.split .lead{font-size:clamp(16.5px,1.6vw,18.5px);line-height:1.65;}
.split .lead b{color:var(--ink);}
.split p+p{margin-top:16px;}

.shot-panel{
  background:linear-gradient(160deg,var(--sky2),var(--sky));
  border:1px solid var(--line);
  border-radius:22px;
  padding:clamp(18px,2.6vw,32px);
  display:flex;
  align-items:center;
  justify-content:center;
}
.shot-panel img{
  width:100%;
  border-radius:14px;
  filter:drop-shadow(0 22px 44px rgba(9,22,39,.18));
}
.shot-panel.bare{background:none;border:0;padding:0;}
.shot-panel.bare img{border-radius:0;filter:drop-shadow(0 26px 50px rgba(9,22,39,.22));}

/* mission quote (brochure) */
.mission{
  background:var(--ink);
  color:#fff;
  padding:28px 32px;
  border-radius:18px;
}
.mission .q{
  font-family:var(--font-display);
  font-size:clamp(17px,1.8vw,21px);
  line-height:1.38;
  font-weight:500;
  letter-spacing:-.01em;
  color:#fff;
}
.mission .by{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--blue-l);margin-top:15px;}

/* ------------------------------------------------------------
   Product index grid (homepage)
   ------------------------------------------------------------ */
.pgrid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  border-top:1px solid var(--line);
  border-left:1px solid var(--line);
  margin-top:clamp(34px,5vw,52px);
}
.pcell{
  border-right:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:30px 30px 30px;
  min-height:228px;
  display:flex;
  flex-direction:column;
  background:#fff;
  position:relative;
  transition:background .2s ease;
}
.pcell:hover{background:var(--sky2);}
.pcell .pb{
  width:52px;height:52px;border-radius:16px;background:var(--sky);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;flex:0 0 auto;
  transition:border-color .2s ease,background .2s ease,transform .2s ease;
}
.pcell .pb img,.pcell .pb svg{width:27px;height:27px;display:block;}
.pcell:hover .pb{border-color:var(--blue-l);background:#fff;transform:translateY(-2px);}
.pcell .pname{font-family:var(--font-display);font-weight:600;font-size:19.5px;color:var(--ink);letter-spacing:-.015em;margin-top:18px;}
.pcell .pdesc{font-size:13px;color:var(--muted);line-height:1.55;margin-top:7px;padding-right:22px;}
.pcell .pnum{
  position:absolute;top:28px;right:28px;
  font-family:var(--font-mono);font-size:9.5px;letter-spacing:.12em;color:var(--faint);
}
.pcell .go{
  position:absolute;right:26px;bottom:26px;
  font-family:var(--font-mono);font-size:16px;color:var(--blue);
  opacity:0;transform:translateX(-6px);
  transition:opacity .22s ease,transform .22s ease;
}
.pcell:hover .go{opacity:1;transform:none;}
/* CTA cells keep an explicit link line */
.pcell .plink{
  font-family:var(--font-mono);font-size:10px;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;color:var(--blue);
  display:inline-flex;align-items:center;gap:8px;margin-top:auto;padding-top:16px;
}
.pcell .plink .ar{transition:transform .2s ease;}
.pcell:hover .plink .ar{transform:translateX(4px);}
.pcell.cta .pdesc{flex:0 0 auto;}

/* ------------------------------------------------------------
   Product tabs (homepage showcase)
   ------------------------------------------------------------ */
.ptabs-wrap{margin-top:clamp(34px,5vw,52px);}
.ptabs{
  display:flex;
  border:1px solid var(--line);
  border-radius:20px 20px 0 0;
  background:var(--sky2);
  overflow-x:auto;
  overflow-y:hidden;
  scrollbar-width:none;
}
.ptabs::-webkit-scrollbar{display:none;}
.ptab{
  flex:1 0 auto;
  padding:16px 18px 14px;
  text-align:center;
  font-family:var(--font-display);
  font-weight:600;
  font-size:13.5px;
  letter-spacing:-.01em;
  color:var(--muted);
  border-right:1px solid var(--line);
  cursor:pointer;
  white-space:nowrap;
  position:relative;
  transition:background .2s ease,color .2s ease;
}
.ptab:last-child{border-right:0;}
.ptab .tn{display:block;font-family:var(--font-mono);font-weight:500;font-size:8.5px;letter-spacing:.14em;color:var(--faint);margin-bottom:5px;}
.ptab:hover{background:#fff;color:var(--ink);}
.ptab.active{background:#fff;color:var(--ink);}
.ptab.active:before{
  content:"";position:absolute;left:-1px;right:-1px;top:-1px;height:2.5px;
  background:var(--blue);border-radius:2px 2px 0 0;
}
.ptab.active .tn{color:var(--blue);}
.ptab.active:after{
  content:"";position:absolute;left:0;right:0;bottom:-1px;height:1px;background:#fff;
}

.ppanels{
  border:1px solid var(--line);
  border-top:0;
  border-radius:0 0 20px 20px;
  background:#fff;
  overflow:hidden;
}
.ppanel{
  display:none;
  position:relative;
  grid-template-columns:minmax(0,.92fr) minmax(0,1.08fr);
  gap:18px clamp(28px,4.5vw,64px);
  align-items:center;
  padding:clamp(28px,4.5vw,52px) clamp(28px,4.5vw,56px) clamp(20px,3vw,28px);
  overflow:hidden;
}
.ppanel.active{display:grid;animation:panelIn .45s cubic-bezier(.2,.65,.25,1);}
@keyframes panelIn{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:none;}}
/* giant ghost product number */
.ppanel .pp-num{
  position:absolute;top:18px;right:30px;
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(54px,6vw,84px);letter-spacing:-.04em;line-height:1;
  color:var(--sky);user-select:none;pointer-events:none;
}
/* staggered entrance of the copy column */
@media (prefers-reduced-motion:no-preference){
  .ppanel.active .pp-copy>*{animation:panelIn .5s cubic-bezier(.2,.65,.25,1) both;}
  .ppanel.active .pp-copy>*:nth-child(1){animation-delay:.04s;}
  .ppanel.active .pp-copy>*:nth-child(2){animation-delay:.1s;}
  .ppanel.active .pp-copy>*:nth-child(3){animation-delay:.16s;}
  .ppanel.active .pp-copy>*:nth-child(4){animation-delay:.22s;}
  .ppanel.active .pp-copy>*:nth-child(5){animation-delay:.28s;}
  .ppanel.active .pp-copy>*:nth-child(6){animation-delay:.34s;}
  .ppanel.active .pp-copy>*:nth-child(7){animation-delay:.4s;}
  .ppanel.active .pp-visual{animation:panelIn .6s cubic-bezier(.2,.65,.25,1) .15s both;}
}
.ppanel .pp-icon{
  width:52px;height:52px;border-radius:16px;background:var(--sky);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;margin-bottom:18px;
}
.ppanel .pp-icon img,.ppanel .pp-icon svg{width:27px;height:27px;display:block;}
.ppanel h3{font-size:clamp(26px,3vw,38px);letter-spacing:-.025em;margin-top:12px;}
.ppanel .pp-tag{
  font-family:var(--font-display);font-weight:500;
  font-size:clamp(16px,1.7vw,19.5px);color:var(--ink2);
  margin-top:10px;letter-spacing:-.01em;line-height:1.3;max-width:32ch;
}
.ppanel .pp-desc{font-size:14.5px;line-height:1.65;color:var(--muted);margin-top:14px;max-width:54ch;}
/* two-column feature list (brochure blist) */
.ppanel .pp-blist{
  display:grid;grid-template-columns:1fr 1fr;gap:11px 22px;
  margin-top:20px;max-width:56ch;
}
.ppanel .pp-blist li{
  position:relative;padding-left:20px;
  font-family:var(--font-display);font-weight:600;
  font-size:13.5px;letter-spacing:-.005em;color:var(--ink);line-height:1.35;
}
.ppanel .pp-blist li:before{
  content:"";position:absolute;left:0;top:5px;width:8px;height:8px;border-radius:2px;background:var(--blue);
}
.ppanel .p-link{
  display:inline-flex;align-items:center;gap:9px;margin-top:24px;
  font-family:var(--font-mono);font-size:10.5px;font-weight:600;
  letter-spacing:.15em;text-transform:uppercase;color:var(--blue);
}
.ppanel .p-link .ar{transition:transform .2s ease;}
.ppanel .p-link:hover .ar{transform:translateX(4px);}
.ppanel .pp-visual{display:flex;align-items:center;justify-content:center;min-width:0;}
.ppanel .ppv-float{position:relative;}
@media (prefers-reduced-motion:no-preference){
  .ppanel .ppv-float{animation:float 8.5s ease-in-out infinite;}
}
.ppanel .pp-visual img{max-height:460px;width:auto;max-width:100%;filter:drop-shadow(0 24px 46px rgba(9,22,39,.16));}
/* floating KPI card on the visual (brochure fcardlet) */
.pp-kpi{
  position:absolute;right:-2%;bottom:6%;
  background:#fff;border:1px solid var(--line);border-radius:16px;
  padding:13px 17px;max-width:200px;
  box-shadow:0 18px 40px rgba(9,22,39,.16);
}
.pp-kpi .fk{font-family:var(--font-mono);font-size:8.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--blue);}
.pp-kpi .fv{font-family:var(--font-display);font-weight:600;font-size:22px;color:var(--ink);margin-top:4px;letter-spacing:-.02em;line-height:1.05;}
.pp-kpi .fv.good{color:var(--green-d);}
.pp-kpi .fd{font-family:var(--font-mono);font-size:8px;color:var(--muted);margin-top:5px;text-transform:uppercase;letter-spacing:.06em;line-height:1.5;}
/* panel footer strip (brochure sum-foot) */
.ppanel .pp-foot{
  grid-column:1/-1;
  display:flex;justify-content:space-between;align-items:center;gap:12px;
  border-top:1px solid var(--line);
  padding-top:15px;margin-top:6px;
  font-family:var(--font-mono);font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);
}

/* ------------------------------------------------------------
   Ecosystem diagram (brochure architecture)
   ------------------------------------------------------------ */
.arch-flow{display:flex;flex-direction:column;margin-top:clamp(32px,4.5vw,48px);}
.arch-lbl{
  font-family:var(--font-mono);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--blue);display:flex;align-items:center;gap:10px;margin-bottom:13px;
}
.arch-lbl .n{color:var(--faint);}
.arch-nav{border:1px solid var(--line);border-radius:20px;background:var(--paper);display:flex;overflow:hidden;}
.arch-nav .idn{flex:0 0 30%;background:var(--ink);color:#fff;padding:24px 28px;display:flex;flex-direction:column;justify-content:center;}
.arch-nav .idn .nn{font-family:var(--font-display);font-weight:600;font-size:clamp(19px,2vw,24px);letter-spacing:-.01em;}
.arch-nav .idn .nr{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--blue-l);margin-top:6px;}
.arch-nav .nbody{flex:1;padding:20px 24px;display:flex;flex-direction:column;justify-content:center;gap:12px;}
.arch-chips{display:flex;flex-wrap:wrap;gap:8px;}
.arch-chip{
  font-family:var(--font-display);font-weight:600;font-size:13px;color:var(--ink);
  background:var(--sky);border:1px solid var(--line);border-radius:100px;padding:7px 13px;letter-spacing:-.01em;
}
.arch-extra{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.06em;color:var(--muted);text-transform:uppercase;}
.arch-extra b{color:var(--blue-d);font-weight:600;}
.arch-feeders{display:grid;grid-template-columns:repeat(4,1fr);gap:11px;margin-top:11px;}
.arch-app{border:1px solid var(--line);border-radius:16px;background:var(--sky2);padding:18px;display:flex;flex-direction:column;gap:9px;transition:all .22s ease;}
.arch-app:hover{border-color:var(--blue-l);transform:translateY(-2px);box-shadow:0 12px 26px rgba(9,22,39,.08);}
.arch-app .badge{width:32px;height:32px;border-radius:100px;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:12px;letter-spacing:-.02em;}
.arch-app .an{font-family:var(--font-display);font-weight:600;font-size:15.5px;color:var(--ink);letter-spacing:-.01em;}
.arch-app .ar{font-family:var(--font-mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);line-height:1.4;}
.arch-conn{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50px;}
.arch-conn .ln{width:1px;flex:1;min-height:14px;background:var(--line-d);}
.arch-conn .cv{color:var(--blue);font-size:13px;line-height:1;margin:2px 0;}
.arch-hub{
  align-self:center;background:var(--ink);border-radius:15px;padding:24px 58px;text-align:center;
  position:relative;box-shadow:0 18px 40px rgba(9,22,39,.26);
}
.arch-hub:before{content:"";position:absolute;inset:6px;border:1px solid rgba(255,255,255,.16);border-radius:10px;pointer-events:none;}
.arch-hub .hn{font-family:var(--font-display);font-weight:700;font-size:clamp(28px,3.2vw,38px);color:#fff;letter-spacing:-.02em;line-height:1;}
.arch-hub .hr{font-family:var(--font-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--blue-l);margin-top:7px;}
.arch-an{border:1px solid var(--line);border-radius:20px;background:linear-gradient(160deg,var(--sky2),var(--sky));overflow:hidden;}
.arch-an .anh{display:flex;flex-wrap:wrap;align-items:baseline;justify-content:space-between;gap:8px;padding:17px 24px;border-bottom:1px solid var(--line);}
.arch-an .anh .at{font-family:var(--font-display);font-weight:600;font-size:19px;color:var(--ink);letter-spacing:-.01em;}
.arch-an .anh .as{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--blue);}
.arch-quads{display:grid;grid-template-columns:repeat(4,1fr);}
.arch-q{padding:18px 22px;border-right:1px solid var(--line);}
.arch-q:last-child{border-right:0;}
.arch-q .qt{font-family:var(--font-display);font-weight:600;font-size:14.5px;color:var(--ink);letter-spacing:-.01em;}
.arch-q .qd{font-family:var(--font-mono);font-size:10px;letter-spacing:.04em;color:var(--blue-d);margin-top:4px;}

/* ------------------------------------------------------------
   Feature cards grid (brochure fgrid)
   ------------------------------------------------------------ */
.fgrid{
  display:grid;grid-template-columns:1fr 1fr;
  border-top:1px solid var(--line);border-left:1px solid var(--line);
  margin-top:clamp(28px,4vw,44px);
}
.fgrid.cols3{grid-template-columns:repeat(3,1fr);}
.fcard{
  border-right:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:24px 26px;background:#fff;transition:background .2s ease;
}
.fcard:hover{background:var(--sky2);}
.fcard .fnum{font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;color:var(--blue);font-weight:600;text-transform:uppercase;}
.fcard .ftt{font-family:var(--font-display);font-weight:600;font-size:16.5px;color:var(--ink);margin:9px 0 7px;letter-spacing:-.01em;}
.fcard p{font-size:13.5px;line-height:1.55;color:var(--muted);}
.fcard .fchk{font-family:var(--font-display);font-weight:700;font-size:15px;color:#1f9d57;}

/* checklist (brochure blist) */
.blist{display:flex;flex-direction:column;gap:13px;}
.blist li{position:relative;padding-left:24px;font-size:14.5px;line-height:1.55;color:var(--ink2);}
.blist li:before{content:"";position:absolute;left:0;top:7px;width:9px;height:9px;border-radius:2px;background:var(--blue);}
.blist li b{font-weight:600;color:var(--ink);}

/* chips */
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:13px;}
.chip{
  font-family:var(--font-mono);font-size:11px;letter-spacing:.03em;color:var(--ink2);
  background:var(--sky2);border:1px solid var(--line);border-radius:100px;padding:8px 13px;
}
.chip-lbl{font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--blue);}

/* lifecycle strip (brochure tloop) */
.tloop{
  display:flex;
  border:1px solid var(--line);
  border-radius:18px;
  overflow:hidden;
  margin-top:18px;
}
.tloop .st{flex:1;padding:16px 17px;border-right:1px solid var(--line);background:var(--sky2);}
.tloop .st:last-child{border-right:0;background:var(--sky);}
.tloop .sn{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.1em;color:var(--blue);font-weight:600;text-transform:uppercase;}
.tloop .sl{font-family:var(--font-display);font-weight:600;font-size:15px;color:var(--ink);letter-spacing:-.01em;margin-top:6px;}
.tloop .sd{font-size:11.5px;color:var(--muted);line-height:1.42;margin-top:5px;}

/* ------------------------------------------------------------
   Product detail page
   ------------------------------------------------------------ */
.pd-hero{padding:clamp(40px,5.5vw,72px) 0 0;}
.pd-hero .shot-panel{max-width:980px;margin:0 auto;}
.pd-hero .shot-panel.bare{max-width:880px;}
.pd-section{padding:clamp(48px,6.5vw,88px) 0;}
.pd-gallery{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:clamp(28px,4vw,44px);}
.pd-gallery .shot-panel{padding:clamp(14px,2vw,24px);}

.glance{
  border:1px solid var(--line);
  border-radius:20px;
  background:var(--sky2);
  padding:clamp(24px,3.5vw,40px);
  display:grid;
  grid-template-columns:minmax(0,.85fr) minmax(0,1.15fr);
  gap:clamp(24px,4vw,56px);
  align-items:start;
}
.glance .gt{font-family:var(--font-display);font-weight:600;font-size:clamp(20px,2.2vw,26px);color:var(--ink);letter-spacing:-.015em;line-height:1.15;max-width:16ch;}
.glance .gk{font-family:var(--font-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--blue);margin-bottom:12px;}

/* CTA panel (replaces old sidebar contact card) */
.cta-panel{
  background:radial-gradient(120% 120% at 80% 0%,var(--navy-2) 0%,var(--navy) 62%);
  border-radius:26px;
  padding:clamp(30px,4.5vw,52px);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:28px;
  flex-wrap:wrap;
  position:relative;
  overflow:hidden;
}
.cta-panel .ck{font-family:var(--font-mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--blue-l);}
.cta-panel h3{color:#fff;font-size:clamp(21px,2.4vw,28px);margin-top:10px;letter-spacing:-.02em;max-width:24ch;}
.cta-panel p{color:rgba(255,255,255,.75);font-size:14px;margin-top:10px;max-width:52ch;line-height:1.6;}
.cta-panel .cta-actions{display:flex;gap:12px;flex-wrap:wrap;}

/* prev / next product nav */
.pnav{
  display:grid;grid-template-columns:1fr 1fr;
  border:1px solid var(--line);border-radius:20px;overflow:hidden;
  margin-top:clamp(28px,4vw,44px);
}
.pnav a{padding:22px 26px;display:flex;flex-direction:column;gap:6px;transition:background .2s ease;}
.pnav a:hover{background:var(--sky2);}
.pnav a+a{border-left:1px solid var(--line);text-align:right;align-items:flex-end;}
.pnav .k{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--faint);}
.pnav .v{font-family:var(--font-display);font-weight:600;font-size:17px;color:var(--ink);letter-spacing:-.01em;}

/* ------------------------------------------------------------
   Browser-window mockup (Qualify dashboard)
   ------------------------------------------------------------ */
.bwin{
  position:relative;width:min(520px,100%);margin:0 auto;
  background:#0c1b35;border:1px solid #35599f;
  border-radius:22px;box-shadow:0 40px 70px rgba(0,0,0,.45);overflow:hidden;
}
.bbar{background:#0e1d38;padding:12px 15px;display:flex;align-items:center;gap:7px;border-bottom:1px solid rgba(255,255,255,.08);}
.bbar .bd{width:9px;height:9px;border-radius:50%;flex:0 0 auto;}
.bbar .burl{
  margin-left:11px;flex:1;background:rgba(255,255,255,.08);border-radius:10px;padding:7px 13px;
  font-family:var(--font-mono);font-size:9.5px;letter-spacing:.05em;color:rgba(255,255,255,.6);
}
.bscreen{background:#f4f7fc;padding:20px;}
.bscreen .bst{display:flex;align-items:baseline;justify-content:space-between;gap:8px;margin-bottom:14px;}
.bscreen .bst .bt{font-family:var(--font-display);font-weight:600;font-size:15.5px;color:var(--ink);letter-spacing:-.01em;}
.bscreen .bst .bsub{font-family:var(--font-mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);}
.kgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}
.ktile{background:#fff;border:1px solid var(--line);border-radius:14px;padding:13px 15px;}
.ktile .kv{font-family:var(--font-display);font-weight:600;font-size:24px;color:var(--ink);letter-spacing:-.02em;line-height:1;}
.ktile .kk{font-family:var(--font-mono);font-size:8.4px;letter-spacing:.09em;text-transform:uppercase;color:var(--muted);margin-top:6px;}
.ktile.accent{background:var(--sky);border-color:var(--blue-l);}
.ktile.accent .kv{color:var(--blue-d);}
.trows{margin-top:14px;display:flex;flex-direction:column;}
.trow{display:flex;align-items:center;gap:12px;padding:11px 2px;border-top:1px solid var(--line);}
.trow .av{
  width:32px;height:32px;border-radius:50%;background:var(--blue);color:#fff;flex:0 0 auto;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-mono);font-size:9.5px;font-weight:600;
}
.trow .av.a2{background:var(--ink);}
.trow .av.a3{background:var(--blue-d);}
.trow .who{flex:1;min-width:0;}
.trow .nm{font-family:var(--font-display);font-weight:600;font-size:13px;color:var(--ink);letter-spacing:-.01em;line-height:1.2;}
.trow .pg{font-family:var(--font-mono);font-size:9px;letter-spacing:.03em;color:var(--muted);margin-top:3px;text-transform:uppercase;}
.trow .sc{
  font-family:var(--font-display);font-weight:700;font-size:13px;border-radius:10px;padding:4px 10px;flex:0 0 auto;
}
.trow .sc.g{background:#dff3e8;color:var(--green-d);}
.trow .sc.y{background:#fff0d6;color:#a06a13;}
.trow .sc.r{background:#ffe3e0;color:#c0392b;}

/* ------------------------------------------------------------
   Clients
   ------------------------------------------------------------ */
.logowall{display:grid;grid-template-columns:repeat(4,1fr);gap:13px;margin-top:clamp(32px,4.5vw,48px);}
.logocell{
  border:1px solid var(--line);border-radius:16px;padding:24px 16px 16px;
  display:flex;flex-direction:column;align-items:center;gap:14px;background:#fff;
  transition:all .22s ease;
}
.logocell:hover{border-color:var(--blue-l);transform:translateY(-2px);box-shadow:0 14px 30px rgba(9,22,39,.08);}
.logocell img{width:auto;max-width:80%;height:36px;object-fit:contain;}
.logocell .cf{
  font-family:var(--font-mono);font-size:9px;letter-spacing:.06em;color:var(--muted);
  text-transform:uppercase;text-align:center;line-height:1.4;
}
.logocell.more{justify-content:center;background:transparent;border-style:dashed;}
.logocell .morebadge{
  display:flex;align-items:center;justify-content:center;height:36px;
  font-family:var(--font-display);font-weight:700;font-size:22px;letter-spacing:-.02em;color:var(--blue-d);
}

/* ------------------------------------------------------------
   News
   ------------------------------------------------------------ */
.news-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:clamp(32px,4.5vw,48px);}
.news-card{
  border:1px solid var(--line);border-radius:20px;overflow:hidden;background:#fff;
  display:flex;flex-direction:column;transition:all .22s ease;
}
.news-card:hover{border-color:var(--blue-l);transform:translateY(-3px);box-shadow:0 18px 38px rgba(9,22,39,.1);}
.news-card .nimg{aspect-ratio:16/10;overflow:hidden;background:var(--sky);}
.news-card .nimg img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease;}
.news-card:hover .nimg img{transform:scale(1.04);}
.news-card .nbody{padding:18px 20px 20px;display:flex;flex-direction:column;gap:10px;flex:1;}
.news-card .nmeta{font-family:var(--font-mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);display:flex;gap:10px;flex-wrap:wrap;}
.news-card .nmeta b{color:var(--blue);font-weight:500;}
.news-card h4{font-size:16px;letter-spacing:-.015em;line-height:1.3;flex:1;}
.news-card .plink{
  font-family:var(--font-mono);font-size:10px;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;color:var(--blue);
  display:inline-flex;align-items:center;gap:8px;
}

/* article page */
.article{max-width:780px;margin:0 auto;}
.article-hero{max-width:980px;margin:clamp(36px,5vw,56px) auto 0;}
.article-hero img{width:100%;border-radius:22px;border:1px solid var(--line);}
.article .meta{
  display:flex;flex-wrap:wrap;gap:10px 22px;
  font-family:var(--font-mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);
  padding-bottom:18px;border-bottom:1px solid var(--line);margin-bottom:clamp(26px,4vw,40px);
}
.article .meta b{color:var(--ink);font-weight:600;}
.article p{font-size:16.5px;line-height:1.75;color:var(--ink2);}
.article p+p{margin-top:20px;}
.article .pull{
  background:var(--sky2);
  border:1px solid var(--line);
  border-left:3px solid var(--blue);
  border-radius:16px;
  padding:24px 28px;
  margin:26px 0;
}
.article .pull p{font-family:var(--font-display);font-size:17.5px;line-height:1.5;color:var(--ink);font-weight:500;letter-spacing:-.005em;}
.article .pull .who{font-family:var(--font-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--blue);margin-top:14px;}

/* ------------------------------------------------------------
   Contact
   ------------------------------------------------------------ */
.contact-grid{
  display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);
  gap:clamp(36px,5.5vw,80px);align-items:start;
}
.cinfo{display:flex;flex-direction:column;gap:26px;margin-top:clamp(26px,4vw,40px);}
.cinfo .ci .ck{font-family:var(--font-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--blue);}
.cinfo .ci .cv{font-family:var(--font-display);font-size:18px;font-weight:500;color:var(--ink);margin-top:7px;line-height:1.45;letter-spacing:-.01em;}
.cinfo .ci .cv a:hover{color:var(--blue);}
.cinfo .ci .cs{font-size:13px;color:var(--muted);margin-top:4px;}

.cform{
  border:1px solid var(--line);
  border-radius:24px;
  background:var(--sky2);
  padding:clamp(26px,3.5vw,40px);
}
.cform h3{font-size:clamp(20px,2.2vw,25px);letter-spacing:-.02em;}
.cform .fsub{font-size:13.5px;color:var(--muted);margin-top:8px;}
.cform .frow{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:14px;}
.cform .frow.single{grid-template-columns:1fr;}
.field input,.field textarea{
  width:100%;
  background:#fff;
  border:1px solid var(--line);
  border-radius:14px;
  padding:15px 16px;
  font-family:var(--font-body);
  font-size:14.5px;
  color:var(--ink);
  transition:border-color .2s ease,box-shadow .2s ease;
}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(25,87,230,.12);}
.field input::placeholder,.field textarea::placeholder{color:var(--faint);}
.field textarea{min-height:140px;resize:vertical;}
.cform .btn{width:100%;margin-top:18px;}
#result{font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--green-d);text-align:center;margin-top:14px;min-height:16px;}

.map-panel{margin-top:clamp(44px,6vw,72px);border:1px solid var(--line);border-radius:22px;overflow:hidden;}
.map-panel iframe{display:block;width:100%;height:440px;border:0;filter:saturate(.82);}

/* ------------------------------------------------------------
   Prose (policy pages)
   ------------------------------------------------------------ */
.prose{max-width:820px;margin:0 auto;}
.prose h2,.prose h3,.prose h4,.prose h5{margin:34px 0 12px;font-size:21px;letter-spacing:-.015em;}
.prose h5{font-size:17px;}
.prose p{margin:0 0 14px;font-size:15px;line-height:1.75;color:var(--ink2);}
.prose ul,.prose ol{margin:0 0 16px;padding-left:22px;}
.prose ul{list-style:disc;}
.prose ol{list-style:decimal;}
.prose li{font-size:15px;line-height:1.7;color:var(--ink2);margin-bottom:6px;}
.prose a{color:var(--blue);text-decoration:underline;text-underline-offset:3px;}
.prose .optech-divider{height:1px;background:var(--line);margin:26px 0;}
.prose table{width:100%;border-collapse:collapse;margin:0 0 18px;font-size:13.5px;}
.prose th,.prose td{border:1px solid var(--line);padding:10px 12px;text-align:left;vertical-align:top;}
.prose th{background:var(--sky2);font-family:var(--font-display);}

/* ------------------------------------------------------------
   404
   ------------------------------------------------------------ */
.err-wrap{
  min-height:calc(100vh - var(--header-h));
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:calc(var(--header-h) + 40px) var(--pad-x) 80px;
  position:relative;overflow:hidden;
}
.err-wrap .code{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(110px,22vw,220px);line-height:1;letter-spacing:-.05em;
  color:var(--ink);
}
.err-wrap .code em{font-style:normal;color:var(--blue);}
.err-wrap h2{font-size:clamp(22px,3vw,30px);margin-top:10px;}
.err-wrap p{color:var(--muted);margin-top:14px;max-width:46ch;}
.err-wrap .btn{margin-top:30px;}
.err-kicker{font-family:var(--font-mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--blue);margin-bottom:18px;}

/* ------------------------------------------------------------
   CTA band + footer
   ------------------------------------------------------------ */
.cta-band{
  position:relative;
  background:radial-gradient(120% 90% at 22% 90%,var(--navy-2) 0%,var(--navy) 58%);
  color:#fff;
  padding:clamp(64px,8vw,104px) 0;
  overflow:hidden;
}
.cta-band .inner{text-align:center;max-width:760px;margin:0 auto;position:relative;}
.cta-band .kicker{justify-content:center;color:var(--blue-l);}
.cta-band h2{color:#fff;font-size:clamp(30px,4vw,46px);letter-spacing:-.03em;margin-top:14px;}
.cta-band p{color:rgba(255,255,255,.78);margin-top:16px;font-size:clamp(15px,1.5vw,17px);line-height:1.65;}
.cta-band .actions{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;margin-top:32px;}

.site-footer{
  background:#fff;
  border-top:1px solid var(--line);
  color:var(--ink2);
  padding:clamp(52px,7vw,76px) 0 0;
}
.footer-grid{
  display:grid;grid-template-columns:minmax(0,1.35fr) repeat(3,minmax(0,1fr));
  gap:clamp(28px,4vw,56px);padding-bottom:clamp(36px,5vw,52px);
}
.footer-brand img{height:18px;width:auto;}
.footer-brand p{font-size:13.5px;color:var(--muted);margin-top:16px;max-width:30ch;line-height:1.6;}
.footer-social{display:flex;gap:10px;margin-top:20px;}
.footer-social a{
  width:38px;height:38px;border:1px solid var(--line);border-radius:100px;
  display:flex;align-items:center;justify-content:center;transition:all .2s ease;
}
.footer-social a:hover{border-color:var(--blue);background:var(--sky2);}
.footer-social svg{width:17px;height:17px;fill:var(--ink);transition:fill .2s ease;}
.footer-social a:hover svg{fill:var(--blue);}
.fcol .fh{
  font-family:var(--font-mono);font-size:9.5px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--blue);margin-bottom:16px;
}
.fcol ul{display:flex;flex-direction:column;gap:9px;}
.fcol ul.two-col{display:grid;grid-template-columns:1fr 1fr;gap:9px 26px;align-content:start;}
.fcol a{font-size:13.5px;color:var(--ink2);transition:color .2s ease;}
.fcol a:hover{color:var(--blue);}
.footer-bottom{
  border-top:1px solid var(--line);
  padding:20px 0;
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:10px;
  font-family:var(--font-mono);font-size:9.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--faint);
}
.footer-bottom b{color:var(--ink);font-weight:600;}

/* ------------------------------------------------------------
   Reveal animations
   ------------------------------------------------------------ */
@media (prefers-reduced-motion:no-preference){
  .reveal{opacity:0;transform:translateY(20px);transition:opacity .7s cubic-bezier(.2,.65,.25,1),transform .7s cubic-bezier(.2,.65,.25,1);}
  .reveal.in{opacity:1;transform:none;}
  .reveal.d1{transition-delay:.08s;}
  .reveal.d2{transition-delay:.16s;}
  .reveal.d3{transition-delay:.24s;}
}

/* ------------------------------------------------------------
   Responsive
   ------------------------------------------------------------ */
@media (max-width:1080px){
  .hero-grid{grid-template-columns:1fr;gap:48px;}
  .split{grid-template-columns:1fr;gap:38px;}
  .split.media-first .split-media{order:-1;}
  .ppanel{grid-template-columns:1fr;gap:30px;}
  .ppanel .pp-visual{order:2;}
  .ppanel .pp-foot{order:3;}
  .ptab{flex:0 0 auto;padding:14px 20px 12px;}
  .pgrid{grid-template-columns:1fr 1fr;}
  .news-grid{grid-template-columns:1fr 1fr;}
  .logowall{grid-template-columns:repeat(3,1fr);}
  .arch-quads{grid-template-columns:1fr 1fr;}
  .arch-q{border-bottom:1px solid var(--line);}
  .arch-q:nth-child(2n){border-right:0;}
  .arch-q:nth-last-child(-n+2){border-bottom:0;}
  .contact-grid{grid-template-columns:1fr;}
  .glance{grid-template-columns:1fr;}
}

@media (max-width:920px){
  .main-nav,.header-cta .hdr-link{display:none;}
  .nav-toggle{display:flex;padding:6px;}
  /* mobile: solid white header bar, flush to the top — merges with the iOS status bar */
  .site-header .logo img,
  .site-header.scrolled .logo img{height:17px;}
  .site-header .container,
  .site-header.scrolled .container,
  .site-header.scrolled.over-dark .container{
    max-width:none;
    margin:0;
    height:60px;
    gap:12px;
    padding-left:20px;
    padding-right:14px;
    border-radius:0;
    border:0;
    border-bottom:1px solid rgba(9,22,39,.10);
    background:#fff;
    -webkit-backdrop-filter:none;
    backdrop-filter:none;
    box-shadow:0 2px 16px rgba(9,22,39,.06);
  }
  /* dark logo + hamburger on the white bar (cancel the over-dark white treatment) */
  body.has-dark-hero .site-header:not(.scrolled) .logo img,
  .site-header.over-dark .logo img{filter:none;}
  body.has-dark-hero .site-header:not(.scrolled) .nav-toggle span,
  .site-header.over-dark .nav-toggle span{background:var(--ink);}
  .header-cta{gap:8px;}
  .header-cta .btn{padding:9px 13px;font-size:9.5px;letter-spacing:.1em;}
  .arch-feeders{grid-template-columns:1fr 1fr;}
  .arch-nav{flex-direction:column;}
  .arch-nav .idn{flex:0 0 auto;}
  .tloop{flex-direction:column;}
  .tloop .st{border-right:0;border-bottom:1px solid var(--line);}
  .tloop .st:last-child{border-bottom:0;}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .fgrid.cols3{grid-template-columns:1fr 1fr;}
}

@media (max-width:640px){
  .hero-mini-stats{flex-wrap:wrap;gap:24px 30px;}
  .gcard{display:none;}
  .hc-aurora{filter:blur(46px);}
  .ppanel .pp-num{font-size:42px;top:16px;right:20px;}
  .ppanel .pp-blist{grid-template-columns:1fr;}
  .pp-kpi{position:static;display:inline-block;margin-top:14px;}
  .pgrid{grid-template-columns:1fr;}
  .fgrid,.fgrid.cols3{grid-template-columns:1fr;}
  .news-grid{grid-template-columns:1fr;}
  .logowall{grid-template-columns:1fr 1fr;}
  .footer-grid{grid-template-columns:1fr;}
  .pd-gallery{grid-template-columns:1fr;}
  .pnav{grid-template-columns:1fr;}
  .pnav a+a{border-left:0;border-top:1px solid var(--line);text-align:left;align-items:flex-start;}
  .arch-feeders{grid-template-columns:1fr;}
  .arch-quads{grid-template-columns:1fr;}
  .arch-q{border-right:0;}
  .cform .frow{grid-template-columns:1fr;}
  .cta-panel{flex-direction:column;align-items:flex-start;}
}

/* app-row KPI variant (ONE panel) */
.pp-kpi .ka{display:flex;align-items:center;gap:7px;margin-top:6px;}
.pp-kpi .ka img{width:20px;height:20px;display:block;}
.pp-kpi .ka .plus{
  width:20px;height:20px;border-radius:6px;background:var(--sky);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-mono);font-size:9px;font-weight:600;color:var(--blue-d);
}

/* ============================================================
   HERO v2 — premium enterprise atmosphere (dark theme)
   Palette: #0A1633 deep navy · #123D8F royal · #2E6CFF accent · #fff
   Appended overrides + new ambient layers (cloud bank, aircraft).
   Structure / animation stay defined by the base hero rules above.
   ============================================================ */
.has-dark-hero .hero-wrap{background:var(--navy);}
/* accent unification to #2E6CFF */
.hero-card h1 em{color:#2E6CFF;}
.hero-card .arc .fp{stroke:rgba(46,108,255,.5);}
.fp-dot{background:#2E6CFF;box-shadow:0 0 0 6px rgba(46,108,255,.16),0 0 18px rgba(46,108,255,.62);}
.hero-eyebrow{color:#ffffff;}
.tw-caret{background:#2E6CFF;}

/* volumetric cloud bank, low in the scene, melted into the navy
   (add the photo at /assets/images/clouds.png — stays invisible until then) */
.hc-clouds{
  position:absolute;left:0;right:0;bottom:0;height:58%;
  z-index:1;pointer-events:none;
  background:var(--navy) url("/assets/images/clouds.webp") center bottom / cover no-repeat;
  opacity:.5;
  mix-blend-mode:screen;
  -webkit-mask-image:linear-gradient(180deg,transparent 0%,#000 48%);
  mask-image:linear-gradient(180deg,transparent 0%,#000 48%);
}

/* three floating EFB cards arranged around the tablet */
.gcard{max-width:210px;}
.gcard.g1{left:-7%;top:5%;}
.gcard.g2{right:-6%;bottom:7%;}
.gcard.g3{right:-9%;top:25%;}
.gcard.g4{left:-9%;bottom:19%;}
@media (prefers-reduced-motion:no-preference){
  .gcard.g3{animation:gdrift2 7.6s ease-in-out .9s infinite;}
  .gcard.g4{animation:gdrift1 8.8s ease-in-out .5s infinite;}
}
@media (max-width:1080px){
  .gcard.g3,.gcard.g4{display:none;}
}

/* ============================================================
   LEGAL PAGES (one/privacy-policy, one/cookie-policy)
   Neutralize leftover optech / Bootstrap scaffolding inside .prose
   so the policy text flows in the clean prose column.
   ============================================================ */
.prose .container{max-width:none;padding:0;}
.prose .sec-title{max-width:none;margin:0;font-size:inherit;line-height:inherit;letter-spacing:normal;}
.prose .text{margin:0 0 14px;font-size:15px;line-height:1.75;color:var(--ink2);}
.prose .sub-title{
  font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.14em;
  text-transform:uppercase;color:var(--muted);margin:0 0 20px;
}
.prose .col-xl-4,.prose .optech-pd-sidebar-wrap{display:none;}
.prose h3:empty,.prose h4:empty{display:none;}

/* ============================================================
   HERO CTAs — equal-width symmetric buttons; clearer secondary
   (primary blue left untouched)
   ============================================================ */
.hero-ctas .btn{min-width:232px;flex:1 1 0;}
.hero-ctas .btn-ghost.on-dark{
  background:color-mix(in srgb, #122158 50%, transparent);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.42),
    inset 0 0 0 1.5px rgba(255,255,255,.62),
    0 8px 22px rgba(0,0,0,.30);
}
.hero-ctas .btn-ghost.on-dark:hover{
  background:color-mix(in srgb, #122158 58%, transparent);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.5),
    inset 0 0 0 1.5px rgba(255,255,255,.82),
    0 12px 26px rgba(0,0,0,.36);
}

/* ============================================================
   MOBILE REFINEMENTS (v2) — full responsive pass
   Layered after the base 1080/920/640 breakpoints.
   ============================================================ */
/* prevent grid/flex blowout so single-column layouts actually fit
   (a child's min-content was forcing items wider than the viewport) */
.hero-grid > *, .split > *, .ppanel > *, .footer-grid > *,
.contact-grid > *, .glance > *{min-width:0;}

@media (max-width:1080px){
  /* hero stacks: contain the tablet, drop the floating cards */
  .hero-card .hc-inner{padding:calc(var(--header-h) + 28px) 0 clamp(48px,7vw,72px);}
  .hero-grid{gap:30px;align-items:center;}
  .hero-left{max-width:720px;padding-bottom:0;}
  .hero-left .hsp{display:none;}
  .hero-visual{margin-top:2px;}
  .hero-visual img.device{width:min(620px,92vw);}
  .gcard{display:none;}
  .hc-clouds{height:52%;opacity:.42;}
  .ht-marquee{min-width:0;max-width:none;}
  .hero-note{text-align:left;}
}

@media (max-width:640px){
  .hero-card .hc-inner{padding:calc(var(--header-h) + 18px) 0 54px;}
  .hero-grid{gap:26px;}
  /* headline scales to fit narrow screens */
  .hero-card h1{font-size:clamp(30px,8.5vw,40px);line-height:1;}
  .hero-eyebrow{font-size:10px;letter-spacing:.18em;gap:8px;margin-bottom:8px;}
  .tw-caret{width:7px;height:14px;}
  .hero-desc{font-size:14.5px;margin-top:18px;max-width:none;}
  /* CTAs: full-width, stacked, symmetric */
  .hero-ctas{flex-direction:column;align-items:stretch;gap:12px;margin-top:24px;}
  .hero-ctas .btn{min-width:0;width:100%;}
  .hero-trust{margin-top:22px;}
  .ht-track{gap:30px;padding-left:30px;}
  .hero-visual img.device{width:min(430px,94vw);}
  .hc-clouds{height:44%;opacity:.36;}
  /* stats: clean 2×2 grid (no broken vertical dividers) */
  .hero-mini-stats{display:grid;grid-template-columns:1fr 1fr;gap:22px 20px;padding-top:22px;}
  .hero-mini-stats .ms,
  .hero-mini-stats .ms + .ms{padding:0;border-left:0;}
  .hero-mini-stats .ms .v{font-size:clamp(30px,9vw,40px);}
  .hero-mini-stats .ms .l{white-space:normal;font-size:7.5px;}
}

/* ============================================================
   Glass cards (Safari-safe) — real frosted glass via backdrop-filter,
   but PLAIN rgba shadows. The original rectangle artifact in WebKit
   came from color-mix() in the multi-layer box-shadow, not the blur.
   ============================================================ */
.gcard{
  background:linear-gradient(155deg, rgba(42,58,102,.50), rgba(18,28,55,.40));
  -webkit-backdrop-filter:blur(14px) saturate(135%);
  backdrop-filter:blur(14px) saturate(135%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.22),
    inset 0 0 0 1px rgba(255,255,255,.12),
    0 14px 30px rgba(3,10,28,.40);
}
/* ONE-panel KPI card → frosted glass over the light panel */
.pp-kpi{
  background:rgba(255,255,255,.82);
  -webkit-backdrop-filter:blur(18px) saturate(150%);
  backdrop-filter:blur(18px) saturate(150%);
  border:1px solid rgba(255,255,255,.95);
  box-shadow:
    inset 0 1px 0 #fff,
    0 20px 46px rgba(9,22,39,.22);
}

/* Qualify — full-width row spanning both products-dropdown columns; styled like every other item */
.dropdown a.pf-wide{grid-column:1 / -1;}
/* external-link arrow on the Qualify row → sits far right, marks a separate page */
.dropdown a.pf-wide .pf-ext{
  margin-left:auto;flex:0 0 auto;display:block;
  width:18px;height:18px;color:var(--muted);
  transition:transform .2s ease,color .2s ease;
}
.dropdown a.pf-wide:hover .pf-ext{transform:translate(2px,-2px);color:var(--blue);}
.site-header.over-dark .dropdown a.pf-wide .pf-ext{color:rgba(255,255,255,.5);}
.site-header.over-dark .dropdown a.pf-wide:hover .pf-ext{color:#fff;}

/* ============================================================
   EFB cards — one strong efficiency card + two quiet status cards.
   Keep the tablet map readable and avoid viewport-edge overflow.
   Map centre stays open.
   ============================================================ */
.gcard.g1{
  left:-4%;top:0;right:auto;
  max-width:238px;padding:15px 17px;
  background:linear-gradient(155deg, rgba(31,92,71,.60), rgba(17,52,44,.50));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.22),
    inset 0 0 0 1px rgba(110,232,180,.40),
    0 18px 40px rgba(3,10,28,.46),
    0 0 38px rgba(70,211,154,.18);
}
.gcard.g1 .gk{color:#9ff0cc;}
.gcard.g1 .gv,.gcard.g1 .gv.good{color:#fff;font-size:18.5px;}
.gcard.g1 .gd{color:rgba(255,255,255,.74);}

.gcard.g2,.gcard.g3{
  max-width:166px;padding:10px 13px;
  background:linear-gradient(155deg, rgba(34,48,86,.40), rgba(15,25,48,.32));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.10),
    inset 0 0 0 1px rgba(255,255,255,.07),
    0 10px 24px rgba(3,10,28,.32);
}
.gcard.g2 .gk,.gcard.g3 .gk{color:rgba(124,154,205,.8);}
.gcard.g2 .gv,.gcard.g3 .gv{font-size:13.5px;color:rgba(255,255,255,.8);}
.gcard.g2 .gv.good,.gcard.g3 .gv.good{color:rgba(95,224,168,.8);}
.gcard.g2 .gd,.gcard.g3 .gd{color:rgba(255,255,255,.5);}
.gcard.g3{right:2%;top:20%;left:auto;}
.gcard.g2{right:8%;bottom:7%;left:auto;}

/* soft hand-off: the hero's cloud band dissolves into the light section
   below (#eef2f9), so there's no hard seam — clouds bridge the gap */
.has-dark-hero .hero-card::after{
  content:"";
  position:absolute;left:0;right:0;bottom:0;
  height:clamp(170px,26vh,320px);
  z-index:2;pointer-events:none;
  background:linear-gradient(180deg,
    rgba(238,242,249,0) 0%,
    rgba(238,242,249,.5) 58%,
    #eef2f9 100%);
}
