/* Pastikan @import ada di paling atas */
@import url('https://fonts.googleapis.com/css2?family=Lato:wght@300;400;700&family=Merriweather:wght@400;700&display=swap');

/* Terapkan font */
body {
    font-family: 'Lato', sans-serif !important; /* <--- TAMBAHKAN !important DI SINI */
    height: 100%;
    display: flex;
    flex-direction: column;
}

h1, h2, h3, h4, h5, h6, .navbar-brand {
    font-family: 'Merriweather', serif !important; /* <--- TAMBAHKAN !important DI SINI */
}

/* ... sisa kode CSS Anda yang sebelumnya ... */

/* Styling untuk membuat card tinggi gambar seragam */
.card-img-top {
    width: 100%;
    height: 200px;
    object-fit: cover;
}

/* Styling untuk card body agar tingginya relatif seragam */
.card-body {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    min-height: 200px;
}

.card-text small {
    display: block;
    margin-bottom: 5px;
}

.btn-primary {
    background-color: #007bff;
    border-color: #007bff;
}

.btn-primary:hover {
    background-color: #0056b3;
    border-color: #0056b3;
}

.card-body .btn {
    margin-top: auto;
}

.container.mt-4 {
    flex: 1; /* Agar mengambil sisa ruang */
}
footer {
    flex-shrink: 0; /* Mencegah footer menyusut */
}

/* ... Media Queries akan ditambahkan nanti ... */

body {
    font-family: Arial, sans-serif;
}

/* Styling untuk membuat card tinggi gambar seragam */
.card-img-top {
    width: 100%;
    height: 200px; /* Atur tinggi yang diinginkan untuk semua gambar card */
    object-fit: cover; /* Memastikan gambar mengisi area tanpa terdistorsi */
}

/* Styling untuk card body agar tingginya relatif seragam */
.card-body {
    display: flex;
    flex-direction: column;
    justify-content: space-between; /* Untuk mendorong tombol ke bawah */
    min-height: 200px; /* Atur tinggi minimal untuk body card */
}

.card-text small {
    display: block; /* Memastikan setiap baris small text berada di baris baru */
    margin-bottom: 5px;
}

/* Override warna tombol Baca Selengkapnya */
.btn-primary {
    background-color: #007bff; /* Biru Bootstrap */
    border-color: #007bff;
}

.btn-primary:hover {
    background-color: #0056b3;
    border-color: #0056b3;
}

/* Styling untuk tombol di bagian bawah card */
.card-body .btn {
    margin-top: auto; /* Mendorong tombol ke bagian bawah card */
}

/* ... kode CSS sebelumnya ... */

.navbar-brand img {
    margin-right: 8px; /* Sedikit jarak antara logo dan teks */
}

/* Memastikan footer selalu di bawah jika konten pendek */
html, body {
    height: 100%;
}
body {
    display: flex;
    flex-direction: column;
}
.container.mt-4 { /* Konten utama */
    flex: 1; /* Agar mengambil sisa ruang */
}
footer {
    flex-shrink: 0; /* Mencegah footer menyusut */
}

/* ... (KODE CSS ANDA SEBELUMNYA, TERMASUK ATURAN GLOBAL DAN MEDIA QUERY UNTUK max-width: 991.98px) ... */


/* === MEDIA QUERIES UNTUK RESPONSIVITAS === */

/* Untuk perangkat yang lebih kecil dari 992px (lebar desktop ke bawah) */
@media (max-width: 991.98px) {
    .navbar-brand {
        font-size: 1.1rem !important; /* Sedikit perkecil judul navbar di tablet/mobile */
    }
    .navbar-brand img {
        width: 25px; /* Perkecil logo di navbar */
        height: 25px;
    }
    .nav-link {
        font-size: 0.95rem !important; /* Perkecil link navigasi */
    }
}

/* Untuk perangkat yang lebih kecil dari 768px (hanya mobile) */
@media (max-width: 767.98px) {
    /* Ukuran font untuk Judul H1 */
    h1 {
        font-size: 1.8rem !important; /* Cukup besar tapi tidak terlalu mendominasi */
        margin-bottom: 1rem !important;
    }
    /* Ukuran font untuk Judul H3 */
    h3 {
        font-size: 1.35rem !important; /* Ukuran sub-judul di mobile */
        margin-bottom: 1rem !important;
    }
    /* Ukuran font untuk lead text (seperti info khatib) */
    .lead {
        font-size: 0.95rem !important; /* Perkecil lagi font lead text */
    }
    /* Ukuran font umum untuk paragraf dan text di card */
    body, p, .card-text, .card-title, .card-header,
    /* === Target spesifik untuk Tabel (header & cell) === */
    .table thead th, /* Header tabel */
    .table tbody td    /* Isi sel tabel */
    {
        font-size: 0.8rem !important; /* Perkecil font untuk semua teks umum dan tabel */
    }

    .card-text small {
        font-size: 0.7rem !important; /* Ukuran font terkecil */
    }
    .carousel-item img {
        height: 200px; /* Perkecil tinggi slider di mobile agar tidak terlalu makan tempat */
        object-fit: cover;
    }
    .card-body {
        min-height: auto; /* Hapus min-height agar card body menyesuaikan konten di mobile */
        padding: 0.8rem; /* Sedikit perkecil padding card */
    }
    .card-img-top {
        height: 150px; /* Perkecil tinggi gambar card di mobile */
    }
    .table-responsive {
        margin-bottom: 1rem;
    }
    .btn {
        font-size: 0.85rem !important; /* Ukuran font tombol di mobile */
        padding: 0.4rem 0.8rem !important; /* Sesuaikan padding tombol */
    }
    .btn-lg { /* Untuk tombol besar seperti "Lihat Semua Jadwal Kegiatan" */
        font-size: 0.95rem !important;
        padding: 0.6rem 1.2rem !important;
    }
    footer {
        padding-top: 1.5rem !important;
        padding-bottom: 1.5rem !important;
        font-size: 0.8rem !important; /* Perkecil font di footer */
    }
    .social-icons a i {
        font-size: 1.2rem !important; /* Perkecil ikon sosial media */
    }

    /* === Penyesuaian khusus untuk kolom Tabel Laporan Kas === */
    .table tbody td:nth-child(4) { /* Kolom Keterangan */
        max-width: 150px; /* Batasi lebar maksimum */
        word-wrap: break-word; /* Memastikan teks panjang pecah baris */
        white-space: normal; /* Override default nowrap */
        padding-right: 5px !important; /* Kurangi padding kanan */
    }

    .table tbody td:nth-child(5) { /* Kolom Jumlah */
        white-space: nowrap; /* Pastikan nominal tetap dalam satu baris */
        padding-left: 5px !important; /* Kurangi padding kiri */
    }

    .table tbody td { /* Padding umum untuk semua sel tabel */
        padding: 0.5rem 0.5rem !important;
    }

    /* Tambahan untuk card header di laporan kas (Summary cards) */
    .card.bg-success .card-title,
    .card.bg-danger .card-title,
    .card.bg-primary .card-title {
        font-size: 1rem !important; /* Perkecil font judul saldo di card */
    }
    .card.bg-success .card-header,
    .card.bg-danger .card-header,
    .card.bg-primary .card-header {
        font-size: 0.85rem !important; /* Perkecil font header saldo di card */
    }
}