    @keyframes float {

        0%,
        100% {
            transform: translateY(0);
        }

        50% {
            transform: translateY(-20px);
        }
    }

    @keyframes pulse-glow {

        0%,
        100% {
            box-shadow: 0 0 20px rgba(255, 193, 7, 0.4);
        }

        50% {
            box-shadow: 0 0 40px rgba(255, 193, 7, 0.8);
        }
    }

    .hero-modern {
        background: linear-gradient(135deg, #0d9488 0%, #0f766e 50%, #134e4a 100%);
        position: relative;
        overflow: hidden;
        min-height: 100vh;
    }

    .blob-1 {
        position: absolute;
        width: 600px;
        height: 600px;
        background: radial-gradient(circle, rgba(45, 212, 191, 0.3) 0%, transparent 70%);
        border-radius: 50%;
        top: -200px;
        right: -200px;
        animation: float 8s ease-in-out infinite;
    }

    .blob-2 {
        position: absolute;
        width: 400px;
        height: 400px;
        background: radial-gradient(circle, rgba(251, 191, 36, 0.2) 0%, transparent 70%);
        border-radius: 50%;
        bottom: -100px;
        left: -100px;
        animation: float 6s ease-in-out infinite reverse;
    }

    .badge-glow {
        animation: pulse-glow 2s ease-in-out infinite;
    }

    .hover-lift {
        transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    }

    .hover-lift:hover {
        transform: translateY(-10px);
        box-shadow: 0 20px 40px rgba(0, 0, 0, 0.15);
    }

    .glass-card {
        background: rgba(255, 255, 255, 0.1);
        backdrop-filter: blur(10px);
        border: 1px solid rgba(255, 255, 255, 0.2);
    }

    .gradient-text {
        background: linear-gradient(135deg, #fbbf24 0%, #f97316 100%);
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
        background-clip: text;
    }

    .btn-gradient {
        background: linear-gradient(135deg, #fbbf24 0%, #f97316 100%);
        border: none;
        transition: all 0.3s ease;
    }

    .btn-gradient:hover {
        transform: translateY(-3px);
        box-shadow: 0 10px 30px rgba(251, 191, 36, 0.4);
    }

    .section-pattern {
        background-color: #f8fafc;
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100' height='100' viewBox='0 0 100 100'%3E%3Cg fill-rule='evenodd'%3E%3Cg fill='%230d9488' fill-opacity='0.03'%3E%3Cpath opacity='.5' d='M96 95h4v1h-4v4h-1v-4h-9v4h-1v-4h-9v4h-1v-4h-9v4h-1v-4h-9v4h-1v-4h-9v4h-1v-4h-9v4h-1v-4h-9v4h-1v-4H0v-1h15v-9H0v-1h15v-9H0v-1h15v-9H0v-1h15v-9H0v-1h15v-9H0v-1h15v-9H0v-1h15v-9H0v-1h15v-9H0v-1h15V0h1v15h9V0h1v15h9V0h1v15h9V0h1v15h9V0h1v15h9V0h1v15h9V0h1v15h9V0h1v15h9V0h1v15h4v1h-4v9h4v1h-4v9h4v1h-4v9h4v1h-4v9h4v1h-4v9h4v1h-4v9h4v1h-4v9h4v1h-4v9zm-1 0v-9h-9v9h9zm-10 0v-9h-9v9h9zm-10 0v-9h-9v9h9zm-10 0v-9h-9v9h9zm-10 0v-9h-9v9h9zm-10 0v-9h-9v9h9zm-10 0v-9h-9v9h9zm-10 0v-9h-9v9h9zm-9-10h9v-9h-9v9zm10 0h9v-9h-9v9zm10 0h9v-9h-9v9zm10 0h9v-9h-9v9zm10 0h9v-9h-9v9zm10 0h9v-9h-9v9zm10 0h9v-9h-9v9zm10 0h9v-9h-9v9z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
    }

    .icon-box {
        width: 70px;
        height: 70px;
        display: flex;
        align-items: center;
        justify-content: center;
        border-radius: 20px;
        font-size: 1.75rem;
        transition: all 0.3s ease;
    }

    .feature-card:hover .icon-box {
        transform: scale(1.1) rotate(5deg);
    }

    /* ===== Datatable styling ===== */

    .card-prestasi {
        border-radius: 1.5rem;
        border: none;
    }

    #prestasiTable thead th {
        background-color: #0f766e;
        color: #fff;
        border: none;
        font-size: .9rem;
        text-transform: uppercase;
        letter-spacing: .05em;
    }

    #prestasiTable tbody tr:nth-child(even) {
        background-color: #f9fafb;
    }

    #prestasiTable tbody tr:hover {
        background-color: #ecfeff;
    }

    #prestasiTable tbody td {
        vertical-align: middle;
        font-size: .92rem;
    }

    #prestasiTable_wrapper .dataTables_filter {
        text-align: left;
    }

    #prestasiTable_wrapper .dataTables_filter label {
        font-weight: 500;
        color: #0f172a;
    }

    #prestasiTable_wrapper .dataTables_filter input {
        margin-left: .75rem;
        border-radius: 999px;
        border: 1px solid #cbd5e1;
        padding: .35rem 1rem;
        font-size: .9rem;
        max-width: 260px;
        box-shadow: none;
    }

    #prestasiTable_wrapper .dataTables_filter input:focus {
        border-color: var(--brand);
        outline: 0;
        box-shadow: 0 0 0 2px rgba(13, 148, 136, .25);
    }

    #prestasiTable_wrapper .dataTables_paginate {
        margin-top: 1rem;
    }

    /* Bungkus ul/li: biarkan transparan */
    #prestasiTable_wrapper .dataTables_paginate {
        margin-top: 1rem;
    }

    #prestasiTable_wrapper .dataTables_paginate .paginate_button {
        background: transparent !important;
        border: none !important;
        padding: 0;
    }

    /* Styling tombol sebenarnya (anchor) */
    #prestasiTable_wrapper .dataTables_paginate .page-link {
        border-radius: 999px !important;
        border: 1px solid transparent;
        padding: .25rem .75rem;
        margin: 0 .1rem;
        font-size: .85rem;
        color: #0f172a;
        box-shadow: none;
    }

    /* Active + hover state */
    #prestasiTable_wrapper .dataTables_paginate .page-item.active .page-link,
    #prestasiTable_wrapper .dataTables_paginate .page-link:hover {
        background-color: #0d9488;
        border-color: #0d9488;
        color: #fff;
    }

    /* Disable state biar soft */
    #prestasiTable_wrapper .dataTables_paginate .page-item.disabled .page-link {
        color: #cbd5e1;
        background-color: #f8fafc;
        border-color: transparent;
    }


    #prestasiTable_wrapper .dataTables_info {
        font-size: .85rem;
        color: #64748b;
        padding-top: .9rem;
    }

    .badge-unit {
        border-radius: 999px;
        font-size: .75rem;
        padding: .25rem .7rem;
    }

    .filter-chip {
        border-radius: 999px;
        font-size: .85rem;
    }

    .filter-chip.active {
        background-color: var(--brand);
        color: #fff;
        border-color: var(--brand);
    }

    #prestasiSearch {
        border-radius: 999px;
        font-size: .9rem;
        box-shadow: none;
    }

    #prestasiSearch:focus {
        border-color: #0d9488;
        box-shadow: 0 0 0 2px rgba(13, 148, 136, .15);
    }

    .input-group-text {
        border-radius: 999px 0 0 999px;
    }

    /* Search bar custom */
    .prestasi-search-input {
        border-radius: 999px;
        border: 1px solid #d1d5db;
        padding-left: 2.5rem;
        /* ruang buat icon */
        padding-right: 1rem;
        font-size: 0.9rem;
        box-shadow: none;
    }

    .prestasi-search-input::placeholder {
        color: #9ca3af;
    }

    .prestasi-search-input:focus {
        border-color: #0d9488;
        box-shadow: 0 0 0 2px rgba(13, 148, 136, 0.18);
    }

    /* icon di dalam input */
    .prestasi-search-icon {
        position: absolute;
        left: 0.9rem;
        top: 50%;
        transform: translateY(-50%);
        color: #9ca3af;
        pointer-events: none;
        font-size: 0.9rem;
    }

    /* === OVERRIDE mading card so it looks like poster, not cropped === */
    .mading-card {
        display: block;
        border-radius: 24px;
        overflow: hidden;
        background: #ffffff;
        padding: 8px;
        margin-left: 10px;
        /* white frame around poster */
        box-shadow: 0 16px 35px rgba(15, 23, 42, 0.18);
        transition: transform .25s ease, box-shadow .25s ease;
    }

    .mading-card figure {
        margin: 0;
    }

    /* show whole poster, don't crop */
    .mading-card img {
        display: block;
        width: 100%;
        height: auto;
        /* <– important: no fixed height */
        object-fit: contain;
        /* soft background behind poster */
    }

    /* simple hover */
    @media (hover: hover) {
        .mading-card:hover {
            transform: translateY(-6px);
            box-shadow: 0 22px 45px rgba(15, 23, 42, 0.22);
        }
    }

    /* spacing between slides */
    .mading-carousel .slick-slide {
        padding: 0 14px;
    }

    /* arrows: simpler & a bit smaller */
    .mading-carousel .slick-prev,
    .mading-carousel .slick-next {
        width: 46px;
        height: 96px;
        background: #f97316;
        color: #fff;
        border: none;
        outline: none;
        display: flex !important;
        align-items: center;
        justify-content: center;
        font-size: 1.3rem;
        top: 50%;
        transform: translateY(-50%);
        z-index: 5;
    }

    .mading-carousel .slick-prev {
        left: -10px;
        border-radius: 0 16px 16px 0;
    }

    .mading-carousel .slick-next {
        right: -10px;
        border-radius: 16px 0 0 16px;
    }

    .mading-carousel .slick-prev::before,
    .mading-carousel .slick-next::before {
        content: "";
    }

    /* responsive tweaks */
    @media (max-width: 991.98px) {
        .mading-carousel .slick-prev {
            left: 0;
        }

        .mading-carousel .slick-next {
            right: 0;
        }
    }

    @media (max-width: 767.98px) {
        .mading-carousel .slick-slide {
            padding: 0 8px;
        }

        .mading-card {
            border-radius: 18px;
            padding: 6px;
        }
    }