:root{
--green:#2f6b3d;
--green-dark:#1f4d2b;
--gold:#f2c230;
--light:#f5f8f6;
--dark:#1b1f23;
}
body{font-family:Montserrat,sans-serif;background:#fff;color:#333}
.topbar{background:var(--green-dark);color:#fff;font-size:.85rem}
.navbar{background:#fff!important;box-shadow:0 8px 30px rgba(0,0,0,.06)}
.navbar-brand{font-weight:800;color:var(--green)!important}
.hero{
background:linear-gradient(rgba(20,40,25,.75),rgba(20,40,25,.75)),
linear-gradient(135deg,var(--green-dark),var(--green));
padding:120px 0;
position:relative;
overflow:hidden;
}
.hero:after{
content:'';
position:absolute;
width:700px;height:700px;
right:-250px;top:-250px;
border-radius:50%;
background:rgba(255,255,255,.05);
}.hero-img{

    width:100%;

    height:100%;

    object-fit:cover;

    display:block;

    transition:all .5s ease;
}

.hero-card:hover .hero-img{

    transform:scale(1.04);
}
.hero h1 {
    font-size: clamp(2rem,3vw,3rem);
    font-weight: 800;
    color: #fff;
}.hero p{color:#e9efe9}
.hero-card{

    border-radius:28px;

    overflow:hidden;

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

    background:white;

    height:420px;
}
.navbar-brand{
    padding:0;
}

.navbar-logo{
    height:72px;
    width:auto;
    display:block;
    transition:all .3s ease;
}

.navbar-brand:hover .navbar-logo{
    transform:scale(1.02);
}
.section-title{font-weight:800;color:var(--green)}
.service-card,.social-card{
border:none;border-radius:22px;
box-shadow:0 15px 40px rgba(0,0,0,.08);
transition:.3s;
height:100%;
}
.service-card:hover,.social-card:hover{transform:translateY(-8px)}
.icon-circle{
width:80px;height:80px;border-radius:50%;
background:var(--light);
display:flex;align-items:center;justify-content:center;
margin:auto;font-size:32px;color:var(--green)
}
.stats{background:var(--light)}
.stat-box{
background:#fff;border-radius:20px;padding:30px;
box-shadow:0 10px 30px rgba(0,0,0,.08)
}
.stat-number{font-size:3rem;font-weight:800;color:var(--green)}
.cta-band{
background:linear-gradient(135deg,var(--green),#4a8a59);
color:#fff;
}
.footer{
background:var(--dark);
color:#fff;
position:relative;
}
.footer:before{
content:'';position:absolute;top:0;left:0;width:100%;height:5px;
background:linear-gradient(90deg,var(--green),var(--gold));
}
.footer-box{
background:rgba(255,255,255,.04);
border:1px solid rgba(255,255,255,.08);
border-radius:18px;padding:24px;height:100%;
}
.social-cta{

    background:
    linear-gradient(
        135deg,
        #1f2d3d 0%,
        #24384a 100%);

    position:relative;

    overflow:hidden;

    color:white;
}

.social-cta::before{

    content:'';

    position:absolute;

    width:700px;
    height:700px;

    border-radius:50%;

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

    top:-250px;
    right:-250px;
}

.social-label{

    color:#59c36a;

    font-weight:700;

    text-transform:uppercase;

    letter-spacing:2px;
}

.social-title{

   
        font-size: clamp(1.5rem, 2vw, 2rem);
        font-weight: 500;

    line-height:1.15;

    margin-top:20px;
}

.social-text{

    font-size:1.1rem;

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

    line-height:1.9;
}.btn-facebook{

    background:#1877F2;

    color:white;

    padding:18px 32px;

    border-radius:8px;

    text-decoration:none;

    font-weight:700;

    transition:.3s;
}

.btn-facebook:hover{

    transform:translateY(-3px);

    color:white;
}

.btn-instagram{

    background:transparent;

    border:2px solid rgba(255,255,255,.3);

    color:white;

    padding:18px 32px;

    border-radius:8px;

    text-decoration:none;

    font-weight:700;

    transition:.3s;
}

.btn-instagram:hover{

    background:white;

    color:#222;
}.btn-facebook{

    background:transparent;

    border:2px solid rgba(255,255,255,.3);

    color:white;


    padding:18px 32px;

    border-radius:8px;

    text-decoration:none;

    font-weight:700;

    transition:.3s;
}

.btn-facebook:hover{

    transform:translateY(-3px);

    color:white;
}

.btn-instagram{

    background:transparent;

    border:2px solid rgba(255,255,255,.3);

    color:white;

    padding:18px 32px;

    border-radius:8px;

    text-decoration:none;

    font-weight:700;

    transition:.3s;
}

.btn-instagram:hover{

    background:white;

    color:#222;
}
.footer-modern{

    background:
    linear-gradient(
        135deg,
        #13293d 0%,
        #0f2234 100%);

    color:white;

    padding-top:90px;
}

.footer-modern h5{

    font-weight:700;

    margin-bottom:25px;

    color:white;
}

.footer-description{

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

    line-height:1.9;
}

.footer-list{

    list-style:none;

    padding:0;
    margin:0;
}

.footer-list li{

    margin-bottom:15px;

    color:rgba(255,255,255,.70);
}
.footer-list a{

 
    color:rgba(255,255,255,.70);
}

.footer-bottom{

    margin-top:70px;

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

    padding:30px 0;
}

.copyright{

    color:rgba(255,255,255,.65);
}

.social-links{

    display:flex;

    justify-content:flex-end;

    gap:25px;
}

.social-links a{

    color:white;

    font-size:20px;

    transition:.3s;
}

.social-links a:hover{

    color:var(--amarillo);

    transform:translateY(-3px);
}.services-modern{

    background:#f7f8f7;
}

.section-subtitle{

    color:var(--verde);

    font-weight:700;

    text-transform:uppercase;

    letter-spacing:2px;

    font-size:.85rem;
}

.section-title-main{

    font-size:clamp(2rem,4vw,3.2rem);

    font-weight:800;

    color:#24384a;

    margin-top:15px;
}/* ==========================
   SECCION SERVICIOS
========================== */

.services-modern{
    background:#f7f8f7;
    padding:90px 0;
}

.section-subtitle{
    color:var(--verde);
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:2px;
    font-size:.85rem;
}

.section-title-main{
    font-size:clamp(2rem,4vw,3.5rem);
    font-weight:800;
    color:#24384a;
    margin-top:15px;
    margin-bottom:20px;
}

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

.service-card-v2{

    background:white;

    border-radius:24px;

    padding:50px 40px;

    height:100%;

    position:relative;

    transition:all .35s ease;

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

    overflow:hidden;
}

.service-card-v2:hover{

    transform:translateY(-10px);

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

.service-card-v2::before{

    content:'';

    position:absolute;

    top:0;
    left:0;

    width:100%;
    height:5px;

    background:
        linear-gradient(
        90deg,
        var(--verde),
        var(--azul));
}

/* ==========================
   ICONO
========================== */

.service-icon{

    width:90px;
    height:90px;

    border-radius:20px;

    background:#f3f8f4;

    display:flex;

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

    margin-bottom:35px;

    font-size:38px;

    color:var(--verde);

    transition:.3s;
}

.service-card-v2:hover .service-icon{

    transform:scale(1.08);

    background:#eef8f0;
}

/* ==========================
   TITULO
========================== */

.service-content h3{

    font-size:2rem;

    font-weight:700;

    color:#24384a;

    margin-bottom:25px;

    line-height:1.2;
}

/* ==========================
   DIVISOR
========================== */

.service-divider{

    width:100%;

    height:1px;

    background:#e5e5e5;

    margin-bottom:25px;
}

/* ==========================
   TEXTO
========================== */

.service-content p{

    color:#7a8793;

    line-height:1.9;

    font-size:1rem;

    margin-bottom:30px;
}

/* ==========================
   LINK
========================== */

.service-link{

    color:var(--verde);

    text-decoration:none;

    font-weight:700;

    display:inline-flex;

    align-items:center;

    gap:10px;

    transition:.3s;
}

.service-link:hover{

    color:var(--verde);

    gap:15px;
}

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

@media(max-width:991px){

    .service-card-v2{

        padding:40px 30px;
    }

    .service-content h3{

        font-size:1.7rem;
    }

    .service-icon{

        width:75px;
        height:75px;

        font-size:32px;
    }

}