*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#060608;--bg-card:#0c0c10;--bg-panel:#0a0a0ef0;--bg-input:#111116;--border:#1a140a;--border-gold:#8b6914;--border-glow:#ff8c0033;--text:#c8b89a;--text-dim:#7a6e5a;--text-muted:#3e3828;--accent:#e85d00;--gold:#d4a418;--red:#a11;--red-bright:#d22;--blue:#1a4a8a;--blue-bright:#3a7aff;--green:#1a6a1a;--green-bright:#3a3;--purple:#6a3aaa;--hp-fill:linear-gradient(90deg, #4a0000, #8b0000, #a11);--mana-fill:linear-gradient(90deg, #0a1a3a, #1a3a6a, #25a);--xp-fill:linear-gradient(90deg, #3a2800, #8b6914, #d4a418);--pixel:"Press Start 2P", monospace;--ui:"Inter", -apple-system, sans-serif;--stone-border:linear-gradient(135deg, #2a1a0a, #1a1208, #2a1a0a, #0e0a06)}html{font-size:16px}body{background:var(--bg);color:var(--text);font-family:var(--ui);min-height:100vh;line-height:1.5}.df-panel{background:var(--bg-panel);border:1px solid var(--border);border-image:var(--stone-border) 1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:inset 0 1px #ffc8640a,inset 0 -1px #00000080,0 4px 16px #0009}.nes-box{background:var(--bg-card);border:1px solid var(--border);padding:12px;box-shadow:0 2px 12px #00000080,inset 0 1px #ffc86408}.pixel-text{font-family:var(--pixel)}.pixel-title{font-family:var(--pixel);color:var(--gold);text-shadow:0 0 12px #d4a4184d,2px 2px #000;font-size:1rem}.pixel-sm{font-family:var(--pixel);color:var(--text);font-size:.5rem;line-height:1.8}.btn{font-family:var(--pixel);border:1px solid var(--border-gold);color:var(--gold);cursor:pointer;text-transform:uppercase;letter-spacing:1px;text-shadow:0 0 6px #d4a4184d;background:linear-gradient(#8b691426 0%,#0a0804e6 100%);padding:8px 16px;font-size:.5rem;transition:all .2s}.btn:hover{border-color:var(--gold);background:linear-gradient(#8b69144d 0%,#141008f2 100%);box-shadow:0 0 12px #d4a41833,inset 0 1px #ffc8641a}.btn:disabled{opacity:.3;cursor:default}.btn:disabled:hover{box-shadow:none;background:linear-gradient(#8b691426 0%,#0a0804e6 100%)}.btn-red{border-color:var(--red);color:var(--red-bright)}.btn-red:hover{border-color:var(--red-bright);box-shadow:0 0 12px #aa11114d}.btn-green{border-color:var(--green);color:var(--green-bright)}.btn-green:hover{border-color:var(--green-bright);box-shadow:0 0 12px #1a6a1a4d}.btn-gold{border-color:var(--gold);color:var(--gold)}.btn-gold:hover{background:#d4a41826;box-shadow:0 0 16px #d4a4184d}.btn-purple{border-color:var(--purple);color:#9a6aee}.btn-full{width:100%}.page{max-width:1400px;margin:0 auto;padding:0 8px 32px}.page-center{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:32px 16px;display:flex}.game-layout{gap:0;width:100%;max-width:1400px;height:calc(100vh - 50px);min-height:600px;margin:0 auto;display:flex}.game-sidebar{border-right:1px solid var(--border);background:#080808;flex-direction:column;flex-shrink:0;gap:1px;width:240px;display:flex;overflow:hidden auto}.sidebar-section{background:var(--bg-card);border-bottom:1px solid var(--border);padding:10px}.sidebar-section-title{font-family:var(--pixel);color:var(--text-muted);text-transform:uppercase;letter-spacing:2px;margin-bottom:8px;font-size:.35rem}.minimap-container{border:1px solid var(--border);background:#000;width:220px;height:176px;margin:0 auto;position:relative;overflow:hidden}.minimap-canvas{width:100%;height:100%;image-rendering:pixelated}.hero-portrait{border:1px solid var(--border-gold);background:#0a0a0a;border-radius:2px;width:80px;height:80px;margin:0 auto 8px;overflow:hidden;box-shadow:0 0 8px #d4a4181a}.hero-portrait img{object-fit:cover;width:100%;height:100%}.bar-container{background:#0a0808;border:1px solid #281e1499;border-radius:1px;width:100%;height:10px;margin:3px 0;position:relative;overflow:hidden}.bar-fill{height:100%;transition:width .4s;position:relative}.bar-fill:after{content:"";background:linear-gradient(#ffffff1a 0%,#0000 50%);position:absolute;inset:0}.bar-hp{background:var(--hp-fill)}.bar-mana{background:var(--mana-fill)}.bar-xp{background:var(--xp-fill)}.bar-label{font-family:var(--pixel);color:var(--text-dim);justify-content:space-between;padding:0 2px;font-size:.3rem;display:flex}.army-unit{cursor:pointer;border:1px solid #0000;border-radius:2px;align-items:center;gap:6px;margin-bottom:2px;padding:4px 6px;transition:all .15s;display:flex}.army-unit:hover{border-color:var(--border);background:#d4a4180d}.army-unit.selected{border-color:var(--border-gold);background:#d4a4181a;box-shadow:0 0 8px #d4a4181a}.army-unit-sprite{text-align:center;width:28px;height:28px;font-size:20px;line-height:28px}.army-unit-info{flex:1;min-width:0}.army-unit-name{font-family:var(--pixel);color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.25rem;overflow:hidden}.army-unit-role{font-family:var(--pixel);color:var(--text-muted);font-size:.2rem}.game-viewport{border:1px solid var(--border);background:#050505;flex:1;min-width:600px;height:100%;position:relative;overflow:hidden}.game-viewport:after{content:"";pointer-events:none;z-index:50;background:radial-gradient(#0000 35%,#00000080 75%,#000000bf 100%);position:absolute;inset:0}.ambient-particles{pointer-events:none;z-index:45;position:absolute;inset:0;overflow:hidden}.particle{opacity:0;border-radius:50%;position:absolute}.particle-ember{background:#f60;width:3px;height:3px;animation:3s ease-out infinite emberRise;box-shadow:0 0 4px 1px #f609}@keyframes emberRise{0%{opacity:0;transform:translate(0)scale(1)}20%{opacity:.9}80%{opacity:.4;transform:translate(20px,-80px)scale(.5)}to{opacity:0;transform:translate(30px,-120px)scale(.2)}}.particle-wisp{background:#648cff99;width:4px;height:4px;animation:5s ease-in-out infinite wispFloat;box-shadow:0 0 8px 3px #648cff4d}@keyframes wispFloat{0%{opacity:0;transform:translate(0)}25%{opacity:.7;transform:translate(20px,-15px)}50%{opacity:.3;transform:translate(-15px,-35px)}75%{opacity:.6;transform:translate(25px,-55px)}to{opacity:0;transform:translate(5px,-70px)}}.particle-spore{background:#50b43c80;width:2px;height:2px;animation:7s linear infinite sporeFloat;box-shadow:0 0 4px 1px #50b43c4d}@keyframes sporeFloat{0%{opacity:0;transform:translate(0)}15%{opacity:.6}85%{opacity:.3}to{opacity:0;transform:translate(30px,-90px)}}.particle-dust{background:#a0825a66;width:2px;height:2px;animation:6s linear infinite dustFloat}@keyframes dustFloat{0%{opacity:0;transform:translate(0)rotate(0)}20%{opacity:.4}80%{opacity:.2}to{opacity:0;transform:translate(40px,-80px)rotate(360deg)}}.damage-flash{pointer-events:none;z-index:48;background:radial-gradient(circle,#b4000033 0%,#5000004d 100%);animation:.3s ease-out forwards flashFade;position:absolute;inset:0}@keyframes flashFade{0%{opacity:1}to{opacity:0}}.float-text{font-family:var(--pixel);z-index:55;pointer-events:none;text-shadow:0 0 6px,1px 1px 2px #000;font-size:.5rem;animation:1.2s ease-out forwards floatUp;position:absolute}.float-text-damage{color:#f33}.float-text-heal{color:#3f3}.float-text-xp{color:var(--gold)}@keyframes floatUp{0%{opacity:1;transform:translateY(0)scale(1.2)}30%{transform:translateY(-10px)scale(1)}to{opacity:0;transform:translateY(-50px)scale(.8)}}.tile-grid{will-change:transform;grid-template-rows:repeat(48,64px);grid-template-columns:repeat(48,64px);width:3072px;height:3072px;transition:transform .18s cubic-bezier(.25,.46,.45,.94);display:grid}.tile{-webkit-user-select:none;user-select:none;image-rendering:auto;background-position:50%;background-repeat:no-repeat;background-size:cover;justify-content:center;align-items:center;width:64px;height:64px;font-size:16px;display:flex;position:relative}.tile:after{content:"";pointer-events:none;position:absolute;inset:0;box-shadow:inset 0 0 3px #0003}.tile-grass{background-color:#141a0e}.tile-forest{background-color:#0a120a}.tile-water{background-color:#060e1a}.tile-hills{background-color:#1a160e}.tile-night{background-color:#08081a}.tile-dungeon{background-color:#140a0a}.tile-path{background-color:#1a1610}.tile-wall{background-color:#1a1a1a}.tile-water{animation:5s ease-in-out infinite waterDark}@keyframes waterDark{0%,to{filter:brightness()}50%{filter:brightness(1.08)hue-rotate(3deg)}}.tile-dungeon:before{content:"";pointer-events:none;background:radial-gradient(circle at 60% 70%,#ff50140f 0%,#0000 60%);animation:2.5s ease-in-out infinite torchFlicker;position:absolute;inset:0}@keyframes torchFlicker{0%,to{opacity:.2}20%{opacity:.6}40%{opacity:.3}70%{opacity:.7}}.tile-night:before{content:"";pointer-events:none;background:radial-gradient(circle at 40% 30%,#5064c80d 0%,#0000 50%);animation:6s ease-in-out infinite moonPulse;position:absolute;inset:0}@keyframes moonPulse{0%,to{opacity:.3}50%{opacity:.7}}.tile-forest:before{content:"";pointer-events:none;background:linear-gradient(#0028001a 0%,#0000 100%);animation:8s ease-in-out infinite fogDrift;position:absolute;inset:0}@keyframes fogDrift{0%,to{opacity:.2;transform:translate(0)}50%{opacity:.5;transform:translate(3px)}}.tactical-tile{pointer-events:none;z-index:8;border:1px solid #0000;transition:all .2s;position:absolute;inset:0}.tactical-tile.deploy-zone{background:#1e64c81f;border-color:#1e64c84d}.tactical-tile.threat-zone{background:#c81e1e1a;border-color:#c81e1e33}.tactical-tile.defended{background:#1ea01e1a;border-color:#1ea01e40}.tactical-tile.patrol-zone{border-style:dashed;border-color:#d4a4184d}.sprite-char{object-fit:contain;image-rendering:auto;z-index:10;filter:drop-shadow(1px 2px 4px #000c);width:48px;height:48px}.sprite-char-player{filter:drop-shadow(0 0 8px #e85d0040)drop-shadow(0 0 20px #e85d001a)drop-shadow(2px 4px 8px #000c);z-index:20;width:96px;height:96px;transition:transform .12s;position:absolute;top:50%;left:50%;transform:translate(-50%,-65%)}.sprite-char-player.facing-left{transform:translate(-50%,-65%)scaleX(-1)}.sprite-char-player.is-moving{animation:.25s ease-in-out infinite runBounce}@keyframes runBounce{0%,to{margin-top:0}50%{margin-top:-4px}}.sprite-char-player.is-attacking{animation:.35s ease-out attackLunge}@keyframes attackLunge{0%{filter:drop-shadow(0 0 8px #e85d0040)drop-shadow(2px 4px 8px #000c);transform:translate(-50%,-65%)scale(1)}30%{filter:drop-shadow(0 0 16px #ff500080)drop-shadow(2px 4px 8px #000c);transform:translate(-50%,-65%)scale(1.2)}to{filter:drop-shadow(0 0 8px #e85d0040)drop-shadow(2px 4px 8px #000c);transform:translate(-50%,-65%)scale(1)}}.sprite-char-player.is-hit{animation:.25s ease-out hitShake}@keyframes hitShake{0%,to{transform:translate(-50%,-65%)}25%{transform:translate(-46%,-65%)}75%{transform:translate(-54%,-65%)}}.sprite-char-player.is-dead{animation:1s ease-out forwards deathFall}@keyframes deathFall{0%{opacity:1;transform:translate(-50%,-65%)rotate(0)}to{opacity:.2;filter:grayscale()brightness(.3);transform:translate(-50%,-45%)rotate(80deg)}}.sprite-enemy-img{object-fit:contain;image-rendering:auto;filter:drop-shadow(1px 2px 4px #000c);width:48px;height:48px;transition:transform .3s}.sprite-enemy-img.enemy-idle{animation:2.5s ease-in-out infinite enemyBreathe}@keyframes enemyBreathe{0%,to{transform:scale(1)translateY(0)}50%{transform:scale(1.03)translateY(-1px)}}.sprite-enemy-img.enemy-aggro{filter:drop-shadow(1px 2px 4px #000c)drop-shadow(0 0 6px #c81e1e80);animation:.6s ease-in-out infinite enemyAggro}@keyframes enemyAggro{0%,to{transform:scale(1)}50%{transform:scale(1.06)translateY(-2px)}}.sprite-npc-friendly{filter:drop-shadow(1px 2px 4px #000c)drop-shadow(0 0 6px #c8a03c4d);animation:3s ease-in-out infinite npcGlow}@keyframes npcGlow{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}.sprite-item-img{object-fit:contain;image-rendering:auto;filter:drop-shadow(1px 2px 3px #0009);width:40px;height:40px}.sprite-hero{z-index:20;font-size:48px;position:absolute;top:50%;left:50%;transform:translate(-50%,-65%)}.sprite-enemy,.sprite-npc{font-size:32px}.sprite-item{font-size:28px}.alliance-tag{font-family:var(--pixel);white-space:nowrap;z-index:11;pointer-events:none;text-shadow:0 0 4px;background:#000000bf;border:1px solid;border-radius:1px;padding:1px 4px;font-size:.2rem;line-height:1.3;position:absolute;top:0}.deploy-banner{z-index:9;pointer-events:none;width:12px;height:16px;position:absolute;bottom:2px;right:2px}.deploy-banner:before{content:"";background:#666;width:2px;height:16px;display:block;position:absolute;right:0}.deploy-banner:after{content:"";background:var(--green-bright);clip-path:polygon(0 0,100% 0,100% 60%,50% 100%,0 60%);width:10px;height:8px;display:block;position:absolute;top:0;right:2px}@keyframes spriteAnim1{0%{background-position-x:0}to{background-position-x:-512px}}@keyframes spriteAnim2{0%{background-position-x:0}to{background-position-x:-1024px}}@keyframes spriteAnim3{0%{background-position-x:0}to{background-position-x:-1536px}}@keyframes spriteAnim4{0%{background-position-x:0}to{background-position-x:-2048px}}@keyframes spriteAnim5{0%{background-position-x:0}to{background-position-x:-2560px}}@keyframes spriteAnim6{0%{background-position-x:0}to{background-position-x:-3072px}}.sprite-portal{animation:2s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1;filter:drop-shadow(0 0 4px #e85d004d);transform:scale(1)}50%{opacity:.7;filter:drop-shadow(0 0 10px #e85d0080);transform:scale(1.08)}}.game-bottombar{background:var(--bg-card);border-top:1px solid var(--border);font-family:var(--pixel);color:var(--text-dim);align-items:center;gap:12px;padding:6px 12px;font-size:.3rem;display:flex}.game-bottombar .log-text{white-space:nowrap;text-overflow:ellipsis;color:var(--text);flex:1;overflow:hidden}.game-bottombar .hotkey{color:var(--text-muted);border:1px solid var(--border);background:#ffffff05;border-radius:2px;padding:2px 6px}.game-bottombar .hotkey kbd{color:var(--gold);font-family:var(--pixel)}.game-nav{border-bottom:1px solid var(--border);background:linear-gradient(#0e0e10 0%,#080808 100%);align-items:center;gap:8px;padding:8px 16px;display:flex}.game-nav a{font-family:var(--pixel);color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;padding:4px 8px;font-size:.4rem;text-decoration:none;transition:color .15s}.game-nav a:hover{color:var(--gold);text-shadow:0 0 8px #d4a4184d}.stat-bar{flex-wrap:wrap;justify-content:center;gap:12px;margin:12px 0;display:flex}.stat-item{text-align:center;min-width:50px}.stat-label{font-family:var(--pixel);color:var(--text-muted);text-transform:uppercase;margin-bottom:2px;font-size:.35rem;display:block}.stat-val{font-family:var(--pixel);font-size:.7rem;display:block}.stat-val.str{color:var(--red-bright)}.stat-val.dex{color:var(--green-bright)}.stat-val.con{color:var(--gold)}.stat-val.int{color:var(--blue-bright)}.stat-val.wis{color:var(--purple)}.stat-val.cha{color:#c68}.world-map{border:1px solid var(--border);background:#000;gap:1px;width:fit-content;margin:0 auto;display:grid}.map-cell{cursor:pointer;width:12px;height:12px;transition:all .1s;position:relative}.map-cell:hover{outline:1px solid var(--gold);z-index:1}.map-cell.current{outline:2px solid var(--accent);z-index:2;box-shadow:0 0 6px #e85d0066}.map-plains{background:#1a2a1a}.map-forest{background:#0e1a0e}.map-water{background:#0e1420}.map-hills{background:#2a2018}.map-night{background:#10101e}.map-dungeon{background:#1e0e1e}.inv-grid{grid-template-columns:repeat(6,1fr);gap:6px;margin:12px 0;display:grid}.inv-slot{aspect-ratio:1;background:var(--bg-input);border:1px solid var(--border);cursor:pointer;flex-direction:column;justify-content:center;align-items:center;font-size:1.5rem;transition:border-color .15s;display:flex;position:relative}.inv-slot:hover{border-color:var(--border-gold)}.inv-slot.equipped{border-color:var(--gold);box-shadow:0 0 8px #d4a41833}.inv-count{font-family:var(--pixel);color:var(--text-dim);font-size:.4rem;position:absolute;bottom:2px;right:4px}.equip-grid{grid-template-columns:1fr 1fr 1fr;gap:8px;max-width:300px;margin:16px auto;display:grid}.equip-slot{text-align:center}.equip-slot-name{font-family:var(--pixel);color:var(--text-muted);text-transform:uppercase;margin-bottom:4px;font-size:.35rem}.dialog-box{border:1px solid var(--border-gold);font-family:var(--pixel);color:var(--text);background:#000000d9;max-width:480px;margin:12px auto;padding:10px 14px;font-size:.45rem;line-height:2;position:relative;box-shadow:0 0 20px #00000080}.dialog-box:after{content:"▼";color:var(--gold);animation:1s steps(2,end) infinite blink;position:absolute;bottom:4px;right:8px}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.combat-panel{justify-content:center;align-items:center;gap:16px;max-width:500px;margin:12px auto;padding:16px;display:flex}.combatant{text-align:center;flex:1}.combatant-sprite{margin-bottom:8px;font-size:3rem}.combat-vs{font-family:var(--pixel);color:var(--red-bright);text-shadow:0 0 8px #aa111180;font-size:1rem}@media (width<=1080px){.game-sidebar{width:200px}.minimap-container{width:180px;height:144px}}@media (width<=900px){.game-layout{flex-direction:column;height:auto}.game-sidebar{border-right:none;border-bottom:1px solid var(--border);flex-direction:row;width:100%;height:auto;overflow-x:auto}.sidebar-section{min-width:200px}.game-viewport{min-height:500px}}
