/* =========================
   CITY HERO
========================= */

.city-hero{

    padding:40px 0;

    background:#fff;

}

.city-hero-grid{

    display:grid;

    grid-template-columns:
    1.3fr 1fr;

    gap:60px;

    align-items:center;

}

/* IMAGE */

.city-hero-image{

    overflow:hidden;

    border-radius:8px;

}

.city-hero-image img{

    width:100%;

    height:380px;

    object-fit:cover;

    display:block;

}

/* CONTENT */

.city-hero-content{

    text-align:center;

}

/* LABEL */

.hero-label{

    display:block;

    font-size:14px;

    letter-spacing:2px;

    text-transform:uppercase;

    margin-bottom:8px;

    color:#666;

}

/* H1 */

.city-hero-content h1{

    font-size:42px;

    font-weight:700;

    line-height:1.2;

    margin-bottom:10px;

    color:#111;

}

/* 24 JAM */

.hero-24{

    font-size:82px;

    font-family:Georgia, serif;

    font-style:italic;

    line-height:1;

    color:#111;

    margin-bottom:12px;

}

/* DESC */

.city-hero-content p{

    font-size:22px;

    line-height:1.4;

    color:#333;

    margin-bottom:25px;

}

/* BUTTON */

.hero-wa{

    display:inline-block;

    padding:14px 30px;

    background:#25D366;

    color:#fff;

    text-decoration:none;

    border-radius:8px;

    font-weight:600;

}

.hero-wa:hover{

    color:#fff;

}

/* TOP */

.tab-top{

    display:flex;

    justify-content:space-between;

    align-items:center;

    margin-bottom:40px;

}

/* SEE ALL */

/* .see-all{

    color:#111;

    text-decoration:none;

    font-size:14px;

    font-weight:600;

}

.see-all:hover{

    color:#944fd4;

} */

@media(max-width:991px){

    .city-hero{

        padding:20px 0;

    }

    .city-hero-grid{

        grid-template-columns:1fr;

        gap:25px;

    }

    .city-hero-image img{

        height:220px;

    }

    .city-hero-content h1{

        font-size:28px;

    }

    .hero-24{

        font-size:60px;

    }

    .city-hero-content p{

        font-size:16px;

    }

    .hero-wa{

        width:100%;

        text-align:center;

    }

}

/* =========================
   PRODUCT SECTION
========================= */

.product-section{

    padding:90px 0;

    background:#fff;

}

/* TITLE */

.section-title{

    text-align:center;

    margin-bottom:50px;

}

.section-title h2{

    font-size:42px;

    font-weight:700;

    margin-bottom:16px;

    color:#111;

}

.section-title p{

    max-width:760px;

    margin:auto;

    font-size:17px;

    line-height:1.9;

    color:#777;

}

/* GRID */

.product-slider{

    display:grid;

    grid-template-columns:
    repeat(3,1fr);

    gap:28px;

}

/* CARD */

.product-card{

    background:#fff;

    border-radius:28px;

    overflow:hidden;

    text-decoration:none;

    box-shadow:
    0 10px 30px rgba(0,0,0,.05);

    transition:.3s;

}

.product-card:hover{

    transform:translateY(-8px);

    box-shadow:
    0 20px 40px rgba(0,0,0,.08);

}

/* IMAGE */

.product-image{

    height:320px;

    overflow:hidden;

    background:#f8f8f8;

}

.product-image img{

    width:100%;
    height:100%;

    object-fit:cover;

    transition:.5s;

}

.product-card:hover img{

    transform:scale(1.06);

}

/* CONTENT */

.product-content{

    padding:24px;

}

/* TITLE */

.product-content h3{

    font-size:20px;

    line-height:1.6;

    font-weight:600;

    color:#111;

    margin-bottom:16px;

}

/* PRICE */

.product-price{

    font-size:22px;

    font-weight:700;

    color:#944fd4;

}

/* =========================
   CONTENT SEO
========================= */

.city-content-section{

    padding:90px 0;

    background:#fafafa;

}

.city-content-box{

    max-width:1000px;

    margin:auto;

    background:white;

    padding:50px;

    border-radius:30px;

    line-height:2;

    font-size:17px;

    color:#555;

    box-shadow:
    0 10px 30px rgba(0,0,0,.04);

}

/* =========================
   FAQ
========================= */

.city-faq{

    padding:70px 0;

    background:#fafafa;

}

.city-faq h2{

    text-align:center;

    font-size:34px;

    font-weight:700;

    margin-bottom:35px;

}

.city-faq .accordion{

    max-width:900px;

    margin:auto;

}

.city-faq .accordion-item{

    border:1px solid #eee;

    margin-bottom:12px;

    border-radius:12px;

    overflow:hidden;

}

.city-faq .accordion-button{

    font-weight:600;

    padding:18px 22px;

}

.city-faq .accordion-body{

    color:#666;

    line-height:1.8;

}

@media(max-width:991px){

    .city-faq{

        padding:50px 0;

    }

    .city-faq h2{

        font-size:24px;

    }

}

/* =========================
   MOBILE
========================= */

@media(max-width:991px){

    /* HERO */

    .city-hero{

        height:520px;

    }

    .city-content h1{

        font-size:42px;

        line-height:1.3;

        margin-bottom:18px;

    }

    .city-content h2{

        font-size:16px;

        line-height:1.8;

    }

    /* PRODUCT */

    .product-section{

        padding:70px 0;

    }

    .section-title{

        margin-bottom:35px;

    }

    .section-title h2{

        font-size:32px;

    }

    .section-title p{

        font-size:15px;

        line-height:1.8;

    }

    /* GRID */

    .product-slider{

        grid-template-columns:1fr;

        gap:20px;

    }

    /* CARD */

    .product-card{

        border-radius:22px;

    }

    .product-image{

        height:260px;

    }

    .product-content{

        padding:20px;

    }

    .product-content h3{

        font-size:18px;

    }

    .product-price{

        font-size:20px;

    }

    /* CONTENT

    .city-content-section,
    .faq-section{

        padding:70px 0;

    }

    .city-content-box,
    .faq-box{

        padding:28px;

        border-radius:22px;

        font-size:15px;

        line-height:1.9;

    } */

}

/* =========================
   DUKA SECTION
========================= */

.duka-section{

    background:#000;

    padding:30px 0 50px;

}

/* HEADER */

.duka-header{

    display:flex;
    justify-content:space-between;
    align-items:center;

    margin-bottom:30px;

}

.duka-header h2{

    color:#fff;

    font-size:24px;

    font-weight:700;

    margin:0;

}

.duka-header a{

    color:#fff;

    text-decoration:none;

    font-size:14px;

    font-weight:600;

}

/* =========================
   PRODUCT GRID
========================= */

.duka-products{

    display:grid;

    grid-template-columns:repeat(6,1fr);

    gap:16px;
    
    display:flex;


}

/* =========================
   CARD
========================= */

.duka-card{

    width:100%;

    min-width:0;

    text-decoration:none;

    color:#fff;

    display:flex;

    flex-direction:column;

    align-items:center;

    text-align:center;
    flex:1;

    min-width:0;

}

/* =========================
   IMAGE
========================= */

.duka-image{

    width:100%;

    height:260px;

    display:flex;

    align-items:center;
    justify-content:center;

    overflow:hidden;

}

.duka-image img{

    width:100%;
    height:100%;

    object-fit:contain;

    transition:.3s;

}

.duka-card:hover img{

    transform:scale(1.03);

}

/* =========================
   TITLE
========================= */

.duka-card h3{

    color:#fff;

    font-size:14px;

    font-weight:600;

    text-transform:uppercase;

    margin:12px 0 8px;

    line-height:1.4;

    width:100%;

    white-space:nowrap;

    overflow:hidden;

    text-overflow:ellipsis;

}

/* =========================
   PRICE
========================= */

.duka-price{

    display:flex;

    flex-direction:column;

    align-items:center;

    gap:4px;

}

.duka-price .price-before{

    color:#FF4D4D;

    font-size:12px;

    text-decoration:line-through;

}

.duka-price .price-now{

    color:#fff;

    font-size:22px;

    font-weight:700;

}

.city-category-title{

    text-align:center;

    margin-bottom:30px;

}

.city-category-title h2{

    color:#944fd4;

    font-size:28px;

    font-weight:700;

    margin-bottom:8px;

}

.city-category-title p{

    color:#666;

    font-size:15px;

}

/* =========================
   MOBILE
========================= */

@media(max-width:991px){

    .duka-section{

        padding:25px 0 40px;

    }

    .duka-header{

        margin-bottom:20px;

    }

    .duka-header h2{

        font-size:18px;

        line-height:1.3;

    }

    .duka-header a{

        font-size:12px;

    }

    .duka-products{

        display:grid;

        grid-template-columns:
        repeat(2,1fr);

        gap:28px 18px;

    }

    .duka-card{

        width:100%;

    }

    .duka-image{

        height:220px;

    }

    .duka-image img{

        object-fit:contain;

    }

    .duka-card h3{

        white-space:normal;

        overflow:visible;

        text-overflow:unset;

        min-height:36px;

        font-size:13px;

        line-height:1.3;

        margin:8px 0 6px;

    }

    .duka-price .price-before{

        font-size:11px;
        color:#FF4D4D;

    }

    .duka-price .price-now{

        font-size:18px;

        color:#fff;

    }

}
/* =========================
   TAB SECTION
========================= */

.tab-section{

    padding:60px 0;

    background:#fff;

}

/* =========================
   TAB BUTTON
========================= */

.tab-buttons{

    display:flex;

    justify-content:center;
    align-items:center;

    flex-wrap:wrap;

    gap:8px;

    margin-bottom:35px;

}

/* BUTTON */

.tab-btn{

    border:none;

    background:#f5f5f5;

    color:#444;

    padding:12px 18px;

    font-size:13px;

    font-weight:600;

    cursor:pointer;

    transition:.25s;

}

/* ACTIVE */

.tab-btn.active{

    background:#5d9b9b;

    color:#fff;

}

/* HILANGKAN GARIS BAWAH */

.tab-btn.active::after{

    display:none;

}

/* =========================
   GRID
========================= */

.tab-grid{

    display:grid;

    grid-template-columns:
    repeat(6,1fr);

    gap:24px;

}

/* =========================
   CARD
========================= */

.tab-card{

    text-decoration:none;

    color:#222;

    display:flex;

    flex-direction:column;

}

/* =========================
   IMAGE
========================= */

.tab-image{

    height:240px;

    display:flex;

    align-items:center;
    justify-content:center;

    overflow:hidden;

}

.tab-image img{

    width:100%;
    height:100%;

    object-fit:contain;

}

/* =========================
   BODY
========================= */

.tab-body{

    padding-top:12px;

    text-align:center;

}

/* TITLE */

.tab-body h3{

    font-size:14px;

    font-weight:600;

    line-height:1.35;

    color:#444;

    margin-bottom:8px;

    min-height:40px;

    display:-webkit-box;

    -webkit-box-orient:vertical;

    overflow:hidden;

    text-transform:none;

}

/* =========================
   PRICE
========================= */

.tab-price{

    display:flex;

    flex-direction:column;

    align-items:center;

    gap:4px;

}

.price-before{

    font-size:12px;

    color:#FF4D4D;

    text-decoration:line-through;

}

.price-now{

    font-size:18px;

    font-weight:700;

    color:#444;

}

/* =========================
   MOBILE
========================= */

@media(max-width:991px){

    .tab-section{

        padding:40px 0;

    }

    /* TAB */

    .tab-buttons{

        justify-content:center;

        gap:6px;

        margin-bottom:25px;

    }

    .tab-btn{

        padding:10px 14px;

        font-size:12px;

    }

    /* GRID */

    .tab-grid{

        grid-template-columns:
        repeat(2,1fr);

        gap:30px 14px;

    }

    /* IMAGE */

    .tab-image{

        height:180px;

    }

    .tab-image img{

        width:100%;
        height:100%;

        object-fit:contain;

    }

    /* TITLE */

    .tab-body h3{

        font-size:12px;

        line-height:1.3;

        min-height:34px;

        margin-bottom:6px;

    }

    /* PRICE */

    .price-before{

        font-size:10px;
        color:#FF4D4D;

    }

    .price-now{

        font-size:15px;

    }

    .tab-top{

        flex-direction:column;

        align-items:flex-start;

        gap:14px;

    }

    .see-all{

        font-size:13px;

    }


}

