:root{--bg:#f5f6f8;--card:#fff;--text:#1f2329;--text-sub:#86909c;--line:#e5e6eb;--brand:#1677ff;--brand-deep:#0958d9;--brand-hot:#4096ff;--brand-soft:#e8f3ff;--brand-faint:#1677ff14;--danger:#d92d20;--positive:#0f6f64;--bg-muted:#f2f3f5;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;font-family:system-ui,-apple-system,Segoe UI,Roboto,PingFang SC,Microsoft YaHei,sans-serif;font-size:116%;font-weight:400;line-height:1.5}*{box-sizing:border-box}html,body{width:100%;min-height:100dvh;margin:0}html,body,#root{height:100%}body{min-height:100dvh;overflow-x:hidden}#root{min-height:100dvh}.app{background:var(--bg);max-width:430px;min-height:100dvh;margin:0 auto;padding-bottom:64px}.access-denied-page{background:#f0f4f8;justify-content:center;align-items:center;min-height:100dvh;padding:24px;display:flex}.access-denied-card{text-align:center;background:#fff;border-radius:16px;width:100%;max-width:340px;padding:40px 28px 32px;box-shadow:0 4px 24px #0000001a}.access-denied-icon{margin-bottom:16px;font-size:48px}.access-denied-title{color:#1a2540;margin:0 0 8px;font-size:20px;font-weight:700}.access-denied-name{color:#2563eb;margin:0 0 12px;font-size:15px;font-weight:600}.access-denied-desc{color:#64748b;margin:0 0 20px;font-size:13px;line-height:1.6}.access-denied-meta{color:#94a3b8;flex-wrap:wrap;justify-content:center;gap:6px;font-size:12px;display:flex}.lark-host .app{width:100%;max-width:none;min-height:100dvh;padding-bottom:calc(64px + env(safe-area-inset-bottom,0px));margin:0}.hero{background:var(--card);color:var(--text);border-bottom:1px solid var(--line);margin-bottom:14px;padding:12px 14px 16px;box-shadow:0 1px 2px #1f23290a}.hero--sub{margin-bottom:0}.hero-top{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.hero-actions{align-items:center;gap:8px;display:flex}.user-menu{position:relative}.avatar-trigger,.avatar-fallback{border:1px solid var(--line);background:var(--brand-soft);width:36px;height:36px;color:var(--brand);border-radius:50%;justify-content:center;align-items:center;font-weight:700;display:inline-flex;overflow:hidden}.avatar-trigger{cursor:pointer}.avatar-image{object-fit:cover;width:100%;height:100%}.avatar-image.large,.avatar-fallback.large{width:48px;height:48px}.user-card{border:1px solid var(--line);background:var(--card);z-index:20;border-radius:14px;width:280px;padding:12px;position:absolute;top:44px;right:0;box-shadow:0 10px 30px #1f23291f}.user-card-head{align-items:center;gap:10px;margin-bottom:12px;display:flex}.user-info-list{gap:8px;display:grid}.hero-title{color:var(--text);margin:0;font-size:17px;font-weight:600}.hero-sub{color:var(--text-sub);margin:4px 0 0;font-size:12px}.toolbar-stack{gap:8px;margin-top:8px;display:grid}.scope-back-row{justify-content:flex-start;display:flex}.period-row{justify-content:space-between;align-items:center;gap:10px;width:100%;display:flex}.period-segmented{flex:none;gap:8px;display:flex}.date-range-panel{border:1px solid var(--line);background:var(--bg-muted);border-radius:12px;gap:10px;padding:10px;display:grid}.date-range-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.date-range-grid label{gap:6px;display:grid}.date-range-grid input{border:1px solid var(--line);color:var(--text);background:#fff;border-radius:10px;padding:10px 12px}.segmented{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.segmented.period-segmented{gap:8px;display:flex}.segmented.compact{grid-template-columns:repeat(2,minmax(0,1fr));width:92px}.segmented button,.ghost-btn,.chip,.chip.muted,.button-reset{border:1px solid var(--line);background:var(--bg-muted);color:var(--text);cursor:pointer;border-radius:10px;min-height:36px;padding:0 12px;font-size:13px}.segmented button.active{background:var(--brand-soft);color:var(--brand);border-color:#1677ff33;font-weight:600}.quick-query-trigger{background:var(--brand-soft);color:var(--brand);cursor:pointer;border:1px solid #1677ff33;border-radius:12px;min-height:40px;padding:0 14px;font-weight:600}.quick-query-panel{border:1px solid var(--line);background:var(--bg-muted);border-radius:12px;gap:8px;padding:10px;display:grid}.store-row{display:block}.search-input-wrap{align-items:stretch;gap:8px;display:flex}.store-row input{border:1px solid var(--line);background:var(--bg-muted);color:var(--text);box-sizing:border-box;border-radius:10px;flex:1;min-height:40px;padding:10px 12px;font-size:14px}.store-row input::placeholder{color:var(--text-sub)}.store-row button{background:var(--brand);color:#fff;cursor:pointer;border:none;border-radius:10px;min-height:40px;padding:0 14px;font-weight:600}.store-suggest-wrap{flex:1;position:relative}.store-suggest-wrap input{box-sizing:border-box;width:100%}.store-suggest-list{border:1px solid var(--line);z-index:200;background:#fff;border-radius:10px;max-height:320px;margin:0;padding:4px 0;list-style:none;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto;box-shadow:0 4px 16px #0000001f}.store-suggest-list li{cursor:pointer;align-items:center;gap:6px;padding:9px 14px;font-size:13px;transition:background .1s;display:flex}.store-suggest-list li:hover{background:#f0f5ff}.sug-code{color:var(--brand);flex-shrink:0;min-width:64px;font-size:12px;font-weight:600}.sug-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.sug-dist{color:#888;background:#f4f6fb;border-radius:6px;flex-shrink:0;padding:1px 6px;font-size:11px}.period-segmented button{min-width:60px;padding:0 10px}.quick-store-panel{gap:8px;display:grid}.quick-block{background:var(--bg-muted);border:1px solid var(--line);border-radius:12px;padding:10px}.quick-title{color:var(--text-sub);margin-bottom:6px;font-size:11px}.chip-row{gap:8px;display:flex;overflow-x:auto}.chip{white-space:nowrap;min-height:32px}.chip.muted{background:#fff}.banner{background:var(--bg-muted);border:1px solid var(--line);color:var(--text);border-radius:10px;margin:10px 12px;padding:10px 12px;font-size:12px}.banner.err{color:var(--danger);background:#fff5f5;border-color:#d92d2040}.card{background:var(--card);border:1px solid var(--line);border-radius:0 0 14px 14px;margin:0 12px 12px;padding:16px;box-shadow:0 2px 6px #1677ff17}.card:before{content:"";background:linear-gradient(90deg,#0958d9,#1677ff 38%,#4096ff 68%,#91caff);border-radius:0;height:4px;margin:-16px -16px 14px;display:block}.card-head{justify-content:space-between;align-items:flex-start;margin-bottom:12px;display:flex}.card-head h2{color:var(--text);margin:0;font-size:16px}.meta{color:var(--text-sub);font-size:11px}.big-num{letter-spacing:-.02em;color:var(--text);font-size:26px;font-weight:700}.money-hint{color:var(--text-sub);font-size:12px;font-weight:500}.money-val{align-items:inherit;flex-direction:column;gap:0;line-height:1.3;display:inline-flex}span.money-val{flex-direction:row;align-items:baseline;gap:3px}.cny-hint{color:var(--text-sub);letter-spacing:0;white-space:nowrap;font-size:.72em;font-weight:400}.pill{background:var(--brand-soft);color:var(--brand);border:1px solid #1677ff33;border-radius:100px;margin-top:8px;padding:4px 12px;font-size:12px;font-weight:600;display:inline-block}.gap-line{text-align:center;color:var(--text);margin-top:10px;font-size:12px;font-weight:500}.gap-line.bad{color:var(--danger)}.gap-line.ok{color:var(--positive)}.trend-arrow{vertical-align:middle;margin-right:1px;font-size:10px;font-style:normal}.trend-up{color:var(--positive)}.trend-down{color:var(--danger)}.progress-track{background:var(--line);border-radius:6px;height:10px;margin-top:12px;overflow:hidden}.progress-track.slim{height:8px;margin-top:8px}.progress-fill{background:linear-gradient(90deg, var(--brand-deep), var(--brand) 50%, var(--brand-hot));border-radius:6px;height:100%;transition:width .3s}@keyframes shimmer{0%{transform:translate(-100%)translateZ(0)}to{transform:translate(400%)translateZ(0)}}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.6)}}@keyframes fill-in{0%{width:0}}.dual-progress-wrap{margin-top:10px}.dual-progress-labels{color:var(--muted);justify-content:space-between;margin-bottom:4px;font-size:.72rem;display:flex}.dual-progress-track{background:#e2e8f0;border-radius:8px;height:12px;position:relative;overflow:visible}.dual-progress-baseline{will-change:width;background:linear-gradient(90deg,#2563eb,#3b82f6);border-radius:8px 0 0 8px;height:100%;animation:.9s ease-out both fill-in;position:absolute;top:0;left:0;overflow:hidden;transform:translateZ(0)}.dual-progress-stretch{will-change:width;background:linear-gradient(90deg,#2563eb,#3b82f6,#f59e0b,#f97316);border-radius:8px;height:100%;animation:1.1s ease-out both fill-in;position:absolute;top:0;left:0;overflow:hidden;transform:translateZ(0)}.dual-progress-exceeded{will-change:opacity;background:linear-gradient(90deg,#2563eb 0%,#3b82f6 30%,#f59e0b 55%,#22c55e 80%,#16a34a 100%);border-radius:8px;width:100%;height:100%;animation:1.1s ease-out both fill-in;position:absolute;top:0;left:0;overflow:hidden;transform:translateZ(0);box-shadow:0 0 8px #22c55e80}.dual-progress-baseline:after,.dual-progress-stretch:after,.dual-progress-exceeded:after{content:"";will-change:transform;background:linear-gradient(90deg,#0000,#ffffff73,#0000);width:40%;height:100%;animation:2.4s ease-in-out infinite shimmer;position:absolute;top:0;left:0;transform:translate(-100%)translateZ(0)}.dual-progress-dot{z-index:4;background:#fff;border:2px solid #3b82f6;border-radius:50%;width:10px;height:10px;margin:auto 0;animation:1.6s ease-in-out infinite pulse-dot;position:absolute;top:0;bottom:0;transform:translate(-50%);box-shadow:0 0 0 3px #3b82f640}.dual-progress-dot.stretch{border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b40}.dual-progress-dot.exceeded{border-color:#22c55e;box-shadow:0 0 0 3px #22c55e4d}.dual-progress-divider{z-index:3;background:#fff;border-radius:1px;width:2px;height:calc(100% + 6px);position:absolute;top:-3px}.dual-progress-pcts{justify-content:space-between;margin-top:5px;font-size:.75rem;display:flex}.dual-progress-pcts .p-baseline{color:#2563eb;font-weight:700}.dual-progress-pcts .p-stretch{color:#f59e0b;font-weight:700}.dual-progress-pcts .p-stretch.exceeded{color:#16a34a}.achieve-rows{grid-template-columns:1fr 1fr;gap:4px 12px;margin-top:8px;font-size:.75rem;display:grid}.achieve-row{align-items:center;gap:5px;display:flex}.achieve-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.achieve-dot.baseline{background:#3b82f6}.achieve-dot.stretch{background:#f59e0b}.achieve-label{color:var(--muted)}.achieve-val{color:var(--fg);font-weight:700}.achieve-rate{color:var(--muted)}.achieve-badge{border-radius:12px;align-items:center;gap:4px;padding:2px 8px;font-size:.72rem;font-weight:600;display:inline-flex}.achieve-badge.achieved{color:#16a34a;background:#dcfce7}.achieve-badge.unachieved{color:#dc2626;background:#fee2e2}.kpi-grid{grid-template-columns:repeat(3,1fr);gap:8px;margin-top:14px;display:grid}.kpi{background:var(--bg-muted);text-align:left;box-sizing:border-box;border:1px solid #0000;border-radius:10px;min-width:0;padding:10px}.kpi .l{color:var(--text-sub);margin-bottom:4px;font-size:12px}.kpi .v{color:var(--text);flex-wrap:wrap;justify-content:flex-start;align-items:baseline;gap:3px;min-height:0;font-size:15px;font-weight:700;display:flex}.cat-scroll{gap:10px;padding-bottom:4px;display:flex;overflow-x:auto}.cat{background:var(--bg-muted);border:1px solid var(--line);text-align:center;border-radius:10px;min-width:100px;padding:10px}.cat .n{color:var(--text);font-size:12px;font-weight:600}.cat .a{color:var(--brand);margin-top:6px;font-size:14px;font-weight:700}.cat .p{color:var(--text-sub);margin-top:4px;font-size:11px}.alert-li{border-bottom:1px solid var(--line);color:var(--text);gap:10px;padding:10px 0;font-size:13px;display:flex}.alert-li:last-child{border-bottom:none}.tag{border-radius:4px;flex-shrink:0;align-self:flex-start;padding:4px 8px;font-size:10px;font-weight:700}.tag-warn{color:#d46b08;background:#fff7e8}.tag-risk{background:var(--brand-soft);color:var(--brand-deep)}.alert-detail{color:var(--text-sub);margin-top:4px;font-size:11px;display:block}.alert-main{flex:1}.alert-row{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.tag-outline{color:var(--text-sub);border:1px solid var(--line);background:#fff}.alert-open-btn{white-space:nowrap;align-self:center}.compare-grid{grid-template-columns:repeat(2,1fr);gap:10px;display:grid}.compare-grid.compare-grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.compare-item,.region-item,.setting-row,.ranking-item{border:1px solid var(--line);background:var(--bg-muted);border-radius:12px;padding:12px}.compare-label{color:var(--text-sub);margin-bottom:4px;font-size:11px}.metric-value{color:var(--text);font-size:16px;font-weight:700;line-height:1.2;display:block}.metric-value.interactive{color:var(--brand);font-weight:800}.metric-inline-trigger{background:var(--brand-faint);border:1px solid #1677ff24;border-radius:12px;min-height:auto;padding:10px 12px}.fresh-line-item{grid-template-columns:minmax(0,1.1fr) minmax(0,1.9fr);justify-content:stretch;align-items:center;column-gap:12px;width:100%;display:grid}.fresh-name-wrap{min-width:0}.fresh-name{white-space:nowrap;font-size:13px;display:block}.fresh-metric-trigger{text-align:center;background:0 0;border:none;border-radius:0;justify-self:stretch;width:100%;min-width:0;padding:0}.fresh-metric-trigger:hover{background:0 0;border-color:#0000}.fresh-line-item>.ranking-right,.fresh-line-item>.fresh-metric-trigger{text-align:center;min-width:0}.fresh-metrics-grid{grid-template-columns:repeat(3,minmax(0,1fr));align-items:center;gap:12px;min-width:0;display:grid}.fresh-metric-cell{text-align:center;min-width:0}.compare-item.button-reset,.inventory-trigger,.metric-inline-trigger.interactive-block{background:var(--brand-faint);border-color:#1677ff24}.compare-item.button-reset:hover,.inventory-trigger:hover,.metric-inline-trigger.interactive-block:hover{background:var(--brand-soft);border-color:#1677ff38}.inventory-trigger.active{background:var(--brand-soft);border-color:#1677ff33}.inventory-money,.inventory-money>div:first-child{color:var(--text);font-size:16px;font-weight:700;line-height:1.2}.region-list,.ranking-list{gap:10px;display:grid}.region-row,.region-meta,.ranking-item,.setting-row{justify-content:space-between;gap:10px;display:flex}.region-meta{color:var(--text-sub);margin-top:8px;font-size:11px}.button-reset{text-align:left;width:100%}.ranking-left{gap:10px;display:flex}.ranking-right{text-align:right}.rank-no{background:var(--brand-soft);width:24px;height:24px;color:var(--brand);border-radius:50%;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:inline-flex}.ghost-btn{background:#fff}.link-btn{color:var(--brand);background:0 0;border:none;padding:0;font-size:13px;font-weight:600}.setting-row select{border:1px solid var(--line);min-width:140px;color:var(--text);background:#fff;border-radius:8px;padding:6px 10px}.pl-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:14px;display:grid}.pl-summary-card,.pl-line-item,.note-item{border:1px solid var(--line);background:var(--bg-muted);border-radius:12px;padding:12px}.pl-summary-card.highlight{background:#eef9f1;border-color:#0f6f6433}.notes-list,.pl-line-list{gap:10px;display:grid}.note-item{align-items:flex-start;gap:10px;display:flex}.pl-line-item{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.inventory-sku-item{align-items:center}.ops-focus-card,.ops-risk-card{border:1px solid var(--line);background:var(--bg-muted);border-radius:12px;margin-top:12px;padding:12px}.ops-focus-card .card-head,.ops-risk-card .card-head{margin-bottom:10px}.ops-focus-card h3,.ops-risk-card h3{color:var(--text);margin:0;font-size:14px}.ops-risk-grid{gap:10px;margin-top:12px;display:grid}.ops-risk-list{gap:8px;display:grid}.ops-risk-item{border:1px solid var(--line);background:#fff;border-radius:10px;justify-content:space-between;gap:10px;padding:10px;display:flex}.tabbar{-webkit-overflow-scrolling:touch;scrollbar-width:none;max-width:430px;padding:4px 0 calc(4px + env(safe-area-inset-bottom));z-index:10;background:linear-gradient(#e8f3ff 0%,#f4f9ff 100%);border-top:1.5px solid #1677ff2e;margin:0 auto;display:flex;position:fixed;bottom:0;left:0;right:0;overflow:auto hidden;box-shadow:0 -2px 10px #1677ff14}.tabbar::-webkit-scrollbar{display:none}.tabbar button{color:#6b88b8;cursor:pointer;letter-spacing:.02em;white-space:nowrap;background:0 0;border:none;flex:none;justify-content:center;align-items:center;min-width:60px;min-height:40px;padding:0 10px;font-size:13px;font-weight:500;transition:color .15s;display:flex}.tabbar button.active{color:var(--brand);font-weight:700;position:relative}.tabbar button.active:after{content:"";background:var(--brand);border-radius:2px;width:20px;height:3px;position:absolute;bottom:0;left:50%;transform:translate(-50%)}.placeholder-page{text-align:center;color:var(--text-sub);padding:24px 16px}.page-wrap{padding-top:12px;padding-bottom:48px}.loading{text-align:center;color:var(--text-sub);padding:24px}.compare-period-block{border:1px solid var(--line);border-radius:12px;margin-top:14px;overflow:hidden}.compare-period-title{color:var(--text-sub);background:var(--bg-muted);border-bottom:1px solid var(--line);padding:8px 12px;font-size:12px;font-weight:600}.compare-period-grid{grid-template-columns:minmax(80px,1.2fr) repeat(3,minmax(0,1fr));font-size:12px;display:grid}.compare-period-col-head{color:var(--text-sub);background:var(--bg-muted);text-align:center;border-bottom:1px solid var(--line);padding:6px 10px;font-weight:600}.compare-period-col-label{background:var(--bg-muted);border-bottom:1px solid var(--line)}.compare-period-row-label{color:var(--text-sub);border-bottom:1px solid var(--line);background:var(--bg-muted);align-items:center;padding:8px 10px;font-size:11px;display:flex}.compare-period-cell{text-align:center;border-bottom:1px solid var(--line);color:var(--text);padding:8px 10px;font-weight:600}.store-rank-block{margin-top:14px}.store-rank-section{border:1px solid var(--line);border-radius:12px;overflow:hidden}.store-rank-row{border-bottom:1px solid var(--line);align-items:center;gap:8px;padding:8px 12px;font-size:13px;display:flex}.store-rank-row:last-child{border-bottom:none}.store-rank-no{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:11px;font-weight:700;display:inline-flex}.store-rank-no.top{background:var(--brand-soft);color:var(--brand)}.store-rank-no.last{color:var(--danger);background:#fef3f2}.store-rank-name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.store-rank-val{flex-shrink:0;font-size:13px;font-weight:700}.positive-text{color:var(--positive)}.danger-text{color:var(--danger)}.cat-overview-sku-summary{background:#dbeafe;border-bottom:2px solid #93c5fd;flex-wrap:wrap;align-items:center;gap:6px;padding:9px 14px;font-size:12px;display:flex}.cat-overview-sku-item{align-items:center;gap:4px;display:flex}.cat-overview-sku-sep{color:#60a5fa;font-size:12px;font-weight:300}.cat-group-block{border:1px solid var(--line);border-radius:0;margin-bottom:10px;overflow:hidden}.cat-group-head{background:var(--bg-muted);border-bottom:1px solid var(--line);flex-direction:column;display:flex}.cat-group-head-row1{justify-content:space-between;align-items:center;gap:8px;padding:9px 12px 4px;display:flex}.cat-group-name-block{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.cat-group-head-row2{flex-wrap:wrap;align-items:center;gap:10px;padding:0 12px 8px;display:flex}.cat-group-name{color:var(--text);font-size:14px;font-weight:700}.cat-group-mix{color:var(--brand);font-size:16px;font-weight:800}.cat-group-sales{color:var(--text);font-size:13px;font-weight:600}.cat-group-rate{font-size:12px}.cat-group-compare-row{background:var(--bg);border-bottom:1px solid var(--line);color:var(--text-sub);gap:12px;padding:5px 12px;font-size:11px;display:flex}.cat-item-list{border:1px solid var(--line);background:#fff;border-top:none;display:block}.cat-item-list-wide{overflow-x:auto}.cat-item-header{color:var(--text-sub);background:var(--bg-muted);border-bottom:1px solid var(--line);grid-template-columns:1fr 74px 66px 46px;align-items:center;gap:4px;padding:6px 12px;font-size:12px;font-weight:600;display:grid}.cat-item-list-wide .cat-item-header,.cat-item-list-wide .cat-item-row-wide{box-sizing:border-box;border-top:none;border-left:none;border-right:none;grid-template-columns:minmax(90px,1.2fr) 40px 62px 60px 46px 62px 38px 50px 42px;gap:4px;min-width:730px;padding-left:12px;padding-right:12px;display:grid}.cat-item-list-wide>div{box-sizing:border-box;min-width:730px}.cat-item-qty-col{text-align:right;color:var(--text-sub);font-size:12px}.cat-item-row{border:none;border-bottom:1px solid var(--line);box-sizing:border-box;text-align:left;cursor:pointer;background:#fff;border-radius:0;grid-template-columns:1fr 74px 66px 46px;align-items:center;gap:4px;width:100%;padding:8px 12px;font-size:12px;transition:background .12s;display:grid}.cat-item-row:last-child{border-bottom:none}.cat-item-row:hover{background:#f0f5ff}.cat-item-expanded{background:var(--brand-soft)!important}.cat-item-name-col{min-width:0}.cat-item-sales-col,.cat-item-avg-col,.cat-item-rate-col,.cat-item-num-col{text-align:right}.cat-group-meta{white-space:nowrap;font-size:11px}.cat-active-sku-meta{color:var(--brand);font-weight:600}.cat-item-name{color:var(--text);word-break:keep-all;min-width:0;line-height:1.4}.cat-item-sales,.cat-item-avg{color:var(--text);text-align:right;font-weight:600}.hourly-tabs{align-items:center;gap:4px;display:flex}.hourly-tab{border:1px solid var(--line);color:var(--text-sub);cursor:pointer;background:0 0;border-radius:20px;padding:3px 10px;font-size:13px;line-height:1.4;transition:background .15s,color .15s}.hourly-tab.active{background:var(--brand);color:#fff;border-color:var(--brand);font-weight:600}.hourly-legend{color:var(--text-sub);align-items:center;gap:10px;padding:6px 0 2px;font-size:11px;display:flex}.hourly-legend-dot{vertical-align:middle;border-radius:2px;width:10px;height:3px;margin-right:3px;display:inline-block}.hourly-ctrl-row{border-bottom:1px solid var(--line);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:6px;padding:5px 0 6px;display:flex}.hourly-metric-row{border-bottom:1px solid var(--line);gap:6px;margin-bottom:8px;padding:6px 0 4px;display:flex}.hourly-series-toggle{align-items:center;gap:5px;display:flex}.series-toggle-btn{border:1px solid var(--line);color:var(--text-sub);cursor:pointer;background:0 0;border-radius:12px;align-items:center;gap:3px;padding:2px 8px;font-size:10px;transition:background .15s,color .15s,border-color .15s;display:flex}.series-toggle-btn.active{color:var(--text);background:#f0f7ff;border-color:#bfdbfe;font-weight:600}.series-dot{border-radius:2px;flex-shrink:0;width:8px;height:8px;display:inline-block}.hourly-metric-btn{border:1px solid var(--line);color:var(--text-sub);cursor:pointer;background:0 0;border-radius:12px;padding:2px 12px;font-size:11px;transition:background .15s,color .15s}.hourly-metric-btn.active{background:var(--brand);color:#fff;border-color:var(--brand);font-weight:600}.hourly-table{margin-top:6px}.hourly-header-row,.hourly-row{border-bottom:1px solid var(--line);text-align:left;cursor:pointer;background:0 0;border-radius:0;grid-template-columns:48px 1fr 1fr 1fr;align-items:center;gap:6px;width:100%;padding:6px;font-size:11px;transition:background .15s;display:grid}.hourly-header-row{color:var(--text-sub);background:var(--bg-muted);cursor:default;font-weight:600}.hourly-row:hover{background:var(--bg-muted)}.hourly-row:last-child{border-bottom:none}.hourly-row-selected{background:#eff6ff!important}.hourly-label-col{color:var(--text-sub);white-space:nowrap;font-size:12px;font-weight:600}.hourly-row-selected .hourly-label-col{color:var(--brand)}.hourly-val-col{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1px;min-width:0;display:flex}.hourly-header-row .hourly-val-col{flex-direction:row;justify-content:center;align-items:center}.hourly-num{color:var(--text);white-space:nowrap;font-size:10px;font-weight:600}.hourly-orders{color:var(--text-sub);white-space:nowrap;font-size:9px}.sku-movers-panel{border-top:1px solid var(--line);margin-top:12px;padding-top:12px}.sku-movers-head{justify-content:space-between;align-items:center;margin-bottom:6px;font-size:12px;display:flex}.sku-movers-filters{border-bottom:1px solid var(--line);flex-wrap:wrap;gap:12px;margin-bottom:8px;padding:5px 0 8px;display:flex}.sku-filter-group{align-items:center;gap:4px;display:flex}.sku-filter-label{color:var(--text-sub);white-space:nowrap;margin-right:2px;font-size:10px}.sku-filter-btn{border:1px solid var(--line);color:var(--text-sub);cursor:pointer;white-space:nowrap;background:0 0;border-radius:10px;padding:2px 8px;font-size:10px;transition:background .15s,color .15s}.sku-filter-btn.active{background:var(--brand);color:#fff;border-color:var(--brand);font-weight:600}.sku-movers-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.sku-movers-col-title{border-bottom:1px solid var(--line);margin-bottom:4px;padding:3px 0 4px;font-size:10px;font-weight:700}.sku-mover-row{border-bottom:1px solid var(--line);grid-template-columns:14px 1fr auto;align-items:center;gap:4px;padding:3px 0;font-size:10px;display:grid}.sku-mover-row:last-child{border-bottom:none}.sku-rank{color:var(--text-sub);text-align:center;font-size:9px;font-weight:700}.sku-name{white-space:nowrap;text-overflow:ellipsis;color:var(--text);overflow:hidden}.sku-change{white-space:nowrap;font-size:9px;font-weight:700}@media (width<=380px){.kpi-grid,.compare-grid,.pl-summary-grid,.segmented{grid-template-columns:repeat(2,minmax(0,1fr))}}.sku-rank-header{color:var(--text-sub);background:var(--bg-muted);border-top:1px solid var(--line);border-bottom:1px solid var(--line);grid-template-columns:36px 1fr 74px 52px;align-items:center;gap:4px;padding:6px 12px;font-size:12px;font-weight:600;display:grid}.sku-rank-row{border-bottom:1px solid var(--line);grid-template-columns:36px 1fr 74px 52px;align-items:center;gap:4px;padding:10px 12px;transition:background .15s;display:grid}.sku-rank-row:last-child{border-bottom:none}.sku-rank-no-col{text-align:center}.sku-rank-val-col{text-align:right}.sku-rank-name-col{min-width:0}.sku-rank-badge{background:var(--bg-muted);width:24px;height:24px;color:var(--text-sub);border-radius:50%;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:inline-flex}.sku-rank-top1{color:#7a5800;background:gold}.sku-rank-top2{color:#555;background:silver}.sku-rank-top3{color:#fff;background:#cd7f32}.sku-rank-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:500;line-height:1.4;overflow:hidden}.sku-rank-sub{color:var(--text-sub);margin-top:2px;font-size:11px}.sku-rank-sales{color:var(--brand);font-size:12px;font-weight:700}.sku-rank-contrib{color:var(--text);font-size:12px;font-weight:600}.psd-hero{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:12px;display:flex}.psd-compare{flex-direction:column;gap:6px;margin-bottom:4px;display:flex}.psd-compare-item{flex-direction:column;align-items:flex-end;display:flex}.psd-compare-label{color:var(--text-sub);font-size:10px}.psd-compare-val{color:var(--text);flex-wrap:nowrap;align-items:baseline;gap:3px;font-size:14px;font-weight:700;display:flex}.psd-growth{white-space:nowrap;font-size:10px;font-weight:700}.psd-growth-up{color:#389e0d}.psd-growth-dn{color:#cf1322}.kpi-grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}.kpi-grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.kpi-sub .kpi-sub-row{color:var(--text-sub);justify-content:space-between;gap:4px;margin-top:6px;font-size:11px;display:flex}.kpi-sub .kpi-sub-row>span{white-space:nowrap;flex-direction:column;flex:1;gap:2px;min-width:0;display:flex;overflow:hidden}.kpi-sub .kpi-sub-row b{color:var(--text);font-size:12px;font-weight:600;display:block}.kpi-trend{vertical-align:middle;margin-left:4px;font-size:9px;font-weight:700;line-height:1;display:inline-block}.kpi-trend.up{color:#389e0d}.kpi-trend.down{color:#cf1322}.kpi.kpi-down{background:#fff1f0;border-color:#cf13221f}.kpi.kpi-up{background:#f0fff4;border-color:#0f6f6426}.kpi-tooltip-anchor{color:#94a3b8;cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;margin-left:4px;font-size:11px;line-height:1;display:inline-flex;position:relative}.kpi-tooltip-anchor:active{color:#475569}.kpi-tooltip-bubble{color:#f1f5f9;white-space:normal;word-break:break-word;z-index:9999;pointer-events:auto;text-align:left;background:#1e293bf2;border-radius:8px;width:220px;padding:8px 12px;font-size:12px;line-height:1.6;position:fixed;box-shadow:0 4px 16px #0000004d}.kpi.kpi-threshold-green{background:#f0fff4;border-color:#0f6f642e}.kpi.kpi-threshold-green .v{color:#0f6f64}.kpi.kpi-threshold-orange{background:#fffbeb;border-color:#d9770633}.kpi.kpi-threshold-orange .v{color:#b45309}.kpi.kpi-threshold-red{background:#fff1f0;border-color:#cf132226}.kpi.kpi-threshold-red .v{color:#cf1322}.cat-group-toggle{color:var(--brand);flex-shrink:0;margin-left:auto;font-size:11px;font-weight:600}.cat-sort-btn{cursor:pointer;color:var(--text-sub);white-space:nowrap;text-align:right;background:0 0;border:none;justify-content:flex-end;align-items:center;gap:2px;padding:0;font-size:12px;font-weight:600;display:flex}.cat-sort-btn:hover{color:var(--brand)}.sort-icon{opacity:.4;font-size:10px}.sort-icon.active{opacity:1;color:var(--brand)}.cat-sku-panel{background:var(--bg);border-bottom:1px solid var(--line);box-sizing:border-box;min-width:620px;padding:0 0 4px}.cat-sku-hint{color:var(--text-sub);box-sizing:border-box;min-width:620px;padding:6px 12px 0;font-size:11px}.cat-sku-header-wide{box-sizing:border-box;min-width:720px;color:var(--text-sub);border-bottom:1px solid var(--line);background:#f0f4ff;grid-template-columns:22px minmax(0,1fr) 66px 58px 56px 66px 42px 42px;gap:6px;padding:5px 16px;font-size:10px;font-weight:600;display:grid}.cat-sku-row-wide{box-sizing:border-box;background:#fff;border-bottom:1px solid #eef1f7;grid-template-columns:22px minmax(0,1fr) 66px 58px 56px 66px 42px 42px;align-items:center;gap:6px;min-width:720px;padding:6px 16px;font-size:11px;display:grid}.cat-sku-num,.cat-sku-rate{text-align:right;font-size:11px}.cat-sku-load-more{border:1px dashed var(--brand);background:var(--brand-soft);width:calc(100% - 24px);color:var(--brand);cursor:pointer;text-align:center;border-radius:8px;margin:8px 12px 10px;padding:8px 12px;font-size:12px;font-weight:600;display:block}.cat-sku-load-more:hover:not(:disabled){background:#dbeafe}.cat-sku-load-more:disabled{opacity:.6;cursor:wait}.cat-sku-load-done{text-align:center;padding:6px 12px 10px;font-size:11px}.cat-sku-header{color:var(--text-sub);border-bottom:1px solid var(--line);background:#f0f4ff;grid-template-columns:28px 1fr 70px 56px;gap:4px;padding:5px 16px;font-size:10px;font-weight:600;display:grid}.cat-sku-header.cat-sku-header-wide,.cat-sku-row.cat-sku-row-wide{box-sizing:border-box;grid-template-columns:22px minmax(0,1fr) 66px 58px 56px 66px 42px 42px;gap:6px;min-width:720px}.cat-sku-row{background:#fff;border-bottom:1px solid #eef1f7;grid-template-columns:28px 1fr 70px 56px;align-items:center;gap:4px;padding:6px 16px;font-size:11px;display:grid}.cat-sku-row:last-child{border-bottom:none}.cat-sku-row:nth-child(2n){background:#f5f7fb}.cat-sku-rank{text-align:center;color:var(--text-sub);font-size:11px;font-weight:700}.cat-sku-name{min-width:0;color:var(--text);flex-direction:column;gap:1px;display:flex;overflow:hidden}.cat-sku-name-text{white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.cat-sku-code{color:var(--text-sub);white-space:nowrap;font-size:10px}.cat-sku-sales{text-align:right;color:var(--brand);font-size:11px;font-weight:600}.cat-sku-orders,.cat-sku-qty{text-align:right;color:var(--text-sub);font-size:11px}.sku-rank-header-5,.sku-rank-row-5{grid-template-columns:36px 1fr 70px 56px 52px}.sku-rank-vol{color:var(--text);text-align:right;font-size:12px;font-weight:600}.top-sku-scroll{-webkit-overflow-scrolling:touch;border:1px solid var(--line);border-radius:0;overflow-x:auto}.top-sku-header,.top-sku-row{grid-template-columns:150px 96px 72px 64px 56px 52px;align-items:stretch;gap:0;min-width:496px;font-size:12px;display:grid}.top-sku-header{color:var(--text-sub);background:#eef2f8;border-bottom:2px solid #c8d4e8;border-radius:0;align-items:center;font-size:12px;font-weight:700}.top-sku-header>*{white-space:nowrap;align-items:center;padding:10px 6px;line-height:1.3;display:flex}.top-sku-header .tsk-val{text-align:right;justify-content:flex-end}.top-sku-row{border-bottom:1px solid var(--line)}.top-sku-row:last-child{border-bottom:none}.top-sku-row:nth-child(odd){background:#fff}.top-sku-row:nth-child(2n){background:#f8fafd}.top-sku-row>*{padding:8px}.tsk-name{width:160px;min-width:160px}.tsk-sku-name{color:var(--text);white-space:normal;word-break:break-word;font-size:12px;font-weight:600;line-height:1.4}.tsk-sku-code{color:var(--text-sub);margin-top:1px;font-size:10px}.tsk-val{text-align:right;min-width:0}.tsk-primary{color:var(--text);font-size:11.5px;font-weight:600;line-height:1.3}.tsk-secondary{color:var(--text-sub);font-size:10px;line-height:1.3}.tsk-chg-row{flex-wrap:wrap;justify-content:flex-end;gap:4px;margin-top:2px;display:flex}.tsk-chg-up{color:#389e0d;white-space:nowrap;font-size:10px;font-weight:700}.tsk-chg-dn{color:#cf1322;white-space:nowrap;font-size:10px;font-weight:700}.tsk-chg-na{color:var(--text-sub);font-weight:400}.fx-rate-bar{color:#7c5f00;white-space:nowrap;background:#fffbe6;border-bottom:1px solid #ffe58f;align-items:center;gap:4px;padding:5px 16px;font-size:12px;display:flex;overflow:hidden}.fx-rate-bar strong{color:#d46b08;flex-shrink:0;font-weight:700}.fx-rate-bar .fx-source{color:#ad8b00;opacity:.85;text-overflow:ellipsis;flex-shrink:1;min-width:0;font-size:10px;overflow:hidden}.same-period-bar{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;margin-top:14px;padding:10px 14px}.same-period-title{color:#64748b;margin-bottom:8px;font-size:.78rem;font-weight:500}.same-period-row{gap:24px;display:flex}.same-period-item{flex-direction:column;gap:2px;display:flex}.same-period-label{color:#94a3b8;font-size:.75rem}.same-period-val{color:#1e293b;font-size:1.05rem;font-weight:700}.trend-section{min-height:360px;margin-top:16px;padding-bottom:24px}.trend-chart-hint{text-align:center;color:#94a3b8;margin:10px 0 0;font-size:.7rem;line-height:1.4}.trend-chart-wrap{margin-top:12px}.trend-chart-wrap svg{width:100%;height:auto;min-height:140px;display:block}.trend-legend{justify-content:center;gap:20px;margin-top:6px;font-size:.78rem;display:flex}.trend-legend-item{font-weight:500}.trend-detail{border-top:1px solid #e5e7eb;margin-top:16px;padding-top:12px}.trend-detail-title{color:#374151;margin-bottom:10px;font-size:.85rem;font-weight:600}.data-table{border-collapse:collapse}.data-table th{color:#6b7280;white-space:nowrap;background:#f9fafb;border-bottom:1px solid #e5e7eb;padding:6px 10px;font-size:.78rem;font-weight:600}.data-table td{white-space:nowrap;border-bottom:1px solid #f3f4f6;padding:5px 10px}.data-table tr:last-child td{border-bottom:none}.data-table tbody tr.row-loss{background:#fff1f2}.data-table tbody tr.row-loss td{border-bottom-color:#fecdd3}.kpi-rt-row{color:#6366f1;border-top:1px dashed #e5e7eb;margin-top:4px;padding-top:4px;font-size:.72rem}.kpi-rt-row b{color:#4f46e5}.trend-period-select{color:#374151;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:6px;outline:none;min-width:90px;padding:4px 8px;font-size:.82rem}.trend-period-select:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f626}.trend-card-head{flex-wrap:nowrap;align-items:center;gap:8px;display:flex}.trend-card-head h2{flex-shrink:0;margin-right:auto}.trend-custom-inline{flex-wrap:nowrap;flex-shrink:1;align-items:center;gap:6px;min-width:0;display:flex}.trend-custom-inline input[type=date]{border:1px solid #d1d5db;border-radius:6px;outline:none;width:108px;min-width:0;padding:3px 6px;font-size:.78rem}.trend-custom-inline input[type=date]:focus{border-color:#3b82f6}.trend-custom-sep{color:#6b7280;font-size:.9rem}.trend-custom-btn{color:#fff;cursor:pointer;background:#3b82f6;border:none;border-radius:6px;padding:4px 14px;font-size:.82rem;font-weight:500}.trend-custom-btn:hover{background:#2563eb}.trend-custom-error{color:#ef4444;white-space:nowrap;font-size:.75rem}@media (width<=480px){.trend-card-head{flex-wrap:wrap}.trend-custom-inline{flex-wrap:wrap;order:2;width:100%}.trend-card-head .trend-period-select{order:1;margin-left:auto}.trend-card-head h2{order:0;margin-right:0}}.trend-pagination{color:#374151;justify-content:center;align-items:center;gap:12px;margin-top:10px;font-size:.82rem;display:flex}.trend-pagination button{cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:4px;padding:2px 10px;font-size:1rem;line-height:1.2}.trend-pagination button:disabled{opacity:.4;cursor:default}.store-kpi-cards{flex-wrap:wrap;gap:10px;margin-top:10px;display:flex}.store-kpi-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;flex:120px;min-width:100px;padding:10px 14px}.store-kpi-label{color:#6b7280;margin-bottom:4px;font-size:.75rem}.store-kpi-val{color:#111827;font-size:1rem;font-weight:700}@media (orientation:landscape){.app,.page-wrap{max-width:100%;padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);padding-bottom:max(48px, env(safe-area-inset-bottom,0))}.app-header{max-width:100%;padding:0 20px}.card{border-radius:14px;margin:10px 16px}.kpi-grid,.kpi-grid-2{grid-template-columns:repeat(4,minmax(0,1fr))}.kpi-grid-4{grid-template-columns:repeat(6,minmax(0,1fr))}.psd-hero{flex-flow:wrap;align-items:flex-start;gap:24px}.psd-hero .hero-main{flex:none}.psd-hero .psd-compare{flex:1 1 0}.trend-detail-scroll{max-height:none;overflow-x:auto}.data-table th,.data-table td{padding:8px 14px;font-size:.82rem}.store-kpi-cards{grid-template-columns:repeat(4,1fr)}.app{padding-bottom:env(safe-area-inset-bottom,0)}}@media (orientation:landscape) and (height<=500px){.app-header{padding-top:6px;padding-bottom:6px}.card{margin:6px 12px}.kpi{padding:7px 8px}.kpi .v{font-size:1rem}.kpi-sub-row,.kpi-rt-row{font-size:.68rem}}@media (width>=768px){.app,.page-wrap{max-width:960px;margin:0 auto;padding-bottom:48px;padding-left:16px;padding-right:16px}.card{border-radius:16px;margin:10px 0}.kpi-grid,.kpi-grid-2{grid-template-columns:repeat(4,minmax(0,1fr))}.kpi-grid-4{grid-template-columns:repeat(6,minmax(0,1fr))}.store-kpi-cards{grid-template-columns:repeat(4,1fr)}.data-table{min-width:unset}}.alert-bell-btn{width:36px;height:36px;color:var(--text-secondary,#6b7280);cursor:pointer;background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex;position:relative}.alert-bell-btn:hover{color:#ef4444;background:#ef444414}.alert-bell-badge{color:#fff;text-align:center;pointer-events:none;background:#ef4444;border-radius:8px;min-width:16px;height:16px;padding:0 3px;font-size:10px;font-weight:700;line-height:16px;position:absolute;top:2px;right:2px}.alert-banner{color:#92400e;cursor:pointer;text-align:left;background:linear-gradient(135deg,#fff7ed 0%,#fef3c7 100%);border:none;border-left:3px solid #f59e0b;border-radius:10px;align-items:center;gap:8px;width:100%;margin-bottom:8px;padding:10px 14px;font-size:13.5px;transition:background .15s;display:flex}.alert-banner:hover{background:linear-gradient(135deg,#fef3c7 0%,#fde68a 100%)}.alert-banner strong{color:#ef4444;font-size:15px}.alert-bell-btn--critical .alert-bell-badge{animation:2s ease-in-out infinite badgePulse}@keyframes badgePulse{0%{box-shadow:0 0 #cf132280}60%{box-shadow:0 0 0 5px #cf132200}to{box-shadow:0 0 #cf132200}}.back-arrow-btn{width:32px;height:32px;color:var(--text-secondary,#6b7280);cursor:pointer;background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-right:-4px;transition:background .15s,color .15s;display:flex}.back-arrow-btn:hover{color:var(--text-primary,#111827);background:#0000000f}
