/*
Theme Name: ananas
Theme URI: https://ananasstudio.com
Version: 2.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: ananas
Template: Divi
*/
/*@import url("../Divi/style.css");*/

#main-header {box-shadow: 0 0 0 rgb(0 0 0 / 100%);-moz-box-shadow: 0 0 0 rgba(0,0,0,1);-webkit-box-shadow: 0 0 0 rgb(0 0 0 / 100%);}
#main-header.et-fixed-header {box-shadow: 0 0 0 rgb(0 0 0 / 100%)!important;-moz-box-shadow: 0 0 0 rgba(0,0,0,1)!important;-webkit-box-shadow: 0 0 0 rgb(0 0 0 / 100%)!important;}

#top-menu li {padding-right:42px;}
.et_pb_toggle_content ul li {padding-bottom:13px;}


.acf-proyecto-bloque{
  margin-bottom: 24px;
}

/* 2 FULL WIDTH */
.acf-bloque-full .acf-item-full{
  margin: 0 0 24px 0;
}
.acf-bloque-full .acf-item-full:last-child{
  margin-bottom: 0;
}

/* 4 en 2 columnas (simulando gap 24px) */
.acf-bloque-grid{
  margin-left: -12px;
  margin-right: -12px;
}
.acf-bloque-grid:after{
  content: "";
  display: block;
  clear: both;
}
.acf-bloque-grid .acf-item-grid{
  float: left;
  width: 50%;
  padding-left: 12px;
  padding-right: 12px;
  box-sizing: border-box;
  margin: 0 0 24px 0;
}

/* Reset figure + imagen responsive */
.acf-proyecto-galeria figure{
  margin: 0;
}
.acf-proyecto-galeria img.acf-img{
  width: 100%;
  height: auto;
  display: block;
}

/* Móvil: 1 columna */
@media (max-width: 767px){
  .acf-bloque-grid{
    margin-left: 0;
    margin-right: 0;
  }
  .acf-bloque-grid .acf-item-grid{
    float: none;
    width: 100%;
    padding-left: 0;
    padding-right: 0;
  }
}
.acf-proyecto-galeria img.acf-img{
  width: 100%;
  height: auto;
  display: block;
  border-radius: 25px;
}
.acf-proyecto-galeria figure{
  overflow: hidden;
  border-radius: 25px;
}
/* Si en el bloque de doble columna queda 1 sola, que sea full width */
.acf-bloque-grid .acf-item-grid--full{
  float: none;
  width: 100%;
  padding-left: 12px;
  padding-right: 12px;
  clear: both;
  box-sizing: border-box;
}


/* ===============================
   DIVI SLIDER -> BULLETS EN LÍNEAS
   Ocupan 90% de ancho y se reparten
================================ */

/* Contenedor líneas */
.slider-lineas .et-pb-controllers{
  position:absolute!important;
  top:26px!important;
  bottom:auto!important;
  left:50%!important;
  transform:translateX(-50%)!important;
  width:90%!important;              /* 👈 ocupa el 90% */
  max-width:1200px!important;
  display:flex!important;           /* 👈 reparten espacio */
  gap:14px!important;               /* separación entre líneas */
  justify-content:center!important;
  padding:0!important;
  margin:0!important;
  z-index:50!important;
}

/* Cada bullet = una línea */
.slider-lineas .et-pb-controllers a{
  flex:1!important;                 /* 👈 cada línea ocupa una parte */
  height:4px!important;
  border-radius:999px!important;
  background:rgba(255,255,255,0.35)!important;
  display:block!important;
  margin:0!important;
  padding:0!important;
}

/* Activo */
.slider-lineas .et-pb-controllers a.et-pb-active-control{
  background:#fff!important;
}

/* Ajuste móvil */
@media(max-width:767px){
  .slider-lineas .et-pb-controllers{
    top:16px!important;
    gap:8px!important;
  }
  .slider-lineas .et-pb-controllers a{
    height:3px!important;
  }
}


/* =========================================================
   DIVI Filterable Portfolio
   Módulo con clase: portfolio-proyectos
   - 2 columnas en desktop/tablet
   - 1 columna en móvil
   - Título · Categoría en la misma línea
   - Sin huecos laterales / centrado correcto
   ========================================================= */

/* 0) Evita desbordes horizontales SOLO por este bloque */
.portfolio-proyectos,
.portfolio-proyectos *{
  box-sizing: border-box;
}

/* 1) Asegura que el módulo y sus wrappers ocupan todo el ancho disponible */
.portfolio-proyectos.et_pb_filterable_portfolio,
.portfolio-proyectos .et_pb_module,
.portfolio-proyectos .et_pb_portfolio_items_wrapper,
.portfolio-proyectos .et_pb_portfolio_items{
  width: 100% !important;
  max-width: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* 2) Layout estable: FLEX sin márgenes negativos (para no "correrse") */
.portfolio-proyectos .et_pb_portfolio_items{
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: center !important;   /* centra si sobra espacio */
  align-items: stretch !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* 3) Item: 2 columnas + separación controlada por padding */
.portfolio-proyectos .et_pb_portfolio_item{
  float: none !important;
  clear: none !important;
  display: block !important;

  width: 50% !important;               /* 2 columnas */
  padding-left: 20px !important;       /* gutter */
  padding-right: 20px !important;      /* gutter */
  margin: 0 0 40px 0 !important;       /* separación vertical */
}
.portfolio-proyectos .et_portfolio_image {padding-bottom:10px;}

/* Asegura que el contenido interno no genere desplazamiento */
.portfolio-proyectos .et_pb_portfolio_item > *{
  max-width: 100% !important;
}

/* 4) Móvil: 1 columna + sin padding lateral (para que quede centrado) */
@media (max-width: 980px){
  .portfolio-proyectos .et_pb_portfolio_item{
    width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
}

/* 5) Título y categoría en la misma línea */
.portfolio-proyectos .et_pb_portfolio_item h2.et_pb_module_header,
.portfolio-proyectos .et_pb_portfolio_item p.post-meta{
  display: inline !important;
  margin: 0 !important;
  padding: 0 !important;
  line-height: 1.2 !important;
}

/* separador antes de la categoría */
.portfolio-proyectos .et_pb_portfolio_item p.post-meta:before{
  content: " · " !important;
  opacity: 0.6;
}

/* oculta el "En:" / "In:" de Divi (si aparece) */
.portfolio-proyectos .et_pb_portfolio_item p.post-meta span{
  display: none !important;
}

/* 6) Por si Divi mete un centrado raro o ancho fijo en el <a> de imagen */
.portfolio-proyectos .et_pb_portfolio_item a,
.portfolio-proyectos .et_pb_portfolio_item img{
  max-width: 100% !important;
}