:root{--bg:#f8f6f1;--surface:#fff;--primary:#a6812b;--primary-dark:#876619;--accent:#c9a24b;--text:#2a2620;--muted:#8a8276;--border:#ece6da;--good:#2fa37a;--danger:#c0392b;--shadow:0 1px 3px #2a26200f, 0 6px 20px #2a26200f}*{box-sizing:border-box}html,body,#root{height:100%}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}.muted{color:var(--muted)}.pad{padding:14px}.login-wrap{text-align:center;background:radial-gradient(1200px 500px at 50% -10%, #b8902f1a, transparent), var(--bg);justify-content:center;align-items:center;min-height:100%;padding:24px;display:flex}.login-card{width:100%;max-width:380px}.login-title{letter-spacing:-.3px;margin:0;font-size:26px;font-weight:800}.app{flex-direction:column;min-height:100%;display:flex}.topbar{background:var(--primary);color:#fff;z-index:5;justify-content:space-between;align-items:center;padding:14px 22px;display:flex;position:sticky;top:0}.brand{letter-spacing:.2px;font-weight:700}.layout{flex:1;grid-template-columns:340px 1fr;align-items:start;gap:20px;width:100%;margin:0 auto;padding:20px;display:grid}.sidebar{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:16px;flex-direction:column;max-height:calc(100vh - 110px);padding:14px;display:flex;position:sticky;top:84px}.search input{margin-bottom:10px}.lista{margin:0;padding:0;list-style:none;overflow-y:auto}.item{cursor:pointer;border:1px solid #0000;border-radius:12px;justify-content:space-between;align-items:center;gap:10px;padding:11px 12px;transition:background .12s,border-color .12s;display:flex}.item:hover{background:#fbf7ee}.item.activo{border-color:var(--primary);background:#f8f1e2}.item .nom{font-size:14px;font-weight:600}.item .meta{color:var(--muted);margin-top:2px;font-size:12px}.detalle{min-width:0}.placeholder{background:var(--surface);border:1px dashed var(--border);text-align:center;color:var(--muted);border-radius:16px;padding:60px 24px}.det-head{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px;display:flex}.det-nombre{letter-spacing:-.2px;margin:0 0 2px;font-size:22px;font-weight:800}.stats{gap:14px;margin-bottom:18px;display:flex}.stat{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);text-align:center;border-radius:14px;flex:1;padding:14px 16px}.stat.wide{text-align:left}.stat-l{color:var(--muted);margin-bottom:5px;font-size:12px;display:block}.stat-v{font-size:20px;font-weight:800}.card{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:16px;margin-bottom:18px;padding:20px}.card-t{margin:0 0 14px;font-size:15px;font-weight:700}.form-head{justify-content:space-between;align-items:center;display:flex}label{margin:12px 0 6px;font-size:13px;font-weight:600;display:block}input{border:1px solid var(--border);color:#2a2620;background:#fff;border-radius:10px;width:100%;padding:11px 13px;font-family:inherit;font-size:15px}input::placeholder{color:#b3ac9f}input:focus{outline:2px solid var(--primary);outline-offset:-1px}.grid4{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.btn{cursor:pointer;border:none;border-radius:10px;padding:12px 20px;font-family:inherit;font-size:15px;font-weight:700}.btn.primary{background:var(--primary);color:#fff;margin-top:18px}.btn.primary:hover{background:var(--primary-dark)}.btn.primary:disabled{opacity:.6;cursor:default}.btn.block{width:100%}.btn.ghost-light{color:#fff;background:#ffffff26;padding:8px 16px}.btn.ghost-light:hover{background:#ffffff47}.link{color:var(--primary);cursor:pointer;background:0 0;border:none;padding:4px 6px;font-family:inherit;font-size:13px;font-weight:600}.link:hover{text-decoration:underline}.link.danger{color:var(--danger)}.badge{white-space:nowrap;border-radius:99px;padding:3px 10px;font-size:11px;font-weight:700}.badge.on{color:var(--good);background:#e7f6ef}.badge.off{color:var(--danger);background:#fdeceb}table{border-collapse:collapse;width:100%}th,td{text-align:left;border-bottom:1px solid var(--border);padding:10px 8px;font-size:14px}th{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}tr:last-child td{border-bottom:none}.acciones{white-space:nowrap;text-align:right}.msg{border-radius:10px;margin-bottom:14px;padding:11px 14px;font-size:14px}.msg.error{color:var(--danger);background:#fdeceb}.msg.ok{color:var(--good);background:#e7f6ef}.grafica{width:100%}.svg{width:100%;height:auto;display:block}.eje{stroke:var(--border)}.linea{stroke:var(--primary);stroke-width:2.5px}.punto{fill:var(--accent);transition:r .1s}.guia{stroke:var(--accent);stroke-dasharray:4 4;opacity:.7}.axis{fill:var(--muted);font-size:11px}.tip-box{fill:var(--text);opacity:.94}.tip-1{fill:#fff;font-size:13px;font-weight:700}.tip-2{fill:#ffffffbf;font-size:11px}@media (width<=820px){.layout{grid-template-columns:1fr}.sidebar{max-height:320px;position:static}.grid4{grid-template-columns:1fr 1fr}.stats{flex-wrap:wrap}.stat{min-width:100px}}.modal-overlay{z-index:50;background:#2a262080;justify-content:center;align-items:center;padding:24px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal-card{background:var(--surface);text-align:center;border-radius:20px;width:100%;max-width:360px;padding:30px 26px 24px;animation:.16s pop;box-shadow:0 18px 50px #2a262040}.modal-titulo{margin:14px 0 0;font-size:21px;font-weight:800}.modal-texto{color:var(--muted);margin:8px 0 0;font-size:15px;line-height:1.45}.modal-acciones{justify-content:center;gap:10px;margin-top:24px;display:flex}.btn.primary-sm{background:var(--primary);color:#fff;padding:11px 26px}.btn.primary-sm:hover{background:var(--primary-dark)}.btn.neutro{color:var(--text);border:1px solid var(--border);background:#fff;padding:11px 22px}.btn.neutro:hover{background:#faf7f0}.btn.peligro{background:var(--danger);color:#fff;padding:11px 26px}.btn.peligro:hover{filter:brightness(.93)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes pop{0%{opacity:0;transform:translateY(8px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.cargando-btn{justify-content:center;align-items:center;gap:9px;display:inline-flex}.spinner{border:2px solid #fff6;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.6s linear infinite girar}@keyframes girar{to{transform:rotate(360deg)}}.total-box{background:#f8f1e2;border-radius:12px;justify-content:space-between;align-items:center;margin-top:14px;padding:12px 16px;display:flex}.total-box .l{color:var(--primary-dark);font-weight:600}.total-box .v{color:var(--primary-dark);font-size:20px;font-weight:800}.dia-bloque{border-top:1px solid var(--border);margin-top:8px;padding-top:12px}.dia-bloque:first-of-type{border-top:none;margin-top:0;padding-top:0}.dia-fecha{color:var(--muted);margin-bottom:6px;font-size:13px;font-weight:700}.ej-nombre{color:var(--text);margin-top:8px;font-size:14px;font-weight:700}.serie-fila{align-items:center;gap:12px;padding:6px 0;display:flex}.serie-fila .txt{flex:1;font-size:14px}.serie-fila .fuerte{font-weight:800}input:disabled{color:var(--muted);background:#f3efe7}.login-logo{object-fit:contain;border-radius:16px;width:200px;height:200px;margin:0 auto 14px;display:block}.panel_detail{object-fit:contain;border-radius:10px;width:50px;height:50px;display:block}
