:root{--bg-void:#050508;--bg-base:#0a0a10;--bg-surface:#111118;--bg-raised:#18182400;--bg-elevated:#1e1e2c;--bg-input:#0d0d14;--bg-hover:#1a1a28;--glass-bg:#0e0e16bf;--glass-border:#ffffff0f;--glass-blur:blur(24px) saturate(1.6);--accent-50:#eef2ff;--accent-400:#818cf8;--accent-500:#6366f1;--accent-600:#4f46e5;--accent-700:#4338ca;--accent-glow:#6366f133;--accent-gradient:linear-gradient(135deg, #6366f1 0%, #8b5cf6 50%, #a78bfa 100%);--accent-gradient-vivid:linear-gradient(135deg, #818cf8 0%, #a78bfa 50%, #c4b5fd 100%);--text-primary:#f1f1f6;--text-secondary:#8e8ea8;--text-tertiary:#55556a;--text-accent:var(--accent-400);--border-subtle:#ffffff0a;--border-default:#ffffff12;--border-strong:#ffffff1f;--border-accent:#6366f166;--sp-1:4px;--sp-2:8px;--sp-3:12px;--sp-4:16px;--sp-5:20px;--sp-6:24px;--sp-8:32px;--r-xs:6px;--r-sm:8px;--r-md:12px;--r-lg:16px;--r-xl:20px;--r-2xl:24px;--r-full:9999px;--shadow-sm:0 1px 3px #00000080, 0 1px 2px #0006;--shadow-md:0 4px 12px #00000080, 0 2px 4px #0006;--shadow-lg:0 8px 32px #0009, 0 4px 8px #0006;--shadow-xl:0 16px 48px #000000b3, 0 8px 16px #00000080;--shadow-glow:0 0 24px var(--accent-glow), 0 0 64px #6366f114;--shadow-canvas:0 20px 80px #000c, 0 0 0 1px #ffffff0a;--ease:cubic-bezier(.16, 1, .3, 1);--t-fast:.12s;--t-med:.2s;--t-slow:.35s}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{background:var(--bg-void);color:var(--text-primary);min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;overflow:hidden}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}input,textarea,select{color:inherit;background:0 0;border:none;outline:none;font-family:inherit}img{max-width:100%;display:block}#app{flex-direction:column;height:100vh;display:flex;overflow:hidden}.nav{height:52px;padding:0 var(--sp-5);background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border-bottom:1px solid var(--glass-border);z-index:100;flex-shrink:0;justify-content:space-between;align-items:center;display:flex;position:relative}.nav:before{content:"";background:var(--accent-gradient);opacity:.7;height:2px;position:absolute;top:0;left:0;right:0}.nav-brand{align-items:center;gap:var(--sp-2);display:flex}.nav-logo-img{border-radius:var(--r-sm);object-fit:contain;width:28px;height:28px;box-shadow:0 2px 8px var(--accent-glow)}.nav-title{letter-spacing:-.4px;font-size:15px;font-weight:700}.nav-title span{background:var(--accent-gradient-vivid);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.nav-actions{gap:var(--sp-2);display:flex}.workspace{flex:1;grid-template-columns:280px 1fr;gap:0;display:grid;overflow:hidden}@media (width<=860px){.workspace{grid-template-columns:1fr}.sidebar{max-height:40vh}}.sidebar{background:var(--bg-base);border-right:1px solid var(--border-subtle);flex-direction:column;display:flex;position:relative;overflow:hidden auto}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-track{background:0 0}.sidebar::-webkit-scrollbar-thumb{background:var(--border-default);border-radius:var(--r-full)}.sidebar::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}.panel{border-bottom:1px solid var(--border-subtle)}.panel-header{padding:var(--sp-3) var(--sp-4);text-transform:uppercase;letter-spacing:.8px;color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;transition:color var(--t-fast), background var(--t-fast);align-items:center;gap:6px;font-size:11px;font-weight:600;display:flex}.panel-header:hover{color:var(--text-primary);background:#ffffff05}.panel-header .icon{font-size:13px}.panel-header .chevron{transition:transform var(--t-med) var(--ease);color:var(--text-tertiary);margin-left:auto;font-size:10px}.panel-header.collapsed .chevron{transform:rotate(-90deg)}.panel-body{padding:var(--sp-2) var(--sp-4) var(--sp-4);gap:var(--sp-3);animation:panelIn var(--t-slow) var(--ease);flex-direction:column;display:flex}.panel-body.collapsed{display:none}@keyframes panelIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.form-group{gap:var(--sp-1);flex-direction:column;display:flex}.form-label{color:var(--text-tertiary);letter-spacing:.6px;text-transform:uppercase;font-size:10px;font-weight:600}.form-input{background:var(--bg-input);border:1px solid var(--border-default);border-radius:var(--r-sm);color:var(--text-primary);transition:border-color var(--t-fast), box-shadow var(--t-fast), background var(--t-fast);padding:8px 10px;font-size:13px}.form-input:hover{border-color:var(--border-strong)}.form-input:focus{border-color:var(--accent-500);box-shadow:0 0 0 3px var(--accent-glow);background:var(--bg-surface)}.form-input::placeholder{color:var(--text-tertiary)}.form-select{background:var(--bg-input);border:1px solid var(--border-default);border-radius:var(--r-sm);color:var(--text-primary);cursor:pointer;transition:border-color var(--t-fast), box-shadow var(--t-fast);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%238e8ea8' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding:8px 28px 8px 10px;font-size:12px;font-weight:500}.form-select:hover{border-color:var(--border-strong)}.form-select:focus{border-color:var(--accent-500);box-shadow:0 0 0 3px var(--accent-glow);outline:none}.form-select option{background:var(--bg-surface);color:var(--text-primary);padding:4px 8px}.hidden{display:none!important}.slide-badge{letter-spacing:.8px;text-transform:uppercase;color:var(--accent-400);border-radius:var(--r-full);text-align:center;background:#6366f114;border:1px solid #6366f126;padding:5px 12px;font-size:10px;font-weight:700}.color-picker-group{align-items:center;gap:var(--sp-2);display:flex}.color-swatch{border-radius:var(--r-sm);border:2px solid var(--border-default);cursor:pointer;width:32px;height:32px;transition:border-color var(--t-fast), transform var(--t-fast);box-shadow:var(--shadow-sm);flex-shrink:0;overflow:hidden}.color-swatch:hover{border-color:var(--border-strong);transform:scale(1.05)}.color-swatch input[type=color]{cursor:pointer;border:none;width:44px;height:44px;margin:-6px;padding:0}.gradient-presets{flex-wrap:wrap;gap:6px;display:flex}.gradient-preset{border-radius:var(--r-sm);cursor:pointer;width:32px;height:32px;transition:all var(--t-fast) var(--ease);box-shadow:var(--shadow-sm);border:2px solid #0000;position:relative}.gradient-preset:hover{box-shadow:var(--shadow-md);z-index:1;transform:scale(1.15)}.gradient-preset.active{box-shadow:0 0 0 2px var(--accent-glow), var(--shadow-md);border-color:#fff;transform:scale(1.1)}.device-grid{grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:4px;display:grid}.device-btn{background:var(--bg-input);border:1px solid var(--border-default);border-radius:var(--r-sm);text-align:center;color:var(--text-secondary);transition:all var(--t-fast) var(--ease);letter-spacing:.2px;flex-direction:column;align-items:center;gap:1px;padding:6px 2px;font-size:9px;font-weight:600;display:flex}.device-btn .device-icon{font-size:14px;line-height:1}.device-btn:hover{background:var(--bg-hover);border-color:var(--border-strong);color:var(--text-primary);transform:translateY(-1px)}.device-btn.active{background:var(--accent-gradient);color:#fff;box-shadow:var(--shadow-glow);border-color:#0000;transform:translateY(-1px)}.template-grid{grid-template-columns:repeat(3,1fr);gap:6px;display:grid}.template-card{background:var(--bg-input);border:1px solid var(--border-default);border-radius:var(--r-md);text-align:center;transition:all var(--t-med) var(--ease);flex-direction:column;align-items:center;gap:4px;padding:6px 4px;display:flex;position:relative;overflow:hidden}.template-card:before{content:"";background:var(--accent-gradient);opacity:0;transition:opacity var(--t-med);border-radius:inherit;position:absolute;inset:0}.template-card:hover{border-color:var(--border-accent);box-shadow:var(--shadow-lg), var(--shadow-glow);transform:translateY(-3px)}.template-card:hover:before{opacity:.08}.template-preview{border-radius:var(--r-xs);width:100%;height:28px;display:block;position:relative}.template-icon{width:24px;height:24px;transition:transform var(--t-fast);color:var(--accent-400);justify-content:center;align-items:center;display:flex;position:relative}.template-icon svg{width:100%;height:100%}.template-card:hover .template-icon{color:var(--accent-50);transform:scale(1.15)}.template-name{color:var(--text-tertiary);letter-spacing:.3px;text-transform:uppercase;transition:color var(--t-fast);font-size:8px;font-weight:700;position:relative}.template-card:hover .template-name{color:var(--text-primary)}.template-cat-tab{flex:0!important;padding:4px 8px!important;font-size:10px!important}.panel-count{color:var(--accent-400);border-radius:var(--r-full);letter-spacing:0;text-transform:none;background:#6366f11f;margin-left:4px;padding:1px 6px;font-size:9px;font-weight:700}.tab-bar{background:var(--bg-input);border-radius:var(--r-sm);border:1px solid var(--border-subtle);gap:2px;padding:3px;display:flex}.tab-btn{border-radius:var(--r-xs);color:var(--text-tertiary);text-align:center;transition:all var(--t-fast) var(--ease);letter-spacing:.2px;flex:1;padding:6px 8px;font-size:11px;font-weight:600}.tab-btn:hover{color:var(--text-secondary);background:#ffffff08}.tab-btn.active{background:var(--bg-elevated);color:var(--text-primary);box-shadow:var(--shadow-sm)}.toggle-row{justify-content:space-between;align-items:center;display:flex}.toggle-label{color:var(--text-secondary);font-size:13px;font-weight:500}.toggle{background:var(--bg-elevated);border-radius:var(--r-full);cursor:pointer;width:38px;height:20px;transition:background var(--t-med) var(--ease);border:1px solid var(--border-default);position:relative}.toggle.on{background:var(--accent-500);border-color:var(--accent-600);box-shadow:0 0 12px var(--accent-glow)}.toggle:after{content:"";background:var(--text-secondary);width:14px;height:14px;transition:transform var(--t-med) var(--ease), background var(--t-fast);box-shadow:var(--shadow-sm);border-radius:50%;position:absolute;top:2px;left:2px}.toggle.on:after{background:#fff;transform:translate(18px)}.range-row{align-items:center;gap:var(--sp-2);display:flex}.range-row input[type=range]{appearance:none;background:var(--bg-elevated);border-radius:var(--r-full);outline:none;flex:1;height:4px}.range-row input[type=range]::-webkit-slider-thumb{appearance:none;background:var(--accent-gradient-vivid);cursor:pointer;width:14px;height:14px;box-shadow:0 0 8px var(--accent-glow), var(--shadow-sm);transition:transform var(--t-fast) var(--ease), box-shadow var(--t-fast);border:2px solid #fff;border-radius:50%}.range-row input[type=range]::-webkit-slider-thumb:hover{box-shadow:0 0 14px var(--accent-glow), var(--shadow-md);transform:scale(1.2)}.range-row input[type=range]:active::-webkit-slider-thumb{transform:scale(1.1)}.range-value{color:var(--text-tertiary);text-align:right;font-variant-numeric:tabular-nums;min-width:28px;font-size:10px;font-weight:700}.upload-area{border:1.5px dashed var(--border-default);border-radius:var(--r-md);padding:14px var(--sp-3);text-align:center;cursor:pointer;transition:all var(--t-med) var(--ease);position:relative;overflow:hidden}.upload-area:before{content:"";background:var(--accent-gradient);opacity:0;transition:opacity var(--t-med);position:absolute;inset:0}.upload-area:hover{border-color:var(--accent-500);transform:scale(1.01)}.upload-area:hover:before{opacity:.04}.upload-area.drag-over{border-color:var(--accent-400);box-shadow:var(--shadow-glow);transform:scale(1.02)}.upload-area.drag-over:before{opacity:.08}.upload-icon{color:var(--accent-400);justify-content:center;align-items:center;margin-bottom:2px;display:flex;position:relative}.upload-text{color:var(--text-secondary);font-size:11px;line-height:1.5;position:relative}.upload-text strong{color:var(--accent-400);font-weight:600}.canvas-area{background:var(--bg-void);flex-direction:column;display:flex;position:relative;overflow:hidden}.canvas-area:before{content:"";pointer-events:none;z-index:0;background-image:radial-gradient(circle at 1px 1px,#ffffff08 1px,#0000 0);background-size:24px 24px;position:absolute;inset:0}.canvas-toolbar{align-items:center;gap:var(--sp-2);padding:6px var(--sp-4);background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border-bottom:1px solid var(--glass-border);z-index:10;flex-shrink:0;display:flex;position:relative}.canvas-toolbar .separator{background:var(--border-default);width:1px;height:18px;margin:0 var(--sp-1)}.toolbar-btn{border-radius:var(--r-xs);color:var(--text-secondary);transition:all var(--t-fast) var(--ease);letter-spacing:.1px;white-space:nowrap;align-items:center;gap:4px;padding:6px 11px;font-size:11px;font-weight:600;display:inline-flex}.toolbar-btn:hover{color:var(--text-primary);background:#ffffff0d}.toolbar-btn.primary{background:var(--accent-gradient);color:#fff;box-shadow:var(--shadow-sm)}.toolbar-btn.primary:hover{box-shadow:var(--shadow-glow), var(--shadow-md);filter:brightness(1.1);transform:translateY(-1px)}.toolbar-btn.primary:active{filter:brightness(.95);transform:translateY(0)}.toolbar-btn.danger{color:#f87171}.toolbar-btn.danger:hover{background:#f8717114}.toolbar-info{color:var(--text-tertiary);font-variant-numeric:tabular-nums;letter-spacing:.5px;margin-left:auto;font-size:10px;font-weight:600}.ic{flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;display:inline-flex}.ic svg{width:100%;height:100%;transition:transform var(--t-fast) var(--ease)}.ic-label{letter-spacing:.2px;font-size:11px;font-weight:600}.toolbar-btn:hover .ic svg{transform:scale(1.1)}.toolbar-btn.primary .ic svg{stroke:#fff}.panel-header .ic{opacity:.9;width:14px;height:14px}.panel-header .ic svg{stroke:var(--accent-400)}.upload-icon .ic,.upload-icon svg{width:32px;height:32px;stroke:var(--accent-400);opacity:.7}.form-divider{background:var(--border-subtle);height:1px;margin:var(--sp-3) 0}.preview-container{z-index:1;flex:1;justify-content:center;align-items:center;min-height:0;display:flex;position:relative;overflow:hidden}.preview-container.drag-hover{outline:2px dashed var(--accent-400);outline-offset:-4px}.preview-canvas-wrapper{justify-content:center;align-items:center;display:flex;position:relative}.preview-canvas-wrapper:before{content:"";background:radial-gradient(ellipse at center, var(--accent-glow), transparent 70%);opacity:.4;pointer-events:none;transition:opacity var(--t-slow);z-index:-1;position:absolute;inset:-20%}.preview-canvas-wrapper:hover:before{opacity:.6}#preview-canvas{border-radius:var(--r-lg);box-shadow:var(--shadow-canvas);cursor:grab;transition:box-shadow var(--t-med), transform var(--t-med) var(--ease);max-height:calc(100vh - 200px)}#preview-canvas:hover{box-shadow:var(--shadow-canvas), var(--shadow-glow)}#preview-canvas:active{cursor:grabbing;transform:scale(.995)}.canvas-cursor-hint{bottom:var(--sp-4);color:var(--text-tertiary);border-radius:var(--r-full);-webkit-backdrop-filter:blur(12px);pointer-events:none;opacity:1;transition:opacity var(--t-med);letter-spacing:.3px;border:1px solid var(--glass-border);z-index:10;background:#000000b3;padding:4px 14px;font-size:10px;font-weight:600;position:absolute;left:50%;transform:translate(-50%)}.canvas-cursor-hint.hidden{opacity:0}.preview-empty{justify-content:center;align-items:center;gap:var(--sp-4);padding:var(--sp-8);color:var(--text-tertiary);text-align:center;flex-direction:column;display:flex;position:absolute}.preview-empty .icon{opacity:.15;color:var(--accent-400);animation:3s ease-in-out infinite emptyPulse}.preview-empty .icon svg{width:48px;height:48px}@keyframes emptyPulse{0%,to{opacity:.15;transform:scale(1)}50%{opacity:.25;transform:scale(1.08)}}.preview-empty h3{color:var(--text-secondary);letter-spacing:-.3px;font-size:16px;font-weight:700}.preview-empty p{max-width:260px;font-size:12px;line-height:1.6}.filmstrip-container{align-items:flex-end;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);background:var(--bg-base);border-top:1px solid var(--border-subtle);z-index:10;flex-shrink:0;min-height:60px;display:flex;overflow:auto hidden}.filmstrip-container::-webkit-scrollbar{height:3px}.filmstrip-container::-webkit-scrollbar-track{background:0 0}.filmstrip-container::-webkit-scrollbar-thumb{background:var(--border-default);border-radius:var(--r-full)}.filmstrip{gap:var(--sp-3);flex:1;align-items:flex-end;min-width:0;display:flex}.filmstrip-placeholder{color:var(--text-tertiary);white-space:nowrap;letter-spacing:.2px;padding:4px 0;font-size:11px;font-weight:500}.filmstrip-thumb{border-radius:var(--r-md);border:2px solid var(--border-default);cursor:pointer;transition:all var(--t-med) var(--ease);background:var(--bg-surface);flex-direction:column;flex-shrink:0;display:flex;position:relative;overflow:hidden}.filmstrip-thumb canvas{pointer-events:none;display:block}.filmstrip-thumb:hover{border-color:var(--border-strong);box-shadow:var(--shadow-lg);transform:translateY(-4px)scale(1.02)}.filmstrip-thumb.active{border-color:var(--accent-400);box-shadow:0 0 0 3px var(--accent-glow), var(--shadow-lg);transform:translateY(-3px)}.filmstrip-badge{color:#fff;border-radius:var(--r-xs);-webkit-backdrop-filter:blur(6px);letter-spacing:-.2px;background:#000000bf;place-items:center;width:18px;height:18px;font-size:9px;font-weight:800;display:grid;position:absolute;top:4px;left:4px}.filmstrip-label{color:var(--text-tertiary);text-align:center;text-overflow:ellipsis;white-space:nowrap;letter-spacing:.2px;background:var(--bg-surface);max-width:100%;padding:3px 4px 2px;font-size:9px;font-weight:600;overflow:hidden}.filmstrip-thumb.active .filmstrip-label{color:var(--accent-400)}.filmstrip-add{border-radius:var(--r-md);border:1.5px dashed var(--border-default);width:48px;height:88px;color:var(--text-tertiary);transition:all var(--t-med) var(--ease);flex-shrink:0;align-self:flex-start;place-items:center;display:grid}.filmstrip-add svg{width:20px;height:20px}.filmstrip-add:hover{border-color:var(--accent-400);color:var(--accent-400);background:#6366f10d;transform:scale(1.05)}.modal-overlay{-webkit-backdrop-filter:blur(12px);z-index:1000;opacity:0;pointer-events:none;transition:opacity var(--t-med) var(--ease);background:#000c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-overlay.visible{opacity:1;pointer-events:auto}.modal{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--r-xl);width:90%;max-width:400px;padding:var(--sp-6);box-shadow:var(--shadow-xl);transition:transform var(--t-slow) var(--ease);transform:translateY(20px)scale(.96)}.modal-overlay.visible .modal{transform:translateY(0)scale(1)}.modal h2{margin-bottom:var(--sp-3);letter-spacing:-.3px;font-size:17px;font-weight:700}.modal-footer{justify-content:flex-end;gap:var(--sp-2);margin-top:var(--sp-5);display:flex}.btn{border-radius:var(--r-sm);transition:all var(--t-fast) var(--ease);letter-spacing:.1px;align-items:center;gap:6px;padding:8px 16px;font-size:12px;font-weight:600;display:inline-flex}.btn-primary{background:var(--accent-gradient);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover{box-shadow:var(--shadow-glow), var(--shadow-md);transform:translateY(-1px)}.btn-secondary{background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border-default)}.btn-secondary:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-strong)}.progress-bar{background:var(--bg-input);border-radius:var(--r-full);width:100%;height:3px;margin-top:var(--sp-3);overflow:hidden}.progress-fill{background:var(--accent-gradient);border-radius:var(--r-full);height:100%;transition:width var(--t-med) var(--ease)}.toast-container{bottom:var(--sp-6);right:var(--sp-6);z-index:2000;pointer-events:none;flex-direction:column-reverse;gap:10px;display:flex;position:fixed}.toast{pointer-events:auto;-webkit-backdrop-filter:blur(24px)saturate(1.8);transform-origin:100%;background:#12121cd9;border:1px solid #ffffff14;border-radius:14px;min-width:260px;max-width:380px;padding:0;animation:.5s cubic-bezier(.34,1.56,.64,1) forwards toastSlideIn;position:relative;overflow:hidden;box-shadow:0 8px 32px #00000080,0 2px 8px #0000004d,inset 0 1px #ffffff0a}.toast-inner{align-items:center;gap:12px;padding:12px 14px 12px 12px;display:flex}.toast-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex;position:relative}.toast-icon svg{z-index:1;width:18px;height:18px;position:relative}.toast.success .toast-icon{background:#34d3991f;box-shadow:0 0 12px #34d39926}.toast.error .toast-icon{background:#f871711f;box-shadow:0 0 12px #f8717126}.toast.info .toast-icon{background:#818cf81f;box-shadow:0 0 12px #818cf826}.toast-text{color:#ffffffe0;letter-spacing:.1px;flex:1;font-size:12.5px;font-weight:500;line-height:1.4}.toast-title{text-transform:uppercase;letter-spacing:.6px;margin-bottom:2px;font-size:11px;font-weight:700}.toast.success .toast-title{color:#34d399}.toast.error .toast-title{color:#f87171}.toast.info .toast-title{color:#818cf8}.toast-close{color:#ffffff4d;cursor:pointer;background:0 0;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;padding:0;transition:all .15s;display:flex}.toast-close:hover{color:#ffffffb3;background:#ffffff0f}.toast-close svg{width:12px;height:12px}.toast-progress{border-radius:0 0 14px 14px;height:2px;animation:linear forwards toastProgress;position:absolute;bottom:0;left:0}.toast.success .toast-progress{background:linear-gradient(90deg,#34d399,#6ee7b7);box-shadow:0 0 8px #34d39966}.toast.error .toast-progress{background:linear-gradient(90deg,#f87171,#fca5a5);box-shadow:0 0 8px #f8717166}.toast.info .toast-progress{background:linear-gradient(90deg,#818cf8,#a5b4fc);box-shadow:0 0 8px #818cf866}.toast.success{border-color:#34d39926;box-shadow:0 8px 32px #00000080,0 0 20px #34d3990f,inset 0 1px #34d3990f}.toast.error{border-color:#f8717126;box-shadow:0 8px 32px #00000080,0 0 20px #f871710f,inset 0 1px #f871710f}.toast.info{border-color:#818cf826;box-shadow:0 8px 32px #00000080,0 0 20px #818cf80f,inset 0 1px #818cf80f}.toast.toast-exit{animation:.35s cubic-bezier(.55,0,1,.45) forwards toastSlideOut}@keyframes toastSlideIn{0%{opacity:0;transform:translate(calc(100% + 24px))scale(.9)}to{opacity:1;transform:translate(0)scale(1)}}@keyframes toastSlideOut{0%{opacity:1;transform:translate(0)scale(1)}to{opacity:0;transform:translate(calc(100% + 24px))scale(.9)}}@keyframes toastProgress{0%{width:100%}to{width:0%}}.paywall-overlay{z-index:1000;opacity:0;pointer-events:none;transition:opacity var(--t-med) var(--ease);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.paywall-overlay.visible{opacity:1;pointer-events:auto}.paywall-backdrop{-webkit-backdrop-filter:blur(12px);background:#050508d9;position:absolute;inset:0}.auth-modal-card,.upgrade-modal-card{background:var(--bg-surface);border:1px solid var(--glass-border);border-radius:var(--r-2xl);width:100%;max-width:440px;padding:var(--sp-6) var(--sp-8);box-shadow:var(--shadow-xl), 0 0 0 1px #ffffff05;transition:transform var(--t-slow) var(--ease);position:relative;transform:translateY(20px)scale(.95)}.paywall-overlay.visible .auth-modal-card,.paywall-overlay.visible .upgrade-modal-card{transform:translateY(0)scale(1)}.upgrade-modal-card{max-width:500px;padding:var(--sp-8)}.upgrade-modal-card:before{content:"";background:var(--accent-gradient);opacity:.03;border-radius:inherit;pointer-events:none;position:absolute;inset:0}.paywall-close{top:var(--sp-4);right:var(--sp-4);width:32px;height:32px;color:var(--text-tertiary);transition:all var(--t-fast);cursor:pointer;background:#ffffff08;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute}.paywall-close:hover{color:var(--text-primary);background:#ffffff1a}.auth-header{text-align:center;margin-bottom:var(--sp-6)}.auth-logo-img{border-radius:var(--r-md);object-fit:contain;width:56px;height:56px;margin:0 auto var(--sp-4);box-shadow:0 4px 16px var(--accent-glow);display:block}.auth-header h2{letter-spacing:-.5px;margin-bottom:6px;font-size:22px;font-weight:700}.auth-header p{color:var(--text-secondary);font-size:14px}.auth-feature-context{border-radius:var(--r-md);margin-bottom:var(--sp-6);color:var(--accent-50);background:#6366f11a;border:1px solid #6366f133;align-items:center;gap:12px;padding:12px 16px;font-size:13px;display:flex}.auth-buttons{flex-direction:column;gap:12px;display:flex}.auth-btn{border-radius:var(--r-md);width:100%;height:44px;transition:all var(--t-fast);cursor:pointer;justify-content:center;align-items:center;gap:12px;font-size:14px;font-weight:600;display:flex}.auth-btn-google,.auth-btn-apple{background:var(--bg-input);border:1px solid var(--border-strong);color:var(--text-primary)}.auth-btn-google:hover,.auth-btn-apple:hover{background:var(--bg-elevated);border-color:#fff3}.auth-divider{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:1px;align-items:center;margin:24px 0;font-size:12px;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border-default);flex:1;height:1px}.auth-divider span{padding:0 16px}.auth-form{flex-direction:column;gap:12px;display:flex}.auth-input{background:var(--bg-input);border:1px solid var(--border-default);border-radius:var(--r-md);width:100%;height:44px;color:var(--text-primary);padding:0 16px;font-size:14px}.auth-input:focus{border-color:var(--accent-500);box-shadow:0 0 0 3px var(--accent-glow)}.auth-btn-email{color:#000;background:#fff}.auth-btn-email:hover{background:#f0f0f0}.auth-link{color:var(--text-secondary);text-align:center;width:100%;margin-top:16px;font-size:13px}.auth-link strong{color:var(--text-primary)}.upgrade-header{text-align:center;margin-bottom:var(--sp-6)}.upgrade-badge-big{border-radius:var(--r-full);background:var(--accent-gradient);color:#fff;letter-spacing:1px;box-shadow:var(--shadow-glow);margin-bottom:16px;padding:4px 12px;font-size:12px;font-weight:800;display:inline-block}.upgrade-header h2{letter-spacing:-.5px;margin-bottom:8px;font-size:28px;font-weight:800}.upgrade-header p{color:var(--text-secondary);font-size:15px}.upgrade-feature-highlight{border:1px solid var(--border-default);border-radius:var(--r-md);margin-bottom:var(--sp-6);background:#ffffff08;gap:16px;padding:16px;display:flex}.upgrade-feature-icon{font-size:24px}.upgrade-feature-highlight strong{color:var(--text-primary);margin-bottom:4px;font-size:15px;display:block}.upgrade-feature-highlight p{color:var(--text-secondary);margin:0;font-size:13px;line-height:1.5}.upgrade-pricing{margin-bottom:var(--sp-6);grid-template-columns:1fr 1fr;gap:12px;display:grid}.pricing-option{border:2px solid var(--border-default);border-radius:var(--r-md);cursor:pointer;transition:all var(--t-fast);padding:16px;position:relative}.pricing-option:hover{border-color:var(--border-strong);background:#ffffff05}.pricing-option.active{border-color:var(--accent-500);background:#6366f10d}.pricing-radio{border:2px solid var(--border-strong);border-radius:50%;width:18px;height:18px;position:absolute;top:16px;right:16px}.pricing-option.active .pricing-radio{border-color:var(--accent-500)}.pricing-option.active .pricing-radio:after{content:"";background:var(--accent-500);border-radius:50%;position:absolute;inset:3px}.pricing-label{color:var(--text-primary);align-items:center;gap:8px;margin-bottom:8px;font-size:13px;font-weight:600;display:flex}.pricing-save{color:#000;background:#34d399;border-radius:4px;padding:2px 6px;font-size:10px;font-weight:700}.pricing-amount{color:#fff;align-items:baseline;gap:4px;font-size:24px;font-weight:800;display:flex}.pricing-amount span{color:var(--text-tertiary);font-size:13px;font-weight:500}.pricing-monthly{color:var(--text-secondary);margin-top:4px;font-size:12px}.upgrade-cta{border-radius:var(--r-md);background:var(--accent-gradient);color:#fff;width:100%;height:52px;box-shadow:var(--shadow-sm), 0 0 20px var(--accent-glow);transition:all var(--t-fast);cursor:pointer;justify-content:center;align-items:center;gap:8px;margin-bottom:24px;font-size:16px;font-weight:700;display:flex}.upgrade-cta:hover{box-shadow:var(--shadow-md), 0 0 30px var(--accent-glow);transform:translateY(-2px)}.upgrade-features{color:var(--text-secondary);grid-template-columns:1fr 1fr;gap:12px;margin-bottom:24px;font-size:13px;list-style:none;display:grid}.upgrade-features li{align-items:flex-start;gap:8px;line-height:1.4;display:flex}.upgrade-features li .pro-star{color:#fbbf24}.upgrade-guarantee{text-align:center;color:var(--text-tertiary);justify-content:center;align-items:center;gap:6px;font-size:12px;display:flex}.nav-actions{align-items:center;gap:var(--sp-3);display:flex;position:relative}.nav-actions-group{align-items:center;gap:var(--sp-2);display:flex}#nav-user{align-items:center;gap:12px;display:flex}.nav-signin-btn{color:var(--text-secondary);height:32px;transition:all var(--t-fast);border-radius:16px;align-items:center;gap:6px;padding:0 12px;font-size:13px;font-weight:500;display:flex}.nav-signin-btn:hover{color:var(--text-primary);background:#ffffff0f}.nav-upgrade-btn{background:var(--accent-gradient);color:#fff;height:32px;box-shadow:0 2px 10px var(--accent-glow);border-radius:16px;align-items:center;gap:6px;padding:0 16px;font-size:13px;font-weight:600;display:flex}.nav-upgrade-btn:hover{filter:brightness(1.1);box-shadow:0 4px 16px var(--accent-glow);transform:translateY(-1px)}.nav-user-pill{background:var(--bg-input);border:1px solid var(--border-default);border-radius:var(--r-full);cursor:pointer;transition:border-color var(--t-fast);align-items:center;gap:8px;padding:4px 12px 4px 4px;display:flex}.nav-user-pill:hover{border-color:var(--border-strong)}.nav-avatar{object-fit:cover;border-radius:50%;width:24px;height:24px}.nav-avatar-initials{background:var(--border-strong);color:#fff;justify-content:center;align-items:center;font-size:10px;font-weight:700;display:flex}.nav-user-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;max-width:100px;font-size:13px;font-weight:500;overflow:hidden}.nav-plan-badge{border-radius:4px;padding:2px 6px;font-size:9px;font-weight:800}.nav-plan-pro{background:var(--accent-gradient);color:#fff}.nav-chevron{color:var(--text-tertiary);transition:transform .2s}.nav-user-dropdown:not(.hidden)~.nav-user-pill .nav-chevron{transform:rotate(180deg)}.nav-user-dropdown{background:var(--bg-surface);border:1px solid var(--glass-border);border-radius:var(--r-md);width:220px;box-shadow:var(--shadow-lg), 0 0 0 1px #ffffff05;animation:panelIn var(--t-fast) var(--ease);z-index:200;padding:6px;position:absolute;top:calc(100% + 12px);right:0}.dropdown-header{padding:10px}.dropdown-email{color:var(--text-primary);margin-bottom:2px;font-size:13px;font-weight:500}.dropdown-plan{color:var(--text-secondary);font-size:11px}.dropdown-divider{background:var(--border-default);height:1px;margin:6px 0}.dropdown-item{width:100%;color:var(--text-secondary);border-radius:var(--r-sm);transition:all var(--t-fast);cursor:pointer;text-align:left;align-items:center;gap:10px;padding:8px 10px;font-size:13px;display:flex}.dropdown-item:hover{color:var(--text-primary);background:#ffffff0d}.dropdown-upgrade{color:var(--accent-400)}.dropdown-upgrade:hover{color:var(--accent-500);background:#6366f11a}.export-menu-item{background:var(--bg-input);border:1px solid var(--border-default);border-radius:var(--r-md);transition:all var(--t-fast);cursor:pointer;text-align:left;color:var(--text-primary);align-items:center;gap:16px;width:100%;padding:16px;display:flex}.export-menu-item:hover{border-color:var(--border-strong);background:#ffffff0d}.export-menu-item .export-icon{background:#ffffff0d;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:20px;display:flex}.export-menu-item .export-text{flex:1}.export-menu-item .export-text strong{margin-bottom:4px;font-size:14px;display:block}.export-menu-item .export-text span{color:var(--text-secondary);font-size:12px;line-height:1.4;display:block}.premium-export{background:#6366f10d;border-color:#6366f14d}.premium-export:hover{border-color:var(--accent-500);background:#6366f11a}.premium-export .export-icon{background:#6366f133}
