/* GeneXBit site — shared styles. Self-contained, no external CDN. */

@font-face{
  font-family:"Fraunces";
  src:url("assets/fonts/fraunces.woff2") format("woff2");
  font-weight:300 700;font-style:normal;font-display:swap;
}
@font-face{
  font-family:"DM Sans";
  src:url("assets/fonts/dmsans.woff2") format("woff2");
  font-weight:300 700;font-style:normal;font-display:swap;
}

*{box-sizing:border-box;margin:0;padding:0}

:root{
  --ink:#0C1733;--ink2:#14224A;--ink3:#0A1228;--blue:#2E7DF0;--blue-d:#1F6BDD;
  --sky:#7DB0F7;--paper:#F6F8FC;--line:#E4EAF3;--text:#0C1733;--muted:#5A678A;
  --green:#2FB574;--amber:#F5A623;--red:#E5484D;
  --on-dark:#E2E8F0;--on-dark-soft:#B9C6E4;--on-dark-mute:#8FA2C9;
  --disp:"Fraunces",Georgia,"Times New Roman",serif;
  --sans:"DM Sans",system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --mono:"SF Mono","Cascadia Code",ui-monospace,Consolas,monospace;
  --shadow:0 30px 60px rgba(9,18,42,.35);
  --radius:18px;
}

html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--text);line-height:1.6;background:var(--paper);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}

.wrap{max-width:1120px;margin:0 auto;padding:0 28px}
a{color:inherit;text-decoration:none}
img,svg{max-width:100%}

.eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:2.5px;text-transform:uppercase;color:var(--blue)}
.eyebrow.on-dark{color:var(--sky)}

h1,h2,h3,.disp{font-family:var(--disp);font-weight:600;letter-spacing:-.5px;line-height:1.08}
h1{font-size:clamp(38px,5.4vw,60px);text-wrap:balance}
h2{font-size:clamp(28px,3.6vw,38px);text-wrap:balance}
h3{font-size:19px;letter-spacing:-.2px}

/* ---------- Top nav (sticky, all pages) ---------- */
.topbar{position:sticky;top:0;z-index:50;background:rgba(10,18,40,.82);
  backdrop-filter:saturate(140%) blur(12px);-webkit-backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid rgba(125,176,247,.16)}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{font-family:var(--sans);font-size:21px;font-weight:700;letter-spacing:-.4px;color:#EAF0FB}
.brand b{color:var(--sky);font-weight:700}
.navlinks{display:flex;align-items:center;gap:28px}
.navlinks a{font-size:14.5px;color:var(--on-dark-soft);transition:color .18s}
.navlinks a:hover{color:#fff}
.navlinks a.active{color:#fff}
.navlinks a.active::after{content:"";display:block;height:2px;border-radius:2px;background:var(--blue);margin-top:5px}
.nav-cta{font-family:var(--sans);font-weight:600;font-size:14px;padding:9px 16px;border-radius:10px;
  background:var(--blue);color:#fff;transition:background .2s,transform .12s}
.nav-cta:hover{background:var(--blue-d);transform:translateY(-1px);color:#fff}
.menu-btn{display:none}

/* ---------- Buttons ---------- */
.btn{display:inline-block;font-family:var(--sans);font-weight:600;font-size:15px;padding:13px 24px;
  border-radius:12px;cursor:pointer;border:1px solid transparent;transition:transform .12s,background .2s,border-color .2s}
.btn.primary{background:var(--blue);color:#fff}
.btn.primary:hover{transform:translateY(-2px);background:var(--blue-d);color:#fff}
.btn.ghost{border-color:rgba(255,255,255,.28);color:var(--on-dark)}
.btn.ghost:hover{border-color:#fff}
.btn.dark{background:var(--ink);color:#fff}
.btn.dark:hover{transform:translateY(-2px);background:var(--ink2)}

/* ---------- Dark hero band (inner pages) ---------- */
.band{position:relative;background:var(--ink);color:var(--on-dark);overflow:hidden}
.band::before{content:"";position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(125,176,247,.14) 1.1px,transparent 1.2px);background-size:24px 24px;opacity:.6}
.band::after{content:"";position:absolute;right:-160px;top:-180px;width:520px;height:520px;
  background:radial-gradient(closest-side,rgba(46,125,240,.26),transparent 70%)}
.band .inner{position:relative;padding:66px 0 70px}
.band h1{margin-top:14px}
.band .lede{color:var(--on-dark-soft);font-size:18px;max-width:36em;margin-top:16px}

/* ---------- Sections ---------- */
.sec{padding:76px 0}
.sec.tight{padding:56px 0}
.sec.white{background:#fff;border-top:1px solid var(--line)}
.sec .lead{color:var(--muted);font-size:17px;max-width:36em;margin-top:14px}
.center{text-align:center;margin-left:auto;margin-right:auto}

/* ---------- Cards / grids ---------- */
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:36px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:36px}
.feat{background:#fff;border:1px solid var(--line);border-radius:16px;padding:24px;transition:transform .18s,box-shadow .18s,border-color .18s}
.feat:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(12,23,51,.09);border-color:#D3E0F6}
.feat .ic{width:40px;height:40px;border-radius:11px;background:#EAF1FE;color:var(--blue);
  display:grid;place-items:center;font-weight:700;font-family:var(--mono);font-size:15px}
.feat h3{margin:16px 0 7px}
.feat p{color:var(--muted);font-size:14.5px}

/* ---------- Reveal on scroll ---------- */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  *{animation:none !important}
  html{scroll-behavior:auto}
}

/* ---------- Footer ---------- */
footer{background:#08122A;color:var(--on-dark-mute);font-size:13.5px}
footer .fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:28px;padding:44px 28px 22px}
footer .brand{font-size:19px;margin-bottom:10px}
footer h5{color:#CFD9EF;font-size:13px;letter-spacing:.4px;margin-bottom:12px;font-weight:600}
footer a{display:block;color:var(--on-dark-mute);margin:7px 0;transition:color .18s}
footer a:hover{color:#fff}
footer .tag{color:var(--on-dark-mute);margin-top:8px;max-width:28em;line-height:1.6}
footer .fbot{border-top:1px solid rgba(125,176,247,.14);padding:16px 28px;display:flex;
  justify-content:space-between;flex-wrap:wrap;gap:8px;max-width:1120px;margin:0 auto}
footer b{color:#CFD9EF;font-weight:600}

/* ---------- Responsive ---------- */
@media (max-width:860px){
  .grid3,.grid2{grid-template-columns:1fr}
  .navlinks{display:none}
  footer .fgrid{grid-template-columns:1fr 1fr}
}

/* ================= HOME HERO ================= */
.hero{position:relative;background:var(--ink);color:var(--on-dark);overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(125,176,247,.14) 1.1px,transparent 1.2px);background-size:24px 24px;opacity:.55}
.hero::after{content:"";position:absolute;left:-180px;bottom:-200px;width:560px;height:560px;
  background:radial-gradient(closest-side,rgba(46,125,240,.22),transparent 70%)}
.heroGrid{position:relative;display:grid;grid-template-columns:1.02fr .98fr;gap:44px;align-items:center;padding:60px 0 84px}
.hero .lede{color:var(--on-dark-soft);font-size:18px;max-width:31em;margin-top:18px}
.hero .cta{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap}
.hero .stores{margin-top:22px;font-family:var(--mono);font-size:12px;color:var(--on-dark-mute);letter-spacing:.5px}
.hero .trustrow{display:flex;gap:22px;margin-top:26px;flex-wrap:wrap}
.hero .trustrow span{font-size:13px;color:var(--on-dark-soft);display:flex;align-items:center;gap:7px}
.hero .trustrow .tick{color:var(--green);font-weight:700}
@media (max-width:860px){.heroGrid{grid-template-columns:1fr;gap:30px;padding:36px 0 56px}.mapwrap{order:-1}}

/* ================= ILLUSTRATED MAP ================= */
.mapwrap{position:relative;border-radius:22px;overflow:hidden;
  border:1px solid rgba(125,176,247,.22);box-shadow:var(--shadow);background:#0f1e42}
.mapwrap svg{display:block;width:100%;height:auto}
.map-chip{position:absolute;background:rgba(11,23,51,.86);backdrop-filter:blur(6px);
  border:1px solid rgba(125,176,247,.28);border-radius:12px;padding:9px 12px;display:flex;align-items:center;gap:9px;
  font-size:13px;color:#EAF0FB;box-shadow:0 10px 24px rgba(0,0,0,.3)}
.map-chip .av{width:26px;height:26px;border-radius:8px;display:grid;place-items:center;font-weight:700;color:#fff;font-size:12px;font-family:var(--sans)}
.map-chip .who{font-weight:600;font-family:var(--sans)}
.map-chip .ago{font-family:var(--mono);font-size:11px;color:var(--on-dark-mute)}
.chip-child{top:14px;left:14px}
.chip-place{bottom:14px;right:14px;font-family:var(--mono);font-size:11.5px;letter-spacing:.4px;color:var(--sky)}

/* map: self-drawing route */
.route{fill:none;stroke:var(--blue);stroke-width:4;stroke-linecap:round;
  stroke-dasharray:520;stroke-dashoffset:520;animation:draw 2.6s ease forwards .3s}
.route-ghost{fill:none;stroke:rgba(125,176,247,.18);stroke-width:4;stroke-linecap:round}
@keyframes draw{to{stroke-dashoffset:0}}
/* marker traveling the route */
.mover{offset-path:path("M92 300 C150 250 150 250 210 250 C300 250 300 150 380 132");
  offset-rotate:0deg;animation:move 2.6s ease forwards .3s}
@keyframes move{from{offset-distance:0%}to{offset-distance:100%}}
/* sonar pulse on child pin */
.sonar{transform-origin:center;transform-box:fill-box;animation:sonar 2.2s ease-out infinite 2.8s}
@keyframes sonar{0%{transform:scale(.4);opacity:.7}80%{opacity:0}100%{transform:scale(2.6);opacity:0}}
.pin-glow{filter:drop-shadow(0 0 10px rgba(46,125,240,.9))}
/* breathing geofence */
.geo{transform-origin:center;transform-box:fill-box;animation:breathe 4s ease-in-out infinite}
@keyframes breathe{0%,100%{transform:scale(1);opacity:.85}50%{transform:scale(1.05);opacity:1}}
/* marching-ants safe-zone border */
.ants{fill:rgba(47,181,116,.08);stroke:var(--green);stroke-width:2.5;stroke-dasharray:7 7;
  animation:ants 12s linear infinite}
@keyframes ants{to{stroke-dashoffset:-140}}

/* ================= FEATURE VISUAL TILES ================= */
.vtile{background:#0f1e42;border:1px solid rgba(125,176,247,.2);border-radius:18px;overflow:hidden;
  color:var(--on-dark);display:flex;flex-direction:column}
.vtile .art{position:relative;aspect-ratio:16/10;background:radial-gradient(120% 120% at 30% 0%,#14224A,#0b1836);
  display:grid;place-items:center;overflow:hidden}
.vtile .art svg{width:82%;height:auto}
.vtile .cap{padding:18px 20px 22px}
.vtile .cap h3{color:#EEF3FD}
.vtile .cap p{color:var(--on-dark-soft);font-size:14px;margin-top:6px}
.vtile .k{font-family:var(--mono);font-size:11px;letter-spacing:1.6px;text-transform:uppercase;color:var(--sky)}

/* SOS urgent pulse */
.sos-ring{transform-origin:center;transform-box:fill-box;animation:sos 1.1s ease-out infinite}
@keyframes sos{0%{transform:scale(.6);opacity:.85}100%{transform:scale(2.2);opacity:0}}
/* battery drain */
.batt-fill{transform-origin:left center;transform-box:fill-box;animation:drain 5s ease-in-out infinite}
@keyframes drain{0%{transform:scaleX(1);fill:var(--green)}70%{fill:var(--amber)}100%{transform:scaleX(.18);fill:var(--red)}}
/* count-up-ish timeline dots */
.tl-dot{opacity:0;animation:pop .5s ease forwards}
.tl-dot:nth-child(1){animation-delay:.2s}.tl-dot:nth-child(2){animation-delay:.6s}
.tl-dot:nth-child(3){animation-delay:1s}.tl-dot:nth-child(4){animation-delay:1.4s}
@keyframes pop{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
/* constellation twinkle */
.tw{animation:tw 3s ease-in-out infinite}
.tw:nth-child(2){animation-delay:.6s}.tw:nth-child(3){animation-delay:1.2s}.tw:nth-child(4){animation-delay:1.8s}
@keyframes tw{0%,100%{opacity:.55}50%{opacity:1}}

/* ================= WAITLIST FORM ================= */
.wait{max-width:520px;margin:30px auto 0;display:flex;gap:10px;flex-wrap:wrap}
.wait input[type=email]{flex:1;min-width:220px;font-family:var(--sans);font-size:15px;padding:14px 16px;
  border-radius:12px;border:1px solid var(--line);background:#fff;color:var(--text)}
.wait input[type=email]:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(46,125,240,.16)}
.wait .btn{white-space:nowrap}
.wait.on-dark input[type=email]{background:rgba(255,255,255,.06);border-color:rgba(125,176,247,.3);color:#fff}
.wait.on-dark input[type=email]::placeholder{color:var(--on-dark-mute)}
.hp{position:absolute;left:-9999px}
.formnote{font-size:12.5px;color:var(--muted);margin-top:12px}
.band .formnote{color:var(--on-dark-mute)}

/* ================= PRICING PLACEHOLDER ================= */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:40px}
.tier{background:#fff;border:1px solid var(--line);border-radius:18px;padding:28px 24px;position:relative;display:flex;flex-direction:column}
.tier.hot{border-color:var(--blue);box-shadow:0 20px 44px rgba(46,125,240,.16)}
.tier .badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--blue);color:#fff;
  font-family:var(--mono);font-size:11px;letter-spacing:1px;text-transform:uppercase;padding:5px 12px;border-radius:20px}
.tier h3{font-size:20px}
.tier .price{font-family:var(--disp);font-size:34px;color:var(--ink);margin:12px 0 2px}
.tier .price small{font-family:var(--sans);font-size:14px;color:var(--muted);font-weight:400}
.tier .soon{font-family:var(--mono);font-size:12px;letter-spacing:1px;color:var(--amber);text-transform:uppercase}
.tier ul{list-style:none;margin:18px 0 24px}
.tier li{font-size:14.5px;color:var(--muted);padding:7px 0 7px 26px;position:relative}
.tier li::before{content:"✓";position:absolute;left:0;color:var(--green);font-weight:700}
.tier .btn{margin-top:auto}
@media (max-width:860px){.tiers{grid-template-columns:1fr}}

/* privacy "can't not won't" blocks */
.pcard{background:#fff;border:1px solid var(--line);border-radius:16px;padding:26px}
.pcard .k{font-family:var(--mono);font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--green)}
.pcard h3{margin:10px 0 8px}
.pcard p{color:var(--muted);font-size:15px}
.callout{background:var(--ink);color:var(--on-dark);border-radius:20px;padding:34px 32px;margin-top:36px;position:relative;overflow:hidden}
.callout::after{content:"";position:absolute;right:-120px;top:-120px;width:360px;height:360px;
  background:radial-gradient(closest-side,rgba(47,181,116,.22),transparent 70%)}
.callout .big{font-family:var(--disp);font-size:clamp(22px,3vw,30px);line-height:1.25;position:relative;max-width:20em}
.callout .big em{color:var(--green);font-style:normal}

/* maplib map animations */
.gx-geo{transform-box:fill-box;transform-origin:center;animation:gxbr 4s ease-in-out infinite}
@keyframes gxbr{0%,100%{transform:scale(1);opacity:.85}50%{transform:scale(1.06);opacity:1}}
.gx-ants{animation:gxants 12s linear infinite}
@keyframes gxants{to{stroke-dashoffset:-140}}
.gx-sonar{transform-box:fill-box;transform-origin:center;animation:gxso 2.2s ease-out infinite}
@keyframes gxso{0%{transform:scale(.4);opacity:.7}80%{opacity:0}100%{transform:scale(2.6);opacity:0}}
