/* ============================================
   LA LLORONA - COMPONENTS CSS
   Cards, botones, forms, badges, KPIs, etc.
   Light Theme Enterprise
   ============================================ */

/* ── BADGES & CHIPS ── */
.bx {
  display: inline-flex; align-items: center;
  padding: 3px 10px; border-radius: 20px;
  font-size: 10px; font-weight: 700; border: 1px solid;
}
.by { background: var(--gdl); color: var(--gd); border-color: rgba(27, 107, 58, .25); }
.bg { background: var(--grl); color: var(--gr); border-color: rgba(21, 128, 61, .15); }
.br { background: var(--rel); color: var(--re); border-color: rgba(192, 57, 43, .15); }
.bb { background: var(--bll); color: var(--bl); border-color: rgba(30, 58, 95, .15); }
.ba { background: var(--aml); color: var(--am); border-color: rgba(180, 83, 9, .15); }
.bfl { background: var(--fll); color: var(--fl); border-color: rgba(192, 57, 43, .15); }

.ch {
  display: inline-flex; padding: 2px 8px; border-radius: 5px;
  font-size: 11px; font-weight: 700; border: 1px solid;
}
.cg { background: var(--grl); color: var(--gr); border-color: rgba(21, 128, 61, .12); }
.cr { background: var(--rel); color: var(--re); border-color: rgba(192, 57, 43, .12); }
.cy { background: var(--gdl); color: var(--gd); border-color: rgba(27, 107, 58, .1); }
.cb { background: var(--bll); color: var(--bl); border-color: rgba(30, 58, 95, .12); }
.ca { background: var(--aml); color: var(--am); border-color: rgba(180, 83, 9, .12); }
.cfl { background: var(--fll); color: var(--fl); border-color: rgba(248, 113, 113, .25); }
.ctg {
  background: rgba(109, 40, 217, .06); color: #6D28D9;
  border: 1px solid rgba(109, 40, 217, .12);
  padding: 2px 7px; border-radius: 5px; font-size: 10px; font-weight: 700;
}

/* ── KPI CARDS ── */
.kg {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(155px, 1fr));
  gap: 12px; margin-bottom: 18px;
}
.kp {
  background: var(--s); border: 1px solid var(--bd); border-radius: 12px;
  padding: 14px 16px; position: relative; overflow: hidden;
  box-shadow: var(--card-shadow);
}
.kp::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
}
.kp.ky::before { background: #1B6B3A; }
.kp.kg::before { background: #15803D; }
.kp.kr::before { background: #C0392B; }
.kp.kb::before { background: #1E3A5F; }
.kp.ka::before { background: #B45309; }
.kp.kfl { border-color: rgba(192, 57, 43, .2); background: rgba(192, 57, 43, .04); }
.kp.kfl::before { background: #C0392B; }
.kl {
  font-size: 9px; letter-spacing: 2px; text-transform: uppercase;
  color: var(--t3); margin-bottom: 5px; font-weight: 700;
}
.kv { font-size: 21px; font-weight: 800; color: var(--t1); line-height: 1; }
.ks { font-size: 11px; color: var(--t3); margin-top: 4px; }
.kd { font-size: 11px; font-weight: 700; margin-top: 3px; }
.kd.up { color: var(--gr); }
.kd.dn { color: var(--re); }
.kd.fl { color: var(--fl); }

/* ── CARDS ── */
.card {
  background: var(--s); border: 1px solid var(--bd); border-radius: 12px;
  padding: 16px 18px; margin-bottom: 14px; box-shadow: var(--card-shadow);
}
.ct {
  font-size: 9px; letter-spacing: 2px; text-transform: uppercase;
  color: var(--t3); margin-bottom: 12px;
  display: flex; align-items: center; gap: 8px; font-weight: 700;
}
.ct span { flex: 1; }

/* ── LAYOUTS ── */
.g2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 14px; }
.g3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; margin-bottom: 14px; }

/* ── TABS ── */
.tabs {
  display: flex; border-bottom: 1px solid var(--bd);
  margin-bottom: 14px; gap: 2px;
}
.tab {
  padding: 8px 16px; font-size: 12px; font-weight: 600;
  color: var(--t3); cursor: pointer;
  border-bottom: 2px solid transparent; margin-bottom: -1px;
  transition: all .12s; border-radius: 6px 6px 0 0;
}
.tab:hover { color: var(--t2); background: var(--s2); }
.tab.on { color: #1B6B3A; border-bottom-color: #1B6B3A; font-weight: 700; }

/* ── FORMS ── */
.fld { display: flex; flex-direction: column; gap: 5px; margin-bottom: 14px; }
.fld label {
  font-size: 9px; letter-spacing: 2px; text-transform: uppercase;
  color: var(--t3); font-weight: 700;
}
.fld input, .fld select, .fld textarea {
  padding: 9px 12px; border: 1.5px solid var(--bd); border-radius: 8px;
  font-size: 13px; background: var(--s2); color: var(--t1);
  transition: border-color .12s, box-shadow .12s;
}
.fld input:focus, .fld select:focus {
  outline: none; border-color: #1B6B3A;
  box-shadow: 0 0 0 3px rgba(27, 107, 58, .1);
}
.f2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.f3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 10px; }

/* ── BUTTONS ── */
.btn {
  padding: 8px 18px; border-radius: 8px; font-size: 13px; font-weight: 700;
  cursor: pointer; transition: all .15s; border: 1.5px solid transparent;
  display: inline-flex; align-items: center; gap: 6px;
}
.bsm { padding: 6px 14px; font-size: 12px; }
.blg { padding: 11px 26px; font-size: 14px; }
.btn.by2 {
  background: #1B6B3A; color: #FFFFFF; border-color: #1B6B3A; box-shadow: none;
}
.btn.by2:hover { background: #155D30; box-shadow: none; }
.btn.bg2 { background: #15803D; color: #FFFFFF; border-color: #15803D; }
.btn.bg2:hover { filter: brightness(1.15); }
.btn.br2 { background: transparent; color: #C0392B; border-color: #C0392B; }
.btn.br2:hover { filter: brightness(1.15); }
.btn.bb2 { background: #1E3A5F; color: #FFFFFF; border-color: #1E3A5F; }
.btn.bo {
  background: transparent; color: #4A4A4A; border-color: #D0D0C8;
}
.btn.bo:hover { background: #F5F5F1; border-color: #D0D0C8; }

/* ── NOTIFICATIONS ── */
.nt {
  display: flex; gap: 8px; align-items: flex-start;
  padding: 10px 13px; border-radius: 9px;
  margin-bottom: 12px; font-size: 12px; line-height: 1.5;
}
.nt span:first-child { flex-shrink: 0; font-size: 14px; }
.nb { background: var(--bll); border: 1px solid rgba(30, 58, 95, .12); color: var(--bl); }
.ng { background: var(--grl); border: 1px solid rgba(21, 128, 61, .12); color: var(--gr); }
.ny { background: var(--gdl); border: 1px solid rgba(27, 107, 58, .1); color: var(--gd); }
.nfl { background: var(--rel); border: 1px solid rgba(192, 57, 43, .12); color: var(--re); }

/* ── MODALS ── */
#modals {
  position: fixed; inset: 0; background: rgba(0, 0, 0, .7);
  display: none; align-items: center; justify-content: center;
  z-index: 9999; backdrop-filter: blur(4px);
}
.modal {
  background: #FFFFFF; border: 1px solid #E0E0DA; border-radius: 16px;
  width: 560px; max-width: 94vw; max-height: 90vh; overflow-y: auto;
  box-shadow: 0 12px 40px rgba(0, 0, 0, .15);
}
.mbg {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
}
.mh {
  padding: 20px 24px 16px; border-bottom: 1px solid var(--bd);
  display: flex; align-items: center; justify-content: space-between;
}
.mh h3 { font-size: 16px; font-weight: 800; color: var(--t1); }
.mclose {
  background: var(--s2); border: 1px solid var(--bd); border-radius: 8px;
  width: 30px; height: 30px; cursor: pointer; color: var(--t3); font-size: 16px;
  display: flex; align-items: center; justify-content: center;
}
.mclose:hover { background: var(--s3); color: var(--t1); }
.mb { padding: 18px 24px; }
.mf {
  padding: 14px 24px; border-top: 1px solid var(--bd);
  display: flex; justify-content: flex-end; gap: 8px;
}

/* ── PROGRESS BARS ── */
.pb { height: 5px; background: var(--s3); border-radius: 3px; overflow: hidden; margin-top: 6px; }
.pf { height: 100%; border-radius: 3px; }

/* ── ACTION CARDS ── */
.ac {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 16px; border-radius: 11px;
  cursor: pointer; transition: all .15s; border: 1.5px solid; margin-bottom: 10px;
}
.ac-icon {
  width: 36px; height: 36px; border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; flex-shrink: 0;
}
.ac-body { flex: 1; }
.ac-title { font-size: 14px; font-weight: 700; color: var(--t1); }
.ac-sub { font-size: 11px; color: var(--t3); margin-top: 2px; }
.ac-arrow { font-size: 18px; color: var(--t4); }
.acy { background: var(--gdl); border-color: rgba(27, 107, 58, .15); }
.acy:hover { background: rgba(27, 107, 58, .08); border-color: rgba(27, 107, 58, .2); }
.ac-out { background: var(--s); border-color: var(--bd); }
.ac-out:hover { background: var(--s2); }
.acb { border-color: rgba(30, 58, 95, .15); background: var(--bll); }
.acg { border-color: rgba(21, 128, 61, .15); background: var(--grl); }
.acr { border-color: rgba(192, 57, 43, .15); background: var(--rel); }

/* ── FILE DROP ── */
.file-drop {
  border: 2px dashed var(--bd2); border-radius: 10px; padding: 24px;
  text-align: center; cursor: pointer; transition: all .15s; color: var(--t3);
}
.file-drop:hover { border-color: #1B6B3A; background: rgba(27, 107, 58, .04); }

/* ── CANVAS (chart) ── */
.cb { position: relative; }

/* ── SECTION HEADER ── */
.sh {
  display: flex; align-items: flex-start; justify-content: space-between;
  margin-bottom: 18px;
}
.sh h2 { font-size: 20px; font-weight: 800; color: #1A1A1A; }
.sh .sub { font-size: 11px; color: var(--t3); margin-top: 3px; }

/* ── CHART CONTAINERS (altura fluida; reemplazan height inline) ── */
/* Base = altura desktop (paridad pixel). Chart.js escala dentro (responsive). */
.chart-h       { position: relative; height: 260px; }
.chart-h-daily { position: relative; height: 280px; }
.chart-h-sm    { position: relative; height: 175px; }
.chart-h-lg    { position: relative; height: 340px; }

/* ============================================================
   RESPONSIVE ADITIVO — solo aplica bajo el breakpoint.
   Arriba de 768px el render queda idéntico al desktop actual.
   ============================================================ */
@media (max-width: 768px) {
  /* Grids fijos del design system colapsan a 1 columna */
  .g2, .g3 { grid-template-columns: 1fr; }
  .f2, .f3 { grid-template-columns: 1fr; }

  /* KPIs: el .kg ya es auto-fit; afinamos el minimo para 2 col en 360px */
  .kg { grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); }

  /* Alturas de chart mas compactas en movil */
  .chart-h, .chart-h-daily { height: 220px; }
  .chart-h-sm { height: 150px; }
  .chart-h-lg { height: 240px; }
}

/* ── TABLA REAPILABLE (.rt) — en movil cada fila se vuelve bloque ──
   Uso: <table class="rt"> + cada <td data-label="Concepto">. Cero ramas JS.
   En desktop es una tabla nativa normal. */
@media (max-width: 768px) {
  table.rt thead { display: none; }
  table.rt, table.rt tbody, table.rt tr, table.rt td { display: block; width: 100%; }
  table.rt tr {
    border: 1px solid var(--bd); border-radius: 10px;
    margin-bottom: 10px; padding: 6px 12px; background: var(--s);
  }
  table.rt td {
    display: flex; justify-content: space-between; align-items: baseline;
    gap: 12px; padding: 5px 0; text-align: right; border: 0;
  }
  table.rt td::before {
    content: attr(data-label); flex-shrink: 0; text-align: left;
    font-weight: 700; color: var(--t3);
    text-transform: uppercase; font-size: 9px; letter-spacing: 1px;
  }
  table.rt td:empty { display: none; }
}

/* ── Retrofit responsive de módulos ── */
/* .gm1: colapsa a 1 columna en móvil un grid con plantilla NO estándar
   (pesos 1.4fr.., anchos fijos px, repeat(N,1fr) auto). El template inline se
   conserva para desktop; .gm1 solo fuerza 1 col bajo el breakpoint. Único uso
   legítimo de !important: pisar el grid-template-columns inline en móvil. */
@media (max-width: 768px) {
  .gm1 { grid-template-columns: 1fr !important; }
}
/* Tableta (769-1024px): los grids fijos de 3 columnas bajan a 2 para no apretar.
   Los KPI (.kg) ya fluyen solos por auto-fit, no necesitan regla. */
@media (min-width: 769px) and (max-width: 1024px) {
  .g3 { grid-template-columns: 1fr 1fr; }
  .f3 { grid-template-columns: 1fr 1fr; }
}
