/* ============================================================
   Prism League — design system
   ============================================================ */
:root{
  /* brighter, higher-contrast dark theme — elevated surfaces read clearly */
  --bg:#11162a; --bg2:#171d38; --panel:#212a4e; --panel2:#2c3766;
  --ink:#f4f7ff; --muted:#aeb9da; --line:#41507f;
  --brand:#8a6bff; --brand2:#1ee8cf; --gold:#ffd25e;
  --good:#3fe39a; --bad:#ff6b7a;
  --radius:16px; --radius-sm:10px;
  --shadow:0 14px 44px rgba(0,0,0,.5);
  --t-Ember:#ff7a52; --t-Bloom:#56e07a; --t-Tide:#49b4ff;
  --t-Spark:#ffd84a; --t-Stone:#d6a866; --t-Mind:#bd7bff; --t-Neutral:#c4cde0;
  --r-common:#aebcdb; --r-uncommon:#5fe2ad; --r-rare:#58b4ff;
  --r-epic:#cf78ff; --r-legendary:#ffbe4d;
  --nav-h:70px;
  --font:"Segoe UI",system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
html{font-size:18px}   /* global UI scale (was 16px default) */
body{
  font-family:var(--font); color:var(--ink); background:var(--bg); font-size:1rem;
  background-image:
    radial-gradient(1200px 600px at 80% -10%, rgba(138,107,255,.26), transparent 60%),
    radial-gradient(1000px 500px at -10% 10%, rgba(30,232,207,.16), transparent 55%),
    radial-gradient(900px 800px at 50% 120%, rgba(255,210,94,.10), transparent 60%);
  -webkit-font-smoothing:antialiased; overflow-x:hidden;
}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
img{max-width:100%}
::selection{background:var(--brand);color:#fff}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:var(--line);border-radius:10px}
::-webkit-scrollbar-track{background:transparent}

#app{min-height:100%;display:flex;flex-direction:column}

/* ---- top bar ---- */
#topbar{
  position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:1rem;
  padding:.7rem clamp(.8rem,3vw,1.6rem);
  background:linear-gradient(180deg,rgba(12,16,30,.92),rgba(12,16,30,.72));
  backdrop-filter:blur(14px);border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:center;gap:.6rem}
.brand-mark{width:30px;height:30px;border-radius:8px;
  background:conic-gradient(from 210deg,var(--brand),var(--brand2),var(--gold),var(--brand));
  box-shadow:0 0 22px rgba(124,92,255,.6);clip-path:polygon(50% 0,100% 50%,50% 100%,0 50%)}
.brand-name{font-weight:800;letter-spacing:.14em;font-size:.95rem}
.brand-name span{color:var(--brand2)}
.nav{display:flex;gap:.25rem;margin-left:.5rem;flex:1}
.nav-btn{padding:.55rem .9rem;border-radius:10px;color:var(--muted);font-weight:600;font-size:.92rem;transition:.18s}
.nav-btn:hover{color:var(--ink);background:rgba(255,255,255,.06)}
.nav-btn.active{color:#fff;background:linear-gradient(135deg,rgba(124,92,255,.4),rgba(0,224,198,.25));box-shadow:inset 0 0 0 1px var(--line)}
.wallet{display:flex;align-items:center;gap:.5rem}
.coins{display:flex;align-items:center;gap:.45rem;padding:.5rem .85rem;border-radius:999px;
  background:linear-gradient(135deg,#2a2140,#1a1f3a);border:1px solid var(--line);font-weight:800;color:var(--gold)}
.coin-ico{width:18px;height:18px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#ffe79a,#ffae3b 60%,#b9791a);box-shadow:0 0 10px rgba(255,180,60,.5)}
.menu-toggle{display:none;font-size:1.4rem;padding:.2rem .5rem;color:var(--ink)}

#view{flex:1;width:100%;max-width:1240px;margin:0 auto;padding:clamp(1rem,3vw,2rem);animation:fade .35s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ---- generic ui ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.8rem 1.3rem;border-radius:12px;font-weight:700;font-size:.95rem;
  background:var(--panel2);border:1px solid var(--line);transition:.16s;color:var(--ink)}
.btn:hover{transform:translateY(-2px);border-color:#3b478a}
.btn:active{transform:translateY(0)}
.btn.primary{background:linear-gradient(135deg,var(--brand),#5a3fe0);border:none;box-shadow:0 8px 24px rgba(124,92,255,.4)}
.btn.accent{background:linear-gradient(135deg,var(--brand2),#08b39c);border:none;color:#04231f}
.btn.gold{background:linear-gradient(135deg,#ffd877,#f2a93b);border:none;color:#3a2400}
.btn.ghost{background:transparent}
.btn.danger{background:linear-gradient(135deg,#ff5d6c,#d6354c);border:none}
.btn:disabled{opacity:.45;cursor:not-allowed;transform:none}
.btn-lg{padding:1rem 1.6rem;font-size:1.05rem}
.chip{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .7rem;border-radius:999px;font-size:.78rem;font-weight:700;background:rgba(255,255,255,.07);border:1px solid var(--line)}
.section-title{font-size:clamp(1.4rem,3.5vw,2rem);font-weight:800;letter-spacing:-.01em;margin:.2rem 0 1rem}
.muted{color:var(--muted)}
.panel{background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--line);border-radius:var(--radius);padding:1.2rem}
.row{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap}
.spread{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}

/* ---- HOME ---- */
.hero{position:relative;border-radius:24px;overflow:hidden;padding:clamp(1.6rem,5vw,3.4rem);
  background:linear-gradient(135deg,rgba(124,92,255,.25),rgba(0,224,198,.12) 60%,rgba(255,177,61,.1));
  border:1px solid var(--line);box-shadow:var(--shadow)}
.hero h1{font-size:clamp(2.1rem,6vw,3.8rem);margin:0 0 .4rem;font-weight:900;letter-spacing:-.02em;
  background:linear-gradient(120deg,#fff,#cdd6ff 40%,var(--brand2));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p{max-width:54ch;color:#c7d0ee;font-size:clamp(1rem,2.4vw,1.18rem);line-height:1.55}
.hero .row{margin-top:1.4rem}
.hero-glow{position:absolute;inset:auto -10% -40% auto;width:60%;height:120%;background:radial-gradient(circle,rgba(124,92,255,.5),transparent 60%);filter:blur(30px);pointer-events:none}
.tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-top:1.4rem}
.tile{position:relative;overflow:hidden;border-radius:18px;padding:1.3rem;background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--line);transition:.18s;text-align:left}
.tile:hover{transform:translateY(-4px);border-color:#3b478a;box-shadow:var(--shadow)}
.tile h3{margin:.2rem 0 .3rem;font-size:1.2rem}
.tile p{margin:0;color:var(--muted);font-size:.9rem}
.tile .ico{font-size:1.8rem;margin-bottom:.4rem;display:block}
.stat-strip{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1.2rem}
.stat-strip .s{flex:1;min-width:120px;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:.9rem 1rem}
.stat-strip .s b{display:block;font-size:1.6rem;font-weight:800}
.stat-strip .s span{color:var(--muted);font-size:.82rem}

/* ============================================================
   CARD COMPONENT
   ============================================================ */
.card{
  --type:var(--t-Neutral);
  position:relative;width:var(--cw,200px);aspect-ratio:5/7;border-radius:14px;
  background:linear-gradient(160deg,color-mix(in srgb,var(--type) 42%,#101428),#0b0f22);
  border:2px solid color-mix(in srgb,var(--type) 60%,#fff 0%);
  box-shadow:0 8px 22px rgba(0,0,0,.5);
  overflow:hidden;cursor:pointer;transition:transform .15s,box-shadow .15s;
  isolation:isolate;user-select:none;
}
.card:hover{transform:translateY(-5px) scale(1.02);box-shadow:0 16px 40px rgba(0,0,0,.6)}
.card .frame{position:absolute;inset:0;border-radius:12px;border:1px solid rgba(255,255,255,.14);margin:5px;pointer-events:none}
.card .art{position:absolute;left:6px;right:6px;top:30px;bottom:34%;border-radius:10px;
  background:radial-gradient(120% 90% at 50% 20%,color-mix(in srgb,var(--type) 45%,#0a0e1e),#070a16);
  overflow:hidden;display:flex;align-items:center;justify-content:center}
.card .art canvas,.card .art img{width:100%;height:100%;object-fit:contain}
.card .art .ph{color:var(--muted);font-size:.7rem;text-align:center;padding:.4rem}
.card .topline{position:absolute;left:10px;right:10px;top:8px;display:flex;justify-content:space-between;align-items:center;z-index:2}
.card .nm{font-weight:800;font-size:calc(var(--cw,200px)*.072);text-shadow:0 1px 3px rgba(0,0,0,.7);letter-spacing:.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:62%}
.card .hp{font-weight:800;font-size:calc(var(--cw,200px)*.06);color:#fff}
.card .hp small{font-size:.7em;color:#ffd0d0}
.card .typebadge{position:absolute;top:30px;right:10px;z-index:3;width:26px;height:26px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:900;color:#fff;
  background:var(--type);box-shadow:0 2px 8px rgba(0,0,0,.5),inset 0 0 0 2px rgba(255,255,255,.35)}
.card .info{position:absolute;left:6px;right:6px;bottom:6px;height:31%;border-radius:10px;
  background:linear-gradient(180deg,rgba(8,11,24,.85),rgba(8,11,24,.96));border:1px solid rgba(255,255,255,.08);padding:5px 7px;display:flex;flex-direction:column;gap:3px;z-index:2}
.card .atk{display:flex;align-items:center;gap:5px;font-size:calc(var(--cw,200px)*.052)}
.card .atk .cost{display:flex;gap:1px}
.card .pip{width:calc(var(--cw,200px)*.05);height:calc(var(--cw,200px)*.05);border-radius:50%;background:var(--type);box-shadow:inset 0 0 0 1px rgba(255,255,255,.4)}
.card .atk .anm{flex:1;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card .atk .dmg{font-weight:900;color:#fff}
.card .atk .efx{display:block;color:var(--brand2);font-size:.86em;font-weight:600}
.card .footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto;font-size:calc(var(--cw,200px)*.044);color:var(--muted)}
.card .trait{color:var(--gold);font-weight:700;text-transform:capitalize}
.card .rar{display:flex;align-items:center;gap:3px;font-weight:700}
.card .gem{width:9px;height:9px;border-radius:2px;transform:rotate(45deg);background:var(--rc,#fff);box-shadow:0 0 6px var(--rc,#fff)}
.card .dex{position:absolute;bottom:4px;right:8px;font-size:calc(var(--cw,200px)*.04);color:rgba(255,255,255,.3);z-index:3}
/* evolution-chain indicator */
.card .evo-tag{position:absolute;left:7px;top:calc(30px + 4px);z-index:3;display:flex;align-items:center;gap:calc(var(--cw,200px)*.018);
  background:rgba(8,11,24,.72);border:1px solid rgba(255,255,255,.14);border-radius:999px;padding:calc(var(--cw,200px)*.012) calc(var(--cw,200px)*.03);
  font-size:calc(var(--cw,200px)*.05);line-height:1}
.card .evo-tag .estage{width:calc(var(--cw,200px)*.04);height:calc(var(--cw,200px)*.04);border-radius:50%;background:rgba(255,255,255,.22);box-shadow:inset 0 0 0 1px rgba(255,255,255,.18)}
.card .evo-tag .estage.on{background:var(--brand2);box-shadow:0 0 5px var(--brand2)}
.card.r-rare{border-color:#5fa8ff}
.card.r-epic{border-color:#c061ff;box-shadow:0 8px 26px rgba(192,97,255,.3)}
.card.r-legendary{border-color:#ffb13d;box-shadow:0 8px 30px rgba(255,177,61,.4)}

/* foil */
.card.foil::after{content:"";position:absolute;inset:0;border-radius:12px;pointer-events:none;z-index:4;mix-blend-mode:color-dodge;opacity:.55;
  background:linear-gradient(115deg,transparent 20%,rgba(255,0,128,.5),rgba(0,255,200,.5),rgba(120,80,255,.5),transparent 80%);
  background-size:300% 300%;animation:foilshift 4s linear infinite}
.card.foil .frame{border-color:rgba(255,255,255,.5)}
@keyframes foilshift{0%{background-position:0% 50%}100%{background-position:100% 50%}}
.card .foilbadge{position:absolute;left:8px;bottom:4px;z-index:5;font-size:calc(var(--cw,200px)*.04);font-weight:800;color:#fff;
  background:linear-gradient(90deg,#ff4dd8,#46e0ff);-webkit-background-clip:text;background-clip:text;letter-spacing:.1em}
.card .count{position:absolute;top:-8px;right:-8px;z-index:6;background:var(--brand);color:#fff;font-weight:800;font-size:.8rem;min-width:24px;height:24px;border-radius:12px;display:flex;align-items:center;justify-content:center;box-shadow:0 3px 10px rgba(0,0,0,.5);padding:0 6px}
.card.locked{filter:grayscale(.85) brightness(.5);opacity:.7}
.card.locked .art::after{content:"?";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:3rem;font-weight:900;color:rgba(255,255,255,.25)}
.card.mini{--cw:128px}
.card.sel{outline:3px solid var(--brand2);outline-offset:2px}
.card-zoom{box-shadow:0 24px 70px rgba(0,0,0,.7),0 0 0 1px rgba(255,255,255,.08)!important;animation:zoomin .14s ease;will-change:transform}
.card-zoom:hover{transform:none!important}
@keyframes zoomin{from{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}

/* collection grid */
.collection-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(208px,1fr));gap:1.1rem;justify-items:center}
.filters{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center;margin-bottom:1.2rem}
.filters input[type=search]{background:var(--panel);border:1px solid var(--line);color:var(--ink);padding:.6rem .9rem;border-radius:10px;min-width:180px}
.seg{display:flex;background:var(--panel);border:1px solid var(--line);border-radius:10px;overflow:hidden}
.seg button{padding:.5rem .8rem;font-weight:600;color:var(--muted);font-size:.85rem}
.seg button.on{background:var(--brand);color:#fff}
.pill-types{display:flex;gap:.3rem;flex-wrap:wrap}
.ptype{padding:.4rem .7rem;border-radius:999px;font-size:.8rem;font-weight:700;border:1px solid var(--line);background:var(--panel);color:var(--muted)}
.ptype.on{color:#fff;border-color:transparent}

/* ---- SHOP ---- */
.shop-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.4rem;margin-top:1.2rem}
.packbox{position:relative;border-radius:20px;padding:1.4rem;overflow:hidden;border:1px solid var(--line);
  background:linear-gradient(180deg,var(--panel),var(--bg2));box-shadow:var(--shadow);display:flex;flex-direction:column;gap:.8rem;transition:.2s}
.packbox:hover{transform:translateY(-5px)}
.pack-art{height:200px;border-radius:14px;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.pack-art .seal{position:absolute;width:70px;height:70px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#fff,var(--gold));display:flex;align-items:center;justify-content:center;font-weight:900;color:#5a3b00;box-shadow:0 6px 20px rgba(0,0,0,.4)}
.pack-art .wrap-shine{position:absolute;inset:0;background:linear-gradient(115deg,transparent 30%,rgba(255,255,255,.25),transparent 60%);background-size:250% 250%;animation:foilshift 5s linear infinite}
.pack-odds{font-size:.8rem;color:var(--muted);line-height:1.5}

/* pack opening overlay */
.opener{position:fixed;inset:0;z-index:200;background:radial-gradient(circle at 50% 40%,#1a1f3e,#06070f);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem}
.opener .reveal{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;max-width:1100px}
.reveal .card{--cw:190px;animation:cardpop .5s cubic-bezier(.2,1.4,.4,1) backwards}
.flash{position:fixed;inset:0;background:#fff;z-index:210;pointer-events:none;opacity:0}
@keyframes cardpop{from{transform:translateY(40px) scale(.6) rotateY(60deg);opacity:0}to{transform:none;opacity:1}}
.opener .new-tag{position:absolute;top:6px;left:50%;transform:translateX(-50%);z-index:8;background:var(--good);color:#04231f;font-weight:900;font-size:.7rem;padding:2px 8px;border-radius:8px;box-shadow:0 3px 10px rgba(0,0,0,.4)}
.opener .opened-title{display:none;margin:0;font-size:clamp(1.4rem,4vw,2rem);font-weight:900;background:linear-gradient(120deg,#fff,var(--brand2));-webkit-background-clip:text;background-clip:text;color:transparent}
.opener .opened-title.show{display:block;animation:fadein .5s ease}
.opener-shield{position:fixed;inset:0;z-index:235;cursor:progress}   /* blocks clicks during the open animation */
@keyframes fadein{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}

/* ---- SHINY PACK + TEAR-OPEN ---- */
.pack-stage{display:flex;flex-direction:column;align-items:center;gap:1.2rem;user-select:none;-webkit-user-select:none}
.pack-title{font-size:clamp(1.3rem,4vw,2rem);font-weight:900;letter-spacing:.02em;background:linear-gradient(120deg,#fff,var(--brand2));-webkit-background-clip:text;background-clip:text;color:transparent}
.pack-wrap{perspective:1100px;touch-action:none}
.pack{position:relative;width:clamp(210px,24vw,290px);aspect-ratio:5/8;border-radius:20px;cursor:grab;transform-style:preserve-3d;
  box-shadow:0 30px 80px rgba(0,0,0,.65),0 0 55px rgba(138,107,255,.28);will-change:transform}
.pack.cutting{cursor:grabbing}
.pack .layer{position:absolute;inset:0;border-radius:18px}
.pack .body2{background:var(--pc);border:2px solid rgba(255,255,255,.22);box-shadow:inset 0 0 70px rgba(0,0,0,.45)}
.pack .foil{mix-blend-mode:overlay;opacity:.78;background-size:300% 300%;animation:foilshift 3.2s linear infinite;
  background:linear-gradient(115deg,transparent 16%,rgba(255,40,200,.75),rgba(0,255,220,.75) 42%,rgba(150,90,255,.75) 58%,transparent 84%)}
.pack .holo{mix-blend-mode:screen;opacity:.5;background:repeating-linear-gradient(115deg,rgba(255,255,255,.08) 0 7px,transparent 7px 15px)}
.pack .face{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.6);z-index:2;text-align:center;padding:0 10px}
.pack .face .crest{width:84px;height:84px;clip-path:polygon(50% 0,100% 50%,50% 100%,0 50%);margin-bottom:.5rem;
  background:conic-gradient(from 210deg,#fff,var(--brand2),var(--gold),#fff);box-shadow:0 0 38px rgba(255,255,255,.6)}
.pack .face .pname{font-weight:900;letter-spacing:.2em;font-size:1.5rem;line-height:.95}
.pack .face .pname2{font-weight:900;letter-spacing:.14em;font-size:1.1rem;color:var(--brand2)}
.pack .face .psize{font-weight:800;font-size:.68rem;letter-spacing:.1em;opacity:.9;margin-top:.55rem;border:1px solid rgba(255,255,255,.45);padding:.22rem .7rem;border-radius:999px}
.pack .lid{position:absolute;top:0;left:0;right:0;height:23%;border-radius:18px 18px 0 0;overflow:hidden;transform-origin:top center;z-index:4;
  background:var(--pc);border:2px solid rgba(255,255,255,.22);border-bottom:none;box-shadow:0 8px 18px rgba(0,0,0,.35);backface-visibility:hidden}
.pack .lid .foil{border-radius:16px 16px 0 0}
.pack .ripsvg{position:absolute;top:calc(23% - 8px);left:0;width:100%;height:16px;z-index:5;overflow:visible;filter:drop-shadow(0 0 7px rgba(255,255,255,.85))}
.cutter{position:fixed;z-index:240;pointer-events:none;transform:translate(-50%,-50%) rotate(8deg);filter:drop-shadow(0 3px 6px rgba(0,0,0,.6))}
.pack-hint{color:#cdd6f4;font-weight:700;font-size:1.02rem;display:flex;gap:.55rem;align-items:center;animation:hintpulse 1.7s ease infinite}
.pack-hint .swipe{display:inline-block;animation:swipe 1.6s ease infinite}
@keyframes swipe{0%,100%{transform:translateX(-7px) rotate(8deg)}50%{transform:translateX(11px) rotate(8deg)}}
@keyframes hintpulse{0%,100%{opacity:.65}50%{opacity:1}}

/* ---- DETAIL MODAL ---- */
#modal-root .overlay{position:fixed;inset:0;z-index:150;background:rgba(4,6,14,.72);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:1rem;animation:fade .2s}
.detail{display:flex;gap:1.6rem;max-width:880px;width:100%;background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--line);border-radius:20px;padding:1.6rem;box-shadow:var(--shadow);position:relative}
.detail .big-view{width:300px;height:380px;border-radius:16px;flex-shrink:0;background:radial-gradient(120% 90% at 50% 10%,#1a2140,#080b18);position:relative;overflow:hidden}
.detail .big-view canvas{width:100%;height:100%}
.detail .meta{flex:1;min-width:0}
.detail h2{margin:.2rem 0;font-size:1.8rem}
.detail .close{position:absolute;top:12px;right:14px;font-size:1.4rem;color:var(--muted);z-index:5}
.detail .atk-row{background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:12px;padding:.7rem .9rem;margin:.5rem 0;display:flex;align-items:center;gap:.7rem}
.detail .atk-row .dmg{font-size:1.4rem;font-weight:900;margin-left:auto}
.evo-chain{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap;margin-top:1rem}
.evo-chain .arrow{color:var(--muted)}

/* ---- DECK BUILDER ---- */
.deck-layout{display:grid;grid-template-columns:1fr 320px;gap:1.4rem;align-items:start}
.deck-side{position:sticky;top:80px;background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--line);border-radius:16px;padding:1rem}
.deck-list{display:flex;flex-direction:column;gap:.35rem;max-height:46vh;overflow:auto;margin:.6rem 0}
.deck-item{display:flex;align-items:center;gap:.5rem;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:9px;padding:.35rem .5rem;font-size:.86rem}
.deck-item .swatch{width:10px;height:10px;border-radius:3px}
.deck-item .qty{margin-left:auto;font-weight:800}
.deck-item button{padding:0 .4rem;color:var(--muted);font-size:1rem}
.deck-bar{height:10px;border-radius:6px;background:var(--panel2);overflow:hidden;border:1px solid var(--line)}
.deck-bar i{display:block;height:100%;background:linear-gradient(90deg,var(--brand),var(--brand2))}
.curve{display:flex;align-items:flex-end;gap:3px;height:54px;margin-top:.5rem}
.curve .bar{flex:1;background:linear-gradient(180deg,var(--brand),#3a2fb0);border-radius:4px 4px 0 0;min-height:3px;position:relative}
.curve .bar span{position:absolute;top:-16px;left:0;right:0;text-align:center;font-size:.7rem;color:var(--muted)}

@media(max-width:820px){
  .deck-layout{grid-template-columns:1fr}
  .deck-side{position:static}
}

/* ---- DESIGNER ---- */
.designer{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem;align-items:start}
.designer .preview{display:flex;justify-content:center;align-items:flex-start}
.designer .controls{display:flex;flex-direction:column;gap:.9rem}
.field label{display:block;font-size:.82rem;color:var(--muted);margin-bottom:.3rem;font-weight:600}
.field input,.field select,.field textarea{width:100%;background:var(--panel);border:1px solid var(--line);color:var(--ink);padding:.6rem .8rem;border-radius:10px;font-size:.95rem}
.field.row2{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}
.model-pick{display:flex;gap:.5rem;flex-wrap:wrap;max-height:160px;overflow:auto;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:.5rem}
.model-pick button{padding:.35rem .6rem;border-radius:8px;background:var(--panel2);border:1px solid var(--line);font-size:.8rem;color:var(--muted)}
.model-pick button.on{background:var(--brand);color:#fff}
@media(max-width:820px){.designer{grid-template-columns:1fr}}

/* ============================================================
   BATTLE
   ============================================================ */
.battle{position:relative;height:calc(100dvh - var(--nav-h));margin:calc(-1 * clamp(1rem,3vw,2rem));padding:.5rem clamp(.6rem,2vw,1.4rem);overflow:hidden;
  display:flex;flex-direction:column;
  background:radial-gradient(1000px 540px at 50% -5%,rgba(138,107,255,.2),transparent 62%),
             radial-gradient(800px 540px at 50% 105%,rgba(30,232,207,.14),transparent 58%)}
/* ---- Hearthstone-style framed board ---- */
.board{flex:1 1 0;min-height:0;display:flex;flex-direction:column;border-radius:18px;position:relative;overflow:hidden;
  border:2px solid #2a3357;
  box-shadow:inset 0 0 0 2px rgba(255,210,94,.16), inset 0 0 90px rgba(0,0,0,.6), 0 14px 40px rgba(0,0,0,.5);
  background:
    radial-gradient(1100px 460px at 50% -8%, rgba(255,107,122,.14), transparent 60%),
    radial-gradient(1100px 460px at 50% 108%, rgba(63,227,154,.13), transparent 60%),
    repeating-linear-gradient(90deg, rgba(255,255,255,.02) 0 1px, transparent 1px 42px),
    repeating-linear-gradient(0deg, rgba(255,255,255,.02) 0 1px, transparent 1px 42px),
    radial-gradient(130% 120% at 50% 50%, #1b2238, #0b0f1e)}
.lane{flex:1 1 0;min-height:0;display:flex;flex-direction:column;gap:.25rem;padding:.45rem clamp(.5rem,1.5vw,1.1rem);position:relative}
.lane.opp{justify-content:flex-start}
.lane.you{justify-content:flex-end}
.lane-row{display:flex;align-items:center;gap:clamp(.5rem,2vw,1.4rem);flex:1;min-height:0}
.active-slot{flex:0 0 auto;position:relative;width:clamp(130px,18.5vh,196px);height:clamp(130px,18.5vh,196px);border-radius:18px;
  background:radial-gradient(circle at 50% 26%, rgba(138,107,255,.14), transparent 70%);
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.1), inset 0 0 26px rgba(0,0,0,.45)}
.active-slot .slot-label{position:absolute;top:6px;left:0;right:0;text-align:center;font-size:.58rem;letter-spacing:.2em;font-weight:800;color:rgba(255,255,255,.26);pointer-events:none;z-index:0}

.pbar{display:flex;align-items:center;gap:.7rem;padding:.4rem .9rem;border-radius:14px;background:rgba(16,22,42,.72);border:1px solid var(--line);box-shadow:0 4px 16px rgba(0,0,0,.3)}
.pbar .avatar{width:40px;height:40px;border-radius:50%;background:conic-gradient(from 0deg,var(--brand),var(--brand2),var(--gold),var(--brand));display:flex;align-items:center;justify-content:center;font-weight:900;font-size:1.1rem}
.pbar .pname{font-weight:800;font-size:1rem;line-height:1.1}
.pbar .prizes{display:flex;gap:5px;margin-top:3px}
.prize-dot{width:15px;height:15px;border-radius:50%;background:var(--panel2);border:1px solid var(--line)}
.prize-dot.won{background:var(--gold);box-shadow:0 0 10px var(--gold)}
.pbar .meta{color:var(--muted);font-size:.85rem;font-weight:700;margin-left:.4rem}

.battle-mon{width:100%;height:100%;position:relative;border-radius:18px}
.battle-mon canvas{width:100%;height:100%}
.battle-mon .hpbar{position:absolute;bottom:6px;left:12%;right:12%;height:11px;border-radius:7px;background:#0009;border:1px solid var(--line);overflow:hidden}
.battle-mon .hpbar i{display:block;height:100%;background:linear-gradient(90deg,var(--good),#9bf0c0);transition:width .5s}
.battle-mon .hpbar.low i{background:linear-gradient(90deg,var(--bad),#ffa6ae)}
.battle-mon .nameplate{position:absolute;top:-12px;left:50%;transform:translateX(-50%);white-space:nowrap;background:rgba(14,18,36,.95);border:1px solid var(--line);border-radius:9px;padding:3px 12px;font-weight:800;font-size:.95rem;box-shadow:0 3px 12px rgba(0,0,0,.4)}
.battle-mon .energy-dots{position:absolute;bottom:-30px;left:50%;transform:translateX(-50%);
  height:25px;line-height:23px;padding:0 12px;border-radius:999px;white-space:nowrap;text-align:center;
  background:rgba(12,16,30,.88);border:1px solid var(--line);box-shadow:0 4px 12px rgba(0,0,0,.45);font-size:13px}
.battle-mon .energy-dots .ebolt{vertical-align:middle;margin-right:5px;filter:drop-shadow(0 0 4px rgba(255,210,94,.7))}
.battle-mon .energy-dots .epips{vertical-align:middle;letter-spacing:3px;font-size:13px;color:var(--type,#888);
  text-shadow:0 0 7px color-mix(in srgb,var(--type,#888) 55%,transparent)}
.battle-mon .energy-dots.ready{border-color:var(--good);box-shadow:0 0 13px rgba(63,227,154,.5)}
.status-tag{position:absolute;top:-10px;right:-6px;font-size:.68rem;font-weight:800;padding:2px 7px;border-radius:6px}
.status-tag.poison{background:var(--t-Mind);color:#fff}
.status-tag.stun{background:var(--t-Spark);color:#3a2a00}
.battle-mon.targetable{cursor:pointer;box-shadow:0 0 0 3px var(--brand2),0 0 22px rgba(30,232,207,.5)}

/* bench as a row of (slightly smaller) cards in framed slots */
.bench-row{display:flex;gap:clamp(.35rem,1vw,.7rem);align-items:center;flex:1;min-height:0;justify-content:flex-start;flex-wrap:nowrap}
.bslot{flex:0 0 auto;position:relative;border-radius:12px;display:flex;align-items:center;justify-content:center}
.bslot.empty{width:clamp(76px,13vh,118px);aspect-ratio:5/7;border:1.5px dashed rgba(255,255,255,.12);background:rgba(255,255,255,.02)}
.bslot .bslot-plus{color:rgba(255,255,255,.16);font-size:1.7rem;font-weight:300}
.bslot.targetable{outline:2px solid var(--brand2);outline-offset:3px;border-radius:15px;cursor:pointer}
.bench-card{transition:transform .12s}
.bench-card .bcard-hp{position:absolute;left:6%;right:6%;bottom:5px;height:6px;border-radius:4px;background:#000a;border:1px solid var(--line);overflow:hidden;z-index:5}
.bench-card .bcard-hp i{display:block;height:100%;background:linear-gradient(90deg,var(--good),#9bf0c0);transition:width .4s}
.bench-card .bcard-hp i.low{background:linear-gradient(90deg,var(--bad),#ffa6ae)}
.bench-card .bcard-energy{position:absolute;top:5px;left:5px;z-index:6;background:rgba(12,16,30,.92);border:1px solid var(--line);border-radius:999px;padding:1px 6px;font-size:.6rem;font-weight:800;color:var(--gold)}
.bench-card .bcard-energy.ready{border-color:var(--good);color:var(--good)}

/* THE SURGE meter */
.surge{flex:0 0 auto;display:flex;align-items:center;justify-content:center;gap:.7rem;padding:.3rem 0;position:relative}
.mom-label{font-size:.82rem;color:var(--muted);font-weight:800;letter-spacing:.04em}
.mom-label.bad{color:var(--bad)} .mom-label.good{color:var(--good)}
.mom-track{width:min(440px,64vw);height:18px;border-radius:11px;border:1px solid var(--line);position:relative;overflow:visible;
  background:linear-gradient(90deg,rgba(255,107,122,.4),rgba(255,255,255,.06) 50%,rgba(63,227,154,.4))}
.mom-needle{position:absolute;top:50%;width:22px;height:22px;border-radius:50%;background:conic-gradient(from 0deg,var(--brand),var(--brand2),var(--gold),var(--brand));transform:translate(-50%,-50%);left:50%;transition:left .5s cubic-bezier(.4,1.4,.5,1);box-shadow:0 0 16px rgba(138,107,255,.8),0 0 0 2px #0008}
.surge-tag{position:absolute;top:-30px;left:50%;transform:translateX(-50%);white-space:nowrap;font-weight:900;font-size:.82rem;color:var(--gold);background:rgba(20,16,4,.7);border:1px solid var(--gold);border-radius:8px;padding:2px 10px;opacity:0;transition:opacity .3s}
.surge-tag.on{opacity:1}
.surge-ready{animation:surgepulse 1s ease infinite}
@keyframes surgepulse{0%,100%{box-shadow:0 0 16px rgba(255,210,94,.6),0 0 0 2px #0008}50%{box-shadow:0 0 30px rgba(255,210,94,1),0 0 0 2px #0008}}

/* hand */
.hand-zone{flex:0 0 auto;display:flex;justify-content:center;align-items:flex-end;min-height:clamp(120px,20vh,196px);padding-top:.4rem;perspective:1200px}
.hand-zone .card{--cw:clamp(110px,15vh,150px);margin:0 -16px;transform-origin:bottom center;transition:transform .18s,margin .18s;cursor:grab}
.hand-zone .card:hover{transform:translateY(-30px);z-index:10;margin:0 10px}
.hand-zone .card.playable{box-shadow:0 0 0 2px var(--good),0 14px 34px rgba(0,0,0,.55)}

.battle-controls{position:absolute;bottom:clamp(.6rem,2vh,1.1rem);right:clamp(.6rem,2vw,1.2rem);display:flex;gap:.5rem;z-index:20;flex-direction:column;align-items:flex-end}
.battle-controls .btn{box-shadow:0 6px 18px rgba(0,0,0,.4)}
.turn-banner{position:fixed;top:42%;left:50%;transform:translate(-50%,-50%) scale(.7);z-index:120;font-size:clamp(2rem,8vw,4rem);font-weight:900;letter-spacing:.05em;opacity:0;pointer-events:none;text-shadow:0 4px 30px rgba(0,0,0,.85)}
.turn-banner.show{animation:banner 1.4s ease forwards}
@keyframes banner{0%{opacity:0;transform:translate(-50%,-50%) scale(.6)}20%{opacity:1;transform:translate(-50%,-50%) scale(1)}80%{opacity:1}100%{opacity:0;transform:translate(-50%,-50%) scale(1.1)}}

.log{position:absolute;left:clamp(.6rem,2vw,1.2rem);bottom:clamp(.6rem,2vh,1.1rem);width:min(300px,34vw);max-height:130px;overflow:auto;background:rgba(14,18,36,.78);border:1px solid var(--line);border-radius:12px;padding:.6rem .8rem;font-size:.82rem;z-index:20}
.log p{margin:.18rem 0;color:var(--muted)}
.log p b{color:var(--ink)}
.dmg-float{position:fixed;font-weight:900;font-size:2rem;color:#fff;text-shadow:0 2px 10px #000;pointer-events:none;z-index:130;animation:dmgfloat 1s ease forwards}
@keyframes dmgfloat{0%{transform:translateY(0) scale(.6);opacity:0}20%{transform:translateY(-12px) scale(1.25);opacity:1}100%{transform:translateY(-60px) scale(1);opacity:0}}

/* attack picker */
.attack-picker{position:absolute;bottom:120px;left:50%;transform:translateX(-50%);z-index:40;display:flex;flex-direction:column;gap:.5rem;background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--line);border-radius:16px;padding:1rem;box-shadow:var(--shadow);min-width:260px}
.attack-opt{display:flex;align-items:center;gap:.6rem;padding:.6rem .8rem;border-radius:10px;background:rgba(255,255,255,.04);border:1px solid var(--line);text-align:left;width:100%}
.attack-opt:hover{border-color:var(--brand2)}
.attack-opt:disabled{opacity:.4}
.attack-opt .dmg{margin-left:auto;font-weight:900;font-size:1.15rem}

/* result */
.result-screen{position:fixed;inset:0;z-index:160;background:radial-gradient(circle at 50% 40%,rgba(20,26,55,.96),rgba(4,6,14,.98));display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.2rem;text-align:center;animation:fade .4s}
.result-screen h1{font-size:clamp(2.5rem,9vw,5rem);font-weight:900;margin:0}
.result-screen.win h1{background:linear-gradient(120deg,#ffe79a,var(--gold));-webkit-background-clip:text;background-clip:text;color:transparent}
.result-screen.lose h1{color:var(--bad)}
.reward-line{font-size:1.3rem;color:var(--gold);font-weight:800}

/* ---- toasts ---- */
#toast-stack{position:fixed;bottom:1rem;left:50%;transform:translateX(-50%);z-index:300;display:flex;flex-direction:column;gap:.5rem;align-items:center;pointer-events:none}
.toast{background:linear-gradient(135deg,var(--panel2),var(--panel));border:1px solid var(--line);border-radius:12px;padding:.7rem 1.1rem;font-weight:600;box-shadow:var(--shadow);animation:toastin .3s ease;max-width:90vw}
.toast.good{border-color:var(--good)}
.toast.bad{border-color:var(--bad)}
.toast.gold{border-color:var(--gold)}
@keyframes toastin{from{transform:translateY(20px);opacity:0}to{transform:none;opacity:1}}

/* tutorial coach marks */
.coach{position:fixed;top:74px;left:50%;transform:translateX(-50%);z-index:170;width:min(460px,92vw);
  background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--brand);border-radius:16px;
  padding:1rem 1.2rem;box-shadow:0 18px 54px rgba(0,0,0,.65),0 0 0 1px rgba(138,107,255,.3);animation:coachin .3s ease}
.coach h3{margin:.25rem 0;font-size:1.25rem}
.coach p{margin:.3rem 0 .85rem;color:#dbe2ff;font-size:.97rem;line-height:1.5}
.coach-step{font-size:.72rem;color:var(--brand2);font-weight:800;text-transform:uppercase;letter-spacing:.08em}
.coach-actions{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap}
.coach-hint{color:var(--gold);font-weight:700;font-size:.86rem}
.coach-ring{position:fixed;z-index:160;border:3px solid var(--brand2);border-radius:16px;pointer-events:none;
  box-shadow:0 0 0 9999px rgba(6,8,15,.45),0 0 22px rgba(30,232,207,.6);transition:left .2s,top .2s,width .2s,height .2s;animation:ringpulse 1.4s ease infinite}
@keyframes ringpulse{0%,100%{box-shadow:0 0 0 9999px rgba(6,8,15,.45),0 0 16px rgba(30,232,207,.5)}50%{box-shadow:0 0 0 9999px rgba(6,8,15,.45),0 0 30px rgba(30,232,207,.95)}}
@keyframes coachin{from{opacity:0;transform:translateX(-50%) translateY(-12px)}to{opacity:1;transform:translateX(-50%)}}

/* empty states / loaders */
.empty{text-align:center;padding:3rem 1rem;color:var(--muted)}
.spinner{width:34px;height:34px;border-radius:50%;border:3px solid var(--line);border-top-color:var(--brand2);animation:spin 1s linear infinite;margin:1rem auto}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-screen{position:fixed;inset:0;z-index:400;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem}
.loading-screen .brand-mark{width:60px;height:60px;animation:pulse 1.4s ease infinite}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.15)}}

@media(max-width:760px){
  .nav{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;background:var(--panel);padding:.6rem;border-bottom:1px solid var(--line)}
  .nav.open{display:flex}
  .menu-toggle{display:block}
  .detail{flex-direction:column}
  .detail .big-view{width:100%;height:300px}
  .field-mid{grid-template-columns:1fr}
  .log{display:none}
}

/* ---- DEV PANEL (dev mode only) ---- */
.dev-badge{position:fixed;right:10px;bottom:10px;z-index:500;background:#1a1020;border:1px solid #ff6b7a;color:#ff9aa3;font:700 12px/1 "Cascadia Code",Consolas,monospace;padding:.4rem .6rem;border-radius:8px;letter-spacing:.12em;opacity:.5;cursor:pointer}
.dev-badge:hover{opacity:1}
.dev-panel{position:fixed;top:0;right:0;height:100dvh;width:min(390px,94vw);z-index:560;transform:translateX(106%);
  transition:transform .25s cubic-bezier(.3,.8,.3,1);background:linear-gradient(180deg,#16101f,#0b0911);
  border-left:2px solid #ff6b7a;box-shadow:-14px 0 44px rgba(0,0,0,.6);display:flex;flex-direction:column;
  font-family:"Cascadia Code",Consolas,monospace}
.dev-panel.open{transform:none}
.dev-head{display:flex;justify-content:space-between;align-items:center;padding:.8rem 1rem;border-bottom:1px solid #3a2433;color:#ff9aa3;font-weight:800;letter-spacing:.06em}
.dev-head small{color:#7a5563;font-weight:600;margin-left:.4rem;font-size:.7rem}
.dev-x{color:#ff9aa3;font-size:1.1rem;cursor:pointer}
.dev-status{padding:.55rem 1rem;font-size:.72rem;color:#cdb6c2;border-bottom:1px solid #2a1c26;line-height:1.8}
.dev-status b{color:#fff}
.dev-body{flex:1;overflow-y:auto;padding:.5rem 1rem 2.5rem}
.dev-sec{margin:.7rem 0}
.dev-sec h4{margin:.2rem 0 .5rem;color:#ff8a98;font-size:.74rem;letter-spacing:.04em;text-transform:uppercase}
.dev-btns{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center}
.dev-btns button{background:#241726;border:1px solid #4a2f3e;color:#ffd6dd;font:600 12px/1 "Cascadia Code",Consolas,monospace;padding:.45rem .6rem;border-radius:7px;cursor:pointer;transition:.12s}
.dev-btns button:hover{background:#3a2030;border-color:#ff6b7a}
.dev-btns button.warn{border-color:#ff5d6c;color:#ff9aa3}
.dev-btns button.warn:hover{background:#3a1216}
.dev-btns button.gold{border-color:var(--gold);color:var(--gold)}
.dev-inline{display:flex;gap:.3rem;align-items:center}
.dev-btns input{background:#0f0b14;border:1px solid #4a2f3e;color:#fff;border-radius:6px;padding:.42rem;font:600 12px monospace;width:96px}
.dev-chk{display:flex;align-items:center;gap:.25rem;color:#cdb6c2;font-size:.72rem}
.dev-chk input{width:auto}
