:root{
 --black:#000;
 --accent:#ebaa00;
 --max:1440px;
}

/* =========================
   RESET
========================= */
*{
  margin:0;
  padding:0;
  box-sizing:border-box;
    
}

body{
  font-family:'Barlow',sans-serif;
  background:#fff;
  color:#000;
margin-left: 2%;
  margin-right: 2%;
}

/* =========================
   ENLACES
========================= */
a{
  color:#000;
  text-decoration:none;
  transition:color .3s ease;
}

a:hover,.active{color:#ebaa00}
.container{
 max-width:1440px;
 margin:auto;
 padding:0 24px;
}
a.active{
  color:var(--accent);
}

/* =========================
   CONTENEDOR
========================= */
.container{
  max-width:var(--max);
  margin:auto;
  padding:0 24px;
}

/* =========================
   CABECERA RESPONSIVE TODA LA WEB
========================= */
header{
 position:sticky;
 top:0;
 background:#fff;
 z-index:999;
}


.site-header{
  position:sticky;
  top:0;
  background:#fff;
  z-index:999;
  border-bottom:15px solid rgba(0,0,0,.0);
}

.nav{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:24px;
  padding:20px 0;
  flex-wrap:wrap;
}

.logo{
  font-size:clamp(2rem,2vw,2rem);
  font-weight:700;
  line-height:1.5;
  white-space:nowrap;
}

.logo span{
  font-weight:300;
}

.menu{
 display:flex;
 gap:28px;
 font-weight:600;
     align-items:center;
  flex-wrap:wrap;
}

.menu a{
  font-size:1.2rem;
  font-weight:500;
  white-space:nowrap;
}

/* =========================
   CONTENIDO GENERAL
========================= */
.page-layout{
  padding-top:10px;
}

h1{
  color:var(--accent);
  margin-bottom:18px;
  font-size:clamp(1.1rem,4vw,1.5rem);
}

.intro-text{
  max-width:1200px;
  line-height:1.3;
  margin-bottom:28px;
  font-size:1.05rem;
}



/* =========================
   INDEX SLIDER
========================= */
.hero-slider{
  position:relative;
  overflow:hidden;
  margin-bottom:50px;
}

.slides{
  display:flex;
  transition:transform .6s ease;
}

.slides img{
  width:100%;
  height:auto;
  display:block;
  flex-shrink:0;
}

.slider{
 position:relative;
 margin:10px auto 40px;
 overflow:hidden;
}

.slide{min-width:100%}
.slide img{
 width:100%;
 display:block;
}

/* =========================
   GALERÍA SOCIAL
========================= */
.justified-gallery{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  align-items:flex-start;
  margin-bottom:60px;
}

.justified-gallery img{
  display:block;
  height:260px;
  width:auto;
  object-fit:cover;
  cursor:pointer;
  transition:transform .35s ease;
}

.justified-gallery img:hover{
  transform:scale(1.01);
}

/* =========================
   FOOTER
========================= */
.footer{
  text-align:center;
  padding:0px 20px 20px;
  margin-bottom:20px;
}

.footer-menu{
  display:flex;
  justify-content:center;
  gap:30px;
  flex-wrap:wrap;
  margin-bottom:20px;
}

/* =========================
   LIGHTBOX
========================= */
.lightbox{
  position:fixed;
  inset:0;
  display:none;
  justify-content:center;
  align-items:center;
  background:rgba(255,255,255,1);
  z-index:9999;
}

.lightbox.active{
  display:flex;
}

.lightbox img{
  max-width:85%;
  max-height:87vh;
  object-fit:contain;
}

.lb-btn{
  position:absolute;
  color:#b8b8b8;
  background:none;
  border:none;
  font-size:2rem;
  cursor:pointer;
}

.lb-btn:hover{
  color:var(--accent);
}

.lb-close{top:10px;right:10px}
.lb-prev{left:10px}
.lb-next{right:10px}




.lb-counter{
 position:fixed;
 top:20px;
 left:10px;
 color:#b8b8b8;
 font-size:1.5rem;
 z-index:10001;
 padding:5px 5x;
}





/* =========================
   MÓVIL
========================= */
@media (max-width:950px){

  .nav{
    flex-direction:column;
    align-items:center;
    gap:10px;
    padding:14px 0;
  }

  .logo{
    font-size:1.9rem;
    text-align:center;
    white-space:nowrap;
  }

  .menu{
    width:100%;
    justify-content:center;
    gap:20px;
  }

  .menu a{
    font-size:1.2rem;
    letter-spacing:.01em;
  }

  .intro-text{
    font-size:.95rem;
    line-height:1.55;
    margin-bottom:22px;
  }

  .justified-gallery img{
    height:160px;
  }
    .footer-menu{
 display:flex;
 justify-content:center;
 gap:40px;
 flex-wrap:wrap;
 margin-bottom:20px;
}

    
@media(max-width:760px)
{
 .nav{flex-direction:column;
    align-items:center;
    gap:10px;
    padding:14px 0;}
}

  .footer-menu{
    flex-direction:column;
    gap:14px;
      font-size:.85rem;
  }
      p{
    font-size:.8rem;
  }
     .lb-counter{
   top:12px;
   left:12px;
   font-size:.85rem;
 }
}

@media (max-width:600px){
  .container{
    padding:0 16px;
  }

  .logo{
    font-size:1.5rem;
  }

   .menu{
    width:100%;
    justify-content:center;
    gap:20px;
  }

  .menu a{
    font-size:.9rem;
    letter-spacing:.01em;
  }

  .intro-text{
    font-size:.9rem;
    line-height:1.5;
  }

  .justified-gallery{
    gap:10px;
  }

  .justified-gallery img{
    height:140px;
  }

    .footer-menu{
        font-size:.85rem;
}

    p{
    font-size:.75rem;
  }
         .lb-counter{
   top:12px;
   left:12px;
   font-size:.85rem;
 }
}