
.u-section-1 .u-sheet-1 {
  min-height: 720px;
  display: flex;
  align-items: center;
}

.u-section-1 .u-group-1 {
  width: 780px;
  min-height: 420px;
  margin: 60px 0 60px auto;
  box-shadow: 0 18px 45px rgba(0, 0, 0, 0.14);
}

.u-section-1 .u-container-layout-1 {
  padding: 40px 48px;
}

.u-section-1 .u-text-1 {
  margin: 0;
  font-size: 0.95rem;
  font-weight: 700;
  letter-spacing: 3px;
}

.u-section-1 .u-text-2 {
  margin: 18px 0 0;
  font-size: 3.3rem;
  line-height: 1.08;
}

.u-section-1 .u-text-3 {
  margin: 24px 0 0;
  font-size: 1.125rem;
  line-height: 1.8;
}

.u-section-1 .u-btn-1 {
  margin: 28px 0 0;
  padding: 16px 34px;
  font-weight: 700;
  letter-spacing: 1px;
}

.u-section-2,
.u-section-4 {
  background: #f7f7f7;
}

.u-section-2 .u-sheet-1,
.u-section-3 .u-sheet-1,
.u-section-4 .u-sheet-1 {
  min-height: 100px;
  padding-top: 70px;
  padding-bottom: 70px;
}

.u-section-2 .u-group-1,
.u-section-3 .u-group-1,
.u-section-4 .u-group-1 {
  box-shadow: 0 12px 30px rgba(34, 34, 34, 0.07);
}

.u-section-2 .u-container-layout-1,
.u-section-3 .u-container-layout-1,
.u-section-4 .u-container-layout-1 {
  padding: 42px;
}

.u-section-2 .u-text-1,
.u-section-3 .u-text-1,
.u-section-4 .u-text-1 {
  margin: 0;
  font-size: 2.45rem;
  line-height: 1.12;
}

.u-section-2 h3,
.u-section-3 h3,
.u-section-4 h3 {
  margin-top: 34px;
  margin-bottom: 0;
  font-size: 1.45rem;
  color: #01696f;
}

.u-section-2 p,
.u-section-3 p,
.u-section-4 p,
.u-section-2 li,
.u-section-3 li,
.u-section-4 li {
  line-height: 1.85;
}

.u-section-2 .u-text-2,
.u-section-2 .u-text-3,
.u-section-2 .u-text-21,
.u-section-2 .u-text-25,
.u-section-2 .u-text-26,
.u-section-2 .u-text-27,
.u-section-2 .u-text-29,
.u-section-2 .u-text-31,
.u-section-2 .u-text-32,
.u-section-2 .u-text-34,
.u-section-2 .u-text-36,
.u-section-3 .u-text-2,
.u-section-3 .u-text-3,
.u-section-3 .u-text-7,
.u-section-3 .u-text-10,
.u-section-3 .u-text-12,
.u-section-3 .u-text-14,
.u-section-3 .u-text-16,
.u-section-3 .u-text-17,
.u-section-3 .u-text-19,
.u-section-3 .u-text-20,
.u-section-3 .u-text-22,
.u-section-3 .u-text-25,
.u-section-3 .u-text-26,
.u-section-4 .u-text-2,
.u-section-4 .u-text-3,
.u-section-4 .u-text-5,
.u-section-4 .u-text-11,
.u-section-4 .u-text-13 {
  margin-top: 18px;
  margin-bottom: 0;
}

.u-list-1 {
  margin-top: 26px;
}

.u-repeater-1 {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.u-repeater-1 .u-list-item {
  background: #c2c2c2;
}

.u-repeater-1 .u-similar-container {
  padding: 20px 22px;
}

.u-repeater-1 h3 {
  margin-top: 0;
  font-size: 0.92rem;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: #01696f;
}

.u-repeater-1 p {
  margin-top: 8px;
}

.u-text-23,
.u-text-5,
.u-text-7,
.u-text-23 {
  padding-left: 20px;
  margin-top: 18px;
}

.u-group-2 {
  margin-top: 24px;
}

.u-section-2 .u-container-layout-2,
.u-section-3 .u-container-layout-2,
.u-section-4 .u-container-layout-2 {
  padding: 24px 28px;
}

.u-section-2 .u-text-28,
.u-section-3 .u-text-8,
.u-section-4 .u-text-9 {
  margin: 0;
}

.u-table-1 {
  margin-top: 20px;
}

.u-table-1 th,
.u-table-1 td {
  padding: 16px 14px;
}

.u-footer .u-sheet-1 {
  min-height: 110px;
}

.u-footer .u-text-1 {
  margin: 40px auto;
}

@media (max-width: 1199px) {
  .u-section-1 .u-group-1 { width: 700px; }
}

@media (max-width: 991px) {
  .u-section-1 .u-group-1 {
    width: 100%;
    margin-top: 50px;
    margin-bottom: 50px;
  }

  .u-repeater-1 {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  .u-section-1 .u-sheet-1 {
    min-height: 620px;
  }

  .u-section-1 .u-container-layout-1,
  .u-section-2 .u-container-layout-1,
  .u-section-2 .u-container-layout-2,
  .u-section-3 .u-container-layout-1,
  .u-section-3 .u-container-layout-2,
  .u-section-4 .u-container-layout-1,
  .u-section-4 .u-container-layout-2 {
    padding: 28px;
  }

  .u-section-1 .u-text-2 {
    font-size: 2.5rem;
  }

  .u-section-2 .u-text-1,
  .u-section-3 .u-text-1,
  .u-section-4 .u-text-1 {
    font-size: 2rem;
  }
}

@media (max-width: 575px) {
  .u-section-1 .u-sheet-1 {
    min-height: 520px;
  }

  .u-section-1 .u-text-2 {
    font-size: 2rem;
  }

  .u-section-1 .u-container-layout-1,
  .u-section-2 .u-container-layout-1,
  .u-section-2 .u-container-layout-2,
  .u-section-3 .u-container-layout-1,
  .u-section-3 .u-container-layout-2,
  .u-section-4 .u-container-layout-1,
  .u-section-4 .u-container-layout-2 {
    padding: 22px;
  }
}

/* Titulos */
.u-section-2 .u-text-1,
.u-section-3 .u-text-1,
.u-section-4 .u-text-1 {
  margin: 0 0 10px;
  font-size: 2.45rem;
  line-height: 1.12;
  color: #01696f;
  font-weight: 800;
  letter-spacing: 0.2px;
  position: relative;
  display: block;
  width: calc(100% + 40px);
  margin-left: -20px;
  padding: 0 20px 18px;
}

.u-section-2 .u-text-1::after,
.u-section-3 .u-text-1::after,
.u-section-4 .u-text-1::after {
  content: "";
  position: absolute;
  left: 20px;
  right: 20px;
  bottom: 0;
  height: 3px;
  background-color: #01696f;
  border-radius: 999px;
}

/* Fuerza a que los contenedores no tengan una altura mínima fija */
.u-sheet {
  min-height: auto !important;
}

/* Reduce el espacio interno de los cajetines */
.u-list-item .u-container-layout {
    padding: 15px 20px !important; /* Menos espacio arriba/abajo */
    min-height: auto !important;   /* Quita la altura mínima gigante */
}

/* Ajusta los márgenes de los títulos y textos dentro de los cajetines */
.u-list-item h3 {
    margin-bottom: 5px !important;
    margin-top: 0 !important;
}

.u-list-item p {
    margin-bottom: 0 !important;
}


        
  .legal-wrapper {
      background-color: #f8fafc; /* Un gris azulado extremadamente claro */
      max-width: 1000px; /* Ancho optimizado para lectura */
      margin: 0px auto;
      padding: 25px 25px;
      font-family: 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
      line-height: 1.6;
  }

  /* CABECERA (HERO) */
  .legal-header {
      margin-bottom: 50px;
      border-left: 5px solid #01696f; /* Acento visual de marca */
      padding-left: 30px;
  }

  .legal-header h1 {
      color: #01696f;
      font-size: clamp(2rem, 5vw, 3rem); /* Tamaño fluido */
      font-weight: 800;
      margin: 0 0 20px 0;
      line-height: 1.1;
  }

  .legal-header p {
      color: #2d3748; /* Contraste alto para accesibilidad */
      font-size: 1.2rem;
      max-width: 75ch; /* Máximo 75 caracteres por línea (ideal lectura) */
      margin: 0;
  }

  /* ACORDEÓN */
  .accordion {
      width: 100%;
      margin-top: 5px;
  }

  .accordion-item {
      background-color: #ffffff;
      border: 1px solid #d1e3e7;
      border-radius: 12px;
      margin-bottom: 12px;
      overflow: hidden;
      transition: box-shadow 0.3s ease;
  }

  .accordion-item:hover {
      box-shadow: 0 4px 12px rgba(0,0,0,0.05);
  }

  /* BOTÓN DISPARADOR */
  .accordion-trigger {
      width: 100%;
      padding: 22px 30px;
      display: flex;
      justify-content: space-between;
      align-items: center;
      border: none;
      outline: none;
      background-color: #f0f7f9; /* El azulito claro que pediste */
      color: #01696f;
      cursor: pointer;
      font-size: 1.2rem;
      font-weight: 700;
      text-align: left;
  }

  /* Hover y Focus (Accesibilidad por teclado) */
  .accordion-trigger:hover, 
  .accordion-trigger:focus {
      background-color: #e2eff3 !important;
      text-decoration: underline;
  }

  .accordion-trigger[aria-expanded="true"] {
      background-color: #01696f !important;
      color: #ffffff !important;
  }

  /* ICONO +/- */
  .accordion-icon {
      position: relative;
      width: 18px;
      height: 18px;
      flex-shrink: 0;
  }

  .accordion-icon::before, .accordion-icon::after {
      content: "";
      position: absolute;
      background-color: currentColor;
      transition: transform 0.3s ease;
  }

  .accordion-icon::before { top: 8px; left: 0; width: 100%; height: 2px; }
  .accordion-icon::after { top: 0; left: 8px; width: 2px; height: 100%; }

  .accordion-trigger[aria-expanded="true"] .accordion-icon::after {
      transform: rotate(90deg);
      opacity: 0;
  }

  /* CONTENIDO */
  .accordion-panel {
      background: #fff;
  }

   .panel-content {
      padding: 5px;
      border-top: 1px solid #edf2f7;
      color: #4a5568;
  }

  .accordion-panel[hidden] {
      display: none;
  }

  /* Ajustes para móviles */
  @media (max-width: 768px) {
      .legal-header { padding-left: 20px; }
      .accordion-trigger { padding: 18px 20px; font-size: 1.1rem; }
      .panel-content { padding: 25px; }
  }

/* 1. Seleccionamos los títulos dentro del panel del acordeón */
 
.panel-content h3.u-text 
 {
    display: block;
    width: 100% !important;
    margin-bottom: 20px !important;
    padding-bottom: 10px !important;
    position: relative;
    border-bottom: 1px solid #d1e3e7; /* La raya directa es más fiable que el ::after */
}

/* 2. Si quieres que la raya sea de tu color corporativo verde */
.panel-content h3.u-text {
    color: #01696f !important;
    border-bottom-color: #01696f; /* Cambia a verde si prefieres */
}

/* 3. Ajuste de espaciado para que no se pegue el texto de abajo */
.panel-content p.u-text {
    margin-top: 15px !important;
}



/* Corrección para Tablas Responsivas en Móvil */
@media (max-width: 768px) {
    .u-table-responsive {
        display: block;
        width: 100%;
        overflow-x: auto; /* Permite scroll horizontal */
        -webkit-overflow-scrolling: touch; /* Scroll suave en iOS */
        word-break: normal;
        white-space: nowrap; /* Evita que el texto se amontone demasiado */
    }

    .u-table-entity {
        min-width: 600px; /* Fuerza un ancho mínimo para que los datos sean legibles */
    }
    
    .u-table-entity td, .u-table-entity th {
        white-space: normal; /* Permite que el texto de la descripción salte de línea */
        min-width: 120px;
        font-size: 14px; /* Texto un poco más pequeño para móviles */
        padding: 10px !important;
    }
}