/* =========================
   STYLE KUIS ONLINE RESPONSIVE
   ========================= */

/* Reset & Base */
* {
    text-decoration: none;
    margin: auto;
    padding: auto;
    box-sizing: border-box;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    font-size: 1.em;
    font-family: 'Open Sans', 'Comic Sans MS', Arial;
    line-height: 0.;
    color: #000000;
    transition: all 0.3s ease;

}

body {
    margin: 0;
    min-height: 100vh;
    font-family: 'Open Sans', sans-serif;
    font-size: 1.15em;
    font-weight: 400;
    color: #333;
    background: linear-gradient(135deg, rgb(216, 216, 216) 0%, rgb(192, 210, 230) 100%);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    line-height: 1.6;
    overflow-x: hidden;
    scroll-behavior: smooth;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}

/* Container */
.container,
.login-form {
    background: linear-gradient(135deg, #e1e1e4 60%, #aeb3f5 100%);
    padding: 48px 36px;
    border-radius: 22px;
    max-width: auto;
    margin: 40px auto 24px auto;
    box-shadow: 0 12px 36px 0 rgba(44, 62, 80, 0.22), 0 2px 10px rgba(166, 170, 241, 0.18);
    color: #353232;
    font-size: 1.15em;
    text-align: center;
    position: relative;
    /* Untuk efek hover */
    overflow: hidden;
    /* Mencegah konten meluap */



    .login-form {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 4px;
        /* Jarak antar elemen */
    }

    /* Efek hover pada container */
    .container:hover,
    .login-form:hover {
        box-shadow: 0 16px 48px rgba(44, 62, 80, 0.3), 0 4px 20px rgba(166, 170, 241, 0.25);
        transform: none;
        transition: none;
    }

    /* Button */
    .login-btn,
    .logout-button {
        background: linear-gradient(90deg, #7d9ef8 0%, #1585e1 70%);
        color: #ffff00;
        border: none;
        border-radius: 15px;
        font-size: 1.13em;
        font-weight: bold;
        padding: 14px 38px;
        margin: 14px auto;
        letter-spacing: 1.2px;
        cursor: pointer;
        outline: none;
        width: auto;
        max-width: 240px;
        min-width: 120px;
        text-align: center;
        box-sizing: border-box;
        position: relative;
        overflow: hidden;
    }

    .login-btn::after,
    .logout-button::after {
        content: '';
        position: absolute;
        left: 50%;
        top: 50%;
        width: 0;
        height: 0;
        background: rgba(255, 255, 255, 0.18);
        border-radius: 50%;
        z-index: 0;
    }

    .login-btn:hover,
    .logout-button:hover {
        background: linear-gradient(90deg, #ff7f50 0%, #ffb347 100%);
        color: #fffbe7;
        box-shadow: 0 10px 32px #ffb34755, 0 2px 12px #ffe08277;
    }

    .login-btn:hover::after,
    .logout-button:hover::after {
        width: 220%;
        height: 220%;
    }

    .login-btn:active,
    .logout-button:active {
        transform: scale(0.97);
        box-shadow: 0 2px 8px #ffb34733;
    }

    .mapel-list {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        flex-direction: row;
        justify-content: center;
        gap: 24px;
        padding: 120px;
        background: #d6d9ea;
        border-radius: 18px;
        box-shadow: 0 4px 18px #ffe08255;
        max-width: 1200px;
        margin: 0 auto;
        font-family: 'Comic Sans MS', 'Comic Sans', cursive, Arial, sans-serif;
        font-size: 1.1em;
        color: #3d1f14;
        margin-top: 36px;
    }

    .mapel-card {
        background: linear-gradient(120deg, #e7ebff 60%, #1115dd 100%);
        border-radius: 22px;
        box-shadow: 0 4px 18px #ffe08255;
        padding: 60px 74px;
        max-width: 300%;
        margin: 12px;
        cursor: pointer;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        text-align: center;
        font-family: 'Comic Sans MS', 'Comic Sans', cursive, Arial, sans-serif;
        font-size: 1.05em;
        color: #ff7f50;
        border: 2.5px solid #ffb347;
    }

    .emoji {
        font-size: 7.02em;
        margin-top: 12px;
        display: block;
        transition: transform 0.2s, margin-bottom 0.2s;
        color: #ff9800;
        text-align: center;
        margin-bottom: 12px;
        transition: transform 0.2s;
        color: #ff7f50;
        text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.2);
        margin-bottom: 0px;
        /* Reset margin for hover effect */

    }

    .mapel-card:hover {
        transform: scale(1.05) rotate(-2deg);
        box-shadow: 0 8px 32px #ffb34755;
        background: linear-gradient(120deg, #ffe082 60%, #fffbe7 100%);
        color: #007bff;
    }

    .mapel-card a {
        text-decoration: none;
        color: inherit;
        font-weight: bold;
        display: block;
        width: 100%;
        height: 100%;
        text-align: center;
        padding: 12px 0;
        transition: color 0.2s, text-decoration 0.2s;
        font-size: 2.1em;
    }


    .mapel-card:hover .emoji {
        transform: scale(1.1) rotate(5deg);
        margin-bottom: 10px;
        display: block;
    }

    .login-form {
        max-width: 340px;
        margin: 60px auto;
        background: #fffbe7;
        border-radius: 18px;
        padding: 28px 24px;
        box-shadow: 0 4px 18px #ffe08255;
        border: 2px solid #ffe082;
    }

    .login-form label {
        display: block;
        margin-top: 12px;
        font-weight: bold;
        color: #ff7f50;
    }

    .login-form input[type="text"],
    .login-form input[type="password"] {
        width: 100%;
        padding: 8px 10px;
        margin-top: 4px;
        border-radius: 8px;
        border: 1.5px solid #ffb347;
        font-size: 1em;
    }

    .login-form button {
        margin-top: 18px;
        padding: 10px 28px;
        background: linear-gradient(90deg, #ffb347 0%, #ffcc80 100%);
        color: #fff;
        border: none;
        border-radius: 22px;
        font-size: 1.1em;
        font-weight: bold;
        cursor: pointer;
    }

    .login-form button:hover {
        background: linear-gradient(90deg, #ffcc80 0%, #ffb347 100%);
        color: #ff7f50;
    }

    .error-msg {
        color: red;
        font-size: 0.9em;
        margin-top: 12px;
        font-weight: bold;
        text-align: center;
    }

    .success-msg {
        color: green;
        font-size: 0.9em;
        font-weight: bold;
        margin-top: 10px;
        text-align: center;
    }


    /* Responsif: tombol tetap kecil di layar kecil */
    @media (max-width: 768px) {

        .login-btn,
        .logout-button {
            width: auto !important;
            min-width: 80px;
            max-width: 180px;
            padding: 10px 18px;
            font-size: 1em;
            margin: 0 auto;
        }
    }

    .login-btn:hover,
    .logout-button:hover {
        background: linear-gradient(90deg, #66bb6a 0%, #4caf50 100%);
        box-shadow: 0 6px 20px rgba(76, 175, 80, 0.25);
        transform: translateY(-2px);
    }

    .input-field {
        width: 100%;
        padding: 12px 16px;
        border-radius: 8px;
        border: 2px solid #ffb347;
        background: #fffde7;
        color: #1a237e;
        font-size: 1em;
        font-weight: 400;
        box-shadow: 0 2px 8px rgba(255, 160, 0, 0.2);
        transition: border-color 0.2s, box-shadow 0.2s, background-color 0.2s, color 0.2s;
    }

    .input-field::placeholder {
        color: #1a237e;
        opacity: 0.7;
        /* Opasitas placeholder */
        font-style: italic;
        /* Gaya font placeholder */
        transition: color 0.2s, opacity 0.2s;
        font-size: 0.95em;
        /* Ukuran font placeholder */
        font-weight: 400;
        /* Berat font placeholder */

    }

    .input-field:hover {
        border-color: #ff9800;
        box-shadow: 0 2px 12px #ffe08277;
        background: #fffde7;
        color: #1a237e;
        transition: border-color 0.2s, box-shadow 0.2s, background-color 0.2s, color 0.2s;

    }


    .input-field:focus {
        border-color: #ff9800;
        box-shadow: 0 2px 12px #ffe08277;
        background: #fffde7;
        color: #1a237e;
        outline: none;
        /* Menghilangkan outline default */


    }

    /* Kartu Mapel */
    .mapel-list {
        flex-wrap: wrap;
        gap: 18px 24px;
        justify-content: center;
        /* Membuat kartu mapel rata kiri-kanan (tengah jika sisa) */
        align-items: flex-start;
        margin-top: 18px;
        list-style: none;
        /* Menghilangkan bullet point */
        margin: 0 auto;
        /* Pusatkan daftar mapel */
        padding: 9px 16px;
        /* Tambahkan padding horizontal */
        box-sizing: border-box;
        /* Pastikan padding tidak menambah lebar total */
        overflow: hidden;
        /* Mencegah konten meluap */
        position: relative;
        /* Untuk efek hover pada kartu mapel */
        /* Transisi halus untuk hover */
        background: rgba(202, 212, 232, 0.9);
        /* Latar belakang semi-transparan */
        border-radius: 16px;
        /* Sudut melengkung */
        box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
        /* Bayangan halus */
        backdrop-filter: blur(10px);
        /* Efek blur pada latar belakang */
        z-index: 1;
        /* Pastikan daftar mapel berada di atas elemen lain */
        margin: 0 auto;
        /* Pusatkan daftar mapel */
        border: 1px solid #ffffff;
        /* Tambahkan border untuk daftar mapel */
        border-radius: 16px;
        /* Sudut melengkung untuk daftar mapel */
        background: linear-gradient(135deg, #e7e8ea 60%, #c9c1f2 100%);
        /* Latar belakang gradasi */
        box-shadow: 0 12px 36px rgba(44, 62, 80, 0.22), 0 2px 10px rgba(166, 170, 241, 0.18);
        /* Bayangan halus */
        /* Transisi halus untuk hover */
    }


    .mapel-card {
        flex: inherit;
        /* Lebar minimum 220px, fleksibel */
        margin: 0;
        box-sizing: border-box;
        padding: 28px 28px;
        width: 220px;
        /* Lebar tetap 220px */
        height: 220px;
        /* Tinggi tetap 220px */
        font-family: 'Comic Sans MS', 'Comic Sans', cursive, Arial, sans-serif;
        font-size: 0.3em;
        color: #1a237e;
        /* Warna teks */
        border-radius: 16px;
        box-shadow: 0 2px 10px #ffe08255;
        background: linear-gradient(120deg, #c9caef 80%, #cec9f4 100%);
        border: 1px solid #cdc4f0;
        transition: background 0.2s, color 0.2s, box-shadow 0.2s;
        text-align: center;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        cursor: pointer;
        position: relative;
        overflow: hidden;
        /* Mencegah konten meluap */
        color: #1a237e;
        /* Warna teks default */
        text-decoration: none;
        /* Menghilangkan garis bawah pada link */
        font-weight: 500;
        /* Berat font default */
        /* Transisi halus */
        /* Tambahkan efek hover */
        box-shadow: 0 4px 16px rgba(255, 160, 0, 0.2);
        /* Bayangan halus */
        background: linear-gradient(120deg, #fcfdff 80%, #e1e4ff 100%);
        /* Efek blur pada latar belakang */
        z-index: 1;
        /* Pastikan kartu mapel berada di atas elemen lain */
        /* Transisi halus untuk hover */
        /* Tambahkan efek hover */
        box-shadow: 0 6px 50px rgba(0, 0, 0, 0.25);


    }


    .logout-button {
        background: linear-gradient(90deg, #52ff52 0%, #17e663 100%);
        color: #fff !important;
        border-radius: 10px;
        font-size: 1.08em;
        font-weight: bold;
        padding: 12px 32px;
        border: none;
        box-shadow: 0 0px 0px rgba(38, 2, 117, 0.18);
        margin: 10px auto;
        letter-spacing: 1.1px;
        cursor: pointer;
        outline: none;
        width: auto;
        /* Penting: agar tidak memanjang */
        max-width: 220px;
        /* Tambahkan batas lebar maksimum */
        min-width: 100px;
        /* Tambahkan batas lebar minimum */
        text-align: center;
        box-sizing: border-box;
    }

    .logout-button {
        width: auto !important;
        background: #e44101;
        min-width: 80px;
        max-width: 180px;
        padding: 10px 18px;
        font-size: 1.4em;
        margin-left: 0;
        /* posisi ke kiri */
        box-shadow: 0 4px 16px #ff573355, 0 2px 8px #ff573333;
        transition: box-shadow 0.2s, border 0.2s;
        border-radius: 6px;
        color: white;
        text-decoration: none;
        display: inline-block;
    }


    .mapel-card:hover {
        background: linear-gradient(120deg, #ffe082 80%, #fffbe7 100%);
        box-shadow: 0 4px 16px rgba(255, 160, 0, 0.2);
    }

    .mapel-card:hover::before {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: rgba(255, 255, 255, 0.2);
        backdrop-filter: blur(10px);
        border-radius: 16px;
        z-index: -1;
        /* Pastikan berada di belakang konten */

    }

    .mapel-card:hover h3 {
        color: #ff9800;
        /* Ganti warna teks judul saat hover */
    }

    .mapel-card h3 {
        font-size: 1.2em;
        font-weight: 600;
        color: #1a237e;
        /* Warna teks judul */
        margin-bottom: 12px;
        /* Jarak bawah judul */
        /* Transisi warna teks judul */
    }

    .mapel-card p {
        font-size: 1em;
        color: #424242;
        /* Warna teks deskripsi */
        margin-bottom: 12px;
        /* Jarak bawah deskripsi */
        /* Transisi warna teks deskripsi */
    }

    .mapel-card a {
        text-decoration: none;
        color: #1a237e;
        /* Warna teks link */
        /* Transisi warna dan dekorasi teks link */
        font-size: 3.8em;
        /* Ukuran font link */
        margin-bottom: 12px;
        /* Jarak bawah link */
        display: inline-block;
        /* Agar padding berfungsi */
        padding: 6px 12px;
        /* Padding link */

    }

    .mapel-card a:hover {
        color: #ff9800;
        /* Ganti warna teks link saat hover */
        text-decoration: underline;
        /* Tambahkan garis bawah saat hover */
    }

    .emoji {
        color: #ff9800;
        font-size: 10.9em;
        text-align: center;
        letter-spacing: 0.5px;
        margin: 2px auto 2px;
        display: block;
    }

    .form-opsi-jawaban label {
        display: block;
        background: #fffbe7;
        border: 2px solid #ffb347;
        border-radius: 12px;
        margin: 12px auto 0 auto;
        padding: 10px 16px 10px 38px;
        font-size: 1.07em;
        color: #1a237e;
        cursor: pointer;
        max-width: 480px;
        text-align: left;
        position: relative;
        box-shadow: 0 1px 6px #ffe08233;
    }

    .form-opsi-jawaban label:hover {
        background: #ffe08244;
        border-color: #ff9800;
    }

    .form-opsi-jawaban input[type="radio"]:checked+label {
        border-color: #ffb347;
    }

    .form-opsi-jawaban input[type="radio"] {
        position: absolute;
        left: 12px;
        top: 50%;
        transform: translateY(-50%);
        accent-color: #ffb347;
    }

    .pertanyaan-besar {
        color: #010316;
        /* Biru tua */
        font-size: 1.1em;
        text-align: left;
        margin-bottom: 20px;
        border: 2px solid #e0e0e0;
        border-radius: 12px;
        background-color: #fffbe7;
        padding: 20px 16px;
        box-shadow: 0 2px 8px rgba(102, 102, 100, 0.3);
        display: block;
        max-width: 800px;
        width: 100%;
        line-height: 1.6;
        transition: box-shadow 0.3s ease;
    }


    /* Tambahkan di style.css Anda atau di <style> pada <head> */
    #navigation {
        padding: 12px 8px;
        background: #f8fafd;
        border-radius: 12px;
        border: 1.5px solid #b3c6ff;
        box-shadow: 0 2px 8px rgba(50, 12, 239, 0.07);
        margin-top: 0;
        margin-bottom: 10px;
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        gap: 10px;
        align-items: center;
        justify-items: center;
    }

    #navigation button {
        border-radius: 8px;
        border: 2px solid #b3c6ff;
        background: #e3eaff;
        color: #222;
        font-weight: bold;
        cursor: pointer;
        transition: background 0.2s, color 0.2s, border 0.2s;
        margin: 0;
        width: 48px;
        height: 48px;
        font-size: 22px;
        box-shadow: 0 2px 6px #b3c6ff33;
    }

    #navigation button.nav-btn-aktif {
        background: linear-gradient(135deg, #ff9800 60%, #ffd180 100%);
        color: #fff;
        border: 2.5px solid #ff9800;
        box-shadow: 0 2px 8px #ff980055;
    }

    #navigation button.nav-btn-sudah {
        background: linear-gradient(135deg, #43e97b 60%, #38f9d7 100%);
        color: #fff;
        border: 2.5px solid #43e97b;
        box-shadow: 0 2px 8px #43e97b55;
    }

    #navigation button.nav-btn-belum {
        background: #e3eaff;
        color: #222;
        border: 2px solid #b3c6ff;
    }

    #navigation button:disabled {
        opacity: 0.5;
        cursor: not-allowed;
    }

    #navigation button:hover:not(:disabled) {
        background: linear-gradient(135deg, #320cef 60%, #b3c6ff 100%);
        color: #fff;
        border: 2.5px solid #320cef;
    }

    /* Tambahkan di bagian <style> Anda */


    @media (max-width: 400px) {


        .container-flex-soal {
            display: flex;

            flex-direction: column !important;
            align-items: stretch !important;
        }

        #navigation {
            margin-top: 24px !important;
            margin-bottom: 0 !important;
            max-width: 100% !important;
            width: 100% !important;
        }

        .mapel-card {
            flex: inherit;
            /* Lebar minimum 220px, fleksibel */
            margin: 0;
            box-sizing: border-box;
            padding: 28px 28px;
            width: 110px;
            /* Lebar tetap 220px */
            height: 100px;
            /* Tinggi tetap 220px */
            font-family: 'Comic Sans MS', 'Comic Sans', cursive, Arial, sans-serif;
            font-size: 0.3em;
            color: #1a237e;
            /* Warna teks */
            border-radius: 16px;
            box-shadow: 0 2px 10px #ffe08255;
            background: linear-gradient(120deg, #fffbe7 80%, #ffe082 100%);
            border: 2px solid #ffb347;
            text-align: center;
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            cursor: pointer;
            position: relative;
            overflow: hidden;
            /* Mencegah konten meluap */
            color: #1a237e;
            /* Warna teks default */
            text-decoration: none;
            /* Menghilangkan garis bawah pada link */
            font-weight: 500;
            /* Berat font default */
            /* Transisi halus */
            /* Tambahkan efek hover */
            box-shadow: 0 4px 16px rgba(255, 160, 0, 0.2);
            /* Bayangan halus */
            background: linear-gradient(120deg, #fffbe7 80%, #ffe082 100%);
            backdrop-filter: blur(10px);
            /* Efek blur pada latar belakang */
            z-index: 1;
            /* Pastikan kartu mapel berada di atas elemen lain */
            transition: box-shadow 0.3s ease, transform 0.3s ease, background 0.3s ease;
            /* Transisi halus untuk hover */
            /* Tambahkan efek hover */
            box-shadow: 0 6px 20px rgba(255, 160, 0, 0.25);
            /* Bayangan lebih dalam saat hover */
            transform: translateY(0);
            /* Pastikan tidak ada pergeseran awal */
            transition: box-shadow 0.3s ease, transform 0.3s ease, background 0.3s ease;
            /* Transisi halus untuk hover */
            /* Tambahkan efek hover */
            box-shadow: 0 6px 20px rgba(255, 160, 0, 0.25);
            /* Bayangan lebih dalam saat hover */
            /* Pastikan tidak ada pergeseran awal */
            /* Tambahkan efek hover */
            /* Transisi halus untuk hover */
            box-shadow: 0 6px 20px rgba(255, 160, 0, 0.25);
            /* Bayangan lebih dalam saat hover */
            /* Pastikan tidak ada pergeseran awal */
            /* Tambahkan efek hover */
            /* Transisi halus untuk hover */
            box-shadow: 0 6px 20px rgba(255, 160, 0, 0.25);
            /* Bayangan lebih dalam saat hover */
            /* Pastikan tidak ada pergeseran awal */
            /* Tambahkan efek hover */
            /* Transisi halus untuk hover */
            box-shadow: 0 6px 20px rgba(255, 160, 0, 0.25);
            /* Bayangan lebih dalam saat hover */
            /* Pastikan tidak ada pergeseran awal */
            /* Tambahkan efek hover */
            /* Transisi halus untuk hover */
            box-shadow: 0 6px 20px rgba(255, 160, 0, 0.25);
            /* Bayangan lebih dalam saat hover */
            /* Pastikan tidak ada pergeseran awal */
            /* Tambahkan efek hover */
            /* Transisi halus untuk hover */
            box-shadow: 0 6px 20px rgba(255, 160, 0, 0.25);
            /* Bayangan lebih dalam saat hover */
            /* Pastikan tidak ada pergeseran awal */
            /* Tambahkan efek hover */
            /* Transisi halus untuk hover */
            box-shadow: 0 6px 20px rgba(255, 160, 0, 0.25);
            /* Bayangan lebih dalam saat hover */
            /* Pastikan tidak ada pergeseran awal */
            /* Tambahkan efek hover */
            /* Transisi halus untuk hover */
            box-shadow: 0 6px 20px rgba(255, 160, 0, 0.25);
            /* Bayangan lebih dalam saat hover */
            /* Pastikan tidak ada pergeseran awal */


        }

        .mapel-card:hover {
            transform: translateY(-4px);
            box-shadow: 0 6px 24px rgba(255, 160, 0, 0.35);
        }


        .mapel-card a {
            text-decoration: none;
            color: inherit;
            font-weight: bold;
            display: block;
            width: 80%;
            height: 80%;
            text-align: center;
            padding: 1px 0px 1px 0px;
            font-size: 1.7em;
            margin-bottom: 43px;
        }


        .body {
            overflow-x: hidden;
        }


        .emoji {
            font-size: 5.5em;
            color: #ff9800;
            text-align: center;
            margin: opx auto 10px;
            padding: 0px 0px 0px 0px;
            display: block;
            color: #ff7f50;
            text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.2);
            margin-bottom: 0px;
            /* Reset margin for hover effect */

        }

        .pertanyaan-besar {
            width: 400px;
            max-width: 100%;
            font-size: 0.9em !important;
            /* Biru tua */
            color: rgb(7, 7, 7);
            /* Agar teks kontras dengan latar belakang */
            padding: 10px;
            /* Opsional, agar konten tidak terlalu mepet */
            box-sizing: border-box;
            /* Supaya padding tidak menambah lebar total */
        }


        .form-opsi-jawaban label {

            font-size: 0.9em;

        }


        .login-btn {

            font-size: 0.8em;

        }


        .logout-button {
            background: linear-gradient(120deg, #e04111 80%, #f30404 100%);
            font-size: 1.0em;

        }

        #navigation {
            grid-template-columns: repeat(5, 1fr);
            gap: 8px;
            padding: 1px;
        }

        #modalConfirm>div {
            padding: 18px 6vw !important;
            font-size: 1em !important;
        }
    }