:root{--ink: #111111;--warm-gray: #555555;--pearl: #D7D7D7;--soft-beige: #F5F3F3;--white: #FFFFFF;--blush: #FEEBEF;--blush-mid: #F9C4D0;--blush-deep: #E8829A;--lavender: #EAE6FF;--lav-mid: #C8BFFF;--lav-deep: #8B7CF6;--sky: #E6F2FF;--sky-mid: #93C5FD;--surface-2: #FAFAFA;--surface-3: #F5F5F5;--border: #EAEAEA;--border-strong:#D0D0D0;--ok: #22C55E;--ok-bg: #DCFCE7;--ok-txt: #166534;--lo: #F59E0B;--lo-bg: #FEF9C3;--lo-txt: #854D0E;--er: #EF4444;--er-bg: #FEE2E2;--er-txt: #991B1B;--font: "Poppins", "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "SF Mono", "Fira Code", monospace;--r-sm: 12px;--r-md: 16px;--r-lg: 24px;--r-xl: 32px;--r-pill: 999px;--shadow-sm: 0 1px 3px rgba(0,0,0,.05), 0 1px 2px rgba(0,0,0,.03);--shadow-md: 0 4px 16px rgba(0,0,0,.07), 0 2px 4px rgba(0,0,0,.04);--shadow-hover: 0 16px 48px rgba(0,0,0,.13), 0 4px 12px rgba(0,0,0,.06);--ease: cubic-bezier(.4, 0, .2, 1);--dur-fast: .15s;--dur-base: .2s}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow:hidden}body{font-family:var(--font);background:var(--surface-2);color:var(--ink);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{text-decoration:none;color:inherit}button,input,select,textarea{font-family:var(--font)}#app{display:flex;height:100vh}#sb{width:248px;flex-shrink:0;background:var(--white);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;transition:width var(--dur-base) var(--ease)}#sb::-webkit-scrollbar{width:3px}#sb::-webkit-scrollbar-thumb{background:var(--pearl);border-radius:2px}#sb.collapsed{width:68px}#sb.collapsed .sb-wordmark,#sb.collapsed .sb-product,#sb.collapsed .sb-sync span,#sb.collapsed .sb-grp,#sb.collapsed .nb-label,#sb.collapsed .nb-badge,#sb.collapsed .sb-footer{display:none}#sb.collapsed .sb-logo{padding:20px 0 16px;display:flex;flex-direction:column;align-items:center}#sb.collapsed .sb-sync{justify-content:center;margin-top:10px}#sb.collapsed .nb{justify-content:center;padding:10px 0;border-left-width:0}#sb.collapsed .nb.on{border-left-width:0;box-shadow:inset 2px 0 0 var(--ink)}.sb-toggle{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;cursor:pointer;color:var(--warm-gray);border:1px solid var(--border);background:var(--white);flex-shrink:0;transition:all var(--dur-fast) var(--ease)}.sb-toggle:hover{color:var(--ink);background:var(--surface-3)}.sb-toggle svg{width:15px;height:15px}.sb-logo{padding:26px 22px 20px;border-bottom:1px solid var(--border)}.sb-wordmark{font-size:19px;font-weight:700;letter-spacing:-.025em;color:var(--ink)}.sb-wordmark em{font-style:normal;color:var(--warm-gray);font-weight:300}.sb-product{font-size:10px;color:var(--warm-gray);letter-spacing:.1em;text-transform:uppercase;margin-top:2px}.sb-sync{display:flex;align-items:center;gap:6px;margin-top:12px;font-size:11px;color:var(--warm-gray)}.sb-pulse{width:7px;height:7px;border-radius:50%;background:var(--ok);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.35}}.sb-nav{padding:10px 0;flex:1}.sb-grp{font-size:9.5px;font-weight:700;color:var(--warm-gray);letter-spacing:.1em;text-transform:uppercase;padding:10px 22px 4px}.nb{display:flex;align-items:center;gap:10px;padding:8px 22px;font-size:13.5px;font-weight:600;color:var(--warm-gray);cursor:pointer;border-left:2px solid transparent;transition:all var(--dur-fast) var(--ease);-webkit-user-select:none;user-select:none}.nb:hover{color:var(--ink);background:var(--surface-3)}.nb.on{color:var(--ink);background:var(--surface-2);border-left-color:var(--ink);font-weight:700}.nb svg{width:16px;height:16px;stroke-width:1.75;flex-shrink:0;opacity:.6}.nb.on svg{opacity:1}.nb-badge{background:var(--er);color:#fff;font-size:10px;font-weight:700;padding:1px 6px;border-radius:var(--r-pill);margin-left:auto}.nb-soon{font-size:9.5px;font-weight:600;color:var(--warm-gray);letter-spacing:.04em;margin-left:auto;padding:1px 7px;border-radius:var(--r-pill);background:var(--surface-3);border:1px solid var(--border)}.nb-disabled{opacity:.55;cursor:not-allowed}.nb-disabled:hover{color:var(--warm-gray);background:transparent}.sb-footer{padding:14px 22px;border-top:1px solid var(--border);font-size:11px;color:var(--warm-gray);line-height:1.6}#main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}#topbar{background:var(--white);border-bottom:1px solid var(--border);padding:13px 28px;flex-shrink:0;display:flex;align-items:center;justify-content:space-between}.tb-title{font-size:17px;font-weight:600;letter-spacing:-.02em;color:var(--ink)}.tb-sub{font-size:12px;color:var(--warm-gray);margin-top:1px}.tb-right{display:flex;gap:8px;align-items:center}.tb-search{position:relative}.tb-search input{height:36px;border-radius:var(--r-pill);border:1.5px solid var(--border);padding:0 14px 0 36px;font-size:13px;width:200px;outline:none;background:var(--surface-2);color:var(--ink);transition:border-color var(--dur-fast) var(--ease)}.tb-search input:focus{border-color:var(--ink)}.tb-search svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);width:14px;height:14px;stroke:var(--warm-gray);pointer-events:none}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;height:48px;padding:0 22px;border-radius:var(--r-md);font-size:14px;font-weight:500;cursor:pointer;border:none;transition:all var(--dur-base) var(--ease);letter-spacing:-.01em;white-space:nowrap}.btn-primary{background:var(--ink);color:#fff}.btn-primary:hover{opacity:.88;transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background:var(--white);color:var(--ink);border:1.5px solid var(--ink)}.btn-secondary:hover{background:var(--surface-2)}.btn-ghost{background:transparent;color:var(--ink)}.btn-ghost:hover{background:var(--surface-3)}.btn-blush{background:var(--blush);color:var(--ink);border:none}.btn-blush:hover{background:var(--blush-mid)}.btn-sm{height:36px;padding:0 16px;border-radius:var(--r-sm);font-size:13px}.btn svg{width:15px;height:15px;stroke-width:2}#content{flex:1;overflow-y:auto;padding:28px}#content::-webkit-scrollbar{width:5px}#content::-webkit-scrollbar-thumb{background:var(--pearl);border-radius:3px}.page{display:flex;flex-direction:column;gap:18px}.card{background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);padding:22px 24px}.card-title{font-size:15px;font-weight:600;letter-spacing:-.01em;color:var(--ink)}.card-sub{font-size:12px;color:var(--warm-gray);margin-top:2px}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.grid-2{display:grid;grid-template-columns:2fr 1fr;gap:16px}.grid-half{display:grid;grid-template-columns:1fr 1fr;gap:16px}.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.kpi{background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);padding:22px}.kpi-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px}.kpi-ico{width:40px;height:40px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center}.kpi-ico svg{width:19px;height:19px;stroke-width:1.75}.kpi-trend{font-size:12px;font-weight:600;display:flex;align-items:center;gap:3px}.kpi-trend svg{width:13px;height:13px}.kpi-val{font-size:27px;font-weight:700;letter-spacing:-.03em;color:var(--ink);margin-bottom:4px;font-variant-numeric:tabular-nums}.kpi-lbl{font-size:12.5px;color:var(--warm-gray)}.stat-box{background:var(--white);border:1px solid var(--border);border-radius:var(--r-md);padding:14px 18px;text-align:center}.stat-num{font-size:24px;font-weight:700;letter-spacing:-.025em;font-variant-numeric:tabular-nums}.stat-lbl{font-size:11.5px;color:var(--warm-gray);margin-top:3px}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:var(--r-pill);font-size:11.5px;font-weight:500}.b-ok{background:var(--ok-bg);color:var(--ok-txt)}.b-lo{background:var(--lo-bg);color:var(--lo-txt)}.b-er{background:var(--er-bg);color:var(--er-txt)}.b-def{background:var(--surface-3);color:var(--warm-gray)}.b-blush{background:var(--blush);color:#9b2335}.b-lav{background:var(--lavender);color:#4c3baf}.b-ink{background:var(--ink);color:#fff}.pill-row{display:flex;gap:5px;flex-wrap:wrap}.pill{padding:4px 11px;border-radius:var(--r-pill);font-size:12px;cursor:pointer;border:1px solid var(--border);background:var(--surface-2);color:var(--warm-gray);transition:all var(--dur-fast) var(--ease);white-space:nowrap;-webkit-user-select:none;user-select:none}.pill.on{background:var(--ink);border-color:var(--ink);color:#fff;font-weight:500}.pill:hover:not(.on){border-color:var(--ink);color:var(--ink)}.filter-bar{background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px 20px;display:flex;gap:16px;flex-wrap:wrap;align-items:center}.fl{font-size:10px;font-weight:600;color:var(--warm-gray);letter-spacing:.08em;text-transform:uppercase;flex-shrink:0}.vsep{width:1px;height:18px;background:var(--border);flex-shrink:0}.ss-wrap{position:relative}.ss-btn{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;height:36px;padding:0 12px 0 14px;cursor:pointer;border-radius:var(--r-pill);border:1.5px solid var(--border);background:var(--surface-2);color:var(--ink);font-size:13px;transition:border-color var(--dur-fast) var(--ease)}.ss-btn:hover{border-color:var(--border-strong)}.ss-btn svg{width:15px;height:15px;stroke:var(--warm-gray);flex-shrink:0}.ss-lg .ss-btn{height:48px;padding:0 16px;font-size:15px;font-weight:600;border:2px solid var(--ink);background:var(--white);box-shadow:var(--shadow-sm);gap:10px}.ss-lg .ss-btn:hover{background:var(--surface-2)}.ss-lg .ss-search{height:44px;font-size:14px}.ss-val{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ss-panel{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:30;background:var(--white);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-md);overflow:hidden}.ss-search{width:100%;height:38px;border:none;border-bottom:1px solid var(--border);padding:0 14px;font-size:13px;outline:none;color:var(--ink);background:var(--white)}.ss-list{max-height:260px;overflow-y:auto;padding:4px}.ss-list::-webkit-scrollbar{width:5px}.ss-list::-webkit-scrollbar-thumb{background:var(--pearl);border-radius:3px}.ss-opt{padding:8px 12px;font-size:13px;border-radius:8px;cursor:pointer;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ss-opt:hover{background:var(--surface-3)}.ss-opt.on{background:var(--ink);color:#fff;font-weight:600}.ss-empty{padding:14px;font-size:13px;color:var(--warm-gray);text-align:center}.tbl-wrap{background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}.dtbl{width:100%;border-collapse:collapse}.dtbl thead th{background:var(--surface-2);padding:11px 18px;text-align:left;font-size:11px;font-weight:600;color:var(--warm-gray);letter-spacing:.06em;text-transform:uppercase;border-bottom:1px solid var(--border);white-space:nowrap}.dtbl tbody td{padding:12px 18px;font-size:13.5px;color:var(--ink);border-bottom:1px solid var(--border);vertical-align:middle}.dtbl tbody tr:last-child td{border-bottom:none}.dtbl tbody tr{transition:background var(--dur-fast) var(--ease)}.dtbl tbody tr:hover{background:var(--surface-2)}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:13px;font-weight:500;color:var(--ink)}.field input,.field select,.field textarea{height:44px;border-radius:var(--r-md);border:1.5px solid var(--border);padding:0 14px;font-size:14px;outline:none;color:var(--ink);background:var(--white);transition:border-color var(--dur-fast) var(--ease)}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--ink);box-shadow:0 0 0 3px #11111112}.field textarea{height:auto;padding:12px 14px;resize:vertical;line-height:1.5}.field select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23555555' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px;cursor:pointer}.matrix-outer{background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}.matrix-head{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--border)}.matrix-label{font-size:14px;font-weight:600;color:var(--ink)}.matrix-sub{font-size:12.5px;color:var(--warm-gray);margin-left:8px}.legend{display:flex;gap:16px}.leg-item{display:flex;align-items:center;gap:5px;font-size:11.5px;color:var(--warm-gray)}.leg-dot{width:10px;height:10px;border-radius:3px}.matrix-scroll{overflow:auto;max-height:400px}#matrix-tbl{border-collapse:collapse;width:max-content;min-width:100%}#matrix-tbl thead th{position:sticky;top:0;background:var(--surface-2);z-index:9;padding:7px 4px;font-size:10.5px;font-weight:600;color:var(--warm-gray);text-align:center;border-bottom:1px solid var(--border);white-space:nowrap;min-width:42px;letter-spacing:.04em}#matrix-tbl thead th:first-child{position:sticky;left:0;z-index:10;text-align:left;padding:7px 16px;min-width:72px;background:var(--surface-2);border-right:1px solid var(--border)}#matrix-tbl tbody td{padding:3px;border-bottom:1px solid var(--surface-2);text-align:center}#matrix-tbl tbody td:first-child{position:sticky;left:0;background:var(--white);z-index:1;padding:4px 16px;font-size:12.5px;color:var(--warm-gray);font-weight:600;font-variant-numeric:tabular-nums;border-right:1px solid var(--border);white-space:nowrap}.mc{display:inline-flex;align-items:center;justify-content:center;width:34px;height:24px;border-radius:5px;font-size:12.5px;font-weight:700;cursor:pointer;font-variant-numeric:tabular-nums;transition:transform var(--dur-fast) var(--ease)}.mc:hover{transform:scale(1.2);position:relative;z-index:5}.mc.ok{background:var(--ok-bg);color:var(--ok-txt)}.mc.lo{background:var(--lo-bg);color:var(--lo-txt)}.mc.er{background:var(--er-bg);color:var(--er-txt)}.alert-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--r-sm);border-left:3px solid;font-size:13px;margin-bottom:5px}.alert-item.out{background:var(--er-bg);border-color:var(--er)}.alert-item.low{background:var(--lo-bg);border-color:var(--lo)}.row-item{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border)}.row-item:last-child{border-bottom:none}.ri-name{font-size:13.5px;color:var(--ink)}.ri-sub{font-size:11.5px;color:var(--warm-gray);margin-top:1px}.cell-av{display:flex;align-items:center;gap:10px}.av{width:32px;height:32px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:11.5px;font-weight:600}.av-name{font-size:13.5px;font-weight:500}.av-sub{font-size:11.5px;color:var(--warm-gray)}.rank-num{width:22px;height:22px;border-radius:6px;flex-shrink:0;background:var(--surface-3);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--warm-gray)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.success-block{background:var(--ok-bg);border-radius:var(--r-lg);padding:32px;text-align:center;color:var(--ok-txt)}.success-block svg{width:36px;height:36px;stroke:var(--ok);margin-bottom:10px}.chart-wrap{position:relative}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#11111173;display:flex;align-items:center;justify-content:center;padding:24px}.modal-card{background:var(--white);border-radius:var(--r-lg);box-shadow:var(--shadow-hover);width:100%;max-width:460px;max-height:90vh;overflow-y:auto}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--border)}.modal-title{font-size:16px;font-weight:700;letter-spacing:-.015em}.modal-x{width:30px;height:30px;border-radius:8px;cursor:pointer;border:none;background:var(--surface-3);color:var(--ink);font-size:16px;line-height:1}.modal-x:hover{background:var(--border-strong)}.modal-body{padding:22px}.modal-foot{display:flex;gap:10px;justify-content:flex-end;padding:16px 22px;border-top:1px solid var(--border)}.slip-row{display:flex;align-items:center;justify-content:space-between;padding:9px 0;font-size:13.5px}.slip-row+.slip-row{border-top:1px solid var(--border)}.slip-total{padding:12px 0 0;margin-top:6px;border-top:2px solid var(--ink);display:flex;align-items:center;justify-content:space-between}.slip-total .v{font-size:22px;font-weight:800;letter-spacing:-.02em}.link-code{font-family:var(--font-mono);font-weight:700;font-size:13px;color:var(--ink);background:none;border:none;cursor:pointer;padding:0;border-bottom:1.5px dashed var(--border-strong);transition:color var(--dur-fast) var(--ease)}.link-code:hover{color:var(--lav-deep);border-bottom-color:var(--lav-deep)}.num{font-variant-numeric:tabular-nums}.mono{font-family:var(--font-mono)}.text-muted{color:var(--warm-gray)}.fw-6{font-weight:600}.fw-7{font-weight:700}.sheet-wrap{background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);overflow:auto;max-height:75vh}.sheet{border-collapse:separate;border-spacing:0;font-size:12px;width:max-content;min-width:100%}.sheet thead th{position:sticky;top:0;background:var(--surface-2);color:var(--ink);font-weight:700;border-bottom:1px solid var(--border);padding:6px 10px;text-align:center;white-space:nowrap;z-index:3}.sheet thead tr:nth-child(2) th{top:30px;z-index:3}.sheet th.sheet-cat{background:#f4f1ea;border-left:1px solid var(--border);border-right:1px solid var(--border)}.sheet th.sheet-prod{font-weight:600;background:#fafaf7;min-width:36px;max-width:64px;white-space:normal;word-break:break-word;line-height:1.2;padding:4px;vertical-align:bottom}.sheet th.sheet-fz{position:sticky;left:0;background:#ebe7da;z-index:5;min-width:84px;border-right:2px solid #a59980;box-shadow:2px 0 #0000000f}.sheet thead th.sheet-fz{z-index:6;background:#e3ddca}.sheet th.sheet-row-h{font-weight:600;text-align:left;background:#ebe7da;border-bottom:1px solid var(--border);border-right:2px solid #a59980;box-shadow:2px 0 #0000000f;padding:4px 10px;color:var(--ink)}.sheet td.sheet-cell{padding:3px 4px;text-align:center;border-bottom:1px solid var(--border);border-right:1px dashed #ececec;white-space:nowrap;font-variant-numeric:tabular-nums;min-width:32px;max-width:64px}.sheet td.sheet-cell.muted{color:#c8c8c8}.sheet td.sheet-cell.is-low{background:#fff8e1;color:var(--lo);font-weight:600}.sheet td.sheet-cell.is-zero{color:var(--er);font-weight:700;background:var(--white)}.sheet td.sheet-cell.is-na{background:repeating-linear-gradient(135deg,#f1f1f1 0,#f1f1f1 6px,#e7e7e7 6px,#e7e7e7 12px);color:transparent;cursor:not-allowed}.sheet tbody tr:hover td.sheet-cell{background:#fafafa}.sheet tbody tr:hover td.sheet-cell.is-low{background:#fff3c4}.sheet tbody tr:hover td.sheet-cell.is-zero{background:#fff5f5}.sheet tbody tr:hover td.sheet-cell.is-na{background:repeating-linear-gradient(135deg,#ececec 0,#ececec 6px,#e2e2e2 6px,#e2e2e2 12px)}.modal-card.preview-card{max-width:920px;width:92vw;max-height:88vh;display:flex;flex-direction:column}.preview-body{overflow:auto;padding:16px 20px}.preview-cat{margin-bottom:22px}.preview-cat-h{font-weight:700;font-size:14px;margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border);color:var(--ink)}.preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:10px}.preview-prod{background:var(--white);border:1px solid var(--border);border-radius:8px;padding:6px;font-size:11px;text-align:center}.preview-prod img{width:100%;height:90px;object-fit:contain;background:#f7f5ee;border-radius:4px;display:block}.preview-prod .preview-imgna{width:100%;height:90px;background:#f1f1f1;border-radius:4px;display:flex;align-items:center;justify-content:center;color:#aaa}.preview-prod-n{margin-top:4px;line-height:1.2;word-break:break-word;min-height:26px}
