:root{--bg-primary:#0f1923;--bg-secondary:#1a2332;--bg-panel:#1a2332d9;--text-primary:#fff;--text-secondary:#a0aec0;--text-muted:#718096;--accent:#00bcd4;--accent-hover:#00acc1;--border-color:#ffffff1a;--glass-shadow:0 8px 32px 0 #0000005e;--font-family:"Noto Sans SC", system-ui, -apple-system, sans-serif}body.light-theme{--bg-primary:#f5f7fa;--bg-secondary:#fff;--bg-panel:#ffffffe6;--text-primary:#1a202c;--text-secondary:#4a5568;--text-muted:#a0aec0;--accent:#0097a7;--accent-hover:#00838f;--border-color:#0000001a;--glass-shadow:0 4px 16px 0 #0000001a}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;overflow:hidden}#root{flex-direction:column;width:100vw;height:100vh;display:flex}.custom-marker{color:#fff;cursor:pointer;text-shadow:0 1px 2px #000c;border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;font-size:14px;font-weight:700;transition:transform .2s,z-index;display:flex;box-shadow:0 4px 6px #0000004d,inset 0 0 0 2px #ffffff4d}.custom-marker:hover{z-index:999!important;transform:scale(1.5)!important}.glass-panel{background:var(--bg-panel);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-color);box-shadow:var(--glass-shadow)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.amap-sug-result{color:#fff!important;-webkit-backdrop-filter:blur(12px)!important;background:#1a2332eb!important;border:1px solid #ffffff1a!important;border-radius:8px!important;padding:4px 0!important;box-shadow:0 4px 16px #00000080!important}.auto-item{transition:background .2s;color:#fff!important;padding:8px 12px!important}.auto-item:hover{color:var(--accent)!important;background:#ffffff1a!important}.auto-item .auto-item-span{color:#a0aec0!important}body.light-theme .amap-sug-result{color:#1a202c!important;background:#fffffff2!important;border:1px solid #0000001f!important;box-shadow:0 4px 16px #00000026!important}body.light-theme .auto-item{color:#1a202c!important}body.light-theme .auto-item:hover{color:#0097a7!important;background:#0000000f!important}body.light-theme .auto-item .auto-item-span{color:#718096!important}.map-container{flex:1;width:100%;height:100%;position:relative}.amap-container{width:100%;height:100%}.amap-logo,.amap-copyright{display:none!important}.user-loc-marker{width:24px;height:24px;position:relative}.user-loc-core{z-index:2;background:#ff3d00;border:2px solid #fff;border-radius:50%;width:16px;height:16px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 4px #00000080}.user-loc-pulse{z-index:1;background:#ff3d0066;border-radius:50%;width:48px;height:48px;animation:1.5s infinite pulse;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}@media (width<=768px){.amap-toolbar{bottom:140px!important;right:10px!important}.amap-scalecontrol{bottom:130px!important;left:10px!important}.custom-marker{width:26px;height:26px;font-size:12px}}.search-bar{width:100%;position:relative}.search-input{border:1px solid var(--border-color);width:100%;color:var(--text-primary);background:#ffffff0d;border-radius:8px;outline:none;padding:10px 14px 10px 36px;font-size:14px;transition:all .2s}.search-input:focus{border-color:var(--accent);background:#ffffff1a;box-shadow:0 0 0 2px #00bcd433}.search-icon{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.clear-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:4px;display:flex;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.clear-btn:hover{color:var(--text-primary);background:#ffffff1a}@media (width<=768px){.search-input{padding:12px 14px 12px 38px;font-size:16px}}.sidebar{border-right:1px solid var(--border-color);background:var(--bg-primary);flex-direction:column;flex:1;width:100%;min-height:0;display:flex}.sidebar-header{border-bottom:1px solid var(--border-color);background:var(--bg-secondary);flex-shrink:0;padding:20px}.sidebar-header h1{color:var(--accent);align-items:center;gap:8px;margin-bottom:12px;font-size:1.2rem;font-weight:600;display:flex}.school-list{-webkit-overflow-scrolling:touch;flex:1;padding:10px;overflow-y:auto}.school-item{cursor:pointer;background:#ffffff08;border:1px solid #0000;border-radius:6px;align-items:center;margin-bottom:4px;padding:8px 12px;transition:all .2s;display:flex}.school-item:hover{background:#ffffff14}.school-item.selected{border-color:var(--accent);background:#00bcd41a}.school-rank-badge{color:#fff;border-radius:6px;justify-content:center;align-items:center;min-width:28px;height:28px;margin-right:10px;font-size:13px;font-weight:700;display:flex;box-shadow:0 2px 4px #0003}.school-info{flex:1;min-width:0}.school-name{text-overflow:ellipsis;white-space:nowrap;margin-bottom:2px;font-size:13px;font-weight:500;overflow:hidden}.school-meta{color:var(--text-muted);gap:6px;font-size:11px;display:flex}.school-grade{background:#ffffff1a;border-radius:4px;padding:1px 4px;font-size:10px}@media (width<=768px){.sidebar{border-right:none}.sidebar-header{padding:12px 16px}.sidebar-header h1{margin-bottom:8px;font-size:1rem}.school-list{padding:6px 10px}.school-item{min-height:44px;margin-bottom:2px;padding:10px 12px}.school-name{font-size:14px}.school-meta{font-size:12px}}.info-panel-wrapper{pointer-events:none;z-index:20;justify-content:center;width:100%;padding:20px;display:flex;position:absolute;bottom:0;left:0}.info-panel{pointer-events:auto;border-radius:12px;width:100%;max-width:600px;transition:transform .4s cubic-bezier(.16,1,.3,1);overflow:hidden;transform:translateY(150%)}.info-panel.visible{transform:translateY(0)}.info-header{border-bottom:1px solid var(--border-color);background:#0003;justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.info-title{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.info-title h2{text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:1.1rem;font-weight:600;overflow:hidden}.info-grade{background:var(--accent);color:#fff;border-radius:12px;flex-shrink:0;padding:2px 6px;font-size:11px;font-weight:500}.close-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:4px;transition:all .2s;display:flex}.close-btn:hover{color:var(--text-primary);background:#ffffff1a}.info-content{grid-template-columns:repeat(2,1fr);gap:8px 12px;padding:12px 16px;display:grid}.info-stat{flex-direction:column;gap:2px;display:flex}.info-stat .label{color:var(--text-muted);font-size:11px}.info-stat .value{color:var(--text-primary);font-size:13px;font-weight:500}.route-stat{border:1px solid var(--accent);background:#00bcd41a;border-radius:6px;grid-column:1/-1;padding:8px 10px}.route-label{color:var(--accent)!important}.route-value{color:var(--text-primary)!important}.info-note{color:var(--text-secondary);background:#ffffff08;border-radius:6px;grid-column:1/-1;margin-top:4px;padding:8px 10px;font-size:12px;line-height:1.4}@media (width<=768px){.info-panel-wrapper{z-index:150;padding:10px;bottom:120px}.info-panel{border-radius:10px;max-width:100%}.info-title h2{font-size:.95rem}.info-content{grid-template-columns:repeat(2,1fr);gap:6px 10px;padding:10px 12px}.info-stat .label{font-size:10px}.info-stat .value{font-size:12px}.info-note{font-size:11px}}.transport-mode{background:#ffffff0d;border-radius:8px;gap:8px;margin-top:12px;padding:4px;display:flex}.mode-btn{color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:6px;flex:1;justify-content:center;align-items:center;padding:8px;font-size:13px;transition:all .2s;display:flex}.mode-btn:hover{color:var(--text-primary);background:#ffffff1a}.mode-btn.active{background:var(--accent);color:#fff}@media (width<=768px){.transport-mode{gap:4px;margin-top:8px}.mode-btn{min-height:36px;padding:8px 4px;font-size:12px}}.my-location{border-top:1px solid var(--border-color);background:#0000001a;flex-shrink:0;padding:16px}.my-loc-btn{border:1px dashed var(--accent);width:100%;color:var(--accent);cursor:pointer;background:#00bcd41a;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:10px;font-weight:500;transition:all .2s;display:flex}.my-loc-btn:hover{background:#00bcd433}.my-loc-info{background:#ffffff0d;border-radius:8px;justify-content:space-between;align-items:center;gap:8px;padding:12px;display:flex}.my-loc-info span{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;align-items:center;gap:6px;min-width:0;font-size:13px;display:flex;overflow:hidden}.remove-loc-btn{color:#ef4444;cursor:pointer;background:0 0;border:none;border-radius:4px;flex-shrink:0;padding:4px 8px}.remove-loc-btn:hover{background:#ef44441a}.user-marker{background-color:var(--accent);border:3px solid #fff;border-radius:50%;width:24px;height:24px;animation:2s infinite pulse;box-shadow:0 0 10px #00bcd499,0 4px 6px #0000004d}@keyframes pulse{0%{box-shadow:0 0 #00bcd466}70%{box-shadow:0 0 0 10px #00bcd400}to{box-shadow:0 0 #00bcd400}}@media (width<=768px){.my-location{padding:10px 16px}.my-loc-info{padding:10px}.my-loc-info span{font-size:12px}}.app-wrapper{flex-direction:column;width:100vw;height:100dvh;display:flex;overflow:hidden}.watermark-banner{color:var(--text-muted);z-index:100;pointer-events:none;background:rgba(var(--bg-panel-rgb), .5);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);letter-spacing:.5px;text-shadow:1px 1px 0 var(--bg-primary), -1px -1px 0 var(--bg-primary), 1px -1px 0 var(--bg-primary), -1px 1px 0 var(--bg-primary);opacity:.8;border-radius:8px;padding:6px 12px;font-size:18px;font-weight:500;position:absolute;top:16px;left:50%;transform:translate(-50%)}.app-container{flex:1;width:100%;display:flex;overflow:hidden}.left-panel{z-index:10;background:var(--bg-primary);flex-direction:column;width:280px;height:100%;display:flex;box-shadow:4px 0 16px #0003}.main-content{flex:1;height:100%;position:relative}@media (width<=768px){.app-container{flex-direction:column;position:relative}.main-content{z-index:1;width:100%;height:100%;position:absolute;top:0;left:0}.watermark-banner{padding:4px 10px;font-size:13px;top:10px}.left-panel.drawer{z-index:200;border-radius:16px 16px 0 0;width:100%;transition:height .35s cubic-bezier(.32,.72,0,1);position:fixed;bottom:0;left:0;overflow:hidden;box-shadow:0 -4px 24px #00000059}.left-panel.drawer-collapsed{height:120px}.left-panel.drawer-half{height:50dvh}.left-panel.drawer-full{height:85dvh}.drawer-handle{cursor:grab;touch-action:none;flex-shrink:0;justify-content:center;align-items:center;padding:10px 0 6px;display:flex}.drawer-handle-bar{background:var(--text-muted);opacity:.5;border-radius:3px;width:40px;height:5px;transition:opacity .2s}.drawer-handle:active .drawer-handle-bar{opacity:.9}}@media (width>=769px){.drawer-handle{display:none}}
