@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&display=swap";.toast-stack[data-v-1bb5cb6c]{position:fixed;top:16px;right:16px;display:flex;flex-direction:column;gap:8px;z-index:2000}.toast[data-v-1bb5cb6c]{min-width:220px;background:#111827;border:1px solid #1f2937;color:#e5e7eb;padding:10px 12px;border-radius:8px;box-shadow:0 4px 12px #00000059;display:flex;justify-content:space-between;align-items:center}.toast.success[data-v-1bb5cb6c]{border-color:#10b981;color:#ecfdf3}.toast.error[data-v-1bb5cb6c]{border-color:#ef4444;color:#fee2e2}.toast.info[data-v-1bb5cb6c]{border-color:#3b82f6;color:#e0f2fe}.toast button[data-v-1bb5cb6c]{background:transparent;border:none;color:inherit;cursor:pointer}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:#0f0f0f;color:#e5e5e5}#app{min-height:100vh}a{text-decoration:none;color:inherit}*{margin:0;padding:0;box-sizing:border-box}:root{color-scheme:dark;--font-sans: "Space Grotesk", "Inter", "Segoe UI", system-ui, -apple-system, sans-serif;--bg-body: #05070b;--bg-elevated: #0c121b;--bg-surface: #111927;--bg-accent: linear-gradient(135deg, rgba(0, 204, 255, .12), rgba(0, 153, 255, .08));--border-color: rgba(255, 255, 255, .06);--border-strong: rgba(0, 204, 255, .35);--text-primary: #f8fbff;--text-secondary: rgba(217, 226, 240, .72);--text-muted: rgba(127, 150, 179, .72);--brand-cyan: #00ccff;--brand-green: #22d3a5;--danger: #ef4444;--radius-lg: 18px;--radius-md: 14px;--radius-sm: 10px;--sidebar-width: clamp(168px, 12.5vw, 192px);--sidebar-width-md: clamp(148px, 16vw, 172px);--sidebar-width-sm: 64px;--page-padding: clamp(1.5rem, 1vw + 1rem, 2.5rem);--page-max-width: 1440px;--transition-snappy: .18s ease;--shadow-soft: 0 14px 40px rgba(4, 11, 24, .35)}body{font-family:var(--font-sans);background:radial-gradient(circle at top left,rgba(0,204,255,.08),transparent 45%),var(--bg-body);color:var(--text-primary);line-height:1.56;min-height:100vh;-webkit-font-smoothing:antialiased}#app{min-height:100dvh;display:flex;flex-direction:column}.page-shell{display:flex;min-height:100dvh;width:100%;position:relative;background:transparent}.page-content{flex:1;margin-left:calc(var(--sidebar-width) + clamp(1.1rem,1.8vw,2.2rem));padding:var(--page-padding);width:100%;max-width:none;margin-right:clamp(1.1rem,1.8vw,2.2rem);display:flex;flex-direction:column;gap:clamp(1.5rem,1vw + 1rem,2.5rem)}.page-section{background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);overflow:hidden}.page-header{display:flex;align-items:center;justify-content:space-between;gap:clamp(1rem,2vw,2rem);background:var(--bg-surface);border-radius:var(--radius-lg);padding:clamp(1.25rem,1.5vw,2rem) clamp(1.25rem,2vw,2.5rem);border:1px solid var(--border-color);position:sticky;top:clamp(.75rem,1vw,1.5rem);z-index:5;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background-image:linear-gradient(125deg,#00ccff17,#111a24bf)}.page-header .page-title{display:flex;flex-direction:column;gap:.35rem;text-align:center;flex:1}.page-header h1{font-size:clamp(1.6rem,2.4vw,2.2rem);font-weight:600;letter-spacing:-.01em;color:var(--text-primary)}.page-header p{color:var(--text-secondary);font-size:clamp(.9rem,.85vw,1.05rem)}.page-header .page-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:.75rem}.menu-toggle{display:none;position:fixed;top:18px;left:18px;z-index:4000;background:#0a121cf2;border:1px solid var(--border-strong);color:var(--text-primary);padding:10px 14px;border-radius:999px;font-size:1.2rem;box-shadow:0 12px 35px #0099ff2e;transition:var(--transition-snappy)}.menu-toggle:active{transform:translateY(1px) scale(.96)}.tag-badge{display:inline-flex;align-items:center;gap:.4rem;padding:.25rem .75rem;border-radius:999px;font-size:.75rem;font-weight:600;background:#00ccff1f;border:1px solid rgba(0,204,255,.32);color:var(--brand-cyan);text-transform:uppercase;letter-spacing:.08em}.card-grid{display:grid;gap:clamp(1rem,1.5vw,1.75rem)}.card-grid.columns-2{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.card-grid.columns-3{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.page-card{background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:clamp(1rem,1.2vw,1.75rem);display:flex;flex-direction:column;gap:.85rem;position:relative}.page-card .card-heading{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.page-card h2,.page-card h3{font-size:clamp(1.1rem,1.4vw,1.35rem);font-weight:600;color:var(--text-primary)}.page-card p{font-size:.95rem;color:var(--text-secondary)}.btn,.btn-primary,.btn-secondary,.btn-danger,.refresh-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border-radius:999px;padding:.65rem 1.4rem;font-size:.95rem;font-weight:600;cursor:pointer;border:1px solid transparent;transition:var(--transition-snappy);min-height:42px;white-space:nowrap}.btn-primary,.refresh-btn{background:linear-gradient(135deg,#00ccffd9,#0080ffd9);color:#001625;border-color:#00ccffa6;box-shadow:0 12px 24px #00ccff2e}.btn-primary:hover,.refresh-btn:hover{transform:translateY(-1px);box-shadow:0 18px 32px #00ccff38}.btn-secondary{background:#111a24e6;border-color:#0cf3;color:var(--text-primary)}.btn-secondary:hover{border-color:#00ccff73}.btn-danger{background:#ef44441f;border-color:#ef444459;color:#fca5a5}.btn-danger:hover{background:#ef444433}.desktop-only{display:block}.mobile-only{display:none}.table-wrapper{width:100%;overflow-x:auto;border-radius:var(--radius-md);border:1px solid rgba(255,255,255,.04);background:#080c14cc}table{width:100%;border-collapse:collapse;min-width:720px;font-size:.92rem}thead{background:#0f1824d9;text-transform:uppercase;letter-spacing:.08em}th,td{padding:.9rem 1.2rem;border-bottom:1px solid rgba(255,255,255,.04);text-align:left}th{font-size:.75rem;color:var(--text-muted)}tbody tr:hover{background:#0099ff0d}.mobile-card-list{display:grid;gap:1rem}.mobile-card{background:#0e1420f2;border:1px solid rgba(0,204,255,.12);border-radius:var(--radius-md);padding:1rem;display:flex;flex-direction:column;gap:.65rem}.mobile-card .mobile-row{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;font-size:.9rem}.mobile-card .mobile-row strong{color:var(--text-secondary);font-weight:600}.status-dot{width:9px;height:9px;border-radius:50%;display:inline-flex;margin-right:.5rem;box-shadow:0 0 12px #00ffaa59}.status-dot.online{background:var(--brand-green)}.status-dot.offline{background:#ef4444d9;box-shadow:0 0 12px #ef444459}.role-badge{border-radius:999px;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-flex;align-items:center;gap:.4rem}.role-badge.admin{background:#ffbc4a1f;color:#fbbf24;border:1px solid rgba(255,188,74,.45)}.role-badge.user{background:#00ccff1f;color:var(--brand-cyan);border:1px solid rgba(0,204,255,.32)}.empty-state,.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:clamp(2.5rem,6vh,4rem);background:#0a1018d9;border-radius:var(--radius-lg);border:1px dashed rgba(0,204,255,.15);color:var(--text-secondary);text-align:center}.empty-state .empty-icon{font-size:clamp(2.5rem,5vw,3.5rem)}.spinner{width:44px;height:44px;border-radius:50%;border:3px solid rgba(0,204,255,.2);border-top-color:var(--brand-cyan);animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.stats-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:clamp(.85rem,1.25vw,1.5rem);padding:clamp(1.1rem,1.5vw,1.75rem);background:#0c1420d9;border-radius:var(--radius-lg);border:1px solid rgba(0,204,255,.08)}.stat-block{display:flex;flex-direction:column;gap:.35rem}.stat-block .label{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.stat-block .value{font-size:clamp(1.45rem,2.4vw,2.1rem);font-weight:600;color:var(--text-primary)}.stat-block .value.success{color:var(--brand-green)}.stat-block .value.warning{color:#facc15}.stat-block .value.danger{color:var(--danger)}.grid-auto-fit{display:grid;gap:clamp(1rem,1.5vw,1.75rem);grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.scrollable{overflow:auto;scrollbar-width:thin;scrollbar-color:rgba(0,204,255,.25) transparent}.scrollable::-webkit-scrollbar{width:8px;height:8px}.scrollable::-webkit-scrollbar-thumb{background:#00ccff40;border-radius:999px}.label-muted{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.mono{font-family:Fira Code,JetBrains Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.chip{display:inline-flex;align-items:center;padding:.35rem .85rem;border-radius:999px;background:#00ccff1f;border:1px solid rgba(0,204,255,.25);font-size:.75rem;color:var(--brand-cyan);font-weight:600}.danger-text{color:#f87171d9}.success-text{color:#2dd4bfe6}.muted-text{color:var(--text-muted)}.list-pills{display:flex;flex-wrap:wrap;gap:.45rem}.pill{padding:.3rem .75rem;border-radius:999px;background:#00ccff1a;color:var(--brand-cyan);font-size:.78rem;font-weight:500}.divider-line{width:100%;height:1px;background:#ffffff0f;margin:.75rem 0}.section-title{font-size:clamp(1.15rem,1.6vw,1.4rem);font-weight:600;color:var(--text-primary)}.section-subtitle{font-size:.95rem;color:var(--text-secondary)}.chip-list{display:flex;flex-wrap:wrap;gap:.45rem}.chip-item{padding:.3rem .85rem;border-radius:999px;background:#0f1824d9;border:1px solid rgba(0,204,255,.18);font-size:.78rem;color:var(--text-secondary)}.sticky-actions{position:sticky;top:clamp(.85rem,1vw,1.5rem);z-index:4}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:5000;display:grid;place-items:center}.modal-surface{width:min(520px,calc(100vw - 2.5rem));background:#0a121cf2;border-radius:var(--radius-lg);border:1px solid rgba(0,204,255,.2);box-shadow:0 24px 60px #030810a6;padding:clamp(1.25rem,1.8vw,2rem)}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.modal-header h2{font-size:1.4rem;font-weight:600}.modal-body{display:flex;flex-direction:column;gap:1rem}form .form-row{display:grid;gap:.75rem}label{font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-weight:600}input,select,textarea{width:100%;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.08);background:#090c14d9;padding:.75rem 1rem;color:var(--text-primary);font-family:var(--font-sans);font-size:.95rem;transition:border var(--transition-snappy),background var(--transition-snappy)}input:focus,select:focus,textarea:focus{outline:none;border-color:#00ccff73;box-shadow:0 0 0 3px #00ccff1f}.danger-border{border-color:#ef444473!important;box-shadow:0 0 0 3px #ef44442e}@media (max-width: 1280px){:root{--sidebar-width: var(--sidebar-width-md)}}@media (max-width: 1024px){.page-content{margin-left:calc(var(--sidebar-width-sm) + clamp(.75rem,2vw,1.4rem));margin-right:clamp(.75rem,2vw,1.4rem)}table{min-width:640px}}@media (max-width: 840px){.page-header{flex-direction:column;align-items:center;text-align:center;position:relative}.page-header .page-actions{width:100%;justify-content:center}.page-content{margin-left:0;margin-right:0;padding-top:calc(var(--page-padding) + 1.5rem)}.menu-toggle{display:inline-flex}.desktop-only{display:none}.mobile-only{display:block}body{overflow-x:hidden}.sidebar{position:fixed;inset:0 auto 0 0;width:clamp(220px,70vw,260px);transform:translate(-100%);transition:transform var(--transition-snappy);box-shadow:0 24px 60px #030810bf}.sidebar.open{transform:translate(0)}.page-content{padding-inline:clamp(1.15rem,4vw,1.75rem)}.page-card{padding:clamp(.95rem,3vw,1.35rem)}.stats-bar{grid-template-columns:1fr 1fr}}@media (max-width: 640px){.page-header{padding:1.1rem 1.2rem}.page-header .page-title{gap:.25rem}.page-header h1{font-size:1.45rem}.page-card h2,.page-card h3{font-size:1.08rem}.page-card{gap:.7rem}.stats-bar{grid-template-columns:1fr}.mobile-card-list{display:grid;gap:.9rem}.mobile-card .mobile-row{flex-direction:column;gap:.25rem}.page-header .page-actions{flex-direction:column}.btn,.btn-primary,.btn-secondary,.btn-danger,.refresh-btn{width:100%}}@media (max-width: 420px){.page-content{padding-inline:clamp(.85rem,5vw,1.2rem)}.card-grid.columns-2,.card-grid.columns-3,.grid-auto-fit{grid-template-columns:1fr}}
