:root{--bg-primary: #1e1e1e;--bg-secondary: #252526;--bg-tertiary: #2d2d2d;--bg-header: #333333;--accent-primary: #007acc;--accent-hover: #008be5;--border-color: #3e3e42;--text-primary: #e1e1e1;--text-secondary: #aaaaaa;--text-muted: #666666;--sidebar-width: 50px;--panel-width: 280px;--header-height: 40px;--footer-height: 25px;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:var(--text-primary);background-color:var(--bg-primary);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box;margin:0;padding:0}body{margin:0;display:flex;min-width:320px;min-height:100vh;overflow:hidden}#root{width:100%;height:100vh;display:flex;flex-direction:column}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.glass{background:#2d2d2db3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1)}.flex-center{display:flex;align-items:center;justify-content:center}.panel-header{height:30px;background:var(--bg-tertiary);display:flex;align-items:center;padding:0 12px;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);border-bottom:1px solid var(--border-color);-webkit-user-select:none;user-select:none}.canvas-container{width:100%;height:100%;position:relative;overflow:visible;touch-action:none}.canvas-stack{position:relative;transform-origin:center center;background-color:#fff;background-image:linear-gradient(45deg,#e0e0e0 25%,transparent 25%),linear-gradient(-45deg,#e0e0e0 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#e0e0e0 75%),linear-gradient(-45deg,transparent 75%,#e0e0e0 75%);background-size:20px 20px;background-position:0 0,0 10px,10px -10px,-10px 0px;box-shadow:0 30px 100px #000c;flex-shrink:0;touch-action:none}.layer-canvas{position:absolute;top:0;left:0;width:100%;height:100%;transform-origin:0 0;image-rendering:pixelated;pointer-events:none}.layer-wrapper.visible{display:block}.layer-wrapper.hidden{display:none}.selection-overlay{position:absolute;border:1px dashed white;outline:1px dashed black;pointer-events:none;z-index:1000;animation:selection-ants .5s infinite linear}@keyframes selection-ants{0%{stroke-dashoffset:0}to{stroke-dashoffset:-10}}.brush-cursor{position:absolute;border:1px solid rgba(255,255,255,.8);box-shadow:0 0 0 1px #00000080;border-radius:50%;pointer-events:none;z-index:1001;transform:translate(-50%,-50%);mix-blend-mode:difference}.crop-marquee{position:absolute;border:2px solid #fff;outline:2000px solid rgba(0,0,0,.6);z-index:10000;box-shadow:0 0 20px #00000080}.crop-handle{position:absolute;width:14px;height:14px;background-color:#0078d4;border:2px solid #fff;border-radius:2px;z-index:10001;pointer-events:auto}.crop-handle:after{content:"";position:absolute;inset:-12px;background:transparent}.crop-handle.tl{top:-6px;left:-6px;cursor:nwse-resize}.crop-handle.tr{top:-6px;right:-6px;cursor:nesw-resize}.crop-handle.bl{bottom:-6px;left:-6px;cursor:nesw-resize}.crop-handle.br{bottom:-6px;right:-6px;cursor:nwse-resize}.crop-handle.tm{top:-6px;left:calc(50% - 6px);cursor:ns-resize}.crop-handle.bm{bottom:-6px;left:calc(50% - 6px);cursor:ns-resize}.crop-handle.lm{top:calc(50% - 6px);left:-6px;cursor:ew-resize}.crop-handle.rm{top:calc(50% - 6px);right:-6px;cursor:ew-resize}.crop-actions-bar{position:absolute;display:flex;gap:8px;padding:8px;background:#1e1e1ee6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:8px;box-shadow:0 8px 32px #00000080;z-index:10002;border:1px solid rgba(255,255,255,.1)}.crop-actions-bar.bottom{bottom:-50px;left:50%;transform:translate(-50%)}.crop-action-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;border-radius:6px;cursor:pointer;font-weight:700;transition:all .2s ease}.crop-action-btn.confirm{background:#2ecc71;color:#fff}.crop-action-btn.confirm:hover{background:#27ae60;transform:scale(1.1)}.crop-action-btn.cancel{background:#e74c3c;color:#fff}.crop-action-btn.cancel:hover{background:#c0392b;transform:scale(1.1)}.selection-marquee{position:absolute;border:1px dashed rgba(255,255,255,.95);outline:1px dashed rgba(0,0,0,.9);pointer-events:none;z-index:1000;background-color:#0078d714;box-shadow:0 0 0 1px #0000002e;-webkit-backdrop-filter:saturate(1.05);backdrop-filter:saturate(1.05);animation:marquee-animation .75s linear infinite;will-change:outline-offset,opacity}.selection-inverse-mask{position:absolute;pointer-events:none;z-index:999;background:#0c101647;box-shadow:inset 0 0 0 1px #ffffff14;animation:inverse-mask-fade .14s ease-out;will-change:opacity}.lasso-svg path{vector-effect:non-scaling-stroke}.marching-ants{animation:marching-ants-animation .5s linear infinite}@keyframes marching-ants-animation{0%{stroke-dashoffset:0}to{stroke-dashoffset:-8}}@keyframes inverse-mask-fade{0%{opacity:0}to{opacity:1}}.text-editor-input{position:absolute;opacity:.01;color:transparent;caret-color:transparent;background:transparent;border:none;outline:none;z-index:10001;padding:0;margin:0;resize:none;overflow:hidden;font-size:16px;line-height:1.2}.text-action-bar{position:absolute;z-index:10000;display:flex;gap:8px;pointer-events:auto;background:#333;padding:4px;border-radius:4px;box-shadow:0 4px 12px #00000080;border:1px solid rgba(255,255,255,.1)}.text-action-bar button{width:26px;height:26px;display:flex;align-items:center;justify-content:center;border:none;border-radius:3px;cursor:pointer;font-weight:700;color:#fff;transition:transform .1s}.text-action-bar button:active{transform:scale(.9)}.text-action-bar .commit-btn{background:#4caf50}.text-action-bar .cancel-btn{background:#f44336}@media screen and (max-width:768px){.text-action-bar{padding:6px;gap:10px;border-radius:6px}.text-action-bar button{width:36px;height:36px;font-size:16px}}.layer-move-outline{position:absolute;border:1.5px dashed #0078d4;outline:1px dashed rgba(255,255,255,.8);pointer-events:none;z-index:9999;box-shadow:0 0 4px #0003}.layer-move-outline .handle{position:absolute;width:8px;height:8px;background-color:#fff;border:1.5px solid #0078d4;box-shadow:0 1px 3px #0000004d;transform:translate(-50%,-50%);pointer-events:none}.layer-move-outline .handle.tl{top:0;left:0}.layer-move-outline .handle.tm{top:0;left:50%}.layer-move-outline .handle.tr{top:0;left:100%}.layer-move-outline .handle.ml{top:50%;left:0}.layer-move-outline .handle.mr{top:50%;left:100%}.layer-move-outline .handle.bl{top:100%;left:0}.layer-move-outline .handle.bm{top:100%;left:50%}.layer-move-outline .handle.br{top:100%;left:100%}.artboard-plus-btn{position:absolute;width:36px;height:36px;border-radius:50%;background-color:#1e1e1ebf;border:1.5px solid #0078d4;color:#0078d4;display:flex;align-items:center;justify-content:center;cursor:pointer;pointer-events:auto;transition:all .2s ease;box-shadow:0 2px 8px #0006}.artboard-plus-btn svg{stroke:currentColor}.artboard-plus-btn.top{top:-26px;left:50%;transform:translate(-50%,-50%)}.artboard-plus-btn.bottom{bottom:-26px;left:50%;transform:translate(-50%,50%)}.artboard-plus-btn.left{left:-26px;top:50%;transform:translate(-50%,-50%)}.artboard-plus-btn.right{right:-26px;top:50%;transform:translate(50%,-50%)}.artboard-plus-btn.top:hover{background-color:#0078d4;color:#fff;transform:translate(-50%,-50%) scale(1.1)}.artboard-plus-btn.bottom:hover{background-color:#0078d4;color:#fff;transform:translate(-50%,50%) scale(1.1)}.artboard-plus-btn.left:hover{background-color:#0078d4;color:#fff;transform:translate(-50%,-50%) scale(1.1)}.artboard-plus-btn.right:hover{background-color:#0078d4;color:#fff;transform:translate(50%,-50%) scale(1.1)}.welcome-overlay{position:fixed;inset:0;background-color:#0d0d0d;z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow-y:auto;overflow-x:hidden;color:#fff;font-family:Outfit,Inter,system-ui,sans-serif;padding:1.25rem 0}.welcome-overlay::-webkit-scrollbar{width:.375rem}.welcome-overlay::-webkit-scrollbar-track{background:transparent}.welcome-overlay::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:.625rem}.welcome-bg-glow{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:100vw;height:100vh;background:radial-gradient(circle,rgba(0,120,212,.12) 0%,transparent 70%);pointer-events:none;filter:blur(3.75rem);z-index:0}.welcome-content{width:100%;max-width:50rem;padding:2.5rem 1.25rem;z-index:1;display:flex;flex-direction:column;gap:2.5rem;margin:auto}.welcome-header{text-align:center}.welcome-logo{margin-bottom:1.25rem;display:inline-block}.welcome-header h1{font-size:clamp(1.75rem,5vw,2.625rem);font-weight:800;margin-bottom:.75rem;background:linear-gradient(135deg,#fff,#aaa);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.02em}.welcome-header p{color:#888;font-size:clamp(.875rem,2vw,1.125rem);font-weight:400;max-width:31.25rem;margin:0 auto}.welcome-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(18.75rem,1fr));gap:1.25rem;min-height:12.5rem}.welcome-card{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:1.25rem;padding:1.5rem;display:flex;flex-direction:column;gap:1rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;height:100%}.welcome-card:hover{background:#ffffff0d;border-color:#0078d466;transform:translateY(-.25rem);box-shadow:0 .9375rem 1.875rem #0006}.card-icon{width:3rem;height:3rem;background:#0078d41a;color:#0078d4;border-radius:.75rem;display:flex;align-items:center;justify-content:center}.card-info h3{font-size:1.125rem;font-weight:600;margin-bottom:.375rem}.card-info p{color:#777;font-size:.8125rem;line-height:1.5}.card-shortcut{position:absolute;top:1.5rem;right:1.5rem;font-size:.625rem;color:#444;background:#ffffff0a;padding:.1875rem .375rem;border-radius:.25rem;font-weight:600}.new-doc-form{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:1.25rem;padding:1.5rem;display:flex;flex-direction:column;gap:1rem;height:100%}.new-doc-form h3{font-size:1.125rem;font-weight:600}.form-row{display:grid;grid-template-columns:1fr 1fr auto;gap:.75rem;align-items:flex-end}.orientation-toggle{display:flex;gap:.25rem;background:#0000004d;padding:.25rem;border-radius:.625rem;border:1px solid rgba(255,255,255,.1)}.orientation-toggle button{background:transparent;border:none;color:#555;padding:.375rem;border-radius:.375rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.orientation-toggle button:hover{color:#aaa;background:#ffffff0d}.orientation-toggle button.active{color:#0078d4;background:#0078d41a}.input-group{display:flex;flex-direction:column;gap:.375rem}.input-group label{font-size:.6875rem;color:#555;text-transform:uppercase;font-weight:600}.input-group input{background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:.625rem;padding:.625rem;color:#fff;font-family:inherit;font-size:.875rem;outline:none;transition:border-color .2s;width:100%}.input-group input:focus{border-color:#0078d4}.form-presets{display:flex;flex-wrap:wrap;gap:.375rem}.form-presets button{background:#ffffff0d;border:1px solid transparent;color:#888;padding:.3125rem .625rem;border-radius:.375rem;font-size:.6875rem;cursor:pointer;transition:all .2s}.form-presets button:hover{background:#ffffff1a;color:#fff}.form-actions{display:flex;gap:.625rem;margin-top:auto;padding-top:.625rem}.btn-cancel{flex:1;background:transparent;border:1px solid rgba(255,255,255,.1);color:#666;padding:.625rem;border-radius:.625rem;cursor:pointer;font-weight:600;font-size:.8125rem}.btn-create{flex:2;background:#0078d4;border:none;color:#fff;padding:.625rem;border-radius:.625rem;cursor:pointer;font-weight:600;font-size:.8125rem;transition:background .2s}.welcome-footer{display:flex;justify-content:center;flex-wrap:wrap;gap:1.25rem 2.5rem;margin-top:1.25rem}.footer-item{display:flex;align-items:center;gap:.5rem;color:#555;font-size:.8125rem}.github-star-btn{display:flex;align-items:center;gap:.5rem;color:#fff;font-size:.8125rem;text-decoration:none;background:#ffffff0d;padding:.375rem .875rem;border-radius:1.25rem;border:1px solid rgba(255,255,255,.1);transition:all .3s ease}.github-star-btn:hover{background:#24292e;border-color:#fff;transform:translateY(-2px)}.welcome-social{margin-top:2.5rem;color:#333;font-size:.6875rem;text-align:center;padding-bottom:1.25rem}@media(max-width:37.5rem){.welcome-overlay{justify-content:flex-start;padding-top:2.5rem}.welcome-content{gap:1.875rem}.welcome-grid{grid-template-columns:1fr}.welcome-card,.new-doc-form{padding:1.25rem}.form-row{grid-template-columns:1fr 1fr;gap:.625rem}.orientation-group{grid-column:span 2;align-items:center}.orientation-toggle{width:100%;justify-content:center}.orientation-toggle button{flex:1}.welcome-footer{flex-direction:column;align-items:flex-start;padding-left:1.25rem;gap:.75rem}.card-shortcut{display:none}}.menubar{display:flex;height:100%;align-items:center;background-color:var(--bg-header)}.menu-item-container{position:relative;display:flex;align-items:center;padding:0 .625rem;cursor:pointer;height:100%;font-size:.8125rem;color:var(--text-secondary);transition:all .15s ease;white-space:nowrap}.menu-item-container:hover,.menu-item-container.active{background-color:var(--bg-tertiary);color:var(--text-primary)}.menu-title-row{display:flex;align-items:center;height:100%}.menu-dropdown-wrapper{display:none}.menu-item-container.active .menu-dropdown-wrapper{display:block}.menu-dropdown{position:absolute;top:100%;left:0;background:var(--bg-header);border:1px solid var(--border-color);min-width:13.75rem;display:flex;flex-direction:column;box-shadow:0 .625rem 1.875rem #00000080;padding:.25rem 0;z-index:2000;animation:menuFadeIn .15s ease-out}@keyframes menuFadeIn{0%{opacity:0;transform:translateY(.3125rem)}to{opacity:1;transform:translateY(0)}}.menu-option{padding:.375rem 1rem;font-size:.75rem;display:flex;align-items:center;justify-content:space-between;gap:1.25rem;color:var(--text-primary);position:relative;transition:background-color .1s}.menu-option:hover{background-color:var(--accent-primary);color:#fff}.menu-option.disabled{opacity:.4;cursor:default;pointer-events:none}.menu-option .shortcut{color:var(--text-muted);font-size:.6875rem}.menu-option:hover .shortcut{color:#fffc}.menu-option-content{display:flex;justify-content:space-between;align-items:center;flex:1}.menu-option-check{width:.875rem;flex-shrink:0;font-size:.6875rem;color:var(--accent-primary);margin-right:.25rem;text-align:center}.submenu-arrow{margin-left:.5rem;opacity:.6}.menu-option:hover .submenu-arrow{opacity:1}.menu-submenu-wrapper{display:none}.menubar .menu-submenu{position:absolute;top:-.25rem;left:100%;background:var(--bg-header);border:1px solid var(--border-color);min-width:12.5rem;display:flex;flex-direction:column;box-shadow:.625rem .625rem 1.875rem #00000080;padding:.25rem 0;z-index:2100}@media(max-width:48rem){.menubar{position:fixed;top:0;left:-100%;width:17.5rem;height:100vh;background-color:var(--bg-header);flex-direction:column;z-index:2000;transition:left .3s cubic-bezier(.4,0,.2,1);border-right:1px solid var(--border-color);padding-top:0;display:flex;overflow-y:auto}.menubar.mobile-open{left:0}.menu-items-wrapper{display:flex;flex-direction:column;width:100%;padding:.625rem 0}.mobile-menu-header{display:flex;align-items:center;justify-content:space-between;padding:.625rem 1.25rem;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);width:100%;position:sticky;top:0;z-index:10}.mobile-menu-header span{font-weight:600;font-size:1rem}.mobile-menu-header button{background:transparent;border:none;color:var(--text-primary);cursor:pointer}.menu-item-container{width:100%;height:auto;min-height:2.25rem;padding:0 1.25rem;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(255,255,255,.05)}.menu-title-row{display:flex;justify-content:space-between;align-items:center;width:100%;height:2.25rem;flex-shrink:0}.menu-title-row .submenu-icon{transition:transform .2s ease;transform:rotate(0)}.menu-item-container.active .menu-title-row .submenu-icon{transform:rotate(90deg)}.menu-dropdown-wrapper{display:grid;grid-template-rows:0fr;transition:grid-template-rows .3s cubic-bezier(.4,0,.2,1);width:100%;overflow:hidden}.menu-dropdown-wrapper.open{grid-template-rows:1fr}.menu-dropdown-inner{min-height:0}.menu-dropdown{position:static;width:100%;box-shadow:none;border:none;background:var(--bg-secondary);padding:.25rem 0;display:flex;flex-direction:column;animation:none}.menu-option{padding:.5rem 1.25rem .5rem calc(1.25rem + var(--depth, 1) * .75rem);border-bottom:1px solid rgba(255,255,255,.02);width:100%;box-sizing:border-box}.menu-option.submenu-parent{flex-wrap:wrap;padding:.5rem 1.25rem .5rem calc(1.25rem + var(--depth, 1) * .75rem)}.menu-submenu-wrapper{display:grid;grid-template-rows:0fr;transition:grid-template-rows .3s cubic-bezier(.4,0,.2,1);width:100%;overflow:hidden}.menu-submenu-wrapper.open{grid-template-rows:1fr}.menu-submenu-inner{min-height:0}.menubar .menu-submenu{position:static;width:100%;box-shadow:none;border:none;background:#00000026;padding:0;display:flex;flex-direction:column}.menu-option .submenu-arrow{transition:transform .25s ease;transform:rotate(0)}.menu-option.active>.submenu-arrow{transform:rotate(90deg)}}@media(min-width:48.06rem){.menu-items-wrapper{display:flex;height:100%}.mobile-menu-header,.menu-submenu-wrapper{display:none}.menu-option.submenu-parent:hover>.menu-submenu-wrapper,.menu-option.submenu-parent.active>.menu-submenu-wrapper{display:block}}.tab-bar{display:flex;align-items:center;background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);height:2.25rem;padding:0 .5rem;-webkit-user-select:none;user-select:none;overflow:hidden}.tabs-container{display:flex;height:100%;overflow-x:auto;scrollbar-width:none}.tabs-container::-webkit-scrollbar{display:none}.tab{display:flex;align-items:center;padding:0 .75rem;background-color:var(--bg-tertiary);border-right:1px solid var(--border-color);font-size:.75rem;color:var(--text-muted);cursor:pointer;min-width:7.5rem;max-width:12.5rem;transition:all .2s ease;position:relative}.tab:hover{background-color:#3d3d3d;color:var(--text-primary)}.tab.active{background-color:var(--bg-primary);color:var(--text-primary);border-bottom:2px solid var(--accent-primary);height:calc(100% + 1px);margin-bottom:-1px;z-index:1}.tab-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-right:.5rem}.close-tab{display:flex;align-items:center;justify-content:center;width:1rem;height:1rem;border-radius:2px;border:none;background:transparent;color:var(--text-muted);opacity:0;transition:all .2s ease}.tab:hover .close-tab,.tab.active .close-tab{opacity:1}.close-tab:hover{background-color:#ffffff1a;color:#ff4d4d}.new-tab-btn{display:flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;margin-left:.5rem;border:none;background:transparent;color:var(--text-muted);border-radius:.25rem;cursor:pointer;transition:all .2s ease}.new-tab-btn:hover{background-color:#ffffff0d;color:var(--text-primary)}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000b3;-webkit-backdrop-filter:blur(.25rem);backdrop-filter:blur(.25rem);display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s ease-out}.modal-content{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:.75rem;width:28.12rem;max-width:90vw;box-shadow:0 1.25rem 2.5rem #00000080;overflow:hidden;display:flex;flex-direction:column}.modal-header{padding:1rem 1.25rem;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;background:var(--bg-header)}.modal-header h3{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary)}.modal-close-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem;display:flex;align-items:center;border-radius:.25rem;transition:all .2s}.modal-close-btn:hover{background:#ffffff1a;color:var(--text-primary)}.modal-body{padding:1.25rem;display:flex;flex-direction:column;gap:1.25rem}.modal-actions{padding:1rem 1.25rem;background:var(--bg-header);border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:.75rem}.provider-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.provider-card{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:.5rem;padding:1rem;display:flex;flex-direction:column;align-items:center;gap:.625rem;cursor:pointer;transition:all .2s}.provider-card:hover{border-color:var(--accent-primary);background:#0078d41a;transform:translateY(-2px)}.provider-card.selected{border-color:var(--accent-primary);background:#0078d426;box-shadow:0 0 0 1px var(--accent-primary)}.provider-icon{width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center;background:#ffffff0d;border-radius:.625rem}.provider-name{font-size:.75rem;font-weight:500;color:var(--text-secondary)}.provider-card.selected .provider-name{color:var(--text-primary)}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.75rem;color:var(--text-secondary)}.form-input{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:.375rem;padding:.5rem .75rem;color:var(--text-primary);font-size:.8125rem;outline:none}.form-input:focus{border-color:var(--accent-primary)}.success-state{display:flex;flex-direction:column;align-items:center;text-align:center;gap:1rem;padding:1.25rem 0}.success-icon{width:3.75rem;height:3.75rem;background:#4caf5026;color:#4caf50;border-radius:50%;display:flex;align-items:center;justify-content:center}.success-link-box{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:.375rem;padding:.25rem;display:flex;width:100%}.success-link{flex:1;padding:.375rem .625rem;font-size:.75rem;color:var(--text-secondary);background:transparent;border:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.copy-btn{background:var(--accent-primary);color:#fff;border:none;border-radius:.25rem;padding:.25rem .75rem;font-size:.75rem;font-weight:500;cursor:pointer}.copy-btn:hover{background:#0086f0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.btn{padding:.5rem 1rem;border-radius:.375rem;font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .2s;border:none}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:#444}.btn-primary{background:var(--accent-primary);color:#fff}.btn-primary:hover{background:#0086f0}.btn:disabled{opacity:.5;cursor:not-allowed}@media(max-width:30rem){.provider-grid{grid-template-columns:1fr;gap:.5rem}}.dialog-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(.25rem);backdrop-filter:blur(.25rem)}.dialog-content{background:#2a2a2a;border-radius:.5rem;width:90%;max-width:37.5rem;color:#fff;box-shadow:0 .625rem 1.875rem #00000080;display:flex;flex-direction:column}.export-dialog{max-width:50rem}.dialog-header{padding:1rem 1.25rem;border-bottom:1px solid #333;display:flex;justify-content:space-between;align-items:center}.dialog-header h2{margin:0;font-size:1rem;font-weight:500}.dialog-close{background:none;border:none;color:#888;cursor:pointer;padding:.25rem}.dialog-close:hover{color:#fff}.dialog-body{padding:1.25rem;display:flex;flex-direction:column;gap:1.5rem}.new-doc-body{flex-direction:row}.presets-sidebar{flex:1;border-right:1px solid #333;padding-right:1.25rem}.presets-sidebar h3{margin-top:0;font-size:.75rem;text-transform:uppercase;color:#888;margin-bottom:.75rem}.preset-list{display:flex;flex-direction:column;gap:.5rem}.preset-item{background:#333;border:1px solid transparent;padding:.625rem;border-radius:.25rem;text-align:left;color:#fff;cursor:pointer;transition:all .2s}.preset-item:hover{background:#3a3a3a;border-color:#4a4a4a}.preset-name{font-weight:500;font-size:.875rem}.preset-dims{font-size:.75rem;color:#aaa;margin-top:.25rem}.doc-settings{flex:1.5;display:flex;flex-direction:column;gap:1rem}.setting-group{display:flex;flex-direction:column;gap:.375rem}.setting-group label{font-size:.75rem;color:#aaa}.setting-group input[type=number],.setting-group select{background:#1a1a1a;border:1px solid #444;color:#fff;padding:.5rem .75rem;border-radius:.25rem;font-family:inherit}.setting-group input[type=number]:focus,.setting-group select:focus{outline:none;border-color:#06c}.dialog-footer{padding:1rem 1.25rem;border-top:1px solid #333;display:flex;justify-content:flex-end;gap:.75rem}.btn-primary,.btn-secondary{padding:.5rem 1rem;border-radius:.25rem;font-size:.875rem;cursor:pointer;border:none;font-weight:500}.btn-primary{background:#06c;color:#fff}.btn-primary:hover{background:#07e}.btn-secondary{background:transparent;border:1px solid #555;color:#ddd}.btn-secondary:hover{background:#333}.export-body{flex-direction:row}.export-preview{flex:2;background:#1a1a1a;border:1px solid #333;border-radius:.25rem;display:flex;align-items:center;justify-content:center;padding:1.25rem}.export-settings{flex:1;display:flex;flex-direction:column;gap:1.25rem}.info-grid{display:flex;flex-direction:column;gap:.75rem}.info-row{display:flex;justify-content:space-between;border-bottom:1px solid #333;padding-bottom:.5rem}.info-label{color:#888}.info-note{font-size:.75rem;color:#888;margin-top:1.25rem;font-style:italic}.export-preview-container{flex:2;display:flex;flex-direction:column;background:#1e1e1e;border:1px solid #333;border-radius:.25rem;overflow:hidden}.export-preview{flex:1;display:flex;align-items:center;justify-content:center;padding:1.25rem;background:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAAXNSR0IArs4c6QAAADFJREFUOE9jZCASMDKgCHb29v5HgAEYjUaDYTRgMBoMBoMhwIABnQ3AwE4YTYNBNBgAAGe9CRB2a1/uAAAAAElFTkSuQmCC) repeat}.export-preview canvas{max-width:100%;max-height:25rem;object-fit:contain;box-shadow:0 .25rem .625rem #00000080}.export-preview-footer{display:flex;justify-content:space-between;padding:.5rem .75rem;background:#111;color:#aaa;font-size:.75rem}.export-settings{flex:1;display:flex;flex-direction:column;gap:1rem}.export-row-2{display:flex;gap:.75rem}.export-row-dims{display:flex;gap:.5rem;align-items:center}.export-row-dims .setting-group{flex:1}.link-button-container{display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%;padding-bottom:2px}.link-button{background:#333;border:1px solid #444;color:#888;cursor:pointer;border-radius:.25rem;padding:.375rem;display:flex;align-items:center;justify-content:center;transition:all .2s}.link-button.active{background:#444;color:#fff;border-color:#555}.link-button:hover{background:#555;color:#fff}.unit-select{width:3.75rem}.quality-group{margin-top:.5rem}.quality-header{display:flex;justify-content:space-between;font-size:.75rem;color:#aaa;margin-bottom:.25rem}.export-checkboxes{display:flex;flex-direction:column;gap:.5rem;margin-top:.75rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:#ccc;cursor:pointer}.export-actions{display:flex;gap:.5rem;margin-top:auto}.btn-save{flex:1;background:#4a4a4a;color:#fff;border:1px solid #5a5a5a;padding:.5rem;border-radius:.25rem;cursor:pointer;font-weight:500}.btn-save:hover{background:#5a5a5a}.btn-more{width:2.25rem;background:#4a4a4a;color:#fff;border:1px solid #5a5a5a;border-radius:.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;font-weight:700}.btn-more:hover{background:#5a5a5a}.camera-dialog .dialog-body{display:flex;flex-direction:column}.dialog-tabs{display:flex;border-bottom:1px solid var(--border-color);margin-bottom:.9375rem}.tab-btn{background:none;border:none;padding:.625rem .9375rem;color:var(--text-color);cursor:pointer;border-bottom:2px solid transparent}.tab-btn:hover{background-color:var(--hover-bg)}.tab-btn.active{border-bottom-color:var(--primary-color);color:var(--primary-color)}.exif-toolbar{margin-bottom:.9375rem;display:flex;justify-content:flex-end}.exif-section{margin-bottom:1.25rem}.exif-section h3{margin:0 0 .625rem;font-size:.875rem;color:var(--text-color);border-bottom:1px solid var(--border-color);padding-bottom:.3125rem}.exif-table{display:flex;flex-direction:column;gap:.5rem}.exif-row{display:flex;align-items:center;gap:.625rem}.exif-label{width:9.375rem;font-size:.75rem;color:#999;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.exif-input{flex:1;background:var(--bg-dark);border:1px solid var(--border-color);color:var(--text-color);padding:.25rem .5rem;border-radius:.25rem}.btn-sm{padding:.25rem .5rem;font-size:.75rem}.exif-add-new{margin-top:1.25rem;padding-top:.9375rem;border-top:1px dashed var(--border-color)}.exif-add-new h4{margin:0 0 .625rem;font-size:.8125rem}.add-tag-row{display:flex;gap:.625rem}.add-tag-row select,.add-tag-row input{background:var(--bg-dark);border:1px solid var(--border-color);color:var(--text-color);padding:.375rem;border-radius:.25rem}.add-tag-row input{flex:1}@media(max-width:48rem){.export-body{flex-direction:column;gap:1rem;overflow-y:auto;max-height:70vh}.export-preview-container{flex:none;width:100%;max-height:15.62rem}.export-preview canvas{max-height:12.5rem}.export-settings{flex:none;width:100%}.export-row-2,.export-row-dims{flex-direction:column;align-items:stretch}.export-row-dims{gap:.75rem}.link-button-container{flex-direction:row;justify-content:center;padding:.25rem 0}.dialog-content{width:95%;max-height:90vh}.dialog-body{padding:1rem}.new-doc-body{flex-direction:column;gap:1rem;overflow-y:auto}.presets-sidebar{border-right:none;border-bottom:1px solid #333;padding-right:0;padding-bottom:1rem;flex:none}.doc-settings{flex:none}}.adjustment-sliders-container{display:flex;flex-direction:column;gap:1.25rem;padding:.5rem 0}.adjustment-control-row{display:flex;flex-direction:column;gap:.5rem}.control-header{display:flex;justify-content:space-between;align-items:center}.control-header label{font-size:.875rem;font-weight:500;color:#ddd}.control-number-input{width:4rem;background:#1a1a1a;border:1px solid #444;color:#fff;padding:.25rem .375rem;border-radius:.25rem;font-family:inherit;font-size:.8125rem;text-align:right}.control-number-input:focus{outline:none;border-color:#06c}.slider-wrapper{display:flex;align-items:center}.adjustment-range{flex:1;-webkit-appearance:none;appearance:none;width:100%;height:.375rem;border-radius:.25rem;background:#333;outline:none}.adjustment-range::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:1rem;height:1rem;border-radius:50%;background:#06c;cursor:pointer;transition:background .15s}.adjustment-range::-webkit-slider-thumb:hover{background:#07e}.hue-range-slider{background:linear-gradient(to right,red,#ff0 17%,#0f0 33%,#0ff,#00f 67%,#f0f 83%,red)}.hue-range-slider::-webkit-slider-thumb{background:#fff;border:2px solid #333}.effects-panel-container{display:flex;flex-direction:column;max-height:20rem;overflow-y:auto;padding-right:.25rem}.effects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(7.5rem,1fr));gap:.75rem}.effect-card-btn{background:#1e1e1e;border:1px solid #444;border-radius:.375rem;padding:.75rem .5rem;color:#fff;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:.25rem;transition:all .2s ease;text-align:center}.effect-card-btn:hover{background:#2b2b2b;border-color:#555}.effect-card-btn.active{border-color:#06c;background:#253346;box-shadow:0 0 0 1px #06c}.effect-card-title{font-size:.8125rem;font-weight:600}.effect-card-desc{font-size:.6875rem;color:#888}.dialog-overlay.adjustment-overlay{background:#00000026;-webkit-backdrop-filter:none;backdrop-filter:none;pointer-events:none}.dialog-overlay.adjustment-overlay .dialog-content{pointer-events:auto;box-shadow:0 .625rem 2.5rem #000000a6}.dialog-overlay.adjustment-overlay .draggable-header{cursor:move;-webkit-user-select:none;user-select:none}.alert-container{position:fixed;top:60px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px;pointer-events:none}@media(max-width:768px){.alert-container{top:60px;right:50%;transform:translate(50%);width:90%;max-width:400px}}.alert-box{padding:12px 16px;border-radius:4px;font-family:Inter,system-ui,sans-serif;font-size:14px;color:#333;box-shadow:0 4px 6px #0000001a;display:flex;align-items:center;pointer-events:auto;animation:slideIn .3s ease-out;border-left:8px solid transparent}.alert-type{font-weight:700;margin-right:6px}.alert-info{background-color:#d1e5f0;border-left-color:#4a86a8;color:#4a86a8}.alert-info .alert-type{color:#4a86a8}.alert-warning{background-color:#f6efd5;border-left-color:#9e7f45;color:#9e7f45}.alert-warning .alert-type{color:#9e7f45}.alert-success{background-color:#d6f0d1;border-left-color:#4ca64c;color:#4ca64c}.alert-success .alert-type{color:#4ca64c}.alert-error{background-color:#f0d1d1;border-left-color:#d9534f;color:#d9534f}.alert-error .alert-type{color:#d9534f}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media(max-width:768px){@keyframes slideIn{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}}:root{--header-height: 2.375rem;--options-height: 2rem;--sidebar-width: 15rem;--toolbar-width: 2.75rem;--bg-primary: #1c1c1c;--bg-secondary: #252525;--bg-tertiary: #333333;--bg-header: #2f2f2f;--border-color: #3e3e3e;--text-primary: #e0e0e0;--text-secondary: #aaaaaa;--text-muted: #777777;--accent-primary: #0078d4}*{box-sizing:border-box;margin:0;padding:0;-webkit-user-select:none;user-select:none}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);overflow:hidden}.app-layout{display:flex;flex-direction:column;height:100vh;height:100dvh;width:100vw}.app-header{height:var(--header-height);background-color:var(--bg-header);border-bottom:1px solid var(--border-color);display:flex;align-items:center;padding:0 .625rem;z-index:1300}.main-nav{display:flex;height:100%}.menu-item-container{position:relative;display:flex;align-items:center;padding:0 .625rem;cursor:pointer;height:100%;font-size:.8125rem;color:var(--text-secondary)}.menu-item-container:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.menu-option{padding:.5rem 1rem;font-size:.75rem;display:flex;justify-content:space-between}.menu-option:hover{background-color:var(--accent-primary)}.menu-option .shortcut{color:var(--text-muted)}.menu-divider{height:1px;background-color:var(--border-color);margin:.25rem 0}.menu-option.submenu-parent{position:relative;justify-content:space-between}.menu-submenu{position:absolute;top:-.25rem;left:100%;background:var(--bg-header);border:1px solid var(--border-color);min-width:11.25rem;display:none;flex-direction:column;box-shadow:.625rem .625rem 1.875rem #00000080;padding:.25rem 0;z-index:1000}.menu-option.submenu-parent:hover .menu-submenu{display:flex}.options-bar{min-height:var(--options-height);background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);display:flex;align-items:flex-start;align-content:flex-start;flex-wrap:wrap;padding:.375rem .625rem;gap:.9375rem;font-size:.6875rem;overflow:visible;overflow-x:auto;overflow-y:hidden;white-space:nowrap;scrollbar-width:thin}.tool-indicator{font-weight:700;color:var(--text-primary);min-width:3.75rem}.options-divider{width:1px;height:1.25rem;background:var(--border-color);margin:0 .9375rem;align-self:stretch}.quick-actions{display:flex;align-items:center;flex-wrap:wrap;gap:.375rem;padding-left:.3125rem;margin-left:auto}.action-btn{background:transparent;border:none;color:var(--text-muted);width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:.375rem;cursor:pointer;transition:all .2s}.action-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.action-btn:active:not(:disabled){background:var(--accent-primary);color:#fff;transform:scale(.95)}.action-btn:disabled{opacity:.2;cursor:not-allowed}.action-btn.delete-btn:hover:not(:disabled){background:#f4433633;color:#f44336}.action-divider{width:1px;height:1rem;background:var(--border-color);margin:0 .375rem}.option-control{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;min-height:1.75rem;flex-shrink:0}.app-body{display:flex;flex:1;overflow:hidden}.left-toolbar{width:var(--toolbar-width);background-color:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;overflow:visible;position:relative;z-index:1001}.tools-container{flex:1;overflow-y:auto;display:flex;flex-direction:column;align-items:center;padding:.5rem 0;gap:.25rem}.tools-container::-webkit-scrollbar{width:.25rem}.tools-container::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:2px}.tool-btn{width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border:none;background:none;color:var(--text-muted);cursor:pointer;border-radius:.25rem;transition:all .2s;flex-shrink:0}.tool-btn:hover{background-color:var(--bg-tertiary)}.tool-btn.active{background-color:var(--bg-tertiary);border-color:var(--accent-primary);color:var(--text-primary)}.toolbar-colors{padding:1.25rem 0;display:flex;flex-direction:column;align-items:center;gap:.75rem;border-top:1px solid var(--border-color);background-color:var(--bg-secondary);margin-top:auto;width:100%;position:relative;z-index:10}.color-squares-container{position:relative;width:2rem;height:2rem}.color-square{width:1.25rem;height:1.25rem;border:2px solid #fff;box-shadow:0 0 0 1px #000;position:absolute;cursor:pointer;transition:transform .1s}.color-square:hover{transform:scale(1.05);z-index:5}.color-square.primary{z-index:2;top:0;left:0}.color-square.secondary{z-index:1;bottom:0;right:0}.color-actions{display:flex;width:2rem;justify-content:space-between;align-items:center}.color-action-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px;display:flex;align-items:center;justify-content:center;transition:color .2s}.color-action-btn:hover{color:var(--text-primary)}.color-action-btn svg{width:.75rem;height:.75rem}.picker-controls input[type=range]{appearance:none;background:transparent;cursor:pointer}.picker-controls input[type=range]::-webkit-slider-thumb{appearance:none;width:.75rem;height:.75rem;background:#fff;border-radius:50%;border:1px solid #444;box-shadow:0 0 2px #00000080;margin-top:-1px}.picker-controls input[type=range]::-moz-range-thumb{width:.75rem;height:.75rem;background:#fff;border-radius:50%;border:1px solid #444;box-shadow:0 0 2px #00000080}.workspace{flex:1;display:flex;flex-direction:column;background-color:#303030;position:relative;min-width:0;min-height:0}.canvas-viewport{flex:1;position:relative;overflow:hidden;background-color:#303030;min-width:0;min-height:0}.canvas-container{width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:visible;position:relative}.canvas-stack{position:relative;background-color:#fff;background-image:linear-gradient(45deg,#e0e0e0 25%,transparent 25%),linear-gradient(-45deg,#e0e0e0 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#e0e0e0 75%),linear-gradient(-45deg,transparent 75%,#e0e0e0 75%);background-size:1.25rem 1.25rem;background-position:0 0,0 .625rem,.625rem -.625rem,-.625rem 0px;transform-origin:center center;box-shadow:0 .625rem 2.5rem #0009;flex-shrink:0;touch-action:none}.layer-canvas{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;image-rendering:pixelated}.layer-canvas.hidden{display:none}.status-bar{height:1.5rem;background-color:var(--bg-header);border-top:1px solid var(--border-color);display:flex;align-items:center;padding:0 .625rem;gap:1.25rem;font-size:.6875rem;color:var(--text-muted)}.status-ready{color:#4caf50;margin-left:auto;display:flex;align-items:center}.status-processing{color:#ff9800;margin-left:auto;display:flex;align-items:center}.status-lighting{color:#fdd835;display:flex;align-items:center;margin-right:.9375rem}.animate-spin{animation:spin 1s linear infinite}.side-panels{width:var(--sidebar-width);background-color:var(--bg-secondary);border-left:1px solid var(--border-color);display:flex;flex-direction:column}.side-panel{display:flex;flex-direction:column;border-bottom:1px solid var(--border-color);flex:1;overflow:scroll}.history-panel{flex:1;min-height:9.375rem}.layers-panel{flex:2;min-height:12.5rem}.lights-panel{flex:1;min-height:7.5rem}.no-items{padding:1.25rem;text-align:center;color:var(--text-secondary);font-size:.6875rem;font-style:italic;overflow-y:scroll}.panel-tab{padding:.5rem .75rem;background-color:var(--bg-header);font-size:.6875rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase}.panel-content{flex:1;overflow-y:auto;padding:2px}.layer-node{border-bottom:1px solid rgba(255,255,255,.05)}.layer-node.dragging{opacity:.5;background:var(--bg-header)}.layer-node.drag-before .layer-row{border-top:2px solid var(--accent-primary)!important}.layer-node.drag-after .layer-row{border-bottom:2px solid var(--accent-primary)!important}.layer-node.drag-inside .layer-row{background-color:#0078d433!important;outline:1.5px solid var(--accent-primary)!important;outline-offset:-1.5px}.adj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:12px;background-color:#2b2b2b}.adj-btn{background-color:#3c3c3c;border:1px solid #454545;border-radius:4px;padding:8px 4px;display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;color:#ccc;transition:all .2s ease;box-shadow:0 1px 2px #0003;font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.adj-btn:hover{background-color:#4a4a4a;border-color:#555;color:#fff}.adj-btn i,.adj-btn svg{font-size:18px;width:18px;height:18px;margin-bottom:2px;color:#eee}.adj-btn span{font-size:10px}.history-item,.layer-row{padding:.375rem .625rem;font-size:.6875rem;cursor:pointer;display:flex;align-items:center;gap:.5rem}.history-item.active,.layer-row.active{background-color:var(--accent-primary);color:#fff}.layer-eye{width:1rem;opacity:.7}.layer-order-btns{margin-left:auto;display:flex;gap:2px;opacity:0;transition:opacity .2s}.layer-row:hover .layer-order-btns{opacity:1}.layer-order-btns button{background:transparent;border:none;color:inherit;cursor:pointer;padding:2px;display:flex;align-items:center;border-radius:2px}.layer-order-btns button:hover{background:#fff3}.layer-thumb{width:3rem;min-height:.625rem;background-color:#333;border:1px solid #444;flex-shrink:0;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;background-image:linear-gradient(45deg,#444 25%,transparent 25%),linear-gradient(-45deg,#444 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#444 75%),linear-gradient(-45deg,transparent 75%,#444 75%);background-size:.5rem .5rem;background-position:0 0,0 .25rem,.25rem -.25rem,-.25rem 0px}.layer-thumb img{width:100%;height:100%;object-fit:contain;z-index:1;position:relative}.layer-title{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.layer-global-properties{display:flex;flex-direction:column;gap:.5rem;padding:.625rem;background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.layer-properties-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;width:100%}.blend-select{flex:1.2;min-width:0}.opacity-control,.fill-control{flex:1.5;display:flex;align-items:center;gap:.375rem;font-size:.6875rem;color:#ccc;min-width:0}.opacity-control input[type=range],.fill-control input[type=range]{flex:1;min-width:0;height:.25rem;-webkit-appearance:none;appearance:none;background:var(--bg-tertiary);border-radius:2px;outline:none}.opacity-control input[type=range]::-webkit-slider-thumb,.fill-control input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:.75rem;height:.75rem;background:var(--accent-primary);border-radius:50%;cursor:pointer}.lock-control{display:flex;align-items:center;gap:.25rem;font-size:.6875rem;color:#ccc}.lock-btn{background:none;border:none;color:#888;padding:2px;cursor:pointer;border-radius:2px;display:flex;align-items:center;justify-content:center;width:1.125rem;height:1.125rem;transition:all .15s ease}.lock-btn:hover{background:var(--bg-tertiary);color:#ccc}.lock-btn.active{background:var(--accent-primary);color:#fff}.lock-btn:disabled{opacity:.4;cursor:not-allowed}.layer-lock-indicator{display:flex;align-items:center;justify-content:center;color:var(--accent-primary)}.layer-row.active .layer-lock-indicator{color:#fff}.opacity-val{min-width:2.188rem;text-align:right;color:var(--accent-primary);font-weight:500;cursor:text}.opacity-input,.value-input{width:2.375rem;height:1.125rem;background:var(--bg-tertiary);color:var(--accent-primary);border:1px solid var(--accent-primary);border-radius:2px;font-size:.625rem;padding:0 2px;text-align:center;outline:none;font-weight:600;box-sizing:border-box}.opacity-input::-webkit-inner-spin-button,.opacity-input::-webkit-outer-spin-button,.value-input::-webkit-inner-spin-button,.value-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.value-label{cursor:text;min-width:2.188rem;text-align:center;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:.1875rem;padding:1px .375rem;color:var(--accent-primary);font-weight:600;transition:all .2s}.value-label:hover{border-color:var(--accent-primary);background:var(--bg-hover)}.blend-select{width:100%;padding:.25rem .375rem;background:var(--bg-tertiary);color:#fff;border:1px solid var(--border-color);border-radius:.25rem;font-size:.6875rem;outline:none}.blend-select:focus{border-color:var(--accent-primary)}.panel-footer{padding:.3125rem;background-color:var(--bg-tertiary);display:flex;gap:.625rem}.panel-footer button{background:transparent;border:none;color:var(--text-secondary);cursor:pointer}.panel-footer button:hover:not(:disabled){color:var(--text-primary)}.selection-marquee{position:absolute;border:1px dashed rgba(255,255,255,.95);outline:1px dashed rgba(0,0,0,.9);outline-offset:0;box-shadow:0 0 0 1px #0000002e;pointer-events:none;z-index:10000;background-color:#0078d714;-webkit-backdrop-filter:saturate(1.05);backdrop-filter:saturate(1.05);animation:marquee-animation .75s infinite linear;will-change:outline-offset,opacity}@keyframes marquee-animation{0%{outline-offset:0}to{outline-offset:-.5rem}}.brush-cursor{position:absolute;border:1px solid white;box-shadow:0 0 0 1px #000;border-radius:50%;pointer-events:none;transform:translate(-50%,-50%);z-index:10001;mix-blend-mode:difference}.inline-text-editor{position:absolute;background:#ffffff0d;border:1px solid #0078d4;color:inherit;font-family:Arial,sans-serif;padding:.25rem;margin:0;resize:none;overflow:visible;white-space:pre-wrap;word-wrap:break-word;outline:2px solid rgba(0,120,212,.3);z-index:10002;min-width:6.25rem;min-height:1.2em;caret-color:#0078d4}.processing-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#000000d9;backdrop-filter:blur(.5rem);-webkit-backdrop-filter:blur(.5rem);padding:1.875rem 3.125rem;border-radius:1rem;display:flex;flex-direction:column;align-items:center;gap:1.25rem;z-index:100000;border:1px solid rgba(255,255,255,.1);box-shadow:0 1.25rem 3.125rem #00000080;animation:fadeIn .3s ease-out}.processing-spinner{width:2.5rem;height:2.5rem;border:.1875rem solid rgba(255,255,255,.1);border-top-color:#0078d4;border-radius:50%;animation:spin .8s linear infinite}.processing-message{color:#fff;font-size:.875rem;font-weight:500;letter-spacing:.02em}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translate(-50%,-45%)}to{opacity:1;transform:translate(-50%,-50%)}}@keyframes simpleFadeIn{0%{opacity:0}to{opacity:1}}.crop-marquee{cursor:crosshair}.crop-handle{position:absolute;width:14px;height:14px;background:#fff;border:2px solid #0078d7;border-radius:2px;z-index:10001;pointer-events:auto;box-shadow:0 2px 5px #0000004d}.crop-handle.tl{top:-7px;left:-7px;cursor:nwse-resize}.crop-handle.tr{top:-7px;right:-7px;cursor:nesw-resize}.crop-handle.bl{bottom:-7px;left:-7px;cursor:nesw-resize}.crop-handle.br{bottom:-7px;right:-7px;cursor:nwse-resize}.crop-handle.tm{top:-7px;left:50%;margin-left:-7px;cursor:ns-resize}.crop-handle.bm{bottom:-7px;left:50%;margin-left:-7px;cursor:ns-resize}.crop-handle.lm{left:-7px;top:50%;margin-top:-7px;cursor:ew-resize}.crop-handle.rm{right:-7px;top:50%;margin-top:-7px;cursor:ew-resize}.crop-actions-bar{position:absolute;bottom:-2.812rem;right:0;display:flex;gap:.5rem;background:#222;padding:.375rem;border-radius:.5rem;box-shadow:0 .625rem 1.875rem #0009;pointer-events:auto;border:1px solid rgba(255,255,255,.1);z-index:10001}.crop-actions-bar.bottom{top:auto;bottom:-2.812rem}.crop-action-btn{width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border:none;border-radius:.375rem;cursor:pointer;color:#fff;transition:all .2s}.crop-action-btn.confirm{background:#2e7d32}.crop-action-btn.confirm:hover{background:#388e3c}.crop-action-btn.cancel{background:#c62828}.crop-action-btn.cancel:hover{background:#d32f2f}@media(max-width:48rem){.crop-handle{width:20px;height:20px}.crop-handle.tl{top:-10px;left:-10px}.crop-handle.tr{top:-10px;right:-10px}.crop-handle.bl{bottom:-10px;left:-10px}.crop-handle.br{bottom:-10px;right:-10px}.crop-handle.tm{top:-10px;margin-left:-10px}.crop-handle.bm{bottom:-10px;margin-left:-10px}.crop-handle.lm{left:-10px;margin-top:-10px}.crop-handle.rm{right:-10px;margin-top:-10px}.crop-actions-bar{top:-55px}}.modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:100000;backdrop-filter:blur(.5rem);-webkit-backdrop-filter:blur(.5rem);animation:fadeIn .2s ease-out}.modal-content{background:#1e1e1e;border-radius:1rem;padding:1.5rem;width:90%;max-width:20rem;box-shadow:0 1.25rem 3.75rem #000c;border:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;gap:1.25rem}.modal-content h3{margin:0;font-size:1.125rem;color:#fff;font-weight:600}.modal-header{display:flex;justify-content:space-between;align-items:center;width:100%}.modal-close-btn{background:transparent;border:none;color:#888;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.modal-close-btn:hover{background:#ffffff1a;color:#fff}.modal-body{display:flex;flex-direction:column;align-items:center}.modal-actions{display:flex;justify-content:center;gap:.75rem}.premium-btn-sm.secondary{background:transparent;border:1px solid #333;color:#888}.premium-btn-sm.secondary:hover{background:#252525;color:#fff}.shortcut{margin-left:auto;font-size:.625rem;color:var(--text-muted);font-family:monospace}.lasso-svg{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.marquee-dash{animation:marquee .75s linear infinite}@keyframes marquee{0%{stroke-dashoffset:12}to{stroke-dashoffset:0}}@media(max-width:48rem){:root{--header-height: 3.125rem;--options-height: 2.75rem;--sidebar-width: 100%;--toolbar-width: 100%}body{overflow:hidden;position:fixed;width:100%;height:100%}.app-header{justify-content:space-between;padding:0 .9375rem}.header-left,.header-right{display:flex;align-items:center;gap:.75rem}.app-logo{display:flex;align-items:center;gap:.5rem;font-weight:700;font-size:.875rem;color:var(--text-primary)}.mobile-menu-btn,.mobile-panel-toggle{display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-secondary);cursor:pointer;width:2.25rem;height:2.25rem;border-radius:.5rem;transition:all .2s}.mobile-panel-toggle.active{background-color:var(--accent-primary);color:#fff}.main-nav{position:fixed;top:0;left:-100%;width:80%;height:100vh;background-color:var(--bg-header);flex-direction:column;z-index:2000;transition:left .3s ease;box-shadow:.625rem 0 1.875rem #00000080;padding:1.25rem 0;overflow-y:auto}.main-nav.mobile-open{left:0}.mobile-menu-header{display:flex;justify-content:space-between;align-items:center;padding:0 1.25rem 1.25rem;border-bottom:1px solid var(--border-color);margin-bottom:.625rem}.mobile-menu-header span{font-weight:700;font-size:1.125rem}.mobile-menu-header button{background:none;border:none;color:var(--text-secondary)}.menu-item-container{height:auto;min-height:3.125rem;font-size:1rem;padding:.75rem 1.25rem;width:100%;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start}.options-bar{display:flex;flex-wrap:nowrap;align-items:center;padding:.375rem .75rem;overflow-x:auto;overflow-y:hidden;white-space:nowrap;gap:.75rem;-webkit-overflow-scrolling:touch;height:var(--options-height)}.options-bar::-webkit-scrollbar{display:none}.options-divider{width:1px;height:1rem;background:var(--border-color);margin:0 .5rem;align-self:center}.quick-actions{display:flex;flex-wrap:nowrap;gap:.5rem;margin-left:auto}.tool-indicator{font-size:.625rem;min-width:auto}.app-body{position:relative}.toolbar-wrapper,.side-panels{position:fixed;bottom:-100%;left:0;width:100%;height:60vh;background-color:var(--bg-secondary);z-index:2000;transition:bottom .3s cubic-bezier(.4,0,.2,1);border-top:1px solid var(--border-color);border-radius:1.25rem 1.25rem 0 0;box-shadow:0 -.625rem 2.5rem #00000080;display:flex;flex-direction:column}.toolbar-wrapper.mobile-open,.side-panels.mobile-open{bottom:0}.mobile-panel-header{display:flex;justify-content:space-between;align-items:center;padding:.9375rem 1.25rem;border-bottom:1px solid var(--border-color)}.mobile-panel-header span{font-weight:700;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.mobile-panel-header button{background:none;border:none;color:var(--text-muted)}.left-toolbar{width:100%;height:100%;border-right:none}.tools-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(2.75rem,1fr));gap:.75rem;padding:1.25rem;align-items:start}.tool-btn{width:2.75rem;height:2.75rem}.toolbar-colors{flex-direction:row;padding:.9375rem 1.25rem;gap:1.25rem;justify-content:center}.workspace{width:100%;height:100%}.side-panels{padding-bottom:constant(safe-area-inset-bottom);padding-bottom:env(safe-area-inset-bottom);height:70vh}.side-panels.mobile-open{bottom:0}.side-panel{border-bottom:1px solid var(--border-color)}.history-panel{max-height:30%}.layers-panel{flex:1;overflow-y:scroll}.status-bar{display:none}.canvas-viewport{padding:0}.canvas-viewport>div:not(.canvas-container){display:none!important}.canvas-stack{max-width:none;max-height:none}.mobile-backdrop{position:fixed;inset:0;background:#0006;backdrop-filter:blur(.5rem);-webkit-backdrop-filter:blur(.5rem);z-index:1200;animation:simpleFadeIn .3s ease}.app-layout.menu-active .mobile-backdrop{z-index:1600}.app-layout.menu-active .app-header{z-index:2100}}@media(min-width:48.06rem){.mobile-menu-btn,.header-right,.mobile-panel-header,.mobile-menu-header{display:none}.app-logo{display:flex;align-items:center;gap:.5rem;font-weight:700;font-size:.875rem;color:var(--text-primary);margin-right:.9375rem}.toolbar-wrapper,.side-panels{position:relative;bottom:auto;left:auto;height:auto;width:auto;border-radius:0;box-shadow:none;transition:none}}@media(max-width:48rem){.menu-option .shortcut{display:none}}.empty-workspace-overlay{position:absolute;inset:0;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;z-index:2000;padding:1.25rem}.welcome-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:1.5rem;padding:2.5rem;text-align:center;max-width:28.12rem;width:100%;box-shadow:0 1.875rem 6.25rem #00000080;animation:slideUpWelcome .6s cubic-bezier(.16,1,.3,1)}.welcome-icon{width:5rem;height:5rem;background:#0078d41a;color:#0078d4;border-radius:1.25rem;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem}.welcome-card h2{font-size:1.5rem;font-weight:700;margin-bottom:.75rem;color:#fff}.welcome-card p{color:#aaa;margin-bottom:2rem;line-height:1.5}.welcome-actions{display:flex;flex-direction:column;gap:.75rem}.welcome-btn{display:flex;align-items:center;justify-content:center;gap:.625rem;padding:.875rem 1.5rem;border-radius:.75rem;font-weight:600;cursor:pointer;transition:all .2s;border:none;font-size:.9375rem}.welcome-btn.primary{background:#0078d4;color:#fff}.welcome-btn.primary:hover{background:#0086ed;transform:translateY(-2px)}.welcome-btn.secondary{background:#ffffff0d;color:#fff;border:1px solid var(--border-color)}.welcome-btn.secondary:hover{background:#ffffff1a;transform:translateY(-2px)}@keyframes slideUpWelcome{0%{opacity:0;transform:translateY(2.5rem)}to{opacity:1;transform:translateY(0)}}@media(max-width:48rem){.welcome-card{padding:1.875rem 1.25rem}}.tool-context-menu{background-color:var(--bg-header);border:1px solid var(--border-color);border-radius:.25rem;box-shadow:.3125rem .3125rem 1.25rem #00000080;padding:.25rem 0;min-width:11.25rem;display:flex;flex-direction:column}.context-menu-item{padding:.5rem .75rem;display:flex;align-items:center;gap:.625rem;font-size:.75rem;cursor:pointer;color:var(--text-secondary);transition:all .1s}.context-menu-item:hover{background-color:var(--accent-primary);color:#fff}.context-menu-item.active{background-color:var(--bg-tertiary);color:var(--text-primary);border-left:.1875rem solid var(--accent-primary);padding-left:.5625rem}.context-menu-item .item-icon{width:1rem;height:1rem;opacity:.8}.context-menu-item .item-label{flex:1}.context-menu-item .item-shortcut{color:var(--text-muted);font-size:.625rem;opacity:.6}.context-menu-item:hover .item-shortcut{color:#ffffffb3;opacity:1}.tool-btn{position:relative}.variant-indicator{position:absolute;bottom:2px;right:2px;width:0;height:0;border-left:.3125rem solid transparent;border-bottom:.3125rem solid var(--text-muted)}.tool-btn:hover .variant-indicator,.tool-btn.active .variant-indicator{border-bottom-color:var(--text-primary)}.pattern-preview{width:1.5rem;height:1.5rem;border-radius:.25rem;border:1px solid var(--border-color);overflow:hidden;margin-left:.5rem;background:#000;display:flex;align-items:center;justify-content:center}.pattern-preview img{width:100%;height:100%;object-fit:cover}.layer-rename-input{background:var(--bg-primary);border:1px solid var(--accent-primary);color:var(--text-primary);font-family:inherit;font-size:.6875rem;padding:2px .25rem;border-radius:2px;outline:none;width:100%;flex-grow:1}.layer-row.long-press-active{background-color:var(--bg-tertiary);opacity:.8;transform:scale(.98);transition:all .1s ease}.dock-panel{display:flex;flex-direction:column;overflow:hidden;min-height:0}.dock-tabs{display:flex;flex-shrink:0;background-color:var(--bg-primary);border-bottom:1px solid var(--border-color);overflow-x:auto;scrollbar-width:none}.dock-tabs::-webkit-scrollbar{display:none}.dock-tab{padding:.4375rem .75rem;font-size:.6875rem;font-weight:600;color:var(--text-muted);background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap;text-transform:uppercase;letter-spacing:.04em;transition:color .15s,border-color .15s;flex-shrink:0}.dock-tab:hover{color:var(--text-primary)}.dock-tab.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary)}.top-dock{flex:0 0 auto;max-height:10rem}.adjustments-dock{flex:0 0 auto}.bottom-dock{flex:1 1 0;min-height:0;display:flex;flex-direction:column}.bottom-dock>.panel-content{flex:1;overflow-y:auto;min-height:0}.layers-footer{flex-shrink:0;gap:.25rem;justify-content:flex-end;border-top:1px solid var(--border-color)}.layers-footer-btn{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:.25rem .375rem;display:flex;align-items:center;justify-content:center;border-radius:.25rem;transition:all .15s}.layers-footer-btn:hover:not(:disabled){background:var(--bg-tertiary);color:var(--text-primary)}.layers-footer-btn.layers-footer-delete:hover:not(:disabled){background:#f4433626;color:#f44336}.layers-footer-btn:disabled{opacity:.3;cursor:not-allowed}.swatches-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(1.375rem,1fr));gap:.25rem;padding:.625rem}.swatch-btn{width:1.375rem;height:1.375rem;border:1px solid rgba(255,255,255,.15);border-radius:.1875rem;cursor:pointer;transition:transform .1s,box-shadow .1s}.swatch-btn:hover{transform:scale(1.15);box-shadow:0 0 0 2px var(--accent-primary);position:relative;z-index:1}.channel-row{display:flex;align-items:center;gap:.5rem;padding:.4375rem .625rem;font-size:.6875rem;cursor:pointer;transition:background .1s}.channel-row:hover{background:var(--bg-tertiary)}.channel-eye{color:var(--text-muted);flex-shrink:0}.channel-swatch{width:2.25rem;height:.875rem;border-radius:2px;border:1px solid rgba(255,255,255,.1);flex-shrink:0}.channel-name{flex:1;color:var(--text-primary)}.channel-shortcut{font-size:.625rem;color:var(--text-muted);font-family:monospace}.mobile-panel-tabs{display:none!important}@media(max-width:48rem){.side-panels:before{content:"";display:block;width:2.5rem;height:.25rem;border-radius:2px;background:#fff3;margin:.625rem auto 0;flex-shrink:0}.mobile-panel-tabs{display:flex!important;overflow-x:auto;scrollbar-width:none;background-color:var(--bg-primary);border-bottom:1px solid var(--border-color);flex-shrink:0}.mobile-panel-tabs::-webkit-scrollbar{display:none}.mobile-panel-tab{padding:.75rem 1rem;font-size:.75rem;font-weight:600;color:var(--text-muted);background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap;text-transform:uppercase;letter-spacing:.04em;transition:color .15s,border-color .15s;flex-shrink:0}.mobile-panel-tab:hover{color:var(--text-primary)}.mobile-panel-tab.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary)}.side-panels .top-dock,.side-panels .adjustments-dock,.side-panels .bottom-dock{display:none}.side-panels.mobile-panel-history .top-dock,.side-panels.mobile-panel-swatches .top-dock,.side-panels.mobile-panel-adjustments .adjustments-dock,.side-panels.mobile-panel-layers .bottom-dock,.side-panels.mobile-panel-channels .bottom-dock,.side-panels.mobile-panel-paths .bottom-dock{display:flex;flex:1;min-height:0;max-height:none;flex-direction:column}.dock-tab{padding:.875rem 1.125rem;font-size:.75rem}.layer-row{min-height:2.75rem;padding:.5rem .75rem;font-size:.75rem;gap:.625rem}.layer-thumb{width:2.25rem;min-height:2.25rem}.layer-order-btns{opacity:1}.layer-order-btns button{padding:.375rem;min-width:1.875rem;min-height:1.875rem}.layer-global-properties{padding:.75rem;gap:.625rem}.blend-select{height:2.5rem;font-size:.8125rem;padding:.375rem .5rem}.opacity-control,.fill-control{font-size:.8125rem;gap:.625rem}.opacity-control input[type=range],.fill-control input[type=range]{height:.375rem}.opacity-control input[type=range]::-webkit-slider-thumb,.fill-control input[type=range]::-webkit-slider-thumb{width:1.25rem;height:1.25rem}.opacity-val{min-width:2.75rem;font-size:.8125rem}.layer-properties-row{gap:.875rem}.lock-control{font-size:.8125rem;gap:.375rem}.lock-btn{width:2rem;height:2rem}.lock-btn svg{width:1rem;height:1rem}.layers-footer{padding:.5rem .625rem;gap:.375rem}.layers-footer-btn{padding:.5rem .625rem;min-width:2.375rem;min-height:2.375rem}.swatches-grid{grid-template-columns:repeat(auto-fill,minmax(2rem,1fr));gap:.375rem;padding:.75rem}.swatch-btn{width:2rem;height:2rem;border-radius:.25rem}.channel-row{min-height:2.75rem;padding:.625rem .875rem;font-size:.8125rem}.channel-swatch{width:3rem;height:1.125rem}.history-item{min-height:2.5rem;font-size:.75rem;padding:.5rem .75rem}.panel-content{-webkit-overflow-scrolling:touch}.adj-grid{gap:8px;padding:12px}.adj-btn{width:auto;min-height:3.5rem;padding:8px 4px}.adj-btn:active{background:#4a4a4a;border-color:#555;color:#fff}}.layer-context-menu{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;box-shadow:0 4px 12px #00000080;display:flex;flex-direction:column;min-width:150px;padding:4px;pointer-events:auto}.layer-context-menu .menu-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;background:none;border:none;color:var(--text-primary);font-size:13px;text-align:left;cursor:pointer;border-radius:2px;transition:background-color .1s}.layer-context-menu .menu-item:hover{background-color:var(--accent-primary);color:#fff}.layer-context-menu .menu-item.text-danger:hover{background-color:#d32f2f}
