:root{--bg:#fafaf7;--bg-elev:#fff;--bg-sunken:#f4f3ee;--bg-hover:#f0efe9;--border:#e6e4dc;--border-strong:#d4d1c6;--ink:#1a1a17;--ink-2:#45433c;--ink-3:#76736a;--ink-4:#a4a096;--accent:oklch(62% .13 150);--accent-soft:oklch(95% .04 150);--accent-ink:oklch(38% .1 150);--amber:oklch(72% .14 75);--amber-soft:oklch(95% .05 80);--amber-ink:oklch(45% .12 65);--red:oklch(58% .17 22);--red-soft:oklch(95% .03 22);--red-ink:oklch(40% .15 22);--blue:oklch(58% .13 245);--blue-soft:oklch(96% .03 245);--blue-ink:oklch(38% .12 245);--radius:10px;--radius-sm:6px;--radius-lg:14px;--font-sans:"Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;--font-mono:"JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;--row-h:44px;--pad:20px}[data-theme=slate]{--bg:#f6f7f9;--bg-elev:#fff;--bg-sunken:#eef0f3;--bg-hover:#e8ebf0;--border:#e2e5ea;--border-strong:#cdd2da;--ink:#0f1420;--ink-2:#3a4155;--ink-3:#6b7385;--ink-4:#9aa1b2;--accent:oklch(58% .16 255);--accent-soft:oklch(96% .03 255);--accent-ink:oklch(38% .14 255)}[data-theme=terracotta]{--bg:#fbf7f3;--bg-elev:#fff;--bg-sunken:#f4eee6;--bg-hover:#efe8dd;--border:#e8dfd2;--border-strong:#d4c6b2;--ink:#241c14;--ink-2:#4b3e2e;--ink-3:#857562;--ink-4:#b3a591;--accent:oklch(60% .15 40);--accent-soft:oklch(95% .04 40);--accent-ink:oklch(40% .14 40)}[data-density=compact]{--row-h:36px;--pad:14px}*{box-sizing:border-box}html,body{background:var(--bg);color:var(--ink);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;font-feature-settings:"cv02", "cv03", "cv04", "cv11";margin:0;padding:0;font-size:14px;line-height:1.45}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit;font-size:inherit}.mono{font-family:var(--font-mono);font-feature-settings:"ss01"}.tabular{font-variant-numeric:tabular-nums}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-strong);border:2px solid var(--bg);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--ink-4)}.app-shell{grid-template-columns:248px 1fr;min-height:100vh;transition:grid-template-columns .3s cubic-bezier(.4,0,.2,1);display:grid}[data-layout=compact-nav] .app-shell{grid-template-columns:64px 1fr}.sidebar-brand,.sidebar-scroll,.nav-item,.sidebar-user,.nav-collapse-btn{transition:all .3s cubic-bezier(.4,0,.2,1)}[data-layout=compact-nav] .sidebar-brand{justify-content:center;padding:18px 0 14px}[data-layout=compact-nav] .sidebar-brand .brand-text{display:none}[data-layout=compact-nav] .sidebar-scroll{padding:10px 6px 12px}[data-layout=compact-nav] .nav-item{justify-content:center;padding:9px 6px}[data-layout=compact-nav] .nav-item .nav-text,[data-layout=compact-nav] .nav-item .nav-badge{display:none}[data-layout=compact-nav] .sidebar-user{flex-direction:column;gap:6px;padding:10px 6px}[data-layout=compact-nav] .sidebar-user .user-info,[data-layout=compact-nav] .nav-collapse-btn .label{display:none}[data-layout=compact-nav] .nav-item:hover:after{content:attr(data-label);background:var(--ink);color:var(--bg);white-space:nowrap;z-index:100;pointer-events:none;border-radius:6px;padding:5px 9px;font-size:12px;position:absolute;top:50%;left:calc(100% + 8px);transform:translateY(-50%);box-shadow:0 4px 12px #00000026}.nav-collapse-btn{border-radius:var(--radius-sm);border:1px solid var(--border);color:var(--ink-3);cursor:pointer;background:0 0;justify-content:flex-start;align-items:center;gap:8px;width:calc(100% - 8px);margin:6px 4px 0;padding:8px 10px;font-size:12px;display:flex}.nav-collapse-btn:hover{background:var(--bg-hover);color:var(--ink)}[data-layout=compact-nav] .nav-collapse-btn{justify-content:center;padding:8px}.sidebar{background:var(--bg-elev);border-right:1px solid var(--border);flex-direction:column;height:100vh;display:flex;position:sticky;top:0;overflow:hidden}.sidebar-brand{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:18px 18px 14px;display:flex}.brand-mark{background:var(--ink);width:30px;height:30px;color:var(--bg);letter-spacing:-.02em;border-radius:8px;flex-shrink:0;place-items:center;font-size:13px;font-weight:700;display:grid}img.brand-mark{object-fit:contain;background:0 0}.brand-name{letter-spacing:-.01em;font-size:15px;font-weight:600}.brand-sub{color:var(--ink-3);margin-top:-2px;font-size:11px}.sidebar-scroll{flex:1;padding:10px 10px 12px;overflow-y:auto}.nav-group{margin-top:14px}.nav-group:first-child{margin-top:4px}.nav-label{text-transform:uppercase;letter-spacing:.08em;color:var(--ink-4);padding:6px 10px;font-size:10px;font-weight:600}.nav-item{border-radius:var(--radius-sm);color:var(--ink-2);cursor:pointer;-webkit-user-select:none;user-select:none;text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:7px 10px;font-size:13.5px;font-weight:500;text-decoration:none;display:flex;position:relative}.nav-item:hover{background:var(--bg-hover);color:var(--ink)}.nav-item.active{background:var(--ink);color:var(--bg)}.nav-icon{flex-shrink:0;place-items:center;width:18px;height:18px;display:grid}.nav-icon svg{width:16px;height:16px;stroke:var(--ink-3);fill:none;stroke-width:1.6px;stroke-linecap:round;stroke-linejoin:round}.nav-item.active .nav-icon svg{stroke:var(--bg)}.nav-item:hover .nav-icon svg{stroke:var(--ink)}.nav-badge{background:var(--bg-sunken);color:var(--ink-3);font-variant-numeric:tabular-nums;border-radius:10px;margin-left:auto;padding:1px 6px;font-size:10.5px;font-weight:600}.nav-item.active .nav-badge{color:var(--bg);background:#ffffff26}.sidebar-user{border-top:1px solid var(--border);align-items:center;gap:10px;padding:12px;display:flex}.user-avatar{background:var(--accent-soft);width:32px;height:32px;color:var(--accent-ink);border-radius:50%;place-items:center;font-size:12px;font-weight:600;display:grid}.user-info{flex:1;min-width:0}.user-name{font-size:13px;font-weight:600}.user-role{color:var(--ink-3);align-items:center;gap:6px;font-size:11px;display:flex}.main{background:var(--bg);flex-direction:column;min-width:0;height:100vh;display:flex;overflow:hidden}.topbar{border-bottom:1px solid var(--border);background:var(--bg-elev);z-index:10;flex-shrink:0;justify-content:space-between;align-items:center;gap:16px;height:56px;padding:0 24px;display:flex;position:sticky;top:0}.crumbs{color:var(--ink-3);align-items:center;gap:8px;font-size:13px;display:flex}.crumbs .sep{color:var(--ink-4)}.crumbs .current{color:var(--ink);font-weight:500}.top-actions{align-items:center;gap:12px;display:flex}.icon-btn{border:1px solid var(--border);background:var(--bg-elev);width:32px;height:32px;color:var(--ink-3);border-radius:50%;place-items:center;transition:all .15s;display:grid;position:relative}.icon-btn:hover{background:var(--bg-sunken);color:var(--ink);border-color:var(--border-strong)}.dot{background:var(--red);border:1.5px solid var(--bg-elev);border-radius:50%;width:6px;height:6px;position:absolute;top:6px;right:6px}.page-container{flex:1;padding:24px 28px 48px;overflow-y:auto}.page{flex-direction:column;gap:20px;max-width:1440px;margin:0 auto;display:flex}[data-layout=compact-nav] .page,[data-tables=compact] .page{max-width:none}.page-header{justify-content:space-between;align-items:flex-end;gap:20px;display:flex}.page-title-group{flex-direction:column;gap:4px;display:flex}.page-title{letter-spacing:-.015em;margin:0;font-size:22px;font-weight:600}.page-sub{color:var(--ink-3);font-size:13.5px}.btn{border-radius:var(--radius-sm);border:1px solid var(--border-strong);background:var(--bg-elev);height:34px;color:var(--ink);cursor:pointer;align-items:center;gap:6px;padding:0 12px;font-size:13px;font-weight:500;text-decoration:none;transition:all .12s;display:inline-flex}.btn:hover{background:var(--bg-hover)}.btn.primary{background:var(--ink);border-color:var(--ink);color:var(--bg)}.btn.primary:hover{background:#000}.btn.accent{background:var(--accent);border-color:var(--accent);color:#fff}.btn.accent:hover{filter:brightness(.95)}.btn.ghost{background:0 0;border-color:#0000}.btn.ghost:hover{background:var(--bg-sunken)}.btn svg{stroke:currentColor;fill:none;stroke-width:1.8px;width:14px;height:14px}.btn.sm{border-radius:5px;height:28px;padding:0 9px;font-size:12px}.card{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;display:flex;overflow:hidden}.card-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:14px 18px;display:flex}.card-title{margin:0;font-size:14px;font-weight:600}.card-sub{color:var(--ink-3);margin-top:2px;font-size:12px}.card-body{padding:var(--pad);flex:1}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;display:grid}.kpi{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:4px;padding:16px 18px;display:flex;position:relative;overflow:hidden}.kpi-label{color:var(--ink-3);font-size:12px;font-weight:500}.kpi-value{letter-spacing:-.02em;font-variant-numeric:tabular-nums;font-size:26px;font-weight:600}.kpi-delta{color:var(--ink-3);align-items:center;gap:5px;font-size:12px;display:flex}.kpi-delta.up{color:var(--accent-ink)}.kpi-delta.down{color:var(--red-ink)}.kpi-spark{opacity:.8;width:60px;height:30px;position:absolute;top:14px;right:12px}.table{border-collapse:collapse;width:100%;font-size:13px}.table thead th{text-align:left;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-3);border-bottom:1px solid var(--border);background:var(--bg-sunken);z-index:10;padding:10px 14px;font-size:11.5px;font-weight:500;position:sticky;top:0}.table thead th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .1s}.table thead th.sortable:hover{background:var(--bg-hover)}.table thead th.sticky{z-index:20;background:var(--bg-sunken);position:sticky;left:0}.table-scroll{position:relative;overflow:auto}.card>.table-scroll{border-radius:0 0 var(--radius) var(--radius)}.table tbody td{height:var(--row-h);border-bottom:1px solid var(--border);vertical-align:middle;padding:0 14px}.table tbody tr:hover{background:var(--bg-hover)}.table .num{font-variant-numeric:tabular-nums;text-align:right}.filter-bar{border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:12px;padding:12px 18px;display:flex}.search{flex-shrink:0;align-items:center;display:flex;position:relative}.search svg{width:14px;height:14px;stroke:var(--ink-4);pointer-events:none;stroke-width:2px;position:absolute;left:10px}.search input{border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--bg-elev);outline:none;width:200px;height:32px;padding:0 10px 0 32px;font-size:13px;transition:all .15s}.search input:focus{border-color:var(--accent);background:var(--bg-elev)}.pill{border:1px solid var(--border-strong);background:var(--bg-elev);height:32px;color:var(--ink-2);cursor:pointer;border-radius:999px;align-items:center;gap:6px;padding:0 12px;font-size:12.5px;font-weight:500;transition:all .15s;display:flex}.pill:hover{background:var(--bg-sunken)}.pill.active{background:var(--ink);color:var(--bg);border-color:var(--ink)}.filter-sidebar{background:var(--bg-elev);flex-direction:column;flex-shrink:0;width:260px;max-height:100%;display:flex}.filter-sidebar .card-body{overflow-y:auto}.filter-sidebar::-webkit-scrollbar{width:4px}.filter-sidebar::-webkit-scrollbar-thumb{background:var(--border)}.chip{background:var(--bg-sunken);color:var(--ink-2);border:1px solid var(--border);border-radius:999px;align-items:center;gap:5px;padding:2px 8px;font-size:11.5px;font-weight:500;display:inline-flex}.chip.green{background:var(--accent-soft);color:var(--accent-ink);border-color:#0000}.chip.amber{background:var(--amber-soft);color:var(--amber-ink);border-color:#0000}.chip.red{background:var(--red-soft);color:var(--red-ink);border-color:#0000}.chip.blue{background:var(--blue-soft);color:var(--blue-ink);border-color:#0000}.chip.success{background:var(--accent-soft);color:var(--accent-ink);border-color:#0000}.chip.warning{background:var(--amber-soft);color:var(--amber-ink);border-color:#0000}.chip.danger{background:var(--red-soft);color:var(--red-ink);border-color:#0000}.chip.info{background:var(--blue-soft);color:var(--blue-ink);border-color:#0000}.chip .bullet{background:currentColor;border-radius:50%;width:6px;height:6px}.auth-layout{background:var(--bg-sunken);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.auth-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:400px;padding:40px;box-shadow:0 8px 30px #0000000a}.auth-logo{flex-direction:column;align-items:center;gap:12px;margin-bottom:32px;display:flex}.auth-title{letter-spacing:-.02em;text-align:center;margin:0;font-size:24px;font-weight:700}.auth-sub{color:var(--ink-3);text-align:center;margin-top:8px;font-size:14px}.form-group{margin-bottom:20px}.form-label{color:var(--ink-2);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.input{border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--bg-elev);outline:none;width:100%;height:40px;padding:0 12px;transition:border-color .15s}.input:focus{border-color:var(--accent)}.input.sm{height:32px;padding:0 10px;font-size:13px}.error-banner{background:var(--red-soft);color:var(--red-ink);border-radius:var(--radius-sm);border:1px solid var(--red-soft);text-align:center;margin-bottom:20px;padding:12px;font-size:13px}.grid-2{grid-template-columns:1fr 1fr;gap:16px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}@media (width<=1024px){.app-shell{grid-template-columns:1fr}.sidebar{display:none}}.bg-group-a{background:var(--bg)}.bg-group-b{background:#f7f7f2}tr.bg-group-a:hover,tr.bg-group-b:hover{background:var(--bg-sunken)}.action-bar-floating{bottom:24px;left:calc(var(--sidebar-width) + 24px);z-index:100;animation:.4s cubic-bezier(.16,1,.3,1) slide-up;position:fixed;right:24px}.action-bar-content{-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-strong);background:#fffc;border-radius:100px;align-items:center;gap:24px;padding:8px 12px 8px 24px;display:flex;box-shadow:0 12px 24px -8px #00000014,0 4px 6px -2px #00000005}.stat-group{align-items:center;gap:20px;display:flex}.stat-item{flex-direction:column;display:flex}.stat-label{text-transform:uppercase;letter-spacing:.1em;color:var(--ink-4);font-size:10px;font-weight:700}.stat-value{font-family:var(--font-mono);color:var(--ink);font-size:14px;font-weight:600}.stat-divider{background:var(--border);width:1px;height:24px}@keyframes slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0006;place-items:center;animation:.2s ease-out fade-in;display:grid;position:fixed;inset:0}.modal-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-lg);width:90%;max-width:500px;animation:.3s cubic-bezier(.16,1,.3,1) scale-up;box-shadow:0 20px 40px -12px #00000026}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 20px;display:flex}.modal-title{align-items:center;gap:10px;font-size:15px;font-weight:600;display:flex}.modal-close{width:32px;height:32px;color:var(--ink-4);background:0 0;border:none;border-radius:50%;place-items:center;transition:all .15s;display:grid}.modal-close:hover{background:var(--bg-sunken);color:var(--ink)}.modal-body{flex-direction:column;padding:24px 20px;display:flex}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:12px;padding:16px 20px;display:flex}.user-menu-popover{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);z-index:50;padding:6px;animation:.2s cubic-bezier(.16,1,.3,1) slide-up;position:absolute;bottom:60px;left:12px;right:12px;box-shadow:0 10px 25px -5px #0000001a}[data-layout=compact-nav] .user-menu-popover{width:220px;position:fixed;bottom:16px;left:70px;right:auto}.popover-item{border-radius:var(--radius-sm);color:var(--ink-2);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:8px 10px;font-size:13px;font-weight:500;transition:all .1s;display:flex}.popover-item:hover{background:var(--bg-sunken);color:var(--ink)}.popover-item.danger{color:var(--red-ink)}.popover-item.danger:hover{background:var(--red-soft)}.settings-trigger{width:32px;height:32px;color:var(--ink-4);background:0 0;border:1px solid #0000;border-radius:8px;place-items:center;transition:all .2s;display:grid}.settings-trigger:hover,.settings-trigger.active{background:var(--bg-sunken);color:var(--ink);border-color:var(--border)}.accent-text{color:var(--accent)}.green-text{color:var(--accent-ink)}.alert-mini{border-radius:var(--radius-sm);align-items:center;gap:8px;padding:10px 12px;font-size:12px;display:flex}.alert-mini.danger{background:var(--red-soft);color:var(--red-ink)}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes scale-up{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.session-selector{background:var(--bg-elev);border:1px solid var(--border-strong);border-radius:var(--radius-sm);align-items:center;gap:10px;height:36px;padding:0 14px;transition:all .2s cubic-bezier(.16,1,.3,1);display:flex;position:relative;box-shadow:0 1px 2px #00000008}.session-selector:hover{border-color:var(--accent);background:var(--bg-hover);box-shadow:0 2px 8px #0000000d}.session-selector select{color:var(--ink);cursor:pointer;appearance:none;background:0 0;border:none;outline:none;flex:1;padding-right:24px;font-size:13.5px;font-weight:600}.session-selector:after{content:"";border-right:1.5px solid var(--ink-4);border-bottom:1.5px solid var(--ink-4);pointer-events:none;width:8px;height:8px;margin-top:-4px;position:absolute;right:14px;transform:rotate(45deg)}.session-selector:hover:after{border-color:var(--accent)}.session-selector .dot-status{background:var(--accent);width:8px;height:8px;box-shadow:0 0 0 3px var(--accent-soft);border-radius:50%;flex-shrink:0}.session-selector.empty .dot-status{background:var(--ink-4);box-shadow:none}@keyframes spin{to{transform:rotate(360deg)}}.loading-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:100;border-radius:var(--radius);background:#fff9;flex-direction:column;justify-content:center;align-items:center;gap:12px;display:flex;position:absolute;inset:0}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:24px;height:24px;animation:.8s linear infinite spin;display:inline-block}.spin{animation:1s linear infinite spin}.stock-bar{align-items:center;gap:6px;display:flex}.stock-bar .bar{background:var(--bg-sunken);border-radius:3px;flex:1;max-width:60px;height:5px;overflow:hidden}.table.picking-orders-table{min-width:1400px}[data-tables=compact] .table.picking-orders-table{min-width:0}[data-tables=compact] .table{font-size:12.5px}[data-tables=compact] .table thead th,[data-tables=compact] .table tbody td{padding:0 8px}[data-tables=compact] .table thead th{font-size:10.5px}[data-tables=compact] .table.stock-table .col-sku{width:110px}[data-tables=compact] .table.stock-table .col-ubic{width:140px}[data-tables=compact] .table.stock-table .col-num{width:70px}[data-tables=compact] .table.stock-table .col-disp{width:100px}[data-tables=compact] .table.stock-table .col-mov{width:80px}[data-tables=compact] .table.stock-table .col-estado{width:90px}.stock-bar .fill{background:var(--accent-ink);border-radius:3px;height:100%}.stock-bar .fill.low{background:var(--amber-ink)}.stock-bar .fill.critical{background:var(--red-ink)}.backdrop{z-index:40;background:#14131066;animation:.18s fade-in;position:fixed;inset:0}.drawer{background:var(--bg);z-index:41;flex-direction:column;width:680px;max-width:100vw;animation:.25s cubic-bezier(.2,.8,.2,1) slide-right;display:flex;position:fixed;top:0;bottom:0;right:0;box-shadow:-20px 0 60px #0000001f}.drawer.drawer-wide{width:min(1100px,96vw)}@keyframes slide-right{0%{transform:translate(100%)}to{transform:translate(0)}}@media print{.sidebar,.topbar,.no-print,.action-bar-floating{display:none!important}.app-shell,.main,.page-container,.page{margin:0;padding:0;display:block}.print-area .card{box-shadow:none;border:none;padding:0}.print-area .table-scroll{max-height:none!important;overflow:visible!important}.print-area .table{font-size:11px;min-width:0!important}body{background:#fff}}
