*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;font-size:15px;line-height:1.6}#app{width:100%;margin:0;padding:0}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#fff3}:root{--sidebar-w:250px;--sidebar-collapsed-w:64px;--color-bg:#0b0e14;--color-surface:#12151e;--color-surface-elevated:#1a1e2e;--color-border:#ffffff0f;--color-border-hover:#ffffff1f;--color-primary:#22c55e;--color-primary-soft:#22c55e1f;--color-primary-hover:#22c55e2e;--color-text:#e2e8f0;--color-text-muted:#64748b;--color-text-bright:#f8fafc;--color-danger:#ef4444;--color-danger-soft:#ef44441f;--color-warning:#f59e0b;--color-warning-soft:#f59e0b1f;--color-info:#3b82f6;--color-info-soft:#3b82f61f;--color-purple:#a855f7;--color-purple-soft:#a855f71f;--font:"Inter", system-ui, -apple-system, sans-serif;--radius:12px;--radius-sm:8px;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 32px #00000080;--transition:.2s cubic-bezier(.4, 0, .2, 1)}body{background:var(--color-bg);color:var(--color-text);font-family:var(--font)}.app-layout{grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh;transition:grid-template-columns var(--transition);display:grid}.app-layout:has(.sidebar.collapsed){grid-template-columns:var(--sidebar-collapsed-w) 1fr}.sidebar{background:var(--color-surface);border-right:1px solid var(--color-border);height:100vh;transition:width var(--transition);z-index:100;flex-direction:column;display:flex;position:sticky;top:0;overflow:hidden}.sidebar-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;min-height:72px;padding:1.25rem 1rem;display:flex}.logo-wrap{align-items:center;gap:.75rem;display:flex;overflow:hidden}.logo-img{flex-shrink:0;width:38px;height:38px;display:block}.sidebar.collapsed .logo-img{cursor:pointer}.sidebar.collapsed .sidebar-header{justify-content:center;padding:1.25rem .5rem}.logo-text{white-space:nowrap;overflow:hidden}.logo-text h1{color:var(--color-text-bright);font-size:.95rem;font-weight:700;line-height:1.2}.logo-tagline{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:.65rem;font-weight:500}.collapse-btn{width:28px;height:28px;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.collapse-btn:hover{background:var(--color-border-hover);color:var(--color-text)}.collapse-btn svg{width:16px;height:16px}.nav-menu{flex:1;padding:.75rem 0;list-style:none;overflow-y:auto}.nav-item{color:var(--color-text-muted);transition:all var(--transition);border-radius:var(--radius-sm);align-items:center;gap:.75rem;margin:.15rem .5rem;padding:.6rem 1rem;font-size:.85rem;font-weight:500;text-decoration:none;display:flex;position:relative}.nav-icon{flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.nav-icon svg{width:100%;height:100%}.nav-item:hover{color:var(--color-text);background:#ffffff0a}.nav-item.active{color:var(--color-primary);background:var(--color-primary-soft)}.nav-item.active .nav-icon{color:var(--color-primary)}.nav-divider{background:var(--color-border);height:1px;margin:.5rem .75rem}.sidebar.collapsed .nav-item{justify-content:center;margin:.15rem .35rem;padding:.7rem}.sidebar.collapsed .collapse-btn{margin:0 auto}.api-status{color:var(--color-text-muted);border-top:1px solid var(--color-border);align-items:center;gap:.5rem;padding:.75rem 1rem;font-size:.7rem;font-weight:500;display:flex}.status-dot{background:var(--color-danger);width:7px;height:7px;box-shadow:0 0 6px var(--color-danger);transition:all var(--transition);border-radius:50%;flex-shrink:0}.api-status.ok .status-dot{background:var(--color-primary);box-shadow:0 0 6px var(--color-primary)}.sidebar.collapsed .api-status{justify-content:center}.main-content{background:var(--color-bg);min-height:100vh;padding:2rem 2.5rem;overflow-y:auto}.page-fade-enter-active,.page-fade-leave-active{transition:opacity .2s,transform .2s}.page-fade-enter-from{opacity:0;transform:translateY(8px)}.page-fade-leave-to{opacity:0;transform:translateY(-4px)}.fade-text-enter-active,.fade-text-leave-active{transition:opacity .15s}.fade-text-enter-from,.fade-text-leave-to{opacity:0}.page-header{margin-bottom:2rem}.page-title{color:var(--color-text-bright);letter-spacing:-.02em;margin-bottom:.35rem;font-size:1.75rem;font-weight:800}.page-subtitle{color:var(--color-text-muted);font-size:.9rem;font-weight:400}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);transition:border-color var(--transition);padding:1.5rem}.card:hover{border-color:var(--color-border-hover)}.card-title{color:var(--color-text-bright);align-items:center;gap:.5rem;margin-bottom:1rem;font-size:.85rem;font-weight:600;display:flex}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem;display:grid}.kpi-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);transition:all var(--transition);padding:1.25rem 1.5rem}.kpi-card:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.kpi-value{color:var(--color-primary);letter-spacing:-.03em;font-size:2rem;font-weight:800;line-height:1.1}.kpi-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;margin-top:.35rem;font-size:.75rem;font-weight:500}.badge{letter-spacing:.02em;border-radius:999px;align-items:center;padding:.2rem .65rem;font-size:.7rem;font-weight:600;display:inline-flex}.badge-green{background:var(--color-primary-soft);color:var(--color-primary)}.badge-red{background:var(--color-danger-soft);color:var(--color-danger)}.badge-yellow{background:var(--color-warning-soft);color:var(--color-warning)}.badge-blue{background:var(--color-info-soft);color:var(--color-info)}.badge-purple{background:var(--color-purple-soft);color:var(--color-purple)}table{border-collapse:collapse;width:100%;font-size:.85rem}th{text-align:left;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);text-transform:uppercase;letter-spacing:.05em;padding:.75rem 1rem;font-size:.75rem;font-weight:600}td{border-bottom:1px solid #ffffff08;padding:.75rem 1rem}tr{transition:background var(--transition)}tr:hover td{background:#ffffff05}.select{background:var(--color-bg);border:1px solid var(--color-border);color:var(--color-text);border-radius:var(--radius-sm);font-size:.85rem;font-family:var(--font);cursor:pointer;transition:all var(--transition);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M2 4l4 4 4-4'/%3E%3C/svg%3E");background-position:right .75rem center;background-repeat:no-repeat;padding:.55rem 2rem .55rem .85rem}.select:hover{border-color:var(--color-border-hover)}.select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-soft);outline:none}.btn{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text);font-size:.85rem;font-weight:500;font-family:var(--font);cursor:pointer;transition:all var(--transition);align-items:center;gap:.5rem;padding:.55rem 1.15rem;display:inline-flex}.btn:hover{background:var(--color-surface-elevated);border-color:var(--color-border-hover)}.btn-primary{background:var(--color-primary);color:#0b0e14;border-color:var(--color-primary);font-weight:600}.btn-primary:hover{background:#16a34a;border-color:#16a34a}.loading-state{color:var(--color-text-muted);flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:4rem 2rem;display:flex}.spinner{border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:32px;height:32px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.error-state{text-align:center;color:var(--color-danger);background:var(--color-danger-soft);border-radius:var(--radius);padding:3rem 2rem;font-size:.9rem}.empty-state{text-align:center;color:var(--color-text-muted);padding:4rem 2rem}.empty-state-icon{opacity:.5;margin-bottom:1rem;font-size:3rem}.empty-state-text{font-size:.9rem}.pill-filters{flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem;display:flex}.pill{border:1px solid var(--color-border);color:var(--color-text-muted);font-size:.8rem;font-weight:500;font-family:var(--font);cursor:pointer;transition:all var(--transition);background:0 0;border-radius:999px;padding:.4rem 1rem}.pill:hover{border-color:var(--color-border-hover);color:var(--color-text)}.pill.active{background:var(--color-primary-soft);border-color:var(--color-primary);color:var(--color-primary)}.grid-2{grid-template-columns:repeat(2,1fr);gap:1.5rem;display:grid}@media (width<=900px){.grid-2{grid-template-columns:1fr}}.mobile-only{display:none!important}@media (width<=768px){.desktop-only{display:none!important}.mobile-only{display:flex!important}.app-layout{grid-template-columns:1fr}.app-layout:has(.sidebar.collapsed){grid-template-columns:1fr}.sidebar{width:var(--sidebar-w);z-index:1000;box-shadow:var(--shadow-lg);position:fixed;top:0;left:0;transform:translate(-100%)}.sidebar.mobile-open{width:var(--sidebar-w)!important;transform:translate(0)!important}.sidebar.collapsed:not(.mobile-open){transform:translate(-100%)}.main-content{padding:1.25rem}.mobile-header{align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.mobile-menu-btn{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);width:36px;height:36px;color:var(--color-text);cursor:pointer;justify-content:center;align-items:center;display:flex}.mobile-title{color:var(--color-text-bright);font-size:.95rem;font-weight:700}.mobile-overlay{z-index:999;background:#00000080;position:fixed;inset:0}.kpi-grid{grid-template-columns:repeat(2,1fr)!important}.page-title{font-size:1.35rem}}@media (width>=769px){.mobile-header,.mobile-overlay,.mobile-menu-btn{display:none!important}}
