*,:before,:after{box-sizing:border-box;margin:0;padding:0}button,a{touch-action:manipulation}button:disabled{opacity:var(--disabled-opacity);cursor:not-allowed;filter:grayscale(.25);box-shadow:none!important;animation:none!important;transform:none!important}html,body{overscroll-behavior:none}:root{--bg:#07060f;--bg2:#0d0c1a;--bg3:#151426;--border:#7c6af738;--border-subtle:#7c6af71a;--accent:#8b76ff;--danger:#ff6b6b;--accent3:#5ef5c0;--text:#f0f0f8;--text2:#b0a8d8;--text3:#6a6490;--text-chat:#d8d4f0;--surface:var(--bg2);--muted:var(--text3);--accent-hover:#7865f0;--disabled-opacity:.4;--accent-muted:#7c6af71f;--accent-subtle:#7c6af70f;--accent-glow:#7c6af759;--accent3-muted:#6af7c81f;--accent3-subtle:#6af7c80f;--accent3-glow:#6af7c847;--surface2:#ffffff0d;--fs-2xs:9px;--fs-xs:10px;--fs-sm:11px;--fs-base:12px;--fs-md:13px;--fs-lg:14px;--fs-xl:16px;--fs-2xl:18px;--fs-3xl:22px;--fs-hero:72px;--sp-1:4px;--sp-2:8px;--sp-3:12px;--sp-4:16px;--sp-5:20px;--sp-6:24px;--sp-8:32px;--r-sm:5px;--r-md:8px;--r-lg:12px;--r-xl:16px;--r-2xl:22px;--r-full:9999px;--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 12px 40px #0006;--shadow-lg:0 24px 64px #0009;--shadow-accent:0 4px 20px var(--accent-glow);--shadow-accent3:0 4px 16px var(--accent3-glow);--font-display:"Syne",sans-serif;--font-mono:"Space Mono",monospace;--font-sans:-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--safe-top:env(safe-area-inset-top,0px);--safe-bottom:env(safe-area-inset-bottom,0px);--safe-left:env(safe-area-inset-left,0px);--safe-right:env(safe-area-inset-right,0px)}html,body{height:100%;color:var(--text);font-family:var(--font-mono);overflow:hidden}body{background:radial-gradient(ellipse 110% 55% at 50% -5%,#8b76ff1a 0%,transparent 60%),radial-gradient(ellipse 60% 40% at 90% 100%,#5ef5c00d 0%,transparent 55%),var(--bg)}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.app-root{flex-direction:column;height:100vh;display:flex}.pro-crown-strip{background:linear-gradient(90deg,var(--accent)0%,var(--accent3)50%,var(--accent)100%);z-index:9999;pointer-events:none;background-size:200% 100%;height:2px;animation:4s linear infinite crownShimmer;position:fixed;top:0;left:0;right:0}@keyframes crownShimmer{0%{background-position:0 0}to{background-position:200% 0}}.pro-chip{color:var(--accent);letter-spacing:1.5px;text-transform:uppercase;background:linear-gradient(135deg,#8b76ff2e,#5ef5c01f);border:1px solid #8b76ff59;border-radius:20px;align-items:center;padding:2px 8px;font-family:Courier New,monospace;font-size:9px;font-weight:800;animation:3s ease-in-out infinite chipGlow;display:inline-flex}@keyframes chipGlow{0%,to{box-shadow:0 0 #0000}50%{box-shadow:0 0 8px 1px #8b76ff4d}}.app-header{padding:env(safe-area-inset-top)20px 0;height:calc(56px + env(safe-area-inset-top));border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(12px);z-index:20;background:linear-gradient(#0d0c1af2 0%,#0d0c1ad9 100%);flex-shrink:0;align-items:center;gap:24px;display:flex}.logo{align-items:center;gap:8px;display:flex}.logo-home{cursor:pointer;transition:opacity .15s}.logo-home:hover{opacity:.75}.header-nav{align-items:center;gap:12px;margin-left:auto;display:flex}.tab-switcher{background:var(--bg3);border:1px solid var(--border);border-radius:var(--r-lg);scrollbar-width:none;-ms-overflow-style:none;flex-shrink:1;gap:1px;min-width:0;padding:3px;display:flex;overflow:auto hidden}.tab-switcher::-webkit-scrollbar{display:none}.tab-btn{color:var(--text2);font-family:var(--font-mono);letter-spacing:1px;cursor:pointer;border-radius:var(--r-md);background:0 0;border:none;padding:5px 16px;font-size:11px;transition:all .15s cubic-bezier(.16,1,.3,1)}.tab-btn:hover:not(.active){color:var(--text);background:#ffffff0d;transform:translateY(-1px)}.tab-btn:active{transform:scale(.94)}.tab-btn.active{background:var(--accent);color:#fff}.tab-btn-debug{color:var(--text3);border-left:1px solid var(--border);letter-spacing:0;margin-left:4px;padding-left:12px}.tab-btn-debug:hover:not(.active){color:var(--text2);background:#ffffff0a}.tab-btn-debug.active{color:var(--accent3);background:#6af7c81a}.debug-panel{height:100%;font-family:var(--font-mono);background:#0d0d1a;flex-direction:column;font-size:11px;display:flex}.debug-header{background:#111;border-bottom:1px solid #222;justify-content:space-between;align-items:center;padding:8px 14px;display:flex}.debug-title{color:#666;letter-spacing:1px;text-transform:uppercase;font-size:10px}.debug-clear{color:#555;border-radius:var(--r-sm);cursor:pointer;font-size:10px;font-family:var(--font-mono);background:0 0;border:1px solid #333;padding:2px 8px;transition:all .15s}.debug-clear:hover{color:#888;border-color:#555}.debug-tabs{border-bottom:1px solid #1a1a1a;display:flex}.debug-tab{color:#444;cursor:pointer;font-family:var(--font-mono);background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:5px;font-size:10px;transition:all .15s}.debug-tab:hover{color:#666}.debug-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.debug-body{flex:1;overflow:hidden}.debug-scroll{height:100%;padding:8px;overflow-y:auto}.debug-empty{color:#333;text-align:center;margin-top:24px}.debug-event{margin-bottom:4px;padding-left:8px;line-height:1.5}.debug-event-chunk{border-left:2px solid #333}.debug-event-done{border-left:2px solid #0f8}.debug-event-error{border-left:2px solid #f44}.debug-event-info{border-left:2px solid #48f}.debug-time{color:#444}.debug-event-chunk .debug-type{color:#555}.debug-event-done .debug-type{color:#0f8}.debug-event-error .debug-type{color:#f44}.debug-event-info .debug-type{color:#48f}.debug-data{color:#aaa;word-break:break-all}.debug-raw{color:#aaa;white-space:pre-wrap;word-break:break-all;margin:0;font-size:10px}.debug-footer{color:#333;border-top:1px solid #1a1a1a;padding:4px 10px;font-size:10px}.header-controls{align-items:center;gap:6px;display:flex}.icon-btn{color:var(--text2);cursor:pointer;border-radius:var(--r-md);background:0 0;border:1px solid #0000;padding:5px 8px;font-size:13px;transition:all .2s cubic-bezier(.16,1,.3,1)}.icon-btn:hover{border-color:var(--border);color:var(--text);transform:translateY(-1px)}.icon-btn:active{transform:scale(.93)}.icon-btn.active{border-color:var(--accent);color:var(--accent);animation:2s ease-in-out infinite breathe}.icon-btn.incognito-active{border-color:var(--danger);color:var(--danger);animation:1.5s ease-in-out infinite pulse}.donate-header-btn{color:var(--accent3);cursor:pointer;letter-spacing:.5px;background:linear-gradient(135deg,#8b76ff1f,#5ef5c014);border:1px solid #8b76ff4d;border-radius:20px;align-items:center;gap:5px;padding:5px 12px;font-size:12px;font-weight:600;text-decoration:none;transition:all .25s cubic-bezier(.16,1,.3,1);display:inline-flex}@keyframes donateFloat{0%,to{transform:translateY(0);box-shadow:0 0 #0000}50%{transform:translateY(-2px);box-shadow:0 4px 14px #5ef5c033}}.donate-header-btn:hover{border-color:var(--accent3);color:#fff;background:linear-gradient(135deg,#8b76ff38,#5ef5c029);animation:none;transform:translateY(-2px);box-shadow:0 4px 18px #5ef5c047}.share-btn{background:var(--accent);color:#fff;cursor:pointer;border-radius:var(--r-md);font-size:12px;font-weight:600;font-family:var(--font-mono);border:none;padding:5px 12px;transition:all .2s cubic-bezier(.16,1,.3,1)}.share-btn:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 4px 14px #8b5cf666}.share-btn:active{transform:scale(.95)}.share-btn:disabled{opacity:.5;cursor:not-allowed;animation:none}.header-status{border-left:1px solid var(--border);align-items:center;gap:6px;margin-left:2px;padding-left:10px;display:flex}.status-dot{font-size:10px}.status-dot.ready{color:var(--text3)}.status-dot.generating{color:var(--accent3);animation:1s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes floatSlow{0%,to{transform:translateY(0)rotate(0)}50%{transform:translateY(-5px)rotate(2deg)}}@keyframes breathe{0%,to{opacity:.7;transform:scale(1)}50%{opacity:1;transform:scale(1.04)}}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes staggerFade{0%{opacity:0;transform:translateY(8px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes glowPulse{0%,to{box-shadow:0 0 #0000}50%{box-shadow:0 0 20px 4px var(--accent-glow,#8b5cf640)}}@keyframes scanLine{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes orbitSpin{to{transform:rotate(360deg)}}.spinner{vertical-align:middle;border:2px solid;border-top-color:#0000;border-radius:50%;width:12px;height:12px;animation:.7s linear infinite spin;display:inline-block}.status-text{color:var(--text3);font-size:11px}.app-body{flex:1;display:flex;position:relative;overflow:hidden}.sidebar{background:var(--bg);border-right:1px solid var(--border-subtle);flex-direction:column;height:100%;min-height:0;display:flex}.sidebar-section:last-child{flex:1;min-height:0;overflow:hidden}.sidebar-files{scrollbar-width:none;flex-direction:column;flex:1;min-height:0;padding:0 8px 12px;display:flex;overflow-y:auto}.sidebar-files::-webkit-scrollbar{display:none}.sidebar-section .no-files{font-size:var(--fs-sm);color:var(--text3);text-align:center;flex:1;justify-content:center;align-items:center;padding:24px 16px;line-height:1.6;display:flex}.file-item{border-radius:var(--r-md);font-size:var(--fs-base);cursor:pointer;color:var(--text2);border-left:2px solid #0000;align-items:center;gap:8px;margin-bottom:1px;padding:7px 10px 7px 8px;transition:background .15s,color .15s,border-color .15s;display:flex;position:relative}.file-item:hover{background:var(--accent-subtle);color:var(--text)}.file-item.active{background:var(--accent3-muted);color:var(--accent3);border-left-color:var(--accent3)}.file-item:hover .file-download-btn,.file-item.active .file-download-btn{opacity:1}.file-download-btn{opacity:0;flex-shrink:0;transition:opacity .15s}.file-icon{font-size:var(--fs-2xs);font-weight:700;font-family:var(--font-mono);color:var(--text3);background:var(--bg3);border:1px solid var(--border-subtle);letter-spacing:0;text-align:center;border-radius:3px;flex-shrink:0;min-width:26px;padding:1px 4px;line-height:14px}.file-item.active .file-icon{color:var(--accent3);background:var(--accent3-muted);border-color:#6af7c840}.file-name{text-overflow:ellipsis;white-space:nowrap;font-size:var(--fs-base);flex:1;overflow:hidden}.no-files{padding:var(--sp-4)var(--sp-3);font-size:var(--fs-sm);color:var(--text3);text-align:center;line-height:1.6}.main-content{flex:1;position:relative;overflow:hidden}.panel{height:100%;display:none}.chat-panel{flex-direction:column;height:100%;display:flex}.chat-messages{flex-direction:column;flex:1;gap:24px;padding:24px;display:flex;overflow-y:auto}.chat-empty{color:var(--text3);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:14px;display:flex}.chat-empty-logo{background:linear-gradient(135deg,var(--accent),var(--accent3));width:56px;height:56px;font-family:var(--font-mono);color:var(--bg);border-radius:14px;justify-content:center;align-items:center;font-size:22px;font-weight:700;animation:3s ease-in-out infinite float,3s ease-in-out infinite glowPulse;display:flex}.chat-empty-title{font-family:var(--font-mono);letter-spacing:3px;color:var(--text);font-size:16px;font-weight:700}.chat-empty-sub{font-size:14px;font-family:var(--font-sans);color:var(--text3);text-align:center;max-width:280px;line-height:1.7}.chat-suggestions{flex-wrap:wrap;justify-content:center;gap:8px;margin-top:4px;display:flex}.suggestion-btn{background:var(--accent-subtle);border:1px solid var(--border);color:var(--text2);font-family:var(--font-sans);cursor:pointer;border-radius:var(--r-full);padding:7px 16px;font-size:12px;transition:all .15s}.suggestion-btn:hover{border-color:var(--accent);color:var(--accent)}.message{border-radius:var(--r-xl);border:1px solid #0000;flex-direction:column;gap:6px;max-width:100%;padding:14px 18px;animation:.3s cubic-bezier(.16,1,.3,1) forwards messageIn;display:flex}.message.user{background:#8b76ff14;border-color:#8b76ff2e}.message.assistant{background:#5ef5c00d;border-color:#5ef5c01f}.message-role{letter-spacing:2px;text-transform:uppercase;font-size:10px;font-family:var(--font-mono);margin-bottom:4px}.message.user .message-role{color:var(--accent)}.message.assistant .message-role{color:var(--accent3)}.message-content{font-size:14px;line-height:1.85;font-family:var(--font-sans);color:var(--text);word-break:break-word}.message.assistant .message-content{color:var(--text-chat)}.support-nudge{background:var(--accent-muted);border:1px solid var(--border);border-radius:8px;flex-wrap:wrap;align-items:center;gap:12px;margin:0 0 10px;padding:10px 14px;display:flex}.support-nudge-icon{color:var(--accent);flex-shrink:0;font-size:14px}.support-nudge-text{min-width:0;color:var(--text2);flex:1;align-items:baseline;gap:8px;font-size:12px;display:flex}.support-nudge-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.support-nudge-btn{background:var(--accent);color:#000;font-family:var(--font-mono);cursor:pointer;border:none;border-radius:5px;padding:5px 12px;font-size:11px;font-weight:700;text-decoration:none;transition:opacity .15s}.support-nudge-btn:hover{opacity:.85}.support-nudge-dismiss{color:var(--text3);font-family:var(--font-mono);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 6px;font-size:11px;transition:color .15s}.support-nudge-dismiss:hover{color:var(--text2)}.chat-input-area{border-top:1px solid var(--border);background:linear-gradient(0deg,var(--bg3)0%,var(--bg2)100%);padding:16px 24px;padding-bottom:calc(16px + env(safe-area-inset-bottom));flex-direction:column;gap:8px;padding-right:72px;display:flex}@media (max-width:600px){.chat-input-area{padding-right:24px}}.chat-textarea{background:var(--bg);border:1px solid var(--border);color:var(--text);font-family:var(--font-sans);border-radius:var(--r-lg);resize:none;outline:none;flex:1;min-height:44px;max-height:200px;padding:12px 14px;font-size:14px;line-height:1.5;transition:border-color .2s,box-shadow .2s}.chat-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #8b76ff26}.chat-textarea::placeholder{color:var(--text3)}.send-btn{background:var(--accent);color:#fff;height:44px;font-family:var(--font-mono);letter-spacing:1px;cursor:pointer;border-radius:var(--r-lg);text-transform:uppercase;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:0 20px;font-size:12px;transition:all .15s cubic-bezier(.16,1,.3,1);display:flex;box-shadow:0 0 #7c6af700}.send-btn:hover{background:var(--accent-hover)}.send-btn:disabled{opacity:.4;cursor:not-allowed}.discard-btn{border:1px solid var(--danger,#ff4d4d);color:var(--danger,#ff4d4d);font-size:11px;font-family:var(--font-mono);letter-spacing:.05em;border-radius:var(--r-sm);cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;background:0 0;align-self:flex-start;margin-bottom:6px;padding:4px 12px;transition:background .15s,color .15s}.discard-btn:hover{background:#ff4d4d1f}.chat-input-row{align-items:flex-end;gap:8px;display:flex}.upload-btn{background:var(--bg3);border:1px solid var(--border);width:44px;height:44px;color:var(--text2);cursor:pointer;border-radius:var(--r-lg);flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:16px;line-height:1;transition:all .15s;display:flex}.upload-btn:hover{background:var(--bg);border-color:var(--accent);color:var(--accent)}.upload-btn:disabled{opacity:.4;cursor:not-allowed}.audio-toggle-btn{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);cursor:pointer;white-space:nowrap;flex-shrink:0;height:44px;padding:0 12px;font-size:16px;transition:border-color .15s,background .15s;overflow:hidden}.audio-toggle-btn:hover{border-color:var(--accent);background:var(--bg)}.audio-toggle-btn--on{border-color:var(--accent);background:#7c6af71f}.audio-toggle-btn:disabled{opacity:.4;cursor:not-allowed}.voice-btn{border-radius:var(--r-lg);border:1px solid var(--border);background:var(--bg3);width:44px;height:44px;color:var(--text3);cursor:pointer;-webkit-tap-highlight-color:transparent;flex-shrink:0;justify-content:center;align-items:center;font-size:15px;transition:color .2s,border-color .2s,background .2s,box-shadow .2s;display:flex}.voice-btn--idle:hover{border-color:var(--accent);color:var(--accent);background:var(--bg)}.voice-btn--listening{border-color:var(--accent);color:var(--accent);background:#7c6af71a;animation:1.8s ease-in-out infinite voice-pulse}.voice-btn--activated{color:#22c55e;background:#22c55e1f;border-color:#22c55e;box-shadow:0 0 8px #22c55e59}.voice-btn--unsupported{opacity:.3;cursor:not-allowed}.voice-btn:disabled{opacity:.4;cursor:not-allowed;animation:none}.voice-error{color:#f87171;padding:4px 8px;font-size:11px}.voice-hint{color:var(--text3);padding:4px 8px;font-size:11px;animation:2s ease-in-out infinite voice-pulse}.mobile-input-overlay{display:none}@media (max-width:768px){.mobile-input-overlay{-webkit-backdrop-filter:blur(6px);z-index:9000;background:#000000ad;align-items:flex-start;padding-top:20px;padding-left:12px;padding-right:12px;display:flex;position:fixed;inset:0}.mobile-input-sheet{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-xl);width:100%;box-shadow:0 0 0 1px var(--border-subtle),var(--shadow-lg),0 0 40px var(--accent-glow);flex-direction:column;padding:0;display:flex;overflow:hidden}.mobile-input-header{border-bottom:1px solid var(--border-subtle);align-items:center;gap:10px;padding:14px 16px 12px;display:flex}.mobile-input-mark{font-family:var(--font-mono);color:var(--accent);letter-spacing:.5px;flex-shrink:0;font-size:13px;font-weight:700}.mobile-input-label{font-family:var(--font-mono);color:var(--text3);letter-spacing:.8px;text-transform:uppercase;flex:1;font-size:11px}.mobile-input-close{color:var(--text3);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:2px 4px;font-size:14px;line-height:1;transition:color .15s}.mobile-input-close:active{color:var(--text)}.mobile-input-textarea{border:none;border-bottom:1px solid var(--border-subtle);width:100%;color:var(--text);font-size:15px;font-family:var(--font-sans);resize:none;min-height:140px;caret-color:var(--accent);background:0 0;outline:none;padding:16px;line-height:1.6}.mobile-input-textarea::placeholder{color:var(--text3)}.mobile-input-actions{justify-content:flex-end;align-items:center;gap:8px;padding:12px 16px;display:flex}.mobile-input-cancel{border:1px solid var(--border);color:var(--text3);border-radius:var(--r-md);font-family:var(--font-mono);cursor:pointer;background:0 0;padding:9px 18px;font-size:12px;transition:border-color .15s,color .15s}.mobile-input-cancel:active{border-color:var(--text2);color:var(--text)}.mobile-input-send{background:var(--accent);color:#fff;border-radius:var(--r-md);font-family:var(--font-mono);letter-spacing:.5px;cursor:pointer;border:1px solid #0000;padding:9px 22px;font-size:12px;font-weight:700;transition:background .15s,box-shadow .15s}.mobile-input-send:not(:disabled):active{background:var(--accent-hover);box-shadow:var(--shadow-accent)}.mobile-input-send:disabled{opacity:var(--disabled-opacity)}}@keyframes voice-pulse{0%,to{box-shadow:0 0 #7c6af766}50%{box-shadow:0 0 0 5px #7c6af700}}.mode-dropdown{flex-shrink:0;position:relative}.mode-dropdown-btn{background:var(--bg3);border:1px solid var(--border);height:44px;color:var(--text2);cursor:pointer;border-radius:var(--r-lg);align-items:center;gap:4px;padding:0 10px;font-size:16px;line-height:1;transition:border-color .15s,color .15s,background .15s;display:flex}.mode-dropdown-btn:hover{background:var(--bg);border-color:var(--accent);color:var(--accent)}.mode-dropdown-btn.active{background:var(--accent-muted);border-color:var(--accent);color:var(--accent)}.mode-dropdown-btn:disabled{opacity:.4;cursor:not-allowed}.mode-dropdown-arrow{color:var(--text3);font-size:8px;display:inline-block}.mode-dropdown-panel{background:var(--bg2);border:1px solid var(--border);z-index:200;border-radius:10px;min-width:210px;padding:6px;position:absolute;bottom:calc(100% + 8px);left:0;box-shadow:0 12px 40px #00000080}.mode-dropdown-option{width:100%;color:var(--text2);font-family:var(--font-mono);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:7px;align-items:center;gap:10px;padding:8px 10px;font-size:12px;transition:background .12s,color .12s;display:flex}.mode-dropdown-option:hover{background:var(--bg3);color:var(--text)}.mode-dropdown-option.selected{color:var(--accent);background:#7c6af71f}.mode-dropdown-label{flex:1}.mode-dropdown-check{color:var(--accent);font-size:11px}.mode-dropdown-icon{font-size:16px}.persona-switcher{flex-shrink:0;position:relative}.persona-switcher-btn{background:var(--bg3);border:1px solid var(--border);height:44px;color:var(--text2);font-size:12px;font-family:var(--font-mono);cursor:pointer;border-radius:var(--r-lg);white-space:nowrap;align-items:center;gap:4px;padding:0 10px;line-height:1;transition:border-color .15s,color .15s,background .15s,transform .15s cubic-bezier(.16,1,.3,1);display:flex}.persona-switcher-btn:hover:not(:disabled){background:var(--bg);border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}.persona-switcher-btn.active{background:var(--accent-muted);border-color:var(--accent);color:var(--accent)}.persona-switcher-btn:disabled{opacity:.4;cursor:not-allowed}.persona-switcher-symbol{font-size:13px;line-height:1}.persona-switcher-name{letter-spacing:.02em;font-size:11px;font-weight:600}.persona-switcher-arrow{color:var(--text3);font-size:8px}.persona-switcher-panel{background:var(--bg2);border:1px solid var(--border);z-index:200;border-radius:10px;min-width:230px;padding:6px;position:absolute;top:calc(100% + 8px);left:0;box-shadow:0 12px 40px #00000080}.persona-switcher-option{width:100%;color:var(--text2);font-family:var(--font-mono);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:7px;align-items:center;gap:10px;padding:8px 10px;font-size:12px;transition:background .12s,color .12s;display:flex}.persona-switcher-option:hover{background:var(--bg3);color:var(--text)}.persona-switcher-option.selected{color:var(--accent);background:#7c6af71f}.persona-switcher-opt-symbol{text-align:center;flex-shrink:0;width:18px;font-size:14px;line-height:1}.persona-switcher-opt-label{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.persona-switcher-opt-name{color:inherit;font-size:12px;font-weight:600}.persona-switcher-opt-desc{color:var(--text3);white-space:nowrap;text-overflow:ellipsis;font-size:10px;overflow:hidden}.persona-switcher-option.selected .persona-switcher-opt-desc{color:var(--accent);opacity:.7}.persona-switcher-check{color:var(--accent);flex-shrink:0;font-size:10px}.send-btn.send-btn-image{background:#9333ea}.send-btn.send-btn-image:hover:not(:disabled){background:#7e22ce}.generated-image-wrap{flex-direction:column;gap:8px;max-width:480px;display:flex}.generated-image{border:1px solid var(--border);background:var(--bg3);border-radius:10px;width:100%;display:block}.generated-image-prompt{color:var(--text3);font-size:11px;font-style:italic;line-height:1.4}.generated-image-actions{gap:8px;display:flex}.generated-image-download{color:var(--accent);border:1px solid var(--accent);border-radius:5px;padding:4px 8px;font-size:11px;text-decoration:none;transition:all .15s}.generated-image-download:hover{background:#7c6af726}.generated-video-wrap{flex-direction:column;gap:8px;max-width:480px;display:flex}.generated-video-thumb{aspect-ratio:16/9;border:1px solid var(--border);background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:10px;justify-content:center;align-items:center;width:100%;display:flex;position:relative;overflow:hidden}.generated-video-player{border-radius:10px;width:100%;height:100%;display:block}.generated-video-play-btn{color:#fff;cursor:pointer;width:56px;height:56px;box-shadow:0 4px 20px var(--accent-glow);background:#7c6af7d9;border:none;border-radius:50%;justify-content:center;align-items:center;padding-left:4px;font-size:20px;display:flex}.generated-music-wrap{flex-direction:column;gap:8px;max-width:420px;display:flex}.generated-music-player{border:1px solid var(--border);background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:10px;align-items:center;gap:12px;padding:14px 16px;display:flex;overflow:hidden}.generated-music-btn{color:#fff;cursor:pointer;width:44px;height:44px;box-shadow:0 4px 16px var(--accent-glow);background:#7c6af7d9;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding-left:2px;font-size:16px;display:flex}.generated-music-waveform{flex:1;align-items:center;gap:3px;height:32px;display:flex}.waveform-bar{background:var(--accent);border-radius:2px;flex-shrink:0;width:3px;height:4px}.chat-image-preview{background:var(--bg3);border:1px solid var(--border);border-radius:var(--r-lg);align-items:center;gap:8px;padding:8px 12px;display:flex}.img-clear-btn{color:var(--text3);cursor:pointer;border-radius:var(--r-sm);background:0 0;border:none;padding:2px 6px;font-size:14px;line-height:1;transition:color .15s}.img-clear-btn:hover{color:var(--danger)}.chat-img-thumb{object-fit:cover;border-radius:var(--r-md);border:1px solid var(--border);width:64px;height:64px;display:block}.editor-panel{flex-direction:column;height:100%;display:flex}.editor-header{background:var(--bg2);border-bottom:1px solid var(--border);color:var(--text2);flex-wrap:wrap;align-items:center;gap:8px;padding:8px 16px;font-size:12px;display:flex}.editor-filename{color:var(--accent3)}.editor-lang{color:var(--text3);font-size:11px}.editor-actions{gap:4px;margin-left:auto;display:flex}.editor-action-btn{background:var(--bg3);border:1px solid var(--border);color:var(--text2);cursor:pointer;font-size:11px;font-family:var(--font-mono);letter-spacing:.5px;white-space:nowrap;border-radius:5px;padding:4px 9px;transition:all .12s}.editor-action-btn:hover{background:var(--accent);color:#000;border-color:var(--accent)}.editor-stats{color:var(--text3);white-space:nowrap;font-size:10px}.editor-empty{justify-content:center;align-items:center;gap:var(--sp-2);color:var(--text3);flex-direction:column;flex:1;display:flex}.editor-empty-icon{font-size:var(--fs-2xl);opacity:.25;font-family:var(--font-mono);letter-spacing:-2px}.editor-empty-text{font-size:var(--fs-base);font-family:var(--font-mono);letter-spacing:.5px;text-align:center;max-width:240px;color:var(--text3);line-height:1.7}.preview-panel{flex-direction:column;height:100%;display:flex}.preview-header{background:var(--bg2);border-bottom:1px solid var(--border);color:var(--text3);z-index:10;flex-wrap:wrap;align-items:center;gap:8px;min-height:44px;padding:10px 16px;font-size:11px;display:flex;position:relative}.preview-frame{background:#fff;border:none;flex:1;width:100%;min-height:0}.preview-empty{justify-content:center;align-items:center;gap:var(--sp-2);color:var(--text3);flex-direction:column;flex:1;display:flex}.preview-empty-icon{font-size:var(--fs-2xl);opacity:.25}.preview-empty-text{font-size:var(--fs-base);font-family:var(--font-mono);letter-spacing:.5px;text-align:center;max-width:240px;color:var(--text3);line-height:1.7}.sidebar-section{flex-direction:column;display:flex}.sidebar-header-row{justify-content:space-between;align-items:center;padding:18px 16px 8px;display:flex}.sidebar-header{font-size:var(--fs-2xs);letter-spacing:2px;color:var(--text3);text-transform:uppercase;font-weight:600;font-family:var(--font-mono)}.sidebar-new-btn{border:1px solid var(--border);color:var(--text3);border-radius:var(--r-sm);cursor:pointer;background:0 0;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:15px;line-height:1;transition:border-color .15s,color .15s,background .15s;display:flex}.sidebar-new-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-subtle)}.sidebar-projects{scrollbar-width:none;max-height:220px;padding:0 8px 12px;overflow-y:auto}.sidebar-projects::-webkit-scrollbar{display:none}.project-item{border-radius:var(--r-md);font-size:var(--fs-base);cursor:pointer;color:var(--text2);border-left:2px solid #0000;justify-content:space-between;align-items:center;gap:6px;margin-bottom:1px;padding:8px 10px 8px 8px;transition:background .15s,color .15s,border-color .15s;display:flex;position:relative}.project-item:hover{background:var(--accent-subtle);color:var(--text)}.project-item.active{background:var(--accent-muted);color:var(--accent);border-left-color:var(--accent)}.project-hex-icon{color:var(--text3);flex-shrink:0;margin-top:1px;font-size:11px;line-height:1}.project-item.active .project-hex-icon{color:var(--accent)}.project-name{text-overflow:ellipsis;white-space:nowrap;font-size:var(--fs-base);flex:1;overflow:hidden}.project-actions{opacity:0;flex-shrink:0;gap:2px;transition:opacity .15s;display:flex}.project-item:hover .project-actions{opacity:1}@media (hover:none){.project-actions{opacity:1}}.action-btn{color:var(--text3);cursor:pointer;border-radius:var(--r-sm);touch-action:manipulation;-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;padding:0;font-size:11px;transition:color .15s,background .15s;display:flex}.action-btn:hover{color:var(--text);background:var(--bg3)}.action-btn.danger:hover{color:var(--danger);background:#ff6b6b1a}.rename-input{background:var(--bg2);border:1px solid var(--accent);color:var(--text);font-family:var(--font-mono);font-size:var(--fs-base);border-radius:var(--r-sm);box-shadow:0 0 0 2px var(--accent-subtle);outline:none;flex:1;padding:3px 8px}.delete-confirm-overlay{z-index:9999;-webkit-backdrop-filter:blur(4px);background:#000000b8;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.delete-confirm-dialog{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);width:90%;max-width:320px;box-shadow:var(--shadow-md);flex-direction:column;gap:6px;padding:24px 24px 20px;display:flex}.delete-confirm-title{font-size:var(--fs-md);color:var(--text);font-weight:700;font-family:var(--font-display);margin:0}.delete-confirm-name{font-size:var(--fs-base);color:var(--accent);font-family:var(--font-mono);word-break:break-all;opacity:.9;margin:2px 0 0}.delete-confirm-body{font-size:var(--fs-sm);color:var(--text3);margin:4px 0 14px;line-height:1.6}.delete-confirm-actions{justify-content:flex-end;gap:8px;display:flex}.delete-confirm-cancel{border:1px solid var(--border);color:var(--text2);border-radius:var(--r-md);font-size:var(--fs-sm);font-family:var(--font-mono);cursor:pointer;background:0 0;padding:7px 16px;transition:border-color .15s,color .15s}.delete-confirm-cancel:hover{border-color:var(--text3);color:var(--text)}.delete-confirm-confirm{color:var(--danger);border-radius:var(--r-md);font-size:var(--fs-sm);font-family:var(--font-mono);cursor:pointer;background:#ff6b6b26;border:1px solid #ff6b6b66;padding:7px 16px;font-weight:700;transition:background .15s,border-color .15s}.delete-confirm-confirm:hover{border-color:var(--danger);background:#ff6b6b40}.sidebar-divider{background:var(--border-subtle);flex-shrink:0;height:1px;margin:4px 16px}.no-project{color:var(--text3);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:14px;width:100%;padding:24px;animation:.5s cubic-bezier(.16,1,.3,1) both fadeSlideUp;display:flex}.no-project-title{font-family:var(--font-mono);letter-spacing:3px;color:var(--text);font-size:16px;font-weight:700;animation:3s ease-in-out infinite breathe}.no-project-sub{font-size:16px;font-family:var(--font-sans);color:var(--text2);text-align:center;font-weight:500;line-height:1.6;animation:.6s cubic-bezier(.16,1,.3,1) .1s both fadeSlideUp}.no-project-features{font-size:12px;font-family:var(--font-mono);color:var(--text3);text-align:center;letter-spacing:.3px;animation:.6s cubic-bezier(.16,1,.3,1) .2s both fadeSlideUp}.no-project-examples{flex-wrap:wrap;justify-content:center;gap:8px;max-width:380px;margin-top:16px;margin-bottom:4px;display:flex}.no-project-examples span{font-size:12px;font-family:var(--font-sans);color:var(--text2);background:var(--surface2);border:1px solid var(--border);cursor:pointer;border-radius:20px;padding:5px 12px;transition:all .2s cubic-bezier(.16,1,.3,1);animation:.5s cubic-bezier(.16,1,.3,1) both staggerFade}.no-project-examples span:first-child{animation-delay:.25s}.no-project-examples span:nth-child(2){animation-delay:.32s}.no-project-examples span:nth-child(3){animation-delay:.39s}.no-project-examples span:nth-child(4){animation-delay:.46s}.no-project-examples span:hover{background:var(--accent);color:#fff;border-color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 12px #8b5cf64d}.no-project-hint{font-size:11px;font-family:var(--font-sans);color:var(--text3);text-align:center;opacity:.7;margin-top:4px;animation:.6s cubic-bezier(.16,1,.3,1) .5s both fadeSlideUp}.new-project-btn-large{background:var(--accent);color:#fff;font-family:var(--font-mono);cursor:pointer;border-radius:var(--r-md);border:none;margin-top:8px;padding:12px 28px;font-size:13px;transition:all .2s cubic-bezier(.16,1,.3,1);animation:.5s cubic-bezier(.16,1,.3,1) .18s both staggerFade,2.5s ease-in-out .5s infinite glowPulse}.new-project-btn-large:hover{background:var(--accent-hover);transform:translateY(-2px)scale(1.03);box-shadow:0 6px 20px #8b5cf666}.project-name-display{color:var(--text3);font-size:12px;font-family:var(--font-mono);border-left:1px solid var(--border);margin-left:4px;padding-left:14px;animation:.4s cubic-bezier(.16,1,.3,1) both fadeSlideUp}.file-item button{color:var(--text3);font-size:var(--fs-sm)}.settings-panel{background:var(--bg2);border-left:1px solid var(--border);z-index:100;width:420px;height:100%;padding:24px 24px calc(48px + env(safe-area-inset-bottom));flex-direction:column;gap:24px;display:flex;position:absolute;top:0;right:0;overflow-y:auto}.settings-header{font-family:var(--font-display);color:var(--text);font-size:16px;font-weight:700}.settings-section{flex-direction:column;gap:8px;display:flex}.settings-account-row{flex-direction:row;justify-content:space-between;align-items:center}.model-toggle{grid-template-columns:1fr 1fr;gap:6px;display:grid}.model-toggle-btn{border:1px solid var(--border);background:var(--bg2);cursor:pointer;text-align:left;border-radius:8px;flex-direction:column;align-items:flex-start;gap:2px;padding:10px 12px;transition:border-color .15s,background .15s;display:flex}.model-toggle-btn:hover{border-color:var(--accent3);background:var(--bg3)}.model-toggle-btn.active{border-color:var(--accent);background:#8b76ff1a}.model-toggle-name{color:var(--text);font-size:12px;font-weight:700;font-family:var(--font-mono)}.model-toggle-btn.active .model-toggle-name{color:var(--accent)}.model-toggle-sub{color:var(--text3);font-size:10px;font-family:var(--font-mono)}.settings-support-card .support-card-body{border-radius:var(--r-md);background:linear-gradient(135deg,#8b76ff14,#5ef5c00f);border:1px solid #8b76ff33;flex-direction:column;gap:10px;padding:12px 14px;display:flex}.support-card-text{color:var(--text2);font-size:12px;line-height:1.6}.support-kofi-btn{color:var(--accent3);font-family:var(--font-mono);letter-spacing:.3px;background:linear-gradient(135deg,#8b76ff2e,#5ef5c01f);border:1px solid #8b76ff59;border-radius:20px;justify-content:center;align-items:center;padding:7px 16px;font-size:12px;font-weight:600;text-decoration:none;transition:all .2s cubic-bezier(.16,1,.3,1);display:inline-flex}.support-kofi-btn:hover{border-color:var(--accent3);color:#fff;background:linear-gradient(135deg,#8b76ff47,#5ef5c033);transform:translateY(-1px);box-shadow:0 4px 14px #5ef5c033}.settings-credits{border-top:1px solid var(--border);margin-top:4px;padding-top:12px}.credit-row{justify-content:space-between;align-items:baseline;gap:8px;display:flex}.credit-row-name{color:var(--text);font-size:12px;font-weight:600}.credit-row-role{color:var(--text3);font-size:11px}.credits-footer{align-items:center;gap:8px;margin-top:4px;display:flex}.credits-dot{color:var(--text3);font-size:11px}.credits-email,.credits-kofi{color:var(--accent3);font-size:11px;text-decoration:none}.credits-email:hover,.credits-kofi:hover{text-decoration:underline}.settings-label{letter-spacing:2px;text-transform:uppercase;color:var(--text3);font-size:11px}.settings-textarea{background:var(--bg3);border:1px solid var(--border);color:var(--text);font-family:var(--font-mono);border-radius:var(--r-md);resize:vertical;outline:none;padding:12px;font-size:12px;line-height:1.6;transition:border-color .15s}.settings-textarea:focus{border-color:var(--accent)}.settings-hint{color:var(--text3);font-size:11px;line-height:1.6}.publish-link{color:var(--accent3);margin-left:8px;font-size:11px;text-decoration:none}.publish-link:hover{text-decoration:underline}@media (max-width:768px){.header-nav{gap:2px}.project-name-display{display:none}.tab-btn{padding:5px 10px;font-size:10px}input,select,.mobile-input-textarea{font-size:16px!important}.chat-textarea{font-size:14px!important}.chat-input-area{padding:10px 16px;padding-bottom:calc(10px + env(safe-area-inset-bottom))}.chat-input-row{gap:6px}.chat-textarea{resize:none;cursor:pointer;caret-color:#0000;min-height:40px;max-height:40px;padding:10px 14px;overflow:hidden;font-size:14px!important}.send-btn{letter-spacing:0;min-width:44px;padding:0 14px;font-size:16px}.settings-panel{border-left:none;border-top:1px solid var(--border);width:100%!important}.header-status{display:none}}@media (max-width:600px){.app-header{height:auto;padding:env(safe-area-inset-top)0 0;flex-wrap:wrap;gap:0}.header-nav{display:contents}.logo{flex-shrink:0;align-items:center;height:52px;padding-left:12px;display:flex}.header-controls{align-items:center;gap:4px;height:52px;margin-left:auto;padding-right:8px;display:flex}.tab-switcher{border:none;border-top:1px solid var(--border-subtle);background:var(--bg2);border-radius:0;order:3;gap:1px;width:100%;padding:4px 8px 6px}.tab-btn{letter-spacing:.5px;flex:1;padding:5px 2px;font-size:10px}.tab-btn-debug{display:none}}.sidebar{animation:.4s .1s both slideRight}.main-content{animation:.4s .2s both fadeIn}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideRight{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes messageIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.send-btn:hover:not(:disabled){box-shadow:0 4px 20px var(--accent-glow);transform:translateY(-1px)}.send-btn:active:not(:disabled){transform:translateY(0)scale(.98)}.new-project-btn-large{transition:all .2s cubic-bezier(.16,1,.3,1)}.new-project-btn-large:hover{box-shadow:0 8px 30px var(--accent-glow);transform:translateY(-2px)}.new-project-btn-large:active{transform:scale(.97)}.panel{transition:opacity .2s}.panel.panel-active{animation:.25s forwards panelFadeIn}@keyframes panelFadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.generating-dots:after{content:"";animation:1.2s infinite dots}@keyframes dots{0%{content:"."}33%{content:".."}66%{content:"..."}to{content:""}}.run-btn{background:var(--bg3);border:1px solid var(--accent3);color:var(--accent3);font-family:var(--font-mono);letter-spacing:1px;cursor:pointer;border-radius:var(--r-md);text-transform:uppercase;flex-shrink:0;padding:8px 16px;font-size:11px;transition:all .15s cubic-bezier(.16,1,.3,1)}.run-btn:hover:not(:disabled){background:var(--accent3);color:var(--bg);box-shadow:0 4px 16px var(--accent3-glow);transform:translateY(-1px)}.run-btn:active:not(:disabled){transform:scale(.97)}.run-btn:disabled{opacity:.4;cursor:not-allowed}.run-btn-cancel{color:#f87171;border-color:#f87171}.run-btn-cancel:hover:not(:disabled){color:#000;background:#f87171;box-shadow:0 4px 16px #f871714d}.terminal-stderr{border-top:1px solid #f8717133;margin-top:8px;padding-top:8px;color:#f87171!important}[style*="rgba(0,0,0,0.5)"]{animation:.2s forwards overlayFade}@keyframes overlayFade{0%{opacity:0}to{opacity:1}}.message-content p{margin-bottom:8px}.message-content p:last-child{margin-bottom:0}.message-content strong{color:var(--text);font-weight:700}.message-content em{color:var(--text2);font-style:italic}.message-content code{background:var(--bg);font-family:var(--font-mono);color:var(--accent3);border-radius:3px;padding:2px 6px;font-size:12px}.message-content pre{background:var(--bg);border-radius:var(--r-md);border:1px solid var(--border);margin:8px 0;padding:12px;overflow-x:auto}.message-content pre code{color:var(--text2);background:0 0;padding:0}.message-content ul,.message-content ol{margin:8px 0;padding-left:20px}.message-content li{margin-bottom:4px;line-height:1.6}.message-content h1,.message-content h2,.message-content h3{font-family:var(--font-display);color:var(--text);margin:12px 0 6px}.message-content h1{font-size:18px}.message-content h2{font-size:15px}.message-content h3{font-size:13px}.preview-header{flex-wrap:wrap;gap:8px;padding:10px 16px}@media (max-width:768px){.preview-header{padding:10px 12px}.publish-link{word-break:break-all;width:100%;margin-top:4px;font-size:10px;display:block}}.publish-url-bar{background:var(--accent3-muted);word-break:break-all;border-bottom:1px solid #6af7c833;padding:8px 16px;font-size:12px}.settings-panel{overflow-y:auto}@media (max-width:600px){.settings-panel{width:100%;height:100%;top:0}}.incognito-banner{color:var(--danger);letter-spacing:1px;text-align:center;background:#ff6b6b1a;border-bottom:1px solid #ff6b6b4d;flex-shrink:0;padding:8px 20px;font-size:11px}.message-content pre{border:1px solid var(--border);border-radius:var(--r-lg);background:#0d0d14;margin:12px 0;overflow:hidden}.message-content pre code{font-family:var(--font-mono);color:#a8b1c2;background:0 0;padding:16px;font-size:12px;line-height:1.7;display:block;overflow-x:auto}.message-content code{border-radius:var(--r-sm);font-family:var(--font-mono);color:var(--accent3);border:1px solid var(--border);background:#0d0d14;padding:2px 6px;font-size:12px}.message-content pre>code{color:#a8b1c2;background:0 0;border:none;border-radius:0;padding:16px}.preview-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.export-menu{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-md);z-index:50;min-width:110px;animation:.15s fadeSlideUp;position:absolute;top:calc(100% + 6px);right:0;overflow:hidden;box-shadow:0 8px 24px #00000080}.export-menu-item{width:100%;color:var(--text2);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:6px;padding:9px 14px;font-size:12px;transition:background .1s,color .1s;display:flex}.export-menu-item:hover{background:var(--bg3);color:var(--text)}.pro-gate-overlay{z-index:10;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);border-radius:var(--r-md);cursor:pointer;background:#08070f8c;justify-content:center;align-items:center;transition:background .2s;display:flex;position:absolute;inset:0}.pro-gate-overlay:hover{background:#08070fad}.pro-gate-badge{background:linear-gradient(135deg,var(--accent),var(--accent3));color:#0d0c1a;letter-spacing:1.5px;border-radius:20px;padding:4px 12px;font-family:Courier New,monospace;font-size:11px;font-weight:800;animation:2s ease-in-out infinite chipGlow}.pro-gate-blurred{filter:blur(2px);pointer-events:none;-webkit-user-select:none;user-select:none}.mode-dropdown-option--locked{opacity:.6}.mode-dropdown-option--locked:hover{opacity:1;background:var(--bg3)}.mode-dropdown-pro-badge{color:var(--accent);letter-spacing:1px;border:1px solid #8b76ff4d;border-radius:4px;margin-left:auto;padding:1px 5px;font-family:Courier New,monospace;font-size:9px;font-weight:700}.export-menu-badge--pro{color:var(--accent);border-color:#8b76ff4d}.export-menu-badge{color:var(--text3);border:1px solid var(--border);border-radius:4px;padding:1px 4px;font-size:9px}@media (max-width:768px){.preview-panel{flex-direction:column;height:100%;display:flex;overflow:hidden}.preview-header{background:var(--bg2);flex-shrink:0}.preview-frame{flex:1;min-height:0}.publish-url-bar{flex-shrink:0}}.app-root{flex-direction:column;height:100dvh;display:flex;overflow:hidden}.main-content{flex-direction:column;flex:1;display:flex;overflow:hidden}.panel{flex:1;display:none;overflow:hidden}.panel.panel-active{flex-direction:column;display:flex}.generation-progress{flex-direction:column;gap:10px;padding:4px 0;display:flex}.gen-progress-header{justify-content:space-between;align-items:center;display:flex}.gen-progress-file{font-family:var(--font-mono);color:var(--accent3);letter-spacing:.5px;font-size:12px}.gen-progress-count{font-family:var(--font-mono);color:var(--text3);font-size:11px}.gen-progress-bar-track{background:#2a2a3a;border-radius:3px;width:100%;height:6px;overflow:hidden}.gen-progress-bar-fill{background:var(--accent3);border-radius:3px;height:100%;transition:width .6s ease-out}.gen-progress-bar-scanning{width:40%;transition:none;animation:1.4s ease-in-out infinite progress-scan}@keyframes progress-scan{0%{transform:translate(-100%)}to{transform:translate(350%)}}.gen-progress-pct{font-family:var(--font-mono);color:var(--text3);margin-top:4px;font-size:11px}.gen-progress-files{flex-wrap:wrap;gap:6px;display:flex}.gen-file-chip{font-family:var(--font-mono);border-radius:var(--r-sm);border:1px solid var(--border);color:var(--text3);background:0 0;padding:3px 8px;font-size:10px;transition:all .2s}.gen-file-chip.active{border-color:var(--accent3);color:var(--accent3);background:var(--accent3-subtle)}.gen-file-chip.done{color:#6af7c880;border-color:#6af7c84d}.animated-logo-wrap{border-radius:var(--r-md);align-items:center;gap:8px;padding:0 4px 0 0;display:flex;position:relative;overflow:hidden}.logo-icon-svg{border:1px solid var(--border);border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.animated-logo-text{font-family:var(--font-display);letter-spacing:3px;color:var(--text);white-space:nowrap;font-size:18px;font-weight:800}@keyframes logo-shimmer-slide{0%{transform:translate(-150%)}70%{transform:translate(350%)}to{transform:translate(350%)}}.logo-shimmer{pointer-events:none;height:100%;animation:logo-shimmer-slide var(--logo-speed,4s)ease-in-out infinite;position:absolute;top:0;left:0}@media (max-width:768px){.animated-logo-text{font-size:14px}}.sidebar-backdrop{z-index:15;background:#00000080;position:fixed;inset:0}.sidebar-trigger{z-index:20;align-items:center;display:flex;position:absolute;top:50%;left:0;transform:translateY(-50%)}.sidebar-tab{cursor:pointer;background:linear-gradient(#0000 0%,#7c6af773 15%,#7c6af7d9 35%,#6af7c8d9 65%,#6af7c873 85%,#0000 100%);border:none;border-radius:0 10px 10px 0;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:64px;animation:2.4s ease-in-out infinite glow-pulse;display:flex}@keyframes glow-pulse{0%,to{box-shadow:0 0 8px 1px var(--accent-glow),2px 0 16px #7c6af733;opacity:.85}50%{opacity:1;box-shadow:0 0 16px 3px #6af7c880,2px 0 24px #6af7c840}}.sidebar-tab-chevron{color:#f0fffaf2;font-size:12px;font-weight:900;line-height:1;transition:transform .3s cubic-bezier(.16,1,.3,1),text-shadow .3s}.sidebar-tab-chevron.open{text-shadow:0 0 6px #6af7c8cc;transform:rotate(180deg)}.sidebar-floating-panel{border-radius:var(--r-xl);-webkit-backdrop-filter:blur(16px);background:#111118f2;border:1px solid #2a2a3ae6;max-height:min(80vh,520px);overflow:hidden;box-shadow:0 12px 40px #0006,0 2px 8px #0000004d}.sidebar-floating-panel .sidebar{background:0 0;width:220px;height:100%}.image-editor-overlay{z-index:1000;background:#0a0a0ff7;flex-direction:column;display:flex;position:fixed;inset:0}.image-editor-header{border-bottom:1px solid var(--border);background:var(--bg2);flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 20px;display:flex}.image-editor-title{color:var(--accent);letter-spacing:2px;font-size:12px;font-weight:600;font-family:var(--font-mono)}.image-editor-tabs{background:var(--bg3);border:1px solid var(--border);border-radius:var(--r-md);gap:2px;padding:2px;display:flex}.image-editor-tab{color:var(--text2);font-family:var(--font-mono);letter-spacing:1px;cursor:pointer;border-radius:var(--r-sm);background:0 0;border:none;padding:5px 16px;font-size:11px;transition:all .15s}.image-editor-tab.active{background:var(--accent);color:#fff}.image-editor-close{color:var(--text3);cursor:pointer;border-radius:var(--r-sm);background:0 0;border:none;padding:4px 8px;font-size:18px;line-height:1;transition:color .15s}.image-editor-close:hover{color:var(--text)}.image-editor-canvas-area{flex:1;min-height:0;display:flex}.image-editor-pane{flex-direction:column;flex:1;gap:10px;min-height:0;padding:16px;display:flex}.image-editor-pane+.image-editor-pane{border-left:1px solid var(--border)}.image-editor-pane-label{color:var(--text3);text-transform:uppercase;letter-spacing:1px;font-size:9px;font-family:var(--font-mono);flex-shrink:0}.image-editor-image-wrap{background:var(--bg3);border-radius:var(--r-lg);border:1px solid var(--border);flex:1;justify-content:center;align-items:center;min-height:0;display:flex;position:relative;overflow:hidden}.image-editor-source{object-fit:contain;border-radius:var(--r-md);-webkit-user-select:none;user-select:none;max-width:100%;max-height:100%;display:block}.image-editor-canvas{cursor:crosshair;touch-action:none;position:absolute}.image-editor-brush-tools{flex-wrap:wrap;flex-shrink:0;align-items:center;gap:8px;display:flex}.image-editor-brush-btn{background:var(--bg3);border:1px solid var(--border);color:var(--text2);cursor:pointer;font-size:11px;font-family:var(--font-mono);border-radius:5px;padding:5px 10px;transition:all .15s}.image-editor-brush-btn:hover{border-color:var(--accent);color:var(--accent)}.image-editor-brush-size{color:var(--text3);font-size:10px;font-family:var(--font-mono);align-items:center;gap:6px;display:flex}.image-editor-brush-size input[type=range]{width:80px;accent-color:var(--accent);cursor:pointer}.image-editor-placeholder{width:100%;height:100%;color:var(--text3);font-size:12px;font-family:var(--font-mono);justify-content:center;align-items:center;display:flex}.image-editor-result{object-fit:contain;border-radius:var(--r-md);max-width:100%;max-height:100%;display:block}.image-editor-result-actions{flex-wrap:wrap;flex-shrink:0;gap:8px;display:flex}.image-editor-error{color:var(--danger);font-size:12px;font-family:var(--font-mono);border-radius:var(--r-md);background:#ff6b6b14;border:1px solid #ff6b6b33;flex-shrink:0;padding:8px 12px}.image-editor-footer{border-top:1px solid var(--border);background:var(--bg2);flex-shrink:0;align-items:center;gap:8px;padding:12px 20px;display:flex}.image-editor-prompt{background:var(--bg3);border:1px solid var(--border);border-radius:var(--r-lg);color:var(--text);font-size:13px;font-family:var(--font-mono);resize:none;outline:none;flex:1;height:42px;padding:10px 14px;transition:border-color .15s}.image-editor-prompt:focus{border-color:var(--accent)}.image-editor-generate-btn{background:var(--accent);color:#fff;font-family:var(--font-mono);letter-spacing:1px;cursor:pointer;border-radius:var(--r-lg);white-space:nowrap;border:none;flex-shrink:0;padding:10px 20px;font-size:12px;transition:all .15s}.image-editor-generate-btn:hover:not(:disabled){background:var(--accent-hover)}.image-editor-generate-btn:disabled{opacity:.4;cursor:not-allowed}.image-editor-confirm-btn{background:var(--bg3);border:1px solid var(--accent3);color:var(--accent3);font-family:var(--font-mono);cursor:pointer;border-radius:var(--r-lg);white-space:nowrap;flex-shrink:0;padding:10px 16px;font-size:12px;transition:all .15s}.image-editor-confirm-btn:hover:not(:disabled){background:#6af7c81a}.image-editor-confirm-btn:disabled{opacity:.4;cursor:not-allowed}.image-editor-chain-btn{background:var(--bg3);border:1px solid var(--border);color:var(--text2);font-family:var(--font-mono);cursor:pointer;border-radius:5px;padding:5px 10px;font-size:11px;transition:all .15s}.image-editor-chain-btn:hover{border-color:var(--accent);color:var(--accent)}.image-editor-download-link{color:var(--accent);border:1px solid var(--accent);font-size:11px;font-family:var(--font-mono);border-radius:5px;padding:5px 10px;text-decoration:none;transition:all .15s}.image-editor-download-link:hover{background:#7c6af726}.generated-image-edit-btn{color:var(--text2);background:var(--bg3);border:1px solid var(--border);cursor:pointer;font-size:11px;font-family:var(--font-mono);border-radius:5px;align-self:flex-start;padding:4px 8px;transition:all .15s}.generated-image-edit-btn:hover{border-color:var(--accent);color:var(--accent)}.generating-card{aspect-ratio:16/9;border-radius:var(--r-xl);border:1px solid var(--border);background:linear-gradient(135deg,#12121e,#1a1a2e,#12121e);justify-content:center;align-items:center;width:100%;max-width:480px;min-height:120px;display:flex;position:relative;overflow:hidden}.generating-shimmer{background:linear-gradient(90deg,#0000 0%,#7c6af714 40%,#7c6af72e 50%,#7c6af714 60%,#0000 100%) 0 0/200% 100%;animation:2s ease-in-out infinite shimmer-sweep;position:absolute;inset:0}@keyframes shimmer-sweep{0%{background-position:200% 0}to{background-position:-200% 0}}.generating-card-body{z-index:1;flex-direction:column;align-items:center;gap:12px;display:flex;position:relative}.generating-icon{font-size:32px;display:block}.generating-label{font-family:var(--font-mono);color:var(--text2);letter-spacing:2px;text-transform:uppercase;font-size:12px}.generating-dot{margin-left:1px;display:inline-block}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-box{background:var(--bg2);border:1px solid var(--border);border-radius:14px;width:360px;max-width:calc(100vw - 32px);padding:28px 28px 24px;box-shadow:0 24px 64px #0009}.modal-title{font-family:var(--font-display);color:var(--text);letter-spacing:.5px;margin-bottom:16px;font-size:16px;font-weight:700}.modal-input{background:var(--bg3);border:1px solid var(--border);border-radius:var(--r-lg);width:100%;color:var(--text);font-family:var(--font-mono);outline:none;margin-bottom:20px;padding:10px 14px;font-size:13px;transition:border-color .15s}.modal-input:focus{border-color:var(--accent)}.modal-actions{justify-content:flex-end;gap:10px;display:flex}.modal-btn{border-radius:var(--r-lg);border:1px solid var(--border);font-family:var(--font-mono);cursor:pointer;padding:8px 20px;font-size:12px;transition:all .15s}.modal-btn-cancel{background:var(--bg3);color:var(--text2)}.modal-btn-cancel:hover{border-color:var(--text2);color:var(--text)}.modal-btn-confirm{background:var(--accent);color:#fff;border-color:var(--accent)}.modal-btn-confirm:hover{background:var(--accent-hover)}.auth-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.auth-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-2xl);flex-direction:column;gap:16px;width:100%;max-width:380px;padding:32px;display:flex}.auth-logo{color:var(--accent);text-align:center;letter-spacing:2px;font-size:24px;font-weight:700}.auth-title{color:var(--text);text-align:center;font-size:18px;font-weight:600}.auth-oauth-stack{flex-direction:column;gap:8px;display:flex}.auth-google-btn{border-radius:var(--r-lg);color:#3c4043;cursor:pointer;width:100%;font-size:14px;font-weight:500;font-family:var(--font-sans);background:#fff;border:1px solid #dadce0;justify-content:center;align-items:center;gap:10px;padding:11px 16px;transition:background .15s,box-shadow .15s;display:flex}.auth-google-btn:hover{background:#f8f9fa;box-shadow:0 1px 4px #0000002e}.auth-google-icon{background:linear-gradient(135deg,#4285f4 25%,#ea4335 50%,#fbbc04 75%,#34a853);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:15px;font-weight:800;line-height:1}.auth-oauth-btn{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-lg);width:100%;color:var(--text2);cursor:pointer;font-size:12px;font-family:var(--font-mono);justify-content:center;align-items:center;gap:6px;padding:8px 12px;transition:border-color .15s,color .15s;display:flex}.auth-oauth-btn:hover{border-color:var(--border);color:var(--text)}.auth-oauth-icon{font-size:13px;font-weight:700}.auth-divider{color:var(--muted);align-items:center;gap:10px;font-size:12px;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border);flex:1;height:1px}.auth-tabs{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-lg);padding:3px;display:flex}.auth-tab{border-radius:var(--r-md);color:var(--muted);cursor:pointer;background:0 0;border:none;flex:1;padding:7px;font-size:13px;transition:background .15s,color .15s}.auth-tab.active{background:var(--surface);color:var(--text)}.auth-input{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-lg);width:100%;color:var(--text);box-sizing:border-box;padding:10px 12px;font-family:inherit;font-size:14px;transition:border-color .15s}.auth-input:focus{border-color:var(--accent);outline:none}.auth-error{color:#ff6b6b;border-radius:var(--r-md);background:#ff6b6b1a;border:1px solid #ff6b6b33;padding:8px 10px;font-size:12px}.auth-message{color:#6bcb77;border-radius:var(--r-md);text-align:center;background:#6bcb771a;border:1px solid #6bcb7733;padding:12px;font-size:13px}.auth-submit{background:var(--accent);border-radius:var(--r-lg);color:#fff;cursor:pointer;border:none;width:100%;padding:11px;font-size:14px;font-weight:600;transition:opacity .15s}.auth-submit:hover{opacity:.9}.auth-submit:disabled{opacity:var(--disabled-opacity);cursor:not-allowed}.auth-forgot{width:100%;color:var(--muted);cursor:pointer;text-align:center;background:0 0;border:none;padding:4px;font-size:12px;transition:color .15s}.auth-forgot:hover{color:var(--accent)}.user-avatar-btn{background:var(--accent);cursor:pointer;color:#fff;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:700;transition:opacity .15s;display:flex;overflow:hidden}.user-avatar-btn:hover{opacity:.85}.user-avatar-btn img{object-fit:cover;width:100%;height:100%}.auth-signout-btn{border-radius:var(--r-lg);color:#ff6b6b;cursor:pointer;background:#ff6b6b14;border:1px solid #ff6b6b40;width:100%;margin-top:8px;padding:9px;font-size:13px;transition:background .15s}.auth-signout-btn:hover{background:#ff6b6b26}.splash-root{z-index:9999;cursor:pointer;background:#050508;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.splash-root.exiting{animation:.5s cubic-bezier(.7,0,.3,1) forwards splashWipe}@keyframes splashWipe{0%{clip-path:inset(0 0% 0 0)}to{clip-path:inset(0 100% 0 0)}}.splash-canvas{pointer-events:none;position:absolute;inset:0}.splash-center{z-index:2;pointer-events:none;flex-direction:column;align-items:center;display:flex;position:relative}.splash-mark{font-family:var(--font-display);color:#fff;letter-spacing:-2px;opacity:0;font-size:72px;font-weight:800;transition:opacity .6s,transform .6s;transform:scale(.85)}.splash-mark.visible{opacity:1;transform:scale(1)}.splash-ring{border:1px solid var(--accent);opacity:0;pointer-events:none;border-radius:50%;width:120px;height:120px;position:absolute;top:50%;left:50%}.splash-ring.pulse{animation:1.2s ease-out forwards splashRing}@keyframes splashRing{0%{opacity:.8;transform:translate(-50%,-50%)scale(.5)}to{opacity:0;transform:translate(-50%,-50%)scale(2.5)}}.splash-tagline{font-family:var(--font-mono);letter-spacing:6px;text-transform:uppercase;color:#4a4a6a;opacity:0;margin-top:16px;font-size:10px;transition:opacity .6s .1s,transform .6s .1s;transform:translateY(8px)}.splash-tagline.visible{opacity:.6;transform:translateY(0)}.splash-sub{font-family:var(--font-sans,sans-serif);color:#3a3a58;text-align:center;opacity:0;max-width:280px;margin-top:10px;font-size:13px;line-height:1.5;transition:opacity .7s,transform .7s;transform:translateY(6px)}.splash-sub.visible{opacity:.45;transform:translateY(0)}.splash-grain{z-index:3;pointer-events:none;opacity:.04;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");position:absolute;inset:0}.splash-mute{z-index:10;border:1px solid var(--accent-glow);width:34px;height:34px;color:var(--accent);font-family:var(--font-mono);cursor:pointer;pointer-events:all;background:#7c6af714;border-radius:50%;justify-content:center;align-items:center;font-size:15px;animation:1.8s ease-in-out infinite mutePulse;display:flex;position:absolute;bottom:24px;right:24px}@keyframes mutePulse{0%,to{opacity:.4}50%{opacity:1}}.personality-locked{background:var(--accent-subtle);border:1px solid #7c6af733;border-radius:10px;align-items:center;gap:10px;margin-bottom:4px;padding:12px 14px;display:flex}.personality-locked-label{color:var(--accent);letter-spacing:1px;font-size:11px}.personality-locked-sub{color:var(--text3);margin-top:2px;font-size:10px}.personality-slider-row{flex-direction:column;gap:5px;display:flex}.personality-slider-ends{color:var(--text3);justify-content:space-between;font-size:10px;display:flex}.personality-slider-track{background:var(--border);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:2px;height:3px;position:relative}.personality-slider-fill{background:linear-gradient(90deg,var(--accent),#9c8af7);pointer-events:none;border-radius:2px;height:100%}.personality-slider-thumb{border:2px solid var(--accent);cursor:grab;background:#fff;border-radius:50%;width:14px;height:14px;position:absolute;top:-5.5px;transform:translate(-50%);box-shadow:0 0 8px #7c6af780}.personality-slider-thumb:active{cursor:grabbing}.memory-manager{flex-direction:column;gap:10px;display:flex;position:relative}.memory-empty{color:var(--text3);text-align:center;border:1px dashed var(--border);border-radius:var(--r-lg);padding:12px 0;font-size:12px}.memory-list{flex-direction:column;gap:6px;display:flex}.memory-chip{background:var(--bg3);border:1px solid var(--border);border-radius:var(--r-lg);align-items:flex-start;gap:8px;padding:9px 12px;transition:border-color .15s;display:flex}.memory-chip:hover{border-color:var(--accent)}.memory-chip-text{color:var(--text-chat);word-break:break-word;flex:1;font-size:12px;line-height:1.5}.memory-chip-actions{flex-shrink:0;gap:4px;margin-top:1px;display:flex}.memory-chip-btn{color:var(--text3);cursor:pointer;border-radius:var(--r-sm);background:0 0;border:none;padding:2px 5px;font-size:14px;line-height:1;transition:color .15s,background .15s}.memory-chip-btn:hover{color:var(--text);background:#ffffff0f}.memory-chip-delete:hover{color:var(--danger)!important}.memory-add-btn{border:1px dashed var(--border);border-radius:var(--r-lg);color:var(--text3);font-size:12px;font-family:var(--font-mono);cursor:pointer;text-align:center;background:0 0;width:100%;padding:8px;transition:border-color .15s,color .15s}.memory-add-btn:hover{border-color:var(--accent);color:var(--accent)}.memory-modal-overlay{z-index:200;background:#0006;position:fixed;inset:0}.memory-modal{z-index:201;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-xl);flex-direction:column;gap:12px;width:320px;padding:20px;display:flex;position:fixed;top:50%;left:50%;box-shadow:0 20px 60px #00000080}.memory-modal-title{color:var(--text);letter-spacing:.5px;font-size:13px;font-weight:600}.memory-modal-input{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-lg);width:100%;color:var(--text);font-size:13px;font-family:var(--font-mono);resize:none;box-sizing:border-box;padding:10px 12px;line-height:1.5;transition:border-color .15s}.memory-modal-input:focus{border-color:var(--accent);outline:none}.memory-modal-actions{justify-content:flex-end;gap:8px;display:flex}.memory-modal-cancel{border:1px solid var(--border);color:var(--text2);font-size:12px;font-family:var(--font-mono);cursor:pointer;background:0 0;border-radius:7px;padding:7px 14px;transition:border-color .15s}.memory-modal-cancel:hover{border-color:var(--text2)}.memory-modal-save{background:var(--accent);color:#fff;font-size:12px;font-family:var(--font-mono);cursor:pointer;border:none;border-radius:7px;padding:7px 14px;font-weight:600;transition:opacity .15s}.memory-modal-save:hover{opacity:.85}.memory-modal-save:disabled{opacity:.4;cursor:not-allowed}.memwin-backdrop{z-index:190;background:#0000008c;position:fixed;inset:0}.memwin{z-index:191;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-xl);flex-direction:column;width:min(540px,100vw - 24px);max-height:min(640px,100vh - 48px);display:flex;position:fixed;top:50%;left:50%;overflow:hidden;box-shadow:0 24px 80px #0000008c}.memwin-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.memwin-title{color:var(--text);font-size:14px;font-weight:700;font-family:var(--font-display);letter-spacing:.4px}.memwin-close{color:var(--text3);cursor:pointer;border-radius:var(--r-sm);background:0 0;border:none;padding:2px 6px;font-size:22px;line-height:1;transition:color .15s,background .15s}.memwin-close:hover{color:var(--text);background:var(--bg3)}.memwin-body{-webkit-overflow-scrolling:touch;flex:1;padding:14px 20px;overflow-y:auto}.memwin-empty{color:var(--text3);text-align:center;padding:40px 0;font-size:13px}.memwin-list{flex-direction:column;gap:8px;display:flex}.memwin-footer{border-top:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 20px;display:flex}.memwin-count{color:var(--text3);font-size:11px;font-family:var(--font-mono)}.memwin-add-btn{background:var(--accent);border-radius:var(--r-lg);color:#fff;font-size:12px;font-family:var(--font-mono);cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;padding:8px 18px;font-weight:600;transition:opacity .15s}.memwin-add-btn:hover{opacity:.85}.memory-chip-num{color:var(--text3);font-size:10px;font-family:var(--font-mono);flex-shrink:0;min-width:18px;padding-top:1px}.memory-compiled-preview{background:var(--bg3);border:1px solid var(--border);border-radius:var(--r-lg);-webkit-overflow-scrolling:touch;flex-direction:column;gap:3px;max-height:110px;margin-bottom:8px;padding:10px 12px;display:flex;overflow-y:auto}.install-prompt{bottom:calc(var(--safe-bottom) + 64px);left:var(--sp-3);right:var(--sp-3);z-index:9000;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--sp-3);align-items:center;gap:var(--sp-2);display:flex;position:fixed;box-shadow:0 8px 32px #0006}.install-prompt__body{align-items:center;gap:var(--sp-2);flex:1;display:flex}.install-prompt__text{font-size:var(--fs-sm);color:var(--text2);flex:1;margin:0}.install-prompt__install{background:var(--accent);color:#fff;border-radius:var(--r-md);padding:var(--sp-1)var(--sp-3);font-size:var(--fs-sm);cursor:pointer;white-space:nowrap;border:none;font-weight:600}.install-prompt__dismiss{color:var(--text3);cursor:pointer;padding:0 var(--sp-1);background:0 0;border:none;flex-shrink:0;font-size:20px;line-height:1}.memory-compiled-line{color:var(--text2);font-size:11px;font-family:var(--font-mono);line-height:1.5}.memory-manage-btn{border:1px dashed var(--border);border-radius:var(--r-lg);width:100%;color:var(--text2);font-size:12px;font-family:var(--font-mono);cursor:pointer;text-align:center;-webkit-tap-highlight-color:transparent;background:0 0;padding:8px 12px;transition:border-color .15s,color .15s}.memory-manage-btn:hover{border-color:var(--accent);color:var(--accent)}.create-error-toast{z-index:400;color:#fff;font-size:13px;font-family:var(--font-mono);border-radius:var(--r-lg);white-space:nowrap;pointer-events:none;background:#c0392b;padding:10px 20px;position:fixed;bottom:24px;left:50%;transform:translate(-50%);box-shadow:0 4px 20px #00000059}@media (max-width:600px){.memwin{border-radius:var(--r-lg);width:calc(100vw - 16px);max-height:calc(100svh - 32px);top:50%}.memwin-header{padding:14px 16px}.memwin-body{padding:12px 16px}.memwin-footer{padding:10px 16px}.memory-modal{width:calc(100vw - 32px)}}.landing-root{background:var(--bg);height:100vh;min-height:100vh;color:var(--text);font-family:var(--font-mono);-webkit-overflow-scrolling:touch;overflow:hidden auto}.landing-header{z-index:100;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border-subtle);background:#07060fe0;justify-content:space-between;align-items:center;padding:16px 40px;display:flex;position:sticky;top:0}.landing-logo{color:var(--accent);letter-spacing:-.02em;font-size:20px;font-weight:700}.landing-signin-btn{border:1px solid var(--border);border-radius:var(--r-full);color:var(--text);font-family:var(--font-mono);cursor:pointer;background:0 0;padding:8px 22px;font-size:11px;transition:border-color .2s,color .2s}.landing-signin-btn:hover{border-color:var(--accent);color:var(--accent)}.landing-hero{text-align:center;flex-direction:column;align-items:center;max-width:900px;margin:0 auto;padding:120px 24px 80px;display:flex;position:relative}.landing-hero-glow{pointer-events:none;background:radial-gradient(60% 55% at 50% 30%,#7c6af724 0%,#0000 70%);width:800px;height:500px;position:absolute;top:0;left:50%;transform:translate(-50%)}.landing-hero-badge{border:1px solid var(--border);border-radius:var(--r-full);background:var(--accent-subtle);color:var(--accent);letter-spacing:.1em;text-transform:uppercase;align-items:center;gap:8px;margin-bottom:36px;padding:6px 18px;font-size:10px;display:inline-flex;position:relative}.landing-headline{font-family:var(--font-display);letter-spacing:-.03em;background:linear-gradient(140deg,#f0f0f8 20%,#8b76ff 60%,#c4b8ff 90%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:28px;font-size:clamp(52px,10vw,96px);font-weight:800;line-height:1.03;position:relative}.landing-subheadline{color:var(--text2);max-width:560px;margin-bottom:44px;font-size:16px;line-height:1.75;position:relative}.landing-ctas{flex-wrap:wrap;justify-content:center;gap:12px;margin-bottom:22px;display:flex;position:relative}.landing-cta-primary{background:var(--accent);color:#fff;border-radius:var(--r-full);font-family:var(--font-mono);cursor:pointer;border:none;padding:15px 40px;font-size:13px;font-weight:700;transition:background .2s,transform .15s,box-shadow .2s}.landing-cta-primary:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 6px 24px #7c6af766}.landing-cta-secondary{color:var(--text);border:1px solid var(--border);border-radius:var(--r-full);font-family:var(--font-mono);cursor:pointer;background:0 0;padding:15px 40px;font-size:13px;transition:border-color .2s,color .2s}.landing-cta-secondary:hover{border-color:var(--text2);color:var(--text)}.landing-hint{color:var(--text3);font-size:11px;position:relative}.landing-marquee{border-top:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle);background:#7c6af70a;margin-bottom:72px;padding:14px 0;overflow:hidden}.landing-marquee-track{width:max-content;animation:36s linear infinite marqueeScroll;display:flex}.landing-marquee-item{font-size:10px;font-family:var(--font-mono);color:var(--text3);letter-spacing:.1em;text-transform:uppercase;white-space:nowrap;align-items:center;gap:10px;padding:0 28px;display:flex}.landing-marquee-dot{color:var(--accent);font-size:13px}@keyframes marqueeScroll{0%{transform:translate(0)}to{transform:translate(-50%)}}.landing-bento-section{grid-template-columns:repeat(3,1fr);gap:16px;max-width:1000px;margin:0 auto 72px;padding:0 24px;display:grid}.landing-bento-card{background:var(--bg2);border:1px solid var(--border-subtle);border-radius:var(--r-xl);padding:36px 28px 28px;transition:border-color .2s,transform .2s,box-shadow .2s;position:relative;overflow:hidden}.landing-bento-card:before{content:"";background:linear-gradient(90deg,transparent 0%,var(--accent)50%,transparent 100%);opacity:0;height:1px;transition:opacity .3s;position:absolute;top:0;left:0;right:0}.landing-bento-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 8px 32px #7c6af726}.landing-bento-card:hover:before{opacity:1}.landing-bento-icon{color:var(--accent);margin-bottom:18px;font-size:26px;display:block}.landing-bento-title{font-family:var(--font-display);color:var(--text);letter-spacing:-.01em;margin-bottom:12px;font-size:20px;font-weight:700}.landing-bento-desc{color:var(--text2);margin-bottom:20px;font-size:12px;line-height:1.75}.landing-bento-tag{border:1px solid var(--border);border-radius:var(--r-full);color:var(--text3);letter-spacing:.06em;text-transform:uppercase;padding:4px 12px;font-size:9px;display:inline-block}.landing-demo-bar{background:var(--bg2);border-bottom:1px solid var(--border);align-items:center;gap:6px;padding:10px 14px;display:flex}.landing-demo-dot{background:var(--border);border-radius:50%;width:10px;height:10px}.landing-demo-bar-title{font-size:11px;font-family:var(--font-mono);color:var(--text3);margin-left:10px}.landing-demo-placeholder{background:var(--bg2);aspect-ratio:16/9;justify-content:center;align-items:center;display:flex}.landing-demo-placeholder-inner{text-align:center;flex-direction:column;align-items:center;gap:10px;padding:24px;display:flex}.landing-demo-placeholder-icon{color:var(--border);font-size:32px}.landing-demo-placeholder-text{font-family:var(--font-mono);font-size:var(--fs-sm);color:var(--text3)}.landing-demo-placeholder-sub{color:var(--text3);opacity:.6;max-width:340px;font-size:11px;line-height:1.6}.landing-demo-placeholder-sub code{color:var(--accent);font-family:var(--font-mono)}.landing-demo-img{width:100%;display:block}.landing-manifesto{text-align:center;max-width:760px;margin:0 auto 16px;padding:0 24px}.landing-manifesto-text{color:var(--text2);font-size:16px;line-height:1.75}.landing-manifesto-text strong{color:var(--accent);font-weight:700}.landing-comparison{max-width:680px;margin:0 auto 64px;padding:0 24px}.landing-comparison-title{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;color:var(--text3);text-align:center;margin-bottom:20px;font-size:11px}.landing-comparison-table{border:1px solid var(--border);border-radius:10px;grid-template-columns:1fr 1fr;gap:2px;display:grid;overflow:hidden}.landing-comparison-col-header{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;background:var(--bg3);padding:10px 16px;font-size:11px;font-weight:700}.landing-comparison-col--them .landing-comparison-col-header{color:var(--text3)}.landing-comparison-col--us .landing-comparison-col-header{color:var(--accent);background:var(--accent-muted)}.landing-comparison-row{background:var(--bg2);border-top:1px solid var(--border-subtle);padding:9px 16px;font-size:13px}.landing-comparison-row--them{color:var(--text3)}.landing-comparison-row--us{color:var(--text)}.landing-features{grid-template-columns:repeat(4,1fr);gap:16px;max-width:920px;margin:0 auto;padding:0 24px 80px;display:grid}.landing-feature-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-xl);padding:28px 24px}.landing-feature-icon{color:var(--accent);margin-bottom:14px;font-size:22px;display:block}.landing-feature-title{color:var(--text);margin-bottom:8px;font-size:13px;font-weight:700}.landing-feature-desc{color:var(--text2);font-size:11px;line-height:1.7}.landing-roadmap{max-width:900px;margin:0 auto;padding:72px 24px}.landing-roadmap-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:32px;display:flex}.landing-roadmap-label{text-transform:uppercase;letter-spacing:.1em;color:var(--accent);margin-bottom:8px;font-size:11px;font-weight:700}.landing-roadmap-title{letter-spacing:-.5px;color:var(--text1);margin:0 0 8px;font-size:clamp(24px,4vw,36px);font-weight:800}.landing-roadmap-sub{color:var(--text3);max-width:380px;margin:0;font-size:13px;line-height:1.6}.landing-roadmap-btn{border:1px solid var(--border);color:var(--text2);font-family:var(--font-mono);background:0 0;border-radius:8px;flex-shrink:0;align-self:center;padding:9px 18px;font-size:12px;font-weight:700;text-decoration:none;transition:border-color .15s,color .15s}.landing-roadmap-btn:hover{border-color:var(--accent);color:var(--accent)}.landing-roadmap-grid{grid-template-columns:1fr 1fr;gap:24px;display:grid}@media (max-width:640px){.landing-roadmap-grid{grid-template-columns:1fr}}.landing-roadmap-col{background:var(--bg1);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:12px;padding:20px;display:flex}.landing-roadmap-col-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text3);border-bottom:1px solid var(--border);padding-bottom:10px;font-size:10px;font-weight:700}.landing-roadmap-item{align-items:flex-start;gap:10px;display:flex}.landing-roadmap-item--dim{opacity:.55}.landing-roadmap-item-icon{color:var(--accent);flex-shrink:0;margin-top:2px;font-size:11px}.landing-roadmap-item-name{color:var(--text1);margin-bottom:1px;font-size:12px;font-weight:700}.landing-roadmap-item-desc{color:var(--text3);font-size:11px;line-height:1.5}.landing-roadmap-see-all{border-top:1px solid var(--border);color:var(--accent);margin-top:auto;padding-top:10px;font-size:11px;font-weight:700;text-decoration:none;transition:opacity .15s}.landing-roadmap-see-all:hover{opacity:.75}.landing-pricing{text-align:center;max-width:720px;margin:0 auto;padding:0 24px 80px}.landing-pricing-title{font-family:var(--font-display);color:var(--text);margin-bottom:40px;font-size:28px;font-weight:700}.landing-pricing-tiers{grid-template-columns:1fr 1fr;gap:16px;display:grid}.landing-tier{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-xl);text-align:left;padding:32px 24px;position:relative}.landing-tier--pro{border-color:var(--accent);background:#7c6af70d}.landing-tier-pro-badge{background:var(--accent);color:#fff;letter-spacing:.12em;border-radius:var(--r-full);padding:4px 14px;font-size:9px;font-weight:700;position:absolute;top:-12px;left:50%;transform:translate(-50%)}.landing-tier-label{color:var(--text2);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px;font-size:11px}.landing-tier-price{font-family:var(--font-display);color:var(--text);margin-bottom:24px;font-size:42px;font-weight:800}.landing-tier-price span{color:var(--text2);font-size:14px}.landing-tier-features{flex-direction:column;gap:10px;margin-bottom:28px;list-style:none;display:flex}.landing-tier-features li{color:var(--text2);padding-left:18px;font-size:11px;position:relative}.landing-tier-features li:before{content:"✓";color:var(--accent3);position:absolute;left:0}.landing-tier-cta{border:1px solid var(--border);border-radius:var(--r-md);width:100%;color:var(--text);font-family:var(--font-mono);cursor:pointer;background:0 0;padding:12px;font-size:11px;transition:border-color .2s}.landing-tier-cta:hover{border-color:var(--text2)}.landing-tier-cta--pro{background:var(--accent);border-color:var(--accent);color:#fff}.landing-tier-cta--pro:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.landing-closer{text-align:center;border-top:1px solid var(--border-subtle);background:linear-gradient(#0000 0%,#7c6af712 50%,#0000 100%);padding:96px 24px}.landing-closer-inner{flex-direction:column;align-items:center;gap:20px;max-width:560px;margin:0 auto;display:flex}.landing-closer-badge{font-family:var(--font-mono);color:var(--accent);border:1px solid var(--accent);border-radius:var(--r-xl);background:var(--accent-subtle);justify-content:center;align-items:center;width:56px;height:56px;font-size:18px;font-weight:700;display:flex}.landing-closer-headline{font-family:var(--font-display);letter-spacing:-.02em;color:var(--text);font-size:clamp(28px,5vw,48px);font-weight:800}.landing-closer-sub{color:var(--text2);font-size:13px;line-height:1.65}.landing-footer{border-top:1px solid var(--border-subtle);text-align:center;color:var(--text3);justify-content:center;align-items:center;gap:10px;padding:28px 24px;font-size:11px;display:flex}.landing-footer-sep{color:var(--border)}.landing-footer-link{color:var(--text2);text-decoration:none;transition:color .15s}.landing-footer-link:hover{color:var(--accent)}.auth-close-btn{color:var(--text3);cursor:pointer;background:0 0;border:none;padding:4px;font-size:14px;line-height:1;transition:color .15s;position:absolute;top:16px;right:16px}.auth-close-btn:hover{color:var(--text)}.auth-box{position:relative}@media (max-width:900px){.landing-features{grid-template-columns:repeat(2,1fr)}.landing-bento-section{grid-template-columns:1fr}}@media (max-width:640px){.landing-features,.landing-pricing-tiers{grid-template-columns:1fr}.landing-header{padding:14px 20px}.landing-hero{padding:72px 20px 56px}.landing-bento-section{grid-template-columns:1fr;margin-bottom:48px}}.landing-cta-primary{animation:3s ease-in-out 1.2s infinite glowPulse}.landing-cta-primary:hover{transform:translateY(-2px)scale(1.02);box-shadow:0 8px 28px #7c6af773}.landing-cta-primary:active{transform:scale(.97)}.landing-cta-secondary:hover{border-color:var(--text2);transform:translateY(-1px)}.landing-feature-card{transition:transform .2s cubic-bezier(.16,1,.3,1),box-shadow .2s,border-color .2s;animation:.5s cubic-bezier(.16,1,.3,1) both fadeSlideUp}.landing-feature-card:first-child{animation-delay:.1s}.landing-feature-card:nth-child(2){animation-delay:.18s}.landing-feature-card:nth-child(3){animation-delay:.26s}.landing-feature-card:nth-child(4){animation-delay:.34s}.landing-feature-card:nth-child(5){animation-delay:.42s}.landing-feature-card:nth-child(6){animation-delay:.5s}.landing-feature-card:hover{border-color:var(--accent);transform:translateY(-5px);box-shadow:0 8px 32px #7c6af733}.landing-feature-icon{animation:4s ease-in-out infinite breathe}.landing-pricing-title{animation:.5s cubic-bezier(.16,1,.3,1) .1s both fadeSlideUp}.landing-tier{transition:transform .2s cubic-bezier(.16,1,.3,1),box-shadow .2s,border-color .2s;animation:.5s cubic-bezier(.16,1,.3,1) both fadeSlideUp}.landing-tier:first-child{animation-delay:.15s}.landing-tier:nth-child(2){animation-delay:.25s}.landing-tier:hover{transform:translateY(-4px);box-shadow:0 8px 28px #0000004d}.landing-tier--pro:hover{box-shadow:0 8px 32px #7c6af74d}.landing-tier-cta{transition:all .15s cubic-bezier(.16,1,.3,1)}.landing-tier-cta:hover{border-color:var(--text2);transform:translateY(-1px)}.landing-tier-cta--pro:hover{background:var(--accent-hover);transform:translateY(-1px)}.checkin-card{background:var(--bg2);border:1px solid var(--accent);border-radius:var(--r-xl);width:100%;max-width:400px;box-shadow:0 0 0 4px #7c6af714,var(--shadow-md);margin-bottom:16px;padding:20px 20px 0;overflow:hidden}.checkin-header{align-items:center;gap:8px;margin-bottom:10px;display:flex}.checkin-icon{color:var(--accent);font-size:14px}.checkin-label{color:var(--accent);text-transform:uppercase;letter-spacing:.08em;font-size:11px;font-weight:700}.checkin-body{color:var(--text2);margin-bottom:16px;font-size:13px;line-height:1.6}.checkin-project-name{color:var(--text);font-style:normal}.checkin-error{color:var(--text2);font-style:italic}.checkin-actions{gap:8px;margin-bottom:14px;display:flex}.checkin-continue{background:var(--accent);border-radius:var(--r-full);color:#fff;font-family:var(--font-mono);cursor:pointer;border:none;padding:8px 20px;font-size:12px;font-weight:700;transition:background .15s,transform .1s}.checkin-continue:hover{background:var(--accent-hover);transform:translateY(-1px)}.checkin-dismiss{border:1px solid var(--border);border-radius:var(--r-full);color:var(--text3);font-family:var(--font-mono);cursor:pointer;background:0 0;padding:8px 16px;font-size:12px;transition:border-color .15s,color .15s}.checkin-dismiss:hover{border-color:var(--text2);color:var(--text2)}.checkin-timer-bar{background:var(--bg3);height:2px;margin:0 -20px}.checkin-timer-progress{background:var(--accent);height:100%;animation:8s linear forwards checkinTimer}@keyframes checkinTimer{0%{width:100%}to{width:0%}}.image-studio{background:var(--bg1);flex-direction:column;height:100%;display:flex;overflow:hidden}.image-studio-toolbar{background:var(--bg2);border-bottom:1px solid var(--border);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:10px;padding:8px 12px;display:flex}.image-studio-logo{color:var(--accent);white-space:nowrap;margin-right:4px;font-size:12px;font-weight:700}.image-studio-tools{gap:4px;display:flex}.image-tool-btn{border:1px solid var(--border);background:var(--bg3);color:var(--text2);cursor:pointer;border-radius:5px;padding:5px 10px;font-size:11px;transition:all .15s}.image-tool-btn:hover{border-color:var(--accent);color:var(--text)}.image-tool-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.image-studio-header-right{flex-wrap:wrap;align-items:center;gap:8px;margin-left:auto;display:flex}.image-color-picker{border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:4px;width:28px;height:28px;padding:0}.image-size-slider{width:70px;accent-color:var(--accent)}.image-size-label{color:var(--text3);min-width:26px;font-size:10px}.image-studio-status{color:var(--accent);opacity:.8;font-size:11px}.image-btn{border:1px solid var(--border);background:var(--bg3);color:var(--text2);cursor:pointer;white-space:nowrap;border-radius:5px;padding:5px 10px;font-size:11px;transition:all .15s}.image-btn:hover{border-color:var(--accent);color:var(--text)}.image-btn.image-btn-sm{padding:4px 8px;font-size:10px}.image-btn.image-btn-primary{background:var(--accent);color:#fff;border-color:var(--accent);width:100%;margin-top:8px;padding:8px;font-weight:600}.image-btn.image-btn-primary:hover:not(:disabled){background:var(--accent-hover)}.image-btn:disabled{opacity:.4;cursor:not-allowed}.image-studio-body{flex:1;display:flex;overflow:hidden}.image-canvas-wrap{background:var(--bg1);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:8px;padding:16px;display:flex;overflow:auto}.image-canvas{cursor:crosshair;touch-action:none;border-radius:4px;max-width:100%;max-height:calc(100vh - 160px);box-shadow:0 4px 24px #0006}.image-mask-hint{color:var(--accent);opacity:.9;align-items:center;gap:4px;font-size:11px;display:flex}.image-canvas-wrap{position:relative}.image-text-overlay{z-index:10;position:absolute;transform:translateY(-50%)}.image-text-input{border:1px dashed var(--accent);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0006;border-radius:2px;outline:none;min-width:80px;padding:2px 4px;font-family:Inter,sans-serif;font-weight:700}.image-tool-sep{background:var(--border);align-self:center;width:1px;height:20px;margin:0 2px}.image-tools-panel{flex-direction:column;flex:1;gap:16px;padding:12px;display:flex;overflow-y:auto}.image-tools-section{flex-direction:column;gap:8px;display:flex}.image-tools-label{color:var(--text3);letter-spacing:1px;text-transform:uppercase;font-size:10px;font-weight:700}.image-tools-grid{grid-template-columns:repeat(3,1fr);gap:4px;display:grid}.image-tool-grid-btn{background:var(--bg3);border:1px solid var(--border);cursor:pointer;color:var(--text2);border-radius:6px;flex-direction:column;align-items:center;gap:3px;padding:8px 4px;font-size:10px;transition:all .12s;display:flex}.image-tool-grid-btn:hover{border-color:var(--accent);color:var(--text)}.image-tool-grid-btn.active{background:var(--accent);color:#000;border-color:var(--accent)}.image-tool-icon{font-size:16px}.image-tool-name{letter-spacing:.3px;white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-size:9px;overflow:hidden}.image-color-picker-lg{border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:6px;width:40px;height:36px}.image-right-panel{border-left:1px solid var(--border);background:var(--bg2);flex-direction:column;flex-shrink:0;width:240px;display:flex;overflow:hidden}.image-panel-tabs{border-bottom:1px solid var(--border);flex-shrink:0;display:flex}.image-panel-tab{color:var(--text3);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:8px 4px;font-size:10px;font-weight:600;transition:all .15s}.image-panel-tab:hover{color:var(--text2)}.image-panel-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.image-layers{flex:1;padding:8px;overflow-y:auto}.image-layers-header{color:var(--text2);justify-content:space-between;align-items:center;margin-bottom:8px;font-size:11px;font-weight:600;display:flex}.image-layer-row{cursor:pointer;border:1px solid #0000;border-radius:5px;align-items:center;gap:4px;margin-bottom:3px;padding:5px 6px;transition:all .12s;display:flex}.image-layer-row:hover{background:var(--bg3)}.image-layer-row.active{background:var(--bg3);border-color:var(--accent)}.image-layer-vis{cursor:pointer;color:var(--text3);background:0 0;border:none;flex-shrink:0;padding:0 2px;font-size:12px}.image-layer-name{color:var(--text);background:0 0;border:none;border-radius:3px;flex:1;min-width:0;padding:2px 4px;font-size:11px}.image-layer-name:focus{background:var(--bg1);outline:none}.image-layer-opacity{width:40px;accent-color:var(--accent);flex-shrink:0}.image-layer-btns{flex-shrink:0;gap:1px;display:flex}.image-layer-btns button{cursor:pointer;color:var(--text3);background:0 0;border:none;border-radius:3px;padding:1px 3px;font-size:11px}.image-layer-btns button:hover{color:var(--accent);background:var(--bg1)}.image-filters{padding:12px;overflow-y:auto}.image-filter-row{align-items:center;gap:6px;margin-bottom:10px;display:flex}.image-filter-label{color:var(--text2);flex-shrink:0;width:72px;font-size:11px}.image-filter-slider{accent-color:var(--accent);flex:1}.image-filter-value{color:var(--text3);text-align:right;width:34px;font-size:10px}.image-ai-panel{flex-direction:column;gap:10px;padding:12px;display:flex;overflow-y:auto}.image-ai-mode-row{gap:4px;display:flex}.image-ai-mode-btn{border:1px solid var(--border);background:var(--bg3);color:var(--text2);cursor:pointer;border-radius:5px;flex:1;padding:5px 4px;font-size:10px;font-weight:600;transition:all .15s}.image-ai-mode-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.image-ai-desc{color:var(--text3);font-size:10px;line-height:1.4}.image-ai-prompt{background:var(--bg3);border:1px solid var(--border);width:100%;color:var(--text);resize:vertical;border-radius:6px;padding:8px;font-family:inherit;font-size:12px;line-height:1.4}.image-ai-prompt:focus{border-color:var(--accent);outline:none}.image-ai-mask-note{color:var(--text3);background:var(--bg3);border-radius:5px;padding:6px 8px;font-size:10px;line-height:1.4}.suggestion-btn{animation:.4s cubic-bezier(.16,1,.3,1) both staggerFade}.chat-suggestions .suggestion-btn:first-child{animation-delay:50ms}.chat-suggestions .suggestion-btn:nth-child(2){animation-delay:.12s}.chat-suggestions .suggestion-btn:nth-child(3){animation-delay:.19s}.chat-suggestions .suggestion-btn:nth-child(4){animation-delay:.26s}.suggestion-btn:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 12px #7c6af733}.suggestion-btn:active{transform:scale(.96)}.project-item{transition:background .18s,color .18s,border-color .18s,transform .15s cubic-bezier(.16,1,.3,1)}.project-item:hover{background:var(--bg3);color:var(--text);transform:translate(2px)}.file-item{transition:background .18s,color .18s,border-color .18s,transform .15s cubic-bezier(.16,1,.3,1)}.file-item:hover{background:var(--bg3);color:var(--text);transform:translate(2px)}.preview-empty-icon{animation:4s ease-in-out infinite float}.preview-empty-text{animation:.5s cubic-bezier(.16,1,.3,1) .1s both fadeSlideUp}.settings-section{animation:.4s cubic-bezier(.16,1,.3,1) both fadeSlideUp}.settings-panel .settings-section:first-child{animation-delay:50ms}.settings-panel .settings-section:nth-child(2){animation-delay:.1s}.settings-panel .settings-section:nth-child(3){animation-delay:.15s}.settings-panel .settings-section:nth-child(4){animation-delay:.2s}.settings-panel .settings-section:nth-child(5){animation-delay:.25s}.settings-textarea{transition:border-color .15s,box-shadow .15s,transform .1s}.settings-textarea:focus{transform:scaleY(1.005)}.upload-btn{transition:all .15s cubic-bezier(.16,1,.3,1)}.upload-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}.upload-btn:active:not(:disabled){transform:scale(.95)}.audio-toggle-btn{transition:all .15s cubic-bezier(.16,1,.3,1)}.audio-toggle-btn:hover:not(:disabled){border-color:var(--accent);transform:translateY(-1px)}.mode-dropdown-btn{transition:all .15s cubic-bezier(.16,1,.3,1)}.mode-dropdown-btn:hover:not(:disabled){transform:translateY(-1px)}.chat-empty-title{animation:.5s cubic-bezier(.16,1,.3,1) .1s both fadeSlideUp}.chat-empty-sub{animation:.5s cubic-bezier(.16,1,.3,1) .2s both fadeSlideUp}.msg-flag-area{margin-top:6px}.msg-flag-btn{cursor:pointer;font-size:10px;font-family:var(--font-mono);color:var(--text3);opacity:0;background:0 0;border:none;padding:2px 0;transition:opacity .15s}.message.assistant:hover .msg-flag-btn{opacity:1}.msg-flag-noted{color:var(--accent3);font-size:10px;font-family:var(--font-mono)}.msg-flag-form{background:var(--bg3);border:1px solid var(--border);border-radius:var(--r-md);flex-direction:column;gap:8px;margin-top:4px;padding:10px 12px;display:flex}.msg-flag-question{color:var(--text2);letter-spacing:.3px;font-size:11px;font-weight:600}.msg-flag-chips{flex-wrap:wrap;gap:6px;display:flex}.msg-flag-chip{background:var(--bg2);border:1px solid var(--border);color:var(--text2);font-size:11px;font-family:var(--font-mono);cursor:pointer;border-radius:4px;padding:3px 8px;transition:all .15s}.msg-flag-chip.active{border-color:var(--accent);color:var(--accent);background:#7c6af71a}.msg-flag-chip:hover{border-color:var(--text3)}.msg-flag-input{background:var(--bg2);border:1px solid var(--border);color:var(--text);font-family:var(--font-mono);border-radius:4px;outline:none;padding:6px 8px;font-size:11px}.msg-flag-input:focus{border-color:var(--accent)}.msg-flag-actions{justify-content:flex-end;gap:8px;display:flex}.msg-flag-cancel{border:1px solid var(--border);color:var(--text3);font-size:11px;font-family:var(--font-mono);cursor:pointer;background:0 0;border-radius:4px;padding:4px 10px}.msg-flag-send{background:var(--accent);color:#fff;font-size:11px;font-family:var(--font-mono);cursor:pointer;border:none;border-radius:4px;padding:4px 12px;font-weight:600}.msg-flag-send:disabled{opacity:.5;cursor:default}.chat-error-block{border-radius:var(--r-md);background:#ff505012;border:1px solid #ff505038;align-items:flex-start;gap:10px;margin:2px 0;padding:10px 14px;display:flex}.chat-error-icon{color:#ff6060;background:#ff505026;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;margin-top:1px;font-size:13px;font-weight:700;display:flex}.chat-error-body{flex-direction:column;flex:1;gap:6px;display:flex}.chat-error-msg{color:var(--text2);font-size:13px;line-height:1.55}.chat-error-report{color:#ff6060;cursor:pointer;font-size:11px;font-family:var(--font-mono);background:0 0;border:1px solid #ff50504d;border-radius:4px;align-self:flex-start;padding:3px 8px;transition:all .15s}.chat-error-report:hover:not(:disabled){background:#ff50501f;border-color:#ff6060}.chat-error-report:disabled{opacity:.5;cursor:default;color:var(--text3);filter:none;border-color:#ffffff26}.clarify-card{flex-direction:column;gap:12px;padding:4px 0;display:flex}.clarify-question{font-size:14px;font-family:var(--font-sans);color:var(--text);font-weight:500;line-height:1.6}.clarify-options{flex-wrap:wrap;gap:8px;display:flex}.clarify-option-btn{background:var(--accent-subtle);border:1px solid var(--border);color:var(--text2);font-family:var(--font-sans);cursor:pointer;border-radius:var(--r-full);padding:8px 18px;font-size:13px;transition:all .15s cubic-bezier(.16,1,.3,1)}.clarify-option-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 4px 14px var(--accent-glow);transform:translateY(-2px)}.clarify-option-btn:active{transform:scale(.96)}.wallpaper-bg-layer{z-index:0;pointer-events:none;background-position:50%;background-size:cover;position:fixed;inset:-60px}html.has-wallpaper .app-root{z-index:1;position:relative}html.has-wallpaper{--bg:#0a0a0fc7;--bg2:#111118d1;--bg3:#1a1a24db}html.has-wallpaper body{background-color:#0a0a0f}html.has-wallpaper .app-root,html.has-wallpaper .app-header,html.has-wallpaper .sidebar,html.has-wallpaper .chat-panel,html.has-wallpaper .chat-input-area,html.has-wallpaper .settings-panel,html.has-wallpaper .preview-panel,html.has-wallpaper .editor-panel{-webkit-backdrop-filter:blur(18px)saturate(1.2)}.wallpaper-section{flex-direction:column;gap:10px;display:flex}.wallpaper-blur-row{align-items:center;gap:10px;display:flex}.wallpaper-blur-label{font-size:var(--fs-xs);color:var(--text2);font-family:var(--font-mono);min-width:28px}.wallpaper-blur-value{font-size:var(--fs-xs);color:var(--text2);font-family:var(--font-mono);text-align:right;min-width:24px}.wallpaper-blur-slider{appearance:none;background:var(--border);cursor:pointer;border-radius:2px;outline:none;flex:1;height:4px}.wallpaper-blur-slider::-webkit-slider-thumb{appearance:none;background:var(--accent);cursor:pointer;border-radius:50%;width:14px;height:14px;transition:transform .15s}.wallpaper-blur-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.wallpaper-blur-slider::-moz-range-thumb{background:var(--accent);cursor:pointer;border:none;border-radius:50%;width:14px;height:14px}.wallpaper-preview{border-radius:var(--r-lg);border:1px solid var(--border);background-position:50%;background-size:cover;width:100%;height:96px}.wallpaper-actions{gap:8px;display:flex}.wallpaper-upload-btn{background:var(--bg3);border:1px solid var(--accent);color:var(--accent);font-family:var(--font-mono);letter-spacing:1px;cursor:pointer;border-radius:var(--r-md);text-transform:uppercase;flex:1;padding:10px 16px;font-size:11px;transition:all .15s cubic-bezier(.16,1,.3,1)}.wallpaper-upload-btn:hover{background:var(--accent);color:#fff;transform:translateY(-1px)}.wallpaper-clear-btn{border:1px solid var(--border);color:var(--text3);font-family:var(--font-mono);letter-spacing:.5px;cursor:pointer;border-radius:var(--r-md);background:0 0;padding:10px 14px;font-size:11px;transition:all .15s}.wallpaper-clear-btn:hover{border-color:var(--danger);color:var(--danger)}.cropper-overlay{z-index:9999;background:#000000b8;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.cropper-modal{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);flex-direction:column;gap:14px;width:fit-content;max-width:min(96vw,1040px);padding:20px;display:flex;box-shadow:0 24px 64px #0009}.cropper-header{align-items:baseline;gap:12px;display:flex}.cropper-title{font-family:var(--font-mono);letter-spacing:1px;color:var(--accent);text-transform:uppercase;font-size:13px}.cropper-hint{font-family:var(--font-mono);color:var(--text3);font-size:10px}.cropper-canvas-wrap{border-radius:var(--r-md);border:1px solid var(--border);justify-content:center;align-items:center;max-width:90vw;max-height:70vh;display:flex;overflow:hidden}.cropper-canvas{cursor:crosshair;touch-action:none;max-width:90vw;max-height:70vh;display:block}.cropper-actions{justify-content:flex-end;gap:10px;display:flex}.cropper-skip-btn{border:1px solid var(--border);color:var(--text2);font-family:var(--font-mono);letter-spacing:.5px;cursor:pointer;border-radius:var(--r-md);background:0 0;padding:10px 18px;font-size:11px;transition:all .15s}.cropper-skip-btn:hover{border-color:var(--text2);color:var(--text1)}.cropper-apply-btn{background:var(--bg3);border:1px solid var(--accent);color:var(--accent);font-family:var(--font-mono);letter-spacing:1px;text-transform:uppercase;cursor:pointer;border-radius:var(--r-md);padding:10px 20px;font-size:11px;transition:all .15s cubic-bezier(.16,1,.3,1)}.cropper-apply-btn:hover{background:var(--accent);color:#fff;transform:translateY(-1px)}.cropper-loading{font-family:var(--font-mono);color:var(--text2);text-align:center;padding:40px 60px;font-size:13px}[data-theme=light]{--bg:#f0f0f5;--bg2:#fff;--bg3:#e4e4ec;--border:#c8c8d8;--border-subtle:#d8d8e8;--text:#1a1a2e;--text2:#5a5a7a;--text3:#9090b0;--text-chat:#2a2a4a;--surface:#fff;--muted:#9090b0}[data-theme=oled]{--bg:#000;--bg2:#080808;--bg3:#101010;--border:#1e1e1e;--border-subtle:#141414;--text:#f0f0f8;--text2:#a8a8c8;--text3:#6e6e90;--text-chat:#d4d4e8;--surface:#080808;--muted:#4a4a6a}.theme-customizer{flex-direction:column;gap:16px;display:flex}.theme-row{flex-direction:column;gap:8px;display:flex}.theme-row-label{color:var(--text3);letter-spacing:1px;text-transform:uppercase;font-size:11px}.theme-mode-btns{gap:6px;display:flex}.theme-mode-btn{border-radius:var(--r-lg);border:1px solid var(--border);background:var(--bg3);color:var(--text2);font-size:11px;font-family:var(--font-mono);cursor:pointer;text-align:center;flex:1;padding:8px 4px;transition:all .15s}.theme-mode-btn:hover{border-color:var(--accent);color:var(--text)}.theme-mode-btn.active{border-color:var(--accent);background:var(--accent);color:#fff}.theme-accent-swatches{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.theme-swatch{cursor:pointer;border:2px solid #0000;border-radius:50%;flex-shrink:0;width:28px;height:28px;transition:transform .15s,border-color .15s}.theme-swatch:hover{transform:scale(1.15)}.theme-swatch.active{border-color:var(--text);transform:scale(1.1)}.theme-swatch-custom{border:2px dashed var(--border);cursor:pointer;width:28px;height:28px;color:var(--text3);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;transition:border-color .15s;display:flex;overflow:hidden}.theme-swatch-custom:hover{border-color:var(--accent)}.theme-swatch-custom input[type=color]{opacity:0;cursor:pointer;width:28px;height:28px;font-size:16px;position:absolute}.theme-row--font{flex-direction:column;align-items:flex-start;gap:8px}.theme-font-grid{grid-template-columns:1fr 1fr;gap:6px;width:100%;display:grid}.theme-font-btn{background:var(--bg0);border:1px solid var(--border);cursor:pointer;text-align:left;border-radius:8px;flex-direction:column;gap:2px;padding:8px 10px;transition:border-color .15s,background .15s;display:flex}.theme-font-btn:hover{border-color:color-mix(in srgb,var(--accent)50%,transparent)}.theme-font-btn.active{border-color:var(--accent);background:color-mix(in srgb,var(--accent)10%,transparent)}.theme-font-name{color:var(--text1);font-size:12px;font-weight:600;line-height:1.2}.theme-font-hint{color:var(--text3);font-size:10px;font-family:var(--font-mono);letter-spacing:.03em;line-height:1.2}.launch-splash{z-index:9999;background:var(--bg);cursor:pointer;-webkit-user-select:none;user-select:none;flex-direction:column;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.launch-splash__pulse{background:radial-gradient(circle,#7c6af738 0%,#0000 70%);border-radius:50%;width:320px;height:320px;animation:2s ease-in-out infinite splash-pulse;position:absolute}@keyframes splash-pulse{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.3)}}.launch-splash__content{text-align:center;position:relative}.launch-splash__title{font-size:var(--fs-hero);color:var(--accent);letter-spacing:-.02em;margin:0 0 var(--sp-2);font-weight:700;line-height:1}.launch-splash__tagline{font-size:var(--fs-sm);color:var(--text2);letter-spacing:.04em;margin:0}.launch-splash__hint{bottom:calc(var(--safe-bottom) + var(--sp-6));font-size:var(--fs-xs);color:var(--text2);letter-spacing:.06em;margin:0;position:absolute}.theme-font-select:focus{border-color:var(--accent);outline:none}.sw-update-toast{bottom:calc(var(--safe-bottom) + var(--sp-4));right:var(--sp-4);z-index:1001;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--sp-2)var(--sp-3);align-items:center;gap:var(--sp-3);font-size:var(--fs-sm);color:var(--text2);display:flex;position:fixed;box-shadow:0 4px 24px #00000080}.sw-update-toast__reload{background:var(--accent);color:#fff;border-radius:var(--r-md);padding:var(--sp-1)var(--sp-2);font-size:var(--fs-xs);cursor:pointer;white-space:nowrap;border:none;font-weight:600}.sw-update-toast__reload:hover{background:var(--accent-hover)}.companion-trigger{cursor:pointer;z-index:200;background:linear-gradient(135deg,#7c3aed,#4f46e5);border:none;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;transition:box-shadow .2s,transform .15s;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 4px 20px #7c3aed73}.companion-trigger:hover{transform:scale(1.05);box-shadow:0 6px 28px #7c3aed99}.companion-trigger-label{color:#fff;z-index:1;font-family:Syne,sans-serif;font-size:18px;font-weight:800;line-height:1;position:relative}.companion-trigger-ring{pointer-events:none;border:1.5px solid #7c3aed80;border-radius:50%;position:absolute}.companion-trigger-ring--1{animation:3s ease-in-out infinite companion-breathe;inset:-8px}.companion-trigger-ring--2{animation:3s ease-in-out .5s infinite companion-breathe;inset:-16px}.companion-trigger--open:not(.companion-trigger--responding) .companion-trigger-ring{display:none}.companion-trigger--responding .companion-trigger-ring--1{border-color:#7c3aede6;animation:1s ease-in-out infinite companion-pulse-ring;display:block}.companion-trigger--responding .companion-trigger-ring--2{display:none}@keyframes companion-breathe{0%,to{opacity:.5;transform:scale(1)}50%{opacity:.85;transform:scale(1.1)}}@media (max-width:600px){.companion-trigger{width:42px;height:42px;bottom:90px;right:16px}}@keyframes companion-pulse-ring{0%,to{opacity:.4;transform:scale(1)}50%{opacity:1;transform:scale(1.18)}}.companion-drawer{z-index:300;background:#0e0e1a;border-left:1px solid #7c3aed33;flex-direction:column;width:300px;display:flex;position:fixed;top:0;bottom:0;right:0;overflow:hidden;box-shadow:-8px 0 40px #0009}@media (max-width:600px){.companion-drawer{border-top:none;border-bottom:1px solid #7c3aed4d;border-left:none;border-radius:0 0 18px 18px;width:100%;height:44vh;inset:0 0 auto;box-shadow:0 8px 32px #000000b3}.companion-header{padding:10px 12px}.companion-messages{gap:6px;padding:8px 10px}.companion-bubble{padding:6px 8px;font-size:11px}.companion-empty{padding:12px 10px;font-size:11px}.companion-input-area{gap:4px;padding:8px 10px}.companion-capture-btn{padding:3px 7px;font-size:10px}.companion-textarea{font-size:13px}}.companion-header{border-bottom:1px solid #7c3aed26;flex-shrink:0;align-items:center;gap:8px;padding:12px 14px;display:flex}.companion-logo{color:#7c3aed;font-size:16px;line-height:1}.companion-title{letter-spacing:.12em;color:#e8e8f0;font-family:Syne,sans-serif;font-size:12px;font-weight:700}.companion-session{color:#7c3aed99;margin-left:2px;font-family:JetBrains Mono,monospace;font-size:10px}.companion-clear{color:#4a4a6a;cursor:pointer;background:0 0;border:none;margin-left:auto;padding:4px;font-size:14px;line-height:1;transition:color .15s}.companion-clear:hover{color:#e8e8f0}.companion-clear:disabled{opacity:.3;cursor:default}.companion-close{color:#4a4a6a;cursor:pointer;background:0 0;border:none;padding:4px;font-size:12px;line-height:1;transition:color .15s}.companion-close:hover{color:#e8e8f0}.companion-messages{flex-direction:column;flex:1;gap:8px;padding:12px;display:flex;overflow-y:auto}.companion-empty{color:#4a4a6a;text-align:center;padding:24px 12px;font-size:11px;line-height:1.6}.companion-bubble{word-break:break-word;border-radius:10px;max-width:100%;padding:8px 10px;font-size:12px;line-height:1.55}.companion-bubble--user{color:#c8c8e0;background:#7c3aed2e;border-bottom-right-radius:3px;align-self:flex-end}.companion-bubble--assistant{color:#c0c0d8;white-space:pre-wrap;background:#ffffff0a;border-bottom-left-radius:3px;align-self:flex-start}.companion-cursor{vertical-align:middle;background:#7c3aed;width:2px;height:12px;margin-left:2px;animation:.8s step-end infinite companion-blink;display:inline-block}@keyframes companion-blink{0%,to{opacity:1}50%{opacity:0}}.companion-capture-card{background:#7c3aed14;border:1px solid #7c3aed33;border-radius:8px;margin-bottom:4px;padding:8px 10px;position:relative;overflow:hidden}.companion-capture-label{color:#7c3aedcc;letter-spacing:.05em;margin-bottom:6px;font-size:10px}.companion-capture-thumb{object-fit:cover;border-radius:4px;width:100%;max-height:100px;display:block}.companion-scan-line{background:linear-gradient(90deg,#0000,#7c3aed99,#0000);height:1px;animation:2s linear infinite companion-scan;position:absolute;top:0;left:0;right:0}@keyframes companion-scan{0%{top:0}to{top:100%}}.companion-input-area{border-top:1px solid #7c3aed1f;flex-direction:column;flex-shrink:0;gap:6px;padding:10px;display:flex}.companion-capture-row{align-items:center;gap:6px;display:flex}.companion-capture-btn{color:#88a;cursor:pointer;background:#ffffff0a;border:1px solid #ffffff14;border-radius:6px;padding:4px 8px;font-size:10px;transition:background .15s,color .15s,border-color .15s}.companion-capture-btn:hover:not(:disabled){color:#c8c8e0;background:#7c3aed26;border-color:#7c3aed59}.companion-capture-btn.active{color:#c8c8e0;background:#7c3aed33;border-color:#7c3aed80}.companion-capture-btn:disabled{opacity:.4;cursor:default}.companion-capture-error{color:#ff6b6b;margin-left:4px;font-size:10px}.companion-pending-badge{color:#7c3aede6;background:#7c3aed1f;border:1px solid #7c3aed40;border-radius:6px;align-items:center;gap:6px;padding:4px 8px;font-size:10px;display:flex}.companion-pending-clear{color:#4a4a6a;cursor:pointer;background:0 0;border:none;margin-left:auto;padding:0;font-size:10px;line-height:1}.companion-pending-clear:hover{color:#ff6b6b}.companion-input-row{align-items:flex-end;gap:6px;display:flex}.companion-textarea{color:#e8e8f0;resize:none;background:#ffffff0a;border:1px solid #7c3aed33;border-radius:8px;flex:1;min-height:34px;max-height:100px;padding:7px 10px;font-family:inherit;font-size:12px;line-height:1.5;transition:border-color .15s;overflow-y:auto}.companion-textarea:focus{border-color:#7c3aed73;outline:none}.companion-textarea::placeholder{color:#4a4a6a}.companion-textarea:disabled{opacity:.5}.companion-send{color:#c8c8e0;cursor:pointer;background:#7c3aed40;border:1px solid #7c3aed66;border-radius:8px;flex-shrink:0;padding:7px 11px;font-size:12px;line-height:1;transition:background .15s}.companion-send:hover:not(:disabled){background:#7c3aed66}.companion-send:disabled{opacity:.4;cursor:default}.suggestion-chips{flex-wrap:wrap;gap:8px;padding:4px 0 8px;display:flex}.suggestion-chip{background:var(--bg3);border:1px solid var(--border);color:var(--text2);cursor:pointer;font-size:12px;font-family:var(--font-sans);-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation;border-radius:20px;padding:6px 14px;transition:border-color .15s,color .15s,background .15s}.suggestion-chip:hover{border-color:var(--accent);color:var(--accent);background:#7c6af714}.pricing-overlay{z-index:2000;padding:var(--sp-4);background:#000000b8;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.pricing-card{border-radius:var(--r-xl);padding:var(--sp-6);background:#0f0f1a;border:1px solid #ffffff1a;width:100%;max-width:560px;position:relative;box-shadow:0 24px 80px #000c}.pricing-close{top:var(--sp-4);right:var(--sp-4);color:var(--text3);cursor:pointer;border-radius:var(--r-sm);background:0 0;border:none;padding:4px 8px;font-size:16px;transition:color .15s;position:absolute}.pricing-close:hover{color:var(--text)}.pricing-header{text-align:center;margin-bottom:var(--sp-5)}.pricing-logo{color:var(--accent);font-size:28px;font-weight:800;font-family:var(--font-mono);margin-bottom:var(--sp-3)}.pricing-title{font-size:var(--fs-lg);color:var(--text);margin:0 0 var(--sp-2);font-weight:700}.pricing-reason{font-size:var(--fs-sm);color:var(--text2);margin:0}.pricing-tiers{gap:var(--sp-3);margin-bottom:var(--sp-4);grid-template-columns:1fr 1fr;display:grid}@media (max-width:480px){.pricing-tiers{grid-template-columns:1fr}}.pricing-tier{border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--sp-4);position:relative}.pricing-tier--pro{border-color:var(--accent);background:#7c6af70f}.pricing-tier-badge{background:var(--accent);color:#fff;letter-spacing:.06em;text-transform:uppercase;border-radius:20px;padding:2px 10px;font-size:10px;font-weight:700;position:absolute;top:-10px;left:50%;transform:translate(-50%)}.pricing-tier-name{font-size:var(--fs-sm);color:var(--text2);margin-bottom:4px;font-weight:600}.pricing-tier-price{font-size:var(--fs-2xl);color:var(--text);margin-bottom:var(--sp-3);font-weight:800}.pricing-tier-price span{font-size:var(--fs-sm);color:var(--text2);font-weight:400}.pricing-original-price{font-size:var(--fs-sm);color:var(--text2);font-family:var(--font-mono);margin-right:6px;text-decoration:line-through}.pricing-founding-label{font-size:var(--fs-xs);color:var(--accent);font-family:var(--font-mono);letter-spacing:.04em;text-transform:uppercase;margin-top:2px}.pricing-tier-list{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.pricing-tier-list li{font-size:var(--fs-xs);color:var(--text2);align-items:baseline;gap:6px;display:flex}.pricing-check{color:var(--accent);flex-shrink:0;font-size:11px}.pricing-check--dim{color:var(--text3)}.pricing-usage-bar{margin-top:var(--sp-3);color:var(--text3);font-size:11px}.pricing-usage-bar>div{background:var(--border);border-radius:2px;height:4px;margin-bottom:4px;overflow:hidden}.pricing-usage-fill{background:var(--accent);border-radius:2px;height:100%;transition:width .4s}.pricing-error{font-size:var(--fs-xs);color:#f87171;text-align:center;margin-bottom:var(--sp-3)}.pricing-upgrade-btn{background:var(--accent);color:#fff;border-radius:var(--r-md);width:100%;font-size:var(--fs-sm);cursor:pointer;touch-action:manipulation;border:none;padding:12px;font-weight:700;transition:background .15s,opacity .15s}.pricing-upgrade-btn:hover{background:var(--accent-hover)}.pricing-upgrade-btn:disabled{opacity:.6;cursor:wait}.pricing-free-ai-btn{border:1px solid var(--border);width:100%;color:var(--text2);font-size:var(--fs-xs);font-family:var(--font-mono);cursor:pointer;text-align:center;touch-action:manipulation;background:0 0;border-radius:8px;padding:10px 16px;transition:border-color .15s,color .15s}.pricing-free-ai-btn:hover{border-color:var(--accent3);color:var(--text)}.pricing-note{text-align:center;font-size:var(--fs-xs);color:var(--text3);margin:var(--sp-2)0 0}.plan-badge-row{align-items:center;gap:var(--sp-3);margin-bottom:var(--sp-3);display:flex}.plan-badge{font-size:var(--fs-xs);letter-spacing:.04em;border-radius:20px;padding:3px 10px;font-weight:700}.plan-badge--free{color:var(--text2);border:1px solid var(--border);background:#ffffff0f}.plan-badge--pro{color:var(--accent);border:1px solid var(--accent);background:#7c6af72e}.plan-usage{font-size:var(--fs-xs);color:var(--text3)}.plan-dates{color:var(--text3);flex-wrap:wrap;gap:4px;margin-top:4px;font-size:11px;display:flex}.plan-upgrade-btn{background:var(--accent);color:#fff;border-radius:var(--r-md);width:100%;font-size:var(--fs-xs);cursor:pointer;touch-action:manipulation;border:none;padding:9px 12px;font-weight:700;transition:background .15s}.plan-upgrade-btn:hover{background:var(--accent-hover)}.plan-portal-btn{width:100%;color:var(--text2);border:1px solid var(--border);border-radius:var(--r-md);font-size:var(--fs-xs);cursor:pointer;touch-action:manipulation;background:0 0;padding:9px 12px;font-weight:600;transition:border-color .15s,color .15s}.beta-banner{z-index:9999;background:color-mix(in srgb,var(--accent)15%,var(--bg2));border-bottom:1px solid var(--accent);font-size:11px;font-family:var(--font-mono);color:var(--text2);text-align:center;padding:5px 16px;position:fixed;top:0;left:0;right:0}body:has(.beta-banner) .app-root{height:calc(100vh - 28px);margin-top:28px}.beta-banner a{color:var(--accent);text-decoration:none}.beta-banner a:hover{text-decoration:underline}.feedback-header-btn{border:1px solid var(--border);color:var(--text2);font-size:var(--fs-xs);font-family:var(--font-mono);cursor:pointer;background:0 0;border-radius:6px;padding:5px 10px;transition:border-color .15s,color .15s}.feedback-header-btn:hover{border-color:var(--accent);color:var(--accent)}.feedback-backdrop{z-index:1100;background:#0000008c;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.feedback-modal{background:var(--bg2);border:1px solid var(--border);border-radius:14px;flex-direction:column;gap:14px;width:100%;max-width:440px;padding:24px;display:flex}.feedback-header{justify-content:space-between;align-items:center;display:flex}.feedback-title{font-family:var(--font-mono);font-size:var(--fs-sm);color:var(--text1);font-weight:700}.feedback-close{color:var(--text3);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:14px;line-height:1;transition:color .15s}.feedback-close:hover{color:var(--text1)}.feedback-type-row{gap:8px;display:flex}.feedback-type-btn{background:var(--bg3);border:1px solid var(--border);color:var(--text2);font-size:var(--fs-xs);font-family:var(--font-mono);cursor:pointer;border-radius:7px;flex:1;padding:6px 8px;transition:border-color .15s,color .15s,background .15s}.feedback-type-btn:hover{border-color:var(--accent);color:var(--accent)}.feedback-type-btn.active{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb,var(--accent)10%,transparent)}.feedback-textarea{background:var(--bg3);border:1px solid var(--border);width:100%;color:var(--text1);font-family:var(--font-mono);font-size:var(--fs-xs);resize:vertical;border-radius:8px;outline:none;padding:10px 12px;line-height:1.55;transition:border-color .15s}.feedback-textarea:focus{border-color:var(--accent)}.feedback-textarea::placeholder{color:var(--text3)}.feedback-email{background:var(--bg3);border:1px solid var(--border);width:100%;color:var(--text1);font-family:var(--font-mono);font-size:var(--fs-xs);border-radius:8px;outline:none;padding:8px 12px;transition:border-color .15s}.feedback-email:focus{border-color:var(--accent)}.feedback-email::placeholder{color:var(--text3)}.feedback-footer{justify-content:space-between;align-items:center;gap:8px;display:flex}.feedback-hint{color:var(--text3);font-size:11px;font-family:var(--font-mono)}.feedback-hint a{color:var(--text2);text-decoration:none}.feedback-hint a:hover{color:var(--accent)}.feedback-submit{background:var(--accent);color:#fff;font-family:var(--font-mono);font-size:var(--fs-xs);cursor:pointer;border:none;border-radius:7px;padding:8px 18px;font-weight:700;transition:opacity .15s}.feedback-submit:disabled{opacity:.45;cursor:not-allowed}.feedback-submit:not(:disabled):hover{opacity:.85}.feedback-done{text-align:center;flex-direction:column;align-items:center;gap:10px;padding:16px 0;display:flex}.feedback-done-icon{color:var(--accent);font-size:28px}.feedback-done-text{font-family:var(--font-mono);font-size:var(--fs-sm);color:var(--text1);font-weight:700}.feedback-done-sub{font-size:var(--fs-xs);color:var(--text3);font-family:var(--font-mono)}.rm-root{background:var(--bg0);height:100vh;color:var(--text1);font-family:var(--font-mono);padding:0 0 80px;overflow-y:auto}.rm-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 32px;display:flex}.rm-logo{color:var(--accent);letter-spacing:-.5px;font-size:20px;font-weight:700;text-decoration:none}.rm-back{font-size:var(--fs-sm);color:var(--text3);text-decoration:none;transition:color .15s}.rm-back:hover{color:var(--text1)}.rm-hero{text-align:center;flex-direction:column;align-items:center;gap:16px;padding:72px 24px 56px;display:flex}.rm-hero-badge{letter-spacing:.12em;text-transform:uppercase;color:var(--accent);background:color-mix(in srgb,var(--accent)12%,transparent);border:1px solid color-mix(in srgb,var(--accent)30%,transparent);border-radius:20px;padding:4px 12px;font-size:11px;font-weight:700}.rm-headline{letter-spacing:-1px;margin:0;font-size:clamp(32px,5vw,52px);font-weight:800;line-height:1.1}.rm-subheadline{font-size:var(--fs-sm);color:var(--text3);max-width:480px;margin:0;line-height:1.65}.rm-support-btn{background:var(--accent);color:#000;font-family:var(--font-mono);font-size:var(--fs-sm);border-radius:8px;align-items:center;gap:6px;margin-top:8px;padding:10px 22px;font-weight:700;text-decoration:none;transition:opacity .15s;display:inline-flex}.rm-support-btn:hover{opacity:.85}.rm-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;max-width:1100px;margin:0 auto;padding:0 24px;display:grid}.rm-section{background:var(--bg1);border:1px solid var(--border);border-radius:12px;padding:24px}.rm-section--dim{opacity:.6}.rm-section-header{border-bottom:1px solid var(--border);align-items:center;gap:10px;margin-bottom:20px;padding-bottom:14px;display:flex}.rm-section-icon{color:var(--accent);font-size:16px;font-weight:700}.rm-section-title{font-size:var(--fs-sm);letter-spacing:.04em;text-transform:uppercase;color:var(--text2);font-weight:700}.rm-items{flex-direction:column;gap:14px;display:flex}.rm-item{align-items:flex-start;gap:10px;display:flex}.rm-item-dot{color:var(--accent);opacity:.7;flex-shrink:0;margin-top:2px;font-size:10px}.rm-item-label{font-size:var(--fs-sm);color:var(--text1);font-weight:600}.rm-item-desc{font-size:var(--fs-xs);color:var(--text3);line-height:1.5}.rm-header-nav{align-items:center;gap:20px;display:flex}.rm-nav-link{font-size:var(--fs-sm);color:var(--text3);text-decoration:none;transition:color .15s}.rm-nav-link:hover{color:var(--text1)}.rm-section-badge{color:var(--text3);background:var(--bg2);border:1px solid var(--border);border-radius:20px;margin-left:auto;padding:2px 8px;font-size:10px}.rm-hero-actions{flex-wrap:wrap;justify-content:center;align-items:center;gap:12px;margin-top:8px;display:flex}.rm-cta-primary{background:var(--accent);color:#000;font-family:var(--font-mono);font-size:var(--fs-sm);border-radius:8px;align-items:center;padding:10px 22px;font-weight:700;text-decoration:none;transition:opacity .15s;display:inline-flex}.rm-cta-primary:hover{opacity:.85}.rm-cta-secondary{color:var(--text2);font-family:var(--font-mono);font-size:var(--fs-sm);border:1px solid var(--border);background:0 0;border-radius:8px;align-items:center;gap:6px;padding:10px 22px;font-weight:700;text-decoration:none;transition:border-color .15s,color .15s;display:inline-flex}.rm-cta-secondary:hover{border-color:var(--accent);color:var(--accent)}.rm-stats-row{flex-wrap:wrap;justify-content:center;gap:32px;margin-top:12px;display:flex}.rm-stat{flex-direction:column;align-items:center;gap:2px;display:flex}.rm-stat-num{color:var(--accent);font-size:28px;font-weight:800;line-height:1}.rm-stat-label{color:var(--text3);text-align:center;font-size:10px}.rm-mission{max-width:680px;margin:60px auto 0;padding:0 24px}.rm-mission-inner{background:var(--bg1);border:1px solid var(--border);text-align:center;border-radius:16px;flex-direction:column;align-items:center;gap:16px;padding:40px;display:flex}.rm-mission-icon{color:var(--accent);font-size:28px;font-weight:800}.rm-mission-quote{color:var(--text1);max-width:540px;margin:0;font-size:clamp(14px,2vw,18px);font-style:italic;line-height:1.7}.rm-mission-author{font-size:var(--fs-xs);color:var(--text3)}.rm-mission-actions{margin-top:8px}.rm-footer{font-size:var(--fs-xs);color:var(--text3);flex-wrap:wrap;justify-content:center;align-items:center;gap:12px;padding:40px 24px 0;display:flex}.rm-footer-link{color:var(--accent);text-decoration:none;transition:opacity .15s}.rm-footer-link:hover{opacity:.75}.rm-footer-sep{color:var(--border)}.plan-portal-btn:hover{border-color:var(--accent);color:var(--accent)}.plan-resync-btn{width:100%;color:var(--text3);font-family:var(--font-mono);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:6px;padding:6px 0;font-size:10px;transition:color .15s}.plan-resync-btn:hover{color:var(--text2)}.referral-loading{font-size:var(--fs-xs);color:var(--text3);font-family:var(--font-mono)}.apikey-section{flex-direction:column;gap:8px;display:flex}.apikey-reveal{background:#7c6af71f;border:1px solid #7c6af766;border-radius:8px;flex-direction:column;gap:6px;padding:10px 12px;display:flex}.apikey-reveal-label{color:var(--accent);text-transform:uppercase;letter-spacing:.08em;font-size:10px;font-weight:700}.apikey-reveal-row{align-items:center;gap:8px;display:flex}.apikey-code{color:var(--text-primary);word-break:break-all;flex:1;font-family:JetBrains Mono,monospace;font-size:11px}.apikey-copy-btn{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:6px;padding:5px 10px;font-size:11px;font-weight:700}.apikey-row{background:#ffffff0a;border:1px solid #ffffff12;border-radius:7px;justify-content:space-between;align-items:center;gap:8px;padding:8px 10px;display:flex}.apikey-row-meta{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.apikey-name{color:var(--text-primary);font-size:12px;font-weight:600}.apikey-hint{color:var(--text-secondary);font-size:10px}.apikey-revoke-btn{color:#ff5050;cursor:pointer;background:0 0;border:1px solid #ff505066;border-radius:5px;padding:4px 8px;font-size:10px;font-weight:700;transition:background .15s}.apikey-revoke-btn:hover{background:#ff50501f}.apikey-create-row{gap:6px;display:flex}.apikey-name-input{color:var(--text-primary);background:#ffffff0f;border:1px solid #ffffff1f;border-radius:6px;flex:1;padding:6px 10px;font-family:inherit;font-size:12px}.apikey-name-input::placeholder{color:var(--text-secondary)}.apikey-create-btn{color:var(--accent);cursor:pointer;white-space:nowrap;background:#7c6af72e;border:1px solid #7c6af759;border-radius:6px;padding:6px 12px;font-size:11px;font-weight:700}.apikey-create-btn:disabled{opacity:.5;cursor:not-allowed}.apikey-migration-notice{color:#e8a045;background:#e8a04514;border:1px solid #e8a04533;border-radius:6px;margin:0 0 10px;padding:6px 10px;font-size:10px;line-height:1.5}.apikey-error-text{color:#ff6b6b;margin:4px 0 0;font-size:11px;line-height:1.5}.apikey-hint-text{color:var(--text-secondary);margin:0;font-size:10px;line-height:1.5}.apikey-hint-text code{background:#ffffff12;border-radius:3px;padding:1px 4px;font-family:JetBrains Mono,monospace}.pantheon-onboarding-card{background:#7c6af712;border:1px solid #7c6af738;border-radius:8px;flex-direction:column;gap:7px;margin:0 0 10px;padding:10px 12px;display:flex}.pantheon-onboarding-title{color:var(--accent);text-transform:uppercase;letter-spacing:.08em;font-size:10px;font-weight:700}.pantheon-onboarding-steps{color:var(--text-secondary);flex-direction:column;gap:4px;margin:0;padding:0 0 0 14px;font-size:11px;line-height:1.5;display:flex}.pantheon-onboarding-link{color:var(--accent);text-underline-offset:2px;-webkit-text-decoration:underline #7c6af773;text-decoration:underline #7c6af773}.pantheon-onboarding-link:hover{-webkit-text-decoration-color:var(--accent);text-decoration-color:var(--accent)}.pantheon-onboarding-code{color:var(--text-primary);background:#ffffff12;border-radius:3px;padding:1px 4px;font-family:JetBrains Mono,monospace;font-size:10px}.referral-panel{flex-direction:column;gap:12px;display:flex}.referral-desc{font-size:var(--fs-xs);color:var(--text3);margin:0;line-height:1.55}.referral-desc strong{color:var(--text2);font-weight:600}.referral-link-row{background:var(--bg0);border:1px solid var(--border);border-radius:8px;align-items:center;gap:8px;padding:8px 10px;display:flex}.referral-link-text{color:var(--text2);font-size:11px;font-family:var(--font-mono);text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.referral-copy-btn{background:var(--accent);color:#000;font-family:var(--font-mono);cursor:pointer;border:none;border-radius:5px;flex-shrink:0;padding:4px 10px;font-size:11px;font-weight:700;transition:opacity .15s}.referral-copy-btn:hover{opacity:.85}.referral-stats{gap:16px;display:flex}.referral-stat{flex-direction:column;gap:2px;display:flex}.referral-stat-value{color:var(--text1);font-size:22px;font-weight:800;line-height:1}.referral-stat--bonus .referral-stat-value{color:var(--accent)}.referral-stat-label{color:var(--text3);font-size:10px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em}.gal-root{background:var(--bg0);height:100vh;color:var(--text1);font-family:var(--font-mono);padding-bottom:80px;overflow-y:auto}.gal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 32px;display:flex}.gal-logo{color:var(--accent);font-size:20px;font-weight:700;text-decoration:none}.gal-back{font-size:var(--fs-sm);color:var(--text3);text-decoration:none;transition:color .15s}.gal-back:hover{color:var(--text1)}.gal-hero{text-align:center;flex-direction:column;align-items:center;gap:14px;padding:64px 24px 40px;display:flex}.gal-hero-badge{letter-spacing:.12em;text-transform:uppercase;color:var(--accent);background:color-mix(in srgb,var(--accent)12%,transparent);border:1px solid color-mix(in srgb,var(--accent)30%,transparent);border-radius:20px;padding:4px 12px;font-size:11px;font-weight:700}.gal-headline{letter-spacing:-.5px;margin:0;font-size:clamp(28px,4vw,44px);font-weight:800}.gal-subheadline{font-size:var(--fs-sm);color:var(--text3);margin:0}.gal-loading{justify-content:center;padding:80px;display:flex}.gal-loading-dots{align-items:center;gap:6px;display:flex}.gal-loading-dots span{background:var(--accent);border-radius:50%;width:6px;height:6px;animation:1.2s ease-in-out infinite gal-pulse}.gal-loading-dots span:nth-child(2){animation-delay:.2s}.gal-loading-dots span:nth-child(3){animation-delay:.4s}@keyframes gal-pulse{0%,80%,to{opacity:.2;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.gal-empty{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:80px 24px;display:flex}.gal-empty-icon{color:var(--accent);font-size:32px}.gal-empty-title{font-size:18px;font-weight:700}.gal-empty-sub{font-size:var(--fs-sm);color:var(--text3)}.gal-empty-btn{background:var(--accent);color:#000;font-family:var(--font-mono);font-size:var(--fs-sm);border-radius:8px;margin-top:8px;padding:10px 22px;font-weight:700;text-decoration:none;transition:opacity .15s}.gal-empty-btn:hover{opacity:.85}.gal-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px;max-width:1200px;margin:0 auto;padding:0 24px;display:grid}.gal-card{background:var(--bg1);border:1px solid var(--border);border-radius:12px;transition:border-color .15s,transform .15s;overflow:hidden}.gal-card:hover{border-color:color-mix(in srgb,var(--accent)40%,transparent);transform:translateY(-2px)}.gal-card-preview{aspect-ratio:16/9;background:var(--bg0);width:100%;position:relative;overflow:hidden}.gal-card-preview iframe{pointer-events:none;border:none;width:100%;height:100%;display:block}.gal-card-preview-placeholder{background:var(--bg0);justify-content:center;align-items:center;width:100%;height:100%;display:flex}.gal-placeholder-logo{color:var(--accent);opacity:.3;font-size:24px;font-weight:700;font-family:var(--font-mono)}.gal-card-body{flex-direction:column;gap:8px;padding:14px 16px;display:flex}.gal-card-name{font-size:var(--fs-sm);color:var(--text1);white-space:nowrap;text-overflow:ellipsis;font-weight:700;overflow:hidden}.gal-card-meta{color:var(--text3);justify-content:space-between;align-items:center;font-size:11px;display:flex}.gal-card-remixes{color:var(--accent);font-weight:600}.gal-card-remix-btn{border:1px solid var(--accent);color:var(--accent);font-family:var(--font-mono);cursor:pointer;background:0 0;border-radius:6px;align-self:flex-end;padding:6px 14px;font-size:12px;font-weight:700;transition:background .15s,color .15s}.gal-card-remix-btn:hover:not(:disabled){background:var(--accent);color:#000}.gal-card-remix-btn:disabled{opacity:.5;cursor:not-allowed}.gal-footer{font-size:var(--fs-xs);color:var(--text3);justify-content:center;align-items:center;gap:12px;padding:48px 24px 0;display:flex}.gal-footer-link{color:var(--accent);text-decoration:none;transition:opacity .15s}.gal-footer-link:hover{opacity:.75}.gal-footer-sep{color:var(--border)}.gallery-publish-btn{font-family:var(--font-mono);font-size:var(--fs-xs);border:1px solid var(--accent);color:var(--accent);cursor:pointer;white-space:nowrap;background:0 0;border-radius:6px;padding:5px 12px;font-weight:600;transition:background .15s,color .15s}.gallery-publish-btn:hover:not(:disabled){background:var(--accent);color:#000}.gallery-publish-btn.published{border-color:var(--text3);color:var(--text3);cursor:default}.gallery-publish-modal{background:var(--bg1);border:1px solid var(--border);border-radius:14px;flex-direction:column;gap:14px;width:min(420px,90vw);padding:28px;display:flex}.gpm-title{color:var(--text1);font-size:16px;font-weight:800}.gpm-desc{font-size:var(--fs-sm);color:var(--text3);margin:0;line-height:1.6}.gpm-desc strong{color:var(--text2);font-weight:600}.gpm-label{color:var(--text2);text-transform:uppercase;letter-spacing:.06em;font-size:11px;font-weight:600}.gpm-input{background:var(--bg0);border:1px solid var(--border);color:var(--text1);font-family:var(--font-mono);font-size:var(--fs-sm);box-sizing:border-box;border-radius:8px;width:100%;padding:9px 12px}.gpm-input:focus{border-color:var(--accent);outline:none}.gpm-actions{justify-content:flex-end;gap:10px;margin-top:4px;display:flex}.gpm-cancel{border:1px solid var(--border);color:var(--text3);font-family:var(--font-mono);font-size:var(--fs-sm);cursor:pointer;background:0 0;border-radius:7px;padding:8px 16px;transition:border-color .15s,color .15s}.gpm-cancel:hover{border-color:var(--text2);color:var(--text1)}.gpm-confirm{background:var(--accent);color:#000;font-family:var(--font-mono);font-size:var(--fs-sm);cursor:pointer;border:none;border-radius:7px;padding:8px 18px;font-weight:700;transition:opacity .15s}.gpm-confirm:hover{opacity:.85}.gate-root{background:var(--bg0);min-height:100vh;font-family:var(--font-mono);justify-content:center;align-items:center;padding:24px;display:flex}.gate-card{text-align:center;flex-direction:column;align-items:center;gap:16px;width:min(400px,100%);display:flex}.gate-logo{color:var(--accent);letter-spacing:-1px;font-size:32px;font-weight:800}.gate-title{color:var(--text1);margin:0;font-size:22px;font-weight:800}.gate-desc{font-size:var(--fs-sm);color:var(--text3);margin:0;line-height:1.6}.gate-form{flex-direction:column;gap:10px;width:100%;margin-top:8px;display:flex}.gate-input{background:var(--bg1);border:1px solid var(--border);width:100%;color:var(--text1);font-family:var(--font-mono);text-align:center;letter-spacing:.12em;box-sizing:border-box;border-radius:10px;padding:12px 16px;font-size:16px;transition:border-color .15s}.gate-input:focus{border-color:var(--accent);outline:none}.gate-input--error{border-color:#f76a6a}.gate-error{font-size:var(--fs-xs);color:#f76a6a;text-align:center}.gate-btn{background:var(--accent);color:#000;width:100%;font-family:var(--font-mono);font-size:var(--fs-sm);cursor:pointer;border:none;border-radius:10px;padding:12px;font-weight:700;transition:opacity .15s}.gate-btn:hover:not(:disabled){opacity:.85}.gate-btn:disabled{opacity:.4;cursor:not-allowed}.gate-hint{font-size:var(--fs-xs);color:var(--text3);margin:0}.gate-hint-link{color:var(--accent);text-decoration:none}.gate-hint-link:hover{opacity:.75}.gate-input-wrap{width:100%;position:relative}.gate-input-wrap .gate-input{padding-right:44px}.gate-peek-btn{color:var(--text3);cursor:pointer;-webkit-user-select:none;user-select:none;background:0 0;border:none;padding:4px;font-size:16px;line-height:1;transition:color .15s;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.gate-peek-btn:hover{color:var(--text1)}.gal-grid{grid-template-columns:repeat(auto-fill,minmax(480px,1fr))!important;gap:32px!important}.gal-card-preview{aspect-ratio:4/3!important}.gal-card-body{gap:10px!important;padding:18px 20px!important}.gal-card-name{font-size:16px!important}.gal-card-meta{font-size:13px!important}.gal-card-remix-btn{padding:8px 18px!important;font-size:13px!important}.landing-header-nav{align-items:center;gap:20px;display:flex}.landing-nav-link{font-family:var(--font-mono);font-size:var(--fs-sm);color:var(--text3);text-decoration:none;transition:color .15s}.landing-nav-link:hover{color:var(--text1)}.landing-gallery{max-width:1200px;margin:0 auto;padding:80px 24px}.landing-gallery-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:36px;display:flex}.landing-gallery-label{letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:8px;font-size:11px;font-weight:700}.landing-gallery-title{letter-spacing:-.5px;color:var(--text1);margin:0 0 8px;font-size:clamp(24px,3vw,36px);font-weight:800}.landing-gallery-sub{font-size:var(--fs-sm);color:var(--text3);font-family:var(--font-mono);margin:0}.landing-gallery-browse-btn{border:1px solid var(--accent);color:var(--accent);font-family:var(--font-mono);font-size:var(--fs-sm);white-space:nowrap;border-radius:8px;flex-shrink:0;align-items:center;padding:10px 22px;font-weight:700;text-decoration:none;transition:background .15s,color .15s;display:inline-flex}.landing-gallery-browse-btn:hover{background:var(--accent);color:#000}.landing-gal-grid{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}@media (max-width:900px){.landing-gal-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:600px){.landing-gal-grid{grid-template-columns:1fr}}.landing-gal-card{background:var(--bg1);border:1px solid var(--border);border-radius:12px;text-decoration:none;transition:border-color .15s,transform .15s;display:block;overflow:hidden}.landing-gal-card:hover{border-color:color-mix(in srgb,var(--accent)50%,transparent);transform:translateY(-3px)}.landing-gal-preview{aspect-ratio:4/3;background:var(--bg0);width:100%;position:relative;overflow:hidden}.landing-gal-preview iframe{pointer-events:none;border:none;width:100%;height:100%;display:block}.landing-gal-placeholder{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.landing-gal-placeholder span{color:var(--accent);opacity:.2;font-size:28px;font-weight:700;font-family:var(--font-mono)}.landing-gal-card-body{flex-direction:column;gap:4px;padding:14px 16px;display:flex}.landing-gal-card-name{font-size:var(--fs-sm);color:var(--text1);white-space:nowrap;text-overflow:ellipsis;font-weight:700;overflow:hidden}.landing-gal-card-meta{color:var(--text3);font-size:11px;font-family:var(--font-mono)}.landing-gallery-cta-row{justify-content:center;margin-top:32px;display:flex}.landing-gallery-cta-link{font-family:var(--font-mono);font-size:var(--fs-sm);color:var(--accent);text-decoration:none;transition:opacity .15s}.landing-gallery-cta-link:hover{opacity:.75}.crop-overlay{z-index:1200;background:#000000b3;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.crop-modal{background:var(--bg2);border:1px solid var(--border);border-radius:12px;flex-direction:column;width:min(860px,100%);max-height:90vh;display:flex;overflow:hidden}.crop-modal-header{border-bottom:1px solid var(--border-subtle);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:12px;padding:12px 16px;display:flex}.crop-ratio-pills{flex-wrap:wrap;flex:1;gap:4px;display:flex}.crop-ratio-pill{background:var(--bg3);border:1px solid var(--border-subtle);color:var(--text3);font-family:var(--font-mono);cursor:pointer;border-radius:4px;padding:3px 9px;font-size:10px;transition:color .15s,border-color .15s,background .15s}.crop-ratio-pill:hover{color:var(--text);border-color:var(--border)}.crop-ratio-pill.active{background:var(--accent-muted);border-color:var(--accent);color:var(--accent)}.crop-modal-title{font-family:var(--font-mono);color:var(--text);font-size:13px;font-weight:700}.crop-modal-close{color:var(--text3);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:14px;transition:color .15s,background .15s}.crop-modal-close:hover{color:var(--text);background:var(--surface2)}.crop-modal-body{flex:1;gap:16px;min-height:0;padding:16px;display:flex;overflow:hidden}.crop-pane{flex-direction:column;flex:1;gap:8px;min-width:0;display:flex}.crop-pane-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--text3);font-size:10px}.crop-image-wrap{border:1px solid var(--border-subtle);background:#000;border-radius:6px;flex:1;min-height:200px;position:relative;overflow:hidden}.crop-source-img{object-fit:contain;pointer-events:none;width:100%;height:100%;display:block}.crop-shade{pointer-events:none;background:#0000008c;position:absolute}.crop-shade-t{width:100%;top:0;left:0}.crop-shade-b{width:100%;left:0}.crop-rect{border:2px solid var(--accent);cursor:move;position:absolute;box-shadow:0 0 0 1px #0006}.crop-handle{background:var(--accent);border:2px solid #fff;border-radius:2px;width:14px;height:14px;position:absolute}.crop-handle-nw{cursor:nw-resize;top:-7px;left:-7px}.crop-handle-ne{cursor:ne-resize;top:-7px;right:-7px}.crop-handle-sw{cursor:sw-resize;bottom:-7px;left:-7px}.crop-handle-se{cursor:se-resize;bottom:-7px;right:-7px}.crop-dimensions{font-family:var(--font-mono);color:var(--text3);text-align:center;height:16px;font-size:10px}.crop-preview-wrap{border:1px solid var(--border-subtle);background:#000;border-radius:6px;flex:1;justify-content:center;align-items:center;min-height:200px;display:flex;overflow:hidden}.crop-preview-img{object-fit:contain;max-width:100%;max-height:100%}.crop-preview-empty{font-family:var(--font-mono);color:var(--text3);font-size:11px}.crop-modal-footer{border-top:1px solid var(--border-subtle);flex-shrink:0;gap:8px;padding:12px 16px;display:flex}.crop-apply-btn{background:var(--accent);color:#000;font-family:var(--font-mono);cursor:pointer;border:none;border-radius:6px;padding:7px 16px;font-size:12px;font-weight:700;transition:opacity .15s}.crop-apply-btn:hover:not(:disabled){opacity:.85}.crop-apply-btn:disabled{opacity:var(--disabled-opacity);cursor:not-allowed}.crop-download-btn{background:var(--bg3);color:var(--text);border:1px solid var(--border);font-family:var(--font-mono);cursor:pointer;border-radius:6px;padding:7px 16px;font-size:12px;transition:opacity .15s}.crop-download-btn:hover{opacity:.8}@media (max-width:600px){.crop-modal-body{flex-direction:column}}.ve-panel{background:var(--bg);flex-direction:column;height:100%;display:flex;overflow:hidden}.ve-header{border-bottom:1px solid var(--border);font-family:var(--font-mono);color:var(--text);flex-shrink:0;justify-content:space-between;align-items:center;padding:10px 16px;font-size:12px;font-weight:700;display:flex}.ve-header-actions{align-items:center;gap:8px;display:flex}.ve-btn{font-family:var(--font-mono);border:1px solid var(--border);background:var(--bg2);color:var(--text);cursor:pointer;border-radius:5px;align-items:center;padding:5px 12px;font-size:11px;font-weight:700;text-decoration:none;transition:opacity .15s;display:inline-flex}.ve-btn:hover:not(:disabled){opacity:.8}.ve-btn:disabled{opacity:var(--disabled-opacity);cursor:not-allowed}.ve-btn-sm{padding:3px 9px;font-size:10px}.ve-btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.ve-btn-success{color:#fff;background:#16a34a;border-color:#16a34a}.ve-upload{border:2px dashed var(--border);cursor:pointer;border-radius:10px;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:10px;margin:24px;transition:border-color .15s,background .15s;display:flex}.ve-upload:hover{border-color:var(--accent);background:color-mix(in srgb,var(--accent)5%,transparent)}.ve-upload-icon{color:var(--text2);font-size:36px;line-height:1}.ve-upload-title{font-family:var(--font-mono);color:var(--text);font-size:14px;font-weight:700}.ve-upload-sub{font-family:var(--font-mono);color:var(--text3);font-size:11px}.ve-upload-shortcuts{font-family:var(--font-mono);color:var(--text3);opacity:.7;margin-top:8px;font-size:10px}.ve-workspace{flex:1;gap:0;min-height:0;display:flex;overflow:hidden}.ve-player-wrap{background:#000;flex:1;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.ve-video{max-width:100%;max-height:100%;display:block}.ve-canvas-overlay{pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0}.ve-side{border-left:1px solid var(--border);background:var(--bg2);flex-direction:column;flex-shrink:0;width:220px;display:flex;overflow:hidden}.ve-side-title{font-family:var(--font-mono);color:var(--text2);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:8px 12px;font-size:11px;font-weight:700;display:flex}.ve-overlay-list{flex:1;padding:4px 0;overflow-y:auto}.ve-overlay-empty{font-family:var(--font-mono);color:var(--text3);text-align:center;padding:16px 12px;font-size:11px}.ve-overlay-item{cursor:pointer;border-bottom:1px solid var(--border);align-items:center;gap:6px;padding:6px 10px;transition:background .1s;display:flex}.ve-overlay-item:hover{background:var(--bg3)}.ve-overlay-item.selected{background:color-mix(in srgb,var(--accent)12%,var(--bg2))}.ve-overlay-swatch{border:1px solid #ffffff26;border-radius:2px;flex-shrink:0;width:10px;height:10px}.ve-overlay-text{font-family:var(--font-mono);color:var(--text);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:11px;overflow:hidden}.ve-overlay-time{font-family:var(--font-mono);color:var(--text3);white-space:nowrap;font-size:10px}.ve-overlay-del{color:var(--text3);cursor:pointer;background:0 0;border:none;border-radius:3px;flex-shrink:0;padding:2px 4px;font-size:10px;line-height:1}.ve-overlay-del:hover{color:#ef4444;background:#ef44441a}.ve-delete-overlay-btn{border:1px solid color-mix(in srgb,#ef4444 50%,var(--border));color:#ef4444;width:100%;font-family:var(--font-mono);cursor:pointer;background:0 0;border-radius:4px;margin-top:6px;padding:5px 0;font-size:10px;transition:background .1s}.ve-delete-overlay-btn:hover{background:#ef44441a}.ve-overlay-editor{border-top:1px solid var(--border);flex-direction:column;gap:6px;padding:10px;display:flex;overflow-y:auto}.ve-label{font-family:var(--font-mono);color:var(--text3);text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px;font-size:10px;display:block}.ve-input{box-sizing:border-box;background:var(--bg);border:1px solid var(--border);width:100%;color:var(--text);font-family:var(--font-mono);border-radius:4px;outline:none;padding:4px 7px;font-size:11px}.ve-input:focus{border-color:var(--accent)}.ve-input-sm{width:100%}.ve-row{gap:8px;display:flex}.ve-field{flex:1}.ve-color{border:1px solid var(--border);background:var(--bg);cursor:pointer;border-radius:4px;width:100%;height:28px;padding:2px}.ve-controls{border-top:1px solid var(--border);background:var(--bg2);flex-direction:column;flex-shrink:0;gap:0;display:flex}.ve-controls-row{align-items:center;gap:6px;padding:5px 12px;display:flex}.ve-controls-row+.ve-controls-row{border-top:1px solid var(--border)}.ve-controls-row2{padding-top:4px;padding-bottom:5px}.ve-controls-label{font-family:var(--font-mono);color:var(--text3);text-transform:uppercase;letter-spacing:.04em;flex-shrink:0;font-size:10px}.ve-play-btn{border:1px solid var(--border);color:var(--text);cursor:pointer;background:0 0;border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;min-width:26px;height:26px;padding:0 5px;font-size:12px;transition:background .1s;display:flex}.ve-play-btn:hover{background:var(--bg3)}.ve-play-main{border-color:var(--accent);min-width:32px;color:var(--accent);font-size:14px}.ve-play-main:hover{background:color-mix(in srgb,var(--accent)12%,transparent)}.ve-time{font-family:var(--font-mono);color:var(--text2);white-space:nowrap;font-size:11px}.ve-trim-label{font-family:var(--font-mono);color:var(--text3);white-space:nowrap;font-size:11px}.ve-trim-dur{color:var(--accent);font-size:10px}.ve-speed-group{gap:2px;display:flex}.ve-speed-btn{font-family:var(--font-mono);border:1px solid var(--border);background:var(--bg);color:var(--text2);cursor:pointer;white-space:nowrap;border-radius:4px;padding:3px 6px;font-size:10px;font-weight:700;transition:background .1s,color .1s}.ve-speed-btn:hover{background:var(--bg3);color:var(--text)}.ve-speed-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.ve-icon-btn{border:1px solid var(--border);color:var(--text2);font-family:var(--font-mono);cursor:pointer;white-space:nowrap;background:0 0;border-radius:4px;align-items:center;gap:3px;padding:3px 7px;font-size:10px;transition:background .1s,color .1s;display:flex}.ve-icon-btn:hover{background:var(--bg3)}.ve-icon-btn.active{color:var(--accent);border-color:var(--accent);background:color-mix(in srgb,var(--accent)10%,transparent)}.ve-volume-slider{width:80px;height:3px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}.ve-timeline-wrap{background:var(--bg2);border-top:1px solid var(--border);flex-shrink:0;padding:6px 14px 2px}.ve-timeline{cursor:crosshair;-webkit-user-select:none;user-select:none;border-radius:5px;height:52px;position:relative;overflow:hidden}.ve-thumbs{width:100%;height:100%;display:flex}.ve-thumb{object-fit:cover;pointer-events:none;flex:1;height:100%;display:block}.ve-thumbs-loading{width:100%;height:100%;font-family:var(--font-mono);color:var(--text3);background:var(--bg3);justify-content:center;align-items:center;font-size:10px;display:flex}.ve-trim-shade{pointer-events:none;background:#0000008c;height:100%;position:absolute;top:0}.ve-trim-shade-l{left:0}.ve-trim-shade-r{right:0}.ve-handle{background:var(--accent);cursor:ew-resize;z-index:3;border-radius:2px;width:6px;height:100%;position:absolute;top:0;transform:translate(-50%)}.ve-handle:after{content:"";background:#fff9;border-radius:1px;width:2px;height:18px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.ve-playhead{cursor:ew-resize;z-index:4;pointer-events:all;background:#fff;width:2px;height:100%;position:absolute;top:0;transform:translate(-50%)}.ve-playhead:before{content:"";background:#fff;border-radius:50%;width:8px;height:8px;position:absolute;top:-4px;left:50%;transform:translate(-50%)}.ve-trim-bracket{border-top:2px solid var(--accent);border-bottom:2px solid var(--accent);pointer-events:none;z-index:1;box-sizing:border-box;height:100%;position:absolute;top:0}.ve-ruler{height:16px;margin-top:2px;position:relative}.ve-ruler-mark{font-family:var(--font-mono);color:var(--text3);white-space:nowrap;pointer-events:none;font-size:9px;position:absolute;transform:translate(-50%)}.ve-overlay-marker{background:color-mix(in srgb,var(--accent)60%,transparent);cursor:pointer;z-index:2;border-radius:2px;height:6px;transition:background .1s;position:absolute;bottom:0}.ve-overlay-marker.active{background:var(--accent);height:8px}.ve-ai-bar{border-top:1px solid var(--border);background:var(--bg);flex-shrink:0;align-items:center;gap:8px;padding:8px 14px;display:flex}.ve-ai-icon{color:var(--accent);flex-shrink:0;font-size:14px}.ve-ai-message{color:var(--accent);background:#6af7c80f;border-top:1px solid #6af7c81f;flex-shrink:0;padding:6px 14px;font-size:11px}.ve-ai-input{background:var(--bg2);border:1px solid var(--border);color:var(--text);font-family:var(--font-mono);border-radius:5px;outline:none;flex:1;padding:6px 10px;font-size:11px}.ve-ai-input:focus{border-color:var(--accent)}.ve-ai-input::placeholder{color:var(--text3)}@media (max-width:600px){.ve-side,.ve-trim-label{display:none}.ve-upload{margin:16px}}.studio-panel{background:var(--bg);height:100%;font-family:var(--font-mono);flex-direction:column;display:flex;overflow:hidden}.studio-header{border-bottom:1px solid var(--border);background:var(--bg2);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:12px;padding:8px 14px;display:flex}.studio-logo{color:var(--text);font-size:12px;font-weight:700}.studio-transport{align-items:center;gap:6px;display:flex}.studio-transport-btn{background:var(--bg3);border:1px solid var(--border);color:var(--text);font-family:var(--font-mono);cursor:pointer;border-radius:5px;padding:4px 11px;font-size:11px;font-weight:700;transition:background .1s}.studio-transport-btn:hover{background:var(--bg)}.studio-transport-btn.recording{color:#ef4444;border-color:#ef4444;animation:1s infinite studio-rec-blink}@keyframes studio-rec-blink{0%,to{opacity:1}50%{opacity:.4}}.studio-mic-meter{background:var(--bg3);border-radius:3px;width:60px;height:6px;overflow:hidden}.studio-mic-level{background:#22c55e;border-radius:3px;height:100%;transition:width 50ms}.studio-bpm-row{align-items:center;gap:6px;display:flex}.studio-bpm-label{color:var(--text3);text-transform:uppercase;letter-spacing:.04em;font-size:10px}.studio-bpm-input{background:var(--bg);border:1px solid var(--border);width:48px;color:var(--text);font-family:var(--font-mono);text-align:center;border-radius:4px;outline:none;padding:3px 5px;font-size:12px;font-weight:700}.studio-bpm-input:focus{border-color:var(--accent)}.studio-bpm-slider{width:70px;accent-color:var(--accent);cursor:pointer}.studio-header-actions{align-items:center;gap:6px;margin-left:auto;display:flex}.studio-status{color:var(--text3);font-size:10px;font-style:italic}.studio-btn{font-family:var(--font-mono);border:1px solid var(--border);background:var(--bg2);color:var(--text);cursor:pointer;white-space:nowrap;border-radius:5px;align-items:center;gap:4px;padding:5px 11px;font-size:11px;font-weight:700;text-decoration:none;transition:opacity .15s;display:inline-flex}.studio-btn:hover:not(:disabled){opacity:.8}.studio-btn:disabled{opacity:var(--disabled-opacity);cursor:not-allowed}.studio-btn-sm{padding:3px 8px;font-size:10px}.studio-btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.studio-btn-success{color:#fff;background:#16a34a;border-color:#16a34a}.studio-body{flex:1;min-height:0;display:flex;overflow:hidden}.studio-tracks{border-right:1px solid var(--border);background:var(--bg2);flex-direction:column;flex-shrink:0;width:240px;display:flex;overflow:hidden}.studio-tracks-header{border-bottom:1px solid var(--border);color:var(--text2);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:4px;padding:7px 10px;font-size:10px;font-weight:700;display:flex}.studio-tracks-header>span{flex:1}.studio-tracks-empty{color:var(--text3);text-align:center;padding:20px 14px;font-size:11px;line-height:1.6}.studio-track{border-bottom:1px solid var(--border);cursor:pointer;padding:8px 10px;transition:background .1s;overflow:hidden}.studio-track:hover{background:var(--bg3)}.studio-track.selected{background:color-mix(in srgb,var(--accent)8%,var(--bg2))}.studio-track-top{align-items:center;gap:4px;margin-bottom:5px;display:flex}.studio-track-name{color:var(--text);font-family:var(--font-mono);background:0 0;border:none;outline:none;flex:1;min-width:0;padding:0;font-size:11px;font-weight:700}.studio-track-del{color:var(--text3);cursor:pointer;background:0 0;border:none;border-radius:3px;flex-shrink:0;padding:2px 3px;font-size:10px}.studio-track-del:hover{color:#ef4444}.studio-track-controls{align-items:center;gap:4px;margin-bottom:4px;display:flex}.studio-track-btn{font-family:var(--font-mono);border:1px solid var(--border);background:var(--bg);color:var(--text2);cursor:pointer;border-radius:3px;flex-shrink:0;padding:2px 6px;font-size:9px;font-weight:700;transition:background .1s,color .1s}.studio-track-btn:hover{background:var(--bg3)}.studio-track-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.studio-track-vol,.studio-track-pan{height:3px;accent-color:var(--accent);cursor:pointer;flex:1;min-width:0}.studio-instrument-sel{background:var(--bg);border:1px solid var(--border);width:100%;color:var(--text);font-family:var(--font-mono);cursor:pointer;border-radius:4px;outline:none;margin-top:4px;padding:3px 5px;font-size:10px}.studio-track-audio{border-radius:4px;width:100%;height:28px;margin-top:4px}.studio-editor{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.studio-tabs{border-bottom:1px solid var(--border);background:var(--bg2);flex-shrink:0;display:flex}.studio-tab{font-family:var(--font-mono);color:var(--text2);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;padding:8px 14px;font-size:11px;font-weight:700;transition:color .1s}.studio-tab:hover{color:var(--text)}.studio-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.studio-ai-gen{flex-direction:column;flex:1;gap:12px;padding:14px;display:flex;overflow-y:auto}.studio-ai-gen-prompt{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);width:100%;color:var(--text);font-family:var(--font-mono);resize:none;padding:10px 12px;font-size:12px;transition:border-color .15s}.studio-ai-gen-prompt:focus{border-color:var(--accent);outline:none}.studio-ai-gen-genres{flex-wrap:wrap;gap:6px;display:flex}.studio-genre-chip{font-family:var(--font-mono);border:1px solid var(--border);color:var(--text2);cursor:pointer;background:0 0;border-radius:20px;padding:4px 10px;font-size:10px;font-weight:600;transition:all .15s}.studio-genre-chip:hover{border-color:var(--accent);color:var(--accent)}.studio-genre-chip.active{background:var(--accent);border-color:var(--accent);color:#fff}.studio-ai-gen-controls{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.studio-ai-gen-dur-label{font-family:var(--font-mono);color:var(--text2);margin-right:2px;font-size:11px}.studio-dur-btn{font-family:var(--font-mono);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text2);cursor:pointer;background:0 0;padding:5px 10px;font-size:11px;font-weight:600;transition:all .15s}.studio-dur-btn:hover{border-color:var(--accent);color:var(--accent)}.studio-dur-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.studio-ai-gen-error{font-family:var(--font-mono);color:var(--error,#f87171);border-radius:var(--r-sm);background:#f8717114;border:1px solid #f8717133;padding:6px 10px;font-size:11px}.studio-ai-gen-tracks{flex-direction:column;gap:10px;display:flex}.studio-ai-gen-empty{font-family:var(--font-mono);color:var(--text3,var(--text2));opacity:.5;text-align:center;padding:24px 0;font-size:11px}.studio-ai-gen-locked{text-align:center;height:100%;min-height:200px;color:var(--text2);font-family:var(--font-mono);flex-direction:column;justify-content:center;align-items:center;gap:10px;font-size:12px;display:flex}.studio-ai-gen-lock-icon{opacity:.3;font-size:28px}.studio-ai-gen-lock-sub{opacity:.6;font-size:11px}.studio-piano-wrap{flex-direction:column;flex:1;padding:12px;display:flex;overflow:hidden}.studio-piano-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:6px;margin-bottom:10px;display:flex}.studio-piano-hint{color:var(--text3);font-size:10px}.studio-octave-group{align-items:center;gap:6px;display:flex}.studio-octave-label{color:var(--text2);text-align:center;width:40px;font-size:11px}.studio-piano{flex:1;align-items:flex-start;gap:2px;display:flex}.piano-octave{flex:1;height:140px;display:flex;position:relative}.piano-white{cursor:pointer;z-index:1;background:#f0ece0;border:1px solid #aaa;border-radius:0 0 4px 4px;flex:1;min-width:0;height:100%;transition:background 50ms;position:relative}.piano-white:hover{background:#e8e4d8}.piano-white.lit{background:color-mix(in srgb,var(--accent)60%,#f0ece0)}.piano-black{cursor:pointer;z-index:2;background:#1a1a1a;border:1px solid #000;border-radius:0 0 3px 3px;width:12%;height:58%;transition:background 50ms;position:absolute;top:0}.piano-black:hover{background:#333}.piano-black.lit{background:var(--accent)}.piano-black-pos-0{left:9.28571%}.piano-black-pos-1{left:23.5714%}.piano-black-pos-3{left:52.1429%}.piano-black-pos-4{left:66.4286%}.piano-black-pos-5{left:80.7143%}.studio-piano-inst-row{align-items:center;gap:8px;margin-top:10px;display:flex}.studio-piano-inst-label{color:var(--text3);flex-shrink:0;font-size:10px}.studio-drums{flex-direction:column;flex:1;gap:12px;padding:10px;display:flex;overflow-y:auto}.studio-drums-empty{color:var(--text3);text-align:center;flex-direction:column;align-items:center;gap:8px;padding:24px;font-size:11px;display:flex}.studio-drum-track{background:var(--bg2);border:1px solid var(--border);border-radius:6px;padding:10px}.studio-drum-track-label{text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;font-size:10px;font-weight:700}.studio-drum-row{align-items:center;gap:8px;margin-bottom:4px;display:flex}.studio-drum-label{width:46px;color:var(--text3);text-align:right;flex-shrink:0;font-size:9px}.studio-drum-steps{flex:1;gap:3px;display:flex}.studio-drum-step{border:1px solid var(--border);background:var(--bg3);cursor:pointer;border-radius:3px;flex:1;min-width:0;height:24px;transition:background .1s}.studio-drum-step.bar{border-color:color-mix(in srgb,var(--accent)30%,var(--border))}.studio-drum-step.on{background:var(--accent);border-color:var(--accent)}.studio-drum-step.beat{outline-offset:-2px;outline:2px solid #fff}.studio-drum-step:hover{background:color-mix(in srgb,var(--accent)30%,var(--bg3))}.studio-drum-step.on:hover{opacity:.8}.studio-effects{flex-direction:column;flex:1;gap:12px;padding:14px;display:flex;overflow-y:auto}.studio-fx-title{color:var(--text);border-bottom:2px solid var(--border);padding-bottom:8px;font-size:11px;font-weight:700}.studio-fx-row{align-items:center;gap:10px;display:flex}.studio-fx-label{width:68px;color:var(--text3);flex-shrink:0;font-size:10px}.studio-fx-slider{accent-color:var(--accent);cursor:pointer;flex:1}.studio-fx-value{width:52px;color:var(--text2);text-align:right;flex-shrink:0;font-size:10px}.studio-mixer{background:var(--bg);flex:1;align-items:flex-end;gap:2px;padding:12px;display:flex;overflow-x:auto}.studio-mixer-channel{border:1px solid var(--border);background:var(--bg2);cursor:pointer;border-radius:6px;flex-direction:column;align-items:center;gap:4px;min-width:56px;padding:8px 6px;transition:background .1s;display:flex}.studio-mixer-channel:hover{background:var(--bg3)}.studio-mixer-channel.selected{border-color:var(--accent)}.studio-mixer-vol-wrap{align-items:center;height:100px;display:flex}.studio-mixer-vol{writing-mode:vertical-lr;height:90px;accent-color:var(--accent);cursor:pointer;direction:rtl}.studio-mixer-fader-label{color:var(--text3);font-size:9px}.studio-mixer-channel-name{text-align:center;text-overflow:ellipsis;white-space:nowrap;max-width:44px;font-size:9px;font-weight:700;overflow:hidden}.studio-ai-bar{border-top:1px solid var(--border);background:var(--bg);flex-shrink:0;align-items:center;gap:8px;padding:8px 14px;display:flex}.studio-ai-icon{color:var(--accent);flex-shrink:0;font-size:14px}.studio-ai-input{background:var(--bg2);border:1px solid var(--border);color:var(--text);font-family:var(--font-mono);border-radius:5px;outline:none;flex:1;padding:6px 10px;font-size:11px}.studio-ai-input:focus{border-color:var(--accent)}.studio-ai-input::placeholder{color:var(--text3)}@media (max-width:600px){.studio-tracks{width:180px}.studio-drum-label,.studio-piano-hint{display:none}}.notes-root{background:var(--bg1);height:100%;color:var(--fg1);display:flex;overflow:hidden}.notes-sidebar{border-right:1px solid var(--border);background:var(--bg2);flex-direction:column;width:220px;min-width:220px;transition:width .2s,min-width .2s;display:flex;overflow:hidden}.notes-sidebar:not(.open){width:0;min-width:0}.notes-sidebar-top{border-bottom:1px solid var(--border);flex-direction:column;gap:6px;padding:10px;display:flex}.notes-new-btn{background:var(--accent);color:#000;cursor:pointer;letter-spacing:.02em;border:none;border-radius:6px;padding:7px 10px;font-size:13px;font-weight:700}.notes-new-btn:hover{filter:brightness(1.15)}.notes-search{background:var(--bg3);border:1px solid var(--border);color:var(--fg1);box-sizing:border-box;border-radius:6px;outline:none;width:100%;padding:6px 8px;font-size:12px}.notes-list{flex:1;padding:6px 0;overflow-y:auto}.notes-list-item{cursor:pointer;border-bottom:1px solid #0000;padding:9px 12px;transition:background .15s;position:relative}.notes-list-item:hover{background:var(--bg3)}.notes-list-item.active{background:var(--bg3);border-left:2px solid var(--accent)}.notes-list-title{white-space:nowrap;text-overflow:ellipsis;padding-right:22px;font-size:13px;font-weight:600;overflow:hidden}.notes-list-date{color:var(--fg3);margin-top:2px;font-size:10px}.notes-list-del{color:var(--fg3);cursor:pointer;opacity:0;background:0 0;border:none;padding:2px 4px;font-size:11px;transition:opacity .15s;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.notes-list-item:hover .notes-list-del{opacity:1}.notes-list-del:hover{color:var(--fg1)}.notes-empty{color:var(--fg3);text-align:center;padding:16px;font-size:12px}.notes-main{flex-direction:column;flex:1;display:flex;overflow:hidden}.notes-topbar{border-bottom:1px solid var(--border);background:var(--bg2);flex-wrap:wrap;align-items:center;gap:8px;min-height:44px;padding:8px 12px;display:flex}.notes-sidebar-toggle{border:1px solid var(--border);color:var(--fg2);cursor:pointer;background:0 0;border-radius:5px;flex-shrink:0;padding:4px 7px;font-size:14px}.notes-sidebar-toggle:hover{background:var(--bg3)}.notes-title-input{color:var(--fg1);background:0 0;border:none;outline:none;flex:1;min-width:80px;font-size:16px;font-weight:700}.notes-title-input::placeholder{color:var(--fg3)}.notes-save-status{color:var(--fg3);white-space:nowrap;font-size:11px}.notes-pick-hint{color:var(--fg3);font-size:13px}.notes-mode-btn{background:var(--bg3);border:1px solid var(--border);color:var(--fg2);cursor:pointer;white-space:nowrap;border-radius:6px;padding:5px 10px;font-size:12px}.notes-mode-btn.active{background:var(--accent);color:#000;border-color:var(--accent)}.notes-mode-btn:hover:not(.active){background:var(--bg3);filter:brightness(1.1)}.notes-export-wrap{position:relative}.notes-export-btn{background:var(--bg3);border:1px solid var(--border);color:var(--fg2);cursor:pointer;border-radius:6px;padding:5px 10px;font-size:12px}.notes-export-menu{background:var(--bg2);border:1px solid var(--border);z-index:100;border-radius:7px;min-width:120px;display:none;position:absolute;top:calc(100% + 4px);right:0;overflow:hidden}.notes-export-wrap:hover .notes-export-menu{flex-direction:column;display:flex}.notes-export-menu button{color:var(--fg1);cursor:pointer;text-align:left;background:0 0;border:none;padding:8px 12px;font-size:12px}.notes-export-menu button:hover{background:var(--bg3)}.notes-toolbar{border-bottom:1px solid var(--border);background:var(--bg2);flex-wrap:wrap;align-items:center;gap:3px;padding:5px 10px;display:flex;overflow-x:auto}.notes-toolbar-sep{background:var(--border);flex-shrink:0;width:1px;height:18px;margin:0 3px}.notes-tool-btn{color:var(--fg2);cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #0000;border-radius:4px;min-width:26px;padding:3px 7px;font-size:12px}.notes-tool-btn:hover{background:var(--bg3);border-color:var(--border)}.notes-tool-btn.on{background:var(--accent);color:#000;border-color:var(--accent)}.notes-select{background:var(--bg3);border:1px solid var(--border);color:var(--fg1);cursor:pointer;border-radius:4px;outline:none;max-width:120px;padding:3px 5px;font-size:12px}.notes-select-sm{max-width:54px}.notes-color-wrap{flex-shrink:0;align-items:center;gap:3px;display:flex}.notes-color-label{color:var(--fg2);font-size:12px;font-weight:700}.notes-color-row{gap:3px;display:flex}.notes-color-dot{cursor:pointer;border:2px solid #0000;border-radius:50%;flex-shrink:0;width:16px;height:16px;padding:0}.notes-color-dot:hover,.notes-color-dot.selected{border-color:var(--fg1)}.notes-draw-toolbar{gap:5px}.notes-draw-label{color:var(--fg3);white-space:nowrap;font-size:11px}.notes-draw-hint{color:var(--fg3);margin-left:auto;font-size:11px}.notes-editor-wrap{flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden}.notes-editor-scroll{flex:1;padding:0;overflow-y:auto}.notes-editor-inner{min-height:100%;color:var(--fg1);caret-color:var(--accent);outline:none;padding:24px 32px;font-family:inherit;font-size:15px;line-height:1.7}.notes-editor-inner:focus{outline:none}.notes-editor-inner p{margin:0 0 .5em}.notes-editor-inner h1{margin:.6em 0 .3em;font-size:2em;font-weight:800}.notes-editor-inner h2{margin:.6em 0 .3em;font-size:1.5em;font-weight:700}.notes-editor-inner h3{margin:.5em 0 .25em;font-size:1.2em;font-weight:600}.notes-editor-inner ul,.notes-editor-inner ol{margin:.3em 0;padding-left:1.4em}.notes-editor-inner li{margin:.15em 0}.notes-editor-inner blockquote{border-left:3px solid var(--accent);color:var(--fg2);margin:.5em 0;padding:.3em .8em;font-style:italic}.notes-editor-inner hr{border:none;border-top:1px solid var(--border);margin:1em 0}.notes-editor-inner a{color:var(--accent);text-decoration:underline}.notes-code-block,.notes-editor-inner pre{background:var(--bg3);border:1px solid var(--border);white-space:pre;color:#7dd3fc;border-radius:6px;margin:.6em 0;padding:12px 16px;font-family:JetBrains Mono,Fira Code,monospace;font-size:13px;line-height:1.6;overflow-x:auto}.notes-editor-inner code:not(pre code){background:var(--bg3);color:#7dd3fc;border-radius:3px;padding:1px 5px;font-family:JetBrains Mono,monospace;font-size:.88em}.notes-editor-inner table{border-collapse:collapse;width:100%;margin:.8em 0;font-size:13px}.notes-editor-inner th{background:var(--bg3);border:1px solid var(--border);text-align:left;color:var(--fg1);padding:7px 10px;font-weight:700}.notes-editor-inner td{border:1px solid var(--border);vertical-align:top;padding:6px 10px}.notes-editor-inner .selectedCell{background:color-mix(in srgb,var(--accent)12%,transparent)}.notes-canvas{pointer-events:none;touch-action:none;z-index:10;position:absolute;inset:0}.notes-canvas.active{pointer-events:all;cursor:crosshair}.notes-empty-state{color:var(--fg3);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;display:flex}.notes-empty-icon{color:var(--accent);opacity:.5;font-size:40px}.notes-empty-title{color:var(--fg1);font-size:22px;font-weight:800}.notes-empty-sub{text-align:center;max-width:300px;font-size:13px}.notes-empty-btn{background:var(--accent);color:#000;cursor:pointer;border:none;border-radius:8px;margin-top:8px;padding:10px 20px;font-size:14px;font-weight:700}.notes-empty-btn:hover{filter:brightness(1.15)}@media (max-width:640px){.notes-sidebar{z-index:20;width:100%;min-width:0;height:100%;position:absolute}.notes-sidebar:not(.open){display:none}.notes-editor-inner{padding:16px}.notes-toolbar{padding:4px 6px}}.threed-studio{background:var(--bg1);flex-direction:column;height:100%;display:flex;overflow:hidden}.threed-toolbar{background:var(--bg2);border-bottom:1px solid var(--border);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:10px;padding:8px 12px;display:flex}.threed-logo{color:var(--accent);white-space:nowrap;flex-shrink:0;font-size:12px;font-weight:700}.threed-prompt-row{flex-wrap:wrap;flex:1;align-items:center;gap:8px;min-width:0;display:flex}.threed-prompt-input{background:var(--bg3);border:1px solid var(--border);min-width:180px;color:var(--text);border-radius:6px;outline:none;flex:1;padding:6px 10px;font-size:12px;transition:border-color .15s}.threed-prompt-input:focus{border-color:var(--accent)}.threed-prompt-input:disabled{opacity:.5}.threed-prompt-input::placeholder{color:var(--text3)}.threed-btn{border:1px solid var(--border);background:var(--bg3);color:var(--text2);cursor:pointer;white-space:nowrap;border-radius:6px;flex-shrink:0;padding:6px 12px;font-size:11px;transition:all .15s}.threed-btn:hover:not(:disabled){border-color:var(--accent);color:var(--text)}.threed-btn:disabled{opacity:.4;cursor:not-allowed}.threed-btn-primary{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600}.threed-btn-primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover);color:#fff}.threed-status{color:var(--accent);width:100%;padding:2px 0;font-size:11px}.threed-status--error{color:#f87171}.threed-canvas-wrap{background:#0a0a10;flex:1;position:relative;overflow:hidden}.threed-canvas{width:100%;height:100%;display:block}.threed-controls-hint{color:#ffffff40;pointer-events:none;white-space:nowrap;letter-spacing:.04em;font-size:10px;position:absolute;bottom:10px;left:50%;transform:translate(-50%)}.threed-loading-overlay{z-index:10;background:#0a0a10bf;flex-direction:column;justify-content:center;align-items:center;gap:10px;display:flex;position:absolute;inset:0}.threed-loading-spinner{color:var(--accent);font-size:28px;animation:1.4s linear infinite threed-spin}@keyframes threed-spin{to{transform:rotate(360deg)}}.threed-loading-text{color:var(--text2);letter-spacing:.05em;font-size:12px}.cl-root{min-height:100vh;color:var(--text);font-family:var(--font-mono);background:#0d0d0d;padding:0 0 80px}.cl-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 32px;display:flex}.cl-logo{color:var(--accent);letter-spacing:-.5px;font-size:20px;font-weight:700;text-decoration:none}.cl-header-nav{align-items:center;gap:20px;display:flex}.cl-nav-link{font-size:var(--fs-sm);color:var(--text3);text-decoration:none;transition:color .15s}.cl-nav-link:hover{color:var(--text)}.cl-hero{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:64px 24px 48px;display:flex}.cl-hero-badge{letter-spacing:.12em;text-transform:uppercase;color:var(--accent);background:color-mix(in srgb,var(--accent)12%,transparent);border:1px solid color-mix(in srgb,var(--accent)30%,transparent);border-radius:20px;padding:4px 12px;font-size:11px;font-weight:700}.cl-headline{letter-spacing:-1px;font-size:clamp(28px,5vw,48px);font-weight:800;line-height:1.1;font-family:var(--font-display);margin:0}.cl-subheadline{font-size:var(--fs-sm);color:var(--text3);max-width:420px;margin:0;line-height:1.65}.cl-feed{flex-direction:column;gap:32px;max-width:720px;margin:0 auto;padding:0 24px;display:flex}.cl-entry{border:1px solid var(--border);border-radius:var(--r-lg);background:var(--bg2);padding:28px 32px}.cl-entry-meta{border-bottom:1px solid var(--border-subtle);flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;padding-bottom:14px;display:flex}.cl-entry-date{font-size:var(--fs-xs);font-family:var(--font-mono);color:var(--text3);letter-spacing:.06em}.cl-entry-label{letter-spacing:.1em;text-transform:uppercase;color:var(--accent);background:color-mix(in srgb,var(--accent)10%,transparent);border:1px solid color-mix(in srgb,var(--accent)25%,transparent);border-radius:var(--r-full);padding:2px 8px;font-size:10px;font-weight:700}.cl-entry-title{font-size:var(--fs-xl);color:var(--text);font-weight:700;font-family:var(--font-display);margin:0 0 20px;line-height:1.3}.cl-section{margin-bottom:18px}.cl-section:last-child{margin-bottom:0}.cl-section-label{letter-spacing:.12em;text-transform:uppercase;margin-bottom:10px;font-size:10px;font-weight:700}.cl-section-label--added{color:var(--accent3)}.cl-section-label--fixed{color:#f0a060}.cl-section-label--internal{color:var(--text3)}.cl-items{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.cl-item{font-size:var(--fs-sm);color:var(--text2);align-items:flex-start;gap:10px;line-height:1.6;display:flex}.cl-item-dot{color:var(--accent);opacity:.7;flex-shrink:0;margin-top:4px;font-size:9px}.cl-item-dot--fixed{color:#f0a060}.cl-item-dot--internal{color:var(--text3)}.cl-item strong{color:var(--text);font-weight:600}.cl-footer{font-size:var(--fs-xs);color:var(--text3);flex-wrap:wrap;justify-content:center;align-items:center;gap:12px;padding:40px 24px 0;display:flex}.cl-footer-link{color:var(--accent);text-decoration:none;transition:opacity .15s}.cl-footer-link:hover{opacity:.75}.cl-footer-sep{color:var(--border)}