:root{
  --bg:#0B0B0E;
  --panel:#111116;
  --panel2:#15151C;
  --text:#FFFFFF;
  --muted:#A6A6B3;
  --line:#232331;
  --accent:#FE4B4E;
  --accent2:#ff7b7d;
  --good:#22c55e;
  --warn:#f59e0b;
  --bad:#ef4444;
  --shadow: 0 16px 40px rgba(0,0,0,.35);
  --radius: 18px;
  --radius2: 12px;
  --mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  --sans: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--text);
  background:
    radial-gradient(1200px 600px at 10% -10%, rgba(254,75,78,.18), transparent 60%),
    radial-gradient(900px 500px at 85% 0%, rgba(254,75,78,.10), transparent 55%),
    linear-gradient(180deg, #060607 0%, var(--bg) 40%, #07070A 100%);
}
a{color:inherit}
.container{max-width:1320px;margin:0 auto;padding:22px;}
.header{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:16px 18px;
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.08);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  backdrop-filter: blur(10px);
}
.brand{display:flex;align-items:center;gap:14px;}
.brand img{height:36px;width:auto;display:block;}
.brand .title{display:flex;flex-direction:column;line-height:1.1;}
.brand .title .h1{font-size:16px;font-weight:800;letter-spacing:.06em;}
.brand .title .sub{font-size:12px;color:var(--muted);margin-top:2px;}
.header .right{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end;}
.pill{
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  padding:8px 10px;border-radius:999px;color:var(--muted);font-size:12px;
}
.btn{
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: var(--text);
  padding:10px 12px;border-radius:12px;cursor:pointer;
  font-weight:700;font-size:13px;display:inline-flex;align-items:center;gap:8px;
  transition:.15s ease;
}
.btn:hover{transform:translateY(-1px);border-color:rgba(254,75,78,.45)}
.btn.primary{border-color:rgba(254,75,78,.55);background:rgba(254,75,78,.12);}
.btn.primary:hover{background:rgba(254,75,78,.18)}
.layout{display:grid;grid-template-columns:340px 1fr;gap:18px;margin-top:18px;}
.card{
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow:hidden;
}
.card .card-h{
  padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.06);
  display:flex;align-items:center;justify-content:space-between;gap:10px;
}
.card .card-h h2{margin:0;font-size:13px;letter-spacing:.03em;color:var(--muted);text-transform:uppercase;}
.card .card-b{padding:14px 16px 16px 16px;}
.filters{display:flex;flex-direction:column;gap:12px;}
.field label{display:block;font-size:12px;color:var(--muted);margin-bottom:6px;}
.select,.input{
  width:100%;padding:11px 12px;border-radius:12px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.25);color:var(--text);outline:none;
}
.select:focus,.input:focus{border-color:rgba(254,75,78,.6)}
.small{font-size:12px;color:var(--muted);}
.row{display:flex;gap:10px;}
.row>*{flex:1}
.kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;}
.kpi{
  border:1px solid rgba(255,255,255,.08);
  background: rgba(0,0,0,.22);
  border-radius: var(--radius2);
  padding: 12px 12px;
}
.kpi .k{font-size:12px;color:var(--muted)}
.kpi .v{margin-top:6px;font-size:18px;font-weight:900;letter-spacing:.01em;}
.kpi .s{margin-top:4px;font-size:12px;color:var(--muted);font-family:var(--mono);}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.chart-wrap{
  background: rgba(0,0,0,.20);
  border:1px solid rgba(255,255,255,.08);
  border-radius: var(--radius2);
  padding: 10px 10px 6px 10px;
}
.chart-wrap .t{
  font-size:12px;color:var(--muted);
  margin:6px 6px 10px 6px;
  display:flex;justify-content:space-between;gap:10px;
}
.chart-wrap{
  position: relative;
  height: 360px;      /* fija la altura del bloque */
  overflow: hidden;   /* por si algo se dispara */
}

.chart-wrap canvas{
  display: block;
  height: 300px !important;
  max-height: 300px !important;
  width: 100% !important;
}.table-tools{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px;}
.table-tools .input{max-width:320px}
.table{width:100%;border-collapse:collapse;}
.table th,.table td{border-bottom:1px solid rgba(255,255,255,.06);padding:10px 8px;font-size:12px;vertical-align:top;}
.table th{
  text-align:left;color:var(--muted);font-weight:800;
  position: sticky;top: 0;
  background: rgba(13,13,18,.92);
  backdrop-filter: blur(10px);
}
.badge{
  display:inline-flex;align-items:center;gap:6px;border-radius:999px;
  padding:4px 8px;font-size:11px;font-weight:800;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
}
.badge.accent{border-color:rgba(254,75,78,.45);background:rgba(254,75,78,.12)}
.badge.muted{color:var(--muted)}
.footer-note{margin-top:10px;font-size:12px;color:var(--muted);}
hr.sep{border:0;height:1px;background:rgba(255,255,255,.08);margin:12px 0;}
@media (max-width: 1100px){
  .layout{grid-template-columns:1fr}
  .kpis{grid-template-columns:repeat(2,1fr)}
  .grid2{grid-template-columns:1fr}
  .header{flex-direction:column;align-items:flex-start}
  .header .right{width:100%;justify-content:flex-start}
}
