/* === CSS Gốc === */
body {
    font-family: 'Roboto', sans-serif;
    background: linear-gradient(to right, #e0eafc, #cfdef3); /* Gradient nền */
    color: #333;
    margin: 0; /* Thêm để loại bỏ margin mặc định */
    padding: 0; /* Thêm để loại bỏ padding mặc định */
    box-sizing: border-box; /* Đảm bảo padding không làm tăng kích thước tổng */
}

*, *:before, *:after {
  box-sizing: inherit; /* Kế thừa box-sizing cho tất cả phần tử */
}

.container {
    background-color: #fff;
    padding: 30px;
    border-radius: 15px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    max-width: 600px;
    margin: 50px auto;
}

h1 {
    color: #3498db; /* Màu xanh dương */
    text-align: center;
    margin-top: 0; /* Điều chỉnh margin */
    margin-bottom: 25px;
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.1); /* Hiệu ứng đổ bóng cho chữ */
    font-size: 2.2em; /* Kích thước chữ gốc */
}

h2 {
    color: #2ecc71; /* Màu xanh lá cây */
    margin-top: 30px; /* Tăng khoảng cách với phần trên */
    margin-bottom: 15px;
    font-size: 1.5em; /* Kích thước chữ gốc */
    text-align: center; /* Căn giữa tiêu đề môn học */
}

ul {
    list-style: none;
    padding: 0;
    display: grid;
    /* Áp dụng cho cả grade-list và subject-list ban đầu */
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); /* Responsive grid gốc */
    gap: 15px;
    margin-bottom: 20px; /* Thêm khoảng cách dưới cho danh sách */
}

li {
    padding: 15px;
    border: none;
    border-radius: 10px;
    background-color: #f5f5f5;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
    cursor: pointer;
    transition: all 0.3s ease;
    text-align: center;
    font-size: 1em; /* Kích thước chữ gốc */
    /* Ngăn chữ quá dài phá vỡ layout (tùy chọn) */
    /* overflow-wrap: break-word; */
    /* word-break: break-word; */
}

li:hover {
    background: linear-gradient(to right, #f7971e, #ffd200); /* Gradient khi hover */
    color: #fff;
    transform: translateY(-3px); /* Hiệu ứng di chuyển lên */
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}

/* Hiệu ứng animation cho danh sách khối lớp */
.grade-list li {
    animation: fadeIn 0.5s ease forwards; /* Hiệu ứng fade in */
}

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Delay animation cho từng item */
.grade-list li:nth-child(1) { animation-delay: 0.1s; }
.grade-list li:nth-child(2) { animation-delay: 0.15s; }
.grade-list li:nth-child(3) { animation-delay: 0.2s; }
.grade-list li:nth-child(4) { animation-delay: 0.25s; }
.grade-list li:nth-child(5) { animation-delay: 0.3s; }
.grade-list li:nth-child(6) { animation-delay: 0.35s; }
.grade-list li:nth-child(7) { animation-delay: 0.4s; }
.grade-list li:nth-child(8) { animation-delay: 0.45s; }
.grade-list li:nth-child(9) { animation-delay: 0.5s; }
.grade-list li:nth-child(10) { animation-delay: 0.55s; }
.grade-list li:nth-child(11) { animation-delay: 0.6s; }
.grade-list li:nth-child(12) { animation-delay: 0.65s; }
/* Lưu ý: Animation cho subject-list chưa được thêm, nếu muốn cần thêm tương tự */


.logo-container {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 20px;
}

.logo {
    max-width: 150px; /* Kích thước gốc */
    height: auto;
    display: block;
}

/* === Media Queries cho Responsive === */

/* Cho máy tính bảng và điện thoại lớn (chiều rộng <= 768px) */
@media (max-width: 768px) {
    .container {
        padding: 25px;
        margin: 40px auto;
        /* Có thể giảm max-width nếu muốn container hẹp hơn trên tablet */
        /* max-width: 90%; */
    }

     h1 {
        font-size: 2em;
    }

    h2 {
        font-size: 1.4em;
    }

    ul {
        gap: 12px; /* Giảm khoảng cách một chút */
    }

    /* Giữ grade-list tự động điều chỉnh nhưng có thể min nhỏ hơn */
    .grade-list {
        grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
    }

    /* Đặt subject-list thành 3 cột để thoáng hơn tablet */
     .subject-list {
        grid-template-columns: repeat(3, 1fr); /* Thử 3 cột trên tablet */
     }

    li {
        padding: 12px;
        font-size: 0.95em;
    }

    .logo {
        max-width: 130px;
    }
}

/* Cho điện thoại di động (chiều rộng <= 600px) */
@media (max-width: 600px) {
    .container {
        padding: 20px;
        margin: 30px auto;
        width: 90%; /* Cho phép container co lại theo màn hình */
        max-width: none; /* Bỏ max-width cố định */
    }

    h1 {
        font-size: 1.8em;
    }

    h2 {
        font-size: 1.3em;
    }

    ul {
        gap: 10px; /* Giảm khoảng cách tiếp */
    }

     /* Đặt grade-list thành 3 cột cố định hoặc auto-fit min nhỏ hơn */
    .grade-list {
        grid-template-columns: repeat(3, 1fr); /* Cố định 3 cột cho dễ nhìn */
        /* Hoặc: grid-template-columns: repeat(auto-fit, minmax(90px, 1fr)); */
    }

    /* !!! Quan trọng: Đặt subject-list thành 2 cột */
    .subject-list {
        grid-template-columns: 1fr 1fr; /* Buộc hiển thị 2 cột */
    }

    li {
        padding: 10px 8px; /* Giảm padding ngang để tiết kiệm không gian */
        font-size: 0.9em;
    }

    .logo {
        max-width: 100px;
    }
}

/* Cho điện thoại di động rất nhỏ (chiều rộng <= 420px) */
@media (max-width: 420px) {
    .container {
        padding: 15px;
        margin: 20px auto;
        width: 95%; /* Sát viền hơn */
    }

     h1 {
        font-size: 1.6em;
    }

    h2 {
        font-size: 1.2em;
    }

    ul {
        gap: 8px;
    }

    /* Có thể đặt grade-list thành 2 cột */
     .grade-list {
        grid-template-columns: 1fr 1fr;
     }

    /* !!! Quan trọng: Đặt subject-list thành 1 cột */
    .subject-list {
        grid-template-columns: 1fr; /* Buộc hiển thị 1 cột */
    }

    /* Điều chỉnh lại padding và text-align cho subject list khi 1 cột */
    .subject-list li {
        text-align: left; /* Căn trái cho dễ đọc */
        padding: 12px 15px; /* Tăng lại padding cho dễ bấm */
        font-size: 0.9em; /* Giữ nguyên hoặc tăng nhẹ nếu muốn */
    }

     li {
        /* Đảm bảo các li khác (grade) cũng có font size hợp lý */
        font-size: 0.9em;
     }

     .logo {
        max-width: 80px;
    }
}