.spraytest-container{font-family:system-ui,sans-serif;overflow:hidden;overscroll-behavior:none;background:var(--surface-page);color:var(--text-primary);height:100vh;width:100vw}canvas{display:block;cursor:crosshair;touch-action:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;border-radius:var(--radius-xl)}.zoom-space-maker{position:relative;margin:auto}.canvas-wrapper{position:relative;display:inline-block;flex-shrink:0;overflow:hidden;border:0 solid var(--surface-overlay-light);background-color:var(--surface-page);border-radius:var(--radius-xl);transform-origin:top left}.canvas-grid-overlay{position:absolute;top:0;left:0;width:calc(100% - 1px);height:calc(100% - 1px);pointer-events:none;z-index:10;opacity:0;transition:opacity .3s ease;background-image:linear-gradient(to right,transparent 799px,var(--border-subtle) 799px),linear-gradient(to bottom,transparent 799px,var(--border-subtle) 799px),linear-gradient(to right,transparent 399px,var(--border-muted) 399px),linear-gradient(to bottom,transparent 399px,var(--border-muted) 399px);background-size:800px 800px,800px 800px,400px 400px,400px 400px;background-position:0 0,0 0,0 0,0 0}@media (max-width:700px){#burger{display:block}#controls-panel{right:-100%;opacity:0;visibility:hidden;transition:all .3s ease}#controls-panel.open{right:0;opacity:1;visibility:visible}#canvas-container{width:100vw;height:100vh;overflow:auto;overscroll-behavior:none;display:flex;background:var(--surface-control)}}@media (min-width:701px){#burger{display:none!important}#controls-panel{right:0!important;opacity:1!important;visibility:visible!important}#canvas-container{position:absolute;top:var(--space-4);left:var(--space-4);right:416px;bottom:56px;width:auto;height:auto;border-radius:var(--radius-xl);overflow:auto;overscroll-behavior:none;display:flex;background:var(--surface-panel);border:1px solid var(--surface-panel)}}#customCursor{position:fixed;width:16px;height:16px;border-radius:var(--radius-full);background:var(--color-brand);pointer-events:none;transform:translate(-50%,-50%);z-index:var(--z-cursor);display:none;box-shadow:0 0 6px var(--color-brand)}.controls-wrapper{position:fixed;top:var(--space-4);right:var(--space-4);width:384px;z-index:var(--z-controls);display:flex;flex-direction:column;gap:var(--space-4)}#controls-canvas,#controls-panel{width:100%;height:226px;background:var(--surface-panel);padding:var(--space-4) var(--space-4);color:var(--text-primary);overflow-y:auto;transition:all var(--transition-smooth);border-radius:var(--radius-xl);border:none;box-sizing:border-box}#controls-canvas{display:flex;flex-direction:column;gap:var(--space-3)}#resetBtn{width:100%;padding:var(--space-3) var(--space-4);background:var(--surface-control);color:var(--text-primary);border:none;border-radius:var(--radius-xl);cursor:pointer;font-size:var(--text-md);transition:all var(--transition-base);margin-top:0;margin-left:0}#resetBtn:hover{background:var(--surface-control-hover)}.panel-with-toggle{display:flex;flex-direction:column;align-items:center;width:100%}.panel-toggle-stick{opacity:0!important;pointer-events:none;transition:opacity .3s ease 1s!important}.panel-toggle-stick:after,.panel-toggle-stick:before{background-color:var(--text-muted)!important}.panel-toggle-stick:hover:after,.panel-toggle-stick:hover:before{background-color:var(--color-brand,#f36)!important}.panel-with-toggle:hover .panel-toggle-stick{opacity:1!important;pointer-events:auto;transition:opacity .15s ease 0s!important}@media (max-width:700px){.panel-toggle-stick{opacity:.25!important;pointer-events:auto!important}}.minimap-wrapper{width:100%;display:flex;flex-direction:column;box-sizing:border-box;margin-bottom:var(--space-2)}.minimap-label{font-size:16px;color:var(--text-secondary);font-weight:500;text-align:center}.minimap-canvas{background:var(--surface-control);border:1px solid var(--surface-panel);border-radius:var(--radius-md);cursor:crosshair;width:100%;height:auto;display:block}.spraytest-container label{margin:0;color:var(--text-secondary);font-size:16px;font-weight:500}.controls-panel-inner{margin-bottom:0}.controls-canvas-inner,.controls-panel-inner{display:flex;flex-direction:column;gap:var(--space-5)}.control-group{display:flex;flex-direction:column;gap:var(--space-4);margin:0!important}.control-group:has(.horizontal){gap:0}.spraytest-container input[type=range]{width:100%;height:6px!important;background:var(--surface-control-active);border-radius:var(--radius-full);outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;margin:0!important}.spraytest-container input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;background:var(--color-brand);border-radius:50%;cursor:pointer;border:none;box-shadow:0 2px 6px var(--surface-overlay-dark);-webkit-transition:transform var(--transition-fast);transition:transform var(--transition-fast)}.spraytest-container input[type=range]::-moz-range-thumb{-moz-appearance:none;appearance:none;width:18px;height:18px;background:var(--color-brand);border-radius:50%;cursor:pointer;border:none;box-shadow:0 2px 6px var(--surface-overlay-dark);-moz-transition:transform var(--transition-fast);transition:transform var(--transition-fast)}input[type=color]{width:50px;height:50px;border:none;border-radius:var(--radius-sm);cursor:pointer;background:transparent}input[type=color]::-webkit-color-swatch-wrapper{padding:0}input[type=color]::-webkit-color-swatch{border:none;border-radius:var(--radius-sm)}input[type=file]{width:100%;box-sizing:border-box;padding:var(--space-2);margin-top:var(--space-3);background:var(--border-muted);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:14px}.color-picker-modal button,.spraytest-container button{cursor:pointer;font-family:inherit}.reset-preset-btn{background:var(--surface-control)!important;border:none!important;color:var(--text-primary)!important;padding:var(--space-3) var(--space-4)!important;border-radius:var(--radius-xl)!important;font-size:var(--text-md)!important;width:100%!important;margin-bottom:0!important;transition:all var(--transition-base)!important;margin-left:0}.reset-preset-btn:hover{background:var(--surface-control-hover)!important;opacity:.8!important}.reset-preset-btn:active{opacity:.9!important}#version,.feedback-link{font-size:.7rem;color:var(--text-muted);pointer-events:auto;padding:var(--space-1) 0;border-radius:var(--radius-xs);cursor:pointer;transition:color .2s ease;text-decoration:none}#version:hover,.feedback-link:hover{color:var(--color-brand)}.preview-mode-bar{display:flex;align-items:center;gap:var(--space-2);width:90%;box-sizing:border-box;margin-top:var(--space-4);margin-bottom:var(--space-4);margin-left:var(--space-4);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);animation:previewBarSlideIn .28s cubic-bezier(var(--transition-spring));overflow:hidden}@keyframes previewBarSlideIn{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}.preview-mode-color-swatch{width:34px;height:34px;border-radius:50%;flex-shrink:0;box-shadow:0 2px 8px var(--surface-overlay-dark)}.preview-mode-label{font-size:13px;color:var(--text-primary);font-weight:500;flex:1 1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.preview-confirm-btn{background:var(--color-success-alpha-20);border:0 solid var(--color-success-alpha-40);color:var(--color-success);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);font-size:13px;font-weight:700;cursor:pointer;white-space:nowrap;transition:all .2s ease}.preview-confirm-btn:hover{background:var(--color-success-alpha-40);border-color:var(--color-success);color:var(--text-primary)}.preview-cancel-btn{background:transparent;border:1px solid var(--border-subtle);color:var(--text-muted);border-radius:var(--radius-sm);width:32px;height:32px;font-size:var(--text-md);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);flex-shrink:0}.preview-cancel-btn:hover{background:var(--color-brand-alpha-10);border-color:var(--color-brand-alpha-50);color:var(--color-brand)}@media (min-width:769px){.mobile-preview-bar-container{display:none}}@media (max-width:768px){.mobile-preview-bar-container{position:fixed;bottom:85px;left:5%;width:90%;z-index:1000}.preview-mode-bar{width:100%;margin:0;padding:var(--space-2) var(--space-3);border-radius:var(--radius-lg);box-shadow:0 8px 32px var(--surface-overlay-darker);background:var(--surface-overlay);border:1px solid var(--border-subtle)}}.view-counter{font-size:.7rem;color:var(--text-muted);padding:var(--space-1) 0;cursor:default;display:flex;align-items:center;gap:var(--space-1)}.view-icon{font-size:1.1rem;line-height:1;position:relative;top:-1px}.changelog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:transparent;z-index:3000}.changelog-modal{position:fixed;left:var(--space-4);bottom:var(--space-7);width:280px;max-height:480px;background:var(--surface-panel);border:1px solid var(--border-dark);border-radius:var(--radius-lg);z-index:var(--z-modal);display:flex;flex-direction:column;box-shadow:0 10px 30px var(--surface-overlay-darker);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur)}@media (max-width:700px){.changelog-modal{left:auto;bottom:auto;right:var(--space-4);top:60px}}.changelog-content{padding:var(--space-4);overflow-y:auto;font-size:14px;line-height:1.5;color:var(--text-primary)}.changelog-entry{margin-bottom:var(--space-5)}.changelog-entry:last-child{margin-bottom:0}.changelog-entry-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-2);color:var(--color-brand);font-weight:700}.changelog-entry-date{font-size:12px;color:var(--text-secondary);font-weight:400}.lang-modal,.mobile-dropdown-modal{position:fixed;background:var(--surface-panel);border:1px solid var(--border-dark);border-radius:var(--radius-md);z-index:var(--z-modal);display:flex;flex-direction:column;-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);padding:var(--space-2)}@media (min-width:701px){.lang-modal{left:170px;bottom:var(--space-7);width:150px}}.dropdown-option{padding:var(--space-2) var(--space-4);background:transparent;color:var(--text-primary);border:none;text-align:left;font-size:14px;cursor:pointer;transition:background .2s,color .2s;text-transform:capitalize;margin-top:var(--space-1);margin-bottom:var(--space-1);text-decoration:none;display:block}.dropdown-option:hover{background:var(--surface-control-hover);color:var(--color-brand)}.mobile-dropdown-modal{right:var(--space-4);top:60px;left:auto!important;bottom:auto!important;width:auto;min-width:180px}@media (max-width:700px){.lang-modal{right:var(--space-4)!important;top:60px!important;left:auto!important;bottom:auto!important;width:auto!important;min-width:180px!important}}.lang-option{display:flex;justify-content:space-between;align-items:center;padding:var(--space-2) var(--space-4);background:transparent;color:var(--text-primary);border:none;text-align:left;font-size:14px;cursor:pointer;transition:background .2s,color .2s;text-transform:capitalize;margin-top:var(--space-1);margin-bottom:var(--space-1)}.hotkey-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;background:var(--surface-control);color:var(--text-muted);border-radius:var(--radius-xs);font-size:10px;font-family:monospace;opacity:0;transition:opacity .2s;pointer-events:none}.lang-option:hover .hotkey-badge{opacity:1}.lang-option:hover{background:var(--border-muted);color:var(--color-brand)}.lang-option.active{color:var(--color-brand);font-weight:700}.changelog-entry ul{margin:0;padding-left:var(--space-4);color:var(--text-secondary)}.changelog-entry li{margin-bottom:var(--space-1)}.can-indicator{padding-top:var(--space-2);background:var(--surface-control);margin-bottom:var(--space-6);margin-top:var(--space-4);border-radius:var(--radius-lg);position:relative;padding-bottom:var(--space-2)}.cans-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:0;gap:0;margin-bottom:0;align-items:center}.can-grid-cell{display:flex;justify-content:center;align-items:center;padding:var(--space-2);width:100%;height:100%}.preview-indicator-override{border:none!important;box-shadow:none!important;transform:none!important}.preview-indicator-override:hover{transform:none!important;opacity:.8!important}.can-item{position:relative;cursor:pointer;transition:all .2s ease;opacity:.7;height:70px;align-content:center}.can-item:hover{transform:scale(1.15);opacity:1}.can-item.active{transform:scale(1.16);opacity:1}.can-item.empty{opacity:.7}.can-item.empty:hover{opacity:1}.can-item.roller{width:48px;height:28px;padding:0;border-radius:var(--radius-xs);inline-size:auto;margin:var(--space-2) var(--space-4) var(--space-3);align-content:center;align-items:center}.can-item.roller .can-visual{width:100%;height:100%;border-radius:var(--radius-xs);position:relative;overflow:hidden;background:var(--surface-control-active)}.can-item.roller .can-fill{border-radius:var(--radius-xs);position:absolute;bottom:0;left:0;right:0;width:100%;transition:height .3s ease}.can-item.roller.empty .can-visual{background:var(--surface-control-active)}.can-item.roller .can-plus{display:none}.can-visual{width:48px;height:48px;margin:0 auto;background:var(--surface-control-active);border-radius:50%;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}.can-fill{position:absolute;bottom:0;width:100%;border-radius:50%;transform-origin:bottom center}.can-item:not(.roller) .can-fill{background:linear-gradient(to top,var(--current-color,var(--color-brand)),var(--current-color-light,var(--color-brand-light)))}.can-plus{font-size:16px;color:var(--text-secondary);font-weight:700}.can-percentage{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:11px;font-weight:700;color:var(--text-primary);text-shadow:0 1px 2px var(--surface-overlay);opacity:0;transition:opacity .2s ease;pointer-events:none;z-index:2}.can-item.roller:hover .roller-percentage{opacity:1}.can-label{font-size:10px;text-align:center;margin-top:var(--space-1);color:var(--text-secondary)}.color-picker-overlay{width:100%;height:100%;z-index:5000}.color-picker-container{background:var(--surface-control-active);padding:var(--space-5);border-radius:var(--radius-md);text-align:center;max-width:90%;width:250px;border:1px solid var(--border-dark)}.color-picker-buttons,.presets-container{display:flex;gap:var(--space-2)}.presets-container{z-index:1000;padding:0;margin-bottom:0}.preset-button{flex:1 1;padding:var(--space-2) 0;background:var(--surface-control);color:var(--text-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);font-size:var(--text-base);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-fast);letter-spacing:.5px;text-align:center;margin:0;white-space:nowrap}.preset-button.active{background:var(--surface-control-active);color:var(--text-primary);border-color:var(--surface-overlay-medium)}.preset-button:hover{background:var(--surface-control-hover)}.preset-button.flat-active{border-color:var(--color-brand-alpha-50)}.flat-suffix{color:inherit;font-size:16px;font-weight:500;margin-left:var(--space-1);letter-spacing:0}.flat-mode-control{margin-top:0}.flat-mode-label{display:flex;align-items:center;justify-content:space-between;width:100%;cursor:default;-webkit-user-select:none;-moz-user-select:none;user-select:none;gap:var(--space-2)}.flat-mode-label>span{font-size:16px;font-weight:500;color:var(--text-secondary);flex:1 1}.flat-mode-label .switch{flex-shrink:0}.drip-indicator{display:inline-block;margin-left:var(--space-1);font-size:10px;color:var(--color-warn);animation:drip-pulse 1s infinite}@keyframes drip-pulse{0%{opacity:.5}50%{opacity:1}to{opacity:.5}}.preset-info{font-size:14px;color:var(--text-secondary);margin-bottom:var(--space-4);line-height:1.3;font-style:none;text-align:center}.dynamic-info{font-size:10px;color:var(--text-muted);margin-bottom:var(--space-2);margin-top:var(--space-1);line-height:1.2;text-align:center}.can-item:hover .can-percentage{opacity:1}.can-item.empty:hover .can-percentage{opacity:0}@keyframes paintDecrease{0%{transform:scaleY(1);opacity:1}50%{transform:scaleY(.95);opacity:.8}to{transform:scaleY(1);opacity:1}}.paint-decrease-animation{animation:paintDecrease .4s cubic-bezier(.4,0,.2,1)}.add-can-button{grid-column:span 3;padding:var(--space-3);background:var(--surface-control-active);border:1px var(--surface-control-active);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);text-align:center;color:var(--border-muted);font-size:var(--text-base);margin:var(--space-4)}.add-can-button:hover{background:var(--surface-control)}.add-can-item{cursor:pointer;opacity:.6}.add-can-item:hover{opacity:1;transition:all .2s ease}.add-can-item .can-visual{background:var(--surface-control-active);font-size:14px}.add-can-item .can-plus{font-size:larger;color:var(--text-secondary);font-weight:700;align-content:center;transition:all .2s ease}.paint-empty-toast{position:fixed;bottom:var(--space-5);left:50%;transform:translateX(-50%) translateY(100px);z-index:10000;min-width:300px;max-width:90%;background:var(--surface-panel);color:var(--text-primary);padding:var(--space-4) var(--space-5);border-radius:var(--radius-lg);font-family:inherit;font-size:var(--text-md);font-weight:var(--font-weight-medium);line-height:var(--lh-base);opacity:0;visibility:hidden;transition:all var(--transition-smooth);border:1px solid var(--border-subtle);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);overflow:hidden}.paint-empty-toast:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;animation:shimmer 2s infinite}.paint-empty-toast.show{transform:translateX(-50%) translateY(0);opacity:1;visibility:visible}.toast-content{display:flex;align-items:center;gap:var(--space-3)}.toast-icon{font-size:20px;filter:drop-shadow(var(--shadow-sm))}.toast-text{flex:1 1;text-align:left}@media (max-width:768px){.paint-empty-toast{min-width:280px;padding:var(--space-3) var(--space-5);font-size:15px;bottom:var(--space-4)}.toast-content{gap:var(--space-2)}.toast-icon{font-size:18px}}@media (max-width:480px){.paint-empty-toast{min-width:260px;padding:var(--space-3) var(--space-4);font-size:14px;border-radius:var(--radius-md);bottom:var(--space-3)}.toast-icon{font-size:16px}}.mobile-sheet{position:fixed;left:var(--space-4);right:var(--space-4);margin:0 auto;width:auto;max-width:440px;bottom:82px;max-height:48vh;background:var(--surface-panel);border-radius:var(--radius-2xl);z-index:var(--z-modal);animation:slideUp .3s cubic-bezier(.34,1.56,.64,1);display:flex;flex-direction:column;overflow:hidden;box-shadow:0 -4px 32px var(--surface-overlay-darker);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--border-subtle)}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.sheet-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) var(--space-4) var(--space-2)}.sheet-header h3{margin:0;font-size:var(--text-lg);font-weight:var(--font-weight-bold);color:var(--text-primary)}.sheet-close{background:transparent;border:none;color:var(--text-secondary);font-size:20px;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.sheet-close:active{color:var(--text-primary);transform:scale(.9)}.mobile-sheet .sheet-content{padding:0 var(--space-4) var(--space-2);overflow-y:hidden;flex:1 1;display:flex;flex-direction:column}.mobile-sheet .can-grid-cell{height:72px;padding:var(--space-2)}.mobile-sheet .cans-grid{grid-template-columns:repeat(4,1fr)!important;max-width:100%;margin-bottom:0!important}.mobile-sheet .cans-grid.sprays-group{gap:0!important}.can-swiper-container{position:relative;width:100%;overflow:hidden;touch-action:pan-y;cursor:-webkit-grab;cursor:grab}.can-swiper-container:active{cursor:-webkit-grabbing;cursor:grabbing}.can-swiper-viewport{width:100%;display:flex;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:auto;scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain}.can-swiper-viewport::-webkit-scrollbar{display:none}.can-swiper-dots{display:flex;justify-content:center;align-items:center;gap:var(--space-2);height:10px;padding-bottom:10px;z-index:10;box-sizing:border-box}.can-swiper-dot{background:var(--border-muted);opacity:.5}.can-swiper-dot.active{background:var(--text-secondary)}.can-indicator .can-swiper-container{margin-top:var(--space-2)}.mobile-sheet .can-item{margin:0}.mobile-sheet .can-item.roller{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:60px!important;height:36px!important;margin:0!important}.can-indicator{flex-shrink:0}.can-swiper-slide{flex:0 0 100%;width:100%;scroll-snap-align:start;box-sizing:border-box;padding:0 var(--space-1);display:flex;flex-direction:column}.can-swiper-dot{width:8px;height:8px;border-radius:50%;background:var(--text-muted);transition:all .2s ease;opacity:.6}.can-swiper-dot.active{background:var(--color-gray-600);opacity:1}.mobile-sheet .can-item.roller .can-visual{width:100%;height:100%}.mobile-sheet .can-item.roller .can-plus{display:flex;align-items:center;justify-content:center;font-size:16px}.settings-group{margin-bottom:var(--space-5)}.settings-group-horizontal label{flex-direction:row!important;justify-content:flex-start;align-items:center;gap:var(--space-3)}.settings-group label{display:flex;flex-direction:column;gap:var(--space-2);color:var(--text-primary);font-size:14px}.settings-group input[type=range]{width:100%;height:6px;background:var(--surface-control-active);border-radius:var(--radius-full);outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.settings-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;background:var(--color-brand);border-radius:50%;cursor:pointer;border:none}.settings-group input[type=range]::-moz-range-thumb{width:20px;height:20px;background:var(--color-brand);border-radius:50%;cursor:pointer;border:none}.reset-settings-wrapper{box-sizing:border-box;width:100%;overflow:hidden;margin-bottom:var(--space-3)}.reset-settings-btn{display:block;width:100%;max-width:100%;box-sizing:border-box;padding:var(--space-3) var(--space-4);background:var(--surface-control);color:var(--text-primary);border:none;border-radius:var(--radius-full);font-size:var(--text-md);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-base);margin-top:0}.reset-settings-btn:active{background:var(--surface-control-hover);transform:scale(.98)}.settings-modal{max-height:50vh}.preset-buttons-row{margin-bottom:var(--space-4)}.mobile-toolbar{display:none}@media (max-width:768px){*{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-touch-callout:none;touch-action:manipulation}input,textarea{-webkit-user-select:text;-moz-user-select:text;user-select:text;touch-action:auto}.controls-wrapper,.footer-links,.mobile-toolbar{display:none!important}.mobile-toolbar *{pointer-events:none}.toolbar-tab{flex:1 1;display:flex;align-items:center;justify-content:center;height:50px;background:transparent;border:none;cursor:pointer;transition:all .2s ease;border-radius:var(--radius-md);margin:0 var(--space-1);pointer-events:auto!important;z-index:10}.toolbar-tab *{pointer-events:none!important}.toolbar-tab:active{background:var(--border-subtle);transform:scale(.95)}.toolbar-minimap-wrapper{display:flex;justify-content:center;align-items:center;width:100px;max-height:50px}.toolbar-minimap-wrapper .minimap-canvas{width:100%;height:36px;border:1px solid var(--surface-overlay-light);border-radius:var(--radius-sm);display:block;background:var(--surface-control)}.preset-indicator{display:flex;align-items:center;justify-content:center;width:60px;height:48px;background:transparent;border-radius:var(--radius-md);border:1px solid var(--border-subtle)}.preset-label{font-size:8px;font-weight:700;color:var(--text-primary);text-transform:uppercase}.color-circle{width:36px;height:36px;border-radius:50%;border:1px solid var(--border-dark);box-shadow:0 2px 8px var(--surface-overlay-dark);position:relative;overflow:hidden;background:var(--surface-control-active)}.color-circle .can-fill{position:absolute;bottom:0;left:0;width:100%;border-radius:0;background:linear-gradient(to top,var(--current-color,var(--color-brand)),var(--current-color-light,var(--color-brand-light)));transition:height .3s ease}.roller-rectangle{width:50px;height:36px;border-radius:var(--radius-sm);border:1px solid var(--border-dark);background:var(--surface-control-active);position:relative;overflow:hidden}.roller-rectangle .roller-fill{position:absolute;bottom:0;left:0;width:100%;border-radius:0;transition:height .3s ease}.reset-icon,.settings-icon{font-size:24px}.footer-links{display:none!important}.sheet-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:transparent;z-index:2500;pointer-events:auto}#canvas-container{overflow:auto!important;-webkit-overflow-scrolling:touch;width:100vw!important;height:calc(100vh - 70px)!important;display:flex}#canvas-container::-webkit-scrollbar{width:12px;height:12px}#canvas-container::-webkit-scrollbar-track{background:var(--border-subtle);border-radius:var(--radius-sm)}#canvas-container::-webkit-scrollbar-thumb{background:var(--surface-overlay-light);border-radius:var(--radius-sm)}#canvas-container::-webkit-scrollbar-thumb:hover{background:var(--surface-overlay-medium)}#canvas-container{scrollbar-width:auto;scrollbar-color:hsla(0,0%,100%,.3) hsla(0,0%,100%,.1)}}.switch-container{display:flex;justify-content:space-between;align-items:center}.switch-label{color:var(--text-secondary);font-size:16px;font-weight:500;margin:0}.switch{position:relative;display:inline-block;width:44px;height:24px;margin:0}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--surface-control);transition:var(--transition-base);border-radius:var(--radius-full)}.slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:var(--text-primary);transition:.3s;border-radius:50%}input:checked+.slider{background-color:var(--color-brand)}input:checked+.slider:before{transform:translateX(20px)}.zoom-value-active{cursor:pointer;transition:color var(--transition-fast);color:var(--text-primary)}.zoom-value-active:hover{color:var(--color-brand)}.color-picker-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--surface-overlay);z-index:2000;align-items:center;justify-content:center;padding:var(--space-4)}.color-picker-modal,.color-picker-overlay{-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);display:flex}.color-picker-modal{background:var(--surface-panel);padding:0 var(--space-6) 0 var(--space-6);border-radius:var(--radius-xl);width:100%;max-width:760px;flex-direction:column;box-shadow:0 12px 48px var(--surface-overlay-darker);border:1px solid var(--border-subtle);position:relative!important;height:70vh;min-height:560px;max-height:800px}.color-picker-header{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;margin-bottom:var(--space-5);margin-top:var(--space-5);width:100%;position:relative}.color-picker-header h4{grid-column:1;justify-self:start;margin:0;color:var(--text-primary);font-size:20px;font-weight:600;display:flex;align-items:center;gap:var(--space-2);white-space:nowrap}.color-picker-close{grid-column:3;justify-self:end;background:transparent;border:none;color:var(--text-secondary);font-size:24px;cursor:pointer;padding:var(--space-2);margin:0!important;border-radius:50%;line-height:1;transition:color .2s ease;z-index:10!important}.color-picker-close:hover{color:var(--color-brand);background:transparent}.color-picker-tabs{grid-column:2;justify-self:center;display:flex;gap:var(--space-3);position:relative}@media (max-width:600px){.color-picker-header{grid-template-columns:1fr auto;row-gap:16px}.color-picker-header h4{grid-column:1;grid-row:1}.color-picker-close{grid-column:2;grid-row:1}.color-picker-tabs{grid-column:1/-1;grid-row:2;width:100%;justify-content:center}.color-tab{flex:1 1;width:auto}}.color-tab{background:transparent;color:var(--text-secondary);border:1px solid var(--border-subtle);padding:var(--space-2) var(--space-5);border-radius:var(--radius-md);cursor:pointer;font-weight:600;font-size:15px;height:44px;width:170px;transition:all .2s ease;margin-top:0;margin-bottom:0}.color-tab:hover{color:var(--text-primary);background:var(--border-muted)}.color-tab.active{background:var(--surface-control-active);color:var(--text-primary);border-color:var(--border-muted);box-shadow:0 2px 8px var(--surface-overlay-dark)}.color-picker-content{flex:1 1;overflow-y:auto;padding-right:var(--space-2);padding-top:var(--space-4)}.color-picker-content::-webkit-scrollbar{width:8px}.color-picker-content::-webkit-scrollbar-track{background:var(--border-muted);border-radius:var(--radius-xs)}.color-picker-content::-webkit-scrollbar-thumb{background:var(--surface-overlay-light);border-radius:var(--radius-xs)}.color-picker-content::-webkit-scrollbar-thumb:hover{background:var(--surface-overlay-medium)}.montana-gallery{display:grid;grid-template-columns:repeat(7,1fr);grid-gap:var(--space-2);gap:var(--space-2);padding-bottom:var(--space-5);padding-top:var(--space-2)}.color-tile{background:var(--surface-panel);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;display:flex;flex-direction:column;height:120px;box-shadow:0 4px 12px var(--surface-overlay-dark);transition:transform .2s cubic-bezier(var(--transition-spring)),box-shadow .2s}.color-tile:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 8px 24px var(--surface-overlay-dark)}.color-tile.selected{border-color:var(--color-brand);transform:scale(1.02);box-shadow:0 0 0 4px var(--color-brand)}.color-tile-swatch{height:65px;width:100%;flex-shrink:0}.color-tile-info{flex:1 1;padding:var(--space-2) var(--space-2);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:var(--space-1)}.color-code{color:var(--text-muted);font-size:10px;font-weight:600;line-height:1}.color-name{color:var(--text-primary);font-size:11px;font-weight:700;line-height:1.1;letter-spacing:-.2px;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.market-tab-container{display:flex;flex-direction:column;width:100%}.market-section-title{color:var(--text-primary);font-size:16px;font-weight:700;margin:var(--space-4) 0 var(--space-2) var(--space-2);letter-spacing:.5px}.custom-colors-list{display:flex;flex-direction:column;gap:var(--space-3);max-width:600px;margin:0 auto;width:100%;box-sizing:border-box}.custom-rows-header{padding:0 var(--space-1);color:var(--text-secondary);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-1)}.custom-color-row,.custom-rows-header{display:grid;grid-template-columns:48px 100px 1fr 44px;grid-gap:var(--space-3);gap:var(--space-3)}.custom-color-row{align-items:center;position:relative}.custom-row-indicator{width:48px;height:48px;border-radius:50%;cursor:pointer;border:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:center;transition:transform .2s,box-shadow .2s;background-color:var(--surface-control-active)}.custom-row-indicator:hover{transform:scale(1.1);background-color:var(--border-muted);border:1px solid var(--border-muted)}.custom-row-empty-dot{width:12px;height:12px;border-radius:50%;background:transparent}.hidden-row-color-input{position:absolute;opacity:0;pointer-events:none;width:1px;height:1px}.custom-row-input{background:var(--surface-control-active);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;padding:0 var(--space-4);height:44px;outline:none;transition:border-color .2s;font-family:inherit}@media (max-width:460px){.custom-color-row,.custom-rows-header{grid-template-columns:48px 1fr 44px!important}.custom-row-input.name-input,.custom-rows-header span:nth-child(3){display:none}}@media (max-width:360px){.custom-colors-list{padding:var(--space-4) 0}}.custom-row-input:focus{border-color:var(--color-brand);background:var(--border-dark)}.custom-row-input.hex-input{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-weight:600;text-transform:uppercase;letter-spacing:1px}.custom-row-clear-btn{width:44px;height:44px;border-radius:var(--radius-md);background:transparent;color:var(--text-muted);border:1px solid transparent;display:flex;align-items:center;justify-content:center;font-size:16px;cursor:default;transition:all .2s}.custom-row-clear-btn.active{cursor:pointer;background:var(--border-muted);border-color:var(--border-subtle);color:var(--text-primary)}.custom-row-clear-btn.active:hover{background:var(--color-brand-alpha-10);color:var(--color-brand);border-color:var(--color-brand-alpha-30)}.add-more-custom-rows-btn{width:100%;background:var(--surface-control-active);color:var(--text-secondary);font-size:16px;font-weight:600;transition:all .2s;margin-top:var(--space-2)}.add-more-custom-rows-btn,.add-more-custom-rows-btn:hover{padding:var(--space-3);height:auto;border-radius:var(--radius-md);border:1px solid var(--border-subtle);cursor:pointer}.add-more-custom-rows-btn:hover{font-size:var(--text-base);font-weight:var(--font-weight-semibold);background:var(--surface-control-hover);color:var(--text-primary);transition:background var(--transition-fast),transform var(--transition-fast)}.color-picker-footer{border-top:1px solid var(--border-subtle);display:flex;gap:var(--space-4);padding:var(--space-4) 0 var(--space-5)}.btn-apply{flex:1 1;padding:var(--space-3);border-radius:var(--radius-md);font-size:var(--text-base);font-weight:var(--font-weight-bold);background:var(--color-success-alpha-20);border:1px solid var(--color-success-alpha-40);color:var(--color-success);cursor:pointer;transition:all var(--transition-base)}.btn-apply:hover{background:var(--color-success-alpha-40);border-color:var(--color-success);color:var(--text-primary)}.btn-apply:active{transform:scale(.98)}.btn-cancel{flex:1 1;padding:var(--space-3);border-radius:var(--radius-md);font-size:var(--text-base);font-weight:var(--font-weight-semibold);background:var(--surface-control);color:var(--text-primary);border:none;cursor:pointer;transition:all var(--transition-base)}.btn-cancel:hover{background:var(--border-dark)}.btn-cancel:active{transform:scale(.98)}@media (max-width:768px){.color-picker-overlay{padding:0;align-items:flex-end}.color-picker-modal{border-radius:var(--radius-xl) var(--radius-xl) 0 0;max-height:45vh;padding:var(--space-4) var(--space-4) var(--space-6);margin:0 auto;width:100%;max-width:480px;border-bottom:none;border-left:none;border-right:none;margin-bottom:var(--space-7)}.montana-gallery{grid-template-columns:repeat(auto-fill,minmax(44px,1fr));gap:var(--space-3);padding:var(--space-2) var(--space-1) var(--space-5);justify-content:center}.color-tile{height:44px;width:44px;border-radius:50%;border:2px solid var(--surface-control-hover);background:transparent;box-shadow:0 2px 8px var(--surface-overlay-dark);margin:0 auto}.color-tile:hover{transform:scale(1.1);box-shadow:0 4px 12px var(--surface-overlay-dark)}.color-tile.selected{border-color:var(--text-primary);box-shadow:0 0 0 2px var(--color-brand);transform:scale(1.1)}.color-tile-swatch{height:100%;width:100%;border-radius:50%}.color-tile-info{display:none}}.spraytest-container.fullscreen-mode #canvas-container{top:0;left:0;right:0;bottom:0;border-radius:var(--radius-xl);border:none;width:100vw;height:100vh}.spraytest-container.fullscreen-mode #previewCanvas,.spraytest-container.fullscreen-mode #sprayCanvas,.spraytest-container.fullscreen-mode .canvas-wrapper{border-radius:var(--radius-xl)}.floating-controls-bar{position:fixed;top:var(--space-4);right:var(--space-4);height:42px;display:flex;align-items:center;z-index:var(--z-modal);pointer-events:auto}.dropdown-divider{height:1px;background:var(--border-subtle);margin:var(--space-1) var(--space-4);opacity:.5}.pan-mode-btn{position:fixed;bottom:var(--space-6);right:var(--space-6);width:48px;height:48px;background:var(--surface-control);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:50%;border:1px solid var(--border-muted);box-shadow:0 8px 32px var(--surface-overlay-darker);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:var(--z-modal);transition:all .2s cubic-bezier(.34,1.56,.64,1);color:var(--text-primary)}.pan-mode-btn:hover{background:var(--surface-control-hover);border:1px solid var(--border-subtle)}.pan-mode-btn img{width:24px;height:24px;transition:transform .2s,filter .2s;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none;pointer-events:none}html:not([data-theme=light]) .pan-mode-btn img{filter:invert(1)}@media (max-width:700px){.floating-controls-bar{top:var(--space-2);right:var(--space-2)}.pan-mode-btn{bottom:var(--space-4);right:var(--space-4);width:48px;height:48px}}.spraytest-container.fullscreen-mode .mobile-sheet{position:fixed!important;top:64px!important;right:var(--space-4)!important;left:auto!important;bottom:auto!important;width:400px!important;max-width:calc(100vw - 32px)!important;max-height:80vh!important;margin:0!important;border-radius:var(--radius-lg)!important;box-shadow:var(--shadow-lg)!important;animation:slideDownFade .25s cubic-bezier(.34,1.56,.64,1)!important;z-index:4000!important}.spraytest-container.fullscreen-mode .changelog-modal,.spraytest-container.fullscreen-mode .lang-modal,.spraytest-container.fullscreen-mode .mobile-dropdown-modal,.spraytest-container.fullscreen-mode .settings-modal{position:fixed!important;top:64px!important;right:var(--space-4)!important;left:auto!important;bottom:auto!important;width:auto!important;min-width:240px!important;max-width:90vw!important;z-index:10000!important;box-shadow:var(--shadow-lg)!important;animation:slideDownFade .25s cubic-bezier(.34,1.56,.64,1)!important;background:var(--surface-panel)!important;-webkit-backdrop-filter:var(--glass-blur)!important;backdrop-filter:var(--glass-blur)!important;border:1px solid var(--border-dark)!important;border-radius:var(--radius-lg)!important}@keyframes slideDownFade{0%{opacity:0;transform:translateY(-12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}
/*# sourceMappingURL=c2ece8c2a6f138c0.css.map*/