.topbar{position:sticky;top:0;z-index:100;display:flex;align-items:center;padding:0 1.5rem;height:56px;background:#13152a;border-bottom:1px solid #2a2d4a;box-shadow:0 2px 12px #00000080}.topbar-title{font-size:1.125rem;font-weight:600;letter-spacing:.02em;color:#e2e6f5;flex:1}.topbar-logout{background:none;border:1px solid #2a2d4a;border-radius:6px;color:#6b7299;font-size:.8rem;padding:.3rem .75rem;cursor:pointer;transition:color .15s,border-color .15s;font-family:inherit}.topbar-logout:hover{color:#e2e6f5;border-color:#4a4f7a}.error-page{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.25rem;min-height:calc(100vh - 56px);text-align:center;padding:2rem}.error-page__icon{width:64px;height:64px;color:#e07aaa}.error-page__title{font-size:1.375rem;font-weight:600;color:#e2e6f5}.error-page__message{font-size:.9375rem;color:#7a82aa}.error-page__button{display:inline-flex;align-items:center;gap:.5rem;margin-top:.5rem;padding:.6rem 1.4rem;border:1px solid #4a3fa0;border-radius:8px;background:#2e2a6e;color:#c8cfe8;font-size:.9375rem;font-weight:500;cursor:pointer;transition:background .15s ease,border-color .15s ease}.error-page__button:hover{background:#3a3588;border-color:#6a5fc0}.error-page__button:active{background:#252060}.skeleton{background:#181b33;border-radius:8px;border:1px solid #2a2d4a;overflow:hidden;position:relative}.skeleton:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent 0%,rgba(120,100,220,.08) 50%,transparent 100%);background-size:200% 100%;animation:skeleton-shimmer 1.6s ease-in-out infinite}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-dashboard{max-width:960px;margin:0 auto;padding:2rem;display:flex;flex-direction:column;gap:1.5rem}.skeleton-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem}.skeleton-card{height:96px}.skeleton-block{height:220px}.server-list{background:#181b33;border:1px solid #2a2d4a;border-radius:12px;padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.server-list-title{font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:#6b7299}.server-list-items{list-style:none;display:flex;flex-direction:column;gap:.6rem}.server-item{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;border-radius:8px;background:#13152a;border:1px solid #23264a;cursor:pointer;transition:background .15s,border-color .15s}.server-item:hover{background:#1a1e38;border-color:#3a3f6a}.server-name{font-weight:600;font-size:.95rem;color:#e2e6f5;flex:1}.server-last-seen{font-size:.78rem;color:#6b7299;white-space:nowrap}.server-item-chevron{font-size:1.1rem;color:#3a3f6a;line-height:1;transition:color .15s}.server-item:hover .server-item-chevron{color:#6b7299}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:200;animation:fade-in .2s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.drawer{position:fixed;bottom:0;left:0;right:0;z-index:201;max-height:80vh;background:#13152a;border-top:1px solid #2a2d4a;border-radius:16px 16px 0 0;display:flex;flex-direction:column;transform:translateY(100%);transition:transform .3s cubic-bezier(.32,.72,0,1);box-shadow:0 -8px 40px #0009}.drawer--open{transform:translateY(0)}.drawer-handle-row{display:flex;justify-content:center;padding:.75rem 0 .25rem;flex-shrink:0}.drawer-handle{width:40px;height:4px;border-radius:2px;background:#2a2d4a}.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem 1rem;border-bottom:1px solid #1e2140;flex-shrink:0}.drawer-header-left{display:flex;align-items:center;gap:.75rem}.drawer-hostname{font-size:1.2rem;font-weight:700;color:#e2e6f5}.drawer-close{background:none;border:none;color:#6b7299;font-size:1rem;cursor:pointer;padding:.25rem .5rem;border-radius:6px;transition:color .15s,background .15s}.drawer-close:hover{color:#e2e6f5;background:#1e2140}.drawer-body{overflow-y:auto;padding:1.25rem 1.5rem 2rem;display:flex;flex-direction:column;gap:1.5rem}.drawer-section{display:flex;flex-direction:column;gap:.75rem}.drawer-section-title{font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#6b7299}.stat-grid{display:flex;flex-wrap:wrap;gap:.5rem}.stat{background:#181b33;border:1px solid #2a2d4a;border-radius:8px;padding:.5rem .85rem;display:flex;flex-direction:column;gap:.2rem;min-width:120px}.stat-label{font-size:.65rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#6b7299}.stat-value{font-size:.9rem;font-weight:600;color:#e2e6f5;font-variant-numeric:tabular-nums}.resource-rows{display:flex;flex-direction:column;gap:.85rem}.resource-row{display:flex;flex-direction:column;gap:.3rem}.resource-row-header{display:flex;justify-content:space-between;align-items:baseline}.resource-label{font-size:.8rem;color:#c8cfe8;font-weight:500}.resource-value{font-size:.78rem;color:#6b7299;font-variant-numeric:tabular-nums}.bar-wrap{height:6px;background:#1e2140;border-radius:3px;overflow:hidden}.bar-fill{height:100%;border-radius:3px;transition:width .4s ease}.bar-fill--ok{background:#4ade80}.bar-fill--warn{background:#facc15}.bar-fill--danger{background:#f87171}.container-group-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#4a4f7a;margin-bottom:-.25rem}.container-list{list-style:none;display:flex;flex-direction:column;gap:.4rem}.container-item{display:grid;grid-template-columns:10px 1fr 1fr auto;align-items:center;gap:.6rem;padding:.45rem .75rem;background:#181b33;border:1px solid #2a2d4a;border-radius:7px;font-size:.82rem}.container-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.container-dot--running{background:#4ade80}.container-dot--stopped{background:#f87171}.container-name{font-weight:600;color:#e2e6f5;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.container-image{color:#6b7299;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.container-status{color:#4a4f7a;white-space:nowrap;text-align:right;font-size:.75rem}.server-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.server-dot--green{background:#4ade80;box-shadow:0 0 6px #4ade8088}.server-dot--yellow{background:#facc15;box-shadow:0 0 6px #facc1588}.server-dot--red{background:#f87171;box-shadow:0 0 6px #f8717188}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#0d0f1e;padding:1rem}.login-card{width:100%;max-width:360px;background:#181b33;border:1px solid #2a2d4a;border-radius:16px;padding:2rem 2rem 2.5rem;display:flex;flex-direction:column;gap:1.75rem}.login-title{font-size:1.1rem;font-weight:700;color:#e2e6f5;text-align:center;letter-spacing:.02em}.login-form{display:flex;flex-direction:column;gap:1rem}.login-field{display:flex;flex-direction:column;gap:.4rem}.login-label{font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#6b7299}.login-input{background:#13152a;border:1px solid #2a2d4a;border-radius:8px;padding:.6rem .75rem;font-size:.95rem;color:#e2e6f5;outline:none;transition:border-color .15s;font-family:inherit}.login-input:focus{border-color:#5b6aaa}.login-input:disabled{opacity:.5}.login-error{font-size:.82rem;color:#f87171;text-align:center}.login-btn{margin-top:.5rem;padding:.65rem;border:none;border-radius:8px;background:#3d4fa0;color:#e2e6f5;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s;font-family:inherit}.login-btn:hover:not(:disabled){background:#4d61b8}.login-btn:disabled{opacity:.6;cursor:not-allowed}*{box-sizing:border-box;margin:0;padding:0}body{font-family:system-ui,sans-serif;background:#0d0f1e;color:#c8cfe8}main{max-width:960px;margin:0 auto;padding:2rem}.dashboard-grid{display:grid;grid-template-columns:auto 1fr;gap:1.25rem;align-items:stretch}@media (max-width: 600px){.dashboard-grid{grid-template-columns:1fr}}h1{font-size:2rem;margin-bottom:1.5rem}
