@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&family=Outfit:wght@300;400;500;600;700;800;900&family=JetBrains+Mono:ital,wght@0,300;0,400;0,500;0,600;1,400&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root,[data-theme=dark]{--bg-void: #03040a;--bg-deep: #060810;--bg-dark: #080c16;--bg-mid: #0c1020;--bg-surface: #101828;--bg-raised: #141e2e;--bg-hover: #1a2438;--glass-0: rgba(255,255,255,.012);--glass-1: rgba(255,255,255,.028);--glass-2: rgba(255,255,255,.052);--glass-3: rgba(255,255,255,.082);--glass-4: rgba(255,255,255,.11);--glass-border: rgba(255,255,255,.065);--glass-border-bright: rgba(255,255,255,.13);--neon-cyan: #38bdf8;--neon-cyan-dim: rgba(56,189,248,.12);--neon-cyan-glow: 0 0 24px rgba(56,189,248,.4), 0 0 60px rgba(56,189,248,.15);--neon-blue: #60a5fa;--neon-indigo: #818cf8;--neon-purple: #a78bfa;--neon-purple-dim: rgba(167,139,250,.13);--neon-purple-glow: 0 0 24px rgba(167,139,250,.4);--neon-violet: #c084fc;--neon-green: #34d399;--neon-green-dim: rgba(52,211,153,.13);--neon-orange: #fb923c;--neon-orange-dim: rgba(251,146,60,.13);--neon-red: #f87171;--neon-pink: #f472b6;--text-primary: rgba(240,246,255,.93);--text-secondary: rgba(180,200,235,.58);--text-tertiary: rgba(140,165,210,.34);--text-accent: var(--neon-cyan);--topbar-bg: rgba(4,6,14,.92);--sidebar-bg: rgba(5,7,16,.9);--ai-bg: rgba(5,7,16,.9);--tab-bar-bg: rgba(4,6,14,.88);--island-bg: rgba(6,9,20,.97);--island-border: rgba(56,189,248,.18);--island-shadow: 0 -1px 0 rgba(56,189,248,.12), 0 -16px 50px rgba(0,0,0,.8), 0 0 80px rgba(56,189,248,.04);--panel-shadow: 0 0 0 1px rgba(56,189,248,.06), 0 32px 80px rgba(0,0,0,.75), inset 0 1px 0 rgba(255,255,255,.04);--card-glow: 0 0 0 1px rgba(56,189,248,.08), 0 16px 40px rgba(0,0,0,.6), 0 0 80px rgba(56,189,248,.04)}[data-theme=light]{--bg-void: #eef2f9;--bg-deep: #e6ecf7;--bg-dark: #dde5f5;--bg-mid: #f8faff;--bg-surface: #ffffff;--bg-raised: #f4f6fd;--bg-hover: #ebf0fc;--glass-0: rgba(0,0,0,.01);--glass-1: rgba(0,0,0,.025);--glass-2: rgba(0,0,0,.045);--glass-3: rgba(0,0,0,.07);--glass-4: rgba(0,0,0,.1);--glass-border: rgba(0,0,0,.09);--glass-border-bright: rgba(0,0,0,.17);--neon-cyan: #0284c7;--neon-cyan-dim: rgba(2,132,199,.1);--neon-cyan-glow: 0 0 12px rgba(2,132,199,.2);--neon-blue: #2563eb;--neon-indigo: #4f46e5;--neon-purple: #7c3aed;--neon-purple-dim: rgba(124,58,237,.1);--neon-purple-glow: 0 0 12px rgba(124,58,237,.2);--neon-violet: #9333ea;--neon-green: #16a34a;--neon-green-dim: rgba(22,163,74,.1);--neon-orange: #d97706;--neon-orange-dim: rgba(217,119,6,.1);--neon-red: #dc2626;--neon-pink: #db2777;--text-primary: rgba(10,15,30,.88);--text-secondary: rgba(30,50,90,.55);--text-tertiary: rgba(30,50,90,.36);--text-accent: var(--neon-cyan);--topbar-bg: rgba(255,255,255,.94);--sidebar-bg: rgba(248,250,255,.96);--ai-bg: rgba(248,250,255,.96);--tab-bar-bg: rgba(238,242,249,.94);--island-bg: rgba(255,255,255,.97);--island-border: rgba(0,0,0,.12);--island-shadow: 0 -2px 24px rgba(0,0,0,.1);--panel-shadow: 0 0 0 1px rgba(0,0,0,.06), 0 16px 40px rgba(0,0,0,.1);--card-glow: 0 0 0 1px rgba(0,0,0,.07), 0 8px 24px rgba(0,0,0,.1)}:root{--font-code: "JetBrains Mono", "Fira Code", monospace;--font-ui: "Space Grotesk", system-ui, sans-serif;--font-display: "Outfit", "Space Grotesk", sans-serif;--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1);--transition-fast: .11s var(--ease-in-out);--transition-base: .2s var(--ease-out);--transition-slow: .34s var(--ease-out);--transition-spring: .42s var(--ease-spring);--sidebar-width: 248px;--ai-panel-width: 348px;--topbar-height: 50px;--tab-height: 40px;--island-height: 76px;--blur-xs: blur(4px);--blur-sm: blur(10px);--blur-md: blur(20px);--blur-lg: blur(32px);--blur-xl: blur(48px);--blur-2xl: blur(72px);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-2xl: 28px}html,body{height:100%;overflow:hidden;background:var(--bg-void);color:var(--text-primary);font-family:var(--font-ui);font-size:13px;font-weight:400;letter-spacing:-.01em;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;transition:background .4s,color .3s}#root{height:100%;display:flex;flex-direction:column}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#648cdc33;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#648cdc66}::selection{background:#38bdf82e;color:var(--text-primary)}.app-layout{display:flex;flex-direction:column;height:100vh;height:100dvh;background:var(--bg-void);position:relative;overflow:hidden;transition:background .4s}[data-theme=dark] .app-layout:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 80% 60% at 10% 95%,rgba(56,189,248,.065) 0%,transparent 55%),radial-gradient(ellipse 60% 70% at 90% 5%,rgba(99,102,241,.055) 0%,transparent 55%),radial-gradient(ellipse 50% 55% at 50% 50%,rgba(167,139,250,.035) 0%,transparent 60%),radial-gradient(ellipse 40% 45% at 25% 30%,rgba(52,211,153,.03) 0%,transparent 50%);pointer-events:none;z-index:0;animation:auroraDrift 18s ease-in-out infinite alternate}[data-theme=dark] .app-layout:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(56,189,248,.014) 1px,transparent 1px),linear-gradient(90deg,rgba(56,189,248,.014) 1px,transparent 1px);background-size:52px 52px;pointer-events:none;z-index:0;-webkit-mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 30%,transparent 80%);mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 30%,transparent 80%)}@keyframes auroraDrift{0%{opacity:.8;transform:scale(1) translateY(0)}33%{opacity:1;transform:scale(1.02) translateY(-8px)}66%{opacity:.9;transform:scale(.99) translateY(4px)}to{opacity:1;transform:scale(1.01) translateY(-4px)}}.topbar{height:var(--topbar-height);display:flex;align-items:center;padding:0 16px;gap:8px;background:var(--topbar-bg);backdrop-filter:blur(28px) saturate(180%) brightness(1.05);-webkit-backdrop-filter:blur(28px) saturate(180%) brightness(1.05);border-bottom:1px solid var(--glass-border);position:relative;z-index:100;flex-shrink:0;transition:background .3s}[data-theme=dark] .topbar:after{content:"";position:absolute;bottom:0;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,rgba(56,189,248,.28),rgba(167,139,250,.22),transparent);pointer-events:none;animation:shimmerLine 4s ease-in-out infinite}@keyframes shimmerLine{0%,to{opacity:.5;transform:scaleX(.85)}50%{opacity:1;transform:scaleX(1)}}.topbar-logo{font-family:var(--font-display);font-size:15px;font-weight:800;letter-spacing:.18em;background:linear-gradient(135deg,#38bdf8,#818cf8,#c084fc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;white-space:nowrap;background-size:200% 200%;animation:logoShimmer 5s ease infinite;filter:drop-shadow(0 0 14px rgba(56,189,248,.35))}@keyframes logoShimmer{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.topbar-logo span{background:none;-webkit-text-fill-color:var(--text-tertiary);font-size:10px;font-weight:400;letter-spacing:.1em;margin-left:7px;font-family:var(--font-code)}.topbar-divider{width:1px;height:22px;background:linear-gradient(180deg,transparent,var(--glass-border-bright),transparent);margin:0 4px}.topbar-actions{display:flex;align-items:center;gap:4px;margin-left:auto}.topbar-filename{font-family:var(--font-code);font-size:11.5px;color:var(--text-secondary);max-width:210px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar-file-actions{display:flex;align-items:center;gap:3px}.workspace{display:flex;flex:1;overflow:hidden;position:relative;z-index:1}.sidebar{width:var(--sidebar-width);display:flex;flex-direction:column;background:var(--sidebar-bg);backdrop-filter:blur(28px) saturate(160%);-webkit-backdrop-filter:blur(28px) saturate(160%);border-right:1px solid var(--glass-border);overflow:hidden;flex-shrink:0;transition:width var(--transition-slow),background .3s;position:relative}.sidebar.collapsed{width:0}[data-theme=dark] .sidebar:after{content:"";position:absolute;top:15%;right:0;width:1px;height:70%;background:linear-gradient(180deg,transparent,rgba(56,189,248,.22),rgba(167,139,250,.18),transparent);pointer-events:none;animation:edgeGlow 3s ease-in-out infinite alternate}@keyframes edgeGlow{0%{opacity:.4}to{opacity:1}}.sidebar-header{padding:12px 12px 8px;border-bottom:1px solid var(--glass-border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.sidebar-title{font-family:var(--font-display);font-size:9.5px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;background:linear-gradient(90deg,var(--neon-cyan),var(--neon-purple));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-actions{display:flex;gap:2px;align-items:center}.sidebar-actions .btn-icon{padding:4px;border-radius:var(--radius-sm);border-color:transparent;background:transparent;color:var(--text-tertiary);transition:all var(--transition-fast)}.sidebar-actions .btn-icon:hover{background:#38bdf81a;border-color:#38bdf833;color:var(--neon-cyan);transform:scale(1.1)}.file-tree{flex:1;overflow-y:auto;padding:6px}.file-item{display:flex;align-items:center;gap:6px;padding:5px 9px;cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast);white-space:nowrap;overflow:hidden;position:relative;margin-bottom:1px}.file-item:hover{background:#38bdf812;transform:translate(2px)}.file-item.active{background:#38bdf81a;box-shadow:inset 0 0 0 1px #38bdf833}.file-item.active:before{content:"";position:absolute;left:0;top:18%;bottom:18%;width:2.5px;border-radius:2px;background:linear-gradient(180deg,var(--neon-cyan),var(--neon-purple));box-shadow:0 0 10px #38bdf8b3;animation:activeFilePulse 2s ease-in-out infinite}@keyframes activeFilePulse{0%,to{box-shadow:0 0 6px #38bdf880}50%{box-shadow:0 0 14px #38bdf8e6}}.file-item-name{font-family:var(--font-code);font-size:11.5px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;transition:color var(--transition-fast)}.file-item.active .file-item-name{color:var(--neon-cyan)}.file-item:hover .file-item-name{color:var(--text-primary)}.folder-item{display:flex;align-items:center;gap:6px;padding:5px 9px;cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast);margin-bottom:1px}.folder-item:hover{background:#38bdf80f;transform:translate(2px)}.folder-name{font-family:var(--font-code);font-size:11.5px;font-weight:600;color:#c8d7f0a6;transition:color var(--transition-fast)}.folder-item:hover .folder-name{color:var(--text-primary)}.file-tree-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:36px 16px;gap:12px;opacity:.6}.file-tree-empty-icon{width:42px;height:42px;border-radius:12px;background:#38bdf812;border:1px solid rgba(56,189,248,.14);display:flex;align-items:center;justify-content:center;color:var(--neon-cyan)}.file-tree-empty p{font-size:10.5px;color:var(--text-tertiary);text-align:center;line-height:1.6}.editor-area{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0;width:0}.tab-bar{height:var(--tab-height);display:flex;align-items:flex-end;background:var(--tab-bar-bg);border-bottom:1px solid var(--glass-border);overflow-x:auto;overflow-y:hidden;flex-shrink:0;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);position:relative}.tab-bar::-webkit-scrollbar{height:2px}.tab-bar::-webkit-scrollbar-thumb{background:#38bdf833}[data-theme=dark] .tab-bar:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(56,189,248,.12) 25%,rgba(99,102,241,.15) 50%,rgba(167,139,250,.12) 75%,transparent 100%);pointer-events:none}.tab{height:36px;display:flex;align-items:center;gap:7px;padding:0 16px;cursor:pointer;border-top:1px solid transparent;border-left:1px solid transparent;border-right:1px solid transparent;white-space:nowrap;transition:all var(--transition-fast);position:relative;flex-shrink:0;background:transparent;font-family:var(--font-code);font-size:11.5px;color:var(--text-tertiary);border-radius:var(--radius-sm) var(--radius-sm) 0 0}.tab:hover{color:var(--text-secondary);background:#38bdf80d}.tab.active{color:#e1f0ffeb;background:#0e1424f2;border-color:#38bdf824;border-bottom-color:#0e1424f2}.tab.active:after{content:"";position:absolute;top:0;left:0;right:0;height:1.5px;background:linear-gradient(90deg,var(--neon-cyan),var(--neon-purple));box-shadow:0 0 12px #38bdf880,0 0 24px #38bdf833;border-radius:2px 2px 0 0}.tab-close{width:15px;height:15px;border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-fast),background var(--transition-fast),transform var(--transition-fast);background:none;border:none;cursor:pointer;color:var(--text-tertiary)}.tab:hover .tab-close,.tab.active .tab-close{opacity:1}.tab-close:hover{background:#f8717133;color:var(--neon-red);transform:scale(1.15) rotate(90deg)}.editor-container{flex:1;overflow:hidden;position:relative}.editor-container.ai-streaming:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border:1.5px solid rgba(56,189,248,.35);box-shadow:inset 0 0 40px #38bdf80a,0 0 40px #38bdf80f;pointer-events:none;z-index:10;animation:streamGlow 1.8s ease-in-out infinite alternate}@keyframes streamGlow{0%{opacity:.5;border-color:#38bdf840}to{opacity:1;border-color:#38bdf880}}.editor-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-tertiary);gap:14px}.editor-empty h2{font-family:var(--font-display);font-size:24px;font-weight:800;letter-spacing:.14em;background:linear-gradient(135deg,#38bdf859,#a78bfa4d);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.editor-empty p{font-size:12px;color:var(--text-tertiary);text-align:center;max-width:220px;line-height:1.6}.ai-panel{width:var(--ai-panel-width);display:flex;flex-direction:column;background:var(--ai-bg);backdrop-filter:blur(28px) saturate(160%);-webkit-backdrop-filter:blur(28px) saturate(160%);border-left:1px solid var(--glass-border);overflow:hidden;flex-shrink:0;transition:width var(--transition-slow),border-color var(--transition-slow),background .3s;position:relative}.ai-panel.collapsed{width:0;border-left-color:transparent}[data-theme=dark] .ai-panel:before{content:"";position:absolute;top:15%;left:0;width:1px;height:70%;background:linear-gradient(180deg,transparent,rgba(167,139,250,.22),rgba(56,189,248,.18),transparent);pointer-events:none;z-index:1;animation:edgeGlow 3.5s ease-in-out infinite alternate}.ai-panel-header{padding:12px 14px;border-bottom:1px solid var(--glass-border);display:flex;flex-direction:column;gap:12px;flex-shrink:0}.ai-panel-title{display:flex;align-items:center;justify-content:space-between}.ai-panel-title h3{font-family:var(--font-display);font-size:10.5px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;background:linear-gradient(90deg,var(--neon-cyan),var(--neon-purple));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 0 8px rgba(56,189,248,.3))}.model-selector{display:flex;flex-direction:column;gap:6px}.model-label{font-size:9.5px;color:var(--text-tertiary);letter-spacing:.1em;text-transform:uppercase;font-weight:600}.model-grid{display:grid;grid-template-columns:1fr 1fr;gap:5px}.model-btn{padding:7px 9px;border-radius:var(--radius-md);border:1px solid var(--glass-border);background:var(--glass-1);cursor:pointer;text-align:left;transition:all var(--transition-fast);font-family:var(--font-code);font-size:9.5px;color:var(--text-secondary);line-height:1.45;position:relative;overflow:hidden}.model-btn:hover{border-color:var(--glass-border-bright);color:var(--text-primary);transform:translateY(-1px);box-shadow:0 4px 16px #0000004d;background:var(--glass-2)}.model-btn.active{background:#38bdf81a!important;border-color:#38bdf859!important;color:var(--neon-cyan)!important;box-shadow:0 0 16px #38bdf826!important}.model-btn .model-provider{font-size:8.5px;opacity:.6;display:block;margin-bottom:2px}.token-bar{padding:7px 14px 9px;border-bottom:1px solid var(--glass-border);flex-shrink:0}.token-label{display:flex;justify-content:space-between;font-size:9.5px;color:var(--text-tertiary);margin-bottom:5px}.token-track{height:3px;background:var(--glass-2);border-radius:2px;overflow:hidden}.token-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,var(--neon-cyan),var(--neon-purple));transition:width var(--transition-slow);box-shadow:0 0 8px #38bdf866;position:relative;overflow:hidden}.token-fill:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.3) 50%,transparent 100%);animation:tokenShimmer 2.5s linear infinite}@keyframes tokenShimmer{0%{transform:translate(-100%)}to{transform:translate(200%)}}.chat-messages{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:12px}.message{display:flex;flex-direction:column;gap:5px;animation:msgSlideIn .28s var(--ease-out)}@keyframes msgSlideIn{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.message-role{font-size:9.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase}.message-role.user{color:var(--neon-cyan)}.message-role.assistant{color:var(--neon-purple)}.message-content{padding:10px 12px;border-radius:var(--radius-lg);font-family:var(--font-ui);font-size:12.5px;line-height:1.65;color:var(--text-primary);border:1px solid var(--glass-border);position:relative;overflow:hidden;transition:box-shadow var(--transition-base)}.message-content.user{background:#38bdf812;border-color:#38bdf82e;border-radius:var(--radius-lg) var(--radius-lg) var(--radius-sm) var(--radius-lg)}.message-content.assistant{background:#a78bfa0f;border-color:#a78bfa24;border-radius:var(--radius-sm) var(--radius-lg) var(--radius-lg) var(--radius-lg)}.message-content:hover{box-shadow:0 4px 20px #0003}.message-content pre{margin-top:8px;background:#00000073;padding:10px 12px;border-radius:var(--radius-md);overflow-x:auto;font-family:var(--font-code);font-size:11px;line-height:1.55;border:1px solid rgba(255,255,255,.07)}.message-content code{font-family:var(--font-code);background:#00000059;padding:1.5px 5px;border-radius:4px;font-size:11px;color:var(--neon-cyan)}.message-content pre code{background:none;padding:0;color:#a8ff78}.streaming-cursor{display:inline-block;width:8px;height:14px;background:var(--neon-cyan);margin-left:2px;animation:blinkCursor .65s ease infinite;vertical-align:middle;border-radius:1.5px;box-shadow:0 0 10px #38bdf8b3}@keyframes blinkCursor{0%,to{opacity:1}50%{opacity:0}}.chat-input-area{padding:12px;border-top:1px solid var(--glass-border);display:flex;flex-direction:column;gap:8px;flex-shrink:0;background:#00000026;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.chat-textarea{width:100%;min-height:68px;max-height:160px;padding:10px 12px;background:var(--glass-1);border:1px solid var(--glass-border);border-radius:var(--radius-lg);color:var(--text-primary);font-family:var(--font-ui);font-size:12.5px;line-height:1.55;resize:none;outline:none;transition:all var(--transition-fast)}.chat-textarea:focus{border-color:#38bdf84d;box-shadow:0 0 0 3px #38bdf812,0 0 20px #38bdf80d;background:var(--glass-2)}.chat-textarea::placeholder{color:var(--text-tertiary)}.chat-actions{display:flex;gap:6px;align-items:center}.thinking-toggle{display:flex;align-items:center;gap:5px;font-size:10.5px;color:var(--text-tertiary);cursor:pointer;padding:5px 9px;border-radius:var(--radius-md);border:1px solid var(--glass-border);background:none;transition:all var(--transition-fast);font-family:var(--font-ui);font-weight:500}.thinking-toggle:hover{background:#38bdf80f;border-color:#38bdf833;color:var(--text-secondary)}.thinking-toggle.active{color:var(--neon-orange);border-color:#fb923c4d;background:#fb923c14;box-shadow:0 0 12px #fb923c1f}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:5px 13px;border-radius:var(--radius-md);border:1px solid var(--glass-border);background:var(--glass-1);color:var(--text-secondary);font-family:var(--font-ui);font-size:11.5px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;text-decoration:none;position:relative;overflow:hidden}.btn:hover{background:var(--glass-2);color:var(--text-primary);border-color:var(--glass-border-bright);transform:translateY(-1px);box-shadow:0 4px 16px #00000040}.btn:active{transform:scale(.97) translateY(0)}.btn-primary{background:#38bdf81a;border-color:#38bdf847;color:var(--neon-cyan)}.btn-primary:hover{background:#38bdf82e;box-shadow:0 0 18px #38bdf82e,0 4px 16px #0003}.btn-send{flex:1;background:linear-gradient(135deg,#38bdf81f,#6366f11a);border-color:#38bdf847;color:var(--text-primary);font-weight:600;font-size:12px;padding:7px 14px}.btn-send:hover{background:linear-gradient(135deg,#38bdf838,#6366f12e);box-shadow:0 0 22px #38bdf82e,0 4px 16px #0003}.btn-send:disabled{opacity:.3;cursor:not-allowed;transform:none}.btn-icon{padding:5px 6px;border-radius:var(--radius-md)}.btn-icon:hover{transform:scale(1.08)}.auth-screen{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:var(--bg-void);z-index:1000;padding:20px;overflow:hidden}[data-theme=dark] .auth-screen:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 75% 60% at 15% 90%,rgba(56,189,248,.1) 0%,transparent 55%),radial-gradient(ellipse 60% 70% at 88% 12%,rgba(99,102,241,.09) 0%,transparent 55%),radial-gradient(ellipse 50% 50% at 50% 50%,rgba(167,139,250,.06) 0%,transparent 60%);pointer-events:none;animation:auroraDrift 14s ease-in-out infinite alternate}[data-theme=dark] .auth-screen:after{content:"";position:fixed;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(56,189,248,.04) 0%,transparent 70%);top:-100px;right:-100px;pointer-events:none;animation:floatOrb 8s ease-in-out infinite alternate}@keyframes floatOrb{0%{transform:translate(0) scale(1)}to{transform:translate(-30px,40px) scale(1.1)}}.auth-card{background:#080c18eb;backdrop-filter:blur(48px) saturate(180%) brightness(1.08);-webkit-backdrop-filter:blur(48px) saturate(180%) brightness(1.08);border:1px solid rgba(56,189,248,.14);border-radius:var(--radius-2xl);padding:40px;width:100%;max-width:420px;position:relative;z-index:1;box-shadow:0 0 0 1px #38bdf80f,0 40px 100px #000000bf,0 0 80px #38bdf80a,inset 0 1px #ffffff0d;animation:cardEntrance .5s var(--ease-spring)}@keyframes cardEntrance{0%{opacity:0;transform:translateY(24px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.auth-card:before{content:"";position:absolute;top:0;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,rgba(56,189,248,.5),rgba(99,102,241,.4),rgba(167,139,250,.4),transparent);border-radius:2px}.auth-logo{text-align:center;margin-bottom:10px}.auth-logo h1{font-family:var(--font-display);font-size:32px;font-weight:900;letter-spacing:.2em;background:linear-gradient(135deg,#38bdf8,#818cf8,#c084fc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;background-size:200% 200%;animation:logoShimmer 5s ease infinite;filter:drop-shadow(0 0 24px rgba(56,189,248,.45))}.auth-logo p{font-size:11px;color:var(--text-tertiary);letter-spacing:.16em;text-transform:uppercase;font-family:var(--font-code);margin-top:5px}.auth-divider{height:1px;background:linear-gradient(90deg,transparent,var(--glass-border-bright),transparent);margin:28px 0}.auth-form{display:flex;flex-direction:column;gap:12px}.auth-input-group{display:flex;flex-direction:column;gap:5px}.auth-label{font-size:10px;font-weight:600;color:var(--text-tertiary);letter-spacing:.12em;text-transform:uppercase}.auth-input{padding:11px 14px;background:var(--glass-1);border:1px solid var(--glass-border);border-radius:var(--radius-lg);color:var(--text-primary);font-family:var(--font-ui);font-size:13.5px;outline:none;transition:all var(--transition-fast)}.auth-input:focus{border-color:#38bdf866;box-shadow:0 0 0 3px #38bdf814,0 0 20px #38bdf80d;background:var(--glass-2)}.auth-input::placeholder{color:var(--text-tertiary)}.auth-or{display:flex;align-items:center;gap:12px;font-size:10px;color:var(--text-tertiary)}.auth-or:before,.auth-or:after{content:"";flex:1;height:1px;background:var(--glass-border)}.btn-google{display:flex;align-items:center;justify-content:center;gap:10px;padding:11px;background:var(--glass-2);border:1px solid var(--glass-border);border-radius:var(--radius-lg);cursor:pointer;color:var(--text-secondary);font-family:var(--font-ui);font-size:13px;font-weight:500;transition:all var(--transition-fast);width:100%}.btn-google:hover{background:var(--glass-3);border-color:var(--glass-border-bright);color:var(--text-primary);transform:translateY(-1px);box-shadow:0 6px 20px #0000004d}.auth-error{padding:9px 13px;background:#f871711a;border:1px solid rgba(248,113,113,.25);border-radius:var(--radius-md);color:var(--neon-red);font-size:11.5px;animation:shakeIn .3s ease}@keyframes shakeIn{0%,to{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}}.auth-switch{text-align:center;margin-top:18px;font-size:11.5px;color:var(--text-tertiary)}.auth-switch button{background:none;border:none;color:var(--neon-cyan);cursor:pointer;font-size:11.5px;text-decoration:underline;margin-left:4px}.auth-switch button:hover{color:var(--neon-blue)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000006b8;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:500;padding:16px;animation:fadeIn .2s ease-out}.modal-card{background:#080c1af7;-webkit-backdrop-filter:var(--blur-xl);backdrop-filter:var(--blur-xl);border:1px solid var(--glass-border-bright);border-radius:var(--radius-xl);padding:26px;width:100%;max-width:500px;max-height:88vh;overflow-y:auto;position:relative;box-shadow:var(--panel-shadow);animation:fadeInScale .25s var(--ease-spring)}.modal-card:before{content:"";position:absolute;top:0;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,rgba(56,189,248,.4),rgba(167,139,250,.35),transparent)}.modal-title{font-family:var(--font-display);font-size:13.5px;font-weight:700;letter-spacing:.14em;background:linear-gradient(90deg,var(--neon-cyan),var(--neon-purple));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:22px;display:flex;align-items:center;gap:8px}.settings-section{margin-bottom:22px}.settings-section-title{font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--text-tertiary);margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--glass-border)}.api-key-field{display:flex;gap:7px;align-items:center}.api-key-input{flex:1;padding:9px 12px;background:var(--glass-1);border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-code);font-size:11.5px;outline:none;transition:all var(--transition-fast)}.api-key-input:focus{border-color:#38bdf84d;box-shadow:0 0 0 3px #38bdf812;background:var(--glass-2)}.api-key-input::placeholder{color:var(--text-tertiary)}.status-bar{height:22px;display:flex;align-items:center;padding:0 12px;gap:14px;background:#38bdf808;border-top:1px solid rgba(56,189,248,.07);flex-shrink:0;overflow:hidden}.status-item{font-family:var(--font-code);font-size:10px;color:var(--text-tertiary);display:flex;align-items:center;gap:5px;white-space:nowrap}.status-item.active{color:var(--neon-green)}.status-item.streaming{color:var(--neon-cyan)}.status-dot{width:5px;height:5px;border-radius:50%;background:currentColor}.status-dot.pulse{animation:statusPulse 1.2s ease infinite}@keyframes statusPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.75)}}.context-menu{position:fixed;background:#080c1afa;-webkit-backdrop-filter:blur(32px) saturate(180%);backdrop-filter:blur(32px) saturate(180%);border:1px solid rgba(56,189,248,.13);border-radius:var(--radius-lg);padding:5px;z-index:999;min-width:148px;box-shadow:0 0 0 1px #38bdf80d,0 20px 50px #000000bf,0 0 30px #38bdf80a;animation:ctxMenuIn .15s var(--ease-out)}@keyframes ctxMenuIn{0%{opacity:0;transform:scale(.92) translateY(-6px)}to{opacity:1;transform:scale(1) translateY(0)}}.context-menu-item{padding:7px 12px;border-radius:var(--radius-sm);font-size:12px;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;gap:9px;transition:all var(--transition-fast)}.context-menu-item:hover{background:#38bdf817;color:var(--text-primary);transform:translate(2px)}.context-menu-item.danger:hover{background:#f871711f;color:var(--neon-red)}.thinking-indicator{display:flex;align-items:center;gap:8px;padding:9px 11px;background:#fb923c14;border:1px solid rgba(251,146,60,.22);border-radius:var(--radius-lg);font-size:11px;color:var(--neon-orange);animation:thinkingPulse 2s ease-in-out infinite}@keyframes thinkingPulse{0%,to{box-shadow:0 0 #fb923c00}50%{box-shadow:0 0 14px #fb923c26}}.thinking-dots{display:flex;gap:3.5px}.thinking-dots span{width:4.5px;height:4.5px;border-radius:50%;background:var(--neon-orange);animation:thinkDot 1.3s ease infinite}.thinking-dots span:nth-child(2){animation-delay:.22s}.thinking-dots span:nth-child(3){animation-delay:.44s}@keyframes thinkDot{0%,80%,to{transform:scale(.55);opacity:.4}40%{transform:scale(1.1);opacity:1}}.diff-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 7px;border-radius:var(--radius-sm);font-size:9.5px;font-weight:700;font-family:var(--font-code);letter-spacing:.06em}.diff-badge.added{background:#34d3991f;color:var(--neon-green)}.diff-badge.removed{background:#f871711f;color:var(--neon-red)}.toast-container{position:fixed;bottom:36px;right:18px;z-index:1000;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{padding:11px 18px;border-radius:var(--radius-lg);font-size:12.5px;color:var(--text-primary);border:1px solid var(--glass-border);-webkit-backdrop-filter:var(--blur-md);backdrop-filter:var(--blur-md);animation:toastIn .35s var(--ease-spring);display:flex;align-items:center;gap:9px;min-width:230px;max-width:330px;box-shadow:0 10px 30px #00000073;pointer-events:all;position:relative;overflow:hidden}.toast:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent)}@keyframes toastIn{0%{opacity:0;transform:translate(50px) scale(.9)}to{opacity:1;transform:translate(0) scale(1)}}.toast.success{background:#34d3991c;border-color:#34d39947;color:var(--neon-green)}.toast.error{background:#f871711c;border-color:#f8717147;color:var(--neon-red)}.toast.info{background:#38bdf817;border-color:#38bdf842;color:var(--neon-cyan)}.fade-in{animation:fadeIn .25s ease-out}.slide-up{animation:slideUp .32s var(--ease-spring)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(14px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.93) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.monaco-editor .ai-suggested-line{background:#38bdf80f!important;border-left:2px solid var(--neon-cyan)!important}.bento-card{background:#0a0f1cf0;border:1px solid rgba(56,189,248,.1);border-radius:var(--radius-xl);-webkit-backdrop-filter:blur(24px) saturate(160%);backdrop-filter:blur(24px) saturate(160%);box-shadow:var(--card-glow)}[data-theme=light] .btn{color:var(--text-secondary)}[data-theme=light] .btn:hover{background:var(--glass-2);color:var(--text-primary)}[data-theme=light] .tab.active{background:var(--bg-surface);border-color:var(--glass-border)}[data-theme=light] .tab.active:after{background:linear-gradient(90deg,var(--neon-cyan),var(--neon-indigo));box-shadow:none}[data-theme=light] .file-item.active{background:var(--neon-cyan-dim);box-shadow:inset 0 0 0 1px #0284c733}[data-theme=light] .file-item.active:before{background:var(--neon-cyan);box-shadow:0 0 8px #0284c780}[data-theme=light] .file-item.active .file-item-name{color:var(--neon-cyan)}[data-theme=light] .context-menu{background:#fffffffa;border-color:var(--glass-border);box-shadow:0 8px 32px #00000024}[data-theme=light] .toast{background:var(--bg-surface);color:var(--text-primary)}[data-theme=light] .toast.success{background:#16a34a12;border-color:#16a34a47;color:var(--neon-green)}[data-theme=light] .toast.error{background:#dc262612;border-color:#dc262647;color:var(--neon-red)}[data-theme=light] .toast.info{background:#0284c712;border-color:#0284c740;color:var(--neon-cyan)}[data-theme=light] .editor-empty h2{filter:none}[data-theme=light] .message-content.user{background:#0284c712;border-color:#0284c72e}[data-theme=light] .message-content.assistant{background:#7c3aed0f;border-color:#7c3aed24}[data-theme=light] .message-content code{color:var(--neon-cyan)}[data-theme=light] .auth-card{background:#fffffff2;border-color:#0000001a;box-shadow:0 20px 60px #00000024,0 4px 16px #00000014}[data-theme=light] .auth-card:before{background:linear-gradient(90deg,transparent,rgba(2,132,199,.3),transparent)}[data-theme=light] .modal-card{background:#fffffffa;border-color:var(--glass-border)}[data-theme=light] .modal-card:before{background:linear-gradient(90deg,transparent,rgba(2,132,199,.3),transparent)}[data-theme=light] .streaming-cursor{background:var(--neon-cyan);box-shadow:0 0 8px #0284c799}@media (max-width: 768px){:root{--topbar-height: 48px;--island-height: 72px}.mobile-editor-area{flex:1;display:flex;flex-direction:column;overflow:hidden;width:100%;min-width:0;padding-bottom:var(--island-height)}.mobile-editor-area .editor-container{flex:1;overflow:hidden;position:relative}.mobile-sheet{position:fixed;top:var(--topbar-height);bottom:var(--island-height);z-index:300;display:flex;flex-direction:column;background:var(--sidebar-bg);-webkit-backdrop-filter:var(--blur-lg);backdrop-filter:var(--blur-lg);transition:transform var(--transition-slow);overflow:hidden}.mobile-sheet-left{left:0;width:min(82vw,290px);border-right:1px solid var(--glass-border);transform:translate(-108%);box-shadow:6px 0 50px #0009}.mobile-sheet-right{right:0;width:min(100vw,410px);border-left:1px solid var(--glass-border);transform:translate(108%);box-shadow:-6px 0 50px #0009}.mobile-sheet.open{transform:translate(0)}.mobile-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:250;animation:fadeIn .22s ease}.bottom-island{position:fixed;bottom:0;left:0;right:0;z-index:400;display:flex;align-items:flex-end;justify-content:center;padding:0 22px max(12px,env(safe-area-inset-bottom,12px));pointer-events:none;height:var(--island-height)}.bottom-island-inner{display:flex;align-items:center;gap:4px;background:var(--island-bg);border:1px solid var(--island-border);border-radius:var(--radius-2xl);padding:8px 10px;box-shadow:var(--island-shadow);-webkit-backdrop-filter:blur(28px) saturate(180%);backdrop-filter:blur(28px) saturate(180%);pointer-events:all;transition:all .3s;position:relative;overflow:hidden}[data-theme=dark] .bottom-island-inner:before{content:"";position:absolute;top:0;left:5%;right:5%;height:1px;background:linear-gradient(90deg,transparent,rgba(56,189,248,.4),transparent);animation:shimmerLine 3s ease infinite}.island-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:7px 16px;border-radius:var(--radius-xl);border:none;background:transparent;cursor:pointer;color:var(--text-tertiary);transition:all var(--transition-fast);min-width:58px}.island-btn span{font-size:10px;font-family:var(--font-ui);font-weight:600;letter-spacing:.02em}.island-btn:hover{color:var(--text-secondary);background:var(--glass-2)}.island-btn.active{color:var(--neon-cyan);background:#38bdf81a}.island-btn.active.ai-active{color:var(--neon-purple);background:#a78bfa1f}.island-btn-center{width:50px;height:50px;min-width:50px;border-radius:50%;padding:0;background:linear-gradient(135deg,#38bdf833,#6366f129);border:1px solid rgba(56,189,248,.32);color:var(--text-primary);box-shadow:0 0 22px #38bdf82e,0 6px 22px #00000073;animation:centerBtnGlow 3s ease-in-out infinite alternate}@keyframes centerBtnGlow{0%{box-shadow:0 0 16px #38bdf824,0 6px 22px #00000073}to{box-shadow:0 0 30px #38bdf847,0 6px 22px #00000073}}.island-btn-center:hover{background:linear-gradient(135deg,#38bdf84d,#6366f142);transform:scale(1.06)}.island-btn-center:active{transform:scale(.95)}.file-item,.folder-item{padding:9px 14px;min-height:42px}.tab{padding:0 10px;font-size:11px}}@media (max-width: 480px){:root{--topbar-height: 46px}.island-btn{padding:7px 13px;min-width:52px}.topbar-logo{font-size:14px;letter-spacing:.12em}}
