@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--bg: #1a1a2e;--surface: #16213e;--surface-alt: #0f3460;--accent: #e94560;--accent-alt: #533483;--text: #eaeaea;--text-dim: #8a8a9a;--knit-color: #e94560;--purl-color: #0f3460;--yarn-primary: #e8a87c;--yarn-secondary: #85cdca;--radius: 12px}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{width:100%;height:100%;font-family:Inter,sans-serif;background:var(--bg);color:var(--text);overflow:hidden}.app{display:flex;height:100vh;gap:0}.sidebar{width:320px;min-width:320px;background:var(--surface);border-right:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;overflow-y:auto}.sidebar-header{padding:24px 20px 16px;border-bottom:1px solid rgba(255,255,255,.06)}.sidebar-header h1{font-size:20px;font-weight:700;letter-spacing:-.5px;background:linear-gradient(135deg,var(--accent),var(--yarn-primary));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.sidebar-header p{font-size:12px;color:var(--text-dim);margin-top:4px}.sidebar-section{padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.06)}.sidebar-section h3{font-size:11px;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-dim);margin-bottom:12px;font-weight:600}.pattern-grid-wrapper{display:flex;justify-content:center}.pattern-grid{display:inline-grid;gap:2px;background:#0000004d;padding:4px;border-radius:8px}.pattern-cell{width:24px;height:24px;border-radius:4px;cursor:pointer;border:none;font-size:9px;font-weight:700;font-family:Inter,sans-serif;color:#ffffffb3;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.pattern-cell:hover{transform:scale(1.15);z-index:1}.pattern-cell.knit{background:var(--knit-color)}.pattern-cell.purl{background:var(--surface-alt)}.control-row{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.control-row label{font-size:12px;color:var(--text-dim);display:flex;justify-content:space-between}.control-row label span{color:var(--accent);font-weight:600}.control-row input[type=range]{-webkit-appearance:none;width:100%;height:4px;border-radius:2px;background:#ffffff14;outline:none}.control-row input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer;box-shadow:0 0 8px #e9456066}.color-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}.color-row label{font-size:12px;color:var(--text-dim);flex:1}.color-row input[type=color]{-webkit-appearance:none;width:32px;height:32px;border:2px solid rgba(255,255,255,.1);border-radius:6px;cursor:pointer;background:none;padding:0}.color-row input[type=color]::-webkit-color-swatch-wrapper{padding:2px}.color-row input[type=color]::-webkit-color-swatch{border:none;border-radius:3px}.color-palette{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.color-swatch{width:28px;height:28px;border-radius:6px;border:2px solid transparent;cursor:pointer;transition:all .15s ease}.color-swatch:hover{transform:scale(1.15)}.color-swatch.active{border-color:#fff;box-shadow:0 0 8px #fff6}.color-input-mini{width:28px;height:28px;border:2px solid rgba(255,255,255,.1);border-radius:6px;cursor:pointer;background:none;padding:0;-webkit-appearance:none}.color-input-mini::-webkit-color-swatch-wrapper{padding:2px}.color-input-mini::-webkit-color-swatch{border:none;border-radius:3px}.legend{display:flex;gap:16px;padding:12px 0 0}.legend-item{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-dim)}.legend-dot{width:10px;height:10px;border-radius:3px}.legend-dot.knit{background:var(--knit-color)}.legend-dot.purl{background:var(--surface-alt)}.scene-area{flex:1;position:relative;overflow:hidden;background:var(--bg)}.scene-area canvas{width:100%!important;height:100%!important;display:block}.scene-hint{position:absolute;bottom:16px;left:50%;transform:translate(-50%);font-size:11px;color:#ffffff4d;pointer-events:none;letter-spacing:.5px}.loading{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--text-dim);background:var(--bg)}.btn{padding:8px 16px;border:none;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s ease;font-family:Inter,sans-serif}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:#d63851;transform:translateY(-1px)}.btn-row{display:flex;gap:8px;flex-wrap:wrap}.btn-sm{padding:6px 10px;font-size:11px}.preset-grid{display:flex;flex-wrap:wrap;gap:6px}.preset-btn{padding:6px 10px;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:6px;color:var(--text);font-size:11px;cursor:pointer;transition:all .15s ease;font-family:Inter,sans-serif}.preset-btn:hover{background:#e9456026;border-color:var(--accent)}.jacquard-controls{display:flex;gap:8px;margin-bottom:12px}.upload-btn{flex:1;padding:8px 12px;background:#ffffff0f;border:1px dashed rgba(255,255,255,.15);border-radius:8px;color:var(--text);font-size:12px;cursor:pointer;transition:all .15s ease;font-family:Inter,sans-serif}.upload-btn:hover{background:#e945601f;border-color:var(--accent)}.video-thumbnails{margin-bottom:12px}.video-thumbnails label{display:block;font-size:11px;color:var(--text-dim);margin-bottom:6px}.thumbnail-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:4px}.thumbnail{width:100%;border-radius:4px;cursor:pointer;border:2px solid transparent;transition:all .15s ease;aspect-ratio:16/9;object-fit:cover}.thumbnail:hover{border-color:var(--accent);transform:scale(1.05)}.jacquard-preview{margin-bottom:12px;border-radius:8px;overflow:hidden;border:1px solid rgba(255,255,255,.08)}.preview-img{width:100%;display:block;border-radius:7px}.clear-btn{width:100%;padding:8px;margin-top:8px;background:#e945601a;border:1px solid rgba(233,69,96,.3);border-radius:8px;color:var(--accent);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s ease;font-family:Inter,sans-serif}.clear-btn:hover{background:#e9456033}.muted-text{font-size:12px;color:var(--text-dim);font-style:italic;text-align:center;padding:8px 0}.pattern-cell{min-width:14px;min-height:14px}.video-play-btn{margin-top:8px;background:#4caf501f!important;border-color:#4caf5066!important;color:#4caf50!important;font-weight:600}.video-play-btn:hover{background:#4caf5040!important}.video-playback-controls{margin:8px 0;padding:12px;background:#4caf5014;border:1px solid rgba(76,175,80,.25);border-radius:10px}.playback-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}.playback-badge{display:inline-block;padding:2px 8px;background:#4caf50;color:#fff;border-radius:4px;font-size:10px;font-weight:700;letter-spacing:1px;animation:pulse-glow 1.5s infinite}@keyframes pulse-glow{0%,to{box-shadow:0 0 4px #4caf504d}50%{box-shadow:0 0 12px #4caf50b3}}.playback-label{font-size:12px;color:var(--text-dim)}.playback-buttons{display:flex;gap:8px}.playback-btn{flex:1;padding:8px 12px;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);border-radius:6px;color:var(--text);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s ease;font-family:Inter,sans-serif}.playback-btn:hover{background:#ffffff1a}.playback-btn.stop-btn{background:#e945601a;border-color:#e945604d;color:var(--accent)}.playback-btn.stop-btn:hover{background:#e9456033}.active-mode-btn{background:#ffc10726!important;border-color:#ffc10780!important;color:#ffc107!important;font-weight:600;box-shadow:0 0 12px #ffc10726}.paint-mode-panel{margin-top:10px;padding:12px;background:#ffc1070f;border:1px solid rgba(255,193,7,.2);border-radius:10px}.paint-label{font-size:11px;color:var(--text-muted);margin-bottom:6px;display:block}.custom-palette{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.palette-item{position:relative;display:inline-flex}.palette-item .color-swatch{width:30px;height:30px;border-radius:6px}.remove-color-btn{position:absolute;top:-4px;right:-4px;width:14px;height:14px;border-radius:50%;background:#e94560e6;color:#fff;font-size:10px;line-height:1;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s ease}.palette-item:hover .remove-color-btn{opacity:1}.add-color-row{display:flex;align-items:center;gap:8px}.add-color-btn{padding:4px 12px;background:#ffc1071f;border:1px solid rgba(255,193,7,.3);border-radius:6px;color:#ffc107;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s ease;white-space:nowrap}.add-color-btn:hover{background:#ffc10740}.paint-hint{margin-top:8px;font-size:10px;color:var(--text-muted);opacity:.7;line-height:1.4}.pattern-cell.paintable{cursor:crosshair!important}.pattern-cell.paintable:hover{outline:2px solid #ffc107!important;outline-offset:-1px;z-index:1}
