/* ============================================================
   HALO VISION — main landing page
   Vibe: Jedi / sci-fi · metallic + energetic blue plasma · glyphs &
   geometric line-work · gaming-HUD energy, social-clean · smooth,
   sleek, sharp · 3D depth via layered shadow + gradient.
   Base: dark COSMIC BLUE (#0E1C2E, never black) · silver · NO gold.
   Hero + nav keep the EXACT-SPEC mechanics (sentinel + sticky +
   negative-margin overlay, hover-to-play, layered parallax).
   ============================================================ */

:root{
  --bg:          #0B1726;
  --bg-elev-1:   #122336;
  --bg-elev-2:   #1A3145;
  --nebula:      #244055;
  --steel:       #3C5870;

  --cyan:        #6FB6DE;
  --cyan-hi:     #9AD2EE;
  --plasma:      #56C7FF;   /* energetic blue plasma */
  --plasma-hot:  #B6ECFF;
  --beam:        #CDE8F6;

  --chrome:      #EEF3F7;
  --silver:      #C5CFD8;
  --pewter:      #95A3B0;
  --graphite:    #5A6776;

  --ink:         #F5F9FC;
  --ink-muted:   #B6C2CD;
  --ink-quiet:   #82909E;

  --line:        rgba(120,200,245,0.16);
  --line-strong: rgba(120,200,245,0.36);
  --glow:        rgba(86,199,255,0.55);

  --ff-roman:   "Orbitron", "Manrope", sans-serif;
  --ff-display: "Orbitron", "Manrope", sans-serif;
  --ff-body:    "Manrope", system-ui, sans-serif;

  --ease-lux:   cubic-bezier(0.16,1,0.3,1);
  --metal:      linear-gradient(157deg,#1C3349 0%,#122336 100%);

  --nav-h-tall:  104px;
  --nav-h-stuck:  68px;
  --maxw:        1180px;
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
section[id], .hero[id]{scroll-margin-top:calc(var(--nav-h-stuck) + 16px);}
body{
  background:
    radial-gradient(1200px 800px at 80% -200px, rgba(86,199,255,0.10), transparent 60%),
    var(--bg);
  color:var(--ink);font-family:var(--ff-body);font-weight:300;line-height:1.6;
  overflow-x:hidden;text-wrap:pretty;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;}
.center{text-align:center;}

/* chrome / silver gradient text */
.section__title, .nav__brand-text{
  background:linear-gradient(180deg,#FFFFFF 0%,#DCE6EE 22%,#A9B7C4 50%,#6B7A88 72%,#E6EEF4 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}

/* metallic surface helper (reused) */
.metal{
  background:
    linear-gradient(180deg, rgba(180,236,255,0.07) 0%, transparent 22%),
    linear-gradient(158deg, #1A3145 0%, #122336 60%, #0E1F30 100%);
  border:1px solid var(--line);
  box-shadow:
    inset 0 1px 0 rgba(182,236,255,0.18),
    inset 0 0 0 1px rgba(255,255,255,0.02),
    0 2px 6px rgba(0,0,0,0.5),
    0 22px 50px -22px rgba(0,0,0,0.8);
}

/* HUD corner brackets — applied to .hud elements */
.hud{position:relative;}
.hud::before,.hud::after{content:"";position:absolute;width:18px;height:18px;pointer-events:none;
  border:1.5px solid var(--plasma);filter:drop-shadow(0 0 5px var(--glow));opacity:.75;transition:opacity .4s var(--ease-lux);}
.hud::before{top:9px;left:9px;border-right:none;border-bottom:none;}
.hud::after{bottom:9px;right:9px;border-left:none;border-top:none;}
.hud:hover::before,.hud:hover::after{opacity:1;}

/* ============================================================
   BOOT LOADER (injected by JS)
   ============================================================ */
#boot{position:fixed;inset:0;z-index:9999;display:grid;place-items:center;
  background:radial-gradient(700px 500px at 50% 45%, #16293D, #0B1726 70%);
  transition:opacity .7s var(--ease-lux), visibility .7s;}
#boot.done{opacity:0;visibility:hidden;}
.boot__core{display:flex;flex-direction:column;align-items:center;gap:22px;}
.boot__halo{width:184px;height:auto;overflow:visible;animation:halofloat 3.2s ease-in-out infinite, haloflash 1.6s ease-in-out infinite;}
.boot__halo .halo-base{fill:none;stroke:rgba(86,199,255,.20);stroke-width:4;}
.boot__halo .halo-spin{fill:none;stroke:#D6F2FF;stroke-width:4;stroke-linecap:round;
  stroke-dasharray:72 278;stroke-dashoffset:0;
  filter:drop-shadow(0 0 5px #fff) drop-shadow(0 0 12px var(--plasma)) drop-shadow(0 0 22px var(--glow));
  animation:halospin 1.2s linear infinite;}
.boot__mark{position:absolute;inset:0;margin:auto;width:38px;height:auto;}
.boot__txt{font-family:var(--ff-body);font-size:11px;letter-spacing:.42em;text-transform:uppercase;color:var(--cyan-hi);}
@keyframes halospin{to{stroke-dashoffset:-350;}}
@keyframes halofloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;height:clamp(560px,80vh,760px);padding-bottom:var(--nav-h-tall);
  display:flex;align-items:center;overflow:hidden;isolation:isolate;background:var(--bg);}
.hero__bg{position:absolute;top:-8%;bottom:-8%;left:50%;width:min(calc(100% + 360px),1820px);height:116%;
  object-fit:cover;object-position:center;--py:0px;transform:translate3d(-50%,var(--py),0);
  pointer-events:none;will-change:transform;z-index:0;}
.hero__veil{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(90deg, rgba(7,15,26,0.82) 0%, rgba(7,15,26,0.52) 18%, rgba(7,15,26,0.18) 36%,
      rgba(7,15,26,0.0) 56%, rgba(7,15,26,0.0) 82%, rgba(7,15,26,0.42) 100%),
    linear-gradient(180deg, rgba(7,15,26,0.45) 0%, rgba(7,15,26,0.0) 26%, rgba(7,15,26,0.0) 62%, rgba(7,15,26,0.82) 100%);}
/* plasma geometric grid overlay */
.hero__grain{position:absolute;inset:0;z-index:1;pointer-events:none;opacity:.5;
  background-image:
    linear-gradient(rgba(86,199,255,0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(86,199,255,0.05) 1px, transparent 1px);
  background-size:46px 46px;
  -webkit-mask:radial-gradient(60% 60% at 30% 50%, #000, transparent 75%);
          mask:radial-gradient(60% 60% at 30% 50%, #000, transparent 75%);}
.hero__content{position:relative;z-index:2;max-width:1280px;width:100%;margin:0 auto;
  padding:clamp(2rem,5vh,3.5rem) clamp(1.5rem,5vw,4rem);will-change:transform;}
.hero__text{max-width:600px;}
.hero__eyebrow{display:flex;gap:16px;align-items:center;margin-bottom:18px;
  letter-spacing:.36em;text-transform:uppercase;font-size:12px;color:var(--cyan-hi);}
.hero__eyebrow span{position:relative;text-shadow:0 0 12px var(--glow);}
.hero__eyebrow span+span::before{content:"";position:absolute;left:-10px;top:50%;width:4px;height:4px;
  transform:translate(-50%,-50%) rotate(45deg);background:var(--plasma);box-shadow:0 0 6px var(--glow);}
.hero__bolt{color:var(--plasma);filter:drop-shadow(0 0 12px var(--glow));margin-bottom:10px;animation:bolt 7s infinite;}
@keyframes bolt{0%,90%,100%{opacity:.9}93%{opacity:.2}95%{opacity:1}}
.hero__title{font-family:var(--ff-roman);font-weight:500;font-size:clamp(2.75rem,7.6vw,5.9rem);
  line-height:1;letter-spacing:.06em;margin:0 0 1rem;white-space:nowrap;
  background:linear-gradient(180deg,#FFFFFF 0%,#DCE6EE 24%,#A9B7C4 52%,#6B7A88 74%,#E6EEF4 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 3px 5px rgba(0,0,0,.75)) drop-shadow(0 0 30px rgba(120,200,245,.35));}
.hero__subtitle{font-family:var(--ff-display);font-style:italic;color:var(--silver);
  font-size:clamp(1rem,2.2vw,1.45rem);letter-spacing:.04em;margin-bottom:14px;}
.hero__copy{color:var(--ink-muted);max-width:500px;margin-bottom:18px;text-shadow:0 1px 6px rgba(7,15,26,.85);}
.hero__copy .hi{color:var(--plasma-hot);font-style:italic;text-shadow:0 0 14px var(--glow);}
.hero__dates{font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-quiet);}

/* hero intro sequence (triggered by body.loaded) */
.hero__text > *{opacity:0;transform:translateY(22px);transition:opacity .9s var(--ease-lux), transform .9s var(--ease-lux);}
body.loaded .hero__text > *{opacity:1;transform:none;}
body.loaded .hero__text > *:nth-child(1){transition-delay:.05s;}
body.loaded .hero__text > *:nth-child(2){transition-delay:.15s;}
body.loaded .hero__text > *:nth-child(3){transition-delay:.28s;}
body.loaded .hero__text > *:nth-child(4){transition-delay:.40s;}
body.loaded .hero__text > *:nth-child(5){transition-delay:.52s;}
body.loaded .hero__text > *:nth-child(6){transition-delay:.62s;}

.nav-sentinel{position:absolute;left:0;right:0;bottom:var(--nav-h-tall);height:1px;pointer-events:none;}

/* ============================================================
   NAV — overlaid on hero bottom, rises + locks on scroll
   ============================================================ */
.nav{position:sticky;top:0;z-index:50;margin-top:calc(-1 * var(--nav-h-tall));
  background:linear-gradient(180deg, rgba(16,30,46,0.40) 0%, rgba(20,38,58,0.55) 60%, rgba(26,48,70,0.66) 100%);
  -webkit-backdrop-filter:blur(9px) saturate(130%);backdrop-filter:blur(9px) saturate(130%);
  border-top:1px solid rgba(120,200,245,0.18);border-bottom:1px solid rgba(0,0,0,0.45);
  box-shadow:inset 0 1px 0 rgba(182,236,255,0.16), 0 14px 38px -14px rgba(0,0,0,0.75);
  transition:background .5s var(--ease-lux), backdrop-filter .5s var(--ease-lux), border-color .5s var(--ease-lux), box-shadow .5s var(--ease-lux);}
.nav::after{content:"";position:absolute;left:0;right:0;top:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--plasma),transparent);opacity:.5;}
.nav__inner{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:2rem;
  height:var(--nav-h-tall);max-width:1240px;margin:0 auto;padding:0 clamp(1.5rem,4vw,3rem);
  transition:height .45s var(--ease-lux);}
.nav__cta{justify-self:start;}
.nav__links{justify-self:center;}
.nav__brand{justify-self:end;}
.nav__brand{display:flex;align-items:center;gap:10px;opacity:0;transform:translateX(8px);
  transition:opacity .45s var(--ease-lux), transform .45s var(--ease-lux);pointer-events:none;}
.nav__brand-mark{width:22px;height:auto;filter:drop-shadow(0 0 8px var(--glow));}
.nav__brand-text{font-family:var(--ff-roman);font-weight:500;font-size:16px;letter-spacing:.28em;
  filter:drop-shadow(0 1px 2px rgba(0,0,0,.7)) drop-shadow(0 0 14px rgba(120,200,245,.5));transition:font-size .45s var(--ease-lux);}
.nav__links{display:flex;gap:clamp(1.5rem,3vw,2.75rem);list-style:none;}
.nav__links a{font-family:var(--ff-body);font-size:12px;font-weight:500;letter-spacing:.25em;text-transform:uppercase;
  color:#EAF1F7;padding:.5rem 0;position:relative;text-shadow:0 1px 2px rgba(0,0,0,.85),0 2px 6px rgba(0,0,0,.7);
  transition:color .3s var(--ease-lux);}
.nav__links a::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--plasma);
  box-shadow:0 0 8px var(--glow);transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease-lux);}
.nav__links a:hover{color:#fff;}
.nav__links a:hover::after{transform:scaleX(1);}

.btn{display:inline-block;cursor:pointer;border:1px solid transparent;font-family:var(--ff-body);transition:all .4s var(--ease-lux);}
.nav__cta .btn{padding:1.0rem 2.2rem;font-size:12.5px;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:#EAF4FB;
  background:linear-gradient(180deg, rgba(120,200,245,0.14) 0%, transparent 55%), linear-gradient(180deg, #16293D 0%, #0A1726 100%);
  border:1px solid rgba(120,200,245,0.5);border-radius:3px;
  
  box-shadow:inset 0 1px 0 rgba(182,236,255,0.25), inset 0 -1px 0 rgba(0,0,0,0.55), 0 8px 18px rgba(0,0,0,0.6);}
.nav__cta .btn:hover{color:#fff;border-color:var(--plasma);transform:translateY(-1px);
  box-shadow:inset 0 1px 0 rgba(182,236,255,0.35), 0 0 26px var(--glow), 0 10px 24px rgba(0,0,0,.6);}

.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;justify-self:end;}
.nav__burger span{width:24px;height:2px;background:var(--silver);transition:.3s;box-shadow:0 0 6px var(--glow);}
.nav__burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav__burger.is-open span:nth-child(2){opacity:0;}
.nav__burger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
.nav__drawer{padding:8px 24px 22px;background:rgba(10,20,34,0.97);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-top:1px solid var(--line);}
.nav__drawer[hidden]{display:none;}
.nav__drawer-links{list-style:none;}
.nav__drawer-links a{display:block;padding:14px 4px;color:var(--ink-muted);font-size:15px;letter-spacing:.08em;border-bottom:1px solid var(--line);}

.nav.is-stuck{background:linear-gradient(180deg, rgba(10,20,34,0.80) 0%, rgba(14,28,46,0.88) 100%);
  -webkit-backdrop-filter:blur(15px) saturate(145%);backdrop-filter:blur(15px) saturate(145%);
  border-top-color:transparent;border-bottom-color:var(--line);box-shadow:0 12px 42px -12px rgba(0,0,0,0.65);}
.nav.is-stuck .nav__inner{height:var(--nav-h-stuck);}
.nav.is-stuck .nav__brand{opacity:1;transform:translateX(0);pointer-events:auto;}
.nav.is-stuck .nav__brand-text{font-size:15px;}
.nav.is-stuck .nav__links a{color:var(--ink-muted);}
.nav.is-stuck .nav__links a:hover{color:var(--ink);}
.nav.is-stuck .nav__cta .btn{padding:.8rem 1.7rem;font-size:12px;}

/* ============================================================
   BODY BUTTONS
   ============================================================ */
.btn--lg{padding:16px 36px;font-size:13px;}
.btn--cyan,.btn--ghost{font-size:12.5px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;padding:14px 30px;border-radius:3px;
  }
.btn--cyan{color:#06131F;
  background:linear-gradient(180deg, var(--plasma-hot) 0%, var(--plasma) 45%, #2E9FD8 100%);
  border:1px solid rgba(182,236,255,0.6);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.45), 0 0 26px var(--glow), 0 10px 26px rgba(0,0,0,.5);}
.btn--cyan:hover{transform:translateY(-2px);box-shadow:inset 0 1px 0 rgba(255,255,255,0.55), 0 0 40px var(--glow), 0 14px 32px rgba(0,0,0,.55);}
.btn--ghost{color:var(--beam);background:linear-gradient(180deg, rgba(120,200,245,0.08), transparent);border:1px solid var(--line-strong);}
.btn--ghost:hover{border-color:var(--plasma);transform:translateY(-2px);box-shadow:0 0 30px var(--glow) inset;}

/* ============================================================
   SECTIONS
   ============================================================ */
.section{padding:118px 0;position:relative;}
.section--alt{background:
  linear-gradient(rgba(86,199,255,0.035) 1px, transparent 1px),
  linear-gradient(90deg, rgba(86,199,255,0.035) 1px, transparent 1px),
  linear-gradient(180deg,var(--bg),var(--bg-elev-1));
  background-size:54px 54px, 54px 54px, 100% 100%;}
.section--alt::before,.section::after{content:"";position:absolute;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--line-strong),transparent);}
.section--alt::before{top:0;}
.eyebrow{display:inline-flex;align-items:center;gap:12px;letter-spacing:.32em;text-transform:uppercase;font-size:12px;color:var(--cyan);margin-bottom:14px;}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--plasma);box-shadow:0 0 8px var(--glow);}
.section__title{font-family:var(--ff-display);font-weight:700;font-size:clamp(26px,4.4vw,48px);line-height:1.16;letter-spacing:.16em;margin-bottom:22px;text-transform:uppercase;}
.section__lede{color:var(--ink-muted);max-width:700px;margin-bottom:42px;}
.section__lede em{color:var(--ink-quiet);font-style:italic;}
.placeholder-tag{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:var(--ink-quiet);
  font-size:12px;letter-spacing:.14em;text-transform:uppercase;border:1px dashed var(--line-strong);border-radius:inherit;}

.offer-hero{display:grid;grid-template-columns:1.1fr 1fr;border-radius:6px;overflow:hidden;margin-bottom:34px;
  background:linear-gradient(158deg,#1A3145 0%,#122336 60%,#0E1F30 100%);border:1px solid var(--line);
  box-shadow:inset 0 1px 0 rgba(182,236,255,0.14), 0 26px 60px -24px rgba(0,0,0,0.85);
  transition:transform .7s var(--ease-lux), box-shadow .7s var(--ease-lux);}
.offer-hero:hover{transform:translateY(-4px);box-shadow:inset 0 1px 0 rgba(182,236,255,0.2), 0 30px 80px -26px var(--glow);}
.offer-hero__media{min-height:360px;background:linear-gradient(135deg,var(--nebula),#16293D);position:relative;}
.offer-hero__body{padding:48px;display:flex;flex-direction:column;align-items:flex-start;gap:16px;justify-content:center;}
.offer-hero__kicker{display:inline-flex;align-items:center;gap:10px;letter-spacing:.26em;text-transform:uppercase;font-size:11px;color:var(--cyan-hi);}
.offer-hero__kicker::before{content:"";width:18px;height:1px;background:var(--plasma);box-shadow:0 0 6px var(--glow);}
.offer-hero__title{font-family:var(--ff-display);font-size:clamp(26px,3.4vw,42px);color:var(--chrome);}
.offer-hero__body p{color:var(--ink-muted);}

.offer-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.offer-card{border-radius:5px;padding:20px;position:relative;
  background:linear-gradient(160deg,#16293D 0%,#0F2032 100%);border:1px solid var(--line);
  box-shadow:inset 0 1px 0 rgba(182,236,255,0.12), 0 16px 40px -20px rgba(0,0,0,0.8);
  transition:transform .55s var(--ease-lux), box-shadow .55s var(--ease-lux), border-color .4s;}
.offer-card:hover{transform:translateY(-5px);border-color:var(--line-strong);box-shadow:inset 0 1px 0 rgba(182,236,255,0.2), 0 22px 55px -20px var(--glow);}
.offer-card__media{aspect-ratio:16/10;border-radius:3px;background:linear-gradient(135deg,var(--nebula),#16293D);margin-bottom:16px;}
.offer-card h4{font-family:var(--ff-display);font-size:21px;color:var(--chrome);margin-bottom:8px;}
.offer-card p{color:var(--ink-muted);font-size:14.5px;margin-bottom:14px;}
.offer-card a{color:var(--plasma);font-size:13px;letter-spacing:.08em;text-shadow:0 0 10px var(--glow);}

.video-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-bottom:36px;}
.video-card{display:block;}
.video-card__thumb{aspect-ratio:16/9;border-radius:5px;background:linear-gradient(135deg,var(--nebula),#16293D);overflow:hidden;position:relative;
  border:1px solid var(--line);box-shadow:0 16px 40px -20px rgba(0,0,0,0.8);transition:transform .55s var(--ease-lux), box-shadow .55s var(--ease-lux);}
.video-card:hover .video-card__thumb{transform:translateY(-5px);box-shadow:0 22px 55px -20px var(--glow);}
.video-card__title{display:block;margin-top:12px;color:var(--ink-muted);font-size:14px;}

.about{display:grid;grid-template-columns:.85fr 1.15fr;gap:56px;align-items:center;}
.about__media{aspect-ratio:4/5;border-radius:6px;position:relative;
  background:linear-gradient(135deg,var(--nebula),#16293D);border:1px solid var(--line);
  box-shadow:inset 0 1px 0 rgba(182,236,255,0.14), 0 26px 60px -24px rgba(0,0,0,0.85);}
.about__body p{color:var(--ink-muted);margin-bottom:16px;}

.cal{list-style:none;display:flex;flex-direction:column;gap:14px;max-width:780px;}
.cal__item{display:flex;gap:22px;align-items:center;padding:20px 24px;border-radius:4px;
  background:linear-gradient(160deg,#16293D,#0F2032);border:1px solid var(--line);
  box-shadow:inset 0 1px 0 rgba(182,236,255,0.1), 0 14px 36px -20px rgba(0,0,0,0.8);
  transition:border-color .4s, transform .5s var(--ease-lux), box-shadow .5s;}
.cal__item:hover{border-color:var(--line-strong);transform:translateX(5px);box-shadow:0 18px 44px -20px var(--glow);}
.cal__date{display:flex;flex-direction:column;align-items:center;min-width:56px;color:var(--plasma);text-shadow:0 0 10px var(--glow);}
.cal__date b{font-family:var(--ff-display);font-size:26px;line-height:1;}
.cal__date small{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-quiet);}
.cal__info{display:flex;flex-direction:column;}
.cal__info strong{font-weight:500;color:var(--chrome);}
.cal__info em{font-style:normal;color:var(--ink-quiet);font-size:13.5px;}

.section--chat{background:radial-gradient(800px 420px at 50% 0%, rgba(86,199,255,0.16), transparent 60%), linear-gradient(180deg,var(--bg-elev-1),var(--bg));}
.chat__mark{width:56px;margin:0 auto 22px;opacity:.95;filter:drop-shadow(0 0 16px var(--glow));}
.chat__note{margin-top:18px;color:var(--ink-quiet);font-size:13px;}

.footer{background:#081320;border-top:1px solid var(--line);padding:66px 0 28px;position:relative;}
.footer::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--plasma),transparent);opacity:.45;}
.footer__inner{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr 1fr;gap:30px;}
.footer__logo{width:150px;margin-bottom:14px;}
.footer__brand p{color:var(--ink-quiet);font-size:14px;max-width:260px;}
.footer__col h5{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--silver);margin-bottom:16px;font-weight:500;}
.footer__col a{display:block;color:var(--ink-muted);font-size:14px;padding:6px 0;transition:color .3s;}
.footer__col a:hover{color:var(--plasma);text-shadow:0 0 10px var(--glow);}
.footer__legal{text-align:center;color:var(--graphite);font-size:12px;margin-top:48px;letter-spacing:.06em;}

.chat-fab{position:fixed;right:22px;bottom:22px;z-index:90;width:62px;height:62px;border-radius:50%;cursor:pointer;
  border:1px solid var(--line-strong);background:linear-gradient(180deg,var(--bg-elev-2),var(--bg-elev-1));
  display:flex;align-items:center;justify-content:center;
  box-shadow:inset 0 1px 0 rgba(182,236,255,0.2), 0 10px 30px rgba(0,0,0,.5), 0 0 26px var(--glow);
  transition:transform .5s var(--ease-lux), box-shadow .5s;animation:fabpulse 3.6s ease-in-out infinite;}
.chat-fab img{width:30px;filter:drop-shadow(0 0 8px var(--glow));}
.chat-fab:hover{transform:translateY(-3px) scale(1.05);box-shadow:0 14px 40px rgba(0,0,0,.55), 0 0 44px var(--glow);}
@keyframes fabpulse{0%,100%{box-shadow:inset 0 1px 0 rgba(182,236,255,0.2),0 10px 30px rgba(0,0,0,.5),0 0 22px var(--glow);}50%{box-shadow:inset 0 1px 0 rgba(182,236,255,0.2),0 10px 30px rgba(0,0,0,.5),0 0 40px var(--glow);}}

/* ============================================================
   SCROLL REVEALS — directional + clip "scan-in"
   ============================================================ */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .9s var(--ease-lux) var(--d,0s), transform .9s var(--ease-lux) var(--d,0s);}
.reveal.is-visible{opacity:1;transform:none;}
.reveal--l{transform:translateX(-40px);}
.reveal--r{transform:translateX(40px);}
.reveal--clip{clip-path:inset(0 100% 0 0);opacity:1;transform:none;transition:clip-path 1s var(--ease-lux) var(--d,0s);}
.reveal--clip.is-visible{clip-path:inset(0 0 0 0);}

/* ============================================================
   MOBILE
   ============================================================ */
@media (max-width:860px){
  .offer-hero{grid-template-columns:1fr;}
  .offer-grid,.video-grid{grid-template-columns:1fr 1fr;}
  .about{grid-template-columns:1fr;gap:30px;}
  .footer__inner{grid-template-columns:1fr 1fr;}
}
@media (max-width:760px){
  .hero{height:clamp(520px,76vh,660px);}
  .hero__title{font-size:clamp(2.5rem,12vw,4.5rem);}
  .hero__text{max-width:100%;}
  .nav__links{display:none;}
  .nav__brand{display:none;}
  .nav__burger{display:flex;}
  .nav__inner{grid-template-columns:1fr auto;gap:1rem;padding:0 1rem;}
  .section{padding:78px 0;}
  .offer-grid,.video-grid,.footer__inner{grid-template-columns:1fr;}
  .offer-hero__body{padding:30px;}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important;}
  .reveal,.reveal--clip{opacity:1;transform:none;clip-path:none;}
  body.loaded .hero__text > *{transition-delay:0s;}
}

/* ---- nav dual buttons: primary "Get HALO" + smaller "Member Login" ---- */
.nav__cta{display:flex;align-items:center;gap:14px;}
.nav__cta .btn--get{color:#06131F;font-weight:700;letter-spacing:.2em;
  background:linear-gradient(180deg,var(--plasma-hot) 0%,var(--plasma) 48%,#2E9FD8 100%);
  border:1px solid rgba(182,236,255,.65);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.5),0 0 24px var(--glow),0 8px 18px rgba(0,0,0,.5);}
.nav__cta .btn--get:hover{color:#02101C;border-color:var(--plasma-hot);transform:translateY(-1px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.6),0 0 40px var(--glow),0 12px 26px rgba(0,0,0,.55);}
.nav__cta .btn--login{padding:.72rem 1.35rem;font-size:11px;font-weight:500;letter-spacing:.22em;color:#C9DEEC;
  background:linear-gradient(180deg,rgba(120,200,245,.06),transparent 60%),linear-gradient(180deg,#16293D,#0A1726);
  border:1px solid var(--line-strong);
  box-shadow:inset 0 1px 0 rgba(182,236,255,.16),0 6px 14px rgba(0,0,0,.45);}
.nav__cta .btn--login:hover{color:#fff;border-color:var(--plasma);box-shadow:inset 0 1px 0 rgba(182,236,255,.24),0 0 18px var(--glow);}
.nav.is-stuck .nav__cta .btn--get{padding:.72rem 1.6rem;font-size:12px;}
.nav.is-stuck .nav__cta .btn--login{padding:.6rem 1.15rem;font-size:10.5px;}
@media (max-width:760px){ .nav__cta{display:none;} }

/* ============================================================
   CENTERED NAV + RETRO-TECH CONTROL BUTTONS + TV/CRT HERO
   (appended overrides — source-order wins)
   ============================================================ */

/* --- center the whole nav cluster; brand floats at the right edge --- */
.nav__inner{display:flex;justify-content:center;align-items:center;gap:clamp(1.25rem,3vw,2.6rem);position:relative;}
.nav__links{order:1;}
.nav__cta{order:2;}
.nav__brand{position:absolute;right:clamp(1.5rem,4vw,3rem);top:50%;transform:translateY(-50%) translateX(8px);}
.nav.is-stuck .nav__brand{transform:translateY(-50%) translateX(0);}
.nav__burger{position:absolute;right:1rem;top:50%;transform:translateY(-50%);}

/* --- retro-tech control keys: brushed-metal face, knurled grip, glowing LED --- */
.nav__cta .btn{position:relative;border-radius:7px;padding:.92rem 1.5rem .92rem 2.45rem;text-transform:uppercase;}
.nav__cta .btn::before{ /* the LED */
  content:"";position:absolute;left:14px;top:50%;transform:translateY(-50%);
  width:8px;height:8px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%, #EAFBFF, var(--plasma) 60%, #1E6E96);
  box-shadow:0 0 8px var(--glow),0 0 16px var(--glow), inset 0 0 2px rgba(255,255,255,.85);
  animation:ledpulse 2.4s ease-in-out infinite;}
.nav__cta .btn::after{ /* knurled grip ridges */
  content:"";position:absolute;right:9px;top:50%;transform:translateY(-50%);width:13px;height:58%;
  background:repeating-linear-gradient(90deg, rgba(255,255,255,0.20) 0 1px, transparent 1px 3px);
  border-radius:2px;opacity:.45;pointer-events:none;}
.nav__cta .btn--get{color:#06131F;font-weight:700;letter-spacing:.2em;border:1px solid rgba(182,236,255,.6);
  background:linear-gradient(180deg,#E2F4FF 0%,#A9D8F2 16%,#6FB6DE 52%,#3E86B0 100%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.75), inset 0 -2px 4px rgba(0,0,0,.30), 0 0 22px var(--glow), 0 8px 16px rgba(0,0,0,.5);}
.nav__cta .btn--get:hover{transform:translateY(-1px);box-shadow:inset 0 1px 0 rgba(255,255,255,.85), inset 0 -2px 4px rgba(0,0,0,.3), 0 0 38px var(--glow), 0 12px 24px rgba(0,0,0,.55);}
.nav__cta .btn--login{color:#CFE3F0;font-weight:600;letter-spacing:.2em;font-size:11px;border:1px solid var(--line-strong);
  background:linear-gradient(180deg,#33506A 0%,#1D3346 32%,#142536 100%);
  box-shadow:inset 0 1px 0 rgba(182,236,255,.22), inset 0 -2px 4px rgba(0,0,0,.42), 0 6px 14px rgba(0,0,0,.5);}
.nav__cta .btn--login::before{background:radial-gradient(circle at 35% 30%, #BBD0DD, #5E7E8E 60%, #243744);box-shadow:0 0 5px rgba(120,200,245,.35);animation:none;}
.nav__cta .btn--login:hover{color:#fff;border-color:var(--plasma);box-shadow:inset 0 1px 0 rgba(182,236,255,.3), 0 0 18px var(--glow), 0 6px 14px rgba(0,0,0,.5);}
.nav__cta .btn--login:hover::before{background:radial-gradient(circle at 35% 30%, #EAFBFF, var(--plasma) 60%, #1E6E96);box-shadow:0 0 8px var(--glow);}
@keyframes ledpulse{0%,100%{opacity:.65}50%{opacity:1}}

/* --- HERO as a retro-futuristic screen: scanlines + CRT vignette + power LED --- */
.hero__scanlines{position:absolute;inset:0;z-index:2;pointer-events:none;opacity:.45;mix-blend-mode:multiply;
  background:repeating-linear-gradient(0deg, rgba(0,0,0,0.22) 0 1px, transparent 1px 3px);}
.hero::after{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background:radial-gradient(125% 125% at 50% 50%, transparent 58%, rgba(7,15,26,0.55) 100%);
  box-shadow:inset 0 0 130px 26px rgba(0,0,0,0.55), inset 0 0 0 1px rgba(120,200,245,0.14);}
.tv-led{position:absolute;right:20px;bottom:calc(var(--nav-h-tall) + 18px);z-index:3;width:9px;height:9px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%, #EAFBFF, var(--plasma) 60%, #1E6E96);
  box-shadow:0 0 10px var(--glow),0 0 20px var(--glow);animation:ledpulse 3s ease-in-out infinite;}

/* --- mobile: brand mark centered-left, burger right --- */
@media (max-width:760px){
  .nav__inner{justify-content:flex-start;}
  .nav__brand{display:flex;position:static;transform:none;opacity:1;pointer-events:auto;margin-right:auto;}
  .nav__brand-text{display:none;}
}

/* --- remove rollover plasma GLOW on body cards/rows (keep the lift, neutral shadow) --- */
.offer-hero:hover{box-shadow:inset 0 1px 0 rgba(182,236,255,0.14), 0 26px 60px -24px rgba(0,0,0,0.85);}
.offer-card:hover{box-shadow:inset 0 1px 0 rgba(182,236,255,0.12), 0 18px 44px -20px rgba(0,0,0,0.8);}
.video-card:hover .video-card__thumb{box-shadow:0 18px 44px -20px rgba(0,0,0,0.8);}
.cal__item:hover{box-shadow:0 14px 36px -20px rgba(0,0,0,0.8);}

/* ============================================================
   SMALLER nav buttons + LOCKED-STATE layout
   (logo left · links collapse to hamburger · Get HALO + Member Login + burger right)
   ============================================================ */

/* shrink the retro keys (both states) */
.nav__cta .btn{padding:.6rem 1.05rem .6rem 1.95rem;font-size:11px;border-radius:6px;}
.nav__cta .btn--get{font-size:11px;letter-spacing:.16em;}
.nav__cta .btn--login{font-size:10px;letter-spacing:.16em;padding:.55rem 1rem .55rem 1.8rem;}
.nav__cta .btn::before{left:11px;width:7px;height:7px;}      /* LED */
.nav__cta .btn::after{right:7px;width:11px;height:54%;}      /* knurl */

/* LOCKED (stuck): logo left, buttons + burger right, links hidden */
.nav.is-stuck .nav__inner{justify-content:flex-start;gap:16px;}
.nav.is-stuck .nav__links{display:none;}                     /* collapse into hamburger */
.nav.is-stuck .nav__brand{position:static;transform:none;opacity:1;pointer-events:auto;order:0;margin-right:auto;}
.nav.is-stuck .nav__cta{order:1;}
.nav.is-stuck .nav__burger{display:flex;position:static;transform:none;order:2;}
.nav.is-stuck .nav__cta .btn--get{padding:.55rem 1rem .55rem 1.85rem;font-size:10.5px;}
.nav.is-stuck .nav__cta .btn--login{padding:.5rem .9rem .5rem 1.7rem;font-size:10px;}

/* --- nav brand = REAL logo art (never font-duplicated) --- */
.nav__brand-logo{height:34px;width:auto;display:block;filter:drop-shadow(0 0 10px rgba(86,199,255,.35));}
.nav.is-stuck .nav__brand-logo{height:30px;}
@media (max-width:760px){ .nav__brand-logo{height:26px;} }

/* ============================================================
   LOCKED NAV v2: logo LEFT · buttons CENTER · burger RIGHT
   + slimmer (low-height) tech buttons
   ============================================================ */
.nav.is-stuck .nav__inner{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;}
.nav.is-stuck .nav__links{display:none;}
.nav.is-stuck .nav__brand{grid-column:1;justify-self:start;position:static;transform:none;opacity:1;pointer-events:auto;margin:0;}
.nav.is-stuck .nav__cta{grid-column:2;justify-self:center;}
.nav.is-stuck .nav__burger{grid-column:3;justify-self:end;display:flex;position:static;transform:none;}

/* slim tech keys — less height, both states */
.nav__cta .btn{padding:.4rem 1rem .4rem 1.8rem;font-size:10.5px;border-radius:5px;}
.nav__cta .btn--login{padding:.38rem .9rem .38rem 1.7rem;font-size:10px;}
.nav__cta .btn::before{left:10px;width:6px;height:6px;}     /* LED */
.nav__cta .btn::after{right:7px;width:10px;height:50%;}      /* knurl */
.nav.is-stuck .nav__cta .btn--get{padding:.34rem .85rem .34rem 1.7rem;font-size:10px;}
.nav.is-stuck .nav__cta .btn--login{padding:.32rem .8rem .32rem 1.6rem;font-size:9.5px;}

/* ============================================================
   MOBILE NAV (<=760): big logo left + burger right on top row,
   Get HALO + Member Login always visible & centered below
   ============================================================ */
@media (max-width:760px){
  .nav__inner, .nav.is-stuck .nav__inner{
    display:grid;grid-template-columns:1fr auto;
    grid-template-areas:"brand burger" "cta cta";
    align-items:center;row-gap:10px;column-gap:12px;
    height:auto;min-height:var(--nav-h-stuck);padding:12px 16px;
  }
  .nav__links{display:none;}
  .nav__brand{grid-area:brand;justify-self:start;position:static;transform:none;opacity:1;pointer-events:auto;margin:0;display:flex;}
  .nav__brand-logo{height:64px;}                 /* ~2.5x bigger than before */
  .nav__burger{grid-area:burger;justify-self:end;position:static;transform:none;display:flex;}
  .nav__cta{grid-area:cta;display:flex;justify-content:center;gap:12px;}
  .nav__cta .btn--get{font-size:10.5px;}
  .nav__cta .btn--login{font-size:10px;}
}

/* ============================================================
   MOBILE NAV v2: single row — logo LEFT (big + shadow),
   buttons CENTER (stacked, tiny), burger RIGHT
   ============================================================ */
@media (max-width:760px){
  .nav__inner, .nav.is-stuck .nav__inner{
    grid-template-columns:auto 1fr auto;
    grid-template-areas:"brand cta burger";
    row-gap:0;column-gap:10px;align-items:center;padding:8px 14px;height:auto;
  }
  .nav__brand{grid-area:brand;}
  .nav__brand-logo{height:96px;                 /* ~1.5x bigger again */
    filter:drop-shadow(0 10px 16px rgba(0,0,0,.65)) drop-shadow(0 0 16px rgba(86,199,255,.45));}
  .nav__cta{grid-area:cta;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:7px;}
  .nav__cta .btn{font-size:9px;letter-spacing:.12em;padding:.3rem .7rem .3rem 1.35rem;}
  .nav__cta .btn::before{left:7px;width:5px;height:5px;}   /* smaller LED */
  .nav__cta .btn::after{display:none;}                     /* drop knurl to save width */
  .nav__burger{grid-area:burger;}
}

/* ============================================================
   MOBILE NAV v3: EVERYTHING ON ONE LINE
   logo | Get HALO | Member Login | hamburger
   ============================================================ */
@media (max-width:760px){
  .nav__inner, .nav.is-stuck .nav__inner{
    display:grid;grid-template-columns:auto 1fr auto;
    grid-template-areas:"brand cta burger";
    align-items:center;column-gap:8px;row-gap:0;padding:8px 12px;height:auto;
  }
  .nav__brand{grid-area:brand;}
  .nav__brand-logo{height:88px;max-width:40vw;width:auto;object-fit:contain;
    filter:drop-shadow(0 10px 16px rgba(0,0,0,.65)) drop-shadow(0 0 16px rgba(86,199,255,.45));}
  .nav__cta{grid-area:cta;display:flex;flex-direction:row;flex-wrap:nowrap;justify-content:center;align-items:center;gap:6px;}
  .nav__cta .btn{font-size:8.5px;letter-spacing:.08em;padding:.34rem .5rem .34rem 1.05rem;white-space:nowrap;}
  .nav__cta .btn::before{left:6px;width:5px;height:5px;}
  .nav__cta .btn::after{display:none;}
  .nav__burger{grid-area:burger;justify-self:end;}
}

/* ============================================================
   MOBILE NAV v4: true page-center buttons + smaller logo
   layout = [logo]1fr | [btn btn]auto(center) | [burger]1fr
   ============================================================ */
@media (max-width:760px){
  .nav__inner, .nav.is-stuck .nav__inner{
    grid-template-columns:1fr auto 1fr;
    grid-template-areas:"brand cta burger";
  }
  .nav__brand{grid-area:brand;justify-self:start;}
  .nav__brand-logo{height:44px;max-width:none;}
  .nav__cta{grid-area:cta;justify-self:center;flex-direction:row;flex-wrap:nowrap;gap:8px;}
  .nav__cta .btn{font-size:9.5px;letter-spacing:.1em;padding:.38rem .6rem .38rem 1.2rem;}
  .nav__cta .btn::before{left:7px;width:5px;height:5px;}
  .nav__burger{grid-area:burger;justify-self:end;}
}

/* ============================================================
   NAV LOGO: smaller · translucent · hover = full white + pop + shadow
   ============================================================ */
.nav__brand-logo{
  height:24px;opacity:.6;
  transition:opacity .35s var(--ease-lux), transform .35s var(--ease-lux), filter .35s var(--ease-lux);
  filter:drop-shadow(0 8px 16px rgba(0,0,0,.7)) drop-shadow(0 3px 6px rgba(0,0,0,.55)) drop-shadow(0 0 14px rgba(86,199,255,.4));
}
.nav.is-stuck .nav__brand-logo{height:24px;}
.nav__brand:hover .nav__brand-logo{
  opacity:1;transform:scale(1.12);
  filter:drop-shadow(0 12px 22px rgba(0,0,0,.78)) drop-shadow(0 0 24px rgba(86,199,255,.75));
}
@media (max-width:760px){ .nav__brand-logo{height:30px;} }

/* ============================================================
   HAMBURGER DRAWER direction flip:
   over hero (tall) -> opens UPWARD · locked (stuck) -> opens DOWNWARD
   ============================================================ */
.nav__drawer{position:absolute;left:0;right:0;bottom:100%;top:auto;z-index:60;
  border-top:none;border-bottom:1px solid var(--line);
  box-shadow:0 -14px 34px rgba(0,0,0,.55);}
.nav.is-stuck .nav__drawer{top:100%;bottom:auto;
  border-bottom:none;border-top:1px solid var(--line);
  box-shadow:0 14px 34px rgba(0,0,0,.55);}

/* hamburger: translucent -> hover full white + pop */
.nav__burger{opacity:.6;transition:opacity .3s var(--ease-lux), transform .3s var(--ease-lux);}
.nav__burger:hover{opacity:1;transform:scale(1.14);}
.nav__burger:hover span{background:#fff;box-shadow:0 0 9px var(--glow);}

/* hamburger: same layered shadow as the logo */
.nav__burger{
  filter:drop-shadow(0 8px 16px rgba(0,0,0,.7)) drop-shadow(0 3px 6px rgba(0,0,0,.55)) drop-shadow(0 0 14px rgba(86,199,255,.4));
  transition:opacity .3s var(--ease-lux), transform .3s var(--ease-lux), filter .3s var(--ease-lux);
}
.nav__burger:hover{
  filter:drop-shadow(0 12px 22px rgba(0,0,0,.78)) drop-shadow(0 0 24px rgba(86,199,255,.75));
}

/* ============================================================
   MATCH the two nav buttons: identical metal + identical shadow.
   Only difference: Get HALO gets a lighter-blue outline (primary).
   ============================================================ */
.nav__cta .btn--get, .nav__cta .btn--login{
  color:#DCEBF6;font-weight:600;letter-spacing:.16em;
  background:linear-gradient(180deg, rgba(120,200,245,0.08) 0%, transparent 55%),
             linear-gradient(180deg,#1A3145 0%,#0C1B2B 100%);
  box-shadow:inset 0 1px 0 rgba(182,236,255,.20), inset 0 -1px 0 rgba(0,0,0,.45), 0 6px 16px rgba(0,0,0,.5);
}
.nav__cta .btn--get{border:1px solid var(--plasma-hot);}     /* lighter blue outline = primary */
.nav__cta .btn--login{border:1px solid var(--line-strong);} /* dimmer outline */
.nav__cta .btn--get:hover, .nav__cta .btn--login:hover{
  transform:translateY(-1px);border-color:var(--plasma);
  box-shadow:inset 0 1px 0 rgba(182,236,255,.28), 0 8px 20px rgba(0,0,0,.55), 0 0 16px rgba(86,199,255,.32);
}

/* ============================================================
   HERO CLEANUP + WALL-EXTENDING BACKDROP
   - remove line/scanline/CRT overlays (keep the clip clean)
   - blurred frame of the same clip fills wide-screen edges
   - video edges feather into the blur; far edges fade to wall-white
   ============================================================ */
.hero__scanlines,.hero__grain{display:none!important;}
.hero::after{display:none!important;}        /* kill CRT vignette/frame line */
.tv-led{display:none!important;}             /* clean */

.hero{
  background:
    linear-gradient(90deg, rgba(233,236,240,.92) 0%, rgba(233,236,240,0) 13%,
                            rgba(233,236,240,0) 87%, rgba(233,236,240,.92) 100%),
    url("../img/hero-bg-blur.jpg") center/cover no-repeat,
    #AAB2BC;
}
/* video feathers into the matching blurred wall on the sides */
.hero__bg{
  -webkit-mask:linear-gradient(90deg, transparent 0, #000 6%, #000 94%, transparent 100%);
          mask:linear-gradient(90deg, transparent 0, #000 6%, #000 94%, transparent 100%);
}
/* lighter veil: only a soft bottom darken so the nav/logo stay legible */
.hero__veil{background:linear-gradient(180deg, transparent 58%, rgba(7,15,26,.5) 100%);}

/* ============================================================
   HERO HOME ICON (top-right, dark) + GET HALO hover flash + orb flicker
   ============================================================ */
/* hero home button — translucent, hover pops solid; hides when nav locks */
.hero__home{position:fixed;top:18px;left:22px;z-index:40;display:block;width:50px;line-height:0;
  opacity:.55;transition:opacity .3s var(--ease-lux), transform .3s var(--ease-lux), filter .3s var(--ease-lux);
  filter:drop-shadow(0 8px 16px rgba(0,0,0,.55)) drop-shadow(0 0 12px rgba(86,199,255,.3));}
.hero__home img{width:100%;height:auto;display:block;}
.hero__home:hover{opacity:1;transform:scale(1.12);
  filter:drop-shadow(0 12px 22px rgba(0,0,0,.65)) drop-shadow(0 0 22px rgba(86,199,255,.65));}
.is-navstuck .hero__home{opacity:0;pointer-events:none;}
@media (max-width:760px){ .hero__home{width:40px;top:14px;left:14px;} }

/* Get HALO: light up + single flash on hover; dark text on bright bg for contrast */
@keyframes getflash{0%{filter:brightness(1.75)}45%{filter:brightness(1)}56%{filter:brightness(1.3)}100%{filter:brightness(1)}}
.nav__cta .btn--get:hover{
  background:linear-gradient(180deg,#EAF8FF 0%,#9AD2EE 45%,#56C7FF 100%);
  color:#04121E;border-color:#EAF8FF;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.6), 0 0 24px var(--glow), 0 8px 20px rgba(0,0,0,.5);
  animation:getflash .5s ease-out 1;
}
.nav__cta .btn--get:hover::before{background:radial-gradient(circle at 35% 30%, #FFFFFF, #2E9FD8 70%);}

/* the orb/LED on Get HALO: continuous glow + flicker loop (invites a click) */
@keyframes orbflicker{
  0%,100%{opacity:1;box-shadow:0 0 6px var(--glow),0 0 12px var(--glow);}
  44%{opacity:1;}
  47%{opacity:.3;}
  50%{opacity:1;box-shadow:0 0 11px #fff,0 0 22px var(--plasma-hot);}
  61%{opacity:.5;}
  65%{opacity:1;}
  84%{opacity:1;box-shadow:0 0 5px var(--glow);}
}
.nav__cta .btn--get::before{animation:orbflicker 2.6s infinite var(--ease-lux);}

/* hero home (white) — deeper shadow for light wall + tilt/skew + solid on hover */
.hero__home{filter:drop-shadow(0 7px 13px rgba(0,0,0,.6)) drop-shadow(0 2px 5px rgba(0,0,0,.5)) drop-shadow(0 0 12px rgba(86,199,255,.35));}
.hero__home:hover{opacity:1;transform:scale(1.12) rotate(-7deg) skewX(-7deg);
  filter:drop-shadow(0 12px 22px rgba(0,0,0,.7)) drop-shadow(0 0 24px rgba(86,199,255,.7));}

/* hero home: simple float on hover (no skew) */
.hero__home:hover{
  opacity:1;transform:translateY(-6px) scale(1.05);
  filter:drop-shadow(0 16px 22px rgba(0,0,0,.6)) drop-shadow(0 0 22px rgba(86,199,255,.6));
}

/* drawer = compact panel anchored under the hamburger (not full width) */
.nav__drawer{left:auto;right:clamp(1.25rem,4vw,3rem);width:min(260px,82vw);border-radius:10px;
  box-shadow:0 16px 40px rgba(0,0,0,.6), 0 0 0 1px var(--line);}
.nav__drawer-links a:last-child{border-bottom:none;}

/* nudge drawer ~100px left on wider screens */
@media (min-width:761px){ .nav__drawer{right:calc(clamp(1.25rem,4vw,3rem) + 100px);} }

/* shine-woosh energy sweep on drawer links */
.nav__drawer-links a{position:relative;overflow:hidden;transition:color .3s var(--ease-lux);}
.nav__drawer-links a::after{content:"";position:absolute;top:0;left:-130%;width:75%;height:100%;pointer-events:none;
  background:linear-gradient(110deg, transparent 0%, rgba(182,236,255,.55) 50%, transparent 100%);transform:skewX(-18deg);}
.nav__drawer-links a:hover{color:#fff;text-shadow:0 0 10px var(--glow);}
.nav__drawer-links a:hover::after{animation:woosh .6s var(--ease-lux);}
@keyframes woosh{from{left:-130%}to{left:140%}}

/* two quick flashes per rotation on the loading halo */
@keyframes haloflash{
  0%,22%,100%{filter:brightness(1);}
  5%{filter:brightness(1.9) drop-shadow(0 0 16px var(--plasma-hot));}
  9%{filter:brightness(1);}
  14%{filter:brightness(1.9) drop-shadow(0 0 16px var(--plasma-hot));}
  18%{filter:brightness(1);}
}

/* ============================================================
   HERO video: contained + smaller so the full TV shows,
   light wall/void fills the space around it
   ============================================================ */
.hero__bg{
  top:50%;bottom:auto;left:50%;
  width:min(74vw,1040px);height:90%;
  object-fit:contain;object-position:center;
  transform:translate(-50%, calc(-50% + var(--py)));
}
/* brighten the surround into a soft white void (wall-matched) */
.hero{
  background:
    radial-gradient(120% 105% at 50% 42%, rgba(240,243,246,.55), rgba(240,243,246,.12) 52%, rgba(240,243,246,.62) 100%),
    url("../img/hero-bg-blur.jpg") center/cover no-repeat,
    #C9D0D7;
}
@media (max-width:760px){ .hero__bg{width:92vw;height:78%;} }

/* HERO video back to full-fill (cover), minimal zoom so it isn't stretched */
.hero__bg{
  top:50%;left:50%;bottom:auto;width:100%;height:112%;
  object-fit:cover;object-position:center;
  transform:translate(-50%, calc(-50% + var(--py)));
}
.hero{background:#0E1C2E;}   /* simple base; cover fills so no void needed */
@media (max-width:760px){ .hero__bg{width:100%;height:108%;} }

/* HERO: original full-fill size, crop anchored to BOTTOM (show more of the TV base) */
.hero{
  background:
    linear-gradient(90deg, rgba(233,236,240,.92) 0%, rgba(233,236,240,0) 13%,
                            rgba(233,236,240,0) 87%, rgba(233,236,240,.92) 100%),
    url("../img/hero-bg-blur.jpg") center/cover no-repeat,
    #AAB2BC;
}
.hero__bg{
  top:-8%;bottom:-8%;left:50%;width:min(calc(100% + 360px),1820px);height:116%;
  object-fit:cover;object-position:center bottom;
  transform:translate3d(-50%, var(--py), 0);
}
@media (max-width:760px){ .hero__bg{width:min(calc(100% + 360px),1820px);height:116%;} }

/* ============================================================
   HERO: shrink video (contained), favor the bottom,
   side edges feather into a WHITE-OUT void
   ============================================================ */
.hero{
  background:
    linear-gradient(90deg, #EEF1F4 0%, rgba(238,241,244,0) 24%,
                            rgba(238,241,244,0) 76%, #EEF1F4 100%),
    #E7EAEE;
}
.hero__veil{background:none;}   /* no dark band over the white void */
.hero__bg{
  top:50%;left:50%;bottom:auto;
  width:min(72vw,1000px);height:96%;
  object-fit:contain;object-position:center bottom;
  transform:translate(-50%, calc(-50% + var(--py)));
  -webkit-mask:linear-gradient(90deg, transparent 0, #000 12%, #000 88%, transparent 100%);
          mask:linear-gradient(90deg, transparent 0, #000 12%, #000 88%, transparent 100%);
}
@media (max-width:760px){ .hero__bg{width:94vw;height:84%;} }

/* HERO: FILL the space (cover) + white-out feathered side edges + show more bottom */
.hero{
  background:
    linear-gradient(90deg, #EEF1F4 0%, rgba(238,241,244,0) 16%,
                            rgba(238,241,244,0) 84%, #EEF1F4 100%),
    #E7EAEE;
}
.hero__veil{background:none;}
.hero__bg{
  top:-8%;bottom:-8%;left:50%;width:min(calc(100% + 360px),1820px);height:116%;
  object-fit:cover;object-position:center bottom;
  transform:translate3d(-50%, var(--py), 0);
  -webkit-mask:linear-gradient(90deg, transparent 0, #000 12%, #000 88%, transparent 100%);
          mask:linear-gradient(90deg, transparent 0, #000 12%, #000 88%, transparent 100%);
}
@media (max-width:760px){ .hero__bg{width:min(calc(100% + 360px),1820px);height:116%;} }

/* drop hero video ~33px to reveal a touch more halo up top */
.hero__bg{transform:translate3d(-50%, calc(var(--py) + 23px), 0);}

/* shift hero video UP on smaller screens so only ~half the halo shows
   (TODO: swap in a mobile-cropped hero video for the real fix) */
@media (max-width:1024px){ .hero__bg{transform:translate3d(-50%, calc(var(--py) - 20px), 0);} }
@media (max-width:760px){  .hero__bg{transform:translate3d(-50%, calc(var(--py) - 70px), 0);} }

/* side edges: wider feather that dissolves into the video's own wall blue-grey (no hard edge) */
.hero{ background:#A6ADB6; }   /* matches the wall tone at the video's edge */
.hero__bg{
  -webkit-mask:linear-gradient(90deg, transparent 0, #000 20%, #000 80%, transparent 100%);
          mask:linear-gradient(90deg, transparent 0, #000 20%, #000 80%, transparent 100%);
}

/* FIX: nav must always fill the space the hero reserves (no gap under it).
   Mobile rules had set height:auto (shorter than reserved) -> hero showed through. */
@media (max-width:1024px){
  .nav__inner{ height:var(--nav-h-tall)!important; min-height:var(--nav-h-tall)!important; }
}
