
*{box-sizing:border-box}:root{--blue:#00A6D6;--dark:#063B52;--navy:#101820;--bg:#F3F7FA;--border:#D8E2EA;--soft:#EAF7FC}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;background:linear-gradient(180deg,#fff 0%,var(--bg) 100%);color:var(--navy)}
.app{max-width:980px;margin:0 auto;padding:14px}.loginScreen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:18px}.loginCard{width:100%;max-width:430px;background:white;border:1px solid var(--border);border-radius:28px;padding:22px;box-shadow:0 14px 36px rgba(6,59,82,.16)}.loginLogo{width:100%;max-width:310px;display:block;margin:0 auto 16px}.loginCard h1{text-align:center;margin:0 0 6px}.loginCard p{text-align:center;color:var(--dark);font-weight:700}.loginError{color:#b91c1c;font-weight:900;text-align:center;min-height:22px;margin-top:8px}
.brandHeader{background:white;border:1px solid var(--border);border-radius:26px;padding:18px;box-shadow:0 10px 26px rgba(6,59,82,.12);display:flex;justify-content:space-between;align-items:center;gap:12px}.brandBlock{display:flex;align-items:center;gap:14px}.brandLogo{width:180px;max-width:52vw}.brandText h1{margin:0;font-size:22px}.brandText p{margin:4px 0 0;color:var(--dark);font-weight:800}.headerActions{display:flex;align-items:center;gap:8px}.roleBadge{background:var(--soft);color:var(--dark);border:1px solid #8AD7EF;border-radius:999px;padding:7px 9px;font-size:12px;font-weight:900}.logoutBtn{width:auto;padding:8px 10px;border-radius:999px;font-size:12px;background:var(--dark);margin:0}.version{background:var(--blue);color:white;padding:8px 10px;border-radius:999px;font-weight:900;font-size:13px}
.tabs{display:flex;gap:8px;overflow-x:auto;padding:14px 0 18px}.tab{border:0;border-radius:16px;background:#E5EDF2;color:var(--navy);font-weight:900;padding:14px 16px;white-space:nowrap;font-size:15px}.tab.active,button{background:var(--blue);color:white}.panel{display:none}.panel.active{display:block}
h2{margin:8px 0 14px}.card{background:white;border:1px solid var(--border);border-radius:22px;padding:16px;margin-bottom:22px;box-shadow:0 8px 18px rgba(0,0,0,.05)}label{display:block;font-weight:900;margin:10px 0 6px}input,select,textarea{width:100%;border:1px solid #C9D7E0;border-radius:16px;padding:14px;font-size:16px;margin-bottom:10px;background:#FBFDFE}textarea{min-height:170px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}
button{width:100%;border:0;border-radius:18px;font-size:16px;font-weight:900;padding:15px;margin:6px 0;cursor:pointer}button.secondary,.backBtn{background:var(--dark)}button.ok{background:#0E8F62}.danger,.pendingOkBtn{background:#C62828!important}.doneBtn{background:#0E8F62!important}
.hint{color:#64748b;font-size:14px;line-height:1.45}.topnote{background:var(--soft);border:1px solid #8AD7EF;color:var(--dark);border-radius:18px;padding:12px;margin-bottom:12px;font-size:14px;font-weight:800}.status{background:#F8FBFC;border:1px solid #C9D7E0;border-radius:16px;padding:12px;margin:10px 0;color:var(--dark);font-weight:700}.miniStatus{display:none}
.list{display:grid;gap:12px}.item{background:white;border:1px solid var(--border);border-radius:20px;padding:15px}.item h3{margin:0 0 8px;font-size:19px}.meta{color:#64748b;font-size:14px;line-height:1.5}.row{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px}.bar{display:flex;margin-bottom:8px}.backBtn{width:auto;border-radius:14px;padding:11px 14px}
.quickBox{background:#f8fafc;border:1px solid #cbd5e1;border-radius:18px;padding:12px;margin:12px 0}.quickTitle,.zoneTitle{font-weight:900;color:var(--dark);margin-bottom:8px}.quickCenters{display:flex;flex-wrap:wrap;gap:8px}.quickChip{width:auto;margin:0;padding:10px 12px;border-radius:999px;background:#DDF4FB;color:var(--dark);border:1px solid #A9DDEC;font-size:14px}.quickZones{display:grid;gap:12px}.zoneGroup{border:1px solid var(--border);background:#fff;border-radius:16px;padding:10px}.zoneTitle{display:flex;justify-content:space-between}.zoneCount{font-size:12px;color:#64748b;background:var(--soft);border:1px solid #8AD7EF;border-radius:999px;padding:3px 7px}
.tableWrap{width:100%;overflow:auto;margin-top:12px;border:1px solid var(--border);border-radius:16px;background:white}.excelTable{width:100%;border-collapse:collapse;font-size:13px;min-width:760px}.excelTable th{background:var(--dark);color:white;text-align:left;padding:10px}.excelTable td{border-top:1px solid var(--border);padding:9px 10px}.tableMapLink,.mapsLink{display:inline-block;background:var(--blue);color:#fff!important;text-decoration:none;font-weight:900;border-radius:999px;padding:7px 9px}.excelFilters{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
body.worker-role .adminOnly,body.worker-role .adminOnlyBlock{display:none!important}body.admin-role .workerOnly,body.admin-role #fichar,body.admin-role #clave{display:none!important}
.datePill{display:inline-block;background:var(--soft);color:var(--dark);border:1px solid #8AD7EF;border-radius:999px;padding:4px 8px;font-size:12px;font-weight:900;margin-bottom:6px}.emptyDay{background:#fff7ed;border:1px solid #fed7aa;color:#9a3412}
@media(max-width:640px){.app{padding:10px}.brandHeader{align-items:flex-start}.brandBlock{flex-direction:column;align-items:flex-start}.brandLogo{width:230px;max-width:78vw}.brandText h1{display:none}.headerActions{flex-direction:column;align-items:flex-end}.row,.excelFilters{grid-template-columns:1fr}}

/* v4.9 estabilidad profesional */
.plannerSplit{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}
.legacyTextarea,
.legacyTextareaLabel{
  display:none!important;
}
.modalBackdrop{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.45);
  z-index:9999;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:18px;
}
.modalCard{
  width:100%;
  max-width:560px;
  background:#fff;
  border-radius:24px;
  padding:18px;
  box-shadow:0 18px 50px rgba(0,0,0,.30);
}
.modalCard textarea{
  min-height:190px;
}
.noteBox{
  margin-top:8px;
  background:#fff7ed;
  border:1px solid #fed7aa;
  color:#7c2d12;
  border-radius:14px;
  padding:9px;
  font-size:14px;
}
@media(max-width:640px){
  .plannerSplit{grid-template-columns:1fr}
}

/* v5.0 editor administrador de planificación */
.plannerEditorBox{
  background:#F8FDFF;
  border:2px solid #00A6D6;
  border-radius:20px;
  padding:14px;
  margin:16px 0;
}
.plannerEditor{
  display:grid;
  gap:10px;
  margin-top:12px;
}
.planRow{
  display:grid;
  grid-template-columns:70px 140px 1fr 110px 170px;
  gap:8px;
  align-items:end;
  background:#fff;
  border:1px solid #D8E2EA;
  border-radius:16px;
  padding:10px;
}
.planRow label{
  margin:0 0 4px;
  font-size:12px;
}
.planRow input,
.planRow select{
  margin:0;
  padding:10px;
  border-radius:12px;
  font-size:14px;
}
.planActions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:6px;
}
.planActions button{
  margin:0;
  padding:10px;
  font-size:13px;
  border-radius:12px;
}
.planStatus{
  font-weight:900;
  border-radius:999px;
  padding:9px 10px;
  text-align:center;
  font-size:13px;
}
.planStatusPendiente{
  background:#fee2e2;
  color:#991b1b;
}
.planStatusTerminado{
  background:#dcfce7;
  color:#166534;
}
.planEmpty{
  background:#fff7ed;
  border:1px solid #fed7aa;
  color:#9a3412;
  border-radius:16px;
  padding:12px;
  font-weight:800;
}
@media(max-width:800px){
  .planRow{
    grid-template-columns:1fr;
  }
  .planActions{
    grid-template-columns:1fr 1fr;
  }
}

/* v5.1 unificación trabajos/planificador */
.unifiedPlannerCard{
  border:2px solid #00A6D6;
  background:#F8FDFF;
}
body.worker-role .unifiedPlannerCard{
  display:none!important;
}

/* v5.2 fotos en notas */
.photoPreview{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(90px,1fr));
  gap:10px;
  margin:10px 0;
}
.photoItem{
  position:relative;
  border:1px solid #D8E2EA;
  border-radius:14px;
  overflow:hidden;
  background:#F8FBFC;
}
.photoItem img{
  width:100%;
  height:90px;
  object-fit:cover;
  display:block;
}
.photoItem button{
  position:absolute;
  top:4px;
  right:4px;
  width:auto;
  margin:0;
  padding:5px 7px;
  border-radius:999px;
  background:#C62828!important;
  font-size:12px;
}
.fotoBadge{
  display:inline-block;
  margin-top:6px;
  background:#EAF7FC;
  color:#063B52;
  border:1px solid #8AD7EF;
  border-radius:999px;
  padding:4px 8px;
  font-size:12px;
  font-weight:900;
}

/* v5.3 listas desplegables compactas */
.selectAddRow{
  display:grid;
  grid-template-columns:1fr 110px;
  gap:8px;
  align-items:end;
}
.selectAddRow select,
.selectAddRow button{
  margin:0;
}
.zoneSelectGrid{
  display:grid;
  grid-template-columns:1fr 1.4fr 130px;
  gap:8px;
  align-items:end;
}
.zoneSelectGrid select,
.zoneSelectGrid button{
  margin:0;
}
.quickBox{
  margin:10px 0;
}
@media(max-width:640px){
  .selectAddRow,
  .zoneSelectGrid{
    grid-template-columns:1fr;
  }
}

/* v5.4 editor simple agrupado por operario */
.plannerEditor{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  margin-top:12px;
}
.workerPlanGroup{
  background:#fff;
  border:1px solid #D8E2EA;
  border-radius:18px;
  padding:12px;
}
.workerPlanTitle{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:8px;
  font-weight:900;
  color:#063B52;
  margin-bottom:10px;
}
.workerPlanCount{
  background:#EAF7FC;
  border:1px solid #8AD7EF;
  color:#063B52;
  border-radius:999px;
  padding:4px 8px;
  font-size:12px;
}
.simplePlanList{
  display:grid;
  gap:8px;
}
.simplePlanItem{
  display:grid;
  grid-template-columns:40px 1fr 120px;
  gap:8px;
  align-items:center;
  border:1px solid #E5EDF2;
  border-radius:14px;
  padding:8px;
  background:#F8FBFC;
}
.simplePlanItem input{
  margin:0;
  padding:10px;
  border-radius:12px;
  font-size:14px;
}
.simplePlanActions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:6px;
}
.simplePlanActions button{
  margin:0;
  padding:9px;
  font-size:12px;
  border-radius:12px;
}
.simplePlanDone{
  opacity:.65;
}
.simplePlanDone input{
  background:#eef2f7;
}
@media(max-width:800px){
  .plannerEditor{
    grid-template-columns:1fr;
  }
  .simplePlanItem{
    grid-template-columns:1fr;
  }
}

/* v5.5 quitar ceros/campo orden del editor */
.simplePlanItem{
  grid-template-columns:1fr 120px!important;
}
@media(max-width:800px){
  .simplePlanItem{
    grid-template-columns:1fr!important;
  }
}

/* v5.6 editor con orden e insertar */
.simplePlanItem{
  grid-template-columns:1fr 230px!important;
}
.simplePlanActions{
  grid-template-columns:1fr 1fr 1fr!important;
}
.simplePlanActions button{
  font-size:11px!important;
  padding:8px!important;
}
@media(max-width:800px){
  .simplePlanItem{
    grid-template-columns:1fr!important;
  }
  .simplePlanActions{
    grid-template-columns:1fr 1fr 1fr!important;
  }
}

/* v5.7 editor de texto único */
.plannerEditorBox,
.plannerEditor{
  display:none!important;
}
.plannerSplit textarea{
  min-height:260px;
  font-size:16px;
  line-height:1.45;
}
.textoEditorNotice{
  background:#EAF7FC;
  border:1px solid #8AD7EF;
  border-radius:14px;
  padding:10px;
}

/* v5.8 editor único real */
.plannerEditorBox,
.plannerEditor,
.plannerSplit,
.legacyTextarea,
.legacyTextareaLabel{
  display:none!important;
}
.mainDayEditor{
  display:block!important;
  min-height:330px!important;
  font-size:17px!important;
  line-height:1.55!important;
  font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace!important;
}
.textoEditorNotice{
  background:#EAF7FC;
  border:1px solid #8AD7EF;
  border-radius:14px;
  padding:10px;
}

/* v5.9 editor único y clientes fusionados */
.plannerEditorBox,
.plannerEditor,
.plannerSplit,
.legacyTextarea,
.legacyTextareaLabel{
  display:none!important;
}
.mainDayEditor{
  display:block!important;
  min-height:360px!important;
  font-size:17px!important;
  line-height:1.55!important;
  font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace!important;
}
.textoEditorNotice{
  background:#EAF7FC;
  border:1px solid #8AD7EF;
  border-radius:14px;
  padding:10px;
}

/* v6.0 edición de días ya generados */
.textoEditorNotice{
  background:#EAF7FC;
  border:1px solid #8AD7EF;
  border-radius:14px;
  padding:10px;
}
.mainDayEditor{
  min-height:360px!important;
}

/* v6.2 tablas editables */
.tableEditInput,
.tableEditSelect{
  width:100%;
  min-width:110px;
  margin:0;
  padding:8px;
  border-radius:10px;
  font-size:13px;
}
.tableEditTrabajo{
  min-width:180px;
}
.tableEditNotas{
  min-width:160px;
}
.tableActions{
  display:grid;
  gap:6px;
  min-width:105px;
}
.tableActions button{
  margin:0;
  padding:8px;
  font-size:12px;
  border-radius:10px;
}
.excelTable td{
  vertical-align:middle;
}

/* v6.3 horarios editables */
.horarioEditInput,
.horarioEditSelect{
  width:100%;
  min-width:105px;
  margin:0;
  padding:8px;
  border-radius:10px;
  font-size:13px;
}
.horarioActions{
  display:grid;
  gap:6px;
  min-width:105px;
}
.horarioActions button{
  margin:0;
  padding:8px;
  font-size:12px;
  border-radius:10px;
}
.manualBadge{
  display:inline-block;
  background:#fff7ed;
  border:1px solid #fed7aa;
  color:#9a3412;
  border-radius:999px;
  padding:3px 7px;
  font-size:11px;
  font-weight:900;
}

/* v6.7 tablas retráctiles agrupadas */
.groupedTable{display:grid;gap:10px;margin-top:12px}
.groupBlock{border:1px solid #D8E2EA;border-radius:18px;overflow:hidden;background:#fff}
.groupHeader{width:100%;border:0;border-radius:0;margin:0;padding:13px 14px;background:#EAF7FC!important;color:#063B52!important;display:flex;align-items:center;justify-content:space-between;gap:10px;font-weight:900;text-align:left}
.groupHeader span{display:inline-flex;align-items:center;gap:8px}
.groupBody{display:none;padding:10px}
.groupBlock.open .groupBody{display:block}
.groupCount{background:#fff;border:1px solid #8AD7EF;border-radius:999px;padding:4px 8px;font-size:12px;white-space:nowrap}
.groupMiniTable{width:100%;border-collapse:collapse;font-size:13px}
.groupMiniTable th{background:#063B52;color:#fff;text-align:left;padding:8px}
.groupMiniTable td{border-top:1px solid #D8E2EA;padding:8px;vertical-align:middle}
.groupMiniTable input,.groupMiniTable select{margin:0}
.groupEmpty{background:#fff7ed;border:1px solid #fed7aa;color:#9a3412;border-radius:14px;padding:12px;font-weight:800}
@media(max-width:760px){.groupMiniTable{min-width:720px}.groupBody{overflow-x:auto}}

/* v6.8 tablas más compactas */
.groupedTable{
  gap:6px!important;
  margin-top:8px!important;
}
.groupBlock{
  border-radius:12px!important;
}
.groupHeader{
  padding:8px 10px!important;
  min-height:38px!important;
  font-size:14px!important;
  line-height:1.15!important;
}
.groupHeader span{
  gap:5px!important;
}
.groupCount{
  padding:2px 7px!important;
  font-size:11px!important;
}
.groupBody{
  padding:6px!important;
}
.groupMiniTable{
  font-size:12px!important;
}
.groupMiniTable th{
  padding:6px!important;
}
.groupMiniTable td{
  padding:5px!important;
}
.tableEditInput,
.tableEditSelect,
.horarioEditInput,
.horarioEditSelect{
  padding:6px!important;
  border-radius:8px!important;
  font-size:12px!important;
  min-width:85px!important;
}
.tableEditTrabajo{
  min-width:150px!important;
}
.tableEditNotas{
  min-width:120px!important;
}
.tableActions,
.horarioActions{
  min-width:74px!important;
  gap:4px!important;
}
.tableActions button,
.horarioActions button{
  padding:6px!important;
  font-size:11px!important;
  border-radius:8px!important;
}
.tableMapLink{
  padding:5px 7px!important;
  font-size:11px!important;
}
.manualBadge{
  padding:2px 6px!important;
  font-size:10px!important;
}
.card{
  padding:12px!important;
}
.tableWrap{
  margin-top:8px!important;
}
.excelFilters{
  gap:6px!important;
}
@media(max-width:760px){
  .groupMiniTable{
    min-width:620px!important;
  }
}

/* v6.9 tablas separadas por operario */
.workerGroupHeader{
  background:#063B52!important;
  color:#fff!important;
}
.workerGroupHeader .groupCount{
  color:#063B52!important;
}
.daySubBlock{
  border:1px solid #D8E2EA;
  border-radius:12px;
  margin:6px 0;
  overflow:hidden;
}
.daySubHeader{
  background:#F8FBFC;
  color:#063B52;
  font-weight:900;
  padding:7px 9px;
  border-bottom:1px solid #D8E2EA;
  display:flex;
  justify-content:space-between;
  gap:8px;
  font-size:13px;
}
.daySubBody{
  padding:5px;
  overflow-x:auto;
}
.workerEmpty{
  padding:10px;
  color:#64748b;
  font-weight:800;
}

/* v7.2 días retráctiles dentro del operario */
.daySubHeader{
  width:100%;
  border:0;
  margin:0;
  border-radius:0;
  background:#F8FBFC!important;
  color:#063B52!important;
  font-weight:900;
  padding:7px 9px!important;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:8px;
  font-size:13px;
  text-align:left;
}
.daySubBody{
  display:none;
}
.daySubBlock.dayOpen .daySubBody{
  display:block;
}
.daySubCount{
  background:#EAF7FC;
  border:1px solid #8AD7EF;
  border-radius:999px;
  padding:2px 7px;
  font-size:11px;
  white-space:nowrap;
}

/* v7.3 limpieza vista operarios */
body.worker-role .adminMessageForWorkers{
  display:none!important;
}

/* v7.4 logos restaurados y estables */
.loginLogo{
  width:100%!important;
  max-width:310px!important;
  height:auto!important;
  object-fit:contain!important;
  display:block!important;
  margin:0 auto 16px!important;
}
.brandLogo{
  width:180px!important;
  max-width:52vw!important;
  height:auto!important;
  object-fit:contain!important;
}
@media(max-width:640px){
  .brandLogo{
    width:230px!important;
    max-width:78vw!important;
  }
}

/* v7.6 pestaña Clave para operarios */
body.admin-role #clave,
body.admin-role .workerOnly{
  display:none!important;
}
body.worker-role .adminMessageForWorkers{
  display:none!important;
}

/* v7.7 fichaje GPS robusto */
button:disabled{
  opacity:.65;
  cursor:not-allowed;
}

/* v8.7 emergencia estable */
#loginScreen{
  display:flex;
}
#mainApp{
  display:none;
}

/* v8.9 Excel compacto sin tocar login */
.sectionTitleRow{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  margin:0 0 6px!important;
}
.sectionTitleRow h3{
  margin:0!important;
}
.miniExcelBtn{
  width:auto!important;
  min-width:54px!important;
  padding:5px 9px!important;
  margin:0!important;
  border-radius:999px!important;
  font-size:11px!important;
  line-height:1!important;
  background:#063B52!important;
  color:#fff!important;
}

/* v9.2 trabajos finalizados desplegables por operario */
.finalizadosList{
  display:grid!important;
  gap:6px!important;
}
.finalizadosHint{
  margin:0 0 8px!important;
  font-size:12px!important;
}
.completedWorkerGroup{
  border:1px solid #D8E2EA!important;
  border-radius:13px!important;
  overflow:hidden!important;
  background:#fff!important;
  margin-bottom:6px!important;
}
.completedWorkerHeader{
  width:100%!important;
  border:0!important;
  border-radius:0!important;
  margin:0!important;
  padding:8px 10px!important;
  background:#EAF7FC!important;
  color:#063B52!important;
  display:flex!important;
  justify-content:space-between!important;
  align-items:center!important;
  font-weight:900!important;
  text-align:left!important;
  font-size:13px!important;
}
.completedWorkerBody{
  display:none!important;
  padding:6px!important;
}
.completedWorkerGroup.open .completedWorkerBody{
  display:grid!important;
  gap:6px!important;
}
.completedCount{
  background:#fff!important;
  border:1px solid #8AD7EF!important;
  border-radius:999px!important;
  padding:2px 7px!important;
  font-size:11px!important;
  white-space:nowrap!important;
}
.completedWorkerBody .item{
  padding:9px!important;
  border-radius:12px!important;
  margin:0!important;
}
.completedWorkerBody .item h3{
  font-size:15px!important;
  margin:0 0 4px!important;
}

/* v9.4 Tablas Excel en bloques desplegables */
.collapsibleExcelCard{
  padding:0!important;
  margin-bottom:8px!important;
  border-radius:16px!important;
  overflow:hidden!important;
}
.excelCardSummary{
  cursor:pointer;
  list-style:none;
  padding:10px 12px!important;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  font-weight:900;
  color:#063B52;
  background:#EAF7FC;
}
.excelCardSummary::-webkit-details-marker{
  display:none;
}
.excelCardSummary::before{
  content:'▸';
  font-weight:900;
  margin-right:4px;
}
.collapsibleExcelCard[open] .excelCardSummary::before{
  content:'▾';
}
.excelCardSummary span{
  flex:1;
  font-size:18px;
}
.collapsibleExcelBody{
  padding:9px!important;
}
.collapsibleExcelCard:not([open]){
  min-height:auto!important;
}
.collapsibleExcelCard:not([open]) .collapsibleExcelBody{
  display:none!important;
}
.collapsibleExcelCard .excelFilters{
  margin-top:0!important;
}
.collapsibleExcelCard .tableWrap{
  margin-top:6px!important;
}
.collapsibleExcelCard .miniExcelBtn{
  flex:0 0 auto;
}
/* Evita que al pulsar Excel se abra/cierre el desplegable */
.excelCardSummary .miniExcelBtn{
  position:relative;
  z-index:2;
}

/* v9.5 quitar explicación en Tablas Excel */
#tablas h2{
  margin-bottom:14px!important;
}

/* v9.7 actualización trabajos finalizados admin */
#btnActualizarFinalizados{
  min-width:auto!important;
  padding:5px 9px!important;
  font-size:11px!important;
}

/* v9.8 mensajes internos */
.mensajesList{
  display:grid;
  gap:8px;
}
.mensajeItem{
  border:1px solid #D8E2EA;
  border-radius:14px;
  padding:10px;
  background:#fff;
}
.mensajeMine{
  background:#EAF7FC;
  border-color:#8AD7EF;
}
.mensajeOther{
  background:#F8FBFC;
}
.mensajeMeta{
  font-size:11px;
  font-weight:900;
  color:#64748b;
  margin-bottom:5px;
}
.mensajeTexto{
  font-size:14px;
  font-weight:800;
  color:#0f172a;
  white-space:pre-wrap;
}

/* v9.9 notificaciones mensajes */
.msgBadge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:20px;
  height:20px;
  padding:0 6px;
  border-radius:999px;
  background:#dc2626;
  color:#fff;
  font-size:11px;
  font-weight:900;
  margin-left:6px;
}
.miniNotifyBtn{
  margin-top:8px!important;
  padding:8px!important;
  border-radius:12px!important;
  font-size:12px!important;
}

/* v10.1 avisos automáticos */
.avisosActivos{
  background:#dcfce7!important;
  color:#166534!important;
  border:1px solid #86efac!important;
}
.avisosBloqueados{
  background:#fee2e2!important;
  color:#991b1b!important;
  border:1px solid #fecaca!important;
}

/* v10.2 control lectura operarios */
.controlLecturaCard{
  margin-top:8px!important;
}
.controlLecturaGrid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
}
.controlLecturaItem{
  border:1px solid #D8E2EA;
  border-radius:14px;
  padding:10px;
  background:#F8FBFC;
}
.controlLecturaItem h4{
  margin:0 0 8px;
  color:#063B52;
}
.controlLine{
  display:flex;
  justify-content:space-between;
  gap:8px;
  font-size:13px;
  padding:4px 0;
}
.okText{
  color:#166534;
}
.badText{
  color:#991b1b;
}
@media(max-width:680px){
  .controlLecturaGrid{
    grid-template-columns:1fr;
  }
}

/* v10.4 mensajes separados, lectura y no repetición */
.mensajeWorkerGroup{
  border:1px solid #D8E2EA;
  border-radius:14px;
  overflow:hidden;
  background:#fff;
  margin-bottom:8px;
}
.mensajeWorkerHeader{
  width:100%;
  border:0;
  border-radius:0;
  margin:0;
  padding:9px 11px;
  background:#EAF7FC!important;
  color:#063B52!important;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  font-weight:900;
  text-align:left;
}
.mensajeWorkerBody{
  display:none;
  padding:8px;
}
.mensajeWorkerGroup.open .mensajeWorkerBody{
  display:grid;
  gap:8px;
}
.mensajeCount{
  background:#fff;
  border:1px solid #8AD7EF;
  border-radius:999px;
  padding:2px 7px;
  font-size:11px;
  white-space:nowrap;
}
.readStatus{
  display:inline-block;
  margin-top:6px;
  font-size:11px;
  font-weight:900;
  border-radius:999px;
  padding:3px 7px;
}
.readYes{
  background:#dcfce7;
  color:#166534;
  border:1px solid #86efac;
}
.readNo{
  background:#fee2e2;
  color:#991b1b;
  border:1px solid #fecaca;
}

/* v10.5 mensajería mejorada */
.mensajesComposerCard{
  position:sticky;
  top:0;
  z-index:5;
  box-shadow:0 6px 18px rgba(2, 6, 23, .08);
}
.mensajesComposerCard textarea{
  min-height:78px!important;
  resize:vertical;
  font-size:15px!important;
}
.mensajeActionsRow{
  display:grid;
  grid-template-columns:1fr auto;
  gap:8px;
  align-items:center;
}
.mensajeActionsRow #btnEnviarMensaje{
  margin:0!important;
}
.mensajeActionsRow .miniNotifyBtn{
  margin:0!important;
  white-space:nowrap;
}
.mensajesList{
  display:grid!important;
  gap:8px!important;
}
.mensajeWorkerGroup{
  border:1px solid #D8E2EA!important;
  border-radius:16px!important;
  overflow:hidden!important;
  background:#fff!important;
  margin-bottom:8px!important;
}
.mensajeWorkerHeader{
  width:100%!important;
  border:0!important;
  border-radius:0!important;
  margin:0!important;
  padding:10px 12px!important;
  background:#EAF7FC!important;
  color:#063B52!important;
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:8px!important;
  font-weight:900!important;
  text-align:left!important;
}
.mensajeWorkerHeader span:first-child{
  display:flex;
  align-items:center;
  gap:6px;
}
.mensajeWorkerBody{
  display:none!important;
  padding:10px!important;
  background:#f8fafc;
}
.mensajeWorkerGroup.open .mensajeWorkerBody{
  display:flex!important;
  flex-direction:column!important;
  gap:8px!important;
}
.mensajeCount{
  background:#fff!important;
  border:1px solid #8AD7EF!important;
  border-radius:999px!important;
  padding:3px 8px!important;
  font-size:11px!important;
  white-space:nowrap!important;
}
.mensajeItem{
  max-width:86%;
  border:1px solid #D8E2EA!important;
  border-radius:16px!important;
  padding:9px 10px!important;
  margin:0!important;
  box-shadow:0 2px 8px rgba(2,6,23,.05);
}
.mensajeMine{
  justify-self:end;
  align-self:flex-end;
  background:#DFF6FF!important;
  border-color:#8AD7EF!important;
  border-bottom-right-radius:5px!important;
}
.mensajeOther{
  justify-self:start;
  align-self:flex-start;
  background:#fff!important;
  border-bottom-left-radius:5px!important;
}
.mensajeMeta{
  font-size:10.5px!important;
  font-weight:900!important;
  color:#64748b!important;
  margin-bottom:5px!important;
}
.mensajeTexto{
  font-size:14px!important;
  line-height:1.35!important;
  font-weight:750!important;
  color:#0f172a!important;
  white-space:pre-wrap!important;
  word-break:break-word;
}
.readStatus{
  display:inline-block!important;
  margin-top:7px!important;
  font-size:10.5px!important;
  font-weight:900!important;
  border-radius:999px!important;
  padding:3px 7px!important;
}
.readYes{
  background:#dcfce7!important;
  color:#166534!important;
  border:1px solid #86efac!important;
}
.readNo{
  background:#fee2e2!important;
  color:#991b1b!important;
  border:1px solid #fecaca!important;
}
.msgBadge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:20px;
  height:20px;
  padding:0 6px;
  border-radius:999px;
  background:#dc2626;
  color:#fff;
  font-size:11px;
  font-weight:900;
  margin-left:6px;
}
.mensajeEmptyThread{
  padding:12px;
  border:1px dashed #cbd5e1;
  border-radius:14px;
  color:#64748b;
  font-weight:800;
  background:#fff;
}
@media(max-width:680px){
  .mensajeItem{
    max-width:94%;
  }
  .mensajeActionsRow{
    grid-template-columns:1fr;
  }
  .mensajeActionsRow .miniNotifyBtn{
    width:100%!important;
  }
}

/* v10.6 trabajos realizados por operario y día */
.completedDayGroup{
  border:1px solid #D8E2EA;
  border-radius:12px;
  overflow:hidden;
  background:#fff;
  margin-bottom:6px;
}
.completedDayHeader{
  width:100%;
  border:0;
  border-radius:0;
  margin:0;
  padding:8px 10px;
  background:#F8FBFC!important;
  color:#063B52!important;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  font-weight:900;
  text-align:left;
  font-size:13px;
}
.completedDayBody{
  display:none;
  padding:7px;
  background:#fff;
}
.completedDayGroup.open .completedDayBody{
  display:grid;
  gap:7px;
}
.completedDayCount{
  background:#EAF7FC;
  border:1px solid #8AD7EF;
  border-radius:999px;
  padding:2px 7px;
  font-size:11px;
  white-space:nowrap;
}
.completedWorkerBody{
  background:#f8fafc!important;
}

/* v10.7 interfaz compacta */
.panel h2{
  margin:6px 0 10px!important;
}
.card{
  margin-bottom:9px!important;
}
.compactDateCard{
  padding:9px!important;
}
.fieldInline{
  display:grid;
  grid-template-columns:auto 1fr;
  align-items:center;
  gap:10px;
}
.fieldInline label{
  margin:0!important;
  font-weight:900;
  color:#063B52;
}
.fieldInline input{
  margin:0!important;
}
.compactAdminDetails{
  padding:0!important;
  overflow:hidden;
}
.compactAdminSummary{
  list-style:none;
  cursor:pointer;
  padding:10px 12px;
  font-weight:900;
  color:#063B52;
  background:#EAF7FC;
  display:flex;
  justify-content:space-between;
  align-items:center;
}
.compactAdminSummary::-webkit-details-marker{
  display:none;
}
.compactAdminSummary::before{
  content:'▸';
  margin-right:8px;
}
.compactAdminDetails[open] .compactAdminSummary::before{
  content:'▾';
}
.compactAdminBody{
  padding:10px;
}
.unifiedPlannerCard .compactAdminBody{
  display:grid;
  gap:8px;
}
.unifiedPlannerCard label,
.mensajesComposerCard label{
  margin-top:6px!important;
}
.mainDayEditor{
  min-height:150px!important;
}
.quickBox{
  margin:6px 0!important;
  padding:8px!important;
}
.zoneSelectGrid{
  gap:6px!important;
}
#btnGuardarPlanDia,
#btnVaciarPlanDia,
#btnCargarDiaOperario{
  margin-top:4px!important;
}
#listaTrabajos .item{
  margin-bottom:8px!important;
}
#tablas .card,
#mensajes .card{
  margin-bottom:8px!important;
}
.finalizadosList{
  margin-top:6px!important;
}
@media(max-width:680px){
  .fieldInline{
    grid-template-columns:1fr;
    gap:5px;
  }
}

/* v10.8 cabecera Irala fusionada y elegante */
.brandHeaderElegant{
  padding:14px!important;
  border-radius:28px!important;
  background:linear-gradient(135deg,#ffffff 0%,#f4fbfe 100%)!important;
  box-shadow:0 12px 30px rgba(6,59,82,.14)!important;
  display:grid!important;
  gap:10px!important;
}
.brandTopRow{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.brandHeaderElegant .brandBlock{
  display:flex!important;
  align-items:center!important;
  gap:14px!important;
  min-width:0;
}
.brandHeaderElegant .brandLogo{
  width:220px!important;
  max-width:48vw!important;
  height:auto!important;
  display:block!important;
  object-fit:contain!important;
}
.brandHeaderElegant .brandText{
  min-width:0;
}
.brandHeaderElegant .brandText h1{
  font-size:22px!important;
  line-height:1.05!important;
  margin:0!important;
  color:#0f172a!important;
}
.brandHeaderElegant .brandText p{
  font-size:12px!important;
  line-height:1.2!important;
  margin:4px 0 0!important;
  color:#063B52!important;
  font-weight:900!important;
}
.brandHeaderElegant .headerActions{
  display:flex!important;
  align-items:center!important;
  justify-content:flex-end!important;
  flex-wrap:wrap!important;
  gap:6px!important;
  max-width:42%;
}
.brandHeaderElegant .roleBadge,
.brandHeaderElegant .logoutBtn,
.brandHeaderElegant .version{
  font-size:11px!important;
  padding:6px 8px!important;
  border-radius:999px!important;
  margin:0!important;
  width:auto!important;
  white-space:nowrap!important;
}
.brandInfoRow{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
  align-items:center;
  border-top:1px solid #D8E2EA;
  padding-top:8px;
}
.headerChip{
  display:inline-flex;
  align-items:center;
  min-height:26px;
  border-radius:999px;
  padding:5px 9px;
  background:#EAF7FC;
  color:#063B52;
  border:1px solid #8AD7EF;
  font-size:12px;
  font-weight:900;
}
.headerChipAlert{
  background:#fee2e2!important;
  color:#991b1b!important;
  border-color:#fecaca!important;
}
.tabs{
  padding:10px 0 12px!important;
  gap:7px!important;
}
.tab{
  padding:11px 13px!important;
  border-radius:15px!important;
  font-size:14px!important;
}
@media(max-width:720px){
  .brandTopRow{
    align-items:flex-start;
  }
  .brandHeaderElegant .brandLogo{
    width:190px!important;
    max-width:62vw!important;
  }
  .brandHeaderElegant .brandText h1{
    font-size:18px!important;
  }
  .brandHeaderElegant .headerActions{
    max-width:38%;
    gap:5px!important;
  }
  .brandHeaderElegant .roleBadge{
    max-width:100%;
    overflow:hidden;
    text-overflow:ellipsis;
  }
}
@media(max-width:430px){
  .brandHeaderElegant{
    padding:12px!important;
  }
  .brandHeaderElegant .brandBlock{
    gap:8px!important;
  }
  .brandHeaderElegant .brandLogo{
    width:165px!important;
    max-width:58vw!important;
  }
  .brandHeaderElegant .brandText h1{
    display:none;
  }
  .brandHeaderElegant .brandText p{
    display:none;
  }
  .brandHeaderElegant .headerActions{
    max-width:44%;
  }
  .brandInfoRow{
    padding-top:7px;
  }
  .headerChip{
    font-size:11px;
    min-height:24px;
    padding:4px 8px;
  }
}


/* v10.9 pestaña Leads integrada */
.leadsIntro{
  margin:-6px 0 10px;
  color:#063B52;
  font-weight:800;
  font-size:13px;
}
.leadsModule{
  --leads-panel:#ffffff;
  --leads-panel-2:#F8FBFC;
  --leads-text:#0f172a;
  --leads-muted:#64748b;
  --leads-accent:#00A6D6;
  --leads-border:#D8E2EA;
  --leads-warn:#f59e0b;
}
.leadsModule *{box-sizing:border-box}
.leadsModule .layout{
  display:grid;
  grid-template-columns:330px 1fr;
  gap:12px;
  padding:0;
}
.leadsModule .panel{
  background:var(--leads-panel);
  border:1px solid var(--leads-border);
  border-radius:18px;
  padding:12px;
  color:var(--leads-text);
  display:block!important;
}
.leadsModule .controls{
  display:flex;
  flex-direction:column;
  gap:10px;
  position:sticky;
  top:12px;
  height:fit-content;
}
.leadsModule section h2,
.leadsModule .results h2{
  margin:0 0 8px;
  font-size:1rem;
  color:#0f172a;
}
.leadsModule label{
  display:block;
  font-size:.84rem;
  color:var(--leads-muted);
  margin:7px 0;
  font-weight:900;
}
.leadsModule input,
.leadsModule select,
.leadsModule textarea,
.leadsModule button{
  width:100%;
  margin-top:5px;
  border-radius:12px;
  border:1px solid var(--leads-border);
  background:var(--leads-panel-2);
  color:var(--leads-text);
  padding:9px 10px;
  font:inherit;
}
.leadsModule textarea{resize:vertical; min-height:auto!important}
.leadsModule button{
  cursor:pointer;
  background:#00A6D6;
  color:white;
  font-weight:900;
  border:none;
}
.leadsModule button.secondary{
  background:#063B52;
  color:white;
  border:1px solid #063B52;
}
.leadsModule button.hidden{display:none}
.leadsModule .actions{display:flex;gap:8px}
.leadsModule .actions>*{flex:1}
.leadsModule .actions.compact{gap:6px}
.leadsModule .actions.compact button{padding:7px 8px;font-size:12px}
.leadsModule .actions.right{justify-content:flex-end}
.leadsModule .hint{color:var(--leads-muted);font-size:.78rem;line-height:1.35}
.leadsModule .toolbar{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:10px;
  margin-bottom:10px;
}
.leadsModule .toolbar p{margin:.25rem 0 0;color:var(--leads-muted);font-size:13px}
.leadsModule .toolbar-actions{display:flex;gap:8px}
.leadsModule .toolbar-actions button{width:auto}
.leadsModule .summary-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:8px;
  margin-bottom:10px;
}
.leadsModule .summary-grid article{
  background:#F8FBFC;
  border-radius:14px;
  padding:10px;
  border:1px solid var(--leads-border);
}
.leadsModule .summary-grid span{display:block;color:var(--leads-muted);font-size:.78rem;font-weight:800}
.leadsModule .summary-grid strong{font-size:1.35rem;color:#063B52}
.leadsModule .table-wrap{
  overflow:auto;
  border-radius:14px;
  border:1px solid var(--leads-border);
}
.leadsModule table{width:100%;border-collapse:collapse;min-width:760px;background:white}
.leadsModule th,
.leadsModule td{
  padding:9px 10px;
  border-bottom:1px solid var(--leads-border);
  text-align:left;
  vertical-align:top;
  color:#0f172a;
  font-size:13px;
}
.leadsModule th{
  color:#063B52;
  background:#EAF7FC;
  font-weight:900;
}
.leadsModule .companyCell{font-weight:900}
.leadsModule .score{
  display:inline-flex;
  min-width:42px;
  justify-content:center;
  border-radius:999px;
  padding:4px 8px;
  font-weight:900;
}
.leadsModule .score.hot{background:#dcfce7;color:#166534}
.leadsModule .score.mid{background:#fef3c7;color:#92400e}
.leadsModule .score.low{background:#fee2e2;color:#991b1b}
.leadsPanel dialog{
  border:none;
  border-radius:18px;
  padding:0;
  max-width:980px;
  width:calc(100vw - 28px);
}
.leadsPanel dialog::backdrop{background:rgba(15,23,42,.55)}
.leadsModule .dialog-card{
  background:white;
  color:#0f172a;
  border:1px solid #D8E2EA;
  border-radius:18px;
  padding:14px;
}
.leadsModule .dialog-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.leadsModule .dialog-head h2{margin:0}
.leadsModule .dialog-head button{width:auto}
.leadsModule .dialog-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  margin-top:12px;
}
.leadsModule .meta{
  color:#64748b;
  font-size:13px;
  font-weight:800;
  line-height:1.45;
}
.leadsModule .detail-box{
  white-space:pre-wrap;
  background:#F8FBFC;
  border:1px solid #D8E2EA;
  border-radius:12px;
  padding:10px;
  color:#0f172a;
  max-height:320px;
  overflow:auto;
}
.leadsModule #leads_emailOutput{
  min-height:330px!important;
  font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
}
@media(max-width:900px){
  .leadsModule .layout{grid-template-columns:1fr}
  .leadsModule .controls{position:static}
  .leadsModule .dialog-grid{grid-template-columns:1fr}
}
@media(max-width:650px){
  .leadsModule .toolbar{display:grid}
  .leadsModule .summary-grid{grid-template-columns:1fr}
  .leadsModule .actions{display:grid}
}

.leadsModuleStatus{
  margin:0 0 10px;
  padding:8px 10px;
  border-radius:12px;
  background:#fff7ed;
  color:#9a3412;
  border:1px solid #fed7aa;
  font-size:12px;
  font-weight:800;
  display:none;
}
.leadsModuleStatus:not(:empty){
  display:block;
}

/* v11.2 Leads: detalle a pantalla completa y búsqueda de contacto */
.leadsPanel dialog{
  max-width:none!important;
  width:100vw!important;
  height:100dvh!important;
  max-height:100dvh!important;
  margin:0!important;
  border-radius:0!important;
  padding:0!important;
}
.leadsPanel dialog::backdrop{
  background:rgba(15,23,42,.72)!important;
}
.leadsModule .dialog-card{
  width:100%!important;
  min-height:100dvh!important;
  border-radius:0!important;
  border:0!important;
  padding:14px!important;
  display:flex!important;
  flex-direction:column!important;
}
.leadsModule .dialog-head{
  position:sticky!important;
  top:0!important;
  z-index:4!important;
  background:white!important;
  padding:4px 0 10px!important;
  border-bottom:1px solid #D8E2EA!important;
}
.leadsModule .dialog-head h2{
  font-size:20px!important;
  line-height:1.15!important;
  max-width:72%!important;
}
.leadsModule .dialog-head button{
  width:auto!important;
  min-width:82px!important;
}
.leadsModule .dialog-grid{
  flex:1!important;
  overflow:auto!important;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr)!important;
  gap:14px!important;
  padding-top:12px!important;
}
.leadsModule .detail-box{
  max-height:38dvh!important;
}
.leadsModule #leads_emailOutput{
  min-height:52dvh!important;
}
.leadContactBox{
  margin-top:8px;
}
.leadContactGrid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
}
.leadContactBtn{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:40px;
  padding:8px 10px;
  border-radius:12px;
  background:#EAF7FC;
  color:#063B52;
  border:1px solid #8AD7EF;
  text-decoration:none;
  font-weight:900;
  font-size:13px;
  text-align:center;
}
.leadContactHint{
  margin-top:8px;
  font-size:12px;
  line-height:1.35;
  color:#64748b;
  font-weight:800;
}
@media(max-width:760px){
  .leadsModule .dialog-grid{
    grid-template-columns:1fr!important;
  }
  .leadsModule .dialog-head h2{
    font-size:18px!important;
    max-width:68%!important;
  }
  .leadsModule .detail-box{
    max-height:28dvh!important;
  }
  .leadsModule #leads_emailOutput{
    min-height:44dvh!important;
  }
  .leadContactGrid{
    grid-template-columns:1fr;
  }
}

/* v11.3 Leads: guía avanzada para conseguir contacto */
.leadFoundContactBox,
.leadContactGuideBox{
  margin-top:8px;
}
.leadFoundGrid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
}
.leadFoundGrid label{
  font-size:12px!important;
  font-weight:900!important;
  color:#64748b!important;
  margin:0!important;
}
.leadFoundGrid input,
.leadFoundGrid select,
.leadFoundGrid textarea{
  width:100%!important;
  margin-top:4px!important;
  border:1px solid #D8E2EA!important;
  border-radius:12px!important;
  padding:8px!important;
  background:#F8FBFC!important;
  color:#0f172a!important;
  font-size:13px!important;
}
.leadFull{
  grid-column:1/-1;
}
.leadFoundActions{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
  margin:10px 0;
}
.leadFoundActions button,
.leadEmailPatternBox button{
  width:100%!important;
  border-radius:12px!important;
  padding:9px!important;
  font-size:12px!important;
  font-weight:900!important;
}
.leadGuideItem{
  border:1px solid #D8E2EA;
  border-radius:14px;
  background:#fff;
  overflow:hidden;
  margin-bottom:8px;
}
.leadGuideItem summary{
  cursor:pointer;
  list-style:none;
  padding:10px 11px;
  background:#EAF7FC;
  color:#063B52;
  font-weight:900;
  font-size:13px;
}
.leadGuideItem summary::-webkit-details-marker{
  display:none;
}
.leadGuideItem summary::before{
  content:"▸ ";
}
.leadGuideItem[open] summary::before{
  content:"▾ ";
}
.leadGuideBody{
  padding:10px;
}
.leadGuideBody p{
  margin:0 0 8px!important;
  color:#334155;
  font-size:12px;
  line-height:1.35;
  font-weight:750;
}
.leadGuideButtons{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
}
.leadEmailPatternResult{
  display:grid;
  gap:6px;
  margin-top:8px;
}
.leadEmailOption{
  display:grid;
  grid-template-columns:1fr auto;
  gap:6px;
  align-items:center;
  padding:7px;
  border:1px solid #D8E2EA;
  border-radius:10px;
  background:#F8FBFC;
  font-size:12px;
  font-weight:900;
}
.leadEmailOption button{
  padding:6px 8px!important;
  font-size:11px!important;
}
.leadSmallWarn{
  padding:8px;
  border-radius:10px;
  background:#fff7ed;
  border:1px solid #fed7aa;
  color:#9a3412;
  font-weight:900;
  font-size:12px;
}
.leadLegalNote{
  margin-top:8px;
  padding:8px 10px;
  border-radius:12px;
  background:#f8fafc;
  border:1px solid #D8E2EA;
  color:#64748b;
  font-size:11px;
  line-height:1.35;
  font-weight:800;
}
@media(max-width:760px){
  .leadFoundGrid,
  .leadFoundActions,
  .leadGuideButtons{
    grid-template-columns:1fr;
  }
}

/* v11.4 cabecera más aprovechada */
.brandHeaderElegant{
  padding:16px 18px!important;
}
.brandHeaderElegant .brandTopRow{
  display:grid!important;
  grid-template-columns:minmax(0,1fr) auto!important;
  align-items:center!important;
  gap:10px!important;
  min-height:128px!important;
}
.brandHeaderElegant .brandBlock{
  width:100%!important;
  min-width:0!important;
}
.brandHeaderElegant .brandLogo{
  width:335px!important;
  max-width:72vw!important;
}
.brandHeaderElegant .headerActions{
  max-width:none!important;
  min-width:86px!important;
  align-self:center!important;
  justify-content:center!important;
  align-items:center!important;
}
.brandHeaderElegant .roleBadge,
.brandHeaderElegant .logoutBtn,
.brandHeaderElegant .version{
  min-width:78px!important;
  text-align:center!important;
  justify-content:center!important;
}
.brandInfoRow{
  width:100%!important;
  border-top:1px solid #D8E2EA!important;
  justify-content:flex-start!important;
}
.headerChip{
  min-width:150px!important;
  justify-content:center!important;
}
@media(max-width:720px){
  .brandHeaderElegant{
    padding:14px!important;
  }
  .brandHeaderElegant .brandTopRow{
    grid-template-columns:minmax(0,1fr) 82px!important;
    min-height:122px!important;
  }
  .brandHeaderElegant .brandLogo{
    width:300px!important;
    max-width:70vw!important;
  }
  .brandHeaderElegant .headerActions{
    min-width:78px!important;
  }
  .brandHeaderElegant .roleBadge,
  .brandHeaderElegant .logoutBtn,
  .brandHeaderElegant .version{
    min-width:72px!important;
    padding:7px 8px!important;
  }
}
@media(max-width:430px){
  .brandHeaderElegant .brandTopRow{
    grid-template-columns:minmax(0,1fr) 78px!important;
    min-height:118px!important;
  }
  .brandHeaderElegant .brandLogo{
    width:275px!important;
    max-width:68vw!important;
  }
  .headerChip{
    min-width:auto!important;
    flex:1 1 145px!important;
  }
}

/* v11.4 notas corregidas y más cómodas */
.modalBackdrop{
  align-items:stretch!important;
  justify-content:center!important;
  padding:12px!important;
}
.modalCard{
  max-height:92dvh!important;
  overflow:auto!important;
}
.modalCard textarea#notaTexto{
  min-height:220px!important;
  width:100%!important;
  font-size:16px!important;
  line-height:1.35!important;
}
.notaHintFix{
  margin-top:4px!important;
  margin-bottom:8px!important;
}
.completedDayBody .row{
  margin-top:8px!important;
}

/* v11.5 notas sin depender de columna fotos */
.notaFotosDisabled{
  margin:10px 0;
  padding:10px 12px;
  border-radius:14px;
  background:#fff7ed;
  border:1px solid #fed7aa;
  color:#9a3412;
  font-size:13px;
  line-height:1.35;
  font-weight:800;
}
.notaFotosDisabled code{
  background:#fff;
  border:1px solid #fed7aa;
  border-radius:7px;
  padding:1px 5px;
}

/* v11.6 fotos activadas en notas */
#notaFotosInput{
  background:#F8FBFC!important;
  border:1px solid #D8E2EA!important;
  border-radius:14px!important;
  padding:12px!important;
}
.photoPreview{
  display:grid!important;
}

/* v11.7 Control de cobros */
.cobrosSummaryGrid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:8px;
  margin-bottom:10px;
}
.cobroCard{
  background:#ffffff;
  border:1px solid #D8E2EA;
  border-radius:16px;
  padding:10px;
  box-shadow:0 2px 10px rgba(2,6,23,.05);
}
.cobroCard span{
  display:block;
  font-size:11px;
  color:#64748b;
  font-weight:900;
}
.cobroCard b{
  display:block;
  margin-top:3px;
  color:#063B52;
  font-size:18px;
}
.dangerCard b{ color:#991b1b; }
.cobrosButtonGrid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:8px;
}
.fileActionBtn{
  display:flex!important;
  align-items:center;
  justify-content:center;
  text-align:center;
  background:#00A6D6;
  color:white!important;
  border-radius:14px;
  padding:11px 10px;
  font-weight:900;
  cursor:pointer;
  margin:0!important;
}
.fileActionBtn input{ display:none; }
.cobrosButtonGrid button{
  margin:0!important;
  border-radius:14px!important;
}
.cobrosHint{
  margin-top:8px!important;
  font-size:12px!important;
}
.cobrosFilters{
  display:grid;
  grid-template-columns:100px 140px 1fr 180px 170px;
  gap:8px;
  align-items:end;
}
.cobrosFilters label{
  margin:0!important;
  font-size:12px!important;
}
.cobrosFilters input,
.cobrosFilters select{
  margin-top:4px!important;
}
.cobrosTableWrap{
  overflow:auto;
  border:1px solid #D8E2EA;
  border-radius:16px;
}
.cobrosTable{
  min-width:1120px;
  width:100%;
  border-collapse:collapse;
  background:#fff;
}
.cobrosTable th{
  background:#EAF7FC;
  color:#063B52;
  font-size:12px;
  font-weight:900;
  padding:9px;
  text-align:left;
  border-bottom:1px solid #D8E2EA;
}
.cobrosTable td{
  padding:7px;
  border-bottom:1px solid #EEF2F7;
  vertical-align:top;
}
.cobroInput{
  width:100%;
  border:1px solid #D8E2EA;
  border-radius:10px;
  padding:7px;
  font-size:12px;
  background:#F8FBFC;
  color:#0f172a;
}
.cobroInput.amount{ text-align:right; }
.cobroInput.obs{
  min-height:42px;
  resize:vertical;
}
.cobroActions{
  display:grid;
  grid-template-columns:1fr;
  gap:5px;
}
.cobroActions button{
  padding:7px!important;
  font-size:11px!important;
  margin:0!important;
  border-radius:10px!important;
}
.cobrosEmpty{
  text-align:center;
  color:#64748b;
  font-weight:900;
  padding:18px!important;
}
.miniCounter{
  background:#EAF7FC;
  border:1px solid #8AD7EF;
  color:#063B52;
  border-radius:999px;
  padding:4px 8px;
  font-size:12px;
  font-weight:900;
}
.cobrosHelpCard summary{
  cursor:pointer;
  color:#063B52;
  font-weight:900;
}
.cobrosHelpText{
  color:#334155;
  font-size:13px;
  line-height:1.4;
}
@media(max-width:900px){
  .cobrosSummaryGrid{ grid-template-columns:repeat(2,minmax(0,1fr)); }
  .cobrosButtonGrid{ grid-template-columns:1fr 1fr; }
  .cobrosFilters{ grid-template-columns:1fr 1fr; }
}
@media(max-width:560px){
  .cobrosSummaryGrid,
  .cobrosButtonGrid,
  .cobrosFilters{ grid-template-columns:1fr; }
}

/* v11.8 control de cobros real Supabase */
.cobrosActionsCard::before{
  content:'Base de datos Supabase activa: las facturas, banco, C19 y conciliaciones se guardan como histórico real.';
  display:block;
  margin-bottom:8px;
  padding:8px 10px;
  border-radius:12px;
  background:#dcfce7;
  color:#166534;
  border:1px solid #86efac;
  font-size:12px;
  font-weight:900;
}

/* v12.0 Control cobros avanzado */
.cobrosSummaryGridAdvanced{
  grid-template-columns:repeat(5,minmax(0,1fr))!important;
}
.warnCard b{ color:#b45309!important; }
.cobroIncidenciaRow td{
  background:#fff7ed!important;
}
.cobroIncidenciaRow td:first-child{
  border-left:4px solid #dc2626!important;
}
.cobrosRulesCard summary{
  cursor:pointer;
  font-weight:900;
  color:#063B52;
}
.cobrosRulesGrid{
  display:grid;
  grid-template-columns:1fr 180px 1fr 1fr 140px;
  gap:8px;
  align-items:end;
  margin-top:10px;
}
.cobrosRulesGrid label{
  margin:0!important;
  font-size:12px!important;
}
.cobrosRulesGrid input,
.cobrosRulesGrid select,
.cobrosRulesGrid textarea{
  width:100%;
  margin-top:4px!important;
  border:1px solid #D8E2EA;
  border-radius:12px;
  padding:8px;
  background:#F8FBFC;
}
.cobrosRulesGrid button{
  margin:0!important;
  border-radius:12px!important;
}
.cobrosReglasLista{
  display:grid;
  gap:6px;
  margin-top:10px;
}
.reglaCobroItem{
  display:grid;
  grid-template-columns:1fr 130px 1.5fr 80px;
  gap:8px;
  align-items:center;
  border:1px solid #D8E2EA;
  border-radius:12px;
  padding:8px;
  background:#F8FBFC;
  font-size:12px;
}
.reglaCobroItem small{
  color:#64748b;
}
.reglaCobroItem button{
  padding:6px!important;
  margin:0!important;
  border-radius:10px!important;
}
.cobrosEmptySmall{
  color:#64748b;
  font-weight:900;
  font-size:12px;
  padding:8px;
}
@media(max-width:900px){
  .cobrosSummaryGridAdvanced{grid-template-columns:repeat(2,minmax(0,1fr))!important}
  .cobrosRulesGrid{grid-template-columns:1fr}
  .reglaCobroItem{grid-template-columns:1fr}
}

/* v12.1 Face ID / huella directo */
.biometricAutoBox{
  margin:10px 0 12px;
  padding:14px;
  border-radius:18px;
  background:#EAF7FC;
  border:1px solid #8AD7EF;
  color:#063B52;
  text-align:center;
  gap:5px;
  justify-items:center;
  font-weight:900;
}
.biometricAutoBox .faceIcon{
  font-size:34px;
  line-height:1;
}
.biometricAutoBox span{
  display:block;
  font-size:13px;
  color:#0f172a;
  font-weight:800;
}

/* v12.2 Face ID limpio: sin globos propios de la app */
.biometricAutoBox{
  display:none!important;
}
.biometricStatusHidden{
  display:none!important;
}
#loginIntroText{
  font-size:13px!important;
  color:#64748b!important;
  margin-bottom:10px!important;
}

/* v12.4 Holiday Inn Express Bilbao Airport */
.holidayHero{background:linear-gradient(135deg,#EAF7FC,#fff);border:1px solid #8AD7EF;border-radius:22px;padding:16px;margin-bottom:12px}
.holidayHero h2{margin:0;color:#063B52;font-size:26px;line-height:1.1}.holidayHero p{margin:6px 0 2px;font-weight:900}.holidayHero small{color:#64748b;font-weight:800}
.holidaySummaryGrid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-bottom:10px}.holidaySummaryCard{background:#fff;border:1px solid #D8E2EA;border-radius:16px;padding:10px}.holidaySummaryCard span{display:block;font-size:11px;font-weight:900;color:#64748b}.holidaySummaryCard b{display:block;margin-top:3px;color:#063B52;font-size:18px}
.holidayActions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.holidayActions button{margin:0!important;border-radius:14px!important}
.holidayTabs{display:flex;gap:8px;overflow-x:auto;padding:4px 0 10px}.holidayPlantTab{flex:0 0 auto;border:0;border-radius:999px;padding:10px 14px;font-weight:900;background:#E8EEF3;color:#0f172a}.holidayPlantTab.active{background:#00A6D6;color:#fff}
.holidayZoneBlock{border:1px solid #D8E2EA;border-radius:18px;background:#fff;margin-bottom:10px;overflow:hidden}.holidayZoneBlock summary{cursor:pointer;padding:12px 14px;background:#EAF7FC;color:#063B52;font-weight:950;display:flex;justify-content:space-between;align-items:center;font-size:18px}
.holidayZoneActions{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:10px}.holidayZoneActions button{margin:0!important;border-radius:12px!important;font-size:13px!important}.holidayCards{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding:10px}
.holidayCard{border:1px solid #D8E2EA;border-radius:16px;padding:10px;background:#F8FBFC}.holidayCard.done{border-color:#86efac;background:#f0fdf4}.holidayCard.pending{border-color:#fed7aa;background:#fff7ed}.holidayCardTop{display:flex;justify-content:space-between;gap:8px;align-items:flex-start}.holidayCardTop b{font-size:22px;color:#063B52}.holidayName{display:block;font-size:12px;font-weight:900;color:#64748b}
.holidayCheck{display:flex!important;align-items:center;gap:6px;font-size:12px!important;font-weight:900!important;color:#0f172a!important;margin:0!important}.holidayCheck input{width:20px;height:20px}.holidayMeta{display:flex;flex-wrap:wrap;gap:6px;margin:8px 0}.holidayMeta span{background:#fff;border:1px solid #D8E2EA;border-radius:999px;padding:4px 7px;font-size:11px;font-weight:900;color:#334155}
.holidayEditGrid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.holidayEditGrid label{margin:0!important;font-size:12px!important;font-weight:900!important;color:#64748b!important}.holidayEditGrid input,.holidayEditGrid textarea{width:100%;margin-top:4px!important;border:1px solid #D8E2EA;border-radius:12px;padding:8px;background:#fff;color:#0f172a;font-size:13px}.holidayObs{grid-column:1/-1}.holidayCardActions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:8px}.holidayCardActions button{margin:0!important;padding:8px!important;font-size:12px!important;border-radius:12px!important}
.errorBox{color:#991b1b;font-weight:900;background:#fff7ed!important;border-color:#fed7aa!important}
@media(max-width:720px){.holidaySummaryGrid{grid-template-columns:repeat(2,minmax(0,1fr))}.holidayActions,.holidayZoneActions,.holidayCards,.holidayEditGrid,.holidayCardActions{grid-template-columns:1fr}.holidayHero h2{font-size:22px}}

/* v12.5 Especial hoteles */
.especialHotelGrid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.especialHotelCard{
  text-align:left;
  background:linear-gradient(135deg,#EAF7FC,#fff);
  border:1px solid #8AD7EF;
  border-radius:20px;
  padding:16px;
  box-shadow:0 6px 18px rgba(2,6,23,.06);
  color:#0f172a;
}
.especialHotelCard b{
  display:block;
  color:#063B52;
  font-size:18px;
  margin-bottom:6px;
}
.especialHotelCard span{
  display:block;
  font-weight:900;
  margin-bottom:6px;
}
.especialHotelCard small{
  color:#64748b;
  font-weight:800;
}
.hotelHero{
  background:linear-gradient(135deg,#EAF7FC,#fff);
  border:1px solid #8AD7EF;
  border-radius:22px;
  padding:16px;
  margin-bottom:12px;
}
.hotelHero h2{
  margin:0;
  color:#063B52;
  font-size:26px;
  line-height:1.1;
}
.hotelHero p{margin:6px 0 2px;font-weight:900}
.hotelHero small{color:#64748b;font-weight:800}
.hotelSummaryGrid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:8px;
  margin-bottom:10px;
}
.hotelSummaryCard{
  background:#fff;
  border:1px solid #D8E2EA;
  border-radius:16px;
  padding:10px;
}
.hotelSummaryCard span{display:block;font-size:11px;font-weight:900;color:#64748b}
.hotelSummaryCard b{display:block;margin-top:3px;color:#063B52;font-size:18px}
.hotelActions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
.hotelActions button{margin:0!important;border-radius:14px!important}
.hotelTabs{
  display:flex;
  gap:8px;
  overflow-x:auto;
  padding:4px 0 10px;
}
.occidentalZoneTab{
  flex:0 0 auto;
  border:0;
  border-radius:999px;
  padding:10px 14px;
  font-weight:900;
  background:#E8EEF3;
  color:#0f172a;
}
.occidentalZoneTab.active{background:#00A6D6;color:#fff}
.hotelZoneBlock{
  border:1px solid #D8E2EA;
  border-radius:18px;
  background:#fff;
  margin-bottom:10px;
  overflow:hidden;
}
.hotelZoneBlock summary{
  cursor:pointer;
  padding:12px 14px;
  background:#EAF7FC;
  color:#063B52;
  font-weight:950;
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-size:18px;
}
.hotelZoneActions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  padding:10px;
}
.hotelZoneActions button{margin:0!important;border-radius:12px!important;font-size:13px!important}
.hotelQuickGrid,.holidayCards{
  display:grid!important;
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
  gap:8px!important;
  padding:10px!important;
}
.hotelQuickCard{
  min-height:86px;
  border:1px solid #D8E2EA;
  border-radius:16px;
  padding:9px;
  text-align:center;
  display:grid;
  place-items:center;
  gap:2px;
  background:#fff7ed;
  color:#0f172a;
}
.hotelQuickCard b{font-size:21px;color:#063B52}
.hotelQuickCard span{font-size:11px;font-weight:900;color:#64748b}
.hotelQuickCard small{font-size:11px;font-weight:900}
.hotelQuickCard em{
  font-style:normal;
  font-size:10px;
  background:#fde68a;
  border-radius:999px;
  padding:2px 5px;
}
.hotelQuickCard.done{
  background:#dcfce7;
  border-color:#86efac;
}
.hotelQuickCard.pending{
  background:#fff7ed;
  border-color:#fed7aa;
}
@media(max-width:720px){
  .especialHotelGrid,.hotelSummaryGrid{grid-template-columns:1fr}
  .hotelActions,.hotelZoneActions{grid-template-columns:1fr}
  .hotelQuickGrid,.holidayCards{grid-template-columns:repeat(2,minmax(0,1fr))!important}
  .hotelHero h2{font-size:22px}
}

/* v12.8 Occidental: selector estable y zonas comunes corregidas */
.occidentalTabsExpanded{
  gap:7px!important;
  padding-bottom:12px!important;
}
.occidentalTabsExpanded .occidentalZoneTab{
  white-space:nowrap!important;
}
.hotelZoneBlock.singleZone{
  display:block!important;
}
.hotelZoneBlock.singleZone > summary{
  list-style:none!important;
}
.hotelZoneBlock.singleZone > summary::-webkit-details-marker{
  display:none!important;
}
.hotelQuickCard{
  touch-action:manipulation!important;
}
@media(max-width:720px){
  .occidentalTabsExpanded .occidentalZoneTab{
    padding:9px 12px!important;
    font-size:12px!important;
  }
}

/* v13.0 Enviar PDF hoteles */
.hotelActions,
.holidayActions{
  grid-template-columns:repeat(4,minmax(0,1fr))!important;
}
#btnHolidaySendPdf,
#btnOccidentalSendPdf{
  background:#16a34a!important;
  color:#fff!important;
}
@media(max-width:720px){
  .hotelActions,
  .holidayActions{
    grid-template-columns:1fr 1fr!important;
  }
}

/* v13.2 Fix selector plantas Occidental */
#occidentalTabs{
  display:flex!important;
  gap:8px!important;
  overflow-x:auto!important;
  overflow-y:hidden!important;
  padding:6px 0 12px!important;
  -webkit-overflow-scrolling:touch!important;
  scrollbar-width:thin;
}
#occidentalTabs .occidentalZoneTab{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  flex:0 0 auto!important;
  min-width:max-content!important;
  max-width:none!important;
}

/* v13.3 Selector Occidental visible */
.occidentalSelectorBox{
  background:#fff;
  border:1px solid #D8E2EA;
  border-radius:18px;
  padding:10px;
  margin:10px 0;
}
.occidentalSelectorBox label{
  display:block;
  font-size:12px;
  font-weight:900;
  color:#063B52;
  margin-bottom:8px;
}
#occidentalZoneSelect{
  width:100%;
  margin-top:5px;
  border:1px solid #D8E2EA;
  border-radius:14px;
  padding:11px;
  font-size:15px;
  font-weight:900;
  background:#F8FBFC;
  color:#0f172a;
}
#occidentalTabs{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:7px!important;
  overflow:visible!important;
  padding:0!important;
}
#occidentalTabs .occidentalZoneTab{
  width:100%!important;
  min-width:0!important;
  max-width:none!important;
  white-space:normal!important;
  min-height:42px!important;
  padding:9px 8px!important;
  line-height:1.1!important;
  border-radius:14px!important;
}
@media(min-width:760px){
  #occidentalTabs{
    grid-template-columns:repeat(4,minmax(0,1fr))!important;
  }
}

/* v13.4 Zonas comunes unificadas */
.hotelQuickCard b{
  word-break:break-word!important;
}

/* v13.5 Fix marcar planta/zona y PDF */
.hotelZoneActions button{
  touch-action:manipulation!important;
}

/* v13.6 Botones fijos selección Occidental */
.occidentalFixedActions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  margin-top:10px;
}
.occidentalFixedActions button{
  margin:0!important;
  border-radius:14px!important;
  min-height:44px!important;
}
.occidentalFixedActions button:first-child{
  background:#16a34a!important;
  color:#fff!important;
}
@media(max-width:720px){
  .occidentalFixedActions{
    grid-template-columns:1fr!important;
  }
}

/* v13.7 Mantener marcadas y exportación fiable */
.occidentalKeepBox,
.holidayKeepBox{
  border:1px solid #D8E2EA;
  border-radius:18px;
  background:#fff;
  padding:10px;
  margin:10px 0;
}
.switchLine{
  display:flex!important;
  align-items:center;
  gap:9px;
  font-weight:900!important;
  color:#063B52!important;
  margin:0 0 10px!important;
  font-size:13px!important;
}
.switchLine input{
  width:20px;
  height:20px;
}
.occidentalKeepBox .danger,
.holidayKeepBox .danger{
  width:100%;
  margin:0!important;
  border-radius:14px!important;
  background:#fee2e2!important;
  color:#991b1b!important;
}
#btnHolidaySendPdf,
#btnOccidentalSendPdf{
  background:#15803d!important;
  color:#fff!important;
}

/* v13.9 Occidental selector estable y visible */
.occidentalSelectorBox{
  display:block!important;
  background:#fff!important;
  border:1px solid #D8E2EA!important;
  border-radius:18px!important;
  padding:10px!important;
  margin:10px 0!important;
}
#occidentalZoneSelect{
  display:block!important;
  width:100%!important;
  min-height:46px!important;
  border:1px solid #D8E2EA!important;
  border-radius:14px!important;
  padding:10px!important;
  font-size:16px!important;
  font-weight:900!important;
  background:#F8FBFC!important;
  color:#0f172a!important;
}
#occidentalTabs{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:8px!important;
  margin-top:10px!important;
  overflow:visible!important;
}
#occidentalTabs .occidentalZoneTab{
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  width:100%!important;
  min-height:42px!important;
  white-space:normal!important;
  border-radius:14px!important;
  padding:8px!important;
}
.occidentalFixedActions{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:8px!important;
  margin-top:10px!important;
}
.occidentalFixedActions button{
  margin:0!important;
  min-height:44px!important;
  border-radius:14px!important;
}
.occidentalFixedActions button:first-child{
  background:#16a34a!important;
  color:#fff!important;
}
.hotelZoneBlock.singleZone > summary{
  list-style:none!important;
}
.emptyBox{
  grid-column:1/-1;
  padding:14px;
  border-radius:14px;
  background:#fff7ed;
  color:#991b1b;
  font-weight:900;
}
@media(min-width:760px){
  #occidentalTabs{ grid-template-columns:repeat(3,minmax(0,1fr))!important; }
}
@media(max-width:720px){
  .occidentalFixedActions{ grid-template-columns:1fr!important; }
}

/* v14.0 Occidental rehecho */
.v140Box{
  display:block!important;
  background:#fff!important;
  border:2px solid #8AD7EF!important;
}
#occidentalZoneSelect{
  display:block!important;
  width:100%!important;
  min-height:50px!important;
  font-size:17px!important;
  font-weight:900!important;
  color:#0f172a!important;
  background:#fff!important;
  border:2px solid #00A6D6!important;
  border-radius:14px!important;
  padding:10px!important;
}
#occidentalTabs{
  display:grid!important;
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
  gap:8px!important;
  overflow:visible!important;
  margin-top:10px!important;
  padding:0!important;
}
#occidentalTabs .occidentalZoneTab{
  width:100%!important;
  min-height:42px!important;
  border-radius:14px!important;
  white-space:normal!important;
  font-weight:900!important;
}
#occidentalTabs .occidentalZoneTab.active{
  background:#00A6D6!important;
  color:#fff!important;
}
.occidentalFixedActions{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:8px!important;
  margin-top:10px!important;
}
.occidentalFixedActions button{
  min-height:46px!important;
  margin:0!important;
  border-radius:14px!important;
}
.occidentalFixedActions button:first-child{
  background:#16a34a!important;
  color:#fff!important;
}
@media(max-width:720px){
  #occidentalTabs{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
  }
  .occidentalFixedActions{
    grid-template-columns:1fr!important;
  }
}

/* v14.1 Occidental simple */
#occidentalZones .hotelZoneActions{
  display:none!important;
}
#btnOccidentalSendPdf{
  background:#15803d!important;
  color:#fff!important;
}

/* v14.2 zonas comunes repetibles */
#occidentalZones .hotelQuickCard.done small{
  font-weight:900!important;
}
#occidentalZones .hotelQuickCard.pending small{
  font-weight:900!important;
}

/* v14.5 Telegram fin de trabajo */
#telegramWorkerUrl{
  width:100%;
  border:1px solid #D8E2EA;
  border-radius:14px;
  padding:10px;
  font-size:15px;
}
#btnSaveTelegramSettings,
#btnTestTelegram{
  margin-top:8px!important;
}

/* v15.0 Frecuencias */
.frecuenciaHero{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.frecuenciaHero h3{margin:0 0 4px;color:#063B52;}
.frecuenciaHero p{margin:0;color:#64748b;font-size:13px;}
.freqActions{display:flex;gap:8px;flex-wrap:wrap;}
.freqKpis{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:8px;
  margin:10px 0;
}
.freqKpi{
  background:#fff;
  border:1px solid #D8E2EA;
  border-radius:16px;
  padding:10px;
}
.freqKpi span{display:block;font-size:11px;color:#64748b;font-weight:800;text-transform:uppercase;}
.freqKpi b{display:block;font-size:22px;color:#063B52;margin-top:3px;}
.freqKpi.ok b{color:#15803d;}
.freqKpi.pending b{color:#b45309;}
.freqFilters{
  display:grid;
  grid-template-columns:2fr 1fr;
  gap:10px;
}
.freqFilters input,.freqFilters select{
  width:100%;
  border:1px solid #D8E2EA;
  border-radius:14px;
  padding:10px;
  font-size:15px;
}
.frecuenciasLista{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.freqClientCard{
  background:#fff;
  border:1px solid #D8E2EA;
  border-radius:18px;
  padding:0;
  overflow:hidden;
}
.freqClientCard summary{
  display:flex;
  justify-content:space-between;
  gap:10px;
  align-items:center;
  padding:12px;
  cursor:pointer;
}
.freqClientCard summary b{display:block;color:#063B52;font-size:15px;}
.freqClientCard summary span{display:block;color:#64748b;font-size:12px;margin-top:2px;}
.freqPendingText{color:#b45309;font-size:12px;white-space:nowrap;}
.freqOkText{color:#15803d;font-size:12px;white-space:nowrap;}
.freqMonths{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
  padding:0 12px 12px;
}
.freqMonth{
  border:1px solid #E2E8F0;
  border-radius:14px;
  padding:8px;
  background:#F8FBFC;
}
.freqMonth h4{
  margin:0 0 6px;
  font-size:11px;
  color:#334155;
  text-transform:uppercase;
}
.freqDots{display:flex;gap:5px;flex-wrap:wrap;}
.freqDot{
  width:26px;
  height:26px;
  border-radius:999px;
  border:2px solid #CBD5E1;
  background:#fff;
  color:#475569;
  font-size:10px;
  font-weight:900;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0;
}
.freqDot.done.previo{
  background:#DBEAFE;
  border-color:#60A5FA;
  color:#1D4ED8;
}
.freqDot.done.app{
  background:#DCFCE7;
  border-color:#22C55E;
  color:#166534;
}
.freqDot.pending{
  background:#fff;
  border-color:#CBD5E1;
  color:#94A3B8;
}
@media(max-width:720px){
  .frecuenciaHero{align-items:stretch;flex-direction:column;}
  .freqKpis{grid-template-columns:repeat(2,minmax(0,1fr));}
  .freqFilters{grid-template-columns:1fr;}
  .freqMonths{grid-template-columns:1fr;}
}

/* v15.2 Frecuencias pendientes por mes */
.frecuenciasPendientesBox{
  border:2px solid #8AD7EF!important;
}
.freqMonthControls{
  display:grid;
  grid-template-columns:1fr auto auto;
  gap:8px;
  align-items:end;
}
.freqMonthControls label{
  font-weight:900;
  color:#063B52;
}
#frecuenciasMesPendientes{
  width:100%;
  min-height:44px;
  border:1px solid #D8E2EA;
  border-radius:14px;
  padding:10px;
  font-weight:900;
  background:#fff;
}
.freqPendingSummary{
  margin-top:10px;
  padding:10px;
  background:#EAF7FC;
  border-radius:14px;
  color:#063B52;
  font-weight:800;
}
.freqPendingSummary span{
  display:block;
  font-size:12px;
  margin-top:4px;
  color:#475569;
}
.freqPendingList{
  display:grid;
  gap:8px;
  margin-top:10px;
}
.freqPendingItem{
  display:grid;
  grid-template-columns:1fr auto;
  gap:8px;
  align-items:center;
  border:1px solid #D8E2EA;
  border-radius:16px;
  padding:10px;
  background:#fff;
}
.freqPendingItem b{
  display:block;
  color:#0f172a;
}
.freqPendingItem small,
.freqPendingItem span{
  display:block;
  font-size:12px;
  color:#475569;
  margin-top:2px;
}
.freqPendingItem button{
  min-height:40px;
  border-radius:13px!important;
  background:#16a34a!important;
  color:#fff!important;
}
.freqPendingEmpty{
  padding:14px;
  border-radius:14px;
  background:#fff7ed;
  color:#991b1b;
  font-weight:900;
}
@media(max-width:720px){
  .freqMonthControls{
    grid-template-columns:1fr;
  }
  .freqPendingItem{
    grid-template-columns:1fr;
  }
}

/* v15.3 Frecuencias: meses desplegables */
.freqMonthTopActions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  margin-top:8px;
}
.freqMonthsAccordion{
  display:grid;
  gap:10px;
  margin-top:12px;
}
.freqMonthDetail{
  border:1px solid #D8E2EA;
  border-radius:18px;
  background:#fff;
  overflow:hidden;
}
.freqMonthDetail summary{
  display:grid;
  grid-template-columns:1fr auto;
  gap:4px 10px;
  align-items:center;
  padding:13px;
  cursor:pointer;
  list-style:none;
}
.freqMonthDetail summary::-webkit-details-marker{
  display:none;
}
.freqMonthDetail summary span{
  font-weight:1000;
  color:#063B52;
  font-size:16px;
}
.freqMonthDetail summary b{
  padding:6px 9px;
  border-radius:999px;
  font-size:12px;
  background:#EAF7FC;
  color:#063B52;
}
.freqMonthDetail summary small{
  grid-column:1/-1;
  color:#64748b;
  font-weight:800;
}
.freqMonthDetail.pending summary b{
  background:#fff7ed;
  color:#c2410c;
}
.freqMonthDetail.ok summary b{
  background:#dcfce7;
  color:#166534;
}
.freqMonthDetail.closed summary b{
  background:#e0e7ff;
  color:#3730a3;
}
.freqMonthClosed{
  margin:0 12px 12px;
  padding:12px;
  border-radius:14px;
  background:#e0e7ff;
  color:#3730a3;
  font-weight:900;
}
.freqMonthClients{
  display:grid;
  gap:8px;
  padding:0 12px 12px;
}
.freqMonthClient{
  border:1px solid #E2E8F0;
  border-radius:16px;
  padding:10px;
  background:#F8FBFC;
}
.freqMonthClientHead{
  display:grid;
  grid-template-columns:1fr auto;
  gap:8px;
  align-items:start;
}
.freqMonthClientHead b{
  display:block;
  color:#0f172a;
}
.freqMonthClientHead small{
  display:block;
  color:#64748b;
  font-size:12px;
  margin-top:2px;
}
.freqMonthClientHead strong{
  padding:6px 8px;
  border-radius:999px;
  background:#fee2e2;
  color:#991b1b;
  font-size:12px;
}
.freqMonthCircles{
  display:flex;
  flex-wrap:wrap;
  gap:7px;
  margin-top:8px;
}
.freqPendingCircle{
  width:34px!important;
  height:34px!important;
  min-height:34px!important;
  padding:0!important;
  border-radius:999px!important;
  background:#fff!important;
  border:2px solid #f97316!important;
  color:#9a3412!important;
  font-weight:1000!important;
}
.freqMonthActions{
  margin-top:8px;
}
.freqMonthActions button{
  width:100%;
  min-height:38px;
  border-radius:13px!important;
  background:#16a34a!important;
  color:#fff!important;
}
@media(max-width:720px){
  .freqMonthTopActions{
    grid-template-columns:1fr;
  }
  .freqMonthClientHead{
    grid-template-columns:1fr;
  }
}

/* v15.4 Frecuencias por municipios */
.freqMunicipiosList{
  display:grid;
  gap:9px;
  padding:0 12px 12px;
}
.freqMunicipioDetail{
  border:1px solid #BFEAF6;
  border-radius:16px;
  background:#F8FBFC;
  overflow:hidden;
}
.freqMunicipioDetail summary{
  display:grid;
  grid-template-columns:1fr auto;
  gap:3px 8px;
  align-items:center;
  padding:11px;
  cursor:pointer;
  list-style:none;
  background:#EAF7FC;
}
.freqMunicipioDetail summary::-webkit-details-marker{
  display:none;
}
.freqMunicipioDetail summary span{
  font-weight:1000;
  color:#063B52;
}
.freqMunicipioDetail summary b{
  padding:5px 8px;
  border-radius:999px;
  background:#fff7ed;
  color:#c2410c;
  font-size:12px;
}
.freqMunicipioDetail summary small{
  grid-column:1/-1;
  color:#64748b;
  font-weight:800;
  font-size:12px;
}
.freqMunicipioDetail .freqMonthClients{
  padding:10px;
}

/* v15.5 Frecuencias: municipios > centros > colocar en trabajos */
.freqMunicipioDetail{
  margin-bottom:8px;
}
.freqCentroDetail{
  border:1px solid #E2E8F0;
  border-radius:15px;
  background:#fff;
  overflow:hidden;
  margin:8px 0;
}
.freqCentroDetail summary{
  display:grid;
  grid-template-columns:1fr auto;
  gap:4px 8px;
  align-items:center;
  padding:10px;
  cursor:pointer;
  list-style:none;
}
.freqCentroDetail summary::-webkit-details-marker{
  display:none;
}
.freqCentroDetail summary span{
  font-weight:1000;
  color:#0f172a;
}
.freqCentroDetail summary b{
  padding:5px 8px;
  border-radius:999px;
  background:#fee2e2;
  color:#991b1b;
  font-size:12px;
}
.freqCentroDetail summary small{
  grid-column:1/-1;
  color:#64748b;
  font-size:12px;
  font-weight:800;
}
.freqCentroBody{
  padding:0 10px 10px;
}
.freqTrabajoPlanner{
  display:grid;
  grid-template-columns:1fr 1fr auto;
  gap:8px;
  align-items:end;
  margin-top:8px;
  padding:9px;
  background:#F8FBFC;
  border-radius:14px;
  border:1px solid #D8E2EA;
}
.freqTrabajoPlanner label{
  font-size:12px;
  font-weight:900;
  color:#063B52;
}
.freqTrabajoPlanner input,
.freqTrabajoPlanner select{
  width:100%;
  min-height:38px;
  border:1px solid #D8E2EA;
  border-radius:12px;
  padding:7px;
  background:#fff;
  font-weight:800;
}
.freqTrabajoPlanner button{
  min-height:38px;
  border-radius:12px!important;
  background:#00A6D6!important;
  color:#fff!important;
}
@media(max-width:720px){
  .freqTrabajoPlanner{
    grid-template-columns:1fr;
  }
}

/* v15.7 Municipios corregidos por bloques reales */
.freqMunicipioDetail summary span{
  text-transform:none;
}

/* v15.11 Frecuencias: hechos y colocados por mes */
.freqSectionTitle{
  margin:10px 12px 6px;
  font-weight:1000;
  color:#063B52;
  font-size:13px;
}
.freqMonthStatusBlock{
  margin:10px 12px 12px;
  border:1px solid #D8E2EA;
  border-radius:15px;
  background:#fff;
  overflow:hidden;
}
.freqMonthStatusBlock summary{
  display:grid;
  grid-template-columns:1fr auto;
  gap:8px;
  align-items:center;
  padding:10px;
  cursor:pointer;
  list-style:none;
  background:#F8FBFC;
}
.freqMonthStatusBlock summary::-webkit-details-marker{
  display:none;
}
.freqMonthStatusBlock summary span{
  font-weight:1000;
  color:#063B52;
}
.freqMonthStatusBlock summary b{
  padding:5px 8px;
  border-radius:999px;
  background:#EAF7FC;
  color:#063B52;
}
.freqStatusList{
  display:grid;
  gap:8px;
  padding:10px;
}
.freqStatusMunicipio{
  border:1px solid #E2E8F0;
  border-radius:14px;
  overflow:hidden;
  background:#fff;
}
.freqStatusMunicipio summary{
  background:#EAF7FC;
}
.freqStatusMunicipio summary small{
  grid-column:1/-1;
  color:#64748b;
  font-size:12px;
}
.freqStatusRows{
  display:grid;
  gap:6px;
  padding:8px;
}
.freqStatusRow{
  border-radius:12px;
  padding:8px;
  border:1px solid #E2E8F0;
}
.freqStatusRow.done{
  background:#ecfdf5;
  border-color:#bbf7d0;
}
.freqStatusRow.placed{
  background:#eff6ff;
  border-color:#bfdbfe;
}
.freqStatusRow b{
  display:block;
  color:#0f172a;
}
.freqStatusRow small,
.freqStatusRow span{
  display:block;
  color:#475569;
  font-size:12px;
  margin-top:2px;
}
.freqDoneEmpty,
.freqPlacedEmpty{
  margin:10px;
  padding:12px;
  border-radius:14px;
  background:#F8FBFC;
  color:#64748b;
  font-weight:900;
}

/* v15.12 Frecuencias: programado y municipio completo */
.freqMonthKpis{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:8px;
  padding:10px 12px;
}
.freqMonthKpis span{
  display:block;
  padding:9px;
  border-radius:14px;
  background:#F8FBFC;
  border:1px solid #D8E2EA;
  font-size:12px;
  font-weight:900;
  color:#475569;
}
.freqMonthKpis b{
  display:block;
  color:#063B52;
  font-size:18px;
  margin-top:2px;
}
.freqProgramadoBox{
  margin:0 0 8px;
  padding:9px;
  border-radius:13px;
  background:#dbeafe;
  color:#1d4ed8;
  font-weight:900;
  font-size:12px;
}
.freqMunicipioPlanner{
  display:grid;
  grid-template-columns:1fr 1fr auto;
  gap:8px;
  align-items:end;
  padding:10px;
  background:#ffffff;
  border-bottom:1px solid #D8E2EA;
}
.freqMunicipioPlanner label{
  font-size:12px;
  font-weight:900;
  color:#063B52;
}
.freqMunicipioPlanner input,
.freqMunicipioPlanner select{
  width:100%;
  min-height:38px;
  border:1px solid #D8E2EA;
  border-radius:12px;
  padding:7px;
  background:#fff;
  font-weight:800;
}
.freqMunicipioPlanner button{
  min-height:38px;
  border-radius:12px!important;
  background:#0f766e!important;
  color:#fff!important;
}
@media(max-width:720px){
  .freqMonthKpis{
    grid-template-columns:repeat(2,1fr);
  }
  .freqMunicipioPlanner{
    grid-template-columns:1fr;
  }
}

/* v15.13 Fix programados */
.freqProgramadoBox{border:1px solid #93c5fd!important;}

/* v15.14 Operario Todos */
.freqTrabajoPlanner select option[value="Todos"],
.freqMunicipioPlanner select option[value="Todos"]{
  font-weight:1000;
}

/* v15.16 Mensajes lectura fix */
.mensajesTopActions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  margin-bottom:10px;
}
.mensajeThreadDetails{
  border:1px solid #D8E2EA;
  border-radius:16px;
  background:#fff;
  overflow:hidden;
  margin-bottom:10px;
}
.mensajeThreadDetails summary{
  display:grid;
  grid-template-columns:1fr auto;
  gap:8px;
  align-items:center;
  padding:12px;
  cursor:pointer;
  background:#EAF7FC;
  list-style:none;
}
.mensajeThreadDetails summary::-webkit-details-marker{
  display:none;
}
.mensajeThreadDetails summary span{
  font-weight:1000;
  color:#063B52;
}
.mensajeThreadDetails summary b{
  font-size:12px;
  color:#063B52;
}
.mensajeThreadBody{
  display:flex;
  flex-direction:column;
  gap:8px;
  padding:10px;
  background:#f8fafc;
}
.mensajeThreadWorker{
  border:1px solid #D8E2EA;
  border-radius:16px;
}
.mensajeUnread{
  border:2px solid #f97316!important;
}
.mensajeReadLine{
  margin-top:6px;
  font-size:12px;
  font-weight:900;
  color:#64748b;
}
.mensajeReadBtn{
  margin-top:8px;
  width:100%;
}
@media(max-width:720px){
  .mensajesTopActions{
    grid-template-columns:1fr;
  }
}

/* v15.17 Frecuencias multiselección */
.freqBulkPanel{
  display:grid;
  grid-template-columns:1.2fr 1fr 1fr auto auto;
  gap:8px;
  align-items:end;
  padding:10px 12px;
  border-bottom:1px solid #D8E2EA;
  background:#F8FBFC;
}
.freqBulkPanel b{
  display:block;
  color:#063B52;
  font-weight:1000;
}
.freqBulkPanel small{
  display:block;
  color:#64748b;
  font-weight:900;
}
.freqBulkPanel label{
  font-size:12px;
  font-weight:900;
  color:#063B52;
}
.freqBulkPanel input,
.freqBulkPanel select{
  width:100%;
  min-height:38px;
  border:1px solid #D8E2EA;
  border-radius:12px;
  padding:7px;
  background:#fff;
  font-weight:800;
}
.freqBulkPanel button{
  min-height:38px;
  border-radius:12px!important;
}
.freqBulkPanel button:disabled{
  opacity:.45;
}
.freqSelectCheck{
  display:flex;
  align-items:center;
  justify-content:center;
  width:34px;
  height:34px;
  border-radius:12px;
  background:#EAF7FC;
  border:1px solid #BFEAF6;
  cursor:pointer;
}
.freqSelectCheck input{
  width:20px;
  height:20px;
}
.freqCentroDetail summary{
  grid-template-columns:auto 1fr auto!important;
}
.freqCentroDetail summary small{
  grid-column:2/-1!important;
}
@media(max-width:720px){
  .freqBulkPanel{
    grid-template-columns:1fr;
  }
}

/* v15.19 Sacar de hechos + Excel visual */
.freqStatusRow{
  display:grid;
  grid-template-columns:1fr auto;
  gap:8px;
  align-items:center;
}
.freqStatusRow .miniExcelBtn{
  min-height:34px;
  padding:7px 10px!important;
  font-size:12px!important;
  border-radius:10px!important;
}
.freqExcelVisualBox{
  border:2px solid #ef4444;
  border-radius:18px;
  background:#fff;
  margin:12px 0;
  overflow:hidden;
}
.freqExcelVisualBox>summary{
  display:grid;
  grid-template-columns:1fr auto;
  gap:8px;
  padding:13px;
  cursor:pointer;
  background:#fff1f2;
  list-style:none;
}
.freqExcelVisualBox>summary::-webkit-details-marker,
.freqExcelOrigen>summary::-webkit-details-marker{
  display:none;
}
.freqExcelVisualBox>summary span,
.freqExcelOrigen>summary span{
  font-weight:1000;
  color:#991b1b;
}
.freqExcelVisualBox>summary b,
.freqExcelOrigen>summary b{
  font-size:12px;
  padding:5px 8px;
  border-radius:999px;
  background:#fee2e2;
  color:#991b1b;
}
.freqExcelLegend{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  padding:10px 13px;
  font-size:12px;
  font-weight:900;
  color:#475569;
}
.freqExcelLegend span{
  display:flex;
  align-items:center;
  gap:5px;
}
.legendCircle{
  width:18px;
  height:18px;
  border:2px solid #94a3b8;
  border-radius:999px;
  display:inline-block;
  position:relative;
}
.legendCircle.done{
  border-color:#ef4444;
}
.legendCircle.done:after,
.excelCircle.done:after{
  content:'';
  position:absolute;
  left:3px;
  right:3px;
  top:50%;
  height:2px;
  background:#ef4444;
  transform:rotate(-35deg);
}
.legendCircle.programmed{
  border-color:#2563eb;
  background:#dbeafe;
}
.freqExcelOrigen{
  margin:8px 10px 12px;
  border:1px solid #fecaca;
  border-radius:15px;
  overflow:hidden;
}
.freqExcelOrigen>summary{
  display:grid;
  grid-template-columns:1fr auto;
  padding:10px;
  background:#fff7f7;
  cursor:pointer;
  list-style:none;
}
.freqExcelTableWrap{
  max-height:420px;
  overflow:auto;
}
.freqExcelTable{
  width:100%;
  border-collapse:collapse;
  font-size:12px;
}
.freqExcelTable th{
  position:sticky;
  top:0;
  z-index:2;
  background:#991b1b;
  color:#fff;
  padding:8px;
  text-align:left;
}
.freqExcelTable td{
  border-bottom:1px solid #fee2e2;
  padding:7px;
  vertical-align:top;
}
.excelCircleWrap{
  display:flex;
  flex-wrap:wrap;
  gap:4px;
  min-width:160px;
}
.excelCircle{
  width:24px;
  height:24px;
  border-radius:999px;
  border:2px solid #94a3b8;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:10px;
  font-weight:900;
  position:relative;
  background:#fff;
  color:#64748b;
}
.excelCircle.done{
  border-color:#ef4444;
  color:#ef4444;
  background:#fff1f2;
}
.excelCircle.programmed{
  border-color:#2563eb;
  background:#dbeafe;
  color:#1d4ed8;
}
@media(max-width:720px){
  .freqStatusRow{
    grid-template-columns:1fr;
  }
  .freqExcelTable{
    font-size:11px;
  }
  .excelCircle{
    width:22px;
    height:22px;
  }
}

/* v15.20 */
.freqBulkPanel .btnFreqBulkProgramar,.freqBulkPanel .btnFreqBulkClear{min-height:38px;}

/* v15.22 Excel visual premium */
.freqExcelVisualBox{
  border:1px solid #cbd5e1;
  border-radius:20px;
  background:linear-gradient(180deg,#ffffff 0%,#f8fbff 100%);
  overflow:hidden;
  box-shadow:0 8px 28px rgba(2,6,23,.06);
  margin:14px 0;
}
.freqExcelVisualBox>summary{
  list-style:none;
  cursor:pointer;
  padding:14px 16px;
  background:linear-gradient(135deg,#062e46 0%,#0b5877 100%);
  color:#fff;
}
.freqExcelVisualBox>summary::-webkit-details-marker,
.freqExcelOrigen>summary::-webkit-details-marker{
  display:none;
}
.freqExcelHero{
  display:grid;
  grid-template-columns:1fr auto;
  gap:14px;
  align-items:center;
}
.freqExcelEyebrow{
  display:inline-block;
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
  opacity:.8;
  margin-bottom:4px;
}
.freqExcelHero strong{
  display:block;
  font-size:20px;
  line-height:1.1;
  margin-bottom:4px;
}
.freqExcelHero small{
  display:block;
  max-width:620px;
  font-size:12px;
  line-height:1.4;
  opacity:.9;
}
.freqExcelHeroStats{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  justify-content:flex-end;
}
.freqExcelToolbar{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  padding:14px 16px 6px;
}
.freqStatPill{
  display:inline-flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:2px;
  min-width:68px;
  padding:8px 10px;
  border-radius:14px;
  background:#f1f5f9;
  color:#0f172a;
  border:1px solid #dbe2ea;
}
.freqStatPill b{
  font-size:16px;
  line-height:1;
  font-weight:1000;
}
.freqStatPill small{
  font-size:11px;
  font-weight:900;
  color:#475569;
  line-height:1.05;
}
.freqStatPill.dark{
  background:rgba(255,255,255,.12);
  border-color:rgba(255,255,255,.18);
  color:#fff;
}
.freqStatPill.dark small{ color:rgba(255,255,255,.9); }
.freqStatPill.done{ background:#fff1f2; border-color:#fecdd3; }
.freqStatPill.done b, .freqStatPill.done small{ color:#be123c; }
.freqStatPill.programmed{ background:#eff6ff; border-color:#bfdbfe; }
.freqStatPill.programmed b, .freqStatPill.programmed small{ color:#1d4ed8; }
.freqStatPill.pending{ background:#f8fafc; border-color:#cbd5e1; }
.freqStatPill.pending b, .freqStatPill.pending small{ color:#475569; }

.freqExcelLegend{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  padding:8px 16px 14px;
  color:#334155;
  font-size:12px;
  font-weight:900;
}
.freqExcelLegend span{ display:flex; align-items:center; gap:6px; }
.legendCircle{
  width:20px;
  height:20px;
  border:2px solid #94a3b8;
  border-radius:999px;
  position:relative;
  display:inline-block;
  background:#fff;
}
.legendCircle.done{
  border-color:#ef4444;
  background:#fff1f2;
}
.legendCircle.done:after,
.excelCircle.done:after{
  content:'';
  position:absolute;
  left:2px;
  right:2px;
  top:50%;
  height:3px;
  background:#ef4444;
  transform:rotate(-35deg);
  border-radius:999px;
}
.legendCircle.programmed{
  border-color:#2563eb;
  background:#dbeafe;
}
.legendCircle.programmed:before{
  content:'';
  position:absolute;
  inset:5px;
  background:#2563eb;
  border-radius:999px;
}

.freqExcelOriginStack{
  display:flex;
  flex-direction:column;
  gap:14px;
  padding:0 12px 14px;
}
.freqExcelOrigen{
  border:1px solid #dbe2ea;
  border-radius:18px;
  background:#fff;
  overflow:hidden;
}
.freqExcelOrigen>summary{
  list-style:none;
  cursor:pointer;
  padding:12px 14px;
  background:#f8fafc;
}
.freqExcelOrigenHead{
  display:grid;
  grid-template-columns:1fr auto;
  gap:12px;
  align-items:center;
}
.freqExcelOrigenTitle{
  display:block;
  font-size:16px;
  font-weight:1000;
  color:#063b52;
}
.freqExcelOrigenHead small{
  color:#64748b;
  font-size:12px;
  font-weight:900;
}
.freqExcelMiniStats{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  justify-content:flex-end;
}
.freqExcelMiniStats .freqStatPill{
  min-width:52px;
  padding:6px 8px;
  border-radius:12px;
}
.freqExcelMiniStats .freqStatPill b{ font-size:14px; }
.freqExcelMiniStats .freqStatPill small{ font-size:10px; }

.freqExcelMunicipiosGrid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(320px, 1fr));
  gap:12px;
  padding:12px;
  background:#f8fafc;
}
.freqExcelMunicipioCard{
  border:1px solid #dbe2ea;
  border-radius:18px;
  background:#fff;
  box-shadow:0 6px 18px rgba(15,23,42,.05);
  overflow:hidden;
}
.freqExcelMunicipioHead{
  display:grid;
  grid-template-columns:1fr auto;
  gap:10px;
  align-items:center;
  padding:12px 12px 10px;
  border-bottom:1px solid #eef2f7;
  background:linear-gradient(180deg,#ffffff 0%,#f8fbff 100%);
}
.freqExcelMunicipioHead strong{
  display:block;
  font-size:15px;
  color:#0f172a;
}
.freqExcelMunicipioHead small{
  color:#64748b;
  font-size:12px;
  font-weight:900;
}
.freqExcelClientList{
  display:flex;
  flex-direction:column;
  gap:10px;
  padding:10px;
}
.freqExcelClientCard{
  border:1px solid #e2e8f0;
  border-radius:16px;
  background:#fff;
  padding:10px;
}
.freqExcelClientHead{
  display:grid;
  grid-template-columns:1fr auto;
  gap:10px;
  align-items:start;
  margin-bottom:10px;
}
.freqExcelClientTitle strong{
  display:block;
  font-size:14px;
  color:#0f172a;
  line-height:1.2;
}
.freqExcelClientTitle small{
  display:block;
  margin-top:4px;
  color:#64748b;
  font-size:11px;
  font-weight:900;
  line-height:1.3;
}
.excelCircleBoard{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.excelCircle{
  position:relative;
  width:44px;
  height:44px;
  border-radius:999px;
  border:3px solid #94a3b8;
  background:#fff;
  display:inline-flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  line-height:1;
  box-shadow:0 3px 8px rgba(15,23,42,.05);
}
.excelCircle i{
  font-style:normal;
  font-size:9px;
  font-weight:1000;
  color:#64748b;
  text-transform:uppercase;
}
.excelCircle b{
  font-size:13px;
  font-weight:1000;
  color:#334155;
}
.excelCircle.pending{
  border-color:#94a3b8;
  background:#fff;
}
.excelCircle.programmed{
  border-color:#2563eb;
  background:linear-gradient(180deg,#eff6ff 0%,#dbeafe 100%);
}
.excelCircle.programmed b,
.excelCircle.programmed i{
  color:#1d4ed8;
}
.excelCircle.programmed:before{
  content:'';
  position:absolute;
  inset:7px;
  border-radius:999px;
  border:2px solid rgba(37,99,235,.25);
}
.excelCircle.done{
  border-color:#ef4444;
  background:linear-gradient(180deg,#fff1f2 0%,#ffe4e6 100%);
}
.excelCircle.done b,
.excelCircle.done i{
  color:#be123c;
}
@media (max-width: 720px){
  .freqExcelHero{
    grid-template-columns:1fr;
  }
  .freqExcelMunicipiosGrid{
    grid-template-columns:1fr;
  }
  .freqExcelClientHead,
  .freqExcelMunicipioHead,
  .freqExcelOrigenHead{
    grid-template-columns:1fr;
  }
  .freqExcelHero strong{
    font-size:18px;
  }
  .excelCircle{
    width:40px;
    height:40px;
  }
}

/* v15.23 Excel calendario real */
.freqExcelVisualBox{
  border:1px solid #cbd5e1;
  border-radius:20px;
  background:#fff;
  overflow:hidden;
  margin:14px 0;
  box-shadow:0 8px 28px rgba(2,6,23,.06);
}
.freqExcelVisualBox>summary{
  list-style:none;
  cursor:pointer;
  padding:14px 16px;
  background:linear-gradient(135deg,#062e46 0%,#0b5877 100%);
  color:#fff;
}
.freqExcelVisualBox>summary::-webkit-details-marker,
.freqExcelOrigenCalendar>summary::-webkit-details-marker{
  display:none;
}
.freqExcelHero{
  display:grid;
  grid-template-columns:1fr auto;
  gap:14px;
  align-items:center;
}
.freqExcelEyebrow{
  display:inline-block;
  font-size:11px;
  font-weight:1000;
  text-transform:uppercase;
  letter-spacing:.08em;
  opacity:.85;
}
.freqExcelHero strong{
  display:block;
  font-size:20px;
  margin-top:3px;
}
.freqExcelHero small{
  display:block;
  font-size:12px;
  opacity:.9;
  margin-top:4px;
}
.freqExcelHeroStats,.freqExcelMiniStats,.freqExcelToolbar{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  justify-content:flex-end;
}
.freqExcelToolbar{
  justify-content:flex-start;
  padding:14px 16px 4px;
}
.freqStatPill{
  display:inline-flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  min-width:64px;
  padding:7px 9px;
  border-radius:14px;
  border:1px solid #dbe2ea;
  background:#f8fafc;
}
.freqStatPill b{font-size:16px;line-height:1;font-weight:1000;color:#0f172a;}
.freqStatPill small{font-size:10px;font-weight:900;color:#475569;}
.freqStatPill.dark{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.25);}
.freqStatPill.dark b,.freqStatPill.dark small{color:#fff;}
.freqStatPill.done{background:#fff1f2;border-color:#fecdd3;}
.freqStatPill.done b,.freqStatPill.done small{color:#be123c;}
.freqStatPill.programmed{background:#eff6ff;border-color:#bfdbfe;}
.freqStatPill.programmed b,.freqStatPill.programmed small{color:#1d4ed8;}
.freqStatPill.pending{background:#f8fafc;border-color:#cbd5e1;}
.freqExcelLegend{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  padding:8px 16px 14px;
  font-size:12px;
  color:#334155;
  font-weight:900;
}
.freqExcelLegend span{display:flex;align-items:center;gap:6px;}
.legendCircle{
  width:20px;
  height:20px;
  border-radius:999px;
  border:2px solid #94a3b8;
  display:inline-block;
  position:relative;
  background:#fff;
}
.legendCircle.programmed{border-color:#2563eb;background:#dbeafe;}
.legendCircle.done{border-color:#ef4444;background:#fff1f2;}
.legendCircle.done:after,.excelDot.done:after{
  content:'';
  position:absolute;
  left:1px;
  right:1px;
  top:50%;
  height:3px;
  background:#ef4444;
  border-radius:999px;
  transform:rotate(-35deg);
}
.freqExcelOrigenCalendar{
  margin:10px 12px 16px;
  border:1px solid #dbe2ea;
  border-radius:18px;
  overflow:hidden;
  background:#fff;
}
.freqExcelOrigenCalendar>summary{
  list-style:none;
  padding:12px 14px;
  cursor:pointer;
  background:#f8fafc;
}
.freqExcelOrigenHead{
  display:grid;
  grid-template-columns:1fr auto;
  gap:12px;
  align-items:center;
}
.freqExcelOrigenTitle{
  display:block;
  font-size:16px;
  font-weight:1000;
  color:#063b52;
}
.freqExcelOrigenHead small{
  color:#64748b;
  font-size:12px;
  font-weight:900;
}
.freqCalendarScroll{
  overflow:auto;
  max-height:72vh;
  border-top:1px solid #e2e8f0;
}
.freqCalendarTable{
  width:max-content;
  min-width:100%;
  border-collapse:separate;
  border-spacing:0;
  font-size:12px;
}
.freqCalendarTable th{
  position:sticky;
  top:0;
  z-index:5;
  background:#0b5877;
  color:#fff;
  padding:9px 8px;
  text-align:center;
  border-right:1px solid rgba(255,255,255,.18);
  min-width:74px;
}
.freqCalendarTable th.stickyClient{
  left:0;
  z-index:7;
  text-align:left;
  min-width:260px;
}
.freqCalendarTable td{
  border-right:1px solid #e2e8f0;
  border-bottom:1px solid #e2e8f0;
  padding:6px;
  vertical-align:middle;
  background:#fff;
}
.freqCalendarTable .stickyClient{
  position:sticky;
  left:0;
  z-index:3;
  background:#fff;
  box-shadow:4px 0 8px rgba(15,23,42,.05);
}
.municipioHeaderRow td{
  position:sticky;
  left:0;
  z-index:4;
  background:#eaf7fc!important;
  color:#063b52;
  font-weight:1000;
  font-size:13px;
  padding:9px 10px;
  border-top:2px solid #bfeaf6;
}
.clientCell strong{
  display:block;
  max-width:250px;
  color:#0f172a;
  font-size:12px;
  line-height:1.2;
}
.clientCell small{
  display:block;
  color:#64748b;
  font-size:10px;
  margin-top:3px;
  font-weight:800;
}
.monthCell{
  min-width:74px;
  height:48px;
  text-align:center;
}
.monthCell.hasDots{
  background:#fffefa;
}
.monthDots{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  align-items:center;
  gap:4px;
  min-height:34px;
}
.excelDot{
  width:30px;
  height:30px;
  border-radius:999px;
  border:3px solid #94a3b8;
  background:#fff;
  color:#334155;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:11px;
  font-weight:1000;
  position:relative;
  box-shadow:0 2px 5px rgba(15,23,42,.07);
}
.excelDot.programmed{
  border-color:#2563eb;
  background:#dbeafe;
  color:#1d4ed8;
}
.excelDot.done{
  border-color:#ef4444;
  background:#fff1f2;
  color:#be123c;
}
@media(max-width:720px){
  .freqExcelHero,.freqExcelOrigenHead{
    grid-template-columns:1fr;
  }
  .freqCalendarTable th.stickyClient{
    min-width:210px;
  }
  .clientCell strong{
    max-width:200px;
  }
  .freqCalendarTable th,
  .monthCell{
    min-width:58px;
  }
  .excelDot{
    width:26px;
    height:26px;
    font-size:10px;
    border-width:2px;
  }
}

/* v15.24 Vista Excel mes a mes */
.freqExcelMonthTabs{
  display:flex;
  gap:7px;
  overflow-x:auto;
  padding:10px 14px;
  border-top:1px solid #e2e8f0;
  border-bottom:1px solid #e2e8f0;
  background:#f8fafc;
  -webkit-overflow-scrolling:touch;
}
.freqExcelMonthTabs button{
  flex:0 0 auto;
  min-width:62px;
  min-height:42px;
  border-radius:14px!important;
  border:1px solid #cbd5e1!important;
  background:#fff!important;
  color:#334155!important;
  font-weight:1000!important;
  font-size:13px!important;
}
.freqExcelMonthTabs button.active{
  background:#063b52!important;
  color:#fff!important;
  border-color:#063b52!important;
  box-shadow:0 4px 14px rgba(6,59,82,.25);
}
.freqExcelMesVista{
  padding:12px;
  background:#eef7fb;
}
.freqExcelMesHeader{
  display:grid;
  grid-template-columns:1fr auto;
  gap:12px;
  align-items:center;
  padding:14px;
  border-radius:18px;
  background:linear-gradient(135deg,#0b5877 0%,#063b52 100%);
  color:#fff;
  margin-bottom:12px;
}
.freqExcelMesHeader strong{
  display:block;
  font-size:24px;
  line-height:1.05;
}
.freqExcelMesHeader small{
  display:block;
  opacity:.9;
  font-weight:800;
  margin-top:4px;
}
.freqExcelMesOrigenStack{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.freqExcelMesOrigen{
  border:1px solid #cbd5e1;
  border-radius:18px;
  overflow:hidden;
  background:#fff;
}
.freqExcelMesOrigen>summary{
  list-style:none;
  cursor:pointer;
  display:grid;
  grid-template-columns:1fr auto;
  gap:8px;
  align-items:center;
  padding:12px;
  background:#fff;
}
.freqExcelMesOrigen>summary::-webkit-details-marker,
.freqExcelFullCalendar>summary::-webkit-details-marker{
  display:none;
}
.freqExcelMesOrigen>summary span{
  color:#063b52;
  font-weight:1000;
  font-size:15px;
}
.freqExcelMesOrigen>summary b{
  background:#eaf7fc;
  color:#063b52;
  border-radius:999px;
  padding:5px 9px;
  font-size:12px;
}
.freqExcelMesMunicipios{
  display:flex;
  flex-direction:column;
  gap:10px;
  padding:10px;
  background:#f8fafc;
}
.freqExcelMesMunicipio{
  border:1px solid #dbe2ea;
  border-radius:16px;
  background:#fff;
  overflow:hidden;
}
.freqExcelMesMunicipio header{
  display:grid;
  grid-template-columns:1fr auto;
  gap:8px;
  align-items:center;
  padding:10px 12px;
  background:#f1f5f9;
  border-bottom:1px solid #e2e8f0;
}
.freqExcelMesMunicipio header strong{
  color:#0f172a;
  font-size:14px;
}
.freqExcelMesMunicipio header small{
  color:#64748b;
  font-weight:900;
  font-size:12px;
}
.freqExcelMesCards{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:10px;
  padding:10px;
}
.freqExcelMesCard{
  border:1px solid #dbe2ea;
  border-radius:16px;
  background:#fff;
  padding:12px;
}
.freqExcelMesCard.hasPending{
  border-left:6px solid #94a3b8;
}
.freqExcelMesCard.allDone{
  border-left:6px solid #ef4444;
}
.freqExcelMesCardTop{
  display:grid;
  grid-template-columns:1fr auto;
  gap:8px;
  margin-bottom:10px;
}
.freqExcelMesCardTop strong{
  display:block;
  color:#0f172a;
  font-size:14px;
  line-height:1.2;
}
.freqExcelMesCardTop small{
  display:block;
  color:#64748b;
  font-size:11px;
  font-weight:900;
  margin-top:4px;
}
.freqExcelMesCardStats{
  display:flex;
  flex-direction:column;
  gap:4px;
  align-items:flex-end;
}
.freqExcelMesCardStats span{
  border-radius:999px;
  padding:3px 7px;
  font-size:11px;
  font-weight:1000;
  white-space:nowrap;
}
.freqExcelMesCardStats .done{background:#fff1f2;color:#be123c;}
.freqExcelMesCardStats .programmed{background:#eff6ff;color:#1d4ed8;}
.freqExcelMesCardStats .pending{background:#f1f5f9;color:#475569;}
.freqExcelMesDots{
  display:flex;
  flex-wrap:wrap;
  gap:9px;
}
.excelDotBig{
  width:48px;
  height:48px;
  border-radius:999px;
  border:4px solid #94a3b8;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:#fff;
  color:#334155;
  font-weight:1000;
  position:relative;
  box-shadow:0 4px 10px rgba(15,23,42,.08);
}
.excelDotBig b{
  font-size:15px;
  z-index:1;
}
.excelDotBig.programmed{
  border-color:#2563eb;
  background:#dbeafe;
  color:#1d4ed8;
}
.excelDotBig.done{
  border-color:#ef4444;
  background:#fff1f2;
  color:#be123c;
}
.excelDotBig.done:after{
  content:'';
  position:absolute;
  left:3px;
  right:3px;
  top:50%;
  height:4px;
  background:#ef4444;
  border-radius:999px;
  transform:rotate(-35deg);
}
.freqExcelFullCalendar{
  margin:12px;
  border:1px solid #cbd5e1;
  border-radius:18px;
  overflow:hidden;
  background:#fff;
}
.freqExcelFullCalendar>summary{
  list-style:none;
  cursor:pointer;
  display:grid;
  grid-template-columns:1fr auto;
  gap:8px;
  padding:12px;
  background:#f8fafc;
}
.freqExcelFullCalendar>summary span{
  font-weight:1000;
  color:#063b52;
}
.freqExcelFullCalendar>summary b{
  background:#eaf7fc;
  color:#063b52;
  border-radius:999px;
  padding:5px 9px;
  font-size:12px;
}
@media(max-width:720px){
  .freqExcelMesHeader{
    grid-template-columns:1fr;
  }
  .freqExcelMesHeader strong{
    font-size:22px;
  }
  .freqExcelMesCards{
    grid-template-columns:1fr;
  }
  .excelDotBig{
    width:52px;
    height:52px;
  }
}

/* v15.25 Un círculo por colocación */
.freqOneCircleHint{
  margin:0 0 8px;
  padding:8px 9px;
  border-radius:12px;
  background:#fff7ed;
  color:#9a3412;
  font-size:12px;
  font-weight:900;
  border:1px solid #fed7aa;
}

/* v16.0 Frecuencias reconstruidas limpias */
.freqCleanRoot{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.freqMonthTabsClean{
  display:flex;
  gap:8px;
  overflow-x:auto;
  padding:10px 2px 12px;
  -webkit-overflow-scrolling:touch;
}
.freqMonthTabsClean button{
  flex:0 0 auto;
  min-width:86px;
  min-height:58px;
  border-radius:16px!important;
  border:1px solid #cbd5e1!important;
  background:#fff!important;
  color:#334155!important;
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:3px;
  padding:8px!important;
}
.freqMonthTabsClean button b{
  font-size:14px;
  font-weight:1000;
}
.freqMonthTabsClean button small{
  font-size:10px;
  font-weight:900;
  color:#64748b;
}
.freqMonthTabsClean button.active{
  background:#063b52!important;
  color:#fff!important;
  border-color:#063b52!important;
  box-shadow:0 6px 16px rgba(6,59,82,.25);
}
.freqMonthTabsClean button.active small{color:rgba(255,255,255,.9);}
.freqCleanMonth{
  border:1px solid #dbe2ea;
  border-radius:20px;
  overflow:hidden;
  background:#fff;
  box-shadow:0 8px 24px rgba(15,23,42,.05);
}
.freqCleanMonthHeader{
  display:grid;
  grid-template-columns:1fr auto;
  gap:12px;
  align-items:center;
  padding:16px;
  background:linear-gradient(135deg,#0b5877,#063b52);
  color:#fff;
}
.freqCleanMonthHeader span{
  font-size:11px;
  font-weight:1000;
  text-transform:uppercase;
  letter-spacing:.08em;
  opacity:.85;
}
.freqCleanMonthHeader h3{
  margin:2px 0;
  font-size:26px;
  line-height:1.05;
}
.freqCleanMonthHeader p{
  margin:0;
  font-size:12px;
  opacity:.9;
}
.freqCleanStats,.freqExcelHeroStats{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  justify-content:flex-end;
}
.freqStatPill{
  display:inline-flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  min-width:66px;
  padding:7px 9px;
  border-radius:14px;
  border:1px solid #dbe2ea;
  background:#f8fafc;
}
.freqStatPill b{font-size:16px;line-height:1;font-weight:1000;color:#0f172a;}
.freqStatPill small{font-size:10px;font-weight:900;color:#475569;}
.freqStatPill.pending{background:#f8fafc;border-color:#cbd5e1;}
.freqStatPill.programmed{background:#eff6ff;border-color:#bfdbfe;}
.freqStatPill.programmed b,.freqStatPill.programmed small{color:#1d4ed8;}
.freqStatPill.done{background:#fff1f2;border-color:#fecdd3;}
.freqStatPill.done b,.freqStatPill.done small{color:#be123c;}
.freqBulkClean{
  display:grid;
  grid-template-columns:1.2fr 1fr 1fr auto auto;
  gap:8px;
  align-items:end;
  padding:12px;
  background:#f8fafc;
  border-bottom:1px solid #e2e8f0;
}
.freqBulkClean b{display:block;color:#063b52;font-weight:1000;}
.freqBulkClean small{display:block;color:#64748b;font-weight:900;font-size:12px;}
.freqBulkClean label{font-size:12px;font-weight:900;color:#063b52;}
.freqBulkClean input,.freqBulkClean select{
  width:100%;
  min-height:38px;
  border:1px solid #cbd5e1;
  border-radius:12px;
  padding:7px;
  background:#fff;
  font-weight:800;
}
.freqBulkClean button{min-height:38px;border-radius:12px!important;}
.freqBulkClean button:disabled{opacity:.45;}
.freqCleanContent{
  display:flex;
  flex-direction:column;
  gap:12px;
  padding:12px;
  background:#eef7fb;
}
.freqOrigenClean{
  border:1px solid #cbd5e1;
  border-radius:18px;
  background:#fff;
  overflow:hidden;
}
.freqOrigenClean>summary{
  list-style:none;
  display:grid;
  grid-template-columns:1fr auto;
  gap:8px;
  padding:12px;
  cursor:pointer;
  background:#fff;
}
.freqOrigenClean>summary::-webkit-details-marker,
.freqStatusClean>summary::-webkit-details-marker,
.freqFullCalendar>summary::-webkit-details-marker{display:none;}
.freqOrigenClean>summary span{font-weight:1000;color:#063b52;}
.freqOrigenClean>summary b{font-size:12px;color:#063b52;background:#eaf7fc;padding:5px 9px;border-radius:999px;}
.freqMunicipiosClean{
  display:flex;
  flex-direction:column;
  gap:10px;
  padding:10px;
  background:#f8fafc;
}
.freqMunicipioClean{
  border:1px solid #dbe2ea;
  border-radius:16px;
  background:#fff;
  overflow:hidden;
}
.freqMunicipioClean>header{
  display:grid;
  grid-template-columns:1fr auto;
  gap:8px;
  align-items:center;
  padding:10px 12px;
  background:#f1f5f9;
  border-bottom:1px solid #e2e8f0;
}
.freqMunicipioClean strong{display:block;color:#0f172a;}
.freqMunicipioClean small{display:block;color:#64748b;font-weight:900;font-size:12px;}
.freqCardsClean{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(270px,1fr));
  gap:10px;
  padding:10px;
}
.freqClientClean{
  border:1px solid #dbe2ea;
  border-radius:16px;
  background:#fff;
  padding:11px;
}
.freqClientClean.hasPending{border-left:6px solid #94a3b8;}
.freqClientClean.noPending{border-left:6px solid #ef4444;}
.freqClientCleanTop{
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:8px;
  align-items:start;
}
.freqClientSelect{
  width:34px;height:34px;border-radius:12px;background:#eaf7fc;border:1px solid #bfeaf6;display:flex;align-items:center;justify-content:center;
}
.freqClientSelect input{width:19px;height:19px;}
.freqClientCleanTop strong{display:block;color:#0f172a;font-size:14px;line-height:1.2;}
.freqClientCleanTop small{display:block;color:#64748b;font-size:11px;font-weight:900;margin-top:4px;}
.freqClientCleanTop button{
  border-radius:12px!important;
  padding:8px 10px!important;
  min-height:34px;
}
.freqClientCleanTop button:disabled{opacity:.45;}
.freqNextHint{
  margin:8px 0;
  padding:8px 9px;
  border-radius:12px;
  background:#fff7ed;
  color:#9a3412;
  font-size:12px;
  font-weight:900;
  border:1px solid #fed7aa;
}
.freqDotsClean{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.freqDotClean{
  width:44px;
  height:44px;
  border-radius:999px;
  border:4px solid #94a3b8;
  background:#fff;
  color:#334155;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  position:relative;
  box-shadow:0 4px 10px rgba(15,23,42,.08);
}
.freqDotClean b{font-size:14px;font-weight:1000;z-index:1;}
.freqDotClean.programmed{border-color:#2563eb;background:#dbeafe;color:#1d4ed8;}
.freqDotClean.done{border-color:#ef4444;background:#fff1f2;color:#be123c;}
.freqDotClean.done:after{
  content:'';
  position:absolute;
  left:3px;right:3px;top:50%;
  height:4px;
  background:#ef4444;
  border-radius:999px;
  transform:rotate(-35deg);
}
.freqStatusClean,.freqFullCalendar{
  margin:12px;
  border:1px solid #cbd5e1;
  border-radius:18px;
  overflow:hidden;
  background:#fff;
}
.freqStatusClean>summary,.freqFullCalendar>summary{
  list-style:none;
  display:grid;
  grid-template-columns:1fr auto;
  gap:8px;
  padding:12px;
  cursor:pointer;
  background:#f8fafc;
}
.freqStatusClean>summary span,.freqFullCalendar>summary span{font-weight:1000;color:#063b52;}
.freqStatusClean>summary b,.freqFullCalendar>summary b{font-size:12px;color:#063b52;background:#eaf7fc;border-radius:999px;padding:5px 9px;}
.freqStatusGrid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:10px;
  padding:10px;
  background:#f8fafc;
}
.freqStatusItem{
  display:grid;
  grid-template-columns:1fr auto;
  gap:8px;
  align-items:center;
  border:1px solid #dbe2ea;
  border-radius:14px;
  padding:10px;
  background:#fff;
}
.freqStatusItem b{display:block;color:#0f172a;}
.freqStatusItem small,.freqStatusItem span{display:block;color:#64748b;font-size:11px;font-weight:900;margin-top:3px;}
.freqStatusItem.hecho{border-left:6px solid #ef4444;}
.freqStatusItem.programado{border-left:6px solid #2563eb;}
.freqCalendarScroll{overflow:auto;max-height:70vh;}
.freqCalendarOriginTitle{
  position:sticky;left:0;
  background:#eaf7fc;
  color:#063b52;
  font-weight:1000;
  padding:9px 10px;
  border-top:1px solid #cbd5e1;
}
.freqCalendarTableClean{
  width:max-content;
  min-width:100%;
  border-collapse:separate;
  border-spacing:0;
  font-size:12px;
}
.freqCalendarTableClean th{
  position:sticky;top:0;z-index:5;
  background:#0b5877;color:#fff;
  padding:8px;
  min-width:64px;
  border-right:1px solid rgba(255,255,255,.2);
}
.freqCalendarTableClean th.stickyClient{left:0;z-index:7;text-align:left;min-width:240px;}
.freqCalendarTableClean td{
  border-right:1px solid #e2e8f0;
  border-bottom:1px solid #e2e8f0;
  padding:6px;
  text-align:center;
  background:#fff;
}
.freqCalendarTableClean .stickyClient{
  position:sticky;left:0;z-index:3;text-align:left;background:#fff;box-shadow:4px 0 8px rgba(15,23,42,.05);
}
.freqCalendarTableClean .stickyClient b{display:block;color:#0f172a;}
.freqCalendarTableClean .stickyClient small{display:block;color:#64748b;font-size:10px;font-weight:900;margin-top:3px;}
@media(max-width:720px){
  .freqCleanMonthHeader,.freqBulkClean,.freqMunicipioClean>header,.freqStatusItem{
    grid-template-columns:1fr;
  }
  .freqCardsClean,.freqStatusGrid{grid-template-columns:1fr;}
  .freqDotClean{width:50px;height:50px;}
  .freqClientCleanTop{grid-template-columns:auto 1fr;}
  .freqClientCleanTop button{grid-column:1/-1;width:100%;}
}

/* v16.1 Municipios desplegables */
.freqMunicipioClean{
  border:1px solid #dbe2ea;
  border-radius:18px;
  background:#fff;
  overflow:hidden;
}
.freqMunicipioClean>summary.freqMunicipioSummary{
  list-style:none;
  cursor:pointer;
  display:grid;
  grid-template-columns:1fr auto auto;
  gap:10px;
  align-items:center;
  padding:15px 14px;
  background:linear-gradient(180deg,#ffffff 0%,#f1f8fb 100%);
  border-bottom:1px solid #e2e8f0;
}
.freqMunicipioClean>summary.freqMunicipioSummary::-webkit-details-marker{
  display:none;
}
.freqMunicipioClean>summary.freqMunicipioSummary:before{
  content:'▸';
  color:#063b52;
  font-weight:1000;
  font-size:20px;
  transform:rotate(0deg);
  transition:transform .15s ease;
  grid-column:1;
  grid-row:1;
  justify-self:start;
  margin-left:0;
}
.freqMunicipioClean[open]>summary.freqMunicipioSummary:before{
  transform:rotate(90deg);
}
.freqMunicipioTitleBlock{
  padding-left:28px;
}
.freqMunicipioTitleBlock strong{
  display:block;
  color:#063b52;
  font-size:22px;
  line-height:1.05;
  font-weight:1000;
  letter-spacing:-.02em;
}
.freqMunicipioTitleBlock small{
  display:block;
  color:#64748b;
  font-size:13px;
  font-weight:900;
  margin-top:5px;
}
.freqMunicipioBadges{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  justify-content:flex-end;
}
.freqMunicipioBadges span{
  border-radius:999px;
  padding:5px 8px;
  font-size:11px;
  font-weight:1000;
  white-space:nowrap;
}
.freqMunicipioBadges .pending{
  background:#f1f5f9;
  color:#475569;
}
.freqMunicipioBadges .programmed{
  background:#eff6ff;
  color:#1d4ed8;
}
.freqMunicipioBadges .done{
  background:#fff1f2;
  color:#be123c;
}
.freqMunicipioProgramBtn{
  min-height:38px;
  border-radius:12px!important;
  white-space:nowrap;
}
.freqMunicipioClean:not([open]) .freqCardsClean{
  display:none;
}
@media(max-width:720px){
  .freqMunicipioClean>summary.freqMunicipioSummary{
    grid-template-columns:1fr;
    gap:8px;
    padding:16px 13px;
  }
  .freqMunicipioClean>summary.freqMunicipioSummary:before{
    grid-column:1;
    grid-row:1;
  }
  .freqMunicipioTitleBlock{
    padding-left:30px;
  }
  .freqMunicipioTitleBlock strong{
    font-size:24px;
  }
  .freqMunicipioBadges{
    justify-content:flex-start;
    padding-left:30px;
  }
  .freqMunicipioProgramBtn{
    width:100%;
    margin-top:4px;
  }
}


/* v18.0 Resumen mensual separado: solo afecta a la pestaña nueva */
.resumenMensualHero{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:10px;
  align-items:center;
}
.resumenMensualHero h3{
  margin:0 0 4px;
}
.resumenMensualHero p{
  margin:0;
  color:#64748b;
}
.resumenMensualActions button{
  white-space:nowrap;
}
.resumenMensualRoot,
.resumenMensualRoot *{
  box-sizing:border-box;
}
.rmKpis{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:8px;
  margin:10px 0;
}
.rmKpis div{
  background:#fff;
  border:1px solid #dbe2ea;
  border-radius:14px;
  padding:10px;
  text-align:center;
}
.rmKpis span{
  display:block;
  color:#64748b;
  font-size:11px;
  font-weight:900;
}
.rmKpis b{
  display:block;
  color:#063b52;
  font-size:24px;
  line-height:1;
  margin-top:4px;
}
.rmAccordion{
  display:flex;
  flex-direction:column;
  gap:8px;
  width:100%;
  max-width:100%;
  overflow-x:hidden;
}
.rmMonth{
  width:100%;
  max-width:100%;
  border:1px solid #cbd5e1;
  border-radius:15px;
  background:#fff;
  overflow:hidden;
}
.rmMonth>summary{
  list-style:none;
  display:grid;
  grid-template-columns:minmax(0,1fr) 28px;
  gap:8px;
  align-items:center;
  padding:10px 11px;
  background:#eef8fb;
  cursor:pointer;
}
.rmMonth>summary::-webkit-details-marker,
.rmMunicipio>summary::-webkit-details-marker{
  display:none;
}
.rmMonthTitle{
  min-width:0;
}
.rmMonthTitle strong{
  display:block;
  color:#063b52;
  font-size:18px;
  font-weight:1000;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.rmMonthTitle small{
  display:block;
  color:#64748b;
  font-size:11px;
  font-weight:900;
  margin-top:2px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.rmChevron{
  width:26px;
  height:26px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#dbeafe;
  color:#063b52;
  font-weight:1000;
  transition:transform .15s ease;
}
.rmMonth[open] .rmChevron{
  transform:rotate(180deg);
}
.rmMonthBody{
  padding:8px;
  background:#f8fafc;
  display:flex;
  flex-direction:column;
  gap:7px;
}
.rmMunicipio{
  background:#fff;
  border:1px solid #e2e8f0;
  border-radius:13px;
  overflow:hidden;
}
.rmMunicipio>summary{
  list-style:none;
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:8px;
  align-items:center;
  padding:8px 9px;
  cursor:pointer;
}
.rmMunicipio>summary strong{
  min-width:0;
  color:#0f172a;
  font-size:14px;
  font-weight:1000;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.rmMunicipio>summary span{
  color:#64748b;
  font-size:10px;
  font-weight:900;
  white-space:nowrap;
}
.rmRows{
  display:flex;
  flex-direction:column;
  gap:0;
  padding:0 7px 7px;
}
.rmRow{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:8px;
  align-items:center;
  padding:6px 0;
  border-top:1px solid #eef2f7;
}
.rmName{
  min-width:0;
}
.rmName b{
  display:block;
  color:#0f172a;
  font-size:12px;
  line-height:1.1;
  font-weight:1000;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.rmName small{
  display:block;
  color:#64748b;
  font-size:9px;
  font-weight:900;
  margin-top:2px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.rmDots{
  display:flex;
  flex-wrap:wrap;
  justify-content:flex-end;
  gap:3px;
  max-width:96px;
}
.rmDot{
  width:20px;
  height:20px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:2px solid #f59e0b;
  color:#92400e;
  background:#fff7ed;
  font-size:8px;
  font-weight:1000;
  line-height:1;
}
.rmEmpty{
  padding:10px;
  color:#64748b;
  font-size:12px;
  font-weight:900;
  background:#fff;
  border-radius:12px;
  border:1px solid #e2e8f0;
}
@media(max-width:720px){
  .resumenMensualHero{
    grid-template-columns:1fr;
  }
  .resumenMensualActions button{
    width:100%;
  }
  .rmKpis{
    grid-template-columns:repeat(3,1fr);
    gap:5px;
  }
  .rmKpis div{
    padding:8px 5px;
  }
  .rmKpis b{
    font-size:20px;
  }
  .rmMonthTitle strong{
    font-size:17px;
  }
  .rmMonthBody{
    padding:6px;
  }
  .rmMunicipio>summary{
    grid-template-columns:minmax(0,1fr);
    gap:2px;
  }
  .rmMunicipio>summary span{
    white-space:normal;
  }
  .rmRow{
    grid-template-columns:minmax(0,1fr) auto;
    gap:5px;
  }
  .rmDots{
    max-width:78px;
    gap:2px;
  }
  .rmDot{
    width:18px;
    height:18px;
    font-size:8px;
  }
}

/* v18.1 Occidental Gobernanta */
.occGobAdminRoot,.occGobAdminRoot *{box-sizing:border-box}
.occGobKpis{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:10px 0}
.occGobKpis div{background:#fff;border:1px solid #dbe2ea;border-radius:14px;padding:10px;text-align:center}
.occGobKpis span{display:block;color:#64748b;font-size:11px;font-weight:900}
.occGobKpis b{display:block;color:#063b52;font-size:24px;line-height:1;margin-top:4px}
.occGobBlock{background:#fff;border:1px solid #dbe2ea;border-radius:16px;margin:10px 0;overflow:hidden}
.occGobBlock>summary{list-style:none;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:center;padding:11px 12px;background:#eef8fb;cursor:pointer}
.occGobBlock>summary::-webkit-details-marker{display:none}
.occGobBlock>summary strong{color:#063b52;font-size:16px;font-weight:1000}
.occGobBlock>summary span{background:#fff;border:1px solid #bfeaf6;border-radius:999px;padding:4px 8px;color:#063b52;font-size:12px;font-weight:1000}
.occGobList{display:flex;flex-direction:column;gap:8px;padding:8px}
.occGobRow{border:1px solid #e2e8f0;border-left:5px solid #f59e0b;border-radius:14px;padding:10px;background:#fff}
.occGobRow.estado-en_gestion{border-left-color:#2563eb}
.occGobRow.estado-realizado{border-left-color:#16a34a}
.occGobRow.estado-cancelado{border-left-color:#64748b;opacity:.75}
.occGobTop{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:center}
.occGobTop b{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#0f172a;font-size:15px}
.occGobTop span{border-radius:999px;background:#f1f5f9;color:#334155;font-size:11px;font-weight:1000;padding:4px 8px}
.occGobRow p{margin:8px 0;color:#0f172a;font-size:14px;line-height:1.25;white-space:pre-wrap}
.occGobRow small{display:block;color:#64748b;font-size:11px;font-weight:800;margin-top:4px}
.occGobBtns{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-top:10px}
.occGobBtns button{padding:8px 6px;font-size:11px;border-radius:10px}
@media(max-width:720px){.occGobKpis{gap:5px}.occGobKpis div{padding:8px 5px}.occGobKpis b{font-size:20px}.occGobBtns{grid-template-columns:1fr 1fr}}


/* v18.3 Solicitudes dentro de Especiales > Occidental */
.occSolicitudesInsideOccidental{
  background:#fff;
  border:1px solid #dbe2ea;
  border-radius:18px;
  margin:12px 0;
  overflow:hidden;
}
.occSolicitudesInsideOccidental>summary{
  list-style:none;
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:8px;
  align-items:center;
  padding:12px;
  background:#eef8fb;
  cursor:pointer;
}
.occSolicitudesInsideOccidental>summary::-webkit-details-marker{display:none}
.occSolicitudesInsideOccidental>summary strong{
  color:#063b52;
  font-size:18px;
  font-weight:1000;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.occSolicitudesInsideOccidental>summary span{
  background:#fff;
  border:1px solid #bfeaf6;
  border-radius:999px;
  padding:4px 8px;
  color:#063b52;
  font-size:12px;
  font-weight:1000;
}
.occSolicitudesInsideOccidental>.card{ margin:10px; }
.occSolicitudesInsideOccidental #occGobMsg,
.occSolicitudesInsideOccidental #occGobRoot{
  margin-left:10px;
  margin-right:10px;
}


/* v18.4 Occidental sin bloqueo */
.occSolicitudesInsideOccidental #occGobMsg{
  background:#eef8fb;
  border:1px solid #bfeaf6;
  color:#063b52;
  border-radius:12px;
  padding:9px 10px;
  font-size:12px;
  font-weight:900;
}


/* v19.9 Programados sin duplicar + multiquitar */
.freqMultiRemoveBar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:10px 12px;
  background:#fff7ed;
  border-bottom:1px solid #fed7aa;
}
.freqMiniCheck,
.freqProgSelect{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:12px;
  font-weight:900;
  color:#475569;
}
.freqProgSelect{
  margin-bottom:6px;
}
.freqStatusActions{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:6px;
}
button.danger{
  background:#dc2626 !important;
  color:white !important;
  border-color:#dc2626 !important;
}
button.danger:disabled{
  opacity:.45;
}
@media(max-width:720px){
  .freqMultiRemoveBar{
    flex-direction:column;
    align-items:stretch;
  }
  .freqStatusActions{
    align-items:stretch;
  }
}


/* v20.2 Frecuencias limpias */
.freqKpi.programmed b{color:#2563eb}
.freqCleanBoard{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.freqCleanSection{
  border:1px solid #dbe2ea;
  border-radius:18px;
  background:#fff;
  overflow:hidden;
}
.freqCleanSection>summary{
  list-style:none;
  display:flex;
  justify-content:space-between;
  gap:10px;
  align-items:center;
  padding:12px 14px;
  cursor:pointer;
  background:#f8fafc;
}
.freqCleanSection>summary::-webkit-details-marker{display:none}
.freqCleanSection>summary strong{font-size:16px;color:#0f172a}
.freqCleanSection>summary span{
  min-width:32px;
  height:26px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:#e2e8f0;
  font-weight:1000;
  color:#0f172a;
}
.freqCleanSection.programado>summary{background:#eff6ff}
.freqCleanSection.hecho>summary{background:#ecfdf5}
.freqCleanSection.pendiente>summary{background:#fff7ed}
.freqCleanMunicipio{
  border-top:1px solid #e2e8f0;
}
.freqCleanMunicipio>summary{
  list-style:none;
  display:flex;
  justify-content:space-between;
  padding:10px 14px;
  background:#ffffff;
  cursor:pointer;
}
.freqCleanMunicipio>summary::-webkit-details-marker{display:none}
.freqCleanMunicipio>summary b{font-size:13px;color:#334155}
.freqCleanItems{
  display:flex;
  flex-direction:column;
  gap:8px;
  padding:10px;
  background:#f8fafc;
}
.freqCleanItem{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:10px;
  align-items:center;
  border:1px solid #e2e8f0;
  border-radius:16px;
  padding:10px;
  background:#fff;
}
.freqCleanItem.hecho{border-color:#bbf7d0}
.freqCleanItem.programado{border-color:#bfdbfe}
.freqCleanItem.pendiente{border-color:#fed7aa}
.freqCleanLeft{
  display:flex;
  gap:9px;
  align-items:flex-start;
  min-width:0;
}
.freqStateDot{
  width:14px;
  height:14px;
  border-radius:50%;
  margin-top:3px;
  flex:0 0 auto;
  background:#f59e0b;
}
.freqStateDot.programado{background:#2563eb}
.freqStateDot.hecho{background:#16a34a}
.freqCleanLeft b{
  display:block;
  font-size:14px;
  color:#0f172a;
}
.freqCleanLeft small,
.freqCleanLeft em{
  display:block;
  font-size:11px;
  color:#64748b;
  font-style:normal;
  margin-top:2px;
}
.freqCleanRight{
  display:flex;
  align-items:flex-end;
  flex-direction:column;
  gap:6px;
}
.freqBadge{
  border-radius:999px;
  padding:4px 8px;
  font-size:11px;
  font-weight:1000;
  background:#ffedd5;
  color:#9a3412;
}
.freqBadge.programado{background:#dbeafe;color:#1d4ed8}
.freqBadge.hecho{background:#dcfce7;color:#15803d}
.freqMultiRemoveBar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:10px 12px;
  background:#eff6ff;
  border:1px solid #bfdbfe;
  border-radius:16px;
}
.freqMiniCheck,
.freqProgSelect{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:12px;
  font-weight:900;
  color:#475569;
}
button.danger{
  background:#dc2626 !important;
  color:#fff !important;
  border-color:#dc2626 !important;
}
.rmDotProg{background:#2563eb;color:#fff}
.rmDotDone{background:#16a34a;color:#fff}
.rmEstado_programado>summary{background:#eff6ff}
.rmEstado_hecho>summary{background:#ecfdf5}
.rmMunBlock h4{
  margin:10px 0 6px;
  font-size:12px;
  color:#64748b;
}
@media(max-width:720px){
  .freqCleanItem{
    grid-template-columns:1fr;
  }
  .freqCleanRight{
    align-items:stretch;
  }
  .freqMultiRemoveBar{
    flex-direction:column;
    align-items:stretch;
  }
}


/* v20.5 Programar Frecuencias simple */
.freqProgramBar{
  background:#ecfdf5;
  border-color:#bbf7d0;
}
.freqProgramBar button{
  background:#16a34a !important;
  color:#fff !important;
  border-color:#16a34a !important;
}


/* v20.6 Multiquitar hechos */
.freqHechosBar{
  background:#ecfdf5;
  border-color:#bbf7d0;
}

/* v20.7 Sacar todos los hechos */
.freqHechosBar{background:#ecfdf5;border-color:#bbf7d0;}

/* v21.0 App rearmada limpia */
.freqKpi.programmed b{color:#2563eb}
.freqCleanBoard{display:flex;flex-direction:column;gap:12px}
.freqCleanSection{border:1px solid #dbe2ea;border-radius:18px;background:#fff;overflow:hidden}
.freqCleanSection>summary{list-style:none;display:flex;justify-content:space-between;gap:10px;align-items:center;padding:12px 14px;cursor:pointer;background:#f8fafc}
.freqCleanSection>summary::-webkit-details-marker{display:none}
.freqCleanSection>summary strong{font-size:16px;color:#0f172a}
.freqCleanSection>summary span{min-width:32px;height:26px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:#e2e8f0;font-weight:1000;color:#0f172a}
.freqCleanSection.programado>summary{background:#eff6ff}
.freqCleanSection.hecho>summary{background:#ecfdf5}
.freqCleanSection.pendiente>summary{background:#fff7ed}
.freqCleanMunicipio{border-top:1px solid #e2e8f0}
.freqCleanMunicipio>summary{list-style:none;display:flex;justify-content:space-between;padding:10px 14px;background:#fff;cursor:pointer}
.freqCleanMunicipio>summary::-webkit-details-marker{display:none}
.freqCleanItems{display:flex;flex-direction:column;gap:8px;padding:10px;background:#f8fafc}
.freqCleanItem{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center;border:1px solid #e2e8f0;border-radius:16px;padding:10px;background:#fff}
.freqCleanItem.hecho{border-color:#bbf7d0}.freqCleanItem.programado{border-color:#bfdbfe}.freqCleanItem.pendiente{border-color:#fed7aa}
.freqCleanLeft{display:flex;gap:9px;align-items:flex-start;min-width:0}
.freqStateDot{width:14px;height:14px;border-radius:50%;margin-top:3px;flex:0 0 auto;background:#f59e0b}.freqStateDot.programado{background:#2563eb}.freqStateDot.hecho{background:#16a34a}
.freqCleanLeft b{display:block;font-size:14px;color:#0f172a}.freqCleanLeft small,.freqCleanLeft em{display:block;font-size:11px;color:#64748b;font-style:normal;margin-top:2px}
.freqCleanRight{display:flex;align-items:flex-end;flex-direction:column;gap:6px}
.freqBadge{border-radius:999px;padding:4px 8px;font-size:11px;font-weight:1000;background:#ffedd5;color:#9a3412}.freqBadge.programado{background:#dbeafe;color:#1d4ed8}.freqBadge.hecho{background:#dcfce7;color:#15803d}
.freqMultiRemoveBar{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:16px}
.freqProgramBar{background:#ecfdf5;border-color:#bbf7d0}.freqProgramBar button{background:#16a34a!important;color:#fff!important;border-color:#16a34a!important}
.freqHechosBar{background:#ecfdf5;border-color:#bbf7d0}
.freqMiniCheck,.freqProgSelect{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:900;color:#475569}
button.danger{background:#dc2626!important;color:#fff!important;border-color:#dc2626!important}
.rmDotProg{background:#2563eb;color:#fff}.rmDotDone{background:#16a34a;color:#fff}
.rmEstado_programado>summary{background:#eff6ff}.rmEstado_hecho>summary{background:#ecfdf5}.rmMunBlock h4{margin:10px 0 6px;font-size:12px;color:#64748b}
@media(max-width:720px){.freqCleanItem{grid-template-columns:1fr}.freqCleanRight{align-items:stretch}.freqMultiRemoveBar{flex-direction:column;align-items:stretch}}

/* v21.2 Tabla 2 colocada */
.freqCleanOrigen{
  border-top:1px solid #cbd5e1;
  background:#f1f5f9;
}
.freqCleanOrigen>summary{
  list-style:none;
  display:flex;
  justify-content:space-between;
  padding:10px 14px;
  background:#e2e8f0;
  cursor:pointer;
}
.freqCleanOrigen>summary::-webkit-details-marker{display:none}
.freqCleanOrigen>summary b{
  font-size:13px;
  font-weight:1000;
  color:#0f172a;
}

/* v21.4 Diagnóstico Frecuencias */
.freqDebugPanel{
  background:#fff;
  border:1px solid #cbd5e1;
  border-radius:14px;
  padding:8px 10px;
  margin:10px 0;
}
.freqDebugPanel summary{
  cursor:pointer;
  font-weight:900;
  color:#334155;
}
.freqDebugPanel div{
  font-size:12px;
  color:#475569;
  line-height:1.35;
  margin-top:4px;
}
.freqDebugPanel .warn{
  color:#b45309;
  font-weight:900;
}

/* v22.6 Overlay Frecuencias */
.freqCleanBoard{display:flex;flex-direction:column;gap:12px}
.freqCleanSection{border:1px solid #dbe2ea;border-radius:18px;background:#fff;overflow:hidden}
.freqCleanSection>summary{list-style:none;display:flex;justify-content:space-between;gap:10px;align-items:center;padding:12px 14px;cursor:pointer;background:#f8fafc}
.freqCleanSection>summary::-webkit-details-marker{display:none}
.freqCleanOrigen>summary,.freqCleanMunicipio>summary{list-style:none;display:flex;justify-content:space-between;padding:10px 14px;cursor:pointer}
.freqCleanOrigen>summary{background:#e2e8f0}.freqCleanMunicipio>summary{background:#fff}
.freqCleanItems{display:flex;flex-direction:column;gap:8px;padding:10px;background:#f8fafc}
.freqCleanItem{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center;border:1px solid #e2e8f0;border-radius:16px;padding:10px;background:#fff}
.freqCleanLeft{display:flex;gap:9px;align-items:flex-start;min-width:0}
.freqStateDot{width:14px;height:14px;border-radius:50%;margin-top:3px;flex:0 0 auto;background:#f59e0b}.freqStateDot.programado{background:#2563eb}.freqStateDot.hecho{background:#16a34a}
.freqCleanLeft b{display:block;font-size:14px;color:#0f172a}.freqCleanLeft small,.freqCleanLeft em{display:block;font-size:11px;color:#64748b;font-style:normal;margin-top:2px}
.freqCleanRight{display:flex;align-items:flex-end;flex-direction:column;gap:6px}
.freqBadge{border-radius:999px;padding:4px 8px;font-size:11px;font-weight:1000;background:#ffedd5;color:#9a3412}.freqBadge.programado{background:#dbeafe;color:#1d4ed8}.freqBadge.hecho{background:#dcfce7;color:#15803d}
.freqDebugPanel{background:#fff;border:1px solid #cbd5e1;border-radius:14px;padding:8px 10px;margin:10px 0}.freqDebugPanel summary{cursor:pointer;font-weight:900;color:#334155}.freqDebugPanel div{font-size:12px;color:#475569;line-height:1.35;margin-top:4px}

/* v22.7 Operativa Frecuencias */
.freqMultiRemoveBar{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:16px;flex-wrap:wrap}
.freqProgramBar{background:#ecfdf5;border-color:#bbf7d0}
.freqHechosBar{background:#ecfdf5;border-color:#bbf7d0}
.freqMiniCheck,.freqProgSelect{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:900;color:#475569}
button.danger{background:#dc2626!important;color:#fff!important;border-color:#dc2626!important}
.freqCleanRight button{font-size:12px;padding:6px 8px}
@media(max-width:720px){.freqMultiRemoveBar{flex-direction:column;align-items:stretch}.freqCleanRight{align-items:stretch}}

/* v22.8 Resumen mensual desplegable */
.rmAccordion{display:flex;flex-direction:column;gap:12px;margin-top:12px}
.rmMonth{border:1px solid #dbe2ea;border-radius:18px;background:#fff;overflow:hidden}
.rmMonth>summary{list-style:none;display:flex;justify-content:space-between;align-items:center;gap:10px;padding:14px;background:#f8fafc;cursor:pointer}
.rmMonth>summary::-webkit-details-marker{display:none}
.rmMonthTitle strong{display:block;font-size:16px;color:#0f172a}
.rmMonthTitle small{display:block;font-size:12px;color:#64748b;margin-top:3px}
.rmChevron{font-size:18px;color:#64748b}
.rmMonthBody{display:flex;flex-direction:column;gap:10px;padding:10px;background:#f8fafc}
.rmEstado{border:1px solid #e2e8f0;border-radius:16px;background:#fff;overflow:hidden}
.rmEstado>summary{list-style:none;display:flex;justify-content:space-between;align-items:center;padding:11px 12px;cursor:pointer}
.rmEstado>summary::-webkit-details-marker{display:none}
.rmEstado>summary strong{font-size:14px;color:#0f172a}
.rmEstado>summary span,.rmOrigen>summary span,.rmMunicipio>summary span{min-width:28px;height:24px;border-radius:999px;background:#e2e8f0;display:inline-flex;align-items:center;justify-content:center;font-weight:1000;font-size:12px;color:#334155}
.rmEstado_pendiente>summary{background:#fff7ed}
.rmEstado_programado>summary{background:#eff6ff}
.rmEstado_hecho>summary{background:#ecfdf5}
.rmEstadoBody{padding:8px;background:#fff}
.rmOrigen,.rmMunicipio{border:1px solid #e2e8f0;border-radius:14px;margin:8px 0;overflow:hidden}
.rmOrigen>summary,.rmMunicipio>summary{list-style:none;display:flex;justify-content:space-between;align-items:center;padding:9px 10px;cursor:pointer}
.rmOrigen>summary{background:#e2e8f0}
.rmMunicipio>summary{background:#f8fafc}
.rmOrigen>summary::-webkit-details-marker,.rmMunicipio>summary::-webkit-details-marker{display:none}
.rmRows{display:flex;flex-direction:column;gap:7px;padding:8px;background:#fff}
.rmRow{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center;border:1px solid #e2e8f0;border-radius:13px;padding:9px;background:#fff}
.rmRow.pendiente{border-color:#fed7aa}
.rmRow.programado{border-color:#bfdbfe}
.rmRow.hecho{border-color:#bbf7d0}
.rmName b{display:block;font-size:13px;color:#0f172a}
.rmName small{display:block;font-size:11px;color:#64748b;margin-top:2px}
.rmDots{display:flex;gap:4px;flex-wrap:wrap;justify-content:flex-end}
.rmDot{min-width:22px;height:22px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:1000}
.rmDotPend{background:#fed7aa;color:#9a3412}
.rmDotProg{background:#bfdbfe;color:#1d4ed8}
.rmDotDone{background:#bbf7d0;color:#15803d}
.rmEmpty{padding:10px;color:#64748b;font-size:13px}
@media(max-width:720px){.rmRow{grid-template-columns:1fr}.rmDots{justify-content:flex-start}}
