/* Import Google Fonts */
@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@400;700&family=Open+Sans:wght@400;600&display=swap');

body {
    font-family: 'Open Sans', sans-serif; /* Font chữ cho nội dung chính */
    margin: 0;
    padding: 20px; /* Giữ padding tổng thể cho desktop */
    background-color: #f8f8f8; /* Nền nhẹ nhàng hơn */
    color: #333;
    padding-bottom: 90px;
}

.container {
    max-width: 900px;
    margin: 20px auto; /* Giữ auto để căn giữa trên màn hình lớn */
    background-color: #ffffff; /* Nền trắng cho container */
    padding: 10px; /* Tăng padding để tạo khoảng trắng */
    border-radius: 10px; /* Bo tròn góc nhiều hơn */
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08); /* Đổ bóng mềm mại hơn */
}

h1 {
    font-family: 'Roboto', sans-serif; /* Font chữ riêng cho tiêu đề */
    text-align: center;
    color: #0056b3;
    margin-top: 0; /* Đảm bảo không có margin top mặc định */
    margin-bottom: 15px; /* Giảm khoảng cách dưới tiêu đề */
    font-size: 2.5em; /* Tăng kích thước tiêu đề */
    font-weight: 700; /* Đậm hơn */
}

table {
    width: 100%; /* Đảm bảo bảng chiếm 100% chiều rộng của container */
    border-collapse: separate; /* Thay đổi để dùng border-spacing */
    border-spacing: 0 8px; /* Thêm khoảng cách giữa các hàng */
    margin-top: 15px; /* Giảm khoảng cách trên bảng */
}

th, td {
    border: 1px solid #e0e0e0; /* Màu border nhẹ hơn */
    padding: 15px 10px; /* Tăng padding cho ô */
    text-align: center;
    white-space: nowrap;
    border-radius: 5px; /* Bo tròn góc cho từng ô */
    font-weight: bold; /* In đậm toàn bộ nội dung trong <td> */
}

th {
    background-color: #007bff; /* Màu xanh nổi bật */
    color: white;
    font-weight: 600; /* Đậm vừa phải (giữ nguyên cho tiêu đề) */
    text-transform: uppercase; /* Chữ hoa cho tiêu đề cột */
    padding: 18px 10px; /* Tăng padding cho đầu bảng */
    border-bottom: none; /* Xóa border dưới cùng để tránh bị trùng */
}

/* Đảm bảo tiêu đề bảng cũng được bo tròn góc */
th:first-child {
    border-top-left-radius: 8px;
}
th:last-child {
    border-top-right-radius: 8px;
}
tbody tr:first-child td:first-child {
    border-top-left-radius: 8px;
}
tbody tr:first-child td:last-child {
    border-top-right-radius: 8px;
}
tbody tr:last-child td:first-child {
    border-bottom-left-radius: 8px;
}
tbody tr:last-child td:last-child {
    border-bottom-right-radius: 8px;
}


tr:nth-child(even) {
    background-color: #f2f7fc; /* Màu nền nhẹ nhàng hơn cho hàng chẵn */
}

tr:hover {
    background-color: #e6f7ff; /* Màu hover sáng hơn, tạo cảm giác tinh tế */
    transform: translateY(-2px); /* Hiệu ứng nhấc nhẹ lên khi hover */
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.05); /* Đổ bóng nhẹ khi hover */
    transition: all 0.2s ease-in-out; /* Chuyển đổi mượt mà */
}

/* In đậm và màu đỏ cho Số SIM (áp dụng riêng sau khi in đậm chung) */
td:nth-child(1) { /* Ô số SIM (cột Số SIM sau khi xóa STT) */
    font-size: 1.5em; /* Tăng cỡ chữ số sim lên thêm */
    color: #FF0000; /* Màu đỏ #ee0033 (giữ lại ở đây để ghi đè màu chung) */
}

.order-button {
    background-color: #28a745; /* Màu xanh lá cây */
    color: white;
    padding: 12px 20px; /* Tăng kích thước nút đặt mua */
    border: none;
    border-radius: 7px; /* Bo tròn góc nhiều hơn */
    cursor: pointer;
    font-size: 16px; /* Tăng cỡ chữ nút đặt mua */
    font-weight: 600; /* Đã có sẵn */
    transition: background-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
    white-space: nowrap;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2); /* Đổ bóng cho nút */
}

.order-button:hover {
    background-color: #218838; /* Màu xanh đậm hơn khi hover */
    transform: translateY(-2px); /* Nút nhấc lên nhẹ khi hover */
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.3); /* Đổ bóng rõ hơn khi hover */
}

/* --- Kiểu dáng cho các nút nổi (Floating Contact Buttons) --- */
.floating-contact-wrapper {
    position: fixed;
    bottom: 25px; /* Dịch lên một chút */
    right: 25px; /* Dịch vào một chút */
    display: flex;
    flex-direction: column;
    gap: 18px; /* Tăng khoảng cách giữa các nút */
    z-index: 1000;
}

.contact-button {
    display: flex;
    align-items: center;
    width: auto; /* Thay đổi width thành auto để phù hợp với nội dung */
    height: 60px;
    border-radius: 30px; /* Bo tròn theo chiều dài */
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.25); /* Đổ bóng rõ hơn */
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    text-decoration: none;
    padding-right: 20px; /* Thêm padding bên phải cho văn bản */

    animation: vibrate 3.6s ease-in-out infinite;
}

.contact-button:hover {
    transform: translateY(-5px); /* Nhấc lên nhiều hơn khi hover */
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.4);
    animation: none;
}

.contact-button img {
    width: 45px; /* Tăng kích thước icon bên trong */
    height: 45px;
    background-color: transparent;
    border-radius: 50%; /* Đảm bảo icon vẫn tròn */
    margin-right: 10px; /* Khoảng cách giữa icon và text */
    margin-left: 5px; /* Dịch icon vào một chút */
}

.hotline-button {
    background-color: #007bff; /* Màu xanh dương cho hotline */
    color: white; /* Thêm màu chữ cho nút hotline */
}

.zalo-button {
    background-color: #008f71; /* Màu xanh Zalo chuẩn hơn */
    color: white; /* Thêm màu chữ cho nút zalo */
}

.button-text {
    font-size: 16px;
    font-weight: 700; /* Sử dụng 700 thay vì 'bold' để tường minh hơn */
    white-space: nowrap; /* Đảm bảo văn bản không bị xuống dòng */
}

/* --- Hiệu ứng rung --- */
@keyframes vibrate {
    0% { transform: translate(0, 0); }
    1% { transform: translate(-2px, -2px); }
    2% { transform: translate(2px, 2px); }
    3% { transform: translate(-2px, -2px); }
    4% { transform: translate(2px, 2px); }
    5.5% { transform: translate(0, 0); }

    6% { transform: translate(0, 0); }
    7% { transform: translate(-2px, -2px); }
    8% { transform: translate(2px, 2px); }
    9% { transform: translate(-2px, -2px); }
    10% { transform: translate(2px, 2px); }
    11.5% { transform: translate(0, 0); }

    12% { transform: translate(0, 0); }
    13% { transform: translate(-2px, -2px); }
    14% { transform: translate(2px, 2px); }
    15% { transform: translate(-2px, -2px); }
    16% { transform: translate(2px, 2px); }
    17.5% { transform: translate(0, 0); }

    18% { transform: translate(0, 0); }
    100% { transform: translate(0, 0); }
}

/* --- Dòng chữ chạy ngang (Marquee) --- */
.marquee-container {
    width: 100%;
    overflow: hidden; /* Quan trọng: Ẩn phần chữ bị tràn ra ngoài */
    background-color: #f7d23f; /* Màu nền cho dải chữ chạy, bạn có thể thay đổi */
    color: #333; /* Màu chữ */
    padding: 4px 0; /* Giảm padding trên và dưới cho desktop */
    box-shadow: 0 2px 5px rgba(0,0,0,0.1); /* Đổ bóng nhẹ */
    margin-bottom: 20px; /* Khoảng cách giữa dòng chữ chạy và container chính */
    white-space: nowrap; /* Đảm bảo chữ không bị xuống dòng */
    box-sizing: border-box; /* Bao gồm padding vào chiều rộng */
    position: sticky; /* Giúp dòng chữ dính ở trên cùng khi cuộn */
    top: 0; /* Dính vào top */
    z-index: 100; /* Đảm bảo nó nằm trên các phần tử khác */
}

.marquee-text {
    display: inline-block; /* Quan trọng: Cho phép áp dụng transform */
    padding-left: 100%; /* Bắt đầu chữ từ bên ngoài màn hình bên phải */
    animation: marquee 30s linear infinite; /* Đã thay đổi: Tăng thời gian animation lên 30s */
    font-size: 1.1em; /* Kích thước chữ */
    font-weight: 600; /* In đậm chữ */
    color: #FF0000; /* Màu chữ nổi bật hơn */
    /* text-shadow: 1px 1px 2px rgba(0,0,0,0.2); */
}

/* Định nghĩa animation cho dòng chữ chạy */
@keyframes marquee {
    0% { transform: translateX(0); }
    100% { transform: translateX(-100%); }
}


/* --- Media Queries cho màn hình nhỏ hơn --- */

@media (max-width: 768px) {
    body {
        padding: 0 0 120px 0;
    }
    .container {
        margin: 20px 0;
        padding: 20px;
        width: 100%;
        box-sizing: border-box;
    }

    h1 {
        font-size: 2em;
        margin-bottom: 10px;
    }

    table {
        font-size: 0.85em;
        border-spacing: 0 6px;
        margin-top: 10px;
    }

    th, td {
        padding: 10px 8px;
        border-radius: 4px;
        font-weight: bold;
    }

    td:nth-child(1) {
        font-size: 1.3em;
        color: #FF0000;
    }

    table th:nth-child(1), table td:nth-child(1) {
        width: 40%;
    }
    table th:nth-child(2), table td:nth-child(2) {
        width: 20%;
    }
    table th:nth-child(3), table td:nth-child(3) {
        width: 20%;
    }
    table th:nth-child(4), table td:nth-child(4) {
        width: 20%;
    }

    .order-button {
        padding: 10px 15px;
        font-size: 13px;
        border-radius: 6px;
        box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15);
    }

    .floating-contact-wrapper {
        flex-direction: row;
        bottom: 20px;
        left: 50%;
        transform: translateX(-50%);
        right: auto;
        width: 90%;
        justify-content: space-around;
        gap: 12px;
    }

    .contact-button {
        width: auto;
        height: 55px;
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
        padding-right: 15px;
    }

    .contact-button img {
        width: 40px;
        height: 40px;
        margin-right: 8px;
        margin-left: 4px;
    }

    .button-text {
        font-size: 14px;
        font-weight: 700;
    }

    /* Điều chỉnh responsive cho dòng chữ chạy */
    .marquee-container {
        padding: 3px 0;
        margin-bottom: 15px;
    }
    .marquee-text {
        animation-duration: 50s; /* Đã thay đổi: Tăng thời gian animation lên 25s trên màn hình nhỏ */
    }
}

@media (max-width: 480px) {
    body {
        padding: 0 0 110px 0;
    }

    .container {
        margin: 15px 0;
        padding: 15px;
        border-radius: 8px;
        width: 100%;
        box-sizing: border-box;
    }

    h1 {
        font-size: 1.8em;
        margin-bottom: 8px;
    }

    table {
        font-size: 0.75em;
        border-spacing: 0 5px;
        margin-top: 8px;
    }

    th, td {
        padding: 8px 5px;
        min-width: 40px;
        border-radius: 3px;
        font-weight: bold;
    }

    td:nth-child(1) {
        font-size: 1.2em;
        color: #FF0000;
    }

    table th:nth-child(1), table td:nth-child(1) {
        width: 45%;
    }
    table th:nth-child(2), table td:nth-child(2) {
        width: 23%;
    }
    table th:nth-child(3), table td:nth-child(3) {
        width: 17%;
    }
    table th:nth-child(4), table td:nth-child(4) {
        width: 15%;
    }

    .order-button {
        font-size: 11px;
        padding: 8px 12px;
        border-radius: 5px;
    }

    .floating-contact-wrapper {
        bottom: 15px;
        width: 95%;
        gap: 10px;
    }
    .contact-button {
        width: auto;
        height: 50px;
        box-shadow: 0 3px 10px rgba(0, 0, 0, 0.18);
        padding-right: 12px;
    }
    .contact-button img {
        width: 35px;
        height: 35px;
        margin-right: 6px;
        margin-left: 3px;
    }
    .button-text {
        font-size: 12px;
        font-weight: 700;
    }

    /* Điều chỉnh responsive cho dòng chữ chạy */
    .marquee-container {
        padding: 2px 0;
        margin-bottom: 10px;
    }
    .marquee-text {
        animation-duration: 35s; /* Đã thay đổi: Tăng thời gian animation lên 18s trên điện thoại nhỏ */
    }
}