/* ============================================================
   DevHive Studio — Homepage "AURORA CONTROL" (dark concept)
   - Hero + Stage visuals preserved (animation now self-runs)
   - "How we work" journey preserved (re-themed dark)
   - Everything else recreated: bento capabilities, impact band,
     engineering principles, testimonial stream, dark FAQ, CTA.
   Scoped to .home so other pages stay untouched.
   ============================================================ */

/* ---------- home-scoped tokens ---------- */
.home{
  --bg:#0b1422;
  --bg2:#0e1a2c;
  --panel:rgba(255,255,255,.038);
  --panel2:rgba(255,255,255,.06);
  --line2:rgba(255,255,255,.09);
  --line3:rgba(255,255,255,.14);
  --txt:#9fb2c6;
  --txt-dim:#728aa1;
  --vio:#7b6cff;
  --mono:"JetBrains Mono",ui-monospace,monospace;
}

/* ============================================================
   ATMOSPHERE — full-page dark background, aurora + grid
   ============================================================ */
body.home{background:var(--bg);color:var(--txt)}
.home main{position:relative;z-index:1}
.home::before,.home::after{content:"";position:fixed;inset:0;pointer-events:none;z-index:0}
.home::before{
  background:
    radial-gradient(900px 620px at 12% -8%,rgba(0,189,195,.18),transparent 60%),
    radial-gradient(820px 600px at 92% 6%,rgba(123,108,255,.17),transparent 60%),
    radial-gradient(1000px 760px at 50% 118%,rgba(2,119,212,.16),transparent 60%),
    linear-gradient(180deg,#0d1828,#0a1322 45%,#0b1525 100%);
  animation:auroraDrift 26s ease-in-out infinite alternate;
}
.home::after{
  background-image:
    linear-gradient(rgba(122,170,200,.045) 1px,transparent 1px),
    linear-gradient(90deg,rgba(122,170,200,.045) 1px,transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(ellipse 75% 60% at 50% 30%,#000,transparent 85%);
          mask-image:radial-gradient(ellipse 75% 60% at 50% 30%,#000,transparent 85%);
  opacity:.5;
}
@keyframes auroraDrift{0%{transform:translate3d(0,0,0) scale(1)}100%{transform:translate3d(0,-22px,0) scale(1.04)}}
@media(prefers-reduced-motion:reduce){.home::before{animation:none}}

/* ---------- shared-class overrides for dark ---------- */
.home .section{padding:108px 0;position:relative;z-index:1}
.home .section.tight{padding:74px 0}
.home .bg-mist,.home .bg-navy{background:transparent;color:var(--txt)}
.home h1,.home h2,.home h3,.home h4{color:#f3f8fc}
.home .title{color:#fff}
.home .lead{color:var(--txt)}
.home .center{text-align:center}
.home .eyebrow{display:inline-flex;align-items:center;gap:10px;font:700 12px/1 var(--mono);letter-spacing:.22em;text-transform:uppercase;color:#7ff0e6;margin-bottom:18px}
.home .eyebrow::before{content:"";width:22px;height:2px;border-radius:2px;background:linear-gradient(90deg,var(--teal),var(--vio))}
.home .sec-head{max-width:760px;margin:0 auto}
.home .btn-ghost{background:transparent;color:#fff;border:1.5px solid var(--line3)}
.home .btn-ghost:hover{border-color:var(--teal);color:var(--teal);transform:translateY(-3px)}
.home .checks li{color:#cfe0ea}
.home .checks .ck{background:rgba(0,189,195,.14);color:#5ff0df;border:1px solid rgba(0,189,195,.3)}

/* header stays dark-glass on this page */
/* header flips to a crisp light glass the moment you scroll */
.home .site-header.scrolled{background:rgba(8,14,24,.94);backdrop-filter:blur(14px);box-shadow:0 8px 30px rgba(0,0,0,.4);border-bottom:1px solid rgba(255,255,255,.06)}
.home .site-header.scrolled .nav .nav-links>li>a{color:#e7f1f8}
.home .site-header.scrolled .nav-links>li>a:hover,.home .site-header.scrolled .nav-links>li>a.active{color:var(--teal)}
.home .site-header.scrolled .brand .wordmark b{color:#fff}
.home .site-header.scrolled .brand .wordmark span{color:var(--sky)}
.home .site-header.scrolled .burger span{background:#fff}

/* ============================================================
   HERO  (kept) — entrance is pure-CSS, self-runs on load
   ============================================================ */
.hero-v2{text-align:center;background-color:transparent !important;
  background-image:
    radial-gradient(1200px 760px at 50% -12%,rgba(3,170,225,.22),transparent 60%),
    radial-gradient(900px 700px at 12% 110%,rgba(0,189,195,.16),transparent 55%),
    radial-gradient(900px 700px at 88% 120%,rgba(106,92,255,.16),transparent 55%) !important;}
.hero-v2::before{background:radial-gradient(ellipse 60% 42% at 50% -6%,rgba(255,255,255,.05),transparent 70%) !important}
.hero-v2 .hero-pad{padding:188px 0 70px}
.hero-top{max-width:840px;margin:0 auto}
.hero-v2 .hero-badge{margin:0 auto 26px}
.hero-v2 h1{font-size:clamp(38px,6vw,74px);letter-spacing:-.03em;line-height:1.02;color:#fff}
.hero-v2 .flawless-word{background:linear-gradient(110deg,#7ff0e6,#03aae1 50%,#9b8bff);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-v2 p.lead{color:#a7c2d4;max-width:650px;margin:24px auto 0;font-size:clamp(16.5px,2vw,20px)}
.hero-v2 .hero-cta{justify-content:center;margin-top:36px}
.hero-v2 .btn-ghost{color:#fff;border-color:rgba(255,255,255,.26)}
.hero-v2 .btn-ghost:hover{border-color:var(--teal);color:var(--teal)}
.hero-proof{display:flex;justify-content:center;align-items:center;gap:10px;flex-wrap:wrap;margin-top:30px;color:#8db0c6;font-size:13.5px;font-weight:600}
.hero-proof .stars{color:#ffc24b;letter-spacing:2px;font-size:14px}
.hero-proof .av-row{display:flex}
.hero-proof .av-row img{width:30px;height:30px;border-radius:50%;object-fit:cover;border:2px solid #0a1c2c;margin-left:-9px;background:#0a1c2c}
.hero-proof .av-row img:first-child{margin-left:0}

/* SELF-RUNNING entrance — guaranteed on load, not gated by observer */
.hero-rise{opacity:0;transform:translateY(34px);animation:heroRise .9s var(--ease) forwards}
.hero-rise.d1{animation-delay:.10s}.hero-rise.d2{animation-delay:.22s}.hero-rise.d3{animation-delay:.34s}
.hero-rise.d4{animation-delay:.46s}.hero-rise.d5{animation-delay:.58s}
@keyframes heroRise{to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){.hero-rise{animation:none;opacity:1;transform:none}}

/* ---------- STAGE (preserved) ---------- */
.stage{position:relative;width:100%;max-width:1000px;margin:48px auto 0;height:640px;display:flex;align-items:center;justify-content:center}
.stage-glow{position:absolute;width:680px;height:680px;border-radius:50%;z-index:0;pointer-events:none;background:radial-gradient(circle,rgba(3,170,225,.16),rgba(123,108,255,.1) 45%,transparent 70%);animation:stageGlow 7s ease-in-out infinite}
@keyframes stageGlow{0%,100%{opacity:.7;transform:scale(.96)}50%{opacity:1;transform:scale(1.05)}}
/* device sits centred directly in the stage now */
.stage>.device{position:relative;z-index:3}
.stage .blob{position:absolute;border-radius:50%;filter:blur(70px);pointer-events:none;z-index:0}
.stage .blob.b1{width:360px;height:360px;background:radial-gradient(circle,rgba(0,189,195,.45),transparent 70%);left:8%;top:18%;animation:floatBlob 13s ease-in-out infinite}
.stage .blob.b2{width:380px;height:380px;background:radial-gradient(circle,rgba(2,119,212,.42),transparent 70%);right:6%;top:26%;animation:floatBlob 16s ease-in-out infinite reverse}
.stage .blob.b3{width:300px;height:300px;background:radial-gradient(circle,rgba(124,77,255,.34),transparent 70%);left:40%;bottom:2%;animation:floatBlob 18s ease-in-out infinite}
@keyframes floatBlob{0%,100%{transform:translate(0,0)}50%{transform:translate(26px,-22px)}}
.ring-sys{position:absolute;width:620px;height:620px;z-index:1;display:grid;place-items:center;filter:drop-shadow(0 0 14px rgba(3,170,225,.28))}
.ring-sys svg{width:100%;height:100%;overflow:visible}
.ring-rot{transform-box:fill-box;transform-origin:center;animation:ringSpin 60s linear infinite}
@keyframes ringSpin{to{transform:rotate(360deg)}}
.ring-rot-r{transform-box:fill-box;transform-origin:center;animation:ringSpin 90s linear infinite reverse}
.comet{transform-box:fill-box;transform-origin:center;animation:ringSpin 9s linear infinite}
.ring-faint{stroke:rgba(133,205,235,.16);fill:none}
.ring-tick{fill:rgba(150,215,240,.5)}
.stage .dot{position:absolute;border-radius:50%;z-index:4}
.stage .dot::after{content:"";position:absolute;inset:-9px;border-radius:50%;opacity:.5;filter:blur(7px);background:inherit}
.stage .dot.d1{width:18px;height:18px;background:#00e0c6;left:16%;top:24%;animation:bob 6s ease-in-out infinite}
.stage .dot.d2{width:14px;height:14px;background:#6a5cff;right:14%;top:36%;animation:bob 7.5s ease-in-out infinite}
.stage .dot.d3{width:12px;height:12px;background:#03aae1;right:24%;bottom:20%;animation:bob 6.8s ease-in-out infinite reverse}
.stage .dot.d4{width:10px;height:10px;background:#ff5da2;left:23%;bottom:24%;animation:bob 8s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-16px)}}
.device{position:relative;z-index:3;width:440px;max-width:88vw;background:linear-gradient(180deg,#0c2030,#081726);border:1px solid rgba(120,200,235,.16);border-radius:20px;box-shadow:0 50px 120px rgba(0,10,25,.7),0 0 0 1px rgba(255,255,255,.02) inset,0 0 70px rgba(3,170,225,.14);overflow:hidden;animation:deviceFloat 8s ease-in-out infinite;backdrop-filter:blur(4px)}
@keyframes deviceFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
.dev-bar{display:flex;align-items:center;gap:8px;padding:13px 16px;border-bottom:1px solid rgba(255,255,255,.06)}
.dev-bar .tl{display:flex;gap:7px}
.dev-bar .tl i{width:11px;height:11px;border-radius:50%;display:block}
.dev-bar .tl i:nth-child(1){background:#ff5f57}.dev-bar .tl i:nth-child(2){background:#febc2e}.dev-bar .tl i:nth-child(3){background:#28c840}
.dev-bar .url{margin-left:8px;flex:1;display:flex;align-items:center;gap:7px;justify-content:center;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.06);border-radius:8px;padding:6px 12px;color:#7fa6bd;font-family:var(--mono);font-size:11.5px}
.dev-bar .url svg{width:12px;height:12px;color:#46c08f}
.dev-body{padding:18px}
.dev-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.dev-head h5{font-family:var(--display);color:#fff;font-size:16px;font-weight:700;letter-spacing:-.01em}
.dev-live{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:11px;font-weight:600;color:#46c08f;background:rgba(40,200,100,.12);border:1px solid rgba(40,200,100,.22);padding:4px 10px;border-radius:20px}
.dev-live i{width:7px;height:7px;border-radius:50%;background:#46c08f;animation:pulse 2s infinite}
.dev-chart{display:flex;align-items:flex-end;gap:7px;height:64px;padding:8px 2px 12px;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:12px}
.dev-chart b{flex:1;height:100%;border-radius:5px 5px 2px 2px;background:linear-gradient(180deg,var(--teal),var(--blue));transform-origin:bottom;transform:scaleY(.2);opacity:.9;animation:barGrowLoop 3.2s ease-in-out infinite}
.dev-chart b:nth-child(1){animation-delay:0s}.dev-chart b:nth-child(2){animation-delay:.18s}.dev-chart b:nth-child(3){animation-delay:.36s}.dev-chart b:nth-child(4){animation-delay:.54s}.dev-chart b:nth-child(5){animation-delay:.72s}.dev-chart b:nth-child(6){animation-delay:.9s}.dev-chart b:nth-child(7){animation-delay:1.08s}.dev-chart b:nth-child(8){animation-delay:1.26s}
@keyframes barGrowLoop{0%,100%{transform:scaleY(.2)}50%{transform:scaleY(1)}}
.dev-row{display:flex;align-items:center;gap:11px;padding:10px 11px;border-radius:11px;margin-bottom:7px;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.05);position:relative;overflow:hidden}
.dev-row .rd{width:9px;height:9px;border-radius:50%;flex:none}
.dev-row .rd.ok{background:#46c08f;box-shadow:0 0 10px rgba(70,192,143,.7)}
.dev-row .rd.run{background:#ffb43d;box-shadow:0 0 10px rgba(255,180,61,.7)}
.dev-row .rn{flex:1;min-width:0}
.dev-row .rn b{display:block;color:#e6f1f9;font-family:var(--body);font-weight:700;font-size:13px;line-height:1.2}
.dev-row .rn span{display:block;color:#7fa0b6;font-size:11px;font-family:var(--mono)}
.dev-row .rt{font-family:var(--mono);font-size:11px;font-weight:600;flex:none}
.dev-row .rt.ok{color:#46c08f}.dev-row .rt.run{color:#ffb43d}
.dev-row.lit{animation:rowLit 6s ease-in-out infinite}
.dev-row.lit.l1{animation-delay:0s}.dev-row.lit.l2{animation-delay:1.5s}.dev-row.lit.l3{animation-delay:3s}.dev-row.lit.l4{animation-delay:4.5s}
@keyframes rowLit{0%,82%,100%{background:rgba(255,255,255,.02);border-color:rgba(255,255,255,.05)}10%,72%{background:rgba(3,170,225,.1);border-color:rgba(3,170,225,.3)}}
.dev-row .prog{position:absolute;left:0;bottom:0;height:2px;background:linear-gradient(90deg,var(--teal),var(--sky));border-radius:2px;width:30%;animation:progLoop 4s ease-in-out infinite}
@keyframes progLoop{0%{width:12%}70%{width:92%}100%{width:12%}}
.dev-foot{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:12px}
.dev-foot div{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05);border-radius:10px;padding:10px 12px}
.dev-foot b{display:block;font-family:var(--display);color:#fff;font-size:18px;line-height:1}
.dev-foot small{color:#7fa0b6;font-size:10.5px;font-family:var(--mono);letter-spacing:.02em}
.float-card{position:absolute;z-index:5;background:rgba(11,28,42,.86);border:1px solid rgba(133,205,235,.18);border-radius:14px;box-shadow:0 24px 60px rgba(0,8,20,.55);backdrop-filter:blur(12px);padding:13px 15px;color:#fff}
.fc-deploy{left:-2%;top:14%;display:flex;align-items:center;gap:11px;animation:cardFloat 7s ease-in-out infinite}
.fc-deploy .ico{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;background:rgba(40,200,100,.16);color:#46c08f;flex:none}
.fc-deploy .ico svg{width:18px;height:18px}
.fc-deploy b{display:block;font-family:var(--body);font-size:13px;font-weight:700}
.fc-deploy span{display:block;font-size:11px;color:#8aa9bf;font-family:var(--mono)}
.fc-review{left:1%;bottom:9%;display:flex;align-items:center;gap:11px;animation:cardFloat 8.5s ease-in-out infinite reverse}
.fc-review img{width:38px;height:38px;border-radius:50%;object-fit:cover;flex:none}
.fc-review .stars{color:#ffc24b;font-size:11px;letter-spacing:1px;line-height:1}
.fc-review b{display:block;font-family:var(--body);font-size:12.5px;font-weight:700;margin-top:2px}
.fc-review span{display:block;font-size:10.5px;color:#8aa9bf}
.fc-clients{right:-1%;top:30%;animation:cardFloat 7.8s ease-in-out infinite}
.fc-clients .row{display:flex;align-items:center}
.fc-clients .row img{width:26px;height:26px;border-radius:50%;object-fit:cover;border:2px solid #0b1c2a;margin-left:-8px}
.fc-clients .row img:first-child{margin-left:0}
.fc-clients .meta{margin-top:8px}
.fc-clients .meta b{font-family:var(--display);font-size:16px;color:#fff;line-height:1}
.fc-clients .meta span{display:block;font-size:10.5px;color:#8aa9bf;font-family:var(--mono)}
.fc-ai{right:3%;bottom:16%;display:flex;align-items:center;gap:10px;animation:cardFloat 9s ease-in-out infinite}
.fc-ai .ico{width:32px;height:32px;border-radius:9px;display:grid;place-items:center;background:rgba(124,77,255,.18);color:#b9aaff;flex:none}
.fc-ai .ico svg{width:17px;height:17px}
.fc-ai b{font-family:var(--body);font-size:12.5px;font-weight:700;display:block}
.fc-ai span{font-size:10.5px;color:#8aa9bf;font-family:var(--mono)}
@keyframes cardFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-15px)}}
.scroll-cue{display:flex;flex-direction:column;align-items:center;gap:7px;margin-top:54px;color:#5f7e93;font-size:11.5px;font-family:var(--mono);letter-spacing:.16em;text-transform:uppercase}
.scroll-cue .mouse{width:24px;height:38px;border:1.6px solid rgba(150,200,225,.4);border-radius:14px;position:relative}
.scroll-cue .mouse::after{content:"";position:absolute;left:50%;top:7px;width:3px;height:7px;border-radius:3px;background:var(--teal);transform:translateX(-50%);animation:wheel 1.8s ease-in-out infinite}
@keyframes wheel{0%{opacity:0;top:7px}30%{opacity:1}70%{opacity:1}100%{opacity:0;top:17px}}
.scenes{position:absolute;inset:0;z-index:2}
.scene{position:absolute;inset:0;opacity:0;visibility:hidden;transition:opacity .55s var(--ease),visibility .55s;pointer-events:none;will-change:opacity;transform:translateZ(0);backface-visibility:hidden}
/* hidden scenes stop all inner motion so the cross-fade stays smooth (no lag) */
.scene:not(.on) *{animation-play-state:paused!important}
.scene.on{opacity:1;visibility:visible;pointer-events:auto}
.scene .device{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%)}
.scene.on .device{animation:deviceFloatC 8s ease-in-out infinite}
@keyframes deviceFloatC{0%,100%{transform:translate(-50%,-50%)}50%{transform:translate(-50%,calc(-50% - 14px))}}
.scene .dev-row,.scene .dev-foot,.scene .dev-chart,.scene .float-card{opacity:0;transform:translateY(12px);transition:opacity .5s var(--ease),transform .5s var(--ease)}
.scene.on .dev-chart{opacity:1;transform:none;transition-delay:.15s}
.scene.on .dev-row.l1{opacity:1;transform:none;transition-delay:.34s}
.scene.on .dev-row.l2{opacity:1;transform:none;transition-delay:.5s}
.scene.on .dev-row.l3{opacity:1;transform:none;transition-delay:.66s}
.scene.on .dev-row.l4{opacity:1;transform:none;transition-delay:.82s}
.scene.on .dev-foot{opacity:1;transform:none;transition-delay:1s}
.scene.on .float-card{opacity:1;transform:none}
.scene.on .fc-deploy{transition-delay:1.15s}.scene.on .fc-ai{transition-delay:1.32s}
.scene.on .fc-clients{transition-delay:1.48s}.scene.on .fc-review{transition-delay:1.62s}
.scene-dots{position:absolute;left:50%;bottom:-6px;transform:translateX(-50%);z-index:6;display:flex;gap:10px}
.scene-dots button{width:9px;height:9px;border-radius:50%;border:1px solid rgba(255,255,255,.5);background:transparent;cursor:pointer;transition:all .3s;padding:0}
.scene-dots button.on{background:var(--teal);border-color:var(--teal);width:24px;border-radius:6px}
.cy-radar{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:380px;height:380px;max-width:86vw;display:grid;place-items:center}
.cy-grid{position:absolute;inset:0;width:100%;height:100%}
.cy-grid circle,.cy-grid line{fill:none;stroke:rgba(0,224,198,.22);stroke-width:1}
.cy-pulse{position:absolute;width:120px;height:120px;border-radius:50%;border:1.5px solid rgba(0,224,198,.45);animation:cyPulse 3s ease-out infinite}
.cy-pulse.p2{animation-delay:1s}.cy-pulse.p3{animation-delay:2s}
@keyframes cyPulse{0%{transform:scale(.4);opacity:.9}100%{transform:scale(3.0);opacity:0}}
.cy-sweep{position:absolute;width:50%;height:50%;left:50%;top:50%;transform-origin:top left;background:conic-gradient(from 0deg,rgba(0,224,198,.42),transparent 32%);border-radius:0 0 100% 0;animation:cySweep 4s linear infinite}
@keyframes cySweep{to{transform:rotate(360deg)}}
.cy-blip{position:absolute;width:10px;height:10px;border-radius:50%;background:#7ff0e6;box-shadow:0 0 12px #7ff0e6;animation:cyBlip 4s ease-in-out infinite}
.cy-blip.b1{left:68%;top:30%}.cy-blip.b2{left:30%;top:64%;animation-delay:1.3s;background:#6a5cff;box-shadow:0 0 12px #6a5cff}.cy-blip.b3{left:60%;top:70%;animation-delay:2.4s;background:#03aae1;box-shadow:0 0 12px #03aae1}
@keyframes cyBlip{0%,100%{opacity:0;transform:scale(.5)}40%{opacity:1;transform:scale(1)}}
.cy-core{position:relative;z-index:3;width:150px;height:150px;border-radius:50%;display:grid;place-items:center;text-align:center;color:#bff7ee;background:radial-gradient(circle,rgba(0,40,52,.95),rgba(0,21,35,.92));border:1px solid rgba(0,224,198,.4);box-shadow:0 0 0 8px rgba(0,224,198,.06),0 26px 60px -16px rgba(0,0,0,.7)}
.cy-core svg{width:46px;height:46px;color:#00e0c6;filter:drop-shadow(0 0 8px rgba(0,224,198,.6));margin-bottom:6px}
.cy-core b{display:block;font-family:var(--display);font-size:17px;color:#fff;line-height:1}
.cy-core span{display:block;font:600 11px var(--mono);letter-spacing:.08em;color:#7fd9cf;margin-top:4px}
/* ===== SCENE 3 · neural inference graph ===== */
.nn-wrap{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:380px;height:340px;max-width:88vw;display:grid;place-items:center}
.nn-glow{position:absolute;width:260px;height:260px;border-radius:50%;background:radial-gradient(circle,rgba(124,108,255,.32),transparent 68%);filter:blur(8px);animation:nnGlow 5s ease-in-out infinite}
@keyframes nnGlow{0%,100%{opacity:.55;transform:scale(.95)}50%{opacity:.95;transform:scale(1.06)}}
.nn-net{position:relative;z-index:2;width:330px;height:300px;overflow:visible}
.nn-net .edge{fill:none;stroke:rgba(150,170,255,.32);stroke-width:1.4;stroke-dasharray:5 9;animation:nnFlow 2.6s linear infinite}
.nn-net .edge.e2{stroke:rgba(0,224,198,.34);animation-duration:3.1s}
.nn-net .edge.e3{stroke:rgba(2,170,225,.34);animation-duration:2.2s;animation-delay:.4s}
@keyframes nnFlow{to{stroke-dashoffset:-56}}
.nn-net .node{fill:#0a1726;stroke-width:2.2;animation:nnPulse 2.8s ease-in-out infinite}
.nn-net .node.in{stroke:#03aae1}
.nn-net .node.hid{stroke:#7c6cff}
.nn-net .node.out{stroke:#00e0c6}
.nn-net .node.h2{animation-delay:.5s}.nn-net .node.h3{animation-delay:1s}.nn-net .node.h4{animation-delay:1.4s}
@keyframes nnPulse{0%,100%{filter:drop-shadow(0 0 0 transparent)}50%{filter:drop-shadow(0 0 7px currentColor)}}
.nn-net .node.in{color:#03aae1}.nn-net .node.hid{color:#7c6cff}.nn-net .node.out{color:#00e0c6}
.nn-label{position:absolute;z-index:4;background:#fff;color:#0c1c2a;font:600 12.5px var(--body);padding:9px 14px;border-radius:14px;box-shadow:0 18px 40px -14px rgba(0,0,0,.55);white-space:nowrap;animation:nnFloat 6s ease-in-out infinite}
.nn-label.q{left:-4%;top:8%}
.nn-label.a{right:-6%;bottom:10%;background:linear-gradient(120deg,#6a5cff,#7c4dff);color:#fff;animation-delay:1.4s}
.nn-tag{position:absolute;z-index:4;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:#cfe0ea;font:700 12px var(--mono);letter-spacing:.06em;pointer-events:none}
.nn-tag b{display:block;font-family:var(--display);font-size:20px;color:#fff;letter-spacing:0}
@keyframes nnFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@media(max-width:600px){.nn-label{display:none}.nn-wrap{width:300px}}

/* ============================================================
   GLASS PANEL helper
   ============================================================ */
.glass{position:relative;background:var(--panel);border:1px solid var(--line2);border-radius:22px;backdrop-filter:blur(10px)}
.glass::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;background:linear-gradient(140deg,rgba(127,240,230,.5),transparent 40%,transparent 70%,rgba(123,108,255,.4));-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 .45s}
.glass:hover::before{opacity:1}

/* ============================================================
   1) TECH STREAM — dual marquee, grayscale->color on hover
   ============================================================ */
.tech-stream{position:relative;padding:40px 0;border-top:1px solid var(--line2);border-bottom:1px solid var(--line2)}
.tech-stream .lab{text-align:center;font:700 12px/1 var(--mono);letter-spacing:.24em;text-transform:uppercase;color:var(--txt-dim);margin-bottom:30px}
.ts-mask{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.ts-row{display:flex;align-items:center;width:max-content;animation:tsScroll 64s linear infinite;will-change:transform}
.ts-row.r2{animation-duration:78s;animation-direction:reverse;margin-top:34px}
/* per-item trailing margin (NOT gap) so both halves are exactly equal -> seamless -50% loop, no jump/restart */
.ts-chip{flex:none;display:grid;place-items:center;margin-right:62px;transition:transform .35s var(--ease)}
.ts-chip:hover{transform:translateY(-6px) scale(1.06)}
.ts-chip img{height:42px;width:auto;max-width:64px;object-fit:contain;display:block;pointer-events:none;filter:drop-shadow(0 4px 14px rgba(0,0,0,.45))}
.ts-chip.ts-svg svg{height:42px;width:42px;display:block;filter:drop-shadow(0 4px 14px rgba(0,0,0,.45))}
@keyframes tsScroll{to{transform:translateX(-50%)}}
@media(max-width:600px){.ts-chip img,.ts-chip.ts-svg svg{height:34px;width:34px}.ts-chip{margin-right:44px}}

/* ============================================================
   2) IMPACT BAND — animated counters
   ============================================================ */
.impact-panel{display:grid;grid-template-columns:repeat(4,1fr);overflow:hidden;border-radius:24px;border:1px solid var(--line2);background:var(--panel)}
.imp{position:relative;padding:46px 30px;text-align:left}
.imp + .imp{border-left:1px solid var(--line2)}
.imp .imp-ic{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;margin-bottom:18px;background:linear-gradient(140deg,rgba(0,189,195,.2),rgba(123,108,255,.16));color:#7ff0e6;border:1px solid rgba(0,189,195,.25)}
.imp .imp-ic svg{width:20px;height:20px}
.imp .imp-n{font-family:var(--display);font-weight:800;font-size:clamp(38px,4.6vw,56px);line-height:1;background:linear-gradient(120deg,#9ff7ee,#03aae1 55%,#9b8bff);-webkit-background-clip:text;background-clip:text;color:transparent}
.imp .imp-l{margin-top:10px;color:#dbe8f2;font-size:14.5px;font-weight:600}
.imp .imp-s{margin-top:4px;color:var(--txt-dim);font:600 11.5px var(--mono);letter-spacing:.05em}
.imp::after{content:"";position:absolute;left:30px;bottom:26px;height:3px;width:0;border-radius:3px;background:linear-gradient(90deg,var(--teal),var(--vio));transition:width .9s var(--ease) .25s;box-shadow:0 0 12px rgba(0,189,195,.5)}
.imp.in::after{width:40px}
@media(max-width:820px){.impact-panel{grid-template-columns:1fr 1fr}.imp:nth-child(3),.imp:nth-child(4){border-top:1px solid var(--line2)}.imp:nth-child(3){border-left:none}}
@media(max-width:480px){.impact-panel{grid-template-columns:1fr}.imp + .imp{border-left:none;border-top:1px solid var(--line2)}}

/* ============================================================
   3) CAPABILITIES — BENTO grid w/ cursor spotlight
   ============================================================ */
.bento{display:grid;grid-template-columns:repeat(6,1fr);gap:18px;margin-top:54px;grid-auto-rows:minmax(168px,auto)}
.bento .tile{position:relative;overflow:hidden;border-radius:20px;padding:26px;background:var(--panel);border:1px solid var(--line2);text-decoration:none;display:flex;flex-direction:column;justify-content:space-between;transition:transform .45s var(--ease),border-color .45s,background .45s}
.bento .tile::before{content:"";position:absolute;inset:0;opacity:0;transition:opacity .4s;pointer-events:none;background:radial-gradient(360px circle at var(--mx,50%) var(--my,50%),rgba(0,189,195,.16),transparent 60%)}
.bento .tile:hover{transform:translateY(-5px);border-color:rgba(0,189,195,.42);background:rgba(255,255,255,.06)}
.bento .tile:hover::before{opacity:1}
.bento .tile .ti{width:48px;height:48px;border-radius:13px;display:grid;place-items:center;background:linear-gradient(140deg,rgba(0,189,195,.18),rgba(123,108,255,.16));color:#7ff0e6;border:1px solid rgba(127,240,230,.22);position:relative;z-index:1}
.bento .tile .ti svg{width:24px;height:24px}
.bento .tile h3{color:#fff;font-size:18px;margin:18px 0 7px;font-family:var(--display);position:relative;z-index:1}
.bento .tile p{color:var(--txt);font-size:14px;line-height:1.55;margin:0;position:relative;z-index:1}
.bento .tile .go{margin-top:16px;display:inline-flex;align-items:center;gap:7px;color:#7ff0e6;font-weight:700;font-size:13.5px;position:relative;z-index:1;opacity:0;transform:translateX(-6px);transition:opacity .35s,transform .35s}
.bento .tile:hover .go{opacity:1;transform:none}
.bento .tile .go svg{width:16px;height:16px}
.bento .t-feature{grid-column:span 3;grid-row:span 2;background:linear-gradient(160deg,rgba(0,189,195,.12),rgba(123,108,255,.1)),var(--panel)}
.bento .t-feature h3{font-size:clamp(22px,2.4vw,28px)}
.bento .t-feature p{font-size:15px;max-width:40ch}
.bento .t-wide{grid-column:span 3}
.bento .t-md{grid-column:span 2}
.bento .t-sm{grid-column:span 1}
.bento .t-tall{grid-column:span 2;grid-row:span 2}
.bento .more-tile{grid-column:span 1;align-items:center;justify-content:center;text-align:center;background:linear-gradient(160deg,rgba(123,108,255,.16),rgba(0,189,195,.1))}
.bento .more-tile h3{margin:10px 0 0;font-size:16px}
@media(max-width:1000px){.bento{grid-template-columns:repeat(4,1fr)}.bento .t-feature{grid-column:span 4;grid-row:span 1}.bento .t-wide{grid-column:span 4}.bento .t-md,.bento .t-tall{grid-column:span 2;grid-row:span 1}.bento .t-sm,.bento .more-tile{grid-column:span 2}}
@media(max-width:600px){.bento{grid-template-columns:1fr}.bento .tile,.bento .t-feature,.bento .t-wide,.bento .t-md,.bento .t-tall,.bento .t-sm,.bento .more-tile{grid-column:span 1;grid-row:span 1}}

/* ============================================================
   4) ENGINEERING PRINCIPLES — sticky heading + live terminal
   ============================================================ */
.principles{display:grid;grid-template-columns:.85fr 1.15fr;gap:60px;align-items:start}
.principles .p-left{position:sticky;top:120px}
.principles .p-left h2{margin-bottom:18px}
.principles .p-left p{color:var(--txt);font-size:16px;line-height:1.7;margin-bottom:26px}
.prin-list{list-style:none;display:flex;flex-direction:column;gap:14px}
.prin-list li{position:relative;padding:18px 20px 18px 22px;border-radius:16px;background:var(--panel);border:1px solid var(--line2);overflow:hidden;transition:border-color .4s,transform .4s}
.prin-list li::after{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--teal),var(--vio));transform:scaleY(0);transform-origin:top;transition:transform .45s var(--ease)}
.prin-list li:hover{transform:translateX(4px);border-color:rgba(0,189,195,.4)}
.prin-list li:hover::after{transform:scaleY(1)}
.prin-list .pk{font:700 11px var(--mono);letter-spacing:.14em;color:#7ff0e6;text-transform:uppercase}
.prin-list b{display:block;color:#fff;font-family:var(--display);font-size:16.5px;margin:5px 0 4px}
.prin-list span.tx{color:var(--txt);font-size:13.8px;line-height:1.55}
.term{border-radius:20px;overflow:hidden;border:1px solid var(--line3);background:linear-gradient(180deg,#0a1827,#06101c);box-shadow:0 50px 120px rgba(0,8,20,.6)}
.term-bar{display:flex;align-items:center;gap:8px;padding:13px 16px;border-bottom:1px solid rgba(255,255,255,.07)}
.term-bar i{width:11px;height:11px;border-radius:50%}
.term-bar i:nth-child(1){background:#ff5f57}.term-bar i:nth-child(2){background:#febc2e}.term-bar i:nth-child(3){background:#28c840}
.term-bar span{margin-left:8px;color:#6f8aa0;font:600 12px var(--mono)}
.term-body{padding:22px 22px 26px;font-family:var(--mono);font-size:13.5px;line-height:1.95;min-height:330px}
.term-body .ln{display:block;opacity:0;transform:translateY(6px);animation:termIn .5s var(--ease) forwards}
.term-body .ln:nth-child(1){animation-delay:.15s}.term-body .ln:nth-child(2){animation-delay:.55s}
.term-body .ln:nth-child(3){animation-delay:.95s}.term-body .ln:nth-child(4){animation-delay:1.45s}
.term-body .ln:nth-child(5){animation-delay:1.95s}.term-body .ln:nth-child(6){animation-delay:2.4s}
.term-body .ln:nth-child(7){animation-delay:2.95s}.term-body .ln:nth-child(8){animation-delay:3.4s}
@keyframes termIn{to{opacity:1;transform:none}}
.term-body .pr{color:#5fd3c6}.term-body .cm{color:#5f7e93}.term-body .ok{color:#46c08f}
.term-body .wh{color:#cfe0ea}.term-body .vi{color:#b9aaff}.term-body .ye{color:#ffc24b}
.term-body .cur{display:inline-block;width:9px;height:16px;background:#7ff0e6;vertical-align:-2px;animation:blink 1.1s steps(1) infinite}
@keyframes blink{50%{opacity:0}}
@media(max-width:900px){.principles{grid-template-columns:1fr;gap:38px}.principles .p-left{position:static}}

/* ============================================================
   5) HOW WE WORK — journey (KEPT, dark themed)
   ============================================================ */
.journey-sec{position:relative}
.jy-line{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:60px}
.jy-line::before{content:"";position:absolute;left:6%;right:6%;top:34px;height:3px;border-radius:3px;background:var(--line2)}
.jy-line::after{content:"";position:absolute;left:6%;top:34px;height:3px;border-radius:3px;background:linear-gradient(90deg,var(--teal),var(--blue),var(--vio));width:0;transition:width 1.6s var(--ease) .3s;box-shadow:0 0 14px rgba(0,189,195,.55)}
.jy-line.in::after{width:88%}
.jy-step{position:relative;text-align:center;padding:0 6px}
.jy-dot{width:70px;height:70px;margin:0 auto 20px;border-radius:20px;display:grid;place-items:center;position:relative;z-index:2;background:linear-gradient(180deg,#0c2032,#081623);border:1px solid var(--line3);box-shadow:0 18px 40px -16px rgba(0,0,0,.7);color:#7ff0e6;transition:transform .5s var(--ease),box-shadow .5s,border-color .5s,background .5s,color .5s}
.jy-dot svg{width:30px;height:30px}
.jy-step.in .jy-dot{animation:jyPop .6s var(--ease) backwards}
.jy-step:nth-child(2).in .jy-dot{animation-delay:.25s}
.jy-step:nth-child(3).in .jy-dot{animation-delay:.5s}
.jy-step:nth-child(4).in .jy-dot{animation-delay:.75s}
@keyframes jyPop{0%{transform:scale(.5);opacity:0}60%{transform:scale(1.12)}100%{transform:scale(1);opacity:1}}
.jy-dot:hover{background:linear-gradient(140deg,var(--teal),var(--blue));border-color:transparent;color:#fff;transform:translateY(-6px);box-shadow:0 22px 50px -16px rgba(0,189,195,.55)}
.jy-num{font:700 11px var(--mono);letter-spacing:.14em;color:#7ff0e6}
.jy-step h3{font-size:18px;margin:7px 0 6px;font-family:var(--display);color:#fff}
.jy-step p{color:var(--txt);font-size:14px;margin:0}
@media(max-width:760px){.jy-line{grid-template-columns:1fr 1fr;gap:34px 18px}.jy-line::before,.jy-line::after{display:none}}

/* ============================================================
   6) TESTIMONIALS — continuous stream
   ============================================================ */
.tstream-mask{overflow:hidden;margin-top:50px;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.tstream{display:flex;gap:22px;width:max-content;animation:tScroll 52s linear infinite;will-change:transform}
/* testimonials marquee never pauses on hover */
@keyframes tScroll{to{transform:translateX(-50%)}}
.tq{width:380px;flex:none;border-radius:20px;padding:28px;background:var(--panel);border:1px solid var(--line2);transition:border-color .4s,transform .4s}
.tq:hover{border-color:rgba(0,189,195,.4);transform:translateY(-4px)}
.tq .stars{color:#ffc24b;letter-spacing:2px;font-size:14px}
.tq p{color:#dbe8f2;font-size:15px;line-height:1.6;margin:14px 0 20px}
.tq .who{display:flex;align-items:center;gap:13px}
.tq .who img{width:46px;height:46px;border-radius:50%;object-fit:cover;flex:none;border:1px solid var(--line3)}
.tq .who b{display:block;color:#fff;font-size:14.5px}
.tq .who span{display:block;color:var(--txt-dim);font:600 12px var(--mono)}

/* ============================================================
   7) FAQ — dark glass accordion
   ============================================================ */
.home .faq{max-width:820px;margin:50px auto 0;display:flex;flex-direction:column;gap:14px}
.home .faq-item{border:1px solid var(--line2);border-radius:16px;background:var(--panel);overflow:hidden;transition:border-color .4s}
.home .faq-item:hover{border-color:rgba(0,189,195,.32)}
.home .faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:20px 24px;background:none;border:none;cursor:pointer;text-align:left;font-family:var(--display);font-weight:700;font-size:17px;color:#eef5fa}
.home .faq-q .pm{flex:none;width:30px;height:30px;border-radius:9px;display:grid;place-items:center;background:rgba(0,189,195,.14);color:#7ff0e6;font-size:20px;font-weight:400;transition:transform .35s var(--ease),background .35s}
.home .faq-item.open .faq-q .pm{transform:rotate(45deg);background:linear-gradient(140deg,var(--teal),var(--vio));color:#fff}
.home .faq-a{max-height:0;overflow:hidden;transition:max-height .45s var(--ease)}
.home .faq-a p{padding:0 24px 22px;color:var(--txt);font-size:15px;line-height:1.65;margin:0}

/* ============================================================
   8) FINAL CTA — aurora glow band
   ============================================================ */
.cta-aurora{position:relative;overflow:hidden;border-radius:30px;padding:78px 40px;text-align:center;background:linear-gradient(160deg,rgba(0,189,195,.12),rgba(123,108,255,.12)),#0e1a2c;border:1px solid var(--line3)}
.cta-aurora::before{content:"";position:absolute;inset:-40%;z-index:0;background:conic-gradient(from 0deg,transparent,rgba(0,189,195,.18),transparent 35%,rgba(123,108,255,.18),transparent 70%);animation:ctaSpin 18s linear infinite}
@keyframes ctaSpin{to{transform:rotate(360deg)}}
.cta-aurora .cta-grid{position:absolute;inset:0;z-index:0;opacity:.4;background-image:linear-gradient(rgba(122,170,200,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(122,170,200,.08) 1px,transparent 1px);background-size:48px 48px;-webkit-mask-image:radial-gradient(ellipse at center,#000,transparent 75%);mask-image:radial-gradient(ellipse at center,#000,transparent 75%)}
.cta-aurora>*{position:relative;z-index:2}
.cta-aurora h2{font-size:clamp(30px,4.5vw,52px);color:#fff;letter-spacing:-.02em;line-height:1.05;max-width:18ch;margin:14px auto 0}
.cta-aurora p{color:#bcd0e0;max-width:60ch;margin:18px auto 0;font-size:17px}
.cta-aurora .hero-cta{justify-content:center;margin-top:34px}

/* ============================================================
   Responsive (hero/stage preserved)
   ============================================================ */
@media(max-width:920px){
  .stage{height:560px;max-width:560px}
  .ring-sys{width:480px;height:480px}
  .device{width:380px}
  .fc-clients,.fc-ai{display:none}
  .fc-deploy{left:-4%;top:8%}
  .fc-review{left:-3%;bottom:6%}
  .tq{width:320px}
}
@media(max-width:680px){
  .hero-v2 .hero-pad{padding:130px 0 40px}
  .stage{height:470px;max-width:100%}
  .ring-sys{width:400px;height:400px}
  .device{width:300px;border-radius:16px}
  .dev-chart{height:50px}
  .dev-foot small{font-size:9.5px}
  .float-card{padding:10px 12px}
  .fc-deploy{left:-2%;top:5%}
  .fc-deploy span{display:none}
  .fc-review{left:-2%;bottom:4%}
  .fc-review span{display:none}
  .stage .dot.d4{display:none}
  .home .section{padding:78px 0}
}
@media(max-width:420px){
  .device{width:260px}
  .ring-sys{width:340px;height:340px}
  .stage{height:420px}
}

/* ============================================================
   v2 ADD-ONS — proof band redesign · more-services link · sprint vitals
   ============================================================ */
/* ---- PROOF (replaces old "by the numbers" slab) ---- */
.proof-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:50px}
.pf-card{position:relative;overflow:hidden;border-radius:20px;padding:30px 26px 26px;background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.018));border:1px solid var(--line2);transition:transform .45s var(--ease),border-color .45s}
.pf-card::before{content:"";position:absolute;inset:0;opacity:0;transition:opacity .45s;background:radial-gradient(420px circle at 30% 0%,rgba(0,189,195,.14),transparent 60%)}
.pf-card:hover{transform:translateY(-6px);border-color:rgba(0,189,195,.4)}
.pf-card:hover::before{opacity:1}
.pf-top{display:flex;align-items:center;justify-content:space-between;gap:10px;position:relative;z-index:1}
.pf-ic{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;background:linear-gradient(140deg,rgba(0,189,195,.2),rgba(123,108,255,.16));color:#7ff0e6;border:1px solid rgba(0,189,195,.25)}
.pf-ic svg{width:19px;height:19px}
.pf-tag{font:700 10.5px var(--mono);letter-spacing:.12em;color:var(--txt-dim);text-transform:uppercase}
.pf-n{position:relative;z-index:1;margin-top:22px;font-family:var(--display);font-weight:800;font-size:clamp(34px,4.4vw,50px);line-height:1;color:#fff}
.pf-l{position:relative;z-index:1;margin-top:10px;color:#dbe8f2;font-size:14px;font-weight:600;line-height:1.4}
.pf-track{position:relative;z-index:1;margin-top:18px;height:4px;border-radius:4px;background:rgba(255,255,255,.08);overflow:hidden}
.pf-track i{position:absolute;left:0;top:0;bottom:0;width:0;border-radius:4px;background:linear-gradient(90deg,var(--teal),var(--vio));box-shadow:0 0 12px rgba(0,189,195,.5);transition:width 1.1s var(--ease) .2s}
.pf-card.in .pf-track i{width:var(--w,70%)}
@media(max-width:820px){.proof-grid{grid-template-columns:1fr 1fr}}
@media(max-width:460px){.proof-grid{grid-template-columns:1fr}}

/* ---- centered "all services" text link ---- */
.more-link{display:inline-flex;align-items:center;gap:9px;font-family:var(--display);font-weight:700;font-size:17px;color:#eaf3fa;text-decoration:none;padding:6px 2px;position:relative;transition:color .35s,gap .35s}
.more-link::after{content:"";position:absolute;left:0;right:0;bottom:-3px;height:2px;border-radius:2px;background:linear-gradient(90deg,var(--teal),var(--vio));transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.more-link:hover{color:#fff;gap:13px}
.more-link:hover::after{transform:scaleX(1)}
.more-link svg{width:18px;height:18px;color:#7ff0e6}

/* ---- sprint vitals (fills the right column under the terminal) ---- */
.p-right{display:flex;flex-direction:column;gap:20px}
.vitals{border-radius:20px;border:1px solid var(--line2);background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.015));padding:24px 24px 26px}
.vitals h4{margin:0 0 4px;font-family:var(--display);font-size:16.5px;color:#fff}
.vitals .vh-sub{margin:0 0 20px;font:600 11.5px var(--mono);letter-spacing:.06em;color:var(--txt-dim)}
.vital + .vital{margin-top:16px}
.vital .v-top{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-bottom:8px}
.vital .v-top span{color:#cfe0ea;font-size:13.5px;font-weight:600}
.vital .v-top b{font-family:var(--display);font-size:16px;background:linear-gradient(120deg,#9ff7ee,#9b8bff);-webkit-background-clip:text;background-clip:text;color:transparent}
.vital .v-bar{height:6px;border-radius:6px;background:rgba(255,255,255,.07);overflow:hidden}
.vital .v-bar i{display:block;height:100%;width:0;border-radius:6px;background:linear-gradient(90deg,var(--teal),var(--vio));transition:width 1.2s var(--ease) .25s}
.vitals.in .v-bar i{width:var(--w,80%)}

/* ---- availability mini-card (fills right column under vitals) ---- */
.avail{display:flex;align-items:center;gap:16px;border-radius:18px;border:1px solid var(--line2);background:linear-gradient(120deg,rgba(0,189,195,.1),rgba(123,108,255,.08)),var(--panel);padding:18px 22px}
.avail .dot{position:relative;flex:none;width:11px;height:11px;border-radius:50%;background:#3ee68f;box-shadow:0 0 0 4px rgba(62,230,143,.18)}
.avail .dot::after{content:"";position:absolute;inset:0;border-radius:50%;background:#3ee68f;animation:availPing 2s ease-out infinite}
@keyframes availPing{0%{transform:scale(1);opacity:.7}100%{transform:scale(3.4);opacity:0}}
.avail .at{flex:1;min-width:0}
.avail .at b{display:block;color:#fff;font-family:var(--display);font-size:15px}
.avail .at span{display:block;color:var(--txt-dim);font:600 11.5px var(--mono);letter-spacing:.04em;margin-top:2px}
.avail a{flex:none;display:inline-flex;align-items:center;gap:6px;color:#7ff0e6;font-weight:700;font-size:13.5px;text-decoration:none;white-space:nowrap;transition:gap .3s}
.avail a:hover{gap:10px}
.avail a svg{width:15px;height:15px}
/* enhanced Q3 banner: capacity bar + reply meta */
.avail-bar{margin-top:9px;height:5px;border-radius:5px;background:rgba(255,255,255,.1);overflow:hidden;max-width:230px}
.avail-bar i{display:block;height:100%;width:var(--fill,67%);border-radius:5px;background:linear-gradient(90deg,#3ee68f,#7ff0e6);box-shadow:0 0 12px rgba(62,230,143,.5)}
.avail-meta{flex:none;display:flex;flex-direction:column;align-items:flex-end;gap:9px}
.avail-reply{display:inline-flex;align-items:center;gap:6px;color:var(--txt-dim);font:600 11.5px var(--mono);letter-spacing:.03em;white-space:nowrap}
.avail-reply svg{width:14px;height:14px;color:#7ff0e6}
@media(max-width:560px){
  .avail{flex-wrap:wrap;gap:14px}
  .avail-meta{width:100%;flex-direction:row;align-items:center;justify-content:space-between}
  .avail-bar{max-width:none}
}
