*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #0b0c0f;--bg-secondary: #131419;--bg-tertiary: #1b1d24;--bg-elevated: #23252e;--border-color: rgba(255, 255, 255, .07);--border-glow: rgba(84, 112, 255, .16);--text-primary: #ecedf1;--text-secondary: #9a9ca8;--text-tertiary: #63656f;--accent-primary: #5470ff;--accent-secondary: #7d92ff;--accent-hover: #6d86ff;--accent-light: rgba(84, 112, 255, .1);--accent-glow: rgba(84, 112, 255, .22);--success: #34d399;--error: #f87171;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4), 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .5), 0 2px 4px rgba(0, 0, 0, .3);--shadow-lg: 0 12px 40px rgba(0, 0, 0, .6), 0 4px 12px rgba(0, 0, 0, .4);--glass-bg: rgba(17, 19, 24, .72);--glass-border: rgba(255, 255, 255, .05);--glass-blur: blur(24px) saturate(160%);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-pill: 999px;--transition-fast: .15s cubic-bezier(.22, 1, .36, 1);--transition-smooth: .25s cubic-bezier(.22, 1, .36, 1);--transition-spring: .4s cubic-bezier(.34, 1.56, .64, 1);--font-sans: "Geist", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "SF Mono", "Fira Code", monospace}[data-theme=light]{--bg-primary: #f1f1ee;--bg-secondary: #fbfbf9;--bg-tertiary: #ecece8;--bg-elevated: #ffffff;--border-color: rgba(21, 22, 26, .08);--border-glow: rgba(35, 72, 255, .16);--text-primary: #15161a;--text-secondary: #55565e;--text-tertiary: #8a8b92;--accent-primary: #2348ff;--accent-secondary: #4f7cff;--accent-hover: #1a37d6;--accent-light: rgba(35, 72, 255, .07);--accent-glow: rgba(35, 72, 255, .18);--glass-bg: rgba(255, 255, 255, .78);--glass-border: rgba(0, 0, 0, .04);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 16px rgba(0, 0, 0, .08), 0 2px 4px rgba(0, 0, 0, .04);--shadow-lg: 0 12px 40px rgba(0, 0, 0, .1), 0 4px 12px rgba(0, 0, 0, .06)}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);overflow:hidden;height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-container{display:flex;height:100vh;width:100vw}.header{position:fixed;top:0;left:0;right:0;height:52px;background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-bottom:1px solid var(--glass-border);display:flex;align-items:center;padding:0 20px;z-index:1000;box-shadow:0 1px 0 var(--border-glow)}.header:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:1px;background:var(--accent-primary);opacity:.18}.header-content{display:flex;align-items:center;justify-content:space-between;width:100%}.logo{display:flex;align-items:center;gap:10px;font-size:17px;font-weight:600;letter-spacing:-.3px;color:var(--text-primary)}.logo-icon{width:30px;height:30px;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:15px;box-shadow:0 2px 8px var(--accent-glow);transition:transform var(--transition-spring),box-shadow var(--transition-smooth)}.logo-icon:hover{transform:scale(1.08) rotate(-4deg);box-shadow:0 4px 16px var(--accent-glow)}.header-actions{display:flex;gap:6px;align-items:center}.sidebar{width:360px;background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-right:1px solid var(--glass-border);margin-top:52px;height:calc(100vh - 52px);overflow-y:auto;overflow-x:hidden;position:relative}.sidebar:before{content:"";position:absolute;top:0;right:0;width:1px;height:100%;background:linear-gradient(180deg,var(--accent-primary),transparent 55%);opacity:.12;pointer-events:none}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:3px}.sidebar::-webkit-scrollbar-thumb:hover{background:#ffffff24}.sidebar-section{padding:20px;border-bottom:1px solid var(--border-color);animation:sectionReveal .5s var(--transition-smooth) backwards}@keyframes sectionReveal{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.sidebar-section:nth-child(1){animation-delay:.02s}.sidebar-section:nth-child(2){animation-delay:.04s}.sidebar-section:nth-child(3){animation-delay:.06s}.sidebar-section:nth-child(4){animation-delay:.08s}.sidebar-section:nth-child(5){animation-delay:.1s}.sidebar-section:nth-child(6){animation-delay:.12s}.sidebar-section:nth-child(7){animation-delay:.14s}.sidebar-section:nth-child(8){animation-delay:.16s}.sidebar-section:nth-child(9){animation-delay:.18s}.sidebar-section:nth-child(10){animation-delay:.2s}.sidebar-section:nth-child(n+11){animation-delay:.22s}.section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1.2px;margin-bottom:14px;color:var(--text-secondary);display:flex;align-items:center;gap:8px}.section-title:before{content:"";width:5px;height:5px;border-radius:50%;background:var(--accent-primary);flex-shrink:0}.main-content{flex:1;margin-top:52px;padding:16px 28px 52px;overflow:auto;background:var(--bg-primary);display:flex;flex-direction:column;margin-right:260px;transition:margin-right var(--transition-smooth)}.main-content.layers-collapsed{margin-right:36px}.canvas-container{width:100%;flex:1;display:flex;align-items:center;justify-content:center;position:relative}.canvas-wrapper{position:relative;max-width:100%;transition:all .3s ease}.canvas-wrapper-v4{transform-origin:center center;transition:transform .05s linear;will-change:transform}#preview-canvas{display:block;max-width:100%;max-height:calc(100vh - 160px);border-radius:var(--radius-md);box-shadow:var(--shadow-lg),0 0 0 1px var(--glass-border)}.upload-zone{width:600px;height:400px;border:1.5px dashed rgba(84,112,255,.28);border-radius:20px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;cursor:pointer;transition:all var(--transition-smooth);background:linear-gradient(135deg,#5470ff0d,#5470ff05);position:relative;overflow:hidden}.upload-zone:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 50% 50%,var(--accent-light),transparent 70%);opacity:0;transition:opacity var(--transition-smooth)}.upload-zone:hover{border-color:var(--accent-primary)}.upload-zone:hover:before{opacity:1}.upload-zone.drag-over{border-color:var(--accent-primary);border-style:solid;background:#5470ff12;transform:scale(1.01);box-shadow:inset 0 0 60px var(--accent-light),0 0 30px var(--accent-light)}.upload-icon{font-size:48px;color:var(--text-secondary);position:relative;z-index:1}.upload-text{text-align:center;position:relative;z-index:1}.upload-text h3{font-size:17px;font-weight:600;margin-bottom:8px;color:var(--text-primary);letter-spacing:-.2px}.upload-text p{font-size:13px;color:var(--text-secondary)}.control-group{margin-bottom:16px}.control-label{display:block;font-size:11px;font-weight:500;margin-bottom:6px;color:var(--text-secondary);letter-spacing:.3px;text-transform:uppercase}.control-input{width:100%;padding:9px 12px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:13px;font-family:var(--font-sans);transition:all var(--transition-fast)}.control-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-light),0 0 16px var(--accent-light);background:var(--bg-elevated)}.control-input::placeholder{color:var(--text-tertiary)}textarea.control-input{resize:vertical}input[type=range]{width:100%;height:4px;background:var(--bg-tertiary);border-radius:2px;outline:none;padding:0;border:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;background:var(--accent-primary);border-radius:50%;cursor:pointer;transition:all var(--transition-fast);box-shadow:0 0 0 3px var(--bg-secondary),0 0 8px var(--accent-glow)}input[type=range]::-webkit-slider-thumb:hover{background:#8f95ff;transform:scale(1.15);box-shadow:0 0 0 3px var(--bg-secondary),0 0 14px var(--accent-glow)}input[type=range]:active::-webkit-slider-thumb{transform:scale(1.25);box-shadow:0 0 0 3px var(--bg-secondary),0 0 20px var(--accent-glow)}input[type=range]::-moz-range-thumb{width:14px;height:14px;background:var(--accent-primary);border-radius:50%;cursor:pointer;border:none;box-shadow:0 0 0 3px var(--bg-secondary),0 0 8px var(--accent-glow)}.range-group{display:flex;align-items:center;gap:12px}.range-input{flex:1}.range-value{min-width:42px;text-align:right;font-size:11px;font-family:var(--font-mono);font-weight:500;color:var(--accent-primary);letter-spacing:-.3px}.color-picker-wrapper{display:flex;gap:10px;align-items:center}.color-preview{width:36px;height:36px;border-radius:var(--radius-sm);border:1.5px solid var(--border-color);cursor:pointer;transition:all var(--transition-fast);position:relative;overflow:hidden;box-shadow:0 2px 6px #0003}.color-preview:hover{border-color:var(--accent-primary);transform:scale(1.06);box-shadow:0 2px 10px #0000004d}.color-preview input[type=color]{position:absolute;top:-10px;left:-10px;width:calc(100% + 20px);height:calc(100% + 20px);border:none;cursor:pointer}.gradient-stops{display:flex;flex-direction:column;gap:10px;margin-top:10px}.gradient-stop{display:flex;gap:10px;align-items:center}.gradient-stop-color{width:30px;height:30px;border-radius:var(--radius-sm);border:1.5px solid var(--border-color);cursor:pointer;position:relative;overflow:hidden}.gradient-stop-color input[type=color]{position:absolute;top:-10px;left:-10px;width:calc(100% + 20px);height:calc(100% + 20px);border:none;cursor:pointer}.gradient-stop-position{flex:1}.gradient-preview{width:100%;height:56px;border-radius:var(--radius-md);margin-top:10px;border:1px solid var(--border-color);box-shadow:inset 0 2px 4px #00000026}.preset-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-top:10px}.preset-button{height:56px;border-radius:var(--radius-md);border:1.5px solid var(--border-color);cursor:pointer;transition:all var(--transition-fast);position:relative;overflow:hidden}.preset-button:hover{border-color:#ffffff26;transform:translateY(-2px) scale(1.01);box-shadow:var(--shadow-md),0 0 20px #0003}.preset-button.active{border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--accent-light),var(--shadow-md)}.preset-label{position:absolute;bottom:0;left:0;right:0;text-align:center;font-size:10px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.7);padding:6px 4px;background:linear-gradient(to top,rgba(0,0,0,.5),transparent)}.btn{padding:8px 16px;border-radius:var(--radius-sm);border:none;font-size:13px;font-weight:500;font-family:var(--font-sans);letter-spacing:-.1px;cursor:pointer;transition:all var(--transition-fast);display:inline-flex;align-items:center;gap:6px;justify-content:center;position:relative;overflow:hidden}.btn:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(255,255,255,.06),transparent);pointer-events:none}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn:disabled:active{transform:none}.btn-primary{background:var(--accent-primary);color:#fff;box-shadow:0 1px 3px var(--accent-glow)}.btn-primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 4px 16px var(--accent-glow);transform:translateY(-1px)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--bg-elevated);border-color:#ffffff1a;box-shadow:var(--shadow-sm)}.btn-success{background:var(--success);color:#042f2e;box-shadow:0 1px 3px #34d3994d}.btn-success:hover:not(:disabled){background:#2dd4bf;box-shadow:0 4px 16px #34d3994d;transform:translateY(-1px)}.toggle-switch{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.toggle-label{font-size:13px;font-weight:500;color:var(--text-primary)}.switch{position:relative;width:40px;height:22px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--bg-tertiary);border:1px solid var(--border-color);transition:all var(--transition-smooth);border-radius:var(--radius-pill)}.slider:before{position:absolute;content:"";height:14px;width:14px;left:3px;bottom:3px;background-color:var(--text-tertiary);transition:all var(--transition-spring);border-radius:50%}input:checked+.slider{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));border-color:transparent;box-shadow:0 0 12px var(--accent-light)}input:checked+.slider:before{transform:translate(18px);background-color:#fff}select.control-input{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%235c607a' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}input[type=number].control-input{-moz-appearance:textfield;font-family:var(--font-mono)}input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.angle-input-group{display:flex;gap:12px;align-items:center}.angle-visual{width:36px;height:36px;border-radius:var(--radius-sm);background:var(--bg-tertiary);border:1px solid var(--border-color);position:relative;display:flex;align-items:center;justify-content:center}.angle-indicator{width:2px;height:14px;background:var(--accent-primary);position:absolute;top:50%;left:50%;transform-origin:center bottom;border-radius:2px;box-shadow:0 0 6px var(--accent-glow)}.shadow-preset-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;margin-top:10px}.shadow-preset-btn{padding:10px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);text-align:center;font-size:12px;font-weight:500;color:var(--text-secondary)}.shadow-preset-btn:hover{background:var(--bg-elevated);border-color:#ffffff1a;color:var(--text-primary)}.shadow-preset-btn.active{background:var(--accent-light);border-color:var(--accent-primary);color:var(--accent-primary);box-shadow:0 0 12px var(--accent-light)}.export-size-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}.size-preset-btn{padding:10px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:12px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);text-align:left}.size-preset-btn:hover{background:var(--bg-elevated);border-color:#ffffff1a}.size-preset-btn.active{background:var(--accent-light);border-color:var(--accent-primary);color:var(--accent-primary)}.size-preset-label{display:block;font-weight:600;margin-bottom:2px;font-size:12px}.size-preset-dims{font-size:10px;font-family:var(--font-mono);color:var(--text-tertiary)}.notification{position:fixed;top:68px;right:20px;padding:12px 18px;background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:10px;z-index:2000;transform:translate(400px);opacity:0;transition:all var(--transition-smooth)}.notification.show{transform:translate(0);opacity:1}.notification.success{border-color:#34d3994d;box-shadow:var(--shadow-lg),0 0 20px #34d39914}.notification.error{border-color:#f871714d;box-shadow:var(--shadow-lg),0 0 20px #f8717114}.notification-icon{font-size:18px}.notification-text{font-size:13px;font-weight:500}.info-text{font-size:11px;color:var(--text-tertiary);margin-top:6px;line-height:1.6}.divider{height:1px;background:var(--border-color);margin:14px 0}.checkbox-label{display:flex;align-items:center;gap:8px;font-size:13px;cursor:pointer;color:var(--text-primary)}.checkbox-label input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--accent-primary)}#file-input{display:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff0f;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff1f}.tab-row{display:flex;gap:2px;margin-bottom:14px;background:var(--bg-tertiary);padding:3px;border-radius:var(--radius-sm)}.tab-btn{flex:1;padding:7px;border:none;background:transparent;color:var(--text-tertiary);border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;font-family:var(--font-sans);transition:all var(--transition-fast)}.tab-btn:hover{color:var(--text-secondary)}.tab-btn.active{background:var(--bg-elevated);color:var(--text-primary);box-shadow:var(--shadow-sm)}.annotation-toolbar{display:flex;align-items:center;gap:4px;padding:6px 12px;background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-md);margin-bottom:12px;flex-wrap:wrap;box-shadow:var(--shadow-md),0 0 0 1px var(--border-glow)}.ann-tool-btn{padding:5px 10px;border:1px solid transparent;background:transparent;color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;font-size:11px;font-weight:500;font-family:var(--font-sans);transition:all var(--transition-fast);white-space:nowrap}.ann-tool-btn:hover{color:var(--text-primary);background:var(--accent-light);border-color:var(--border-glow)}.ann-tool-btn.active{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary);box-shadow:0 2px 10px var(--accent-glow)}#preview-canvas[data-tool=arrow],#preview-canvas[data-tool=rect],#preview-canvas[data-tool=circle],#preview-canvas[data-tool=number],#preview-canvas[data-tool=redact],#preview-canvas[data-tool=spotlight]{cursor:crosshair}#preview-canvas[data-tool=select]{cursor:default}.shortcuts-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:3000;display:flex;align-items:center;justify-content:center}.shortcuts-modal{background:var(--bg-secondary);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:24px;min-width:420px;box-shadow:var(--shadow-lg),0 0 80px #0000004d;animation:modalIn .25s var(--transition-smooth)}@keyframes modalIn{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.shortcuts-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.shortcuts-header h3{font-size:15px;font-weight:600;letter-spacing:-.2px}.shortcuts-grid{display:flex;flex-direction:column;gap:10px}.shortcut-item{display:flex;align-items:center;justify-content:space-between;gap:16px}.shortcut-item span{color:var(--text-secondary);font-size:13px}kbd{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;padding:3px 8px;font-family:var(--font-mono);font-size:11px;color:var(--text-primary);white-space:nowrap;box-shadow:0 1px 2px #0003}.checkerboard-info{width:100%;height:36px;border-radius:var(--radius-sm);background-image:conic-gradient(#808080 90deg,transparent 90deg 180deg,#808080 180deg 270deg,transparent 270deg);background-size:14px 14px;margin-bottom:8px;border:1px solid var(--border-color)}@media (max-width: 1024px){.sidebar{width:320px}}.layers-panel{position:fixed;top:52px;right:0;bottom:0;width:260px;background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-left:1px solid var(--glass-border);display:flex;flex-direction:column;z-index:900;transition:transform var(--transition-smooth)}.layers-panel.collapsed{transform:translate(calc(100% - 36px))}.layers-header{padding:12px 14px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between}.layers-header h3{font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--text-secondary)}.layers-toggle-btn{background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;padding:4px 8px;font-size:13px;border-radius:4px;transition:all var(--transition-fast)}.layers-toggle-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.layers-list{flex:1;overflow-y:auto;padding:4px}.layer-row{display:flex;align-items:center;gap:6px;padding:5px 8px;border-radius:var(--radius-sm);cursor:pointer;border:1px solid transparent;margin-bottom:1px;transition:all var(--transition-fast)}.layer-row:hover{background:#ffffff08}.layer-row.selected{background:var(--accent-light);border-color:var(--accent-primary)}.layer-row.dragging{opacity:.45}.layer-row.drop-target{border-top:2px solid var(--accent-primary)}.layer-icon{width:18px;text-align:center;opacity:.7;font-size:11px}.layer-name{flex:1;font-size:12px;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.layer-name[contenteditable=true]{outline:1px solid var(--accent-primary);background:var(--bg-primary);padding:1px 4px;border-radius:3px}.layer-action-btn{width:22px;height:22px;border:none;background:transparent;color:var(--text-tertiary);cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:11px;transition:all var(--transition-fast)}.layer-action-btn:hover{background:var(--bg-primary);color:var(--text-primary)}.layer-action-btn.active{color:var(--accent-primary)}.layer-action-btn.locked{color:#fbbf24}.layers-empty{padding:24px 12px;text-align:center;color:var(--text-tertiary);font-size:12px}.history-timeline{position:fixed;left:0;right:0;bottom:0;height:36px;background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-top:1px solid var(--glass-border);display:flex;align-items:center;gap:8px;padding:0 14px;z-index:900;font-size:10px;color:var(--text-tertiary)}.history-track{flex:1;height:16px;display:flex;align-items:center;gap:3px;overflow-x:auto;padding:2px 0}.history-dot{width:8px;height:8px;border-radius:50%;background:var(--bg-tertiary);border:1px solid var(--border-color);cursor:pointer;flex-shrink:0;transition:all var(--transition-fast)}.history-dot:hover{transform:scale(1.5);background:var(--accent-primary)}.history-dot.current{background:var(--accent-primary);border-color:var(--accent-primary);transform:scale(1.3);box-shadow:0 0 8px var(--accent-glow)}.history-dot.future{opacity:.4}.history-controls{display:flex;gap:3px}.history-btn{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary);padding:2px 7px;font-size:10px;font-family:var(--font-sans);border-radius:4px;cursor:pointer;transition:all var(--transition-fast)}.history-btn:hover:not(:disabled){color:var(--text-primary);border-color:var(--accent-primary)}.history-btn:disabled{opacity:.35;cursor:not-allowed}.canvas-viewport{position:relative;flex:1;min-height:0;display:flex;align-items:center;justify-content:center;overflow:hidden}.canvas-viewport.panning{cursor:grab}.canvas-viewport.panning.active{cursor:grabbing}.zoom-controls{position:absolute;top:12px;right:12px;z-index:100;display:flex;align-items:center;gap:2px;background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-sm);padding:3px;box-shadow:var(--shadow-md)}.zoom-controls button{background:transparent;border:none;color:var(--text-primary);cursor:pointer;padding:4px 9px;border-radius:4px;font-size:13px;font-weight:500;transition:all var(--transition-fast)}.zoom-controls button:hover{background:var(--bg-tertiary)}.zoom-label{font-size:11px;font-family:var(--font-mono);color:var(--text-secondary);min-width:44px;text-align:center;font-variant-numeric:tabular-nums}.minimap{position:absolute;top:56px;right:12px;z-index:100;width:160px;height:90px;background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-sm);overflow:hidden;box-shadow:var(--shadow-md);display:none}.minimap.visible{display:block}.minimap canvas{width:100%;height:100%;display:block}.minimap-viewport{position:absolute;border:1.5px solid var(--accent-primary);background:#7c83ff1f;pointer-events:none}.palette-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:3200;display:none;align-items:flex-start;justify-content:center;padding-top:12vh;animation:paletteFade .15s ease-out}.palette-overlay.visible{display:flex}@keyframes paletteFade{0%{opacity:0}to{opacity:1}}.palette{width:min(600px,90vw);background:var(--bg-secondary);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg),0 0 80px #0000004d,0 0 0 1px var(--border-glow);overflow:hidden;animation:paletteSlide .2s ease-out}@keyframes paletteSlide{0%{transform:translateY(-16px) scale(.98);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.palette-input{width:100%;padding:16px 20px;border:none;outline:none;background:transparent;color:var(--text-primary);font-size:15px;font-family:var(--font-sans);border-bottom:1px solid var(--border-color)}.palette-input::placeholder{color:var(--text-tertiary)}.palette-results{max-height:50vh;overflow-y:auto;padding:4px}.palette-item{padding:10px 14px;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;gap:12px;font-size:13px;color:var(--text-primary);transition:background var(--transition-fast)}.palette-item:hover,.palette-item.active{background:var(--accent-light)}.palette-item .palette-hint{margin-left:auto;font-size:10px;font-family:var(--font-mono);color:var(--text-tertiary)}.palette-item .palette-icon{font-size:14px;opacity:.7}.palette-empty{padding:24px;text-align:center;color:var(--text-tertiary);font-size:13px}.sticker-drawer{position:absolute;top:56px;left:16px;z-index:95;width:320px;background:var(--bg-secondary);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:none;flex-direction:column;animation:modalIn .2s ease-out}.sticker-drawer.visible{display:flex}.sticker-drawer-header{padding:10px 14px;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.sticker-cats{display:flex;gap:2px;padding:6px;border-bottom:1px solid var(--border-color)}.sticker-cat-btn{flex:1;padding:5px;background:transparent;border:1px solid transparent;border-radius:4px;font-size:11px;font-family:var(--font-sans);cursor:pointer;color:var(--text-tertiary);transition:all var(--transition-fast)}.sticker-cat-btn:hover{color:var(--text-secondary)}.sticker-cat-btn.active{background:var(--accent-light);color:var(--accent-primary);border-color:var(--accent-primary)}.sticker-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:4px;padding:10px;max-height:260px;overflow-y:auto}.sticker-tile{aspect-ratio:1;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:20px;transition:all var(--transition-fast)}.sticker-tile:hover{border-color:var(--accent-primary);background:var(--accent-light);transform:scale(1.08)}.mesh-pad{position:relative;width:100%;aspect-ratio:16/9;border-radius:var(--radius-md);border:1px solid var(--border-color);overflow:hidden;margin:8px 0;cursor:crosshair}.mesh-handle{position:absolute;width:20px;height:20px;border-radius:50%;transform:translate(-50%,-50%);border:2.5px solid white;box-shadow:0 2px 10px #00000080;cursor:grab;transition:transform .1s;z-index:1}.mesh-handle:hover{transform:translate(-50%,-50%) scale(1.15)}.mesh-handle.dragging{cursor:grabbing;transform:translate(-50%,-50%) scale(1.25)}.scenes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.scene-tile{aspect-ratio:4/3;background:var(--bg-tertiary);border:1.5px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;padding:6px;transition:all var(--transition-fast);display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:10px;color:var(--text-tertiary);gap:4px}.scene-tile:hover{border-color:#ffffff1f;color:var(--text-secondary)}.scene-tile.active{border-color:var(--accent-primary);background:var(--accent-light);color:var(--accent-primary);box-shadow:0 0 12px var(--accent-light)}.scene-tile .scene-thumb{font-size:20px}.status-pill{position:fixed;top:62px;left:50%;transform:translate(-50%);padding:5px 14px;background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-pill);font-size:11px;font-family:var(--font-mono);color:var(--text-secondary);z-index:80;opacity:0;pointer-events:none;transition:opacity .2s}.status-pill.visible{opacity:1}.layout-picker-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:4px}.layout-btn{padding:5px;background:var(--bg-tertiary);border:1.5px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);aspect-ratio:1;display:flex;align-items:center;justify-content:center}.layout-btn:hover{border-color:#ffffff1f}.layout-btn.active{border-color:var(--accent-primary);background:var(--accent-light)}.lp{width:100%;height:100%;display:flex;gap:2px;padding:4px;box-sizing:border-box}.lp-img{background:var(--text-tertiary);border-radius:1px;flex:1;min-width:0;min-height:0;opacity:.5}.lp-col{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.lp-row-inner{display:flex;gap:2px;flex:1;min-height:0}.alignment-buttons{display:flex;gap:3px}.align-btn{flex:1;padding:7px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:12px;font-weight:500;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast)}.align-btn:hover{border-color:#ffffff1a;color:var(--text-primary)}.align-btn.active{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.gradient-editor-block{margin:10px 0}.grad-strip{position:relative;width:100%;height:28px;border-radius:var(--radius-sm);border:1px solid var(--border-color);cursor:crosshair;margin:8px 0 16px;box-shadow:inset 0 1px 3px #0003}.grad-stop-marker{position:absolute;top:100%;transform:translate(-50%,-2px);width:14px;height:14px;border-radius:50%;border:2px solid var(--bg-secondary);box-shadow:0 0 0 1px var(--border-color),0 2px 4px #0006;cursor:grab;transition:all var(--transition-fast)}.grad-stop-marker.selected{box-shadow:0 0 0 2px var(--accent-primary),0 2px 6px #0006;transform:translate(-50%,-2px) scale(1.2)}.grad-stop-marker:active{cursor:grabbing}.font-upload-row{display:flex;gap:8px;align-items:center;margin:8px 0}.custom-font-pill{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-pill);font-size:11px;margin:2px}.custom-font-pill button{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:0 2px;font-size:13px}.palette-swatches{display:flex;gap:5px;flex-wrap:wrap;margin:8px 0}.palette-swatch{width:36px;height:36px;border-radius:var(--radius-sm);cursor:pointer;border:1px solid rgba(0,0,0,.15);position:relative;transition:all var(--transition-fast);box-shadow:0 2px 6px #0003}.palette-swatch:hover{transform:scale(1.12);box-shadow:0 4px 12px #0000004d}.palette-swatch-label{position:absolute;bottom:-15px;left:50%;transform:translate(-50%);font-size:9px;font-family:var(--font-mono);color:var(--text-secondary);white-space:nowrap;opacity:0;transition:opacity var(--transition-fast)}.palette-swatch:hover .palette-swatch-label{opacity:1}.palette-apply-row{display:flex;flex-wrap:wrap;gap:5px;margin-top:20px}.crop-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:50}.crop-region{position:absolute;pointer-events:auto;cursor:move;box-shadow:0 0 0 9999px #0009;border:1px dashed rgba(255,255,255,.85)}.crop-handle{position:absolute;width:10px;height:10px;background:var(--accent-primary);border:2px solid #fff;border-radius:2px;pointer-events:auto}.crop-handle.nw{top:-6px;left:-6px;cursor:nwse-resize}.crop-handle.ne{top:-6px;right:-6px;cursor:nesw-resize}.crop-handle.sw{bottom:-6px;left:-6px;cursor:nesw-resize}.crop-handle.se{bottom:-6px;right:-6px;cursor:nwse-resize}.crop-toolbar{position:absolute;bottom:-50px;left:50%;transform:translate(-50%);display:flex;gap:6px;padding:6px 10px;background:var(--bg-secondary);border:1px solid var(--glass-border);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);pointer-events:auto;align-items:center}.crop-toolbar select,.crop-toolbar input[type=range]{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:4px;padding:4px 8px;font-size:11px;font-family:var(--font-sans)}.ai-action-grid{display:grid;grid-template-columns:1fr 1fr;gap:5px;margin:8px 0}.ai-action-grid .btn{padding:7px 5px;font-size:11px}.ocr-result{max-height:170px;overflow:auto;padding:8px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:12px;font-family:var(--font-mono);white-space:pre-wrap;margin:8px 0}.account-pill{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-pill);font-size:11px}.auth-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:2000;display:none;align-items:center;justify-content:center}.auth-modal-overlay.visible{display:flex}.auth-modal{background:var(--bg-secondary);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:24px;min-width:320px;max-width:400px;box-shadow:var(--shadow-lg),0 0 80px #0000004d;animation:modalIn .25s ease-out}.auth-modal h3{margin-bottom:12px;font-weight:600;font-size:16px;letter-spacing:-.2px}.auth-modal .control-input{margin-bottom:8px;width:100%}.auth-modal-actions{display:flex;gap:8px;margin-top:12px}.auth-modal-actions .btn{flex:1}.ai-progress{display:flex;align-items:center;gap:8px;padding:7px;background:var(--bg-tertiary);border-radius:var(--radius-sm);font-size:11px;font-family:var(--font-mono);margin:6px 0}.ai-progress-bar{flex:1;height:4px;background:var(--border-color);border-radius:2px;overflow:hidden;position:relative}.ai-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary));transition:width .2s;border-radius:2px}.ai-progress.indeterminate .ai-progress-fill{width:40%!important;background:linear-gradient(90deg,transparent,var(--accent-primary),var(--accent-secondary),transparent);animation:ai-progress-slide 1.4s ease-in-out infinite}@keyframes ai-progress-slide{0%{transform:translate(-120%)}to{transform:translate(280%)}}#preview-canvas,.canvas-viewport,.mesh-handle,.grad-strip,.grad-stop-marker,.crop-region,.crop-handle{touch-action:none}.annotation-toolbar,.canvas-viewport,.zoom-controls,.header-actions{-webkit-touch-callout:none;touch-action:manipulation}.canvas-viewport{touch-action:none}#sidebar-toggle-btn{display:none}.sidebar-backdrop{position:fixed;top:52px;right:0;bottom:0;left:0;background:#0000008c;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:1050;opacity:0;pointer-events:none;transition:opacity var(--transition-smooth)}.sidebar-backdrop.show{opacity:1;pointer-events:auto}.header{padding-left:max(20px,env(safe-area-inset-left));padding-right:max(20px,env(safe-area-inset-right))}.history-timeline{padding-bottom:env(safe-area-inset-bottom)}@media (max-width: 1024px){.sidebar{width:320px}.main-content{padding-left:16px;padding-right:16px}.layers-panel{transform:translate(calc(100% - 36px))}.main-content{margin-right:36px}}@media (max-width: 767px){.sidebar{position:fixed;top:52px;left:0;bottom:0;width:min(85vw,360px);z-index:1100;transform:translate(-100%);transition:transform var(--transition-smooth);margin-top:0;padding-bottom:env(safe-area-inset-bottom)}.sidebar.open{transform:translate(0);box-shadow:var(--shadow-lg)}.main-content{margin-right:0;padding:8px 12px 48px}.layers-panel{display:none}#preview-canvas{max-height:calc(100vh - 180px)}#sidebar-toggle-btn{display:inline-flex}.header{padding-left:max(12px,env(safe-area-inset-left));padding-right:max(12px,env(safe-area-inset-right))}.logo{font-size:15px;gap:8px}.annotation-toolbar{flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;position:sticky;top:0;z-index:80;-webkit-overflow-scrolling:touch}.annotation-toolbar>*{flex-shrink:0}.upload-zone{min-height:50vh}}@media (max-width: 1024px){.upload-zone{width:100%;max-width:600px;height:auto;aspect-ratio:3 / 2;min-height:240px}}@media (pointer: coarse){.btn{min-height:44px}.ann-tool-btn,.tab-btn{min-height:40px}.zoom-controls button{min-width:40px;min-height:40px}input[type=range]::-webkit-slider-thumb{width:22px;height:22px}input[type=range]::-moz-range-thumb{width:22px;height:22px}.switch{width:48px;height:28px}.slider:before{height:20px;width:20px}input:checked+.slider:before{transform:translate(22px)}.mesh-handle{width:28px;height:28px}.layer-action-btn{width:30px;height:30px}}.app-mode-toggle{display:flex;gap:4px;padding:4px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md)}.app-mode-btn{flex:1;padding:7px 10px;border:none;cursor:pointer;background:transparent;color:var(--text-secondary);font-family:inherit;font-size:13px;font-weight:500;border-radius:var(--radius-sm);transition:all .15s ease}.app-mode-btn:hover{color:var(--text-primary)}.app-mode-btn.active{background:var(--accent-primary);color:#fff;box-shadow:var(--shadow-sm)}.set-filmstrip{display:flex;gap:8px;overflow-x:auto;padding:4px 2px 10px;margin-bottom:8px}.set-panel-chip{flex:0 0 auto;cursor:pointer;position:relative;border-radius:var(--radius-sm);transition:transform .12s ease}.set-panel-chip:hover{transform:translateY(-2px)}.set-panel-thumb{width:46px;height:72px;border-radius:var(--radius-sm);border:2px solid var(--border-color);overflow:hidden;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);font-size:20px}.set-panel-chip.active .set-panel-thumb{border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--accent-glow)}.set-panel-thumb img{width:100%;height:100%;object-fit:cover}.set-panel-num{position:absolute;top:-6px;right:-6px;width:18px;height:18px;border-radius:50%;background:var(--accent-primary);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center}.batch-drop{border:2px dashed var(--border-color);border-radius:var(--radius-md);padding:22px 12px;text-align:center;cursor:pointer;color:var(--text-secondary);font-size:13px;transition:all .15s ease}.batch-drop:hover,.batch-drop.dragover{border-color:var(--accent-primary);color:var(--text-primary);background:var(--accent-light)}.batch-row{display:flex;align-items:center;gap:10px;padding:6px;border-radius:var(--radius-sm);background:var(--bg-tertiary);margin-bottom:6px}.batch-thumb{width:36px;height:36px;border-radius:var(--radius-sm);overflow:hidden;background:var(--bg-primary);flex:0 0 auto}.batch-thumb img{width:100%;height:100%;object-fit:cover}.batch-name{flex:1;font-size:12px;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.batch-del{border:none;background:transparent;cursor:pointer;color:var(--text-tertiary);font-size:14px;padding:4px 6px;border-radius:var(--radius-sm)}.batch-del:hover{color:var(--error);background:var(--bg-primary)}.eraser-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#0009;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:20px}.eraser-modal{background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:18px;box-shadow:var(--shadow-lg);max-width:92vw}.eraser-head{display:flex;flex-direction:column;gap:2px;margin-bottom:12px}.eraser-head strong{font-size:15px;color:var(--text-primary)}.eraser-canvas-wrap{display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border-radius:var(--radius-sm);padding:8px}.eraser-canvas-wrap canvas{max-width:100%;cursor:crosshair;border-radius:4px;touch-action:none}.eraser-controls{display:flex;align-items:center;gap:10px;margin-top:12px}.eraser-controls .btn{padding:7px 12px}
