.cloth-app{--cloth-bg: #f4f4f0;--cloth-surface: #ffffff;--cloth-black: #000;--cloth-border: 3px solid #000;--cloth-border-thick: 4px solid #000;--cloth-shadow: 4px 4px 0px #000;--cloth-shadow-lg: 8px 8px 0px #000;--cloth-yellow: #fef08a;--cloth-yellow-hot: #fde047;--cloth-lime: #a3e635;--cloth-pink: #f472b6;--cloth-blue: #93c5fd;position:relative;width:100%;display:flex;overflow:hidden;background:var(--cloth-bg);font-family:Space Grotesk,sans-serif;-webkit-user-select:none;user-select:none}.cloth-app.cloth-app--fullpage{height:calc(100vh - 104px);min-height:400px}.cloth-app .cloth-sidebar{width:280px;background:var(--cloth-surface);border-right:var(--cloth-border-thick);overflow-y:auto;flex-shrink:0;display:flex;flex-direction:column}.cloth-app .cloth-sidebar::-webkit-scrollbar{width:4px}.cloth-app .cloth-sidebar::-webkit-scrollbar-track{background:#f0f0ec}.cloth-app .cloth-sidebar::-webkit-scrollbar-thumb{background:#000}.cloth-app .cloth-section{border-bottom:3px solid #000;padding:14px 16px}.cloth-app .cloth-section-head{display:flex;align-items:center;gap:8px;margin-bottom:12px}.cloth-app .cloth-section-num{font-family:JetBrains Mono,monospace;font-size:9px;font-weight:700;background:#000;color:#fff;padding:3px 6px;letter-spacing:.5px}.cloth-app .cloth-section-title{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase}.cloth-app .cloth-section-line{flex:1;height:2px;background:#000;opacity:.15}.cloth-app .cloth-tex-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px}.cloth-app .cloth-tex-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 6px;border:3px solid #000;background:var(--cloth-bg);cursor:pointer;transition:all .08s ease;box-shadow:var(--cloth-shadow);font-family:Space Grotesk,sans-serif}.cloth-app .cloth-tex-btn:hover{transform:translate(-2px,-2px);box-shadow:6px 6px #000}.cloth-app .cloth-tex-btn.active{background:var(--cloth-yellow-hot)}.cloth-app .cloth-tex-btn svg{width:20px;height:20px}.cloth-app .cloth-tex-btn-label{font-family:JetBrains Mono,monospace;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.cloth-app .cloth-upload-area{border:3px dashed #000;padding:16px;text-align:center;cursor:pointer;transition:background .1s;margin-bottom:10px}.cloth-app .cloth-upload-area:hover{background:var(--cloth-yellow)}.cloth-app .cloth-upload-area.drag-over{background:var(--cloth-lime)}.cloth-app .cloth-upload-label{font-family:JetBrains Mono,monospace;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;display:block;margin-bottom:4px}.cloth-app .cloth-upload-sub{font-size:10px;opacity:.5;font-family:JetBrains Mono,monospace}.cloth-app .cloth-color-row{display:flex;gap:6px;margin-bottom:10px}.cloth-app .cloth-color-swatch{width:28px;height:28px;border:3px solid #000;cursor:pointer;transition:all .08s;box-shadow:2px 2px #000;padding:0;background:none}.cloth-app .cloth-color-swatch:hover{transform:translate(-1px,-1px);box-shadow:3px 3px #000}.cloth-app .cloth-color-swatch.active{box-shadow:0 0 #000;transform:translate(2px,2px);outline:3px solid var(--cloth-yellow-hot);outline-offset:1px}.cloth-app .cloth-bg-swatch{width:28px;height:28px;cursor:pointer;transition:all .08s;flex-shrink:0;border:3px solid #000;box-shadow:2px 2px #000;padding:0;background:none}.cloth-app .cloth-bg-swatch:hover{transform:translate(-1px,-1px);box-shadow:3px 3px #000}.cloth-app .cloth-bg-swatch.active{box-shadow:0 0 #000;transform:translate(2px,2px);outline:3px solid var(--cloth-yellow-hot);outline-offset:1px}.cloth-app .cloth-ctrl-row{margin-bottom:10px}.cloth-app .cloth-ctrl-label{display:flex;justify-content:space-between;align-items:center;margin-bottom:5px}.cloth-app .cloth-ctrl-name{font-family:JetBrains Mono,monospace;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.cloth-app .cloth-ctrl-val{font-family:JetBrains Mono,monospace;font-size:10px;font-weight:700;background:var(--cloth-yellow-hot);padding:1px 6px;border:2px solid #000;min-width:40px;text-align:center}.cloth-app .cloth-sidebar input[type=range]{width:100%;height:6px;-webkit-appearance:none;appearance:none;background:#000;outline:none;cursor:pointer}.cloth-app .cloth-sidebar input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;background:var(--cloth-yellow-hot);border:3px solid #000;cursor:pointer}.cloth-app .cloth-sidebar input[type=range]::-moz-range-thumb{width:16px;height:16px;background:var(--cloth-yellow-hot);border:3px solid #000;cursor:pointer}.cloth-app .cloth-preset-grid{display:flex;flex-wrap:wrap;gap:6px}.cloth-app .cloth-preset-chip{font-family:JetBrains Mono,monospace;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:5px 10px;border:2px solid #000;background:var(--cloth-bg);cursor:pointer;box-shadow:2px 2px #000;transition:all .08s}.cloth-app .cloth-preset-chip:hover{background:var(--cloth-yellow);transform:translate(-1px,-1px);box-shadow:3px 3px #000}.cloth-app .cloth-preset-chip.active{background:var(--cloth-yellow-hot);box-shadow:0 0 #000;transform:translate(2px,2px)}.cloth-app .cloth-video-controls{display:none;gap:6px;align-items:center;margin-top:8px}.cloth-app .cloth-video-controls.visible{display:flex}.cloth-app .cloth-vid-btn{font-family:JetBrains Mono,monospace;font-size:10px;font-weight:700;padding:5px 10px;border:2px solid #000;background:var(--cloth-bg);cursor:pointer;box-shadow:2px 2px #000;text-transform:uppercase;letter-spacing:.5px;transition:all .08s}.cloth-app .cloth-vid-btn:hover{background:var(--cloth-lime);transform:translate(-1px,-1px);box-shadow:3px 3px #000}.cloth-app .cloth-btn-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:8px}.cloth-app .cloth-btn{font-family:Space Grotesk,sans-serif;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:8px 10px;border:3px solid #000;background:var(--cloth-surface);cursor:pointer;box-shadow:var(--cloth-shadow);transition:all .08s ease;text-align:center}.cloth-app .cloth-btn:hover{transform:translate(-2px,-2px);box-shadow:6px 6px #000}.cloth-app .cloth-btn:active{transform:translate(4px,4px);box-shadow:0 0 #000}.cloth-app .cloth-btn.yellow{background:var(--cloth-yellow-hot)}.cloth-app .cloth-btn.lime{background:var(--cloth-lime)}.cloth-app .cloth-btn.pink{background:var(--cloth-pink)}.cloth-app .cloth-btn.full{grid-column:1 / -1}.cloth-app .cloth-canvas-wrap{flex:1;position:relative;background:#f4f4f0;overflow:hidden}.cloth-app .cloth-canvas-wrap canvas{display:block;width:100%!important;height:100%!important}.cloth-app .cloth-info-overlay{position:absolute;top:12px;left:12px;font-family:JetBrains Mono,monospace;font-size:10px;font-weight:600;color:#ffffff80;letter-spacing:1px;text-transform:uppercase;pointer-events:none;line-height:1.8}.cloth-app .cloth-hint-bar{position:absolute;bottom:0;left:0;right:0;padding:8px 16px;background:#000000b3;font-family:JetBrains Mono,monospace;font-size:10px;color:#ffffff80;letter-spacing:1px;text-transform:uppercase;display:flex;gap:24px}.cloth-app .cloth-hint-bar span{color:var(--cloth-yellow-hot)}.cloth-app .cloth-fps-label{font-family:JetBrains Mono,monospace;font-size:10px;font-weight:600;letter-spacing:1px;text-transform:uppercase;position:absolute;top:12px;right:14px;color:#ffffff80;pointer-events:none}@media(max-width:768px){.cloth-app{flex-direction:column}.cloth-app .cloth-sidebar{width:100%;max-height:40vh;border-right:none;border-bottom:var(--cloth-border-thick)}.cloth-app .cloth-canvas-wrap{min-height:300px}}
