*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--c-text:#1a1a1a;--c-muted:#6b6b6b;--c-border:#e4e4e0;--c-bg:#f5f5f3;--c-card:#ffffff;--c-sidebar:#1e1e1e;--c-sidebar-hover:#2e2e2e;--c-sidebar-active:#2a3f60;--c-sidebar-text:#d0d0d0;--c-sidebar-muted:#888;--c-blue:#185FA5;--c-blue-dark:#0C447C;--c-blue-light:#E6F1FB;--c-ok:#3B6D11;--c-ok-bg:#EAF3DE;--c-ok-bar:#639922;--c-warn:#854F0B;--c-warn-bg:#FAEEDA;--c-warn-bar:#EF9F27;--c-danger:#A32D2D;--c-danger-bg:#FCEBEB;--c-danger-bar:#E24B4A;--c-purple:#534AB7;--c-purple-bg:#EEEDFE;--sidebar-w:220px;--topbar-h:52px;--nav-h:60px;--safe-bottom:env(safe-area-inset-bottom,0px);--safe-top:env(safe-area-inset-top,0px)}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;background:var(--c-bg);color:var(--c-text);overscroll-behavior:none;-webkit-font-smoothing:antialiased}.app-shell,body{min-height:100dvh}.app-shell,.sidebar{display:flex}.sidebar{width:var(--sidebar-w);background:var(--c-sidebar);flex-direction:column;flex-shrink:0;position:fixed;left:0;top:0;bottom:0;z-index:100;overflow-y:auto}.sidebar-logo{padding:20px 16px 14px;border-bottom:1px solid rgba(255,255,255,.08)}.sidebar-logo-title{font-size:15px;font-weight:600;color:#fff}.sidebar-logo-sub{font-size:11px;color:var(--c-sidebar-muted);margin-top:2px}.sidebar-section{padding:12px 8px 4px}.sidebar-section-label{font-size:10px;color:#555;text-transform:uppercase;letter-spacing:.08em;padding:0 8px 6px}.sidebar-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:8px;color:var(--c-sidebar-text);font-size:13px;font-weight:400;cursor:pointer;transition:all .15s;border:none;background:none;width:100%;text-align:left;margin-bottom:1px}.sidebar-item:hover{background:var(--c-sidebar-hover);color:#fff}.sidebar-item.active{background:var(--c-sidebar-active);color:#fff;font-weight:500}.sidebar-item svg{flex-shrink:0;opacity:.7}.sidebar-item.active svg{opacity:1}.sidebar-badge{margin-left:auto;background:var(--c-danger);color:#fff;font-size:10px;font-weight:600;padding:1px 6px;border-radius:10px}.sidebar-badge.warn{background:var(--c-warn)}.sidebar-footer{margin-top:auto;padding:12px 16px;border-top:1px solid rgba(255,255,255,.08)}.sidebar-sync{font-size:11px;color:#555}.sidebar-sync span{color:#888;display:block;margin-top:1px}.main-area{flex:1 1;margin-left:var(--sidebar-w);display:flex;flex-direction:column;min-height:100dvh}.page-content{flex:1 1;overflow-y:auto}.topbar{position:sticky;top:0;z-index:50;background:var(--c-card);border-bottom:1px solid var(--c-border);padding:0 20px;height:var(--topbar-h);display:flex;align-items:center;justify-content:space-between;gap:12px}.topbar-title{font-size:16px;font-weight:600;color:var(--c-text)}.topbar-sub{font-size:12px;color:var(--c-muted);margin-left:10px}.topbar-left,.topbar-right{display:flex;align-items:center}.topbar-right{gap:8px}@media (max-width:768px){.sidebar{display:none}.main-area{margin-left:0}.page-content{padding-bottom:calc(var(--nav-h) + var(--safe-bottom))}.topbar{padding:0 14px}.bottom-nav{display:flex}}@media (min-width:769px){.bottom-nav{display:none}.page-content{padding-bottom:0}}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:calc(var(--nav-h) + var(--safe-bottom));background:var(--c-card);border-top:1px solid var(--c-border);align-items:flex-start;padding-top:6px;z-index:100}.nav-item{flex:1 1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 4px;cursor:pointer;color:var(--c-muted);border:none;background:none;transition:color .15s;-webkit-tap-highlight-color:transparent}.nav-item.active{color:var(--c-blue)}.nav-item svg{width:22px;height:22px}.nav-label{font-size:10px;font-weight:500}.stat-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1px;background:var(--c-border);border-bottom:1px solid var(--c-border)}.stat-cell{background:var(--c-card);padding:12px 16px}.stat-label{font-size:11px;color:var(--c-muted);margin-bottom:4px}.stat-value{font-size:22px;font-weight:600;color:var(--c-text)}.stat-value.green{color:var(--c-ok)}.stat-value.amber{color:var(--c-warn)}.stat-value.red{color:var(--c-danger)}.stat-sub{font-size:11px;color:var(--c-muted);margin-top:2px}@media (max-width:600px){.stat-cell{padding:10px}.stat-value{font-size:18px}.stat-strip{grid-template-columns:repeat(4,minmax(0,1fr))}}.alert{display:flex;align-items:flex-start;gap:10px;padding:10px 20px;border-bottom:1px solid}.alert-danger{background:var(--c-danger-bg);border-color:var(--c-danger-bar)}.alert-warn{background:var(--c-warn-bg);border-color:var(--c-warn-bar)}.alert-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:4px}.alert-danger .alert-dot{background:var(--c-danger)}.alert-warn .alert-dot{background:var(--c-warn)}.alert-text{font-size:13px;line-height:1.4;flex:1 1;color:var(--c-text)}.alert-btn{padding:5px 12px;border-radius:20px;font-size:12px;font-weight:500;cursor:pointer;border:none;background:var(--c-danger);color:#fff;white-space:nowrap;flex-shrink:0}.filter-bar{background:var(--c-card);border-bottom:1px solid var(--c-border);padding:10px 20px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}@media (max-width:768px){.filter-bar{padding:10px 14px}}.filter-label{font-size:12px;color:var(--c-muted);white-space:nowrap}.pills{display:flex;gap:4px;flex-wrap:wrap}.pill{padding:5px 12px;border-radius:20px;font-size:12px;font-weight:500;cursor:pointer;border:1px solid var(--c-border);color:var(--c-muted);background:var(--c-card);white-space:nowrap;transition:all .15s;-webkit-tap-highlight-color:transparent}.pill.active-all{background:var(--c-blue-light);color:var(--c-blue-dark);border-color:#85B7EB}.pill.active-danger{background:var(--c-danger-bg);color:var(--c-danger);border-color:var(--c-danger-bar)}.pill.active-warn{background:var(--c-warn-bg);color:var(--c-warn);border-color:var(--c-warn-bar)}.pill.active-ok{background:var(--c-ok-bg);color:var(--c-ok);border-color:var(--c-ok-bar)}.search-input{flex:1 1;min-width:160px;padding:8px 12px;border-radius:8px;border:1px solid var(--c-border);background:var(--c-bg);font-size:13px;color:var(--c-text);outline:none}.search-input:focus{border-color:var(--c-blue)}.thr-input{width:60px;padding:8px;border-radius:8px;border:1px solid var(--c-border);background:var(--c-bg);font-size:13px;color:var(--c-text);text-align:center;outline:none}.thr-input:focus{border-color:var(--c-blue)}.product-table-wrap{overflow-x:auto;background:var(--c-card)}.product-table{width:100%;border-collapse:collapse;min-width:700px}.product-table th{font-size:11px;color:var(--c-muted);text-align:left;padding:10px 16px;font-weight:500;text-transform:uppercase;letter-spacing:.05em;background:var(--c-bg);white-space:nowrap}.product-table td,.product-table th{border-bottom:1px solid var(--c-border)}.product-table td{padding:0;vertical-align:middle;font-size:13px;color:var(--c-text)}.product-table tr:last-child td{border-bottom:none}.product-table tr:hover td{background:#fafaf8}.td-inner{padding:10px 16px;display:flex;align-items:center}.product-table tr.row-danger td{background:#fff8f8}.product-table tr.row-warn td{background:#fffbf5}.product-table tr.row-danger:hover td{background:#fff0f0}.card-list{padding:10px;display:flex;flex-direction:column;gap:8px}.product-card{background:var(--c-card);border-radius:12px;border:1px solid var(--c-border);overflow:hidden}.product-card.status-danger{border-color:var(--c-danger-bar)}.product-card.status-warn{border-color:var(--c-warn-bar)}.card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;padding:12px 14px 6px}.card-name{font-size:14px;font-weight:600;color:var(--c-text);line-height:1.3}.card-meta{display:flex;align-items:center;gap:10px;padding:4px 14px 10px;flex-wrap:wrap}.meta-sku{font-family:ui-monospace,SF Mono,monospace;font-size:11px;background:var(--c-bg);padding:2px 7px;border-radius:5px}.meta-cat,.meta-sku{color:var(--c-muted)}.meta-cat{font-size:12px}.meta-price{font-size:13px;font-weight:600;color:var(--c-text);margin-left:auto}.card-stock{display:flex;align-items:center;gap:12px;padding:10px 14px 12px;border-top:1px solid var(--c-border)}.bar-section{flex:1 1;display:flex;flex-direction:column;gap:5px}.bar-track{height:8px;border-radius:4px;background:var(--c-bg);overflow:hidden}.bar-fill{height:100%;border-radius:4px;transition:width .3s}.bar-labels{display:flex;justify-content:space-between;align-items:center}.bar-pct{font-size:12px;font-weight:600}.bar-max{font-size:11px;color:var(--c-muted)}.stock-input-box{display:flex;flex-direction:column;align-items:center;gap:3px}.stock-input-label{font-size:10px;color:var(--c-muted);text-transform:uppercase;letter-spacing:.04em}.stock-input{width:72px;padding:8px 6px;border-radius:8px;border:1.5px solid var(--c-border);background:var(--c-bg);font-size:18px;font-weight:600;color:var(--c-text);text-align:center;outline:none;appearance:none;transition:border-color .15s}.stock-input:focus{border-color:var(--c-blue)}.badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap}.badge-ok{background:var(--c-ok-bg);color:var(--c-ok)}.badge-warn{background:var(--c-warn-bg);color:var(--c-warn)}.badge-danger{background:var(--c-danger-bg);color:var(--c-danger)}.badge-blue{background:var(--c-blue-light);color:var(--c-blue-dark)}.badge-purple{background:var(--c-purple-bg);color:var(--c-purple)}.sku-tag{font-family:ui-monospace,monospace;font-size:11px;color:var(--c-muted);background:var(--c-bg);padding:2px 7px;border-radius:5px;white-space:nowrap}.drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:300;display:flex;align-items:flex-end;justify-content:center}@media (min-width:769px){.drawer-overlay{align-items:center}.drawer{border-radius:12px!important;max-width:640px!important;max-height:80vh!important}}.drawer{background:var(--c-card);border-radius:16px 16px 0 0;width:100%;max-width:100%;max-height:88dvh;display:flex;flex-direction:column;overflow:hidden}.drawer-handle{width:36px;height:4px;border-radius:2px;background:var(--c-border);margin:10px auto 6px;flex-shrink:0}.drawer-header{padding:4px 18px 14px;border-bottom:1px solid var(--c-border);flex-shrink:0}.drawer-title{font-size:16px;font-weight:600;color:var(--c-text)}.drawer-sub{font-size:12px;color:var(--c-muted);margin-top:3px}.drawer-body{overflow-y:auto;-webkit-overflow-scrolling:touch;flex:1 1}.drawer-footer{padding:12px 18px;border-top:1px solid var(--c-border);flex-shrink:0;display:flex;gap:8px}.variant-row{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:12px;padding:12px 18px;border-bottom:1px solid var(--c-border)}.variant-row:last-child{border-bottom:none}.variant-attrs{display:flex;gap:6px;flex-wrap:wrap;margin-top:4px}.attr-chip{font-size:11px;padding:2px 8px;border-radius:20px;background:var(--c-bg);border:1px solid var(--c-border);color:var(--c-muted)}.variant-price{font-size:12px;color:var(--c-muted);margin-top:2px}.variant-input{width:72px;padding:8px 6px;border-radius:8px;border:1.5px solid var(--c-border);background:var(--c-bg);font-size:16px;font-weight:600;color:var(--c-text);text-align:center;outline:none;appearance:none}.variant-input:focus{border-color:var(--c-blue)}.saving-dot{width:8px;height:8px;border-radius:50%;background:var(--c-ok-bar);animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.order-card{background:var(--c-card);border-radius:10px;border:1px solid var(--c-border);overflow:hidden;margin-bottom:8px}.order-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;cursor:pointer;gap:12px}.order-num{font-size:14px;font-weight:600;color:var(--c-text)}.order-meta{font-size:12px;color:var(--c-muted);margin-top:2px}.order-total{font-size:15px;font-weight:600;color:var(--c-text);white-space:nowrap}.order-detail{border-top:1px solid var(--c-border);padding:14px 16px;display:flex;flex-direction:column;gap:12px}.detail-section-title{font-size:11px;color:var(--c-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}.order-item-row{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--c-border);font-size:13px}.order-item-row:last-child{border-bottom:none}.status-btn-group{display:flex;gap:6px;flex-wrap:wrap}.status-btn{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:500;cursor:pointer;border:1px solid var(--c-border);background:var(--c-bg);color:var(--c-muted);transition:all .15s}.status-btn.active{background:var(--c-blue);color:#fff;border-color:var(--c-blue)}.status-btn:hover:not(.active){background:var(--c-border)}.customer-card{background:var(--c-card);border-radius:10px;border:1px solid var(--c-border);overflow:hidden;margin-bottom:8px}.avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:#fff;flex-shrink:0}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.info-cell{background:var(--c-bg);border-radius:8px;padding:10px 12px}.info-cell-label{font-size:11px;color:var(--c-muted);margin-bottom:2px}.info-cell-value{font-size:14px;font-weight:500;color:var(--c-text)}.action-row{display:flex;gap:8px}.action-btn{flex:1 1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px;border-radius:8px;border:1px solid var(--c-border);background:var(--c-bg);font-size:13px;font-weight:500;text-decoration:none;color:var(--c-blue);cursor:pointer}.action-btn.green{color:var(--c-ok)}.settings-page{padding:20px;display:flex;flex-direction:column;gap:14px;max-width:640px}@media (max-width:768px){.settings-page{padding:14px}}.settings-card{background:var(--c-card);border-radius:12px;border:1px solid var(--c-border);padding:18px}.settings-card-title{font-size:14px;font-weight:600;color:var(--c-text);margin-bottom:14px}.form-group{display:flex;flex-direction:column;gap:5px;margin-bottom:12px}.form-group:last-child{margin-bottom:0}.form-label{font-size:12px;color:var(--c-muted);font-weight:500}.form-input{padding:10px 12px;border-radius:8px;border:1px solid var(--c-border);background:var(--c-bg);font-size:14px;color:var(--c-text);outline:none;appearance:none;transition:border-color .15s}.form-input:focus{border-color:var(--c-blue)}.form-input::placeholder{color:var(--c-muted)}textarea.form-input{resize:vertical;min-height:80px}.form-hint{font-size:11px;color:var(--c-muted);line-height:1.4}.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;border:1px solid var(--c-border);background:var(--c-card);color:var(--c-text);transition:all .15s;white-space:nowrap;-webkit-tap-highlight-color:transparent}.btn:hover{background:var(--c-bg)}.btn:active{transform:scale(.98)}.btn-primary{background:var(--c-blue);color:#fff;border-color:var(--c-blue);width:100%;justify-content:center;padding:12px}.btn-primary:hover{background:var(--c-blue-dark)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-sm{padding:5px 12px;font-size:12px;border-radius:6px}.btn-danger{background:var(--c-danger-bg);color:var(--c-danger);border-color:var(--c-danger-bar);width:100%;padding:12px}.btn-danger,.btn-icon{justify-content:center}.btn-icon{display:inline-flex;align-items:center;width:32px;height:32px;border-radius:6px;border:1px solid var(--c-border);background:var(--c-card);cursor:pointer;color:var(--c-muted);-webkit-tap-highlight-color:transparent}.btn-icon:hover{background:var(--c-bg);color:var(--c-text)}.status-indicator{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:8px;font-size:13px;font-weight:500}.status-ok{background:var(--c-ok-bg);color:var(--c-ok)}.status-error{background:var(--c-danger-bg);color:var(--c-danger)}.status-dot{width:8px;height:8px;border-radius:50%;background:currentColor}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:56px 24px;text-align:center;gap:10px}.empty-state svg{opacity:.25}.empty-title{font-size:15px;font-weight:600;color:var(--c-text)}.empty-sub{font-size:13px;color:var(--c-muted);line-height:1.5}.loading-spinner{display:flex;align-items:center;justify-content:center;padding:56px}.spinner{width:32px;height:32px;border:3px solid var(--c-border);border-top-color:var(--c-blue);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.toast{position:fixed;bottom:calc(var(--nav-h) + var(--safe-bottom) + 12px);left:50%;transform:translateX(-50%);background:#1a1a1a;color:#fff;padding:10px 20px;border-radius:20px;font-size:13px;font-weight:500;z-index:400;white-space:nowrap;animation:fadeUp .2s ease}@media (min-width:769px){.toast{bottom:20px}}@keyframes fadeUp{0%{opacity:0;transform:translateX(-50%) translateY(8px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.mini-stock-input{width:72px;padding:6px 8px;border-radius:6px;border:1.5px solid var(--c-border);background:var(--c-bg);font-size:14px;font-weight:600;color:var(--c-text);text-align:center;outline:none;transition:border-color .15s}.mini-stock-input:focus{border-color:var(--c-blue)}.shipping-card{background:var(--c-card);border-radius:10px;border:1px solid var(--c-border);padding:14px 16px;margin-bottom:8px}.shipping-step{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid var(--c-border)}.shipping-step:last-child{border-bottom:none}.step-dot-wrap{display:flex;flex-direction:column;align-items:center;gap:0}.step-dot{width:12px;height:12px;border-radius:50%;background:var(--c-blue);flex-shrink:0;margin-top:3px}.step-dot.done{background:var(--c-ok)}.step-dot.pending,.step-line{background:var(--c-border)}.step-line{width:2px;flex:1 1;margin:2px 0}.product-table tbody tr{transition:background .1s}.product-table tbody tr:hover td{background:#f0f4fa!important}.product-table tbody tr td:first-child .td-inner div:first-child:hover{text-decoration:underline}@media (min-width:900px){.kbd-hint{display:inline-flex!important;align-items:center;gap:4px}}.unsaved-dot{width:7px;height:7px;border-radius:50%;background:var(--c-warn);display:inline-block;margin-left:6px;animation:pulse 1.5s ease infinite}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@media (max-width:768px){.product-table-wrap{display:none!important}.product-mobile-list{display:flex!important;flex-direction:column;gap:8px;padding:8px}.filter-bar{flex-direction:column!important;align-items:stretch!important}.filter-bar .pills{flex-wrap:wrap}.filter-bar select{width:100%!important}.stat-strip{grid-template-columns:repeat(2,1fr)!important}.topbar-right .btn{padding:6px 10px!important;font-size:12px!important}}.product-mobile-list{display:none}.product-mobile-card{background:var(--c-card);border:1px solid var(--c-border);border-radius:12px;padding:12px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent}.product-mobile-card:active{opacity:.85;transform:scale(.99)}.product-mobile-card.danger{border-left:3px solid var(--c-danger)}.product-mobile-card.warning{border-left:3px solid var(--c-warn-bar)}.pmcard-img{width:56px;height:56px;border-radius:8px;overflow:hidden;border:1px solid var(--c-border);background:var(--c-bg);flex-shrink:0}.pmcard-img img{width:100%;height:100%;object-fit:cover;display:block}.pmcard-img .placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.pmcard-info{flex:1 1;min-width:0}.pmcard-name{font-size:13px;font-weight:600;color:var(--c-blue);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pmcard-cat{font-size:11px;color:var(--c-muted);margin-top:2px}.pmcard-meta{display:flex;gap:8px;align-items:center;margin-top:5px;flex-wrap:wrap}.pmcard-price{font-size:13px;font-weight:600;color:var(--c-text)}.pmcard-stock-ok{font-size:12px;font-weight:700;color:var(--c-ok)}.pmcard-stock-warn{font-size:12px;font-weight:700;color:var(--c-warn)}.pmcard-stock-danger{font-size:12px;font-weight:700;color:var(--c-danger)}.pmcard-actions{display:flex;flex-direction:column;gap:6px;flex-shrink:0}