/* ============================================================
   UnityESS — Cinematic Luxury Experience
   Shared design system  ·  Light Premium  ·  Blue (Ornate)
   ============================================================ */

:root{
  /* Blue — Ornate / UnityESS family */
  --blue:        #016297;   /* primary */
  --blue-deep:   #013F66;   /* midnight */
  --blue-ink:    #06192B;   /* near-black ink */
  --blue-soft:   #2E8BC0;
  --blue-glow:   #4FA8D8;

  /* Light premium neutrals */
  --paper:       #FFFFFF;
  --paper-2:     #F4F8FB;   /* light tint */
  --paper-3:     #E7F0F6;   /* medium tint */
  --line:        rgba(6,25,43,.12);

  /* Text */
  --ink:         #0B1E2D;
  --ink-2:       #2C4456;
  --muted:       #5E7689;

  --radius:      18px;
  --ease:        cubic-bezier(.22,1,.36,1);
  --ease-out:    cubic-bezier(.16,1,.3,1);
  --maxw:        1320px;
}

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

html{ -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; }
html.lenis, html.lenis body{ height:auto; }
.lenis.lenis-smooth{ scroll-behavior:auto !important; }

body{
  font-family:"Chivo", "Helvetica Neue", Arial, sans-serif;
  background:var(--paper);
  color:var(--ink);
  font-weight:300;
  line-height:1.5;
  overflow-x:hidden;
  cursor:none;
}

img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }

::selection{ background:var(--blue); color:#fff; }

/* ---------- Type ---------- */
.display{
  font-weight:200;
  line-height:.98;
  letter-spacing:-.03em;
  font-size:clamp(2.6rem, 7.2vw, 7.4rem);
}
.h2{
  font-weight:200;
  letter-spacing:-.025em;
  line-height:1.02;
  font-size:clamp(2rem, 4.6vw, 4.2rem);
}
.h3{
  font-weight:300;
  letter-spacing:-.02em;
  font-size:clamp(1.4rem, 2.4vw, 2.1rem);
}
.eyebrow{
  display:inline-block;
  position:relative;
  font-size:clamp(.9rem, 1.15vw, 1.1rem);
  font-weight:600;
  letter-spacing:.3em;
  text-transform:uppercase;
  padding-bottom:.85rem;
  /* rich blue gradient fill (with solid fallback) */
  color:var(--blue);
  background:linear-gradient(95deg, var(--blue-deep) 0%, var(--blue) 45%, var(--blue-glow) 100%);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
}
.eyebrow::after{
  content:"";
  position:absolute;
  left:50%; bottom:0;
  transform:translateX(-50%);
  width:2.4rem; height:2px;
  border-radius:2px;
  background:linear-gradient(90deg, var(--blue) 0%, var(--blue-glow) 100%);
}
.lead{
  font-size:clamp(1.05rem, 1.5vw, 1.4rem);
  font-weight:300;
  color:var(--ink-2);
  line-height:1.55;
}
.muted{ color:var(--muted); }
.thin{ font-weight:200; }

/* ---------- Layout ---------- */
.wrap{ width:min(var(--maxw), 90vw); margin-inline:auto; }
section{ position:relative; }
.pad{ padding:clamp(6rem, 13vh, 11rem) 0; }

/* ---------- Custom cursor ---------- */
.cursor{
  position:fixed; top:0; left:0; z-index:9999;
  width:9px; height:9px; border-radius:50%;
  background:var(--blue);
  pointer-events:none;
  transform:translate(-50%,-50%);
  mix-blend-mode:normal;
}
.cursor-ring{
  position:fixed; top:0; left:0; z-index:9998;
  width:42px; height:42px; border-radius:50%;
  border:1px solid rgba(1,98,151,.45);
  pointer-events:none;
  transform:translate(-50%,-50%);
  transition:width .35s var(--ease), height .35s var(--ease),
             background .35s var(--ease), border-color .35s var(--ease);
}
.cursor-ring.hot{
  width:74px; height:74px;
  background:rgba(1,98,151,.08);
  border-color:rgba(1,98,151,.7);
}
@media (hover:none){ body{cursor:auto;} .cursor,.cursor-ring{display:none;} }

/* ---------- Nav ---------- */
.nav{
  position:fixed; inset:0 0 auto 0; z-index:900;
  display:flex; align-items:center; justify-content:space-between;
  padding:1.4rem clamp(1.2rem,5vw,3.2rem);
  background:rgba(255,255,255,.9);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  box-shadow:0 1px 0 var(--line);
  transition:background .5s var(--ease), backdrop-filter .5s var(--ease), padding .5s var(--ease), box-shadow .5s var(--ease);
}
.nav.scrolled{
  background:rgba(255,255,255,.82);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  padding-top:.95rem; padding-bottom:.95rem;
  box-shadow:0 1px 0 var(--line);
}
.brand{ display:flex; align-items:center; gap:.6rem; font-weight:500; letter-spacing:-.01em; font-size:1.18rem; color:var(--ink); }
.brand .mark{ width:26px; height:26px; flex:none; }
.brand-logo{ height:30px; width:auto; display:block; }
.foot-brand .brand-logo{ height:40px; }
.brand b{ font-weight:700; }
.brand .e{ color:var(--blue); font-weight:300; }
/* nav text stays dark on the solid header */

.nav-links{ display:flex; align-items:center; gap:clamp(1.2rem,2.6vw,2.6rem); }
.nav-links a{ font-size:.92rem; font-weight:400; position:relative; }
.nav-links a:not(.btn)::after{
  content:""; position:absolute; left:0; bottom:-5px; height:1px; width:0; background:currentColor;
  transition:width .4s var(--ease);
}
.nav-links a:not(.btn):hover::after{ width:100%; }
.btn{
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.7rem 1.4rem; border-radius:100px;
  background:var(--blue); color:#fff !important;
  font-size:.9rem; font-weight:400;
  transition:transform .4s var(--ease), background .4s var(--ease), box-shadow .4s var(--ease);
  box-shadow:0 8px 24px -10px rgba(1,98,151,.6);
}
.btn:hover{ transform:translateY(-2px); background:var(--blue-deep); }
.btn.ghost{ background:transparent; color:var(--ink) !important; border:1px solid var(--line); box-shadow:none; }
.nav:not(.scrolled) .btn.ghost{ color:#fff !important; border-color:rgba(255,255,255,.4); }
.btn.ghost:hover{ border-color:var(--blue); color:var(--blue) !important; }
@media(max-width:760px){ .nav-links .hide-sm{ display:none; } }

/* ---------- Hero ---------- */
.hero{ aspect-ratio:16/9; max-height:100svh; min-height:0; position:relative; overflow:hidden; display:flex; align-items:flex-end; }
.hero-media{ position:absolute; inset:0; will-change:transform; }
.hero-media img{ width:100%; height:100%; object-fit:cover; }
.hero-scrim{
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(3,18,32,.42) 0%, rgba(3,18,32,0) 24%, rgba(3,18,32,0) 100%);
}
.hero-inner{ position:relative; z-index:3; width:100%; padding-bottom:clamp(3rem,8vh,6rem); color:#fff; }
.hero .display{ color:#fff; max-width:16ch; }
.hero .eyebrow{
  color:var(--blue-glow);
  background:linear-gradient(95deg, var(--blue-glow) 0%, #9fd4ef 100%);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
}
.hero .eyebrow::after{ background:linear-gradient(90deg, var(--blue-glow) 0%, rgba(159,212,239,.2) 100%); }
.hero-sub{ margin-top:1.4rem; max-width:46ch; color:rgba(255,255,255,.82); font-size:clamp(1rem,1.4vw,1.3rem); font-weight:300; }
.hero-cta{ margin-top:2.2rem; display:flex; gap:1rem; flex-wrap:wrap; }
.scroll-cue{
  position:absolute; left:50%; bottom:1.6rem; transform:translateX(-50%); z-index:4;
  display:flex; flex-direction:column; align-items:center; gap:.55rem;
  color:rgba(255,255,255,.7); font-size:.66rem; letter-spacing:.3em; text-transform:uppercase;
}
.scroll-cue .bar{ width:1px; height:46px; background:linear-gradient(rgba(255,255,255,.8),rgba(255,255,255,0)); animation:cue 2.4s var(--ease) infinite; transform-origin:top; }
@keyframes cue{ 0%{transform:scaleY(0);opacity:0} 30%{opacity:1} 60%{transform:scaleY(1);opacity:1} 100%{transform:scaleY(1);opacity:0} }

/* ---------- Reveal primitives ---------- */
.reveal{ opacity:0; transform:translateY(34px); }
.line-mask{ overflow:hidden; display:block; }
.line-mask > span{ display:block; transform:translateY(110%); }
.fade{ opacity:0; }

/* ---------- Stats ---------- */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border-block:1px solid var(--line); }
.stat{ background:var(--paper); padding:clamp(2rem,4vw,3.4rem) clamp(1.2rem,2.5vw,2rem); }
.stat .num{ font-size:clamp(2.2rem,4.4vw,3.6rem); font-weight:200; letter-spacing:-.03em; color:var(--blue); line-height:1; }
.stat .lbl{ margin-top:.7rem; font-size:.8rem; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); }
@media(max-width:820px){ .stats{ grid-template-columns:repeat(2,1fr); } }

/* ---------- Section intro ---------- */
.intro-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,5rem); align-items:center; }
@media(max-width:900px){ .intro-grid{ grid-template-columns:1fr; } }

/* image that expands on scroll */
.expand-wrap{ width:100%; display:flex; justify-content:center; }
.expand{
  position:relative; overflow:hidden; border-radius:var(--radius);
  width:62%; aspect-ratio:16/9; will-change:width,transform; box-shadow:0 40px 80px -40px rgba(6,25,43,.45);
}
.expand img{ width:100%; height:120%; object-fit:cover; will-change:transform; }
@media(max-width:900px){ .expand{ width:88%; } }

/* ---------- Products ---------- */
.prod-head{ display:flex; justify-content:space-between; align-items:flex-end; gap:2rem; flex-wrap:wrap; margin-bottom:clamp(2.4rem,5vw,4rem); }
.prod-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1rem,1.6vw,1.6rem); }
@media(max-width:900px){ .prod-grid{ grid-template-columns:1fr; } }
.card{
  position:relative; overflow:hidden; border-radius:var(--radius);
  background:var(--paper-2); border:1px solid var(--line);
  min-height:clamp(380px,46vw,560px); display:flex; flex-direction:column; justify-content:flex-end;
  isolation:isolate;
}
.card .media{ position:absolute; inset:0; z-index:-1; }
.card .media img{ width:100%; height:100%; object-fit:cover; transition:transform 1.2s var(--ease); }
.card::after{ content:""; position:absolute; inset:0; z-index:-1; background:linear-gradient(180deg, rgba(6,25,43,0) 38%, rgba(6,25,43,.82) 100%); }
.card:hover .media img{ transform:scale(1.07); }
.card .body{ padding:clamp(1.4rem,2.4vw,2.2rem); color:#fff; }
.card .tag{ font-size:.7rem; letter-spacing:.26em; text-transform:uppercase; color:var(--blue-glow); }
.card .name{ font-size:clamp(1.5rem,2.4vw,2.1rem); font-weight:300; margin-top:.5rem; letter-spacing:-.02em; }
.card .cap{ margin-top:.35rem; color:rgba(255,255,255,.78); font-size:.98rem; }
.card .go{ margin-top:1.1rem; display:inline-flex; align-items:center; gap:.5rem; font-size:.86rem; letter-spacing:.04em; }
.card .go svg{ transition:transform .45s var(--ease); }
.card:hover .go svg{ transform:translateX(6px); }

/* ---------- Feature rows (intelligence) ---------- */
.feat{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,6vw,6rem); align-items:center; padding-block:clamp(3rem,7vh,6rem); }
.feat:nth-child(even) .feat-media{ order:-1; }
@media(max-width:900px){ .feat{ grid-template-columns:1fr; } .feat:nth-child(even) .feat-media{ order:0; } }
.feat-media{ border-radius:var(--radius); overflow:hidden; aspect-ratio:5/4; box-shadow:0 40px 80px -48px rgba(6,25,43,.5); }
.feat-media img{ width:100%; height:114%; object-fit:cover; will-change:transform; }
.feat .num-mark{ font-size:.8rem; letter-spacing:.3em; color:var(--blue); }

/* ---------- Big statement / manufacturing ---------- */
.banner{ position:relative; height:108vh; overflow:hidden; display:flex; align-items:center; }
.banner-media{ position:absolute; inset:-14% 0; will-change:transform; }
.banner-media img{ width:100%; height:100%; object-fit:cover; }
.banner-scrim{ position:absolute; inset:0; background:
  linear-gradient(90deg, rgba(6,25,43,.92) 0%, rgba(6,25,43,.72) 38%, rgba(6,25,43,.42) 70%, rgba(6,25,43,.30) 100%),
  linear-gradient(180deg, rgba(6,25,43,.45) 0%, rgba(6,25,43,.15) 45%, rgba(6,25,43,.55) 100%); }
.banner-inner{ position:relative; z-index:2; color:#fff; }
.banner .big-num{ font-size:clamp(4rem,12vw,11rem); font-weight:200; line-height:.9; letter-spacing:-.04em; }

/* ---------- Applications ---------- */
.apps{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
@media(max-width:760px){ .apps{ grid-template-columns:1fr; } }
.app{ background:var(--paper); padding:clamp(2rem,3.6vw,3.2rem); transition:background .5s var(--ease); }
.app:hover{ background:var(--paper-2); }
.app .idx{ font-size:.78rem; letter-spacing:.24em; color:var(--blue); }
.app h4{ font-size:clamp(1.25rem,2vw,1.6rem); font-weight:300; margin:.9rem 0 .7rem; letter-spacing:-.015em; }
.app p{ color:var(--muted); font-size:.98rem; max-width:46ch; }

/* ---------- CTA ---------- */
.cta{ text-align:center; }
.cta .h2{ max-width:18ch; margin-inline:auto; }
.cta .lead{ max-width:52ch; margin:1.4rem auto 2.4rem; }

/* ---------- Footer ---------- */
.footer{ background:var(--blue-ink); color:rgba(255,255,255,.74); padding:clamp(3.5rem,7vh,6rem) 0 2.5rem; }
.footer a{ color:rgba(255,255,255,.74); transition:color .3s var(--ease); }
.footer a:hover{ color:#fff; }
.foot-grid{ display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:2rem; }
@media(max-width:820px){ .foot-grid{ grid-template-columns:1fr 1fr; } }
.footer h5{ color:#fff; font-weight:500; font-size:.82rem; letter-spacing:.16em; text-transform:uppercase; margin-bottom:1.1rem; }
.footer ul{ list-style:none; display:flex; flex-direction:column; gap:.6rem; font-size:.95rem; }
.foot-brand .brand{ color:#fff; }
.foot-brand .mark .ring{ stroke:#fff; } .foot-brand .mark .core{ fill:#fff; }
.foot-brand p{ margin-top:1.1rem; max-width:34ch; font-size:.95rem; line-height:1.6; }
.foot-bottom{ margin-top:clamp(2.5rem,5vh,4rem); padding-top:1.6rem; border-top:1px solid rgba(255,255,255,.12); display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; font-size:.84rem; color:rgba(255,255,255,.5); }
.foot-contact{ display:inline-flex; align-items:center; gap:.6rem; }
.foot-contact a{ color:rgba(255,255,255,.72); }
.foot-contact a:hover{ color:#fff; }
.foot-contact .dot{ color:rgba(255,255,255,.3); }

/* ---------- Page hero (product pages) ---------- */
.phero{ height:86svh; min-height:560px; position:relative; overflow:hidden; display:flex; align-items:flex-end; }
.phero-media{ position:absolute; inset:-12% 0; will-change:transform; }
.phero-media img{ width:100%; height:100%; object-fit:cover; }
.phero-scrim{ position:absolute; inset:0; background:linear-gradient(180deg, rgba(3,18,32,.5), rgba(3,18,32,.1) 40%, rgba(3,18,32,.82)); }
.phero-inner{ position:relative; z-index:3; color:#fff; width:100%; padding-bottom:clamp(2.5rem,7vh,5rem); }

/* spec grid */
.specs{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border-block:1px solid var(--line); }
@media(max-width:820px){ .specs{ grid-template-columns:repeat(2,1fr); } }
.spec{ background:var(--paper); padding:clamp(1.8rem,3vw,2.8rem) clamp(1.2rem,2vw,1.8rem); }
.spec .v{ font-size:clamp(1.8rem,3.4vw,2.8rem); font-weight:200; color:var(--blue); letter-spacing:-.02em; line-height:1; }
.spec .k{ margin-top:.65rem; font-size:.78rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); }

.detail-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,5rem); align-items:center; }
@media(max-width:900px){ .detail-grid{ grid-template-columns:1fr; } }
.detail-media{ border-radius:var(--radius); overflow:hidden; aspect-ratio:4/3; box-shadow:0 40px 80px -48px rgba(6,25,43,.5); }
.detail-media img{ width:100%; height:112%; object-fit:cover; will-change:transform; }

.tick{ list-style:none; display:flex; flex-direction:column; gap:1rem; margin-top:1.6rem; }
.tick li{ display:flex; gap:.85rem; align-items:flex-start; font-size:1.02rem; color:var(--ink-2); }
.tick svg{ flex:none; margin-top:.25rem; }

.backlink{ display:inline-flex; align-items:center; gap:.5rem; color:var(--blue); font-size:.9rem; }

hr.rule{ border:none; border-top:1px solid var(--line); }

/* ---------- Spec table ---------- */
.spectable{ width:100%; border-collapse:collapse; margin-top:2rem; }
.spectable th, .spectable td{ text-align:left; padding:1rem 1.2rem; border-bottom:1px solid var(--line); vertical-align:top; font-size:.98rem; }
.spectable th{ width:34%; font-weight:400; color:var(--muted); font-size:.86rem; letter-spacing:.04em; }
.spectable td{ color:var(--ink); font-weight:300; }
.spectable tr:nth-child(even){ background:var(--paper-2); }
@media(max-width:680px){ .spectable th{ width:42%; } .spectable th,.spectable td{ padding:.8rem .7rem; font-size:.9rem; } }

/* banner video */
.banner-media video{ width:100%; height:100%; object-fit:cover; }
.feat-media video, .detail-media video, .phero-media video{ width:100%; height:100%; object-fit:cover; }

/* comparison table */
.spectable.compare{ min-width:680px; }
.spectable.compare thead th{ color:var(--ink); font-weight:500; font-size:.82rem; letter-spacing:.1em; text-transform:uppercase; border-bottom:1px solid var(--line); }
.spectable.compare thead th:first-child{ color:var(--muted); }
.spectable.compare tbody th{ width:22%; }
.spectable.compare td{ width:26%; }
.spectable.compare tbody tr:last-child td{ background:transparent; }
.spectable.compare tbody tr:nth-child(even){ background:var(--paper); }

/* ============ Hero page (Ornate redesign) ============ */
.badge-row{ display:flex; gap:.6rem; flex-wrap:wrap; }
.badge{ font-size:.74rem; letter-spacing:.12em; text-transform:uppercase; color:var(--blue); border:1px solid var(--line); border-radius:100px; padding:.5rem .9rem; }
.nav:not(.scrolled) .badge{ color:#fff; border-color:rgba(255,255,255,.4); }

/* story split */
.story{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(2rem,5vw,5rem); align-items:center; }
@media(max-width:900px){ .story{ grid-template-columns:1fr; } }
.story-media{ border-radius:var(--radius); overflow:hidden; aspect-ratio:4/3; box-shadow:0 40px 80px -48px rgba(6,25,43,.5); }
.story-media img{ width:100%; height:112%; object-fit:cover; will-change:transform; }
.story-media.badge-media{ display:grid; place-items:center; background:#f1f1ef; aspect-ratio:4/3; }
.story-media.badge-media img{ width:auto; height:auto; max-width:74%; max-height:74%; object-fit:contain; }

/* gallery (Innovating) */
.gallery{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(.7rem,1.4vw,1.2rem); }
@media(max-width:900px){ .gallery{ grid-template-columns:repeat(2,1fr); } }
.gtile{ position:relative; overflow:hidden; border-radius:14px; aspect-ratio:3/4; display:block; }
.gtile img{ width:100%; height:100%; object-fit:cover; transition:transform 1.1s var(--ease); }
.gtile:hover img{ transform:scale(1.07); }
.gtile::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(6,25,43,0) 45%,rgba(6,25,43,.8)); }
.gtile span{ position:absolute; left:1rem; bottom:1rem; z-index:2; color:#fff; font-size:.98rem; font-weight:400; letter-spacing:-.01em; }

/* product 4-grid */
.prod4{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(.8rem,1.4vw,1.4rem); }
@media(max-width:900px){ .prod4{ grid-template-columns:repeat(2,1fr); } }
@media(max-width:520px){ .prod4{ grid-template-columns:1fr; } }
.pcard{ display:block; border:1px solid var(--line); border-radius:16px; overflow:hidden; background:var(--paper); transition:transform .5s var(--ease), box-shadow .5s var(--ease); }
.pcard:hover{ transform:translateY(-4px); box-shadow:0 30px 60px -34px rgba(6,25,43,.4); }
.pcard .pimg{ aspect-ratio:4/3; overflow:hidden; background:#fff; display:grid; place-items:center; }
.pcard .pimg img{ width:100%; height:100%; object-fit:contain; padding:.7rem; transition:transform 1.1s var(--ease); }
.pcard:hover .pimg img{ transform:scale(1.06); }
.pcard .pbody{ padding:1.1rem 1.2rem 1.3rem; }
.pcard .pbody .t{ font-size:1.05rem; font-weight:400; }
.pcard .pbody .s{ color:var(--muted); font-size:.86rem; margin-top:.25rem; }

/* clients band */
.clients{ background:var(--paper); border-radius:var(--radius); border:1px solid var(--line); padding:clamp(1.6rem,3vw,2.6rem); }
.clients img{ width:100%; height:auto; }

/* news cards */
.news{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1rem,1.8vw,1.6rem); }
@media(max-width:900px){ .news{ grid-template-columns:1fr; } }
.ncard{ display:flex; flex-direction:column; border:1px solid var(--line); border-radius:16px; overflow:hidden; background:var(--paper); transition:transform .5s var(--ease), box-shadow .5s var(--ease); }
.ncard:hover{ transform:translateY(-4px); box-shadow:0 30px 60px -34px rgba(6,25,43,.4); }
.ncard .nimg{ aspect-ratio:16/10; overflow:hidden; }
.ncard .nimg img{ width:100%; height:100%; object-fit:cover; transition:transform 1.1s var(--ease); }
.ncard:hover .nimg img{ transform:scale(1.05); }
.ncard .nbody{ padding:1.3rem 1.3rem 1.5rem; display:flex; flex-direction:column; gap:.6rem; flex:1; }
.ncard .ndate{ font-size:.76rem; letter-spacing:.1em; text-transform:uppercase; color:var(--blue); }
.ncard h4{ font-size:1.1rem; font-weight:400; line-height:1.25; letter-spacing:-.01em; }
.ncard p{ color:var(--muted); font-size:.92rem; flex:1; }
.ncard .go{ color:var(--blue); font-size:.86rem; }

/* hero video */
.hero-media video{ width:100%; height:100%; object-fit:cover; }

/* ============ Futuristic banner scene ============ */
.future{ position:absolute; inset:0; overflow:hidden; }
.future .f-canvas{ position:absolute; inset:0; width:100%; height:100%; }
/* perspective grid floor */
.future .f-grid{
  position:absolute; left:-25%; right:-25%; bottom:-8%; height:70%;
  background-image:
    linear-gradient(rgba(79,168,216,.30) 1px, transparent 1px),
    linear-gradient(90deg, rgba(79,168,216,.30) 1px, transparent 1px);
  background-size:64px 64px;
  transform:perspective(420px) rotateX(64deg);
  transform-origin:bottom center;
  -webkit-mask-image:linear-gradient(transparent 0%, #000 55%, #000 100%);
  mask-image:linear-gradient(transparent 0%, #000 55%, #000 100%);
  animation:gridflow 7s linear infinite;
}
@keyframes gridflow{ from{ background-position:0 0,0 0; } to{ background-position:0 64px,64px 0; } }
/* neon horizon */
.future .f-horizon{
  position:absolute; left:0; right:0; top:54%; height:1px;
  background:linear-gradient(90deg, transparent, rgba(79,168,216,.9) 35%, rgba(159,208,236,1) 50%, rgba(79,168,216,.9) 65%, transparent);
  box-shadow:0 0 50px 10px rgba(79,168,216,.45);
}
.future .f-haze{
  position:absolute; left:0; right:0; top:18%; height:48%;
  background:radial-gradient(60% 80% at 50% 100%, rgba(79,168,216,.28), transparent 70%);
}
/* pulsing energy core */
.future .f-core{
  position:absolute; top:54%; left:50%; width:14px; height:14px; transform:translate(-50%,-50%);
  border-radius:50%; background:#bfe3f6; box-shadow:0 0 24px 6px rgba(159,208,236,.9);
}
.future .f-core::before, .future .f-core::after{
  content:""; position:absolute; inset:0; border-radius:50%; border:1px solid rgba(159,208,236,.6);
  animation:corePulse 3.2s ease-out infinite;
}
.future .f-core::after{ animation-delay:1.6s; }
@keyframes corePulse{ 0%{ transform:scale(1); opacity:.8; } 100%{ transform:scale(11); opacity:0; } }
/* left readability scrim over the scene */
.future .f-scrim{
  position:absolute; inset:0;
  background:linear-gradient(90deg, rgba(6,25,43,.85) 0%, rgba(6,25,43,.45) 40%, rgba(6,25,43,.15) 70%, rgba(6,25,43,.4) 100%),
            linear-gradient(180deg, rgba(6,25,43,.4), rgba(6,25,43,0) 40%, rgba(6,25,43,.55));
}
@media (prefers-reduced-motion: reduce){ .future .f-grid, .future .f-core::before, .future .f-core::after{ animation:none; } }

/* ============ Parallax cross-fade slideshow ============ */
.slideshow{ position:absolute; inset:-12% 0; }
.slideshow .slide{ position:absolute; inset:0; opacity:0; will-change:opacity,transform; animation:kenburns 30s infinite; }
.slideshow .slide img{ width:100%; height:100%; object-fit:cover; }
.slideshow .slide:nth-child(1){ animation-delay:0s; }
.slideshow .slide:nth-child(2){ animation-delay:6s; }
.slideshow .slide:nth-child(3){ animation-delay:12s; }
.slideshow .slide:nth-child(4){ animation-delay:18s; }
.slideshow .slide:nth-child(5){ animation-delay:24s; }
@keyframes kenburns{
  0%   { opacity:0; transform:scale(1.14); }
  3%   { opacity:1; }
  18%  { opacity:1; }
  21%  { opacity:0; transform:scale(1.0); }
  100% { opacity:0; transform:scale(1.0); }
}
@media (prefers-reduced-motion: reduce){
  .slideshow .slide{ animation:none; opacity:0; }
  .slideshow .slide:nth-child(1){ opacity:1; }
}
