*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;}
:root{
  --bg:rgba(6,6,10,.93);--bg2:rgba(8,8,14,.95);--panel:rgba(8,8,14,.90);--panel2:rgba(10,10,18,.93);
  --border:#263e5a;--border2:#365880;
  --gold:#ffd166;--gold2:#e09820;--gold-dark:#7a4800;
  --pink:#ff6eb4;--mint:#5effc8;--sky:#7ec8ff;--lavender:#a8c8ff;
  --text:#ffffff;--text2:#b8cce0;--text3:#d0dde8;
}
body{font-family:'Press Start 2P',monospace;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden;}
/* Background scene */
body::before{content:'';position:fixed;inset:-6px;
  background-image:url('../orig_big.png');
  background-size:cover;background-position:center top;background-repeat:no-repeat;
  /* Blurred + dimmed: creates depth behind the floating console panel */
  -webkit-mask:none;
  filter:blur(4px) brightness(.6) saturate(1.0);
  pointer-events:none;z-index:0;}
/* Scanlines + vignette */
body::after{content:'';position:fixed;inset:0;
  background:
    repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(0,0,0,.07) 3px,rgba(0,0,0,.07) 4px),
    radial-gradient(ellipse at center,transparent 60%,rgba(0,0,0,.2) 100%);
  pointer-events:none;z-index:9999;}
.header{background:linear-gradient(180deg,rgba(8,14,26,.92) 0%,rgba(6,12,22,.88) 100%);backdrop-filter:blur(4px);border-bottom:3px solid var(--gold2);padding:10px 14px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;box-shadow:0 4px 28px rgba(0,0,0,.7),0 1px 0 rgba(255,209,102,.08) inset;}
.logo{font-family:'Press Start 2P',monospace;font-size:14px;color:var(--gold);text-shadow:0 0 20px rgba(255,209,102,.6),3px 3px 0 var(--gold-dark);letter-spacing:2px;}
.set-badge{font-size:8px;color:var(--sky);background:rgba(126,200,255,.08);border:1px solid rgba(126,200,255,.22);padding:3px 7px;letter-spacing:2px;text-transform:uppercase;}
.coins-wrap{display:flex;align-items:center;gap:6px;background:linear-gradient(135deg,rgba(255,209,102,.12),rgba(255,209,102,.06));border:2px solid var(--gold2);padding:5px 10px 5px 7px;line-height:1;box-shadow:0 2px 0 var(--gold-dark),inset 0 1px 0 rgba(255,255,255,.1);}
.coin-val{font-family:'Press Start 2P',monospace;font-size:12px;color:var(--gold);min-width:36px;}
.nav{display:flex;background:linear-gradient(180deg,rgba(8,14,26,.9) 0%,rgba(6,12,22,.86) 100%);backdrop-filter:blur(4px);border-bottom:3px solid rgba(255,209,102,.2);position:relative;z-index:10;}
.nav-btn{flex:1;padding:8px 1px 6px;background:none;border:none;border-bottom:3px solid transparent;color:var(--text2);font-family:'Press Start 2P',monospace;font-size:7px;text-transform:uppercase;cursor:pointer;transition:color .15s,border-color .15s,background .15s;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:4px;min-width:0;line-height:1;}
.nav-btn .ni{font-size:16px;line-height:1;}
#nav-battle .ni{font-size:16px;width:16px;height:16px;display:flex;align-items:center;justify-content:center;overflow:hidden;}
.nav-btn.active{color:var(--gold);border-bottom-color:var(--gold);background:rgba(255,209,102,.06);}
.nav-btn:hover:not(.active){color:var(--sky);background:rgba(126,200,255,.04);}
.screen{display:none;padding:14px 12px;min-height:calc(100vh - 120px);position:relative;z-index:1;background:rgba(4,8,14,.45);text-shadow:0 1px 3px rgba(0,0,0,1),0 2px 8px rgba(0,0,0,.8);}
.screen.active{display:block;}
.btn{font-family:'Press Start 2P',monospace;border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:6px;color:#fff;transition:filter .1s,transform .08s,box-shadow .08s;}
.btn:active{transform:translateY(2px)!important;box-shadow:none!important;}
.btn-gold{background:var(--gold);box-shadow:0 4px 0 var(--gold-dark),3px 0 0 var(--gold2),3px 4px 0 var(--gold-dark);color:#2a1200;font-size:11px;padding:12px 20px;}
.btn-gold:hover{filter:brightness(1.12);}
.btn-blue{background:#4466dd;box-shadow:0 4px 0 #1a2a88,3px 0 0 #2244bb,3px 4px 0 #1a2a88;font-size:11px;padding:10px 18px;}
.btn-green{background:#1faa58;box-shadow:0 4px 0 #0a5a28,3px 0 0 #158844,3px 4px 0 #0a5a28;font-size:11px;padding:10px 18px;}
.btn-gray{background:#2e1e44;box-shadow:0 3px 0 #100a1c,2px 0 0 #221630,2px 3px 0 #100a1c;font-size:10px;padding:8px 14px;color:var(--text3);}
.btn:disabled{opacity:.35;cursor:not-allowed;transform:none!important;box-shadow:none!important;}
.btn-sm{font-size:9px!important;padding:7px 12px!important;}
.sl{font-family:'Press Start 2P',monospace;font-size:9px;color:var(--gold);text-transform:uppercase;letter-spacing:2px;margin-bottom:12px;display:flex;align-items:center;gap:10px;
  background:linear-gradient(90deg,rgba(6,6,10,.88) 0%,rgba(6,6,10,.7) 60%,rgba(6,6,10,.3) 100%);
  border-left:3px solid var(--gold);padding:7px 10px 7px 12px;}
.sl::before{content:'◆';font-size:7px;color:var(--gold);}
.sl::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,rgba(255,209,102,.3),transparent);}
.season-tabs{display:flex;gap:6px;margin-bottom:12px;overflow-x:auto;padding-bottom:4px;}
.season-tab{flex-shrink:0;font-family:'Press Start 2P',monospace;font-size:9px;padding:8px 14px;border:2px solid var(--border);border-bottom:3px solid var(--border);background:rgba(6,6,10,.88);color:var(--text2);cursor:pointer;text-transform:uppercase;transition:all .1s;box-shadow:0 3px 0 rgba(0,0,0,.5);}
.season-tab.active{border-color:var(--gold);border-bottom-color:var(--gold-dark);color:var(--gold);background:rgba(8,6,0,.88);box-shadow:0 3px 0 var(--gold-dark);}
.season-header{background:linear-gradient(135deg,#162438 0%,#1c2e4a 50%,#162438 100%);border:2px solid rgba(255,209,102,.28);border-left:4px solid var(--gold);padding:16px 14px;margin-bottom:14px;display:flex;align-items:center;gap:14px;position:relative;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.06);}
.season-header::before{content:'';position:absolute;top:0;right:0;width:40%;height:100%;background:linear-gradient(270deg,rgba(255,209,102,.06) 0%,transparent 100%);pointer-events:none;}
.season-header::after{content:'◆  ◆  ◆';position:absolute;bottom:7px;right:14px;font-size:6px;color:rgba(255,209,102,.2);letter-spacing:8px;}
.season-icon{font-size:38px;filter:drop-shadow(0 0 10px rgba(255,209,102,.5));}
.season-title{font-family:'Press Start 2P',monospace;font-size:12px;color:var(--gold);margin-bottom:6px;text-shadow:0 0 16px rgba(255,209,102,.4),2px 2px 0 var(--gold-dark);}
.season-sub{font-size:9px;color:var(--text3);line-height:2.2;}
.pack-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px;}
.pack-option{background:linear-gradient(160deg,#162438 0%,#1c2e4a 100%);border:2px solid var(--border2);padding:0 0 12px;text-align:center;cursor:pointer;transition:all .16s;position:relative;overflow:hidden;display:flex;flex-direction:column;align-items:center;box-shadow:0 4px 0 #080e18,0 6px 18px rgba(0,0,0,.4);}
/* Diagonal shine streak — CR signature */
.pack-option::before{content:'';position:absolute;top:-30px;left:-40px;width:60px;height:200%;background:linear-gradient(105deg,transparent 30%,rgba(255,255,255,.06) 50%,transparent 70%);pointer-events:none;z-index:1;transition:left .3s ease;}
.pack-option:hover::before{left:120%;}
.pack-option:hover{border-color:var(--sky);transform:translateY(-4px);box-shadow:0 8px 0 #080e18,0 12px 28px rgba(14,60,100,.5);}
.pack-option.selected{border-color:var(--gold);box-shadow:0 4px 0 var(--gold-dark),0 6px 20px rgba(255,209,102,.2);}
.pack-option-icon{width:100%;display:flex;align-items:center;justify-content:center;padding:16px 0 10px;background:linear-gradient(180deg,rgba(0,0,0,.25) 0%,transparent 100%);}
.pack-option-icon img{height:120px;width:auto;image-rendering:pixelated;filter:drop-shadow(0 4px 12px rgba(0,0,0,.6));transition:transform .16s;}
.pack-option:hover .pack-option-icon img{transform:translateY(-4px) scale(1.04);}
.pack-option-name{font-family:'Press Start 2P',monospace;font-size:9px;color:var(--text);margin-top:2px;margin-bottom:5px;line-height:1.8;}
.pack-option-price{font-family:'Press Start 2P',monospace;font-size:11px;color:var(--gold);text-shadow:0 0 10px rgba(255,209,102,.3);}
.pack-option-desc{display:none;}
.pack-option.free-badge::after{content:'FREE';position:absolute;top:0;right:0;background:var(--mint);color:#002a18;font-family:'Press Start 2P',monospace;font-size:7px;padding:4px 7px;}
.pack-rarity-strip{display:flex;width:100%;height:6px;margin-top:8px;border:1px solid rgba(255,255,255,.06);overflow:hidden;}
.pack-rarity-seg{height:100%;transition:width .3s ease;}
.pack-highlight{font-family:'Press Start 2P',monospace;font-size:8px;margin-top:6px;padding:3px 6px;border:1px solid;letter-spacing:.5px;}
.pack-odds-row{display:flex;justify-content:space-between;width:100%;margin-top:6px;gap:2px;}
.pack-odds-cell{flex:1;text-align:center;}
.pack-odds-pct{font-family:'Press Start 2P',monospace;font-size:8px;font-weight:900;}
.pack-odds-label{font-family:'Press Start 2P',monospace;font-size:7px;color:var(--text2);margin-top:1px;}
.daily-section{background:linear-gradient(135deg,rgba(94,255,200,.04) 0%,rgba(126,200,255,.03) 100%);border:2px solid rgba(94,255,200,.13);padding:12px 14px;margin-bottom:12px;}
.daily-title{font-family:'Press Start 2P',monospace;font-size:9px;color:var(--mint);text-transform:uppercase;letter-spacing:1px;margin-bottom:10px;opacity:.75;}
.pack-opening-overlay{position:fixed;inset:0;background:radial-gradient(ellipse at center,#0e1e38 0%,#060e1a 100%);z-index:200;display:flex;flex-direction:column;align-items:center;padding:14px 12px 16px;overflow-y:auto;}
.opening-header{width:100%;max-width:380px;display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;}
/* Flat card grid */
.card-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;width:100%;max-width:380px;margin-bottom:10px;}
.grid-card{cursor:pointer;position:relative;transition:transform .18s cubic-bezier(.34,1.56,.64,1),filter .15s;border-radius:5px;aspect-ratio:.68;overflow:hidden;}
.grid-card:hover:not(.revealed){transform:translateY(-3px) scale(1.05);filter:brightness(1.15);}
.grid-card.revealed{cursor:default;}
.grid-card .card{position:absolute;inset:0;width:100%;height:100%;padding:6px 4px 4px;font-size:80%;}
.grid-card .card-back{position:absolute;inset:0;width:100%;height:100%;}
.grid-card .card .card-name{font-size:5px!important;}
.grid-card .card .card-type-badge{font-size:4px!important;padding:1px 3px!important;}
.grid-card .card .card-set{font-size:4px!important;}
.grid-card .card .card-grade{font-size:6px!important;}
.grid-card .card .foil-badge{font-size:4px!important;}
.grid-card .card .card-img-area{width:75%!important;}
.grid-card .card-back::after{font-size:16px!important;}
.grid-card.just-revealed{animation:cardPop .28s cubic-bezier(.34,1.56,.64,1) forwards;}
@keyframes cardPop{0%{transform:scale(.75);opacity:0}60%{transform:scale(1.06)}100%{transform:scale(1);opacity:1}}
/* Card back */
.card-back{width:100%;aspect-ratio:.68;border-radius:5px;border:2px solid var(--border2);background:url('../art/card/Back.png') center/cover no-repeat;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;box-shadow:2px 2px 0 #04080f,0 4px 12px rgba(0,0,0,.7);}
.card-back::before{content:none;}
.card-back::after{content:none;}
.card-back.energy-back::after{content:none;}
/* Preview panel */
.card-preview-panel{width:100%;max-width:150px;margin:0 auto 10px;min-height:40px;display:flex;align-items:center;justify-content:center;}
/* Actions row */
.opening-actions-row{display:flex;gap:8px;width:100%;max-width:380px;}
.opening-title{font-family:'Press Start 2P',monospace;font-size:11px;color:var(--gold);text-shadow:0 0 16px rgba(255,209,102,.5);}
.opening-count{font-family:'Press Start 2P',monospace;font-size:7px;color:var(--text2);}
.card{padding:10px 8px 8px;display:flex;flex-direction:column;align-items:center;gap:4px;position:relative;border:3px solid transparent;width:100%;aspect-ratio:.68;justify-content:space-between;}
.card.flip-in{animation:flipIn .5s cubic-bezier(.34,1.56,.64,1) forwards;}
@keyframes flipIn{0%{transform:rotateY(90deg) scale(.6);opacity:0;}60%{transform:rotateY(-6deg) scale(1.05);}100%{transform:rotateY(0) scale(1);opacity:1;}}
.card.legendary-shine::after{content:'';position:absolute;inset:0;background:repeating-linear-gradient(45deg,rgba(255,255,255,.03) 0px,rgba(255,255,255,.03) 2px,transparent 2px,transparent 8px);pointer-events:none;}
.card.foil{animation:lp 2.5s ease-in-out infinite;}
.card.foil::before{content:'';position:absolute;inset:0;z-index:3;pointer-events:none;border-radius:2px;
  background:
    repeating-linear-gradient(0deg,
      rgba(255,0,128,.07) 0px,rgba(255,128,0,.07) 4px,
      rgba(0,255,128,.07) 8px,rgba(0,128,255,.07) 12px,
      rgba(128,0,255,.07) 16px,rgba(255,0,128,.07) 20px),
    repeating-linear-gradient(90deg,rgba(255,255,255,.025) 0px,transparent 2px,transparent 8px,rgba(255,255,255,.025) 10px);
  background-size:100% 20px,10px 100%;
  mix-blend-mode:screen;
  animation:rippleMove 1.8s linear infinite;}
.card.foil::after{content:'';position:absolute;inset:0;z-index:4;pointer-events:none;
  background:repeating-linear-gradient(45deg,rgba(255,255,255,.05) 0px,rgba(255,255,255,.05) 1px,transparent 1px,transparent 5px);
  mix-blend-mode:overlay;}
@keyframes rippleMove{
  0%{background-position:0 0,0 0;filter:hue-rotate(0deg);}
  100%{background-position:0 20px,0 0;filter:hue-rotate(360deg);}
}
.foil-badge{position:absolute;top:4px;left:4px;font-family:'Press Start 2P',monospace;font-size:5px;padding:2px 4px;
  background:linear-gradient(90deg,#ff3296,#50c8ff,#64ff96,#ffc832,#c850ff);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  filter:drop-shadow(0 0 4px rgba(255,255,255,.5));letter-spacing:1px;animation:badgeHolo 2s linear infinite;}
@keyframes badgeHolo{
  0%{filter:hue-rotate(0deg) drop-shadow(0 0 3px rgba(255,255,255,.5));}
  100%{filter:hue-rotate(360deg) drop-shadow(0 0 5px rgba(255,255,255,.8));}
}
.tray-card.foil-tray{outline:2px solid transparent;animation:foilBorder 3s ease-in-out infinite alternate;}
@keyframes foilBorder{0%{outline-color:rgba(255,50,150,.6);}33%{outline-color:rgba(80,200,255,.6);}66%{outline-color:rgba(100,255,150,.6);}100%{outline-color:rgba(255,200,50,.6);}}
.card-top-bar{width:100%;height:3px;}
.card-img-area{width:80%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.35);border:2px solid rgba(255,255,255,.07);overflow:hidden;position:relative;}
.card-img-area img{width:100%;height:100%;object-fit:contain;image-rendering:pixelated;}
.card-name{font-family:'Press Start 2P',monospace;font-size:7px;text-align:center;line-height:1.6;width:100%;}
.card-type-badge{font-family:'Press Start 2P',monospace;font-size:6px;padding:2px 5px;text-transform:uppercase;}
.card-grade{font-family:'Press Start 2P',monospace;font-size:9px;padding:2px 6px;}
.card-set{font-family:'Press Start 2P',monospace;font-size:6px;color:rgba(255,255,255,.22);text-align:center;}
.rarity-common{background:#0e1020;border-color:#2a3460;}
.rarity-uncommon{background:#091614;border-color:#0e4430;}
.rarity-rare{background:#090a28;border-color:#1020a0;}
.rarity-epic{background:#150828;border-color:#6614c0;}
.rarity-legendary{background:#180c00;border-color:var(--gold);box-shadow:0 0 0 1px var(--gold-dark),3px 3px 0 #2d1600;animation:lp 2.5s ease-in-out infinite;}
@keyframes packFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes lp{0%,100%{box-shadow:0 0 0 1px var(--gold-dark),3px 3px 0 #2d1600,0 0 14px rgba(255,209,102,.2)}50%{box-shadow:0 0 0 2px var(--gold),3px 3px 0 var(--gold-dark),0 0 28px rgba(255,209,102,.5)}}
.rarity-energy{background:#080e0c;border-color:#0e3a24;}
.grade-10{background:var(--gold);color:#1a0800;}.grade-9{background:#e09010;color:#0a0400;}.grade-8{background:#1a9448;color:#eaffee;}
.grade-7{background:#0e6830;color:#fff;}.grade-6{background:#1030aa;color:#fff;}.grade-5{background:#4010b0;color:#fff;}
.grade-4{background:#6e10b0;color:#fff;}.grade-3{background:#aa107a;color:#fff;}.grade-2{background:#aa1010;color:#fff;}.grade-1{background:#181426;color:#4a3860;}
.collection-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;flex-wrap:wrap;gap:8px;}
.collection-title{font-family:'Press Start 2P',monospace;font-size:11px;color:var(--text);}
.collection-stats{font-family:'Press Start 2P',monospace;font-size:9px;color:var(--lavender);opacity:.7;}
.filter-row{display:flex;gap:4px;margin-bottom:14px;flex-wrap:wrap;}
.filter-chip{font-family:'Press Start 2P',monospace;font-size:8px;padding:6px 10px;border:1px solid var(--border);background:rgba(6,6,10,.85);color:var(--text2);cursor:pointer;text-transform:uppercase;transition:all .1s;}
.filter-chip:hover{border-color:var(--sky);color:var(--sky);}
.filter-chip.active{border-color:var(--gold);color:var(--gold);background:rgba(255,209,102,.08);}
.dex-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;}
.dex-card{background:var(--panel);border:2px solid var(--border);padding:10px 6px;text-align:center;cursor:pointer;transition:all .14s;position:relative;display:flex;flex-direction:column;align-items:center;gap:3px;}
.dex-card:hover:not(.unowned){transform:translateY(-3px) scale(1.02);box-shadow:0 6px 20px rgba(20,60,120,.6);}
.dex-card.unowned{opacity:.18;cursor:default;filter:grayscale(1);}
.owned-count{position:absolute;top:4px;right:4px;background:var(--gold);color:#1a0800;font-family:'Press Start 2P',monospace;font-size:7px;width:17px;height:17px;display:flex;align-items:center;justify-content:center;}
.dex-icon{font-size:28px;line-height:1;display:flex;align-items:center;justify-content:center;height:56px;}
.dex-name{font-family:'Press Start 2P',monospace;font-size:9px;line-height:1.6;}
.dex-type{font-family:'Press Start 2P',monospace;font-size:8px;padding:2px 5px;text-transform:uppercase;}
.dex-rarity-strip{width:60%;height:2px;margin:2px auto 0;}
.dex-rarity-label{font-family:'Press Start 2P',monospace;font-size:8px;}
.dex-number{font-family:'Press Start 2P',monospace;font-size:7px;color:var(--text2);}
.dex-rarity-common{border-color:#2a3460;}.dex-rarity-uncommon{border-color:#0e4430;}.dex-rarity-rare{border-color:#1020a0;}
.dex-rarity-epic{border-color:#6614c0;}.dex-rarity-legendary{border-color:var(--gold);}.dex-rarity-energy{border-color:#0e3a24;}
.modal-overlay{position:fixed;inset:0;background:rgba(4,8,20,.92);z-index:300;display:flex;align-items:center;justify-content:center;padding:16px;}
.modal{background:var(--panel2);border:2px solid var(--border2);border-top:3px solid var(--sky);box-shadow:0 0 0 1px var(--border),0 20px 60px rgba(0,0,0,.8);width:100%;max-width:420px;padding:18px;max-height:85vh;overflow-y:auto;animation:mPop .14s ease forwards;position:relative;}
@keyframes mPop{from{transform:scale(.88) translateY(8px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}
.modal-close{position:absolute;top:12px;right:12px;width:22px;height:22px;background:var(--border);border:1px solid var(--border2);color:var(--text2);font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;}
.modal-close:hover{color:var(--pink);}
.card-image-modal{position:fixed;inset:0;background:rgba(4,2,10,.97);z-index:1000;display:flex;align-items:center;justify-content:center;cursor:pointer;perspective:900px;}
.card-image-modal-inner{max-width:360px;width:94%;position:relative;transition:transform 0.06s ease,box-shadow 0.08s ease;border-radius:10px;}
.psa-slab{
  position:relative;
  border-radius:6px;
  background:linear-gradient(160deg,rgba(200,220,255,.18) 0%,rgba(180,210,255,.08) 40%,rgba(160,200,255,.13) 100%);
  border:2px solid rgba(180,210,255,.45);
  box-shadow:0 0 0 1px rgba(255,255,255,.08),0 8px 32px rgba(0,0,0,.7),inset 0 1px 0 rgba(255,255,255,.25),inset 0 -1px 0 rgba(255,255,255,.08);
  padding:10px 10px 38px 10px;
}
.psa-slab::before{
  content:'';position:absolute;inset:0;border-radius:6px;
  background:linear-gradient(120deg,rgba(255,255,255,.13) 0%,transparent 50%,rgba(255,255,255,.06) 100%);
  pointer-events:none;z-index:2;
}
.psa-slab-label{
  position:absolute;bottom:0;left:0;right:0;height:36px;
  background:linear-gradient(90deg,#00004a 0%,#0000a0 40%,#0000c8 60%,#00004a 100%);
  border-top:2px solid rgba(100,140,255,.5);
  border-radius:0 0 4px 4px;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 10px;z-index:3;
}
.psa-slab-label-text{font-family:'Press Start 2P',monospace;font-size:6px;color:#aac8ff;letter-spacing:1px;text-transform:uppercase;}
.psa-slab-grade{font-family:'Press Start 2P',monospace;font-size:11px;letter-spacing:1px;}
.psa-slab .card{border-radius:3px;position:relative;z-index:1;}
.owned-cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:10px;}
/* ── PROFILE ── */
.profile-btn{display:none;align-items:center;gap:6px;background:rgba(196,168,255,.07);border:1px solid var(--border2);padding:4px 8px 4px 4px;cursor:pointer;transition:all .14s;flex-shrink:0;}
.profile-btn:hover{border-color:var(--lavender);background:rgba(196,168,255,.14);}
.profile-avatar{width:22px;height:22px;display:flex;align-items:center;justify-content:center;font-size:16px;border-radius:2px;background:var(--panel2);border:1px solid var(--border2);flex-shrink:0;}
.profile-name{font-family:'Press Start 2P',monospace;font-size:8px;color:var(--text2);max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.profile-modal{position:fixed;inset:0;background:rgba(8,4,18,.92);z-index:400;display:flex;align-items:flex-start;justify-content:center;padding:12px;overflow-y:auto;}
.profile-modal-box{background:var(--panel2);border:2px solid var(--border2);width:100%;max-width:560px;padding:20px;animation:mPop .14s ease forwards;position:relative;margin-top:40px;box-sizing:border-box;}
.profile-section-title{font-family:'Press Start 2P',monospace;font-size:9px;color:var(--lavender);text-transform:uppercase;letter-spacing:2px;margin:14px 0 8px;display:flex;align-items:center;gap:8px;}
.profile-section-title::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,rgba(196,168,255,.25),transparent);}
.profile-avatar-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;}
.profile-avatar-option{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;background:var(--panel);border:2px solid var(--border);cursor:pointer;transition:all .12s;padding:8px;}
.profile-avatar-option:hover{border-color:var(--lavender);transform:scale(1.05);}
.profile-avatar-option.owned{border-color:var(--border2);}
.profile-avatar-option.equipped{border-color:var(--gold);background:rgba(255,209,102,.06);}
.profile-avatar-option.locked{opacity:.4;cursor:default;}
.profile-avatar-price{font-family:'Press Start 2P',monospace;font-size:7px;color:var(--gold);}
.profile-title-grid{display:flex;flex-direction:column;gap:6px;}
.profile-title-option{display:flex;align-items:center;justify-content:space-between;background:var(--panel);border:2px solid var(--border);padding:11px 14px;cursor:pointer;transition:all .12s;}
.profile-title-option:hover{border-color:var(--lavender);}
.profile-title-option.equipped{border-color:var(--gold);background:rgba(255,209,102,.06);}
.profile-title-option.locked{opacity:.4;cursor:default;}
.profile-title-name{font-family:'Press Start 2P',monospace;font-size:9px;}
.profile-title-price{font-family:'Press Start 2P',monospace;font-size:8px;color:var(--gold);}
.profile-preview{display:flex;align-items:center;gap:10px;background:var(--panel);border:2px solid var(--border2);padding:10px 12px;margin-bottom:4px;}
.profile-preview-avatar{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:26px;border:2px solid var(--border2);background:var(--bg);border-radius:3px;}
.profile-preview-info{display:flex;flex-direction:column;gap:4px;}
.profile-preview-name{font-family:'Press Start 2P',monospace;font-size:9px;color:var(--text);}
.profile-preview-title{font-family:'Press Start 2P',monospace;font-size:6px;color:var(--lavender);}
/* ── AUTH SCREEN ── */
.auth-overlay{position:fixed;inset:0;background:radial-gradient(ellipse at 50% 30%,#0e1e38 0%,#060c18 100%);z-index:1000;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;}
.auth-box{width:100%;max-width:360px;background:#162438;border:2px solid var(--border2);border-top:3px solid var(--gold2);padding:28px 22px;display:flex;flex-direction:column;gap:14px;box-shadow:0 8px 0 #080e18,0 12px 40px rgba(0,0,0,.7);}
.auth-logo{font-family:'Press Start 2P',monospace;font-size:18px;color:var(--gold);text-shadow:0 0 18px rgba(255,209,102,.5),3px 3px 0 var(--gold-dark);letter-spacing:2px;text-align:center;margin-bottom:4px;}
.auth-sub{font-family:'Press Start 2P',monospace;font-size:9px;color:var(--text2);text-align:center;line-height:2;}
.auth-label{font-family:'Press Start 2P',monospace;font-size:9px;color:var(--text3);margin-bottom:4px;display:block;}
.auth-input{width:100%;background:#0a1422;border:2px solid var(--border);color:var(--text);font-family:'Press Start 2P',monospace;font-size:9px;padding:10px 12px;outline:none;transition:border-color .15s;}
.auth-input:focus{border-color:var(--sky);}
.auth-input::placeholder{color:var(--text2);opacity:.5;}
.auth-toggle{font-family:'Press Start 2P',monospace;font-size:9px;color:var(--lavender);text-align:center;cursor:pointer;text-decoration:underline;background:none;border:none;}
.auth-toggle:hover{color:var(--gold);}
.auth-err{font-family:'Press Start 2P',monospace;font-size:9px;color:var(--pink);text-align:center;line-height:1.8;min-height:14px;}
/* ── BATTLE ── */
@keyframes battleCardIn{0%{transform:translateY(-20px) scale(.8);opacity:0;}60%{transform:translateY(4px) scale(1.05);}100%{transform:translateY(0) scale(1);opacity:1;}}
@keyframes battleClash{0%{transform:scale(0) rotate(-10deg);opacity:0;} 40%{transform:scale(1.5) rotate(5deg);opacity:1;} 70%{transform:scale(1.1) rotate(-2deg);} 100%{transform:scale(0) rotate(10deg);opacity:0;}}
@keyframes cpuThink{0%,100%{opacity:.3;transform:scale(.9);} 50%{opacity:1;transform:scale(1.1);}}
@keyframes battleShake{0%,100%{transform:translateX(0);} 20%{transform:translateX(-5px);} 40%{transform:translateX(5px);} 60%{transform:translateX(-3px);} 80%{transform:translateX(3px);}}
.battle-card-reveal{animation:battleCardIn .35s cubic-bezier(.34,1.56,.64,1) forwards;}
.battle-clash-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(0);font-size:36px;pointer-events:none;z-index:10;animation:battleClash .65s ease forwards;}
.cpu-thinking{display:flex;gap:5px;align-items:center;justify-content:center;padding:6px 0;}
.cpu-thinking-dot{width:7px;height:7px;border-radius:50%;background:var(--lavender);animation:cpuThink .5s ease-in-out infinite;}
.cpu-thinking-dot:nth-child(2){animation-delay:.17s;}
.cpu-thinking-dot:nth-child(3){animation-delay:.34s;}
.battle-field-shake{animation:battleShake .35s ease;}
.play-hub-wrap{display:flex;flex-direction:column;align-items:center;gap:10px;padding:16px 12px 24px;}
.play-hub-title{font-family:'Press Start 2P',monospace;font-size:14px;color:var(--lavender);text-shadow:0 0 16px rgba(196,168,255,.4);}
.play-hub-sub{font-size:7px;color:var(--text3);text-align:center;}
.play-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%;}
.play-card{background:linear-gradient(160deg,var(--panel) 0%,var(--panel2) 100%);border:2px solid var(--border);padding:18px 10px 14px;display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;transition:all .14s;}
.play-card:hover{border-color:var(--lavender);transform:translateY(-2px);box-shadow:0 6px 20px rgba(20,60,120,.4);}
.play-card-icon{font-size:28px;line-height:1;}
.play-card-name{font-family:'Press Start 2P',monospace;font-size:8px;color:var(--text);text-align:center;}
.play-card-desc{font-size:7px;color:var(--text3);text-align:center;line-height:1.8;}
.play-card-locked{opacity:.45;cursor:default;}
.play-card-locked:hover{transform:none;border-color:var(--border);box-shadow:none;}
.battle-lobby{display:flex;flex-direction:column;align-items:center;gap:12px;padding:8px 0 20px;}
.battle-title{font-family:'Press Start 2P',monospace;font-size:14px;color:var(--gold);text-shadow:0 0 16px rgba(255,209,102,.5),3px 3px 0 var(--gold-dark);}
.battle-sub{font-size:9px;color:var(--text3);text-align:center;line-height:2;}
.battle-tier{width:100%;background:linear-gradient(160deg,var(--panel) 0%,var(--panel2) 100%);border:2px solid var(--border);padding:12px 14px;display:flex;align-items:center;justify-content:space-between;gap:10px;cursor:pointer;transition:all .14s;}
.battle-tier:hover{border-color:var(--lavender);transform:translateY(-2px);box-shadow:0 6px 20px rgba(20,60,120,.4);}
.battle-tier-info{display:flex;flex-direction:column;gap:4px;}
.battle-tier-name{font-family:'Press Start 2P',monospace;font-size:9px;color:var(--text);}
.battle-tier-desc{font-size:9px;color:var(--text2);line-height:1.8;}
.battle-tier-reward{font-family:'Press Start 2P',monospace;font-size:10px;color:var(--gold);text-align:right;white-space:nowrap;}
.battle-arena{display:flex;flex-direction:column;gap:10px;min-height:calc(100vh - 140px);}
.battle-scoreboard{display:flex;justify-content:space-between;align-items:center;background:var(--panel);border:2px solid var(--border);padding:8px 12px;}
.battle-score-side{display:flex;flex-direction:column;align-items:center;gap:3px;}
.battle-score-name{font-family:'Press Start 2P',monospace;font-size:9px;color:var(--text2);}
.battle-score-wins{display:flex;gap:4px;}
.battle-score-pip{width:14px;height:14px;border:2px solid var(--border2);border-radius:2px;}
.battle-score-pip.won{background:var(--gold);}
.battle-vs{font-family:'Press Start 2P',monospace;font-size:10px;color:var(--text2);}
.battle-field{display:grid;grid-template-columns:1fr 1fr;gap:8px;min-height:90px;}
.battle-played-card{background:var(--panel2);border:2px solid var(--border2);padding:10px 8px;display:flex;flex-direction:column;align-items:center;gap:4px;position:relative;}
.battle-played-card.winner{border-color:var(--gold);box-shadow:0 0 12px rgba(255,209,102,.4);}
.battle-played-card.loser{opacity:.4;}
.battle-played-icon{font-size:28px;}
.battle-played-name{font-family:'Press Start 2P',monospace;font-size:8px;color:var(--text);text-align:center;}
.battle-played-element{font-size:8px;padding:2px 6px;font-family:'Press Start 2P',monospace;}
.battle-played-value{font-family:'Press Start 2P',monospace;font-size:11px;color:var(--gold);}
.battle-result-badge{position:absolute;top:-8px;left:50%;transform:translateX(-50%);font-family:'Press Start 2P',monospace;font-size:8px;padding:2px 6px;white-space:nowrap;}
.battle-hand{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-top:4px;}
.battle-hand-card{background:var(--panel);border:2px solid var(--border);padding:6px 4px;display:flex;flex-direction:column;align-items:center;gap:3px;cursor:pointer;transition:all .14s;position:relative;}
.battle-hand-card:hover:not(.used){transform:translateY(-4px);border-color:var(--lavender);box-shadow:0 6px 16px rgba(20,60,120,.5);}
.battle-hand-card.used{opacity:.25;cursor:default;pointer-events:none;}
.battle-hand-card.selected{border-color:var(--gold);background:rgba(255,209,102,.06);transform:translateY(-4px);}
.battle-hand-icon{font-size:20px;}
.battle-hand-name{font-family:'Press Start 2P',monospace;font-size:7px;color:var(--text);text-align:center;line-height:1.5;}
.battle-hand-value{font-family:'Press Start 2P',monospace;font-size:10px;color:var(--gold);}
.battle-hand-element{font-size:7px;padding:2px 4px;font-family:'Press Start 2P',monospace;border-radius:2px;}
.battle-status{font-family:'Press Start 2P',monospace;font-size:9px;color:var(--text2);text-align:center;min-height:16px;}
.battle-actions{display:flex;gap:8px;justify-content:center;}
.battle-type-legend{display:flex;gap:6px;justify-content:center;flex-wrap:wrap;margin-top:4px;}
.battle-type-chip{font-size:8px;font-family:'Press Start 2P',monospace;padding:4px 7px;border:1px solid;border-radius:2px;}
.battle-end-overlay{position:fixed;inset:0;background:rgba(4,8,18,.95);z-index:500;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:20px;}
.battle-end-title{font-family:'Press Start 2P',monospace;font-size:22px;text-align:center;}
.battle-end-sub{font-family:'Press Start 2P',monospace;font-size:9px;color:var(--text2);text-align:center;line-height:2.2;}
.battle-type-strip{display:flex;align-items:center;gap:5px;font-family:'Press Start 2P',monospace;font-size:7px;background:rgba(8,8,14,.7);border:1px solid var(--border);padding:5px 8px;flex-wrap:wrap;justify-content:center;}
.bts-arrow{color:var(--text3);font-size:9px;}
.battle-reason{font-family:'Press Start 2P',monospace;font-size:7px;padding:4px 8px;margin-top:2px;display:inline-block;}
.battle-reason.win{color:var(--mint);}
.battle-reason.loss{color:var(--pink);}
.battle-reason.tie{color:var(--text2);}
.battle-sel-preview{display:flex;align-items:center;justify-content:space-between;gap:10px;background:rgba(255,209,102,.05);border:1px solid var(--gold2);padding:8px 10px;margin-top:2px;}
.battle-sel-meta{display:flex;flex-direction:column;gap:5px;flex:1;}
.battle-sel-matchup{display:flex;gap:10px;font-family:'Press Start 2P',monospace;font-size:6px;flex-wrap:wrap;}
.wz-wrap{display:flex;flex-direction:column;align-items:center;gap:12px;padding-top:6px;}
.wz-biome-tabs{display:flex;gap:6px;width:100%;margin-bottom:2px;}
.wz-biome-tab{flex:1;font-family:'Press Start 2P',monospace;font-size:8px;padding:8px 4px;border:2px solid var(--border);background:rgba(6,6,10,.88);color:var(--text2);cursor:pointer;text-align:center;text-transform:uppercase;transition:all .1s;}
.wz-biome-tab.active{border-color:var(--mint);color:var(--mint);background:rgba(94,255,200,.06);}
.wz-scene{position:relative;width:100%;max-width:360px;height:200px;overflow:hidden;cursor:default;touch-action:manipulation;border:2px solid rgba(94,255,200,.18);}
.wz-scene-label{position:absolute;top:8px;left:10px;font-family:'Press Start 2P',monospace;font-size:7px;color:rgba(94,255,200,.5);pointer-events:none;z-index:6;}
.wz-spot{position:absolute;display:flex;flex-direction:column;align-items:center;cursor:pointer;user-select:none;animation:spotPop .25s cubic-bezier(.34,1.56,.64,1) forwards;z-index:5;}
@keyframes spotPop{0%{transform:scale(0) rotate(-10deg);opacity:0}100%{transform:scale(1) rotate(0);opacity:1}}
.wz-spot-bubble{background:var(--panel2);border:2px solid var(--mint);padding:4px 7px;font-family:'Press Start 2P',monospace;font-size:9px;white-space:nowrap;box-shadow:0 0 10px rgba(94,255,200,.4);}
.wz-spot-bubble.golden{border-color:var(--gold);background:rgba(255,209,102,.08);box-shadow:0 0 14px rgba(255,209,102,.6);animation:goldenPulse 0.8s ease-in-out infinite;}
@keyframes goldenPulse{0%,100%{box-shadow:0 0 10px rgba(255,209,102,.4)}50%{box-shadow:0 0 22px rgba(255,209,102,.9)}}
.wz-spot-icon{font-size:22px;margin-bottom:2px;}
.wz-collected{position:absolute;font-family:'Press Start 2P',monospace;font-size:13px;pointer-events:none;animation:cPop .9s ease forwards;white-space:nowrap;}
.coin-pop{position:absolute;top:0;left:50%;transform:translateX(-50%);font-family:'Press Start 2P',monospace;font-size:12px;color:var(--gold);pointer-events:none;animation:cPop .9s ease forwards;white-space:nowrap;text-shadow:0 0 8px rgba(255,209,102,.6);}
@keyframes cPop{0%{opacity:1;transform:translateX(-50%) translateY(0)}100%{opacity:0;transform:translateX(-50%) translateY(-60px)}}
.wz-stamina-wrap{width:100%;max-width:360px;}
.wz-stamina-label{display:flex;justify-content:space-between;font-family:'Press Start 2P',monospace;font-size:9px;color:var(--text2);margin-bottom:5px;}
.wz-stamina-track{height:12px;background:var(--bg);border:1px solid var(--border2);}
.wz-stamina-fill{height:100%;background:linear-gradient(90deg,var(--mint),#2ee8a0);transition:width .35s ease;}
.wz-regen-note{font-family:'Press Start 2P',monospace;font-size:7px;color:var(--text2);text-align:center;margin-top:4px;}
.wz-biome-desc{font-family:'Press Start 2P',monospace;font-size:7px;color:rgba(94,255,200,.4);text-align:center;line-height:2;padding:0 8px;}
.wz-recent{width:100%;max-width:360px;}
.wz-recent-title{font-family:'Press Start 2P',monospace;font-size:7px;color:var(--lavender);opacity:.7;text-transform:uppercase;letter-spacing:2px;margin-bottom:6px;}
.wz-recent-list{display:flex;flex-wrap:wrap;gap:5px;}
.wz-recent-chip{font-family:'Press Start 2P',monospace;font-size:7px;padding:3px 7px;background:var(--panel);border:1px solid var(--border2);color:var(--text3);}
.fanfare{position:fixed;inset:0;pointer-events:none;z-index:450;overflow:hidden;}
.fanfare-particle{position:absolute;animation:pFly 1.4s ease forwards;}
@keyframes pFly{0%{opacity:1;transform:translateY(0) scale(1);}100%{opacity:0;transform:translateY(-220px) scale(0);}}
.toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%);background:var(--panel2);border:2px solid var(--border2);box-shadow:0 4px 20px rgba(0,0,0,.6);padding:12px 18px;font-family:'Press Start 2P',monospace;font-size:10px;color:var(--text);z-index:500;white-space:nowrap;animation:tIn .12s ease forwards;}
@keyframes tIn{from{opacity:0;transform:translateX(-50%) translateY(8px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
.ach-pop{position:fixed;top:70px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,#0e1e38,#162438);border:2px solid var(--gold);box-shadow:0 0 20px rgba(255,209,102,.2);padding:10px 14px;display:flex;align-items:center;gap:10px;z-index:500;animation:achIn .15s ease,achOut .2s ease 2.7s forwards;white-space:nowrap;}
@keyframes achIn{from{opacity:0;transform:translateX(-50%) translateY(-16px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
@keyframes achOut{to{opacity:0;transform:translateX(-50%) translateY(-16px)}}
.market-tabs{display:flex;gap:0;margin-bottom:14px;border-bottom:2px solid var(--border);}
.market-tab{flex:1;padding:10px 4px;background:rgba(6,6,10,.7);border:none;border-bottom:2px solid transparent;color:var(--text2);font-family:'Press Start 2P',monospace;font-size:9px;cursor:pointer;text-align:center;text-transform:uppercase;margin-bottom:-2px;transition:color .1s;}
.market-tab:hover{color:var(--lavender);}
.market-tab.active{color:var(--gold);border-bottom-color:var(--gold);}
.listing-card{background:var(--panel);border:1px solid var(--border);border-left:3px solid var(--border2);padding:10px 12px;display:flex;align-items:center;gap:10px;margin-bottom:6px;transition:all .12s;}
.listing-card:hover{border-left-color:var(--pink);background:var(--panel2);transform:translateX(2px);}
.listing-icon{font-size:28px;line-height:1;flex-shrink:0;}
.listing-info{flex:1;min-width:0;}
.listing-name{font-family:'Press Start 2P',monospace;font-size:10px;line-height:1.6;}
.listing-meta{font-family:'Press Start 2P',monospace;font-size:9px;color:var(--text3);margin-top:4px;display:flex;align-items:center;gap:6px;flex-wrap:wrap;}
.listing-price{font-family:'Press Start 2P',monospace;font-size:14px;color:var(--gold);text-align:right;flex-shrink:0;}
.listing-seller{font-family:'Press Start 2P',monospace;font-size:8px;color:var(--text2);text-align:right;margin-top:3px;}
.listing-expires{font-family:'Press Start 2P',monospace;font-size:8px;color:var(--text2);margin-top:3px;}
.gc{display:inline-block!important;width:18px!important;height:18px!important;min-width:18px;background:url('../art/icon/gold.png') center/contain no-repeat!important;vertical-align:-2px;margin-right:2px;flex-shrink:0;}
.gc-lg{display:inline-block!important;width:28px!important;height:28px!important;min-width:28px;background:url('../art/icon/gold.png') center/contain no-repeat!important;vertical-align:-4px;flex-shrink:0;}
.sell-card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:10px;}
.sell-card-item{background:var(--panel);border:1px solid var(--border);padding:8px 6px;text-align:center;cursor:pointer;transition:all .12s;display:flex;flex-direction:column;align-items:center;gap:3px;overflow:hidden;}
.sell-card-item:hover{border-color:var(--lavender);background:var(--panel2);transform:translateY(-2px);}
.price-input{background:var(--bg);border:2px solid var(--border);border-bottom-color:var(--border2);padding:8px 10px;color:var(--text);font-family:'Press Start 2P',monospace;font-size:10px;width:100%;text-align:center;margin:8px 0;}
.price-input:focus{outline:none;border-color:var(--gold);}
.username-setup{background:var(--panel);border:2px solid rgba(196,168,255,.22);padding:22px;text-align:center;max-width:320px;margin:40px auto 0;}
.username-input{background:var(--bg);border:2px solid var(--border);padding:10px 12px;color:var(--text);font-family:'Press Start 2P',monospace;font-size:11px;width:100%;text-align:center;margin:12px 0;}
.username-input:focus{outline:none;border-color:var(--lavender);}
.empty-state{text-align:center;padding:36px 20px;color:var(--text2);}
.empty-icon{font-size:44px;margin-bottom:12px;}
.ug-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px;}
.ug-card{background:var(--panel);border:2px solid var(--border);padding:10px 6px 8px;text-align:center;cursor:pointer;transition:all .14s;display:flex;flex-direction:column;align-items:center;gap:4px;}
.ug-card:hover{border-color:var(--lavender);background:var(--panel2);transform:translateY(-3px);box-shadow:0 6px 20px rgba(20,60,120,.4);}
.ug-card.ugsel{border-color:var(--gold);}
.pending-item{background:var(--panel);border:1px solid var(--border);border-left:3px solid var(--lavender);padding:10px 12px;display:flex;align-items:center;gap:10px;margin-bottom:6px;}
.grade-tabs{display:flex;gap:0;margin-bottom:14px;border-bottom:2px solid var(--border);}
.grade-tab{flex:1;padding:10px;background:rgba(6,6,10,.7);border:none;border-bottom:2px solid transparent;color:var(--text2);font-family:'Press Start 2P',monospace;font-size:9px;cursor:pointer;text-align:center;text-transform:uppercase;margin-bottom:-2px;transition:color .1s;}
.grade-tab:hover{color:var(--lavender);}
.grade-tab.active{color:var(--gold);border-bottom-color:var(--gold);}
.bsheet{background:linear-gradient(180deg,var(--panel2) 0%,#1e1230 100%);border-top:2px solid var(--border2);box-shadow:0 -12px 40px rgba(0,0,0,.7);padding:18px 14px 44px;position:fixed;bottom:0;left:0;right:0;z-index:250;animation:sup .16s ease;}
@keyframes sup{from{transform:translateY(100%)}to{transform:translateY(0)}}
.tbtn{width:100%;background:var(--panel);border:1px solid var(--border);border-bottom:2px solid var(--border2);padding:12px 14px;margin-bottom:8px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-family:'Press Start 2P',monospace;color:var(--text);transition:all .12s;}
.tbtn:hover:not(:disabled){border-color:var(--lavender);background:var(--panel2);}
.tbtn:disabled{opacity:.3;cursor:not-allowed;}
.gr-ov{position:fixed;inset:0;background:radial-gradient(ellipse at center,#0a1828 0%,#020608 100%);z-index:500;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;}
.slot-num{font-family:'Press Start 2P',monospace;font-size:88px;line-height:1;text-shadow:0 0 40px currentColor;}
@keyframes slam{0%{transform:scale(2.5);opacity:0}40%{transform:scale(.95)}60%{transform:scale(1.05)}100%{transform:scale(1);opacity:1}}
.slam{animation:slam .25s ease forwards;}
/* SOCIAL TABS */
.social-tabs{display:flex;gap:0;margin-bottom:14px;border-bottom:2px solid var(--border);}
.social-tab{flex:1;padding:10px 4px;background:rgba(6,6,10,.7);border:none;border-bottom:2px solid transparent;color:var(--text2);font-family:'Press Start 2P',monospace;font-size:9px;cursor:pointer;text-align:center;text-transform:uppercase;margin-bottom:-2px;transition:color .1s;}
.social-tab:hover{color:var(--lavender);}
.social-tab.active{color:var(--gold);border-bottom-color:var(--gold);}
/* LEADERBOARD */
.lb-row{display:flex;align-items:center;gap:10px;padding:10px 12px;margin-bottom:6px;background:var(--panel);border:1px solid var(--border);border-left:3px solid var(--border2);transition:all .12s;}
.lb-row.me{border-left-color:var(--gold);background:rgba(255,209,102,.04);}
.lb-rank{font-family:'Press Start 2P',monospace;font-size:11px;color:var(--text2);min-width:28px;text-align:center;}
.lb-rank.top1{color:var(--gold);}
.lb-rank.top2{color:#c0c0c0;}
.lb-rank.top3{color:#cd7f32;}
.lb-name{font-family:'Press Start 2P',monospace;font-size:10px;flex:1;color:var(--text);}
.lb-score{font-family:'Press Start 2P',monospace;font-size:9px;color:var(--lavender);text-align:right;}
/* TRADE */
.trade-offer{background:var(--panel);border:2px solid var(--border);padding:12px;margin-bottom:8px;position:relative;}
.trade-offer.incoming{border-color:var(--mint);}
.trade-offer.outgoing{border-color:var(--lavender);opacity:.85;}
.trade-arrow{font-size:20px;text-align:center;margin:6px 0;}
.trade-card-row{display:flex;gap:6px;flex-wrap:wrap;}
.trade-card-chip{background:var(--panel2);border:1px solid var(--border2);padding:4px 8px;font-family:'Press Start 2P',monospace;font-size:7px;display:flex;align-items:center;gap:4px;}
/* ── MEMORY MATCH ── */
.mem-wrap{display:flex;flex-direction:column;align-items:center;gap:10px;padding:12px 8px 24px;width:100%;box-sizing:border-box;}
.mem-header{display:flex;gap:28px;justify-content:center;}
.mem-hstat{font-family:'Press Start 2P',monospace;font-size:11px;display:flex;align-items:center;}
.mem-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:7px;width:100%;max-width:360px;}
.mem-card{aspect-ratio:.72;cursor:pointer;position:relative;}
.mem-card-inner{width:100%;height:100%;transition:transform .32s;transform-style:preserve-3d;position:relative;}
.mem-card.flipped .mem-card-inner,.mem-card.matched .mem-card-inner{transform:rotateY(180deg);}
.mem-card-back,.mem-card-front{position:absolute;width:100%;height:100%;backface-visibility:hidden;-webkit-backface-visibility:hidden;border:2px solid var(--border2);display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:3px;}
.mem-card-back{background:url('../art/card/Back.png') center/cover no-repeat;box-shadow:2px 2px 0 #04080f;}
.mem-card-front{transform:rotateY(180deg);background:var(--panel);}
.mem-card.matched .mem-card-front{border-color:var(--mint);box-shadow:0 0 10px rgba(94,255,200,.4);}
.mem-card:not(.flipped):not(.matched):hover .mem-card-inner{transform:rotateY(14deg);}
.mem-stats-row{display:flex;gap:28px;justify-content:center;}
.mem-stat{text-align:center;}
.mem-stat-val{font-family:'Press Start 2P',monospace;font-size:20px;}
.mem-stat-label{font-size:6px;color:var(--text3);margin-top:4px;letter-spacing:.5px;}
/* ── CODIMON SLOTS ── */
.slots-machine{background:linear-gradient(160deg,#0a1628 0%,#0d1e38 100%);border:3px solid var(--gold2);box-shadow:0 0 0 1px var(--gold-dark),0 8px 28px rgba(0,0,0,.6),inset 0 1px 0 rgba(255,255,255,.06);padding:14px;width:100%;max-width:320px;box-sizing:border-box;}
.slots-window{background:#020408;border:2px solid var(--border);padding:10px;display:flex;justify-content:center;margin-bottom:10px;}
.slots-reel-wrap{display:flex;gap:8px;}
.slot-reel{width:72px;height:80px;border:2px solid var(--border2);background:rgba(4,4,10,.9);display:flex;align-items:center;justify-content:center;overflow:hidden;}
.slot-cell{font-size:38px;line-height:1;text-align:center;user-select:none;}
.slots-result{min-height:22px;text-align:center;padding:2px 0;}
.slots-paytable{background:rgba(8,8,14,.8);border:1px solid var(--border);padding:10px 14px;width:100%;max-width:320px;box-sizing:border-box;margin-top:2px;}
.slots-pay-row{display:flex;justify-content:space-between;font-size:6px;color:var(--text2);padding:4px 0;border-bottom:1px solid rgba(38,62,90,.3);}
.slots-pay-row:last-child{border-bottom:none;}
/* ── GEMS & BATTLE PASS ── */
.gems-wrap{display:flex;align-items:center;gap:4px;background:rgba(56,189,248,.1);border:1px solid #38bdf8;padding:3px 8px;flex-shrink:0;}
.gem-val{font-family:'Press Start 2P',monospace;font-size:9px;color:#38bdf8;}
/* Gem Store overlay tabs */
.gs-tabs{display:flex;gap:4px;margin-bottom:14px;}
.gs-tab{flex:1;background:var(--panel);border:1px solid var(--border2);color:var(--text2);font-family:'Press Start 2P',monospace;font-size:7px;padding:8px 4px;cursor:pointer;}
.gs-tab.active{background:var(--panel2);border-color:var(--sky);color:var(--sky);}
/* Gem packages grid */
.gs-pkg-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.gs-pkg-card{background:var(--panel);border:1px solid var(--border2);padding:14px 10px;text-align:center;cursor:pointer;transition:border-color .15s;}
.gs-pkg-card:hover{border-color:var(--sky);}
/* Battle Pass panels */
.bp-buy-panel{background:linear-gradient(160deg,#2a1400 0%,#0e0500 100%);border:2px solid var(--gold);padding:20px 16px;text-align:center;margin-bottom:14px;}
.bp-progress-panel{background:linear-gradient(160deg,#2a1400 0%,#0e0500 100%);border:2px solid var(--gold);padding:12px 14px;margin-bottom:14px;}
.bp-xp-track{height:8px;background:var(--panel);border:1px solid var(--border2);border-radius:4px;overflow:hidden;margin-top:4px;}
.bp-xp-fill{height:100%;background:linear-gradient(90deg,var(--gold2),var(--gold));border-radius:4px;transition:width .4s ease;}
/* BP level-up popup */
.bp-level-pop{position:fixed;top:72px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,#422006,#7a3a00);border:2px solid var(--gold);color:var(--text);font-family:'Press Start 2P',monospace;padding:10px 16px;z-index:1200;display:flex;align-items:center;gap:10px;white-space:nowrap;pointer-events:none;animation:bpPop .5s ease forwards;}
@keyframes bpPop{0%{opacity:0;transform:translateX(-50%) translateY(-8px)}100%{opacity:1;transform:translateX(-50%) translateY(0)}}
/* Cosmetic items in gem store */
.gs-cosmetic-item{background:var(--panel2);border:2px solid var(--border2);padding:8px 5px;text-align:center;cursor:pointer;transition:border-color .15s;}
.gs-cosmetic-item:hover{border-color:var(--text2);}
.gs-cosmetic-item.equipped{border-color:var(--gold);}
/* Card sleeve body classes */
body.sleeve-dragon-scale .card-back{background:linear-gradient(135deg,#7b2d00,#c84b00,#7b2d00)!important;border-color:#c84b00!important;}
body.sleeve-neon-grid .card-back{background:linear-gradient(135deg,#001a2e,#003d73,#0066cc,#003d73,#001a2e)!important;border-color:#0066cc!important;}
body.sleeve-crystal .card-back{background:linear-gradient(135deg,#a8d8ea,#e8f4fc,#a8d8ea)!important;border-color:#a8d8ea!important;}
body.sleeve-gold-foil .card-back{background:linear-gradient(135deg,#b8860b,#ffd700,#b8860b)!important;border-color:#ffd700!important;}
body.sleeve-season1 .card-back{background:linear-gradient(135deg,#1a0a2e,#6b21a8,#1a0a2e)!important;border-color:#6b21a8!important;}
/* Display case effects */
@keyframes dcShimmer{0%,100%{filter:brightness(1)}50%{filter:brightness(1.35) drop-shadow(0 0 5px rgba(255,255,255,.5));}}
@keyframes dcLightning{0%,100%{box-shadow:0 0 10px 2px #7dd3fc}50%{box-shadow:0 0 20px 5px #38bdf8,0 0 35px 8px rgba(56,189,248,.25);}}
@keyframes dcAura{0%,100%{box-shadow:0 0 10px 2px #f59e0b}50%{box-shadow:0 0 22px 6px #fcd34d,0 0 40px 10px rgba(245,158,11,.3);}}
.dc-effect-shimmer{animation:dcShimmer 2s ease-in-out infinite;}
.dc-effect-lightning{animation:dcLightning 1.2s ease-in-out infinite;}
.dc-effect-legendary-aura{animation:dcAura 1.5s ease-in-out infinite;}

/* ══════════════════════════════════════════════════════════════
   MASTER REFACTOR — Retro Game Client Polish (LoL-inspired HUD)
   ══════════════════════════════════════════════════════════════ */

/* ── 1. FLOATING CONSOLE: 1200px panel hovering over blurred scene ── */
.screen {
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
  padding: 14px 18px;
  /* Gold filigree frame — forged-metal Hextech feel */
  border: 3px solid transparent;
  border-image: linear-gradient(135deg, #c89b3c 0%, #785a28 100%) 1;
  /* Outer shadow = console lift off background. Inset = carved tray interior */
  box-shadow:
    /* Massive vertical drop — panel floats above the blurred scene */
    0 30px 60px rgba(0,0,0,.80),
    /* Lateral edge shadows push background away */
    -6px 0 50px rgba(0,0,0,.98),
     6px 0 50px rgba(0,0,0,.98),
     0   0 90px rgba(126,200,255,.04),
    /* Interior tray carve */
    inset 0 6px 28px rgba(0,0,0,.85),
    inset 4px  0 18px rgba(0,0,0,.55),
    inset -4px 0 18px rgba(0,0,0,.55),
    inset 0 -4px 14px rgba(0,0,0,.5);
}

/* ── 2. DEPTH & DIMENSIONALITY: inset tray shadows on panels ── */
.season-header {
  box-shadow:
    0 4px 20px rgba(0,0,0,.4),
    inset 0 1px 0 rgba(255,255,255,.06),
    inset 0 5px 18px rgba(0,0,0,.6) !important;
}
.pack-option {
  min-height: 290px;
  justify-content: flex-start;
  padding: 0 0 16px !important;
  box-shadow:
    0 4px 0 #080e18,
    0 6px 18px rgba(0,0,0,.4),
    inset 0 5px 14px rgba(0,0,0,.5) !important;
}
.pack-option:hover {
  filter: brightness(1.2) drop-shadow(0 0 15px rgba(200,155,60,.4)) !important;
  box-shadow:
    0 8px 0 #080e18,
    0 12px 28px rgba(14,60,100,.5),
    inset 0 3px 10px rgba(0,0,0,.35) !important;
}
.pack-option.selected {
  box-shadow:
    0 4px 0 var(--gold-dark),
    0 6px 20px rgba(255,209,102,.2),
    inset 0 5px 14px rgba(0,0,0,.5) !important;
}
.dex-card {
  box-shadow: inset 0 4px 12px rgba(0,0,0,.6) !important;
}
.modal {
  box-shadow:
    0 0 0 1px var(--border),
    0 20px 60px rgba(0,0,0,.8),
    inset 0 2px 0 rgba(255,255,255,.04),
    inset 0 -5px 18px rgba(0,0,0,.55) !important;
}
.battle-scoreboard  { box-shadow: inset 0 3px 10px rgba(0,0,0,.6) !important; }
.battle-played-card { box-shadow: inset 0 3px 10px rgba(0,0,0,.55) !important; }
.battle-played-card.winner {
  box-shadow: 0 0 12px rgba(255,209,102,.4), inset 0 3px 10px rgba(0,0,0,.4) !important;
}

/* ── 3. HUD NAVIGATION: full-width frosted glass frame ── */
.header {
  background: rgba(8,14,26,.68) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
  box-shadow:
    0 4px 28px rgba(0,0,0,.7),
    inset 0 1px 0 rgba(255,209,102,.1),
    inset 0 -1px 0 rgba(255,209,102,.04) !important;
}
.nav {
  backdrop-filter: blur(8px) !important;
  -webkit-backdrop-filter: blur(8px) !important;
}

/* ── 4. TACTILE FEEDBACK: hover scale + physical press-down ── */
/* Gold / primary buttons scale up on hover */
.btn-gold:hover {
  filter: brightness(1.12);
  transform: scale(1.03) translateY(-1px);
}
.btn-blue:hover  { filter: brightness(1.1); transform: scale(1.02) translateY(-1px); }
.btn-green:hover { filter: brightness(1.1); transform: scale(1.02) translateY(-1px); }

/* Pack cards press 2px, border collapses, inner shadow deepens */
.pack-option:active {
  transform: translateY(2px) !important;
  border-width: 1px !important;
  box-shadow:
    0 2px 0 #080e18,
    0 3px 8px rgba(0,0,0,.5),
    inset 0 6px 16px rgba(0,0,0,.7) !important;
}
.nav-btn:active     { transform: translateY(1px); background: rgba(255,209,102,.03) !important; }
.season-tab:active  { transform: translateY(1px); box-shadow: none !important; }
.filter-chip:active { transform: translateY(1px); }
.play-card:active   { transform: translateY(1px) !important; box-shadow: none !important; }
.battle-tier:active { transform: translateY(1px) !important; box-shadow: none !important; }
.dex-card:active:not(.unowned) { transform: translateY(1px) scale(1.01) !important; }

/* ── 5. VERTICALITY: portrait pack image height ── */
.pack-option-icon { padding: 20px 0 14px !important; }
.pack-option-icon img { height: 140px !important; }
.pack-option-price { font-size: 13px !important; }

/* ── 6. GRID LOGIC: auto-fit collapses empty tracks, center aligns items ── */
.pack-grid {
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)) !important;
  justify-content: center !important;
  gap: 14px !important;
}
.dex-grid {
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)) !important;
  justify-content: center !important;
}

/* ── 7. RARITY TIER SYSTEM: pack-option tiers injected by shop.js ── */

/* — PREMIUM tier (blue/lavender border, soft pulsing ambient) — */
@keyframes packPremiumGlow {
  0%,100% { box-shadow: 0 4px 0 #080e18, 0  8px 16px rgba(168,200,255,.12), inset 0 5px 14px rgba(0,0,0,.5); }
     50%   { box-shadow: 0 4px 0 #080e18, 0 16px 28px rgba(168,200,255,.35), inset 0 5px 14px rgba(0,0,0,.5); }
}
.pack-option.pack-tier-premium {
  border-color: var(--lavender) !important;
  animation: packPremiumGlow 3s ease-in-out infinite !important;
}

/* — EPIC tier (purple border, violet corona) — */
@keyframes packEpicGlow {
  0%,100% { box-shadow: 0 4px 0 #080e18, 0  8px 18px rgba(124,58,237,.18), inset 0 5px 14px rgba(0,0,0,.5); }
     50%   { box-shadow: 0 4px 0 #080e18, 0 18px 36px rgba(124,58,237,.52), inset 0 5px 14px rgba(0,0,0,.5); }
}
.pack-option.pack-tier-epic {
  border-color: #8b5cf6 !important;
  background: linear-gradient(160deg,#0d0414 0%,#1a0828 50%,#0d0414 100%) !important;
  animation: packEpicGlow 2.5s ease-in-out infinite !important;
}

/* — LEGENDARY tier (gold border + animated shimmer streak + pulsing corona) — */
@keyframes packLegendaryGlow {
  0%,100% {
    border-color: var(--gold-dark);
    box-shadow: 0 4px 0 #080e18, 0 12px 24px rgba(255,209,102,.22), inset 0 5px 14px rgba(0,0,0,.5);
  }
  50% {
    border-color: var(--gold);
    box-shadow: 0 4px 0 #080e18, 0 20px 48px rgba(255,209,102,.6), 0 0 80px rgba(255,209,102,.1), inset 0 5px 14px rgba(0,0,0,.5);
  }
}
@keyframes packLegendaryShimmer {
  0%   { left: -60px; opacity: 0; }
  8%   { opacity: 1; }
  92%  { opacity: 1; }
  100% { left: 130%; opacity: 0; }
}
.pack-option.pack-tier-legendary {
  border-color: var(--gold) !important;
  background: linear-gradient(160deg,#1a0c00 0%,#2e1600 50%,#1a0c00 100%) !important;
  animation: packLegendaryGlow 2s ease-in-out infinite !important;
}
/* Override the shine streak: make it gold-tinted and on a loop */
.pack-option.pack-tier-legendary::before {
  width: 50px !important;
  background: linear-gradient(105deg,transparent 20%,rgba(255,209,102,.22) 50%,transparent 80%) !important;
  animation: packLegendaryShimmer 2.4s ease-in-out infinite !important;
}

/* ── 8. TYPOGRAPHY: black-offset drop shadow on all key labels ── */
.sl                              { text-shadow: 2px 2px 0px #000 !important; }
.collection-title                { text-shadow: 2px 2px 0px #000 !important; }
.pack-option-name                { text-shadow: 2px 2px 0px #000 !important; }
.pack-option-price               { text-shadow: 0 0 10px rgba(255,209,102,.3), 2px 2px 0px #000 !important; }
.dex-name                        { text-shadow: 2px 2px 0px #000 !important; }
.lb-name                         { text-shadow: 2px 2px 0px #000 !important; }
.battle-end-title                { text-shadow: 3px 3px 0px #000 !important; }
.battle-tier-name                { text-shadow: 2px 2px 0px #000 !important; }
.play-hub-title                  { text-shadow: 0 0 16px rgba(196,168,255,.4), 2px 2px 0px #000 !important; }
.play-card-name                  { text-shadow: 2px 2px 0px #000 !important; }
.opening-title                   { text-shadow: 0 0 16px rgba(255,209,102,.5), 2px 2px 0px #000 !important; }
.season-title                    { text-shadow: 0 0 16px rgba(255,209,102,.4), 2px 2px 0px #000 !important; }
.daily-title                     { text-shadow: 2px 2px 0px #000 !important; }
.market-tab.active,
.grade-tab.active,
.social-tab.active               { text-shadow: 1px 1px 0px #000; }
.auth-sub                        { text-shadow: 1px 1px 0px #000; }

/* ── 9. HEXTECH NAV: active tab highlights from above, not below ── */
/* Kill the bottom-bar highlight the original rule sets */
.nav-btn.active {
  border-bottom-color: transparent !important;
  border-bottom: none !important;
  /* Top-light: a thin gold bar + inset glow radiating downward */
  border-top: 3px solid #c8aa6e !important;
  box-shadow: inset 0 10px 20px -10px rgba(200,170,110,.30) !important;
  /* Lit text: white with gold ambient glow */
  color: #fff !important;
  text-shadow: 0 0 10px var(--gold) !important;
}
