*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0d0d1a;--bg-card:#161628;--bg-panel:#112;--border:#2a2a4a;--text:#dde0f0;--text-muted:#7a7a9a;--accent:#4a90ff;--team1:#4a90ff;--team2:#ff4a4a;--success:#4c6;--danger:#ff4a4a;--warning:#fc4;--cell-size:52px}html,body,#root{width:100%;height:100%;overflow:hidden}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px}.app{flex-direction:column;width:100%;height:100%;display:flex;overflow:hidden}.btn{cursor:pointer;white-space:nowrap;-webkit-user-select:none;user-select:none;border:1.5px solid #0000;border-radius:8px;justify-content:center;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .15s;display:inline-flex}.btn:active{transform:scale(.96)}.btn-primary{background:var(--team1);color:#fff;border-color:var(--team1)}.btn-primary:hover{background:#3a7ddd}.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}.btn-danger:hover{background:#dd3a3a}.btn-secondary{color:var(--text);border-color:var(--border);background:#2a2a4a}.btn-secondary:hover{background:#3a3a5a}.btn-outline{color:var(--text);border-color:var(--border);background:0 0}.btn-outline:hover{background:#ffffff0f}.btn-success{background:var(--success);color:#000;border-color:var(--success);font-weight:700}.btn-success:hover{background:#3b5}.btn-danger-outline{color:var(--danger);border-color:var(--danger);background:0 0}.btn-danger-outline:hover{background:#ff4a4a1a}.btn-text{color:var(--text-muted);background:0 0;border-color:#0000;padding:6px 10px;font-size:12px}.btn-text:hover{color:var(--text)}.btn-disabled,.btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.btn-hero{background:var(--bg-card);border:1.5px solid var(--border);color:var(--text);cursor:pointer;border-radius:12px;flex-direction:column;align-items:center;gap:4px;min-width:180px;padding:20px 24px;font-size:16px;font-weight:700;transition:all .2s;display:flex}.btn-hero:hover{border-color:var(--accent);background:#1e1e38;transform:translateY(-2px)}.btn-sub{color:var(--text-muted);font-size:11px;font-weight:400}.coming-soon{color:var(--warning)}.end-turn-btn{width:100%;margin-top:4px}@keyframes pulse-border{0%,to{box-shadow:0 0 #4a90ff66}50%{box-shadow:0 0 0 6px #4a90ff00}}.pulse{animation:1.5s ease-in-out infinite pulse-border}.home-menu{flex-direction:column;flex:1;align-items:center;gap:28px;padding:40px 20px;display:flex;overflow-y:auto}.home-hero{text-align:center}.home-logo-icon{margin-bottom:8px;font-size:56px}.home-title{letter-spacing:-1px;background:linear-gradient(135deg,#4a90ff,#c44aff);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:clamp(28px,8vw,52px);font-weight:900}.home-subtitle{color:var(--text-muted);margin-top:6px;font-size:15px}.home-nav{flex-wrap:wrap;justify-content:center;gap:16px;display:flex}.home-sections{flex-wrap:wrap;justify-content:center;gap:20px;width:100%;max-width:800px;display:flex}.home-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;flex:1;min-width:260px;max-width:380px;padding:20px}.home-card h3{color:var(--accent);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;font-size:14px;font-weight:700}.how-to-list{padding-left:18px}.how-to-list li{color:var(--text-muted);margin-bottom:8px;font-size:13px;line-height:1.5}.how-to-list strong{color:var(--text)}.terrain-legend{flex-direction:column;gap:6px;display:flex}.legend-row{align-items:center;gap:8px;font-size:12px;display:flex}.legend-icon{border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;display:flex}.legend-name{color:var(--text);flex:1;font-weight:600}.legend-effects{font-size:11px;font-weight:600}.home-footer{color:var(--text-muted);font-size:11px}.sandbox-mode{flex-direction:column;flex:1;display:flex;overflow:hidden}.sandbox-header{background:var(--bg-panel);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:10px 16px;display:flex}.sandbox-title{color:var(--text);text-align:center;flex:1;font-size:15px;font-weight:700}.header-back{padding:6px 10px;font-size:12px}.header-editor-btn{padding:6px 12px;font-size:12px}.sandbox-body{flex:1;display:flex;position:relative;overflow:hidden}.board-area{background:#0a0a14;flex:1;justify-content:flex-start;align-items:flex-start;min-width:0;padding:12px;display:flex;position:relative;overflow:auto}.side-panel{background:var(--bg-panel);border-left:1px solid var(--border);flex-direction:column;flex-shrink:0;width:280px;display:flex;overflow:hidden}.map-editor{flex-direction:column;height:100%;display:flex;overflow:hidden}.editor-tabs{border-bottom:1px solid var(--border);flex-shrink:0;display:flex}.editor-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:10px 8px;font-size:12px;font-weight:600;transition:all .15s}.editor-tab:hover{color:var(--text);background:#ffffff0a}.editor-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.editor-scroll-content{flex-direction:column;flex:1;gap:14px;padding:12px;display:flex;overflow-y:auto}.editor-actions{border-top:1px solid var(--border);flex-shrink:0;gap:8px;padding:12px;display:flex}.editor-actions .btn{flex:1}.editor-warning{text-align:center;color:var(--warning);padding:0 12px 8px;font-size:11px}.palette-section-label{text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-bottom:6px;font-size:10px;font-weight:800}.unit-palette{flex-direction:column;gap:10px;display:flex}.palette-team-row{gap:8px;display:flex}.team-btn{border:1.5px solid var(--border);background:var(--bg-card);color:var(--text-muted);cursor:pointer;border-radius:8px;flex:1;padding:8px;font-size:12px;font-weight:700;transition:all .15s}.team-btn.team1.active{border-color:var(--team1);color:var(--team1);background:#4a90ff26}.team-btn.team2.active{border-color:var(--team2);color:var(--team2);background:#ff4a4a26}.team-btn:hover:not(.active){background:#ffffff0f}.palette-units{flex-direction:column;gap:6px;display:flex}.palette-unit-btn{border:1.5px solid var(--border);background:var(--bg-card);color:var(--text);cursor:pointer;text-align:left;border-radius:8px;align-items:center;gap:10px;width:100%;padding:8px 10px;transition:all .15s;display:flex}.palette-unit-btn:hover{background:#1e1e38}.palette-unit-btn.active.team1{border-color:var(--team1);background:#4a90ff1f}.palette-unit-btn.active.team2{border-color:var(--team2);background:#ff4a4a1f}.unit-btn-emoji{text-align:center;flex-shrink:0;width:28px;font-size:20px}.unit-btn-info{flex-direction:column;flex:1;min-width:0;display:flex}.unit-btn-name{font-size:13px;font-weight:700}.unit-btn-stats{color:var(--text-muted);font-size:10px}.unit-stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:12px}.unit-stat-header{align-items:center;gap:8px;margin-bottom:10px;font-size:14px;font-weight:700;display:flex}.unit-stat-grid{grid-template-columns:1fr 1fr;gap:6px;display:grid}.unit-stat-grid>div{background:var(--bg);border-radius:4px;flex-direction:column;padding:5px 8px;display:flex}.stat-key{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-size:9px}.terrain-palette{flex-direction:column;gap:10px;display:flex}.terrain-grid{grid-template-columns:repeat(3,1fr);gap:6px;display:grid}.terrain-tile{cursor:pointer;background:#0000004d;border:2px solid #ffffff1f;border-radius:8px;flex-direction:column;align-items:center;padding:4px;transition:all .15s;display:flex}.terrain-tile:hover{filter:brightness(1.2);border-color:#fff6}.terrain-tile.selected{box-shadow:0 0 10px #ffffff59;border-color:#fff!important}.terrain-name{color:#fff;text-shadow:0 1px 3px #000;margin-top:2px;font-size:9px;font-weight:700}.terrain-info-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:8px;padding:12px;display:flex}.terrain-info-header{align-items:center;gap:8px;font-size:14px;font-weight:700;display:flex}.terrain-info-desc{color:var(--text-muted);font-size:11px;line-height:1.5}.terrain-stats{gap:12px;display:flex}.terrain-stat{background:var(--bg);border-radius:4px;flex-direction:column;flex:1;align-items:center;padding:5px 10px;display:flex}.terrain-stat-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:2px;font-size:9px}.terrain-move-costs{flex-direction:column;gap:4px;display:flex}.terrain-move-grid{grid-template-columns:1fr 1fr;gap:4px;display:grid}.terrain-move-grid span{background:var(--bg);border-radius:4px;padding:3px 6px;font-size:11px}.erase-panel{text-align:center;color:var(--text-muted);padding:8px 0;font-size:13px;line-height:1.6}.erase-note{color:var(--text-muted);margin-top:8px;font-size:11px}.map-size-section{flex-direction:column;gap:6px;display:flex}.size-presets{flex-wrap:wrap;gap:6px;display:flex}.size-btn{border:1.5px solid var(--border);background:var(--bg-card);color:var(--text-muted);cursor:pointer;border-radius:6px;padding:6px 12px;font-size:12px;font-weight:700;transition:all .15s}.size-btn.active{border-color:var(--accent);color:var(--accent)}.size-btn:hover:not(.active){background:#ffffff0f}.unit-count-row{justify-content:center;gap:12px;display:flex}.unit-count{font-size:13px;font-weight:700}.team1-count{color:var(--team1)}.team2-count{color:var(--team2)}.action-panel{flex-direction:column;gap:10px;height:100%;padding:12px;display:flex;overflow-y:auto}.turn-header{border-left:3px solid;padding-left:10px}.turn-player{font-size:15px;font-weight:800}.turn-meta{color:var(--text-muted);margin-top:2px;font-size:11px}.unit-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:8px;padding:10px;display:flex}.unit-card-header{align-items:center;gap:8px;display:flex}.unit-card-emoji{font-size:22px}.unit-card-info{flex:1;min-width:0}.unit-card-name{font-size:13px;font-weight:700}.unit-card-terrain{color:var(--text-muted);margin-top:2px;font-size:11px}.unit-card-hp{flex-shrink:0;font-size:15px;font-weight:900}.hp-bar-track{background:#ffffff1a;border-radius:3px;height:5px;overflow:hidden}.hp-bar-fill{border-radius:3px;height:100%;transition:width .3s}.action-buttons{flex-direction:column;gap:6px;display:flex}.action-buttons .btn{width:100%}.action-hint{text-align:center;color:var(--text-muted);background:var(--bg-card);border:1px solid var(--border);border-radius:6px;padding:6px;font-size:12px}.idle-hint{font-style:italic}.battle-log{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;flex:1;min-height:0;padding:8px;overflow-y:auto}.battle-log-title{text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-bottom:6px;font-size:10px;font-weight:700}.battle-log-entry{color:var(--text-muted);border-bottom:1px solid #ffffff0d;padding:3px 0;font-size:11px;line-height:1.4}.battle-log-entry:last-child{border-bottom:none}.back-btn{align-self:flex-start;margin-top:auto}.win-banner{text-align:center;background:var(--bg-card);border:2px solid;border-radius:8px;padding:16px;font-size:22px;font-weight:900}.battle-forecast{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border);background:#0a0a19eb;border-radius:10px;min-width:260px;max-width:320px;padding:12px;box-shadow:0 4px 24px #00000080}.forecast-title{text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);text-align:center;margin-bottom:10px;font-size:11px;font-weight:800}.forecast-row{align-items:center;gap:8px;display:flex}.forecast-vs{color:var(--text-muted);flex-shrink:0;font-size:11px;font-weight:900}.forecast-unit{background:var(--bg-card);border-radius:6px;flex-direction:column;flex:1;align-items:center;gap:3px;padding:8px 6px;display:flex}.forecast-unit-label{text-transform:uppercase;letter-spacing:.5px;font-size:9px;font-weight:800}.forecast-unit-icon{font-size:22px}.forecast-unit-name{font-size:11px;font-weight:700}.forecast-terrain{color:var(--text-muted);font-size:10px}.forecast-hp{align-items:center;gap:4px;margin-top:2px;font-size:16px;font-weight:900;display:flex}.forecast-arrow{color:var(--text-muted);font-size:11px}.forecast-summary{flex-direction:column;gap:3px;margin-top:8px;display:flex}.forecast-note{text-align:center;font-size:11px}.board-cell{transition:filter .1s}.cell-move{cursor:pointer!important}.cell-attack{cursor:crosshair!important}@media (width<=700px){.sandbox-body{flex-direction:column}.side-panel{border-left:none;border-top:1px solid var(--border);width:100%;max-height:40vh;overflow-y:auto}.board-area{flex:1;min-height:0}.home-menu{gap:20px;padding:24px 16px}.home-nav{flex-direction:column;width:100%}.btn-hero{width:100%}.forecast-overlay{bottom:8px;left:8px;right:8px}.battle-forecast{min-width:0;max-width:100%}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#4a4a6a}.terrain-thumb{aspect-ratio:1;background-position:50%;background-size:cover;border-radius:4px;width:100%;margin-bottom:4px}.terrain-info-thumb{background-position:50%;background-size:cover;border-radius:6px;flex-shrink:0;width:36px;height:36px}.unit-btn-sprite{object-fit:contain;width:36px;height:36px;image-rendering:pixelated;flex-shrink:0;display:block}@keyframes unit-float{0%,to{transform:none}}@keyframes unit-hit-flash{0%{transform:scale(1.2);filter:brightness(20)saturate(0)!important}to{filter:inherit;transform:scale(1)}}.unit-sprite-wrapper.unit-idle{animation:2s ease-in-out infinite unit-float}.unit-sprite-wrapper.unit-acted{animation:none}.unit-sprite-wrapper.unit-hit .unit-sprite-img-container img{animation:.45s ease-out forwards unit-hit-flash}@keyframes move-shimmer{0%,to{opacity:.45}50%{opacity:.65}}@keyframes attack-pulse{0%,to{opacity:.42}50%{opacity:.65}}@keyframes active-glow{0%,to{opacity:.35}50%{opacity:.6}}.cell-overlay{pointer-events:none;z-index:1;position:absolute;inset:0}.cell-overlay-move{background:#4682ff80;animation:1.2s ease-in-out infinite move-shimmer}.cell-overlay-attack{background:#ff32328c;animation:.8s ease-in-out infinite attack-pulse}.cell-overlay-active{outline-offset:-2px;background:#ffdc2873;outline:2px solid #ffdc28cc;animation:1s ease-in-out infinite active-glow}@keyframes river-shimmer{0%{background-position:0 0}to{background-position:200% 200%}}.terrain-river:after{content:"";pointer-events:none;z-index:0;background:linear-gradient(135deg,#0000 40%,#ffffff26 50%,#0000 60%) 0 0/200% 200%;animation:2.5s linear infinite river-shimmer;position:absolute;inset:0}@keyframes swamp-pulse{0%,to{opacity:0}40%,60%{opacity:.35}}.terrain-swamp:after{content:"";pointer-events:none;z-index:0;background:radial-gradient(circle at 30% 60%,#50a05080 0%,#0000 50%),radial-gradient(circle at 70% 30%,#3c8c3c66 0%,#0000 40%);animation:3s ease-in-out infinite swamp-pulse;position:absolute;inset:0}@keyframes forest-sway{0%,to{transform:scaleX(1)}50%{transform:scaleX(1.01)}}.terrain-forest{animation:4s ease-in-out infinite forest-sway}.unit-sprite-wrapper{z-index:2}.global-topbar{background:var(--bg-panel);border-bottom:1px solid var(--border);flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:8px 16px;display:flex}.topbar-logo{color:var(--accent);font-size:15px;font-weight:800}.topbar-center{gap:4px;display:flex}.topbar-right{align-items:center;gap:4px;display:flex}.topbar-left{align-items:center;display:flex}.topbar-nav-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:6px 12px;font-size:12px;font-weight:600;transition:all .15s}.topbar-nav-btn:hover{color:var(--text);background:#ffffff0f}.topbar-nav-btn.active{color:var(--accent);background:#4a90ff1f}.topbar-general-btn{color:var(--text);font-size:12px}.auth-screen{background:radial-gradient(ellipse at top, #1a1a3a 0%, var(--bg) 60%);flex:1;justify-content:center;align-items:center;padding:20px;display:flex}.auth-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;flex-direction:column;gap:16px;width:100%;max-width:420px;padding:32px 28px;display:flex}.auth-logo{text-align:center}.auth-tabs{border-bottom:1px solid var(--border);display:flex}.auth-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:10px;font-size:14px;font-weight:700;transition:all .15s}.auth-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.auth-form{flex-direction:column;gap:12px;display:flex}.form-group{flex-direction:column;gap:5px;display:flex}.form-group label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:700}.form-group input,.form-group textarea,.form-select{background:var(--bg);border:1px solid var(--border);color:var(--text);box-sizing:border-box;border-radius:8px;outline:none;width:100%;padding:10px 12px;font-size:14px;transition:border-color .15s}.form-group input:focus,.form-group textarea:focus,.form-select:focus{border-color:var(--accent)}.form-input-sm{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:6px;padding:6px 10px}.form-textarea{resize:vertical;font-family:inherit}.form-select{appearance:none;cursor:pointer}.auth-error{color:#f88;background:#ff4a4a1f;border:1px solid #ff4a4a66;border-radius:8px;padding:10px;font-size:13px}.auth-footer{text-align:center;color:var(--text-muted);font-size:11px}.home-welcome{color:var(--text-muted);margin-top:8px;font-size:14px}.home-stats-row{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.stat-chip{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:6px 14px;font-size:13px;font-weight:600}.general-screen{flex:1;justify-content:center;align-items:flex-start;padding:20px;display:flex;overflow-y:auto}.general-creator{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;flex-direction:column;gap:14px;width:100%;max-width:640px;padding:24px;display:flex}.general-header{align-items:center;gap:16px;display:flex}.general-portrait-big{font-size:56px}.general-form{flex-direction:column;gap:12px;display:flex}.portrait-grid{grid-template-columns:repeat(8,1fr);gap:6px;display:grid}.portrait-btn{background:var(--bg);cursor:pointer;border:2px solid #0000;border-radius:8px;padding:4px;font-size:24px;transition:all .15s}.portrait-btn:hover{background:#1e1e38}.portrait-btn.selected{border-color:var(--accent);background:#4a90ff26}.loadout-rules{background:var(--bg);border-radius:8px;padding:10px 12px;font-size:13px}.current-loadout{flex-direction:column;gap:6px;display:flex}.loadout-slot{background:var(--bg);border:1.5px solid var(--border);border-radius:8px;align-items:center;gap:8px;min-height:44px;padding:8px 12px;display:flex}.loadout-slot.filled{border-color:var(--accent)}.loadout-slot.empty{opacity:.5}.slot-num{color:var(--text-muted);min-width:44px;font-size:10px;font-weight:800}.slot-info{flex-direction:column;flex:1;display:flex}.slot-name{font-size:12px;font-weight:700}.ability-rank-group{flex-direction:column;gap:6px;display:flex}.ability-rank-header{align-items:center;padding:2px 0;font-size:13px;display:flex}.ability-grid{flex-direction:column;gap:5px;display:flex}.ability-card{background:var(--bg);border:1.5px solid var(--border);cursor:pointer;text-align:left;border-radius:8px;align-items:flex-start;gap:10px;width:100%;padding:8px 12px;transition:all .15s;display:flex;position:relative}.ability-card:hover:not(.blocked){border-color:var(--accent);background:#4a90ff14}.ability-card.equipped{border-color:var(--success);background:#44cc6614}.ability-card.blocked{opacity:.35;cursor:not-allowed}.ability-icon{flex-shrink:0;font-size:20px}.ability-info{flex-direction:column;flex:1;display:flex}.ability-name{font-size:12px;font-weight:700}.ability-desc{color:var(--text-muted);margin-top:2px;font-size:11px}.equipped-check{color:var(--success);font-size:14px;font-weight:800;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.ability-hud-overlay{z-index:10;pointer-events:none;position:absolute;bottom:12px;right:12px}.ability-hud-overlay *{pointer-events:auto}.ability-hud{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border);background:#0a0a19eb;border-radius:10px;flex-direction:column;gap:8px;min-width:220px;max-width:260px;padding:10px 12px;display:flex}.hud-general-id{border-bottom:1px solid var(--border);align-items:center;gap:8px;padding-bottom:6px;display:flex}.hud-portrait{font-size:22px}.hud-general-text{flex-direction:column;display:flex}.hud-general-name{font-size:12px;font-weight:700}.hud-general-title{color:var(--text-muted);font-size:10px}.hud-slots{flex-direction:column;gap:6px;display:flex}.hud-slot{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;align-items:center;gap:6px;padding:6px 8px;display:flex}.hud-slot.ready{border-color:#fc0;box-shadow:0 0 8px #ffcc004d}.hud-slot.inactive{opacity:.5}.hud-slot-stars{min-width:32px;font-size:8px}.hud-slot-icon{flex-shrink:0;font-size:16px}.hud-slot-name{white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-size:10px;font-weight:700;overflow:hidden}.hud-meter-track{background:#ffffff1a;border-radius:3px;flex-shrink:0;width:48px;height:5px;overflow:hidden}.hud-meter-fill{border-radius:3px;height:100%;transition:width .4s}.hud-meter-label{color:var(--text-muted);text-align:right;white-space:nowrap;min-width:36px;font-size:8px}@keyframes hud-ready-pulse{0%,to{box-shadow:0 0 6px #ffcc004d}50%{box-shadow:0 0 14px #ffcc00b3}}.hud-slot.ready{animation:1.2s ease-in-out infinite hud-ready-pulse}.hud-activate-btn{padding:3px 8px;font-size:10px;font-weight:800}.btn-warning{color:#000;cursor:pointer;background:#fc0;border:none;border-radius:5px}.lobby-screen{flex-direction:column;flex:1;display:flex;overflow:hidden}.lobby-header{padding:16px 16px 0}.lobby-header h2{margin-bottom:10px}.lobby-tabs{border-bottom:1px solid var(--border);display:flex}.lobby-loading,.lobby-empty{text-align:center;color:var(--text-muted);padding:40px}.lobby-empty button{margin-top:12px}.match-list{flex-direction:column;flex:1;gap:8px;padding:12px;display:flex;overflow-y:auto}.match-card{background:var(--bg-card);border:1px solid var(--border);cursor:pointer;border-radius:10px;padding:12px 14px;transition:all .15s}.match-card:hover{border-color:var(--accent)}.match-card.my-turn{border-color:#fc4}.match-card-vs{justify-content:space-between;align-items:center;font-size:14px;font-weight:700;display:flex}.match-code{color:var(--text-muted);font-family:monospace;font-size:11px}.match-card-meta{color:var(--text-muted);flex-wrap:wrap;align-items:center;gap:10px;margin-top:6px;font-size:12px;display:flex}.match-status{font-size:11px}.your-turn-badge{color:#000;background:#fc4;border-radius:10px;padding:2px 6px;font-size:9px;font-weight:900}.deadline-label{color:#f84;font-size:11px}.lobby-form{max-width:400px;padding:20px}.lobby-form h3{margin-bottom:8px}.code-input{letter-spacing:3px;text-transform:uppercase;text-align:center;font-family:monospace;font-size:18px}.campaign-screen{flex-direction:column;flex:1;display:flex;overflow:hidden}.resource-bar{gap:8px;display:flex}.resource-chip{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:4px 10px;font-size:12px;font-weight:700}.campaign-tabs{border-bottom:1px solid var(--border);flex-shrink:0;display:flex;overflow-x:auto}.campaign-content{flex:1;padding:16px;overflow-y:auto}.flash-msg{color:#4d6;text-align:center;background:#44cc6626;border:1px solid #4c6;border-radius:6px;margin:4px 16px;padding:8px 16px;font-size:13px}.base-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;display:grid}.building-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;align-items:center;gap:12px;padding:14px;display:flex}.building-emoji{flex-shrink:0;font-size:32px}.building-info{flex:1}.building-name{font-size:14px;font-weight:700}.building-desc{color:var(--text-muted);margin:2px 0;font-size:11px}.building-level{color:#fc4;font-size:11px}.building-upgrade-btn{padding:5px 10px;font-size:11px}.building-max{color:var(--success);font-size:11px;font-weight:800}.roster-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;display:grid}.roster-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;align-items:center;gap:10px;padding:12px;display:flex}.roster-info{flex:1}.roster-name{font-size:13px;font-weight:700}.roster-level{color:var(--text-muted);font-size:11px}.roster-bonuses{margin-top:2px;font-size:11px}.research-section{flex-direction:column;gap:20px;display:flex}.res-cat-title{text-transform:uppercase;letter-spacing:1px;color:var(--accent);margin-bottom:8px;font-size:13px;font-weight:800}.research-nodes{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:8px;display:grid}.research-node{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:5px;padding:10px 12px;display:flex}.research-node.done{background:#44cc660f;border-color:#4c6}.research-node.in-progress{border-color:#fc4}.research-node.locked{opacity:.45}.res-node-header{align-items:center;gap:6px;display:flex}.res-tier{background:var(--bg);color:var(--text-muted);border-radius:4px;padding:2px 5px;font-size:9px;font-weight:800}.res-name{flex:1;font-size:12px;font-weight:700}.res-desc{color:var(--text-muted);font-size:11px;line-height:1.4}.res-costs{color:var(--text-muted);gap:8px;font-size:11px;display:flex}.res-progress-label{color:#fc4;font-size:10px}.crafting-section{flex-direction:column;gap:16px;display:flex}.active-jobs{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:12px}.active-jobs h3{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:8px;font-size:12px;font-weight:800}.craft-job{border-bottom:1px solid var(--border);justify-content:space-between;padding:4px 0;font-size:12px;display:flex}.recipe-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;display:grid}.recipe-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:5px;padding:12px;display:flex}.recipe-name{font-size:13px;font-weight:700}.recipe-desc{color:var(--text-muted);font-size:11px;line-height:1.4}.recipe-costs{color:var(--text-muted);gap:8px;font-size:11px;display:flex}.recipe-meta{color:var(--text-muted);font-size:10px}.mission-list{flex-direction:column;gap:8px;display:flex}.mission-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:12px}.mission-card.completed{border-color:#4c6}.mission-header{align-items:center;gap:8px;margin-bottom:4px;display:flex}.mission-name{flex:1;font-size:14px;font-weight:700}.mission-diff{text-transform:uppercase;font-size:11px;font-weight:700}.mission-stars{font-size:12px}.mission-desc{color:var(--text-muted);margin-bottom:6px;font-size:12px}.mission-rewards{color:var(--text-muted);gap:8px;font-size:12px;display:flex}.notif-panel{background:var(--bg-card);border:1px solid var(--border);z-index:100;border-radius:10px;width:300px;max-height:400px;position:absolute;top:100%;right:0;overflow:hidden auto;box-shadow:0 8px 24px #0006}.notif-header{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);border-bottom:1px solid var(--border);padding:10px 14px;font-size:12px;font-weight:800}.notif-empty{text-align:center;color:var(--text-muted);padding:20px;font-size:13px}.notif-item{border-bottom:1px solid var(--border);cursor:pointer;padding:10px 14px}.notif-item.unread{background:#4a90ff0f}.notif-title{font-size:13px;font-weight:700}.notif-body{color:var(--text-muted);margin-top:2px;font-size:12px}.notif-time{color:var(--text-muted);margin-top:4px;font-size:10px}.btn-capture{color:#fff;background:linear-gradient(135deg,#1a6a1a,#2a9a2a);border-color:#2a9a2a}.btn-capture:hover{background:linear-gradient(135deg,#1d8a1d,#3b3)}.factory-produce-hint{color:#ffdc32cc;pointer-events:none;z-index:3;text-shadow:0 0 8px #000c;justify-content:center;align-items:center;font-size:20px;font-weight:900;display:flex;position:absolute;inset:0}.build-menu{flex-direction:column;gap:8px;display:flex}.build-menu-header{justify-content:space-between;align-items:center;font-size:13px;font-weight:700;display:flex}.gold-display{color:#fc4;font-weight:800}.build-unit-list{flex-direction:column;gap:6px;display:flex}.build-unit-row{background:var(--bg-card);border:1.5px solid var(--border);cursor:pointer;text-align:left;border-radius:8px;align-items:center;gap:10px;width:100%;padding:8px 10px;transition:all .15s;display:flex}.build-unit-row:hover:not(.unaffordable){border-color:var(--accent);background:#1e1e38}.build-unit-row.unaffordable{opacity:.35;cursor:not-allowed}.build-unit-info{flex-direction:column;flex:1;display:flex}.build-unit-name{font-size:12px;font-weight:700}.build-unit-stats{color:var(--text-muted);font-size:10px}.build-unit-cost{white-space:nowrap;font-size:12px;font-weight:800}.can-afford{color:#fc4}.cant-afford{color:#888}.gold-row{color:#fc4;gap:10px;margin-top:2px;font-size:12px;display:flex}.creator-meta{flex-direction:column;gap:8px;display:flex}.victory-section{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:8px;padding:10px 12px;display:flex}.victory-toggle{cursor:pointer;align-items:center;gap:8px;font-size:13px;display:flex}.victory-toggle input[type=checkbox]{cursor:pointer;width:16px;height:16px}.export-modal-bg{z-index:1000;background:#000000b3;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.export-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;flex-direction:column;width:100%;max-width:720px;max-height:90vh;display:flex;overflow:hidden}.export-modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 16px;font-size:15px;display:flex}.export-format-tabs{border-bottom:1px solid var(--border);display:flex}.export-textarea{color:#afa;resize:none;background:#0a0a14;border:none;outline:none;flex:1;min-height:300px;padding:12px 16px;font-family:monospace;font-size:12px;line-height:1.5}@keyframes stealth-pulse{0%,to{opacity:1}50%{opacity:.65}}.unit-stealth{animation:2.5s ease-in-out infinite stealth-pulse}@keyframes laser-beam{0%{opacity:0;transform:scaleY(0)}30%{opacity:.9;transform:scaleY(1)}to{opacity:0;transform:scaleY(0)}}.laser-tower-beam{pointer-events:none;z-index:3;background:linear-gradient(#0000,#64b4ffe6);width:3px;height:24px;animation:1.8s ease-in-out infinite laser-beam;position:absolute;top:0;left:50%;transform:translate(-50%)}.tag-deployed,.tag-deploying,.tag-stealth,.tag-mds{vertical-align:middle;border-radius:4px;margin-left:5px;padding:1px 5px;font-size:9px;font-weight:800}.tag-deployed{color:#64b4ff;background:#64b4ff33;border:1px solid #64b4ff44}.tag-deploying{color:#fc0;background:#fc03;border:1px solid #fc04}.tag-stealth{color:#8e8;background:#64ff6426;border:1px solid #8e84}.tag-mds{color:#4a90ff;background:#4a90ff26;border:1px solid #4a90ff44}.unit-card-sprite{object-fit:contain;width:40px;height:40px;image-rendering:pixelated;filter:sepia(.6)saturate(3)hue-rotate(155deg)brightness(1.1);flex-shrink:0}.btn-deploy{color:#64b4ff;background:linear-gradient(135deg,#1a3a6a,#1a5a9a);border-color:#4a90ff;font-weight:700}.btn-deploy:hover{background:linear-gradient(135deg,#1e4a82,#1e72c2)}.deploying-notice{background:#ffcc0014;border:1px solid #ffcc0040;border-radius:8px;flex-direction:column;gap:5px;padding:8px 10px;display:flex}.deploy-progress-row{color:#fc4;justify-content:space-between;align-items:center;font-size:12px;display:flex}.deploy-pip-row{gap:4px;display:flex}.deploy-pip{background:#ffffff26;border:1px solid #ffcc004d;border-radius:3px;width:12px;height:12px}.deploy-pip.filled{background:#fc0;border-color:#fc0}.settings-overlay{z-index:50;width:320px;position:absolute;top:0;bottom:0;right:280px;box-shadow:-4px 0 24px #00000080}.settings-drawer{background:var(--bg-panel);border-left:1px solid var(--border);flex-direction:column;height:100%;display:flex;overflow:hidden}.settings-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 14px;font-size:14px;font-weight:700;display:flex}.settings-scroll{flex-direction:column;flex:1;gap:14px;padding:12px;display:flex;overflow-y:auto}.settings-section{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:10px;padding:10px 12px;display:flex}.settings-section-title{text-transform:uppercase;letter-spacing:.7px;color:var(--accent);font-size:11px;font-weight:800}.settings-row{flex-direction:column;gap:5px;display:flex}.settings-row label{color:var(--text);font-size:12px;font-weight:600}.slider-group{align-items:center;gap:8px;display:flex}.slider-group input[type=range]{cursor:pointer;accent-color:var(--accent);flex:1}.slider-val{text-align:right;min-width:42px;color:var(--accent);font-size:12px;font-weight:800}.setting-note{color:var(--text-muted);margin:0;font-size:10px;line-height:1.5}.unit-mult-row{align-items:center;flex-direction:row!important;gap:8px!important}.unit-mult-label{align-items:center;gap:6px;min-width:90px;font-size:12px;display:flex}.battle-log-entry.log-mds{color:#64b4ff}.battle-log-entry.log-laser{color:#8af}.header-settings-btn{padding:6px 10px;font-size:14px}.header-settings-btn.active{border-color:var(--accent);background:#4a90ff1f}@media (width<=700px){.settings-overlay{width:100%;right:0}}.terrain-trench:after{content:"";pointer-events:none;border:2px dashed #64462899;border-radius:2px;position:absolute;inset:4px}@keyframes forest-clear-pulse{0%,to{opacity:.5}50%{opacity:.75}}.cell-overlay-forest{background:#ff640080;animation:.8s ease-in-out infinite forest-clear-pulse}.excavator-toolbar{background:#503c142e;border:1px solid #c88c3c4d;border-radius:8px;flex-direction:column;gap:6px;padding:10px;display:flex}.exc-tool-row{grid-template-columns:repeat(4,1fr);gap:6px;display:grid}.exc-tool-btn{border:1.5px solid var(--border);background:var(--bg-card);color:var(--text-muted);cursor:pointer;border-radius:6px;flex-direction:column;align-items:center;gap:2px;padding:6px 2px;font-size:11px;font-weight:700;transition:all .15s;display:flex}.exc-tool-btn:hover:not(.disabled){color:#c88a3c;background:#c88c3c1a;border-color:#c88a3c}.exc-tool-btn.active{color:#c88a3c;background:#c88c3c2e;border-color:#c88a3c}.exc-tool-btn.disabled{opacity:.35;cursor:not-allowed}.btn-merge{color:#afa;background:linear-gradient(135deg,#1a5a1a,#2a8a2a);border-color:#4a4;font-weight:700}.btn-merge:hover{background:linear-gradient(135deg,#1d7a1d,#3b3)}.battle-log-entry.log-dig{color:#c88a3c}*{-webkit-tap-highlight-color:transparent}html,body{overscroll-behavior:none;overflow:hidden}#root{height:100dvh}.app,.sandbox-mode{padding-bottom:env(safe-area-inset-bottom)}.btn{min-width:44px;min-height:44px}.editor-tab,.team-btn{min-height:44px}.palette-unit-btn{min-height:52px}.exc-tool-btn{min-height:44px}.portrait-btn{min-width:48px;min-height:48px;font-size:28px}.terrain-tile{min-height:64px}input[type=range]{min-height:36px}.header-controls{align-items:center;gap:4px;display:flex}.zoom-btn{border:1px solid var(--border);background:var(--bg-card);width:34px;height:34px;color:var(--text);cursor:pointer;border-radius:6px;justify-content:center;align-items:center;font-size:18px;font-weight:700;line-height:1;transition:all .15s;display:flex}.zoom-btn:hover:not(:disabled){background:#ffffff14}.zoom-btn:disabled{opacity:.3;cursor:default}.zoom-label{color:var(--text-muted);text-align:center;min-width:36px;font-size:11px}.board-area{-webkit-overflow-scrolling:touch;overscroll-behavior:contain;scroll-snap-type:none;overflow:auto}.board-scroll-container{touch-action:pan-x pan-y}.board-cell{touch-action:none}.desktop-only{display:flex}.mobile-only{display:none}@media (width<=700px){.desktop-only{display:none!important}.mobile-only{flex-direction:column;display:flex!important}}.mobile-panel-wrapper{z-index:80;pointer-events:none;position:fixed;bottom:0;left:0;right:0}.mobile-panel-wrapper>*{pointer-events:auto}.mobile-mini-hud{background:var(--bg-panel);border-top:3px solid var(--border);cursor:pointer;-webkit-user-select:none;user-select:none}.mini-hud-inner{border-top:3px solid #0000;align-items:center;gap:10px;padding:10px 16px;font-size:13px;transition:border-color .2s;display:flex}.mobile-sheet{background:var(--bg-panel);border-top:1px solid var(--border);border-radius:16px 16px 0 0;flex-direction:column;max-height:70vh;transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;position:absolute;bottom:0;left:0;right:0;overflow:hidden;transform:translateY(100%)}.mobile-sheet.open{transform:translateY(0)}.sheet-handle-row{cursor:pointer;-webkit-user-select:none;user-select:none;flex-shrink:0;justify-content:center;align-items:center;gap:8px;padding:10px 16px 6px;display:flex}.sheet-handle{background:var(--border);border-radius:2px;width:40px;height:4px}.sheet-handle-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:700}.sheet-content{-webkit-overflow-scrolling:touch;flex:1;overflow-y:auto}@media (width<=700px){.sandbox-body{padding-bottom:56px}.board-area{flex:1;min-height:0}.sandbox-header{padding:6px 10px}.sandbox-title{font-size:13px}.header-back{padding:6px 8px;font-size:11px}.header-editor-btn,.header-settings-btn{min-width:36px;min-height:36px;padding:6px 8px;font-size:13px}.action-buttons .btn{min-height:48px;font-size:14px}.end-turn-btn{min-height:52px;font-size:15px;font-weight:800}.forecast-overlay{bottom:68px;left:8px;right:8px}.battle-forecast{max-width:100%}.ability-hud-overlay{inset:48px 6px auto auto}.ability-hud{max-width:180px}.hud-slot-name{display:none}.home-menu{gap:14px;padding:16px 12px}.home-nav{flex-direction:column;width:100%}.btn-hero{width:100%;padding:14px 16px}.global-topbar{flex-wrap:wrap;padding:6px 10px}.topbar-center{flex-wrap:wrap;gap:2px}.topbar-nav-btn{padding:4px 8px;font-size:11px}.lobby-form{padding:12px}.campaign-tabs .editor-tab{padding:8px 6px;font-size:11px}.base-grid{grid-template-columns:1fr}.roster-grid{grid-template-columns:1fr 1fr}.research-nodes{grid-template-columns:1fr}.recipe-grid{grid-template-columns:1fr 1fr}.settings-overlay{z-index:200;width:100%;position:fixed;top:0;bottom:0;right:0}.export-modal-bg{align-items:flex-end;padding:0}.export-modal{border-radius:16px 16px 0 0;max-height:95vh}}@media (width<=900px) and (orientation:landscape){.sandbox-body{flex-direction:row;padding-bottom:0}.mobile-panel-wrapper{flex-shrink:0;width:260px;height:100%;position:relative;bottom:auto;left:auto;right:auto;overflow-y:auto}.mobile-sheet{border-top:none;border-left:1px solid var(--border);border-radius:0;max-height:100%;position:relative;transform:none!important}.mobile-mini-hud,.sheet-handle-row{display:none}.board-area{flex:1;padding-bottom:0}.sandbox-body{padding-bottom:0!important}}.guest-block{flex-direction:column;align-items:center;gap:8px;padding:16px 0 4px;display:flex}.guest-btn{border-radius:10px;width:100%;padding:14px;font-size:16px}.guest-note{color:var(--text-muted);text-align:center;max-width:300px;font-size:11px;line-height:1.5}.auth-divider{color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;align-items:center;gap:10px;font-size:11px;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border);flex:1;height:1px}.game-board{gap:0!important}.board-cell{outline:none}@keyframes unit-idle-ground{0%{transform:rotate(-.8deg)scale(1)}25%{transform:rotate(.4deg)scale(1.01)}50%{transform:rotate(.8deg)scale(1)}75%{transform:rotate(-.4deg)scale(1.01)}to{transform:rotate(-.8deg)scale(1)}}.unit-idle-ground{animation:3s ease-in-out infinite unit-idle-ground}.unit-acted{opacity:.5;animation:none!important}.unit-hit .unit-sprite-wrapper{animation:.4s ease-out forwards unit-hit-flash}.game-board img[src*="/sprites/units/"]{mix-blend-mode:multiply}.game-overlay-anchor{pointer-events:none;z-index:50;flex-direction:column;justify-content:flex-end;align-items:center;gap:8px;padding:12px;display:flex;position:absolute;inset:0}.game-overlay-anchor>*{pointer-events:auto}.overlay-pill-bar{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0a0a19e0;border:1px solid #ffffff1f;border-radius:50px;flex-wrap:wrap;justify-content:center;align-items:center;gap:8px;width:auto;max-width:420px;padding:8px 12px;display:flex;box-shadow:0 4px 20px #00000080}.overlay-pill-btn{cursor:pointer;white-space:nowrap;border:1.5px solid #0000;border-radius:40px;justify-content:center;align-items:center;min-width:80px;height:44px;padding:0 20px;font-size:14px;font-weight:800;transition:all .15s;display:flex}.overlay-pill-btn:active{transform:scale(.94)}.confirm-btn{color:#fff;background:#48f;border-color:#69f}.cancel-btn{color:#aaa;background:#ffffff1a;border-color:#fff3}.attack-btn{color:#fff;background:#d33;border-color:#f55}.wait-btn{color:#ccc;background:#ffffff14;border-color:#ffffff26}.capture-btn{color:#fff;background:#3a4;border-color:#5c6}.deploy-btn{color:#64b4ff;background:#1a5aaa;border-color:#48c}.merge-btn{color:#afa;background:#272;border-color:#4a4}.end-turn-ready{color:#fff;background:#48f;border-color:#69f;height:52px;padding:0 28px;font-size:15px;animation:1.4s ease-in-out infinite pulse-border}.end-turn-idle{color:#888;background:#ffffff14;border-color:#ffffff1f;height:36px;padding:0 14px;font-size:12px}.overlay-hint{color:#ffffffb3;padding:0 8px;font-size:12px}.overlay-turn-info{align-items:center;gap:10px;padding:6px 8px;font-size:13px;display:flex}.overlay-win{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:100;background:#000000bf;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.overlay-win-inner{background:var(--bg-card);border:1px solid var(--border);text-align:center;border-radius:20px;flex-direction:column;gap:12px;padding:40px 48px;display:flex}.overlay-win-trophy{font-size:64px}.overlay-win-title{font-size:28px;font-weight:900}.overlay-win-reason{color:var(--text-muted);font-size:14px}.overlay-tray{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border);background:#0a0a19f0;border-radius:16px;min-width:260px;max-width:340px;padding:12px;position:absolute;bottom:12px;left:50%;transform:translate(-50%);box-shadow:0 8px 32px #0009}.forecast-overlay{z-index:55;pointer-events:none;position:absolute;bottom:80px;left:12px}.board-cell:hover{filter:brightness(1.08)}@keyframes move-pulse{0%,to{opacity:.38}50%{opacity:.58}}.cell-overlay-move{animation:1.2s ease-in-out infinite move-pulse}.cell-overlay-attack{animation:.9s ease-in-out infinite attack-pulse}@media (width<=700px){.overlay-pill-bar{gap:6px;padding:6px 10px}.overlay-pill-btn{height:48px;padding:0 16px;font-size:13px}.end-turn-ready{height:52px;font-size:14px}.game-overlay-anchor{padding:8px}}
