*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #0f0f0f;--bg-secondary: #1a1a2e;--bg-tertiary: #16213e;--bg-card: #1e1e2e;--bg-input: #2a2a3e;--border: #2d2d44;--text-primary: #e4e4e7;--text-secondary: #a1a1aa;--text-muted: #71717a;--accent: #8b5cf6;--accent-hover: #7c3aed;--accent-dim: rgba(139, 92, 246, .15);--success: #22c55e;--error: #ef4444}html,body,#root{height:100%;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:var(--text-primary);background:var(--bg-primary)}.app-layout{display:flex;flex-direction:column;height:100%}.app-header{display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:52px;background:var(--bg-secondary);border-bottom:1px solid var(--border);flex-shrink:0}.app-header-left{display:flex;align-items:center;gap:12px}.app-logo{font-size:15px;font-weight:700;color:var(--accent);letter-spacing:-.02em}.app-header-actions{display:flex;gap:8px;align-items:center}.app-body{display:flex;flex:1;overflow:hidden}.btn{padding:7px 16px;border:none;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;gap:6px}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--border)}.btn-sm{padding:5px 12px;font-size:12px}.btn:disabled{opacity:.5;cursor:not-allowed}.chat-panel-wrapper{position:relative;width:420px;min-width:0;display:flex;flex-shrink:0;transition:width .25s ease}.chat-panel-wrapper.collapsed{width:0}.chat-panel-wrapper.collapsed .chat-panel{opacity:0;pointer-events:none}.chat-collapse-btn{position:absolute;right:-14px;top:50%;transform:translateY(-50%);z-index:10;width:28px;height:28px;border-radius:50%;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-muted);font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.chat-collapse-btn:hover{background:var(--bg-input);color:var(--text-primary);border-color:var(--accent)}.chat-panel{width:420px;display:flex;flex-direction:column;background:var(--bg-secondary);border-right:1px solid var(--border);overflow:hidden;transition:opacity .2s ease}.chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:16px}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track{background:transparent}.chat-messages::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--text-muted);padding:32px;text-align:center}.chat-empty h2{font-size:20px;font-weight:600;color:var(--text-primary)}.chat-empty p{font-size:14px;line-height:1.5;max-width:300px}.chat-suggestions{display:flex;flex-direction:column;gap:8px;width:100%;max-width:320px}.chat-suggestion{padding:10px 14px;background:var(--bg-input);border:1px solid var(--border);border-radius:10px;color:var(--text-secondary);font-size:13px;cursor:pointer;text-align:left;transition:all .15s}.chat-suggestion:hover{border-color:var(--accent);color:var(--text-primary);background:var(--accent-dim)}.chat-input-area{padding:16px;border-top:1px solid var(--border)}.chat-input-wrapper{display:flex;gap:8px;background:var(--bg-input);border:1px solid var(--border);border-radius:12px;padding:4px 4px 4px 14px;transition:border-color .15s}.chat-input-wrapper:focus-within{border-color:var(--accent)}.chat-input{flex:1;background:none;border:none;color:var(--text-primary);font-size:14px;outline:none;resize:none;font-family:inherit;line-height:1.5;padding:6px 0;max-height:120px}.chat-input::placeholder{color:var(--text-muted)}.chat-send-btn{width:36px;height:36px;border-radius:8px;border:none;background:var(--accent);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;align-self:flex-end;transition:background .15s;font-size:16px}.chat-send-btn:hover{background:var(--accent-hover)}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed}.message{display:flex;gap:10px}.message-avatar{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex-shrink:0}.message-user .message-avatar{background:var(--accent-dim);color:var(--accent)}.message-assistant .message-avatar{background:#22c55e26;color:var(--success)}.message-content{flex:1;min-width:0}.message-content p{font-size:14px;line-height:1.6;color:var(--text-primary);margin-bottom:4px}.message-content pre{background:var(--bg-primary);border:1px solid var(--border);border-radius:8px;padding:12px;margin:8px 0;overflow-x:auto;font-size:12px;line-height:1.5}.message-content code{font-family:JetBrains Mono,Fira Code,monospace;font-size:12px}.message-content :not(pre)>code{background:var(--bg-input);padding:2px 6px;border-radius:4px;font-size:13px}.message-content ul,.message-content ol{margin:8px 0;padding-left:20px}.message-content li{font-size:14px;line-height:1.6}.streaming-cursor:after{content:"|";animation:blink 1s infinite;color:var(--accent);font-weight:700}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.ai-building-status{display:flex;align-items:center;gap:10px;padding:8px 0;color:var(--text-secondary);font-size:14px}.ai-building-status p{color:var(--text-secondary)!important;margin:0!important}.building-indicator{display:flex;gap:4px}.building-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:buildingBounce 1.4s infinite ease-in-out both}.building-dot:nth-child(1){animation-delay:-.32s}.building-dot:nth-child(2){animation-delay:-.16s}.building-dot:nth-child(3){animation-delay:0s}@keyframes buildingBounce{0%,80%,to{transform:scale(.4);opacity:.4}40%{transform:scale(1);opacity:1}}.generated-files{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.generated-file-tag{display:inline-flex;align-items:center;padding:3px 10px;border-radius:6px;background:var(--accent-dim);color:var(--accent);font-size:11px;font-weight:500;font-family:JetBrains Mono,Fira Code,monospace}.preview-panel{flex:1;display:flex;flex-direction:column;background:var(--bg-primary);overflow:hidden}.preview-tabs{display:flex;align-items:center;gap:0;padding:0 16px;height:44px;background:var(--bg-secondary);border-bottom:1px solid var(--border)}.preview-tab{padding:8px 16px;border:none;background:none;color:var(--text-muted);font-size:13px;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;transition:all .15s;height:100%;display:flex;align-items:center}.preview-tab.active{color:var(--text-primary);border-bottom-color:var(--accent)}.preview-tab:hover:not(.active){color:var(--text-secondary)}.preview-content{flex:1;overflow:hidden}.preview-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-muted);font-size:14px;gap:8px}.preview-empty-icon{font-size:48px;opacity:.3}.code-panel{display:flex;flex-direction:column;height:100%;background:var(--bg-primary)}.file-explorer{display:flex;gap:0;padding:0 8px;background:var(--bg-secondary);border-bottom:1px solid var(--border);overflow-x:auto;flex-shrink:0}.file-explorer::-webkit-scrollbar{height:0}.file-tab{display:flex;align-items:center;gap:6px;padding:8px 14px;border:none;background:none;color:var(--text-muted);font-size:12px;font-family:JetBrains Mono,Fira Code,monospace;cursor:pointer;white-space:nowrap;border-bottom:2px solid transparent;transition:all .15s}.file-tab:hover{color:var(--text-secondary);background:#ffffff08}.file-tab.active{color:var(--text-primary);border-bottom-color:var(--accent);background:#ffffff0d}.file-icon{font-size:13px}.code-editor{flex:1;overflow:auto;padding:16px;margin:0;font-family:JetBrains Mono,Fira Code,monospace;font-size:13px;line-height:1.7;color:var(--text-primary);white-space:pre;-moz-tab-size:2;tab-size:2;background:var(--bg-primary)}.code-editor::-webkit-scrollbar{width:8px;height:8px}.code-editor::-webkit-scrollbar-track{background:transparent}.code-editor::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.file-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;margin-left:6px;border-radius:9px;background:var(--accent-dim);color:var(--accent);font-size:10px;font-weight:600}.streaming-badge{display:flex;align-items:center;gap:8px;margin-left:auto;padding:0 12px;font-size:12px;color:var(--accent);font-weight:500}.streaming-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}.sandpack-tab-pane{height:100%;width:100%;flex-direction:column}.preview-content .sp-wrapper,.preview-content .sp-layout,.preview-content .sp-stack,.preview-content .sp-preview,.preview-content .sp-preview-container,.preview-content .sp-preview-iframe{height:100%!important}.preview-content .sp-layout{border:none!important;border-radius:0!important;background:transparent!important;width:100%!important}.preview-content .sp-preview-actions,.preview-content [class*=openInCSB],.preview-content a[title="Open in CodeSandbox"]{display:none!important}.preview-content .sp-file-explorer{min-width:220px!important;max-width:280px!important;background:#1a1a2e!important;border-right:1px solid #2d2d44!important;height:100%!important;overflow-y:auto!important}.preview-content .sp-code-editor{flex:1!important;height:100%!important;background:#0f0f0f!important}.preview-content .sp-tabs{background:#1a1a2e!important;border-bottom:1px solid #2d2d44!important}.streaming-code-view{height:100%;width:100%;overflow:auto;background:var(--bg-primary)}.auth-page{display:flex;align-items:center;justify-content:center;height:100%;background:var(--bg-primary)}.auth-card{background:var(--bg-card);padding:36px;border-radius:16px;border:1px solid var(--border);width:380px}.auth-card h2{margin-bottom:24px;font-size:22px;font-weight:600}.auth-field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.auth-field label{font-size:13px;font-weight:500;color:var(--text-secondary)}.auth-field input{padding:10px 14px;background:var(--bg-input);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:14px;outline:none;transition:border-color .15s}.auth-field input:focus{border-color:var(--accent)}.auth-card .btn{width:100%;padding:10px;margin-top:8px;justify-content:center}.auth-toggle{margin-top:16px;text-align:center;font-size:13px;color:var(--text-muted)}.auth-toggle a{color:var(--accent);cursor:pointer;text-decoration:none}.error-msg{color:var(--error);font-size:13px;margin-bottom:12px;padding:8px 12px;background:#ef44441a;border-radius:8px}
