html,body,#root{width:100%;height:100%;margin:0;padding:0;overflow:hidden}body{color:#d4d4d4;background:#1e1e1e;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif}.env-vars-manager{background:#252526;border-radius:6px;overflow:hidden}.env-vars-header{border-bottom:1px solid #3c3c3c;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.env-vars-header h3{color:#ddd;margin:0;font-size:13px;font-weight:600}.env-vars-actions{gap:8px;display:flex}.preset-btn,.add-btn{cursor:pointer;border-radius:4px;align-items:center;gap:4px;padding:4px 10px;font-size:12px;transition:all .15s;display:flex}.preset-btn{color:#ccc;background:#3c3c3c;border:1px solid #555}.preset-btn:hover{color:#fff;background:#4c4c4c}.add-btn{color:#fff;background:#0e639c;border:none}.presets-panel{background:#2d2d2d;border-bottom:1px solid #3c3c3c;padding:8px}.presets-header{color:#969696;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:12px;display:flex}.presets-header button{color:#969696;cursor:pointer;background:0 0;border:none;align-items:center;display:flex}.presets-grid{grid-template-columns:repeat(4,1fr);gap:6px;display:grid}.preset-item{color:#ccc;cursor:pointer;background:#3c3c3c;border:1px solid #4c4c4c;border-radius:4px;align-items:center;gap:6px;padding:8px;font-size:11px;transition:all .15s;display:flex}.preset-item:hover{color:#fff;background:#4c4c4c;border-color:#5c5c5c}.preset-item:disabled{opacity:.5;cursor:not-allowed}.env-vars-error{color:#f48771;background:#5a1d1d;border-left:3px solid #f48771;justify-content:space-between;align-items:center;padding:8px 12px;font-size:12px;display:flex}.env-vars-error button{color:#f48771;cursor:pointer;background:0 0;border:none;align-items:center;display:flex}.env-var-form,.env-var-edit-form{background:#2d2d2d;border-bottom:1px solid #3c3c3c;padding:12px}.form-row{align-items:center;gap:8px;margin-bottom:8px;display:flex}.form-row:last-child{margin-bottom:0}.key-input,.value-input{color:#d4d4d4;background:#3c3c3c;border:1px solid #555;border-radius:3px;outline:none;flex:1;padding:6px 10px;font-family:SF Mono,Monaco,Courier New,monospace;font-size:13px}.key-input{text-transform:uppercase;flex:.4}.key-input:focus,.value-input:focus{border-color:#007acc}.value-input{flex:.6}.secret-toggle{color:#969696;cursor:pointer;align-items:center;gap:6px;margin-right:auto;font-size:12px;display:flex}.secret-toggle input{accent-color:#007acc}.form-actions{gap:4px;display:flex}.cancel-btn,.save-btn{cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:6px;transition:all .15s;display:flex}.cancel-btn{color:#969696}.cancel-btn:hover{color:#ccc;background:#3c3c3c}.save-btn{color:#fff;background:#0e639c}.save-btn:hover{background:#17b}.env-vars-list{max-height:400px;overflow-y:auto}.env-vars-loading,.env-vars-empty{color:#969696;flex-direction:column;justify-content:center;align-items:center;padding:40px;display:flex}.env-vars-empty p{margin:8px 0 0;font-size:13px}.env-vars-empty .hint{color:#6e6e6e;font-size:12px}.env-var-item{border-bottom:1px solid #3c3c3c;justify-content:space-between;align-items:center;padding:10px 16px;transition:background .1s;display:flex}.env-var-item:hover{background:#2a2d2e}.env-var-item.editing{background:#2d2d2d}.env-var-key{color:#9cdcfe;flex:.4;align-items:center;gap:8px;min-width:0;font-family:SF Mono,Monaco,Courier New,monospace;font-size:13px;display:flex}.lock-icon{color:#ce9178}.key-icon{color:#ccc}.env-var-value{flex:.6;align-items:center;gap:8px;min-width:0;display:flex}.env-var-value .value-text{color:#ce9178;text-overflow:ellipsis;white-space:nowrap;flex:1;font-family:SF Mono,Monaco,Courier New,monospace;font-size:12px;overflow:hidden}.env-var-controls{opacity:0;gap:4px;transition:opacity .15s;display:flex}.env-var-item:hover .env-var-controls{opacity:1}.reveal-btn,.edit-btn,.delete-btn{color:#969696;cursor:pointer;background:0 0;border:none;border-radius:3px;justify-content:center;align-items:center;padding:4px;transition:all .15s;display:flex}.reveal-btn:hover,.edit-btn:hover{color:#fff;background:#3c3c3c}.delete-btn:hover{color:#f48771;background:#5a1d1d}.account-manager{color:#e0e0e0;padding:1rem}.account-loading{color:#888;align-items:center;gap:.5rem;padding:2rem;display:flex}.account-header{border-bottom:1px solid #333;align-items:center;gap:.75rem;margin-bottom:1rem;padding-bottom:1rem;display:flex}.account-header h2{flex:1;margin:0;font-size:1.1rem}.plan-badge{color:#888;background:#333;border-radius:4px;padding:.2rem .5rem;font-size:.7rem}.plan-badge.free{color:#a0aec0;background:#2d3748}.plan-badge.pro{color:#48bb78;background:#1a472a}.account-tabs{gap:.25rem;margin-bottom:1rem;display:flex}.account-tabs .tab{color:#888;cursor:pointer;background:#252525;border:none;border-radius:6px;flex:1;justify-content:center;align-items:center;gap:.5rem;padding:.5rem;font-size:.85rem;transition:all .2s;display:flex}.account-tabs .tab:hover{background:#333}.account-tabs .tab.active{color:#6366f1;background:#1a1a2e}.account-tabs .tab .count{background:#333;border-radius:10px;padding:.1rem .4rem;font-size:.75rem}.tab-content{flex-direction:column;gap:1rem;display:flex}.form-group{flex-direction:column;gap:.5rem;display:flex}.form-group label{color:#888;font-size:.85rem}.form-group input[type=text],.form-group input[type=email],.form-group select{color:#e0e0e0;background:#1a1a1a;border:1px solid #333;border-radius:6px;padding:.6rem;font-size:.9rem}.form-group input:focus,.form-group select:focus{border-color:#6366f1;outline:none}.plan-info{background:#1a1a1a;border-radius:6px;padding:.75rem}.plan-info span{font-size:.9rem}.plan-info .hint{color:#666;margin:.5rem 0 0;font-size:.8rem}.save-btn{color:#fff;cursor:pointer;background:#6366f1;border:none;border-radius:6px;padding:.6rem 1rem;font-size:.9rem;transition:background .2s}.save-btn:hover:not(:disabled){background:#4f46e5}.save-btn:disabled{opacity:.5;cursor:not-allowed}.invite-form{background:#1a1a1a;border-radius:8px;padding:1rem}.invite-form h3{color:#ccc;margin:0 0 .75rem;font-size:.95rem}.invite-form .form-row{gap:.5rem;margin-bottom:.5rem;display:flex}.invite-form input{color:#e0e0e0;background:#252525;border:1px solid #333;border-radius:4px;flex:1;padding:.5rem;font-size:.85rem}.invite-form select{color:#e0e0e0;background:#252525;border:1px solid #333;border-radius:4px;padding:.5rem;font-size:.85rem}.invite-form button{color:#fff;cursor:pointer;background:#22c55e;border:none;border-radius:4px;align-items:center;gap:.3rem;padding:.5rem .75rem;font-size:.85rem;display:flex}.invite-form button:disabled{opacity:.5;cursor:not-allowed}.team-list{margin-top:.5rem}.team-list h3{color:#ccc;margin:0 0 .75rem;font-size:.95rem}.team-list .empty{text-align:center;color:#666;padding:1rem;font-size:.85rem}.team-list ul{margin:0;padding:0;list-style:none}.team-member{background:#1a1a1a;border-radius:6px;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding:.75rem;display:flex}.team-member .member-info{align-items:center;gap:.5rem;display:flex}.team-member .member-info>div{flex-direction:column;display:flex}.team-member .member-info strong{font-size:.9rem}.team-member .member-info span{color:#666;font-size:.8rem}.team-member .member-actions{align-items:center;gap:.5rem;display:flex}.team-member .member-actions select{color:#e0e0e0;background:#252525;border:1px solid #333;border-radius:4px;padding:.3rem .5rem;font-size:.8rem}.team-member .remove-btn{color:#888;cursor:pointer;background:0 0;border:1px solid #444;border-radius:4px;padding:.3rem .5rem;transition:all .2s}.team-member .remove-btn:hover{color:#fca5a5;background:#7f1d1d;border-color:#dc2626}.schema-builder{color:#e0e0e0;height:100%;padding:1rem;overflow-y:auto}.schema-header{border-bottom:1px solid #333;align-items:center;gap:.5rem;margin-bottom:1rem;padding-bottom:.75rem;display:flex}.schema-header h2{margin:0;font-size:1rem}.schema-ai-section{background:#1a1a1a;border-radius:8px;margin-bottom:1rem;padding:1rem}.schema-ai-section h3{color:#ccc;margin:0 0 .5rem;font-size:.95rem}.schema-ai-section .hint{color:#666;margin:0 0 .75rem;font-size:.8rem}.schema-ai-section textarea{color:#e0e0e0;resize:vertical;background:#252525;border:1px solid #333;border-radius:6px;width:100%;margin-bottom:.75rem;padding:.75rem;font-size:.85rem}.schema-ai-section textarea:focus{border-color:#6366f1;outline:none}.generate-btn{color:#fff;cursor:pointer;background:#6366f1;border:none;border-radius:6px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.85rem;display:flex}.generate-btn:hover:not(:disabled){background:#4f46e5}.generate-btn:disabled{opacity:.5;cursor:not-allowed}.schema-tables-section{flex:1}.tables-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.tables-header h3{color:#ccc;margin:0;font-size:.95rem}.tables-actions{gap:.5rem;display:flex}.add-table-btn,.export-btn{color:#ccc;cursor:pointer;background:#2d2d2d;border:1px solid #444;border-radius:4px;align-items:center;gap:.3rem;padding:.35rem .6rem;font-size:.8rem;display:flex}.add-table-btn:hover,.export-btn:hover{background:#3d3d3d}.empty-tables{color:#666;text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:2rem;display:flex}.empty-tables p{margin:.5rem 0 0;font-size:.9rem}.empty-tables .hint{font-size:.8rem}.tables-list{flex-direction:column;gap:.75rem;display:flex}.table-card{background:#1a1a1a;border-radius:8px;overflow:hidden}.table-header{background:#252525;border-bottom:1px solid #333;align-items:center;gap:.5rem;padding:.75rem;display:flex}.table-name{flex:1;font-size:.9rem;font-weight:600}.column-count{color:#666;font-size:.75rem}.table-actions{gap:.25rem;display:flex}.table-actions button{color:#888;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.25rem .4rem}.table-actions button:hover{color:#ccc;background:#333}.table-actions button.delete:hover{color:#fca5a5;background:#7f1d1d}.columns-list{padding:.5rem}.column-item{background:#1a1a1a;border-radius:4px;align-items:center;gap:.5rem;margin-bottom:.25rem;padding:.4rem .5rem;font-size:.85rem;display:flex}.col-name{color:#e0e0e0;font-family:monospace}.col-type{color:#6366f1;font-family:monospace;font-size:.8rem}.col-badge{border-radius:3px;padding:.1rem .3rem;font-size:.65rem;font-weight:600}.col-badge.pk{color:#48bb78;background:#1a472a}.col-badge.nullable{color:#a0aec0;background:#2d3748}.remove-col{color:#666;cursor:pointer;background:0 0;border:none;border-radius:3px;margin-left:auto;padding:.15rem .3rem}.remove-col:hover{color:#fca5a5;background:#7f1d1d}.no-columns{text-align:center;color:#666;padding:.5rem;font-size:.8rem}.automation-builder{color:#e0e0e0;height:100%;padding:1rem;overflow-y:auto}.automation-header{border-bottom:1px solid #333;align-items:center;gap:.5rem;margin-bottom:1rem;padding-bottom:.75rem;display:flex}.automation-header h2{flex:1;margin:0;font-size:1rem}.add-btn{color:#fff;cursor:pointer;background:#6366f1;border:none;border-radius:6px;align-items:center;gap:.3rem;padding:.4rem .6rem;font-size:.8rem;display:flex}.add-btn:hover{background:#4f46e5}.automation-editor{background:#1a1a1a;border-radius:8px;margin-bottom:1rem;padding:1rem}.automation-editor h3{color:#ccc;margin:0 0 1rem;font-size:.95rem}.automation-editor .form-group{margin-bottom:.75rem}.automation-editor label{color:#888;margin-bottom:.3rem;font-size:.8rem;display:block}.automation-editor input,.automation-editor select{color:#e0e0e0;background:#252525;border:1px solid #333;border-radius:6px;width:100%;padding:.5rem;font-size:.85rem}.automation-editor .form-row{gap:.75rem;display:flex}.automation-editor .form-row .form-group{flex:1}.editor-actions{gap:.5rem;margin-top:1rem;display:flex}.create-btn{color:#fff;cursor:pointer;background:#22c55e;border:none;border-radius:6px;padding:.5rem 1rem;font-size:.85rem}.cancel-btn{color:#ccc;cursor:pointer;background:#444;border:none;border-radius:6px;padding:.5rem 1rem;font-size:.85rem}.automations-list{flex-direction:column;gap:.75rem;display:flex}.empty{color:#666;text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:2rem;display:flex}.empty p{margin:.5rem 0 0}.empty .hint{font-size:.8rem}.automation-card{background:#1a1a1a;border:1px solid #333;border-radius:8px;overflow:hidden}.automation-card.enabled{border-color:#22c55e33}.automation-card.disabled{opacity:.7}.automation-main{align-items:center;gap:1rem;padding:.75rem;display:flex}.automation-info{flex:1}.automation-name{align-items:center;gap:.5rem;font-size:.9rem;font-weight:600;display:flex}.automation-desc{color:#666;margin-top:.25rem;font-size:.8rem}.status-icon.active{color:#22c55e}.status-icon.paused{color:#f59e0b}.status-icon.error{color:#ef4444}.automation-flow{background:#252525;border-radius:6px;align-items:center;gap:.5rem;padding:.4rem .6rem;font-size:.8rem;display:flex}.flow-trigger,.flow-action{color:#888;align-items:center;gap:.3rem;display:flex}.flow-arrow{color:#555}.automation-actions{gap:.25rem;display:flex}.toggle-btn,.delete-btn{color:#888;cursor:pointer;background:0 0;border:1px solid #444;border-radius:4px;padding:.35rem .5rem}.toggle-btn:hover{color:#ccc;background:#333}.toggle-btn.active{color:#22c55e;background:#22c55e33;border-color:#22c55e}.delete-btn:hover{color:#fca5a5;background:#7f1d1d;border-color:#dc2626}.automation-meta{color:#666;background:#252525;border-top:1px solid #333;padding:.4rem .75rem;font-size:.75rem}.analytics-dashboard{max-width:1400px;margin:0 auto;padding:20px}.analytics-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.header-left{align-items:center;gap:10px;display:flex}.header-left h2{margin:0;font-size:1.5rem;font-weight:600}.header-controls{align-items:center;gap:10px;display:flex}.date-select{cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:6px;padding:8px 12px;font-size:14px}.refresh-btn,.export-btn{cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:6px;align-items:center;gap:6px;padding:8px 12px;font-size:14px;transition:all .2s;display:flex}.refresh-btn:hover,.export-btn:hover{background:#f8fafc;border-color:#cbd5e1}.analytics-tabs{border-bottom:1px solid #e2e8f0;gap:4px;margin-bottom:24px;padding-bottom:0;display:flex}.analytics-tabs button{cursor:pointer;color:#64748b;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:6px;margin-bottom:-1px;padding:10px 16px;font-size:14px;transition:all .2s;display:flex}.analytics-tabs button:hover{color:#334155}.analytics-tabs button.active{color:#3b82f6;border-bottom-color:#3b82f6}.analytics-loading{color:#64748b;flex-direction:column;justify-content:center;align-items:center;padding:60px;display:flex}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.overview-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;display:grid}.metric-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;align-items:center;gap:16px;padding:20px;display:flex}.metric-card.highlight{color:#fff;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border:none}.metric-icon{color:#fff;border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.metric-icon.projects{background:#10b981}.metric-icon.deployments{background:#8b5cf6}.metric-icon.requests{background:#f59e0b}.metric-icon.tokens{background:#06b6d4}.metric-icon.cost{background:#fff3}.metric-icon.users{background:#ec4899}.metric-content{flex-direction:column;display:flex}.metric-value{font-size:1.75rem;font-weight:700;line-height:1.2}.metric-label{color:#64748b;font-size:13px}.metric-card.highlight .metric-label{color:#fffc}.costs-section{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:24px}.cost-summary{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.cost-summary h3,.projects-section h3,.timeline-section h3{margin:0;font-size:1.125rem;font-weight:600}.total-cost{flex-direction:column;align-items:flex-end;display:flex}.total-cost .label{color:#64748b;font-size:13px}.total-cost .value{color:#10b981;font-size:2rem;font-weight:700}.cost-cards{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;display:grid}.cost-card{background:#f8fafc;border-radius:8px;padding:16px}.cost-header{justify-content:space-between;margin-bottom:12px;display:flex}.cost-label{font-weight:500}.cost-value{font-weight:600}.cost-details span{color:#64748b;margin-bottom:8px;font-size:13px;display:block}.cost-bar{background:#e2e8f0;border-radius:3px;height:6px;overflow:hidden}.cost-bar-fill{border-radius:3px;height:100%;transition:width .3s}.cost-bar-fill.ai{background:#3b82f6}.cost-bar-fill.deployments{background:#8b5cf6}.cost-bar-fill.storage{background:#10b981}.projects-section{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:24px}.projects-table{border-collapse:collapse;width:100%;margin-top:16px}.projects-table th,.projects-table td{text-align:left;border-bottom:1px solid #e2e8f0;padding:12px}.projects-table th{color:#64748b;text-transform:uppercase;font-size:13px;font-weight:600}.projects-table .project-name{font-weight:500}.projects-table .cost{color:#10b981;font-weight:600}.timeline-section{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:24px}.timeline-chart{margin-top:16px}.timeline-header{color:#64748b;text-transform:uppercase;border-bottom:1px solid #e2e8f0;grid-template-columns:1fr 1fr 1fr 1fr;padding:12px;font-size:13px;font-weight:600;display:grid}.timeline-row{border-bottom:1px solid #f1f5f9;grid-template-columns:1fr 1fr 1fr 1fr;padding:12px;display:grid}.timeline-row:hover{background:#f8fafc}.timeline-date{color:#334155}.timeline-requests{font-weight:500}.timeline-tokens{color:#64748b}.timeline-cost{color:#10b981;font-weight:500}.analytics-dashboard .empty{color:#94a3b8;flex-direction:column;justify-content:center;align-items:center;padding:60px;display:flex}.analytics-dashboard .empty p{margin:8px 0 0}.analytics-dashboard .empty .hint{font-size:13px}*{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary:#0f0f14;--bg-secondary:#18181f;--bg-tertiary:#222230;--bg-elevated:#2a2a3a;--text-primary:#f4f4f5;--text-secondary:#a1a1aa;--text-muted:#71717a;--border-color:#2e2e3a;--accent-primary:#6366f1;--accent-hover:#818cf8;--accent-success:#22c55e;--accent-warning:#f59e0b;--accent-danger:#ef4444;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 10px 40px #00000080;--radius-sm:6px;--radius-md:10px;--radius-lg:16px}body{background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;overflow:hidden}.app-container{background:var(--bg-primary);width:100vw;height:100vh;display:flex}.sidebar{background:var(--bg-secondary);border-right:1px solid var(--border-color);flex-direction:column;width:260px;min-width:260px;display:flex;overflow:hidden}.sidebar-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:20px;display:flex}.sidebar-header h2{background:linear-gradient(135deg, var(--accent-primary), #a78bfa);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:15px;font-weight:700}.project-card{background:var(--bg-tertiary);border-radius:var(--radius-md);cursor:pointer;border:1px solid #0000;align-items:center;gap:12px;margin:12px;padding:14px 16px;transition:all .2s;display:flex}.project-card:hover{background:var(--bg-elevated);border-color:var(--accent-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.project-icon{border-radius:var(--radius-sm);background:linear-gradient(135deg, var(--accent-primary), #8b5cf6);color:#fff;justify-content:center;align-items:center;width:40px;height:40px;font-size:14px;font-weight:700;display:flex;box-shadow:0 4px 12px #6366f14d}.project-info{flex:1;min-width:0}.project-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.project-url{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.nav-section{padding:8px 12px}.nav-section-title{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:8px;padding:0 8px;font-size:11px;font-weight:600}.nav-item{border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);align-items:center;gap:12px;padding:10px 12px;font-size:14px;font-weight:500;transition:all .15s;display:flex}.nav-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-item.active{background:linear-gradient(135deg, var(--accent-primary), #8b5cf6);color:#fff;box-shadow:var(--shadow-sm)}.nav-item svg{flex-shrink:0;width:18px;height:18px}.nav-badge{background:var(--bg-elevated);color:var(--text-muted);border-radius:10px;margin-left:auto;padding:2px 8px;font-size:11px;font-weight:600}.nav-item.active .nav-badge{color:#fff;background:#fff3}.file-tree{flex:1;padding:8px;overflow:auto}.tree-node{-webkit-user-select:none;user-select:none}.tree-item{cursor:pointer;border-radius:var(--radius-sm);color:var(--text-secondary);align-items:center;gap:6px;padding:6px 10px;transition:all .1s;display:flex}.tree-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.tree-item.selected{background:linear-gradient(135deg, var(--accent-primary), #8b5cf6);color:#fff}.tree-chevron{width:16px;color:var(--text-muted);justify-content:center;align-items:center;transition:transform .15s;display:flex}.tree-chevron.expanded{transform:rotate(90deg)}.tree-icon{color:var(--text-muted);align-items:center;display:flex}.tree-icon.folder{color:#fbbf24}.tree-icon.file{color:var(--accent-primary)}.tree-name{white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:13px;overflow:hidden}.main-content{background:var(--bg-primary);flex-direction:column;flex:1;display:flex;overflow:hidden}.top-bar{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:14px 24px;display:flex}.top-bar-left{align-items:center;gap:16px;display:flex}.breadcrumb{color:var(--text-secondary);align-items:center;gap:8px;font-size:14px;display:flex}.breadcrumb-item{align-items:center;gap:8px;display:flex}.breadcrumb-item.current{color:var(--text-primary);font-weight:500}.file-name-display{color:var(--text-primary);background:var(--bg-tertiary);border-radius:var(--radius-sm);border:1px solid var(--border-color);padding:8px 14px;font-size:14px;font-weight:500}.top-bar-actions{align-items:center;gap:10px;display:flex}.action-btn{border-radius:var(--radius-sm);cursor:pointer;border:none;align-items:center;gap:8px;padding:10px 16px;font-size:13px;font-weight:500;transition:all .15s;display:flex}.action-btn.primary{background:linear-gradient(135deg, var(--accent-primary), #8b5cf6);color:#fff;box-shadow:0 4px 12px #6366f14d}.action-btn.primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px #6366f166}.action-btn.secondary{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-color)}.action-btn.secondary:hover{background:var(--bg-elevated);color:var(--text-primary)}.editor-container{flex:1;min-height:0;overflow:hidden}.preview-container{border-top:1px solid var(--border-color);background:var(--bg-secondary);flex-direction:column;height:260px;min-height:180px;display:flex}.preview-header{background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;justify-content:space-between;align-items:center;padding:12px 16px;font-size:12px;display:flex}.preview-tabs{gap:4px;display:flex}.preview-tab{border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;padding:6px 12px;font-size:12px;transition:all .15s}.preview-tab.active{background:var(--accent-primary);color:#fff}.preview-iframe{background:#fff;border:none;flex:1}.no-file{color:var(--text-muted);background:var(--bg-primary);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;display:flex}.no-file svg{width:56px;height:56px;color:var(--border-color)}.no-file p{font-size:15px}.right-panel{background:var(--bg-secondary);border-left:1px solid var(--border-color);flex-direction:column;width:300px;min-width:300px;display:flex;overflow:hidden}.panel-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:18px 20px;display:flex}.panel-header h3{color:var(--text-primary);font-size:14px;font-weight:600}.panel-content{flex:1;padding:16px;overflow-y:auto}.status-badge{border-radius:20px;align-items:center;gap:6px;padding:4px 10px;font-size:12px;font-weight:500;display:inline-flex}.status-badge.success{color:var(--accent-success);background:#22c55e26}.status-badge.warning{color:var(--accent-warning);background:#f59e0b26}.status-badge.error{color:var(--accent-danger);background:#ef444426}.status-badge.neutral{background:var(--bg-tertiary);color:var(--text-secondary)}.btn{border-radius:var(--radius-sm);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;padding:10px 18px;font-size:13px;font-weight:500;transition:all .15s;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--accent-primary), #8b5cf6);color:#fff}.btn-primary:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-secondary)}.btn-secondary:hover{background:var(--bg-elevated);color:var(--text-primary)}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover{background:var(--bg-tertiary);color:var(--text-primary)}.safety-scan-btn{border-radius:var(--radius-sm);cursor:pointer;background:var(--bg-tertiary);color:var(--text-secondary);border:none;align-items:center;gap:6px;padding:8px 14px;font-size:13px;transition:all .15s;display:flex}.safety-scan-btn:hover:not(:disabled){background:var(--bg-elevated);color:var(--text-primary)}.safety-scan-btn:disabled{opacity:.7;cursor:wait}.safety-scan-btn.scanning{background:linear-gradient(135deg, var(--accent-primary), #8b5cf6);color:#fff}.safety-scan-btn.critical,.safety-scan-btn.high{color:var(--accent-danger);background:#ef444426}.safety-scan-btn.medium{color:var(--accent-warning);background:#f59e0b26}.safety-scan-btn.safe{color:var(--accent-success);background:#22c55e26}.spinning{animation:1s linear infinite spin}.scan-results-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#000000bf;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.scan-results-modal{background:var(--bg-secondary);border-radius:var(--radius-lg);width:90%;max-width:700px;max-height:80vh;box-shadow:var(--shadow-lg);border:1px solid var(--border-color);flex-direction:column;display:flex}.scan-results-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.scan-results-header h3{color:var(--text-primary);align-items:center;gap:10px;font-size:18px;font-weight:600;display:flex}.scan-results-header h3 .critical{color:var(--accent-danger)}.scan-results-header h3 .safe{color:var(--accent-success)}.scan-results-header .close-btn{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;padding:8px;display:flex}.scan-results-header .close-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.scan-results-content{flex:1;padding:24px;overflow-y:auto}.scan-summary{border-bottom:1px solid var(--border-color);flex-wrap:wrap;gap:12px;margin-bottom:24px;padding-bottom:20px;display:flex}.scan-summary .stat{border-radius:var(--radius-sm);padding:6px 14px;font-size:13px;font-weight:600}.scan-summary .stat.critical{color:var(--accent-danger);background:#ef444426}.scan-summary .stat.high{color:var(--accent-warning);background:#f59e0b26}.scan-summary .stat.medium{color:#d97706;background:#f59e0b1a}.scan-summary .stat.low{color:var(--accent-primary);background:#6366f126}.scan-summary .stat.time{background:var(--bg-tertiary);color:var(--text-secondary)}.finding-group{margin-bottom:20px}.finding-group h4{align-items:center;gap:8px;margin-bottom:12px;font-size:14px;font-weight:600;display:flex}.finding-group.critical h4{color:var(--accent-danger)}.finding-group.high h4{color:var(--accent-warning)}.finding-group.medium h4{color:#d97706}.finding-group.low h4{color:var(--accent-primary)}.finding-item{background:var(--bg-tertiary);border-radius:var(--radius-md);border-left:3px solid;margin-bottom:10px;padding:14px}.finding-item.critical{border-left-color:var(--accent-danger)}.finding-item.high{border-left-color:var(--accent-warning)}.finding-item.medium{border-left-color:#d97706}.finding-item.low{border-left-color:var(--accent-primary)}.finding-header{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:10px;display:flex}.severity-badge{text-transform:uppercase;border-radius:4px;padding:3px 8px;font-size:11px;font-weight:600}.severity-badge.critical{background:var(--accent-danger);color:#fff}.severity-badge.high{background:var(--accent-warning);color:#fff}.severity-badge.medium{color:#fff;background:#d97706}.severity-badge.low{background:var(--accent-primary);color:#fff}.finding-type{color:var(--text-primary);font-size:13px;font-weight:600}.location{color:var(--text-muted);margin-left:auto;font-size:12px}.finding-message{color:var(--text-secondary);margin-bottom:10px;font-size:13px}.finding-code{background:var(--bg-primary);border-radius:var(--radius-sm);color:var(--text-secondary);margin-bottom:10px;padding:10px;font-family:JetBrains Mono,monospace;font-size:12px;overflow-x:auto}.finding-fix{color:var(--accent-success);font-size:12px;font-style:italic}.no-findings{color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;padding:60px;display:flex}.no-findings svg{width:48px;height:48px;color:var(--accent-success);margin-bottom:16px}.no-findings p{font-size:15px}input,textarea,select{background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);border-radius:var(--radius-sm);outline:none;padding:10px 14px;font-family:inherit;font-size:14px;transition:all .15s}input:focus,textarea:focus,select:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #6366f126}input::placeholder{color:var(--text-muted)}.card{background:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-color);padding:16px}.card-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.card-title{color:var(--text-primary);font-size:14px;font-weight:600}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--border-color)}
