*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f0f13;--surface: #18181f;--surface2: #22222c;--border: #2e2e3a;--text: #e4e4f0;--text-muted: #8888a4;--accent: #6366f1;--accent-light: #818cf8;--green: #22c55e;--red: #ef4444;--radius: 10px;--font: "Inter", sans-serif}body{background:var(--bg);color:var(--text);font-family:var(--font);font-size:14px}.layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:200px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:20px 0}.sidebar-brand{font-size:20px;font-weight:700;padding:0 20px 24px;color:var(--accent-light);letter-spacing:1px}.sidebar-nav{display:flex;flex-direction:column;gap:2px;flex:1}.sidebar-nav a{display:block;padding:10px 20px;color:var(--text-muted);text-decoration:none;border-radius:0;transition:background .15s,color .15s}.sidebar-nav a:hover{background:var(--surface2);color:var(--text)}.sidebar-nav a.active{background:var(--surface2);color:var(--accent-light);border-left:3px solid var(--accent)}.sidebar-footer{padding:16px 20px;display:flex;flex-direction:column;gap:12px}.btn-logout{background:transparent;border:1px solid var(--border);color:var(--text-muted);padding:6px 12px;border-radius:6px;cursor:pointer;font-size:13px;transition:color .15s,border-color .15s}.btn-logout:hover{color:var(--text);border-color:var(--text-muted)}.content{flex:1;overflow-y:auto;padding:28px 32px}.db-health{display:flex;gap:6px;flex-wrap:wrap}.db-pill{font-size:11px;padding:3px 8px;border-radius:20px;font-weight:500}.db-pill.ok{background:#16a34a30;color:var(--green)}.db-pill.err{background:#dc262630;color:var(--red)}.db-pill.loading{background:var(--surface2);color:var(--text-muted)}.page-loading{color:var(--text-muted);padding:40px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.page-header h2{font-size:20px;font-weight:600}.period-filter{display:flex;gap:4px}.period-filter button{background:var(--surface2);border:1px solid var(--border);color:var(--text-muted);padding:5px 12px;border-radius:6px;cursor:pointer;font-size:13px;transition:background .15s,color .15s}.period-filter button.active,.period-filter button:hover{background:var(--accent);border-color:var(--accent);color:#fff}.stat-grid{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:28px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 22px;min-width:150px}.stat-value{font-size:26px;font-weight:700;color:var(--accent-light)}.stat-label{font-size:12px;color:var(--text-muted);margin-top:4px}.stat-sub{font-size:11px;color:var(--text-muted);margin-top:2px}.chart-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px;margin-bottom:32px}.chart-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px}.chart-box.full{grid-column:1 / -1}.chart-box h3{font-size:13px;font-weight:600;color:var(--text-muted);margin-bottom:14px;text-transform:uppercase;letter-spacing:.5px}.section-title{font-size:14px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:14px}.categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.category-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px}.category-card h4{font-size:13px;font-weight:600;margin-bottom:12px;color:var(--accent-light)}.category-card ol{padding-left:18px;display:flex;flex-direction:column;gap:6px}.category-card li{display:flex;justify-content:space-between;align-items:center}.nom-name{font-size:13px}.nom-count{font-size:12px;color:var(--text-muted);background:var(--surface2);padding:1px 8px;border-radius:20px}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table th{text-align:left;padding:8px 10px;color:var(--text-muted);border-bottom:1px solid var(--border);font-weight:500}.data-table td{padding:8px 10px;border-bottom:1px solid var(--border)}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--surface2)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}.login-form{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:36px 40px;width:100%;max-width:360px;display:flex;flex-direction:column;gap:16px}.login-form h1{font-size:22px;font-weight:700;color:var(--accent-light)}.login-error{color:var(--red);font-size:13px}.login-form label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--text-muted)}.login-form input{background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:9px 12px;border-radius:7px;font-size:14px;outline:none;transition:border-color .15s}.login-form input:focus{border-color:var(--accent)}.login-form button{background:var(--accent);color:#fff;border:none;padding:10px;border-radius:7px;cursor:pointer;font-size:14px;font-weight:600;transition:opacity .15s;margin-top:4px}.login-form button:disabled{opacity:.6;cursor:not-allowed}
