/* /Layout/AdminLayout.razor.rz.scp.css */
.admin-viewport[b-oi1ena1eom] {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

.admin-content[b-oi1ena1eom] {
    background: none;
    flex: 1;
}

html[b-oi1ena1eom] {
    overflow-y: scroll;
    scrollbar-gutter: auto;
}
/* /Layout/Components/AdminHeader.razor.rz.scp.css */
.admin-header[b-xp9n5curm6] {
    background: #fff;
    border-bottom: 1px solid #e8e8e8;
    z-index: 1000;
}

.header-content[b-xp9n5curm6] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.6rem 1rem;
}

@media (min-width: 768px) {
    .header-content[b-xp9n5curm6] {
        padding: 0.75rem 2rem;
    }
}

.brand[b-xp9n5curm6] {
    display: flex;
    flex-direction: column;
    gap: 0;
    cursor: pointer;
    line-height: 1;
    color: inherit;
}

.brand-name[b-xp9n5curm6] {
    font-size: 22px;
    font-weight: 700;
    letter-spacing: -0.3px;
    line-height: 1.1;
    color: #2d333f;
    margin: 0;
}

@media (min-width: 768px) {
    .brand-name[b-xp9n5curm6] {
        font-size: 28px;
    }
}

.brand-subtitle[b-xp9n5curm6] {
    font-size: 11px;
    color: #8c8c8c;
    margin: 0;
    line-height: 1;
    margin-top: -2px;
}

.user-menu[b-xp9n5curm6] {
    display: flex;
    align-items: center;
    gap: 8px;
}

.btn-icon[b-xp9n5curm6] {
    position: relative;
    background: #fff;
    border: 1px solid #e2e2e2;
    padding: 8px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background 0.2s, border-color 0.2s;
    color: #333;
}

    .btn-icon:hover[b-xp9n5curm6] {
        background: #f5f5f5;
        border-color: #ccc;
    }

    .btn-icon .badge[b-xp9n5curm6] {
        position: absolute;
        top: -3px;
        right: -3px;
        background: #DA3743;
        color: #fff;
        font-size: 9px;
        padding: 2px 4px;
        border-radius: 10px;
        font-weight: 600;
    }

.btn-user[b-xp9n5curm6] {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 10px;
    border-radius: 8px;
    border: 1px solid #e2e2e2;
    background: #fff;
    cursor: pointer;
    transition: background 0.2s, border-color 0.2s;
    color: #1a1a1a;
}

    .btn-user:hover[b-xp9n5curm6] {
        background: #f5f5f5;
        border-color: #ccc;
    }

    .btn-user i[b-xp9n5curm6] {
        font-size: 12px;
        opacity: 0.7;
    }

.user-avatar[b-xp9n5curm6] {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: #DA3743;
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.user-name[b-xp9n5curm6] {
    font-size: 13px;
    font-weight: 600;
    color: #1a1a1a;
}

.dropdown-item[b-xp9n5curm6] {
    font-weight: 500;
    font-size: 13px;
    padding: 6px 16px;
    display: flex;
    align-items: center;
    color: #4a4a4a;
    width: 100%;
}

button.dropdown-item[b-xp9n5curm6] {
    border: none;
    background: none;
    text-align: left;
}

.dropdown-item:hover[b-xp9n5curm6] {
    background-color: #f7f7f7;
}

.dropdown-item i[b-xp9n5curm6] {
    font-size: 14px !important;
    opacity: 0.7;
    display: inline-flex;
    align-items: center;
    width: 20px;
}

/* NAV */
.admin-nav[b-xp9n5curm6] {
    background: #fff;
    border-bottom: 1px solid #e8e8e8;
    position: sticky;
    top: 0;
    z-index: 999;
}

.nav-content[b-xp9n5curm6] {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    padding: 0.5rem 1rem;
    gap: 1rem;
    margin-top: 0.5rem;
    margin-bottom: 0.5rem;
}

@media (min-width: 992px) {
    .nav-content[b-xp9n5curm6] {
        justify-content: center;
        padding: 0.5rem 2rem;
        flex-wrap: nowrap;
    }
}

.navbar-toggler[b-xp9n5curm6] {
    border: none;
    background: #f8f9fa;
    padding: 0.4rem 0.75rem;
    border-radius: 8px;
    cursor: pointer;
}

    .navbar-toggler i[b-xp9n5curm6] {
        font-size: 1.4rem;
        color: #333;
    }

/* Mobile: menu xổ xuống full width */
.navbar-collapse[b-xp9n5curm6] {
    width: 100%;
}

.nav-links[b-xp9n5curm6] {
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: 0.5rem 0;
}

@media (min-width: 992px) {
    .navbar-toggler[b-xp9n5curm6] {
        display: none;
    }

    .navbar-collapse[b-xp9n5curm6] {
        display: block !important;
        flex: 1; /* thêm dòng này */
    }

    .nav-links[b-xp9n5curm6] {
        flex-direction: row;
        flex-wrap: nowrap;
        padding: 0;
        gap: 2px;
        justify-content: center; /* thêm dòng này */
    }
}


.nav-link[b-xp9n5curm6] {
    color: #666;
    text-decoration: none;
    font-weight: 700;
    font-size: 0.875rem;
    padding: 0.6rem 0.9rem;
    border-radius: 8px;
    transition: all 0.2s;
    display: block;
    white-space: nowrap;
}

    .nav-link:hover[b-xp9n5curm6] {
        background: #f8f9fa;
        color: #bf2d38;
    }

    .nav-link.active[b-xp9n5curm6] {
        background: #f8f9fa;
        color: #bf2d38;
    }

.admin-content[b-xp9n5curm6] {
    overflow-y: overlay;
}
/* /Layout/Components/Chatbot.razor.rz.scp.css */
/* ================= CHATBOT WIDGET ================= */
.chatbot-wrapper[b-g5b0ry54mv] {
    position: fixed;
    bottom: 30px;
    right: 30px;
    z-index: 9999;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
}

/* Nút bong bóng ở góc */
.chatbot-toggle[b-g5b0ry54mv] {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    background: linear-gradient(135deg, #DA3743, #bf2d38);
    color: white;
    border: none;
    font-size: 1.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275), box-shadow 0.3s ease;
    z-index: 2;
}

    .chatbot-toggle:hover[b-g5b0ry54mv] {
        transform: scale(1.05);
        box-shadow: 0 10px 25px rgba(218,55,67,0.4) !important;
    }

/* Khung Chat */
.chatbot-box[b-g5b0ry54mv] {
    position: absolute;
    bottom: 80px;
    right: 0;
    width: 360px;
    height: 480px;
    background: #fff;
    border-radius: 10px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transform-origin: bottom right;
    animation: chat-popup-b-g5b0ry54mv 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275) forwards;
    border: 1px solid rgba(0,0,0,0.08);
    box-shadow: 0 15px 40px rgba(0,0,0,0.12) !important;
}

@keyframes chat-popup-b-g5b0ry54mv {
    0% {
        transform: scale(0.5);
        opacity: 0;
    }

    100% {
        transform: scale(1);
        opacity: 1;
    }
}

/* Header */
.chatbot-header[b-g5b0ry54mv] {
    background: linear-gradient(135deg, #DA3743, #b8222c);
    color: white;
    padding: 16px 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    cursor: pointer;
}

.chatbot-avatar[b-g5b0ry54mv] {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
}

.chatbot-info h6[b-g5b0ry54mv] {
    letter-spacing: 0.3px;
}

/* Body / Messages */
.chatbot-messages[b-g5b0ry54mv] {
    height: 380px;
    overflow-y: auto;
    padding: 20px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    background-color: #fcfcfc;
}

    /* Custom Scrollbar cho phần chat */
    .chatbot-messages[b-g5b0ry54mv]::-webkit-scrollbar {
        width: 6px;
    }

    .chatbot-messages[b-g5b0ry54mv]::-webkit-scrollbar-track {
        background: transparent;
    }

    .chatbot-messages[b-g5b0ry54mv]::-webkit-scrollbar-thumb {
        background: #ddd;
        border-radius: 10px;
    }

        .chatbot-messages[b-g5b0ry54mv]::-webkit-scrollbar-thumb:hover {
            background: #bbb;
        }

.chat-time-badge[b-g5b0ry54mv] {
    background: #f1f3f5;
    color: #888;
    font-size: 0.7rem;
    padding: 4px 10px;
    border-radius: 12px;
}

/* Từng dòng chat */
.msg-row[b-g5b0ry54mv] {
    display: flex;
    align-items: flex-end;
    gap: 8px;
    max-width: 90%;
    animation: fade-in-up-b-g5b0ry54mv 0.3s ease forwards;
}

@keyframes fade-in-up-b-g5b0ry54mv {
    0% {
        opacity: 0;
        transform: translateY(10px);
    }

    100% {
        opacity: 1;
        transform: translateY(0);
    }
}

.msg-right[b-g5b0ry54mv] {
    align-self: flex-end;
    flex-direction: row-reverse;
}

.msg-left[b-g5b0ry54mv] {
    align-self: flex-start;
}

.msg-avatar-small[b-g5b0ry54mv] {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: #DA3743;
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.8rem;
    flex-shrink: 0;
}

/* Chữ trong bong bóng chat (Tin nhắn) */
.msg-bubble[b-g5b0ry54mv] {
    padding: 8px 12px; /* Bo gọn lại một chút cho hợp với chữ nhỏ */
    border-radius: 16px;
    font-size: 0.75rem; /* GIẢM TỪ 0.9rem XUỐNG 0.85rem */
    line-height: 1.45;
    word-wrap: break-word;
    box-shadow: 0 1px 2px rgba(0,0,0,0.05);
}

.msg-right .msg-bubble[b-g5b0ry54mv] {
    background: #DA3743;
    color: white;
    border-bottom-right-radius: 4px; /* Đuôi chat bên phải */
}

.msg-left .msg-bubble[b-g5b0ry54mv] {
    background: #fff;
    color: #333;
    border: 1px solid #eee;
    border-bottom-left-radius: 4px; /* Đuôi chat bên trái */
}

/* Typing Indicator (Đang gõ...) */
.typing-bubble[b-g5b0ry54mv] {
    padding: 12px 16px !important;
}

.typing-indicator[b-g5b0ry54mv] {
    display: flex;
    gap: 4px;
    align-items: center;
    height: 14px;
}

    .typing-indicator span[b-g5b0ry54mv] {
        width: 6px;
        height: 6px;
        background-color: #bbb;
        border-radius: 50%;
        animation: bounce-b-g5b0ry54mv 1.4s infinite ease-in-out both;
    }

        .typing-indicator span:nth-child(1)[b-g5b0ry54mv] {
            animation-delay: -0.32s;
        }

        .typing-indicator span:nth-child(2)[b-g5b0ry54mv] {
            animation-delay: -0.16s;
        }

@keyframes bounce-b-g5b0ry54mv {
    0%, 80%, 100% {
        transform: scale(0);
    }

    40% {
        transform: scale(1);
    }
}

/* Khu vực nhập liệu */
.chatbot-input-area[b-g5b0ry54mv] {
    padding: 12px 16px;
    background: #fff;
    border-top: 1px solid #f0f0f0;
}

.chat-input-wrapper[b-g5b0ry54mv] {
    display: flex;
    align-items: center;
    background: #f4f5f7;
    border-radius: 24px;
    padding: 6px 6px 6px 16px;
    border: 1px solid #e9e9e9;
    transition: border-color 0.2s;
}

    .chat-input-wrapper:focus-within[b-g5b0ry54mv] {
        border-color: #DA3743;
        background: #fff;
        box-shadow: 0 0 0 3px rgba(218,55,67,0.1);
    }

    .chat-input-wrapper input[b-g5b0ry54mv] {
        flex: 1;
        border: none;
        background: transparent;
        outline: none;
        font-size: 0.9rem;
        color: #333;
    }

.chat-send-btn[b-g5b0ry54mv] {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: none;
    background: #e4e6eb;
    color: #aeb4be;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: not-allowed;
    transition: all 0.2s;
}

    .chat-send-btn.active[b-g5b0ry54mv] {
        background: #DA3743;
        color: white;
        cursor: pointer;
    }

        .chat-send-btn.active:hover[b-g5b0ry54mv] {
            background: #b8222c;
            transform: scale(1.05);
        }

.msg-bubble br + b[b-g5b0ry54mv] {
    display: inline-block;
    margin-top: 4px;
}

/* Responsive cho Mobile */
@media (max-width: 576px) {
    .chatbot-box[b-g5b0ry54mv] {
        position: fixed;
        bottom: 0;
        right: 0;
        width: 100%;
        height: 100%;
        border-radius: 0;
        bottom: 0 !important;
    }

    .chatbot-messages[b-g5b0ry54mv] {
        height: 100%;
        flex: 1;
    }

    .chatbot-wrapper[b-g5b0ry54mv] {
        bottom: 20px;
        right: 20px;
    }
}

@media (max-width: 576px) {
    .chatbot-box[b-g5b0ry54mv] {
        position: fixed;
        bottom: 0;
        right: 0;
        width: 100%;
        height: 100%;
        border-radius: 0;
        bottom: 0 !important;
    }

    .chatbot-messages[b-g5b0ry54mv] {
        height: 100%;
        flex: 1;
    }

    .chatbot-wrapper[b-g5b0ry54mv] {
        bottom: 20px;
        right: 20px;
    }

        .chatbot-wrapper.is-open .chatbot-toggle[b-g5b0ry54mv] {
            display: none;
        }
}
/* /Layout/Components/CustomerHeader.razor.rz.scp.css */
/* ================= HEADER ================= */

.customer-header[b-zbpz8yk2oi] {
    background: #fff;
    border-bottom: 1px solid #e8e8e8;
}

.header-content[b-zbpz8yk2oi] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.75rem 2rem;
}

/* ================= BRAND ================= */

.brand[b-zbpz8yk2oi] {
    display: flex;
    flex-direction: column;
    gap: 0;
    cursor: pointer;
    line-height: 1;
}

.brand-name[b-zbpz8yk2oi] {
    font-size: 26px;
    font-weight: 700;
    letter-spacing: -0.3px;
    line-height: 1.1;
    color: #2d333f;
    margin: 0;
}

@media (min-width: 768px) {
    .brand-name[b-zbpz8yk2oi] {
        font-size: 28px;
    }
}

.brand-subtitle[b-zbpz8yk2oi] {
    font-size: 11px;
    color: #8c8c8c;
    margin: 0;
    line-height: 1;
    margin-top: -2px;
}

/* ================= ICON BUTTON (Bell / Chat) ================= */

.btn-icon[b-zbpz8yk2oi] {
    position: relative;
    background: #fff;
    border: 1px solid #e2e2e2;
    padding: 13px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background 0.2s, border-color 0.2s;
}

    .btn-icon i[b-zbpz8yk2oi] {
        font-size: 16px;
        line-height: 1;
        color: #333;
    }

    .btn-icon:hover[b-zbpz8yk2oi] {
        background: #f5f5f5;
        border-color: #ccc;
    }

    .btn-icon .badge[b-zbpz8yk2oi] {
        position: absolute;
        top: -3px;
        right: -3px;
        background: #DA3743;
        color: #fff;
        font-size: 9px;
        padding: 2px 4px;
        border-radius: 10px;
        font-weight: 600;
    }

/* ================= USER DROPDOWN BUTTON ================= */

.btn-user[b-zbpz8yk2oi] {
    display: flex;
    align-items: center;
    gap: 3px;
    padding: 10px 12px;
    border-radius: 8px;
    border: 1px solid #e2e2e2;
    background: #fff;
    cursor: pointer;
    transition: background 0.2s, border-color 0.2s;
}

    .btn-user:hover[b-zbpz8yk2oi] {
        background: #f5f5f5;
        border-color: #ccc;
    }

.user-avatar[b-zbpz8yk2oi] {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: #DA3743;
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
}

.user-name[b-zbpz8yk2oi] {
    font-size: 13px;
    font-weight: 600;
    letter-spacing: -0.1px;
    color: #1a1a1a;
}

.btn-user i[b-zbpz8yk2oi] {
    font-size: 12px;
    opacity: 0.7;
}

/* ================= DROPDOWN ================= */

/* Thu nhỏ tổng thể dropdown */
.dropdown-item[b-zbpz8yk2oi] {
    font-weight: 500;
    font-size: 13px;
    padding: 6px 16px;
    display: flex;
    align-items: center;
    color: #4a4a4a;
    text-align: left;
    width: 100%;
}

button.dropdown-item[b-zbpz8yk2oi] {
    border: none;
    background: none;
}

    /* Thu nhỏ riêng icon */
    .dropdown-item i[b-zbpz8yk2oi] {
        font-size: 14px !important; /* Ép icon nhỏ lại (Bootstrap fs-5 thường là 20px - hơi to) */
        opacity: 0.7;
        line-height: 0;
        display: inline-flex;
        align-items: center;
        width: 20px; /* Cố định độ rộng icon để chữ luôn thẳng hàng dọc */
    }

    /* Khoảng cách cho badge thông báo nếu có */
    .dropdown-item .badge[b-zbpz8yk2oi] {
        font-size: 10px;
        padding: 2px 5px;
    }

    .dropdown-item:hover[b-zbpz8yk2oi] {
        background-color: #f7f7f7;
    }

/* ================= AUTH BUTTONS ================= */

/* Container chứa các nút */
.user-menu[b-zbpz8yk2oi] {
    display: flex;
    align-items: center;
    gap: 8px; /* Thu hẹp khoảng cách các nút một chút */
}

/* Nút Đăng ký (Join) */
.btn-join[b-zbpz8yk2oi] {
    font-size: 13px; /* Đồng bộ 13px */
    font-weight: 600;
    color: #2d333f;
    padding: 10px 16px; /* Giảm padding */
    text-decoration: none;
    border-radius: 5px;
    transition: all 0.2s;
}

    .btn-join:hover[b-zbpz8yk2oi] {
        background: #f5f5f5;
        color: #247F9E;
    }

/* Nút Đăng nhập (Sign in) */
.btn-signin[b-zbpz8yk2oi] {
    background: #247F9E;
    color: #fff;
    font-size: 13px; /* Đồng bộ 13px */
    font-weight: 600;
    padding: 10px 16px; /* Padding cân đối */
    border-radius: 5px;
    text-decoration: none;
    transition: background 0.2s, transform 0.1s;
}

    .btn-signin:hover[b-zbpz8yk2oi] {
        background: #1c667e;
        color: #fff;
    }

    .btn-signin:active[b-zbpz8yk2oi] {
        transform: scale(0.97); /* Hiệu ứng nhấn nút */
    }

/* Nút Search */
.btn-search[b-zbpz8yk2oi] {
    background: transparent;
    border: none;
    font-size: 16px; /* Giảm một chút cho tinh tế */
    color: #5c6370;
    padding: 0 0 0 12px;
    margin-left: 4px;
    border-left: 1px solid #eee; /* Đường kẻ mờ hơn */
    cursor: pointer;
    display: flex;
    align-items: center;
    height: 20px; /* Giới hạn chiều cao đường kẻ */
}

    .btn-search:hover[b-zbpz8yk2oi] {
        color: #247F9E;
    }

.notification-dropdown[b-zbpz8yk2oi] {
    width: 340px;
}

.notification-item[b-zbpz8yk2oi] {
    cursor: pointer;
    transition: background 0.15s;
}

    .notification-item:hover[b-zbpz8yk2oi] {
        background-color: #f8f9fa;
    }

    .notification-item.unread[b-zbpz8yk2oi] {
        background-color: #eff6ff;
    }

        .notification-item.unread:hover[b-zbpz8yk2oi] {
            background-color: #dbeafe;
        }

.fw-semibold[b-zbpz8yk2oi] {
    font-size: 0.8rem;
}

.text-muted[b-zbpz8yk2oi] {
    font-size: 0.7rem;
}

@media (max-width: 576px) {
    .header-content[b-zbpz8yk2oi] {
        padding: 0.75rem 1rem;
    }

    .btn-join[b-zbpz8yk2oi], .btn-signin[b-zbpz8yk2oi] {
        font-size: 11px;
        padding: 7px 10px;
    }

    .btn-search[b-zbpz8yk2oi] {
        padding: 0 0 0 8px;
        margin-left: 2px;
    }

    .user-menu[b-zbpz8yk2oi] {
        gap: 4px;
    }
}
/* /Layout/Components/StaffHeader.razor.rz.scp.css */
.admin-header[b-vqkw3kwxl7] {
    background: #fff;
    border-bottom: 1px solid #e8e8e8;
    z-index: 1000;
}

.header-content[b-vqkw3kwxl7] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.6rem 1rem;
}

@media (min-width: 768px) {
    .header-content[b-vqkw3kwxl7] {
        padding: 0.75rem 2rem;
    }
}

.brand[b-vqkw3kwxl7] {
    display: flex;
    flex-direction: column;
    gap: 0;
    cursor: pointer;
    line-height: 1;
    color: inherit;
}

.brand-name[b-vqkw3kwxl7] {
    font-size: 22px;
    font-weight: 700;
    letter-spacing: -0.3px;
    line-height: 1.1;
    color: #2d333f;
    margin: 0;
}

@media (min-width: 768px) {
    .brand-name[b-vqkw3kwxl7] {
        font-size: 28px;
    }
}

.brand-subtitle[b-vqkw3kwxl7] {
    font-size: 11px;
    color: #8c8c8c;
    margin: 0;
    line-height: 1;
    margin-top: -2px;
}

.user-menu[b-vqkw3kwxl7] {
    display: flex;
    align-items: center;
    gap: 8px;
}

.btn-icon[b-vqkw3kwxl7] {
    position: relative;
    background: #fff;
    border: 1px solid #e2e2e2;
    padding: 8px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background 0.2s, border-color 0.2s;
    color: #333;
}

    .btn-icon:hover[b-vqkw3kwxl7] {
        background: #f5f5f5;
        border-color: #ccc;
    }

    .btn-icon .badge[b-vqkw3kwxl7] {
        position: absolute;
        top: -3px;
        right: -3px;
        background: #DA3743;
        color: #fff;
        font-size: 9px;
        padding: 2px 4px;
        border-radius: 10px;
        font-weight: 600;
    }

.btn-user[b-vqkw3kwxl7] {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 10px;
    border-radius: 8px;
    border: 1px solid #e2e2e2;
    background: #fff;
    cursor: pointer;
    transition: background 0.2s, border-color 0.2s;
    color: #1a1a1a;
}

    .btn-user:hover[b-vqkw3kwxl7] {
        background: #f5f5f5;
        border-color: #ccc;
    }

    .btn-user i[b-vqkw3kwxl7] {
        font-size: 12px;
        opacity: 0.7;
    }

.user-avatar[b-vqkw3kwxl7] {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: #DA3743;
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.user-name[b-vqkw3kwxl7] {
    font-size: 13px;
    font-weight: 600;
    color: #1a1a1a;
}

.dropdown-item[b-vqkw3kwxl7] {
    font-weight: 500;
    font-size: 13px;
    padding: 6px 16px;
    display: flex;
    align-items: center;
    color: #4a4a4a;
    width: 100%;
}

button.dropdown-item[b-vqkw3kwxl7] {
    border: none;
    background: none;
    text-align: left;
}

.dropdown-item:hover[b-vqkw3kwxl7] {
    background-color: #f7f7f7;
}

.dropdown-item i[b-vqkw3kwxl7] {
    font-size: 14px !important;
    opacity: 0.7;
    display: inline-flex;
    align-items: center;
    width: 20px;
}

.admin-nav[b-vqkw3kwxl7] {
    background: #fff;
    border-bottom: 1px solid #e8e8e8;
    position: sticky;
    top: 0;
    z-index: 999;
}

.nav-content[b-vqkw3kwxl7] {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    padding: 0.5rem 1rem;
    gap: 1rem;
    margin-top: 0.5rem;
    margin-bottom: 0.5rem;
}

@media (min-width: 992px) {
    .nav-content[b-vqkw3kwxl7] {
        justify-content: center;
        padding: 0.5rem 2rem;
        flex-wrap: nowrap;
    }
}

.navbar-toggler[b-vqkw3kwxl7] {
    border: none;
    background: #f8f9fa;
    padding: 0.4rem 0.75rem;
    border-radius: 8px;
    cursor: pointer;
}

    .navbar-toggler i[b-vqkw3kwxl7] {
        font-size: 1.4rem;
        color: #333;
    }

.navbar-collapse[b-vqkw3kwxl7] {
    width: 100%;
}

.nav-links[b-vqkw3kwxl7] {
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: 0.5rem 0;
}

@media (min-width: 992px) {
    .navbar-toggler[b-vqkw3kwxl7] {
        display: none;
    }

    .navbar-collapse[b-vqkw3kwxl7] {
        display: block !important;
        flex: 1;
    }

    .nav-links[b-vqkw3kwxl7] {
        flex-direction: row;
        flex-wrap: nowrap;
        padding: 0;
        gap: 2px;
        justify-content: center;
    }
}

.nav-link[b-vqkw3kwxl7] {
    color: #666;
    text-decoration: none;
    font-weight: 700;
    font-size: 0.875rem;
    padding: 0.6rem 0.9rem;
    border-radius: 8px;
    transition: all 0.2s;
    display: block;
    white-space: nowrap;
}

    .nav-link:hover[b-vqkw3kwxl7] {
        background: #f8f9fa;
        color: #bf2d38;
    }

    .nav-link.active[b-vqkw3kwxl7] {
        background: #f8f9fa;
        color: #bf2d38;
    }
/* /Layout/CustomerLayout.razor.rz.scp.css */
/* ================= THIẾT LẬP LAYOUT 100VH ================= */
/* Khối này bọc Header + Content, luôn cao tối thiểu bằng đúng 1 màn hình */
.main-viewport[b-93vbh14vdz] {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

/* Tự động giãn ra lấp đầy khoảng trống, đẩy Footer xuống sát mép dưới */
.customer-content[b-93vbh14vdz] {
    flex: 1;
}

/* ================= FOOTER SECTION ================= */
.customer-footer[b-93vbh14vdz] {
    background-color: #2d333f;
    color: #f3f4f6;
    padding-top: 3rem;
    padding-bottom: 3rem;
    /* Đã xóa margin-top để footer dính liền mạch vào mép dưới màn hình */
}

.brand-name-footer[b-93vbh14vdz] {
    font-weight: 800;
    font-size: 1.2rem;
    letter-spacing: -0.5px;
    color: #ffffff;
}

.footer-desc[b-93vbh14vdz] {
    font-size: 0.75rem;
    color: #9ca3af;
    line-height: 1.6;
}

.footer-heading[b-93vbh14vdz] {
    color: #ffffff;
    font-weight: 700;
    font-size: 1rem;
    margin-bottom: 1.25rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.footer-links[b-93vbh14vdz] {
    list-style: none;
    padding: 0;
    margin: 0;
}

    .footer-links li[b-93vbh14vdz] {
        margin-bottom: 0.85rem;
        font-size: 0.75rem;
        color: #9ca3af;
        display: flex;
        align-items: center;
    }

    .footer-links a[b-93vbh14vdz] {
        color: #9ca3af;
        text-decoration: none;
        transition: color 0.2s ease, transform 0.2s ease;
        display: inline-block;
    }

        /* Hiệu ứng trượt ngang nhẹ khi hover link */
        .footer-links a:hover[b-93vbh14vdz] {
            color: #DA3743;
            transform: translateX(5px);
        }

    .footer-links i[b-93vbh14vdz] {
        color: #DA3743;
    }

/* Khu vực Mạng xã hội */
.footer-social[b-93vbh14vdz] {
    display: flex;
    gap: 0.75rem;
}

    .footer-social a[b-93vbh14vdz] {
        width: 38px;
        height: 38px;
        border-radius: 8px; /* Bo góc vuông nhẹ thay vì tròn vo */
        background: rgba(255, 255, 255, 0.05);
        display: flex;
        align-items: center;
        justify-content: center;
        color: #ffffff;
        font-size: 1.1rem;
        transition: all 0.3s ease;
        border: 1px solid rgba(255, 255, 255, 0.1);
    }

        /* Hiệu ứng nảy lên và đổi màu nền khi hover Icon */
        .footer-social a:hover[b-93vbh14vdz] {
            background: #DA3743;
            border-color: #DA3743;
            transform: translateY(-4px);
        }

.footer-divider[b-93vbh14vdz] {
    border-color: rgba(255, 255, 255, 0.1);
    margin: 0;
}

/* Khu vực bản quyền dưới cùng */
.footer-bottom[b-93vbh14vdz] {
    font-size: 0.85rem;
    color: #9ca3af;
}

.bottom-links a[b-93vbh14vdz] {
    color: #9ca3af;
    text-decoration: none;
    transition: color 0.2s;
}

    .bottom-links a:hover[b-93vbh14vdz] {
        color: #ffffff;
    }
/* /Layout/StaffLayout.razor.rz.scp.css */
.staff-content[b-02lhl20vnm] {
    background: #fff;
    min-height: calc(100vh - 89px - 85px);
    border-top: 1px solid #e8e8e8;
}
/* /Pages/Admin/Bookings.razor.rz.scp.css */
.table > :not(caption) > * > *[b-fmjkxgzibg] {
    padding: 0.75rem 0.75rem;
    border-right: 1px solid #e9ecef;
}

    .table > :not(caption) > * > *:last-child[b-fmjkxgzibg] {
        border-right: none;
    }

.table tbody tr[b-fmjkxgzibg] {
    border-bottom: 1px solid #e9ecef;
}

    .table tbody tr:nth-of-type(odd)[b-fmjkxgzibg] {
        background-color: #ffffff !important;
    }

    .table tbody tr:nth-of-type(even)[b-fmjkxgzibg] {
        background-color: #f8f9fa !important;
    }

.table thead tr[b-fmjkxgzibg] {
    border-bottom: 2px solid #dee2e6;
}

.td-xs[b-fmjkxgzibg] {
    font-size: 0.75rem;
    padding: 2px 6px !important;
}

.table thead tr[b-fmjkxgzibg] {
    background-color: #e9ecef; /* đậm hơn bg-light một chút */
}

.text-muted[b-fmjkxgzibg] {
    font-size: 0.75rem;
    opacity: 0.7;
}

.table-container[b-fmjkxgzibg] {
    border: 1px solid #dee2e6;
    border-radius: 0.375rem;
    overflow: hidden;
    margin: 0 12px 0;
}

.action-btn[b-fmjkxgzibg] {
    padding: 2px 6px;
}

    .action-btn i[b-fmjkxgzibg] {
        font-size: 0.85rem;
    }


    .action-btn.btn-outline-primary:hover[b-fmjkxgzibg] {
        background-color: transparent !important;
        color: #0b5ed7; /* đậm hơn primary */
    }

    .action-btn.btn-outline-danger:hover[b-fmjkxgzibg] {
        background-color: transparent !important;
        color: #b02a37; /* đậm hơn danger */
    }

.form-control[b-fmjkxgzibg],
.btn[b-fmjkxgzibg] {
    box-shadow: none !important;
}

.table-hover tbody tr:hover[b-fmjkxgzibg] {
    background-color: inherit !important;
}

.btn-primary[b-fmjkxgzibg] {
    font-size: 0.875rem;
}

.small-placeholder[b-fmjkxgzibg]::placeholder {
    font-size: 0.75rem;
    opacity: 0.7;
}


.badge[b-fmjkxgzibg] {
    font-weight: 500;
    letter-spacing: 0.3px;
}

.bg-success-subtle[b-fmjkxgzibg] {
    background-color: #d1f2eb !important;
}

.text-success[b-fmjkxgzibg] {
    color: #17a2b8 !important;
}

.bg-danger-subtle[b-fmjkxgzibg] {
    background-color: #f8d7da !important;
}

.text-danger[b-fmjkxgzibg] {
    color: #dc3545 !important;
}

.bg-warning-subtle[b-fmjkxgzibg] {
    background-color: #fff3cd !important;
}

.text-warning[b-fmjkxgzibg] {
    color: #ffc107 !important;
}

.page-link[b-fmjkxgzibg] {
    color: #6c757d;
}

.page-item.active .page-link[b-fmjkxgzibg] {
    background-color: #007bff;
    border-color: #007bff;
}

.btn-outline-primary:hover[b-fmjkxgzibg],
.btn-outline-danger:hover[b-fmjkxgzibg],
.btn-outline-secondary:hover[b-fmjkxgzibg] {
    opacity: 1;
}

.card[b-fmjkxgzibg] {
    overflow: hidden;
}

thead th[b-fmjkxgzibg] {
    position: sticky;
    top: 0;
    background-color: #f8f9fa;
    z-index: 10;
}

.pagination-sm .page-link[b-fmjkxgzibg] {
    font-size: 0.7rem;
    padding: 0.15rem 0.4rem;
}

.btn-outline-success.action-btn:hover[b-fmjkxgzibg] {
    background-color: transparent !important;
    color: #198754 !important;
    opacity: 0.8;
}

.filter-input[b-fmjkxgzibg] {
    font-size: 0.85rem !important; /* Thu nhỏ chữ */

    padding: 0.4rem 0.75rem;
    border-radius: 6px;
    height: 35px; /* Giảm nhẹ chiều cao của ô nhập liệu */
}



    /* Thu nhỏ chữ của placeholder (dòng chữ mờ) */

    .filter-input[b-fmjkxgzibg]::placeholder {
        font-size: 0.8rem;
        opacity: 0.7;
    }



/* Custom cho nút Xóa lọc để đồng bộ kích thước với các ô input */

.btn-clear-filter[b-fmjkxgzibg] {
    font-size: 0.85rem !important;
    padding: 0.4rem 0.75rem;
    border-radius: 6px;
    height: 35px;
    display: flex;
    align-items: center;
    justify-content: center;
}
/* /Pages/Admin/Categories.razor.rz.scp.css */
.table > :not(caption) > * > *[b-wjy0b3jjdg] {
    padding: 0.75rem 0.75rem;
    border-right: 1px solid #e9ecef;
}

    .table > :not(caption) > * > *:last-child[b-wjy0b3jjdg] {
        border-right: none;
    }

.table tbody tr[b-wjy0b3jjdg] {
    border-bottom: 1px solid #e9ecef;
}

    .table tbody tr:nth-of-type(odd)[b-wjy0b3jjdg] {
        background-color: #ffffff !important;
    }

    .table tbody tr:nth-of-type(even)[b-wjy0b3jjdg] {
        background-color: #f8f9fa !important;
    }

.table thead tr[b-wjy0b3jjdg] {
    border-bottom: 2px solid #dee2e6;
}

.td-xs[b-wjy0b3jjdg] {
    font-size: 0.75rem;
    padding: 2px 6px !important;
}

.table thead tr[b-wjy0b3jjdg] {
    background-color: #e9ecef; /* đậm hơn bg-light một chút */
}

.text-muted[b-wjy0b3jjdg] {
    font-size: 0.75rem;
    opacity: 0.7;
}

.table-container[b-wjy0b3jjdg] {
    border: 1px solid #dee2e6;
    border-radius: 0.375rem;
    overflow: hidden;
    margin: 0 12px 0;
}

.action-btn[b-wjy0b3jjdg] {
    padding: 2px 6px;
}

    .action-btn i[b-wjy0b3jjdg] {
        font-size: 0.85rem;
    }


    .action-btn.btn-outline-primary:hover[b-wjy0b3jjdg] {
        background-color: transparent !important;
        color: #0b5ed7; /* đậm hơn primary */
    }

    .action-btn.btn-outline-danger:hover[b-wjy0b3jjdg] {
        background-color: transparent !important;
        color: #b02a37; /* đậm hơn danger */
    }

.form-control[b-wjy0b3jjdg],
.btn[b-wjy0b3jjdg] {
    box-shadow: none !important;
}

.table-hover tbody tr:hover[b-wjy0b3jjdg] {
    background-color: inherit !important;
}

.btn-primary[b-wjy0b3jjdg] {
    font-size: 0.875rem;
}

.small-placeholder[b-wjy0b3jjdg]::placeholder {
    font-size: 0.75rem;
    opacity: 0.7;
}


.badge[b-wjy0b3jjdg] {
    font-weight: 500;
    letter-spacing: 0.3px;
}

.bg-success-subtle[b-wjy0b3jjdg] {
    background-color: #d1f2eb !important;
}

.text-success[b-wjy0b3jjdg] {
    color: #17a2b8 !important;
}

.bg-danger-subtle[b-wjy0b3jjdg] {
    background-color: #f8d7da !important;
}

.text-danger[b-wjy0b3jjdg] {
    color: #dc3545 !important;
}

.bg-warning-subtle[b-wjy0b3jjdg] {
    background-color: #fff3cd !important;
}

.text-warning[b-wjy0b3jjdg] {
    color: #ffc107 !important;
}

.page-link[b-wjy0b3jjdg] {
    color: #6c757d;
}

.page-item.active .page-link[b-wjy0b3jjdg] {
    background-color: #007bff;
    border-color: #007bff;
}

.btn-outline-primary:hover[b-wjy0b3jjdg],
.btn-outline-danger:hover[b-wjy0b3jjdg],
.btn-outline-secondary:hover[b-wjy0b3jjdg] {
    opacity: 1;
}

.card[b-wjy0b3jjdg] {
    overflow: hidden;
}

thead th[b-wjy0b3jjdg] {
    position: sticky;
    top: 0;
    background-color: #f8f9fa;
    z-index: 10;
}

.pagination-sm .page-link[b-wjy0b3jjdg] {
    font-size: 0.7rem;
    padding: 0.15rem 0.4rem;
}

.filter-input[b-wjy0b3jjdg] {
    font-size: 0.85rem !important; /* Thu nhỏ chữ */

    padding: 0.4rem 0.75rem;
    border-radius: 6px;
    height: 35px; /* Giảm nhẹ chiều cao của ô nhập liệu */
}



    /* Thu nhỏ chữ của placeholder (dòng chữ mờ) */

    .filter-input[b-wjy0b3jjdg]::placeholder {
        font-size: 0.8rem;
        opacity: 0.7;
    }
/* /Pages/Admin/Components/BookingDetailModal.razor.rz.scp.css */
/* ===== BACKDROP ===== */
.modal[b-5ipcs942oh] {
    background-color: rgba(0,0,0,0.5);
}

/* ===== MODAL TITLE ===== */
.modal-title[b-5ipcs942oh] {
    font-size: 0.9rem;
    font-weight: 600;
}

/* ===== LABEL ===== */
.modal .form-label[b-5ipcs942oh] {
    font-size: 0.75rem;
    font-weight: 600;
    color: #495057;
    margin-bottom: 4px;
}

/* ===== INPUT / TEXTAREA ===== */
.modal .form-control[b-5ipcs942oh] {
    font-size: 0.8rem;
    padding: 6px 10px;
    background-color: #f8f9fa;
    cursor: default;
}

/* ===== SWITCH ===== */
.modal .form-check-input[b-5ipcs942oh] {
    cursor: default;
}

.btn-cancel[b-5ipcs942oh] {
    background-color: #f8f9fa;
    color: #6c757d;
    border: 1px solid #dcdfe4;
    font-weight: 600;
    font-size: 0.75rem; /* Chữ nhỏ */
    padding: 6px 16px !important;
    border-radius: 6px;
    transition: all 0.2s ease;
}

    .btn-cancel:hover[b-5ipcs942oh] {
        background-color: #e9ecef;
        color: #343a40;
        border-color: #adb5bd;
    }

/* ===== ANIMATION ===== */
.modal-show[b-5ipcs942oh] {
    animation: fadeIn-b-5ipcs942oh 0.2s ease-out forwards;
}

.modal-dialog-top[b-5ipcs942oh] {
    margin: 2rem auto;
    animation: slideDown-b-5ipcs942oh 0.25s ease-out forwards;
}

@keyframes fadeIn-b-5ipcs942oh {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

@keyframes slideDown-b-5ipcs942oh {
    from {
        transform: translateY(-30px);
        opacity: 0;
    }

    to {
        transform: translateY(0);
        opacity: 1;
    }
}

/* ===== OPEN ===== */
.modal-show[b-5ipcs942oh] {
    animation: fadeIn-b-5ipcs942oh 0.2s ease-out forwards;
}

/* ===== CLOSE ===== */
.modal-hide[b-5ipcs942oh] {
    animation: fadeOut-b-5ipcs942oh 0.2s ease-in forwards;
}

/* ===== DIALOG ===== */
.modal-dialog-top[b-5ipcs942oh] {
    margin: 2rem auto;
    animation: slideDown-b-5ipcs942oh 0.25s ease-out forwards;
}

/* khi đóng thì dialog trượt lên */
.modal-hide .modal-dialog-top[b-5ipcs942oh] {
    animation: slideUp-b-5ipcs942oh 0.2s ease-in forwards;
}

/* ===== KEYFRAMES ===== */
@keyframes fadeOut-b-5ipcs942oh {
    from {
        opacity: 1;
    }

    to {
        opacity: 0;
    }
}

@keyframes slideUp-b-5ipcs942oh {
    from {
        transform: translateY(0);
        opacity: 1;
    }

    to {
        transform: translateY(-20px);
        opacity: 0;
    }
}
/* /Pages/Admin/Components/BookingModal.razor.rz.scp.css */
/* Kế thừa UI nhưng thu nhỏ chữ và form */

.modal-body[b-vov4myfak5] {
    font-size: 0.85rem;
}

.modal-title[b-vov4myfak5] {
    font-size: 1.1rem !important;
}

.modal .form-label[b-vov4myfak5] {
    font-size: 0.8rem;
    font-weight: 600;
    color: #495057;
    margin-bottom: 4px;
}

.modal .form-control[b-vov4myfak5],
.modal .form-select[b-vov4myfak5] {
    font-size: 0.8rem;
    padding: 5px 10px;
}

.modal h6.fw-bold[b-vov4myfak5] {
    font-size: 0.9rem;
}

.table th[b-vov4myfak5], .table td[b-vov4myfak5] {
    font-size: 0.85rem !important;
}

/* Nút tăng giảm số lượng */
.qty-micro[b-vov4myfak5] {
    padding: 2px;
    min-width: 60px;
    justify-content: space-between;
}

.btn-micro[b-vov4myfak5] {
    background: transparent;
    border: none;
    padding: 0;
    width: 18px;
    height: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #495057;
    border-radius: 4px;
    transition: 0.15s ease;
    font-size: 0.8rem;
}

    .btn-micro:hover[b-vov4myfak5] {
        background: #e9ecef;
        color: #DA3743;
    }

.qty-val-micro[b-vov4myfak5] {
    font-size: 0.8rem !important;
}

/* Thanh thêm món */
.add-item-bar[b-vov4myfak5] {
    border-color: #e9ecef !important;
    padding: 10px !important; /* Giảm padding */
}

    .add-item-bar .form-select-sm[b-vov4myfak5],
    .add-item-bar .form-control-sm[b-vov4myfak5],
    .add-item-bar .btn-sm[b-vov4myfak5] {
        height: 32px; /* Thu gọn chiều cao */
        font-size: 0.8rem;
    }

.btn-custom-add[b-vov4myfak5] {
    background-color: #fff;
    color: #DA3743;
    border: 1px solid #DA3743;
    font-weight: 500;
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 32px;
}

    .btn-custom-add:hover:not(:disabled)[b-vov4myfak5] {
        background-color: #DA3743;
        color: #fff;
    }

    .btn-custom-add:disabled[b-vov4myfak5] {
        border-color: #ced4da;
        color: #6c757d;
        background-color: #f8f9fa;
        cursor: not-allowed;
    }

/* Nút dưới Footer */
.btn-cancel[b-vov4myfak5] {
    background-color: #f8f9fa;
    color: #6c757d;
    border: 1px solid #dcdfe4;
    font-weight: 600;
    font-size: 0.75rem; /* Chữ nhỏ */
    padding: 6px 16px !important;
    border-radius: 6px;
    transition: all 0.2s ease;
}

    .btn-cancel:hover[b-vov4myfak5] {
        background-color: #e9ecef;
        color: #343a40;
        border-color: #adb5bd;
    }

.btn-save[b-vov4myfak5] {
    background-color: #0d6efd;
    color: #ffffff;
    border: 1px solid #0d6efd;
    font-weight: 600;
    font-size: 0.75rem; /* Chữ nhỏ */
    padding: 6px 16px !important;
    border-radius: 6px;
    transition: all 0.3s;
    display: inline-flex;
    align-items: center;
}

    .btn-save:hover:not(:disabled)[b-vov4myfak5] {
        background-color: #0b5ed7;
        border-color: #0a58ca;
        color: #ffffff;
    }

.border-dashed[b-vov4myfak5] {
    border-style: dashed !important;
}

/* Modal Error */
.modal-error[b-vov4myfak5] {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    background: #fdecea;
    color: #c0392b;
    padding: 8px 12px;
    border-radius: 6px;
    font-size: 0.8rem; /* Chữ nhỏ */
    animation: slideDown-b-vov4myfak5 0.25s ease-out;
}

    .modal-error i[b-vov4myfak5] {
        font-size: 14px;
        flex-shrink: 0;
        margin-top: 2px;
    }

    .modal-error ul[b-vov4myfak5] {
        margin: 0;
        padding-left: 16px;
        flex: 1;
    }

    .modal-error li[b-vov4myfak5] {
        list-style: disc;
        line-height: 1.4;
    }

/* Animations Modal */
.modal-show[b-vov4myfak5] {
    animation: fadeIn-b-vov4myfak5 0.2s ease-out forwards;
}

.modal-hide[b-vov4myfak5] {
    animation: fadeOut-b-vov4myfak5 0.2s ease-in forwards;
}

.modal-dialog-top[b-vov4myfak5] {
    margin: 2rem auto;
    animation: slideDown-b-vov4myfak5 0.25s ease-out forwards;
}

.modal-hide .modal-dialog-top[b-vov4myfak5] {
    animation: slideUp-b-vov4myfak5 0.2s ease-in forwards;
}

@keyframes fadeIn-b-vov4myfak5 {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

@keyframes fadeOut-b-vov4myfak5 {
    from {
        opacity: 1;
    }

    to {
        opacity: 0;
    }
}

@keyframes slideDown-b-vov4myfak5 {
    from {
        transform: translateY(-30px);
        opacity: 0;
    }

    to {
        transform: translateY(0);
        opacity: 1;
    }
}

@keyframes slideUp-b-vov4myfak5 {
    from {
        transform: translateY(0);
        opacity: 1;
    }

    to {
        transform: translateY(-20px);
        opacity: 0;
    }
}

.modal[b-vov4myfak5] {
    background-color: rgba(0,0,0,0.5);
}

@media (max-width: 768px) {
    .add-item-bar > div[b-vov4myfak5] {
        width: 100% !important;
    }
}
/* /Pages/Admin/Components/CategoryDetailModal.razor.rz.scp.css */
/* ===== BACKDROP ===== */
.modal[b-d7lz5cgpkj] {
    background-color: rgba(0,0,0,0.5);
}

/* ===== MODAL TITLE ===== */
.modal-title[b-d7lz5cgpkj] {
    font-size: 0.9rem;
    font-weight: 600;
}

/* ===== LABEL ===== */
.modal .form-label[b-d7lz5cgpkj] {
    font-size: 0.75rem;
    font-weight: 600;
    color: #495057;
    margin-bottom: 4px;
}

/* ===== INPUT / TEXTAREA ===== */
.modal .form-control[b-d7lz5cgpkj] {
    font-size: 0.8rem;
    padding: 6px 10px;
    background-color: #f8f9fa;
    cursor: default;
}

/* ===== SWITCH ===== */
.modal .form-check-input[b-d7lz5cgpkj] {
    cursor: default;
}

.btn-cancel[b-d7lz5cgpkj] {
    background-color: #f8f9fa;
    color: #6c757d;
    border: 1px solid #dcdfe4;
    font-weight: 600;
    font-size: 0.75rem; /* Chữ nhỏ */
    padding: 6px 16px !important;
    border-radius: 6px;
    transition: all 0.2s ease;
}

    .btn-cancel:hover[b-d7lz5cgpkj] {
        background-color: #e9ecef;
        color: #343a40;
        border-color: #adb5bd;
    }

/* ===== ANIMATION ===== */
.modal-show[b-d7lz5cgpkj] {
    animation: fadeIn-b-d7lz5cgpkj 0.2s ease-out forwards;
}

.modal-dialog-top[b-d7lz5cgpkj] {
    margin: 2rem auto;
    animation: slideDown-b-d7lz5cgpkj 0.25s ease-out forwards;
}

@keyframes fadeIn-b-d7lz5cgpkj {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

@keyframes slideDown-b-d7lz5cgpkj {
    from {
        transform: translateY(-30px);
        opacity: 0;
    }

    to {
        transform: translateY(0);
        opacity: 1;
    }
}

/* ===== OPEN ===== */
.modal-show[b-d7lz5cgpkj] {
    animation: fadeIn-b-d7lz5cgpkj 0.2s ease-out forwards;
}

/* ===== CLOSE ===== */
.modal-hide[b-d7lz5cgpkj] {
    animation: fadeOut-b-d7lz5cgpkj 0.2s ease-in forwards;
}

/* ===== DIALOG ===== */
.modal-dialog-top[b-d7lz5cgpkj] {
    margin: 2rem auto;
    animation: slideDown-b-d7lz5cgpkj 0.25s ease-out forwards;
}

/* khi đóng thì dialog trượt lên */
.modal-hide .modal-dialog-top[b-d7lz5cgpkj] {
    animation: slideUp-b-d7lz5cgpkj 0.2s ease-in forwards;
}

/* ===== KEYFRAMES ===== */
@keyframes fadeOut-b-d7lz5cgpkj {
    from {
        opacity: 1;
    }

    to {
        opacity: 0;
    }
}

@keyframes slideUp-b-d7lz5cgpkj {
    from {
        transform: translateY(0);
        opacity: 1;
    }

    to {
        transform: translateY(-20px);
        opacity: 0;
    }
}
/* /Pages/Admin/Components/CategoryModal.razor.rz.scp.css */
.modal-dialog-top[b-e3q58x79t0] {
    margin: 2rem auto;
    animation: slideDown-b-e3q58x79t0 0.3s ease-out;
}

.modal-title[b-e3q58x79t0] {
    font-size: 0.9rem; /* nhỏ hơn h5 mặc định */
    font-weight: 600; /* đậm vừa, không gắt */
}

.modal .form-label[b-e3q58x79t0] {
    font-size: 0.75rem;
    font-weight: 600;
    color: #495057;
    margin-bottom: 4px;
}

.modal .form-control[b-e3q58x79t0] {
    font-size: 0.8rem; /* nhỏ chữ khi nhập */
    padding: 6px 10px; /* gọn chiều cao */
}

.btn-cancel[b-e3q58x79t0] {
    background-color: #f8f9fa;
    color: #6c757d;
    border: 1px solid #dcdfe4;
    font-weight: 600;
    font-size: 0.75rem; /* Chữ nhỏ */
    padding: 6px 16px !important;
    border-radius: 6px;
    transition: all 0.2s ease;
}

    .btn-cancel:hover[b-e3q58x79t0] {
        background-color: #e9ecef;
        color: #343a40;
        border-color: #adb5bd;
    }

.btn-save[b-e3q58x79t0] {
    background-color: #0d6efd;
    color: #ffffff;
    border: 1px solid #0d6efd;
    font-weight: 600;
    font-size: 0.75rem; /* Chữ nhỏ */
    padding: 6px 16px !important;
    border-radius: 6px;
    transition: all 0.3s;
    display: inline-flex;
    align-items: center;
}

    .btn-save:hover:not(:disabled)[b-e3q58x79t0] {
        background-color: #0b5ed7;
        border-color: #0a58ca;
        color: #ffffff;
    }

@keyframes slideDown-b-e3q58x79t0 {
    from {
        transform: translateY(-100px);
        opacity: 0;
    }

    to {
        transform: translateY(0);
        opacity: 1;
    }
}

.modal.fade.show[b-e3q58x79t0] {
    animation: fadeIn-b-e3q58x79t0 0.3s ease-out;
}

@keyframes fadeIn-b-e3q58x79t0 {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

/* nền mờ */
.modal[b-e3q58x79t0] {
    background-color: rgba(0,0,0,0.5);
}

/* OPEN */
.modal-show[b-e3q58x79t0] {
    animation: fadeIn-b-e3q58x79t0 0.2s ease-out forwards;
}

/* CLOSE */
.modal-hide[b-e3q58x79t0] {
    animation: fadeOut-b-e3q58x79t0 0.2s ease-in forwards;
}

/* dialog */
.modal-dialog-top[b-e3q58x79t0] {
    margin: 2rem auto;
    animation: slideDown-b-e3q58x79t0 0.25s ease-out forwards;
}

/* khi đóng thì slide lên nhẹ */
.modal-hide .modal-dialog-top[b-e3q58x79t0] {
    animation: slideUp-b-e3q58x79t0 0.2s ease-in forwards;
}

/* keyframes */
@keyframes fadeIn-b-e3q58x79t0 {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

@keyframes fadeOut-b-e3q58x79t0 {
    from {
        opacity: 1;
    }

    to {
        opacity: 0;
    }
}

@keyframes slideDown-b-e3q58x79t0 {
    from {
        transform: translateY(-30px);
        opacity: 0;
    }

    to {
        transform: translateY(0);
        opacity: 1;
    }
}

@keyframes slideUp-b-e3q58x79t0 {
    from {
        transform: translateY(0);
        opacity: 1;
    }

    to {
        transform: translateY(-20px);
        opacity: 0;
    }
}

/* Error giống login */
.modal-error[b-e3q58x79t0] {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    background: #fdecea;
    color: #c0392b;
    padding: 10px 12px;
    border-radius: 8px;
    font-size: 12px;
    margin: 0 16px 12px;
}

    .modal-error i[b-e3q58x79t0] {
        font-size: 16px;
        flex-shrink: 0;
        margin-top: 1px;
    }

    .modal-error ul[b-e3q58x79t0] {
        margin: 0;
        padding-left: 16px;
        flex: 1;
    }

    .modal-error li[b-e3q58x79t0] {
        list-style: disc;
        line-height: 1.4;
    }

.modal-error[b-e3q58x79t0] {
    animation: slideDown-b-e3q58x79t0 0.25s ease-out;
}
/* /Pages/Admin/Components/MenuItemDetailModal.razor.rz.scp.css */
/* ===== BACKDROP ===== */
.modal[b-0z4gdhaj6l] {
    background-color: rgba(0,0,0,0.5);
}

/* ===== MODAL TITLE ===== */
.modal-title[b-0z4gdhaj6l] {
    font-size: 0.9rem;
    font-weight: 600;
}

/* ===== LABEL ===== */
.modal .form-label[b-0z4gdhaj6l] {
    font-size: 0.75rem;
    font-weight: 600;
    color: #495057;
    margin-bottom: 4px;
}

/* ===== INPUT / TEXTAREA ===== */
.modal .form-control[b-0z4gdhaj6l] {
    font-size: 0.8rem;
    padding: 6px 10px;
    background-color: #f8f9fa;
    cursor: default;
}

/* ===== SWITCH ===== */
.modal .form-check-input[b-0z4gdhaj6l] {
    cursor: default;
}

.btn-cancel[b-0z4gdhaj6l] {
    background-color: #f8f9fa;
    color: #6c757d;
    border: 1px solid #dcdfe4;
    font-weight: 600;
    font-size: 0.75rem; /* Chữ nhỏ */
    padding: 6px 16px !important;
    border-radius: 6px;
    transition: all 0.2s ease;
}

    .btn-cancel:hover[b-0z4gdhaj6l] {
        background-color: #e9ecef;
        color: #343a40;
        border-color: #adb5bd;
    }

/* ===== ANIMATION ===== */
.modal-show[b-0z4gdhaj6l] {
    animation: fadeIn-b-0z4gdhaj6l 0.2s ease-out forwards;
}

.modal-dialog-top[b-0z4gdhaj6l] {
    margin: 2rem auto;
    animation: slideDown-b-0z4gdhaj6l 0.25s ease-out forwards;
}

@keyframes fadeIn-b-0z4gdhaj6l {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

@keyframes slideDown-b-0z4gdhaj6l {
    from {
        transform: translateY(-30px);
        opacity: 0;
    }

    to {
        transform: translateY(0);
        opacity: 1;
    }
}

/* ===== OPEN ===== */
.modal-show[b-0z4gdhaj6l] {
    animation: fadeIn-b-0z4gdhaj6l 0.2s ease-out forwards;
}

/* ===== CLOSE ===== */
.modal-hide[b-0z4gdhaj6l] {
    animation: fadeOut-b-0z4gdhaj6l 0.2s ease-in forwards;
}

/* ===== DIALOG ===== */
.modal-dialog-top[b-0z4gdhaj6l] {
    margin: 2rem auto;
    animation: slideDown-b-0z4gdhaj6l 0.25s ease-out forwards;
}

/* khi đóng thì dialog trượt lên */
.modal-hide .modal-dialog-top[b-0z4gdhaj6l] {
    animation: slideUp-b-0z4gdhaj6l 0.2s ease-in forwards;
}

/* ===== KEYFRAMES ===== */
@keyframes fadeOut-b-0z4gdhaj6l {
    from {
        opacity: 1;
    }

    to {
        opacity: 0;
    }
}

@keyframes slideUp-b-0z4gdhaj6l {
    from {
        transform: translateY(0);
        opacity: 1;
    }

    to {
        transform: translateY(-20px);
        opacity: 0;
    }
}
/* /Pages/Admin/Components/MenuItemModal.razor.rz.scp.css */
.modal-dialog-top[b-8wla3bdzyj] {
    margin: 2rem auto;
    animation: slideDown-b-8wla3bdzyj 0.3s ease-out;
}

.modal-title[b-8wla3bdzyj] {
    font-size: 0.9rem; /* nhỏ hơn h5 mặc định */
    font-weight: 600; /* đậm vừa, không gắt */
}

.modal .form-label[b-8wla3bdzyj] {
    font-size: 0.75rem;
    font-weight: 600;
    color: #495057;
    margin-bottom: 4px;
}

.modal .form-control[b-8wla3bdzyj] {
    font-size: 0.8rem; /* nhỏ chữ khi nhập */
    padding: 6px 10px; /* gọn chiều cao */
}

.btn-cancel[b-8wla3bdzyj] {
    background-color: #f8f9fa;
    color: #6c757d;
    border: 1px solid #dcdfe4;
    font-weight: 600;
    font-size: 0.75rem; /* Chữ nhỏ */
    padding: 6px 16px !important;
    border-radius: 6px;
    transition: all 0.2s ease;
}

    .btn-cancel:hover[b-8wla3bdzyj] {
        background-color: #e9ecef;
        color: #343a40;
        border-color: #adb5bd;
    }

.btn-save[b-8wla3bdzyj] {
    background-color: #0d6efd;
    color: #ffffff;
    border: 1px solid #0d6efd;
    font-weight: 600;
    font-size: 0.75rem; /* Chữ nhỏ */
    padding: 6px 16px !important;
    border-radius: 6px;
    transition: all 0.3s;
    display: inline-flex;
    align-items: center;
}

    .btn-save:hover:not(:disabled)[b-8wla3bdzyj] {
        background-color: #0b5ed7;
        border-color: #0a58ca;
        color: #ffffff;
    }

@keyframes slideDown-b-8wla3bdzyj {
    from {
        transform: translateY(-100px);
        opacity: 0;
    }

    to {
        transform: translateY(0);
        opacity: 1;
    }
}

.modal.fade.show[b-8wla3bdzyj] {
    animation: fadeIn-b-8wla3bdzyj 0.3s ease-out;
}

@keyframes fadeIn-b-8wla3bdzyj {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

/* nền mờ */
.modal[b-8wla3bdzyj] {
    background-color: rgba(0,0,0,0.5);
}

/* OPEN */
.modal-show[b-8wla3bdzyj] {
    animation: fadeIn-b-8wla3bdzyj 0.2s ease-out forwards;
}

/* CLOSE */
.modal-hide[b-8wla3bdzyj] {
    animation: fadeOut-b-8wla3bdzyj 0.2s ease-in forwards;
}

/* dialog */
.modal-dialog-top[b-8wla3bdzyj] {
    margin: 2rem auto;
    animation: slideDown-b-8wla3bdzyj 0.25s ease-out forwards;
}

/* khi đóng thì slide lên nhẹ */
.modal-hide .modal-dialog-top[b-8wla3bdzyj] {
    animation: slideUp-b-8wla3bdzyj 0.2s ease-in forwards;
}

/* keyframes */
@keyframes fadeIn-b-8wla3bdzyj {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

@keyframes fadeOut-b-8wla3bdzyj {
    from {
        opacity: 1;
    }

    to {
        opacity: 0;
    }
}

@keyframes slideDown-b-8wla3bdzyj {
    from {
        transform: translateY(-30px);
        opacity: 0;
    }

    to {
        transform: translateY(0);
        opacity: 1;
    }
}

@keyframes slideUp-b-8wla3bdzyj {
    from {
        transform: translateY(0);
        opacity: 1;
    }

    to {
        transform: translateY(-20px);
        opacity: 0;
    }
}

/* Error giống login */
.modal-error[b-8wla3bdzyj] {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    background: #fdecea;
    color: #c0392b;
    padding: 10px 12px;
    border-radius: 8px;
    font-size: 12px;
    margin: 0 16px 12px;
}

    .modal-error i[b-8wla3bdzyj] {
        font-size: 16px;
        flex-shrink: 0;
        margin-top: 1px;
    }

    .modal-error ul[b-8wla3bdzyj] {
        margin: 0;
        padding-left: 16px;
        flex: 1;
    }

    .modal-error li[b-8wla3bdzyj] {
        list-style: disc;
        line-height: 1.4;
    }

.modal-error[b-8wla3bdzyj] {
    animation: slideDown-b-8wla3bdzyj 0.25s ease-out;
}
/* /Pages/Admin/Components/TableDetailModal.razor.rz.scp.css */
/* ===== BACKDROP ===== */
.modal[b-7e1w3amavi] {
    background-color: rgba(0,0,0,0.5);
}

/* ===== MODAL TITLE ===== */
.modal-title[b-7e1w3amavi] {
    font-size: 0.9rem;
    font-weight: 600;
}

/* ===== LABEL ===== */
.modal .form-label[b-7e1w3amavi] {
    font-size: 0.75rem;
    font-weight: 600;
    color: #495057;
    margin-bottom: 4px;
}

/* ===== INPUT / TEXTAREA ===== */
.modal .form-control[b-7e1w3amavi] {
    font-size: 0.8rem;
    padding: 6px 10px;
    background-color: #f8f9fa;
    cursor: default;
}

/* ===== SWITCH ===== */
.modal .form-check-input[b-7e1w3amavi] {
    cursor: default;
}

/* ===== FOOTER BUTTON ===== */
.btn-cancel[b-7e1w3amavi] {
    background-color: #f8f9fa;
    color: #6c757d;
    border: 1px solid #dcdfe4;
    font-weight: 600;
    font-size: 0.75rem; /* Chữ nhỏ */
    padding: 6px 16px !important;
    border-radius: 6px;
    transition: all 0.2s ease;
}

    .btn-cancel:hover[b-7e1w3amavi] {
        background-color: #e9ecef;
        color: #343a40;
        border-color: #adb5bd;
    }

/* ===== ANIMATION ===== */
.modal-show[b-7e1w3amavi] {
    animation: fadeIn-b-7e1w3amavi 0.2s ease-out forwards;
}

.modal-dialog-top[b-7e1w3amavi] {
    margin: 2rem auto;
    animation: slideDown-b-7e1w3amavi 0.25s ease-out forwards;
}

@keyframes fadeIn-b-7e1w3amavi {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

@keyframes slideDown-b-7e1w3amavi {
    from {
        transform: translateY(-30px);
        opacity: 0;
    }

    to {
        transform: translateY(0);
        opacity: 1;
    }
}

/* ===== OPEN ===== */
.modal-show[b-7e1w3amavi] {
    animation: fadeIn-b-7e1w3amavi 0.2s ease-out forwards;
}

/* ===== CLOSE ===== */
.modal-hide[b-7e1w3amavi] {
    animation: fadeOut-b-7e1w3amavi 0.2s ease-in forwards;
}

/* ===== DIALOG ===== */
.modal-dialog-top[b-7e1w3amavi] {
    margin: 2rem auto;
    animation: slideDown-b-7e1w3amavi 0.25s ease-out forwards;
}

/* khi đóng thì dialog trượt lên */
.modal-hide .modal-dialog-top[b-7e1w3amavi] {
    animation: slideUp-b-7e1w3amavi 0.2s ease-in forwards;
}

/* ===== KEYFRAMES ===== */
@keyframes fadeOut-b-7e1w3amavi {
    from {
        opacity: 1;
    }

    to {
        opacity: 0;
    }
}

@keyframes slideUp-b-7e1w3amavi {
    from {
        transform: translateY(0);
        opacity: 1;
    }

    to {
        transform: translateY(-20px);
        opacity: 0;
    }
}
/* /Pages/Admin/Components/TableModal.razor.rz.scp.css */
.modal-dialog-top[b-5c0rq8ejmf] {
    margin: 2rem auto;
    animation: slideDown-b-5c0rq8ejmf 0.3s ease-out;
}

.modal-title[b-5c0rq8ejmf] {
    font-size: 0.9rem; /* nhỏ hơn h5 mặc định */
    font-weight: 600; /* đậm vừa, không gắt */
}

.modal .form-label[b-5c0rq8ejmf] {
    font-size: 0.75rem;
    font-weight: 600;
    color: #495057;
    margin-bottom: 4px;
}

.modal .form-control[b-5c0rq8ejmf] {
    font-size: 0.8rem; /* nhỏ chữ khi nhập */
    padding: 6px 10px; /* gọn chiều cao */
}

.btn-cancel[b-5c0rq8ejmf] {
    background-color: #f8f9fa;
    color: #6c757d;
    border: 1px solid #dcdfe4;
    font-weight: 600;
    font-size: 0.75rem; /* Chữ nhỏ */
    padding: 6px 16px !important;
    border-radius: 6px;
    transition: all 0.2s ease;
}

    .btn-cancel:hover[b-5c0rq8ejmf] {
        background-color: #e9ecef;
        color: #343a40;
        border-color: #adb5bd;
    }

.btn-save[b-5c0rq8ejmf] {
    background-color: #0d6efd;
    color: #ffffff;
    border: 1px solid #0d6efd;
    font-weight: 600;
    font-size: 0.75rem; /* Chữ nhỏ */
    padding: 6px 16px !important;
    border-radius: 6px;
    transition: all 0.3s;
    display: inline-flex;
    align-items: center;
}

    .btn-save:hover:not(:disabled)[b-5c0rq8ejmf] {
        background-color: #0b5ed7;
        border-color: #0a58ca;
        color: #ffffff;
    }

@keyframes slideDown-b-5c0rq8ejmf {
    from {
        transform: translateY(-100px);
        opacity: 0;
    }

    to {
        transform: translateY(0);
        opacity: 1;
    }
}

.modal.fade.show[b-5c0rq8ejmf] {
    animation: fadeIn-b-5c0rq8ejmf 0.3s ease-out;
}

@keyframes fadeIn-b-5c0rq8ejmf {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

/* nền mờ */
.modal[b-5c0rq8ejmf] {
    background-color: rgba(0,0,0,0.5);
}

/* OPEN */
.modal-show[b-5c0rq8ejmf] {
    animation: fadeIn-b-5c0rq8ejmf 0.2s ease-out forwards;
}

/* CLOSE */
.modal-hide[b-5c0rq8ejmf] {
    animation: fadeOut-b-5c0rq8ejmf 0.2s ease-in forwards;
}

/* dialog */
.modal-dialog-top[b-5c0rq8ejmf] {
    margin: 2rem auto;
    animation: slideDown-b-5c0rq8ejmf 0.25s ease-out forwards;
}

/* khi đóng thì slide lên nhẹ */
.modal-hide .modal-dialog-top[b-5c0rq8ejmf] {
    animation: slideUp-b-5c0rq8ejmf 0.2s ease-in forwards;
}

/* keyframes */
@keyframes fadeIn-b-5c0rq8ejmf {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

@keyframes fadeOut-b-5c0rq8ejmf {
    from {
        opacity: 1;
    }

    to {
        opacity: 0;
    }
}

@keyframes slideDown-b-5c0rq8ejmf {
    from {
        transform: translateY(-30px);
        opacity: 0;
    }

    to {
        transform: translateY(0);
        opacity: 1;
    }
}

@keyframes slideUp-b-5c0rq8ejmf {
    from {
        transform: translateY(0);
        opacity: 1;
    }

    to {
        transform: translateY(-20px);
        opacity: 0;
    }
}

/* Error giống login */
.modal-error[b-5c0rq8ejmf] {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    background: #fdecea;
    color: #c0392b;
    padding: 10px 12px;
    border-radius: 8px;
    font-size: 12px;
    margin: 0 16px 12px;
}

    .modal-error i[b-5c0rq8ejmf] {
        font-size: 16px;
        flex-shrink: 0;
        margin-top: 1px;
    }

    .modal-error ul[b-5c0rq8ejmf] {
        margin: 0;
        padding-left: 16px;
        flex: 1;
    }

    .modal-error li[b-5c0rq8ejmf] {
        list-style: disc;
        line-height: 1.4;
    }

.modal-error[b-5c0rq8ejmf] {
    animation: slideDown-b-5c0rq8ejmf 0.25s ease-out;
}
/* /Pages/Admin/Components/TableTypeDetailModal.razor.rz.scp.css */
/* ===== BACKDROP ===== */
.modal[b-hex4i73r8u] {
    background-color: rgba(0,0,0,0.5);
}

/* ===== MODAL TITLE ===== */
.modal-title[b-hex4i73r8u] {
    font-size: 0.9rem;
    font-weight: 600;
}

/* ===== LABEL ===== */
.modal .form-label[b-hex4i73r8u] {
    font-size: 0.75rem;
    font-weight: 600;
    color: #495057;
    margin-bottom: 4px;
}

/* ===== INPUT / TEXTAREA ===== */
.modal .form-control[b-hex4i73r8u] {
    font-size: 0.8rem;
    padding: 6px 10px;
    background-color: #f8f9fa;
    cursor: default;
}

/* ===== SWITCH ===== */
.modal .form-check-input[b-hex4i73r8u] {
    cursor: default;
}

/* ===== FOOTER BUTTON ===== */
.btn-cancel[b-hex4i73r8u] {
    background-color: #f8f9fa;
    color: #6c757d;
    border: 1px solid #dcdfe4;
    font-weight: 600;
    font-size: 0.75rem; /* Chữ nhỏ */
    padding: 6px 16px !important;
    border-radius: 6px;
    transition: all 0.2s ease;
}

    .btn-cancel:hover[b-hex4i73r8u] {
        background-color: #e9ecef;
        color: #343a40;
        border-color: #adb5bd;
    }

/* ===== ANIMATION ===== */
.modal-show[b-hex4i73r8u] {
    animation: fadeIn-b-hex4i73r8u 0.2s ease-out forwards;
}

.modal-dialog-top[b-hex4i73r8u] {
    margin: 2rem auto;
    animation: slideDown-b-hex4i73r8u 0.25s ease-out forwards;
}

@keyframes fadeIn-b-hex4i73r8u {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

@keyframes slideDown-b-hex4i73r8u {
    from {
        transform: translateY(-30px);
        opacity: 0;
    }

    to {
        transform: translateY(0);
        opacity: 1;
    }
}

/* ===== OPEN ===== */
.modal-show[b-hex4i73r8u] {
    animation: fadeIn-b-hex4i73r8u 0.2s ease-out forwards;
}

/* ===== CLOSE ===== */
.modal-hide[b-hex4i73r8u] {
    animation: fadeOut-b-hex4i73r8u 0.2s ease-in forwards;
}

/* ===== DIALOG ===== */
.modal-dialog-top[b-hex4i73r8u] {
    margin: 2rem auto;
    animation: slideDown-b-hex4i73r8u 0.25s ease-out forwards;
}

/* khi đóng thì dialog trượt lên */
.modal-hide .modal-dialog-top[b-hex4i73r8u] {
    animation: slideUp-b-hex4i73r8u 0.2s ease-in forwards;
}

/* ===== KEYFRAMES ===== */
@keyframes fadeOut-b-hex4i73r8u {
    from {
        opacity: 1;
    }

    to {
        opacity: 0;
    }
}

@keyframes slideUp-b-hex4i73r8u {
    from {
        transform: translateY(0);
        opacity: 1;
    }

    to {
        transform: translateY(-20px);
        opacity: 0;
    }
}
/* /Pages/Admin/Components/TableTypeModal.razor.rz.scp.css */
.modal-dialog-top[b-h26ki8mdwg] {
    margin: 2rem auto;
    animation: slideDown-b-h26ki8mdwg 0.3s ease-out;
}

.modal-title[b-h26ki8mdwg] {
    font-size: 0.9rem; /* nhỏ hơn h5 mặc định */
    font-weight: 600; /* đậm vừa, không gắt */
}

.modal .form-label[b-h26ki8mdwg] {
    font-size: 0.75rem;
    font-weight: 600;
    color: #495057;
    margin-bottom: 4px;
}

.modal .form-control[b-h26ki8mdwg] {
    font-size: 0.8rem; /* nhỏ chữ khi nhập */
    padding: 6px 10px; /* gọn chiều cao */
}

.btn-cancel[b-h26ki8mdwg] {
    background-color: #f8f9fa;
    color: #6c757d;
    border: 1px solid #dcdfe4;
    font-weight: 600;
    font-size: 0.75rem; /* Chữ nhỏ */
    padding: 6px 16px !important;
    border-radius: 6px;
    transition: all 0.2s ease;
}

    .btn-cancel:hover[b-h26ki8mdwg] {
        background-color: #e9ecef;
        color: #343a40;
        border-color: #adb5bd;
    }

.btn-save[b-h26ki8mdwg] {
    background-color: #0d6efd;
    color: #ffffff;
    border: 1px solid #0d6efd;
    font-weight: 600;
    font-size: 0.75rem; /* Chữ nhỏ */
    padding: 6px 16px !important;
    border-radius: 6px;
    transition: all 0.3s;
    display: inline-flex;
    align-items: center;
}

    .btn-save:hover:not(:disabled)[b-h26ki8mdwg] {
        background-color: #0b5ed7;
        border-color: #0a58ca;
        color: #ffffff;
    }

@keyframes slideDown-b-h26ki8mdwg {
    from {
        transform: translateY(-100px);
        opacity: 0;
    }

    to {
        transform: translateY(0);
        opacity: 1;
    }
}

.modal.fade.show[b-h26ki8mdwg] {
    animation: fadeIn-b-h26ki8mdwg 0.3s ease-out;
}

@keyframes fadeIn-b-h26ki8mdwg {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

/* nền mờ */
.modal[b-h26ki8mdwg] {
    background-color: rgba(0,0,0,0.5);
}

/* OPEN */
.modal-show[b-h26ki8mdwg] {
    animation: fadeIn-b-h26ki8mdwg 0.2s ease-out forwards;
}

/* CLOSE */
.modal-hide[b-h26ki8mdwg] {
    animation: fadeOut-b-h26ki8mdwg 0.2s ease-in forwards;
}

/* dialog */
.modal-dialog-top[b-h26ki8mdwg] {
    margin: 2rem auto;
    animation: slideDown-b-h26ki8mdwg 0.25s ease-out forwards;
}

/* khi đóng thì slide lên nhẹ */
.modal-hide .modal-dialog-top[b-h26ki8mdwg] {
    animation: slideUp-b-h26ki8mdwg 0.2s ease-in forwards;
}

/* keyframes */
@keyframes fadeIn-b-h26ki8mdwg {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

@keyframes fadeOut-b-h26ki8mdwg {
    from {
        opacity: 1;
    }

    to {
        opacity: 0;
    }
}

@keyframes slideDown-b-h26ki8mdwg {
    from {
        transform: translateY(-30px);
        opacity: 0;
    }

    to {
        transform: translateY(0);
        opacity: 1;
    }
}

@keyframes slideUp-b-h26ki8mdwg {
    from {
        transform: translateY(0);
        opacity: 1;
    }

    to {
        transform: translateY(-20px);
        opacity: 0;
    }
}

/* Error giống login */
.modal-error[b-h26ki8mdwg] {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    background: #fdecea;
    color: #c0392b;
    padding: 10px 12px;
    border-radius: 8px;
    font-size: 12px;
    margin: 0 16px 12px;
}

    .modal-error i[b-h26ki8mdwg] {
        font-size: 16px;
        flex-shrink: 0;
        margin-top: 1px;
    }

    .modal-error ul[b-h26ki8mdwg] {
        margin: 0;
        padding-left: 16px;
        flex: 1;
    }

    .modal-error li[b-h26ki8mdwg] {
        list-style: disc;
        line-height: 1.4;
    }

.modal-error[b-h26ki8mdwg] {
    animation: slideDown-b-h26ki8mdwg 0.25s ease-out;
}
/* /Pages/Admin/Components/UserDetailModal.razor.rz.scp.css */
/* ===== BACKDROP ===== */
.modal[b-bkntfata4w] {
    background-color: rgba(0,0,0,0.5);
}

/* ===== MODAL TITLE ===== */
.modal-title[b-bkntfata4w] {
    font-size: 0.9rem;
    font-weight: 600;
}

/* ===== LABEL ===== */
.modal .form-label[b-bkntfata4w] {
    font-size: 0.75rem;
    font-weight: 600;
    color: #495057;
    margin-bottom: 4px;
}

/* ===== INPUT / TEXTAREA ===== */
.modal .form-control[b-bkntfata4w] {
    font-size: 0.8rem;
    padding: 6px 10px;
    background-color: #f8f9fa;
    cursor: default;
}

/* ===== SWITCH ===== */
.modal .form-check-input[b-bkntfata4w] {
    cursor: default;
}

/* ===== FOOTER BUTTON ===== */
.btn-cancel[b-bkntfata4w] {
    background-color: #f8f9fa;
    color: #6c757d;
    border: 1px solid #dcdfe4;
    font-weight: 600;
    font-size: 0.75rem; /* Chữ nhỏ */
    padding: 6px 16px !important;
    border-radius: 6px;
    transition: all 0.2s ease;
}

    .btn-cancel:hover[b-bkntfata4w] {
        background-color: #e9ecef;
        color: #343a40;
        border-color: #adb5bd;
    }

/* ===== ANIMATION ===== */
.modal-show[b-bkntfata4w] {
    animation: fadeIn-b-bkntfata4w 0.2s ease-out forwards;
}

.modal-dialog-top[b-bkntfata4w] {
    margin: 2rem auto;
    animation: slideDown-b-bkntfata4w 0.25s ease-out forwards;
}

@keyframes fadeIn-b-bkntfata4w {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

@keyframes slideDown-b-bkntfata4w {
    from {
        transform: translateY(-30px);
        opacity: 0;
    }

    to {
        transform: translateY(0);
        opacity: 1;
    }
}

/* ===== OPEN ===== */
.modal-show[b-bkntfata4w] {
    animation: fadeIn-b-bkntfata4w 0.2s ease-out forwards;
}

/* ===== CLOSE ===== */
.modal-hide[b-bkntfata4w] {
    animation: fadeOut-b-bkntfata4w 0.2s ease-in forwards;
}

/* ===== DIALOG ===== */
.modal-dialog-top[b-bkntfata4w] {
    margin: 2rem auto;
    animation: slideDown-b-bkntfata4w 0.25s ease-out forwards;
}

/* khi đóng thì dialog trượt lên */
.modal-hide .modal-dialog-top[b-bkntfata4w] {
    animation: slideUp-b-bkntfata4w 0.2s ease-in forwards;
}

/* ===== KEYFRAMES ===== */
@keyframes fadeOut-b-bkntfata4w {
    from {
        opacity: 1;
    }

    to {
        opacity: 0;
    }
}

@keyframes slideUp-b-bkntfata4w {
    from {
        transform: translateY(0);
        opacity: 1;
    }

    to {
        transform: translateY(-20px);
        opacity: 0;
    }
}
/* /Pages/Admin/Components/UserModal.razor.rz.scp.css */
.modal-dialog-top[b-e5o03gjhcb] {
    margin: 2rem auto;
    animation: slideDown-b-e5o03gjhcb 0.3s ease-out;
}

.modal-title[b-e5o03gjhcb] {
    font-size: 0.9rem; /* nhỏ hơn h5 mặc định */
    font-weight: 600; /* đậm vừa, không gắt */
}

.modal .form-label[b-e5o03gjhcb] {
    font-size: 0.75rem;
    font-weight: 600;
    color: #495057;
    margin-bottom: 4px;
}

.modal .form-control[b-e5o03gjhcb] {
    font-size: 0.8rem; /* nhỏ chữ khi nhập */
    padding: 6px 10px; /* gọn chiều cao */
}

.btn-cancel[b-e5o03gjhcb] {
    background-color: #f8f9fa;
    color: #6c757d;
    border: 1px solid #dcdfe4;
    font-weight: 600;
    font-size: 0.75rem; /* Chữ nhỏ */
    padding: 6px 16px !important;
    border-radius: 6px;
    transition: all 0.2s ease;
}

    .btn-cancel:hover[b-e5o03gjhcb] {
        background-color: #e9ecef;
        color: #343a40;
        border-color: #adb5bd;
    }

.btn-save[b-e5o03gjhcb] {
    background-color: #0d6efd;
    color: #ffffff;
    border: 1px solid #0d6efd;
    font-weight: 600;
    font-size: 0.75rem; /* Chữ nhỏ */
    padding: 6px 16px !important;
    border-radius: 6px;
    transition: all 0.3s;
    display: inline-flex;
    align-items: center;
}

    .btn-save:hover:not(:disabled)[b-e5o03gjhcb] {
        background-color: #0b5ed7;
        border-color: #0a58ca;
        color: #ffffff;
    }

@keyframes slideDown-b-e5o03gjhcb {
    from {
        transform: translateY(-100px);
        opacity: 0;
    }

    to {
        transform: translateY(0);
        opacity: 1;
    }
}

.modal.fade.show[b-e5o03gjhcb] {
    animation: fadeIn-b-e5o03gjhcb 0.3s ease-out;
}

@keyframes fadeIn-b-e5o03gjhcb {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

/* nền mờ */
.modal[b-e5o03gjhcb] {
    background-color: rgba(0,0,0,0.5);
}

/* OPEN */
.modal-show[b-e5o03gjhcb] {
    animation: fadeIn-b-e5o03gjhcb 0.2s ease-out forwards;
}

/* CLOSE */
.modal-hide[b-e5o03gjhcb] {
    animation: fadeOut-b-e5o03gjhcb 0.2s ease-in forwards;
}

/* dialog */
.modal-dialog-top[b-e5o03gjhcb] {
    margin: 2rem auto;
    animation: slideDown-b-e5o03gjhcb 0.25s ease-out forwards;
}

/* khi đóng thì slide lên nhẹ */
.modal-hide .modal-dialog-top[b-e5o03gjhcb] {
    animation: slideUp-b-e5o03gjhcb 0.2s ease-in forwards;
}

/* keyframes */
@keyframes fadeIn-b-e5o03gjhcb {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

@keyframes fadeOut-b-e5o03gjhcb {
    from {
        opacity: 1;
    }

    to {
        opacity: 0;
    }
}

@keyframes slideDown-b-e5o03gjhcb {
    from {
        transform: translateY(-30px);
        opacity: 0;
    }

    to {
        transform: translateY(0);
        opacity: 1;
    }
}

@keyframes slideUp-b-e5o03gjhcb {
    from {
        transform: translateY(0);
        opacity: 1;
    }

    to {
        transform: translateY(-20px);
        opacity: 0;
    }
}

/* Error giống login */
.modal-error[b-e5o03gjhcb] {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    background: #fdecea;
    color: #c0392b;
    padding: 10px 12px;
    border-radius: 8px;
    font-size: 12px;
    margin: 0 16px 12px;
}

    .modal-error i[b-e5o03gjhcb] {
        font-size: 16px;
        flex-shrink: 0;
        margin-top: 1px;
    }

    .modal-error ul[b-e5o03gjhcb] {
        margin: 0;
        padding-left: 16px;
        flex: 1;
    }

    .modal-error li[b-e5o03gjhcb] {
        list-style: disc;
        line-height: 1.4;
    }

.modal-error[b-e5o03gjhcb] {
    animation: slideDown-b-e5o03gjhcb 0.25s ease-out;
}
/* /Pages/Admin/Dashboard.razor.rz.scp.css */
body[b-hsxg6d51a1] {
    font-family: 'DM Sans', sans-serif;
    background: #f4f3f0;
    color: #111;
    -webkit-font-smoothing: antialiased;
    font-size: 15px;
}

/* ── Container ── */
.dashboard-container[b-hsxg6d51a1] {
    max-width: 1200px;
}

.moderns-xuat[b-hsxg6d51a1] {
    background: none !important;
    border: none !important;
    box-shadow: none !important;
}

/* ── Card ── */
.modern-card[b-hsxg6d51a1] {
    background: #ffffff;
    border: 1.5px solid #e2e1dd;
    border-radius: 7px;
    box-shadow: 0 1px 4px rgba(0,0,0,.05), 0 4px 18px rgba(0,0,0,.04);
    transition: box-shadow .18s ease, border-color .18s ease;
}

    .modern-card:hover[b-hsxg6d51a1] {
        box-shadow: 0 2px 10px rgba(0,0,0,.08), 0 8px 32px rgba(0,0,0,.06);
        border-color: #cac9c4;
    }

/* ── Toolbar ── */
.dashboard-toolbar[b-hsxg6d51a1] {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    padding: 10px 0 10px 16px;
    gap: 10px;
}

.dashboard-toolbar-right[b-hsxg6d51a1] {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.date-filter-group[b-hsxg6d51a1] {
    display: flex;
    align-items: center;
    gap: 8px;
    background: #f4f3f0;
    border: 1.5px solid #e2e1dd;
    border-radius: 5px;
    padding: 5px 12px;
    font-size: 13px;
    font-weight: 500;
    color: #888;
}

.date-sep[b-hsxg6d51a1] {
    width: 1px;
    height: 16px;
    background: #e2e1dd;
}

.dashboard-date-input[b-hsxg6d51a1] {
    border: none;
    background: transparent;
    font-family: 'DM Sans', sans-serif;
    font-size: 13px;
    color: #111;
    outline: none;
    cursor: pointer;
    padding: 0;
}

    .dashboard-date-input[b-hsxg6d51a1]::-webkit-calendar-picker-indicator {
        opacity: .45;
        cursor: pointer;
    }

.action-btn[b-hsxg6d51a1] {
    background: #111;
    color: #fff;
    border: none;
    border-radius: 5px;
    padding: 6px 14px;
    font-size: 13px;
    font-weight: 500;
    font-family: 'DM Sans', sans-serif;
    transition: background .18s ease;
}

    .action-btn:hover[b-hsxg6d51a1] {
        background: #333;
        color: #fff;
    }

.btn-export[b-hsxg6d51a1] {
    background: #fff;
    color: #333;
    border: 1.5px solid #e2e1dd;
    border-radius: 5px;
    padding: 5px 14px;
    font-size: 13px;
    font-weight: 500;
    font-family: 'DM Sans', sans-serif;
    transition: all .18s ease;
}

    .btn-export:hover[b-hsxg6d51a1] {
        background: #f4f3f0;
        border-color: #bbb;
        color: #111;
    }

.dashboard-dropdown-menu[b-hsxg6d51a1] {
    border: 1.5px solid #e2e1dd;
    border-radius: 12px;
    box-shadow: 0 4px 24px rgba(0,0,0,.09);
    padding: 6px;
    min-width: 200px;
    background: #fff;
}

    .dashboard-dropdown-menu .dropdown-item[b-hsxg6d51a1] {
        border-radius: 8px;
        padding: 8px 12px;
        font-size: 13.5px;
        color: #333;
        transition: background .15s;
    }

        .dashboard-dropdown-menu .dropdown-item:hover[b-hsxg6d51a1] {
            background: #f4f3f0;
            color: #111;
        }

/* ── Spinner ── */
.dashboard-spinner[b-hsxg6d51a1] {
    width: 44px;
    height: 44px;
    border-width: 3px;
}

/* ── Stat Cards — left accent bar ── */
.stat-card-revenue[b-hsxg6d51a1],
.stat-card-booking[b-hsxg6d51a1],
.stat-card-customer[b-hsxg6d51a1],
.stat-card-rating[b-hsxg6d51a1] {
    position: relative;
}

    .stat-card-revenue[b-hsxg6d51a1]::before {
        background: #16a34a;
    }

    .stat-card-booking[b-hsxg6d51a1]::before {
        background: #0369a1;
    }

    .stat-card-customer[b-hsxg6d51a1]::before {
        background: #6d28d9;
    }

    .stat-card-rating[b-hsxg6d51a1]::before {
        background: #d97706;
    }

    .stat-card-revenue[b-hsxg6d51a1]::before,
    .stat-card-booking[b-hsxg6d51a1]::before,
    .stat-card-customer[b-hsxg6d51a1]::before,
    .stat-card-rating[b-hsxg6d51a1]::before {
        content: '';
        position: absolute;
        top: 18px;
        bottom: 18px;
        left: 0;
        width: 3px;
        border-radius: 0 3px 3px 0;
    }

    /* Numbers mono */
    .stat-card-revenue h3[b-hsxg6d51a1],
    .stat-card-booking h3[b-hsxg6d51a1],
    .stat-card-customer h3[b-hsxg6d51a1],
    .stat-card-rating h3[b-hsxg6d51a1] {
        font-family: 'DM Mono', monospace;
        font-size: 1.6rem;
        letter-spacing: -.02em;
    }

.stat-card-footer[b-hsxg6d51a1] {
    border-top-color: #f0efe9 !important;
}

    .stat-card-footer span[b-hsxg6d51a1] {
        font-size: 12.5px;
    }

.stat-icon-wrapper[b-hsxg6d51a1] {
    width: 44px;
    height: 44px;
    flex-shrink: 0;
}

.stat-icon-purple[b-hsxg6d51a1] {
    background: #f5f3ff !important;
    color: #6d28d9 !important;
}

.rating-star-icon[b-hsxg6d51a1] {
    font-size: 1rem;
}

/* ── Progress Bars ── */
.stat-progress-bar-wrapper[b-hsxg6d51a1] {
    height: 7px;
    background: #f0efe9 !important;
    border: 1px solid #e2e1dd;
}

    .stat-progress-bar-wrapper .progress-bar[b-hsxg6d51a1] {
        transition: width .8s cubic-bezier(.4,0,.2,1);
    }

/* Growth row */
.modern-card .p-3.bg-light[b-hsxg6d51a1] {
    background: #f4f3f0 !important;
    border: 1.5px solid #e2e1dd;
    border-radius: 10px !important;
}

/* ── Section Labels ── */
.modern-card h6.fw-bold[b-hsxg6d51a1] {
    font-size: 13px;
    letter-spacing: .04em;
    text-transform: uppercase;
    color: #555;
}

/* ── Operational Status numbers ── */
.modern-card .row.g-0 h4[b-hsxg6d51a1] {
    font-family: 'DM Mono', monospace;
    font-size: 1.5rem;
    letter-spacing: -.02em;
}

.modern-card .row.g-0 .text-muted.small[b-hsxg6d51a1] {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .05em;
}

.border-light-subtle[b-hsxg6d51a1] {
    border-color: #ebebea !important;
}

/* ── Tables ── */
.custom-table[b-hsxg6d51a1] {
    font-size: 13.5px;
}

    .custom-table thead th[b-hsxg6d51a1] {
        font-size: 11px;
        font-weight: 600;
        letter-spacing: .06em;
        text-transform: uppercase;
        color: #999;
        background: #faf9f7;
        border-bottom: 1.5px solid #e2e1dd;
        padding-top: 10px;
        padding-bottom: 10px;
    }

    .custom-table tbody tr[b-hsxg6d51a1] {
        border-color: #f0efe9;
        transition: background .15s;
    }

        .custom-table tbody tr:hover[b-hsxg6d51a1] {
            background: #faf9f7;
        }

    .custom-table tbody td[b-hsxg6d51a1] {
        padding-top: 11px;
        padding-bottom: 11px;
        vertical-align: middle;
        border-color: #f0efe9;
    }

.table-col-index[b-hsxg6d51a1] {
    width: 44px;
}

/* thay thế 2 rule cũ */
.stat-progress-bar-wrapper[b-hsxg6d51a1]  .progress-bar.bg-success {
    background-color: #16a34a !important;
}

.stat-progress-bar-wrapper[b-hsxg6d51a1]  .progress-bar.bg-danger {
    background-color: #dc2626 !important;
}

/* Avatar */
.avatar-circle[b-hsxg6d51a1] {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 600;
    background: #f4f3f0;
    border: 1.5px solid #e2e1dd;
    color: #555;
    flex-shrink: 0;
    text-transform: uppercase;
}

/* ── Status Dots ── */
.status-dot[b-hsxg6d51a1] {
    display: inline-block;
    width: 7px;
    height: 7px;
    border-radius: 50%;
    vertical-align: middle;
}

/* ── Badges ── */
.badge.bg-light[b-hsxg6d51a1] {
    background: #f4f3f0 !important;
    border: 1.5px solid #e2e1dd !important;
    color: #444 !important;
    font-weight: 500;
    font-size: 12px;
}

.badge.bg-success-subtle[b-hsxg6d51a1] {
    font-size: 12px;
    font-weight: 600;
    font-family: 'DM Mono', monospace;
}

.badge.bg-danger-subtle[b-hsxg6d51a1] {
    font-size: 12px;
    font-weight: 600;
    font-family: 'DM Mono', monospace;
}

/* ── Link ── */
.btn-link-hover[b-hsxg6d51a1] {
    font-size: 13px;
    transition: opacity .18s;
}

    .btn-link-hover:hover[b-hsxg6d51a1] {
        opacity: .65;
    }

/* ── Charts ── */
.chart-wrapper-offset[b-hsxg6d51a1] {
    margin: -10px -14px 0;
}

.apexcharts-canvas[b-hsxg6d51a1] {
    font-family: 'DM Sans', sans-serif !important;
}

.apexcharts-tooltip[b-hsxg6d51a1] {
    border: 1.5px solid #e2e1dd !important;
    box-shadow: 0 4px 20px rgba(0,0,0,.09) !important;
    border-radius: 10px !important;
    font-family: 'DM Sans', sans-serif !important;
    font-size: 12.5px !important;
}

.apexcharts-tooltip-title[b-hsxg6d51a1] {
    background: #f4f3f0 !important;
    border-bottom: 1px solid #e2e1dd !important;
    font-weight: 600 !important;
}

/* ── Misc ── */
.border-dashed[b-hsxg6d51a1] {
    border-style: dashed !important;
    border-color: #e2e1dd !important;
}

.text-muted[b-hsxg6d51a1] {
    color: #888 !important;
}

/* ── Responsive ── */
@media (max-width: 768px) {
    .dashboard-toolbar[b-hsxg6d51a1] {
        flex-direction: column;
        align-items: stretch;
    }

    .dashboard-toolbar-right[b-hsxg6d51a1] {
        justify-content: flex-end;
    }

    .stat-card-revenue h3[b-hsxg6d51a1],
    .stat-card-booking h3[b-hsxg6d51a1],
    .stat-card-customer h3[b-hsxg6d51a1],
    .stat-card-rating h3[b-hsxg6d51a1] {
        font-size: 1.3rem;
    }
}
/* /Pages/Admin/MenuItems.razor.rz.scp.css */
.table > :not(caption) > * > *[b-ze1ssaf3my] {
    padding: 0.75rem 0.75rem;
    border-right: 1px solid #e9ecef;
}

    .table > :not(caption) > * > *:last-child[b-ze1ssaf3my] {
        border-right: none;
    }

.table tbody tr[b-ze1ssaf3my] {
    border-bottom: 1px solid #e9ecef;
}

    .table tbody tr:nth-of-type(odd)[b-ze1ssaf3my] {
        background-color: #ffffff !important;
    }

    .table tbody tr:nth-of-type(even)[b-ze1ssaf3my] {
        background-color: #f8f9fa !important;
    }

.table thead tr[b-ze1ssaf3my] {
    border-bottom: 2px solid #dee2e6;
}

.td-xs[b-ze1ssaf3my] {
    font-size: 0.75rem;
    padding: 2px 6px !important;
}

.table thead tr[b-ze1ssaf3my] {
    background-color: #e9ecef; /* đậm hơn bg-light một chút */
}

.text-muted[b-ze1ssaf3my] {
    font-size: 0.75rem;
    opacity: 0.7;
}

.table-container[b-ze1ssaf3my] {
    border: 1px solid #dee2e6;
    border-radius: 0.375rem;
    overflow: hidden;
    margin: 0 12px 0;
}

.action-btn[b-ze1ssaf3my] {
    padding: 2px 6px;
}

    .action-btn i[b-ze1ssaf3my] {
        font-size: 0.85rem;
    }


    .action-btn.btn-outline-primary:hover[b-ze1ssaf3my] {
        background-color: transparent !important;
        color: #0b5ed7; /* đậm hơn primary */
    }

    .action-btn.btn-outline-danger:hover[b-ze1ssaf3my] {
        background-color: transparent !important;
        color: #b02a37; /* đậm hơn danger */
    }

.form-control[b-ze1ssaf3my],
.btn[b-ze1ssaf3my] {
    box-shadow: none !important;
}

.table-hover tbody tr:hover[b-ze1ssaf3my] {
    background-color: inherit !important;
}

.btn-primary[b-ze1ssaf3my] {
    font-size: 0.875rem;
}

.small-placeholder[b-ze1ssaf3my]::placeholder {
    font-size: 0.75rem;
    opacity: 0.7;
}


.badge[b-ze1ssaf3my] {
    font-weight: 500;
    letter-spacing: 0.3px;
}

.bg-success-subtle[b-ze1ssaf3my] {
    background-color: #d1f2eb !important;
}

.text-success[b-ze1ssaf3my] {
    color: #17a2b8 !important;
}

.bg-danger-subtle[b-ze1ssaf3my] {
    background-color: #f8d7da !important;
}

.text-danger[b-ze1ssaf3my] {
    color: #dc3545 !important;
}

.bg-warning-subtle[b-ze1ssaf3my] {
    background-color: #fff3cd !important;
}

.text-warning[b-ze1ssaf3my] {
    color: #ffc107 !important;
}

.page-link[b-ze1ssaf3my] {
    color: #6c757d;
}

.page-item.active .page-link[b-ze1ssaf3my] {
    background-color: #007bff;
    border-color: #007bff;
}

.btn-outline-primary:hover[b-ze1ssaf3my],
.btn-outline-danger:hover[b-ze1ssaf3my],
.btn-outline-secondary:hover[b-ze1ssaf3my] {
    opacity: 1;
}

.card[b-ze1ssaf3my] {
    overflow: hidden;
}

thead th[b-ze1ssaf3my] {
    position: sticky;
    top: 0;
    background-color: #f8f9fa;
    z-index: 10;
}

.pagination-sm .page-link[b-ze1ssaf3my] {
    font-size: 0.7rem;
    padding: 0.15rem 0.4rem;
}

.filter-input[b-ze1ssaf3my] {
    font-size: 0.85rem !important; /* Thu nhỏ chữ */

    padding: 0.4rem 0.75rem;
    border-radius: 6px;
    height: 35px; /* Giảm nhẹ chiều cao của ô nhập liệu */
}



    /* Thu nhỏ chữ của placeholder (dòng chữ mờ) */

    .filter-input[b-ze1ssaf3my]::placeholder {
        font-size: 0.8rem;
        opacity: 0.7;
    }
/* /Pages/Admin/Payments.razor.rz.scp.css */
.table > :not(caption) > * > *[b-k1kauspsg7] {
    padding: 0.75rem 0.75rem;
    border-right: 1px solid #e9ecef;
}

    .table > :not(caption) > * > *:last-child[b-k1kauspsg7] {
        border-right: none;
    }

.table tbody tr[b-k1kauspsg7] {
    border-bottom: 1px solid #e9ecef;
}

    .table tbody tr:nth-of-type(odd)[b-k1kauspsg7] {
        background-color: #ffffff !important;
    }

    .table tbody tr:nth-of-type(even)[b-k1kauspsg7] {
        background-color: #f8f9fa !important;
    }

.table thead tr[b-k1kauspsg7] {
    border-bottom: 2px solid #dee2e6;
}

.td-xs[b-k1kauspsg7] {
    font-size: 0.75rem;
    padding: 2px 6px !important;
}

.table thead tr[b-k1kauspsg7] {
    background-color: #e9ecef; /* đậm hơn bg-light một chút */
}

.text-muted[b-k1kauspsg7] {
    font-size: 0.75rem;
    opacity: 0.7;
}

.table-container[b-k1kauspsg7] {
    border: 1px solid #dee2e6;
    border-radius: 0.375rem;
    overflow: hidden;
    margin: 0 12px 0;
}

.action-btn[b-k1kauspsg7] {
    padding: 2px 6px;
}

    .action-btn i[b-k1kauspsg7] {
        font-size: 0.85rem;
    }


    .action-btn.btn-outline-primary:hover[b-k1kauspsg7] {
        background-color: transparent !important;
        color: #0b5ed7; /* đậm hơn primary */
    }

    .action-btn.btn-outline-danger:hover[b-k1kauspsg7] {
        background-color: transparent !important;
        color: #b02a37; /* đậm hơn danger */
    }

.form-control[b-k1kauspsg7],
.btn[b-k1kauspsg7] {
    box-shadow: none !important;
}

.table-hover tbody tr:hover[b-k1kauspsg7] {
    background-color: inherit !important;
}

.btn-primary[b-k1kauspsg7] {
    font-size: 0.875rem;
}

.small-placeholder[b-k1kauspsg7]::placeholder {
    font-size: 0.75rem;
    opacity: 0.7;
}


.badge[b-k1kauspsg7] {
    font-weight: 500;
    letter-spacing: 0.3px;
}

.bg-success-subtle[b-k1kauspsg7] {
    background-color: #d1f2eb !important;
}

.text-success[b-k1kauspsg7] {
    color: #17a2b8 !important;
}

.bg-danger-subtle[b-k1kauspsg7] {
    background-color: #f8d7da !important;
}

.text-danger[b-k1kauspsg7] {
    color: #dc3545 !important;
}

.bg-warning-subtle[b-k1kauspsg7] {
    background-color: #fff3cd !important;
}

.text-warning[b-k1kauspsg7] {
    color: #ffc107 !important;
}

.page-link[b-k1kauspsg7] {
    color: #6c757d;
}

.page-item.active .page-link[b-k1kauspsg7] {
    background-color: #007bff;
    border-color: #007bff;
}

.btn-outline-primary:hover[b-k1kauspsg7],
.btn-outline-danger:hover[b-k1kauspsg7],
.btn-outline-secondary:hover[b-k1kauspsg7] {
    opacity: 1;
}

.card[b-k1kauspsg7] {
    overflow: hidden;
}

thead th[b-k1kauspsg7] {
    position: sticky;
    top: 0;
    background-color: #f8f9fa;
    z-index: 10;
}

.pagination-sm .page-link[b-k1kauspsg7] {
    font-size: 0.7rem;
    padding: 0.15rem 0.4rem;
}

.filter-input[b-k1kauspsg7] {
    font-size: 0.85rem !important; /* Thu nhỏ chữ */

    padding: 0.4rem 0.75rem;
    border-radius: 6px;
    height: 35px; /* Giảm nhẹ chiều cao của ô nhập liệu */
}



    /* Thu nhỏ chữ của placeholder (dòng chữ mờ) */

    .filter-input[b-k1kauspsg7]::placeholder {
        font-size: 0.8rem;
        opacity: 0.7;
    }
/* /Pages/Admin/Reviews.razor.rz.scp.css */
.table > :not(caption) > * > *[b-twyuxffdz1] {
    padding: 0.75rem 0.75rem;
    border-right: 1px solid #e9ecef;
}

    .table > :not(caption) > * > *:last-child[b-twyuxffdz1] {
        border-right: none;
    }

.table tbody tr[b-twyuxffdz1] {
    border-bottom: 1px solid #e9ecef;
}

    .table tbody tr:nth-of-type(odd)[b-twyuxffdz1] {
        background-color: #ffffff !important;
    }

    .table tbody tr:nth-of-type(even)[b-twyuxffdz1] {
        background-color: #f8f9fa !important;
    }

.table thead tr[b-twyuxffdz1] {
    border-bottom: 2px solid #dee2e6;
}

.td-xs[b-twyuxffdz1] {
    font-size: 0.75rem;
    padding: 2px 6px !important;
}

.table thead tr[b-twyuxffdz1] {
    background-color: #e9ecef; /* đậm hơn bg-light một chút */
}

.text-muted[b-twyuxffdz1] {
    font-size: 0.75rem;
    opacity: 0.7;
}

.table-container[b-twyuxffdz1] {
    border: 1px solid #dee2e6;
    border-radius: 0.375rem;
    overflow: hidden;
    margin: 0 12px 0;
}

.action-btn[b-twyuxffdz1] {
    padding: 2px 6px;
}

    .action-btn i[b-twyuxffdz1] {
        font-size: 0.85rem;
    }


    .action-btn.btn-outline-primary:hover[b-twyuxffdz1] {
        background-color: transparent !important;
        color: #0b5ed7; /* đậm hơn primary */
    }

    .action-btn.btn-outline-danger:hover[b-twyuxffdz1] {
        background-color: transparent !important;
        color: #b02a37; /* đậm hơn danger */
    }

.form-control[b-twyuxffdz1],
.btn[b-twyuxffdz1] {
    box-shadow: none !important;
}

.table-hover tbody tr:hover[b-twyuxffdz1] {
    background-color: inherit !important;
}

.btn-primary[b-twyuxffdz1] {
    font-size: 0.875rem;
}

.small-placeholder[b-twyuxffdz1]::placeholder {
    font-size: 0.75rem;
    opacity: 0.7;
}


.badge[b-twyuxffdz1] {
    font-weight: 500;
    letter-spacing: 0.3px;
}

.bg-success-subtle[b-twyuxffdz1] {
    background-color: #d1f2eb !important;
}

.text-success[b-twyuxffdz1] {
    color: #17a2b8 !important;
}

.bg-danger-subtle[b-twyuxffdz1] {
    background-color: #f8d7da !important;
}

.text-danger[b-twyuxffdz1] {
    color: #dc3545 !important;
}

.bg-warning-subtle[b-twyuxffdz1] {
    background-color: #fff3cd !important;
}

.text-warning[b-twyuxffdz1] {
    color: #ffc107 !important;
}

.page-link[b-twyuxffdz1] {
    color: #6c757d;
}

.page-item.active .page-link[b-twyuxffdz1] {
    background-color: #007bff;
    border-color: #007bff;
}

.btn-outline-primary:hover[b-twyuxffdz1],
.btn-outline-danger:hover[b-twyuxffdz1],
.btn-outline-secondary:hover[b-twyuxffdz1] {
    opacity: 1;
}

.card[b-twyuxffdz1] {
    overflow: hidden;
}

thead th[b-twyuxffdz1] {
    position: sticky;
    top: 0;
    background-color: #f8f9fa;
    z-index: 10;
}

.pagination-sm .page-link[b-twyuxffdz1] {
    font-size: 0.7rem;
    padding: 0.15rem 0.4rem;
}

/* =========================================
   CUSTOM DETAIL MODAL STYLES (ĐÃ THU NHỎ)
   ========================================= */

/* Nền mờ phía sau modal */
.custom-detail-modal[b-twyuxffdz1] {
    background: rgba(15, 23, 42, 0.5) !important;
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    animation: modalFadeIn-b-twyuxffdz1 0.25s ease-out;
}

    /* Ép modal nhỏ lại hơn mặc định của modal-sm (Bootstrap mặc định là 300px) */
    .custom-detail-modal .modal-dialog[b-twyuxffdz1] {
        max-width: 450px;
    }

    /* Khối nội dung chính của modal */
    .custom-detail-modal .modal-content[b-twyuxffdz1] {
        border: none;
        border-radius: 7px; /* Bo góc vừa phải */
        box-shadow: 0 15px 30px rgba(0, 0, 0, 0.15);
        overflow: hidden;
        animation: modalSlideUp-b-twyuxffdz1 0.3s cubic-bezier(0.16, 1, 0.3, 1);
        padding: 0.5rem 1rem;
    }

    /* Phần Header */
    .custom-detail-modal .modal-header[b-twyuxffdz1] {
        border-bottom: 1px solid #f1f5f9;
        padding: 1rem 1rem; /* Giảm khoảng cách */
        background-color: #ffffff;
    }

    .custom-detail-modal .modal-title[b-twyuxffdz1] {
        font-size: 0.95rem; /* Thu nhỏ tiêu đề */
        color: #1e293b;
        letter-spacing: -0.01em;
    }

    /* Nút close */
    .custom-detail-modal .btn-close[b-twyuxffdz1] {
        background-size: 0.7em; /* Thu nhỏ nút x */
        opacity: 0.5;
        transition: opacity 0.2s;
    }

        .custom-detail-modal .btn-close:hover[b-twyuxffdz1] {
            opacity: 1;
        }

    /* Phần Body */
    .custom-detail-modal .modal-body[b-twyuxffdz1] {
        padding: 1rem; /* Giảm khoảng cách body */
        background-color: #f8fafc;
    }

/* Các khối thông tin */
.info-card[b-twyuxffdz1] {
    background: #ffffff;
    border: 1px solid #e2e8f0;
    border-radius: 0.5rem;
    padding: 0.85rem; /* Giảm khoảng cách card */
}

.info-label[b-twyuxffdz1] {
    font-size: 0.65rem; /* Thu nhỏ nhãn (Khách hàng, số bàn...) */
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: #64748b;
    margin-bottom: 0.25rem;
    font-weight: 700;
}

.info-value[b-twyuxffdz1] {
    font-size: 0.85rem; /* Thu nhỏ giá trị */
    color: #334155;
    font-weight: 500;
    margin-bottom: 0;
}

    .info-value .badge[b-twyuxffdz1] {
        font-size: 0.75rem; /* Thu nhỏ badge số bàn */
        padding: 0.3em 0.5em;
    }

/* Ngôi sao đánh giá */
.text-warning i[b-twyuxffdz1] {
    font-size: 0.8rem; /* Thu nhỏ ngôi sao */
}

/* Khung nhận xét riêng biệt */
.comment-box[b-twyuxffdz1] {
    background-color: #f1f5f9;
    border-radius: 0.4rem;
    padding: 0.75rem 0.85rem; /* Giảm padding */
    position: relative;
    margin-top: 0.4rem;
    border-left: 3px solid #cbd5e1; /* Làm vạch kẻ nhỏ lại */
}

.comment-text[b-twyuxffdz1] {
    color: #475569;
    font-size: 0.8rem; /* Thu nhỏ chữ nhận xét */
    line-height: 1.4;
    margin-bottom: 0;
    font-style: italic;
}

/* Phần Footer */
.custom-detail-modal .modal-footer[b-twyuxffdz1] {
    border-top: 1px solid #f1f5f9;
    padding: 0.6rem 1rem; /* Giảm padding footer */
    background-color: #ffffff;
}

    .custom-detail-modal .modal-footer .btn[b-twyuxffdz1] {
        padding: 0.35rem 1rem;
        border-radius: 0.4rem;
        font-weight: 500;
        font-size: 0.8rem; /* Thu nhỏ chữ nút Đóng */
    }

/* Animations */
@keyframes modalFadeIn-b-twyuxffdz1 {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

@keyframes modalSlideUp-b-twyuxffdz1 {
    from {
        opacity: 0;
        transform: translateY(15px) scale(0.98);
    }

    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

.filter-input[b-twyuxffdz1] {
    font-size: 0.85rem !important; /* Thu nhỏ chữ */

    padding: 0.4rem 0.75rem;
    border-radius: 6px;
    height: 35px; /* Giảm nhẹ chiều cao của ô nhập liệu */
}



    /* Thu nhỏ chữ của placeholder (dòng chữ mờ) */

    .filter-input[b-twyuxffdz1]::placeholder {
        font-size: 0.8rem;
        opacity: 0.7;
    }

.btn-cancel[b-twyuxffdz1] {
    background-color: #f8f9fa;
    color: #6c757d;
    border: 1px solid #dcdfe4;
    font-weight: 600;
    font-size: 0.75rem; /* Chữ nhỏ */
    padding: 6px 16px !important;
    border-radius: 6px;
    transition: all 0.2s ease;
}

    .btn-cancel:hover[b-twyuxffdz1] {
        background-color: #e9ecef;
        color: #343a40;
        border-color: #adb5bd;
    }
/* /Pages/Admin/Tables.razor.rz.scp.css */
.table > :not(caption) > * > *[b-td0bt79m7t] {
    padding: 0.75rem 0.75rem;
    border-right: 1px solid #e9ecef;
}

    .table > :not(caption) > * > *:last-child[b-td0bt79m7t] {
        border-right: none;
    }

.table tbody tr[b-td0bt79m7t] {
    border-bottom: 1px solid #e9ecef;
}

    .table tbody tr:nth-of-type(odd)[b-td0bt79m7t] {
        background-color: #ffffff !important;
    }

    .table tbody tr:nth-of-type(even)[b-td0bt79m7t] {
        background-color: #f8f9fa !important;
    }

.table thead tr[b-td0bt79m7t] {
    border-bottom: 2px solid #dee2e6;
}

.td-xs[b-td0bt79m7t] {
    font-size: 0.75rem;
    padding: 2px 6px !important;
}

.table thead tr[b-td0bt79m7t] {
    background-color: #e9ecef; /* đậm hơn bg-light một chút */
}

.text-muted[b-td0bt79m7t] {
    font-size: 0.75rem;
    opacity: 0.7;
}

.table-container[b-td0bt79m7t] {
    border: 1px solid #dee2e6;
    border-radius: 0.375rem;
    overflow: hidden;
    margin: 0 12px 0;
}

.action-btn[b-td0bt79m7t] {
    padding: 2px 6px;
}

    .action-btn i[b-td0bt79m7t] {
        font-size: 0.85rem;
    }


    .action-btn.btn-outline-primary:hover[b-td0bt79m7t] {
        background-color: transparent !important;
        color: #0b5ed7; /* đậm hơn primary */
    }

    .action-btn.btn-outline-danger:hover[b-td0bt79m7t] {
        background-color: transparent !important;
        color: #b02a37; /* đậm hơn danger */
    }

.form-control[b-td0bt79m7t],
.btn[b-td0bt79m7t] {
    box-shadow: none !important;
}

.table-hover tbody tr:hover[b-td0bt79m7t] {
    background-color: inherit !important;
}

.btn-primary[b-td0bt79m7t] {
    font-size: 0.875rem;
}

.small-placeholder[b-td0bt79m7t]::placeholder {
    font-size: 0.75rem;
    opacity: 0.7;
}


.badge[b-td0bt79m7t] {
    font-weight: 500;
    letter-spacing: 0.3px;
}

.bg-success-subtle[b-td0bt79m7t] {
    background-color: #d1f2eb !important;
}

.text-success[b-td0bt79m7t] {
    color: #17a2b8 !important;
}

.bg-danger-subtle[b-td0bt79m7t] {
    background-color: #f8d7da !important;
}

.text-danger[b-td0bt79m7t] {
    color: #dc3545 !important;
}

.bg-warning-subtle[b-td0bt79m7t] {
    background-color: #fff3cd !important;
}

.text-warning[b-td0bt79m7t] {
    color: #ffc107 !important;
}

.page-link[b-td0bt79m7t] {
    color: #6c757d;
}

.page-item.active .page-link[b-td0bt79m7t] {
    background-color: #007bff;
    border-color: #007bff;
}

.btn-outline-primary:hover[b-td0bt79m7t],
.btn-outline-danger:hover[b-td0bt79m7t],
.btn-outline-secondary:hover[b-td0bt79m7t] {
    opacity: 1;
}

.card[b-td0bt79m7t] {
    overflow: hidden;
}

thead th[b-td0bt79m7t] {
    position: sticky;
    top: 0;
    background-color: #f8f9fa;
    z-index: 10;
}

.pagination-sm .page-link[b-td0bt79m7t] {
    font-size: 0.7rem;
    padding: 0.15rem 0.4rem;
}

.filter-input[b-td0bt79m7t] {
    font-size: 0.85rem !important; /* Thu nhỏ chữ */

    padding: 0.4rem 0.75rem;
    border-radius: 6px;
    height: 35px; /* Giảm nhẹ chiều cao của ô nhập liệu */
}



    /* Thu nhỏ chữ của placeholder (dòng chữ mờ) */

    .filter-input[b-td0bt79m7t]::placeholder {
        font-size: 0.8rem;
        opacity: 0.7;
    }
/* /Pages/Admin/TableTypes.razor.rz.scp.css */
.table > :not(caption) > * > *[b-ue9jshkziv] {
    padding: 0.75rem 0.75rem;
    border-right: 1px solid #e9ecef;
}

    .table > :not(caption) > * > *:last-child[b-ue9jshkziv] {
        border-right: none;
    }

.table tbody tr[b-ue9jshkziv] {
    border-bottom: 1px solid #e9ecef;
}

    .table tbody tr:nth-of-type(odd)[b-ue9jshkziv] {
        background-color: #ffffff !important;
    }

    .table tbody tr:nth-of-type(even)[b-ue9jshkziv] {
        background-color: #f8f9fa !important;
    }

.table thead tr[b-ue9jshkziv] {
    border-bottom: 2px solid #dee2e6;
}

.td-xs[b-ue9jshkziv] {
    font-size: 0.75rem;
    padding: 2px 6px !important;
}

.table thead tr[b-ue9jshkziv] {
    background-color: #e9ecef; /* đậm hơn bg-light một chút */
}

.text-muted[b-ue9jshkziv] {
    font-size: 0.75rem;
    opacity: 0.7;
}

.table-container[b-ue9jshkziv] {
    border: 1px solid #dee2e6;
    border-radius: 0.375rem;
    overflow: hidden;
    margin: 0 12px 0;
}

.action-btn[b-ue9jshkziv] {
    padding: 2px 6px;
}

    .action-btn i[b-ue9jshkziv] {
        font-size: 0.85rem;
    }


.action-btn.btn-outline-primary:hover[b-ue9jshkziv] {
    background-color: transparent !important;
    color: #0b5ed7; /* đậm hơn primary */
}

.action-btn.btn-outline-danger:hover[b-ue9jshkziv] {
    background-color: transparent !important;
    color: #b02a37; /* đậm hơn danger */
}

.form-control[b-ue9jshkziv],
.btn[b-ue9jshkziv] {
    box-shadow: none !important;
}

.table-hover tbody tr:hover[b-ue9jshkziv] {
    background-color: inherit !important;
}

.btn-primary[b-ue9jshkziv] {
    font-size: 0.875rem;
}

.small-placeholder[b-ue9jshkziv]::placeholder {
    font-size: 0.75rem;
    opacity: 0.7;
}


.badge[b-ue9jshkziv] {
    font-weight: 500;
    letter-spacing: 0.3px;
}

.bg-success-subtle[b-ue9jshkziv] {
    background-color: #d1f2eb !important;
}

.text-success[b-ue9jshkziv] {
    color: #17a2b8 !important;
}

.bg-danger-subtle[b-ue9jshkziv] {
    background-color: #f8d7da !important;
}

.text-danger[b-ue9jshkziv] {
    color: #dc3545 !important;
}

.bg-warning-subtle[b-ue9jshkziv] {
    background-color: #fff3cd !important;
}

.text-warning[b-ue9jshkziv] {
    color: #ffc107 !important;
}

.page-link[b-ue9jshkziv] {
    color: #6c757d;
}

.page-item.active .page-link[b-ue9jshkziv] {
    background-color: #007bff;
    border-color: #007bff;
}

.btn-outline-primary:hover[b-ue9jshkziv],
.btn-outline-danger:hover[b-ue9jshkziv],
.btn-outline-secondary:hover[b-ue9jshkziv] {
    opacity: 1;
}

.card[b-ue9jshkziv] {
    overflow: hidden;
}

thead th[b-ue9jshkziv] {
    position: sticky;
    top: 0;
    background-color: #f8f9fa;
    z-index: 10;
}

.pagination-sm .page-link[b-ue9jshkziv] {
    font-size: 0.7rem;
    padding: 0.15rem 0.4rem;
}

.filter-input[b-ue9jshkziv] {
    font-size: 0.85rem !important; /* Thu nhỏ chữ */

    padding: 0.4rem 0.75rem;
    border-radius: 6px;
    height: 35px; /* Giảm nhẹ chiều cao của ô nhập liệu */
}



    /* Thu nhỏ chữ của placeholder (dòng chữ mờ) */

    .filter-input[b-ue9jshkziv]::placeholder {
        font-size: 0.8rem;
        opacity: 0.7;
    }
/* /Pages/Admin/Users.razor.rz.scp.css */
.table > :not(caption) > * > *[b-o0ooir75rl] {
    padding: 0.75rem 0.75rem;
    border-right: 1px solid #e9ecef;
}

    .table > :not(caption) > * > *:last-child[b-o0ooir75rl] {
        border-right: none;
    }

.table tbody tr[b-o0ooir75rl] {
    border-bottom: 1px solid #e9ecef;
}

    .table tbody tr:nth-of-type(odd)[b-o0ooir75rl] {
        background-color: #ffffff !important;
    }

    .table tbody tr:nth-of-type(even)[b-o0ooir75rl] {
        background-color: #f8f9fa !important;
    }

.table thead tr[b-o0ooir75rl] {
    border-bottom: 2px solid #dee2e6;
}

.td-xs[b-o0ooir75rl] {
    font-size: 0.75rem;
    padding: 2px 6px !important;
}

.table thead tr[b-o0ooir75rl] {
    background-color: #e9ecef; /* đậm hơn bg-light một chút */
}

.text-muted[b-o0ooir75rl] {
    font-size: 0.75rem;
    opacity: 0.7;
}

.table-container[b-o0ooir75rl] {
    border: 1px solid #dee2e6;
    border-radius: 0.375rem;
    overflow: hidden;
    margin: 0 12px 0;
}

.action-btn[b-o0ooir75rl] {
    padding: 2px 6px;
}

    .action-btn i[b-o0ooir75rl] {
        font-size: 0.85rem;
    }


    .action-btn.btn-outline-primary:hover[b-o0ooir75rl] {
        background-color: transparent !important;
        color: #0b5ed7; /* đậm hơn primary */
    }

    .action-btn.btn-outline-danger:hover[b-o0ooir75rl] {
        background-color: transparent !important;
        color: #b02a37; /* đậm hơn danger */
    }

.form-control[b-o0ooir75rl],
.btn[b-o0ooir75rl] {
    box-shadow: none !important;
}

.table-hover tbody tr:hover[b-o0ooir75rl] {
    background-color: inherit !important;
}

.btn-primary[b-o0ooir75rl] {
    font-size: 0.875rem;
}

.small-placeholder[b-o0ooir75rl]::placeholder {
    font-size: 0.75rem;
    opacity: 0.7;
}


.badge[b-o0ooir75rl] {
    font-weight: 500;
    letter-spacing: 0.3px;
}

.bg-success-subtle[b-o0ooir75rl] {
    background-color: #d1f2eb !important;
}

.text-success[b-o0ooir75rl] {
    color: #17a2b8 !important;
}

.bg-danger-subtle[b-o0ooir75rl] {
    background-color: #f8d7da !important;
}

.text-danger[b-o0ooir75rl] {
    color: #dc3545 !important;
}

.bg-warning-subtle[b-o0ooir75rl] {
    background-color: #fff3cd !important;
}

.text-warning[b-o0ooir75rl] {
    color: #ffc107 !important;
}

.page-link[b-o0ooir75rl] {
    color: #6c757d;
}

.page-item.active .page-link[b-o0ooir75rl] {
    background-color: #007bff;
    border-color: #007bff;
}

.btn-outline-primary:hover[b-o0ooir75rl],
.btn-outline-danger:hover[b-o0ooir75rl],
.btn-outline-secondary:hover[b-o0ooir75rl] {
    opacity: 1;
}

.card[b-o0ooir75rl] {
    overflow: hidden;
}

thead th[b-o0ooir75rl] {
    position: sticky;
    top: 0;
    background-color: #f8f9fa;
    z-index: 10;
}

.pagination-sm .page-link[b-o0ooir75rl] {
    font-size: 0.7rem;
    padding: 0.15rem 0.4rem;
}

.filter-input[b-o0ooir75rl] {
    font-size: 0.85rem !important; /* Thu nhỏ chữ */

    padding: 0.4rem 0.75rem;
    border-radius: 6px;
    height: 35px; /* Giảm nhẹ chiều cao của ô nhập liệu */
}



    /* Thu nhỏ chữ của placeholder (dòng chữ mờ) */

    .filter-input[b-o0ooir75rl]::placeholder {
        font-size: 0.8rem;
        opacity: 0.7;
    }
/* /Pages/Auth/Login.razor.rz.scp.css */
*:focus[b-7xjzjfyai4] {
    outline: none !important;
    box-shadow: none !important;
}

.login-container[b-7xjzjfyai4] {
    min-height: 100vh;
    display: flex;
    justify-content: center;
    align-items: center;
    background: linear-gradient(135deg, #f5f7fa, #c3cfe2);
    padding: 20px;
}

.login-card[b-7xjzjfyai4] {
    background: #fff;
    width: 100%;
    max-width: 380px;
    padding: 32px;
    border-radius: 12px;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.1);
}

.logo-section[b-7xjzjfyai4] {
    text-align: center;
    margin-bottom: 24px;
}

.brand-name[b-7xjzjfyai4] {
    font-size: 28px;
    font-weight: 900;
    color: #2c3e50;
    margin: 0;
    letter-spacing: -1px;
}

.brand-subtitle[b-7xjzjfyai4] {
    font-size: 11px;
    color: #7f8c8d;
    margin-top: 4px;
}

.input-box[b-7xjzjfyai4] {
    position: relative;
}

.custom-input[b-7xjzjfyai4],
.custom-input[b-7xjzjfyai4]::placeholder {
    font-size: 10px !important;
}

input.custom-input[b-7xjzjfyai4] {
    font-size: 10px !important;
}

.custom-input[b-7xjzjfyai4] {
    border-radius: 8px !important;
    border: 1px solid #e0e6ed !important;
    background: #f8f9fa !important;
    font-size: 10px !important;
    padding-left: 4px !important;
    padding-top: 0.5rem !important;
    padding-bottom: 0.5rem !important;
    min-height: 48px !important;
    transition: all 0.2s ease !important;
}

    .custom-input:focus[b-7xjzjfyai4] {
        background: #fff !important;
        border-color: #DA3743 !important;
    }

.floating-label[b-7xjzjfyai4] {
    position: absolute;
    left: 40px;
    top: 50%;
    transform: translateY(-50%);
    background: transparent;
    padding: 0 4px;
    color: #6c757d;
    font-size: 13px;
    pointer-events: none;
    transition: all 0.2s ease;
    z-index: 2;
}

.custom-input:focus ~ .floating-label[b-7xjzjfyai4],
.custom-input:not(:placeholder-shown) ~ .floating-label[b-7xjzjfyai4] {
    top: 0;
    left: 12px;
    font-size: 10px;
    color: #3498db;
    background: #fff;
    padding: 0 5px;
    font-weight: 600;
}

.input-icon[b-7xjzjfyai4] {
    position: absolute;
    left: 14px;
    top: 50%;
    transform: translateY(-50%);
    color: #6c757d;
    font-size: 16px;
    pointer-events: none;
    z-index: 3;
    transition: color 0.2s ease;
}

.input-box:focus-within .input-icon[b-7xjzjfyai4] {
    color: #3498db;
}

.form-options[b-7xjzjfyai4] {
    display: flex;
    justify-content: flex-end;
    margin-bottom: 16px;
    font-size: 12px;
}

.forgot-link[b-7xjzjfyai4] {
    color: #DA3743;
    text-decoration: none;
    font-weight: 500;
}

    .forgot-link:hover[b-7xjzjfyai4] {
        text-decoration: underline;
    }

.btn-login[b-7xjzjfyai4] {
    border-radius: 8px !important;
    padding: 12px !important;
    font-weight: 600 !important;
    background: #DA3743 !important;
    border: none !important;
    box-shadow: 0 4px 12px rgba(218, 55, 67, 0.3) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    font-size: 13px !important;
    transition: all 0.3s ease !important;
}

    .btn-login:hover:not(:disabled)[b-7xjzjfyai4] {
        background: #bf2d38 !important;
        box-shadow: 0 6px 16px rgba(218, 55, 67, 0.4) !important;
    }

    .btn-login:disabled[b-7xjzjfyai4] {
        background: #f0a0a5 !important;
        opacity: 0.7;
    }

.btn-google[b-7xjzjfyai4] {
    border-radius: 8px !important;
    padding: 12px !important;
    font-weight: 500 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    font-size: 13px !important;
    background: #fff;
    transition: all 0.2s ease;
    border: 1px solid #e0e0e0;
}

    .btn-google:hover[b-7xjzjfyai4] {
        background: #f5f5f5;
        border-color: #d0d0d0;
        color: #6c757d;
    }

.google-icon[b-7xjzjfyai4] {
    width: 16px;
    height: 16px;
}

.divider[b-7xjzjfyai4] {
    display: flex;
    align-items: center;
    margin: 20px 0;
    color: #6c757d;
    font-size: 12px;
}

    .divider[b-7xjzjfyai4]::before,
    .divider[b-7xjzjfyai4]::after {
        content: "";
        flex: 1;
        border-bottom: 1px solid #dee2e6;
    }

    .divider span[b-7xjzjfyai4] {
        padding: 0 12px;
        font-weight: 500;
    }

.spinner[b-7xjzjfyai4] {
    display: inline-block;
    width: 16px;
    height: 16px;
    border: 2px solid rgba(255, 255, 255, 0.3);
    border-top-color: #fff;
    border-radius: 50%;
    animation: spin-b-7xjzjfyai4 0.6s linear infinite;
}

@keyframes spin-b-7xjzjfyai4 {
    to {
        transform: rotate(360deg);
    }
}

.login-error[b-7xjzjfyai4] {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    background: #fdecea;
    color: #c0392b;
    padding: 12px;
    border-radius: 8px;
    font-size: 12px;
    margin-bottom: 16px;
}

    .login-error i[b-7xjzjfyai4] {
        font-size: 16px;
        flex-shrink: 0;
        margin-top: 1px;
    }

    .login-error ul[b-7xjzjfyai4] {
        margin: 0;
        padding-left: 16px;
        flex: 1;
    }

    .login-error li[b-7xjzjfyai4] {
        list-style: disc;
        line-height: 1.5;
    }

.register-link[b-7xjzjfyai4] {
    margin-top: 20px;
    text-align: center;
    font-size: 12px;
    color: #6c757d;
}

    .register-link a[b-7xjzjfyai4] {
        margin-left: 5px;
        color: #DA3743;
        font-weight: 600;
        text-decoration: none;
    }

        .register-link a:hover[b-7xjzjfyai4] {
            color: #DA3743;
            text-decoration: underline;
        }

.login-success[b-7xjzjfyai4] {
    background: linear-gradient(135deg, #d4edda 0%, #c3e6cb 100%);
    border: 1px solid #c3e6cb;
    color: #155724;
    padding: 1rem;
    border-radius: 12px;
    margin-bottom: 1.5rem;
    display: flex;
    align-items: center;
    gap: 0.75rem;
    animation: slideDown-b-7xjzjfyai4 0.3s ease-out;
}

    .login-success i[b-7xjzjfyai4] {
        font-size: 1.5rem;
    }

@keyframes slideDown-b-7xjzjfyai4 {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@media (max-width: 480px) {
    .login-card[b-7xjzjfyai4] {
        padding: 32px 18px;
    }

    .brand-name[b-7xjzjfyai4] {
        font-size: 24px;
    }
}

.modal-error[b-7xjzjfyai4] {
    animation: slideDown-b-7xjzjfyai4 0.25s ease-out;
}
/* /Pages/Auth/Register.razor.rz.scp.css */
*:focus[b-y8e75kq8c6] {
    outline: none !important;
    box-shadow: none !important;
}

.register-container[b-y8e75kq8c6] {
    min-height: 100vh;
    display: flex;
    justify-content: center;
    align-items: center;
    background: linear-gradient(135deg, #f5f7fa, #c3cfe2);
    padding: 20px;
}

.register-card[b-y8e75kq8c6] {
    background: #fff;
    width: 100%;
    max-width: 380px;
    padding: 32px;
    border-radius: 12px;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.1);
}

.logo-section[b-y8e75kq8c6] {
    text-align: center;
    margin-bottom: 24px;
}

.brand-name[b-y8e75kq8c6] {
    font-size: 28px;
    font-weight: 900;
    color: #2c3e50;
    margin: 0;
    letter-spacing: -1px;
}

.brand-subtitle[b-y8e75kq8c6] {
    font-size: 11px;
    color: #7f8c8d;
    margin-top: 4px;
}

.input-box[b-y8e75kq8c6] {
    position: relative;
}

.custom-input[b-y8e75kq8c6] {
    border-radius: 8px !important;
    border: 1px solid #e0e6ed !important;
    background: #f8f9fa !important;
    font-size: 10px !important;
    padding-left: 40px !important;
    padding-top: 0.5rem !important;
    padding-bottom: 0.5rem !important;
    min-height: 48px !important;
    transition: all 0.2s ease !important;
}

    .custom-input:focus[b-y8e75kq8c6] {
        background: #fff !important;
        border-color: #DA3743 !important;
    }

.floating-label[b-y8e75kq8c6] {
    position: absolute;
    left: 40px;
    top: 50%;
    transform: translateY(-50%);
    background: transparent;
    padding: 0 4px;
    color: #6c757d;
    font-size: 13px;
    pointer-events: none;
    transition: all 0.2s ease;
    z-index: 2;
}

.custom-input:focus ~ .floating-label[b-y8e75kq8c6],
.custom-input:not(:placeholder-shown) ~ .floating-label[b-y8e75kq8c6] {
    top: 0;
    left: 12px;
    font-size: 10px;
    color: #3498db;
    background: #fff;
    padding: 0 5px;
    font-weight: 600;
}

.input-icon[b-y8e75kq8c6] {
    position: absolute;
    left: 14px;
    top: 50%;
    transform: translateY(-50%);
    color: #6c757d;
    font-size: 16px;
    pointer-events: none;
    z-index: 3;
    transition: color 0.2s ease;
}

.input-box:focus-within .input-icon[b-y8e75kq8c6] {
    color: #3498db;
}

.btn-register[b-y8e75kq8c6] {
    border-radius: 8px !important;
    padding: 12px !important;
    font-weight: 600 !important;
    background: #DA3743 !important;
    border: none !important;
    box-shadow: 0 4px 12px rgba(52, 152, 219, 0.3) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    font-size: 13px !important;
    transition: all 0.3s ease !important;
    margin-top: 50px !important;
}

    .btn-register:hover:not(:disabled)[b-y8e75kq8c6] {
        background: #bf2d38 !important;
        box-shadow: 0 6px 16px rgba(52, 152, 219, 0.4) !important;
    }

    .btn-register:disabled[b-y8e75kq8c6] {
        background: #f0a0a5 !important;
        opacity: 0.7;
    }

.spinner[b-y8e75kq8c6] {
    display: inline-block;
    width: 16px;
    height: 16px;
    border: 2px solid rgba(255, 255, 255, 0.3);
    border-top-color: #fff;
    border-radius: 50%;
    animation: spin-b-y8e75kq8c6 0.6s linear infinite;
}

@keyframes spin-b-y8e75kq8c6 {
    to {
        transform: rotate(360deg);
    }
}

.register-error[b-y8e75kq8c6] {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    background: #fdecea;
    color: #c0392b;
    padding: 12px;
    border-radius: 8px;
    font-size: 12px;
    margin-bottom: 16px;
}

    .register-error i[b-y8e75kq8c6] {
        font-size: 16px;
        flex-shrink: 0;
        margin-top: 1px;
    }

    .register-error ul[b-y8e75kq8c6] {
        margin: 0;
        padding-left: 16px;
        flex: 1;
    }

    .register-error li[b-y8e75kq8c6] {
        list-style: disc;
        line-height: 1.5;
    }

.register-success[b-y8e75kq8c6] {
    display: flex;
    align-items: center;
    gap: 10px;
    background: #d4edda;
    color: #155724;
    padding: 12px;
    border-radius: 8px;
    font-size: 12px;
    margin-bottom: 16px;
}

    .register-success i[b-y8e75kq8c6] {
        font-size: 16px;
        flex-shrink: 0;
    }

.login-link[b-y8e75kq8c6] {
    margin-top: 20px;
    text-align: center;
    font-size: 12px;
    color: #6c757d;
}

    .login-link a[b-y8e75kq8c6] {
        margin-left: 5px;
        color: #DA3743;
        font-weight: 600;
        text-decoration: none;
    }

        .login-link a:hover[b-y8e75kq8c6] {
            color: #DA3743;
            text-decoration: underline;
        }

@media (max-width: 480px) {
    .register-card[b-y8e75kq8c6] {
        padding: 32px 18px;
    }

    .brand-name[b-y8e75kq8c6] {
        font-size: 24px;
    }
}

.modal-error[b-y8e75kq8c6] {
    animation: slideDown 0.25s ease-out;
}
/* /Pages/Customer/BookingDetail.razor.rz.scp.css */
.btn-outline-secondary[b-gynhwc72t1] {
    background-color: #ffffff;
    color: #4a4a4a;
    border: 1px solid #dcdfe4;
    font-weight: 600;
    /* Giảm padding và font-size */
    padding: 0.35rem 0.8rem;
    font-size: 0.8rem;
    border-radius: 5px; /* Bo góc nhỏ lại cho cân đối */
    transition: all 0.2s ease;
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
}

.text-muted[b-gynhwc72t1] {
    font-size: 0.875rem;
}

.booking-detail-container[b-gynhwc72t1] {
    max-width: 900px;
}

.table-borderless td[b-gynhwc72t1] {
    padding: 0.5rem 0;
}

    .table-borderless td:first-child[b-gynhwc72t1] {
        width: 150px;
    }

.btn-outline-secondary[b-gynhwc72t1],
.status[b-gynhwc72t1] {
    font-size: 0.75rem;
}

.mb-1[b-gynhwc72t1] {
    font-size: 1rem;
}
/* /Pages/Customer/BookingEdit.razor.rz.scp.css */
.btn-outline-secondary[b-4td181bjly] {
    background-color: #ffffff;
    color: #4a4a4a;
    border: 1px solid #dcdfe4;
    font-weight: 600;
    /* Giảm padding và font-size */
    padding: 0.35rem 0.8rem;
    font-size: 0.8rem;
    border-radius: 5px; /* Bo góc nhỏ lại cho cân đối */
    transition: all 0.2s ease;
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
}

.message[b-4td181bjly] {
    margin-bottom: 1rem;
}

.text-muted[b-4td181bjly] {
    font-size: 0.875rem;
}

.booking-detail-container[b-4td181bjly] {
    max-width: 900px;
}

.table-borderless td[b-4td181bjly] {
    padding: 0.5rem 0;
}

    .table-borderless td:first-child[b-4td181bjly] {
        width: 150px;
    }

.btn-outline-secondary[b-4td181bjly],
.status[b-4td181bjly] {
    font-size: 0.75rem;
}

.mb-1[b-4td181bjly] {
    font-size: 1rem;
}

.qty-micro[b-4td181bjly] {
    padding: 2px;
    min-width: 65px;
    justify-content: space-between;
}

.btn-micro[b-4td181bjly] {
    background: transparent;
    border: none;
    padding: 0;
    width: 20px;
    height: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #495057;
    border-radius: 4px;
    transition: 0.15s ease;
}

    .btn-micro:hover[b-4td181bjly] {
        background: #e9ecef;
        color: #DA3743;
    }

/* Tùy chỉnh thanh thêm món */
.add-item-bar[b-4td181bjly] {
    border-color: #e9ecef !important;
}

    /* Đảm bảo các thành phần trong thanh (select, input, button) có chiều cao bằng nhau */
    .add-item-bar .form-select-sm[b-4td181bjly],
    .add-item-bar .form-control-sm[b-4td181bjly],
    .add-item-bar .btn-sm[b-4td181bjly] {
        height: 36px;
        font-size: 0.875rem;
    }

    /* Ẩn mũi tên tăng giảm số mặc định của input number (tùy chọn, giúp gọn hơn) */
    .add-item-bar input[type=number][b-4td181bjly]::-webkit-inner-spin-button,
    .add-item-bar input[type=number][b-4td181bjly]::-webkit-outer-spin-button {
        -webkit-appearance: none;
        margin: 0;
    }

    .add-item-bar input[type=number][b-4td181bjly] {
        -moz-appearance: textfield; /* Firefox */
    }

/* Tùy chỉnh nút Thêm (Đồng bộ với màu #DA3743 của bạn) */
.btn-custom-add[b-4td181bjly] {
    background-color: #fff;
    color: #DA3743;
    border: 1px solid #DA3743;
    font-weight: 500;
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    justify-content: center;
}

    .btn-custom-add:hover:not(:disabled)[b-4td181bjly] {
        background-color: #DA3743;
        color: #fff;
    }

    .btn-custom-add:disabled[b-4td181bjly] {
        border-color: #ced4da;
        color: #6c757d;
        background-color: #f8f9fa;
        cursor: not-allowed;
    }

/* Xử lý hiển thị tốt trên màn hình nhỏ (Mobile) */
@media (max-width: 768px) {
    .add-item-bar > div[b-4td181bjly] {
        width: 100% !important; /* Buộc tất cả rớt dòng và full width */
    }
}

.textarea[b-4td181bjly] {
    font-size: 0.875rem !important;
}
/* Nút Hủy bỏ */
.btn-cancel[b-4td181bjly] {
    background-color: #f8f9fa;
    color: #6c757d;
    border: 1px solid #dcdfe4;
    font-weight: 600;
    font-size: 0.85rem;
    border-radius: 6px;
    transition: all 0.2s ease;
}

    .btn-cancel:hover[b-4td181bjly] {
        background-color: #e9ecef;
        color: #343a40;
        border-color: #adb5bd;
    }

/* Nút Lưu thay đổi (Tông màu đỏ thương hiệu) */
.btn-save[b-4td181bjly] {
    background-color: #DA3743; /* Màu đỏ chủ đạo của bạn */
    color: #ffffff;
    border: 1px solid #DA3743;
    font-weight: 600;
    font-size: 0.85rem;
    border-radius: 6px;
    transition: all 0.3s;
    display: inline-flex;
    align-items: center;
}

    .btn-save:hover:not(:disabled)[b-4td181bjly] {
        background-color: #b52a35; /* Đỏ đậm hơn khi hover */
        border-color: #b52a35;
        color: #ffffff;
        box-shadow: 0 4px 12px rgba(218, 55, 67, 0.25);
    }

    .btn-save:active:not(:disabled)[b-4td181bjly] {
        transform: translateY(0);
    }

    /* Trạng thái khi đang lưu hoặc bị khóa */
    .btn-save:disabled[b-4td181bjly] {
        background-color: #ea868d;
        border-color: #ea868d;
        color: rgba(255, 255, 255, 0.8);
        cursor: not-allowed;
    }

    /* Đồng bộ icon trong nút */
    .btn-save i[b-4td181bjly], .btn-cancel i[b-4td181bjly] {
        font-size: 0.9rem;
    }
/* /Pages/Customer/BookTable.razor.rz.scp.css */
.container[b-i16nokm4qe] {
    max-width: 1200px;
    padding: 2rem 1rem;
    margin: 0 auto;
}

.countdown-elegant[b-i16nokm4qe] {
    background-color: transparent; /* Bỏ background */
    color: #4a4a4a;
    font-size: 0.875rem;
    padding: 0.5rem 0;
    margin-top: 0.5rem;
}

    /* Chỉnh màu icon và tạo hiệu ứng nhịp đập */
    .countdown-elegant .bi-clock-history[b-i16nokm4qe] {
        color: #DA3743; /* Màu đỏ thương hiệu */
        font-size: 1.2rem;
        animation: clockPulse-b-i16nokm4qe 1.5s infinite;
    }

    /* Làm nổi bật số thời gian */
    .countdown-elegant .time-display[b-i16nokm4qe] {
        color: #DA3743;
        font-size: 1.15rem;
        font-family: 'Courier New', Courier, monospace; /* Dùng font monospace để số không bị giật ngang khi đếm */
        background: #fff0f1; /* Nền đỏ cực nhạt để số nổi lên */
        padding: 2px 8px;
        border-radius: 6px;
        border: 1px solid rgba(218, 55, 67, 0.2);
        margin-left: 4px;
    }

/* Hiệu ứng nhịp đập cho icon đồng hồ */
@keyframes clockPulse-b-i16nokm4qe {
    0% {
        transform: scale(1);
        opacity: 1;
    }

    50% {
        transform: scale(1.1);
        opacity: 0.7;
    }

    100% {
        transform: scale(1);
        opacity: 1;
    }
}

.message[b-i16nokm4qe] {
    max-width: 1200px;
    padding: 1rem 0rem;
}
/* /Pages/Customer/ChangePassword.razor.rz.scp.css */
/* =========================================
       LAYOUT & CONTAINER (TRANG PASSWORD)
       ========================================= */
.hp-page-wrapper[b-a8ih5bde0q] {
    min-height: 100vh;
    padding: 3rem 1.5rem;
    background-color: transparent;
    display: flex;
    justify-content: center;
    align-items: flex-start;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

/* Card thu nhỏ cho form đổi mật khẩu */
.hp-password-card[b-a8ih5bde0q] {
    width: 100%;
    max-width: 550px;
    background-color: #ffffff;
    border: 1px solid #e5e7eb;
    border-radius: 7px;
    padding: 2.5rem;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05), 0 2px 4px -1px rgba(0, 0, 0, 0.03);
}

/* =========================================
       HEADER & NÚT BACK
       ========================================= */
.hp-pwd-header[b-a8ih5bde0q] {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: 2rem;
    padding-bottom: 1.5rem;
    border-bottom: 1px solid #f3f4f6;
}

.hp-title[b-a8ih5bde0q] {
    font-size: 1.5rem;
    font-weight: 600;
    color: #111827;
    margin: 0 0 0.4rem 0;
}

.hp-subtitle[b-a8ih5bde0q] {
    font-size: 0.9rem;
    color: #6b7280;
    margin: 0;
}

/* =========================================
       FORM & INPUTS
       ========================================= */
.hp-form[b-a8ih5bde0q] {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.hp-form-group[b-a8ih5bde0q] {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.hp-label[b-a8ih5bde0q] {
    font-size: 0.875rem;
    font-weight: 600;
    color: #374151;
}

.hp-input[b-a8ih5bde0q] {
    width: 100%;
    padding: 0.5rem 0.9rem;
    font-size: 0.75rem;
    color: #111827;
    background-color: #ffffff;
    border: 1px solid #9ca3af;
    border-radius: 6px;
    outline: none;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
    transition: all 0.2s ease-in-out;
}

    .hp-input[b-a8ih5bde0q]::placeholder {
        color: #9ca3af;
    }

    .hp-input:hover[b-a8ih5bde0q] {
        border-color: #6b7280;
    }

/* =========================================
       BUTTONS
       ========================================= */
.hp-form-actions[b-a8ih5bde0q] {
    display: flex;
    justify-content: flex-end;
    gap: 1rem;
    padding-top: 2rem;
    border-top: 1px solid #f3f4f6;
}

.hp-btn[b-a8ih5bde0q] {
    padding: 0.625rem 1.25rem;
    font-size: 0.75rem;
    font-weight: 500;
    border-radius: 5px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
    border: none;
}

.hp-btn-primary[b-a8ih5bde0q] {
    background-color: #DA3743;
    color: #ffffff;
}

    .hp-btn-primary:hover:not(:disabled)[b-a8ih5bde0q] {
        background-color: #bf2d38;
    }

    .hp-btn-primary:disabled[b-a8ih5bde0q] {
        opacity: 0.6;
        cursor: not-allowed;
    }

.hp-btn-outline[b-a8ih5bde0q] {
    background-color: #ffffff;
    color: #374151;
    border: 1px solid #d1d5db;
}

    .hp-btn-outline:hover[b-a8ih5bde0q] {
        background-color: #f9fafb;
        color: #111827;
        border-color: #9ca3af;
    }

/* =========================================
       ALERTS
       ========================================= */
.hp-alert[b-a8ih5bde0q] {
    padding: 1rem;
    border-radius: 6px;
    margin-bottom: 1.5rem;
    font-size: 0.7rem;
    display: flex;
    align-items: flex-start;
    gap: 0.6rem;
}

.hp-alert-success[b-a8ih5bde0q] {
    background-color: #f0fdf4;
    color: #166534;
    border: 1px solid #bbf7d0;
}

.hp-alert-danger[b-a8ih5bde0q] {
    background-color: #fef2f2;
    color: #991b1b;
    border: 1px solid #fecaca;
}

/* =========================================
       RESPONSIVE (MOBILE)
       ========================================= */
@media (max-width: 576px) {
    .hp-password-card[b-a8ih5bde0q] {
        padding: 1.5rem;
    }

    .hp-pwd-header[b-a8ih5bde0q] {
        flex-direction: column;
        align-items: flex-start;
    }

    .hp-form-actions[b-a8ih5bde0q] {
        flex-direction: column-reverse;
    }

    .hp-btn[b-a8ih5bde0q] {
        width: 100%;
    }
}
/* /Pages/Customer/Components/AlertMessage.razor.rz.scp.css */
.hp-alert[b-kcogj2ytde] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 1rem;
    border-radius: 6px;
    font-size: 0.75rem;
}

.hp-alert-success[b-kcogj2ytde] {
    background-color: #f0fdf4;
    color: #166534;
    border: 1px solid #bbf7d0;
}

.hp-alert-danger[b-kcogj2ytde] {
    background-color: #fef2f2;
    color: #991b1b;
    border: 1px solid #fecaca;
}
/* /Pages/Customer/Components/BookConfirmSection.razor.rz.scp.css */
/* Container chính */
.checkout-container[b-k340mrojh9] {
    max-width: 1200px;
    margin-left: auto;
    margin-right: auto;
}

/* Nút quay lại Text */
.btn-back-step[b-k340mrojh9] {
    background-color: #ffffff;
    color: #4a4a4a;
    border: 1px solid #dcdfe4;
    font-weight: 600;
    padding: 0.35rem 0.8rem;
    font-size: 0.8rem;
    border-radius: 5px;
    transition: all 0.2s ease;
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;    
}

    .btn-back-step:hover[b-k340mrojh9] {
        background-color: #f8f9fa;
        color: #1a1a1a;
        border-color: #c4c8d0;
    }

/* ================= CLASS DÙNG CHUNG CHO 2 CỘT ================= */
.checkout-card[b-k340mrojh9] {
    background-color: #ffffff;
    border-radius: 12px;
    padding: 1.75rem;
    border: 1px solid #ebecf0;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.04);
}

/* Kích hoạt Sticky cho cột phải */
.summary-card[b-k340mrojh9] {
    top: 2rem;
    z-index: 10;
}

/* Tiêu đề */
.section-title[b-k340mrojh9], .summary-title[b-k340mrojh9] {
    font-weight: 700;
    color: #111111;
    font-size: 1.3rem;
    letter-spacing: -0.3px;
    border-bottom: 2px solid #f0f0f0;
    padding-bottom: 0.75rem;
}

/* Form Inputs */
.form-label[b-k340mrojh9] {
    font-size: 0.9rem;
    color: #444;
}

.custom-input[b-k340mrojh9] {
    border-radius: 8px;
    border: 1px solid #d1d5db;
    padding: 0.6rem 1rem;
    font-size: 0.75rem;
    color: #111;
    transition: all 0.2s ease-in-out;
    background-color: #f9fafb;
}

    .custom-input:focus[b-k340mrojh9] {
        background-color: #ffffff;
        border-color: #DA3743;
        box-shadow: 0 0 0 1px #DA3743;
    }

    .custom-input[b-k340mrojh9]::placeholder {
        color: #9ca3af;
        font-size: 0.9rem;
    }

/* ================= CHI TIẾT CỘT PHẢI ================= */
.summary-row[b-k340mrojh9] {
    display: flex;
    justify-content: space-between;
    font-size: 0.85rem;
    margin-bottom: 0.85rem;
}

.edit-time-link[b-k340mrojh9] {
    display: inline-block;
    margin-top: 4px;
    font-size: 0.8rem;
    color: #0d6efd;
    cursor: pointer;
    font-weight: 500;
    transition: 0.2s;
}

    .edit-time-link:hover[b-k340mrojh9] {
        color: #DA3743;
        text-decoration: underline;
    }

.summary-divider[b-k340mrojh9] {
    height: 1px;
    background-color: #ebecf0;
    margin: 1.25rem 0;
}

/* Danh sách món ăn */
.summary-items-list[b-k340mrojh9] {
    max-height: 220px;
    overflow-y: auto;
}

    .summary-items-list[b-k340mrojh9]::-webkit-scrollbar {
        width: 4px;
    }

    .summary-items-list[b-k340mrojh9]::-webkit-scrollbar-thumb {
        background-color: #d1d5db;
        border-radius: 4px;
    }

        .summary-items-list[b-k340mrojh9]::-webkit-scrollbar-thumb:hover {
            background-color: #DA3743;
        }

/* Bộ điều khiển số lượng món ăn nhỏ gọn (Micro) */
.qty-micro[b-k340mrojh9] {
    padding: 2px;
    min-width: 65px;
    justify-content: space-between;
}

.btn-micro[b-k340mrojh9] {
    background: transparent;
    border: none;
    padding: 0;
    width: 20px;
    height: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #495057;
    border-radius: 4px;
    transition: 0.15s ease;
}

    .btn-micro:hover[b-k340mrojh9] {
        background: #e9ecef;
        color: #DA3743;
    }

.qty-val-micro[b-k340mrojh9] {
    font-weight: 600;
    font-size: 0.8rem;
    width: 16px;
    text-align: center;
    color: #212529;
}

/* Nút Xác Nhận To, Rõ Ràng */
.btn-confirm[b-k340mrojh9] {
    background-color: #DA3743;
    color: #ffffff;
    font-weight: 700;
    font-size: 1.05rem;
    padding: 0.9rem 1.5rem;
    border-radius: 6px;
    border: none;
    transition: all 0.2s;
    display: flex;
    justify-content: center;
    align-items: center;
}

    .btn-confirm:hover:not(:disabled)[b-k340mrojh9] {
        background-color: #bf2d38;
        box-shadow: 0 6px 16px rgba(218, 55, 67, 0.25);
        transform: translateY(0);
    }

    .btn-confirm:disabled[b-k340mrojh9] {
        background-color: #fca5a5;
        cursor: not-allowed;
    }

/* Mobile Responsive */
@media (max-width: 991px) {
    .summary-card[b-k340mrojh9] {
        margin-top: 0;
        position: static !important; /* Tắt sticky trên điện thoại */
    }

    .checkout-card[b-k340mrojh9] {
        padding: 1.25rem; /* Thu nhỏ đệm trên điện thoại */
    }
}
/* /Pages/Customer/Components/BookMenuSection.razor.rz.scp.css */
.menu-card[b-kmwqedy358] {
    border: 1px solid #f0f0f0;
    border-radius: 8px;
    overflow: hidden;
    transition: 0.25s ease;
    background: #fff;
    box-shadow: 0 4px 14px rgba(0,0,0,0.03);
}

.menu-img[b-kmwqedy358] {
    height: 130px;
    object-fit: cover;
    width: 100%;
}

.menu-img-placeholder[b-kmwqedy358] {
    height: 150px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #f8f9fa;
    font-size: 2rem;
    color: #ccc;
}

.badge-featured[b-kmwqedy358] {
    position: absolute;
    top: 12px;
    right: 12px;
    background: #DA3743;
    color: white;
    padding: 6px 10px;
    border-radius: 4px;
    font-size: 0.5rem;
    font-weight: 600;
}

.menu-title[b-kmwqedy358] {
    font-weight: 600;
    font-size: 1rem;
    margin-bottom: 0.5rem;
    color: #222;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.menu-time[b-kmwqedy358] {
    font-size: 0.75rem;
    color: #999;
}

.menu-price[b-kmwqedy358] {
    font-size: 1rem;
    font-weight: 800;
    color: #DA3743;
    margin-top: 0.3rem;
}

.badge-tag[b-kmwqedy358] {
    font-size: 0.7rem;
    padding: 3px 6px;
    border-radius: 6px;
    margin-bottom: 0.5rem;
}

    .badge-tag.veg[b-kmwqedy358] {
        background: #e8f7ee;
        color: #28a745;
    }

    .badge-tag.spicy[b-kmwqedy358] {
        background: #fdecea;
        color: #dc3545;
    }

    .badge-tag.kcal[b-kmwqedy358] {
        background: #f1f3f5;
        color: #555;
    }

.btn-add[b-kmwqedy358] {
    width: 26px;
    height: 26px;
    border-radius: 50%;
    border: none;
    background: #DA3743;
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
    padding: 0;
}

    .btn-add i[b-kmwqedy358] {
        font-size: 0.9rem;
    }

    .btn-add:hover[b-kmwqedy358] {
        background: #bf2d38;
        transform: scale(1.05);
    }

.qty-box[b-kmwqedy358] {
    height: 26px;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: #f8f9fa;
    border-radius: 13px;
    padding: 0 8px;
    border: 1px solid #eee;
}

    .qty-box button[b-kmwqedy358] {
        border: none;
        background: none;
        font-size: 0.75rem;
        color: #DA3743;
        cursor: pointer;
        padding: 0;
        display: flex;
        align-items: center;
        justify-content: center;
        width: 12px;
        height: 100%;
    }

    .qty-box span[b-kmwqedy358] {
        font-weight: 700;
        font-size: 0.85rem;
        min-width: 12px;
        text-align: center;
        color: #333;
    }

.custom-filter-select[b-kmwqedy358] {
    width: auto;
    min-width: 150px;
    border-radius: 3px;
    border-color: #dcdfe4;
    color: #4a4a4a;
    font-weight: 500;
    cursor: pointer;
    padding: 0.4rem 2rem 0.4rem 1rem;
    font-size: 0.7rem;
}

.btn-back-step[b-kmwqedy358] {
    background-color: #ffffff;
    color: #4a4a4a;
    border: 1px solid #dcdfe4;
    font-weight: 600;
    /* Giảm padding và font-size */
    padding: 0.35rem 0.8rem;
    font-size: 0.8rem;
    border-radius: 5px; /* Bo góc nhỏ lại cho cân đối */
    transition: all 0.2s ease;
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
}

    .btn-back-step:hover[b-kmwqedy358] {
        background-color: #f8f9fa;
        color: #1a1a1a;
        border-color: #c4c8d0;
    }

.btn-continue-step[b-kmwqedy358] {
    background-color: #DA3743;
    color: #ffffff;
    font-weight: 600;
    /* Đồng bộ kích thước với nút Back */
    padding: 0.35rem 1.2rem;
    font-size: 0.8rem;
    border-radius: 5px;
    border: none;
    transition: all 0.2s ease;
    display: inline-flex;
    align-items: center;
}

    .btn-continue-step:hover[b-kmwqedy358] {
        background-color: #bf2d38;
        color: #ffffff;
        box-shadow: 0 2px 8px rgba(218, 55, 67, 0.2);
    }

    .btn-continue-step:active[b-kmwqedy358] {
        transform: translateY(0);
        box-shadow: none;
    }

.selected-summary-compact[b-kmwqedy358] {
    background-color: #fff;
    border: 1px solid #eaeaea;
    border-radius: 6px;
    padding: 12px 16px; /* Giảm padding viền ngoài */
}

/* Khung chứa nút cộng trừ siêu nhỏ */
.qty-control-compact[b-kmwqedy358] {
    display: flex;
    align-items: center;
    background-color: #f8f9fa;
    border-radius: 12px;
    border: 1px solid #e9ecef;
    padding: 1px;
}

    /* Nút bấm thu nhỏ tối đa */
    .qty-control-compact .btn-qty[b-kmwqedy358] {
        background: transparent;
        border: none;
        color: #555;
        width: 20px; /* Thu nhỏ từ 26px xuống 20px */
        height: 20px;
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 0.8rem;
        padding: 0;
    }

        .qty-control-compact .btn-qty:hover[b-kmwqedy358] {
            color: #DA3743;
        }

    /* Số lượng thu nhỏ */
    .qty-control-compact .qty-val[b-kmwqedy358] {
        font-weight: 600;
        font-size: 0.8rem;
        min-width: 16px;
        text-align: center;
        color: #333;
    }

/* =========================================================
   STYLE CHO NÚT GIỎ HÀNG (CART BUTTON)
   ========================================================= */
.cart-btn[b-kmwqedy358] {
    position: relative;
    width: 32px;
    height: 32px;
    border-radius: 8px;
    border: 1px solid #e2e2e2;
    background: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: 1.1rem;
    color: #4a4a4a;
    transition: all 0.2s ease;
}

    .cart-btn:hover[b-kmwqedy358] {
        background: #f8f9fa;
        border-color: #dcdfe4;
    }

    .cart-btn.has-items[b-kmwqedy358] {
        border-color: #DA3743;
        color: #DA3743;
        background-color: #fffaf9;
    }

.cart-badge[b-kmwqedy358] {
    position: absolute;
    top: -6px;
    right: -6px;
    background: #DA3743;
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    min-width: 18px;
    height: 18px;
    border-radius: 9px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 4px;
    box-shadow: 0 2px 4px rgba(218, 55, 67, 0.3);
}

/* =========================================================
   STYLE CHO BẢNG GIỎ HÀNG (CART PANEL DROPDOWN)
   ========================================================= */
.cart-panel[b-kmwqedy358] {
    min-width: 320px;
    max-width: 360px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.1) !important;
    border-radius: 7px;
    border: 1px solid #f0f0f0;
    padding: 1.25rem !important;
    margin-top: 10px !important;
}

/* Danh sách món ăn trong giỏ & Thanh cuộn mượt */
.cart-list[b-kmwqedy358] {
    max-height: 250px;
    overflow-y: auto;
    padding-right: 6px;
}

    .cart-list[b-kmwqedy358]::-webkit-scrollbar {
        width: 4px;
    }

    .cart-list[b-kmwqedy358]::-webkit-scrollbar-track {
        background: transparent;
    }

    .cart-list[b-kmwqedy358]::-webkit-scrollbar-thumb {
        background: #dee2e6;
        border-radius: 4px;
    }

        .cart-list[b-kmwqedy358]::-webkit-scrollbar-thumb:hover {
            background: #DA3743;
        }

/* =========================================================
   STYLE CHO BỘ NÚT TĂNG GIẢM TRONG GIỎ HÀNG (MICRO QTY)
   ========================================================= */
.qty-micro[b-kmwqedy358] {
    padding: 2px;
    min-width: 70px;
    justify-content: space-between;
    background-color: #f8f9fa;
    border: 1px solid #e9ecef !important;
}

.btn-micro[b-kmwqedy358] {
    background: transparent;
    border: none;
    padding: 0;
    width: 22px;
    height: 22px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #495057;
    border-radius: 4px;
    transition: 0.15s ease;
    font-size: 0.9rem;
}

    .btn-micro:hover[b-kmwqedy358] {
        background: #e2e6ea;
        color: #DA3743;
    }

.qty-val-micro[b-kmwqedy358] {
    font-weight: 600;
    font-size: 0.85rem;
    width: 20px;
    text-align: center;
    color: #212529;
}

/* ================= TÌM KIẾM MÓN ĂN ================= */
.search-input[b-kmwqedy358] {
    border-radius: 5px;
    border: 1px solid #dcdfe4;
    font-size: 0.8rem;
    color: #4a4a4a;
    transition: all 0.2s ease-in-out;
    background-color: #fff;
}

    /* Hiệu ứng khi click/nhập vào ô tìm kiếm */
    .search-input:focus[b-kmwqedy358] {
        border-color: #DA3743;
        box-shadow: 0 0 0 1px rgba(218, 55, 67, 0.5); /* Sáng viền đỏ nhẹ */
        outline: none;
    }

    .search-input[b-kmwqedy358]::placeholder {
        color: #9ca3af;
        font-size: 0.8rem;
    }

.btn-search[b-kmwqedy358] {
    background-color: #DA3743;
    color: #ffffff;
    font-weight: 600;
    font-size: 0.8rem;
    border: none;
    border-radius: 5px;
    padding: 0.35rem 0.8rem;
    transition: all 0.2s ease;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    white-space: nowrap; /* Tránh rớt dòng chữ */
}

    .btn-search:hover[b-kmwqedy358] {
        background-color: #bf2d38;
        color: #ffffff;
        box-shadow: 0 2px 6px rgba(218, 55, 67, 0.25); /* Đổ bóng đỏ khi hover */
    }

    .btn-search:active[b-kmwqedy358] {
        transform: translateY(1px); /* Lún xuống nhẹ khi bấm */
        box-shadow: none;
    }
/* /Pages/Customer/Components/BookTableSection.razor.rz.scp.css */
.table-card[b-uqnaa77tls] {
    border: 1px solid #f0f0f0;
    border-radius: 8px;
    overflow: hidden;
    transition: 0.25s ease;
    background: #fff;
    box-shadow: 0 4px 14px rgba(0,0,0,0.03);
    cursor: pointer;
}

    .table-card.selected[b-uqnaa77tls] {
        border: 1px solid #DA3743;
        box-shadow: 0 4px 12px rgba(218,55,67,0.2);
    }

.table-img[b-uqnaa77tls] {
    height: 130px;
    object-fit: cover;
    width: 100%;
}

.table-img-placeholder[b-uqnaa77tls] {
    height: 150px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #f8f9fa;
    font-size: 2rem;
    color: #ccc;
}

.badge-selected[b-uqnaa77tls] {
    position: absolute;
    top: 8px;
    right: 8px;
    background: #DA3743;
    color: white;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    box-shadow: 0 2px 8px rgba(218,55,67,0.4);
}

.table-title[b-uqnaa77tls] {
    font-weight: 600;
    font-size: 1rem;
    margin-bottom: 0.5rem;
    color: #222;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.alert-warning[b-uqnaa77tls] {
    font-size: 0.7rem;
}

.table-price[b-uqnaa77tls] {
    font-size: 1rem;
    font-weight: 800;
    color: #DA3743;
    margin-top: 0.3rem;
}

.badge-tag[b-uqnaa77tls] {
    font-size: 0.7rem;
    padding: 3px 6px;
    border-radius: 6px;
    margin-bottom: 0.5rem;
}

    .badge-tag.veg[b-uqnaa77tls] {
        background: #e8f7ee;
        color: #28a745;
    }

    .badge-tag.kcal[b-uqnaa77tls] {
        background: #f1f3f5;
        color: #555;
    }

.custom-filter-select[b-uqnaa77tls] {
    width: auto;
    min-width: 150px;
    border-radius: 5px;
    border-color: #dcdfe4;
    color: #4a4a4a;
    font-weight: 500;
    cursor: pointer;
    padding: 0.4rem 2rem 0.4rem 1rem;
    font-size: 0.7rem;
}

.btn-continue-step[b-uqnaa77tls] {
    background-color: #DA3743;
    color: #ffffff;
    font-weight: 600;
    /* Đồng bộ kích thước với nút Back */
    padding: 0.35rem 1.2rem;
    font-size: 0.8rem;
    border-radius: 5px;
    border: none;
    transition: all 0.2s ease;
    display: inline-flex;
    align-items: center;
}

    .btn-continue-step:hover[b-uqnaa77tls] {
        background-color: #bf2d38;
        color: #ffffff;
        box-shadow: 0 2px 8px rgba(218, 55, 67, 0.2);
    }

    .btn-continue-step:active[b-uqnaa77tls] {
        transform: translateY(0);
        box-shadow: none;
    }

/* Container chứa toàn bộ bản đồ (Giữ nguyên) */
.floor-plan-wrapper[b-uqnaa77tls] {
    background-color: #f8f9fa;
    border: 2px dashed #dee2e6;
    border-radius: 12px;
    padding: 15px;
    margin-bottom: 3rem !important;
}

.floor-plan-container[b-uqnaa77tls] {
    position: relative;
    width: 100%;
    height: 500px;
    background-color: #ffffff;
    border-radius: 8px;
    box-shadow: inset 0 0 10px rgba(0,0,0,0.05);
    overflow: hidden;
    background-image: radial-gradient(#e9ecef 1px, transparent 1px);
    background-size: 20px 20px;
}

/* Thay thế toàn bộ phần .table-node và các shape */

.table-node[b-uqnaa77tls] {
    position: absolute;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transform: translate(-50%, -50%);
    z-index: 10;
}

    .table-node:hover .table-surface[b-uqnaa77tls] {
        border-color: #DA3743;
        box-shadow: 0 6px 16px rgba(218, 55, 67, 0.25);
    }

    .table-node.selected .table-surface[b-uqnaa77tls] {
        background-color: #DA3743;
        border-color: #bf2d38;
        color: white;
    }

    .table-node.selected .table-capacity[b-uqnaa77tls] {
        color: #ffdce0;
    }

    .table-node.selected .chair[b-uqnaa77tls] {
        background-color: #bf2d38;
        border-color: #9e2530;
    }

/* Bề mặt bàn */
.table-surface[b-uqnaa77tls] {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background-color: #ffffff;
    border: 2px solid #ced4da;
    box-shadow: 0 4px 8px rgba(0,0,0,0.08);
    transition: all 0.2s ease;
    position: relative;
    z-index: 2;
}

/* Ghế */
.chair[b-uqnaa77tls] {
    position: absolute;
    background-color: #e9ecef;
    border: 2px solid #ced4da;
    border-radius: 4px;
    transition: all 0.2s ease;
    z-index: 1;
}

/* === ROUND: bàn tròn + ghế xung quanh === */
.table-node.round .table-surface[b-uqnaa77tls] {
    border-radius: 50%;
    width: 72px;
    height: 72px;
}

.table-node.round .chair[b-uqnaa77tls] {
    width: 14px;
    height: 10px;
    border-radius: 3px 3px 6px 6px;
}

/* Ghế trên */
.table-node.round .chair-top[b-uqnaa77tls] {
    top: -14px;
    left: 50%;
    transform: translateX(-50%);
}

/* Ghế dưới */
.table-node.round .chair-bottom[b-uqnaa77tls] {
    bottom: -14px;
    left: 50%;
    transform: translateX(-50%) rotate(180deg);
}

/* Ghế trái */
.table-node.round .chair-left[b-uqnaa77tls] {
    left: -14px;
    top: 50%;
    transform: translateY(-50%) rotate(-90deg);
}

/* Ghế phải */
.table-node.round .chair-right[b-uqnaa77tls] {
    right: -14px;
    top: 50%;
    transform: translateY(-50%) rotate(90deg);
}

/* === SQUARE: bàn vuông + ghế 4 cạnh === */
.table-node.square .table-surface[b-uqnaa77tls] {
    border-radius: 10px;
    width: 76px;
    height: 76px;
}

.table-node.square .chair[b-uqnaa77tls] {
    width: 18px;
    height: 10px;
    border-radius: 3px 3px 6px 6px;
}

.table-node.square .chair-top[b-uqnaa77tls] {
    top: -14px;
    left: 50%;
    transform: translateX(-50%);
}

.table-node.square .chair-bottom[b-uqnaa77tls] {
    bottom: -14px;
    left: 50%;
    transform: translateX(-50%) rotate(180deg);
}

.table-node.square .chair-left[b-uqnaa77tls] {
    left: -14px;
    top: 50%;
    transform: translateY(-50%) rotate(-90deg);
}

.table-node.square .chair-right[b-uqnaa77tls] {
    right: -14px;
    top: 50%;
    transform: translateY(-50%) rotate(90deg);
}

/* === RECTANGLE: bàn chữ nhật + 2 ghế mỗi cạnh dài === */
.table-node.rectangle .table-surface[b-uqnaa77tls] {
    border-radius: 10px;
    width: 110px;
    height: 68px;
}

.table-node.rectangle .chair[b-uqnaa77tls] {
    width: 18px;
    height: 10px;
    border-radius: 3px 3px 6px 6px;
}

.table-node.rectangle .chair-top-1[b-uqnaa77tls] {
    top: -14px;
    left: 28%;
    transform: translateX(-50%);
}

.table-node.rectangle .chair-top-2[b-uqnaa77tls] {
    top: -14px;
    left: 72%;
    transform: translateX(-50%);
}

.table-node.rectangle .chair-bottom-1[b-uqnaa77tls] {
    bottom: -14px;
    left: 28%;
    transform: translateX(-50%) rotate(180deg);
}

.table-node.rectangle .chair-bottom-2[b-uqnaa77tls] {
    bottom: -14px;
    left: 72%;
    transform: translateX(-50%) rotate(180deg);
}

.table-node.rectangle .chair-left[b-uqnaa77tls] {
    left: -14px;
    top: 50%;
    transform: translateY(-50%) rotate(-90deg);
}

.table-node.rectangle .chair-right[b-uqnaa77tls] {
    right: -14px;
    top: 50%;
    transform: translateY(-50%) rotate(90deg);
}

.table-node .table-name[b-uqnaa77tls] {
    font-weight: 700;
    font-size: 0.85rem;
    line-height: 1.1;
}

.table-node .table-capacity[b-uqnaa77tls] {
    font-size: 0.65rem;
    opacity: 0.8;
}

.table-check[b-uqnaa77tls] {
    position: absolute;
    top: -8px;
    right: -8px;
    background: white;
    border-radius: 50%;
    color: #DA3743;
    font-size: 1.1rem;
    line-height: 1;
    box-shadow: 0 2px 4px rgba(218, 55, 67, 0.3);
    z-index: 5;
}
/* /Pages/Customer/Components/Pagination.razor.rz.scp.css */
.pagination[b-036bvk3zyh] {
    gap: 0.2rem;
}

.page-item .page-link[b-036bvk3zyh] {
    color: #4a4a4a;
    background-color: #ffffff;
    border: 1px solid #dcdfe4;
    border-radius: 5px;
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 0.7rem;
    transition: all 0.2s ease-in-out;
    padding: 0;
}

.page-item:not(.active):not(.disabled) .page-link:hover[b-036bvk3zyh] {
    background-color: #f8f9fa;
    color: #DA3743;
    border-color: #c4c8d0;
}

.page-item.active .page-link[b-036bvk3zyh] {
    background-color: #DA3743;
    color: #ffffff;
    border-color: #DA3743;
    box-shadow: 0 4px 10px rgba(218, 55, 67, 0.25);
    z-index: 1;
}

.page-item.disabled .page-link[b-036bvk3zyh] {
    color: #adb5bd;
    background-color: #f9fafb;
    border-color: #ebecf0;
    cursor: not-allowed;
    opacity: 0.7;
}

.page-link i[b-036bvk3zyh] {
    font-size: 0.8rem;
    line-height: 1;
}
/* /Pages/Customer/Components/SearchBar.razor.rz.scp.css */
.search-section[b-70k1azlokn] {
    padding: 0.7rem 1.5rem 1.25rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.85rem;
    background: #fff;
}

.search-bar[b-70k1azlokn] {
    display: flex;
    align-items: stretch;
    gap: 0.4rem;
    width: 100%;
    max-width: 860px;
}

.search-group[b-70k1azlokn] {
    display: flex;
    align-items: stretch;
    border: 1px solid #d0d0d0;
    border-radius: 4px;
    background: #fff;
    box-shadow: 0 1px 3px rgba(0,0,0,0.06);
    flex-shrink: 0;
    overflow: visible;
}

    .search-group > *:first-child[b-70k1azlokn] {
        border-top-left-radius: 4px;
        border-bottom-left-radius: 4px;
    }

    .search-group > *:last-child[b-70k1azlokn] {
        border-top-right-radius: 4px;
        border-bottom-right-radius: 4px;
    }

.search-field[b-70k1azlokn] {
    display: flex;
    align-items: center;
    gap: 7px;
    padding: 0 1rem;
    font-size: 0.875rem;
    color: #222;
    cursor: pointer;
    white-space: nowrap;
    transition: background 0.15s;
    min-height: 46px;
}

    .search-field:hover[b-70k1azlokn] {
        background: #fafafa;
    }

    .search-field i[b-70k1azlokn] {
        color: #666;
        font-size: 0.95rem;
        flex-shrink: 0;
    }

    .search-field input[type="date"][b-70k1azlokn],
    .search-field input[type="number"][b-70k1azlokn] {
        border: none;
        outline: none;
        background: transparent;
        font-size: 0.875rem;
        color: #222;
        cursor: pointer;
        padding: 0;
        font-family: inherit;
    }

    .search-field input[type="number"][b-70k1azlokn] {
        font-weight: 700;
        width: 32px;
        text-align: center;
        -moz-appearance: textfield;
    }

        .search-field input[type="number"][b-70k1azlokn]::-webkit-outer-spin-button,
        .search-field input[type="number"][b-70k1azlokn]::-webkit-inner-spin-button {
            -webkit-appearance: none;
            margin: 0;
        }

.small-arrow[b-70k1azlokn] {
    font-size: 0.65rem !important;
    color: #999 !important;
}

.field-unit[b-70k1azlokn] {
    font-size: 0.8rem;
    color: #555;
}

.search-divider[b-70k1azlokn] {
    width: 1px;
    background: #e8e8e8;
    flex-shrink: 0;
    align-self: stretch;
    margin: 8px 0;
}

.custom-time-dropdown[b-70k1azlokn] {
    position: relative;
    display: flex;
    align-items: stretch;
}

.dropdown-overlay[b-70k1azlokn] {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 999;
}

.time-dropdown-menu[b-70k1azlokn] {
    position: absolute;
    top: 110%;
    left: 50%;
    transform: translateX(-50%);
    background: #fff;
    border: 1px solid #e0e0e0;
    border-radius: 8px;
    box-shadow: 0 10px 25px rgba(0,0,0,0.15);
    z-index: 1000;
    width: 130px;
    max-height: 260px;
    overflow-y: auto;
    padding: 0.5rem 0;
    list-style: none;
    margin: 0;
}

    .time-dropdown-menu[b-70k1azlokn]::-webkit-scrollbar {
        width: 6px;
    }

    .time-dropdown-menu[b-70k1azlokn]::-webkit-scrollbar-track {
        background: #f1f1f1;
        border-radius: 8px;
    }

    .time-dropdown-menu[b-70k1azlokn]::-webkit-scrollbar-thumb {
        background: #ccc;
        border-radius: 8px;
    }

        .time-dropdown-menu[b-70k1azlokn]::-webkit-scrollbar-thumb:hover {
            background: #aaa;
        }

.time-dropdown-item[b-70k1azlokn] {
    padding: 0.6rem 1rem;
    font-size: 0.9rem;
    color: #333;
    cursor: pointer;
    text-align: center;
    transition: all 0.2s ease;
}

    .time-dropdown-item:hover[b-70k1azlokn] {
        background-color: #fff0f1;
        color: #DA3743;
        font-weight: 600;
    }

    .time-dropdown-item.active[b-70k1azlokn] {
        background-color: #DA3743;
        color: white;
        font-weight: 600;
    }

.search-field--input[b-70k1azlokn] {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 0 1rem;
    background: #fff;
    flex: 1;
    min-width: 0;
    min-height: 46px;
    border: 1px solid #d0d0d0;
    box-shadow: none;
    border-radius: 4px;
}

    .search-field--input:focus-within[b-70k1azlokn] {
        border-color: #aaa;
    }

    .search-field--input i[b-70k1azlokn] {
        color: #888;
        font-size: 0.9rem;
        flex-shrink: 0;
    }

    .search-field--input input[b-70k1azlokn] {
        border: none;
        outline: none;
        font-size: 0.875rem;
        color: #222;
        background: transparent;
        width: 100%;
        font-family: inherit;
    }

        .search-field--input input[b-70k1azlokn]::placeholder {
            color: #bbb;
        }

.search-btn[b-70k1azlokn] {
    background: #DA3743;
    color: #fff;
    border: none;
    padding: 0 1.5rem;
    font-weight: 700;
    font-size: 0.9rem;
    cursor: pointer;
    transition: background 0.2s;
    white-space: nowrap;
    flex-shrink: 0;
    border-radius: 4px;
    min-height: 46px;
    letter-spacing: 0.01em;
}

    .search-btn:hover[b-70k1azlokn] {
        background: #bf2d38;
    }

    .search-btn:active[b-70k1azlokn] {
        background: #a8252f;
    }

.search-location-hint[b-70k1azlokn] {
    font-size: 0.8rem;
    color: #777;
    display: flex;
    align-items: center;
    gap: 0.35rem;
}

.location-link[b-70k1azlokn] {
    color: #DA3743;
    font-weight: 600;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 3px;
    transition: opacity 0.2s;
}

    .location-link:hover[b-70k1azlokn] {
        opacity: 0.75;
        color: #DA3743;
    }

    .location-link i[b-70k1azlokn] {
        font-size: 0.8rem;
    }

.btn-text-mobile[b-70k1azlokn] {
    display: none;
}

.search-row2[b-70k1azlokn] {
    display: flex;
    align-items: stretch;
    gap: 0.4rem;
    border: none;
    box-shadow: none;
    flex: 1;
}

@media (max-width: 768px) {
    .search-section[b-70k1azlokn] {
        padding: 0.7rem 1rem 1rem;
    }

    .search-bar[b-70k1azlokn] {
        flex-direction: column;
        gap: 0.4rem;
        max-width: 100%;
    }

    .search-group[b-70k1azlokn] {
        width: 100%;
        flex-direction: row;
        flex-wrap: nowrap;
        border-radius: 4px;
    }

        .search-group > .search-field[b-70k1azlokn],
        .search-group > .custom-time-dropdown[b-70k1azlokn] {
            flex: 1;
            min-width: 0;
            justify-content: center;
            padding: 0 0.4rem;
            font-size: 0.75rem;
            min-height: 42px;
        }

            .search-group > .search-field:first-child[b-70k1azlokn] {
                flex: 1.2;
            }

    .search-divider[b-70k1azlokn] {
        display: flex;
        margin: 5px 0;
    }

    .small-arrow[b-70k1azlokn] {
        display: none !important;
    }

    .search-row2[b-70k1azlokn] {
        display: flex;
        gap: 0.4rem;
        border: none;
        box-shadow: none;
        overflow: visible;
    }

    .search-field--input[b-70k1azlokn] {
        display: flex;
        flex: 1;
        min-height: 44px;
        border-radius: 4px;
        border: 1px solid #d0d0d0;
        box-shadow: 0 1px 3px rgba(0,0,0,0.06);
    }

    .search-btn[b-70k1azlokn] {
        width: auto;
        min-height: 44px;
        border-radius: 4px;
        font-size: 0.85rem;
        padding: 0 1.2rem;
        flex-shrink: 0;
    }

    .search-location-hint[b-70k1azlokn] {
        display: flex;
        flex-direction: column;
        align-items: center;
        text-align: center;
        gap: 0.25rem;
        width: 100%;
    }

    .location-link[b-70k1azlokn] {
        display: flex;
        justify-content: center;
    }

    .btn-text-desktop[b-70k1azlokn] {
        display: none;
    }

    .btn-text-mobile[b-70k1azlokn] {
        display: inline;
    }

    .search-field input[type="date"][b-70k1azlokn],
    .search-field input[type="number"][b-70k1azlokn] {
        font-size: 0.75rem;
    }

    input[type="date"][b-70k1azlokn]::-webkit-calendar-picker-indicator {
        display: none !important;
        opacity: 0;
        width: 0;
        padding: 0;
    }

    .search-field[b-70k1azlokn] {
        position: relative;
        overflow: hidden;
    }

        .search-field input[type="date"][b-70k1azlokn] {
            width: 100%;
            min-width: 0;
        }

            .search-field input[type="date"][b-70k1azlokn]::-webkit-calendar-picker-indicator {
                position: absolute;
                right: 0;
                opacity: 0;
                width: 100%;
                height: 100%;
                cursor: pointer;
            }
}

@media (max-width: 480px) {
    .search-field[b-70k1azlokn] {
        font-size: 0.72rem;
    }

    .search-location-hint[b-70k1azlokn] {
        font-size: 0.75rem;
    }
}
/* /Pages/Customer/Home.razor.rz.scp.css */
/* ================= DANH SÁCH (MÓN ĂN & BÀN) ================= */
.container[b-08v1whl7p1] {
    max-width: 1200px;
    padding: 2rem 1rem;
}

.next-menu[b-08v1whl7p1] {
    display: flex;
    justify-content: flex-end;
    margin-bottom: 0.5rem;
    margin-right: 0.5rem;
}

    .next-menu a[b-08v1whl7p1] {
        font-size: 0.9rem;
        font-weight: 600;
        color: #DA3743;
        text-decoration: none;
        display: flex;
        align-items: center;
        gap: 4px;
        transition: opacity 0.2s;
    }

        .next-menu a:hover[b-08v1whl7p1] {
            opacity: 0.75;
        }

.menu-card[b-08v1whl7p1] {
    border: 1px solid #f0f0f0;
    border-radius: 8px;
    overflow: hidden;
    transition: 0.25s ease;
    background: #fff;
    box-shadow: 0 4px 14px rgba(0,0,0,0.03);
    cursor: pointer;
}

.menu-img[b-08v1whl7p1] {
    height: 130px;
    object-fit: cover;
    width: 100%;
}

.menu-img-placeholder[b-08v1whl7p1] {
    height: 150px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #f8f9fa;
    font-size: 2rem;
    color: #ccc;
}

.badge-featured[b-08v1whl7p1] {
    position: absolute;
    top: 12px;
    right: 12px;
    background: #DA3743;
    color: white;
    padding: 6px 10px;
    border-radius: 4px;
    font-size: 0.5rem;
    font-weight: 600;
}

.menu-title[b-08v1whl7p1] {
    font-weight: 600;
    font-size: 1rem;
    margin-bottom: 0.5rem;
    color: #222;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.badge-tag[b-08v1whl7p1] {
    font-size: 0.7rem;
    padding: 3px 6px;
    border-radius: 6px;
    margin-bottom: 0.5rem;
}

    .badge-tag.veg[b-08v1whl7p1] {
        background: #e8f7ee;
        color: #28a745;
    }

    .badge-tag.spicy[b-08v1whl7p1] {
        background: #fdecea;
        color: #dc3545;
    }

    .badge-tag.kcal[b-08v1whl7p1] {
        background: #f1f3f5;
        color: #555;
    }

.menu-desc[b-08v1whl7p1] {
    font-size: 0.7rem;
    color: #777;
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.menu-time[b-08v1whl7p1] {
    font-size: 0.75rem;
    color: #999;
    margin-bottom: 0;
}

.menu-price[b-08v1whl7p1] {
    font-size: 1rem;
    font-weight: 800;
    color: #DA3743;
    margin-top: 0.3rem;
}

.btn-add[b-08v1whl7p1] {
    width: 26px;
    height: 26px;
    border-radius: 50%;
    border: none;
    background: #DA3743;
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
    padding: 0;
}

    .btn-add i[b-08v1whl7p1] {
        font-size: 0.9rem;
    }

    .btn-add:hover[b-08v1whl7p1] {
        background: #bf2d38;
        transform: scale(1.05);
    }

/* ================= FAQ SECTION ================= */
.faq-title[b-08v1whl7p1] {
    color: #2d333f;
    font-size: 1.5rem;
    letter-spacing: -0.5px;
    line-height: 1.3;
    margin-bottom: 3rem;
}

.faq-description[b-08v1whl7p1] {
    line-height: 1.7;
    font-size: 0.85rem;
    color: #4a4a4a !important;
}

@media (max-width: 768px) {
    .faq-title[b-08v1whl7p1] {
        font-size: 1.4rem;
        letter-spacing: -0.2px;
    }

    .faq-description[b-08v1whl7p1] {
        font-size: 0.75rem;
        line-height: 1.5;
    }
}

/* ================= HOW IT WORKS SECTION ================= */
.hiw-section[b-08v1whl7p1] {
    margin-bottom: 3rem;
    margin-top: 3rem !important;
    padding-top: 3rem !important;
}

.hiw-item[b-08v1whl7p1] {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 1.25rem;
    padding-right: 1rem;
}

.hiw-icon[b-08v1whl7p1] {
    font-size: 2.5rem;
    color: #2d333f;
    line-height: 1;
    opacity: 0.9;
}

.hiw-text[b-08v1whl7p1] {
    font-size: 0.95rem;
    font-weight: 600;
    color: #2d333f;
    line-height: 1.5;
    margin: 0;
    letter-spacing: -0.1px;
}

@media (max-width: 768px) {
    .hiw-item[b-08v1whl7p1] {
        align-items: center;
        text-align: center;
        padding-right: 0;
        gap: 1rem;
    }
}

/* ================= TẠI SAO CHỌN HUETAYY ================= */
.features-section[b-08v1whl7p1] {
    margin-top: 5rem;
    margin-bottom: 3rem;
}

.feature-card[b-08v1whl7p1] {
    background: #fff;
    border: 1px solid transparent;
}

.feature-icon-wrapper[b-08v1whl7p1] {
    width: 80px;
    height: 80px;
    background-color: #fdecea;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
}

.hiw-textt[b-08v1whl7p1] {
    line-height: 1.7;
    font-size: 0.75rem !important;
    color: #4a4a4a !important;
}

.transition-hover[b-08v1whl7p1] {
    transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
}

    .transition-hover:hover[b-08v1whl7p1] {
        transform: translateY(-8px);
        box-shadow: 0 15px 30px rgba(0,0,0,0.08) !important;
        border-color: #f0f0f0;
    }

        .transition-hover:hover .feature-icon-wrapper[b-08v1whl7p1] {
            transform: scale(1.1);
            background-color: #DA3743;
        }

            .transition-hover:hover .feature-icon-wrapper i[b-08v1whl7p1] {
                color: #fff !important;
            }

/* ================= NÚT TẢI APP (APP STORE & GOOGLE PLAY) ================= */
.store-btn[b-08v1whl7p1] {
    background-color: #fff;
    border-color: #e0e0e0 !important;
    transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
    min-width: 170px;
    box-shadow: 0 2px 4px rgba(0,0,0,0.02);
}

    .store-btn:hover[b-08v1whl7p1] {
        box-shadow: 0 8px 15px rgba(0,0,0,0.08) !important;
        border-color: #ccc !important;
    }

.play-icon-colorful[b-08v1whl7p1] {
    background: -webkit-linear-gradient(45deg, #4285F4 15%, #34A853 45%, #FBBC05 75%, #EA4335 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    display: inline-block;
}

/* ================= ĐĂNG KÝ ĐỐI TÁC (PARTNER) ================= */
.partner-card[b-08v1whl7p1] {
    background: #fdfdfd;
    border: 1px solid #eaeaea !important;
    transition: box-shadow 0.3s ease;
}

    .partner-card:hover[b-08v1whl7p1] {
        box-shadow: 0 10px 30px rgba(0,0,0,0.08) !important;
    }

.partner-icon-wrapper[b-08v1whl7p1] {
    width: 70px;
    height: 70px;
    background-color: #2d333f;
}

/* ================= REFERRAL SECTION ================= */
.referral-section[b-08v1whl7p1] {
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

    .referral-section:hover[b-08v1whl7p1] {
        box-shadow: 0 10px 30px rgba(0,0,0,0.06) !important;
    }

.gift-icon-wrapper[b-08v1whl7p1] {
    width: 60px;
    height: 60px;
}

.copy-btn[b-08v1whl7p1] {
    background-color: #DA3743;
    transition: background-color 0.2s, transform 0.1s;
}

    .copy-btn:hover[b-08v1whl7p1] {
        background-color: #bf2d38;
    }

    .copy-btn:active[b-08v1whl7p1] {
        transform: scale(0.95);
    }

.referral-bg-pattern[b-08v1whl7p1] {
    position: absolute;
    top: -50px;
    right: -50px;
    width: 300px;
    height: 300px;
    background: radial-gradient(circle, rgba(218,55,67,0.05) 0%, rgba(218,55,67,0) 70%);
    border-radius: 50%;
    z-index: 0;
    pointer-events: none;
}

/* ================= REVIEWS SECTION ================= */
.reviews-section[b-08v1whl7p1] {
    background: #fff !important;
    border: none;
    margin-top: 5rem !important;
}

.review-summary[b-08v1whl7p1] {
    background: #fff;
    padding: 0.4rem 1.2rem 0.4rem 0.4rem;
    border-radius: 50px;
    box-shadow: 0 4px 15px rgba(0,0,0,0.04);
    border: 1px solid #eaeaea;
}

.review-card[b-08v1whl7p1] {
    background: #fff;
    border: 1px solid #eaeaea;
    transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
    box-shadow: 0 4px 14px rgba(0,0,0,0.02);
    position: relative;
    overflow: hidden;
}

    .review-card:hover[b-08v1whl7p1] {
        transform: translateY(-2px);
        box-shadow: 0 12px 24px rgba(0,0,0,0.08);
        border-color: #DA3743;
    }

.review-avatar[b-08v1whl7p1] {
    width: 45px;
    height: 45px;
    background: linear-gradient(135deg, #DA3743, #ff6b76);
    color: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    font-weight: 700;
    flex-shrink: 0;
}

.review-text[b-08v1whl7p1] {
    font-size: 0.8rem;
    color: #555;
    line-height: 1.6;
    font-style: italic;
    display: -webkit-box;
    -webkit-line-clamp: 4;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.review-quote-icon[b-08v1whl7p1] {
    position: absolute;
    bottom: -10px;
    right: 15px;
    font-size: 6rem;
    color: #DA3743;
    opacity: 0.05;
    line-height: 1;
    z-index: 0;
    transform: rotate(10deg);
}

@media (max-width: 768px) {
    .hiw-section[b-08v1whl7p1] {
        margin-top: 1rem !important;
        padding-top: 1rem !important;
        margin-bottom: 1rem;
    }

    .features-section[b-08v1whl7p1] {
        margin-top: 1.5rem;
        margin-bottom: 1rem;
    }

    .reviews-section[b-08v1whl7p1] {
        margin-top: 1.5rem !important;
    }

    .faq-section[b-08v1whl7p1] {
        padding-top: 1rem !important;
        padding-bottom: 1rem !important;
    }

    .app-promo-section[b-08v1whl7p1] {
        padding-top: 1rem !important;
        padding-bottom: 1rem !important;
        margin-top: 1rem !important;
    }

    .partner-section[b-08v1whl7p1] {
        padding-top: 1rem !important;
        padding-bottom: 1rem !important;
        margin-bottom: 1rem !important;
    }

    .store-btn[b-08v1whl7p1] {
        min-width: 0;
        flex: 1;
        padding: 0.4rem 0.75rem !important;
    }

        .store-btn .bi[b-08v1whl7p1] {
            font-size: 1.5rem !important;
        }

        .store-btn span[style][b-08v1whl7p1] {
            font-size: 0.85rem !important;
        }
}
/* /Pages/Customer/Menu-item.razor.rz.scp.css */
.food-container[b-qmz68zy41p] {
    max-width: 1000px;
    margin: 2rem auto;
    padding: 0 1.5rem;
    font-family: system-ui, -apple-system, sans-serif;
    color: #333;
}

.btn-outline-secondary[b-qmz68zy41p] {
    background-color: #ffffff;
    color: #4a4a4a;
    border: 1px solid #dcdfe4;
    font-weight: 600;
    /* Giảm padding và font-size */
    padding: 0.35rem 0.8rem;
    font-size: 0.8rem;
    border-radius: 5px; /* Bo góc nhỏ lại cho cân đối */
    transition: all 0.2s ease;
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
}

/* Layout chính */
.food-grid[b-qmz68zy41p] {
    display: grid;
    grid-template-columns: 1fr 1.2fr;
    gap: 4rem;
    align-items: flex-start;
}

/* Cột Trái - Hình ảnh & Tags */
.image-wrapper[b-qmz68zy41p] {
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.08); /* Đổ bóng tạo chiều sâu */
    background: #f8f9fa;
}

.food-visual img[b-qmz68zy41p] {
    width: 100%;
    aspect-ratio: 1;
    object-fit: cover;
    display: block;
    transition: transform 0.3s ease;
}

.tags-list[b-qmz68zy41p] {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 1.5rem;
}

.tag-badge[b-qmz68zy41p] {
    font-size: 0.8rem;
    color: #495057;
    background-color: #f1f3f5;
    padding: 6px 14px;
    border-radius: 100px;
    font-weight: 500;
}

/* Cột Phải - Nội dung */
.cat-name[b-qmz68zy41p] {
    color: #DA3743; /* Màu thương hiệu */
    font-weight: 700;
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    margin-bottom: 0.5rem;
}

.header-row[b-qmz68zy41p] {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
}

.name-block h1[b-qmz68zy41p] {
    font-size: 2.25rem;
    margin: 0;
    color: #1a1a1a;
    font-weight: 800;
    letter-spacing: -0.5px;
    line-height: 1.2;
}

.status-label[b-qmz68zy41p] {
    font-size: 0.85rem;
    font-weight: 500;
    margin-top: 8px;
    display: flex;
    align-items: center;
    gap: 6px;
}

    .status-label.is-on[b-qmz68zy41p] {
        color: #2ecc71;
    }

    .status-label.is-off[b-qmz68zy41p] {
        color: #95a5a6;
    }

    .status-label i[b-qmz68zy41p] {
        font-size: 0.6rem;
    }

.price-block[b-qmz68zy41p] {
    font-size: 2rem;
    font-weight: 800;
    color: #DA3743; /* Đổi sang đỏ để thu hút */
    white-space: nowrap;
}

    .price-block small[b-qmz68zy41p] {
        font-size: 1.2rem;
        margin-left: 2px;
        vertical-align: top;
        line-height: 2;
    }

.divider[b-qmz68zy41p] {
    height: 1px;
    background: #eaeaea;
    margin: 2rem 0;
}

.section label[b-qmz68zy41p] {
    display: block;
    font-size: 0.8rem;
    text-transform: uppercase;
    color: #adb5bd;
    margin-bottom: 0.75rem;
    font-weight: 700;
    letter-spacing: 1px;
}

.section p[b-qmz68zy41p] {
    color: #495057;
    line-height: 1.7;
    margin: 0;
    font-size: 1rem;
}

/* Thông số (Specs) */
.specs-grid[b-qmz68zy41p] {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 1.5rem;
    margin: 2.5rem 0;
}

.spec-item[b-qmz68zy41p] {
    display: flex;
    align-items: center;
    gap: 12px;
}

.icon-box[b-qmz68zy41p] {
    width: 40px;
    height: 40px;
    background: #f8f9fa;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
}

    .icon-box i[b-qmz68zy41p] {
        font-size: 1.2rem;
        color: #6c757d;
    }

.spec-item small[b-qmz68zy41p] {
    display: block;
    color: #868e96;
    font-size: 0.75rem;
    text-transform: uppercase;
    font-weight: 600;
    margin-bottom: 2px;
}

.spec-item strong[b-qmz68zy41p] {
    font-size: 0.95rem;
    color: #212529;
}

.pills[b-qmz68zy41p] {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}

    .pills span[b-qmz68zy41p] {
        font-size: 0.7rem;
        padding: 3px 8px;
        border-radius: 6px;
        font-weight: 600;
        text-transform: uppercase;
    }

    .pills .v[b-qmz68zy41p] {
        background: #eafaf1;
        color: #27ae60;
    }

    .pills .s[b-qmz68zy41p] {
        background: #fdedec;
        color: #c0392b;
    }

    .pills .f[b-qmz68zy41p] {
        background: #fef9e7;
        color: #f39c12;
    }

    .pills .n[b-qmz68zy41p] {
        background: #f1f3f5;
        color: #6c757d;
    }
/* Nền cho "Không cay" */

/* Responsive Mobile */
@media (max-width: 850px) {
    .food-grid[b-qmz68zy41p] {
        grid-template-columns: 1fr;
        gap: 2rem;
    }

    .header-row[b-qmz68zy41p] {
        flex-direction: column;
    }

    .name-block h1[b-qmz68zy41p] {
        font-size: 1.8rem;
    }

    .price-block[b-qmz68zy41p] {
        font-size: 1.75rem;
    }

    .specs-grid[b-qmz68zy41p] {
        grid-template-columns: 1fr 1fr;
    }
}
/* /Pages/Customer/Menu.razor.rz.scp.css */
/* ================= TỔNG QUAN & BỐ CỤC ================= */
.container-menuitem[b-eje4w0ddq8] {
    max-width: 1200px;
    margin: 0 auto;
    padding: 2rem 1rem;
}

.menu-header[b-eje4w0ddq8] {
    padding-bottom: 0.75rem;
    border-bottom: 1px solid #f0f0f0;
    margin-bottom: 2rem;
    margin-top: 2rem;
}

    .menu-header .d-flex > div:first-child[b-eje4w0ddq8] {
        flex-shrink: 0;
    }

.card[b-eje4w0ddq8] {
    cursor: pointer;
}

.titles[b-eje4w0ddq8] {
    font-family: 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
    font-size: 1.5rem;
    font-weight: 700;
    color: #1a1a1a;
    letter-spacing: -0.5px; /* Ép chữ sát lại một chút cho hiện đại */
}

.menu-count[b-eje4w0ddq8] {
    font-size: 0.8rem;
    font-weight: 600;
    color: #DA3743;
    background-color: #fdecea; /* Nền đỏ nhạt */
    padding: 4px 10px;
    border-radius: 20px; /* Bo tròn hoàn toàn */
}

/* ================= THANH TÌM KIẾM & BỘ LỌC ================= */
.menu-filter-bar[b-eje4w0ddq8] {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: nowrap;
    justify-content: flex-end;
    flex-shrink: 0;
}

.search-input[b-eje4w0ddq8] {
    width: 200px;
    border-radius: 5px;
    border: 1px solid #dcdfe4;
    font-size: 0.8rem;
    color: #4a4a4a;
    transition: all 0.2s ease-in-out;
    background-color: #fff;
}

    .search-input:focus[b-eje4w0ddq8] {
        border-color: #DA3743;
        box-shadow: 0 0 0 1px rgba(218, 55, 67, 0.5); /* Sáng viền đỏ nhẹ */
        outline: none;
    }

    .search-input[b-eje4w0ddq8]::placeholder {
        color: #9ca3af;
        font-size: 0.8rem;
    }

.btn-search[b-eje4w0ddq8] {
    background-color: #DA3743;
    color: #ffffff;
    font-weight: 600;
    font-size: 0.8rem;
    border: none;
    border-radius: 5px;
    padding: 0.35rem 0.8rem;
    transition: all 0.2s ease;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    white-space: nowrap;
}

    .btn-search:hover[b-eje4w0ddq8] {
        background-color: #bf2d38;
        color: #ffffff;
        box-shadow: 0 2px 6px rgba(218, 55, 67, 0.25);
    }

    .btn-search:active[b-eje4w0ddq8] {
        transform: translateY(1px);
        box-shadow: none;
    }

.custom-filter-select[b-eje4w0ddq8] {
    width: auto;
    min-width: 140px;
    border-radius: 3px;
    border-color: #dcdfe4;
    color: #4a4a4a;
    font-weight: 500;
    cursor: pointer;
    padding: 0.4rem 2rem 0.4rem 1rem;
    font-size: 0.7rem;
}

/* Nút chuyển đổi View (Grid/List) - Trong HTML bạn đang mượn class cart-btn */
.cart-btn[b-eje4w0ddq8] {
    position: relative;
    width: 32px;
    height: 32px;
    border-radius: 8px;
    border: 1px solid #e2e2e2;
    background: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: 1.1rem;
    color: #4a4a4a;
    transition: all 0.2s ease;
}

    .cart-btn:hover[b-eje4w0ddq8] {
        background: #f8f9fa;
        border-color: #dcdfe4;
    }

    .cart-btn.active[b-eje4w0ddq8] {
        background: #2d333f;
        color: #fff;
        border-color: #2d333f;
    }

/* ================= DANH SÁCH MÓN ĂN (CARD & ITEM) ================= */
.menu-card[b-eje4w0ddq8] {
    border: 1px solid #f0f0f0;
    border-radius: 8px;
    overflow: hidden;
    transition: 0.25s ease;
    background: #fff;
    box-shadow: 0 4px 14px rgba(0,0,0,0.03);
}

.menu-img[b-eje4w0ddq8] {
    height: 130px;
    object-fit: cover;
    width: 100%;
}

.menu-img-placeholder[b-eje4w0ddq8] {
    height: 150px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #f8f9fa;
    font-size: 2rem;
    color: #ccc;
}

.menu-title[b-eje4w0ddq8] {
    font-weight: 600;
    font-size: 1rem;
    margin-bottom: 0.5rem;
    color: #222;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.menu-desc[b-eje4w0ddq8] {
    font-size: 0.75rem;
    color: #888;
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    margin-bottom: 0.5rem;
}

.menu-time[b-eje4w0ddq8] {
    font-size: 0.75rem;
    color: #999;
}

.menu-price[b-eje4w0ddq8] {
    font-size: 1rem;
    font-weight: 800;
    color: #DA3743;
    margin-top: 0.3rem;
}

/* ================= BADGE & TAGS ================= */
.badge-featured[b-eje4w0ddq8] {
    position: absolute;
    top: 12px;
    right: 12px;
    background: #DA3743;
    color: white;
    padding: 6px 10px;
    border-radius: 4px;
    font-size: 0.5rem;
    font-weight: 600;
}

.badge-tag[b-eje4w0ddq8] {
    font-size: 0.7rem;
    padding: 3px 6px;
    border-radius: 6px;
    margin-bottom: 0.5rem;
}

    .badge-tag.veg[b-eje4w0ddq8] {
        background: #e8f7ee;
        color: #28a745;
    }

    .badge-tag.spicy[b-eje4w0ddq8] {
        background: #fdecea;
        color: #dc3545;
    }

    .badge-tag.kcal[b-eje4w0ddq8] {
        background: #f1f3f5;
        color: #555;
    }

/* ================= CHẾ ĐỘ HIỂN THỊ DẠNG DANH SÁCH (LIST VIEW) ================= */

/* Style tổng thể cho khung thẻ danh sách */
.list-card[b-eje4w0ddq8] {
    border: 1px solid #f0f0f0;
    border-radius: 8px;
    background: #fff;
    transition: all 0.25s ease;
    box-shadow: 0 2px 8px rgba(0,0,0,0.02);
}

    .list-card:hover[b-eje4w0ddq8] {
        box-shadow: 0 4px 14px rgba(0,0,0,0.06);
        border-color: #e8e8e8;
    }

.min-width-0[b-eje4w0ddq8] {
    min-width: 0;
}

/* ================= RESPONSIVE CHO LIST VIEW TRÊN ĐIỆN THOẠI ================= */
@media (max-width: 576px) {
    /* Chuyển layout từ ngang sang dọc trên màn hình nhỏ */
    .list-card .card-body > .d-flex[b-eje4w0ddq8] {
        flex-direction: column;
        align-items: stretch !important;
    }

    /* Mở rộng ảnh full chiều ngang */
    .list-card img[b-eje4w0ddq8],
    .list-card .bg-light.rounded-3[b-eje4w0ddq8] {
        width: 100% !important;
        height: 180px !important;
        margin-bottom: 0.5rem;
    }

    /* Căn chỉnh lại phần giá tiền và nút Đặt bàn */
    .list-card .text-end[b-eje4w0ddq8] {
        text-align: left !important;
        margin-top: 0.5rem;
        display: flex;
        justify-content: space-between;
        align-items: center;
        width: 100%;
    }

    .list-card .menu-price[b-eje4w0ddq8] {
        margin-bottom: 0 !important;
    }
}

/* ================= RESPONSIVE TRÊN ĐIỆN THOẠI ================= */
@media (max-width: 768px) {
    .menu-header .d-flex.justify-content-between[b-eje4w0ddq8] {
        flex-direction: column;
        gap: 12px;
    }

    .menu-filter-bar[b-eje4w0ddq8] {
        flex-direction: column;
        align-items: stretch;
        width: 100%;
    }

    .search-input[b-eje4w0ddq8],
    .custom-filter-select[b-eje4w0ddq8] {
        width: 100%;
    }

    .menu-filter-bar .ms-auto[b-eje4w0ddq8] {
        margin-left: 0 !important;
    }
}
/* /Pages/Customer/MyBookings.razor.rz.scp.css */
/* =========================================
   1. LAYOUT CHUNG & CONTAINER
   ========================================= */
.booking-page-container[b-ud687sz0fr] {
    max-width: 900px;
    margin: 0 auto;
}

.page-title[b-ud687sz0fr] {
    color: #2d333f;
    letter-spacing: -0.5px;
}

.btn-xoaloc[b-ud687sz0fr] {
    padding: 0.25rem 0.5rem !important;
    font-size: 0.875rem !important;
    line-height: 1.5 !important;
}

/* =========================================
   2. DANH SÁCH & THẺ ĐẶT BÀN (CARDS)
   ========================================= */
.booking-list[b-ud687sz0fr] {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.booking-card[b-ud687sz0fr] {
    background: #ffffff;
    border: 1px solid #eef0f2;
    border-radius: 12px;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.03);
    overflow: hidden;
}

.booking-card-header[b-ud687sz0fr] {
    background: #fafbfc;
    padding: 1rem 1.5rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid #eef0f2;
}

.booking-code[b-ud687sz0fr] {
    font-weight: 700;
    color: #1a1a1a;
    font-size: 0.75rem;
}

.booking-price[b-ud687sz0fr] {
    font-weight: 800;
    color: #DA3743;
    font-size: 1rem;
}

.booking-card-body[b-ud687sz0fr] {
    padding: 1.5rem;
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
}

/* Grid Thông tin */
.booking-info-grid[b-ud687sz0fr] {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.85rem 2rem;
}

.info-item[b-ud687sz0fr] {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    font-size: 0.75rem;
    color: #4a4a4a;
}

    .info-item i[b-ud687sz0fr] {
        color: #8c92a0;
        font-size: 1.1rem;
    }

    .info-item strong[b-ud687sz0fr] {
        color: #2d333f;
        font-weight: 600;
    }

/* =========================================
   3. TRẠNG THÁI (STATUS BADGES)
   ========================================= */
.status-badge[b-ud687sz0fr] {
    padding: 4px 10px;
    border-radius: 20px;
    font-size: 0.6rem;
    font-weight: 700;
    letter-spacing: 0.3px;
    text-transform: uppercase;
}

.status-pending[b-ud687sz0fr] {
    background: #fff3cd;
    color: #856404;
}

.status-confirmed[b-ud687sz0fr] {
    background: #cce5ff;
    color: #004085;
}

.status-completed[b-ud687sz0fr] {
    background: #d4edda;
    color: #155724;
}

.status-cancelled[b-ud687sz0fr] {
    background: #f8d7da;
    color: #721c24;
}

.status-default[b-ud687sz0fr] {
    background: #e2e3e5;
    color: #383d41;
}

/* =========================================
   4. NÚT BẤM (BUTTONS) & HÀNH ĐỘNG
   ========================================= */
.btn[b-ud687sz0fr] {
    border-radius: 7px;
    font-weight: 600;
    padding: 0.35rem 0.7rem;
}

.btn-white[b-ud687sz0fr],
.btn-primary-custom[b-ud687sz0fr] {
    font-size: 0.75rem;
    padding: 0.35rem 0.9rem;
}

.btn-primary-custom[b-ud687sz0fr] {
    background-color: #DA3743;
    color: #ffffff;
    border: none;
}

.btn-reviewed[b-ud687sz0fr] {
    border: 1px solid #28a745;
    color: #28a745;
    background: #eafaf1;
}

    .btn-reviewed:disabled[b-ud687sz0fr] {
        opacity: 1;
    }

.booking-actions[b-ud687sz0fr] {
    display: flex;
    gap: 0.75rem;
}

    .booking-actions .btn[b-ud687sz0fr] {
        font-size: 0.75rem;
        padding: 0.25rem 0.75rem;
    }

    /* --- GIỮ NGUYÊN MÀU KHI HOVER CÁC NÚT TRONG DANH SÁCH --- */
    .booking-actions .btn-primary-custom:hover[b-ud687sz0fr] {
        background-color: #DA3743 !important;
        color: #ffffff !important;
    }

    .booking-actions .btn-outline-primary:hover[b-ud687sz0fr] {
        background-color: transparent !important;
        color: #0d6efd !important;
    }

    .booking-actions .btn-outline-dark:hover[b-ud687sz0fr] {
        background-color: transparent !important;
        color: #212529 !important;
    }

    .booking-actions .btn-warning:hover[b-ud687sz0fr] {
        background-color: #ffc107 !important;
        color: #212529 !important;
        border-color: #ffc107 !important;
    }

    .booking-actions .btn-outline-warning:hover[b-ud687sz0fr] {
        background-color: transparent !important;
        color: #ffc107 !important;
    }

    .booking-actions .btn-outline-danger:hover[b-ud687sz0fr] {
        background-color: transparent !important;
        color: #dc3545 !important;
    }

/* Phân trang */
.pagination-sm .page-link[b-ud687sz0fr] {
    font-size: 0.75rem;
    padding: 0.25rem 0.5rem;
}

/* =========================================
   5. MODAL CHUNG (HỦY BÀN & ĐÁNH GIÁ)
   ========================================= */
.custom-modal[b-ud687sz0fr] {
    background: rgba(15, 23, 42, 0.6) !important;
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    animation: fadeInBg-b-ud687sz0fr 0.2s ease-out;
}

    .custom-modal .modal-content[b-ud687sz0fr] {
        border-radius: 8px;
        overflow: hidden;
        border: none;
        animation: slideUpModal-b-ud687sz0fr 0.3s cubic-bezier(0.16, 1, 0.3, 1);
    }

    .custom-modal .modal-header[b-ud687sz0fr] {
        background-color: #ffffff;
        padding: 1.2rem 1.5rem;
        border-bottom: 1px solid #f1f5f9;
    }

    .custom-modal .modal-body[b-ud687sz0fr] {
        background-color: #ffffff;
        padding: 1.5rem;
    }

    .custom-modal .modal-footer[b-ud687sz0fr] {
        border-top: 1px solid #f1f5f9;
        padding: 0.75rem 1.5rem;
        background: #ffffff;
        margin-bottom: 0.5rem;
    }

        .custom-modal .modal-footer .btn[b-ud687sz0fr] {
            font-size: 0.75rem;
            padding: 0.35rem 0.7rem;
        }

.rating-stars-modal i:hover[b-ud687sz0fr] {
    transform: scale(1.15);
}

/* =========================================
   6. FORM & INPUTS (TRONG MODAL)
   ========================================= */
.custom-textarea[b-ud687sz0fr] {
    border-radius: 8px;
    border: 1px solid #e2e8f0;
    padding: 0.8rem 1rem;
    font-size: 0.75rem;
    background-color: #f8fafc;
    transition: all 0.2s ease;
    resize: none;
}

.review-quick-tag[b-ud687sz0fr] {
    padding: 5px 12px;
    border-radius: 8px;
    border: 1px solid #e2e8f0;
    font-size: 0.7rem;
    font-weight: 500;
    cursor: pointer;
    background: #ffffff;
    color: #64748b;
    transition: all 0.2s ease;
    user-select: none;
}

    .review-quick-tag:hover[b-ud687sz0fr] {
        border-color: #DA3743;
        color: #DA3743;
        background-color: rgba(218, 55, 67, 0.04);
    }

    .review-quick-tag.active[b-ud687sz0fr] {
        background: #DA3743;
        border-color: #DA3743;
        color: #ffffff;
        box-shadow: 0 4px 10px rgba(218, 55, 67, 0.2);
    }

/* Animations Modal */
@keyframes fadeInBg-b-ud687sz0fr {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

@keyframes slideUpModal-b-ud687sz0fr {
    from {
        opacity: 0;
        transform: translateY(20px) scale(0.98);
    }

    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}
/* /Pages/Customer/MyReviews.razor.rz.scp.css */
/* =========================================
   1. LAYOUT CHUNG & CONTAINER
   ========================================= */
.review-page-container[b-x2a2k7749t] {
    max-width: 900px;
    margin: 0 auto;
}

.page-title[b-x2a2k7749t] {
    color: #2d333f;
    letter-spacing: -0.5px;
}

/* =========================================
   2. DANH SÁCH & THẺ ĐÁNH GIÁ (REVIEW CARDS)
   ========================================= */
.review-list[b-x2a2k7749t] {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.review-card[b-x2a2k7749t] {
    background: #ffffff;
    border: 1px solid #eef0f2;
    border-radius: 12px;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.03);
    overflow: hidden;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

    .review-card:hover[b-x2a2k7749t] {
        border-color: #e2e5e9;
    }

.review-card-header[b-x2a2k7749t] {
    background: #fafbfc;
    padding: 1rem 1.5rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid #eef0f2;
}

.review-card-body[b-x2a2k7749t] {
    padding: 1.5rem;
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
}

/* 2.1 Thành phần trong thẻ đánh giá */
.review-table[b-x2a2k7749t],
.review-date[b-x2a2k7749t] {
    font-weight: 700;
    font-size: 0.75rem;
}

.review-table[b-x2a2k7749t] {
    color: #1a1a1a;
}

.review-date[b-x2a2k7749t] {
    color: #8c92a0;
    font-weight: 600;
}

.review-info[b-x2a2k7749t] {
    flex: 1;
}

.review-comment[b-x2a2k7749t] {
    display: flex;
    align-items: flex-start;
    gap: 0.6rem;
    font-size: 0.75rem;
    color: #4a4a4a;
    line-height: 1.6;
}

    .review-comment i[b-x2a2k7749t] {
        color: #8c92a0;
        font-size: 1.1rem;
        margin-top: 2px;
    }

.review-actions[b-x2a2k7749t] {
    display: flex;
    gap: 0.75rem;
    color: #DA3743 !important;
}

/* 2.2 Đánh giá sao (Stars) */
.rating-stars i[b-x2a2k7749t] {
    color: #ffc107;
    font-size: 0.9rem;
    margin-left: 2px;
}

    .rating-stars i.bi-star[b-x2a2k7749t] {
        color: #dee2e6;
    }

/* =========================================
   3. NÚT BẤM (BUTTONS)
   ========================================= */
.btn[b-x2a2k7749t] {
    border-radius: 8px;
    font-weight: 600;
    padding: 0.35rem 0.7rem;
}

.btn-white[b-x2a2k7749t],
.btn-primary-custom[b-x2a2k7749t] {
    font-size: 0.75rem;
    padding: 0.35rem 0.9rem;
}

.btn-primary-custom[b-x2a2k7749t] {
    background-color: #DA3743;
    color: #ffffff;
    border: none;
    transition: 0.2s;
}

    .btn-primary-custom:hover[b-x2a2k7749t] {
        background-color: #bf2d38;
        color: #ffffff;
    }

.btn-edit[b-x2a2k7749t] {
    color: #DA3743 !important;
    border: 1px solid #DA3743 !important;
    font-size: 0.75rem;
    padding: 0.25rem 0.5rem;
    margin-top: 0.7rem;
    border-radius: 6px;
    background-color: transparent;
    transition: all 0.2s;
}

    .btn-edit:hover[b-x2a2k7749t] {
        color: #ffffff !important;
        background-color: #DA3743 !important;
        border-color: #DA3743 !important;
    }

/* =========================================
   4. MODAL CHỈNH SỬA ĐÁNH GIÁ
   ========================================= */
.custom-modal[b-x2a2k7749t] {
    background: rgba(15, 23, 42, 0.4) !important;
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}

    .custom-modal .modal-content[b-x2a2k7749t] {
        border-radius: 8px;
        overflow: hidden;
        transform: translateY(0);
        transition: all 0.3s ease-in-out;
    }

    .custom-modal .modal-header[b-x2a2k7749t] {
        background-color: #ffffff;
        padding: 1.2rem 1.5rem;
        border-bottom: 1px solid #f1f5f9;
    }

    .custom-modal .modal-body[b-x2a2k7749t] {
        background-color: #ffffff;
        padding: 1.5rem;
    }

    .custom-modal .modal-footer[b-x2a2k7749t] {
        border-top: 1px solid #f1f5f9;
        padding: 0.75rem 1.5rem;
        margin-bottom: 0.5rem;
        background: #fff;
    }

.rating-stars-modal i:hover[b-x2a2k7749t] {
    transform: scale(1.15);
}

/* =========================================
   5. FORM & INPUTS (TRONG MODAL)
   ========================================= */
/* 5.1 Khung nhập text */
.custom-textarea[b-x2a2k7749t] {
    border-radius: 8px;
    border: 1px solid #e2e8f0;
    padding: 0.8rem 1rem;
    font-size: 0.75rem;
    background-color: #f8fafc;
    transition: all 0.2s ease;
    resize: none;
}

/* 5.2 Các thẻ đánh giá nhanh (Tags) */
.review-quick-tag[b-x2a2k7749t] {
    padding: 5px 12px;
    border-radius: 8px;
    border: 1px solid #e2e8f0;
    font-size: 0.7rem;
    font-weight: 500;
    cursor: pointer;
    background: #ffffff;
    color: #64748b;
    transition: all 0.2s ease;
    user-select: none;
}

    .review-quick-tag:hover[b-x2a2k7749t] {
        border-color: #DA3743;
        color: #DA3743;
        background-color: rgba(218, 55, 67, 0.04);
    }

    .review-quick-tag.active[b-x2a2k7749t] {
        background: #DA3743;
        border-color: #DA3743;
        color: #ffffff;
        box-shadow: 0 4px 10px rgba(218, 55, 67, 0.2);
    }
/* /Pages/Customer/Profile.razor.rz.scp.css */
/* =========================================
   LAYOUT & CONTAINER (TỐI GIẢN, HIỆN ĐẠI)
   ========================================= */
.hp-page-wrapper[b-vonw5fpz1j] {
    min-height: 100vh;
    padding: 3rem 1.5rem;
    background-color: transparent; /* Sửa 'none' thành 'transparent' cho chuẩn CSS */
    display: flex;
    justify-content: center;
    align-items: flex-start;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

.hp-main-card[b-vonw5fpz1j] {
    width: 100%;
    max-width: 960px;
    background-color: #ffffff;
    border: 1px solid #e5e7eb;
    border-radius: 7px;
    display: flex;
    flex-direction: row;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05), 0 2px 4px -1px rgba(0, 0, 0, 0.03);
    overflow: hidden;
}

/* =========================================
   SIDEBAR (CỘT TRÁI)
   ========================================= */
.hp-sidebar[b-vonw5fpz1j] {
    width: 320px;
    background-color: #ffffff;
    border-right: 1px solid #e5e7eb;
    padding: 3rem 2rem;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.hp-avatar-section[b-vonw5fpz1j] {
    text-align: center;
}

.hp-avatar-container[b-vonw5fpz1j] {
    position: relative;
    margin-bottom: 1.5rem;
    display: inline-block;
}

.hp-avatar-img[b-vonw5fpz1j] {
    width: 120px;
    height: 120px;
    border-radius: 50%;
    object-fit: cover;
    background-color: #f3f4f6;
    border: 3px solid #ffffff;
    box-shadow: 0 0 0 2px #d1d5db, 0 4px 10px rgba(0,0,0,0.08);
}

.hp-btn-edit-avatar[b-vonw5fpz1j] {
    position: absolute;
    bottom: 4px;
    right: 4px;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background-color: #ffffff;
    color: #4b5563;
    border: 1px solid #d1d5db;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    box-shadow: 0 2px 4px rgba(0,0,0,0.05);
    transition: all 0.2s ease;
}

    .hp-btn-edit-avatar:hover[b-vonw5fpz1j] {
        color: #DA3743;
        border-color: #DA3743;
    }

.hp-user-name[b-vonw5fpz1j] {
    font-size: 1.25rem;
    font-weight: 600;
    color: #111827;
    margin: 0 0 0.25rem 0;
}

.hp-user-role[b-vonw5fpz1j] {
    font-size: 0.875rem;
    color: #6b7280;
}

/* =========================================
   CONTENT (CỘT PHẢI)
   ========================================= */
.hp-content[b-vonw5fpz1j] {
    flex: 1;
    padding: 3rem 4rem;
    background-color: #ffffff;
}

.hp-header[b-vonw5fpz1j] {
    margin-bottom: 2.5rem;
    border-bottom: 1px solid #f3f4f6;
    padding-bottom: 1.5rem;
}

.hp-title[b-vonw5fpz1j] {
    font-size: 1.5rem;
    font-weight: 600;
    color: #111827;
    margin: 0 0 0.5rem 0;
}

.hp-subtitle[b-vonw5fpz1j] {
    font-size: 0.9rem;
    color: #6b7280;
    margin: 0;
}

/* =========================================
   FORM & INPUTS (VIỀN ĐẬM, CÓ KHỐI)
   ========================================= */
.hp-form[b-vonw5fpz1j] {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.hp-form-row[b-vonw5fpz1j] {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
}

.hp-form-group[b-vonw5fpz1j] {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.hp-label[b-vonw5fpz1j] {
    font-size: 0.875rem;
    font-weight: 600;
    color: #374151;
}

.hp-input[b-vonw5fpz1j] {
    width: 100%;
    padding: 0.5rem 0.9rem;
    font-size: 0.75rem;
    color: #111827;
    background-color: #ffffff;
    border: 1px solid #9ca3af;
    border-radius: 6px;
    outline: none;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
    transition: all 0.2s ease-in-out;
}

    .hp-input[b-vonw5fpz1j]::placeholder {
        color: #9ca3af;
    }

    .hp-input:hover[b-vonw5fpz1j] {
        border-color: #6b7280;
    }

/* =========================================
   BUTTONS
   ========================================= */
.hp-form-actions[b-vonw5fpz1j] {
    display: flex;
    justify-content: flex-end;
    gap: 1rem;
    padding-top: 2rem;
    border-top: 1px solid #f3f4f6;
}

.hp-btn[b-vonw5fpz1j] {
    padding: 0.625rem 1.25rem;
    font-size: 0.75rem;
    font-weight: 500;
    border-radius: 5px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
    border: none;
}

.hp-btn-primary[b-vonw5fpz1j] {
    background-color: #DA3743;
    color: #ffffff;
}

    .hp-btn-primary:hover:not(:disabled)[b-vonw5fpz1j] {
        background-color: #bf2d38;
    }

    .hp-btn-primary:disabled[b-vonw5fpz1j] {
        opacity: 0.6;
        cursor: not-allowed;
    }

.hp-btn-outline[b-vonw5fpz1j] {
    background-color: #ffffff;
    color: #374151;
    border: 1px solid #d1d5db;
}

    .hp-btn-outline:hover[b-vonw5fpz1j] {
        background-color: #f9fafb;
        color: #111827;
        border-color: #9ca3af;
    }

/* =========================================
   ALERTS
   ========================================= */
.hp-alert[b-vonw5fpz1j] {
    padding: 1rem;
    border-radius: 6px;
    margin-bottom: 1.5rem;
    font-size: 0.7rem;
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    align-items: center;
}

    .hp-alert ul[b-vonw5fpz1j] {
        margin: 0;
        padding-left: 1.5rem;
    }

.hp-alert-success[b-vonw5fpz1j] {
    background-color: #f0fdf4;
    color: #166534;
    border: 1px solid #bbf7d0;
}

.hp-alert-danger[b-vonw5fpz1j] {
    background-color: #fef2f2;
    color: #991b1b;
    border: 1px solid #fecaca;
}

/* =========================================
   RESPONSIVE (MOBILE)
   ========================================= */
@media (max-width: 768px) {
    .hp-main-card[b-vonw5fpz1j] {
        flex-direction: column;
    }

    .hp-sidebar[b-vonw5fpz1j] {
        width: 100%;
        border-right: none;
        border-bottom: 1px solid #e5e7eb;
        padding: 2rem 1.5rem;
    }

    .hp-content[b-vonw5fpz1j] {
        padding: 2rem 1.5rem;
    }

    .hp-form-row[b-vonw5fpz1j] {
        grid-template-columns: 1fr;
    }

    .hp-form-actions[b-vonw5fpz1j] {
        flex-direction: column;
    }

    .hp-btn[b-vonw5fpz1j] {
        width: 100%;
    }
}
/* /Pages/NotFoundPage.razor.rz.scp.css */
/* Bao bọc toàn bộ trang lỗi để căn giữa */
.error-page-wrapper[b-mqx7896kme] {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 75vh;
    padding: 2rem 1rem;
    background-color: transparent;
}

/* Khung card hiển thị nội dung */
.error-card[b-mqx7896kme] {
    background-color: #ffffff;
    max-width: 480px;
    width: 100%;
    padding: 3rem;
    border-radius: 1rem;
    box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.1); /* Tạo bóng đổ (Shadow) mềm mại */
    text-align: center;
    transition: transform 0.3s ease;
}

/* Icon bản đồ */
.error-icon[b-mqx7896kme] {
    margin-bottom: 1.5rem;
}

    .error-icon i[b-mqx7896kme] {
        font-size: 5rem;
        color: #ffc107; /* Màu vàng cảnh báo */
        text-shadow: 0 4px 10px rgba(255, 193, 7, 0.3); /* Bóng cho icon nổi bật hơn */
    }

/* Tiêu đề lỗi */
.error-title[b-mqx7896kme] {
    font-weight: 700;
    margin-bottom: 0.5rem;
    color: #212529;
}

/* Mô tả lỗi */
.error-description[b-mqx7896kme] {
    color: #6c757d;
    margin-bottom: 2rem;
    font-size: 1.05rem;
}

/* Nút Về trang chủ */
.btn-return-home[b-mqx7896kme] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background-color: #ffc107;
    color: #000;
    text-decoration: none;
    padding: 0.75rem 2rem;
    border-radius: 50px;
    font-weight: 600;
    transition: all 0.3s ease; /* Hiệu ứng chuyển mượt */
}

    .btn-return-home i[b-mqx7896kme] {
        margin-right: 0.5rem;
    }

    /* Hiệu ứng khi di chuột vào nút */
    .btn-return-home:hover[b-mqx7896kme] {
        background-color: #ffca2c;
        color: #000;
        transform: translateY(-3px); /* Đẩy nút lên nhẹ */
        box-shadow: 0 4px 12px rgba(255, 193, 7, 0.4); /* Phát sáng nút */
    }
/* /Pages/Payment/Failed.razor.rz.scp.css */
/* Hiệu ứng mờ dần và trượt lên cho Card */
@keyframes fadeInUp-b-13ltmc4ur8 {
    0% {
        opacity: 0;
        transform: translateY(30px);
    }

    100% {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Hiệu ứng nảy (pop) sinh động cho Icon */
@keyframes popIn-b-13ltmc4ur8 {
    0% {
        opacity: 0;
        transform: scale(0.5);
    }

    50% {
        opacity: 1;
        transform: scale(1.1);
    }

    100% {
        opacity: 1;
        transform: scale(1);
    }
}

/* Class áp dụng cho khối Card */
.payment-card[b-13ltmc4ur8] {
    animation: fadeInUp-b-13ltmc4ur8 0.6s ease-out forwards;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

    /* Hiệu ứng khi di chuột vào Card */
    .payment-card:hover[b-13ltmc4ur8] {
        box-shadow: 0 15px 35px rgba(0,0,0,0.1) !important;
    }

/* Class áp dụng cho Icon */
.icon-animated[b-13ltmc4ur8] {
    animation: popIn-b-13ltmc4ur8 0.6s cubic-bezier(0.175, 0.885, 0.32, 1.275) forwards;
    display: inline-block; /* Cần thiết để transform (scale) hoạt động */
}

/* Hiệu ứng cho nút bấm */
.btn-animated[b-13ltmc4ur8] {
    transition: all 0.3s ease;
}

    .btn-animated:hover[b-13ltmc4ur8] {
        box-shadow: 0 5px 15px rgba(0,0,0,0.1);
    }
/* /Pages/Payment/Success.razor.rz.scp.css */
/* Hiệu ứng mờ dần và trượt lên cho Card */
@keyframes fadeInUp-b-y9xkq3l17x {
    0% {
        opacity: 0;
        transform: translateY(30px);
    }

    100% {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Hiệu ứng nảy (pop) sinh động cho Icon */
@keyframes popIn-b-y9xkq3l17x {
    0% {
        opacity: 0;
        transform: scale(0.5);
    }

    50% {
        opacity: 1;
        transform: scale(1.1);
    }

    100% {
        opacity: 1;
        transform: scale(1);
    }
}

/* Class áp dụng cho khối Card */
.payment-card[b-y9xkq3l17x] {
    animation: fadeInUp-b-y9xkq3l17x 0.6s ease-out forwards;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

    /* Hiệu ứng khi di chuột vào Card */
    .payment-card:hover[b-y9xkq3l17x] {
        box-shadow: 0 15px 35px rgba(0,0,0,0.1) !important;
    }

/* Class áp dụng cho Icon */
.icon-animated[b-y9xkq3l17x] {
    animation: popIn-b-y9xkq3l17x 0.6s cubic-bezier(0.175, 0.885, 0.32, 1.275) forwards;
    display: inline-block; /* Cần thiết để transform (scale) hoạt động */
}

/* Hiệu ứng cho nút bấm */
.btn-animated[b-y9xkq3l17x] {
    transition: all 0.3s ease;
}

    .btn-animated:hover[b-y9xkq3l17x] {
        box-shadow: 0 5px 15px rgba(0,0,0,0.1);
    }
/* /Pages/Staff/Booking.razor.rz.scp.css */
.table > :not(caption) > * > *[b-n0yj26ffbw] {
    padding: 0.75rem 0.75rem;
    border-right: 1px solid #e9ecef;
}

    .table > :not(caption) > * > *:last-child[b-n0yj26ffbw] {
        border-right: none;
    }

.table tbody tr[b-n0yj26ffbw] {
    border-bottom: 1px solid #e9ecef;
}

    .table tbody tr:nth-of-type(odd)[b-n0yj26ffbw] {
        background-color: #ffffff !important;
    }

    .table tbody tr:nth-of-type(even)[b-n0yj26ffbw] {
        background-color: #f8f9fa !important;
    }

.table thead tr[b-n0yj26ffbw] {
    border-bottom: 2px solid #dee2e6;
}

.td-xs[b-n0yj26ffbw] {
    font-size: 0.75rem;
    padding: 2px 6px !important;
}

.table thead tr[b-n0yj26ffbw] {
    background-color: #e9ecef;
}

.text-muted[b-n0yj26ffbw] {
    font-size: 0.75rem;
    opacity: 0.7;
}

.table-container[b-n0yj26ffbw] {
    border: 1px solid #dee2e6;
    border-radius: 0.375rem;
    overflow: hidden;
    margin: 0 12px 0;
}

.action-btn[b-n0yj26ffbw] {
    padding: 2px 6px;
}

    .action-btn i[b-n0yj26ffbw] {
        font-size: 0.85rem;
    }


    .action-btn.btn-outline-primary:hover[b-n0yj26ffbw] {
        background-color: transparent !important;
        color: #0b5ed7; /* đậm hơn primary */
    }

    .action-btn.btn-outline-danger:hover[b-n0yj26ffbw] {
        background-color: transparent !important;
        color: #b02a37; /* đậm hơn danger */
    }

.form-control[b-n0yj26ffbw],
.btn[b-n0yj26ffbw] {
    box-shadow: none !important;
}

.table-hover tbody tr:hover[b-n0yj26ffbw] {
    background-color: inherit !important;
}

.btn-primary[b-n0yj26ffbw] {
    font-size: 0.875rem;
}

.small-placeholder[b-n0yj26ffbw]::placeholder {
    font-size: 0.75rem;
    opacity: 0.7;
}


.badge[b-n0yj26ffbw] {
    font-weight: 500;
    letter-spacing: 0.3px;
}

.bg-success-subtle[b-n0yj26ffbw] {
    background-color: #d1f2eb !important;
}

.text-success[b-n0yj26ffbw] {
    color: #17a2b8 !important;
}

.bg-danger-subtle[b-n0yj26ffbw] {
    background-color: #f8d7da !important;
}

.text-danger[b-n0yj26ffbw] {
    color: #dc3545 !important;
}

.bg-warning-subtle[b-n0yj26ffbw] {
    background-color: #fff3cd !important;
}

.text-warning[b-n0yj26ffbw] {
    color: #ffc107 !important;
}

.page-link[b-n0yj26ffbw] {
    color: #6c757d;
}

.page-item.active .page-link[b-n0yj26ffbw] {
    background-color: #007bff;
    border-color: #007bff;
}

.btn-outline-primary:hover[b-n0yj26ffbw],
.btn-outline-danger:hover[b-n0yj26ffbw],
.btn-outline-secondary:hover[b-n0yj26ffbw] {
    opacity: 1;
}

.card[b-n0yj26ffbw] {
    overflow: hidden;
}

thead th[b-n0yj26ffbw] {
    position: sticky;
    top: 0;
    background-color: #f8f9fa;
    z-index: 10;
}

.pagination-sm .page-link[b-n0yj26ffbw] {
    font-size: 0.7rem;
    padding: 0.15rem 0.4rem;
}

.btn-outline-success.action-btn:hover[b-n0yj26ffbw] {
    background-color: transparent !important;
    color: #198754 !important;
    opacity: 0.8;
}

.container-fluid[b-n0yj26ffbw] {
    background-color: #ffffff !important;
}

/* Custom cho nút Thêm booking */

.btn-add-booking[b-n0yj26ffbw] {
    padding: 0.5rem 1rem;
    font-size: 0.75rem;
    font-weight: 600;
    border-radius: 8px;
    background-color: #198754;
    border: none;
    transition: all 0.2s ease-in-out;
}



    .btn-add-booking:hover[b-n0yj26ffbw] {
        background-color: #157347;
        box-shadow: 0 4px 8px rgba(25, 135, 84, 0.2) !important;
    }



/* Custom cho chữ của các ô filter nhỏ đi */

.filter-input[b-n0yj26ffbw] {
    font-size: 0.85rem !important; /* Thu nhỏ chữ */

    padding: 0.4rem 0.75rem;
    border-radius: 6px;
    height: 35px; /* Giảm nhẹ chiều cao của ô nhập liệu */
}



    /* Thu nhỏ chữ của placeholder (dòng chữ mờ) */

    .filter-input[b-n0yj26ffbw]::placeholder {
        font-size: 0.8rem;
        opacity: 0.7;
    }



/* Custom cho nút Xóa lọc để đồng bộ kích thước với các ô input */

.btn-clear-filter[b-n0yj26ffbw] {
    font-size: 0.85rem !important;
    padding: 0.4rem 0.75rem;
    border-radius: 6px;
    height: 35px;
    display: flex;
    align-items: center;
    justify-content: center;
}
/* /Pages/Staff/CreateWalkIn.razor.rz.scp.css */
/* =========================================
   Overrides cho Child Components (BookTable, BookMenu)
   ========================================= */
[b-l6o307kyrk] .floor-plan-wrapper,
[b-l6o307kyrk] .btn-continue-step,
[b-l6o307kyrk] .container-menuitem .btn-back-step {
    display: none !important;
}

/* =========================================
   Nút Quay Lại (Back Button)
   ========================================= */
/* Nút quay lại Text */
.btn-back-step[b-l6o307kyrk] {
    background-color: #ffffff;
    color: #4a4a4a;
    border: 1px solid #dcdfe4;
    font-weight: 600;
    padding: 0.35rem 0.8rem;
    font-size: 0.8rem;
    border-radius: 5px;
    transition: all 0.2s ease;
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
}

    .btn-back-step:hover[b-l6o307kyrk] {
        background-color: #f8f9fa;
        color: #1a1a1a;
        border-color: #c4c8d0;
    }

/* =========================================
   Card & Layout
   ========================================= */
.card[b-l6o307kyrk] {
    border-radius: 12px;
    transition: box-shadow 0.3s ease;
}

    .card:hover[b-l6o307kyrk] {
        box-shadow: 0 8px 24px rgba(149, 157, 165, 0.1) !important;
    }

.card-header[b-l6o307kyrk] {
    padding: 1.25rem 1.5rem;
    border-bottom: 2px solid #f3f4f6 !important;
    border-top-left-radius: 12px !important;
    border-top-right-radius: 12px !important;
}

    .card-header h5[b-l6o307kyrk] {
        color: #1f2937;
    }

.card-footer[b-l6o307kyrk] {
    padding: 1.25rem 1.5rem;
    border-top: 2px solid #f3f4f6 !important;
    border-bottom-left-radius: 12px !important;
    border-bottom-right-radius: 12px !important;
}

/* =========================================
   Form Controls (Input, Label)
   ========================================= */
.form-label[b-l6o307kyrk] {
    font-weight: 600;
    color: #374151;
    font-size: 0.9rem;
    margin-bottom: 0.4rem;
}

.form-control[b-l6o307kyrk] {
    border-radius: 8px;
    border: 1px solid #d1d5db;
    padding: 0.6rem 1rem;
    color: #1f2937;
    transition: all 0.2s ease-in-out;
}

    .form-control:focus[b-l6o307kyrk] {
        border-color: #3b82f6; /* Chuyển màu viền sang xanh dương khi focus */
        box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.15); /* Hiệu ứng glow nhẹ */
        outline: none;
    }

/* =========================================
   Buttons (Primary, Success, Secondary)
   ========================================= */
.btn[b-l6o307kyrk] {
    border-radius: 8px;
    font-weight: 500;
    padding: 0.6rem 1.25rem;
    transition: all 0.2s;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

    .btn:active:not(:disabled)[b-l6o307kyrk] {
        transform: scale(0.97);
    }

    .btn:disabled[b-l6o307kyrk] {
        cursor: not-allowed;
        opacity: 0.65;
    }

/* Tùy chỉnh nút Tìm bàn */
.btn-primary[b-l6o307kyrk] {
    background-color: #0d6efd;
    border-color: #0d6efd;
    box-shadow: 0 2px 4px rgba(13, 110, 253, 0.15);
}

    .btn-primary:hover:not(:disabled)[b-l6o307kyrk] {
        background-color: #0b5ed7;
        border-color: #0a58ca;
        box-shadow: 0 4px 8px rgba(13, 110, 253, 0.2);
    }

/* Tùy chỉnh nút Tạo booking */
.btn-success[b-l6o307kyrk] {
    background-color: #10b981;
    border-color: #10b981;
    color: white;
    box-shadow: 0 2px 4px rgba(16, 185, 129, 0.15);
}

    .btn-success:hover:not(:disabled)[b-l6o307kyrk] {
        background-color: #059669;
        border-color: #047857;
        box-shadow: 0 4px 8px rgba(16, 185, 129, 0.2);
    }
