:root{--color-primary: #2563EB;--color-primary-hover: #1d4ed8;--color-primary-light: #eff6ff;--color-bg: #FFFFFF;--color-bg-subtle: #F8FAFC;--color-bg-muted: #F1F5F9;--color-text: #1E293B;--color-text-secondary: #64748B;--color-text-muted: #94A3B8;--color-border: #E2E8F0;--color-border-strong: #CBD5E1;--color-card-bg: #FFFFFF;--card-radius: 4px;--card-shadow: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--card-shadow-hover: 0 4px 12px rgba(0,0,0,.1);--color-up: #10B981;--color-up-bg: #d1fae5;--color-down: #EF4444;--color-down-bg: #fee2e2;--color-flat: #94A3B8;--color-flat-bg: #f1f5f9;--radius-sm: 4px;--radius-md: 4px;--radius-lg: 4px;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", sans-serif}html,body,#root{height:100%}body{font-family:var(--font-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--color-bg-subtle);color:var(--color-text)}.metric-value,.kpi-value,.stat-value,.funnel-bar,.store-metric b,.num{font-variant-numeric:tabular-nums;font-weight:700;color:var(--color-text)}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit}a{text-decoration:none;color:inherit}.emoji{display:inline-flex;align-items:center;justify-content:center;line-height:1}.btn-primary,button[type=submit],.btn-primary-outline{transition:background .18s ease,color .18s ease,border-color .18s ease,box-shadow .18s ease,transform .1s ease}.btn-primary:hover,button[type=submit]:hover,.btn-primary-outline:hover{box-shadow:0 3px 10px #2563eb4d;transform:translateY(-1px)}.btn-primary:active,button[type=submit]:active,.btn-primary-outline:active{transform:translateY(0);box-shadow:none}.btn,button:not([type]),.btn-secondary{transition:background .18s ease,color .18s ease,border-color .18s ease,box-shadow .18s ease}.btn:hover,button:not([type]):hover,.btn-secondary:hover{background:#f1f5f9;border-color:#cbd5e1}.btn-text,.text-btn,.link-btn{transition:color .15s ease,background .15s ease}.btn-text:hover,.text-btn:hover,.link-btn:hover{color:#2563eb;background:#eff6ff}table{width:100%;border-collapse:collapse}tbody tr{transition:background .12s ease}tbody tr:nth-child(2n){background:#fafbfc}tbody tr:nth-child(2n):hover{background:#f1f5f9!important}tbody tr:nth-child(odd):hover{background:#f8fafc}thead th{background:#f8fafc;color:#64748b;font-size:12px;font-weight:600;letter-spacing:.03em;border-bottom:2px solid #E2E8F0;padding:8px 12px;text-align:left}tbody td{padding:9px 12px;border-bottom:1px solid #F1F5F9;font-size:13px;color:#1e293b}tbody tr:last-child td{border-bottom:none}.card,.data-card,.kpi-card,.stat-card,.grid-card{transition:box-shadow .2s ease,transform .2s ease}.card:hover,.data-card:hover,.kpi-card:hover,.stat-card:hover,.grid-card:hover{box-shadow:var(--card-shadow-hover);transform:translateY(-1px)}input:focus,select:focus,textarea:focus{outline:none;border-color:#2563eb!important;box-shadow:0 0 0 3px #2563eb1a}.tag,.badge,.status-tag{transition:background .15s ease,color .15s ease,border-color .15s ease}.spinner,.loading{transition:opacity .2s ease}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;background:#f8fafc;color:#1e293b}.app{display:flex;min-height:100vh}.sidebar{width:220px;background:#fff;border-right:1px solid #E2E8F0;display:flex;flex-direction:column;position:fixed;height:100vh;left:0;top:0;z-index:100;transition:transform .3s ease}.logo{padding:20px 16px;border-bottom:1px solid #E2E8F0;display:flex;align-items:center;gap:10px}.logo-icon{width:28px;height:28px;background:#2563eb;color:#fff;display:flex;align-items:center;justify-content:center;border-radius:6px;font-size:14px;font-weight:700;flex-shrink:0}.logo-title{font-size:14px;font-weight:700;color:#1e293b;line-height:1.3}.logo-subtitle{font-size:11px;color:#94a3b8;margin-top:1px}.nav-menu{flex:1;padding:10px 8px;display:flex;flex-direction:column;gap:2px;overflow-y:auto}.nav-group{border-radius:4px;padding:4px;transition:background .15s}.nav-group:hover{background:#f8fafc}.nav-group-title{display:flex;align-items:center;gap:6px;padding:0 8px;height:36px;font-size:11px;font-weight:700;color:#94a3b8;letter-spacing:.05em;text-transform:uppercase;cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:4px;transition:color .15s;box-sizing:border-box}.nav-group-title:hover{color:#64748b}.nav-group-icon{width:14px;height:14px;display:flex;align-items:center;justify-content:center;color:#cbd5e1;flex-shrink:0}.nav-group-arrow{margin-left:auto;display:flex;align-items:center;color:#cbd5e1;transition:transform .2s ease}.nav-group-arrow.rotated{transform:rotate(90deg)}.nav-group-items{display:flex;flex-direction:column;gap:1px;overflow:hidden;max-height:500px;transition:max-height .3s ease,opacity .2s ease;opacity:1}.nav-group-items.hidden{max-height:0;opacity:0}.nav-item{display:flex;align-items:center;gap:8px;padding:0 10px;height:36px;border-radius:4px;cursor:pointer;transition:background .15s,color .15s;background:transparent;border:none;color:#64748b;font-size:13px;font-weight:500;text-align:left;white-space:nowrap;width:100%;box-sizing:border-box}.nav-item:hover{background:#f8fafc;color:#1e293b}.nav-item.active{background:#eff6ff;color:#2563eb;font-weight:600}.nav-icon{flex-shrink:0;width:16px;height:16px;display:flex;align-items:center;justify-content:center;color:inherit;opacity:.7}.nav-item.active .nav-icon{opacity:1}.nav-label{flex:1}.nav-dashboard{margin-bottom:6px;padding:3px;border-radius:4px;background:transparent;transition:background .15s}.nav-dashboard:hover{background:#f8fafc}.nav-dashboard .nav-item{border-radius:4px;font-weight:600;color:#64748b;height:36px;padding:0 10px}.nav-dashboard .nav-item:hover{background:#f1f5f9;color:#1e293b}.nav-dashboard .nav-item.active{background:#2563eb;color:#fff}.nav-dashboard .nav-item.active .nav-icon{opacity:1}.sidebar-footer{padding:12px 16px;border-top:1px solid #E2E8F0}.current-date{font-size:11px;color:#94a3b8;text-align:center;margin-bottom:8px}.version-badge{display:block;margin:0 auto;padding:3px 12px;background:#f8fafc;border:1px solid #E2E8F0;border-radius:12px;color:#94a3b8;font-size:11px;cursor:pointer;transition:all .2s}.version-badge:hover{background:#f1f5f9;color:#64748b;border-color:#cbd5e1}.main-content{flex:1;margin-left:220px;padding:20px;min-height:100vh;overflow-y:auto;max-height:100vh;transition:margin-left .3s ease}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:56px;background:#fff;border-bottom:1px solid #E2E8F0;color:#1e293b;align-items:center;justify-content:space-between;padding:0 16px;z-index:200}.mobile-logo{display:flex;align-items:center;gap:8px}.mobile-logo-icon{font-size:20px}.mobile-logo-text{font-size:14px;font-weight:700}.hamburger{display:flex;flex-direction:column;justify-content:center;align-items:center;width:36px;height:36px;background:transparent;border:none;cursor:pointer;gap:5px}.hamburger span{display:block;width:22px;height:2px;background:#1e293b;border-radius:2px;transition:all .3s}.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.hamburger.active span:nth-child(2){opacity:0}.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.mobile-overlay{display:none;position:fixed;inset:0;background:#0006;z-index:150;opacity:0;transition:opacity .3s}.mobile-overlay.active{opacity:1}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#e2e8f0;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#cbd5e1}@media(max-width:1024px){.sidebar{width:180px}.main-content{margin-left:180px}}@media(max-width:768px){.sidebar{transform:translate(-100%);width:260px;background:#fff}.sidebar.mobile-open{transform:translate(0)}.main-content{margin-left:0;margin-top:56px;padding:16px;max-height:calc(100vh - 56px)}.mobile-header{display:flex}.mobile-overlay{display:block;pointer-events:none}.mobile-overlay.active{pointer-events:auto}.nav-group-items.hidden{max-height:none;opacity:1}.nav-group-arrow{display:none}}@media(max-width:480px){.main-content{padding:12px}.nav-menu{padding:8px 6px}.nav-item{padding:8px 10px;font-size:13px}}.modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:8px;max-width:90%;max-height:80vh;overflow:hidden;box-shadow:0 20px 60px #0003;animation:slideUp .25s ease}@keyframes slideUp{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}.changelog-modal{width:480px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #E2E8F0;background:#f8fafc}.modal-header h2{font-size:15px;font-weight:700;color:#1e293b}.modal-close{width:28px;height:28px;border:none;background:transparent;font-size:20px;color:#94a3b8;cursor:pointer;border-radius:4px;line-height:1;transition:all .15s}.modal-close:hover{background:#f1f5f9;color:#64748b}.modal-body{padding:20px;max-height:60vh;overflow-y:auto}.changelog-item{padding:14px 16px;background:#f8fafc;border-radius:4px;margin-bottom:10px;border:1px solid #E2E8F0}.changelog-item:last-child{margin-bottom:0}.changelog-version{font-size:14px;font-weight:700;color:#2563eb;margin-bottom:3px}.changelog-date{font-size:12px;color:#94a3b8;margin-bottom:10px}.changelog-changes{margin:0;padding-left:18px}.changelog-changes li{font-size:13px;color:#475569;line-height:1.7}
