:root{--bg-primary: #0f0f1a;--bg-secondary: #1a1a2e;--bg-tertiary: #252540;--text-primary: #ffffff;--text-secondary: #a0a0b0;--accent-primary: #6366f1;--accent-secondary: #8b5cf6;--success: #22c55e;--warning: #f59e0b;--danger: #ef4444;--border-color: #333355;--sidebar-width: 240px;--sidebar-collapsed-width: 60px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6}.material-symbols-outlined{font-family:Material Symbols Outlined;font-weight:400;font-style:normal;font-size:24px;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;word-wrap:normal;direction:ltr;-webkit-font-feature-settings:"liga";-webkit-font-smoothing:antialiased}.app-container{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;transition:width .3s ease;position:fixed;height:100vh;z-index:100}.sidebar.collapsed{width:var(--sidebar-collapsed-width)}.sidebar-header{padding:1.5rem 1rem;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border-color)}.logo{display:flex;align-items:center;gap:.5rem;font-size:1.25rem;font-weight:700;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;white-space:nowrap}.logo-icon,.logo-icon-only{font-size:1.75rem;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.toggle-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;border-radius:4px;transition:all .2s}.toggle-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.sidebar-nav{flex:1;padding:1rem 0;overflow-y:auto}.nav-item{display:flex;align-items:center;padding:.75rem 1rem;color:var(--text-secondary);text-decoration:none;transition:all .2s;border-left:3px solid transparent;position:relative}.nav-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-item.router-link-active{background:#6366f11a;color:var(--accent-primary);border-left-color:var(--accent-primary)}.nav-icon{font-size:1.5rem;min-width:2rem;text-align:center;display:flex;align-items:center;justify-content:center}.nav-label{margin-left:.75rem;font-weight:500;flex:1}.nav-badge{background:var(--accent-primary);color:#fff;font-size:.75rem;font-weight:600;padding:.125rem .5rem;border-radius:9999px;margin-left:auto;min-width:1.5rem;text-align:center;animation:pulse-badge 2s infinite}@keyframes pulse-badge{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}.sidebar-footer{padding:1rem;border-top:1px solid var(--border-color)}.version{font-size:.75rem;color:var(--text-secondary);text-align:center}.main-content{flex:1;margin-left:var(--sidebar-width);padding:2rem;transition:margin-left .3s ease;min-height:100vh;overflow-x:hidden;max-width:calc(100vw - var(--sidebar-width))}.sidebar.collapsed+.main-content,.sidebar.collapsed~.main-content{margin-left:var(--sidebar-collapsed-width);max-width:calc(100vw - var(--sidebar-collapsed-width))}.card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.card-title{font-size:1.125rem;font-weight:600}.btn{padding:.5rem 1rem;border-radius:8px;border:none;cursor:pointer;font-weight:500;transition:all .2s;display:inline-flex;align-items:center;gap:.5rem}.btn-primary{background:var(--accent-primary);color:#fff}.btn-primary:hover{background:var(--accent-secondary)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary)}.btn-secondary:hover{background:var(--border-color)}.badge{padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600}.badge-success{background:#22c55e33;color:var(--success)}.badge-warning{background:#f59e0b33;color:var(--warning)}.badge-danger{background:#ef444433;color:var(--danger)}.badge-info{background:#6366f133;color:var(--accent-primary)}.grid{display:grid;gap:1.5rem}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}@media(max-width:1200px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}.sidebar{width:var(--sidebar-collapsed-width)}.main-content{margin-left:var(--sidebar-collapsed-width)}}.loading{display:flex;align-items:center;justify-content:center;padding:2rem;color:var(--text-secondary)}.spinner{width:2rem;height:2rem;border:3px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error{background:#ef44441a;border:1px solid var(--danger);color:var(--danger);padding:1rem;border-radius:8px}.table-container{overflow-x:auto}table{width:100%;border-collapse:collapse}th,td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border-color)}th{font-weight:600;color:var(--text-secondary);font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}tr:hover{background:var(--bg-tertiary)}.stars{display:flex;gap:.25rem}.star{cursor:pointer;font-size:1.5rem;transition:transform .1s}.star:hover{transform:scale(1.2)}.star.filled{color:#fbbf24}.star.empty{color:var(--text-secondary)}
