/* =====================================================
   FINAL CLEAN DROPDOWN – YOUR STAY
===================================================== */

/* ================= BASE ================= */
.hero-menu li.has-dropdown {
    position: relative;
}

/* reset list */
.hero-menu .dropdown-menu {
    list-style: none;
    margin: 0;
    padding: 0;
}

/* =====================================================
   DESKTOP (≥992px)
===================================================== */
@media (min-width: 992px) {

    /* submenu floating rapi */
    .hero-menu .has-dropdown .dropdown-menu {
        position: absolute;
        top: 100%;
        left: 0;

        min-width: 240px;
        background: #ffffff;

        padding: 10px 0;
        margin-top: 8px;

        border-radius: 10px;
        box-shadow:
            0 18px 40px rgba(0,0,0,0.15),
            0 6px 16px rgba(0,0,0,0.08);

        display: none;
        z-index: 5000;
    }

    /* tampil saat aktif */
    .hero-menu li.has-dropdown.active > .dropdown-menu {
        display: block;
    }

    /* item submenu */
    .hero-menu .dropdown-menu li {
        width: 100%;
    }

    .hero-menu .dropdown-menu li a {
        display: block;
        width: 100%;

        padding: 12px 22px;

        font-size: 14px;
        letter-spacing: 1px;
        color: #2f2f2f;
        text-decoration: none;

        white-space: nowrap;
    }

    .hero-menu .dropdown-menu li a:hover {
        background: #f4f6f5;
    }
}

/* =====================================================
   MOBILE & TABLET (<992px)
===================================================== */
@media (max-width: 991px) {

    /* submenu menyatu dengan menu */
    .hero-menu .has-dropdown .dropdown-menu {
        position: static;
        width: 100%;

        display: none;

        padding: 8px 0 0;
        margin: 0;

        box-shadow: none;
        border-radius: 0;
        background: transparent;
    }

    .hero-menu li.has-dropdown.active > .dropdown-menu {
        display: block;
    }

    /* item submenu mobile */
    .hero-menu .dropdown-menu li a {
        padding: 10px 0;
        font-size: 16px;
        letter-spacing: 1.5px;
    }
}

/* =====================================================
   VISUAL CUE (OPTIONAL TAPI RAPI)
===================================================== */
.hero-menu .has-dropdown > .dropdown-toggle::after {
    content: "▾";
    font-size: 11px;
    margin-left: 6px;
    transition: transform 0.3s ease;
}

.hero-menu .has-dropdown.active > .dropdown-toggle::after {
    transform: rotate(180deg);
}

/* =====================================================
   DROPDOWN – FONT & DIVIDER (FINAL)
===================================================== */

/* FONT KHUSUS DROPDOWN */
.hero-menu .dropdown-menu li a {
    font-family: 'Cormorant Garamond', serif;
    font-weight: 500;
    letter-spacing: 0.8px;
}

/* GARIS PEMBATAS TIPIS TRANSPARAN */
.hero-menu .dropdown-menu li {
    position: relative;
}

/* divider kecil, tidak full width */
.hero-menu .dropdown-menu li:not(:last-child)::after {
    content: "";
    position: absolute;
    left: 18px;
    right: 18px;
    bottom: 0;
    height: 1px;
    background: rgba(0, 0, 0, 0.10);
}

/* hover lembut & elegan */
.hero-menu .dropdown-menu li a:hover {
    background: rgba(46, 79, 59, 0.06);
}


/* =====================================================
   DROPDOWN – MOBILE & TABLET (NO BOX / NO BORDER)
===================================================== */

@media (max-width: 991px) {

    /* hilangkan kotak pembungkus dropdown */
    .hero-menu .has-dropdown .dropdown-menu {
        background: transparent;
        box-shadow: none;
        border: none;
        border-radius: 0;

        padding: 6px 0 0;
        margin: 0;
    }

    /* item tetap rapi */
    .hero-menu .dropdown-menu li a {
        background: transparent;
        padding-left: 0;
        padding-right: 0;
    }

    /* divider tetap halus (opsional, boleh dihapus jika mau) */
    .hero-menu .dropdown-menu li:not(:last-child)::after {
        left: 0;
        right: 0;
        background: rgba(0, 0, 0, 0.08);
    }
}







/* =====================================================
   CABIN GLAMPING – HERO FULLSCREEN
===================================================== */

.cabin-hero {
    position: relative;
    width: 100%;
    height: 100vh;
}

/* BACKGROUND IMAGE */
.cabin-hero-bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    transform: scale(1.02);
}

/* OVERLAY OPTIONAL */
.cabin-hero::after {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.35);
}

/* CONTENT WRAPPER */
.cabin-hero-content {
    position: relative;
    z-index: 2;

    width: 100%;
    height: 100%;

    display: flex;
    align-items: center;
    padding-left: 8%;
}

/* TEXT BOX */
.cabin-hero-box {

background: rgba(35, 90, 61, 0.342); /* 🔥 hijau transparan */

    padding: 48px 44px;
    border-radius: 14px;

    box-shadow:
        0 25px 50px rgba(0, 0, 0, 0.25);
}

/* EYEBROW */
.cabin-eyebrow {
    font-family: 'Norwester';
    font-size: 14px;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: #ffffff;
    display: block;
    margin-bottom: 14px;
}

/* TITLE */
.cabin-title {
    font-family: 'Norwester';
    font-size: 46px;
    font-weight: 600;
    margin-bottom: 16px;
    color: #ffffff;
}

/* DIVIDER */
.cabin-divider {
    width: 200px;
    height: 2px;
    background: #cad351;
}

/* DESCRIPTION */
.cabin-desc {
    font-family: 'Cormorant Garamond', serif;
    font-size: 18px;
    line-height: 1.8;
    color: #ffffff;
}

/* =====================================================
   RESPONSIVE
===================================================== */

/* Tablet */
@media (max-width: 991px) {
    .cabin-hero-content {
        padding-left: 6%;
        padding-right: 6%;
    }

    .cabin-hero-box {
        max-width: 100%;
    }

    .cabin-title {
        font-size: 38px;
    }
}

/* Mobile */
@media (max-width: 576px) {
    .cabin-hero {
        min-height: 100vh;
    }

    .cabin-hero-content {
        align-items: flex-start; 
        padding: 0px;
    }

    .cabin-hero-box {
        padding: 28px 26px;
        border-radius: 12px;
    }

    .cabin-title {
        font-size: 32px;
    }

    .cabin-desc {
        font-size: 16px;
    }
}


/* =====================================================
   CABIN HERO – SPACING DESKTOP ONLY
===================================================== */

@media (min-width: 992px) {

    /* container text di atas image */
    .cabin-hero-content {
        display: flex;
        align-items: flex-start;

        /* 🔼 JARAK ATAS TEXT BOX DARI IMAGE */
        padding-top: 28vh;

        /* 🔽 JARAK BAWAH TEXT BOX KE BATAS IMAGE */
        padding-bottom: 8vh;

        padding-left: 8%;
        padding-right: 0;
    }

    /* ukuran & jarak dalam text box */
    .cabin-hero-box {
        width: 1400px;
 min-height: 540px;   /* 🔥 TINGGI BOX (MINIMAL) *
        /* jarak isi text box */
        padding: 56px 52px;

        /* ❌ jangan pakai height / min-height */
    }
}

.cabin-hero .cabin-title {
    margin-bottom: 0 !important;
}
.cabin-hero .cabin-divider {
    margin-top: 8px;     /* 🔥 jarak dari title */
    margin-bottom: 30px; /* 🔥 jarak ke desc */
}

.cabin-hero-box > * {
    margin-top: 0;
}



/* =====================================================
   CENTER EYEBROW, TITLE & DIVIDER
   TABLET & MOBILE ONLY
===================================================== */

@media (max-width: 991px) {

    /* EYEBROW */
    .cabin-eyebrow {
        text-align: center;
        width: 100%;
    }

    /* TITLE */
    .cabin-title {
        text-align: center;
    }

    /* DIVIDER */
    .cabin-divider {
        margin-left: auto;
        margin-right: auto;
    }
}
@media (max-width: 576px) {
    .cabin-eyebrow {
        margin-bottom: 10px;
    }

    .cabin-title {
        margin-bottom: 14px;
    }

    .cabin-divider {
        margin-bottom: 20px;
    }
}



/* =====================================================
   CABIN DESCRIPTION – JUSTIFY ALL DEVICES
===================================================== */

.cabin-desc {
    text-align: justify;        /* rata kiri-kanan */
    text-justify: inter-word;   /* spasi kata rapi */

    hyphens: auto;              /* pemenggalan kata (browser support) */
    -webkit-hyphens: auto;
    -ms-hyphens: auto;

    margin: 0;                  /* cegah jarak aneh */
}
@media (max-width: 480px) {
    .cabin-desc {
        text-align: justify;
        word-spacing: -0.3px; /* bikin spasi lebih natural */
    }
}



/* =====================================================
   CABIN HERO – CURTAIN REVEAL (PRO)
===================================================== */

/* ===== TEXT BOX BASE ===== */
.cabin-hero-box {
    position: relative;
    overflow: hidden; /* 🔥 WAJIB untuk curtain */
}

/* ===== CURTAIN LAYER ===== */
.cabin-hero-box::before {
    content: "";
    position: absolute;
    inset: 0;

    background: rgba(35, 90, 61, 0.507); /* warna gorden */
    z-index: 5;

    transform: translateX(0);
    transition: transform 1.2s cubic-bezier(0.77, 0, 0.18, 1);
}

/* ===== STATE AWAL TEXT ===== */
.cabin-eyebrow,
.cabin-title,
.cabin-divider,
.cabin-desc {
    opacity: 0;
    transform: translateY(24px);
    transition:
        opacity 0.8s ease,
        transform 0.8s cubic-bezier(0.22, 1, 0.36, 1);
}

/* =====================================================
   SAAT HERO AKTIF
===================================================== */

/* GORDEN TERBUKA */
.cabin-hero.is-visible .cabin-hero-box::before {
    transform: translateX(100%);
}

/* TEXT MUNCUL BERGANTIAN */
.cabin-hero.is-visible .cabin-eyebrow {
    opacity: 1;
    transform: translateY(0);
    transition-delay: 0.9s;
}

.cabin-hero.is-visible .cabin-title {
    opacity: 1;
    transform: translateY(0);
    transition-delay: 1.1s;
}

.cabin-hero.is-visible .cabin-divider {
    opacity: 1;
    transform: translateY(0);
    transition-delay: 1.3s;
}

.cabin-hero.is-visible .cabin-desc {
    opacity: 1;
    transform: translateY(0);
    transition-delay: 1.5s;
}

/* =====================================================
   MOBILE & TABLET – LEBIH RINGAN
===================================================== */
@media (max-width: 991px) {
    .cabin-hero-box::before {
        transition-duration: 1s;
    }

    .cabin-eyebrow,
    .cabin-title,
    .cabin-divider,
    .cabin-desc {
        transform: translateY(18px);
    }
}

@media (max-width: 576px) {
    .cabin-hero-box::before {
        transition-duration: 0.9s;
    }

    .cabin-eyebrow,
    .cabin-title,
    .cabin-divider,
    .cabin-desc {
        transform: translateY(14px);
    }
}


                        /* =====================================================
                                               SECTION END
                        ===================================================== */







/* =====================================================
   BUKIT BENTANG LAND – EXPERIENCE SECTION (FIXED)
===================================================== */

/* ================= SECTION WRAPPER ================= */
.bbl-experience {
    background: #f6f7f6;
    overflow: hidden;
}

/* =====================================================
   EXPERIENCE SECTION – PADDING CONTROL SYSTEM
===================================================== */

:root {
    /* DESKTOP / LAPTOP */
    --bbl-exp-padding-top-desktop: 120px;
    --bbl-exp-padding-bottom-desktop: 40px;

    /* TABLET */
    --bbl-exp-padding-top-tablet: 80px;
    --bbl-exp-padding-bottom-tablet: 10px;

    /* MOBILE */
    --bbl-exp-padding-top-mobile: 40px;
    --bbl-exp-padding-bottom-mobile: 10px;
}

/* ================= TEXT AREA ================= */
.bbl-experience-text {
    max-width: 920px;
    margin: 0 auto;

    padding-top: var(--bbl-exp-padding-top-desktop);
    padding-bottom: var(--bbl-exp-padding-bottom-desktop);
    padding-left: 24px;
    padding-right: 24px;

    text-align: center;
}

@media (max-width: 991px) {
    .bbl-experience-text {
        padding-top: var(--bbl-exp-padding-top-tablet);
        padding-bottom: var(--bbl-exp-padding-bottom-tablet);
    }
}

@media (max-width: 576px) {
    .bbl-experience-text {
        padding-top: var(--bbl-exp-padding-top-mobile);
        padding-bottom: var(--bbl-exp-padding-bottom-mobile);
    }
}

/* ================= TITLE ================= */
.bbl-experience-title {
    font-family: 'Norwester';
    font-size: 42px;
    font-weight: 500;
    letter-spacing: 2px;
    color: #1f2d2b;
    margin-bottom: 16px;
}

/* ================= DIVIDER ================= */
.bbl-experience-divider {
    width: 140px;               /* 🔥 PANJANG GARIS */
    height: 2px;
    background: #cad351;
    margin: 0 auto 32px;
}

/* ================= DESCRIPTION ================= */
.bbl-experience-desc {
    font-family: 'Cormorant Garamond', serif;
    font-size: 18px;
    line-height: 2;
    color: #4a4a4a;

    text-align: justify;
    text-justify: inter-word;
}

.bbl-experience-desc p {
    margin-bottom: 22px;
}

.bbl-experience-desc p:last-child {
    margin-bottom: 0;
}

/* =====================================================
   IMAGE FULL WIDTH (BASE)
===================================================== */

.bbl-experience-image {
    position: relative;
    width: 100vw;
    margin-left: calc(50% - 50vw);
    overflow: hidden;
}

/* =====================================================
   DESKTOP / LAPTOP (≥992px)
   👉 GAMBAR TERPOTONG & BISA DIATUR
===================================================== */

@media (min-width: 992px) {

    .bbl-experience-image {
        height: 1000px;            /* 🔥 ATUR TINGGI FRAME */
    }

    .bbl-experience-image img {
        width: 100%;
        height: 100%;

        object-fit: cover;        /* 🔥 POTONG */
        object-position: center 35%;
        /* ⬆️ ATUR POTONGAN:
           20% = potong atas
           50% = tengah
           70% = potong bawah */
    }
}

/* =====================================================
   TABLET (<992px)
   👉 GAMBAR UTUH
===================================================== */

@media (max-width: 991px) {

    .bbl-experience-image {
        height: auto;
    }

    .bbl-experience-image img {
        width: 100%;
        height: auto;

        object-fit: contain;
        background: #f6f7f6;
    }

    .bbl-experience-title {
        font-size: 34px;
    }
}

/* =====================================================
   MOBILE (<576px)
   👉 GAMBAR UTUH
===================================================== */

@media (max-width: 576px) {

    .bbl-experience-title {
        font-size: 28px;
    }

    .bbl-experience-desc {
        font-size: 16px;
        line-height: 1.9;
    }

    .bbl-experience-image img {
        object-fit: contain;
        background: #f6f7f6;
    }
}



/* ================= IMAGE WRAPPER ================= */
.bbl-experience-image {
    position: relative;
    width: 100vw;
    margin-left: calc(50% - 50vw);
    overflow: hidden;

    /* 🔥 CENTER SYSTEM */
    display: flex;
    align-items: center;
    justify-content: center;
}
.bbl-experience-image {
    position: relative;
    width: 100vw;
    margin-left: calc(50% - 50vw);

    display: flex;                /* 🔥 KUNCI */
    align-items: center;
    justify-content: center;

    overflow: hidden;
}


/* ================= TEXT BOX (GLOBAL) ================= */
.bbl-experience-box {
    position: absolute;          /* 🔥 SATU POSISI UNTUK SEMUA */
    
    width: 100%;
    max-width: 520px;            /* DESKTOP MAX */

    min-height: 280px;           /* 🔥 TINGGI BISA DIATUR */
    padding: 60px 60px;

    background: rgba(46, 79, 59, 0.55);
    
    border-radius: 14px;
    box-shadow: 0 25px 60px rgba(0,0,0,0.25);
    color: #ffffff;

    display: flex;
    flex-direction: column;
    justify-content: center;

    z-index: 2;
}

@media (max-width: 576px) {

    .bbl-experience-box {
        margin: 24px auto;         /* 🔥 ruang napas */
        padding: 26px 22px;
        border-radius: 12px;
    }
}


@media (min-width: 992px) {
    .bbl-experience-box {
        max-width: 620px;
        min-height: 400px;   /* 🔥 ATUR DI SINI */
    }
}



/* =====================================================
   TITLE DI DALAM BOX
===================================================== */

.bbl-box-title {
    font-family: 'Norwester';
    font-size: 40px;
    font-weight: 500;
    letter-spacing: 2px;
    text-align: center;

    margin-bottom: 28px;
    color: #ffffff;
}



/* =====================================================
   LIST DESC (BULLET BULAT)
===================================================== */

.bbl-box-desc {
    width: 100%;
}

/* RESET */
.bbl-box-desc ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

/* ITEM */
.bbl-box-desc li {
    position: relative;
    padding-left: 20px;
    margin-bottom: 12px;

    font-family: 'Cormorant Garamond', serif;
    font-size: 18px;
    line-height: 1.8;
    color: #ffffff;
}

/* BULLET */
.bbl-box-desc li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 11px;

    width: 9px;
    height: 9px;
    border-radius: 50%;
    background: #ffffff;
}



/* =====================================================
   DESKTOP / LAPTOP (≥992px)
   👉 IMAGE BOLEH TERPOTONG
===================================================== */

@media (min-width: 992px) {

    .bbl-experience-image {
        height: 900px;                 /* 🔥 ATUR FRAME */
    }

    .bbl-experience-image img {
        height: 100%;
        object-fit: cover;
        object-position: center 40%;   /* 🔥 ATUR POTONGAN */
    }
}





/* =====================================================
   EXPERIENCE – ANIMATION INITIAL STATE
===================================================== */

/* TEXT AREA (DARI KIRI) */
.animate-exp .bbl-experience-title,
.animate-exp .bbl-experience-divider,
.animate-exp .bbl-experience-desc p {
    opacity: 0;
    transform: translateX(-60px);
}

/* IMAGE (DARI KANAN) */
.animate-exp .bbl-experience-image {
    opacity: 0;
    transform: translateX(80px);
}

/* TEXT BOX (DARI ATAS) */
.animate-exp .bbl-experience-box {
    opacity: 0;
    transform: translateY(-60px);
}

/* LIST ITEM */
.animate-exp .bbl-box-list li {
    opacity: 0;
    transform: translateY(20px);
}


/* =====================================================
   EXPERIENCE – ACTIVE STATE
===================================================== */

.animate-exp.is-visible .bbl-experience-title {
    opacity: 1;
    transform: translateX(0);
    transition: 0.8s ease;
}

.animate-exp.is-visible .bbl-experience-divider {
    opacity: 1;
    transform: translateX(0);
    transition: 0.8s ease;
    transition-delay: 0.15s;
}

.animate-exp.is-visible .bbl-experience-desc p:nth-child(1) {
    opacity: 1;
    transform: translateX(0);
    transition: 0.8s ease;
    transition-delay: 0.3s;
}

.animate-exp.is-visible .bbl-experience-desc p:nth-child(2) {
    opacity: 1;
    transform: translateX(0);
    transition: 0.8s ease;
    transition-delay: 0.45s;
}

/* IMAGE */
.animate-exp.is-visible .bbl-experience-image {
    opacity: 1;
    transform: translateX(0);
    transition: 1.1s cubic-bezier(0.22,1,0.36,1);
    transition-delay: 0.6s;
}

/* TEXT BOX */
.animate-exp.is-visible .bbl-experience-box {
    opacity: 1;
    transform: translateY(0);
    transition: 0.9s cubic-bezier(0.22,1,0.36,1);
    transition-delay: 1s;
}

/* LIST BERGANTIAN */
.animate-exp.is-visible .bbl-box-list li {
    opacity: 1;
    transform: translateY(0);
    transition: 0.6s ease;
}

.animate-exp.is-visible .bbl-box-list li:nth-child(1) { transition-delay: 1.3s; }
.animate-exp.is-visible .bbl-box-list li:nth-child(2) { transition-delay: 1.4s; }
.animate-exp.is-visible .bbl-box-list li:nth-child(3) { transition-delay: 1.5s; }
.animate-exp.is-visible .bbl-box-list li:nth-child(4) { transition-delay: 1.6s; }
.animate-exp.is-visible .bbl-box-list li:nth-child(5) { transition-delay: 1.7s; }
.animate-exp.is-visible .bbl-box-list li:nth-child(6) { transition-delay: 1.8s; }
.animate-exp.is-visible .bbl-box-list li:nth-child(7) { transition-delay: 1.9s; }
.animate-exp.is-visible .bbl-box-list li:nth-child(8) { transition-delay: 2s; }
.animate-exp.is-visible .bbl-box-list li:nth-child(9) { transition-delay: 2.1s; }




                        /* =====================================================
                                               SECTION END
                        ===================================================== */




/* =====================================================
   ROOT SPACING CONTROL
===================================================== */

:root {
    /* DESKTOP */
    --white-padding-top-desktop: 120px;
    --white-padding-bottom-desktop: 60px;

    /* TABLET */
    --white-padding-top-tablet: 80px;
    --white-padding-bottom-tablet: 40px;

    /* MOBILE */
    --white-padding-top-mobile: 60px;
    --white-padding-bottom-mobile: 40px;
}

/* =====================================================
   WHITE SECTION (TEXT AREA SAJA)
===================================================== */

.bbl-white-section {
    background: #ffffff;
    width: 100%;
    overflow-x: hidden; /* 🔥 WAJIB */
}

/* TEXT WRAPPER (AMAN PAKAI MAX-WIDTH) */
.bbl-white-inner {
    max-width: 1200px;
    margin: 0 auto;

    padding-top: var(--white-padding-top-desktop);
    padding-bottom: var(--white-padding-bottom-desktop);
    padding-left: 24px;
    padding-right: 24px;

    text-align: center;
}

@media (max-width: 991px) {
    .bbl-white-inner {
        padding-top: var(--white-padding-top-tablet);
        padding-bottom: var(--white-padding-bottom-tablet);
    }
}

@media (max-width: 576px) {
    .bbl-white-inner {
        padding-top: var(--white-padding-top-mobile);
        padding-bottom: var(--white-padding-bottom-mobile);
    }
}

/* TITLE */
.bbl-white-title {
    font-family: 'Norwester';
    font-size: 42px;
    font-weight: 500;
    letter-spacing: 3px;
    color: #1f2d2b;
}

@media (max-width: 991px) {
    .bbl-white-title {
        font-size: 34px;
    }
}

@media (max-width: 576px) {
    .bbl-white-title {
        font-size: 28px;
    }
}

/* =====================================================
   FULL BLEED GALLERY (100% FIX – NO POTONG)
===================================================== */

/* GLOBAL RESET WAJIB */
html, body {
    margin: 0;
    padding: 0;
    overflow-x: hidden;
}

/* GALLERY ROW (KELUAR TOTAL DARI CONTAINER) */
.bbl-gallery-row {
    position: relative;

    width: 100vw;                /* 🔥 FULL viewport */
    left: 50%;
    right: 50%;
    margin-left: -50vw;          /* 🔥 KUNCI SEBENARNYA */
    margin-right: -50vw;

    padding-top: 40px;
    padding-bottom: 40px;
}

/* IMAGE */
.bbl-gallery-row img {
    width: 100%;
    height: auto;

    display: block;
    object-fit: contain;         /* 🔥 UTUH */
}

/* RESPONSIVE SPACING */
@media (max-width: 991px) {
    .bbl-gallery-row {
        padding-top: 30px;
        padding-bottom: 30px;
    }
}

@media (max-width: 576px) {
    .bbl-gallery-row {
        padding-top: 22px;
        padding-bottom: 22px;
    }
}




/* =====================================================
   FULL WIDTH GALLERY (FIX 100%)
===================================================== */

.bbl-gallery {
    width: 100vw;
    margin-left: calc(50% - 50vw); /* 🔥 KUNCI UTAMA */
    margin-right: calc(50% - 50vw);

    display: flex;
    flex-direction: column;
    gap: 40px;

    padding-bottom: 0px;
}

/* IMAGE ITEM */
.bbl-gallery-item img {
    width: 100%;
    height: auto;
    display: block;
}

/* RESPONSIVE */
@media (max-width: 991px) {
    .bbl-gallery {
        gap: 30px;
        padding-bottom: 40px;
    }

    .bbl-white-title {
        font-size: 34px;
    }
}

@media (max-width: 576px) {
    .bbl-gallery {
        gap: 22px;
        padding-bottom: 30px;
    }

    .bbl-white-title {
        font-size: 28px;
    }
}



:root {
    /* GARIS TITLE – DESKTOP */
    --white-divider-width-desktop: 140px;
    --white-divider-space-top-desktop: 14px;
    --white-divider-space-bottom-desktop: 0px;

    /* TABLET */
    --white-divider-width-tablet: 120px;
    --white-divider-space-top-tablet: 12px;
    --white-divider-space-bottom-tablet: 26px;

    /* MOBILE */
    --white-divider-width-mobile: 90px;
    --white-divider-space-top-mobile: 10px;
    --white-divider-space-bottom-mobile: 22px;
}

.bbl-white-divider {
    width: var(--white-divider-width-desktop);
    height: 2px;
    background: #cad351;

    margin-top: var(--white-divider-space-top-desktop);
    margin-bottom: var(--white-divider-space-bottom-desktop);

    margin-left: auto;
    margin-right: auto;
}


@media (max-width: 991px) {
    .bbl-white-divider {
        width: var(--white-divider-width-tablet);
        margin-top: var(--white-divider-space-top-tablet);
        margin-bottom: var(--white-divider-space-bottom-tablet);
    }
}

@media (max-width: 576px) {
    .bbl-white-divider {
        width: var(--white-divider-width-mobile);
        margin-top: var(--white-divider-space-top-mobile);
        margin-bottom: var(--white-divider-space-bottom-mobile);
    }
}


/* =====================================================
   GALLERY SCROLL ANIMATION (ONLY ANIMATION)
===================================================== */

.anim {
    opacity: 0;
    transition:
        opacity 0.9s ease,
        transform 0.9s cubic-bezier(0.22, 1, 0.36, 1);
    will-change: transform, opacity;
}

/* DIRECTION */
.anim-left {
    transform: translateX(-60px);
}

.anim-right {
    transform: translateX(60px);
}

/* ACTIVE */
.anim-show {
    opacity: 1;
    transform: translateX(0);
}

/* DELAY */
.delay-1 { transition-delay: 0.2s; }
.delay-2 { transition-delay: 0.4s; }
.delay-3 { transition-delay: 0.6s; }
.delay-4 { transition-delay: 0.8s; }

/* MOBILE ADJUST */
@media (max-width: 576px) {
    .anim-left { transform: translateX(-40px); }
    .anim-right { transform: translateX(40px); }
}
