.topbar{z-index:1001;background:#0d0d0d;border-bottom:1px solid #222;justify-content:space-between;align-items:center;height:60px;padding:0 24px;display:flex;position:fixed;top:0;left:0;right:0}.topbar-title{color:#f0f0f0;letter-spacing:.5px;font-size:1.15rem;font-weight:700}.topbar-right{align-items:center;gap:16px;display:flex}.topbar-user{flex-direction:column;align-items:flex-end;line-height:1.25;display:flex}.topbar-user-name{color:#e5e5e5;font-size:.85rem}.topbar-user-email{color:#777;font-size:.75rem}.topbar-role{text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;border:1px solid #0000;border-radius:999px;padding:4px 12px;font-size:.7rem;font-weight:600}.topbar-role--admin{color:#c4b5fd;background:#8b5cf626;border-color:#8b5cf666}.topbar-role--role{color:#6ee7a8;background:#34d3991f;border-color:#34d39959}.topbar-role--none{color:#fca5a5;background:#ef44441f;border-color:#ef444459}@media (width<=480px){.topbar-title{font-size:1rem}.topbar-user-email{display:none}}.info-tooltip{align-items:center;display:inline-flex}.info-tooltip__trigger{color:#aaa;cursor:help;background:#161616;border:1px solid #3a3a3a;border-radius:50%;flex:0 0 18px;justify-content:center;align-items:center;width:18px;height:18px;padding:0;font-family:Georgia,Times New Roman,serif;font-size:.72rem;font-style:italic;font-weight:700;line-height:1;transition:border-color .15s,color .15s,background .15s;display:inline-flex}.info-tooltip__trigger:hover,.info-tooltip__trigger:focus-visible{color:#f0f0f0;background:#1e1e1e;border-color:#888;outline:none}.info-tooltip__popover{z-index:1100;pointer-events:none;background:#1a1a1a;border:1px solid #333;border-radius:8px;flex-direction:column;gap:6px;width:240px;padding:12px 14px;display:flex;position:fixed;transform:translateY(-50%);box-shadow:0 8px 24px #0009}.info-tooltip__title{color:#f0f0f0;letter-spacing:.02em;font-size:.8rem;font-weight:700}.info-tooltip__body{color:#b5b5b5;font-size:.78rem;line-height:1.5}.sidebar{z-index:1000;background:#0d0d0d;border-right:1px solid #222;flex-direction:column;width:260px;height:calc(100dvh - 60px);transition:width .2s;display:flex;position:fixed;top:60px;left:0}.sidebar.collapsed{width:72px}.sidebar-header{border-bottom:1px solid #1c1c1c;justify-content:flex-end;padding:12px;display:flex}.sidebar-toggle{color:#aaa;cursor:pointer;background:#161616;border:1px solid #2a2a2a;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;font-size:1rem;transition:border-color .15s,color .15s;display:flex}.sidebar-toggle:hover{color:#eee;border-color:#555}.sidebar-nav{flex:1;padding:12px 0;overflow:visible auto}.sidebar-item{align-items:center;display:flex}.sidebar-item .sidebar-link{flex:1;min-width:0}.sidebar-info{align-items:center;padding-left:4px;padding-right:14px;display:flex}.sidebar.collapsed .sidebar-info{display:none}.sidebar-link{color:#999;white-space:nowrap;border-left:3px solid #0000;align-items:center;gap:14px;padding:12px 18px;text-decoration:none;transition:background .15s,color .15s,border-color .15s;display:flex}.sidebar-link:hover{color:#e5e5e5;background:#141414}.sidebar-link.active{color:#f0f0f0;background:#161616;border-left-color:silver}.sidebar-icon{justify-content:center;align-items:center;min-width:24px;font-size:1.25rem;display:flex}.sidebar-label{font-size:.9rem;font-weight:500;transition:opacity .2s}.sidebar.collapsed .sidebar-label{opacity:0;width:0;overflow:hidden}.sidebar-footer{border-top:1px solid #1c1c1c;padding:14px}.sidebar-logout{color:#aaa;cursor:pointer;background:0 0;border:1px solid #3a3a3a;border-radius:6px;align-items:center;gap:14px;width:100%;padding:10px 12px;font-size:.9rem;transition:border-color .15s,color .15s;display:flex}.sidebar-logout:hover{color:#eee;border-color:#aaa}@media (width<=768px){.sidebar{width:72px}.sidebar .sidebar-label{opacity:0;width:0;overflow:hidden}.sidebar .sidebar-info{display:none}}.global-loader{z-index:9999;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0a0a0c8c;justify-content:center;align-items:center;animation:.15s ease-out global-loader-fade;display:flex;position:fixed;inset:0}.global-loader__spinner{border:4px solid #ffffff1f;border-top-color:#6ee7a8;border-radius:50%;width:54px;height:54px;animation:.8s linear infinite global-loader-spin}@keyframes global-loader-spin{to{transform:rotate(360deg)}}@keyframes global-loader-fade{0%{opacity:0}to{opacity:1}}@media (prefers-reduced-motion:reduce){.global-loader__spinner{animation-duration:1.6s}.global-loader{animation:none}}.login-container{justify-content:center;align-items:center;min-height:100dvh;padding:24px;display:flex}.login-card{text-align:center;background:#111;border:1px solid #222;width:100%;max-width:420px;padding:48px 40px}.login-header h1{color:#f0f0f0;margin-bottom:8px;font-size:1.5rem;font-weight:700}.login-header h2{color:#888;margin-bottom:32px;font-size:1rem;font-weight:400}.login-content{flex-direction:column;align-items:center;gap:16px;display:flex}.login-content p{color:#888;font-size:.875rem}.loading-spinner{border:2px solid #333;border-top-color:silver;border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.login-retry-btn{color:silver;cursor:pointer;font-size:inherit;background:0 0;border:none;text-decoration:underline}.login-retry-btn:hover{color:#eee}*,:before,:after{box-sizing:border-box}*{margin:0;padding:0}body{color:#d4d4d4;background:#0a0a0a;min-height:100dvh;font-family:system-ui,-apple-system,sans-serif}#root select{appearance:none;cursor:pointer;color:#e5e5e5;background-color:#0d0d0d;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6'><path d='M0 0l5 6 5-6z' fill='%239a9a9a'/></svg>");background-position:right 6px center;background-repeat:no-repeat;border:1px solid #2a2a2a;border-radius:6px;padding:0 18px 0 8px}#root select:hover:not(:disabled){border-color:#3a3a3a}#root select:focus{border-color:#3a3a3a;outline:none}#root select:disabled{opacity:.55;cursor:default}#root select option{color:#e5e5e5;background-color:#141414}#root input:read-only,#root textarea:read-only{cursor:default}#root .gamemgmt select:disabled{opacity:1;cursor:default}#root input[type=checkbox]{appearance:none;vertical-align:middle;cursor:pointer;background-color:#0d0d0d;border:2px solid #4a4a4a;border-radius:4px;flex:none;width:18px;height:18px;margin:0;transition:background-color .12s,border-color .12s;position:relative}#root input[type=checkbox]:hover:not(:disabled){border-color:#3c7d5b}#root input[type=checkbox]:focus-visible{outline-offset:1px;outline:2px solid #3c7d5b}#root input[type=checkbox]:checked{background-color:#2f8f5b;border-color:#3fae72}#root input[type=checkbox]:checked:after{content:"";border:2px solid #f3fff8;border-width:0 2px 2px 0;width:5px;height:9px;position:absolute;top:1px;left:4px;transform:rotate(45deg)}#root input[type=checkbox]:disabled{cursor:default;opacity:1}#root input[type=checkbox]:disabled:not(:checked){background-color:#0e0e0e;border-color:#555}#root input[type=checkbox]:disabled:checked{background-color:#2a7a50;border-color:#3aa068}#root input[type=checkbox]:disabled:checked:after{border-color:#eafff3}.loading-container{flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:100dvh;display:flex}.home-container{flex-direction:column;min-height:100dvh;display:flex}.home-header{border-bottom:1px solid #222;justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.home-header h1{font-size:1.25rem;font-weight:600}.home-main{flex:1;padding:32px 24px}.logout-btn{color:#aaa;cursor:pointer;background:0 0;border:1px solid #3a3a3a;padding:8px 16px;font-size:.875rem;transition:border-color .15s,color .15s}.logout-btn:hover{color:#eee;border-color:#aaa}.home-greeting{color:#888;margin-bottom:20px;font-size:.9rem}.auth-status{color:#6ee7a8;align-items:center;gap:8px;margin-bottom:28px;font-size:.875rem;display:inline-flex}.auth-status__badge{background:#34d399;border-radius:50%;width:8px;height:8px;box-shadow:0 0 8px #34d39980}.card{background:#111;border:1px solid #222;max-width:640px;margin-bottom:20px;padding:24px}.card__title{letter-spacing:.08em;text-transform:uppercase;color:silver;justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:16px;font-size:.8rem;font-weight:600;display:flex}.card__source{letter-spacing:0;text-transform:none;color:#666;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.7rem;font-weight:400}.identity{grid-template-columns:max-content 1fr;align-items:baseline;gap:10px 20px;display:grid}.identity dt{color:#777;font-size:.8rem}.identity dd{color:#e5e5e5;word-break:break-all;font-size:.9rem}.identity .mono{color:silver;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.82rem}.group-list{flex-wrap:wrap;gap:8px;display:flex}.group-chip{color:#d4d4d4;background:#1a1a1a;border:1px solid #2e2e2e;border-radius:999px;padding:4px 12px;font-size:.82rem;list-style:none}.empty{color:#777;font-size:.875rem}.app-content{min-height:100dvh}.page-container{min-height:calc(100dvh - 60px);margin-top:60px;margin-left:260px;transition:margin-left .2s}.page-container.collapsed{margin-left:72px}.page-content{padding:32px 28px}@media (width<=768px){.page-container,.page-container.collapsed{margin-left:72px}}.module-header{align-items:center;gap:16px;margin-bottom:28px;display:flex}.module-header__icon{font-size:2rem;line-height:1}.module-header__title{color:#f0f0f0;font-size:1.4rem;font-weight:700}.module-header__subtitle{color:#888;max-width:560px;margin-top:4px;font-size:.9rem}.placeholder{text-align:center;color:#777;background:#0e0e0e;border:1px dashed #2a2a2a;border-radius:8px;max-width:640px;padding:48px 24px;font-size:.95rem}.access-denied{max-width:640px}.access-denied h2{color:#fca5a5;margin-bottom:12px;font-size:1.3rem}.access-denied p{color:#aaa;margin-bottom:6px;font-size:.9rem}.access-denied__hint{color:#777;font-size:.85rem}
