:root{--bg: #0d1117;--surface: #161b22;--border: #30363d;--accent: #7c6af5;--accent-glow: rgba(124, 106, 245, .3);--success: #3fb950;--danger: #f85149;--warn: #e3b341;--text: #e6edf3;--muted: #8b949e;--radius: 10px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);height:100dvh;overflow:hidden;display:flex;align-items:stretch}.view{display:none;width:100%;height:100%}.view.active{display:flex}#view-setup{justify-content:center;align-items:flex-start;padding:24px 16px;overflow-y:auto}@supports (min-height: fit-content){#view-setup{align-items:center}@media(max-height:700px){#view-setup{align-items:flex-start}}}.setup-container{width:100%;max-width:520px;display:flex;flex-direction:column;gap:24px}.logo{font-size:2.4rem;font-weight:800;letter-spacing:-1px;text-align:center;background:linear-gradient(135deg,#7c6af5,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.tagline{text-align:center;color:var(--muted);font-size:.95rem;margin-top:-16px}.filters-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;display:flex;flex-direction:column;gap:18px}.filters-card h2{font-size:.8rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}.filter-group{display:flex;flex-direction:column;gap:6px}.filter-group label{font-size:.875rem;font-weight:500;color:var(--muted)}.filter-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}select,input[type=text]{background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text);padding:8px 12px;font-size:.9rem;outline:none;width:100%;transition:border-color .15s}select:focus,input[type=text]:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.range-group{display:flex;align-items:center;gap:12px}input[type=range]{flex:1;accent-color:var(--accent);height:4px;cursor:pointer}.range-group span{font-size:.875rem;color:var(--text);min-width:50px;text-align:right}.city-count{text-align:center;font-size:.875rem;color:var(--muted);padding:4px 0}#city-count-num{font-weight:700;color:var(--accent);font-size:1.1rem}.btn-primary,.btn-secondary{padding:10px 20px;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;border:none;transition:all .15s}.btn-primary{background:var(--accent);color:#fff;width:100%;padding:12px;font-size:1rem;letter-spacing:.02em}.btn-primary:hover:not(:disabled){background:#6a58e0;box-shadow:0 0 0 3px var(--accent-glow)}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--border)}#view-game{flex-direction:column;overflow:hidden}.game-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:var(--surface);border-bottom:1px solid var(--border);gap:16px;flex-shrink:0}.game-info{display:flex;align-items:center;gap:20px}.round-label{font-size:.9rem;color:var(--muted);white-space:nowrap}.score-display{font-size:1rem;font-weight:700;color:var(--accent);white-space:nowrap}.timer-container{display:flex;align-items:center;gap:10px;flex:1;max-width:300px}.timer-bar{flex:1;height:6px;background:var(--border);border-radius:3px;overflow:hidden}.timer-fill{height:100%;border-radius:3px;background:var(--success);transition:width .9s linear,background-color .3s}.timer-fill.warn{background:var(--warn)}.timer-fill.danger{background:var(--danger)}.timer-label{font-size:.9rem;font-weight:700;min-width:24px;text-align:right;color:var(--text)}.game-image-container{position:relative;flex:1;overflow:hidden;background:#000;min-height:0}.game-image{width:100%;height:100%;object-fit:contain;object-position:center center;display:block}.game-image.loading{opacity:0}.zoom-controls{position:absolute;bottom:14px;right:14px;display:flex;flex-direction:column;gap:5px;z-index:5}.zoom-btn{width:36px;height:36px;border-radius:7px;background:#0d1117d1;border:1px solid rgba(255,255,255,.14);color:var(--text);font-size:1.25rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);transition:background .15s,opacity .15s;-webkit-user-select:none;user-select:none}.zoom-btn:hover:not(:disabled){background:#283246eb}.zoom-btn:disabled{opacity:.35;cursor:not-allowed}.result-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease}.result-overlay.hidden{display:none}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.result-correct{font-size:1.4rem;font-weight:700;color:var(--success);margin-bottom:6px}.result-wrong{font-size:1.4rem;font-weight:700;color:var(--danger);margin-bottom:6px}.result-points{font-size:1.8rem;font-weight:800;color:var(--success);text-align:center}.result-your-guess{font-size:.9rem;color:var(--muted);text-align:center;margin-top:4px}#result-content{text-align:center;padding:24px}.game-input-area{display:flex;gap:10px;padding:14px 16px;background:var(--surface);border-top:1px solid var(--border);flex-shrink:0}.autocomplete-wrapper{position:relative;flex:1}.guess-input{padding:10px 14px;font-size:1rem}.autocomplete-dropdown{position:absolute;bottom:calc(100% + 6px);left:0;right:0;background:var(--surface);border:1px solid var(--border);border-radius:8px;overflow:hidden;box-shadow:0 -4px 16px #0006;z-index:10}.autocomplete-dropdown.hidden{display:none}.ac-item{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;cursor:pointer;transition:background .1s;border-bottom:1px solid var(--border)}.ac-item:last-child{border-bottom:none}.ac-item:hover,.ac-item.active{background:var(--border)}.ac-city{font-weight:500;font-size:.95rem}.ac-country{font-size:.8rem;color:var(--muted)}#view-results{justify-content:center;align-items:flex-start;padding:24px 16px;overflow-y:auto}@supports (min-height: fit-content){#view-results{align-items:center}@media(max-height:700px){#view-results{align-items:flex-start}}}.results-container{width:100%;max-width:540px;display:flex;flex-direction:column;gap:24px}.results-container h1{text-align:center;font-size:2rem;font-weight:800;letter-spacing:-.5px}.final-score{text-align:center;line-height:1}.score-num{font-size:4rem;font-weight:900;background:linear-gradient(135deg,#7c6af5,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.score-max{font-size:1.2rem;color:var(--muted)}.results-breakdown{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.result-row{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border)}.result-row:last-child{border-bottom:none}.result-row.correct{border-left:3px solid var(--success)}.result-row.wrong{border-left:3px solid var(--danger)}.result-num{width:24px;height:24px;border-radius:50%;background:var(--border);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0}.result-city-info{flex:1;display:flex;flex-direction:column;gap:1px}.result-city-name{font-weight:600;font-size:.95rem}.result-city-country{font-size:.8rem;color:var(--muted)}.result-guess-text{font-size:.8rem;color:var(--danger);flex-shrink:0}.result-pts{font-weight:700;font-size:.95rem;color:var(--success);min-width:48px;text-align:right;flex-shrink:0}.result-row.wrong .result-pts{color:var(--danger)}.results-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.results-actions .btn-primary{grid-column:1 / -1}.results-actions .btn-secondary{flex:1}.btn-share:before{content:"↑ ";font-size:.9em}.attribution{text-align:center;font-size:.75rem;color:var(--muted);opacity:.6}.attribution a{color:inherit;text-decoration:underline;text-underline-offset:2px}.attribution a:hover{opacity:1;color:var(--text)}.toast{position:fixed;bottom:28px;left:50%;transform:translate(-50%) translateY(12px);background:var(--surface);border:1px solid var(--border);color:var(--text);padding:10px 20px;border-radius:8px;font-size:.9rem;font-weight:500;opacity:0;transition:opacity .2s ease,transform .2s ease;z-index:200;pointer-events:none;white-space:nowrap;box-shadow:0 4px 16px #0006}.toast.visible{opacity:1;transform:translate(-50%) translateY(0)}@media(max-width:480px){.game-header{padding:10px 12px;gap:12px}.game-info{gap:12px}.score-display{font-size:.875rem}.game-input-area{padding:10px 12px}.filters-card{padding:16px}}
