/* ==========================================================================
   1. GAYA GLOBAL & DASAR
   ========================================================================== */

/* Mengimpor jenis huruf dari Google Fonts */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;600;700&display=swap');

/* Pengaturan dasar untuk seluruh halaman */
body {
    font-family: 'Poppins', sans-serif; /* Mengatur jenis huruf utama */
    margin: 0;                          /* Menghilangkan margin bawaan browser */
    background-color: #f4f7f9;          /* Warna latar belakang abu-abu terang untuk seluruh halaman */
    color: #333333;                     /* Warna teks utama */
}

/* ==========================================================================
   2. HEADER (BAGIAN ATAS HALAMAN)
   ========================================================================== */

/* Wadah utama header yang akan menempel di atas */
header {
    position: sticky; /* Membuat header "menempel" saat digulir */
    top: 0;           /* Posisi menempelnya di paling atas layar */
    z-index: 1000;    /* Memastikan header selalu di atas konten lain */
    width: 100%;      /* Lebar header selalu penuh */
}

/* --- Baris Atas Header (Logo & Nama Program) --- */
/* --- Baris Atas Header (Logo & Nama Program) --- */
.header-top {
    background-color: #ffffff;
    padding: 0 15%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1); /* Bayangan halus di bawah kotak logo */
    border-bottom: 2px solid #0A4D8C; /* <-- TAMBAHKAN BARIS INI */
}

.logo-background {
    background-color: white;   /* Kotak putih di belakang logo */
    padding: 0.5rem 1rem;      /* Jarak di dalam kotak logo */

}

.logo-background a {
    display: flex;         /* Membuat logo-logo di dalamnya berbaris rapi */
    align-items: center;   /* Menyejajarkan logo secara vertikal */
    gap: 15px;             /* Jarak antar logo */
}

.logo-background img {
    height: 40px;          /* Mengatur tinggi standar untuk semua logo */
}

/* Kustomisasi khusus untuk logo PPM BEM agar menjadi lingkaran */
.logo-background img[src*="logo.jpg"] {
    width: 40px;               /* Paksa lebar agar sama dengan tinggi */
    height: 40px;              /* Paksa tinggi agar sama dengan lebar */
    border-radius: 50%;        /* Mengubah bentuk menjadi lingkaran sempurna */
    object-fit: cover;         /* Memastikan gambar tidak gepeng di dalam lingkaran */
}

.program-name-top h3 {
    margin: 0;                 /* Menghilangkan margin bawaan */
    font-size: 1.9rem;         /* Ukuran teks nama program */
    color: #0A4D8C;            /* Warna biru modern */
}

/* --- Baris Bawah Header (Menu Navigasi) --- */
.header-main {
    background-color: white;   /* Latar belakang putih untuk menu */
    box-shadow: 0 2px 5px rgba(0,0,0,0.1); /* Bayangan halus di bawah menu */
    display: flex;             /* Menggunakan flexbox */
    justify-content: center; /* Menempatkan menu di tengah halaman */
}

.header-main ul {
    list-style: none; /* Menghilangkan bulatan/angka dari daftar */
    margin: 0;        /* Menghilangkan margin bawaan */
    padding: 0;       /* Menghilangkan padding bawaan */
    display: flex;    /* Membuat item menu berbaris horizontal */
}

.header-main ul li a {
    display: block;                  /* Mengubah link menjadi elemen blok agar bisa diberi padding */
    padding: 1.2rem 1.5rem;          /* Jarak di dalam setiap item menu */
    text-decoration: none;           /* Menghilangkan garis bawah dari link */
    color: #002f70;                     /* Warna teks menu */
    font-weight: bold;               /* Menebalkan teks menu */
    border-bottom: 3px solid transparent; /* Garis bawah transparan sebagai dasar animasi */
    transition: color 0.3s ease, border-bottom-color 0.3s ease; /* Transisi halus saat di-hover */
}

.header-main ul li a:hover {
    color: #FF6B00;              /* Warna teks berubah menjadi oranye saat disentuh */
    border-bottom-color: #FF6B00; /* Garis bawah muncul dengan warna oranye saat disentuh */
}

/* ================================= */
/* GAYA UNTUK NAVIGASI STICKY        */
/* ================================= */
.header-main.sticky {
    position: fixed; /* Membuat navigasi "mengambang" dan keluar dari alur normal */
    top: 0;          /* Posisi menempelnya di paling atas */
    left: 0;         /* Posisi menempelnya di paling kiri */
    width: 100%;     /* Lebarnya penuh saat menempel */
}

/* ================================= */
/* HERO SECTION BARU (DENGAN SLIDER) */
/* ================================= */

/* Wadah utama hero section */
.hero {
    height: 85vh;
    position: relative; /* Diperlukan agar slider dan konten bisa ditumpuk */
    display: flex;
    align-items: center;
    justify-content: flex-start;
    padding: 0 5%;
    overflow: hidden; /* Mencegah gambar keluar dari batas */
}

/* Wadah untuk semua gambar slide */
.hero-slider {
    position: absolute; /* Membuatnya bisa ditumpuk di belakang konten */
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0; /* Posisinya di paling belakang */
}

/* Gaya untuk setiap gambar slide */
.slide {
    position: absolute; /* Membuat semua slide bertumpuk di posisi yang sama */
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    opacity: 0; /* Secara default, semua slide disembunyikan */
    transition: opacity 1.5s ease; /* EFEK FADE: transisi halus selama 1.5 detik */
}

/* Gaya untuk slide yang sedang aktif/terlihat */
.slide.active {
    opacity: 1; /* Slide yang aktif akan terlihat */
}

/* Lapisan gelap agar teks lebih terbaca */
.hero::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.4);
    z-index: 1; /* Posisinya di atas gambar, tapi di bawah teks */
}

/* Kotak konten di dalam hero section */
.hero-content {
    background-color: rgba(255, 255, 255, 0.5); /* transparansi 80% */
    padding: 2.5rem;
    border-radius: 10px;
    max-width: 550px;
    z-index: 2; /* Posisinya di paling depan agar bisa diklik */
    box-shadow: 0 10px 20px rgba(0,0,0,0.1);
}

.hero-content h1 {
    font-size: 2.8rem;
    color: #0A4D8C;
    margin: 0 0 1rem 0;
    line-height: 1.2;
}

.hero-content p {
    font-size: 1.1rem;
    margin-bottom: 2rem;
}

.hero-button {
    background-color: #FF6B00;
    color: white;
    padding: 1rem 2rem;
    text-decoration: none;
    font-weight: bold;
    border-radius: 5px;
    transition: background-color 0.3s ease;
}

.hero-button:hover {
    background-color: #D95B00;
}
/* ==========================================================================
   4. GAYA PER HALAMAN
   ========================================================================== */

/* --- Homepage: Seksi Statistik (Kuning) & Dukungan (Abu-abu) --- */
.container {
    max-width: 1200px; /* Lebar maksimum konten di dalamnya */
    margin: 0 auto;    /* Membuatnya berada di tengah */
    padding: 0 2rem;   /* Jarak di kiri dan kanan */
}

.stats-section {
    background-color: #f1c40f; /* Warna latar kuning emas */
    color: #333;
    padding: 4rem 0;
    text-align: center;
}

.stats-section .container {
    display: flex;
    flex-wrap: wrap;          /* Memungkinkan item pindah ke baris baru jika tidak muat */
    justify-content: space-around; /* Menyebar item secara merata */
}

.stats-item {
    min-width: 200px; /* Lebar minimum setiap item statistik */
    margin: 1rem;
}

.stats-item h2 {
    font-size: 3.5rem;
    margin: 0 0 0.5rem 0;
    color: #0A4D8C;
}

.stats-item h4 {
    font-size: 1rem;
    margin: 0 0 0.5rem 0;
}

/* Garis pemisah kecil di bawah subjudul statistik */
.stats-item h4::after {
    content: '';
    display: block;
    width: 40px;
    height: 3px;
    background-color: #0A4D8C;
    margin: 0.75rem auto; /* Jarak atas/bawah dan di tengah */
}

.stats-item p {
    font-size: 0.9rem;
}

.accreditation-section {
    background-color: #f4f7f9; /* Latar abu-abu terang */
    padding: 4rem 0;
    text-align: center;
}

.accreditation-section h2 {
    margin-top: 0;
    font-size: 2rem;
}

/* --- Homepage: Kartu Program Dukungan --- */
.product-container {
    display: flex;
    flex-wrap: wrap;
    gap: 1.5rem; /* Jarak antar kartu */
    justify-content: center;
}

.product-card {
    background-color: white;
    border-radius: 10px;
    box-shadow: 0 4px 8px rgba(0,0,0,0.1);
    width: 300px;
    display: flex;
    flex-direction: column; /* Konten disusun dari atas ke bawah */
    transition: transform 0.3s ease;
    padding: 1rem;
    box-sizing: border-box;
}

.product-card:hover {
    transform: translateY(-5px); /* Efek terangkat saat disentuh */
}

.product-card img {
    width: 100%;
    height: 180px;
    object-fit: cover;
    border-radius: 8px;
    margin-bottom: 1rem;
}

.product-card h3 {
    font-size: 1.2rem;
    margin: 0 0 0.5rem 0;
    color: #0A4D8C;
}

.product-card .description {
    font-size: 0.9rem;
    margin: 0 0 1rem 0;
    flex-grow: 1; /* Memastikan deskripsi mengisi ruang kosong, sehingga tombol selalu di bawah */
}

.product-card .price {
    font-size: 1.1rem;
    font-weight: bold;
    color: #28a745; /* Warna hijau untuk harga */
    margin: 0 0 1rem 0;
}

.product-card .cta-button {
    background-color: #FF6B00;
    color: white;
    border: none;
    padding: 0.8rem;
    border-radius: 5px;
    cursor: pointer;
    font-weight: bold;
    transition: background-color 0.3s ease;
    width: 100%;
}

.product-card .cta-button:hover {
    background-color: #D95B00;
}

/* --- Halaman About Us: Kartu Profil Tim --- */
.team-container {
    display: flex;
    flex-wrap: wrap;
    gap: 1.5rem;
    justify-content: center;
    margin-top: 1.5rem;
}

.team-card {
    background-color: #f4f4f9;
    border-radius: 10px;
    box-shadow: 0 4px 6px rgba(0,0,0,0.05);
    width: 200px;
    padding: 1.5rem;
    text-align: center;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.team-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 12px rgba(0,0,0,0.1);
}

.team-card img {
    width: 100px;
    height: 100px;
    border-radius: 50%;
    object-fit: cover;
    border: 4px solid white;
    box-shadow: 0 2px 4px rgba(0,0,0,0.1);
    margin-bottom: 1rem;
}

.team-card strong {
    display: block;
    font-size: 1.1rem;
    color: #0A4D8C;
    margin-bottom: 0.25rem;
}

.team-card span {
    font-size: 0.9rem;
    color: #555;
}

/* --- Halaman Products: Kartu Pameran Produk --- */
.showcase-container {
    display: flex;
    flex-wrap: wrap;
    gap: 1.5rem;
    justify-content: center;
}

.showcase-card {
    background-color: #FFFFFF;
    border-radius: 10px;
    box-shadow: 0 4px 8px rgba(0,0,0,0.05);
    width: 300px;
    padding: 1.5rem;
    text-align: center;
    border: 1px solid #eee;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.showcase-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 15px rgba(0,0,0,0.1);
}

.showcase-card img {
    width: 100%;
    height: 200px;
    object-fit: cover;
    border-radius: 8px;
    margin-bottom: 1rem;
}

.showcase-card h4 {
    font-size: 1.4rem;
    color: #0A4D8C;
    margin: 0 0 0.5rem 0;
}

.showcase-card p {
    font-size: 0.95rem;
    color: #555;
    line-height: 1.6;
}

/* --- Halaman Shop: Kartu Produk Jualan --- */
.shop-container {
    display: flex;
    flex-wrap: wrap;
    gap: 1.5rem;
    justify-content: center;
}

.shop-card {
    background-color: #FFFFFF;
    border-radius: 10px;
    box-shadow: 0 4px 8px rgba(0,0,0,0.05);
    width: 300px;
    text-align: center;
    overflow: hidden; /* Agar tombol bisa menempel di bawah tanpa merusak sudut */
    border: 1px solid #eee;
    display: flex;
    flex-direction: column;
}

.shop-card img {
    width: 100%;
    height: 200px;
    object-fit: cover;
}

.shop-card h4 {
    font-size: 1.5rem;
    color: #0A4D8C;
    margin: 1rem 0 0.5rem 0;
}

.shop-card .shop-price {
    font-size: 1.3rem;
    font-weight: bold;
    color: #FF6B00;
    margin-bottom: 0.5rem;
}

.shop-card p {
    font-size: 0.9rem;
    color: #555;
    padding: 0 1.5rem;
    margin-bottom: 1.5rem;
    flex-grow: 1; /* Mendorong tombol ke bagian paling bawah */
}

.shop-card .cta-button {
    width: 100%;
    border-radius: 0;
    margin: 0;
    padding: 1rem;
    font-size: 1.1rem;
    background-color: #FF6B00;
    color: white;
    border: none;
    font-weight: bold;
    cursor: pointer;
    transition: background-color 0.3s ease;
}

.shop-card .cta-button:hover {
    background-color: #D95B00;
}

/* --- Halaman Education: Kartu Artikel --- */
.education-container {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.article-card {
    display: flex;
    flex-wrap: wrap; /* Agar responsif di layar kecil */
    background-color: #FFFFFF;
    border-radius: 10px;
    box-shadow: 0 4px 8px rgba(0,0,0,0.05);
    overflow: hidden;
    border: 1px solid #eee;
    transition: box-shadow 0.3s ease;
}

.article-card:hover {
    box-shadow: 0 8px 15px rgba(0,0,0,0.1);
}

.article-image {
    width: 250px;
    min-height: 200px;
    flex-shrink: 0; /* Mencegah gambar menyusut */
}

.article-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.article-content {
    padding: 1.5rem;
    flex-grow: 1; /* Memastikan konten mengisi sisa ruang */
}

.article-content h4 {
    margin-top: 0;
    font-size: 1.3rem;
    color: #0A4D8C;
}

.article-content p {
    line-height: 1.7;
    color: #555;
}

/* --- Halaman Aktivitas: Kartu Kegiatan --- */
.activity-container {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); /* Tata letak grid yang responsif */
    gap: 1.5rem;
}

.activity-card {
    background-color: #FFFFFF;
    border-radius: 10px;
    box-shadow: 0 4px 8px rgba(0,0,0,0.05);
    overflow: hidden;
    border: 1px solid #eee;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.activity-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 15px rgba(0,0,0,0.1);
}

.activity-card img {
    width: 100%;
    height: 200px;
    object-fit: cover;
}

.activity-info {
    padding: 1.5rem;
}

.activity-date {
    display: inline-block; /* Membuatnya hanya selebar konten */
    background-color: #e9f2ff;
    color: #0A4D8C;
    padding: 0.3rem 0.8rem;
    border-radius: 20px; /* Membuat sudutnya sangat melengkung */
    font-size: 0.8rem;
    font-weight: bold;
    margin-bottom: 1rem;
}

.activity-info h4 {
    margin: 0 0 0.5rem 0;
    font-size: 1.3rem;
    color: #0A4D8C;
}

/* --- Halaman Customer Service: FAQ Interaktif --- */
.faq-container {
    max-width: 800px;
    margin: 0 auto;
}

details {
    background-color: #FFFFFF;
    border: 1px solid #eee;
    border-radius: 8px;
    margin-bottom: 1rem;
    box-shadow: 0 2px 4px rgba(0,0,0,0.05);
}

summary {
    font-weight: 600;
    color: #0A4D8C;
    padding: 1rem;
    cursor: pointer;
    list-style: none; /* Menghilangkan panah bawaan */
    position: relative;
}

/* Membuat ikon + / - sebagai pengganti panah */
summary::after {
    content: '+';
    position: absolute;
    right: 1rem;
    font-size: 1.5rem;
    transition: transform 0.2s ease;
}

/* Mengubah ikon menjadi - saat pertanyaan dibuka */
details[open] summary::after {
    content: '-';
    transform: rotate(180deg);
}

details p {
    padding: 0 1rem 1rem 1rem;
    margin: 0;
    line-height: 1.7;
    color: #555;
    border-top: 1px solid #eee;
}

/* --- Halaman Kontak: Info, Formulir, dan Peta --- */
.contact-container {
    display: flex;
    flex-wrap: wrap;
    gap: 2rem;
}

.contact-info, .contact-form {
    flex: 1;           /* Membuat kedua kolom berbagi ruang secara seimbang */
    min-width: 300px;  /* Lebar minimum sebelum pindah ke baris baru */
}

.contact-info h3, .contact-form h3 {
    margin-top: 0;
    color: #0A4D8C;
}

.contact-info ul {
    list-style: none;
    padding: 0;
}

.contact-info ul li {
    margin-bottom: 1rem;
    line-height: 1.6;
}

.form-group {
    margin-bottom: 1rem;
}

.form-group label {
    display: block;
    margin-bottom: 0.5rem;
    font-weight: 600;
}

.form-group input,
.form-group textarea {
    width: 100%;
    padding: 0.8rem;
    border: 1px solid #ccc;
    border-radius: 5px;
    font-family: 'Poppins', sans-serif;
    box-sizing: border-box; /* Memastikan padding tidak menambah lebar total elemen */
}

.form-group textarea {
    resize: vertical; /* Mengizinkan pengguna mengubah tinggi area teks */
}

.contact-form .cta-button {
    width: 100%;
    padding: 1rem;
    border: none;
    border-radius: 5px;
    background-color: #FF6B00;
    color: white;
    font-size: 1.1rem;
    font-weight: bold;
    cursor: pointer;
    transition: background-color 0.3s ease, transform 0.2s ease;
    box-shadow: 0 4px 6px rgba(0,0,0,0.1);
}

.contact-form .cta-button:hover {
    background-color: #D95B00;
    transform: translateY(-2px);
    box-shadow: 0 6px 8px rgba(0,0,0,0.15);
}

.map-container {
    margin-top: 2rem;
    background-color: #FFFFFF;
    padding: 2rem;
    border-radius: 10px;
}

.map-container h3 {
    margin-top: 0;
    text-align: center;
    color: #0A4D8C;
}

/* ==========================================================================
   5. FOOTER (BAGIAN BAWAH HALAMAN)
   ========================================================================== */
footer {
    background-color: #333;
    color: white;
    text-align: center;
    padding: 1.5rem;
    margin-top: 4rem; /* Memberi jarak lebih dari konten terakhir */
}

.footer-logos {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 2rem;
    margin-bottom: 1.5rem;
}

.footer-logos img {
    height: 50px; /* Mengatur tinggi logo di footer */
}

/* ================================= */
/* GAYA HALAMAN SELAIN HOMEPAGE      */
/* ================================= */

/* Untuk judul halaman seperti About Us, Products, dll. */
.page-header {
    background-color: #0A4D8C; /* Latar biru modern */
    color: white;
    text-align: center;
    padding: 3rem 1rem;
}

.page-header h1 {
    margin: 0;
    font-size: 2.5rem;
}

/* Wadah "kotak putih" untuk halaman-halaman ini */
.content-wrapper {
    max-width: 1200px;
    margin: 2rem auto 4rem auto; /* <-- PERBAIKANNYA DI SINI */
    background-color: white;
    padding: 3rem;
    border-radius: 10px;
    box-shadow: 0 15px 30px rgba(0,0,0,0.08);
    position: relative;
    z-index: 10;
    box-sizing: border-box;
}
/* ================================= */
/* GAYA UNTUK MENU AKTIF (HALAMAN SAAT INI) */
/* ================================= */
.header-main ul li a.active {
    color: #FF6B00;              /* Warna teks menjadi oranye, sama seperti saat di-hover */
    border-bottom-color: #FF6B00; /* Garis bawah muncul dengan warna oranye */
}

/* ================================= */
/* GAYA HALAMAN DETAIL PROGRAM       */
/* ================================= */
.detail-container {
    display: flex;       /* Membuat tata letak dua kolom */
    gap: 2.5rem;         /* Jarak antara gambar dan info */
    flex-wrap: wrap;     /* Agar responsif di layar kecil */
}

.detail-image {
    flex: 1;             /* Mengisi ruang yang tersedia */
    min-width: 300px;    /* Lebar minimum sebelum pindah baris */
}

.detail-image img {
    width: 100%;
    border-radius: 10px;
    box-shadow: 0 5px 15px rgba(0,0,0,0.1);
}

.detail-info {
    flex: 1.5;           /* Membuat kolom info sedikit lebih lebar dari gambar */
    min-width: 300px;
}

.detail-info h1 {
    margin-top: 0;
    font-size: 2.2rem;
    color: #0A4D8C;
}

.detail-target {
    background-color: #e9f2ff;
    border-left: 5px solid #0A4D8C;
    padding: 1rem 1.5rem;
    margin: 1.5rem 0;
    border-radius: 5px;
}

.detail-target span {
    font-size: 0.9rem;
    font-weight: bold;
    color: #555;
    display: block;
}

.detail-target p {
    font-size: 2rem;
    font-weight: bold;
    color: #28a745; /* Warna hijau */
    margin: 0.25rem 0 0 0;
}

.detail-info .description {
    font-size: 1.1rem;
    line-height: 1.7;
    margin-bottom: 2rem;
}

/* ================================= */
/* GAYA TOMBOL DI HALAMAN DETAIL     */
/* ================================= */
.detail-info .cta-button {
    width: 100%;
    padding: 1.2rem;
    font-size: 1.2rem;
    background-color: #FF6B00; /* Warna oranye khas */
    color: white;
    border: none;
    border-radius: 5px;
    font-weight: bold;
    cursor: pointer;
    transition: background-color 0.3s ease, transform 0.2s ease;
    box-shadow: 0 4px 6px rgba(0,0,0,0.1);
}

.detail-info .cta-button:hover {
    background-color: #D95B00; /* Oranye lebih gelap saat disentuh */
    transform: translateY(-2px); /* Efek sedikit terangkat */
}



/* ==========================================================================
   6. GAYA RESPONSIF (UNTUK TAMPILAN HP / MOBILE) - VERSI FINAL + RADIUS & POSISI
   ========================================================================== */

/* Di Desktop (layar lebar), sembunyikan tombol hamburger secara default */
.hamburger-menu {
    display: none;
}

/* TAMBAHAN: Variabel global agar mudah ubah kelengkungan sudut menu */
:root {
    --mobile-menu-radius: 25px; /* Atur besar radius sudut kanan menu */
}

/* Aturan ini HANYA berlaku untuk layar dengan lebar 768px atau lebih kecil */
@media (max-width: 768px) {

    /* --- Penyesuaian Header Atas --- */
    .header-top {
        padding: 0.5rem 1rem;             /* Mengurangi jarak tepi agar lebih rapat di HP */
        justify-content: space-between;   /* Logo di kiri, tombol hamburger di kanan */
        flex-direction: row;              /* Elemen header tersusun ke samping */
        gap: 0;                           /* Menghapus jarak berlebih antar elemen */
    }

    /* Sembunyikan tulisan "PPM BEM BERDAMPAK" di HP */
    .program-name-top {
        display: none;
    }

    /* --- TOMBOL HAMBURGER --- */
    .hamburger-menu {
        display: block;
        background: none;
        border: none;
        cursor: pointer;
        padding: 1rem;
        z-index: 1002; /* Di atas semua elemen lain */
    }

    .hamburger-menu span {
        display: block;
        width: 25px;
        height: 3px;
        background-color: #333;
        margin: 5px 0;
        transition: all 0.4s ease;
    }
    
    /* Saat tombol hamburger berubah menjadi 'X' */
    .hamburger-menu.active span {
        background-color: rgb(15, 120, 218); /* Garisnya jadi putih */
    }
    .hamburger-menu.active span:nth-child(1) {
        transform: translateY(8px) rotate(45deg);
    }
    .hamburger-menu.active span:nth-child(2) {
        opacity: 0;
    }
    .hamburger-menu.active span:nth-child(3) {
        transform: translateY(-8px) rotate(-45deg);
    }

    /* --- PENYESUAIAN NAVIGASI UNTUK HP --- */
    .header-main {
        box-shadow: none;  /* Menghapus bayangan header utama di mode HP */
        background: none;  /* Membuat background transparan */
    }
    
    /* --- MENU MOBILE (DRAWER / SIDEBAR) --- */
    #mobile-menu {
        position: fixed;
        top: 100px; /* DIUBAH: Jarak dari atas (atur biar pas di bawah logo) */
        left: -300px; /* Awal posisi menu tersembunyi di luar layar kiri */
        width: 250px; /* Lebar menu (bisa disesuaikan) */
        height: calc(100vh - 80px); /* Tinggi penuh tapi tidak menutupi header */
        background-color: #0A4D8C; /* Warna dasar menu */
        display: flex;
        flex-direction: column;
        justify-content: flex-start; /* Item menu mulai dari atas */
        align-items: flex-start; /* Rata kiri */
        padding: 2rem 0 2rem 0; /* DIUBAH: Jarak atas dikurangi agar tidak terlalu ke bawah */
        transition: left 0.4s ease; /* Animasi geser masuk dari kiri */
        z-index: 1001; /* Di atas konten tapi di bawah tombol */
        box-shadow: 5px 0 15px rgba(0,0,0,0.2); /* Efek bayangan di sisi kanan */

        /* TAMBAHAN: Sudut kanan melengkung */
        border-top-right-radius: var(--mobile-menu-radius);
        border-bottom-right-radius: var(--mobile-menu-radius);

        /* TAMBAHAN: Agar isi menu tidak keluar dari radius */
        overflow: hidden;
    }

    /* Saat menu aktif (terlihat di layar) */
    #mobile-menu.show {
        left: 0; /* Pindahkan ke posisi normal (tampil) */
    }

    /* --- ITEM NAVIGASI DALAM MENU --- */
    #mobile-menu li a {
        color: white; /* Warna teks */
        font-size: 1rem; /* Ukuran teks */
        font-weight: normal; /* Berat teks standar */
        border-bottom: 1px solid rgba(255, 255, 255, 0.1); /* Garis pemisah tipis */
        width: 100%; /* Lebar penuh */
        box-sizing: border-box; /* Pastikan padding tidak memengaruhi lebar */
        text-align: left; /* Teks rata kiri */
        transition: background-color 0.3s ease; /* Efek hover halus */
        padding: 1rem 2rem 1rem 2.5rem; /* Atas kanan bawah kiri */

    }

    #mobile-menu li a i {
    margin-right: 10px; /* Tambah jarak antara ikon dan teks */
    font-size: 1rem;    /* Ukuran ikon biar seimbang dengan teks */
    width: 20px;        /* Biar semua ikon punya lebar seragam */
    text-align: left; /* Posisikan ikon rata tengah */
}


    /* TAMBAHAN: Efek saat hover di menu */
    #mobile-menu li a:hover {
        background-color: rgba(255, 255, 255, 0.1);
    }

    /* --- TIRAI GELAP (BACKDROP) --- */
    .menu-backdrop {
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100vh;
        background-color: rgba(0, 0, 0, 0.5); /* Warna hitam transparan */
        z-index: 1000; /* Di belakang menu tapi di atas konten utama */
        opacity: 0;
        visibility: hidden;
        transition: opacity 0.4s ease, visibility 0.4s ease;
        display: block;
    }

    /* Saat menu aktif, tirai muncul */
    .menu-backdrop.show {
        opacity: 1;
        visibility: visible;
    }
    
    /* --- PENYESUAIAN KONTEN DI MODE HP --- */
    .hero-content h1 { font-size: 2rem; }
    .content-wrapper { padding: 1.5rem; }
    .page-header + .content-wrapper { margin-top: 2rem; }
}



/* ==========================================================================
   5. FOOTER BARU (BAGIAN BAWAH HALAMAN)
   ========================================================================== */
footer {
    background-color: #343a40; /* Warna latar abu-abu gelap */
    color: #adb5bd; /* Warna teks abu-abu terang */
    padding: 3rem 2rem;
    margin-top: 4rem;
    border-top: 4px solid #0A4D8C; /* Garis oranye di atas */
}

.footer-container {
    max-width: 1200px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap; /* Agar rapi di layar kecil */
    gap: 2rem;
}

.footer-left {
    flex: 2; /* Mengambil 2 bagian ruang */
}

.footer-right {
    flex: 1; /* Mengambil 1 bagian ruang */
    display: flex;
    justify-content: flex-end;
    align-items: flex-start;
}

.footer-copyright {
    font-size: 0.9rem;
    margin: 0 0 1.5rem 0;
}

.footer-info {
    list-style: none;
    padding: 0;
    margin: 0;
}

.footer-info li {
    display: flex;
    align-items: center;
    margin-bottom: 0.75rem;
}

.footer-info i {
    color: #FF6B00; /* Warna ikon oranye */
    width: 25px;
    margin-right: 0.5rem;
}

/* ================================= */
/* GAYA IKON SOSIAL DI FOOTER (KOTAK ORANYE) */
/* ================================= */
.footer-social {
    display: flex;
    justify-content: center;
    gap: 0.75rem; /* Jarak antar kotak */
    margin: 1.5rem 0;
}

.footer-social a {
    display: grid;
    place-items: center; /* Membuat ikon otomatis di tengah */
    width: 35px;
    height: 35px;
    background-color: #FF6B00; /* Latar oranye */
    color: white; /* Warna ikon menjadi putih */
    text-decoration: none;
    border-radius: 5px; /* Membuatnya menjadi kotak (bukan lingkaran) */
    font-size: 1.1rem;
    transition: background-color 0.3s ease;
}

.footer-social a:hover {
    background-color: #D95B00; /* Oranye lebih gelap saat disentuh */
}

/* --- Tombol Scroll ke Atas --- */
.scroll-to-top {
    position: fixed; /* Tetap di layar saat di-scroll */
    bottom: 20px;
    right: 20px;
    width: 50px;
    height: 50px;
    background-color: #FF6B00;
    color: white;
    border-radius: 50%; /* Membuatnya bulat */
    display: none; /* Sembunyi secara default */
    place-items: center;
    font-size: 1.2rem;
    text-decoration: none;
    z-index: 999;
    transition: opacity 0.4s ease, visibility 0.4s ease;
}

.scroll-to-top.show {
    display: grid; /* Tampilkan tombolnya */
}