:root{
  --bg:#050713;
  --panel:#0b0f1f;
  --panel2:#101733;
  --text:#f2f3ff;
  --muted:#b7b7d3;
  --border:rgba(255,255,255,.10);
  --shadow: 0 22px 70px rgba(0,0,0,.60);
  --red:#ff3b3b;
  --blue:#2fd2ff;
  --violet:#a45bff;
  --teal:#00ffd5;
  --radius:18px;
  --max:1180px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Helvetica Neue", sans-serif;
  color:var(--text);
  background:
    radial-gradient(900px 600px at 18% 12%, rgba(47,210,255,.18), transparent 58%),
    radial-gradient(880px 560px at 82% 18%, rgba(155,92,255,.14), transparent 58%),
    radial-gradient(820px 560px at 55% 92%, rgba(255,59,59,.12), transparent 60%),
    radial-gradient(760px 520px at 24% 78%, rgba(0,255,213,.08), transparent 62%),
    var(--bg);
  line-height:1.45;
}

body.page-home{
  position: relative;
}
body.page-home::before,
body.page-home::after{
  content: "";
  position: fixed;
  top: 0;
  bottom: 0;
  width: min(360px, 22vw);
  background-image: url("../assets/home-side-figure.webp");
  background-repeat: no-repeat;
  background-size: contain;
  opacity: .18;
  filter: blur(.8px) drop-shadow(0 0 42px rgba(47,210,255,.16));
  pointer-events: none;
  z-index: 0;
  
  -webkit-mask-image: linear-gradient(to bottom, transparent 0%, #000 18%, #000 82%, transparent 100%);
  mask-image: linear-gradient(to bottom, transparent 0%, #000 18%, #000 82%, transparent 100%);
}
body.page-home::before{
  left: 0;
  background-position: left 56%;
  transform: translateX(-18%) rotate(-2deg);
}
body.page-home::after{
  right: 0;
  background-position: right 56%;
  
  transform: translateX(18%) scaleX(-1) rotate(-2deg);
}

body.page-home #conteudo{
  position: relative;
  z-index: 1;
}

@media (max-width: 980px){
  body.page-home::before,
  body.page-home::after{
    display:none;
  }
}

body.page-staff{
  position: relative;
}

body.page-staff::before,
body.page-staff::after{
  content: "";
  position: fixed;
  top: 0;
  bottom: 0;
  width: min(520px, 30vw);
  background-image: url("../assets/staff-side-figure.webp");
  background-repeat: no-repeat;
  
  background-size: 112% auto;
  opacity: .15;
  filter: blur(1.35px) grayscale(.25) saturate(.75) brightness(.85) contrast(1.08)
          drop-shadow(0 0 70px rgba(47,210,255,.16));
  mix-blend-mode: screen;
  pointer-events: none;
  z-index: 0;

  
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-size: 100% 100%;
  mask-size: 100% 100%;
}

body.page-staff::before{
  left: 0;
  background-position: left 72%;
  transform: translateX(-26%) rotate(-1.6deg);

  -webkit-mask-image: radial-gradient(72% 78% at 34% 50%, #000 0%, #000 56%, transparent 100%);
  mask-image: radial-gradient(72% 78% at 34% 50%, #000 0%, #000 56%, transparent 100%);
}

body.page-staff::after{
  right: 0;
  background-position: right 72%;
  transform: translateX(26%) scaleX(-1) rotate(-1.6deg);

  -webkit-mask-image: radial-gradient(72% 78% at 66% 50%, #000 0%, #000 56%, transparent 100%);
  mask-image: radial-gradient(72% 78% at 66% 50%, #000 0%, #000 56%, transparent 100%);
}

body.page-staff #conteudo{
  position: relative;
  z-index: 1;
}

body.page-staff.hasIntro::before,
body.page-staff.hasIntro::after,
body.hasIntro.page-staff::before,
body.hasIntro.page-staff::after{
  opacity: 0 !important;
}

@media (max-width: 980px){
  body.page-staff::before,
  body.page-staff::after{
    display:none;
  }
}

a{color:inherit; text-decoration:none}
code{font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace}

.container{max-width:var(--max); margin:0 auto; padding:0 18px}
.muted{color:var(--muted)}

.skip{
  position:absolute; left:-999px; top:auto; width:1px; height:1px; overflow:hidden;
}
.skip:focus{left:18px; top:10px; width:auto; height:auto; padding:10px 12px; background:rgba(0,0,0,.9); border:1px solid var(--border); border-radius:12px; z-index:999}

.badge{
  display:inline-flex; align-items:center; gap:8px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  font-weight:900;
  letter-spacing:.06em;
  font-size:.78rem;
}
.badge::before{content:""; width:8px; height:8px; border-radius:999px; background:rgba(46,204,113,.9); box-shadow: 0 0 18px rgba(46,204,113,.35)}

.topstrip{
  position:sticky; top:0; z-index:100;
  background: rgba(7,7,11,.88);
  backdrop-filter: blur(14px);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.topstrip__inner{display:flex; align-items:center; justify-content:space-between; gap:12px; padding:10px 0}
.topstrip__left{display:flex; align-items:center; gap:10px; color:var(--muted); font-size:.95rem; flex-wrap:wrap}
.topstrip__right{display:flex; align-items:center; gap:10px; flex-wrap:wrap}
.topstrip__sep{opacity:.65}
.topstrip__link{opacity:.92}
.topstrip__link:hover{opacity:1; color:var(--text)}

.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid var(--border);
  background: rgba(255,255,255,.05);
  color:var(--text);
  font-weight:800;
  letter-spacing:.02em;
  cursor:pointer;
  transition: transform .08s ease, background .2s ease, border-color .2s ease;
  white-space:nowrap;
}
.btn:hover{background: rgba(255,255,255,.08); transform: translateY(-1px)}
.btn:active{transform: translateY(0)}
.btn--primary{
  background: linear-gradient(135deg, rgba(209,43,43,.96), rgba(58,166,255,.18));
  border-color: rgba(209,43,43,.40);
}
.btn--ghost{background: transparent}
.btn--shop{background: rgba(255,255,255,.10); border-color: rgba(255,255,255,.16)}

.mast{
  position:sticky; top:52px; z-index:90;
  background: rgba(7,7,11,.62);
  backdrop-filter: blur(14px);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.mast__inner{display:flex; align-items:center; justify-content:space-between; gap:14px; padding:14px 0}

.mast{
  isolation:isolate;
}
.mast::before{
  content:"";
  position:absolute;
  inset:-120px -90px -60px -90px;
  pointer-events:none;
  z-index:0;
  background:
    radial-gradient(460px 220px at 18% 18%, rgba(47,210,255,.22), transparent 62%),
    radial-gradient(520px 240px at 78% 35%, rgba(155,92,255,.16), transparent 64%),
    radial-gradient(560px 260px at 55% 88%, rgba(255,59,59,.12), transparent 66%);
  filter: blur(26px) saturate(1.35);
  opacity:.65;
  animation: mastAura 14s ease-in-out infinite alternate;
}
.mast::after{
  content:"";
  position:absolute;
  left:-40%;
  right:-40%;
  bottom:0;
  height:2px;
  pointer-events:none;
  z-index:1;
  background:
    linear-gradient(90deg,
      rgba(47,210,255,0),
      rgba(47,210,255,.85),
      rgba(155,92,255,.80),
      rgba(255,59,59,.78),
      rgba(47,210,255,.85),
      rgba(47,210,255,0)
    );
  background-size: 220% 100%;
  filter: drop-shadow(0 0 18px rgba(47,210,255,.22));
  opacity:.95;
  animation: mastLine 9.5s ease-in-out infinite;
}

@keyframes mastAura{
  0%{transform: translate3d(-1.6%, -0.6%, 0) scale(1.02)}
  100%{transform: translate3d(1.6%, 0.8%, 0) scale(1.05)}
}
@keyframes mastLine{
  0%{background-position: 0% 50%}
  50%{background-position: 100% 50%}
  100%{background-position: 0% 50%}
}

.mast__inner{position:relative; z-index:2}

.nav__link{position:relative; overflow:hidden}
.nav__link::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  pointer-events:none;
  background:
    linear-gradient(135deg,
      rgba(47,210,255,.18),
      rgba(155,92,255,.14),
      rgba(255,59,59,.12)
    );
  opacity:0;
  transform: translateY(10%);
  transition: opacity .22s ease, transform .22s ease;
}
.nav__link:hover::before{opacity:1; transform: translateY(0)}
.nav__link.is-active::before{opacity:1; transform: translateY(0)}

@media (prefers-reduced-motion: reduce){
  .mast::before,
  .mast::after{animation:none}
  .nav__link::before{transition:none}
}

.brand{display:flex; align-items:center; gap:12px; min-width: 240px}
.brand__logo{width:80px; height:80px; border-radius:16px; object-fit:contain; background: rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.08)}
.brand__name{font-weight:950; letter-spacing:.10em}
.brand__tag{color:var(--muted); font-size:.86rem; margin-top:2px}

.nav{display:flex; gap:10px; flex-wrap:wrap; align-items:center}
.nav__link{
  padding:10px 12px;
  border-radius:999px;
  border:1px solid transparent;
  color:var(--muted);
  font-weight:900;
  letter-spacing:.05em;
}
.nav__link:hover{border-color: rgba(47,210,255,.22); color:var(--text)}
.nav__link.is-active{
  background: rgba(255,255,255,.06);
  border-color: rgba(47,210,255,.24);
  color:var(--text);
  box-shadow:
    0 0 0 1px rgba(47,210,255,.10),
    0 0 28px rgba(47,210,255,.10);
}

.mast__actions{display:flex; gap:10px; align-items:center; flex-wrap:wrap}

.iconbtn{
  width:44px; height:44px;
  border-radius:14px;
  border:1px solid var(--border);
  background: rgba(255,255,255,.04);
  display:none;
  cursor:pointer;
}
.iconbtn span{display:block; height:2px; width:18px; margin:4px auto; background: var(--text); opacity:.9}
.iconbtn:hover{background: rgba(255,255,255,.07)}

.drawer{display:none}
.drawer.is-open{display:block}
.drawer__backdrop{position:fixed; inset:0; background: rgba(0,0,0,.62); z-index:200}
.drawer__panel{
  position:fixed; top:0; right:0; height:100%; width:min(420px, 92vw);
  background: rgba(12,12,18,.98);
  border-left:1px solid rgba(255,255,255,.10);
  box-shadow: var(--shadow);
  display:flex; flex-direction:column;
  z-index:210;
}
.drawer__head{display:flex; align-items:center; justify-content:space-between; padding:14px; border-bottom:1px solid rgba(255,255,255,.08)}
.drawer__title{font-weight:950; letter-spacing:.06em}
.drawer__close{font-size:26px; line-height:1; border:1px solid rgba(255,255,255,.10); background: rgba(255,255,255,.04); color:var(--text); border-radius:14px; width:44px; height:44px; cursor:pointer}
.drawer__close:hover{background: rgba(255,255,255,.07)}
.drawer__grid{display:grid; gap:12px; padding:14px; overflow:auto}
.drawer__col{border:1px solid rgba(255,255,255,.08); border-radius:16px; padding:12px; background: rgba(255,255,255,.03)}
.drawer__label{color:var(--muted); font-weight:950; letter-spacing:.08em; font-size:.82rem; margin-bottom:8px}
.drawer__col a{display:block; padding:10px; border-radius:12px; color:var(--muted)}
.drawer__col a:hover{background: rgba(255,255,255,.06); color:var(--text)}
.drawer__foot{display:grid; gap:10px; padding:14px; border-top:1px solid rgba(255,255,255,.08)}

.kicker{
  display:inline-flex;
  padding:8px 10px;
  border:1px solid rgba(255,255,255,.10);
  border-radius:999px;
  background: rgba(255,255,255,.04);
  color:var(--muted);
  font-weight:950;
  letter-spacing:.10em;
  font-size:.78rem;
}

.hero{position:relative; overflow:hidden}
.hero__bg{
  position:absolute; inset:-90px -90px auto -90px;
  height:640px;
  background-image:
    
    radial-gradient(520px 280px at 18% 30%, rgba(209,43,43,.24), transparent 62%),
    radial-gradient(540px 300px at 70% 60%, rgba(58,166,255,.18), transparent 62%),
    url("../assets/home_alt.webp")
  );
  background-position: 0 0, 0 0, center;
  background-size: auto, auto, cover;
  background-repeat: no-repeat;
  opacity:.72;
  filter: saturate(1.10) contrast(1.06);
  mask-image: linear-gradient(to bottom, #000  78%, transparent 100%);
}

.hero__inner{
  display:grid;
  grid-template-columns: 1.25fr .85fr;
  gap:18px;
  padding:26px 0 18px;
}

.heroBar{display:flex; gap:10px; flex-wrap:wrap; margin-bottom:12px}
.pill{display:inline-flex; padding:8px 10px; border-radius:999px; border:1px solid rgba(255,255,255,.10); background: rgba(0,0,0,.20); color:rgba(255,255,255,.86); font-weight:900; letter-spacing:.04em; font-size:.86rem}

.slider{
  border:1px solid rgba(255,255,255,.10);
  border-radius:20px;
  background: rgba(255,255,255,.03);
  box-shadow: var(--shadow);
  overflow:hidden;
}
.slider__track{display:flex; width:100%; transform: translateX(0); transition: transform .45s ease}
.slide{min-width:100%; padding:22px}
.slide h1{margin:10px 0 8px 0; line-height:1.05; font-size: clamp(2.0rem, 3.0vw, 2.8rem)}
.lead{color:var(--muted); max-width: 62ch; font-size:1.06rem}

.cta{display:flex; gap:10px; flex-wrap:wrap; align-items:stretch; margin-top:14px}
.ipBox{flex:1 1 260px; border:1px solid rgba(255,255,255,.10); border-radius:16px; padding:10px 12px; background: rgba(0,0,0,.22)}
.ipBox__label{color:var(--muted); font-size:.86rem; font-weight:900; letter-spacing:.05em}
.ipBox__value{font-size:1.06rem}

.note{margin-top:12px; color:rgba(255,255,255,.72); font-size:.92rem}

.slider__controls{display:flex; align-items:center; justify-content:space-between; gap:12px; padding:12px; border-top:1px solid rgba(255,255,255,.08); background: rgba(0,0,0,.18)}
.slider__btn{width:42px; height:42px; border-radius:14px; border:1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.04); color:var(--text); font-size:22px; cursor:pointer}
.slider__btn:hover{background: rgba(255,255,255,.07)}
.slider__dots{display:flex; gap:8px; align-items:center; justify-content:center; flex:1}
.dotBtn{width:10px; height:10px; border-radius:999px; border:1px solid rgba(255,255,255,.30); background: rgba(255,255,255,.10); cursor:pointer}
.dotBtn.is-active{background: rgba(209,43,43,.95); border-color: rgba(209,43,43,.95)}

.hero__right{display:grid; gap:12px}
.card{border:1px solid rgba(255,255,255,.10); border-radius:18px; padding:14px; background: rgba(255,255,255,.03); box-shadow: 0 18px 55px rgba(0,0,0,.42)}
.card__title{font-weight:950; letter-spacing:.04em}
.card__text{color:var(--muted); margin-top:6px}
.card__link{display:inline-flex; margin-top:10px; color:rgba(242,243,255,.92)}
.card__link:hover{text-decoration:underline}
.miniList{margin:10px 0 0 18px; color:rgba(255,255,255,.88)}

.section{padding:22px 0}
.section--alt{background: rgba(255,255,255,.02); border-top:1px solid rgba(255,255,255,.06); border-bottom:1px solid rgba(255,255,255,.06)}
.section__head{display:flex; align-items:flex-end; justify-content:space-between; gap:12px; margin-bottom:12px; flex-wrap:wrap}
.section__head h2{margin:0; letter-spacing:.06em}
.section__head p{margin:0; color:var(--muted)}

.grid3{display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:12px}
.feature{border:1px solid rgba(255,255,255,.10); border-radius:18px; padding:14px; background: rgba(255,255,255,.03)}
.feature__title{font-weight:950}
.feature__text{color:var(--muted); margin-top:6px}

.ctaWide{margin-top:14px; border:1px solid rgba(255,255,255,.10); border-radius:22px; padding:18px; background: linear-gradient(135deg, rgba(255,255,255,.04), rgba(209,43,43,.10)); display:flex; align-items:center; justify-content:space-between; gap:14px; flex-wrap:wrap}
.ctaWide__title{font-weight:950; font-size:1.15rem}
.ctaWide__text{color:var(--muted)}
.ctaWide__actions{display:flex; gap:10px; flex-wrap:wrap}

.pageHero{position:relative; overflow:hidden; border-bottom:1px solid rgba(255,255,255,.06)}
.pageHero__bg{
  position:absolute; inset:-80px -80px auto -80px;
  height:320px;
  background-image:
    radial-gradient(420px 220px at 20% 50%, rgba(209,43,43,.22), transparent 62%),
    radial-gradient(420px 220px at 70% 55%, rgba(58,166,255,.18), transparent 62%),
    image-set(
      url("../assets/bg.webp") type("image/webp"),
      url("../assets/bg.jpg") type("image/jpeg")
    );
  background-position: 0 0, 0 0, center;
  background-size: auto, auto, cover;
  background-repeat:no-repeat;
  opacity:.22;
  mask-image: linear-gradient(to bottom, #000 52%, transparent 100%);
  pointer-events:none;
}

.pageHero__inner{position:relative; z-index:1}

.vipBackBtn{position:relative; z-index:2; margin-bottom:10px}

/* VIP details hero */
.pageHero--vip .pageHero__bg{
  height: 360px;
  background-image:
    radial-gradient(560px 280px at 18% 55%, rgba(255,255,255,.12), transparent 64%),
    radial-gradient(560px 280px at 72% 52%, rgba(0,0,0,.18), transparent 68%),
    var(--vip-hero),
    image-set(
      url("../assets/bg.webp") type("image/webp"),
      url("../assets/bg.jpg") type("image/jpeg")
    );
  background-position: 0 0, 0 0, center, center;
  background-size: auto, auto, cover, cover;
  opacity: .32;
  filter: saturate(1.08) contrast(1.08);
}

/* VIP hero images (CSP-safe — no inline styles) */
.pageHero--vip-cobra{
  --vip-hero: url("../assets/vip_cobra_splash.jpg");
  --vip-accent1: rgba(90,255,160,.96);
  --vip-accent2: rgba(58,166,255,.18);
  --vip-glow: rgba(90,255,160,.22);
}
.pageHero--vip-vibora{
  --vip-hero: url("../assets/vip_vibora_splash.jpg");
  --vip-accent1: rgba(255,170,70,.96);
  --vip-accent2: rgba(255,70,70,.14);
  --vip-glow: rgba(255,170,70,.20);
}
.pageHero--vip-hydra{
  --vip-hero: url("../assets/vip_hydra_splash.jpg");
  --vip-accent1: rgba(185,120,255,.96);
  --vip-accent2: rgba(120,210,255,.14);
  --vip-glow: rgba(185,120,255,.22);
}

/* Kit Kaboom (hero image + accents) */
.pageHero--kit-kaboom{
  --vip-hero: url("../assets/kit_kaboom_splash.jpg");
  --vip-accent1: rgba(255,170,70,.96);
  --vip-accent2: rgba(255,70,70,.14);
  --vip-glow: rgba(255,170,70,.20);
}

/* VIP theme vars on body (para botões/elementos fora do hero) */
body.vipTheme--cobra{
  --vip-accent1: rgba(90,255,160,.96);
  --vip-accent2: rgba(58,166,255,.18);
  --vip-glow: rgba(90,255,160,.22);
}
body.vipTheme--vibora{
  --vip-accent1: rgba(255,170,70,.96);
  --vip-accent2: rgba(255,70,70,.14);
  --vip-glow: rgba(255,170,70,.20);
}
body.vipTheme--hydra{
  --vip-accent1: rgba(185,120,255,.96);
  --vip-accent2: rgba(120,210,255,.14);
  --vip-glow: rgba(185,120,255,.22);
}

/* Kit theme vars (para botões/elementos do kit) */
body.vipTheme--kaboom{
  --vip-accent1: rgba(255,170,70,.96);
  --vip-accent2: rgba(255,70,70,.14);
  --vip-glow: rgba(255,170,70,.20);
}

.vipBadge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.12);
  font-weight: 950;
  letter-spacing: .02em;
}

.vipDetail{display:grid; grid-template-columns: 360px minmax(0,1fr); gap:14px; align-items:start}

.vipPanel{
  border:1px solid rgba(255,255,255,.10);
  border-radius:20px;
  padding:16px;
  background: rgba(255,255,255,.03);
}

.vipDetail__title{margin:0 0 6px 0}
.vipDetail__img{display:block; width:100%; height:auto; border-radius:14px; border:1px solid rgba(255,255,255,.10); background: rgba(0,0,0,.12)}
.vipBenefits{margin:12px 0 0 18px; color: rgba(255,255,255,.90)}

.vipDetail__splashPanel{padding:14px; display:flex; flex-direction:column; gap:12px}
.vipDetail__splashImg{
  display:block;
  width:100%;
  height: 250px;
  object-fit: cover;
  object-position: center top;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.12);
}
.vipDetail__cta{display:flex; flex-wrap:wrap; gap:10px}
.vipDetail__cta--stack{flex-direction:column}
.vipDetail__cta--stack .btn{width:100%}

.btn--vipPrimary{
  background: linear-gradient(135deg, var(--vip-accent1, rgba(209,43,43,.96)), var(--vip-accent2, rgba(58,166,255,.18)));
  border-color: rgba(255,255,255,.22);
  box-shadow:
    0 0 0 1px rgba(255,255,255,.10) inset,
    0 10px 34px var(--vip-glow, rgba(255,59,59,.18));
  position:relative;
  overflow:hidden;
}
.btn--vipPrimary::after{
  content:"";
  position:absolute;
  inset:-2px;
  background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,.22) 42%, transparent 72%);
  transform: translateX(-120%);
  opacity:.55;
  animation: vipShine 2.8s ease-in-out infinite;
}
.btn--vipGhost{
  background: rgba(0,0,0,.10);
  border-color: rgba(255,255,255,.16);
}
.btn--vipGhost:hover{
  border-color: rgba(255,255,255,.26);
  box-shadow: 0 10px 28px rgba(0,0,0,.26);
}
@keyframes vipShine{
  0%{transform: translateX(-120%)}
  55%{transform: translateX(120%)}
  100%{transform: translateX(120%)}
}
@media (prefers-reduced-motion: reduce){
  .btn--vipPrimary::after{animation:none}
}

/* VIP detail layout
   - Benefits should align with the KIT column (right) on desktop.
   - On mobile it stacks naturally.
*/
.vipDetail__benefitsPanel{margin-top:0; grid-column:2}

/* VIP detail pages: keep only the "Voltar" button inside the hero.
   Hide the main site navigation/header actions (Home/Loja/Updates/etc).
*/
.page-vipdetail .mast .nav,
.page-vipdetail .mast .mast__actions,
.page-vipdetail .mast .drawer{display:none !important}
.page-vipdetail .mast__inner{justify-content:flex-start}

@media (max-width: 980px){
  .vipDetail{grid-template-columns: 1fr}
  .vipDetail__splashImg{height: 220px}
  .vipDetail__benefitsPanel{grid-column: 1 / -1}
}

@media (max-width: 980px){
  .vipDetail{grid-template-columns: 1fr}
}

.pageHero__inner{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:14px;
  padding-top:18px;
  padding-bottom:14px;
  flex-wrap:wrap;
}
.pageHero__tools{display:flex; gap:10px; flex-wrap:wrap; align-items:center; position:relative; padding:10px 12px; border-radius:18px; border:1px solid rgba(255,255,255,.10); background: rgba(255,255,255,.02); overflow:hidden; isolation:isolate}

.pageHero--updates .pageHero__inner{align-items:flex-start}
.pageHero--updates .pageHero__tools{
  order: 3;
  width: 100%;
  flex: 0 0 100%;
  max-width: 100%;
  align-self: stretch;
  justify-content: flex-start;
  margin-top: 12px;
}
.pageHero--updates .input{width:min(560px, 100%)}

.input{width:min(460px, 92vw); padding:12px; border-radius:14px; border:1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.03); color:var(--text)}

.chips{display:flex; gap:10px; flex-wrap:wrap}
.chip{padding:10px 12px; border-radius:999px; border:1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.03); color:var(--muted); font-weight:900; cursor:pointer}
.chip.is-active{background: rgba(255,255,255,.08); color:var(--text)}

.pill2{display:inline-flex; padding:7px 10px; border-radius:999px; border:1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.03); color:var(--muted); font-weight:950; letter-spacing:.06em; font-size:.82rem}

.updates{display:grid; gap:12px}
.updateCard{border:1px solid rgba(255,255,255,.10); border-radius:20px; padding:16px; background: rgba(255,255,255,.03)}
.updateCard__meta{display:flex; gap:10px; align-items:center; margin-bottom:6px; flex-wrap:wrap}
.updateCard h2{margin:8px 0 6px 0}
.updateCard ul{margin:10px 0 0 18px; color:rgba(255,255,255,.88)}
.updateCard p{color:var(--muted); margin:10px 0 0 0}

.products{display:grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap:12px}
.product{border:1px solid rgba(255,255,255,.10); border-radius:20px; padding:16px; background: rgba(255,255,255,.03); display:flex; flex-direction:column; min-height: 280px; position:relative}

/* VIP cards (splash encaixada dentro do card + clique no card) */
.product--vip{
  cursor:pointer;
  overflow:hidden;
  isolation:isolate;
  padding:0;
  display:flex;
  flex-direction:column;
  position:relative;
}

/* Splash do VIP como fundo do card inteiro */
.vipCard__media{
  position:absolute;
  inset:0;
  height:auto;
  width:100%;
  background-size:cover;
  /* Mostra mais a parte de cima da splash (rosto do boneco/serpentes) */
  background-position: center top;
  background-repeat:no-repeat;
  z-index:0;
}

/* Overlay leve pra manter legibilidade e dar “acabamento” */
.vipCard__media::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(to bottom,
      rgba(0,0,0,.04) 0%,
      rgba(0,0,0,.18) 34%,
      rgba(0,0,0,.52) 72%,
      rgba(0,0,0,.70) 100%
    );
  pointer-events:none;
}

.vipCard__content{
  position:relative;
  z-index:1;
  padding:16px;
  display:flex;
  flex-direction:column;
  flex:1;
  min-height:0;
  /* dá contraste sem “tampar” totalmente a arte */
  background: linear-gradient(
    to bottom,
    rgba(7,7,11,.08) 0%,
    rgba(7,7,11,.54) 52%,
    rgba(7,7,11,.74) 100%
  );
}

/* Tipografia dos VIPs (mais “neon”/foco, combinando com as splash arts) */
.product--vip{--vip-accent:#ffffff; --vip-accent-rgb:255,255,255;}
.product--vip-cobra{--vip-accent:#57ff3f; --vip-accent-rgb:87,255,63;}
.product--vip-vibora{--vip-accent:#ff9a2f; --vip-accent-rgb:255,154,47;}
.product--vip-hydra{--vip-accent:#b06cff; --vip-accent-rgb:176,108,255;}
.product--kit-kaboom{--vip-accent:#ff9a2f; --vip-accent-rgb:255,154,47;}

.product--vip h3{
  margin:0 0 8px 0;
  font-size: clamp(22px, 2.2vw, 30px);
  font-weight: 950;
  letter-spacing: .02em;
  text-transform: uppercase;
  color: rgba(255,255,255,.98);
  text-shadow:
    0 3px 14px rgba(0,0,0,.95),
    0 0 18px rgba(var(--vip-accent-rgb), .55),
    0 0 38px rgba(var(--vip-accent-rgb), .22);
}

/* Título “arco-íris” (clean) — substitui o RGB animado */
.vipRainbow{
  /* fallback */
  color: rgba(255,255,255,.98);
  text-shadow:
    0 3px 14px rgba(0,0,0,.95),
    0 0 26px rgba(255,255,255,.16);
}

@supports (-webkit-background-clip:text) or (background-clip:text){
  .vipRainbow{
    background: linear-gradient(90deg,
      #ff004c,
      #ff7a00,
      #ffd500,
      #00ff6a,
      #00d5ff,
      #3c5bff,
      #b300ff,
      #ff004c
    );
    background-size: 280% 100%;
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    -webkit-text-fill-color: transparent;
    filter: drop-shadow(0 2px 12px rgba(0,0,0,.55));
  }

  /* animação só no hover (desktop), pra não ficar “poluído” */
  @media (hover:hover) and (pointer:fine){
    .vipRainbow:hover{animation: vipRainbowShift 3.8s linear infinite;}
  }

  @media (prefers-reduced-motion: reduce){
    .vipRainbow:hover{animation:none}
  }

  @keyframes vipRainbowShift{to{background-position: 280% 0;}}
}

@supports (-webkit-background-clip:text) or (background-clip:text){
  /* se o título tiver .vipRainbow, ele usa o arco-íris e ignora o gradiente por VIP */
  .product--vip h3:not(.vipRainbow){
    background: linear-gradient(90deg,
      rgba(255,255,255,1) 0%,
      rgba(255,255,255,.98) 20%,
      rgba(var(--vip-accent-rgb), 1) 100%
    );
    -webkit-background-clip:text;
    background-clip:text;
    color: transparent;
    -webkit-text-fill-color: transparent;
  }
}

.product--vip .muted{
  color: rgba(255,255,255,.88);
  font-weight: 850;
  text-shadow: 0 2px 12px rgba(0,0,0,.92);
  margin: 0 0 12px 0;
}

.product--vip .product__price{
  font-size: 18px;
  color: rgba(255,255,255,.99);
  text-shadow:
    0 3px 14px rgba(0,0,0,.95),
    0 0 16px rgba(var(--vip-accent-rgb), .26);
}

/* Artes (CSP-safe — sem inline style) */
.vipCard__media--cobra{background-image: url("../assets/vip_cobra_splash.jpg");}
.vipCard__media--vibora{background-image: url("../assets/vip_vibora_splash.jpg");}
.vipCard__media--hydra{background-image: url("../assets/vip_hydra_splash.jpg");}

/* Kits (store cards) */
.vipCard__media--kaboom{background-image: url("../assets/kit_kaboom_splash.jpg");background-position:50% 30%;}

.product--vip:hover{border-color: rgba(255,255,255,.18); background: rgba(255,255,255,.05)}
.product--vip:hover .vipCard__media::after{
  background:
    linear-gradient(to bottom,
      rgba(0,0,0,.06) 0%,
      rgba(0,0,0,.22) 34%,
      rgba(0,0,0,.58) 72%,
      rgba(0,0,0,.76) 100%
    );
}
.product--vip:focus-within{outline:2px solid rgba(255,255,255,.22); outline-offset:2px}

.product ul{margin:10px 0 0 18px; color:rgba(255,255,255,.88)}
.product__bottom{margin-top:auto; display:flex; align-items:center; justify-content:space-between; gap:10px}
.page-store .product__bottom{justify-content:flex-end}

/* Na página da loja, VIPs têm: linha (preço + ações) + botão centralizado de detalhes */
.page-store .product--vip .product__bottom{
  display:flex;
  flex-direction:column;
  align-items:stretch;
  gap:12px;
}
.page-store .product--vip .product__row{justify-content:center}
.page-store .product--vip .product__price{text-align:center}

.product__row{display:flex; align-items:center; justify-content:space-between; gap:10px}
.product__details{display:flex; justify-content:center}
.product__details .btn{width:190px; justify-content:center}

/* Botão de detalhes (mais clean e alinhado com os outros) */
.btn--details{
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.16);
  font-weight:850;
}
.btn--details:hover{background: rgba(255,255,255,.10); border-color: rgba(255,255,255,.22)}

@media (max-width: 520px){
  .product__details .btn{width:100%}
}

.product__price{font-weight:950; letter-spacing:.02em; color: rgba(255,255,255,.92)}
.product__actions{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:10px;
}
.product__actions .btn{
  width:190px;
  justify-content:center;
  text-align:center;
  white-space:nowrap;
  line-height:1.2;
  padding:12px 14px;
}

/* Botão de detalhes (centralizado embaixo do card) */
.product__details{margin-top:12px; display:flex; justify-content:center}
.product__details .btn{min-width: 190px; justify-content:center}

@media (max-width: 520px){
  .product__actions .btn{width:100%}
}

.price{font-weight:950}
.product--basic{border-color: rgba(255,255,255,.12)}
.product--mid{border-color: rgba(209,43,43,.25)}
.product--pro{border-color: rgba(209,43,43,.38)}

#vips{position:relative; overflow:hidden}
#vips .vipShowcaseArt{
  position:absolute;
  right: max(-64px, -4vw);
  top: 52%;
  width: min(420px, 34vw);
  opacity: .28;
  pointer-events:none;
  z-index: 0;
  filter: saturate(1.08) contrast(1.06) drop-shadow(0 18px 60px rgba(0,0,0,.58));
  transform: translateY(-50%);
  -webkit-mask-image: radial-gradient(closest-side at 60% 50%, rgba(0,0,0,1), rgba(0,0,0,.75) 62%, rgba(0,0,0,0) 100%);
          mask-image: radial-gradient(closest-side at 60% 50%, rgba(0,0,0,1), rgba(0,0,0,.75) 62%, rgba(0,0,0,0) 100%);
}

#vips .vipShowcaseArt--left{
  position:absolute;
  left: max(-64px, -4vw);
  right: auto;
  top: 52%;
  width: min(420px, 34vw);
  opacity: .24;
  pointer-events:none;
  z-index: 0;
  filter: saturate(1.06) contrast(1.05) drop-shadow(0 18px 60px rgba(0,0,0,.58));
  transform: translateY(-50%);
  -webkit-mask-image: radial-gradient(closest-side at 40% 50%, rgba(0,0,0,1), rgba(0,0,0,.75) 62%, rgba(0,0,0,0) 100%);
          mask-image: radial-gradient(closest-side at 40% 50%, rgba(0,0,0,1), rgba(0,0,0,.75) 62%, rgba(0,0,0,0) 100%);
}
#vips .vipShowcaseArt img{display:block; width:100%; height:auto; image-rendering: pixelated}
#vips .container{position:relative; z-index:1}
@media (max-width: 980px){
  #vips .vipShowcaseArt{display:none}
}
@media (prefers-reduced-motion: no-preference){
  #vips .vipShowcaseArt{animation: vipFloatRight 7.2s ease-in-out infinite}
  #vips .vipShowcaseArt--left{animation: vipFloatLeft 7.2s ease-in-out infinite}

  @keyframes vipFloatRight{
    0%,100%{transform: translateY(-50%) translateX(0)}
    50%{transform: translateY(calc(-50% - 10px)) translateX(-8px)}
  }
  @keyframes vipFloatLeft{
    0%,100%{transform: translateY(-50%) translateX(0)}
    50%{transform: translateY(calc(-50% - 10px)) translateX(8px)}
  }
}

.notice{margin-top:14px; border:1px dashed rgba(255,255,255,.18); border-radius:20px; padding:16px; background: rgba(0,0,0,.18)}
.notice__title{font-weight:950; margin-bottom:6px}

.faq{margin-top:16px; border:1px solid rgba(255,255,255,.10); border-radius:20px; padding:16px; background: rgba(255,255,255,.03)}
.faq h2{margin:0 0 10px 0}
.faq details{border-top:1px solid rgba(255,255,255,.08); padding:10px 0}
.faq details:first-of-type{border-top:0}
.faq summary{cursor:pointer; font-weight:900}
.faq p{color:var(--muted); margin:8px 0 0 0}

.socials{display:grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap:12px}
.socialCard{border:1px solid rgba(255,255,255,.10); border-radius:20px; padding:16px; background: rgba(255,255,255,.03); transition: transform .08s ease, background .2s ease}
.socialCard:hover{transform: translateY(-1px); background: rgba(255,255,255,.05)}
.socialCard__name{font-weight:950}
.socialCard__meta{color:var(--muted); margin-top:6px}
.socialCard__cta{margin-top:12px; color:rgba(242,243,255,.92)}

.discordCta{margin-top:16px; border:1px solid rgba(255,255,255,.10); border-radius:22px; padding:18px; background: linear-gradient(135deg, rgba(58,166,255,.10), rgba(209,43,43,.10)); display:flex; align-items:center; justify-content:space-between; gap:14px; flex-wrap:wrap}

.footer{border-top:1px solid rgba(255,255,255,.08); background: rgba(0,0,0,.18)}
.footer__grid{display:flex; justify-content:center; align-items:center; gap:18px; padding:18px 0; flex-wrap:wrap}
.footer__brand{display:flex; flex-direction:column; align-items:center; justify-content:center; gap:10px; text-align:center}
.footer__brand img{width:46px; height:46px; border-radius:14px; border:1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.03); object-fit:contain; image-rendering: -webkit-optimize-contrast;}
.footer__name{font-weight:950; letter-spacing:.05em}
.footer__muted{color:var(--muted); font-size:.92rem}
.footer__cols{display:flex; gap:22px; flex-wrap:wrap}
.footer__col{display:grid; gap:8px; min-width: 160px}
.footer__label{color:rgba(255,255,255,.78); font-weight:950; letter-spacing:.08em; font-size:.82rem}
.footer__col a{color:var(--muted)}
.footer__col a:hover{color:var(--text); text-decoration:underline}

.footer__bottom{border-top:1px solid rgba(255,255,255,.08); padding:12px 0; display:flex; justify-content:space-between; gap:12px; flex-wrap:wrap; color:rgba(255,255,255,.78)}
.footer__bottomLinks{display:flex; gap:14px; flex-wrap:wrap}
.footer__bottomLinks a{color:var(--muted)}
.footer__bottomLinks a:hover{color:var(--text)}

.footer__logoWrap{
  position:relative;
  width:64px;
  height:64px;
  display:grid;
  place-items:center;
  border-radius:18px;
  animation: footerBob 6.2s ease-in-out infinite;
}
.footer__logoWrap::before{
  content:"";
  position:absolute;
  inset:-18px;
  border-radius:26px;
  background:
    radial-gradient(circle at 28% 30%, rgba(0,212,255,.34), transparent 58%),
    radial-gradient(circle at 72% 34%, rgba(163,67,255,.28), transparent 60%),
    radial-gradient(circle at 55% 76%, rgba(255,58,58,.22), transparent 62%);
  filter: blur(11px);
  opacity:.82;
  pointer-events:none;
  animation: footerFlare 7.2s ease-in-out infinite;
}
.footer__logoWrap::after{
  content:"";
  position:absolute;
  inset:-7px;
  border-radius:22px;
  background: conic-gradient(from 180deg,
    rgba(0,212,255,0),
    rgba(0,212,255,.40),
    rgba(163,67,255,.34),
    rgba(255,58,58,.30),
    rgba(0,212,255,0));
  opacity:.55;
  mix-blend-mode: screen;
  pointer-events:none;
  filter: blur(1px);
  animation: footerSpin 9.5s linear infinite;
}
.footer__logoWrap img{position:relative; z-index:2}
.footer__brand:hover .footer__logoWrap::before{opacity:.95}
.footer__brand:hover .footer__logoWrap::after{opacity:.7}

@keyframes footerBob{
  0%,100%{transform: translateY(0) scale(1)}
  50%{transform: translateY(-3px) scale(1.02)}
}
@keyframes footerFlare{
  0%,100%{transform: translateY(0) rotate(0deg); filter: blur(11px)}
  50%{transform: translateY(-2px) rotate(8deg); filter: blur(13px)}
}
@keyframes footerSpin{
  from{transform: rotate(0deg)}
  to{transform: rotate(360deg)}
}

.footer__grid{justify-content:center; align-items:center}
.footer__bottomLinks .footer__chip{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background: linear-gradient(135deg, rgba(0,212,255,.06), rgba(163,67,255,.05), rgba(255,58,58,.04), rgba(255,255,255,.02));
  background-size: 260% 260%;
  animation: footerChipBg 8.5s ease-in-out infinite;
  color: rgba(255,255,255,.88);
  letter-spacing:.02em;
  overflow:hidden;
  transition: transform .18s ease, border-color .18s ease, background .18s ease, color .18s ease;
}
.footer__bottomLinks .footer__chip::before{
  content:"";
  position:absolute; inset:-18px;
  background:
    radial-gradient(circle at 18% 40%, rgba(0,212,255,.22), transparent 55%),
    radial-gradient(circle at 82% 58%, rgba(163,67,255,.18), transparent 55%),
    radial-gradient(circle at 50% 110%, rgba(255,58,58,.14), transparent 60%);
  filter: blur(18px);
  opacity:0;
  transition: opacity .18s ease;
}
.footer__bottomLinks .footer__chip::after{
  content:"";
  position:absolute; inset:-40%;
  background: linear-gradient(120deg, transparent, rgba(255,255,255,.16), transparent);
  transform: translateX(-120%);
  opacity:0;
}
.footer__bottomLinks .footer__chip:hover{
  transform: translateY(-1px);
  border-color: rgba(255,255,255,.26);
  background: rgba(255,255,255,.05);
  color: var(--text);
}
.footer__bottomLinks .footer__chip:hover::before{opacity:1}
.footer__bottomLinks .footer__chip:hover::after{
  opacity:1;
  animation: footerSheen 1.05s ease;
}
@keyframes footerSheen{
  to{transform: translateX(120%)}
}

@keyframes footerChipBg{
  0%{background-position: 0% 50%}
  50%{background-position: 100% 50%}
  100%{background-position: 0% 50%}
}

@media (max-width: 980px){
  .nav{display:none}
  .iconbtn{display:inline-flex}
  .hero__inner{grid-template-columns: 1fr}
  .grid3{grid-template-columns: 1fr}
  .products{grid-template-columns: 1fr}
  .socials{grid-template-columns: 1fr 1fr}
}
@media (max-width: 520px){
  .socials{grid-template-columns: 1fr}
}

.statusbar{background:rgba(0,0,0,.55);border-bottom:1px solid rgba(255,255,255,.10)}
.statusbar__inner{display:flex;align-items:center;justify-content:space-between;padding:10px 0;gap:12px}
.statusbar__left{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.statusbar__item{display:inline-flex;align-items:baseline;gap:8px;padding:6px 10px;border-radius:10px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);box-shadow:0 6px 18px rgba(0,0,0,.25);font-weight:900;letter-spacing:.06em;font-size:12px}
.statusbar__label{opacity:.75;font-size:11px}
.statusbar__val.is-online{color:#71ff8a}
.statusbar__sep{color:rgba(255,255,255,.28);font-weight:900}
.statusbar__link{display:inline-flex;align-items:center;gap:8px;text-decoration:none;padding:7px 10px;border-radius:10px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);font-weight:900;font-size:12px}
.statusbar__link:hover{background:rgba(255,255,255,.08)}
.ico{display:inline-block;vertical-align:middle}

.rulesGrid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.ruleCard{border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.03);border-radius:var(--radius2);padding:16px}
.ruleCard__top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}
.ruleNo{padding:6px 10px;border-radius:999px;border:1px solid rgba(31,212,255,.25);background:rgba(31,212,255,.10);font-weight:900;letter-spacing:.06em;font-size:12px}
.ruleCard h3{margin:0;font-size:15px;letter-spacing:.02em}
.ruleList{margin:0;padding-left:18px;color:rgba(233,238,246,.78)}
.ruleList li{margin:6px 0}
@media (max-width:720px){.rulesGrid{grid-template-columns:1fr}}

body::before{
  content:"";
  position:fixed;
  inset:-25vh -25vw;
  z-index:-1;
  pointer-events:none;
  background:
    radial-gradient(520px 320px at 20% 20%, rgba(47,210,255,.18), transparent 60%),
    radial-gradient(520px 320px at 80% 30%, rgba(255,59,59,.14), transparent 62%),
    radial-gradient(560px 340px at 55% 80%, rgba(155,92,255,.14), transparent 62%);
  filter: blur(36px) saturate(1.30);
  opacity:.95;
  animation: auroraDrift 16s ease-in-out infinite alternate;
}
@keyframes auroraDrift{
  0%{transform: translate3d(-2%, -1%, 0) scale(1.02)}
  50%{transform: translate3d(2%, 1%, 0) scale(1.04)}
  100%{transform: translate3d(0, 2%, 0) scale(1.03)}
}

.hero__bg, .pageHero__bg{
  animation: bgPan 14s ease-in-out infinite alternate;
}
@keyframes bgPan{
  from{background-position: 0 0, 0 0, center}
  to{background-position: 36px -22px, -32px 20px, center}
}

.card,.feature,.updateCard,.product,.socialCard,.ruleCard,.faq,.notice,.drawer__col{
  position:relative;
  overflow:hidden;
  background: linear-gradient(180deg, rgba(255,255,255,.065), rgba(255,255,255,.028));
  box-shadow: 0 18px 60px rgba(0,0,0,.44);
  transition: transform .22s ease, box-shadow .28s ease, border-color .28s ease, background .28s ease;
}
.card::before,.feature::before,.updateCard::before,.product::before,.socialCard::before,.ruleCard::before,.faq::before,.notice::before,.drawer__col::before{
  content:"";
  position:absolute;
  inset:-2px;
  border-radius: inherit;
  pointer-events:none;
  background:
    radial-gradient(560px 160px at 20% 0%, rgba(47,210,255,.14), transparent 60%),
    radial-gradient(560px 160px at 80% 0%, rgba(255,59,59,.10), transparent 60%),
    linear-gradient(135deg, rgba(47,210,255,.10), rgba(155,92,255,.08), rgba(255,59,59,.08));
  opacity:.72;
}
.card:hover,.feature:hover,.updateCard:hover,.product:hover,.socialCard:hover,.ruleCard:hover,.faq:hover,.notice:hover{
  transform: translateY(-3px);
  border-color: rgba(47,210,255,.28);
  box-shadow:
    0 22px 86px rgba(0,0,0,.60),
    0 0 0 1px rgba(47,210,255,.12),
    0 0 46px rgba(47,210,255,.12);
}

.brand__logo{box-shadow: 0 10px 40px rgba(47,210,255,.12)}

.reveal{opacity:0; transform: translate3d(0,14px,0); transition: opacity .65s ease, transform .65s ease; will-change: opacity, transform}
.reveal.is-in{opacity:1; transform:none}

.updates--timeline{
  --timeline-mid: 56px;
  position:relative;
  display:grid;
  grid-template-columns: 1fr var(--timeline-mid) 1fr;
  gap:18px 12px;
  padding: 10px 0 0;
}
.updates--timeline::before{
  content:"";
  position:absolute;
  left:50%;
  top:0;
  bottom:0;
  width:2px;
  transform: translateX(-50%);
  background: linear-gradient(to bottom, rgba(47,210,255,.0), rgba(47,210,255,.32), rgba(155,92,255,.22), rgba(255,59,59,.20), rgba(47,210,255,.0));
  filter: drop-shadow(0 0 14px rgba(47,210,255,.20));
  opacity:.95;
}
.updates--timeline .updateCard{
  position:relative;
  margin:0;
  width:100%;
  max-width: 100%;
}
.updates--timeline .updateCard:nth-of-type(odd){grid-column:1}
.updates--timeline .updateCard:nth-of-type(even){grid-column:3}

.updates--timeline .updateCard::after{
  content:"";
  position:absolute;
  top:22px;
  width:14px;
  height:14px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.30);
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.98), rgba(47,210,255,.70));
  box-shadow: 0 0 0 6px rgba(47,210,255,.10), 0 0 28px rgba(47,210,255,.18);
}
.updates--timeline .updateCard:nth-of-type(odd)::after{right: calc(-1 * (var(--timeline-mid) / 2 + 7px))}
.updates--timeline .updateCard:nth-of-type(even)::after{left: calc(-1 * (var(--timeline-mid) / 2 + 7px))}

@media (max-width: 880px){
  .updates--timeline{grid-template-columns: 1fr; gap:12px}
  .updates--timeline::before{left:16px; transform:none}
  .updates--timeline .updateCard{max-width: 100%; justify-self:stretch; padding-left:18px}
  .updates--timeline .updateCard:nth-of-type(odd),
  .updates--timeline .updateCard:nth-of-type(even){grid-column:1}
  .updates--timeline .updateCard::after{left:9px; right:auto}
}

.updates--timeline .updatesMascotArt{
  position:absolute;
  top: 56%;
  width: min(560px, 46vw);
  opacity: .20;
  pointer-events:none;
  z-index: 0;
  transform: translateY(-50%);
  filter: saturate(1.06) contrast(1.06) drop-shadow(0 22px 74px rgba(0,0,0,.62));
}

.updates--timeline .updatesMascotArt--right{
  right: max(-120px, -8vw);
  left: auto;
  -webkit-mask-image: radial-gradient(closest-side at 62% 50%, rgba(0,0,0,1), rgba(0,0,0,.76) 62%, rgba(0,0,0,0) 100%);
          mask-image: radial-gradient(closest-side at 62% 50%, rgba(0,0,0,1), rgba(0,0,0,.76) 62%, rgba(0,0,0,0) 100%);
}

.updates--timeline .updatesMascotArt--left{
  left: max(-120px, -8vw);
  right: auto;
  width: min(520px, 44vw);
  opacity: .16;
  -webkit-mask-image: radial-gradient(closest-side at 38% 50%, rgba(0,0,0,1), rgba(0,0,0,.76) 62%, rgba(0,0,0,0) 100%);
          mask-image: radial-gradient(closest-side at 38% 50%, rgba(0,0,0,1), rgba(0,0,0,.76) 62%, rgba(0,0,0,0) 100%);
}

.updates--timeline .updatesMascotArt img{display:block; width:100%; height:auto}

.updates--timeline .updatesMascotArt--right img{transform: scaleX(-1)}

@media (max-width: 980px){
  .updates--timeline .updatesMascotArt{display:none}
}

@media (prefers-reduced-motion: no-preference){
  .updates--timeline .updatesMascotArt--right{animation: updatesMascotFloatR 8.4s ease-in-out infinite}
  .updates--timeline .updatesMascotArt--left{animation: updatesMascotFloatL 8.4s ease-in-out infinite}
  @keyframes updatesMascotFloatR{
    0%,100%{transform: translateY(-50%) translateX(0)}
    50%{transform: translateY(calc(-50% - 10px)) translateX(-10px)}
  }
  @keyframes updatesMascotFloatL{
    0%,100%{transform: translateY(-50%) translateX(0)}
    50%{transform: translateY(calc(-50% - 10px)) translateX(10px)}
  }
}

.cartbtn{
  margin-left:10px;
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  height:44px;
  min-width:44px;
  padding:0 14px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: rgba(233,238,246,.96);
  cursor:pointer;
  font-weight:900;
  letter-spacing:.02em;
  transition: transform .18s ease, background .18s ease, border-color .18s ease;
}
.cartbtn:hover{
  transform: translateY(-1px);
  background: rgba(255,255,255,.09);
  border-color: rgba(47,210,255,.28);
}
.cartbtn__icon{font-size:18px; line-height:1}
.cartbtn__icon svg{width:18px; height:18px; display:block}
.cartbtn__badge{
  position:absolute;
  top:-8px;
  right:-8px;
  min-width:22px;
  height:22px;
  padding:0 6px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  background: rgba(47,210,255,.92);
  color:#051018;
  border: 1px solid rgba(0,0,0,.25);
  font-size:12px;
  font-weight:900;
}

.cartDrawer{position:fixed; inset:0; display:none; z-index:120}
.cartDrawer.is-open{display:block}

.cartDrawer__backdrop{
  position:absolute;
  inset:0;
  background: rgba(0,0,0,.62);
  backdrop-filter: blur(8px);
  z-index:0;
  opacity:0;
  transition: opacity .14s ease;
}
.cartDrawer.is-open .cartDrawer__backdrop{ opacity:1; }

/* Carrinho simples (painel no canto direito, alinhado com a HUD) */
.cartDrawer__panel{
  position:absolute;
  top: var(--cart-top, 96px);
  right: var(--cart-right, 16px);
  left:auto;
  transform: scale(.98);
  width:min(460px, 92vw);
  /* Mantém o painel dentro da tela (considerando o topo calculado) */
  max-height: min(calc(100vh - var(--cart-top, 96px) - 16px), 680px);
  z-index:1;

  border:1px solid rgba(255,255,255,.12);
  border-radius:18px;
  overflow:hidden;
  box-shadow: 0 28px 90px rgba(0,0,0,.70);

  background: rgba(12,14,22,.96);
  display:flex;
  flex-direction:column;

  opacity:0;
  transition: transform .14s ease, opacity .14s ease;
}
.cartDrawer.is-open .cartDrawer__panel{
  opacity:1;
  transform: scale(1);
}

/* Cabeçalho */
.cartDrawer__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:14px 16px;
  border-bottom:1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
}
.cartDrawer__title{font-weight:950; letter-spacing:.02em}
.cartDrawer__close{
  width:40px;
  height:40px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color: rgba(233,238,246,.92);
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  transition: transform .12s ease, background .12s ease;
}
.cartDrawer__close:hover{ background: rgba(255,255,255,.10); transform: translateY(-1px); }

/* Corpo com scroll (só quando precisar) */
.cartDrawer__body{
  padding:12px 16px 14px;
  overflow:auto;
  flex:1;
  background: transparent;

  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,.18) transparent;
}
.cartDrawer__body::-webkit-scrollbar{width:10px}
.cartDrawer__body::-webkit-scrollbar-thumb{background: rgba(255,255,255,.14); border-radius: 999px}
.cartDrawer__body::-webkit-scrollbar-track{background: transparent}

/* Rodapé */
.cartDrawer__foot{
  border-top:1px solid rgba(255,255,255,.08);
  padding:14px 16px calc(14px + env(safe-area-inset-bottom));
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  background: rgba(255,255,255,.03);
}
.cartDrawer__actions{display:flex; gap:10px; align-items:center}
.cartDrawer__actions .btn{white-space:nowrap}

@media (max-width: 520px){
  .cartDrawer__panel{ width:92vw; max-height: 88vh; border-radius:16px; }
  .cartDrawer__foot{ flex-direction:column; align-items:stretch; }
  .cartDrawer__actions{ width:100%; }
  .cartDrawer__actions .btn{ flex:1; }
}

.cartTotal{display:flex; flex-direction:column; gap:2px}
.cartList{display:flex; flex-direction:column; gap:10px; background: transparent}

.cartRow{
  display:grid;
  grid-template-columns: 1fr auto;
  align-items:start;
  gap:12px;
  padding:12px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.05);
}
.cartRow__meta{display:flex; flex-direction:column; gap:4px}
.cartRow__name{font-weight:900}
.cartRow__price{opacity:.85; font-size:13px}
.cartRow__qty{opacity:.75; font-size:12px}
.cartRow__actions{display:flex; gap:8px; align-items:center; flex-wrap:wrap; justify-content:flex-end}

.cartRow__btn{
  width:36px; height:36px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color: rgba(233,238,246,.92);
  cursor:pointer;
  font-weight:1000;
  font-size:18px;
  line-height:1;
}
.cartRow__btn:hover{ background: rgba(255,255,255,.10); }

.cartRow__remove{
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color: rgba(233,238,246,.92);
  cursor:pointer;
  font-weight:900;
  font-size:12px;
  letter-spacing:.02em;
}
.cartRow__remove:hover{ background: rgba(255,255,255,.08); }
.cartIconBtn{
  width:38px; height:38px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color: rgba(233,238,246,.92);
  cursor:pointer;
}
.cartEmpty{padding:12px}
.cartEmpty__title{font-weight:900; margin-bottom:6px}

.product__buttons{display:flex; gap:10px; flex-wrap:wrap; margin-top:10px}

.galleryGrid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:14px;
}
.galleryItem{
  position:relative;
  border-radius: 18px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  cursor: zoom-in;
}
.galleryItem img{
  width:100%;
  height:210px;
  object-fit: cover;
  display:block;
  transition: transform .35s ease;
  transform: translateZ(0) scale(1.02);
  filter: saturate(1.05) contrast(1.05);
}
.galleryItem figcaption{
  position:absolute;
  left:0; right:0; bottom:0;
  padding:12px 12px 14px;
  background: linear-gradient(to top, rgba(0,0,0,.70), rgba(0,0,0,0));
  display:flex;
  flex-direction:column;
  gap:4px;
}
.galleryItem:hover{
  transform: scale(1.06);
  z-index:5;
  border-color: rgba(47,210,255,.22);
  box-shadow: 0 26px 90px rgba(0,0,0,.65);
}
.galleryItem:hover img{transform: translateZ(0) scale(1.16)}
.storyProse p{color: rgba(233,238,246,.84); line-height:1.75; margin:0 0 14px}
.footer__legal{margin-top:10px; opacity:.75; font-size:12px; line-height:1.6}
@media (max-width: 900px){
  .galleryGrid{grid-template-columns: 1fr}
  .galleryItem img{height:240px}
}

.aboutCard{
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(10,12,18,.60);
  backdrop-filter: blur(10px);
  border-radius: var(--radius2);
  padding: 34px 34px 28px;
  box-shadow: 0 22px 90px rgba(0,0,0,.55);
  max-width: 980px;

  overflow: hidden;
}

.aboutLead{
  margin-top: 10px;
  
  display: inline-block;
  max-width: min(62ch, calc(100% - 360px));
  font-size: 1.02rem;
  font-weight: 800;
  letter-spacing: .01em;
  color: rgba(245,248,255,.95);
  line-height: 1.55;

  padding: 12px 14px;
  border-radius: 18px;

  border: 1px solid rgba(255,255,255,.12);
  border-left: 3px solid rgba(0,195,255,.55);

  background: linear-gradient(90deg,
    rgba(0,170,255,.14),
    rgba(140,70,255,.12) 55%,
    rgba(255,80,80,.10)
  );
  box-shadow:
    0 10px 40px rgba(0,0,0,.35),
    0 0 0 1px rgba(0,0,0,.28) inset;
  backdrop-filter: blur(8px);
}

@media (max-width: 980px){
  
  .aboutLead{ max-width: 70ch; }
}

.aboutProse{
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,.08);
}
.aboutProse p{
  color: rgba(233,238,246,.84);
  line-height: 1.8;
  margin: 0 0 14px;
  font-size: 15px;
}
.aboutProse p:last-child{margin-bottom:0}
.aboutActions{
  margin-top: -14px;
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
}

.carousel{
  position: relative;
  margin-top: 14px;
}
.carousel__track{
  display:flex;
  gap:14px;
  overflow-x:auto;
  padding: 6px 52px 14px;
  scroll-snap-type: x proximity;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
  scrollbar-width: thin;
}
.carousel__track::-webkit-scrollbar{height:10px}
.carousel__track::-webkit-scrollbar-thumb{background: rgba(255,255,255,.12); border-radius: 999px}
.carousel__item{
  scroll-snap-align: center;
  flex: 0 0 min(420px, 82vw);
}
.carousel__btn{
  position:absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 42px;
  height: 42px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(10,12,18,.65);
  color: rgba(233,238,246,.95);
  cursor: pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size: 24px;
  z-index: 3;
  backdrop-filter: blur(10px);
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}
.carousel__btn:hover{
  transform: translateY(-50%) scale(1.05);
  border-color: rgba(47,210,255,.26);
  background: rgba(10,12,18,.78);
}
.carousel__btn--prev{left: 10px}
.carousel__btn--next{right: 10px}

.carousel::before, .carousel::after{
  content:"";
  position:absolute;
  top:0; bottom:0;
  width: 58px;
  pointer-events:none;
  z-index:2;
}
.carousel::before{
  left:0;
  background: linear-gradient(to right, rgba(6,8,14,.95), rgba(6,8,14,0));
}
.carousel::after{
  right:0;
  background: linear-gradient(to left, rgba(6,
.carousel .galleryItem{will-change: transform}
.carousel .galleryItem img{will-change: transform}
@media (hover: none), (pointer: coarse){
  .carousel .galleryItem{transition: none}
  .carousel .galleryItem img{transition: none}
}
8,14,.95), rgba(6,8,14,0));
}

.carousel .galleryItem img{height: 240px}
@media (max-width: 900px){
  .carousel__track{padding: 6px 44px 14px}
  .carousel .galleryItem img{height: 220px}
  .carousel__btn{backdrop-filter:none; -webkit-backdrop-filter:none}
}

.structureModal{
  position:fixed;
  inset:0;
  z-index: 160;
  display:block;
}
.structureModal[hidden]{display:none}
.structureModal__backdrop{
  position:absolute;
  inset:0;
  background: rgba(0,0,0,.70);
  backdrop-filter: blur(8px);
}
.structureModal__panel{
  position:absolute;
  left:50%;
  top:50%;
  transform: translate(-50%, -50%);
  width: min(980px, 92vw);
  max-height: min(86vh, 760px);
  overflow: hidden;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(10,12,18,.92);
  box-shadow: 0 30px 120px rgba(0,0,0,.70);
}
.structureModal__close{
  position:absolute;
  top:10px;
  right:10px;
  width:42px;
  height:42px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: rgba(233,238,246,.95);
  cursor:pointer;
  z-index: 2;
}
.structureModal__img{
  width:100%;
  height: min(52vh, 420px);
  object-fit: cover;
  display:block;
  filter: saturate(1.05) contrast(1.05);
}
.structureModal__body{
  padding: 14px 16px 18px;
  overflow:auto;
  max-height: calc(min(86vh, 760px) - min(52vh, 420px));
}
.structureModal__title{
  margin: 0 0 8px;
  font-weight: 1000;
  letter-spacing: .02em;
}
.structureModal__text{
  margin: 0;
  color: rgba(233,238,246,.84);
  line-height: 1.8;
}

.galleryItem figcaption{
  padding: 12px 12px 14px;
}
.galleryItem figcaption strong{
  font-weight: 900;
}
.galleryItem figcaption .muted{
  font-size: 12px;
  opacity: .85;
}

.structureModal__body{
  position: relative;
}
.structureModal__body::before,
.structureModal__body::after{
  content:"";
  position: sticky;
  left:0; right:0;
  height: 18px;
  pointer-events:none;
  display:block;
  z-index: 1;
}
.structureModal__body::before{
  top:0;
  background: linear-gradient(to bottom, rgba(10,12,18,.92), rgba(10,12,18,0));
}
.structureModal__body::after{
  bottom:0;
  background: linear-gradient(to top, rgba(10,12,18,.92), rgba(10,12,18,0));
}

.shopCard__top{display:flex;flex-direction:column;gap:8px}
.shopCard__bottom{margin-top:12px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.shopCard__bottom .price{font-weight:900;letter-spacing:.02em}

.creditGlow{
  position: relative;
  border-radius: 20px;
  padding: 1px;
  overflow: hidden;
  isolation: isolate;
  max-width: 560px;
  margin: 16px auto 0;
}
.creditGlow::before{
  content:"";
  position:absolute;
  inset:-2px;
  background: conic-gradient(
    from 180deg,
    rgba(47,210,255,.0),
    rgba(47,210,255,.85),
    rgba(164,91,255,.85),
    rgba(0,255,213,.85),
    rgba(255,120,200,.75),
    rgba(47,210,255,.85),
    rgba(47,210,255,.0)
  );
  filter: blur(0px);
  opacity: .75;
  animation: creditSpin 6.5s linear infinite;
  z-index: -2;
}
.creditGlow::after{
  content:"";
  position:absolute;
  inset: -18px;
  background:
    radial-gradient(120px 120px at 20% 30%, rgba(47,210,255,.20), transparent 60%),
    radial-gradient(160px 160px at 78% 34%, rgba(164,91,255,.10), transparent 62%),
    radial-gradient(220px 180px at 55% 85%, rgba(0,255,213,.14), transparent 65%);
  filter: blur(10px);
  opacity: .85;
  animation: creditBreath 4.6s ease-in-out infinite;
  z-index: -1;
}
.creditGlow__inner{
  border-radius: 19px;
  padding: 18px 18px 16px;
  background: rgba(10,12,18,.60);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 22px 90px rgba(0,0,0,.55);
  text-align: center;
}
.creditGlow__kicker{
  margin: 0 0 8px;
  font-size: 12px;
  
  letter-spacing: .06em;
  text-transform: none;
  color: rgba(233,238,246,.72);
}
.creditGlow__title{
  margin: 0 0 8px;
  font-weight: 1000;
  letter-spacing: .02em;
}
.creditGlow__text{
  margin: 0;
  color: rgba(233,238,246,.82);
  line-height: 1.7;
}
.creditGlow:hover::before{ opacity: .92; }
.creditGlow:hover .creditGlow__inner{ border-color: rgba(47,210,255,.20); }

@keyframes creditSpin{
  to{ transform: rotate(360deg); }
}
@keyframes creditBreath{
  0%,100%{ transform: translate3d(0,0,0) scale(1); opacity:.75; }
  50%{ transform: translate3d(0,-6px,0) scale(1.02); opacity:.92; }
}

.srOnly{
  position:absolute !important;
  width:1px !important;
  height:1px !important;
  padding:0 !important;
  margin:-1px !important;
  overflow:hidden !important;
  clip:rect(0,0,0,0) !important;
  white-space:nowrap !important;
  border:0 !important;
}

.introOverlay{
  position: fixed;
  inset: 0;
  z-index: 200;
  display: grid;
  place-items: center;
background:
    radial-gradient(900px 600px at 18% 12%, rgba(47,210,255,.22), transparent 60%),
    radial-gradient(860px 560px at 82% 18%, rgba(155,92,255,.22), transparent 60%),
    radial-gradient(820px 560px at 55% 92%, rgba(0,255,213,.10), transparent 62%),
    var(--bg, #050713);
  overflow: hidden;
  cursor: pointer;

  /* entrada super fluida */
  opacity: 0;
  transform: translate3d(0,0,0) scale(1.02);
  transition:
    opacity 920ms cubic-bezier(.22,1,.36,1),
    transform 1250ms cubic-bezier(.22,1,.36,1);
  will-change: opacity, transform;
}

.introOverlay--ready{
  opacity: 1;
  transform: translate3d(0,0,0) scale(1);
}

/* Saída: suave e cinematográfica */
.introOverlay--out{
  opacity: 0;
  transform: translate3d(0,-18px,0) scale(1.01);
  transition:
    opacity var(--intro-out, 1250ms) cubic-bezier(.22,1,.36,1),
    transform var(--intro-out, 1250ms) cubic-bezier(.22,1,.36,1);
  pointer-events: none;
}

/* Camada de “vida” no fundo (sutil): aurora + twinkle + partículas em canvas */
.introOverlay::before{
  content:"";
  position:absolute;
  inset:-35%;
  background:
    radial-gradient(520px 320px at 28% 30%, rgba(60,170,255,.22), transparent 70%),
    radial-gradient(520px 320px at 72% 36%, rgba(170,90,255,.18), transparent 72%),
    radial-gradient(520px 320px at 52% 72%, rgba(0,255,213,.10), transparent 75%);
  opacity: 0;
  filter: blur(78px);
  transform: translate3d(0,0,0);
  z-index: 0;
  pointer-events:none;
}

.introOverlay--ready::before{
  opacity: .55;
  animation: introBgDrift 7.4s ease-in-out infinite alternate;
}

.introOverlay::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(1px 1px at 12% 18%, rgba(255,255,255,.20), transparent 55%),
    radial-gradient(1px 1px at 28% 42%, rgba(120,200,255,.22), transparent 55%),
    radial-gradient(1px 1px at 66% 28%, rgba(255,255,255,.16), transparent 55%),
    radial-gradient(1px 1px at 82% 64%, rgba(210,140,255,.18), transparent 55%),
    radial-gradient(1px 1px at 46% 78%, rgba(255,255,255,.14), transparent 55%);
  opacity: 0;
  filter: blur(.2px);
  mix-blend-mode: screen;
  z-index: 1;
  pointer-events:none;
}

.introOverlay--ready::after{
  opacity: .30;
  animation: introTwinkle 3.6s ease-in-out infinite;
}

@keyframes introBgDrift{
  0%{ transform: translate3d(-1.5%, -1.0%, 0) scale(1); opacity:.48; }
  50%{ opacity:.62; }
  100%{ transform: translate3d(1.5%, 1.0%, 0) scale(1.02); opacity:.58; }
}

@keyframes introTwinkle{
  0%,100%{ opacity: .22; }
  50%{ opacity: .38; }
}

.introOverlay__fx{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  z-index: 1;
  opacity: 0;
  mix-blend-mode: screen;
  pointer-events:none;
  transition: opacity 900ms ease-out;
}

.introOverlay--ready .introOverlay__fx{
  opacity: .72;
}

.introOverlay[hidden]{ display:none; }

.introOverlay__center{
  position: relative;
  z-index: 3;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 18px;
  width: min(720px, 92vw);

  /* entrada do conteúdo */
  opacity: 0;
  transform: translate3d(0,26px,0) scale(.965);
  filter: blur(10px);
  transition:
    opacity 1050ms cubic-bezier(.22,1,.36,1),
    transform 1320ms cubic-bezier(.22,1,.36,1),
    filter 1320ms cubic-bezier(.22,1,.36,1);
}

.introOverlay--ready .introOverlay__center{
  opacity: 1;
  transform: translate3d(0,0,0) scale(1);
  filter: blur(0);
}

.introOverlay--out .introOverlay__center{
  opacity: 0;
  transform: translate3d(0,-10px,0) scale(.985);
  filter: blur(12px);
}

/* Ripple suave ao clicar (dá “wow” sem giro) */
.introOverlay__center::after{
  content:"";
  position:absolute;
  inset:-140px;
  border-radius: 999px;
  background: radial-gradient(circle at 50% 50%, rgba(164,91,255,.22), rgba(47,210,255,.14) 38%, transparent 70%);
  opacity: 0;
  transform: scale(.55);
  filter: blur(2px);
  pointer-events:none;
  z-index: -1;
}

.introOverlay--clicked .introOverlay__center::after{
  animation: introClickRipple 820ms cubic-bezier(.22,1,.36,1) both;
}

@keyframes introClickRipple{
  0%{ opacity: 0; transform: scale(.45); filter: blur(3px); }
  35%{ opacity: .42; }
  100%{ opacity: 0; transform: scale(1.08); filter: blur(6px); }
}

/* ÍCONE */
.introOverlay__iconOuter{
  width: min(420px, 62vw);
  position: relative;
  transform-origin: 50% 50%;
  will-change: transform, filter;
}

/* Halo circular (sem mask-composite -> sem “quadro”) */
.introOverlay__iconOuter::before{
  content:"";
  position:absolute;
  inset:-52px;
  border-radius: 999px;
  background: conic-gradient(from 180deg,
    rgba(47,210,255,0),
    rgba(47,210,255,.95),
    rgba(164,91,255,.85),
    rgba(0,255,213,.65),
    rgba(47,210,255,.95),
    rgba(47,210,255,0)
  );
  opacity: 0;
  filter: blur(1px);
  -webkit-mask-image: radial-gradient(circle, transparent 56%, #000 58%, #000 70%, transparent 72%);
          mask-image: radial-gradient(circle, transparent 56%, #000 58%, #000 70%, transparent 72%);
  pointer-events:none;
}

.introOverlay--ready .introOverlay__iconOuter::before{
  opacity: .86;
  animation: introHaloSpin 2.35s linear infinite, introHaloPulse 1.85s ease-in-out infinite;
}

.introOverlay__iconOuter::after{
  content:"";
  position:absolute;
  inset:-76px;
  border-radius: 999px;
  background: radial-gradient(circle at 50% 55%, rgba(60,170,255,.20), rgba(164,91,255,.12) 45%, transparent 70%);
  opacity: 0;
  filter: blur(18px);
  pointer-events:none;
}

.introOverlay--ready .introOverlay__iconOuter::after{
  opacity: .95;
  animation: introGlowPulse 2.7s ease-in-out infinite;
}

@keyframes introHaloSpin{ to{ transform: rotate(360deg); } }
@keyframes introHaloPulse{
  0%,100%{ filter: blur(1px); opacity:.70; }
  50%{ filter: blur(.6px); opacity: .95; }
}
@keyframes introGlowPulse{
  0%,100%{ transform: scale(1); opacity:.78; }
  50%{ transform: scale(1.03); opacity:.98; }
}

.introOverlay__iconWrap{
  position: relative;
  opacity: 0;
  transform: translate3d(0,16px,0) scale(.90);
  filter: blur(16px) brightness(1.18) saturate(1.25)
          drop-shadow(0 18px 70px rgba(0,0,0,.78))
          drop-shadow(0 0 34px rgba(60,170,255,.28));
  will-change: transform, opacity, filter;
}

.introOverlay--ready .introOverlay__iconWrap{
  animation: introLogoIn 1420ms cubic-bezier(.16,1,.3,1) both;
}

.introOverlay--out .introOverlay__iconWrap{
  animation: introLogoOut var(--intro-out, 1250ms) cubic-bezier(.22,1,.36,1) both;
}

@keyframes introLogoIn{
  0%{
    opacity: 0;
    transform: translate3d(0,24px,0) scale(.86);
    filter: blur(22px) brightness(1.22) saturate(1.35)
            drop-shadow(0 18px 70px rgba(0,0,0,.78))
            drop-shadow(0 0 34px rgba(60,170,255,.20));
  }
  36%{
    opacity: 1;
    transform: translate3d(0,0,0) scale(1.05);
    filter: blur(4px) brightness(1.15) saturate(1.20)
            drop-shadow(0 22px 88px rgba(0,0,0,.80))
            drop-shadow(0 0 46px rgba(60,170,255,.34));
  }
  44%{ transform: translate3d(-3px,-1px,0) scale(1.05) rotate(-.65deg); }
  50%{ transform: translate3d(2px,0,0) scale(1.04) rotate(.55deg); }
  58%{
    transform: translate3d(0,0,0) scale(1.01) rotate(0deg);
    filter: blur(1.6px) brightness(1.06) saturate(1.10)
            drop-shadow(0 20px 82px rgba(0,0,0,.78))
            drop-shadow(0 0 46px rgba(60,170,255,.28));
  }
  100%{
    opacity: 1;
    transform: translate3d(0,0,0) scale(1);
    filter: blur(0) brightness(1) saturate(1)
            drop-shadow(0 18px 70px rgba(0,0,0,.72))
            drop-shadow(0 0 34px rgba(60,170,255,.26));
  }
}

@keyframes introLogoOut{
  0%{
    opacity: 1;
    transform: translate3d(0,0,0) scale(1);
    filter: blur(0) brightness(1) saturate(1)
            drop-shadow(0 18px 70px rgba(0,0,0,.72))
            drop-shadow(0 0 34px rgba(60,170,255,.22));
  }
  100%{
    opacity: 0;
    transform: translate3d(0,-12px,0) scale(.95);
    filter: blur(16px) brightness(.96) saturate(.96)
            drop-shadow(0 10px 40px rgba(0,0,0,.68))
            drop-shadow(0 0 18px rgba(60,170,255,.14));
  }
}

.introOverlay__iconSpin{
  display:block;
  transform: translate3d(0,0,0);
  backface-visibility: hidden;
  transform-origin: 50% 50%;
  will-change: transform;
}

.introOverlay--ready .introOverlay__iconSpin{
  animation: introIconTilt 2.6s ease-in-out infinite;
}

@keyframes introIconTilt{
  0%,100%{ transform: translate3d(0,0,0) rotate(0deg); }
  50%{ transform: translate3d(0,0,0) rotate(-1.2deg); }
}

/* Separa o float do ícone do tilt (evita jitter por composição) */
.introOverlay__iconFloat{
  display:block;
  will-change: transform;
  transform: translate3d(0,0,0);
  backface-visibility: hidden;
  transform-origin: 50% 50%;
  animation: none;
}

.introOverlay--ready .introOverlay__iconFloat{
  animation: introIconFloat 2.45s ease-in-out infinite;
}

.introOverlay__icon{
  width: 100%;
  height: auto;
  display: block;
  backface-visibility: hidden;
  transform: translate3d(0,0,0);
}

@keyframes introIconFloat{
  0%{ transform: translate3d(0,0,0) scale(1); }
  25%{ transform: translate3d(0,-6px,0) scale(1.008); }
  55%{ transform: translate3d(0,-3px,0) scale(1.006); }
  80%{ transform: translate3d(0,-5px,0) scale(1.009); }
  100%{ transform: translate3d(0,0,0) scale(1); }
}

/* Clique: pulse + brilho */
.introOverlay__iconOuter.is-pulsing{
  animation: introIconPulse 700ms cubic-bezier(.22,1,.36,1) both;
}

@keyframes introIconPulse{
  0%{ transform: scale(1); }
  30%{ transform: scale(1.065); }
  100%{ transform: scale(1); }
}

.introOverlay--clicked .introOverlay__iconOuter::before{
  animation-duration: 1.1s, .85s;
  opacity: 1;
}
.introOverlay--clicked .introOverlay__iconOuter::after{
  opacity: 1;
  transform: scale(1.05);
}
.introOverlay--clicked .introOverlay__iconWrap{
  filter: blur(0) brightness(1.02) saturate(1.05)
          drop-shadow(0 26px 95px rgba(0,0,0,.88))
          drop-shadow(0 0 52px rgba(80,190,255,.50));
}

/* BARRA */
.introOverlay__loadBar{
  position: relative;
  width: min(620px, 84vw);
  height: 11px;
  border-radius: 999px;
  background: rgba(0,0,0,.30);
  border: 1px solid rgba(47,210,255,.22);
  overflow: hidden;
  pointer-events: none;
  box-shadow: 0 0 0 1px rgba(164,91,255,.12) inset, 0 18px 70px rgba(0,0,0,.55), 0 0 34px rgba(47,210,255,.20), 0 0 48px rgba(164,91,255,.14);
  will-change: transform, opacity, box-shadow;
  opacity: 0;
  transform: translate3d(0,10px,0);
  transition:
    opacity 1050ms cubic-bezier(.22,1,.36,1),
    transform 1200ms cubic-bezier(.22,1,.36,1),
    box-shadow 1200ms cubic-bezier(.22,1,.36,1);
}

.introOverlay--ready .introOverlay__loadBar{
  opacity: 1;
  transform: translate3d(0,0,0);
  animation: introBarPulse 1.35s ease-in-out infinite;
}

.introOverlay--out .introOverlay__loadBar{
  opacity: 0;
  transform: translate3d(0,14px,0) scale(.985);
}

.introOverlay__loadBar::before{
  content:"";
  position:absolute;
  inset:-18px;
  background: radial-gradient(220px 60px at 50% 50%, rgba(60,170,255,.18), transparent 70%);
  filter: blur(12px);
  opacity: .85;
  animation: introBarGlow 1.8s ease-in-out infinite;
  pointer-events:none;
}

.introOverlay__loadBar::after{
  content:"";
  position:absolute;
  inset:0;

  /* Neon + faixas em movimento (mais “vida”) */
  background-image:
    linear-gradient(90deg, rgba(47,210,255,.18), rgba(164,91,255,.18), rgba(47,210,255,.18)),
    repeating-linear-gradient(135deg,
      rgba(255,255,255,.12) 0 10px,
      rgba(255,255,255,0) 10px 22px
    );
  background-size: 220% 100%, 44px 100%;
  background-position: 0 0, 0 0;

  opacity: .60;
  mix-blend-mode: screen;
  filter: blur(.18px);
  animation:
    introBarNeon 2.2s ease-in-out infinite,
    introBarStripes .85s linear infinite;
  pointer-events:none;
}

@keyframes introBarNeon{
  0%,100%{ opacity: .42; }
  50%{ opacity: .78; }
}

@keyframes introBarStripes{
  from{ background-position: 0 0, 0 0; }
  to{ background-position: 0 0, 88px 0; }
}

@keyframes introBarPulse{
  0%,100%{ filter: drop-shadow(0 0 10px rgba(47,210,255,.18)); }
  50%{ filter: drop-shadow(0 0 18px rgba(164,91,255,.22)); }
}

@keyframes introBarGlow{
  0%,100%{ opacity: .55; transform: scale(1); }
  50%{ opacity: .95; transform: scale(1.03); }
}

.introOverlay__loadFill{
  height: 100%;
  width: 0%;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(60,170,255,.95), rgba(190,90,255,.78), rgba(60,170,255,.90));
  background-size: 220% 100%;
  box-shadow: 0 0 18px rgba(47,210,255,.65), 0 0 44px rgba(164,91,255,.28);
  filter: saturate(1.08) brightness(1.02);
  animation: introFill var(--intro-duration, 5200ms) cubic-bezier(.2,0,.15,1) both, introFillShift .55s linear infinite, introFillPulse 1.25s ease-in-out infinite;
  position: relative;
  overflow: hidden;
}

@keyframes introFillShift{ to{ background-position: 220% 0; } }
@keyframes introFillPulse{
  0%,100%{ filter: saturate(1.06) brightness(1.02); }
  50%{ filter: saturate(1.22) brightness(1.10); }
}

@keyframes introFill{ to{ width: 100%; } }

.introOverlay__loadFill::before{
  content:"";
  position:absolute;
  right:-22px;
  top:-18px;
  width: 56px;
  height: 56px;
  border-radius: 999px;
  background: radial-gradient(circle at 35% 35%,
    rgba(255,255,255,.28),
    rgba(60,170,255,.42) 38%,
    rgba(164,91,255,.30) 62%,
    transparent 72%
  );
  mix-blend-mode: screen;
  filter: blur(1.2px);
  opacity: .92;
  animation: introEdgeSpark .85s ease-in-out infinite;
  pointer-events:none;
}

@keyframes introEdgeSpark{
  0%,100%{ transform: scale(.88); opacity: .70; }
  50%{ transform: scale(1.10); opacity: 1; }
}

.introOverlay__loadFill::after{
  content:"";
  position:absolute;
  top: -6px;
  bottom: -6px;
  left: -40%;
  width: 45%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.22), transparent);
  transform: skewX(-18deg);
  animation: introBarShine .78s ease-in-out infinite;
  opacity: .55;
}

@keyframes introBarShine{
  0%{ left:-40%; }
  60%{ left:120%; }
  100%{ left:120%; }
}

/* O site “nasce” por baixo (super fluido) */
body.hasIntro .topstrip,
body.hasIntro .mast,
body.hasIntro main,
body.hasIntro footer{
  opacity: 0;
  transform: translate3d(0,14px,0) scale(1.01);
  filter: blur(14px);
  transition:
    opacity 1050ms cubic-bezier(.22,1,.36,1),
    transform 1100ms cubic-bezier(.22,1,.36,1),
    filter 1100ms cubic-bezier(.22,1,.36,1);
}

body.hasIntro.introReveal .topstrip,
body.hasIntro.introReveal .mast,
body.hasIntro.introReveal main,
body.hasIntro.introReveal footer{
  opacity: 1;
  transform: translate3d(0,0,0) scale(1);
  filter: blur(0);
}

body.hasIntro{ overflow: auto; }

@media (prefers-reduced-motion: reduce){
  .introOverlay{ transition: none; opacity: 1; transform:none; }
  .introOverlay::before, .introOverlay::after{ animation:none; opacity: 0; }
  .introOverlay__fx{ display:none; }
  .introOverlay__center{ transition:none; opacity:1; transform:none; filter:none; }
  .introOverlay__iconOuter::before,
  .introOverlay__iconOuter::after,
  .introOverlay__iconWrap::before,
  .introOverlay__iconWrap::after{
    content: none !important;
    display: none !important;
    animation: none !important;
    opacity: 0 !important;
    background: none !important;
    filter: none !important;
    transform: none !important;
  }

  .introOverlay__icon{ animation:none; }
  .introOverlay__loadBar{ transition:none; opacity:1; transform:none; }
  .introOverlay__loadFill{ animation:none; width: 100%; }
  body.hasIntro .topstrip,
  body.hasIntro .mast,
  body.hasIntro main,
  body.hasIntro footer{
    transition:none;
    opacity: 1;
    transform:none;
    filter:none;
  }
}

body.introReveal .topstrip,
body.introReveal header,
body.introReveal nav,
body.introReveal main,
body.introReveal footer{
  animation: introContentIn 900ms cubic-bezier(.22,1,.36,1) both;
}

@keyframes introContentIn{
  from{ opacity: 0; transform: translate3d(0, 14px, 0); filter: blur(4px); }
  to{ opacity: 1; transform: none; filter: blur(0); }
}


.socialPanel{
  margin-top: -14px;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  box-shadow: 0 22px 90px rgba(0,0,0,.45);
  overflow: hidden;
  position: relative;
  max-width: 760px;
}
.socialPanel::before{
  content:"";
  position:absolute;
  inset:-2px;
  background:
    radial-gradient(520px 260px at 30% 0%, rgba(47,210,255,.14), transparent 70%),
    radial-gradient(520px 260px at 70% 0%, rgba(164,91,255,.12), transparent 70%);
  opacity:.92;
  pointer-events:none;
}
.socialPanel__title{
  padding: 14px 18px;
  font-weight: 1000;
  letter-spacing: .14em;
  text-transform: uppercase;
  text-align: center;
  background: rgba(0,0,0,.20);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.socialGrid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  padding: 22px 20px 18px;
  place-items: center;
}
.socialIcon{
  width: 70px;
  height: 70px;
  border-radius: 999px;
  display:grid;
  place-items:center;
  position:relative;
  background: rgba(0,0,0,.35);
  border: 1px solid rgba(255,255,255,.10);
  transform: translate3d(0,0,0);
  transition: transform .22s ease, filter .22s ease, box-shadow .22s ease;
  overflow: hidden;
  -webkit-tap-highlight-color: transparent;
}
.socialSvg{
  width: 34px;
  height: 34px;
  opacity: .95;
  color: rgba(233,238,246,.95);
  filter: drop-shadow(0 12px 22px rgba(0,0,0,.55));
  transition: transform .22s ease, filter .22s ease;
}
.socialIcon__ring{
  position:absolute;
  inset:-2px;
  border-radius: 999px;
  background: conic-gradient(from 180deg, rgba(47,210,255,0), rgba(47,210,255,.95), rgba(164,91,255,.80), rgba(0,255,213,.80), rgba(255,120,200,.60), rgba(47,210,255,.95), rgba(47,210,255,0));
  opacity: .0;
  filter: blur(.2px);
  transition: opacity .22s ease;
}
.socialIcon__shine{
  position:absolute;
  inset:0;
  background: radial-gradient(120px 120px at 28% 28%, rgba(255,255,255,.14), transparent 55%);
  opacity:.0;
  transition: opacity .22s ease;
}
.socialIcon::after{
  content:"";
  position:absolute;
  inset:-20px;
  background:
    radial-gradient(80px 80px at 50% 55%, rgba(47,210,255,.10), transparent 65%);
  opacity:0;
  filter: blur(10px);
  transition: opacity .22s ease;
}
.socialIcon:hover{
  transform: translate3d(0,-7px,0) scale(1.05);
  box-shadow: 0 18px 60px rgba(0,0,0,.55);
}
.socialIcon:hover .socialIcon__ring{ opacity: .95; }
.socialIcon:hover .socialIcon__shine{ opacity: 1; }
.socialIcon:hover::after{ opacity: 1; }
.socialIcon:hover .socialSvg{
  transform: scale(1.06) rotate(-2deg);
  filter: drop-shadow(0 16px 28px rgba(0,0,0,.65));
}
.socialIcon--center{
  grid-column: 2 / span 2;
  width: 78px;
  height: 78px;
  margin-top: 2px;
}
.socialHint{
  padding: 0 18px 16px;
  text-align:center;
}

.socialIcon--discord{ box-shadow: 0 0 0 1px rgba(88,101,242,.16) inset; }
.socialIcon--tiktok{ box-shadow: 0 0 0 1px rgba(0,242,234,.14) inset; }
.socialIcon--youtube{ box-shadow: 0 0 0 1px rgba(255,0,0,.14) inset; }
.socialIcon--instagram{ box-shadow: 0 0 0 1px rgba(255,120,200,.14) inset; }
.socialIcon--twitch{ box-shadow: 0 0 0 1px rgba(145,70,255,.14) inset; }

@media (max-width: 640px){
  .socialGrid{ grid-template-columns: repeat(2, 1fr); }
  .socialIcon--center{ grid-column: 1 / span 2; }
}

.hero__right{justify-items:end}
.socialPanel--hero{
  margin-top: 0;
  max-width: 420px;
  width: 100%;
}
.socialPanel--hero .socialGrid{
  padding: 18px 18px 14px;
}
.socialPanel--hero .socialPanel__title{
  letter-spacing: .18em;
}
@media (max-width: 980px){
  .hero__right{justify-items:stretch}
  .socialPanel--hero{max-width:none}
}

.socialPanel--hero{
  height: 100%;
  display: flex;
  flex-direction: column;
  border-radius: 20px; 
}

.socialPanel--hero .socialPanel__title{
  padding: 16px 18px;
}

.socialPanel--hero .socialGrid{
  flex: 1;
  padding: 22px 20px;
  place-content: center;
}

.socialPanel--hero .socialHint{
  margin-top: auto;
  padding: 0 18px 18px;
}

.brand__logo{
  cursor: pointer;
  transition: transform .18s ease, filter .18s ease;
  -webkit-tap-highlight-color: transparent;
}

.brand__logo.is-pop{
  animation: serpensBrandPop .90s cubic-bezier(.16,1,.3,1) both;
  filter: drop-shadow(0 10px 30px rgba(47,210,255,.35)) drop-shadow(0 14px 44px rgba(164,91,255,.25));
}

@keyframes serpensBrandPop{
  0%   { transform: translate3d(0,0,0) scale(1) rotate(0deg); }
  18%  { transform: translate3d(0,-2px,0) scale(1.13) rotate(-2.5deg); }
  40%  { transform: translate3d(0,0,0) scale(.98) rotate(1.2deg); }
  65%  { transform: translate3d(0,-1px,0) scale(1.05) rotate(-.6deg); }
  100% { transform: translate3d(0,0,0) scale(1) rotate(0deg); }
}

.socialPanel--hero{
  height: auto; 
}

.hero__inner{ align-items: stretch; }
.hero__right{ align-self: stretch; }

.hero__inner{ align-items: flex-start; } 
.hero__right{ align-self: flex-start; }
.socialPanel--hero{ height: auto; margin-top: 0; }

.staffGrid{
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 16px;
  margin-top: 14px;
}
.staffCard{
  grid-column: span 12;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  padding: 16px 16px 14px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 18px 60px rgba(0,0,0,.42);
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.staffCard::before{
  content:"";
  position:absolute;
  inset:-2px;
  background:
    radial-gradient(520px 240px at 20% 0%, rgba(47,210,255,.14), transparent 65%),
    radial-gradient(520px 240px at 80% 0%, rgba(164,91,255,.12), transparent 65%);
  opacity: .85;
  pointer-events:none;
}
.staffCard::after{
  content:"";
  position:absolute;
  inset:0;
  background: radial-gradient(260px 180px at 30% 30%, rgba(255,255,255,.06), transparent 60%);
  opacity: 0;
  transition: opacity .22s ease;
  pointer-events:none;
}
.staffCard:hover{
  transform: translate3d(0,-5px,0);
  border-color: rgba(255,255,255,.18);
  box-shadow: 0 26px 82px rgba(0,0,0,.55);
}
.staffCard:hover::after{ opacity: 1; }

.staffCard__rank{
  font-weight: 1000;
  letter-spacing: .14em;
  text-transform: uppercase;
  font-size: 11px;
  opacity: .9;
}
.staffCard__title{
  font-weight: 950;
  margin-top: 6px;
  font-size: 18px;
}
.staffCard__desc{
  margin-top: 8px;
  opacity: .9;
  line-height: 1.55;
  max-width: 62ch;
}

@media (min-width: 860px){
  .staffCard{ grid-column: span 6; }
  .staffCard--owner{ grid-column: span 12; }
}

@media (min-width: 1180px){
  .staffGrid{ gap: 18px; }
  .staffCard{ padding: 18px 18px 16px; border-radius: 20px; }
}

.roster{
  margin-top: 8px;
  display: grid;
  gap: 16px;
}

.rosterGroup{
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  box-shadow: 0 18px 60px rgba(0,0,0,.42);
  position: relative;
}

.rosterGroup::before{
  content:"";
  position:absolute;
  inset:-2px;
  background:
    radial-gradient(520px 240px at 20% 0%, rgba(47,210,255,.12), transparent 65%),
    radial-gradient(520px 240px at 80% 0%, rgba(164,91,255,.10), transparent 65%);
  opacity: .9;
  pointer-events:none;
}

.rosterGroup__bar,
.rosterGroup__members{ position: relative; z-index: 1; }

.rosterGroup__bar{
  padding: 12px 16px;
  font-weight: 1000;
  letter-spacing: .06em;
  text-transform: uppercase;
  font-size: 13px;
  border-bottom: 1px solid rgba(0,0,0,.22);
}

.rosterGroup__members{
  padding: 16px;
  display: flex;
  flex-wrap: wrap;
  gap: 20px 26px;
  align-items: flex-start;
}

.member{
  width: 92px;
  display:flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  text-align: center;
}

.member__avatar{
  width: 64px;
  height: 64px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.18);
  box-shadow: 0 14px 44px rgba(0,0,0,.45);
  image-rendering: pixelated;
}

.member__avatar--hidden{ display:none !important; }

.member__name{
  font-weight: 900;
  font-size: 14px;
  letter-spacing: .02em;
  opacity: .95;
}

.rosterGroup--owner .rosterGroup__bar{
  background: linear-gradient(90deg, rgba(255,255,255,.92), rgba(214,214,214,.92));
  color: rgba(12,12,14,.98);
}
.rosterGroup--director .rosterGroup__bar{
  background: linear-gradient(90deg, rgba(16,38,88,.96), rgba(10,18,42,.96));
}
.rosterGroup--admin .rosterGroup__bar{
  background: linear-gradient(90deg, rgba(225,34,34,.94), rgba(140,0,0,.94));
}
.rosterGroup--mod .rosterGroup__bar{
  background: linear-gradient(90deg, rgba(255,150,40,.94), rgba(255,82,20,.94));
}
.rosterGroup--helper .rosterGroup__bar{
  background: linear-gradient(90deg, rgba(255,230,80,.94), rgba(255,168,20,.94)) !important;
  color: rgba(12,12,14,.98) !important;
}

.rosterGroup--helper .rosterGroup__members{
  /* mantém a caixa com a mesma presença visual das demais, mesmo vazia */
  min-height: 110px;
}

@media (min-width: 860px){
  .roster{ gap: 18px; }
  .rosterGroup__members{ padding: 18px; }
  .member__avatar{ width: 66px; height: 66px; }
}

@media (max-width: 420px){
  .member{ width: 84px; }
  .member__avatar{ width: 60px; height: 60px; }
}

.note--compact{padding:14px 16px; border-radius:16px}

.main--padtop{ padding-top: -14px; }
@media (min-width: 981px){
  .main--padtop{ padding-top: 14px; }
}

40%{ filter: drop-shadow(0 0 22px rgba(80,170,255,.55)) drop-shadow(0 0 38px rgba(190,90,255,.35)); transform: scale(1.02); }
  100%{ filter: drop-shadow(0 0 18px rgba(80,170,255,.42)) drop-shadow(0 0 32px rgba(190,90,255,.26)); transform: scale(1); }
}

50%{ opacity:1; transform: scale(1.07); }
  100%{ opacity:.72; transform: scale(1); }
}

#home, section#home, [data-section="home"]{
  position: relative;
}
#home::before,
section#home::before,
[data-section="home"]::before{
  content:"";
  position:absolute;
  inset: -2px;
  background-image: url("../assets/home_alt.webp");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  filter: saturate(1.05) contrast(1.05);
  opacity: .42;
  pointer-events:none;
  z-index: 0;
}
#home::after,
section#home::after,
[data-section="home"]::after{
  content:"";
  position:absolute;
  inset: -2px;
  background: radial-gradient(900px 520px at 30% 30%, rgba(65,160,255,.18), rgba(0,0,0,.82) 60%, rgba(0,0,0,.92));
  pointer-events:none;
  z-index: 0;
}
#home > * ,
section#home > *,
[data-section="home"] > *{
  position: relative;
  z-index: 1;
}

.serpensCorpWordmark{
  display: inline-flex;
  gap: .18em;
  align-items: baseline;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: clamp(12px, 1.6vw, 16px);
  color: rgba(235,245,255,.92);
  padding: 8px 14px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.20);
  backdrop-filter: blur(8px);
  box-shadow: 0 18px 55px rgba(0,0,0,.35);
}
.serpensCorpWordmark .brandCorp{
  color: rgba(120,210,255,1);
  text-shadow: 0 0 18px rgba(80,180,255,.55);
}

.siteTagline, .brandTagline, .heroTagline, .navTagline, .headerTagline, .tagline{
  max-width: 44ch;
}

#regras .rulesSideWrap{
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 28px;
  align-items: start;
}
#regras .rulesMascot{
  position: sticky;
  top: 110px;
  height: fit-content;
  align-self: start;
  justify-self: end;
  width: 320px;
  pointer-events: none;
  opacity: .98;
  z-index: 1;
}
#regras .rulesMascot::before{
  content:"";
  position:absolute;
  inset:-18px -18px -18px -64px;
  border-radius: 26px;
  background:
    radial-gradient(260px 360px at 70% 25%, rgba(80,180,255,.22), rgba(0,0,0,0) 68%),
    radial-gradient(280px 420px at 55% 65%, rgba(155,92,255,.16), rgba(0,0,0,0) 72%),
    linear-gradient(90deg, rgba(31,212,255,.0), rgba(31,212,255,.10));
  opacity: .85;
  z-index: -1;
  border: 1px solid rgba(255,255,255,.08);
  backdrop-filter: blur(8px);
  box-shadow: 0 22px 65px rgba(0,0,0,.45);
}
#regras .rulesMascot::after{
  content:"";
  position:absolute;
  left:-22px;
  top: 46%;
  width: 14px;
  height: 14px;
  border-radius: 999px;
  border: 2px solid rgba(31,212,255,.55);
  background: rgba(31,212,255,.18);
  box-shadow: 0 0 0 0 rgba(31,212,255,.0);
  animation: rulesPointerPulse 1.7s ease-out infinite;
}
#regras .rulesMascot img{
  width: 220px;
  max-width: 100%;
  height: auto;
  display: block;
  margin-left: auto;
  image-rendering: pixelated;
  transform-origin: 70% 12%;
  transform: rotate(-14deg) translateX(84px) translateY(6px);
  filter: drop-shadow(0 30px 70px rgba(0,0,0,.55)) drop-shadow(0 0 20px rgba(90,180,255,.22));
  border-radius: 18px;
  background: radial-gradient(220px 260px at 55% 30%, rgba(80,180,255,.10), rgba(0,0,0,.18) 60%, rgba(0,0,0,0) 100%);
  animation: rulesMascotFloat 3.8s ease-in-out infinite;
}
#regras .rulesMascot img::selection{ background: transparent; }

#regras .rulesMascot__badge{
  position:absolute;
  right: 10px;
  top: 8px;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(31,212,255,.35);
  background: rgba(0,0,0,.35);
  backdrop-filter: blur(10px);
  font-weight: 900;
  letter-spacing: .08em;
  font-size: 11px;
  color: rgba(210,240,255,.92);
  text-shadow: 0 0 12px rgba(80,180,255,.35);
  transform: rotate(-8deg);
  box-shadow: 0 14px 40px rgba(0,0,0,.35);
}

@keyframes rulesMascotFloat{
  0%{transform: rotate(-14deg) translateX(84px) translateY(6px)}
  50%{transform: rotate(-12.5deg) translateX(84px) translateY(-6px)}
  100%{transform: rotate(-14deg) translateX(84px) translateY(6px)}
}
@keyframes rulesPointerPulse{
  0%{box-shadow: 0 0 0 0 rgba(31,212,255,.0); opacity: .95; transform: translateX(0)}
  60%{box-shadow: 0 0 0 18px rgba(31,212,255,.0); opacity: .55; transform: translateX(-4px)}
  100%{box-shadow: 0 0 0 28px rgba(31,212,255,.0); opacity: 0; transform: translateX(-6px)}
}

@media (prefers-reduced-motion: reduce){
  #regras .rulesMascot img,
  #regras .rulesMascot::after{
    animation: none !important;
  }
}

@media (max-width: 980px){
  #regras .rulesSideWrap{ grid-template-columns: 1fr; }
  #regras .rulesMascot{ display: none; }
}

@keyframes panelAura{
  0%{transform: translate3d(-1.6%, -0.8%, 0) scale(1.02)}
  100%{transform: translate3d(1.6%, 0.9%, 0) scale(1.06)}
}
@keyframes panelLine{
  0%{background-position: 0% 50%}
  50%{background-position: 100% 50%}
  100%{background-position: 0% 50%}
}

.slider,
.socialPanel,
.ruleCard,
.aboutCard{
  position:relative;
  isolation:isolate;
}

.slider::before,
.socialPanel::before,
.ruleCard::before,
.aboutCard::before{
  content:"";
  position:absolute;
  inset:-120px -90px -70px -90px;
  border-radius: inherit;
  pointer-events:none;
  z-index:0;
  background:
    radial-gradient(520px 240px at 18% 18%, rgba(47,210,255,.22), transparent 62%),
    radial-gradient(560px 260px at 78% 32%, rgba(155,92,255,.16), transparent 64%),
    radial-gradient(620px 300px at 55% 92%, rgba(255,59,59,.12), transparent 66%),
    radial-gradient(520px 260px at 26% 88%, rgba(0,255,213,.08), transparent 66%),
    linear-gradient(135deg, rgba(47,210,255,.10), rgba(155,92,255,.08), rgba(255,59,59,.08));
  filter: blur(26px) saturate(1.35);
  opacity:.72;
  animation: panelAura 14s ease-in-out infinite alternate;
}

.slider::after,
.socialPanel::after,
.ruleCard::after,
.aboutCard::after{
  content:"";
  position:absolute;
  left:-40%;
  right:-40%;
  bottom:0;
  height:2px;
  pointer-events:none;
  z-index:1;
  background:
    linear-gradient(90deg,
      rgba(47,210,255,0),
      rgba(47,210,255,.85),
      rgba(155,92,255,.80),
      rgba(255,59,59,.78),
      rgba(47,210,255,.85),
      rgba(47,210,255,0)
    );
  background-size: 220% 100%;
  filter: drop-shadow(0 0 18px rgba(47,210,255,.22));
  opacity:.90;
  animation: panelLine 9.5s ease-in-out infinite;
}

.slider > *,
.socialPanel > *,
.ruleCard > *,
.aboutCard > *{
  position:relative;
  z-index:2;
}

.aboutHydra{
  position:absolute;
  top: -14px;
  right: -24px;
  width: min(520px, 46vw);
  height: min(420px, 38vw);
  background: url("../assets/hydra_about.png") center/contain no-repeat;
  opacity: .46;
  pointer-events:none;
  z-index:1;
  filter: saturate(1.06) contrast(1.06) drop-shadow(0 18px 70px rgba(47,210,255,.16));
  transform: rotate(2deg);
  -webkit-mask-image: radial-gradient(closest-side at 55% 45%, rgba(0,0,0,1) 0%, rgba(0,0,0,1) 62%, rgba(0,0,0,0) 86%);
  mask-image: radial-gradient(closest-side at 55% 45%, rgba(0,0,0,1) 0%, rgba(0,0,0,1) 62%, rgba(0,0,0,0) 86%);
  animation: aboutHydraFloat 7.5s ease-in-out infinite alternate;
}

@keyframes aboutHydraFloat{
  from{ transform: translate3d(0,0,0) rotate(1.2deg) scale(1); }
  to{ transform: translate3d(0,-10px,0) rotate(2.8deg) scale(1.02); }
}

@media (max-width: 980px){
  .aboutHydra{ display:none; }
}

@media (prefers-reduced-motion: reduce){
  .aboutHydra{ animation: none !important; }
}

.slider::before{ opacity:.65; }
.socialPanel::before{ opacity:.78; }
.ruleCard::before{ opacity:.70; }

.slider::after{ opacity:.82; }

@media (prefers-reduced-motion: reduce){
  .slider::before,
  .socialPanel::before,
  .ruleCard::before,
  .slider::after,
  .socialPanel::after,
  .ruleCard::after{
    animation: none !important;
  }
}

@media (max-width: 720px){
  .footer__bottom{justify-content:center; text-align:center}
  .footer__bottomLinks{justify-content:center}
}

.pageHero__tools::before{
  content:"";
  position:absolute;
  inset:-110px -90px -70px -90px;
  border-radius: inherit;
  pointer-events:none;
  z-index:0;
  background:
    radial-gradient(520px 240px at 18% 18%, rgba(47,210,255,.22), transparent 62%),
    radial-gradient(560px 260px at 78% 32%, rgba(155,92,255,.16), transparent 64%),
    radial-gradient(620px 300px at 55% 92%, rgba(255,59,59,.12), transparent 66%),
    radial-gradient(520px 260px at 26% 88%, rgba(0,255,213,.08), transparent 66%),
    linear-gradient(135deg, rgba(47,210,255,.10), rgba(155,92,255,.08), rgba(255,59,59,.08));
  filter: blur(28px) saturate(1.35);
  opacity:.60;
  animation: panelAura 14s ease-in-out infinite alternate;
}
.pageHero__tools::after{
  content:"";
  position:absolute;
  left:-40%;
  right:-40%;
  bottom:0;
  height:2px;
  pointer-events:none;
  z-index:1;
  background:
    linear-gradient(90deg,
      rgba(47,210,255,0),
      rgba(47,210,255,.85),
      rgba(155,92,255,.80),
      rgba(255,59,59,.78),
      rgba(47,210,255,.85),
      rgba(47,210,255,0)
    );
  background-size: 220% 100%;
  filter: drop-shadow(0 0 18px rgba(47,210,255,.22));
  opacity:.80;
  animation: panelLine 9.5s ease-in-out infinite;
}
.pageHero__tools > *{position:relative; z-index:2}

.updates--timeline{isolation:isolate}
.updates--timeline::after{
  content:"";
  position:absolute;
  inset:-160px -120px -120px -120px;
  border-radius: 28px;
  pointer-events:none;
  z-index: -1;
  background:
    radial-gradient(760px 320px at 14% 20%, rgba(47,210,255,.16), transparent 64%),
    radial-gradient(760px 340px at 86% 34%, rgba(155,92,255,.14), transparent 66%),
    radial-gradient(860px 420px at 54% 94%, rgba(255,59,59,.10), transparent 70%);
  filter: blur(40px) saturate(1.25);
  opacity:.38;
  animation: panelAura 16s ease-in-out infinite alternate;
}

.updates--timeline .updateCard{z-index:1}

.updates--timeline::before{
  background-size: 100% 240%;
  animation: updatesSpine 7.8s ease-in-out infinite;
}
@keyframes updatesSpine{
  0%{background-position: 50% 0%}
  50%{background-position: 50% 100%}
  100%{background-position: 50% 0%}
}

@media (prefers-reduced-motion: reduce){
  .pageHero__tools::before,
  .pageHero__tools::after,
  .updates--timeline::before,
  .updates--timeline::after{animation:none !important}
  .chip::before{transition:none}
}

.cartRow__left{display:flex; flex-direction:column; gap:6px; min-width:0}

.cartRow__stepper{display:inline-flex; align-items:center; gap:8px}
.cartRow__qtyBadge{
  min-width:34px;
  height:34px;
  padding:0 10px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:1000;
  font-size:13px;
}
.cartRow__subtotal{opacity:.85; font-size:12px}

/* Toast simples (ex.: "EM BREVE") */
.toast{
  position: fixed;
  left: 50%;
  top: 18px;
  transform: translate(-50%, -10px);
  z-index: 9999;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(10,10,14,.92);
  box-shadow: 0 18px 50px rgba(0,0,0,.55);
  color: #fff;
  font-weight: 1000;
  letter-spacing: .08em;
  text-transform: uppercase;
  opacity: 0;
  pointer-events: none;
  transition: opacity .18s ease, transform .18s ease;
  backdrop-filter: blur(10px);
}
.toast.is-show{
  opacity: 1;
  transform: translate(-50%, 0);
}

.btn.is-soon{
  opacity: .88;
}
.btn.is-soon:hover{
  opacity: 1;
}





@keyframes introBarBob{
  0%,100%{ transform: translate3d(0,0,0); }
  50%{ transform: translate3d(0,4px,0); }
}


/* ===== VIP adjustments (v50) ===== */

/* Force VIP titles to stay clean/white (no gradient/rainbow). */
.vipTitle, .vipHeroTitle{
  background: none !important;
  -webkit-background-clip: initial !important;
  background-clip: initial !important;
  color: rgba(255,255,255,.98) !important;
  -webkit-text-fill-color: rgba(255,255,255,.98) !important;
  text-shadow: 0 10px 28px rgba(0,0,0,.55);
}

/* Keep kit images consistent */
.vipDetail__img{
  width: 100%;
  display: block;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.20);
  box-shadow: 0 18px 55px rgba(0,0,0,.45);
}
.vipDetail__kitPanel .vipDetail__img + .vipDetail__img{
  margin-top: 12px;
}

/* Text block aesthetics like the reference */
.vipTextBlock{
  margin-top: 10px;
  padding: 10px 0 4px;
}
.vipTextHeading{
  font-weight: 1000;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: rgba(0, 209, 255, .92);
  margin: 8px 0 8px;
}
.vipTextList{
  list-style: none;
  padding: 0;
  margin: 0 0 12px;
}
.vipTextList li{
  position: relative;
  padding-left: 16px;
  margin: 6px 0;
  color: rgba(255,255,255,.88);
  line-height: 1.35;
}
.vipTextList li::before{
  content: "-";
  position: absolute;
  left: 0;
  top: 0;
  color: rgba(255,255,255,.65);
}
.vipTextList code{
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-weight: 1000;
  letter-spacing: .02em;
  padding: 1px 6px;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.22);
  color: rgba(255,255,255,.96);
}

/* Footer info cards (Entrega / Pagamentos) */
.vipFooterInfo{
  margin-top: 18px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  max-width: 980px;
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 900px){
  .vipFooterInfo{ grid-template-columns: 1fr; }
}
.vipInfoCard{
  display: flex;
  gap: 12px;
  padding: 18px 18px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(10,10,14,.52);
  box-shadow: 0 18px 55px rgba(0,0,0,.38);
  backdrop-filter: blur(10px);
}
.vipInfoIcon{
  width: 36px;
  height: 36px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.25);
  display: grid;
  place-items: center;
  color: rgba(0, 209, 255, .9);
  flex: 0 0 auto;
}
.vipInfoTitle{
  font-weight: 1000;
  color: rgba(255,255,255,.96);
  letter-spacing: .02em;
}
.vipInfoText{
  margin-top: 4px;
  color: rgba(255,255,255,.72);
  font-size: 13px;
}
.vipInfoBadges{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 10px;
}
.chip{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.22);
  color: rgba(255,255,255,.88);
  font-weight: 900;
  letter-spacing: .04em;
  text-transform: uppercase;
  font-size: 12px;
}

/* VIP footer alignment (center logo + a clean "Voltar ao topo" bar) */
.foot--vip .foot__inner{
  align-items: center;
  text-align: center;
  justify-content: center;
  gap: 12px;
}
.foot--vip .foot__left{
  margin: 0 auto;
}
.foot--vip .brandMini{
  justify-content: center;
}
.foot--vip .foot__right{
  width: 100%;
  display: flex;
  justify-content: center;
}
.backTopBar{
  display: block;
  width: min(520px, 100%);
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.20);
  color: rgba(255,255,255,.86);
  text-decoration: none;
  font-weight: 1000;
  letter-spacing: .06em;
  text-transform: uppercase;
  transition: transform .15s ease, opacity .15s ease, border-color .15s ease;
}
.backTopBar:hover{
  transform: translateY(-1px);
  opacity: 1;
  border-color: rgba(255,255,255,.22);
}

/* Ensure the VIP detail pages don't show the store nav if any leftover */
.page-vipdetail .mast,
.page-vipdetail .nav,
.page-vipdetail .drawerToggle{
  display: none !important;
}

/* Cart button inside VIP detail hero */
.page-vipdetail .cartbtn{ margin-left: 0; }

/* --- Kit hover tooltips (VIP details) --- */
.kitWrap{
  position: relative;
  display: block;
  width: 100%;
}

.kitGrid{
  position: absolute;
  /* default insets tuned for the current kit screenshots */
  left: var(--kitInsetL, 1.15%);
  right: var(--kitInsetR, 1.15%);
  top: var(--kitInsetT, 15.2%);
  bottom: var(--kitInsetB, 20.9%);
  display: grid;
  grid-template-columns: repeat(var(--kitCols, 9), 1fr);
  grid-template-rows: repeat(var(--kitRows, 3), 1fr);
  gap: 0;
  pointer-events: none; /* enable only on cells that have tooltips */
}

.kitCell{
  position: relative;
  border: 0;
  padding: 0;
  margin: 0;
  background: transparent;
  pointer-events: auto;
  cursor: help;
}

.kitCell--empty{
  pointer-events: none;
}

.kitCell:focus{ outline: none; }
.kitCell:focus-visible{ outline: 2px solid rgba(255,255,255,.35); outline-offset: 2px; border-radius: 6px; }

.kitTip{
  position: absolute;
  left: 50%;
  top: 0;
  transform: translate3d(-50%, -110%, 0);
  min-width: 160px;
  max-width: 260px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(0,0,0,.72);
  color: rgba(255,255,255,.92);
  font-size: 12px;
  line-height: 1.25;
  box-shadow: 0 12px 40px rgba(0,0,0,.45);
  opacity: 0;
  pointer-events: none;
  transition: opacity .12s ease, transform .12s ease;
  z-index: 30;
  will-change: opacity, transform;
  contain: paint;
}

.kitTip b{ font-weight: 1000; }

.kitCell:hover .kitTip,
.kitCell:focus-visible .kitTip,
.kitCell.is-open .kitTip{
  opacity: 1;
  transform: translate3d(-50%, -125%, 0);
}

.kitTip::after{
  content: "";
  position: absolute;
  left: 50%;
  bottom: -8px;
  transform: translateX(-50%);
  border: 8px solid transparent;
  border-top-color: rgba(0,0,0,.72);
}



/* === VIP+ mentions === */
.vipplusMentions{margin-top:12px; width:100%; box-sizing:border-box; border:1px dashed rgba(255,255,255,.22); background:rgba(255,255,255,.03); padding:16px; border-radius:18px; min-height:110px; align-items:center; justify-content:center}
.vipplusPlaceholder{width:100%; text-align:center; opacity:.9}
.vipplusMentions .chip{cursor:default}
.vipplusEmpty{margin-top:10px; font-weight:800; opacity:.9}


/* === Hotfix (v99): intro sem halo/progress (menos lag e consistente) === */
.introOverlay__iconOuter::before,
.introOverlay__iconOuter::after{
  opacity: 0 !important;
  animation: none !important;
}
.introOverlay__loadBar{
  display: none !important;
}



/* --- Intro (simple): logo only, no ring/no bar, fail-safe --- */
.introOverlay--simple .introOverlay__iconOuter::before,
.introOverlay--simple .introOverlay__iconOuter::after,
.introOverlay--simple .introOverlay__loadBar{
  display:none !important;
}

.introOverlay--simple .introOverlay__center{
  gap: 0;
  width: min(620px, 90vw);
}

.introOverlay--simple .introOverlay__icon{
  filter: drop-shadow(0 18px 38px rgba(0,0,0,.45));
}

.introOverlay--ready.introOverlay--simple .introOverlay__icon{
  animation: introLogoFloat 2.35s ease-in-out infinite;
}

@keyframes introLogoFloat{
  0%,100%{ transform: translate3d(0,0,0) scale(1); }
  50%{ transform: translate3d(0,-6px,0) scale(1.012); }
}



/* ===========================
   v102 Mobile + Intro fixes
   =========================== */

/* Header IP copy button */
.statusbar__item--ip{display:flex; align-items:center; gap:8px}
.statusbar__copy{
  appearance:none;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.08);
  color: var(--text);
  font-weight:700;
  font-size:12px;
  line-height:1;
  padding:8px 10px;
  border-radius: 999px;
  cursor:pointer;
  transition: transform 140ms ease, background 140ms ease, border-color 140ms ease;
  white-space:nowrap;
}
.statusbar__copy:hover{ background: rgba(255,255,255,.12); transform: translateY(-1px); }
.statusbar__copy:active{ transform: translateY(0); }
.statusbar__copy:disabled{ opacity:.65; cursor:default; transform:none; }

/* Prevent long IP from breaking layout on mobile */
.statusbar__val[data-status-ip]{
  max-width: 360px;
  overflow:hidden;
  text-overflow: ellipsis;
}

/* Intro overlay: logo-only, no circles, no blocking */
.introOverlayV102{
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  background:
    radial-gradient(900px 600px at 50% 35%, rgba(56,189,248,.18), rgba(0,0,0,0)),
    radial-gradient(900px 700px at 40% 65%, rgba(167,139,250,.14), rgba(0,0,0,0)),
    rgba(4,6,12,.92);
  backdrop-filter: blur(10px);
  z-index: 9999;
}
.introOverlayV102__wrap{
  display:flex;
  flex-direction: column;
  align-items:center;
  gap: 14px;
  padding: 18px 18px 16px;
}
.introOverlayV102__logo{
  width: min(220px, 62vw);
  height: auto;
  image-rendering: -webkit-optimize-contrast;
  filter: drop-shadow(0 10px 30px rgba(0,0,0,.55));
  transform: translate3d(0, 10px, 0) scale(.98);
  opacity: 0;
}
.introOverlayV102__bar{
  width: min(420px, 74vw);
  height: 6px;
  border-radius: 999px;
  background: rgba(255,255,255,.10);
  overflow:hidden;
}
.introOverlayV102__bar > i{
  display:block;
  height:100%;
  width: 36%;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(56,189,248,.95), rgba(167,139,250,.95));
  transform: translateX(-110%);
}

html.intro-on .introOverlayV102{ display:flex; }
html.intro-on .introOverlayV102__logo{
  animation: introLogoInV102 620ms cubic-bezier(.2,1,.2,1) 80ms both;
}
html.intro-on .introOverlayV102__bar > i{
  animation: introBarV102 1050ms cubic-bezier(.22,1,.36,1) 120ms both;
}
html.intro-on .introOverlayV102{
  animation: introFadeOutV102 520ms ease 1180ms forwards;
}
@keyframes introLogoInV102{
  from{ opacity:0; transform: translate3d(0, 14px, 0) scale(.985); }
  to{ opacity:1; transform: translate3d(0, 0, 0) scale(1); }
}
@keyframes introBarV102{
  from{ transform: translateX(-110%); }
  to{ transform: translateX(240%); }
}
@keyframes introFadeOutV102{
  to{ opacity:0; visibility:hidden; pointer-events:none; }
}

/* Mobile polish + FPS boosts */
html, body{ overflow-x:hidden; }

@media (max-width: 720px){
  /* Make taps easier */
  .btn, button, a{ touch-action: manipulation; }
  .btn{ min-height: 44px; }

  /* Reduce expensive blur on weaker devices */
  .pill, .glass, .product, .vipPanel, .statusbar__item, .mast, .card, .hero__card{
    backdrop-filter: none !important;
  }
  body.page-home::before,
  body.page-home::after{
    opacity: .10 !important;
    filter: none !important;
  }

  /* Status bar: wrap nicely */
  .statusbar__inner{ flex-direction: column; align-items: flex-start; gap:10px; }
  .statusbar__left{ flex-wrap: wrap; gap:10px; }
  .statusbar__sep{ display:none; }
  .statusbar__val[data-status-ip]{ max-width: 220px; }

  /* Header: keep everything on screen */
  .mast__inner{ gap: 10px; }
  .brand{ gap: 10px; }
  .brand__logo{ width: 44px; height: 44px; }
  .brand__name{ font-size: 18px; }
  .mast__actions{ gap: 8px; }

  /* Sections spacing */
  .section{ padding: 22px 0; }
  .hero{ padding-top: 18px; }

  /* Hero title fits better */
  .hero__title{ font-size: clamp(26px, 8vw, 38px); line-height: 1.05; }
  .hero__subtitle{ font-size: 15px; }
}

@media (max-width: 520px){
  /* Prevent cards from feeling cramped */
  .container{ padding-left: 14px; padding-right: 14px; }
  .products{ gap: 14px; }
  .product{ border-radius: 18px; }

  /* Drawer/cart panels fit small screens */
  .drawer__panel, .cartDrawer__panel{ width: min(92vw, 420px); }
}

/* ============================
   v103 – Mobile stability + FPS
   ============================ */

/* Kill the decorative side figures on smaller screens / "desktop site" mode
   (these can look like a blank column on mobile and also cost FPS). */
@media (max-width: 1280px){
  body.page-home::before,
  body.page-home::after,
  body.page-staff::before,
  body.page-staff::after{
    display:none !important;
  }
}

html, body{
  max-width: 100%;
  overflow-x: clip;
}

/* Mobile header: prevent overflow + make everything tappable */
@media (max-width: 760px){
  .topstrip{ position: relative !important; top:auto !important; }
  .mast{ top: 0 !important; }

  .statusbar__inner{ padding: 10px 0; }
  .statusbar__left{ width: 100%; gap: 8px; }
  .statusbar__sep{ display:none; }
  .statusbar__item{ padding: 8px 10px; border-radius: 14px; }
  .statusbar__item--ip{ flex: 1 0 100%; justify-content: space-between; gap: 10px; }
  .statusbar__val[data-status-ip]{
    max-width: 56vw;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    display: inline-block;
  }
  .statusbar__copy{ padding: 8px 12px; border-radius: 12px; }

  .mast__inner{ padding: 10px 0; }
  .brand{ min-width: 0 !important; flex: 1 1 auto; gap: 10px; }
  .brand__logo{ width: 56px; height: 56px; border-radius: 16px; }
  .brand__name{ font-size: 16px; }
  .mast__actions{ gap: 8px; }
  .iconbtn, .cartbtn{ width: 44px; height: 44px; border-radius: 16px; }
  .cartbtn__badge{ right: -3px; top: -3px; }

  .hero{ padding: 16px 0 28px; }
  .hero__inner{ gap: 14px; }
  .slide{ padding: 16px; }
  .slider{ border-radius: 18px; }
  .slider__controls{ padding: 10px; }
  .dotBtn{ width: 10px; height: 10px; }

  .socialPanel{ border-radius: 18px; }
  .socialGrid{ gap: 12px; padding: 16px 14px 14px; }
  .socialIcon{ width: 62px; height: 62px; }
  .socialSvg{ width: 30px; height: 30px; }
}

/* Touch devices: disable hover-heavy effects */
@media (hover:none){
  .socialIcon:hover{ transform:none !important; box-shadow: none !important; }
  .socialIcon:hover .socialIcon__ring,
  .socialIcon:hover .socialIcon__shine,
  .socialIcon:hover::after{ opacity: 0 !important; }

  .btn:hover,
  .btnPrimary:hover,
  .chip:hover,
  .pill:hover,
  .iconbtn:hover,
  .cartbtn:hover{ transform:none !important; }
}

/* FPS: reduce expensive blur + background animation on mobile/low motion */
@media (max-width: 760px), (prefers-reduced-motion: reduce){
  .panel,
  .mast,
  .topstrip,
  .modal{
    backdrop-filter:none !important;
    -webkit-backdrop-filter:none !important;
  }
  .hero__bg::before{ animation:none !important; }
}

/* ============================
   v103 – Intro logo (JS-driven)
   ============================ */
.introOverlayV103{
  position:fixed; inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  z-index:99999;
  background: radial-gradient(1200px 600px at 50% 45%, rgba(10,26,44,.92), rgba(0,0,0,.96));
}
html.intro-on .introOverlayV103{ display:flex; }
.introOverlayV103__wrap{ display:grid; place-items:center; }
.introOverlayV103__logo{
  width: min(280px, 64vw);
  height: auto;
  filter: drop-shadow(0 22px 60px rgba(0,0,0,.55));
  opacity: 1;
  transform: translateZ(0);
}
.introOverlayV103.is-leaving{ opacity:0; transition: opacity .35s ease; }


/* ==============================
   Mobile usability + performance (v105)
   ============================== */

/* Remove the "circle" background from the intro overlay (logo-only intro). */
.introOverlay::before,
.introOverlay::after {
  display: none !important;
  animation: none !important;
}

/* Bottom mobile navigation (appears only on small screens) */
.mobileNav {
  display: none;
}

@media (max-width: 720px) {
  /* Reduce GPU-heavy blur on mobile for smoother scrolling */
  .topstrip, .mast, .panel, .vipCard, .drawer__panel, .cartDrawer__panel {
    -webkit-backdrop-filter: none !important;
    backdrop-filter: none !important;
  }

  body {
    overflow-x: hidden;
    padding-bottom: 86px; /* space for bottom nav */
  }

  .container {
    padding-left: 14px;
    padding-right: 14px;
  }

  .topstrip__inner {
    flex-wrap: wrap;
    gap: 10px;
  }

  .mast__inner {
    flex-wrap: wrap;
    gap: 10px;
  }

  .brand {
    min-width: 0;
    flex: 1 1 auto;
  }

  .brand__text {
    font-size: 1.05rem;
    line-height: 1.1;
  }

  .pill {
    font-size: .84rem;
    padding: 7px 10px;
  }

  /* Hero: make CTAs easy to tap */
  .cta {
    flex-direction: column;
    align-items: stretch;
  }
  .cta .btn {
    width: 100%;
  }

  
  /* v107: prevent IP box from stretching vertically in mobile CTA column */
  .ipBox { flex: none; }
  .ipBox__value { overflow-wrap: anywhere; word-break: break-word; }

  /* v107: slightly smaller hero copy on small screens */
  .slide h1 { font-size: clamp(1.75rem, 7.2vw, 2.15rem); line-height: 1.08; }
  .slide p { font-size: 1rem; }
/* Store: stack VIP cards on mobile (fixes “3 cards in one row” overflow) */
  .products {
    grid-template-columns: 1fr !important;
  }

  /* Bottom nav */
  .mobileNav {
    display: flex;
    position: fixed;
    left: 12px;
    right: 12px;
    bottom: 12px;
    z-index: 9999;
    gap: 10px;
    padding: 10px;
    border-radius: 18px;
    background: rgba(16, 18, 27, 0.78);
    border: 1px solid rgba(255,255,255,0.10);
    box-shadow: 0 14px 35px rgba(0,0,0,0.35);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
  }

  .mobileNav__item {
    flex: 1 1 0;
    display: grid;
    place-items: center;
    text-decoration: none;
    color: var(--text);
    font-weight: 700;
    padding: 12px 10px;
    border-radius: 14px;
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.08);
    min-height: 44px; /* tap target */
  }

  .mobileNav__item:active {
    transform: scale(0.99);
  }

  body.page-home .mobileNav__item[data-nav="home"],
  body.page-store .mobileNav__item[data-nav="store"],
  body.page-vip-plus .mobileNav__item[data-nav="vipplus"],
  body.page-socials .mobileNav__item[data-nav="social"] {
    background: linear-gradient(90deg, rgba(209,67,67,0.55), rgba(115,79,255,0.40));
    border-color: rgba(255,255,255,0.16);
  }
}

/* Medium screens: 2 columns in store */
@media (max-width: 980px) {
  .products {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}


/* ============================
   v106 – Mobile readability & header sizing
   ============================ */

html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

/* Slightly reduce GPU-heavy effects on mobile and improve legibility */
@media (max-width: 720px) {
  /* Ensure content isn't hidden behind the bottom nav on devices with a gesture bar */
  body {
    padding-bottom: calc(92px + env(safe-area-inset-bottom));
  }

  /* Reduce remaining blur on mobile nav for smoother scrolling */
  .mobileNav {
    -webkit-backdrop-filter: none !important;
    backdrop-filter: none !important;
  }

  /* Make the top status row more proportional on phones */
  .statusbar {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }
  .statusbar__item {
    width: 100%;
    min-width: 0;
  }
  .statusbar__item--ip {
    grid-column: 1 / -1;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
  }
  .statusbar__item--ip .statusbar__value {
    max-width: none;
    flex: 1 1 auto;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .statusbar__copy {
    flex: 0 0 auto;
  }

  /* Drawer/menu: keep it readable and avoid giant spacing */
  .drawer__panel {
    padding: 12px;
  }
  .drawer__grid {
    gap: 10px;
  }
  .drawer__col {
    padding: 12px;
  }
  .drawer__heading {
    font-size: 0.92rem;
  }
  .drawer__link {
    font-size: 1.02rem;
    padding: 10px 10px;
  }
}

/* Extra-small phones */
@media (max-width: 420px) {
  .statusbar__label { font-size: 0.70rem; }
  .statusbar__value { font-size: 0.90rem; }
  .statusbar__copy { padding: 8px 12px; border-radius: 14px; }
  .hero__title { font-size: clamp(1.65rem, 7.2vw, 2.15rem); }
  .hero__sub { font-size: 0.98rem; }
}

/* v107: when the mobile drawer menu is open, hide header strips behind it */
html.drawer-open .statusbar,
html.drawer-open .topstrip {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}


/* ==============================
   v119 – Mobile proportion fixes (não afeta desktop)
   ============================== */

@media (max-width: 720px){
  /* Mobile nav: 5 botões (3 + 2) */
  .mobileNav{ flex-wrap: wrap; }
  .mobileNav__item{
    flex: 1 1 calc(33.333% - 10px);
    font-size: .92rem;
    padding: 11px 8px;
  }

  /* Active states (corrige classes inconsistentes) */
  body.page-home .mobileNav__item[data-nav="home"],
  body.page-store .mobileNav__item[data-nav="store"],
  body.page-vipplus .mobileNav__item[data-nav="vipplus"],
  body.page-vip-plus .mobileNav__item[data-nav="vipplus"],
  body.page-updates .mobileNav__item[data-nav="updates"],
  body.page-about .mobileNav__item[data-nav="about"],
  body.page-staff .mobileNav__item[data-nav="staff"]{
    background: linear-gradient(90deg, rgba(209,67,67,0.55), rgba(115,79,255,0.40));
    border-color: rgba(255,255,255,0.16);
  }

  /* Deixa o "hambúrguer" estável no mobile (evita o quadrado bugado) */
  .iconbtn{
    display: inline-flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 4px;
  }
  .iconbtn span{ margin: 0; width: 18px; }

  /* Um pouco mais de tempo no pop do logo (só no mobile) */
  .brand__logo.is-pop{ animation-duration: 1.05s; }

  /* Slider: evita esticar os slides verticalmente */
  .slider__track{ align-items: flex-start; }
  .slide{ height: auto; align-self: flex-start; }

  /* Slider texto: quebra linha no mobile (evita cortar no canto) */
  .slide p,
  .slide .lead{
    max-width: 100%;
    white-space: normal;
    overflow-wrap: anywhere;
    word-break: break-word;
    hyphens: auto;
  }
}

/* ==============================
   v121 – Mobile slider proportion (isolated)
   ============================== */
@media (max-width: 720px){
  /* Give the hero pills a bit more breathing room below the header */
  .heroBar{ margin-top: 8px; }

  /* Slider: ensure each slide truly fits the viewport width and wraps text */
  .slider{ max-width: 100%; }
  .slider__track{ align-items: stretch; }

  .slide{
    flex: 0 0 100%;
    width: 100%;
    max-width: 100%;
    padding: 16px 16px 18px;
  }

  .slide h1{
    font-size: clamp(1.55rem, 7.0vw, 2.05rem);
    line-height: 1.10;
  }

  /* Make sure paragraphs never get clipped by slider overflow */
  .slide p,
  .slide .lead{
    max-width: 100% !important;
    white-space: normal !important;
    overflow-wrap: anywhere;
    word-break: break-word;
    hyphens: auto;
  }

  .lead{ font-size: .98rem; line-height: 1.45; }

  /* Controls: slightly smaller so they don't steal vertical space */
  .slider__controls{ padding: 10px 12px; }
  .slider__btn{ width: 40px; height: 40px; border-radius: 16px; }
}


/* ==============================
   v121 – Slider proportion fix (mobile only)
   - prevents horizontal clipping inside the slider
   - improves readability + spacing on phones
   - keeps desktop untouched
   ============================== */

@media (max-width: 720px){
  /* Small gap under the sticky header so pills/hero don’t feel “colado” */
  .heroBar{ margin-top: 10px; }

  /* The actual fix: make each slide a strict 100% width flex item */
  .slider{ max-width: 100%; }
  .slider__track{ width: 100%; min-width: 0; align-items: stretch; }
  .slide{
    flex: 0 0 100%;
    width: 100%;
    min-width: 100%;
    max-width: 100%;
    padding: 18px 16px 20px;
  }

  /* Readability: better wrapping + slightly smaller title */
  .slide h1{ font-size: clamp(1.55rem, 6.8vw, 2.05rem); line-height: 1.08; }
  .slide .lead{ max-width: 100%; font-size: .98rem; line-height: 1.45; }
  .slide p{
    max-width: 100%;
    white-space: normal;
    overflow-wrap: anywhere;
    word-break: break-word;
    hyphens: auto;
  }

  /* Controls: keep them compact */
  .slider__controls{ padding: 10px 12px; gap: 10px; }
  .slider__btn{ width: 40px; height: 40px; border-radius: 14px; }
  .slider__dots{ gap: 10px; }
}

/* ===============================
   v122: Mobile slider fix (Android text clipping)
   - Use scroll-snap on phones (no transform-based track)
   - Keeps desktop unchanged
   =============================== */
@media (max-width: 720px){
  /* Track becomes a horizontal scroller */
  .slider__track{
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x proximity;
    -webkit-overflow-scrolling: touch;
    scroll-behavior: smooth;
    transform: none !important;
    transition: none !important;
    will-change: scroll-position;
    scrollbar-width: none;
  }
  .slider__track::-webkit-scrollbar{ display:none; }

  /* Each slide occupies exactly one viewport */
  .slide{
    flex: 0 0 100%;
    min-width: 100%;
    max-width: 100%;
    scroll-snap-align: start;
    scroll-snap-stop: always;
  }

  /* Make sure long titles/copy never clip */
  .slide h1,
  .slide p,
  .slide .lead{
    max-width: 100% !important;
    overflow-wrap: anywhere;
    word-break: break-word;
    hyphens: auto;
  }
}

/* ===============================
   v123: Mobile slider alignment + padding
   - prevents a few pixels of text clipping on Android (offset/rounding)
   - improves readability by giving a bit more right padding
   =============================== */
@media (max-width: 720px){
  /* tiny inner padding avoids border-radius clipping on some devices */
  .slider{ padding-right: 1px; }

  /* a hair more breathing room on the right */
  .slide{ padding: 18px 22px 20px 16px; }

  /* ensure text never gets cut by subpixel rounding */
  .slide h1,
  .slide p,
  .slide .lead{ padding-right: 6px; }
}




/* v124: route transition overlay (lightweight, no blur) */
.routeOverlay{
  position:fixed; inset:0;
  display:flex; align-items:center; justify-content:center;
  background: radial-gradient(900px 520px at 20% 30%, rgba(209,43,43,.22), transparent 60%),
              radial-gradient(980px 540px at 72% 62%, rgba(58,166,255,.18), transparent 62%),
              rgba(5,7,19,.96);
  opacity:0; pointer-events:none;
  transition: opacity .22s ease;
  z-index: 99999;
}
.routeOverlay__logo{
  width: 112px; height:112px;
  filter: drop-shadow(0 20px 40px rgba(0,0,0,.55));
  transform: scale(.92);
  opacity:0;
}
.routeOverlay.is-on{ opacity:1; pointer-events:auto; }
.routeOverlay.is-on .routeOverlay__logo{
  animation: routePop 1100ms ease forwards;
  will-change: transform, opacity;
}
@keyframes routePop{
  0%{opacity:0; transform:scale(.92)}
  58%{opacity:1; transform:scale(1.03)}
  100%{opacity:1; transform:scale(1)}
}
@media (prefers-reduced-motion: reduce){
  .routeOverlay{transition:none}
  .routeOverlay.is-on .routeOverlay__logo{animation:none; opacity:1; transform:none}
}


/* v124: mobile performance + slider clipping fixes */
@media (max-width: 720px){
  :root{ --shadow: 0 10px 28px rgba(0,0,0,.45); }

  /* Disable expensive blur on mobile to reduce stutter */
  .glass, .mast, .topstrip, .drawer, .cartDrawer, .mobileNav, .slider,
  .updateCard, .vipCard, .kitCard, .card, .pill, .chip, .panel{
    backdrop-filter: none !important;
  }

  /* Android text clipping: avoid transforms on slider track */
  .slider__track{
    transform:none !important;
    transition:none !important;
    overflow-x:auto;
    scroll-snap-type: x proximity;
    -webkit-overflow-scrolling: touch;
    scroll-behavior:smooth;
  }
  .slide{ scroll-snap-align:start; padding: 20px 26px 20px 20px; }
  .slide h1{ font-size: clamp(1.75rem, 6vw, 2.35rem); }
  .lead, .slide h1{
    overflow-wrap:anywhere;
    word-break:break-word;
    hyphens:auto;
    text-wrap: pretty;
  }

  /* Prevent bottom nav from blocking content */
  body{ padding-bottom: 86px; }
}


/* ============================
   v126 – Mobile: no clipped text + sharper hero
   ============================ */
@media (max-width: 720px){
  /* Softer layout + guarantee wrap (Android sometimes clips the last chars) */
  .slide{
    display:flex;
    flex-direction:column;
    gap:10px;
    padding: 18px 24px 18px 18px; /* extra right padding */
    box-sizing: border-box;
  }
  .slide > *{ min-width:0; max-width:100%; }

  .slide h1,
  .slide p,
  .slide .lead{
    max-width: 100% !important;
    padding-right: 14px; /* breathing room so it never clips */
    box-sizing: border-box;
  }

  .slide h1{
    white-space: normal !important;
    overflow-wrap: anywhere;
    word-break: break-word;
    hyphens: auto;
  }

  .lead{
    white-space: normal !important;
    overflow-wrap: anywhere;
    word-break: break-word;
  }

  /* Use a higher-res hero image on mobile */
  .hero__bg{
    background-image:
      radial-gradient(520px 280px at 18% 30%, rgba(209,43,43,.24), transparent 62%),
      radial-gradient(540px 300px at 70% 60%, rgba(58,166,255,.18), transparent 62%),
      url("../assets/home-bg.jpg");
    background-position: 0 0, 0 0, center;
    background-size: auto, auto, cover;
    background-repeat: no-repeat;
  }

  /* Extra FPS: stop heavy ambient animations on phones */
  body::before,
  body::after,
  .mast::before,
  .mast::after{
    animation: none !important;
  }
}


/* ==============================
   v127 – Mobile version (chat-style) + scroll fixes
   Inspired by app-like "chat list" navigation for mobile.
   ============================== */

/* Critical: allow scrollable areas inside flex panels (fixes iOS/Safari "can't scroll in menu") */
.drawer__grid{
  flex: 1 1 auto;
  min-height: 0;
  -webkit-overflow-scrolling: touch;
}
.cartDrawer__body{
  min-height: 0;
  -webkit-overflow-scrolling: touch;
}

/* Drawer search (desktop hidden; mobile shows) */
.drawer__search{
  display:none;
  padding: 12px 14px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  background: rgba(0,0,0,.10);
}
.drawer__searchInput{
  width:100%;
  height: 44px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color: var(--text);
  padding: 0 14px;
  font-weight: 850;
  letter-spacing: .01em;
  outline: none;
}
.drawer__searchInput::placeholder{ color: rgba(255,255,255,.55); }
.drawer__searchHint{
  margin-top: 8px;
  color: rgba(255,255,255,.55);
  font-size: .86rem;
}
.drawer__empty{
  display:none;
  padding: 14px;
  color: rgba(255,255,255,.72);
}

/* Chat-style items: keep desktop look intact (subtitle + avatar hidden by default) */
.drawerChat__avatar,
.drawerChat__sub{display:none}
.drawerChat__main{display:block}
.drawerChat__title{display:inline}
.drawerChat{display:block}

/* Mobile: full-screen drawer + chat-like list */
@media (max-width: 720px){
  /* Drawer uses the whole screen (like a chat app) */
  .drawer__panel{
    left:0;
    right:0;
    width:100vw;
    border-left: 0;
    border-right: 0;
    border-radius: 0;
  }
  .drawer__head{
    position: sticky;
    top: 0;
    z-index: 2;
    background: rgba(12,12,18,.98);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
  }
  .drawer__search{display:block}
  .drawer__grid{
    padding: 12px;
    gap: 12px;
  }

  /* Flatten columns into a single vertical list */
  .drawer__col{
    background: transparent;
    border: 0;
    padding: 0;
  }
  .drawer__label{
    margin: 10px 4px 8px;
    font-size: .76rem;
    letter-spacing: .14em;
    opacity: .85;
  }

  /* Chat row styling */
  .drawer__col a.drawerChat{
    display:flex;
    align-items:center;
    gap: 12px;
    padding: 14px 14px;
    border-radius: 18px;
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(255,255,255,.04);
    color: rgba(242,243,255,.94);
  }
  .drawer__col a.drawerChat:hover{
    background: rgba(255,255,255,.06);
    border-color: rgba(255,255,255,.16);
  }
  .drawerChat__avatar{
    display:grid;
    place-items:center;
    width: 42px;
    height: 42px;
    border-radius: 16px;
    background: linear-gradient(135deg, rgba(47,210,255,.22), rgba(164,91,255,.18));
    border: 1px solid rgba(255,255,255,.14);
    box-shadow: 0 16px 45px rgba(0,0,0,.35);
    font-weight: 950;
    letter-spacing: .04em;
    color: rgba(242,243,255,.96);
    flex: 0 0 auto;
  }
  .drawerChat__main{
    display:flex;
    flex-direction:column;
    gap: 2px;
    min-width: 0;
  }
  .drawerChat__title{
    display:block;
    font-weight: 950;
    letter-spacing: .02em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  .drawerChat__sub{
    display:block;
    font-size: .88rem;
    color: rgba(255,255,255,.68);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  /* Chevron */
  .drawer__col a.drawerChat::after{
    content: "›";
    margin-left: auto;
    opacity: .55;
    font-size: 26px;
    line-height: 1;
  }


  /* v160 – Mobile drawer proportions (more compact + consistent) */
  .drawer__grid{ padding: 10px; gap: 10px; }
  .drawer__label{ margin: 8px 4px 6px; }
  .drawer__col a.drawerChat{
    padding: 12px 12px;
    border-radius: 16px;
  }
  .drawerChat__avatar{
    width: 38px;
    height: 38px;
    border-radius: 14px;
  }
  .drawerChat__title{ font-size: 0.98rem; }
  .drawerChat__sub{ font-size: 0.84rem; }
  .drawer__search{ padding: 10px 12px; }
  .drawer__searchInput{ height: 42px; border-radius: 14px; }
  /* Hide the bottom mobile nav while drawer is open (prevents accidental taps behind) */
  html.drawer-open .mobileNav{
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
  }
}

/* If filter finds nothing, show empty state */
html.drawer-has-empty .drawer__empty{display:block}


/* ===============================
   v128 – Mobile proportions fix (hero “caixas”)
   - compact CTA blocks (IP box + buttons)
   - prevent awkward word breaks ("Serpens . razehost . net")
   - shrink slider controls on very small phones
   =============================== */

@media (max-width: 720px){
  /* Give the hero card more usable width (less "gutter") */
  .container{ padding-left: 12px; padding-right: 12px; }

  /* Slightly tighter slide padding so CTAs don't look "gigantes" */
  .slide{ padding: 14px 14px 16px !important; }

  /* More natural wrapping (avoid breaking words in weird spots) */
  .slide p,
  .slide .lead{
    overflow-wrap: break-word !important;
    word-break: normal !important;
    hyphens: auto;
  }

  /* CTA stack: compact + consistent sizing */
  .cta{ gap: 8px !important; margin-top: 12px !important; }

  .ipBox{
    width: 100%;
    flex: none !important;
    padding: 10px 12px;
    border-radius: 16px;
  }

  /* Make IP value fit without looking "quebrado" */
  .ipBox__value{
    font-family: inherit;
    font-weight: 900;
    font-size: 1.02rem;
    letter-spacing: .02em;
    line-height: 1.15;
    white-space: normal;
    overflow-wrap: break-word;
    word-break: normal;
  }

  /* Buttons on mobile: less tall + better proportion */
  .cta .btn{
    width: 100%;
    min-height: 50px;
    padding: 13px 14px;
    border-radius: 16px;
    font-size: 1rem;
  }

  /* Slider controls: slightly tighter */
  .slider__controls{ padding: 9px 10px !important; }
}

@media (max-width: 420px){
  /* Super small phones: make the control bar and buttons smaller */
  .slider__controls{ padding: 8px 10px !important; gap: 8px !important; }
  .slider__btn{ width: 36px !important; height: 36px !important; border-radius: 12px !important; font-size: 20px !important; }
  .dotBtn{ width: 8px !important; height: 8px !important; }
}


/* ===== v130: Hero photo-only slide (better proportions) ===== */
.slide--mediaOnly{
  display:flex;
  flex-direction:column;
}
.slide--mediaOnly .kicker{
  align-self:flex-start;
}
.heroMediaCard{
  margin-top:14px;
  width:100%;
  max-width:100%;
  border:1px solid rgba(255,255,255,.10);
  border-radius:22px;
  overflow:hidden;
  background: rgba(0,0,0,.22);
  box-shadow: 0 18px 44px rgba(0,0,0,.38);
}
/* Taller, more "hero" feeling */
.slide--mediaOnly .heroMediaCard{
  flex:1 1 auto;
  min-height: clamp(300px, 46vh, 600px);
}
.heroMediaCard img{
  width:100%;
  height:100%;
  display:block;
  object-fit: cover;
}

@media (max-width: 900px){
  /* Mobile: keep only the "BEM-VINDO AO SERPENS" + photo card feeling */
  .heroBar{display:none !important;}
  .slide{padding:16px}
  .heroMediaCard{border-radius:20px}
  .slide--mediaOnly .heroMediaCard{
    min-height: clamp(240px, 38vh, 480px);
  }
}
@media (max-width: 420px){
  .slider__controls{padding:10px}
  .slider__btn{width:40px; height:40px; border-radius:14px}
  .slide--mediaOnly .heroMediaCard{
    min-height: clamp(220px, 36vh, 420px);
  }
}

/* =============================
   v131 — Home: foto única + social mais clean
   ============================= */

/* Home não é mais carrossel: esconde controles caso existam */
.page-home .hero .slider__controls,
.page-home .hero .slider__dots,
.page-home .hero .slider__btn{
  display:none !important;
}

/* Mantém colunas alinhadas e com a mesma altura no desktop */
.page-home .hero__inner{ align-items: stretch; }
.page-home .hero__right{ align-self: stretch; }

/* Social (hero) — grid mais “certinho” e menos estranho */
.socialPanel--hero{
  height: auto;
  overflow: hidden;
}

.socialPanel--hero .socialGrid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  padding: 22px 18px 18px;
  place-content: center;
}

/* O ícone “central” (Twitch) fica no meio no desktop/tablet */
.socialPanel--hero .socialIcon--center{ grid-column: 2; }

@media (max-width: 980px){
  .socialPanel--hero .socialGrid{
    padding: 18px 16px 16px;
    gap: 12px;
  }
}

@media (max-width: 640px){
  .socialPanel--hero .socialGrid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  /* No mobile, o “central” vira linha inteira (fica mais equilibrado) */
  .socialPanel--hero .socialIcon--center{ grid-column: 1 / -1; justify-self: center; }
}

/* =============================
   v132 — Home: janela mais clean + proporções iguais
   ============================= */

.page-home .socialPanel--hero{ margin-top: 0 !important; }

.page-home .hero .slider,
.page-home .hero .socialPanel--hero{
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,.12);
  background:
    radial-gradient(640px 280px at 18% 0%, rgba(47,210,255,.10), transparent 62%),
    radial-gradient(640px 280px at 82% 0%, rgba(164,91,255,.10), transparent 62%),
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  box-shadow: 0 22px 75px rgba(0,0,0,.55);
  overflow: hidden;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

/* Remove o "neon line" e o aura animado só na Home */
.page-home .hero .slider::before,
.page-home .hero .slider::after,
.page-home .hero .socialPanel--hero::before,
.page-home .hero .socialPanel--hero::after{
  content: none !important;
  display: none !important;
}

/* Proporções: colunas sempre mesma altura no desktop */
@media (min-width: 981px){
  .page-home .hero__inner{
    align-items: stretch !important;
    grid-template-columns: minmax(0, 1.2fr) minmax(0, .8fr);
  }
  .page-home .hero__left,
  .page-home .hero__right{ align-self: stretch !important; }
  .page-home .hero__right{ display: flex; }
  .page-home .hero__right > *{ flex: 1 1 auto; }
}

/* Social panel: alinhamento e respiro mais consistente */
.page-home .socialPanel--hero .socialPanel__title{
  padding: 16px 18px;
  background: rgba(0,0,0,.18);
  border-bottom: 1px solid rgba(255,255,255,.10);
}
.page-home .socialPanel--hero .socialGrid{
  padding: 26px 22px 22px;
  gap: 16px;
  place-content: center;
}

/* Foto dentro da janela: arredondamento e espaço mais "clean" */
.page-home .slide--mediaOnly .heroMediaCard{
  border-radius: 20px;
  border-color: rgba(255,255,255,.10);
  box-shadow: 0 16px 42px rgba(0,0,0,.38);
}


/* =============================
   v135 — Home desktop: esquerda maior, direita menor + sem bordas
   (apenas desktop; mobile permanece igual)
   ============================= */

@media (min-width: 981px){
  .page-home .hero__inner{
    /* left bigger / right smaller, but keep right usable */
    grid-template-columns: minmax(0, 1.8fr) minmax(300px, .7fr) !important;
  }
}

.page-home .hero .slider,
.page-home .hero .socialPanel--hero,
.page-home .hero .heroMediaCard{
  border: none !important;
}

.page-home .socialPanel--hero .socialPanel__title{
  border-bottom: none !important;
}

.page-home .heroMediaCard img{
  object-position: 50% 55%;
}

/* v135: Hero bar acima das duas colunas (desktop) */
@media (min-width: 981px){
  .page-home .hero__inner{
    grid-template-areas:
      "bar bar"
      "left right";
    grid-template-rows: auto 1fr;
  }
  .page-home .heroBar--wide{ grid-area: bar; margin: 0 0 14px; }
  .page-home .hero__left{ grid-area: left; }
  .page-home .hero__right{ grid-area: right; }
}

/* =============================
   v136 — Mobile: melhorar proporção da foto (Home)
   - evita “achatada”
   - impede o flex de esticar a card
   ============================= */
@media (max-width: 900px){
  .page-home .slide--mediaOnly .heroMediaCard{
    flex: 0 0 auto !important;
    min-height: 0 !important;
    height: auto !important;
    aspect-ratio: 4 / 3;
  }
  .page-home .heroMediaCard img{
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
}
@media (max-width: 420px){
  .page-home .slide--mediaOnly .heroMediaCard{
    aspect-ratio: 3 / 2;
  }
}


/* v137: perf micro-optimizations (no visual/layout changes intended) */
.reveal { will-change: transform, opacity; }
.reveal.is-in { will-change: auto; }

.drawer__panel,
.cartDrawer__panel,
.mobileNav,
.introOverlayV103,
.introOverlayV103__wrap,
.introOverlayV103__logo,
.routeOverlay,
.routeOverlay__logo {
  will-change: transform, opacity;
}

/* Ensure animations stay on compositor when possible */
.btn,
.pill,
.socialBtn,
.socialIcon {
  backface-visibility: hidden;
  transform: translateZ(0);
}

/* Reduce scroll jank on mobile */
@supports (-webkit-overflow-scrolling: touch){
  .structureModal__body { -webkit-overflow-scrolling: touch; }
}


/* === Performance tweaks (safe) === */

/* Reduce expensive backdrop blur on mobile to keep scrolling silky on low-end devices */
@media (max-width: 820px){
  .topstrip,
  .mast,
  .panel,
  .vipCard,
  .drawer__panel,
  .cartDrawer__panel,
  .pill,
  .glass,
  .product,
  .vipPanel,
  .statusbar__item,
  .card,
  .hero__card,
  .toast,
  .modal,
  .cartDrawer__backdrop,
  .structureModal__backdrop,
  .introOverlayV102,
  .aboutCard,
  .aboutLead,
  .vipInfoCard,
  .updateCard,
  .kitCard,
  .chip,
  .drawer__head,
  .mobileNav{
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }
}

/* Respect reduced motion preferences */
@media (prefers-reduced-motion: reduce){
  html:focus-within{ scroll-behavior: auto !important; }
  *, *::before, *::after{
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
}

.u-mark--orange{color:#f5a623;font-weight:700}
.u-mark--yellow{color:#ffd54a;font-weight:700}
.u-mark--lightgreen{color:#7CFC9A;font-weight:700}
.u-mark--red{color:#ff6565;font-weight:700}
.u-mark--cyan{color:#62e7ff;font-weight:700}
.u-mark--blue{color:#74a7ff;font-weight:700}
.u-mark--purple{color:#b98bff;font-weight:700}
.u-mark--white{color:#ffffff;font-weight:700}
