/*======================================*/
/*===== Custom css ditulis di sini =====*/
/*======================================*/


*{
    padding: 0;
    margin: 0;
    /* border: 1px solid red; */
}

:root{

    --helixa: "Helixa", sans-serif;
    --standie: "Standie", sans-serif;

    /* font size */
    --text-xs: 12px;
    --text-sm: 14px;
    --text-normal: 16px; 
    --text-lg: 18px; 
    --text-xl: 20px; 
    --text-2xl: 24px; 
    --text-3xl: 30px; 
    --text-4xl: 36px; 
    --text-5xl: 48px; 
    --text-6xl: 60px; 
    --text-7xl: 72px; 
    --text-8xl: 96px; 
    --text-9xl:128px;

    --hitam: #1B1B1B;

    --abu-muda: #F6F6F6;
    --abu-tua: #828282;

    /* --hijau-1: #01290F; */
    --hijau-1: #014217;
    --hijau-2: #02852F;

    --kuning: #FFCC33;

    
}
body{
    overflow-x: hidden;

    margin-top: 70px;
    font-family: "Inter", sans-serif;

    color: var(--hijau-1);
    background-color: #F8FAF7;
}
a{
    text-decoration: none !important;
}
img {
    width: 100%;
}
*, h1, h2, h3, h4, h5, h6, p{
    padding: 0;
    margin: 0;
    /* border: 1px solid red; */
}
button{
    border: 0;
    background-color: transparent;
}
li{
    list-style: none;
}


/*====================================================*/
/*==================== COMPONENTS ====================*/
/*====================================================*/

.gambar-rounded{
    overflow: hidden;
}
.gambar-rounded img{
    width: 100%;
    height: 100%;
    object-fit: contain;
}

/*===== BUTTON KUNING =====*/
.button-kuning{
    padding: 12px 20px;
    background-color: var(--kuning);

    text-align: center;
    font-size: 16px;
    font-weight: 600;
    color: var(--hijau-1) !important;

    border-radius: 999px;
}

/*===== BUTTON HIJAU =====*/
.button-hijau{
    padding: 12px 20px;
    background-color: var(--hijau-1);

    text-align: center;
    font-size: 16px;
    font-weight: 600;
    color: #FFFFFF !important;

    border-radius: 999px;
}

/*===============*/
/*===== NAV =====*/
/*===============*/
nav{
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1001;

    width: 100%;
    height: 70px;

    background-color: #F8FAF7;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 4px 0;
}

nav .nav-logo{
    width: 20%;
    height: 100%;
    padding: 8px 0;
}
nav .nav-logo img{
    width: 100%;
}

nav .nav-container{
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.nav-button{
    display: none;
}

.nav-links{
    position: relative;

    list-style:none;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 40px;
    width: 70%;

    transition: .5s ease-out;
}
.nav-links > a,
.nav-links .dropdown > a,
.nav-menu .links > a,
.nav-menu .links .accordion > h2{
    position: relative;

    font-size: var(--text-xl);
    font-weight: 600;
    color: var(--hijau-1);
}
.nav-links > a::after,
.nav-links .dropdown > a::after{
    content: "";

    position: absolute;
    bottom: -10px;
    left: 50%;
    transform: translateX(-50%);

    width: 0;
    height: 3px;

    background-color: #339800;
    border-radius: 9999px;

    transition: .25s ease-out;
}
.nav-links > a:hover::after,
.nav-links .dropdown > a:hover::after{
    width: 50px;
}
.nav-links .dropdown-menu,
.nav-menu .links .dropdown-menu{
    border-radius: 8px;
}
.nav-links .dropdown-menu .dropdown-item,
.nav-menu .links .dropdown-menu .dropdown-item{
    text-align: center;
    font-size: var(--text-sm);
    font-weight: 600;
    color: var(--hijau-1);

    transition: .2s;
}
.nav-links .dropdown-menu .dropdown-item:hover,
.nav-menu .links .dropdown-menu .dropdown-item:hover{
    color: #FFFFFF;
    background-color: var(--hijau-2);
}

.nav-lang{
    position: relative;

    width: 7%;
    margin-left: 32px;

    display: flex;
    align-items: center;
    justify-content: flex-end;
}
.nav-lang::before{
    content: "";

    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);

    width: 3px;
    height: 24px;
    
    background-color: #339800;
    border-radius: 9999px;
}
.nav-lang a,
.nav-menu .lang a{
    display: flex;
    align-items: center;
    gap: 4px;

    font-size: var(--text-xl);
    font-weight: 600;
    color: var(--hijau-1);
    text-transform: uppercase;
}

nav .button-menu{
    display: none;
}

.nav-menu{
    display: none;
}
.nav-menu .button-close{
    display: none;
}


/*==================*/
/*===== FOOTER =====*/
/*==================*/
footer{
    margin-top: 120px;
    padding-top: 60px;
    padding-left: 16px;
    padding-right: 16px;
    background-color: #01290F;
}
footer .footer-row{
    display: flex;
    justify-content: space-between;
    gap: 32px;
}
footer .footer-row > div{
}
footer .footer-row .about{
    width: 20%;
}
footer .footer-row .about p{
    margin-top: 8px;
    font-size: var(--text-xs);
    color: #FFFFFF;
    line-height: 24px;
}
footer .footer-row .about .labels{
    margin-top: 16px;
}
footer .footer-row .company,
footer .footer-row .product,
footer .footer-row .service,
footer .footer-row .contact,
footer .footer-row .socmed{
    width: 15%;
}
footer .footer-row h4{
    margin-bottom: 12px;
    font-size: var(--text-base);
    color: #B3BFAD;
}
footer .footer-row .links,
footer .footer-row .list{
    display: flex;
    flex-direction: column;
    gap: 4px;
}
footer .footer-row .links a,
footer .footer-row .list h5{
    font-size: var(--text-sm);
    color: #FFFFFF;
}
footer .footer-row .list h5{
    display: flex;
    flex-wrap: nowrap;
}
footer .footer-row .socmed .socmed-links{
    display: flex;
    gap: 4px;
}
footer .footer-row .socmed .socmed-links a img{
    width: 24px;
}
footer .copyright{
    padding: 30px 0 24px;
}
footer .copyright p{
    text-align: center;
    font-size: var(--text-base);
    color: #FFFFFF;
}


/*===========================*/
/*===== BUTTON WHATSAPP =====*/
/*===========================*/
.button-whatsapp{
    position: fixed;
    bottom: 72px;
    right: 32px;

    width: 72px;
    height: 72px;

    z-index: 1000;
}




/*==============================================*/
/*==================== HOME ====================*/
/*==============================================*/

/*=====================*/
/*===== HOME HERO =====*/
/*=====================*/
.home-hero{
    margin-top: 20px;
}
.home-hero .swiper-home-hero{
    margin-left: 50px;
    margin-right: 50px;
}
.home-hero .swiper-wrapper{
    align-items: stretch;
}
.home-hero .swiper-slide{
    background-color: #F8FAF7;
    height: auto;
}
.home-hero .slide{
    display: flex;
    justify-content: space-between;
}
.home-hero .slide .gambar{
    flex-shrink: 0;
    width: 46%;
    aspect-ratio: 6/5;

    border-radius: 20px;
    overflow: hidden;
}
.home-hero .slide .gambar img{
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.home-hero .slide .konten{
    flex-shrink: 0;
    width: 46%;
    margin-right: 32px;
    padding-bottom: 32px;
}
.home-hero .slide .konten h3{
    font-size: var(--text-xl);
    color: #919D9D;
    text-transform: uppercase;
    letter-spacing: 5px;
}
.home-hero .slide .konten h1{
    margin-top: 8px;
    font-size: var(--text-5xl);
    font-weight: 800;
    color: var(--hijau-2);
    text-transform: uppercase;
    letter-spacing: 3px;
}
.home-hero .slide .konten .icon{
    margin-top: 30px;
}
.home-hero .slide .konten .link{
    margin-top: 32px;
}

.home-hero .swiper-navigation-home-hero{
    position: absolute;

    left: 0;
    top: 50%;
    transform: translateY(-50%);

    width: 100%;
}
.home-hero .swiper-navigation-home-hero .button-prev{
    width: 48px;
    position: absolute;
    left: 0;
}
.home-hero .swiper-navigation-home-hero .button-next{
    width: 48px;
    position: absolute;
    right: 0;
}








/*======================*/
/*===== HOME ABOUT =====*/
/*======================*/
.home-about{
    margin-top: 60px;
    margin-bottom: 16px;
    padding: 0 16px;
}
.home-about h2,
.home-product h2,
.home-service h2,
.home-why h2,
.home-partner h2,
.home-contact h2{
    text-align: center;
    font-size: var(--text-4xl);
    font-weight: 600;
    color: var(--hijau-2);
}
.home-about .about-row{
    display: flex;
    align-items: center;
    gap: 32px;

    margin-top: 16px;
}
.home-about .about-row .konten{
    width: 50%;
}
.home-about .about-row .konten p{
    font-size: var(--text-lg);
    color: var(--hijau-1);
    line-height: 32px;
}
.home-about .about-row .video{
    width: 50%;
}

.home-about .about-row .video video{
    width: 80%;
    aspect-ratio: 4/3;
    border-radius: 8px;
    object-fit: cover;
}

/*========================*/
/*===== HOME PRODUCT =====*/
/*========================*/

.home-product{
    margin-top: 60px;
    margin-bottom: 16px;
    padding: 0 16px;
}
.home-product .swiper-home-product{
    position: relative;
    margin-top: 24px;
    margin-left: 70px;
    margin-right: 70px;
}
.home-product .swiper-home-product .swiper-slide{
    opacity: .7;
    transform: scale(.9);
}
.home-product .swiper-home-product .swiper-slide.swiper-slide-active{
    opacity: 1;
    transform: scale(1);
}
.home-product .swiper-home-product .item{
    position: relative;
    aspect-ratio: 3/4.1;

    border: 2px solid var(--hijau-2);
    border-radius: 8px;
    overflow: hidden;
}
.home-product .swiper-home-product .item .gambar{
    aspect-ratio: 3.1/2.7;

    transition: .5s all;
}
.home-product .swiper-home-product .item .gambar img{
    width: 100%;
    height: 100%;

    object-fit: cover;
}
.home-product .swiper-home-product .item .konten{
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: space-between;
    
    padding: 30px 20px 20px;

}
.home-product .swiper-home-product .item .konten .text{
    position: relative;
    width: 100%;
}
.home-product .swiper-home-product .item .konten h3{
    text-align: center;
    font-size: var(--text-xl);
    font-weight: 600;
    color: var(--hijau-1);
}
.home-product .swiper-home-product .item .konten p{
    position: absolute;

    margin-top: 16px;

    text-align: center;
    font-size: var(--text-sm);
    color: var(--hijau-1);

    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3; /* Show only three lines */
    line-height: 1.5; /* Adjust the line height as needed */
    max-height: calc(3 * 1.5em); /* Limit to three lines */
    text-overflow: ellipsis;

    opacity: 0;
    overflow: hidden;

    transition: .5s;
}
.home-product .swiper-home-product .item .konten .link{
    margin-top: 32px;
}
.home-product .swiper-home-product .item .konten a{
    position: absolute;
    bottom: 30px;
    left: 50%;
    transform: translateX(-50%);


    padding: 12px 20px;
    background-color: var(--kuning);

    text-align: center;
    font-size: 16px;
    font-weight: 600;
    color: var(--hijau-1);

    border-radius: 999px;

}
.home-product .swiper-home-product .swiper-slide.swiper-slide-active .item:hover .gambar{
    aspect-ratio: 3.1/2;
}
.home-product .swiper-home-product .swiper-slide.swiper-slide-active .item:hover p{
    opacity: 1;
}   

.home-product .swiper-navigation-home-product{
    position: absolute;

    left: 0;
    top: 50%;
    z-index: 10;
    transform: translateY(-50%);

    width: 100%;
}
.home-product .swiper-navigation-home-product .button-prev{
    position: absolute;
    left: 0;
    width: 60px;
}
.home-product .swiper-navigation-home-product .button-next{
    position: absolute;
    right: 0;
    width: 60px;
}


/*========================*/
/*===== HOME SERVICE =====*/
/*========================*/
.home-service{
    margin-top: 60px;
    margin-bottom: 16px;
    padding: 0 16px;
}
.home-service .swiper-slide{
    background-color: #F8FAF7;
}
.home-service .service-content{
    display: flex;
    align-items: center;
    justify-content: space-between;

    margin-top: 32px;

}
.home-service .service-content .gambar{
    flex-shrink: 0;
    
    width: 38%;
    aspect-ratio: 1/1;
    border-radius: 9999px;
    overflow: hidden;
}
.home-service .service-content .gambar img{
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.home-service .service-content .konten{
    flex-shrink: 0;

    width: 58%;
    padding: 32px 16px;
}
.home-service .service-content .konten h3{
    font-size: 36px;
    font-weight: 700;
    color: var(--hijau-1);
}
.home-service .service-content .konten p{
    margin-top: 32px;

    font-size: var(--text-2xl);
    color: var(--hijau-1);
}
.home-service .service-content .konten .link{
    margin-top: 60px;
}
.home-service .service-content .konten a{
    padding: 32px 60px;
    background-color: var(--kuning);

    font-size: 16px;
    font-weight: 600;
    color: var(--hijau-1);

    border-radius: 999px;
}

.home-service .service-pagination{
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 18px;

    margin-top: 50px;
}
.home-service .home-service-pagination .swiper-pagination-bullet{
    display: block;

    width: 120px;
    height: 8px;

    background-color: #9BA596;
    border-radius: 0;
    opacity: 1;

    transition: .25s;
}
.home-service .home-service-pagination .swiper-pagination-bullet-active{
    background-color: var(--hijau-1);
}

/*====================*/
/*===== HOME WHY =====*/
/*====================*/

.home-why{
    margin-top: 100px;
    margin-bottom: 16px;
    padding: 0 16px;
}
.home-why .why-grid{
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    row-gap: 40px;

    margin-top: 32px;
}
.home-why .why-grid .item{
    flex-shrink: 0;
    width: 33%;
    padding: 0 32px;
}
.home-why .why-grid .item .gambar{
    width: 20%;
    aspect-ratio: 1/1;
    margin: 0 auto;
}
.home-why .why-grid .item .gambar img{
    width: 100%;
    height: 100%;
    object-fit: contain;
}
.home-why .why-grid .item .konten{
    margin-top: 20px;
}
.home-why .why-grid .item .konten h3{
    text-align: center;
    font-size: var(--text-xl);
    font-weight: 600;
    color: var(--hijau-1);
}
.home-why .why-grid .item .konten p{
    text-align: center;
    font-size: var(--text-sm);
    color: var(--hijau-1);
}

/*========================*/
/*===== HOME PARTNER =====*/
/*========================*/

.home-partner{
    margin-top: 150px;
    margin-bottom: 16px;
    padding: 0 16px;
}
.home-partner .swiper-home-partner{
    margin-top: 40px;
}
.home-partner .item{
    aspect-ratio: 1/1;
}
.home-partner .item img{
    width: 75%;
    height: 75%;
    object-fit: contain;
}


/*========================*/
/*===== HOME CONTACT =====*/
/*========================*/
.home-contact{
    margin-top: 100px;
    margin-bottom: 16px;
    padding: 0 16px;
}
.home-contact .link{
    margin-top: 32px;
    display: flex;
    justify-content: center;
}


/*=================================================*/
/*==================== PRODUCT ====================*/
/*=================================================*/

/*========================*/
/*===== PRODUCT HERO =====*/
/*========================*/
.product-hero{
    position: relative;

    height: 25vw;

    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
}
.product-hero .gradient-hijau{
    position: absolute;
    top: 0;
    left: 0;

    width: 100%;
    height: 100%;

    background-image: linear-gradient(90deg, #04AD36CC, #209F45A6, #3C905580, #73737300);    ;
}
.product-hero .container-hero{
    position: relative;
    z-index: 10;

    display: flex;
    align-items: center;

    height: 100%;
}
.product-hero h2{
    font-size: var(--text-4xl);
    font-weight: 700;
    color: #FFFFFF;

    max-width: 60%;
}

/*===========================*/
/*===== PRODUCT SUBMENU =====*/
/*===========================*/
.product-submenu{
    position: relative;
    width: 100%;
    padding: 12px 16px;

    background-color: #0F6C29;
}
.product-submenu .submenu-links{
    display: flex;
    justify-content: space-around;
    align-items: center;
    gap: 16px;
}
.product-submenu .submenu-links a{
    position: relative;
    font-size: var(--text-md);
    font-weight: 600;
    text-align: center;
    color: #FFFFFF;

}

.product-submenu .submenu-links a::before{
    content: "";

    position: absolute;
    bottom: -10px;
    left: 50%;
    transform: translateX(-50%);

    width: 0;
    height: 3px;

    background-color: #339800;
    border-radius: 9999px;

    transition: .25s ease-out;
}
.product-submenu .submenu-links > a:hover::before{
    width: 50px;
}
.product-submenu .button-submenu{
    display: none;
}

/*========================*/
/*===== PROCUCT INFO =====*/
/*========================*/
.product-info{
    margin-top: 60px;
    margin-bottom: 16px;
    padding: 0 16px;
}
.product-info .info-row{
    display: flex;
    justify-content: space-between;
    gap: 48px;
}
.product-info .info-row .gambar{
    display: flex;
    align-items: center;
    justify-content: center;

    width: 40%;
    aspect-ratio: 4/3;

    /* background-color: #E3F0DB; */
    border-radius: 16px;
    overflow: hidden;
}
.product-info .info-row .gambar img{
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.product-info .info-row .konten{
    width: 60%;
}
.product-info .info-row .konten h3{
    font-size: var(--text-4xl);
    font-weight: 700;
    color: var(--hijau-2);
}
.product-info .info-row .konten p{
    margin-top: 20px;

    font-size: var(--text-xl);
}


/*=========================*/
/*===== PRODUCT ADVAN =====*/
/*=========================*/
.product-advan{
    margin-top: 60px;
    margin-bottom: 16px;
    padding: 60px 16px;

    background-color: #E3F0DB;
}
.product-advan h3{
    text-align: center;
    font-size: var(--text-4xl);
    font-weight: 700;
    color: var(--hijau-2);
}
.product-advan .advan-row{
    display: flex;
    align-items: stretch;
    justify-content: space-between;

    margin-top: 60px;
}
.product-advan .advan-row .item{
    width: 30%;
    padding: 40px 32px;

    background-color: #FFFFFF;

}
.product-advan .advan-row .item .gambar img{
    width: 40%;
    aspect-ratio: 1/1;
    object-fit: contain;
    object-position: center;
}
.product-advan .advan-row .item .konten{
    margin-top: 20px;
}
.product-advan .advan-row .item .konten h4{
    font-size: var(--text-2xl);
    font-weight: 600;
}
.product-advan .advan-row .item .konten p{
    margin-top: 16px;
    font-size: var(--text-xl);
    line-height: 24px;
}


/*============================*/
/*===== PRODUCT ACTIVITY =====*/
/*============================*/
.product-activity{
    margin-top: 60px;
    margin-bottom: 60px;
    padding: 60px 16px;
}
.product-activity h3{
    text-align: center;
    font-size: var(--text-4xl);
    font-weight: 700;
    color: var(--hijau-2);
}
.product-activity .activity-row{
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    row-gap: 32px;
    
    margin-top: 60px;
}
.product-activity .activity-row .item{
    width: 33%;
    aspect-ratio: 1.4/1;
    padding: 0 16px;
}
.product-activity .activity-row .item img,
.product-activity .activity-row .item video{
    width: 100%;
    height: 100%;

    object-fit: cover;
}


/*=================================================*/
/*==================== SERVICE ====================*/
/*=================================================*/

/*========================*/
/*===== SERVICE HERO =====*/
/*========================*/
.service-hero{
    position: relative;

    height: 25vw;

    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
}
.service-hero .gradient-hijau{
    position: absolute;
    top: 0;
    left: 0;

    width: 100%;
    height: 100%;

    background-image: linear-gradient(90deg, #04AD36CC, #209F45A6, #3C905580, #73737300);    ;
}
.service-hero .container-hero{
    position: relative;
    z-index: 10;

    display: flex;
    align-items: center;

    height: 100%;
}
.service-hero h2{
    font-size: var(--text-4xl);
    font-weight: 700;
    color: #FFFFFF;

    max-width: 60%;
}


/*========================*/
/*===== SERVICE INFO =====*/
/*========================*/
.service-info{
    margin-top: 60px;
    margin-bottom: 16px;
    padding: 0 16px;
}
.service-info .info-row{
    display: flex;
    justify-content: space-between;
    gap: 48px;
}
.service-info .info-row .gambar{
    display: flex;
    align-items: center;
    justify-content: center;
    
    width: 40%;
    aspect-ratio: 1/1;
    
    background-color: #E3F0DB;
    border-radius: 16px;
    overflow: hidden;
}
.service-info .info-row .gambar img{
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.service-info .info-row .konten{
    width: 60%;
}
.service-info .info-row .konten h3{
    font-size: var(--text-4xl);
    font-weight: 700;
    color: var(--hijau-2);
}
.service-info .info-row .konten p{
    margin-top: 20px;

    font-size: var(--text-xl);
}


/*============================*/
/*===== SERVICE ACTIVITY =====*/
/*============================*/
.service-activity{
    margin-top: 60px;
    margin-bottom: 60px;
    padding: 60px 16px;
}
.service-activity h3{
    text-align: center;
    font-size: var(--text-4xl);
    font-weight: 700;
    color: var(--hijau-2);
}
.service-activity .activity-row{
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    row-gap: 32px;
    
    margin-top: 60px;
}
.service-activity .activity-row .item{
    width: 33%;
    padding: 12px 16px;
}
.service-activity .activity-row .item img,
.service-activity .activity-row .item video{
    width: 100%;
    height: 100%;
    display: flex;
    aspect-ratio: 1/1;
    object-fit: cover;
    justify-items: center;
}


/*===========================*/
/*===== SERVICE BENEFIT =====*/
/*===========================*/

.service-benefit{
    margin-top: 100px;
    margin-bottom: 16px;
    padding: 0 16px;
}
.service-benefit h3{
    text-align: center;
    font-size: var(--text-4xl);
    font-weight: 700;
    color: var(--hijau-2);
}
.service-benefit .benefit-grid{
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    row-gap: 40px;

    margin-top: 60px;
}
.service-benefit .benefit-grid .item{
    flex-shrink: 0;
    width: 33%;
    padding: 0 32px;
}
.service-benefit .benefit-grid .item .gambar{
    width: 20%;
    margin: 0 auto;
}
.service-benefit .benefit-grid .item .konten{
    margin-top: 20px;
}
.service-benefit .benefit-grid .item .konten h3{
    text-align: center;
    font-size: var(--text-xl);
    font-weight: 600;
    color: var(--hijau-1);
}
.service-benefit .benefit-grid .item .konten h4{
    text-align: center;
}
.service-benefit .benefit-grid .item .konten p{
    text-align: center;
    font-size: var(--text-sm);
    color: var(--hijau-1);
}


/*===========================*/
/*===== SERVICE CONTACT =====*/
/*===========================*/
.service-contact{
    margin-top: 100px;
    margin-bottom: 16px;
    padding: 0 16px;
}
.service-contact h3{
    text-align: center;
    font-size: var(--text-4xl);
    font-weight: 700;
    color: var(--hijau-2);
}
.service-contact .link{
    margin-top: 32px;
    display: flex;
    justify-content: center;
}



/*=================================================*/
/*==================== CONTACT ====================*/
/*=================================================*/

/*========================*/
/*===== CONTACT HERO =====*/
/*========================*/
.contact-hero{
    position: relative;

    height: 15vw;

    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
}
.contact-hero .gradient-hijau{
    position: absolute;
    top: 0;
    left: 0;

    width: 100%;
    height: 100%;

    background-image: linear-gradient(90deg, #04AD36CC, #209F45A6, #3C905580, #73737300);    ;
}
.contact-hero .container-hero{
    position: relative;
    z-index: 10;

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

    height: 100%;
}
.contact-hero h2{
    text-align: center;
    font-size: var(--text-4xl);
    font-weight: 700;
    color: #FFFFFF;
}


/*===========================*/
/*===== CONTACT CONTENT =====*/
/*===========================*/
.contact-content{
    padding: 40px 0;

    background-color: #E3F0DB;
}
.contact-content .content-row{
    display: flex;
    /* align-items: center; */
    gap: 32px;
}
.contact-content .content-row .content-info{
    width: 50%;
}
.contact-content .content-row .content-info h3{
    font-size: var(--text-5xl);
    font-weight: 700;
}
.contact-content .content-row .content-info > p{
    margin-top: 20px;
    font-size: var(--text-base)
}

.contact-content .content-row .content-info .info{
    margin-top: 20px;
}
.contact-content .content-row .content-info .info .item{
    display: flex;
    align-items: center;
    gap: 6px;
}
.contact-content .content-row .content-info .info > .region{
    margin: 16px 0;
}
.contact-content .content-row .content-info .info h4{
    margin-bottom: 4px;
    font-size: var(--text-base);
    font-weight: 600;
}
.contact-content .content-row .content-info .info .cs{
    font-size: var(--text-base);
}
.contact-content .content-row .content-info .info span{
    font-weight: 600;
}



.contact-content .content-row .content-form{
    width: 50%;
    padding: 32px;

    background-color: #FFFFFF;
    border-radius: 20px;
    box-shadow: 0 0 8px #1b1b1b3e;
}
.contact-content .content-row .content-form h3{
    font-size: var(--text-5xl);
    font-weight: 700;
}
.contact-content .content-row .content-form p{
    margin-top: 16px;
    font-size: var(--text-base);
}
.contact-content .content-row .content-form .form{
    margin: 20px 0;
}
.contact-content .content-row .content-form .form form > div{
    margin: 12px 0;
}
.contact-content .content-row .content-form .form input,
.contact-content .content-row .content-form .form textarea{
    width: 100%;

    padding: 12px 10px;

    border: 1px solid var(--hijau-1);
    border-radius: 4px;

    resize: none;
}
.contact-content .content-row .content-form .form input::placeholder,
.contact-content .content-row .content-form .form textarea::placeholder{
    font-size: var(--text-sm);
    color: #8A938D;
}
.contact-content .content-row .content-form .form form .button{
    display: flex;
    justify-content: flex-end;
}
.contact-content .content-row .content-form .form form .button span{
    font-size: var(--text-sm);
    color: var(--hijau-1);
    display: none;
}

/*========================*/
/*===== CONTACT MAPS =====*/
/*========================*/
.contact-maps{
    margin-top: 80px;
}
.contact-maps .maps-row{
    display: flex;
    gap: 32px;
}
.contact-maps .maps-row .maps{
    width: 50%;
    aspect-ratio: 1/1;
}
.contact-maps .maps-row .location{
    width: 50%;
}
.contact-maps .maps-row .location h3{
    margin-bottom: 20px;
    font-size: var(--text-5xl);
    font-weight: 700;
}
.contact-maps .maps-row .location .item{
    margin: 8px 0;
}
.contact-maps .maps-row .location .item h4{
    font-size: var(--text-xl);
    font-weight: 600;
}
.contact-maps .maps-row .location .item p{
    font-size: var(--text-lg);
}








/*============================================================*/
/*==================== 404 NOT FOUND PAGE ====================*/
/*============================================================*/
.notfound{
    min-height: 80vh;
}
.notfound .container{
    height: 100%;
}
.notfound .notfound-row{
    display: flex;
    align-items: center;

    height: 100%;
}
.notfound .notfound-row .gambar{
    display: flex;
    align-items: center;
    width: 50%;
}
.notfound .notfound-row .gambar img{
    width: 90%;
}
.notfound .notfound-row .konten{
    width: 50%;
}
.notfound .notfound-row .konten h1{
    font-size: var(--text-8xl);
    font-weight: 700;
    color: var(--hijau-1);
}
.notfound .notfound-row .konten p{
    margin-top: 16px;

    font-size: var(--text-4xl);
    font-weight: 600;
    line-height: 110%;
}
.notfound .notfound-row .konten .link{
    margin-top: 32px;
}







/*====================================================*/
/*==================== DESKTOP XL ====================*/
/*====================================================*/
@media only screen and (max-width: 1400px){
    .home-product .swiper-home-product .item{
        aspect-ratio: 3/4.5;
    }
}


/*====================================================*/
/*==================== DESKTOP LG ====================*/
/*====================================================*/
@media only screen and (max-width: 1200px){
    .home-product .swiper-home-product .item{
        aspect-ratio: 3/5.1;
    }
}


/*================================================*/
/*==================== MOBILE ====================*/
/*================================================*/
@media only screen and (max-width: 992px) {
    body{
        margin-top: 50px;
    }

    
    .button-abu{
        font-size: var(--text-xl);
        
        padding: 4px 16px;
    }

    /*===== BUTTON KUNING =====*/
    .button-kuning{
        
        font-size: 12px;
    }

    /*==================*/
    /*===== NAVBAR =====*/
    /*==================*/
    nav{
        height: 50px;
    }
    nav .nav-container{
        padding: 0 16px;
    }
    nav .nav-logo{
        width: 50%;
    }
    nav .nav-button{
        width: 10%;
        display: block;
    }
    nav .nav-button .button-menu{
        cursor: pointer;
    }
    .nav-links{
        display: none;
    }
    .nav-lang{
        display: none;
    }
    .nav-links .button-close{
        display: block;
    }
    nav .button-menu{
        display: block;
    }

    nav .nav-menu{
        display: block;

        position: absolute;
        top: 0;
        right: 0;

        height: 100vh;
        width: 0;

        background-color: #FFFFFF;

        box-shadow: -5px 5px 10px #1B1B1B55;

        overflow: hidden;

        transition: .5s ease-out;
    }
    nav .nav-menu *{
        white-space: nowrap;
    }
    nav .nav-menu.active *{
        white-space: normal;
    }
    nav .nav-menu.active{
        width: 80vw;
    }
    nav .nav-menu .menu-wrapper{
        width: 100%;
        height: 100%;

        padding: 80px 32px 16px;
    }
    nav .nav-menu .menu-wrapper .links > a{
        text-align: right;
        padding: 8px 0;
    }
    nav .nav-menu .menu-wrapper .collapse{
        padding-right: 32px;
        text-align: right;
    }
    nav .nav-menu .menu-wrapper .collapse ul li a,
    nav .nav-menu .menu-wrapper .collapse ul li a{
        text-align: right;
        font-size: var(--text-lg);
        color: var(--hijau-1);
    }
    nav .nav-menu .menu-wrapper .lang a{
        margin-top: 16px;
        justify-content: right;
    }
    .nav-menu .button-close{
        display: block;
        position: absolute;
        top: 16px;
        right: 32px;
    }



    /*==================*/
    /*===== FOOTER =====*/
    /*==================*/
    footer{
        margin-top: 60px;
        padding-top: 32px;
        padding-left: 16px;
        padding-right: 16px;
        background-color: #01290F;
    }
    footer .footer-row{
        flex-direction: column;
    }
    footer .footer-row .about{
        width: 100%;
    }
    footer .footer-row .about p{
        text-align: center;
    }
    footer .footer-row .company,
    footer .footer-row .product,
    footer .footer-row .service,
    footer .footer-row .contact,
    footer .footer-row .socmed{
        width: 100%;
    }



    /*==============================================*/
    /*==================== HOME ====================*/
    /*==============================================*/

    /*=====================*/
    /*===== HOME HERO =====*/
    /*=====================*/
    .home-hero .swiper-slide{
        padding-bottom: 32px;
    }
    .home-hero .slide{
        flex-direction: column;
        align-items: center;
    }
    .home-hero .slide .gambar{
        width: 90%;
        aspect-ratio: 2.3/1.2;
        border-radius: 12px;
    }
    .home-hero .slide .konten{
        width: 100%;
        margin: 16px 0 0;
        
    }
    .home-hero .slide .konten h3{
        text-align: center;
        font-size: var(--text-sm);
        letter-spacing: 3px;
    }
    .home-hero .slide .konten h1{
        font-size: var(--text-2xl);
        text-align: center;
    }
    .home-hero .slide .konten .icon{
        display: flex;
        justify-content: center;
        margin-top: 20px;
    }
    .home-hero .slide .konten > p{
        text-align: center;
    }
    .home-hero .slide .konten .link{
        text-align: center;
    }
    
    /*======================*/
    /*===== HOME ABOUT =====*/
    /*======================*/
    .home-about{
        margin-top: 32px;
        padding: 0;
    }
    .home-about h2,
    .home-product h2,
    .home-service h2,
    .home-why h2,
    .home-partner h2,
    .home-contact h2{
        font-size: var(--text-2xl);
    }
    .home-about .about-row{
        flex-direction: column-reverse;
        gap: 16px;
    }
    .home-about .about-row .konten{
        width: 100%;
    }
    .home-about .about-row .konten p{
        font-size: var(--text-base);
        line-height: 28px;
    }
    .home-about .about-row .video{
        width: 100%;
    }

    /*========================*/
    /*===== HOME PRODUCT =====*/
    /*========================*/

    .home-product{
        margin-top: 40px;
        padding: 0;
    }
    .home-product .swiper-home-product{
        margin-top: 24px;
        margin-left: 50px;
        margin-right: 50px;
    }
    .home-product .swiper-home-product .swiper-slide{
        opacity: 1;
        transform: scale(1);
    }
    .home-product .swiper-home-product .swiper-slide.swiper-slide-active{
        opacity: 1;
        transform: scale(1);
    }

    .home-product .swiper-home-product .item{
        aspect-ratio: auto;
    }
    .home-product .swiper-home-product .item .gambar{
        aspect-ratio: auto;
    }
    .home-product .swiper-home-product .item .konten p{
        position: static;
        opacity: 1;
    }
    .home-product .swiper-home-product .item .konten a{
        position: static;
        opacity: 1;
    }
    .home-product .swiper-home-product .swiper-slide.swiper-slide-active .item:hover .gambar{
        aspect-ratio: auto;
    }
    .home-product .swiper-navigation-home-product .button-prev{
        left: 8px;
        width: 40px;
    }
    .home-product .swiper-navigation-home-product .button-next{
        right: 8px;
        width: 40px;
    }


        
    /*========================*/
    /*===== HOME SERVICE =====*/
    /*========================*/
    .home-service{
        margin-top: 60px;
        margin-bottom: 16px;
        padding: 0;
    }
    .home-service .service-content{
        flex-direction: column;

        margin-top: 32px;
    }
    .home-service .service-content .gambar{
        width: 60%;
    }
    .home-service .service-content .konten{
        width: 100%;
    }
    .home-service .service-content .konten h3{
        text-align: center;
        font-size: var(--text-lg);
    }
    .home-service .service-content .konten p{
        margin-top: 16px;
        text-align: center;
        font-size: var(--text-sm);
    }
    .home-service .service-content .konten .link{
        margin-top: 40px;
        text-align: center;
    }
    .home-service .service-content .konten a{
        padding: 12px 20px;
        background-color: var(--kuning);

        font-size: 14px;
    }
    .home-service .service-pagination{
        gap: 12px;

        margin-top: 0px;
    }
    .home-service .home-service-pagination .swiper-pagination-bullet{
        width: 60px;
        height: 6px;
    }

    
    /*====================*/
    /*===== HOME WHY =====*/
    /*====================*/

    .home-why{
        margin-top: 100px;
        margin-bottom: 16px;
        padding: 0;
    }
    .home-why .why-grid{
        row-gap: 32px;

        margin-top: 20px;
    }
    .home-why .why-grid .item{
        width: 100%;
        padding: 0 16px;
    }
    .home-why .why-grid .item .gambar{
        width: 40%;
    }
    .home-why .why-grid .item .konten{
        margin-top: 16px;
    }


    /*=================================================*/
    /*==================== PRODUCT ====================*/
    /*=================================================*/

    /*========================*/
    /*===== PRODUCT HERO =====*/
    /*========================*/
    .product-hero{
        height: 80vw;
    }
    .product-hero .container-hero{
        justify-content: center;
    }
    .product-hero h2{
        text-align: center;
        font-size: var(--text-2xl);

        max-width: 90%;
    }

    /*===========================*/
    /*===== PRODUCT SUBMENU =====*/
    /*===========================*/
    .product-submenu .button-submenu{
        display: flex;
        justify-content: space-between;
        align-items: center;
    }
    .product-submenu .button-submenu p{
        color: #FFFFFF;
        font-size: var(--text-xl);
        font-weight: 600;
    }
    .product-submenu .submenu-links{
        position: absolute;
        top: 100%;
        left: 0;

        width: 100%;
        height: 0;
        /* padding: 16px 8px; */
        padding: 0 0;

        background-color: #0F6C29;

        flex-direction: column;

        overflow: hidden;

        transition: .5s;
    }
    .product-submenu .submenu-links.active{
        height: auto;
        padding: 16px 8px;
        
    }
    


    /*========================*/
    /*===== PROCUCT INFO =====*/
    /*========================*/
    .product-info{
    }
    .product-info .info-row{
        flex-direction: column;
        gap: 24px;
    }
    .product-info .info-row .gambar{
        width: 100%;
    }
    .product-info .info-row .gambar img{
        width: 80%;
    }
    .product-info .info-row .konten{
        width: 100%;
    }
    .product-info .info-row .konten h3{
        font-size: var(--text-3xl);
    }
    .product-info .info-row .konten p{
        font-size: var(--text-base);
    }


    /*=========================*/
    /*===== PRODUCT ADVAN =====*/
    /*=========================*/
    .product-advan .advan-row{
        flex-direction: column;
        gap: 32px;
    }
    .product-advan .advan-row .item{
        width: 100%;
        border-radius: 8px;
    }
    .product-advan .advan-row .item .gambar{
        text-align: center;
    }
    .product-advan .advan-row .item .gambar img{
        width: 50%;
    }
    .product-advan .advan-row .item .konten h4{
        text-align: center;
        font-size: var(--text-xl);
    }
    .product-advan .advan-row .item .konten p{
        text-align: center;
        font-size: var(--text-sm);
        line-height: 18px;
    }
    
    /*============================*/
    /*===== PRODUCT ACTIVITY =====*/
    /*============================*/
    .product-activity{
        padding: 16px;
        margin-top: 32px;
    }
    .product-activity h3{
        margin-top: 0px;
        font-size: var(--text-2xl);
    }
    .product-activity .activity-row{
        flex-direction: column;
    }
    .product-activity .activity-row .item{
        width: 100%;
        padding: 0;
    }

    
    /*=================================================*/
    /*==================== SERVICE ====================*/
    /*=================================================*/

    /*========================*/
    /*===== SERVICE HERO =====*/
    /*========================*/
    .service-hero{
        height: 80vw;
    }
    .service-hero .container-hero{
        justify-content: center;
    }
    .service-hero h2{
        text-align: center;
        font-size: var(--text-2xl);

        max-width: 90%;
    }

    
    /*========================*/
    /*===== SERVICE INFO =====*/
    /*========================*/
    .service-info{
        padding: 0;
    }
    .service-info .info-row{
        flex-direction: column;
        gap: 24px;
    }
    .service-info .info-row .gambar{
        width: 100%;
    }
    .service-info .info-row .gambar img{
        width: 100%;
        height: 100%;
    }
    .service-info .info-row .konten{
        width: 100%;
    }
    .service-info .info-row .konten h3{
        font-size: var(--text-3xl);
    }
    .service-info .info-row .konten p{
        font-size: var(--text-base);
    }


    /*============================*/
    /*===== SERVICE ACTIVITY =====*/
    /*============================*/
    .service-activity{
        padding: 16px;
        margin-top: 32px;
    }
    .service-activity h3{
        margin-top: 0px;
        font-size: var(--text-2xl);
    }
    .service-activity .activity-row{
        flex-direction: column;
        margin-top: 16px;
    }
    .service-activity .activity-row .item{
        width: 100%;
        padding: 0;
        display: flex;
        align-items: center;
        aspect-ratio: 1/1;
    }

    
    /*===========================*/
    /*===== SERVICE BENEFIT =====*/
    /*===========================*/
    .service-benefit{
        margin-top: 100px;
    }
    .service-benefit h3{
        font-size: var(--text-2xl);
    }
    .service-benefit .benefit-grid{
        flex-direction: column;
        row-gap: 20px;

        margin-top: 40px;
    }
    .service-benefit .benefit-grid .item{
        width: 100%;
    }
    .service-benefit .benefit-grid .item .gambar{
        width: 30%;
    }
    
    /*===========================*/
    /*===== SERVICE CONTACT =====*/
    /*===========================*/
    .service-contact{
        margin-top: 60px;
    }
    .service-contact h3{
        font-size: var(--text-3xl);
    }
    


    /*============================================================*/
    /*==================== 404 NOT FOUND PAGE ====================*/
    /*============================================================*/
    .notfound{
        min-height: 80vh;
        padding: 48px 0;
    }
    .notfound .notfound-row{
        flex-direction: column;
    }
    .notfound .notfound-row .gambar{
        width: 80%;
    }
    .notfound .notfound-row .gambar img{
        width: 90%;
    }
    .notfound .notfound-row .konten{
        width: 100%;
    }
    .notfound .notfound-row .konten h1{
        font-size: var(--text-6xl);
        text-align: center;
    }
    .notfound .notfound-row .konten p{
        font-size: var(--text-2xl);
        text-align: center;
    }
    .notfound .notfound-row .konten .link{
        text-align: center;
    }









    
    /*=================================================*/
    /*==================== CONTACT ====================*/
    /*=================================================*/

    /*========================*/
    /*===== CONTACT HERO =====*/
    /*========================*/
    .contact-hero{
        height: 60vw;
    }

    .contact-hero h2{
        font-size: var(--text-3xl);
    }


    /*===========================*/
    /*===== CONTACT CONTENT =====*/
    /*===========================*/
    .contact-content{
        padding: 20px 0;

        background-color: #E3F0DB;
    }
    .contact-content .content-row{
        flex-direction: column;
    }
    .contact-content .content-row .content-info{
        width: 100%;
    }

    .contact-content .content-row .content-form{
        width: 100%;
    }
    .contact-content .content-row .content-form h3{
        font-size: var(--text-3xl);
    }

    
    /*========================*/
    /*===== CONTACT MAPS =====*/
    /*========================*/
    .contact-maps{
        margin-top: 80px;
    }
    .contact-maps .maps-row{
        flex-direction: column;
    }
    .contact-maps .maps-row .maps{
        width: 100%;
    }
    .contact-maps .maps-row .location{
        width: 100%;
    }
    .contact-maps .maps-row .location h3{
        font-size: var(--text-3xl);
    }
    .contact-maps .maps-row .location .item h4{
        font-size: var(--text-lg);
    }
    .contact-maps .maps-row .location .item p{
        font-size: var(--text-base);
    }
    
}