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

html{
    scroll-behavior:smooth;
}

body{
    font-family:Arial, Helvetica, sans-serif;
    color:#fff;
}

.container{
    width:90%;
    max-width:1280px;
    margin:auto;
}

/*================ HEADER ================*/

.header{

    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 1000;

    padding: 20px 0;

    background: transparent;

}

.header .container{

    max-width: 1800px;
    margin: 0 auto;

    padding: 0 25px;

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

    gap: 25px;

}
.header.scrolled{

    background: rgba(13, 92, 68, 0.80);

    backdrop-filter: blur(15px);
    -webkit-backdrop-filter: blur(15px);

    border-bottom: 1px solid rgba(255,255,255,0.05);

    transition: .4s;

}

.logo img{

    height: 70px;
    display: block;

}

.menu{

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

    gap: 14px;

    flex: 1;

    margin: 0 40px;

}

.menu a{

    color: white;
    text-decoration: none;
    font-weight: 600;

    padding: 14px 24px;

    border: 1px solid rgba(255,255,255,.18);

    background: rgba(255,255,255,.05);

    backdrop-filter: blur(12px);

    border-radius: 999px;

    transition: .35s;

    white-space: nowrap;

}

.menu a:hover{

    background: #0d5c44;
    border-color: #0d5c44;

    transform: translateY(-3px);

}

.btn-menu{

    min-width: 260px;

    text-align: center;

    background: #0d5c44;
    color: white;

    padding: 18px 34px;

    border-radius: 999px;

    text-decoration: none;

    font-weight: 700;

    transition: .35s;

    box-shadow: 0 10px 30px rgba(13,92,68,.35);

}

.btn-menu:hover{

    background: #117253;

    transform: translateY(-3px);

}
/*================ HERO ================*/

.hero{
    position:relative;
    min-height:90vh;
    padding-top:90px;
    padding-bottom:60px;
    display:flex;
    justify-content:center;
    align-items:center;
    text-align:center;
    overflow:hidden;
}

.hero-image{
    position:absolute;
    inset:0;

    background:url("../assets/img/hero.jpg") center center/cover no-repeat;
}

.overlay{
    position:absolute;
    inset:0;
    background:rgba(0,0,0,.65);
}

.hero-content{
    position:relative;
    z-index:5;
    max-width:950px;

    display:flex;
    flex-direction:column;
    align-items:center;

    padding-top:100px;
}

.hero-logo{
    width:300px;
    margin-bottom:40px;
    display:block;

}

.tag{

    display:block;

    text-align:center;

    letter-spacing:7px;

    font-size:18px;

    margin-bottom:25px;

}

.hero h1{

    font-size:3rem;

    line-height:1.05;

    margin-bottom:20px;

}

.hero p{

    font-size:30px;

    max-width:950px;

    line-height:1.6;

    margin-bottom:35px;

}

.hero-buttons{

    display:flex;

    gap:25px;

    justify-content:center;

}

.btn-primary{

    background:#0d5c44;

    color:white;

    padding:22px 48px;

    border-radius:60px;

    text-decoration:none;

    font-size:22px;

    font-weight:700;

}

.btn-secondary{

    border:2px solid white;

    color:white;

    padding:22px 48px;

    border-radius:60px;

    text-decoration:none;

    font-size:22px;

    font-weight:600;

}
/*================ PALMEIRAS EN NÚMEROS ================*/

.numbers{

    padding:35px 0 40px;

    background:linear-gradient(
    180deg,
    #ffffff 0%,
    #f4f7f5 100%
    );

    text-align:center;

}

.section-tag{

    display:inline-block;

    background:#0d5c44;

    color:white;

    padding:10px 24px;

    border-radius:50px;

    font-size:13px;

    letter-spacing:3px;

    font-weight:700;

    margin-bottom:18px;

}

.numbers h2{

    text-align:center;

    font-size:52px;

    color:#222;

    margin-bottom:12px;

}

.section-description{

    max-width:720px;

    margin:15px auto 30px;

    color:#666;

    font-size:20px;

    line-height:1.7;

}

.cards{

    display:grid;

    grid-template-columns:repeat(5,1fr);

    gap:28px;

}

.card{

    background:white;

    border-radius:24px;

    padding:35px 18px;

    border:1px solid #edf1ef;

    box-shadow:0 12px 30px rgba(0,0,0,.05);

    transition:.35s;

}

.card:hover{

    transform:translateY(-8px);

    border-color:#0d5c44;

    box-shadow:0 22px 45px rgba(13,92,68,.18);

}

.card h3{

    font-size:46px;

    color:#0d5c44;

    margin-bottom:10px;

    font-weight:800;

}

.card span{

    display:block;

    color:#666;

    font-size:16px;

    text-transform:uppercase;

    letter-spacing:1px;

    font-weight:600;

}
.icon-circle{

    width:72px;
    height:72px;

    margin:0 auto 22px;

    border-radius:50%;

    background:linear-gradient(
        135deg,
        #0d5c44,
        #198754
    );

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

    box-shadow:0 10px 25px rgba(13,92,68,.25);

}

.icon-circle i{

    color:white;

    font-size:30px;

}
/*================ UBICACIÓN ================*/

.location{

    background:white;

    padding:0;

}

.location-grid{

    display:grid;

    grid-template-columns:72% 28%;

    gap:0;

    align-items:stretch;

}

.location-image{

    height:100%;

}

.location-image img{

    width:100%;

    height:800px;

    object-fit:cover;

    display:block;

    transition:.5s;

}
.location-image{

    position:relative;

    height:100%;

}

.location-image img:hover{

    transform:scale(1.02);

}

.location-content h2{

    font-size:46px;

    font-weight:700;

    line-height:1.15;

    color:#1f1f1f;

    margin:18px 0 18px;

}

.location-content p{

    font-size:18px;

    color:#666;

    line-height:1.6;

    margin-bottom:10px;

}

.location-content ul{

    list-style:none;

    margin-bottom:10px;

}

.location-content{

    padding:25px 40px;

    display:flex;

    flex-direction:column;

    justify-content:center;

}
.location-buttons{

    display:flex;

    gap:18px;

    margin-top:-8px;

    align-items:center;

}
.btn-location{

    width:64px;

    height:64px;

    background:#0d5c44;

    border-radius:50%;

    display:flex;

    justify-content:center;

    align-items:center;

    text-decoration:none;

    color:white;

    flex-shrink:0;

    transition:.3s;

}

.btn-location:hover{

    background:#0a4a36;

}

.btn-location:hover{

    background:#0a4a36;

    color:white;

}

.btn-location i{

    font-size:30px;

    margin:0;

    line-height:1;

}
.location-content li{

    display:flex;

    align-items:center;

    gap:14px;

    font-size:18px;

    margin-bottom:22px;

    color:#444;

}

.location-content li i{

    color:#0d5c44;

    font-size:22px;

    width:28px;

    text-align:center;

}
.btn-location-primary{

    background:#0d5c44;

    color:white;

    padding:16px 32px;

    min-width:220px;

    border-radius:50px;

    text-align:center;

    text-decoration:none;

    font-weight:700;

    transition:.3s;

}

.btn-location-primary:hover{

    background:#0a4a36;

}
/*================ ASÍ NACE TU PATRIMONIO ================*/

.journey{

    padding:70px 0;

    background:#f8f8f6;

}

.journey .section-tag{

    display:block;

    width:max-content;

    margin:-35px auto 0;

}

.journey h2{

    text-align:center;

    font-size:52px;

    color:#222;

    margin:18px 0 10px;

}

.journey .section-description{

    text-align:center;

    font-size:22px;

    color:#666;

    margin-bottom:55px;

}

.timeline{

    display:flex;

    align-items:flex-start;

    justify-content:center;

}

.step{

    width:170px;

    text-align:center;

}

.step-circle{

    width:78px;

    height:78px;

    background:#0d5c44;

    color:white;

    border-radius:50%;

    margin:auto;

    display:flex;

    justify-content:center;

    align-items:center;

    font-size:30px;

    box-shadow:0 15px 35px rgba(13,92,68,.25);

    transition:.35s;

}

.step{

    transition:.35s;

}

.step:hover{

    transform:translateY(-8px);

}

.step:hover .step-circle{

    transform:scale(1.08);

    box-shadow:0 22px 45px rgba(13,92,68,.35);

}

.step-month{

    display:inline-block;

    margin-top:16px;

    padding:6px 16px;

    background:#eef7f3;

    color:#0d5c44;

    border-radius:30px;

    font-size:13px;

    font-weight:700;

    letter-spacing:1px;

}

.step h3{

    font-size:19px;

    margin-top:10px;

    line-height:1.5;

    color:#222;
    
    font-size:18px;

    line-height:1.4;

}

.step-line{

    width:90px;

    height:4px;

    background:linear-gradient(to right,#0d5c44,#7fc9b3);

    border-radius:20px;

    margin-top:44px;

}

.journey-footer{

    margin-top:55px;

    text-align:center;

}

.journey-footer h3{

    font-size:42px;

    color:#0d5c44;

    margin-bottom:15px;

}

.journey-footer p{

    font-size:22px;

    color:#555;

    max-width:850px;

    margin:auto;

    line-height:1.8;

}
.step:hover h3{

    color:#0d5c44;

}

.step:hover .step-month{

    background:#0d5c44;

    color:white;

}
/*================ PLANO MAESTRO ================*/

.master-plan{

    padding:0px 0;

    background:#ffffff;

}

.master-plan .section-tag{

    display:block;

    width:max-content;

    margin:0 auto 15px;

}

.master-plan h2{

    text-align:center;

    font-size:48px;

    color:#222;

    margin:18px 0 10px;

}

.master-plan .section-description{

    max-width:760px;

    margin:0 auto 28px;

    text-align:center;

    color:#666;

    font-size:20px;

    line-height:1.7;

}

.plan-wrapper{

    position:relative;

    overflow:hidden;

    border-radius:22px;

    box-shadow:0 30px 80px rgba(0,0,0,.12);

    transition:.45s;
    
    max-width:1500px;

    margin:auto;

    margin-top:0;

}

.plan-wrapper:hover{

    transform:translateY(-6px);

    box-shadow:0 40px 100px rgba(0,0,0,.18);

}

.plan-image{

    overflow:hidden;
    transform:scale(1.02);

}

.plan-image img{

    width:100%;

    display:block;

    transition:transform .8s ease;

}

.plan-wrapper:hover img{

    transform:scale(1.05);

}

.plan-info{

    display:flex;

    justify-content:center;

    gap:80px;

    margin-top:40px;

    flex-wrap:wrap;

}

.plan-item{

    display:flex;

    align-items:center;

    gap:12px;

    color:#0d5c44;

    font-weight:700;

    font-size:18px;

}

.plan-item i{

    font-size:22px;

}

.plan-item span{

    color:#444;

}
/*================ CABAÑAS PREMIUM ================*/

.gallery{

    width:100%;

    height:100vh;

    overflow:hidden;

    position:relative;

    background:#111;

}

.gallery-slider{

    position:relative;

    width:100%;

    height:100%;

}

.slide{

    position:absolute;

    inset:0;

    width:100%;

    height:100%;

    object-fit:cover;

    opacity:0;

    transform:scale(1);

    transition:

    opacity .9s ease,

    transform 7s ease;

}

.slide.active{

    opacity:1;

    transform:scale(1.08);

}

.gallery-overlay{

    position:absolute;

    inset:0;

    background:

    linear-gradient(

    180deg,

    rgba(0,0,0,.20),

    rgba(0,0,0,.05),

    rgba(0,0,0,.45)

    );

    z-index:2;

}

.gallery-content{

    position:absolute;

    left:80px;

    bottom:90px;

    z-index:5;

    background:rgba(13,92,68,.90);

    backdrop-filter:blur(12px);

    padding:35px 45px;

    border-radius:22px;

    box-shadow:0 25px 60px rgba(0,0,0,.30);

    color:white;

    max-width:500px;

}

.gallery-tag{

    display:inline-block;

    letter-spacing:3px;

    font-size:13px;

    margin-bottom:14px;

    font-weight:700;

}

.gallery-content h2{

    font-size:48px;

    line-height:1.15;

    font-weight:700;

}

.gallery-prev,

.gallery-next{

    position:absolute;

    top:50%;

    transform:translateY(-50%);

    width:70px;

    height:70px;

    border-radius:50%;

    border:none;

    background:rgba(13,92,68,.85);

    color:white;

    cursor:pointer;

    font-size:28px;

    transition:.35s;

    z-index:10;

    opacity:0;

}

.gallery:hover .gallery-prev,

.gallery:hover .gallery-next{

    opacity:1;

}

.gallery-prev{

    left:40px;

}

.gallery-next{

    right:40px;

}

.gallery-prev:hover,

.gallery-next:hover{

    transform:translateY(-50%) scale(1.12);

    background:#0d5c44;

}

.gallery-dots{

    position:absolute;

    left:50%;

    bottom:40px;

    transform:translateX(-50%);

    display:flex;

    gap:12px;

    z-index:10;

}

.dot{

    width:45px;

    height:4px;

    border-radius:20px;

    background:rgba(255,255,255,.30);

    transition:.35s;

    cursor:pointer;

}

.dot.active{

    background:white;

    width:80px;

}
/*================ AVANCE PREMIUM ================*/

.progress-gallery{

    display:flex;

    width:100%;

    height:100vh;

    overflow:hidden;

}

.progress-item{

    position:relative;

    flex:1;

    overflow:hidden;

    cursor:pointer;

    transition:flex .8s ease;

}

.progress-item:hover{

    flex:1.8;

}

.progress-item img{

    width:100%;

    height:100%;

    object-fit:cover;

    transition:transform 6s ease;

}

.progress-item:hover img{

    transform:scale(1.08);

}

.progress-overlay{

    position:absolute;

    inset:0;

    background:linear-gradient(

    to top,

    rgba(0,0,0,.60),

    rgba(0,0,0,.10)

    );

    display:flex;

    justify-content:flex-end;

    align-items:flex-start;

    padding:40px;

}

.progress-overlay span{

    color:white;

    font-size:14px;

    letter-spacing:4px;

    font-weight:700;

    padding:14px 26px;

    border:1px solid rgba(255,255,255,.25);

    border-radius:50px;

    backdrop-filter:blur(12px);

    background:rgba(255,255,255,.08);

}
/*================ DOCUMENTACIÓN =================*/

.documents{

    padding:90px 0;

    background:#f8f8f5;

}

.documents .section-tag{

    display:block;

    width:max-content;

    margin:0 auto 18px;

}

.documents h2{

    text-align:center;

    font-size:48px;

    margin-bottom:60px;

    color:#222;

}

.documents-grid{

    display:grid;

    grid-template-columns:repeat(4,1fr);

    gap:28px;

}

.document-card{

    position:relative;

    overflow:hidden;

    border-radius:22px;

    text-decoration:none;

    box-shadow:0 20px 50px rgba(0,0,0,.10);

    transition:.45s;

}

.document-card:hover{

    transform:translateY(-10px);

    box-shadow:0 30px 70px rgba(0,0,0,.18);

}

.document-card img{

    width:100%;

    height:560px;

    object-fit:cover;

    display:block;

    transition:transform .8s ease;

}

.document-card:hover img{

    transform:scale(1.06);

}

.document-overlay{

    position:absolute;

    left:18px;

    right:18px;

    bottom:18px;

    padding:18px 22px;

    border-radius:18px;

    background:rgba(255,255,255,.15);

    backdrop-filter:blur(14px);

    -webkit-backdrop-filter:blur(14px);

    border:1px solid rgba(255,255,255,.25);

    transition:.35s;

}

.document-card:hover .document-overlay{

    background:rgba(13,92,68,.88);

}

.document-overlay h3{

    color:white;

    font-size:19px;

    line-height:1.35;

    font-weight:600;

    margin:0;

}
.document-card::before{

    content:"";

    position:absolute;

    top:0;

    left:0;

    width:0;

    height:5px;

    background:#0d5c44;

    transition:.4s;

    z-index:5;

}

.document-card:hover::before{

    width:100%;

}

.document-card::after{

    content:"";

    position:absolute;

    inset:0;

    background:linear-gradient(

        to top,

        rgba(0,0,0,.45),

        rgba(0,0,0,.05),

        transparent

    );

    pointer-events:none;

}
/*================ ¿QUÉ ENTREGAMOS? ================*/

.master-features{

    padding:45px 0 0;
    background:#fff;

}

.master-features .section-tag{

    display:block;
    width:max-content;
    margin:0 auto 18px;

}

.master-features h2{

    text-align:center;
    font-size:58px;
    line-height:1.08;
    color:#222;
    margin:0;

}

.master-features .section-description{

    max-width:760px;
    margin:16px auto 22px;
    text-align:center;
    color:#666;
    font-size:21px;
    line-height:1.6;

}

/*================ IMAGEN ================*/

.master-image{

    position:relative;
    max-width:1600px;
    margin:auto;
    overflow:hidden;
    border-radius:26px;
    box-shadow:0 30px 70px rgba(0,0,0,.15);

}

.master-image img{

    width:100%;
    height:520px;
    object-fit:cover;
    display:block;

}

/*================ HOTSPOTS ================*/

.hotspot{

    position:absolute;
    transform:translate(-50%,-50%);
    z-index:20;

}

.pulse{

    width:18px;
    height:18px;
    border-radius:50%;
    background:#0d5c44;
    border:4px solid #fff;
    animation:pulse 2s infinite;

}

@keyframes pulse{

0%{

transform:scale(1);
box-shadow:0 0 0 0 rgba(13,92,68,.45);

}

70%{

box-shadow:0 0 0 18px rgba(13,92,68,0);

}

100%{

transform:scale(1);
box-shadow:0 0 0 0 rgba(13,92,68,0);

}

}

/*================ TARJETAS ================*/

.tooltip{

    position:absolute;

    left:50%;
    bottom:30px;

    transform:translateX(-50%);

    width:170px;

    background:#fff;

    border-radius:18px;

    padding:12px;

    box-shadow:0 18px 45px rgba(0,0,0,.18);

    transition:.35s;

}

.hotspot:hover .tooltip{

    transform:translateX(-50%) translateY(-8px);

    box-shadow:0 25px 60px rgba(0,0,0,.25);

}

/* Línea */

.tooltip::after{

    content:"";

    position:absolute;

    left:50%;
    bottom:-24px;

    transform:translateX(-50%);

    width:2px;
    height:24px;

    background:#d8d8d8;

}

/* Círculo superior */

.tooltip::before{

    content:"";

    position:absolute;

    left:50%;
    top:-16px;

    transform:translateX(-50%);

    width:34px;
    height:34px;

    border-radius:50%;

    background:#0d5c44;

    border:3px solid #fff;

    box-shadow:0 8px 16px rgba(0,0,0,.12);

}

.tooltip h3{

    margin:8px 0 6px;

    text-align:center;

    color:#222;

    font-size:15px;

    font-weight:700;

    line-height:1.3;

}

.tooltip p{

    margin:0;

    text-align:center;

    color:#666;

    font-size:14px;

    line-height:1.45;

}

/*================ POSICIONES ================*/

/* Agua y electricidad */

.hotspot3{

    left:22%;
    top:66%;

}

/* Áreas verdes */

.hotspot4{

    left:50%;
    top:40%;

}

/* Cerco perimetral */

.hotspot2{

    left:86%;
    top:62%;

}

/* Pórtico de ingreso */

.hotspot1{

    left:38%;
    top:95%;

}

/* Vías afirmadas */

.hotspot6{

    left:50%;
    top:95%;

}

/* Cámaras de seguridad */

.hotspot5{

    left:62%;
    top:95%;

}
/*================ EFECTO MASONRY ================*/

.moments-column:nth-child(2){

    margin-top:40px;

}

/*================ PLAY =================*/

.play-button{

    position:absolute;

    top:50%;

    left:50%;

    transform:translate(-50%,-50%);

    width:74px;

    height:74px;

    border:none;

    border-radius:50%;

    background:rgba(255,255,255,.88);

    color:#0d5c44;

    font-size:38px;

    cursor:pointer;

    z-index:6;

    transition:.35s;

    box-shadow:0 12px 30px rgba(0,0,0,.25);

}

.play-button:hover{

    transform:translate(-50%,-50%) scale(1.08);

    background:white;

}

.play-button i{

    margin-left:4px;

}

/*================ VIDEO =================*/

.testimonial video{

    width:100%;

    height:280px;

    object-fit:cover;

    cursor:pointer;

}

/*=====================================================
                MOMENTOS PALMEIRAS
======================================================*/

.moments{

    padding:110px 0;
    background:#f7f7f5;
    overflow:hidden;

}

.moments .section-tag{

    display:block;
    width:max-content;
    margin:auto;

}

.moments h2{

    font-size:58px;
    text-align:center;
    margin:22px 0 70px;
    color:#1e1e1e;

}

/*================ GRID =================*/

.moments-grid{

    display:grid;

    grid-template-columns:repeat(3,1fr);

    gap:28px;

}

/*================ TARJETA =================*/

.moment-card{

    position:relative;

    overflow:hidden;

    border-radius:26px;

    cursor:pointer;

    background:white;

    box-shadow:0 20px 50px rgba(0,0,0,.12);

    transition:.45s;

}

.moment-card:hover{

    transform:translateY(-10px);

    box-shadow:0 35px 80px rgba(0,0,0,.20);

}

/*================ IMÁGENES =================*/

.moment-card img{

    width:100%;

    height:520px;

    object-fit:cover;

    display:block;

    transition:1s;

}

.moment-card:hover img{

    transform:scale(1.06);

}

/*================ VIDEO =================*/

.video-card{

    position:relative;

}

.video-card video{

    width:100%;

    height:520px;

    object-fit:cover;

    display:block;

}

/*================ PLAY =================*/

.play-btn{

    position:absolute;

    left:50%;

    top:50%;

    transform:translate(-50%,-50%);

    width:84px;

    height:84px;

    border:none;

    border-radius:50%;

    background:rgba(255,255,255,.92);

    color:#0d5c44;

    font-size:44px;

    cursor:pointer;

    transition:.35s;

    z-index:20;

    box-shadow:0 15px 40px rgba(0,0,0,.25);

}

.play-btn:hover{

    transform:translate(-50%,-50%) scale(1.08);

    background:white;

}

.play-btn i{

    margin-left:5px;

}

/*================ ETIQUETA =================*/

.video-tag{

    position:absolute;

    top:18px;

    left:18px;

    z-index:15;

    padding:9px 18px;

    border-radius:40px;

    background:rgba(13,92,68,.92);

    color:white;

    font-size:13px;

    font-weight:700;

    letter-spacing:.5px;

}

/*================ OVERLAY =================*/

.moment-card::after{

    content:"";

    position:absolute;

    inset:0;

    background:linear-gradient(

    transparent 60%,

    rgba(0,0,0,.12)

    );

    pointer-events:none;

}

/*================ LIGHTBOX =================*/

.lightbox{

    position:fixed;

    inset:0;

    background:rgba(0,0,0,.95);

    display:flex;

    justify-content:center;

    align-items:center;

    opacity:0;

    visibility:hidden;

    transition:.35s;

    z-index:9999;

}

.lightbox.active{

    opacity:1;

    visibility:visible;

}

.lightbox img{

    max-width:92%;

    max-height:92vh;

    border-radius:18px;

    box-shadow:0 30px 80px rgba(0,0,0,.45);

}

.lightbox-close{

    position:absolute;

    top:35px;

    right:40px;

    font-size:42px;

    color:white;

    cursor:pointer;

}

.lightbox-prev,
.lightbox-next{

    position:absolute;

    top:50%;

    transform:translateY(-50%);

    width:70px;

    height:70px;

    border-radius:50%;

    border:none;

    background:rgba(255,255,255,.12);

    color:white;

    font-size:34px;

    cursor:pointer;

    transition:.3s;

}

.lightbox-prev:hover,
.lightbox-next:hover{

    background:#0d5c44;

}

.lightbox-prev{

    left:30px;

}

.lightbox-next{

    right:30px;

}

/*================ RESPONSIVE =================*/

@media(max-width:992px){

.moments-grid{

grid-template-columns:1fr 1fr;

}

}

@media(max-width:768px){

.moments{

padding:80px 0;

}

.moments h2{

font-size:38px;
margin-bottom:40px;

}

.moments-grid{

grid-template-columns:1fr;

}

.moment-card img,
.video-card video{

height:440px;

}

}

/*================ CTA FINAL =================*/

.final-cta{

    position:relative;
    height:72vh;
    min-height:620px;

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

    overflow:hidden;

}

.cta-video{

    position:absolute;
    inset:0;

    width:100%;
    height:100%;

    object-fit:cover;

    transform:scale(1.08);

}

.cta-overlay{

    position:absolute;
    inset:0;

    background:linear-gradient(

        rgba(0,0,0,.58),

        rgba(0,0,0,.72)

    );

}

.cta-content{

    position:relative;
    z-index:2;

    max-width:900px;

    text-align:center;

    color:white;

    padding:20px;

}

.cta-content .section-tag{

    margin-bottom:18px;

}

.cta-content h2{

    font-size:66px;

    line-height:1.08;

    font-weight:700;

    color:white;

    margin-bottom:28px;

}

.cta-content p{

    max-width:720px;

    margin:auto;

    font-size:22px;

    line-height:1.7;

    color:rgba(255,255,255,.90);

    margin-bottom:48px;

}

/*================ BOTÓN =================*/

.cta-button{

    display:inline-flex;

    align-items:center;

    justify-content:center;

    gap:14px;

    padding:22px 46px;

    border-radius:60px;

    text-decoration:none;

    background:#0d5c44;

    color:white;

    font-size:21px;

    font-weight:700;

    transition:.35s;

    box-shadow:0 18px 45px rgba(0,0,0,.30);

}

.cta-button:hover{

    transform:translateY(-6px);

    background:#117a5a;

    box-shadow:0 28px 55px rgba(0,0,0,.35);

}

.cta-button i{

    font-size:28px;

}

/*================ BENEFICIOS =================*/

.cta-features{

    margin-top:34px;

    display:flex;

    justify-content:center;

    gap:34px;

    flex-wrap:wrap;

}

.cta-features span{

    display:flex;

    align-items:center;

    gap:10px;

    font-size:16px;

    color:rgba(255,255,255,.88);

}

.cta-features i{

    color:#67d89a;

    font-size:18px;

}

/*================ ANIMACIÓN =================*/

.cta-content{

    animation:fadeUp .9s ease;

}

@keyframes fadeUp{

    from{

        opacity:0;

        transform:translateY(35px);

    }

    to{

        opacity:1;

        transform:translateY(0);

    }

}
/*================ FOOTER ================*/

.footer{

    background:#0f1113;

    color:white;

    padding:10px 0 1px;

    text-align:center;

}

.footer-logo{

    width: 400px;

    margin-bottom:-55px;

}

.footer h3{

    font-size:34px;

    margin-bottom:8px;

}

.footer p{

    color:#b8b8b8;

    font-size:18px;

    margin-bottom:12px;

}

.footer-contact{

    display:flex;

    justify-content:center;

    gap:40px;

    flex-wrap:wrap;

    margin-bottom:24px;

}

.footer-contact span{

    display:flex;

    align-items:center;

    gap:10px;

    color:#d5d5d5;

    font-size:16px;

}

.footer-contact i{

    color:#6dd89c;

}

.footer-social{

    display:flex;

    justify-content:center;

    gap:22px;

    margin-bottom:24px;

}

.footer-social a{

    width:58px;

    height:58px;

    border-radius:50%;

    background:#1b1d20;

    display:flex;

    justify-content:center;

    align-items:center;

    text-decoration:none;

    color:white;

    font-size:24px;

    transition:.35s;

}

.footer-social a:hover{

    background:#0d5c44;

    transform:translateY(-6px);

}

.footer-copy{

    color:#888;

    font-size:14px;

    border-top:1px solid rgba(255,255,255,.08);

    padding-top:30px;

}
/*================ MOBILE MENU ================*/

.menu-toggle{
    display:none;
    background:none;
    border:none;
    color:white;
    font-size:36px;
    cursor:pointer;
}

@media (max-width:768px){

    .menu-toggle{
        display:block !important;
        position:relative;
        z-index:9999;
        background:none;
        border:none;
        color:white;
        font-size:36px;
        cursor:pointer;
    }

    .menu{

        display:none;

        position:absolute;

        top:90px;
        left:20px;
        right:20px;

        flex-direction:column;

        background:rgba(13,92,68,.96);

        padding:20px;

        border-radius:20px;

        backdrop-filter:blur(15px);

        z-index:9998;
    }

}
@media (max-width:768px){

    .hero h1{
        font-size: 3rem;
        line-height: 1.05;
    }

    .hero p{
        font-size: 1.2rem;
        line-height: 1.5;
        padding: 0 20px;
    }

}