/* ===========================================
   MUTIARA BUMI DESIGN SYSTEM v1.0
=========================================== */

:root{

    /* BRAND */
    --primary:#198754;
    --primary-dark:#146c43;
    --warning:#ffc107;
    --danger:#dc3545;
    --light:#f8f9fa;
    --white:#ffffff;
    --text:#333333;
    --border:#ececec;
    --text-muted:#777;

    /* UI */
    --radius:10px;
    --radius-lg:18px;

    --shadow:
        0 12px 30px rgba(0,0,0,.08);

    --shadow-hover:
    0 18px 40px rgba(0,0,0,.12);
    --transition:
        .25s ease;

}



.hero::before{
content:'';
position:absolute;
left:0;
top:0;
width:100%;
height:100%;
background:rgba(0,0,0,.55);
}

.hero .container{
position:relative;
z-index:2;
}

.section-title{
font-weight:700;
margin-bottom:30px;
}

.product-card{
background:#fff;
    border:1px solid #eee;

border-radius:24px;

overflow:hidden;

box-shadow:0 15px 40px rgba(0,0,0,.08);

transition:.35s;

height:100%;
}

.product-card:hover{
transform:translateY(-10px);

box-shadow:0 25px 60px rgba(0,0,0,.18);
}

.product-image{

overflow:hidden;

height:250px;

}

.product-image img{

width:100%;

height:100%;

object-fit:cover;

transition:.5s;

}

.product-body{

padding:25px;

}

.product-category{

display:inline-block;

padding:6px 14px;

border-radius:50px;

background:#eaf7ef;

color:#198754;

font-size:.85rem;

font-weight:600;

margin-bottom:15px;

}


.product-body h5{

font-weight:700;

margin-bottom:15px;

}

.product-body p{

color:#666;

line-height:1.7;

min-height:85px;

}

.product-body .btn{

margin-top:10px;

border-radius:50px;

}


.product-card:hover img{

transform:scale(1.08);

}

.gallery-img{
    height:750px;
    object-fit:cover;
    transition:all .3s ease;
}

.gallery-img:hover{
    transform:scale(1.03);
}

.wa-float{
    position:fixed;
    width:60px;
    height:60px;
    bottom:25px;
    right:25px;

    background:#25D366;
    color:white;

    border-radius:50%;
    text-align:center;

    font-size:30px;
    line-height:60px;

    text-decoration:none;

    box-shadow:0 4px 10px rgba(0,0,0,.3);

    z-index:9999;

    transition:.3s;
}

.wa-float:hover{
    transform:scale(1.1);
    color:white;
}

.hero{
    background: linear-gradient(
        135deg,
        #0b7a43 0%,
        #198754 55%,
        #46b97d 100%
    );

    color:#fff;

    padding:110px 0;

    overflow:hidden;

    position:relative;
}

.hero::before{

    content:"";

    position:absolute;

    width:420px;

    height:420px;

    background:rgba(255,255,255,.08);

    border-radius:50%;

    top:-120px;

    right:-120px;

}
.hero::after{

    content:"";

    position:absolute;

    width:260px;

    height:260px;

    background:rgba(255,255,255,.05);

    border-radius:50%;

    bottom:-80px;

    left:-60px;

}

.hero .container{
    position:relative;
    z-index:2;
}

.hero h1{
    text-shadow:2px 2px 10px rgba(0,0,0,.5);
}

.hero p{
    text-shadow:2px 2px 10px rgba(0,0,0,.5);
}

.product-card{
    height:100%;
}

.product-card .card-body{
    display:flex;
    flex-direction:column;
    min-height:120px;
}

.card{
    transition:.3s;
}

.card:hover{
    transform:translateY(-5px);
    box-shadow:0 10px 25px rgba(0,0,0,.15);
}

.detail-img{

    width:100%;

    height:320px;

    object-fit:cover;

    object-position:center top;

    border-radius:var(--radius);

    border:1px solid #e5e5e5;

    transition:.3s;

}

@media(max-width:768px){

.detail-img{

    height:240px;

}

}

.detail-img:hover{
    transform:scale(1.02);
}

.badge{
    padding:10px 15px;
}

.kategori-card{
    border:none;
    border-radius:15px;
    overflow:hidden;
    transition:.3s;
    box-shadow:var(--shadow);
}

.kategori-card:hover{
    transform:translateY(-8px);
    box-shadow:0 15px 35px rgba(0,0,0,.15);
}


.kategori-card:hover{
    transform:translateY(-8px);
    box-shadow:0 15px 30px rgba(0,0,0,.15);
}

.kategori-card img{
    height:220px;
    width:100%;
    object-fit:cover;
}




.logo{
    height:40px;
    width:auto;
}


footer a{
    transition:.3s;
}

footer a:hover{
    color:#ffc107 !important;
    padding-left:5px;
}

footer{
    font-size:15px;
}

footer h4,
footer h5{
    color:#ffc107;
}

footer p,
footer li{
    line-height:1.8;
}



/* =========================
   NAVBAR
========================= */

.navbar{
    padding:12px 0;
    box-shadow:0 2px 15px rgba(0,0,0,.08);
}

.logo{
    height:60px;
    width:auto;
}

.navbar-brand strong{
    font-size:20px;
    letter-spacing:.5px;
}

.navbar-brand small{
    font-size:12px;
    opacity:.9;
}

.navbar-nav .nav-link{
    font-weight:600;
    margin-left:10px;
    position:relative;
    transition:.3s;
}

.navbar-nav .nav-link:hover{
    color:#ffc107 !important;
}

.navbar-nav .nav-link::after{
    content:'';
    position:absolute;
    left:0;
    bottom:-5px;
    width:0;
    height:2px;
    background:#ffc107;
    transition:.3s;
}

.navbar-nav .nav-link:hover::after{
    width:100%;
}

/* =========================
   DROPDOWN
========================= */

.dropdown-menu{

    min-width:280px;

    max-height:420px;

    overflow-y:auto;

    overflow-x:hidden;

    border:none;

    border-radius:18px;

    padding:8px;

    box-shadow:0 15px 35px rgba(0,0,0,.15);

    animation:fadeDropdown .25s ease;

}

.dropdown-item{
    padding:10px 20px;
    font-size:15px;
    transition:.25s;
}

.dropdown-item i{
    color:#198754;
    width:20px;
}

.dropdown-item .badge{
    font-size:11px;
    padding:4px 8px;
}

.dropdown-item:hover{
    background:var(--primary);
    color:#fff;
    padding-left:25px;
}

.dropdown-item:hover i{
    color:#fff;
}


/* Scrollbar */

.dropdown-menu::-webkit-scrollbar{

    width:8px;

}

.dropdown-menu::-webkit-scrollbar-track{

    background:#f1f1f1;

}

.dropdown-menu::-webkit-scrollbar-thumb{

    background:#198754;

    border-radius:20px;

}

.dropdown-menu{

    scrollbar-width:thin;

    scrollbar-color:#198754 #f1f1f1;

}

@keyframes fadeDropdown{
    from{
        opacity:0;
        transform:translateY(10px);
    }
    to{
        opacity:1;
        transform:translateY(0);
    }
}

@media (min-width:992px){

    .dropdown-menu{

        border:none;

        border-radius:18px;

        box-shadow:0 15px 35px rgba(0,0,0,.18);

    }

    .dropdown-toggle::after{

        transition:.3s;

    }

    .dropdown-toggle.show::after{

        transform:rotate(180deg);

    }

}


/* Active Menu */

.navbar-nav .nav-link.active{
    color:#ffc107 !important;
}

.navbar-nav .nav-link.active::after{
    width:100%;
}

/* =====================
TIM MARKETING
===================== */

.marketing-card{
    border:none;
    border-radius:15px;
    overflow:hidden;
    transition:.3s;
    box-shadow:0 5px 15px rgba(0,0,0,.08);
}

.marketing-card:hover{
    transform:translateY(-8px);
    box-shadow:0 20px 40px rgba(0,0,0,.12);
}

.marketing-card .btn-success{
    transition:all .3s ease;
    transform:scale(1.03);
}

.marketing-card:hover .btn-success i{

    transform:translateX(3px);

}

.marketing-card .btn-success i{

    transition:.3s;

}

.marketing-foto{
    height:320px;
    object-fit:cover;
    transition:transform .35s ease;
    object-position:center top;
}

.marketing-card h5{
    font-size:18px;
    margin-bottom:10px;
}

.marketing-foto-utama{
    height:450px;
    object-fit:cover;
    transition:transform .35s ease;
    object-position:center top;
}

.marketing-card{
    overflow:hidden;
    transition:all .3s ease;
}

.marketing-card:hover .marketing-foto,
.marketing-card:hover .marketing-foto-utama{

    transform:scale(1.05);

}

.marketing-foto{
    height:320px;
    object-fit:cover;
}

.product-card img{
    height:250px;
    object-fit:cover;
}


/* ==========================================================
   MUTIARA BUMI UI COMPONENTS
========================================================== */

.card-mb{

    background:var(--white);

    border-radius:var(--radius);

    border:1px solid var(--border);

    box-shadow:var(--shadow);

    transition:var(--transition);

    overflow:hidden;

}

.card-mb:hover{

    transform:translateY(-4px);

    box-shadow:
        0 18px 40px rgba(0,0,0,.12);

}

/* ==========================================================
   SECTION TITLE
========================================================== */

.section-title{

    font-size:42px;

    font-weight:800;

    color:var(--text);

    text-align:center;

    margin-bottom:12px;

}

.section-subtitle{

    text-align:center;

    color:#777;

    font-size:17px;

    margin-bottom:50px;

}

.custom-dropdown-menu a i{

    color:var(--primary);

    width:20px;

    text-align:center;

    font-size:16px;

    transition:var(--transition);

}

/* SOCIAL LINKS */

.social-links{

    display:flex;

    gap:12px;

    margin-top:15px;

}

.social-links a{

    width:42px;

    height:42px;

    display:flex;

    align-items:center;

    justify-content:center;

    border-radius:50%;

    background:rgba(255,255,255,.08);

    color:#fff;

    text-decoration:none;

    transition:var(--transition);

}

.social-links a:hover{

    background:var(--warning);

    color:var(--text);

    transform:translateY(-3px);

}

/* Facebook */
.social-facebook:hover{
    background:#1877F2 !important;
    color:#fff !important;
    box-shadow:0 0 18px rgba(24,119,242,.45);
}

/* YouTube */
.social-youtube:hover{
    background:#FF0000 !important;
    color:#fff !important;
    box-shadow:0 0 18px rgba(255,0,0,.45);
}

/* Shopee */
.social-shopee:hover{
    background:#EE4D2D !important;
    color:#fff !important;
    box-shadow:0 0 18px rgba(238,77,45,.45);
}

.social-links img{

    width:35px;
    height:35px;

    object-fit:contain;

    transition:var(--transition);

}

.product-spec{

    display:grid;

    grid-template-columns:repeat(2,1fr);

    gap:12px;

    margin-bottom:25px;

}

.spec-item{

    background:#fff;

    border:1px solid #e8e8e8;

    border-radius:12px;

    padding:15px;

    box-shadow:0 4px 12px rgba(0,0,0,.05);

}

.spec-label{

    font-size:13px;

    color:#666;

    margin-bottom:5px;

}

.spec-value{

    font-weight:700;

    color:#198754;

    font-size:18px;

}

.product-spec{
    display:grid;
    grid-template-columns:repeat(2,1fr);
}

@media(max-width:768px){

.product-spec{

    grid-template-columns:1fr;

}
}
/* ===========================
   MEGA MENU PRODUK
=========================== */

@media (min-width: 992px){

  .produk-menu{

    width:560px;

}

    padding:15px;

    background:#fff;

    border-radius:18px;

    box-shadow:0 15px 35px rgba(0,0,0,.18);

}

    .produk-menu > li{

        list-style:none;

    }

    .produk-menu .dropdown-divider{

        grid-column:1 / -1;

        margin:8px 0;

    }

    .produk-menu .dropdown-item.fw-bold{

        grid-column:1 / -1;

        text-align:center;

    }
    .produk-menu .dropdown-item{

    border-radius:10px;

    padding:10px 15px;

}

.produk-menu .dropdown-item:hover{

    transform:translateX(6px);

}

.produk-menu .fw-bold{

    background:#198754;

    color:#fff !important;

    border-radius:10px;

    text-align:center;

}

.hero-card{

    background:#fff;

    border-radius:28px;

    padding:18px;

    box-shadow:0 25px 70px rgba(0,0,0,.20);

    transform:rotate(-2deg);

    transition:.4s;
}
.hero-card:hover{

    transform:rotate(0deg) translateY(-8px);

}

.hero-image{

    position:relative;

    z-index:2;

}


.hero .badge{

    font-size:.95rem;

    border-radius:50px;

    padding:10px 18px;

}


.hero .btn{

    border-radius:50px;

    font-weight:600;

}
.hero-card img{
    width:100%;
    border-radius:18px;
}


.why-card{

background:#fff;

padding:35px 25px;

border-radius:22px;

text-align:center;

height:100%;

box-shadow:0 10px 30px rgba(0,0,0,.08);

transition:.35s;

}

.why-card:hover{

transform:translateY(-10px);

box-shadow:0 20px 45px rgba(0,0,0,.15);

}

.why-icon{

width:80px;

height:80px;

margin:auto;

margin-bottom:20px;

background:#198754;

color:#fff;

border-radius:50%;

display:flex;

align-items:center;

justify-content:center;

font-size:30px;

}

.why-card h5{

font-weight:700;

margin-bottom:15px;

}

.why-card p{

color:#666;

font-size:.95rem;

line-height:1.7;

}

/* ======================================
   MOBILE RESPONSIVE
====================================== */

@media (max-width:768px){

    .hero{
        padding:60px 0;
    }

    .hero h1{
        font-size:2.3rem;
        line-height:1.2;
    }

    .hero p{
        font-size:16px;
    }

    .hero-card{
        transform:none;
        margin-top:20px;
    }

    .section-title{
        font-size:2.2rem;
    }

    .product-card{
        margin-bottom:20px;
    }

    .product-image{
        height:220px;
    }

    .product-body{
        padding:18px;
    }

    .product-body h5{
        font-size:1.4rem;
    }

    .product-body p{
        min-height:auto;
        margin-bottom:15px;
    }

    .product-body .btn{
        width:100%;
    }

}

.hero-title{
    font-size:3.8rem;
}

@media(max-width:768px){

.hero-title{

    font-size:2.2rem;

}



/* ===== TEST MOBILE ===== */
@media (max-width:768px){

    .product-card{
        width:100% !important;
        display:block !important;
    }

    .product-image{
        width:100% !important;
    }

    .product-image img{
        width:100% !important;
        height:220px !important;
        object-fit:cover !important;
        display:block !important;
    }

}