/* =============================================
   MYSTERY BOX PREMIUM — main.css
   Versi: 1.0 | Pisahkan dari index.php
============================================= */

/* ---- VARIABLES ---- */
:root{
    --dark:#030508;--surface:#111827;--elevated:#162035;
    --border:rgba(255,255,255,0.06);--border2:rgba(255,255,255,0.14);
    --text:#f1f5ff;--text2:#8b97b0;--text3:#a0abbc;
    --gold:#f59e0b;--gold2:#fde68a;
    --purple:#8b5cf6;--purple2:#c4b5fd;
    --cyan:#06b6d4;--green:#10b981;--red:#ef4444;
    --t:all 0.32s cubic-bezier(0.4,0,0.2,1);
    --r:16px;--rl:24px;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Outfit',sans-serif;background:var(--dark);color:var(--text);overflow-x:hidden;min-height:100vh}

/* ---- BACKGROUND ---- */
.bg{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.bg-mesh{position:absolute;inset:0;background:
  radial-gradient(ellipse 900px 600px at 50% -100px,rgba(139,92,246,.18) 0%,transparent 70%),
  radial-gradient(ellipse 600px 400px at 90% 55%,rgba(245,158,11,.07) 0%,transparent 65%),
  radial-gradient(ellipse 500px 600px at -10% 85%,rgba(6,182,212,.07) 0%,transparent 65%),
  linear-gradient(180deg,#030508 0%,#07091a 40%,#030508 100%)}
.bg-grid{position:absolute;inset:0;opacity:.025;
  background-image:linear-gradient(var(--border2) 1px,transparent 1px),linear-gradient(90deg,var(--border2) 1px,transparent 1px);
  background-size:60px 60px}
.star{position:absolute;border-radius:50%;animation:twinkle var(--d,3s) ease-in-out infinite var(--dl,0s)}
@keyframes twinkle{0%,100%{opacity:.1;transform:scale(1)}50%{opacity:.7;transform:scale(1.4)}}
.fp{position:absolute;animation:fpUp var(--dr,8s) ease-in-out infinite var(--de,0s);opacity:0}
@keyframes fpUp{0%{opacity:0;transform:translateY(0) scale(.5)}20%{opacity:.5}80%{opacity:.15}100%{opacity:0;transform:translateY(-130px) scale(.2)}}

/* ---- RUNNING TEXT ---- */
.running-text-bar{
    position:relative;z-index:150;
    background:linear-gradient(90deg,#7c3aed,#9333ea,#7c3aed);
    overflow:hidden;height:32px;display:flex;align-items:center;
}
.running-text-track{
    display:flex;align-items:center;gap:0;
    animation:runText 30s linear infinite;
    white-space:nowrap;
}
@keyframes runText{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.running-text-item{
    font-size:12px;font-weight:600;color:rgba(255,255,255,.9);
    letter-spacing:1px;padding:0 32px;display:inline-flex;align-items:center;gap:8px;
}
.running-text-item::after{content:'✦';color:rgba(255,255,255,.4);padding-left:32px}

/* ---- HEADER ---- */
header{position:sticky;top:0;z-index:200;padding:13px 40px;
  background:rgba(3,5,8,.82);backdrop-filter:blur(24px) saturate(180%);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between}
.logo{display:flex;align-items:center;gap:12px}
.logo-box{width:42px;height:42px;border-radius:12px;
  background:linear-gradient(135deg,var(--purple),#6d28d9);
  display:flex;align-items:center;justify-content:center;font-size:20px;
  box-shadow:0 0 22px rgba(139,92,246,.4);animation:lPulse 4s ease-in-out infinite}
@keyframes lPulse{0%,100%{box-shadow:0 0 20px rgba(139,92,246,.3)}50%{box-shadow:0 0 40px rgba(139,92,246,.6)}}
.logo-nm{font-family:'Bebas Neue',sans-serif;font-size:26px;letter-spacing:2px;
  background:linear-gradient(90deg,#fff,var(--gold2));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.nav-r{display:flex;align-items:center;gap:10px}
.nbtn{padding:8px 18px;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;
  border:1px solid var(--border2);background:rgba(255,255,255,.04);color:var(--text2);
  transition:var(--t);font-family:'Outfit',sans-serif;text-decoration:none;
  display:inline-flex;align-items:center;gap:6px}
.nbtn:hover{border-color:var(--purple);color:var(--purple2);background:rgba(139,92,246,.08)}
.nbtn.gold{background:linear-gradient(135deg,var(--gold),#d97706);border:none;color:#000;font-weight:700}
.nbtn.gold:hover{filter:brightness(1.1);transform:translateY(-1px)}

/* ---- HERO ---- */
.hero{position:relative;z-index:10;text-align:center;padding:90px 20px 50px}
.hero-pill{display:inline-flex;align-items:center;gap:8px;
  background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.3);
  border-radius:100px;padding:6px 22px;font-size:12px;font-weight:700;
  color:var(--gold2);letter-spacing:1px;text-transform:uppercase;
  margin-bottom:28px;animation:fD .8s ease both}
@keyframes fD{from{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}
@keyframes fU{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
.hero-h1{font-family:'Bebas Neue',sans-serif;
  font-size:clamp(58px,11vw,112px);letter-spacing:3px;line-height:.93;
  margin-bottom:22px;animation:fU .8s ease .1s both}
.hero-h1 .l1{display:block;color:var(--text)}
.hero-h1 .l2{display:block;
  background:linear-gradient(135deg,var(--gold) 0%,#ff8c00 50%,var(--gold2) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  filter:drop-shadow(0 0 40px rgba(245,158,11,.4))}
.hero-sub{font-size:clamp(14px,2.5vw,18px);color:var(--text2);
  max-width:540px;margin:0 auto 52px;line-height:1.75;animation:fU .8s ease .2s both}

/* ---- CLAIM FORM ---- */
.claim-w{position:relative;z-index:10;max-width:580px;margin:0 auto 60px;padding:0 20px;animation:fU .8s ease .3s both}
.claim-c{background:linear-gradient(145deg,rgba(14,21,37,.97),rgba(10,16,28,.97));
  border:1px solid var(--border2);border-radius:var(--rl);padding:38px;
  backdrop-filter:blur(20px);
  box-shadow:0 24px 70px rgba(0,0,0,.55),inset 0 1px 0 rgba(255,255,255,.06);
  position:relative;overflow:hidden;transition:var(--t)}
.claim-c::before{content:'';position:absolute;top:0;left:10%;right:10%;height:1px;
  background:linear-gradient(90deg,transparent,var(--purple),var(--gold),transparent);opacity:.6}
.claim-c.validated{border-color:rgba(245,158,11,.35);box-shadow:0 24px 70px rgba(0,0,0,.55),0 0 60px rgba(245,158,11,.08),inset 0 1px 0 rgba(255,255,255,.06)}
.claim-t{font-family:'Bebas Neue',sans-serif;font-size:30px;letter-spacing:2px;text-align:center;margin-bottom:6px}
.claim-s{font-size:13px;color:var(--text3);text-align:center;margin-bottom:28px;transition:var(--t)}
.ig{margin-bottom:18px}
.il{display:block;font-size:11px;font-weight:700;color:var(--text2);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:8px}
.iw{position:relative}
.ii{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--text3);font-size:16px;pointer-events:none;transition:var(--t)}
.inf{width:100%;background:rgba(255,255,255,.04);border:1.5px solid rgba(255,255,255,.08);
  border-radius:12px;padding:13px 18px 13px 46px;color:var(--text);
  font-size:15px;font-family:'Outfit',sans-serif;font-weight:500;outline:none;transition:var(--t)}
.inf:focus{border-color:var(--purple);background:rgba(139,92,246,.06);box-shadow:0 0 0 4px rgba(139,92,246,.12)}
.inf:focus~.ii,.iw:focus-within .ii{color:var(--purple2)}
.inf.valid{border-color:var(--green)!important;background:rgba(16,185,129,.05)!important}
.inf.valid~.ii{color:var(--green)!important}
#cpnF{text-transform:uppercase;letter-spacing:3px;font-size:20px;font-weight:800;text-align:center;padding:16px;font-family:'Outfit',sans-serif}
.btn-open{width:100%;padding:17px;
  background:linear-gradient(135deg,#7c3aed 0%,#6d28d9 40%,#9333ea 100%);
  border:none;border-radius:12px;color:#fff;
  font-size:18px;font-weight:800;font-family:'Outfit',sans-serif;
  letter-spacing:.5px;cursor:pointer;transition:var(--t);
  position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;gap:12px;margin-top:22px}
.btn-open::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.15),transparent);opacity:0;transition:var(--t)}
.btn-open:hover::after{opacity:1}
.btn-open:hover{transform:translateY(-2px);box-shadow:0 14px 40px rgba(124,58,237,.55)}
.btn-open:active{transform:translateY(0)}
.btn-open.ld{pointer-events:none;opacity:.75}
.err{color:#fca5a5;font-size:13px;margin-top:12px;display:none;align-items:center;gap:7px;justify-content:center;text-align:center}
.spin{width:22px;height:22px;border:2.5px solid rgba(255,255,255,.25);border-top-color:#fff;border-radius:50%;animation:sp .6s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}

/* ---- STEP INDICATOR ---- */
.step-bar{display:none;align-items:center;justify-content:center;gap:0;margin:0 20px 40px;position:relative;z-index:10;animation:fU .5s ease both}
.step-bar.show{display:flex}
.step{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1;max-width:140px}
.step-circle{width:40px;height:40px;border-radius:50%;border:2px solid var(--border2);
  display:flex;align-items:center;justify-content:center;
  background:var(--surface);color:var(--text3);transition:var(--t);font-weight:700;font-size:14px;position:relative;z-index:1}
.step.done .step-circle{background:var(--green);border-color:var(--green);color:#fff}
.step.active .step-circle{background:linear-gradient(135deg,var(--gold),#d97706);border-color:var(--gold);color:#000;box-shadow:0 0 20px rgba(245,158,11,.5);animation:stepPulse 1.5s ease-in-out infinite}
@keyframes stepPulse{0%,100%{box-shadow:0 0 20px rgba(245,158,11,.4)}50%{box-shadow:0 0 40px rgba(245,158,11,.7)}}
.step-label{font-size:11px;font-weight:600;color:var(--text3);text-align:center;letter-spacing:.5px}
.step.done .step-label,.step.active .step-label{color:var(--text2)}
.step-line{flex:1;height:2px;background:var(--border2);margin:0 -2px;margin-top:-20px;position:relative;z-index:0;transition:var(--t);max-width:60px}
.step-line.done{background:var(--green)}

/* ---- BOXES SECTION ---- */
.sec{position:relative;z-index:10;max-width:960px;margin:0 auto;padding:0 16px}
.shd{text-align:center;margin-bottom:28px}
.sk{display:inline-flex;align-items:center;gap:8px;font-size:11px;font-weight:700;color:var(--gold);letter-spacing:3px;text-transform:uppercase;margin-bottom:10px}
.st{font-family:'Bebas Neue',sans-serif;font-size:clamp(32px,6vw,56px);letter-spacing:2px;margin-bottom:8px;
  background:linear-gradient(180deg,var(--text) 40%,var(--text3));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.sd{font-size:14px;color:var(--text3);max-width:420px;margin:0 auto;transition:var(--t)}
.pick-banner{display:none;margin:0 auto 24px;max-width:540px;
  background:linear-gradient(135deg,rgba(245,158,11,.12),rgba(245,158,11,.05));
  border:1px solid rgba(245,158,11,.35);border-radius:12px;padding:12px 20px;text-align:center;animation:fU .4s ease both}
.pick-banner.show{display:block}
.pick-banner-t{font-family:'Bebas Neue',sans-serif;font-size:20px;letter-spacing:2px;color:var(--gold2);margin-bottom:2px}
.pick-banner-s{font-size:12px;color:var(--text2)}
.bw{margin-bottom:48px}
.bg2{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}

/* ---- GIFT BOX ---- */
.gbox{position:relative;border-radius:14px;cursor:default;transition:var(--t);aspect-ratio:3/4;overflow:hidden;border:1px solid var(--border);background:#0b1120}
.gbox.idle{opacity:1;filter:none}
.gbox.selectable{cursor:pointer;opacity:1;filter:none;animation:boxIn .45s ease both}
@keyframes boxIn{from{opacity:0;transform:translateY(16px) scale(.92)}to{opacity:1;transform:translateY(0) scale(1)}}
.gbox.selectable:hover{transform:translateY(-7px) scale(1.03);z-index:5}
.gbox.selectable:hover .bc{background:linear-gradient(145deg,#1c1200,#2e1c00)!important}
.gbox.selectable:hover .bc-hint{opacity:1;transform:translateY(0)}
.gbox.selectable .bc::after{content:'';position:absolute;inset:0;border-radius:14px;
  background:linear-gradient(115deg,transparent 40%,rgba(255,255,255,.04) 50%,transparent 60%);
  background-size:250% 250%;animation:shimmer 2.2s linear infinite}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.gbox.chosen{z-index:10;transform:scale(1.06)!important;border-color:var(--gold)!important;
  box-shadow:0 0 0 2px rgba(245,158,11,.4),0 20px 60px rgba(245,158,11,.35)!important}
.gbox.faded{transform:scale(.97)!important;pointer-events:none}

/* Mystery cover */
.bc{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:linear-gradient(160deg,#0d1830 0%,#12213d 60%,#0a1520 100%);
  border-radius:14px;transition:var(--t);z-index:2;padding:12px}
.bc-n{position:absolute;top:8px;left:8px;width:24px;height:24px;border-radius:6px;
  background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;
  font-size:10px;font-weight:800;color:rgba(255,255,255,.35);backdrop-filter:blur(4px)}
.bc-svg{width:70%;aspect-ratio:1/1;margin-bottom:4px;transition:var(--t)}
.bc-svg-idle{display:block}.bc-svg-select{display:none}
.gbox.selectable .bc-svg-idle{display:none}.gbox.selectable .bc-svg-select{display:block}
.bc-lbl{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.3);margin-top:2px}
.bc-lock{position:absolute;width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.45);backdrop-filter:blur(3px);border-radius:14px;transition:var(--t)}
.bc-lock i{font-size:22px;color:rgba(255,255,255,.25)}
.gbox.selectable .bc-lock{opacity:0;pointer-events:none}
.bc-hint{position:absolute;bottom:10px;background:linear-gradient(135deg,rgba(245,158,11,.2),rgba(245,158,11,.1));
  border:1px solid rgba(245,158,11,.5);border-radius:20px;padding:3px 12px;
  font-size:10px;font-weight:800;color:var(--gold2);letter-spacing:1px;
  opacity:0;transform:translateY(4px);transition:var(--t);white-space:nowrap}

/* Revealed */
.gbox.rv .bc{opacity:0;pointer-events:none;transform:scale(.65) rotate(8deg)}
.br{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:12px;border-radius:14px;z-index:1}
.ri{width:58%;aspect-ratio:1/1;object-fit:contain;border-radius:10px;margin-bottom:8px;
  filter:drop-shadow(0 6px 18px rgba(0,0,0,.6));animation:rb .65s cubic-bezier(.175,.885,.32,1.275) both}
@keyframes rb{from{transform:scale(.2) rotate(-12deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}
.re{font-size:clamp(32px,5vw,44px);filter:drop-shadow(0 6px 14px rgba(0,0,0,.5));margin-bottom:8px;animation:rb .65s cubic-bezier(.175,.885,.32,1.275) both}
.rn{font-size:10px;font-weight:700;text-align:center;color:rgba(255,255,255,.9);line-height:1.3}
.rv2{font-size:9px;color:var(--gold);margin-top:3px;font-weight:700}
.wg{animation:wG 1.5s ease-in-out infinite alternate}
@keyframes wG{from{box-shadow:0 0 16px rgba(245,158,11,.3)}to{box-shadow:0 0 60px rgba(245,158,11,.8),0 0 100px rgba(245,158,11,.1)}}

/* Category colors */
.box-utama{border-color:rgba(245,158,11,.25)}.box-utama .bc,.box-utama .br{background:linear-gradient(160deg,#1a0c00,#2e1800)}.box-utama.selectable:hover{box-shadow:0 20px 50px rgba(245,158,11,.25)!important}
.box-favorit{border-color:rgba(139,92,246,.2)}.box-favorit .bc,.box-favorit .br{background:linear-gradient(160deg,#080420,#130838)}.box-favorit.selectable:hover{box-shadow:0 20px 50px rgba(139,92,246,.25)!important}
.box-hiburan{border-color:rgba(6,182,212,.12)}.box-hiburan .bc,.box-hiburan .br{background:linear-gradient(160deg,#020c18,#041828)}.box-hiburan.selectable:hover{box-shadow:0 20px 50px rgba(6,182,212,.2)!important}
.box-zonk{border-color:rgba(255,255,255,.04)}.box-zonk .bc,.box-zonk .br{background:linear-gradient(160deg,#0a0a0a,#151515)}

/* ---- CATALOG ---- */
.cat-box{background:linear-gradient(135deg,rgba(14,21,37,.7),rgba(10,16,28,.7));border:1px solid var(--border);border-radius:var(--rl);padding:34px;backdrop-filter:blur(10px);margin-bottom:100px}
.cat-t{font-family:'Bebas Neue',sans-serif;font-size:26px;letter-spacing:2px;margin-bottom:24px;display:flex;align-items:center;gap:10px}
.cat-g{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:12px}
.ci{display:flex;align-items:center;gap:12px;background:rgba(255,255,255,.025);border:1px solid var(--border);border-radius:12px;padding:14px;transition:var(--t)}
.ci:hover{background:rgba(255,255,255,.05);border-color:var(--border2);transform:translateY(-2px)}
.ci-img{width:50px;height:50px;border-radius:10px;object-fit:contain;background:rgba(0,0,0,.3);padding:4px;flex-shrink:0}
.ci-ico{width:50px;height:50px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:26px;flex-shrink:0}
.ci-n{font-size:13px;font-weight:600;margin-bottom:2px}
.ci-v{font-size:11px;color:var(--gold);font-weight:600}
.cbdg{margin-left:auto;flex-shrink:0;padding:3px 8px;border-radius:6px;font-size:10px;font-weight:700}
.cu{background:rgba(245,158,11,.15);color:var(--gold2)}
.cf{background:rgba(139,92,246,.15);color:var(--purple2)}
.ch{background:rgba(6,182,212,.15);color:#67e8f9}
.cz{background:rgba(255,255,255,.05);color:var(--text3)}

/* ---- RESULT MODAL ---- */
.ov{position:fixed;inset:0;background:rgba(0,0,0,.9);backdrop-filter:blur(16px);z-index:1000;display:none;align-items:center;justify-content:center;padding:20px}
.ov.show{display:flex}
.rm{position:relative;width:100%;max-width:500px;border-radius:28px;padding:52px 44px 44px;text-align:center;overflow:hidden;animation:rP .55s cubic-bezier(.175,.885,.32,1.275) both}
@keyframes rP{from{opacity:0;transform:scale(.6) translateY(50px)}to{opacity:1;transform:scale(1) translateY(0)}}
.rm.win{background:linear-gradient(160deg,#0a1428 0%,#17053a 50%,#0a1428 100%);border:1px solid rgba(245,158,11,.5);box-shadow:0 0 120px rgba(245,158,11,.2),0 40px 80px rgba(0,0,0,.8)}
.rm.zonk{background:linear-gradient(160deg,#0d1424,#111827);border:1px solid rgba(255,255,255,.1);box-shadow:0 40px 80px rgba(0,0,0,.8)}
.rx{position:absolute;top:18px;right:18px;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.06);border:1px solid var(--border2);color:var(--text2);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--t)}
.rx:hover{background:rgba(255,255,255,.12);color:var(--text)}
.cf2{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.cp{position:absolute;border-radius:2px;animation:cpF var(--d,3s) ease-in infinite var(--dl,0s);opacity:0}
@keyframes cpF{0%{opacity:1;transform:translateY(-10px) rotate(0deg)}100%{opacity:0;transform:translateY(520px) rotate(720deg)}}
.rgi{width:130px;height:130px;object-fit:contain;filter:drop-shadow(0 0 30px rgba(245,158,11,.6));animation:rIP .7s cubic-bezier(.175,.885,.32,1.275) .25s both;border-radius:16px;margin-bottom:18px}
@keyframes rIP{from{transform:scale(0) rotate(-20deg)}to{transform:scale(1) rotate(0)}}
.rge{font-size:96px;display:block;filter:drop-shadow(0 0 30px rgba(245,158,11,.6));animation:rIP .7s cubic-bezier(.175,.885,.32,1.275) .25s both;margin-bottom:18px}
.rt{font-family:'Bebas Neue',sans-serif;font-size:50px;letter-spacing:3px;background:linear-gradient(135deg,var(--gold),var(--gold2),var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:8px;animation:fU .4s ease .4s both}
.rt.zt{background:none;-webkit-text-fill-color:var(--text3);font-size:36px}
.rgn{font-size:26px;font-weight:800;color:var(--text);margin-bottom:6px;animation:fU .4s ease .48s both}
.rgv{font-size:16px;color:var(--gold2);font-weight:600;margin-bottom:22px;animation:fU .4s ease .54s both}
.ri2{background:rgba(255,255,255,.04);border:1px solid var(--border2);border-radius:12px;padding:15px 18px;margin-bottom:22px;font-size:13px;color:var(--text2);line-height:1.85;animation:fU .4s ease .58s both;text-align:left}
.ri2 strong{color:var(--text)}
.rbs{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;animation:fU .4s ease .62s both}
.rb2{padding:12px 26px;border-radius:12px;font-size:14px;font-weight:700;font-family:'Outfit',sans-serif;cursor:pointer;border:none;transition:var(--t)}
.rb2.p{background:linear-gradient(135deg,var(--purple),#6d28d9);color:#fff}
.rb2.p:hover{filter:brightness(1.12);transform:translateY(-1px)}
.rb2.s{background:rgba(255,255,255,.06);border:1px solid var(--border2);color:var(--text2)}
.rb2.s:hover{background:rgba(255,255,255,.1)}

/* ---- HISTORY ---- */
.hs{position:relative;z-index:10;max-width:820px;margin:0 auto;padding:0 20px 100px;display:none}
.hs.show{display:block}

/* ---- FOOTER ---- */
footer{position:relative;z-index:10;border-top:1px solid var(--border);padding:36px 40px 24px;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:16px}
.fl a{font-size:13px;color:var(--text3);text-decoration:none;margin-right:20px;transition:var(--t);cursor:pointer;background:none;border:none;font-family:'Outfit',sans-serif}
.fl a:hover,.fl button:hover{color:var(--purple2)}
.fc{width:100%;text-align:center;font-size:12px;color:var(--text3);padding-top:16px;border-top:1px solid var(--border);margin-top:8px}

/* ---- POPUP (footer modals) ---- */
.popup-overlay{position:fixed;inset:0;background:rgba(0,0,0,.85);backdrop-filter:blur(10px);z-index:2000;display:none;align-items:center;justify-content:center;padding:16px}
.popup-overlay.show{display:flex}
.popup-modal{background:linear-gradient(145deg,#0e1525,#111827);border:1px solid rgba(255,255,255,.1);border-radius:20px;width:100%;max-width:560px;max-height:88vh;display:flex;flex-direction:column;box-shadow:0 24px 80px rgba(0,0,0,.7);animation:popIn .3s cubic-bezier(.175,.885,.32,1.275) both}
@keyframes popIn{from{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}
.popup-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.07);flex-shrink:0}
.popup-title{font-family:'Bebas Neue',sans-serif;font-size:22px;letter-spacing:2px;color:var(--text);display:flex;align-items:center;gap:10px}
.popup-close{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:var(--text2);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--t)}
.popup-close:hover{background:rgba(239,68,68,.15);border-color:rgba(239,68,68,.4);color:#fca5a5}
.popup-body{overflow-y:auto;padding:24px;flex:1}
.popup-body::-webkit-scrollbar{width:4px}
.popup-body::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:2px}
.popup-body h3{font-size:13px;font-weight:700;color:var(--gold2);margin:16px 0 8px;padding-left:10px;border-left:3px solid var(--gold)}
.popup-body h3:first-child{margin-top:0}
.popup-body p{font-size:13px;color:var(--text2);line-height:1.7;margin-bottom:8px}
.popup-body ul{padding-left:18px;margin-bottom:12px}
.popup-body ul li{font-size:13px;color:var(--text2);line-height:1.7;margin-bottom:4px}
.popup-body ul li strong,.popup-body p strong{color:var(--text)}
.popup-body a{color:var(--purple2);text-decoration:underline}
/* Cara bermain step items */
.step-item{display:flex;gap:14px;align-items:flex-start;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:14px;margin-bottom:10px}
.sn{width:30px;height:30px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,var(--purple),#6d28d9);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;color:#fff}
.step-item strong{display:block;font-size:13px;font-weight:700;color:var(--text);margin-bottom:4px}
.step-item p{font-size:12px;color:var(--text2);line-height:1.6;margin:0}
.popup-footer{padding:16px 24px;border-top:1px solid rgba(255,255,255,.07);flex-shrink:0}
.popup-btn{width:100%;padding:13px;background:linear-gradient(135deg,var(--purple),#6d28d9);border:none;border-radius:10px;color:#fff;font-size:15px;font-weight:700;font-family:'Outfit',sans-serif;cursor:pointer;transition:var(--t);display:flex;align-items:center;justify-content:center;gap:8px}
.popup-btn:hover{filter:brightness(1.1);transform:translateY(-1px)}

/* ---- RESPONSIVE ---- */
@media(max-width:900px){.bg2{grid-template-columns:repeat(3,1fr);gap:10px}header{padding:13px 20px}}
@media(max-width:620px){
  .bg2{grid-template-columns:repeat(3,1fr);gap:8px}
  .claim-c{padding:24px}.hero{padding:60px 16px 24px}
  .rm{padding:36px 20px 30px}footer{padding:24px 16px}
  .bc-hint{display:none}.sec{padding:0 10px}
}
@media(max-width:400px){
  .bg2{grid-template-columns:repeat(3,1fr);gap:6px}
  .bc-fa,.re{font-size:22px}.ri{width:50%}.rn{font-size:9px}
}