/* ====== Futuristic theme aligned to logo background ====== */
:root{
  /* Deep midnight blue to match logo background */
  --bg:#070d19;
  --bg-2:#0b1326;
  --panel:#0c1426;
  --text:#e7f2ff;
  --muted:#91a6c7;
  --brand:#49c2ff;
  --brand-2:#9ae2ff;
  --accent:#00ecff;

  --radius:16px;
  --ring:0 0 0 2px rgba(73,194,255,.4);
  --container:1200px;

  /* Site-wide layout & motion helpers */
  --edge: clamp(12px, 2vw, 22px);      /* side gutters */
  --lift: translateY(-2px) scale(1.02);/* hover lift */
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0; color:var(--text);
  background:
    radial-gradient(1200px 900px at 20% -10%, rgba(0,180,255,.10), transparent 60%),
    radial-gradient(1000px 700px at 100% 110%, rgba(0,120,255,.08), transparent 60%),
    radial-gradient(1200px 1200px at 50% 120%, rgba(0,40,80,.35), transparent 65%),
    linear-gradient(180deg, var(--bg), var(--bg-2));
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,Arial,sans-serif;
  line-height:1.6; letter-spacing:.2px;
  overflow-x:hidden;
}

/* Full-screen animated canvas background */
#nebula{position:fixed; inset:0; z-index:-2; background:transparent}
/* Subtle vignetting */
.vignette{position:fixed; inset:0; pointer-events:none; z-index:-1;
  background:
    radial-gradient(1200px 700px at 50% 30%, transparent 65%, rgba(0,0,0,.3)),
    radial-gradient(1000px 600px at 50% 100%, transparent 60%, rgba(0,0,0,.35));
}

/* Typography & containers */
.container{max-width:var(--container); margin:0 auto; padding-inline:var(--edge)}
h1,h2,h3{line-height:1.2;margin:0 0 .5rem}
h1{font-size:clamp(2.4rem,5vw,3.8rem); font-family:Orbitron,Inter,sans-serif; letter-spacing:.08em; text-transform:uppercase}
h2{font-size:clamp(1.6rem,3vw,2.2rem)}
h3{font-size:1.1rem}
p{margin:.5rem 0 1rem}
a{color:var(--brand); text-decoration:none}
a:hover{color:var(--brand-2)}
img{max-width:100%; height:auto; display:block}

/* ===== Navigation: desktop flex row; mobile absolute dropdown ===== */
.site-header{position:relative}
.nav{position:sticky; top:0; z-index:1000; backdrop-filter: blur(10px);
  background:linear-gradient(180deg, rgba(7,13,25,.92), rgba(7,13,25,.55) 70%, transparent)}

/* Desktop row */
.nav .container{display:flex; align-items:center; justify-content:space-between; gap:24px; min-height:56px; padding-block:14px}
.brand{display:flex; align-items:center; gap:12px; color:var(--text); white-space:nowrap}
.brand img{width:40px; height:40px; border-radius:50%; filter: drop-shadow(0 0 12px rgba(73,194,255,.35))}
.brand span{font-family:Orbitron,Inter,sans-serif; letter-spacing:.08em; white-space:nowrap; display:inline-block}

#navToggle{display:none} /* hidden on desktop */

.nav-menu{display:flex; gap:22px; list-style:none; margin:0; padding:0}
.nav-menu a{padding:8px 10px; border-radius:10px; color:var(--text)}

.cta{
  margin-left:12px;
  padding:10px 14px; border-radius:14px;
  background:linear-gradient(90deg,var(--brand),var(--accent));
  color:#00101a; font-weight:800;
  box-shadow:0 8px 34px rgba(73,194,255,.30)
}

/* Mobile behavior */
@media (max-width:1200px){
  .nav .container{position:relative}
  .desktop-cta{display:none !important} /* keep CTA only inside panel on mobile */

  #navToggle{
    display:block;
    position:absolute;
    right:var(--edge);
    top:50%;
    transform:translateY(-50%);
    font-size:1.3rem;
    background:none; border:0; color:var(--text);
    z-index:1001; /* above panel */
  }

  #navMenu{display:none}

  .nav .container.nav-open #navMenu{
    display:grid;
    position:absolute;
    right:var(--edge);
    top:calc(100% + 8px);
    width:min(86vw, 360px);
    gap:12px; list-style:none; margin:0; padding:14px 16px;
    background:rgba(7,13,25,.85);
    border:1px solid rgba(156,220,255,.16);
    border-radius:12px;
    box-shadow:0 18px 60px rgba(0,0,0,.45);
    z-index:1000; /* below toggle */
  }

  /* CTA inside the dropdown panel */
  .nav .container.nav-open #navMenu .cta{
    display:inline-block; text-align:center; margin-top:8px;
  }
}

/* ===== Buttons & link interactions ===== */
h1,h2,h3, .brand span, .nav-menu a, .btn { font-family: Orbitron, Inter, sans-serif; letter-spacing:.06em }

.btn, .cta, .nav-menu a{
  position:relative;
  transition: transform .18s ease, box-shadow .18s ease, background-color .18s ease, color .18s ease;
  will-change: transform, box-shadow;
}
.btn:hover, .cta:hover, .nav-menu a:hover{ transform:var(--lift); box-shadow:0 10px 30px rgba(73,194,255,.25) }
.btn:active, .cta:active, .nav-menu a:active{ transform:translateY(0) scale(.98); box-shadow:0 6px 20px rgba(73,194,255,.18) }
.btn:focus-visible, .cta:focus-visible, .nav-menu a:focus-visible{
  outline:none; box-shadow:0 0 0 2px rgba(73,194,255,.5), 0 8px 30px rgba(73,194,255,.22); border-radius:12px
}
@media (prefers-reduced-motion:reduce){
  .btn, .cta, .nav-menu a{ transition:none }
  .btn:hover, .cta:hover, .nav-menu a:hover{ transform:none; box-shadow:none }
}

/* ===== Hero ===== */
.hero{padding: clamp(36px,8vw,90px) 0 56px; position:relative}
.hero .container{display:grid; grid-template-columns:1.15fr .85fr; gap: clamp(20px,4vw,44px); align-items:center}
.hero-copy .sub{color:var(--muted)}
.hero-copy .lead{max-width:62ch}
.hero-ctas{display:flex; gap:12px; margin-top:12px}
.btn{display:inline-block; padding:12px 16px; border-radius:12px; border:1px solid rgba(156,220,255,.22); font-weight:800}
.btn.primary{background:linear-gradient(90deg,var(--brand),var(--accent)); color:#00101a}
.btn.ghost{color:var(--brand); background:rgba(76,195,255,.06)}



@keyframes drift{to{transform: perspective(800px) rotateX(60deg) translateY(28%)}}

/* ===== Sections ===== */
.section{padding: clamp(42px,7vw,96px) 0}

.section-header{max-width:860px; margin:0 auto 22px; text-align:center}
.muted{color:var(--muted)} .small{font-size:.9rem}

/* ===== Cards ===== */
.cards{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap:18px; margin-top:20px;
  padding-inline: clamp(16px,4vw,32px);
  max-width:1000px; /* ensures no more than ~3 cards per row */
}
.card{
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border:1px solid rgba(156,220,255,.16); border-radius:var(--radius); padding:18px;
  position:relative; overflow:hidden
}
.card::after{content:""; position:absolute; inset:-2px; border-radius:inherit; background: radial-gradient(240px 120px at var(--mx,50%) -10%, rgba(0,236,255,.35), transparent 60%); opacity:0; transition:opacity .25s}
.card:hover::after{opacity:.8}

/* Flip-card set (no layout shift) */
.cards{ align-items:stretch }
.cards .card{
  position:relative; min-height:200px; height:220px;
  overflow:visible; background: transparent; border:none;
  perspective: 900px; isolation:isolate;
}
.card-shell{
  position:absolute; inset:0; border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border:1px solid rgba(156,220,255,.16);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04), 0 10px 40px rgba(0,0,0,.28);
  overflow:hidden;
}
.card-shell::before{
  content:""; position:absolute; inset:-1px; border-radius:inherit;
  background: conic-gradient(from 0deg, rgba(0,236,255,.0) 0 20%, rgba(0,236,255,.35) 25%, rgba(0,236,255,.0) 30% 100%);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  padding:1px; animation: scan 4s linear infinite; opacity:.6;
}
@keyframes scan{ to{ transform: rotate(360deg) } }

.card-inner{ position:absolute; inset:0; transform-style: preserve-3d; transition: transform .6s cubic-bezier(.2,.7,.2,1) }
.card:hover .card-inner, .card:focus-within .card-inner, .card.open .card-inner{ transform: rotateY(180deg) }
.face{ position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; padding:18px; backface-visibility:hidden }
.face.front{ gap:.6rem }
.face.front h3{ margin:0 }
.face.front .hint{ color:var(--muted); font-size:.85rem }
.face.back{ transform: rotateY(180deg); text-align:left; gap:.6rem }
.face.back h3{ margin:0 0 .2rem 0 }
.face.back p{ margin:.2rem 0 0 0 }

.card-glow{
  pointer-events:none; position:absolute; inset:-15%; border-radius:inherit; 
  background: radial-gradient(180px 120px at var(--mx,50%) var(--my,30%), rgba(0,236,255,.22), transparent 60%);
  mix-blend-mode: screen; opacity:.65; transition: opacity .2s;
}
.card:hover .card-glow{ opacity:.9 }
.card:focus-within .card-shell{ box-shadow: var(--ring) }

/* ===== Hero art / HeyGen slot ===== */
.hero-art img{ background: transparent !important }
.hero-art img.pulsate { animation: pulseScale 6s ease-in-out infinite; transform-origin: 50% 50%; will-change: transform }
@keyframes pulseScale { 0%,100% { transform: scale(1.00) } 50% { transform: scale(1.03) } }
.hero-art img.pulsate-strong { animation: pulseStrong 3s ease-in-out infinite; filter: drop-shadow(0 0 22px rgba(73,194,255,.25)) }
@keyframes pulseStrong { 0%,100% { transform: scale(1.00) } 50% { transform: scale(1.08) } }

.heygen-slot{
  position: relative; width: 100%; aspect-ratio: 1 / 1; border-radius: 16px; overflow: hidden;
  border: 1px solid rgba(156,220,255,.16);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04), 0 10px 40px rgba(0,0,0,.28);
  background: transparent !important;
}
.heygen-slot iframe { width:100%; height:100%; border:0; display:block }

/* ===== Stats & Needs ===== */
.stats{
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 18px; margin: 20px 0; padding-inline: clamp(16px, 4vw, 32px);
}
.stat{background:rgba(12,18,31,.6); border:1px solid rgba(156,220,255,.16); border-radius:var(--radius); padding:18px; text-align:center; position:relative; overflow:hidden}
.stat::before{content:""; position:absolute; inset:0; background: radial-gradient(220px 120px at 50% -20%, rgba(0,236,255,.22), transparent 60%); opacity:.6}
.stat-num{font-weight:900; font-size:2.2rem; text-shadow:0 0 22px rgba(73,194,255,.25)}
.stat-unit{font-weight:800; margin-left:4px}

.need-grid{
  display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 18px; margin: 0 auto; padding-inline: clamp(16px, 4vw, 32px);
  max-width: 1000px; justify-content: center; text-align: center;
}
.need{background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02)); border:1px solid rgba(156,220,255,.16); border-radius:var(--radius); padding:18px}

/* ===== Case Study ===== */
.section.case-study .container { max-width: 1100px; margin: 0 auto; padding: min(6vw, 48px) 20px }
.section.case-study h2 { margin-bottom: 12px }
.section.case-study p { margin-bottom: 24px; opacity: .9 }

.chart-wrap { position: relative; width: 100%; height: 420px }
@media (min-width: 900px) { .chart-wrap { height: 520px } }
@media (min-width: 1100px){ .chart-wrap{ height: 560px } }

.cs-header { text-align: center; margin-bottom: 22px }
.cs-header .sub { color: var(--muted); margin-top: 4px; font-size: 1.05rem }

.cs-cards{
  display:grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap:18px; margin-top: 22px;
}
.cs-card{
  position:relative; padding:18px; border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border:1px solid rgba(156,220,255,.16);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04), 0 10px 40px rgba(0,0,0,.28);
  overflow:hidden; min-height: 140px;
  transition: transform .2s ease, box-shadow .2s ease;
}
.cs-card:hover{ transform: translateY(-2px); box-shadow: 0 16px 50px rgba(0,0,0,.35) }
.cs-card::after{
  content:""; position:absolute; inset:-2px; border-radius:inherit;
  background: radial-gradient(220px 120px at var(--mx,50%) -10%, rgba(0,236,255,.25), transparent 60%);
  opacity:0; transition: opacity .25s;
}
.cs-card:hover::after{ opacity:.7 }
.cs-card-title{
  margin:0 0 .4rem 0;
  font-size: clamp(1.0rem, 0.7vw + .9rem, 1.15rem);
  font-family: Orbitron, Inter, sans-serif;
  letter-spacing:.04em;
}

/* ===== About ===== */
.about-grid{display:grid; grid-template-columns:repeat(auto-fit, minmax(300px,1fr)); gap:18px; padding-inline:clamp(16px,4vw,32px)}
.about-card{background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02)); border:1px solid rgba(156,220,255,.16); border-radius:var(--radius); padding:18px}

/* ===== Wordmark ===== */
.wordmark{display:none}
.wordmark img{width:min(640px,90%); height:auto; filter:drop-shadow(0 8px 26px rgba(73,194,255,.28))}

/* ===== Contact ===== */
.contact{max-width:900px; margin:0 auto; padding-inline:clamp(16px,4vw,32px)}
.contact .grid{display:grid; grid-template-columns:repeat(2,1fr); gap:12px}
.contact label{display:flex; flex-direction:column; gap:6px}
input,textarea{background:#0b1429; border:1px solid rgba(156,220,255,.18); color:var(--text); border-radius:12px; padding:12px; font:inherit}
input:focus,textarea:focus{outline:none; box-shadow:var(--ring); border-color:rgba(156,220,255,.36)}

/* ===== Footer ===== */
.site-footer{padding:28px 0; text-align:center; color:var(--muted)}

/* ===== Reveal on scroll ===== */
.reveal{opacity:0; transform:translateY(12px)}
.reveal.in{opacity:1; transform:none; transition:opacity .7s ease, transform .7s ease}

/* ===== Responsive tweaks ===== */
@media (max-width: 980px){
  .hero .container, .case{grid-template-columns:1fr}
  .contact .grid{grid-template-columns:1fr}
}

/* Keep header a positioned anchor */
.nav { position: sticky; top: 0; z-index: 1000; }
.nav .container { position: relative; display: flex; align-items: center; min-height: 56px; }

/* Brand locked top-left */
.brand { position: relative; left: 0; }

/* Hamburger locked top-right (mobile only) */
#navToggle { display: none; } /* hidden on desktop */

@media (max-width:1200px){
  /* Hide desktop CTA in mobile header; we’ll show CTA in the panel if you added it in the UL */
  .desktop-cta { display: none !important; }

  #navToggle{
    display: block;
    position: absolute;
    right: var(--edge);            /* <-- top-right */
    top: 50%;
    transform: translateY(-50%);
    font-size: 1.3rem;
    background: none;
    border: 0;
    color: va
/* Base: menu hidden on mobile */
@media (max-width:1200px){
  #navMenu{ display:none !important; }
  /* Show only when the header container has .nav-open */
  .nav .container.nav-open #navMenu{
    display:grid !important;
    position:absolute;
    right:var(--edge);
    top:calc(100% + 8px);
    width:min(86vw, 360px);
    gap:12px; list-style:none; margin:0; padding:14px 16px;
    background:rgba(7,13,25,.85);
    border:1px solid rgba(156,220,255,.16);
    border-radius:12px;
    box-shadow:0 18px 60px rgba(0,0,0,.45);
    z-index:1000;
  }

  /* Keep the hamburger always clickable */
  #navToggle{
    position:absolute;
    right:var(--edge);
    top:50%;
    transform:translateY(-50%);
    z-index:1001;
  }
}
:root{
  /* add this once near your other vars */
  --nav-h: 64px; /* adjust if your bar is taller/shorter */
}

/* make the bar fixed and full-width */
.nav{
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  backdrop-filter: blur(10px);
  background: linear-gradient(180deg, rgba(7,13,25,.92), rgba(7,13,25,.55) 70%, transparent);
}

/* ensure the container defines the bar height */
.nav .container{
  min-height: var(--nav-h);
  position: relative;            /* keeps the dropdown anchored under the hamburger */
}

/* give the page room so content doesn't hide under the fixed bar */
body{
  padding-top: var(--nav-h);
}
.nav .container.nav-open #navMenu{
  position: absolute;
  top: calc(100% + 8px);
  right: var(--edge);
  /* ... */
}
/* desktop/base (you likely already have 3 columns somewhere) */
.stats{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

/* tablet: two columns */
@media (max-width: 900px){
  .stats{
    grid-template-columns: repeat(2, 1fr);
  }
}

/* mobile: one column per row */
@media (max-width: 600px){
  .stats{
    grid-template-columns: 1fr;
  }
}


/* ===== FINAL Impact layout overrides (target the exact node) ===== */

/* Desktop: one centered row of three */
section#impact .container.stats {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(260px, 1fr)) !important;
  gap: 18px !important;
  max-width: 1050px !important;
  margin: 20px auto !important;      /* centers the whole grid */
  justify-items: center !important;
}

section#impact .container.stats .stat {
  width: 100% !important;
  max-width: 320px !important;        /* consistent tile width */
}

/* Tablet: two columns */
@media (max-width: 1024px){
  section#impact .container.stats {
    grid-template-columns: repeat(2, minmax(260px, 1fr)) !important;
  }
}

/* Phone: one per row */
@media (max-width: 640px){
  section#impact .container.stats {
    grid-template-columns: 1fr !important;
    max-width: 580px !important;      /* optional: keeps tiles from stretching too wide */
  }
}

.grid-bg { display: none !important; }
/* Kill any background bands/lines across sections */
.grid-bg { display: none !important; }          /* hides the grid overlay entirely */
.section.alt { background: none !important; }   /* removes the top gradient strip */

/* Optional: make sure no stray borders show as lines */
.section { border: 0 !important; }
.container, .cards, .case-study .container { background: transparent !important; }

/* Remove the dark vignette overlay that creates horizontal bands */
.vignette { display: none !important; }

/* Remove the faint section divider lines */
.section.alt {
  background: none !important;
}

.section {
  background: none !important;
}


