:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}.header{background:#1a1a2e;color:#fff;padding:12px 24px;display:flex;align-items:center;gap:24px}.header-brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:#fff}.header-brand h1{font-size:18px;font-weight:700;letter-spacing:-.5px}.subtitle{font-size:12px;color:#88a}.header-nav{margin-left:auto;display:flex;gap:8px}.nav-link{padding:6px 14px;border:1px solid #444;border-radius:6px;background:transparent;color:#aaa;font-size:12px;cursor:pointer;transition:all .15s;text-decoration:none}.nav-link:hover{border-color:#666;color:#fff}.nav-link.active{background:#0f3460;border-color:#0f3460;color:#fff}.catalog-page{flex:1;overflow-y:auto;background:#f5f5f7}.catalog-toolbar{display:flex;align-items:center;gap:16px;padding:16px 24px;background:#fff;border-bottom:1px solid #e0e0e5}.catalog-search{flex:1;max-width:400px;padding:8px 14px;border:1px solid #ddd;border-radius:8px;font-size:13px;outline:none;transition:border-color .15s}.catalog-search:focus{border-color:#0f3460}.catalog-count{font-size:12px;color:#888}.catalog-content{padding:16px 24px;max-width:1200px;margin:0 auto}.catalog-loading{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px}.catalog-error{flex:1;display:flex;align-items:center;justify-content:center;color:#e94560;font-size:14px}.category-section{margin-bottom:16px}.category-header{display:flex;align-items:center;gap:10px;width:100%;padding:10px 0;border:none;background:transparent;cursor:pointer;font-family:inherit}.category-header h2{font-size:16px;font-weight:700;text-transform:capitalize;color:#1a1a2e}.category-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.category-count{font-size:12px;color:#888;background:#f0f0f4;padding:2px 8px;border-radius:10px}.category-arrow{margin-left:auto;font-size:14px;color:#888;transition:transform .2s}.category-arrow.collapsed{transform:rotate(-90deg)}.category-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;padding:4px 0 12px}.template-card{background:#fff;border:1px solid #e8e8ee;border-radius:10px;padding:16px;cursor:pointer;transition:all .15s}.template-card:hover{border-color:#0f3460;box-shadow:0 2px 12px #0f34601a;transform:translateY(-1px)}.card-header{display:flex;align-items:center;margin-bottom:8px}.card-badge{font-size:10px;color:#fff;padding:2px 8px;border-radius:12px;text-transform:capitalize}.card-title{font-size:14px;font-weight:600;color:#1a1a2e;margin-bottom:6px}.card-meta{display:flex;gap:12px;font-size:11px;color:#888;margin-bottom:8px}.card-panels{display:flex;flex-wrap:wrap;gap:4px}.card-panel-tag{font-size:10px;background:#f0f0f4;color:#666;padding:2px 6px;border-radius:4px;text-transform:capitalize}.pattern-canvas{flex:1;position:relative;background:#eeeef2;overflow:hidden}.canvas-controls{position:absolute;top:12px;right:12px;z-index:10;display:flex;align-items:center;gap:8px}.canvas-btn{padding:4px 10px;border:1px solid #ccc;border-radius:4px;background:#fff;font-size:11px;cursor:pointer;transition:all .15s}.canvas-btn:hover{border-color:#0f3460;color:#0f3460}.canvas-zoom{font-size:11px;color:#888;background:#fff;padding:4px 8px;border-radius:4px;border:1px solid #e0e0e5}.canvas-legend{position:absolute;bottom:12px;left:12px;display:flex;gap:12px;background:#ffffffe6;padding:6px 12px;border-radius:6px;border:1px solid #e0e0e5}.legend-item{display:flex;align-items:center;gap:4px}.legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.legend-label{font-size:10px;color:#666;font-weight:600}.garment-page{display:flex;flex:1;overflow:hidden;height:calc(100vh - 50px)}.sidebar{width:280px;background:#fff;border-right:1px solid #e0e0e5;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:8px}.sidebar-back{margin-bottom:4px}.back-link{font-size:12px;color:#0f3460;text-decoration:none}.back-link:hover{text-decoration:underline}.sidebar-panel{background:#fafafa;border:1px solid #e8e8ee;border-radius:8px;padding:12px}.sidebar-panel h3{font-size:10px;text-transform:uppercase;letter-spacing:.8px;color:#888;margin-bottom:8px}.garment-info{display:flex;flex-direction:column;gap:6px}.garment-name{font-size:14px;font-weight:600;color:#1a1a2e}.garment-meta{display:flex;gap:6px}.size-buttons{display:flex;flex-wrap:wrap;gap:4px}.size-btn{flex:0 0 auto;min-width:38px;padding:6px 4px;border:2px solid #ddd;border-radius:6px;background:#fff;font-size:11px;font-weight:600;cursor:pointer;transition:all .15s;color:#1a1a2e;text-align:center}.size-btn:hover{border-color:#0f3460}.size-btn.active{background:#0f3460;color:#fff;border-color:#0f3460}.sleeve-selector{display:flex;flex-wrap:wrap;gap:4px}.sleeve-btn{flex:0 0 auto;min-width:38px;padding:6px 8px;border:2px solid #ddd;border-radius:6px;background:#fff;font-size:11px;font-weight:600;cursor:pointer;transition:all .15s;color:#1a1a2e;text-align:center}.sleeve-btn:hover{border-color:#0f3460}.sleeve-btn.active{background:#0f3460;color:#fff;border-color:#0f3460}.panel-tabs{display:flex;flex-wrap:wrap;gap:4px}.panel-tab{padding:5px 10px;border:1px solid #ddd;border-radius:4px;background:#fff;font-size:11px;cursor:pointer;transition:all .15s}.panel-tab:hover{border-color:#0f3460}.panel-tab.active{background:#0f3460;color:#fff;border-color:#0f3460}.toggle{display:flex;align-items:center;gap:6px;font-size:12px;padding:3px 0;cursor:pointer}.toggle input{accent-color:#0f3460}.measurement-table{width:100%;border-collapse:collapse;font-size:11px}.measurement-table th{text-align:left;padding:4px;border-bottom:2px solid #e0e0e5;color:#888;font-size:10px;text-transform:uppercase}.measurement-table td{padding:3px 4px;border-bottom:1px solid #f0f0f0}.measurement-table .value{text-align:right;font-weight:600;font-variant-numeric:tabular-nums;color:#0f3460}.export-buttons{display:flex;gap:8px}.export-btn{flex:1;padding:8px;border:2px solid #0f3460;border-radius:6px;background:#fff;color:#0f3460;font-size:12px;font-weight:700;cursor:pointer;text-align:center;text-decoration:none;transition:all .15s}.export-btn:hover{background:#0f3460;color:#fff}.garment-main{flex:1;display:flex;position:relative;overflow:hidden}.garment-error{flex:1;display:flex;align-items:center;justify-content:center;color:#e94560;font-size:14px}.loading-overlay{position:absolute;inset:0;background:#ffffffe6;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10}.loading-overlay p{font-size:14px;color:#666}.sketch-view{flex:1;display:flex;flex-direction:column;height:100%;background:#f5f5f7}.sketch-component-error{padding:10px 24px;background:#fef2f2;color:#991b1b;border-bottom:1px solid #fecaca;font-size:13px}.sketch-topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:#fff;border-bottom:1px solid #e8e8ee;flex-shrink:0}.sketch-topbar-left{display:flex;align-items:center}.sketch-back-btn{padding:8px 16px;border:1px solid #d0d0d8;border-radius:6px;background:#fff;color:#1a1a2e;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.sketch-back-btn:hover{background:#f5f5f7}.sketch-topbar-center{display:flex;align-items:center;gap:8px}.sketch-garment-name{font-size:15px;font-weight:600;color:#1a1a2e;text-transform:capitalize}.sketch-confidence{font-size:12px;font-weight:600;color:#2ecc71;background:#ecfdf5;padding:2px 8px;border-radius:12px}.sketch-attempts{font-size:11px;font-weight:500;color:#666;background:#f0f0f4;padding:2px 8px;border-radius:12px}.sketch-topbar-right{display:flex;align-items:center;gap:8px}.sketch-edit-btn{padding:8px 16px;border:1px solid #0f3460;border-radius:6px;background:#fff;color:#0f3460;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.sketch-edit-btn:hover{background:#f0f4fa}.sketch-next-btn{padding:8px 20px;border:none;border-radius:6px;background:#0f3460;color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.sketch-next-btn:hover{background:#1a4a80}.sketch-body{flex:1;display:flex;min-height:0;overflow:hidden}.sketch-left{flex:0 0 320px;display:flex;flex-direction:column;padding:24px;gap:16px;background:#fafafa;overflow-y:auto;border-right:1px solid #e8e8ee}.sketch-left-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#999}.sketch-inspiration-img{max-width:100%;max-height:300px;object-fit:contain;border-radius:8px;border:1px solid #e8e8ee}.sketch-inspiration-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.sketch-inspiration-thumb{width:100%;height:130px;object-fit:cover;border-radius:6px;border:1px solid #e8e8ee}.sketch-right{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:16px 24px;background:#fff;overflow-y:auto;min-width:0}.sketch-right-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#999;margin-bottom:12px}.sketch-bbox-btn{padding:8px 14px;border:1px solid #d0d0d8;border-radius:6px;background:#fff;color:#1a1a2e;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.sketch-bbox-btn:hover{background:#f5f5f7}.sketch-bbox-btn.active{background:#0f3460;color:#fff;border-color:#0f3460}.sketch-svg-wrapper{flex:1;position:relative;display:flex;align-items:center;justify-content:center;width:100%;min-height:0}.sketch-svg-container{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.sketch-svg-container svg{max-width:100%;max-height:100%}.sketch-svg-container img{width:100%;height:auto;max-height:calc(100vh - 140px);object-fit:contain}.sketch-bbox-rect{position:absolute;border:2px solid;pointer-events:none;z-index:10}.sketch-bbox-label{position:absolute;top:-1px;left:-1px;padding:1px 6px;font-size:11px;font-weight:600;color:#fff;border-radius:0 0 4px;white-space:nowrap}.sketch-editor{flex:1;display:flex;flex-direction:column;height:100vh;overflow:hidden;background:#f5f5f7}.editor-topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:#fff;border-bottom:1px solid #e8e8ee;flex-shrink:0}.editor-topbar-left{display:flex;align-items:center}.editor-back-btn{padding:8px 16px;border:1px solid #d0d0d8;border-radius:6px;background:#fff;color:#1a1a2e;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.editor-back-btn:hover{background:#f5f5f7}.editor-topbar-center{display:flex;align-items:center;gap:8px}.editor-garment-name{font-size:15px;font-weight:600;color:#1a1a2e;text-transform:capitalize}.editor-mode-badge{font-size:11px;font-weight:600;color:#0f3460;background:#dbeafe;padding:2px 8px;border-radius:12px}.editor-mode-badge.segmenting{color:#b45309;background:#fef3c7}.editor-next-btn{padding:8px 20px;border:none;border-radius:6px;background:#0f3460;color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.editor-next-btn:hover{background:#1a4a80}.editor-reextract-btn{padding:8px 16px;border:1px solid #d0d0d8;border-radius:6px;background:#fff;color:#0f3460;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.editor-reextract-btn:hover:not(:disabled){background:#dbeafe;border-color:#93c5fd}.editor-reextract-btn:disabled{opacity:.6;cursor:not-allowed}.editor-body{flex:1;display:flex;min-height:0;overflow:hidden}.editor-layer-panel{flex:0 0 320px;display:flex;flex-direction:column;padding:16px;background:#fafafa;border-right:1px solid #e8e8ee;overflow-y:auto}.editor-panel-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#999;margin-bottom:12px}.editor-layer-list{display:flex;flex-direction:column;gap:12px}.editor-layer-group{display:flex;flex-direction:column;gap:4px}.editor-layer-group-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;color:#b0b0b8;margin-bottom:2px}.editor-layer-item{display:flex;align-items:center;gap:8px;padding:4px 6px;border-radius:4px;cursor:pointer;transition:background .15s}.editor-layer-item:hover{background:#f0f0f4}.editor-layer-item.loading{opacity:.6}.editor-layer-item input[type=checkbox]{accent-color:#0f3460;width:14px;height:14px}.editor-layer-name{font-size:13px;color:#1a1a2e;flex:1}.editor-layer-spinner{width:12px;height:12px;border:2px solid #e0e0e0;border-top-color:#0f3460;border-radius:50%;animation:spin .8s linear infinite}.editor-sketch-area{flex:1;display:flex;flex-direction:column;align-items:stretch;justify-content:stretch;background:#fff;min-width:0;min-height:0;overflow:hidden}.editor-sketch-container{flex:1;display:flex;align-items:center;justify-content:center;width:100%;min-height:0;padding:24px}.editor-sketch-container img{width:100%;height:auto;max-height:calc(100vh - 140px);object-fit:contain}.editor-sketch-loading{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px}.editor-sketch-loading .spinner{width:40px;height:40px;border:4px solid #e0e0e0;border-top-color:#0f3460;border-radius:50%;animation:spin .8s linear infinite}.editor-sketch-loading p{font-size:13px;color:#666}.segment-error-banner{display:flex;align-items:center;gap:12px;padding:10px 16px;background:#fef3c7;border:1px solid #f59e0b;border-radius:6px;margin:12px 24px 0}.segment-error-banner p{flex:1;font-size:13px;color:#92400e;margin:0}.segment-retry-btn{padding:6px 14px;border:1px solid #d97706;border-radius:5px;background:#fff;color:#92400e;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .15s}.segment-retry-btn:hover{background:#fffbeb}.design-canvas-container{flex:1;position:relative;min-height:0;width:100%;overflow:hidden}.design-canvas-loading{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;z-index:10;background:#fffc}.design-canvas-loading .spinner{width:32px;height:32px;border:3px solid #e0e0e0;border-top-color:#0f3460;border-radius:50%;animation:spin .8s linear infinite}.design-canvas-loading span{font-size:12px;color:#666}.editor-canvas-toolbar{display:flex;align-items:center;gap:4px;padding:6px 12px;background:#fafafa;border-bottom:1px solid #e8e8ee;flex-shrink:0;flex-wrap:wrap}.toolbar-group{display:flex;align-items:center;gap:2px}.toolbar-divider{width:1px;height:20px;background:#d0d0d8;margin:0 4px}.toolbar-btn{padding:4px 8px;border:1px solid #d0d0d8;border-radius:4px;background:#fff;color:#1a1a2e;font-size:11px;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap}.toolbar-btn:hover:not(:disabled){background:#f0f0f4}.toolbar-btn.active{background:#0f3460;color:#fff;border-color:#0f3460}.toolbar-btn:disabled{opacity:.4;cursor:not-allowed}.toolbar-zoom-label{font-size:11px;color:#666;min-width:36px;text-align:center}.editor-component-list{display:flex;flex-direction:column;gap:2px}.editor-component-item{display:flex;flex-direction:column;padding:6px 8px;border-radius:6px;cursor:pointer;transition:background .15s;border:1px solid transparent}.editor-component-item:hover{background:#f0f0f4}.editor-component-item.selected{background:#dbeafe;border-color:#93b5e8}.editor-component-item.drop-target{border-top:2px solid #0f3460}.component-row-top{display:flex;align-items:center;gap:8px}.component-thumb{width:40px;height:30px;object-fit:contain;border-radius:3px;border:1px solid #e0e0e0;background:#f9f9f9;flex-shrink:0}.component-name{font-size:12px;color:#1a1a2e;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.component-controls{display:flex;align-items:center;gap:4px;flex-shrink:0}.component-controls input[type=checkbox]{accent-color:#0f3460;width:13px;height:13px}.component-lock-btn{width:20px;height:20px;border:1px solid #d0d0d8;border-radius:3px;background:#fff;color:#999;font-size:10px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.component-lock-btn.locked{background:#fee2e2;color:#dc2626;border-color:#fca5a5}.extract-btn-group{display:flex;gap:1px}.component-extract-btn{width:22px;height:20px;border:1px solid #d0d0d8;border-radius:3px;background:#eff6ff;color:#3b82f6;font-size:9px;font-weight:700;cursor:pointer;padding:0;line-height:1}.extract-btn-group .component-extract-btn:first-child{border-radius:3px 0 0 3px}.extract-btn-group .component-extract-btn:last-child{border-radius:0 3px 3px 0}.extract-btn-group .component-extract-btn:not(:first-child):not(:last-child){border-radius:0}.component-extract-btn:hover{background:#dbeafe;border-color:#93c5fd}.component-row-actions{display:flex;align-items:center;gap:8px;padding:4px 0 0 48px}.component-opacity-label{display:flex;align-items:center;gap:4px;flex:1;min-width:0}.component-opacity-slider{flex:1;height:3px;accent-color:#0f3460;min-width:40px}.component-opacity-value{font-size:10px;color:#999;min-width:28px;text-align:right}.editor-chat-panel{flex:0 0 320px;display:flex;flex-direction:column;background:#fafafa;border-left:1px solid #e8e8ee;padding:16px 0 0}.editor-chat-panel .editor-panel-label{padding:0 16px}.editor-chat-messages{flex:1;overflow-y:auto;padding:8px 16px;display:flex;flex-direction:column;gap:12px}.editor-chat-msg{display:flex;flex-direction:column;gap:4px}.editor-chat-badge{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;padding:1px 6px;border-radius:4px;align-self:flex-start}.editor-chat-msg-user .editor-chat-badge{background:#e8e8ee;color:#666}.editor-chat-msg-assistant .editor-chat-badge{background:#dbeafe;color:#0f3460}.editor-chat-text{font-size:13px;color:#1a1a2e;line-height:1.5;padding:8px 12px;border-radius:8px;background:#fff;border:1px solid #e8e8ee}.editor-chat-msg-assistant .editor-chat-text{background:#f7f9fc}.editor-chat-thumb-wrapper{position:relative;display:inline-block;margin-top:4px}.editor-chat-thumb{width:120px;height:80px;object-fit:contain;border-radius:6px;border:1px solid #e8e8ee;cursor:pointer;transition:border-color .15s}.editor-chat-thumb-wrapper:hover .editor-chat-thumb{border-color:#0f3460}.editor-chat-restore-btn{position:absolute;bottom:4px;right:4px;padding:2px 8px;border:none;border-radius:4px;background:#0f3460d9;color:#fff;font-size:10px;font-weight:600;cursor:pointer;opacity:0;transition:opacity .15s}.editor-chat-thumb-wrapper:hover .editor-chat-restore-btn{opacity:1}.editor-chat-restore-btn:hover{background:#0f3460}.editor-chat-restore-btn:disabled{background:#969696b3;cursor:not-allowed}.editor-chat-typing{display:flex;align-items:center;gap:4px;padding:12px}.editor-typing-dot{width:6px;height:6px;background:#999;border-radius:50%;animation:typing-bounce 1.4s infinite ease-in-out both}.editor-typing-dot:nth-child(1){animation-delay:0s}.editor-typing-dot:nth-child(2){animation-delay:.16s}.editor-typing-dot:nth-child(3){animation-delay:.32s}@keyframes typing-bounce{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}.editor-chat-input-bar{display:flex;gap:8px;padding:12px 16px;border-top:1px solid #e8e8ee;background:#fff}.editor-chat-input{flex:1;padding:8px 12px;border:1px solid #d0d0d8;border-radius:6px;font-size:13px;outline:none;transition:border-color .15s}.editor-chat-input:focus{border-color:#0f3460}.editor-chat-input:disabled{background:#f5f5f7;cursor:not-allowed}.editor-chat-send{padding:8px 16px;border:none;border-radius:6px;background:#0f3460;color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.editor-chat-send:hover:not(:disabled){background:#1a4a80}.editor-chat-send:disabled{background:#b0b0b8;cursor:not-allowed}.editor-layers-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 16px;gap:8px}.editor-layers-loading .spinner{width:24px;height:24px;border:3px solid #e0e0e0;border-top-color:#0f3460;border-radius:50%;animation:spin .8s linear infinite}.editor-layers-loading p{font-size:12px;color:#999}.canvas-scale-bar{position:absolute;bottom:16px;left:16px;display:flex;flex-direction:column;align-items:flex-start;gap:2px;pointer-events:none;z-index:5}.scale-label{font-size:11px;font-weight:700;color:#d22828;background:#ffffffe6;padding:1px 6px;border-radius:2px}.scale-line{height:5px;background:#d22828;border-left:3px solid #d22828;border-right:3px solid #d22828;min-width:20px}.base-sketch-entry{border-bottom:1px solid #e0e0e8;margin-bottom:4px;padding-bottom:8px;cursor:default}.base-sketch-thumb{width:40px;height:30px;border-radius:3px;border:1px solid #e0e0e0;background:repeating-conic-gradient(#e8e8e8 0% 25%,#f5f5f5 0% 50%) 50% / 8px 8px;flex-shrink:0}.editor-component-item.loading{opacity:.6}.component-loading-overlay{position:absolute;border:2px dashed #3b82f6;border-radius:4px;pointer-events:none;display:flex;align-items:center;justify-content:center}.parts-view{flex:1;display:flex;flex-direction:column;height:100%;background:#f5f5f7}.parts-topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:#fff;border-bottom:1px solid #e8e8ee;flex-shrink:0}.parts-topbar-left{display:flex;align-items:center}.parts-back-btn{padding:8px 16px;border:1px solid #d0d0d8;border-radius:6px;background:#fff;color:#1a1a2e;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.parts-back-btn:hover{background:#f5f5f7}.parts-topbar-center{display:flex;align-items:center;gap:8px}.parts-garment-name{font-size:15px;font-weight:600;color:#1a1a2e;text-transform:capitalize}.parts-stage-badge{font-size:11px;font-weight:600;color:#4a90d9;background:#ebf3fc;padding:2px 8px;border-radius:12px}.parts-next-btn{padding:8px 20px;border:none;border-radius:6px;background:#0f3460;color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.parts-next-btn:hover{background:#1a4a80}.parts-body{flex:1;display:flex;min-height:0;overflow:hidden}.parts-left{flex:0 0 320px;display:flex;flex-direction:column;padding:24px;gap:16px;background:#fafafa;overflow-y:auto;border-right:1px solid #e8e8ee}.parts-left-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#999}.parts-inspiration-img{max-width:100%;max-height:200px;object-fit:contain;border-radius:8px;border:1px solid #e8e8ee}.parts-legend{display:flex;flex-direction:column;gap:8px}.parts-legend-item{display:flex;align-items:flex-start;gap:10px;padding:6px 8px;border-radius:6px;transition:background .15s}.parts-legend-item:hover{background:#f0f0f4}.parts-legend-number{flex-shrink:0;width:22px;height:22px;border-radius:50%;background:#4a90d9;color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center}.parts-legend-info{display:flex;flex-direction:column;gap:2px;min-width:0}.parts-legend-name{font-size:12px;font-weight:600;color:#1a1a2e;text-transform:uppercase;letter-spacing:.3px}.parts-legend-desc{font-size:11px;color:#666;line-height:1.3}.parts-legend-dims{font-size:10px;font-weight:600;color:#0f3460;background:#e8f0fe;padding:1px 6px;border-radius:3px;display:inline-block;width:fit-content;letter-spacing:.2px}.parts-legend-view-badge{font-size:9px;font-weight:600;text-transform:uppercase;padding:1px 5px;border-radius:3px;display:inline-block;width:fit-content}.parts-legend-view-badge.front{color:#4a90d9;background:#ebf3fc}.parts-legend-view-badge.back{color:#d97a4a;background:#fdf2eb}.parts-right{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:16px 24px;background:#fff;overflow:auto;min-width:0}.parts-right-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#999;margin-bottom:12px}.parts-sketch-wrapper{position:relative;display:inline-block;max-width:100%}.parts-sketch-img{display:block;max-width:100%;max-height:calc(100vh - 160px);object-fit:contain}.parts-svg-overlay{position:absolute;top:0;left:0;pointer-events:none}.parts-callout-dot{fill:#4a90d9;stroke:#fff;stroke-width:1}.parts-callout-line{stroke:#4a90d9;stroke-width:.8;fill:none;opacity:.7}.parts-callout-number-bg{fill:#4a90d9;stroke:#fff;stroke-width:1}.parts-callout-number{fill:#fff;font-size:8px;font-weight:700;text-anchor:middle;dominant-baseline:central}.parts-bbox-group{pointer-events:none;opacity:.35;transition:opacity .2s}.parts-svg-overlay:hover .parts-bbox-group{opacity:.7}.parts-bbox-rect{fill:none;stroke:#0f3460;stroke-width:1;stroke-dasharray:4 3}.parts-bbox-label{fill:#0f3460;font-size:9px;font-weight:600;text-anchor:middle;dominant-baseline:hanging}.parts-bbox-label-v{dominant-baseline:auto}.parts-loading-overlay{position:absolute;inset:0;background:#ffffffbf;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;border-radius:8px}.parts-loading-spinner{width:36px;height:36px;border:3px solid #e8e8ee;border-top-color:#4a90d9;border-radius:50%;animation:parts-spin .8s linear infinite}@keyframes parts-spin{to{transform:rotate(360deg)}}.parts-loading-text{font-size:13px;font-weight:500;color:#4a90d9}.parts-legend-loading{color:#999;font-size:12px;padding:4px 0}.parts-legend-error{color:#e74c3c;font-size:12px;padding:8px;background:#fdf2f2;border-radius:6px;border:1px solid #f5c6cb}.parts-sketch-fallback{width:100%;display:flex;align-items:center;justify-content:center}.parts-sketch-fallback img{max-width:100%;max-height:calc(100vh - 160px);object-fit:contain}.parts-sketch-fallback svg{max-width:100%;max-height:calc(100vh - 160px)}.parts-no-overlay-msg{position:absolute;bottom:12px;left:50%;transform:translate(-50%);background:#0009;color:#fff;font-size:12px;padding:6px 14px;border-radius:4px;white-space:nowrap}.parts-legend-item{cursor:pointer}.parts-legend-item.active{background:#ebf3fc;border:1px solid #4A90D9;border-radius:6px}.parts-callout-group{pointer-events:all;cursor:pointer}.parts-callout-group:hover .parts-callout-number-bg,.parts-callout-group:hover .parts-callout-dot{fill:#1a4a80}.parts-detail-panel{width:100%;height:100%;display:flex;flex-direction:column;overflow:hidden}.parts-detail-header{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid #e8e8ee;flex-shrink:0}.parts-detail-back-btn{padding:6px 12px;border:1px solid #d0d0d8;border-radius:5px;background:#fff;color:#1a1a2e;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s}.parts-detail-back-btn:hover{background:#f5f5f7}.parts-detail-title{font-size:15px;font-weight:700;color:#1a1a2e;text-transform:uppercase;letter-spacing:.3px}.parts-detail-content{flex:1;overflow-y:auto;padding:20px 24px;display:flex;flex-direction:column;gap:24px}.parts-detail-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:60px 0}.parts-detail-error{color:#e74c3c;font-size:13px;padding:16px;background:#fdf2f2;border-radius:8px;border:1px solid #f5c6cb;display:flex;align-items:center;gap:12px}.parts-detail-retry-btn{padding:6px 14px;border:1px solid #e74c3c;border-radius:5px;background:#fff;color:#e74c3c;font-size:12px;font-weight:500;cursor:pointer;flex-shrink:0}.parts-detail-retry-btn:hover{background:#fdf2f2}.parts-detail-section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#999;margin-bottom:8px;display:block}.parts-detail-image-section{display:flex;flex-direction:column}.parts-detail-image{max-width:100%;max-height:400px;object-fit:contain;border-radius:8px;border:1px solid #e8e8ee}.parts-detail-specs-section{display:flex;flex-direction:column}.parts-detail-spec-grid{display:flex;flex-direction:column;gap:10px}.parts-detail-spec-item{padding:12px 14px;border-left:3px solid #4A90D9;background:#fafbfd;border-radius:0 6px 6px 0}.parts-detail-spec-label{display:block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:#4a90d9;margin-bottom:4px}.parts-detail-spec-value{display:block;font-size:13px;color:#333;line-height:1.5;white-space:pre-wrap}.parts-detail-progress{position:relative;height:28px;background:#e8e8ee;overflow:hidden;display:flex;align-items:center;padding:0 12px;flex-shrink:0}.parts-detail-progress-bar{position:absolute;left:0;top:0;bottom:0;background:#4a90d9;opacity:.25;transition:width .3s ease}.parts-detail-progress span{position:relative;font-size:11px;font-weight:600;color:#1a1a2e;letter-spacing:.3px}.spec-canvas-container{flex:1;position:relative;background:#eeeef2;overflow:hidden;min-height:0}.spec-canvas-controls{position:absolute;top:12px;right:12px;z-index:10;display:flex;align-items:center;gap:6px}.spec-canvas-btn{padding:5px 10px;border:1px solid #d0d0d8;border-radius:4px;background:#fff;color:#1a1a2e;font-size:11px;font-weight:500;cursor:pointer;transition:all .15s}.spec-canvas-btn:hover{background:#f5f5f7}.spec-canvas-zoom{font-size:11px;font-weight:600;color:#666;background:#fff;padding:4px 8px;border-radius:4px;border:1px solid #d0d0d8}.spec-inline-edit{position:absolute;z-index:20;padding:2px 6px;border:2px solid #D94A4A;border-radius:4px;font-size:12px;font-family:Consolas,monospace;color:#d94a4a;font-weight:600;background:#fff;outline:none;width:80px;text-align:center;box-shadow:0 2px 8px #00000026}.spec-canvas-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:8px;color:#999;font-size:13px}.spec-view{flex:1;display:flex;flex-direction:column;height:100%;background:#f5f5f7}.spec-topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:#fff;border-bottom:1px solid #e8e8ee;flex-shrink:0}.spec-topbar-left{display:flex;align-items:center}.spec-back-btn{padding:8px 16px;border:1px solid #d0d0d8;border-radius:6px;background:#fff;color:#1a1a2e;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.spec-back-btn:hover{background:#f5f5f7}.spec-topbar-center{display:flex;align-items:center;gap:8px}.spec-garment-name{font-size:15px;font-weight:600;color:#1a1a2e;text-transform:capitalize}.spec-stage-badge{font-size:11px;font-weight:600;color:#0f7b6c;background:#e6f7f4;padding:2px 8px;border-radius:12px}.spec-model-badge{font-size:10px;font-weight:500;color:#555;background:#f0f0f0;padding:2px 6px;border-radius:10px}.spec-next-btn{padding:8px 20px;border:none;border-radius:6px;background:#0f3460;color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.spec-next-btn:hover{background:#1a4a80}.spec-size-bar{display:flex;align-items:center;gap:4px;padding:8px 24px;background:#fff;border-bottom:1px solid #e8e8ee;flex-shrink:0}.spec-size-label{font-size:12px;font-weight:600;color:#666;margin-right:8px}.spec-size-btn{padding:4px 12px;border:1px solid #d0d0d8;border-radius:4px;background:#fff;color:#1a1a2e;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}.spec-size-btn:hover{background:#f0f0f4}.spec-size-btn.active{background:#0f3460;color:#fff;border-color:#0f3460}.spec-body{flex:1;display:flex;min-height:0;overflow:hidden}.spec-left{flex:0 0 380px;display:flex;flex-direction:column;padding:20px;gap:12px;background:#fafafa;overflow-y:auto;border-right:1px solid #e8e8ee}.spec-left-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#999}.spec-inspiration-img{max-width:100%;max-height:160px;object-fit:contain;border-radius:8px;border:1px solid #e8e8ee}.spec-table-loading{font-size:12px;color:#999;padding:8px 0}.spec-table{width:100%;border-collapse:collapse;font-size:11px}.spec-table th{text-align:center;padding:6px 4px;font-weight:700;color:#666;border-bottom:2px solid #e8e8ee;font-size:10px;text-transform:uppercase}.spec-table th:first-child{text-align:left;padding-left:8px}.spec-table th.active{color:#0f3460;border-bottom-color:#0f3460}.spec-table td{text-align:center;padding:5px 4px;border-bottom:1px solid #f0f0f4;color:#444;cursor:pointer;transition:background .1s}.spec-table td:first-child{text-align:left;padding-left:8px;cursor:default}.spec-table td:hover:not(:first-child){background:#f0f5ff}.spec-table-name{font-weight:600;color:#1a1a2e;white-space:nowrap}.spec-table td.active{font-weight:700;color:#0f3460;background:#f0f5ff}.spec-table-sketch-val{font-weight:700!important;color:#d94a4a!important;background:#fdf2f2;text-align:center}.spec-table-cell-modified{color:#e67e22!important;font-weight:700!important}.spec-table-cell-editing{padding:2px!important}.spec-table-input{width:100%;padding:3px 4px;border:2px solid #0f3460;border-radius:3px;font-size:11px;font-weight:600;text-align:center;color:#0f3460;outline:none;background:#f0f5ff}.spec-table-row-highlight{background:#f0f5ff!important}.spec-table-row-highlight td:first-child{border-left:3px solid #4A90D9}.spec-table tbody tr:hover{background:#f5f5f7}.spec-right{flex:1;display:flex;flex-direction:column;position:relative;background:#fff;overflow:hidden;min-width:0}.spec-layer-panel{display:flex;flex-direction:column;gap:2px}.spec-layer-row{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:5px;transition:all .15s;cursor:grab}.spec-layer-row:hover{background:#f0f0f4}.spec-layer-row.dragging{opacity:.4}.spec-layer-row.drop-target{border-top:2px solid #4A90D9}.spec-layer-handle{color:#bbb;font-size:12px;cursor:grab;-webkit-user-select:none;user-select:none;letter-spacing:-2px}.spec-layer-toggle{display:flex;align-items:center;gap:6px;cursor:pointer;flex:1}.spec-layer-toggle input[type=checkbox]{accent-color:#0f3460;cursor:pointer}.spec-layer-label{font-size:12px;font-weight:500;color:#333}.spec-dims-loading{position:absolute;top:12px;left:50%;transform:translate(-50%);z-index:50;display:flex;align-items:center;gap:8px;padding:8px 16px;background:#fffffff2;border:1px solid #e8e8ee;border-radius:8px;box-shadow:0 2px 8px #0000001a;font-size:12px;color:#666}.spec-inline-edit{position:fixed;z-index:100;padding:2px 6px;border:2px solid #D94A4A;border-radius:4px;font-size:12px;font-family:Consolas,monospace;color:#d94a4a;font-weight:600;background:#fff;outline:none;width:80px;text-align:center;box-shadow:0 2px 8px #00000026}.tp-view{flex:1;display:flex;flex-direction:column;height:100%;background:#f5f5f7}.tp-topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:#fff;border-bottom:1px solid #e8e8ee;flex-shrink:0}.tp-topbar-left{display:flex;align-items:center}.tp-back-btn{padding:8px 16px;border:1px solid #d0d0d8;border-radius:6px;background:#fff;color:#1a1a2e;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.tp-back-btn:hover{background:#f5f5f7}.tp-topbar-center{display:flex;align-items:center;gap:8px}.tp-garment-name{font-size:15px;font-weight:600;color:#1a1a2e;text-transform:capitalize}.tp-stage-badge{font-size:11px;font-weight:600;color:#7c3aed;background:#f3e8ff;padding:2px 8px;border-radius:12px}.tp-tab-bar{display:flex;gap:0;background:#fff;border-bottom:2px solid #e8e8ee;padding:0 24px;flex-shrink:0}.tp-tab{padding:12px 20px;border:none;background:none;font-size:13px;font-weight:500;color:#666;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s}.tp-tab:hover{color:#1a1a2e}.tp-tab.active{color:#0f3460;border-bottom-color:#0f3460;font-weight:600}.tp-content{flex:1;overflow-y:auto;padding:24px}.tp-section{margin-bottom:24px}.tp-section-title{font-size:14px;font-weight:700;color:#1a1a2e;margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid #e8e8ee}.tp-section-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#888;display:block;margin-bottom:8px}.tp-table{width:100%;border-collapse:collapse;font-size:12px;background:#fff;border-radius:8px;overflow:hidden;border:1px solid #e8e8ee}.tp-table th{text-align:left;padding:10px 12px;background:#f8f8fa;color:#555;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.03em;border-bottom:1px solid #e8e8ee}.tp-table td{padding:10px 12px;border-bottom:1px solid #f0f0f4;color:#333;vertical-align:top}.tp-table tr:last-child td{border-bottom:none}.tp-table tr:hover td{background:#fafafe}.tp-overview{display:flex;gap:24px;flex-wrap:wrap}.tp-overview-images{display:flex;gap:16px;flex-wrap:wrap}.tp-overview-img-card{background:#fff;border:1px solid #e8e8ee;border-radius:8px;padding:12px;display:flex;flex-direction:column;gap:8px}.tp-overview-img-card img{max-width:280px;max-height:320px;object-fit:contain;border-radius:4px}.tp-overview-details{flex:1;min-width:260px;background:#fff;border:1px solid #e8e8ee;border-radius:8px;padding:16px}.tp-detail-grid{display:flex;flex-direction:column;gap:0}.tp-detail-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #f0f0f4;font-size:13px}.tp-detail-row:last-child{border-bottom:none}.tp-detail-key{color:#888;font-weight:500}.tp-detail-val{color:#1a1a2e;font-weight:600;text-transform:capitalize}.tp-bom{display:flex;flex-direction:column;gap:20px}.tp-bom-group{background:#fff;border:1px solid #e8e8ee;border-radius:8px;overflow:hidden}.tp-bom-group-title{font-size:13px;font-weight:700;color:#1a1a2e;padding:12px 16px;margin:0;background:#f8f8fa;border-bottom:1px solid #e8e8ee}.tp-bom-group .tp-table{border:none;border-radius:0}.tp-bom-name{font-weight:600;color:#1a1a2e}.tp-color-cell{display:flex;align-items:center;gap:6px}.tp-color-swatch{display:inline-block;width:16px;height:16px;border-radius:3px;border:1px solid #ddd;flex-shrink:0}.tp-bom-notes{font-size:12px;color:#666;padding:12px 16px;background:#fffbeb;border:1px solid #fde68a;border-radius:8px}.tp-measurements{display:flex;gap:24px}.tp-measurements-left{flex:0 0 300px}.tp-measurements-sketch{background:#fff;border:1px solid #e8e8ee;border-radius:8px;padding:12px}.tp-measurements-sketch img{width:100%;object-fit:contain;border-radius:4px}.tp-measurements-right{flex:1;min-width:0}.tp-size-bar{display:flex;align-items:center;gap:4px;margin-bottom:16px}.tp-size-label{font-size:12px;font-weight:600;color:#888;margin-right:8px}.tp-size-btn{padding:4px 12px;border:1px solid #d0d0d8;border-radius:4px;background:#fff;font-size:12px;font-weight:500;color:#555;cursor:pointer;transition:all .15s}.tp-size-btn.active{background:#0f3460;color:#fff;border-color:#0f3460}.tp-pom-table th.active-size,.tp-pom-table td.active-size{background:#eef2ff;font-weight:600}.tp-pom-name{font-weight:600;color:#1a1a2e}.tp-unit-note{font-size:11px;color:#888;margin-top:8px}.tp-empty{font-size:13px;color:#888;padding:24px;text-align:center}.tp-construction{display:flex;flex-direction:column;gap:24px}.tp-assembly-list{background:#fff;border:1px solid #e8e8ee;border-radius:8px;padding:16px 16px 16px 36px;margin:0}.tp-assembly-step{padding:8px 0;border-bottom:1px solid #f0f0f4;font-size:13px;display:flex;flex-direction:column;gap:2px}.tp-assembly-step:last-child{border-bottom:none}.tp-step-desc{color:#1a1a2e;font-weight:500}.tp-step-parts{font-size:11px;color:#0f3460}.tp-step-notes{font-size:11px;color:#888;font-style:italic}.tp-list{background:#fff;border:1px solid #e8e8ee;border-radius:8px;padding:16px 16px 16px 36px;margin:0;font-size:13px;color:#333}.tp-list li{padding:4px 0}.tp-flats{display:flex;flex-direction:column;gap:24px}.tp-panels-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.tp-panel-card{background:#fff;border:1px solid #e8e8ee;border-radius:8px;overflow:hidden}.tp-panel-svg{padding:12px;display:flex;justify-content:center;align-items:center;background:#fafafa;min-height:200px}.tp-panel-svg svg{max-width:100%;max-height:300px}.tp-panel-info{padding:10px 12px;border-top:1px solid #e8e8ee;display:flex;flex-direction:column;gap:2px}.tp-panel-name{font-size:13px;font-weight:600;color:#1a1a2e}.tp-panel-dims,.tp-panel-sa{font-size:11px;color:#888}.tp-assembly-svg{background:#fff;border:1px solid #e8e8ee;border-radius:8px;padding:16px;display:flex;justify-content:center}.tp-assembly-svg svg{max-width:100%;max-height:500px}.tp-components-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}.tp-component-card{background:#fff;border:1px solid #e8e8ee;border-radius:8px;overflow:hidden}.tp-component-card img{width:100%;height:150px;object-fit:contain;background:#fafafa;padding:8px}.tp-component-info{padding:8px 10px;border-top:1px solid #e8e8ee;display:flex;flex-direction:column;gap:2px}.tp-component-name{font-size:12px;font-weight:600;color:#1a1a2e}.tp-component-dims{font-size:11px;color:#888}.tp-download-btn{display:inline-block;padding:10px 24px;background:#0f3460;color:#fff;border-radius:6px;font-size:13px;font-weight:600;text-decoration:none;transition:all .15s}.tp-download-btn:hover{background:#1a4a80}.tp-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:60px}.tp-loading-spinner{width:40px;height:40px;border:4px solid #e0e0e0;border-top-color:#0f3460;border-radius:50%;animation:tp-spin .8s linear infinite}@keyframes tp-spin{to{transform:rotate(360deg)}}.tp-loading-text{font-size:14px;color:#666}.vision-page{flex:1;overflow-y:auto;background:#f5f5f7;display:flex;align-items:flex-start;justify-content:center;padding:40px 24px}.vision-content{max-width:800px;width:100%;display:flex;flex-direction:column;gap:24px}.vision-upload-area{width:100%}.drop-zone{border:2px dashed #ccc;border-radius:12px;padding:60px;text-align:center;background:#fff;transition:all .15s}.drop-zone.drag-over{background:#d5e8d4;border-color:#2ecc71}.drop-loading{display:flex;flex-direction:column;align-items:center;gap:12px}.drop-loading p{font-size:14px;color:#666}.drop-title{font-size:18px;font-weight:600;color:#1a1a2e;margin-bottom:8px}.drop-sub{font-size:13px;color:#888;margin-bottom:16px}.upload-btn{padding:10px 24px;border:2px solid #0f3460;border-radius:8px;background:#0f3460;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s}.upload-btn:hover{background:#1a4a80}.drop-staged{display:flex;flex-direction:column;align-items:center;gap:16px}.drop-previews{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.drop-preview-thumb{width:120px;height:120px;object-fit:cover;border-radius:8px;border:2px solid #e8e8ee}.drop-staged-info{font-size:13px;color:#666}.drop-staged-actions{display:flex;gap:10px}.submit-btn{padding:10px 32px;font-size:15px}.clear-btn{background:#fff;color:#0f3460}.clear-btn:hover{background:#f0f4fa}.vision-pattern-toggle{display:flex;align-items:center;gap:8px;font-size:13px;color:#1a1a2e;cursor:pointer;-webkit-user-select:none;user-select:none}.vision-pattern-toggle input[type=checkbox]{width:16px;height:16px;accent-color:#0f3460;cursor:pointer}.vision-error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:12px 16px;border-radius:8px;font-size:13px}.vision-results-area{display:flex;gap:24px;background:#fff;border-radius:12px;padding:24px;border:1px solid #e8e8ee}.vision-preview{flex:0 0 240px}.vision-preview img{width:100%;border-radius:8px;object-fit:cover}.vision-details{flex:1;display:flex;flex-direction:column;gap:16px}.analysis-results h3{font-size:14px;font-weight:700;color:#1a1a2e;margin-bottom:8px}.analysis-meta{display:flex;gap:6px;margin-bottom:12px}.tag{background:#e94560;color:#fff;font-size:10px;padding:2px 8px;border-radius:12px;text-transform:capitalize}.tag.confidence{background:#2ecc71}.analysis-features{display:flex;flex-direction:column}.feature-row{display:flex;justify-content:space-between;font-size:12px;padding:4px 0;border-bottom:1px solid #f0f0f0}.feature-row span:last-child{font-weight:600;text-transform:capitalize}.comparison-section{margin-top:12px;padding-top:12px;border-top:1px solid #e8e8ee}.comparison-scores{display:flex;flex-direction:column;gap:2px}.comparison-score-row{display:flex;justify-content:space-between;font-size:12px;padding:3px 0}.comparison-score-row span:last-child{font-weight:600}.comparison-toggle{margin-top:8px;background:none;border:none;color:#0f3460;font-size:11px;font-weight:500;cursor:pointer;padding:0;text-decoration:underline}.comparison-toggle:hover{color:#1a4a80}.comparison-details{margin-top:8px;display:flex;flex-direction:column;gap:8px}.comparison-issue-group{font-size:11px}.comparison-issue-label{display:inline-block;font-weight:600;font-size:10px;text-transform:uppercase;letter-spacing:.3px;padding:1px 6px;border-radius:4px;margin-bottom:4px}.comparison-issue-label.warning{background:#fef3c7;color:#92400e}.comparison-issue-label.info{background:#dbeafe;color:#1e40af}.comparison-issue-group ul{margin:4px 0 0;padding-left:16px;list-style:disc}.comparison-issue-group li{font-size:11px;color:#444;line-height:1.4;margin-bottom:2px}.block-classification-section{margin-top:12px;padding-top:12px;border-top:1px solid #e8e8ee}.block-classification-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.block-classification-label{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:#888}.block-classification-value{font-size:13px;font-weight:600;color:#222}.block-construction-elements{margin-top:8px}.block-elements-label{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:#888;display:block;margin-bottom:4px}.block-elements-list{display:flex;flex-wrap:wrap;gap:4px}.block-element-tag{font-size:10px;padding:2px 8px;border-radius:10px;background:#dbeafe;color:#1e40af}.vision-generate-btn{padding:10px 24px;border:2px solid #0f3460;border-radius:8px;background:#0f3460;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s;align-self:flex-start}.vision-generate-btn:hover{background:#1a4a80}.spinner{width:40px;height:40px;border:4px solid #e0e0e0;border-top-color:#0f3460;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.garment-listing{width:100%}.garment-listing-header{font-size:13px;font-weight:600;color:#555;text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.garment-listing-loading,.garment-listing-error{font-size:13px;color:#999;padding:8px 0}.garment-listing-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.garment-card{background:#fff;border-radius:10px;overflow:hidden;border:1px solid #e8e8ee;cursor:pointer;transition:transform .15s,box-shadow .15s}.garment-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001a}.garment-card-thumb{position:relative;width:100%;aspect-ratio:3/4;background:#f0f0f5;overflow:hidden}.garment-card-thumb img{width:100%;height:100%;object-fit:cover}.garment-card-no-thumb{width:100%;height:100%;background:#e8e8ee}.garment-card-dots{position:absolute;bottom:6px;left:0;right:0;display:flex;justify-content:center;gap:4px}.garment-card-dot{width:5px;height:5px;border-radius:50%;background:#fff9}.garment-card-dot.active{background:#fff}.garment-card-info{padding:8px 10px;display:flex;flex-direction:column;gap:3px}.garment-card-name{font-size:12px;font-weight:600;color:#1a1a2e;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.garment-card-date{font-size:11px;color:#999}.garment-card-status{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;padding:2px 6px;border-radius:4px;align-self:flex-start;background:#e8e8ee;color:#666}.garment-card-status-generated{background:#e6f4ea;color:#2e7d32}.garment-card-status-parts_identified{background:#e3f2fd;color:#1565c0}.garment-card-status-created{background:#f5f5f5;color:#888}.garment-modal-overlay{position:fixed;inset:0;background:#00000073;z-index:1000;display:flex;align-items:center;justify-content:center}.garment-modal{background:#fff;border-radius:14px;padding:28px;width:90%;max-width:680px;max-height:85vh;overflow-y:auto;position:relative;box-shadow:0 12px 48px #0000002e}.garment-modal-close{position:absolute;top:16px;right:16px;background:none;border:none;font-size:22px;color:#888;cursor:pointer;line-height:1}.garment-modal-title{font-size:18px;font-weight:700;color:#1a1a2e;margin-bottom:16px;padding-right:32px}.garment-modal-loading,.garment-modal-error{font-size:14px;color:#999;padding:16px 0}.garment-modal-body{display:flex;gap:20px}.garment-modal-images{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:8px}.garment-modal-main-img{width:180px;height:240px;object-fit:cover;border-radius:8px;border:1px solid #e8e8ee}.garment-modal-dots{display:flex;gap:6px}.garment-modal-dot{width:7px;height:7px;border-radius:50%;background:#ddd;border:none;cursor:pointer;padding:0}.garment-modal-dot.active{background:#4a90d9}.garment-modal-meta{flex:1;display:flex;flex-direction:column;gap:16px}.garment-modal-sketch img{width:100%;max-height:140px;object-fit:contain;border-radius:6px;background:#f5f5f7}.garment-modal-label{font-size:11px;font-weight:600;color:#aaa;text-transform:uppercase;letter-spacing:.4px;display:block;margin-bottom:4px}.garment-modal-fields{display:flex;flex-direction:column;gap:8px}.garment-modal-field{display:flex;gap:8px;font-size:13px}.garment-modal-field-label{color:#888;min-width:80px;flex-shrink:0}.wizard-wrapper{display:flex;flex-direction:column;flex:1;overflow:hidden;height:100%}.wizard-breadcrumb{display:flex;align-items:center;padding:0 20px;height:36px;background:#fff;border-bottom:1px solid #e8e8ee;flex-shrink:0;gap:0}.wizard-breadcrumb-item{display:flex;align-items:center}.wizard-breadcrumb-sep{color:#ccc;font-size:14px;margin:0 2px;-webkit-user-select:none;user-select:none}.wizard-breadcrumb-btn{background:none;border:none;padding:4px 8px;border-radius:5px;font-size:12px;font-weight:500;cursor:pointer;color:#aaa;transition:background .12s,color .12s}.wizard-breadcrumb-btn.accessible{color:#555;cursor:pointer}.wizard-breadcrumb-btn.accessible:hover{background:#f0f0f5;color:#1a1a2e}.wizard-breadcrumb-btn.active{color:#1a1a2e;font-weight:700;background:#f0f0f5}.wizard-breadcrumb-btn.locked{cursor:default;opacity:.4}.wizard-step-content{flex:1;overflow:hidden;display:flex;flex-direction:column;min-height:0}.garment-modal-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;padding-right:32px}.garment-modal-header .garment-modal-title{margin-bottom:0;padding-right:0}.garment-modal-open-btn{flex-shrink:0;padding:8px 16px;background:#1a1a2e;color:#fff;border:none;border-radius:7px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s;white-space:nowrap}.garment-modal-open-btn:hover{background:#2d2d4a}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#f5f5f7;color:#1a1a2e}.app{min-height:100vh;display:flex;flex-direction:column}.app-content{display:flex;flex:1;overflow:hidden;height:calc(100vh - 50px)}
