*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f172a;--surface: #1e293b;--surface2: #273449;--border: #334155;--text: #f1f5f9;--text-muted: #94a3b8;--accent: #3b82f6;--correct: #22c55e;--wrong: #ef4444;--revealed: #f59e0b;--radius: 8px;--map-bg: #dce8f0}html,body,#root{height:100%}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow:hidden}.app{display:flex;flex-direction:column;height:100vh}.header{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1.25rem;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;gap:1rem}.header-left{display:flex;align-items:center;gap:.5rem;min-width:160px}.header-icon{font-size:1.1rem}h1{font-size:1.05rem;font-weight:700;letter-spacing:-.02em}.header-center{font-size:.9rem;color:var(--text-muted)}.header-center strong{color:var(--text)}.header-right{min-width:160px;text-align:right}.header-score{font-size:1rem;font-weight:700;color:var(--accent)}.score-max{font-size:.8rem;font-weight:400;color:var(--text-muted)}.game-body{flex:1;display:flex;min-height:0;position:relative}.map-section{flex:1;display:flex;flex-direction:column;min-width:0}.overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;background:var(--bg);padding:2rem;text-align:center}.overlay-msg{font-size:1.1rem;font-weight:700}.overlay-sub{font-size:.875rem;color:var(--text-muted);max-width:32ch}.gameover-score{font-size:2.5rem;font-weight:800;color:var(--accent);letter-spacing:-.03em}.spinner{width:38px;height:38px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .75s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.map-wrap{flex:1;min-height:0;position:relative}.map-wrap :global(.leaflet-container),.map-wrap .leaflet-container{background:var(--map-bg)!important}.map-wrap.correct{box-shadow:inset 0 0 0 3px var(--correct)}.map-wrap.revealed{box-shadow:inset 0 0 0 3px var(--revealed)}.map-wrap.shake{animation:shake .4s ease}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-7px)}40%{transform:translate(7px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.controls{background:var(--surface);border-top:1px solid var(--border);padding:.75rem 1.25rem;display:flex;flex-direction:column;gap:.5rem;flex-shrink:0}.attempt-pips{display:flex;align-items:center;gap:.5rem}.pip{display:inline-block;width:10px;height:10px;border-radius:50%;flex-shrink:0}.pip-ok{background:var(--correct)}.pip-warn{background:var(--revealed)}.pip-danger{background:var(--wrong)}.pip-empty{background:var(--border)}.attempt-label{font-size:.78rem;color:var(--text-muted);margin-left:.25rem}.guess-form{display:flex;gap:.5rem}.guess-input{flex:1;background:var(--bg);border:1px solid var(--border);color:var(--text);padding:.5rem .75rem;border-radius:var(--radius);font-size:.95rem;outline:none;transition:border-color .15s;min-width:0}.guess-input:focus{border-color:var(--accent)}.guess-input::placeholder{color:var(--text-muted)}.btn{border:none;border-radius:var(--radius);font-size:.9rem;font-weight:600;cursor:pointer;padding:.5rem 1.1rem;transition:opacity .15s;white-space:nowrap}.btn:disabled{opacity:.35;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:not(:disabled):hover{opacity:.85}.btn-ghost{background:transparent;color:var(--text-muted);border:1px solid var(--border);font-weight:400;font-size:.83rem;padding:.375rem .875rem;align-self:flex-start}.btn-ghost:hover{color:var(--text);border-color:var(--text-muted)}.result-card{display:flex;flex-direction:column;gap:.4rem}.result-header{display:flex;flex-direction:column;gap:.15rem}.result-label{font-size:.75rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase}.result-label.correct{color:var(--correct)}.result-label.revealed{color:var(--revealed)}.result-name{font-size:1.25rem;font-weight:700;letter-spacing:-.02em;line-height:1.2}.result-meta{display:flex;flex-wrap:wrap;gap:.4rem}.meta-chip{background:var(--surface2);border:1px solid var(--border);border-radius:4px;padding:.2rem .5rem;font-size:.78rem;color:var(--text-muted)}.scoreboard{width:230px;flex-shrink:0;background:var(--surface);border-left:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.scoreboard-title{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);padding:.6rem .875rem .4rem;border-bottom:1px solid var(--border);flex-shrink:0}.scoreboard-rows{flex:1;overflow-y:auto}.sb-row{display:grid;grid-template-columns:18px 1fr auto auto;align-items:center;gap:.4rem;padding:.4rem .875rem;border-bottom:1px solid var(--border);font-size:.8rem;transition:background .1s}.sb-row.sb-current{background:var(--surface2)}.sb-row.sb-solved .sb-name{color:var(--text)}.sb-row.sb-missed .sb-name{color:var(--text-muted)}.sb-row.sb-pending .sb-name{color:var(--border)}.sb-num{color:var(--text-muted);font-size:.72rem;text-align:right}.sb-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.sb-dots{font-size:.65rem;letter-spacing:-1px;flex-shrink:0}.dot-gold{color:#f59e0b}.dot-silver{color:#94a3b8}.dot-bronze{color:#b45309}.dot-miss{color:var(--wrong)}.sb-pts{font-size:.72rem;font-weight:700;color:var(--accent);white-space:nowrap;flex-shrink:0}.scoreboard-total{display:flex;justify-content:space-between;align-items:center;padding:.6rem .875rem;border-top:1px solid var(--border);font-size:.8rem;font-weight:600;color:var(--text-muted);flex-shrink:0}.total-score{font-size:1rem;font-weight:800;color:var(--accent)}.total-max{font-size:.75rem;font-weight:400;color:var(--text-muted)}
