:root{--bg: #eef1f6;--card: #fff;--border: #e2e6ea;--primary: #2563eb;--primary-hover: #1d4ed8;--danger: #dc2626;--muted: #64748b;--radius: 12px;--control-height: 2.55rem;--control-pad-y: .52rem;--control-pad-x: .72rem;--btn-pad-y: .34rem;--btn-pad-x: .58rem;--btn-font: .8125rem;--btn-radius: 7px;--btn-height: 2.2rem}*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--bg);color:#212529;line-height:1.45}.app-shell{min-height:100vh;display:flex;flex-direction:column}.topbar{position:sticky;top:0;z-index:20;background:#ffffffd1;backdrop-filter:blur(12px) saturate(1.4);-webkit-backdrop-filter:blur(12px) saturate(1.4);border-bottom:1px solid rgba(15,23,42,.06);padding:.5rem .65rem;display:flex;flex-wrap:nowrap;align-items:center;gap:.4rem;min-width:0}.topbar-main{display:flex;flex-wrap:nowrap;align-items:center;gap:.4rem;flex:1 1 0;min-width:0}.topbar h1{margin:0;font-size:1rem;font-weight:650;letter-spacing:-.02em;color:#0f172a;flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar .btn-logout{flex:0 0 auto;margin-left:auto}.tabs{display:flex;gap:.45rem;flex-wrap:nowrap;flex-shrink:0;align-items:center}.tab-btn{border:1px solid transparent;min-height:var(--btn-height);padding:.26rem .62rem;border-radius:var(--btn-radius);font-size:.78rem;font-weight:650;font-family:inherit;cursor:pointer;box-sizing:border-box;transition:background .14s ease,border-color .14s ease,color .14s ease,box-shadow .14s ease,transform .12s ease}.tab-btn:active{transform:scale(.98)}.tab-order{background:#e7f1ff;border-color:#9ec5fe;color:#084298}.tab-order:hover{background:#cfe2ff}.tab-order.active{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 1px 2px #2563eb59}.tab-stocks{background:#e2f4ea;border-color:#9ee5c8;color:#0a4d26}.tab-stocks:hover{background:#cce9d8}.tab-stocks.active{background:#15803d;border-color:#166534;color:#fff;box-shadow:0 1px 2px #16653459}.tab-orders{background:#f3e8ff;border-color:#d4a5f5;color:#5b2c91}.tab-orders:hover{background:#e9d5ff}.tab-orders.active{background:#6d28d9;border-color:#5b21b6;color:#fff;box-shadow:0 1px 2px #5b21b659}.btn.btn-logout{background:#ef4444;color:#fff;border:1px solid #dc2626;font-weight:600}.btn.btn-logout:hover{background:#dc2626;border-color:#b91c1c}.btn.btn-logout:active{background:#b91c1c}main{flex:1;padding:.75rem;max-width:1100px;margin:0 auto;width:100%}.card{background:var(--card);border:1px solid rgba(15,23,42,.06);border-radius:var(--radius);padding:.95rem 1rem;margin-bottom:.75rem;box-shadow:0 1px 3px #0f172a0d}.card h2{margin:0 0 .75rem;font-size:1.1rem}.card-section-head{display:flex;align-items:center;gap:.2rem;margin-bottom:.75rem}.card-section-head h2{margin:0;font-size:1.1rem}.section-refresh{flex-shrink:0}.row{display:flex;flex-wrap:wrap;gap:.65rem;margin-bottom:.65rem}.row>*{flex:1 1 180px}label{display:block;font-size:.82rem;color:var(--muted);margin-bottom:.2rem}input[type=text],input[type=password],input[type=number],input[type=tel],input[type=search],select,textarea{width:100%;min-height:var(--control-height);padding:var(--control-pad-y) var(--control-pad-x);border:1px solid var(--border);border-radius:var(--btn-radius);font-size:.9375rem;font-family:inherit;line-height:1.45;box-sizing:border-box}textarea{min-height:5.5rem;resize:vertical}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.3rem;border:none;border-radius:var(--btn-radius);padding:var(--btn-pad-y) var(--btn-pad-x);min-height:var(--btn-height);font-size:var(--btn-font);font-weight:650;font-family:inherit;line-height:1.2;cursor:pointer;background:#e2e8f0;color:#1e293b;transition:background .14s ease,border-color .14s ease,color .14s ease,box-shadow .14s ease,transform .1s ease}.btn:active:not(:disabled){transform:scale(.98)}.btn:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.btn .ico{display:block;flex-shrink:0}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 1px 2px #2563eb40}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-primary:disabled{opacity:.55;cursor:not-allowed;transform:none}.btn-danger{background:var(--danger);color:#fff;border:1px solid #b91c1c;box-shadow:0 1px 2px #dc262633}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-ghost{background:#ffffffb3;border:1px solid rgba(15,23,42,.1);color:#334155}.btn-ghost:hover:not(:disabled){background:#fff;border-color:#0f172a24}.btn-sm{min-height:2rem;padding:.22rem .52rem;font-size:.78rem}.btn.btn-icon{padding:.28rem;min-width:var(--btn-height);min-height:var(--btn-height);gap:0}.btn.btn-icon.btn-danger{border-color:transparent}.btn.btn-icon.btn-logout{border-color:#ffffff59}.size-grid{display:flex;flex-wrap:wrap;gap:.45rem}.size-btn{border:1px solid rgba(15,23,42,.1);background:#fff;border-radius:var(--btn-radius);padding:.34rem .48rem;font-size:.78rem;font-weight:500;text-align:left;cursor:pointer;min-width:3.75rem;transition:border-color .12s ease,background .12s ease,box-shadow .12s ease}.size-btn.active{border-color:var(--primary);background:#eff6ff;box-shadow:0 0 0 1px #2563eb33}.size-btn .sub{display:block;font-size:.65rem;color:var(--muted);margin-top:.12rem;font-weight:500}.order-lines-empty{margin:0;color:var(--muted);font-size:.92rem}.order-lines{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.55rem}.order-line{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.75rem .9rem;border:1px solid var(--border);border-radius:var(--radius);background:#fff;box-shadow:0 1px 2px #0000000d}.order-line-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:.2rem}.order-line-title{font-size:.98rem;font-weight:600;color:#1a1d21;line-height:1.35}.order-line-sub{font-size:.84rem;color:var(--muted);letter-spacing:.01em}.alert{padding:.55rem .65rem;border-radius:var(--btn-radius);margin-bottom:.55rem;font-size:.88rem}.alert-success{background:#d1e7dd;color:#0f5132}.alert-danger{background:#f8d7da;color:#842029}.order-submit-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:110;display:flex;align-items:center;justify-content:center;background:#0f172a61;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);animation:modal-in .16s ease-out}.order-submit-overlay__box{display:flex;flex-direction:column;align-items:center;gap:.85rem;min-width:15rem;padding:1.25rem 1.5rem;background:var(--card);border:1px solid rgba(15,23,42,.08);border-radius:var(--radius);box-shadow:0 16px 48px #0f172a33}.order-submit-spinner{width:2.35rem;height:2.35rem;border:3px solid rgba(37,99,235,.2);border-top-color:var(--primary);border-radius:50%;animation:order-submit-spin .75s linear infinite}@keyframes order-submit-spin{to{transform:rotate(360deg)}}.order-submit-overlay__text{margin:0;font-size:.9rem;font-weight:600;color:#334155;text-align:center}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#0f172a7a;display:flex;align-items:center;justify-content:center;padding:1rem;animation:modal-in .18s ease-out}@keyframes modal-in{0%{opacity:0}to{opacity:1}}.modal-panel{width:100%;max-width:26rem;max-height:min(85vh,32rem);display:flex;flex-direction:column;background:var(--card);border:1px solid rgba(15,23,42,.08);border-radius:var(--radius);box-shadow:0 16px 48px #0f172a2e;padding:1rem 1.05rem}.modal-panel--success{border-color:#16a34a47}.modal-panel--error{border-color:#dc262647}.modal-title{margin:0 0 .55rem;font-size:1.05rem;font-weight:650;color:#0f172a;letter-spacing:-.02em}.modal-body{margin:0 0 .85rem;display:flex;flex-direction:column;gap:.65rem;flex:1 1 auto;min-height:0;overflow-y:auto}.modal-body-main{font-size:.9rem;line-height:1.45;color:#334155;white-space:pre-wrap;word-break:break-word}.modal-order-number{margin:0;padding:.55rem .65rem;border-radius:var(--btn-radius);background:#f1f5f9;border:1px solid rgba(15,23,42,.08);font-size:.92rem;line-height:1.4}.modal-order-label{display:block;font-size:.78rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.2rem}.modal-order-number strong{font-size:1.02rem;font-weight:650;color:#0f172a;letter-spacing:-.02em}.modal-order-number--hero{margin-bottom:.15rem}.modal-order-number--hero strong{font-size:1.2rem;display:block;margin-top:.15rem}.modal-actions{display:flex;justify-content:flex-end;gap:.5rem;flex-shrink:0}.modal-panel--composition{max-width:min(52rem,96vw);max-height:min(88vh,42rem)}.modal-composition-subtitle{margin:-.15rem 0 .55rem;font-size:.84rem;color:var(--muted);line-height:1.35}.modal-body--composition{margin:0 0 .65rem;flex:1 1 auto;min-height:0;overflow:auto}.order-composition-table{width:100%;border-collapse:collapse;font-size:.82rem;border:1px solid var(--border);border-radius:var(--btn-radius);overflow:hidden}.order-composition-table th,.order-composition-table td{padding:.35rem .45rem;border-bottom:1px solid var(--border);vertical-align:top}.order-composition-table thead th{position:static;background:#e9ecef;font-weight:600;font-size:.78rem;white-space:nowrap}.order-composition-table tbody tr:last-child td{border-bottom:none}.order-composition-table--compact{font-size:.72rem}.order-composition-table--compact th,.order-composition-table--compact td{padding:.28rem .35rem}.orders-composition-empty{color:var(--muted);font-size:.85rem}.th-order-composition,.td-order-composition{min-width:5.5rem;max-width:8.5rem;text-align:center;vertical-align:middle}.orders-btn-composition{width:100%;max-width:7.5rem;justify-content:center}.table-wrap{overflow:auto;max-height:min(70vh,640px);border:1px solid var(--border);border-radius:var(--radius);background:#fff}table{width:100%;border-collapse:collapse;font-size:.85rem}th,td{padding:.45rem .4rem;border-bottom:1px solid var(--border);text-align:left;vertical-align:top}th{position:sticky;top:0;background:#e9ecef;z-index:2;font-weight:600;white-space:nowrap}th.th-sort{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .12s ease}th.th-sort:hover{background:#dde2e6}th.th-sort:active{background:#cfd6dc}.table-sort-hint{margin:0 0 .5rem;font-size:.8rem;color:var(--muted)}.orders-table tbody tr.order-row{transition:background-color .14s ease}.orders-table tbody tr.order-row--st-empty{background-color:#94a3b833}.orders-table tbody tr.order-row--st-new{background-color:#3b82f624}.orders-table tbody tr.order-row--st-wait{background-color:#f59e0b29}.orders-table tbody tr.order-row--st-picked{background-color:#10b98124}.orders-table tbody tr.order-row--st-shipped{background-color:#8b5cf624}.orders-table tbody tr.order-row--st-done{background-color:#22c55e26}.orders-table tbody tr.order-row--st-cancel{background-color:#ef444424}.orders-table tbody tr.order-row--st-return{background-color:#f9731626}.orders-table tbody tr.order-row--st-progress{background-color:#6366f124}.orders-table tbody tr.order-row--st-nobuy{background-color:#64748b2e}.orders-table tbody tr.order-row--st-repeat{background-color:#c084fc24}.orders-table tbody tr.order-row--st-confirm{background-color:#14b8a624}.orders-table tbody tr.order-row--st-pay{background-color:#eab3082e}.orders-table tbody tr.order-row--st-courier{background-color:#0ea5e926}.orders-table tbody tr.order-row--st-other{background-color:#78716c29}.orders-table tbody tr.order-row--st-empty:hover{background-color:#94a3b847}.orders-table tbody tr.order-row--st-new:hover{background-color:#3b82f633}.orders-table tbody tr.order-row--st-wait:hover{background-color:#f59e0b38}.orders-table tbody tr.order-row--st-picked:hover{background-color:#10b98133}.orders-table tbody tr.order-row--st-shipped:hover{background-color:#8b5cf633}.orders-table tbody tr.order-row--st-done:hover{background-color:#22c55e38}.orders-table tbody tr.order-row--st-cancel:hover{background-color:#ef444433}.orders-table tbody tr.order-row--st-return:hover{background-color:#f9731638}.orders-table tbody tr.order-row--st-progress:hover{background-color:#6366f133}.orders-table tbody tr.order-row--st-nobuy:hover{background-color:#64748b3d}.orders-table tbody tr.order-row--st-repeat:hover{background-color:#c084fc33}.orders-table tbody tr.order-row--st-confirm:hover{background-color:#14b8a633}.orders-table tbody tr.order-row--st-pay:hover{background-color:#eab3083d}.orders-table tbody tr.order-row--st-courier:hover{background-color:#0ea5e938}.orders-table tbody tr.order-row--st-other:hover{background-color:#78716c38}.orders-td-date{white-space:nowrap;font-variant-numeric:tabular-nums;font-size:.82rem;letter-spacing:.01em}.order-status-pill{display:inline-flex;align-items:center;max-width:100%;padding:.2rem .58rem;border-radius:999px;font-size:.78rem;font-weight:650;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border:1px solid transparent;vertical-align:middle}.order-status-pill--st-empty{color:#64748b;background:#94a3b838;border-color:#64748b47}.order-status-pill--st-new{color:#1d4ed8;background:#3b82f629;border-color:#2563eb47}.order-status-pill--st-wait{color:#b45309;background:#f59e0b2e;border-color:#d977064d}.order-status-pill--st-picked{color:#047857;background:#10b98129;border-color:#05966947}.order-status-pill--st-shipped{color:#6d28d9;background:#8b5cf629;border-color:#6d28d947}.order-status-pill--st-done{color:#15803d;background:#22c55e2b;border-color:#16a34a4d}.order-status-pill--st-cancel{color:#b91c1c;background:#ef444426;border-color:#dc262647}.order-status-pill--st-return{color:#c2410c;background:#f9731629;border-color:#ea580c47}.order-status-pill--st-progress{color:#4338ca;background:#6366f129;border-color:#4338ca47}.order-status-pill--st-nobuy{color:#475569;background:#64748b2e;border-color:#47556947}.order-status-pill--st-repeat{color:#7e22ce;background:#c084fc29;border-color:#7e22ce42}.order-status-pill--st-confirm{color:#0f766e;background:#14b8a629;border-color:#0d948847}.order-status-pill--st-pay{color:#a16207;background:#eab30833;border-color:#ca8a0452}.order-status-pill--st-courier{color:#0369a1;background:#0ea5e929;border-color:#0284c747}.order-status-pill--st-other{color:#57534e;background:#78716c2e;border-color:#57534e47}td.num{text-align:right;white-space:nowrap}.login-panel{max-width:380px;margin:3rem auto;padding:1.25rem 1.35rem}.login-panel h2{text-align:center;font-size:1.2rem;margin-bottom:1rem}.login-form{display:flex;flex-direction:column;gap:1rem}.login-field{display:flex;flex-direction:column;gap:.35rem}.login-label{display:block;margin:0;font-size:.875rem;font-weight:500;color:var(--muted);letter-spacing:.01em}.login-input{width:100%;margin:0;display:block;box-sizing:border-box;min-height:var(--control-height);padding:var(--control-pad-y) var(--control-pad-x);font-size:.9375rem;line-height:1.45;font-family:inherit;color:#0f172a;background:#fff;border:1px solid rgba(15,23,42,.1);border-radius:var(--btn-radius);transition:border-color .15s ease,box-shadow .15s ease}.login-input::placeholder{color:#adb5bd}.login-input:hover{border-color:#ced4da}.login-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb2e}.login-submit{width:100%;margin-top:.15rem;min-height:var(--btn-height);font-weight:650;font-size:var(--btn-font)}.toolbar{display:flex;flex-wrap:wrap;gap:.65rem;margin-bottom:.65rem;align-items:flex-end}.toolbar-search{flex:1 1 240px;min-width:0}.orders-toolbar{align-items:flex-end}.orders-status-field{flex:0 1 220px;min-width:10rem;max-width:100%}.orders-status-select{width:100%;cursor:pointer}.stocks-toolbar{align-items:flex-end}.stocks-search-field{flex:1 1 260px;min-width:0;margin-bottom:0}.stocks-switch{display:flex;align-items:center;gap:.5rem;cursor:pointer;-webkit-user-select:none;user-select:none;flex-shrink:0;margin-bottom:.05rem}.stocks-switch input{position:absolute;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden;clip:rect(0 0 0 0);clip-path:inset(50%);white-space:nowrap;border:0;opacity:.01}.stocks-switch-track{position:relative;width:2.55rem;height:1.38rem;border-radius:999px;background:#ced4da;flex-shrink:0;transition:background .2s ease}.stocks-switch-track:after{content:"";position:absolute;width:1.08rem;height:1.08rem;border-radius:50%;background:#fff;top:.15rem;left:.15rem;transition:transform .2s ease;box-shadow:0 1px 3px #0003}.stocks-switch input:checked+.stocks-switch-track{background:var(--primary)}.stocks-switch input:checked+.stocks-switch-track:after{transform:translate(1.12rem)}.stocks-switch-text{font-size:.84rem;font-weight:500;color:#343a40;max-width:9rem;line-height:1.25}.title-preview{font-size:.95rem;font-weight:500;margin:.25rem 0 .5rem}.order-field-block{margin-bottom:1rem}.order-field-block:last-of-type{margin-bottom:0}.order-field-label{display:block;margin:0 0 .4rem;font-size:.875rem;font-weight:500;color:var(--muted)}.choice-btn-row{display:flex;flex-wrap:wrap;gap:.45rem}.choice-btn{border:1px solid rgba(15,23,42,.1);background:#fff;color:#0f172a;min-height:var(--btn-height);padding:.28rem .58rem;border-radius:var(--btn-radius);font-size:.75rem;font-weight:650;cursor:pointer;font-family:inherit;line-height:1.25;text-align:center;transition:border-color .12s ease,background .12s ease,box-shadow .12s ease,transform .1s ease;box-sizing:border-box}.choice-btn:active{transform:scale(.98)}.choice-btn:hover{border-color:#0f172a29;background:#f8fafc}.choice-btn.active{border-color:var(--primary);background:#eff6ff;color:#1d4ed8;box-shadow:0 0 0 1px #2563eb38}.delivery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(8.5rem,1fr));gap:.65rem}.delivery-tile{display:flex;flex-direction:column;align-items:center;gap:.35rem;padding:.5rem .38rem .42rem;border:1px solid rgba(15,23,42,.1);border-radius:var(--btn-radius);background:#fff;cursor:pointer;font-family:inherit;transition:border-color .12s ease,box-shadow .12s ease,background .12s ease,transform .1s ease}.delivery-tile:active{transform:scale(.99)}.delivery-tile:hover{border-color:#0f172a24;background:#fafbfc}.delivery-tile--active{border-color:var(--primary);background:#eff6ff;box-shadow:0 0 0 1px #2563eb47}.delivery-tile-icon{width:100%;height:2.35rem;display:flex;align-items:center;justify-content:center;padding:0 .2rem}.delivery-tile-icon img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain}.delivery-tile-caption{font-size:.65rem;font-weight:650;line-height:1.22;text-align:center;color:#334155;-webkit-hyphens:auto;hyphens:auto;overflow-wrap:anywhere}.stack-fields{display:flex;flex-direction:column;gap:.85rem;margin-bottom:.25rem}.stack-input,.stack-textarea{width:100%;margin:0;min-height:var(--control-height);padding:var(--control-pad-y) var(--control-pad-x);border:1px solid rgba(15,23,42,.1);border-radius:var(--btn-radius);font-size:.9375rem;font-family:inherit;line-height:1.45;box-sizing:border-box;transition:border-color .15s,box-shadow .15s}.stack-input:focus,.stack-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb29}.stack-textarea{min-height:5.5rem;height:auto;resize:vertical}@media (max-width: 520px){.topbar{gap:.3rem;padding:.45rem .5rem}.tab-btn{padding:.22rem .48rem;font-size:.72rem}th,td{font-size:.78rem}}
