/* =========================
   BASE
========================= */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: Arial, Helvetica, sans-serif;
  background: url('/img/bg.png') no-repeat center center fixed;
  background-size: cover;        /* que ocupe toda la pantalla */
  color:#111;
}
a{color:#0b57d0;text-decoration:none}
a:hover{text-decoration:underline}

/* =========================
   TITULOS
========================= */
.title-container{display:flex;justify-content:center;margin:18px 0}
.title-container h1{
  margin:0;
  background:#fff;
  padding:10px 18px;
  border-radius:10px;
  border:1px solid #e6e6e6;
  color:#e1007a;
  box-shadow:0 3px 10px rgba(0,0,0,.06);
}

/* =========================
   LAYOUT CONTENIDO
========================= */
.main-content{padding:18px}
.page-wrap{max-width:1100px;margin:0 auto}
.page-wrap.wide{max-width:1600px;margin:0 auto}
.center-wrap{max-width:1100px;margin:0 auto}

/* cuando sidebar está abierto empuja contenido */
.main-with-sidebar{margin-left:0;transition:.25s}
.sidebar.open ~ .main-with-sidebar{margin-left:260px}

/* =========================
   CARDS / BOTONES
========================= */
.card{
  background:#fff;
  border:1px solid #e6e6e6;
  border-radius:12px;
  box-shadow:0 3px 14px rgba(0,0,0,.06);
  padding:16px;
}
.card + .card{margin-top:14px}

.btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  border-radius:8px;
  border:1px solid #d0d0d0;
  padding:8px 12px;
  background:#fff;
  color:#111;
  font-weight:800;
  cursor:pointer;
  text-decoration:none !important;
}
.btn:hover{filter:brightness(.98)}
.btn-primary{background:#e1007a;border-color:#e1007a;color:#fff}
.btn-primary:hover{filter:brightness(.96)}
.btn-secondary{background:#fff}
.btn-danger{background:#e11d48;border-color:#e11d48;color:#fff}
.btn-sm{padding:7px 10px;border-radius:8px;font-weight:900}

/* =========================
   FORMULARIOS
========================= */
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px 14px}
@media(max-width:980px){.form-grid{grid-template-columns:1fr}}

.field label{display:block;font-weight:900;margin-bottom:6px}
.field input,.field select,.field textarea{
  width:100%;
  padding:10px 12px;
  border:1px solid #d4d4d4;
  border-radius:9px;
  outline:none;
  background:#fff;
}
.field textarea{min-height:90px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{
  border-color:#e1007a;
  box-shadow:0 0 0 3px rgba(225,0,122,.12);
}
.help{font-size:12px;color:#666;font-weight:800;margin-top:6px}

.form-actions{
  display:flex;
  justify-content:flex-end;
  gap:10px;
  margin-top:12px;
  flex-wrap:wrap;
}

/* RANGOS (ini - fin) */
.range{
  display:grid;
  grid-template-columns:1fr auto 1fr;
  gap:8px;
  align-items:center;
}
.range .sep{font-weight:900;color:#666;text-align:center}
@media(max-width:980px){
  .range{grid-template-columns:1fr}
  .range .sep{display:none}
}

/* =========================
   FILTROS HISTORIAL (evita desbordes)
========================= */
.filters-grid{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:10px 12px;
  align-items:end;
}
.filters-grid .span-2{grid-column:span 2}
.filters-grid .span-3{grid-column:span 3}
.filters-grid .span-5{grid-column:1 / -1}

@media(max-width:1200px){
  .filters-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .filters-grid .span-2,.filters-grid .span-3{grid-column:1 / -1}
}
@media(max-width:720px){
  .filters-grid{grid-template-columns:1fr}
}

/* =========================
   TABLAS (más compactas)
========================= */
.table-wrap{
  overflow:auto;
  background:#fff;
  border:1px solid #e6e6e6;
  border-radius:12px;
  box-shadow:0 3px 14px rgba(0,0,0,.06);
}
table.table{
  width:100%;
  border-collapse:collapse;
  table-layout:auto;
}
.table th,.table td{
  border-bottom:1px solid #eee;
  padding:8px 10px;
  font-size:12px;
  white-space:nowrap;
  vertical-align:top;
}
.table th{
  background:#fafafa;
  text-align:left;
  border-bottom:1px solid #e7e7e7;
}
.table tr:hover td{background:#fcfcfc}

/* =========================
   PAGINACION (centrada, pequeña)
========================= */
.pagination-wrap{
  display:flex;
  justify-content:center;
  padding:12px 0 4px;
}
.pagination{
  display:flex;
  gap:6px;
  align-items:center;
}
.page-btn{
  min-width:34px;
  height:34px;
  display:flex;
  align-items:center;
  justify-content:center;
  border:1px solid #d6d6d6;
  border-radius:10px;
  font-weight:900;
  background:#fff;
  color:#111;
  text-decoration:none !important;
}
.page-btn:hover{filter:brightness(.97)}
.page-btn.active{
  background:#e1007a;
  border-color:#e1007a;
  color:#fff;
}

/* =========================
   FLASH
========================= */
.flash-ok{background:#ecfdf5;border:1px solid #34d399;color:#065f46;padding:10px;border-radius:10px;margin-bottom:10px;font-weight:800}
.flash-err{background:#fef2f2;border:1px solid #f87171;color:#7f1d1d;padding:10px;border-radius:10px;margin-bottom:10px;font-weight:800}

/* =========================
   KPI / DASHBOARD
========================= */
.kpi{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px}
@media(max-width:1200px){.kpi{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(max-width:720px){.kpi{grid-template-columns:repeat(2,minmax(0,1fr))}}
.kpi .k{
  background:#fff;
  border:1px solid #e6e6e6;
  border-radius:12px;
  padding:12px;
  box-shadow:0 3px 10px rgba(0,0,0,.06)
}
.kpi .k h4{margin:0 0 8px 0;color:#555;font-weight:900;font-size:13px}
.kpi .k h2{margin:0;font-size:24px}

/* charts (contenedor con altura fija para que NO sea gigante) */
.chart-fixed{height:260px}
.chart-fixed.sm{height:220px}
.chart-fixed canvas{width:100% !important;height:100% !important}

/* =========================
   SIDEBAR
========================= */
.sidebar-toggle{
  position:fixed;left:10px;top:10px;z-index:1000;
  background:#e1007a;color:#fff;border:0;border-radius:12px;
  width:44px;height:44px;font-size:20px;cursor:pointer;font-weight:900;
}
.sidebar{
  position:fixed;left:0;top:0;bottom:0;width:260px;
  background:#7f9cc9;
  padding-top:54px;
  transform:translateX(-100%);
  transition:.25s;
  z-index:999;
}
.sidebar.open{transform:none}
.sidebar-content{padding:10px;color:#fff;position:relative;height:100%}
.sidebar .menu-group{
  margin:10px 8px 14px;
  padding:10px;
  border-radius:12px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.15)
}
.sidebar .menu-title{
  font-weight:900;
  color:#222;
  margin:2px 2px 10px 2px;
  display:flex;
  gap:6px;
  padding:7px 10px;
  border-radius:10px;
  background:pink;
}
.sidebar a{
  display:block;
  padding:8px 10px;
  color:#fff;
  border-radius:10px;
  font-weight:900;
}
.sidebar a:hover{background:rgba(255,255,255,.12);text-decoration:none}

.sidebar-footer{
  position:absolute;left:0;right:0;bottom:12px;
  padding:0 12px;
}
.btn-logout{
  width:100%;
  text-align:center;
  background:#e1007a;
  color:#fff !important;
  padding:10px 12px;
  border-radius:12px;
  font-weight:900;
  display:block;
}
.btn-logout:hover{filter:brightness(.96);text-decoration:none}

/* =========================
   DASHBOARD ONLY (NO afecta otras vistas)
========================= */
.dash-page .page-wrap.wide{
  max-width: 1240px; /* baja el ancho del dashboard */
}

/* KPI: 4 columnas (4 + 4 simétrico) */
.dash-page .kpi{
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:12px;
}
@media(max-width:1100px){
  .dash-page .kpi{grid-template-columns:repeat(2, minmax(0,1fr));}
}
@media(max-width:720px){
  .dash-page .kpi{grid-template-columns:1fr;}
}

/* Bloque barra */
.dash-page .dash-block{
  margin-top:14px;
}
.dash-page .dash-bar-h{
  height:220px; /* barra más compacta (fila sola) */
}
.dash-page .dash-bar-h canvas{
  width:100% !important;
  height:100% !important;
}

/* 3 pies en una sola fila, mismo tamaño */
.dash-page .dash-pies-row{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:14px;
  margin-top:14px;
}
.dash-page .dash-pie-h{
  height:200px; /* igual para los 3 */
}
.dash-page .dash-pie-h canvas{
  width:100% !important;
  height:100% !important;
}

/* Responsive pies */
@media(max-width:1100px){
  .dash-page .dash-pies-row{grid-template-columns:repeat(2, minmax(0,1fr));}
}
@media(max-width:720px){
  .dash-page .dash-pies-row{grid-template-columns:1fr;}
}

