/* 
Reducir espaciado del titulo de pagina de wordpress
*/
body.page-id-5957 #primary {
  margin: 0em 0 !important;
}




/* HERO portada (HTML:
<section class="home-cover">
  <img class="home-cover__media" src="URL" alt="..." width="1920" height="720" loading="eager" decoding="async" fetchpriority="high">
  <h1 class="home-cover__title">Letras gigantes para eventos en Barcelona</h1>
</section>
) */


.home-cover{
  /* Ajusta los colores del overlay si quieres */
  --ovl1: rgba(0,0,0,.65);        
  --ovl2: rgba(40,111,252,.25);   
  --ovl3: rgba(40,111,252,.30);     
  position: relative;
  display: flex;
  align-items: flex-end;
  /*min-height: clamp(260px, 40vw, 520px);*/
  aspect-ratio: 1920 / 611; /* ajusta a la proporción real de tu archivo */
  padding-block: clamp(16px, 4vw, 32px);   /* espaciado borde arriba/abajo */
  padding-inline: clamp(12px, 3.5vw, 24px);/* izquierda/derecha (acerca el H1 al borde) */
  color: #fff;
  overflow: hidden;
 /* para evitar desbordes en móviles estrechos */
  overflow-wrap: anywhere;
  hyphens: auto;
}



/* Degradado lineal de izquierda (oscuro) a derecha (claro) */
.home-cover::before{
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(90deg, var(--ovl1) 0%, var(--ovl2) 55%, var(--ovl3) 90%);
  z-index: 1;
}



/* Imagen de fondo ocupando todo el contenedor */
.home-cover__media{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; object-position: center;
  display: block; max-width: none;
  z-index: 0;
}


/* Título encima */
.home-cover__title{
  position: relative; z-index: 2;
  margin: 0;
  max-width: min(50%, 780px);
  line-height: 1.08;
  font-size: clamp(24px, 3.2vw, 42px);
  /* Sombra del titulo
  text-shadow: 0 2px 3px rgba(255, 255, 255, 0.35);
  */
  color: #ffffff;
}

/* Ajustes responsive */
@media (max-width: 768px){
  .home-cover{ padding: clamp(16px, 5vw, 24px); }
  .home-cover__title{ font-size: clamp(24px, 6vw, 34px); }
  .home-cover{
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
  }
  .home-cover{ aspect-ratio: 16 / 10; } /* contenedor imagen más alto que 16/9 */
}







/* 

CSS grid categorias

*/

.home-grid-categorias {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 20px;
  margin: 30px 0;
  margin-top: 20px !important; /* margen superior de los grid*/
}

@media (max-width: 767px) {
  .home-grid-categorias {
    grid-template-columns: repeat(2, 1fr);
  }
  .home-titulo-seccion {
  font-size: 1.4rem !important;
  }

}

.home-categoria-card {
  background: #fff;
  border: 1px solid #eee;
  border-radius: 5px;
  box-shadow: 0 2px 6px rgba(0,0,0,0.08);
  overflow: hidden;
  transition: transform 0.3s ease;
  display: flex;
  flex-direction: column;
  height: 100%;
}

.home-categoria-card:hover {
  transform: translateY(-5px);
}

.home-categoria-card img {
  width: 100%;
  height: auto;
  display: block;
}






/*                                                   Botones CSS GRID                     */

/* Contenedor del botón */
.botones-cta-home{
  display:flex;
  justify-content:center;
  align-items:center;     /* Para centrar el contenido dentro */
  margin-top: auto;          /* <-- esto lo lleva al fondo */
  padding-inline:16px;
  margin-bottom:12px;     /* Margen debajo del botón */
}

/* Botón */
.btn-cta-home{
  display:block;
  width:100%;              /* Usa el 100% del ancho disponible */
  max-width:240px;         /* Limitar el tamaño máximo */
  margin:12px 16px 0 16px; /* Espaciado adecuado alrededor */
  padding:8px 20px;        /* Padding ajustado */
  font-size:14px;          /* Tamaño de fuente más adecuado */
  border-radius:5px;
  font-weight:500;
  text-decoration:none;
  background:#C49A6B;
  color:#fff;
  text-align:center;      /* Asegura que el texto esté centrado */
  transition:transform .06s ease, opacity .2s ease;
}

.botones-cta-home .btn-cta-home:hover {
    color: #000;   /* Cambiar texto a negro al pasar el ratón */
    background-color: #fff;  /* Cambiar fondo a blanco al pasar el ratón */
    border: 2px solid #575656;  /* Cambiar el borde a negro en hover */
}


/* Hover y active */
.btn-cta-home:hover {
  transform: translateY(-1px);
  opacity: .92;
}

.btn-cta-home:active {
  transform: translateY(0);
}

/* En móvil: ajuste de botón */
@media (max-width: 600px){
  .btn-cta-home{
    width:100%;          /* El botón ocupará todo el ancho */
    padding:8px 15px;    /* Ajuste de padding */
    margin:0 0 12px;     /* Separación abajo */
    font-size:14px;      /* Mantener tamaño de fuente adecuado */
  }
}

/* Asegura que las tarjetas no se deformen */
.home-categoria-card{
  display: flex;
  flex-direction: column;
  height: 100%;
  background: #fff;
  border: 1px solid #eee;
  border-radius: 5px;
  box-shadow: 0 2px 6px rgba(0,0,0,0.08);
  overflow: hidden;
  transition: transform 0.3s ease;
}

.home-categoria-card:hover {
  transform: translateY(-5px);
}






/* FIN css BOTONES CTA Tarjetas grid */






/* Ajusta en pc */
@media (min-width: 768px) {
  .home-categoria-card img {
    height: 300px; /* Ajusta al gusto */
    object-fit: cover;
  }
.home-titulo-seccion {
  font-size: 1.7rem !important;
  
}

}



/* Ajusta titulos categorias GRID */
.home-categoria-titulo {
  font-weight: 450;
  font-size: 0.97rem;
  line-height: 1.4;
  text-align: center;
  padding: 10px;
  min-height: 3.8em; /* Aproximadamente 2 líneas */
  display: flex;
  align-items: flex-start;
  justify-content: center;
}

.home-img-overlay {
  position: relative;
}

.home-img-overlay::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(0, 80, 160, 0.05);
  pointer-events: none;
}



/* 
*
Estos son los titulos H2 de la seccion 
*
*/


.home-titulo-seccion {
  font-size: 1.7rem ;
  font-weight: 500;
  text-align: center;
  position: relative;
  display: block; /* CAMBIADO: block en lugar de inline-block */
  margin: 40px 0 20px 0; /* margin vertical, no horizontal */
  padding-bottom: 5px;
  color: #1e1e1e;
}







/* Aqui va el bloque de descripcion de fabricante festivat
 descripcion 
 foto
*/

:root { --gap-col: clamp(24px, 5vw, 80px); }

/* contenedor general (como ya lo tenías) */
.bloque-fabricante{
  display: grid;
  grid-template-columns: minmax(0,1.5fr) minmax(0,1fr); /* texto | imagen */
  align-items: start;
  gap: 1.5rem var(--gap-col); /* 1.5rem = espacio vertical | var(--gap-col) = espacio entre columnas */
  background:#f5f6f7;
  padding:2rem;
  border-radius:1px;
}

/* H2 solo arriba */
.bloque-fabricante > .home-titulo-seccion{
  grid-column: 1 / -1;
  margin: 0 0 1rem 0;
  text-align: left;

}

/* Fuerza cada bloque a su columna (esto es la clave) */
.contenedor-descripcion-fabricante
{ 
  grid-column: 1; 
  font-size: 0.9rem ;
}
.contenedor-imagen{ grid-column: 2; }

.contenedor-imagen{
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border-radius: 12px;
}
.contenedor-imagen img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Responsive */
@media (max-width:900px){
  .bloque-fabricante{ grid-template-columns: 1fr; }
  .contenedor-descripcion-fabricante,
  .contenedor-imagen{ grid-column: 1; }
}



