@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";.splash-screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:var(--bg-dark);color:var(--text-primary);transition:opacity .5s ease-in-out}.splash-screen.fade-out{opacity:0;pointer-events:none}.splash-content{display:flex;flex-direction:column;align-items:center;gap:1.5rem;animation:splashScaleUp .8s cubic-bezier(.16,1,.3,1) forwards}@keyframes splashScaleUp{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.splash-logo-container{width:120px;height:120px;border-radius:20%;background:var(--bg-card);box-shadow:0 8px 32px color-mix(in srgb,var(--accent-blue) 40%,transparent);display:flex;align-items:center;justify-content:center;padding:1rem}.splash-logo{width:100%;height:100%;object-fit:contain}.splash-title{font-size:1.5rem;font-weight:700;letter-spacing:-.02em;color:var(--accent-blue)}.splash-loader{width:240px;height:4px;background:var(--bg-card);border-radius:4px;overflow:hidden;position:relative;margin-top:1rem}.splash-loader:after{content:"";position:absolute;top:0;left:0;height:100%;width:30%;background:var(--accent-blue);border-radius:4px;animation:loaderProgress 1.5s infinite ease-in-out}@keyframes loaderProgress{0%{left:-30%}to{left:100%}}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;overflow:hidden}html,body{background:#0b0f19;color:#f8fafc}html[data-theme=light],body[data-theme=light]{background:#f8fafc;color:#0f172a}:root{--bg-dark: #f8fafc;--bg-card: #ffffff;--bg-hover: #f1f5f9;--text-primary: #0f172a;--text-secondary: #64748b;--accent-blue: #4f46e5;--accent-green: #10b981;--accent-red: #ef4444;--accent-yellow: #f59e0b;--border-color: #e2e8f0;--bg-accent: #eef2ff;--bg-accent-hover: #e0e7ff;--bg-muted: #f1f5f9;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05)}.app.theme-dark{--bg-dark: #0B0F19;--bg-card: #151C2C;--bg-hover: #1E293B;--text-primary: #f8fafc;--text-secondary: #94a3b8;--accent-blue: #6366f1;--accent-green: #10b981;--accent-red: #ef4444;--accent-yellow: #f59e0b;--border-color: #2a3441;--bg-accent: #1e293b;--bg-accent-hover: #334155;--bg-muted: #0f172a;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .5);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4), 0 2px 4px -1px rgba(0, 0, 0, .2);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5), 0 4px 6px -2px rgba(0, 0, 0, .3)}.app.theme-light{--bg-dark: #f8fafc;--bg-card: #ffffff;--bg-hover: #f1f5f9;--text-primary: #0f172a;--text-secondary: #64748b;--accent-blue: #4f46e5;--accent-green: #10b981;--accent-red: #ef4444;--accent-yellow: #f59e0b;--border-color: #e2e8f0;--bg-accent: #eef2ff;--bg-accent-hover: #e0e7ff;--bg-muted: #f1f5f9;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05)}button,.truck-card,.case-card,.plan-card,.placed-card,input{transition:all .25s cubic-bezier(.4,0,.2,1)}button:active:not(:disabled){transform:scale(.97)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.app{height:100%;min-height:100vh;display:flex;flex-direction:column;overflow:hidden;color:var(--text-primary)}.app.loading,.app.error{align-items:center;justify-content:center;gap:1rem}.spinner{width:48px;height:48px;border:3px solid var(--border-color);border-top-color:var(--accent-blue);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error{text-align:center}.error .hint{color:var(--text-secondary);font-size:.875rem;margin-top:.5rem}.app-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;background:var(--bg-card);border-bottom:1px solid var(--border-color)}.app-header h1{font-size:1.25rem;font-weight:600}.header-actions{display:flex;gap:.5rem}.header-actions button{padding:.5rem .8rem;border:1px solid transparent;border-radius:.5rem;background:var(--bg-accent);color:var(--text-primary);cursor:pointer;font-size:.875rem;font-weight:500;box-shadow:var(--shadow-sm)}.header-actions button:hover:not(:disabled){background:var(--bg-accent-hover);border-color:var(--accent-blue);box-shadow:var(--shadow-md);transform:translateY(-1px)}.header-actions button:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.app-main{flex:1;display:grid;grid-template-columns:300px 1fr 340px;gap:1px;background:var(--border-color);min-height:0;overflow:hidden}.sidebar{background:var(--bg-card);padding:1rem;overflow-y:auto;min-height:0}.sidebar h3{font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin-bottom:.75rem}.main-view{position:relative;background:var(--bg-muted);min-height:0;overflow:hidden}.view-controls{position:absolute;top:.75rem;left:.75rem;z-index:20;display:flex;gap:.4rem;flex-wrap:wrap;max-width:min(100% - 1.5rem,680px)}.view-controls button{padding:.5rem .75rem;border:1px solid rgba(255,255,255,.1);border-radius:.5rem;background:#0f172aa6;color:#f1f5f9;cursor:pointer;font-size:.75rem;font-weight:500;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:var(--shadow-sm)}.view-controls button.selected,.view-controls button:hover:not(:disabled){border-color:var(--accent-blue);background:#4f46e5d9;color:#fff;box-shadow:0 0 12px #4f46e566}.view-controls button:disabled{opacity:.45;cursor:not-allowed}.view-hint{align-self:center;font-size:.7rem;color:var(--text-secondary);background:#0f172ab3;border:1px solid var(--border-color);border-radius:.375rem;padding:.32rem .45rem}.item-actions-menu{position:fixed;z-index:1200;display:flex;flex-direction:column;gap:.35rem;min-width:160px;padding:.45rem;border:1px solid var(--border-color);border-radius:.45rem;background:#0f172af2;box-shadow:0 12px 24px #00000059}.item-actions-menu button{width:100%;text-align:left;padding:.45rem .55rem;border:1px solid var(--border-color);border-radius:.35rem;background:var(--bg-card);color:var(--text-primary);cursor:pointer;font-size:.78rem}.item-actions-menu button:hover{border-color:var(--accent-blue)}.metrics-overlay{position:absolute;top:.75rem;right:.75rem;z-index:25;width:min(320px,calc(100% - 1.5rem));max-height:calc(100% - 1.5rem);overflow-y:auto}.metrics-overlay.collapsed{width:auto;max-height:none;overflow:visible}.metrics-overlay .metrics-panel{margin-top:0;padding:1rem;border-top:none;border:1px solid rgba(255,255,255,.08);border-radius:1rem;background:#0f172abf;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:var(--shadow-lg);color:#f1f5f9}.metrics-overlay .metrics-panel h3,.metrics-overlay .metrics-panel .metric .label,.metrics-overlay .metrics-panel h4{color:#cbd5e1}.metrics-overlay.collapsed .metrics-panel{width:auto}.app.theme-light .metrics-overlay .metrics-panel{background:#f8fafceb}.truck-view-3d{width:100%;height:100%;min-height:0}.truck-view-3d.empty{display:flex;align-items:center;justify-content:center;color:var(--text-secondary)}.truck-view-3d.error{display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--accent-red);padding:2rem;text-align:center}.truck-list{display:flex;flex-direction:column;gap:.5rem}.truck-card{padding:1rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:.75rem;text-align:left;color:var(--text-primary);cursor:pointer;box-shadow:var(--shadow-sm)}.truck-card:hover{border-color:var(--accent-blue);box-shadow:var(--shadow-md);transform:translateY(-2px)}.truck-card.selected{border-color:var(--accent-blue);background:var(--bg-accent);box-shadow:0 0 0 1px var(--accent-blue),var(--shadow-sm)}.truck-name{font-weight:500;margin-bottom:.25rem;color:var(--text-primary)}.truck-dims,.truck-capacity{font-size:.75rem;color:var(--text-secondary)}.case-list{display:flex;flex-direction:column;gap:.5rem;max-height:300px;overflow-y:auto}.case-card{padding:1rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:.75rem;display:flex;flex-direction:column;gap:.65rem;text-align:left;color:var(--text-primary);cursor:default;box-shadow:var(--shadow-sm)}.case-card:hover{border-color:var(--accent-blue);box-shadow:var(--shadow-md);transform:translateY(-2px)}.case-card.selected{border-color:var(--accent-green);background:color-mix(in srgb,var(--accent-green) 10%,transparent);box-shadow:0 0 0 1px var(--accent-green),var(--shadow-sm)}.case-card-main{width:100%;border:none;background:transparent;color:inherit;text-align:left;cursor:pointer;padding:0}.case-card-main:focus-visible{outline:2px solid var(--accent-blue);outline-offset:3px;border-radius:.45rem}.case-card-actions{display:flex;gap:.4rem}.case-action-btn{flex:1;min-height:36px;border:1px solid var(--border-color);border-radius:.45rem;font-size:.74rem;font-weight:600;cursor:pointer}.case-action-add{background:var(--accent-green);border-color:transparent;color:#fff}.case-action-edit{background:var(--bg-accent);color:var(--text-primary)}.case-action-edit:hover:not(:disabled){border-color:var(--accent-blue);background:var(--bg-accent-hover)}.case-edit-dialog{width:clamp(320px,94vw,820px);max-height:88vh}.case-name{font-weight:500;font-size:.875rem;color:var(--text-primary)}.case-info{font-size:.75rem;color:var(--text-secondary);margin-top:.25rem}.case-tags{display:flex;gap:.25rem;margin-top:.5rem}.tag{font-size:.625rem;padding:.125rem .375rem;border-radius:.25rem;text-transform:uppercase}.tag.no-stack{background:var(--accent-red);color:#fff}.tag.upright{background:var(--accent-yellow);color:#000}.tag.container{background:var(--accent-blue, #3b82f6);color:#fff}.placement-controls{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.placement-controls h4{font-size:.875rem;margin-bottom:.75rem}.position-inputs{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;margin-bottom:.75rem}.position-inputs label{display:flex;flex-direction:column;gap:.25rem;font-size:.75rem;color:var(--text-secondary);min-width:0}.position-inputs label small{font-size:.66rem;color:var(--text-secondary)}.position-inputs label.toggle-input{flex-direction:row;align-items:center;min-width:0}.position-inputs input:not([type=checkbox]){width:100%;min-width:0;padding:.6rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:.5rem;color:var(--text-primary);font-size:.875rem;transition:border-color .2s,box-shadow .2s}.position-inputs input:not([type=checkbox]):focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent-blue) 30%,transparent)}.yaw-selector{margin-bottom:.75rem}.yaw-selector label{font-size:.75rem;color:var(--text-secondary);display:block;margin-bottom:.25rem}.yaw-buttons{display:flex;gap:.25rem}.yaw-buttons button{flex:1;padding:.5rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:.375rem;color:var(--text-primary);cursor:pointer;font-size:.75rem}.yaw-buttons button:hover:not(:disabled){border-color:var(--accent-blue)}.yaw-buttons button.selected{background:var(--accent-blue);border-color:var(--accent-blue)}.yaw-buttons button:disabled{opacity:.3;cursor:not-allowed}.place-button{width:100%;padding:.875rem;background:var(--accent-green);border:none;border-radius:.5rem;color:#fff;font-weight:600;font-size:.95rem;cursor:pointer;box-shadow:0 4px 12px color-mix(in srgb,var(--accent-green) 40%,transparent)}.place-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px color-mix(in srgb,var(--accent-green) 60%,transparent)}.danger-button{width:100%;margin-top:.75rem;padding:.875rem;background:var(--accent-red);border:none;border-radius:.5rem;color:#fff;font-weight:600;font-size:.95rem;cursor:pointer;box-shadow:0 4px 12px color-mix(in srgb,var(--accent-red) 40%,transparent)}.danger-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px color-mix(in srgb,var(--accent-red) 60%,transparent)}.danger-button:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.metrics-panel{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.metrics-panel-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.4rem}.metrics-panel-header h3{margin:0;font-size:.92rem}.metrics-toggle-btn{min-width:1.9rem;height:1.9rem;border:1px solid var(--border-color);border-radius:.375rem;background:var(--bg-accent);color:var(--text-primary);font-size:1rem;line-height:1;cursor:pointer}.metrics-toggle-btn:hover{background:var(--bg-accent-hover)}.metric-group{margin-bottom:1rem}.metric-group h4{font-size:.75rem;color:var(--text-secondary);margin-bottom:.5rem}.metric{display:flex;flex-direction:column;gap:.25rem;padding:.5rem 0}.metric .label{font-size:.75rem;color:var(--text-secondary)}.metric .value{font-size:.875rem;font-weight:500}.metric.warning .value{color:var(--accent-yellow)}.metric.danger .value{color:var(--accent-red)}.bar-container{height:4px;background:var(--bg-card);border-radius:2px;overflow:hidden}.bar{height:100%;background:var(--accent-blue);transition:width .3s}.metric.warning .bar{background:var(--accent-yellow)}.metric.danger .bar{background:var(--accent-red)}.balance-bars{display:flex;flex-direction:column;gap:.5rem}.balance-side{display:flex;align-items:center;gap:.5rem;font-size:.75rem}.balance-bar{flex:1;height:8px;background:var(--bg-card);border-radius:4px;overflow:hidden}.balance-bar>div{height:100%;background:var(--accent-blue)}.warnings{padding:.75rem;background:#ef44441a;border-radius:.5rem;margin-top:.5rem}.warnings h4{font-size:.75rem;color:var(--accent-red);margin-bottom:.5rem}.warnings ul{list-style:none;font-size:.75rem;color:var(--text-secondary)}.warnings li{padding:.25rem 0}.auto-pack-section{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border-color)}.quantity-inputs{display:flex;flex-direction:column;gap:.5rem}.quantity-inputs label{display:flex;justify-content:space-between;align-items:center;font-size:.75rem;color:var(--text-secondary)}.quantity-inputs input{width:60px;padding:.25rem .5rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:.25rem;color:var(--text-primary);text-align:right}.selected-instance{margin-top:1rem;padding:.75rem;background:#22c55e1a;border:1px solid var(--accent-green);border-radius:.5rem}.selected-instance h4{font-size:.875rem;margin-bottom:.5rem}.selected-instance p{font-size:.75rem;color:var(--text-secondary);margin-bottom:.5rem}.selected-instance button{width:100%;padding:.5rem;background:var(--accent-red);border:none;border-radius:.375rem;color:#fff;font-size:.75rem;cursor:pointer}.validation-error{position:absolute;bottom:1rem;left:1rem;right:1rem;padding:1rem;background:#ef4444e6;border-radius:.5rem;max-width:400px}.validation-error h4{font-size:.875rem;margin-bottom:.5rem}.validation-error ul{list-style:none;font-size:.75rem}.validation-error pre{margin-top:.5rem;font-size:.625rem;overflow-x:auto}.empty-message{color:var(--text-secondary);font-size:.875rem;text-align:center;padding:1rem}.error-message{margin-top:.5rem;color:var(--accent-red);font-size:.75rem}.import-error{margin:.5rem 1.5rem 0;padding:.5rem .75rem;border:1px solid var(--accent-red);border-radius:.375rem;background:color-mix(in srgb,var(--accent-red) 12%,transparent);color:var(--text-primary);font-size:.82rem}.toast-stack{position:fixed;right:1rem;bottom:1rem;z-index:1300;display:flex;flex-direction:column;gap:.5rem;width:min(420px,calc(100vw - 2rem));pointer-events:none}.toast-item{display:flex;align-items:flex-start;justify-content:space-between;gap:.6rem;padding:.7rem .8rem;border-radius:.6rem;border:1px solid color-mix(in srgb,var(--accent-red) 35%,var(--border-color));background:color-mix(in srgb,var(--bg-card) 88%,var(--accent-red) 12%);color:var(--text-primary);box-shadow:var(--shadow-lg);pointer-events:auto}.toast-item span{font-size:.82rem;line-height:1.3}.toast-item button{border:none;background:transparent;color:inherit;font-size:1rem;line-height:1;cursor:pointer;opacity:.8}.toast-item button:hover{opacity:1}.selected-name{font-weight:600;font-size:.875rem;color:var(--accent-green);margin-bottom:.5rem}.selected-details{display:flex;flex-direction:column;gap:.25rem;font-size:.7rem;color:var(--text-secondary);margin-bottom:.75rem}.dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.dialog{background:var(--bg-card);border:1px solid var(--border-color);border-radius:.75rem;padding:1.5rem;width:clamp(280px,90vw,480px);max-height:80vh;overflow-y:auto}.dialog h3{font-size:1rem;margin-bottom:1rem}.dialog-help{font-size:.75rem;color:var(--text-secondary);margin-bottom:.75rem;line-height:1.35}.dialog input[type=text]{width:100%;padding:.625rem .75rem;background:var(--bg-dark);border:1px solid var(--border-color);border-radius:.375rem;color:var(--text-primary);font-size:.875rem;margin-bottom:1rem}.dialog input[type=text]:focus{outline:none;border-color:var(--accent-blue)}.dialog-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1rem}.dialog-actions button{padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:.375rem;background:var(--bg-accent);color:var(--text-primary);cursor:pointer;font-size:.875rem}.dialog-actions button.primary{background:var(--accent-blue);border-color:var(--accent-blue)}.dialog-actions button.primary:disabled{opacity:.5;cursor:not-allowed}.dialog-actions button:hover:not(:disabled){filter:brightness(1.15)}.case-labels-dialog{max-width:520px;padding:0;overflow:hidden}.cl-dialog-header{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.5rem;border-bottom:1px solid var(--border-color);background:var(--bg-muted)}.cl-dialog-header h3{margin:0;font-size:1rem;font-weight:700}.cl-close-btn{background:none;border:none;color:var(--text-secondary);font-size:1rem;cursor:pointer;line-height:1;padding:4px 6px;border-radius:4px}.cl-close-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.cl-section{padding:1rem 1.5rem;border-bottom:1px solid var(--border-color)}.cl-notes-section{border-bottom:none;padding-bottom:0}.cl-section-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-secondary);margin-bottom:.65rem}.cl-file-btn{display:inline-flex;align-items:center;gap:6px;padding:.45rem .9rem;background:var(--bg-accent);border:1px solid var(--border-color);border-radius:.375rem;color:var(--text-primary);font-size:.825rem;cursor:pointer;font-weight:600}.cl-file-btn:hover{filter:brightness(1.1)}.cl-logo-preview{display:flex;align-items:center;gap:10px;margin-top:8px;padding:8px 10px;background:var(--bg-muted);border-radius:6px;border:1px solid var(--border-color)}.cl-logo-preview img{height:38px;width:auto;object-fit:contain}.cl-remove-btn{margin-left:auto;padding:4px 10px;background:none;border:1px solid var(--border-color);border-radius:4px;color:var(--text-secondary);font-size:.75rem;cursor:pointer}.cl-remove-btn:hover{border-color:var(--accent-red);color:var(--accent-red)}.cl-font-toggle{display:flex;gap:10px}.cl-font-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 8px;background:var(--bg-muted);border:2px solid var(--border-color);border-radius:8px;cursor:pointer;color:var(--text-secondary);font-size:.8rem;font-weight:600;transition:border-color .15s,color .15s,background .15s}.cl-font-btn.active{border-color:var(--accent-blue);color:var(--accent-blue);background:var(--bg-accent)}.cl-font-btn:hover:not(.active){border-color:var(--text-secondary);color:var(--text-primary)}.cl-font-preview{font-size:1.6rem;line-height:1;font-weight:700}.cl-notes-list{max-height:280px;overflow-y:auto;display:flex;flex-direction:column;gap:8px;padding-bottom:1rem}.cl-no-containers{font-size:.85rem;color:var(--text-secondary);font-style:italic;margin:0;padding:.5rem 0}.cl-note-item{display:flex;flex-direction:column;gap:4px}.cl-note-label{display:flex;align-items:center;gap:6px;font-size:.8rem;font-weight:600;color:var(--text-primary)}.cl-note-num{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 4px;background:var(--bg-accent);color:var(--accent-blue);border-radius:4px;font-size:.72rem;font-weight:700}.cl-note-textarea{width:100%;padding:7px 10px;background:var(--bg-dark);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:.8rem;resize:vertical;min-height:48px;box-sizing:border-box;font-family:inherit}.cl-note-textarea:focus{outline:none;border-color:var(--accent-blue)}.case-labels-dialog .dialog-actions{padding:.9rem 1.5rem;margin:0;border-top:1px solid var(--border-color);background:var(--bg-muted)}.plan-list{display:flex;flex-direction:column;gap:.5rem;max-height:400px;overflow-y:auto}.plan-card{padding:.75rem;background:var(--bg-dark);border:1px solid var(--border-color);border-radius:.5rem;text-align:left;cursor:pointer;transition:all .15s;width:100%}.plan-card:hover{border-color:var(--accent-blue)}.plan-name{font-weight:500;font-size:.875rem;margin-bottom:.25rem}.plan-meta{font-size:.75rem;color:var(--text-secondary)}.plan-date{font-size:.625rem;color:var(--text-secondary);margin-top:.25rem}.app-main.left-collapsed{grid-template-columns:1fr 340px}.app-main.right-collapsed{grid-template-columns:300px 1fr}.app-main.left-collapsed.right-collapsed{grid-template-columns:1fr}.sidebar.desktop-hidden{display:none}.placed-items{margin-top:1rem;border-top:1px solid var(--border-color);padding-top:1rem}.placed-list{display:flex;flex-direction:column;gap:.375rem;max-height:180px;overflow-y:auto}.staged-actions{margin-bottom:.5rem}.staged-actions button{width:100%;padding:.45rem .6rem;border:1px solid var(--border-color);border-radius:.35rem;background:var(--bg-card);color:var(--text-primary);cursor:pointer;font-size:.75rem}.staged-actions button:disabled{opacity:.45;cursor:not-allowed}.placed-card{display:flex;justify-content:space-between;padding:.4rem .5rem;border:1px solid var(--border-color);border-radius:.375rem;background:var(--bg-card);color:var(--text-primary);font-size:.7rem;cursor:grab}.placed-card input[type=checkbox]{margin-right:.4rem;accent-color:var(--accent-blue)}.placed-card.selected{border-color:var(--accent-green)}.position-inputs.compact{grid-template-columns:repeat(2,1fr)}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.5rem}.form-field{display:flex;flex-direction:column;gap:.25rem;min-width:0}.form-field span{font-size:.72rem;color:var(--text-secondary)}.loading-rules{margin-bottom:.75rem}.loading-rules-title{display:block;margin-bottom:.35rem;font-size:.75rem;color:var(--text-secondary)}.loading-rules-group{grid-column:1 / -1}.toggle-input{display:flex;align-items:center;gap:.45rem;font-size:.78rem;color:var(--text-secondary);min-width:0}.toggle-input span{min-width:0;overflow-wrap:break-word}.toggle-input input{width:auto;accent-color:var(--accent-blue)}.form-grid input:not([type=checkbox]){width:100%;min-width:0;padding:.5rem;background:var(--bg-dark);border:1px solid var(--border-color);border-radius:.375rem;color:var(--text-primary)}.case-header-row{display:flex;align-items:center;justify-content:space-between;gap:.6rem}.case-header-main{display:flex;align-items:center;gap:.5rem;min-width:0}.case-count-badge{min-width:1.6rem;height:1.6rem;padding:0 .4rem;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;color:#fff;background:color-mix(in srgb,var(--accent-blue) 85%,#1e293b 15%);box-shadow:var(--shadow-sm);flex:0 0 auto}.case-color-dot{width:.65rem;height:.65rem;border-radius:999px;flex:0 0 auto}.mobile-drop-hint,.mobile-menu-btn,.mobile-tab-bar,.mobile-menu-overlay,.mobile-case-actions,.mobile-autoload-fab{display:none}.color-input{display:flex;align-items:center;justify-content:space-between;gap:.5rem;font-size:.8rem;color:var(--text-secondary);grid-column:1 / -1;margin-top:.25rem;padding-top:.25rem}.app.theme-light .view-controls button{background:#ffffffbf;color:#0f172a;border-color:#0000001a}.app.theme-light .view-controls button.selected,.app.theme-light .view-controls button:hover:not(:disabled){background:var(--accent-blue);color:#fff;border-color:var(--accent-blue);box-shadow:0 4px 12px color-mix(in srgb,var(--accent-blue) 40%,transparent)}.app.theme-light .view-hint{background:#e2e8f0;color:var(--text-secondary);border-color:var(--border-color)}.app.theme-light .item-actions-menu{background:#f8fafc;border-color:var(--border-color)}.app.theme-light .item-actions-menu button{background:#e2e8f0;color:var(--text-primary)}.app.theme-light .truck-card,.app.theme-light .case-card,.app.theme-light .plan-card,.app.theme-light .placed-card{border-color:var(--border-color)}.app.theme-light .position-inputs input:not([type=checkbox]),.app.theme-light .form-grid input:not([type=checkbox]),.app.theme-light .dialog input[type=text],.app.theme-light .quantity-inputs input{background:#f8fafc;border-color:var(--border-color);color:var(--text-primary)}.app.theme-light .header-actions button:disabled,.app.theme-light .staged-actions button:disabled,.app.theme-light .yaw-buttons button:disabled{opacity:.65}.app.theme-dark .truck-card,.app.theme-dark .case-card{color:#e6eefb}.app.theme-dark .truck-name,.app.theme-dark .case-name{color:#f8fbff}.app.theme-dark .truck-dims,.app.theme-dark .truck-capacity,.app.theme-dark .case-info{color:#d0dceb}@media (max-width: 960px){.app-header{flex-direction:row;align-items:center;padding:.5rem .75rem;padding-top:calc(env(safe-area-inset-top,0px) + .5rem);gap:0}.app-header h1{font-size:1rem;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-actions{display:none}.mobile-menu-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--bg-accent);border:1px solid var(--border-color);border-radius:.5rem;color:var(--text-primary);cursor:pointer;flex-shrink:0}.mobile-menu-overlay{display:flex;position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;background:#00000080;align-items:flex-end;justify-content:center}.mobile-menu-sheet{width:100%;max-height:70vh;overflow-y:auto;background:var(--bg-card);border-top:1px solid var(--border-color);border-radius:1rem 1rem 0 0;padding:.5rem 0 calc(env(safe-area-inset-bottom,0px) + .5rem);animation:slideUp .2s ease-out}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.mobile-menu-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--border-color);font-weight:600;font-size:.9rem}.mobile-menu-header button{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;background:var(--bg-accent);border-radius:50%;color:var(--text-primary);font-size:1.25rem;cursor:pointer}.mobile-menu-items{display:flex;flex-direction:column;padding:.25rem .75rem}.mobile-menu-items button{width:100%;text-align:left;padding:.85rem .75rem;border:none;background:none;color:var(--text-primary);font-size:.875rem;cursor:pointer;border-radius:.5rem}.mobile-menu-items button:active{background:var(--bg-accent)}.mobile-menu-items button:disabled{opacity:.4;cursor:not-allowed}.app{min-height:0;height:100%;height:100dvh}.app-main,.app-main.left-collapsed,.app-main.right-collapsed,.app-main.left-collapsed.right-collapsed{grid-template-columns:1fr;grid-template-rows:1fr;overflow:hidden;min-height:0}.sidebar.desktop-hidden,.app-main .sidebar.left,.app-main .main-view,.app-main .sidebar.right{display:none}.app-main[data-mobile-tab=trucks] .sidebar.left{display:flex;flex-direction:column;height:100%;overflow-y:auto}.app-main[data-mobile-tab=view] .main-view{display:block;height:100%}.app-main[data-mobile-tab=cases] .sidebar.right{display:flex;flex-direction:column;height:100%;overflow-y:auto}.sidebar{max-height:none}.main-view,.truck-view-3d{min-height:0;height:100%}.mobile-tab-bar{display:flex;position:relative;z-index:100;background:var(--bg-card);border-top:2px solid var(--border-color);padding:.25rem 0 calc(env(safe-area-inset-bottom,0px) + .25rem);flex-shrink:0;min-height:56px}html.ios-pwa .mobile-tab-bar{padding-bottom:calc(env(safe-area-inset-bottom,0px) + .65rem);min-height:60px}.mobile-tab-bar button{flex:1;display:flex;flex-direction:column;align-items:center;gap:.2rem;padding:.5rem .25rem;border:none;background:none;color:var(--text-secondary);font-size:.7rem;cursor:pointer;transition:color .15s;min-height:44px}.mobile-tab-bar button.active{color:var(--accent-blue);font-weight:600}.mobile-tab-bar button svg{flex-shrink:0}.view-controls{max-width:calc(100% - 1rem);top:.5rem;left:.5rem;gap:.3rem}.view-controls button{padding:.35rem .5rem;font-size:.65rem}.metrics-overlay{width:min(300px,calc(100% - 1rem));top:.5rem;right:.5rem}.position-inputs{grid-template-columns:repeat(3,1fr)}.position-inputs.compact{grid-template-columns:repeat(2,1fr)}.position-inputs input:not([type=checkbox]),.quantity-inputs input{padding:.6rem .5rem;font-size:1rem;-webkit-appearance:none;-moz-appearance:none;appearance:none}.placed-list{max-height:none}.placed-card{padding:.55rem .6rem;font-size:.78rem;min-height:44px;align-items:center}.mobile-drop-hint{display:inline;font-size:.65rem;color:var(--text-secondary)}.selected-instance{padding:.85rem}.selected-instance button{min-height:44px;font-size:.85rem}.yaw-buttons button{min-height:44px;font-size:.8rem}.dialog{width:calc(100vw - 1rem);max-height:calc(100vh - 2rem);border-radius:.75rem}.dialog-actions button{min-height:44px;font-size:.9rem}.sidebar{padding:.75rem .75rem 1rem}.case-list{max-height:none}.case-card{padding:.85rem;min-height:44px}.case-card-actions{gap:.35rem}.case-action-btn{min-height:42px;font-size:.78rem;padding:.45rem .35rem}.truck-card{padding:.85rem;min-height:44px}.auto-pack-section{margin-top:1rem}.quantity-inputs label{font-size:.85rem;padding:.25rem 0}.staged-actions button{min-height:44px;font-size:.85rem}.place-button,.danger-button{min-height:44px;font-size:.9rem}.validation-error{bottom:.5rem;left:.5rem;right:.5rem;max-width:none}.toast-stack{right:.5rem;left:.5rem;width:auto;bottom:calc(env(safe-area-inset-bottom,0px) + 3.6rem)}.mobile-case-actions{display:flex;position:absolute;bottom:.85rem;left:50%;transform:translate(-50%);z-index:30;align-items:center;gap:.4rem;flex-wrap:wrap;justify-content:center;background:#0f172aeb;border:1px solid var(--border-color);border-radius:2rem;padding:.45rem .9rem;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);max-width:calc(100% - 1.5rem);box-shadow:0 4px 16px #0006}.mobile-case-name{font-size:.72rem;font-weight:500;color:var(--accent-green);width:100%;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:240px}.mobile-case-actions button{padding:.4rem .85rem;border:1px solid var(--border-color);border-radius:1.5rem;background:var(--bg-card);color:var(--text-primary);font-size:.78rem;cursor:pointer;min-height:36px;white-space:nowrap}.mobile-case-actions button:active{filter:brightness(1.2)}.mobile-case-actions button.danger{border-color:var(--accent-red);color:var(--accent-red)}.mobile-autoload-fab{display:inline-flex;position:absolute;right:.75rem;bottom:calc(env(safe-area-inset-bottom,0px) + 4.4rem);z-index:35;align-items:center;justify-content:center;min-height:44px;padding:.62rem .95rem;border:none;border-radius:999px;background:var(--accent-green);color:#fff;font-size:.8rem;font-weight:600;box-shadow:0 8px 18px color-mix(in srgb,var(--accent-green) 45%,transparent)}.mobile-autoload-fab:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}.mobile-autoload-fab:active:not(:disabled){transform:scale(.98)}}@media (max-width: 960px){.app.theme-light .mobile-menu-btn{background:var(--bg-accent);border-color:var(--border-color)}.app.theme-light .mobile-menu-sheet,.app.theme-light .mobile-tab-bar{background:var(--bg-card)}.app.theme-light .mobile-case-actions{background:#f8fafcf2}}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{height:100%}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#8894ab66;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#8894ab99}
