:root{--bg-base:#0a0a0f;--bg-elevated:#111118;--bg-surface:#16161f;--bg-overlay:#ffffff08;--bg-overlay-hover:#ffffff0f;--bg-overlay-active:#ffffff17;--primary:#7c5cfc;--primary-light:#a78bfa;--primary-dark:#6341e0;--primary-bg:#7c5cfc14;--primary-bg-hover:#7c5cfc26;--primary-border:#7c5cfc40;--accent-cyan:#06b6d4;--accent-pink:#f472b6;--accent-green:#34d399;--accent-amber:#fbbf24;--gradient-primary:linear-gradient(135deg, #7c5cfc 0%, #06b6d4 100%);--gradient-hero:linear-gradient(180deg, #0a0a0f 0%, #111118 50%, #0d0d15 100%);--gradient-glow:linear-gradient(135deg, #7c5cfc26 0%, #06b6d414 100%);--gradient-card:linear-gradient(145deg, #ffffff08 0%, #ffffff03 100%);--gradient-border:linear-gradient(135deg, #7c5cfc66, #06b6d466);--gradient-text:linear-gradient(135deg, #a78bfa, #06b6d4);--gradient-button-hover:linear-gradient(135deg, #8b6cff 0%, #0cc0d8 100%);--gradient-surface:linear-gradient(180deg, #7c5cfc0a 0%, transparent 100%);--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--text-disabled:#475569;--border:#ffffff0f;--border-light:#ffffff0a;--border-hover:#ffffff1f;--border-focus:#7c5cfc80;--success:#34d399;--warning:#fbbf24;--error:#f87171;--info:#60a5fa;--radius-xs:4px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--space-3xl:64px;--space-4xl:96px;--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 4px 16px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-xl:0 16px 48px #0009;--glow-primary:0 0 30px #7c5cfc33;--glow-primary-strong:0 0 50px #7c5cfc59;--glow-cyan:0 0 30px #06b6d433;--glow-button:0 4px 24px #7c5cfc4d, 0 0 60px #7c5cfc26;--transition-fast:.15s ease;--transition-base:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.4s cubic-bezier(.4, 0, .2, 1);--transition-spring:.5s cubic-bezier(.34, 1.56, .64, 1);--glass-bg:#ffffff0a;--glass-bg-strong:#ffffff12;--glass-border:#ffffff14;--glass-blur:20px}[data-theme=light]{--bg-base:#f8f9fb;--bg-elevated:#fff;--bg-surface:#f1f3f5;--bg-overlay:#00000008;--bg-overlay-hover:#0000000f;--bg-overlay-active:#00000017;--primary:#6341e0;--primary-light:#7c5cfc;--primary-dark:#4f2dc4;--primary-bg:#6341e00f;--primary-bg-hover:#6341e01f;--primary-border:#6341e033;--gradient-primary:linear-gradient(135deg, #6341e0 0%, #0891b2 100%);--gradient-hero:linear-gradient(180deg, #f8f9fb 0%, #eef0f4 50%, #f8f9fb 100%);--gradient-glow:linear-gradient(135deg, #6341e014 0%, #0891b20a 100%);--gradient-card:linear-gradient(145deg, #00000003 0%, #00000008 100%);--gradient-border:linear-gradient(135deg, #6341e04d, #0891b24d);--gradient-text:linear-gradient(135deg, #6341e0, #0891b2);--gradient-button-hover:linear-gradient(135deg, #7050e8 0%, #0ca5c7 100%);--gradient-surface:linear-gradient(180deg, #6341e008 0%, transparent 100%);--text-primary:#1a1a2e;--text-secondary:#4a5568;--text-muted:#718096;--text-disabled:#a0aec0;--border:#00000014;--border-light:#0000000a;--border-hover:#00000026;--border-focus:#6341e080;--success:#059669;--warning:#d97706;--error:#dc2626;--info:#2563eb;--shadow-sm:0 1px 3px #00000014;--shadow-md:0 4px 12px #0000001a;--shadow-lg:0 8px 24px #0000001f;--shadow-xl:0 16px 48px #00000026;--glow-primary:0 0 20px #6341e01f;--glow-primary-strong:0 0 40px #6341e033;--glow-button:0 4px 16px #6341e033;--glow-cyan:0 0 20px #0891b21f;--glass-bg:#ffffffb3;--glass-bg-strong:#ffffffd9;--glass-border:#00000014;--glass-blur:20px;--accent-cyan:#0891b2;--accent-pink:#db2777;--accent-green:#059669;--accent-amber:#d97706}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans), var(--font-cjk), -apple-system, BlinkMacSystemFont, sans-serif;background:var(--bg-base);color:var(--text-primary);min-height:100vh;line-height:1.6;overflow-x:hidden}a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer;color:inherit;background:0 0;border:none}img{max-width:100%;display:block}.btn>svg,.generate-btn>svg,.param-label>svg,.results-section h3>svg,.studio-header h1>svg,.cta-section h2>svg,.hero-actions .btn>svg,.result-card-actions .btn>svg{stroke-width:1.5px;flex-shrink:0;width:18px;height:18px}::selection{color:#f1f5f9;background:#7c5cfc4d}[data-theme=light] ::selection{color:#1a1a2e;background:#6341e033}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#fff3}[data-theme=light] ::-webkit-scrollbar-thumb{background:#0000001f}[data-theme=light] ::-webkit-scrollbar-thumb:hover{background:#00000038}.glass-panel{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border)}.glass-card{background:var(--glass-bg-strong);-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border);border-radius:var(--radius-lg)}.gradient-text{background:var(--gradient-text);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.glow-border{position:relative}.glow-border:before{content:"";border-radius:inherit;background:var(--gradient-border);-webkit-mask-composite:xor;opacity:0;transition:opacity var(--transition-base);padding:1px;position:absolute;inset:-1px;-webkit-mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);-webkit-mask-position:0 0,0 0;-webkit-mask-size:auto,auto;-webkit-mask-repeat:repeat,repeat;-webkit-mask-clip:content-box,border-box;-webkit-mask-origin:content-box,border-box;-webkit-mask-composite:xor;mask-composite:exclude;-webkit-mask-source-type:auto,auto;mask-mode:match-source,match-source}.glow-border:hover:before{opacity:1}.spinner{border:3px solid var(--border);border-top-color:var(--primary);width:48px;height:48px;margin-bottom:var(--space-md);border-radius:50%;animation:.8s linear infinite spin}.loading-overlay{padding:var(--space-3xl);background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border);flex-direction:column;justify-content:center;align-items:center;display:flex}.loading-text{color:var(--text-secondary);font-size:14px;animation:1.5s infinite pulse-text}.error-message{padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);color:var(--error);align-items:center;gap:var(--space-sm);margin-bottom:var(--space-lg);background:#f8717114;border:1px solid #f8717133;font-size:14px;display:flex}@keyframes fadeInUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse-dot{0%,to{opacity:1;box-shadow:0 0 8px #34d39980}50%{opacity:.5;box-shadow:0 0 16px #34d399cc}}@keyframes pulse-text{0%,to{opacity:1}50%{opacity:.5}}@keyframes float{0%,to{transform:translate(0)}50%{transform:translate(20px,-30px)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes glow-pulse{0%,to{box-shadow:var(--glow-primary)}50%{box-shadow:var(--glow-primary-strong)}}@keyframes border-flow{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}@keyframes mesh-drift-1{0%,to{transform:translate(0)scale(1)}25%{transform:translate(80px,-60px)scale(1.1)}50%{transform:translate(-40px,-120px)scale(.95)}75%{transform:translate(-100px,40px)scale(1.05)}}@keyframes mesh-drift-2{0%,to{transform:translate(0)scale(1)}25%{transform:translate(-90px,80px)scale(1.08)}50%{transform:translate(60px,40px)scale(.92)}75%{transform:translate(120px,-70px)scale(1.12)}}@keyframes mesh-drift-3{0%,to{transform:translate(0)scale(1)}25%{transform:translate(50px,100px)scale(1.15)}50%{transform:translate(-80px,60px)scale(.9)}75%{transform:translate(40px,-90px)scale(1.05)}}@keyframes mesh-drift-4{0%,to{transform:translate(0)scale(1)rotate(0)}25%{transform:translate(70px,-80px)scale(1.12)rotate(15deg)}50%{transform:translate(-50px,-40px)scale(.88)rotate(-10deg)}75%{transform:translate(-90px,60px)scale(1.08)rotate(5deg)}}@keyframes mesh-drift-5{0%,to{transform:translate(0)scale(1)rotate(0)}33%{transform:translate(100px,50px)scale(1.2)rotate(-20deg)}66%{transform:translate(-60px,-70px)scale(.85)rotate(10deg)}}@keyframes keyword-shimmer{0%{background-position:-200%}to{background-position:200%}}@keyframes hero-gradient-rotate{0%{transform:translate(-50%,-50%)rotate(0)}to{transform:translate(-50%,-50%)rotate(360deg)}}@keyframes gradient-sweep{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}@keyframes breathe-glow{0%,to{opacity:.4;transform:scale(1)}50%{opacity:.7;transform:scale(1.08)}}.mesh-blob{filter:blur(100px);pointer-events:none;will-change:transform;mix-blend-mode:screen;border-radius:50%;position:absolute}.mesh-blob--purple{background:radial-gradient(circle,#7c5cfc40 0%,#0000 70%);width:500px;height:500px;animation:12s ease-in-out infinite mesh-drift-1}.mesh-blob--cyan{background:radial-gradient(circle,#06b6d433 0%,#0000 70%);width:450px;height:450px;animation:15s ease-in-out infinite mesh-drift-2}.mesh-blob--pink{background:radial-gradient(circle,#f472b626 0%,#0000 70%);width:400px;height:400px;animation:18s ease-in-out infinite mesh-drift-3}.gradient-line{background:linear-gradient(90deg,#0000 0%,#7c5cfc99 20%,#06b6d499 50%,#f472b666 80%,#0000 100%) 0 0/200% 100%;height:1px;animation:4s ease-in-out infinite gradient-sweep}.section-gradient-divider{pointer-events:none;z-index:0;background:linear-gradient(#0000 0%,#7c5cfc08 30%,#06b6d405 60%,#0000 100%);height:200px;margin-top:-100px;margin-bottom:-100px;position:relative}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
.navbar{height:64px;padding:0 var(--space-xl);z-index:1000;background:#0a0a0f;border-bottom:1px solid #ffffff0f;justify-content:space-between;align-items:center;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;left:0;right:0}.navbar:after{content:"";background:linear-gradient(90deg,#0000 0%,#7c5cfc66 15%,#06b6d466 50%,#f472b640 85%,#0000 100%) 0 0/200% 100%;height:1px;animation:4s ease-in-out infinite gradient-sweep;position:absolute;bottom:0;left:0;right:0}.navbar-logo{font-family:var(--font-display), sans-serif;color:var(--text-primary);letter-spacing:-.02em;flex-shrink:0;align-items:center;gap:10px;font-size:17px;font-weight:700;display:flex}.navbar-logo .logo-icon{border-radius:var(--radius-sm);background:var(--gradient-primary);color:#fff;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.navbar-logo .logo-icon svg{width:18px;height:18px}.navbar-links{border-radius:var(--radius-full);background:#ffffff0a;border:1px solid #ffffff0f;align-items:center;gap:4px;padding:4px;display:flex}.navbar-links a{color:var(--text-muted);border-radius:var(--radius-full);white-space:nowrap;letter-spacing:.01em;padding:7px 18px;font-size:14px;font-weight:500;transition:all .25s cubic-bezier(.4,0,.2,1);position:relative}.navbar-links a:hover{color:var(--text-primary);background:#ffffff0f}.navbar-links a.active{color:#fff;background:#7c5cfc2e;box-shadow:0 0 12px #7c5cfc1f,inset 0 1px #ffffff0f}.navbar-links a:after{display:none}.navbar-actions{align-items:center;gap:var(--space-md);flex-shrink:0;display:flex}.navbar-hamburger{cursor:pointer;z-index:1001;background:0 0;border:none;flex-direction:column;gap:5px;padding:6px;display:none}.hamburger-line{background:var(--text-primary);border-radius:2px;width:22px;height:2px;transition:all .3s;display:block}.hamburger-line.open:first-child{transform:rotate(45deg)translate(5px,5px)}.hamburger-line.open:nth-child(2){opacity:0}.hamburger-line.open:nth-child(3){transform:rotate(-45deg)translate(5px,-5px)}.navbar-mobile-menu{background:var(--bg-base);z-index:999;padding:var(--space-xl);gap:var(--space-sm);flex-direction:column;animation:.2s fadeInUp;display:flex;position:fixed;inset:64px 0 0}.navbar-mobile-link{color:var(--text-secondary);border-radius:var(--radius-md);padding:14px 16px;font-size:16px;font-weight:500;transition:all .2s;display:block}.navbar-mobile-link:hover,.navbar-mobile-link.active{background:var(--bg-overlay-hover);color:var(--text-primary)}.navbar-mobile-action{margin-top:var(--space-lg);padding-top:var(--space-lg);border-top:1px solid var(--border);gap:var(--space-sm);flex-direction:column;display:flex}.navbar-mobile-action .btn{justify-content:center;width:100%}.navbar-auth-btn{white-space:nowrap;padding:6px 16px!important;font-size:13px!important}.navbar-user-menu{position:relative}.navbar-user-trigger{background:var(--bg-overlay-hover,#ffffff0f);border:1px solid var(--border);cursor:pointer;color:var(--text-primary);border-radius:999px;align-items:center;gap:8px;padding:4px 12px 4px 4px;font-size:13px;font-weight:500;transition:all .2s;display:flex}.navbar-user-trigger:hover{background:#7c5cfc1a;border-color:#7c5cfc4d}.navbar-avatar{background:var(--gradient-primary,linear-gradient(135deg, #7c5cfc, #06b6d4));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;font-weight:700;display:flex}.navbar-username{text-overflow:ellipsis;white-space:nowrap;max-width:80px;overflow:hidden}.navbar-chevron{opacity:.5;flex-shrink:0;transition:transform .2s}.navbar-chevron.open{transform:rotate(180deg)}.navbar-dropdown{background:var(--bg-secondary,#1a1a2e);border:1px solid var(--border);z-index:1100;border-radius:14px;width:220px;padding:6px;animation:.15s dropdownIn;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 12px 40px #0006}@keyframes dropdownIn{0%{opacity:0;transform:translateY(-6px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.navbar-dropdown-header{flex-direction:column;gap:2px;padding:10px 12px;display:flex}.navbar-dropdown-name{color:var(--text-primary);font-size:14px;font-weight:600}.navbar-dropdown-email{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;font-size:11px;overflow:hidden}.navbar-dropdown-credits{color:#fbbf24;margin-top:4px;font-size:12px;font-weight:600}.navbar-dropdown-divider{background:var(--border);height:1px;margin:4px 8px}.navbar-dropdown-item{color:var(--text-secondary);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:10px;align-items:center;gap:8px;width:100%;padding:9px 12px;font-size:13px;font-weight:500;transition:all .15s;display:flex}.navbar-dropdown-item:hover{background:var(--bg-overlay-hover,#ffffff0f);color:var(--text-primary)}.navbar-dropdown-logout:hover{color:#f87171;background:#f8717114}@media (max-width:768px){.navbar-links,.navbar-actions{display:none}.navbar-hamburger{display:flex}.navbar{padding:0 var(--space-md)}}@media (max-width:480px){.navbar-actions{display:none}}[data-theme=light] .navbar{background:#fff;border-bottom-color:#0000000f}[data-theme=light] .navbar:after{background:linear-gradient(90deg,#0000 0%,#6341e040 15%,#0891b240 50%,#db277726 85%,#0000 100%) 0 0/200% 100%}[data-theme=light] .navbar-links{background:#00000008;border-color:#0000000f}[data-theme=light] .navbar-links a:hover{background:#0000000d}[data-theme=light] .navbar-links a.active{color:var(--text-primary);background:#6341e01a;box-shadow:0 0 10px #6341e00f,inset 0 1px #fffc}[data-theme=light] .navbar-mobile-menu{background:var(--bg-base)}[data-theme=light] .navbar-user-trigger{background:#0000000a;border-color:#00000014}[data-theme=light] .navbar-user-trigger:hover{background:#6341e014;border-color:#6341e033}[data-theme=light] .navbar-dropdown{background:#fff;border-color:#00000014;box-shadow:0 12px 40px #0000001f}[data-theme=light] .navbar-dropdown-item:hover{background:#0000000a}
.btn{border-radius:var(--radius-md);transition:all var(--transition-base);white-space:nowrap;cursor:pointer;justify-content:center;align-items:center;gap:8px;padding:10px 24px;font-size:14px;font-weight:600;display:inline-flex;position:relative;overflow:hidden}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--glow-button)}.btn-primary:hover{background:var(--gradient-button-hover);transform:translateY(-1px);box-shadow:0 6px 32px #7c5cfc66,0 0 80px #7c5cfc33}.btn-primary:active{transform:translateY(0)}.btn-outline{color:var(--primary-light);border:1.5px solid var(--primary-border);background:0 0}.btn-outline:hover{background:var(--primary-bg);border-color:var(--primary);box-shadow:var(--glow-primary)}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover{background:var(--bg-overlay-hover);color:var(--text-primary)}.btn-lg{border-radius:var(--radius-lg);padding:14px 36px;font-size:16px}.btn-sm{border-radius:var(--radius-sm);padding:6px 16px;font-size:13px}.btn-icon{border-radius:var(--radius-md);width:40px;height:40px;padding:0}
.studio-layout{background:var(--bg-base);height:100vh;padding-top:64px;display:flex}.sidebar{background:var(--bg-elevated);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:220px;display:flex;overflow-y:auto}.sidebar-section{padding:var(--space-md) var(--space-sm)}.sidebar-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;padding:var(--space-sm) var(--space-md);margin-bottom:var(--space-xs);font-size:13px;font-weight:600}.sidebar-item{padding:10px var(--space-md);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);align-items:center;gap:10px;margin-bottom:2px;font-size:15px;font-weight:400;display:flex}.sidebar-item:hover{background:var(--bg-overlay-hover);color:var(--text-primary)}.sidebar-item.active{background:var(--primary-bg);color:var(--primary-light);font-weight:500}.sidebar-item .item-icon{color:currentColor;opacity:.7;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.sidebar-item .item-icon svg{stroke-width:1.5px;width:16px;height:16px}.sidebar-item:hover .item-icon,.sidebar-item.active .item-icon{opacity:1}.sidebar-item .badge{background:var(--gradient-primary);color:#fff;border-radius:var(--radius-full);margin-left:auto;padding:2px 6px;font-size:10px;font-weight:600}.studio-main{background:var(--bg-base);flex:1;padding:0;position:relative;overflow:hidden}.studio-canvas{gap:var(--space-lg);padding:var(--space-xl);flex-wrap:wrap;place-content:start center;align-items:start;min-height:calc(100vh - 284px);display:flex}.studio-canvas-empty{width:100%;min-height:400px;color:var(--text-muted);justify-content:center;align-items:center;gap:var(--space-md);flex-direction:column;display:flex}.studio-canvas-empty .empty-icon{opacity:.4;font-size:48px}.studio-canvas-empty .empty-text{font-size:15px;font-weight:500}.studio-canvas-empty .empty-hint{opacity:.6;font-size:13px}.canvas-card{background:var(--bg-elevated);border:1px solid var(--border);transition:all var(--transition-base);border-radius:20px;position:relative;overflow:hidden}.canvas-card:hover{border-color:var(--border-hover);box-shadow:0 8px 32px #0000004d, var(--glow-primary);transform:translateY(-2px)}.canvas-upload-card{border:2px dashed var(--border-hover);background:var(--bg-surface);cursor:pointer;width:280px;height:280px;transition:all var(--transition-base);justify-content:center;align-items:center;gap:var(--space-sm);border-radius:20px;flex-direction:column;display:flex}.canvas-upload-card:hover,.canvas-upload-card.drag-over{border-color:var(--primary);background:var(--primary-bg);box-shadow:var(--glow-primary)}.canvas-upload-card input[type=file]{display:none}.canvas-upload-card .upload-icon{color:var(--text-muted);font-size:32px}.canvas-upload-card .upload-text{color:var(--text-secondary);font-size:13px;font-weight:500}.canvas-upload-card .upload-hint{color:var(--text-muted);font-size:11px}.canvas-upload-card.has-image{border-style:solid;border-color:var(--border);padding:0}.canvas-upload-card.has-image img{object-fit:cover;border-radius:18px;width:100%;height:100%}.canvas-upload-card .remove-btn{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;cursor:pointer;width:28px;height:28px;transition:all var(--transition-fast);z-index:2;background:#000000b3;border:1px solid #ffffff1a;border-radius:50%;justify-content:center;align-items:center;font-size:14px;display:flex;position:absolute;top:8px;right:8px}.canvas-upload-card .remove-btn:hover{background:var(--error);transform:scale(1.1)}.canvas-result-card{background:var(--bg-elevated);border:1px solid var(--border);width:280px;transition:all var(--transition-base);border-radius:20px;overflow:hidden}.canvas-result-card:hover{border-color:var(--primary-border);box-shadow:0 8px 32px #0000004d, var(--glow-primary);transform:translateY(-3px)}.canvas-result-card img{aspect-ratio:1;object-fit:cover;width:100%;display:block}.canvas-result-card .result-actions{gap:6px;padding:10px 12px;display:flex}.canvas-result-card .result-actions .btn{flex:1;padding:6px 10px;font-size:12px}.studio-bottom-bar{z-index:100;pointer-events:none;justify-content:center;display:flex;position:fixed;bottom:20px;left:244px;right:24px}.bottom-bar-inner{pointer-events:auto;-webkit-backdrop-filter:blur(24px);background:#26262ad9;border:1px solid #ffffff14;border-radius:24px;flex-direction:column;gap:12px;width:100%;max-width:900px;padding:16px 20px;display:flex;box-shadow:0 8px 48px #00000080,0 0 0 1px #ffffff0a}.bottom-bar-templates{flex-wrap:wrap;gap:6px;display:flex}.bottom-bar-templates .tpl-tag{color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:#ffffff0f;border:1px solid #ffffff14;border-radius:20px;padding:5px 14px;font-size:12px;font-weight:500}.bottom-bar-templates .tpl-tag:hover{color:var(--text-primary);background:#ffffff1f;border-color:#ffffff26}.bottom-bar-templates .tpl-tag.active{background:var(--primary-bg);border-color:var(--primary);color:var(--primary-light)}.bottom-bar-prompt{position:relative}.bottom-bar-prompt textarea{width:100%;min-height:56px;max-height:120px;color:var(--text-primary);resize:none;transition:all var(--transition-fast);background:#ffffff0d;border:none;border-radius:16px;outline:none;padding:12px 120px 12px 16px;font-family:inherit;font-size:14px;line-height:1.5}.bottom-bar-prompt textarea::placeholder{color:var(--text-muted)}.bottom-bar-prompt textarea:focus{background:#ffffff14;box-shadow:0 0 0 2px #7c5cfc33}.bottom-bar-prompt .generate-float-btn{background:var(--gradient-primary);color:#fff;font-size:13px;font-weight:700;font-family:var(--font-display), var(--font-cjk), sans-serif;cursor:pointer;transition:all var(--transition-base);box-shadow:var(--glow-button);border:none;border-radius:12px;align-items:center;gap:6px;padding:8px 20px;display:flex;position:absolute;bottom:8px;right:8px}.bottom-bar-prompt .generate-float-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 24px #7c5cfc73}.bottom-bar-prompt .generate-float-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.bottom-bar-params{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.bottom-bar-params .param-chip{color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;-webkit-user-select:none;user-select:none;background:#ffffff0f;border:1px solid #ffffff14;border-radius:20px;align-items:center;gap:4px;padding:4px 12px;font-size:12px;display:inline-flex}.bottom-bar-params .param-chip:hover{color:var(--text-primary);background:#ffffff1a}.bottom-bar-params .param-chip.active{background:var(--primary-bg);border-color:var(--primary);color:var(--primary-light)}.bottom-bar-params .param-divider{background:#ffffff14;width:1px;height:20px;margin:0 4px}.bottom-bar-params .param-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-right:2px;font-size:11px;font-weight:600}.bottom-bar-tags{flex-wrap:wrap;gap:4px;display:flex}.bottom-bar-tags .quick-tag{color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:1px solid #ffffff0f;border-radius:12px;padding:3px 10px;font-size:11px}.bottom-bar-tags .quick-tag:hover{border-color:var(--primary-border);color:var(--primary-light);background:var(--primary-bg)}.studio-header{display:none}.studio-header h1{font-family:var(--font-display), var(--font-cjk), sans-serif;margin-bottom:var(--space-xs);background:var(--gradient-text);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:24px;font-weight:700}.studio-header p{color:var(--text-secondary);font-size:14px}.template-section{margin-bottom:var(--space-xl)}.template-section h3{font-family:var(--font-display), var(--font-cjk), sans-serif;margin-bottom:var(--space-md);align-items:center;gap:var(--space-sm);color:var(--text-primary);font-size:15px;font-weight:600;display:flex}.template-section h3>svg{stroke-width:1.5px;width:18px;height:18px;color:var(--primary-light);flex-shrink:0}.template-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(140px,1fr));display:grid}.template-card{background:var(--bg-surface);border:1.5px solid var(--border);border-radius:var(--radius-md);padding:var(--space-md);text-align:center;cursor:pointer;transition:all var(--transition-base);position:relative;overflow:hidden}.template-card:hover{border-color:var(--border-hover);background:var(--bg-overlay-hover);box-shadow:var(--shadow-md);transform:translateY(-2px)}.template-card.active{border-color:var(--primary);background:var(--primary-bg);box-shadow:var(--glow-primary)}.template-card .template-icon{margin-bottom:var(--space-sm);justify-content:center;align-items:center;height:40px;font-size:28px;display:flex}.template-card .template-icon svg{stroke-width:1.5px;width:28px;height:28px;color:var(--primary-light)}.template-card .template-name{color:var(--text-secondary);font-size:13px;font-weight:500}.template-card.active .template-name{color:var(--primary-light)}.upload-zone{border:2px dashed var(--border-hover);border-radius:var(--radius-lg);padding:var(--space-2xl) var(--space-xl);text-align:center;cursor:pointer;transition:all var(--transition-base);background:var(--bg-surface);margin-bottom:var(--space-lg);position:relative}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--primary);background:var(--primary-bg);box-shadow:var(--glow-primary)}.upload-zone .upload-icon{margin-bottom:var(--space-md);color:var(--text-muted);justify-content:center;align-items:center;display:flex}.upload-zone .upload-icon svg{stroke-width:1px;width:48px;height:48px}.upload-zone .upload-text{color:var(--text-secondary);margin-bottom:var(--space-xs);font-size:15px;font-weight:500}.upload-zone .upload-hint{color:var(--text-muted);font-size:12px}.upload-zone input[type=file]{display:none}.upload-preview{display:inline-block;position:relative}.upload-preview img{border-radius:var(--radius-md);object-fit:contain;border:1px solid var(--border);max-width:300px;max-height:250px}.upload-preview .remove-btn{background:var(--error);color:#fff;cursor:pointer;width:24px;height:24px;transition:transform var(--transition-fast);border-radius:50%;justify-content:center;align-items:center;font-size:12px;display:flex;position:absolute;top:-8px;right:-8px;box-shadow:0 2px 8px #f8717166}.upload-preview .remove-btn:hover{transform:scale(1.15)}.prompt-section{margin-bottom:var(--space-lg)}.prompt-input-wrapper{background:var(--bg-surface);border:1.5px solid var(--border);border-radius:var(--radius-lg);transition:all var(--transition-fast);overflow:hidden}.prompt-input-wrapper:focus-within{border-color:var(--border-focus);box-shadow:0 0 0 3px #7c5cfc1a, var(--glow-primary)}.prompt-textarea{width:100%;min-height:100px;padding:var(--space-md);resize:vertical;color:var(--text-primary);background:0 0;border:none;outline:none;font-family:inherit;font-size:14px;line-height:1.6}.prompt-textarea::placeholder{color:var(--text-muted)}.prompt-toolbar{padding:var(--space-sm) var(--space-md);border-top:1px solid var(--border);background:var(--bg-overlay);justify-content:space-between;align-items:center;display:flex}.prompt-tags{flex-wrap:wrap;gap:6px;display:flex}.prompt-tag{background:var(--bg-overlay);border:1px solid var(--border);border-radius:var(--radius-full);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);padding:4px 12px;font-size:12px}.prompt-tag:hover{border-color:var(--primary-border);color:var(--primary-light);background:var(--primary-bg)}.char-count{color:var(--text-muted);font-size:12px}.params-panel{gap:var(--space-lg);background:var(--bg-surface);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-lg);border:1px solid var(--border);flex-wrap:wrap;display:flex}.param-group{gap:var(--space-sm);flex-direction:column;display:flex}.param-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:600}.param-options{flex-wrap:wrap;gap:6px;display:flex}.param-option{background:var(--bg-overlay);border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);padding:6px 16px;font-size:13px;font-weight:500}.param-option:hover{border-color:var(--border-hover);color:var(--text-primary);background:var(--bg-overlay-hover)}.param-option.active{background:var(--primary-bg);border-color:var(--primary);color:var(--primary-light);box-shadow:0 0 12px #7c5cfc26}.generate-bar{margin-bottom:var(--space-xl);justify-content:space-between;align-items:center;display:flex}.generate-btn{background:var(--gradient-primary);color:#fff;border-radius:var(--radius-lg);font-size:16px;font-weight:700;font-family:var(--font-display), var(--font-cjk), sans-serif;cursor:pointer;transition:all var(--transition-base);box-shadow:var(--glow-button);align-items:center;gap:var(--space-sm);border:none;padding:14px 48px;display:flex;position:relative;overflow:hidden}.generate-btn:before{content:"";opacity:0;transition:opacity var(--transition-base);background:linear-gradient(135deg,#ffffff1a 0%,#0000 50%);position:absolute;inset:0}.generate-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 40px #7c5cfc73,0 0 100px #7c5cfc33}.generate-btn:hover:not(:disabled):before{opacity:1}.generate-btn:disabled{opacity:.4;cursor:not-allowed;box-shadow:none;transform:none}.results-section{margin-top:var(--space-xl)}.results-section h3{font-family:var(--font-display), var(--font-cjk), sans-serif;margin-bottom:var(--space-md);align-items:center;gap:var(--space-sm);color:var(--text-primary);font-size:16px;font-weight:600;display:flex}.results-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.result-card{background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border);transition:all var(--transition-base);position:relative;overflow:hidden}.result-card:hover{box-shadow:var(--glow-primary);border-color:var(--primary-border);transform:translateY(-2px)}.result-card img{aspect-ratio:1;object-fit:cover;width:100%;display:block}.result-card-actions{padding:var(--space-md);gap:var(--space-sm);display:flex}.result-card-actions .btn{flex:1}.studio-main>*{animation:.25s ease-out fadeInUp}@media (max-width:768px){.sidebar{display:none}.studio-main{padding-bottom:280px}.studio-bottom-bar{bottom:12px;left:12px;right:12px}.bottom-bar-inner{border-radius:18px;padding:12px 14px}.canvas-upload-card,.canvas-result-card{width:100%;max-width:320px}.canvas-upload-card{height:240px}.params-panel{flex-direction:column}.template-grid{grid-template-columns:repeat(3,1fr)}.generate-btn{justify-content:center;width:100%}.results-grid{grid-template-columns:1fr}}@media (max-width:480px){.template-grid{grid-template-columns:repeat(2,1fr)}}[data-theme=light] .bottom-bar-inner{background:#ffffffe0;border-color:#00000014;box-shadow:0 8px 48px #0000001a,0 0 0 1px #0000000a}[data-theme=light] .bottom-bar-templates .tpl-tag{color:var(--text-secondary);background:#0000000a;border-color:#00000014}[data-theme=light] .bottom-bar-templates .tpl-tag:hover{color:var(--text-primary);background:#00000014;border-color:#0000001f}[data-theme=light] .bottom-bar-prompt textarea{color:var(--text-primary);background:#00000008}[data-theme=light] .bottom-bar-prompt textarea:focus{background:#0000000d;box-shadow:0 0 0 2px #6341e026}[data-theme=light] .bottom-bar-params .param-chip{color:var(--text-secondary);background:#0000000a;border-color:#00000014}[data-theme=light] .bottom-bar-params .param-chip:hover{color:var(--text-primary);background:#00000014}[data-theme=light] .bottom-bar-params .param-divider{background:#00000014}[data-theme=light] .bottom-bar-tags .quick-tag{border-color:#0000000f}[data-theme=light] .canvas-upload-card .remove-btn{color:var(--error);background:#ffffffe6;border-color:#0000001a}[data-theme=light] .canvas-upload-card .remove-btn:hover{background:var(--error);color:#fff}[data-theme=light] .node-sidebar:before{background:linear-gradient(#6341e00a 0%,#0000 100%)}.sidebar-shortcut-hint{padding:var(--space-sm) var(--space-md) var(--space-md);border-top:1px solid var(--border);margin-top:auto}.sidebar-shortcut-hint button{width:100%;color:var(--text-muted);background:var(--bg-overlay);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;gap:6px;padding:8px 12px;font-size:12px;display:flex}.sidebar-shortcut-hint button:hover{color:var(--text-primary);background:var(--bg-overlay-hover);border-color:var(--border-hover)}.shortcut-help-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;background:#0009;justify-content:center;align-items:center;animation:.2s fadeInUp;display:flex;position:fixed;inset:0}.shortcut-help-panel{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-xl);width:420px;max-height:80vh;box-shadow:var(--shadow-xl), var(--glow-primary);overflow-y:auto}.shortcut-help-header{padding:var(--space-lg) var(--space-xl);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.shortcut-help-header h3{color:var(--text-primary);font-size:16px;font-weight:700}.shortcut-help-close{border-radius:var(--radius-sm);width:28px;height:28px;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;font-size:14px;display:flex}.shortcut-help-close:hover{background:var(--bg-overlay-hover);color:var(--text-primary)}.shortcut-help-body{padding:var(--space-lg) var(--space-xl)}.shortcut-group{margin-bottom:var(--space-lg)}.shortcut-group:last-child{margin-bottom:0}.shortcut-group-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:var(--space-sm);font-size:11px;font-weight:700}.shortcut-row{justify-content:space-between;align-items:center;padding:6px 0;display:flex}.shortcut-desc{color:var(--text-secondary);font-size:13px}.shortcut-keys{gap:4px;display:flex}.shortcut-keys kbd,.shortcut-help-footer kbd{background:var(--bg-surface);border:1px solid var(--border-hover);border-radius:var(--radius-xs);min-width:24px;height:24px;font-family:var(--font-sans), monospace;color:var(--text-primary);justify-content:center;align-items:center;padding:0 6px;font-size:11px;font-weight:600;display:inline-flex;box-shadow:0 1px 2px #0003}.shortcut-help-footer{padding:var(--space-md) var(--space-xl);border-top:1px solid var(--border);color:var(--text-muted);text-align:center;font-size:12px}[data-theme=light] .shortcut-help-overlay{background:#0000004d}[data-theme=light] .shortcut-keys kbd,[data-theme=light] .shortcut-help-footer kbd{background:var(--bg-surface);border-color:var(--border);box-shadow:0 1px 2px #00000014}
.hero{min-height:100vh;padding:120px var(--space-xl) var(--space-3xl);background:var(--bg-base);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.hero>.hero-badge,.hero>h1,.hero>p,.hero>.hero-actions{width:100%;max-width:800px;margin-left:auto;margin-right:auto}.hero:before{content:"";filter:blur(120px);pointer-events:none;background:conic-gradient(at 70% 30%,#7c5cfc2e 0deg,#06b6d424 60deg,#f472b61f 120deg,#fbbf240f 180deg,#7c5cfc14 240deg,#34d3991a 300deg,#7c5cfc2e 360deg);width:150%;height:150%;animation:30s linear infinite hero-gradient-rotate;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.hero:after{content:"";background:radial-gradient(ellipse 80% 70% at 50% 45%, transparent 0%, var(--bg-base) 75%);pointer-events:none;position:absolute;inset:0}.hero-glow-1{pointer-events:none;filter:blur(80px);will-change:transform;mix-blend-mode:screen;background:radial-gradient(circle,#7c5cfc59 0%,#7c5cfc14 40%,#0000 70%);border-radius:50%;width:800px;height:800px;animation:12s ease-in-out infinite mesh-drift-1;position:absolute;top:-200px;right:-100px}.hero-glow-2{pointer-events:none;filter:blur(90px);will-change:transform;mix-blend-mode:screen;background:radial-gradient(circle,#06b6d44d 0%,#06b6d40f 40%,#0000 70%);border-radius:50%;width:700px;height:700px;animation:15s ease-in-out infinite mesh-drift-2;position:absolute;bottom:-120px;left:-150px}.hero-glow-3{pointer-events:none;filter:blur(100px);will-change:transform;mix-blend-mode:screen;background:radial-gradient(circle,#f472b640 0%,#f472b60d 40%,#0000 70%);border-radius:50%;width:600px;height:600px;animation:18s ease-in-out infinite mesh-drift-3;position:absolute;top:25%;left:55%}.hero-glow-4{pointer-events:none;filter:blur(110px);will-change:transform;mix-blend-mode:screen;background:radial-gradient(circle,#fbbf242e 0%,#fbbf2408 40%,#0000 70%);border-radius:50%;width:550px;height:550px;animation:20s ease-in-out infinite mesh-drift-4;position:absolute;top:10%;left:-5%}.hero-glow-5{pointer-events:none;filter:blur(100px);will-change:transform;mix-blend-mode:screen;background:radial-gradient(circle,#34d39933 0%,#34d3990a 40%,#0000 70%);border-radius:50%;width:450px;height:450px;animation:22s ease-in-out infinite mesh-drift-5;position:absolute;bottom:15%;right:10%}.hero-badge{-webkit-backdrop-filter:none;backdrop-filter:none;color:var(--text-secondary);margin-bottom:var(--space-xl);z-index:2;background:0 0;border:none;border-radius:0;align-items:center;gap:8px;padding:6px 0;font-size:14px;font-weight:500;animation:.6s fadeInUp;display:inline-flex;position:relative}.hero-badge .dot{background:var(--accent-green);border-radius:50%;width:6px;height:6px;animation:2s infinite pulse-dot;box-shadow:0 0 8px #34d39980}.hero h1{font-family:var(--font-display), var(--font-cjk), sans-serif;letter-spacing:-.03em;margin-bottom:var(--space-lg);color:var(--text-primary);z-index:2;text-align:center;margin-left:auto;margin-right:auto;font-size:64px;font-weight:800;line-height:1.1;animation:.6s .1s both fadeInUp;position:relative}.hero-keyword{background:linear-gradient(90deg,#a78bfa 0%,#06b6d4 25%,#f472b6 50%,#fbbf24 75%,#a78bfa 100%) 0 0/200%;-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;animation:4s linear infinite keyword-shimmer;position:relative}.hero-keyword:after{content:"";opacity:.6;filter:blur(1px);background:linear-gradient(90deg,#a78bfa,#06b6d4,#f472b6);border-radius:2px;height:3px;position:absolute;bottom:-4px;left:0;right:0}.hero p{color:var(--text-secondary);max-width:560px;margin-left:auto;margin-right:auto;margin-bottom:var(--space-xl);z-index:2;text-align:center;font-size:18px;line-height:1.8;animation:.6s .2s both fadeInUp;position:relative}.hero-actions{gap:var(--space-md);z-index:2;justify-content:center;animation:.6s .3s both fadeInUp;display:flex;position:relative}.features{padding:var(--space-4xl) var(--space-xl);max-width:1200px;margin:0 auto;position:relative}.features:before{content:"";pointer-events:none;background:radial-gradient(70% 100% at 50% 0,#7c5cfc0f 0%,#06b6d408 50%,#0000 100%);width:100%;max-width:800px;height:200px;animation:6s ease-in-out infinite breathe-glow;position:absolute;top:-80px;left:50%;transform:translate(-50%)}.features-header{text-align:center;margin-bottom:var(--space-3xl)}.features-header h2{font-family:var(--font-display), var(--font-cjk), sans-serif;margin-bottom:var(--space-md);letter-spacing:-.02em;font-size:40px;font-weight:700}.features-header p{color:var(--text-secondary);font-size:16px}.features-grid{gap:var(--space-lg);grid-template-columns:repeat(12,1fr);display:grid}.feature-card{background:var(--gradient-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-xl);transition:all var(--transition-base);cursor:pointer;animation:.6s both bentoFadeIn;animation-delay:calc(var(--card-index,0) * 80ms);position:relative;overflow:hidden}@keyframes bentoFadeIn{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.feature-card:before{content:"";border-radius:inherit;background:var(--gradient-border);-webkit-mask-composite:xor;opacity:0;transition:opacity var(--transition-base);padding:1px;position:absolute;inset:-1px;-webkit-mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);-webkit-mask-position:0 0,0 0;-webkit-mask-size:auto,auto;-webkit-mask-repeat:repeat,repeat;-webkit-mask-clip:content-box,border-box;-webkit-mask-origin:content-box,border-box;-webkit-mask-composite:xor;mask-composite:exclude;-webkit-mask-source-type:auto,auto;mask-mode:match-source,match-source}.feature-card:hover{box-shadow:var(--glow-primary);background:var(--bg-overlay-hover);transform:translateY(-6px)}.feature-card:hover:before{opacity:1}.feature-deco{pointer-events:none;opacity:.35;width:240px;height:240px;transition:opacity var(--transition-base), transform var(--transition-base);border-radius:50%;position:absolute;top:-60px;right:-60px}.feature-card:hover .feature-deco{opacity:.6;transform:scale(1.15)}.bento-hero{flex-direction:row;grid-column:span 8;align-items:stretch;min-height:340px;display:flex}.bento-hero .feature-content{padding-right:var(--space-xl);z-index:1;flex-direction:column;flex:1;justify-content:flex-end;display:flex;position:relative}.bento-hero .feature-showcase{z-index:1;padding:var(--space-md);flex:0 0 45%;justify-content:center;align-items:center;display:flex;position:relative}.bento-hero .feature-showcase img{border-radius:var(--radius-lg);object-fit:cover;width:100%;height:auto;transition:transform .4s;box-shadow:0 8px 32px #00000040}.bento-hero:hover .feature-showcase img{transform:translateY(-4px)scale(1.02)}.bento-normal{flex-direction:column;grid-column:span 4;display:flex}.bento-normal .feature-content{z-index:1;position:relative}.bento-wide{align-items:center;gap:var(--space-xl);flex-direction:row;grid-column:span 12;min-height:160px;display:flex}.bento-wide .feature-content{z-index:1;flex:1;position:relative}.feature-workflow-deco{padding-right:var(--space-lg);z-index:1;flex-shrink:0;align-items:center;gap:0;display:flex;position:relative}.workflow-node{background:#a78bfa1a;border:1px solid #a78bfa33;border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;font-size:20px;transition:all .3s;display:flex}.feature-card:hover .workflow-node{background:#a78bfa2e;border-color:#a78bfa59;transform:scale(1.08)}.workflow-line{background:linear-gradient(90deg,#a78bfa4d,#a78bfa1a);width:32px;height:2px}.feature-card .icon{background:var(--primary-bg);border-radius:var(--radius-md);width:48px;height:48px;margin-bottom:var(--space-md);color:var(--primary-light);transition:all var(--transition-base);justify-content:center;align-items:center;display:flex}.bento-hero .icon{border-radius:var(--radius-lg);width:56px;height:56px;margin-bottom:var(--space-lg)}.feature-card .icon svg{stroke-width:1.5px;width:24px;height:24px}.bento-hero .icon svg{width:28px;height:28px}.feature-card:hover .icon{background:var(--primary-bg-hover);box-shadow:var(--glow-primary);transform:scale(1.08)}.feature-card h3{font-family:var(--font-display), var(--font-cjk), sans-serif;margin-bottom:var(--space-sm);color:var(--text-primary);font-size:17px;font-weight:600}.bento-hero h3{margin-bottom:var(--space-md);font-size:22px}.bento-wide h3{font-size:20px}.feature-card p{color:var(--text-secondary);font-size:14px;line-height:1.7}.bento-hero p{max-width:400px;font-size:15px}@media (max-width:900px){.bento-hero{flex-direction:column;grid-column:span 12;min-height:auto}.bento-hero .feature-content{padding-right:0;padding-bottom:var(--space-md)}.bento-normal{grid-column:span 6}.bento-wide{flex-direction:column;align-items:flex-start}.feature-workflow-deco{padding-right:0}}@media (max-width:600px){.bento-normal{grid-column:span 12}.workflow-node{width:36px;height:36px;font-size:16px}.workflow-line{width:20px}}.cta-section{padding:var(--space-4xl) var(--space-xl);text-align:center;position:relative;overflow:hidden}.cta-section:before{content:"";pointer-events:none;background:radial-gradient(60% 80%,#7c5cfc1a 0%,#06b6d40d 40%,#f472b608 70%,#0000 100%);width:900px;height:500px;animation:8s ease-in-out infinite breathe-glow;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.cta-section h2{font-family:var(--font-display), var(--font-cjk), sans-serif;margin-bottom:var(--space-md);font-size:36px;font-weight:700;position:relative}.cta-section p{color:var(--text-secondary);margin-bottom:var(--space-xl);font-size:16px;position:relative}.site-footer{padding:var(--space-xl);text-align:center;border-top:1px solid var(--border);color:var(--text-muted);font-size:13px}.terms-page{padding:100px var(--space-xl) var(--space-4xl);min-height:100vh}.terms-container{max-width:720px;margin:0 auto}.terms-container h1{font-family:var(--font-display), var(--font-cjk), sans-serif;margin-bottom:var(--space-sm);font-size:32px;font-weight:700}.terms-updated{color:var(--text-muted);margin-bottom:var(--space-3xl);font-size:13px}.terms-section{margin-bottom:var(--space-xl)}.terms-section h2{font-family:var(--font-display), var(--font-cjk), sans-serif;margin-bottom:var(--space-md);color:var(--text-primary);font-size:18px;font-weight:600}.terms-section p,.terms-section li{color:var(--text-secondary);font-size:14px;line-height:1.8}.terms-section ul{padding:0;list-style:none}.terms-section li{padding:6px 0 6px 4px}.terms-back{margin-top:var(--space-3xl);text-align:center}@media (max-width:1024px){.hero h1{font-size:48px}.bento-hero{flex-direction:column;grid-column:span 12;min-height:auto}.bento-normal{grid-column:span 6}}@media (max-width:768px){.hero h1{font-size:36px}.hero p{font-size:16px}.bento-hero,.bento-normal{grid-column:span 12}.hero-actions{flex-direction:column;align-items:center}.features-header h2{font-size:28px}}@media (max-width:480px){.hero h1{font-size:28px}}
.tap-app{color:#e4e4e7;-webkit-user-select:none;user-select:none;background:#09090b;flex-direction:column;height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;display:flex;overflow:hidden}.tap-app-embedded{background:var(--bg-base,#09090b);height:calc(100vh - 64px);color:var(--text-primary,#e4e4e7);-webkit-user-select:none;user-select:none;flex-direction:row;flex:1;margin-top:64px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;display:flex;overflow:hidden}.tap-topbar-actions{align-items:center;gap:6px;display:flex}.tap-topbar{z-index:100;background:#0a0a0c;border-bottom:1px solid #27272a;flex-shrink:0;justify-content:space-between;align-items:center;height:48px;padding:0 12px;display:flex}.tap-topbar-left{align-items:center;gap:12px;display:flex}.tap-topbar-right{align-items:center;gap:6px;display:flex}.tap-logo{align-items:center;gap:8px;display:flex}.tap-logo-text{letter-spacing:.02em;color:#fafafa;font-size:14px;font-weight:600}.tap-project-name{color:#71717a;cursor:pointer;border-radius:4px;padding:2px 8px;font-size:12px;transition:all .2s}.tap-project-name:hover{color:#a1a1aa;background:#18181b}.tap-project-input{color:#e4e4e7;background:#18181b;border:1px solid #3f3f46;border-radius:4px;outline:none;min-width:100px;max-width:200px;padding:2px 8px;font-size:12px}.tap-btn{cursor:pointer;color:#a1a1aa;background:#27272a;border:none;border-radius:6px;align-items:center;gap:4px;padding:6px 10px;font-size:12px;font-weight:500;transition:all .2s;display:inline-flex}.tap-btn:hover{color:#e4e4e7;background:#3f3f46}.tap-btn:disabled{opacity:.4;cursor:not-allowed}.tap-btn svg{width:14px;height:14px}.tap-btn-primary{color:#fff;background:#2563eb}.tap-btn-primary:hover{background:#3b82f6}.tap-btn-danger{color:#fff;background:#dc2626;animation:1.5s ease-in-out infinite tap-pulse}@keyframes tap-pulse{0%,to{opacity:1}50%{opacity:.8}}.tap-save-msg{color:#60a5fa;padding:0 8px;font-size:11px}.tap-main{flex:1;display:flex;position:relative;overflow:hidden}.tap-sidebar{z-index:90;background:#0a0a0c;border-right:1px solid #27272a;flex-direction:column;flex-shrink:0;align-items:center;gap:4px;width:48px;padding:8px 0;display:flex}.tap-side-spacer{flex:1}.tap-side-btn{color:#71717a;cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;transition:all .2s;display:flex}.tap-side-btn:hover{color:#d4d4d8;background:#27272a}.tap-side-btn.active{color:#60a5fa;background:#27272a}.tap-side-btn svg{width:18px;height:18px}.tap-panel{z-index:80;color:#e4e4e7;background:#0f0f12;border-right:1px solid #27272a;flex-direction:column;width:260px;animation:.2s tap-slide-in;display:flex;position:absolute;top:0;bottom:0;left:48px}@keyframes tap-slide-in{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.tap-panel-header{color:#fafafa;border-bottom:1px solid #27272a;justify-content:space-between;align-items:center;padding:14px 16px;font-size:13px;font-weight:600;display:flex}.tap-panel-close{color:#71717a;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px;transition:all .2s;display:flex}.tap-panel-close:hover{color:#e4e4e7;background:#27272a}.tap-panel-close svg{width:16px;height:16px}.tap-panel-body{flex:1;padding:8px;overflow-y:auto}.tap-add-section{margin-bottom:12px}.tap-add-section-title{color:inherit;opacity:.5;text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px;padding:4px 8px;font-size:10px;font-weight:600}.tap-add-item{width:100%;color:var(--text-primary,#e4e4e7);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;padding:8px 10px;transition:all .15s;display:flex}.tap-add-item:hover{background:#7c5cfc14}.tap-add-item-icon{color:#7c5cfc;background:#7c5cfc1f;border:1px solid #7c5cfc33;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.tap-add-item-icon svg{width:16px;height:16px}.tap-add-item-info{min-width:0}.tap-add-item-name{color:inherit;font-size:13px;font-weight:600}.tap-add-item-desc{color:inherit;opacity:.6;margin-top:1px;font-size:11px}.tap-add-item[data-type=aiGenerate] .tap-add-item-icon{color:#7c5cfc;background:#7c5cfc1f;border-color:#7c5cfc40}.tap-add-item[data-type=aiVideo] .tap-add-item-icon{color:#06b6d4;background:#06b6d41f;border-color:#06b6d440}.tap-add-item[data-type=upscale] .tap-add-item-icon{color:#34d399;background:#34d3991f;border-color:#34d39940}.tap-add-item[data-type=changeBg] .tap-add-item-icon{color:#f472b6;background:#f472b61f;border-color:#f472b640}.tap-add-item[data-type=controlNet] .tap-add-item-icon{color:#fbbf24;background:#fbbf241f;border-color:#fbbf2440}.tap-add-item[data-type=conditional] .tap-add-item-icon{color:#fb923c;background:#fb923c1f;border-color:#fb923c40}.tap-add-item[data-type=imageInput] .tap-add-item-icon{color:#60a5fa;background:#60a5fa1f;border-color:#60a5fa40}.tap-add-item[data-type=videoInput] .tap-add-item-icon{color:#818cf8;background:#818cf81f;border-color:#818cf840}.tap-add-item[data-type=textPrompt] .tap-add-item-icon{color:#a78bfa;background:#a78bfa1f;border-color:#a78bfa40}.tap-add-item[data-type=output] .tap-add-item-icon{color:#34d399;background:#34d3991f;border-color:#34d39940}.tap-add-item[data-type=dataSource] .tap-add-item-icon{color:#94a3b8;background:#94a3b81f;border-color:#94a3b840}.tap-add-item[data-type=export] .tap-add-item-icon{color:#2dd4bf;background:#2dd4bf1f;border-color:#2dd4bf40}.tap-template-card{color:#d4d4d8;cursor:pointer;text-align:left;background:#18181b;border:1px solid #27272a;border-radius:8px;width:100%;margin-bottom:6px;padding:12px;transition:all .2s;display:block}.tap-template-card:hover{background:#1c1c20;border-color:#3f3f46}.tap-template-name{margin-bottom:4px;font-size:13px;font-weight:600}.tap-template-desc{color:#71717a;font-size:11px}.tap-canvas{cursor:default;background:#09090b;flex:1;position:relative;overflow:hidden}.tap-canvas-bg{pointer-events:none;opacity:.5;background-image:radial-gradient(circle,#27272a .8px,#0000 .8px);background-size:24px 24px;position:absolute;inset:-5000px}.tap-nodes-layer{pointer-events:none;position:absolute;top:0;left:0}.tap-connections-svg{pointer-events:none;z-index:1;position:absolute;inset:0;overflow:visible}.tap-node-wrapper{pointer-events:auto;cursor:grab;background:#18181b;border:1px solid #27272a;border-radius:10px;min-height:80px;transition:box-shadow .2s,border-color .2s;position:absolute}.tap-node-wrapper:hover{border-color:#3f3f46;box-shadow:0 4px 20px #0006}.tap-node-wrapper.selected{border-color:#60a5fa;box-shadow:0 0 0 1px #60a5fa,0 4px 24px #60a5fa26}.tap-node-wrapper.running{border-color:#f59e0b;box-shadow:0 0 0 1px #f59e0b,0 0 20px #f59e0b26}.tap-node-wrapper.error{border-color:#ef4444}.tap-node-wrapper.done{border-color:#22c55e}.tap-node-wrapper:active{cursor:grabbing}.tap-node-header{background:#141416;border-bottom:1px solid #27272a;border-radius:10px 10px 0 0;align-items:center;gap:6px;padding:8px 12px;font-size:12px;font-weight:600;display:flex}.tap-node-header.ntype-imageInput{border-top:2px solid #60a5fa}.tap-node-header.ntype-videoInput{border-top:2px solid #a78bfa}.tap-node-header.ntype-textPrompt{border-top:2px solid #fbbf24}.tap-node-header.ntype-aiGenerate{border-top:2px solid #f472b6}.tap-node-header.ntype-aiVideo{border-top:2px solid #c084fc}.tap-node-header.ntype-upscale{border-top:2px solid #34d399}.tap-node-header.ntype-changeBg{border-top:2px solid #06b6d4}.tap-node-header.ntype-output{border-top:2px solid #f97316}.tap-node-header.ntype-controlNet{border-top:2px solid #8b5cf6}.tap-node-header.ntype-conditional{border-top:2px solid #eab308}.tap-node-header.ntype-dataSource{border-top:2px solid #14b8a6}.tap-node-header.ntype-export{border-top:2px solid #ec4899}.tap-node-icon{color:#a1a1aa;display:flex}.tap-node-icon svg{width:14px;height:14px}.tap-node-title{color:#d4d4d8;flex:1}.tap-node-status-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.tap-node-status-dot.running{background:#f59e0b;animation:1s infinite tap-pulse;box-shadow:0 0 6px #f59e0b}.tap-node-status-dot.done{background:#22c55e;box-shadow:0 0 6px #22c55e}.tap-node-status-dot.error{background:#ef4444;box-shadow:0 0 6px #ef4444}.tap-node-body{padding:10px 12px}.tap-node-textarea{color:#e4e4e7;resize:vertical;-webkit-user-select:text;user-select:text;background:#0f0f12;border:1px solid #27272a;border-radius:6px;outline:none;width:100%;min-height:60px;padding:8px;font-family:inherit;font-size:12px;line-height:1.5}.tap-node-textarea:focus{border-color:#3f3f46}.tap-node-char-count{color:#52525b;text-align:right;margin-top:4px;font-size:10px}.tap-node-select{color:#e4e4e7;cursor:pointer;-webkit-user-select:none;user-select:none;background:#0f0f12;border:1px solid #27272a;border-radius:6px;outline:none;width:100%;margin-bottom:6px;padding:6px 8px;font-size:12px}.tap-node-preview{background:#0f0f12;border-radius:6px;margin-top:6px;position:relative;overflow:hidden}.tap-node-preview img{border-radius:6px;width:100%;display:block}.tap-preview-remove,.tap-preview-download{color:#fff;cursor:pointer;background:#0009;border:none;border-radius:6px;justify-content:center;align-items:center;width:24px;height:24px;text-decoration:none;transition:background .2s;display:flex;position:absolute;top:6px;right:6px}.tap-preview-remove:hover{background:#ef4444}.tap-preview-download:hover{background:#2563eb}.tap-preview-remove svg,.tap-preview-download svg{width:12px;height:12px}.tap-node-upload{cursor:pointer;color:#71717a;border:1px dashed #3f3f46;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:6px;min-height:80px;padding:16px;font-size:12px;transition:all .2s;display:flex}.tap-node-upload:hover{color:#a1a1aa;background:#60a5fa0d;border-color:#60a5fa}.tap-upload-icon{color:#52525b}.tap-upload-icon svg{width:24px;height:24px}.tap-node-info{color:#71717a;padding:4px 0;font-size:12px}.tap-node-error{color:#ef4444;background:#ef44441a;border-radius:4px;margin-top:4px;padding:4px 6px;font-size:11px}.tap-node-slider-row{color:#a1a1aa;align-items:center;gap:8px;margin-top:4px;font-size:11px;display:flex}.tap-node-slider-row input[type=range]{accent-color:#60a5fa;flex:1;height:4px}.tap-port{cursor:crosshair;z-index:10;pointer-events:auto;border:2px solid #18181b;border-radius:50%;width:12px;height:12px;transition:transform .15s,box-shadow .15s;position:absolute}.tap-port:hover{transform:scale(1.4);box-shadow:0 0 8px}.tap-port-input{left:-6px}.tap-port-output{right:-6px}.tap-port-label{color:#71717a;white-space:nowrap;pointer-events:none;font-size:9px;position:absolute;top:50%;transform:translateY(-50%)}.tap-port-label-left{right:18px}.tap-port-label-right{left:18px}.tap-empty{text-align:center;z-index:5;pointer-events:auto;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.tap-empty-icon{color:#3f3f46;margin-bottom:16px}.tap-empty-icon svg{width:48px;height:48px}.tap-empty-title{color:#d4d4d8;margin-bottom:8px;font-size:20px;font-weight:600}.tap-empty-desc{color:#71717a;margin-bottom:20px;font-size:13px}.tap-empty-actions{justify-content:center;gap:8px;display:flex}.tap-empty-btn{color:#d4d4d8;cursor:pointer;background:#18181b;border:1px solid #27272a;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-size:13px;transition:all .2s;display:inline-flex}.tap-empty-btn:hover{color:#fff;background:#60a5fa14;border-color:#60a5fa}.tap-empty-btn svg{width:16px;height:16px}.tap-progress{z-index:50;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#09090be6;border-bottom:1px solid #27272a;padding:8px 16px;position:absolute;top:0;left:0;right:0}.tap-progress-info{color:#a1a1aa;justify-content:space-between;margin-bottom:6px;font-size:11px;display:flex}.tap-progress-track{background:#27272a;border-radius:2px;height:3px;overflow:hidden}.tap-progress-fill{background:linear-gradient(90deg,#2563eb,#60a5fa);border-radius:2px;height:100%;transition:width .4s}.tap-runlog{z-index:40;background:#0f0f12f2;border:1px solid #27272a;border-radius:8px;max-width:360px;max-height:200px;padding:10px 12px;font-family:Courier New,monospace;font-size:11px;position:absolute;bottom:12px;left:12px;overflow-y:auto}.tap-runlog-line{color:#a1a1aa;padding:2px 0;line-height:1.4}.tap-picker-overlay{z-index:200;position:fixed;inset:0}.tap-picker{z-index:201;background:#141416;border:1px solid #27272a;border-radius:10px;min-width:200px;max-height:400px;padding:8px;animation:.15s tap-slide-in;position:fixed;overflow-y:auto;box-shadow:0 8px 32px #00000080}.tap-picker-header{color:#a1a1aa;border-bottom:1px solid #27272a;margin-bottom:4px;padding:4px 8px 8px;font-size:12px;font-weight:600}.tap-picker-section{margin-bottom:6px}.tap-picker-section-title{color:#52525b;text-transform:uppercase;letter-spacing:.05em;padding:4px 8px 2px;font-size:10px}.tap-picker-item{color:#d4d4d8;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:6px;align-items:center;gap:8px;width:100%;padding:6px 8px;font-size:12px;transition:background .15s;display:flex}.tap-picker-item:hover{background:#1c1c20}.tap-picker-item-icon{color:#71717a}.tap-picker-item-icon svg{width:14px;height:14px}.tap-context-menu{z-index:300;background:#141416;border:1px solid #27272a;border-radius:8px;min-width:160px;padding:4px;position:fixed;box-shadow:0 8px 24px #00000080}.tap-ctx-item{color:#d4d4d8;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:6px;align-items:center;gap:8px;width:100%;padding:8px 12px;font-size:12px;transition:background .15s;display:flex}.tap-ctx-item:hover{background:#1c1c20}.tap-ctx-item svg{color:#71717a;width:14px;height:14px}.tap-ctx-danger:hover{color:#ef4444;background:#ef44441a}.tap-ctx-danger:hover svg{color:#ef4444}.tap-history-panel{z-index:50;background:#0f0f12;border-left:1px solid #27272a;flex-shrink:0;width:300px;animation:.2s tap-history-in;overflow-y:auto}@keyframes tap-history-in{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}[data-theme=light] .tap-app{color:#18181b;background:#fafafa}[data-theme=light] .tap-topbar{background:#fff;border-color:#e4e4e7}[data-theme=light] .tap-logo-text{color:#18181b}[data-theme=light] .tap-project-name{color:#71717a}[data-theme=light] .tap-project-name:hover{color:#3f3f46;background:#f4f4f5}[data-theme=light] .tap-project-input{color:#18181b;background:#fff;border-color:#d4d4d8}[data-theme=light] .tap-btn{color:#52525b;background:#f4f4f5}[data-theme=light] .tap-btn:hover{color:#18181b;background:#e4e4e7}[data-theme=light] .tap-sidebar{background:#fff;border-color:#e4e4e7}[data-theme=light] .tap-side-btn{color:#71717a}[data-theme=light] .tap-side-btn:hover{color:#18181b;background:#f4f4f5}[data-theme=light] .tap-side-btn.active{color:#2563eb;background:#eff6ff}[data-theme=light] .tap-app-embedded{color:#1a1a2e}[data-theme=light] .tap-panel{color:#1a1a2e;background:#fff;border-color:#e4e4e7}[data-theme=light] .tap-panel-header{color:#18181b;border-color:#e4e4e7}[data-theme=light] .tap-panel-close{color:#71717a}[data-theme=light] .tap-panel-close:hover{color:#18181b;background:#f4f4f5}[data-theme=light] .tap-add-section-title{color:#6b7280}[data-theme=light] .tap-add-item{color:#1a1a2e}[data-theme=light] .tap-add-item:hover{background:#6341e00f}[data-theme=light] .tap-add-item-name{color:#1a1a2e}[data-theme=light] .tap-add-item-desc{color:#4a5568}[data-theme=light] .tap-add-item-icon{color:#6341e0;background:#6341e01a;border-color:#6341e033}[data-theme=light] .tap-template-card{color:#18181b;background:#f4f4f5;border-color:#e4e4e7}[data-theme=light] .tap-template-card:hover{background:#fff;border-color:#d4d4d8}[data-theme=light] .tap-canvas{background:#fafafa}[data-theme=light] .tap-canvas-bg{background-image:radial-gradient(circle,#d4d4d8 .8px,#0000 .8px)}[data-theme=light] .tap-node-wrapper{background:#fff;border-color:#e4e4e7;box-shadow:0 1px 4px #0000000f}[data-theme=light] .tap-node-wrapper:hover{border-color:#d4d4d8;box-shadow:0 4px 16px #0000001a}[data-theme=light] .tap-node-wrapper.selected{border-color:#3b82f6;box-shadow:0 0 0 1px #3b82f6,0 4px 16px #3b82f626}[data-theme=light] .tap-node-header{background:#f9fafb;border-color:#e4e4e7}[data-theme=light] .tap-node-title,[data-theme=light] .tap-node-body{color:#18181b}[data-theme=light] .tap-node-textarea,[data-theme=light] .tap-node-select{color:#18181b;background:#f4f4f5;border-color:#e4e4e7}[data-theme=light] .tap-node-upload{color:#71717a;border-color:#d4d4d8}[data-theme=light] .tap-node-upload:hover{background:#3b82f60d;border-color:#3b82f6}[data-theme=light] .tap-node-info{color:#71717a}[data-theme=light] .tap-port{border-color:#fff}[data-theme=light] .tap-empty-title{color:#18181b}[data-theme=light] .tap-empty-btn{color:#18181b;background:#fff;border-color:#e4e4e7}[data-theme=light] .tap-empty-btn:hover{background:#3b82f60d;border-color:#3b82f6}[data-theme=light] .tap-progress{background:#fafafaf2;border-color:#e4e4e7}[data-theme=light] .tap-runlog{background:#fffffff2;border-color:#e4e4e7}[data-theme=light] .tap-runlog-line{color:#3f3f46}[data-theme=light] .tap-picker{background:#fff;border-color:#e4e4e7;box-shadow:0 8px 32px #0000001f}[data-theme=light] .tap-picker-item:hover{background:#f4f4f5}[data-theme=light] .tap-context-menu{background:#fff;border-color:#e4e4e7;box-shadow:0 8px 24px #0000001f}[data-theme=light] .tap-ctx-item:hover{background:#f4f4f5}[data-theme=light] .tap-ctx-item{color:#18181b}[data-theme=light] .tap-history-panel{background:#fff;border-color:#e4e4e7}
