/*
Theme Name: Sitio Web IAC.
Author: Citiaps
Description: Tema personalizado para el sitio web de IAC.
Version: 2.0
*/
/* Estilos General*/

.main-default{
  min-height: 60vh;
}

.page-documentos{
  min-height: 60vh;
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  font-family: 'HelveticaNeueLTStd-Cn', sans-serif;
}

h1, h2, h3, h4, h5, h6 {
  font-family: 'BebasNeuePro-SemiExpRegular', sans-serif;
}

h1 {
  font-size: 2.5em;
  color: #666;
}

h2{
  font-size: 1.8em;
  color: #666;
}

h3{
  font-size: 1.6em;
  color: #E77500;
}

h4{
  font-size: 1.4em;
  color: #666;
}

h5{
  font-size: 1.2em;
  color: #666;
}

h6{
  font-size: 1em;
  color: #666;
}

p{
  font-size: 1.5em;
  color: #666;
  text-align: justify;
}

a {
  color: #E77500;
  text-decoration: none;
}
a:hover {
  color: #00A499;
}


ul {
  font-size: 1.4em;
  color: #666;
  text-align: justify;
}
ol {
  font-size: 1.4em;
  color: #666;
  text-align: justify;
}

::marker{
  color: #808080;
  font-size: 1em;
}

@media (max-width: 768px) {
  h1 {
    font-size: 2em;
  }
  h2 {
    font-size: 1.6em;
  }
  h3 {
    font-size: 1.4em;
  }
  h4 {
    font-size: 1.2em;
  }
  h5 {
    font-size: 1em;
  }
  h6 {
    font-size: 0.8em;
  }
  p {
    font-size: 1.2em;
  }
  a {
    font-size: 1.2em;
  }
  ul {
    font-size: 1.2em;
  }
  ol {
    font-size: 1.2em;
  }
  ::marker{
    font-size: 1em;
  }
}

/* ------------------- */
/* Estilos Header */
/* ------------------- */
.main-navegation {
  display: flex;
  flex-direction: column;
}

.color-bar {
  display: flex;
  height: 10px;
}

.color {
  height: 100%;
}

.turquoise {
  flex: 5; /* 50% */
  background-color: #00A499; 
}

.purple {
  flex: 3; /* 30% */
  background-color: #8C4799;  
}

.orange {
  flex: 2; /* 20% */
  background-color: #ffa040;
}

.logo-institucional {
  margin-left: 191px;
}

.logo-image {
  padding: 1rem;
  width: 400px;
}

.menu-container {
  padding: 1rem 0;
}

.nav-menu {
  font-family: 'BebasNeuePro-SemiExpRegular', sans-serif;
  max-width: 1470px;
  margin: 0 auto;
  list-style-type: none;
  padding: 0;
  display: flex;
  justify-content: flex-end;
}

.nav-menu li {
  margin: 0 10px;
}

.nav-menu a {
  text-decoration: none;
  color: #808080;
  font-size: 18px;
  font-weight: 500;
  transition: color 0.3s ease;
  position: relative;
  padding-bottom: 5px;
}

.nav-menu a:hover,
.nav-menu .current-menu-item > a {
  color: #f0f0f0;
}

.nav-menu .current-menu-item > a {
  color: #E77500;
}

.nav-menu a:hover {
  color: #E77500;
}

.hamburger-icon {
  display: none;
  cursor: pointer;
}

.hamburger-icon img {
  width: 30px;
}

.menu-container .nav-menu .sub-menu {
  display: none;
}

/* Responsive Styles */

@media (max-width: 768px) {


  .hidden-responsive {
    display: none;
  }

  .main-navigation {
      position: relative;
  }

  .logo-institucional {
      margin-left: 0;
      width: 100%;
  }

  .logo-image {
      padding: 1rem;
      width: 300px; /* Unificación */
  }

  .nav-menu {
      display: none;
      flex-direction: column;
      gap: 20px;
      background-color: #525252;
      width: 100%;
      position: absolute;
      top: 0;
      left: 0;
      padding: 1rem;
      box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
      z-index: 1000;
      flex-wrap: wrap; /* Unificación */
      justify-content: center;
  }


  .nav-menu a {
    font-size: 1.5em; /* Unificación */
    padding: 10px; /* Unificación */
    color: #fff; /* Unificación */
  }

  .nav-menu li {
      margin: 10px 0; /* Unificación */
  }

  .nav-menu a {
      font-size: 20px; /* Unificación */
  }

  .nav-menu.open {
      display: flex;
      margin-top: 60px;
      justify-content: center;
      align-items: center;
  }

  .menu-container {
      display: flex;
      justify-content: flex-end;
      align-items: center;
      background-color: #ffffff;
      font-family: "BebasNeuePro-SemiExpRegular", sans-serif;
  }

  .menu-container .nav-menu .sub-menu {
      display: block;
      margin-left: 20px;
  }

  /* .menu-container .nav-menu .sub-menu a {
      font-size: 1.2em;
  } */

  .hamburger-icon {
      display: block;
      padding: 1rem;
  }

  .menu-item {
    width: 100%;
  }
}


/* ------------------- */
/* Estilos básicos para el footer */
/* ------------------- */
.footer {
  background-color: #394049;
  color: #fff;
  padding-bottom: 30px;
  padding-top: 10px;
  flex-shrink: 0;
  width: 100%;
  margin-top: auto;
}

.hr{
  border: 1px solid #666;
}

.footer-container {
  padding-top: 30px;
  display: flex;
  justify-content: space-around;
  align-items: center;
  flex-direction: row;
  margin: 0 auto;
  max-width: 1700px;
  gap: 20px;
}

.footer-item {
  text-align: start;
  padding: 10px;
  font: 0.9em 'HelveticaNeueLTStd-Cn', sans-serif;
  margin: 10px;
  width: 100%;

  display: flex;
  justify-content: center;
  align-items: center;

  flex-direction: column;
  gap: 20px;
}

.footer-item img {
  width: 40%;
}

.footer-item a {
  color: #fff;
  text-decoration: none;

  max-width: 100%;
  max-height: 100%;
}

.footer-item h3{
  max-width: 100%;
}

.footer-red-social {
  display: flex;
  justify-content: center;
  gap: 20px;
}

.footer-red-social img {
  width: 50px;
  height: 50px;
}

.footer-red-social img:hover {
  transform: scale(1.1);
}

@media (max-width: 768px) {
  .footer-container {
    flex-direction: column;
  }

  .footer-item {
    width: 100%;
    align-items: center;
    justify-content: center;
  }
}

/* ------------------------- */
/* Estilos básicos para el slider */
/* ------------------------- */
.slider {
  position: relative;
  max-width: 100vw;
  margin: auto;
  overflow: hidden;
}

.slides {
  display: flex;
  transition: transform 0.5s ease-in-out;
  width: 100vw;
}

.slide {
  min-width: 100vw;
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

.slide-image {
  position: relative;
  width: 100%;
  height: 20vw;
  overflow: hidden;
}

.slide-image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.slide-content {
  position: absolute;
  bottom: 20px;
  left: 20px;
  background: rgba(0, 0, 0, 0.5);
  color: #fff;
  padding: 10px;
  border-radius: 5px;
}

/* Contenedor de navegación del slider */
.slider-nav {
  position: absolute;
  width: 100%;
  display: flex;
  justify-content: space-between;
  top: 50%;
  transform: translateY(-50%);
  padding: 0 20px;
  opacity: 0; /* Oculta las flechas por defecto */
  transition: opacity 0.3s ease;
}

.slider:hover .slider-nav {
  opacity: 1; /* Muestra las flechas al pasar el cursor sobre el slider */
}

.slider-nav .prev,
.slider-nav .next {
  color: #ffffff;
  cursor: pointer;
  user-select: none;
  border-radius: 50%;
  width: 50px;
  height: 50px;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: rgba(0, 0, 0, 0.308);
  font-size: 2em;
}


/* ------------------------- */
/* Estilos Index */
/* ------------------------- */
.section-index {
  display: flex;
  flex-direction: column;
  gap: 20px;
  padding: 20px;
  max-width: 1470px;
  margin: auto;
  align-items: left;
  width: 100%;
}

.br-index{
  border-bottom: 1px solid #666;
  margin-bottom: 20px;
}

/* video */

.video-section{
  display: flex;
  flex-direction: column;
  gap: 20px;
  background-color: #DAE9F9;
  border-radius: 10px;
  padding: 20px;
}

.video-section h2{
  font-size: 1.8em;
  color: #000000;
}

.video-item h3{
  color: #E77500;
  text-decoration: none;
  font-weight: 500;

  font-size: 1.5em;
  text-align: center;
}

.video-container {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(400px, 1fr));
  gap: 20px;
  justify-items: center;
  align-items: start;
  width: 100%;
}

.video-wrapper {
  width: 100%;
  display: flex;
  justify-content: center;
}

.video-item{
  width: 400px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  align-items: center;
  height: 100%;
  padding-bottom: 20px;

  border-top-left-radius: 15px;
  border-bottom-right-radius: 15px;
  background-color: #fff;
  padding: 20px;
  box-sizing: border-box;

  border-bottom: 3px solid #E77500;
  transition: all 0.3s ease;
}

.video-item:hover {
  border-bottom: 3px solid #00A499;
  box-shadow: 0 3px 8px rgba(0,0,0,0.1);
}

.video-button{
  width: 100%;
  padding-top: 20px;
  text-align: center;

  font-size: 1.2em;
  color: #E77500;
}

iframe {
  width: 100%;
  height: 300px;
  border: none;
  border-top-left-radius: 10px;
  
  overflow: hidden;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  transition: transform 0.5s;
}

@media (max-width: 768px) {
  .video-container {
    flex-direction: column;
    align-items: center;
    justify-content: center;

  }

  .video-item {
    width: 80%;
    height: 100%;
  }
  .video-item h3 {
    font-size: 1.2em;
  }
  .video-button {
    font-size: 1em;
  }

  iframe {
    height: 200px;
  }
}

/* Ultima edición */
.container-ultima-edicion{
  width: 100%;
}
.box-ultima-edicion {
  display: flex;
  flex-direction: row;
  gap: 20px;
}

@media (max-width: 768px) {
  .box-ultima-edicion {
    flex-direction: column;
    align-items: center;

  }
}

.item-foto-ultima-edicion{
  height: 480px;
}

.box-ultima-edicion img {
  width: 370px;
  height: 100%;

  object-fit: cover;
}
.item-info-ultima-edicion {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 40px;
}

.item-info-ultima-edicion .title{
  font-size: 1.8em;
  color: #E77500;
  text-decoration: none;
}

.item-info-ultima-edicion .title:hover{
  color: #00A499;
}

.item-archive-ultima-edicion {
  width: 100%;

  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}
.article-ultima-edicion{
  width: 100%;
  border-bottom: 1px solid #666;
  padding-bottom: 40px;
}

.article-ultima-edicion a{
  color: #00A499;
  text-decoration: none;
  font-size: 1.2em;
}
.article-ultima-edicion a:hover{
  color: #E77500;
}
.vermas-ultima-edicion{
  width: 100%;
  text-align: right;
}
.vermas-ultima-edicion a{
  color: #E77500;
  text-decoration: none;
}
.vermas-ultima-edicion a:hover{
  color: #00A499;
}

/* indexacion */
/* informativos */
.container-informativos,
.container-indexacion{
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 20px;
  justify-content: space-around;
  align-items: center;
}

.indexacion-section .box-indexacion {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  justify-items: center;
  align-items: start;
  width: 100%;
}

@media (max-width: 768px) {
  .container-informativos,
  .container-indexacion{
    flex-direction: column;
    align-items: center;
  }

  .indexacion-section .box-indexacion {
    grid-template-columns: repeat(1, 1fr);
  }

  .box-indexacion {
    display: flex;
    flex-direction: column;
    gap: 20px;
    align-items: center;
  }
}


.item-informativos,
.item-indexacion{
  width: 300px;
  height: 100px;
}

.item-informativos img,
.item-indexacion img{
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.item-informativos img:hover,
.item-indexacion img:hover{
  transform: scale(1.1);
  transition: transform 0.5s;
}

.ver-mas-indexacion{
  padding-top: 20px;
  width: 100%;
  text-align: center;
}
.ver-mas-indexacion a{
  color: #666;
  text-decoration: none;
  border: 1px solid #ddd;
  padding: 10px;
  background-color: #fff;
}
.ver-mas-indexacion a:hover{
  color: #E77500;
}

/* Noticias */
.container-noticias {
  width: 100%;
  display: flex;
  flex-direction: row;
  gap: 20px;
}

.box-noticias {
  display: grid;
  /* grid-template-columns: repeat(3, 1fr); */
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 20px;
  justify-items: center;
  align-items: start;
  width: 100%;
}

.item-noticias {
  width: 300px;
  height: 300px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 10px;
  border: 1px solid #ddd;
  padding: 10px;
  box-sizing: border-box;

  border-top-left-radius: 15px;
  border-bottom-right-radius: 15px;
  padding-bottom: 20px;
  
  border-bottom: 3px solid #E77500;
  transition: all 0.3s ease;
}

.item-noticias:hover {
  box-shadow: 0 3px 8px rgba(0,0,0,0.1);
  border-bottom: 3px solid #00A499;
}

.item-img-noticias {
  width: 100%;
  height: 150px;
}

.item-noticias img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-top-left-radius: 5px;
}

.item-description-noticias {
  height: 48px;
  overflow: hidden; /* Oculta el contenido adicional */
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2; /* Limita a 2 líneas */
  line-clamp: 2;
  overflow: hidden;
  text-overflow: ellipsis; /* Añade puntos suspensivos al final */
}

.item-date-noticias {
  color: #666;
  font-size: 1em;
}

@media (max-width: 768px) {

  .item-noticias {
    width: 90%;
    height: 100%;
  }


}

.item-noticias a {
  color: #666;
  text-decoration: none;
  text-align: justify;
  font-size: 1.2em;
}

.item-noticias a:hover {
  color: #00A499;
}

.ver-noticia {
  width: 100%;
  text-align: left;
}

.ver-noticia a {
  color: #E77500;
  text-decoration: none;
}

.ver-noticia a:hover {
  color: #00A499;
}

.ver-mas-noticias {
  padding-top: 20px;
  width: 100%;
  text-align: center;
  padding-bottom: 40px;
}

.ver-mas-noticias a {
  display: inline-block;
  padding: 12px 30px;
  background-color: #E77500;
  color: #fff;
  text-decoration: none;
  border-radius: 5px;
  font-size: 1em;
  font-weight: 500;
  transition: background-color 0.3s ease, transform 0.2s ease;
}

.ver-mas-noticias a:hover {
  background-color: #00A499;
  transform: translateY(-2px);
}

/* archive noticias */
.indexacion-section,
.noticia-section {
  display: flex;
  flex-direction: column;
  gap: 20px;
  padding: 20px;
  max-width: 1470px;
  margin: auto;
  align-items: left;
}

/* page noticias con sidebar */
.noticia-section-page {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.noticia-section-page h1 {
  font-size: 2.5em;
  color: #666;
  margin-bottom: 20px;
}

/* ------------------------------
   Página Prensa con Pestañas
------------------------------ */
.prensa-section-page {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.prensa-section-page h1 {
  font-size: 2.5em;
  color: #666;
  margin-bottom: 20px;
}

.prensa-tabs-container {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

/* Navegación de pestañas */
.prensa-tabs-nav {
  display: flex;
  gap: 10px;
  border-bottom: 2px solid #ddd;
  padding-bottom: 0;
  flex-wrap: wrap;
}

.prensa-tab-btn {
  background: transparent;
  border: none;
  padding: 12px 30px;
  font-family: 'BebasNeuePro-SemiExpRegular', sans-serif;
  font-size: 1.2em;
  color: #666;
  cursor: pointer;
  border-bottom: 3px solid transparent;
  transition: all 0.3s ease;
  position: relative;
  bottom: -2px;
}

.prensa-tab-btn:hover {
  color: #E77500;
  background: rgba(231, 117, 0, 0.05);
}

.prensa-tab-btn.active {
  color: #E77500;
  border-bottom-color: #E77500;
  font-weight: bold;
}

/* Contenido de las pestañas */
.prensa-tabs-content {
  width: 100%;
  padding: 20px 0;
}

.prensa-tab-panel {
  display: none;
}

.prensa-tab-panel.active {
  display: block;
  animation: fadeIn 0.3s ease-in;
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Grids para cada sección */
.entrevistas-box {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 20px;
  width: 100%;
}

.videos-box-prensa {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 20px;
  width: 100%;
}

/* Estilos para items de entrevistas (igual que columnas) */
.item-entrevista {
  background: #fff;
  border: 1px solid #ddd;
  border-radius: 8px;
  overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  display: flex;
  flex-direction: column;
}

.item-entrevista:hover {
  transform: translateY(-5px);
  box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

.item-img-entrevista {
  width: 100%;
  height: 200px;
  overflow: hidden;
}

.item-img-entrevista img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}

.item-entrevista:hover .item-img-entrevista img {
  transform: scale(1.05);
}

.item-description-entrevista {
  padding: 15px;
  flex-grow: 1;
}

.item-description-entrevista a {
  text-decoration: none;
  color: #333;
  font-size: 1.1em;
  font-weight: bold;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.item-description-entrevista a:hover {
  color: #E77500;
}

.fecha-entrevista {
  padding: 0 15px;
  color: #666;
  font-size: 0.9em;
  margin-bottom: 10px;
}

.ver-entrevista {
  padding: 15px;
  text-align: center;
}

.ver-entrevista a {
  display: inline-block;
  padding: 8px 20px;
  background: #E77500;
  color: #fff;
  text-decoration: none;
  border-radius: 5px;
  transition: all 0.3s ease;
  font-size: 0.9em;
}

.ver-entrevista a:hover {
  background: #00A499;
  transform: translateY(-2px);
}

/* Estilos para videos en página prensa */
.item-video-prensa {
  background: #fff;
  border: 1px solid #ddd;
  border-radius: 8px;
  overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  display: flex;
  flex-direction: column;
}

.item-video-prensa:hover {
  transform: translateY(-5px);
  box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

.video-link-prensa {
  text-decoration: none;
  color: inherit;
}

.video-thumbnail-prensa {
  position: relative;
  width: 100%;
  padding-bottom: 56.25%; /* Aspect ratio 16:9 */
  overflow: hidden;
  background: #000;
}

.video-thumbnail-prensa img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.play-button-prensa {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  opacity: 0.9;
  transition: opacity 0.3s ease, transform 0.3s ease;
}

.item-video-prensa:hover .play-button-prensa {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1.1);
}

.video-title-prensa {
  padding: 15px;
}

.video-title-prensa h3 {
  font-size: 1.1em;
  color: #333;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.video-link-prensa:hover .video-title-prensa h3 {
  color: #E77500;
}

.video-descripcion-prensa {
  padding: 0 15px 15px;
  color: #666;
  font-size: 0.9em;
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Responsive para pestañas */
@media (max-width: 768px) {
  .prensa-tabs-nav {
    flex-direction: column;
    gap: 0;
    border-bottom: none;
  }
  
  .prensa-tab-btn {
    border-bottom: 1px solid #ddd;
    border-left: 3px solid transparent;
    bottom: 0;
    text-align: left;
  }
  
  .prensa-tab-btn.active {
    border-bottom: 1px solid #ddd;
    border-left-color: #E77500;
  }
  
  .entrevistas-box,
  .videos-box-prensa {
    grid-template-columns: 1fr;
  }
}

.indexacion-container,
.noticia-container {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.indexacion-title,
.noticia-titulo{
  font-size: 1.8em;
}

.noticia-box {
  display: grid;
  /* grid-template-columns: repeat(3, 1fr); */
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 20px;
  justify-items: center;
}

.fecha-noticia{
  color: #666;
  font-size: 1em;
}

.pagination {
  display: flex;
  justify-content: center;
  gap: 20px;
}

.pagination a {
  color: #E77500;
  text-decoration: none;
}

.pagination a:hover {
  color: #00A499;
}


/*single noticia*/
.single-noticia{
  display: flex;
  flex-direction: row;
  gap: 40px;
  padding: 20px;
  max-width: 1470px;
  margin: auto;
  align-items: left;

  margin-bottom: 20px;
}

.single-noticia-imagen {
  width: 400px; /* Fijás un ancho */
  flex-shrink: 0; /* Evita que se encoja si el contenedor es más chico */
  display: flex;
  align-items: flex-start;
}

.single-noticia-imagen img {
  width: 100%;       /* Se adapta al contenedor */
  height: auto;      /* Mantiene la proporción */
  object-fit: contain; /* Asegura que no se recorte nada */
}


.single-noticia-content{
  max-width: 70%;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

/* ------------------------------
   Single Entrevista (mismo estilo que single noticia)
------------------------------ */
.single-entrevista{
  display: flex;
  flex-direction: row;
  gap: 40px;
  padding: 20px;
  max-width: 1470px;
  margin: auto;
  align-items: left;
  margin-bottom: 20px;
}

.single-entrevista-imagen {
  width: 400px;
  flex-shrink: 0;
  display: flex;
  align-items: flex-start;
}

.single-entrevista-imagen img {
  width: 100%;
  height: auto;
  object-fit: contain;
}

.single-entrevista-content{
  max-width: 70%;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

/* ------------------------------
   Single Columna de Opinión (mismo estilo)
------------------------------ */
.single-columna-opinion {
  display: flex;
  flex-direction: row;
  gap: 40px;
  padding: 20px;
  max-width: 1470px;
  margin: auto;
  align-items: left;
  margin-bottom: 20px;
}

.single-columna-opinion-imagen {
  width: 400px;
  flex-shrink: 0;
  display: flex;
  align-items: flex-start;
}

.single-columna-opinion-imagen img {
  width: 100%;
  height: auto;
  object-fit: contain;
}

.single-columna-opinion-content{
  max-width: 70%;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

@media (max-width: 768px) {
  .single-noticia{
    flex-direction: column;
    align-items: center;
  }

  .single-noticia-imagen {
    width: 100%;
    flex-shrink: 0;
    display: flex;
    align-items: center;
  }

  .single-noticia-content{
    max-width: 100%;
    display: flex;
    flex-direction: column;
    gap: 20px;
  }

  .single-entrevista{
    flex-direction: column;
    align-items: center;
  }

  .single-entrevista-imagen {
    width: 100%;
    flex-shrink: 0;
    display: flex;
    align-items: center;
  }

  .single-entrevista-content{
    max-width: 100%;
    display: flex;
    flex-direction: column;
    gap: 20px;
  }

  .single-columna-opinion{
    flex-direction: column;
    align-items: center;
  }

  .single-columna-opinion-imagen {
    width: 100%;
    flex-shrink: 0;
    display: flex;
    align-items: center;
  }

  .single-columna-opinion-content{
    max-width: 100%;
    display: flex;
    flex-direction: column;
    gap: 20px;
  }
}

/* ------------------------- */


/* otros numeros */
.main-otros-numeros {
  background-color: #DAE9F9;
  padding-bottom: 20px;
}

.container-otros-numeros {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.box-otros-numeros {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  justify-items: center;
}

.item-otros-numeros {
  border: 1px solid #ddd;
  display: flex;
  flex-direction: column; /* Cambio para apilar elementos verticalmente */
  align-items: center; /* Centra los elementos en la columna */
  width: 350px;
  padding: 10px;
  gap: 10px;
  background-color: #fff;
}

.item-otros-numeros:hover {
  transform: scale(1.1);
  transition: transform 0.5s;
}

.item-img-otros-numeros {
  flex-shrink: 0;
  width: 150px;
  height: 200px;
}

.item-otros-numeros img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.item-otros-numeros a {
  color: #E77500;
  text-decoration: none;
  white-space: normal;
  word-wrap: break-word;
  text-align: center;
  font-size: 1.2em;

}

.item-otros-numeros a:hover {
  color: #00A499;
}

.ver-mas-otros-numeros {
  padding-top: 20px;
  width: 100%;
  text-align: center;
}

.ver-mas-otros-numeros a {
  color: #666;
  text-decoration: none;
  border: 1px solid #ddd;
  padding: 10px;
  background-color: #fff;
}

.ver-mas-otros-numeros a:hover {
  color: #E77500;
}

.img-badge {
  position: absolute;
  background-color: rgba(0, 0, 0, 0.7);
  color: white;
  padding: 0.4em 0.6em;
  border-bottom-right-radius: 0.5em;
  font-size: 120%;
}


/* ------------------------- */
/* Estilos para la página default */
/* ------------------------- */
.main-default {
  display: flex;
  flex-direction: row;
  gap: 20px;
  padding: 20px;  
  padding-bottom: 4rem;
  max-width: 1470px;
  margin: auto;
  align-items: left;

  font-size: 0.8em;
}

.main-default section{
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.main-default ul {
  padding-left: 20px;
}

.main-default ol {
  padding-left: 20px;
}

.main-default aside:not(:has(> ul:empty)) {
  width: 30%;
}

.main-default aside ul {
  padding-left: 20px;
  padding-right: 20px;
}

.main-default aside ul li{
  padding: 10px;
  width: 100%;
  border-bottom: 1px solid #E77500;
}

.main-default aside ul li ul li{
  border-bottom: none;
  font-size: 0.7em;
}

.main-default aside li a.active {
  color: #E77500;
}

.main-default aside ul li a{
  color: #808080;
  text-decoration: none;
  font-size: 1em;
}

.main-default aside ul li a:hover{
  color: #00A499;
}

.main-default section{
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 20px;
}



/* ------------------------- */
/* Responsive Styles for Small Devices */
@media (max-width: 576px) {
  /* Slider */
  .slide-image {
    height: 30vw;
  }

  /* Content Sections */
  .section-index,
  .indexacion-section,
  .informativos-index,
  .noticia-section,
  .container-otros-numeros,
  .main-cuerpo-editorial,
  .main-default{
    padding: 10px;
    margin-bottom: 20px;
    width: 100%;
  }

  /* Layouts in Grid */
  .box-informativos,
  .box-noticias,
  .noticia-box,
  .box-otros-numeros {
    grid-template-columns: 1fr;
  }


}





/* ------------------------- */
/* Estilos aside index */
/* ------------------------- */

.index{
  display: flex;
  flex-direction: row;
  gap: 20px;
  padding: 20px;
  max-width: 1470px;
  margin: auto;
  align-items: center;
  justify-content: center
}

.index aside {
  width: 30%;
}

.index .content {
  width: 70%;
  display: flex;
  flex-direction: column;
}

.aside-index{
  display: flex;
  flex-direction: column;
  gap: 40px;
}

.informativos-index{
  padding: 20px;
}

@media (max-width: 768px) {
  .index {
    flex-direction: column;
  }

  .index aside {
    width: 100%;
  }

  .index .content {
    width: 100%;
  }
}

/* ------------------------- */
/* Estilos para la página de nosotros (academicos/funcionarios) */
/* ------------------------- */

.academicos{
  display: flex;
  flex-direction: column;
  margin: 1rem auto;
  align-items: left;
  width: 100%;
}

.academicos-1{
  display: flex;
  flex-direction: column;
  margin: auto;
  align-items: left;
  width: 100%;
}

.academicos-1 h1{
margin-bottom: 1rem;
}


.miembros-directivo {
  padding-top: 2rem;
  padding-bottom: 2rem;
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  width: 100%;
  justify-content: center;
}

.miembros {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  justify-content: center;
  align-content: center;
}

.miembro {
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
  box-sizing: border-box;
  padding: 10px;
  display: flex;
  flex-direction: column;
  align-items: center;
  background-color: #fff;
  row-gap: 20px;
  border-radius: 10px;
  width: 250px;
}

.miembro h3 {
  font-family: "HelveticaNeueLTStd-Cn", sans-serif;
  font-size: 20px;
  color: rgb(0, 164, 153);
  font-weight: 600;
  text-align: center;
}

.miembro-detalle {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  row-gap: 1px;
}

.miembro-correo{
  font-size: 16px;
  font-family: 'HelveticaNeueLTStd-Cn', sans-serif;
  font-weight: 500;
  color: rgb(57, 64, 73);
}

.miembro-rol{
  font-size: 20px;
  font-family: 'HelveticaNeueLTStd-Cn', sans-serif;
  font-weight: 700;
  color: rgb(234, 118, 0);
  text-align: center;
}

.miembro-telefono{
  font-size: 16px;
  font-family: 'HelveticaNeueLTStd-Cn', sans-serif;
  font-weight: 500;
  color: rgb(57, 64, 73);
}

.miembro-grado{
  font-size: 16px;
  font-family: 'HelveticaNeueLTStd-Cn', sans-serif;
  font-weight: 500;
  color: rgb(140, 71, 153);
  text-align: center;
}

.miembro-linea-trabajo{
  font-size: 15px;
  font-family: 'HelveticaNeueLTStd-Cn', sans-serif;
  font-weight: 400;
  color: rgb(102, 102, 102);
  text-align: center;
  font-style: italic;
}

.miembro-imagen img {
  width: 200px;
  height: 200px;
  object-fit: cover;
  border-radius: 50%;
  display: block;
  margin: 0 auto;
}

/* ------------------------- */
/* Estilos para la single miembro */
/* ------------------------- */

.seccion-miembro {
  display: flex;
  flex-direction: column;
  gap: 20px;
  padding: 20px;
  max-width: 1300px;
  margin: auto;
  align-items: left;
}
.cuerpo-miembro {
  display: flex;
  flex-direction: row;
  width: 100%;
  gap: 100px;
  padding: 20px;
  margin: auto;
  align-items: flex-start; /* Esto asegura que la imagen y los datos se alineen al principio */
}

.foto-miembro {
  flex: 0 0 15%;
  display: flex;
  justify-content: center;
  align-items: center;
}

.foto-miembro img {
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  object-fit: cover;
}

.datos-miembro {
  flex: 0 0 70%;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.datos-miembro h4 {
  font-weight: 500;
  font-size: 1.5em;
  
}


@media (max-width: 768px) {
  .cuerpo-miembro {
    flex-direction: column;
    align-items: center;
    gap: 30px;
  }

  .foto-miembro {
    flex: 0 0 100%;
    display: flex;
    justify-content: center;
    align-items: center;
  }

  .datos-miembro {
    flex: 0 0 100%;
    display: flex;
    flex-direction: column;
    gap: 20px;
    align-items: center;
  }
}


/* Estilos lista summary */
summary {
  font-size: 2em;
  font-weight: 700;
  color: #E77500;
  padding: 10px;
  cursor: pointer;
  list-style: none;
}

summary:hover {
  color: #00A499;
}

.summary-content{
  padding-left: 20px;
  padding-right: 20px;
}

details {
  border-bottom: 1px solid #afafaf;
  overflow: hidden;
  transition: height 0.3s ease-in-out;
}

details[open] {
  transition: height 0.3s ease-in-out;
}

@media (max-width: 768px) {
  .wp-block-group {
    display: flex;
    flex-direction: column;
    gap: 20px;
  }
}

/* Estilos para la eventos del index */

.doc-container{
  display: flex;
  flex-direction: column;
  gap: 5px;
  padding: 20px;
  margin: auto;
  align-items: center;
}

@media (max-width: 768px) {
  .doc-container{
    width: 100%;
  }

  .doc-container .evento-container {
    width: 100%;
    max-width: 100%;
  }

  .doc-container .evento-link {
    width: 100%;
  }
  
}

.evento-link {
  display: block;
  text-decoration: none;
  color: inherit;
  margin-bottom: 15px;
  width: 100%;
}

.evento-container {
  display: flex;
  align-items: center;
  border: 1px solid #e0e0e0;
  border-radius: 5px;
  padding: 15px;
  transition: all 0.3s ease;

}



.evento-container:hover {
  box-shadow: 0 3px 8px rgba(0,0,0,0.1);
}

.evento-fecha {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: 60px;
  text-align: center;
}

.evento-dia {
  font-size: 28px;
  font-weight: bold;
  color: #555;
  line-height: 1;
}

.evento-mes {
  font-size: 18px;
  color: #777;
  text-transform: uppercase;
}

.evento-separador {
  width: 2px;
  height: 50px;
  background-color: #00A499;
  margin: 0 15px;
}

.evento-info {
  flex-grow: 1;
}

.evento-info h4 {
  margin: 0 0 5px 0;
  font-size: 18px;
  color: #00A499;
}

.evento-fecha-completa {
  font-size: 14px;
  color: #777;
}
/* 
.tribe-common-c-btn
.tribe-common-c-btn-border */

.tribe-common-c-btn-border {
  border: 1px solid #E77500 !important;
  color: #E77500 !important;
  text-decoration: none !important;
}
.tribe-common-c-btn-border:hover {
  background-color: #E77500 !important;
  color: #fff !important;
}
.tribe-common-c-btn {
  background-color: #E77500 !important;
  color: #fff !important;
  text-decoration: none !important;
}
.tribe-common-c-btn:hover {
  background-color: #00A499 !important;
  color: #fff !important;
}


/* 
  Estilos para la página de Documetos
*/
.page-documentos {
  display: flex;
  width: 100%;
  max-width: 1270px;
  margin: 0 auto;
  padding-bottom: 20px;
  padding-top: 20px;
  flex-direction: column;
  gap: 20px;
}

.page-documentos h1{
  font-size: 2.5em;
}


/* Estilos para el contenedor de filtrar */
.filtrar-tipo-documento {
  position: relative;
  display: inline-block;

  
  margin-right: -1px;
}

/* Estilos para el título "Filtrar" (botón) */
.filtrar-tipo-documento h4 {
  display: inline-block;
  font-weight: 400;
  color: #fff;
  text-align: center;
  vertical-align: middle;
  user-select: none;
  background-color: #E77500;
  border: 1px solid #cc6600;
  padding: 0.375rem 0.75rem;
  font-size: 1rem;
  line-height: 1.5;
  border-top-left-radius: 0.25rem;
  border-bottom-left-radius: 0.25rem;
  transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
  cursor: pointer;
}

.filtrar-tipo-documento h4:hover {
  color: #fff;
  background-color: #cc6600;
  border-color: #cc6600;
}

/* Pequeño triángulo indicador */
.filtrar-tipo-documento h4:after {
  content: "▼";
  margin-left: 8px;
  font-size: 12px;
}

.filtrar-tipo-documento h4:active {
  color: #fff;
  background-color: #cc6600;
  border-color: #cc6600;
}


/* Estilos para la lista desplegable */
.filtrar-tipo-documento .tipo-documento {
  position: absolute;
  display: none;
  list-style: none;
  padding: 0;
  margin: 0;
  background-color: white;
  border: 1px solid #ddd;
  border-radius: 4px;
  box-shadow: 0 2px 5px rgba(0,0,0,0.2);
  min-width: 150px;
  z-index: 100;

}

/* Mostrar la lista al pasar el cursor sobre el contenedor */
.filtrar-tipo-documento:hover .tipo-documento {
  display: block;
}

/* Estilos para cada elemento de la lista */
.filtrar-tipo-documento .tipo-documento li {
  padding: 0;
  margin: 0;
}

.filtrar-tipo-documento .tipo-documento li a {
  display: block;
  padding: 10px 15px;
  text-decoration: none;
  color: #333;
  transition: background-color 0.2s;

  font-family: 'HelveticaNeueLTStd-Cn', sans-serif;
  font-size: 16px;
  font-weight: 400;
  
}

.filtrar-tipo-documento .tipo-documento li a:hover {
  background-color: #f5f5f5;
  color: #00A499
}


.documentos-tabla {
  width: 100%;
  border-collapse: collapse;
  margin: 20px 0;
}

.documentos-tabla thead {
  background-color: #f4f4f4;
}

.documentos-tabla th, .documentos-tabla td {
  padding: 10px;
  border: 1px solid #ddd;
}

.documentos-tabla th a {
  text-decoration: none; /* Quitar subrayado */
  color: inherit; /* Heredar el color del encabezado */
  display: inline-block; /* Mantener el comportamiento en línea */
}

.documentos-tabla th a:hover {
  color: inherit; /* Evitar cambio de color al pasar el cursor */
}


.documentos-tabla .tipo-archivo {
  text-align: center;
  vertical-align: middle;
  width: 80px;
}

.documentos-tabla .descargar-archivo {
  text-align: center;
  vertical-align: middle;
  width: 150px;
}

.documentos-tabla .fecha-publicacion {
  text-align: center;
  vertical-align: middle;
  width: 150px;

  font-size: 14px;
}




.documentos-tabla .tipo-archivo img {
  width: 24px;
  height: auto;
}

.documentos-tabla .nombre-documento h2 {
  font-size: 16px;
  margin: 0;
}

.documentos-tabla .nombre-documento p {
  font-size: 12px;
  color: #555;
}

.documentos-tabla .btn-download {
  display: inline-block;
  padding: 8px 12px;
  background-color: #E77500;
  color: white;
  text-decoration: none;
  border-radius: 4px;
  font-size: 14px;
}

.documentos-tabla .btn-download:hover {
  background-color: #cc6600;
}

@media (max-width: 768px) {
  .page-documentos {
    padding: 0 20px;
  }

  .documentos-tabla .tipo-archivo {
    width: 25px;
  }

  .documentos-tabla .descargar-archivo {
    width: 50px;
  }

}


/* Formulario de búsqueda */
.searchform .input-group {
  display: flex;
  flex-wrap: nowrap;
  align-items: stretch;
  width: 100%;
  max-width: 600px;
  margin: 0 auto;
  border-radius: 4px;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.searchform .form-control,
.searchform .form-control-2 {
  display: block;
  width: 100%;
  padding: 0.375rem 0.75rem;
  font-size: 1rem;
  line-height: 1.5;
  color: #495057;
  background-color: #fff;
  background-clip: padding-box;
  border: 1px solid #ced4da;
  border-top-left-radius: 0.25rem;
  border-bottom-left-radius: 0.25rem;
  transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}

.searchform .form-control.else{
  border-top-left-radius: 0rem;
  border-bottom-left-radius: 0rem;
}

.searchform .form-control-2{
  border-top-right-radius: 0.25rem;
  border-bottom-right-radius: 0.25rem;
}

.searchform .form-control:focus,
.searchform .form-control-2:focus {
  border-color: #E77500;
  outline: 0;
  box-shadow: 0 0 0 0.2rem rgba(0, 164, 153, 0.255);
}

.searchform .input-group-append {
  display: flex;
  margin-left: -1px;
}

.searchform .btn {
  display: inline-block;
  font-weight: 400;
  color: #fff;
  text-align: center;
  vertical-align: middle;
  user-select: none;
  background-color: #E77500;
  border: 1px solid #cc6600;
  padding: 0.375rem 0.75rem;
  font-size: 1rem;
  line-height: 1.5;
  border-top-right-radius: 0.25rem;
  border-bottom-right-radius: 0.25rem;
  transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
  cursor: pointer;
}

.searchform .btn:hover {
  color: #fff;
  background-color: #cc6600;
  border-color: #cc6600;
}

.searchform .btn:active {
  color: #fff;
  background-color: #cc6600;
  border-color: #cc6600;
}

/* Estilos para plantilla de miembro - Versión sobria */

/* Contenedor principal */
.perfil-academico {
  max-width: 1300px;
  margin: 0 auto;
  padding: 2rem 1rem;
  font-family: 'HelveticaNeueLTStd-Cn', sans-serif;
}

.perfil-academico h1 {
  color: #525252;
  font-size: 2.2em;
  margin-bottom: 0.5rem;
  position: relative;
  padding-bottom: 0.5rem;
  width: fit-content;
}

/* Sección principal con foto e información básica */
.perfil-principal {
  display: flex;
  flex-direction: row;
  gap: 2.5rem;
  margin: 2rem 0;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid #ddd;
}

/* Foto del académico */
.perfil-foto {
  width: 230px;
  flex-shrink: 0;
}

.perfil-foto img {
  width: 100%;
  height: 230px;
  border-radius: 50%;
  object-fit: cover;
}

/* Información básica */
.perfil-info {
  flex: 1;
}

.perfil-campo {
  margin-bottom: 1rem;
  display: flex;
  flex-direction: row;
  align-items: baseline;
}

.perfil-etiqueta {
  color: #E77500;
  font-weight: 500;
  min-width: 70px;
  margin-right: 0.5rem;
  font-size: 1.1rem;
}

.perfil-valor {
  color: #666;
  font-size: 1.1rem;
}

.perfil-biografia {
  margin-top: 1rem;
}

.perfil-biografia p {
  color: #666;
  font-size: 1.1rem;
  line-height: 1.6;
  margin-bottom: 1rem;
  text-align: justify;
}

/* Sección de contacto */
.perfil-contacto {
  margin-top: 1.5rem;
}

.perfil-contacto h2 {
  color: #E77500;
  font-size: 1.5rem;
  margin-bottom: 1rem;
  font-weight: 500;
}

/* Estilos responsivos */
@media (max-width: 992px) {
  .perfil-principal {
    gap: 2rem;
  }
  
  .perfil-foto {
    width: 200px;
  }
  
  .perfil-foto img {
    height: 200px;
  }
}

@media (max-width: 768px) {
  .perfil-academico {
    padding: 1.5rem 1rem;
  }
  
  .perfil-academico h1 {
    width: 100%;
    text-align: center;
  }
  
  .perfil-principal {
    flex-direction: column;
    align-items: center;
    text-align: center;
    margin: 0;
    padding: 0;
  }
  
  .perfil-foto {
    width: 180px;
    margin-bottom: 1rem;
  }
  
  .perfil-foto img {
    height: 180px;
  }
  
  .perfil-campo {
    flex-direction: column;
    align-items: center;
  }
  
  .perfil-etiqueta {
    margin-bottom: 0.3rem;
  }
  
  .perfil-contacto h2 {
    text-align: center;
  }
}

@media (max-width: 576px) {
  .perfil-academico h1 {
    font-size: 1.8em;
  }
  
  .perfil-biografia p,
  .perfil-valor,
  .perfil-etiqueta {
    font-size: 0.9rem;
  }
}

/* ========================================= */
/* Estilos para la sección de Videos (Home) */
/* ========================================= */

.section-videos {
  background-color: #f9f9f9;
  border-radius: 10px;
  padding: 30px 20px;
  margin-top: 40px;
}

.section-videos h2 {
  font-size: 1.8em;
  color: #666;
  margin-bottom: 30px;
  text-align: left;
}

.container-videos {
  width: 100%;
}

.box-videos {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 30px;
  width: 100%;
  margin-bottom: 20px;
}

.item-video {
  position: relative;
  background-color: #fff;
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.item-video:hover {
  transform: translateY(-5px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.video-link {
  display: block;
  text-decoration: none;
  color: inherit;
}

.item-img-video {
  position: relative;
  width: 100%;
  padding-bottom: 56.25%; /* Aspect ratio 16:9 */
  overflow: hidden;
  background-color: #000;
}

.item-img-video img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: opacity 0.3s ease;
}

.item-video:hover .item-img-video img {
  opacity: 0.85;
}

/* Overlay con botón de play */
.video-play-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: rgba(0, 0, 0, 0.3);
  transition: background-color 0.3s ease;
}

.item-video:hover .video-play-overlay {
  background-color: rgba(0, 0, 0, 0.5);
}

.play-button {
  transform: scale(1);
  transition: transform 0.3s ease;
}

.item-video:hover .play-button {
  transform: scale(1.2);
}

.play-button svg {
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.3));
}

/* Descripción del video */
.item-description-video {
  padding: 20px;
  background-color: #fff;
}

.item-description-video h3 {
  font-size: 1.3em;
  color: #333;
  margin-bottom: 10px;
  font-weight: 600;
  line-height: 1.3;
  transition: color 0.3s ease;
  
  /* Limitar a 2 líneas */
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}

.item-video:hover .item-description-video h3 {
  color: #E77500;
}

.video-excerpt {
  font-size: 0.95em;
  color: #666;
  line-height: 1.5;
  margin: 0;
  text-align: left;
  
  /* Limitar a 3 líneas */
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Botón "Más videos" */
.ver-mas-videos {
  padding-top: 30px;
  width: 100%;
  text-align: center;
}

.ver-mas-videos a {
  display: inline-block;
  padding: 12px 30px;
  background-color: #E77500;
  color: #fff;
  text-decoration: none;
  border-radius: 5px;
  font-size: 1em;
  font-weight: 500;
  transition: background-color 0.3s ease, transform 0.2s ease;
}

.ver-mas-videos a:hover {
  background-color: #00A499;
  transform: translateY(-2px);
}

/* Responsive */
@media (max-width: 992px) {
  .box-videos {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
  }
  
  .item-description-video h3 {
    font-size: 1.2em;
  }
  
  .video-excerpt {
    font-size: 0.9em;
  }
}

@media (max-width: 768px) {
  .section-videos {
    padding: 20px 15px;
    margin-top: 20px;
  }
  
  .section-videos h2 {
    font-size: 1.8em;
    text-align: center;
  }
  
  .box-videos {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  
  .item-description-video {
    padding: 15px;
  }
  
  .item-description-video h3 {
    font-size: 1.1em;
  }
  
  .video-excerpt {
    font-size: 0.85em;
    -webkit-line-clamp: 2;
  }
  
  .ver-mas-videos a {
    font-size: 1em;
    padding: 10px 25px;
  }
}

@media (max-width: 576px) {
  .play-button svg {
    width: 48px;
    height: 34px;
  }
}

/* ========================================= */
/* Estilos para Columnas de Opinión (Home) */
/* ========================================= */

/* Contenedor principal - igual que noticias */
.container-columnas-opinion {
  width: 100%;
  display: flex;
  flex-direction: row;
  gap: 20px;
}

.box-columnas-opinion {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 20px;
  justify-items: center;
  align-items: start;
  width: 100%;
}

.item-columnas-opinion {
  width: 300px;
  height: 300px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 10px;
  border: 1px solid #ddd;
  padding: 10px;
  box-sizing: border-box;

  border-top-left-radius: 15px;
  border-bottom-right-radius: 15px;
  padding-bottom: 20px;
  
  border-bottom: 3px solid #E77500;
  transition: all 0.3s ease;
}

.item-columnas-opinion:hover {
  box-shadow: 0 3px 8px rgba(0,0,0,0.1);
  border-bottom: 3px solid #00A499;
}

.item-img-columnas-opinion {
  width: 100%;
  height: 150px;
}

.item-columnas-opinion img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-top-left-radius: 5px;
}

.item-description-columnas-opinion {
  height: 48px;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  overflow: hidden;
  text-overflow: ellipsis;
}

.item-date-columnas-opinion {
  color: #666;
  font-size: 1em;
}

.item-columnas-opinion a {
  color: #666;
  text-decoration: none;
  text-align: justify;
  font-size: 1.2em;
}

.item-columnas-opinion a:hover {
  color: #00A499;
}

.ver-columna {
  width: 100%;
  text-align: left;
}

.ver-columna a {
  color: #E77500;
  text-decoration: none;
}

.ver-columna a:hover {
  color: #00A499;
}

.ver-mas-columnas-opinion {
  padding-top: 20px;
  width: 100%;
  text-align: center;
  padding-bottom: 40px;
}

.ver-mas-columnas-opinion a {
  display: inline-block;
  padding: 12px 30px;
  background-color: #E77500;
  color: #fff;
  text-decoration: none;
  border-radius: 5px;
  font-size: 1em;
  font-weight: 500;
  transition: background-color 0.3s ease, transform 0.2s ease;
}

.ver-mas-columnas-opinion a:hover {
  background-color: #00A499;
  transform: translateY(-2px);
}

/* Responsive */
@media (max-width: 768px) {
  .item-columnas-opinion {
    width: 90%;
    height: 100%;
  }
}

/* ========================================= */
/* Archive Columnas de Opinión */
/* ========================================= */

.columnas-opinion-section {
  display: flex;
  flex-direction: column;
  gap: 20px;
  padding: 20px;
  max-width: 1470px;
  margin: auto;
  align-items: left;
}

.columnas-opinion-container {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.columnas-opinion-titulo {
  font-size: 1.8em;
}

.columnas-opinion-box {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 20px;
  justify-items: center;
}

.fecha-columna {
  color: #666;
  font-size: 1em;
}

/* ========================================= */
/* Single Columna de Opinión */
/* ========================================= */

.single-columna-opinion {
  display: flex;
  flex-direction: row;
  gap: 40px;
  padding: 20px;
  max-width: 1470px;
  margin: auto;
  align-items: left;
  margin-bottom: 20px;
}

.single-columna-opinion-imagen {
  width: 400px;
  flex-shrink: 0;
  display: flex;
  align-items: flex-start;
}

.single-columna-opinion-imagen img {
  width: 100%;
  height: auto;
  object-fit: contain;
}

.single-columna-opinion-content {
  max-width: 70%;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

@media (max-width: 768px) {
  .single-columna-opinion {
    flex-direction: column;
    align-items: center;
  }

  .single-columna-opinion-imagen {
    width: 100%;
    flex-shrink: 0;
    display: flex;
    align-items: center;
  }

  .single-columna-opinion-content {
    max-width: 100%;
    display: flex;
    flex-direction: column;
    gap: 20px;
  }
}

