*{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary:#0a0a0a;--bg-secondary:#111;--bg-tertiary:#1a1a1a;--bg-elevated:#1f1f1f;--bg-hover:#262626;--text-primary:#fff;--text-secondary:#a3a3a3;--text-tertiary:#737373;--accent-primary:#10b981;--accent-primary-hover:#059669;--accent-secondary:#14b8a6;--accent-gradient:linear-gradient(135deg,#10b981,#14b8a6);--border-color:#262626;--border-hover:#404040;--success:#10b981;--error:#ef4444;--warning:#f59e0b;--shadow-sm:0 1px 2px 0 rgba(0,0,0,.3);--shadow-md:0 4px 6px -1px rgba(0,0,0,.3),0 2px 4px -1px rgba(0,0,0,.2);--shadow-lg:0 10px 15px -3px rgba(0,0,0,.3),0 4px 6px -2px rgba(0,0,0,.2);--shadow-xl:0 20px 25px -5px rgba(0,0,0,.3),0 10px 10px -5px rgba(0,0,0,.2);--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--transition-fast:150ms cubic-bezier(0.4,0,0.2,1);--transition-base:200ms cubic-bezier(0.4,0,0.2,1);--transition-slow:300ms cubic-bezier(0.4,0,0.2,1)}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#0a0a0a;background:var(--bg-primary);color:#fff;color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6;min-height:100vh}code{background:#1a1a1a;background:var(--bg-tertiary);border-radius:6px;border-radius:var(--radius-sm);font-family:SF Mono,Monaco,Inconsolata,Fira Code,Droid Sans Mono,Source Code Pro,monospace;font-size:.9em;padding:2px 6px}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#111;background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:#1f1f1f;background:var(--bg-elevated);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#262626;background:var(--bg-hover)}::selection{background:#10b981;background:var(--accent-primary);color:#fff;color:var(--text-primary)}.navbar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--bg-secondary);background:hsla(0,0%,7%,.8);border-bottom:1px solid var(--border-color);position:-webkit-sticky;position:sticky;top:0;z-index:100}.navbar-content{height:64px;justify-content:space-between;margin:0;max-width:100%;padding:0 16px}.navbar-brand,.navbar-content{align-items:center;display:flex}.navbar-brand{color:var(--text-primary);font-size:18px;font-weight:700;gap:8px;letter-spacing:-.5px;text-decoration:none;transition:all var(--transition-base)}.brand-icon{align-items:center;background:var(--accent-primary);border-radius:6px;color:var(--bg-primary);display:flex;font-size:12px;font-weight:900;height:24px;justify-content:center;line-height:1;width:24px}.navbar-logo{height:32px;object-fit:contain;width:32px}.navbar-brand:hover{opacity:.8}.navbar-menu{align-items:center;display:flex;gap:24px}.navbar-link{color:var(--text-secondary);font-size:14px;font-weight:500;position:relative;text-decoration:none;transition:color var(--transition-base)}.navbar-link:hover{color:var(--text-primary)}.navbar-link:after{background:var(--text-primary);bottom:-4px;content:"";height:2px;left:0;position:absolute;transition:width var(--transition-base);width:0}.navbar-link:hover:after{width:100%}.navbar-user{align-items:center;display:flex;gap:16px}.user-name{color:var(--text-secondary)}.signout-button,.user-name{font-size:14px;font-weight:500}.signout-button{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;padding:8px 16px;transition:all var(--transition-base)}.signout-button:hover{background:var(--bg-hover);border-color:var(--border-hover);transform:translateY(-1px)}.admin-link{color:#6366f1;color:var(--accent-color,#6366f1);font-weight:600}.admin-link:hover{color:#818cf8;color:var(--accent-color,#818cf8)}.auth-container{align-items:center;background:var(--bg-primary);display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:20px;position:relative}.auth-container:before{animation:rotate 20s linear infinite;background:radial-gradient(circle,rgba(59,130,246,.1) 0,transparent 70%);content:"";height:200%;left:-50%;position:absolute;top:-50%;width:200%}@keyframes rotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.auth-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:420px;padding:48px;position:relative;width:100%;z-index:1}.auth-card h1{-webkit-text-fill-color:transparent;background:linear-gradient(135deg,var(--text-primary) 0,var(--text-secondary) 100%);-webkit-background-clip:text;background-clip:text;color:var(--text-primary);font-size:32px;font-weight:700;letter-spacing:-1px;margin:0 0 12px;text-align:center}.auth-subtitle{color:var(--text-secondary);font-size:15px;margin:0 0 32px;text-align:center}.auth-form{gap:20px}.auth-form,.form-group{display:flex;flex-direction:column}.form-group{gap:8px}.form-group label{color:var(--text-secondary)}.form-group input{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:15px;padding:14px 18px;transition:all var(--transition-base)}.form-group input:focus{background:var(--bg-elevated);border-color:var(--text-primary);box-shadow:0 0 0 3px hsla(0,0%,100%,.1);outline:none}.form-group input:disabled{background-color:var(--bg-tertiary);cursor:not-allowed;opacity:.5}.form-group input::placeholder{color:var(--text-tertiary)}.auth-button{background:var(--text-primary);border:none;border-radius:var(--radius-md);box-shadow:0 1px 2px rgba(0,0,0,.1);color:var(--bg-primary);cursor:pointer;font-size:16px;font-weight:600;margin-top:10px;padding:14px 24px;transition:all var(--transition-base)}.auth-button:hover:not(:disabled){background:var(--text-secondary);box-shadow:0 4px 12px rgba(0,0,0,.15);transform:translateY(-2px)}.auth-button:active:not(:disabled){box-shadow:0 1px 2px rgba(0,0,0,.1);transform:translateY(0)}.auth-button:disabled{background:var(--text-tertiary);cursor:not-allowed;opacity:.4;transform:none}.auth-link{color:var(--text-secondary);font-size:14px;margin-top:24px;text-align:center}.auth-link a{color:var(--text-primary);font-weight:600;text-decoration:none;transition:color var(--transition-base)}.auth-link a:hover{color:var(--text-secondary);text-decoration:underline}.loading-spinner-container{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center}.loading-spinner-container.full-screen{min-height:200px;padding:60px 20px}.loading-spinner{animation:spin .8s linear infinite;border:3px solid #2a2a3a;border-radius:50%;border-top-color:#6366f1;border:3px solid var(--border-color,#2a2a3a);border-top-color:var(--accent-color,#6366f1)}.loading-spinner.small{border-width:2px;height:24px;width:24px}.loading-spinner.medium{border-width:3px;height:40px;width:40px}.loading-spinner.large{border-width:4px;height:56px;width:56px}.loading-spinner-message{color:#a0a0a0;color:var(--text-secondary,#a0a0a0);font-size:16px;margin:0;text-align:center}@keyframes spin{to{transform:rotate(1turn)}}.projects-layout{background:var(--bg-primary);display:flex;height:calc(100vh - 64px);overflow:hidden;width:100%}.projects-sidebar{background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;min-width:280px;overflow:hidden;position:relative;transition:transform var(--transition-slow),width var(--transition-slow);width:280px}.projects-sidebar.closed{border-right:none;min-width:0;transform:translateX(-100%);width:0}.sidebar-header{gap:12px;min-height:60px}.sidebar-header-content{align-items:center;display:flex;flex:1 1;gap:12px;justify-content:space-between;min-width:0}.projects-sidebar.closed .sidebar-header-content{opacity:0;pointer-events:none}.sidebar-toggle-button{align-items:center;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;display:flex;flex-shrink:0;height:28px;justify-content:center;padding:6px;transition:all var(--transition-base);width:28px}.sidebar-toggle-button:hover{background:var(--bg-hover);border-color:var(--border-hover);color:var(--text-primary)}.toggle-icon{height:16px;width:16px}.sidebar-toggle-overlay{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-md);color:var(--text-secondary);cursor:pointer;display:flex;justify-content:center;left:16px;padding:10px;position:fixed;top:80px;transition:all var(--transition-base);z-index:50}.sidebar-toggle-overlay:hover{background:var(--bg-hover);border-color:var(--border-hover);box-shadow:var(--shadow-lg);color:var(--text-primary);transform:translateY(-2px)}.sidebar-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:20px 16px}.sidebar-header h2{color:var(--text-primary);font-size:18px;font-weight:600;letter-spacing:-.3px;margin:0}.sidebar-content{flex:1 1;overflow-y:auto;padding:8px}.sidebar-empty{align-items:center;color:var(--text-secondary);display:flex;flex-direction:column;height:100%;justify-content:center;padding:40px 20px;text-align:center}.sidebar-empty .empty-icon{height:48px;margin-bottom:16px;opacity:.4;width:48px}.sidebar-empty p{font-size:14px;margin:0}.projects-list{gap:12px}.project-group,.projects-list{display:flex;flex-direction:column}.project-group{gap:1px}.project-group-header{color:var(--text-tertiary);font-size:11px;font-weight:600;letter-spacing:.5px;padding:8px 12px 4px;text-transform:uppercase}.project-item{align-items:center;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);cursor:pointer;display:flex;justify-content:space-between;padding:4px 12px;transition:all var(--transition-base)}.project-item:hover{background:var(--bg-hover);border-radius:var(--radius-sm)}.project-item.active{background:var(--bg-elevated);border-color:var(--text-primary);box-shadow:0 0 0 1px hsla(0,0%,100%,.1)}.project-item-content{align-items:center;display:flex;flex:1 1;min-width:0}.project-item-info{flex:1 1;min-width:0}.project-item-info h3{color:var(--text-primary);font-size:14px;font-weight:500;line-height:1.4;margin:0;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.loading-more{color:var(--text-tertiary);font-size:12px;padding:16px;text-align:center}.project-item-delete{align-items:center;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-tertiary);cursor:pointer;display:flex;justify-content:center;opacity:0;padding:6px;transition:all var(--transition-base)}.project-item:hover .project-item-delete{opacity:1}.project-item-delete:hover{background:rgba(239,68,68,.1);color:var(--error)}.delete-icon{height:16px;width:16px}.projects-main{background:var(--bg-primary);display:flex;flex:1 1;flex-direction:column;overflow:hidden;overflow-y:auto;position:relative;transition:margin-left var(--transition-slow)}.projects-main.sidebar-closed{margin-left:0}.projects-main:after{background-image:repeating-linear-gradient(0deg,transparent,transparent 2px,hsla(0,0%,100%,.01) 0,hsla(0,0%,100%,.01) 4px),repeating-linear-gradient(90deg,transparent,transparent 2px,hsla(0,0%,100%,.01) 0,hsla(0,0%,100%,.01) 4px);bottom:0;content:"";left:0;opacity:.3;pointer-events:none;position:absolute;right:0;top:0;z-index:2}.ai-chat-container{background-position:50%;background-repeat:no-repeat;background-size:cover;height:100%;padding:0;z-index:1}.ai-chat-container,.hero-section{display:flex;flex-direction:column;margin:0 auto;position:relative;width:100%}.hero-section{align-items:center;justify-content:center;max-width:800px;min-height:100%;padding:80px 32px;z-index:2}.hero-content{margin-bottom:64px;position:relative;text-align:center;z-index:1}.hero-title{color:var(--text-primary);font-size:56px;font-weight:700;letter-spacing:-2px;line-height:1.1;margin:0 0 20px}.hero-subtitle{color:var(--text-secondary);font-size:20px;font-weight:400;line-height:1.6;margin:0}.hero-input-form{max-width:700px;position:relative;width:100%;z-index:1}.template-selector-wrapper{align-items:center;display:flex;gap:12px;justify-content:center;margin-top:16px;padding:0 4px}.template-label{color:var(--text-secondary);font-size:14px;font-weight:500;white-space:nowrap}.template-select{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;font-family:inherit;font-size:14px;min-width:200px;padding:8px 16px;transition:all var(--transition-base)}.template-select:hover:not(:disabled){background:var(--bg-elevated);border-color:var(--border-hover)}.template-select:focus{border-color:var(--text-primary);box-shadow:0 0 0 3px hsla(0,0%,100%,.1);outline:none}.template-select:disabled{cursor:not-allowed;opacity:.5}.hero-input-wrapper{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:0 4px 24px rgba(0,0,0,.2);display:flex;gap:16px;padding:20px 24px;transition:all var(--transition-base)}.hero-input-wrapper:focus-within{background:var(--bg-elevated);border-color:var(--text-primary);box-shadow:0 0 0 3px hsla(0,0%,100%,.1),0 8px 32px rgba(0,0,0,.3)}.hero-input-container{flex:1 1;position:relative}.hero-input{background:transparent;border:none;border-radius:var(--radius-lg);color:var(--text-primary);font-family:inherit;font-size:16px;line-height:1.6;max-height:200px;min-height:64px;overflow-y:auto;padding:18px 20px;resize:none;scrollbar-color:var(--bg-elevated) transparent;scrollbar-width:thin;transition:all var(--transition-base);width:100%}.hero-input::-webkit-scrollbar{width:6px}.hero-input::-webkit-scrollbar-track{background:transparent}.hero-input::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:3px}.hero-input:focus{outline:none}.hero-input:disabled{cursor:not-allowed;opacity:.5}.animated-placeholder{color:var(--text-tertiary);font-family:inherit;font-size:16px;left:20px;line-height:1.6;opacity:.6;pointer-events:none;position:absolute;top:18px;white-space:pre-wrap}.animated-placeholder:after{animation:blink 1s infinite;background:var(--text-tertiary);content:"";display:inline-block;height:18px;margin-left:2px;vertical-align:middle;width:2px}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.hero-send-button{align-items:center;background:var(--text-primary);border:none;border-radius:var(--radius-md);box-shadow:0 2px 8px rgba(0,0,0,.2);color:var(--bg-primary);cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:10px;height:64px;padding:18px 32px;transition:all var(--transition-base);white-space:nowrap}.hero-send-button:hover:not(:disabled){background:var(--text-secondary);box-shadow:0 6px 16px rgba(0,0,0,.25);transform:translateY(-2px)}.hero-send-button:active:not(:disabled){box-shadow:0 2px 8px rgba(0,0,0,.2);transform:translateY(0)}.hero-send-button:disabled{background:var(--text-tertiary);cursor:not-allowed;opacity:.4;transform:none}.arrow-icon{height:18px;width:18px}.button-loading{align-items:center;display:flex;gap:4px}.button-loading span{animation:bounce 1.4s ease-in-out infinite both;background:#fff;border-radius:50%;height:6px;width:6px}.button-loading span:first-child{animation-delay:-.32s}.button-loading span:nth-child(2){animation-delay:-.16s}@keyframes bounce{0%,80%,to{opacity:.5;transform:scale(0)}40%{opacity:1;transform:scale(1)}}.error-message{margin:0 32px 20px}.sidebar-content::-webkit-scrollbar{width:6px}.sidebar-content::-webkit-scrollbar-track{background:transparent}.sidebar-content::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:3px}.sidebar-content::-webkit-scrollbar-thumb:hover{background:var(--bg-hover)}@media (max-width:768px){.projects-layout{flex-direction:column}.projects-sidebar{border-bottom:1px solid var(--border-color);border-right:none;height:200px;width:100%}.hero-section{padding:60px 24px}.hero-title{font-size:40px;letter-spacing:-1.5px}.hero-subtitle{font-size:18px}.hero-input-wrapper{align-items:stretch;flex-direction:column;padding:16px 20px}.hero-input{min-height:56px;padding:16px 18px}.hero-send-button{height:56px;justify-content:center;width:100%}}.file-browser-container{background:var(--bg-primary);display:flex;height:100%;overflow:hidden}.file-browser{background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;min-width:250px;overflow:hidden;width:300px}.file-browser-header{align-items:center;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:16px}.file-browser-header h3{color:var(--text-primary);font-size:16px;font-weight:600;margin:0}.refresh-button{align-items:center;background:none;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;display:flex;justify-content:center;padding:4px 8px;transition:background var(--transition-base)}.refresh-button:hover{background:var(--bg-hover);color:var(--text-primary)}.file-browser-content{flex:1 1;overflow-y:auto;padding:8px}.file-tree-container{width:100%}.file-tree{list-style:none}.file-tree,.file-tree-item{margin:0;padding:0}.file-item{align-items:center;border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;display:flex;font-size:14px;gap:8px;padding:6px 12px;transition:background var(--transition-base)}.file-item:hover{background:var(--bg-hover)}.file-item.selected{background:var(--accent-primary);color:#fff}.file-icon{flex-shrink:0;font-size:16px}.file-name{flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-tree-children{border-left:1px solid var(--border-color);margin-left:20px;padding-left:8px}.file-browser-empty{align-items:center;color:var(--text-secondary);display:flex;flex-direction:column;height:100%;justify-content:center;text-align:center;width:100%}.file-browser-empty p{font-size:14px;margin:8px 0}.file-browser-hint{color:var(--text-tertiary);font-size:12px}.empty-files,.file-browser-error{color:var(--text-secondary);font-size:14px;padding:40px 20px;text-align:center}.file-browser-error{color:var(--error)}.retry-button{background:var(--accent-primary);border:none;border-radius:var(--radius-md);color:#fff;display:block;font-weight:500;margin:16px auto}.retry-button:hover{background:var(--accent-hover)}.file-editor{flex:1 1;flex-direction:column;overflow:hidden}.file-editor,.file-editor-empty{background:var(--bg-primary);display:flex}.file-editor-empty{align-items:center;flex:1 1;justify-content:center}.file-editor-empty-message{color:var(--text-secondary);font-size:14px;text-align:center}.file-editor-header{align-items:center;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);display:flex;flex-shrink:0;justify-content:space-between;padding:12px 16px}.file-editor-title{align-items:center;color:var(--text-primary);display:flex;flex:1 1;font-size:13px;font-weight:600;gap:8px;overflow:hidden}.file-path{font-family:SF Mono,Monaco,Courier New,monospace;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-editor-actions{align-items:center;display:flex;gap:12px}.unsaved-indicator{animation:pulse 2s infinite;color:var(--accent-primary);font-size:12px}.save-button{background:var(--accent-primary);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:8px 16px;transition:all var(--transition-base)}.save-button:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px)}.save-button:disabled{cursor:not-allowed;opacity:.5}.file-editor-error{background:rgba(239,68,68,.1);border-bottom:1px solid var(--border-color);color:var(--error);font-size:13px;padding:12px 20px}.file-editor-content{background:#1e1e1e;display:flex;flex:1 1;flex-direction:column;overflow:hidden;position:relative}.file-editor-loading{color:var(--text-secondary);padding:40px;text-align:center}.xterm{cursor:text;position:relative;-moz-user-select:none;user-select:none;-ms-user-select:none;-webkit-user-select:none}.xterm.focus,.xterm:focus{outline:none}.xterm .xterm-helpers{position:absolute;top:0;z-index:5}.xterm .xterm-helper-textarea{border:0;height:0;left:-9999em;margin:0;opacity:0;overflow:hidden;padding:0;position:absolute;resize:none;top:0;white-space:nowrap;width:0;z-index:-5}.xterm .composition-view{background:#000;color:#fff;display:none;position:absolute;white-space:nowrap;z-index:1}.xterm .composition-view.active{display:block}.xterm .xterm-viewport{background-color:#000;bottom:0;cursor:default;left:0;overflow-y:scroll;position:absolute;right:0;top:0}.xterm .xterm-screen{position:relative}.xterm .xterm-screen canvas{left:0;position:absolute;top:0}.xterm .xterm-scroll-area{visibility:hidden}.xterm-char-measure-element{display:inline-block;left:-9999em;line-height:normal;position:absolute;top:0;visibility:hidden}.xterm.enable-mouse-events{cursor:default}.xterm .xterm-cursor-pointer,.xterm.xterm-cursor-pointer{cursor:pointer}.xterm.column-select.focus{cursor:crosshair}.xterm .xterm-accessibility,.xterm .xterm-message{bottom:0;color:transparent;left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:10}.xterm .live-region{height:1px;left:-9999px;overflow:hidden;position:absolute;width:1px}.xterm-dim{opacity:1!important}.xterm-underline-1{text-decoration:underline}.xterm-underline-2{-webkit-text-decoration:double underline;text-decoration:double underline}.xterm-underline-3{-webkit-text-decoration:wavy underline;text-decoration:wavy underline}.xterm-underline-4{-webkit-text-decoration:dotted underline;text-decoration:dotted underline}.xterm-underline-5{-webkit-text-decoration:dashed underline;text-decoration:dashed underline}.xterm-overline{text-decoration:overline}.xterm-overline.xterm-underline-1{text-decoration:overline underline}.xterm-overline.xterm-underline-2{-webkit-text-decoration:overline double underline;text-decoration:overline double underline}.xterm-overline.xterm-underline-3{-webkit-text-decoration:overline wavy underline;text-decoration:overline wavy underline}.xterm-overline.xterm-underline-4{-webkit-text-decoration:overline dotted underline;text-decoration:overline dotted underline}.xterm-overline.xterm-underline-5{-webkit-text-decoration:overline dashed underline;text-decoration:overline dashed underline}.xterm-strikethrough{text-decoration:line-through}.xterm-screen .xterm-decoration-container .xterm-decoration{position:absolute;z-index:6}.xterm-screen .xterm-decoration-container .xterm-decoration.xterm-decoration-top-layer{z-index:7}.xterm-decoration-overview-ruler{pointer-events:none;position:absolute;right:0;top:0;z-index:8}.xterm-decoration-top{position:relative;z-index:2}.interactive-terminal{background:#1e1e1e;box-sizing:border-box;display:flex;flex-direction:column;height:100%;min-height:200px;overflow:hidden;padding:8px;width:100%}.xterm-container{flex:1 1;height:100%;min-height:150px;position:relative;width:100%}.xterm-container .xterm{height:100%;padding:0}.xterm-container .xterm-screen,.xterm-container .xterm-viewport{background-color:#1e1e1e!important}.xterm-container .xterm-viewport::-webkit-scrollbar{width:8px}.xterm-container .xterm-viewport::-webkit-scrollbar-track{background:#1e1e1e}.xterm-container .xterm-viewport::-webkit-scrollbar-thumb{background:#444;border-radius:4px}.xterm-container .xterm-viewport::-webkit-scrollbar-thumb:hover{background:#555}.terminal-container{background:#1e1e1e;border-radius:8px;box-shadow:0 4px 6px rgba(0,0,0,.3);display:flex;flex-direction:column;height:100%;overflow:hidden}.terminal-header{align-items:center;background:#2d2d2d;border-bottom:1px solid #3d3d3d;display:flex;justify-content:space-between;padding:12px 16px;-webkit-user-select:none;user-select:none}.terminal-header-left{align-items:center;display:flex;gap:16px}.terminal-title{align-items:center;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:4px 8px;transition:background .2s ease}.terminal-title:hover{background:hsla(0,0%,100%,.1)}.terminal-icon{align-items:center;color:currentColor;display:flex;height:16px;justify-content:center;width:16px}.terminal-icon svg{height:100%;width:100%}.terminal-header-right{align-items:center;display:flex;gap:12px}.terminal-status{font-size:12px;gap:6px}.terminal-status,.terminal-toggle-btn{align-items:center;color:#999;display:flex}.terminal-toggle-btn{background:none;border:none;border-radius:4px;cursor:pointer;justify-content:center;padding:4px 8px;transition:all .2s ease}.terminal-toggle-btn:hover{background:hsla(0,0%,100%,.1);color:#fff}.toggle-icon{font-size:12px;transition:transform .2s ease}.status-indicator{background:#666;border-radius:50%;height:8px;width:8px}.status-indicator.connected{background:#4caf50;box-shadow:0 0 8px rgba(76,175,80,.5)}.status-indicator.disconnected{background:#f44336}.terminal-content{color:#d4d4d4;flex:1 1;font-family:Monaco,Menlo,Ubuntu Mono,Consolas,source-code-pro,monospace;font-size:13px;line-height:1.5;overflow-y:auto;padding:16px}.terminal-empty{align-items:center;color:#666;display:flex;flex-direction:column;height:100%;justify-content:center;text-align:center}.terminal-empty p{margin:8px 0}.terminal-hint{color:#555;font-size:12px}.terminal-lines{display:flex;flex-direction:column;gap:2px}.terminal-line{display:flex;gap:12px;padding:2px 0;word-break:break-word}.terminal-timestamp{color:#666;font-size:11px;min-width:80px;white-space:nowrap}.terminal-text{color:#d4d4d4;flex:1 1;white-space:pre-wrap;word-break:break-word}.terminal-content::-webkit-scrollbar{width:8px}.terminal-content::-webkit-scrollbar-track{background:#1e1e1e}.terminal-content::-webkit-scrollbar-thumb{background:#444;border-radius:4px}.terminal-content::-webkit-scrollbar-thumb:hover{background:#555}.terminal-tabs{align-items:center;background:#252525;border-bottom:1px solid #3d3d3d;display:flex;gap:4px;overflow-x:auto;padding:8px 12px}.terminal-tabs::-webkit-scrollbar{height:4px}.terminal-tabs::-webkit-scrollbar-track{background:#252525}.terminal-tabs::-webkit-scrollbar-thumb{background:#444;border-radius:2px}.terminal-tab{align-items:center;background:#2d2d2d;border:1px solid transparent;border-radius:4px;color:#999;cursor:pointer;display:flex;font-size:13px;gap:6px;padding:6px 12px;transition:all .2s ease;-webkit-user-select:none;user-select:none;white-space:nowrap}.terminal-tab:hover{background:#333;color:#ddd}.terminal-tab.active{background:#1e1e1e;border-color:#4caf50;color:#fff}.tab-icon{align-items:center;color:currentColor;display:flex;flex-shrink:0;height:14px;justify-content:center;width:14px}.tab-icon svg{height:100%;width:100%}.tab-title{font-weight:500}.tab-close-btn{align-items:center;background:none;border:none;border-radius:2px;color:#999;cursor:pointer;display:flex;font-size:18px;height:18px;justify-content:center;line-height:1;margin-left:4px;padding:0;transition:all .2s ease;width:18px}.tab-close-btn:hover{background:hsla(0,0%,100%,.1);color:#f44336}.terminal-new-tab-btn{align-items:center;background:#2d2d2d;border:1px solid #3d3d3d;border-radius:4px;color:#4caf50;cursor:pointer;display:flex;font-size:18px;font-weight:700;height:28px;justify-content:center;margin-left:4px;transition:all .2s ease;width:28px}.terminal-new-tab-btn:hover{background:#333;border-color:#4caf50;transform:scale(1.1)}.terminal-tab-content{flex:1 1;height:100%;min-height:200px}.project-detail-container,.terminal-tab-content{display:flex;flex-direction:column;overflow:hidden;width:100%}.project-detail-container{background:var(--bg-primary);height:calc(100vh - 64px);margin:0;padding:0}.project-detail-header{align-items:center;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);display:flex;flex-shrink:0;gap:20px;padding:16px 24px}.back-button{align-items:center;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:8px 16px;transition:all var(--transition-base)}.back-icon{height:16px;width:16px}.back-button:hover{background:var(--bg-hover);border-color:var(--border-hover);transform:translateX(-2px)}.project-info{flex:1 1}.project-info h1{color:var(--text-primary);font-size:20px;font-weight:600;letter-spacing:-.3px;margin:0}.connection-status{align-items:center;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);display:flex;font-size:13px;font-weight:500;gap:8px;padding:6px 14px}.start-agent-button{background:var(--accent-primary);border:1px solid var(--accent-primary);border-radius:var(--radius-md);color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:8px 16px;transition:all var(--transition-base);white-space:nowrap}.start-agent-button:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover);box-shadow:0 4px 12px rgba(99,102,241,.4);transform:translateY(-1px)}.start-agent-button:disabled{cursor:not-allowed;opacity:.6}.stop-agent-button{background:var(--error);border:1px solid var(--error);border-radius:var(--radius-md);color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:8px 16px;transition:all var(--transition-base);white-space:nowrap}.stop-agent-button:hover:not(:disabled){background:#dc2626;border-color:#dc2626;box-shadow:0 4px 12px rgba(239,68,68,.4);transform:translateY(-1px)}.stop-agent-button:disabled{cursor:not-allowed;opacity:.6}.total-cost{align-items:center;background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.2);border-radius:var(--radius-md);color:var(--success);display:flex;font-size:13px;font-weight:600;gap:8px;padding:6px 14px}.cost-icon{font-size:14px}.cost-label{opacity:.8}.cost-amount{font-weight:700}.status-dot{animation:pulse 2s infinite;border-radius:50%;height:8px;width:8px}.status-dot.connected{background-color:var(--success);box-shadow:0 0 8px rgba(16,185,129,.5)}.status-dot.disconnected{background-color:var(--error);box-shadow:0 0 8px rgba(239,68,68,.5)}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.content-wrapper{border-top:1px solid var(--border-color);display:flex;flex:1 1;gap:0;overflow:hidden}.chat-section{background:var(--bg-secondary);border-right:1px solid var(--border-color);min-width:350px;width:400px}.chat-section,.right-panel{display:flex;flex-direction:column;overflow:hidden}.right-panel{background:var(--bg-primary);flex:1 1}.iframe-section{flex:1 1;min-height:300px}.iframe-section,.preview-section-container{background:var(--bg-primary);display:flex;flex-direction:column;overflow:hidden}.preview-section-container{height:100%}.preview-tabs{align-items:center;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);display:flex;flex-shrink:0;gap:4px;overflow-x:auto;padding:8px 12px}.preview-tabs::-webkit-scrollbar{height:4px}.preview-tabs::-webkit-scrollbar-track{background:var(--bg-secondary)}.preview-tabs::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:2px}.preview-tab{align-items:center;background:var(--bg-tertiary);border:1px solid transparent;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;display:flex;font-size:13px;gap:6px;padding:6px 12px;transition:all var(--transition-base);-webkit-user-select:none;user-select:none;white-space:nowrap}.preview-tab:hover{background:var(--bg-hover);color:var(--text-primary)}.preview-tab.active{background:var(--bg-primary);border-color:var(--accent-primary);color:var(--text-primary)}.preview-tab .tab-icon{align-items:center;color:currentColor;display:flex;flex-shrink:0;height:14px;justify-content:center;width:14px}.preview-tab .tab-icon svg{height:100%;width:100%}.preview-tab .tab-title{font-weight:500}.preview-tab-content{display:flex;flex:1 1;flex-direction:column;height:100%;overflow:hidden;width:100%}.terminal-section{background:var(--bg-primary);border-top:1px solid var(--border-color);height:300px;overflow:hidden;transition:height .3s ease}.terminal-section.collapsed{height:auto;min-height:auto}.port-tabs{background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);display:flex;flex-shrink:0;gap:4px;padding:12px 12px 0}.port-tab-button{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-bottom:none;border-radius:var(--radius-md) var(--radius-md) 0 0;color:var(--text-secondary);cursor:pointer;font-family:SF Mono,Monaco,monospace;font-size:13px;font-weight:500;padding:10px 16px;position:relative;transition:all var(--transition-base)}.port-tab-button:hover{background-color:var(--bg-hover);color:var(--text-primary)}.port-tab-button.active{background-color:var(--bg-primary);border-color:var(--border-color);color:var(--text-primary)}.port-tab-button.active:after{background:var(--accent-primary);border-radius:2px 2px 0 0;bottom:-1px;content:"";height:2px;left:0;position:absolute;right:0}.active-port-input-wrapper,.browser-controls{align-items:center;background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);display:flex;flex-shrink:0;gap:8px;padding:12px}.browser-nav-button{align-items:center;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:flex;flex-shrink:0;justify-content:center;padding:10px 12px;transition:all var(--transition-base)}.browser-nav-button:hover{background-color:var(--bg-hover);border-color:var(--border-hover);color:var(--text-primary)}.browser-nav-button:active{transform:scale(.95)}.browser-icon{height:16px;width:16px}.browser-url-input{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);flex:1 1;font-family:SF Mono,Monaco,monospace;font-size:13px;font-weight:500;outline:none;padding:10px 14px;transition:all var(--transition-base)}.browser-url-input:focus{background-color:var(--bg-elevated);border-color:var(--accent-primary);box-shadow:0 0 0 3px rgba(16,185,129,.1)}.browser-url-input::placeholder{color:var(--text-tertiary);opacity:.6}.active-port-input{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);flex:1 1;font-family:SF Mono,Monaco,monospace;font-size:13px;font-weight:500;outline:none;padding:10px 14px;transition:all var(--transition-base)}.active-port-input:focus{background-color:var(--bg-elevated);border-color:var(--accent-primary);box-shadow:0 0 0 3px rgba(16,185,129,.1)}.active-port-input::placeholder{color:var(--text-tertiary);opacity:.6}.refresh-iframe-button{align-items:center;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:flex;flex-shrink:0;font-size:14px;height:-webkit-fit-content;height:fit-content;justify-content:center;padding:10px 12px;transition:all var(--transition-base)}.refresh-icon{height:16px;width:16px}.refresh-iframe-button:hover{background-color:var(--bg-hover);border-color:var(--border-hover);color:var(--text-primary)}.refresh-iframe-button:hover .refresh-icon{transform:rotate(180deg);transition:transform var(--transition-base)}.refresh-iframe-button:active{transform:scale(.95)}.iframe-container{background:var(--bg-primary);flex:1 1;overflow:hidden;position:relative}.preview-iframe{background:#fff;border:none;height:100%;width:100%}.no-ports-message{align-items:center;color:var(--text-secondary);display:flex;font-size:15px;height:100%;justify-content:center;padding:40px;text-align:center}.messages-container{background-color:var(--bg-secondary);display:flex;flex:1 1;flex-direction:column;gap:12px;overflow-y:auto;padding:20px}.empty-messages{align-items:center;color:var(--text-secondary);display:flex;font-size:15px;height:100%;justify-content:center;padding:40px;text-align:center}.message{word-wrap:break-word;animation:slideIn .3s ease-out;border-radius:var(--radius-lg);margin-bottom:0;max-width:90%;padding:14px 16px}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.user-message{background:var(--text-primary);border-bottom-right-radius:4px;box-shadow:var(--shadow-sm);color:var(--bg-primary);margin-left:auto}.agent-message{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-bottom-left-radius:4px;color:var(--text-primary);margin-right:auto}.tool-use-message{background-color:rgba(16,185,129,.1)!important;border:1px solid rgba(16,185,129,.3)!important;color:var(--accent-primary)}.tool-use-message .message-content{background-color:rgba(16,185,129,.15);border-left:3px solid var(--accent-primary);border-radius:var(--radius-sm);font-family:SF Mono,Monaco,monospace;font-size:13px;padding:8px 12px}.result-success-message{background-color:rgba(16,185,129,.1)!important;border:1px solid rgba(16,185,129,.3)!important;color:var(--success)}.result-success-message .message-content{background-color:rgba(16,185,129,.15);border-left:3px solid var(--success);border-radius:var(--radius-sm);font-family:SF Mono,Monaco,monospace;font-size:14px;font-weight:600;padding:8px 12px}.message-header{font-size:11px;gap:8px;justify-content:space-between;margin-bottom:8px;opacity:.8}.message-header,.message-role{align-items:center;display:flex}.message-role{font-size:10px;font-weight:600;gap:6px;letter-spacing:.5px;text-transform:uppercase}.result-icon{color:var(--success);height:12px;width:12px}.message-time{font-size:10px;opacity:.7}.message-content{word-wrap:break-word;font-size:14px;line-height:1.6}.message-form{background-color:var(--bg-secondary);border-top:1px solid var(--border-color);display:flex;flex-shrink:0;gap:10px;padding:16px}.message-input{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-primary);flex:1 1;font-size:14px;padding:12px 16px;transition:all var(--transition-base)}.message-input:focus{background:var(--bg-elevated);border-color:var(--text-primary);box-shadow:0 0 0 3px hsla(0,0%,100%,.1);outline:none}.message-input:disabled{background-color:var(--bg-tertiary);cursor:not-allowed;opacity:.5}.message-input::placeholder{color:var(--text-tertiary)}.send-button{align-items:center;background:var(--text-primary);border:none;border-radius:var(--radius-md);box-shadow:0 1px 2px rgba(0,0,0,.1);color:var(--bg-primary);cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:12px 28px;transition:all var(--transition-base);white-space:nowrap}.send-icon{height:18px;width:18px}.send-button:hover:not(:disabled){background:var(--text-secondary);box-shadow:0 4px 12px rgba(0,0,0,.15);transform:translateY(-1px)}.send-button:active:not(:disabled){box-shadow:0 1px 2px rgba(0,0,0,.1);transform:translateY(0)}.send-button:disabled{background:var(--text-tertiary);cursor:not-allowed;opacity:.4;transform:none}.error-state{padding:100px 20px;text-align:center}.error-state h2{color:var(--error);margin-bottom:10px}.error-state p{color:var(--text-secondary);margin-bottom:20px}.error-state button{background:var(--text-primary);border:none;border-radius:var(--radius-md);color:var(--bg-primary);cursor:pointer;font-size:16px;font-weight:600;padding:12px 24px;transition:all var(--transition-base)}.error-state button:hover{background:var(--text-secondary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.error-message{background-color:rgba(239,68,68,.1);border-radius:var(--radius-md);color:var(--error);font-size:14px;margin:16px 24px;padding:12px 16px}.messages-container::-webkit-scrollbar{width:6px}.messages-container::-webkit-scrollbar-track{background:transparent}.messages-container::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:3px}.messages-container::-webkit-scrollbar-thumb:hover{background:var(--bg-hover)}.json-popup-overlay{align-items:center;animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:rgba(0,0,0,.8);bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.json-popup{animation:slideUp .3s ease-out;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;max-height:80vh;max-width:800px;width:90%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.json-popup-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:20px}.json-popup-header h3{color:var(--text-primary);font-size:18px;font-weight:600;margin:0}.close-button{align-items:center;background:none;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;display:flex;height:32px;justify-content:center;padding:0;transition:all var(--transition-base);width:32px}.close-icon{height:20px;width:20px}.close-button:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.json-content{background-color:var(--bg-primary);border-bottom-left-radius:var(--radius-xl);border-bottom-right-radius:var(--radius-xl);color:var(--text-primary);flex:1 1;font-family:SF Mono,Monaco,monospace;font-size:13px;line-height:1.6;margin:0;overflow:auto;padding:20px}.json-content::-webkit-scrollbar{height:8px;width:8px}.json-content::-webkit-scrollbar-track{background:var(--bg-secondary)}.json-content::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:4px}.json-content::-webkit-scrollbar-thumb:hover{background:var(--bg-hover)}.view-json-button{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;font-size:11px;font-weight:600;padding:4px 10px;transition:all var(--transition-base)}.view-json-button:hover{background-color:var(--bg-hover);border-color:var(--border-hover);color:var(--text-primary)}.agent-message .view-json-button{background-color:var(--bg-tertiary);border-color:var(--border-color);color:var(--text-secondary)}.user-message .view-json-button{background-color:hsla(0,0%,100%,.2);border-color:hsla(0,0%,100%,.4);color:#fff}.user-message .view-json-button:hover{background-color:hsla(0,0%,100%,.3);border-color:#fff}.admin-dashboard{background:#0a0a0f;background:var(--bg-primary,#0a0a0f);min-height:calc(100vh - 64px);overflow-y:auto;padding:24px;width:100%}.admin-dashboard-container{margin:0 auto;max-width:1400px}.admin-header{margin-bottom:32px}.admin-header h1{color:#fff;color:var(--text-primary,#fff);font-size:32px;font-weight:600;margin:0 0 8px}.admin-subtitle{color:#a0a0a0;color:var(--text-secondary,#a0a0a0);font-size:16px;margin:0}.admin-tabs{border-bottom:1px solid #2a2a3a;border-bottom:1px solid var(--border-color,#2a2a3a);display:flex;gap:8px;margin-bottom:24px}.tab-button{background:transparent;border:none;border-bottom:2px solid transparent;color:#a0a0a0;color:var(--text-secondary,#a0a0a0);cursor:pointer;font-size:14px;font-weight:500;margin-bottom:-1px;padding:12px 24px;transition:all .2s}.tab-button:hover{background:#1a1a28;background:var(--bg-tertiary,#1a1a28);color:#fff;color:var(--text-primary,#fff)}.tab-button.active{border-bottom-color:#6366f1;border-bottom-color:var(--accent-color,#6366f1);color:#6366f1;color:var(--accent-color,#6366f1)}.error-message{align-items:center;background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#fca5a5;display:flex;gap:16px;justify-content:space-between;margin-bottom:24px;padding:16px}.retry-button{background:rgba(239,68,68,.2);border:1px solid rgba(239,68,68,.4);border-radius:6px;color:#fca5a5;cursor:pointer;font-size:14px;padding:8px 16px;transition:all .2s}.retry-button:hover{background:rgba(239,68,68,.3);border-color:rgba(239,68,68,.5)}.users-table-container{background:#141420;background:var(--bg-secondary,#141420);border:1px solid #2a2a3a;border:1px solid var(--border-color,#2a2a3a);border-radius:12px;margin-bottom:24px;overflow:hidden}.table-header{background:#1a1a28;background:var(--bg-tertiary,#1a1a28);border-bottom:1px solid #2a2a3a;border-bottom:1px solid var(--border-color,#2a2a3a)}.table-header-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:2fr 1.5fr 1.5fr .8fr 1.5fr 1fr;padding:16px 20px}.table-body{max-height:600px;overflow-y:auto}.table-row{grid-gap:16px;border-bottom:1px solid #2a2a3a;border-bottom:1px solid var(--border-color,#2a2a3a);display:grid;gap:16px;grid-template-columns:2fr 1.5fr 1.5fr .8fr 1.5fr 1fr;padding:16px 20px;transition:background .2s}.table-row:hover{background:#1a1a28;background:var(--bg-tertiary,#1a1a28)}.table-row:last-child{border-bottom:none}.table-cell{align-items:center;color:#fff;color:var(--text-primary,#fff);display:flex;font-size:14px;gap:8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-cell{font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.header-cell,.text-muted{color:#a0a0a0;color:var(--text-secondary,#a0a0a0)}.text-muted{font-style:italic}.role-badges-container{align-items:center;display:flex;flex-wrap:wrap;gap:6px}.role-badge{border-radius:12px;display:inline-block;font-size:12px;font-weight:500;letter-spacing:.5px;padding:4px 12px;text-transform:uppercase;white-space:nowrap}.role-badge.admin{background:rgba(99,102,241,.2);border:1px solid rgba(99,102,241,.3);color:#818cf8}.role-badge.user{background:rgba(34,197,94,.2);border:1px solid rgba(34,197,94,.3);color:#4ade80}.empty-state{color:#a0a0a0;color:var(--text-secondary,#a0a0a0);padding:60px 20px;text-align:center}.admin-stats{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:24px}.stat-card{background:#141420;background:var(--bg-secondary,#141420);border:1px solid #2a2a3a;border:1px solid var(--border-color,#2a2a3a);border-radius:12px;padding:24px;text-align:center;transition:transform .2s,box-shadow .2s}.stat-card:hover{box-shadow:0 4px 12px rgba(0,0,0,.3);transform:translateY(-2px)}.stat-value{color:#6366f1;color:var(--accent-color,#6366f1);font-size:36px;font-weight:700;margin-bottom:8px}.stat-label{color:#a0a0a0;color:var(--text-secondary,#a0a0a0);font-size:14px;letter-spacing:.5px;text-transform:uppercase}.table-body::-webkit-scrollbar{width:8px}.table-body::-webkit-scrollbar-track{background:#1a1a28;background:var(--bg-tertiary,#1a1a28)}.table-body::-webkit-scrollbar-thumb{background:#2a2a3a;background:var(--border-color,#2a2a3a);border-radius:4px}.table-body::-webkit-scrollbar-thumb:hover{background:#a0a0a0;background:var(--text-secondary,#a0a0a0)}.projects-table-container{background:#141420;background:var(--bg-secondary,#141420);border:1px solid #2a2a3a;border:1px solid var(--border-color,#2a2a3a);border-radius:12px;margin-bottom:24px;overflow:hidden}.projects-header,.projects-table-container .table-row{grid-template-columns:2fr 1.5fr 1fr 2fr 1.5fr}.project-url-link{color:#6366f1;color:var(--accent-color,#6366f1);display:block;max-width:100%;overflow:hidden;text-decoration:none;text-overflow:ellipsis;transition:color .2s;white-space:nowrap}.project-url-link:hover{color:#818cf8;text-decoration:underline}.clickable-row{cursor:pointer}.clickable-row:hover{background:#1f1f2e!important;background:var(--bg-hover,#1f1f2e)!important}.status-badge{border-radius:12px;display:inline-block;font-size:12px;font-weight:500;letter-spacing:.5px;padding:4px 12px;text-transform:uppercase}.status-badge.online{background:rgba(34,197,94,.2);border:1px solid rgba(34,197,94,.3);color:#4ade80}.status-badge.starting{background:rgba(251,191,36,.2);border:1px solid rgba(251,191,36,.3);color:#fbbf24}.status-badge.offline{background:rgba(156,163,175,.2);border:1px solid rgba(156,163,175,.3);color:#9ca3af}.load-more-container{border-top:1px solid #2a2a3a;border-top:1px solid var(--border-color,#2a2a3a);padding:20px;text-align:center}.load-more-button{background:#1a1a28;background:var(--bg-tertiary,#1a1a28);border:1px solid #2a2a3a;border:1px solid var(--border-color,#2a2a3a);border-radius:8px;color:#fff;color:var(--text-primary,#fff);cursor:pointer;font-size:14px;font-weight:500;padding:10px 24px;transition:all .2s}.load-more-button:hover:not(:disabled){background:#1f1f2e;background:var(--bg-hover,#1f1f2e);border-color:#3a3a4a;border-color:var(--border-hover,#3a3a4a)}.load-more-button:disabled{cursor:not-allowed;opacity:.5}.edit-roles-button-small{background:#1a1a28;background:var(--bg-tertiary,#1a1a28);border:1px solid #2a2a3a;border:1px solid var(--border-color,#2a2a3a);border-radius:6px;color:#fff;color:var(--text-primary,#fff);cursor:pointer;font-size:12px;font-weight:500;padding:6px 12px;transition:all .2s}.edit-roles-button-small:hover{background:#1f1f2e;background:var(--bg-hover,#1f1f2e);border-color:#6366f1;border-color:var(--accent-color,#6366f1);color:#6366f1;color:var(--accent-color,#6366f1)}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:rgba(0,0,0,.7);bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{animation:modalSlideIn .2s ease-out;background:#141420;background:var(--bg-secondary,#141420);border:1px solid #2a2a3a;border:1px solid var(--border-color,#2a2a3a);border-radius:12px;box-shadow:0 20px 25px -5px rgba(0,0,0,.3),0 10px 10px -5px rgba(0,0,0,.2);max-height:90vh;max-width:500px;overflow-y:auto;width:90%}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{align-items:center;border-bottom:1px solid #2a2a3a;border-bottom:1px solid var(--border-color,#2a2a3a);display:flex;justify-content:space-between;padding:20px 24px}.modal-header h2{color:#fff;color:var(--text-primary,#fff);font-size:20px;font-weight:600;margin:0}.modal-close{align-items:center;background:transparent;border:none;border-radius:6px;color:#a0a0a0;color:var(--text-secondary,#a0a0a0);cursor:pointer;display:flex;font-size:28px;height:32px;justify-content:center;line-height:1;padding:0;transition:all .2s;width:32px}.modal-close:hover{background:#1a1a28;background:var(--bg-tertiary,#1a1a28);color:#fff;color:var(--text-primary,#fff)}.modal-body{padding:24px}.modal-user-info{border-bottom:1px solid #2a2a3a;border-bottom:1px solid var(--border-color,#2a2a3a);margin-bottom:24px;padding-bottom:20px}.modal-user-info p{color:#fff;color:var(--text-primary,#fff);font-size:14px;margin:8px 0}.modal-user-info strong{color:#a0a0a0;color:var(--text-secondary,#a0a0a0);margin-right:8px}.role-editor{display:flex;flex-direction:column;gap:16px}.role-editor-label{color:#fff;color:var(--text-primary,#fff);font-size:14px;font-weight:600;margin-bottom:4px}.role-checkboxes{display:flex;flex-direction:column;gap:12px}.role-checkbox{align-items:center;border-radius:6px;color:#fff;color:var(--text-primary,#fff);cursor:pointer;display:flex;font-size:14px;gap:12px;padding:8px;transition:background .2s}.role-checkbox:hover{background:#1a1a28;background:var(--bg-tertiary,#1a1a28)}.role-checkbox input[type=checkbox]{accent-color:#6366f1;accent-color:var(--accent-color,#6366f1);cursor:pointer;height:18px;width:18px}.role-checkbox input[type=checkbox]:disabled{cursor:not-allowed;opacity:.5}.modal-footer{border-top:1px solid #2a2a3a;border-top:1px solid var(--border-color,#2a2a3a);display:flex;gap:12px;justify-content:flex-end;padding:20px 24px}.cancel-roles-button,.save-roles-button{border:1px solid;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s}.save-roles-button{background:#6366f1;background:var(--accent-color,#6366f1);border-color:#6366f1;border-color:var(--accent-color,#6366f1);color:#fff}.save-roles-button:hover:not(:disabled){background:#818cf8;border-color:#818cf8}.save-roles-button:disabled{cursor:not-allowed;opacity:.5}.cancel-roles-button{background:transparent;border-color:#2a2a3a;border-color:var(--border-color,#2a2a3a);color:#a0a0a0;color:var(--text-secondary,#a0a0a0)}.cancel-roles-button:hover:not(:disabled){background:#1a1a28;background:var(--bg-tertiary,#1a1a28);border-color:#3a3a4a;border-color:var(--border-hover,#3a3a4a);color:#fff;color:var(--text-primary,#fff)}.cancel-roles-button:disabled{cursor:not-allowed;opacity:.5}.vms-header-actions{display:flex;justify-content:flex-end;margin-bottom:24px}.create-vm-button{background:#6366f1;background:var(--accent-color,#6366f1);border:1px solid #6366f1;border:1px solid var(--accent-color,#6366f1);border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s}.create-vm-button:hover{background:#818cf8;border-color:#818cf8}.vms-container{grid-gap:24px;display:grid;gap:24px;grid-template-columns:400px 1fr;min-height:600px}.vms-list{display:flex;flex-direction:column;gap:16px;max-height:calc(100vh - 200px);overflow-y:auto}.vm-card{background:#141420;background:var(--bg-secondary,#141420);border:1px solid #2a2a3a;border:1px solid var(--border-color,#2a2a3a);border-radius:12px;cursor:pointer;padding:16px;transition:all .2s}.vm-card:hover{box-shadow:0 4px 12px rgba(0,0,0,.3);transform:translateY(-2px)}.vm-card.selected,.vm-card:hover{border-color:#6366f1;border-color:var(--accent-color,#6366f1)}.vm-card.selected{background:#1a1a28;background:var(--bg-tertiary,#1a1a28)}.vm-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.vm-card-header h3{color:#fff;color:var(--text-primary,#fff);font-size:16px;font-weight:600;margin:0}.vm-card-actions{display:flex;gap:8px}.delete-vm-button,.edit-vm-button{border:1px solid;border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;padding:4px 12px;transition:all .2s}.edit-vm-button{background:transparent;border-color:#2a2a3a;border-color:var(--border-color,#2a2a3a);color:#a0a0a0;color:var(--text-secondary,#a0a0a0)}.edit-vm-button:hover{background:#1a1a28;background:var(--bg-tertiary,#1a1a28);border-color:#6366f1;border-color:var(--accent-color,#6366f1);color:#6366f1;color:var(--accent-color,#6366f1)}.delete-vm-button{background:transparent;border-color:rgba(239,68,68,.3);color:#fca5a5}.delete-vm-button:hover{background:rgba(239,68,68,.1);border-color:rgba(239,68,68,.5);color:#f87171}.vm-card-body{display:flex;flex-direction:column;gap:12px}.vm-info-row{align-items:center;display:flex;font-size:13px;gap:8px}.vm-info-label{color:#a0a0a0;color:var(--text-secondary,#a0a0a0);font-weight:500}.vm-key{font-size:11px;padding:4px 8px}.vm-key,.vm-key-full{background:#1a1a28;background:var(--bg-tertiary,#1a1a28);border:1px solid #2a2a3a;border:1px solid var(--border-color,#2a2a3a);border-radius:4px;color:#6366f1;color:var(--accent-color,#6366f1);font-family:monospace;word-break:break-all}.vm-key-full{display:block;font-size:12px;margin-top:8px;padding:8px}.vm-stats-preview{border-top:1px solid #2a2a3a;border-top:1px solid var(--border-color,#2a2a3a);display:flex;flex-direction:column;gap:8px;padding-top:12px}.vm-stat-item{display:flex;font-size:13px;justify-content:space-between}.vm-stat-label{color:#a0a0a0;color:var(--text-secondary,#a0a0a0)}.vm-stat-value{color:#fff;color:var(--text-primary,#fff);font-weight:500}.vm-no-stats{border-top:1px solid #2a2a3a;border-top:1px solid var(--border-color,#2a2a3a);padding-top:12px}.vm-no-stats p{color:#a0a0a0;color:var(--text-secondary,#a0a0a0);font-size:12px;font-style:italic;margin:0}.vm-details{background:#141420;background:var(--bg-secondary,#141420);border:1px solid #2a2a3a;border:1px solid var(--border-color,#2a2a3a);border-radius:12px;max-height:calc(100vh - 200px);overflow-y:auto;padding:24px}.vm-details-header{align-items:center;border-bottom:1px solid #2a2a3a;border-bottom:1px solid var(--border-color,#2a2a3a);display:flex;justify-content:space-between;margin-bottom:24px;padding-bottom:16px}.vm-details-header h2{color:#fff;color:var(--text-primary,#fff);font-size:24px;font-weight:600;margin:0}.close-details-button{align-items:center;background:transparent;border:none;border-radius:6px;color:#a0a0a0;color:var(--text-secondary,#a0a0a0);cursor:pointer;display:flex;font-size:28px;height:32px;justify-content:center;line-height:1;padding:0;transition:all .2s;width:32px}.close-details-button:hover{background:#1a1a28;background:var(--bg-tertiary,#1a1a28);color:#fff;color:var(--text-primary,#fff)}.vm-details-content{display:flex;flex-direction:column;gap:32px}.vm-graphs-section h3,.vm-limits-section h3{color:#fff;color:var(--text-primary,#fff);font-size:18px;font-weight:600;margin:0 0 16px}.vm-limits-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.vm-limit-item{background:#1a1a28;background:var(--bg-tertiary,#1a1a28);border:1px solid #2a2a3a;border:1px solid var(--border-color,#2a2a3a);border-radius:8px;display:flex;flex-direction:column;gap:8px;padding:16px}.vm-limit-label{color:#a0a0a0;color:var(--text-secondary,#a0a0a0);font-size:12px;letter-spacing:.5px;text-transform:uppercase}.vm-limit-value{color:#6366f1;color:var(--accent-color,#6366f1);font-size:20px;font-weight:600}.vm-graphs{display:flex;flex-direction:column;gap:32px}.vm-graph h4{color:#fff;color:var(--text-primary,#fff);font-size:14px;font-weight:600;margin:0 0 12px}.vm-graph-container{background:#1a1a28;background:var(--bg-tertiary,#1a1a28);border:1px solid #2a2a3a;border:1px solid var(--border-color,#2a2a3a);border-radius:8px;padding:16px;position:relative}.vm-graph-svg{display:block;height:200px;width:100%}.vm-graph-labels{color:#a0a0a0;color:var(--text-secondary,#a0a0a0);display:flex;font-size:11px;justify-content:space-between;margin-top:8px}.vm-graph-tooltip{pointer-events:none;position:absolute;transform:translateX(-50%);white-space:nowrap;z-index:1000}.vm-graph-tooltip-content{background:#0f0f1a;background:var(--bg-primary,#0f0f1a);border:1px solid #2a2a3a;border:1px solid var(--border-color,#2a2a3a);border-radius:6px;box-shadow:0 4px 12px rgba(0,0,0,.5);min-width:180px;opacity:1;padding:8px 12px}.vm-graph-tooltip-time{color:#a0a0a0;color:var(--text-secondary,#a0a0a0);font-size:11px;margin-bottom:4px}.vm-graph-tooltip-value{color:#fff;color:var(--text-primary,#fff);font-size:13px;font-weight:600}.vm-no-stats-details{color:#a0a0a0;color:var(--text-secondary,#a0a0a0);padding:40px;text-align:center}.vm-key-display{border-top:1px solid #2a2a3a;border-top:1px solid var(--border-color,#2a2a3a);margin-top:16px;padding-top:16px}.vm-key-display label{color:#fff;color:var(--text-primary,#fff);display:block;font-size:14px;font-weight:600;margin-bottom:8px}.form-group{margin-bottom:20px}.form-group label{display:block;font-weight:500;margin-bottom:8px}.form-group label,.form-input{color:#fff;color:var(--text-primary,#fff);font-size:14px}.form-input{background:#1a1a28;background:var(--bg-tertiary,#1a1a28);border:1px solid #2a2a3a;border:1px solid var(--border-color,#2a2a3a);border-radius:6px;padding:10px 12px;transition:all .2s;width:100%}.form-input:focus{border-color:#6366f1;border-color:var(--accent-color,#6366f1);box-shadow:0 0 0 3px rgba(99,102,241,.1);outline:none}.form-input::placeholder{color:#a0a0a0;color:var(--text-secondary,#a0a0a0)}@media (max-width:1024px){.vms-container{grid-template-columns:1fr}.vm-details{max-height:none}.table-header-row,.table-row{gap:12px;grid-template-columns:2fr 1fr 1.5fr .8fr 1.2fr 1fr;grid-template-columns:2fr 1fr 1fr .8fr 1.2fr;padding:12px 16px}}@media (max-width:768px){.admin-dashboard{padding:16px}.admin-tabs{flex-direction:column;gap:0}.tab-button{border-bottom:1px solid #2a2a3a;border-bottom:1px solid var(--border-color,#2a2a3a);border-left:2px solid transparent;border-right:none;margin-bottom:0}.tab-button.active{border-bottom-color:#2a2a3a;border-bottom-color:var(--border-color,#2a2a3a);border-left-color:#6366f1;border-left-color:var(--accent-color,#6366f1)}.table-header-row,.table-row{gap:8px;grid-template-columns:1fr}.projects-header{grid-template-columns:1fr}.header-cell{display:none}.table-cell:before{color:#a0a0a0;color:var(--text-secondary,#a0a0a0);content:attr(data-label);font-size:11px;font-weight:600;margin-right:8px;text-transform:uppercase}.admin-stats{grid-template-columns:1fr}}.App{background:var(--bg-primary);color:var(--text-primary);min-height:100vh}
/*# sourceMappingURL=main.eac0fd5c.css.map*/