*{box-sizing:border-box}html,body,#root{height:100%;margin:0;overscroll-behavior:none}body{font-family:Segoe UI,Roboto,system-ui,sans-serif;background:#24261f;color:#eee7d3;-webkit-tap-highlight-color:transparent;touch-action:none}button{font-family:inherit;cursor:pointer}.app-root{height:100dvh;width:100vw;overflow:hidden;display:flex;flex-direction:column}.screen{flex:1;display:flex;flex-direction:column;align-items:center;padding:max(16px,env(safe-area-inset-top)) 16px max(16px,env(safe-area-inset-bottom));overflow-y:auto;gap:14px}.screen-title{font-size:1.4rem;margin:4px 0;color:#e7d9a8}.menu-screen{position:relative;justify-content:center;text-align:center;gap:18px}.mute-toggle{position:absolute;top:max(12px,env(safe-area-inset-top));right:16px;width:44px;height:44px;border-radius:50%;border:2px solid rgba(238,231,211,.4);background:#eee7d31f;font-size:1.3rem;display:flex;align-items:center;justify-content:center}.menu-badge{font-size:3rem}.menu-title{font-size:1.8rem;margin:0;color:#e7d9a8;text-shadow:2px 2px 0 #000}.menu-subtitle{max-width:320px;opacity:.85;line-height:1.4}.menu-actions{display:flex;flex-direction:column;gap:10px;width:100%;max-width:280px}.menu-hint{font-size:.8rem;opacity:.6;max-width:260px}.btn{border:none;border-radius:10px;padding:14px 20px;font-size:1rem;font-weight:600;min-height:48px}.btn-primary{background:#c94a3a;color:#fff}.btn-secondary{background:#3a3f33;color:#eee7d3}.screen-actions{display:flex;gap:10px;width:100%;max-width:400px;margin-top:auto}.screen-actions .btn{flex:1}.card-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;width:100%;max-width:480px}.card{background:#33362b;border:2px solid transparent;border-radius:12px;padding:12px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px;color:#eee7d3;min-height:120px}.card-selected{border-color:#e7d9a8;background:#454833}.card-icon{font-size:1.8rem}.card-name{font-size:.85rem;font-weight:700}.card-tagline{font-size:.72rem;opacity:.75;line-height:1.3}.difficulty-pill{font-size:.68rem;padding:2px 8px;border-radius:999px;background:#4a7a3a}.difficulty-rostov{background:#8a7a2a}.difficulty-donbass{background:#a3521f}.difficulty-krym{background:#8a2a2a}.game-screen{position:relative;flex:1;width:100%;height:100%;touch-action:none;overflow:hidden}.game-canvas{display:block;width:100%;height:100%}.hud{position:absolute;top:max(10px,env(safe-area-inset-top));left:0;right:0;display:flex;justify-content:center;gap:24px;pointer-events:none}.hud-item{background:#00000073;padding:6px 14px;border-radius:10px;display:flex;flex-direction:column;align-items:center;min-width:90px}.hud-label{font-size:.62rem;opacity:.7;text-transform:uppercase}.hud-value{font-size:1.1rem;font-weight:700;color:#f0e6c0}.touch-btn{position:absolute;bottom:max(20px,env(safe-area-inset-bottom));width:76px;height:76px;border-radius:50%;background:#eee7d32e;border:2px solid rgba(238,231,211,.5);color:#eee7d3;font-size:1.6rem;display:flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none}.touch-btn-up{right:20px;bottom:110px}.touch-btn-down{right:20px;bottom:20px}.gameover-screen{text-align:center}.death-cause{opacity:.85;font-size:.9rem;max-width:320px}.score-block{display:flex;flex-direction:column;align-items:center}.score-value{font-size:2.6rem;font-weight:800;color:#e7d9a8}.score-label{font-size:.8rem;opacity:.7;text-transform:uppercase}.new-record-badge{margin-top:6px;background:#c94a3a;padding:4px 12px;border-radius:999px;font-size:.8rem;font-weight:700}.caricature{display:flex;flex-direction:column;align-items:center;gap:8px;max-width:320px}.caricature-svg{width:130px;height:130px}.speech-bubble{background:#eee7d3;color:#24261f;border-radius:10px;padding:10px 14px;font-size:.82rem;line-height:1.35}.speech-persona{font-weight:700;font-size:.72rem;opacity:.7;margin-bottom:2px}.leaderboard-title{margin:4px 0 0;font-size:1rem;color:#e7d9a8}.leaderboard{width:100%;max-width:420px;border-collapse:collapse;font-size:.78rem}.leaderboard th,.leaderboard td{padding:6px 8px;text-align:left;border-bottom:1px solid rgba(238,231,211,.15)}.leaderboard-highlight{background:#c94a3a59}.leaderboard-empty{opacity:.7;font-size:.85rem}@media (min-width: 700px){.card-grid{grid-template-columns:repeat(3,1fr)}}@media (orientation: landscape) and (max-height: 480px){.menu-title{font-size:1.4rem}.screen{gap:8px;padding-top:8px}.card-grid{grid-template-columns:repeat(4,1fr)}}
