:root{--sr-green:#1f8a4c;--sr-red:#c8102e;--sr-gold:#ffcf2e;--water:#0a86d6;--water-d:#0066ad;--sev-light:#f7b500;--sev-moderate:#f37121;--sev-severe:#e0301e;--safe:#1f8a4c;--bg:#eef3f8;--card:#fff;--ink:#0f1b2d;--muted:#5d6b82;--line:#e2e8f1;--shadow:0 6px 22px rgba(16,33,61,.1);--radius:18px}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}body,html{margin:0;padding:0}body{background:var(--bg);color:var(--ink);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;overscroll-behavior-y:none}a{color:inherit;text-decoration:none}button{font-family:inherit}:focus-visible{outline:3px solid var(--water);outline-offset:2px;border-radius:6px}@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}.app{max-width:480px;margin:0 auto;min-height:100dvh;display:flex;flex-direction:column;background:var(--bg);position:relative}.app-header{position:-webkit-sticky;position:sticky;top:0;z-index:40;justify-content:space-between;padding:calc(env(safe-area-inset-top) + 12px) 16px 12px;background:linear-gradient(120deg,var(--sr-green),var(--water));color:#fff}.app-header,.app-header .brand{display:flex;align-items:center}.app-header .brand{gap:9px;font-weight:800;font-size:19px;letter-spacing:.2px}.app-header .brand small{display:block;font-weight:500;font-size:11px;opacity:.9;letter-spacing:0}.flag-accent{height:4px;background:linear-gradient(to right,var(--sr-green) 0 20%,#fff 20% 30%,var(--sr-red) 30% 70%,#fff 70% 80%,var(--sr-green) 80% 100%)}.content{flex:1 1;padding:16px 16px 92px}.content.flush{padding:0 0 76px}.langs{display:flex;gap:4px;background:hsla(0,0%,100%,.18);border-radius:999px;padding:3px}.langs button{border:0;background:transparent;color:#fff;opacity:.7;font-weight:700;font-size:12px;padding:5px 9px;border-radius:999px;cursor:pointer}.langs button.on{background:#fff;color:var(--water-d);opacity:1}.tabbar{position:fixed;left:50%;transform:translateX(-50%);bottom:0;width:100%;max-width:480px;z-index:50;display:grid;grid-template-columns:1fr 1fr 1.1fr 1fr 1fr;align-items:end;background:var(--card);border-top:1px solid var(--line);padding:8px 0 calc(env(safe-area-inset-bottom) + 8px);box-shadow:0 -4px 20px rgba(16,33,61,.08)}.tab{display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--muted);font-size:10px;font-weight:600}.tab.on{color:var(--water-d)}.tab svg{width:24px;height:24px}.tab-fab{align-self:start;margin-top:-26px}.tab-fab .fab{width:62px;height:62px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(140deg,var(--sr-red),#ff5a3c);color:#fff;box-shadow:0 8px 20px rgba(200,16,46,.4);border:4px solid var(--card)}.tab-fab .fab svg{width:28px;height:28px}.tab-fab span{display:block;text-align:center;font-size:11px;font-weight:700;color:var(--sr-red);margin-top:4px}h1{font-size:23px;line-height:1.2;margin:6px 0 4px;font-weight:800}.sub{color:var(--muted);font-size:14px;margin:0 0 16px}.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px}.card+.card{margin-top:12px}.hero{border-radius:var(--radius);padding:18px;color:#fff;box-shadow:var(--shadow);display:flex;align-items:center;gap:14px}.hero.clear{background:linear-gradient(135deg,var(--sr-green),#2bb673)}.hero.alert{background:linear-gradient(135deg,var(--sev-moderate),var(--sev-severe))}.hero .big{font-size:34px;font-weight:900;line-height:1}.hero .lbl{font-size:14px;font-weight:600;opacity:.95}.mapwrap{position:relative;height:380px}.map{position:absolute;inset:0;width:100%;height:100%}.maplibregl-canvas,.maplibregl-map{width:100%!important;height:100%!important}.maplibregl-popup-content{border-radius:12px;font-family:inherit;padding:10px 12px}.row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--line)}.row:last-child{border-bottom:0}.row .rowicon{font-size:18px;flex:none}.row .road{font-weight:700;font-size:15px}.row .meta{color:var(--muted);font-size:12px}.sevdot{width:12px;height:12px;border-radius:50%;flex:none}.sev-light{background:var(--sev-light)}.sev-moderate{background:var(--sev-moderate)}.sev-severe{background:var(--sev-severe)}.pill{margin-left:auto;font-weight:800;font-size:13px;padding:5px 11px;border-radius:999px;background:#eef3f8;color:var(--ink)}.field{position:relative}input.search{width:100%;padding:14px 16px;border-radius:14px;border:1.5px solid var(--line);background:#fff;color:var(--ink);font-size:16px;outline:none}input.search:focus{border-color:var(--water)}.results{margin-top:6px;border-radius:14px;overflow:hidden;box-shadow:var(--shadow)}.results button{display:block;width:100%;text-align:left;background:#fff;border:0;border-bottom:1px solid var(--line);color:var(--ink);padding:14px 16px;cursor:pointer;font-size:15px}.results button:active{background:#eef6fd}.results button:last-child{border-bottom:0}.type-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:10px;gap:10px}.type-opt{display:flex;align-items:center;gap:10px;padding:14px;border-radius:14px;border:2px solid var(--line);background:#fff;cursor:pointer;font-size:14px;font-weight:700}.type-opt .emoji{font-size:20px}.type-opt.on{border-color:var(--water);background:#eef6fd}.sev-grid{display:grid;grid-gap:10px;gap:10px;margin-top:6px}.sev-opt{display:flex;align-items:center;gap:12px;width:100%;text-align:left;padding:14px;border-radius:14px;border:2px solid var(--line);background:#fff;cursor:pointer;font-size:15px;font-weight:600}.sev-opt .ic{width:14px;height:14px;border-radius:50%;flex:none}.sev-opt.on{border-color:var(--water);background:#eef6fd}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;background:var(--water);color:#fff;border:0;border-radius:14px;padding:16px;font-size:16px;font-weight:800;cursor:pointer}.btn:disabled{opacity:.45}.btn.red{background:var(--sr-red)}.btn.green{background:var(--sr-green)}.btn.wa{background:#25d366}.btn.ghost{background:#fff;color:var(--ink);border:1.5px solid var(--line)}.btn-row{display:flex;gap:10px;margin-top:12px}.btn-row .btn{width:auto;flex:1 1}.chip{display:inline-flex;align-items:center;gap:5px;background:#eef3f8;border-radius:999px;padding:5px 11px;font-weight:600}.chip,.note{font-size:13px}.note{color:var(--muted);margin-top:10px}.center{text-align:center}.big-count{font-size:64px;font-weight:900;line-height:1}.legend{display:flex;gap:14px;font-size:12px;color:var(--muted);padding:10px 16px 0;flex-wrap:wrap}.legend span{display:inline-flex;align-items:center;gap:5px}.skel{background:linear-gradient(90deg,#e9eef5,#f4f8fc,#e9eef5);background-size:200% 100%;animation:sh 1.2s infinite;border-radius:10px}@keyframes sh{0%{background-position:200% 0}to{background-position:-200% 0}}.confetti{position:fixed;inset:0;pointer-events:none;z-index:999;overflow:hidden}.confetti span{position:absolute;top:-40px;animation-name:fall;animation-timing-function:ease-in;animation-fill-mode:forwards}@keyframes fall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(105vh) rotate(var(--rot));opacity:.9}}.level-card{background:linear-gradient(135deg,var(--water),var(--sr-green));color:#fff;border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}.level-card .lv{font-size:13px;opacity:.9;font-weight:600}.level-card .lvname{font-size:26px;font-weight:900;margin:2px 0 12px}.bar{height:10px;background:hsla(0,0%,100%,.3);overflow:hidden}.bar,.bar>i{border-radius:999px}.bar>i{display:block;height:100%;background:var(--sr-gold);transition:width .6s ease}.stat-row{display:flex;gap:10px;margin-top:12px}.stat{flex:1 1;background:var(--card);border-radius:14px;padding:12px;text-align:center;box-shadow:var(--shadow)}.stat .n{font-size:24px;font-weight:900}.stat .l{font-size:11px;color:var(--muted);font-weight:600}.badge-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:10px;gap:10px}.badge-item{background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px 8px;text-align:center}.badge-item.locked{opacity:.35;filter:grayscale(1)}.badge-item .be{font-size:28px}.badge-item .bl{font-size:11px;font-weight:600;margin-top:4px}.lb-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--line)}.lb-row:last-child{border-bottom:0}.lb-row.me{background:#eef6fd;margin:0 -16px;padding:12px 16px;border-radius:12px}.lb-rank{font-weight:900;width:30px;text-align:center;color:var(--muted)}.lb-rank.top{color:var(--sr-gold);font-size:18px}.nameinput{display:flex;gap:8px}.nameinput input{flex:1 1}.pin{display:grid;place-items:center;cursor:pointer;animation:pop .4s cubic-bezier(.2,1.4,.4,1)}.pin .bubble{width:38px;height:38px;border-radius:50% 50% 50% 8px;transform:rotate(45deg);display:grid;place-items:center;box-shadow:0 3px 8px rgba(0,0,0,.3);border:2px solid #fff}.pin .bubble span{transform:rotate(-45deg);font-size:18px}.pin .cnt{position:absolute;top:-6px;right:-6px;background:#111;color:#fff;font-size:10px;font-weight:800;border-radius:999px;padding:1px 5px;border:1.5px solid #fff}.pin.sev-severe .bubble{background:var(--sev-severe);animation:pulse 1.2s infinite}.pin.sev-moderate .bubble{background:var(--sev-moderate)}.pin.sev-light .bubble{background:var(--sev-light)}@keyframes pop{0%{transform:scale(0)}to{transform:scale(1)}}@keyframes pulse{0%,to{box-shadow:0 3px 8px rgba(224,48,30,.5)}50%{box-shadow:0 0 0 8px rgba(224,48,30,0)}}.popbtns{display:flex;flex-direction:column;gap:6px;margin-top:8px}.popbtns a,.popbtns button{border:0;border-radius:8px;padding:7px 10px;font-weight:700;font-size:13px;cursor:pointer;text-align:center}.popbtns .pc{background:var(--safe);color:#fff}.popbtns .pg{background:#6b7280;color:#fff}.popbtns .ps{background:#25d366;color:#fff}.toast{position:fixed;left:50%;bottom:96px;transform:translateX(-50%);background:#111;color:#fff;padding:10px 18px;border-radius:999px;font-weight:800;z-index:800;box-shadow:var(--shadow);animation:pop .3s}.filters{display:flex;gap:8px;overflow-x:auto;padding:2px 0 4px;-webkit-overflow-scrolling:touch;scrollbar-width:none}.filters::-webkit-scrollbar{display:none}.fchip{flex:none;display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:999px;border:1.5px solid var(--line);background:#fff;color:var(--ink);font-size:13px;font-weight:700;cursor:pointer;white-space:nowrap}.fchip.on{background:var(--water);border-color:var(--water);color:#fff}.fchip.allchip.on{background:var(--ink);border-color:var(--ink)}.maprow{display:flex;justify-content:space-between;padding:8px 14px 12px;color:var(--muted)}.maprow,.refresh-btn{align-items:center;font-size:12px}.refresh-btn{display:inline-flex;gap:5px;border:1px solid var(--line);background:#fff;color:var(--ink);border-radius:999px;padding:6px 12px;font-weight:700;cursor:pointer}.refresh-btn:active{transform:scale(.96)}.errbox{text-align:center;padding:8px 0}.errbox .btn{width:auto;display:inline-flex;margin-top:8px;padding:10px 18px}.desk-nav{display:none}.home-grid{display:grid;grid-gap:12px;gap:12px}.home-hero{grid-area:hero}.home-map{grid-area:map}.home-list{grid-area:list}@media (min-width:880px){.app{max-width:1180px;min-height:100dvh}.app-header{padding:14px 28px}.app-header .brand{font-size:22px}.desk-nav{display:flex;align-items:center;gap:6px;margin-left:auto;margin-right:18px}.desk-nav a{color:hsla(0,0%,100%,.85);font-weight:700;font-size:14px;padding:8px 14px;border-radius:999px}.desk-nav a:hover{background:hsla(0,0%,100%,.15);color:#fff}.desk-nav a.on{background:#fff;color:var(--water-d)}.desk-nav a.report{background:var(--sr-red);color:#fff}.desk-nav a.report:hover{filter:brightness(1.08)}.tabbar{display:none}.content{padding:24px 28px 40px}.home-grid{grid-template-columns:1fr 380px;grid-template-areas:"hero hero" "map list";gap:18px;align-items:start}.home-map .mapwrap{height:calc(100dvh - 230px);min-height:460px}.home-list{position:-webkit-sticky;position:sticky;top:92px;max-height:calc(100dvh - 130px);overflow:auto;margin:0}.content>.sub,.content>h1{max-width:720px}.type-grid{grid-template-columns:repeat(3,1fr)}h1{font-size:28px}}@media (min-width:1240px){.home-grid{grid-template-columns:1fr 420px}}