*,:before,:after{box-sizing:border-box;margin:0;padding:0}@keyframes spin{to{transform:rotate(360deg)}}:root{--primary:#ea580c;--primary-dark:#c2410c;--primary-light:#fff7ed;--bg:#f1f5f9;--sidebar-bg:#1e2334;--sidebar-active:#ea580c;--card-bg:#fff;--text-primary:#1e293b;--text-secondary:#475569;--text-muted:#94a3b8;--border:#e2e8f0;--success:#10b981;--danger:#ef4444;--warning:#f59e0b;--info:#3b82f6;--sidebar-width:220px;--topbar-height:60px;--radius:12px;--shadow:0 1px 3px rgba(0,0,0,.07), 0 4px 12px rgba(0,0,0,.05);--shadow-md:0 4px 16px rgba(0,0,0,.1)}[data-theme=dark]{--bg:#0f172a;--card-bg:#1e293b;--border:#334155;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--primary:#fb923c;--primary-dark:#ea580c;--primary-light:#431407;--sidebar-bg:#0c1222;--shadow:0 1px 3px rgba(0,0,0,.2), 0 4px 12px rgba(0,0,0,.15);--shadow-md:0 4px 16px rgba(0,0,0,.25)}[data-theme=dark] .data-table th{background:#1e293b}[data-theme=dark] .data-table tbody tr:hover{background:#334155}[data-theme=dark] .data-table tbody tr.selected{background:#431407}[data-theme=dark] .kpi-card,[data-theme=dark] .table-card,[data-theme=dark] .chart-card{box-shadow:0 2px 8px rgba(0,0,0,.3)}[data-theme=dark] .tag-success{color:#6ee7b7;background:#064e3b}[data-theme=dark] .tag-danger{color:#fca5a5;background:#7f1d1d}[data-theme=dark] .tag-warning{color:#fcd34d;background:#78350f}[data-theme=dark] .tag-info{color:#93c5fd;background:#1e3a5f}[data-theme=dark] .tag-muted{color:#94a3b8;background:#334155}.theme-toggle{cursor:pointer;color:var(--text-secondary);align-items:center;gap:10px;padding:10px 14px;font-size:13px;transition:background .15s;display:flex}.theme-toggle:hover{background:var(--bg)}.theme-toggle-icon{font-size:16px}.theme-toggle-track{background:var(--border);border-radius:10px;width:36px;height:20px;transition:background .2s;position:relative}.theme-toggle-track:after{content:"";background:#fff;border-radius:50%;width:16px;height:16px;transition:transform .2s;position:absolute;top:2px;left:2px;box-shadow:0 1px 3px rgba(0,0,0,.2)}[data-theme=dark] .theme-toggle-track{background:var(--primary)}[data-theme=dark] .theme-toggle-track:after{transform:translate(16px)}html,body{background:var(--bg);height:100%;color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;font-size:14px;line-height:1.5}.sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);z-index:100;flex-direction:column;transition:transform .25s;display:flex;position:fixed;top:0;bottom:0;left:0}.master-detail{height:calc(100vh - var(--topbar-height) - 48px);gap:0;display:flex}.master-panel{border-right:1px solid var(--border);background:var(--card-bg);width:40%;min-width:320px;max-width:500px;overflow-y:auto}.master-panel--full{width:100%;max-width:none}.detail-panel{background:var(--bg);flex:1;padding:24px;overflow-y:auto}.detail-panel--empty{color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;display:flex}.detail-close{background:var(--bg);width:28px;height:28px;color:var(--text-muted);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:14px;transition:background .15s;display:flex;position:absolute;top:12px;right:12px}.detail-close:hover{background:var(--border);color:var(--text-primary)}.main-wrapper{margin-left:var(--sidebar-width);flex-direction:column;min-height:100vh;transition:margin-left .25s;display:flex}.sidebar-logo{border-bottom:1px solid rgba(255,255,255,.07);align-items:center;gap:10px;padding:20px 18px;display:flex}.logo-icon{background:var(--primary);color:#fff;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:18px;font-weight:800;display:flex}.logo-text{color:#fff;letter-spacing:.5px;font-size:16px;font-weight:700}.sidebar-nav{flex:1;padding:12px 10px;overflow-y:auto}.nav-item{color:rgba(255,255,255,.6);border-radius:8px;align-items:center;gap:10px;margin-bottom:2px;padding:10px 12px;font-size:13.5px;text-decoration:none;transition:all .18s;display:flex}.nav-item svg{fill:currentColor;flex-shrink:0;width:18px;height:18px}.nav-item:hover{color:#fff;background:rgba(255,255,255,.07)}.nav-item.active{color:#fff;background:var(--primary)}.nav-divider{background:rgba(255,255,255,.07);height:1px;margin:10px 4px}.sidebar-footer{border-top:1px solid rgba(255,255,255,.07);padding:14px 16px}.last-update{color:rgba(255,255,255,.3);font-size:11px}.topbar{height:var(--topbar-height);background:var(--card-bg);border-bottom:1px solid var(--border);z-index:50;align-items:center;gap:12px;padding:0 24px;display:flex;position:-webkit-sticky;position:sticky;top:0;box-shadow:0 1px 4px rgba(0,0,0,.04)}.menu-toggle{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;border-radius:6px;padding:6px;display:none}.menu-toggle svg{fill:currentColor;width:20px;height:20px}.menu-toggle:hover{background:var(--bg)}.topbar-title{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:16px;font-weight:600;overflow:hidden}.topbar-actions{flex-shrink:0;align-items:center;gap:10px;display:flex;position:relative}.date-range select{border:1px solid var(--border);color:var(--text-primary);background:var(--bg);cursor:pointer;border-radius:8px;outline:none;padding:7px 12px;font-size:13px}.btn-primary{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;transition:background .18s;display:flex}.btn-primary svg{fill:currentColor;width:15px;height:15px}.btn-primary:hover{background:var(--primary-dark)}.btn-secondary{background:var(--bg);color:var(--text-primary);border:1px solid var(--border);cursor:pointer;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;transition:all .18s;display:flex}.btn-secondary:hover{background:var(--border)}.btn-outline{color:var(--text-primary);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;transition:all .18s;display:flex}.btn-outline:hover{background:var(--bg);border-color:var(--primary);color:var(--primary)}.main-content{flex-direction:column;flex:1;min-height:0;padding:24px;display:flex;overflow-y:auto}.main-content>.page-layout,.main-content>.table-card,.main-content .sku-panel{flex-direction:column;flex:1;min-height:0;display:flex}.todo-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;margin-bottom:24px;display:grid}.todo-card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;text-align:center;border-left:3px solid transparent;flex-direction:column;align-items:center;padding:16px;transition:all .18s;display:flex}.todo-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.todo-card--orange{border-left-color:var(--primary)}.todo-card--red{border-left-color:var(--danger)}.todo-card--blue{border-left-color:var(--info)}.todo-card--green{border-left-color:var(--success)}.todo-card--yellow{border-left-color:var(--warning)}.todo-icon{margin-bottom:6px;font-size:24px}.todo-count{color:var(--text-primary);font-size:28px;font-weight:700;line-height:1.2}.todo-label{color:var(--text-secondary);margin-top:4px;font-size:12px;font-weight:500}.todo-action{color:var(--primary);margin-top:8px;font-size:11px;font-weight:600}.kpi-card--drillable{cursor:pointer;transition:transform .18s,box-shadow .18s}.kpi-card--drillable:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.kpi-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;max-height:120px;margin-bottom:24px;display:grid;overflow-x:auto}.kpi-card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;position:relative;overflow:hidden}.kpi-card:before{content:"";height:3px;position:absolute;top:0;left:0;right:0}.kpi-card.orange:before{background:var(--primary)}.kpi-card.green:before{background:var(--success)}.kpi-card.red:before{background:var(--danger)}.kpi-card.blue:before{background:var(--info)}.kpi-card.yellow:before{background:var(--warning)}.kpi-card.purple:before{background:#8b5cf6}.kpi-card.cyan:before{background:#06b6d4}.kpi-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;margin-bottom:8px;font-size:12px;font-weight:500}.kpi-value{color:var(--text-primary);word-break:break-all;overflow-wrap:break-word;margin-bottom:8px;font-size:26px;font-weight:700;line-height:1.2}.kpi-change{align-items:center;gap:3px;font-size:12px;display:flex}.kpi-change.up{color:var(--success)}.kpi-change.down{color:var(--danger)}.kpi-change.flat{color:var(--text-muted)}.chart-grid{grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:20px;margin-bottom:24px;display:grid}.chart-card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}.chart-card.full-width{grid-column:1/-1}.card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.card-title{color:var(--text-primary);font-size:14px;font-weight:600}.card-subtitle{color:var(--text-muted);margin-top:2px;font-size:12px}.card-actions{gap:6px;display:flex}.tag{border-radius:20px;align-items:center;padding:3px 8px;font-size:11px;font-weight:500;display:inline-flex}.tag-success{color:#059669;background:#d1fae5}.tag-danger{color:#dc2626;background:#fee2e2}.tag-warning{color:#d97706;background:#fef3c7}.tag-info{color:#2563eb;background:#dbeafe}.tag-muted{background:var(--bg);color:var(--text-muted)}.table-card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;flex:1;min-height:0;margin-bottom:24px;display:flex;overflow:hidden}.table-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.table-title{font-size:14px;font-weight:600}.search-box{border:1px solid var(--border);background:var(--bg);border-radius:8px;align-items:center;gap:6px;padding:6px 12px;display:flex}.search-box input{color:var(--text-primary);background:0 0;border:none;outline:none;width:200px;font-size:13px}.search-box svg{width:14px;height:14px;fill:var(--text-muted)}.data-table{border-collapse:collapse;width:100%}.data-table th{background:var(--bg);text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;white-space:nowrap;z-index:10;box-shadow:0 1px 0 var(--border);padding:10px 16px;font-size:12px;font-weight:600;position:-webkit-sticky;position:sticky;top:0}.data-table td{border-top:1px solid var(--border);color:var(--text-primary);padding:12px 16px;font-size:13px}.data-table tbody tr{cursor:pointer;transition:all .15s}.data-table tbody tr:hover{background:#f1f5f9;transform:translate(2px);box-shadow:0 2px 8px rgba(0,0,0,.06)}.data-table tbody tr.selected{border-left:3px solid var(--primary);background:#fff7ed}.data-table tr:hover td{background:0 0}.table-img{object-fit:cover;background:var(--bg);border-radius:6px;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;display:inline-flex}.pagination{border-top:1px solid var(--border);color:var(--text-muted);justify-content:space-between;align-items:center;padding:12px 20px;font-size:13px;display:flex}.pagination-btns{gap:4px;display:flex}.page-btn{border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:6px;justify-content:center;align-items:center;width:30px;height:30px;font-size:13px;display:flex}.page-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.page-btn:hover:not(.active){background:var(--bg)}.page-layout,.page-content,.page-body{flex-direction:column;flex:1;min-height:0;display:flex}.pagination-sticky{background:var(--card-bg);border-top:1px solid var(--border);z-index:100;padding:12px 20px;position:-webkit-sticky;position:sticky;bottom:0;box-shadow:0 -2px 8px rgba(0,0,0,.04)}.table-scroll{flex:1;min-height:0;overflow:auto}.page-header{flex-shrink:0;margin-bottom:16px}.page-header h1{color:var(--text-primary);margin:0 0 4px;font-size:20px;font-weight:600}.page-header .subtitle{color:var(--text-muted);font-size:13px}.page-toolbar{flex-wrap:wrap;flex-shrink:0;gap:8px;margin-bottom:16px;display:flex}.table-toolbar{align-items:center;gap:8px;display:flex}.empty-state{text-align:center;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;padding:60px 20px;display:flex}.empty-state svg{opacity:.5;width:64px;height:64px;margin-bottom:16px}.empty-state p{margin:0;font-size:14px}.page-ellipsis{color:var(--text-muted);padding:0 4px}.batch-bar{z-index:20;background:var(--card-bg);border-bottom:2px solid var(--primary);justify-content:space-between;align-items:center;padding:10px 16px;animation:.2s slideDown;display:flex;position:-webkit-sticky;position:sticky;top:0}@keyframes slideDown{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}.batch-bar-info{color:var(--text-primary);align-items:center;gap:10px;font-size:13px;font-weight:500;display:flex}.batch-bar-count{background:var(--primary);color:#fff;border-radius:12px;padding:2px 10px;font-size:12px;font-weight:600}.batch-bar-actions{gap:8px;display:flex}.batch-bar-actions .btn-secondary,.batch-bar-actions .btn-primary{padding:6px 14px;font-size:12px}.row-checkbox{width:16px;height:16px;accent-color:var(--primary);cursor:pointer;flex-shrink:0}.import-page{max-width:860px}.import-tabs{background:var(--bg);border-radius:10px;gap:0;width:-webkit-fit-content;width:-moz-fit-content;width:fit-content;margin-bottom:24px;padding:4px;display:flex}.import-tab{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:7px;padding:8px 20px;font-size:13px;font-weight:500;transition:all .18s}.import-tab.active{background:var(--card-bg);color:var(--text-primary);box-shadow:var(--shadow)}.import-panel{display:none}.import-panel.active{display:block}.drop-zone{border:2px dashed var(--border);border-radius:var(--radius);text-align:center;cursor:pointer;background:var(--card-bg);padding:48px 24px;transition:all .2s}.drop-zone:hover,.drop-zone.drag-over{border-color:var(--primary);background:var(--primary-light)}.drop-icon{margin-bottom:12px;font-size:48px}.drop-title{margin-bottom:6px;font-size:16px;font-weight:600}.drop-hint{color:var(--text-muted);margin-bottom:16px;font-size:13px}.supported-types{justify-content:center;gap:8px;margin-top:12px;display:flex}.type-badge{background:var(--bg);color:var(--text-secondary);border-radius:20px;padding:3px 10px;font-size:11px;font-weight:600}.import-mapping{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);margin-top:16px;padding:20px;display:none}.mapping-title{align-items:center;gap:8px;margin-bottom:16px;font-size:14px;font-weight:600;display:flex}.mapping-row{grid-template-columns:1fr 40px 1fr;align-items:center;gap:10px;margin-bottom:10px;display:grid}.mapping-arrow{text-align:center;color:var(--text-muted);font-size:18px}.mapping-select{border:1px solid var(--border);background:var(--bg);border-radius:8px;outline:none;width:100%;padding:7px 10px;font-size:13px}.manual-form{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px}.form-grid{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px;display:grid}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px;font-size:12px;font-weight:600}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--border);color:var(--text-primary);background:var(--bg);border-radius:8px;outline:none;padding:8px 12px;font-size:13px;transition:border-color .18s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);background:#fff}.form-group.full{grid-column:1/-1}.section-header{flex-shrink:0;margin-bottom:20px}.section-title{color:var(--text-primary);font-size:18px;font-weight:700}.section-desc{color:var(--text-muted);margin-top:4px;font-size:13px}.empty-state{text-align:center;color:var(--text-muted);padding:60px 20px}.empty-icon{margin-bottom:12px;font-size:48px}.empty-title{color:var(--text-secondary);margin-bottom:6px;font-size:16px;font-weight:600}.empty-desc{font-size:13px}.empty-action{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:8px;align-items:center;gap:6px;margin-top:16px;padding:10px 24px;font-size:13px;font-weight:500;transition:background .18s;display:inline-flex}.empty-action:hover{background:var(--primary-dark)}.empty-action svg{fill:currentColor;width:16px;height:16px}.empty-hint-action{background:var(--bg);color:var(--text-secondary);border:1px solid var(--border);cursor:pointer;border-radius:6px;align-items:center;gap:4px;margin-top:8px;padding:6px 14px;font-size:12px;transition:all .15s;display:inline-flex}.empty-hint-action:hover{border-color:var(--primary);color:var(--primary)}.progress-bar{background:var(--bg);border-radius:3px;height:6px;margin-top:6px;overflow:hidden}.progress-fill{background:var(--primary);border-radius:3px;height:100%;transition:width .4s}.progress-fill.green{background:var(--success)}.progress-fill.red{background:var(--danger)}.progress-fill.blue{background:var(--info)}.metric-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:10px 0;display:flex}.metric-row:last-child{border-bottom:none}.metric-label{color:var(--text-secondary);font-size:13px}.metric-value{font-size:13px;font-weight:600}.toast-container{z-index:9999;flex-direction:column;gap:8px;display:flex;position:fixed;top:20px;right:20px}.toast{color:#fff;box-shadow:var(--shadow-md);background:#1e293b;border-radius:10px;align-items:center;gap:8px;min-width:220px;padding:12px 18px;font-size:13px;animation:.25s slideIn;display:flex}.toast.success{border-left:3px solid var(--success)}.toast.error{border-left:3px solid var(--danger)}.toast.info{border-left:3px solid var(--info)}@keyframes slideIn{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}.table-scroll{-webkit-overflow-scrolling:touch;min-height:0;max-height:calc(100vh - var(--topbar-height) - 100px);flex:1;overflow:auto}.table-scroll--with-kpi{max-height:calc(100vh - var(--topbar-height) - 180px)}.table-scroll--tall{max-height:70vh}.table-scroll--short{max-height:30vh}.freeze-col{z-index:5;background:var(--card-bg);position:-webkit-sticky;position:sticky;left:0}.data-table th.freeze-col{z-index:15;background:var(--bg)}.freeze-col:after{content:"";pointer-events:none;background:linear-gradient(90deg,rgba(0,0,0,.06),transparent);width:6px;position:absolute;top:0;bottom:0;right:-6px}.sku-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:3px solid transparent;margin-bottom:-2px;padding:12px 20px;font-size:14px;font-weight:500;transition:color .15s,border-color .15s}.sku-tab:hover{color:var(--text-primary)}.sku-tab-active{color:var(--primary)!important;border-bottom-color:var(--primary)!important}.fr-seg-bar{background:var(--bg);border:1px solid var(--border);border-radius:10px;gap:0;width:-webkit-fit-content;width:-moz-fit-content;width:fit-content;margin-bottom:18px;padding:4px;display:flex;box-shadow:inset 0 1px 3px rgba(0,0,0,.08)}.fr-tab{cursor:pointer;color:var(--text-secondary);white-space:nowrap;background:0 0;border:none;border-radius:7px;padding:7px 20px;font-size:13px;font-weight:500;transition:all .2s}.fr-tab:hover{background:rgba(var(--primary-rgb),.08);color:var(--primary)}.fr-tab-active{border:1px solid var(--border);box-shadow:0 1px 4px rgba(0,0,0,.12);background:var(--card-bg)!important;color:var(--primary)!important;font-weight:600!important}.fr-tab-sm{border-radius:6px;padding:5px 16px;font-size:13px}.pager{border-top:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;display:flex}.pager-info{color:var(--text-muted);font-size:13px}.pager-btns{gap:4px;display:flex}.pager-btn{border:1px solid var(--border);background:var(--bg);min-width:32px;height:32px;color:var(--text-secondary);cursor:pointer;border-radius:6px;justify-content:center;align-items:center;padding:0 8px;font-size:13px;transition:all .15s;display:inline-flex}.pager-btn:hover:not(:disabled){background:var(--primary);color:#fff;border-color:var(--primary)}.pager-btn.active{background:var(--primary);color:#fff;border-color:var(--primary);font-weight:600}.pager-btn:disabled{opacity:.35;cursor:not-allowed}.modal-overlay{z-index:2000;background:rgba(0,0,0,.45);justify-content:center;align-items:center;animation:.18s fadeIn;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-box{background:var(--card-bg);border-radius:14px;flex-direction:column;width:90%;max-width:560px;max-height:90vh;animation:.2s slideUp;display:flex;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.25)}.modal-box.wide{max-width:800px}.modal-box.x-wide{max-width:960px}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 20px 14px;display:flex}.modal-title{color:var(--text-primary);font-size:15px;font-weight:700}.modal-close{background:var(--bg);width:28px;height:28px;color:var(--text-muted);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:14px;transition:background .15s;display:flex}.modal-close:hover{background:var(--border);color:var(--text-primary)}.modal-body{flex:1;min-height:0;padding:20px;overflow-y:auto}.modal-footer{border-top:1px solid var(--border);background:var(--bg);flex-shrink:0;justify-content:flex-end;gap:12px;padding:14px 20px;display:flex}@media (max-width:1024px){.modal-box.x-wide{max-width:85vw}}@media (max-width:768px){.modal-box{width:95%;max-height:85vh}.modal-box.wide,.modal-box.x-wide{max-width:95%}}.form-input{border:1px solid var(--border);width:100%;color:var(--text-primary);background:var(--bg);border-radius:8px;outline:none;padding:9px 12px;font-size:13px;transition:border-color .18s}.form-input:focus{border-color:var(--primary);background:#fff}.kpi-icon{margin-bottom:6px;font-size:22px;display:block}.nav-sub{font-size:13px;padding-left:36px!important}.nav-sub svg{opacity:.8;width:16px!important;height:16px!important}.nav-group{margin-bottom:2px}.nav-group-title{color:rgba(255,255,255,.7);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;cursor:pointer;border-radius:8px;align-items:center;gap:10px;padding:10px 12px;font-size:14px;font-weight:500;transition:background .15s,color .15s;display:flex}.nav-group-title:hover{color:#fff;background:rgba(255,255,255,.07)}.nav-group-title svg{fill:currentColor;flex-shrink:0;width:18px;height:18px}.nav-group-title .nav-arrow{opacity:.6;flex-shrink:0;margin-left:auto;transition:transform .22s;width:14px!important;height:14px!important}.nav-group.expanded .nav-group-title .nav-arrow{opacity:.9;transform:rotate(180deg)}.nav-group .nav-group-children{max-height:0;transition:max-height .25s;overflow:hidden}.nav-group.expanded .nav-group-children{max-height:400px}#userBadge{background:var(--bg);border:1px solid var(--border);cursor:pointer;border-radius:20px;flex-shrink:0;align-items:center;gap:8px;padding:6px 12px;transition:background .18s;display:flex}#userBadge:hover{background:var(--border)}#userAvatar{color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;font-weight:700;display:flex}#userName{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;max-width:80px;font-size:13px;overflow:hidden}.badge-arrow{width:14px;height:14px;fill:var(--text-muted);flex-shrink:0}#userMenu{background:var(--card-bg);border:1px solid var(--border);z-index:1000;border-radius:12px;min-width:160px;display:none;position:absolute;top:60px;right:20px;overflow:hidden;box-shadow:0 8px 24px rgba(0,0,0,.15)}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#9ca3af}@media (max-width:1024px){:root{--sidebar-width:200px}.kpi-grid{grid-template-columns:repeat(3,1fr)}.chart-grid{grid-template-columns:1fr}}@media (max-width:768px){.btn-primary,.btn-secondary,.btn-outline{min-height:44px!important;padding:10px 16px!important;font-size:14px!important}.mobile-action-bar{background:var(--card-bg);border-top:1px solid var(--border);z-index:100;gap:8px;padding:12px 16px;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -2px 8px rgba(0,0,0,.05)}.mobile-action-bar .btn-primary,.mobile-action-bar .btn-secondary{flex:1;justify-content:center}.sidebar{z-index:300;width:240px;transform:translate(-100%)}.sidebar.open{transform:translate(0);box-shadow:4px 0 24px rgba(0,0,0,.3)}.sidebar-overlay{z-index:299;background:rgba(0,0,0,.45);display:none;position:fixed;top:0;bottom:0;left:0;right:0}.sidebar-overlay.show{display:block}.main-wrapper{margin-left:0}.menu-toggle{display:flex}.topbar{z-index:200;gap:6px;height:52px;padding:0 12px;position:-webkit-sticky;position:sticky;top:0}.topbar-title{white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:14px;font-weight:600;overflow:hidden}.topbar-actions{flex-shrink:0;gap:4px}.date-range,.topbar-actions>.btn-primary,#syncStatus{display:none!important}#userBadge{background:0 0;border:none;border-radius:50%;justify-content:center;gap:0;width:36px;height:36px;padding:4px}.badge-arrow,#userName{display:none}#userMenu{top:48px;right:0}.main-content{padding:12px 10px 80px}.master-detail{flex-direction:column;height:auto;min-height:60vh}.master-panel{border-right:none;border-bottom:1px solid var(--border);width:100%;min-width:0;max-width:none;max-height:40vh}.detail-panel{padding:16px}.detail-sheet{background:var(--card-bg);z-index:1000;border-radius:16px 16px 0 0;max-height:80vh;transition:transform .3s;position:fixed;bottom:0;left:0;right:0;overflow-y:auto;transform:translateY(100%);box-shadow:0 -4px 20px rgba(0,0,0,.15)}.detail-sheet.open{transform:translateY(0)}.detail-sheet-handle{background:var(--border);border-radius:2px;width:40px;height:4px;margin:8px auto}.todo-grid{grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:16px}.todo-card{padding:12px 10px}.todo-count{font-size:22px}.todo-icon{font-size:20px}.kpi-grid{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px}.kpi-card{padding:14px 12px}.kpi-icon{margin-bottom:4px;font-size:18px}.kpi-label{font-size:11px}.kpi-value{font-size:18px}.kpi-change{font-size:11px}.chart-grid{grid-template-columns:1fr;gap:12px;margin-bottom:16px}.chart-card{padding:14px 12px}.chart-card canvas{max-height:200px!important}.card-title{font-size:13px}.table-card{border-radius:10px}.table-header{flex-wrap:wrap;gap:8px;padding:12px 14px}.table-title{font-size:13px}.table-scroll{-webkit-overflow-scrolling:touch;overflow-x:auto}.data-table{min-width:560px}.data-table th{padding:8px 10px;font-size:11px}.data-table td{white-space:nowrap;padding:9px 10px;font-size:12px}.pagination{flex-wrap:wrap;gap:8px;padding:10px 14px;font-size:12px}.search-box{padding:5px 10px}.search-box input{width:100px;font-size:12px}.section-header{margin-bottom:14px}.section-title{font-size:15px}.section-desc{font-size:12px}.import-page{max-width:100%}.import-tabs{width:100%}.import-tab{text-align:center;flex:1;padding:7px 8px;font-size:12px}.form-grid{grid-template-columns:1fr}.drop-zone{padding:32px 16px}.drop-icon{font-size:36px}.drop-title{font-size:14px}.mapping-row{grid-template-columns:1fr 24px 1fr;gap:6px}.modal-box{width:95%;max-height:85vh}}.field-hint{background:var(--bg);width:16px;height:16px;color:var(--text-muted);cursor:help;vertical-align:middle;border-radius:50%;justify-content:center;align-items:center;margin-left:4px;font-size:11px;font-weight:600;display:inline-flex;position:relative}.field-hint:before{content:"?"}.field-hint:after{content:attr(data-tip);color:#fff;white-space:nowrap;white-space:normal;opacity:0;pointer-events:none;z-index:100;background:#1e293b;border-radius:6px;max-width:260px;margin-bottom:6px;padding:8px 12px;font-size:12px;font-weight:400;transition:opacity .15s,transform .15s;position:absolute;bottom:100%;left:50%;transform:translate(-50%);box-shadow:0 4px 12px rgba(0,0,0,.2)}.field-hint:hover:after{opacity:1;pointer-events:auto}label .field-hint{margin-left:6px}.fs-11{font-size:11px}.fs-12{font-size:12px}.fs-13{font-size:13px}.fs-14{font-size:14px}.fs-16{font-size:16px}.fs-18{font-size:18px}.fs-20{font-size:20px}.fw-500{font-weight:500}.fw-600{font-weight:600}.fw-700{font-weight:700}.c-danger{color:#ef4444}.c-secondary{color:var(--text-secondary)}.c-muted{color:var(--text-muted)}.c-primary{color:var(--primary)}.c-white{color:#fff}.c-warning{color:#f59e0b}.c-success{color:var(--success)}.c-info{color:var(--info)}.d-none{display:none}.d-flex{display:flex}.d-block{display:block}.d-inline{display:inline}.d-inline-flex{display:inline-flex}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.gap-4{gap:4px}.gap-6{gap:6px}.gap-8{gap:8px}.gap-10{gap:10px}.gap-12{gap:12px}.flex-wrap{flex-wrap:wrap}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.flex-1{flex:1}.flex-col{flex-direction:column}.text-center{text-align:center}.text-right{text-align:right}.text-left{text-align:left}.nowrap{white-space:nowrap}.o-ellipsis{text-overflow:ellipsis;overflow:hidden}.bd{border:1px solid var(--border)}.bd-none{border:none}.bd-ddd{border:1px solid #ddd}.bd-danger{border:1px solid #fca5a5}.bt{border-top:1px solid var(--border)}.bb{border-bottom:1px solid var(--border)}.r-4{border-radius:4px}.r-6{border-radius:6px}.r-8{border-radius:8px}.r-10{border-radius:10px}.r-12{border-radius:12px}.r-full{border-radius:50%}.mb-4{margin-bottom:4px}.mb-6{margin-bottom:6px}.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.ml-4{margin-left:4px}.ml-8{margin-left:8px}.mr-4{margin-right:4px}.p-8{padding:8px}.p-10{padding:10px}.p-16{padding:16px}.p-20{padding:20px}.px-8{padding-left:8px;padding-right:8px}.py-4{padding-top:4px;padding-bottom:4px}.cur-ptr{cursor:pointer}.bg-card{background:var(--card-bg)}.bg-main{background:var(--bg)}.bg-transparent{background:0 0}.overflow-hidden{overflow:hidden}.ox-auto{overflow-x:auto}.w-full{width:100%}.h-full{height:100%}.min-w-100{min-width:100px}.gc-full{grid-column:1/-1}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.th-sticky{z-index:10;background:var(--card-bg);min-width:100px;position:-webkit-sticky;position:sticky;top:0}.btn-xs{padding:3px 8px;font-size:12px}.btn-sm{padding:6px 12px;font-size:13px}.btn-md{padding:8px 16px;font-size:13px}.btn-lg{padding:10px 20px;font-size:14px}.form-label{color:var(--text-secondary);margin-bottom:6px;font-size:13px;font-weight:500;display:block}.form-label-dark{color:var(--text-primary);margin-bottom:6px;font-size:13px;font-weight:500;display:block}.form-label-title{margin-bottom:8px;font-weight:600;display:block}.modal-close-btn{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;padding:4px;font-size:20px;line-height:1}.empty-hint{text-align:center;color:var(--text-secondary);padding:40px}.loading-overlay{z-index:9999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:rgba(0,0,0,.5);flex-direction:column;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.loading-spinner{border:4px solid rgba(255,255,255,.2);border-top-color:var(--primary);border-radius:50%;width:48px;height:48px;animation:.8s linear infinite spin}.loading-text{color:#fff;margin-top:16px;font-size:14px;font-weight:500}.loading-progress{background:rgba(255,255,255,.2);border-radius:2px;width:200px;height:4px;margin-top:12px;overflow:hidden}.loading-progress-bar{background:var(--primary);height:100%;transition:width .3s}.dashboard-container{padding-bottom:40px}.db-section{margin-bottom:24px}.db-section-header{justify-content:space-between;align-items:center;margin-bottom:12px;padding:0 2px;display:flex}.db-section-title{color:var(--text-primary);font-size:16px;font-weight:600}.dashboard-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.dashboard-header-left,.dashboard-greeting{align-items:center;gap:12px;display:flex}.dashboard-greeting-emoji{font-size:28px;line-height:1}.dashboard-greeting-text{color:var(--text-primary);font-size:20px;font-weight:700;line-height:1.3}.dashboard-greeting-text strong{color:var(--primary)}.dashboard-greeting-date{color:var(--text-muted);margin-top:2px;font-size:13px;font-weight:400}.dashboard-header-right{align-items:center;gap:12px;display:flex}.dashboard-date-filter{background:var(--bg);border:1px solid var(--border);border-radius:8px;gap:4px;padding:3px;display:flex}.dashboard-date-btn{cursor:pointer;color:var(--text-secondary);white-space:nowrap;background:0 0;border:none;border-radius:6px;padding:6px 14px;font-size:13px;font-weight:500;transition:all .2s}.dashboard-date-btn:hover{background:var(--card-bg);color:var(--primary)}.dashboard-date-btn.active{background:var(--card-bg);color:var(--primary);border:1px solid var(--border);font-weight:600;box-shadow:0 1px 4px rgba(0,0,0,.1)}.dashboard-refresh-btn{border:1px solid var(--border);background:var(--card-bg);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;transition:all .18s;display:flex}.dashboard-refresh-btn:hover{background:var(--bg);color:var(--primary);border-color:var(--primary)}.dashboard-refresh-btn.db-spinning svg{animation:.8s linear spin}.db-todo-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;margin-bottom:24px;display:grid}.db-todo-card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;text-align:center;border-left:3px solid transparent;flex-direction:column;align-items:center;padding:16px;transition:all .18s;display:flex}.db-todo-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.db-todo-card--orange{border-left-color:var(--primary)}.db-todo-card--red{border-left-color:var(--danger)}.db-todo-card--blue{border-left-color:var(--info)}.db-todo-card--green{border-left-color:var(--success)}.db-todo-card--yellow{border-left-color:var(--warning)}.db-todo-card--purple{border-left-color:#8b5cf6}.db-todo-icon{margin-bottom:6px;font-size:24px}.db-todo-count{color:var(--text-primary);font-size:28px;font-weight:700;line-height:1.2}.db-todo-label{color:var(--text-secondary);margin-top:4px;font-size:12px;font-weight:500}.db-todo-action{color:var(--primary);margin-top:8px;font-size:11px;font-weight:600}.db-kpi-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:24px;display:grid}.db-chart-grid{grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:20px;margin-bottom:24px;display:grid}.db-chart-card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}.db-chart-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.db-chart-title{color:var(--text-primary);font-size:14px;font-weight:600}.db-chart-body{justify-content:center;align-items:center;min-height:220px;display:flex}.db-chart-body canvas{max-height:280px;width:100%!important}.db-shortcut-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:12px;margin-bottom:24px;display:grid}.db-shortcut-card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:20px 12px;transition:all .18s;display:flex}.db-shortcut-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary);transform:translateY(-3px)}.db-shortcut-icon{margin-bottom:8px;font-size:28px}.db-shortcut-label{color:var(--text-secondary);font-size:13px;font-weight:500}.db-activity-timeline{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}.db-activity-item{border-bottom:1px solid var(--border);gap:12px;padding:12px 0;display:flex}.db-activity-item:last-child{border-bottom:none;padding-bottom:0}.db-activity-item:first-child{padding-top:0}.db-activity-icon{flex-shrink:0;margin-top:2px;font-size:20px}.db-activity-content{flex:1;min-width:0}.db-activity-title{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;margin-bottom:4px;font-size:13px;font-weight:500;overflow:hidden}.db-activity-meta{align-items:center;gap:12px;display:flex}.db-activity-amount{color:var(--success);font-size:13px;font-weight:600}.db-activity-time{color:var(--text-muted);font-size:12px}.db-shop-ranking{margin-bottom:24px}.db-table-card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.db-data-table{border-collapse:collapse;width:100%}.db-data-table th{background:var(--bg);text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;white-space:nowrap;z-index:10;box-shadow:0 1px 0 var(--border);padding:12px 16px;font-size:12px;font-weight:600;position:-webkit-sticky;position:sticky;top:0}.db-data-table td{border-top:1px solid var(--border);color:var(--text-primary);padding:12px 16px;font-size:13px}.db-data-table tbody tr{cursor:pointer;transition:all .15s}.db-data-table tbody tr:hover{background:#f1f5f9}[data-theme=dark] .db-data-table tbody tr:hover{background:#334155}.db-rank-badge{border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;font-weight:700;display:inline-flex}.db-rank-badge--top{color:#fff;background:linear-gradient(135deg,#f59e0b,#ea580c)}.db-rank-badge--normal{background:var(--bg);color:var(--text-secondary)}.db-shop-name{color:var(--text-primary);font-weight:500}.db-amount{font-variant-numeric:tabular-nums;font-weight:600}.db-amount--positive{color:var(--success)}.db-amount--negative{color:var(--danger)}.db-number{font-variant-numeric:tabular-nums}.db-change{align-items:center;gap:2px;font-size:12px;font-weight:600;display:inline-flex}.db-change--up{color:var(--success)}.db-change--down{color:var(--danger)}.db-empty-hint{text-align:center;color:var(--text-muted);padding:40px 20px;font-size:14px}@media (max-width:768px){.dashboard-header{flex-direction:column;align-items:flex-start;margin-bottom:16px}.dashboard-header-right{justify-content:flex-start;width:100%}.dashboard-greeting-text{font-size:18px}.dashboard-greeting-emoji{font-size:24px}.db-todo-grid{grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:16px}.db-todo-card{padding:12px 10px}.db-todo-count{font-size:22px}.db-todo-icon{font-size:20px}.db-kpi-grid{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px}.db-chart-grid{grid-template-columns:1fr;gap:12px;margin-bottom:16px}.db-chart-card{padding:14px 12px}.db-chart-body{min-height:180px}.db-chart-body canvas{max-height:200px!important}.db-chart-title{font-size:13px}.db-shortcut-grid{grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:16px}.db-shortcut-card{padding:14px 8px}.db-shortcut-icon{font-size:22px}.db-shortcut-label{font-size:11px}.db-activity-timeline{padding:14px 12px}.db-data-table{min-width:560px}.db-data-table th{padding:10px 12px;font-size:11px}.db-data-table td{white-space:nowrap;padding:10px 12px;font-size:12px}.db-section-title{font-size:14px}}@media (max-width:1024px){.db-kpi-grid{grid-template-columns:repeat(3,1fr)}.db-chart-grid{grid-template-columns:1fr}.db-shortcut-grid{grid-template-columns:repeat(4,1fr)}}#global-loader{z-index:999999;background:rgba(30,35,52,.95);justify-content:center;align-items:center;width:100%;height:100%;transition:opacity .3s;display:flex;position:fixed;top:0;left:0}#global-loader.hidden{opacity:0;pointer-events:none}.loader-container{text-align:center;color:#fff}.loader-spinner{border:4px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;width:60px;height:60px;margin:0 auto 24px;animation:1s linear infinite spin}.loader-text{letter-spacing:.5px;font-size:16px;font-weight:500;animation:1.5s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}
