:root{--color-primary:#c026d3;--color-primary-dark:#a21caf;--color-primary-light:#d946ef;--color-secondary:#3b82f6;--color-secondary-dark:#2563eb;--color-secondary-light:#60a5fa;--color-success:#10b981;--color-success-dark:#059669;--color-warning:#f59e0b;--color-warning-dark:#d97706;--color-error:#ef4444;--color-error-dark:#dc2626;--color-info:#2563eb;--gradient-primary:linear-gradient(135deg, #c026d3 0%, #ec4899 100%);--gradient-primary-hover:linear-gradient(135deg, #a21caf 0%, #db2777 100%);--gradient-success:linear-gradient(135deg, #10b981 0%, #059669 100%);--gradient-error:linear-gradient(135deg, #ef4444 0%, #dc2626 100%);--gradient-info:linear-gradient(135deg, #2563eb 0%, #1e40af 100%);--space-xs:.25rem;--space-sm:.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:2.5rem;--space-3xl:3rem;--font-family-base:-apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-family-mono:"Courier New", Courier, monospace;--font-size-xs:.75rem;--font-size-sm:.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--z-dropdown:100;--z-sticky:200;--z-fixed:300;--z-modal-backdrop:900;--z-modal:1000;--z-popover:1100;--z-tooltip:1200;--breakpoint-sm:480px;--breakpoint-md:768px;--breakpoint-lg:1024px;--breakpoint-xl:1200px;--breakpoint-2xl:1400px;--transition-fast:.15s ease;--transition-base:.2s ease;--transition-slow:.3s ease}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1;box-shadow:0 0 #10b98166}50%{opacity:.8;box-shadow:0 0 0 6px #10b98100}}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-family-base);font-size:var(--font-size-base);color:var(--text-primary);background:var(--bg-primary);margin:0;padding:0;line-height:1.5}h1,h2,h3,h4,h5,h6{margin:0;font-weight:600;line-height:1.2}p{margin:0}a{color:inherit;transition:color var(--transition-base);text-decoration:none}ul,ol{list-style:none}input,textarea,select,button{font-family:inherit;font-size:inherit;line-height:inherit;color:inherit}input,textarea,select{background:0 0;border:none;padding:0}button{cursor:pointer;background:0 0;border:none;padding:0}button:disabled{cursor:not-allowed}input[type=checkbox],input[type=radio]{cursor:pointer}img{max-width:100%;height:auto;display:block}table{border-collapse:collapse;border-spacing:0;width:100%}th,td{text-align:left;vertical-align:top}code,pre{font-family:var(--font-family-mono)}blockquote{margin:0}hr{border:none;border-top:1px solid var(--border-primary);margin:0}.flex{display:flex}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-wrap{flex-wrap:wrap}.flex-nowrap{flex-wrap:nowrap}.inline-flex{display:inline-flex}.grid{display:grid}.block{display:block}.inline-block{display:inline-block}.hidden{display:none}.items-start{align-items:flex-start}.items-center{align-items:center}.items-end{align-items:flex-end}.items-stretch{align-items:stretch}.justify-start{justify-content:flex-start}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}.justify-evenly{justify-content:space-evenly}.gap-xs{gap:var(--space-xs)}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.gap-xl{gap:var(--space-xl)}.p-xs{padding:var(--space-xs)}.p-sm{padding:var(--space-sm)}.p-md{padding:var(--space-md)}.p-lg{padding:var(--space-lg)}.p-xl{padding:var(--space-xl)}.px-xs{padding-left:var(--space-xs);padding-right:var(--space-xs)}.px-sm{padding-left:var(--space-sm);padding-right:var(--space-sm)}.px-md{padding-left:var(--space-md);padding-right:var(--space-md)}.px-lg{padding-left:var(--space-lg);padding-right:var(--space-lg)}.px-xl{padding-left:var(--space-xl);padding-right:var(--space-xl)}.py-xs{padding-top:var(--space-xs);padding-bottom:var(--space-xs)}.py-sm{padding-top:var(--space-sm);padding-bottom:var(--space-sm)}.py-md{padding-top:var(--space-md);padding-bottom:var(--space-md)}.py-lg{padding-top:var(--space-lg);padding-bottom:var(--space-lg)}.py-xl{padding-top:var(--space-xl);padding-bottom:var(--space-xl)}.m-xs{margin:var(--space-xs)}.m-sm{margin:var(--space-sm)}.m-md{margin:var(--space-md)}.m-lg{margin:var(--space-lg)}.m-xl{margin:var(--space-xl)}.mx-xs{margin-left:var(--space-xs);margin-right:var(--space-xs)}.mx-sm{margin-left:var(--space-sm);margin-right:var(--space-sm)}.mx-md{margin-left:var(--space-md);margin-right:var(--space-md)}.mx-lg{margin-left:var(--space-lg);margin-right:var(--space-lg)}.mx-xl{margin-left:var(--space-xl);margin-right:var(--space-xl)}.my-xs{margin-top:var(--space-xs);margin-bottom:var(--space-xs)}.my-sm{margin-top:var(--space-sm);margin-bottom:var(--space-sm)}.my-md{margin-top:var(--space-md);margin-bottom:var(--space-md)}.my-lg{margin-top:var(--space-lg);margin-bottom:var(--space-lg)}.my-xl{margin-top:var(--space-xl);margin-bottom:var(--space-xl)}.mt-xs{margin-top:var(--space-xs)}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mt-xl{margin-top:var(--space-xl)}.mb-xs{margin-bottom:var(--space-xs)}.mb-sm{margin-bottom:var(--space-sm)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.mb-xl{margin-bottom:var(--space-xl)}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.text-justify{text-align:justify}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}.text-muted{color:var(--text-muted)}.text-success{color:var(--color-success)}.text-error{color:var(--color-error)}.text-warning{color:var(--color-warning)}.text-info{color:var(--color-info)}.bg-primary{background:var(--bg-primary)}.bg-secondary{background:var(--bg-secondary)}.bg-tertiary{background:var(--bg-tertiary)}.bg-success{background:var(--color-success)}.bg-error{background:var(--color-error)}.bg-warning{background:var(--color-warning)}.bg-info{background:var(--color-info)}.border{border:1px solid var(--border-primary)}.border-top{border-top:1px solid var(--border-primary)}.border-bottom{border-bottom:1px solid var(--border-primary)}.border-left{border-left:1px solid var(--border-primary)}.border-right{border-right:1px solid var(--border-primary)}.rounded-sm{border-radius:var(--radius-sm)}.rounded-md{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-full{border-radius:9999px}.w-full{width:100%}.h-full{height:100%}.w-auto{width:auto}.h-auto{height:auto}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}.flex-1{flex:1}.flex-grow{flex-grow:1}.flex-shrink{flex-shrink:1}.flex-shrink-0{flex-shrink:0}.opacity-50{opacity:.5}.opacity-75{opacity:.75}.opacity-100{opacity:1}.cursor-pointer{cursor:pointer}.cursor-default{cursor:default}.cursor-not-allowed{cursor:not-allowed}.is-disabled{opacity:.6;cursor:not-allowed}.is-loading{opacity:.7;pointer-events:none}.is-hidden{display:none}.has-error{border-color:var(--color-error)}.has-success{border-color:var(--color-success)}.transition-fast{transition:all var(--transition-fast)}.transition-base{transition:all var(--transition-base)}.transition-slow{transition:all var(--transition-slow)}.context-menu{background:var(--bg-elevated);border:1px solid var(--border-primary);box-shadow:var(--shadow-md);z-index:1000;border-radius:4px;min-width:200px;position:fixed}.context-menu-item{cursor:pointer;color:var(--text-primary);padding:8px 12px}.context-menu-item+.context-menu-item{border-top:1px solid var(--border-subtle)}.context-menu-item:hover{background:var(--bg-hover)}.modal-content{background:var(--bg-elevated);color:var(--text-primary);max-width:600px;max-height:80vh;box-shadow:var(--shadow-overlay);border-radius:8px;padding:24px;overflow:auto}.modal-content h2,.modal-content h3,.modal-content strong{color:var(--text-primary)}.modal-content .detail-value{color:var(--text-secondary)}.modal-content .mono-value{background:var(--bg-tertiary);color:var(--text-primary);border-radius:4px;padding:8px;font-family:monospace}:root{--gradient-primary:linear-gradient(135deg, var(--color-primary) 0%, #ec4899 100%);--gradient-primary-hover:linear-gradient(135deg, var(--color-primary-dark) 0%, #db2777 100%);--gradient-primary-alt:linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);--gradient-secondary:linear-gradient(135deg, #3b4a9e 0%, #4a2d6b 100%);--gradient-purple:linear-gradient(135deg, #a855f7 0%, #ec4899 100%);--gradient-purple-hover:linear-gradient(135deg, #9333ea 0%, #db2777 100%);--gradient-purple-dark:linear-gradient(135deg, #7c3aed 0%, #5b21b6 100%);--gradient-success:linear-gradient(135deg, var(--color-success) 0%, var(--color-success-dark) 100%);--gradient-danger:linear-gradient(135deg, var(--color-error) 0%, var(--color-error-dark) 100%);--gradient-danger-hover:linear-gradient(135deg, var(--color-error-dark) 0%, #b91c1c 100%);--gradient-danger-alt:linear-gradient(135deg, var(--color-error-dark) 0%, #b91c1c 100%);--gradient-info:linear-gradient(135deg, var(--color-info) 0%, #1e40af 100%);--gradient-verify:linear-gradient(135deg, #667eea 0%, #764ba2 100%);--gradient-save:linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);--gradient-save-hover:linear-gradient(135deg, #d946ef 0%, var(--color-primary) 100%);--bg-primary:#f8f9fa;--bg-secondary:#fff;--bg-tertiary:#f9fafb;--bg-input:#f8f9fa;--bg-hover:#f3f4f6;--bg-active:#e5e7eb;--bg-elevated:#fff;--text-primary:#111827;--text-secondary:#374151;--text-placeholder:var(--text-muted);--border-primary:#e5e7eb;--border-secondary:#d1d5db;--border-subtle:#f3f4f6;--shadow-sm:0 1px 3px #0000001a;--shadow-md:0 4px 12px #0000001a;--shadow-lg:0 10px 25px #0000001a;--shadow-overlay:0 20px 40px #0003}[data-theme=dark]{--bg-primary:#0a0a0a;--bg-secondary:#1a1a1a;--bg-tertiary:#0f0f0f;--bg-input:#2a2a2a;--bg-hover:#2a2a2a;--bg-active:#333;--bg-elevated:#1a1a1a;--text-primary:#f9fafb;--text-secondary:#e5e7eb;--text-tertiary:var(--text-muted);--text-muted:var(--text-tertiary);--text-placeholder:var(--text-tertiary);--border-primary:#333;--border-secondary:#404040;--border-subtle:#2a2a2a;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 12px #0000004d;--shadow-lg:0 10px 25px #0006;--shadow-overlay:0 20px 40px #00000080}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-primary);color:var(--text-primary);margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}[data-theme=dark] table td,[data-theme=dark] table tbody td{color:var(--text-secondary)}[data-theme=dark] input:not([type=checkbox]):not([type=radio]):not(.chat-input),[data-theme=dark] textarea:not(.chat-input),[data-theme=dark] select{background:var(--bg-input);border-color:var(--border-secondary);color:var(--text-primary)}[data-theme=dark] input::placeholder,[data-theme=dark] textarea::placeholder{color:var(--text-placeholder)}[data-theme=dark] .card,[data-theme=dark] .content-card,[data-theme=dark] .info-card,[data-theme=dark] .metric-card,[data-theme=dark] .deployment-card,[data-theme=dark] .settings-section,[data-theme=dark] .delete-confirm-section,[data-theme=dark] .upload-area,[data-theme=dark] .recommendation-item,[data-theme=dark] .wizard-step,[data-theme=dark] .chat-container,[data-theme=dark] .chat-message,[data-theme=dark] .confirm-modal-content,[data-theme=dark] .project-sidebar,[data-theme=dark] .table-container{background:var(--bg-secondary);border-color:var(--border-primary)}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.auth-container{height:100vh;font-family:Aptos,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;display:flex;overflow:hidden}.auth-branding{background:#000;flex-direction:column;flex:0 0 40%;justify-content:space-between;align-items:center;padding:60px;display:flex;position:relative}.branding-content{flex:1;justify-content:center;align-items:center;display:flex}.brand-logo{width:auto;height:60px}.powered-by{align-items:center;gap:var(--space-sm);color:#fff;font-size:var(--font-size-sm);display:flex}.siit-logo{width:auto;height:40px}.auth-form-side{background:var(--bg-primary);flex:0 0 60%;justify-content:center;align-items:center;padding:40px;display:flex;overflow-y:auto}.auth-form-container{width:100%;max-width:400px}.form-content{width:100%}.form-content h1{color:var(--text-primary);margin:0 0 8px;font-size:36px;font-weight:600}.subtitle{font-size:var(--font-size-base);color:var(--text-tertiary);margin:0 0 32px}.auth-form{width:100%}.form-field{margin-bottom:20px}.form-input{border:1px solid var(--border-secondary);border-radius:var(--radius-md);width:100%;color:var(--text-primary);background:var(--bg-secondary);transition:all var(--transition-base);padding:14px 16px;font-family:inherit;font-size:15px}.form-input::placeholder{color:var(--text-muted)}.checkbox-field{margin:24px 0}.checkbox-label{align-items:flex-start;gap:var(--space-xs);cursor:pointer;font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.5;display:flex}.checkbox-input{width:18px;height:18px;accent-color:var(--color-primary);cursor:pointer;margin-top:2px}.forgot-link{text-align:right;margin-bottom:20px}.link-purple{color:var(--color-primary);font-size:var(--font-size-sm);cursor:pointer;background:0 0;border:none;padding:0;font-family:inherit;text-decoration:none}.link-purple:hover{color:var(--color-primary-dark);text-decoration:underline}.error-message{color:var(--color-error-dark);border-radius:var(--radius-md);font-size:var(--font-size-sm);background:#fee2e2;border:1px solid #fecaca;margin-bottom:20px;padding:12px 16px}.success-message{color:#166534;border-radius:var(--radius-md);font-size:var(--font-size-sm);background:#dcfce7;border:1px solid #bbf7d0;margin-bottom:20px;padding:12px 16px}.session-expired-message{color:#92400e;border-radius:var(--radius-md);font-size:var(--font-size-sm);background:#fef3c7;border:2px solid #fbbf24;align-items:center;gap:10px;margin-bottom:24px;padding:14px 18px;font-weight:500;animation:.3s ease-out slideDown;display:flex}.expired-icon{font-size:var(--font-size-xl)}.verification-prompt{text-align:center;margin-bottom:16px}.resend-verification-button{background:var(--color-secondary);color:#fff;border-radius:var(--radius-md);font-size:var(--font-size-sm);cursor:pointer;border:none;padding:10px 20px;font-weight:500;transition:background .2s}.resend-verification-button:hover{background:var(--color-info)}.submit-button{background:var(--gradient-primary);color:#fff;border-radius:var(--radius-md);width:100%;font-size:var(--font-size-base);cursor:pointer;transition:all var(--transition-base);border:none;padding:14px 24px;font-family:inherit;font-weight:500}.submit-button:hover:not(:disabled){background:var(--gradient-primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #c026d34d}.submit-button:disabled{opacity:.7;cursor:not-allowed}.form-footer{text-align:center;border-top:1px solid var(--border-primary);margin-top:24px;padding-top:24px}.footer-text{font-size:var(--font-size-sm);color:var(--text-tertiary)}.modal-overlay{z-index:var(--z-modal);padding:var(--space-lg);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-elevated);border-radius:var(--radius-lg);width:100%;max-width:480px;padding:var(--space-xl);box-shadow:var(--shadow-overlay)}.modal-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.modal-header h2{font-size:var(--font-size-2xl);color:var(--text-primary);margin:0;font-weight:600}.close-btn{color:var(--text-tertiary);cursor:pointer;border-radius:var(--radius-sm);width:32px;height:32px;transition:all var(--transition-base);background:0 0;border:none;justify-content:center;align-items:center;padding:0;font-size:28px;display:flex}.close-btn:hover{background:var(--bg-hover);color:var(--text-secondary)}.modal-description{color:var(--text-tertiary);margin-bottom:24px;line-height:1.5}.cancel-btn{background:var(--bg-secondary);color:var(--text-tertiary);border:1px solid var(--border-secondary);border-radius:var(--radius-md);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);padding:10px 20px;font-family:inherit;font-weight:500}.cancel-btn:hover{background:var(--bg-hover);color:var(--text-secondary);border-color:var(--text-muted)}.message{border-radius:var(--radius-md);font-size:var(--font-size-sm);margin-bottom:20px;padding:12px 16px}@media (width<=768px){.auth-container{flex-direction:column}.auth-branding{flex:none;height:200px;padding:40px 20px}.brand-logo{height:40px}.auth-form-side{padding:var(--space-lg);flex:1}.form-content h1{font-size:28px}}.verify-email-container{background:var(--gradient-verify);min-height:100vh;padding:var(--space-lg);justify-content:center;align-items:center;display:flex}.verify-email-card{border-radius:var(--radius-md);text-align:center;background:#fff;width:100%;max-width:500px;padding:40px;box-shadow:0 10px 40px #0000001a}.logo-section{margin-bottom:30px}.logo{height:40px}.verifying,.success,.error{padding:20px 0}.spinner{border:4px solid #f3f3f3;border-top:4px solid var(--color-secondary);border-radius:50%;width:50px;height:50px;margin:0 auto 20px;animation:1s linear infinite spin}.success-icon{color:#fff;background-color:#48bb78;border-radius:50%;width:80px;height:80px;margin:0 auto 20px;font-size:50px;line-height:80px}.error-icon{color:#fff;background-color:#f56565;border-radius:50%;width:80px;height:80px;margin:0 auto 20px;font-size:50px;line-height:80px}h2{color:#2d3748;margin-bottom:15px}p{color:#718096;margin-bottom:10px;line-height:1.6}.redirect-message{font-size:var(--font-size-sm);color:#a0aec0;font-style:italic}.verify-email-container .btn-primary{background-color:var(--color-secondary);color:#fff;font-size:var(--font-size-base);cursor:pointer;border:none;border-radius:5px;margin-top:20px;padding:12px 24px;transition:background-color .3s}.verify-email-container .btn-primary:hover{background-color:#3182ce}.sidebar-new{border-right:1px solid var(--border-primary);width:200px;height:100vh;z-index:var(--z-modal);background:#1a1a1a;flex-direction:column;display:flex;position:fixed;top:0;left:0}.sidebar-navigation{gap:var(--space-xs);flex-direction:column;flex:1;padding:16px 0;display:flex}.nav-link{align-items:center;gap:var(--space-sm);color:#a0a0a0;border-radius:var(--radius-md);font-size:var(--font-size-sm);transition:all var(--transition-base);margin:0 8px;padding:12px 16px;font-weight:500;text-decoration:none;display:flex}.nav-link:hover{color:#fff;background:#2a2a2a}.nav-link.active{background:var(--color-primary);color:#fff}.nav-link.active .nav-icon{color:#fff}.nav-icon{color:inherit;flex-shrink:0}.nav-label{color:inherit}.sidebar-footer{padding:var(--space-md);border-top:1px solid var(--border-primary);gap:var(--space-sm);flex-direction:column;display:flex}.logout-button{align-items:center;gap:var(--space-sm);border-radius:var(--radius-md);color:#a0a0a0;width:100%;font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);text-align:left;background:0 0;border:none;padding:12px 16px;font-weight:500;display:flex}.logout-button .nav-icon{color:inherit;flex-shrink:0}.logout-button .nav-label{color:inherit}@media (width<=768px){.sidebar-new{border-right:none;border-bottom:1px solid var(--border-primary);width:100%;height:auto;position:relative}.sidebar-navigation{padding:var(--space-xs);flex-direction:row;overflow-x:auto}.nav-link{white-space:nowrap;margin:0 4px}}.dark-mode-toggle{padding:var(--space-xs);border-radius:var(--radius-md);background:var(--bg-hover);border:1px solid var(--border-secondary);color:var(--text-tertiary);cursor:pointer;transition:all var(--transition-base);justify-content:center;align-items:center;display:flex}.dark-mode-toggle:hover{background:var(--bg-active);color:var(--text-secondary)}.page-layout{background:var(--bg-primary);min-height:100vh;font-family:Aptos,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;display:flex}.main-layout{flex-direction:column;flex:1;margin-left:200px;display:flex}.page-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);z-index:var(--z-dropdown);padding:16px 24px;position:sticky;top:0}.header-content{justify-content:space-between;align-items:center;width:100%;max-width:1200px;margin:0 auto;display:flex}.header-left{align-items:center;gap:var(--space-md);flex:1;min-width:0;display:flex}.page-title{font-size:var(--font-size-2xl);color:var(--text-primary);margin:0;font-weight:600}.header-center{flex:0 400px;margin:0 24px}.search-container-new{width:100%;position:relative}.search-input-new{background:var(--bg-input);border:1px solid var(--border-secondary);border-radius:var(--radius-md);width:100%;font-size:var(--font-size-sm);color:var(--text-secondary);transition:all var(--transition-base);padding:10px 12px 10px 40px}.search-input-new::placeholder{color:var(--text-muted)}.search-input-new:focus{border-color:var(--color-primary);background:var(--bg-secondary);outline:none;box-shadow:0 0 0 3px #c026d31a}.search-icon-new{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.header-right{justify-content:flex-end;align-items:center;gap:var(--space-md);flex:1;display:flex}.user-menu{cursor:pointer;position:relative}.user-menu>svg{color:var(--text-tertiary);padding:var(--space-xs);border-radius:var(--radius-md);background:var(--bg-hover);transition:all var(--transition-base);border:1px solid var(--border-secondary)}.user-menu:hover>svg{background:var(--bg-active);color:var(--text-secondary)}.user-dropdown{background:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;min-width:180px;transition:all var(--transition-base);z-index:var(--z-modal);margin-top:8px;position:absolute;top:100%;right:0;transform:translateY(-8px)}.user-menu:hover .user-dropdown{opacity:1;visibility:visible;transform:translateY(0)}.user-dropdown a,.user-dropdown button{width:100%;color:var(--text-secondary);text-align:left;cursor:pointer;font-family:inherit;font-size:var(--font-size-sm);background:0 0;border:none;padding:12px 16px;text-decoration:none;transition:background .2s;display:block}.user-dropdown a:hover,.user-dropdown button:hover{background:var(--bg-hover)}.user-dropdown a:first-child{border-radius:8px 8px 0 0}.user-dropdown button:last-child{border-top:1px solid var(--border-primary);color:var(--color-error-dark);border-radius:0 0 8px 8px}.user-dropdown button:last-child:hover{background:#fee2e2}.page-content{padding:var(--space-lg);flex:1;width:100%;max-width:1200px;margin:0 auto}@media (width<=768px){.main-layout{margin-left:0}.header-content{gap:var(--space-md);flex-direction:column;align-items:stretch}.header-center{flex:none;margin:0}.page-content{padding:var(--space-md)}}.projects-container{max-width:100%}.loading-state{color:var(--text-tertiary);justify-content:center;align-items:center;padding:3rem;font-size:1rem;display:flex}.error-message{color:var(--color-error-dark);background:#fee2e2;border:1px solid #fecaca;border-radius:.5rem;margin-bottom:1.5rem;padding:.75rem 1rem}.empty-state h3{color:var(--text-secondary);margin:0 0 .5rem;font-size:1.25rem;font-weight:600}.projects-table{background:var(--bg-secondary);border:1px solid var(--border-primary);box-shadow:var(--shadow-sm);border-radius:.75rem;margin-bottom:1.5rem;overflow:visible}.projects-table table{border-collapse:collapse;table-layout:fixed;width:100%}.projects-table th,.projects-table td{width:25%}.projects-table thead{background:var(--bg-tertiary);border-bottom:1px solid var(--border-primary)}.projects-table th{text-align:left;text-transform:uppercase;color:var(--text-tertiary);letter-spacing:.05em;padding:1rem 1.25rem;font-size:.75rem;font-weight:600}.projects-table th:last-child{width:25%}.projects-table tbody tr{border-bottom:1px solid var(--border-subtle);cursor:pointer;transition:background .2s}.projects-table tbody tr:hover{background:var(--bg-tertiary)}.projects-table tbody tr:last-child{border-bottom:none}.projects-table td{color:var(--text-secondary);vertical-align:middle;padding:1.25rem;font-size:.875rem}.model-name{color:var(--text-tertiary);font-size:.875rem}.status-badge{text-transform:capitalize;background:var(--bg-hover);color:var(--text-tertiary);border-radius:1.25rem;padding:.25rem .75rem;font-size:.75rem;font-weight:500}.actions-cell,.dropdown-menu-container{position:relative}.menu-btn{border:1px solid var(--border-primary);background:var(--bg-secondary);width:2rem;height:2rem;color:var(--text-tertiary);cursor:pointer;transition:all var(--transition-base);border-radius:.375rem;justify-content:center;align-items:center;display:flex}.menu-btn:hover{background:var(--bg-hover);color:var(--text-secondary);border-color:var(--border-secondary)}.dropdown-menu{background:var(--bg-elevated);border:1px solid var(--border-primary);min-width:11.25rem;max-height:25rem;box-shadow:var(--shadow-md);z-index:var(--z-modal);border-radius:.5rem;position:absolute;top:2.25rem;left:0;overflow-y:auto}.menu-item{background:var(--bg-elevated);width:100%;color:var(--text-secondary);text-align:left;cursor:pointer;border:none;align-items:center;gap:.75rem;padding:.625rem 1rem;font-size:.875rem;transition:background .15s;display:flex}.menu-item:hover{background:var(--bg-hover)}.menu-item.danger{color:var(--color-error-dark)}.menu-item.danger:hover{background:#fee2e2}.menu-divider{background:var(--border-primary);height:1px;margin:.25rem 0}.pagination-info{color:var(--text-tertiary);align-items:center;gap:.5rem;font-size:.875rem;display:flex}.rows-select{border:1px solid var(--border-secondary);background:var(--bg-secondary);color:var(--text-secondary);border-radius:.25rem;padding:.25rem .5rem;font-size:.875rem}.pagination-btn{border:1px solid var(--border-secondary);background:var(--bg-secondary);width:2rem;height:2rem;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-base);border-radius:.25rem;justify-content:center;align-items:center;font-size:.875rem;display:flex}@media (width<=64rem){.projects-table{overflow:visible}.projects-table table{border:0}.projects-table thead{display:none}.projects-table tbody tr{border-bottom:1px solid var(--border-primary);border-radius:0;margin-bottom:.75rem;padding:1rem 3.5rem 1rem 1rem;display:block;position:relative}.projects-table tbody tr:last-child{border-bottom:none}.projects-table td{text-align:left;border-bottom:none;align-items:center;gap:.5rem;padding:.5rem 0;display:flex}.projects-table td:before{content:attr(data-label) ": ";color:var(--text-tertiary);flex-shrink:0;font-size:.875rem;font-weight:600}.projects-table td.actions-cell{border:none;padding:0;position:absolute;top:50%;right:1rem;transform:translateY(-50%)}.projects-table td.actions-cell:before{display:none}.dropdown-menu{left:auto;right:0}.pagination{flex-direction:column;gap:1rem}}.btn-primary{align-items:center;gap:var(--space-xs);background:var(--color-primary);color:#fff;border-radius:var(--radius-md);font-weight:500;font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);border:none;padding:10px 16px;text-decoration:none;display:inline-flex}.btn-secondary{align-items:center;gap:var(--space-xs);background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border-secondary);border-radius:var(--radius-md);font-weight:500;font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);padding:10px 16px;text-decoration:none;display:inline-flex}.back-btn{align-items:center;gap:var(--space-xs);background:var(--bg-hover);color:var(--text-tertiary);border-radius:var(--radius-sm);font-weight:500;font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);border:none;padding:8px 12px;text-decoration:none;display:inline-flex}.back-btn:hover{background:var(--bg-active);color:var(--text-secondary)}.edit-btn{align-items:center;gap:var(--space-xs);background:var(--bg-secondary);color:var(--text-tertiary);border:1px solid var(--border-secondary);border-radius:var(--radius-sm);font-weight:500;font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);padding:8px 12px;text-decoration:none;display:inline-flex}.edit-btn:hover{background:var(--bg-hover);color:var(--text-secondary);border-color:var(--text-muted)}.project-actions{align-items:center;gap:var(--space-sm);display:flex}.models-container{max-width:100%}.models-actions{align-items:center;gap:var(--space-md);display:flex}.search-container-models{min-width:300px;position:relative}.search-input-models{background:var(--bg-input);border:1px solid var(--border-secondary);border-radius:var(--radius-md);width:100%;font-size:var(--font-size-sm);color:var(--text-secondary);transition:all var(--transition-base);padding:10px 12px 10px 40px}.search-input-models::placeholder{color:var(--text-muted)}.search-input-models:focus{border-color:var(--color-primary);background:var(--bg-secondary);outline:none;box-shadow:0 0 0 3px #c026d31a}.search-icon-models{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:64px 24px;display:flex}.models-table{background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-primary);box-shadow:var(--shadow-sm);margin-bottom:24px;overflow:hidden}.table-row{gap:var(--space-md);padding:var(--space-lg);border-bottom:1px solid var(--border-subtle);cursor:pointer;grid-template-columns:3fr 1fr 2fr 2fr 3fr;transition:background .2s;display:grid}.table-row.selected{background:var(--bg-hover);border-left:4px solid #f97316}.origin-badge{border-radius:var(--radius-lg);font-size:var(--font-size-xs);text-transform:capitalize;padding:4px 12px;font-weight:500;display:inline-block}.origin-badge.user{color:#1d4ed8;background:#dbeafe}.origin-badge.community{color:#065f46;background:#d1fae5}.selection-actions{justify-content:center;margin-top:16px;padding:24px 0;display:flex}.pagination{border-top:1px solid var(--border-primary);justify-content:space-between;align-items:center;margin-top:24px;padding:16px 0;display:flex}.pagination-info{align-items:center;gap:var(--space-xs);font-size:var(--font-size-sm);color:var(--text-tertiary);display:flex}.rows-select{border:1px solid var(--border-secondary);border-radius:var(--radius-sm);font-size:var(--font-size-sm);background:var(--bg-secondary);color:var(--text-secondary);padding:4px 8px}.pagination-btn:hover:not(:disabled){background:var(--bg-hover);border-color:var(--text-muted)}.btn-create-project{background:linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);color:#fff;border-radius:var(--radius-sm);font-weight:500;font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);border:none;padding:6px 12px;box-shadow:0 2px 4px #c026d333}.btn-create-project:hover{background:linear-gradient(135deg, #d946ef 0%, var(--color-primary) 100%);transform:translateY(-1px);box-shadow:0 4px 8px #c026d34d}@media (width<=1024px){.models-actions{align-items:stretch;gap:var(--space-sm);flex-direction:column}.search-container-models{min-width:auto}.table-header,.table-row{gap:var(--space-xs);grid-template-columns:1fr}.header-cell{display:none}.table-row{padding:var(--space-md);flex-direction:column;display:flex}.cell{justify-content:space-between;align-items:center;padding:8px 0;display:flex}.pagination{gap:var(--space-md);flex-direction:column}}.benchmark-devices{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.device-badge{color:#0369a1;border-radius:var(--radius-sm);white-space:nowrap;background:#e0f2fe;border:1px solid #bae6fd;padding:4px 8px;font-size:11px;font-weight:500;display:inline-block}.no-benchmarks{color:var(--text-muted);font-size:var(--font-size-sm);font-style:italic}.upload-container{max-width:800px;margin:0 auto}.upload-zone{border-radius:var(--radius-lg);text-align:center;transition:all var(--transition-slow);cursor:pointer;background:#f9fafb;border:2px dashed #d1d5db;margin-bottom:32px;padding:64px 32px}.upload-zone.drag-over{border-color:var(--color-primary);background:#faf5ff;transform:scale(1.02)}.upload-zone.has-file{border-color:var(--color-success);cursor:default;background:#f0fdf4}.upload-icon{color:var(--color-primary);margin-bottom:24px}.upload-zone.drag-over .upload-icon{color:var(--color-primary-dark);transform:scale(1.1)}.upload-text h3{font-size:var(--font-size-lg);color:#374151;margin:0 0 24px;font-weight:500}.divider{color:var(--text-muted);font-size:var(--font-size-sm);align-items:center;margin:24px 0;display:flex}.divider:before,.divider:after{content:"";background:#e5e7eb;flex:1;height:1px}.divider span{padding:0 16px}.browse-btn{align-items:center;gap:var(--space-xs);background:var(--color-primary);color:#fff;border-radius:var(--radius-md);font-weight:500;font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);border:none;padding:12px 24px;text-decoration:none;display:inline-flex}.browse-btn:hover{background:var(--color-primary-dark);transform:translateY(-1px)}.file-selected{align-items:center;gap:var(--space-lg);flex-direction:column;display:flex}.file-info{align-items:center;gap:var(--space-md);padding:var(--space-lg);border-radius:var(--radius-lg);border:1px solid var(--border-primary);background:#fff;display:flex;box-shadow:0 2px 4px #0000000d}.file-info svg{color:var(--color-success)}.file-details h4{font-size:var(--font-size-base);color:#111827;margin:0 0 4px;font-weight:500}.file-details p{font-size:var(--font-size-sm);color:var(--text-tertiary);margin:0}.upload-progress{align-items:center;gap:var(--space-xs);flex-direction:column;min-width:200px;display:flex}.progress-bar{border-radius:var(--radius-sm);background:#e5e7eb;width:100%;height:8px;overflow:hidden}.progress-fill{background:var(--color-primary);height:100%;transition:width .3s}.progress-text{font-size:var(--font-size-sm);color:#374151;font-weight:500}.upload-actions{gap:var(--space-sm);display:flex}.btn-secondary{align-items:center;gap:var(--space-xs);color:#374151;border:1px solid var(--border-secondary);border-radius:var(--radius-md);font-weight:500;font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);background:#fff;padding:10px 16px;text-decoration:none;display:inline-flex}.btn-primary:hover{background:var(--color-primary-dark);transform:translateY(-1px)}.upload-info{border-radius:var(--radius-lg);padding:var(--space-lg);border:1px solid var(--border-primary);background:#fff}.upload-info h4{font-size:var(--font-size-base);color:#111827;margin:0 0 16px;font-weight:600}.upload-info ul{margin:0;padding:0;list-style:none}.upload-info li{color:var(--text-tertiary);font-size:var(--font-size-sm);padding:8px 0 8px 20px;position:relative}.upload-info li:before{content:"•";color:var(--color-primary);font-weight:700;position:absolute;left:0}@media (width<=768px){.upload-zone{padding:48px 24px}.upload-text h3{font-size:var(--font-size-base)}.file-info{text-align:center;flex-direction:column}.upload-actions{flex-direction:column;width:100%}.upload-actions button{justify-content:center;width:100%}}.model-options{margin:12px 0}.model-options-label{color:#888;margin-bottom:8px;font-size:14px}[data-theme=light] .model-options-label{color:#666}.model-options-grid{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.model-option-btn{text-align:center;cursor:pointer;background:#1e1e1e;border:2px solid #333;border-radius:8px;flex-direction:column;align-items:center;padding:16px 12px;transition:all .2s;display:flex}[data-theme=light] .model-option-btn{background:#fff;border-color:#e0e0e0}.model-option-btn:hover{background:#2a2a2a;border-color:#007bff}[data-theme=light] .model-option-btn:hover{background:#f8f9fa}.model-option-name{color:#e0e0e0;word-break:break-word;margin-bottom:6px;font-size:13px;font-weight:600}[data-theme=light] .model-option-name{color:#333}.model-option-description{color:#888;font-size:12px;line-height:1.4}[data-theme=light] .model-option-description{color:#666}@media (width<=600px){.model-options-grid{grid-template-columns:1fr}}.config-form-container{margin:6px 0}.config-form-label{color:#888;margin-bottom:6px;font-size:13px}[data-theme=light] .config-form-label{color:#666}.config-form{background:#1e1e1e;border:2px solid #333;border-radius:8px;padding:10px}[data-theme=light] .config-form{background:#fff;border-color:#e0e0e0}.form-section-title{color:#e0e0e0;border-top:1px solid #333;margin:8px 0 6px;padding-top:8px;font-size:14px;font-weight:600}[data-theme=light] .form-section-title{color:#333;border-top-color:#e0e0e0}.form-row{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:8px;display:grid}.config-field{margin:0}.config-field-full{margin:0 0 8px}.config-field label{color:#ccc;margin-bottom:3px;font-size:13px;font-weight:500;display:block}[data-theme=light] .config-field label{color:#333}.config-field input{color:#e0e0e0;background:#2a2a2a;border:1px solid #444;border-radius:4px;width:100%;padding:6px 10px;font-size:13px}[data-theme=light] .config-field input{color:#333;background:#fff;border-color:#ddd}.config-field input:focus{border-color:#007bff;outline:none}.config-field input::placeholder{color:#666}[data-theme=light] .config-field input::placeholder{color:#999}.config-form-submit{color:#fff;cursor:pointer;background:#007bff;border:none;border-radius:6px;width:100%;margin-top:8px;padding:8px;font-size:13px;font-weight:600;transition:background .2s}.config-form-submit:hover{background:#0056b3}.project-created-card{background:#0c2d48;border:2px solid #0ea5e9;border-radius:8px;margin:12px 0;padding:16px}[data-theme=light] .project-created-card{background:#f0f9ff}.project-created-header{align-items:center;gap:12px;margin-bottom:16px;display:flex}.success-icon{color:#10b981;flex-shrink:0}.project-created-title{color:#e0e0e0;margin:0 0 4px;font-size:16px;font-weight:600}[data-theme=light] .project-created-title{color:#333}.project-created-name{color:#888;margin:0;font-size:14px}[data-theme=light] .project-created-name{color:#666}.btn-view-recommendations{color:#fff;cursor:pointer;background:#0ea5e9;border:none;border-radius:6px;justify-content:center;align-items:center;gap:8px;width:100%;padding:10px;font-weight:600;transition:background .2s;display:flex}.btn-view-recommendations:hover{background:#0284c7}.chat-container{border-radius:var(--radius-lg);background:#000;border:1px solid #333;flex-direction:column;max-width:900px;height:calc(100vh - 140px);margin:0 auto;font-family:Courier New,Consolas,monospace;display:flex;overflow:hidden;box-shadow:0 4px 20px #00000080}[data-theme=light] .chat-container{box-shadow:var(--shadow-md);background:#f5f5f5;border-color:#d1d5db}.chat-messages{padding:var(--space-lg);gap:var(--space-md);background:#000;flex-direction:column;flex:1;display:flex;overflow-y:auto}[data-theme=light] .chat-messages{background:#f5f5f5}.chat-message{max-width:100%;display:flex}.chat-message-user,.chat-message-assistant{align-self:flex-start}.chat-bubble{word-wrap:break-word;border-radius:0;padding:0;font-family:Courier New,Consolas,monospace;font-size:16px;font-weight:500;line-height:1.6}.chat-bubble-user:before,.chat-bubble-assistant:before{vertical-align:baseline;display:inline}.chat-bubble-user{color:#4af626;white-space:pre-wrap;background:#000}[data-theme=light] .chat-bubble-user{color:#1a1a1a;background:#f5f5f5}.chat-bubble-user:before{content:"$ ";color:#4af626;font-weight:700}[data-theme=light] .chat-bubble-user:before{color:#059669}.chat-bubble-assistant{color:#e0e0e0;background:#000;border-bottom-left-radius:0}[data-theme=light] .chat-bubble-assistant{color:#1a1a1a;background:#f5f5f5}.chat-bubble-assistant:before{content:"> ";color:#888}[data-theme=light] .chat-bubble-assistant:before{color:#6b7280}.chat-bubble-assistant p{color:#e0e0e0;margin:0 0 8px;display:inline}[data-theme=light] .chat-bubble-assistant p{color:#1a1a1a}.chat-bubble-assistant p:first-child{display:inline}.chat-bubble-assistant p:last-child{margin-bottom:0}.chat-bubble-assistant strong{color:#4af626;font-weight:600}[data-theme=light] .chat-bubble-assistant strong{color:#059669}.chat-bubble-assistant ul,.chat-bubble-assistant ol{color:#e0e0e0;margin:8px 0;padding-left:20px}[data-theme=light] .chat-bubble-assistant ul,[data-theme=light] .chat-bubble-assistant ol{color:#1a1a1a}.chat-bubble-assistant li{margin-bottom:4px}.chat-bubble-assistant code{border-radius:var(--radius-sm);font-size:var(--font-size-sm);color:#4af626;background:#1e1e1e;border:1px solid #333;padding:2px 6px;font-family:Courier New,Consolas,monospace}[data-theme=light] .chat-bubble-assistant code{color:#059669;background:#e5e7eb;border-color:#d1d5db}.chat-bubble-assistant pre{color:#e0e0e0;border-radius:var(--radius-sm);background:#1e1e1e;border:1px solid #333;margin:8px 0;padding:12px 16px;overflow-x:auto}[data-theme=light] .chat-bubble-assistant pre{color:#1a1a1a;background:#e5e7eb;border-color:#d1d5db}.chat-bubble-assistant pre code{color:inherit;background:0 0;border:none;padding:0}.chat-loading-indicator{flex-direction:column;justify-content:center;align-self:center;align-items:center;gap:12px;padding:32px;display:flex}.chat-loading-spinner{color:#c026d3;animation:1s linear infinite spin}.chat-loading-indicator p{color:#6b7280;margin:0;font-size:14px;font-weight:500}[data-theme=light] .chat-loading-indicator p{color:#9ca3af}.chat-error-message{color:#fca5a5;background:#451a1a;border:1px solid #7f1d1d;border-radius:8px;align-self:stretch;align-items:center;gap:12px;max-width:85%;padding:16px;display:flex}[data-theme=light] .chat-error-message{color:#b91c1c;background:#fee2e2;border-color:#f87171}.chat-error-message svg:first-child{flex-shrink:0}.chat-error-message p{flex:1;margin:0;font-size:14px;line-height:1.5}.chat-error-close{color:#fca5a5;cursor:pointer;background:0 0;border:none;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;padding:4px;transition:background .2s;display:flex}[data-theme=light] .chat-error-close{color:#b91c1c}.chat-error-close:hover{background:#fca5a51a}[data-theme=light] .chat-error-close:hover{background:#b91c1c1a}.chat-typing-indicator{gap:var(--space-xs);color:#4af626;padding:4px 0;display:flex}[data-theme=light] .chat-typing-indicator{color:#059669}.chat-typing-indicator:before{content:"> ";color:#888}[data-theme=light] .chat-typing-indicator:before{color:#6b7280}.chat-typing-indicator span{background:#4af626;border-radius:0;width:8px;height:8px;animation:1.4s ease-in-out infinite typing-bounce}[data-theme=light] .chat-typing-indicator span{background:#059669}.chat-typing-indicator span:nth-child(2){animation-delay:.2s}.chat-typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing-bounce{0%,60%,to{opacity:.3}30%{opacity:1}}.chat-tool-card{border-radius:var(--radius-sm);background:#1e1e1e;border:1px solid #333;margin-top:12px;overflow:hidden}[data-theme=light] .chat-tool-card{background:#f9fafb;border-color:#d1d5db}.tool-card-header{align-items:center;gap:var(--space-xs);font-size:var(--font-size-xs);color:#4af626;text-transform:uppercase;letter-spacing:.03em;background:#000;border-bottom:1px solid #333;padding:10px 14px;font-weight:600;display:flex}[data-theme=light] .tool-card-header{color:#059669;background:#f3f4f6;border-bottom-color:#d1d5db}.tool-card-header svg{color:#4af626}[data-theme=light] .tool-card-header svg{color:#059669}.tool-card-empty{font-size:var(--font-size-sm);color:#888;margin:0;padding:14px;font-style:italic}[data-theme=light] .tool-card-empty{color:#6b7280}.tool-card-models{flex-direction:column;display:flex}.tool-model-item{border-bottom:1px solid #333;justify-content:space-between;align-items:center;padding:10px 14px;transition:background .15s;display:flex}[data-theme=light] .tool-model-item{border-bottom-color:#e5e7eb}.tool-model-item:last-child{border-bottom:none}.tool-model-item:hover{background:#000}[data-theme=light] .tool-model-item:hover{background:#f3f4f6}.tool-model-name{font-size:var(--font-size-sm);color:#e0e0e0;font-weight:500}[data-theme=light] .tool-model-name{color:#1a1a1a}.tool-model-meta{font-size:var(--font-size-xs);color:#888}[data-theme=light] .tool-model-meta{color:#6b7280}.chat-project-created{align-items:center;gap:var(--space-md);padding:var(--space-md);border-radius:var(--radius-sm);background:#1e1e1e;border:1px solid #4af626;margin-top:12px;display:flex}[data-theme=light] .chat-project-created{background:#f0fdf4;border-color:#059669}.project-created-icon{color:#4af626;flex-shrink:0}[data-theme=light] .project-created-icon{color:#059669}.project-created-content h3{color:#4af626;margin:0 0 4px;font-size:15px;font-weight:600}[data-theme=light] .project-created-content h3{color:#059669}.project-created-content p{font-size:var(--font-size-sm);color:#e0e0e0;margin:0 0 12px}[data-theme=light] .project-created-content p{color:#374151}.btn-view-recommendations{color:#000;border-radius:var(--radius-sm);font-size:var(--font-size-sm);cursor:pointer;background:#4af626;border:none;align-items:center;gap:6px;padding:8px 16px;font-family:Courier New,Consolas,monospace;font-weight:700;transition:all .2s;display:inline-flex}.btn-view-recommendations:hover{background:#3dd61f;box-shadow:0 0 5px #4af6264d}.chat-input-area{background:#000;border-top:1px solid #333;padding:16px 24px}[data-theme=light] .chat-input-area{border-top-color:var(--border-primary);background:#f5f5f5}.chat-input-wrapper{align-items:center;gap:var(--space-sm);background:#000;border:none;border-radius:0;padding:0;transition:none;display:flex}[data-theme=light] .chat-input-wrapper{background:#f5f5f5}.chat-input-wrapper:before{content:"$ ";color:#4af626;font-family:Courier New,Consolas,monospace;font-size:16px;font-weight:700;line-height:1.5}[data-theme=light] .chat-input-wrapper:before{color:#059669}.chat-input-wrapper:focus-within{box-shadow:none;border:none}.chat-input{resize:none;color:#4af626;caret-color:#4af626;background:#000;border:none;outline:none;flex:1;min-height:24px;max-height:120px;padding:0;font-family:Courier New,Consolas,monospace;font-size:16px;font-weight:500;line-height:1.5}[data-theme=light] .chat-input{color:#1a1a1a;caret-color:#1a1a1a;background:#f5f5f5}.chat-input::placeholder{color:#666}.chat-input:disabled{opacity:.6}.chat-send-btn{color:#4af626;border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:1px solid #333;flex-shrink:0;justify-content:center;align-items:center;width:64px;height:64px;transition:all .2s;display:flex}[data-theme=light] .chat-send-btn{color:#059669;border-color:var(--border-primary)}.chat-send-btn:hover:not(:disabled){background:#1e1e1e;border-color:#4af626;box-shadow:0 0 5px #4af6264d}[data-theme=light] .chat-send-btn:hover:not(:disabled){background:#e5e7eb;border-color:#059669;box-shadow:0 0 5px #0596694d}.chat-send-btn:disabled{color:#333;cursor:not-allowed;background:0 0;border-color:#333}[data-theme=light] .chat-send-btn:disabled{border-color:var(--border-secondary);color:var(--text-tertiary)}.chat-send-logo{filter:brightness(0)saturate()invert(85%)sepia(48%)saturate(2448%)hue-rotate(45deg)brightness(102%)contrast(95%);width:64px;height:64px}[data-theme=light] .chat-send-logo{filter:brightness(0)saturate()invert(35%)sepia(98%)saturate(1247%)hue-rotate(130deg)brightness(96%)contrast(101%)}.chat-input-completed{justify-content:center;padding:8px 0;display:flex}@media (width<=768px){.chat-container{border-left:none;border-right:none;border-radius:0;height:calc(100vh - 120px)}.chat-messages{padding:var(--space-md)}.chat-message{max-width:100%}.chat-input-area{padding:12px 16px}}.wizard-container{max-width:1200px;margin:0 auto}.wizard-actions{justify-content:flex-end;align-items:center;gap:var(--space-sm);border-bottom:1px solid var(--border-primary);width:100%;margin-bottom:24px;padding-bottom:24px;display:flex}.navigation-buttons{align-items:center;gap:var(--space-sm);display:flex}.btn-cancel{align-items:center;gap:var(--space-xs);color:#fff;border-radius:var(--radius-md);font-weight:500;font-size:var(--font-size-sm);cursor:pointer;height:40px;transition:all var(--transition-base);background:#f97316;border:none;padding:10px 16px;line-height:1.5;display:inline-flex}.btn-secondary{align-items:center;gap:var(--space-xs);background:var(--bg-hover);color:var(--text-secondary);border:1px solid var(--border-secondary);border-radius:var(--radius-md);font-weight:500;font-size:var(--font-size-sm);cursor:pointer;height:40px;transition:all var(--transition-base);align-self:center;padding:10px 16px;line-height:1.5;display:inline-flex}.btn-primary{align-items:center;gap:var(--space-xs);background:var(--color-secondary);color:#fff;border-radius:var(--radius-md);font-weight:500;font-size:var(--font-size-sm);cursor:pointer;height:40px;transition:all var(--transition-base);border:none;align-self:center;padding:10px 16px;line-height:1.5;display:inline-flex}.btn-primary:not(:disabled):hover{background:var(--color-info)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-create{align-items:center;gap:var(--space-xs);background:var(--text-muted);color:#fff;border-radius:var(--radius-md);font-weight:500;font-size:var(--font-size-sm);cursor:pointer;height:40px;transition:all var(--transition-base);border:none;padding:10px 16px;line-height:1.5;display:inline-flex}.btn-create:not(:disabled){background:var(--color-primary)}.btn-create:not(:disabled):hover{background:var(--color-primary-dark)}.btn-create:disabled{opacity:.6;cursor:not-allowed}.wizard-steps{border-bottom:1px solid var(--border-primary);justify-content:center;align-items:center;margin-bottom:48px;padding-bottom:24px;display:flex}.wizard-step-indicator{align-items:center;gap:var(--space-xs);display:flex;position:relative}.step-number{background:var(--bg-active);width:32px;height:32px;color:var(--text-tertiary);font-size:var(--font-size-sm);z-index:2;border-radius:50%;justify-content:center;align-items:center;font-weight:600;display:flex;position:relative}.wizard-step-indicator.active .step-number,.wizard-step-indicator.completed .step-number{background:var(--color-primary);color:#fff}.step-name{font-size:var(--font-size-sm);color:var(--text-tertiary);font-weight:500}.wizard-step-indicator.active .step-name{color:var(--color-primary);font-weight:600}.wizard-step-indicator.completed .step-name{color:var(--color-primary)}.wizard-content{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--space-xl);border:1px solid var(--border-primary);min-height:400px;margin-bottom:24px;box-shadow:0 1px 3px #0000001a}.wizard-step h2{font-size:var(--font-size-2xl);color:var(--text-primary);margin:0 0 24px;font-weight:600}.wizard-step p{color:var(--text-tertiary);margin-bottom:32px;line-height:1.5}.form-layout{gap:var(--space-xl);grid-template-columns:1fr 1fr;display:grid}.form-column{gap:var(--space-lg);flex-direction:column;display:flex}.form-field{gap:var(--space-xs);flex-direction:column;display:flex}.form-field label{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:500}.form-input,.form-textarea{border:1px solid var(--border-secondary);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--text-primary);transition:all var(--transition-base);padding:12px 16px;font-family:inherit}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}.form-input:focus,.form-textarea:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #c026d31a}.form-textarea{resize:vertical;min-height:120px}.dropdown-container{position:relative}.dropdown-button{border:1px solid var(--border-secondary);border-radius:var(--radius-md);background:var(--bg-secondary);width:100%;color:var(--text-primary);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.dropdown-button:hover{border-color:var(--text-muted)}.dropdown-menu{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);z-index:10;max-height:400px;margin-top:4px;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 4px 6px #0000001a}.dropdown-item{text-align:left;width:100%;color:var(--text-secondary);font-size:var(--font-size-sm);cursor:pointer;background:0 0;border:none;padding:12px 16px;transition:background .2s;display:block}.dropdown-item:hover{background:var(--bg-tertiary)}.model-search-container{border-bottom:1px solid var(--border-primary);padding:12px 16px;position:relative}.model-search-input{border:1px solid var(--border-secondary);border-radius:var(--radius-sm);width:100%;font-size:var(--font-size-sm);color:var(--text-secondary);background:var(--bg-tertiary);padding:8px 12px 8px 32px}.model-search-input:focus{border-color:var(--color-primary);background:var(--bg-secondary);outline:none}.model-search-icon{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:20px;transform:translateY(-50%)}.model-upload-section{border-bottom:1px solid var(--border-primary);padding:12px 16px}.model-upload-button{align-items:center;gap:var(--space-xs);background:var(--color-primary);color:#fff;border-radius:var(--radius-sm);width:100%;font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);border:none;padding:8px 12px;font-weight:500;display:flex}.model-upload-button:hover{background:var(--color-primary-dark);color:#fff}.model-section-header{font-size:var(--font-size-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;background:var(--bg-tertiary);border-bottom:1px solid var(--border-primary);padding:8px 16px;font-weight:600}.dropdown-item.user-model{border-left:3px solid var(--color-warning);background:#fef3c7}.dropdown-item.user-model:hover{background:#fde68a}.dropdown-item.system-model:hover{background:var(--bg-tertiary)}.model-info{flex-direction:column;align-items:flex-start;gap:2px;display:flex}.model-name{color:var(--text-primary);font-weight:500}.model-type{font-size:var(--font-size-xs);color:var(--text-tertiary)}.dropdown-item.user-model .model-type{color:var(--color-warning-dark);font-weight:500}.no-models-found{padding:var(--space-md);text-align:center;color:var(--text-tertiary);font-style:italic}.config-grid{gap:var(--space-lg);grid-template-columns:repeat(2,1fr);display:grid}.step-header{justify-content:space-between;align-items:flex-start;margin-bottom:24px;display:flex}.search-container-wizard{min-width:300px;position:relative}.search-input-wizard{border:1px solid var(--border-secondary);border-radius:var(--radius-md);width:100%;font-size:var(--font-size-sm);color:var(--text-secondary);transition:all var(--transition-base);padding:10px 12px 10px 40px}.search-input-wizard:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #c026d31a}.search-icon-wizard{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.recommendations-table .table-row{gap:var(--space-md);border-bottom:1px solid var(--border-subtle);cursor:pointer;transition:all var(--transition-base);grid-template-columns:repeat(6,1fr);padding:16px 20px;display:grid;position:relative}.recommendations-table .table-row.user-selected{background:var(--color-primary);color:#fff}.pagination-btn:hover{background:var(--bg-hover);border-color:var(--text-muted)}.deployment-card{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-xl);text-align:center;transition:all var(--transition-base)}.deployment-card:hover{border-color:var(--color-primary);box-shadow:0 4px 12px #c026d31a}.deployment-card p{color:var(--text-tertiary);margin:0 0 24px;line-height:1.5}.deployment-btn{border-radius:var(--radius-md);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);border:none;justify-content:center;align-items:center;min-width:120px;padding:12px 24px;font-weight:500;display:inline-flex}.deployment-btn.terraform{background:var(--gradient-primary);color:#fff}.deployment-btn.terraform:hover{background:var(--gradient-primary-hover)}.deployment-btn.manual{background:var(--gradient-primary);color:#fff}.deployment-btn.manual:hover{background:var(--gradient-primary-hover)}.wizard-navigation{justify-content:flex-start;display:flex}.btn-previous{align-items:center;gap:var(--space-xs);background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border-secondary);border-radius:var(--radius-md);font-weight:500;font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);padding:10px 16px;display:inline-flex}.btn-previous:hover{background:var(--bg-tertiary);border-color:var(--text-muted)}@media (width<=768px){.wizard-steps{padding-bottom:16px;overflow-x:auto}.wizard-step-indicator:not(:last-child):after{width:50px;right:-29px}.wizard-content{padding:var(--space-lg)}.form-layout{gap:var(--space-lg);grid-template-columns:1fr}.config-grid{grid-template-columns:1fr}.step-header{gap:var(--space-md);flex-direction:column;align-items:stretch}.search-container-wizard{min-width:auto}.recommendations-table .table-header,.recommendations-table .table-row{gap:var(--space-xs);grid-template-columns:1fr}.recommendations-table .table-header{display:none}.deployment-options{gap:var(--space-lg);grid-template-columns:1fr}.wizard-actions{flex-direction:column-reverse}.wizard-actions button{justify-content:center;width:100%}}.step-description{color:var(--text-tertiary);font-size:var(--font-size-sm);margin:-16px 0 24px}.quick-create-section{border-top:1px solid var(--border-primary);margin-top:40px;padding-top:32px}.quick-create-divider{text-align:center;margin-bottom:24px;position:relative}.quick-create-divider span{background:var(--bg-secondary);color:var(--text-muted);font-size:var(--font-size-sm);z-index:1;padding:0 16px;font-weight:500;display:inline-block;position:relative}.quick-create-divider:before{content:"";background:var(--bg-active);z-index:0;height:1px;position:absolute;top:50%;left:0;right:0}.btn-quick-create{align-items:center;gap:var(--space-xs);background:var(--color-success);color:#fff;border-radius:var(--radius-md);font-weight:500;font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);border:none;justify-content:center;width:100%;padding:12px 24px;display:inline-flex}.btn-quick-create:not(:disabled):hover{background:var(--color-success-dark)}.btn-quick-create:disabled{opacity:.6;cursor:not-allowed}.quick-create-hint{font-size:var(--font-size-sm);color:var(--text-tertiary);text-align:center;margin-top:12px}.config-section{gap:var(--space-xs);flex-direction:column;display:flex}.config-row{align-items:start;gap:var(--space-md);border-bottom:1px solid var(--border-subtle);grid-template-columns:240px 1fr 120px;padding:8px 0;display:grid}.config-row:last-child{border-bottom:none}.config-label{flex-direction:column;display:flex}.config-label label{font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:2px;font-weight:500;display:block}.config-controls{align-items:center;gap:var(--space-sm);display:flex}.field-help{font-size:var(--font-size-xs);color:var(--text-tertiary);margin:0}.preset-buttons{gap:var(--space-xs);flex-wrap:wrap;display:flex}.preset-btn{border:1px solid var(--border-secondary);border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--text-secondary);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);padding:8px 16px;font-weight:500}.preset-btn:hover{border-color:var(--text-muted);background:var(--bg-tertiary)}.preset-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.form-input-narrow{border:1px solid var(--border-secondary);border-radius:var(--radius-sm);width:120px;font-size:var(--font-size-sm);color:var(--text-primary);transition:all var(--transition-base);padding:8px 12px;font-family:inherit}.form-input-narrow:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #c026d31a}.btn-quick-defaults{align-items:center;gap:var(--space-xs);background:var(--color-success);color:#fff;border-radius:var(--radius-md);font-weight:500;font-size:var(--font-size-sm);cursor:pointer;height:40px;transition:all var(--transition-base);white-space:nowrap;border:none;align-self:center;padding:10px 16px;line-height:1.5;display:inline-flex}.btn-quick-defaults:not(:disabled):hover{background:var(--color-success-dark)}.btn-quick-defaults:disabled{opacity:.6;cursor:not-allowed}.constraints-section{gap:var(--space-md);flex-direction:column;display:flex}.use-case-examples{border-radius:var(--radius-md);background:#f0fdf4;border:1px solid #bbf7d0;flex-direction:column;gap:10px;padding:14px;display:flex}.use-case-examples label{font-size:var(--font-size-sm);color:var(--color-success-dark);margin:0;font-weight:600}.use-case-buttons{gap:var(--space-xs);flex-wrap:wrap;display:flex}.use-case-btn{border:1px solid var(--color-success-dark);border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--color-success-dark);font-size:var(--font-size-xs);cursor:pointer;transition:all var(--transition-base);padding:6px 12px;font-weight:500}.use-case-btn:hover{background:var(--color-success-dark);color:#fff}.constraints-form{gap:var(--space-xs);flex-direction:column;display:flex}.constraint-row{align-items:center;gap:var(--space-md);border-bottom:1px solid var(--border-subtle);padding:8px 0;display:flex}.constraint-row:last-child{border-bottom:none}.constraint-label{flex:0 0 280px;min-width:280px}.constraint-label label{font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:2px;font-weight:500;display:block}.review-section-compact{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-md);padding:var(--space-lg)}.review-grid{gap:var(--space-lg);grid-template-columns:repeat(3,1fr);display:grid}.review-column{gap:var(--space-xs);flex-direction:column;display:flex}.review-column h3{font-size:var(--font-size-sm);color:var(--text-primary);border-bottom:2px solid var(--color-primary);margin:0 0 8px;padding-bottom:8px;font-weight:600}.review-row{justify-content:space-between;align-items:baseline;padding:6px 0;display:flex}.review-label{font-size:var(--font-size-sm);color:var(--text-tertiary);font-weight:500}.review-value{font-size:var(--font-size-sm);color:var(--text-primary);text-align:right;font-weight:500}.no-constraints{font-size:var(--font-size-sm);color:var(--text-muted);margin:0;font-style:italic}@media (width<=768px){.config-row,.constraint-row{gap:var(--space-sm);flex-direction:column}.config-label,.constraint-label{flex:1;padding-top:0}.config-controls{flex-direction:column;align-items:stretch}.form-input-narrow{width:100%}.preset-buttons{gap:6px}.preset-btn{font-size:var(--font-size-sm);padding:6px 12px}.use-case-buttons{flex-direction:column}.use-case-btn{width:100%}.review-grid{gap:var(--space-md);grid-template-columns:1fr}.review-row{gap:var(--space-xs);flex-direction:column}.review-value{text-align:left}}.project-creator-content{width:100%;height:100%}.mode-toggle{gap:var(--space-xs);background:var(--bg-hover);border-radius:var(--radius-md);padding:4px;display:flex}.mode-toggle-button{border-radius:var(--radius-sm);color:var(--text-tertiary);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;background:0 0;border:none;align-items:center;gap:6px;padding:8px 16px;font-weight:500;display:flex}.mode-toggle-button:hover{background:var(--bg-active);color:var(--text-secondary)}.mode-toggle-button.active{background:var(--bg-secondary);color:var(--color-secondary);box-shadow:0 1px 2px #0000000d}.back-button-simple{color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:0;transition:color .2s;display:flex}.back-button-simple:hover{color:var(--text-secondary)}.project-sidebar{border-right:1px solid var(--border-primary);width:250px;height:100vh;z-index:var(--z-dropdown);background:#1a1a1a;flex-direction:column;display:flex;position:fixed;top:0;left:0;overflow-y:auto}.sidebar-logo{text-decoration:none;display:block}.logo-image{width:100%;max-width:180px;height:auto}.sidebar-navigation{flex:1;padding:1rem 0}.nav-item{color:#a0a0a0;transition:all var(--transition-base);cursor:pointer;width:100%;font-size:var(--font-size-sm);background:0 0;border:none;align-items:center;gap:.75rem;padding:.75rem 1rem;text-decoration:none;display:flex}.nav-item.active{background:var(--color-primary);color:#fff}.main-item{justify-content:space-between;font-weight:500}.sub-menu{padding-left:1rem}.sub-menu-item{color:#a0a0a0;transition:all var(--transition-base);font-size:var(--font-size-sm);align-items:center;gap:.75rem;padding:.625rem 1rem;text-decoration:none;display:flex}.sub-menu-item:hover{color:#fff;background:#2a2a2a}.sub-menu-item.active{background:var(--color-primary);color:#fff}.sub-menu-item.disabled{opacity:.5;cursor:not-allowed;color:var(--text-tertiary);pointer-events:none}.sub-menu-item.disabled:hover{color:var(--text-tertiary);background:0 0}.sidebar-footer{border-top:1px solid var(--border-primary);padding:1rem}.logout-button{color:#a0a0a0;cursor:pointer;width:100%;transition:all var(--transition-base);font-size:var(--font-size-sm);background:0 0;border:none;align-items:center;gap:.75rem;padding:.75rem 1rem;display:flex}.project-configuration{background-color:var(--bg-primary);min-height:100vh;display:flex}.configuration-content{flex:1;margin-left:250px}.configuration-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);z-index:10;padding:1.5rem 2rem;position:sticky;top:0}.configuration-header .header-content{max-width:1400px;margin:0 auto}.configuration-header .header-left h1{color:var(--text-primary);margin:0;font-size:1.5rem}.configuration-section{max-width:800px;margin:2rem auto;padding:0 2rem}.info-banner{border-radius:var(--radius-md);color:#1e40af;background:#eff6ff;border:1px solid #bfdbfe;align-items:start;gap:1rem;margin-bottom:2rem;padding:1rem;display:flex}.info-banner svg{flex-shrink:0;margin-top:.125rem}.error-banner{border-radius:var(--radius-md);color:#991b1b;background:#fee2e2;border:1px solid #fecaca;margin-bottom:1rem;padding:1rem}.success-banner{border-radius:var(--radius-md);color:#065f46;background:#d1fae5;border:1px solid #a7f3d0;margin-bottom:1rem;padding:1rem}.configuration-form{background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid #e2e8f0;margin-bottom:2rem;padding:2rem}.form-group{margin-bottom:1.5rem}.form-group:last-of-type{margin-bottom:2rem}.form-group label{color:#1e293b;flex-direction:column;gap:.25rem;margin-bottom:.5rem;font-weight:600;display:flex}.help-text{color:#64748b;font-size:.875rem;font-weight:400}.form-input{border-radius:var(--radius-sm);width:100%;transition:all var(--transition-base);border:1px solid #e2e8f0;padding:.75rem;font-size:1rem}.form-input:focus{border-color:var(--color-secondary);outline:none;box-shadow:0 0 0 3px #3b82f61a}.input-hint{color:#64748b;margin-top:.5rem;font-size:.875rem}.form-actions{border-top:1px solid #e2e8f0;justify-content:flex-end;padding-top:1rem;display:flex}.save-btn{background:var(--color-secondary);color:#fff;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-base);border:none;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;display:flex}.save-btn:hover:not(:disabled){background:var(--color-info);transform:translateY(-1px);box-shadow:0 4px 6px #0000001a}.save-btn:disabled{cursor:not-allowed;background:#94a3b8}.configuration-info{background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid #e2e8f0;padding:2rem}.configuration-info h3{color:#1e293b;margin-top:0;margin-bottom:1rem}.configuration-info ul{margin:0;padding-left:1.5rem}.configuration-info li{color:#475569;margin-bottom:1rem;line-height:1.6}.configuration-info li:last-child{margin-bottom:0}.configuration-info strong{color:#1e293b}.error-state h2{color:var(--color-error-dark);margin-bottom:.5rem}.error-state p{color:#64748b;margin-bottom:1.5rem}.back-button{background:var(--color-secondary);color:#fff;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-base);border:none;padding:.75rem 1.5rem;font-size:1rem}.constraints-section-config{margin-top:2rem}.constraints-section-config h2{color:#1e293b;margin-bottom:.5rem;font-size:1.25rem}.section-description{color:#64748b;margin-bottom:1.5rem;font-size:.875rem}.constraints-notification{border-radius:var(--radius-md);background:#fef3c7;border:1px solid #fcd34d;align-items:center;gap:1rem;margin-top:2rem;margin-bottom:2rem;padding:1.5rem;display:flex}.constraints-notification svg{color:var(--color-warning-dark);flex-shrink:0}.notification-content{color:#92400e;flex:1}.notification-content p{margin:0 0 .5rem}.notification-content p:last-child{margin-bottom:0}.view-recommendations-btn{background:var(--color-warning-dark);color:#fff;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;border:none;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.875rem;font-weight:500;display:flex}.view-recommendations-btn:hover{background:#b45309;transform:translateY(-1px);box-shadow:0 4px 6px #0000001a}@media (width<=768px){.constraints-notification{flex-direction:column;align-items:flex-start}.view-recommendations-btn{justify-content:center;width:100%}}.recommendation-list{background:var(--bg-primary);min-height:100vh;font-family:Aptos,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;display:flex}.recommendation-content{flex-direction:column;flex:1;margin-left:250px;padding:0;display:flex}.recommendation-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);margin-bottom:0;padding:24px 32px}.recommendation-header .header-content{justify-content:space-between;align-items:center;gap:var(--space-lg);display:flex}.recommendation-header h1{color:#1a1a1a;margin:0;font-size:28px;font-weight:600}.back-btn{align-items:center;gap:var(--space-xs);background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border-secondary);border-radius:var(--radius-md);font-weight:500;font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);padding:10px 16px;text-decoration:none;display:inline-flex}.back-btn:hover{background:var(--bg-primary);border-color:var(--text-muted)}.header-right{align-items:center;gap:var(--space-sm);display:flex}.refresh-btn{align-items:center;gap:var(--space-xs);color:#fff;border-radius:var(--radius-md);font-weight:500;font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);background:linear-gradient(135deg,#48bb78 0%,#38a169 100%);border:none;padding:10px 16px;display:inline-flex;box-shadow:0 2px 4px #48bb7833}.refresh-btn:hover:not(:disabled){background:linear-gradient(135deg,#38a169 0%,#2f855a 100%);transform:translateY(-1px);box-shadow:0 4px 8px #48bb784d}.refresh-btn .spinning{animation:1s linear infinite spin}.refresh-message{border-radius:var(--radius-md);margin:1rem 2rem;padding:1rem 1.5rem;font-weight:500;animation:.3s ease-out slideDown}.refresh-message.success{color:#22543d;background:#c6f6d5;border:1px solid #9ae6b4}.refresh-message.error{color:#742a2a;background:#fed7d7;border:1px solid #fc8181}.recommendation-section{padding:var(--space-xl);flex:1}.section-header{justify-content:space-between;align-items:flex-start;margin-bottom:24px;display:flex}.section-header h2{font-size:var(--font-size-2xl);color:var(--text-primary);margin:0 0 8px;font-weight:600}.section-header p{color:var(--text-tertiary);margin:0;line-height:1.5}.search-container-recommendation{min-width:300px;position:relative}.search-input-recommendation{border:1px solid var(--border-secondary);border-radius:var(--radius-md);width:100%;font-size:var(--font-size-sm);color:var(--text-secondary);transition:all var(--transition-base);padding:10px 12px 10px 40px}.search-input-recommendation:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #c026d31a}.search-icon-recommendation{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.recommendations-table{background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-primary);overflow:hidden}.recommendations-table .table-header{gap:var(--space-sm);background:var(--bg-primary);border-bottom:1px solid var(--border-primary);font-weight:600;font-size:var(--font-size-xs);text-transform:uppercase;color:var(--text-tertiary);letter-spacing:.05em;grid-template-columns:1fr 1.5fr 1fr 1fr .8fr 1fr 1fr 1.2fr;padding:16px 20px;display:grid}.recommendations-table .table-body{flex-direction:column;display:flex}.recommendations-table .table-row{gap:var(--space-sm);border-bottom:1px solid var(--border-subtle);cursor:pointer;transition:all var(--transition-base);grid-template-columns:1fr 1.5fr 1fr 1fr .8fr 1fr 1fr 1.2fr;padding:16px 20px;font-size:.9rem;display:grid;position:relative}.recommendations-table .table-row:hover{background:var(--bg-primary)}.recommendations-table .table-row.selected{color:#fff;background:#f97316}.recommendations-table .table-row:last-child{border-bottom:none}.selection-indicator{color:#fff;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.data-source-badge{border-radius:var(--radius-sm);text-transform:uppercase;padding:.25rem .5rem;font-size:.75rem;font-weight:600;display:inline-block}.data-source-badge.benchmark{color:#1565c0;background-color:#e3f2fd}.data-source-badge.model{color:#6a1b9a;background-color:#f3e5f5}.data-source-badge.unknown{color:#757575;background-color:#f5f5f5}.pagination-simple{border-top:1px solid var(--border-primary);font-size:var(--font-size-sm);color:var(--text-tertiary);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.pagination-info{align-items:center;gap:var(--space-xs);display:flex}.rows-select{border:1px solid var(--border-secondary);border-radius:var(--radius-sm);background:var(--bg-secondary);font-size:var(--font-size-sm);color:var(--text-secondary);padding:4px 8px}.page-info{margin-left:16px}.pagination-controls{gap:var(--space-xs);display:flex}.pagination-btn{border:1px solid var(--border-secondary);border-radius:var(--radius-sm);background:var(--bg-secondary);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-base);font-size:var(--font-size-sm);justify-content:center;align-items:center;display:flex}.pagination-btn:hover:not(:disabled){border-color:var(--text-muted);background:#f3f4f6}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.deploy-section,.action-section{justify-content:center;gap:var(--space-md);padding:var(--space-lg);border-top:1px solid var(--border-primary);margin-top:24px;display:flex}.deploy-btn{align-items:center;gap:var(--space-xs);background:linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);color:#fff;border-radius:var(--radius-md);font-weight:600;font-size:var(--font-size-base);cursor:pointer;transition:all var(--transition-slow);border:none;padding:12px 24px;display:inline-flex;box-shadow:0 4px 12px #c026d34d}.deploy-btn:hover{background:linear-gradient(135deg, #d946ef 0%, var(--color-primary) 100%);transform:translateY(-2px);box-shadow:0 6px 16px #c026d366}.back-dashboard-btn{align-items:center;gap:var(--space-xs);background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border-secondary);border-radius:var(--radius-md);font-weight:600;font-size:var(--font-size-base);cursor:pointer;transition:all var(--transition-base);padding:12px 24px;display:inline-flex;box-shadow:0 1px 3px #0000001a}.back-dashboard-btn:hover{background:var(--bg-primary);border-color:var(--text-muted);transform:translateY(-1px);box-shadow:0 4px 6px #0000001a}.loading-state,.error-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:400px;padding:48px;display:flex}.error-state h2{font-size:var(--font-size-2xl);color:var(--text-primary);margin:0 0 16px;font-weight:600}.error-state p{color:var(--text-tertiary);margin:0 0 24px}.back-button{align-items:center;gap:var(--space-xs);background:var(--color-primary);color:#fff;border-radius:var(--radius-md);font-weight:500;font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);border:none;padding:10px 16px;text-decoration:none;display:inline-flex}.back-button:hover{background:var(--color-primary-dark)}@media (width<=768px){.recommendation-section{padding:var(--space-md)}.section-header{gap:var(--space-md);flex-direction:column;align-items:stretch}.search-container-recommendation{min-width:auto}.recommendations-table .table-header,.recommendations-table .table-row{gap:var(--space-xs);grid-template-columns:1fr}.recommendations-table .table-header{display:none}.pagination-simple{gap:var(--space-md);flex-direction:column}.pagination-info{gap:var(--space-xs);flex-direction:column}}.model-summary-box{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);gap:2rem;margin:1.5rem 2rem;padding:1.5rem;display:flex;box-shadow:0 1px 3px #0000001a}.summary-section{flex:1;gap:1rem;display:flex}.summary-icon{color:var(--color-primary);align-items:flex-start;padding-top:.25rem;display:flex}.summary-content{flex:1}.summary-title{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin:0 0 .5rem;font-size:.875rem;font-weight:600}.summary-value{color:var(--text-primary);margin:0;font-size:1.125rem;font-weight:600}.summary-divider{background:#e5e7eb;width:1px}.summary-params{flex-wrap:wrap;gap:1.5rem;display:flex}.param-item{flex-direction:column;gap:.25rem;display:flex}.param-label{color:var(--text-tertiary);font-size:.875rem}.param-value{color:var(--text-primary);font-size:1rem;font-weight:600}@media (width<=768px){.model-summary-box{flex-direction:column;gap:1.5rem;margin:1rem;padding:1rem}.summary-divider{width:100%;height:1px}.summary-params{gap:1rem}}.deployment-container{max-width:1200px;margin:0}.deployment-header{margin-bottom:32px}.deployment-header h1{font-size:var(--font-size-2xl);color:var(--text-primary);margin:16px 0 0;font-weight:600}.back-btn{align-items:center;gap:var(--space-xs);color:var(--text-secondary);border:1px solid var(--border-secondary);border-radius:var(--radius-md);font-weight:500;font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);background:#f3f4f6;padding:8px 16px;display:inline-flex}.back-btn:hover{background:#e5e7eb}.deployment-content{padding:0}.deployment-description{font-size:var(--font-size-base);color:var(--text-tertiary);margin-bottom:40px;line-height:1.6}.deployment-options{gap:var(--space-lg);grid-template-columns:repeat(3,1fr);margin-top:32px;display:grid}@media (width<=1200px){.deployment-options{grid-template-columns:1fr}}.deployment-card{border:2px solid var(--border-primary);border-radius:var(--radius-xl);padding:var(--space-xl);transition:all var(--transition-slow);text-align:center;background:#fff;flex-direction:column;align-items:center;display:flex}.deployment-card:hover{border-color:var(--color-primary);transform:translateY(-4px);box-shadow:0 8px 24px #c026d326}.card-icon{border-radius:var(--radius-xl);justify-content:center;align-items:center;width:80px;height:80px;margin-bottom:24px;display:flex}.hosted-icon{background:var(--gradient-success);color:#fff}.iac-icon{background:var(--gradient-purple-dark);color:#fff}.manual-icon{background:var(--gradient-info);color:#fff}.deployment-card h3{font-size:var(--font-size-xl);color:var(--text-primary);margin:0 0 8px;font-weight:600}.card-subtitle{font-size:var(--font-size-sm);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin:0 0 16px;font-weight:600}.deployment-card p{font-size:var(--font-size-sm);color:var(--text-tertiary);margin:0 0 24px;line-height:1.6}.deployment-btn{border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-slow);border:none;width:100%;max-width:280px;padding:12px 24px;font-size:15px;font-weight:600}.hosted-btn{background:var(--gradient-success);color:#fff;box-shadow:0 4px 12px #10b9814d}.hosted-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #10b98166}.iac-btn{background:var(--gradient-purple-dark);color:#fff;box-shadow:0 4px 12px #7c3aed4d}.iac-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #7c3aed66}.manual-btn{background:var(--gradient-info);color:#fff;box-shadow:0 4px 12px #2563eb4d}.manual-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #2563eb66}@media (width<=768px){.deployment-card{padding:var(--space-lg)}.card-icon{width:64px;height:64px}.deployment-card h3{font-size:var(--font-size-lg)}}.deployment-instructions-container{max-width:900px;padding:var(--space-lg);margin:0 auto}.instructions-header{justify-content:space-between;align-items:center;margin-bottom:32px;display:flex}.header-actions{align-items:center;gap:var(--space-sm);display:flex}.cache-badge{color:#065f46;border-radius:var(--radius-sm);font-size:var(--font-size-sm);background:#d1fae5;align-items:center;gap:6px;padding:6px 12px;font-weight:500;display:inline-flex}.clear-cache-btn{color:#92400e;border-radius:var(--radius-sm);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);background:#fef3c7;border:1px solid #fbbf24;align-items:center;gap:6px;padding:6px 12px;font-weight:500;display:inline-flex}.clear-cache-btn:hover{border-color:var(--color-warning);background:#fde68a}.download-btn{color:#1e40af;border:1px solid var(--color-secondary);border-radius:var(--radius-sm);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);background:#dbeafe;align-items:center;gap:6px;padding:6px 12px;font-weight:500;display:inline-flex}.download-btn:hover{border-color:var(--color-info);background:#bfdbfe}.loading-container{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:400px;display:flex}.spinner{color:var(--color-secondary);animation:1s linear infinite spin}.loading-container h2{font-size:var(--font-size-2xl);color:#1f2937;margin-top:24px;font-weight:600}.loading-container p{color:var(--text-tertiary);margin-top:8px;font-size:15px}.error-container{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:400px;display:flex}.error-icon{color:var(--color-error-dark)}.error-container h2{font-size:var(--font-size-2xl);color:#1f2937;margin-top:24px;font-weight:600}.error-container p{color:var(--text-tertiary);max-width:500px;margin-top:8px;font-size:15px}.btn-secondary{align-items:center;gap:var(--space-xs);color:#374151;border:1px solid var(--border-secondary);border-radius:var(--radius-md);font-weight:500;font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);background:#f3f4f6;padding:10px 20px;display:inline-flex}.btn-primary{align-items:center;gap:var(--space-xs);background:var(--color-secondary);color:#fff;border-radius:var(--radius-md);font-weight:500;font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);border:none;padding:10px 20px;display:inline-flex}.instructions-content{border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-xl);background:#fff;line-height:1.7}.instructions-content h1{color:#1f2937;margin:0 0 16px;font-size:32px;font-weight:700}.instructions-content h2{font-size:var(--font-size-2xl);color:#1f2937;border-bottom:2px solid #e5e7eb;margin:32px 0 16px;padding-bottom:8px;font-weight:600}.instructions-content h3{font-size:var(--font-size-xl);color:#374151;margin:24px 0 12px;font-weight:600}.instructions-content h4{font-size:var(--font-size-base);color:#4b5563;margin:16px 0 8px;font-weight:600}.instructions-content p{color:#374151;margin:12px 0}.instructions-content ul,.instructions-content ol{color:#374151;margin:12px 0 12px 24px}.instructions-content li{margin:8px 0}.instructions-content a{color:var(--color-secondary);border-bottom:1px solid #0000;text-decoration:none;transition:border-color .2s}.instructions-content a:hover{border-bottom-color:var(--color-secondary)}.instructions-content code{color:var(--color-error-dark);border-radius:var(--radius-sm);background:#f3f4f6;padding:2px 6px;font-family:Courier New,Courier,monospace;font-size:.9em}.instructions-content blockquote{border-left:4px solid var(--color-secondary);color:var(--text-tertiary);margin:16px 0;padding-left:16px;font-style:italic}.instructions-content strong{color:#1f2937;font-weight:600}.code-block-wrapper{border-radius:var(--radius-md);border:1px solid var(--border-primary);margin:16px 0;overflow:hidden}.code-block-header{background:#1f2937;border-bottom:1px solid #374151;justify-content:space-between;align-items:center;padding:8px 16px;display:flex}.code-language{font-size:var(--font-size-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.copy-button{color:#d1d5db;border-radius:var(--radius-sm);font-size:var(--font-size-xs);cursor:pointer;transition:all var(--transition-base);background:0 0;border:1px solid #4b5563;align-items:center;gap:6px;padding:4px 10px;font-weight:500;display:inline-flex}.copy-button:hover{color:#f3f4f6;border-color:var(--text-tertiary);background:#374151}.code-block-wrapper pre{padding:var(--space-md);white-space:pre;word-wrap:normal;word-break:normal;background:#1f2937;border-radius:0;margin:0;overflow-x:auto}.code-block-wrapper code{color:inherit;font-size:var(--font-size-sm);white-space:pre;word-wrap:normal;word-break:normal;background:0 0;padding:0;line-height:1.6}.code-block-wrapper>div{max-width:100%;overflow-x:auto}.instructions-footer{border-top:1px solid var(--border-primary);text-align:center;margin-top:32px;padding-top:16px}.instructions-footer p{font-size:var(--font-size-sm);color:var(--text-muted);margin:0}.confirmation-content{border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-xl);background:#fff}.confirmation-content h2{font-size:var(--font-size-2xl);color:#1f2937;margin:0 0 8px;font-weight:600}.confirmation-content>p{color:var(--text-tertiary);margin-bottom:24px}.config-summary{border:1px solid var(--border-primary);border-radius:var(--radius-md);padding:var(--space-lg);background:#f9fafb;margin-bottom:24px}.config-summary h3{font-size:var(--font-size-lg);color:#1f2937;margin:0 0 16px;font-weight:600}.config-details{gap:var(--space-sm);grid-template-columns:repeat(auto-fit,minmax(250px,1fr));display:grid}.config-details div{font-size:var(--font-size-sm);color:#374151}.config-details strong{color:#1f2937;margin-right:8px;font-weight:600}.prompt-preview{margin-bottom:24px}.prompt-preview h3{font-size:var(--font-size-base);color:#1f2937;margin:0 0 12px;font-weight:600}.prompt-text{color:#f3f4f6;padding:var(--space-md);white-space:pre-wrap;word-wrap:break-word;font-family:Courier New,Courier,monospace;font-size:var(--font-size-sm);background:#1f2937;border-radius:0 0 8px 8px;margin:0;line-height:1.6;overflow-x:auto}@media (width<=768px){.deployment-instructions-container{padding:var(--space-md)}.instructions-content,.confirmation-content{padding:var(--space-lg)}.instructions-content h1{font-size:var(--font-size-2xl)}.instructions-content h2{font-size:var(--font-size-xl)}.instructions-content h3{font-size:var(--font-size-lg)}.error-actions{flex-direction:column;width:100%}.error-actions button{width:100%}.config-details{grid-template-columns:1fr}.format-options{flex-direction:column}.format-btn{width:100%}}.format-selector{padding:var(--space-lg);border:1px solid var(--border-primary);border-radius:var(--radius-md);background:#f9fafb;margin:24px 0}.format-selector h3{font-size:var(--font-size-base);color:#111827;margin:0 0 8px;font-weight:600}.format-description{font-size:var(--font-size-sm);color:var(--text-tertiary);margin:0 0 16px}.format-options{gap:var(--space-md);grid-template-columns:1fr 1fr;display:grid}.format-btn{align-items:flex-start;gap:var(--space-sm);padding:var(--space-md);border:2px solid var(--border-primary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);text-align:left;background:#fff;display:flex}.format-btn:hover{border-color:var(--color-secondary);box-shadow:0 2px 8px #3b82f61a}.format-btn.active{border-color:var(--color-secondary);background:#eff6ff}.format-btn svg{color:var(--text-tertiary);flex-shrink:0;transition:color .2s}.format-btn:hover svg,.format-btn.active svg{color:var(--color-secondary)}.format-content{gap:var(--space-xs);flex-direction:column;display:flex}.format-content strong{font-size:var(--font-size-sm);color:#111827;font-weight:600}.format-content p{font-size:var(--font-size-sm);color:var(--text-tertiary);margin:0}.format-detail{font-size:var(--font-size-xs);color:var(--text-muted);margin-top:4px;font-style:italic;display:inline-block}.opentofu-container{max-width:1200px;margin:0 auto;padding:1.5rem}.opentofu-header{margin-bottom:1.5rem}.opentofu-header h1{color:#2c3e50;margin-bottom:.25rem;font-size:1.5rem}.opentofu-header .subtitle{color:#6c757d;font-size:.95rem}.config-summary{border-radius:var(--radius-sm);background:#fff;border:1px solid #dee2e6;margin-bottom:1.25rem;padding:1rem}.config-summary h2{color:#2c3e50;align-items:center;gap:.5rem;margin-bottom:1rem;font-size:1.05rem;font-weight:600;display:flex}.config-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem;display:grid}.config-item{border-radius:var(--radius-sm);background:#f8f9fa;border-left:3px solid #007bff;flex-direction:column;gap:.25rem;padding:.75rem;display:flex}.config-item strong{color:#6c757d;text-transform:uppercase;letter-spacing:.5px;font-size:.7rem;font-weight:500}.config-item span{color:#2c3e50;font-size:.9rem;font-weight:600}.files-preview{border-radius:var(--radius-sm);background:#fff;border:1px solid #dee2e6;margin-bottom:1.25rem;padding:1rem}.files-preview h2{color:#2c3e50;align-items:center;gap:.5rem;margin-bottom:1rem;font-size:1.05rem;font-weight:600;display:flex}.files-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.5rem;display:grid}.file-item{border-radius:var(--radius-sm);color:#495057;background:#f8f9fa;align-items:center;gap:.4rem;padding:.4rem .6rem;font-family:Courier New,monospace;font-size:.75rem;display:flex}.file-item svg{color:#6c757d;flex-shrink:0}.action-buttons{justify-content:center;gap:.75rem;width:100%;max-width:500px;margin-top:1.5rem;display:flex}.btn-primary,.btn-secondary,.btn-download,.btn-cancel{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-base);border:none;align-items:center;gap:.4rem;padding:.6rem 1.2rem;font-size:.875rem;font-weight:500;display:inline-flex}.btn-primary:hover{background:#0056b3}.btn-secondary:hover{background:#f8f9fa}.btn-download{color:#fff;background:#28a745;padding:1rem 2rem;font-size:1.1rem}.btn-download:hover:not(:disabled){background:#218838}.btn-download:disabled{opacity:.5;cursor:not-allowed}.loading-container,.error-container{flex-direction:column;justify-content:center;align-items:center;gap:1.5rem;min-height:400px;display:flex}.generating-container{flex-direction:column;justify-content:center;align-items:center;gap:2rem;min-height:500px;display:flex}.generating-container h2{color:#2c3e50;font-size:1.8rem}.generating-container p{color:#6c757d;font-size:1.1rem}.progress-bar-container{width:100%;max-width:500px;margin:1rem 0}.progress-bar{border-radius:var(--radius-lg);background:#e9ecef;width:100%;height:24px;overflow:hidden;box-shadow:inset 0 1px 3px #0000001a}.progress-bar-fill{border-radius:var(--radius-lg);background:linear-gradient(90deg,#007bff 0%,#0056b3 100%);height:100%;transition:width .3s;box-shadow:0 0 10px #007bff80}.progress-info{color:#6c757d;justify-content:space-between;margin-top:.5rem;font-size:.875rem;display:flex}.error-inline{border-radius:var(--radius-sm);color:#721c24;background:#f8d7da;border:1px solid #f5c6cb;align-items:center;gap:.5rem;width:100%;max-width:500px;padding:.75rem 1rem;display:flex}.progress-steps{flex-direction:column;gap:1rem;width:100%;max-width:400px;display:flex}.progress-step{border-radius:var(--radius-sm);color:#6c757d;background:#f8f9fa;align-items:center;gap:.75rem;padding:.75rem 1rem;display:flex}.progress-step.completed{color:#28a745}.progress-step.active{color:#007bff;background:#e7f1ff;font-weight:500}.spinner-small{animation:1s linear infinite spin}.ready-container{max-width:800px;margin:0 auto}.success-header{text-align:center;margin-bottom:2rem}.success-header h2{color:#2c3e50;margin:1rem 0;font-size:2rem}.success-header p{color:#6c757d;font-size:1.1rem}.generation-time{color:#28a745;font-size:.95rem;font-weight:600}.download-section{border-radius:var(--radius-md);background:#f8f9fa;flex-direction:column;align-items:center;gap:1rem;margin-bottom:3rem;padding:2rem;display:flex}.expires-notice{color:#6c757d;font-size:.875rem}.next-steps{border-radius:var(--radius-md);background:#fff;border:1px solid #dee2e6;margin-bottom:2rem;padding:1.5rem}.next-steps h3{color:#2c3e50;margin-bottom:1rem;font-size:1.3rem}.next-steps ol{margin-bottom:1rem;margin-left:1.5rem}.next-steps li{color:#495057;margin-bottom:1rem}.next-steps pre{color:#ecf0f1;border-radius:var(--radius-sm);background:#2c3e50;margin-top:.5rem;padding:.5rem .75rem;font-family:Courier New,monospace;font-size:.875rem;overflow-x:auto}.next-steps .note{border-radius:var(--radius-sm);color:#856404;background:#fff3cd;border:1px solid #ffc107;align-items:center;gap:.5rem;margin-top:1rem;padding:.75rem;display:flex}.next-steps code{color:#e83e8c;background:#e9ecef;border-radius:3px;padding:.2rem .4rem;font-family:Courier New,monospace;font-size:.875rem}.package-info{border-radius:var(--radius-md);background:#fff;border:1px solid #dee2e6;margin-bottom:2rem;padding:1.5rem}.package-info h3{color:#2c3e50;margin-bottom:1rem;font-size:1.3rem}.info-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;display:grid}.info-item{flex-direction:column;gap:.25rem;display:flex}.info-item strong{color:#6c757d;font-size:.875rem;font-weight:500}.info-item span{color:#2c3e50;font-size:1rem}.cached-badge,.fresh-badge{border-radius:var(--radius-lg);padding:.25rem .75rem;font-size:.875rem;font-weight:500;display:inline-block}.files-included{border-radius:var(--radius-md);background:#fff;border:1px solid #dee2e6;margin-bottom:2rem;padding:1.5rem}.files-included h3{color:#2c3e50;margin-bottom:1rem;font-size:1.3rem}.cached-badge{color:#155724;background:#d4edda}.fresh-badge{color:#0c5460;background:#d1ecf1}.error-container h2{color:#dc3545;margin-bottom:1rem}.error-container p{color:#6c757d;margin-bottom:1rem}.error-container .error-message{border-radius:var(--radius-md);text-align:left;white-space:pre-wrap;word-break:break-word;background:#f8d7da;border:1px solid #f5c6cb;max-width:600px;padding:1rem 1.5rem;font-family:monospace;font-size:.9rem}.error-actions{gap:1rem;margin-top:1.5rem;display:flex}.btn-danger{color:#fff;border-radius:var(--radius-sm);cursor:pointer;background:#dc3545;border:none;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:1rem;transition:background .2s;display:flex}.btn-danger:disabled{cursor:not-allowed;background:#e4606d}.progress-steps.multi-agent{max-width:500px}.progress-step.phase-header{background:#e9ecef;border-left:3px solid #6c757d;margin-top:.5rem;font-size:.9rem;font-weight:600}.progress-step.phase-header.active{background:#e7f1ff;border-left-color:#007bff}.progress-step.phase-header.completed{background:#d4edda;border-left-color:#28a745}.phase-label{color:#495057}.phase-agents{flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem;padding-left:1rem;display:flex}.progress-step.agent-step{flex:none;min-width:120px;padding:.5rem .75rem;font-size:.85rem}.progress-step.agent-step.pending{opacity:.6}.progress-step.agent-step.in_progress{color:#007bff;background:#e7f1ff;font-weight:500}.progress-step.agent-step.completed{color:#155724;background:#d4edda}.progress-step.agent-step.failed{color:#721c24;background:#f8d7da}.phase-message{color:#6c757d;font-style:italic}.validation-report{border-radius:var(--radius-md);background:#fff;border:1px solid #dee2e6;margin-bottom:2rem;padding:1.5rem}.validation-report.pass{background:#f8fff8;border-color:#28a745}.validation-report.fail{background:#fff8f8;border-color:#dc3545}.validation-report h3{align-items:center;gap:.5rem;margin-bottom:1rem;font-size:1.2rem;display:flex}.validation-summary{flex-wrap:wrap;gap:.75rem;margin-bottom:1rem;display:flex}.issue-count{border-radius:var(--radius-sm);padding:.35rem .75rem;font-size:.85rem;font-weight:500}.issue-count.critical{color:#721c24;background:#f8d7da}.issue-count.high{color:#7a3e00;background:#ffe5d0}.issue-count.medium{color:#856404;background:#fff3cd}.issue-count.low{color:#0c5460;background:#d1ecf1}.issue-count.info{color:#495057;background:#e9ecef}.cost-estimate{border-radius:var(--radius-sm);background:#f8f9fa;padding:.75rem;font-size:.95rem}.cost-breakdown{color:#6c757d;margin-top:.25rem;font-size:.85rem;display:block}.validation-checks{border-top:1px solid #dee2e6;margin-top:1.25rem;padding-top:1rem}.validation-checks h4{color:#495057;margin-bottom:.75rem;font-size:1rem;font-weight:600}.checks-list{flex-direction:column;gap:.75rem;display:flex}.check-item{border-radius:var(--radius-sm);background:#f8f9fa;border-left:3px solid #6c757d;padding:.75rem 1rem}.check-item.severity-critical{background:#fff5f5;border-left-color:#dc3545}.check-item.severity-high{background:#fff8f0;border-left-color:#fd7e14}.check-item.severity-medium{background:#fffcf0;border-left-color:#ffc107}.check-item.severity-low{background:#f0fcff;border-left-color:#17a2b8}.check-item.severity-info{background:#f8f9fa;border-left-color:#6c757d}.check-header{flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.check-status{text-transform:uppercase;letter-spacing:.5px;border-radius:3px;align-items:center;padding:.15rem .5rem;font-size:.7rem;font-weight:600;display:inline-flex}.check-status.pass{color:#155724;background:#d4edda}.check-status.fail{color:#721c24;background:#f8d7da}.check-status.skip{color:#495057;background:#e9ecef}.check-severity{text-transform:uppercase;letter-spacing:.5px;border-radius:3px;align-items:center;padding:.15rem .5rem;font-size:.7rem;font-weight:600;display:inline-flex}.check-severity.critical{color:#721c24;background:#f8d7da}.check-severity.high{color:#7a3e00;background:#ffe5d0}.check-severity.medium{color:#856404;background:#fff3cd}.check-severity.low{color:#0c5460;background:#d1ecf1}.check-severity.info{color:#495057;background:#e9ecef}.check-name{color:#2c3e50;font-size:.9rem;font-weight:500}.check-details{color:#495057;font-size:.85rem}.check-message{margin:0 0 .5rem;line-height:1.4}.check-location{color:#6c757d;align-items:center;gap:.35rem;margin:0 0 .5rem;font-family:Courier New,monospace;font-size:.8rem;display:flex}.check-location svg{flex-shrink:0}.check-remediation{border-radius:var(--radius-sm);background:#ffffffb3;margin:0;padding:.5rem .75rem;font-size:.8rem;line-height:1.4}.check-remediation strong{color:#28a745}.passed-checks-count{color:#28a745;border-top:1px dashed #dee2e6;align-items:center;gap:.35rem;margin-top:.75rem;padding-top:.75rem;font-size:.85rem;font-weight:500;display:flex}.validation-summary-section{margin-bottom:1rem}.validation-note{border-radius:var(--radius-sm);color:#856404;background:#fff8e6;border:1px solid #ffc107;align-items:flex-start;gap:.5rem;margin-top:.75rem;padding:.75rem;font-size:.85rem;line-height:1.4;display:flex}.validation-note svg{flex-shrink:0;margin-top:2px}.post-download-badge{color:#2e7d32;text-transform:uppercase;background:#e8f5e9;border-radius:3px;align-items:center;margin-left:.5rem;padding:.15rem .5rem;font-size:.7rem;font-weight:500;display:inline-flex}.issue-count{cursor:pointer;border:none;font-family:inherit}.issue-count.clickable{cursor:pointer;transition:all var(--transition-base)}.issue-count.clickable:hover{opacity:.85;transform:scale(1.05);box-shadow:0 2px 8px #00000026}.issue-count.clickable:active{transform:scale(.98)}.issue-modal-backdrop{z-index:var(--z-modal);background:#00000080;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.issue-modal{border-radius:var(--radius-lg);background:#fff;flex-direction:column;width:100%;max-width:600px;max-height:80vh;animation:.2s ease-out modalSlideIn;display:flex;box-shadow:0 10px 40px #0003}.issue-modal-header{background:#f8f9fa;border-bottom:1px solid #dee2e6;border-radius:12px 12px 0 0;justify-content:space-between;align-items:center;padding:1rem 1.5rem;display:flex}.issue-modal-title{align-items:center;gap:.75rem;display:flex}.issue-modal-title h3{color:#2c3e50;margin:0;font-size:1.2rem}.issue-modal-close{cursor:pointer;border-radius:var(--radius-sm);color:#6c757d;transition:all var(--transition-base);background:0 0;border:none;padding:.5rem}.issue-modal-close:hover{color:#2c3e50;background:#e9ecef}.issue-modal-content{flex:1;padding:1.5rem;overflow-y:auto}.no-issues{text-align:center;color:#6c757d;padding:2rem;font-size:1rem}.modal-checks-list{flex-direction:column;gap:1rem;display:flex}.modal-check-item{border-radius:var(--radius-md);background:#f8f9fa;border-left:4px solid #6c757d;padding:1rem}.modal-check-item.severity-critical{background:#fff5f5;border-left-color:#dc3545}.modal-check-item.severity-high{background:#fff8f0;border-left-color:#fd7e14}.modal-check-item.severity-medium{background:#fffcf0;border-left-color:#ffc107}.modal-check-item.severity-low{background:#f0fcff;border-left-color:#17a2b8}.modal-check-item.severity-info{background:#f8f9fa;border-left-color:#6c757d}.modal-check-header{flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.75rem;display:flex}.modal-check-header .check-name{color:#2c3e50;font-size:.95rem;font-weight:600}.modal-check-details{color:#495057;font-size:.9rem}.modal-check-details .check-message{margin:0 0 .75rem;line-height:1.5}.modal-check-details .check-location{color:#6c757d;align-items:center;gap:.35rem;margin:0 0 .75rem;font-family:Courier New,monospace;font-size:.85rem;display:flex}.modal-check-details .check-remediation{border-radius:var(--radius-sm);background:#fffc;margin:0;padding:.75rem;font-size:.85rem;line-height:1.5}.modal-check-details .check-remediation strong{color:#28a745}.deployment-instructions{border-radius:var(--radius-md);background:#fff;border:1px solid #dee2e6;margin-bottom:2rem;overflow:hidden}.instructions-toggle{cursor:pointer;color:#2c3e50;background:#f8f9fa;border:none;align-items:center;gap:.75rem;width:100%;padding:1rem 1.5rem;font-size:1.1rem;font-weight:600;transition:background .2s;display:flex}.instructions-toggle:hover{background:#e9ecef}.instructions-toggle span{text-align:left;flex:1}.instructions-content{border-top:1px solid #dee2e6;max-height:600px;padding:1.5rem;overflow-y:auto}.readme-content{white-space:pre-wrap;word-wrap:break-word;color:#2c3e50;border-radius:var(--radius-sm);background:#f8f9fa;margin:0;padding:1rem;font-family:Courier New,monospace;font-size:.85rem;line-height:1.6}@media (width<=768px){.opentofu-container{padding:1rem}.config-grid,.files-grid{grid-template-columns:1fr}.action-buttons{flex-direction:column}.action-buttons button{width:100%}.phase-agents{flex-direction:column;padding-left:.5rem}.progress-step.agent-step{width:100%;min-width:0}.validation-summary{flex-direction:column}.check-header{flex-direction:column;align-items:flex-start;gap:.35rem}.check-status,.check-severity{margin-bottom:.25rem}}.deployments-container{max-width:100%}.empty-state{text-align:center;border-top:1px solid var(--border-subtle);flex-direction:column;justify-content:center;align-items:center;padding:64px 24px;display:flex}.empty-icon{color:var(--text-muted);margin-bottom:16px}.empty-state h3{font-size:var(--font-size-xl);color:var(--text-secondary);margin:0 0 8px;font-weight:600}.empty-state p{color:var(--text-tertiary);max-width:400px;margin:0 0 24px}.deployments-filters{gap:var(--space-sm);flex-wrap:wrap;margin-bottom:24px;display:flex}.filter-input{border:1px solid var(--border-secondary);border-radius:var(--radius-md);min-width:200px;font-size:var(--font-size-sm);background:var(--bg-secondary);color:var(--text-secondary);flex:1;padding:10px 12px;transition:border-color .2s}.filter-input:focus{border-color:#6366f1;outline:none;box-shadow:0 0 0 3px #6366f11a}.filter-select{border:1px solid var(--border-secondary);border-radius:var(--radius-md);font-size:var(--font-size-sm);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;padding:10px 12px;transition:border-color .2s}.deployments-table{background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-primary);box-shadow:var(--shadow-sm);margin-bottom:24px;overflow:hidden}.table-header{gap:var(--space-md);background:var(--bg-tertiary);border-bottom:1px solid var(--border-primary);font-weight:600;font-size:var(--font-size-xs);text-transform:uppercase;color:var(--text-tertiary);letter-spacing:.05em;grid-template-columns:1.5fr .8fr 1fr 1fr 1fr .8fr .8fr 1.2fr;padding:16px 20px;display:grid}.table-body{flex-direction:column;display:flex}.table-row{gap:var(--space-md);padding:var(--space-lg);border-bottom:1px solid var(--border-subtle);transition:all var(--transition-base);grid-template-columns:1.5fr .8fr 1fr 1fr 1fr .8fr .8fr 1.2fr;display:grid}.table-row.clickable{cursor:pointer}.table-row:hover{background:var(--bg-tertiary)}.table-row.clickable:hover{background:var(--bg-hover);box-shadow:0 1px 3px #0000000d}.table-row:last-child{border-bottom:none}.cell{color:var(--text-secondary);font-size:var(--font-size-sm);align-items:center;display:flex}.deployments-table .instance-type{font-family:Courier New,monospace;font-size:var(--font-size-sm);color:var(--text-tertiary)}.status-badge{font-size:var(--font-size-xs);text-transform:capitalize;white-space:nowrap;border-radius:20px;padding:4px 12px;font-weight:500}.status-badge.inactive{background:var(--bg-hover);color:var(--text-tertiary)}.status-badge.generating{color:#92400e;cursor:pointer;background:#fef3c7;align-items:center;display:inline-flex}.status-badge.generating:hover{background:#fde68a}.type-badge{align-items:center;gap:var(--space-xs);border-radius:var(--radius-sm);font-size:var(--font-size-xs);white-space:nowrap;padding:4px 8px;font-weight:500;display:inline-flex}.type-badge.iac-opentofu{color:#1e40af;background:#dbeafe}.type-badge.manual-cli{color:#166534;background:#dcfce7}.type-badge.manual-console{color:#7c3aed;background:#f3e8ff}.metrics-status svg{width:12px;height:12px}.action-buttons{gap:var(--space-xs);display:flex}.btn-primary{border-radius:var(--radius-sm);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);color:#fff;background:linear-gradient(#6366f1 0%,#4f46e5 100%);border:none;align-items:center;gap:6px;padding:6px 12px;font-weight:500;display:flex}.btn-primary svg{width:14px;height:14px}.btn-secondary{border:1px solid var(--border-secondary);border-radius:var(--radius-sm);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);background:var(--bg-secondary);color:var(--text-secondary);align-items:center;gap:6px;padding:6px 12px;font-weight:500;display:flex}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--text-muted);transform:translateY(-1px)}.btn-secondary svg{width:14px;height:14px}.btn-progress{border:1px solid var(--color-warning);border-radius:var(--radius-sm);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);color:#92400e;background:#fef3c7;align-items:center;gap:6px;padding:6px 12px;font-weight:500;display:flex}.btn-progress:hover{border-color:var(--color-warning-dark);background:#fde68a;transform:translateY(-1px);box-shadow:0 2px 8px #f59e0b33}.btn-progress svg{width:14px;height:14px}@media (width<=1200px){.table-header,.table-row{gap:var(--space-sm);grid-template-columns:1.5fr .8fr 1fr 1fr .8fr 1.2fr}.table-header .header-cell:nth-child(5),.table-row .cell:nth-child(5),.table-header .header-cell:nth-child(7),.table-row .cell:nth-child(7){display:none}}@media (width<=768px){.table-header{display:none}.table-row{padding:var(--space-md);gap:var(--space-sm);flex-direction:column;display:flex}.cell{justify-content:space-between;align-items:center;display:flex}.cell:before{content:attr(data-label);color:var(--text-tertiary);font-weight:600;font-size:var(--font-size-xs);text-transform:uppercase}.action-buttons{justify-content:flex-end}}.modal-overlay{z-index:var(--z-modal);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-elevated);border-radius:var(--radius-lg);padding:var(--space-xl);width:90%;max-width:500px;box-shadow:var(--shadow-overlay)}.modal-content h2{font-size:var(--font-size-2xl);color:var(--color-error-dark);margin:0 0 16px;font-weight:600}.modal-content p{color:var(--text-tertiary);margin:0 0 16px;line-height:1.6}.deployment-details{background:var(--bg-tertiary);padding:var(--space-md);border-radius:var(--radius-md);margin-bottom:16px}.deployment-details p{font-size:var(--font-size-sm);margin:4px 0}.warning-box{border-radius:var(--radius-md);padding:var(--space-md);background:#fef3c7;border:1px solid #fbbf24;margin-bottom:16px}.warning-box p{color:#92400e;margin:0 0 8px}.warning-box ul{color:#92400e;margin:8px 0 0 20px;padding:0}.warning-box li{margin:4px 0}.modal-actions{gap:var(--space-sm);justify-content:flex-end;margin-top:24px;display:flex}.modal-actions button{align-items:center;gap:var(--space-xs);display:flex}.btn-danger{background:var(--color-error-dark);color:#fff;border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-size-sm);border:none;align-items:center;gap:6px;padding:10px 20px;font-weight:500;transition:background .2s;display:flex}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-danger:disabled{opacity:.6;cursor:not-allowed}.animate-spin{animation:1s linear infinite spin}.project-deployments{background-color:var(--bg-primary);min-height:100vh;display:flex}.deployments-content{flex:1;margin-left:250px;padding:2rem}.deployments-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);z-index:10;padding:1.5rem 2rem;position:sticky;top:0}.deployments-content .header-content{max-width:1400px;margin:0 auto}.header-left{align-items:center;gap:1rem;display:flex}.deployments-header h1{color:var(--text-primary);margin:0;font-size:1.5rem}.back-btn{border-radius:var(--radius-sm);color:#64748b;cursor:pointer;transition:all var(--transition-base);background:0 0;border:1px solid #e2e8f0;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;display:flex}.back-btn:hover{color:#1e293b;background:#f1f5f9;border-color:#cbd5e1}.refresh-button{color:#fff;border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-size-sm);background:#4a90e2;border:none;padding:8px 16px;font-weight:600;transition:background .2s}.refresh-button:hover:not(:disabled){background:#357abd}.refresh-button:disabled{opacity:.6;cursor:not-allowed}.deployments-section{max-width:1400px;margin:2rem auto;padding:0 2rem}.project-deployments h3{color:#333;font-size:var(--font-size-xl);margin-top:0;margin-bottom:10px}.info-text{color:#666;font-size:var(--font-size-sm);margin-bottom:20px;line-height:1.5}.deployments-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:15px;margin-bottom:20px;display:grid}.deployment-card{background:var(--bg-secondary);border:1px solid var(--border-secondary);border-radius:var(--radius-md);transition:all var(--transition-base);padding:15px;box-shadow:0 2px 4px #0000000d}.deployment-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.deployment-header{justify-content:space-between;gap:var(--space-xs);margin-bottom:12px;display:flex}.cloud-badge{color:#fff;border-radius:var(--radius-lg);font-size:var(--font-size-xs);text-transform:uppercase;background:#4a90e2;padding:4px 10px;font-weight:600}.cached-badge{color:#fff;border-radius:var(--radius-lg);font-size:var(--font-size-xs);background:#5cb85c;padding:4px 10px;font-weight:600}.deployment-info{margin-bottom:12px}.deployment-info h4{color:#333;font-size:var(--font-size-base);margin:0 0 5px;font-weight:600}.deployment-info .region{color:#666;font-size:var(--font-size-sm);margin:3px 0}.deployment-info .model{color:#888;font-size:var(--font-size-xs);white-space:nowrap;text-overflow:ellipsis;margin:3px 0;font-family:Courier New,monospace;overflow:hidden}.deployment-footer{border-top:1px solid #eee;margin-top:12px;padding-top:12px}.deployment-footer .date{font-size:var(--font-size-xs);color:#999}.cache-info{border-radius:var(--radius-sm);font-size:var(--font-size-sm);color:#333;background:#e7f3ff;border-left:4px solid #4a90e2;padding:12px 15px;line-height:1.6}.cache-info strong{color:#2c5f8d}.project-deployments.empty{text-align:center;color:#666;background:var(--bg-secondary);border:2px dashed var(--border-secondary);padding:40px 20px}.project-deployments.empty p{font-size:var(--font-size-base);margin:10px 0}.help-text{font-size:var(--font-size-sm);color:#999;margin-top:10px}.loading{text-align:center;color:#64748b;padding:2rem}.error{border-radius:var(--radius-md);color:#991b1b;background:#fee2e2;border:1px solid #fecaca;margin-bottom:1rem;padding:1rem}.empty-state{text-align:center;background:var(--bg-secondary);border-radius:var(--radius-lg);color:#64748b;border:2px dashed #e2e8f0;padding:4rem 2rem}.empty-state p{margin:.5rem 0;font-size:1rem}.deployments-table-container{background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid #e2e8f0;overflow:hidden}.deployments-table{border-collapse:collapse;width:100%}.deployments-table thead{border-bottom:1px solid var(--border-primary);background:#4a90e2}.deployments-table th{padding:var(--space-sm);text-align:left;color:#fff;font-weight:600;font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.5px}.deployments-table tbody tr{border-bottom:1px solid var(--border-primary);transition:background-color .2s}.deployments-table tbody tr:last-child{border-bottom:none}.deployments-table tbody tr:hover{background:#f8fafc}.deployments-table td{color:#1e293b;padding:1rem}.model-cell{color:#64748b;font-family:Courier New,monospace;font-size:.875rem}.actions-cell{gap:.5rem;display:flex}.action-button{border-radius:var(--radius-sm);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;border:none;padding:6px 12px;font-weight:600}.view-button{color:#fff;background:#4a90e2}.view-button:hover:not(:disabled){background:#357abd}.download-button{color:#fff;background:#5cb85c}.download-button:hover:not(:disabled){background:#4a9a4a}.delete-button{color:#fff;background:#d9534f}.delete-button:hover:not(:disabled){background:#c9302c}.connect-button{color:#fff;background:#8b5cf6}.connect-button:hover:not(:disabled){background:#7c3aed}.action-button:disabled{opacity:.5;cursor:not-allowed}.modal-overlay{z-index:var(--z-modal);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-secondary);border-radius:var(--radius-lg);width:90%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a}.modal-small{max-width:500px}.modal-header{border-bottom:1px solid var(--border-primary);justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.modal-header h3{color:#1e293b;margin:0;font-size:1.25rem}.modal-close{color:#64748b;cursor:pointer;border-radius:var(--radius-sm);width:2rem;height:2rem;transition:all var(--transition-base);background:0 0;border:none;justify-content:center;align-items:center;padding:0;font-size:1.5rem;display:flex}.modal-close:hover{color:#1e293b;background:#f1f5f9}.button{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-base);border:none;padding:.75rem 1.5rem;font-size:1rem;font-weight:500}.secondary-button{color:#475569;background:#f1f5f9}.secondary-button:hover:not(:disabled){background:#e2e8f0}.button:disabled{opacity:.6;cursor:not-allowed}.detail-section:last-child{margin-bottom:0}.detail-section h4{color:#1e293b;margin:0 0 1rem;font-size:1rem;font-weight:600}.detail-grid{grid-template-columns:repeat(2,1fr);gap:1rem;display:grid}.detail-item{flex-direction:column;gap:.25rem;display:flex}.detail-item label{color:#64748b;font-size:.875rem;font-weight:500}.detail-item span{color:#1e293b;font-size:1rem}.file-list{max-height:200px;margin:0;padding-left:1.5rem;overflow-y:auto}.file-list li{color:#475569;margin-bottom:.5rem;font-family:Courier New,monospace;font-size:.875rem}.deployment-info{border-radius:var(--radius-md);color:#475569;background:#f8fafc;margin:1rem 0;padding:1rem;line-height:1.6}.delete-options{margin-top:1.5rem}.checkbox-label{cursor:pointer;color:#1e293b;align-items:center;gap:.5rem;font-weight:500;display:flex}.delete-hint{color:#64748b;margin-top:.75rem;padding-left:1.75rem;font-size:.875rem;line-height:1.5}.type-badge{border-radius:var(--radius-lg);text-transform:uppercase;letter-spacing:.5px;padding:4px 10px;font-size:11px;font-weight:600;display:inline-block}.status-badge{border-radius:var(--radius-lg);text-transform:uppercase;letter-spacing:.5px;padding:4px 10px;font-size:11px;font-weight:600;display:inline-block}.status-badge.status-pending{color:#92400e;background:#fef3c7}.status-badge.status-generating{color:#1e40af;background:#dbeafe;animation:2s ease-in-out infinite pulse}.status-badge.status-completed{color:#065f46;background:#d1fae5}.status-badge.status-failed{color:#991b1b;background:#fee2e2}.status-badge.status-cancelled{color:var(--text-secondary);background:#e5e7eb}.status-badge.status-unknown{color:var(--text-tertiary);background:#f3f4f6}.instructions-content{border-radius:var(--radius-md);background:#f8fafc;border:1px solid #e2e8f0;max-height:500px;padding:1rem;overflow-y:auto}.instructions-content pre{font-family:Courier New,monospace;font-size:var(--font-size-sm);white-space:pre-wrap;word-wrap:break-word;color:#1e293b;margin:0;line-height:1.6}@media (width<=768px){.project-deployments{margin:20px 0;padding:15px}.deployments-grid{grid-template-columns:1fr}.deployment-header{flex-wrap:wrap}.cache-info{font-size:var(--font-size-sm);padding:10px}}@media (width<=480px){.project-deployments h3{font-size:var(--font-size-lg)}.deployment-card{padding:var(--space-sm)}.info-text{font-size:var(--font-size-sm)}}.deployments-table-wrapper{background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-primary);overflow:hidden;box-shadow:0 1px 3px #0000001a}.deployments-content .table-header{gap:var(--space-md);font-weight:600;font-size:var(--font-size-sm);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;background:#f9fafb;border-bottom:2px solid #e5e7eb;grid-template-columns:1.5fr 1fr 1fr 1fr .8fr .8fr 1.2fr;padding:16px 20px;display:grid}.header-cell{align-items:center;display:flex}.deployments-content .table-body{flex-direction:column;display:flex}.deployments-content .table-row{gap:var(--space-md);padding:var(--space-lg);border-bottom:1px solid var(--border-subtle);transition:all var(--transition-base);grid-template-columns:1.5fr 1fr 1fr 1fr .8fr .8fr 1.2fr;display:grid}.deployments-content .table-row.clickable{cursor:pointer}.deployments-content .table-row:hover{background:#f9fafb}.deployments-content .table-row.clickable:hover{background:#eff6ff;box-shadow:0 1px 3px #0000000d}.deployments-content .table-row:last-child{border-bottom:none}.cell{font-size:var(--font-size-sm);color:var(--text-secondary);align-items:center;display:flex}.project-name{color:var(--text-primary);font-weight:500}.deployments-content .instance-type{font-family:Monaco,Courier New,monospace;font-size:var(--font-size-sm);color:var(--text-secondary);background:var(--bg-hover);border-radius:var(--radius-sm);padding:4px 8px}.status-badge{border-radius:var(--radius-lg);font-size:var(--font-size-xs);text-transform:capitalize;align-items:center;padding:4px 12px;font-weight:600;display:inline-flex}.status-badge.active{color:#065f46;background:#d1fae5}.status-badge.pending{color:#92400e;background:#fef3c7}.status-badge.error{color:#991b1b;background:#fee2e2}.status-badge.inactive{color:var(--text-tertiary);background:#f3f4f6}.metrics-status{font-size:var(--font-size-sm);align-items:center;gap:6px;font-weight:500;display:flex}.metrics-status.connected{color:var(--color-success-dark)}.metrics-status.disconnected{color:var(--text-tertiary)}.action-buttons{gap:var(--space-xs)}.btn-primary,.btn-secondary{border-radius:var(--radius-sm);font-size:var(--font-size-sm);transition:all var(--transition-base);cursor:pointer;border:none;align-items:center;gap:6px;padding:8px 14px;font-weight:500;display:inline-flex}.btn-primary{color:#fff;background:linear-gradient(#6366f1 0%,#4f46e5 100%)}.btn-primary:hover{background:linear-gradient(#4f46e5 0%,#4338ca 100%);transform:translateY(-1px);box-shadow:0 2px 8px #4f46e54d}.btn-secondary{color:var(--text-secondary);border:1px solid var(--border-secondary);background:linear-gradient(#f3f4f6 0%,#e5e7eb 100%)}.btn-secondary:hover{border-color:var(--text-muted);background:linear-gradient(#e5e7eb 0%,#d1d5db 100%)}.back-link{align-items:center;gap:var(--space-xs);color:#6366f1;font-size:var(--font-size-sm);margin-bottom:16px;font-weight:500;text-decoration:none;transition:color .2s;display:inline-flex}.back-link:hover{color:#4f46e5}.loading-state,.empty-state,.error-message{text-align:center;padding:48px 24px}.empty-state{justify-content:center;align-items:center;gap:var(--space-md);flex-direction:column;padding:64px 24px;display:flex}.empty-state p{color:var(--text-tertiary);margin:0}@media (width<=1200px){.table-header,.table-row{gap:var(--space-sm);grid-template-columns:1.5fr 1fr 1fr .8fr 1.2fr}.table-header .header-cell:nth-child(4),.table-row .cell:nth-child(4){display:none}}@media (width<=768px){.table-header{display:none}.table-row{padding:var(--space-md);gap:var(--space-sm);flex-direction:column;display:flex}.cell{justify-content:space-between}.cell:before{content:attr(data-label);color:var(--text-tertiary);font-weight:600;font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.5px}.action-buttons{flex-wrap:wrap}}.connection-status-wrapper{align-items:center;gap:var(--space-sm);flex-direction:column;margin-bottom:16px;display:flex}.connection-status-not-connected{align-items:center;gap:var(--space-sm);flex-direction:column;width:100%;display:flex}.not-connected-badge{align-items:center;gap:var(--space-xs);color:#92400e;border-radius:var(--radius-md);font-size:var(--font-size-base);text-transform:uppercase;letter-spacing:.05em;background:linear-gradient(135deg,#fef3c7 0%,#fde68a 100%);border:1px solid #fcd34d;padding:12px 24px;font-weight:600;display:inline-flex}.disconnected-indicator{background:var(--color-warning);border-radius:50%;width:10px;height:10px}.connect-button{align-items:center;gap:var(--space-xs);background:var(--color-secondary);color:#fff;border-radius:var(--radius-sm);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);border:none;padding:10px 20px;font-weight:500;display:inline-flex}.connect-button:hover{background:#3182ce;transform:translateY(-1px);box-shadow:0 2px 8px #4299e14d}.connect-button:active{transform:translateY(0)}.deploy-button{justify-content:center;align-items:center;gap:var(--space-xs);color:#fff;border-radius:var(--radius-md);font-size:var(--font-size-base);text-transform:uppercase;letter-spacing:.05em;cursor:pointer;transition:all var(--transition-base);background:#8b5cf6;border:none;padding:12px 32px;font-weight:600;display:inline-flex;box-shadow:0 2px 4px #8b5cf633}.deploy-button:hover{background:#7c3aed;transform:translateY(-2px);box-shadow:0 4px 8px #8b5cf64d}.deploy-button:active{transform:translateY(0);box-shadow:0 2px 4px #8b5cf633}.deploy-button:after{content:"→";transition:transform .2s}.deploy-button:hover:after{transform:translate(4px)}.connection-separator{align-items:center;gap:var(--space-sm);width:100%;color:var(--text-muted);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.1em;display:flex}.connection-separator:before,.connection-separator:after{content:"";background:#e5e7eb;flex:1;height:1px}.connect-external-link{color:var(--text-tertiary);font-size:var(--font-size-sm);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;padding:0;text-decoration:none;transition:color .2s;display:inline-flex}.connect-external-link:hover{color:#8b5cf6}.connect-external-link svg{transition:transform .2s}.connect-external-link:hover svg{transform:scale(1.1)}.connection-status-connected{align-items:center;gap:var(--space-sm);flex-direction:column;width:100%;display:flex}.connected-badge{align-items:center;gap:var(--space-xs);color:var(--color-success-dark);border-radius:var(--radius-md);font-size:var(--font-size-base);text-transform:uppercase;letter-spacing:.05em;background:linear-gradient(135deg,#ecfdf5 0%,#d1fae5 100%);border:1px solid #a7f3d0;padding:12px 24px;font-weight:600;display:inline-flex}.connected-indicator{background:var(--color-success);border-radius:50%;width:10px;height:10px;animation:2s infinite pulse}.connection-details{width:100%;padding:var(--space-sm);border-radius:var(--radius-md);border:1px solid var(--border-primary);background:#f9fafb}.connection-detail-row{font-size:var(--font-size-sm);justify-content:space-between;align-items:center;padding:4px 0;display:flex}.connection-detail-label{color:var(--text-tertiary);font-weight:500}.connection-detail-value{color:#1f2937;font-family:Monaco,Menlo,monospace;font-weight:500;font-size:var(--font-size-xs);text-overflow:ellipsis;white-space:nowrap;max-width:200px;overflow:hidden}.disconnect-button{color:var(--text-tertiary);border:1px solid var(--border-secondary);border-radius:var(--radius-sm);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);background:#fff;align-items:center;gap:6px;padding:8px 16px;font-weight:500;display:inline-flex}.disconnect-button:hover{color:var(--color-error-dark);background:#fef2f2;border-color:#fecaca}.connection-status-deployed{justify-content:center;align-items:center;gap:var(--space-xs);color:var(--color-success-dark);border-radius:var(--radius-md);font-size:var(--font-size-base);text-transform:uppercase;letter-spacing:.05em;background:linear-gradient(135deg,#ecfdf5 0%,#d1fae5 100%);border:1px solid #a7f3d0;padding:12px 32px;font-weight:600;display:inline-flex}@media (width<=480px){.connection-detail-value{max-width:140px}}.connection-modal-overlay{z-index:var(--z-modal);padding:var(--space-md);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.connection-modal{border-radius:var(--radius-lg);background:#fff;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 10px 25px #0003}.connection-modal-header{border-bottom:1px solid var(--border-primary);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.connection-modal-header h2{font-size:var(--font-size-lg);color:#1a1a1a;align-items:center;gap:var(--space-xs);margin:0;font-weight:600;display:flex}.connection-modal-close{cursor:pointer;color:var(--text-tertiary);border-radius:var(--radius-sm);transition:all var(--transition-base);background:0 0;border:none;padding:4px}.connection-modal-close:hover{color:#374151;background:#f3f4f6}.connection-modal-body{padding:var(--space-lg)}.connection-modal-description{color:var(--text-tertiary);font-size:var(--font-size-sm);margin:0 0 24px;line-height:1.5}.connection-form{flex-direction:column;gap:20px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{font-size:var(--font-size-sm);color:#374151;align-items:center;gap:var(--space-xs);font-weight:500;display:flex}.form-group label .required{color:var(--color-error)}.form-group input,.form-group select{border:1px solid var(--border-secondary);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:#1a1a1a;transition:all var(--transition-base);background:#fff;padding:10px 12px}.form-group input:focus,.form-group select:focus{border-color:#8b5cf6;outline:none;box-shadow:0 0 0 3px #8b5cf61a}.form-group input::placeholder{color:var(--text-muted)}.form-group input.error{border-color:var(--color-error)}.form-group .field-error{font-size:var(--font-size-xs);color:var(--color-error);margin-top:2px}.form-group .field-hint{font-size:var(--font-size-xs);color:var(--text-tertiary)}.form-group-optional{opacity:.9}.form-group-optional label{color:var(--text-tertiary)}.connection-test-result{gap:var(--space-xs);padding:var(--space-sm);border-radius:var(--radius-md);font-size:var(--font-size-sm);flex-direction:column;display:flex}.connection-test-result.success{color:var(--color-success-dark);background:#ecfdf5;border:1px solid #a7f3d0}.connection-test-result.error{color:var(--color-error-dark);background:#fef2f2;border:1px solid #fecaca}.test-result-header{align-items:center;gap:var(--space-xs);display:flex}.test-result-message{flex:1;font-weight:500}.test-result-latency{font-size:var(--font-size-xs);opacity:.8;font-weight:400}.test-result-details{font-size:var(--font-size-sm);opacity:.9;white-space:pre-line;padding-left:26px;line-height:1.5}.connection-test-result .latency{font-size:var(--font-size-xs);opacity:.8;margin-left:auto}.form-group .field-hint code{border-radius:var(--radius-sm);font-size:var(--font-size-xs);background:#f3f4f6;padding:2px 6px;font-family:monospace}.connection-modal-footer{justify-content:flex-end;gap:var(--space-sm);border-top:1px solid var(--border-primary);background:#f9fafb;border-radius:0 0 12px 12px;padding:16px 24px;display:flex}.btn-cancel{color:#374151;border:1px solid var(--border-secondary);border-radius:var(--radius-md);font-weight:500;font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);background:#fff;padding:10px 16px}.btn-cancel:hover{border-color:var(--text-muted);background:#f9fafb}.btn-test{color:#374151;border:1px solid var(--border-secondary);border-radius:var(--radius-md);font-weight:500;font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);background:#f3f4f6;align-items:center;gap:6px;padding:10px 16px;display:flex}.btn-test:hover:not(:disabled){background:#e5e7eb}.btn-test:disabled{opacity:.5;cursor:not-allowed}.btn-connect{color:#fff;border-radius:var(--radius-md);font-weight:500;font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);background:#8b5cf6;border:none;align-items:center;gap:6px;padding:10px 20px;display:flex}.btn-connect:hover:not(:disabled){background:#7c3aed}.btn-connect:disabled{opacity:.5;cursor:not-allowed}.btn-connect.loading,.btn-test.loading{pointer-events:none;position:relative}.spinner{animation:1s linear infinite spin}.prefilled-info{border-radius:var(--radius-md);padding:var(--space-md);background:#f8fafc;border:1px solid #e2e8f0;margin-bottom:20px}.prefilled-info h4{font-size:var(--font-size-sm);color:#374151;margin:0 0 12px;font-weight:600}.prefilled-grid{gap:var(--space-sm);grid-template-columns:repeat(2,1fr);display:grid}.prefilled-item{gap:var(--space-xs);flex-direction:column;display:flex}.prefilled-label{font-size:var(--font-size-xs);color:var(--text-tertiary)}.prefilled-value{font-size:var(--font-size-sm);color:#1f2937;font-family:monospace}@media (width<=480px){.connection-modal{max-width:100%;margin:var(--space-xs);max-height:calc(100vh - 32px)}.connection-modal-footer{gap:var(--space-xs);flex-direction:column-reverse}.connection-modal-footer button{justify-content:center;width:100%}}:root{--metric-value:#06b6d4;--status-good:#10b981;--status-warning:#f59e0b;--status-critical:#ef4444}.metrics-dashboard{gap:var(--space-lg);flex-direction:column;display:flex}.metrics-dashboard-header{justify-content:space-between;align-items:center;display:flex}.metrics-dashboard-header h2{font-size:var(--font-size-xl);color:#1a1a1a;margin:0;font-weight:600}.metrics-dashboard-controls{align-items:center;gap:var(--space-sm);display:flex}.metrics-last-updated{font-size:var(--font-size-xs);color:var(--text-tertiary)}.metrics-refresh-btn{align-items:center;gap:var(--space-xs);color:#374151;border:1px solid var(--border-secondary);border-radius:var(--radius-sm);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);background:#fff;padding:6px 12px;display:flex}.metrics-refresh-btn:hover{border-color:var(--text-muted);background:#f9fafb}.metrics-refresh-btn:disabled{opacity:.5;cursor:not-allowed}.metrics-refresh-btn .spinner{animation:1s linear infinite spin}.metrics-sections-grid{grid-template-columns:repeat(2,1fr);gap:20px;display:grid}.metrics-sections-grid>.metrics-section-card .chart-card{box-shadow:none;border:none;margin-bottom:0;padding:0}.metrics-section-card{border:1px solid var(--border-primary);border-radius:var(--radius-md);padding:var(--space-md);background:#f9fafb}.metrics-section-header{align-items:center;gap:var(--space-xs);border-bottom:1px solid var(--border-primary);margin-bottom:16px;padding-bottom:12px;display:flex}.metrics-section-header svg{color:var(--text-tertiary)}.metrics-section-header h3{font-size:var(--font-size-sm);color:#374151;text-transform:uppercase;letter-spacing:.05em;margin:0;font-weight:600}.metrics-section-content{gap:var(--space-sm);flex-direction:column;display:flex}.metric-card{gap:var(--space-xs);flex-direction:column;display:flex}.metric-card-header{align-items:center;gap:var(--space-xs);display:flex}.metric-card-label{font-size:var(--font-size-xs);color:var(--text-tertiary);font-weight:500}.metric-card-tooltip{color:var(--text-muted);cursor:help}.metric-card-tooltip:hover{color:var(--text-tertiary)}.metric-card-value-wrapper{align-items:baseline;gap:var(--space-xs);display:flex}.metric-card-value{font-size:var(--font-size-2xl);color:var(--metric-value);font-weight:700;line-height:1}.metric-card-unit{font-size:var(--font-size-sm);opacity:.8;margin-left:2px;font-weight:500}.metric-card-subvalue{font-size:var(--font-size-xs);color:var(--text-muted)}.metric-card-loading{align-items:center;height:28px;display:flex}.progress-bar-container{width:100%}.progress-bar-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.progress-bar-label{font-size:var(--font-size-xs);color:var(--text-tertiary);font-weight:500}.progress-bar-value{font-size:var(--font-size-xs);color:#374151;font-weight:500}.progress-bar-track{border-radius:var(--radius-sm);background:#e5e7eb;width:100%;height:8px;overflow:hidden}.progress-bar-fill{border-radius:var(--radius-sm);height:100%;transition:width .3s,background-color .3s}.status-badge{border-radius:var(--radius-lg);font-size:var(--font-size-xs);align-items:center;gap:6px;padding:4px 10px;font-weight:500;display:inline-flex}.status-badge-dot{border-radius:50%;width:6px;height:6px}.status-badge.pulse .status-badge-dot{animation:2s infinite pulse-badge}@keyframes pulse-badge{0%,to{opacity:1}50%{opacity:.5}}.tooltip-wrapper{align-items:center;display:inline-flex;position:relative}.tooltip-icon{color:var(--text-muted);cursor:help}.tooltip-icon:hover{color:var(--text-tertiary)}.tooltip-content{color:#fff;font-size:var(--font-size-xs);border-radius:var(--radius-sm);white-space:nowrap;white-space:normal;max-width:250px;z-index:var(--z-dropdown);background:#1f2937;margin-bottom:8px;padding:8px 12px;line-height:1.4;position:absolute;bottom:100%;left:50%;transform:translate(-50%);box-shadow:0 4px 12px #00000026}.tooltip-arrow{background:#1f2937;width:8px;height:8px;position:absolute;bottom:-4px;left:50%;transform:translate(-50%)rotate(45deg)}.gpu-content{gap:var(--space-md)}.gpu-progress-item{margin-bottom:4px}.gpu-metrics-row{gap:var(--space-md);grid-template-columns:1fr 1fr;display:grid}.queue-counts{gap:var(--space-lg);display:flex}.queue-count-item{gap:var(--space-xs);flex-direction:column;display:flex}.queue-count-label{font-size:var(--font-size-xs);color:var(--text-tertiary);font-weight:500}.queue-count-value{color:var(--metric-value);font-size:28px;font-weight:700}.queue-count-value.running{color:var(--status-good)}.queue-count-value.waiting.warning{color:var(--status-warning)}.queue-count-value.waiting.critical{color:var(--status-critical)}.queue-success-rate{align-items:center;gap:var(--space-sm);display:flex}.queue-error-rate{align-items:center;gap:var(--space-xs);border-radius:var(--radius-sm);font-size:var(--font-size-sm);background:#ef44441a;padding:8px 12px;display:flex}.error-rate-label{color:var(--text-tertiary)}.error-rate-value{color:var(--status-critical);font-weight:600}.metrics-empty-state{text-align:center;color:var(--text-tertiary);flex-direction:column;justify-content:center;align-items:center;padding:48px 24px;display:flex}.metrics-empty-state svg{color:var(--text-muted);margin-bottom:16px}.metrics-empty-state h3{font-size:var(--font-size-lg);color:#374151;margin:0 0 8px;font-weight:600}.metrics-empty-state p{font-size:var(--font-size-sm);color:var(--text-tertiary);max-width:400px;margin:0}.metrics-error{justify-content:center;align-items:center;gap:var(--space-xs);padding:var(--space-md);border-radius:var(--radius-md);color:var(--status-critical);font-size:var(--font-size-sm);background:#ef44441a;border:1px solid #ef444433;display:flex}@media (width<=900px){.metrics-sections-grid{grid-template-columns:1fr}}@media (width<=480px){.metrics-dashboard-header{align-items:flex-start;gap:var(--space-sm);flex-direction:column}.gpu-metrics-row{grid-template-columns:1fr}.queue-counts{gap:var(--space-sm);flex-direction:column}.metric-card-value{font-size:var(--font-size-xl)}.queue-count-value{font-size:var(--font-size-2xl)}}.retention-settings{border-radius:var(--radius-md);padding:var(--space-lg);background:#fff;margin-top:24px;box-shadow:0 1px 3px #0000001a}.retention-header{margin-bottom:20px}.retention-header h3{font-size:var(--font-size-lg);color:#1a202c;margin:0 0 8px;font-weight:600}.retention-description{font-size:var(--font-size-sm);color:#718096;margin:0;line-height:1.5}.retention-display{padding:var(--space-md);border-radius:var(--radius-sm);background-color:#f7fafc;justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.current-setting{gap:var(--space-sm);align-items:center;display:flex}.current-setting .label{font-size:var(--font-size-sm);color:#4a5568;font-weight:500}.current-setting .value{font-size:var(--font-size-base);color:#2d3748;border-radius:var(--radius-sm);background-color:#edf2f7;padding:4px 12px;font-weight:600}.edit-button{background-color:var(--color-secondary);color:#fff;border-radius:var(--radius-sm);font-size:var(--font-size-sm);cursor:pointer;border:none;padding:8px 16px;font-weight:500;transition:background-color .2s}.edit-button:hover{background-color:#3182ce}.retention-editor{padding:var(--space-md);border-radius:var(--radius-sm);background-color:#f7fafc;margin-bottom:16px}.presets-label{font-size:var(--font-size-sm);color:#2d3748;margin-bottom:12px;font-weight:500}.presets{gap:var(--space-sm);grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:20px;display:grid}.preset-button{padding:var(--space-sm);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-base);text-align:center;background-color:#fff;border:2px solid #e2e8f0}.preset-button:hover{border-color:var(--color-secondary);transform:translateY(-2px);box-shadow:0 2px 8px #4299e11a}.preset-button.active{border-color:var(--color-secondary);background-color:#ebf8ff}.preset-label{font-size:var(--font-size-sm);color:#2d3748;margin-bottom:4px;font-weight:600}.preset-storage{font-size:var(--font-size-xs);color:#4a5568;margin-bottom:4px}.preset-description{color:#718096;font-size:11px}.custom-input{align-items:center;gap:var(--space-sm);padding:var(--space-md);border-radius:var(--radius-sm);background-color:#fff;margin-bottom:16px;display:flex}.custom-input label{font-size:var(--font-size-sm);color:#2d3748;min-width:100px;font-weight:500}.custom-input input{border-radius:var(--radius-sm);font-size:var(--font-size-sm);border:1px solid #cbd5e0;width:100px;padding:8px 12px}.custom-input input:focus{border-color:var(--color-secondary);outline:none;box-shadow:0 0 0 3px #4299e11a}.input-hint{font-size:var(--font-size-xs);color:#718096}.error-message{align-items:center;gap:var(--space-xs);padding:var(--space-sm);border-radius:var(--radius-sm);color:#c53030;font-size:var(--font-size-sm);background-color:#fff5f5;border-left:4px solid #fc8181;margin-bottom:16px;display:flex}.actions{justify-content:flex-end;gap:var(--space-sm);display:flex}.cancel-button{color:#4a5568;border-radius:var(--radius-sm);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);background-color:#fff;border:1px solid #cbd5e0;padding:10px 20px;font-weight:500}.cancel-button:hover:not(:disabled){background-color:#f7fafc;border-color:#a0aec0}.cancel-button:disabled{cursor:not-allowed;opacity:.5}.save-button{color:#fff;border-radius:var(--radius-sm);font-size:var(--font-size-sm);cursor:pointer;background-color:#48bb78;border:none;padding:10px 20px;font-weight:500;transition:background-color .2s}.save-button:hover:not(:disabled){background-color:#38a169}.save-button:disabled{cursor:not-allowed;opacity:.7}.retention-info{gap:var(--space-sm);padding:var(--space-sm);border-left:4px solid var(--color-secondary);border-radius:var(--radius-sm);font-size:var(--font-size-sm);color:#2c5282;background-color:#ebf8ff;line-height:1.5;display:flex}.retention-info svg{flex-shrink:0;margin-top:2px}@media (width<=768px){.retention-settings{padding:var(--space-md)}.retention-display{align-items:flex-start;gap:var(--space-sm);flex-direction:column}.presets{grid-template-columns:1fr}.custom-input{flex-direction:column;align-items:flex-start}.custom-input label{min-width:unset}.actions{flex-direction:column-reverse}.actions button{width:100%}}.disconnect-modal-overlay{z-index:var(--z-modal);background-color:#00000080;justify-content:center;align-items:center;animation:.2s ease-in-out fadeIn;display:flex;position:fixed;inset:0}.disconnect-modal{border-radius:var(--radius-md);background:#fff;width:90%;max-width:600px;max-height:90vh;animation:.3s ease-out slideUp;overflow-y:auto;box-shadow:0 4px 12px #00000026}.disconnect-modal-header{border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:24px 24px 16px;display:flex}.disconnect-modal-header h2{font-size:var(--font-size-xl);color:#1a202c;margin:0;font-weight:600}.close-button{cursor:pointer;color:#718096;border-radius:var(--radius-sm);background:0 0;border:none;justify-content:center;align-items:center;padding:4px;transition:background-color .2s;display:flex}.close-button:hover{background-color:#f7fafc}.close-button:disabled{cursor:not-allowed;opacity:.5}.disconnect-modal-body{padding:var(--space-lg)}.connection-details{border-radius:var(--radius-sm);padding:var(--space-md);background-color:#f7fafc;margin-bottom:20px}.detail-row{border-bottom:1px solid #e2e8f0;justify-content:space-between;padding:8px 0;display:flex}.detail-row:last-child{border-bottom:none}.detail-label{color:#4a5568;font-weight:500;font-size:var(--font-size-sm)}.detail-value{color:#1a202c;font-size:var(--font-size-sm);word-break:break-all;text-align:right;max-width:60%}.detail-value.status-active{color:#38a169;font-weight:500}.detail-value.status-inactive{color:#718096}.detail-value.status-error{color:#e53e3e;font-weight:500}.warning-box{gap:var(--space-sm);padding:var(--space-md);border-left:4px solid var(--color-warning);border-radius:var(--radius-sm);background-color:#fef5e7;margin-bottom:16px;display:flex}.warning-box svg{color:var(--color-warning);flex-shrink:0;margin-top:2px}.warning-title{color:#78350f;font-weight:600;font-size:var(--font-size-sm);margin:0 0 4px}.warning-description{color:#92400e;font-size:var(--font-size-sm);margin:0;line-height:1.5}.error-box{align-items:center;gap:var(--space-xs);padding:var(--space-sm);border-left:4px solid var(--color-error);border-radius:var(--radius-sm);color:#991b1b;font-size:var(--font-size-sm);background-color:#fef2f2;display:flex}.error-box svg{flex-shrink:0}.disconnect-modal-footer{justify-content:flex-end;gap:var(--space-sm);background-color:#f7fafc;border-top:1px solid #e2e8f0;padding:16px 24px;display:flex}.btn-secondary{color:#4a5568;border-radius:var(--radius-sm);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);background-color:#fff;border:1px solid #cbd5e0;padding:10px 20px;font-weight:500}.btn-secondary:hover:not(:disabled){background-color:#f7fafc;border-color:#a0aec0}.btn-secondary:disabled{cursor:not-allowed;opacity:.5}.btn-danger{color:#fff;border-radius:var(--radius-sm);font-size:var(--font-size-sm);cursor:pointer;align-items:center;gap:var(--space-xs);background-color:#e53e3e;border:none;padding:10px 20px;font-weight:500;transition:background-color .2s;display:flex}.btn-danger:hover:not(:disabled){background-color:#c53030}.btn-danger:disabled{cursor:not-allowed;opacity:.7}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:14px;height:14px;animation:.8s linear infinite spin}@media (width<=768px){.disconnect-modal{width:95%;max-height:95vh}.disconnect-modal-header h2{font-size:var(--font-size-lg)}.disconnect-modal-body{padding:var(--space-md)}.detail-row{gap:var(--space-xs);flex-direction:column}.detail-value{text-align:left;max-width:100%}.disconnect-modal-footer{padding:12px 16px}}.latency-chart{border-radius:var(--radius-lg);padding:var(--space-lg);border:1px solid var(--border-primary);background:#fff;box-shadow:0 1px 3px #0000001a}.latency-chart .recharts-wrapper,.latency-chart .recharts-text{font-family:inherit}.latency-chart-tooltip{border:1px solid var(--border-primary);border-radius:var(--radius-md);padding:var(--space-sm);background:#fff;box-shadow:0 4px 6px #0000001a}.latency-chart-tooltip .tooltip-label{color:#1a1a1a;font-weight:600;font-size:var(--font-size-sm);margin:0 0 8px}.latency-chart-tooltip .tooltip-value{font-size:var(--font-size-sm);margin:4px 0;font-weight:500}.chart-loading,.chart-empty{height:300px;color:var(--text-tertiary);font-size:var(--font-size-sm);text-align:center;padding:var(--space-lg);justify-content:center;align-items:center;display:flex}.chart-loading{border-radius:var(--radius-md);background:#f9fafb}.chart-empty{border-radius:var(--radius-md);background:#f9fafb;border:2px dashed #e5e7eb}@media (width<=768px){.latency-chart{padding:var(--space-md)}.chart-title{font-size:var(--font-size-base)}}.power-consumption-chart{border-radius:var(--radius-lg);padding:var(--space-lg);border:1px solid var(--border-primary);background:#fff;box-shadow:0 1px 3px #0000001a}.chart-title{font-size:var(--font-size-lg);color:#1a1a1a;margin:0 0 16px;font-weight:600}.power-consumption-chart .recharts-wrapper,.power-consumption-chart .recharts-text{font-family:inherit}.power-chart-tooltip{border:1px solid var(--border-primary);border-radius:var(--radius-md);padding:var(--space-sm);background:#fff;box-shadow:0 4px 6px #0000001a}.tooltip-label{color:#1a1a1a;font-weight:500;font-size:var(--font-size-sm);margin:0 0 8px}.tooltip-value{font-size:var(--font-size-sm);margin:4px 0;font-weight:500}.power-consumption-chart .chart-loading,.power-consumption-chart .chart-empty{height:300px;color:var(--text-tertiary);font-size:var(--font-size-sm);text-align:center;padding:var(--space-lg);justify-content:center;align-items:center;display:flex}.power-consumption-chart .chart-loading{border-radius:var(--radius-md);background:#f9fafb}.power-consumption-chart .chart-empty{border-radius:var(--radius-md);background:#f9fafb;border:2px dashed #e5e7eb}@media (width<=768px){.power-consumption-chart{padding:var(--space-md)}.chart-title{font-size:var(--font-size-base)}}.llm-chat-container{border-radius:var(--radius-lg);border:1px solid var(--border-primary);background:#fff;flex-direction:column;height:600px;display:flex;overflow:hidden;box-shadow:0 1px 3px #0000001a}.llm-chat-header{border-bottom:1px solid var(--border-primary);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.llm-chat-header-info{align-items:center;gap:var(--space-xs);color:var(--text-secondary);display:flex}.llm-chat-title{font-size:var(--font-size-base);color:var(--text-primary);font-weight:600}.llm-chat-model-badge{font-size:var(--font-size-xs);color:#6366f1;border-radius:var(--radius-lg);background:#eef2ff;border:1px solid #c7d2fe;padding:2px 10px;font-weight:500}.llm-chat-clear-btn{border:1px solid var(--border-secondary);border-radius:var(--radius-sm);color:var(--text-tertiary);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);background:#fff;align-items:center;gap:6px;padding:6px 12px;font-weight:500;display:flex}.llm-chat-clear-btn:hover:not(:disabled){border-color:var(--text-muted);color:var(--text-secondary);background:#f9fafb}.llm-chat-clear-btn:disabled{opacity:.4;cursor:not-allowed}.llm-chat-messages{padding:var(--space-lg);gap:var(--space-md);flex-direction:column;flex:1;display:flex;overflow-y:auto}.llm-chat-empty{color:var(--text-muted);text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:40px;display:flex}.llm-chat-empty-icon{color:#d1d5db;margin-bottom:12px}.llm-chat-empty p{font-size:var(--font-size-sm);max-width:300px;margin:0}.llm-chat-message{gap:10px;max-width:85%;display:flex}.llm-chat-message-user{flex-direction:row-reverse;align-self:flex-end}.llm-chat-message-assistant{align-self:flex-start}.llm-chat-message-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.llm-chat-message-user .llm-chat-message-icon{color:#fff;background:#6366f1}.llm-chat-message-assistant .llm-chat-message-icon{color:var(--text-tertiary);background:#f3f4f6}.llm-chat-message-content{border-radius:var(--radius-lg);font-size:var(--font-size-sm);white-space:pre-wrap;word-break:break-word;padding:10px 14px;line-height:1.5}.llm-chat-message-user .llm-chat-message-content{color:#fff;background:#6366f1;border-bottom-right-radius:4px}.llm-chat-message-assistant .llm-chat-message-content{color:var(--text-secondary);background:#f3f4f6;border-bottom-left-radius:4px}.llm-chat-typing-indicator{gap:var(--space-xs);padding:4px 0;display:inline-flex}.llm-chat-typing-indicator span{background:var(--text-muted);border-radius:50%;width:6px;height:6px;animation:1.4s ease-in-out infinite both llm-chat-bounce}.llm-chat-typing-indicator span:first-child{animation-delay:-.32s}.llm-chat-typing-indicator span:nth-child(2){animation-delay:-.16s}@keyframes llm-chat-bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.llm-chat-error{align-items:center;gap:var(--space-xs);border-radius:var(--radius-md);color:var(--color-error-dark);font-size:var(--font-size-sm);background:#fef2f2;border:1px solid #fecaca;padding:10px 14px;display:flex}.llm-chat-input-area{border-top:1px solid var(--border-primary);flex-shrink:0;align-items:flex-end;gap:10px;padding:16px 20px;display:flex}.llm-chat-input{border:1px solid var(--border-secondary);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--text-secondary);resize:none;background:#fff;outline:none;flex:1;max-height:150px;padding:10px 14px;font-family:inherit;line-height:1.5;transition:border-color .2s,box-shadow .2s}.llm-chat-input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.llm-chat-input:disabled{color:var(--text-muted);background:#f9fafb}.llm-chat-input::placeholder{color:var(--text-muted)}.llm-chat-send-btn{border-radius:var(--radius-md);color:#fff;cursor:pointer;width:40px;height:40px;transition:all var(--transition-base);background:linear-gradient(#6366f1 0%,#4f46e5 100%);border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.llm-chat-send-btn:hover:not(:disabled){background:linear-gradient(#4f46e5 0%,#4338ca 100%);transform:translateY(-1px);box-shadow:0 2px 8px #6366f14d}.llm-chat-send-btn:disabled{opacity:.4;cursor:not-allowed}@media (width<=768px){.llm-chat-container{height:500px}.llm-chat-message{max-width:95%}.llm-chat-header{padding:12px 16px}.llm-chat-messages{padding:var(--space-md)}.llm-chat-input-area{padding:12px 16px}}.deployment-dashboard{max-width:1400px;margin:0 auto}.breadcrumb{align-items:center;gap:var(--space-xs);font-size:var(--font-size-sm);color:var(--text-tertiary);margin-bottom:16px;display:flex}.breadcrumb a{color:#6366f1;text-decoration:none;transition:color .2s}.breadcrumb a:hover{color:#4f46e5}.breadcrumb span{color:var(--text-secondary);font-weight:500}.breadcrumb-name{cursor:pointer;border-radius:var(--radius-sm);align-items:center;gap:6px;margin:-2px -6px;padding:2px 6px;transition:background .15s;display:inline-flex}.breadcrumb-name:hover{background:#f3f4f6}.breadcrumb-edit-icon{color:var(--text-muted);opacity:0;transition:opacity .15s}.breadcrumb-name:hover .breadcrumb-edit-icon{opacity:1}.breadcrumb-name-input{font-size:var(--font-size-sm);color:var(--text-secondary);border-radius:var(--radius-sm);background:#fff;border:1px solid #6366f1;outline:none;padding:2px 6px;font-weight:500;box-shadow:0 0 0 3px #6366f11a}.dashboard-tabs{gap:var(--space-xs);border-radius:var(--radius-md);background:#f3f4f6;margin-bottom:24px;padding:4px;display:flex}.dashboard-tab{align-items:center;gap:var(--space-xs);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--text-tertiary);cursor:pointer;transition:all var(--transition-base);background:0 0;border:none;padding:10px 20px;font-weight:500;display:flex}.dashboard-tab:hover{color:#4f46e5;background:#fff9}.dashboard-tab.active{color:#6366f1;background:#fff;box-shadow:0 1px 3px #0000001a}.connection-config{border-radius:var(--radius-lg);border:1px solid var(--border-primary);padding:var(--space-lg);background:#fff;margin-bottom:24px;box-shadow:0 1px 3px #0000001a}.connection-config h3{font-size:var(--font-size-lg);color:var(--text-primary);margin:0 0 20px;font-weight:600}.connection-config-form{gap:var(--space-md);flex-direction:column;display:flex}.connection-config-field label{font-weight:500;font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:6px;display:block}.connection-config-field input{border:1px solid var(--border-secondary);border-radius:var(--radius-md);width:100%;font-size:var(--font-size-sm);color:var(--text-secondary);box-sizing:border-box;background:#fff;padding:10px 12px;transition:border-color .2s,box-shadow .2s}.connection-config-field input:focus{border-color:#6366f1;outline:none;box-shadow:0 0 0 3px #6366f11a}.connection-config-actions{gap:var(--space-sm);margin-top:4px;display:flex}.connection-test-inline{align-items:center;gap:var(--space-xs);border-radius:var(--radius-md);font-size:var(--font-size-sm);flex-wrap:wrap;padding:12px 16px;display:flex}.connection-test-inline.success{color:#15803d;background:#f0fdf4;border:1px solid #86efac}.connection-test-inline.error{color:var(--color-error-dark);background:#fef2f2;border:1px solid #fecaca}.connection-test-inline .test-latency{color:var(--text-tertiary);font-size:var(--font-size-sm)}.connection-test-inline .test-details{width:100%;font-size:var(--font-size-sm);opacity:.85;margin-top:2px}.deployment-status-bar{align-items:center;gap:var(--space-sm);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:#0f172a;background:linear-gradient(135deg,#f0f9ff 0%,#e0f2fe 100%);border:1px solid #bae6fd;margin-bottom:24px;padding:10px 16px;font-weight:500;display:flex}.status-bar-item{align-items:center;display:inline-flex}.status-bar-separator{color:#94a3b8;font-weight:300}.time-range-selector{gap:var(--space-xs);padding:var(--space-md);border-radius:var(--radius-lg);border:1px solid var(--border-primary);background:#fff;margin-bottom:24px;display:flex}.time-range-btn{border:1px solid var(--border-secondary);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);background:#fff;padding:8px 16px;font-weight:500}.time-range-btn:hover{border-color:var(--text-muted);background:#f9fafb}.time-range-btn.active{color:#fff;background:linear-gradient(#6366f1 0%,#4f46e5 100%);border-color:#4f46e5}.kpis{gap:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:24px;display:grid}.kpi-card{border-radius:var(--radius-lg);border:1px solid var(--border-primary);padding:var(--space-lg);transition:all var(--transition-base);background:#fff;box-shadow:0 1px 3px #0000001a}.kpi-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.kpi-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.kpi-title{align-items:center;gap:var(--space-xs);font-size:var(--font-size-sm);color:var(--text-tertiary);font-weight:500;display:flex}.kpi-icon{width:18px;height:18px;color:var(--text-muted)}.kpi-unit{font-size:var(--font-size-base);color:var(--text-tertiary);margin-left:4px}.kpi-subtitle{font-size:var(--font-size-sm);color:var(--text-muted)}.chart-card{border-radius:var(--radius-lg);border:1px solid var(--border-primary);padding:var(--space-lg);background:#fff;margin-bottom:24px;box-shadow:0 1px 3px #0000001a}.chart-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.chart-title{font-size:var(--font-size-lg);color:var(--text-primary);font-weight:600}.chart-container{height:300px;position:relative}.chart-loading{height:100%;color:var(--text-muted);font-size:var(--font-size-sm);justify-content:center;align-items:center;display:flex}.chart-error{height:100%;color:var(--color-error-dark);font-size:var(--font-size-sm);justify-content:center;align-items:center;display:flex}.retention-settings{border-radius:var(--radius-lg);border:1px solid var(--border-primary);padding:var(--space-lg);background:#fff;margin-bottom:24px;box-shadow:0 1px 3px #0000001a}.retention-settings h3{font-size:var(--font-size-lg);color:var(--text-primary);margin:0 0 16px;font-weight:600}.retention-controls{align-items:center;gap:var(--space-sm);display:flex}.retention-input{border:1px solid var(--border-secondary);border-radius:var(--radius-md);font-size:var(--font-size-sm);width:120px;color:var(--text-secondary);background:#fff;padding:10px 12px}.retention-input:focus{border-color:#6366f1;outline:none;box-shadow:0 0 0 3px #6366f11a}.btn-save{border-radius:var(--radius-md);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);background:linear-gradient(180deg, var(--color-success) 0%, var(--color-success-dark) 100%);color:#fff;border:none;align-items:center;gap:6px;padding:10px 16px;font-weight:500;display:flex}.btn-save:hover{background:linear-gradient(180deg, var(--color-success-dark) 0%, #047857 100%);transform:translateY(-1px);box-shadow:0 2px 8px #10b9814d}.btn-save:disabled{opacity:.5;cursor:not-allowed;transform:none}.danger-zone{border-radius:var(--radius-lg);padding:var(--space-lg);background:#fff;border:2px solid #fee2e2;margin-bottom:24px}.danger-zone h3{font-size:var(--font-size-lg);color:var(--color-error-dark);margin:0 0 8px;font-weight:600}.danger-zone p{font-size:var(--font-size-sm);color:var(--text-tertiary);margin:0 0 16px}.btn-danger{align-items:center;gap:var(--space-xs);border-radius:var(--radius-md);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);background:linear-gradient(180deg, var(--color-error) 0%, var(--color-error-dark) 100%);color:#fff;border:none;padding:10px 16px;font-weight:500;display:flex}.btn-danger:hover{background:linear-gradient(180deg, var(--color-error-dark) 0%, #b91c1c 100%);transform:translateY(-1px);box-shadow:0 2px 8px #ef44444d}.btn-danger svg{width:16px;height:16px}.loading-state{color:var(--text-tertiary);font-size:var(--font-size-base);justify-content:center;align-items:center;padding:48px;display:flex}.error-message{color:var(--color-error-dark);border-radius:var(--radius-md);background:#fee2e2;border:1px solid #fecaca;margin-bottom:24px;padding:12px 16px}.status-indicator{border-radius:50%;width:12px;height:12px;margin-right:8px;display:inline-block}.status-indicator.active{background:linear-gradient(135deg, var(--color-success) 0%, var(--color-success-dark) 100%);box-shadow:0 0 8px #10b98166}.status-indicator.pending{background:linear-gradient(135deg, var(--color-warning) 0%, var(--color-warning-dark) 100%);box-shadow:0 0 8px #f59e0b66}.status-indicator.error{background:linear-gradient(135deg, var(--color-error) 0%, var(--color-error-dark) 100%);box-shadow:0 0 8px #ef444466}.kpi-grid{gap:var(--space-md);grid-template-columns:repeat(3,1fr);margin-bottom:24px;display:grid}@media (width<=1200px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}.kpi-item{border-radius:var(--radius-md);padding:var(--space-lg);transition:all var(--transition-base);background:#fff;border:1px solid #e2e8f0}.kpi-item:hover{border-color:var(--color-secondary);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.kpi-label{font-size:var(--font-size-sm);color:#64748b;margin-bottom:8px;font-weight:500}.kpi-value{color:#0f172a;margin-bottom:4px;font-size:32px;font-weight:700}.kpi-unit{font-size:var(--font-size-sm);color:#94a3b8;font-weight:400}@media (width<=768px){.kpis,.kpi-grid{grid-template-columns:1fr}.chart-container{height:250px}.retention-controls{flex-direction:column;align-items:stretch}.retention-input{width:100%}.dashboard-tabs{gap:var(--space-xs)}.dashboard-tab{font-size:var(--font-size-sm);flex:1;justify-content:center;padding:8px 12px}.connection-config-actions{flex-direction:column}}.settings-container{max-width:800px;margin:0;padding:0}.page-description{color:var(--text-tertiary);margin-bottom:2rem;font-size:.95rem;line-height:1.6}.settings-section{background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-primary);margin-bottom:2.5rem;padding:2rem}.settings-section h3{color:var(--text-primary);border-bottom:1px solid var(--border-primary);margin:0 0 1.5rem;padding-bottom:.5rem;font-size:1.2rem;font-weight:600}.form-group{flex-direction:column;gap:.75rem;margin-bottom:1.5rem;display:flex}.form-group label{color:var(--text-primary);margin-bottom:0;font-size:.95rem;font-weight:600}.settings-input{border:1px solid var(--border-secondary);border-radius:var(--radius-md);transition:all var(--transition-slow);background:var(--bg-input);color:var(--text-primary);padding:.875rem 1rem;font-family:inherit;font-size:1rem}.settings-input::placeholder{color:var(--text-muted)}.settings-input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #c026d31a}.settings-input:disabled{opacity:.6;cursor:not-allowed}.settings-checkbox{accent-color:var(--color-primary);margin-right:.75rem;transform:scale(1.2)}.form-group label:has(.settings-checkbox){cursor:pointer;flex-direction:row;align-items:center}.settings-actions{flex-wrap:wrap;justify-content:center;gap:1rem;margin-top:3rem;display:flex}.save-btn{background:var(--gradient-save);color:#fff;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-slow);border:none;padding:.75rem 1.5rem;font-size:.95rem;font-weight:600;box-shadow:0 2px 8px #c026d34d}.save-btn:hover{background:var(--gradient-save-hover);transform:translateY(-1px);box-shadow:0 4px 12px #c026d366}.save-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.success-message{border-radius:var(--radius-md);color:#4ade80;background:#22c55e33;border:1px solid #22c55e66;margin-top:1rem;padding:1rem;font-weight:500}.error-message{border-radius:var(--radius-md);color:#f87171;background:#ef444433;border:1px solid #ef444466;margin-top:1rem;padding:1rem;font-weight:500}.danger-zone{border-radius:var(--radius-md);background:#ef44440d;border:2px solid #ef44444d;margin-top:3rem;padding:2rem}.danger-zone h3{color:var(--color-error-dark);border-bottom-color:#ef44444d}.danger-warning{color:var(--color-error-dark);margin-bottom:1rem;font-size:.95rem;font-weight:500}.delete-info-list{margin:1rem 0 1.5rem;padding-left:0;list-style:none}.delete-info-list li{color:var(--text-tertiary);padding:.5rem 0 .5rem 1.5rem;font-size:.95rem;position:relative}.delete-info-list li:before{content:"•";color:var(--color-error-dark);font-weight:700;position:absolute;left:.5rem}.delete-btn{background:var(--gradient-danger-alt);color:#fff;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-slow);border:none;padding:.75rem 1.5rem;font-size:.95rem;font-weight:600;box-shadow:0 2px 8px #dc26264d}.delete-btn:hover{background:linear-gradient(135deg, var(--color-error) 0%, var(--color-error-dark) 100%);transform:translateY(-1px);box-shadow:0 4px 12px #dc262666}.delete-confirm-section{background:var(--bg-secondary);border-radius:var(--radius-md);margin-top:1rem;padding:1.5rem}.confirm-text{color:var(--text-primary);text-align:center;margin-bottom:1.5rem;font-weight:500}.delete-btn-confirm{background:linear-gradient(135deg, var(--color-error-dark) 0%, #991b1b 100%);color:#fff;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-slow);border:none;padding:.75rem 1.5rem;font-size:.95rem;font-weight:700;box-shadow:0 2px 8px #dc262666}.delete-btn-confirm:hover{background:linear-gradient(135deg, var(--color-error) 0%, #b91c1c 100%);transform:translateY(-1px);box-shadow:0 4px 12px #dc262680}.delete-btn-confirm:disabled,.delete-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.cancel-btn{background:var(--bg-hover);color:var(--text-secondary);border:1px solid var(--border-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-slow);padding:.75rem 1.5rem;font-size:.95rem;font-weight:600}.cancel-btn:hover{background:var(--bg-active);border-color:var(--text-muted)}.cancel-btn:disabled{opacity:.6;cursor:not-allowed}@media (width<=768px){.settings-container{padding:1rem}.settings-actions{flex-direction:column}.danger-zone{padding:1.5rem}}:root{--toastify-color-light:#fff;--toastify-color-dark:#121212;--toastify-color-info:#3498db;--toastify-color-success:#07bc0c;--toastify-color-warning:#f1c40f;--toastify-color-error:#e74d3c;--toastify-color-transparent:#ffffffb3;--toastify-icon-color-info:var(--toastify-color-info);--toastify-icon-color-success:var(--toastify-color-success);--toastify-icon-color-warning:var(--toastify-color-warning);--toastify-icon-color-error:var(--toastify-color-error);--toastify-container-width:fit-content;--toastify-toast-width:320px;--toastify-toast-offset:16px;--toastify-toast-top:max(var(--toastify-toast-offset), env(safe-area-inset-top));--toastify-toast-right:max(var(--toastify-toast-offset), env(safe-area-inset-right));--toastify-toast-left:max(var(--toastify-toast-offset), env(safe-area-inset-left));--toastify-toast-bottom:max(var(--toastify-toast-offset), env(safe-area-inset-bottom));--toastify-toast-background:#fff;--toastify-toast-padding:14px;--toastify-toast-min-height:64px;--toastify-toast-max-height:800px;--toastify-toast-bd-radius:6px;--toastify-toast-shadow:0px 4px 12px #0000001a;--toastify-font-family:sans-serif;--toastify-z-index:9999;--toastify-text-color-light:#757575;--toastify-text-color-dark:#fff;--toastify-text-color-info:#fff;--toastify-text-color-success:#fff;--toastify-text-color-warning:#fff;--toastify-text-color-error:#fff;--toastify-spinner-color:#616161;--toastify-spinner-color-empty-area:#e0e0e0;--toastify-color-progress-light:linear-gradient(to right, #4cd964, #5ac8fa, #007aff, #34aadc, #5856d6, #ff2d55);--toastify-color-progress-dark:#bb86fc;--toastify-color-progress-info:var(--toastify-color-info);--toastify-color-progress-success:var(--toastify-color-success);--toastify-color-progress-warning:var(--toastify-color-warning);--toastify-color-progress-error:var(--toastify-color-error);--toastify-color-progress-bgo:.2}.Toastify__toast-container{z-index:var(--toastify-z-index);-webkit-transform:translate3d(0, 0, var(--toastify-z-index));width:var(--toastify-container-width);box-sizing:border-box;color:#fff;flex-direction:column;display:flex;position:fixed}.Toastify__toast-container--top-left{top:var(--toastify-toast-top);left:var(--toastify-toast-left)}.Toastify__toast-container--top-center{top:var(--toastify-toast-top);align-items:center;left:50%;transform:translate(-50%)}.Toastify__toast-container--top-right{top:var(--toastify-toast-top);right:var(--toastify-toast-right);align-items:end}.Toastify__toast-container--bottom-left{bottom:var(--toastify-toast-bottom);left:var(--toastify-toast-left)}.Toastify__toast-container--bottom-center{bottom:var(--toastify-toast-bottom);align-items:center;left:50%;transform:translate(-50%)}.Toastify__toast-container--bottom-right{bottom:var(--toastify-toast-bottom);right:var(--toastify-toast-right);align-items:end}.Toastify__toast{--y:0;touch-action:none;width:var(--toastify-toast-width);min-height:var(--toastify-toast-min-height);box-sizing:border-box;padding:var(--toastify-toast-padding);border-radius:var(--toastify-toast-bd-radius);box-shadow:var(--toastify-toast-shadow);max-height:var(--toastify-toast-max-height);font-family:var(--toastify-font-family);z-index:0;word-break:break-word;flex:auto;align-items:center;margin-bottom:1rem;display:flex;position:relative}@media only screen and (width<=480px){.Toastify__toast-container{width:100vw;left:env(safe-area-inset-left);margin:0}.Toastify__toast-container--top-left,.Toastify__toast-container--top-center,.Toastify__toast-container--top-right{top:env(safe-area-inset-top);transform:translate(0)}.Toastify__toast-container--bottom-left,.Toastify__toast-container--bottom-center,.Toastify__toast-container--bottom-right{bottom:env(safe-area-inset-bottom);transform:translate(0)}.Toastify__toast-container--rtl{right:env(safe-area-inset-right);left:initial}.Toastify__toast{--toastify-toast-width:100%;border-radius:0;margin-bottom:0}}.Toastify__toast-container[data-stacked=true]{width:var(--toastify-toast-width)}.Toastify__toast--stacked{width:100%;transform:translate3d(0, var(--y), 0) scale(var(--s));transition:transform .3s;position:absolute}.Toastify__toast--stacked[data-collapsed] .Toastify__toast-body,.Toastify__toast--stacked[data-collapsed] .Toastify__close-button{transition:opacity .1s}.Toastify__toast--stacked[data-collapsed=false]{overflow:visible}.Toastify__toast--stacked[data-collapsed=true]:not(:last-child)>*{opacity:0}.Toastify__toast--stacked:after{content:"";height:calc(var(--g) * 1px);position:absolute;bottom:100%;left:0;right:0}.Toastify__toast--stacked[data-pos=top]{top:0}.Toastify__toast--stacked[data-pos=bot]{bottom:0}.Toastify__toast--stacked[data-pos=bot].Toastify__toast--stacked:before{transform-origin:top}.Toastify__toast--stacked[data-pos=top].Toastify__toast--stacked:before{transform-origin:bottom}.Toastify__toast--stacked:before{content:"";z-index:-1;height:100%;position:absolute;bottom:0;left:0;right:0;transform:scaleY(3)}.Toastify__toast--rtl{direction:rtl}.Toastify__toast--close-on-click{cursor:pointer}.Toastify__toast-icon{flex-shrink:0;width:22px;margin-inline-end:10px;display:flex}.Toastify--animate{animation-duration:.5s;animation-fill-mode:both}.Toastify--animate-icon{animation-duration:.3s;animation-fill-mode:both}.Toastify__toast-theme--dark{background:var(--toastify-color-dark);color:var(--toastify-text-color-dark)}.Toastify__toast-theme--light,.Toastify__toast-theme--colored.Toastify__toast--default{background:var(--toastify-color-light);color:var(--toastify-text-color-light)}.Toastify__toast-theme--colored.Toastify__toast--info{color:var(--toastify-text-color-info);background:var(--toastify-color-info)}.Toastify__toast-theme--colored.Toastify__toast--success{color:var(--toastify-text-color-success);background:var(--toastify-color-success)}.Toastify__toast-theme--colored.Toastify__toast--warning{color:var(--toastify-text-color-warning);background:var(--toastify-color-warning)}.Toastify__toast-theme--colored.Toastify__toast--error{color:var(--toastify-text-color-error);background:var(--toastify-color-error)}.Toastify__progress-bar-theme--light{background:var(--toastify-color-progress-light)}.Toastify__progress-bar-theme--dark{background:var(--toastify-color-progress-dark)}.Toastify__progress-bar--info{background:var(--toastify-color-progress-info)}.Toastify__progress-bar--success{background:var(--toastify-color-progress-success)}.Toastify__progress-bar--warning{background:var(--toastify-color-progress-warning)}.Toastify__progress-bar--error{background:var(--toastify-color-progress-error)}.Toastify__progress-bar-theme--colored.Toastify__progress-bar--info,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--success,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--warning,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--error{background:var(--toastify-color-transparent)}.Toastify__close-button{color:#fff;cursor:pointer;opacity:.7;z-index:1;background:0 0;border:none;outline:none;padding:0;transition:all .3s;position:absolute;top:6px;right:6px}.Toastify__toast--rtl .Toastify__close-button{left:6px;right:unset}.Toastify__close-button--light{color:#000;opacity:.3}.Toastify__close-button>svg{fill:currentColor;width:14px;height:16px}.Toastify__close-button:hover,.Toastify__close-button:focus{opacity:1}@keyframes Toastify__trackProgress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.Toastify__progress-bar{z-index:1;opacity:.7;transform-origin:0;width:100%;height:100%;position:absolute;bottom:0;left:0}.Toastify__progress-bar--animated{animation:linear forwards Toastify__trackProgress}.Toastify__progress-bar--controlled{transition:transform .2s}.Toastify__progress-bar--rtl{right:0;left:initial;transform-origin:100%;border-bottom-left-radius:initial}.Toastify__progress-bar--wrp{border-bottom-left-radius:var(--toastify-toast-bd-radius);border-bottom-right-radius:var(--toastify-toast-bd-radius);width:100%;height:5px;position:absolute;bottom:0;left:0;overflow:hidden}.Toastify__progress-bar--wrp[data-hidden=true]{opacity:0}.Toastify__progress-bar--bg{opacity:var(--toastify-color-progress-bgo);width:100%;height:100%}.Toastify__spinner{box-sizing:border-box;border:2px solid;border-color:var(--toastify-spinner-color-empty-area);border-right-color:var(--toastify-spinner-color);border-radius:100%;width:20px;height:20px;animation:.65s linear infinite Toastify__spin}@keyframes Toastify__bounceInRight{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate(3000px)}60%{opacity:1;transform:translate(-25px)}75%{transform:translate(10px)}90%{transform:translate(-5px)}to{transform:none}}@keyframes Toastify__bounceOutRight{20%{opacity:1;transform:translate3d(-20px, var(--y), 0)}to{opacity:0;transform:translate3d(2000px, var(--y), 0)}}@keyframes Toastify__bounceInLeft{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate(-3000px)}60%{opacity:1;transform:translate(25px)}75%{transform:translate(-10px)}90%{transform:translate(5px)}to{transform:none}}@keyframes Toastify__bounceOutLeft{20%{opacity:1;transform:translate3d(20px, var(--y), 0)}to{opacity:0;transform:translate3d(-2000px, var(--y), 0)}}@keyframes Toastify__bounceInUp{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translateY(3000px)}60%{opacity:1;transform:translateY(-20px)}75%{transform:translateY(10px)}90%{transform:translateY(-5px)}to{transform:translate(0,0)}}@keyframes Toastify__bounceOutUp{20%{transform:translate3d(0, calc(var(--y) - 10px), 0)}40%,45%{opacity:1;transform:translate3d(0, calc(var(--y) + 20px), 0)}to{opacity:0;transform:translateY(-2000px)}}@keyframes Toastify__bounceInDown{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translateY(-3000px)}60%{opacity:1;transform:translateY(25px)}75%{transform:translateY(-10px)}90%{transform:translateY(5px)}to{transform:none}}@keyframes Toastify__bounceOutDown{20%{transform:translate3d(0, calc(var(--y) - 10px), 0)}40%,45%{opacity:1;transform:translate3d(0, calc(var(--y) + 20px), 0)}to{opacity:0;transform:translateY(2000px)}}.Toastify__bounce-enter--top-left,.Toastify__bounce-enter--bottom-left{animation-name:Toastify__bounceInLeft}.Toastify__bounce-enter--top-right,.Toastify__bounce-enter--bottom-right{animation-name:Toastify__bounceInRight}.Toastify__bounce-enter--top-center{animation-name:Toastify__bounceInDown}.Toastify__bounce-enter--bottom-center{animation-name:Toastify__bounceInUp}.Toastify__bounce-exit--top-left,.Toastify__bounce-exit--bottom-left{animation-name:Toastify__bounceOutLeft}.Toastify__bounce-exit--top-right,.Toastify__bounce-exit--bottom-right{animation-name:Toastify__bounceOutRight}.Toastify__bounce-exit--top-center{animation-name:Toastify__bounceOutUp}.Toastify__bounce-exit--bottom-center{animation-name:Toastify__bounceOutDown}@keyframes Toastify__zoomIn{0%{opacity:0;transform:scale3d(.3,.3,.3)}50%{opacity:1}}@keyframes Toastify__zoomOut{0%{opacity:1}50%{opacity:0;transform:translate3d(0, var(--y), 0) scale3d(.3, .3, .3)}to{opacity:0}}.Toastify__zoom-enter{animation-name:Toastify__zoomIn}.Toastify__zoom-exit{animation-name:Toastify__zoomOut}@keyframes Toastify__flipIn{0%{opacity:0;animation-timing-function:ease-in;transform:perspective(400px)rotateX(90deg)}40%{animation-timing-function:ease-in;transform:perspective(400px)rotateX(-20deg)}60%{opacity:1;transform:perspective(400px)rotateX(10deg)}80%{transform:perspective(400px)rotateX(-5deg)}to{transform:perspective(400px)}}@keyframes Toastify__flipOut{0%{transform:translate3d(0, var(--y), 0) perspective(400px)}30%{transform:translate3d(0, var(--y), 0) perspective(400px) rotate3d(1, 0, 0, -20deg);opacity:1}to{transform:translate3d(0, var(--y), 0) perspective(400px) rotate3d(1, 0, 0, 90deg);opacity:0}}.Toastify__flip-enter{animation-name:Toastify__flipIn}.Toastify__flip-exit{animation-name:Toastify__flipOut}@keyframes Toastify__slideInRight{0%{visibility:visible;transform:translate(110%)}to{transform:translate3d(0, var(--y), 0)}}@keyframes Toastify__slideInLeft{0%{visibility:visible;transform:translate(-110%)}to{transform:translate3d(0, var(--y), 0)}}@keyframes Toastify__slideInUp{0%{visibility:visible;transform:translateY(110%)}to{transform:translate3d(0, var(--y), 0)}}@keyframes Toastify__slideInDown{0%{visibility:visible;transform:translateY(-110%)}to{transform:translate3d(0, var(--y), 0)}}@keyframes Toastify__slideOutRight{0%{transform:translate3d(0, var(--y), 0)}to{visibility:hidden;transform:translate3d(110%, var(--y), 0)}}@keyframes Toastify__slideOutLeft{0%{transform:translate3d(0, var(--y), 0)}to{visibility:hidden;transform:translate3d(-110%, var(--y), 0)}}@keyframes Toastify__slideOutDown{0%{transform:translate3d(0, var(--y), 0)}to{visibility:hidden;transform:translateY(500px)}}@keyframes Toastify__slideOutUp{0%{transform:translate3d(0, var(--y), 0)}to{visibility:hidden;transform:translateY(-500px)}}.Toastify__slide-enter--top-left,.Toastify__slide-enter--bottom-left{animation-name:Toastify__slideInLeft}.Toastify__slide-enter--top-right,.Toastify__slide-enter--bottom-right{animation-name:Toastify__slideInRight}.Toastify__slide-enter--top-center{animation-name:Toastify__slideInDown}.Toastify__slide-enter--bottom-center{animation-name:Toastify__slideInUp}.Toastify__slide-exit--top-left,.Toastify__slide-exit--bottom-left{animation-name:Toastify__slideOutLeft;animation-duration:.3s;animation-timing-function:ease-in}.Toastify__slide-exit--top-right,.Toastify__slide-exit--bottom-right{animation-name:Toastify__slideOutRight;animation-duration:.3s;animation-timing-function:ease-in}.Toastify__slide-exit--top-center{animation-name:Toastify__slideOutUp;animation-duration:.3s;animation-timing-function:ease-in}.Toastify__slide-exit--bottom-center{animation-name:Toastify__slideOutDown;animation-duration:.3s;animation-timing-function:ease-in}@keyframes Toastify__spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.admin-dashboard-new{background:var(--bg-primary);min-height:100vh;font-family:Aptos,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;display:flex}.admin-sidebar{border-right:1px solid var(--border-primary);width:200px;height:100vh;z-index:var(--z-modal);background:#1a1a1a;flex-direction:column;display:flex;position:fixed;top:0;left:0;overflow-y:auto}.sidebar-header{border-bottom:1px solid var(--border-primary);padding:24px 16px}.sidebar-logo{align-items:center;text-decoration:none;display:flex}.logo-image{width:auto;height:32px}.sidebar-navigation{flex-direction:column;flex:1;padding:16px 0;display:flex}.nav-section{margin-bottom:8px}.nav-item{align-items:center;gap:var(--space-sm);color:#a0a0a0;border-radius:var(--radius-md);font-size:var(--font-size-sm);transition:all var(--transition-base);cursor:pointer;text-align:left;background:0 0;border:none;width:calc(100% - 16px);margin:0 8px;padding:12px 16px;font-weight:500;text-decoration:none;display:flex}.nav-item:hover{color:#fff;background:#2a2a2a}.nav-item.main-item{position:relative}.nav-item.main-item.active{background:var(--color-primary);color:#fff}.nav-item svg:last-child{margin-left:auto}.sub-menu{margin-top:4px;margin-left:24px}.sub-menu-item{align-items:center;gap:var(--space-xs);color:gray;border-radius:var(--radius-md);font-size:var(--font-size-sm);transition:all var(--transition-base);border-left:2px solid #0000;margin:2px 8px 2px 0;padding:10px 16px;text-decoration:none;display:flex}.sub-menu-item:hover{color:#fff;border-left-color:var(--color-primary);background:#2a2a2a}.sub-menu-item.active{color:#fff;border-left-color:var(--color-primary);background:#2a2a2a;font-weight:600}.sidebar-footer{padding:var(--space-md);border-top:1px solid var(--border-primary);margin-top:auto}.logout-button{align-items:center;gap:var(--space-sm);color:#a0a0a0;border-radius:var(--radius-md);width:100%;font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);text-align:left;background:0 0;border:none;padding:12px 16px;font-weight:500;display:flex}.logout-button:hover{color:#fff;background:#2a2a2a}.admin-content{min-height:100vh;padding:var(--space-xl);flex:1;margin-left:200px}.Toastify__toast{border-radius:var(--radius-md);font-family:inherit;box-shadow:0 4px 12px #00000026}.Toastify__toast--success{background:#48bb78}.Toastify__toast--error{background:#f56565}.Toastify__toast--warning{background:#ed8936}.Toastify__toast--info{background:var(--color-secondary)}.Toastify__progress-bar{background:#ffffffb3}@media (width<=768px){.admin-sidebar{width:60px}.admin-sidebar .nav-item span,.admin-sidebar .sub-menu-item span,.admin-sidebar .logout-button span{display:none}.admin-sidebar .nav-item,.admin-sidebar .logout-button{justify-content:center}.admin-sidebar .sub-menu{margin-left:0}.admin-content{margin-left:60px}}.search-bar{width:100%;max-width:400px;position:relative}.search-icon{width:20px;height:20px;color:var(--text-tertiary);pointer-events:none;position:absolute;top:50%;left:1rem;transform:translateY(-50%)}.search-input{border:2px solid var(--border-primary);background:var(--bg-secondary);width:100%;color:var(--text-primary);border-radius:8px;padding:.75rem 3rem;font-size:1rem;transition:all .2s}.search-input:focus{border-color:#4299e1;outline:none;box-shadow:0 0 0 3px #4299e11a}.search-input::placeholder{color:var(--text-muted)}.search-clear{cursor:pointer;color:var(--text-tertiary);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:.25rem;transition:all .2s;display:flex;position:absolute;top:50%;right:1rem;transform:translateY(-50%)}.search-clear:hover{background:var(--bg-hover);color:var(--text-primary)}.search-clear svg{width:18px;height:18px}@media (width<=768px){.search-bar{max-width:100%}}.pagination-container{border-top:1px solid #e2e8f0;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-top:2rem;padding-top:1.5rem;display:flex}.pagination-info{color:#718096;font-size:.875rem;font-weight:500}.pagination-controls{align-items:center;gap:.5rem;display:flex}.pagination-button{color:#4a5568;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:6px;justify-content:center;align-items:center;min-width:36px;height:36px;padding:.5rem;font-weight:500;transition:all .2s;display:flex}.pagination-button:hover:not(:disabled){color:#4299e1;background:#ebf8ff;border-color:#4299e1}.pagination-button.active{color:#fff;background:#4299e1;border-color:#4299e1;font-weight:600}.pagination-button:disabled{opacity:.4;cursor:not-allowed}.pagination-button svg{width:18px;height:18px}.pagination-ellipsis{color:#a0aec0;padding:.5rem;font-weight:600}@media (width<=640px){.pagination-container{text-align:center;flex-direction:column;align-items:center}.pagination-info{order:2}.pagination-controls{order:1}}.modal-content{background:#fff;border-radius:12px;width:90%;max-width:500px;animation:.3s slideUp;box-shadow:0 20px 60px #0000004d}.modal-header{border-bottom:2px solid var(--border-primary);padding:1.5rem}.modal-header h2{color:#2d3748;margin:0;font-size:1.5rem}.modal-header-danger{border-bottom-color:#f56565}.modal-header-warning{border-bottom-color:#ed8936}.modal-header-info{border-bottom-color:#4299e1}.modal-body{padding:1.5rem}.modal-body p{color:#4a5568;margin:0;line-height:1.6}.modal-footer{border-top:1px solid #e2e8f0;justify-content:flex-end;gap:1rem;padding:1rem 1.5rem;display:flex}.btn-cancel,.btn-confirm{cursor:pointer;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:.875rem;font-weight:600;transition:all .2s}.btn-cancel{color:#2d3748;background:#e2e8f0}.btn-cancel:hover{background:#cbd5e0}.btn-confirm{color:#fff}.btn-confirm-danger{background:#f56565}.btn-confirm-danger:hover{background:#e53e3e}.btn-confirm-warning{background:#ed8936}.btn-confirm-warning:hover{background:#dd6b20}.btn-confirm-info{background:#4299e1}.btn-confirm-info:hover{background:#3182ce}.user-admin{max-width:1400px;margin:0 auto}.stat-card{background:var(--bg-secondary);padding:var(--space-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border-top:4px solid var(--color-secondary)}[data-theme=dark] .stat-card{background:linear-gradient(135deg,#2a2a2a 0%,#1a1a1a 100%);border:1px solid #404040}.stat-card.stat-pending{border-top-color:#ed8936}.stat-card.stat-approved{border-top-color:#48bb78}.stat-card.stat-suspended{border-top-color:#f56565}.stat-card.stat-admin{border-top-color:#9f7aea}.table-container{background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.users-table{border-collapse:collapse;width:100%}.users-table thead{background:linear-gradient(135deg,#3b4a9e 0%,#4a2d6b 100%)}.users-table th{padding:var(--space-md);text-align:left;text-transform:uppercase;font-weight:600;font-size:var(--font-size-xs);letter-spacing:.05em;color:#fff}.users-table tbody tr{background-color:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);transition:background-color .2s}.users-table tbody tr:hover{background-color:var(--bg-tertiary)}.users-table td{padding:var(--space-md);color:var(--text-secondary);font-size:var(--font-size-sm)}.users-table tbody td{color:var(--text-secondary)}.badge-approved{color:#064e3b;background-color:#a7f3d0}.badge-pending{color:#92400e;background-color:#fef3c7}.badge-rejected{color:#991b1b;background-color:#fee2e2}.badge-suspended{color:#991b1b;background-color:#fecaca}.badge-admin{color:#6b21a8;background-color:#e9d5ff}.badge-user{color:#1e40af;background-color:#dbeafe}.badge-verified{color:#064e3b;font-size:var(--font-size-xs);background-color:#a7f3d0;border-radius:999px;padding:4px 12px;font-weight:600}.badge-unverified{color:#991b1b;font-size:var(--font-size-xs);background-color:#fee2e2;border-radius:999px;padding:4px 12px;font-weight:600}.btn-approve{background:#48bb78}.btn-approve:hover:not(:disabled){background:#38a169}.btn-reject{background:#f56565}.btn-reject:hover:not(:disabled){background:#e53e3e}.btn-suspend{background:#dd6b20}.btn-suspend:hover:not(:disabled){background:#c05621}.btn-promote{background:#805ad5}.btn-promote:hover:not(:disabled){background:#6b46c1}.btn-demote{background:#718096}.btn-demote:hover:not(:disabled){background:#4a5568}.btn-resend{background:var(--color-secondary)}.btn-resend:hover:not(:disabled){background:var(--color-info)}.loading-state,.error-state,.no-users{text-align:center;color:var(--text-tertiary);background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:48px;font-size:15px}.error-state{color:var(--color-error-dark);background:#fef2f2;border:2px solid #fecaca}.error-card{background:var(--bg-secondary);padding:var(--space-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);text-align:center}.error-card h2{color:var(--color-error-dark);margin-bottom:16px}@media (width<=1024px){.stats-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.table-container{overflow-x:auto}}@media (width<=768px){.user-admin{padding:var(--space-md)}.filters-section,.filter-group{flex-direction:column;align-items:stretch}.filter-select{width:100%}.action-buttons{flex-direction:column}.btn{width:100%}}.model-admin{padding:var(--space-lg);max-width:1400px;margin:0 auto}.page-header{justify-content:space-between;align-items:flex-start;gap:var(--space-md);margin-bottom:24px;display:flex}.model-admin .header-content h1{color:#fff;margin:0 0 8px;font-size:28px;font-weight:600}.model-admin .header-content .subtitle{color:var(--text-tertiary);font-size:var(--font-size-sm);margin:0}.model-admin .header-actions{gap:var(--space-sm);display:flex}.btn-primary,.btn-secondary{align-items:center;gap:var(--space-xs);border-radius:var(--radius-sm);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);border:none;padding:10px 16px;font-weight:500;display:flex}.btn-primary{background:linear-gradient(135deg, var(--color-primary) 0%, #9333ea 100%);color:#fff}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg, var(--color-primary-dark) 0%, #7e22ce 100%);transform:translateY(-1px);box-shadow:0 4px 12px #c026d366}.btn-primary:disabled{cursor:not-allowed;opacity:.6;background:#444}.btn-secondary{color:#fff;background:#2a2a2a;border:1px solid #404040}.btn-secondary:hover{background:#333;border-color:#505050}.btn-link{color:var(--color-primary);cursor:pointer;font-size:var(--font-size-sm);background:0 0;border:none;padding:4px 8px}.btn-link:hover{text-decoration:underline}.file-upload-btn{cursor:pointer;margin:0}.file-upload-btn:disabled{cursor:not-allowed;opacity:.6}.stats-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:24px;display:grid}.stat-card{border-radius:var(--radius-md);padding:var(--space-lg);text-align:center;background:#2a2a2a;border:1px solid #404040}.stat-card.total{border-left:4px solid var(--color-secondary)}.stat-card.community{border-left:4px solid var(--color-success)}.stat-card.user-models{border-left:4px solid var(--color-warning)}.stat-label{font-size:var(--font-size-sm);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.controls-bar{gap:var(--space-sm);flex-wrap:wrap;align-items:center;margin-bottom:20px;display:flex}.controls-bar>:first-child{flex:1;min-width:300px}.filter-group label{font-size:var(--font-size-sm);color:var(--text-tertiary);white-space:nowrap}.filter-select{border-radius:var(--radius-sm);color:#fff;font-size:var(--font-size-sm);cursor:pointer;background:#2a2a2a;border:1px solid #404040;min-width:150px;padding:10px 12px}.filter-select:focus{border-color:var(--color-primary);outline:none}.table-container{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);margin-bottom:20px;overflow:hidden}.model-table{border-collapse:collapse;width:100%}.model-table thead{background:linear-gradient(135deg,#3b4a9e 0%,#4a2d6b 100%);border-bottom:1px solid #404040}.model-table th{text-align:left;font-size:var(--font-size-sm);color:#fff;text-transform:uppercase;letter-spacing:.5px;padding:14px 16px;font-weight:600}.model-table tbody tr{background-color:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);transition:background .2s}.model-table tbody tr:hover{background-color:var(--bg-hover)}.model-table tbody tr:last-child{border-bottom:none}.model-table td{font-size:var(--font-size-sm);color:var(--text-secondary);padding:14px 16px}.model-table tbody td{color:var(--text-secondary)}.model-id-cell{max-width:400px}.model-id-wrapper{align-items:center;gap:var(--space-xs);display:flex}.model-id-text{font-family:Courier New,monospace;font-size:var(--font-size-sm);color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.date-cell{color:var(--text-tertiary);white-space:nowrap}.text-muted{color:var(--text-tertiary);font-style:italic}.badge{border-radius:var(--radius-lg);font-size:var(--font-size-xs);white-space:nowrap;padding:4px 10px;font-weight:500;display:inline-block}.badge-library{color:#60a5fa;background:#3b82f626;border:1px solid #3b82f64d}.badge-scenario{color:#c084fc;background:#a855f726;border:1px solid #a855f74d}.badge-community{color:#34d399;background:#10b98126;border:1px solid #10b9814d}.badge-user{color:#fbbf24;background:#f59e0b26;border:1px solid #f59e0b4d}.no-data{text-align:center;color:var(--text-tertiary);padding:60px 20px}.no-data p{font-size:var(--font-size-base);margin:0 0 16px}.loading-spinner{min-height:400px;font-size:var(--font-size-base);color:var(--text-tertiary);justify-content:center;align-items:center;display:flex}.help-section{border-radius:var(--radius-md);padding:var(--space-lg);background:#2a2a2a;border:1px solid #404040;margin-top:24px}.help-section h3{font-size:var(--font-size-base);color:#fff;margin:0 0 12px;font-weight:600}.help-section p{font-size:var(--font-size-sm);color:silver;margin:8px 0}.help-section ul{margin:12px 0;padding-left:24px;list-style-type:disc}.help-section li{font-size:var(--font-size-sm);color:silver;margin:8px 0;line-height:1.6}.help-section li strong{color:#fff;font-weight:600}.help-note{padding:var(--space-sm);border-left:3px solid var(--color-secondary);border-radius:var(--radius-sm);font-size:var(--font-size-sm);color:#a0c4ff;background:#3b82f61a;margin-top:16px}@media (width<=768px){.model-admin{padding:var(--space-md)}.page-header{flex-direction:column}.header-actions{width:100%}.header-actions .btn-primary,.header-actions .btn-secondary{flex:1}.stats-grid{grid-template-columns:1fr}.controls-bar{flex-direction:column;align-items:stretch}.controls-bar>:first-child{min-width:auto}.filter-group{flex-direction:column;align-items:stretch;gap:6px}.filter-select{width:100%}.table-container{overflow-x:auto}.model-table{min-width:600px}.model-id-cell{max-width:250px}}.admin-page{max-width:1400px;margin:0 auto}.admin-page-content{gap:var(--space-lg);flex-direction:column;display:flex}.info-card,.feature-card{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-sm)}.info-card h2,.feature-card h3{font-size:var(--font-size-xl);color:var(--text-primary);margin-bottom:16px;font-weight:600}.info-card p{color:var(--text-tertiary);margin-bottom:12px;line-height:1.6}.link-primary{color:var(--color-primary);font-weight:500;text-decoration:none}.link-primary:hover{text-decoration:underline}.feature-list{margin:0;padding:0;list-style:none}.feature-list li{color:var(--text-tertiary);border-bottom:1px solid var(--border-subtle);padding:10px 0}.feature-list li:last-child{border-bottom:none}@media (width<=768px){.admin-page{padding:var(--space-md)}.admin-page-header h1{font-size:var(--font-size-2xl)}}.instance-admin{max-width:1600px;margin:0 auto}.admin-page-header{margin-bottom:32px}.admin-page-header h1{color:var(--text-primary);margin-bottom:8px;font-size:28px;font-weight:700}.page-subtitle{color:var(--text-tertiary);font-size:15px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:20px;margin-bottom:32px;display:grid}.stat-card{background:var(--bg-secondary);padding:var(--space-lg);border-radius:var(--radius-lg);border-top:4px solid var(--color-secondary);box-shadow:0 1px 3px #0000001a}.stat-card.stat-active{border-top-color:#48bb78}.stat-card.stat-deprecated{border-top-color:#f56565}.stat-card.stat-aws{border-top-color:#f90}.stat-card.stat-gcp{border-top-color:#4285f4}.stat-card.stat-azure{border-top-color:#0089d6}.stat-value{color:var(--text-primary);margin-bottom:8px;font-size:36px;font-weight:700}.stat-label{font-size:var(--font-size-sm);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.filters-section{gap:var(--space-md);flex-wrap:wrap;align-items:center;margin-bottom:24px;display:flex}.filter-group{align-items:center;gap:var(--space-sm);display:flex}.filter-group label{color:var(--text-primary);font-weight:600;font-size:var(--font-size-sm)}.filter-select{border:2px solid var(--border-primary);border-radius:var(--radius-md);font-size:var(--font-size-sm);background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;transition:all var(--transition-base);min-width:160px;padding:10px 16px}.filter-select option{color:var(--text-primary);background:var(--bg-secondary)}.filter-select:hover{border-color:var(--color-primary)}.filter-select:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #c026d31a}.csv-upload-label{background:var(--color-secondary);color:#fff;border-radius:var(--radius-md);cursor:pointer;font-weight:600;font-size:var(--font-size-sm);transition:all var(--transition-base);align-items:center;padding:10px 20px;display:inline-flex}.csv-upload-label:hover{background:#3182ce;transform:translateY(-1px);box-shadow:0 4px 6px #0000001a}.csv-upload-input{display:none}.table-container{background:var(--bg-secondary);border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 1px 3px #0000001a}.instances-table{border-collapse:collapse;width:100%}.instances-table thead{background:linear-gradient(135deg,#3b4a9e 0%,#4a2d6b 100%);border-bottom:1px solid #404040}.instances-table thead tr{background:linear-gradient(135deg,#3b4a9e 0%,#4a2d6b 100%)}.instances-table th{padding:var(--space-md);text-align:left;text-transform:uppercase;font-weight:600;font-size:var(--font-size-xs);letter-spacing:.05em;color:#fff;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;background:0 0}.instances-table th:hover{background:#ffffff1a}.instances-table tbody tr{background-color:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);transition:background-color .2s}.instances-table tbody tr:hover{background-color:var(--bg-hover)}.instances-table td{padding:var(--space-md);color:var(--text-secondary);font-size:var(--font-size-sm)}.instances-table tbody td{color:var(--text-secondary)}.instances-table .instance-type{font-family:Monaco,Menlo,monospace;font-weight:600}.price-cell{color:#16a34a;font-family:Monaco,Menlo,monospace;font-weight:600}.price-monthly{color:var(--text-tertiary);font-family:Monaco,Menlo,monospace}.badge{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;border-radius:999px;padding:4px 12px;font-weight:600;display:inline-block}.badge-aws{color:#e65100;background-color:#fff3e0}.badge-gcp{color:#0d47a1;background-color:#e3f2fd}.badge-azure{color:#01579b;background-color:#e1f5fe}.badge-coreweave{color:#6a1b9a;background-color:#f3e5f5}.badge-runpod{color:#c2185b;background-color:#fce4ec}.badge-scaleway{color:#3949ab;background-color:#e8eaf6}.badge-gcore{color:#f57f17;background-color:#fff9c4}.badge-ovhcloud{color:#00695c;background-color:#e0f2f1}.badge-thunder{color:#ff6f00;background-color:#ffecb3}.badge-active{color:#065f46;background-color:#d1fae5}.badge-deprecated{color:#991b1b;background-color:#fee2e2}.action-buttons{gap:var(--space-xs);flex-wrap:wrap;display:flex}.btn{border-radius:var(--radius-sm);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;color:#fff;border:none;padding:6px 12px;font-weight:600}.btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 6px #0000001a}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-delete{background:#f56565}.btn-delete:hover:not(:disabled){background:#e53e3e}.loading-state,.no-instances{text-align:center;color:var(--text-tertiary);background:var(--bg-secondary);border-radius:var(--radius-lg);padding:48px;font-size:15px}@media (width<=1024px){.stats-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.table-container{overflow-x:auto}.instances-table{min-width:1200px}}@media (width<=768px){.instance-admin{padding:var(--space-md)}.filters-section,.filter-group{flex-direction:column;align-items:stretch}.filter-select{width:100%}.csv-upload-label{justify-content:center;width:100%}}.admin-opentofu-cache{padding:var(--space-lg);max-width:1400px;margin:0 auto}.cache-header{margin-bottom:30px}.cache-header h1{color:#333;margin-bottom:20px;font-size:28px}.cache-stats{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;margin-bottom:20px;display:grid}.stat-card{border:1px solid var(--border-secondary);border-radius:var(--radius-md);background:#f5f5f5;flex-direction:column;padding:15px;transition:transform .2s,box-shadow .2s;display:flex}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.stat-label{font-size:var(--font-size-xs);color:#666;text-transform:uppercase;margin-bottom:5px;font-weight:600}.stat-value{font-size:var(--font-size-2xl);color:#333;font-weight:700}.cache-controls{border-radius:var(--radius-md);background:#f9f9f9;border:1px solid #e0e0e0;justify-content:space-between;align-items:center;margin-bottom:20px;padding:15px;display:flex}.sort-controls{align-items:center;gap:10px;display:flex}.sort-controls label{color:#555;font-weight:600}.sort-controls select{border:1px solid var(--border-secondary);border-radius:var(--radius-sm);background:var(--bg-secondary);cursor:pointer;font-size:var(--font-size-sm);padding:8px 12px}.refresh-btn{border-radius:var(--radius-sm);color:#fff;cursor:pointer;background:#4a90e2;border:none;padding:8px 16px;font-weight:600;transition:background .2s}.refresh-btn:hover:not(:disabled){background:#357abd}.refresh-btn:disabled{opacity:.6;cursor:not-allowed}.error-message{color:#721c24;border-radius:var(--radius-sm);background:#f8d7da;border-left:4px solid #d9534f;margin-bottom:20px;padding:15px}.loading-message{text-align:center;color:#666;font-size:var(--font-size-base);padding:40px}.admin-opentofu-cache .empty-state{text-align:center;background:var(--bg-secondary);border-radius:var(--radius-md);border:2px dashed var(--border-secondary);padding:60px 20px}.admin-opentofu-cache .empty-state p{font-size:var(--font-size-base);color:var(--text-tertiary);margin:10px 0}.empty-hint{font-size:var(--font-size-sm);color:#999}.table-container{margin-bottom:20px;overflow-x:auto}.deployments-table{border-collapse:collapse;background:var(--bg-secondary);border-radius:var(--radius-md);width:100%;overflow:hidden;box-shadow:0 2px 4px #0000001a}.deployments-table th{color:#fff;padding:var(--space-sm);text-align:left;text-transform:uppercase;font-weight:600;font-size:var(--font-size-xs);letter-spacing:.5px;background:#4a90e2}.deployments-table td{padding:var(--space-sm);font-size:var(--font-size-sm);color:#333;border-bottom:1px solid #eee}.deployments-table tbody tr:hover{background:#f5f5f5;transition:background .2s}.deployments-table tbody tr:last-child td{border-bottom:none}.actions{gap:var(--space-xs);flex-wrap:wrap;display:flex}.actions button{border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-size-sm);transition:all var(--transition-base);white-space:nowrap;border:none;padding:6px 12px;font-weight:600}.actions button:disabled{opacity:.5;cursor:not-allowed}.view-btn{color:#fff;background:#4a90e2}.view-btn:hover:not(:disabled){background:#357abd}.download-btn{color:#fff;background:#5cb85c}.download-btn:hover:not(:disabled){background:#4a9a4a}.delete-btn{color:#fff;background:#d9534f}.delete-btn:hover:not(:disabled){background:#c9302c}.pagination{padding:var(--space-lg);border-radius:var(--radius-md);background:#f9f9f9;justify-content:center;align-items:center;gap:20px;display:flex}.pagination button{border-radius:var(--radius-sm);border:1px solid var(--border-secondary);background:var(--bg-secondary);cursor:pointer;transition:all var(--transition-base);padding:8px 16px;font-weight:600}.pagination button:hover:not(:disabled){color:#fff;background:#4a90e2;border-color:#4a90e2}.pagination button:disabled{opacity:.5;cursor:not-allowed}.pagination span{font-size:var(--font-size-sm);color:#666}.modal-overlay{z-index:var(--z-modal);background:#00000080;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-secondary);border-radius:var(--radius-md);width:90%;max-width:800px;max-height:90vh;padding:30px;animation:.3s slideUp;overflow-y:auto;box-shadow:0 4px 20px #0003}.modal-content h2{color:#333;font-size:var(--font-size-2xl);margin-top:0;margin-bottom:20px}.detail-section{margin-bottom:25px}.detail-section h3{font-size:var(--font-size-lg);color:#333;border-bottom:2px solid #4a90e2;margin-bottom:10px;padding-bottom:5px}.detail-table{border-collapse:collapse;width:100%}.detail-table tr{border-bottom:1px solid #eee}.detail-table tr:last-child{border-bottom:none}.detail-table td{font-size:var(--font-size-sm);padding:8px 0}.detail-table td:first-child{color:#666;width:150px;font-weight:700}.detail-table td:last-child{color:#333}.file-list{border-radius:var(--radius-sm);background:#f9f9f9;border:1px solid #e0e0e0;max-height:200px;padding:10px;list-style:none;overflow-y:auto}.file-list li{font-family:monospace;font-size:var(--font-size-sm);color:#333;border-bottom:1px solid #e0e0e0;padding:5px}.file-list li:last-child{border-bottom:none}.readme-preview{border-radius:var(--radius-sm);font-size:var(--font-size-sm);white-space:pre-wrap;color:#333;background:#f5f5f5;border:1px solid #e0e0e0;max-height:300px;padding:15px;font-family:monospace;line-height:1.6;overflow-y:auto}.modal-actions{border-top:1px solid #eee;justify-content:flex-end;gap:10px;margin-top:20px;padding-top:20px;display:flex}.modal-actions button{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-base);border:none;padding:10px 20px;font-weight:600}.modal-actions button:not(.delete-btn):not(.download-btn){color:#fff;background:#6c757d}.modal-actions button:not(.delete-btn):not(.download-btn):hover:not(:disabled){background:#5a6268}.delete-modal{max-width:500px}.delete-target{border-radius:var(--radius-sm);font-size:var(--font-size-sm);background:#fff3cd;border-left:4px solid #ff9800;margin:15px 0;padding:15px}.warning{color:#721c24;padding:var(--space-sm);border-radius:var(--radius-sm);font-size:var(--font-size-sm);background:#f8d7da;border-left:4px solid #d9534f;margin:10px 0}.checkbox-label{align-items:center;gap:var(--space-xs);cursor:pointer;font-size:var(--font-size-sm);color:#333;margin:15px 0;display:flex}.checkbox-label input[type=checkbox]{cursor:pointer;width:18px;height:18px}@media (width<=768px){.admin-opentofu-cache{padding:10px}.cache-stats{grid-template-columns:1fr}.cache-controls{flex-direction:column;gap:15px}.sort-controls{flex-direction:column;width:100%}.sort-controls select{width:100%}.table-container{overflow-x:scroll}.deployments-table{font-size:var(--font-size-xs)}.deployments-table th,.deployments-table td{padding:8px 6px}.actions{flex-direction:column}.actions button{width:100%}.modal-content{padding:var(--space-lg);width:95%}.pagination{flex-direction:column;gap:10px}}.type-badge{border-radius:var(--radius-lg);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;padding:4px 10px;font-size:11px;font-weight:600;display:inline-block}.type-badge.type-hosted{color:#fff;background:#8b5cf6}.type-badge.type_iac_opentofu{color:#fff;background:#4a90e2}.type-badge.type_manual_cli{background:var(--color-success);color:#fff}.type-badge.type_manual_console{background:var(--color-warning);color:#fff}*{box-sizing:border-box;margin:0;padding:0}.App{min-height:100vh}
