*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;height:100%;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}#app{position:fixed;inset:0;width:100dvw;height:100dvh}:root{--nb-h: 52px}#navbar{position:absolute;top:0;left:0;right:0;height:var(--nb-h);background:#fffffff7;backdrop-filter:blur(6px);display:flex;align-items:center;flex-wrap:nowrap;padding:0 12px 0 16px;gap:8px;z-index:20;box-shadow:0 2px 8px #00000026}#navbar-left{flex:1 1 auto;min-width:0;overflow:hidden}#app-title{font-weight:700;font-size:14px;color:#1a1a2e;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.title-short{display:none}.nav-tab{display:inline-flex;align-items:center;height:44px;padding:0 16px;border-radius:22px;font-size:13px;font-weight:600;text-decoration:none;border:2px solid #1a1a2e;color:#1a1a2e;background:transparent;transition:background .15s,color .15s;white-space:nowrap;-webkit-tap-highlight-color:transparent}.nav-tab.active{background:#1a1a2e;color:#fff}.nav-tab.hidden-tab{display:none}#pin-count{font-size:12px;color:#666;white-space:nowrap;flex-shrink:0}#map{position:absolute;top:var(--nb-h);left:0;right:0;bottom:0}#legend{position:absolute;top:calc(var(--nb-h) + 22px);left:10px;background:#ffffffeb;border-radius:8px;padding:8px 12px;box-shadow:0 2px 8px #0000002e;z-index:10;backdrop-filter:blur(4px)}.legend-item{display:flex;align-items:center;gap:7px;font-size:11px;color:#333;line-height:1.3;padding:2px 0}.legend-dot{width:11px;height:11px;border-radius:50%;flex-shrink:0;border:2px solid white;box-shadow:0 1px 3px #0000004d}#popup{position:absolute;bottom:24px;left:50%;transform:translate(-50%);background:#fff;border-radius:10px;padding:16px 20px;min-width:260px;max-width:min(90vw,400px);max-height:50vh;overflow-y:auto;box-shadow:0 4px 20px #00000040;z-index:20}#popup.hidden{display:none}#popup-close{position:absolute;top:8px;right:10px;background:none;border:none;font-size:20px;cursor:pointer;color:#666;line-height:1}.popup-badge{display:inline-block;font-size:11px;font-weight:600;padding:2px 8px;border-radius:10px;margin-bottom:8px}.badge-wigle-or{background:#fff3e0;color:#b47000}.badge-cityroam{background:#e3f2fd;color:#004f80}.badge-wigle-eduroam{background:#fce4f3;color:#7a3060}.badge-eduroam-official{background:#e0f5ee;color:#005c40}.badge-opshort{background:#ff9800;color:#fff;font-size:10px;margin-left:4px}#popup-content table{width:100%;border-collapse:collapse;font-size:13px}#popup-content tr:not(:last-child) td{border-bottom:1px solid #f0f0f0}#popup-content td{padding:5px 4px;vertical-align:top}#popup-content td:first-child{font-weight:600;color:#555;width:40%;padding-right:8px}#geolocate-btn{position:absolute;right:10px;bottom:210px;z-index:10;width:40px;height:40px;border-radius:4px;border:none;background:#fff;box-shadow:0 0 0 2px #0000001a;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;-webkit-tap-highlight-color:transparent}#geolocate-btn:hover{background:#f0f0f0}#geolocate-btn svg{display:block;margin:auto}@keyframes spin{to{transform:rotate(360deg)}}#geolocate-btn.loading svg{animation:spin .8s linear infinite}#find-nearest-btn{position:absolute;right:10px;bottom:160px;z-index:10;width:40px;height:40px;border-radius:4px;border:none;background:#fff;box-shadow:0 0 0 2px #0000001a;cursor:not-allowed;display:flex;align-items:center;justify-content:center;padding:0;opacity:.4;-webkit-tap-highlight-color:transparent;transition:opacity .2s}#find-nearest-btn.active{cursor:pointer;opacity:1}#find-nearest-btn.active:hover{background:#f0f0f0}#find-nearest-btn svg text{font-family:-apple-system,BlinkMacSystemFont,Hiragino Sans,Yu Gothic,sans-serif}#find-nearest-btn svg{display:block;margin:auto}#nearest-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:20;background:#fffffff7;border-radius:16px;padding:24px;text-align:center;box-shadow:0 4px 20px #0000004d;min-width:200px}#nearest-overlay.hidden{display:none}#nearest-arrow{font-size:64px;margin:8px 0;line-height:1;display:inline-block}#nearest-direction{font-size:20px;font-weight:700;color:#1a1a2e}#nearest-distance{font-size:14px;color:#666;margin:4px 0}#nearest-name{font-size:12px;color:#999;margin:4px 0}.nearest-btns{display:flex;gap:8px;margin-top:16px;justify-content:center}#nearest-go-btn{background:#0072b2;color:#fff;border:none;border-radius:8px;padding:10px 20px;font-size:14px;cursor:pointer;-webkit-tap-highlight-color:transparent}#nearest-go-btn:hover{background:#005a8e}#nearest-close-btn{background:#eee;color:#333;border:none;border-radius:8px;padding:10px 20px;font-size:14px;cursor:pointer;-webkit-tap-highlight-color:transparent}#nearest-close-btn:hover{background:#ddd}.popup-go-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;margin-top:12px;padding:10px;background:#4a90e2;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:700;cursor:pointer;-webkit-tap-highlight-color:transparent}.popup-go-btn:hover{background:#357abd}.pin-marker{width:26px;height:26px;border:3px solid white;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 3px 10px #00000059;cursor:pointer;transition:transform .12s ease}.pin-marker:active{transform:scale(1.25)}.pin-marker svg{width:14px;height:14px;display:block}.cluster-marker{border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .12s ease}.cluster-marker:active{transform:scale(1.15)}.cluster-ring{position:absolute;inset:0;border-radius:50%;opacity:.35}.cluster-inner{position:relative;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;box-shadow:0 3px 10px #0000004d;line-height:1}#menu-btn{background:none;border:none;cursor:pointer;color:#555;padding:0 5px;line-height:1;border-radius:4px;-webkit-tap-highlight-color:transparent;transition:background .15s;flex-shrink:0;display:flex;align-items:center;justify-content:center}#menu-btn:hover{background:#00000012}#menu-btn.active{color:#0072b2}#menu-panel{position:absolute;top:var(--nb-h);right:0;width:min(90vw,420px);max-height:80vh;background:#fffffff7;border-radius:0 0 0 10px;box-shadow:-4px 4px 20px #0003;z-index:30;display:flex;flex-direction:column;overflow:hidden}#menu-panel.hidden{display:none}#menu-panel-close{position:absolute;top:8px;right:10px;background:none;border:none;font-size:22px;line-height:1;color:#888;cursor:pointer;padding:4px 6px;border-radius:4px;-webkit-tap-highlight-color:transparent;z-index:1}#menu-panel-close:hover{background:#f0f0f0;color:#222}#menu-panel-content{overflow-y:auto;padding:20px 20px 24px;-webkit-overflow-scrolling:touch}.member-row{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;margin-bottom:4px;border:1px solid #e0e0e0;border-radius:8px;background:#fafbfc;font-size:13px;gap:12px}.member-row .mr-left{text-align:left;flex:1;min-width:0}.member-row .mr-name{color:#1a1a2e;font-weight:600}.member-row .mr-name-en{color:#888;font-size:11px;margin-top:1px}.member-row .mr-counts{text-align:right;white-space:nowrap;font-size:14px;font-weight:700;flex-shrink:0;padding-left:12px;border-left:2px solid #ddd}.member-row .mr-counts .or{color:#0072b2}.member-row .mr-counts .edu{color:#009e73}.member-row .mr-date{color:#aaa;font-size:11px;margin-top:2px}.info-panel-title{font-size:15px;font-weight:700;color:#1a1a2e;margin:0 28px 12px 0;padding-bottom:8px;border-bottom:2px solid #e8e8e8}.info-section{margin-bottom:16px}.info-section:last-child{margin-bottom:0}.info-section-title{font-size:12px;font-weight:700;color:#888;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.info-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px 12px}.info-stat{display:flex;flex-direction:column;gap:2px}.info-stat-label{font-size:11px;font-weight:600}.info-stat-date{font-size:10px;font-weight:400;opacity:.65}.info-stat-val{font-size:18px;font-weight:700;color:#1a1a2e}.info-scan-rows{display:flex;flex-direction:column;gap:4px}.info-scan-row{display:flex;justify-content:space-between;align-items:baseline;font-size:13px}.info-scan-label{color:#666}.info-scan-val{font-weight:600;color:#1a1a2e;text-align:right}.info-minimap-legend{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px;font-size:11px;color:#666;align-items:center}.iml-dot{display:inline-block;width:12px;height:12px;border-radius:2px;margin-right:3px;vertical-align:middle;box-sizing:border-box}#faq-btn{background:none;border:none;cursor:pointer;color:#555;padding:0 5px;line-height:1;border-radius:4px;-webkit-tap-highlight-color:transparent;transition:background .15s;flex-shrink:0;display:flex;align-items:center;justify-content:center}#faq-btn:hover{background:#00000012}#faq-btn.active{color:#0072b2}#faq-btn.hidden{display:none}#faq-overlay{position:fixed;inset:0;z-index:200;background:#00000080;display:flex;align-items:center;justify-content:center;padding:16px}#faq-overlay.hidden{display:none}#faq-modal{position:relative;background:#fff;border-radius:12px;width:100%;max-width:640px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 8px 40px #00000059;overflow:hidden}#faq-close{position:absolute;top:10px;right:12px;background:none;border:none;font-size:24px;line-height:1;color:#666;cursor:pointer;z-index:1;padding:4px 6px;border-radius:4px;-webkit-tap-highlight-color:transparent}#faq-close:hover{background:#f0f0f0;color:#222}#faq-content{overflow-y:auto;padding:24px 24px 28px;-webkit-overflow-scrolling:touch}#faq-title{font-size:17px;font-weight:700;color:#1a1a2e;margin:0 32px 6px 0;padding-bottom:10px;border-bottom:2px solid #e8e8e8}.faq-credit{font-size:13px;color:#555;margin:8px 0 4px}.faq-credit a{color:#0072b2;text-decoration:none}.faq-credit a:hover{text-decoration:underline}.faq-official{font-size:13px;color:#555;margin:4px 0 16px}.faq-official a{color:#0072b2;text-decoration:none}.faq-official a:hover{text-decoration:underline}#faq-page-openroaming.hidden,#faq-page-eduroam.hidden{display:none}.faq-item{margin-bottom:18px;padding-bottom:18px;border-bottom:1px solid #f0f0f0}.faq-item:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.faq-q{font-size:14px;font-weight:700;color:#cc79a7;margin:0 0 8px;line-height:1.5}.faq-a{font-size:13px;color:#444;line-height:1.7;margin:0 0 6px}.faq-a:last-child{margin-bottom:0}.faq-a a{color:#0072b2;text-decoration:none}.faq-a a:hover{text-decoration:underline}@media(max-width:480px){#faq-modal{max-height:85vh;border-radius:10px}#faq-content{padding:18px 16px 22px}}
