/* ============================================================================
   IONITY GLOBAL — Design System  ·  ionity.css
   www.ionity.today · Policy 986 AED
   Native-AI · AIoT · Cloud · Edge · Audit & Forensics
   Author: built for Johan Wilhelm van Antwerp / Ionity Global (Pty) Ltd
   A single, lean, dependency-free design system. No frameworks. No bloat.
   ========================================================================== */

/* ---------------------------------------------------------------- TOKENS -- */
:root {
  /* core brand */
  --bg:            #07080D;
  --bg-2:          #0A0B12;
  --surface:       #0E1018;
  --surface-2:     #12141F;
  --line:          rgba(255,255,255,.08);
  --line-strong:   rgba(120,170,255,.28);

  --text:          #EEF2FB;
  --muted:         #99A4B8;
  --faint:         #5C6678;

  /* official brand: IONITY blue + GLOBAL orange (sampled from the logo) */
  --blue:          #0079E3;
  --blue-deep:     #0A51AB;
  --cyan:          #00D2FF;
  --ice:           #9FD8FF;
  --orange:        #FF9500;
  --amber:         #FFB23E;
  --violet:        #7A5CFF;
  --warn:          #FF9500;
  --good:          #2BE5A0;
  --bad:           #FF2828;
  --live:          #FF2828;

  --grad:          linear-gradient(120deg, var(--blue), var(--cyan));
  --grad-warm:     linear-gradient(120deg, var(--orange), var(--amber));
  --grad-bi:       linear-gradient(120deg, var(--blue) 0%, var(--cyan) 55%, var(--orange) 130%);
  --grad-soft:     linear-gradient(120deg, rgba(0,121,227,.18), rgba(0,210,255,.16));
  --glow:          0 0 24px rgba(0,210,255,.35);
  --glow-blue:     0 0 30px rgba(0,121,227,.5);
  --glow-orange:   0 0 26px rgba(255,149,0,.45);

  /* type */
  --f-display: "Space Grotesk", "Segoe UI", system-ui, sans-serif;
  --f-body:    "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --f-mono:    "JetBrains Mono", ui-monospace, "Cascadia Code", Consolas, monospace;

  /* scale */
  --step--1: clamp(.78rem,.74rem + .2vw,.86rem);
  --step-0:  clamp(.95rem,.9rem + .25vw,1.05rem);
  --step-1:  clamp(1.2rem,1.05rem + .6vw,1.5rem);
  --step-2:  clamp(1.6rem,1.3rem + 1.4vw,2.4rem);
  --step-3:  clamp(2.2rem,1.6rem + 3vw,4rem);
  --step-4:  clamp(2.8rem,1.8rem + 5.2vw,6.5rem);

  --maxw:    1240px;
  --gutter:  clamp(1.1rem, 5vw, 3.5rem);
  --radius:  18px;
  --radius-s:12px;
  --ease:    cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);

  --nav-h:   84px;
  color-scheme: dark;
}

/* ----------------------------------------------------------------- RESET -- */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body {
  font-family:var(--f-body);
  font-size:var(--step-0);
  line-height:1.6;
  color:var(--text);
  background:var(--bg);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg,video { display:block; max-width:100%; height:auto; }
a { color:inherit; text-decoration:none; }
button { font:inherit; cursor:pointer; border:none; background:none; color:inherit; }
ul { list-style:none; }
:focus-visible { outline:2px solid var(--cyan); outline-offset:3px; border-radius:4px; }
::selection { background:rgba(0,210,255,.3); color:#fff; }

/* persistent ambient backdrop --------------------------------------------- */
.bg-field {
  position:fixed; inset:0; z-index:-2; pointer-events:none;
  background:
    radial-gradient(60vw 60vw at 12% -8%, rgba(51,102,255,.16), transparent 60%),
    radial-gradient(50vw 50vw at 92% 8%, rgba(0,210,255,.12), transparent 60%),
    radial-gradient(70vw 70vw at 50% 120%, rgba(122,92,255,.10), transparent 60%),
    var(--bg);
}
.bg-grid {
  position:fixed; inset:0; z-index:-1; pointer-events:none; opacity:.5;
  background-image:
    linear-gradient(rgba(120,170,255,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(120,170,255,.045) 1px, transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(circle at 50% 30%, #000 0%, transparent 78%);
          mask-image:radial-gradient(circle at 50% 30%, #000 0%, transparent 78%);
}

/* ------------------------------------------------------------- TYPOGRAPHY -- */
h1,h2,h3,h4 { font-family:var(--f-display); font-weight:700; line-height:1.05; letter-spacing:-.02em; }
h1 { font-size:var(--step-4); }
h2 { font-size:var(--step-3); }
h3 { font-size:var(--step-2); }
p  { color:var(--muted); }
.lead { font-size:var(--step-1); color:var(--text); opacity:.92; }
.grad-text { background:var(--grad-bi); -webkit-background-clip:text; background-clip:text; color:transparent; }
.warm-text { background:var(--grad-warm); -webkit-background-clip:text; background-clip:text; color:transparent; }
.orange { color:var(--orange); }
.kicker {
  font-family:var(--f-mono); font-size:var(--step--1); letter-spacing:.32em;
  text-transform:uppercase; color:var(--cyan); display:inline-flex; align-items:center; gap:.6rem;
}
.kicker::before { content:""; width:26px; height:1px; background:var(--cyan); opacity:.7; }

/* ----------------------------------------------------------------- LAYOUT -- */
.wrap { width:min(100% - 2*var(--gutter), var(--maxw)); margin-inline:auto; }
section { padding-block:clamp(4rem,9vw,8rem); position:relative; }
.section-head { max-width:62ch; margin-bottom:clamp(2rem,5vw,3.5rem); }
.section-head p { margin-top:1rem; }
.grid { display:grid; gap:1.4rem; }
.cols-2 { grid-template-columns:repeat(2,1fr); }
.cols-3 { grid-template-columns:repeat(3,1fr); }
.cols-4 { grid-template-columns:repeat(4,1fr); }
@media (max-width:900px){ .cols-3,.cols-4 { grid-template-columns:repeat(2,1fr); } }
@media (max-width:620px){ .cols-2,.cols-3,.cols-4 { grid-template-columns:1fr; } }

/* --------------------------------------------------------------------- NAV -- */
.nav {
  position:fixed; top:0; left:0; width:100%; height:var(--nav-h); z-index:1000;
  display:flex; align-items:center; justify-content:space-between;
  padding-inline:var(--gutter);
  background:rgba(7,8,13,.55);
  -webkit-backdrop-filter:blur(16px) saturate(140%); backdrop-filter:blur(16px) saturate(140%);
  border-bottom:1px solid transparent; transition:background .4s, border-color .4s;
}
.nav.scrolled { background:rgba(7,8,13,.9); border-bottom-color:var(--line); }
.brand { display:flex; align-items:center; gap:.7rem; }
.brand .wm { height:58px; width:auto; filter:drop-shadow(0 0 10px rgba(0,121,227,.35)) drop-shadow(0 0 22px rgba(0,210,255,.18)); transition:filter .3s, transform .3s var(--ease-out); }
.brand:hover .wm { filter:drop-shadow(0 0 14px rgba(255,149,0,.5)) drop-shadow(0 0 26px rgba(0,210,255,.3)); transform:translateY(-1px) scale(1.02); }
.foot .brand .wm { height:40px; }
.nav-links { display:flex; align-items:center; gap:1.6rem; }
.nav-links a {
  font-family:var(--f-mono); font-size:.66rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--muted); position:relative; padding:.4rem 0; transition:color .25s;
}
.nav-links a:hover, .nav-links a[aria-current="page"] { color:var(--text); }
.nav-links a::after {
  content:""; position:absolute; left:0; bottom:-2px; height:1px; width:0; background:var(--grad);
  transition:width .3s var(--ease);
}
.nav-links a:hover::after, .nav-links a[aria-current="page"]::after { width:100%; }
.nav-cta { display:flex; align-items:center; gap:.6rem; }

/* nav controls (audio / menu) */
.icon-btn {
  width:38px; height:38px; display:grid; place-items:center; border-radius:50%;
  border:1px solid var(--line); color:var(--muted); transition:.25s;
}
.icon-btn svg { width:18px; height:18px; }
.icon-btn.burger svg { width:20px; height:20px; }
.icon-btn:hover { color:var(--cyan); border-color:var(--line-strong); box-shadow:var(--glow); }
.icon-btn.on { color:var(--cyan); border-color:var(--cyan); }
.burger { display:none; }

@media (max-width:880px){
  .nav-links {
    position:fixed; inset:var(--nav-h) 0 auto 0; flex-direction:column; gap:0;
    background:rgba(7,8,13,.98); border-bottom:1px solid var(--line);
    max-height:0; overflow:hidden; transition:max-height .45s var(--ease); padding:0 var(--gutter);
  }
  .nav-links.open { max-height:80vh; padding-block:1.2rem; }
  .nav-links a { width:100%; padding:1rem 0; font-size:.8rem; border-bottom:1px solid var(--line); }
  .burger { display:grid; }
}

/* ------------------------------------------------------------- BUTTONS ----- */
.btn {
  display:inline-flex; align-items:center; gap:.55rem; padding:.85rem 1.5rem;
  border-radius:999px; font-family:var(--f-mono); font-size:.74rem; letter-spacing:.12em;
  text-transform:uppercase; font-weight:600; transition:.3s var(--ease); position:relative; isolation:isolate;
}
.btn-primary { background:var(--grad); color:#04060f; box-shadow:var(--glow-blue); }
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 0 40px rgba(0,210,255,.6); }
.btn-ghost { border:1px solid var(--line-strong); color:var(--text); }
.btn-ghost:hover { background:var(--grad-soft); border-color:var(--cyan); transform:translateY(-2px); }
.btn-warm { background:var(--grad-warm); color:#1a1000; box-shadow:var(--glow-orange); }
.btn-warm:hover { transform:translateY(-2px); box-shadow:0 0 40px rgba(255,149,0,.6); }
.btn svg { width:16px; height:16px; }
.pill.live .dot { background:var(--live); box-shadow:0 0 10px var(--live); }

/* --------------------------------------------------------------- BADGES ---- */
.pill {
  display:inline-flex; align-items:center; gap:.5rem; padding:.4rem .9rem; border-radius:999px;
  border:1px solid var(--line); background:rgba(255,255,255,.02);
  font-family:var(--f-mono); font-size:.66rem; letter-spacing:.12em; text-transform:uppercase; color:var(--muted);
}
.pill .dot { width:7px; height:7px; border-radius:50%; background:var(--good); box-shadow:0 0 10px var(--good); animation:pulse 2s infinite; }
@keyframes pulse { 50% { opacity:.35; } }

/* --------------------------------------------------------------- CARDS ----- */
.card {
  position:relative; padding:1.8rem; border-radius:var(--radius);
  background:linear-gradient(160deg, var(--surface), var(--bg-2));
  border:1px solid var(--line); overflow:hidden; transition:transform .4s var(--ease), border-color .4s;
}
.card::before {
  content:""; position:absolute; inset:0; border-radius:inherit; padding:1px;
  background:var(--grad); -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude; opacity:0; transition:opacity .4s;
}
.card:hover { transform:translateY(-6px); }
.card:hover::before { opacity:.8; }
.card .ico {
  width:52px; height:52px; border-radius:14px; display:grid; place-items:center; margin-bottom:1.1rem;
  background:var(--grad-soft); border:1px solid var(--line-strong); color:var(--cyan);
}
.card .ico svg { width:26px; height:26px; }
.card h3 { font-size:var(--step-1); margin-bottom:.5rem; }
.card p { font-size:var(--step--1); }
.card .tag-row { display:flex; flex-wrap:wrap; gap:.4rem; margin-top:1.1rem; }
.card .tag { font-family:var(--f-mono); font-size:.6rem; letter-spacing:.1em; text-transform:uppercase;
  color:var(--ice); padding:.25rem .6rem; border:1px solid var(--line); border-radius:6px; }

/* glow border feature card */
.feature {
  display:grid; gap:1.5rem; align-items:center; padding:clamp(1.6rem,4vw,3rem);
  border-radius:var(--radius); border:1px solid var(--line);
  background:radial-gradient(120% 140% at 0% 0%, rgba(51,102,255,.10), transparent 50%), var(--surface);
}
@media (min-width:860px){ .feature.split { grid-template-columns:1.1fr .9fr; } }

/* ------------------------------------------------------ IMMERSIVE / ACTS --- */
.hero {
  min-height:100svh; display:grid; place-items:center; text-align:center;
  padding-top:var(--nav-h); position:relative; overflow:hidden;
}
.hero .inner { max-width:62ch; z-index:2; padding-inline:var(--gutter); }
.hero-wm { width:min(78vw,520px); margin:0 auto 1.6rem; filter:drop-shadow(0 0 40px rgba(0,121,227,.45)); animation:wmIn 1s var(--ease-out) both; }
@keyframes wmIn { from { opacity:0; transform:translateY(14px) scale(.98); filter:drop-shadow(0 0 0 transparent); } }
.hero h1 { margin:.6rem 0 1.2rem; font-size:clamp(2rem,1.4rem + 3.4vw,4.4rem); }
.hero .lead { margin-inline:auto; max-width:46ch; }
.hero .cta-row { margin-top:2rem; display:flex; gap:.9rem; justify-content:center; flex-wrap:wrap; }
.hero-stats { margin-top:3rem; display:flex; gap:clamp(1rem,4vw,3rem); justify-content:center; flex-wrap:wrap; }
.hero-stats .n { font-family:var(--f-display); font-size:var(--step-2); font-weight:700; }
.hero-stats .l { font-family:var(--f-mono); font-size:.6rem; letter-spacing:.2em; text-transform:uppercase; color:var(--faint); }

/* rotating orbital visual behind hero */
.orbit-field { position:absolute; inset:0; z-index:1; pointer-events:none; display:grid; place-items:center; opacity:.55; }
.orbit-field .ring { position:absolute; border:1px solid var(--line-strong); border-radius:50%; }
.orbit-field .r1 { width:min(70vw,640px); aspect-ratio:1; animation:spin 38s linear infinite; }
.orbit-field .r2 { width:min(48vw,440px); aspect-ratio:1; animation:spin 26s linear infinite reverse; border-color:rgba(0,210,255,.22); }
.orbit-field .r3 { width:min(30vw,280px); aspect-ratio:1; animation:spin 18s linear infinite; }
.orbit-field .sat { position:absolute; width:10px; height:10px; border-radius:50%; background:var(--cyan); box-shadow:var(--glow); top:0; left:50%; }
@keyframes spin { to { transform:rotate(360deg); } }

/* ===== PORTAL HERO — AEDi centred (focal) · IO // WAY in the left corner == */
.portal-hero { display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center;
  gap:clamp(.7rem,1.8vw,1.3rem); padding-block:calc(var(--nav-h) + .5rem) 3rem; position:relative; }
.portal-id { z-index:3; padding-inline:var(--gutter); }
.portal-id .hero-wm { width:min(56vw,340px); margin-bottom:.5rem; }

.portal { display:flex; flex-direction:column; align-items:center; text-align:center; gap:.45rem; }
.portal-main { z-index:3; }
.portal-kicker { font-family:var(--f-mono); font-size:.7rem; letter-spacing:.34em; text-transform:uppercase; color:var(--cyan); }
.portal-main h2 { font-size:clamp(1.3rem,.9rem + 1.7vw,2.15rem); line-height:1.12; letter-spacing:-.01em; margin:.1rem 0 .25rem; }
.portal-main p { font-size:var(--step--1); color:var(--muted); max-width:40ch; margin:.65rem auto 0; }
.aedi-cta { margin-top:1.3rem; }

/* IO // WAY — compact card, lower-left, lifted to sit above the floating AEDi launcher */
.portal-corner { position:absolute; left:clamp(1rem,4vw,3.2rem); bottom:clamp(92px,15vh,150px); z-index:3;
  display:flex; align-items:center; gap:.85rem; text-align:left; padding:.7rem .95rem;
  border:1px solid var(--line); border-radius:var(--radius); background:rgba(10,12,20,.42);
  -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px);
  transition:border-color .3s, transform .3s var(--ease-out), background .3s; }
.portal-corner:hover { border-color:var(--orange); transform:translateY(-2px); background:rgba(10,12,20,.62); }
.portal-corner-orbit { position:relative; width:46px; height:46px; flex:none; border-radius:50%;
  border:1px solid rgba(255,255,255,.08); border-top:2px solid var(--orange); border-left:1px solid var(--amber);
  box-shadow:0 0 10px rgba(255,149,0,.3); animation:spin 5s linear infinite; }
.portal-corner-orbit::after { content:""; position:absolute; inset:5px; border-radius:50%;
  border:1px solid transparent; border-top:1px solid rgba(255,255,255,.5); animation:spin 3.5s linear infinite reverse; }
.portal-corner-text { display:flex; flex-direction:column; gap:.18rem; }
.portal-corner .portal-kicker { font-size:.58rem; letter-spacing:.26em; }
.portal-corner-title { font-family:var(--f-display); font-size:.95rem; font-weight:600; line-height:1.15; color:var(--text); }
.portal-corner-cue { font-family:var(--f-mono); font-size:.56rem; letter-spacing:.12em; text-transform:uppercase; color:var(--faint); display:inline-flex; align-items:center; gap:.35rem; transition:color .3s; }
.portal-corner-cue svg { width:12px; height:12px; }
.portal-corner:hover .portal-corner-cue { color:var(--orange); }

/* the orbit-ring portal button (faithful to the old site, new palette) */
.portal-btn { position:relative; width:clamp(120px,16vw,160px); aspect-ratio:1; border:none; background:transparent;
  cursor:pointer; display:grid; place-items:center; border-radius:50%; transition:transform .3s var(--ease-out); }
.portal-btn-lg { width:clamp(140px,16vw,172px); }
.portal-btn:hover { transform:scale(1.06); }
.portal-btn:focus-visible { outline:2px solid var(--cyan); outline-offset:8px; }
.portal-orbit { position:absolute; inset:0; border-radius:50%;
  border:1px solid rgba(255,255,255,.06); border-top:2px solid var(--blue); border-left:1px solid var(--cyan);
  box-shadow:0 0 12px rgba(0,121,227,.25); animation:spin 4s linear infinite, portalGlow 3s ease-in-out infinite; }
.portal-orbit::after { content:""; position:absolute; inset:6px; border-radius:50%;
  border:1px solid transparent; border-top:1px solid rgba(255,255,255,.5); animation:spin 3s linear infinite reverse; }
.portal-scan { position:absolute; inset:-22%; border-radius:50%; pointer-events:none;
  border:1px dashed rgba(0,210,255,.18); border-left:1px solid rgba(0,210,255,.4); border-right:1px solid rgba(0,210,255,.4);
  animation:spin 12s linear infinite reverse; }
.portal-scan::before { content:""; position:absolute; top:-2px; left:50%; width:5px; height:5px; border-radius:50%;
  background:var(--cyan); box-shadow:0 0 10px var(--cyan); }
.portal-core { position:relative; z-index:2; font-family:var(--f-mono); font-size:.72rem; font-weight:600;
  letter-spacing:.14em; text-transform:uppercase; color:var(--text); line-height:1.25; text-shadow:0 0 12px rgba(0,210,255,.4); transition:.3s; }
.portal-btn:hover .portal-core { letter-spacing:.2em; text-shadow:0 0 18px rgba(0,210,255,.9); }

/* warm (orange) variant for IO // WAY */
.portal-io .portal-kicker { color:var(--orange); }
.portal-btn-warm .portal-orbit { border-top-color:var(--orange); border-left-color:var(--amber); box-shadow:0 0 12px rgba(255,149,0,.3); animation:spin 4s linear infinite, portalGlowWarm 3s ease-in-out infinite; }
.portal-btn-warm .portal-scan { border-left-color:rgba(255,178,62,.5); border-right-color:rgba(255,178,62,.5); }
.portal-btn-warm .portal-scan::before { background:var(--orange); box-shadow:0 0 10px var(--orange); }

@keyframes portalGlow { 0%,100%{box-shadow:0 0 10px rgba(0,121,227,.2); border-top-color:var(--blue);} 50%{box-shadow:0 0 28px rgba(0,210,255,.5); border-top-color:#fff;} }
@keyframes portalGlowWarm { 0%,100%{box-shadow:0 0 10px rgba(255,149,0,.2); border-top-color:var(--orange);} 50%{box-shadow:0 0 28px rgba(255,178,62,.55); border-top-color:#fff;} }

.portal-skip { z-index:3; font-family:var(--f-mono); font-size:.66rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--muted); display:inline-flex; align-items:center; gap:.5rem; transition:color .25s; }
.portal-skip:hover { color:var(--cyan); }
.portal-skip svg { width:14px; height:14px; }

@media (max-width:760px){
  .portal-hero { min-height:auto; padding-block:calc(var(--nav-h) + 2rem) 3rem; gap:1.4rem; }
  /* corner card flows back into the column so it can't overlap the centred AEDi */
  .portal-corner { position:static; align-self:center; margin-top:.4rem; }
}

/* scroll progress rail + act dots (adventure) */
.scroll-rail { position:fixed; top:50%; right:18px; transform:translateY(-50%); z-index:900;
  display:flex; flex-direction:column; gap:.85rem; align-items:center; }
.scroll-rail a { width:9px; height:9px; border-radius:50%; border:1px solid var(--line-strong); transition:.3s; position:relative; }
.scroll-rail a.active { background:var(--cyan); box-shadow:var(--glow); border-color:var(--cyan); transform:scale(1.3); }
.scroll-rail a span { position:absolute; right:18px; top:50%; transform:translateY(-50%); white-space:nowrap;
  font-family:var(--f-mono); font-size:.58rem; letter-spacing:.15em; text-transform:uppercase; color:var(--muted);
  opacity:0; pointer-events:none; transition:.3s; }
.scroll-rail a:hover span { opacity:1; }
@media (max-width:820px){ .scroll-rail { display:none; } }

.progress-top { position:fixed; top:0; left:0; height:2px; width:0; background:var(--grad); z-index:1001; box-shadow:var(--glow); }

/* scroll hint chevrons */
.scroll-hint { position:absolute; bottom:24px; left:50%; transform:translateX(-50%); display:flex; flex-direction:column; gap:3px; z-index:3; animation:bob 1.6s var(--ease) infinite; }
.scroll-hint i { width:12px; height:12px; border-right:2px solid var(--cyan); border-bottom:2px solid var(--cyan); transform:rotate(45deg); opacity:.7; }
.scroll-hint i:nth-child(2){ opacity:.4; }
@keyframes bob { 50% { transform:translateX(-50%) translateY(8px); } }

/* reveal on scroll */
.reveal { opacity:0; transform:translateY(28px); transition:opacity .8s var(--ease-out), transform .8s var(--ease-out); }
.reveal.in { opacity:1; transform:none; }
.reveal.d1 { transition-delay:.08s; } .reveal.d2 { transition-delay:.16s; }
.reveal.d3 { transition-delay:.24s; } .reveal.d4 { transition-delay:.32s; }

/* marquee */
.marquee { overflow:hidden; border-block:1px solid var(--line); padding-block:1.1rem; -webkit-mask:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent); mask:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent); }
.marquee ul { display:flex; gap:3rem; width:max-content; animation:scrollx 32s linear infinite; }
.marquee li { font-family:var(--f-mono); font-size:.8rem; letter-spacing:.2em; text-transform:uppercase; color:var(--faint); display:flex; align-items:center; gap:3rem; }
.marquee li::after { content:"◆"; color:var(--cyan); opacity:.5; }
@keyframes scrollx { to { transform:translateX(-50%); } }

/* stat band */
.statband { display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
.statband > div { background:var(--surface); padding:1.6rem; text-align:center; }
.statband .n { font-family:var(--f-display); font-size:var(--step-2); font-weight:700; }
.statband .l { font-family:var(--f-mono); font-size:.6rem; letter-spacing:.18em; text-transform:uppercase; color:var(--faint); margin-top:.3rem; }
@media (max-width:760px){ .statband { grid-template-columns:repeat(2,1fr); } }

/* timeline */
.timeline { position:relative; padding-left:2rem; }
.timeline::before { content:""; position:absolute; left:7px; top:6px; bottom:6px; width:1px; background:var(--grad); }
.timeline li { position:relative; padding:0 0 2rem .6rem; }
.timeline li::before { content:""; position:absolute; left:-1.55rem; top:6px; width:14px; height:14px; border-radius:50%; background:var(--bg); border:2px solid var(--cyan); box-shadow:var(--glow); }
.timeline .yr { font-family:var(--f-mono); font-size:.66rem; letter-spacing:.2em; color:var(--cyan); }
.timeline h4 { font-size:var(--step-1); margin:.2rem 0 .4rem; }

/* ------------------------------------------------------------- EDGE HUD ---- */
.hud {
  border:1px solid var(--line-strong); border-radius:var(--radius);
  background:linear-gradient(160deg, rgba(10,16,32,.9), rgba(7,8,13,.95));
  padding:clamp(1.2rem,3vw,2rem); font-family:var(--f-mono); position:relative; overflow:hidden;
}
.hud::after { content:""; position:absolute; inset:0; background:repeating-linear-gradient(0deg, transparent 0 3px, rgba(0,210,255,.025) 3px 4px); pointer-events:none; }
.hud-head { display:flex; align-items:center; justify-content:space-between; gap:1rem; margin-bottom:1.2rem; border-bottom:1px dashed var(--line); padding-bottom:.8rem; }
.hud-head .t { font-size:.72rem; letter-spacing:.22em; text-transform:uppercase; color:var(--cyan); }
.metric-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius-s); overflow:hidden; }
.metric { background:var(--surface); padding:1rem 1.1rem; }
.metric .k { font-size:.58rem; letter-spacing:.18em; text-transform:uppercase; color:var(--faint); }
.metric .v { font-size:1.25rem; color:var(--text); margin-top:.35rem; font-family:var(--f-display); font-weight:600; word-break:break-word; }
.metric .v.live { color:var(--cyan); }
.bar { height:6px; border-radius:99px; background:rgba(255,255,255,.06); overflow:hidden; margin-top:.5rem; }
.bar > i { display:block; height:100%; width:0; background:var(--grad); transition:width 1s var(--ease); }
.terminal { margin-top:1.2rem; background:#04050a; border:1px solid var(--line); border-radius:var(--radius-s); padding:1rem; font-size:.74rem; color:var(--ice); min-height:90px; max-height:220px; overflow:auto; }
.terminal .ln { opacity:0; animation:tline .4s forwards; white-space:pre-wrap; }
.terminal .ln .ts { color:var(--faint); } .terminal .ln .ok { color:var(--good); } .terminal .ln .warn { color:var(--warn); }
@keyframes tline { to { opacity:1; } }

/* sensor-node level / horizon visual */
.sn-level { position:relative; width:100%; height:120px; border-radius:var(--radius-s); overflow:hidden; border:1px solid var(--line); background:radial-gradient(circle at 50% 50%, rgba(0,121,227,.12), transparent 70%), #05060a; }
.sn-horizon { position:absolute; left:-20%; top:50%; width:140%; height:60%; background:linear-gradient(180deg, transparent, rgba(0,210,255,.14)); border-top:2px solid var(--cyan); box-shadow:0 0 20px rgba(0,210,255,.4); transition:transform .12s linear; }
.sn-bubble { position:absolute; left:50%; top:50%; width:18px; height:18px; margin:-9px 0 0 -9px; border-radius:50%; background:var(--orange); box-shadow:var(--glow-orange); transition:left .12s, top .12s; }

/* radar (presence visual, only filled by REAL data) */
.radar { width:100%; max-width:280px; aspect-ratio:1; margin-inline:auto; position:relative; }
.radar .sweep { position:absolute; inset:0; border-radius:50%; background:conic-gradient(from 0deg, transparent 0 300deg, rgba(0,210,255,.25) 360deg); animation:spin 3.4s linear infinite; }
.radar . rings,.radar svg { position:absolute; inset:0; }

/* --------------------------------------------------------------- FORM ------ */
.field { display:flex; flex-direction:column; gap:.45rem; margin-bottom:1.1rem; }
.field label { font-family:var(--f-mono); font-size:.64rem; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); }
.field input,.field textarea,.field select {
  background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-s);
  padding:.85rem 1rem; color:var(--text); font:inherit; font-size:var(--step-0); transition:border-color .25s, box-shadow .25s;
}
.field input:focus,.field textarea:focus,.field select:focus { border-color:var(--cyan); box-shadow:var(--glow); outline:none; }
.field textarea { min-height:140px; resize:vertical; }

/* --------------------------------------------------------------- FOOTER ---- */
.foot { border-top:1px solid var(--line); padding-block:clamp(3rem,6vw,5rem) 2rem; background:linear-gradient(180deg, transparent, rgba(10,16,32,.4)); }
.foot-grid { display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:2rem; }
@media (max-width:820px){ .foot-grid { grid-template-columns:1fr 1fr; } }
@media (max-width:480px){ .foot-grid { grid-template-columns:1fr; } }
.foot h5 { font-family:var(--f-mono); font-size:.64rem; letter-spacing:.2em; text-transform:uppercase; color:var(--faint); margin-bottom:1rem; }
.foot a { color:var(--muted); font-size:var(--step--1); display:block; padding:.3rem 0; transition:color .2s, padding-left .2s; }
.foot a:hover { color:var(--cyan); padding-left:.3rem; }
.foot .brand { margin-bottom:1rem; }
.foot .blurb { font-size:var(--step--1); max-width:34ch; }
.socials { display:flex; gap:.6rem; margin-top:1.2rem; }
.socials a { width:40px; height:40px; border:1px solid var(--line); border-radius:12px; display:grid; place-items:center; color:var(--muted); padding:0; }
.socials a:hover { color:var(--cyan); border-color:var(--line-strong); box-shadow:var(--glow); transform:translateY(-3px); }
.socials img, .socials a svg { width:18px; height:18px; }
.foot-base { margin-top:2.5rem; padding-top:1.5rem; border-top:1px solid var(--line); display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; }
.foot-base p,.foot-base a { font-family:var(--f-mono); font-size:.62rem; letter-spacing:.1em; color:var(--faint); }

/* --------------------------------------------------------- COOKIE BANNER --- */
.cookie {
  position:fixed; left:50%; bottom:20px; transform:translateX(-50%) translateY(160%);
  width:min(100% - 2rem, 720px); z-index:1200; transition:transform .5s var(--ease-out);
  background:rgba(10,12,20,.96); -webkit-backdrop-filter:blur(14px); backdrop-filter:blur(14px);
  border:1px solid var(--line-strong); border-radius:var(--radius); padding:1.4rem; box-shadow:0 20px 60px rgba(0,0,0,.5);
}
.cookie.show { transform:translateX(-50%) translateY(0); }
.cookie h4 { font-size:1.1rem; margin-bottom:.4rem; }
.cookie p { font-size:var(--step--1); }
.cookie p a { color:var(--cyan); text-decoration:underline; }
.cookie .row { display:flex; gap:.6rem; margin-top:1.1rem; flex-wrap:wrap; }
.cookie .row .btn { font-size:.66rem; padding:.7rem 1.2rem; }
.cookie-toggles { margin-top:1rem; display:grid; gap:.6rem; }
.cookie-toggle { display:flex; align-items:center; justify-content:space-between; gap:1rem; padding:.7rem .9rem; border:1px solid var(--line); border-radius:var(--radius-s); font-size:var(--step--1); }
.switch { position:relative; width:42px; height:24px; flex:none; }
.switch input { opacity:0; width:0; height:0; }
.switch .sl { position:absolute; inset:0; background:var(--surface-2); border:1px solid var(--line); border-radius:99px; transition:.3s; }
.switch .sl::before { content:""; position:absolute; width:16px; height:16px; left:3px; top:3px; background:var(--muted); border-radius:50%; transition:.3s; }
.switch input:checked + .sl { background:var(--grad-soft); border-color:var(--cyan); }
.switch input:checked + .sl::before { transform:translateX(18px); background:var(--cyan); }
.switch input:disabled + .sl { opacity:.5; }

/* --------------------------------------------------------- LOADER ---------- */
.loader { position:fixed; inset:0; z-index:2000; display:grid; place-items:center; background:var(--bg); overflow:hidden; transition:opacity .35s, visibility .35s; }
.loader.done { opacity:0; visibility:hidden; pointer-events:none; }
.loader .mark { max-width:200px; max-height:140px; width:auto; height:auto; filter:drop-shadow(var(--glow-blue)); animation:floaty 2.4s var(--ease) infinite; }
.loader .lbl { position:absolute; bottom:18%; font-family:var(--f-mono); font-size:.62rem; letter-spacing:.3em; text-transform:uppercase; color:var(--faint); }
@keyframes floaty { 50% { transform:translateY(-10px); } }

/* scanline overlay on loader */
.loader::before {
  content:""; position:absolute; inset:0; pointer-events:none; opacity:.5; mix-blend-mode:overlay;
  background:repeating-linear-gradient(0deg, rgba(0,210,255,.06) 0 1px, transparent 1px 3px);
}
/* deliberate digital glitch-out: RGB split + horizontal tear + scan flash */
.loader.glitching { animation:loaderTear .52s steps(2,end) forwards; }
.loader.glitching .mark { animation:markGlitch .52s steps(1,end) forwards; }
.loader.glitching::after {
  content:""; position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(transparent 0%, rgba(255,40,40,.12) 48%, rgba(0,210,255,.12) 52%, transparent 100%);
  animation:scanFlash .52s steps(3,end) forwards;
}
@keyframes loaderTear {
  0%   { clip-path:inset(0 0 0 0); transform:translate3d(0,0,0); }
  18%  { clip-path:inset(12% 0 40% 0); transform:translate3d(-6px,0,0); }
  34%  { clip-path:inset(60% 0 8% 0);  transform:translate3d(7px,0,0); }
  52%  { clip-path:inset(30% 0 30% 0); transform:translate3d(-4px,0,0); }
  70%  { clip-path:inset(0 0 70% 0);   transform:translate3d(5px,0,0); }
  100% { clip-path:inset(50% 0 50% 0); transform:translate3d(0,0,0); opacity:.2; }
}
@keyframes markGlitch {
  0%   { transform:translate(0,0); filter:drop-shadow(2px 0 0 var(--live)) drop-shadow(-2px 0 0 var(--cyan)); }
  20%  { transform:translate(-5px,2px) skewX(-8deg); filter:drop-shadow(5px 0 0 var(--live)) drop-shadow(-5px 0 0 var(--cyan)); }
  40%  { transform:translate(6px,-2px) skewX(6deg);  filter:drop-shadow(-6px 0 0 var(--live)) drop-shadow(6px 0 0 var(--cyan)); }
  60%  { transform:translate(-3px,0) skewX(-3deg);   filter:drop-shadow(3px 0 0 var(--live)) drop-shadow(-3px 0 0 var(--cyan)); }
  80%  { transform:translate(2px,1px); filter:none; opacity:.85; }
  100% { transform:translate(0,0) scale(1.08); filter:drop-shadow(var(--glow-blue)); opacity:0; }
}
@keyframes scanFlash { 0%{transform:translateY(-100%);opacity:0} 30%{opacity:1} 100%{transform:translateY(100%);opacity:0} }

/* --------------------------------------------------------- UTILITIES ------- */
.center { text-align:center; }
.mt-1{margin-top:1rem;} .mt-2{margin-top:2rem;} .mb-0{margin-bottom:0;}
.muted{color:var(--muted);} .mono{font-family:var(--f-mono);}
.flex{display:flex;} .gap{gap:1rem;} .wrapf{flex-wrap:wrap;} .aic{align-items:center;}
.divider { height:1px; background:var(--line); border:none; margin-block:clamp(3rem,7vw,6rem); }
.note { font-family:var(--f-mono); font-size:.66rem; color:var(--faint); border-left:2px solid var(--cyan); padding-left:.8rem; line-height:1.7; }
.skip { position:absolute; left:-999px; top:0; background:var(--cyan); color:#000; padding:.6rem 1rem; z-index:2600; }
.skip:focus { left:8px; top:8px; }

/* ---------------------------------------------------------- AEDI CHAT ------- */
.aedi-wrap { position:fixed; bottom:24px; left:24px; z-index:1500; }

.aedi-fab {
  position:relative; display:flex; align-items:center; gap:.55rem;
  background:linear-gradient(135deg, var(--blue) 0%, var(--cyan) 100%);
  border:none; border-radius:99px; padding:.7rem 1.1rem .7rem .9rem;
  color:#fff; font-family:var(--f-mono); font-size:.7rem; font-weight:600;
  letter-spacing:.1em; text-transform:uppercase; cursor:pointer;
  box-shadow:0 4px 24px rgba(0,121,227,.45), 0 0 0 0 rgba(0,210,255,.4);
  transition:box-shadow .3s, transform .2s;
}
.aedi-fab:hover { transform:translateY(-2px); box-shadow:0 8px 32px rgba(0,121,227,.6), var(--glow-blue); }
.aedi-fab:focus-visible { outline:2px solid var(--cyan); outline-offset:3px; }
.aedi-fab svg { width:20px; height:20px; flex:none; }
.aedi-fab-logo { width:24px; height:24px; flex:none; object-fit:contain; filter:drop-shadow(0 1px 2px rgba(0,0,0,.3)); }

.aedi-badge { pointer-events:none; }

.aedi-pulse {
  position:absolute; inset:-6px; border-radius:99px;
  border:2px solid var(--cyan); opacity:0;
  animation:aedi-ping 2.8s ease-out infinite;
}
@keyframes aedi-ping { 0%{opacity:.6;transform:scale(1)} 100%{opacity:0;transform:scale(1.35)} }

.aedi-panel {
  position:absolute; bottom:calc(100% + 12px); left:0;
  width:min(380px, calc(100vw - 40px)); background:rgba(8,10,18,.97);
  -webkit-backdrop-filter:blur(20px); backdrop-filter:blur(20px);
  border:1px solid var(--line-strong); border-radius:var(--radius);
  box-shadow:0 24px 64px rgba(0,0,0,.6), 0 0 0 1px rgba(0,210,255,.08);
  display:flex; flex-direction:column; overflow:hidden;
  transform-origin:bottom left;
  animation:aedi-in .22s var(--ease-out);
}
.aedi-panel[hidden] { display:none !important; }   /* hidden attr must win over display:flex */
@keyframes aedi-in { from{opacity:0;transform:scale(.92) translateY(8px)} to{opacity:1;transform:none} }

.aedi-head {
  display:flex; align-items:center; gap:.8rem; padding:.9rem 1rem;
  border-bottom:1px solid var(--line); background:rgba(0,121,227,.08);
  flex-shrink:0;
}
.aedi-head > div:first-child { flex:1; min-width:0; }
.aedi-name { font-family:var(--f-mono); font-size:.8rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--cyan); display:block; }
.aedi-sub  { font-size:.58rem; color:var(--faint); letter-spacing:.08em; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; display:block; }
.aedi-status { font-family:var(--f-mono); font-size:.6rem; color:var(--faint); white-space:nowrap; display:flex; align-items:center; gap:.4rem; }
.aedi-status .dot { width:6px; height:6px; background:#3ddc6e; border-radius:50%; box-shadow:0 0 8px #3ddc6e; flex:none; }
.aedi-close { background:none; border:none; color:var(--muted); cursor:pointer; padding:.3rem; border-radius:6px; display:grid; place-items:center; transition:color .2s; }
.aedi-close:hover { color:var(--text); }
.aedi-close svg { width:16px; height:16px; }

.aedi-messages { flex:1; overflow-y:auto; padding:.8rem 1rem; display:flex; flex-direction:column; gap:.7rem; min-height:200px; max-height:320px; scrollbar-width:thin; scrollbar-color:var(--line) transparent; }

.aedi-msg { display:flex; }
.aedi-msg--user { justify-content:flex-end; }
.aedi-msg--model { justify-content:flex-start; }

.aedi-bubble {
  max-width:88%; padding:.6rem .9rem; border-radius:14px; font-size:var(--step--1); line-height:1.6;
}
.aedi-msg--user .aedi-bubble { background:linear-gradient(135deg, var(--blue), var(--blue-deep)); color:#fff; border-bottom-right-radius:4px; }
.aedi-msg--model .aedi-bubble { background:var(--surface); border:1px solid var(--line); color:var(--text); border-bottom-left-radius:4px; }
.aedi-bubble code { font-family:var(--f-mono); font-size:.8em; background:rgba(0,210,255,.1); padding:.1em .4em; border-radius:4px; }
.aedi-bubble a { color:var(--cyan); text-decoration:underline; text-underline-offset:2px; font-weight:500; }
.aedi-bubble a:hover { color:var(--orange); }

.aedi-typing .aedi-bubble { background:var(--surface); border:1px solid var(--line); padding:.7rem 1rem; }
.aedi-dots { display:flex; gap:.35rem; align-items:center; height:1.2em; }
.aedi-dots i { width:6px; height:6px; border-radius:50%; background:var(--cyan); animation:aedi-dot .9s ease-in-out infinite; }
.aedi-dots i:nth-child(2) { animation-delay:.18s; }
.aedi-dots i:nth-child(3) { animation-delay:.36s; }
@keyframes aedi-dot { 0%,80%,100%{opacity:.25;transform:scale(.8)} 40%{opacity:1;transform:scale(1)} }

.aedi-input-row { display:flex; gap:.5rem; padding:.7rem .9rem; border-top:1px solid var(--line); flex-shrink:0; }
.aedi-input {
  flex:1; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-s);
  color:var(--text); font:inherit; font-size:var(--step--1); padding:.55rem .8rem;
  transition:border-color .2s, box-shadow .2s;
}
.aedi-input:focus { outline:none; border-color:var(--cyan); box-shadow:var(--glow); }
.aedi-input::placeholder { color:var(--faint); }
.aedi-send {
  background:var(--blue); border:none; border-radius:var(--radius-s); color:#fff;
  width:36px; height:36px; display:grid; place-items:center; cursor:pointer; flex:none;
  transition:background .2s, transform .15s;
}
.aedi-send:hover { background:var(--cyan); color:#000; transform:scale(1.06); }
.aedi-send:disabled { opacity:.4; cursor:not-allowed; transform:none; }
.aedi-send svg { width:15px; height:15px; }

.aedi-disc { font-family:var(--f-mono); font-size:.54rem; color:var(--faint); text-align:center; padding:.4rem .9rem .6rem; flex-shrink:0; }

@media (max-width:480px) {
  .aedi-wrap { bottom:16px; left:12px; }
  .aedi-panel { width:calc(100vw - 24px); left:-12px; }
  .aedi-fab { padding:.65rem .9rem .65rem .8rem; font-size:.66rem; }
}

/* --------------------------------------------------- REDUCED MOTION -------- */
@media (prefers-reduced-motion: reduce) {
  *,*::before,*::after { animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; scroll-behavior:auto !important; }
  .reveal { opacity:1; transform:none; }
}

/* ==========================================================================
   2026 UPLIFT — 3D backdrop layering · film grain · sheets · glitch · fixes
   (integrated from the parallel design pass; paths made relative for the
   github.io project subpath; pcb/clouds use .jpg)
   ========================================================================== */

/* z-index stack tokens */
:root{ --z-bg3d:-3; --z-bgfield:-2; --z-grid:-1; --z-content:2; --z-rail:900; --z-nav:1000; --z-glitch:3000; }

/* --- 3D WebGL backdrop layering --- */
canvas#bg3d{ position:fixed; inset:0; width:100%; height:100%; z-index:-3 !important; pointer-events:none; display:block; }
html:not(.no3d) .bg-field{ opacity:.45; mix-blend-mode:screen; }
html:not(.no3d) .bg-grid{ opacity:.32; }

/* --- film grain + scanline (one unifying "shot on film" surface) --- */
.grain{ position:fixed; inset:0; z-index:-1; pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); background-size:200px 200px; opacity:.05; mix-blend-mode:overlay; }
.grain::after{ content:""; position:absolute; inset:0;
  background:repeating-linear-gradient(0deg, rgba(255,255,255,.02) 0 1px, transparent 1px 3px); opacity:.5; }
@media (prefers-reduced-motion:reduce){ .grain{ opacity:.035; } }

/* --- mobile logo (still bigger than the timid old 30px) --- */
@media (max-width:880px){ .brand .wm{ height:50px; } }
@media (max-width:420px){ .brand .wm{ height:46px; } }

/* Mobile: zoom the whole layout out a touch (everything scales off rem). The
   nav logo is px-based so it stays prominent. */
@media (max-width:600px){ html{ font-size:90%; } }
@media (max-width:380px){ html{ font-size:86%; } }

/* --- AEDi section: calm translucent panel over the live 3D --- */
#aedi{ background:rgba(14,16,24,.6); border-radius:var(--radius); }

/* --- asymmetry: left-weight the ethos head, keep capability cards centered --- */
#ethos .section-head{ margin-inline:0; text-align:left; }

/* ============================ no3d FALLBACK ============================ */
/* ===========================================================================
   Static fallback backdrop for when the WebGL scene is suppressed.
   backdrop.js adds `html.no3d` whenever it declines to start (reduced-motion,
   low-core, small screen, no WebGL, or CDN/import failure). This recreates the
   legacy "portal" vibe with pure CSS — layered radial glows in the brand
   palette (cyan underlight, blue body, orange warm rim) over the #07080D bg,
   so the page never falls back to a flat colour or a broken image.
   These rules OVERRIDE the default .bg-field declaration in ionity.css.
   =========================================================================== */
html.no3d .bg-field {
  position: fixed;
  inset: 0;
  z-index: -2;
  pointer-events: none;
  /* Cyan underlight + blue body + orange warm rim, fading to the dark bg. */
  background:
    radial-gradient(70vw 55vw at 50% 118%, rgba(0,210,255,.22), transparent 62%),
    radial-gradient(60vw 60vw at 14% -10%, rgba(0,121,227,.18), transparent 60%),
    radial-gradient(46vw 46vw at 88% 6%, rgba(255,149,0,.10), transparent 58%),
    radial-gradient(80vw 70vw at 50% 50%, rgba(10,81,171,.14), transparent 70%),
    var(--bg, #07080D);
  /* Very slow drifting "breathing" of the glows — disabled under reduced-motion
     (see below) so it stays a static image when motion is the reason we bailed. */
  animation: no3dDrift 24s ease-in-out infinite alternate;
}

@keyframes no3dDrift {
  from { background-position: 0 0, 0 0, 0 0, 0 0, 0 0; transform: scale(1); }
  to   { background-position: 0 -2vh, 0 1vh, 0 0, 0 1vh, 0 0; transform: scale(1.03); }
}

/* If motion specifically is the reason for no3d, keep it perfectly still. */
@media (prefers-reduced-motion: reduce) {
  html.no3d .bg-field { animation: none; }
}

/* ============================ GLITCH TRANSITION ======================== */
/* IonityGlitch — page-transition styling. Add to your global stylesheet. */
body.glitching {
  cursor: progress;
}
/* The overlay canvas is created/removed by glitch.js; these rules are a
   belt-and-suspenders guarantee in case the inline styles are ever stripped. */
#ionity-glitch-canvas {
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 3000;          /* above all site chrome incl. nav, cookie, AEDi widget */
  pointer-events: none;   /* never blocks clicks */
  display: block;
  background: #07080D;     /* brand bg, matches the noise base */
}
@media (prefers-reduced-motion: reduce) {
  /* glitch.js already does a 120ms fade instead of the storm; keep cursor calm */
  body.glitching { cursor: progress; }
}
