*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #ff6b35;--secondary-color: #004e89;--background: #1a1a1a;--surface: #242424;--border: #3a3a3a;--text: #e0e0e0;--text-secondary: #a0a0a0;--success: #4caf50;--error: #f44336;--input-bg: #2a2a2a;--input-border: #404040}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color:var(--text);background:var(--surface);line-height:1.6}::-webkit-scrollbar{width:12px;height:12px}::-webkit-scrollbar-track{background:var(--background)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:6px;border:2px solid var(--background)}::-webkit-scrollbar-thumb:hover{background:var(--input-border)}*{scrollbar-width:thin;scrollbar-color:var(--border) var(--background)}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-header{background:var(--secondary-color);color:#fff;padding:1rem 2rem;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;align-items:center;gap:2rem}.header-left{flex-shrink:0;display:flex;align-items:center;gap:1rem}.app-logo{width:50px;height:50px;object-fit:contain}.header-text{display:flex;flex-direction:column}.app-header h1{font-size:1.8rem;font-weight:700;margin-bottom:.25rem}.subtitle{font-size:.9rem;opacity:.9}.header-actions{display:flex;align-items:center;gap:1rem;flex-shrink:0}.app-content{display:flex;flex:1;overflow:hidden}.sidebar{width:420px;min-width:280px;max-width:800px;background:var(--background);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;position:relative}.resize-handle{position:absolute;top:0;right:-8px;width:16px;height:100%;cursor:ew-resize;background:transparent;z-index:10001;transition:background .2s;pointer-events:all}.resize-handle:hover,.resize-handle.resizing{background:var(--primary-color)}.main-content{flex:1;position:relative;overflow:hidden}.parameter-panel{padding:1.5rem;flex:1}.parameter-panel h2{font-size:1.3rem;margin-bottom:1.5rem;color:var(--text)}.param-section{margin-bottom:2rem}.param-section h3{font-size:1rem;margin-bottom:1rem;color:var(--text-secondary);font-weight:600;text-transform:uppercase;font-size:.85rem;letter-spacing:.5px}.param-section.disabled-section{opacity:.5;pointer-events:none}.disabled-note{font-size:.75rem;color:var(--text-secondary);font-weight:400;text-transform:none;margin-left:.5rem}.param-group{margin-bottom:1.25rem}.param-group label{display:block;margin-bottom:.5rem;font-weight:500;font-size:.9rem}.label-with-reset{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.label-with-reset label{margin-bottom:0}.reset-button{background:none;border:1px solid var(--border);color:var(--text-secondary);padding:.25rem .5rem;border-radius:3px;cursor:pointer;font-size:1rem;line-height:1;transition:all .2s;display:flex;align-items:center;justify-content:center}.reset-button:hover{background:var(--surface);color:var(--primary-color);border-color:var(--primary-color);transform:rotate(180deg)}.reset-button:active{transform:rotate(180deg) scale(.95)}.param-group input[type=number],.param-group select{width:100%;padding:.5rem;border:1px solid var(--input-border);border-radius:4px;font-size:.9rem;background:var(--input-bg);color:var(--text)}.param-group select{cursor:pointer}.param-group input[type=number]:focus,.param-group select:focus{outline:none;border-color:var(--primary-color)}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{opacity:1;width:24px;min-width:24px;background:var(--input-bg);border-left:1px solid var(--border);cursor:pointer;margin:0;filter:invert(.9) brightness(1.5)}input[type=number]::-webkit-inner-spin-button:hover,input[type=number]::-webkit-outer-spin-button:hover{background:var(--border);filter:invert(.9) brightness(1.8)}input[type=number]::-webkit-inner-spin-button:active,input[type=number]::-webkit-outer-spin-button:active{background:var(--text-secondary);filter:invert(1) brightness(2)}.input-with-slider input[type=number]{width:100%;margin-bottom:.5rem}.input-with-slider input[type=range]{width:100%;cursor:pointer}.hint{display:block;margin-top:.25rem;font-size:.8rem;color:var(--text-secondary);font-style:italic}.export-button-container{display:flex;flex-direction:column;align-items:flex-end}.export-button{padding:.6rem 1.25rem;background:var(--primary-color);color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s;white-space:nowrap;box-shadow:0 2px 4px #0003}.export-button:hover:not(:disabled){background:#e55a28;box-shadow:0 2px 6px #0000004d}.export-button:disabled{background:#ffffff4d;cursor:not-allowed;box-shadow:none}.error-message{margin-top:.25rem;padding:.25rem .5rem;background:#f8d7da;color:var(--error);border-radius:4px;font-size:.75rem}.url-display{display:flex;align-items:center;gap:.5rem}.url-display label{font-weight:500;font-size:.85rem;white-space:nowrap;color:#ffffffe6}.url-container{display:flex;gap:.5rem}.url-input{width:300px;padding:.5rem .75rem;border:1px solid rgba(255,255,255,.3);border-radius:4px;font-size:.75rem;font-family:monospace;background:#ffffff1a;color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.url-input::selection{background:#ffffff4d}.copy-button{padding:.5rem 1rem;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:4px;font-size:.8rem;cursor:pointer;white-space:nowrap;transition:all .2s;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.copy-button:hover{background:#ffffff4d;border-color:#ffffff80}.preview-canvas{width:100%;height:100%;position:relative}.canvas-container{width:100%;height:100%}.canvas-container canvas{display:block;outline:none}.canvas-instructions{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);background:#000000b3;color:#fff;padding:.5rem 1rem;border-radius:4px;font-size:.85rem;pointer-events:none}.view-mode-icons{position:absolute;top:1rem;right:1rem;display:flex;gap:.5rem;z-index:10}.view-icon-button{display:flex;flex-direction:column;align-items:center;gap:.25rem;background:#0009;border:2px solid rgba(255,255,255,.2);color:#ffffffb3;padding:.75rem;border-radius:8px;cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);min-width:60px}.view-icon-button:hover{background:#000c;border-color:#fff6;color:#ffffffe6;transform:translateY(-2px)}.view-icon-button.active{background:#004e89cc;border-color:#ff6b35cc;color:#fff}.view-icon-button svg{width:24px;height:24px}.view-icon-button span{font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.app-footer{background:var(--surface);border-top:1px solid var(--border);padding:.75rem 2rem;display:flex;justify-content:space-between;align-items:center;font-size:.85rem;color:var(--text-secondary)}.footer-left{display:flex;align-items:center;gap:1rem}.about-button{background:none;border:1px solid var(--border);color:var(--text-secondary);padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.85rem;transition:all .2s;white-space:nowrap}.about-button:hover{background:var(--input-bg);color:var(--primary-color);border-color:var(--primary-color)}.footer-center{flex:1;text-align:center}.footer-right{display:flex;align-items:center;gap:1rem}.master-reset-button{background:var(--error);color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.85rem;font-weight:600;transition:all .2s;white-space:nowrap}.master-reset-button:hover{background:#d32f2f;transform:translateY(-1px);box-shadow:0 2px 4px #0000004d}.master-reset-button:active{transform:translateY(0)}@media (max-width: 768px){.app-header{flex-direction:column;align-items:flex-start;gap:1rem}.header-actions{flex-direction:column;align-items:stretch;width:100%;gap:.75rem}.url-display{flex-direction:column;align-items:flex-start;width:100%}.url-input{width:100%}.app-content{flex-direction:column}.sidebar{width:100%;max-height:50vh;border-right:none;border-bottom:1px solid var(--border)}.main-content{height:50vh}.app-footer{flex-direction:column;gap:1rem;text-align:center}.footer-left{flex-direction:column}.footer-center{order:1}.footer-left{order:2}}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;height:6px;background:var(--border);border-radius:3px;outline:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;background:var(--primary-color);border-radius:50%;cursor:pointer}input[type=range]::-moz-range-thumb{width:18px;height:18px;background:var(--primary-color);border-radius:50%;cursor:pointer;border:none}input[type=range]:hover::-webkit-slider-thumb{background:#e55a28}input[type=range]:hover::-moz-range-thumb{background:#e55a28}.pattern-section{border:2px solid #667eea;border-radius:8px;padding:1rem;margin:1rem 0;background:linear-gradient(135deg,#667eea0d,#764ba20d)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}.section-header h3{margin:0;font-size:1.1rem;color:var(--text)}.btn-randomize{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #667eea4d}.btn-randomize:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-randomize:active{transform:translateY(0);box-shadow:0 2px 4px #667eea4d}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.checkbox-label span{font-weight:500;color:var(--text)}.pattern-params{margin-top:.5rem;padding-top:.5rem;border-top:1px solid rgba(102,126,234,.2)}.printability-note{background:#f59e0b1a;border-left:3px solid #f59e0b;padding:.75rem;margin-top:1rem;border-radius:4px;font-size:.85rem;color:#fbbf24}.printability-note small{display:block;line-height:1.4}.hint{display:block;font-size:.85rem;color:var(--text-secondary);font-style:italic;margin-top:.25rem}.preview-note{background:#2196f31a;border-left:3px solid #2196f3;padding:.75rem;margin-top:1rem;border-radius:4px;font-size:.85rem;color:#60a5fa}.preview-note small{display:block;line-height:1.4}.loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1000;pointer-events:none}.loading-spinner{width:50px;height:50px;border:5px solid rgba(255,255,255,.3);border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{margin-top:1rem;color:#fff;font-size:1rem;font-weight:600;text-shadow:0 2px 4px rgba(0,0,0,.3)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:10000;padding:2rem}.modal-content{background:var(--surface);border:1px solid var(--border);border-radius:8px;max-width:600px;width:100%;max-height:80vh;overflow-y:auto;box-shadow:0 8px 32px #00000080}.modal-header{padding:1.5rem;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.modal-header h2{margin:0;color:var(--text);font-size:1.5rem}.modal-close{background:none;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.modal-close:hover{background:var(--input-bg);color:var(--text)}.modal-body{padding:1.5rem;color:var(--text);line-height:1.6}.modal-body h3{color:var(--primary-color);margin-top:1.5rem;margin-bottom:.75rem;font-size:1.1rem}.modal-body h3:first-child{margin-top:0}.modal-body p{margin-bottom:1rem}.modal-body ul{margin-left:1.5rem;margin-bottom:1rem}.modal-body li{margin-bottom:.5rem}.modal-body code{background:var(--input-bg);padding:.2rem .4rem;border-radius:3px;font-family:Courier New,monospace;font-size:.9em;color:var(--primary-color)}.modal-body a{color:var(--primary-color);text-decoration:none;transition:all .2s;border-bottom:1px solid transparent}.modal-body a:hover{color:#e55a28;border-bottom-color:#e55a28}.kofi-button-container{margin-top:15px;margin-bottom:20px}.kofi-button{display:inline-block;padding:12px 24px!important;background-color:#323842!important;color:#fff!important;text-decoration:none!important;border-radius:5px;font-weight:700;border:none!important;transition:background-color .2s;cursor:pointer}.kofi-button:hover{background-color:#434b57!important;color:#fff!important;border-bottom-color:transparent!important}.reset-confirm-modal{max-width:450px}.reset-confirm-modal .modal-body p{margin-bottom:.75rem;font-size:1rem}.warning-text{color:var(--error);font-weight:600;font-size:.95rem}.modal-footer{padding:1.5rem;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:1rem}.cancel-button,.confirm-button{padding:.6rem 1.2rem;border-radius:4px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;border:none}.cancel-button{background:var(--input-bg);color:var(--text);border:1px solid var(--border)}.cancel-button:hover{background:var(--surface);border-color:var(--text-secondary)}.confirm-button{background:var(--error);color:#fff}.confirm-button:hover{background:#d32f2f;transform:translateY(-1px);box-shadow:0 2px 4px #0000004d}.confirm-button:active{transform:translateY(0)}
