:root{--brand-teal: #0d3838;--brand-teal-700: #0f4040;--brand-teal-600: #156060;--brand-lime: #a3e635;--brand-lime-strong: #84cc16;--brand-lime-fg: #1a2e05;--bg: #f7f7f5;--bg-elev: #ffffff;--bg-sunk: #f0efeb;--panel: #ffffff;--hover: #f3f3f1;--rowhover: #fafaf8;--border: #e7e6e1;--border-strong: #d8d6cf;--divider: #ececea;--fg: #18211f;--fg-muted: #5a625e;--fg-faint: #8a918c;--ok: #17794a;--ok-bg: #e6f4ec;--warn: #b25e09;--warn-bg: #fdf2dc;--err: #b42318;--err-bg: #fde8e6;--info: #0b5fa5;--info-bg: #e6effa;--neu: #545d59;--neu-bg: #ececea;--accent: var(--brand-lime);--accent-strong: var(--brand-lime-strong);--accent-fg: var(--brand-lime-fg);--shadow-sm: 0 1px 0 rgba(15,30,30,.04), 0 1px 2px rgba(15,30,30,.04);--shadow-md: 0 4px 12px -2px rgba(15,30,30,.08), 0 2px 4px -1px rgba(15,30,30,.04);--shadow-lg: 0 12px 32px -8px rgba(15,30,30,.18), 0 4px 8px -2px rgba(15,30,30,.06);--row-h: 36px;--pad-y: 8px;--pad-x: 12px;--r-xs: 4px;--r-sm: 6px;--r: 8px;--r-lg: 10px;--r-xl: 14px;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;--sb-w: 232px;--topbar-h: 48px}[data-theme=dark]{--bg: #0a1414;--bg-elev: #0f1c1c;--bg-sunk: #07100f;--panel: #102020;--hover: #163030;--rowhover: #122525;--border: #1f3535;--border-strong: #2a4444;--divider: #1a2e2e;--fg: #e7efee;--fg-muted: #94a3a0;--fg-faint: #6a7975;--ok: #4ade80;--ok-bg: rgba(74,222,128,.1);--warn: #f0b659;--warn-bg: rgba(240,182,89,.1);--err: #f87171;--err-bg: rgba(248,113,113,.1);--info: #60a5fa;--info-bg: rgba(96,165,250,.1);--neu: #94a3a0;--neu-bg: rgba(148,163,160,.1);--shadow-sm: 0 1px 0 rgba(0,0,0,.4), 0 1px 2px rgba(0,0,0,.3);--shadow-md: 0 4px 12px -2px rgba(0,0,0,.5), 0 2px 4px -1px rgba(0,0,0,.3);--shadow-lg: 0 12px 32px -8px rgba(0,0,0,.6), 0 4px 8px -2px rgba(0,0,0,.4)}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;height:100%}body{font-family:var(--font-sans);font-size:13px;line-height:1.5;color:var(--fg);background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-feature-settings:"cv11","ss01"}button{font:inherit;color:inherit;cursor:pointer}input,select,textarea{font:inherit;color:inherit}a{color:inherit;text-decoration:none}::selection{background:var(--accent);color:var(--accent-fg)}#root{height:100%}.app{display:grid;grid-template-columns:var(--sb-w) 1fr;grid-template-rows:var(--topbar-h) 1fr;grid-template-areas:"sidebar topbar" "sidebar main";height:100vh;background:var(--bg)}.sidebar{grid-area:sidebar;background:var(--brand-teal);color:#d8e6e6;display:flex;flex-direction:column;min-height:0;border-right:1px solid rgba(0,0,0,.2)}[data-theme=dark] .sidebar{background:#061212}.sb-brand{display:flex;align-items:center;gap:10px;padding:14px;height:var(--topbar-h);border-bottom:1px solid rgba(255,255,255,.06)}.sb-logo{width:28px;height:28px;background:var(--brand-lime);color:#082020;border-radius:6px;display:grid;place-items:center;font-weight:800;font-size:14px;flex-shrink:0;box-shadow:0 0 0 1px #0003 inset}.sb-brand-text{display:flex;flex-direction:column;line-height:1.1;min-width:0}.sb-brand-text b{color:#fff;font-size:13px;font-weight:700;letter-spacing:-.01em}.sb-brand-text small{color:#88a3a3;font-size:10px;text-transform:uppercase;letter-spacing:.06em}.sb-nav{flex:1;padding:10px 8px;overflow-y:auto;min-height:0}.sb-section{margin-top:14px}.sb-section:first-child{margin-top:0}.sb-label{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:#6e8585;padding:6px 10px;font-weight:600}.sb-item{display:flex;align-items:center;gap:10px;padding:6px 10px;border-radius:6px;color:#c4d4d4;font-size:13px;font-weight:500;cursor:pointer;-webkit-user-select:none;user-select:none;border:none;background:transparent;width:100%;text-align:left;transition:background .12s,color .12s}.sb-item:hover{background:#ffffff0d;color:#fff}.sb-item.active{background:#a3e6351f;color:#fff}.sb-item.active .sb-icon{color:var(--brand-lime)}.sb-icon{width:16px;height:16px;flex-shrink:0;color:#88a3a3}.sb-item:hover .sb-icon{color:#c4d4d4}.sb-count{margin-left:auto;font-size:11px;background:#ffffff12;color:#a8bdbd;padding:1px 6px;border-radius:10px;font-variant-numeric:tabular-nums}.sb-item.active .sb-count{background:#a3e6352e;color:var(--brand-lime)}.sb-kbd{margin-left:auto;font-family:var(--font-mono);font-size:10px;color:#6a7e7e;padding:1px 5px;border:1px solid rgba(255,255,255,.08);border-radius:3px}.sb-foot{border-top:1px solid rgba(255,255,255,.06);padding:10px;display:flex;align-items:center;gap:8px}.sb-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#4a7878,#2a5050);color:#fff;font-weight:600;font-size:11px;display:grid;place-items:center;flex-shrink:0}.sb-user{display:flex;flex-direction:column;line-height:1.2;min-width:0;flex:1}.sb-user b{color:#fff;font-size:12px;font-weight:600}.sb-user small{color:#7c9090;font-size:11px}.topbar{grid-area:topbar;background:var(--bg-elev);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;padding:0 18px;height:var(--topbar-h)}.crumbs{display:flex;align-items:center;gap:6px;color:var(--fg-muted);font-size:13px;font-weight:500}.crumb-sep{color:var(--fg-faint)}.crumb-curr{color:var(--fg)}.tb-spacer{flex:1}.tb-search{display:flex;align-items:center;gap:8px;background:var(--bg-sunk);border:1px solid var(--border);padding:5px 10px;border-radius:6px;width:280px;color:var(--fg-muted);font-size:12px;cursor:pointer;transition:border-color .12s}.tb-search:hover{border-color:var(--border-strong)}.tb-search .grow{flex:1}.tb-search .kbd-row{display:flex;gap:2px}.kbd{font-family:var(--font-mono);font-size:10px;padding:1px 5px;border:1px solid var(--border);border-radius:3px;background:var(--bg-elev);color:var(--fg-muted);line-height:1.4}.tb-icon-btn{width:30px;height:30px;border-radius:6px;border:none;background:transparent;display:grid;place-items:center;color:var(--fg-muted);transition:background .12s,color .12s;position:relative}.tb-icon-btn:hover{background:var(--hover);color:var(--fg)}.tb-icon-btn .dot{position:absolute;top:6px;right:6px;width:7px;height:7px;border-radius:50%;background:var(--err);border:1.5px solid var(--bg-elev)}.main{grid-area:main;overflow:auto;padding:24px 28px 64px}.main-narrow{max-width:1280px;margin:0 auto}.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:18px}.page-title{display:flex;flex-direction:column;gap:4px}.page-title h1{margin:0;font-size:20px;font-weight:600;letter-spacing:-.01em}.page-title p{margin:0;color:var(--fg-muted);font-size:13px}.page-actions{display:flex;gap:8px;align-items:center}.btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:6px;font-size:13px;font-weight:500;line-height:1;border:1px solid var(--border);background:var(--bg-elev);color:var(--fg);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .12s,border-color .12s,transform .05s;height:30px}.btn:hover{background:var(--hover);border-color:var(--border-strong)}.btn:active{transform:translateY(.5px)}.btn-primary{background:var(--brand-lime);color:var(--brand-lime-fg);border-color:var(--brand-lime-strong);font-weight:600;box-shadow:0 1px #0000000a,inset 0 1px #fff6}.btn-primary:hover{background:var(--brand-lime-strong);border-color:var(--brand-lime-strong)}.btn-ghost{background:transparent;border-color:transparent}.btn-ghost:hover{background:var(--hover);border-color:transparent}.btn-danger{background:var(--err-bg);color:var(--err);border-color:transparent}.btn-danger:hover{background:var(--err);color:#fff;border-color:var(--err)}.btn-sm{padding:4px 8px;height:26px;font-size:12px}.btn-icon{width:30px;padding:0;justify-content:center}.btn-icon.btn-sm{width:26px}.card{background:var(--panel);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm)}.card-pad{padding:18px}.card-head{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}.card-head h3{margin:0;font-size:13px;font-weight:600}.card-head .spacer{flex:1}.field{display:flex;flex-direction:column;gap:5px}.field label,.field-label{font-size:12px;font-weight:500;color:var(--fg);display:flex;align-items:center;gap:6px}.field-label .req{color:var(--err)}.field-hint{font-size:11px;color:var(--fg-muted);margin-top:-1px}.field-error{font-size:11px;color:var(--err);display:flex;align-items:center;gap:4px}.input,.select,.textarea{background:var(--bg-elev);color:var(--fg);border:1px solid var(--border);border-radius:6px;padding:6px 10px;font-size:13px;line-height:1.4;height:32px;outline:none;transition:border-color .12s,box-shadow .12s;width:100%;font-family:inherit}.input:hover,.select:hover,.textarea:hover{border-color:var(--border-strong)}.input:focus,.select:focus,.textarea:focus{border-color:var(--brand-lime-strong);box-shadow:0 0 0 3px #a3e6352e}.input.invalid,.select.invalid{border-color:var(--err);box-shadow:0 0 0 3px #b423181a}.input.mono{font-family:var(--font-mono);font-size:12px}.textarea{height:auto;min-height:72px;padding:8px 10px;resize:vertical}.input::placeholder,.textarea::placeholder{color:var(--fg-faint)}.input-with-icon{position:relative}.input-with-icon svg{position:absolute;left:9px;top:50%;transform:translateY(-50%);color:var(--fg-faint);pointer-events:none}.input-with-icon .input{padding-left:30px}.table-wrap{background:var(--panel);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.table-toolbar{padding:10px 12px;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--border);background:var(--bg-elev)}.table-toolbar .grow{flex:1}table.tbl{width:100%;border-collapse:collapse;font-size:13px}.tbl thead th{text-align:left;font-weight:500;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--fg-muted);padding:8px 12px;border-bottom:1px solid var(--border);background:var(--bg-elev);white-space:nowrap}.tbl thead th.sortable{cursor:pointer}.tbl thead th.sortable:hover{color:var(--fg)}.tbl tbody td{padding:0 12px;height:var(--row-h);border-bottom:1px solid var(--divider);vertical-align:middle;white-space:nowrap}.tbl tbody tr:last-child td{border-bottom:none}.tbl tbody tr{transition:background .08s}.tbl tbody tr:hover{background:var(--rowhover)}.tbl tbody tr.selected{background:#a3e63514}.tbl .mono{font-family:var(--font-mono);font-size:12px;color:var(--fg)}.tbl .num{font-variant-numeric:tabular-nums;text-align:right}.tbl .muted{color:var(--fg-muted)}.tbl .row-link{color:var(--fg);font-weight:500;cursor:pointer}.tbl .row-link:hover{color:var(--brand-teal-600)}[data-theme=dark] .tbl .row-link:hover{color:var(--brand-lime)}.tbl .actions-col{width:1%;padding-right:8px}.badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:500;padding:2px 8px;border-radius:999px;line-height:1.4;white-space:nowrap;font-variant-numeric:tabular-nums}.badge .dot{width:6px;height:6px;border-radius:50%}[data-badge-style=soft] .badge.s-stock{background:var(--neu-bg);color:var(--neu)}[data-badge-style=soft] .badge.s-allocated{background:var(--info-bg);color:var(--info)}[data-badge-style=soft] .badge.s-shipped{background:#7a54c81a;color:#6a4ab8}[data-badge-style=soft] .badge.s-active{background:var(--ok-bg);color:var(--ok)}[data-badge-style=soft] .badge.s-retired{background:var(--neu-bg);color:var(--neu)}[data-badge-style=soft] .badge.s-lost{background:var(--err-bg);color:var(--err)}[data-badge-style=soft] .badge.s-draft{background:var(--neu-bg);color:var(--neu)}[data-badge-style=soft] .badge.s-confirmed{background:var(--info-bg);color:var(--info)}[data-badge-style=soft] .badge.s-delivered{background:var(--ok-bg);color:var(--ok)}[data-badge-style=soft] .badge.s-cancelled{background:var(--err-bg);color:var(--err)}[data-badge-style=soft] .badge.s-paired{background:#0f60601a;color:var(--brand-teal-600)}[data-badge-style=soft] .badge.s-dissolved{background:var(--neu-bg);color:var(--neu)}[data-theme=dark][data-badge-style=soft] .badge.s-shipped{background:#a78bfa1f;color:#c4b5fd}[data-theme=dark][data-badge-style=soft] .badge.s-paired{background:#4ade801a;color:#4ade80}[data-badge-style=filled] .badge{color:#fff;padding:2px 9px}[data-badge-style=filled] .badge.s-stock{background:var(--neu)}[data-badge-style=filled] .badge.s-allocated{background:var(--info)}[data-badge-style=filled] .badge.s-shipped{background:#6a4ab8}[data-badge-style=filled] .badge.s-active{background:var(--ok)}[data-badge-style=filled] .badge.s-retired{background:var(--neu);opacity:.7}[data-badge-style=filled] .badge.s-lost{background:var(--err)}[data-badge-style=filled] .badge.s-draft{background:var(--neu)}[data-badge-style=filled] .badge.s-confirmed{background:var(--info)}[data-badge-style=filled] .badge.s-delivered{background:var(--ok)}[data-badge-style=filled] .badge.s-cancelled{background:var(--err)}[data-badge-style=filled] .badge.s-paired{background:var(--brand-teal-600)}[data-badge-style=filled] .badge.s-dissolved{background:var(--neu);opacity:.7}[data-badge-style=outlined] .badge{background:transparent;border:1px solid currentColor;padding:1px 8px}[data-badge-style=outlined] .badge.s-stock{color:var(--neu)}[data-badge-style=outlined] .badge.s-allocated{color:var(--info)}[data-badge-style=outlined] .badge.s-shipped{color:#6a4ab8}[data-badge-style=outlined] .badge.s-active{color:var(--ok)}[data-badge-style=outlined] .badge.s-retired{color:var(--neu)}[data-badge-style=outlined] .badge.s-lost{color:var(--err)}[data-badge-style=outlined] .badge.s-draft{color:var(--neu)}[data-badge-style=outlined] .badge.s-confirmed{color:var(--info)}[data-badge-style=outlined] .badge.s-delivered{color:var(--ok)}[data-badge-style=outlined] .badge.s-cancelled{color:var(--err)}[data-badge-style=outlined] .badge.s-paired{color:var(--brand-teal-600)}[data-badge-style=outlined] .badge.s-dissolved{color:var(--neu)}.sync-row{display:inline-flex;gap:4px;align-items:center}.sync-pill{display:inline-flex;align-items:center;gap:5px;font-family:var(--font-mono);font-size:10px;font-weight:500;padding:2px 7px;border-radius:4px;border:1px solid var(--border);background:var(--bg-elev);cursor:pointer;transition:background .12s}.sync-pill:hover{background:var(--hover)}.sync-pill .dot{width:6px;height:6px;border-radius:50%;box-shadow:0 0 0 2px var(--bg-elev)}.sync-pill.synced .dot{background:var(--ok)}.sync-pill.pending .dot{background:var(--warn);animation:pulse 1.4s ease-in-out infinite}.sync-pill.failed{border-color:var(--err);background:var(--err-bg);color:var(--err)}.sync-pill.failed .dot{background:var(--err)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}.kpi{background:var(--panel);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px 18px;display:flex;flex-direction:column;gap:6px;box-shadow:var(--shadow-sm);position:relative;transition:border-color .12s,transform .12s;cursor:pointer}.kpi:hover{border-color:var(--border-strong)}.kpi-label{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--fg-muted);font-weight:500}.kpi-value{font-size:26px;font-weight:600;letter-spacing:-.02em;font-variant-numeric:tabular-nums;line-height:1.1}.kpi-foot{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--fg-muted)}.kpi-foot .delta-up{color:var(--ok);font-weight:600}.kpi-foot .delta-down{color:var(--err);font-weight:600}.kpi.alert{border-color:var(--err);background:linear-gradient(180deg,var(--err-bg),var(--panel))}.kpi.alert .kpi-value{color:var(--err)}.activity{display:flex;flex-direction:column}.activity-item{display:flex;gap:12px;padding:10px 18px;border-bottom:1px solid var(--divider)}.activity-item:last-child{border-bottom:none}.activity-icon{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;flex-shrink:0;background:var(--bg-sunk);color:var(--fg-muted)}.activity-icon.green{background:var(--ok-bg);color:var(--ok)}.activity-icon.red{background:var(--err-bg);color:var(--err)}.activity-icon.blue{background:var(--info-bg);color:var(--info)}.activity-body{flex:1;min-width:0;line-height:1.45}.activity-body .row1{font-size:13px}.activity-body .row2{font-size:11px;color:var(--fg-muted)}.activity-body .who{font-weight:600}.activity-body .what{color:var(--fg)}.activity-body .target{font-family:var(--font-mono);color:var(--brand-teal-600)}[data-theme=dark] .activity-body .target{color:var(--brand-lime)}.detail-grid{display:grid;grid-template-columns:1fr 360px;gap:18px;align-items:flex-start}.detail-main{min-width:0;display:flex;flex-direction:column;gap:18px}.detail-side{display:flex;flex-direction:column;gap:14px;position:sticky;top:0}.kv-list{display:grid;grid-template-columns:1fr;gap:0}.kv{display:grid;grid-template-columns:130px 1fr;padding:8px 0;border-bottom:1px solid var(--divider);font-size:13px}.kv:last-child{border-bottom:none}.kv dt{color:var(--fg-muted);font-weight:500;font-size:12px;padding-top:1px}.kv dd{margin:0;color:var(--fg)}.kv dd.mono{font-family:var(--font-mono);font-size:12px}.timeline{display:flex;flex-direction:column;padding:4px 18px 14px}.tl-item{display:grid;grid-template-columns:24px 1fr;gap:10px;padding:8px 0;position:relative}.tl-item:before{content:"";position:absolute;left:11px;top:24px;bottom:-8px;width:1px;background:var(--border)}.tl-item:last-child:before{display:none}.tl-dot{width:22px;height:22px;border-radius:50%;background:var(--panel);border:2px solid var(--border);display:grid;place-items:center;z-index:1;color:var(--fg-muted)}.tl-dot.green{border-color:var(--ok);color:var(--ok)}.tl-dot.red{border-color:var(--err);color:var(--err)}.tl-dot.blue{border-color:var(--info);color:var(--info)}.tl-body{line-height:1.45;padding-top:1px;min-width:0}.tl-body .tl-head{font-size:13px}.tl-body .tl-meta{font-size:11px;color:var(--fg-muted)}.tl-body .tl-detail{margin-top:4px;font-size:12px;color:var(--fg-muted);background:var(--bg-sunk);padding:6px 8px;border-radius:4px;font-family:var(--font-mono);white-space:pre-wrap;border:1px solid var(--divider)}.empty{text-align:center;padding:60px 24px;display:flex;flex-direction:column;align-items:center;gap:10px}.empty-icon{width:56px;height:56px;border-radius:12px;background:var(--bg-sunk);color:var(--fg-muted);display:grid;place-items:center;margin-bottom:4px}.empty h3{margin:0;font-size:15px;font-weight:600}.empty p{margin:0 0 8px;color:var(--fg-muted);max-width:340px}.skel{background:linear-gradient(90deg,var(--bg-sunk),var(--hover),var(--bg-sunk));background-size:200% 100%;animation:skel 1.4s linear infinite;border-radius:4px;height:12px}@keyframes skel{0%{background-position:200% 0}to{background-position:-200% 0}}.tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);margin-bottom:14px}.tab{padding:8px 12px;border:none;background:transparent;font-size:13px;font-weight:500;color:var(--fg-muted);border-bottom:2px solid transparent;margin-bottom:-1px;cursor:pointer;transition:color .12s,border-color .12s}.tab:hover{color:var(--fg)}.tab.active{color:var(--fg);border-bottom-color:var(--brand-lime-strong)}.chip-row{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.chip{display:inline-flex;align-items:center;gap:4px;font-size:12px;padding:3px 9px;border-radius:999px;border:1px solid var(--border);background:var(--bg-elev);color:var(--fg-muted);cursor:pointer;transition:background .12s,color .12s,border-color .12s;height:26px}.chip:hover{background:var(--hover);color:var(--fg)}.chip.active{background:var(--brand-teal);color:#fff;border-color:var(--brand-teal)}[data-theme=dark] .chip.active{background:var(--brand-lime);color:var(--brand-lime-fg);border-color:var(--brand-lime)}.toasts{position:fixed;bottom:20px;right:20px;display:flex;flex-direction:column;gap:8px;z-index:1000}.toast{background:var(--panel);border:1px solid var(--border);border-radius:8px;padding:10px 14px;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-lg);font-size:13px;min-width:280px;animation:toast-in .2s ease-out}.toast.ok{border-left:3px solid var(--ok)}.toast.err{border-left:3px solid var(--err)}.toast .toast-icon{color:var(--ok);display:grid;place-items:center}.toast.err .toast-icon{color:var(--err)}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.auth-wrap{min-height:100vh;display:grid;place-items:center;background:linear-gradient(180deg,var(--brand-teal) 0%,#062424 100%);padding:24px}.auth-card{width:100%;max-width:380px;background:var(--panel);border-radius:14px;padding:32px 28px;box-shadow:0 20px 60px #0006;border:1px solid var(--border)}.auth-logo{width:44px;height:44px;background:var(--brand-lime);color:var(--brand-lime-fg);border-radius:10px;display:grid;place-items:center;font-weight:800;font-size:20px;margin-bottom:18px}.auth-card h1{margin:0 0 6px;font-size:18px;font-weight:600}.auth-card p{margin:0 0 24px;color:var(--fg-muted);font-size:13px}.auth-fields{display:flex;flex-direction:column;gap:14px;margin-bottom:18px}.section{margin-bottom:22px}.section-head{display:flex;align-items:baseline;gap:12px;margin-bottom:12px}.section-head .num{width:22px;height:22px;border-radius:50%;background:var(--brand-teal);color:#fff;display:grid;place-items:center;font-size:12px;font-weight:600;flex-shrink:0}.section-head h3{margin:0;font-size:14px;font-weight:600}.section-head .step-meta{color:var(--fg-muted);font-size:12px}[data-theme=dark] .section-head .num{background:var(--brand-lime);color:var(--brand-lime-fg)}.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}.form-row-stack{display:flex;flex-direction:column;gap:14px}.picker{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:14px}.picker-col{background:var(--panel);border:1px solid var(--border);border-radius:var(--r-lg);display:flex;flex-direction:column;overflow:hidden;min-height:480px}.picker-head{padding:10px 12px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px}.picker-list{flex:1;overflow-y:auto;padding:4px}.picker-item{display:grid;grid-template-columns:16px 1fr auto;gap:10px;padding:8px 10px;border-radius:6px;cursor:pointer;transition:background .08s;align-items:center}.picker-item:hover{background:var(--hover)}.picker-item.selected{background:#a3e63524;border:1px solid var(--brand-lime-strong);padding:7px 9px}.picker-item .pick-radio{width:14px;height:14px;border-radius:50%;border:1.5px solid var(--border-strong);position:relative}.picker-item.selected .pick-radio{border-color:var(--brand-lime-strong)}.picker-item.selected .pick-radio:after{content:"";position:absolute;top:2px;right:2px;bottom:2px;left:2px;background:var(--brand-lime-strong);border-radius:50%}.pick-id{font-family:var(--font-mono);font-size:12px}.pick-meta{font-size:11px;color:var(--fg-muted)}.alloc-items{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:8px;overflow:hidden}.alloc-item{display:grid;grid-template-columns:28px 1fr auto auto;gap:10px;align-items:center;padding:10px 12px;border-bottom:1px solid var(--divider);font-size:13px}.alloc-item:last-child{border-bottom:none}.alloc-item .ai-icon{width:28px;height:28px;border-radius:6px;background:var(--bg-sunk);color:var(--fg-muted);display:grid;place-items:center}.alloc-item .ai-id{font-family:var(--font-mono);font-size:12px}.alloc-item .ai-meta{font-size:11px;color:var(--fg-muted);margin-top:2px}.cmd-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a141480;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:grid;place-items:flex-start center;padding-top:12vh;z-index:100;animation:fade-in .15s ease-out}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.cmd-box{width:92%;max-width:540px;background:var(--panel);border:1px solid var(--border);border-radius:12px;box-shadow:0 30px 80px #0006;overflow:hidden}.cmd-input-row{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border)}.cmd-input{flex:1;border:none;outline:none;background:transparent;font-size:15px;color:var(--fg)}.cmd-input::placeholder{color:var(--fg-faint)}.cmd-results{max-height:360px;overflow-y:auto;padding:6px}.cmd-group-head{padding:6px 10px 4px;font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--fg-faint);font-weight:600}.cmd-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:6px;font-size:13px;cursor:pointer}.cmd-item:hover,.cmd-item.active{background:var(--hover)}.cmd-item.active{background:#a3e6351f}.cmd-item-icon{width:16px;height:16px;color:var(--fg-muted)}.cmd-item-meta{color:var(--fg-muted);margin-left:auto;font-size:11px}.sg-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px}.sg-card{background:var(--panel);border:1px solid var(--border);border-radius:8px;padding:14px;display:flex;flex-direction:column;gap:10px}.sg-swatch{height:60px;border-radius:6px;border:1px solid var(--border);position:relative;overflow:hidden}.sg-swatch-label{position:absolute;bottom:6px;left:8px;font-family:var(--font-mono);font-size:10px;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.4)}.sg-card h4{margin:0;font-size:13px;font-weight:600}.sg-card p{margin:0;font-size:11px;color:var(--fg-muted);font-family:var(--font-mono)}[data-tweaks-panel]{font-family:var(--font-sans)!important}@media (max-width: 900px){.app{grid-template-columns:1fr;grid-template-rows:var(--topbar-h) 1fr;grid-template-areas:"topbar" "main"}.sidebar{position:fixed;top:0;right:0;bottom:0;left:0;width:280px;transform:translate(-100%);z-index:50;transition:transform .2s ease-out}.sidebar.open{transform:translate(0);box-shadow:0 0 80px #0006}.sidebar-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:49;animation:fade-in .15s ease-out}.main{padding:16px 14px 80px}.tb-search{width:auto;flex:1}.tb-search .grow{display:none}.kpi-grid{grid-template-columns:repeat(2,1fr);gap:10px}.kpi{padding:12px 14px}.kpi-value{font-size:22px}.detail-grid{grid-template-columns:1fr}.detail-side{position:static}.form-grid-2,.form-grid-3,.picker{grid-template-columns:1fr}.picker-col{min-height:320px}.page-head{flex-direction:column;align-items:flex-start;gap:10px}.page-actions{width:100%;flex-wrap:wrap}.tbl-mobile thead{display:none}.tbl-mobile,.tbl-mobile tbody,.tbl-mobile tr,.tbl-mobile td{display:block;width:100%}.tbl-mobile tbody tr{border:1px solid var(--border);border-radius:8px;margin-bottom:8px;padding:10px 12px;background:var(--panel)}.tbl-mobile tbody td{height:auto!important;border:none!important;padding:3px 0!important;display:flex;justify-content:space-between;align-items:center}.tbl-mobile tbody td:before{content:attr(data-label);font-size:10px;text-transform:uppercase;color:var(--fg-muted);letter-spacing:.04em;margin-right:8px}.tbl-mobile tbody td:first-child:before{display:none}.tbl-mobile tbody td:first-child{font-weight:600;padding-bottom:6px!important;margin-bottom:4px;border-bottom:1px solid var(--divider)!important}.crumbs{font-size:12px}.crumbs>:not(:last-child):not(.crumb-sep){display:none}}@media print{.no-print,.sidebar,.topbar{display:none!important}body,html,.app,.main{background:#fff!important;color:#000!important}.print-only{display:block!important}.print-only *{color:#000!important}}@media screen{.print-only{display:none}}.label-sticker{width:62mm;padding:4mm;border:.3mm solid #000;font-family:var(--font-mono);display:flex;flex-direction:column;gap:2mm;page-break-after:always;background:#fff;color:#000}.label-sticker .label-title{font-size:9pt;font-weight:700;letter-spacing:.04em}.label-sticker .label-id{font-size:14pt;font-weight:700;word-break:break-all}.label-sticker .label-meta{font-size:7pt;line-height:1.3;word-break:break-all}.label-sticker .label-qr{display:flex;justify-content:center;padding:1mm 0}.label-sticker .label-qr a{display:inline-block;line-height:0}.label-sticker .label-url{font-size:5.5pt;text-align:center;word-break:break-all;line-height:1.2;margin-top:0}.label-sticker .label-url a{color:#000;text-decoration:underline}.label-pairing{width:100mm;padding:5mm}.albaran{width:210mm;min-height:297mm;padding:15mm;font-family:ui-sans-serif,-apple-system,system-ui,sans-serif;background:#fff;color:#000;page-break-after:always}.albaran h1{font-size:18pt;margin:0 0 4mm}.albaran h2{font-size:12pt;margin:6mm 0 2mm}.albaran .albaran-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10mm;border-bottom:.4mm solid #000;padding-bottom:4mm;margin-bottom:4mm}.albaran .albaran-meta{font-size:9pt;line-height:1.4}.albaran .albaran-meta b{display:inline-block;min-width:22mm}.albaran table{width:100%;border-collapse:collapse;margin-top:2mm;font-size:9pt}.albaran th,.albaran td{border-bottom:.2mm solid #888;padding:2mm 2mm 2mm 0;text-align:left;vertical-align:top}.albaran th{font-size:8pt;text-transform:uppercase;letter-spacing:.04em;color:#555}.albaran .albaran-qr{width:16mm;height:16mm}.albaran .albaran-foot{margin-top:8mm;font-size:8pt;color:#666}
