@font-face{font-family:Plus Jakarta Sans Variable;font-style:normal;font-display:swap;font-weight:200 800;src:url(data:font/woff2;base64,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) format("woff2-variations");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Plus Jakarta Sans Variable;font-style:normal;font-display:swap;font-weight:200 800;src:url(./plus-jakarta-sans-vietnamese-wght-normal-qRpaaN48.woff2) format("woff2-variations");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Plus Jakarta Sans Variable;font-style:normal;font-display:swap;font-weight:200 800;src:url(./plus-jakarta-sans-latin-ext-wght-normal-DmpS2jIq.woff2) format("woff2-variations");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Plus Jakarta Sans Variable;font-style:normal;font-display:swap;font-weight:200 800;src:url(./plus-jakarta-sans-latin-wght-normal-eXO_dkmS.woff2) format("woff2-variations");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--bg: #eef3f3;--bg-2: #f6f9f9;--surface: #ffffff;--surface-2: #f3f7f7;--ink: #102027;--muted: #5a6b75;--faint: #93a3ad;--line: #e6edec;--line-2: #dde6e5;--accent: #12b886;--accent-deep: #0ca678;--accent-soft: #e6f7f1;--on-accent: #ffffff;--coral: #ff6b6b;--shadow-sm: 0 2px 10px rgba(16, 32, 39, .06);--shadow: 0 10px 30px rgba(16, 32, 39, .08);--shadow-lg: 0 24px 60px rgba(16, 32, 39, .12);--r-sm: 12px;--r: 18px;--r-lg: 26px;--r-pill: 999px;--font: "Plus Jakarta Sans Variable", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{margin:0;height:100%}body{font-family:var(--font);color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overscroll-behavior:none}#app{position:relative;z-index:1;height:100vh;height:100dvh;overflow:hidden}.screen{height:100%}.screen.center{display:flex;align-items:flex-start;justify-content:center;overflow-y:auto;padding:max(24px,env(safe-area-inset-top)) max(24px,env(safe-area-inset-right)) max(24px,env(safe-area-inset-bottom)) max(24px,env(safe-area-inset-left))}.screen.center>*{margin:auto}[hidden]{display:none!important}.bg-decor{position:fixed;inset:0;z-index:0;background:radial-gradient(60vw 50vh at 82% -8%,rgba(18,184,134,.14),transparent 70%),radial-gradient(55vw 50vh at -5% 105%,rgba(18,184,134,.1),transparent 70%),linear-gradient(180deg,var(--bg-2),var(--bg))}@keyframes reveal{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}[data-reveal]{animation:reveal .6s cubic-bezier(.16,1,.3,1) both}@media(prefers-reduced-motion:reduce){[data-reveal]{animation:none}}.btn{appearance:none;border:none;cursor:pointer;font-family:inherit;font-weight:700;font-size:15px;letter-spacing:.01em;border-radius:var(--r-pill);padding:13px 26px;transition:transform .12s ease,box-shadow .2s ease,background .2s ease,opacity .2s ease}.btn-primary{color:var(--on-accent);background:linear-gradient(135deg,#18cc97,var(--accent) 55%,var(--accent-deep));box-shadow:0 8px 20px #12b88652}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 26px #12b88666}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{cursor:default;color:var(--faint);background:var(--surface-2);box-shadow:none}.btn-lg{font-size:17px;padding:16px 40px}.btn-block{width:100%}.btn-secondary{color:var(--accent-deep);background:var(--accent-soft)}.btn-secondary:hover:not(:disabled){transform:translateY(-2px);background:#d6f2e9}.btn-secondary:active:not(:disabled){transform:translateY(0)}.start-buttons,.summary-buttons{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.daily-note{margin:12px 0 0;font-size:12.5px;font-weight:600;color:var(--muted);min-height:1em}.streak{display:inline-flex;align-items:center;gap:7px;margin:14px auto 0;background:#fff2e6;color:#c2410c;font-weight:800;font-size:13px;padding:7px 15px;border-radius:var(--r-pill)}.streak svg{width:15px;height:15px}.streak b{font-weight:800}.challenge-banner{position:relative;background:var(--accent-soft);border:1px solid rgba(18,184,134,.28);border-radius:var(--r);padding:16px 16px 14px;margin:0 0 22px;text-align:center}.challenge-dismiss{position:absolute;top:5px;right:8px;width:26px;height:26px;appearance:none;border:none;background:transparent;cursor:pointer;font-size:21px;line-height:1;color:var(--accent-deep);opacity:.55;border-radius:8px}.challenge-dismiss:hover{opacity:1}.challenge-banner p{margin:0 0 12px;font-size:14.5px;font-weight:600;color:var(--accent-deep);line-height:1.45}.challenge-banner b{font-weight:800}.challenge-result{margin:4px auto 18px;display:inline-block;font-size:14px;font-weight:700;color:var(--ink);background:var(--surface-2);border-radius:var(--r-pill);padding:9px 18px}.challenge-result b{color:var(--accent-deep)}.start-card{position:relative;background:var(--surface);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:44px 44px 32px;max-width:520px;width:100%;text-align:center}.brand{display:inline-flex;align-items:center;gap:9px;font-weight:800;font-size:15px;letter-spacing:-.01em;color:var(--ink)}.brand .logo{display:inline-flex;width:26px;height:26px;color:var(--accent)}.brand .logo svg{width:100%;height:100%}.brand.sm{font-size:15px}.start-card h1{margin:18px 0 12px;font-size:clamp(30px,5vw,40px);font-weight:800;line-height:1.08;letter-spacing:-.025em}.grad{background:linear-gradient(120deg,var(--accent),var(--accent-deep));-webkit-background-clip:text;background-clip:text;color:transparent}.sub{margin:0 auto 24px;color:var(--muted);font-size:15.5px;line-height:1.6;max-width:42ch}.steps{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-bottom:26px}.step{display:inline-flex;align-items:center;gap:8px;background:var(--surface-2);border-radius:var(--r-pill);padding:8px 14px 8px 8px;font-size:13px;font-weight:600;color:var(--muted)}.step-n{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:var(--accent-soft);color:var(--accent-deep);font-size:12px;font-weight:800}.pickers{display:grid;gap:10px;margin-bottom:24px;justify-items:center}.picker-row{display:flex;align-items:center;gap:14px}.picker-label{font-size:14px;font-weight:600;color:var(--muted);min-width:80px;text-align:right}.seg{display:inline-flex;background:var(--surface-2);border-radius:var(--r-pill);padding:4px;gap:2px}.seg button{appearance:none;border:none;background:transparent;cursor:pointer;font-family:inherit;font-weight:700;font-size:15px;color:var(--muted);width:46px;height:38px;border-radius:var(--r-pill);transition:all .18s ease}.seg button:hover{color:var(--ink)}.seg button.active{background:var(--surface);color:var(--accent-deep);box-shadow:var(--shadow-sm)}.seg.wide button{width:auto;min-width:58px;padding:0 16px}.select-wrap{position:relative;display:inline-flex}.region-select{appearance:none;-webkit-appearance:none;font-family:inherit;font-weight:700;font-size:15px;color:var(--ink);background-color:var(--surface-2);border:none;border-radius:var(--r-pill);padding:10px 40px 10px 18px;cursor:pointer;min-width:170px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1.5 6 6.5 11 1.5' stroke='%235a6b75' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;transition:box-shadow .18s ease}.region-select:hover{box-shadow:inset 0 0 0 1.5px var(--line-2)}.region-select:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.credit{margin:22px 0 0;color:var(--faint);font-size:12px}.credit a{color:inherit;text-decoration:underline;text-underline-offset:2px}.credit a:hover{color:var(--muted)}#game-screen{display:flex;flex-direction:column}.topbar{flex:0 0 auto;position:sticky;top:0;display:flex;align-items:center;justify-content:space-between;padding:14px 22px;background:#ffffffc7;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--line);z-index:5}.topbar-left{display:flex;align-items:center;gap:12px;min-width:0}.leave-btn{appearance:none;cursor:pointer;flex:0 0 auto;display:inline-flex;align-items:center;gap:6px;font-family:inherit;font-weight:700;font-size:13.5px;color:var(--muted);background:var(--surface);border:1px solid var(--line);padding:7px 14px 7px 11px;border-radius:var(--r-pill);box-shadow:var(--shadow-sm);transition:transform .12s ease,box-shadow .2s ease,color .2s ease}.leave-btn:hover{color:var(--ink);transform:translateY(-1px);box-shadow:var(--shadow)}.leave-btn:active{transform:translateY(0)}.leave-btn svg{width:16px;height:16px}.hud{display:flex;gap:10px}.chip{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-pill);padding:7px 16px;box-shadow:var(--shadow-sm)}.chip-label{font-size:12px;font-weight:600;color:var(--faint)}.chip-val{font-size:16px;font-weight:800;font-variant-numeric:tabular-nums}.chip-val.accent{color:var(--accent-deep)}.game-grid{flex:1 1 auto;min-height:0;display:flex;gap:18px;padding:18px}.data-panel{flex:1 1 460px;min-width:0;overflow-y:auto;padding-right:4px}.panel-head h2{margin:0 0 3px;font-size:22px;font-weight:800;letter-spacing:-.02em}.panel-head p{margin:0 0 16px;color:var(--muted);font-size:14px}.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm);margin-bottom:18px}.stat{background:var(--surface);padding:12px 15px}.stat .s-label{font-size:11.5px;font-weight:600;color:var(--faint);display:block;margin-bottom:3px}.stat .s-val{font-size:16px;font-weight:800;font-variant-numeric:tabular-nums;letter-spacing:-.01em}@media(max-width:620px){.stats{grid-template-columns:repeat(2,1fr)}}.charts{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px}.chart-card{background:var(--surface);border-radius:var(--r);padding:14px 16px 16px;box-shadow:var(--shadow-sm);opacity:0;animation:reveal .5s cubic-bezier(.16,1,.3,1) forwards;animation-delay:var(--cd, 0ms);min-width:0}.chart-card:first-child{grid-column:1 / -1}.chart-card-head{display:flex;align-items:baseline;justify-content:space-between;gap:8px;margin-bottom:6px}.chart-card-head h3{margin:0;font-size:15px;font-weight:800;letter-spacing:-.01em}.chart-sub{font-size:12px;color:var(--faint);font-weight:500}.chart-canvas-wrap{position:relative;height:164px;min-width:0;overflow:hidden}.chart-card:first-child .chart-canvas-wrap{height:196px}.map-panel{flex:1 1 520px;min-width:0;position:relative;display:flex;flex-direction:column}.map-wrap{flex:1 1 auto;min-height:0;position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line)}#map{position:absolute;inset:0;background:#dbe7e6}.map-hint{position:absolute;top:14px;left:50%;transform:translate(-50%);z-index:600;background:#102027d1;color:#fff;font-size:13px;font-weight:600;padding:9px 18px;border-radius:var(--r-pill);pointer-events:none;box-shadow:var(--shadow-sm)}.map-actions{flex:0 0 auto;padding-top:14px}.pin-icon{background:none;border:none}.pin{position:relative}.pin svg{display:block;filter:drop-shadow(0 4px 6px rgba(16,32,39,.3))}.pin-guess,.pin-guess svg{width:30px;height:38px}.pin-actual,.pin-actual svg{width:30px;height:38px}.leaflet-tooltip.place-tooltip{background:var(--ink);color:#fff;border:none;border-radius:8px;font-family:var(--font);font-weight:700;font-size:12.5px;box-shadow:var(--shadow-sm);padding:5px 10px}.leaflet-tooltip.place-tooltip:before{border-top-color:var(--ink)}.leaflet-bar{border-radius:var(--r-sm)!important;overflow:hidden;box-shadow:var(--shadow-sm)!important;border:none!important}.leaflet-bar a{background:#fff!important;color:var(--ink)!important;border-color:var(--line)!important}.leaflet-bar a:hover{background:var(--surface-2)!important}.leaflet-control-attribution{background:#ffffffc7!important;border-radius:8px 0 0;color:var(--faint)!important}.leaflet-control-attribution a{color:var(--accent-deep)!important}.result-card{position:absolute;left:0;right:0;bottom:0;z-index:700;background:var(--surface);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:20px 22px 22px;animation:rise .3s cubic-bezier(.16,1,.3,1)}@keyframes rise{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.result-row{display:flex;align-items:center;justify-content:space-between;gap:14px}.result-place{min-width:0}.result-place h3{margin:0;font-size:22px;font-weight:800;letter-spacing:-.02em}.result-place p{margin:2px 0 0;color:var(--muted);font-size:14px}.result-points{text-align:right;white-space:nowrap}.points-val{font-size:26px;font-weight:800;color:var(--accent-deep);font-variant-numeric:tabular-nums}.points-max{font-size:13px;color:var(--faint);font-weight:600}.bar{height:9px;background:var(--surface-2);border-radius:var(--r-pill);overflow:hidden;margin:14px 0 12px}.bar-fill{height:100%;width:0;border-radius:var(--r-pill);background:linear-gradient(90deg,var(--accent),var(--accent-deep));transition:width .8s cubic-bezier(.22,1,.36,1)}.result-distance{margin:0 0 8px;font-weight:700;font-size:14px}.result-climate{margin:0 0 6px;font-size:13.5px;color:var(--muted)}.result-climate b{color:var(--ink);font-weight:700}.result-note{margin:0 0 16px;font-size:13px;color:var(--muted);line-height:1.5}.result-card .btn{margin-top:2px}.summary-card{background:var(--surface);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:34px 34px 30px;max-width:600px;width:100%;text-align:center}.summary-kicker{font-size:13px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--accent-deep)}.final{display:flex;align-items:baseline;justify-content:center;gap:10px;margin:8px 0 4px}.final-val{font-size:60px;font-weight:800;color:var(--ink);font-variant-numeric:tabular-nums;line-height:1;letter-spacing:-.03em}.final-max{font-size:19px;color:var(--faint);font-weight:700}.rating{margin:10px auto 20px;font-size:16px;font-weight:600;color:var(--muted);max-width:36ch}#summary-map{height:270px;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--line);margin-bottom:18px;background:#dbe7e6}.summary-rounds{display:grid;gap:8px;margin-bottom:22px;text-align:left}.summary-row{display:grid;grid-template-columns:26px 1fr auto auto;align-items:center;gap:12px;background:var(--surface-2);border-radius:var(--r-sm);padding:10px 14px}.sr-index{font-weight:800;color:var(--faint);font-variant-numeric:tabular-nums;font-size:13px}.sr-place{display:flex;flex-direction:column;line-height:1.25;min-width:0}.sr-place strong{font-size:14.5px;font-weight:700}.sr-place span{font-size:12px;color:var(--muted)}.sr-dist{font-size:13px;color:var(--muted);font-variant-numeric:tabular-nums;white-space:nowrap}.sr-points{font-weight:800;color:var(--accent-deep);font-variant-numeric:tabular-nums;white-space:nowrap}.data-panel::-webkit-scrollbar,.summary-card::-webkit-scrollbar{width:8px}.data-panel::-webkit-scrollbar-thumb,.summary-card::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:999px}@media(max-width:880px){#app{overflow:auto}#game-screen{height:auto;min-height:100%}.game-grid{flex-direction:column;padding:14px}.data-panel{flex:none;overflow:visible}.map-panel{flex:none}.map-wrap{height:64vh;min-height:420px}.charts{grid-template-columns:1fr}.chart-card:first-child{grid-column:auto}}@media(max-width:480px){.start-card{padding:30px 22px 26px}.summary-card{padding:26px 22px 24px}.sub{font-size:15px}.steps{margin-bottom:22px}.picker-row{flex-direction:column;gap:7px;align-items:stretch;width:100%;max-width:300px}.picker-label{min-width:0;text-align:center}.select-wrap,.region-select,.seg{width:100%}.seg{justify-content:center}.seg button{flex:1}.start-buttons .btn,.summary-buttons .btn{flex:1 1 100%}.start-buttons #start-btn{order:-1}.modal{padding:24px 20px 22px}.modal-title{font-size:20px}.final-val{font-size:50px}#summary-map{height:230px}.map-wrap{height:58vh;min-height:360px}}@media(max-width:430px){.topbar{padding:11px 14px}.topbar .brand.sm{display:none}.hud{gap:8px}.chip{padding:6px 12px}.chip-label{font-size:11px}}.account-bar{position:fixed;top:max(16px,env(safe-area-inset-top));right:max(18px,env(safe-area-inset-right));z-index:900}.account-btn{appearance:none;border:1px solid var(--line);cursor:pointer;font-family:inherit;font-weight:700;font-size:14px;color:var(--ink);background:var(--surface);border-radius:var(--r-pill);padding:9px 18px;box-shadow:var(--shadow-sm);transition:transform .12s ease,box-shadow .2s ease}.account-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow)}.account-menu{position:relative}.account-trigger{appearance:none;border:1px solid var(--line);cursor:pointer;display:flex;align-items:center;gap:8px;background:var(--surface);border-radius:var(--r-pill);padding:6px 14px 6px 6px;box-shadow:var(--shadow-sm);font-family:inherit;font-weight:700;font-size:14px;color:var(--ink)}.account-trigger .avatar{width:28px;height:28px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#18cc97,var(--accent-deep));color:#fff;font-size:13px;font-weight:800;text-transform:uppercase}.account-trigger .chev{width:11px;height:8px;color:var(--muted)}.account-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:160px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-sm);box-shadow:var(--shadow);padding:6px;display:flex;flex-direction:column}.dropdown-item{appearance:none;border:none;background:transparent;cursor:pointer;text-align:left;font-family:inherit;font-weight:600;font-size:14px;color:var(--ink);padding:9px 12px;border-radius:9px}.dropdown-item:hover{background:var(--surface-2)}.modal-overlay{position:fixed;inset:0;z-index:1000;display:flex;align-items:flex-start;justify-content:center;overflow-y:auto;padding:max(20px,env(safe-area-inset-top)) 20px max(20px,env(safe-area-inset-bottom));background:#1020276b;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);animation:fade .2s ease}@keyframes fade{0%{opacity:0}to{opacity:1}}.modal{position:relative;width:100%;max-width:380px;margin:auto;background:var(--surface);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:28px 26px 26px;animation:rise .25s cubic-bezier(.16,1,.3,1)}.modal-lg{max-width:520px}.modal-close{position:absolute;top:14px;right:16px;appearance:none;border:none;background:transparent;cursor:pointer;font-size:24px;line-height:1;color:var(--faint);width:30px;height:30px;border-radius:8px}.modal-close:hover{background:var(--surface-2);color:var(--ink)}.modal-title{margin:0 0 4px;font-size:22px;font-weight:800;letter-spacing:-.02em}.modal-sub{margin:0 0 16px;color:var(--muted);font-size:14px;line-height:1.5}.auth-tabs{display:flex;gap:4px;background:var(--surface-2);border-radius:var(--r-pill);padding:4px;margin:14px 0 18px}.auth-tab{flex:1;appearance:none;border:none;cursor:pointer;font-family:inherit;font-weight:700;font-size:14px;color:var(--muted);background:transparent;padding:9px;border-radius:var(--r-pill);transition:all .18s ease}.auth-tab.active{background:var(--surface);color:var(--accent-deep);box-shadow:var(--shadow-sm)}.auth-form{display:flex;flex-direction:column;gap:12px}.field{display:flex;flex-direction:column;gap:5px;text-align:left}.field label{font-size:12.5px;font-weight:700;color:var(--muted)}.field input{font-family:inherit;font-size:16px;color:var(--ink);background:var(--surface-2);border:1.5px solid transparent;border-radius:var(--r-sm);padding:11px 14px;transition:border-color .15s ease,background .15s ease}.field input:focus{outline:none;border-color:var(--accent);background:var(--surface)}.field input::placeholder{color:var(--faint)}.form-msg{margin:2px 0 0;font-size:13px;font-weight:600}.form-msg.error{color:#e0364f}.form-msg.ok{color:var(--accent-deep)}.or-divider{display:flex;align-items:center;gap:12px;margin:16px 0;color:var(--faint);font-size:12px;font-weight:600}.or-divider:before,.or-divider:after{content:"";flex:1;height:1px;background:var(--line)}.btn-google{color:var(--ink);background:var(--surface);border:1.5px solid var(--line);display:inline-flex;align-items:center;justify-content:center;gap:10px;box-shadow:none}.btn-google:hover:not(:disabled){transform:translateY(-1px);background:var(--surface-2);box-shadow:var(--shadow-sm)}.history-list{display:flex;flex-direction:column;gap:8px;max-height:60vh;overflow-y:auto;margin-top:10px}.history-row{display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--surface-2);border-radius:var(--r-sm);padding:12px 15px}.history-row .h-score{font-weight:800;font-size:17px;font-variant-numeric:tabular-nums}.history-row .h-score small{color:var(--faint);font-weight:600;font-size:12px;margin-left:3px}.history-row .h-meta{display:flex;flex-direction:column;align-items:flex-end;gap:2px;font-size:12.5px;color:var(--muted);text-align:right}.history-row .h-meta .h-mode{font-weight:700;color:var(--ink)}.history-empty{color:var(--muted);font-size:14px;text-align:center;padding:30px 0}.saved-note{margin:12px 0 0;font-size:13px;font-weight:600;color:var(--accent-deep);min-height:1em}.account-btn{display:inline-flex;align-items:center;gap:8px}.leaderboard-bar{position:fixed;top:max(16px,env(safe-area-inset-top));left:max(18px,env(safe-area-inset-left));z-index:900}.toast{position:fixed;left:50%;bottom:max(28px,calc(env(safe-area-inset-bottom) + 16px));transform:translate(-50%);z-index:1100;background:var(--ink);color:#fff;font-weight:700;font-size:14px;padding:12px 22px;border-radius:var(--r-pill);box-shadow:var(--shadow-lg);animation:toast-in .3s cubic-bezier(.16,1,.3,1)}.toast.hide{animation:toast-out .3s ease forwards}@keyframes toast-in{0%{opacity:0;transform:translate(-50%,14px)}to{opacity:1;transform:translate(-50%)}}@keyframes toast-out{0%{opacity:1}to{opacity:0;transform:translate(-50%,10px)}}.lb-tabs{margin-top:14px}.lb-sub{margin:0 0 12px;font-size:12.5px;font-weight:600;color:var(--muted);text-align:center}.lb-list{display:flex;flex-direction:column;gap:4px;max-height:56vh;overflow-y:auto}.lb-row{display:grid;grid-template-columns:38px 1fr auto;align-items:center;gap:12px;padding:10px 14px;border-radius:var(--r-sm);background:var(--surface-2)}.lb-row.me{background:var(--accent-soft);box-shadow:inset 0 0 0 1.5px #12b88659}.lb-rank{font-weight:800;color:var(--muted);font-variant-numeric:tabular-nums;font-size:14px}.lb-row.top1 .lb-rank{color:#d9a200}.lb-row.top2 .lb-rank{color:#9aa6ad}.lb-row.top3 .lb-rank{color:#c08a4a}.lb-name{font-weight:700;font-size:14.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lb-name .you{color:var(--accent-deep);font-weight:700;font-size:11px;margin-left:6px}.lb-score{font-weight:800;font-variant-numeric:tabular-nums;font-size:15px;white-space:nowrap}.lb-score small{color:var(--faint);font-weight:600;font-size:11px;margin-left:2px}.lb-me{margin-top:10px}.lb-empty{color:var(--muted);font-size:14px;text-align:center;padding:28px 0}@media(max-width:560px){.account-bar{top:max(12px,env(safe-area-inset-top));right:max(12px,env(safe-area-inset-right))}.leaderboard-bar{top:max(12px,env(safe-area-inset-top));left:max(12px,env(safe-area-inset-left))}.account-btn{padding:8px 14px;font-size:13.5px}.screen.center{padding-top:calc(env(safe-area-inset-top,0px) + 58px)}}
