/* ============================================================
 * LEXIA · Indemnizaciones (Sprint 2C-6)
 * Estilos de la pestaña "Cálculo UNESPA"
 * 12-mayo-2026
 * ============================================================ */

/* Contenedor general */
.indem-wrapper {
  font-family: inherit;
}

/* Resumen arriba */
.indem-resumen {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 8px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-left: 3px solid var(--gold);
  padding: 14px 18px;
  margin-bottom: 18px;
}
.indem-resumen-item {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.indem-resumen-label {
  font-size: 9px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--text-dim);
}
.indem-resumen-valor {
  font-size: 15px;
  font-weight: 600;
  color: var(--text);
  font-variant-numeric: tabular-nums;
}
.indem-resumen-valor.gold {
  color: var(--gold);
  font-size: 17px;
}

/* Bloque de oferta (OM1, OM2, OM3, Finiquito) */
.indem-oferta {
  background: var(--bg-card);
  border: 1px solid var(--border);
  margin-bottom: 14px;
  overflow: hidden;
}
.indem-oferta-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  background: rgba(0,0,0,0.12);
  cursor: pointer;
  user-select: none;
  border-bottom: 1px solid transparent;
  transition: background 0.15s;
}
.indem-oferta-head:hover {
  background: rgba(0,0,0,0.18);
}
.indem-oferta.expanded .indem-oferta-head {
  border-bottom-color: var(--border);
}
.indem-oferta-head-left {
  display: flex;
  align-items: center;
  gap: 10px;
}
.indem-oferta-flecha {
  display: inline-block;
  font-size: 10px;
  color: var(--text-dim);
  transition: transform 0.15s;
  width: 12px;
}
.indem-oferta.expanded .indem-oferta-flecha {
  transform: rotate(90deg);
}
.indem-oferta-titulo {
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.5px;
  color: var(--text);
}
.indem-oferta-importe {
  font-size: 14px;
  font-weight: 600;
  color: var(--gold);
  font-variant-numeric: tabular-nums;
}
.indem-oferta-estado {
  font-size: 10px;
  letter-spacing: 1px;
  text-transform: uppercase;
  padding: 2px 8px;
  border: 1px solid;
  border-radius: 2px;
}
.indem-oferta-estado.pendiente { color: #c0c0c0; border-color: #6a6a6a; }
.indem-oferta-estado.aceptada  { color: #4caf50; border-color: #4caf50; }
.indem-oferta-estado.rechazada { color: #ef6b6b; border-color: #ef6b6b; }
.indem-oferta-estado.superada  { color: #888;    border-color: #555; }

.indem-oferta-body {
  display: none;
  padding: 14px 16px;
}
.indem-oferta.expanded .indem-oferta-body {
  display: block;
}

/* Fila de metadatos de la oferta (fecha, estado, total) */
.indem-meta-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin-bottom: 16px;
  padding-bottom: 14px;
  border-bottom: 1px dashed var(--border);
}
.indem-field {
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.indem-field label {
  font-size: 9px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--text-dim);
}
.indem-field .ficha-val {
  font-size: 13px;
  color: var(--text);
  padding: 4px 0;
  font-variant-numeric: tabular-nums;
}
.indem-input,
.indem-select {
  background: var(--bg-soft, rgba(255,255,255,0.04));
  border: 1px solid var(--border);
  color: var(--text);
  padding: 5px 7px;
  font-size: 13px;
  font-family: inherit;
  font-variant-numeric: tabular-nums;
}
.indem-input:focus,
.indem-select:focus {
  outline: none;
  border-color: var(--gold);
}

/* Alerta amarilla de suma no cuadra */
.indem-alerta-suma {
  display: flex;
  align-items: center;
  gap: 8px;
  background: rgba(255, 193, 7, 0.10);
  border: 1px solid rgba(255, 193, 7, 0.4);
  color: #f0c040;
  padding: 8px 12px;
  font-size: 12px;
  margin-bottom: 14px;
  border-radius: 2px;
}
.indem-alerta-suma .icono {
  font-size: 14px;
}

/* Sub-bloque (Corporal, Vehículo, Emergente, Lucro) */
.indem-bloque {
  background: rgba(255,255,255,0.025);
  border: 1px solid var(--border);
  margin-bottom: 10px;
  overflow: hidden;
}
.indem-bloque-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 9px 14px;
  cursor: pointer;
  user-select: none;
  background: rgba(0,0,0,0.08);
  transition: background 0.15s;
}
.indem-bloque-head:hover { background: rgba(0,0,0,0.15); }
.indem-bloque-titulo {
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--text);
  font-weight: 600;
}
.indem-bloque-total {
  font-size: 13px;
  font-weight: 600;
  color: var(--gold);
  font-variant-numeric: tabular-nums;
}
.indem-bloque-body {
  display: none;
  padding: 14px;
}
.indem-bloque.expanded .indem-bloque-body { display: block; }
.indem-bloque.expanded .indem-bloque-head {
  border-bottom: 1px solid var(--border);
}

/* Grid de campos dentro de sub-bloque */
.indem-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}
.indem-grid.cols-2 {
  grid-template-columns: repeat(2, 1fr);
}
.indem-grid-full {
  grid-column: 1 / -1;
}
.indem-subgroup {
  border: 1px dashed var(--border);
  padding: 10px;
  margin-top: 8px;
  grid-column: 1 / -1;
  background: rgba(0,0,0,0.04);
}
.indem-subgroup-title {
  font-size: 9px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--text-dim);
  margin-bottom: 6px;
}

/* Total automático del sub-bloque al pie */
.indem-bloque-resumen {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px solid var(--border);
  font-size: 12px;
}
.indem-bloque-resumen-label {
  color: var(--text-dim);
  letter-spacing: 1px;
  text-transform: uppercase;
}
.indem-bloque-resumen-valor {
  color: var(--gold);
  font-size: 14px;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}

/* Notas de la oferta */
.indem-notas {
  margin-top: 14px;
}
.indem-notas textarea {
  width: 100%;
  min-height: 60px;
  background: var(--bg-soft, rgba(255,255,255,0.04));
  border: 1px solid var(--border);
  color: var(--text);
  padding: 8px 10px;
  font-size: 12px;
  font-family: inherit;
  resize: vertical;
}
.indem-notas textarea:focus { outline: none; border-color: var(--gold); }

/* Zona de botones "Añadir oferta" */
.indem-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin: 16px 0;
}
.indem-btn-add {
  background: transparent;
  border: 1px dashed var(--gold);
  color: var(--gold);
  padding: 9px 16px;
  font-size: 11px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  font-family: inherit;
  cursor: pointer;
  transition: all 0.15s;
}
.indem-btn-add:hover {
  background: rgba(212, 175, 55, 0.08);
  border-style: solid;
}
.indem-btn-add:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

/* Botón "Detallar días por persona" dentro del bloque corporal */
.indem-btn-detalle {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--text-dim);
  padding: 5px 11px;
  font-size: 11px;
  font-family: inherit;
  cursor: pointer;
  margin-left: 8px;
  transition: all 0.15s;
}
.indem-btn-detalle:hover {
  color: var(--gold);
  border-color: var(--gold);
}

/* Estado vacío inicial */
.indem-vacio {
  text-align: center;
  padding: 50px 20px;
  background: var(--bg-card);
  border: 1px dashed var(--border);
  color: var(--text-dim);
  font-size: 13px;
}
.indem-vacio-icono {
  font-size: 36px;
  margin-bottom: 12px;
  opacity: 0.4;
}

/* === Modal "Días lesionales por persona" === */
.indem-modal-dias-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
  margin-top: 8px;
}
.indem-modal-dias-table th,
.indem-modal-dias-table td {
  padding: 6px 8px;
  text-align: left;
  border-bottom: 1px solid var(--border);
}
.indem-modal-dias-table th {
  font-size: 9px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--text-dim);
  background: rgba(0,0,0,0.1);
}
.indem-modal-dias-table td.num,
.indem-modal-dias-table th.num {
  text-align: right;
  font-variant-numeric: tabular-nums;
}
.indem-modal-dias-table input {
  width: 90px;
  background: var(--bg-soft, rgba(255,255,255,0.04));
  border: 1px solid var(--border);
  color: var(--text);
  padding: 3px 6px;
  font-size: 12px;
  text-align: right;
  font-variant-numeric: tabular-nums;
  font-family: inherit;
}
.indem-modal-dias-table input:focus { outline: none; border-color: var(--gold); }
.indem-modal-dias-table td.total {
  color: var(--gold);
  font-weight: 600;
}
.indem-modal-dias-persona {
  margin-bottom: 22px;
  padding: 12px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border);
}
.indem-modal-dias-persona-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 8px;
}
.indem-modal-dias-persona-nombre {
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
}
.indem-modal-dias-persona-rol {
  font-size: 10px;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-left: 8px;
}
.indem-modal-dias-persona-total {
  font-size: 13px;
  font-weight: 600;
  color: var(--gold);
  font-variant-numeric: tabular-nums;
}
.indem-modal-dias-gran-total {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 14px;
  background: rgba(212, 175, 55, 0.08);
  border: 1px solid var(--gold);
  margin-top: 14px;
}
.indem-modal-dias-gran-total-label {
  font-size: 11px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--gold);
}
.indem-modal-dias-gran-total-valor {
  font-size: 18px;
  font-weight: 700;
  color: var(--gold);
  font-variant-numeric: tabular-nums;
}

/* Responsive: en pantallas pequeñas comprimir grids */
@media (max-width: 980px) {
  .indem-resumen { grid-template-columns: repeat(2, 1fr); }
  .indem-meta-grid { grid-template-columns: repeat(2, 1fr); }
  .indem-grid { grid-template-columns: 1fr; }
  .indem-grid.cols-2 { grid-template-columns: 1fr; }
}
