:root{color-scheme:dark;font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:#0f172a;color:#e2e8f0}*{box-sizing:border-box}body{margin:0;min-height:100vh;display:flex}.shell{display:grid;grid-template-columns:260px 1fr;width:100%}.nav{background:#111827;padding:24px 20px;border-right:1px solid rgba(148,163,184,.15);display:flex;flex-direction:column;gap:16px;min-height:100vh}.nav h1{font-size:18px;margin:0}.nav .pill{font-size:12px;padding:6px 12px;border-radius:999px;background:#94a3b81f;width:fit-content}.project-selector{display:flex;flex-direction:column;gap:8px;padding:12px;border-radius:12px;background:#0f172a99;border:1px solid rgba(148,163,184,.12)}.project-label{font-size:12px;color:#94a3b8;letter-spacing:.02em;text-transform:uppercase}.project-control{display:grid;gap:8px}.project-control select{background:#1e293bcc;color:#e2e8f0;border:1px solid rgba(148,163,184,.2);border-radius:8px;padding:8px 10px;font-size:13px}.project-control select:disabled{opacity:.6;cursor:not-allowed}.project-link{font-size:13px;color:#60a5fa;text-decoration:none;font-weight:600}.project-link:hover{text-decoration:underline}.project-list{display:flex;flex-direction:column;gap:12px;margin:16px 0}.project-item{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:12px 16px;border-radius:12px;border:1px solid rgba(148,163,184,.12);background:#0f172a99}.project-item.project-selected{border-color:#60a5fa80;box-shadow:0 0 0 1px #60a5fa59}.project-meta{display:flex;flex-direction:column;gap:4px}.project-title{font-size:15px;font-weight:600;color:#e2e8f0}.project-actions{display:flex;align-items:center;gap:8px}.project-button{background:#1d4ed8;color:#f8fafc;border:none;padding:8px 14px;border-radius:10px;font-weight:600;cursor:pointer;opacity:1}.project-button:disabled{cursor:not-allowed;opacity:.6}.project-empty{margin:12px 0;color:#94a3b8;font-size:13px}.nav .menu{display:flex;flex-direction:column;gap:4px;font-size:14px}.nav-link{display:block;padding:10px 16px;color:#cbd5f5;text-decoration:none;border-radius:8px;transition:all .2s}.nav-link:hover{background:#94a3b81a;color:#e2e8f0}.nav-link.active{background:#2563eb33;color:#60a5fa;font-weight:600}.nav-footer{margin-top:auto;padding-top:16px;display:flex;flex-direction:column;gap:12px}.main{display:flex;flex-direction:column}header{display:flex;justify-content:space-between;align-items:center;padding:20px 32px;border-bottom:1px solid rgba(148,163,184,.15);background:#0f172af2}header h2{margin:0;font-size:20px}.status-pill{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border-radius:999px;font-size:13px;font-weight:600}.status-pill span{width:8px;height:8px;border-radius:50%;display:inline-block}.status-online{background:#22c55e26;color:#4ade80}.status-online span{background:#22c55e}.status-offline{background:#f8717126;color:#f87171}.status-offline span{background:#f87171}.status-degraded{background:#fbbf2426;color:#fbbf24}.status-degraded span{background:#fbbf24}.status-syncing{background:#38bdf826;color:#38bdf8}.status-syncing span{background:#38bdf8}.status-blocked{background:#a855f726;color:#c084fc}.status-blocked span{background:#c084fc}.content{padding:32px;display:grid;gap:24px}.card{background:#111827;padding:24px;border-radius:16px;box-shadow:0 12px 32px #0f172a66;border:1px solid rgba(148,163,184,.12)}.card h3{margin-top:0}.activity-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.badge{display:inline-flex;padding:4px 10px;border-radius:999px;font-size:12px;background:#94a3b826}.row{display:flex;align-items:center;justify-content:space-between;gap:16px}.hint{color:#94a3b8;font-size:13px}button{background:#2563eb;color:#f8fafc;border:none;padding:10px 16px;border-radius:10px;font-weight:600;cursor:not-allowed;opacity:.6}.offline-banner{padding:12px 16px;border-radius:12px;background:#f8717126;color:#fecaca;font-size:13px;display:none}.offline-banner.active{display:block}.bridge-warning{padding:12px 16px;border-radius:12px;background:#fbbf2426;color:#fbbf24;font-size:13px}.info-grid{display:grid;gap:8px}.info-row{display:grid;grid-template-columns:90px 1fr;gap:10px;font-size:13px;color:#cbd5f5;word-break:break-all}.info-key{color:#94a3b8;font-weight:600}.info-value{color:#e2e8f0}.sign-in-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:#0f172a;padding:24px}.sign-in-card{width:100%;max-width:460px;background:linear-gradient(180deg,#111827eb,#0f172afa);padding:36px;border-radius:20px;box-shadow:0 30px 60px #0f172a80;border:1px solid rgba(148,163,184,.16);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.sign-in-header{text-align:center;margin-bottom:28px}.sign-in-header h1{font-size:30px;margin:0 0 8px;color:#e2e8f0;letter-spacing:.3px}.sign-in-subtitle{color:#94a3b8;font-size:14px;margin:0}.sign-in-error{background:#f8717126;color:#fecaca;padding:12px 16px;border-radius:8px;margin-bottom:24px;font-size:13px;border:1px solid rgba(248,113,113,.25)}.sign-in-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:600;color:#cbd5f5}.form-group input,.form-group select{padding:12px 16px;border-radius:8px;border:1px solid rgba(148,163,184,.2);background:#0f172a;color:#e2e8f0;font-size:14px;transition:border-color .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa33}.form-group input:disabled,.form-group select:disabled{opacity:.5;cursor:not-allowed}.sign-in-button{padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;border:none;cursor:pointer;transition:all .2s;letter-spacing:.2px}.sign-in-button.primary{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#f8fafc}.sign-in-button.primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 18px #2563eb40}.sign-in-button.secondary{background:#0f172acc;color:#e2e8f0;border:1px solid rgba(148,163,184,.2)}.sign-in-button.secondary:hover:not(:disabled){background:#1e293bcc;border-color:#94a3b859}.sign-in-button.danger{background:#f871711f;color:#fecaca;border:1px solid rgba(248,113,113,.35)}.sign-in-button.danger:hover:not(:disabled){background:#f871712e;border-color:#f8717180}.sign-in-button:disabled{opacity:.5;cursor:not-allowed}.sign-in-divider{display:flex;align-items:center;gap:16px;margin:20px 0;color:#94a3b8;font-size:13px}.sign-in-divider:before,.sign-in-divider:after{content:"";flex:1;height:1px;background:#94a3b833}.sign-in-footer{margin-top:24px;text-align:center}.sign-in-mfa{margin-bottom:24px;padding:18px;border-radius:14px;background:#0f172ab3;border:1px solid rgba(96,165,250,.18);display:grid;gap:14px}.sign-in-mfa h3{margin:0;font-size:16px;color:#e2e8f0}.sign-in-mfa p{margin:0;font-size:13px;color:#94a3b8}.settings-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:16px}#recaptcha-container{height:0;overflow:hidden}.loading-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:#0f172a}.loading-spinner{color:#94a3b8;font-size:16px}.verification-warning{padding:8px 12px;border-radius:8px;background:#fbbf2426;color:#fbbf24;font-size:12px;margin-bottom:8px}.verification-blocked{padding:8px 12px;border-radius:8px;background:#f8717126;color:#f87171;font-size:12px;margin-bottom:8px}.error-boundary{display:flex;align-items:center;justify-content:center;min-height:100vh;background:#0f172a;padding:24px}.error-boundary-content{max-width:500px;background:#111827;padding:32px;border-radius:16px;text-align:center}.error-boundary-content h1{color:#e2e8f0;margin:0 0 16px}.error-boundary-content p{color:#94a3b8;margin:0 0 24px}.error-boundary-content button{background:#2563eb;color:#f8fafc;border:none;padding:12px 24px;border-radius:8px;font-weight:600;cursor:pointer}.error-boundary-content button:hover{background:#1d4ed8}
