/* ===== NYFTY Labs — shared styles ===== */
:root{
  --bg:#060b14;
  --bg-scrim:rgba(6,11,20,.93);  /* sits over the live shader so text stays readable */
  --fg:#f2f6fb;                  /* primary text on --bg */
  --muted:#9fb0c2;               /* secondary text ~9:1 — WCAG AAA */
  --faint:#6b7c90;               /* labels only, large/non-critical */
  --line:rgba(242,246,251,.14);
  --card:#0b1320;
  --card-2:#0e1828;
  --accent:#59b9ff;             /* brand light blue — text/glow on dark */
  --accent-deep:#188af2;        /* brand deep blue — buttons/fills */
  --accent-ink:#04101f;
  --accent2:#188af2;
  --coral:#ff7a5c;
  --ease:cubic-bezier(.16,1,.3,1);
  --maxw:1280px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--fg);font-family:'Poppins',system-ui,sans-serif;
  font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;cursor:none}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:var(--accent);color:var(--accent-ink)}
h1,h2,h3,h4,.disp{font-family:'Montserrat',sans-serif;letter-spacing:-.02em}

canvas#gl{position:fixed;inset:0;width:100%;height:100%;z-index:0;display:block}
.grain{position:fixed;inset:-50%;z-index:1;pointer-events:none;opacity:.04;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 8s steps(6) infinite}
@keyframes grain{0%,100%{transform:translate(0,0)}25%{transform:translate(-4%,2%)}50%{transform:translate(3%,-3%)}75%{transform:translate(-2%,3%)}}
.wrap{position:relative;z-index:2}

/* cursor */
.cursor{position:fixed;top:0;left:0;width:11px;height:11px;border-radius:50%;background:var(--fg);
  z-index:9999;pointer-events:none;mix-blend-mode:difference;transform:translate(-50%,-50%);
  transition:width .3s var(--ease),height .3s var(--ease)}
.cursor.big{width:52px;height:52px}
@media(hover:none){.cursor{display:none}body{cursor:auto}}

/* loader */
.loader{position:fixed;inset:0;z-index:99999;background:var(--bg);display:flex;align-items:flex-end;
  justify-content:flex-end;padding:6vw;transition:opacity .7s var(--ease),visibility .7s}
.loader.done{opacity:0;visibility:hidden}
.loader b{font-family:'Montserrat';font-weight:700;font-size:clamp(3.5rem,14vw,12rem);line-height:.8;
  letter-spacing:-.04em;color:var(--accent)}

/* ===== nav ===== */
.nav{position:fixed;top:0;left:0;right:0;z-index:200;transition:background .4s,backdrop-filter .4s,padding .4s}
.nav .bar{max-width:var(--maxw);margin:0 auto;display:flex;justify-content:space-between;align-items:center;
  padding:20px clamp(18px,4vw,40px)}
.nav.scrolled{background:rgba(5,8,12,.72);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav.scrolled .bar{padding:13px clamp(18px,4vw,40px)}
.brand{font-family:'Montserrat';font-weight:700;font-size:20px;letter-spacing:-.02em}
.brand b{color:var(--accent);font-weight:700}
.nav .links{display:flex;gap:30px;align-items:center}
.nav .links a.nl{font-size:14px;font-weight:500;color:#cdd5da;position:relative;transition:color .3s}
.nav .links a.nl:hover,.nav .links a.nl[aria-current]{color:var(--fg)}
.nav .links a.nl[aria-current]::after{content:'';position:absolute;left:0;bottom:-6px;width:100%;height:2px;
  background:var(--accent);border-radius:2px}
/* ===== button system (pill + circular arrow, rotate-45 on hover) ===== */
.btn{display:inline-flex;align-items:center;gap:13px;font-family:'Montserrat';font-weight:600;
  letter-spacing:.06em;text-transform:uppercase;font-size:13px;padding:11px 12px 11px 24px;
  border-radius:50px;border:1px solid rgba(242,246,251,.4);background:transparent;color:var(--fg);cursor:none;
  transition:background .25s var(--ease),color .25s,border-color .25s,transform .25s}
.btn .arrow{display:grid;place-items:center;width:34px;height:34px;border-radius:50%;
  background:var(--fg);color:var(--bg);font-size:15px;line-height:1;
  transition:background .25s,color .25s,transform .35s var(--ease)}
.btn:hover{background:var(--fg);color:var(--bg);border-color:var(--fg)}
.btn:hover .arrow{background:var(--accent-deep);color:#fff;transform:rotate(45deg)}
.btn:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(89,185,255,.4)}
.btn--primary{background:var(--accent-deep);border-color:var(--accent-deep);color:#fff;box-shadow:0 12px 34px rgba(24,138,242,.28)}
.btn--primary .arrow{background:#fff;color:var(--accent-deep)}
.btn--primary:hover{background:var(--accent);border-color:var(--accent);color:var(--accent-ink);transform:translateY(-2px)}
.btn--primary:hover .arrow{background:var(--accent-ink);color:var(--accent);transform:rotate(45deg)}
.btn--light{border-color:rgba(255,255,255,.4);color:#fff}
.btn--light:hover{background:#fff;color:var(--bg);border-color:#fff}
.btn--ghostlink{border-color:transparent;text-transform:none;letter-spacing:.02em;font-weight:500;
  padding:11px 14px;font-size:14px;color:#cdd5da;font-family:'Poppins'}
.btn--ghostlink:hover{background:transparent;color:var(--accent);border-color:transparent;transform:none}
@media(max-width:880px){.btn{font-size:14px}}
.menu-btn{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:none;padding:8px}
.menu-btn span{width:24px;height:2px;background:var(--fg);transition:transform .35s var(--ease),opacity .2s}
.menu-open .menu-btn span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-open .menu-btn span:nth-child(2){opacity:0}
.menu-open .menu-btn span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@media(max-width:880px){
  /* backdrop-filter on .nav would trap position:fixed children (the menu overlay) inside the bar — drop it on mobile */
  .nav.scrolled{backdrop-filter:none;background:rgba(5,8,12,.96)}
  .nav .links{position:fixed;inset:0;background:rgba(5,8,12,.98);
    flex-direction:column;justify-content:flex-start;align-items:stretch;gap:0;
    padding:88px 24px calc(40px + env(safe-area-inset-bottom));overflow-y:auto;-webkit-overflow-scrolling:touch;
    transform:translateY(-100%);opacity:0;visibility:hidden;pointer-events:none;
    transition:transform .45s var(--ease),opacity .3s,visibility .3s;z-index:190}
  .menu-open .nav .links{transform:none;opacity:1;visibility:visible;pointer-events:auto;backdrop-filter:blur(10px)}
  .nav .links a.nl{font-family:'Montserrat';font-size:1.5rem;font-weight:600;color:var(--fg);
    padding:15px 2px;border-bottom:1px solid var(--line)}
  .nav .links a.nl[aria-current]::after{display:none}
  .nav .links a.nl[aria-current]{color:var(--accent)}
  .nav .links .btn{margin-top:18px;font-size:14px}
  .nav .links .btn--ghostlink{display:none}
  .menu-btn{display:flex;z-index:210}
}

/* ===== Services dropdown / mega menu ===== */
.brand{display:inline-flex;align-items:center}
.brand{margin:-8px 0}
.logo-img{height:96px;width:auto;display:block;margin:-26px 0}
.nav.scrolled .logo-img{height:74px;margin:-18px 0}
.fbrand .logo-img{height:84px;margin:-18px 0}
@media(max-width:880px){.logo-img{height:70px;margin:-16px 0}.nav.scrolled .logo-img{height:62px;margin:-14px 0}}
.has-drop{position:relative;display:flex;align-items:center}
.has-drop::after{content:'';position:absolute;top:100%;left:-12px;right:-12px;height:24px}  /* hover bridge: kills the dead-zone gap to .mega */
.drop-trigger{display:inline-flex;align-items:center;gap:7px;font-size:14px;font-weight:500;color:#cdd5da;transition:color .3s}
.has-drop:hover .drop-trigger,.drop-trigger[aria-current]{color:var(--fg)}
.drop-trigger .car{width:7px;height:7px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;
  transform:rotate(45deg) translateY(-1px);transition:transform .3s var(--ease)}
.mega{position:absolute;top:calc(100% + 16px);left:50%;transform:translateX(-50%) translateY(8px);
  width:min(720px,92vw);background:rgba(8,14,24,.97);backdrop-filter:blur(16px);border:1px solid var(--line);
  border-radius:18px;padding:24px;display:grid;grid-template-columns:repeat(4,1fr);gap:6px 22px;
  opacity:0;visibility:hidden;pointer-events:none;transition:opacity .3s var(--ease),transform .3s var(--ease);
  box-shadow:0 30px 70px rgba(0,0,0,.55);z-index:300}
.mega::before{content:'';position:absolute;top:-16px;left:0;right:0;height:16px}  /* hover bridge */
.has-drop:hover .mega{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.has-drop:hover .drop-trigger .car{transform:rotate(-135deg) translateY(2px)}
.mega .col h6{font-size:11px;text-transform:uppercase;letter-spacing:.13em;color:var(--accent);margin:4px 0 10px;font-weight:600}
.mega .col a{display:block;font-size:14px;color:#cdd5da;padding:8px 0;font-weight:400;line-height:1.35}
.mega .col a:hover{color:var(--fg)}
@media(max-width:880px){
  .has-drop{width:100%;flex-direction:column;align-items:stretch}
  .drop-trigger{font-family:'Montserrat';font-size:1.5rem;font-weight:600;color:var(--fg);
    justify-content:space-between;padding:15px 2px;border-bottom:1px solid var(--line)}
  .has-drop.open .drop-trigger{border-bottom-color:transparent}
  .mega::before{display:none}
  .has-drop.open .drop-trigger .car{transform:rotate(-135deg) translateY(2px)}
  /* mega layout overrides live AFTER the upgraded-mega block below (source order wins) */
}

/* ===== layout ===== */
.section{padding:clamp(70px,11vh,140px) clamp(18px,4vw,40px);position:relative}
.section.scrim{background:var(--bg-scrim)}        /* solid-ish surface over the space bg for legibility */
.wrap .section.scrim + .section.scrim{border-top:1px solid var(--line)}   /* retro hairline rhythm */
.inner{max-width:var(--maxw);margin:0 auto}
.eyebrow{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.18em;color:var(--accent);
  margin-bottom:22px;display:flex;align-items:center;gap:11px}
.eyebrow::before{content:'';width:24px;height:1px;background:var(--accent)}
.h1{font-family:'Montserrat';font-weight:700;font-size:clamp(2.6rem,6.4vw,6rem);line-height:1.06;
  letter-spacing:-.03em;max-width:18ch;text-wrap:balance}
.h1 .g{color:var(--accent)}
.h2{font-family:'Montserrat';font-weight:700;font-size:clamp(1.85rem,4vw,3.2rem);line-height:1.12;
  letter-spacing:-.02em;max-width:22ch;text-wrap:balance}
.h2 .g{color:var(--accent)}
.lead{color:var(--muted);max-width:62ch;font-size:clamp(15.5px,1.5vw,18px);line-height:1.7;margin-top:24px}
.reveal{opacity:0;transform:translateY(36px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* page hero (sub pages) */
.phero{padding:clamp(190px,24vh,270px) clamp(18px,4vw,40px) clamp(60px,9vh,110px)}
.phero .lead{margin-top:26px}
.phero .cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:clamp(30px,4vh,42px)}

/* home hero */
.hero{min-height:100svh;display:flex;align-items:center;padding:120px clamp(18px,4vw,40px) 60px}
.hero{position:relative}
.hero .inner{width:100%;position:relative;z-index:2}
.hero-astro{position:absolute;top:50%;right:clamp(-40px,3vw,80px);width:clamp(240px,30vw,460px);
  margin-top:-150px;pointer-events:none;z-index:1;will-change:transform}
.hero-astro img{width:100%;height:auto;display:block;
  filter:drop-shadow(0 30px 60px rgba(24,138,242,.30));animation:astrofloat 9s ease-in-out infinite}
@keyframes astrofloat{0%,100%{transform:translateY(-12px) rotate(-3deg)}50%{transform:translateY(12px) rotate(2.5deg)}}
@media(max-width:980px){.hero-astro{right:-12vw;width:64vw;opacity:.32}}
@media(max-width:620px){.hero-astro{display:none}}
@media(prefers-reduced-motion:reduce){.hero-astro img{animation:none}}
.kick{display:inline-flex;align-items:center;gap:10px;font-size:12px;font-weight:600;text-transform:uppercase;
  letter-spacing:.18em;color:var(--muted);margin-bottom:28px}
.kick::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 14px var(--accent)}
.hero h1{font-family:'Montserrat';font-weight:700;font-size:clamp(2.7rem,7vw,6.4rem);line-height:1.05;
  letter-spacing:-.03em;max-width:16ch;text-wrap:balance}
.hero h1 .g{color:var(--accent)}
.hero .sub{max-width:56ch;color:#c9d1d6;font-size:clamp(16px,1.6vw,20px);line-height:1.65;margin-top:30px}
.hero .cta{display:flex;gap:14px;margin-top:36px;flex-wrap:wrap}
.hero .cta .btn{font-size:14px}
.anim-up{opacity:0;transform:translateY(22px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.loaded .anim-up{opacity:1;transform:none}
.loaded .d1{transition-delay:.15s}.loaded .d2{transition-delay:.3s}.loaded .d3{transition-delay:.45s}.loaded .d4{transition-delay:.58s}

/* marquee */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;background:var(--bg-scrim)}
.marquee .track{display:flex;white-space:nowrap;will-change:transform;animation:scroll 30s linear infinite}
.marquee span{font-family:'Montserrat';font-weight:600;font-size:clamp(1.4rem,3.4vw,2.8rem);
  padding:16px 24px;color:#cdd5da}
.marquee span em{color:var(--accent);font-style:normal}
@keyframes scroll{to{transform:translateX(-50%)}}

/* values */
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);
  border:1px solid var(--line);border-radius:18px;overflow:hidden;margin-top:clamp(44px,6vh,64px)}
.val{background:var(--card);padding:38px 32px;transition:background .4s}
.val:hover{background:var(--card-2)}
.val .num{font-family:'Montserrat';font-weight:700;font-size:15px;color:var(--accent);margin-bottom:18px}
.val h4{font-weight:600;font-size:20px;margin-bottom:12px}
.val p{color:var(--muted);font-size:15.5px;line-height:1.6}
@media(max-width:880px){.values{grid-template-columns:repeat(2,1fr)}}
@media(max-width:540px){.values{grid-template-columns:1fr}}

/* split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,70px);align-items:start}
.caps{display:flex;flex-direction:column;gap:16px}
.cap{border:1px solid var(--line);border-radius:14px;padding:28px;background:var(--card);
  transition:border-color .4s,transform .4s var(--ease)}
.cap:hover{border-color:rgba(89,185,255,.5);transform:translateX(6px)}
.cap h4{font-weight:600;font-size:18px;margin-bottom:9px}
.cap p{color:var(--muted);font-size:15.5px;line-height:1.55}
@media(max-width:880px){.split{grid-template-columns:1fr}}

/* stats */
.stats{display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(32px,6vw,84px);margin-top:clamp(40px,5vh,56px);border-top:1px solid var(--line);padding-top:46px;text-align:center}
.stats>div{text-align:center;min-width:130px}
.stats .n{font-family:'Montserrat';font-weight:700;font-size:clamp(2.2rem,4.6vw,3.8rem);letter-spacing:-.03em}
.stats .n .g{color:var(--accent)}
.stats .l{color:var(--muted);font-size:13px;text-transform:uppercase;letter-spacing:.1em;margin-top:8px}
@media(max-width:920px){.stats{grid-template-columns:repeat(2,1fr);gap:30px 24px}}

/* testimonial */
.quote{text-align:center;max-width:880px;margin:0 auto;background:var(--card);border:1px solid var(--line);
  border-radius:24px;padding:clamp(40px,6vw,80px) clamp(28px,5vw,72px);position:relative}
.quote::before{content:'\201C';position:absolute;top:clamp(8px,2vw,24px);left:50%;transform:translateX(-50%);
  font-family:'Montserrat';font-weight:700;font-size:clamp(4rem,9vw,7rem);line-height:1;color:var(--accent);opacity:.22}
.quote blockquote{font-family:'Montserrat';font-weight:600;font-size:clamp(1.4rem,2.8vw,2.5rem);line-height:1.3;
  letter-spacing:-.015em;max-width:30ch;margin:18px auto 0;text-wrap:balance}
.quote blockquote .g{color:var(--accent)}
.quote .who{color:var(--muted);font-size:14px;text-transform:uppercase;letter-spacing:.12em;margin-top:30px}

/* blog */
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:clamp(44px,6vh,64px)}
.post{border:1px solid var(--line);border-radius:18px;overflow:hidden;background:var(--card);
  transition:transform .5s var(--ease),border-color .4s}
.post:hover{transform:translateY(-6px);border-color:rgba(89,185,255,.4)}
.post .img{aspect-ratio:16/10}
.post .b{padding:28px}
.post .tag{font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:var(--accent);font-weight:600}
.post h4{font-weight:600;font-size:20px;line-height:1.3;margin:12px 0;text-wrap:balance}
.post p{color:var(--muted);font-size:15px;line-height:1.55}
/* feature the first post as a wide split card */
.posts .post:first-child{grid-column:1 / -1;display:grid;grid-template-columns:1.15fr 1fr;align-items:stretch}
.posts .post:first-child .img{aspect-ratio:auto;min-height:300px}
.posts .post:first-child .b{display:flex;flex-direction:column;justify-content:center;padding:clamp(28px,4vw,52px)}
.posts .post:first-child h4{font-size:clamp(1.4rem,2.4vw,2rem)}
@media(max-width:880px){.posts .post:first-child{grid-template-columns:1fr}.posts .post:first-child .img{min-height:200px}}
.post .read{color:var(--fg);font-size:13px;font-weight:600;margin-top:16px;display:inline-flex;gap:6px}
.post .read .ar{color:var(--accent)}
@media(max-width:880px){.posts{grid-template-columns:1fr}}
.g1{background:radial-gradient(120% 120% at 25% 20%,#59b9ff,#0b1320 68%)}
.g2{background:radial-gradient(120% 120% at 75% 25%,#188af2,#0b1320 66%)}
.g3{background:radial-gradient(130% 120% at 40% 80%,#2b6fff,#0b1320 68%)}

/* contact */
.contact{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,5vw,64px)}
.cinfo{display:flex;flex-direction:column;gap:24px;margin-top:34px}
.cinfo .it .k{font-size:12px;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);margin-bottom:6px}
.cinfo .it .v{font-family:'Montserrat';font-weight:600;font-size:clamp(1.05rem,2vw,1.5rem)}
.cinfo .it .v a:hover{color:var(--accent)}
form{display:flex;flex-direction:column;gap:15px}
form .r{display:grid;grid-template-columns:1fr 1fr;gap:15px}
label{font-size:13px;color:var(--muted);margin-bottom:6px;display:block}
input,textarea{width:100%;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:15px 16px;
  color:var(--fg);font-family:inherit;font-size:15px;transition:border-color .3s}
input::placeholder,textarea::placeholder{color:var(--faint)}
input:focus,textarea:focus{outline:none;border-color:var(--accent)}
textarea{min-height:130px;resize:vertical}
form button{justify-content:center;padding:16px;font-size:15px;border:none}
@media(max-width:880px){.contact{grid-template-columns:1fr}form .r{grid-template-columns:1fr}}

/* checklist (service detail) */
.checks{list-style:none;display:flex;flex-direction:column;gap:14px;margin-top:8px}
.checks li{display:flex;gap:13px;align-items:flex-start;color:#d4dbdf;font-size:15.5px;line-height:1.5}
.checks li::before{content:'';flex:none;width:22px;height:22px;margin-top:1px;border-radius:6px;
  background:rgba(89,185,255,.14);border:1px solid rgba(89,185,255,.5);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2359b9ff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:center;background-size:14px}

/* ===== grouped capability cards (services page) ===== */
.capgroup{margin-top:clamp(40px,6vh,64px)}
.cat-eyebrow{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.16em;color:var(--accent);
  display:inline-flex;align-items:center;gap:11px}
.cat-eyebrow::before{content:'';width:24px;height:1px;background:var(--accent)}
.capcards{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:22px}
.capcard{border:1px solid var(--line);border-radius:18px;padding:30px 28px;background:var(--card);
  display:flex;flex-direction:column;gap:11px;min-height:210px;
  transition:border-color .4s,transform .4s var(--ease)}
.capcard:hover{border-color:rgba(89,185,255,.45);transform:translateY(-5px)}
.capcard h4{font-family:'Montserrat';font-weight:600;font-size:19px;line-height:1.28;color:var(--fg)}
.capcard p{color:var(--muted);font-size:15px;line-height:1.55;flex:1}
.capcard .more{color:var(--accent);font-size:14px;font-weight:600;margin-top:4px}
@media(max-width:1180px){.capcards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.capcards{grid-template-columns:1fr}}

/* ===== value props (home) ===== */
.vprops{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:clamp(44px,6vh,64px)}
.vprop{border:1px solid var(--line);border-radius:18px;padding:36px 30px;background:var(--card);
  transition:border-color .4s,transform .4s var(--ease)}
.vprop:hover{border-color:rgba(89,185,255,.45);transform:translateY(-6px)}
.vprop .vp-ic{width:50px;height:50px;border-radius:13px;border:1px solid rgba(89,185,255,.5);
  background:rgba(89,185,255,.10);display:flex;align-items:center;justify-content:center;margin-bottom:22px}
.vprop .vp-ic svg{width:24px;height:24px;stroke:var(--accent);fill:none;stroke-width:1.7}
.vprop h3{font-family:'Montserrat';font-weight:600;font-size:21px;margin-bottom:11px}
.vprop p{color:var(--muted);font-size:15.5px;line-height:1.6}
@media(max-width:880px){.vprops{grid-template-columns:1fr}}

/* ===== process / how we work (retro line steps) ===== */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:clamp(44px,6vh,64px)}
.pstep{position:relative;padding-top:28px;border-top:1px solid var(--line)}
.pstep::after{content:'';position:absolute;top:-2px;left:0;width:42px;height:3px;background:var(--accent)}
.pstep .pn{font-family:'Montserrat';font-weight:800;font-size:13px;color:var(--accent);letter-spacing:.08em}
.pstep h4{font-family:'Montserrat';font-weight:600;font-size:19px;margin:14px 0 10px;letter-spacing:-.01em}
.pstep p{color:var(--muted);font-size:15px;line-height:1.6}
@media(max-width:880px){.process{grid-template-columns:1fr 1fr;gap:30px 24px}}
@media(max-width:520px){.process{grid-template-columns:1fr}}

/* article prose (blog post) */
.prose{max-width:44rem;margin-top:10px}
.prose p{color:#cfd6da;font-size:clamp(16px,1.5vw,18px);line-height:1.75;margin-bottom:24px}
.prose h2{font-size:clamp(1.4rem,3vw,2rem);margin:44px 0 16px}
.prose h2 .g{color:var(--accent)}
.prose ul{margin:0 0 24px 0;padding-left:0;list-style:none;display:flex;flex-direction:column;gap:12px}
.prose ul li{color:#cfd6da;font-size:16px;line-height:1.6;padding-left:26px;position:relative}
.prose ul li::before{content:'';position:absolute;left:0;top:10px;width:8px;height:8px;border-radius:2px;background:var(--accent)}
.prose .meta{color:var(--muted);font-size:13px;text-transform:uppercase;letter-spacing:.12em;margin-bottom:30px}
/* legal pages: faithful long-form policy content (terms/privacy/disclaimer/opt-out) */
.prose.legal{max-width:48rem}
.prose.legal h2{font-size:clamp(1.2rem,2.4vw,1.6rem);margin:40px 0 14px;color:#fff}
.prose.legal h3{font-size:clamp(1.05rem,2vw,1.25rem);margin:28px 0 10px;color:#eaf2fb}
.prose.legal h4{font-size:1rem;margin:20px 0 8px;color:#dbe6f2}
.prose.legal h5{font-size:11.5px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin:14px 0 2px}
.prose.legal p{margin-bottom:18px}
.prose.legal a{color:var(--accent);text-decoration:underline;text-underline-offset:2px;word-break:break-word}
.prose.legal a:hover{color:#8fd0ff}
.prose.legal i,.prose.legal em{color:var(--muted)}
.prose.legal ol{margin:0 0 22px 22px;padding:0;display:flex;flex-direction:column;gap:10px}
.prose.legal ol li{color:#cfd6da;font-size:16px;line-height:1.65}
.prose.legal ul li::before{top:9px}
.prose.legal .svc-cat{color:var(--accent);font-size:12px;text-transform:uppercase;letter-spacing:.1em;margin:-4px 0 14px;font-weight:600}
.ctable-wrap{overflow-x:auto;margin:14px 0 32px;border:1px solid var(--line);border-radius:12px;-webkit-overflow-scrolling:touch}
.ctable{width:100%;border-collapse:collapse;font-size:14px;min-width:520px}
.ctable th,.ctable td{text-align:left;padding:10px 14px;border-bottom:1px solid var(--line);vertical-align:top}
.ctable thead th{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.08em;background:rgba(255,255,255,.03)}
.ctable tbody td{color:#cfd6da;line-height:1.5}
.ctable tbody td:first-child{color:#fff;font-family:'JetBrains Mono',monospace;font-size:12.5px;word-break:break-word}
.ctable .ctable-cat th{color:var(--accent);font-size:11px;text-transform:uppercase;letter-spacing:.1em;background:rgba(89,185,255,.06)}
.ctable tbody tr:last-child td{border-bottom:none}
.prose.legal .cookie-none{color:var(--muted);font-size:14px;font-style:italic;margin:-6px 0 26px}
.related{margin-top:54px;border-top:1px solid var(--line);padding-top:34px}
.related h5{font-size:12px;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);margin-bottom:18px}
.related .chips{display:flex;flex-wrap:wrap;gap:12px}
.related .chips a{border:1px solid var(--line);border-radius:40px;padding:10px 18px;font-size:14px;font-weight:500;transition:border-color .3s,color .3s}
.related .chips a:hover{border-color:var(--accent);color:var(--accent)}

/* ===== skip link (a11y) ===== */
.skip{position:fixed;top:-60px;left:16px;z-index:10000;background:var(--accent-deep);color:#fff;
  padding:10px 18px;border-radius:8px;font-weight:600;transition:top .25s}
.skip:focus{top:16px;outline:none}

/* ===== breadcrumbs ===== */
.crumbs{display:flex;flex-wrap:wrap;gap:9px;align-items:center;font-size:13px;color:var(--muted);margin-bottom:26px}
.crumbs a{color:var(--muted)}.crumbs a:hover{color:var(--accent)}
.crumbs span{color:var(--faint)}

/* ===== forms (contact + modal) ===== */
.lead-form .form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.lead-form .field.full{grid-column:1/-1}
.field label{display:block;font-size:13px;color:var(--muted);margin-bottom:7px}
.field input,.field textarea{width:100%;background:var(--card);border:1px solid var(--line);border-radius:12px;
  padding:14px 16px;color:var(--fg);font-family:inherit;font-size:15px;transition:border-color .25s,box-shadow .25s}
.field input::placeholder,.field textarea::placeholder{color:var(--faint)}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(89,185,255,.18)}
.field textarea{min-height:120px;resize:vertical}
.lead-form button{margin-top:18px;border:none}
.form-note{margin-top:14px;font-size:13.5px;min-height:1.2em;color:var(--muted)}
@media(max-width:620px){.lead-form .form-grid{grid-template-columns:1fr}}

/* ===== lead modal (form pop) ===== */
body.modal-open{overflow:hidden}
.modal{position:fixed;inset:0;z-index:10000;display:grid;place-items:center;padding:24px}
.modal[hidden]{display:none}
.modal__backdrop{position:fixed;inset:0;background:rgba(2,5,10,.66);backdrop-filter:blur(10px);
  opacity:0;transition:opacity .3s var(--ease)}
.modal.open .modal__backdrop{opacity:1}
.modal__panel{position:relative;z-index:1;width:min(640px,100%);max-height:92vh;overflow:auto;
  background:linear-gradient(180deg,#0c1626,#0a111d);border:1px solid rgba(89,185,255,.22);border-radius:22px;
  padding:clamp(28px,4vw,46px);box-shadow:0 40px 110px rgba(0,0,0,.6);
  opacity:0;transform:translateY(24px) scale(.98);transition:opacity .3s var(--ease),transform .35s var(--ease)}
.modal.open .modal__panel{opacity:1;transform:none}
.modal__panel .h2{font-size:clamp(1.6rem,3.4vw,2.4rem);margin:10px 0 10px;line-height:1.12}
.modal__sub{color:var(--muted);font-size:15px;line-height:1.6;margin-bottom:24px;max-width:48ch}
.modal__close{position:absolute;top:16px;right:16px;width:40px;height:40px;border-radius:50%;
  border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--fg);font-size:22px;line-height:1;cursor:none;
  transition:background .25s,border-color .25s,transform .25s}
.modal__close:hover{background:var(--accent-deep);border-color:var(--accent-deep);transform:rotate(90deg)}
.modal__done{text-align:center;padding:24px 0}
.modal__check{width:64px;height:64px;margin:0 auto 18px;border-radius:50%;display:grid;place-items:center;
  font-size:28px;color:var(--accent);background:rgba(89,185,255,.12);border:1px solid rgba(89,185,255,.5)}
.modal__done h3{font-family:'Montserrat';font-weight:700;font-size:24px;margin-bottom:10px}
.modal__done p{color:var(--muted);max-width:36ch;margin:0 auto}

/* CTA band */
.band{text-align:center}
.band .big{font-family:'Montserrat';font-weight:700;font-size:clamp(2.4rem,8vw,7rem);line-height:.98;
  letter-spacing:-.03em}
.band .big .g{color:var(--accent)}
.band .cta{display:flex;gap:14px;justify-content:center;margin-top:38px;flex-wrap:wrap}

/* ===== footer ===== */
.footer{position:relative;z-index:2;border-top:1px solid var(--line);background:var(--bg-scrim);padding:clamp(60px,8vh,110px) clamp(18px,4vw,40px) 32px;overflow:hidden}
.ftop{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.2fr 1fr;gap:clamp(36px,6vw,90px);
  align-items:center;padding-bottom:clamp(48px,7vh,80px);border-bottom:1px solid var(--line)}
.fcta{font-family:'Montserrat';font-weight:700;font-size:clamp(2rem,4.5vw,3.6rem);line-height:1.08;
  letter-spacing:-.02em;margin-top:16px;max-width:16ch;text-wrap:balance}
.fcta .g{color:var(--accent)}
.fcta-btns{display:flex;gap:14px;margin-top:28px;flex-wrap:wrap}
.fnews label{display:block;font-family:'Montserrat';font-weight:600;font-size:20px;color:var(--fg);margin:0 0 6px}
.fnews-sub{color:var(--muted);font-size:14.5px;margin-bottom:18px}
.fnews-row{display:flex;gap:10px;flex-wrap:wrap}
.fnews-row input{flex:1;min-width:200px;background:var(--card);border:1px solid var(--line);border-radius:40px;
  padding:14px 20px;color:var(--fg);font-family:inherit;font-size:15px;transition:border-color .3s}
.fnews-row input:focus{outline:none;border-color:var(--accent)}
.fnews-row button{border:none;white-space:nowrap}
.fnews-note{color:var(--faint);font-size:12.5px;margin-top:12px}
.fcols{max-width:var(--maxw);margin:clamp(48px,7vh,80px) auto 0;display:grid;grid-template-columns:1.7fr 1fr 1fr 1.2fr;gap:36px}
.fcols h5{font-size:12px;text-transform:uppercase;letter-spacing:.14em;color:var(--accent);margin-bottom:20px;font-weight:600}
.fcols ul{list-style:none;display:flex;flex-direction:column;gap:13px;font-size:14.5px;color:#aeb6bb}
.fcols ul a:hover{color:var(--accent)}
.fcontact li{color:var(--muted);line-height:1.5}
.fbrand p{color:var(--muted);font-size:14.5px;line-height:1.6;margin-top:18px;max-width:36ch}
.fsocial{display:flex;gap:18px;margin-top:22px;font-size:13px;text-transform:uppercase;letter-spacing:.1em}
.fsocial a{color:var(--muted)}.fsocial a:hover{color:var(--accent)}
/* giant retro outlined wordmark */
.fmark{max-width:var(--maxw);margin:clamp(48px,7vh,80px) auto 0;font-family:'Montserrat';font-weight:800;
  font-size:clamp(3rem,15vw,12rem);line-height:.9;letter-spacing:-.03em;text-align:center;
  color:transparent;-webkit-text-stroke:1px rgba(89,185,255,.28);text-stroke:1px rgba(89,185,255,.28);
  user-select:none;white-space:nowrap}
.fbot{max-width:var(--maxw);margin:36px auto 0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;
  color:var(--faint);font-size:12.5px;letter-spacing:.04em;border-top:1px solid var(--line);padding-top:26px}
.flegal{display:flex;flex-wrap:wrap;gap:8px 18px;align-items:center}
.flegal a{color:var(--faint);text-decoration:none}
.flegal a:hover{color:var(--accent)}
@media(max-width:880px){.ftop{grid-template-columns:1fr}.fcols{grid-template-columns:1fr 1fr;gap:30px}}
@media(max-width:540px){.fcols{grid-template-columns:1fr}}

/* ===== LIGHT sections (white rhythm breaks) ===== */
.section--light{background:#eef3f9;color:#0b1728}
.section--light .h1,.section--light .h2,.section--light h3,.section--light h4{color:#0b1728}
.section--light .lead{color:#46586b}
.section--light .g{color:#1671c9}
.section--light .eyebrow,.section--light .cat-eyebrow{color:#1671c9}
.section--light .eyebrow::before,.section--light .cat-eyebrow::before{background:#1671c9}
.section--light .group,.section--light .vprop,.section--light .capcard,.section--light .fcard,.section--light .quote{background:#fff;border-color:#d9e3ee}
.section--light .group li b,.section--light .vprop h3,.section--light .capcard h4{color:#0b1728}
.section--light .group li span,.section--light .vprop p,.section--light .capcard p,.section--light .fcard p,.section--light .pstep p,.section--light .checks li{color:#52627a}
.section--light .group h3{color:#1671c9}
.section--light .values{background:#d9e3ee;border-color:#d9e3ee}
.section--light .val{background:#fff}.section--light .val:hover{background:#f4f8fc}
.section--light .val p{color:#52627a}.section--light .val .num,.section--light .stats .n .g{color:#1671c9}
.section--light .stats,.section--light .pstep{border-color:#cdd9e6}
.section--light .pstep::after{background:#1671c9}
.section--light .vp-ic{background:rgba(22,113,201,.09);border-color:rgba(22,113,201,.45)}
.section--light .vp-ic svg{stroke:#1671c9}
.section--light .capcard:hover,.section--light .group:hover,.section--light .vprop:hover{border-color:rgba(22,113,201,.5)}
.section--light .quote::before{color:#1671c9}
.section--light .who{color:#6b7a8d}
.section--light .capcard .more,.section--light .checks li::before{}
.section--light .checks li::before{background:rgba(22,113,201,.12);border-color:rgba(22,113,201,.5);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231671c9' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center;background-size:14px}
.section--light .btn{border-color:rgba(11,23,40,.35);color:#0b1728}
.section--light .btn .arrow{background:#0b1728;color:#fff}
.section--light .btn:hover{background:#0b1728;color:#fff;border-color:#0b1728}

/* ===== upgraded mega menu ===== */
.mega{width:min(940px,92vw);grid-template-columns:210px 1fr;gap:0;padding:0;overflow:hidden;max-height:min(74vh,560px)}
.mega__feature{background:linear-gradient(180deg,rgba(24,138,242,.16),rgba(8,14,24,.2));padding:24px 22px;display:flex;flex-direction:column;gap:11px;border-right:1px solid var(--line)}
.mega__feature h4{font-family:'Montserrat';font-weight:700;font-size:18px;line-height:1.2;color:var(--fg)}
.mega__feature p{color:var(--muted);font-size:13px;line-height:1.5;flex:1}
.mega__feature .btn{align-self:flex-start;font-size:11px;padding:9px 10px 9px 18px}
.mega__feature .btn .arrow{width:28px;height:28px;font-size:13px}
.mega__cols{display:grid;grid-template-columns:repeat(4,1fr);gap:4px 14px;padding:20px;overflow-y:auto}
.mega .col{min-width:0}
.mega .col h6{font-size:10.5px;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);margin:8px 0 4px;font-weight:600}
.mega .col a{display:block;padding:6px 8px;border-radius:8px;font-family:'Montserrat';font-weight:500;font-size:13px;line-height:1.25;color:#cdd5da;transition:background .2s,color .2s}
.mega .col a:hover{background:rgba(89,185,255,.08);color:var(--fg)}
@media(max-width:880px){
  /* mobile mega: single-column accordion (placed after upgraded-mega base so it wins) */
  .mega__feature{display:none}
  .mega{position:static;transform:none;opacity:1;visibility:visible;pointer-events:auto;width:100%;
    grid-template-columns:1fr;gap:0;background:none;border:none;box-shadow:none;backdrop-filter:none;border-radius:0;
    padding:0;max-height:0;overflow:hidden;transition:max-height .45s var(--ease)}
  .has-drop.open .mega{max-height:1600px;padding:2px 0 12px;border-bottom:1px solid var(--line)}
  .mega__cols{grid-template-columns:1fr;gap:0;padding:0 0 0 4px;overflow:visible}
  .mega .col{text-align:left;min-width:0}
  .mega .col h6{font-size:11px;margin:14px 0 2px}
  .mega .col a{font-family:'Montserrat';font-weight:500;font-size:15px;padding:9px 8px;border-radius:8px}
}

/* ===== service: enterprise "triggers/who" panel + CTA ===== */
.svc-panel{margin-top:clamp(44px,6vh,64px);border:1px solid var(--line);border-radius:24px;overflow:hidden;
  background:linear-gradient(160deg,rgba(24,138,242,.10),rgba(11,19,32,.5));position:relative}
.svc-panel__inner{padding:clamp(30px,4vw,52px)}
.svc-panel .eyebrow{margin-bottom:10px}
.svc-panel h2{margin-bottom:8px}
.svc-panel__grid{display:grid;grid-template-columns:1fr 1fr;gap:14px 30px;margin-top:30px}
.svc-panel__grid li{list-style:none;display:flex;gap:13px;align-items:flex-start;color:#d4dbe3;font-size:15.5px;line-height:1.5}
.svc-panel__grid li::before{content:'';flex:none;width:9px;height:9px;border-radius:50%;margin-top:7px;background:var(--accent);box-shadow:0 0 12px rgba(89,185,255,.6)}
.svc-panel__cta{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;
  margin-top:34px;padding-top:28px;border-top:1px solid var(--line)}
.svc-panel__cta p{font-family:'Montserrat';font-weight:600;font-size:clamp(1.05rem,2vw,1.35rem);color:var(--fg);max-width:30ch}
@media(max-width:680px){.svc-panel__grid{grid-template-columns:1fr}}

/* ===== phero: asymmetric, right-side aside ===== */
.phero .phero-2col{display:grid;grid-template-columns:1.2fr .8fr;gap:clamp(30px,5vw,64px);align-items:center}
.phero-main{min-width:0}
.phero-aside{position:relative}
@media(max-width:900px){.phero .phero-2col{grid-template-columns:1fr}.phero-aside{display:none}}

/* ===== home: interactive engines explorer ===== */
.engines{margin-top:clamp(44px,6vh,64px);display:grid;grid-template-columns:300px 1fr;gap:24px}
.engines__tabs{display:flex;flex-direction:column;gap:8px}
.engines__tab{text-align:left;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px 20px;cursor:none;
  font-family:'Montserrat';font-weight:600;font-size:17px;color:#cdd5da;transition:border-color .3s,background .3s,color .3s;display:flex;justify-content:space-between;align-items:center;gap:12px}
.engines__tab .n{font-size:12px;color:var(--faint)}
.engines__tab[aria-selected="true"]{border-color:var(--accent);background:linear-gradient(120deg,rgba(24,138,242,.16),transparent);color:var(--fg)}
.engines__tab:hover{color:var(--fg)}
.engines__panel{border:1px solid var(--line);border-radius:18px;background:var(--card);padding:clamp(24px,3vw,38px);display:none}
.engines__panel.active{display:block;animation:fadeup .4s var(--ease)}
@keyframes fadeup{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.engines__panel h3{font-family:'Montserrat';font-weight:700;font-size:clamp(1.4rem,2.6vw,2rem);margin-bottom:8px}
.engines__panel .pgrid{display:grid;grid-template-columns:1fr 1fr;gap:14px 26px;margin-top:24px}
.engines__panel .pgrid a{display:block;padding:14px 16px;border:1px solid var(--line);border-radius:12px;transition:border-color .3s,transform .3s var(--ease)}
.engines__panel .pgrid a:hover{border-color:var(--accent);transform:translateX(4px)}
.engines__panel .pgrid b{display:block;font-family:'Montserrat';font-weight:600;font-size:15px;color:var(--fg)}
.engines__panel .pgrid span{display:block;font-size:13px;color:var(--muted);margin-top:3px}
@media(max-width:820px){.engines{grid-template-columns:1fr}.engines__tabs{flex-direction:row;overflow-x:auto}.engines__tab{flex:none}.engines__panel .pgrid{grid-template-columns:1fr}}

/* ===== The Lab — interactive ===== */
.lab{position:relative;border:1px solid var(--line);border-radius:24px;overflow:hidden;margin-top:clamp(44px,6vh,64px);
  background:radial-gradient(120% 140% at 80% 0%,rgba(24,138,242,.18),rgba(8,13,22,.6));min-height:380px;display:grid;grid-template-columns:1fr 1fr}
.lab__copy{padding:clamp(30px,4vw,52px);display:flex;flex-direction:column;justify-content:center}
.lab__copy h3{font-family:'Montserrat';font-weight:700;font-size:clamp(1.6rem,3vw,2.4rem);line-height:1.1;margin-bottom:14px}
.lab__copy p{color:var(--muted);font-size:15.5px;line-height:1.65;max-width:42ch}
.lab__hint{margin-top:18px;font-size:12.5px;text-transform:uppercase;letter-spacing:.14em;color:var(--accent)}
.lab__cta{margin-top:24px}
.lab__stage{position:relative}
.lab__canvas{position:absolute;inset:0;width:100%;height:100%;display:block;cursor:none}
@media(max-width:820px){.lab{grid-template-columns:1fr}.lab__stage{min-height:300px}}

/* ===== capcard icon ===== */
.capcard .ci{width:46px;height:46px;border-radius:12px;background:rgba(89,185,255,.1);border:1px solid rgba(89,185,255,.4);display:grid;place-items:center;margin-bottom:16px}
.capcard .ci svg{width:24px;height:24px;stroke:var(--accent);fill:none;stroke-width:1.7}
.section--light .capcard .ci{background:rgba(22,113,201,.08);border-color:rgba(22,113,201,.4)}
.section--light .capcard .ci svg{stroke:#1671c9}

/* ===== close-section right visual (distinct per engine) ===== */
.viz-wrap{display:flex;justify-content:center;align-items:center}
.viz{width:100%;max-width:400px;border:1px solid var(--line);border-radius:18px;background:#0a1018;overflow:hidden;box-shadow:0 24px 60px rgba(0,0,0,.35)}
.viz__bar{display:flex;align-items:center;gap:7px;padding:11px 14px;border-bottom:1px solid var(--line);font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--muted)}
.vd{width:10px;height:10px;border-radius:50%}.vd.r{background:#ff5f57}.vd.y{background:#febc2e}.vd.g{background:#28c840}
.viz__t{margin-left:6px}
.viz__body{padding:24px}
@media(max-width:880px){.viz{max-width:none}}

/* ===== instrument-framed illustration ===== */
.viz--art{padding:0}
.viz--art .viz__stage{padding:22px;
  background-image:radial-gradient(rgba(89,185,255,.10) 1px,transparent 1px);background-size:22px 22px;
  position:relative}
.viz--art .viz__stage::after{content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(120% 90% at 100% 0,rgba(255,122,92,.10),transparent 60%)}
.viz--art svg{width:100%;height:auto;display:block;position:relative}

/* ===== LabFlow interactive widget ===== */
.labflow{border:1px solid var(--line);border-radius:14px;background:#0a1018;overflow:hidden}
.labflow .lf-bar{display:flex;align-items:center;gap:7px;padding:10px 13px;border-bottom:1px solid var(--line);font-family:'JetBrains Mono',monospace;font-size:11.5px;color:var(--muted)}
.labflow .lf-bar .vd{width:10px;height:10px;border-radius:50%}
.labflow .lf-name{margin-left:6px;color:var(--accent2)}
.labflow svg{display:block;width:100%;height:auto;padding:14px 8px 6px}
.labflow .lf-link{stroke:rgba(89,185,255,.3);stroke-width:1.5}
.labflow .lf-node circle{fill:rgba(89,185,255,.16);stroke:var(--accent2);stroke-width:1.5;transition:fill .25s,stroke .25s;cursor:pointer}
.labflow .lf-node text{fill:var(--muted);font-family:'JetBrains Mono',monospace;font-size:7px;letter-spacing:.06em}
.labflow .lf-node.on circle{fill:rgba(255,122,92,.28);stroke:var(--coral)}
.labflow .lf-node.on text{fill:var(--fg)}
.labflow .lf-tok{fill:var(--coral);transition:cx .38s linear}
.labflow .lf-cap{font-family:'JetBrains Mono',monospace;font-size:12px;line-height:1.5;color:var(--accent2);padding:12px 16px;border-top:1px solid var(--line);min-height:46px}

/* ===== related services ('pairs well with') ===== */
.rel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:30px}
.relcard{display:flex;flex-direction:column;gap:6px;border:1px solid var(--line);border-radius:14px;padding:22px;background:var(--card);position:relative;transition:border-color .3s,transform .3s var(--ease)}
.relcard:hover{border-color:var(--accent);transform:translateY(-4px)}
.relcard b{font-family:'Montserrat';font-weight:600;font-size:16px;padding-right:20px}
.relcard span{color:var(--muted);font-size:13.5px;line-height:1.45}
.relcard i{position:absolute;top:20px;right:20px;color:var(--accent);font-style:normal}
@media(max-width:820px){.rel-grid{grid-template-columns:1fr}}

/* ===== floating help bar / scripted chat ===== */
.chatbar{position:fixed;right:20px;bottom:20px;z-index:9000;display:flex;flex-direction:column;align-items:flex-end;gap:14px}
.chatbar__fab{display:inline-flex;align-items:center;gap:9px;background:var(--accent-deep);color:#fff;border:none;border-radius:40px;
  padding:14px 22px;font-family:'Montserrat';font-weight:600;font-size:14px;cursor:none;box-shadow:0 14px 34px rgba(24,138,242,.4);transition:transform .25s,background .25s}
.chatbar__fab:hover{transform:translateY(-2px);background:var(--accent);color:var(--accent-ink)}
.chatbar__dot{width:9px;height:9px;border-radius:50%;background:#46f0c0;box-shadow:0 0 10px #46f0c0}
.chatbox{width:min(360px,calc(100vw - 32px));background:#0b1320;border:1px solid var(--line);border-radius:18px;overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,.55);display:flex;flex-direction:column;max-height:min(560px,78vh)}
.chatbox[hidden]{display:none}
.chatbox__head{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid var(--line);font-family:'Montserrat';font-weight:600}
.chatbox__x{background:none;border:none;color:var(--muted);font-size:24px;line-height:1;cursor:none}
.chatbox__log{padding:16px;display:flex;flex-direction:column;gap:10px;overflow-y:auto;flex:1;font-size:14px}
.msg{max-width:86%;padding:10px 13px;border-radius:13px;line-height:1.5}
.msg--bot{background:rgba(89,185,255,.1);color:#dbe6f2;align-self:flex-start;border:1px solid var(--line)}
.msg--me{background:var(--accent-deep);color:#fff;align-self:flex-end}
.chat-cta{display:flex;flex-wrap:wrap;gap:8px;background:none!important;border:none!important;max-width:100%;padding:0}
.chat-cta a,.chat-cta button{font-size:13px;font-weight:600;color:var(--accent);background:rgba(89,185,255,.1);border:1px solid rgba(89,185,255,.4);border-radius:30px;padding:8px 14px;cursor:none}
.chat-cta a:hover,.chat-cta button:hover{background:var(--accent-deep);color:#fff}
.chatbox__chips{display:flex;flex-wrap:wrap;gap:7px;padding:0 16px 12px}
.chatbox__chips button{font-size:12.5px;color:#cdd5da;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:30px;padding:7px 12px;cursor:none;transition:border-color .25s,color .25s}
.chatbox__chips button:hover{border-color:var(--accent);color:var(--fg)}
.chatbox__form{display:flex;gap:8px;padding:12px 14px;border-top:1px solid var(--line)}
.chatbox__form input{flex:1;background:#0a1018;border:1px solid var(--line);border-radius:30px;padding:11px 15px;color:var(--fg);font-family:inherit;font-size:14px}
.chatbox__form input:focus{outline:none;border-color:var(--accent)}
.chatbox__form button{flex:none;background:var(--accent-deep);color:#fff;border:none;border-radius:50%;width:40px;height:40px;cursor:none;font-size:17px}
@media(max-width:520px){.chatbar{right:12px;bottom:12px}.chatbar__fab{padding:13px 18px;font-size:13px}}

/* ===== native cursor inside overlays (custom dot vanished over buttons) ===== */
body.modal-open .cursor{opacity:0}
.modal,.modal *,.chatbox,.chatbox *{cursor:auto!important}

/* ===== honeypot (spam trap) ===== */
.hp{position:absolute!important;left:-9999px!important;top:auto;width:1px;height:1px;overflow:hidden}

/* ===== service picker chips ===== */
.opt{color:var(--faint);font-weight:400;font-size:12px}
.chips-pick{display:flex;flex-wrap:wrap;gap:9px;margin-top:8px}
.chip{position:relative;cursor:none;display:inline-flex}
.chip input{position:absolute;opacity:0;width:0;height:0}
.chip span{display:inline-block;padding:9px 15px;border:1px solid var(--line);border-radius:30px;font-size:13.5px;color:#cdd5da;background:var(--card);transition:background .2s,border-color .2s,color .2s}
.chip input:checked+span{background:var(--accent-deep);border-color:var(--accent-deep);color:#fff}
.chip input:focus-visible+span{box-shadow:0 0 0 3px rgba(89,185,255,.4)}

/* ===== interactive FAQ (rail + answer) ===== */
.faqx{display:grid;grid-template-columns:1fr 1.05fr;gap:22px;margin-top:clamp(40px,6vh,60px)}
.faqx__rail{display:flex;flex-direction:column;gap:8px}
.faqx__q{position:relative;text-align:left;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:17px 44px 17px 18px;cursor:none;
  font-family:'Montserrat';font-weight:600;font-size:15px;color:#cdd5da;display:flex;gap:12px;align-items:center;transition:background .25s,border-color .25s,color .25s}
.faqx__num{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--accent2)}
.faqx__car{position:absolute;right:16px;color:var(--accent);opacity:0;transition:opacity .25s,transform .35s var(--ease)}
.faqx__q[aria-selected="true"]{border-color:var(--accent);background:linear-gradient(120deg,rgba(24,138,242,.16),transparent);color:var(--fg)}
.faqx__q[aria-selected="true"] .faqx__car{opacity:1;transform:rotate(45deg)}
.faqx__q:hover{color:var(--fg)}
.faqx__panel{border:1px solid var(--line);border-radius:18px;background:var(--card);padding:clamp(24px,3vw,40px);min-height:170px;display:flex;align-items:center}
.faqx__a{display:none;color:var(--muted);font-size:clamp(15px,1.5vw,17px);line-height:1.7}
.faqx__a.on{display:block;animation:fade .35s var(--ease)}
@media(max-width:820px){.faqx{grid-template-columns:1fr}.faqx__panel{min-height:0}}

/* ===== responsive: 4K up, tiny phones down ===== */
@media(min-width:1800px){:root{--maxw:1500px}html{font-size:17.5px}}
@media(min-width:2400px){:root{--maxw:1720px}html{font-size:19px}}
@media(min-width:3400px){:root{--maxw:2100px}html{font-size:22px}}
svg{max-width:100%}
@media(max-width:360px){html{font-size:15px}.btn{font-size:12px;padding:9px 10px 9px 15px}.btn .arrow{width:28px;height:28px}}

/* ===== mobile: tighten sub-page hero gap + app-style bottom tab bar ===== */
.tabbar{display:none}
@media(max-width:768px){
  .phero{padding-top:104px}
  .hero{min-height:auto;align-items:flex-start;padding:104px clamp(18px,4vw,40px) 56px}
  .tabbar{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:8500;background:rgba(8,13,22,.94);
    backdrop-filter:blur(14px);border-top:1px solid var(--line);justify-content:space-around;
    padding:8px 6px;padding-bottom:calc(8px + env(safe-area-inset-bottom))}
  .tabbar__i{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 4px;min-height:56px;
    color:var(--muted);font-family:'Montserrat';font-size:11px;font-weight:600;border:none;background:none;cursor:none;text-transform:uppercase;letter-spacing:.04em}
  .tabbar__i svg{width:23px;height:23px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
  .tabbar__i[aria-current]{color:var(--accent2)}
  .tabbar__cta{background:var(--accent-deep);border-radius:14px;color:#fff;margin:-2px 4px;flex:1.1}
  .tabbar__cta svg{stroke:#fff}
  body{padding-bottom:74px}            /* clear fixed tab bar */
  .footer{margin-bottom:0}
  .chatbar{bottom:84px}                /* lift chat FAB above the tab bar */
}

/* ===== gradient accent text ===== */
.g{background:linear-gradient(100deg,#59b9ff 0%,#188af2 45%,#8a6bff 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.section--light .g{background:none;-webkit-text-fill-color:#1671c9;color:#1671c9}
.btn .g,.chip .g{background:none;-webkit-text-fill-color:currentColor;color:currentColor}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition-duration:.01ms!important}
  .reveal,.anim-up{opacity:1;transform:none}
}
