:root{--bg: #0f1722;--panel: #16212e;--panel-2: #1b2836;--border: #26384a;--text: #e6edf3;--muted: #9fb0c0;--accent: #3b82f6;--accent-soft: #1e3a5f;--good: #34d399;--warn: #fbbf24;--bad: #f87171;--radius: 10px;--shadow: 0 1px 2px rgba(0, 0, 0, .3);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--text);font-size:14px}a{color:inherit;text-decoration:none}button{font-family:inherit}.app{display:flex;min-height:100vh}.sidebar{width:220px;background:var(--panel);border-right:1px solid var(--border);padding:18px 14px;display:flex;flex-direction:column;gap:4px;position:sticky;top:0;height:100vh}.brand{font-weight:700;font-size:16px;letter-spacing:.3px;padding:4px 8px 16px;color:#fff}.brand small{display:block;font-weight:400;font-size:11px;color:var(--muted);letter-spacing:.5px}.nav a{display:flex;align-items:center;gap:8px;padding:9px 12px;border-radius:8px;color:var(--muted);font-weight:500}.nav a:hover{background:var(--panel-2);color:var(--text)}.nav a.active{background:var(--accent-soft);color:#fff}.sidebar .spacer{flex:1}.logout{background:none;border:1px solid var(--border);color:var(--muted);padding:8px;border-radius:8px;cursor:pointer}.logout:hover{color:var(--text);border-color:var(--muted)}.main{flex:1;padding:24px 28px;max-width:1200px}.page-title{font-size:20px;font-weight:700;margin:0 0 4px}.page-sub{color:var(--muted);margin:0 0 20px}.grid{display:grid;gap:14px}.kpis{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}.kpi .label{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.5px}.kpi .value{font-size:24px;font-weight:700;margin-top:6px}.kpi .value small{font-size:13px;color:var(--muted);font-weight:500}.searchbox{position:relative;margin-bottom:22px}.searchbox input{width:100%;padding:12px 14px;font-size:15px;background:var(--panel);border:1px solid var(--border);color:var(--text);border-radius:10px;outline:none}.searchbox input:focus{border-color:var(--accent)}.results{position:absolute;z-index:20;left:0;right:0;margin-top:6px;background:var(--panel-2);border:1px solid var(--border);border-radius:10px;max-height:340px;overflow:auto;box-shadow:0 8px 24px #0006}.results .row{padding:10px 14px;cursor:pointer;display:flex;justify-content:space-between;gap:10px;border-bottom:1px solid var(--border)}.results .row:last-child{border-bottom:none}.results .row:hover,.results .row.sel{background:var(--accent-soft)}.results .code{font-weight:600}.results .meta{color:var(--muted);font-size:12px}table{width:100%;border-collapse:collapse;font-size:13px}th,td{text-align:left;padding:8px 10px;border-bottom:1px solid var(--border)}th{color:var(--muted);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.4px}td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}tr:hover td{background:#ffffff05}.tag{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600;background:var(--accent-soft);color:#cfe1ff}.tag.good{background:#0d3b2e;color:var(--good)}.tag.warn{background:#3a2f08;color:var(--warn)}.tag.bad{background:#3a1212;color:var(--bad)}.row-flex{display:flex;gap:14px;flex-wrap:wrap}.col{display:flex;flex-direction:column;gap:14px}.muted{color:var(--muted)}.section-title{font-size:14px;font-weight:700;margin:0 0 12px}.right{text-align:right}.btn{background:var(--accent);color:#fff;border:none;padding:10px 16px;border-radius:8px;font-weight:600;cursor:pointer}.btn:hover{filter:brightness(1.08)}.btn.secondary{background:var(--panel-2);border:1px solid var(--border);color:var(--text)}.btn:disabled{opacity:.5;cursor:not-allowed}.input,select.input{background:var(--panel-2);border:1px solid var(--border);color:var(--text);padding:8px 10px;border-radius:8px}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:12px;color:var(--muted)}.banner{padding:12px 14px;border-radius:8px;background:#3a2f08;color:var(--warn);border:1px solid #5b4a10;margin-bottom:18px;font-size:13px}.banner.info{background:var(--accent-soft);color:#cfe1ff;border-color:#2b4b73}.dz{border:2px dashed var(--border);border-radius:12px;padding:26px;text-align:center;cursor:pointer;background:var(--panel);transition:border-color .15s}.dz.over{border-color:var(--accent);background:var(--accent-soft)}.dz h4{margin:0 0 6px}.login-wrap{display:flex;align-items:center;justify-content:center;min-height:100vh}.login-card{width:340px}.login-card h1{font-size:18px;margin:0 0 4px}.login-card .field{margin-top:14px}.err{color:var(--bad);font-size:13px;margin-top:10px}.spinner{color:var(--muted);padding:40px;text-align:center}
