@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--pi-blue: #2563eb;--pi-blue-light: #3b82f6;--pi-blue-dim: #1d4ed8;--bg: #111c2e;--surface: #172538;--surface2: #1f3149;--surface3: #273e5c;--border: #1e3854;--border-bright: #2e527e;--text: #f5f9ff;--text-muted: #b8d0e8;--text-dim: #7a9fc0;--correct: #10b981;--correct-glow: rgba(16, 185, 129, .3);--wrong: #ef4444;--wrong-glow: rgba(239, 68, 68, .3);--revealed: #f59e0b;--revealed-glow:rgba(245, 158, 11, .3);--glow-blue: rgba(37, 99, 235, .3);--glow-blue2: rgba(37, 99, 235, .12);--radius: 8px;--radius-lg: 14px;--radius-xl: 20px;--map-bg: #b8d0e0;--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}html,body,#root{height:100%}body{background:var(--bg);color:var(--text);font-family:var(--font);overflow:hidden;-webkit-font-smoothing:antialiased}.app{display:flex;flex-direction:column;height:100vh}.header{display:flex;align-items:center;justify-content:space-between;padding:0 1.25rem;height:52px;background:linear-gradient(135deg,#080e1c,#0c1628);border-bottom:1px solid rgba(37,99,235,.18);flex-shrink:0;gap:1rem;box-shadow:0 2px 20px #0006}.header-left{display:flex;align-items:center;gap:.65rem;min-width:200px}.header-logo-link{display:inline-flex;align-items:center;gap:.45rem;flex-shrink:0;border-radius:5px;text-decoration:none;transition:opacity .15s,box-shadow .15s}.header-logo-link:hover{opacity:.85;box-shadow:0 0 0 2px #2563eb66}.header-logo-cta{font-size:.68rem;font-weight:600;color:var(--text-muted);white-space:nowrap;transition:color .15s}.header-logo-link:hover .header-logo-cta{color:var(--pi-blue-light)}.header-logo{height:26px;width:auto;background:#fff;border-radius:5px;padding:3px 7px;display:block}.header-divider{width:1px;height:18px;background:var(--border);flex-shrink:0}.header-game-name{font-size:.82rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted)}.header-center{font-size:.875rem;color:var(--text-muted);font-weight:500}.header-center strong{color:var(--text);font-weight:700}.header-right{min-width:200px;display:flex;align-items:center;justify-content:flex-end;gap:.75rem}.header-date{font-size:.75rem;font-weight:500;color:var(--text-muted)}.header-score{font-size:1.05rem;font-weight:800;color:var(--pi-blue-light);letter-spacing:-.02em}.score-max{font-size:.78rem;font-weight:500;color:var(--text-dim)}.diff-chip{font-size:.67rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;border-radius:20px;padding:.2rem .6rem;border:1px solid}.diff-chip-easy{color:#34d399;border-color:#34d3994d;background:#34d39914}.diff-chip-medium{color:#fbbf24;border-color:#fbbf244d;background:#fbbf2414}.diff-chip-hard{color:#f87171;border-color:#f871714d;background:#f8717114}.header-player{font-size:.78rem;font-weight:500;color:var(--text-muted);background:var(--surface2);border:1px solid var(--border);border-radius:20px;padding:.2rem .65rem}.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:.85rem;background:#06090ff5;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:2rem;text-align:center}.overlay-msg{font-size:1.15rem;font-weight:800;letter-spacing:-.02em;color:var(--text)}.overlay-sub{font-size:.875rem;color:var(--text-muted);max-width:34ch}.overlay-gameover{overflow-y:auto;justify-content:flex-start;padding-top:2.5rem}.gameover-score{font-size:3rem;font-weight:900;color:var(--pi-blue-light);letter-spacing:-.05em;line-height:1}.gameover-max{font-size:1.6rem;font-weight:500;color:var(--text-dim)}.score-saved-msg{font-size:.78rem;color:var(--correct);display:flex;align-items:center;gap:.3rem}.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--pi-blue-light);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.map-wrap{flex:1;min-height:0;position:relative;transition:box-shadow .25s ease}.map-wrap :global(.leaflet-container),.map-wrap .leaflet-container{background:var(--map-bg)!important}.map-hint{position:absolute;bottom:10px;left:50%;transform:translate(-50%);font-size:.65rem;font-weight:500;color:#00000073;background:#ffffff8c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:3px 10px;border-radius:20px;pointer-events:none;z-index:450;white-space:nowrap;letter-spacing:.03em}.map-wrap.correct{box-shadow:inset 0 0 0 3px var(--correct),0 0 30px #10b9811a}.map-wrap.revealed{box-shadow:inset 0 0 0 3px var(--revealed),0 0 30px #f59e0b1a}.map-wrap.shake{animation:shake .42s ease}@keyframes shake{0%,to{transform:translate(0)}18%{transform:translate(-8px)}36%{transform:translate(8px)}54%{transform:translate(-5px)}72%{transform:translate(5px)}88%{transform:translate(-2px)}}.controls{background:linear-gradient(180deg,#0c1422,#0a1120);border-top:1px solid rgba(37,99,235,.15);padding:.875rem 1.25rem;display:flex;flex-direction:column;gap:.6rem;flex-shrink:0}.attempt-pips{display:flex;align-items:center;gap:.5rem}.pip{display:inline-block;width:11px;height:11px;border-radius:50%;flex-shrink:0;transition:transform .15s,box-shadow .15s}.pip-ok{background:var(--correct);box-shadow:0 0 8px var(--correct-glow)}.pip-warn{background:var(--revealed);box-shadow:0 0 8px var(--revealed-glow)}.pip-danger{background:var(--wrong);box-shadow:0 0 8px var(--wrong-glow)}.pip-empty{background:var(--surface3);border:1px solid var(--border)}.attempt-label{font-size:.78rem;color:var(--text-muted);margin-left:.25rem;font-weight:500}.guess-wrap{position:relative;display:flex;flex-direction:column;gap:0}.guess-dropdown{position:absolute;bottom:calc(100% + 6px);left:0;right:0;background:var(--surface);border:1px solid var(--border-bright);border-radius:var(--radius-lg);box-shadow:0 -8px 32px #0000008c,0 0 0 1px #2563eb14;max-height:300px;overflow-y:auto;z-index:500;overscroll-behavior:contain}.guess-dropdown::-webkit-scrollbar{width:3px}.guess-dropdown::-webkit-scrollbar-track{background:transparent}.guess-dropdown::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.gd-section{padding:.4rem 0}.gd-section+.gd-section{border-top:1px solid var(--border)}.gd-section-label{font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);padding:.25rem .875rem .2rem}.gd-item{display:flex;align-items:center;width:100%;background:none;border:none;color:var(--text);font-family:var(--font);font-size:.82rem;font-weight:500;text-align:left;padding:.45rem .875rem;cursor:pointer;gap:.4rem;transition:background .1s}.gd-item:hover{background:#2563eb1a;color:var(--text)}.gd-child{padding-left:1.35rem;color:var(--text-muted);font-size:.8rem}.gd-child:hover{color:var(--text)}.gd-child-arrow{color:var(--text-dim);font-size:.72rem;flex-shrink:0}.gd-holdco-group+.gd-holdco-group{border-top:1px solid rgba(30,56,84,.5)}.gd-holdco-header{display:flex;align-items:center;justify-content:space-between;padding:.35rem .875rem .1rem;gap:.5rem}.gd-holdco-name{font-size:.8rem;font-weight:700;color:var(--pi-blue-light)}.gd-holdco-count{font-size:.65rem;color:var(--text-dim);font-weight:500;white-space:nowrap}.guess-form{display:flex;gap:.5rem}.guess-input{flex:1;background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:.55rem .875rem;border-radius:var(--radius);font-size:.9rem;font-family:var(--font);outline:none;transition:border-color .2s,box-shadow .2s;min-width:0}.guess-input:focus{border-color:var(--pi-blue);box-shadow:0 0 0 3px var(--glow-blue2),0 0 12px var(--glow-blue2)}.guess-input::placeholder{color:var(--text-dim)}.btn{border:none;border-radius:var(--radius);font-size:.9rem;font-weight:600;font-family:var(--font);cursor:pointer;padding:.55rem 1.15rem;transition:transform .15s,box-shadow .15s,opacity .15s;white-space:nowrap}.btn:disabled{opacity:.35;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--pi-blue-dim),var(--pi-blue));color:#fff;box-shadow:0 2px 14px var(--glow-blue)}.btn-primary:not(:disabled):hover{transform:translateY(-1px);box-shadow:0 4px 22px #2563eb80}.btn-primary:not(:disabled):active{transform:translateY(0)}.btn-ghost{background:transparent;color:var(--text-muted);border:1px solid var(--border);font-weight:500;font-size:.8rem;padding:.4rem .875rem;align-self:flex-start}.btn-ghost:not(:disabled):hover{color:var(--text);border-color:var(--border-bright);background:var(--surface2)}.result-card{display:flex;flex-direction:column;gap:.5rem}.result-header{display:flex;flex-direction:column;gap:.2rem}.result-label{font-size:.72rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase}.result-label.correct{color:var(--correct)}.result-label.revealed{color:var(--revealed)}.result-name{font-size:1.2rem;font-weight:800;letter-spacing:-.025em;line-height:1.2;color:var(--text)}.result-meta{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.1rem}.meta-chip{background:var(--surface3);border:1px solid var(--border);border-radius:20px;padding:.2rem .6rem;font-size:.74rem;color:var(--text-muted);font-weight:500}.scoreboard{width:240px;flex-shrink:0;background:linear-gradient(180deg,#0c1422,#0a1120);border-left:1px solid rgba(37,99,235,.15);display:flex;flex-direction:column;overflow:hidden}.scoreboard-title{font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim);padding:.7rem 1rem .5rem;border-bottom:1px solid var(--border);flex-shrink:0}.scoreboard-rows{flex:1;overflow-y:auto}.scoreboard-rows::-webkit-scrollbar{width:3px}.scoreboard-rows::-webkit-scrollbar-track{background:transparent}.scoreboard-rows::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.sb-row{display:grid;grid-template-columns:22px 1fr auto auto;align-items:center;gap:.4rem;padding:.45rem 1rem;border-bottom:1px solid rgba(30,56,84,.5);font-size:.8rem;transition:background .15s}.sb-row.sb-current{background:#2563eb12;border-left:2px solid var(--pi-blue);padding-left:calc(1rem - 2px)}.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(--text-dim)}.sb-num{color:var(--text-dim);font-size:.7rem;text-align:right;font-weight:600}.sb-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;font-weight:500;font-size:.78rem}.sb-dots{font-size:.6rem;letter-spacing:-1px;flex-shrink:0}.dot-gold{color:#fbbf24;text-shadow:0 0 6px rgba(251,191,36,.6)}.dot-silver{color:#94a3b8}.dot-bronze{color:#c2773b}.dot-miss{color:var(--wrong)}.sb-pts{font-size:.7rem;font-weight:700;color:var(--pi-blue-light);white-space:nowrap;flex-shrink:0;background:#2563eb1f;border-radius:4px;padding:.1rem .35rem}.scoreboard-total{display:flex;justify-content:space-between;align-items:center;padding:.65rem 1rem;border-top:1px solid rgba(37,99,235,.15);font-size:.78rem;font-weight:600;color:var(--text-muted);flex-shrink:0;background:#2563eb0a}.total-score{font-size:1.05rem;font-weight:900;color:var(--pi-blue-light);letter-spacing:-.02em}.total-max{font-size:.72rem;font-weight:400;color:var(--text-dim)}.gameover-label{font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim)}.name-entry{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:300;padding:1.5rem;background:radial-gradient(ellipse 90% 55% at 50% -5%,rgba(37,99,235,.18) 0%,transparent 70%),linear-gradient(rgba(37,99,235,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(37,99,235,.045) 1px,transparent 1px),#06090f;background-size:auto,44px 44px,44px 44px;overflow-y:auto}.name-entry-card{background:#0c1422eb;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(37,99,235,.22);border-radius:var(--radius-xl);padding:2.75rem 2.25rem 2.25rem;max-width:420px;width:100%;display:flex;flex-direction:column;align-items:center;gap:1.25rem;text-align:center;box-shadow:0 30px 80px #000000b3,0 0 0 1px #2563eb14,0 0 60px #2563eb0f}.name-entry-logo-wrap{background:#fff;border-radius:10px;padding:8px 14px;display:inline-flex;align-items:center;box-shadow:0 4px 20px #00000059}.name-entry-logo{height:32px;width:auto;display:block}.name-entry-title{font-size:1.05rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--text);margin-top:-.25rem}.name-entry-sub{font-size:.82rem;color:var(--text-muted);line-height:1.6;max-width:30ch;margin-top:-.5rem}.name-entry-form{display:flex;flex-direction:column;gap:1rem;width:100%}.name-entry-input{width:100%;background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:.65rem 1rem;border-radius:var(--radius);font-size:.95rem;font-family:var(--font);outline:none;text-align:center;transition:border-color .2s,box-shadow .2s}.name-entry-input:focus{border-color:var(--pi-blue);box-shadow:0 0 0 3px var(--glow-blue2),0 0 16px var(--glow-blue2)}.name-entry-input::placeholder{color:var(--text-dim)}.name-entry-btn{width:100%;padding:.75rem 1rem;font-size:.95rem;font-weight:700;letter-spacing:.04em;border-radius:var(--radius);background:linear-gradient(135deg,var(--pi-blue-dim),var(--pi-blue));color:#fff;border:none;cursor:pointer;box-shadow:0 4px 24px #2563eb73;transition:transform .15s,box-shadow .15s}.name-entry-btn:not(:disabled):hover{transform:translateY(-2px);box-shadow:0 8px 32px #2563eb99}.name-entry-btn:disabled{opacity:.35;cursor:not-allowed}.difficulty-picker{width:100%;display:flex;flex-direction:column;gap:.5rem}.diff-label{font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);text-align:left}.diff-buttons{display:flex;gap:.5rem}.diff-btn{flex:1;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);cursor:pointer;padding:.65rem .4rem;display:flex;flex-direction:column;align-items:center;gap:.25rem;transition:border-color .18s,color .18s,background .18s,transform .15s,box-shadow .18s;font-family:var(--font)}.diff-btn-name{font-size:.82rem;font-weight:700}.diff-btn-desc{font-size:.64rem;line-height:1.3;text-align:center;opacity:.8}.diff-btn:not(.active):hover{border-color:var(--border-bright);color:var(--text);transform:translateY(-1px)}.diff-btn.active{transform:translateY(-1px)}.diff-btn.active.diff-easy{border-color:#34d399;color:#34d399;background:#34d39914;box-shadow:0 0 14px #34d3992e}.diff-btn.active.diff-medium{border-color:#fbbf24;color:#fbbf24;background:#fbbf2414;box-shadow:0 0 14px #fbbf242e}.diff-btn.active.diff-hard{border-color:#f87171;color:#f87171;background:#f8717114;box-shadow:0 0 14px #f871712e}.leaderboard{width:100%;max-width:360px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;margin-top:.25rem}.lb-date{font-size:.68rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.09em;font-weight:600;padding:.6rem .875rem .4rem;border-bottom:1px solid var(--border)}.lb-table{width:100%;border-collapse:collapse;font-size:.82rem}.lb-table thead th{text-align:left;font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);padding:.3rem .875rem;border-bottom:1px solid var(--border)}.lb-table thead th:last-child{text-align:right}.lb-table tbody td{padding:.4rem .875rem;border-bottom:1px solid rgba(30,56,84,.5)}.lb-table tbody tr:last-child td{border-bottom:none}.lb-table tbody tr.lb-me{background:#2563eb1a}.lb-table tbody tr.lb-me .lb-name:after{content:" (you)";font-size:.68rem;color:var(--pi-blue-light);font-weight:500}.lb-rank{color:var(--text-dim);font-size:.72rem;font-weight:700;width:1.5rem}.lb-name{font-weight:600;color:var(--text)}.lb-score{text-align:right;color:var(--pi-blue-light);font-weight:800;white-space:nowrap}.lb-error,.lb-loading,.lb-empty{font-size:.82rem;color:var(--text-muted);padding:.75rem}.lb-error{color:var(--wrong)}.share-wrap{display:flex;flex-direction:column;align-items:center;gap:.6rem;width:100%;max-width:360px}.share-card{width:100%;background:var(--surface2);border:1px solid var(--border-bright);border-radius:var(--radius-lg);padding:1.1rem 1.25rem 1rem;display:flex;flex-direction:column;gap:.6rem;box-shadow:0 4px 24px #00000059,0 0 0 1px #2563eb14}.share-card-header{display:flex;align-items:center;gap:.6rem}.share-card-logo{height:20px;width:auto;background:#fff;border-radius:4px;padding:2px 6px}.share-card-title{font-size:.78rem;font-weight:800;letter-spacing:.07em;text-transform:uppercase;color:var(--text-muted)}.share-card-meta{font-size:.78rem;color:var(--text-muted)}.share-card-meta strong{color:var(--pi-blue-light);font-weight:700}.share-grid{display:flex;flex-direction:column;gap:4px;align-items:center}.share-grid-row{display:flex;gap:4px;align-items:center}.share-dot{width:16px;height:16px;border-radius:3px;flex-shrink:0}.share-card-url{font-size:.68rem;font-weight:600;color:var(--pi-blue-light);letter-spacing:.04em;border-top:1px solid var(--border);padding-top:.5rem;margin-top:.1rem}.share-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.45rem;background:linear-gradient(135deg,#1a4db5,#2563eb);color:#fff;font-size:.9rem;font-weight:700;padding:.65rem 1.25rem;border-radius:var(--radius);box-shadow:0 4px 20px #2563eb66;transition:transform .15s,box-shadow .15s,background .2s;border:none;cursor:pointer;font-family:var(--font)}.share-btn:hover{transform:translateY(-1px);box-shadow:0 6px 28px #2563eb8c}.share-hint{font-size:.7rem;color:var(--text-dim);min-height:1em}.about-pi{width:100%;margin-top:.5rem;padding-top:1.25rem;border-top:1px solid var(--border);display:flex;flex-direction:column;align-items:center;gap:.5rem;text-align:center}.about-pi-logo-wrap{background:#fff;border-radius:7px;padding:5px 10px;display:inline-flex;box-shadow:0 2px 10px #00000040}.about-pi-logo{height:22px;width:auto;display:block}.about-pi-tagline{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--pi-blue-light)}.about-pi-body{font-size:.78rem;color:var(--text-muted);line-height:1.65;max-width:34ch}.about-pi-link{font-size:.78rem;font-weight:600;color:var(--pi-blue-light);text-decoration:none;transition:color .15s}.about-pi-link:hover{color:#fff;text-decoration:underline}.wgl-wrap{background:transparent!important;border:none!important;box-shadow:none!important;overflow:visible!important}.wgl-inner{position:absolute;transform:translate(-50%) translateY(-50%);background:#dc2626e6;border:1px solid rgba(255,100,100,.4);border-radius:5px;color:#fff;font-family:var(--font);font-size:.67rem;font-weight:700;padding:3px 8px;white-space:nowrap;box-shadow:0 2px 8px #00000080;pointer-events:none;line-height:1.5;letter-spacing:.01em}.htp-trigger{height:28px;padding:0 .65rem;border-radius:20px;border:1px solid var(--border-bright);background:var(--surface2);color:var(--text-muted);font-size:.75rem;font-weight:600;font-family:var(--font);cursor:pointer;display:flex;align-items:center;gap:.25rem;flex-shrink:0;white-space:nowrap;transition:background .15s,color .15s,border-color .15s;line-height:1}.htp-trigger:hover{background:var(--surface3);color:var(--text);border-color:var(--pi-blue)}.htp-inline-btn{background:none;border:1px solid var(--border-bright);border-radius:20px;color:var(--text-muted);font-size:.78rem;font-weight:600;font-family:var(--font);cursor:pointer;padding:.35rem .875rem;transition:color .15s,border-color .15s,background .15s;margin-top:-.5rem}.htp-inline-btn:hover{color:var(--text);border-color:var(--pi-blue);background:#2563eb0f}.htp-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:600;display:flex;align-items:center;justify-content:center;padding:1.25rem}.htp-card{background:var(--surface);border:1px solid rgba(37,99,235,.25);border-radius:var(--radius-xl);width:100%;max-width:420px;max-height:90vh;overflow-y:auto;box-shadow:0 30px 80px #000000b3;display:flex;flex-direction:column}.htp-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem .75rem;border-bottom:1px solid var(--border);flex-shrink:0}.htp-title{font-size:1.05rem;font-weight:800;letter-spacing:-.02em}.htp-close{background:none;border:none;color:var(--text-muted);font-size:.9rem;cursor:pointer;padding:.2rem .4rem;border-radius:4px;transition:color .15s,background .15s;font-family:var(--font)}.htp-close:hover{color:var(--text);background:var(--surface2)}.htp-body{padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:1.25rem;overflow-y:auto}.htp-intro{font-size:.875rem;color:var(--text-muted);line-height:1.6}.htp-section{display:flex;flex-direction:column;gap:.6rem}.htp-section-title{font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim)}.htp-score-rows{display:flex;flex-direction:column;gap:.5rem}.htp-score-row{display:flex;align-items:center;gap:.75rem;font-size:.85rem;color:var(--text-muted)}.htp-dots{display:flex;gap:3px;flex-shrink:0}.htp-dot{width:14px;height:14px;border-radius:3px;display:inline-block}.htp-dot-green{background:#22c55e}.htp-dot-amber{background:#f59e0b}.htp-dot-orange{background:#f97316}.htp-dot-miss,.htp-dot-empty{background:#ffffff14;border:1px solid var(--border)}.htp-note{font-size:.75rem;color:var(--text-dim);margin-top:.1rem}.htp-diff-rows{display:flex;flex-direction:column;gap:.5rem}.htp-diff-row{display:flex;align-items:center;gap:.75rem;font-size:.85rem;color:var(--text-muted)}.htp-tips{list-style:none;display:flex;flex-direction:column;gap:.4rem}.htp-tips li{font-size:.85rem;color:var(--text-muted);padding-left:1rem;position:relative;line-height:1.5}.htp-tips li:before{content:"·";position:absolute;left:0;color:var(--pi-blue-light);font-weight:700}.htp-done{margin:0 1.5rem 1.25rem;flex-shrink:0}.mobile-score-strip{display:none;align-items:center;justify-content:space-between;gap:.5rem;padding-top:.4rem;border-top:1px solid var(--border);margin-top:.1rem}.mss-dots{display:flex;gap:4px;flex-wrap:wrap}.mss-dot{width:14px;height:14px;border-radius:3px;flex-shrink:0}.mss-dot-current{outline:2px solid var(--pi-blue-light);outline-offset:1px}.mss-score{font-size:.9rem;font-weight:800;color:var(--pi-blue-light);white-space:nowrap;flex-shrink:0}.mss-max{font-size:.7rem;font-weight:400;color:var(--text-dim)}@media (max-width: 640px){html,body,#root{height:100%;overflow:hidden}.app{height:100vh;height:100dvh}.header{height:auto;padding:.5rem .875rem;flex-wrap:wrap;gap:.4rem}.header-logo-cta,.header-divider{display:none}.header-game-name{font-size:.75rem}.header-player,.header-date{display:none}.header-left{gap:.4rem;min-width:0}.header-right{min-width:0;gap:.5rem}.game-body{flex-direction:column}.map-section{min-height:0}.map-wrap{flex:1;min-height:0}.map-wrap .leaflet-container{touch-action:none}.scoreboard{display:none}.mobile-score-strip{display:flex}.controls{padding:.625rem .875rem;flex-shrink:0}.guess-dropdown{max-height:220px}.overlay{overflow-y:auto;-webkit-overflow-scrolling:touch}}
