:root{--brand:#7a5c2e;--brand-dark:#5d4522;--brand-soft:#f3ede2;--bg:#f4f5f7;--surface:#fff;--border:#e2e4e9;--border-strong:#cfd3da;--text:#1c1e24;--text-2:#4b5160;--text-muted:#7a8194;--ok:#1a7f37;--ok-bg:#e6f4ea;--warn:#9a6700;--warn-bg:#fff3d6;--danger:#b42318;--danger-bg:#fdecea;--info-bg:#eef2f8;--sidebar-bg:#211d17;--sidebar-text:#d9d4ca;--sidebar-muted:#8f887a;--radius:10px;--radius-sm:7px;--shadow-card:0 1px 2px #1012180d, 0 1px 3px #1012180f;--shadow-pop:0 12px 40px #10121838;color:var(--text);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{background:var(--bg);margin:0;font-size:14.5px;line-height:1.45}#root{min-height:100dvh}h1{letter-spacing:-.01em;margin:0;font-size:1.3rem;font-weight:700}button{font:inherit;cursor:pointer}input,select,textarea{font:inherit;color:var(--text);border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--surface);min-height:40px;padding:.5rem .7rem}textarea{min-height:auto}input:focus,select:focus,textarea:focus,button:focus-visible{outline:2px solid var(--brand);outline-offset:1px;border-color:var(--brand)}.app-loading{min-height:100vh;color:var(--text-muted);place-items:center;display:grid}.login-page{background:radial-gradient(1200px 500px at 50% -10%, #eee7da 0%, transparent 60%), var(--bg);place-items:center;min-height:100dvh;padding:1rem;display:grid}.login-card{background:var(--surface);border:1px solid var(--border);text-align:center;width:100%;max-width:380px;box-shadow:var(--shadow-card);border-radius:14px;flex-direction:column;gap:1rem;padding:2.2rem 2rem;display:flex}.login-card h1{font-size:1.2rem}.login-subtitle{color:var(--text-muted);margin:-.6rem 0 .4rem;font-size:.85rem}.login-card img{border-radius:12px;margin:0 auto}.login-card label{text-align:left;color:var(--text-2);flex-direction:column;gap:.3rem;font-size:.82rem;font-weight:600;display:flex}.login-card button[type=submit]{background:var(--brand);color:#fff;border-radius:var(--radius-sm);border:none;min-height:44px;padding:.7rem;font-weight:650}.login-card button[type=submit]:hover{background:var(--brand-dark)}.login-card button[type=submit]:disabled{opacity:.6;cursor:default}.form-error{background:var(--danger-bg);color:var(--danger);border-radius:var(--radius-sm);border:1px solid #f5c6c0;padding:.55rem .75rem;font-size:.85rem}.shell{grid-template-columns:232px 1fr;min-height:100dvh;display:grid}.sidebar{background:var(--sidebar-bg);color:var(--sidebar-text);flex-direction:column;gap:1.1rem;height:100dvh;padding:1.1rem .75rem;display:flex;position:sticky;top:0;overflow-y:auto}.sidebar-brand{color:#fff;align-items:center;gap:.6rem;padding:.1rem .45rem;font-size:1rem;font-weight:700;display:flex}.sidebar-brand img{border-radius:9px}.sidebar-brand small{color:var(--sidebar-muted);letter-spacing:.04em;font-size:.68rem;font-weight:500;display:block}.sidebar-section{text-transform:uppercase;letter-spacing:.09em;color:var(--sidebar-muted);margin-bottom:.2rem;padding:0 .55rem;font-size:.66rem;font-weight:700}.sidebar-nav{flex-direction:column;flex:1;gap:2px;display:flex}.sidebar-nav a{color:var(--sidebar-text);border-radius:var(--radius-sm);align-items:center;gap:.6rem;padding:.52rem .6rem;font-size:.9rem;font-weight:500;text-decoration:none;display:flex}.sidebar-nav a .icon{opacity:.75}.sidebar-nav a:hover{color:#fff;background:#ffffff12}.sidebar-nav a.active{background:var(--brand);color:#fff;font-weight:600}.sidebar-nav a.active .icon{opacity:1}.sidebar-footer{border-top:1px solid #ffffff1a;flex-direction:column;gap:.55rem;padding-top:.8rem;display:flex}.user-box{flex-direction:column;padding:0 .45rem;font-size:.88rem;display:flex}.user-box strong{color:#fff}.user-box small{color:var(--sidebar-muted)}.btn-ghost{color:var(--sidebar-text);border-radius:var(--radius-sm);background:0 0;border:1px solid #ffffff38;min-height:40px;padding:.5rem}.btn-ghost:hover{color:#fff;background:#ffffff14}.topbar-mobile{z-index:40;background:var(--sidebar-bg);color:#fff;padding:.55rem .9rem;padding-top:calc(.55rem + env(safe-area-inset-top));align-items:center;gap:.7rem;display:none;position:sticky;top:0}.topbar-mobile .burger{color:#fff;background:0 0;border:none;place-items:center;padding:.35rem;display:grid}.topbar-title{align-items:center;gap:.5rem;font-size:1rem;font-weight:700;display:flex}.drawer-backdrop{display:none}.content{min-width:0;padding:1.5rem 1.8rem 3rem}.page-header{flex-wrap:wrap;align-items:baseline;gap:.8rem;margin-bottom:1.1rem;display:flex}.page-sub{color:var(--text-muted);font-size:.88rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:1.2rem 1.4rem}.muted{color:var(--text-muted)}.kpi-grid{grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:.9rem;margin-bottom:1.4rem;display:grid}.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-card);color:var(--text);flex-direction:column;gap:.3rem;padding:.95rem 1.05rem;text-decoration:none;transition:border-color .12s,transform .12s;display:flex}.kpi-card:hover{border-color:var(--brand);transform:translateY(-1px)}.kpi-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);align-items:center;gap:.45rem;font-size:.72rem;font-weight:700;display:flex}.kpi-dot{background:var(--border-strong);border-radius:999px;flex:none;width:8px;height:8px}.kpi-dot.ok{background:var(--ok)}.kpi-dot.warn{background:#e0a400}.kpi-value{letter-spacing:-.02em;font-variant-numeric:tabular-nums;font-size:1.65rem;font-weight:750;line-height:1.15}.kpi-sub{color:var(--text-muted);font-size:.8rem}.module-layout{grid-template-columns:208px 1fr;align-items:start;gap:1.3rem;display:grid}.subnav-vertical{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-card);flex-direction:column;gap:.85rem;padding:.75rem .55rem;display:flex;position:sticky;top:1rem}.subnav-group{flex-direction:column;gap:1px;display:flex}.subnav-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding:0 .6rem .3rem;font-size:.66rem;font-weight:700}.subnav-vertical a{color:var(--text-2);border-radius:var(--radius-sm);padding:.42rem .6rem;font-size:.88rem;font-weight:500;text-decoration:none}.subnav-vertical a:hover{background:var(--bg);color:var(--text)}.subnav-vertical a.active{background:var(--brand-soft);color:var(--brand-dark);box-shadow:inset 2.5px 0 0 var(--brand);font-weight:650}.module-content{min-width:0}.toolbar{flex-wrap:wrap;align-items:center;gap:.6rem;margin-bottom:.9rem;display:flex}.search-input{flex:0 260px;min-width:220px}.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-card);-webkit-overflow-scrolling:touch;overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:.88rem}.data-table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);white-space:nowrap;background:#fafbfc;padding:.6rem .85rem;font-size:.72rem;font-weight:650}.data-table td{border-bottom:1px solid var(--border);font-variant-numeric:tabular-nums;padding:.58rem .85rem}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:#f7f8fa}.data-table tfoot td{border-top:2px solid var(--border-strong);font-variant-numeric:tabular-nums;background:#fafbfc;padding:.7rem .85rem}.num{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}.row-actions{white-space:nowrap;text-align:right}.badge{white-space:nowrap;border-radius:999px;padding:.12rem .55rem;font-size:.74rem;font-weight:650;display:inline-block}.badge-on{background:var(--ok-bg);color:var(--ok)}.badge-off{color:var(--text-muted);background:#eceef1}.badge-warn{background:var(--warn-bg);color:var(--warn)}.warning-banner{background:var(--warn-bg);color:var(--warn);border-radius:var(--radius-sm);border:1px solid #ecd9a0;margin-bottom:.7rem;padding:.6rem .85rem;font-size:.88rem}.success-banner{background:var(--ok-bg);color:var(--ok);border-radius:var(--radius-sm);border:1px solid #bfe3c6;margin-bottom:.7rem;padding:.6rem .85rem;font-size:.88rem}.btn-primary{background:var(--brand);color:#fff;border-radius:var(--radius-sm);white-space:nowrap;border:none;min-height:40px;padding:.5rem 1rem;font-weight:650}.btn-primary:hover{background:var(--brand-dark)}.btn-primary:disabled{opacity:.55;cursor:default}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border-strong);border-radius:var(--radius-sm);white-space:nowrap;min-height:40px;padding:.5rem 1rem;font-weight:550}.btn-secondary:hover{border-color:var(--brand);color:var(--brand-dark);background:var(--brand-soft)}.btn-secondary:disabled{opacity:.55;cursor:default}.btn-link{color:var(--brand-dark);background:0 0;border:none;border-radius:6px;padding:.3rem .45rem;font-size:.85rem;font-weight:600}.btn-link:hover{background:var(--brand-soft)}.btn-link.danger{color:var(--danger)}.btn-link.danger:hover{background:var(--danger-bg)}.modal-backdrop{z-index:100;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#12141a80;place-items:center;padding:1rem;display:grid;position:fixed;inset:0}.modal{background:var(--surface);width:100%;max-width:520px;max-height:92dvh;box-shadow:var(--shadow-pop);border-radius:14px;padding:1.5rem 1.6rem;overflow-y:auto}.modal-wide{max-width:780px}.modal h2{margin:0 0 .8rem;font-size:1.08rem;font-weight:700}.modal h3{margin:1.1rem 0 .4rem;font-size:.92rem}.entity-form{grid-template-columns:1fr 1fr;gap:.75rem .9rem;display:grid}.entity-form label{color:var(--text-2);flex-direction:column;gap:.3rem;font-size:.8rem;font-weight:600;display:flex}.entity-form input[type=checkbox]{width:20px;height:20px;min-height:auto;accent-color:var(--brand)}.span-2{grid-column:span 2}.req{color:var(--danger);margin-left:2px}.field-error{color:var(--danger);font-size:.78rem;font-weight:500}.field-label{color:var(--text-2);margin-bottom:.3rem;font-size:.8rem;font-weight:600;display:block}.modal-actions{flex-wrap:wrap;justify-content:flex-end;gap:.6rem;margin-top:1.1rem;display:flex}.checkbox-row{flex-wrap:wrap;gap:.4rem 1.2rem;display:flex}.checkbox-inline{align-items:center;gap:.45rem;font-size:.88rem;flex-direction:row!important;font-weight:500!important;display:flex!important}.checkbox-inline input{width:20px;min-height:auto}.qty-in{color:var(--ok);font-weight:650}.qty-out{color:var(--danger);font-weight:650}.qty-input{width:140px}.qty-input-sm{text-align:right;width:92px;min-height:36px;padding:.35rem .5rem}.unload-box{background:var(--info-bg);border:1px solid var(--border);border-radius:var(--radius);margin-top:1.3rem;padding:1rem 1.1rem}.unload-box h3{margin:0 0 .3rem;font-size:.95rem}@media (width<=900px){.module-layout{grid-template-columns:1fr}.subnav-vertical{flex-flow:wrap;gap:.9rem 1.4rem;position:static}.subnav-group{min-width:130px}}@media (width<=760px){.shell{grid-template-columns:1fr}.topbar-mobile{display:flex}.sidebar{z-index:60;width:min(280px,84vw);box-shadow:var(--shadow-pop);padding-top:calc(1.1rem + env(safe-area-inset-top));transition:transform .22s;position:fixed;inset:0 auto 0 0;transform:translate(-105%)}.shell.drawer-open .sidebar{transform:translate(0)}.drawer-backdrop{z-index:50;background:#12141a73;border:none;padding:0;display:none;position:fixed;inset:0}.shell.drawer-open .drawer-backdrop{display:block}.content{padding:1rem .9rem 4rem}.kpi-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.65rem}.kpi-value{font-size:1.35rem}.toolbar>*{flex:auto}.search-input{min-width:0}.modal{max-height:88dvh;padding:1.2rem 1rem}.entity-form{grid-template-columns:1fr}.span-2{grid-column:span 1}.modal-actions{background:var(--surface);margin-bottom:-.3rem;padding:.7rem 0;position:sticky;bottom:-1.2rem}.data-table{font-size:.84rem}.data-table th,.data-table td{padding:.5rem .6rem}}
