:root{--bg: #0f172a;--card: #111827;--accent: #2dd4bf;--relay: #1d4ed8;--friend: #16a34a;--muted: #94a3b8;--border: rgba(255, 255, 255, .08);--shadow: 0 12px 32px rgba(0, 0, 0, .35)}*{box-sizing:border-box}body{margin:0;padding:0;font-family:Manrope,Noto Sans SC,Segoe UI,Helvetica Neue,sans-serif;background:radial-gradient(circle at 20% 20%,rgba(45,212,191,.08),transparent 35%),radial-gradient(circle at 80% 0%,rgba(37,99,235,.12),transparent 40%),var(--bg);color:#e2e8f0}body.announcement-open{overflow:hidden}#map{height:100vh;width:100%}.announcement-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2200;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(circle at top,rgba(45,212,191,.12),transparent 32%),#030712b8;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);opacity:0;pointer-events:none;transition:opacity .2s ease}.announcement-overlay.open{opacity:1;pointer-events:auto}.announcement-card{width:min(520px,100%);border-radius:20px;border:1px solid rgba(148,163,184,.16);background:linear-gradient(180deg,#111827fa,#0b1221f5);box-shadow:0 28px 80px #0000008c;padding:24px 24px 20px;position:relative;overflow:hidden}.announcement-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at top right,rgba(45,212,191,.12),transparent 28%),radial-gradient(circle at bottom left,rgba(252,211,77,.08),transparent 30%);pointer-events:none}.announcement-card>*{position:relative;z-index:1}.announcement-badge{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:999px;background:#2dd4bf1f;border:1px solid rgba(45,212,191,.25);color:#a7f3d0;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.announcement-title{margin:14px 0 10px;font-size:22px;line-height:1.35;color:#e0f2fe}.announcement-body{margin:0;color:#cbd5e1;line-height:1.8;font-size:15px}.announcement-body strong{color:#fcd34d}.announcement-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px}.announcement-link,.announcement-btn{min-height:44px;padding:0 16px;border-radius:12px;border:1px solid transparent;font-size:14px;font-weight:700;text-decoration:none;cursor:pointer;transition:transform .15s ease,background .15s ease,border-color .15s ease,box-shadow .15s ease}.announcement-link{display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#22d3ee,#0ea5e9);color:#f8fafc;box-shadow:0 10px 28px #0ea5e947;min-width:132px}.announcement-link:hover{transform:translateY(-1px);box-shadow:0 14px 34px #0ea5e95c}.announcement-btn.secondary{background:#ffffff0a;border-color:var(--border);color:#e2e8f0}.announcement-btn.secondary:hover{background:#ffffff14}.announcement-btn.ghost{background:#fcd34d1a;border-color:#fcd34d4d;color:#fde68a}.announcement-btn.ghost:hover{background:#fcd34d29}.announcement-link:focus-visible,.announcement-btn:focus-visible{outline:none;box-shadow:0 0 0 3px #2dd4bf40}.announcement-footnote{margin:14px 0 0;color:var(--muted);font-size:12px;line-height:1.6;word-break:break-all}.announcement-footnote span{color:#a5f3fc}.cq-overlay{position:absolute;top:16px;left:50%;transform:translate(-50%);width:min(360px,calc(100vw - 32px));z-index:1200;display:flex;flex-direction:column;gap:10px;pointer-events:none}.cq-card{background:#111827f2;border:1px solid var(--border);border-radius:16px;padding:14px 16px;box-shadow:var(--shadow);animation:cq-slide 8s ease forwards}.cq-canvas{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:950}.cq-card h4{margin:0;font-size:15px;color:#fcd34d;letter-spacing:1px}.cq-card p{margin:6px 0 0;color:#e2e8f0;font-size:13px}.cq-card b{font-weight:800}.cq-card .purple{color:#c084fc;font-weight:700}.cq-card span{color:#94a3b8;font-size:12px}.cq-wave-icon{pointer-events:none!important}.cq-wave{width:60px;height:60px;border-radius:50%;border:2px solid rgba(252,211,77,.8);background:#fcd34d40;animation:cq-wave 3s ease-out forwards}@keyframes cq-wave{0%{transform:scale(.4);opacity:.9}to{transform:scale(1.6);opacity:0}}@keyframes cq-slide{0%{transform:translateY(-20px);opacity:0}15%{transform:translateY(0);opacity:1}80%{opacity:1}to{transform:translateY(-20px);opacity:0}}.panel{position:absolute;top:16px;left:16px;z-index:1000;display:flex;gap:12px;flex-wrap:wrap;max-width:420px;transition:transform .25s ease,opacity .25s ease}.mode-toggle{position:absolute;top:16px;right:16px;width:44px;height:44px;border-radius:12px;border:1px solid var(--border);background:var(--card);color:#e2e8f0;box-shadow:var(--shadow);cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:1000}.mode-toggle svg{pointer-events:none}.mode-menu{position:absolute;top:66px;right:16px;width:170px;background:var(--card);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow);padding:8px;display:none;z-index:1000}.mode-menu.open{display:block}.mode-option{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;border-radius:8px;cursor:pointer;color:#e2e8f0;font-size:14px}.mode-option:hover{background:#ffffff0d}.mode-option.active{border:1px solid var(--accent);background:#2dd4bf1f}.mode-subtitle{color:var(--muted);font-size:12px}.panel.mobile-hidden{opacity:0;pointer-events:none;transform:translateY(-16px)}.panel-toggle{position:absolute;top:16px;left:16px;width:44px;height:44px;border-radius:12px;border:1px solid var(--border);background:var(--card);color:#e2e8f0;box-shadow:var(--shadow);cursor:pointer;display:none;align-items:center;justify-content:center;font-size:18px;z-index:1100}.panel-toggle.open{border-color:var(--accent)}.card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:12px 14px;box-shadow:var(--shadow);min-width:280px}.title{font-weight:700;letter-spacing:.4px;margin:0 0 4px;color:#e0f2fe}.subtitle{margin:0;color:var(--muted);font-size:13px}.search-box{margin-top:10px;display:flex;flex-direction:column;gap:8px}.search-input{width:100%;padding:10px 12px;border-radius:10px;border:1px solid var(--border);background:#ffffff0a;color:#e2e8f0;outline:none;font-size:14px}.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #2dd4bf26}.search-results{width:100%;background:var(--card);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow);max-height:360px;min-height:140px;overflow-y:auto;padding:4px 0}.search-item{padding:10px 12px;cursor:pointer;border-bottom:1px solid var(--border);font-size:14px;color:#e2e8f0}.search-item:last-child{border-bottom:none}.search-item:hover{background:#ffffff0a}.search-item.active{background:#2dd4bf1f;box-shadow:0 0 0 2px var(--accent) inset}.search-item span{color:var(--muted);margin-left:8px;font-size:12px}.search-empty{padding:14px;color:var(--muted);font-size:13px;text-align:center}.leaflet-container{font-family:inherit}.leaflet-container .leaflet-control-attribution{background:#111827d9;color:var(--muted);border-radius:8px;border:1px solid var(--border)}.leaflet-control-attribution a{color:#e2e8f0;text-decoration:none}.leaflet-popup-content-wrapper{border-radius:12px;box-shadow:var(--shadow);background:#0b1221;border:1px solid var(--border)}.leaflet-popup-content{margin:12px;min-width:260px}.leaflet-control-zoom{display:none!important}.zoom-stack{position:absolute;right:12px;bottom:80px;z-index:1000;display:flex;flex-direction:column;gap:10px}.zoom-btn{width:46px;height:46px;border-radius:14px;background:#0b1324;color:#e2e8f0;border:1px solid var(--border);box-shadow:var(--shadow);display:flex;align-items:center;justify-content:center;cursor:pointer}.zoom-btn:hover{background:#ffffff14}.zoom-btn svg{pointer-events:none}.popup-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.popup-title{margin:0;font-size:18px;color:#bfdbfe}.chip{padding:4px 8px;font-size:12px;border-radius:999px;border:1px solid var(--border);background:#2dd4bf1f;color:#a5f3fc}.popup-sub{margin:0 0 10px;color:var(--muted);font-size:13px}.info-box{background:#111827;border-left:4px solid var(--friend);padding:10px 12px;border-radius:10px;color:#e2e8f0;font-size:14px;display:grid;gap:6px}.green{color:#34d399}.purple{color:#c084fc}.gray{color:var(--muted);font-size:12px}.popup-footer{text-align:right;color:var(--muted);font-size:12px;margin-top:8px}.block-info{background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:8px;padding:8px 10px;margin:8px 0;display:flex;flex-wrap:wrap;gap:6px;align-items:center;font-size:12px}.block-tag{background:#ef44444d;color:#fca5a5;padding:2px 8px;border-radius:4px;font-weight:600}.block-reason{color:#fca5a5}.block-date{color:var(--muted);margin-left:auto}.stats{display:flex;gap:14px;margin-top:10px;font-size:13px;color:var(--muted);align-items:center;flex-wrap:wrap}.stat-item{display:flex;align-items:center;gap:6px;background:#ffffff08;border:1px solid var(--border);border-radius:8px;padding:6px 10px}.stat-item input[type=checkbox]{width:14px;height:14px;accent-color:var(--accent)}.stats strong{color:#e2e8f0;margin-left:4px}@media (max-width: 640px){.panel{top:72px;left:12px;right:12px;margin:0 auto;width:min(420px,calc(100vw - 24px))}.panel-toggle{display:flex}.cq-overlay{top:72px;width:min(320px,calc(100vw - 32px))}.announcement-overlay{padding:16px;align-items:flex-end}.announcement-card{width:100%;padding:20px 18px 18px;border-radius:18px}.announcement-title{font-size:19px}.announcement-body{font-size:14px}.announcement-actions{flex-direction:column}.announcement-link,.announcement-btn{width:100%}}
