:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.pattern-grid-container{display:flex;justify-content:center;padding:5px;overflow:hidden;max-width:100%;width:100%}.pattern-grid{display:grid;gap:0;background-color:#333;border:2px solid #333;min-width:fit-content;min-height:fit-content}.pattern-cell{width:24px;height:24px;cursor:pointer;transition:all .1s ease;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;border:1px solid rgba(0,0,0,.1);outline:none}.pattern-cell:hover{opacity:.8}.pattern-cell:focus{outline:2px solid #007acc;outline-offset:1px}.stitch-knit{background-color:#f8f8f8;color:#333}.stitch-knit:after{content:""}.stitch-purl{background-color:#e8e8e8;color:#666}.stitch-purl:after{content:"•"}.stitch-cable{background-color:#f0f0f0;color:#444}.stitch-cable:after{content:"◊"}.stitch-yarnover{background-color:#fff8dc;color:#666}.stitch-yarnover:after{content:"○"}.stitch-slip{background-color:#e0e0e0;color:#555}.stitch-slip:after{content:"↓"}.stitch-k2tog{background-color:#f5f5f5;color:#444}.stitch-k2tog:after{content:"∧"}.stitch-ssk{background-color:#f5f5f5;color:#444}.stitch-ssk:after{content:"∨"}.stitch-p2tog{background-color:#e8e8e8;color:#555}.stitch-p2tog:after{content:"∩"}.stitch-braiding{background-color:#ffccbc;color:#e65100}.stitch-braiding:after{content:""}.braiding-symbol{font-size:14px;font-weight:700;color:inherit}.pattern-cell[style*=backgroundColor]{color:#fff;text-shadow:1px 1px 1px rgba(0,0,0,.7);border:1px solid rgba(0,0,0,.2)}.pattern-cell[style*=backgroundColor].stitch-knit,.pattern-cell[style*=backgroundColor].stitch-purl,.pattern-cell[style*=backgroundColor].stitch-cable,.pattern-cell[style*=backgroundColor].stitch-yarnover,.pattern-cell[style*=backgroundColor].stitch-slip,.pattern-cell[style*=backgroundColor].stitch-k2tog,.pattern-cell[style*=backgroundColor].stitch-ssk,.pattern-cell[style*=backgroundColor].stitch-p2tog,.pattern-cell[style*=backgroundColor].stitch-braiding{background-color:inherit!important}@media (max-width: 768px){.pattern-cell{width:16px;height:16px;font-size:10px}}@media (max-width: 480px){.pattern-cell{width:14px;height:14px;font-size:9px}}.stitch-palette{background:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;padding:8px;margin-bottom:6px}.stitch-palette h3{margin:0 0 8px;font-size:14px;color:#333;font-weight:600}.stitch-options{display:flex;gap:4px;flex-wrap:wrap}.stitch-option{display:flex;flex-direction:column;align-items:center;padding:6px 8px;border:2px solid #dee2e6;border-radius:4px;background:#fff;cursor:pointer;transition:all .2s ease;min-width:50px}.stitch-option:hover{border-color:#007acc;background:#f0f8ff}.stitch-option.active{border-color:#007acc;background:#007acc;color:#fff}.stitch-symbol{font-size:14px;font-weight:700;margin-bottom:2px;display:block}.stitch-label{font-size:9px;font-weight:500;text-transform:uppercase;letter-spacing:.3px}.stitch-option.active .stitch-symbol{color:#fff}.stitch-option:focus{outline:2px solid #007acc;outline-offset:2px}.stitch-type-braiding{background-color:#ffccbc;color:#e65100}.color-palette{background:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;padding:8px;margin-bottom:6px}.color-palette-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.color-palette h3{margin:0;font-size:14px;color:#333;font-weight:600}.add-color-btn{background:#007acc;color:#fff;border:none;border-radius:50%;width:22px;height:22px;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s ease}.add-color-btn:hover{background:#005a9e}.color-swatches{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:10px}.color-swatch-container{position:relative;display:flex;flex-direction:column;align-items:center}.color-swatch{display:flex;flex-direction:column;align-items:center;padding:4px;border:2px solid #dee2e6;border-radius:4px;background:#fff;cursor:pointer;transition:all .2s ease;min-width:45px;position:relative}.color-swatch:hover{border-color:#007acc;background:#f0f8ff}.color-swatch.active{border-color:#007acc;background:#007acc;color:#fff}.color-preview{width:18px;height:18px;border-radius:3px;margin-bottom:2px;background-color:var(--color-preview, #ccc);border:1px solid #ddd}.color-preview.no-color{background:linear-gradient(45deg,#ccc 25%,transparent 25%),linear-gradient(-45deg,#ccc 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#ccc 75%),linear-gradient(-45deg,transparent 75%,#ccc 75%);background-size:8px 8px;background-position:0 0,0 4px,4px -4px,-4px 0px}.color-name{font-size:8px;font-weight:500;text-align:center;max-width:45px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.remove-color-btn{position:absolute;top:-3px;right:-3px;background:#dc3545;color:#fff;border:none;border-radius:50%;width:14px;height:14px;font-size:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease}.color-swatch-container:hover .remove-color-btn{opacity:1}.remove-color-btn:hover{background:#c82333}.add-color-form{display:flex;gap:8px;align-items:center;margin-bottom:16px;padding:12px;background:#fff;border:1px solid #dee2e6;border-radius:6px}.add-color-form input[type=color]{width:40px;height:32px;border:none;border-radius:4px;cursor:pointer}.add-color-form input[type=text]{flex:1;padding:6px 8px;border:1px solid #ddd;border-radius:4px;font-size:14px}.add-color-form button{padding:6px 12px;border:1px solid #ddd;border-radius:4px;background:#fff;cursor:pointer;font-size:14px;transition:background-color .2s ease}.add-color-form button:first-of-type{background:#28a745;color:#fff;border-color:#28a745}.add-color-form button:first-of-type:hover{background:#218838}.add-color-form button:last-of-type{background:#6c757d;color:#fff;border-color:#6c757d}.add-color-form button:last-of-type:hover{background:#5a6268}.default-colors{border-top:1px solid #dee2e6;padding-top:12px}.default-colors h4{margin:0 0 8px;font-size:12px;color:#666;font-weight:600}.default-color-buttons{display:flex;gap:4px;flex-wrap:wrap}.default-color-btn{width:24px;height:24px;border:1px solid #ddd;border-radius:4px;cursor:pointer;transition:transform .1s ease}.default-color-btn:hover{transform:scale(1.1);border-color:#007acc}.pattern-manager{background:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;padding:8px;margin-bottom:6px}.pattern-manager-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.pattern-manager-title{display:flex;flex-direction:column;gap:2px}.pattern-manager-title h3{margin:0;font-size:14px;color:#333;font-weight:600}.pattern-status{font-size:9px;font-weight:500;padding:2px 6px;border-radius:3px;text-transform:uppercase;letter-spacing:.3px}.pattern-status.saved{background:#d4edda;color:#155724}.pattern-status.unsaved{background:#fff3cd;color:#856404}.pattern-manager-actions{display:flex;gap:4px}.save-pattern-btn,.load-patterns-btn{padding:6px 8px;border:1px solid #ddd;border-radius:4px;background:#fff;cursor:pointer;font-size:10px;font-weight:500;transition:all .2s ease}.save-pattern-btn{background:#007acc;color:#fff;border-color:#007acc}.save-pattern-btn:hover:not(:disabled){background:#005a9e}.load-patterns-btn:hover:not(:disabled){background:#f0f8ff;border-color:#007acc}.save-pattern-btn:disabled,.load-patterns-btn:disabled{opacity:.6;cursor:not-allowed}.error-message{background:#f8d7da;color:#721c24;padding:8px 12px;border:1px solid #f5c6cb;border-radius:4px;margin-bottom:12px;display:flex;justify-content:space-between;align-items:center;font-size:14px}.close-error{background:none;border:none;color:#721c24;cursor:pointer;font-size:18px;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center}.close-error:hover{background:#721c241a;border-radius:50%}.save-dialog-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.save-dialog{background:#fff;border-radius:8px;padding:24px;min-width:300px;max-width:500px;box-shadow:0 4px 20px #00000026}.save-dialog h4{margin:0 0 16px;font-size:18px;color:#333;font-weight:600}.save-dialog-content{display:flex;flex-direction:column;gap:12px}.save-dialog-content label{font-size:14px;font-weight:500;color:#333}.save-dialog-content input{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px}.save-dialog-content input:focus{outline:none;border-color:#007acc;box-shadow:0 0 0 2px #007acc33}.save-dialog-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:8px}.save-btn,.cancel-btn{padding:8px 16px;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease}.save-btn{background:#28a745;color:#fff;border-color:#28a745}.save-btn:hover:not(:disabled){background:#218838}.save-btn:disabled{opacity:.6;cursor:not-allowed}.cancel-btn{background:#fff;color:#333}.cancel-btn:hover{background:#f8f9fa}.patterns-list{max-height:300px;overflow-y:auto;border:1px solid #dee2e6;border-radius:4px;background:#fff}.no-patterns{padding:20px;text-align:center;color:#666;font-style:italic;margin:0}.pattern-item{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid #f0f0f0;transition:background-color .2s ease}.pattern-item:last-child{border-bottom:none}.pattern-item:hover{background:#f8f9fa}.pattern-info{flex:1}.pattern-info h5{margin:0 0 4px;font-size:14px;font-weight:600;color:#333}.pattern-meta{margin:0;font-size:12px;color:#666}.pattern-actions{display:flex;gap:6px}.load-btn,.delete-btn{padding:4px 8px;border:1px solid #ddd;border-radius:3px;cursor:pointer;font-size:11px;font-weight:500;transition:all .2s ease}.load-btn{background:#007acc;color:#fff;border-color:#007acc}.load-btn:hover:not(:disabled){background:#005a9e}.delete-btn{background:#dc3545;color:#fff;border-color:#dc3545}.delete-btn:hover:not(:disabled){background:#c82333}.load-btn:disabled,.delete-btn:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.pattern-manager-header{flex-direction:column;align-items:stretch;gap:8px}.pattern-manager-actions{justify-content:stretch}.save-pattern-btn,.load-patterns-btn{flex:1}.pattern-item{flex-direction:column;align-items:stretch;gap:8px}.pattern-actions{justify-content:stretch}.load-btn,.delete-btn{flex:1}}.export-panel{background:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;padding:8px;margin-bottom:6px}.export-panel-header{margin-bottom:10px}.export-panel h3{margin:0;font-size:14px;color:#333;font-weight:600}.export-options{display:flex;flex-direction:column;gap:10px}.export-option{background:#fff;border:1px solid #dee2e6;border-radius:4px;padding:10px}.export-option h4{margin:0 0 6px;font-size:12px;color:#333;font-weight:600}.export-option p{margin:0 0 8px;font-size:10px;color:#666;line-height:1.3}.export-info{background:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;padding:8px;margin-bottom:10px}.export-info-item{display:flex;justify-content:space-between;align-items:center;margin-bottom:2px;font-size:10px}.export-info-item:last-child{margin-bottom:0}.export-info-item strong{color:#333;font-weight:500}.export-pdf-btn{width:100%;padding:8px 12px;background:#007acc;color:#fff;border:none;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:background-color .2s ease}.export-pdf-btn:hover:not(:disabled){background:#005a9e}.export-pdf-btn:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.export-panel,.export-option{padding:12px}.export-info{padding:8px}.export-info-item{flex-direction:column;align-items:flex-start;gap:2px}}.auto-save-status{display:flex;align-items:center;gap:4px;font-size:10px;padding:4px 8px;border-radius:4px;transition:all .2s ease;min-height:20px}.auto-save-saving{background:#fff3cd;color:#856404;border:1px solid #ffeaa7}.auto-save-saved{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.auto-save-error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.auto-save-icon{font-size:12px;line-height:1}.auto-save-spinner{animation:spin 1s linear infinite}.auto-save-text{font-weight:500;white-space:nowrap}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.auto-save-saved{animation:fadeOut 3s ease-in-out 2s forwards}@keyframes fadeOut{0%{opacity:1}to{opacity:.3}}.braiding-tool{background:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;padding:8px;margin-bottom:6px}.braiding-tool h4{margin:0 0 8px;font-size:12px;color:#333;font-weight:600}.braiding-controls{display:flex;flex-direction:column;gap:6px}.control-group{display:flex;flex-direction:column;gap:2px}.control-group label{font-size:9px;font-weight:500;color:#666}.control-group select,.control-group input{padding:4px 6px;border:1px solid #ddd;border-radius:3px;font-size:10px;background:#fff}.control-group select:focus,.control-group input:focus{outline:none;border-color:#007acc;box-shadow:0 0 0 1px #007acc33}.instruction{font-size:8px;color:#666;margin:0;font-style:italic}.control-actions{display:flex;gap:4px;margin-top:4px}.place-btn,.cancel-btn{padding:4px 8px;border:1px solid #ddd;border-radius:3px;font-size:9px;font-weight:500;cursor:pointer;transition:all .2s ease}.place-btn{background:#ffccbc;color:#e65100;border-color:#ffccbc}.place-btn:hover{background:#ffb74d;border-color:#ffb74d}.cancel-btn{background:#fff;color:#666}.cancel-btn:hover{background:#f5f5f5;border-color:#ccc}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:#fff;border-bottom:1px solid #dee2e6;padding:1rem 2rem;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;align-items:center}.app-header h1{margin:0;font-size:1.5rem;color:#333;font-weight:600}.app-main{flex:1;display:flex;gap:.75rem;padding:.5rem;max-width:100%;margin:0;width:100%;height:calc(100vh - 80px)}.controls-panel{width:200px;flex-shrink:0;display:flex;flex-direction:column;gap:.25rem;overflow-y:auto;max-height:100%}.pattern-controls{background:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;padding:8px}.pattern-controls h2{margin:0 0 8px;font-size:14px;color:#333;font-weight:600}.dimension-controls{display:flex;flex-direction:column;gap:8px;margin-bottom:10px}.dimension-input{display:flex;flex-direction:column;gap:4px}.dimension-input label{font-size:10px;font-weight:500;color:#666}.dimension-input input{padding:4px 6px;border:1px solid #ddd;border-radius:4px;font-size:12px;width:100%}.dimension-input input:focus{outline:none;border-color:#007acc;box-shadow:0 0 0 2px #007acc33}.new-pattern-btn{width:100%;padding:6px 12px;background:#28a745;color:#fff;border:none;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:background-color .2s ease}.new-pattern-btn:hover{background:#218838}.pattern-editor{flex:1;display:flex;justify-content:center;align-items:flex-start;padding:10px;background:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;overflow:hidden;min-height:0}@media (max-width: 1024px){.app-main{flex-direction:column}.controls-panel{width:100%;flex-direction:row;flex-wrap:wrap}.controls-panel>*{flex:1;min-width:200px}}@media (max-width: 768px){.app-header{padding:1rem}.app-main{padding:.5rem;gap:.5rem}.controls-panel{flex-direction:column}.controls-panel>*{min-width:unset}}
