.card-body {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    height: 200px; /* Tentukan tinggi tetap sesuai kebutuhan */
}

.card-body ul {
    flex-grow: 1; /* Memastikan ul mengambil ruang yang tersedia */
    overflow: hidden; /* Menyembunyikan teks yang melebihi ruang */
    text-overflow: ellipsis; /* Menambahkan titik-titik (...) untuk teks panjang */
    white-space: nowrap; /* Membuat teks tetap satu baris */
}

.card-body p {
    margin-top: auto; /* Memastikan tombol "More" selalu berada di bawah */
}

.carousel-item {
    height: 100vh; /* Memenuhi tinggi layar */
    position: relative;
}

.carousel-item img {
    width: 100%; /* Memenuhi lebar penuh */
    height: 100%; /* Memenuhi tinggi penuh */
    object-fit: cover; /* Memastikan gambar tidak terpotong aneh */
}

.dark-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5); /* Warna gelap dengan transparansi */
    z-index: 1; /* Agar overlay berada di atas gambar */
}

.carousel-caption {
    z-index: 2; /* Pastikan teks berada di atas overlay */
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
}

