:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}body{margin:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.app{color:#1a1a2e;background:#f5f6fa;flex-direction:column;min-height:100vh;font-family:Inter,system-ui,-apple-system,sans-serif;display:flex}.app__header{text-align:center;background:#1a1a2e;border-bottom:none;padding:16px 24px}.app__header-content{justify-content:center;align-items:center;gap:12px;display:flex}.app__header-icon{border-radius:10px;width:40px;height:40px}.app__header h1{background:linear-gradient(135deg,#4caf50,#2196f3,#9c27b0);-webkit-text-fill-color:transparent;letter-spacing:-.5px;-webkit-background-clip:text;background-clip:text;margin:0;font-size:1.6rem;font-weight:700}.app__main{box-sizing:border-box;flex-direction:column;flex:1;gap:20px;width:100%;max-width:1600px;margin:0 auto;padding:20px;display:flex}.app__panel{flex-direction:column;gap:16px;display:flex}.app__panel--primary,.app__panel--secondary{flex:auto}.app__drawer{border-radius:0 0 12px 12px;max-height:0;transition:max-height .8s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.app__drawer:before{content:"";z-index:1;background:linear-gradient(90deg,#795548,#8d6e63,#a1887f,#8d6e63,#795548);border-radius:0 0 3px 3px;height:6px;position:absolute;top:0;left:0;right:0}.app__drawer--open{max-height:3000px;transition:max-height 1s cubic-bezier(.4,0,.2,1)}.app__drawer-track{transform-origin:top;padding:12px 0 0}.app__drawer--open .app__drawer-track{animation:.7s cubic-bezier(.34,1.56,.64,1) drawerSlideDown}@keyframes drawerSlideDown{0%{opacity:0;transform:translateY(-30px)scaleY(.95)}to{opacity:1;transform:translateY(0)scaleY(1)}}.app__clear-section{justify-content:flex-end;padding:8px 0;display:flex}.app__clear-button{color:#ff5252;cursor:pointer;background:#ff52521a;border:1px solid #ff52524d;border-radius:8px;padding:8px 16px;font-size:.85rem;font-weight:600;transition:all .2s}.app__clear-button:hover{color:#fff;background:#ff5252;border-color:#ff5252;transform:translateY(-1px);box-shadow:0 4px 12px #ff52524d}.app__dialog-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0009;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.app__dialog{background:#fff;border-radius:16px;width:100%;max-width:400px;padding:28px;box-shadow:0 20px 60px #0000004d}.app__dialog h2{color:#1a1a2e;margin:0 0 12px;font-size:1.25rem}.app__dialog p{color:#555;margin:0 0 24px;line-height:1.6}.app__dialog-actions{justify-content:flex-end;gap:12px;display:flex}.app__dialog-button{cursor:pointer;border:none;border-radius:8px;padding:10px 22px;font-size:.875rem;font-weight:600;transition:all .2s}.app__dialog-button--confirm{color:#fff;background:#ff5252}.app__dialog-button--confirm:hover{background:#d32f2f;transform:translateY(-1px)}.app__dialog-button--cancel{color:#333;background:#f0f0f0}.app__dialog-button--cancel:hover{background:#e0e0e0}@media (width>=768px){.app__main{flex-direction:row;gap:24px;padding:28px}.app__panel--primary{flex:3 1 0;min-width:0}.app__panel--secondary{flex:2 1 0;min-width:0;max-height:calc(100vh - 100px);overflow-y:auto}}.app__panel section,.app__panel .makerworld-search,.app__panel .grid-canvas-container{background:#fffffff2;border:1px solid #fff3;border-radius:16px;padding:20px;transition:box-shadow .3s;box-shadow:0 4px 24px #00000014}.app__panel section:hover,.app__panel .makerworld-search:hover{box-shadow:0 8px 32px #0000001f}.dimension-field{margin-bottom:14px}.dimension-field label{color:#555;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:.8rem;font-weight:600;display:block}.dimension-field input{box-sizing:border-box;color:#1a1a2e;background:#fafafa;border:2px solid #e8e8e8;border-radius:10px;width:100%;padding:12px 14px;font-size:1rem;transition:border-color .2s,box-shadow .2s}.dimension-field input:focus{background:#fff;border-color:#4caf50;outline:none;box-shadow:0 0 0 3px #4caf5026}.dimension-field input[aria-invalid=true]{border-color:#ff5252;box-shadow:0 0 0 3px #ff52521a}.dimension-error{color:#ff5252;margin-top:6px;font-size:.8rem;font-weight:500}.dimension-error p{margin:2px 0}section button[aria-label="Calculate grid from drawer dimensions"]{color:#fff;cursor:pointer;letter-spacing:.3px;background:linear-gradient(135deg,#4caf50,#2e7d32);border:none;border-radius:10px;width:100%;margin-top:8px;padding:14px 24px;font-size:1rem;font-weight:700;transition:all .2s}section button[aria-label="Calculate grid from drawer dimensions"]:hover{transform:translateY(-2px);box-shadow:0 6px 20px #4caf5066}section button[aria-label="Calculate grid from drawer dimensions"]:active{transform:translateY(0)}.confirm-dialog-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0009;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.confirm-dialog{background:#fff;border-radius:16px;width:100%;max-width:400px;padding:28px;box-shadow:0 20px 60px #0000004d}.confirm-dialog h3{margin:0 0 12px;font-size:1.2rem}.confirm-dialog p{color:#555;margin:0 0 24px;line-height:1.6}.confirm-dialog-actions{justify-content:flex-end;gap:12px;display:flex}.confirm-dialog-actions button{cursor:pointer;border:none;border-radius:8px;padding:10px 22px;font-size:.875rem;font-weight:600;transition:all .2s}.box-list__heading{color:#1a1a2e;margin:0 0 14px;font-size:1.1rem;font-weight:700}.box-list__empty{color:#888;font-size:.9rem;font-style:italic}.box-list__items{margin:0;padding:0;list-style:none}.box-list-item{border-bottom:1px solid #f0f0f0;border-radius:8px;align-items:center;gap:10px;padding:10px 8px;transition:background .15s;display:flex}.box-list-item:hover{background:#f8f8f8}.box-list-item:last-child{border-bottom:none}.box-list-item__color{border-radius:6px;flex-shrink:0;width:20px;height:20px;box-shadow:0 2px 4px #00000026}.box-list-item__details{flex-wrap:wrap;flex:1;align-items:center;gap:8px;font-size:.875rem;display:flex}.box-list-item__number{color:#1a1a2e;font-weight:700}.box-list-item__makerworld{background:linear-gradient(135deg,#e3f2fd,#bbdefb);border-radius:4px;padding:2px 8px;font-size:.7rem;font-weight:600}.box-list-item__remove{color:#ff5252;cursor:pointer;background:0 0;border:none;border-radius:8px;padding:6px 10px;font-size:1.1rem;transition:all .15s}.box-list-item__remove:hover{background:#ff52521a;transform:scale(1.1)}.submit-panel{flex-direction:column;gap:14px;display:flex}.submit-panel h3{color:#1a1a2e;margin:0 0 4px;font-size:1.1rem;font-weight:700}.submit-panel__field{margin-bottom:4px}.submit-panel__field label{color:#555;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:.8rem;font-weight:600;display:block}.submit-panel__field input{box-sizing:border-box;color:#1a1a2e;background:#fafafa;border:2px solid #e8e8e8;border-radius:10px;width:100%;padding:10px 14px;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.submit-panel__field input:focus{background:#fff;border-color:#2196f3;outline:none;box-shadow:0 0 0 3px #2196f326}.submit-panel__hint{color:#888;margin-top:4px;font-size:.75rem;display:block}.submit-panel__button{color:#fff;cursor:pointer;letter-spacing:.3px;background:linear-gradient(135deg,#2196f3,#1565c0);border:none;border-radius:10px;padding:14px 24px;font-size:1rem;font-weight:700;transition:all .2s}.submit-panel__button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #2196f366}.submit-panel__button:active:not(:disabled){transform:translateY(0)}.submit-panel__button:disabled{cursor:not-allowed;background:#ccc}.submit-panel__info{color:#888;font-size:.85rem;font-style:italic}.submit-panel__success{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border:1px solid #a5d6a7;border-radius:10px;padding:14px}.submit-panel__success p{color:#2e7d32;margin:0;font-size:.9rem;font-weight:500}.makerworld-search h3{margin:0 0 12px;font-size:1.1rem;font-weight:700}.makerworld-search__input-group{margin-bottom:12px}.makerworld-search__label{color:#555;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:.8rem;font-weight:600;display:block}.makerworld-search__input-row{gap:8px;display:flex}.makerworld-search__input{color:#1a1a2e;background:#fafafa;border:2px solid #e8e8e8;border-radius:10px;flex:1;padding:10px 14px;font-size:.95rem;transition:border-color .2s}.makerworld-search__input:focus{background:#fff;border-color:#9c27b0;outline:none;box-shadow:0 0 0 3px #9c27b026}.makerworld-search__button{color:#fff;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#9c27b0,#7b1fa2);border:none;border-radius:10px;padding:10px 18px;font-size:.85rem;font-weight:600;transition:all .2s}.makerworld-search__button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #9c27b04d}.makerworld-search__button:disabled{cursor:not-allowed;background:#ccc}.makerworld-search__hint{color:#888;margin-top:6px;font-size:.75rem;display:block}.makerworld-search__message{border-radius:8px;margin-bottom:8px;padding:10px 14px;font-size:.85rem}.makerworld-search__message--error{color:#e65100;background:#fff3e0;border:1px solid #ffcc80}.makerworld-search__results{margin:0;padding:0;list-style:none}.makerworld-search__result-item{border-bottom:1px solid #f0f0f0}.makerworld-search__result-item:last-child{border-bottom:none}.makerworld-search__result-button{cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:12px;width:100%;padding:10px;transition:background .15s;display:flex}.makerworld-search__result-button:hover{background:#f5f5f5}.makerworld-search__thumbnail{object-fit:cover;border-radius:6px;flex-shrink:0}.makerworld-search__result-info{flex-direction:column;gap:2px;display:flex}.makerworld-search__result-name{color:#1a1a2e;font-size:.875rem;font-weight:600}.makerworld-search__result-size{color:#888;font-size:.75rem}.placement-indicator{color:#1565c0;text-align:center;background:linear-gradient(135deg,#e3f2fd,#bbdefb);border-radius:8px;margin-bottom:10px;padding:8px 16px;font-size:.85rem;font-weight:500}section h2{color:#1a1a2e;margin:0 0 12px;font-size:1.1rem;font-weight:700}.bin-catalog__tabs{background:#f0f0f0;border-radius:8px;gap:4px;margin-bottom:14px;padding:3px;display:flex;overflow-x:auto}.bin-catalog__tab{cursor:pointer;color:#666;white-space:nowrap;background:0 0;border:none;border-radius:6px;flex-direction:column;flex:1;align-items:center;gap:2px;min-width:0;padding:8px 6px;font-size:.7rem;font-weight:600;transition:all .2s;display:flex}.bin-catalog__tab-emoji{font-size:1.1rem}.bin-catalog__tab-label{text-transform:uppercase;letter-spacing:.3px;font-size:.65rem}.bin-catalog__tab--active{color:#1a1a2e;background:#fff;box-shadow:0 2px 4px #0000001a}.bin-catalog__tab:hover:not(.bin-catalog__tab--active){color:#333}.bin-catalog__selected{color:#2e7d32;background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border-radius:8px;justify-content:space-between;align-items:center;gap:8px;margin-bottom:12px;padding:10px 14px;font-size:.85rem;display:flex}.bin-catalog__cancel{color:#d32f2f;cursor:pointer;background:#fff;border:1px solid #d32f2f;border-radius:6px;padding:4px 12px;font-size:.8rem;font-weight:600;transition:all .15s}.bin-catalog__cancel:hover{background:#ffebee}.bin-catalog__hint{color:#888;text-align:center;padding:12px;font-size:.85rem;font-style:italic}.bin-catalog__grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px;display:grid}.bin-catalog__item{cursor:pointer;text-align:center;background:#fafafa;border:2px solid #e8e8e8;border-radius:10px;flex-direction:column;align-items:center;gap:6px;padding:10px 6px;transition:all .2s;display:flex}.bin-catalog__item:hover{background:#f1f8e9;border-color:#4caf50;transform:translateY(-2px);box-shadow:0 4px 12px #4caf5026}.bin-catalog__item--selected{background:#e8f5e9;border-color:#4caf50;box-shadow:0 0 0 3px #4caf5033}.bin-catalog__item-preview{opacity:.8;background:linear-gradient(135deg,#4caf50,#66bb6a);border-radius:4px;width:100%;max-width:60px;min-height:20px}.bin-catalog__item-name{color:#1a1a2e;font-size:.75rem;font-weight:600;line-height:1.2}.bin-catalog__item-desc{color:#888;font-size:.65rem}
