@font-face {
    font-family: "nulshock";
    src: url("/assets/fonts/Nulshock Bd.otf") format("opentype");
    font-weight: normal;
    font-style: normal;
}

@import url("https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap");

/* 
.montserrat-bold {
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;
} */

body h1 {
    font-family: "nulshock", sans-serif;
    font-size: 60px !important;
}

h5 {
    font-family: "montserrat", sans-serif;
}

p {
    font-family: "Montserrat", sans-serif;
    font-weight: 500;
    font-size: 20px;
    max-width: 70%;
}

.btn-animated {
    --baseColor: #f77104;
    --fillerColor: #0294f9;
    --baseTextColor: #fff;
    --hoverTextColor: #fff;

    font-family: "nulshock", sans-serif;

    width: var(--widhtbutton);
    height: var(--heightbutton);

    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;

    background: var(--baseColor);
    color: var(--baseTextColor);
    padding: 8px 24px;
    font-size: 14px;
    border-radius: 50px;
    overflow: hidden;
    position: relative;
    font-weight: 700;
    text-transform: uppercase;
    cursor: pointer;
}

.btn-animated .button__text {
    position: relative;
    z-index: 2;
    transition: color 0.3s ease;
}

.btn-animated .button__filler {
    background: var(--fillerColor);
    position: absolute;
    width: 150%;
    height: 200%;
    border-radius: 50%;
    top: -50%;
    left: -25%;
    transform: translate3d(0, 75%, 0);
    transition: transform 0.3s ease;
    z-index: 1;
}

.btn-animated:hover .button__filler {
    transform: translate3d(0, 0, 0);
}
.btn-animated:hover .button__text {
    color: var(--hoverTextColor);
}

/* Variasi */
.btn-blue {
    --baseColor: #fff;
    --fillerColor: #0294f9;
    --baseTextColor: #000;
    --hoverTextColor: #fff;
    --widhtbutton: 175px;
    --heightbutton: 46px;
    font-size: 10px;
    padding: 4px 15px !important;
    letter-spacing: 2px;
}

.btn-blue-produk {
    --baseColor: #fff;
    --fillerColor: #0294f9;
    --baseTextColor: #000;
    --hoverTextColor: #fff;
    --widhtbutton: 175px;
    --heightbutton: 46px;
    font-size: 10px;
    padding: 4px 15px !important;
    letter-spacing: 2px;
}

.btn-dwn {
    --widhtbutton: 175px;
    --heightbutton: 46px;
    font-size: 10px;
    padding: 4px 15px !important;
    letter-spacing: 2px;
}
.btn-book {
    --widhtbutton: 175px;
    --heightbutton: 46px;
    font-size: 10px !important;
    padding: 4px 15px !important;
    letter-spacing: 2px;
}
.btn-tokopedia {
    --widhtbutton: 175px;
    --heightbutton: 46px;
    font-size: 10px;
    padding: 4px 15px !important;
    letter-spacing: 2px;
}

.btn-shoppee {
    --widhtbutton: 175px;
    --heightbutton: 46px;
    font-size: 10px;
    padding: 4px 15px !important;
    letter-spacing: 2px;
}

.btn-ios {
    --widhtbutton: 90px;
    --heightbutton: 46px;
    font-size: 10px;
    padding: 4px 15px !important;
    letter-spacing: 2px;
}
.btn-andro {
    --widhtbutton: 140px;
    --heightbutton: 46px;
    font-size: 10px;
    padding: 4px 15px !important;
    letter-spacing: 2px;
}
.btn-download-pdf {
    --widhtbutton: 200px;
    --heightbutton: 46px;
    font-size: 10px !important;
    padding: 4px 15px !important;
    letter-spacing: 2px;
}

.btn-corporate {
    --widhtbutton: 190px;
    --heightbutton: 46px;
    font-size: 10px;
    padding: 4px 15px !important;
    letter-spacing: 2px;
}

.btn-brosur {
    --widhtbutton: 190px;
    --heightbutton: 46px;
    font-size: 10px;
    padding: 4px 15px !important;
    letter-spacing: 2px;
}

.btn-download-brosur {
    --widhtbutton: 210px;
    --heightbutton: 46px;
    font-size: 10px;
    padding: 4px 15px !important;
    letter-spacing: 2px;
}
.btn-download-brosur-2 {
    --widhtbutton: 242px;
    --heightbutton: 46px;
    font-size: 10px;
    padding: 4px 15px !important;
    letter-spacing: 2px;
}

.btn-produk {
    --widhtbutton: 175px;
    --heightbutton: 46px;
    font-size: 10px;
    padding: 4px 15px !important;
    letter-spacing: 2px;
}
.btn-karir {
    --widhtbutton: 185px;
    --heightbutton: 46px;
    font-size: 10px;
    padding: 4px 15px !important;
    letter-spacing: 2px;
}

.btn-news {
    --widhtbutton: 215px;
    --heightbutton: 46px;
    font-size: 10px;
    padding: 4px 15px !important;
    letter-spacing: 2px;
}
.btn-deler {
    --widhtbutton: 175px;
    --heightbutton: 46px;
    border-radius: 300px;
    font-size: 12px;
    padding: 4px 15px !important;
    letter-spacing: 2px;
}
.btn-shop-acc {
    --widhtbutton: 175px;
    --heightbutton: 46px;
    font-size: 10px;
    padding: 4px 15px !important;
    letter-spacing: 2px;
}
.btn-shop-acc-2 {
    --widhtbutton: 140px;
    --heightbutton: 46px;
    font-size: 10px;
    padding: 4px 15px !important;
    letter-spacing: 2px;
}
.btn-deler-bawah {
    /* --widhtbutton: 205px; */
    --heightbutton: 46px;
    border-radius: 300px;
    font-size: 10px;
    padding: 4px 15px !important;
    letter-spacing: 2px;
}
.btn-deler-bawah-2 {
    font-size: 12px;
    padding: 4px 11px !important;
    letter-spacing: 0px;
}

.btn-hero {
    --widhtbutton: 175px;
    --heightbutton: 46px;
    font-size: 10px;
    padding: 4px 15px !important;
    letter-spacing: 2px;
}

.btn-lihat {
    --widhtbutton: 150px;
    --heightbutton: 46px;
    font-size: 10px;
    padding: 4px 15px !important;
    letter-spacing: 2px;
}


.btn-tahunan {
    --widhtbutton: 250px;
    --heightbutton: 46px;
    padding: 4px 15px !important;

    letter-spacing: 2px;
    font-size: 10px;
}

.btn-dealer {
    font-size: 10px !important;
    width: 225px !important;
    height: 46px !important;
    letter-spacing: 2px !important;
    padding: 4px 15px !important;
}

.btn-white {
    font-family: "nulshock", sans-serif;
    font-size: 14px;

    background-color: #fff;
    color: black;
    font-weight: 600;
    border-radius: 50px;
    padding: 8px 20px;
    transition: 0.3s ease;
}
.btn-white:hover {
    background-color: #fff;
    color: black;
}

/* ----------------- Navbar ----------------- */
.navbar {
    background: #fff;
    box-shadow: 0px 0px 10px 0px #0000001a;
    transition: 0.3s;
    padding-top: 0rem; /* kecilin jarak atas */
    padding-bottom: 0rem; /* kecilin jarak bawah */
}

.navbar.scrolled {
    box-shadow: 0px 0px 10px 0px #0000001a;
}
.navbar-nav .nav-link {
    position: relative;
    color: #000;
    font-weight: 500;
    margin: 0 8px;
    transition: color 0.3s ease;
    text-decoration: none;
    letter-spacing: 0.5px;
    padding-bottom: 5px;
    font-size: 14px !important;
}

/* bikin underline animasi, tapi exclude dropdown */
.navbar-nav .nav-link::before {
    /* DIUBAH: Hapus :not(.dropdown-toggle) */
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 0%;
    height: 2px;
    background-color: #f77104;
    transition: width 0.3s ease;
    border-radius: 2px;
}

/* hover efek warna */
.navbar-nav .nav-link:hover {
    color: black;
}

/* hover efek garis bawah */
.navbar-nav .nav-link:hover::before {
    /* DIUBAH: Hapus :not(.dropdown-toggle) */
    width: 100%;
}

.navbar-nav .nav-item.dropdown:hover > .nav-link::before {
    /* <-- Ganti ke ::before */
    width: 100%;
}

/* (JANGAN UBAH INI) Hilangkan caret bawaan Bootstrap (ini tetap menargetkan ::after) */
.navbar-nav .dropdown-toggle::after {
    display: none !important;
}

.btn-download {
    background-color: #f97316;
    color: #fff;
    font-weight: 600;
    border-radius: 50px;
    padding: 8px 20px;
    transition: 0.3s ease;
}
.btn-download:hover {
    background-color: #f77104;
    color: #fff;
}
.navbar-brand img {
    height: 70px;
    padding: 12px 0;
}

.dropdown-menu .dropdown-item {
    position: relative;
    padding: 10px 20px;
    font-weight: 500;
    color: #333;
    text-decoration: none;
    transition: color 0.3s ease;
}

.dropdown-menu .dropdown-item::after {
    content: "";
    position: absolute;
    left: 20px; /* biar sejajar sama teks */
    bottom: 5px;
    width: 0%;
    height: 2px;
    background: #f97316;
    transition: width 0.3s ease;
    border-radius: 2px;
}

.dropdown-menu .dropdown-item:hover {
    color: #f97316;
    background-color: transparent; /* hapus bg hover */
}

.dropdown-menu .dropdown-item:hover::after {
    width: calc(100% - 40px); /* panjang garis sesuai padding kiri-kanan */
}

/* ----------------- Hero ----------------- */
.hero-banner {
    position: relative;
    width: 100%;
    height: calc(100vh - 80px); /* kurangi tinggi navbar */
}
.hero-banner .swiper-slide {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    color: #fff;
    height: 100vh;
    background-size: cover;
    background-position: center;
    background-attachment: fixed;
    position: relative;
    padding-bottom: 200px !important;
}
.hero-banner .container {
    position: relative;
    z-index: 2;
}

.slider-product {
    position: relative;
    width: 100%;
    height: 100vh;
}
.slider-product .swiper-slide {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    color: #fff;
    height: 100vh;
    background-size: cover;
    background-position: center;
    position: relative;
}
.slider-product .container {
    position: relative;
    z-index: 2;
}

/* ----------------- Swiper Scrollbar ----------------- */
.swiper-scrollbar {
    background: rgba(255, 255, 255, 0.2) !important;
    height: 3px !important;
    border-radius: 10px;
    bottom: 30px !important;

    /* ini bagian penting buat memendekkan scrollbar */
    width: 100% !important; /* ubah sesuai kebutuhan, misal 50% atau 70% */
    left: auto !important; /* Hapus positioning left yang tidak perlu */
    right: auto !important; /* Hapus positioning left yang tidak perlu */
}

.swiper-scrollbar-drag {
    background: white !important;
    border-radius: 10px;
}

/* Buttons slide */

.btn-white {
    background-color: #fff;
    color: #000;
    border-radius: 50px;
    padding: 10px 25px;
}
.btn-white:hover {
    background-color: #f0f0f0;
}

.fitur-unggulan {
    margin-bottom: 120px;
}

#tahunan {
    margin-bottom: 150px;
    margin-top: 150px;
}

#tahunan .persen h3 {
    font-family: "nulshock", sans-serif !important;
    font-size: 50px !important;
}

#tahunan .persen h5 {
    font-family: "montserrat", sans-serif !important;
    font-size: 20px !important;
    font-weight: 500;
    color: #6e7887;
    line-height: 10px;
}

.persen {
    margin-top: 100px;
}

.map h2 {
    font-family: "nulshock", sans-serif;
    font-size: 40px;
}

.map p {
    font-family: "montserrat", sans-serif;
    font-size: 20px;
    color: #6e7887;
}

/* MAP CONTAINER (Tidak banyak berubah, hanya memastikan border-radius) */
#map {
    height: 600px;
    width: 100%;
    border-radius: 2rem; /* Sedikit lebih kecil agar lebih elegan */
}

/* POPUP CONTENT */
.popup-content {
    font-family: "Poppins", sans-serif; /* Ganti dengan font modern (jika dimuat) */
    max-width: 280px; /* Lebar sedikit lebih besar */
    padding: 5px;
    line-height: 1.5;
}

.popup-content h4 {
    margin: 0 0 5px;
    font-size: 18px; /* Judul lebih besar */
    font-weight: 700; /* Lebih tebal */
    color: #333333; /* Warna gelap */
}

.popup-content p {
    margin: 0 0 3px;
    font-size: 14px;
    color: #555555;
}

.popup-content p b {
    color: #f26522; /* Highlight 'Dealer' dengan warna brand (misal: oranye) */
    font-weight: 600;
}

/* TOMBOL KONSULTASI YANG LEBIH CERAH */
.btn-consult {
    display: block; /* Membuat tombol selebar popup */
    margin-top: 12px; /* Margin atas lebih besar */
    padding: 8px 15px; /* Padding lebih besar */

    /* Warna Cerah */
    background-color: #f26522; /* Warna Oranye Khas */
    border: 1px solid #f26522;
    border-radius: 8px; /* Sudut sedikit melengkung */

    /* Teks */
    text-decoration: none;
    color: #ffffff !important; /* Teks putih */
    font-size: 14px;
    font-weight: bold;
    text-align: center;

    /* Efek Bayangan */
    box-shadow: 0 4px 8px rgba(242, 101, 34, 0.3);
    transition: all 0.3s ease;
}

.btn-consult:hover {
    background: #d65a1e; /* Warna oranye lebih gelap saat hover */
    border-color: #d65a1e;
    box-shadow: 0 6px 12px rgba(242, 101, 34, 0.4);
    transform: translateY(-1px); /* Efek sedikit naik */
}

.swiper {
    width: 100%;
    height: 100%;
}

.swiper-slide img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

#slider-product {
    margin-left: 3rem;
}

#slider-product .swiper-slide {
    width: 60%;
    margin-top: 50px;
    margin-bottom: 70px;
    margin-left: 5px;
}

.testimoni {
    background-color: #f5f6f7; /* warna background full */
    width: 100%; /* biar full mentok kiri kanan */
}

.text-orange {
    color: #f26522; /* warna teks oranye */
}

.quote-bg {
    position: absolute;
    top: 7px;
    left: -40px;
    color: rgba(0, 0, 0, 0.05);
    z-index: 0;
}

.testimoni h2 {
    position: relative;
    z-index: 1; /* biar teks di atas petik */
    font-family: "montserrat", sans-serif !important;
    font-size: 50px;
    margin-top: 45px;
    margin-bottom: 25px;
}

.testimonial-swiper .swiper-slide img {
    display: block;
    width: 60px;
    height: 60px;
    object-fit: cover;
}

/* --- Gaya Dasar untuk Tombol Navigasi Swiper --- */
.my-swiper-button-prev,
.my-swiper-button-next {
    --baseColor: #ffffff;
    --fillerColor: #0294f9;
    --iconColor: #333333;
    --hoverIconColor: #ffffff;

    width: 46px;
    height: 46px;
    border-radius: 50%;
    background: var(--baseColor);
    border: 1px solid black;
    color: var(--iconColor);
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
    position: relative;
    overflow: hidden;
    transition: color 0.3s ease, border-color 0.3s ease;
}

/* filler animasi bulat */
.my-swiper-button-prev::before,
.my-swiper-button-next::before {
    content: "";
    position: absolute;
    width: 200%;
    height: 200%;
    border-radius: 50%;
    top: -50%;
    left: -50%;
    background: var(--fillerColor);
    transform: translate3d(0, 75%, 0);
    transition: transform 0.3s ease;
    z-index: 1;
}

/* biar icon tetap di atas filler */
.my-swiper-button-prev i,
.my-swiper-button-next i {
    position: relative;
    z-index: 2;
    font-size: 16px;
}

/* Hover efek */
.my-swiper-button-prev:hover::before,
.my-swiper-button-next:hover::before {
    transform: translate3d(0, 0, 0);
}

.my-swiper-button-prev:hover,
.my-swiper-button-next:hover {
    color: var(--hoverIconColor);
    border-color: var(--fillerColor);
}

/* Disabled state */
.my-swiper-button-prev.swiper-button-disabled,
.my-swiper-button-next.swiper-button-disabled {
    opacity: 0.4;
    pointer-events: none;
}

/* --- Style untuk H6 (Tanggal) --- */
.daleman .news-date {
    font-family: "montserrat", sans-serif !important;
    font-size: 14px;
    letter-spacing: 0.5px;
    color: #98a1ae;
    /* Menghapus !important karena class lebih spesifik daripada tag h6 biasa */
}

/* --- Style untuk H3 (Judul Utama) --- */
.daleman .news-title {
    font-size: 18px;
    margin-bottom: 10px;
}

/* --- Style untuk H4 (Deskripsi Singkat) --- */
.daleman .news-description {
    font-family: "montserrat", sans-serif;
    color: #6e7887;
    font-size: 16px;
    line-height: 24px;
    letter-spacing: 0.5px;
    /* Menghapus !important */
}

/* Gaya Khusus Section Hero */
.hero-section {
    max-height: 100%; /* Tinggi minimum yang besar */
    position: relative;
    overflow: hidden; /* Penting untuk menangani background text 'DOWNLOAD' */
}

.mockup-img {
    width: 100%;
    height: auto;
    /* Tambahkan bayangan jika perlu */
}

/* Background Teks Besar 'DOWNLOAD' (opsional) */
.hero-section::before {
    content: "DOWNLOAD";
    position: absolute;
    font-family: "nulshock", sans-serif;
    top: 50px;
    right: 0;
    font-size: 13.7vw;
    font-weight: 900;
    color: #f3f5f6;
    z-index: 0;
    white-space: nowrap;
}

footer h5 {
    font-family: "nulshock", sans-serif;
    color: white;
    font-size: 15px;
}

footer ul {
    list-style: none; /* Hilangin bullet/titik */
    padding-left: 0; /* Hilangin indent bawaan */
    margin: 0;
}
footer a {
    color: #46515d;
    text-decoration: none;
    transition: color 0.3s ease;
    font-weight: 600;
}
footer a:hover {
    color: #ffffff;
}
.social-icons a {
    position: relative;
    border-radius: 50%;
    width: 40px;
    height: 40px;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    background-color: #46515d;
    color: #fff;
    text-decoration: none;
    overflow: hidden;
    transition: color 0.3s ease;
    margin-left: 2px;
}

.social-icons a::before {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 0%;
    background-color: #0294f9;
    z-index: 0;
    transition: height 0.3s ease;
    border-radius: 50%;
}

.social-icons a:hover::before {
    height: 100%;
}

/* Semua child element di atas background */
.social-icons a > * {
    position: relative;
    z-index: 1;
}

.social-icons a:hover {
    color: #fff; /* biar ikon tetap putih */
}

.subscription-form {
    position: relative;
    width: 100%;
}

.subscribe-input {
    border-radius: 50px;
    border: none;
    padding: 12px 50px 12px 20px; /* kanan dilebarin biar ada ruang tombol */
    width: 100%;
}

.subscribe-btn {
    position: absolute;
    top: 50%;
    right: 5px;
    transform: translateY(-50%);
    border-radius: 50%;
    background-color: #f77104;
    border: none;
    width: 40px;
    height: 40px;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;

    overflow: hidden; /* biar efeknya ketutup lingkaran */
    transition: transform 0.3s ease, color 0.3s ease;
}

/* pseudo-element buat animasi isi bawah ke atas */
.subscribe-btn::before {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 0%;
    background-color: #0294f9;
    z-index: 0;
    transition: height 0.3s ease;
    border-radius: 50%;
}

.subscribe-btn:hover::before {
    height: 100%;
}

/* biar ikon/teks di atas lapisan */
.subscribe-btn i,
.subscribe-btn span {
    position: relative;
    z-index: 1;
}

/* animasi tambahan pas hover */
.subscribe-btn:hover {
    transform: translateY(-50%) scale(1.05);
    color: #fff;
}
.floating-menu-container {
    position: fixed;
    bottom: 30px;
    right: 30px;
    z-index: 1000;
}

/* MENU LIST */
.floating-menu-list {
    list-style: none;
    padding: 0;
    margin: 0;
    background-color: #0294f9;
    border-radius: 30px;
    overflow: visible;
    max-height: 60px;
    transition: max-height 0.4s ease-out;
}

/* ITEM MENU */
.floating-menu-list li {
    padding: 15px 0;
    text-align: center;
}

/* LINK UMUM */
.floating-menu-list li a {
    color: white;
    font-size: 18px;
    display: block;
    text-decoration: none;
    position: relative;
}

/* Tooltip untuk menu-item */
.floating-menu-list .menu-item a::after {
    content: attr(data-label);
    font-family: "Montserrat", sans-serif;
    position: absolute;
    letter-spacing: 0.5px;
    right: 110%;
    top: 50%;
    transform: translateY(-50%);
    background: white;
    color: black;
    font-size: 14px;
    padding: 6px 12px;
    border-radius: 20px;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s ease, transform 0.2s ease;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
}

.floating-menu-list .menu-item a:hover::after {
    opacity: 1;
    transform: translateY(-50%) translateX(-5px);
}

/* ========== TAMBAHKAN INI: Tooltip untuk FAB button ========== */
.floating-menu-list .menu-fab a::after {
    content: attr(data-label);
    font-family: "Montserrat", sans-serif;
    position: absolute;
    letter-spacing: 0.5px;
    right: 110%;
    top: 50%;
    transform: translateY(-50%);
    background: white;
    color: black;
    font-size: 14px;
    padding: 6px 12px;
    border-radius: 20px;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s ease, transform 0.2s ease;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
}

.floating-menu-list .menu-fab a:hover::after {
    opacity: 1;
    transform: translateY(-50%) translateX(-5px);
}
/* ========== AKHIR TAMBAHAN ========== */

/* Garis putih antar item */
.floating-menu-list .menu-item {
    border-bottom: 1px solid rgba(255, 255, 255, 0.4);
}

.floating-menu-list .menu-item:last-of-type {
    border-bottom: none;
}

/* FAB di bawah */
.menu-fab {
    background: #0294f9;
    border-radius: 50%;
    width: 60px;
    height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: auto;
}

.menu-fab a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    color: white;
}

.menu-fab img {
    transition: transform 0.3s ease;
}

.floating-menu-container.open .menu-fab img {
    transform: rotate(180deg);
}

/* Sembunyikan item selain FAB saat tertutup */
.floating-menu-list .menu-item {
    display: none;
}

/* OPEN STATE */
.floating-menu-container.open .floating-menu-list {
    max-height: 400px;
    border-radius: 30px;
}

.floating-menu-container.open .floating-menu-list .menu-item {
    display: block;
}

.floating-menu-container.open .menu-fab i:before {
    content: "\f00d";
}


@media (max-width: 768px) {
    .h1-benner {
        font-size: 32px !important;
    }
    .news {
        margin-top: 3rem;
        padding: 0 1rem;
    }

    .news .container-fluid {
        padding: 0;
    }

    .news .row.mx-4 {
        margin-left: 0 !important;
        margin-right: 0 !important;
        margin-bottom: 1.5rem;
    }

    /* Header Section */
    .news .d-flex.justify-content-between {
        flex-direction: column;
        gap: 1rem;
    }

    .news h2 {
        font-family: "nulshock", sans-serif !important;
        letter-spacing: 1px;
        font-size: 1.5rem;
        line-height: 1.3;
    }

    /* Navigation Controls - Mobile */
    .news .d-flex.align-items-center {
        justify-content: space-between;
        width: 100%;
    }

    .news .my-swiper-button-prev,
    .news .my-swiper-button-next {
        cursor: pointer;
        font-size: 1.2rem;
        width: 35px;
        height: 35px;
        display: flex;
        align-items: center;
        justify-content: center;
        background: #f0f0f0;
        border-radius: 50%;
        transition: all 0.3s ease;
    }

    .news .my-swiper-button-prev:hover,
    .news .my-swiper-button-next:hover {
        background: #007bff;
        color: white;
    }

    .news .my-swiper-button-prev {
        margin-right: 0.5rem;
    }

    .news .my-swiper-button-next {
        margin-right: 0.5rem;
    }

    /* Button Lihat Semua - Mobile */
    .news .btn-lihat {
        padding: 0.5rem 1rem;
        font-size: 0.9rem;
    }

    /* Swiper Slides - Mobile */
    .news .swiper-slide {
        padding: 0 0.5rem;
    }

    .news .swiper-slide img {
        border-radius: 1rem;
        width: 100%;
        height: 200px;
        object-fit: cover;
    }

    /* Content Inside Slide */
    .news .daleman {
        margin-top: 1rem;
        padding: 0 0.5rem;
    }

    .news .news-date {
        font-size: 0.75rem;
        color: #666;
        margin-bottom: 0.5rem;
    }

    .news .news-title {
        font-size: 1rem;
        line-height: 1.4;
        margin-bottom: 0.5rem;
    }

    .news .news-title a {
        color: inherit;
        text-decoration: none;
        transition: color 0.3s ease;
        display: block;
    }

    .news .news-title a:hover {
        color: #007bff;
    }

    .news .news-description {
        font-size: 0.85rem;
        line-height: 1.5;
        color: #666;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }

    #tahunan {
        padding: 2rem 0;
        background: #fff;
    }

    #tahunan .container {
        padding: 0 1rem;
    }

    #tahunan .row.mt-5 {
        margin-top: 2rem !important;
    }

    #tahunan .row.mb-5 {
        margin-bottom: 1rem !important;
    }

    /* Title Section */
    #tahunan .text-center h5 {
        font-size: 14px !important;
        color: #f97316;
        margin-bottom: 0.5rem;
    }

    #tahunan .text-center h2 {
        font-family: "nulshock", sans-serif;
        font-size: 3rem;
        letter-spacing: 3px;
        margin-bottom: 0.5rem;
        line-height: 1;
    }

    #tahunan .text-center h3 {
        font-family: "nulshock", sans-serif;
        font-size: 1.2rem;
        line-height: 1.5;
        letter-spacing: 3px;
        margin-top: 0.5rem;
    }

    /* Percentage Stats Section - Mobile (Vertical Stack) */
    #tahunan .persen {
        flex-direction: column;
        gap: 2rem;
        margin-top: 2rem;
    }

    #tahunan .persen .col-3 {
        width: 100%;
        max-width: 300px;
        margin: 0 auto;
        border-right: none !important;
        border-left: none !important;
        border-bottom: 2px solid #d1d5db;
        padding-bottom: 1.5rem;
    }

    #tahunan .persen .col-3:last-child {
        border-bottom: none;
        padding-bottom: 0;
    }

    #tahunan .persen .text-center h3 {
        font-size: 2.5rem;
        letter-spacing: 2px;
        margin-bottom: 0rem;
        font-weight: bold;
    }

    #tahunan .persen .text-center h3 .counter {
        color: #000;
    }

    #tahunan .persen .text-center h3 span[style*="color: #f97316"] {
        color: #f97316 !important;
    }

    #tahunan .persen .text-center h5 {
        font-size: 14px !important;
        color: #666;
        line-height: 1.4;
        margin-top: 0rem;
    }

    /* Button */
    #tahunan center.mt-2 {
        margin-top: 1.5rem !important;
    }

    #tahunan .btn-tahunan {
        margin-top: 2rem !important;
        padding: 0.875rem 1.5rem !important;
        font-size: 0.7rem !important;
        display: inline-block;
        text-decoration: none;
        letter-spacing: 1px;
    }

    /* ==================== NAVBAR MOBILE STYLES (Default) ==================== */
    .navbar {
        padding: 0.75rem 0;
        box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
    }

    .navbar .container-fluid {
        margin-left: 0 !important;
        margin-right: 0 !important;
        padding: 0 1rem !important;
    }

    /* Logo */
    .navbar-brand img {
        max-width: 140px;
        height: auto;
    }

    /* Toggler */
    .navbar-toggler {
        border: none;
        padding: 0.5rem;
    }

    .navbar-toggler:focus {
        box-shadow: none;
        outline: none;
    }

    .navbar-toggler-icon {
        width: 25px;
        height: 20px;
    }

    /* Mobile Menu */
    .navbar-collapse {
        background: white;
        margin-top: 1rem;
        padding: 1rem 0;
    }

    .navbar-nav {
        width: 100%;
    }

    .navbar-nav .nav-item {
        padding: 0.5rem 0;
        border-bottom: 1px solid #f0f0f0;
    }

    .navbar-nav .nav-item:last-child {
        border-bottom: none;
    }

    .navbar-nav .nav-link {
        padding: 0.5rem 1rem !important;
        font-size: 16px;
        color: #333;
        transition: color 0.3s ease;
    }

    .navbar-nav .nav-link:hover,
    .navbar-nav .nav-link.active {
        color: #f97316 !important;
    }

    /* Dropdown */
    .navbar-nav .dropdown-toggle::after {
        display: none;
    }

    .navbar-nav .dropdown-toggle i {
        font-size: 14px;
        transition: transform 0.3s ease;
    }

    .navbar-nav .dropdown-toggle[aria-expanded="true"] i {
        transform: rotate(180deg);
    }

    .dropdown-menu {
        border: none;
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
        margin-top: 0.5rem;
        padding: 1rem;
    }

    .dropdown-menu li {
        display: block !important;
        margin: 0.5rem 0 !important;
    }

    .dropdown-menu li img {
        max-width: 120px;
        height: auto;
        transition: transform 0.3s ease;
    }

    .dropdown-menu li img:hover {
        transform: scale(1.05);
    }

    /* Hide download button on mobile */
    .navbar .d-none.d-lg-block {
        display: none !important;
    }

    /* ==================== HERO BANNER MOBILE STYLES ==================== */
    .hero-banner {
        margin-top: 0;
    }

    .heroSwiper {
        height: 100vh;
        min-height: 100%;
    }

    .heroSwiper .swiper-slide {
        position: relative;
        display: flex;
        align-items: start;
        background-size: cover !important;
        background-position: start !important;
        padding: 3rem 1rem !important;
        
    }

    /* Dark overlay for better text readability */
    .heroSwiper .swiper-slide::before {
        content: "";
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        z-index: 1;
    }

    .heroSwiper .swiper-slide .container {
        position: relative;
        z-index: 2;
        padding: 0 1.5rem;
    }

    .heroSwiper .swiper-slide .col-md-7 {
        width: 100%;
        max-width: 100%;
    }

    /* Hero Text */
    .heroSwiper h1 {
        font-size: 2rem !important;
    }

    .heroSwiper p {
        font-family: "montserrat", sans-serif !important;
        font-weight: 400 !important;
        font-size: 14px !important;
        max-width: 100% !important;
        color: white;
        margin-bottom: 1.5rem;
        line-height: 1.6;
    }

    /* Hero Buttons */
    .heroSwiper .btn-animated {
        padding: 0.875rem 1.5rem !important;
        font-size: 10px;
        margin-bottom: 0.75rem;
        display: block;
        width: 100%;
        max-width: 180px;
        text-align: center;
    }

    .heroSwiper .btn-hero {
        margin-right: 0 !important;
    }

    /* Swiper Scrollbar */
    .heroSwiper .swiper-scrollbar {
        background: rgba(255, 255, 255, 0.3);
        height: 4px;
        border-radius: 10px;
        margin-top: 2rem;
        position: relative;
        bottom: 30px;
    }

    .heroSwiper .swiper-scrollbar-drag {
        background: #f97316;
        border-radius: 10px;
    }

    .btn-produk {
        --widhtbutton: 160px;
        --heightbutton: 40px;
        font-size: 9px;
    }

    .btn-blue-produk {
        --widhtbutton: 160px;
        --heightbutton: 40px;
        font-size: 9px;
    }

    .btn-news-mobile{
        --widhtbutton: 150px;
        --heightbutton: 40px;
        font-size: 10px;
        letter-spacing: 1px;
    }

    #map{
        height: 400px !important;
        border-radius: 0rem !important;
    }

}

