/* =========================================================
   PUBLISHER · Legal Frontend DAL
   Versión limpia y estable
   ========================================================= */

.publisher-legal-page {
  width: 100%;
  background: #ffffff;
  color: #050505;
  padding: 0 0 78px;
}

.publisher-legal-page,
.publisher-legal-page * {
  box-sizing: border-box;
}

/* Contenedor general: mismo ancho para hero, índice y contenido */
.publisher-legal-page__inner {
  width: min(100% - 36px, 1240px);
  margin: 0 auto;
}

/* =========================
   HERO
   ========================= */

.publisher-legal-page__hero {
  width: 100%;
  margin: 0 0 36px;
  padding: 36px 38px 42px;
  border: 1px solid #e8e0d2;
  border-radius: 24px;
  background: linear-gradient(135deg, #fffaf0 0%, #ffffff 58%, #fbf7ef 100%);
}

.publisher-legal-page__eyebrow {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  margin: 0 0 14px;
  padding: 0 12px;
  border-radius: 999px;
  background: #050505;
  color: #ffffff;
  font-size: 11px;
  line-height: 1;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.publisher-legal-page__title {
  margin: 0 0 12px;
  color: #050505;
  font-size: clamp(38px, 5vw, 62px);
  line-height: 0.98;
  font-weight: 900;
  letter-spacing: -0.045em;
}

.publisher-legal-page__intro {
  max-width: 720px;
  margin: 0;
  color: #4f4f4f;
  font-size: 17px;
  line-height: 1.5;
}

/* =========================
   ÍNDICE
   ========================= */

.publisher-legal-page__toc {
  width: 100%;
  margin: 0 0 48px;
  padding: 28px 34px 34px;
  border: 1px solid #e8e0d2;
  border-radius: 22px;
  background: #fffdf8;
}

.publisher-legal-page__toc-title {
  margin: 0 0 22px;
  color: #050505;
  font-size: 13px;
  line-height: 1;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.publisher-legal-page__toc-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-auto-flow: column;
  grid-template-rows: repeat(12, auto);
  gap: 0 52px;
  margin: 0;
  padding: 0;
  list-style: none;
  counter-reset: legal-toc;
}

.publisher-legal-page__toc-item {
  counter-increment: legal-toc;
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr);
  gap: 14px;
  align-items: baseline;
  margin: 0;
  padding: 12px 0;
  border-bottom: 1px solid rgba(5, 5, 5, 0.14);
}

.publisher-legal-page__toc-item::before {
  content: counter(legal-toc, decimal-leading-zero);
  color: #7b756b;
  font-size: 13px;
  line-height: 1.35;
  font-weight: 800;
}

.publisher-legal-page__toc-item a {
  color: #050505 !important;
  text-decoration: underline;
  text-underline-offset: 3px;
  font-size: 14px;
  line-height: 1.35;
  font-weight: 800;
}

.publisher-legal-page__toc-item a:hover,
.publisher-legal-page__toc-item a:focus {
  color: #0f8a90 !important;
}

/* =========================
   CONTENIDO
   ========================= */

.publisher-legal-page__content {
  width: 100%;
  max-width: none;
  margin: 0 auto;
  padding: 0 70px;
}

/* Anula estilos heredados de Astra/WP que puedan alterar títulos */
.publisher-legal-page__content h1,
.publisher-legal-page__content h2,
.publisher-legal-page__content h3,
.publisher-legal-page__content h4,
.publisher-legal-page__content p,
.publisher-legal-page__content ul,
.publisher-legal-page__content ol,
.publisher-legal-page__content li {
  font-family: inherit;
  text-align: left;
}

/* Oculta cualquier H1 pegado accidentalmente dentro del editor */
.publisher-legal-page__content h1 {
  display: none !important;
}

/* Párrafos */
.publisher-legal-page__content p {
  max-width: none;
  margin: 0 0 18px;
  color: #111111;
  font-size: 17px;
  line-height: 1.62;
  font-weight: 400;
}

/* Títulos H2: todos iguales */
.publisher-legal-page__content h2,
.publisher-legal-heading,
.publisher-legal-heading--h2 {
  display: block;
  width: 100%;
  margin: 44px 0 18px !important;
  padding: 28px 0 0 !important;
  border-top: 1px solid rgba(5, 5, 5, 0.14);
  color: #050505 !important;
  font-size: 30px !important;
  line-height: 1.16 !important;
  font-weight: 900 !important;
  letter-spacing: -0.025em;
  text-align: left !important;
  scroll-margin-top: 120px;
}

/* Primer H2 después del índice */
.publisher-legal-page__content h2:first-of-type,
.publisher-legal-page__content .publisher-legal-heading:first-of-type {
  margin-top: 36px !important;
}

/* H3: subtítulos más contenidos */
.publisher-legal-page__content h3 {
  width: 100%;
  margin: 30px 0 14px;
  padding: 0;
  color: #050505;
  font-size: 22px;
  line-height: 1.2;
  font-weight: 850;
  letter-spacing: -0.015em;
  scroll-margin-top: 120px;
}

/* H4 por si se usa */
.publisher-legal-page__content h4 {
  margin: 24px 0 12px;
  color: #050505;
  font-size: 19px;
  line-height: 1.25;
  font-weight: 800;
}

/* Listas limpias */
.publisher-legal-page__content ul,
.publisher-legal-page__content ol {
  margin: 0 0 22px;
  padding-left: 22px;
}

.publisher-legal-page__content li {
  margin: 0 0 9px;
  color: #111111;
  font-size: 17px;
  line-height: 1.62;
}

/* Enlaces */
.publisher-legal-page__content a {
  color: #0f8a90 !important;
  text-decoration: underline;
  text-underline-offset: 3px;
}

/* Negritas */
.publisher-legal-page__content strong {
  color: #050505;
  font-weight: 850;
}

/* Tablas si más adelante las usas */
.publisher-legal-page__content table {
  width: 100%;
  margin: 24px 0;
  border-collapse: collapse;
  border: 1px solid #e8e0d2;
}

.publisher-legal-page__content th,
.publisher-legal-page__content td {
  padding: 13px 14px;
  border-bottom: 1px solid #e8e0d2;
  text-align: left;
  vertical-align: top;
  font-size: 15px;
  line-height: 1.45;
}

.publisher-legal-page__content th {
  background: #fffdf8;
  font-weight: 850;
}

/* =========================
   RESPONSIVE
   ========================= */

@media (max-width: 980px) {
  .publisher-legal-page__content {
    padding: 0 28px;
  }

  .publisher-legal-page__toc-list {
    grid-template-columns: 1fr;
    grid-auto-flow: row;
    grid-template-rows: none;
    gap: 0;
  }
}

@media (max-width: 780px) {
  .publisher-legal-page {
    padding-bottom: 58px;
  }

  .publisher-legal-page__inner {
    width: min(100% - 28px, 1240px);
  }

  .publisher-legal-page__hero {
    margin-bottom: 28px;
    padding: 28px 22px 32px;
    border-radius: 20px;
  }

  .publisher-legal-page__title {
    font-size: 40px;
    line-height: 1;
  }

  .publisher-legal-page__intro {
    font-size: 15px;
    line-height: 1.48;
  }

  .publisher-legal-page__toc {
    margin-bottom: 34px;
    padding: 22px 20px 26px;
    border-radius: 18px;
  }

  .publisher-legal-page__toc-item {
    grid-template-columns: 32px minmax(0, 1fr);
    gap: 12px;
    padding: 11px 0;
  }

  .publisher-legal-page__toc-item a {
    font-size: 14px;
  }

  .publisher-legal-page__content {
    padding: 0;
  }

  .publisher-legal-page__content p,
  .publisher-legal-page__content li {
    font-size: 15.5px;
    line-height: 1.64;
  }

  .publisher-legal-page__content h2,
  .publisher-legal-heading,
  .publisher-legal-heading--h2 {
    margin: 38px 0 16px !important;
    padding-top: 24px !important;
    font-size: 25px !important;
    line-height: 1.16 !important;
  }

  .publisher-legal-page__content h3 {
    margin: 26px 0 12px;
    font-size: 20px;
  }

  .publisher-legal-page__content ul,
  .publisher-legal-page__content ol {
    padding-left: 20px;
  }

  .publisher-legal-page__content table {
    display: block;
    overflow-x: auto;
  }
}


/* =========================================================
   PUBLISHER · Legal ajustes finales
   1) Quitar subrayado del índice
   2) Ensanchar contenido al ancho visual del índice
   ========================================================= */

/* Quitar subrayado de los títulos del índice */
.publisher-legal-page__toc-item a,
.publisher-legal-page__toc-item a:visited,
.publisher-legal-page__toc-item a:hover,
.publisher-legal-page__toc-item a:focus {
  text-decoration: none !important;
}

/* Ensanchar el contenido para que acompañe el ancho de la caja del índice */
.publisher-legal-page__content {
  width: 100% !important;
  max-width: none !important;
  padding-left: 34px !important;
  padding-right: 34px !important;
}

/* Que los textos, listas y títulos no queden encerrados en un ancho menor */
.publisher-legal-page__content p,
.publisher-legal-page__content ul,
.publisher-legal-page__content ol,
.publisher-legal-page__content h2,
.publisher-legal-page__content h3,
.publisher-legal-page__content h4 {
  max-width: none !important;
}

/* En móvil volvemos a quitar padding lateral extra */
@media (max-width: 780px) {
  .publisher-legal-page__content {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
}

