.home-page{margin:0;padding:0;display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;width:100%;background-image:linear-gradient(120deg,#f9fbfd,#e2effd);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.home-page footer{display:flex;justify-content:center;align-items:center;flex-direction:column;position:absolute;bottom:30px}.office-page{margin:0;padding:0;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;width:100%;background-image:linear-gradient(120deg,#f9fbfd,#e2effd);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}header{height:50px;display:flex;justify-content:center;align-items:center}a{text-decoration:none}#logo{display:flex;justify-content:center;align-items:center;margin:10px;padding:10px;height:160px}.nav{display:flex;justify-content:center;align-items:center;flex-wrap:wrap;max-width:700px;font-size:18px;font-weight:700;text-align:center}.buttomNav{margin:10px;padding:10px;border-radius:15%;cursor:pointer}.buttomNav img{width:100px;height:100px}.buttomNav:hover{background-color:#b4dcff;box-shadow:0 0 5px 5px #50509680}.other{height:200px}footer{display:flex;justify-content:center;align-items:center;flex-direction:column;position:absolute;bottom:30px}footer a,a:link,a:visited,a:active{color:#a9a9a9}footer a:hover{color:#696969}:root{--bg: #f5f6fa;--card-bg: #ffffff;--text: #2c3e50;--text-secondary: #7f8c8d;--border: #e8ecf1;--blue: #3498db;--green: #27ae60;--purple: #9b59b6;--orange: #e67e22;--red: #e74c3c;--teal: #1abc9c}.stats-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;color:var(--text-secondary)}.spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--blue);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:16px}.stats-empty{text-align:center;padding:60px 20px;color:var(--text-secondary)}.empty-icon{font-size:48px;margin-bottom:16px}.stats-dashboard{max-width:1200px;margin:0 auto;padding:16px;background:var(--bg);min-height:100vh}.stats-header{text-align:center;margin-bottom:16px}.stats-header h1{font-size:22px;font-weight:600;margin-bottom:4px;color:var(--text)}.stats-header p{color:var(--text-secondary);font-size:13px}.summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:8px;margin-bottom:16px}.summary-card{background:var(--card-bg);border-radius:10px;padding:10px 14px;border:1px solid var(--border);text-align:center}.summary-card .label{font-size:12px;color:var(--text-secondary)}.summary-card.blue .number{color:var(--blue)}.summary-card.green .number{color:var(--green)}.summary-card.purple .number{color:var(--purple)}.summary-card.orange .number{color:var(--orange)}.summary-card.teal .number{color:var(--teal)}.map-section{background:var(--card-bg);border-radius:10px;border:1px solid var(--border);padding:16px;margin-bottom:16px}.map-section h2{font-size:17px;font-weight:600;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--border);color:var(--text)}.china-map{width:100%;height:500px}.app-section{background:var(--card-bg);border-radius:10px;border:1px solid var(--border);padding:16px;margin-bottom:16px}.app-section h2{font-size:17px;font-weight:600;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border);color:var(--text)}.compact-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:12px}.app-stat{background:var(--bg);border-radius:6px;padding:8px 10px;text-align:center;min-width:90px}.app-stat .num{font-size:18px;font-weight:700}.app-stat .lbl{font-size:11px;color:var(--text-secondary);margin-top:2px}.collapse-section{margin-top:10px}.collapse-toggle{display:inline-block;padding:5px 14px;font-size:12px;color:var(--text-secondary);background:var(--bg);border:1px solid var(--border);border-radius:6px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s}.collapse-toggle:hover{background:#e8ecf1}.collapse-body{display:none;margin-top:10px}.collapse-body.open{display:block}.hw-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:6px;margin-bottom:12px}.hw-stat{background:var(--bg);border-radius:6px;padding:8px 10px;text-align:center}.hw-stat .num{font-size:13px;font-weight:600;word-break:break-all}.hw-stat .lbl{font-size:11px;color:var(--text-secondary);margin-top:2px}.charts-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.chart-box{background:var(--bg);border-radius:6px;padding:12px;height:220px;display:flex;flex-direction:column}.chart-box h3{font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:8px;flex-shrink:0}.chart-canvas-wrap{flex:1;min-height:0;position:relative;width:100%}.chart-canvas-wrap canvas{width:100%!important;height:100%!important}.stats-footer{text-align:center;padding:16px 0;color:var(--text-secondary);font-size:11px}.stats-footer a{color:var(--text-secondary);text-decoration:none}.stats-footer a:hover{text-decoration:underline}@media(max-width:768px){.stats-dashboard{padding:8px}.compact-stats{grid-template-columns:repeat(3,1fr)}.charts-row{grid-template-columns:1fr}.stats-header h1{font-size:18px}.chart-box{height:200px}.china-map{height:340px}}.archives-page{min-height:100vh;background:linear-gradient(135deg,#f5ebe0,#e8d9c4);padding:0;display:flex;flex-direction:column}.page-header{display:flex;align-items:center;padding:8px 20px;background:#ffffff80}.container{max-width:1400px;width:100%;margin:10px auto;background:#fff;border-radius:15px;box-shadow:0 20px 60px #00000026;overflow:hidden;display:flex;flex-direction:column;flex:1}.header{background:linear-gradient(#d4b996d9,#c2a67fd9);color:#4a3b28;padding:18px 30px;text-align:center;flex-shrink:0}.header h1{font-size:1.8em;margin:0 0 5px;text-shadow:2px 2px 4px rgba(0,0,0,.1)}.header p{font-size:1em;opacity:.95;margin:0}.search-box{display:flex;flex-wrap:nowrap;gap:8px;align-items:center;justify-content:center;width:100%;max-width:800px;margin:10px auto;padding:5px 10px}.search-input{flex:1;min-width:0;max-width:280px;padding:9px 12px;font-size:13px;border:1px solid #ddd;border-radius:6px;outline:none;background-color:#f8f0e3;color:#4a3b28;transition:all .3s ease}.search-input:focus{border-color:#c2a67f;background-color:#fff;box-shadow:0 0 8px #d4b9964d}.reset-btn{padding:0 14px;height:37px;font-size:13px;line-height:37px;white-space:nowrap;text-align:center;background:#f9e8c8;border:none;border-radius:6px;flex-shrink:0;cursor:pointer;color:#4a3b28}.reset-btn:hover{background:#f3d5a6}.table-container{padding:0 30px 20px;overflow-x:auto;flex:1;overflow-y:auto}table{width:100%;border-collapse:collapse;font-size:16px;table-layout:fixed}thead th{padding:18px 15px;text-align:left;font-weight:600;letter-spacing:.5px;position:sticky;top:0;z-index:10;background:#d4b996;box-shadow:0 2px 4px #0000001a;color:#4a3b28}thead th:first-child,tbody td:first-child{text-align:center;width:190px}thead th:nth-child(2),tbody td:nth-child(2){width:200px;white-space:nowrap;text-align:center}thead th:nth-child(3),tbody td:nth-child(3){width:calc(100% - 590px)}thead th:nth-child(4),tbody td:nth-child(4){width:200px;white-space:nowrap;text-align:left}tbody tr{transition:all .3s ease}tbody tr:nth-child(odd){background-color:#fff}tbody tr:nth-child(2n){background-color:#f8f0e3}tbody tr:hover{background-color:#e8d9c4!important;box-shadow:0 4px 12px #0000001a;font-weight:700}tbody td{padding:15px;border-bottom:1px solid #d4b996;overflow:hidden;text-overflow:ellipsis}.footer{text-align:center;padding:20px;color:#8b6e43;font-size:.95em;border-top:1px solid #d4b996;background-color:#f8f0e3;flex-shrink:0}.footer span{cursor:pointer;text-decoration:none;color:#8b6e43}.footer span:hover{color:#4a3b28}.empty-state{text-align:center;padding:50px 20px;color:#8b6e43;font-size:1.2em}@media(max-width:768px){.header h1{font-size:1.4em}.search-box{flex-wrap:nowrap;padding:5px 8px;gap:5px;margin:6px auto}.search-input{flex:1 1 0;min-width:0;max-width:none;font-size:12px;padding:7px 8px}.reset-btn{padding:0 10px;height:33px;font-size:12px;line-height:33px;flex-shrink:0}.table-container{padding:0 6px 10px}table{font-size:13px;table-layout:auto!important;width:100%;min-width:0}th:nth-child(4),td:nth-child(4){display:none!important}th:nth-child(1),td:nth-child(1){width:50px!important;min-width:50px!important;max-width:50px!important;padding:10px 4px!important;font-size:12px;text-align:center}th:nth-child(2),td:nth-child(2){width:90px!important;min-width:90px!important;max-width:90px!important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:10px 6px!important;font-size:12px}th:nth-child(3),td:nth-child(3){width:auto!important;min-width:0!important;white-space:normal!important;word-break:break-all;overflow:visible;text-overflow:clip;padding:10px 6px!important;font-size:13px;line-height:1.5}thead th{padding:12px 6px!important;font-size:12px}}.login-layout{display:grid;grid-template-columns:1fr 1fr;width:100%;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans SC,sans-serif}.brand-panel{position:relative;display:flex;flex-direction:column;justify-content:space-between;padding:60px 80px;background:linear-gradient(160deg,#0a2a5e,#0d3a7a,#0f4c8f);color:#fff;overflow:hidden}.brand-panel:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255 255 255 / .03) 1px,transparent 1px),linear-gradient(90deg,rgba(255 255 255 / .03) 1px,transparent 1px);background-size:48px 48px;pointer-events:none}.brand-panel>*{position:relative;z-index:1}.brand-header{display:flex;align-items:center;gap:12px}.brand-logo{width:40px;height:40px;background:#ffffff1f;border-radius:10px;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255 255 255 / .1)}.brand-logo svg{width:22px;height:22px;color:#fff}.brand-name{font-size:18px;font-weight:700;letter-spacing:-.02em}.brand-hero{max-width:480px;margin-top:60px}.brand-hero h1{font-size:36px;font-weight:700;line-height:1.3;letter-spacing:-.02em;margin-bottom:16px}.brand-hero h1 span{display:block;font-size:18px;font-weight:400;opacity:.7;letter-spacing:0;margin-top:8px}.brand-features{display:flex;flex-direction:column;gap:24px;max-width:400px;margin-top:40px}.brand-feature{display:flex;align-items:flex-start;gap:14px;opacity:0;animation:featureFadeIn .5s ease forwards}.brand-feature:nth-child(1){animation-delay:.2s}.brand-feature:nth-child(2){animation-delay:.35s}.brand-feature:nth-child(3){animation-delay:.5s}@keyframes featureFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.feature-icon{flex-shrink:0;width:40px;height:40px;border-radius:8px;background:#ffffff14;display:flex;align-items:center;justify-content:center}.feature-icon svg{width:20px;height:20px;color:#fff;opacity:.85}.feature-text{font-size:14px;line-height:1.6;opacity:.8}.feature-text strong{font-weight:600;opacity:1;display:block;font-size:15px;margin-bottom:3px}.brand-footer{font-size:12px;opacity:.4}.form-panel{display:flex;flex-direction:column;justify-content:center;align-items:center;padding:60px;background:#fff}.form-container{width:100%;max-width:420px}.form-header{margin-bottom:40px}.form-header h2{font-size:28px;font-weight:700;color:#1a1a1a;letter-spacing:-.02em;margin-bottom:8px}.form-header p{color:#999;font-size:15px}.form-group{margin-bottom:24px}.form-label{display:block;font-size:14px;font-weight:500;color:#333;margin-bottom:8px}.form-input{width:100%;padding:14px 18px;font-size:15px;font-family:inherit;color:#1a1a1a;background:#fff;border:1.5px solid #e0e0e0;border-radius:12px;transition:border-color .2s ease,box-shadow .2s ease;outline:none;height:52px;box-sizing:border-box}.form-input::placeholder{color:#bbb}.form-input:hover{border-color:silver}.form-input:focus{border-color:#0d3a7a;box-shadow:0 0 0 3px #0d3a7a1a}.password-wrapper{position:relative}.field-error{display:flex;align-items:center;gap:6px;font-size:13px;color:#e53935;margin-bottom:20px;padding:8px 12px;background:#fef2f2;border-radius:8px}.submit-btn{width:100%;padding:14px 24px;font-size:16px;font-weight:600;font-family:inherit;color:#fff;background:#0d3a7a;border:none;border-radius:12px;cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden;height:52px;margin-top:8px}.submit-btn:hover:not(:disabled){background:#0a2a5e;transform:translateY(-1px);box-shadow:0 4px 12px #0d3a7a4d}.submit-btn:active:not(:disabled){transform:translateY(0)}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.submit-btn .spinner{display:none;width:20px;height:20px;border:2px solid rgba(255 255 255 / .3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;margin:0 auto}.submit-btn.loading .btn-text{display:none}.submit-btn.loading .spinner{display:inline-block}@media(max-width:960px){.login-layout{grid-template-columns:1fr}.brand-panel{display:none}.form-panel{padding:40px 24px}}@media(max-width:480px){.form-panel{padding:32px 20px}.form-header h2{font-size:24px}}.dashboard-layout{display:flex;min-height:100vh}.sidebar{position:sticky;top:0;height:100vh;width:var(--sidebar-width);background:var(--color-surface);border-right:1px solid var(--color-border);display:flex;flex-direction:column;transition:width var(--duration-normal) ease;overflow:hidden;flex-shrink:0}.sidebar.collapsed{width:var(--sidebar-collapsed-width)}.sidebar-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-5) var(--space-4);border-bottom:1px solid var(--color-border);min-height:var(--header-height)}.sidebar-logo{width:36px;height:36px;flex-shrink:0;background:linear-gradient(165deg,var(--blue-700),var(--blue-500));border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.sidebar-logo svg{width:20px;height:20px;color:#fff}.sidebar-title{font-size:var(--text-lg);font-weight:700;letter-spacing:-.02em;white-space:nowrap;color:var(--color-text)}.sidebar-nav{flex:1;padding:var(--space-3);overflow-y:auto}.sidebar-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-3);border-radius:var(--radius-md);text-decoration:none;color:var(--color-text-secondary);transition:all var(--duration-fast) ease;margin-bottom:var(--space-1);cursor:pointer;border:none;background:none;width:100%;font-family:var(--font-sans);font-size:var(--text-sm);text-align:left}.sidebar-link:hover{background:var(--gray-100);color:var(--color-text)}.sidebar-link.active{background:var(--blue-50);color:var(--color-primary)}.sidebar-icon{width:22px;height:22px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.sidebar-icon svg{width:20px;height:20px}.sidebar-label{white-space:nowrap;font-weight:500}.sidebar-footer{padding:var(--space-3);border-top:1px solid var(--color-border)}.logout-btn:hover{background:#c5363714!important;color:var(--color-error)!important}.sidebar-toggle{position:absolute;right:-14px;top:36px;width:28px;height:28px;border-radius:50%;background:var(--color-surface);border:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--color-text-secondary);box-shadow:var(--shadow-sm);transition:all var(--duration-fast) ease;z-index:10}.sidebar-toggle:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.sidebar-toggle svg{width:14px;height:14px}.main-content{flex:1;padding:var(--space-8);background:var(--color-bg);overflow-y:auto}@media(max-width:768px){.sidebar{position:fixed;z-index:100;transform:translate(0)}.sidebar.collapsed{transform:translate(-100%)}.main-content{padding:var(--space-4)}}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;color:var(--color-text-secondary)}.loading-spinner{width:36px;height:36px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:var(--space-4)}@keyframes spin{to{transform:rotate(360deg)}}.refresh-hint{font-size:var(--text-xs);color:#e67e22;cursor:pointer;white-space:nowrap}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-3);margin-bottom:var(--space-6)}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5) var(--space-6);display:flex;align-items:center;gap:var(--space-4);transition:all var(--duration-fast) ease;cursor:default}.stat-card:hover{border-color:transparent;box-shadow:0 6px 20px #00000014;transform:translateY(-2px)}.stat-icon{font-size:28px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);flex-shrink:0}.stat-card.blue .stat-icon{background:#dbf3ff}.stat-card.green .stat-icon{background:#dff6de}.stat-card.purple .stat-icon{background:#ebedff;background:oklch(95% .06 280)}.stat-card.teal .stat-icon{background:#cefae9}.stat-card.orange .stat-icon{background:#ffeee3;background:oklch(96% .06 55)}.stat-card.pink .stat-icon{background:#ffe6f6;background:oklch(95% .06 340)}.stat-card.indigo .stat-icon{background:#e0ecff;background:oklch(94% .08 260)}.stat-card.red .stat-icon{background:#ffe7e4;background:oklch(95% .06 25)}.stat-info{min-width:0}.stat-value{font-size:22px;font-weight:700;line-height:1.2;font-variant-numeric:tabular-nums}.stat-label{font-size:var(--text-xs);color:var(--color-text-secondary);margin-top:2px}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-5);margin-bottom:var(--space-5)}.dashboard-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.panel-title{font-size:var(--text-base);font-weight:600;padding:var(--space-4) var(--space-6);margin:0;border-bottom:1px solid var(--color-border);display:flex;align-items:center;gap:var(--space-2)}.panel-title-sm{font-size:var(--text-sm);font-weight:600;padding:var(--space-3) var(--space-5);margin:0;border-bottom:1px solid var(--color-border);display:flex;align-items:center;gap:var(--space-2)}.panel-title-icon{font-size:16px;flex-shrink:0}.panel-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--color-text-secondary);text-align:center}.panel-placeholder svg{width:40px;height:40px;opacity:.3;margin-bottom:var(--space-3)}.panel-placeholder p{font-size:var(--text-sm)}.activity-list{max-height:420px;overflow-y:auto}.empty-activity{display:flex;flex-direction:column;align-items:center;padding:40px 20px;color:var(--color-text-secondary);font-size:var(--text-sm)}.empty-activity span{font-size:28px;margin-bottom:var(--space-2)}.activity-item{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-6);border-bottom:1px solid oklch(97% .002 220);transition:background var(--duration-fast) ease}.activity-item:last-child{border-bottom:none}.activity-item:hover{background:#f5f9fb}.activity-dot{width:8px;height:8px;border-radius:50%;margin-top:7px;flex-shrink:0}.activity-dot.user{background:#3498db}.activity-dot.archive{background:#27ae60}.activity-dot.config{background:#9b59b6}.activity-dot.download{background:#e67e22}.activity-body{display:flex;justify-content:space-between;align-items:baseline;gap:var(--space-3);flex:1;min-width:0}.activity-text{font-size:var(--text-sm);word-break:break-word}.activity-time{font-size:var(--text-xs);color:var(--color-text-secondary);white-space:nowrap;flex-shrink:0}.status-badge{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-size:var(--text-sm);border-bottom:1px solid var(--color-border)}.status-badge.online{background:#f1fcf0;color:#16a34a}.status-badge.offline{background:#fff6f5;background:oklch(98% .02 25);color:#dc2626}.status-pulse{width:10px;height:10px;border-radius:50%;animation:pulse 2s infinite}.status-badge.online .status-pulse{background:#27ae60}.status-badge.offline .status-pulse{background:#e74c3c;animation:pulse-error 1s infinite}@keyframes pulse-error{0%,to{opacity:1}50%{opacity:.4}}.sys-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4) var(--space-6);padding:var(--space-4) var(--space-6)}.sys-info-item{display:flex;flex-direction:column;gap:4px}.sys-info-item.full{grid-column:1 / -1}.sys-label{font-size:var(--text-xs);color:var(--color-text-secondary);font-weight:500}.sys-value{font-size:var(--text-sm);font-weight:500;font-variant-numeric:tabular-nums;display:flex;align-items:center;gap:var(--space-2)}.sys-value.warn{color:#e74c3c}.sys-ver{font-family:monospace;font-size:var(--text-xs);color:var(--color-text-secondary)}.mini-bar{width:60px;height:6px;background:var(--gray-100);border-radius:3px;overflow:hidden;display:inline-block}.mini-bar>span{display:block;height:100%;background:var(--color-primary);border-radius:3px;transition:width .3s ease}.progress-bar{width:100%;height:6px;background:var(--gray-100);border-radius:3px;overflow:hidden;margin-top:4px}.progress-fill{height:100%;border-radius:3px;transition:width .3s ease}.progress-fill.mem{background:linear-gradient(90deg,#3498db,#2980b9)}.progress-fill.disk{background:linear-gradient(90deg,#27ae60,#1abc9c)}.dashboard-bottom-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:var(--space-5)}.dashboard-panel.mini{overflow:hidden}.empty-mini{padding:var(--space-6);text-align:center;font-size:var(--text-sm);color:var(--color-text-secondary)}.mini-table{width:100%;border-collapse:collapse;font-size:var(--text-xs)}.mini-table th{padding:var(--space-2) var(--space-3);text-align:left;font-weight:600;color:var(--color-text-secondary);border-bottom:1px solid var(--color-border);background:var(--gray-50)}.mini-table td{padding:var(--space-2) var(--space-3);border-bottom:1px solid oklch(97% .002 220);vertical-align:middle}.mini-table tbody tr:last-child td{border-bottom:none}.mini-table tbody tr:hover td{background:#f5f9fb}.sw-name-cell{display:flex;align-items:center;gap:var(--space-2)}.rank-num{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;font-size:10px;font-weight:700;color:#fff;background:var(--gray-400);border-radius:50%;flex-shrink:0}.mini-table tr:nth-child(1) .rank-num{background:#f59e0b}.mini-table tr:nth-child(2) .rank-num{background:#d1d5da}.mini-table tr:nth-child(3) .rank-num{background:#cd7f32}.disk-dist-list{padding:var(--space-3) var(--space-5)}.disk-dist-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) 0}.disk-name{font-size:var(--text-xs);font-weight:500;font-family:monospace;min-width:70px;flex-shrink:0}.disk-bar-wrap{flex:1;display:flex;align-items:center;gap:var(--space-2)}.disk-bar{flex:1;height:12px;background:var(--gray-100);border-radius:6px;overflow:hidden}.disk-bar-fill{height:100%;border-radius:6px;transition:width .5s ease;min-width:4px}.disk-count{font-size:var(--text-xs);font-weight:600;color:var(--color-text-secondary);font-variant-numeric:tabular-nums;min-width:42px;text-align:right}@media(max-width:1024px){.stat-grid{grid-template-columns:repeat(2,1fr)}.dashboard-grid,.dashboard-bottom-grid,.sys-info-grid{grid-template-columns:1fr}}@media(max-width:640px){.stat-grid{grid-template-columns:repeat(2,1fr)}.stat-card{padding:var(--space-3) var(--space-4)}.stat-value{font-size:18px}.stat-icon{font-size:22px;width:38px;height:38px}}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.card-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border)}.search-bar{display:flex;align-items:center;gap:var(--space-3);flex:1}.search-input{flex:1;max-width:360px;padding:var(--space-2) var(--space-4);font-size:var(--text-sm);font-family:var(--font-sans);color:var(--color-text);background:var(--gray-50);border:1.5px solid var(--color-border);border-radius:var(--radius-md);outline:none;transition:border-color var(--duration-fast) ease}.search-input:focus{border-color:var(--color-border-focus)}.filter-select{padding:var(--space-2) var(--space-4);font-size:var(--text-sm);font-family:var(--font-sans);color:var(--color-text);background:var(--gray-50);border:1.5px solid var(--color-border);border-radius:var(--radius-md);outline:none;cursor:pointer}.total-count{font-size:var(--text-xs);color:var(--color-text-secondary);white-space:nowrap}.archive-table{table-layout:fixed}.archive-table .col-id{width:90px}.archive-table .col-disk{width:120px}.archive-table .col-name{width:auto}.archive-table .col-remark{width:150px}.archive-table .col-actions{width:100px}.data-table .editing-row{background:#eef7fa}.data-table .new-row{background:#eef9ec}.remark-text{color:var(--color-text-secondary);font-size:var(--text-xs)}.cell-input{width:100%;padding:4px 8px;font-size:var(--text-sm);font-family:var(--font-sans);color:var(--color-text);background:#fff;border:1.5px solid var(--color-border-focus);border-radius:var(--radius-sm);outline:none}.cell-input:focus{border-color:var(--color-primary)}.cell-input.cell-name{font-weight:500}.cell-auto{color:var(--color-text-secondary);font-size:var(--text-xs);text-align:center}.action-buttons,.edit-actions{display:flex;gap:2px}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:16px;color:var(--color-text-secondary);transition:all var(--duration-fast) ease}.btn-icon:hover{background:var(--gray-100);color:var(--color-text)}.btn-icon.success{color:#27ae60}.btn-icon.success:hover{background:#31aa401a}.btn-icon.danger{color:#c53637}.btn-icon.danger:hover{background:#c536371a}.text-center{text-align:center;color:var(--color-text-secondary)}.btn{padding:var(--space-2) var(--space-4);font-size:var(--text-sm);font-weight:500;font-family:var(--font-sans);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast) ease}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-hover)}.btn-outline{background:transparent;color:var(--color-text);border:1.5px solid var(--color-border)}.btn-outline:hover{background:var(--gray-50)}.header-actions{display:flex;gap:var(--space-3)}.pagination{display:flex;align-items:center;justify-content:center;gap:var(--space-4);padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border)}.page-btn{padding:var(--space-2) var(--space-4);font-size:var(--text-sm);font-weight:500;font-family:var(--font-sans);background:var(--gray-50);border:1.5px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast) ease}.page-btn:hover:not(:disabled){background:var(--gray-100)}.page-btn:disabled{opacity:.4;cursor:not-allowed}.page-info{font-size:var(--text-sm);color:var(--color-text-secondary)}.page-jump{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-secondary)}.jump-input{width:48px;padding:var(--space-1) var(--space-2);font-size:var(--text-sm);font-family:var(--font-sans);text-align:center;color:var(--color-text);background:#fff;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);outline:none}.jump-input:focus{border-color:var(--color-primary)}.modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-6);min-width:400px;max-width:500px;box-shadow:0 20px 60px #0003}.modal-title{font-size:var(--text-lg);font-weight:600;margin-bottom:var(--space-2)}.modal-desc{font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-4);line-height:1.6}.modal-desc code{background:var(--gray-100);padding:1px 4px;border-radius:3px;font-size:var(--text-xs)}.import-file-area{margin-bottom:var(--space-4)}.import-file-area input[type=file]{display:none}.import-file-label{display:flex;align-items:center;justify-content:center;padding:var(--space-6);border:2px dashed var(--color-border);border-radius:var(--radius-md);cursor:pointer;font-size:var(--text-sm);color:var(--color-text-secondary);transition:all var(--duration-fast) ease}.import-file-label:hover{border-color:var(--color-primary);background:var(--gray-50);color:var(--color-text)}.import-mode-selector{margin-bottom:var(--space-4)}.mode-label{display:block;font-size:var(--text-sm);font-weight:500;margin-bottom:var(--space-2);color:var(--color-text)}.mode-options{display:flex;flex-direction:column;gap:var(--space-2)}.mode-option{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);border:1.5px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast) ease}.mode-option:hover{background:var(--gray-50)}.mode-option.active{border-color:var(--color-primary);background:#e7f9ff}.mode-option input[type=radio]{display:none}.mode-radio{width:18px;height:18px;min-width:18px;margin-top:2px;border:2px solid var(--color-border);border-radius:50%;transition:all var(--duration-fast) ease;position:relative}.mode-option.active .mode-radio{border-color:var(--color-primary)}.mode-option.active .mode-radio:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:8px;height:8px;background:var(--color-primary);border-radius:50%}.mode-text{display:flex;flex-direction:column;gap:2px}.mode-text strong{font-size:var(--text-sm);font-weight:500}.mode-text small{font-size:var(--text-xs);color:var(--color-text-secondary)}.modal-actions{display:flex;justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-4)}@media(max-width:768px){.card-header{flex-direction:column;align-items:stretch}.search-bar{flex-direction:column}.search-input{max-width:none}.modal{min-width:auto;margin:var(--space-4)}.header-actions{flex-direction:column}}.page-header-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4)}.header-actions{display:flex;gap:var(--space-3);flex-shrink:0}.card-body{padding:var(--space-6)}.section-title{font-size:var(--text-base);font-weight:600;margin-bottom:var(--space-6);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border)}.form-group{margin-bottom:var(--space-5)}.form-group:last-child{margin-bottom:0}.form-label{display:block;font-size:var(--text-sm);font-weight:500;color:var(--color-text);margin-bottom:var(--space-2)}.form-input,.form-select{width:100%;padding:var(--space-3) var(--space-4);font-size:var(--text-sm);font-family:var(--font-sans);color:var(--color-text);background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-md);outline:none;transition:border-color var(--duration-fast) ease}.form-input:focus,.form-select:focus{border-color:var(--color-border-focus)}.form-input:hover,.form-select:hover{border-color:var(--gray-300)}.form-textarea{resize:vertical;min-height:100px;line-height:1.6}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:40px}.toggle-label{display:flex;align-items:center;gap:var(--space-3);cursor:pointer;font-size:var(--text-sm);color:var(--color-text)}.toggle-label input[type=checkbox]{display:none}.toggle-switch{width:44px;height:24px;background:var(--gray-300);border-radius:999px;position:relative;transition:background var(--duration-fast) ease;flex-shrink:0}.toggle-switch:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform var(--duration-fast) ease;box-shadow:var(--shadow-sm)}.toggle-label input:checked+.toggle-switch{background:var(--color-primary)}.toggle-label input:checked+.toggle-switch:after{transform:translate(20px)}.cloud-table{table-layout:fixed}.cloud-table .col-name{width:140px}.cloud-table .col-label{width:auto;min-width:130px}.cloud-table .col-desc{width:auto;min-width:150px}.cloud-table .col-type{width:70px;text-align:center}.cloud-table .col-version{width:80px;text-align:center}.cloud-table .col-status{width:90px;text-align:center}.cloud-table .col-content{width:100px;text-align:center}.cloud-table .col-actions{width:60px;text-align:center}.table-wrap{overflow-x:auto;max-height:600px;overflow-y:auto}.data-table{width:100%;border-collapse:collapse}.data-table th{padding:var(--space-3) var(--space-6);font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);text-align:left;border-bottom:1px solid var(--color-border);background:var(--gray-50);position:sticky;top:0;z-index:1}.data-table td{padding:var(--space-3) var(--space-6);font-size:var(--text-sm);border-bottom:1px solid var(--color-border);color:var(--color-text);vertical-align:middle}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:var(--gray-50)}.disabled-row{opacity:.55}.disabled-row:hover{opacity:.7}.inline-text{display:inline-block;cursor:pointer;padding:2px 6px;border-radius:4px;transition:background var(--duration-fast) ease;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.inline-text:hover{background:var(--gray-100);color:var(--color-primary)}.inline-input{width:100%;padding:2px 6px;font-size:var(--text-sm);font-family:inherit;color:var(--color-text);background:#fff;border:1.5px solid var(--color-primary);border-radius:4px;outline:none;box-shadow:0 0 0 2px #3b82f61a}.inline-select{width:100%;padding:2px 20px 2px 6px;font-size:var(--text-xs);font-family:inherit;color:var(--color-text);background:#fff;border:1.5px solid transparent;border-radius:4px;outline:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 4px center;cursor:pointer}.inline-select:focus{border-color:var(--color-primary)}.sw-tag{display:inline-block;padding:2px 8px;background:#e8f4fd;color:#1976d2;border-radius:4px;font-size:var(--text-xs);font-family:monospace;font-weight:500}.content-edit-btn{display:inline-flex;align-items:center;gap:4px;cursor:pointer;background:none;border:1.5px solid var(--color-border);padding:4px 12px;border-radius:var(--radius-md);transition:all var(--duration-fast) ease;font-size:var(--text-xs);font-weight:500;color:var(--color-primary)}.content-edit-btn:hover{background:#eff6ff;border-color:var(--color-primary)}.edit-icon{font-size:14px}.type-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:var(--text-xs);font-weight:600;letter-spacing:.03em}.type-json{background:#fef3c7;color:#d97706}.type-xml{background:#dbeafe;color:#2563eb}.type-yaml{background:#dcfce7;color:#16a34a}.type-ini{background:#f3e8ff;color:#9333ea}.status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--gray-400);margin-right:4px;vertical-align:middle}.status-dot.active{background:#27ae60}.inline-toggle{justify-content:center}.status-text{font-size:var(--text-xs);font-weight:500}.status-text.off{color:var(--color-text-secondary)}.config-editor-modal{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:0 20px 60px #00000040;display:flex;flex-direction:column;max-height:90vh;overflow:hidden;width:800px;max-width:calc(100vw - 32px);margin:20px auto}.config-editor-modal.fullscreen{width:95vw;height:95vh;max-height:95vh;margin:2.5vh auto;position:relative}.editor-toolbar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border);flex-shrink:0}.editor-title{font-size:var(--text-base);font-weight:600;margin:0;display:flex;align-items:center;gap:var(--space-3)}.editor-subtitle{font-size:var(--text-sm);font-weight:400;color:var(--color-text-secondary)}.toolbar-actions{display:flex;align-items:center;gap:var(--space-2)}.tool-btn{padding:5px 10px;font-size:var(--text-xs);font-weight:500;font-family:var(--font-sans);background:transparent;border:1.5px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;color:var(--color-text);transition:all var(--duration-fast) ease;white-space:nowrap}.tool-btn:hover{background:var(--gray-50);border-color:var(--gray-400)}.tool-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.tool-cancel{color:var(--color-text-secondary)}.tool-save{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.tool-save:hover{background:var(--color-primary-hover)}.toolbar-divider{width:1px;height:20px;background:var(--color-border);margin:0 var(--space-2)}.editor-body{padding:var(--space-6);overflow-y:auto;flex:1}.editor-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4) var(--space-6)}.form-full{grid-column:1 / -1}.editor-body-only-content{display:flex;flex-direction:column;padding:var(--space-6)}.editor-body-only-content .editor-textarea{flex:1;min-height:350px}.editor-content-area{margin-top:var(--space-2)}.editor-textarea{min-height:280px;font-family:var(--font-mono);font-size:var(--text-xs);line-height:1.7;tab-size:2}.sw-select-wrap{position:relative}.sw-input{cursor:pointer}.sw-dropdown{position:absolute;top:100%;left:0;right:0;z-index:100;background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-md);box-shadow:0 8px 24px #0000001f;max-height:180px;overflow-y:auto;margin-top:4px}.sw-dropdown-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);cursor:pointer;transition:background var(--duration-fast) ease;font-size:var(--text-sm)}.sw-dropdown-item:hover{background:var(--gray-50)}.sw-dropdown-item.selected{background:#e4f5fb}.sw-dropdown-value{font-family:monospace;font-size:var(--text-xs);color:var(--color-primary);font-weight:500;min-width:120px}.sw-dropdown-label{color:var(--color-text-secondary);font-size:var(--text-xs);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(max-width:768px){.editor-form-grid{grid-template-columns:1fr}.config-editor-modal{width:calc(100vw - 16px);margin:8px auto}.toolbar-actions{flex-wrap:wrap}.editor-toolbar{flex-direction:column;align-items:stretch;gap:var(--space-3)}.cloud-table .col-desc{display:none}}.china-map-container{border-radius:var(--radius-md);overflow:hidden}.map-error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-10) var(--space-6);background:var(--color-surface);border:1px dashed var(--color-border);border-radius:var(--radius-lg);min-height:300px}.map-error-icon{width:48px;height:48px;line-height:48px;text-align:center;font-size:24px;font-weight:700;color:#fff;background:var(--color-danger);border-radius:50%}.map-error-text{margin:0;color:var(--color-text-secondary);font-size:var(--text-sm)}.map-section{background:var(--color-bg-primary, #fff);border-radius:10px;border:1px solid var(--color-border, #e8ecf1);padding:16px;margin-bottom:16px}.map-section h2{font-size:17px;font-weight:600;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--color-border, #e8ecf1)}#china-map{width:100%;height:560px}.software-accordion{background:var(--color-bg-primary, #fff);border-radius:10px;border:1px solid var(--color-border, #e8ecf1);padding:16px}.section-title{font-size:17px;font-weight:600;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--color-border, #e8ecf1)}.sw-accordion-item{border:1px solid var(--color-border, #e5e7eb);border-radius:8px;margin-bottom:8px;overflow:hidden;transition:box-shadow .2s ease}.sw-accordion-item:last-child{margin-bottom:0}.sw-accordion-item:hover{box-shadow:0 2px 8px #0000000f}.sw-accordion-item.expanded{border-color:var(--color-primary, #3b82f6);box-shadow:0 2px 12px #3b82f614}.accordion-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s ease}.accordion-header:hover{background:#f6f9fa}.accordion-header-left{display:flex;align-items:center;gap:10px;min-width:0}.accordion-arrow{font-size:12px;color:var(--color-text-secondary, #9ca3af);transition:transform .2s ease;width:16px;text-align:center}.accordion-arrow.open{transform:rotate(90deg)}.sw-icon{width:24px;height:24px;flex-shrink:0;color:var(--color-text-secondary, #6b7280)}.sw-name{font-weight:600;font-size:14px;white-space:nowrap}.sw-desc{font-size:12px;color:var(--color-text-secondary, #9ca3af);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.accordion-header-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.stat-badge{display:inline-flex;align-items:center;gap:2px;padding:3px 8px;border-radius:4px;font-size:11px;font-weight:500;white-space:nowrap}.stat-badge.downloads{background:#eff6ff;color:#2563eb}.stat-badge.active{background:#ecfdf5;color:#059669}.stat-badge.version{background:#f3f4f6;color:#4b5563;font-family:monospace}.stat-badge.rating{background:#fffbeb;color:#d97706}.stat-badge .star{color:#f59e0b}.accordion-body{padding:0 16px 16px 52px;border-top:1px solid var(--color-border, #e5e7eb);animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.sub-section-title{font-size:13px;font-weight:600;color:var(--color-text, #374151);margin:14px 0 10px;display:flex;align-items:center;gap:8px}.sub-section-title:first-child{margin-top:10px}.log-count{font-size:11px;font-weight:400;color:var(--color-text-secondary, #9ca3af);background:#f3f4f6;padding:1px 8px;border-radius:10px}.usage-overview{margin-bottom:4px}.usage-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}.usage-stat{display:flex;flex-direction:column;gap:2px;padding:8px 10px;background:#fafcfd;border-radius:6px;border:1px solid oklch(95% .004 220)}.usage-label{font-size:11px;color:var(--color-text-secondary, #9ca3af)}.usage-value{font-size:15px;font-weight:600;color:var(--color-text, #111827)}.usage-value.mono{font-family:monospace;font-size:13px}.usage-value.small{font-size:12px;color:var(--color-text-secondary, #6b7280)}.usage-value .star{color:#f59e0b}.upload-log{margin-top:4px}.log-table{font-size:12px}.log-table th{padding:6px 10px;font-size:11px;background:#f2f6f7}.log-table td{padding:6px 10px;font-size:12px}.log-time{color:var(--color-text-secondary, #6b7280);white-space:nowrap;font-size:11px}.log-action{display:inline-block;padding:1px 6px;border-radius:3px;font-size:11px;font-weight:500;background:#f3f4f6;color:#4b5563}.log-action.upload{background:#eff6ff;color:#2563eb}.log-detail{color:var(--color-text-secondary, #9ca3af);font-size:11px;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mono{font-family:monospace}.loading-state,.empty-state{text-align:center;padding:40px 20px;color:var(--color-text-secondary, #7f8c8d)}@media(max-width:768px){.summary-cards{grid-template-columns:repeat(2,1fr)}#china-map{height:340px}.accordion-header{flex-direction:column;align-items:flex-start;gap:8px}.accordion-header-right{flex-wrap:wrap}.accordion-body{padding-left:16px}.usage-grid{grid-template-columns:repeat(2,1fr)}.log-table{display:block;overflow-x:auto}}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:8px;margin-bottom:16px}.summary-card{background:var(--color-bg-primary, #fff);border-radius:10px;padding:10px 14px;border:1px solid var(--color-border, #e8ecf1);text-align:center}.summary-card .number{font-size:26px;font-weight:700;margin-bottom:2px}.summary-card .label{font-size:12px;color:var(--color-text-secondary, #7f8c8d)}.summary-card.blue .number{color:#3498db}.summary-card.green .number{color:#27ae60}.summary-card.purple .number{color:#9b59b6}.summary-card.orange .number{color:#e67e22}.summary-card.teal .number{color:#1abc9c}.tab-nav{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap;background:var(--color-bg-primary, #fff);padding:12px;border-radius:10px;border:1px solid var(--color-border, #e8ecf1)}.tab-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border:1px solid var(--color-border, #e8ecf1);background:transparent;border-radius:6px;cursor:pointer;font-size:13px;color:var(--color-text-primary, #2c3e50);transition:all .15s}.tab-btn:hover{background:#f5f6fa}.tab-btn.active{background:#3498db;color:#fff;border-color:#3498db}.tab-icon{font-size:16px}.tab-label{white-space:nowrap}.tab-content{background:var(--color-bg-primary, #fff);border-radius:10px;border:1px solid var(--color-border, #e8ecf1);padding:16px;margin-bottom:16px}.tab-header{margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--color-border, #e8ecf1)}.tab-header h3{font-size:17px;font-weight:600;margin-bottom:4px}.tab-desc{font-size:12px;color:var(--color-text-secondary, #7f8c8d)}#visitor-map{width:100%;height:460px;margin-bottom:16px}.live-indicator{display:flex;align-items:center;gap:6px;font-size:12px;color:#27ae60}.live-dot{width:8px;height:8px;background:#27ae60;border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.recent-visitors h4{font-size:14px;font-weight:500;margin-bottom:8px}.keyword-list{display:flex;flex-direction:column;gap:8px}.keyword-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#f5f6fa;border-radius:6px;transition:background .15s}.keyword-item:hover{background:#e8ecf1}.keyword-rank{font-size:16px;font-weight:700;color:#3498db;min-width:24px}.keyword-text{flex:1;font-weight:500}.keyword-count{color:var(--color-text-secondary, #7f8c8d);font-size:13px}.keyword-trend{font-size:16px;font-weight:700}.keyword-trend.up{color:#27ae60}.keyword-trend.down{color:#e74c3c}.keyword-trend.stable{color:#95a5a6}.referrer-list{display:flex;flex-direction:column;gap:12px}.referrer-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--color-border, #e8ecf1)}.referrer-item:last-child{border-bottom:none}.referrer-info{display:flex;align-items:center;gap:8px;min-width:120px}.referrer-type{font-size:10px;padding:2px 6px;border-radius:3px;background:#f0f4f8;color:var(--color-text-secondary, #7f8c8d)}.referrer-name{font-weight:500;font-size:14px}.referrer-bar{flex:1;height:8px;background:#f0f4f8;border-radius:4px;overflow:hidden}.referrer-fill{height:100%;background:linear-gradient(90deg,#3498db,#1abc9c);border-radius:4px;transition:width .6s ease}.referrer-visits{font-size:13px;color:var(--color-text-secondary, #7f8c8d);min-width:60px;text-align:right}.referrer-percent{font-weight:600;font-size:14px;min-width:40px;text-align:right}.device-summary{display:flex;flex-direction:column;gap:16px}.device-chart{display:flex;justify-content:center;padding:16px;background:#f5f6fa;border-radius:8px}.device-legend{display:flex;gap:24px}.legend-item{display:flex;align-items:center;gap:8px;font-size:14px}.legend-color{width:12px;height:12px;border-radius:2px}.legend-color.desktop{background:#3498db}.legend-color.mobile{background:#27ae60}.legend-color.tablet{background:#9b59b6}.device-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px}.device-badge.type-desktop{background:#e8f4fd;color:#3498db}.device-badge.type-mobile{background:#e8f8f0;color:#27ae60}.device-badge.type-tablet{background:#f3e8f9;color:#9b59b6}#click-heatmap{width:100%;height:320px;margin-bottom:12px}.heatmap-legend{display:flex;align-items:center;gap:12px;font-size:12px;color:var(--color-text-secondary, #7f8c8d)}.heatmap-gradient{flex:1}.gradient-bar{height:10px;background:linear-gradient(90deg,#f5f6fa,#e74c3c);border-radius:5px}.empty-feature{text-align:center;padding:24px}.empty-feature .icon{font-size:48px;margin-bottom:12px}.empty-feature h4{font-size:16px;margin-bottom:4px}.empty-feature p{color:var(--color-text-secondary, #7f8c8d);font-size:13px;margin-bottom:16px}.coming-soon{font-size:11px;padding:2px 8px;background:#fff3e0;color:#e67e22;border-radius:4px}.feature-preview{margin-top:20px}.preview-card{background:#f5f6fa;border-radius:8px;padding:16px;text-align:left;max-width:400px;margin:0 auto}.preview-header{display:flex;justify-content:space-between;margin-bottom:12px;font-weight:500}.duration{color:var(--color-text-secondary, #7f8c8d);font-size:12px}.timeline{display:flex;flex-direction:column;gap:0;padding-left:20px;border-left:2px solid #e8ecf1}.timeline-item{position:relative;padding:8px 0 8px 12px}.timeline-dot{position:absolute;left:-7px;top:12px;width:10px;height:10px;background:#3498db;border-radius:50%}.timeline-content{display:flex;gap:12px;font-size:13px}.timeline-content .time{color:var(--color-text-secondary, #7f8c8d);font-family:monospace}.data-table.compact{font-size:12px}.data-table.compact th,.data-table.compact td{padding:6px 8px}.data-table.compact code{background:#f0f4f8;padding:2px 4px;border-radius:3px;font-size:11px}.loading-state{text-align:center;padding:40px 20px;color:var(--color-text-secondary, #7f8c8d)}.map-error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:12px;min-height:200px}.map-error-icon{font-size:40px}.map-error-text{color:var(--color-text-secondary, #7f8c8d);font-size:14px;margin:0}.empty-state{text-align:center;padding:40px 20px;color:var(--color-text-secondary, #7f8c8d)}.empty-state .icon{font-size:40px;margin-bottom:12px}.empty-state h3{margin-bottom:8px;color:var(--color-text-primary, #2c3e50)}@media(max-width:768px){.summary-cards{grid-template-columns:repeat(2,1fr)}#visitor-map{height:300px}.tab-nav{flex-direction:column}.tab-btn{justify-content:center}.device-legend{flex-direction:column;gap:8px}}.user-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(165deg,var(--blue-600),var(--blue-400));color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--text-sm);font-weight:600;flex-shrink:0}.role-badge{display:inline-block;padding:2px 10px;font-size:var(--text-xs);font-weight:600;border-radius:999px}.role-admin{background:#c536371a;color:var(--color-error)}.role-editor{background:var(--blue-50);color:var(--color-primary)}.role-viewer{background:var(--gray-100);color:var(--color-text-secondary)}.settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(380px,1fr));gap:var(--space-6)}:root{--blue-50: oklch(97% .01 250);--blue-100: oklch(93% .03 250);--blue-200: oklch(84% .07 250);--blue-400: oklch(55% .14 250);--blue-500: oklch(45% .16 250);--blue-600: oklch(38% .15 250);--blue-700: oklch(30% .12 250);--gray-50: oklch(97% .005 250);--gray-100: oklch(94% .005 250);--gray-200: oklch(89% .005 250);--gray-300: oklch(82% .008 250);--gray-400: oklch(70% .01 250);--gray-500: oklch(55% .01 250);--gray-600: oklch(43% .01 250);--gray-700: oklch(33% .01 250);--gray-800: oklch(23% .01 250);--gray-900: oklch(16% .01 250);--green-500: oklch(55% .15 160);--red-500: oklch(55% .18 25);--color-bg: var(--gray-50);--color-surface: oklch(100% 0 0);--color-text: var(--gray-900);--color-text-secondary: var(--gray-500);--color-text-tertiary: var(--gray-400);--color-border: var(--gray-200);--color-border-focus: var(--blue-500);--color-primary: var(--blue-600);--color-primary-hover: var(--blue-700);--color-primary-light: var(--blue-50);--color-error: var(--red-500);--color-success: var(--green-500);--font-sans: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, "Cascadia Code", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.25rem;--text-xl: 1.5rem;--text-2xl: 2rem;--leading-tight: 1.25;--leading-normal: 1.5;--leading-relaxed: 1.625;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--shadow-sm: 0 1px 3px oklch(0% 0 0 / .06), 0 1px 2px oklch(0% 0 0 / .04);--shadow-md: 0 4px 6px -1px oklch(0% 0 0 / .06), 0 2px 4px -2px oklch(0% 0 0 / .04);--duration-fast: .15s;--duration-normal: .25s;--sidebar-width: 260px;--sidebar-collapsed-width: 72px;--header-height: 64px}*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-text);background-color:var(--color-bg)}#root{min-height:100vh}.modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-8);width:90%;max-width:560px;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-md)}.modal-title{font-size:var(--text-xl);font-weight:700;margin-bottom:var(--space-6);padding-bottom:var(--space-4);border-bottom:1px solid var(--color-border)}.modal-actions{display:flex;justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-6);padding-top:var(--space-4);border-top:1px solid var(--color-border)}.form-textarea{resize:vertical;min-height:80px;font-family:var(--font-mono);font-size:var(--text-xs)}
