*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #fafafa;--bg-secondary: #ffffff;--bg-panel: #ffffff;--bg-hover: #f5f5f7;--bg-input: #f5f5f7;--text-primary: #1d1d1f;--text-secondary: #86868b;--text-muted: #aeaeb2;--accent: #e8a4b8;--accent-dark: #d4869a;--accent-light: #fdf2f5;--accent-hover: #dba3b3;--border: #e5e5e7;--border-light: #f0f0f2;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .04);--shadow-md: 0 4px 12px rgba(0, 0, 0, .06);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .08);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px}body{font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,Roboto,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;font-size:14px;-webkit-font-smoothing:antialiased}.app{display:flex;flex-direction:column;height:100vh}.header{padding:1rem 1.5rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-light);display:flex;align-items:center;gap:.75rem}.header-logo{width:32px;height:32px;border-radius:var(--radius-sm)}.header h1{font-size:1rem;font-weight:600;letter-spacing:-.01em;color:var(--text-primary)}.workspace{display:grid;grid-template-columns:300px 1fr;flex:1;overflow:hidden}.sidebar{background:var(--bg-secondary);border-right:1px solid var(--border-light);overflow-y:auto;padding:1.25rem;display:flex;flex-direction:column;gap:1rem}.panel{background:var(--bg-panel);border-radius:var(--radius-lg);padding:1.25rem;border:1px solid var(--border-light);box-shadow:var(--shadow-sm)}.panel h2{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:1rem}.upload-area{border:2px dashed var(--border);border-radius:var(--radius-md);padding:2rem 1.5rem;text-align:center;cursor:pointer;transition:all .2s ease;background:var(--bg-input)}.upload-area:hover,.upload-area.dragover{border-color:var(--accent);background:var(--accent-light)}.upload-area p{font-size:.8125rem;color:var(--text-secondary);line-height:1.5}.preview-image{width:100%;margin-top:1rem;border-radius:var(--radius-md);border:1px solid var(--border-light)}.hidden{display:none!important}.form-group{margin-bottom:1rem}.form-group:last-of-type{margin-bottom:0}.form-group label{display:block;font-size:.75rem;font-weight:500;color:var(--text-secondary);margin-bottom:.375rem}.form-group select,.form-group input[type=number]{width:100%;padding:.625rem .875rem;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.875rem;font-family:inherit;transition:all .2s ease;-webkit-appearance:none;appearance:none}.form-group select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2386868b' d='M3 4.5L6 8l3-3.5H3z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2rem}.form-group select:focus,.form-group input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.checkbox-label{display:flex!important;align-items:center;gap:.5rem;font-size:.8125rem!important;font-weight:400!important;color:var(--text-primary)!important;cursor:pointer;margin-top:.625rem}.checkbox-label input[type=checkbox]{width:18px;height:18px;border-radius:5px;border:1.5px solid var(--border);background:var(--bg-input);cursor:pointer;-webkit-appearance:none;appearance:none;transition:all .2s ease}.checkbox-label input[type=checkbox]:checked{background:var(--accent);border-color:var(--accent);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='white' d='M10 3L4.5 8.5 2 6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center}.btn{width:100%;padding:.75rem 1rem;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;font-family:inherit;cursor:pointer;transition:all .2s ease;background:var(--bg-input);color:var(--text-primary);margin-bottom:.5rem;border:1px solid var(--border)}.btn:hover:not(:disabled){background:var(--bg-hover);border-color:var(--border)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn.primary{background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%);color:#fff;border:none;box-shadow:var(--shadow-sm)}.btn.primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn.primary:active:not(:disabled){transform:translateY(0)}#generate-btn{margin-top:1rem}.palette-editor{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem;max-height:200px;overflow-y:auto}.palette-color-item{display:flex;align-items:center;gap:.625rem;padding:.5rem;background:var(--bg-input);border-radius:var(--radius-sm);border:1px solid var(--border-light)}.color-picker-input{width:36px;height:36px;padding:0;border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;background:none}.color-picker-input::-webkit-color-swatch-wrapper{padding:2px}.color-picker-input::-webkit-color-swatch{border:none;border-radius:4px}.color-hex-label{flex:1;font-family:SF Mono,Monaco,monospace;font-size:.8125rem;color:var(--text-secondary)}.btn-delete-color{width:28px;height:28px;padding:0;border:none;background:transparent;color:var(--text-muted);font-size:1.25rem;cursor:pointer;border-radius:var(--radius-sm);transition:all .15s ease;display:flex;align-items:center;justify-content:center}.btn-delete-color:hover{background:var(--accent-light);color:var(--accent-dark)}.canvas-container{position:relative;overflow:hidden;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;background-image:linear-gradient(45deg,#f0f0f2 25%,transparent 25%),linear-gradient(-45deg,#f0f0f2 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#f0f0f2 75%),linear-gradient(-45deg,transparent 75%,#f0f0f2 75%);background-size:20px 20px;background-position:0 0,0 10px,10px -10px,-10px 0px}#pattern-canvas{background:#fff;box-shadow:var(--shadow-lg);border-radius:var(--radius-sm)}.canvas-placeholder{position:absolute;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem}.canvas-placeholder p{color:var(--text-muted);font-size:.9375rem}.summary-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--bg-secondary);border:none;border-radius:var(--radius-xl);padding:0;max-width:520px;width:90%;max-height:85vh;overflow:hidden;color:var(--text-primary);box-shadow:var(--shadow-lg),0 0 0 1px var(--border-light)}.summary-modal::backdrop{background:#0000004d;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;background:var(--bg-panel);border-bottom:1px solid var(--border-light)}.modal-header h2{font-size:1rem;font-weight:600}.btn-close{background:var(--bg-input);border:none;color:var(--text-secondary);width:28px;height:28px;border-radius:50%;font-size:1.125rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;line-height:1}.btn-close:hover{background:var(--accent-light);color:var(--accent-dark)}.modal-body{padding:1.5rem;overflow-y:auto;max-height:calc(85vh - 70px)}.modal-body h3{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-top:1.5rem;margin-bottom:1rem}.summary-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.stat-item{background:var(--bg-input);padding:1rem;border-radius:var(--radius-md);border:1px solid var(--border-light)}.stat-label{display:block;font-size:.6875rem;font-weight:500;text-transform:uppercase;letter-spacing:.03em;color:var(--text-muted);margin-bottom:.25rem}.stat-value{display:block;font-size:1.125rem;font-weight:600;color:var(--text-primary)}.palette-list{display:flex;flex-direction:column;gap:.5rem;max-height:280px;overflow-y:auto;padding-right:.5rem}.palette-list::-webkit-scrollbar{width:6px}.palette-list::-webkit-scrollbar-track{background:transparent}.palette-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.palette-item{display:flex;align-items:center;gap:.875rem;padding:.75rem 1rem;background:var(--bg-input);border-radius:var(--radius-md);border:1px solid var(--border-light);transition:all .15s ease}.palette-item:hover{border-color:var(--accent);background:var(--accent-light)}.palette-symbol{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-weight:700;font-family:SF Mono,Monaco,monospace;font-size:.9375rem;border-radius:var(--radius-sm);flex-shrink:0;box-shadow:var(--shadow-sm)}.palette-info{flex:1;min-width:0}.palette-name{font-size:.875rem;color:var(--text-primary);font-weight:500;margin-bottom:.125rem}.palette-code{font-size:.75rem;color:var(--text-secondary)}.palette-count{text-align:right;display:flex;flex-direction:column;gap:.125rem}.count-stitches{font-size:.8125rem;font-weight:600;color:var(--text-primary)}.count-skeins{font-size:.6875rem;color:var(--text-muted)}.text-muted{color:var(--text-muted);font-size:.8125rem;text-align:center;padding:1rem 0}.saved-patterns-list{display:flex;flex-direction:column;gap:.5rem;max-height:300px;overflow-y:auto}.saved-pattern-card{display:flex;align-items:center;gap:.75rem;padding:.625rem;background:var(--bg-input);border-radius:var(--radius-md);border:1px solid var(--border-light);cursor:pointer;transition:all .15s ease}.saved-pattern-card:hover{border-color:var(--accent);background:var(--accent-light)}.pattern-thumbnail{width:48px;height:48px;border-radius:var(--radius-sm);object-fit:cover;border:1px solid var(--border-light);flex-shrink:0}.pattern-card-info{flex:1;min-width:0}.pattern-card-name{font-size:.8125rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pattern-card-meta{font-size:.6875rem;color:var(--text-secondary);margin-top:.125rem}.pattern-card-date{font-size:.625rem;color:var(--text-muted);margin-top:.125rem}.pattern-card-actions{display:flex;gap:.25rem;flex-shrink:0}.load-pattern-btn,.delete-pattern-btn{width:28px;height:28px;padding:0;border:none;background:transparent;color:var(--text-muted);font-size:1rem;cursor:pointer;border-radius:var(--radius-sm);transition:all .15s ease;display:flex;align-items:center;justify-content:center}.load-pattern-btn:hover{background:var(--accent);color:#fff}.delete-pattern-btn:hover{background:#fee2e2;color:#dc2626}.header-btn{height:36px;padding:0 .875rem;margin-left:auto;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;color:var(--text-secondary);font-size:.8125rem;font-weight:500;font-family:inherit;transition:all .2s ease}.header-btn span{white-space:nowrap}.header-btn:hover{background:var(--accent-light);border-color:var(--accent);color:var(--accent-dark)}.exit-embroidery-btn{position:fixed;top:1rem;left:1rem;z-index:9999;width:44px;height:44px;padding:0;background:#fffffff2;border:1px solid var(--border);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-primary);box-shadow:var(--shadow-md);transition:all .2s ease}.exit-embroidery-btn:hover{background:var(--accent-light);border-color:var(--accent);color:var(--accent-dark);transform:scale(1.05)}body.embroidery-mode .header,body.embroidery-mode .sidebar,body.embroidery-mode .sidebar-overlay{display:none!important}body.embroidery-mode .workspace{grid-template-columns:1fr}body.embroidery-mode .canvas-container{height:100vh}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.menu-toggle{display:none;width:36px;height:36px;padding:8px;margin-left:auto;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;flex-direction:column;justify-content:center;gap:4px}.menu-toggle span{display:block;width:100%;height:2px;background:var(--text-primary);border-radius:1px;transition:all .2s ease}.menu-toggle.active span:nth-child(1){transform:rotate(45deg) translate(4px,4px)}.menu-toggle.active span:nth-child(2){opacity:0}.menu-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}.sidebar-overlay{display:none;position:fixed;inset:0;background:#0000004d;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:90;opacity:0;transition:opacity .3s ease}.sidebar-overlay.active{opacity:1}@media(max-width:768px){.menu-toggle{display:flex}.workspace{grid-template-columns:1fr}.sidebar{position:fixed;top:0;right:-320px;width:300px;height:100vh;z-index:100;border-right:none;border-left:1px solid var(--border-light);box-shadow:var(--shadow-lg);transition:right .3s ease;padding-top:80px}.sidebar.open{right:0}.sidebar-overlay{display:block}.canvas-container{height:calc(100vh - 60px)}.header{position:relative;z-index:101}.summary-modal{width:95%;max-height:90vh}.summary-stats{grid-template-columns:1fr}.header-btn span{display:none}.header-btn{padding:0;width:36px}}
