

    html {
  scroll-behavior: smooth;
}
:root {
            --negro: #0a0a0a;
            --blanco: #ffffff;
            --verde: #25d366;
            --radio-boton: 50px;
            --radio-card: 28px;
        }

        * { margin: 0; padding: 0; box-sizing: border-box; scroll-behavior: smooth; }
        body { 
            font-family: 'Montserrat', sans-serif; 
            background-color: var(--negro); 
            color: var(--blanco); 
            line-height: 1.6;
            padding-bottom: 100px; 
            overflow-x: hidden;
            background: radial-gradient(circle at top, #111 0%, #0a0a0a 60%);
}
        
        /* HEADER - AHORA MÁS VISIBLE */
        header {
            display: flex; 
            justify-content: space-between; 
            align-items: center;
            padding: 15px 7%; 
            background: var(--negro); 
            left: 0;
            top: 0; 
            width: 100%; 
            z-index: 999;
            
            border-bottom: 2px solid var(--verde);
            box-shadow: 0 4px 10px rgba(0,0,0,0.3);

             position: fixed;

             transition: background .35s ease, backdrop-filter .35s ease, padding .35s ease, border-color .35s ease, box-shadow .35s ease;
        }

        .header.scrolled{

    background:rgba(5,5,5,.82);

    backdrop-filter:blur(14px);

    -webkit-backdrop-filter:blur(14px);

    box-shadow:
    0 10px 30px rgba(0,0,0,.22);
    border-bottom:
    1px solid rgba(255,255,255,.06);
}

        .header-container {
  display: flex;
  align-items: center;
  justify-content: space-between;
   width: 100%;
    max-width: 100%;
}
@media (max-width: 768px){

    header {
        padding: 12px 20px; /* 🔥 reemplaza el 7% */
    }

}
        
        .logo { 
            font-size: 20px; 
            font-weight: 700; 
            letter-spacing: 2px; 
            text-transform: uppercase; 
            color: #ffffff; 
            text-decoration: none; 
        }

        @media (max-width: 768px){
    .logo {
        font-size: 16px;
    }
}
        .logo span { color: #25d366; font-weight: 300; }
       nav {
  margin-left: auto;
}
        nav ul { display: flex; list-style: none; gap: 30px; }

        nav ul li a { 
            text-decoration: none; 
            color: #ffffff; 
            font-size: 11px; 
            text-transform: uppercase; 
            letter-spacing: 2px; 
            font-weight: 600;
            transition: 0.3s; 
        }

        nav ul li a:hover { color: #25d366; }
       
        .active-link{
    color: var(--verde) !important;
}

.active-link::after{
    width: 100% !important;
    opacity: 1 !important;
}

/* ================= WHATSAPP FLOTANTE ================= */
.wpp-flotante-fijo {
    position: fixed;
    bottom: 30px;
    right: 30px;
    display: flex;
    align-items: center;
    gap: 12px;
    text-decoration: none;
    z-index: 9999;
    animation: bounce 2s infinite;
}

.wpp-label-fijo {
    background: var(--verde);
    color: #000;
    padding: 12px 22px;
    border-radius: 30px;
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
    box-shadow: 0 10px 30px rgba(0,0,0,0.5);
}

.wpp-icon-fijo {
    width: 60px;
    height: 60px;
    background-color: var(--verde);
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    color: white;
    font-size: 32px;
    box-shadow: 0 10px 30px rgba(37, 211, 102, 0.4);
}

@keyframes bounce {
    0%, 20%, 50%, 80%, 100% { transform: translateY(0); }
    40% { transform: translateY(-10px); }
    60% { transform: translateY(-5px); }
}

/* HERO */
.hero{
    text-align:center;
        position: relative;
    padding:40px 7% 10px;
}
 .hero h1 {
    position: relative;
    display: inline-block;
        margin-bottom: 8px;
        margin-top:50px;

}

.hero::before {
    content: "";
    position: absolute;
    top: -50px;
    left: 50%;
    transform: translateX(-50%);
    width: 400px;
    height: 200px;
    background: radial-gradient(circle, rgba(37,211,102,0.15), transparent 70%);
    filter: blur(60px);
    z-index: 0;
}


.hero h1::after {
    content: "";
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    bottom: -4px;
    width: 50px;
    height: 2px;
    background: var(--verde);
    transition: width 0.4s ease;
}
.hero h1:hover::after {
  width: 60px;
}

.hero p{
    color:#777;
    font-size:18px;
    margin-top: 8px;
}
/* CARDS */

.cards-options{
    display:grid;
    grid-template-columns: 2fr 1fr;
    gap:20px;
}

.cards {
    max-width: 1200px;
     width:100%;
    margin: 0px auto;
    padding: 40px 40px;
    border-radius: 28px;
    background: rgba(255,255,255,0.02);
    border: 1px solid rgba(37,211,102,0.2);
     box-shadow: 0 30px 80px rgba(0,0,0,0.6);
    margin-top: 10px; /* antes era 40–60px aprox */
        margin-bottom: 0;
}

.hero + .cards {
    margin-top: -10px;
}

/* HEADER */
.cards-header {
    text-align: center;
    margin-bottom: 20px;
}

.cards-header h2 {
    font-size: 18px;
    letter-spacing: 3px;
    font-weight: 300;
}

.cards-header p {
    font-size: 13px;
    color: #888;
    margin-top: 10px;
}

/* ===== DESKTOP GRID ORIGINAL ===== */

.cards{
    max-width: 1200px;
    width: 100%;
    margin: 0 auto;
}

.cards-options{
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 20px;
    align-items: stretch;
}

.card-large{
    grid-row: span 2;
}

@media (max-width: 600px){

  .cards-options{
    grid-template-columns: 1fr !important;
  }

  .card-large{
    grid-column: span 1 !important;
    grid-row: span 1 !important;
  }

  .card{
  aspect-ratio: 4 / 3;
  border-radius: 14px;
  overflow: hidden;
}

  
}


.proyectos {
  padding: 10px 8%;
   margin-bottom: 18px;
}

.proyectos h2 {
  font-size: 15px;
    letter-spacing: 4px;
    font-weight: 500;
    
    color: #bbb;
    position: relative;
    display: inline-block;
    margin-bottom: 22px;
    opacity: 0.8;
}


.proyectos h2::after {
  content:"";
    display:block;
    width:32px;
    opacity:0.6;
    height:2px;
    background:var(--verde);
    margin-top:8px;
    transition:0.4s;
    box-shadow:0 0 12px rgba(37,211,102,0.4);
}

.proyectos h2:hover::after {
    width: 40%;
}


/* GRID */

.grid-proyecto{
  max-width: 760px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

@media (max-width: 768px){

  .grid-proyecto{
    max-width: 100%;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
  }

  .proyectos h2{
    font-size: 18px;
    letter-spacing: 4px;
    margin-bottom: 20px;
  }

}

/* ================= CARDS ================= */

.card {
  opacity: 0;
  transform: translateY(20px);
  animation: fadeUp 0.7s cubic-bezier(0.22, 1, 0.36, 1) forwards;
  cursor: pointer;
  border-radius: 14px;
  width: 100%;
  max-width: 100%;
  overflow: hidden;
  position: relative;
  -webkit-tap-highlight-color: transparent;
}

.card:nth-child(1){ animation-delay: 0.15s; }
.card:nth-child(2){ animation-delay: 0.3s; }
.card:nth-child(3){ animation-delay: 0.45s; }

@keyframes fadeUp {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.card-desc{
  font-size: 11px;
  letter-spacing: 1px;
  color: rgba(255,255,255,0.8);
  margin-top: 4px;

  opacity: 0;
  transform: translateY(6px);
  transition: 0.25s ease;

  text-shadow: 0 2px 10px rgba(0,0,0,0.6);
}

.card:hover .card-desc{
  opacity: 1;
  transform: translateY(0);
  color: var(--verde);
}


/* Imagen */
.card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
  position: relative;
  z-index: 1;
}

/* Overlay */
.card .card-overlay {
  position: absolute;
  inset: 0;

  display: flex;
  flex-direction: column;
  justify-content: flex-end;

  padding: 20px;

  background: linear-gradient(
    to top,
    rgba(0,0,0,0.75),
    rgba(0,0,0,0.2),
    transparent
  );

  z-index: 5;
  transition: background 0.3s ease;
}

/* Hover overlay más legible */
.card:hover .card-overlay {
  background: linear-gradient(
    to top,
    rgba(0,0,0,0.85),
    rgba(0,0,0,0.3),
    transparent
  );
}
.card-overlay::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 20px;
  width: 0%;
  height: 2px;
  background: var(--verde);
  transition: 0.3s ease;
}

.card:hover .card-overlay::after {
  width: 40px;
}
.card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    120deg,
    transparent 40%,
    rgba(255,255,255,0.08),
    transparent 60%
  );
  opacity: 0;
  transition: 0.6s ease;
  z-index: 4;
}
.card:hover::before {
  opacity: 1;
}
.card:active{
   transform: scale(0.98);
  filter: brightness(1.05);
}
/* Título */
.card-overlay h3 {
  font-size: 16px;
  font-weight: 600;
  letter-spacing: 1.5px;
  color: #fff;

  text-shadow: 0 2px 10px rgba(0,0,0,0.6);
}

/* Hover imagen (único efecto de escala) */
.card:hover img {
  transform: scale(1.05);
}

/* Hover card limpio (sin scale) */
.card:hover {
  border-color: var(--verde);
  filter: brightness(1) contrast(1.1);
  transform: translateY(-4px);
}

/* Card destacada */
.card-large {
  grid-column: span 2;
  grid-row: span 2;
}

/* Responsive */
@media (max-width: 768px){
    .cards-options {
        grid-template-columns: 1fr;
        gap: 14px;
    }



    .card-large {
        grid-column: span 1;
        grid-row: span 1;
    }





  .card img{
  height: 100%;
  object-fit: cover;
}

  .card-overlay{
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;

    padding: 6px 8px;

   background: linear-gradient(to top, rgba(0,0,0,0.75), rgba(0,0,0,0.1), transparent);

    opacity: 1;
  }

  .card-overlay h3{
    font-size: 13px;       /* 👈 bien chico */
    letter-spacing: 0.8px;
    line-height: 1.1;
    margin: 0;
    text-transform: uppercase;
  }

  .card-desc{
    display: block;
    opacity: 1;
    transform: translateY(0);
    font-size: 12px;
    margin-top: 4px;
    color: rgba(255,255,255,0.75);
  
  }

}

@media (max-width: 600px){
  .cards{
    padding: 20px 16px;
    max-width: 100%;
   
  }
}

@media (max-width: 768px){



  .card-overlay{
    padding: 14px;
    background: linear-gradient(
      to top,
      rgba(0,0,0,0.75),
      rgba(0,0,0,0.2),
      transparent
    );
  }

  .card-overlay h3{
    font-size: 14px;
    letter-spacing: 1.2px;
  }

}


/* SECTIONS */
.section{padding:70px 7%;}
.section-title{
    font-size:12px;
    letter-spacing:3px;
    margin-bottom:20px;
    text-transform:uppercase;
    color: var(--verde);
    position: relative;
    display: inline-block;
}

.section-title::after{
    content:"";
    display:block;
    width:40px;
    height:1px;
    background: var(--verde);
    margin-top:6px;
    opacity:0.6;
}

.section {
    scroll-margin-top: 8px;
}



.gallery-masonry{
    column-count: 5;
    column-gap: 12px;
    gap: 14px;
}
.gallery-masonry .img-wrap{
    position:relative;
    overflow:hidden;
    cursor:zoom-in;
    border-radius:12px;
    border-radius: 18px;   /* 🔥 vuelve efecto pinterest */
    margin-bottom: 14px;   /* 🔥 separa verticalmente */
}

.gallery-masonry .img-wrap img{
    width:100%;
    height:auto;
    display:block;

    transition:transform .4s ease;

    object-fit:cover;
    position:relative;
    filter:contrast(1.05) saturate(0.95);
    transform: scale(1.01);
   

}


.gallery-masonry .img-wrap::after{
    content:"🔍";

    position:absolute;
    top:50%;
    left:50%;
    transform:translate(-50%,-50%) scale(.8);

    width:52px;
    height:52px;
    border-radius:50%;

    display:flex;
    align-items:center;
    justify-content:center;

    background:rgba(0,0,0,.55);
    backdrop-filter:blur(6px);

    color:#fff;
    font-size:22px;

    opacity:0;
    transition:.3s ease;

    pointer-events:none;
}

.gallery-masonry .img-wrap:hover img{
  
      transform: scale(1.03);
    filter: brightness(0.85);
}

.gallery-masonry .img-wrap:hover::after{
   opacity:1;
    transform:translate(-50%,-50%) scale(1);
}

@media (max-width: 768px){

  .galeria-bloque{
    margin-bottom: 20px;
    padding-top: 10px;
  }

  .gallery-masonry{
    display: none;
    columns:2;
  }

  .galeria-bloque.active .gallery-masonry{
    display: block;
  }

  .galeria-subtitulo{
    cursor: pointer;
    margin-top: 14px;
  margin-bottom: 6px;
  font-size: 14px;
  }
  .galeria-header{
        margin-bottom: 10px;
    }

}

@media (max-width: 768px){
    .gallery-masonry .img-wrap::after{
        opacity: 0.35;
        transform: translate(-50%, -50%) scale(0.95);
    }
}




.img-wrap:hover::after{
    opacity: 1;
}

/* RESPONSIVE BIEN HECHO PARA GRID */
@media (max-width: 1400px){
    .gallery-masonry{ column-count: 4; }
}

@media (max-width: 1100px){
    .gallery-masonry{ column-count: 3; }
}

@media (max-width: 800px){
    .gallery-masonry{ column-count: 2; }
}

@media (max-width: 600px){
    .gallery-masonry{ column-count: 1; }
}

/* LIGHTBOX */
.lightbox{
    position:fixed;
    inset:0;
    background:rgba(0,0,0,0.92);
    display:none;
    z-index:2000;

    align-items:center;
    justify-content:center;
}

.lightbox-content{
    position: relative;
    display:flex;
    align-items:center;
    justify-content:center;
    width:100%;
    height:100%;
}

.lightbox img{max-width:85%;max-height:85%;}

.lightbox .close{
    position: absolute;
    top: 18px;
    right: 18px;
    z-index: 9999;

    width: 42px;
    height: 42px;
    display: flex;
    align-items: center;
    justify-content: center;

    border-radius: 50%;
    background: rgba(0,0,0,0.4);
    backdrop-filter: blur(6px);

    font-size: 30px;
    cursor: pointer;
    transition: 0.3s ease;
}

/* hover corregido (sin mover posición) */
.lightbox .close:hover{
    opacity: 1;
    transform: scale(1.1);
    background: rgba(37,211,102,0.25);
}

.nav{position:absolute;top:50%;font-size:40px;cursor:pointer;}
.prev{left:30px;}
.next{right:30px;}

#lightbox-img{
    display:block;
    max-width: 90vw;
    max-height: 85vh;
    width:auto;
    height:auto;
    opacity:1;
    object-fit: contain;
}

/* ================= VIDEOS ================= */


.video-link{
    position:relative;
    display:block;
    width:100%;
    height:100%;
}

.video-link img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
}

/* overlay oscuro suave */
.video-link::after{
    content:"";
    position:absolute;
    inset:0;
    background:rgba(0,0,0,0.25);
    transition:0.3s ease;
}

/* botón play */
.play-btn{
    position:absolute;
    top:50%;
    left:50%;
    transform:translate(-50%, -50%);
    width:68px;
    height:48px;
    border-radius:12px;
    background:#ff0000;
    display:flex;
    align-items:center;
    justify-content:center;
    transition:0.3s ease;
}

/* triángulo blanco */
.play-btn::before{
    content:"";
    border-left:18px solid #fff;
    border-top:10px solid transparent;
    border-bottom:10px solid transparent;
    margin-left:4px;
}

/* hover más tipo YouTube */
.video-wrap:hover .play-btn{
    transform:translate(-50%, -50%) scale(1.1);
    box-shadow:0 0 25px rgba(255,0,0,0.6);
}

.play-btn{
    animation: pulse 2s infinite;
}

@keyframes pulse{
    0%{ box-shadow:0 0 0 0 rgba(255,0,0,0.6); }
    70%{ box-shadow:0 0 0 12px rgba(255,0,0,0); }
    100%{ box-shadow:0 0 0 0 rgba(255,0,0,0); }
    

}

.video-item img{
  filter: brightness(0.9);
}

.video-grid{
    display:flex;
    justify-content:center;
    gap:20px;
    flex-wrap:wrap;
}
.video-play{
  background: rgba(0,0,0,0.6);
  backdrop-filter: blur(6px);
}

.video-wrap{
    width:260px;
    aspect-ratio:9/16;
    border-radius:16px;
    overflow:hidden;
    background:#000;
    border:1px solid rgba(37,211,102,0.25);
    box-shadow: 0 10px 30px rgba(0,0,0,0.5);

    transition:0.3s ease;
}
.video-wrap:hover{
    transform: scale(1.03);
    border-color: rgba(37,211,102,0.6);
    box-shadow: 0 20px 50px rgba(0,0,0,0.7);
}
.video-wrap iframe{
    width:100%;
    height:100%;
    display:block;
}

/* diferencia de tamaños */
.video-item.small .video-wrap{
    width:220px;
}
.video-item{
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 20px 40px rgba(0,0,0,0.5);
  outline: 1px solid rgba(255,255,255,0.05);
  position: relative;
  cursor: pointer;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.video-item.short{
  max-width: 320px;
    margin-bottom: 16px;
 margin-left: auto;
  margin-right: auto;
}
.video-item:hover{
  transform: translateY(-4px);
  box-shadow: 0 20px 50px rgba(0,0,0,0.6);
}
.video-item:hover img{
  transform: scale(1.03);
}
.video-item img{
  transition: transform 0.4s ease;
}
@media (max-width: 768px){

  .video-item{
    transition: transform 0.2s ease;
  }

  .video-item:active{
    transform: scale(0.97);
    filter: brightness(1.05);
  }

}
.featured-video .video-wrap{
    border:1px solid rgba(37,211,102,0.6);
    box-shadow: 0 0 25px rgba(37,211,102,0.25);
}








/* overlay menos pesado (esto es lo que te estaba “inflando” visualmente) */
.card .card-overlay {
  padding: 14px; /* antes 20px */
}



.texto{
flex:1;
max-width:340px;
}
.texto h3{font-size:20px;margin-bottom:10px;}
.texto p{color:#aaa;font-size:14px;max-width:400px;}


/* BOTON TOP */
.top{
    position: fixed;

    bottom: 110px;
    right: 22px;

    width: 52px;
    height: 52px;

    border-radius: 50%;

    display: flex;
    align-items: center;
    justify-content: center;

    cursor: pointer;

    background: rgba(30,30,30,0.88);
    backdrop-filter: blur(12px);

    border: 1px solid rgba(255,255,255,0.12);

    color: #fff;
    font-size: 18px;

    opacity: 0;
    transform: translateY(10px) scale(0.95);

    transition:
      opacity 0.3s ease,
      transform 0.3s ease,
      background 0.3s ease,
      border-color 0.3s ease;

    box-shadow:
  0 12px 30px rgba(0,0,0,0.45),
  0 0 0 1px rgba(255,255,255,0.04),
  0 0 18px rgba(37,211,102,0.14);

    z-index: 999;
}

.top.show{
    opacity: 1;
    transform: translateY(0) scale(1);
    animation: topGlow 2.5s infinite;
}
@keyframes topGlow{
  0%{
    box-shadow:
      0 12px 30px rgba(0,0,0,0.45),
      0 0 0 1px rgba(255,255,255,0.04),
      0 0 10px rgba(37,211,102,0.08);
  }

  50%{
    box-shadow:
      0 12px 30px rgba(0,0,0,0.45),
      0 0 0 1px rgba(255,255,255,0.04),
      0 0 24px rgba(37,211,102,0.18);
  }

  100%{
    box-shadow:
      0 12px 30px rgba(0,0,0,0.45),
      0 0 0 1px rgba(255,255,255,0.04),
      0 0 10px rgba(37,211,102,0.08);
  }
}
.top:hover{
    transform: translateY(-4px) scale(1.06);

    background: rgba(20,20,20,0.9);

    border-color: rgba(37,211,102,0.55);

    box-shadow:
      0 18px 40px rgba(0,0,0,0.55),
      0 0 28px rgba(37,211,102,0.18);
}

.top i{
    transition: 0.3s ease;
}

.top:hover i{
    transform: translateY(-2px);
}
@media (max-width: 768px){

  .top{
    width: 56px;
    height: 56px;

    right: 18px;
    bottom: 95px;
  }

  .top:active{
    transform: scale(0.94);
  }

}




/* --- PRE-FOOTER CON BOTÓN PULSANTE --- */
        .pre-footer {
            background-color: #0a0a0a;
            padding: 80px 7%;
            text-align: center;
            border-top: 1px solid #1a1a1a;
        }

        .pre-footer h2 {
            color: #fff;
            font-weight: 300;
            font-size: 1.3rem;
            letter-spacing: 3px;
            text-transform: uppercase;
            margin-bottom: 35px;
        }

        .btn-cotizar-amigable {
            background-color: transparent;
            color: var(--verde);
            padding: 15px 35px;
            border: 1px solid var(--verde);
            text-decoration: none;
            font-weight: 600;
            text-transform: uppercase;
            font-size: 12px;
            letter-spacing: 2px;
            display: inline-block;
            transition: all 0.3s;
            /* Animación de pulso sutil */
            animation: pulso-verde 2s infinite;
        }

        @keyframes pulso-verde {
            0% { box-shadow: 0 0 0 0 rgba(37, 211, 102, 0.4); }
            70% { box-shadow: 0 0 0 10px rgba(37, 211, 102, 0); }
            100% { box-shadow: 0 0 0 0 rgba(37, 211, 102, 0); }
        }

        .btn-cotizar-amigable:hover {
            background-color: var(--verde);
            color: #000;
            transform: translateY(-2px);
        }

.wpp-float{
position:fixed;
bottom:30px;
right:30px;
width:60px;
height:60px;
background:#25d366;
border-radius:50%;
display:flex;
align-items:center;
justify-content:center;
color:#000;
font-size:28px;
text-decoration:none;
z-index:999;
}



   /* --- ESTILOS DEL MODAL (POP-UP) --- */
.modal-overlay {
    position: fixed; top: 0; left: 0; width: 100%; height: 100%;
    background: rgba(0, 0, 0, 0.85); backdrop-filter: blur(10px);
    display: none; justify-content: center; align-items: center; z-index: 9999;
}

.modal-content {
    background: #1a1a1a; width: 95%; max-width: 750px;
    border-radius: 20px; position: relative;
    box-shadow: 0 20px 50px rgba(0,0,0,0.5); overflow: hidden;
    border: 1px solid rgba(255,255,255,0.1);
    animation: fadeInScale 0.3s ease-out;
}

@keyframes fadeInScale { from { opacity: 0; transform: scale(0.95); } to { opacity: 1; transform: scale(1); } }

.close-modal {
    position: absolute; top: 15px; right: 20px;
    background: none; border: none; color: #ffffff; font-size: 30px;
    cursor: pointer; z-index: 10; opacity: 0.5;
}

.modal-grid { display: grid; grid-template-columns: 1fr; }
@media (max-width: 600px) { .modal-grid { grid-template-columns: 1fr; } }

.modal-option { padding: 50px 40px; text-align: center; display: flex; flex-direction: column; align-items: center; }
.option-wpp { background: rgba(255,255,255,0.03); }

.modal-option i { font-size: 70px; margin-bottom: 20px; color: #25d366; }
.modal-option h3 { text-transform: uppercase; letter-spacing: 2px; font-size: 18px; margin-bottom: 15px; color: #ffffff; }
.modal-option p { font-size: 15px; color: #888; margin-bottom: 30px; }



.btn-modal {
    width: 100%; padding: 15px; border-radius: 50px; border: none;
    text-transform: uppercase; font-weight: 700; font-size: 11px;
    letter-spacing: 1px; cursor: pointer; text-decoration: none;
    transition: 0.3s; display: inline-block; margin-top: 10px;
}
.btn-modal.wpp { background: #25d366; color: #000; }
.btn-modal.call { background: #ffffff; color: #000; }
.btn-modal:hover { transform: translateY(-3px); box-shadow: 0 10px 20px rgba(0,0,0,0.3); }


.sr-only{

    position:absolute;

    width:1px;

    height:1px;

    padding:0;

    margin:-1px;

    overflow:hidden;

    clip:rect(0,0,0,0);

    white-space:nowrap;

    border:0;
}
/* ===== HAMBURGUESA ===== */

.hamburger {
    display: none;
    flex-direction: column;
    gap: 5px;
    cursor: pointer;
    background:transparent;

    border:none;

    box-shadow:none;

    backdrop-filter:none;
}

/* MOBILE */
@media (max-width: 768px){

    nav ul {
        display: none !important;
    }

    .hamburger {
        display: flex;
        position: absolute;
        right: 20px;
        top: 50%;
        transform: translateY(-50%);
        z-index: 3000;
    }

}
@media (max-width: 768px){

    .logo {
        font-size: 15px;
        letter-spacing: 1px;
    }

}
.hamburger span {
    width: 25px;
    height: 2px;
    background: white;
    transition: 0.3s;
}

/* ===== PANEL MOBILE ===== */
.mobile-menu {
    position: fixed;
    top: 0;
    right: -100%;
    width: 80%;
    height: 100vh;
    background: #0a0a0a;
    padding: 80px 40px;
    display: flex;
    flex-direction: column;
    gap: 25px;
    transition: 0.4s ease;
    z-index: 3500; /* 🔥 CAMBIAR SOLO ESTO */
    border-left: 1px solid rgba(255,255,255,0.1);
}

.mobile-menu a {
    color: white;
    text-decoration: none;
    font-size: 18px;
    letter-spacing: 2px;
    text-transform: uppercase;
}

.close-menu {
    position: absolute;
    top: 20px;
    right: 25px;
    font-size: 28px;
    color: white;
    cursor: pointer;
    background:transparent;

    border:none;

    box-shadow:none;

    backdrop-filter:none;
}
@media (max-width: 768px){

    .close-menu{
        top: 20px;
        right: 20px;
        font-size: 32px;
        z-index: 4000;
    }

}

.overlay-menu {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,0.6);
    opacity: 0;
    pointer-events: none;
    transition: 0.3s;
    z-index: 1100;
}

.mobile-menu.active {
    right: 0;
}

.overlay.active {
    opacity: 1;
    pointer-events: all;
}
.overlay-menu.active {
    opacity: 1;
    pointer-events: all;
}

@media (max-width: 768px){
    #lightbox-img{
        max-width: 95vw;
        max-height: 70vh;
    }

    .lightbox-content{
        padding: 10px;
    }
}



@media (max-width: 768px) {
}


 /* --- FOOTER DOS COLUMNAS ESTILO CAPTURA --- */
        footer {
            background-color: #000;
            padding: 60px 7% 120px; /* Espacio negro al final */
            border-top: 1px solid #111;
        }

        .footer-grid {
            display: grid;
                grid-template-columns:repeat(3,1fr);

            gap: 60px;
            max-width: 1200px;
            margin: 0 auto;
             align-items:start;
width: 100%;

        }

        .col-izq h3 {
            color: #fff;
            font-size: 16px;
            letter-spacing: 3px;
            margin-bottom: 15px;
            text-transform: uppercase;
        }
        .col-izq h3 span { color: var(--verde); font-weight: 300; }

        .col-izq p {
            color: #666;
            font-size: 13px;
            line-height: 1.6;
            max-width: 300px;
        }

        .col-der {
            display: flex;
            flex-direction: column;
            justify-content: flex-start;
        }

        .dami-title {
            color: #fff;
            font-size: 14px;
            font-weight: 600;
            margin-bottom: 20px;
            letter-spacing: 1px;
        }

        .contacto-list {
            list-style: none;
            padding: 0;
        }

        .contacto-list li {
            color: #888;
            font-size: 12px;
            margin-bottom: 12px;
            display: flex;
            align-items: center;
            gap: 12px;
        }

        .contacto-list i {
            color: var(--verde);
            font-size: 12px;
            width: 15px;
        }
        .col-izq h3,
.dami-title,
.footer-social h3{

    display:block;

    min-height:22px;

    margin-bottom:20px;
}
.footer-grid > div{

    display:flex;

    flex-direction:column;
}

        /* Responsive para celulares */
        @media (max-width: 768px) {
            .footer-grid { grid-template-columns: 1fr; gap: 40px; }
            footer { padding-bottom: 60px; }
        }


@media (max-width: 600px) {

  .modal-content {
    width: 92%;
    max-width: 92%;
    max-height: 90vh;
    overflow-y: auto;
    border-radius: 18px;
  }

  .modal-grid {
    grid-template-columns: 1fr;
  }

  .modal-option {
    padding: 30px 20px;
  }

  .modal-option i {
    font-size: 32px;
    margin-bottom: 15px;
  }

  .modal-option h3 {
    font-size: 13px;
  }

  .modal-option p {
    font-size: 12px;
    margin-bottom: 20px;
  }

  #formContactoShort input,
  #formContactoShort textarea {
    font-size: 13px;
    padding: 12px;
  }

  .btn-modal {
    font-size: 10px;
    padding: 12px;
  }

  .close-modal {
    top: 10px;
    right: 15px;
    font-size: 26px;
  }
}

.copyright{
    margin-top: 40px;
    text-align: center;

    color: #666;
    font-size: 11px;
    letter-spacing: 1px;

    opacity: 0.8;
}
.section p{
    color:#888;
    max-width:720px;
    margin-bottom:8px;
    font-size:14px;
    line-height:1.8;
}

.muzilli-title{ 
    color:#fff; 
    position:relative; 
    display:inline-block; 
    font-size: 26px; 
    font-weight: 300; 
    letter-spacing: 4px; 
    text-transform: uppercase; 
    margin-bottom: 10px; 
}

.muzilli-title::after{
    content:"";
    display:block;
    width:60px;
    height:2px;
    background:var(--verde);
    margin:8px auto 0;
    transition:0.4s;
    box-shadow:0 0 12px rgba(37,211,102,0.5);
}
.muzilli-title::after{
    content:'';

    position:absolute;
    left:0;
    bottom:-10px;

    width:70px;
    height:1px;

    background:var(--verde);

    transition:0.4s ease;
}

.storytelling-text:hover .muzilli-title::after{
    width:140px;
}

.muzilli-title:hover::after{
    width:120px;
}

.galeria-header{
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    margin-bottom: 20px;
}
.galeria-bloque {
    padding-top: 0px;
    margin-bottom: 0px;
    border-top: 1px solid rgba(255,255,255,0.05);
}

.galeria-subtitulo{
    font-size: 13px;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: var(--verde);
        margin: 0; /* 🔥 esto es CLAVE */

    font-weight: 400;
    display: inline-block;
    cursor: pointer;
    position: relative;
    transition: 0.3s;

    
  margin-bottom: 8px;
}

.galeria-subtitulo::after{
    content:"";
    display:block;
    width:40px;
    height:1px;
    background: var(--verde);
    margin-top:8px;
    transition:0.3s;
    opacity:0.6;
}
.galeria-subtitulo:first-of-type{
  margin-top: 20px;
}

.galeria-subtitulo:hover{
    transform: translateX(6px);
    opacity: 1;
}

.galeria-subtitulo:hover::after{
    width:80px;
    opacity:1;
}
.lb-counter{
    position: absolute;
    top: 12px;
    left: 50%;
    transform: translateX(-50%);

    font-size: 11px;
    letter-spacing: 2px;
    color: #fff;

    background: rgba(0,0,0,0.45);
    backdrop-filter: blur(10px);

    padding: 6px 12px;
    border-radius: 20px;

    z-index: 10;
    pointer-events: none;
}

.galeria-header-principal{
    display:flex;
    align-items:center;
    justify-content:flex-start; /* 🔥 clave: todo junto a la izquierda */
    gap:25px;
    margin-bottom:0px;
}

.galeria-titulos{
    display:flex;
    flex-direction:column;
}



.galeria-header-principal:hover .galeria-title::after{
    width:120px;
}

.section-title {
    position: relative;
    display: inline-block;
}

.section-title::after {
    content: "";
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    bottom: -6px;
    width: 50px;
    height: 2px;
    background: var(--verde);
    transition: width 0.4s ease;
}

.section-title:hover::after {
    width: 60px;
}
.galeria-subtitle{
    font-size:12px;
    font-weight: 300;
    letter-spacing: 2px;
    color:#777;
    margin-top:4px;
}


/* BOTÓN VER MEJORADO */
.btn-ver-principal{
    background:transparent;
    border:1px solid rgba(37,211,102,0.8);
    color:var(--verde);

    padding:14px 26px;   /* 🔥 más grande */
    border-radius:50px;

    font-size:12px;
    letter-spacing:3px;
    font-weight:600;

    display:flex;
    align-items:center;
    gap:8px;

    cursor:pointer;
    transition:0.3s;

    white-space:nowrap;
    box-shadow: 0 0 0 rgba(37,211,102,0);
}

.btn-ver-principal i{
    font-size:14px;
}

/* hover más premium */
.btn-ver-principal:hover{
    background:var(--verde);
    color:#000;
    transform:translateY(-2px) scale(1.05);
    box-shadow: 0 0 18px rgba(37,211,102,0.35),
                0 0 40px rgba(37,211,102,0.15);
}

.lb-arrow:hover{
    opacity:1;
        transform: translateY(-50%) scale(1.15);
    background:rgba(37,211,102,0.25);
}

.lb-hint{
    position:absolute;
    bottom:12px;
    left:50%;
    transform:translateX(-50%);

    font-size:10px;
    color:rgba(255,255,255,0.7);
    letter-spacing:2px;

    background:rgba(0,0,0,0.25);
    padding:5px 10px;
    border-radius:20px;

    pointer-events:none;
}


@media (max-width: 768px){
    .lb-hint{
        font-size: 9px;
        opacity: 0.9;
    }
}

.lb-wrapper{
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    max-width: 92vw;
    max-height: 92vh;
}



.lb-arrow{
    background:rgba(0,0,0,0.45);
    backdrop-filter: blur(8px);
    color:#fff;
    width:38px;
    height:38px;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:18px;
    cursor:pointer;
    transition:0.3s;
    opacity:0.7;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    pointer-events: auto;
}






.lb-footer{
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
}

.lb-controls{
    position: absolute;
    inset: 0;
    pointer-events: none;
}

.lb-arrow,
.close{
    cursor:pointer;
    color:#fff;
    font-size:20px;
    opacity:0.8;
    transition:0.3s;
}

.lb-arrow:hover,
.close:hover{
    opacity:1;
    transform:scale(1.1);
}

.ambientes-wrapper{
    height: auto;
    display: flex;
    flex-direction: column;
    width: 100%;
  max-width: 100%;
  overflow: hidden;
}

/* cada mitad */
.panel{
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 30px 7%;
}

/* separador visual sutil */
.panel.alta{
    border-bottom: 1px solid rgba(255,255,255,0.08);
}


.slide-layout{
    display: flex;
    flex-direction: column;
    gap: 22px;
    align-items: center;
    width: 100%;
}

/* imagen grande protagonista */
.slide-media{
    min-width:0; /* 🔥 SUPER CLAVE */
   width:100%;
}
/* texto a la derecha */
.slide-text h3{
    font-size: 20px;
    letter-spacing: 3px;
    font-weight: 300;
    margin-bottom: 10px;
}

.slide-text p{
    color: #888;
    font-size: 14px;
    line-height: 1.6;
    max-width: 320px;
}






.arrow{
    position:absolute;
    top:50%;
    transform:translateY(-50%);

    z-index:20;

    width:52px;
    height:52px;

    border-radius:50%;

    display:flex;
    align-items:center;
    justify-content:center;

    background:rgba(8,8,8,0.82);

    backdrop-filter:blur(10px);

    border:1px solid rgba(37,211,102,0.35);

    color:#fff;

    font-size:22px;

    cursor:pointer;

    box-shadow:
    0 8px 28px rgba(0,0,0,0.45),
    0 0 18px rgba(37,211,102,0.12);

    transition:
    transform .25s ease,
    background .25s ease,
    box-shadow .25s ease,
    opacity .25s ease;

    opacity:0.95;
}
.arrow:hover{
    background:var(--verde);

    color:#000;

    transform:
    translateY(-50%)
    scale(1.08);

    box-shadow:
    0 0 26px rgba(37,211,102,0.45);
}
.arrow.prev{
    left: 10px;
}

.arrow.next{
    right: 10px;
}



.carousel-title{
    margin-top:10px;
    font-size:12px;
    letter-spacing:2px;
    color:#aaa;
    text-transform:uppercase;
    text-align:center;
}









.carousel-track {
    display: flex;
    width: 100%;
    overflow: hidden;
    touch-action: pan-y;
}

.carousel-item{
    min-width: 100%;
    width: 100%;
    flex-shrink: 0;
}
.carousel-item > img{
  width:100%;
  height:320px;
  object-fit:cover;
  border-radius:16px;
}

.carousel-item span{
  display: block;
  margin-top: 8px;
  font-size: 11px;
  letter-spacing: 2px;
  color: rgba(255,255,255,0.6);
}



@media (min-width: 769px){

  .ambientes-wrapper{
      display: flex;
      flex-direction: column;
      gap: 0px;
  }

  .carousel-track{
      overflow: hidden;
      width: 100%;
  }


  .carousel-item{
    width: 100%;
    flex-shrink: 0;
  }

  .slide-media{
    width: 100%;
  }
}
   


.section-subtitle-mini{
    font-size: 13px;
    color: #888;
    letter-spacing: 1px;
    margin-bottom: 25px;
}

.after-header{
    text-align: left;
    margin-bottom: 25px;
}

.beforeafter-header{
    margin-bottom: 12px; /* antes 25px */
    margin-top:40px;
}

.beforeafter-title{
    font-size: 22px;
    font-weight: 300;
    letter-spacing: 4px;
    text-transform: uppercase;
    color: #fff;
    margin-bottom: 6px;
    position: relative;
}

.beforeafter-title::after{
    content:"";
    display:block;
    width:60px;
    height:2px;
    background: var(--verde);
    margin-top:8px;
    transition:0.4s;
}

.beforeafter-subtitle{
    font-size: 13px;
    color: #888;
    letter-spacing: 1px;
    max-width: 400px;
    line-height: 1.5;
}

.reveal {
  opacity: 0;
  transform: translateY(30px);
  transition: 0.6s ease;
}

.reveal.active {
  opacity: 1;
  transform: none;
}

.video-title {
  text-align: center;
  font-size: 12px;
  letter-spacing: 3px;
  margin-bottom: 12px;
  color: #aaa;
  text-transform: uppercase;
}


@media (max-width: 600px){
  .hero{
    padding: 70px 5% 10px;
  }

  .hero h1{
    font-size: 22px;
    line-height: 1.3;
  }

  .hero p{
    font-size: 14px;
  }
}

@media (max-width: 600px){
  .cards-container{
    grid-template-columns: 1fr;
    gap: 14px;
  }
}

@media (max-width: 600px){
  .gallery-masonry{
    column-count: 1;
  }
}



@media (max-width: 768px){

  .hero,
  .section,
  .panel,
  .cards,
  .proyectos {
    padding: 60px 6%;
  }

  .arrow{
        width:48px;
        height:48px;

        font-size:20px;
    }

    .arrow.prev{
        left:6px;
    }

    .arrow.next{
        right:6px;
    }
}

@media (max-width: 900px) and (orientation: landscape){

    #ambientes .comparison-slider{
        aspect-ratio: 16 / 7;
        max-height: 72vh;
    }

    .hero{
        padding-top: 85px;
    }

}


html, body {
    max-width: 100%;
    overflow-x: hidden;
}

.footer-social{
    display:flex;
    flex-direction:column;
    gap:14px;
}

.footer-social h3{
    color:#fff;
    font-size:14px;
    letter-spacing:2px;
    text-transform:uppercase;
    margin-bottom:10px;
}

.footer-social a{
    color:#888;
    text-decoration:none;
    font-size:13px;

    display:flex;
    align-items:center;
    gap:10px;

    transition:0.3s ease;
}

.footer-social a:hover{
    color:var(--verde);
    transform:translateX(4px);
}

.footer-social i{
    color:var(--verde);
    font-size:14px;
    width:18px;
}

.youtube-more{
    text-align:center;
    margin-top:35px;
}

.youtube-more a{
    display:inline-flex;
    align-items:center;
    gap:10px;

    color:#888;
    text-decoration:none;

    font-size:12px;
    letter-spacing:3px;
    text-transform:uppercase;

    transition:0.3s ease;
}

.youtube-more a:hover{
    color:var(--verde);
    transform:translateY(-2px);
}

.youtube-more i{
    font-size:16px;
    color:#ff0000;
}
.mini-social{
    margin-top:30px;
    text-align:center;
}

.mini-social span{
    display:block;
    font-size:10px;
    letter-spacing:3px;
    text-transform:uppercase;
    color:#666;
    margin-bottom:14px;
}

.mini-social-links{
    display:flex;
    justify-content:center;
    gap:14px;
}

.mini-social-links a{
    width:44px;
    height:44px;


    border-radius:50%;

    display:flex;
    align-items:center;
    justify-content:center;

    text-decoration:none;

    background: transparent;

    border:1px solid rgba(255,255,255,0.06);

    color:#fff;

    transition:0.3s ease;

    position: relative;
    overflow: hidden;
}

.mini-social-links a i{
    position: relative;

    font-size: 28px;
    line-height: 1;

    display:flex;
    align-items:center;
    justify-content:center;
    top: 10px;

    
}

.mini-social-links a:hover{
    color: var(--verde);

    background: rgba(37,211,102,0.06);

    border-color: rgba(37,211,102,0.25);

    transform: translateY(-2px);
}























/* ========================================================= */
/* HERO LINKS */
/* ========================================================= */

.hero-servicios-links{
    display:flex;
    justify-content:center;
    gap:16px;
    margin-top:30px;
    flex-wrap:wrap;
}

.hero-link{
    background-color: transparent;
    color: var(--verde);

    padding: 15px 35px;

    border: 1px solid var(--verde);

    border-radius:50px;

    text-decoration: none;

    font-weight: 600;

    text-transform: uppercase;

    font-size: 12px;

    letter-spacing: 2px;

    display: inline-block;

    transition: all 0.3s;

    animation: hero-pulse 2.2s infinite;
}

@keyframes hero-pulse {

    0% {
        box-shadow: 0 0 0 0 rgba(37, 211, 102, 0.35);
    }

    70% {
        box-shadow: 0 0 0 10px rgba(37, 211, 102, 0);
    }

    100% {
        box-shadow: 0 0 0 0 rgba(37, 211, 102, 0);
    }

}
.hero-link:hover{
    background-color: var(--verde);
    color:#000;

    transform:translateY(-2px);
}
.hero-link:hover{

    background:var(--verde);

    color:#000;

    border-color:var(--verde);

    transform:translateY(-2px);

    box-shadow:
    0 0 22px rgba(37,211,102,0.45);
}






.hero-overlay{
    max-width: 760px;
    text-align:center;
    z-index:2;

    display:flex;
    flex-direction:column;
    align-items:center;
}

.hero-tag{
    display:inline-block;

    margin-bottom:18px;

    padding:8px 14px;

    border-radius:20px;

    font-size:11px;
    letter-spacing:3px;

    background:rgba(255,255,255,0.08);

    border:1px solid rgba(255,255,255,0.1);

    color:var(--verde);
}

.hero-servicio h1{
    font-size: clamp(30px, 4vw, 52px);

    line-height:1.15;

    font-weight:300;

    letter-spacing:1px;

    max-width: 780px;

    margin:0 auto 20px;
}

.hero-servicio p{
    max-width:620px;
    margin:0 auto 28px;

    color:#ccc;

    font-size:16px;

    line-height:1.8;
}


#servicios{
  margin-top: -20px; /* acerca servicios al hero */
  padding-top: 80px;
  display: block;
  text-align: left;
}
.servicios-lista{

  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 18px;
   margin-top: 25px;
  padding-left: 0;
  list-style: none;
  max-width: 700px;
}
.servicios-lista li{
  margin-bottom: 18px;
  text-align: left;
}

.servicios-lista li span{
  display: block;
  font-weight: 500;
  letter-spacing: 1px;
  text-transform: uppercase;
  font-size: 13px;
  color: #ffffff;
  margin-bottom: 5px;
}

.servicios-lista li p{
  margin: 0;
  color: #bdbdbd;
  font-size: 14px;
  line-height: 1.6;
}
.servicio-item{
  padding: 0;
  border: none;
  background: none;
}
.servicio-item:last-child{
  border-bottom: none;
}
.servicio-item:hover{
  border-left: 2px solid var(--verde);
  transform: translateX(4px);
}
.servicio-item h3{
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-bottom: 4px;
  color: #eaeaea;
}

.servicio-item p{
  font-size: 14px;
  line-height: 1.6;
  color: #b8b8b8;
  margin: 0;
}
/* ========================================================= */
/* STORYTELLING */
/* ========================================================= */

.storytelling-grid{
    display:grid;

    grid-template-columns:1fr 1fr;
    gap:60px;

    align-items:center;

    max-width:1100px;
margin: 0 auto;
  overflow: hidden;
    margin:0 auto;
}

.storytelling-img img{
    width:100%;
    max-height:520px;

    object-fit:cover;
position: relative;
    border-radius:24px;
}
.storytelling-img::after{
  content: "→ deslizar";
  position: absolute;
  right: 10px;
  bottom: -22px;

  font-size: 10px;
  letter-spacing: 2px;
  color: rgba(255,255,255,0.4);
}
.storytelling-text p{
    
    margin-bottom:18px;

    max-width:620px;
    font-size: 15px;
  line-height: 1.9;
  color: #d0d0d0;
}


@media (max-width:768px){

    .storytelling-grid{
        grid-template-columns:1fr;

        gap:30px;
    }

    .storytelling-img img{
        height:260px;
    }

    .muzilli-title{
        font-size:34px;
    }

    
    .storytelling-grid{
    grid-template-columns:1fr;
    gap:28px;
}

.muzilli-title{
    font-size:32px;
    letter-spacing:1px;
}

.storytelling-img img{
    max-height:340px;
}
}

.storytelling-premium p{
  font-size: 15px;
  line-height: 1.9;
  color: #d0d0d0;
}
.storytelling-premium .muzilli-title{
    position:relative;
    display:inline-block;

    font-size: clamp(28px, 4vw, 48px);
    
    margin-bottom:22px;
    font-weight: 300;
  letter-spacing: 2px;
  line-height: 1.2;

}

.storytelling-premium .muzilli-title::after{
    content:'';

    position:absolute;
    left:0;
    bottom:-10px;

    width:70px;
    height:1px;

    background:var(--verde);

    transition:0.4s ease;
}

.storytelling-premium:hover .muzilli-title::after{
    width:140px;
}

.btn-primary{
  display: inline-block;
  margin-top: 20px;
  padding: 10px 18px;
  border: 1px solid #2aff8a;
  color: #2aff8a;
  text-transform: uppercase;
  letter-spacing: 2px;
  font-size: 12px;
  text-decoration: none;
  transition: 0.3s ease;
}

.btn-primary:hover{
  background: #2aff8a;
  color: #000;
}
/* ========================================================= */
/* GALERÍA EDITORIAL */
/* ========================================================= */

.gallery-editorial{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:18px;
    margin-top:30px;
}

.editorial-item{
    overflow:hidden;
    border-radius:18px;
    cursor:pointer;
}

.editorial-item img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
    transition:0.4s ease;
}

.editorial-item:hover img{
    transform:scale(1.03);
}

.editorial-item.large{
    grid-column:span 2;
}

.editorial-item.horizontal{
    grid-column:span 2;
}

@media (max-width:768px){

    .gallery-editorial{
        grid-template-columns:1fr;
    }

    .editorial-item.large,
    .editorial-item.horizontal{
        grid-column:span 1;
    }

}

/* ========================================================= */
/* PROCESS */
/* ========================================================= */

.process-carousel{
  display: flex;
  overflow-x: auto;
  gap: 16px;
  scroll-snap-type: x mandatory;
  padding-bottom: 10px;
    scroll-behavior: smooth;

}

.process-item{
  min-width: 260px;
  scroll-snap-align: start;
  position: relative;
  flex: 0 0 auto;
}


.process-item img{
  width: 100%;
  height: 320px;
  object-fit: cover;
  border-radius: 12px;
}

.process-item span{
  display: block;
  margin-top: 8px;
  font-size: 11px;
  letter-spacing: 2px;
  color: rgba(255,255,255,0.6);
}

.process-header{
    margin-bottom:30px;
}

.process-content{
    display:none;
    margin-top:40px;
}

.process-content.active{
    display:block;
}

.process-project{
    margin-bottom:60px;
}

.process-info{
    margin-bottom:20px;
}

.process-gallery{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:16px;
}

.process-step{
    position:relative;
}

.process-step span{
    position:absolute;
    top:12px;
    left:12px;

    background:rgba(0,0,0,0.6);
    backdrop-filter:blur(8px);

    padding:6px 10px;
    border-radius:20px;

    font-size:10px;
    letter-spacing:2px;
    color:#fff;

    z-index:5;
}

.process-carousel::-webkit-scrollbar{
  height: 4px;
}

.process-carousel::-webkit-scrollbar-thumb{
  background: rgba(37,211,102,0.3);
  border-radius: 10px;
}

@media (max-width:768px){

    .process-gallery{
        grid-template-columns:1fr;
    }

}

.mini-espacios-grid{
    display:grid;
    grid-template-columns: repeat(3,1fr);
    gap:18px;
    margin-top:30px;
}

.mini-space{
    position:relative;
    border-radius:18px;
    overflow:hidden;
    aspect-ratio:1/1;
}

.mini-space img{
    width:100%;
    height:100%;
    object-fit:cover;
    transition:0.4s ease;
}

.mini-space span{
    position:absolute;
    bottom:14px;
    left:14px;

    font-size:11px;
    letter-spacing:2px;

    background:rgba(0,0,0,0.5);

    padding:8px 12px;

    border-radius:20px;
}

.mini-space:hover img{
    transform:scale(1.05);
}

@media (max-width: 768px){

  .mini-espacios-grid{
      grid-template-columns:1fr;
  }

}





.more-transformations{
    display:flex;
    justify-content:center;

    margin-top:30px;
}

.btn-more-transformations{
  display: inline-block;
  margin-top: 18px;
  font-size: 13px;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: #bfbfbf;
  border-bottom: 1px solid rgba(255,255,255,0.25);
  padding-bottom: 4px;
  background: transparent;
  transition: 0.3s ease;
}

.btn-more-transformations:hover{
  color: #ffffff;
  border-bottom: 1px solid #00ff88;
}

.extra-transformations{
    display:none;

    margin-top:30px;
}


.btn-more-transformations{
  background: transparent;
  color: var(--verde);
  border: 1px solid var(--verde);
 position: relative;
  padding: 8px 0;
  font-size: 12px;
  letter-spacing: 2px;
  text-transform: uppercase;
  cursor: pointer;
  transition: 0.3s ease;
  display: inline-block;
}

/* hover premium */
.btn-more-transformations:hover{
  background: var(--verde);
  color: #000;
  transform: translateY(-2px);
}

/* pequeño glow suave */
.btn-more-transformations{
  box-shadow: 0 0 0 0 rgba(37,211,102,0.3);
}


.nav-desktop a.active-link{

    color:#00e676;
}

.nav-desktop a.active-link::after{

    width:100%;
}





.proyectos{
    text-align:center;
    padding: 40px 7% 20px;
}

.proyectos-header{
    margin-bottom: 30px;
    margin-top: 80px;
}

.galeria-title{
    font-size: 28px;
    letter-spacing: 4px;
    font-weight: 300;
    margin: 0;
    color: #fff;
    position: relative;
    display: inline-block;
    text-transform: uppercase;
}

.galeria-title::after{
    content:"";
    display:block;
    width:60px;
    height:2px;
    background:var(--verde);
    margin:12px auto 0;
    transition:0.4s;
    box-shadow:0 0 12px rgba(37,211,102,0.4);
}

.proyectos-header:hover .galeria-title::after{
    width:120px;
}

.proyecto-subtitulo{
    color:#8a8a8a;
    font-size:15px;
    max-width:700px;
    margin:20px auto 0;
    line-height:1.7;
}

.hero-servicios-links{
    display:flex;
    justify-content:center;
    gap:16px;
    margin-top:30px;
    flex-wrap:wrap;
}

.hero-link{
    background-color: transparent;
    color: var(--verde);
    padding: 15px 35px;
    border: 1px solid var(--verde);
    border-radius:50px;
    text-decoration: none;
    font-weight: 600;
    text-transform: uppercase;
    font-size: 12px;
    letter-spacing: 2px;
    display: inline-block;
    transition: all 0.3s;
}

.hero-link:hover{
    background: var(--verde);
    color:#000;
    transform: translateY(-2px);
}

@media (max-width: 768px){

    .galeria-title{
        font-size:22px;
        line-height:1.4;
    }

    .proyecto-subtitulo{
        font-size:14px;
    }

    .hero-link{
        width:100%;
        max-width:320px;
    }


  .proyectos{
    padding: 20px 6% 10px;
  }

  .proyectos-header{
    margin-top: 40px;
    margin-bottom: 25px;
  }

  .galeria-title{
    font-size: 2rem;
    letter-spacing: 5px;
    line-height: 1.3;
  }

  .proyecto-subtitulo{
    font-size: 1rem;
    line-height: 1.8;
    margin-top: 18px;
  }


  .hero{
    padding: 110px 6% 30px;
    text-align: left;
  }

  .hero h1{
    font-size: 2.7rem;
    line-height: 1.15;
    letter-spacing: 4px;
    margin-top: 0;
    margin-bottom: 20px;
  }

  .hero h1::after{
    left: 0;
    transform: none;
  }

  .hero p{
    font-size: 1.1rem;
    line-height: 1.7;
    margin-top: 18px;
  }

  .hero-servicios-links{
    margin-top: 35px;
    gap: 14px;
  }

  .hero-link{
    width: 100%;
    text-align: center;
  }

}

/* =========================================================
   BEFORE / AFTER SLIDER
========================================================= */
@media (max-width: 768px){

  .slide-layout{
    display: flex;
    flex-direction: column;
    gap: 20px;
    align-items: center;
  }

  .slide-media{
    width: 100%;
  }




  .slide-text{
    width: 100%;
    text-align: center;
    margin-top: 0;
  }

  .slide-text p{
    max-width: 100%;
    margin: 10px auto 0;
  }

}
    
@media (max-width: 768px){

  /* ================= AMBIENTES ================= */
  /* ===== FIX REAL FIT SCREEN ===== */

  .ambientes-wrapper{
    height: auto; /* 🔥 rompe el bloqueo de 100vh */
  }

  .panel{
    padding: 15px 7%; /* 🔥 reduce altura */
  }

}

.slide-text{
    text-align: center;
    max-width: 700px;
}

.slide-text h3{
  font-size: 18px;
  margin-bottom: 6px;
}

.slide-text p{
  font-size: 13px;
  line-height: 1.5;
}



.img-container{
    position: relative;
    width: 100%;
    height:100%;

}



#ambientes{
  padding-top: 30px;
  padding-bottom: 20px;
}

#ambientes .galeria-header-principal{
  margin-bottom: 4px;
}

#ambientes h2{
  margin-bottom: 6px;
  font-size: clamp(18px, 2.2vw, 24px);
}


#ambientes .slider-container {
  width: 100%;
}


#ambientes .before-after-slider {
  max-height: none;
}


/* texto del slide más compacto */
.slide-text h3 {
  margin-bottom: 6px;
}

.slide-text p {
  font-size: 13px;
  line-height: 1.4;
}

.planta{margin-top:0px;}
.planta h2{margin-bottom:20px;font-weight:300;}

.ambiente-container{
    display:flex;
    align-items:center;
    gap:20px;
    min-height:60vh;
    position:relative;
}



.handle::after{
content:"↔";
position:absolute;
top:50%;
left:50%;
transform:translate(-50%,-50%);
width:36px;
height:36px;
border-radius:50%;
background:#fff;
color:#000;
display:flex;
align-items:center;
justify-content:center;
font-size:14px;
box-shadow:0 10px 20px rgba(0,0,0,0.5);
}

/* FLECHAS */
.flechas{
    position:absolute;
    right:-50px;
    top:30%;
    transform:translateY(-50%);
    display:flex;
    flex-direction:column;
    gap:10px;
}

.flechas span{
    font-size:28px;
    cursor:pointer;
    background: rgba(0,0,0,0.3);
    backdrop-filter: blur(6px);
    width:40px;
    height:40px;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    transition:0.3s;
}


@keyframes pulseHandle {
    0% {
        transform: translate(-50%, -50%) scale(1);
        box-shadow: 0 0 0 0 rgba(255,255,255,0.35);
    }
    70% {
        transform: translate(-50%, -50%) scale(1.05);
        box-shadow: 0 0 0 12px rgba(255,255,255,0);
    }
    100% {
        transform: translate(-50%, -50%) scale(1);
        box-shadow: 0 0 0 0 rgba(255,255,255,0);
    }
}




@media (max-width: 768px){

  
 .slide-media{
    width: 100%;
 }

 .carousel-track{
    width: 100%;
 }

 .carousel-item{
    width: 100%;
    flex-shrink: 0;
 }

#ambientes .comparison-slider{

      width: 100%;

      aspect-ratio: 4 / 5;

      height: auto;

      max-height: none;

      border-radius: 18px;
  }

  .comparison-slider img{
    width: 100%;
    height: 100%;
    object-fit: contain;
  }

  .slide-text{
    text-align: center;
    padding: 0 18px;
    margin-top: 4px;
  }

  .slide-text h3{
    font-size: 18px;
    margin-bottom: 6px;
    letter-spacing: 2px;
  }

  .slide-text p{
    font-size: 13px;
    line-height: 1.6;
    max-width: 100%;
    color: #999;
  }

  .carousel{
    gap: 10px;
  }

  .arrow{
    width: 42px;
    height: 42px;
    font-size: 22px;
  }
#ambientes .panel{
    padding-left: 0;
    padding-right: 0;
}

#ambientes .slide-layout{
    width: 100%;
}

#ambientes .slide-media{
    width: 100%;
}

#ambientes .comparison-slider{
    width: 100vw;
    margin-left: calc(50% - 50vw);

    border-radius: 0;
}
}




/* hint */
.slider-hint{
    position:absolute;
    bottom:10px;
    left:50%;
    transform:translateX(-50%);
    font-size:10px;
    color:#aaa;
    letter-spacing:2px;
    z-index: 5;
}

.pagina-proyecto-muzilli .slider-handle{
    left: 30%;
}
.pagina-proyecto-muzilli .img-before{
    clip-path: inset(0 70% 0 0);
}



.servicio-slider .comparison-slider{
    aspect-ratio: 16 / 10;
    max-width: 900px;
}

.comparison-slider::after{
    content:"";
    position:absolute;
    inset:0;
    background: linear-gradient(to bottom, rgba(0,0,0,0.05), rgba(0,0,0,0));
    pointer-events:none;
}

.comparison-slider img{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    object-fit:contain;
    object-position:center;
    pointer-events:none;
}

.img-after{
    z-index:1;
}

.img-before{
    z-index:2;
    clip-path: inset(0 50% 0 0);
}

.slider-handle{
    position: absolute;
    top: 0;
    bottom: 0;
    left: 50%;
    width: 2px;
    background: rgba(255,255,255,0.8);
    z-index: 10;
    box-shadow: 0 0 20px rgba(255,255,255,0.15);
}

.handle-circle{
    position:absolute;
    top:50%;
    left:50%;
    transform:translate(-50%,-50%);
    width:46px;
    height:46px;
    border-radius:50%;
    background: rgba(255,255,255,0.95);
    color:#000;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:13px;
    font-weight:500;
    box-shadow: 0 10px 30px rgba(0,0,0,0.35);
    backdrop-filter: blur(6px);
    transition: transform 0.2s ease;
}

.slider-handle:hover .handle-circle{
    transform: translate(-50%, -50%) scale(1.08);
}

/* labels */
.label{
    position:absolute;
    top:18px;
    font-size:10px;
    letter-spacing:3px;
    padding:6px 10px;
    background: rgba(0,0,0,0.35);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius:20px;
    color:#fff;
    backdrop-filter: blur(8px);
    z-index:20;
    opacity:0.85;
    transition: opacity 0.2s ease;
}

.comparison-slider .label{
    will-change: transform;
}

.label.before{ left:12px; }
.label.after{ right:12px; }
.panel{
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 30px 7%;
}

/* separador visual sutil */
.panel.alta{
    border-bottom: 1px solid rgba(255,255,255,0.08);
}


.slide-layout{
    display: flex;
    flex-direction: column;
    gap: 22px;
    align-items: center;
    width: 100%;
}

/* imagen grande protagonista */
.slide-media{
    min-width:0; /* 🔥 SUPER CLAVE */
   width:100%;
}
/* texto a la derecha */
.slide-text h3{
    font-size: 20px;
    letter-spacing: 3px;
    font-weight: 300;
    margin-bottom: 10px;
}

.slide-text p{
    color: #888;
    font-size: 14px;
    line-height: 1.6;
    max-width: 320px;
}









.carousel-title{
    margin-top:10px;
    font-size:12px;
    letter-spacing:2px;
    color:#aaa;
    text-transform:uppercase;
    text-align:center;
}





.carousel{
    position: relative;

    display:flex;
    align-items:center;
    justify-content:center;

    width:100%;
    overflow: visible;
}

.carousel-track {
    display: flex;
    width: 100%;
    overflow: hidden;
    touch-action: pan-y;
}

.carousel-item{
    min-width: 100%;
    width: 100%;
    flex-shrink: 0;
}
.carousel-item > img{
  width:100%;
  height:320px;
  object-fit:cover;
  border-radius:16px;
}

.carousel-item span{
  display: block;
  margin-top: 8px;
  font-size: 11px;
  letter-spacing: 2px;
  color: rgba(255,255,255,0.6);
}



@media (min-width: 769px){

  .ambientes-wrapper{
      display: flex;
      flex-direction: column;
      gap: 0px;
  }

  .carousel-track{
      overflow: hidden;
      width: 100%;
  }


  .carousel-item{
    width: 100%;
    flex-shrink: 0;
  }

  .slide-media{
    width: 100%;
  }
}
   



#ambientes .comparison-slider{
    position: relative;

    width: 100%;
    max-width: 1100px;

    margin: 0 auto;

    aspect-ratio: 16 / 9;

    overflow: hidden;

    border-radius: 28px;

    background:#0f0f0f;

    user-select:none;
    -webkit-user-select:none;

    touch-action: pan-y;
}