@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&family=Inter:wght@400;500;600&display=swap";:root{--bg-dark:#0a0d14;--bg-darker:#05060a;--glass-bg:#ffffff08;--glass-border:#ffffff14;--glass-hover:#ffffff0d;--glass-thick:#0a0d14e0;--primary:#8b5cf6;--primary-glow:#8b5cf666;--secondary:#00f0ff;--secondary-glow:#00f0ff66;--success:#10b981;--danger:#f43f5e;--warning:#f59e0b;--info:#3b82f6;--text-main:#f9fafb;--text-muted:#9ca3af;--sidebar-width:280px;--topbar-height:72px;--page-padding:clamp(1.5rem, 4vw, 3rem);--radius-sm:8px;--radius-md:12px;--radius-lg:24px;--font-heading:"Outfit", sans-serif;--font-body:"Inter", sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);background-color:var(--bg-dark);color:var(--text-main);-webkit-font-smoothing:antialiased;background-image:radial-gradient(circle at 0 0,#8b5cf61f 0%,#0000 40%),radial-gradient(circle at 100% 100%,#00f0ff1a 0%,#0000 40%);background-attachment:fixed;min-height:100vh;line-height:1.6;overflow-x:hidden}#root{width:100%;min-height:100vh;display:flex}.app-shell{width:100%;min-height:100vh;display:flex;position:relative}.sidebar{z-index:100;width:var(--sidebar-width);border-right:1px solid var(--glass-border);background:#0a0d14fa;flex-direction:column;height:100vh;padding:24px 16px;display:flex;position:fixed;top:0;left:0}.main-content{margin-left:var(--sidebar-width);background:0 0;flex-direction:column;flex:1;min-height:100vh;display:flex}.sidebar-item{border-radius:var(--radius-md);color:var(--text-muted);align-items:center;gap:12px;margin-bottom:4px;padding:10px 12px;font-size:13px;font-weight:500;text-decoration:none;transition:background .15s,color .15s,transform .15s;display:flex}.sidebar-item:hover{background:var(--glass-hover);color:var(--text-main)}.sidebar-item.active{color:#fff;background:#8b5cf61f;border:1px solid #8b5cf640;box-shadow:0 0 0 1px #8b5cf614}.sidebar-item svg{opacity:.9;flex-shrink:0}.sidebar-item.active svg{color:var(--primary)}.page-shell{padding:var(--page-padding);flex:1;width:100%;max-width:1600px;margin:0 auto}.topbar{height:var(--topbar-height);padding:0 var(--page-padding);z-index:90;-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--glass-border);background:#0a0d14b3;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.topbar-left{flex:1;align-items:center;gap:16px;min-width:0;display:flex}.topbar-divider{background:#ffffff14;flex-shrink:0;width:1px;height:24px;margin:0 8px}.topbar-title-wrap{flex-direction:column;flex-shrink:0;min-width:0;display:flex}.topbar-title{font-family:var(--font-heading);color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:1.25rem;font-weight:700;line-height:1.2;overflow:hidden}.topbar-sub{color:var(--text-muted);margin-top:2px;font-size:.75rem;font-weight:500}.topbar-search{border:1px solid var(--glass-border);border-radius:var(--radius-md);background:#ffffff0d;align-items:center;gap:10px;width:100%;max-width:280px;height:38px;margin-left:20px;padding:0 12px;transition:all .2s;display:flex;position:relative}.topbar-search:focus-within{border-color:var(--primary);background:#ffffff14;max-width:320px;box-shadow:0 0 0 4px #8b5cf61a}.topbar-search input{color:#fff;background:0 0;border:none;outline:none;width:100%;font-size:13px;font-weight:500}.topbar-search input::placeholder{color:var(--text-muted)}.topbar-kbd{color:var(--text-muted);background:#ffffff14;border:1px solid #ffffff1a;border-radius:4px;align-items:center;gap:4px;padding:2px 6px;font-size:10px;font-weight:600;display:flex}.topbar-icon-btn{background:var(--glass-bg);border:1px solid var(--glass-border);width:38px;height:38px;color:var(--text-muted);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;transition:all .2s;display:flex}.topbar-icon-btn:hover{background:var(--glass-hover);color:#fff;border-color:#fff3;transform:translateY(-1px)}.topbar-menu-btn{display:none}.section-header{justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:40px;display:flex}.section-title{margin-bottom:4px;font-size:32px;font-weight:700}.section-subtitle{color:var(--text-muted);font-size:14px}.modal-overlay{z-index:2000;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#020408d9;justify-content:center;align-items:center;padding:24px;animation:.25s ease-out fadeIn;display:flex;position:fixed;inset:0}.modal-container{background:var(--glass-thick);border:1px solid var(--glass-border);border-radius:var(--radius-lg);width:100%;max-width:560px;padding:32px;animation:.4s cubic-bezier(.16,1,.3,1) modalIn;position:relative;box-shadow:0 30px 60px -12px #0009}.modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;transition:color .2s;position:absolute;top:24px;right:24px}.modal-close:hover{color:var(--text-main)}.table-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 4px 20px #0003}.table-wrapper{overflow-x:auto}.data-table{border-collapse:collapse;width:100%}.data-table th{color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;border-bottom:1px solid var(--glass-border);background:#ffffff05;padding:20px 24px;font-size:11px;font-weight:700}.data-table td{border-bottom:1px solid #ffffff08;padding:20px 24px;font-size:14px}.data-table tr:hover:not(.empty-row) td{background:#ffffff05}.btn-primary{background:linear-gradient(135deg, var(--primary) 0%, #6d28d9 100%);color:#fff;border-radius:var(--radius-md);cursor:pointer;box-shadow:0 4px 15px var(--primary-glow);border:none;align-items:center;gap:8px;padding:12px 24px;font-weight:600;transition:all .2s;display:flex}.btn-primary:hover{box-shadow:0 8px 25px var(--primary-glow);transform:translateY(-2px)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.btn-secondary{border-radius:var(--radius-md);color:#e2e8f0;cursor:pointer;white-space:nowrap;background:#ffffff0f;border:1px solid #ffffff24;justify-content:center;align-items:center;gap:8px;padding:10px 18px;font-family:inherit;font-size:13px;font-weight:600;transition:all .2s;display:inline-flex}.btn-secondary:hover:not(:disabled){color:#fff;background:#ffffff1a;border-color:#ffffff38}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.search-input-wrap{width:100%;max-width:320px;position:relative}.form-group{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.form-label{color:var(--text-muted);font-size:13px;font-weight:500}.form-input{border:1px solid var(--glass-border);border-radius:var(--radius-md);color:#fff;background:#00000040;width:100%;padding:12px 16px;font-family:inherit;transition:all .2s}.form-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 4px #8b5cf626}.input-field{border:1px solid var(--glass-border);border-radius:var(--radius-md);color:#fff;background:#00000040;width:100%;padding:12px 16px 12px 48px;font-family:inherit;transition:all .2s}.input-field:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 4px #8b5cf626}.glass-panel,.glass-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.glass-panel{box-shadow:0 4px 24px #00000040}.btn-ghost{border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--text-main);cursor:pointer;white-space:nowrap;background:#ffffff0a;align-items:center;gap:8px;padding:10px 16px;font-family:inherit;font-size:13px;font-weight:500;transition:all .2s;display:inline-flex}.btn-ghost:hover:not(:disabled){background:var(--glass-hover);border-color:#ffffff2e}.btn-ghost:disabled{opacity:.45;cursor:not-allowed}.badge{letter-spacing:.02em;border-radius:999px;align-items:center;padding:4px 10px;font-size:11px;font-weight:600;display:inline-flex}.dashboard-stats-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}@media (width>=900px){.dashboard-stats-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}.dashboard-stats-grid--4{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}@media (width>=768px){.dashboard-stats-grid--4{grid-template-columns:repeat(4,minmax(0,1fr))}}.fade-in{animation:.35s ease-out fadeIn}.room-card{flex-direction:column;gap:14px;padding:18px 20px;display:flex}.room-card__head{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.room-card__title-block{flex:220px;align-items:center;gap:12px;min-width:0;display:flex}.room-card__icon{width:40px;height:40px;color:var(--text-muted);background:#ffffff0f;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.room-card__name{font-size:16px;font-weight:600;line-height:1.3}.room-card__meta{color:var(--text-muted);flex-wrap:wrap;align-items:center;gap:6px;margin-top:4px;font-size:12px;display:flex}.room-card__meta code{color:#d1d5db;background:#00000040;border-radius:6px;padding:2px 6px;font-size:11px}.room-card__badges{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.room-card__status{text-transform:uppercase;letter-spacing:.06em;border-radius:999px;padding:4px 10px;font-size:11px;font-weight:700}.room-card__status.is-open{color:var(--success);background:#10b98126}.room-card__status.is-closed{color:var(--danger);background:#f43f5e1f}.room-card__status.is-warming{color:var(--warning);background:#f59e0b26}.room-card__mode{text-transform:uppercase;letter-spacing:.04em;border-radius:999px;padding:4px 10px;font-size:11px;font-weight:700}.room-card__players{color:var(--text-muted);font-size:12px}.room-card__link-row{border-radius:var(--radius-md);border:1px solid var(--glass-border);background:#0003;flex-wrap:wrap;align-items:center;gap:10px;padding:12px 14px;display:flex}.room-card__link-btn{flex-shrink:0;text-decoration:none}.room-card__link-url{min-width:0;color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;flex:120px;font-size:12px;overflow:hidden}.room-card__icon-btn{padding:10px 12px}.room-card__link-missing{color:var(--text-muted);align-items:flex-start;gap:10px;font-size:13px;line-height:1.45;display:flex}.room-card__link-missing strong{color:var(--text-main);font-weight:600}.room-card__actions{flex-wrap:wrap;align-items:flex-start;gap:16px 24px;display:flex}.room-card__action-group{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.room-card__action-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);min-width:36px;font-size:10px;font-weight:700}.room-card__token-toggle{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;align-self:flex-start;align-items:center;gap:6px;padding:8px 12px;font-family:inherit;font-size:12px;display:inline-flex}.room-card__token-toggle:hover{color:var(--text-main);background:#ffffff0a}.room-card__token-panel{border-radius:var(--radius-md);border:1px dashed var(--glass-border);background:#00000026;flex-wrap:wrap;align-items:center;gap:8px;padding:12px 14px;display:flex}.room-card__token-panel .form-input{flex:200px;min-width:160px}.room-card__token-hint{color:var(--text-muted);flex:100%;margin:0;font-size:12px}.room-card__unmanaged{color:var(--text-muted);margin:0;font-size:13px}@media (width<=640px){.room-card__link-row{flex-direction:column;align-items:stretch}.room-card__link-btn{justify-content:center}.room-card__link-url{white-space:normal;word-break:break-all}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalIn{0%{opacity:0;transform:translateY(30px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}@media (width<=1024px){.sidebar{transition:transform .3s;transform:translate(-100%)}.sidebar.sidebar--open{transform:translate(0)}.main-content{margin-left:0}.topbar-menu-btn{display:block}}@media (width<=640px){.section-header{flex-direction:column;align-items:flex-start}.search-input-wrap{max-width:100%}}
