:root{--bg-0: #080c18;--bg-1: #0e1528;--bg-2: #182038;--accent: #ffd84d;--accent-2: #ff6b3d;--left: #4dd0ff;--right: #ff5277;--text: #f0f2ff;--muted: #7b85a8;--good: #4dffa8;--bad: #ff5277;--font-display: "Bangers", cursive;--font-body: "Outfit", sans-serif;--card-glow: 0 0 20px rgba(255, 216, 77, .15);--glass: rgba(12, 16, 32, .72);--glass-border: rgba(255, 255, 255, .08)}*{box-sizing:border-box;margin:0;padding:0}html,body,#app{width:100%;height:100%;background:var(--bg-0);color:var(--text);font-family:var(--font-body);overflow:hidden;user-select:none}button{font-family:var(--font-body);cursor:pointer;border:none;background:none;color:inherit}.title-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;position:relative;overflow:hidden;background:radial-gradient(ellipse at 25% 20%,rgba(77,208,255,.12),transparent 55%),radial-gradient(ellipse at 75% 80%,rgba(255,82,119,.12),transparent 55%),radial-gradient(circle at 50% 50%,var(--bg-1),var(--bg-0))}.title-screen:before{content:"";position:absolute;inset:-50%;background:repeating-linear-gradient(-45deg,transparent 0px,transparent 60px,rgba(255,216,77,.03) 60px,rgba(255,216,77,.03) 62px);animation:slideLines 12s linear infinite;pointer-events:none}@keyframes slideLines{0%{transform:translate(0)}to{transform:translate(85px)}}.title-screen:after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at center,transparent 40%,rgba(0,0,0,.6) 100%);pointer-events:none}.title-logo{font-family:var(--font-display);font-size:clamp(56px,12vw,160px);font-weight:400;letter-spacing:6px;background:linear-gradient(160deg,#ffd84d 10%,#ff6b3d,#ff5277 90%);-webkit-background-clip:text;background-clip:text;color:transparent;filter:drop-shadow(0 6px 24px rgba(255,107,61,.45)) drop-shadow(0 0 80px rgba(255,107,61,.2));animation:titleFloat 4s ease-in-out infinite;position:relative;z-index:1;text-align:center;line-height:1.1}.title-sub{font-family:var(--font-body);font-size:clamp(13px,1.8vw,20px);font-weight:600;color:var(--muted);margin-top:2px;margin-bottom:44px;letter-spacing:6px;text-transform:uppercase;position:relative;z-index:1}@keyframes titleFloat{0%,to{transform:translateY(0) rotate(-.5deg)}50%{transform:translateY(-12px) rotate(.5deg)}}.btn-primary{font-family:var(--font-display);font-size:26px;letter-spacing:3px;padding:18px 52px;border-radius:14px;background:linear-gradient(160deg,var(--accent),var(--accent-2));color:#1a1200;position:relative;z-index:1;box-shadow:0 6px 28px #ff6b3d73,inset 0 2px #ffffff40,inset 0 -3px #0003;transition:transform .18s cubic-bezier(.4,0,.2,1),box-shadow .18s}.btn-primary:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 12px 40px #ff6b3d8c,inset 0 2px #ffffff40,inset 0 -3px #0003}.btn-primary:active{transform:translateY(0) scale(.98)}.btn-secondary{font-family:var(--font-body);font-weight:700;font-size:14px;padding:10px 22px;border-radius:10px;background:var(--glass);color:var(--text);border:1px solid var(--glass-border);backdrop-filter:blur(8px);transition:all .18s}.btn-secondary:hover{background:#ffffff1f;border-color:#fff3}.builder{display:grid;grid-template-columns:280px 1fr 280px;grid-template-rows:70px 1fr 90px;height:100%;gap:10px;padding:10px;background:radial-gradient(ellipse at 20% 30%,rgba(77,208,255,.06),transparent 50%),radial-gradient(ellipse at 80% 70%,rgba(255,82,119,.06),transparent 50%),var(--bg-0)}.builder-header{grid-column:1 / -1;display:flex;align-items:center;justify-content:space-between;padding:0 18px;background:var(--glass);border:1px solid var(--glass-border);border-radius:12px;backdrop-filter:blur(12px)}.builder-title{font-family:var(--font-display);font-size:24px;letter-spacing:2px}.builder-filters{display:flex;gap:6px}.filter-chip{padding:7px 16px;border-radius:8px;background:#ffffff0f;border:1px solid transparent;font-size:13px;font-weight:600;color:var(--muted);transition:all .18s}.filter-chip:hover{background:#ffffff1a;color:var(--text)}.filter-chip.active{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#1a1200;font-weight:800;border-color:transparent;box-shadow:0 2px 12px #ffd84d4d}.team-panel{display:flex;flex-direction:column;background:var(--glass);border:1px solid var(--glass-border);border-radius:12px;padding:14px;overflow:hidden;backdrop-filter:blur(12px)}.team-panel.left{border-top:3px solid var(--left);box-shadow:inset 0 2px 20px #4dd0ff14}.team-panel.right{border-top:3px solid var(--right);box-shadow:inset 0 2px 20px #ff527714}.team-panel h2{font-family:var(--font-display);font-size:16px;letter-spacing:3px;text-transform:uppercase;margin-bottom:10px}.team-panel.left h2{color:var(--left)}.team-panel.right h2{color:var(--right)}.team-slots{display:grid;grid-template-columns:1fr 1fr;gap:8px;flex:1;overflow-y:auto}.team-slot{aspect-ratio:1;background:#ffffff08;border:2px dashed rgba(255,255,255,.08);border-radius:10px;display:flex;align-items:center;justify-content:center;position:relative;font-size:22px;color:#ffffff26;transition:all .2s}.team-slot.filled{border:2px solid rgba(255,255,255,.2);background:#ffffff0d}.team-slot img{width:100%;height:100%;object-fit:contain;padding:6px}.team-slot .remove{position:absolute;top:3px;right:3px;background:#ff5277cc;color:#fff;border-radius:50%;width:20px;height:20px;font-size:13px;line-height:20px;text-align:center;opacity:0;transition:opacity .15s}.team-slot:hover .remove{opacity:1}.character-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;padding:12px;background:var(--glass);border:1px solid var(--glass-border);border-radius:12px;overflow-y:auto;align-content:start;backdrop-filter:blur(12px)}.char-card{background:linear-gradient(165deg,#ffffff12,#ffffff05);border-radius:12px;padding:10px;display:flex;flex-direction:column;align-items:center;cursor:pointer;transition:all .22s cubic-bezier(.4,0,.2,1);border:1.5px solid rgba(255,255,255,.06);position:relative}.char-card:after{content:"";position:absolute;inset:0;background:linear-gradient(105deg,transparent 30%,rgba(255,255,255,.08) 45%,transparent 60%);transform:translate(-100%);transition:transform .5s ease;pointer-events:none}.char-card:hover:after{transform:translate(100%)}.char-card:hover{transform:translateY(-6px) scale(1.03);border-color:var(--accent);box-shadow:0 8px 24px #ffd84d33,0 0 0 1px #ffd84d26}.char-card:active{transform:translateY(-2px) scale(.98)}.char-card.faction-pokemon{background:linear-gradient(165deg,#ffd84d1f,#ffffff05)}.char-card.faction-plant{background:linear-gradient(165deg,#4dffa81f,#ffffff05)}.char-card.faction-zombie{background:linear-gradient(165deg,#b45ac81f,#ffffff05)}.char-card img{width:96px;height:96px;object-fit:contain;image-rendering:-webkit-optimize-contrast;filter:drop-shadow(0 4px 8px rgba(0,0,0,.4));transition:transform .22s}.char-card:hover img{transform:scale(1.1)}.char-card .name{font-family:var(--font-display);font-size:14px;letter-spacing:1px;margin-top:6px;text-align:center}.char-card .stats{font-size:10px;font-weight:600;color:var(--muted);margin-top:4px;display:flex;gap:6px}.char-card .stats span{display:flex;gap:2px}.builder-footer{grid-column:1 / -1;display:flex;align-items:center;justify-content:space-between;padding:0 24px;background:var(--glass);border:1px solid var(--glass-border);border-radius:12px;backdrop-filter:blur(12px)}.battle-screen{position:relative;width:100%;height:100%}#game-canvas{width:100%;height:100%;display:block}.battle-hud{position:absolute;top:0;left:0;right:0;padding:10px;display:flex;justify-content:space-between;pointer-events:none}.team-roster{display:flex;flex-direction:column;gap:3px;background:var(--glass);padding:10px;border-radius:10px;backdrop-filter:blur(14px);border:1px solid var(--glass-border);min-width:170px}.team-roster.left{border-left:3px solid var(--left)}.team-roster.right{border-right:3px solid var(--right)}.roster-row{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:600}.roster-row img{width:22px;height:22px;object-fit:contain}.roster-row .hp-mini{flex:1;height:5px;background:#ffffff14;border-radius:3px;overflow:hidden}.roster-row .hp-mini-fill{height:100%;background:var(--good);transition:width .2s;border-radius:3px}.roster-row.dead{opacity:.25}.roster-row.dead .hp-mini-fill{background:var(--bad)}.spell-bar{position:absolute;bottom:20px;left:50%;transform:translate(-50%);display:flex;gap:10px;background:var(--glass);padding:12px 16px;border-radius:16px;backdrop-filter:blur(14px);border:1px solid var(--glass-border);pointer-events:auto;box-shadow:0 8px 32px #0006}.spell-btn{width:66px;height:66px;border-radius:12px;background:#ffffff0f;border:2px solid rgba(255,255,255,.08);display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:30px;position:relative;transition:all .18s cubic-bezier(.4,0,.2,1)}.spell-btn:hover:not(:disabled){background:#ffffff24;transform:translateY(-4px);box-shadow:0 6px 20px #ffd84d26}.spell-btn.selected{border-color:var(--accent);background:#ffd84d26;box-shadow:0 0 20px #ffd84d4d,inset 0 0 12px #ffd84d1a}.spell-btn:disabled{opacity:.35;cursor:not-allowed}.spell-btn .label{font-family:var(--font-body);font-size:9px;font-weight:700;color:var(--muted);margin-top:2px;letter-spacing:.5px}.spell-btn .cooldown{position:absolute;inset:0;border-radius:12px;background:#000000a6;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:800;font-family:var(--font-body)}.mana-bar{position:absolute;bottom:104px;left:50%;transform:translate(-50%);width:340px;height:10px;background:#00000080;border-radius:5px;overflow:hidden;border:1px solid rgba(77,208,255,.2)}.mana-fill{height:100%;background:linear-gradient(90deg,#4dd0ff,#9b6bff);transition:width .1s linear;border-radius:5px;box-shadow:0 0 8px #4dd0ff66}.battle-top-bar{position:absolute;top:10px;left:50%;transform:translate(-50%);display:flex;gap:8px;pointer-events:auto;z-index:10}.victory-overlay{position:absolute;inset:0;background:#060812cc;backdrop-filter:blur(12px);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:100;animation:victoryFadeIn .6s cubic-bezier(.4,0,.2,1)}@keyframes victoryFadeIn{0%{opacity:0;backdrop-filter:blur(0px)}to{opacity:1;backdrop-filter:blur(12px)}}.victory-title{font-family:var(--font-display);font-size:clamp(48px,10vw,90px);letter-spacing:6px;background:linear-gradient(160deg,#ffd84d,#ff6b3d);-webkit-background-clip:text;background-clip:text;color:transparent;filter:drop-shadow(0 4px 16px rgba(255,107,61,.5));margin-bottom:12px;animation:victoryPop .6s cubic-bezier(.2,.8,.3,1.2)}@keyframes victoryPop{0%{transform:scale(.3) rotate(-3deg);opacity:0}60%{transform:scale(1.08) rotate(1deg)}to{transform:scale(1) rotate(0);opacity:1}}.victory-sub{font-family:var(--font-body);font-size:22px;font-weight:700;color:var(--muted);margin-bottom:32px;letter-spacing:2px}.victory-buttons{display:flex;gap:16px}.loading{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:18px;font-weight:600;color:var(--muted);letter-spacing:1px}.loading:after{content:"";width:36px;height:36px;border:3px solid rgba(255,255,255,.08);border-top-color:var(--accent);border-radius:50%;margin-left:14px;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.char-tooltip{position:fixed;background:#0a0e1cf2;border:1px solid rgba(255,216,77,.4);border-radius:10px;padding:14px;font-size:12px;font-weight:600;pointer-events:none;z-index:1000;max-width:220px;box-shadow:0 12px 40px #000000b3,0 0 20px #ffd84d14;backdrop-filter:blur(12px)}.char-tooltip h4{font-family:var(--font-display);font-size:16px;letter-spacing:1px;margin-bottom:8px;color:var(--accent)}.char-tooltip .stat-row{display:flex;justify-content:space-between;margin:3px 0}.char-tooltip .desc{color:var(--muted);margin-top:8px;font-style:italic;font-weight:400}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff38}.kill-banner{position:absolute;top:22%;left:50%;transform:translate(-50%) scale(.6);font-family:var(--font-display);font-size:72px;letter-spacing:6px;text-shadow:0 4px 16px rgba(0,0,0,.9),0 0 40px currentColor;pointer-events:none;animation:bannerPop 1.8s ease-out forwards;z-index:50}@keyframes bannerPop{0%{transform:translate(-50%) scale(.4) rotate(-2deg);opacity:0}15%{transform:translate(-50%) scale(1.15) rotate(1deg);opacity:1}30%{transform:translate(-50%) scale(1) rotate(0)}80%{transform:translate(-50%) scale(1);opacity:1}to{transform:translate(-50%) scale(1.1);opacity:0}}.ult-bar{position:absolute;bottom:104px;left:50%;transform:translate(-50%);width:300px;height:12px;background:#00000080;border:2px solid rgba(255,216,77,.5);border-radius:6px;overflow:hidden;z-index:10}.ult-fill{height:100%;width:0%;background:linear-gradient(90deg,#f83,#ffd84d,#fffbe0);transition:width .2s;box-shadow:0 0 10px #ffd84d}.ult-label{position:absolute;top:-2px;left:50%;transform:translate(-50%);font-family:var(--font-display);font-size:10px;color:#fff;text-shadow:0 1px 4px #000;letter-spacing:3px}.weather-tag{position:absolute;top:56px;right:14px;background:var(--glass);border:1px solid var(--glass-border);backdrop-filter:blur(10px);color:#fff;padding:5px 12px;border-radius:8px;font-size:12px;font-weight:700;z-index:10;letter-spacing:.5px}.weather-tag:empty{display:none}.spell-btn.ult-btn{background:linear-gradient(135deg,#281e00cc,#46320099);border-color:#ffd84d80}.spell-btn.ult-btn.ready{animation:ultPulse 1.2s ease-in-out infinite;box-shadow:0 0 20px #ffd84d80,0 0 40px #ffaa334d;border-color:var(--accent)}@keyframes ultPulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.screen-flash{position:fixed;inset:0;pointer-events:none;z-index:200;opacity:0;transition:opacity .45s ease-out;mix-blend-mode:screen}.mvp-card{margin:18px auto;padding:16px 26px;background:linear-gradient(160deg,#281c00e6,#3c2800b3);border:2px solid rgba(255,216,77,.6);border-radius:16px;box-shadow:0 0 32px #ffd84d33,0 12px 40px #00000080;display:inline-flex;flex-direction:column;align-items:center;animation:mvpPop .6s cubic-bezier(.2,.8,.3,1.2);backdrop-filter:blur(12px)}@keyframes mvpPop{0%{transform:scale(.4) rotate(-2deg);opacity:0}60%{transform:scale(1.08);opacity:1}to{transform:scale(1)}}.mvp-label{font-family:var(--font-display);font-size:13px;color:var(--accent);letter-spacing:4px;margin-bottom:8px}.mvp-img{width:96px;height:96px;object-fit:contain;filter:drop-shadow(0 0 16px rgba(255,216,77,.4))}.mvp-name{font-family:var(--font-display);font-size:24px;color:#fff;margin-top:6px;letter-spacing:2px}.mvp-stats{display:flex;gap:14px;font-size:14px;font-weight:700;color:var(--accent);margin-top:6px}.achievement-toast{position:fixed;top:20px;right:-400px;background:linear-gradient(160deg,#120e26f2,#1e1838e6);border:1.5px solid rgba(255,216,77,.5);border-radius:12px;padding:12px 18px;display:flex;align-items:center;gap:14px;box-shadow:0 12px 40px #0009,0 0 20px #ffd84d26;backdrop-filter:blur(14px);z-index:300;animation:toastSlide 4.5s ease-in-out forwards;max-width:360px}@keyframes toastSlide{0%{right:-400px}10%{right:20px}90%{right:20px}to{right:-400px;opacity:0}}.ach-emoji{font-size:36px}.ach-title{font-family:var(--font-display);font-size:11px;color:var(--accent);letter-spacing:3px}.ach-name{font-family:var(--font-display);font-size:18px;color:#fff;letter-spacing:1px}.ach-desc{font-size:12px;color:var(--muted);font-weight:500}.lifetime-stats{display:flex;gap:10px;margin-top:8px;padding-top:6px;border-top:1px solid rgba(255,255,255,.08);font-size:11px;font-weight:700;color:var(--accent)}.streak-badge{display:inline-block;margin-left:12px;padding:4px 14px;background:linear-gradient(135deg,#f52,#fa3);border-radius:8px;font-family:var(--font-display);font-size:15px;letter-spacing:1px;vertical-align:middle;box-shadow:0 0 14px #f836;animation:streakPulse 1.4s ease-in-out infinite}@keyframes streakPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}
