:root{--bg: #0b0c14;--bg-2: #11131c;--bg-3: #161826;--surface: #1c1f2e;--surface-2: #232739;--border: #2a2e44;--text: #e7e8ee;--text-muted: #8b8fa3;--text-dim: #5e6178;--accent: #8b5cf6;--accent-2: #6366f1;--accent-glow: rgba(139, 92, 246, .35);--ok: #22c55e;--warn: #f59e0b;--danger: #ef4444;--info: #3b82f6;--input-bg: #f1efe6;--input-text: #1f1f1f;--shadow: 0 10px 30px rgba(0,0,0,.4)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,Roboto,sans-serif;font-size:14px;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:inherit}input,select,textarea{font:inherit;padding:9px 12px;border:1px solid var(--border);border-radius:10px;background:var(--surface);color:var(--text);transition:border-color .15s,box-shadow .15s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}button{font:inherit;padding:9px 14px;border:1px solid var(--accent);border-radius:10px;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;font-weight:600;transition:filter .15s,transform .05s}button:hover:not(:disabled){filter:brightness(1.08)}button.secondary{background:var(--surface);color:var(--text);border-color:var(--border);font-weight:500}button.secondary:hover:not(:disabled){background:var(--surface-2);filter:none}button.danger{background:linear-gradient(135deg,#ef4444,#dc2626);border-color:#dc2626}button.ghost{background:transparent;border-color:transparent;color:var(--text-muted)}button.ghost:hover{background:var(--surface-2);color:var(--text)}button:disabled{opacity:.5;cursor:not-allowed}.icon-btn{background:transparent;border:1px solid transparent;color:var(--text-muted);padding:6px 8px;border-radius:8px;font-size:14px;font-weight:500;transition:background .15s,color .15s,border-color .15s}.icon-btn:hover{background:var(--surface-2);color:var(--text);border-color:var(--border)}.icon-btn.danger-hover:hover{background:#ef444426;color:var(--danger);border-color:#ef44444d}.layout{display:grid;grid-template-columns:230px 1fr;min-height:100vh}.sidebar{background:var(--bg-2);border-right:1px solid var(--border);padding:16px 12px;display:flex;flex-direction:column;gap:2px;position:sticky;top:0;height:100vh}.sidebar .brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:17px;padding:6px 8px 16px;border-bottom:1px solid var(--border);margin-bottom:12px;color:var(--text)}.sidebar .brand .logo-mini{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:12px;box-shadow:0 4px 14px var(--accent-glow)}.sidebar a{display:flex;align-items:center;gap:10px;color:var(--text-muted);padding:10px 12px;border-radius:8px;font-weight:500;transition:background .15s,color .15s}.sidebar a .nav-icon{width:22px;text-align:center}.sidebar a.active,.sidebar a:hover{background:var(--surface);color:var(--text);text-decoration:none}.sidebar a.active{background:linear-gradient(135deg,#8b5cf62e,#6366f12e);color:var(--text)}.sidebar .spacer{flex:1}.sidebar .user{font-size:12px;color:var(--text-dim);padding:6px 10px}.sidebar .company-select{margin-bottom:14px;padding:0 4px}.sidebar .company-select .label{color:var(--text-dim);margin-bottom:4px}.sidebar .company-name{padding:8px 12px;border-radius:8px;background:var(--surface);border:1px solid var(--border);font-weight:600;color:var(--text);margin-top:4px}.main{padding:24px 28px;overflow:auto;max-width:1500px}.hamburger{display:none}@media (max-width: 900px){.layout{grid-template-columns:1fr}.sidebar{position:fixed;inset:0 auto 0 0;z-index:60;width:260px;transform:translate(-100%);transition:transform .25s ease;box-shadow:var(--shadow)}.sidebar.open{transform:translate(0)}.hamburger{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;background:var(--surface);border:1px solid var(--border);color:var(--text);position:fixed;top:12px;left:12px;z-index:50}.main{padding:64px 16px 16px}.scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:55}}.page-head{margin-bottom:20px}.page-head h1{font-size:24px;margin:0 0 4px}.page-head .muted{font-size:13px}.card{background:var(--bg-2);border:1px solid var(--border);border-radius:14px;padding:18px;margin-bottom:16px}.card h2{margin:0 0 14px;font-size:16px}.card h3{margin:16px 0 8px;font-size:14px}.flex-1{flex:1;min-width:0}.table-wrap{overflow-x:auto;margin:0 -6px}table{width:100%;border-collapse:collapse;font-size:13px}th,td{text-align:left;padding:8px 10px;border-bottom:1px solid var(--border);white-space:nowrap}th{background:var(--surface-2);font-weight:600;color:var(--text-muted);font-size:12px;letter-spacing:.2px}tr:last-child td{border-bottom:none}table.hover-rows tbody tr{transition:background .12s}table.hover-rows tbody tr:hover{background:var(--surface)}table.hover-rows tbody tr .row-actions{opacity:0;transition:opacity .15s}table.hover-rows tbody tr:hover .row-actions{opacity:1}@media (hover: none){table.hover-rows tbody tr .row-actions{opacity:1}}.actions-col{width:1%;text-align:right}.row-actions{display:inline-flex;gap:2px;justify-content:flex-end}.truncate{max-width:360px;overflow:hidden;text-overflow:ellipsis}.toolbar{display:flex;gap:8px;align-items:center;margin-bottom:14px;flex-wrap:wrap}.toolbar .spacer{flex:1}.row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.col{display:flex;flex-direction:column;gap:8px}.label{font-size:12px;color:var(--text-muted);font-weight:500}.muted{color:var(--text-muted)}.dim{color:var(--text-dim)}.danger-text{color:var(--danger)}.warn-text{color:var(--warn)}.ok-text{color:var(--ok)}.error{color:var(--danger);font-size:13px}.empty{padding:30px 20px;text-align:center;color:var(--text-muted);background:var(--surface-2);border-radius:10px;font-size:14px}.empty.big{padding:48px 20px;font-size:15px}.search{min-width:240px;flex:1;max-width:380px}.filters{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-bottom:14px}.filters .search{background:var(--surface)}.pill{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:999px;font-size:11.5px;font-weight:600;background:var(--surface-2);color:var(--text-muted);white-space:nowrap}.pill.green{background:#22c55e26;color:#4ade80}.pill.red{background:#ef444426;color:#f87171}.pill.amber{background:#f59e0b26;color:#fbbf24}.pill.blue{background:#3b82f626;color:#60a5fa}.pill.purple{background:#8b5cf626;color:#a78bfa}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100;padding:16px;animation:fade .15s ease}@keyframes fade{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-2);border:1px solid var(--border);border-radius:14px;padding:22px;width:100%;max-width:640px;max-height:90vh;overflow:auto;box-shadow:var(--shadow);animation:pop .18s ease}@keyframes pop{0%{transform:scale(.96);opacity:0}to{transform:scale(1);opacity:1}}.modal h3{margin:0 0 14px}.form-row{display:grid;grid-template-columns:180px 1fr;gap:10px;align-items:center;margin-bottom:12px}.form-row>span{color:var(--text-muted);font-size:13px}@media (max-width: 600px){.form-row{grid-template-columns:1fr;gap:4px}}.recipe-row{display:grid;grid-template-columns:1fr 110px 36px;gap:6px;margin-bottom:6px}.picker-list{display:flex;flex-direction:column;gap:4px;max-height:360px;overflow:auto}.picker-item{all:unset;cursor:pointer;display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:10px;background:var(--surface);border:1px solid var(--border);transition:background .12s,border-color .12s}.picker-item:hover{background:var(--surface-2);border-color:var(--accent)}.picker-name{font-weight:600;color:var(--text)}.picker-sub{font-size:12px;margin-top:2px}.quick-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:18px}.quick-tile{all:unset;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:8px;padding:22px 16px;background:linear-gradient(135deg,color-mix(in srgb,var(--c) 18%,var(--bg-2)) 0%,var(--bg-2) 100%);border:1px solid color-mix(in srgb,var(--c) 30%,var(--border));border-radius:14px;color:var(--text);font-weight:700;transition:transform .12s,border-color .12s,box-shadow .12s;text-align:center}.quick-tile:hover{transform:translateY(-2px);border-color:var(--c);box-shadow:0 10px 24px color-mix(in srgb,var(--c) 25%,transparent)}.quick-icon{font-size:32px}.quick-label{font-size:15px}.stat-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));margin-bottom:18px}.stat-card{background:var(--bg-2);border:1px solid var(--border);border-left:3px solid var(--c);border-radius:12px;padding:14px 16px}.stat-title{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;font-weight:600}.stat-value{font-size:26px;font-weight:800;margin-top:6px;color:var(--text)}.action-row{display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));margin-bottom:16px}.action-btn{all:unset;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;padding:14px 16px;background:var(--bg-2);border:1px solid color-mix(in srgb,var(--c) 30%,var(--border));border-radius:12px;color:var(--text);font-weight:700;transition:transform .12s,border-color .12s,background .12s}.action-btn:hover{transform:translateY(-1px);border-color:var(--c);background:color-mix(in srgb,var(--c) 10%,var(--bg-2))}.action-icon{font-size:22px}.ops-list{display:flex;flex-direction:column;gap:4px}.op-card{border:1px solid var(--border);border-radius:10px;background:var(--bg-2);transition:border-color .12s}.op-card:hover{border-color:color-mix(in srgb,var(--accent) 30%,var(--border))}.op-main{display:grid;grid-template-columns:90px 130px 1fr 130px 1fr 100px 80px;align-items:center;gap:12px;padding:10px 14px}.op-main:hover .op-actions .icon-btn{opacity:1}.op-date{font-size:12px;color:var(--text-muted)}.op-name{font-weight:600}.op-qty{text-align:right;font-variant-numeric:tabular-nums}.op-qty b{font-size:15px}.op-note{font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.op-user{font-size:12px;text-align:right}.op-actions{display:flex;gap:4px;justify-content:flex-end;align-items:center}.op-actions .icon-btn{opacity:0;transition:opacity .15s}@media (hover: none){.op-actions .icon-btn{opacity:1}}.caret{color:var(--text-muted);font-size:13px;width:14px;text-align:center}.op-children{padding:6px 14px 12px 130px;border-top:1px dashed var(--border);background:color-mix(in srgb,var(--surface-2) 50%,transparent)}.op-children-title{font-size:12px;margin:6px 0}.op-child{display:flex;justify-content:space-between;padding:4px 0;font-size:13px;border-bottom:1px dotted var(--border)}.op-child:last-child{border-bottom:none}@media (max-width: 900px){.op-main{grid-template-columns:1fr auto;grid-template-areas:"name pill" "date qty" "note actions";row-gap:4px}.op-name{grid-area:name}.op-kind{grid-area:pill}.op-date{grid-area:date}.op-qty{grid-area:qty;text-align:right}.op-note{grid-area:note}.op-user{display:none}.op-actions{grid-area:actions}.op-children{padding-left:14px}}.login-page{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;background:var(--bg);position:relative;overflow:hidden}.login-page:before,.login-page:after{content:"";position:absolute;pointer-events:none;width:600px;height:600px;border-radius:50%;filter:blur(120px);opacity:.55}.login-page:before{top:-200px;left:-150px;background:radial-gradient(circle,var(--accent) 0%,transparent 60%)}.login-page:after{bottom:-200px;left:25%;background:radial-gradient(circle,var(--accent-2) 0%,transparent 60%);opacity:.35}.login-left{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;position:relative;z-index:1}.brand-block{text-align:center}.brand-logo{width:120px;height:120px;border-radius:28px;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:44px;letter-spacing:1px;box-shadow:0 20px 60px var(--accent-glow),0 0 0 1px #ffffff14 inset;margin:0 auto 22px}.brand-name{font-size:32px;font-weight:800;color:var(--text);margin:0}.brand-sub{margin-top:10px;color:var(--text-dim);font-size:13px;font-style:italic}.login-right{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;position:relative;z-index:1;background:linear-gradient(180deg,transparent,rgba(0,0,0,.15))}.clock-block{text-align:center;margin-bottom:36px}.clock{font-size:92px;font-weight:200;color:var(--text);letter-spacing:-2px;line-height:1;display:inline-flex;align-items:flex-start}.clock .seconds{font-size:28px;color:var(--text-dim);margin-left:6px;margin-top:12px}.clock-date{margin-top:12px;color:var(--text-muted);font-size:14px;font-weight:500}.login-card{background:var(--bg-2);border:1px solid var(--border);border-radius:18px;padding:28px;width:100%;max-width:460px;box-shadow:var(--shadow)}.login-card-header{display:flex;align-items:center;gap:14px;margin-bottom:22px}.login-card-header .lock-icon{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 8px 20px var(--accent-glow)}.login-card-header h2{margin:0;font-size:17px;font-weight:700}.login-card-header .sub{font-size:12px;color:var(--text-muted);margin-top:2px}.login-input-group{margin-bottom:16px}.login-input-group .label{display:block;margin-bottom:6px;font-weight:600}.login-input{background:var(--input-bg);color:var(--input-text);border:none;padding:14px 16px;width:100%;border-radius:12px;font-size:14px}.login-input:focus{box-shadow:0 0 0 3px var(--accent-glow)}.password-wrap{position:relative}.password-wrap .eye{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:transparent;border:none;color:#6b7280;padding:6px;cursor:pointer}.login-submit{width:100%;padding:14px;border-radius:12px;background:linear-gradient(135deg,var(--accent),var(--accent-2));box-shadow:0 12px 30px var(--accent-glow);font-size:15px;font-weight:700}.welcome-card{background:var(--bg-2);border:1px solid var(--border);border-radius:18px;padding:36px;width:100%;max-width:460px;text-align:center;box-shadow:var(--shadow)}.welcome-check{width:78px;height:78px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#4ade80,#16a34a);box-shadow:0 0 40px #22c55e73;color:#fff;display:flex;align-items:center;justify-content:center;margin:0 auto 18px}.welcome-title{font-size:20px;font-weight:800;margin:0;line-height:1.3}.welcome-sub{color:var(--text-muted);font-size:13px;margin-top:6px}.theme-toggle{position:fixed;top:14px;right:14px;width:40px;height:40px;border-radius:12px;background:var(--surface);border:1px solid var(--border);color:var(--text-muted);display:flex;align-items:center;justify-content:center;z-index:10}.theme-toggle:hover{color:var(--text)}.theme-inline{display:inline-flex;align-items:center;gap:8px;justify-content:center;width:100%;margin-bottom:6px}.login-footer{position:absolute;bottom:18px;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:0 28px;font-size:12px;color:var(--text-dim);z-index:1}@media (max-width: 900px){.login-page{grid-template-columns:1fr}.login-left{padding:48px 24px 16px}.brand-logo{width:84px;height:84px;font-size:30px;border-radius:22px}.brand-name{font-size:22px}.login-right{padding:0 20px 80px}.clock{font-size:60px}.clock .seconds{font-size:20px;margin-top:8px}.login-card{padding:22px}.login-footer{flex-direction:column;gap:6px;padding:0 16px;bottom:14px}}@media (max-width: 480px){.brand-logo{width:72px;height:72px;font-size:26px}.brand-name{font-size:19px}.clock{font-size:48px}.login-card-header .lock-icon{width:38px;height:38px}.login-card{padding:18px;border-radius:14px}.welcome-card{padding:26px}}.toast-root{position:fixed;bottom:20px;right:20px;z-index:200;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{background:var(--bg-2);color:var(--text);border:1px solid var(--border);border-left:3px solid var(--ok);padding:12px 16px;border-radius:10px;box-shadow:var(--shadow);font-weight:500;font-size:13px;animation:slideIn .2s ease;pointer-events:auto;max-width:360px}.toast.error{border-left-color:var(--danger)}.toast.warn{border-left-color:var(--warn)}@keyframes slideIn{0%{transform:translate(20px);opacity:0}to{transform:translate(0);opacity:1}}@media (max-width: 600px){.toast-root{left:16px;right:16px;bottom:16px}.toast{max-width:none}}.company-chips{display:flex;flex-wrap:wrap;gap:4px}.chip{all:unset;cursor:pointer;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600;background:var(--surface-2);color:var(--text-muted);border:1px solid var(--border);transition:background .12s,color .12s,border-color .12s}.chip:hover{color:var(--text)}.chip.on{background:linear-gradient(135deg,#8b5cf640,#6366f140);color:var(--text);border-color:var(--accent)}.item-list{display:flex;flex-direction:column;gap:8px}.item-row{display:flex;align-items:center;gap:14px;padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-radius:10px;transition:border-color .12s}.item-row:hover{border-color:color-mix(in srgb,var(--accent) 30%,var(--border))}.item-info{flex:1;min-width:0;cursor:pointer}.item-title{font-size:15px;margin-bottom:4px}.item-sub{font-size:12.5px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.item-actions{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}.op-btn{all:unset;cursor:pointer;display:inline-flex;align-items:center;gap:6px;padding:7px 11px;border-radius:8px;background:var(--bg-2);border:1px solid var(--border);color:var(--text);font-size:12.5px;font-weight:600;transition:background .12s,border-color .12s,color .12s}.op-btn:hover{background:var(--surface-2);border-color:var(--accent)}.op-btn.green{border-color:#22c55e66;color:#4ade80}.op-btn.green:hover{background:#22c55e1f;color:#4ade80}.op-btn.blue{border-color:#3b82f666;color:#60a5fa}.op-btn.blue:hover{background:#3b82f61f;color:#60a5fa}.op-btn.amber{border-color:#f59e0b66;color:#fbbf24}.op-btn.amber:hover{background:#f59e0b1f;color:#fbbf24}.op-btn.red{border-color:#ef444466;color:#f87171}.op-btn.red:hover{background:#ef44441f;color:#f87171}@media (max-width: 900px){.item-row{flex-direction:column;align-items:stretch}.item-actions{justify-content:flex-start}}.recipe-row-named{display:grid;grid-template-columns:1fr 130px 36px;gap:8px;align-items:center;padding:6px 0;border-bottom:1px dashed var(--border)}.recipe-row-named:last-of-type{border-bottom:none}.recipe-name{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.picker-item.picked{border-color:var(--accent);background:linear-gradient(135deg,#8b5cf61a,#6366f11a)}.picker-check{font-size:16px;width:22px}.req:after{content:" *";color:var(--danger);font-weight:700}.field-error{color:var(--danger);font-size:12px;margin-top:4px}input.invalid,select.invalid{border-color:var(--danger);box-shadow:0 0 0 3px #ef44442e}.help-hint{background:linear-gradient(135deg,#8b5cf61a,#6366f11a);border:1px solid color-mix(in srgb,var(--accent) 30%,var(--border));border-radius:10px;padding:10px 14px;margin-bottom:16px;color:var(--text-muted);font-size:13px;display:flex;align-items:flex-start;gap:10px}.help-hint .help-icon{font-size:16px;flex-shrink:0}.help-hint b{color:var(--text)}.preview-box{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:12px 14px;margin-bottom:14px;font-size:13px}.preview-title{font-weight:700;margin-bottom:8px;color:var(--text)}.preview-sub{margin:6px 0 4px;font-size:12px}.preview-line{display:flex;justify-content:space-between;gap:12px;padding:3px 0;border-bottom:1px dotted var(--border)}.preview-line:last-child{border-bottom:none}.preview-line.bad{color:var(--danger)}.preview-warn{margin-top:8px;padding:8px 10px;border-radius:8px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#f87171;font-size:12.5px}.type-grid{display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));margin-bottom:14px}.type-card{all:unset;cursor:pointer;padding:14px;border-radius:12px;background:var(--surface);border:2px solid var(--border);text-align:left;transition:border-color .12s,background .12s,transform .05s}.type-card:hover{border-color:color-mix(in srgb,var(--accent) 40%,var(--border))}.type-card.on{border-color:var(--accent);background:linear-gradient(135deg,#8b5cf61f,#6366f11a)}.type-card .type-icon{font-size:28px;margin-bottom:6px}.type-card .type-title{font-weight:700;font-size:14px;margin-bottom:4px;color:var(--text)}.type-card .type-desc{font-size:12px;color:var(--text-muted);line-height:1.4}.type-card .type-actions{font-size:11px;margin-top:8px;padding-top:8px;border-top:1px dashed var(--border)}.product-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.product-tile{all:unset;box-sizing:border-box;cursor:pointer;display:flex;flex-direction:column;gap:8px;padding:12px;border-radius:14px;background:var(--surface);border:1px solid var(--border);border-top:3px solid var(--border);text-align:center;transition:border-color .12s,transform .06s,box-shadow .12s}.product-tile:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:color-mix(in srgb,var(--accent) 45%,var(--border))}.product-tile.danger{border-top-color:var(--danger)}.product-tile.warn{border-top-color:var(--warn)}.product-tile.ok{border-top-color:var(--ok)}.product-mockup{width:100%;aspect-ratio:1 / 1;display:flex;align-items:center;justify-content:center;background:var(--bg-2);border-radius:10px;overflow:hidden}.product-mockup img{max-width:100%;max-height:100%;object-fit:contain}.product-mockup-ph{font-size:42px;opacity:.45}.product-tile-name{font-weight:700;font-size:14px;color:var(--text);line-height:1.25}.product-tile-sub{font-size:12px;color:var(--text-muted);display:flex;gap:6px;align-items:center;justify-content:center;flex-wrap:wrap}.product-tile.add{border-style:dashed;border-top-width:1px;align-items:center;justify-content:center;color:var(--text-muted);min-height:190px}.product-tile.add:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}.product-add-plus{font-size:50px;font-weight:300;line-height:1}.product-detail-head{display:flex;gap:16px;align-items:flex-start}.product-mockup.lg{width:120px;height:120px;flex:0 0 120px;aspect-ratio:auto}.tree-placeholder{margin:14px 0 0;padding:28px 16px;border:1px dashed var(--border);border-radius:12px;text-align:center;color:var(--text-muted);font-size:14px;background:var(--bg-2)}.product-mockup{position:relative}.mockup-edit,.mockup-remove{position:absolute;cursor:pointer;width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;line-height:1;border:1px solid var(--border);background:var(--surface);color:var(--text)}.mockup-edit{right:4px;bottom:4px}.mockup-edit:hover{border-color:var(--accent)}.mockup-remove{right:4px;top:4px;font-size:16px;color:var(--danger)}.mockup-remove:hover{background:var(--danger);color:#fff;border-color:var(--danger)}.modal.tree-modal{max-width:940px;width:94vw}.tree-section-title{font-weight:700;font-size:14px;margin:18px 0 8px}.tree-wrap{border:1px solid var(--border);border-radius:12px;overflow:hidden;background:var(--bg-2)}.tree-toolbar{display:flex;align-items:center;gap:8px;padding:8px 10px;border-bottom:1px solid var(--border)}.tree-canvas{position:relative;height:440px;overflow:hidden;cursor:grab;background:radial-gradient(circle,color-mix(in srgb,var(--border) 60%,transparent) 1px,transparent 1px);background-size:22px 22px}.tree-canvas:active{cursor:grabbing}.tree-pan{position:absolute;top:28px;left:0;right:0;display:flex;justify-content:center;transform-origin:top center;will-change:transform}.tree-hint{font-size:11px;padding:6px 10px;border-top:1px solid var(--border)}.tree-node-box-wrap{display:flex;justify-content:center}.tree-node-box{position:relative;width:150px;box-sizing:border-box;background:var(--surface);border:1px solid var(--border);border-top:3px solid var(--accent-2);border-radius:12px;padding:10px;display:flex;flex-direction:column;align-items:center;gap:6px;box-shadow:var(--shadow)}.tree-node-box.is-product{border-top-color:var(--accent)}.tree-node-img{width:64px;height:64px;object-fit:contain;border-radius:8px;background:var(--bg-2)}.tree-node-img.ph{display:flex;align-items:center;justify-content:center;font-size:30px;opacity:.5}.tree-node-name{font-weight:700;font-size:13px;text-align:center;line-height:1.2;word-break:break-word}.tree-node-meta{display:flex;gap:6px;align-items:center;flex-wrap:wrap;justify-content:center;font-size:11.5px}.tree-ops{display:flex;flex-direction:column;gap:4px;width:100%;margin-top:2px}.op-chip{all:unset;cursor:pointer;box-sizing:border-box;font-size:11px;padding:3px 8px;border-radius:999px;background:color-mix(in srgb,var(--accent) 14%,transparent);border:1px solid color-mix(in srgb,var(--accent) 40%,var(--border));color:var(--text);text-align:center}.op-chip.on,.op-chip:hover{background:color-mix(in srgb,var(--accent) 26%,transparent)}.op-detail{font-size:11px;background:var(--bg-2);border-radius:8px;padding:6px 8px;width:100%;line-height:1.4}.op-detail-actions{display:flex;gap:6px;margin-top:6px}.op-detail-actions button{all:unset;cursor:pointer;font-size:11px;padding:2px 8px;border-radius:6px;border:1px solid var(--border);background:var(--surface);color:var(--text)}.op-detail-actions button:hover{border-color:var(--accent)}.op-detail-actions button.danger:hover{border-color:var(--danger);color:var(--danger)}.op-add{all:unset;cursor:pointer;box-sizing:border-box;width:100%;text-align:center;font-size:11px;padding:3px 8px;border-radius:999px;margin-top:2px;border:1px dashed var(--border);color:var(--text-muted)}.op-add:hover{border-color:var(--accent);color:var(--accent)}.tree-node-actions{display:flex;flex-wrap:wrap;gap:4px;width:100%}.tree-node-actions .op-add{width:auto;flex:1 1 auto}.tree-toggle{position:absolute;bottom:-12px;left:50%;transform:translate(-50%);width:22px;height:22px;border-radius:50%;cursor:pointer;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:15px;line-height:1;display:flex;align-items:center;justify-content:center;z-index:2}.tree-toggle:hover{border-color:var(--accent)}.tree-cyclic{position:absolute;top:-10px;right:-8px;font-size:14px}.tree-node-body{display:flex;flex-direction:column;align-items:center;gap:6px;width:100%}.org-tree.horizontal .tree-node-box{flex-direction:row;align-items:center;gap:10px;width:auto;min-width:150px;max-width:250px;padding:8px 12px}.org-tree.horizontal .tree-node-img{width:42px;height:42px}.org-tree.horizontal .tree-node-img.ph{font-size:22px}.org-tree.horizontal .tree-node-body{align-items:flex-start;width:auto;gap:4px}.org-tree.horizontal .tree-node-name{text-align:left}.org-tree.horizontal .tree-node-meta{justify-content:flex-start}.org-tree.horizontal .tree-ops{align-items:flex-start}.org-tree{display:inline-flex;justify-content:center}.org-tree,.org-tree ul{list-style:none;margin:0;padding:0}.org-tree ul{display:flex;padding-top:26px;position:relative}.org-tree li{display:flex;flex-direction:column;align-items:center;position:relative;padding:26px 12px 0}.org-tree li:before,.org-tree li:after{content:"";position:absolute;top:0;right:50%;border-top:2px solid var(--border);width:50%;height:26px}.org-tree li:after{right:auto;left:50%;border-left:2px solid var(--border)}.org-tree li:only-child:before,.org-tree li:only-child:after{display:none}.org-tree li:only-child{padding-top:0}.org-tree li:first-child:before,.org-tree li:last-child:after{border:0 none}.org-tree li:last-child:before{border-right:2px solid var(--border)}.org-tree ul:before{content:"";position:absolute;top:0;left:50%;border-left:2px solid var(--border);width:0;height:26px}.org-tree>li{padding-top:0}.org-tree>li:before,.org-tree>li:after{display:none}.org-tree.horizontal{flex-direction:column;align-items:flex-start}.org-tree.horizontal ul{flex-direction:column;padding-top:0;padding-left:30px}.org-tree.horizontal li{flex-direction:row;align-items:center;padding:5px 0 5px 30px}.org-tree.horizontal li:before,.org-tree.horizontal li:after{top:0;left:0;right:auto;width:30px;height:50%;border-top:0 none;border-left:2px solid var(--border)}.org-tree.horizontal li:after{top:50%;border-top:2px solid var(--border)}.org-tree.horizontal li:only-child:before,.org-tree.horizontal li:only-child:after{display:none}.org-tree.horizontal li:only-child{padding-left:0}.org-tree.horizontal li:first-child:before{border:0 none}.org-tree.horizontal li:last-child:after{border:0 none}.org-tree.horizontal li:last-child:before{border-bottom:2px solid var(--border)}.org-tree.horizontal ul:before{top:50%;left:0;width:30px;height:0;border-left:0 none;border-top:2px solid var(--border)}.org-tree.horizontal>li{padding-left:0}.org-tree.horizontal .tree-toggle{top:auto;right:auto;bottom:-11px;left:50%;transform:translate(-50%)}.batch-toggle{display:flex;align-items:center;gap:0;margin-bottom:10px;flex-wrap:wrap}.seg{all:unset;cursor:pointer;padding:6px 12px;background:var(--surface);border:1px solid var(--border);color:var(--text-muted);font-size:12.5px;font-weight:600;transition:background .12s,color .12s}.seg:first-of-type{border-radius:8px 0 0 8px}.seg:nth-of-type(2){border-radius:0 8px 8px 0;border-left:0}.seg.on{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;border-color:var(--accent)}.batch-size{margin-left:12px;font-size:12.5px;color:var(--text-muted);display:inline-flex;align-items:center;gap:4px}.plan-grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(360px,1fr))}.plan-card{background:var(--bg-2);border:1px solid var(--border);border-left:4px solid var(--border);border-radius:14px;padding:16px}.plan-card.danger{border-left-color:var(--danger)}.plan-card.warn{border-left-color:var(--warn)}.plan-card.ok{border-left-color:var(--ok)}.plan-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:12px}.plan-card-title{font-size:16px;font-weight:700;color:var(--text)}.days-badge{text-align:center;padding:6px 10px;border-radius:10px;background:var(--surface-2);min-width:70px}.days-badge.danger{background:#ef44441f;color:#f87171}.days-badge.warn{background:#f59e0b1f;color:#fbbf24}.days-badge.ok{background:#22c55e1f;color:#4ade80}.days-num{font-size:22px;font-weight:800;line-height:1}.days-lbl{font-size:10px;margin-top:4px;opacity:.9;line-height:1.1}.plan-target{padding:10px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:12px}.seg-group{display:inline-flex}.seg-group .seg:first-of-type{border-radius:8px 0 0 8px}.seg-group .seg:last-of-type{border-radius:0 8px 8px 0;border-left:0}.seg-group .seg:not(:first-of-type):not(:last-of-type){border-left:0}.plan-components{display:flex;flex-direction:column;gap:8px}.plan-comp{padding:4px 0}.plan-comp-head{display:flex;justify-content:space-between;font-size:13px;margin-bottom:4px}.plan-bar{width:100%;height:6px;background:var(--surface-2);border-radius:3px;overflow:hidden}.plan-bar-fill{height:100%;background:var(--accent);transition:width .3s ease}.plan-bar-fill.danger{background:var(--danger)}.plan-bar-fill.warn{background:var(--warn)}.plan-bar-fill.ok{background:var(--ok)}.plan-comp-sub{font-size:11.5px;margin-top:3px}.alert-bar{background:linear-gradient(135deg,#ef44442e,#dc26261a);border:1px solid rgba(239,68,68,.35);color:#f87171;padding:10px 14px;border-radius:10px;margin-bottom:14px;font-weight:600;font-size:13.5px}.print-page{padding:20px;max-width:800px;margin:0 auto}.print-doc{background:#fff;color:#000;padding:40px 48px;border-radius:6px;box-shadow:var(--shadow)}.print-head{display:flex;justify-content:space-between;align-items:flex-start;border-bottom:2px solid #000;padding-bottom:12px;margin-bottom:20px}.print-table{width:100%;border-collapse:collapse;font-size:14px}.print-table th,.print-table td{border:1px solid #444;padding:8px 10px;text-align:left;color:#000;background:transparent;white-space:normal}.print-table th{background:#f3f4f6;font-weight:700}.print-signatures{display:flex;gap:60px;margin-top:60px}.sign{flex:1}.sign-line{border-bottom:1px solid #000;height:1px;margin-bottom:8px}.sign-label{font-size:12px;color:#444}.print-footer{margin-top:40px;font-size:11px}@media print{body,html,#root{background:#fff!important}.layout,.sidebar,.hamburger,.theme-toggle,.no-print{display:none!important}.main{padding:0!important;max-width:none!important}.print-page{padding:0;max-width:none}.print-doc{box-shadow:none;border-radius:0;padding:0}}@media (max-width: 1100px){.item-actions{gap:4px}.op-btn{padding:6px 8px;font-size:12px}.op-btn span:last-child{display:inline}}@media (max-width: 720px){.page-head h1{font-size:20px}.stat-grid{grid-template-columns:repeat(2,1fr)}.stat-value{font-size:22px}.quick-grid{grid-template-columns:repeat(2,1fr)}.quick-tile{padding:16px 10px}.quick-icon{font-size:26px}.action-row{grid-template-columns:repeat(2,1fr)}.type-grid,.plan-grid{grid-template-columns:1fr}.filters{flex-direction:column;align-items:stretch}.filters .row{justify-content:space-between}.search{max-width:none}.toolbar{gap:6px}.modal{padding:16px;border-radius:12px}.modal h3{font-size:15px}table{font-size:12.5px}th,td{padding:6px 8px}.recipe-row-named{grid-template-columns:1fr 90px 32px}.item-row{padding:10px}.item-title{font-size:14px}.item-actions{width:100%;gap:6px}.op-btn{flex:1 1 calc(50% - 6px);justify-content:center}}@media (max-width: 480px){.stat-grid,.quick-grid,.form-row{grid-template-columns:1fr}.batch-toggle{flex-direction:column;align-items:stretch;gap:6px}.batch-size{margin-left:0}.seg-group{display:flex;width:100%}.seg-group .seg{flex:1;text-align:center}}.prod-grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));margin-bottom:16px}.prod-card{background:var(--bg-2);border:1px solid var(--border);border-left:4px solid var(--border);border-radius:14px;padding:16px;display:flex;flex-direction:column;gap:12px}.prod-card.danger{border-left-color:var(--danger)}.prod-card.warn{border-left-color:var(--warn)}.prod-card.ok{border-left-color:var(--ok)}.prod-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}.prod-card-title{font-size:17px;font-weight:800;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.prod-stock{display:flex;align-items:baseline;gap:8px}.prod-stock-num{font-size:32px;font-weight:800;color:var(--text);line-height:1}.prod-stock-lbl{color:var(--text-muted);font-size:13px}.prod-today{display:flex;gap:6px;font-size:13px;flex-wrap:wrap}.prod-today-item{white-space:nowrap}.prod-warn{padding:8px 10px;border-radius:8px;font-size:12.5px}.prod-warn.danger{background:#ef44441f;color:#f87171}.prod-warn.warn{background:#f59e0b1f;color:#fbbf24}.prod-actions{display:flex;gap:6px;flex-wrap:wrap}.prod-actions .op-btn{flex:1 1 auto;justify-content:center}@media (max-width: 600px){.prod-grid{grid-template-columns:1fr}.prod-stock-num{font-size:26px}}.lead-time-box{background:linear-gradient(135deg,#3b82f614,#6366f10f);border:1px solid color-mix(in srgb,var(--info) 30%,var(--border));border-radius:10px;padding:12px 14px;margin-bottom:12px}.lead-time-head{font-weight:700;margin-bottom:4px;color:var(--text);font-size:14px}.item-row.danger{border-left:4px solid var(--danger)}.item-row.warn{border-left:4px solid var(--warn)}.item-row.ok{border-left:4px solid var(--ok)}.days-pill{display:inline-block;padding:1px 8px;border-radius:999px;font-size:12px;font-weight:600;margin-left:4px}.days-pill.danger{background:#ef444426;color:#f87171}.days-pill.warn{background:#f59e0b26;color:#fbbf24}.days-pill.ok{background:#22c55e26;color:#4ade80}.audit-alert td{background:#ef444414!important}.audit-alert:hover td{background:#ef444424!important}.drp{position:relative;display:inline-block}.drp-btn{all:unset;cursor:pointer;display:inline-flex;align-items:center;gap:10px;padding:8px 14px;background:var(--surface);border:1px solid var(--border);border-radius:10px;color:var(--text);font-weight:500;transition:border-color .12s,background .12s}.drp-btn:hover,.drp-btn.open{border-color:var(--accent)}.drp-icon{font-size:16px}.drp-label b{font-size:13px}.drp-caret{font-size:9px;color:var(--text-muted)}.drp-pop{position:absolute;top:calc(100% + 6px);left:0;display:flex;gap:0;background:var(--bg-2);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);z-index:80;overflow:hidden;max-width:calc(100vw - 32px)}.drp-pop.right{left:auto;right:0}.drp-presets{background:var(--surface);padding:12px;border-right:1px solid var(--border);min-width:130px;display:flex;flex-direction:column;gap:4px}.drp-presets-title{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;margin-bottom:6px;padding:0 6px}.drp-preset{all:unset;cursor:pointer;padding:8px 12px;border-radius:8px;color:var(--text-muted);font-size:13px;transition:background .12s,color .12s}.drp-preset:hover{background:var(--surface-2);color:var(--text)}.drp-preset.on{background:linear-gradient(135deg,#8b5cf62e,#6366f12e);color:var(--text);font-weight:600}.drp-cal{padding:14px 16px;min-width:540px}.drp-cal-head{display:flex;align-items:center;gap:16px;margin-bottom:12px}.drp-nav{all:unset;cursor:pointer;width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:18px;border:1px solid var(--border);background:var(--surface)}.drp-nav:hover{color:var(--text);border-color:var(--accent)}.drp-months{display:flex;gap:16px;flex:1}.drp-month-title{flex:1;text-align:center;font-weight:700;font-size:14px;color:var(--text)}.drp-grids{display:flex;gap:16px}.drp-grid{flex:1;min-width:0}.drp-wdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:4px;font-size:11px;color:var(--text-dim);text-align:center}.drp-days{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.drp-day{all:unset;cursor:pointer;aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:500;color:var(--text);border-radius:6px;transition:background .08s}.drp-day:hover:not(.off){background:var(--surface-2)}.drp-day.in{background:#6366f133;color:var(--text);border-radius:0}.drp-day.edge{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;font-weight:700;border-radius:8px}.drp-day.today{box-shadow:inset 0 0 0 1px var(--accent)}.drp-day.off{color:var(--text-dim);opacity:.4;cursor:not-allowed}@media (max-width: 720px){.drp-pop{right:auto;left:0;flex-direction:column}.drp-presets{border-right:none;border-bottom:1px solid var(--border);flex-direction:row;flex-wrap:wrap;min-width:0}.drp-preset{flex:1;text-align:center}.drp-cal{min-width:0;width:min(86vw,460px);padding:12px}.drp-grids{flex-direction:column}.drp-months{flex-direction:column;gap:0}}.collapsible{cursor:pointer;display:flex;align-items:center;gap:8px;-webkit-user-select:none;user-select:none;transition:color .12s}.collapsible:hover{color:var(--accent)}.collapse-caret{font-size:12px;color:var(--text-muted);display:inline-block;width:14px}.stat-sub{font-size:11px;color:var(--text-dim);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.audit-link-card{cursor:pointer;transition:border-color .12s,background .12s}.audit-link-card:hover{border-color:var(--accent);background:var(--surface);text-decoration:none}.tabs-row{margin-bottom:14px}.prod-card-head.clickable{cursor:pointer}.prod-card-head.clickable:hover .prod-card-title{color:var(--accent)}.cl-month{margin-bottom:24px}.cl-month-title{font-weight:700;color:var(--text);margin:6px 0 10px;font-size:16px}.cl-list{display:flex;flex-direction:column;gap:10px;position:relative;padding-left:18px}.cl-list:before{content:"";position:absolute;left:6px;top:6px;bottom:6px;width:1px;background:var(--border)}.cl-card{position:relative;background:var(--bg-2);border:1px solid var(--border);border-radius:12px;padding:14px 18px;transition:border-color .12s}.cl-card:hover{border-color:color-mix(in srgb,var(--accent) 35%,var(--border))}.cl-dot{position:absolute;left:-16px;top:22px;width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 2px var(--bg)}.cl-row1{display:flex;align-items:center;gap:8px;margin-bottom:6px;flex-wrap:wrap}.cl-title{font-size:15px;font-weight:700;color:var(--text);margin-bottom:4px}.cl-desc{color:var(--text-muted);font-size:13.5px;line-height:1.5}.cl-date{font-size:11px}.cl-tag{display:inline-block;padding:2px 8px;background:var(--surface-2);color:var(--text-muted);border-radius:6px;font-size:11.5px;font-weight:600}.cl-pill{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:6px;font-size:11.5px;font-weight:700}.cl-pill.k-new{background:#8b5cf62e;color:#a78bfa}.cl-pill.k-fix{background:#22c55e2e;color:#4ade80}.cl-pill.k-impr{background:#3b82f62e;color:#60a5fa}.cl-pill.k-gen{background:#f59e0b2e;color:#fbbf24}.nav-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:10px;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;font-size:11px;font-weight:800;box-shadow:0 2px 8px #ef444466}.cl-card.fresh{border-color:var(--accent);background:linear-gradient(135deg,rgba(139,92,246,.08),var(--bg-2) 70%);box-shadow:0 0 0 2px #8b5cf626}.cl-card.fresh .cl-dot{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 0 0 2px var(--bg),0 0 12px #ef444480;animation:cl-pulse 1.8s ease-in-out infinite}@keyframes cl-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.4)}}.cl-fresh-pill{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;font-size:10px;font-weight:800;padding:2px 8px;border-radius:6px;letter-spacing:.5px}:root{--ease: cubic-bezier(.4, 0, .2, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--dur-fast: .15s;--dur-base: .25s;--dur-slow: .4s}button,a,.seg,.op-btn,.icon-btn,.item-row,.prod-card,.plan-card,.stat-card,.quick-tile,.action-btn,.type-card,.chip,.picker-item,.cl-card,.nav-badge,.pill,input,select,textarea,.drp-btn,.drp-day{transition-timing-function:var(--ease);transition-duration:var(--dur-base)}.sidebar{transition:transform .3s var(--ease)}.scrim{animation:fade .2s var(--ease)}.modal{animation:pop .28s var(--ease-spring)}.modal-backdrop{animation:fade .18s var(--ease)}.prod-card,.plan-card,.item-row,.stat-card,.cl-card{transition:transform var(--dur-base) var(--ease),border-color var(--dur-base) var(--ease),box-shadow var(--dur-base) var(--ease)}.prod-card:hover,.plan-card:hover,.cl-card:hover,.item-row:hover{transform:translateY(-1px)}.quick-tile:hover,.action-btn:hover,.type-card:hover{transform:translateY(-2px)}button{transition:filter var(--dur-fast) var(--ease),transform 80ms var(--ease)}button:active:not(:disabled){transform:translateY(1px)}.main>*{animation:pageIn .35s var(--ease)}@keyframes pageIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.sidebar a{transition:background var(--dur-base) var(--ease),color var(--dur-base) var(--ease),padding-left var(--dur-fast) var(--ease)}.sidebar a:hover{padding-left:16px}.toast{animation:slideIn .22s var(--ease-spring)}.nav-badge-mini{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;font-size:10.5px;font-weight:700;box-shadow:0 2px 8px var(--accent-glow);animation:pulseSoft 2.4s var(--ease) infinite}@keyframes pulseSoft{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.techop-grid{display:grid;grid-template-columns:1fr 1.2fr 1fr;gap:14px;margin:12px 0 16px;padding:14px;background:var(--surface);border:1px solid var(--border);border-radius:12px}.techop-col{display:flex;flex-direction:column;gap:8px}.techop-col-title{font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;text-align:center;padding-bottom:6px;border-bottom:1px dashed var(--border)}.techop-center{align-items:stretch;justify-content:flex-start}@media (max-width: 700px){.techop-grid{grid-template-columns:1fr}}.snapshot-item{font-size:13px;padding:8px 12px}.snapshot-item.on{background:linear-gradient(135deg,#8b5cf62e,#6366f12e);border-color:var(--accent);color:var(--text)}.item-row.is-product{flex-direction:row-reverse}.item-row.is-product .item-info{text-align:right}.item-row.is-product .item-sub{justify-content:flex-end}@media (max-width: 720px){.item-row.is-product{flex-direction:column}.item-row.is-product .item-info{text-align:left}.item-row.is-product .item-sub{justify-content:flex-start}}.shortage-row.danger td{background:#ef444414}.shortage-row.warn td{background:#f59e0b14}.shortage-row.ok td{background:#22c55e12}.shortage-row.danger td:first-child{box-shadow:inset 3px 0 #ef4444}.shortage-row.warn td:first-child{box-shadow:inset 3px 0 #f59e0b}.shortage-row.ok td:first-child{box-shadow:inset 3px 0 #22c55e}
