:root{font-family:Roboto,system-ui,-apple-system,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;min-width:320px;min-height:100vh}#root{width:100%;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}}.infinite-canvas-container{display:flex;flex:1;height:100%;overflow:hidden;background:var(--bg-secondary)}.assets-panel-content{padding:8px}.asset-section{margin-bottom:16px}.asset-section h4{margin:0 0 8px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);padding:0 4px}.asset-empty{font-size:12px;color:var(--text-muted);padding:8px;text-align:center;background:var(--bg-secondary);border-radius:6px}.asset-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.asset-item{position:relative;aspect-ratio:1;border-radius:6px;overflow:hidden;cursor:grab;border:2px solid transparent;transition:border-color .15s,transform .15s;background:var(--bg-secondary)}.asset-item:hover{border-color:var(--accent-primary);transform:scale(1.02)}.asset-item:active{cursor:grabbing}.asset-item img{width:100%;height:100%;object-fit:cover}.asset-label{position:absolute;bottom:0;left:0;right:0;padding:4px 6px;font-size:10px;color:#fff;background:linear-gradient(transparent,#000000b3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-transform:capitalize}.palette-preview{display:flex;flex-wrap:wrap;width:100%;height:100%}.palette-preview-swatch{flex:1 1 33.33%;min-height:33.33%}.asset-color-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:4px}.asset-swatch{aspect-ratio:1;border-radius:4px;cursor:grab;border:2px solid transparent;transition:border-color .15s,transform .15s}.asset-swatch:hover{border-color:var(--accent-primary);transform:scale(1.1)}.asset-swatch:active{cursor:grabbing}.infinite-canvas-viewport{flex:1;position:relative;overflow:hidden;background:var(--bg-secondary)}.infinite-canvas-content{position:absolute;top:0;left:0;transform-origin:0 0;width:10000px;height:10000px}.canvas-grid-pattern{position:absolute;top:-5000px;left:-5000px;width:20000px;height:20000px;background-image:linear-gradient(var(--border-color) 1px,transparent 1px),linear-gradient(90deg,var(--border-color) 1px,transparent 1px);background-size:50px 50px;opacity:.3;pointer-events:none}.canvas-item{position:absolute;cursor:move;-webkit-user-select:none;user-select:none;border:2px solid transparent;border-radius:4px;overflow:visible;transition:border-color .1s;box-sizing:border-box}.canvas-item-content{width:100%;height:100%;overflow:hidden;border-radius:2px;position:relative}.canvas-item:hover{border-color:var(--border-hover)}.canvas-item.selected{border-color:var(--accent-primary);box-shadow:0 0 0 2px #6366f14d}.canvas-item.dragging{opacity:.9}.canvas-item img{pointer-events:none;display:block}.resize-handle{position:absolute;width:12px;height:12px;background:var(--accent-primary);border:2px solid white;border-radius:50%;z-index:10}.resize-handle.nw{top:-6px;left:-6px;cursor:nwse-resize}.resize-handle.ne{top:-6px;right:-6px;cursor:nesw-resize}.resize-handle.sw{bottom:-6px;left:-6px;cursor:nesw-resize}.resize-handle.se{bottom:-6px;right:-6px;cursor:nwse-resize}.resize-handle:hover{transform:scale(1.2)}.swatch-content{box-shadow:0 2px 8px #0003}.canvas-item-generating{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;background:var(--bg-secondary);border-radius:4px;gap:12px}.generating-spinner{width:32px;height:32px;border:3px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}.generating-text{font-size:12px;color:var(--text-secondary);font-weight:500}.canvas-item.cropping{border-color:transparent!important;box-shadow:none!important}.canvas-item.cropping .canvas-item-content{overflow:visible}.crop-preview-overlay{position:absolute;top:0;left:0;pointer-events:none}.crop-preview-overlay img{display:block}.crop-window{position:absolute;background:transparent;border:2px dashed white;box-shadow:0 0 0 9999px #0009;pointer-events:none}.crop-window:after{content:"";position:absolute;inset:-3px;border:2px solid var(--accent-primary);border-radius:2px;pointer-events:none}.canvas-mode-toolbar{position:absolute;bottom:20px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;padding:8px 16px;box-shadow:0 4px 12px #0000004d;z-index:100}.canvas-mode-toolbar .toolbar-label{font-size:12px;color:var(--text-secondary);margin-right:4px}.canvas-mode-toolbar .toolbar-btn{width:36px;height:36px;border-radius:8px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.canvas-mode-toolbar .toolbar-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.canvas-mode-toolbar .toolbar-btn.active{background:var(--accent-primary);color:#fff;box-shadow:var(--glow-primary)}.canvas-mode-toolbar .toolbar-btn .material-icon{font-family:Material Icons;font-size:20px;font-weight:400;font-style:normal;line-height:1}.canvas-mode-toolbar .toolbar-divider{width:1px;height:24px;background:var(--border-color);margin:0 8px}.canvas-mode-toolbar .opacity-slider{width:80px;height:4px;cursor:pointer;accent-color:var(--accent-primary)}.canvas-mode-toolbar .opacity-value{font-size:12px;color:var(--text-secondary);min-width:36px;text-align:right}.canvas-mode-toolbar .delete-btn:hover{background:#ef444433;color:#ef4444}.context-menu{position:fixed;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 8px 24px #0006;min-width:220px;max-width:280px;z-index:10000;overflow:hidden}.context-menu-section{padding:4px 0}.context-menu-header{padding:8px 12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);display:flex;align-items:center;gap:8px}.context-menu-divider{height:1px;background:var(--border-color);margin:4px 0}.context-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:8px 12px;border:none;background:transparent;color:var(--text-primary);font-size:13px;cursor:pointer;text-align:left;transition:background .1s}.context-menu-item:hover{background:var(--bg-hover)}.context-menu-item .material-icon{font-family:Material Icons;font-size:18px;color:var(--text-secondary)}.context-menu-item:hover .material-icon{color:var(--accent-primary)}.context-menu-item-text{flex:1;display:flex;flex-direction:column;gap:2px}.context-menu-item-label{font-weight:500}.context-menu-item-desc{font-size:11px;color:var(--text-secondary)}.context-menu-arrow{margin-left:auto;font-size:16px!important}.context-menu-ai-prompt{padding:8px}.context-menu-custom-prompt{padding:8px;min-width:250px}.context-menu-custom-prompt .context-menu-header{display:flex;align-items:center;gap:8px;padding:4px 4px 8px}.context-menu-textarea{width:100%;padding:10px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-secondary);color:var(--text-primary);font-size:13px;font-family:inherit;resize:none;margin-bottom:8px;box-sizing:border-box}.context-menu-textarea:focus{outline:none;border-color:var(--accent-primary)}.context-menu-textarea::placeholder{color:var(--text-muted)}.context-menu-back{background:transparent;border:none;padding:4px;cursor:pointer;color:var(--text-secondary);display:flex;align-items:center;border-radius:4px}.context-menu-back:hover{background:var(--bg-hover);color:var(--text-primary)}.context-menu-back .material-icon{font-family:Material Icons;font-size:18px}.context-menu-prompt-input{margin:8px 0}.context-menu-prompt-input textarea{width:100%;padding:10px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-secondary);color:var(--text-primary);font-size:13px;font-family:inherit;resize:none}.context-menu-prompt-input textarea:focus{outline:none;border-color:var(--accent-primary)}.context-menu-prompt-input textarea::placeholder{color:var(--text-muted)}.context-menu-prompt-actions{display:flex;gap:8px;justify-content:flex-end}.context-menu-cancel{padding:6px 12px;border:1px solid var(--border-color);border-radius:6px;background:transparent;color:var(--text-secondary);font-size:12px;cursor:pointer}.context-menu-cancel:hover{background:var(--bg-hover);color:var(--text-primary)}.context-menu-generate{display:flex;align-items:center;gap:6px;padding:6px 12px;border:none;border-radius:6px;background:var(--accent-primary);color:#fff;font-size:12px;font-weight:500;cursor:pointer}.context-menu-generate:hover:not(:disabled){background:var(--accent-hover)}.context-menu-generate:disabled{opacity:.5;cursor:not-allowed}.context-menu-generate .material-icon{font-family:Material Icons;font-size:14px}@media(max-width:768px){.asset-panel{width:180px;min-width:180px}.asset-grid{grid-template-columns:1fr}.asset-color-grid{grid-template-columns:repeat(3,1fr)}.canvas-mode-toolbar{bottom:calc(var(--mobile-bottom-bar-height) + var(--mobile-safe-area-bottom) + 12px);left:50%;transform:translate(-50%);padding:6px 10px;gap:4px;border-radius:10px;width:auto}.canvas-mode-toolbar .toolbar-label{display:none}.canvas-mode-toolbar .toolbar-btn{width:32px;height:32px;min-width:32px;border-radius:6px}.canvas-mode-toolbar .toolbar-btn .material-icon{font-size:18px}.canvas-mode-toolbar .toolbar-divider{margin:0 2px;height:20px}.canvas-mode-toolbar .opacity-slider{width:50px}.canvas-mode-toolbar .opacity-value{font-size:11px;min-width:28px}}.primary-sidebar-spacer{width:var(--primary-sidebar-width, 64px);height:100%;position:relative;z-index:100;flex-shrink:0}.primary-sidebar{width:var(--primary-sidebar-width, 64px);background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;height:100%;position:absolute;top:0;left:0;z-index:101;transition:width .3s cubic-bezier(.4,0,.2,1);overflow:hidden}.primary-sidebar.expanded{width:var(--primary-sidebar-expanded-width, 240px);box-shadow:4px 0 24px #0003}.primary-sidebar-content{display:flex;flex-direction:column;height:100%;padding:1rem 0;width:var(--primary-sidebar-expanded-width, 240px)}.nav-group{display:flex;flex-direction:column;gap:.5rem;padding:0 .5rem}.nav-group.bottom{margin-top:auto}.nav-item{display:flex;align-items:center;height:48px;padding:0 12px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:8px;transition:all .2s;text-align:left;white-space:nowrap;overflow:hidden}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:var(--accent-primary);color:#fff}.nav-item .material-icon{font-size:24px;min-width:24px;margin-right:16px;display:flex;align-items:center;justify-content:center}.nav-label{font-size:.95rem;font-weight:500;opacity:0;transform:translate(-10px);transition:all .2s}.primary-sidebar.expanded .nav-label{opacity:1;transform:translate(0)}.app-main{position:relative}.secondary-sidebar{width:var(--secondary-sidebar-width, 300px);background:var(--bg-primary);background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;height:100%;flex-shrink:0}.secondary-sidebar-header{height:48px;display:flex;align-items:center;padding:0 1rem;border-bottom:1px solid var(--border-color)}.secondary-sidebar-header h2{font-size:.9rem;font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px}.secondary-sidebar-scroll{flex:1;overflow:hidden;display:flex;flex-direction:column}.accordion-item{border-bottom:1px solid var(--border-color);display:flex;flex-direction:column;min-height:40px}.accordion-item.open{flex:1;min-height:0;overflow:hidden}.accordion-header{width:100%;display:flex;align-items:center;padding:.75rem .5rem;background:transparent;border:none;color:var(--text-primary);cursor:pointer;transition:background .2s;flex-shrink:0}.accordion-header:hover{background:var(--bg-hover)}.accordion-icon{font-size:18px;color:var(--text-secondary);margin-right:.5rem;transition:transform .2s}.accordion-title{font-size:.85rem;font-weight:500}.accordion-content{padding:0 .5rem 1rem;animation:slideDown .2s ease-out;flex:1;overflow-y:auto;overflow-x:hidden}@keyframes slideDown{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.palette-list-item{padding:.75rem;border-bottom:1px solid var(--border-color);cursor:pointer;transition:background .15s}.palette-list-item.selected{background:var(--bg-hover);border-left:3px solid var(--accent-primary)}.palette-list-swatches{display:flex;gap:2px;margin-bottom:6px}.palette-list-swatch{width:16px;height:16px;border-radius:2px}.palette-list-info{display:flex;justify-content:space-between;align-items:center}.palette-list-name{font-size:.85rem;color:var(--text-primary)}.mobile-icon-sidebar{display:none}@media(max-width:768px){.mobile-icon-sidebar{display:flex;flex-direction:column;position:fixed;left:0;top:var(--mobile-header-height, 48px);bottom:calc(var(--mobile-bottom-bar-height, 64px) + var(--mobile-safe-area-bottom, 0px));width:56px;background:var(--bg-secondary);border-right:1px solid var(--border-color);z-index:500;padding:8px 0;gap:4px;align-items:center}.mobile-icon-btn{position:relative;width:44px;height:44px;border:none;background:transparent;color:var(--text-secondary);border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.mobile-icon-btn:hover,.mobile-icon-btn:active{background:var(--bg-hover);color:var(--text-primary)}.mobile-icon-btn.active{background:var(--accent-primary);color:#fff}.mobile-icon-btn .material-icon{font-size:22px}.mobile-icon-badge{position:absolute;top:4px;right:4px;min-width:16px;height:16px;padding:0 4px;background:var(--accent-secondary, #f97316);color:#fff;font-size:10px;font-weight:600;border-radius:8px;display:flex;align-items:center;justify-content:center}.mobile-sidebar-backdrop{position:fixed;inset:0;top:var(--mobile-header-height, 48px);bottom:calc(var(--mobile-bottom-bar-height, 64px) + var(--mobile-safe-area-bottom, 0px));background:#0006;z-index:550;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.mobile-slide-panel{position:fixed;left:56px;top:var(--mobile-header-height, 48px);bottom:calc(var(--mobile-bottom-bar-height, 64px) + var(--mobile-safe-area-bottom, 0px));width:calc(100vw - 72px);max-width:320px;background:var(--bg-primary);border-right:1px solid var(--border-color);z-index:600;display:flex;flex-direction:column;transform:translate(-100%);opacity:0;visibility:hidden;transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .3s ease,visibility .3s ease;box-shadow:4px 0 24px #00000026}.mobile-slide-panel.open{transform:translate(0);opacity:1;visibility:visible}.mobile-slide-panel-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border-color);flex-shrink:0}.mobile-slide-panel-header h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.mobile-panel-close{width:32px;height:32px;border:none;background:transparent;color:var(--text-secondary);border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease}.mobile-panel-close:hover,.mobile-panel-close:active{background:var(--bg-hover);color:var(--text-primary)}.mobile-panel-close .material-icon{font-size:20px}.mobile-slide-panel-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:12px}.mobile-palette-list{display:flex;flex-direction:column;gap:8px}.mobile-palette-list .palette-list-item{padding:12px;background:var(--bg-secondary);border-radius:8px;cursor:pointer;transition:all .15s ease}.mobile-palette-list .palette-list-item:hover,.mobile-palette-list .palette-list-item:active{background:var(--bg-hover)}.mobile-palette-list .palette-list-item.selected{background:var(--bg-hover);border:2px solid var(--accent-primary)}.canvas-section{margin-left:56px!important;width:calc(100% - 56px)!important}.editor-toolbar{left:68px!important;right:12px!important}}@media(max-width:375px){.mobile-slide-panel{width:calc(100vw - 64px)}}.mobile-toolbar-fab{position:fixed;bottom:calc(var(--mobile-bottom-bar-height, 64px) + var(--mobile-safe-area-bottom, 0px) + 16px);right:16px;z-index:500;display:none}@media(max-width:768px){.mobile-toolbar-fab{display:block}}.fab-main{width:56px;height:56px;border-radius:50%;border:none;background:#2a2a2a;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #0006;transition:transform .2s ease,background-color .2s ease;position:relative;z-index:10}.fab-main:active{transform:scale(.95)}.fab-main .material-icon{font-size:24px;transition:transform .3s ease}.mobile-toolbar-fab.expanded .fab-main{background:#444}.mobile-toolbar-fab.expanded .fab-main .material-icon{transform:rotate(45deg)}.mobile-toolbar-fab.disabled .fab-main{opacity:.5;pointer-events:none}.fab-radial-item{position:absolute;width:48px;height:48px;border-radius:50%;border:none;background:#333;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000004d;bottom:4px;right:4px;opacity:0;transform:translate(0) scale(.5);pointer-events:none;transition:transform .3s cubic-bezier(.68,-.55,.265,1.55),opacity .2s ease;transition-delay:var(--delay, 0s)}.fab-radial-item .material-icon{font-size:20px}.fab-radial-item.visible{opacity:1;transform:translate(var(--radial-x),var(--radial-y)) scale(1);pointer-events:auto}.fab-radial-item:active{transform:translate(var(--radial-x),var(--radial-y)) scale(.9)}.fab-radial-item:hover,.fab-radial-item:focus{background:#555}.fab-radial-item.toggle{background:#444;border:2px solid #666}.fab-radial-item.toggle.active{background:#0a84ff;border-color:#0a84ff}.mobile-toolbar-fab.expanded:before{content:"";position:fixed;inset:0;background:#0003;z-index:-1;animation:fadeIn .2s ease}.mobile-point-toolbar{position:fixed;bottom:90px;left:50%;transform:translate(-50%);z-index:1000;display:none}.mobile-point-toolbar.visible{display:block}@media(min-width:769px){.mobile-point-toolbar{bottom:20px}}.mobile-point-toolbar-content{display:flex;align-items:center;gap:12px;background:#2a2a2a;border-radius:28px;padding:8px 16px;box-shadow:0 4px 12px #0006}.point-label{color:#fff;font-size:14px;font-weight:500;padding-right:8px;border-right:1px solid #444}.toolbar-actions{display:flex;align-items:center;gap:4px}.mobile-point-toolbar .action-btn{width:40px;height:40px;min-width:40px;min-height:40px;padding:0;border:none!important;outline:none!important;background:none!important;box-shadow:none!important;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;-webkit-appearance:none;appearance:none}.mobile-point-toolbar .action-btn:focus,.mobile-point-toolbar .action-btn:active{border:none!important;outline:none!important;background:none!important;box-shadow:none!important}.mobile-point-toolbar .action-btn .material-icon{font-size:22px}.mobile-point-toolbar .action-btn.active{color:var(--accent-primary)}.mobile-point-toolbar.distance-mode .mobile-point-toolbar-content{flex-direction:column;gap:8px;padding:12px 16px}.distance-header{display:flex;align-items:center;gap:8px;padding-bottom:8px;border-bottom:1px solid #444;width:100%;justify-content:center}.distance-header .point-label{border:none;background:#ff64644d;padding:2px 8px;border-radius:4px}.distance-arrow{color:#888;font-size:16px}.distance-values{display:flex;gap:16px}.distance-item{display:flex;align-items:center;gap:4px}.distance-label{color:#888;font-size:14px}.distance-value{color:#fff;font-size:14px;font-weight:600;font-family:monospace}.distance-item.diagonal .distance-value{color:#ffc864}.grid-distance-info{display:flex;flex-direction:column;gap:6px;padding:0 8px;border-left:1px solid #444}.coord-values{display:flex;gap:12px}.coord-item{display:flex;align-items:center;gap:4px}.coord-label{color:#888;font-size:12px;font-weight:500}.coord-value{color:#fff;font-size:13px;font-weight:600;font-family:monospace}.grid-distances{display:flex;gap:8px}.grid-dist-item{display:flex;align-items:center;gap:2px}.grid-dist-label{color:#6b8afd;font-size:12px}.grid-dist-value{color:#aaa;font-size:12px;font-family:monospace}.palette-panel{width:280px;min-width:280px;max-width:280px;height:100%;background:var(--bg-primary);border-left:1px solid var(--border-color);display:flex;flex-direction:column;overflow:hidden}.palette-panel-header{display:flex;align-items:center;padding:8px 12px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);position:relative;gap:8px}.palette-panel-selector{flex:1;display:flex;align-items:center;gap:8px;padding:6px 10px;background:var(--bg-primary);border-radius:6px;cursor:pointer;transition:background .15s}.palette-panel-selector:hover{background:var(--bg-tertiary)}.palette-panel-swatches{display:flex;gap:2px}.palette-panel-mini-swatch{width:14px;height:14px;border-radius:3px;border:1px solid rgba(0,0,0,.1)}.palette-panel-name{flex:1;font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.palette-panel-arrow{font-size:10px;color:var(--text-secondary)}.palette-panel-close{width:28px;height:28px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center}.palette-panel-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.palette-panel-dropdown{position:absolute;top:100%;left:12px;right:48px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:100;max-height:300px;overflow-y:auto}.palette-panel-dropdown-item{display:flex;align-items:center;gap:8px;padding:10px 12px;cursor:pointer;transition:background .15s}.palette-panel-dropdown-item:hover{background:var(--bg-secondary)}.palette-panel-dropdown-item.active{background:var(--accent-primary);color:#fff}.palette-panel-options{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid var(--border-color);gap:8px}.palette-panel-toggle{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-secondary);cursor:pointer}.palette-panel-toggle input[type=checkbox]{width:14px;height:14px;cursor:pointer}.palette-panel-live-color{width:24px;height:24px;border-radius:4px;border:1px solid rgba(0,0,0,.15);box-shadow:inset 0 0 0 1px #ffffff1a}.palette-panel-sliders{padding:8px 12px;border-bottom:1px solid var(--border-color);display:flex;flex-direction:column;gap:6px;font-size:11px;color:var(--text-secondary)}.palette-panel-slider-row{display:flex;align-items:center;gap:8px}.palette-panel-slider-row span:first-child{min-width:60px}.palette-panel-slider-row input[type=range]{flex:1;cursor:pointer}.palette-panel-slider-row .slider-value{min-width:32px;text-align:right}.palette-panel-colors{flex:1;overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:4px}.palette-panel-color{display:flex;align-items:flex-start;gap:10px;padding:8px;border-radius:8px;cursor:pointer;transition:background .15s;border:2px solid transparent}.palette-panel-color:hover,.palette-panel-color.hovered{background:var(--bg-secondary)}.palette-panel-color.active{background:var(--bg-tertiary);border-color:var(--accent-primary)}.palette-panel-color.closest{background:var(--bg-secondary);border-color:var(--text-secondary)}.palette-panel-color.closest .palette-panel-swatch{box-shadow:0 0 0 2px var(--bg-primary),0 0 0 4px var(--text-secondary)}.palette-panel-swatch{width:40px;height:40px;min-width:40px;border-radius:8px;border:1px solid rgba(0,0,0,.1);display:flex;align-items:center;justify-content:center;position:relative}.palette-panel-number{font-size:14px;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5)}.palette-panel-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.palette-panel-hex{font-size:12px;font-weight:500;color:var(--text-primary);text-transform:uppercase}.palette-panel-recipe{font-size:11px;color:var(--text-secondary);line-height:1.4}.palette-panel-ingredient{display:inline}@media(max-width:768px){.palette-panel{position:fixed;top:50px;right:0;bottom:0;z-index:100;box-shadow:-4px 0 12px #00000026}}@media(min-width:600px)and (max-width:900px){.palette-panel{width:260px;min-width:260px;max-width:260px}}@media(max-width:400px){.palette-panel{width:240px;min-width:240px;max-width:240px}.palette-panel-swatch{width:32px;height:32px;min-width:32px}.palette-panel-number{font-size:12px}}:root{--bg-primary: #1A1B26;--bg-secondary: #2A2E3F;--bg-tertiary: #363B4E;--bg-hover: #3D4255;--text-primary: #E4E4E7;--text-secondary: #A1A1AA;--text-muted: #71717A;--border-color: #3D4255;--accent-primary: #8A63D2;--accent-secondary: #FF7E6B;--accent-primary-hover: #9D7AE0;--accent-secondary-hover: #FF9485;--overlay-bg: rgba(0, 0, 0, .4);--shadow-color: rgba(0, 0, 0, .5);--input-bg: #1A1B26;--input-border: #3D4255;--scrollbar-track: #2A2E3F;--scrollbar-thumb: #3D4255;--accent-gold: #FFD700;--gradient-primary: linear-gradient(135deg, #8A63D2 0%, #637FD2 100%);--glow-primary: 0 0 12px rgba(138, 99, 210, .4);--glow-secondary: 0 0 12px rgba(255, 126, 107, .4);--modal-shadow: 0 8px 32px rgba(0, 0, 0, .6);--mobile-bottom-bar-height: 64px;--mobile-header-height: 48px;--mobile-safe-area-bottom: env(safe-area-inset-bottom, 0px);--primary-sidebar-width: 64px;--primary-sidebar-expanded-width: 240px;--secondary-sidebar-width: 300px}.theme-light{--bg-primary: #FAFBFC;--bg-secondary: #FFFFFF;--bg-tertiary: #F5F6F8;--bg-hover: #EEEEF2;--text-primary: #2D2D3A;--text-secondary: #6B6B7B;--text-muted: #9090A0;--border-color: #E8E8EE;--accent-primary: #8A63D2;--accent-secondary: #FF7E6B;--accent-primary-hover: #9D7AE0;--accent-secondary-hover: #FF9485;--overlay-bg: rgba(0, 0, 0, .15);--shadow-color: rgba(0, 0, 0, .06);--input-bg: #FFFFFF;--input-border: #E8E8EE;--scrollbar-track: #F5F6F8;--scrollbar-thumb: #D8D8E0;--gradient-primary: linear-gradient(135deg, #8A63D2 0%, #637FD2 100%);--modal-shadow: 0 8px 32px rgba(0, 0, 0, .12);--glow-primary: 0 0 12px rgba(138, 99, 210, .25);--glow-secondary: 0 0 12px rgba(255, 126, 107, .25)}*{box-sizing:border-box;margin:0;padding:0}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--scrollbar-track)}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}body{font-family:Roboto,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;overflow-x:hidden}.material-icon{font-family:Material Icons;font-weight:400;font-style:normal;font-size:24px;display:inline-block;line-height:1;text-transform:none;letter-spacing:normal;word-wrap:normal;white-space:nowrap;direction:ltr;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;-moz-osx-font-smoothing:grayscale;font-feature-settings:"liga"}#root{height:100vh;overflow:hidden}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-header{background:var(--bg-secondary);padding:.5rem 1rem;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:center;position:relative;height:50px;flex-shrink:0;z-index:200}.mobile-action-btn:hover{background:var(--accent-primary)}.app-main{display:flex;flex:1;width:100%;height:calc(100vh - 50px);overflow:hidden;position:relative}.canvas-section{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative;height:100%}.icon-sidebar{width:60px;min-width:60px;background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;align-items:center;padding:.5rem .625rem .5rem .5rem;gap:.5rem}.tools-sidebar{width:60px;min-width:60px;background:var(--bg-secondary);border-left:1px solid var(--border-color);display:flex;flex-direction:column;align-items:center;padding:.5rem .5rem .5rem .625rem;gap:.5rem}.icon-sidebar-btn{width:40px;height:40px;border-radius:10px;border:none;background:transparent;color:var(--text-secondary);font-size:1.25rem;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;position:relative}.icon-sidebar-btn .material-icon{font-family:Material Icons;font-size:24px;font-weight:400;font-style:normal;line-height:1;letter-spacing:normal;text-transform:none;white-space:nowrap;word-wrap:normal;direction:ltr;-webkit-font-smoothing:antialiased}.icon-sidebar-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.icon-sidebar-btn.active{background:var(--accent-primary);color:#fff;box-shadow:var(--glow-primary)}.icon-badge{position:absolute;top:2px;right:2px;background:var(--accent-primary);color:#000;font-size:.6rem;font-weight:700;min-width:14px;height:14px;border-radius:7px;display:flex;align-items:center;justify-content:center;padding:0 3px}.panel-overlay{position:fixed;inset:48px 56px 0 0;background:var(--overlay-bg);z-index:999;animation:fadeIn .2s ease-out}.panel-overlay.drag-through{pointer-events:none;background:transparent}.panel-overlay.left{left:56px;right:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.sidebar-panel{width:280px;background:var(--bg-secondary);border-left:1px solid var(--border-color);display:flex;flex-direction:column;position:fixed;top:48px;right:56px;bottom:0;z-index:1000;box-shadow:-8px 0 32px var(--shadow-color);animation:slideIn .2s ease-out}.sidebar-panel.left{left:56px;right:auto;border-left:none;border-right:1px solid var(--border-color);box-shadow:8px 0 32px var(--shadow-color);animation:slideInLeft .2s ease-out}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideInLeft{0%{transform:translate(-100%);opacity:0}to{transform:translate(0);opacity:1}}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;border-bottom:1px solid var(--border-color)}.panel-header h2{font-size:.9rem;font-weight:600;color:var(--accent-primary)}.panel-close{background:transparent;border:none;color:var(--text-secondary);font-size:1.25rem;cursor:pointer;padding:.25rem;line-height:1}.panel-close:hover{color:var(--accent-primary)}.panel-content{flex:1;overflow-y:auto;padding:.5rem;display:flex;flex-direction:column;gap:.5rem}.zoom-controls h3{font-size:.9rem;color:var(--accent-primary);margin-bottom:.5rem}.zoom-buttons{display:flex;align-items:center;gap:.5rem}.zoom-buttons button{background:var(--bg-tertiary);border:none;color:var(--text-primary);padding:.4rem .75rem;border-radius:4px;cursor:pointer;font-size:.9rem}.zoom-buttons button:hover{background:var(--accent-primary)}.zoom-buttons span{min-width:50px;text-align:center;font-size:.9rem;color:var(--accent-primary)}.image-thumbnail-container{width:100%;aspect-ratio:1;border-radius:12px;background:var(--bg-primary);margin-bottom:.5rem;cursor:pointer;position:relative;border:2px solid transparent;transition:border-color .2s}.image-thumbnail-container:hover,.image-thumbnail-container.selected{border-color:var(--accent-primary)}.image-thumbnail{width:100%;height:100%;object-fit:cover}.thumbnail-label{position:absolute;bottom:0;left:0;right:0;background:#000000b3;color:#fff;font-size:.75rem;padding:.25rem .5rem;text-align:center;text-transform:capitalize}.variations-section{margin-top:1rem}.variations-section h3{font-size:.9rem;color:var(--accent-primary);margin-bottom:.5rem}.variations-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.variation-thumbnail{aspect-ratio:1;border-radius:8px;cursor:pointer;position:relative;border:2px solid transparent;transition:border-color .2s}.variation-thumbnail:hover,.variation-thumbnail.selected{border-color:var(--accent-primary)}.variation-thumbnail img{width:100%;height:100%;object-fit:cover}.variation-thumbnail .thumbnail-label{font-size:.65rem}.style-buttons-section{margin-top:1rem}.style-buttons-section h3{font-size:.9rem;color:var(--accent-primary);margin-bottom:.5rem}.style-buttons{display:flex;flex-direction:column;gap:.5rem}.style-btn{display:flex;align-items:center;gap:.5rem;padding:.6rem .75rem;background:var(--border-color);border:none;border-radius:8px;color:var(--text-primary);font-size:.85rem;cursor:pointer;transition:background .2s}.style-btn:hover:not(:disabled){background:var(--bg-hover)}.style-btn:disabled{opacity:.5;cursor:not-allowed}.style-btn .material-icon{font-family:Material Icons;font-size:18px}.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite}.spinner.small{width:14px;height:14px;border-width:2px}.api-key-section{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border-color)}.api-key-section h3{font-size:.9rem;color:var(--accent-primary);margin-bottom:.5rem}.api-key-input{width:100%;padding:.5rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:.85rem}.api-key-input:focus{outline:none;border-color:var(--accent-primary)}.api-key-hint{font-size:.75rem;color:var(--text-muted);margin-top:.5rem}.api-key-hint a{color:var(--accent-primary);text-decoration:none}.api-key-hint a:hover{text-decoration:underline}.canvas-section{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem;background:var(--bg-primary);min-height:100vh;width:calc(100vw - 56px);position:relative}.editor-toolbar{position:fixed;bottom:20px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;padding:8px 16px;box-shadow:0 4px 12px #0000004d;z-index:100}.editor-toolbar .toolbar-label{font-size:12px;color:var(--text-secondary);margin-right:4px}.editor-toolbar .toolbar-divider{width:1px;height:24px;background:var(--border-color);margin:0 4px}.editor-toolbar .toolbar-btn{width:36px;height:36px;border-radius:8px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.editor-toolbar .toolbar-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.editor-toolbar .toolbar-btn.active{background:var(--accent-primary);color:#fff;box-shadow:var(--glow-primary)}.editor-toolbar .toolbar-btn .material-icon{font-family:Material Icons;font-size:20px;font-weight:400;font-style:normal;line-height:1}.editor-toolbar .toolbar-btn.delete-btn:hover{background:#ef444433;color:#ef4444}.toolbar-group{display:flex;align-items:center;gap:.25rem}.toolbar-divider{width:1px;height:24px;background:var(--border-color);margin:0 .25rem}.toolbar-btn{width:40px;height:40px;border-radius:10px;border:none;background:transparent;color:var(--text-secondary);font-size:1.25rem;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}.toolbar-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.toolbar-btn.active{background:var(--accent-primary);color:#fff}.toolbar-icon{font-size:1.1rem;line-height:1}.mobile-only{display:none}@media(max-width:768px){.mobile-only{display:flex}}.toolbar-action-btn{background:var(--accent-primary)!important;color:var(--bg-primary)!important;font-weight:700}.toolbar-action-btn:hover:not(:disabled){background:var(--accent-primary-hover)!important}.toolbar-action-btn:disabled{background:var(--bg-tertiary)!important;color:var(--text-muted)!important;cursor:not-allowed}.toolbar-delete-btn{background:var(--accent-secondary)!important;color:#fff!important}.toolbar-delete-btn:hover{background:#e86a5a!important}.toolbar-add-btn{background:var(--accent-primary)!important;color:var(--bg-primary)!important;font-size:1.5rem!important;font-weight:700}.toolbar-add-btn:hover{background:var(--accent-primary-hover)!important}.toolbar-label{color:var(--accent-primary);font-size:.9rem;font-weight:500;padding:0 .5rem}.display-fab{position:fixed;bottom:1rem;right:1rem;width:52px;height:52px;border-radius:16px;border:1px solid rgba(255,255,255,.1);background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 100%);color:var(--accent-primary);font-size:1.4rem;cursor:pointer;box-shadow:0 4px 16px #0006,inset 0 1px #ffffff0d;transition:all .2s;z-index:10000;display:flex;align-items:center;justify-content:center}.display-fab:hover{background:var(--gradient-primary);color:#fff;transform:translateY(-2px);box-shadow:var(--glow-primary)}.display-fab:active{transform:translateY(0)}.image-uploader{display:flex;flex-direction:column;gap:.75rem}.drop-zone{border:2px dashed var(--border-color);border-radius:8px;padding:1.5rem;text-align:center;cursor:pointer;transition:all .2s}.drop-zone:hover,.drop-zone.dragging{border-color:var(--accent-primary);background:#8a63d21a}.drop-zone p{color:var(--text-muted);font-size:.875rem}.url-input{display:flex;gap:.5rem}.url-input input{flex:1;padding:.5rem;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-primary);color:var(--text-primary);font-size:.875rem}.url-input input:focus{outline:none;border-color:var(--accent-primary)}.url-input button{padding:.5rem 1rem;background:var(--accent-primary);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.875rem}.url-input button:hover{background:var(--accent-primary-hover)}.error{color:var(--accent-secondary);font-size:.75rem}.grid-controls,.paper-settings,.coordinate-display,.image-info{background:var(--bg-primary);border-radius:8px;padding:1rem}.grid-controls h3,.paper-settings h3,.coordinate-display h3,.image-info h3{font-size:.875rem;color:var(--accent-secondary);margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.5px}.grid-line-editor{background:var(--bg-primary);border-radius:8px;padding:1rem}.grid-line-editor .collapsible-header{font-size:.875rem;color:var(--accent-secondary);margin:0;text-transform:uppercase;letter-spacing:.5px}.grid-line-editor .collapse-arrow{font-size:.7rem;transition:transform .2s;display:inline-block}.grid-line-editor .collapse-arrow.expanded{transform:rotate(90deg)}.grid-line-editor-content{margin-top:.75rem}.grid-lines-section{margin-bottom:1rem}.grid-lines-section:last-child{margin-bottom:0}.grid-lines-section h4{font-size:.75rem;color:var(--text-secondary);margin-bottom:.5rem;font-weight:500}.grid-line-item{background:var(--bg-secondary);border-radius:4px;padding:.5rem;margin-bottom:.5rem}.grid-line-item:last-child{margin-bottom:0}.grid-line-item .line-label{font-size:.75rem;color:var(--text-secondary);display:block;margin-bottom:.25rem}.grid-line-item .endpoint-inputs{display:flex;gap:.75rem;flex-wrap:wrap}.grid-line-item .endpoint-inputs label{display:flex;align-items:center;gap:.25rem;font-size:.75rem;color:var(--text-secondary)}.grid-line-item .endpoint-inputs input{width:60px;padding:.25rem .5rem;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-primary);color:var(--text-primary);font-size:.75rem}.grid-line-item .endpoint-inputs .unit-label{font-size:.7rem;color:var(--text-muted)}.control-group{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.control-group label{font-size:.875rem;min-width:80px;color:var(--text-secondary)}.control-group input[type=range]{flex:1;accent-color:var(--accent-primary)}.number-input-group{display:flex;align-items:center;gap:0}.number-input-group button{width:32px;height:32px;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);font-size:1rem;cursor:pointer;transition:all .2s}.number-input-group button:first-child{border-radius:4px 0 0 4px}.number-input-group button:last-child{border-radius:0 4px 4px 0}.number-input-group button:hover:not(:disabled){background:var(--accent-primary);border-color:var(--accent-primary)}.number-input-group button:disabled{opacity:.4;cursor:not-allowed}.number-input-group input[type=number]{width:50px;height:32px;border:1px solid var(--border-color);border-left:none;border-right:none;background:var(--bg-secondary);color:var(--text-primary);text-align:center;font-size:.875rem;-moz-appearance:textfield}.number-input-group input[type=number]::-webkit-outer-spin-button,.number-input-group input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.control-group input[type=number]{width:60px;padding:.25rem .5rem;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-secondary);color:var(--text-primary);font-size:.875rem}.control-group input[type=number]:focus{outline:none;border-color:var(--accent-primary)}.control-group select{padding:.25rem .5rem;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-secondary);color:var(--text-primary);font-size:.875rem}.control-group select:focus{outline:none;border-color:var(--accent-primary)}.control-group .preset-select{flex:1;max-width:160px}.orientation-group{flex-wrap:wrap}.orientation-btn{padding:.25rem .5rem;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-muted);font-size:.75rem;cursor:pointer;transition:all .2s}.orientation-btn:hover:not(:disabled){border-color:var(--accent-primary);color:var(--text-primary)}.orientation-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.orientation-btn:disabled{opacity:.5;cursor:not-allowed}.coordinate-display .hint{color:var(--text-muted);font-size:.875rem;font-style:italic}.coord-row{display:flex;justify-content:space-between;margin-bottom:.5rem;font-size:.875rem}.coord-row .label{color:var(--text-muted)}.coord-row .value{color:var(--accent-primary);font-family:Monaco,Consolas,monospace}.image-info p{font-size:.875rem;color:var(--text-muted);font-family:Monaco,Consolas,monospace}.canvas-container{width:100%;height:calc(100vh - 120px);display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative}.points-controls{position:fixed;bottom:70px;left:50%;transform:translate(-50%);display:flex;gap:.5rem;align-items:center;background:#16213ef2;padding:.5rem 1rem;border-radius:8px;border:1px solid var(--border-color);z-index:9999}.points-controls span{font-size:.875rem;color:var(--text-secondary);margin-right:.5rem}.points-controls button{padding:.25rem .75rem;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-primary);color:var(--text-primary);font-size:.75rem;cursor:pointer;transition:all .2s}.points-controls button:hover{background:var(--accent-primary);border-color:var(--accent-primary)}.rulers-controls{position:fixed;bottom:110px;left:50%;transform:translate(-50%);display:flex;gap:.5rem;align-items:center;background:#16213ef2;padding:.5rem 1rem;border-radius:8px;border:1px solid var(--border-color);z-index:9999}.rulers-controls span{font-size:.875rem;color:var(--text-secondary);margin-right:.5rem}.rulers-controls button{padding:.25rem .75rem;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-primary);color:var(--text-primary);font-size:.75rem;cursor:pointer;transition:all .2s}.rulers-controls button:hover{background:var(--accent-primary);border-color:var(--accent-primary)}.points-list{background:var(--bg-primary);border-radius:8px;padding:.75rem;flex:1;display:flex;flex-direction:column;min-height:0}.points-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.points-header h3{font-size:.875rem;color:var(--accent-secondary);text-transform:uppercase;letter-spacing:.5px;margin:0}.points-header .clear-all-btn{padding:.2rem .5rem;border:1px solid var(--border-color);border-radius:4px;background:transparent;color:var(--text-muted);font-size:.7rem;cursor:pointer;transition:all .2s}.points-header .clear-all-btn:hover{background:var(--accent-secondary);border-color:var(--accent-secondary);color:#fff}.points-list ul{list-style:none;padding:0;margin:0;flex:1;overflow-y:auto}.point-item{display:flex;align-items:center;gap:.5rem;padding:.4rem 0;border-bottom:1px solid var(--border-color)}.point-item:last-child{border-bottom:none}.point-number{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;color:#000;flex-shrink:0}.point-coords{flex:1;font-size:.8rem;color:var(--text-secondary);font-family:Monaco,Consolas,monospace}.point-item.point-hidden{opacity:.5}.toggle-visibility-btn{width:20px;height:20px;border:none;border-radius:4px;background:transparent;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.toggle-visibility-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.toggle-visibility-btn .material-icon{font-size:16px}.delete-point-btn{width:20px;height:20px;border:none;border-radius:4px;background:transparent;color:var(--text-muted);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.delete-point-btn:hover{background:var(--accent-secondary);color:#fff}.draw-mode-toggle{background:var(--bg-secondary);padding:1rem;border-radius:8px}.draw-mode-toggle h3{margin:0 0 .5rem;font-size:.9rem;color:var(--accent-primary)}.mode-buttons{display:flex;gap:.5rem}.mode-btn{flex:1;padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-primary);color:var(--text-secondary);font-size:.85rem;cursor:pointer;transition:all .2s}.mode-btn:hover{background:var(--border-color);color:#fff}.mode-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.rulers-list{background:var(--bg-secondary);padding:.75rem;border-radius:8px;flex:1;display:flex;flex-direction:column;min-height:0}.rulers-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.rulers-header h3{margin:0;font-size:.9rem;color:var(--accent-primary)}.rulers-list ul{list-style:none;padding:0;margin:0;flex:1;overflow-y:auto}.ruler-item{display:flex;align-items:center;gap:.5rem;padding:.4rem 0;border-bottom:1px solid var(--border-color)}.ruler-item:last-child{border-bottom:none}.ruler-indicator{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:#000}.ruler-angle{flex:1;font-family:monospace;font-size:.85rem;color:var(--text-secondary)}.delete-ruler-btn{width:20px;height:20px;border:none;border-radius:4px;background:transparent;color:var(--text-muted);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.delete-ruler-btn:hover{background:var(--accent-secondary);color:#fff}.colors-list{background:var(--bg-secondary);border-radius:0;padding:0;margin:0;flex:1;display:flex;flex-direction:column;min-height:0}.colors-tabs{display:flex;border-bottom:1px solid var(--border-color);background:var(--bg-tertiary)}.colors-tab{flex:1;padding:.6rem .5rem;background:transparent;border:none;color:var(--text-secondary);font-size:.75rem;font-weight:500;cursor:pointer;transition:all .15s ease;border-bottom:2px solid transparent}.colors-tab:hover{color:var(--text-primary);background:var(--bg-hover)}.colors-tab.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary);background:var(--bg-secondary)}.palettes-tab-content{flex:1;overflow-y:auto;padding:.5rem}.palettes-list{display:flex;flex-direction:column;gap:.5rem}.palette-card{background:var(--bg-tertiary);border-radius:6px;padding:.5rem;cursor:pointer;transition:all .15s ease;border:1px solid transparent}.palette-card:hover{background:var(--bg-hover);border-color:var(--border-color)}.palette-card.active{border-color:var(--accent-primary);box-shadow:0 0 0 1px var(--accent-primary)}.palette-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem}.palette-card-name{font-size:.8rem;font-weight:500;color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap}.palette-card-delete{background:transparent;border:none;color:var(--text-muted);font-size:1rem;cursor:pointer;padding:0 .2rem;line-height:1;opacity:0;transition:opacity .15s}.palette-card:hover .palette-card-delete{opacity:1}.palette-card-delete:hover{color:var(--accent-secondary)}.palette-card-colors{display:flex;gap:2px;flex-wrap:wrap;align-items:center}.palette-card-swatch{width:18px;height:18px;border-radius:3px;border:1px solid rgba(0,0,0,.2)}.palette-card-more{font-size:.65rem;color:var(--text-muted);margin-left:2px}.all-colors-tab-content{flex:1;display:flex;flex-direction:column}.colors-header-row{display:flex;align-items:center;gap:.3rem;margin-bottom:.3rem;padding-bottom:.3rem;border-bottom:1px solid var(--border-color)}.colors-count{font-size:.85rem;font-weight:600;color:var(--text-primary);min-width:1.2rem}.colors-list ul{list-style:none;padding:0;margin:0;flex:1;overflow-y:auto;border-radius:6px;min-height:0}.color-item{display:flex;align-items:center;gap:.5rem;padding:.5rem;margin:0;border:none;transition:transform .1s}.color-item:last-child{border-bottom:none}.color-swatch{width:28px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:900;font-family:Arial Black,Helvetica Neue,sans-serif;cursor:pointer;background:transparent!important;border:none;flex-shrink:0;color:inherit!important;text-shadow:1px 1px 0 rgba(0,0,0,.4),-1px -1px 0 rgba(255,255,255,.2),2px 2px 4px rgba(0,0,0,.3)}.color-swatch span{color:inherit!important}.color-values{flex:1;display:flex;flex-direction:column;gap:.1rem;min-width:0}.color-hex{font-family:monospace;font-size:.85rem;color:inherit;cursor:pointer;text-shadow:0 1px 2px rgba(0,0,0,.5)}.color-hex:hover{text-decoration:underline}.color-rgb{font-family:monospace;font-size:.75rem;color:inherit;opacity:.8;cursor:pointer;text-shadow:0 1px 2px rgba(0,0,0,.5)}.color-rgb:hover{text-decoration:underline}.delete-color-btn{width:28px;border:none;background:transparent;color:inherit;font-size:1.3rem;font-weight:900;font-family:Arial Black,Helvetica Neue,sans-serif;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0;text-shadow:1px 1px 0 rgba(0,0,0,.4),-1px -1px 0 rgba(255,255,255,.2),2px 2px 4px rgba(0,0,0,.3);opacity:.7}.delete-color-btn:hover{opacity:1;color:var(--accent-secondary);transform:scale(1.2)}.color-dialog{position:fixed;z-index:1000;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:16px;padding:1rem;box-shadow:var(--modal-shadow);min-width:180px;-webkit-user-select:none;user-select:none}.color-dialog-close{position:absolute;top:8px;right:8px;width:24px;height:24px;border:none;border-radius:50%;background:var(--border-color);color:var(--text-muted);font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.color-dialog-close:hover{background:var(--accent-primary);color:#fff}.color-dialog-swatch{width:100%;height:120px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;margin-bottom:.75rem;border:1px solid rgba(255,255,255,.1)}.color-dialog-info{text-align:center}.color-dialog-hex{font-family:monospace;font-size:1.25rem;font-weight:700;color:#fff;cursor:pointer;padding:.25rem;border-radius:4px;transition:background .2s}.color-dialog-hex:hover{background:var(--border-color);color:var(--accent-primary)}.color-dialog-rgb{font-family:monospace;font-size:.9rem;color:var(--text-muted);cursor:pointer;padding:.25rem;border-radius:4px;transition:background .2s}.color-dialog-rgb:hover{background:var(--border-color);color:var(--accent-primary)}.color-dialog-resize{position:absolute;bottom:0;right:0;width:16px;height:16px;cursor:se-resize;background:linear-gradient(135deg,transparent 50%,var(--border-color) 50%);border-bottom-right-radius:10px}.color-dialog-resize:hover{background:linear-gradient(135deg,transparent 50%,var(--accent-primary) 50%)}.select-btn{padding:.2rem .4rem;font-size:.7rem;background:var(--border-color);color:var(--text-secondary);border:1px solid var(--bg-primary);border-radius:4px;cursor:pointer}.select-btn:hover{background:var(--bg-primary);color:#fff}.select-btn.active{background:var(--accent-primary);color:var(--bg-primary);border-color:var(--accent-primary)}.selection-count{font-size:.7rem;color:var(--text-muted);margin-left:auto}.clear-all-btn{padding:.2rem .4rem;font-size:.7rem}.color-checkbox{width:18px;height:18px;accent-color:var(--accent-primary);cursor:pointer;flex-shrink:0}.color-item.selected{outline:3px solid var(--accent-primary);outline-offset:-3px;z-index:1}.palette-generation{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.palette-generation h4{margin:0 0 .75rem;font-size:.9rem;color:var(--accent-secondary)}.paint-type-select{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.paint-type-select label{font-size:.8rem;color:var(--text-secondary)}.paint-type-select select{flex:1;padding:.4rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);font-size:.85rem}.paint-type-select select:focus{outline:none;border-color:var(--accent-primary)}.paint-set-colors{font-size:.7rem;color:var(--text-muted);line-height:1.4;margin-bottom:.75rem;padding:.5rem;background:var(--bg-primary);border-radius:4px;max-height:60px;overflow-y:auto}.generate-palette-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.6rem 1rem;margin-top:1rem;background:var(--gradient-primary);color:#fff;border:none;border-radius:10px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.generate-palette-btn:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-1px);box-shadow:var(--glow-primary)}.generate-palette-btn:disabled{background:var(--bg-tertiary);color:var(--text-muted);cursor:not-allowed}.generate-palette-btn .material-icon{font-family:Material Icons;font-size:18px}.generate-palette-btn .spinner{width:16px;height:16px;border:2px solid var(--bg-primary);border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite}.palette-dialog-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000}.palette-dialog{background:var(--bg-secondary);border-radius:16px;width:90%;max-width:420px;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--modal-shadow)}.palette-dialog-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.palette-dialog-header h3{margin:0;font-size:1.1rem;color:var(--text-primary)}.palette-dialog-close{background:none;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer;line-height:1;padding:0}.palette-dialog-close:hover{color:var(--accent-primary)}.palette-dialog-body{padding:1.25rem;overflow-y:auto;flex:1}.palette-dialog-colors{margin-bottom:1.25rem}.palette-dialog-colors label{display:block;font-size:.85rem;color:var(--text-secondary);margin-bottom:.5rem}.palette-dialog-swatches{display:flex;flex-wrap:wrap;gap:6px}.palette-dialog-swatch{width:28px;height:28px;border-radius:4px;border:1px solid rgba(255,255,255,.2)}.palette-dialog-field{margin-bottom:1rem}.palette-dialog-field label{display:block;font-size:.85rem;color:var(--text-secondary);margin-bottom:.4rem}.palette-dialog-field select{width:100%;padding:.6rem .75rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:.95rem}.palette-dialog-field select:focus{outline:none;border-color:var(--accent-primary)}.palette-dialog-set-info{background:var(--bg-primary);border-radius:6px;padding:.75rem;margin-top:.5rem}.palette-dialog-set-label{display:block;font-size:.75rem;color:var(--text-muted);margin-bottom:.25rem}.palette-dialog-set-colors{font-size:.8rem;color:var(--text-muted);line-height:1.4}.palette-dialog-footer{display:flex;gap:.75rem;padding:1rem 1.25rem;background:var(--bg-secondary);border-top:1px solid var(--border-color)}.palette-dialog-cancel{flex:1;padding:.7rem;background:transparent;border:1px solid var(--border-color);border-radius:6px;color:var(--text-secondary);font-size:.95rem;cursor:pointer}.palette-dialog-cancel:hover{background:var(--bg-tertiary);border-color:var(--border-color)}.palette-dialog-generate{flex:2;padding:.7rem;background:var(--accent-primary);border:none;border-radius:6px;color:var(--bg-primary);font-size:.95rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem}.palette-dialog-generate:hover:not(:disabled){background:var(--accent-primary-hover)}.palette-dialog-generate:disabled{background:var(--bg-tertiary);color:var(--text-muted);cursor:not-allowed}.palette-dialog-generate .spinner{width:16px;height:16px;border:2px solid var(--bg-primary);border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite}.palette-view{display:flex;flex-direction:column;height:100%}.palette-view-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-color)}.palette-back-btn{background:none;border:none;color:var(--text-muted);font-size:1.1rem;cursor:pointer;padding:.25rem;display:flex;align-items:center}.palette-back-btn:hover{color:var(--accent-primary)}.palette-view-header h3{flex:1;margin:0;font-size:1rem;color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis}.palette-delete-btn{background:none;border:none;color:var(--text-muted);font-size:1.1rem;cursor:pointer;padding:.25rem}.palette-delete-btn:hover{color:var(--accent-secondary)}.palette-meta{font-size:.8rem;color:var(--text-muted);margin-bottom:1rem;line-height:1.5}.palette-meta strong{color:var(--accent-primary)}.palette-colors-section{margin-bottom:1rem}.palette-colors-section h4{margin:0 0 .5rem;font-size:.85rem;color:var(--text-secondary)}.palette-colors-strip{display:flex;flex-wrap:wrap;gap:.25rem}.palette-color-swatch{width:32px;height:32px;border-radius:4px;border:1px solid rgba(255,255,255,.1)}.palette-image-section{flex:1;display:flex;flex-direction:column;min-height:0}.palette-image-thumb{width:100%;border-radius:8px;cursor:pointer;transition:transform .2s,box-shadow .2s}.palette-image-thumb:hover{transform:scale(1.02);box-shadow:0 4px 12px #8a63d24d}.view-full-btn{width:100%;padding:.6rem;margin-top:.75rem;background:var(--border-color);border:1px solid var(--bg-hover);border-radius:6px;color:var(--text-secondary);font-size:.85rem;cursor:pointer;transition:all .2s}.view-full-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--accent-primary)}.palettes-compact{margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:6px}.palette-row{display:flex;height:80px;border-radius:6px;cursor:pointer;background:var(--bg-primary);transition:transform .15s,box-shadow .15s}.palette-row:hover{transform:scale(1.02);box-shadow:0 2px 8px #0000004d}.palette-row-image{flex:0 0 50%}.palette-row-image img{width:100%;height:100%;object-fit:cover}.palette-row-colors{flex:1;display:grid;grid-template-columns:repeat(auto-fill,minmax(20px,1fr));gap:2px;padding:3px}.palette-row-swatch{border-radius:3px;min-height:0}.palettes-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.palettes-section-header h4{margin:0;font-size:.9rem;color:var(--accent-secondary)}.palettes-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem;flex:1;overflow-y:auto;align-content:start}.palette-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;padding:.5rem;cursor:pointer;transition:all .2s}.palette-card:hover{border-color:var(--accent-primary);transform:translateY(-2px)}.palette-card-thumb{width:100%;aspect-ratio:1;border-radius:4px;margin-bottom:.5rem;background:var(--bg-primary)}.palette-card-thumb img{width:100%;height:100%;object-fit:cover}.palette-card-colors{display:flex;gap:2px;margin-bottom:.5rem;height:24px;border-radius:4px}.palette-card-colors .color-strip{flex:1;height:100%}.palette-card-name{font-size:.75rem;color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;text-align:center}.colors-empty,.palettes-empty{text-align:center;color:var(--text-muted);font-size:.85rem;padding:1.5rem 1rem;font-style:italic}.mixing-recipes-preview{margin-top:1rem;padding:.75rem;background:var(--bg-primary);border-radius:6px;border:1px solid var(--border-color);cursor:pointer;transition:border-color .2s,background .2s}.mixing-recipes-preview:hover{border-color:var(--accent-primary);background:var(--bg-secondary)}.mixing-recipes-preview h5{margin:0 0 .5rem;font-size:.8rem;color:var(--accent-primary);text-transform:uppercase;letter-spacing:.5px;display:flex;justify-content:space-between;align-items:center}.mixing-recipes-preview .view-all{font-size:.7rem;text-transform:none;opacity:.7}.mixing-recipes-preview pre{margin:0;font-size:.75rem;color:var(--text-muted);white-space:pre-wrap;word-break:break-word;line-height:1.4;font-family:inherit;max-height:3.6em}.recipes-dialog-floating{position:fixed;top:80px;left:50%;transform:translate(-50%);background:var(--bg-secondary);border-radius:16px;border:1px solid var(--border-color);min-width:300px;min-height:200px;display:flex;flex-direction:column;box-shadow:var(--modal-shadow);z-index:500;-webkit-user-select:none;user-select:none}.recipes-dialog-header{display:flex;align-items:center;padding:.75rem 1rem;border-bottom:1px solid var(--border-color);gap:.75rem;flex-shrink:0}.recipes-dialog-header h3{margin:0;font-size:.85rem;color:var(--accent-primary);text-transform:uppercase;letter-spacing:.5px;flex-shrink:0}.palette-selector{position:relative}.palette-selector-btn{display:flex;align-items:center;gap:.4rem;background:var(--border-color);border:1px solid var(--bg-hover);color:var(--accent-primary);padding:.3rem .5rem;border-radius:4px;cursor:pointer}.palette-selector-btn:hover{border-color:var(--accent-primary)}.palette-selector-colors{display:flex;gap:1px}.palette-selector-swatch{width:12px;height:12px;border-radius:2px;border:1px solid rgba(255,255,255,.2)}.palette-selector-name{font-size:.75rem;font-weight:600;max-width:80px;text-overflow:ellipsis;white-space:nowrap}.palette-selector-arrow{font-size:.6rem;opacity:.7}.palette-selector-menu{position:absolute;top:100%;left:0;margin-top:4px;background:var(--bg-secondary);border:1px solid var(--bg-hover);border-radius:6px;min-width:180px;max-height:200px;overflow-y:auto;z-index:1000;box-shadow:0 4px 12px #0006}.palette-selector-item{display:flex;align-items:center;gap:.5rem;padding:.5rem;cursor:pointer;transition:background .15s}.palette-selector-item:hover{background:var(--border-color)}.palette-selector-item.active{background:var(--bg-hover)}.palette-selector-item .palette-selector-name{color:var(--text-secondary);max-width:none}.layout-dropdown{margin-left:auto;background:var(--border-color);border:1px solid var(--bg-hover);color:var(--text-secondary);padding:.35rem .5rem;border-radius:4px;font-size:.8rem;cursor:pointer;outline:none;transition:all .2s}.layout-dropdown:hover{border-color:var(--accent-primary)}.layout-dropdown:focus{border-color:var(--accent-primary);box-shadow:0 0 0 2px #8a63d233}.layout-dropdown option{background:var(--bg-secondary);color:var(--text-secondary);padding:.5rem}.recipes-dialog-colors{display:flex;gap:2px;padding:.4rem .75rem;background:var(--bg-primary);border-bottom:1px solid var(--border-color);flex-shrink:0}.recipes-color-swatch{width:20px;height:20px;border-radius:3px;border:1px solid rgba(255,255,255,.2);flex-shrink:0}.structured-recipes{display:flex;flex-direction:column;gap:.5rem;overflow-y:auto;min-width:0}.recipe-item{display:flex;gap:.5rem;align-items:flex-start;padding:.4rem .5rem;background:#0f346066;border-radius:6px;min-width:0}.recipe-color{position:relative;flex-shrink:0}.recipe-swatch{display:block;width:40px;height:40px;border-radius:6px;box-shadow:inset 0 0 0 1px #0003;flex-shrink:0}.recipe-number{position:absolute;bottom:-4px;right:-4px;width:18px;height:18px;background:var(--bg-secondary);border:2px solid var(--accent-primary);border-radius:50%;font-size:.65rem;font-weight:700;color:var(--accent-primary);display:flex;align-items:center;justify-content:center}.recipe-ingredients{flex:1;font-size:.8rem;color:var(--text-secondary);line-height:1.4;word-wrap:break-word;overflow-wrap:break-word}.ingredient{display:inline}.recipes-dialog-delete,.recipes-dialog-close{background:transparent;border:none;color:var(--text-muted);font-size:1.25rem;cursor:pointer;padding:4px;line-height:1;transition:all .2s;flex-shrink:0;display:flex;align-items:center;justify-content:center;border-radius:4px}.recipes-dialog-delete .material-icon,.recipes-dialog-close .material-icon{font-size:18px}.recipes-dialog-delete:hover{color:var(--danger-color, #dc2626);background:var(--danger-bg, rgba(220, 38, 38, .1))}.recipes-dialog-close:hover{color:#fff;background:#ffffff1a}.recipes-dialog-body{flex:1;display:flex;min-height:0}.layout-left .recipes-dialog-body{flex-direction:row}.layout-right .recipes-dialog-body{flex-direction:row-reverse}.layout-above .recipes-dialog-body{flex-direction:column}.layout-below .recipes-dialog-body{flex-direction:column-reverse}.recipes-dialog-image{flex:0 0 auto;display:flex;align-items:center;justify-content:center;background:var(--bg-primary)}.layout-left .recipes-dialog-image,.layout-right .recipes-dialog-image{min-width:0}.layout-above .recipes-dialog-image,.layout-below .recipes-dialog-image{width:100%;min-height:0}.recipes-dialog-image img{max-width:100%;max-height:100%;object-fit:contain}.recipes-dialog-content{flex:1;padding:1rem;overflow-y:auto;min-width:0}.recipes-dialog-content pre{margin:0;font-size:.8rem;color:var(--text-secondary);white-space:pre-wrap;word-break:break-word;line-height:1.5;font-family:inherit}.palette-tabs{display:flex;border-bottom:1px solid var(--border-color);flex-shrink:0}.palette-tab{flex:1;padding:.6rem 1rem;background:transparent;border:none;color:var(--text-muted);font-size:.85rem;cursor:pointer;transition:all .2s;border-bottom:2px solid transparent}.palette-tab:hover:not(:disabled){color:var(--text-secondary);background:#8a63d21a}.palette-tab.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary)}.palette-tab:disabled{opacity:.4;cursor:not-allowed}.recipes-dialog-image.tabbed,.recipes-dialog-content.tabbed{width:100%;height:100%;max-width:none;max-height:none}.recipes-dialog-image.tabbed{padding:1rem}.split-divider{flex-shrink:0;background:var(--border-color);transition:background .2s}.split-divider:hover{background:var(--accent-primary)}.split-divider.vertical{width:6px;cursor:col-resize}.split-divider.horizontal{height:6px;cursor:row-resize}.recipes-dialog-resize{position:absolute;bottom:0;right:0;width:16px;height:16px;cursor:nwse-resize;background:linear-gradient(135deg,transparent 50%,var(--accent-primary) 50%);border-radius:0 0 12px;opacity:.5;transition:opacity .2s}.recipes-dialog-resize:hover{opacity:1}.recipes-dialog-generate{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:1.5rem;height:100%;text-align:center}.recipes-dialog-generate p{color:var(--text-secondary);font-size:.95rem;margin:0}.recipes-dialog-generate .generate-hint{font-size:.85rem;color:var(--text-muted)}.generate-options{display:flex;flex-direction:column;gap:.75rem;width:100%;max-width:280px}.generate-field{display:flex;flex-direction:column;gap:.35rem;text-align:left}.generate-field label{font-size:.75rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.generate-field select{width:100%;padding:.5rem .75rem;background:var(--input-bg);border:1px solid var(--input-border);border-radius:6px;color:var(--text-primary);font-size:.9rem;cursor:pointer}.generate-field select:focus{outline:none;border-color:var(--accent-primary)}.generate-set-colors{font-size:.75rem;color:var(--text-muted);line-height:1.4;padding:.5rem;background:var(--bg-tertiary);border-radius:4px;max-height:60px;overflow-y:auto}.generate-recipes-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;background:var(--gradient-primary);color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:transform .2s,box-shadow .2s;margin-top:.5rem}.generate-recipes-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--glow-primary)}.generate-recipes-btn:disabled{opacity:.6;cursor:not-allowed}.recipes-sheet-backdrop{position:fixed;inset:0;background:#00000080;z-index:1200;animation:fadeIn .2s ease}.recipes-bottom-sheet{position:fixed;left:0;right:0;bottom:0;max-height:85vh;background:var(--bg-primary);border-radius:16px 16px 0 0;z-index:1250;display:flex;flex-direction:column;animation:slideUpSheet .3s cubic-bezier(.4,0,.2,1);box-shadow:0 -4px 24px #00000026;padding-bottom:env(safe-area-inset-bottom,0px)}@keyframes slideUpSheet{0%{transform:translateY(100%)}to{transform:translateY(0)}}.recipes-sheet-handle{display:flex;justify-content:center;padding:12px 0 8px;flex-shrink:0}.recipes-sheet-handle .handle-bar{width:36px;height:4px;background:var(--border-color);border-radius:2px}.recipes-sheet-header{display:flex;align-items:center;justify-content:space-between;padding:0 16px 12px;border-bottom:1px solid var(--border-color);flex-shrink:0}.recipes-sheet-header .palette-selector{flex:1}.recipes-sheet-header .palette-selector-btn{width:100%;justify-content:flex-start}.recipes-sheet-delete,.recipes-sheet-close{width:36px;height:36px;border:none;background:var(--bg-tertiary);color:var(--text-secondary);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease;flex-shrink:0;margin-left:8px}.recipes-sheet-delete:hover,.recipes-sheet-delete:active{background:var(--danger-bg, #fee2e2);color:var(--danger-color, #dc2626)}.recipes-sheet-close:hover,.recipes-sheet-close:active{background:var(--bg-hover);color:var(--text-primary)}.recipes-sheet-delete .material-icon,.recipes-sheet-close .material-icon{font-size:20px}.recipes-bottom-sheet .recipes-dialog-colors{padding:12px 16px;border-bottom:1px solid var(--border-color);flex-shrink:0}.recipes-sheet-tabs{display:flex;gap:0;border-bottom:1px solid var(--border-color);flex-shrink:0}.recipes-sheet-tab{flex:1;padding:12px 16px;border:none;background:transparent;color:var(--text-secondary);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .15s ease;position:relative}.recipes-sheet-tab:disabled{opacity:.4;cursor:not-allowed}.recipes-sheet-tab.active{color:var(--accent-primary)}.recipes-sheet-tab.active:after{content:"";position:absolute;bottom:0;left:16px;right:16px;height:2px;background:var(--accent-primary);border-radius:1px 1px 0 0}.recipes-sheet-content{flex:1;overflow-y:auto;padding:16px;min-height:200px}.recipes-sheet-image{display:flex;justify-content:center;align-items:flex-start}.recipes-sheet-image img{max-width:100%;max-height:50vh;object-fit:contain;border-radius:8px}.recipes-sheet-recipes{padding-bottom:16px}.recipes-bottom-sheet .recipes-dialog-generate{padding:16px 0}.recipes-bottom-sheet .generate-options,.recipes-bottom-sheet .generate-field,.recipes-bottom-sheet .generate-field select{width:100%}.color-match-backdrop{position:fixed;inset:0;background:#00000080;z-index:1300;animation:fadeIn .2s ease}.color-match-dialog{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:340px;max-width:90vw;background:var(--bg-primary);border-radius:16px;z-index:1350;box-shadow:0 8px 32px #0003;animation:scaleIn .2s ease;overflow:hidden}.color-match-dialog.mobile{position:fixed;inset:auto 0 0;transform:none;width:100%;max-width:100%;border-radius:16px 16px 0 0;animation:slideUpSheet .3s cubic-bezier(.4,0,.2,1);padding-bottom:env(safe-area-inset-bottom,0px)}@keyframes scaleIn{0%{transform:translate(-50%,-50%) scale(.95);opacity:0}to{transform:translate(-50%,-50%) scale(1);opacity:1}}.color-match-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-color)}.color-match-header h3{margin:0;font-size:1.1rem;font-weight:600;color:var(--text-primary)}.color-match-close{width:32px;height:32px;border:none;background:var(--bg-tertiary);color:var(--text-secondary);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease}.color-match-close:hover{background:var(--bg-hover);color:var(--text-primary)}.color-match-close .material-icon{font-size:18px}.color-match-comparison{display:flex;align-items:center;justify-content:center;gap:16px;padding:24px 20px;background:var(--bg-secondary)}.color-match-swatch{display:flex;flex-direction:column;align-items:center;gap:8px}.color-match-swatch .swatch-color{width:80px;height:80px;border-radius:12px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #00000026}.color-match-swatch .swatch-label{font-size:.85rem;font-weight:600}.color-match-swatch .swatch-hex{font-size:.8rem;font-family:monospace;color:var(--text-secondary)}.color-match-arrow{color:var(--text-muted)}.color-match-arrow .material-icon{font-size:24px}.color-match-info{padding:16px 20px;display:flex;flex-direction:column;gap:12px}.color-match-info>div{display:flex;justify-content:space-between;align-items:center}.color-match-info .accuracy-label,.color-match-info .palette-label,.color-match-info .color-num-label{font-size:.9rem;color:var(--text-secondary)}.color-match-info .accuracy-value{font-size:1.1rem;font-weight:600;color:var(--accent-primary)}.color-match-info .palette-link{background:none;border:none;color:var(--accent-primary);font-size:.9rem;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:4px;padding:0}.color-match-info .palette-link:hover{text-decoration:underline}.color-match-info .palette-link .material-icon{font-size:16px}.color-match-info .color-num-value{font-size:1rem;font-weight:600;color:var(--text-primary)}.color-match-recipe{padding:16px 20px;background:var(--bg-secondary);border-top:1px solid var(--border-color)}.color-match-recipe h4{margin:0 0 8px;font-size:.85rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.color-match-recipe .recipe-ingredients{font-size:.95rem;color:var(--text-primary);line-height:1.5}.color-match-recipe .ingredient{display:inline}.color-match-actions{display:flex;gap:12px;padding:16px 20px;border-top:1px solid var(--border-color)}.match-action-btn{flex:1;padding:12px 16px;border:none;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .15s ease}.match-action-btn.secondary{background:var(--bg-tertiary);color:var(--text-primary)}.match-action-btn.secondary:hover{background:var(--bg-hover)}.match-action-btn.primary{background:var(--accent-primary);color:#fff}.match-action-btn.primary:hover{opacity:.9}.color-match-section{padding:8px 12px;border-top:1px solid var(--border-color);background:var(--bg-secondary)}.color-match-section .match-header{font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:6px}.color-match-section .match-content{display:flex;align-items:center;gap:10px}.color-match-section .match-swatch{width:40px;height:40px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;flex-shrink:0;box-shadow:inset 0 0 0 1px #0000001a}.color-match-section .match-details{flex:1;min-width:0}.color-match-section .match-accuracy{font-size:.85rem;font-weight:600;color:var(--text-primary)}.color-match-section .match-palette-link{background:none;border:none;padding:0;font-size:.8rem;color:var(--accent-primary);cursor:pointer;text-align:left;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.color-match-section .match-palette-link:hover{text-decoration:underline}.color-match-section .match-recipe{font-size:.75rem;color:var(--text-secondary);margin-top:4px;line-height:1.4}.color-match-section .recipe-ingredient{display:inline}.color-preview-mobile-sheet .color-match-section{margin:0 -16px;padding:12px 16px}.color-recipe-generator{border-top:1px solid var(--border-color);padding:8px}.color-recipe-generator.desktop{padding:6px 8px}.recipe-generator-toggle{display:flex;align-items:center;gap:6px;width:100%;padding:6px 8px;background:transparent;border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);cursor:pointer;font-size:12px}.recipe-generator-toggle:hover{background:var(--hover-bg)}.recipe-generator-toggle .material-icon{font-size:16px}.recipe-generator-form{display:flex;flex-direction:column;gap:6px;margin-top:8px}.color-recipe-generator.desktop .recipe-generator-form{flex-direction:row;flex-wrap:wrap;align-items:center}.recipe-generator-form select{padding:4px 6px;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-secondary);color:var(--text-primary);font-size:11px;flex:1;min-width:0}.color-recipe-generator.desktop .recipe-generator-form select{flex:1;min-width:60px}.generate-recipe-btn{padding:6px 12px;background:var(--accent-color);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center;gap:4px}.generate-recipe-btn:disabled{opacity:.6;cursor:not-allowed}.color-recipe-generator.desktop .generate-recipe-btn{padding:4px 8px;font-size:11px}.generated-recipe{padding:8px;background:var(--bg-secondary);border-radius:4px;font-size:11px;line-height:1.4;width:100%}.generated-recipe .recipe-ingredient{display:inline}.palette-builder-dialog{position:fixed;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 8px 32px #0000004d;z-index:1000;display:flex;flex-direction:column;overflow:hidden}.palette-builder-dialog .dialog-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);cursor:grab}.palette-builder-dialog .dialog-title{font-size:13px;font-weight:600;color:var(--text-primary)}.palette-builder-dialog .dialog-actions{display:flex;align-items:center;gap:4px}.palette-builder-dialog .dialog-action-btn{padding:4px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center}.palette-builder-dialog .dialog-action-btn:hover{background:var(--hover-bg);color:var(--text-primary)}.palette-builder-dialog .dialog-action-btn.save{color:var(--accent-color)}.palette-builder-dialog .dialog-action-btn .material-icon{font-size:18px}.palette-builder-dialog .dialog-close-btn{padding:4px 8px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;font-size:18px;line-height:1}.palette-builder-dialog .dialog-close-btn:hover{color:var(--text-primary)}.palette-builder-dialog .dialog-body{flex:1;display:flex;flex-direction:column;overflow:hidden}.palette-builder-dialog .dialog-resize-handle{position:absolute;bottom:0;right:0;width:16px;height:16px;cursor:nwse-resize;background:linear-gradient(-45deg,transparent 30%,var(--border-color) 30%,var(--border-color) 40%,transparent 40%,transparent 60%,var(--border-color) 60%,var(--border-color) 70%,transparent 70%)}.palette-builder-colors{display:flex;flex-wrap:wrap;gap:4px;padding:8px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);max-height:100px;overflow-y:auto}.palette-builder-swatch{width:32px;height:32px;border-radius:4px;cursor:pointer;position:relative;border:2px solid transparent;transition:transform .1s,border-color .1s;display:flex;align-items:center;justify-content:center}.palette-builder-swatch:hover{transform:scale(1.1)}.palette-builder-swatch.selected{border-color:var(--accent-color);box-shadow:0 0 0 2px var(--bg-primary)}.palette-builder-swatch .swatch-index{font-size:10px;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5)}.palette-builder-empty{padding:12px;text-align:center;color:var(--text-secondary);font-size:12px;width:100%}.palette-builder-detail{flex:1;padding:12px;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;gap:10px;min-width:0}.palette-builder-detail.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-secondary);text-align:center}.palette-builder-detail.empty .hint{font-size:11px;opacity:.7;margin-top:4px}.palette-builder-detail .detail-swatch{height:60px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:500}.palette-builder-detail .detail-info{display:flex;gap:8px}.palette-builder-detail .detail-value{flex:1;padding:8px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;cursor:pointer;font-size:11px;font-family:monospace;color:var(--text-primary);display:flex;flex-direction:column;align-items:center;gap:2px;transition:background .1s}.palette-builder-detail .detail-value:hover{background:var(--hover-bg)}.palette-builder-detail .detail-value .copy-hint{font-size:9px;color:var(--text-secondary);font-family:var(--font-family)}.palette-builder-detail .detail-match{padding:8px;background:var(--bg-secondary);border-radius:4px;font-size:11px}.palette-builder-detail .match-label{color:var(--text-secondary);margin-bottom:4px}.palette-builder-detail .match-info{display:flex;align-items:center;gap:6px}.palette-builder-detail .match-swatch-small{width:20px;height:20px;border-radius:3px}.palette-builder-detail .match-percent{color:var(--text-secondary)}.palette-builder-detail .match-palette-link{background:none;border:none;color:var(--accent-color);cursor:pointer;font-size:11px;padding:0}.palette-builder-detail .match-palette-link:hover{text-decoration:underline}.palette-builder-detail .match-recipe-small{margin-top:4px;color:var(--text-secondary);font-size:10px}.palette-builder-detail .detail-recipe-generator{border-top:1px solid var(--border-color);padding-top:10px}.palette-builder-detail .recipe-toggle-btn{display:flex;align-items:center;gap:6px;width:100%;padding:6px 8px;background:transparent;border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);cursor:pointer;font-size:11px}.palette-builder-detail .recipe-toggle-btn:hover{background:var(--hover-bg)}.palette-builder-detail .recipe-toggle-btn .material-icon{font-size:16px}.palette-builder-detail .recipe-form{display:flex;gap:4px;margin-top:8px}.palette-builder-detail .recipe-form select{flex:1;min-width:0;padding:4px;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-secondary);color:var(--text-primary);font-size:10px}.palette-builder-detail .generate-btn{padding:4px 10px;background:var(--accent-color);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:11px}.palette-builder-detail .generate-btn:disabled{opacity:.6}.palette-builder-detail .generated-recipe-result{margin-top:8px;padding:8px;background:var(--bg-secondary);border-radius:4px;font-size:11px;line-height:1.4}.palette-builder-detail .delete-color-btn{display:flex;align-items:center;justify-content:center;gap:4px;padding:6px 12px;background:transparent;border:none;border-radius:4px;color:var(--text-secondary);cursor:pointer;font-size:11px;margin-top:8px;white-space:nowrap;width:auto;flex-shrink:0}.palette-builder-detail .delete-color-btn:hover{background:#e74c3c1a;color:var(--error-color, #e74c3c)}.palette-builder-detail .delete-color-btn .material-icon{font-size:16px;flex-shrink:0}.palette-builder-sheet{position:fixed;bottom:0;left:0;right:0;background:var(--bg-primary);border-radius:16px 16px 0 0;box-shadow:0 -4px 20px #0000004d;z-index:1000;max-height:70vh;display:flex;flex-direction:column}.palette-builder-sheet .sheet-handle{width:40px;height:4px;background:var(--border-color);border-radius:2px;margin:8px auto}.palette-builder-sheet .sheet-header{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;border-bottom:1px solid var(--border-color)}.palette-builder-sheet .sheet-title{font-size:15px;font-weight:600}.palette-builder-sheet .sheet-actions{display:flex;align-items:center;gap:8px}.palette-builder-sheet .sheet-action-btn{padding:6px 12px;background:transparent;border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);font-size:12px;cursor:pointer}.palette-builder-sheet .sheet-close-btn{padding:6px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer}.palette-builder-sheet .palette-builder-colors{padding:12px 16px;overflow-x:auto;flex-wrap:nowrap}.palette-builder-sheet .palette-builder-detail{flex:1;overflow-y:auto;padding:16px}.palette-builder-sheet .save-palette-btn{display:flex;align-items:center;justify-content:center;gap:8px;margin:12px 16px;padding:12px;background:var(--accent-color);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer}.palette-builder-sheet .save-palette-btn .material-icon{font-size:20px}.palette-result{margin-top:1rem;border-radius:8px;border:1px solid var(--border-color);cursor:pointer;transition:transform .2s,box-shadow .2s}.palette-result:hover{transform:scale(1.02);box-shadow:0 4px 12px #8a63d24d}.palette-result img{width:100%;height:auto;display:block}.palette-viewer{display:flex;width:100%;height:100%;background:var(--bg-primary)}.pv-sidebar{width:280px;min-width:280px;background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column}.pv-sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border-color)}.pv-sidebar-header h2{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0}.pv-count{background:var(--accent-primary);color:#fff;font-size:.75rem;font-weight:600;padding:.2rem .5rem;border-radius:10px}.pv-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center;color:var(--text-muted)}.pv-empty .material-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.pv-empty p{margin:.25rem 0}.pv-empty-hint{font-size:.85rem;color:var(--text-muted)}.pv-palette-list{flex:1;overflow-y:auto;padding:.5rem}.pv-palette-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:8px;cursor:pointer;transition:background .2s;margin-bottom:.25rem}.pv-palette-item:hover{background:var(--bg-hover)}.pv-palette-item.selected{background:var(--bg-tertiary);border:1px solid var(--accent-primary)}.pv-palette-swatches{display:flex;gap:2px;flex-shrink:0}.pv-mini-swatch{width:14px;height:14px;border-radius:3px;border:1px solid rgba(255,255,255,.1)}.pv-palette-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.15rem}.pv-palette-name{font-size:.9rem;font-weight:500;color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis}.pv-palette-meta{font-size:.75rem;color:var(--text-muted)}.pv-main{flex:1;overflow-y:auto;padding:2rem;display:flex;flex-direction:column;gap:2rem}.pv-header{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.pv-header h1{font-size:1.75rem;font-weight:600;color:var(--text-primary);margin:0}.pv-paint-set{background:var(--bg-tertiary);color:var(--text-secondary);font-size:.85rem;padding:.35rem .75rem;border-radius:16px}.pv-colors-section h3,.pv-recipes-section h3{font-size:1rem;font-weight:500;color:var(--text-secondary);margin-bottom:1rem}.pv-color-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.75rem}.pv-color-card{aspect-ratio:1;border-radius:12px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;box-shadow:0 2px 8px #0003;transition:transform .2s,box-shadow .2s}.pv-color-card:hover{transform:scale(1.05);box-shadow:0 4px 16px #0000004d}.pv-color-number{font-size:1.5rem;font-weight:700}.pv-color-hex{font-size:.7rem;font-family:monospace;opacity:.8}.pv-recipes-content{display:flex;gap:1.5rem;flex-wrap:wrap}.pv-palette-image{flex:0 0 auto;max-width:400px;border-radius:12px;cursor:pointer;position:relative;box-shadow:0 4px 16px #0000004d;transition:transform .2s}.pv-palette-image:hover{transform:scale(1.02)}.pv-palette-image img{width:100%;height:auto;display:block}.pv-expand-hint{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000000b3);color:#fff;font-size:.75rem;padding:1rem .75rem .5rem;text-align:center;opacity:0;transition:opacity .2s}.pv-palette-image:hover .pv-expand-hint{opacity:1}.pv-recipes-panel{flex:1;min-width:280px}.pv-recipes-list{display:flex;flex-direction:column;gap:.5rem}.pv-recipe-item{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem;background:var(--bg-secondary);border-radius:8px}.pv-recipe-color{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.pv-recipe-swatch{width:24px;height:24px;border-radius:6px;border:2px solid rgba(255,255,255,.2)}.pv-recipe-number{font-weight:600;font-size:.9rem;color:var(--text-primary);min-width:20px}.pv-recipe-ingredients{flex:1;color:var(--text-secondary);font-size:.9rem;line-height:1.5}.pv-ingredient{color:var(--text-primary)}.pv-recipes-text{white-space:pre-wrap;font-size:.85rem;color:var(--text-secondary);line-height:1.6;background:var(--bg-secondary);padding:1rem;border-radius:8px}.pv-no-recipes{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center;background:var(--bg-secondary);border-radius:12px;color:var(--text-muted)}.pv-no-recipes .material-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.pv-no-recipes p{margin:.25rem 0}.pv-no-recipes-hint{font-size:.85rem}.pv-no-selection{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-muted);text-align:center}.pv-no-selection .material-icon{font-size:4rem;margin-bottom:1rem;opacity:.3}.pv-no-selection p{font-size:1.1rem}.pv-no-selection-hint{font-size:.85rem!important;color:var(--text-muted);margin-top:.5rem!important}.pv-image-modal{position:fixed;inset:0;background:#000000e6;z-index:2000;display:flex;align-items:center;justify-content:center;padding:2rem;cursor:pointer}.pv-modal-content{position:relative;max-width:90vw;max-height:90vh;cursor:default}.pv-modal-content img{max-width:100%;max-height:85vh;object-fit:contain;border-radius:8px}.pv-modal-close{position:absolute;top:-40px;right:0;width:36px;height:36px;border:none;background:var(--accent-secondary);color:#fff;font-size:1.5rem;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.pv-modal-close:hover{background:#ff6b6b}@media(max-width:768px){.palette-viewer{flex-direction:column}.pv-sidebar{width:100%;min-width:100%;max-height:40vh}.pv-main{padding:1rem}.pv-color-grid{grid-template-columns:repeat(auto-fill,minmax(70px,1fr))}.pv-recipes-content{flex-direction:column}.pv-palette-image{max-width:100%}}.palette-list-panel{display:flex;flex-direction:column;height:100%}.palette-list-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center;color:var(--text-muted)}.palette-list-empty .material-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.palette-list-empty p{margin:.25rem 0}.palette-list-hint{font-size:.85rem;color:var(--text-muted)}.palette-list-items{display:flex;flex-direction:column;gap:.5rem}.palette-list-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:8px;cursor:pointer;transition:background .2s;border:1px solid transparent}.palette-list-item:hover{background:var(--bg-hover)}.palette-list-item.selected{background:var(--bg-tertiary);border-color:var(--accent-primary)}.palette-list-swatches{display:flex;gap:2px;flex-shrink:0}.palette-list-swatch{width:14px;height:14px;border-radius:3px;border:1px solid rgba(255,255,255,.1)}.palette-list-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.15rem}.palette-list-name{font-size:.9rem;font-weight:500;color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis}.palette-list-meta{font-size:.75rem;color:var(--text-muted)}.palette-fullscreen-overlay{position:fixed;inset:0;background:#000000e6;z-index:2000;display:flex;align-items:center;justify-content:center;padding:2rem;cursor:pointer}.palette-fullscreen-content{position:relative;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;gap:1rem;cursor:default}.palette-fullscreen-content img{max-width:100%;max-height:70vh;object-fit:contain;border-radius:8px}.palette-fullscreen-close{position:absolute;top:-40px;right:0;width:36px;height:36px;border:none;background:var(--accent-secondary);color:#fff;font-size:1.5rem;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.palette-fullscreen-close:hover{background:#ff6b6b}.palette-fullscreen-recipes{background:var(--bg-secondary);padding:1rem;border-radius:8px;max-height:20vh;overflow-y:auto}.palette-fullscreen-recipes h5{margin:0 0 .5rem;font-size:.9rem;color:var(--accent-primary)}.palette-fullscreen-recipes pre{margin:0;font-size:.85rem;color:var(--text-secondary);white-space:pre-wrap;line-height:1.6;font-family:inherit}.canvas-container canvas{box-shadow:0 4px 20px var(--shadow-color)}.canvas-placeholder{color:var(--text-muted);text-align:center;border:2px dashed #444;border-radius:12px;padding:3rem 2rem;cursor:pointer;transition:all .2s;max-width:400px}.canvas-placeholder:hover{border-color:var(--accent-primary);color:var(--text-muted)}.canvas-placeholder.drag-over{border-color:var(--accent-primary);background:#8a63d21a;color:var(--accent-primary)}.selection-menu{display:flex;flex-direction:column;gap:.5rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:.5rem;box-shadow:0 4px 20px var(--shadow-color);z-index:100}.selection-menu-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--accent-primary);color:var(--bg-primary);border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;white-space:nowrap}.selection-menu-btn:hover{background:var(--accent-primary-hover)}.selection-menu-btn.cancel{background:var(--bg-tertiary);color:var(--text-secondary)}.selection-menu-btn.cancel:hover{background:var(--accent-secondary);color:#fff}.color-picker-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000}.color-picker-dialog{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:12px;padding:1.5rem;min-width:320px;max-width:90vw;max-height:80vh;overflow-y:auto}.color-picker-dialog h3{margin:0 0 1rem;font-size:1.1rem;color:var(--text-primary);text-align:center}.palette-name-field{margin-bottom:1rem}.palette-name-input{width:100%;padding:.7rem .9rem;font-size:.95rem;border:2px solid var(--border-color);border-radius:8px;background:var(--input-bg);color:var(--text-primary);transition:border-color .15s,box-shadow .15s;box-sizing:border-box}.palette-name-input::placeholder{color:var(--text-muted)}.palette-name-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #8a63d233}.extracted-colors-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;margin-bottom:1rem}.extracted-color-item{aspect-ratio:1;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.5rem;font-weight:700;border:3px solid transparent;transition:transform .1s,border-color .1s}.extracted-color-item:hover{transform:scale(1.05)}.extracted-color-item.selected{border-color:var(--accent-primary);box-shadow:0 0 10px #8a63d280}.color-picker-actions{display:flex;gap:.75rem;justify-content:flex-end}.picker-btn{padding:.6rem 1.2rem;border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.picker-btn.cancel{background:var(--bg-tertiary);color:var(--text-secondary)}.picker-btn.cancel:hover{background:#444;color:#fff}.picker-btn.save{background:var(--accent-primary);color:var(--bg-primary)}.picker-btn.save:hover:not(:disabled){background:var(--accent-primary-hover)}.picker-btn.save:disabled{background:var(--bg-tertiary);color:var(--text-muted);cursor:not-allowed}.picker-btn.select-all{background:var(--border-color);color:var(--text-primary)}.picker-btn.select-all:hover{background:var(--bg-hover)}.picker-btn.get-more{background:var(--border-color);color:var(--text-primary)}.picker-btn.get-more:hover{background:var(--bg-hover)}.canvas-placeholder p{font-size:1.1rem;margin:0}@media(max-width:900px){.sidebar{width:240px;min-width:240px}.canvas-section{width:calc(100vw - 240px);padding:1rem}}.sidebar-overlay{display:none}@media(max-width:768px){.app-header{padding:.5rem 1rem;justify-content:center}.header-zoom{gap:.3rem}.header-zoom button{padding:.3rem .5rem;font-size:.8rem}.header-zoom span{min-width:40px;font-size:.8rem}.app-main{flex-direction:row;position:relative;overflow:visible}.icon-sidebar,.tools-sidebar{width:48px;min-width:48px;padding:.25rem}.icon-sidebar-btn{width:36px;height:36px}.panel-overlay{right:48px}.panel-overlay.left{left:48px;right:0}.sidebar-panel{right:48px;width:85%;max-width:280px;bottom:70px}.sidebar-panel.left{left:48px;right:auto}.canvas-section{width:calc(100vw - 48px);min-width:calc(100vw - 48px);min-height:100vh;padding:.5rem;padding-bottom:80px}.grid-controls .controls-grid{grid-template-columns:1fr 1fr;gap:.5rem}.paper-settings .settings-row{flex-direction:column;gap:.5rem}.paper-settings select,.paper-settings input{width:100%}.coordinate-display{font-size:.75rem}.coordinate-display .coord-grid{grid-template-columns:1fr;gap:.25rem}.draw-mode-toggle{flex-wrap:wrap}.draw-mode-toggle button{flex:1;min-width:60px;padding:.4rem .6rem;font-size:.75rem}.points-list,.rulers-list,.colors-list{padding:.5rem}.points-list h4,.rulers-list h4,.colors-list h4{font-size:.8rem}.point-item,.ruler-item,.color-item{padding:.4rem;font-size:.75rem}.color-dialog{max-width:calc(100vw - 20px);max-height:calc(100vh - 20px)}.drop-zone{padding:1rem;min-height:80px}.drop-zone p{font-size:.875rem}.url-input-group{flex-direction:column}.url-input-group input,.url-input-group button{width:100%}}@media(max-width:480px){.app-header{padding:.5rem .75rem}.app-header h1{font-size:1.1rem}.app-header p{font-size:.75rem}.sidebar{max-height:40vh;padding:.5rem;gap:.5rem}.canvas-section{min-height:60vh;padding:.25rem}.grid-controls,.paper-settings,.coordinate-display,.points-list,.rulers-list,.colors-list{padding:.4rem}.grid-controls h3,.paper-settings h3{font-size:.8rem}button{font-size:.75rem;padding:.35rem .6rem}}@media(pointer:coarse){button{min-height:44px;min-width:44px}.header-zoom button{min-height:36px;min-width:36px}.delete-point-btn,.delete-ruler-btn,.delete-color-btn{min-width:32px;min-height:32px}input[type=range]{height:8px}input[type=range]::-webkit-slider-thumb{width:24px;height:24px}.color-swatch{width:36px;height:36px}}.auth-modal-overlay{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:2000}.auth-modal{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:16px;padding:2rem;min-width:320px;max-width:400px;position:relative;box-shadow:var(--modal-shadow)}.auth-modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer;padding:.25rem .5rem;line-height:1}.auth-modal-close:hover{color:var(--accent-primary)}.auth-modal-title{margin:0 0 1.5rem;font-size:1.5rem;color:var(--text-primary);text-align:center}.auth-modal-prompt{margin:-.5rem 0 1.5rem;padding:.75rem 1rem;background:#8a63d21a;border:1px solid rgba(138,99,210,.25);border-radius:10px;color:var(--text-secondary);font-size:.9rem;text-align:center;line-height:1.4}.auth-form{display:flex;flex-direction:column;gap:1rem}.auth-field{display:flex;flex-direction:column;gap:.5rem}.auth-field label{color:var(--text-secondary);font-size:.9rem}.auth-field input{padding:.75rem 1rem;background:var(--border-color);border:1px solid var(--bg-hover);border-radius:6px;color:var(--text-primary);font-size:1rem}.auth-field input:focus{outline:none;border-color:var(--accent-primary)}.auth-error{background:#ff7e6b33;border:1px solid var(--accent-secondary);color:var(--accent-secondary);padding:.75rem;border-radius:6px;font-size:.9rem}.auth-message{background:#8a63d233;border:1px solid var(--accent-primary);color:var(--accent-primary);padding:.75rem;border-radius:6px;font-size:.9rem}.auth-submit{padding:.75rem 1.5rem;background:var(--accent-primary);color:var(--bg-primary);border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;margin-top:.5rem}.auth-submit:hover:not(:disabled){background:var(--accent-primary-hover)}.auth-submit:disabled{background:var(--bg-tertiary);color:var(--text-muted);cursor:not-allowed}.auth-links{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem;text-align:center}.auth-link{background:none;border:none;color:var(--accent-primary);font-size:.9rem;cursor:pointer;padding:.25rem}.auth-link:hover{text-decoration:underline}.projects-panel{display:flex;flex-direction:column;height:100%}.new-project-btn{width:100%;padding:10px 16px;border:none;border-radius:6px;background:var(--accent-primary);color:#fff;font-size:.9rem;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;margin-top:12px}.new-project-btn:hover{background:var(--accent-hover)}.projects-loading,.projects-empty,.projects-error{text-align:center;color:var(--text-muted);padding:2rem 1rem;font-size:.9rem}.projects-error{color:var(--accent-secondary)}.projects-list{list-style:none;padding:0;margin:0;flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.5rem}.project-item{display:flex;align-items:center;gap:.75rem;padding:.5rem;background:var(--border-color);border-radius:8px;cursor:pointer;position:relative;transition:background .2s}.project-item:hover{background:var(--bg-hover)}.project-item.current{border:2px solid var(--accent-primary)}.project-thumbnail{width:48px;height:48px;background:var(--bg-primary);border-radius:4px;background-size:cover;background-position:center;flex-shrink:0;display:flex;align-items:center;justify-content:center}.project-thumbnail .no-thumb{font-size:.7rem;color:var(--text-muted);text-align:center}.project-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.25rem}.project-name{color:var(--text-primary);font-size:.9rem;white-space:nowrap;text-overflow:ellipsis}.project-date{color:var(--text-muted);font-size:.75rem}.project-delete-btn{width:24px;height:24px;border:none;background:transparent;color:var(--text-muted);font-size:1.25rem;cursor:pointer;opacity:0;transition:opacity .2s}.project-item:hover .project-delete-btn{opacity:1}.project-delete-btn:hover{color:var(--accent-secondary)}.delete-confirm{position:absolute;inset:0;background:#16213ef2;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem}.delete-confirm p{margin:0;color:var(--text-primary);font-size:.85rem}.delete-confirm-btns{display:flex;gap:.5rem}.delete-confirm-btns button{padding:.4rem .75rem;border:none;border-radius:4px;font-size:.8rem;cursor:pointer}.delete-confirm-btns button:first-child{background:var(--accent-secondary);color:#fff}.delete-confirm-btns button:last-child{background:var(--bg-tertiary);color:var(--text-primary)}.refresh-btn{margin-top:1rem;padding:.5rem 1rem;background:var(--border-color);border:1px solid var(--bg-hover);border-radius:6px;color:var(--text-secondary);font-size:.85rem;cursor:pointer}.refresh-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.refresh-btn:disabled{opacity:.5;cursor:not-allowed}.icon-sidebar-spacer{flex:1}.icon-sidebar-btn.save-btn,.icon-sidebar-btn.user-btn{position:relative}.save-message{position:absolute;left:100%;top:50%;transform:translateY(-50%);margin-left:.5rem;background:var(--accent-primary);color:var(--bg-primary);padding:.25rem .5rem;border-radius:4px;font-size:.75rem;white-space:nowrap;font-family:inherit}.icon-sidebar-btn.user-btn .material-icon{color:inherit}.app-header{display:flex;align-items:center;justify-content:space-between;height:48px;padding:0 1rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);flex-shrink:0}.header-left{display:flex;align-items:center;gap:1rem}.app-logo{font-family:Poppins,sans-serif;font-size:1.1rem;font-weight:700;color:var(--text-primary);letter-spacing:-.5px}.logo-accent{color:var(--accent-primary)}.app-logo-btn{background:none;border:none;padding:0;cursor:pointer;display:flex;align-items:center}.app-logo-btn:hover .app-logo{opacity:.8}.credits-modal h2,.auth-modal h2,.palette-dialog-header h3,.panel-header h2,.recipes-dialog-header h3{font-family:Poppins,sans-serif;font-weight:600}.header-center{display:flex;align-items:center;justify-content:center;flex:1}.project-name-btn{background:none;border:none;color:var(--text-primary);font-size:.95rem;padding:.4rem .75rem;border-radius:6px;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:background .2s}.project-name-btn:hover{background:#ffffff1a}.project-name-input{background:var(--bg-secondary);border:1px solid var(--accent-primary);color:var(--text-primary);font-size:.95rem;padding:.4rem .75rem;border-radius:6px;text-align:center;min-width:200px}.project-name-input:focus{outline:none}.unsaved-dot{width:8px;height:8px;background:var(--accent-secondary);border-radius:50%;display:inline-block}.header-right{display:flex;align-items:center;gap:.75rem}.theme-toggle-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:none;border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all .2s}.theme-toggle-btn:hover{background:var(--bg-tertiary);color:var(--accent-primary)}.theme-toggle-btn .material-icon{font-family:Material Icons;font-size:20px;font-weight:400;font-style:normal;line-height:1}.header-save-btn{display:flex;align-items:center;gap:.4rem;padding:.4rem .75rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-secondary);font-size:.85rem;cursor:pointer;transition:all .2s}.header-save-btn .material-icon,.header-user-btn .material-icon{font-family:Material Icons;font-size:18px;font-weight:400;font-style:normal;line-height:1}.header-save-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary);border-color:var(--accent-primary)}.header-save-btn:disabled{opacity:.6;cursor:not-allowed}.header-save-btn.saving .material-icon{animation:spin 1s linear infinite}.pro-badge{background:linear-gradient(135deg,#f5af19,#f12711);color:#fff;font-size:.7rem;font-weight:700;padding:.25rem .6rem;border-radius:4px;letter-spacing:.5px}.upgrade-btn{background:var(--gradient-primary);color:#fff;font-size:.8rem;font-weight:600;padding:.4rem .75rem;border:none;border-radius:10px;cursor:pointer;transition:all .2s}.upgrade-btn:hover{filter:brightness(1.1);transform:translateY(-1px);box-shadow:var(--glow-primary)}.header-user-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:none;border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all .2s}.header-user-btn:hover{background:var(--bg-tertiary);color:var(--accent-primary)}.sign-in-btn{background:var(--gradient-primary);color:#fff;font-size:.85rem;font-weight:600;padding:.5rem 1rem;margin-right:.5rem;border:none;border-radius:10px;cursor:pointer;transition:all .2s}.sign-in-btn:hover{filter:brightness(1.1);transform:translateY(-1px);box-shadow:var(--glow-primary)}.user-menu-container{position:relative;display:flex;align-items:center;gap:.5rem}.user-menu-backdrop{position:fixed;inset:0;z-index:99}.user-menu-dropdown{position:absolute;top:100%;right:0;margin-top:.5rem;background:var(--bg-secondary);border:1px solid var(--bg-hover);border-radius:8px;min-width:220px;box-shadow:0 8px 24px #0006;z-index:100}.user-menu-header{padding:.75rem 1rem;border-bottom:1px solid var(--bg-hover);display:flex;justify-content:space-between;align-items:center}.user-menu-email{color:var(--text-primary);font-size:.85rem;text-overflow:ellipsis;white-space:nowrap;max-width:140px}.user-menu-plan{font-size:.7rem;font-weight:600;padding:.2rem .5rem;border-radius:4px;text-transform:uppercase}.user-menu-plan.free{background:var(--bg-tertiary);color:var(--text-muted)}.user-menu-plan.pro{background:linear-gradient(135deg,#f5af19,#f12711);color:#fff}.user-menu-items{padding:.5rem 0}.user-menu-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.6rem 1rem;background:none;border:none;color:var(--text-secondary);font-size:.85rem;cursor:pointer;text-align:left;transition:background .2s}.user-menu-item:hover{background:#ffffff1a;color:#fff}.user-menu-item.upgrade{color:#f5af19}.user-menu-item.upgrade:hover{background:#f5af1926}.user-menu-item .material-icon{font-family:Material Icons;font-size:18px;font-weight:400;font-style:normal;line-height:1}.user-menu-divider{border:none;border-top:1px solid var(--bg-hover);margin:.25rem 0}.app{display:flex;flex-direction:column;height:100vh}.app-main{flex:1;display:flex}.credits-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--gradient-primary);border:1px solid transparent;border-radius:20px;color:#fff;font-size:.9rem;cursor:pointer;transition:all .2s}.credits-btn:hover{filter:brightness(1.1);transform:translateY(-1px);box-shadow:var(--glow-primary)}.credits-btn:disabled{opacity:.6;cursor:not-allowed}.credits-icon{color:#f5af19;font-size:1.1rem}.credits-count{font-weight:600}.trial-badge{background:linear-gradient(135deg,var(--accent-primary),#637FD2);color:var(--bg-primary);padding:.15rem .5rem;border-radius:10px;font-size:.75rem;font-weight:600}.credits-modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}.credits-modal{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:20px;padding:1.5rem;max-width:680px;width:95%;max-height:90vh;box-shadow:var(--modal-shadow);overflow-y:auto;position:relative;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.credits-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.credits-modal h2{margin:0;color:var(--text-primary);font-size:1.25rem;font-weight:600}.credits-modal h4{margin:0 0 .75rem;color:var(--text-primary);font-size:.9rem;font-weight:600}.credits-modal .purchase-header{margin-top:1rem}.modal-close{background:none;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer;padding:.25rem .5rem;line-height:1;transition:color .2s}.modal-close:hover{color:var(--text-primary)}.credits-info-row{display:flex;gap:1rem;margin-bottom:1rem}.credits-balance-display{display:flex;align-items:center;gap:.5rem;padding:1rem 1.25rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;flex-shrink:0}.balance-icon{color:#f5af19;font-size:1.25rem}.balance-amount{color:var(--accent-primary);font-size:1.5rem;font-weight:700}.balance-label{color:var(--text-muted);font-size:.85rem}.trials-info{padding:1rem;background:#f5af191a;border:1px solid rgba(245,175,25,.3);border-radius:8px;margin-bottom:1rem}.trials-info p{margin:0 0 .5rem;color:#f5af19;font-weight:600}.trials-info ul{margin:0;padding-left:1.25rem;color:var(--text-secondary)}.trials-info li{margin:.25rem 0}.credits-usage-info{flex:1;padding:.75rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px}.credits-usage-info h4{margin:0 0 .35rem;font-size:.8rem;color:var(--text-primary)}.credits-usage-info ul{margin:0;padding-left:1.25rem;color:var(--text-secondary);font-size:.8rem}.credits-usage-info li{margin:.15rem 0}.usage-note{margin:.35rem 0 0;font-size:.7rem;color:var(--text-muted);font-style:italic}.packs-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem}.pack-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1rem .75rem;background:var(--gradient-primary);border:2px solid rgba(138,99,210,.3);border-radius:12px;cursor:pointer;transition:all .2s}.pack-btn:hover{filter:brightness(1.1);transform:translateY(-2px);box-shadow:var(--glow-primary);border-color:var(--accent-primary)}.pack-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.pack-credits{color:#fff;font-size:1rem;font-weight:600}.pack-price{color:#fffc;font-size:.9rem;font-weight:500;margin:.25rem 0}.pack-desc{color:#fff9;font-size:.7rem;text-align:center}.climate-badge{display:flex;align-items:center;gap:.5rem;margin-top:1rem;padding:.75rem 1rem;background:#22c55e1a;border:1px solid rgba(34,197,94,.25);border-radius:10px}.climate-icon{font-size:1.1rem;flex-shrink:0}.climate-text{color:var(--text-secondary);font-size:.75rem;line-height:1.4}.climate-text strong{color:#22c55e}@media(max-width:600px){.credits-info-row{flex-direction:column;gap:.75rem}.credits-balance-display{justify-content:center}.packs-grid{grid-template-columns:repeat(2,1fr)}.credits-modal{max-width:95%;padding:1rem}}.user-menu-credits{color:var(--accent-primary);font-size:.8rem;font-weight:600}.test-mode-toggle{padding:1rem;background:#ffc1071a;border:1px solid rgba(255,193,7,.3);border-radius:8px;margin-bottom:1rem}.test-mode-toggle label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.test-mode-toggle input[type=checkbox]{width:18px;height:18px;accent-color:#ffc107}.test-mode-label{color:#ffc107;font-weight:600}.test-mode-hint{margin:.5rem 0 0;font-size:.8rem;color:var(--text-muted);font-family:monospace}.projects-dashboard{position:fixed;inset:56px 0 0;background:var(--bg-primary);padding:2rem;overflow-y:auto;z-index:100}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;max-width:1200px;margin-left:auto;margin-right:auto}.dashboard-header h1{font-family:Poppins,sans-serif;font-size:1.75rem;font-weight:700;color:var(--text-primary);margin:0}.new-project-btn-large{display:flex;align-items:center;gap:.5rem;background:var(--gradient-primary);color:#fff;font-size:.95rem;font-weight:600;padding:.75rem 1.25rem;border:none;border-radius:12px;cursor:pointer;transition:all .2s}.new-project-btn-large:hover{filter:brightness(1.1);transform:translateY(-2px);box-shadow:var(--glow-primary)}.new-project-btn-large .material-icon{font-family:Material Icons;font-size:1.25rem;font-weight:400;font-style:normal;line-height:1}.dashboard-loading{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:4rem;color:var(--text-secondary);font-size:1rem}.dashboard-loading .spinner{width:20px;height:20px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.dashboard-error{text-align:center;padding:2rem;color:var(--accent-secondary)}.dashboard-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.dashboard-empty .empty-icon{font-size:4rem;color:var(--text-muted);margin-bottom:1rem}.dashboard-empty h2{font-family:Poppins,sans-serif;font-size:1.5rem;color:var(--text-primary);margin:0 0 .5rem}.dashboard-empty p{color:var(--text-secondary);margin:0 0 1.5rem}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.5rem;max-width:1200px;margin:0 auto}.project-card{position:relative;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;cursor:pointer;transition:all .2s}.project-card:hover{border-color:var(--accent-primary);transform:translateY(-4px);box-shadow:0 8px 24px var(--shadow-color)}.project-card-thumbnail{width:100%;aspect-ratio:4 / 3;background-color:var(--bg-tertiary);background-size:cover;background-position:center;display:flex;align-items:center;justify-content:center}.project-card-thumbnail .no-thumb-icon{font-size:3rem;color:var(--text-muted)}.project-card-info{padding:1rem}.project-card-name{font-family:Poppins,sans-serif;font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 .25rem;white-space:nowrap;text-overflow:ellipsis}.project-card-date{font-size:.8rem;color:var(--text-muted)}.project-card-delete{position:absolute;top:.5rem;right:.5rem;background:#0009;color:#fff;border:none;border-radius:8px;padding:.4rem;cursor:pointer;opacity:0;transition:all .2s}.project-card:hover .project-card-delete{opacity:1}.project-card-delete:hover{background:var(--accent-secondary)}.project-card-delete .material-icon{font-size:1.1rem;display:block}.project-card-delete-confirm{position:absolute;inset:0;background:#000000d9;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:1rem}.project-card-delete-confirm p{color:#fff;font-size:.95rem;margin:0}.project-card-delete-confirm .delete-confirm-btns{display:flex;gap:.5rem}.project-card-delete-confirm .delete-yes{background:var(--accent-secondary);color:#fff;border:none;padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-weight:500}.project-card-delete-confirm .delete-no{background:var(--bg-tertiary);color:var(--text-primary);border:none;padding:.5rem 1rem;border-radius:8px;cursor:pointer}@media(max-width:600px){.projects-dashboard{padding:1rem}.dashboard-header{flex-direction:column;gap:1rem;align-items:stretch}.dashboard-header h1{text-align:center}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem}}.segmentation-legend{position:absolute;top:1rem;right:1rem;background:var(--bg-secondary);border-radius:12px;padding:.75rem;box-shadow:0 4px 16px var(--shadow-color);border:1px solid var(--border-color);z-index:100;min-width:160px}.segmentation-loading{display:flex;align-items:center;justify-content:center;padding:1rem}.segmentation-error{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);font-size:.85rem;padding:.5rem}.segmentation-error .material-icon{color:var(--accent-secondary)}.spinner{width:24px;height:24px;border:3px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.segmentation-classes{display:flex;flex-direction:column;gap:.25rem}.segment-class-item{display:flex;align-items:center;gap:.5rem;padding:.4rem .6rem;background:transparent;border:1px solid transparent;border-radius:8px;cursor:pointer;transition:all .15s}.segment-class-item:hover,.segment-class-item.hovered{background:var(--bg-hover);border-color:var(--segment-color, var(--border-color))}.segment-class-item.checked{background:var(--bg-tertiary)}.segment-checkbox{width:14px;height:14px;accent-color:var(--accent-primary);cursor:pointer;flex-shrink:0}.segment-color-palette{display:flex;gap:2px;flex-shrink:0}.segment-palette-swatch{width:14px;height:14px;border-radius:3px;border:1px solid rgba(255,255,255,.2)}.segment-color-swatch{width:16px;height:16px;border-radius:4px;flex-shrink:0;border:1px solid rgba(255,255,255,.2)}.segment-class-name{font-size:.8rem;color:var(--text-primary);white-space:nowrap;flex:1}.segment-palette-btn{display:flex;align-items:center;justify-content:center;gap:.4rem;width:100%;margin-top:.5rem;padding:.5rem;background:var(--accent-primary);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.85rem;font-weight:500;transition:background .15s}.segment-palette-btn:hover{background:var(--accent-primary-hover)}.segment-palette-btn .material-icon{font-size:1.1rem}.mobile-bottom-bar{display:none;position:fixed;bottom:0;left:0;right:0;height:calc(64px + var(--mobile-safe-area-bottom));padding-bottom:var(--mobile-safe-area-bottom);background:var(--bg-secondary);border-top:1px solid var(--border-color);z-index:1000;align-items:flex-start;justify-content:space-around;padding-top:6px}.mobile-tab-btn{position:relative;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:2px;padding:4px 2px;background:transparent;border:none;color:var(--text-secondary);font-size:10px;cursor:pointer;transition:all .15s;min-height:52px;max-width:72px}.mobile-tab-btn:hover{color:var(--text-primary)}.mobile-tab-btn.active{color:var(--accent-primary)}.mobile-tab-btn.view-switch{color:var(--text-muted)}.mobile-tab-btn.view-switch:hover{color:var(--text-primary)}.mobile-tab-btn .material-icon{font-family:Material Icons;font-size:22px;font-weight:400;font-style:normal;line-height:1;letter-spacing:normal;text-transform:none;white-space:nowrap;word-wrap:normal;direction:ltr;-webkit-font-smoothing:antialiased}.mobile-tab-label{font-size:9px;font-weight:500;white-space:nowrap;text-overflow:ellipsis;max-width:100%}.mobile-tab-badge{position:absolute;top:2px;right:calc(50% - 18px);background:var(--accent-primary);color:#000;font-size:9px;font-weight:700;min-width:16px;height:16px;padding:0 4px;border-radius:8px;display:flex;align-items:center;justify-content:center}.mobile-tools-overlay{position:fixed;inset:0;background:#00000080;z-index:999;display:flex;align-items:flex-end;justify-content:center;padding-bottom:calc(var(--mobile-bottom-bar-height) + var(--mobile-safe-area-bottom))}.mobile-tools-menu{background:var(--bg-secondary);border-radius:16px 16px 0 0;width:100%;max-height:60vh;overflow-y:auto;animation:mobileSlideUp .2s ease-out}.mobile-tools-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px;border-bottom:1px solid var(--border-color);font-weight:600;font-size:16px;color:var(--text-primary)}.mobile-tools-close{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center}.mobile-tools-close .material-icon{font-family:Material Icons;font-size:20px;font-weight:400;font-style:normal;line-height:1}.mobile-tools-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:16px}.mobile-tool-btn{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:16px 8px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;color:var(--text-secondary);cursor:pointer;transition:all .15s;min-height:80px}.mobile-tool-btn:hover,.mobile-tool-btn:active{background:var(--bg-hover);color:var(--text-primary)}.mobile-tool-btn.active{background:var(--accent-primary);color:#000;border-color:var(--accent-primary)}.mobile-tool-btn .material-icon{font-family:Material Icons;font-size:24px;font-weight:400;font-style:normal;line-height:1;letter-spacing:normal;text-transform:none}.mobile-tool-label{font-size:11px;font-weight:500;text-align:center}.mobile-tool-badge{position:absolute;top:8px;right:8px;background:var(--accent-secondary);color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;padding:0 5px;border-radius:9px;display:flex;align-items:center;justify-content:center}.mobile-tool-btn.active .mobile-tool-badge{background:#000;color:var(--accent-primary)}.header-right-mobile{display:none;position:relative}.mobile-menu-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;border:none;color:var(--text-primary);cursor:pointer;border-radius:8px;transition:background .15s}.mobile-menu-btn:hover{background:var(--bg-hover)}.mobile-menu-btn .material-icon{font-family:Material Icons;font-size:24px;font-weight:400;font-style:normal;line-height:1}.mobile-menu-backdrop{position:fixed;inset:0;z-index:998}.mobile-menu-dropdown{position:absolute;top:100%;right:0;margin-top:8px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;min-width:200px;padding:8px;z-index:999;box-shadow:var(--modal-shadow);animation:fadeIn .15s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.mobile-menu-item{display:flex;align-items:center;gap:12px;width:100%;padding:12px;background:transparent;border:none;color:var(--text-primary);font-size:14px;cursor:pointer;border-radius:8px;transition:background .15s;text-align:left}.mobile-menu-item:hover{background:var(--bg-hover)}.mobile-menu-item:disabled{opacity:.6;cursor:not-allowed}.mobile-menu-item .material-icon{font-family:Material Icons;font-size:20px;font-weight:400;font-style:normal;line-height:1;color:var(--text-secondary)}.mobile-menu-item.saving .material-icon{animation:spin 1s linear infinite}.mobile-menu-divider{height:1px;background:var(--border-color);margin:8px 0}.mobile-menu-user-info{display:flex;align-items:center;gap:12px;padding:12px;color:var(--text-secondary)}.mobile-menu-user-info .material-icon{font-family:Material Icons;font-size:28px;font-weight:400;font-style:normal;line-height:1}.mobile-menu-user-details{display:flex;flex-direction:column;gap:2px}.mobile-menu-email{font-size:13px;color:var(--text-primary);max-width:150px;text-overflow:ellipsis;white-space:nowrap}.mobile-menu-credits{font-size:12px;color:var(--accent-primary)}.mobile-credits-hidden{position:absolute;top:0;left:0;width:0;height:0;overflow:visible}.mobile-credits-hidden .credits-btn{position:absolute;width:1px;height:1px;opacity:0}@media(max-width:768px){html,body,#root,.app,.app-main{max-width:100vw;overflow-x:hidden}.mobile-bottom-bar{display:flex}.icon-sidebar,.tools-sidebar,.primary-sidebar-spacer,.primary-sidebar,.secondary-sidebar{display:none!important}.canvas-section{width:100%!important;min-width:100%!important;max-width:100vw;height:calc(100vh - var(--mobile-header-height) - var(--mobile-bottom-bar-height) - var(--mobile-safe-area-bottom));padding-bottom:calc(70px + var(--mobile-safe-area-bottom));overflow-x:hidden}.app-header{height:var(--mobile-header-height);padding:0 10px;gap:8px;overflow:visible}.header-left{flex-shrink:0}.app-logo{font-size:.95rem}.header-center{flex:1;min-width:0;max-width:none;justify-content:flex-start}.project-name-btn{font-size:13px;text-overflow:ellipsis;white-space:nowrap;max-width:100%;padding:.3rem .5rem}.header-right-desktop{display:none!important}.header-right-mobile{display:flex!important;z-index:1100}.mobile-menu-dropdown{z-index:1200!important}.mobile-menu-backdrop{z-index:1100!important}.editor-toolbar{display:none!important}.pending-point-confirm{position:fixed;bottom:90px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:12px;background:#2a2a2a;border-radius:28px;padding:8px 16px;box-shadow:0 4px 12px #0006;z-index:1000}.pending-point-confirm button{width:40px;height:40px;border:none!important;outline:none!important;background:none!important;box-shadow:none!important;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;-webkit-tap-highlight-color:transparent;-webkit-appearance:none;appearance:none}.pending-point-confirm .material-icon{font-size:22px}.pending-color-confirm{position:fixed;bottom:90px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:12px;background:#2a2a2a;border-radius:28px;padding:8px 16px;box-shadow:0 4px 12px #0006;z-index:1000}.pending-color-swatch{width:36px;height:36px;border-radius:8px;border:2px solid rgba(255,255,255,.3);box-shadow:inset 0 0 0 1px #0003}.pending-color-hex{font-size:14px;font-weight:600;color:#fff;font-family:monospace;min-width:70px}.pending-color-confirm button{width:40px;height:40px;border:none!important;outline:none!important;background:none!important;box-shadow:none!important;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;-webkit-tap-highlight-color:transparent;-webkit-appearance:none;appearance:none}.pending-color-confirm .material-icon{font-size:22px}.sidebar-panel{position:fixed!important;top:var(--mobile-header-height)!important;left:0!important;right:0!important;bottom:calc(var(--mobile-bottom-bar-height) + var(--mobile-safe-area-bottom))!important;width:100%!important;max-width:100%!important;border-radius:0!important;animation:mobileSlideUp .25s ease-out}.sidebar-panel.left{left:0!important;right:0!important}.panel-overlay{top:var(--mobile-header-height)!important;left:0!important;right:0!important;bottom:calc(var(--mobile-bottom-bar-height) + var(--mobile-safe-area-bottom))!important}.panel-overlay.left{left:0!important;right:0!important}}@keyframes mobileSlideUp{0%{transform:translateY(20%);opacity:0}to{transform:translateY(0);opacity:1}}.color-preview-mobile-sheet{position:fixed;bottom:calc(var(--mobile-bottom-bar-height) + var(--mobile-safe-area-bottom));left:0;right:0;background:var(--bg-secondary);border-top:1px solid var(--border-color);border-radius:16px 16px 0 0;padding:12px 16px 16px;z-index:1100;animation:mobileSlideUp .2s ease-out}.mobile-sheet-handle{width:32px;height:4px;background:var(--border-color);border-radius:2px;margin:0 auto 12px}.color-preview-mobile-sheet .mobile-swatch{height:80px;border-radius:12px;margin-bottom:12px;display:flex;align-items:center;justify-content:center}.color-preview-mobile-sheet .mobile-info{display:flex;gap:12px;margin-bottom:12px}.mobile-color-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all .15s;min-height:56px}.mobile-color-btn:hover,.mobile-color-btn:active{background:var(--bg-hover);border-color:var(--accent-primary)}.mobile-color-btn .color-value{font-size:13px;font-weight:600;color:var(--text-primary);font-family:monospace}.mobile-color-btn .save-label{font-size:11px;color:var(--text-secondary)}.mobile-dismiss-btn{width:100%;padding:14px;background:transparent;border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);font-size:14px;cursor:pointer;transition:all .15s;min-height:48px}.mobile-dismiss-btn:hover,.mobile-dismiss-btn:active{background:var(--bg-tertiary);color:var(--text-primary)}@media(max-width:375px){.header-center{max-width:30%}.project-name-btn{font-size:12px}.mobile-tab-btn{padding:6px 2px}.mobile-tab-btn .material-icon{font-size:22px}.mobile-tab-label{font-size:9px}}.touch-mode-toggle{position:fixed;bottom:calc(var(--mobile-bottom-bar-height) + var(--mobile-safe-area-bottom) + 80px);right:16px;display:flex;flex-direction:column;gap:8px;z-index:100}.touch-mode-btn{width:48px;height:48px;border-radius:50%;border:none;background:var(--bg-secondary);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 8px var(--shadow-color);transition:all .15s ease}.touch-mode-btn .material-icon{font-family:Material Icons;font-weight:400;font-style:normal;font-size:24px;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;word-wrap:normal;direction:ltr;-webkit-font-feature-settings:"liga";-webkit-font-smoothing:antialiased}.touch-mode-btn.active{background:var(--accent-primary);color:#fff;box-shadow:var(--glow-primary)}.touch-mode-btn:active{transform:scale(.95)}@media(max-width:768px){.app-main{width:100%!important;height:calc(100vh - var(--mobile-bottom-bar-height) - var(--mobile-header-height))!important;margin:0!important;padding:0!important}.canvas-section{width:100%!important;height:100%!important;padding:0!important}.app{padding-bottom:var(--mobile-bottom-bar-height)}}
