@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap";:root,:root[data-theme=dark]{--bg: #0B0B0C;--s1: #141416;--s2: #18181B;--s3: #1F1F23;--s4: #27272A;--bd: #26262A;--bd2: #34343A;--tx: #F5F5F4;--t2: #A8A29E;--t3: #78716C;--t4: #52525B;--ac: #7C7BFF;--ac2: #9997FF;--ac3: #4F46E5;--ac-soft: #1E1F3A;--ac-weak: #15162A;--gn: #34D399;--rd: #F87171;--yl: #FBBF24;--pu: #C084FC;--cy: #22D3EE;--shadow-sm: 0 1px 2px rgba(0,0,0,.35);--shadow-md: 0 12px 32px rgba(0,0,0,.45);color-scheme:dark}:root[data-theme=light]{--bg: #FAFAF9;--s1: #FFFFFF;--s2: #FFFFFF;--s3: #F5F5F4;--s4: #E7E5E4;--bd: #E7E5E4;--bd2: #D6D3D1;--tx: #0C0C0D;--t2: #78716C;--t3: #A8A29E;--t4: #D6D3D1;--ac: #4F46E5;--ac2: #6366F1;--ac3: #3730A3;--ac-soft: #EEF0FF;--ac-weak: #F5F6FF;--gn: #059669;--rd: #DC2626;--yl: #D97706;--pu: #7C3AED;--cy: #0891B2;--shadow-sm: 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 8px 24px rgba(0,0,0,.06);color-scheme:light}:root{--r: 10px;--rs: 6px;--font: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, Menlo, monospace;--sb-w: 248px;--sb-col: 60px;--topbar-h: 56px}.mono{font-family:var(--font-mono);font-feature-settings:"tnum"}.num{font-variant-numeric:tabular-nums}:focus-visible{outline:2px solid var(--ac);outline-offset:2px;border-radius:6px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow-x:hidden}body{font-family:var(--font);background:var(--bg);color:var(--tx);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}.app-shell{display:flex;height:100dvh;overflow:hidden}.app-sidebar{width:var(--sb-w);flex-shrink:0;background:var(--s1);border-right:1px solid var(--bd);display:flex;flex-direction:column;overflow:hidden;transition:width .2s;z-index:10}.app-sidebar.collapsed{width:var(--sb-col)}.app-main{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden}.app-topbar{height:var(--topbar-h);background:var(--s1);border-bottom:1px solid var(--bd);display:flex;align-items:center;padding:0 18px;gap:10px;flex-shrink:0}.app-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:18px}.mob-topbar{display:none;height:var(--topbar-h);background:var(--s1);border-bottom:1px solid var(--bd);align-items:center;padding:0 12px;gap:10px;flex-shrink:0;position:sticky;top:0;z-index:20}.mob-btn{width:36px;height:36px;background:none;border:none;color:var(--t2);cursor:pointer;border-radius:var(--rs);display:flex;align-items:center;justify-content:center}.mob-btn:hover{background:var(--s3);color:var(--tx)}.mob-title{font-size:15px;font-weight:600;color:var(--tx);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mob-logo{font-size:16px;font-weight:800;color:var(--ac);letter-spacing:-.5px}.drawer-back{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:30;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.drawer-back.open{display:block}.drawer{position:fixed;top:0;left:0;bottom:0;width:var(--sb-w);background:var(--s1);border-right:1px solid var(--bd);transform:translate(-100%);transition:transform .25s;z-index:40;display:flex;flex-direction:column;overflow:hidden}.drawer.open{transform:translate(0)}.mob-nav{display:none;position:fixed;bottom:0;left:0;right:0;height:58px;background:var(--s1);border-top:1px solid var(--bd);z-index:20;padding-bottom:env(safe-area-inset-bottom,0)}.mob-nav-inner{display:flex;height:58px;align-items:stretch}.mob-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;background:none;border:none;color:var(--t3);cursor:pointer;padding:4px 2px;transition:color .15s;position:relative}.mob-nav-item.active{color:var(--ac)}.mob-nav-item svg{width:20px;height:20px}.mob-nav-label{font-size:10px;font-weight:500}.mob-nav-badge{position:absolute;top:4px;right:calc(50% - 16px);background:var(--rd);color:#fff;font-size:9px;font-weight:700;min-width:15px;height:15px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 3px}.sb-head{padding:14px 12px;border-bottom:1px solid var(--bd);display:flex;align-items:center;gap:9px;flex-shrink:0;min-height:52px}.sb-logo{width:28px;height:28px;background:var(--ac);border-radius:var(--rs);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:13px;color:#fff;flex-shrink:0}.sb-brand{font-size:13px;font-weight:700;color:var(--tx);overflow:hidden;white-space:nowrap}.sb-col-btn{margin-left:auto;width:26px;height:26px;background:none;border:none;color:var(--t3);cursor:pointer;border-radius:var(--rs);flex-shrink:0;display:flex;align-items:center;justify-content:center}.sb-col-btn:hover{background:var(--s3);color:var(--tx)}.sb-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:6px 0}.sb-sec-label{font-size:10px;font-weight:600;color:var(--t4);text-transform:uppercase;letter-spacing:.08em;padding:6px 12px 4px;white-space:nowrap;overflow:hidden}.sb-item{width:100%;display:flex;align-items:center;gap:9px;padding:8px 12px;background:none;border:none;color:var(--t2);cursor:pointer;font-size:13px;font-weight:500;text-align:left;transition:background .12s,color .12s;position:relative;overflow:hidden;white-space:nowrap}.sb-item svg{width:17px;height:17px;flex-shrink:0}.sb-item:hover{background:var(--s3);color:var(--tx)}.sb-item.active{background:#4f83ff1f;color:var(--ac)}.sb-item.active:before{content:"";position:absolute;left:0;top:20%;bottom:20%;width:3px;background:var(--ac);border-radius:0 2px 2px 0}.sb-item-label{overflow:hidden;text-overflow:ellipsis}.sb-item-badge{margin-left:auto;background:var(--ac);color:#fff;font-size:10px;font-weight:700;padding:1px 5px;border-radius:10px;flex-shrink:0}.sb-user{padding:10px 12px;border-top:1px solid var(--bd);display:flex;align-items:center;gap:8px;flex-shrink:0;overflow:hidden}.sb-avatar{width:28px;height:28px;border-radius:50%;background:var(--s4);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--ac2);flex-shrink:0}.sb-user-info{overflow:hidden;min-width:0}.sb-user-name{font-size:12px;font-weight:600;color:var(--tx);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sb-user-role{font-size:11px;color:var(--t3)}.sb-logout{margin-left:auto;width:26px;height:26px;background:none;border:none;color:var(--t3);cursor:pointer;border-radius:var(--rs);flex-shrink:0;display:flex;align-items:center;justify-content:center}.sb-logout:hover{color:var(--rd);background:#f43f5e1a}.card{background:var(--s2);border:1px solid var(--bd);border-radius:var(--r);overflow:hidden}.card-header{padding:12px 16px;border-bottom:1px solid var(--bd);display:flex;align-items:center;gap:10px;flex-wrap:wrap}.card-title{font-size:14px;font-weight:600;color:var(--tx)}.card-body{padding:16px}.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:10px;margin-bottom:16px}.stat-card{background:var(--s2);border:1px solid var(--bd);border-radius:var(--r);padding:12px 14px}.stat-label{font-size:11px;color:var(--t2);margin-bottom:5px}.stat-value{font-size:22px;font-weight:700;color:var(--tx);line-height:1}.stat-sub{font-size:11px;color:var(--t3);margin-top:3px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}.table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}table{width:100%;border-collapse:collapse}th{text-align:left;font-size:11px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.06em;padding:9px 12px;background:var(--s1);border-bottom:1px solid var(--bd);white-space:nowrap}td{padding:9px 12px;border-bottom:1px solid var(--bd);font-size:13px;color:var(--tx);vertical-align:middle}tr:last-child td{border-bottom:none}tr:hover td{background:var(--s3)}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 13px;border-radius:var(--rs);font-size:13px;font-weight:500;cursor:pointer;border:none;transition:opacity .15s,background .15s;white-space:nowrap;text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn svg{width:14px;height:14px}.btn-primary{background:var(--ac);color:#fff}.btn-primary:hover:not(:disabled){background:var(--ac2)}.btn-secondary{background:var(--s4);color:var(--tx)}.btn-secondary:hover:not(:disabled){background:var(--bd2)}.btn-danger{background:#f43f5e1f;color:var(--rd)}.btn-danger:hover:not(:disabled){background:#f43f5e38}.btn-ghost{background:none;color:var(--t2);border:1px solid var(--bd)}.btn-ghost:hover:not(:disabled){background:var(--s3);color:var(--tx)}.btn-sm{padding:4px 9px;font-size:12px}.btn-icon{padding:7px}.btn-block{width:100%;justify-content:center}.form-group{margin-bottom:13px}.form-label{display:block;font-size:12px;font-weight:500;color:var(--t2);margin-bottom:4px}.form-input,.form-select,.form-textarea{width:100%;background:var(--s1);border:1px solid var(--bd);border-radius:var(--rs);color:var(--tx);font-family:var(--font);font-size:13px;padding:7px 10px;outline:none;transition:border-color .15s;-webkit-appearance:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--ac)}.form-textarea{resize:vertical;min-height:76px}.form-select option{background:var(--s2)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:13px}.form-row{display:flex;gap:8px;align-items:flex-end}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:50;display:flex;align-items:flex-end;justify-content:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{background:var(--s2);border:1px solid var(--bd);width:100%;max-height:90dvh;overflow-y:auto;border-radius:var(--r) var(--r) 0 0;border-bottom:none}.modal-header{padding:14px 16px;border-bottom:1px solid var(--bd);display:flex;align-items:center;gap:10px;position:sticky;top:0;background:var(--s2);z-index:1}.modal-title{font-size:15px;font-weight:600;color:var(--tx);flex:1}.modal-close{width:28px;height:28px;background:none;border:none;color:var(--t2);cursor:pointer;border-radius:var(--rs);display:flex;align-items:center;justify-content:center}.modal-close:hover{background:var(--s4);color:var(--tx)}.modal-body{padding:16px}.modal-footer{padding:12px 16px;border-top:1px solid var(--bd);display:flex;gap:8px;justify-content:flex-end}.badge{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:20px;font-size:11px;font-weight:600}.badge-green{background:#22c55e21;color:var(--gn)}.badge-red{background:#f43f5e21;color:var(--rd)}.badge-yellow{background:#f59e0b21;color:var(--yl)}.badge-blue{background:#4f83ff21;color:var(--ac)}.badge-gray{background:var(--s4);color:var(--t2)}.badge-purple{background:#a855f721;color:var(--pu)}.tabs{display:flex;gap:2px;background:var(--s1);border-radius:var(--rs);padding:3px;overflow-x:auto;scrollbar-width:none;flex-shrink:0}.tabs::-webkit-scrollbar{display:none}.tab{padding:5px 12px;border-radius:5px;font-size:13px;font-weight:500;color:var(--t2);cursor:pointer;border:none;background:none;white-space:nowrap;transition:background .12s,color .12s}.tab.active{background:var(--s2);color:var(--tx)}.page-header{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap}.page-title{font-size:18px;font-weight:700;color:var(--tx)}.page-actions{margin-left:auto;display:flex;gap:8px}.filter-row{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap;align-items:center}.filter-row .form-input,.filter-row .form-select{width:auto;min-width:130px;flex:1;max-width:200px}.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 16px;color:var(--t3);gap:8px;text-align:center}.empty svg{width:38px;height:38px;opacity:.35}.empty-title{font-size:14px;font-weight:600;color:var(--t2)}.login-wrap{min-height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:14px}.login-card{width:100%;max-width:390px;background:var(--s2);border:1px solid var(--bd);border-radius:14px;padding:28px}.login-logo{font-size:22px;font-weight:800;color:var(--ac);margin-bottom:4px;letter-spacing:-.5px}.detail-row{display:flex;align-items:flex-start;padding:9px 0;border-bottom:1px solid var(--bd);gap:10px}.detail-row:last-child{border-bottom:none}.detail-key{font-size:12px;color:var(--t2);width:130px;flex-shrink:0;padding-top:1px}.detail-val{font-size:13px;color:var(--tx);flex:1;min-width:0;word-break:break-word}.cart-layout{display:grid;grid-template-columns:1fr 280px;gap:14px;align-items:start}.news-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:10px}.news-card{background:var(--s2);border:1px solid var(--bd);border-radius:var(--r);overflow:hidden}.news-card-img{width:100%;height:130px;object-fit:cover;background:var(--s3)}.news-card-body{padding:12px 14px}.news-card-title{font-size:14px;font-weight:600;color:var(--tx);margin-bottom:5px}.news-card-text{font-size:12px;color:var(--t2);line-height:1.5}.news-card-date{font-size:11px;color:var(--t3);margin-top:8px}.disc-block{background:#f59e0b12;border:1px solid rgba(245,158,11,.2);border-radius:var(--r);padding:12px 14px;margin-bottom:14px}.disc-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.disc-title{font-size:13px;font-weight:600;color:var(--yl)}.disc-pct{font-size:28px;font-weight:800;color:var(--yl);line-height:1}.alert{padding:10px 13px;border-radius:var(--rs);font-size:13px;margin-bottom:12px}.alert-error{background:#f43f5e1a;color:var(--rd);border:1px solid rgba(244,63,94,.2)}.alert-success{background:#22c55e1a;color:var(--gn);border:1px solid rgba(34,197,94,.2)}.alert-info{background:#4f83ff1a;color:var(--ac);border:1px solid rgba(79,131,255,.2)}.divider{height:1px;background:var(--bd);margin:14px 0}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.flex-1{flex:1}.min-w-0{min-width:0}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.text-right{text-align:right}.text-muted{color:var(--t2)}.fw-600{font-weight:600}.fw-700{font-weight:700}.gap-8{gap:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.spinner{width:18px;height:18px;border:2px solid var(--bd);border-top-color:var(--ac);border-radius:50%;animation:spin .7s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.loading-center{display:flex;align-items:center;justify-content:center;padding:40px;gap:10px;color:var(--t2)}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bd2);border-radius:3px}.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:20px}.kpi{background:var(--s2);border:1px solid var(--bd);border-radius:12px;padding:16px 18px;transition:border-color .15s ease}.kpi:hover{border-color:var(--bd2)}.kpi-label{font-size:11px;font-weight:500;color:var(--t2);text-transform:uppercase;letter-spacing:.04em}.kpi-value{font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-size:26px;font-weight:600;letter-spacing:-.02em;margin-top:6px;color:var(--tx)}.kpi-value .unit{color:var(--t2);font-size:14px;font-weight:500;margin-left:4px}.kpi-delta{display:inline-flex;align-items:center;gap:3px;font-size:12px;font-weight:600;margin-top:8px}.kpi-delta.up{color:var(--gn)}.kpi-delta.down{color:var(--rd)}.kpi-delta .since{color:var(--t2);font-weight:500;margin-left:4px}.kpi .spark{margin-top:10px;height:30px;width:100%;display:block}.chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:var(--s3);border:1px solid var(--bd);border-radius:999px;font-size:12px;font-weight:500;color:var(--t2);cursor:pointer;transition:all .12s ease}.chip:hover{color:var(--tx);border-color:var(--bd2)}.chip.active{background:var(--ac-soft);color:var(--ac);border-color:var(--ac)}.chip .count{color:var(--t3);font-weight:500}.chip.active .count{color:var(--ac);opacity:.7}.badge-status{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:500;background:var(--s3);border:1px solid var(--bd);color:var(--t2)}.badge-status.success{background:#34d3991f;color:var(--gn);border-color:#34d39940}.badge-status.warn{background:#fbbf241f;color:var(--yl);border-color:#fbbf2440}.badge-status.danger{background:#f871711f;color:var(--rd);border-color:#f8717140}.badge-status.info{background:#7c7bff1f;color:var(--ac);border-color:#7c7bff40}.rail{display:flex;align-items:center;gap:4px;min-width:160px}.rail-stage{flex:1;height:3px;border-radius:2px;background:var(--s4);position:relative;overflow:hidden}.rail-stage.done{background:var(--gn)}.rail-stage.current:after{content:"";position:absolute;left:0;top:0;width:60%;height:100%;background:var(--ac);border-radius:2px;animation:railPulse 1.8s ease-in-out infinite}.rail-stage.current{background:var(--s4)}@keyframes railPulse{0%,to{opacity:1}50%{opacity:.5}}.rail-label{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--t2);margin-top:3px}.rail-label .dot{width:6px;height:6px;border-radius:50%;background:var(--ac)}.rail-label.done .dot{background:var(--gn)}.crit{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600}.crit:before{content:"";width:7px;height:7px;border-radius:50%}.crit.critical{color:var(--rd)}.crit.critical:before{background:var(--rd);box-shadow:0 0 0 3px #f8717126}.crit.low{color:var(--yl)}.crit.low:before{background:var(--yl);box-shadow:0 0 0 3px #fbbf2426}.crit.normal{color:var(--gn)}.crit.normal:before{background:var(--gn)}.crit.over{color:var(--t3)}.crit.over:before{background:var(--t3)}.topbar-v2{display:flex;align-items:center;gap:10px;padding:0 20px;height:var(--topbar-h);background:var(--s1);border-bottom:1px solid var(--bd);flex-shrink:0}.topbar-v2 .crumb{color:var(--t2);font-size:13px}.topbar-v2 .crumb strong{color:var(--tx);font-weight:600}.topbar-v2 .spacer{flex:1}.cmdk-trigger{display:inline-flex;align-items:center;gap:10px;background:var(--s2);border:1px solid var(--bd);border-radius:8px;padding:6px 10px;min-width:240px;color:var(--t2);font-size:13px;cursor:pointer;transition:border-color .12s ease}.cmdk-trigger:hover{border-color:var(--bd2)}.cmdk-trigger svg{width:14px;height:14px}.kbd{font-family:var(--font-mono);font-size:11px;background:var(--s3);color:var(--t2);padding:1px 5px;border-radius:4px;border:1px solid var(--bd)}.icon-btn{width:32px;height:32px;display:grid;place-items:center;border-radius:7px;color:var(--t2);background:none;border:none;cursor:pointer;transition:background .12s ease,color .12s ease}.icon-btn:hover{background:var(--s3);color:var(--tx)}.icon-btn svg{width:16px;height:16px}.cmdk{position:fixed;top:88px;left:50%;transform:translate(-50%) translateY(-8px);width:600px;max-width:92vw;background:var(--s2);border:1px solid var(--bd);border-radius:12px;box-shadow:var(--shadow-md);z-index:100;overflow:hidden;opacity:0;pointer-events:none;transition:opacity .14s ease,transform .14s ease}.cmdk.open{opacity:1;pointer-events:all;transform:translate(-50%) translateY(0)}.cmdk input{width:100%;padding:15px 18px;background:transparent;border:none;outline:none;color:var(--tx);font-family:var(--font);font-size:15px;border-bottom:1px solid var(--bd)}.cmdk-list{max-height:380px;overflow-y:auto;padding:6px}.cmdk-group{padding:8px 10px 4px;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--t3);font-weight:600}.cmdk-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:7px;cursor:pointer;font-size:13px;color:var(--tx)}.cmdk-item:hover,.cmdk-item.active{background:var(--ac-weak);color:var(--ac)}.cmdk-item svg{width:14px;height:14px;color:var(--t2)}.cmdk-item.active svg{color:var(--ac)}.cmdk-item .hint{margin-left:auto;color:var(--t3);font-size:11px}.cmdk-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:99;opacity:0;pointer-events:none;transition:opacity .14s ease}.cmdk-backdrop.open{opacity:1;pointer-events:all}.prod-grid{display:grid;grid-template-columns:2fr 1fr;gap:14px;margin-bottom:20px}@media (max-width: 1100px){.prod-grid{grid-template-columns:1fr}}.chart-card{background:var(--s2);border:1px solid var(--bd);border-radius:12px;padding:16px 18px}.chart-card h3{font-size:14px;font-weight:600;color:var(--tx);margin:0 0 4px}.chart-card .sub{font-size:12px;color:var(--t2);margin-bottom:14px}.bar-chart{display:flex;align-items:flex-end;gap:8px;height:160px;padding:8px 0}.bar{flex:1;background:linear-gradient(to top,var(--ac3),var(--ac));border-radius:4px 4px 0 0;min-height:4px;position:relative;cursor:pointer;transition:opacity .12s ease}.bar:hover{opacity:.85}.bar-label{position:absolute;top:-20px;left:50%;transform:translate(-50%);font-size:10px;color:var(--t2);white-space:nowrap;opacity:0;transition:opacity .12s}.bar:hover .bar-label{opacity:1}.bar-x-axis{display:flex;gap:8px;margin-top:6px}.bar-x-axis>span{flex:1;text-align:center;font-size:10px;color:var(--t3)}.donut-wrap{display:flex;align-items:center;gap:16px}.donut-legend{display:flex;flex-direction:column;gap:6px;font-size:12px;flex:1}.donut-legend .row{display:flex;align-items:center;gap:8px}.donut-legend .sw{width:10px;height:10px;border-radius:2px;flex-shrink:0}.donut-legend .row span:last-child{margin-left:auto;color:var(--t2);font-family:var(--font-mono)}.so-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:60;opacity:0;pointer-events:none;transition:opacity .2s ease}.so-backdrop.open{opacity:1;pointer-events:all}.so{position:fixed;top:0;right:0;bottom:0;width:560px;max-width:92vw;background:var(--s2);border-left:1px solid var(--bd);transform:translate(100%);transition:transform .28s cubic-bezier(.32,.72,0,1);z-index:61;display:flex;flex-direction:column;box-shadow:var(--shadow-md)}.so.open{transform:translate(0)}.so-hdr{padding:16px 20px;border-bottom:1px solid var(--bd);display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.so-title{font-size:18px;font-weight:600;letter-spacing:-.01em}.so-meta{color:var(--t2);font-size:12px;margin-top:3px}.so-body{padding:18px 20px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:22px}.so-section-label{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--t3);font-weight:600;margin-bottom:8px}.kv{display:grid;grid-template-columns:140px 1fr;gap:8px 12px;font-size:13px}.kv dt{color:var(--t2);margin:0}.kv dd{margin:0;font-weight:500;color:var(--tx)}.tl{display:flex;flex-direction:column;gap:12px;position:relative;padding-left:6px}.tl:before{content:"";position:absolute;left:10px;top:6px;bottom:6px;width:1px;background:var(--bd)}.tl-item{display:grid;grid-template-columns:16px 1fr auto;gap:12px;align-items:flex-start;position:relative}.tl-dot{width:13px;height:13px;border-radius:50%;background:var(--s2);border:2px solid var(--bd);margin-top:3px;position:relative;z-index:1}.tl-dot.done{background:var(--gn);border-color:var(--gn)}.tl-dot.current{background:var(--ac);border-color:var(--ac);box-shadow:0 0 0 4px var(--ac-soft)}.tl-dot.future{background:var(--s2);border-color:var(--bd2);border-style:dashed}.tl-dot.cancel{background:var(--rd);border-color:var(--rd)}.tl-text{font-size:13px;min-width:0}.tl-text .primary{color:var(--tx);font-weight:500}.tl-text.future .primary{color:var(--t2);font-weight:400}.tl-text .who{display:flex;gap:6px;color:var(--t2);font-size:11px;margin-top:2px;flex-wrap:wrap}.tl-text .src-pill{display:inline-flex;padding:0 6px;height:16px;align-items:center;background:var(--s3);border:1px solid var(--bd);border-radius:10px;font-size:10px;font-weight:500;color:var(--t2)}.tl-text .src-pill.synth{opacity:.7;font-style:italic}.tl-time{color:var(--t3);font-size:11px;white-space:nowrap;font-family:var(--font-mono)}.items-mini{display:flex;flex-direction:column;gap:6px}.items-mini .row{display:grid;grid-template-columns:1fr auto auto;gap:12px;padding:8px 10px;background:var(--s3);border-radius:7px;font-size:13px;align-items:center}.items-mini .sku{font-size:11px;color:var(--t3);font-family:var(--font-mono);margin-top:2px}.items-mini .row .qty{color:var(--t2)}.items-mini .row .total{font-weight:600;font-family:var(--font-mono)}@media (max-width: 640px){.so{width:100%}.kv{grid-template-columns:110px 1fr}}.sync-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;background:var(--s3);border:1px solid var(--bd);font-size:12px;color:var(--t2)}.sync-badge .pulse{width:6px;height:6px;border-radius:50%;background:var(--gn);box-shadow:0 0 0 3px #34d39933;animation:railPulse 1.8s ease-in-out infinite}.sync-badge.warn{color:var(--yl);border-color:#fbbf244d;background:#fbbf2414}.sync-badge.warn .pulse{background:var(--yl);box-shadow:0 0 0 3px #fbbf2433}@media (max-width: 900px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.cmdk-trigger{min-width:auto}.topbar-v2{padding:0 12px}.topbar-v2 .cmdk-trigger span:not(.kbd){display:none}}@media (max-width: 640px){.topbar-v2{display:none}.kpi-grid{gap:8px}.kpi{padding:12px 14px}.kpi-value{font-size:20px}}@media (max-width: 1024px) and (min-width: 641px){.app-sidebar{width:var(--sb-col)}.sb-brand,.sb-sec-label,.sb-item-label,.sb-user-info,.sb-item-badge{display:none}.sb-item{justify-content:center;padding:10px}.sb-head{justify-content:center;padding:12px}.sb-col-btn{display:none}.sb-user{justify-content:center}.sb-logout{margin-left:0}}@media (max-width: 640px){.app-sidebar,.app-topbar{display:none}.mob-topbar{display:flex}.mob-nav{display:block}.app-content{padding:10px;padding-bottom:calc(68px + env(safe-area-inset-bottom,0))}.stat-grid{grid-template-columns:1fr 1fr;gap:8px}.stat-card{padding:10px 12px}.stat-value{font-size:18px}.grid-2,.grid-3,.form-grid,.cart-layout{grid-template-columns:1fr}.cart-items-card{order:2}.cart-checkout-card{order:1}.col-hide-sm{display:none!important}.page-actions{width:100%}.page-actions .btn{flex:1;justify-content:center}.filter-row .form-input,.filter-row .form-select{max-width:100%;flex:1;min-width:100px}.detail-key{width:100px}.modal-overlay{align-items:flex-end}.modal{border-radius:var(--r) var(--r) 0 0}.modal-footer{flex-direction:column-reverse}.modal-footer .btn{width:100%;justify-content:center}.login-card{padding:22px 16px}.topbar-title{font-size:14px}}
