*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}body{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#f1f5f9;color:#0f172a}a{color:inherit}.page{min-height:100vh;background:#f1f5f9;color:#0f172a;margin:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.layout{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.sidebar{background:#0b1220;color:#cbd5e1;border-right:1px solid #0f172a;padding:1rem;display:flex;flex-direction:column;gap:1rem}.sidebar-header{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem}.sidebar-header .logo{width:32px;height:32px;border-radius:999px;background:#111827;display:grid;place-items:center;color:#e5e7eb;font-weight:700}.sidebar-header .brand{display:flex;flex-direction:column;line-height:1.1}.sidebar-header .brand span{font-size:12px;color:#9ca3af}.nav{display:flex;flex-direction:column}.nav-item{text-align:left;background:transparent;border:none;color:#cbd5e1;padding:.6rem .75rem;border-radius:.5rem;cursor:pointer}.nav-item:hover{background:#0f172a}.nav-item.active{background:#111827;color:#fff}.main{display:flex;flex-direction:column;min-width:0}.page.centered{display:flex;align-items:center;justify-content:center;padding:4rem 1.5rem}.header{background:#fff;border-bottom:1px solid #e2e8f0;padding:1.5rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:1.5rem}.header h1{margin:0;font-size:1.5rem}.header p{margin:.25rem 0 0;font-size:.9rem;color:#475569}.header button{background:#0f172a;color:#fff;border:none;border-radius:.5rem;padding:.6rem 1.2rem;cursor:pointer;font-weight:500}.content{padding:2rem;display:flex;flex-direction:column;gap:2rem}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.kpi-card{background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;padding:1.25rem;display:flex;flex-direction:column;gap:.5rem}.kpi-card span{color:#64748b;font-size:.8rem;text-transform:uppercase}.kpi-card strong{font-size:1.8rem;font-weight:600}.panel{background:#fff;border:1px solid #e2e8f0;border-radius:1rem;padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.graph-window{background:#fff;border:1px solid #e2e8f0;border-radius:1rem;padding:1rem}.graph-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.graph-canvas{height:260px;background:linear-gradient(to bottom,#fff,#f8fafc);border-radius:.75rem;display:flex;align-items:center;justify-content:center;color:#64748b}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.panel-header h2{margin:0}.panel-header p{margin:.25rem 0 0;color:#64748b;font-size:.85rem}.panel-header input{border:1px solid #cbd5f5;border-radius:.5rem;padding:.5rem .75rem;font-size:.9rem}.table-wrapper{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:.9rem}thead{background:#f8fafc}thead th{text-align:left;font-weight:600;color:#475569;padding:.75rem}tbody td{padding:.75rem;border-top:1px solid #e2e8f0;color:#1e293b}.error-card{background:#fff;border:1px solid #fecdd3;color:#b91c1c;padding:2rem;border-radius:1rem;max-width:420px;text-align:center;display:flex;flex-direction:column;gap:1rem}.error-card h2{margin:0}.error-card button{border:none;padding:.6rem 1.2rem;border-radius:.5rem;background:#0f172a;color:#fff;cursor:pointer}.badge{display:inline-block;padding:.25rem .5rem;font-size:.75rem;border-radius:.375rem;background:#e5e7eb;color:#111827}.badge.green{background:#dcfce7;color:#065f46}.badge.blue{background:#dbeafe;color:#1e40af}.badge.role-admin{background:#fee2e2;color:#7f1d1d}.badge.role-user{background:#f3f4f6;color:#111827}
