:root{--bg-primary:#0a0e17;--bg-secondary:#111827;--bg-card:#1a2233;--bg-card-hover:#1f2b3d;--border-color:#1e2d3d;--text-primary:#e2e8f0;--text-secondary:#94a3b8;--text-muted:#64748b;--accent-green:#22c55e;--accent-green-bg:#22c55e1a;--accent-red:#ef4444;--accent-red-bg:#ef44441a;--accent-yellow:#eab308;--accent-yellow-bg:#eab3081a;--accent-blue:#3b82f6;--accent-blue-bg:#3b82f61a;--accent-purple:#a855f7;--radius:12px;--radius-sm:8px;--sidebar-width:240px;--log-bg:#000;--log-color:#a3e635}[data-theme=light]{--bg-primary:#f1f5f9;--bg-secondary:#fff;--bg-card:#fff;--bg-card-hover:#f8fafc;--border-color:#e2e8f0;--text-primary:#1e293b;--text-secondary:#475569;--text-muted:#94a3b8;--accent-green-bg:#22c55e14;--accent-red-bg:#ef444414;--accent-yellow-bg:#eab30814;--accent-blue-bg:#3b82f614;--log-bg:#1e293b;--log-color:#a3e635}*{box-sizing:border-box;margin:0;padding:0}body{background-color:#0a0e17;background-color:var(--bg-primary);color:#e2e8f0;color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.6;min-height:100vh}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#111827;background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:#1e2d3d;background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#64748b;background:var(--text-muted)}.tabs{background:#111827;background:var(--bg-secondary);border:1px solid #1e2d3d;border:1px solid var(--border-color);border-radius:12px;border-radius:var(--radius);gap:4px;margin-bottom:24px;padding:4px}.tab,.tabs{display:flex}.tab{align-items:center;background:#0000;border:none;border-radius:8px;border-radius:var(--radius-sm);color:#94a3b8;color:var(--text-secondary);cursor:pointer;font-size:14px;font-weight:500;gap:8px;padding:10px 20px;transition:all .2s;white-space:nowrap}.tab:hover{background:#1a2233;background:var(--bg-card);color:#e2e8f0;color:var(--text-primary)}.tab.active{background:#3b82f6;background:var(--accent-blue);color:#fff}.card{background:#1a2233;background:var(--bg-card);border:1px solid #1e2d3d;border:1px solid var(--border-color);border-radius:12px;border-radius:var(--radius);padding:20px;transition:border-color .2s}.card:hover{border-color:#64748b;border-color:var(--text-muted)}.card-header{justify-content:space-between;margin-bottom:12px}.card-header,.card-title{align-items:center;display:flex}.card-title{color:#94a3b8;color:var(--text-secondary);font-size:14px;font-weight:500;gap:8px}.card-title .icon{font-size:16px}.badge{align-items:center;background:#1f2b3d;background:var(--bg-card-hover);border:1px solid #1e2d3d;border:1px solid var(--border-color);border-radius:999px;color:#94a3b8;color:var(--text-secondary);display:inline-flex;font-size:11px;font-weight:600;gap:6px;letter-spacing:.8px;padding:6px 14px;text-transform:uppercase}.badge.healthy,.badge.online,.badge.running{background:#22c55e1a;background:var(--accent-green-bg);border-color:#22c55e40;color:#22c55e;color:var(--accent-green)}.badge.down,.badge.error,.badge.stopped{background:#ef44441a;background:var(--accent-red-bg);border-color:#ef444440;color:#ef4444;color:var(--accent-red)}.badge.degraded,.badge.pending,.badge.shutting-down,.badge.stopping{background:#eab3081a;background:var(--accent-yellow-bg);border-color:#eab30840;color:#eab308;color:var(--accent-yellow)}.badge .dot{animation:pulse-dot 2s ease-in-out infinite;background:currentColor;border-radius:50%;box-shadow:0 0 6px currentColor;height:7px;width:7px}@keyframes pulse-dot{0%,to{box-shadow:0 0 6px currentColor;opacity:1}50%{box-shadow:0 0 2px currentColor;opacity:.6}}.skeleton-shimmer{background:#1a2233;background:var(--bg-card);overflow:hidden;position:relative}.skeleton-shimmer:after{animation:shimmer 1.5s ease-in-out infinite;background:linear-gradient(90deg,#0000,#1f2b3d 50%,#0000);background:linear-gradient(90deg,#0000 0,var(--bg-card-hover) 50%,#0000 100%);content:"";inset:0;position:absolute}@keyframes shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.grid-4{grid-gap:16px;grid-template-columns:repeat(4,1fr)}.grid-2,.grid-4{display:grid;gap:16px}.grid-2{grid-gap:16px;grid-template-columns:repeat(2,1fr)}.grid-2-1{grid-gap:16px;grid-template-columns:2fr 1fr}.grid-2-1,.grid-3{display:grid;gap:16px}.grid-3{grid-gap:16px;grid-template-columns:repeat(3,1fr)}@media (max-width:1024px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.grid-2,.grid-2-1,.grid-3,.grid-4{grid-template-columns:1fr}}.status-banner{background:#1a2233;background:var(--bg-card);border:1px solid #1e2d3d;border:1px solid var(--border-color);border-radius:12px;border-radius:var(--radius);margin-bottom:24px;padding:24px}.status-banner.healthy{border-left:4px solid #22c55e;border-left:4px solid var(--accent-green)}.status-banner.degraded{border-left:4px solid #eab308;border-left:4px solid var(--accent-yellow)}.status-banner.down{border-left:4px solid #ef4444;border-left:4px solid var(--accent-red)}.status-banner h2{font-size:24px;font-weight:700;margin-bottom:4px}.status-banner .subtitle{color:#64748b;color:var(--text-muted);font-size:13px}.service-card{align-items:center;display:flex;gap:12px}.service-card .service-icon{color:#64748b;color:var(--text-muted);font-size:20px}.service-card .service-name{font-size:14px;font-weight:500}.service-card .service-status{font-size:13px;font-weight:600}.service-card .service-detail{color:#64748b;color:var(--text-muted);font-size:12px}.metric-value{font-size:28px;font-weight:700;margin-bottom:4px}.metric-label{color:#64748b;color:var(--text-muted);font-size:13px}.progress-bar{background:#111827;background:var(--bg-secondary);border-radius:3px;height:6px;margin-top:8px;overflow:hidden}.progress-fill{border-radius:3px;height:100%;transition:width .5s ease}.progress-fill.green{background:#22c55e;background:var(--accent-green)}.progress-fill.yellow{background:#eab308;background:var(--accent-yellow)}.progress-fill.red{background:#ef4444;background:var(--accent-red)}.progress-fill.blue{background:#3b82f6;background:var(--accent-blue)}.btn{align-items:center;border:none;border-radius:8px;border-radius:var(--radius-sm);cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:8px;padding:10px 20px;transition:all .2s}.btn:disabled{cursor:not-allowed;opacity:.5}.btn-primary{background:#3b82f6;background:var(--accent-blue);color:#fff}.btn-primary:hover:not(:disabled){background:#2563eb}.btn-success{background:#22c55e;background:var(--accent-green);color:#fff}.btn-success:hover:not(:disabled){background:#16a34a}.btn-danger{background:#ef4444;background:var(--accent-red);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-outline{background:#0000;border:1px solid #1e2d3d;border:1px solid var(--border-color);color:#94a3b8;color:var(--text-secondary)}.btn-outline:hover:not(:disabled){background:#1a2233;background:var(--bg-card);border-color:#64748b;border-color:var(--text-muted)}.log-viewer{background:#000;background:var(--log-bg);border:1px solid #1e2d3d;border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius-sm);color:#a3e635;color:var(--log-color);font-family:JetBrains Mono,Fira Code,Consolas,monospace;font-size:12px;line-height:1.5;max-height:500px;overflow-y:auto;padding:16px;white-space:pre-wrap;word-break:break-all}.table-container{overflow-x:auto}table{border-collapse:collapse;width:100%}th{color:#64748b;color:var(--text-muted);font-size:12px;font-weight:600;letter-spacing:.5px;text-align:left;text-transform:uppercase}td,th{border-bottom:1px solid #1e2d3d;border-bottom:1px solid var(--border-color);padding:12px 16px}td{font-size:14px}tr:hover td{background:#1f2b3d;background:var(--bg-card-hover)}.app-layout{display:flex;min-height:100vh}.sidebar{background:#111827;background:var(--bg-secondary);border-right:1px solid #1e2d3d;border-right:1px solid var(--border-color);bottom:0;display:flex;flex-direction:column;left:0;overflow-y:auto;padding:0;position:fixed;top:0;width:240px;width:var(--sidebar-width);z-index:50}.sidebar-header{justify-content:space-between;padding:20px 16px 16px}.sidebar-header,.sidebar-profile{align-items:center;border-bottom:1px solid #1e2d3d;border-bottom:1px solid var(--border-color);display:flex}.sidebar-profile{gap:10px;padding:14px 16px}.profile-avatar{align-items:center;background:#3b82f6;background:var(--accent-blue);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:14px;font-weight:700;height:34px;justify-content:center;text-transform:uppercase;width:34px}.profile-info{display:flex;flex-direction:column;gap:2px;min-width:0}.profile-name{color:#e2e8f0;color:var(--text-primary);font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.role-badge{align-items:center;border-radius:999px;display:inline-flex;font-size:10px;font-weight:700;letter-spacing:.5px;padding:1px 6px;text-transform:uppercase;width:-webkit-fit-content;width:fit-content}.role-badge.admin{background:#6366f126;color:#3b82f6;color:var(--accent-blue)}.role-badge.validation{background:#f59e0b26;color:#eab308;color:var(--accent-yellow)}.sidebar-header h2{font-weight:700;gap:8px}.sidebar-header h2,.theme-toggle{align-items:center;display:flex;font-size:18px}.theme-toggle{background:#0000;border:1px solid #1e2d3d;border:1px solid var(--border-color);border-radius:6px;color:#94a3b8;color:var(--text-secondary);cursor:pointer;padding:6px;transition:all .2s}.theme-toggle:hover{background:#1a2233;background:var(--bg-card);color:#e2e8f0;color:var(--text-primary)}.sidebar nav{flex:1 1;padding:12px 0}.nav-section{margin-bottom:8px}.nav-section-label{align-items:center;color:#64748b;color:var(--text-muted);display:flex;font-size:14px;font-weight:700;gap:8px;letter-spacing:1px;padding:8px 16px 6px;text-transform:uppercase}.nav-section-label .status-badge{margin-left:auto}.env-dot{border-radius:50%;height:8px;width:8px}.env-dot.prod{background:#ef4444;background:var(--accent-red)}.env-dot.staging{background:#eab308;background:var(--accent-yellow)}.status-badge{border-radius:3px;display:inline-block;font-size:9px;font-weight:700;letter-spacing:.5px;line-height:14px;margin-left:4px;padding:1px 5px;vertical-align:middle}.status-badge.loading{background:#1a2233;background:var(--bg-card);color:#64748b;color:var(--text-muted)}@keyframes pulse-badge{0%,to{opacity:1}50%{opacity:.5}}.nav-item{align-items:center;background:#0000;border:none;border-radius:8px;border-radius:var(--radius-sm);color:#94a3b8;color:var(--text-secondary);cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:10px;margin:2px 8px;padding:9px 12px;text-align:left;transition:all .15s;width:calc(100% - 16px)}.nav-item:hover{background:#1a2233;background:var(--bg-card);color:#e2e8f0;color:var(--text-primary)}.nav-item.active{background:#3b82f61a;background:var(--accent-blue-bg);color:#3b82f6;color:var(--accent-blue);font-weight:600}.nav-item .nav-icon{flex-shrink:0;font-size:16px}.sidebar-footer{border-top:1px solid #1e2d3d;border-top:1px solid var(--border-color);padding:12px 16px}.sidebar-footer .btn{font-size:13px;justify-content:center;padding:8px;width:100%}.sidebar-footer-info{align-items:center;color:#64748b;color:var(--text-muted);display:flex;flex-direction:column;font-size:11px;gap:2px;line-height:1.4;margin-top:12px;opacity:.6}.sidebar-footer-info span:first-child{color:#3b82f6;color:var(--accent-blue);font-size:12px;font-weight:600;margin-bottom:2px;opacity:1}.main-content{flex:1 1;margin-left:240px;margin-left:var(--sidebar-width);max-width:calc(100% - 240px);max-width:calc(100% - var(--sidebar-width));padding:24px}.layout{margin:0 auto;max-width:1400px;padding:0}.header{justify-content:space-between;margin-bottom:24px}.header,.header h1{align-items:center;display:flex}.header h1{font-size:24px;font-weight:700;gap:12px}.header .subtitle{color:#64748b;color:var(--text-muted);font-size:14px;margin-top:2px}.toggle{background:#1e2d3d;background:var(--border-color);border-radius:13px;cursor:pointer;height:26px;position:relative;transition:background .3s;width:48px}.toggle.active{background:#22c55e;background:var(--accent-green)}.toggle:after{background:#fff;border-radius:50%;content:"";height:20px;left:3px;position:absolute;top:3px;transition:transform .3s;width:20px}.toggle.active:after{transform:translateX(22px)}.login-container{align-items:center;background:#0a0e17;background:var(--bg-primary);display:flex;justify-content:center;min-height:100vh}.login-card{background:#1a2233;background:var(--bg-card);border:1px solid #1e2d3d;border:1px solid var(--border-color);border-radius:12px;border-radius:var(--radius);max-width:420px;padding:40px;width:100%}.login-card h1{font-size:24px;margin-bottom:8px;text-align:center}.login-card .subtitle{color:#64748b;color:var(--text-muted);font-size:14px;margin-bottom:32px;text-align:center}.form-group{margin-bottom:20px}.form-group label{color:#94a3b8;color:var(--text-secondary);display:block;font-size:13px;font-weight:500;margin-bottom:6px}.form-group input{background:#111827;background:var(--bg-secondary);border:1px solid #1e2d3d;border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius-sm);color:#e2e8f0;color:var(--text-primary);font-size:14px;outline:none;padding:12px 16px;transition:border-color .2s;width:100%}.form-group input:focus{border-color:#3b82f6;border-color:var(--accent-blue)}.input-password-wrapper{align-items:center;display:flex;position:relative}.input-password-wrapper input{padding-right:44px}.password-toggle{align-items:center;background:none;border:none;border-radius:4px;color:#64748b;color:var(--text-muted);cursor:pointer;display:flex;font-size:18px;padding:6px;position:absolute;right:8px;transition:color .2s}.password-toggle:hover{color:#e2e8f0;color:var(--text-primary)}.form-error{color:#ef4444;color:var(--accent-red);font-size:13px;margin-top:8px;text-align:center}.staging-ec2-status{align-items:center;display:flex;gap:16px}.staging-actions{display:flex;flex-wrap:wrap;gap:8px}.staging-tech-footer{background:var(--card-bg);border:1px dashed #1e2d3d;border:1px dashed var(--border-color);opacity:.75}.tech-details-grid{color:#64748b;color:var(--text-muted);display:flex;flex-wrap:wrap;font-size:11px;gap:8px 24px;padding-top:4px}.tech-details-grid strong{color:#94a3b8;color:var(--text-secondary);font-weight:500}.backup-row{align-items:center;border-bottom:1px solid #1e2d3d;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:12px 0}.backup-row:last-child{border-bottom:none}.backup-info{display:flex;flex-direction:column;gap:2px}.backup-filename{font-family:monospace;font-size:14px;font-weight:500}.backup-details{color:#64748b;color:var(--text-muted);font-size:12px}.fade-in{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.modal-overlay{align-items:center;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;display:flex;inset:0;justify-content:center;position:fixed;z-index:100}.modal{background:#1a2233;background:var(--bg-card);border:1px solid #1e2d3d;border:1px solid var(--border-color);border-radius:12px;border-radius:var(--radius);box-shadow:0 20px 60px #0006;max-width:480px;padding:32px;width:100%}.modal h3{font-size:18px;font-weight:700;margin-bottom:8px}.modal p{color:#94a3b8;color:var(--text-secondary);font-size:14px;line-height:1.5;margin-bottom:20px}.modal .warning-text{background:#ef44441a;background:var(--accent-red-bg);border:1px solid #ef444433;border-radius:8px;border-radius:var(--radius-sm);color:#ef4444;color:var(--accent-red);font-size:13px;font-weight:600;margin-bottom:20px;padding:12px}.modal .pin-input{background:#111827;background:var(--bg-secondary);border:2px solid #1e2d3d;border:2px solid var(--border-color);border-radius:8px;border-radius:var(--radius-sm);color:#e2e8f0;color:var(--text-primary);font-size:24px;font-weight:700;letter-spacing:12px;margin-bottom:8px;outline:none;padding:14px 16px;text-align:center;transition:border-color .2s;width:100%}.modal .pin-input:focus{border-color:#3b82f6;border-color:var(--accent-blue)}.modal .pin-error{color:#ef4444;color:var(--accent-red);font-size:13px;margin-bottom:16px;text-align:center}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.modal-actions .btn{justify-content:center;min-width:120px}.btn-sm{border-radius:6px;font-size:12px;padding:4px 10px}.btn-icon{align-items:center;background:#0000;border:1px solid #1e2d3d;border:1px solid var(--border-color);border-radius:6px;color:#94a3b8;color:var(--text-secondary);cursor:pointer;display:inline-flex;font-size:14px;padding:6px;transition:all .2s}.btn-icon:hover{background:#1f2b3d;background:var(--bg-card-hover);color:#e2e8f0;color:var(--text-primary)}.btn-icon.danger:hover{background:#ef44441a;background:var(--accent-red-bg);border-color:#ef44444d;color:#ef4444;color:var(--accent-red)}.query-text{font-family:JetBrains Mono,monospace;font-size:12px;max-width:400px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.page-title{align-items:center;display:flex;font-size:22px;font-weight:700;gap:10px;margin-bottom:20px}.page-title .title-icon{color:#3b82f6;color:var(--accent-blue);font-size:24px}.section{margin-bottom:24px}.section-title{align-items:center;color:#94a3b8;color:var(--text-secondary);display:flex;font-size:16px;font-weight:600;gap:8px;margin-bottom:12px}.empty-state{color:#64748b;color:var(--text-muted);padding:40px 20px;text-align:center}.empty-state .empty-icon{font-size:40px;margin-bottom:12px}@media (max-width:768px){.sidebar{--sidebar-width:60px;width:60px}.nav-item span,.nav-section-label span:not(.env-dot),.sidebar-header h2 span,.sidebar-profile .profile-info{display:none}.sidebar-profile{justify-content:center;padding:10px 0}.main-content{margin-left:60px;max-width:calc(100% - 60px)}}
/*# sourceMappingURL=main.4e2331aa.css.map*/