/* JDServer-Webs v6.6 — climate_pro_normals.css
 * Normales climáticas mensuales (multi-año)
 * Estética alineada con climate_pro_monthly + climate_pro
 */

/* Contenedor del módulo dentro de la página */
#climate-pro-normals{
  max-width: 1120px;
  margin: 18px auto 0;   /* igual filosofía que climate_pro_page */
}

/* Card principal del módulo */
.climatepro-normals{
  border-radius: 18px;
  border: 1px solid var(--border);
  background: var(--card);
  box-shadow: var(--shadow-1);
  padding: 14px 18px 18px;
  margin-top: 0;
}

/* Cabecera */
.climatepro-normals-head{
  margin-bottom: 10px;
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:12px;
}

.climatepro-normals-title{
  margin: 0;
  font-size: 1.02rem;
  font-weight:600;
}

.climatepro-normals-sub{
  margin: 3px 0 0;
  font-size: .88rem;
  color: var(--muted);
}

/* Texto de rango de años usado (lado derecho) */
.climatepro-normals-range{
  font-size:.84rem;
  color:var(--muted);
  white-space: nowrap;
}

/* Mensaje vacío */
.climatepro-normals-empty{
  margin: 8px 0 0;
  font-size: .9rem;
  color: var(--muted);
}

/* Tabla */

.climatepro-normals-table-wrap{
  margin-top: 10px;
  overflow-x: auto;
}

.climatepro-normals-table{
  width: 100%;
  border-collapse: collapse;
  font-size: .88rem;
  min-width: 520px;
}

.climatepro-normals-table thead th{
  text-align: left;
  padding: 6px 8px;
  border-bottom: 1px solid var(--border);
  white-space: nowrap; /* escritorio: 1 línea */
}

.climatepro-normals-table tbody td{
  padding: 6px 8px;
  border-bottom: 1px solid color-mix(in oklab, var(--border) 60%, transparent);
  vertical-align: middle;
}

/* Nombre del mes + badges */

.climatepro-norm-month-name{
  font-weight: 500;
}

.climatepro-norm-badges{
  display: inline-flex;
  gap: 4px;
  margin-left: 6px;
}

.climatepro-norm-badge{
  display: inline-flex;
  align-items: center;
  padding: 2px 7px;
  border-radius: 999px;
  font-size: .75rem;
  border: 1px solid var(--border);
  background: var(--bg-elevated, var(--card));
  color: var(--muted);
}

/* Mes más cálido (climáticamente) */
.climatepro-norm-badge.warmest{
  border-color: color-mix(in oklab, var(--brand) 45%, transparent);
}

/* Mes más lluvioso (climáticamente) */
.climatepro-norm-badge.wettest{
  border-color: color-mix(in oklab, var(--brand) 45%, transparent);
}

/* Resaltar filas especiales ligeramente */

.climatepro-normals-table tbody tr.is-warmest{
  background: color-mix(in oklab, var(--brand) 6%, transparent);
}

.climatepro-normals-table tbody tr.is-wettest{
  background: color-mix(in oklab, var(--brand) 10%, transparent);
}

.climatepro-normals-table tbody tr.is-warmest.is-wettest{
  background: color-mix(in oklab, var(--brand) 14%, transparent);
}

/* ================== Responsive (móvil) ================== */

@media (max-width: 640px){

  /* Mismo margen vertical que el módulo mensual */
  #climate-pro-normals{
    margin: 14px 0 40px;
  }

  /* Card con padding idéntico al monthly */
  .climatepro-normals{
    padding: 14px 12px 18px;
  }

  /* Título / subtítulo alineados al monthly */
  .climatepro-normals-title{
    font-size: 1.05rem;
  }

  .climatepro-normals-sub{
    margin-top: 3px;
    font-size: .88rem;
  }

  .climatepro-normals-head{
    align-items:flex-end;
    gap:12px;
  }

  .climatepro-normals-range{
    font-size:.86rem;
  }

  /* Tabla compacta + cabeceras en 2 líneas como monthly */
  .climatepro-normals-table{
    min-width: 100%;
    font-size: .84rem;
  }

  .climatepro-normals-table thead th{
    white-space: normal;     /* deja que se partan en 2 líneas */
    line-height: 1.15;
    padding: 4px 6px;
    font-size: .78rem;
  }

  .climatepro-normals-table tbody td{
    padding: 4px 6px;
    font-size: .82rem;
  }
}
/* === Climograma de normales (gráfico serie completa) ===================== */

.climatepro-normals-chart-wrap{
  margin-top: 18px;
}

.climatepro-normals-chart-title{
  margin: 0 0 8px;
  font-size: .9rem;
  color: var(--muted);
}

.climatepro-normals-chart-wrap canvas{
  width: 100%;
  max-height: 260px;
}

/* Ajustes mobile */
@media (max-width: 640px){
  .climatepro-normals-chart-wrap{
    margin-top: 14px;
  }
  .climatepro-normals-chart-wrap canvas{
    max-height: 230px;
  }
}
