*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#1a1a2e;-webkit-tap-highlight-color:transparent;touch-action:manipulation;background:#f5f7fa;width:100%;height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,Helvetica Neue,Helvetica,Arial,sans-serif;overflow:hidden}#root{width:100%;height:100%}button{font-family:inherit}.app{background:#f5f7fa;width:100vw;height:100vh;display:flex;overflow:hidden}.sidebar{background:#fff;border-right:1px solid #e8ecf1;flex-direction:column;width:340px;min-width:340px;height:100vh;display:flex;overflow:hidden;box-shadow:2px 0 12px #0000000a}.sidebar-header{border-bottom:1px solid #f0f2f5;padding:24px 24px 16px}.sidebar-header h1{color:#1a1a2e;align-items:center;gap:10px;margin:0;font-size:20px;font-weight:700;display:flex}.sidebar-header h1 svg{color:#1a7a9a}.search-section{border-bottom:1px solid #f0f2f5;padding:16px 24px;position:relative}.search-wrapper{align-items:center;display:flex;position:relative}.search-icon{color:#b0b8c4;pointer-events:none;position:absolute;left:12px}.search-input{color:#1a1a2e;background:#f8fafc;border:1px solid #e0e5ec;border-radius:10px;outline:none;width:100%;padding:10px 36px;font-family:inherit;font-size:13px;transition:all .2s}.search-input::placeholder{color:#b0b8c4}.search-input:focus{background:#fff;border-color:#1a7a9a;box-shadow:0 0 0 3px #1a7a9a14}.search-clear{cursor:pointer;color:#b0b8c4;background:0 0;border:none;border-radius:4px;align-items:center;padding:4px;transition:color .2s;display:flex;position:absolute;right:8px}.search-clear:hover{color:#666}.search-dropdown{z-index:100;background:#fff;border:1px solid #e0e5ec;border-radius:10px;max-height:320px;position:absolute;top:calc(100% - 4px);left:24px;right:24px;overflow-y:auto;box-shadow:0 8px 24px #0000001a}.search-dropdown::-webkit-scrollbar{width:5px}.search-dropdown::-webkit-scrollbar-thumb{background:#ddd;border-radius:3px}.search-empty{text-align:center;color:#b0b8c4;padding:24px;font-size:13px}.search-result-item{cursor:pointer;text-align:left;background:0 0;border:none;border-bottom:1px solid #f5f5f5;justify-content:space-between;align-items:center;width:100%;padding:10px 14px;font-family:inherit;transition:background .15s;display:flex}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background:#f5f9fc}.search-result-item.visited{background:#f6ffed}.search-result-item.visited:hover{background:#eef9e6}.search-result-info{flex-direction:column;gap:2px;display:flex}.search-result-name{color:#1a1a2e;font-size:13px;font-weight:600}.search-result-province{color:#8c96a5;font-size:11px}.search-result-badge{color:#1a7a9a;white-space:nowrap;background:#e6f7ff;border:1px solid #bae7ff;border-radius:20px;padding:3px 10px;font-size:11px;font-weight:500}.search-result-badge.visited{color:#389e0d;background:#f6ffed;border-color:#b7eb8f}.list-header-actions{align-items:center;gap:8px;display:flex}.export-btn{color:#1a7a9a;cursor:pointer;background:0 0;border:1px solid #d0d5dd;border-radius:6px;align-items:center;gap:4px;padding:4px 12px;font-family:inherit;font-size:12px;font-weight:500;transition:all .2s;display:flex}.export-btn:hover{background:#f0f7ff;border-color:#1a7a9a}.stats-grid{border-bottom:1px solid #f0f2f5;grid-template-columns:1fr 1fr;gap:12px;padding:20px 24px;display:grid}.stat-card{text-align:center;background:linear-gradient(135deg,#f8fbff 0%,#f0f7ff 100%);border:1px solid #e6f0fa;border-radius:12px;padding:16px}.stat-card.wide{text-align:left;grid-column:1/-1;padding:14px 16px}.stat-number{color:#1a7a9a;margin-bottom:4px;font-size:28px;font-weight:800;line-height:1}.stat-label{color:#8c96a5;font-size:12px;font-weight:500}.stat-progress{background:#e8ecf1;border-radius:3px;height:6px;margin-bottom:8px;overflow:hidden}.stat-progress-bar{background:linear-gradient(90deg,#1a7a9a,#52c41a);border-radius:3px;min-width:2px;height:100%;transition:width .5s}.visited-list{flex:1;padding:16px 24px 24px;overflow-y:auto}.list-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.list-header h2{color:#1a1a2e;margin:0;font-size:15px;font-weight:600}.clear-btn{color:#ff4d4f;cursor:pointer;background:0 0;border:1px solid #ff7875;border-radius:6px;padding:4px 12px;font-size:12px;transition:all .2s}.clear-btn:hover{background:#fff1f0}.empty-state{text-align:center;color:#c0c7d0;padding:40px 0}.empty-state p{margin:8px 0 0;font-size:14px}.empty-state .hint{color:#bbb;font-size:12px}.province-groups{flex-direction:column;gap:16px;display:flex}.province-group{background:#fafbfc;border:1px solid #eef1f5;border-radius:10px;padding:14px 16px}.province-name{color:#2c3e50;justify-content:space-between;align-items:center;margin-bottom:10px;font-size:14px;font-weight:600;display:flex}.city-count{color:#8c96a5;font-size:12px;font-weight:400}.city-tags{flex-wrap:wrap;gap:6px;display:flex}.city-tag{color:#135200;background:linear-gradient(135deg,#e6f7ed 0%,#d9f2e6 100%);border:1px solid #b7eb8f;border-radius:20px;padding:4px 10px;font-size:12px;font-weight:500;display:inline-block}.main{flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden}.map-container{flex-direction:column;flex:1;display:flex;position:relative}.map-header{z-index:10;background:#fff;border-bottom:1px solid #e8ecf1;padding:12px 20px}.map-title{color:#8c96a5;align-items:center;gap:8px;font-size:14px;display:flex}.map-title svg{color:#1a7a9a}.breadcrumb{align-items:center;gap:8px;font-size:14px;display:flex}.back-btn{color:#1a7a9a;cursor:pointer;background:0 0;border:1px solid #d9dde3;border-radius:8px;align-items:center;gap:4px;padding:6px 14px;font-size:13px;font-weight:500;transition:all .2s;display:flex}.back-btn:hover{background:#f0f7ff;border-color:#1a7a9a}.breadcrumb-sep{color:#d0d5dd}.breadcrumb-current{color:#1a1a2e;font-weight:600}.chart{flex:1;width:100%;min-height:0}.loading-overlay{z-index:20;color:#8c96a5;flex-direction:column;align-items:center;gap:12px;font-size:14px;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.loading-text{color:#555;font-size:14px;font-weight:500}.progress-bar-wrapper{background:#e8ecf1;border-radius:3px;width:220px;height:6px;overflow:hidden}.progress-bar{background:linear-gradient(90deg,#1a7a9a,#52c41a);border-radius:3px;height:100%;transition:width .3s}.progress-text{color:#aaa;font-size:12px}.spinner{border:3px solid #e8ecf1;border-top-color:#1a7a9a;border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.visited-list::-webkit-scrollbar{width:5px}.visited-list::-webkit-scrollbar-track{background:0 0}.visited-list::-webkit-scrollbar-thumb{background:#ddd;border-radius:3px}.visited-list::-webkit-scrollbar-thumb:hover{background:#bbb}.app.mobile{position:relative}.app.mobile .main{width:100vw;height:100dvh}.app.mobile .map-header{display:none}.mobile-top-bar{z-index:50;padding:10px 16px;padding-top:calc(10px + env(safe-area-inset-top,0px));-webkit-backdrop-filter:blur(12px);background:#ffffffe0;border-bottom:1px solid #e8ecf199;justify-content:space-between;align-items:center;display:flex;position:fixed;top:0;left:0;right:0}.mobile-top-title{color:#1a1a2e;align-items:center;gap:6px;font-size:15px;font-weight:700;display:flex}.mobile-top-title svg{color:#1a7a9a}.mobile-top-stats{color:#1a7a9a;align-items:center;gap:6px;font-size:13px;font-weight:600;display:flex}.mobile-stat-sep{color:#c5d3e0}.mobile-fab{bottom:24px;bottom:calc(24px + env(safe-area-inset-bottom,0px));z-index:50;color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#1a7a9a;border:none;border-radius:28px;align-items:center;gap:8px;padding:14px 20px;font-family:inherit;font-size:14px;font-weight:600;transition:transform .2s,box-shadow .2s;display:flex;position:fixed;right:16px;box-shadow:0 4px 20px #1a7a9a59,0 2px 8px #0000001a}.mobile-fab:active{transform:scale(.95);box-shadow:0 2px 12px #1a7a9a4d}.mobile-fab-label{white-space:nowrap}.mobile-sheet-overlay{z-index:90;opacity:0;pointer-events:none;background:#0000004d;transition:opacity .3s;position:fixed;inset:0}.mobile-sheet-overlay.open{opacity:1;pointer-events:auto}.mobile-sheet{z-index:100;max-height:85dvh;padding-bottom:env(safe-area-inset-bottom,0px);background:#fff;border-radius:20px 20px 0 0;flex-direction:column;transition:transform .35s cubic-bezier(.32,.72,0,1);display:flex;position:fixed;bottom:0;left:0;right:0;overflow:hidden;transform:translateY(100%);box-shadow:0 -4px 30px #0000001f}.mobile-sheet.open{transform:translateY(0)}.mobile-sheet-handle{cursor:pointer;-webkit-tap-highlight-color:transparent;flex-shrink:0;justify-content:center;padding:12px 0 4px;display:flex}.handle-bar{background:#d0d5dd;border-radius:2px;width:36px;height:4px}.mobile-sheet .sidebar{width:100%;min-width:100%;height:auto;max-height:none;box-shadow:none;-webkit-overflow-scrolling:touch;border-right:none;flex:1;overflow-y:auto}.mobile-sheet .sidebar-header{border-bottom:1px solid #f0f2f5;justify-content:space-between;align-items:center;padding:8px 20px 14px;display:flex}.mobile-sheet .sidebar-header h1{font-size:17px}.sheet-close-btn{color:#666;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#f0f2f5;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:background .2s;display:flex}.sheet-close-btn:active{background:#e0e3e8}.mobile-sheet .search-section{padding:12px 20px}.mobile-sheet .search-input{border-radius:12px;padding:12px 40px;font-size:16px}.mobile-sheet .search-dropdown{max-height:240px;left:20px;right:20px}.mobile-sheet .search-result-item{min-height:48px;padding:12px 16px}.mobile-sheet .search-result-name{font-size:14px}.mobile-sheet .search-result-province{font-size:12px}.mobile-sheet .search-result-badge{padding:5px 14px;font-size:12px}.mobile-sheet .stats-grid{gap:10px;padding:16px 20px}.mobile-sheet .stat-card{padding:12px}.mobile-sheet .stat-number{font-size:24px}.mobile-sheet .visited-list{padding:14px 20px 20px}.mobile-sheet .clear-btn,.mobile-sheet .export-btn{min-height:36px;padding:6px 14px;font-size:13px}.mobile-sheet .city-tag{padding:6px 12px;font-size:13px}.mobile-sheet .province-group{padding:12px 14px}@media (width<=1024px) and (width>=769px){.sidebar{width:300px;min-width:300px}}
