:root{color:#0f172a;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;--primary:#2563eb;--primary-dark:#1d4ed8;--text-muted:#64748b;--border:#e2e8f0;--card:#ffffffeb;--shadow:0 20px 60px #0f172a1f;background:#eef2f7;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif}*{box-sizing:border-box}html,body,#app{min-height:100%;margin:0}body{background:radial-gradient(circle at 10% 10%,#2563eb24,#0000 30%),radial-gradient(circle at 90% 0,#0ea5e91f,#0000 28%),#eef2f7;min-width:320px}button,input,select{font:inherit}.page-shell{width:min(1120px,100%);margin:0 auto;padding:28px 18px 44px}.hero-card,.toolbar-card,.table-card{background:var(--card);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:var(--shadow);border:1px solid #e2e8f0d9}.hero-card{color:#fff;background:linear-gradient(135deg, #0f172af5, #1e40afe6), var(--card);border-radius:28px;justify-content:space-between;align-items:stretch;gap:24px;padding:30px;display:flex;overflow:hidden}.eyebrow{color:#bfdbfe;letter-spacing:.18em;text-transform:uppercase;margin:0 0 10px;font-size:14px;font-weight:700}.hero-card h1{letter-spacing:-.04em;margin:0;font-size:clamp(30px,5vw,54px)}.subtitle{color:#dbeafe;max-width:560px;margin:14px 0 0;font-size:16px}.module-switcher{background:#ffffff1a;border:1px solid #ffffff2e;border-radius:14px;gap:8px;margin-bottom:18px;padding:5px;display:inline-flex}.module-switcher a{color:#dbeafe;text-align:center;border-radius:10px;min-width:72px;padding:8px 12px;font-weight:900;text-decoration:none}.module-switcher a.active{color:#0f172a;background:#fff}.hero-total{background:#ffffff1a;border:1px solid #ffffff2e;border-radius:22px;align-content:center;justify-items:end;min-width:230px;padding:22px;display:grid}.hero-total span,.hero-total small{color:#bfdbfe}.hero-total strong{letter-spacing:-.04em;margin:8px 0;font-size:clamp(26px,4vw,40px)}.hero-logout{color:#fff;cursor:pointer;background:#ffffff1f;border:1px solid #ffffff47;border-radius:10px;height:34px;margin-top:12px;padding:0 12px;font-weight:800}.auth-card{place-items:center;min-height:calc(100vh - 72px);display:grid}.login-panel{width:min(420px,100%);box-shadow:var(--shadow);background:#fff;border:1px solid #e2e8f0e6;border-radius:24px;gap:18px;padding:28px;display:grid}.login-panel h1{margin:0;font-size:30px}.login-error{color:#b91c1c;margin:0;font-weight:800}.toolbar-card{z-index:30;border-radius:22px;gap:16px;margin-top:18px;padding:18px;display:grid;position:relative;overflow:visible}.filter-header{justify-content:space-between;align-items:center;gap:14px;display:flex}.filter-header h2{margin:0;font-size:20px}.filter-header p{color:var(--text-muted);margin:6px 0 0;font-size:13px}.collapse-button{border:1px solid var(--border);color:#334155;cursor:pointer;background:#fff;border-radius:999px;flex:none;justify-content:center;align-items:center;gap:8px;height:40px;padding:0 14px;font-weight:800;display:inline-flex}.card-collapse-button{white-space:nowrap;height:36px;padding:0 12px;font-size:13px}.card-actions{flex:none;gap:8px;display:flex}.card-export-button{white-space:nowrap;border-radius:12px;height:36px;padding:0 12px;font-size:13px}.collapse-icon{transition:transform .16s;display:inline-block}.collapse-icon.open{transform:rotate(180deg)}.filters-panel{gap:16px;display:grid}.filter-grid{grid-template-columns:repeat(4,minmax(160px,1fr));align-items:end;gap:14px;display:grid}.filter-field{color:#334155;gap:8px;font-weight:700;display:grid}.filter-field input,.filter-field select,.multi-select summary{border:1px solid var(--border);color:#0f172a;background:#fff;border-radius:14px;height:44px;padding:0 14px}.filter-field select{cursor:pointer}.price-band-controls{gap:8px;display:grid}.price-band-controls.has-custom{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}.multi-select{position:relative}.multi-select summary{cursor:pointer;justify-content:space-between;align-items:center;list-style:none;display:flex}.multi-select summary::-webkit-details-marker{display:none}.multi-select summary:after{content:"⌄";color:var(--text-muted)}.checkbox-panel{z-index:1000;border:1px solid var(--border);background:#fff;border-radius:14px;max-height:260px;padding:10px;display:grid;position:absolute;top:calc(100% + 8px);left:0;right:0;overflow:auto;box-shadow:0 16px 36px #0f172a29}.checkbox-option{color:#334155;cursor:pointer;border-radius:10px;align-items:center;gap:8px;padding:9px 8px;font-size:14px;display:flex}.checkbox-option:hover{background:#f8fafc}.checkbox-option input{width:16px;height:16px}.checkbox-all{color:var(--primary);font-weight:800}.source-toggle{border:0;grid-template-columns:1fr 1fr;gap:8px;min-width:260px;margin:0;padding:0;display:grid}.source-toggle legend{color:#334155;grid-column:1/-1;margin-bottom:8px;font-weight:700}.source-toggle label{border:1px solid var(--border);color:#334155;cursor:pointer;background:#fff;border-radius:14px;place-items:center;height:44px;font-weight:800;display:grid}.source-toggle label.active{color:#fff;border-color:var(--primary);background:var(--primary)}.source-toggle input{opacity:0;pointer-events:none;position:absolute}.actions-row{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.refresh-button,.quick-button{cursor:pointer;border:0;border-radius:14px;height:44px;padding:0 20px;font-weight:800;transition:transform .16s,background .16s}.refresh-button{color:#fff;background:var(--primary)}.quick-button{color:var(--primary);background:#dbeafe}.refresh-button:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px)}.quick-button:hover:not(:disabled){background:#bfdbfe;transform:translateY(-1px)}.refresh-button:disabled,.quick-button:disabled{cursor:not-allowed;opacity:.65}.table-card{z-index:1;border-radius:24px;margin-top:18px;padding:22px;position:relative}.results-stack{gap:18px;display:grid}.results-stack .table-card{margin-top:18px}.results-stack .table-card+.table-card{margin-top:0}.table-header{justify-content:space-between;gap:12px;margin-bottom:16px;display:flex}.table-header h2{margin:0;font-size:22px}.table-header p{color:var(--text-muted);margin:6px 0 0;font-size:14px}.collapsible-card-header{grid-template-columns:minmax(0,1fr) auto;align-items:flex-start;display:grid}.collapsible-card-header>div{min-width:0}.state{min-height:150px;color:var(--text-muted);border:1px dashed var(--border);background:#f8fafc;border-radius:18px;place-items:center;display:grid}.state-error{color:#b91c1c;background:#fef2f2;border-color:#fecaca}.responsive-table{border:1px solid var(--border);border-radius:18px;overflow:auto}table{border-collapse:collapse;background:#fff;width:100%;min-width:640px}th,td{border-bottom:1px solid var(--border);text-align:left;white-space:nowrap;padding:16px 18px}th{color:#475569;letter-spacing:.06em;background:#f8fafc;font-size:13px}tbody tr:hover{background:#f8fafc}.rank-col{text-align:center;width:86px}.number-col,.money-col{text-align:right}.money-col{font-weight:800}.store-cell,.product-cell{color:#0f172a;font-weight:700}.product-info{align-items:center;gap:12px;min-width:260px;display:flex}.expand-button{height:32px;color:var(--primary);cursor:pointer;background:#eff6ff;border:1px solid #bfdbfe;border-radius:10px;flex:none;padding:0 10px;font-size:12px;font-weight:900}.expand-button:disabled{cursor:not-allowed;opacity:.45}.product-thumb-button{cursor:zoom-in;background:0 0;border:0;border-radius:12px;flex:none;width:46px;height:46px;padding:0}.product-thumb-button:focus-visible{outline-offset:2px;outline:3px solid #2563eb4d}.product-thumb{border:1px solid var(--border);object-fit:cover;background:#f8fafc;border-radius:12px;flex:none;width:46px;height:46px}.product-thumb-button .product-thumb{display:block}.product-thumb-placeholder{color:#94a3b8;place-items:center;font-size:12px;font-weight:800;display:inline-grid}.product-name{white-space:normal;min-width:0;line-height:1.35}.image-preview-backdrop{z-index:1000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0f172ac2;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.image-preview-panel{gap:12px;width:min(860px,100vw - 48px);max-height:calc(100vh - 48px);display:grid}.image-preview-header{color:#fff;justify-content:space-between;align-items:center;gap:16px;font-weight:800;display:flex}.image-preview-header span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.image-preview-close{color:#fff;cursor:pointer;background:#0f172a6b;border:1px solid #ffffff73;border-radius:999px;flex:none;place-items:center;width:38px;height:38px;font-size:26px;line-height:1;display:inline-grid}.image-preview-large{object-fit:contain;background:#fff;border-radius:8px;max-width:100%;max-height:calc(100vh - 122px);margin:0 auto;display:block;box-shadow:0 24px 72px #00000047}.rank-badge{color:#475569;background:#e2e8f0;border-radius:999px;place-items:center;width:34px;height:34px;font-weight:900;display:inline-grid}.rank-top{color:#fff;background:linear-gradient(135deg,#f97316,#ef4444);box-shadow:0 8px 18px #ef444442}tfoot td{color:#0f172a;background:#eff6ff;border-bottom:0;font-weight:900}.category-summary-cell{background:#f8fbff;padding:14px 18px}.category-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.category-summary-item{color:#0f172a;background:#fff;border:1px solid #bfdbfe;border-radius:14px;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;display:flex}.category-summary-item strong{color:var(--primary);font-size:18px}.category-summary-item small{color:var(--text-muted);font-weight:700}.category-name{color:#334155}.color-breakdown-cell{background:#f8fbff;padding:14px 18px}.color-breakdown-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.color-breakdown-item{background:#fff;border:1px solid #dbeafe;border-radius:12px;gap:6px;padding:12px;display:grid}.color-breakdown-item span{color:#334155}.color-breakdown-item strong{color:#0f172a}.color-breakdown-item small{color:var(--text-muted);font-weight:800}.inline-state{min-height:64px;color:var(--text-muted);border:1px dashed var(--border);background:#fff;border-radius:14px;place-items:center;display:grid}.inline-error{color:#b91c1c;background:#fef2f2;border-color:#fecaca}.chart-card{overflow:hidden}.chart-header{align-items:flex-start}.chart-controls{flex:none;gap:8px;display:flex}.chart-controls select{border:1px solid var(--border);color:#0f172a;background:#fff;border-radius:12px;height:38px;padding:0 12px;font-weight:800}.chart-body{gap:14px;display:grid}.bar-chart{gap:12px;display:grid}.bar-row{grid-template-columns:minmax(120px,210px) 1fr minmax(110px,auto);align-items:center;gap:12px;display:grid}.bar-label{color:#334155;text-overflow:ellipsis;white-space:nowrap;font-weight:800;overflow:hidden}.bar-track{background:#e2e8f0;border-radius:999px;height:16px;overflow:hidden}.bar-fill{border-radius:inherit;background:linear-gradient(90deg,#2563eb,#16a34a);height:100%;display:block}.bar-row strong{text-align:right}.pie-chart{grid-template-columns:220px 1fr;align-items:center;gap:22px;display:grid}.pie-visual{aspect-ratio:1;width:220px;box-shadow:inset 0 0 0 1px var(--border), 0 12px 28px #0f172a1a;border:10px solid #fff;border-radius:50%;padding:0}.pie-slice{cursor:pointer;transform-box:fill-box;transform-origin:50%;outline:none;transition:opacity .16s,transform .16s}.pie-slice:hover,.pie-slice:focus,.pie-slice.active{opacity:.88;transform:scale(1.015)}.chart-legend{gap:10px;display:grid}.legend-row{color:#334155;cursor:pointer;border-radius:10px;grid-template-columns:12px 1fr auto;align-items:center;gap:10px;padding:6px 8px;font-weight:800;display:grid}.legend-row.active,.legend-row:hover{background:#f1f5f9}.legend-row span:nth-child(2){text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.legend-dot{border-radius:999px;width:12px;height:12px}.pie-detail{border:1px solid var(--border);background:#f8fafc;border-radius:12px;gap:4px;margin-top:4px;padding:12px;display:grid}.pie-detail span{color:#334155;font-weight:900}.pie-detail strong{color:var(--primary)}.pie-detail small{color:var(--text-muted);font-weight:800}.line-chart{gap:10px;display:grid}.line-chart svg{border:1px solid var(--border);background:linear-gradient(#f8fafc 1px,#0000 1px) 0 0/100% 44px,#fff;border-radius:16px;width:100%;height:240px}.line-path{fill:none;stroke:var(--primary);stroke-linecap:round;stroke-linejoin:round;stroke-width:4px}.axis-labels{color:var(--text-muted);gap:8px;font-size:12px;font-weight:700;display:flex;overflow:auto}.axis-labels span{text-overflow:ellipsis;white-space:nowrap;flex:none;max-width:120px;overflow:hidden}@media (width<=720px){.page-shell{padding:14px 12px 28px}.hero-card{border-radius:22px;padding:22px;display:grid}.hero-total{justify-items:start;min-width:0;padding:16px}.toolbar-card{align-items:stretch;gap:12px;display:grid}.filter-header{align-items:flex-start}.filter-header h2{font-size:18px}.filter-header p{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.filter-grid{grid-template-columns:1fr}.filter-field input,.filter-field select,.multi-select summary,.source-toggle,.refresh-button,.quick-button{width:100%}.checkbox-panel{margin-top:8px;position:static}.actions-row{grid-template-columns:1fr 1fr;display:grid}.actions-row .refresh-button{grid-column:1/-1}.price-band-controls.has-custom{grid-template-columns:1fr}.table-card{border-radius:20px;padding:14px}.collapsible-card-header{grid-template-columns:1fr}.card-collapse-button{justify-self:end}.card-actions{justify-content:flex-end;justify-self:stretch}.responsive-table{border:0;overflow:visible}table{background:0 0;min-width:0}thead{display:none}tbody,tfoot,tr,td{width:100%;display:block}tbody tr,tfoot tr{border:1px solid var(--border);background:#fff;border-radius:16px;margin-bottom:12px;overflow:hidden;box-shadow:0 8px 24px #0f172a0f}tfoot tr{background:#eff6ff}tfoot tr.category-summary-row{background:#f8fbff}td{border-bottom:1px solid var(--border);white-space:normal;text-align:right;justify-content:space-between;gap:14px;padding:12px 14px;display:flex}td:before{color:#64748b;flex:none;font-weight:700}td.rank-col:before{content:"排名"}td.store-cell:before{content:"商店"}td.product-cell:before{content:"单品"}td.number-col:before{content:"数量"}td.money-col:before{content:"金额"}td.category-summary-cell{text-align:left;padding:12px;display:block}td.category-summary-cell:before,td.color-breakdown-cell:before{content:none}.category-summary-grid{grid-template-columns:1fr}.color-breakdown-cell{text-align:left;padding:12px;display:block}.color-breakdown-grid{grid-template-columns:1fr}.category-summary-item{gap:6px;display:grid}.rank-col,.number-col,.money-col{text-align:right;width:100%}.store-cell>span,.product-name{max-width:68%}.product-info{justify-content:flex-end;min-width:0}.image-preview-backdrop{padding:12px}.image-preview-panel{width:calc(100vw - 24px);max-height:calc(100vh - 24px)}.image-preview-large{max-height:calc(100vh - 104px)}.chart-header,.chart-controls{width:100%;display:grid}.chart-controls{grid-template-columns:1fr 1fr}.chart-controls .card-collapse-button{grid-column:1/-1;width:100%}.chart-controls .card-export-button{width:100%}.bar-row{grid-template-columns:1fr;gap:6px}.bar-row strong{text-align:left}.pie-chart{grid-template-columns:1fr;justify-items:center}.pie-visual{width:min(220px,80vw)}tfoot td:last-child,tbody td:last-child{border-bottom:0}}
