/* ============================================================
   CosmicMC v2 — Master Stylesheet (Purple + Cyan Dual Accent)
   ============================================================ */

/* ── Tokens ── */
:root {
  --bg0: #06040f;
  --bg1: #0c0820;

  /* PURPLE ACCENT */
  --a1: #6d28d9;
  --a2: #8b5cf6;
  --a3: #a78bfa;

  /* CRIMSON ACCENT */
  --c1: #991b1b;
  --c2: #dc2626;
  --c3: #f87171;

  --text: #f0edff;
  --muted: rgba(240,237,255,.72);
  --muted-hi: rgba(240,237,255,.88);
  --glass: rgba(109,40,217,.07);
  --glass-hi: rgba(109,40,217,.13);
  --stroke: rgba(139,92,246,.18);
  --stroke-hi: rgba(167,139,250,.3);
  --r: 18px;
  --glow: 0 0 40px rgba(109,40,217,.35);
}

/* ── Reset ── */
*,::before,::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
html,body{height:100%}
body{
  font-family:ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial;
  color:var(--text);
  background:var(--bg0);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer}

/* ── Layout ── */
.container{width:min(1200px,calc(100% - 48px));margin:0 auto}
.page{min-height:100dvh;display:flex;flex-direction:column}

/* ── Background ── */
#nebulaCanvas{position:fixed;inset:0;z-index:-3;width:100%;height:100%}

body::before{
  content:"";
  position:fixed;inset:0;z-index:-2;
  background:
    radial-gradient(ellipse 1400px 900px at 15% 0%, rgba(109,40,217,.20),transparent 60%),
    radial-gradient(ellipse 1000px 700px at 85% 20%, rgba(91,33,182,.16),transparent 60%),
    radial-gradient(ellipse 800px 600px at 50% 100%, rgba(139,92,246,.10),transparent 60%),
    linear-gradient(180deg,var(--bg0),var(--bg1));
  animation:bgPulse 14s ease-in-out infinite alternate;
  pointer-events:none;
}
@keyframes bgPulse{
  0%{opacity:.85}
  100%{opacity:1}
}

/* ── Gradient text — purple to cyan ── */
.grad{
  background:linear-gradient(90deg,var(--a2),var(--c2));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.grad-anim{
  background:linear-gradient(90deg,var(--a1),var(--a2),var(--c2),var(--a2),var(--a1));
  background-size:300% 100%;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  animation:gradShift 5s linear infinite;
}
@keyframes gradShift{to{background-position:-300% 0}}

/* ============================================================
   TOPBAR
   ============================================================ */
.topbar{
  position:sticky;top:0;z-index:100;
  backdrop-filter:blur(22px) saturate(1.3);
  background:linear-gradient(180deg,rgba(6,4,15,.88),rgba(6,4,15,.45));
  border-bottom:1px solid var(--stroke);
}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  gap:14px;padding:13px 0;
}

/* logo — horizontal image, no text next to it */
.brand{display:flex;align-items:center;gap:10px;min-width:56px;flex-shrink:0}
.brand img{
  width:auto;height:50px;max-width:220px;border-radius:8px;
  object-fit:contain;
  filter:drop-shadow(0 0 10px rgba(220,38,38,.55)) drop-shadow(0 0 5px rgba(139,92,246,.45));
  transition:filter .3s,transform .3s;
}
.brand:hover img{
  filter:drop-shadow(0 0 20px rgba(220,38,38,.8)) drop-shadow(0 0 10px rgba(139,92,246,.6));
  transform:scale(1.05);
}
.brandName{display:none}

/* nav menu */
.menu{display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.menu a{
  display:inline-flex;align-items:center;gap:7px;
  padding:8px 12px;border-radius:12px;
  color:var(--muted);border:1px solid transparent;
  font-size:14px;font-weight:600;
  transition:color .2s,background .2s,border-color .2s,transform .15s;
  position:relative;
}
.menu a::after{
  content:"";
  position:absolute;bottom:4px;left:12px;right:12px;
  height:2px;background:linear-gradient(90deg,var(--a1),var(--c2));
  border-radius:99px;transform:scaleX(0);
  transition:transform .25s cubic-bezier(.34,1.56,.64,1);
}
.menu a:hover::after,.menu a.active::after{transform:scaleX(1)}
.menu a:hover{color:var(--text);background:var(--glass);border-color:var(--stroke);transform:translateY(-1px)}
.menu a.active{color:var(--text);background:rgba(109,40,217,.1);border-color:var(--stroke)}
.menu a svg{width:15px;height:15px;opacity:.75;flex-shrink:0}
.menu a span{background:linear-gradient(90deg,var(--a2),var(--c2));-webkit-background-clip:text;background-clip:text;color:transparent}

/* right controls */
.rightControls{display:flex;align-items:center;gap:8px;flex-shrink:0}

/* pill */
.pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 12px;border-radius:12px;
  border:1px solid var(--stroke);background:var(--glass);
  font-size:14px;font-weight:600;
  transition:background .2s,border-color .2s,transform .15s;
  cursor:pointer;color:var(--text);
}
.pill:hover{background:var(--glass-hi);border-color:var(--stroke-hi);transform:translateY(-1px)}
.pill b,.pill span{background:linear-gradient(90deg,var(--a2),var(--c2));-webkit-background-clip:text;background-clip:text;color:transparent}
.pill svg{opacity:.7}

/* lang dropdown */
.langWrap{position:relative}
.langBtn{
  display:inline-flex;align-items:center;padding:8px 12px;border-radius:12px;
  border:1px solid var(--stroke);background:var(--glass);
  font-weight:800;font-size:13px;cursor:pointer;
  background:linear-gradient(90deg,var(--a1),var(--c2));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  border:1px solid var(--stroke);background-color:var(--glass);
}
.langMenu{
  position:absolute;right:0;top:calc(100% + 8px);
  min-width:190px;border-radius:14px;
  border:1px solid var(--stroke);
  background:rgba(8,6,20,.96);backdrop-filter:blur(20px);
  box-shadow:0 20px 60px rgba(0,0,0,.6),0 0 0 1px rgba(139,92,246,.1);
  padding:6px;display:none;z-index:9999;
}
.langMenu.open{display:block;animation:dropIn .15s ease}
@keyframes dropIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.langItem{
  width:100%;display:flex;align-items:center;justify-content:space-between;
  padding:9px 12px;border-radius:10px;
  border:1px solid transparent;background:transparent;
  color:var(--muted-hi);font-size:14px;
  transition:background .15s,border-color .15s;
}
.langItem:hover{background:var(--glass);border-color:var(--stroke)}
.langItem span{opacity:.5;font-size:12px}

/* theme toggle — inline buttons */
.themeToggle{display:flex;gap:4px;align-items:center}
.themeToggleBtn{
  width:36px;height:36px;border-radius:10px;
  border:1px solid var(--stroke);background:var(--glass);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--text);
  transition:background .2s,border-color .2s,transform .15s;
}
.themeToggleBtn:hover{background:var(--glass-hi);border-color:var(--stroke-hi);transform:translateY(-1px)}
.themeToggleBtn.active{background:linear-gradient(135deg,var(--a1),var(--c2));border-color:transparent;color:#fff}
.themeToggleBtn svg{width:16px;height:16px}

/* home icon button */
.homeIconBtn{
  width:36px;height:36px;border-radius:10px;
  border:1px solid var(--stroke);background:var(--glass);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--text);
  transition:background .2s,border-color .2s,transform .15s;
  text-decoration:none;
}
.homeIconBtn:hover{background:var(--glass-hi);border-color:var(--stroke-hi);transform:translateY(-1px)}
.homeIconBtn svg{width:16px;height:16px}

/* theme panel — kept for backward compat, always hidden */
.themePanel{
  position:fixed;right:18px;top:75px;
  width:min(340px,calc(100% - 36px));
  border-radius:18px;border:1px solid var(--stroke);
  background:rgba(8,6,20,.95);backdrop-filter:blur(22px);
  box-shadow:0 24px 70px rgba(0,0,0,.65),0 0 0 1px rgba(139,92,246,.08);
  padding:16px;display:none;z-index:9999;
  animation:dropIn .2s ease;
}
.themePanel.open{display:none}
.themePanel h3{font-size:14px;font-weight:900;margin-bottom:8px;display:flex;align-items:center;gap:8px;color:var(--text)}
.themeRow{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:12px}
.themeRow label{color:var(--muted);font-size:13px;flex-shrink:0}
.themeActions{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  border-radius:12px;padding:11px 16px;
  border:1px solid var(--stroke);background:var(--glass);
  color:var(--text);font-size:14px;font-weight:600;
  cursor:pointer;white-space:nowrap;
  transition:transform .18s,background .18s,border-color .18s,box-shadow .18s;
  position:relative;overflow:hidden;
}
.btn::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(105deg,transparent 40%,rgba(255,255,255,.10) 50%,transparent 60%);
  transform:translateX(-100%);transition:transform .45s ease;pointer-events:none;
}
.btn:hover::before{transform:translateX(100%)}
.btn:hover{background:var(--glass-hi);border-color:var(--stroke-hi);transform:translateY(-2px);box-shadow:0 10px 30px rgba(0,0,0,.25)}
.btn:active{transform:translateY(0) scale(.97)}
.btn svg{opacity:.8;flex-shrink:0}

.btn.primary{
  background:linear-gradient(135deg,var(--a1),var(--c2));
  border:none;color:#fff;
  box-shadow:0 0 0 0 rgba(109,40,217,.4);
  animation:btnPulse 3s ease-in-out infinite;
}
.btn.primary:hover{
  filter:brightness(1.12);transform:translateY(-3px);
  box-shadow:0 14px 40px rgba(109,40,217,.35);
  animation:none;
}
@keyframes btnPulse{
  0%,100%{box-shadow:0 0 0 0 rgba(109,40,217,.4)}
  50%{box-shadow:0 0 0 7px rgba(109,40,217,.0)}
}
.btn.ghost{background:transparent;border-color:var(--stroke)}
.btn.ghost:hover{background:var(--glass)}

/* ripple */
.ripple{
  position:absolute;border-radius:50%;
  transform:scale(0);animation:rippleAnim .5s linear;
  background:rgba(167,139,250,.22);pointer-events:none;
}
@keyframes rippleAnim{to{transform:scale(4);opacity:0}}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;
  padding:60px 0 44px;
  min-height:90dvh;
  display:flex;align-items:center;
}
.heroVideo{position:absolute;inset:0;z-index:-1;overflow:hidden}
.heroVideo video{
  width:100%;height:100%;object-fit:cover;
  filter:saturate(.9) contrast(1.05) brightness(.5);
}
.heroVideo::after{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse 900px 600px at 20% 30%,rgba(109,40,217,.35),transparent 60%),
    radial-gradient(ellipse 700px 500px at 80% 20%,rgba(91,33,182,.25),transparent 55%),
    linear-gradient(180deg,rgba(6,4,15,.25) 0%,rgba(6,4,15,.80) 100%);
}

/* floating orbs */
.heroOrbs{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:0}
.orb{
  position:absolute;border-radius:50%;
  filter:blur(80px);opacity:.18;
  animation:orbFloat linear infinite;
}
.orb:nth-child(1){
  width:500px;height:500px;
  background:radial-gradient(circle,var(--a1),transparent 70%);
  left:-10%;top:10%;animation-duration:22s;
}
.orb:nth-child(2){
  width:350px;height:350px;
  background:radial-gradient(circle,var(--a2),transparent 70%);
  right:-8%;top:30%;animation-duration:17s;animation-delay:-6s;
}
.orb:nth-child(3){
  width:280px;height:280px;
  background:radial-gradient(circle,var(--c2),transparent 70%);
  left:45%;bottom:5%;animation-duration:14s;animation-delay:-9s;
}
@keyframes orbFloat{
  0%,100%{transform:translate(0,0) scale(1)}
  25%{transform:translate(28px,-38px) scale(1.04)}
  50%{transform:translate(-18px,28px) scale(.96)}
  75%{transform:translate(36px,18px) scale(1.02)}
}

.heroGrid{
  display:grid;grid-template-columns:1.25fr .75fr;
  gap:20px;align-items:start;position:relative;z-index:1;
}
@media(max-width:960px){.heroGrid{grid-template-columns:1fr}}

/* ============================================================
   CARDS
   ============================================================ */
.card{
  border-radius:var(--r);
  border:1px solid var(--stroke);
  background:var(--glass);
  box-shadow:0 16px 50px rgba(0,0,0,.25);
  overflow:hidden;
  transition:box-shadow .3s,transform .3s,border-color .3s;
  transform-style:preserve-3d;
}
.card:hover{border-color:var(--stroke-hi);box-shadow:0 24px 70px rgba(0,0,0,.4),0 0 30px rgba(109,40,217,.15)}

.card.glowBorder{border:1px solid transparent;background-clip:padding-box;position:relative}
.card.glowBorder::before{
  content:"";position:absolute;inset:-1px;
  border-radius:calc(var(--r) + 1px);
  background:linear-gradient(135deg,var(--a1),var(--a2),var(--c2),var(--a1));
  background-size:300% 300%;animation:borderShift 6s linear infinite;
  z-index:-1;opacity:0;transition:opacity .35s;
}
.card.glowBorder:hover::before{opacity:1}
@keyframes borderShift{to{background-position:300% 0}}

.pad{padding:20px}

/* badges */
.badges{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.badge{
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 13px;border-radius:999px;
  border:1px solid var(--stroke);background:linear-gradient(135deg,rgba(109,40,217,.15),rgba(6,182,212,.1));
  color:var(--muted-hi);font-size:12px;font-weight:600;
  letter-spacing:.02em;
}
.badge svg{width:13px;height:13px;opacity:.8}

/* typography */
.title{font-size:50px;line-height:1.04;letter-spacing:-.8px;font-weight:900;color:var(--text)}
@media(max-width:640px){.title{font-size:38px}}
@media(max-width:420px){.title{font-size:30px}}

.lead{margin:12px 0 18px;color:var(--muted-hi);font-size:15.5px;line-height:1.65}
.h2{font-size:22px;font-weight:900;margin:0 0 6px;letter-spacing:-.3px;color:var(--text)}
.p{margin:0;color:var(--muted);line-height:1.6;font-size:14px}

.heroActions{display:flex;flex-wrap:wrap;gap:10px;margin-top:6px}
hr.sep{border:none;border-top:1px solid rgba(139,92,246,.15);margin:16px 0}
.kicker{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:rgba(240,237,255,.45);margin-bottom:4px}

/* IP box */
.ipBox{
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;flex-wrap:wrap;
  padding:14px 16px;border-radius:14px;
  border:1px solid var(--stroke);background:rgba(109,40,217,.08);
}
.ipText{font-weight:900;font-size:18px;letter-spacing:.6px;color:var(--text);font-family:ui-monospace,"Cascadia Code",monospace}

/* stats */
.statsRow{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:14px}
@media(max-width:480px){.statsRow{grid-template-columns:1fr}}
.statBox{
  text-align:center;padding:14px 8px;border-radius:14px;
  border:1px solid var(--stroke);background:rgba(109,40,217,.07);
}
.statNum{
  font-size:26px;font-weight:950;
  background:linear-gradient(135deg,var(--a2),var(--c2));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.statLabel{font-size:12px;color:var(--muted);margin-top:3px;font-weight:500}

/* section */
.section{padding:44px 0}
.pageHero{padding:60px 0 28px;position:relative;overflow:hidden}
.pageHero::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse 900px 500px at 50% 0%,rgba(109,40,217,.15),transparent 60%);
  pointer-events:none;
}
.pageHero .container{position:relative;z-index:1}

/* section actions centering */
.sectionActions{display:flex;justify-content:center;gap:10px;flex-wrap:wrap;margin-top:20px}

/* grid */
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:16px}

/* notice */
.notice{
  padding:13px 15px;border-radius:13px;
  border:1px solid var(--stroke);background:rgba(109,40,217,.06);
  color:var(--muted);line-height:1.55;font-size:14px;
}

/* social row */
.socialRow{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}

/* ── MODE CARDS — Home carousel ── */
.modeCarouselWrap{
  position:relative;
  margin:0 -4px;
}
.modeCarousel{
  display:flex;gap:12px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  padding:6px 4px 14px;
  cursor:grab;
}
.modeCarousel:active{cursor:grabbing}
.modeCarousel::-webkit-scrollbar{display:none}
.modeCarouselCard{
  flex:0 0 190px;
  scroll-snap-align:start;
}
/* scrollbar dots indicator */
.carouselDots{display:flex;gap:6px;justify-content:center;margin-top:4px}
.carouselDot{
  width:6px;height:6px;border-radius:50%;
  background:rgba(139,92,246,.25);
  transition:background .2s,transform .2s;cursor:pointer;border:none;
}
.carouselDot.active{background:var(--a2);transform:scale(1.3)}

/* mode card thumbnails — vivid game-specific gradients */
.modThumb{
  height:110px;display:flex;align-items:center;justify-content:center;
  border-bottom:1px solid var(--stroke);overflow:hidden;position:relative;
}
.modThumb::after, .modThumbLg::after{
  content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(45deg,transparent,transparent 8px,rgba(255,255,255,.025) 8px,rgba(255,255,255,.025) 9px);
  pointer-events:none;z-index:0;
}
.modThumb svg{width:44px;height:44px;opacity:.75;color:#fff;position:relative;z-index:2}
.modThumb::before{content:"";position:absolute;inset:0;opacity:.9}
.modThumb-smp::before{background:linear-gradient(135deg,#064e3b,#065f46,#1e1b4b)}
.modThumb-bedwars::before{background:linear-gradient(135deg,#7f1d1d,#991b1b,#450a0a)}
.modThumb-practice::before{background:linear-gradient(135deg,#0c4a6e,#0369a1,#164e63)}
.modThumb-buildbattle::before{background:linear-gradient(135deg,#78350f,#b45309,#92400e)}
.modThumb-pillar::before{background:linear-gradient(135deg,#1e1b4b,#312e81,#0f172a)}
.modThumb-duels::before{background:linear-gradient(135deg,#881337,#9f1239,#4c0519)}

/* ── MODS page large cards ── */
.modCardLarge{grid-column:span 6}
@media(max-width:700px){.modCardLarge{grid-column:span 12}}

.modThumbLg{
  height:200px;display:flex;align-items:center;justify-content:center;
  border-bottom:1px solid var(--stroke);overflow:hidden;position:relative;
}
.modThumbLg::before{content:"";position:absolute;inset:0;opacity:.95}
.modThumbLg-smp::before{background:linear-gradient(135deg,#064e3b,#065f46,#1e1b4b)}
.modThumbLg-bedwars::before{background:linear-gradient(135deg,#7f1d1d,#991b1b,#450a0a)}
.modThumbLg-practice::before{background:linear-gradient(135deg,#0c4a6e,#0369a1,#164e63)}
.modThumbLg-buildbattle::before{background:linear-gradient(135deg,#78350f,#b45309,#92400e)}
.modThumbLg-pillar::before{background:linear-gradient(135deg,#1e1b4b,#312e81,#0f172a)}
.modThumbLg-duels::before{background:linear-gradient(135deg,#881337,#9f1239,#4c0519)}
.modThumbLg svg{width:60px;height:60px;color:#fff;opacity:.85;position:relative;z-index:2}

.cardTitle{font-weight:900;margin:0 0 6px;font-size:15px;color:var(--text)}
.small{font-size:13px;color:var(--muted-hi);line-height:1.55;margin:0}

.modeTag{
  display:inline-flex;align-items:center;gap:5px;
  padding:4px 10px;border-radius:8px;
  font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;
  background:linear-gradient(90deg,var(--a1),var(--c2));color:#fff;
  margin-bottom:8px;
}
.modeTag svg{width:12px;height:12px}

/* ── STORE ── */
.rankCard{grid-column:span 4}
@media(max-width:1040px){.rankCard{grid-column:span 6}}
@media(max-width:580px){.rankCard{grid-column:span 12}}
.rankCard.featured{grid-column:span 4}
@media(max-width:1040px){.rankCard.featured{grid-column:span 12}}

.featuredBanner{
  position:absolute;top:-1px;left:50%;transform:translateX(-50%);
  background:linear-gradient(90deg,var(--a1),var(--c2));
  padding:4px 16px;border-radius:0 0 11px 11px;
  font-size:11px;font-weight:800;color:#fff;white-space:nowrap;z-index:2;
  letter-spacing:.06em;text-transform:uppercase;
}
.rankHeader{
  padding:22px 20px 16px;
  border-bottom:1px solid var(--stroke);text-align:center;
}
.rankIcon{
  width:52px;height:52px;border-radius:16px;
  background:linear-gradient(135deg,var(--a1),var(--c2));
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 12px;
}
.rankIcon svg{width:26px;height:26px;color:#fff}
.rankName{font-size:20px;font-weight:900;margin-bottom:4px;color:var(--text)}
.rankDesc{font-size:13px;color:var(--muted-hi);line-height:1.5}
.rankBadge{
  display:inline-block;padding:4px 12px;border-radius:999px;
  font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
  background:linear-gradient(90deg,var(--a1),var(--c2));color:#fff;margin-bottom:8px;
}
.rankPerks{padding:14px 20px}
.rankPerk{
  display:flex;align-items:center;gap:10px;
  padding:7px 0;border-bottom:1px solid rgba(139,92,246,.06);
  font-size:13.5px;color:var(--muted-hi);
}
.rankPerk:last-child{border-bottom:none}
.rankPerkIcon{
  width:18px;height:18px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--a1),var(--c2));
  display:flex;align-items:center;justify-content:center;
}
.rankPerkIcon svg{width:10px;height:10px;color:#fff}
.rankFooter{padding:14px 20px 20px;border-top:1px solid var(--stroke);text-align:center}
.rankPrice{
  font-size:30px;font-weight:950;
  background:linear-gradient(90deg,var(--a2),var(--c2));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.rankPricePer{font-size:13px;color:var(--muted);margin-bottom:12px}

/* ── STAFF ── */
.staffCard{grid-column:span 4}
@media(max-width:1040px){.staffCard{grid-column:span 6}}
@media(max-width:580px){.staffCard{grid-column:span 12}}

.staffRole{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 12px;border-radius:999px;
  font-size:11px;font-weight:800;letter-spacing:.07em;text-transform:uppercase;
  margin-bottom:10px;
}
.staffRole svg{width:12px;height:12px}
.role-owner{background:linear-gradient(90deg,rgba(109,40,217,.35),rgba(6,182,212,.2));color:var(--a3);border:1px solid rgba(139,92,246,.25)}
.role-admin{background:linear-gradient(90deg,rgba(91,33,182,.35),rgba(6,182,212,.2));color:var(--a2);border:1px solid rgba(109,40,217,.25)}
.role-mod{background:linear-gradient(90deg,rgba(76,29,149,.35),rgba(6,182,212,.2));color:var(--a3);border:1px solid rgba(91,33,182,.25)}
.role-helper{background:linear-gradient(90deg,rgba(109,40,217,.25),rgba(6,182,212,.15));color:var(--a3);border:1px solid rgba(167,139,250,.2)}

.memberList{list-style:none;display:flex;flex-direction:column;gap:7px;margin-top:10px}
.memberList li{
  display:flex;align-items:center;gap:10px;
  padding:9px 12px;border-radius:11px;
  background:rgba(109,40,217,.07);border:1px solid rgba(139,92,246,.1);
  font-size:13.5px;font-weight:600;color:var(--text);
  transition:background .2s,transform .2s;
}
.memberList li:hover{background:rgba(109,40,217,.14);transform:translateX(3px)}
.memberList li.empty{color:var(--muted);font-weight:400;font-style:italic;font-size:13px}
.memberList li::before{
  content:"";width:6px;height:6px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--a2),var(--c2));
}

/* ── RULES ── */
.ruleSection{margin-bottom:0}
.ruleSectionTitle{
  display:flex;align-items:center;gap:10px;
  font-size:18px;font-weight:900;margin-bottom:14px;color:var(--text);
}
.ruleSectionTitle .ruleIcon{
  width:34px;height:34px;border-radius:10px;
  background:linear-gradient(135deg,var(--a1),var(--c2));
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.ruleSectionTitle .ruleIcon svg{width:17px;height:17px;color:#fff}

.ruleList{list-style:none;display:flex;flex-direction:column;gap:6px}
.ruleList li{
  padding:10px 14px;border-radius:11px;
  background:rgba(109,40,217,.06);border:1px solid rgba(139,92,246,.1);
  font-size:13.5px;line-height:1.6;color:var(--muted-hi);
  display:flex;align-items:flex-start;gap:10px;
  transition:background .2s,border-color .2s,transform .2s;
}
.ruleList li:hover{background:rgba(109,40,217,.12);border-color:var(--stroke);transform:translateX(3px)}
.ruleArrow{
  flex-shrink:0;margin-top:2px;
  width:16px;height:16px;opacity:.6;
  background:linear-gradient(135deg,var(--a2),var(--c2));
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='5' y1='12' x2='19' y2='12'/%3E%3Cpolyline points='12 5 19 12 12 19'/%3E%3C/svg%3E") center/contain no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='5' y1='12' x2='19' y2='12'/%3E%3Cpolyline points='12 5 19 12 12 19'/%3E%3C/svg%3E") center/contain no-repeat;
}

/* ── FOOTER ── */
.footer{
  margin-top:auto;border-top:1px solid var(--stroke);
  background:rgba(0,0,0,.2);padding:30px 0 20px;
}
.footerGrid{
  display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:20px;align-items:start;
}
@media(max-width:940px){.footerGrid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footerGrid{grid-template-columns:1fr}}
.footerLogoRow{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.footerLogoRow img{width:26px;height:26px;border-radius:8px;opacity:.9}
.footerLogoRow b{font-size:15px;font-weight:900;color:var(--text)}
.footerDesc{color:var(--muted);font-size:13.5px;line-height:1.6}
.footerTitle{
  font-weight:800;font-size:11px;letter-spacing:.08em;
  text-transform:uppercase;color:rgba(240,237,255,.4);margin-bottom:12px;
}
.footerLinks{display:flex;flex-direction:column;gap:9px}
.footerLinks a{color:var(--muted);font-size:13.5px;transition:color .2s,transform .15s;display:inline-block}
.footerLinks a:hover{color:var(--text);transform:translateX(3px)}
.footerBottom{
  margin-top:20px;padding-top:14px;border-top:1px solid rgba(139,92,246,.08);
  display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;
  color:rgba(240,237,255,.35);font-size:12.5px;
}

/* ── MODE LOCKED / COMING SOON ── */
.modeLocked{position:relative;pointer-events:none;opacity:.55}
.modeLocked .modThumb,.modeLocked .modThumbLg{filter:grayscale(.6)}
.modeLockedBadge{
  position:absolute;top:8px;right:8px;z-index:3;
  display:inline-flex;align-items:center;gap:5px;
  padding:4px 10px;border-radius:99px;
  background:rgba(0,0,0,.55);backdrop-filter:blur(6px);
  border:1px solid rgba(139,92,246,.3);
  font-size:10px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;
  color:rgba(240,237,255,.7);
}
.modeLockedBadge svg{width:10px;height:10px;opacity:.8}
.modeActiveLink{cursor:pointer;pointer-events:auto}
.modeActiveBadge{
  position:absolute;top:8px;right:8px;z-index:3;
  display:inline-flex;align-items:center;gap:5px;
  padding:4px 10px;border-radius:99px;
  background:linear-gradient(90deg,var(--a1),var(--c2));
  font-size:10px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;
  color:#fff;
  box-shadow:0 0 14px rgba(109,40,217,.5);
}
.modeActiveBadge svg{width:10px;height:10px}

/* ── SCROLL REVEAL ── */
.reveal{
  opacity:0;transform:translateY(26px);
  transition:opacity .6s cubic-bezier(.16,1,.3,1),transform .6s cubic-bezier(.16,1,.3,1);
}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal[data-delay="1"]{transition-delay:.08s}
.reveal[data-delay="2"]{transition-delay:.16s}
.reveal[data-delay="3"]{transition-delay:.24s}
.reveal[data-delay="4"]{transition-delay:.32s}
.reveal[data-delay="5"]{transition-delay:.40s}
.reveal[data-delay="6"]{transition-delay:.48s}

/* hero text slide-up */
.heroLine{overflow:hidden}
.heroLine span{display:block;animation:slideUp .8s cubic-bezier(.16,1,.3,1) both}
.heroLine:nth-child(2) span{animation-delay:.12s}
.heroLine:nth-child(3) span{animation-delay:.22s}
@keyframes slideUp{from{transform:translateY(110%);opacity:0}to{transform:translateY(0);opacity:1}}

.cursor{
  display:inline-block;width:2px;height:.9em;
  background:var(--a3);margin-left:2px;vertical-align:middle;
  animation:blink .8s step-end infinite;
}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}

/* ── MOBILE NAV ── */
@media(max-width:780px){
  .menu{display:none}
  .menu.open{
    display:flex;flex-direction:column;align-items:stretch;
    position:fixed;inset:0;top:68px;
    background:rgba(6,4,15,.97);backdrop-filter:blur(22px);
    padding:16px;z-index:99;gap:6px;
    animation:dropIn .2s ease;
  }
  .menu.open a{padding:13px 16px;font-size:14px;border-radius:12px;border:1px solid var(--stroke)}
  .menuToggle{display:flex!important}
}
.menuToggle{
  display:none;flex-direction:column;gap:5px;
  padding:9px;border-radius:11px;border:1px solid var(--stroke);background:var(--glass);
}
.menuToggle span{display:block;width:20px;height:2px;background:var(--text);border-radius:2px;transition:transform .28s,opacity .28s}
.menuToggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menuToggle.open span:nth-child(2){opacity:0}
.menuToggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── LIGHT MODE ── */
html[data-scheme="light"] body{color:#0e0b24}
html[data-scheme="light"] body::before{
  background:
    radial-gradient(ellipse 1400px 900px at 15% 0%,rgba(109,40,217,.08),transparent 60%),
    radial-gradient(ellipse 800px 600px at 85% 20%,rgba(91,33,182,.06),transparent 55%),
    linear-gradient(180deg,#f4f0ff,#ece5ff);
}
html[data-scheme="light"] #nebulaCanvas{opacity:.15}
html[data-scheme="light"] .topbar{background:linear-gradient(180deg,rgba(244,240,255,.92),rgba(244,240,255,.65));border-bottom:1px solid rgba(109,40,217,.12)}
html[data-scheme="light"] .card{background:rgba(255,255,255,.75);border-color:rgba(109,40,217,.12)}
html[data-scheme="light"] .card:hover{border-color:rgba(109,40,217,.25)}
html[data-scheme="light"] .notice,
html[data-scheme="light"] .ipBox,
html[data-scheme="light"] .statBox{background:rgba(109,40,217,.05)!important;border-color:rgba(109,40,217,.14)!important}
html[data-scheme="light"] .btn{background:rgba(255,255,255,.7);border-color:rgba(109,40,217,.14);color:#0e0b24}
html[data-scheme="light"] .btn.primary{color:#fff}
html[data-scheme="light"] .themeToggleBtn{background:rgba(255,255,255,.7);border-color:rgba(109,40,217,.14);color:#0e0b24}
html[data-scheme="light"] .themeToggleBtn:hover{background:rgba(255,255,255,.85);border-color:rgba(109,40,217,.2)}
html[data-scheme="light"] .themeToggleBtn.active{background:linear-gradient(135deg,var(--a1),var(--c2))!important;border-color:transparent!important;color:#fff!important}
html[data-scheme="light"] .homeIconBtn{background:rgba(255,255,255,.7);border-color:rgba(109,40,217,.14);color:#0e0b24}
html[data-scheme="light"] .homeIconBtn:hover{background:rgba(255,255,255,.85);border-color:rgba(109,40,217,.2)}
/* Text colors in light mode — each selector properly scoped */
html[data-scheme="light"] .lead,
html[data-scheme="light"] .p,
html[data-scheme="light"] .small,
html[data-scheme="light"] .notice,
html[data-scheme="light"] .badge,
html[data-scheme="light"] .muted{color:rgba(14,11,36,.65)}
html[data-scheme="light"] .text,
html[data-scheme="light"] .title,
html[data-scheme="light"] .h2,
html[data-scheme="light"] .cardTitle,
html[data-scheme="light"] .ipText,
html[data-scheme="light"] .statNum{color:#0e0b24!important}
html[data-scheme="light"] .statNum{-webkit-background-clip:unset;background-clip:unset;background:none;color:var(--a1)!important}
html[data-scheme="light"] .footer{background:rgba(255,255,255,.5);border-top:1px solid rgba(109,40,217,.1)}
html[data-scheme="light"] .footerDesc,
html[data-scheme="light"] .footerLinks a,
html[data-scheme="light"] .footerBottom{color:rgba(14,11,36,.55)}
html[data-scheme="light"] .footerLinks a:hover{color:#0e0b24}
html[data-scheme="light"] .footerTitle{color:rgba(14,11,36,.38)}
html[data-scheme="light"] .memberList li{background:rgba(109,40,217,.06);border-color:rgba(109,40,217,.12);color:#0e0b24}
html[data-scheme="light"] .ruleList li{background:rgba(109,40,217,.05);border-color:rgba(109,40,217,.1);color:rgba(14,11,36,.75)}
html[data-scheme="light"] .rankPerk,
html[data-scheme="light"] .rankDesc{color:rgba(14,11,36,.7)}
html[data-scheme="light"] .langMenu,
html[data-scheme="light"] .themePanel{background:rgba(244,240,255,.97);border-color:rgba(109,40,217,.14)}
html[data-scheme="light"] .langItem{color:rgba(14,11,36,.8)}
html[data-scheme="light"] .themePanel h3,
html[data-scheme="light"] .themeRow label{color:#0e0b24}
html[data-scheme="light"] .menu a{color:rgba(14,11,36,.6)}
html[data-scheme="light"] .menu a:hover,
html[data-scheme="light"] .menu a.active{color:#0e0b24;background:rgba(109,40,217,.08)}
html[data-scheme="light"] .modeCarousel .card{background:rgba(255,255,255,.8)}
html[data-scheme="light"] .staffRole,
html[data-scheme="light"] .staffRoleLabel{color:var(--a1)!important}
html[data-scheme="light"] .kicker{color:rgba(14,11,36,.45)}
html[data-scheme="light"] .statLabel{color:rgba(14,11,36,.55)}

/* ── PLANET DECORATION (CSS-drawn animated) ── */
.planetDeco{
  position:relative;width:280px;height:280px;flex-shrink:0;pointer-events:none;
  animation:planetReveal .9s cubic-bezier(.16,1,.3,1) both,
             planetFloat 7s ease-in-out infinite .9s;
}
@keyframes planetReveal{
  from{opacity:0;transform:scale(.5) rotate(-25deg)}
  to{opacity:1;transform:scale(1) rotate(0deg)}
}
@keyframes planetFloat{
  0%,100%{transform:translateY(0) rotate(0deg)}
  50%{transform:translateY(-14px) rotate(3deg)}
}

/* Glow halo */
.planetGlow{
  position:absolute;inset:-25%;border-radius:50%;
  background:radial-gradient(circle,rgba(220,38,38,.18) 0%,rgba(109,40,217,.1) 50%,transparent 70%);
  animation:glowPulse 3.5s ease-in-out infinite;
}
@keyframes glowPulse{
  0%,100%{opacity:.7;transform:scale(1)}
  50%{opacity:1;transform:scale(1.08)}
}

/* Ring back (behind planet) */
.planetRingBack{
  position:absolute;top:50%;left:50%;
  width:160%;height:32%;
  transform:translate(-50%,-50%) rotateX(72deg);
  border-radius:50%;
  border:14px solid rgba(160,30,30,.35);
  border-left-color:transparent;border-right-color:transparent;
  filter:blur(1px);
}

/* Planet body */
.planetBody{
  position:absolute;top:20%;left:20%;width:60%;height:60%;
  border-radius:50%;
  background:
    radial-gradient(ellipse 40% 38% at 32% 30%, #ff9966, transparent),
    radial-gradient(ellipse 70% 70% at 50% 50%, #dc2626 0%, #7f1d1d 55%, #3b0808 100%);
  box-shadow:
    0 0 50px rgba(220,38,38,.5),
    0 0 90px rgba(220,38,38,.2),
    inset -18px -10px 28px rgba(0,0,0,.55);
  overflow:hidden;
}
/* crater spots */
.planetBody::before{
  content:"";position:absolute;
  width:18%;height:18%;border-radius:50%;
  top:25%;left:30%;
  background:rgba(0,0,0,.18);
  box-shadow:
    40px 10px 0 5px rgba(0,0,0,.12),
    -20px 30px 0 3px rgba(0,0,0,.1),
    25px -10px 0 4px rgba(0,0,0,.09);
}

/* Ring front (over planet) */
.planetRingFront{
  position:absolute;top:50%;left:50%;
  width:160%;height:32%;
  transform:translate(-50%,-50%) rotateX(72deg);
  border-radius:50%;
  border:14px solid transparent;
  border-top-color:rgba(220,38,38,.8);
  border-right-color:rgba(220,38,38,.6);
  box-shadow:0 0 18px rgba(220,38,38,.4);
}
.planetRingFront2{
  position:absolute;top:50%;left:50%;
  width:135%;height:25%;
  transform:translate(-50%,-50%) rotateX(72deg);
  border-radius:50%;
  border:7px solid transparent;
  border-top-color:rgba(248,113,113,.55);
  border-right-color:rgba(248,113,113,.4);
}

/* Planet used on hero */
.heroPlanet{
  position:absolute;right:-40px;top:50%;transform:translateY(-50%);
  z-index:0;opacity:.85;
}
@media(max-width:900px){.heroPlanet{display:none}}

/* ── CRACK BADGE ── */
.crackBadge{
  display:inline-flex;align-items:center;gap:6px;
  padding:4px 12px;border-radius:99px;
  background:rgba(220,38,38,.12);border:1px solid rgba(220,38,38,.3);
  font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;
  color:var(--c3);
}
.crackBadge svg{width:11px;height:11px;stroke:var(--c3);fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}

/* ── SHOP KITS ── */
.kitCard{
  grid-column:span 4;position:relative;text-align:center;
}
@media(max-width:1040px){.kitCard{grid-column:span 4}}
@media(max-width:760px){.kitCard{grid-column:span 6}}
@media(max-width:480px){.kitCard{grid-column:span 12}}
.kitBanner{
  position:absolute;top:-1px;left:50%;transform:translateX(-50%);
  background:linear-gradient(90deg,var(--a1),var(--c2));
  padding:3px 12px;border-radius:0 0 9px 9px;
  font-size:9px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;
  color:#fff;white-space:nowrap;z-index:2;
}

/* ── JOIN TEAM SECTION ── */
.joinTeamFull{
  grid-column:span 12;
  text-align:center;padding:40px 20px;
}

/* langMenu light mode */
html[data-scheme="light"] .langMenu{background:rgba(244,240,255,.97);border-color:rgba(109,40,217,.14)}

/* ═══════════════════════════════════════════
   LOADING SCREEN
═══════════════════════════════════════════ */
#cosmicLoader{
  position:fixed;inset:0;z-index:9999;
  background:#05000f;
  display:flex;align-items:center;justify-content:center;flex-direction:column;
  transition:opacity .55s ease,visibility .55s ease;
}
#cosmicLoader.out{opacity:0;visibility:hidden;pointer-events:none}
.loaderPlanet{
  width:150px;height:150px;border-radius:50%;overflow:hidden;
  position:relative;
  box-shadow:0 0 70px rgba(220,38,38,.65),0 0 140px rgba(109,40,217,.25);
  margin-bottom:28px;
  animation:loaderSlideUp .7s cubic-bezier(.16,1,.3,1) both;
}
.loaderPlanet img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;border-radius:50%;
  animation:planet2DImg 10s linear infinite;
}
.loaderPlanet img.broken{display:none}
.loaderPlanetCSS{
  position:absolute;inset:0;
  border-radius:50%;overflow:hidden;
  background:radial-gradient(ellipse 70% 70% at 50% 50%, #dc2626 0%, #7f1d1d 55%, #2a0000 100%);
}
.loaderPlanetCSS::before{
  content:"";
  position:absolute;top:0;left:-50%;
  width:200%;height:100%;
  background:
    radial-gradient(ellipse 20% 10% at 25% 38%,rgba(255,130,70,.7),transparent),
    radial-gradient(ellipse 12% 6% at 63% 62%,rgba(255,80,40,.5),transparent),
    linear-gradient(180deg,
      #1a0000 0%,#5a0a0a 10%,#7f1d1d 20%,
      #dc2626 30%,#b91c1c 42%,#991b1b 52%,
      #c81e1e 62%,#dc2626 72%,#991b1b 82%,#1a0000 100%);
  animation:planetSurfaceScroll 3s linear infinite;
}
.loaderPlanetCSS::after{
  content:"";position:absolute;inset:0;border-radius:50%;
  box-shadow:inset -50px -35px 70px rgba(0,0,0,.7);
}
.loaderTitle{
  font-size:2.2rem;font-weight:950;letter-spacing:.04em;
  background:linear-gradient(90deg,#a78bfa,#f87171);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  margin-bottom:4px;
  animation:loaderSlideUp .7s .15s cubic-bezier(.16,1,.3,1) both;
}
.loaderSub{
  font-size:13px;color:rgba(255,255,255,.35);font-weight:500;letter-spacing:.1em;text-transform:uppercase;
  animation:loaderSlideUp .7s .25s cubic-bezier(.16,1,.3,1) both;
}
.loaderDots{
  display:flex;gap:7px;margin-top:22px;
  animation:loaderSlideUp .7s .35s cubic-bezier(.16,1,.3,1) both;
}
.loaderDots span{
  width:7px;height:7px;border-radius:50%;
  background:var(--a2);
  animation:loaderDot 1.1s ease-in-out infinite;
}
.loaderDots span:nth-child(2){animation-delay:.15s}
.loaderDots span:nth-child(3){animation-delay:.3s}
@keyframes loaderDot{
  0%,80%,100%{transform:scale(.55);opacity:.3}
  40%{transform:scale(1);opacity:1}
}
@keyframes loaderSlideUp{
  from{opacity:0;transform:translateY(22px)}
  to{opacity:1;transform:translateY(0)}
}

/* ═══════════════════════════════════════════
   2D PLANET — fixed top-right
═══════════════════════════════════════════ */
.planet2D{
  position:fixed;top:-95px;right:-95px;
  width:420px;height:420px;
  border-radius:50%;overflow:hidden;
  pointer-events:none;z-index:0;
  animation:planet2DEntry 1.8s 1.2s cubic-bezier(.16,1,.3,1) both;
  box-shadow:
    0 0 0 2px rgba(220,38,38,.1),
    0 0 90px rgba(220,38,38,.4),
    0 0 200px rgba(220,38,38,.15),
    inset -80px -55px 100px rgba(0,0,0,.72);
}
.planet2DSurface{
  position:absolute;top:0;left:-50%;
  width:200%;height:100%;
  background:
    radial-gradient(ellipse 22% 9% at 28% 38%,rgba(255,130,70,.75),transparent),
    radial-gradient(ellipse 14% 6% at 66% 63%,rgba(255,80,40,.55),transparent),
    radial-gradient(ellipse 32% 5% at 82% 24%,rgba(180,40,15,.45),transparent),
    radial-gradient(ellipse 10% 10% at 15% 72%,rgba(255,100,50,.35),transparent),
    linear-gradient(180deg,
      #1a0000 0%,#4a0505 8%,#7f1d1d 17%,
      #dc2626 26%,#b91c1c 35%,#991b1b 44%,
      #7f1d1d 52%,#c81e1e 60%,#dc2626 68%,
      #991b1b 76%,#7f1d1d 85%,#3a0303 93%,#1a0000 100%
    );
  animation:planetSurfaceScroll 18s linear infinite;
}
.planet2DAtmo{
  position:absolute;inset:-8%;border-radius:50%;pointer-events:none;
  background:radial-gradient(circle at 50% 50%,transparent 48%,rgba(220,38,38,.09) 65%,rgba(109,40,217,.06) 80%,transparent 95%);
  animation:planet2DGlow 5s ease-in-out infinite;
}
.planet2DImg{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;border-radius:50%;
  animation:planet2DImg 30s linear infinite;
}
@keyframes planetSurfaceScroll{
  from{transform:translateX(0)}
  to{transform:translateX(50%)}
}
@keyframes planet2DImg{
  from{transform:rotate(0deg)}
  to{transform:rotate(360deg)}
}
@keyframes planet2DEntry{
  from{opacity:0;transform:scale(.25) translate(120px,-120px)}
  to{opacity:1;transform:scale(1) translate(0,0)}
}
@keyframes planet2DGlow{
  0%,100%{opacity:.7}
  50%{opacity:1}
}
@media(max-width:900px){
  .planet2D{width:240px;height:240px;top:-55px;right:-55px}
}
@media(max-width:600px){
  .planet2D{width:160px;height:160px;top:-35px;right:-35px}
}

/* ═══════════════════════════════════════════
   PURCHASE MODAL
═══════════════════════════════════════════ */
#buyModal{
  position:fixed;inset:0;z-index:4000;
  display:flex;align-items:center;justify-content:center;
  padding:16px;
  background:rgba(0,0,0,.75);backdrop-filter:blur(8px);
  opacity:0;visibility:hidden;
  transition:opacity .25s ease,visibility .25s ease;
}
#buyModal.open{opacity:1;visibility:visible}
.buyModalBox{
  background:var(--bg2);border:1px solid var(--stroke);
  border-radius:20px;padding:32px;
  max-width:440px;width:100%;
  position:relative;
  box-shadow:0 25px 80px rgba(0,0,0,.6),0 0 0 1px rgba(109,40,217,.15);
  transform:scale(.92);
  transition:transform .25s cubic-bezier(.16,1,.3,1);
}
#buyModal.open .buyModalBox{transform:scale(1)}
.buyModalClose{
  position:absolute;top:16px;right:16px;
  width:32px;height:32px;border-radius:50%;
  background:var(--bg3);border:none;cursor:pointer;color:var(--muted);
  display:flex;align-items:center;justify-content:center;
  transition:background .2s,color .2s;
}
.buyModalClose:hover{background:var(--stroke);color:var(--text)}
.buyModalProduct{
  display:flex;gap:14px;align-items:center;
  padding:16px;background:var(--bg3);border-radius:12px;margin-bottom:20px;
  border:1px solid var(--stroke);
}
.buyModalIcon{
  width:48px;height:48px;border-radius:12px;flex-shrink:0;
  background:linear-gradient(135deg,var(--a1),var(--c2));
  display:flex;align-items:center;justify-content:center;
  font-size:22px;
}
.buyModalName{font-size:16px;font-weight:800;color:var(--text)}
.buyModalPrice{font-size:22px;font-weight:950;color:var(--c3);margin-top:2px}
.buyModalSteps{margin-bottom:20px}
.buyModalSteps li{
  display:flex;gap:10px;align-items:flex-start;
  padding:8px 0;border-bottom:1px solid var(--stroke);
  font-size:13.5px;color:var(--muted-hi);line-height:1.5;
}
.buyModalSteps li:last-child{border-bottom:none}
.buyStepNum{
  width:22px;height:22px;border-radius:50%;flex-shrink:0;
  background:var(--a1);color:#fff;
  font-size:11px;font-weight:900;
  display:flex;align-items:center;justify-content:center;
  margin-top:1px;
}
.buyModalActions{display:flex;gap:10px}

/* ═══════════════════════════════════════════
   SOCIAL ROW — enhanced
═══════════════════════════════════════════ */
.socialRow{
  display:flex;flex-wrap:wrap;gap:8px;margin-top:14px;
}
.socialRow .btn{
  display:inline-flex;align-items:center;gap:7px;
  padding:9px 14px;border-radius:12px;font-size:13px;font-weight:700;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);
  color:var(--muted-hi);
  transition:background .2s,border-color .2s,color .2s,transform .15s;
}
.socialRow .btn:hover{
  background:rgba(255,255,255,.1);
  border-color:rgba(255,255,255,.2);
  color:#fff;transform:translateY(-2px);
}

/* ═══════════════════════════════════════════
   MODS PAGE — FEATURED SMP CARD
═══════════════════════════════════════════ */
.modCardFeatured{grid-column:span 12}
@media(max-width:700px){.modCardFeatured{grid-column:span 12}}

.modThumbFeatured{
  height:280px;position:relative;overflow:hidden;
  border-bottom:1px solid var(--stroke);
}
.modThumbFeatured::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg,#0a1628 0%,#0d2618 40%,#1a0a2e 100%);
  z-index:0;
}
.modThumbFeatured .thumbScene{
  position:absolute;inset:0;width:100%;height:100%;z-index:1;
}

/* Active badge pulse */
@keyframes activePulse{
  0%,100%{box-shadow:0 0 14px rgba(109,40,217,.5)}
  50%{box-shadow:0 0 32px rgba(109,40,217,.95),0 0 0 10px rgba(109,40,217,.07)}
}
.modeActiveBadge{animation:activePulse 2s ease-in-out infinite}

/* Stars twinkling */
@keyframes starTwinkle{
  0%,100%{opacity:.8}
  50%{opacity:.1}
}
.thumbStar{animation:starTwinkle var(--dur,3s) ease-in-out infinite}

/* Sword glow */
@keyframes swordGlowAnim{
  0%,100%{filter:drop-shadow(0 0 8px #67e8f9) drop-shadow(0 0 20px #5b21b6)}
  50%{filter:drop-shadow(0 0 20px #67e8f9) drop-shadow(0 0 45px #7c3aed)}
}
.thumbSword{animation:swordGlowAnim 3s ease-in-out infinite}

/* Floating hearts */
@keyframes heartFloat{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-10px)}
}
.thumbHeart{animation:heartFloat 4s ease-in-out infinite}
.thumbHeart2{animation:heartFloat 4s 1.8s ease-in-out infinite}

/* Lock overlay on locked thumbnails */
.modThumbLockOverlay{
  position:absolute;inset:0;z-index:5;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:rgba(0,0,0,.44);backdrop-filter:blur(1.5px);
  gap:8px;
}
.modThumbLockOverlay svg{width:50px;height:50px;color:rgba(255,255,255,.5)}
.modThumbLockText{
  font-size:10px;font-weight:800;letter-spacing:.15em;
  text-transform:uppercase;color:rgba(255,255,255,.4);
}

/* Override locked card global styles */
.modeLocked{opacity:1!important;pointer-events:none}
.modeLocked .modThumbLg{filter:grayscale(.6) brightness(.6)!important}
.modeLocked .pad{opacity:.65}

/* Bigger icons in locked thumbnails */
.modThumbLg svg{width:80px!important;height:80px!important;opacity:.92!important}

/* Particles sparkle in SMP scene */
@keyframes sparkleFloat{
  0%,100%{opacity:.7;transform:translateY(0) scale(1)}
  50%{opacity:.2;transform:translateY(-12px) scale(.6)}
}
.thumbSparkle{animation:sparkleFloat var(--dur,3s) ease-in-out infinite}
.thumbSparkle:nth-child(2){animation-delay:-1s}
.thumbSparkle:nth-child(3){animation-delay:-2s}
.thumbSparkle:nth-child(4){animation-delay:-.5s}

/* ═══════════════════════════════════════════
   HOME — Big title + Social buttons
═══════════════════════════════════════════ */
.homeMainTitle{
  font-size:clamp(2.8rem,7vw,5.5rem);
  font-weight:950;
  letter-spacing:.04em;
  line-height:1;
  margin-bottom:14px;
  background:linear-gradient(90deg,#a78bfa 0%,#f87171 50%,#a78bfa 100%);
  background-size:200% auto;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  animation:gradFlow 4s linear infinite;
}

.homeSocialBtn{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:8px;padding:16px 12px;
  border-radius:14px;text-decoration:none;
  font-size:13px;font-weight:800;
  border:1px solid transparent;
  transition:transform .18s,box-shadow .18s,opacity .18s;
}
.homeSocialBtn:hover{transform:translateY(-3px);opacity:.92}
.homeSocialBtn span{font-size:12px;font-weight:700}

.homeSocialDiscord{
  background:rgba(88,101,242,.2);
  border-color:rgba(88,101,242,.35);
  color:#a5b4fc;
  box-shadow:0 4px 20px rgba(88,101,242,.12);
}
.homeSocialDiscord:hover{box-shadow:0 8px 30px rgba(88,101,242,.25)}

.homeSocialYT{
  background:rgba(255,0,0,.15);
  border-color:rgba(255,50,50,.3);
  color:#fca5a5;
  box-shadow:0 4px 20px rgba(255,0,0,.1);
}
.homeSocialYT:hover{box-shadow:0 8px 30px rgba(255,0,0,.2)}

.homeSocialTwitch{
  background:rgba(145,70,255,.18);
  border-color:rgba(145,70,255,.32);
  color:#c4b5fd;
  box-shadow:0 4px 20px rgba(145,70,255,.1);
}
.homeSocialTwitch:hover{box-shadow:0 8px 30px rgba(145,70,255,.22)}
