/* ============================================================
   NEXUS — Hero carousel (full-bleed) com iso card stack
   Slides: pitch (7s) · video showcase (20s) · notícias (6s cada)
   Auto-play, pausa em hover, swipe touch, dots com progressbar.
   ============================================================ */

.nx-hero{--nx-nav-h:72px;position:relative;margin-top:var(--nx-nav-h);height:680px;max-height:calc(88vh - var(--nx-nav-h));overflow:hidden;background:#000;font-family:var(--font-sans,'Plus Jakarta Sans',sans-serif);color:#fff}
body.has-newsbar .nx-hero{--nx-nav-h:calc(72px + var(--nx-newsbar-h,40px))}
.nx-hero-track{position:absolute;inset:0;display:flex;transition:transform .8s cubic-bezier(.65,.05,.36,1);will-change:transform}
.nx-hero-slide{flex:0 0 100%;position:relative;height:100%;overflow:hidden}
.nx-hero-media{position:absolute;inset:0;width:100%;height:100%}
.nx-hero-media img,.nx-hero-media video{width:100%;height:100%;object-fit:cover;display:block}
.nx-hero-overlay{position:absolute;inset:0;background:linear-gradient(100deg,rgba(12,20,16,.80) 0%,rgba(12,20,16,.55) 45%,rgba(12,20,16,.15) 100%)}

.nx-hero-inner{position:relative;height:100%;display:flex;flex-direction:column;justify-content:center;max-width:1240px;margin:0 auto;padding:0 48px;z-index:2}

/* — Eyebrow + título + sub — */
.nx-hero-eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(107,255,143,.14);color:#6bff8f;padding:6px 14px;border-radius:999px;font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;width:max-content;margin-bottom:18px;border:1px solid rgba(107,255,143,.22)}
.nx-hero-eyebrow .dot{width:7px;height:7px;border-radius:50%;background:#6bff8f;box-shadow:0 0 0 0 rgba(107,255,143,.6);animation:nxHeroPulse 2s infinite}
@keyframes nxHeroPulse{0%,100%{box-shadow:0 0 0 0 rgba(107,255,143,.55)}50%{box-shadow:0 0 0 8px rgba(107,255,143,0)}}
.nx-hero-title{font-size:clamp(2rem,5.4vw,4.2rem);font-weight:800;line-height:1.05;letter-spacing:-.025em;margin-bottom:18px;max-width:760px;color:#fff}
.nx-hero-title .accent{background:linear-gradient(120deg,#6bff8f 0%,#fff 100%);-webkit-background-clip:text;background-clip:text;color:transparent}
.nx-hero-sub{font-size:1.05rem;font-weight:400;color:#cbd5d0;line-height:1.55;max-width:560px;margin-bottom:28px}
.nx-hero-cta{display:flex;gap:12px;flex-wrap:wrap}
.nx-hero-btn{display:inline-flex;align-items:center;gap:8px;padding:13px 22px;border-radius:9px;font-weight:700;font-size:.88rem;text-decoration:none;border:1.5px solid transparent;transition:transform .15s ease,background .15s ease;font-family:inherit;cursor:pointer}
.nx-hero-btn.primary{background:#006e2f;color:#fff;box-shadow:0 8px 22px -8px rgba(0,110,47,.55)}
.nx-hero-btn.primary:hover{background:#22c55e;transform:translateY(-1px)}
.nx-hero-btn.ghost{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.22);backdrop-filter:blur(8px)}
.nx-hero-btn.ghost:hover{background:rgba(255,255,255,.16)}

/* — Pitch slide (split grid) — */
.nx-pitch-bg{background:
  radial-gradient(circle at 18% 25%,rgba(107,255,143,.18),transparent 45%),
  radial-gradient(circle at 82% 80%,rgba(0,110,47,.30),transparent 50%),
  linear-gradient(135deg,#06120c 0%,#0c1410 50%,#0d1a14 100%)}
.nx-pitch-bg::before{content:"";position:absolute;inset:0;background-image:
  linear-gradient(rgba(107,255,143,.06) 1px,transparent 1px),
  linear-gradient(90deg,rgba(107,255,143,.06) 1px,transparent 1px);
  background-size:56px 56px;mask:radial-gradient(ellipse at 30% 50%,#000 30%,transparent 75%);
  -webkit-mask:radial-gradient(ellipse at 30% 50%,#000 30%,transparent 75%)}
.nx-pitch-grid{position:relative;z-index:2;height:100%;display:grid;grid-template-columns:1.15fr .85fr;gap:40px;align-items:center;max-width:1240px;margin:0 auto;padding:0 48px;color:#fff}
.nx-pitch-left{max-width:560px}
.nx-pitch-right{position:relative;display:flex;align-items:center;justify-content:center;height:100%}

/* — Stats no pitch — */
.nx-pitch-stats{display:flex;align-items:center;gap:22px;margin-top:32px;padding-top:24px;border-top:1px solid rgba(107,255,143,.16)}
.nx-pstat{display:flex;flex-direction:column}
.nx-pstat .num{font-size:1.7rem;font-weight:800;color:#6bff8f;letter-spacing:-.02em;line-height:1}
.nx-pstat .lbl{font-size:.7rem;color:rgba(232,245,236,.65);text-transform:uppercase;letter-spacing:.05em;margin-top:6px;font-weight:600}
.nx-pstat-sep{width:1px;height:30px;background:rgba(107,255,143,.18)}

/* — Iso card stack (Storage / Compute / Network) — */
.nx-iso-stack{position:relative;width:100%;max-width:460px;height:440px;perspective:1400px;perspective-origin:50% 30%;display:flex;align-items:center;justify-content:center;transform-style:preserve-3d}
.nx-iso-floor{position:absolute;left:50%;top:78%;width:280px;height:60px;transform:translate(-50%,-50%) rotateX(75deg);background:radial-gradient(ellipse at center,rgba(107,255,143,.35),transparent 70%);filter:blur(14px);pointer-events:none}
.nx-iso-card{position:absolute;width:300px;background:linear-gradient(135deg,rgba(13,46,24,.78),rgba(6,18,12,.72));backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(107,255,143,.22);border-radius:16px;padding:14px 16px;display:flex;align-items:center;gap:14px;color:#e8f5ec;box-shadow:0 22px 40px -16px rgba(0,110,47,.55),inset 0 1px 0 rgba(255,255,255,.08)}
.nx-iso-card::before{content:"";position:absolute;left:0;top:14px;bottom:14px;width:3px;border-radius:0 3px 3px 0;background:linear-gradient(180deg,#6bff8f,#006e2f)}
.nx-iso-card.iso-storage{--tx:40px;--ty:-110px;--tz:60px;animation:nxIsoFloat 5s ease-in-out infinite}
.nx-iso-card.iso-compute{--tx:0;--ty:0;--tz:0;animation:nxIsoFloat 5s ease-in-out infinite -1.7s}
.nx-iso-card.iso-network{--tx:-40px;--ty:110px;--tz:-60px;animation:nxIsoFloat 5s ease-in-out infinite -3.4s}
@keyframes nxIsoFloat{
  0%,100%{transform:rotateX(58deg) rotateZ(-32deg) translate3d(var(--tx,0),var(--ty,0),var(--tz,0))}
  50%    {transform:rotateX(58deg) rotateZ(-32deg) translate3d(var(--tx,0),calc(var(--ty,0) - 8px),var(--tz,0))}
}
.nx-iso-ico{flex-shrink:0;width:38px;height:38px;border-radius:10px;background:rgba(107,255,143,.12);border:1px solid rgba(107,255,143,.20);color:#6bff8f;display:flex;align-items:center;justify-content:center;animation:nxIcoGlow 3s ease-in-out infinite}
@keyframes nxIcoGlow{
  0%,100%{box-shadow:0 0 0 0 rgba(107,255,143,0)}
  50%    {box-shadow:0 0 18px 2px rgba(107,255,143,.18)}
}
.nx-iso-info{flex:1;display:flex;flex-direction:column;gap:3px;min-width:0}
.nx-iso-info strong{font-size:.78rem;font-weight:700;color:#fff;letter-spacing:.02em}

/* ── Storage: bars que pulsam (data fluindo) ── */
.nx-iso-bars{display:flex;flex-direction:column;gap:3px;margin-top:2px}
.nx-iso-bar{position:relative;height:5px;background:rgba(107,255,143,.10);border-radius:3px;overflow:hidden}
.nx-iso-bar span{display:block;width:var(--w,50%);height:100%;background:linear-gradient(90deg,#6bff8f,#22c55e);border-radius:3px;position:relative}
/* Brilho a percorrer a bar */
.nx-iso-bar span::after{content:"";position:absolute;top:0;left:-30%;width:30%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.55),transparent);animation:nxStoreShine 2.8s ease-in-out infinite}
@keyframes nxStoreShine{
  0%   {left:-30%}
  60%  {left:120%}
  100% {left:120%}
}
.iso-storage .nx-iso-bar:nth-child(1) span{animation:nxStoreBar1 4.2s ease-in-out infinite}
.iso-storage .nx-iso-bar:nth-child(2) span{animation:nxStoreBar2 3.6s ease-in-out infinite -1.2s}
@keyframes nxStoreBar1{0%,100%{width:78%}50%{width:90%}}
@keyframes nxStoreBar2{0%,100%{width:55%}50%{width:66%}}

/* ── Compute: linha de scan + valores que vibram subtilmente ── */
.nx-iso-row{display:flex;justify-content:space-between;font-size:.66rem;color:rgba(232,245,236,.65)}
.nx-iso-row b{color:#6bff8f;font-weight:700;animation:nxValShift 4s ease-in-out infinite}
.iso-compute .nx-iso-row:nth-child(3) b{animation-delay:-2s}
@keyframes nxValShift{
  0%,100%{transform:translateY(0);opacity:1}
  48%    {transform:translateY(-1px);opacity:.6}
  52%    {transform:translateY(1px);opacity:1}
}
.iso-compute{position:relative;overflow:hidden}
.iso-compute::after{content:"";position:absolute;left:0;right:0;top:0;height:1px;background:linear-gradient(90deg,transparent,rgba(107,255,143,.65),transparent);animation:nxComputeScan 3.5s linear infinite;pointer-events:none}
@keyframes nxComputeScan{
  0%   {transform:translateY(0)}
  100% {transform:translateY(80px)}
}

/* ── Network: sparkline a fluir + seta animada + ondas radar ── */
.nx-iso-spark{width:80px;height:22px;margin-top:2px;overflow:visible}
.nx-iso-spark polyline{stroke-dasharray:6 4;animation:nxSparkFlow 1.6s linear infinite}
@keyframes nxSparkFlow{from{stroke-dashoffset:0}to{stroke-dashoffset:-20}}

.nx-iso-pill{flex-shrink:0;background:rgba(107,255,143,.14);color:#6bff8f;font-size:.65rem;font-weight:700;padding:3px 8px;border-radius:5px;border:1px solid rgba(107,255,143,.20);animation:nxPillBreath 3s ease-in-out infinite}
@keyframes nxPillBreath{0%,100%{background:rgba(107,255,143,.14);border-color:rgba(107,255,143,.20)}50%{background:rgba(107,255,143,.22);border-color:rgba(107,255,143,.40)}}

.nx-iso-led{flex-shrink:0;width:8px;height:8px;border-radius:50%;background:#6bff8f;box-shadow:0 0 10px rgba(107,255,143,.8);animation:nxLedBlink 1.4s ease-in-out infinite;position:relative}
.nx-iso-led::after{content:"";position:absolute;inset:-2px;border-radius:50%;border:1px solid rgba(107,255,143,.6);animation:nxLedRing 1.8s ease-out infinite}
@keyframes nxLedBlink{0%,100%{opacity:1}50%{opacity:.3}}
@keyframes nxLedRing{
  0%  {transform:scale(.8);opacity:.7}
  100%{transform:scale(2.2);opacity:0}
}

.nx-iso-arrow{flex-shrink:0;color:#6bff8f;font-weight:800;font-size:1rem;opacity:.85;animation:nxArrowGo 2.2s ease-in-out infinite;text-shadow:0 0 0 rgba(107,255,143,0)}
@keyframes nxArrowGo{
  0%,100%{transform:translate(0,0);opacity:.65;text-shadow:0 0 0 rgba(107,255,143,0)}
  50%    {transform:translate(2px,-3px);opacity:1;text-shadow:0 0 8px rgba(107,255,143,.7)}
}

/* — Video showcase — */
.nx-vid-vignette{position:absolute;inset:0;pointer-events:none;background:
  radial-gradient(ellipse at center,transparent 55%,rgba(12,20,16,.45) 100%),
  linear-gradient(180deg,rgba(12,20,16,.35) 0%,transparent 25%,transparent 75%,rgba(12,20,16,.35) 100%)}
.nx-vid-pill{position:absolute;top:34px;left:50%;transform:translateX(-50%);z-index:2;display:flex;align-items:center;gap:10px;background:rgba(0,0,0,.45);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.22);padding:8px 18px;border-radius:999px;color:#fff;font-size:.74rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.nx-vid-pill::before{content:"";width:7px;height:7px;border-radius:50%;background:#6bff8f;box-shadow:0 0 12px rgba(107,255,143,.7)}

/* — News slide — */
.nx-news-tag{display:inline-flex;align-items:center;gap:7px;background:rgba(0,110,47,.85);color:#fff;padding:6px 12px;border-radius:6px;font-size:.7rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;margin-bottom:14px;border:1px solid transparent;width:max-content;box-shadow:0 4px 12px -4px rgba(0,0,0,.4);line-height:1}
.nx-news-tag svg{flex-shrink:0;opacity:.95}
.nx-news-tag.kind-noticia { background:rgba(0,110,47,.90)  }
.nx-news-tag.kind-evento  { background:rgba(124,58,237,.90); border-color:rgba(196,181,253,.30) }
.nx-news-tag.kind-aviso   { background:rgba(217,119,6,.92); border-color:rgba(252,211,77,.32) }
.nx-news-tag.kind-showcase{ background:rgba(14,116,144,.92); border-color:rgba(125,211,252,.32) }

/* — Nav (arrows + dots) — */
.nx-hero-arrow{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.20);color:#fff;font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:3;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);opacity:0;transition:opacity .25s,background .15s,transform .15s;font-family:inherit;line-height:1;padding:0}
.nx-hero:hover .nx-hero-arrow{opacity:1}
.nx-hero-arrow:hover{background:rgba(255,255,255,.22);transform:translateY(-50%) scale(1.06)}
.nx-hero-arrow.prev{left:26px}
.nx-hero-arrow.next{right:26px}
.nx-hero-arrow:focus-visible{outline:2px solid #6bff8f;outline-offset:3px}

.nx-hero-dots{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:3}
.nx-hero-dot{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.35);border:0;cursor:pointer;padding:0;transition:all .25s ease;position:relative;overflow:hidden}
.nx-hero-dot.active{width:32px;border-radius:5px;background:rgba(255,255,255,.18)}
.nx-hero-dot.active::after{content:"";position:absolute;inset:0;background:#6bff8f;border-radius:5px;transform-origin:left;animation:nxHeroFill var(--slide-dur,6s) linear forwards}
@keyframes nxHeroFill{from{transform:scaleX(0)}to{transform:scaleX(1)}}
.nx-hero.paused .nx-hero-dot.active::after{animation-play-state:paused}

/* — Responsive — */
@media (max-width:900px){
  .nx-hero{height:580px}
  .nx-pitch-grid{grid-template-columns:1fr;padding:0 22px;gap:24px}
  .nx-pitch-right{display:none}
  .nx-pitch-stats{flex-wrap:wrap;gap:14px 22px}
  .nx-pstat-sep{display:none}
  .nx-hero-inner{padding:0 22px}
  .nx-hero-arrow{display:none}
}

/* — Reduced motion — */
@media (prefers-reduced-motion:reduce){
  .nx-hero-track{transition:none}
  .nx-hero-eyebrow .dot,
  .nx-iso-card,.nx-iso-led,.nx-iso-led::after,
  .nx-iso-ico,.nx-iso-pill,.nx-iso-arrow,
  .nx-iso-bar span,.nx-iso-bar span::after,
  .nx-iso-row b,.iso-compute::after,
  .nx-iso-spark polyline{animation:none !important}
  .nx-hero-dot.active::after{animation:none;transform:scaleX(1)}
}
