﻿
/* Base Styles */
:root {
    --primary-color: var(--bs-main);
    --primary-hover: var(--bs-main-700);
    --secondary-color: var();
    --secondary-color: var(0-);
    --secondary-color: var(0);
    --secondary-color: #f6f6f6;
    --text-color: #111827;
    --text-secondary: var();
    --text-secondary: var(--bs-gray-600);
    --background-color: var(--bg-main);
    --card-background: #ffffff;
    --shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
    --radius: var(--px-8);
    --transition: all 0.2s ease-in-out;
}

.required {
    color: var(--danger-color);
}
/* Layout */
.app-container {
    min-height: 100vh;
}


.main-title {
    font-size: 1.5rem;
    font-weight: 700;
    margin-bottom: 1rem;
}
/* Tab Navigation */
.tab-nav {
    margin-bottom: 1.5rem;
}

.tab-border {
    border-bottom: 1px solid var(--border-color);
}

.tab-links {
    display: flex;
    gap: 2rem;
}

.tab-link {
    padding: 1rem 0.25rem;
    border-bottom: 2px solid transparent;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--text-secondary);
    text-decoration: none;
    transition: var(--transition);
}

    .tab-link:hover {
        color: var(--text-color);
        border-bottom-color: var(--border-color);
    }

    .tab-link.active {
        color: var(--primary-color);
        border-bottom-color: var(--primary-color);
    }

/* Drawer Component */
.drawer-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0, 0, 0, 0.5);
    z-index: 50;
    display: none;
    opacity: 0;
    transition: opacity 0.3s ease;
}

    .drawer-overlay.open {
        display: block;
        opacity: 1;
    }


.drawer-header {
    position: sticky;
    top: 0;
    z-index: 10;
    background-color: var(--card-background);
    border-bottom: 1px solid var(--border-color);
    padding: 1rem 1.5rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.drawer-title {
    font-size: 1.25rem;
    font-weight: 600;
}

.drawer-actions {
    display: flex;
    gap: 0.75rem;
    align-items: center;
}

.with-icon {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}

.mb-6 {
    margin-bottom: 1.5rem;
}

/* Form Styles */
.booking-form-container {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    height: calc(100vh - 120px);
}

@media (min-width: 768px) {
    .booking-form-container {
        flex-direction: row;
    }
}

.form-container {
    flex: 1;
    overflow-y: auto;
    padding-right: 1rem;
}

.booking-form {
    padding-bottom: 2rem;
}

.form-section {
    margin-bottom: 2rem;
}

.section-title {
    font-size: 1.125rem;
    font-weight: 500;
    margin-bottom: 1rem;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid var(--border-color);
}

.form-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
}

.form-label {
    display: block;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--text-color);
    margin-bottom: 0.25rem;
}

.form-input,
.form-select,
.form-textarea {
    width: 100%;
    padding: 0.5rem 0.75rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    font-size: 0.875rem;
    transition: var(--transition);
}

    .form-input:focus,
    .form-select:focus,
    .form-textarea:focus {
        outline: none;
        box-shadow: 0 0 0 2px rgba(37, 99, 235, 0.2);
        border-color: var(--primary-color);
    }

    .form-input.readonly {
        background-color: var(--secondary-color);
    }

.input-with-button {
    display: flex;
}

    .input-with-button .form-input {
        flex: 1;
        border-top-right-radius: 0;
        border-bottom-right-radius: 0;
    }

.input-button {
    background-color: var(--secondary-color);
    border: 1px solid var(--border-color);
    border-left: 0;
    border-top-right-radius: var(--radius);
    border-bottom-right-radius: var(--radius);
    padding: 0 0.75rem;
    display: flex;
    align-items: center;
    cursor: pointer;
    transition: var(--transition);
}

    .input-button:hover {
        background-color: var(--secondary-hover);
    }

.input-with-icon {
    position: relative;
}

.input-icon {
    position: absolute;
    right: 0.75rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--text-secondary);
    pointer-events: none;
}

.select-wrapper {
    position: relative;
}

.select-icon {
    position: absolute;
    right: 0.75rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--text-secondary);
    pointer-events: none;
}

.form-select {
    appearance: none;
    padding-right: 2rem;
}

.form-textarea {
    resize: vertical;
    min-height: 100px;
}

.form-checkbox {
    display: flex;
    align-items: center;
    margin-bottom: 2rem;
}

.checkbox-input {
    width: 1rem;
    height: 1rem;
    margin-right: 0.5rem;
    border-radius: 0.25rem;
    border: 1px solid var(--border-color);
}

.checkbox-label {
    font-size: 0.875rem;
    color: var(--text-color);
}

.hidden-submit {
    position: absolute;
    left: -9999px;
    visibility: hidden;
}
/* Search Dropdown */
.search-dropdown {
    position: absolute;
    z-index: 10;
    margin-top: 0.25rem;
    width: 100%;
    background-color: white;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    display: none;
}

.search-header {
    padding: 0.5rem;
    border-bottom: 1px solid var(--border-color);
}

.search-input {
    width: 100%;
    padding: 0.5rem 0.75rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    font-size: 0.875rem;
}

.search-results {
    max-height: 15rem;
    overflow-y: auto;
    list-style: none;
}

.search-result-item {
    padding: 0.75rem;
    cursor: pointer;
    display: flex;
    align-items: center;
}

    .search-result-item:hover {
        background-color: var(--secondary-color);
    }

.search-result-icon {
    margin-right: 0.5rem;
    color: var(--text-secondary);
}

.search-result-empty {
    padding: 0.75rem;
    color: var(--text-secondary);
}

.search-footer {
    padding: 0.5rem;
    border-top: 1px solid var(--border-color);
    display: flex;
    justify-content: flex-end;
}

.search-close-btn {
    padding: 0.25rem 0.75rem;
    font-size: 0.875rem;
    color: var(--text-secondary);
    background: none;
    border: none;
    cursor: pointer;
}

    .search-close-btn:hover {
        color: var(--text-color);
    }
/* Rooms Table */
.rooms-container {
    margin-bottom: 1rem;
}

.rooms-table {
    width: 100%;
    border-collapse: collapse;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    overflow: hidden;
}

    .rooms-table th {
        background-color: var(--secondary-color);
        text-align: left;
        padding: 0.75rem 1rem;
        font-size: 0.875rem;
        font-weight: 500;
        color: var(--text-secondary);
        border-bottom: 1px solid var(--border-color);
    }

    .rooms-table td {
        padding: 0.75rem 1rem;
        border-bottom: 1px solid var(--border-color);
    }

    .rooms-table tr:last-child td {
        border-bottom: none;
    }

.room-name {
    font-weight: 500;
}

.room-code {
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.room-guest-inputs {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.room-guest-input {
    width: 100%;
    padding: 0.375rem 0.75rem;
    font-size: 0.875rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
}

.quantity-control {
    display: flex;
    align-items: center;
}

.quantity-btn {
    padding: 0.25rem;
    border: 1px solid var(--border-color);
    background-color: white;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
}

    .quantity-btn:first-child {
        border-radius: var(--radius) 0 0 var(--radius);
    }

    .quantity-btn:last-child {
        border-radius: 0 var(--radius) var(--radius) 0;
    }

    .quantity-btn:hover {
        background-color: var(--secondary-color);
    }

    .quantity-btn:disabled {
        background-color: var(--secondary-color);
        cursor: not-allowed;
    }

.quantity-input {
    width: 3rem;
    padding: 0.25rem 0;
    border-top: 1px solid var(--border-color);
    border-bottom: 1px solid var(--border-color);
    border-left: 0;
    border-right: 0;
    text-align: center;
}

    .quantity-input:focus {
        outline: none;
    }

.price-input {
    width: 100%;
    padding: 0.375rem 0.75rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
}

.remove-room-btn {
    padding: 0.375rem;
    color: var(--text-secondary);
    border: none;
    background: none;
    border-radius: 9999px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
}

    .remove-room-btn:hover {
        color: var(--danger-color);
        background-color: rgba(220, 38, 38, 0.1);
    }

.no-rooms-message {
    text-align: center;
    padding: 1.5rem;
    border: 1px dashed var(--border-color);
    border-radius: var(--radius);
    background-color: var(--secondary-color);
    color: var(--text-secondary);
}

.room-totals {
    margin-top: 1rem;
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
}

.total-item {
    background-color: var(--secondary-color);
    padding: 0.5rem 1rem;
    border-radius: var(--radius);
}

.total-label {
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.total-value {
    font-weight: 500;
}
/* Preview Container */
.preview-container {
    flex: 1;
    border-left: 1px solid var(--border-color);
    padding-left: 1rem;
    display: none;
}

@media (min-width: 768px) {
    .preview-container {
        display: block;
    }
}

.preview-header {
    position: sticky;
    top: 0;
    background-color: white;
    padding-bottom: 0.5rem;
}

.preview-title {
    font-size: 1.125rem;
    font-weight: 500;
    margin-bottom: 0.5rem;
}

.booking-preview {
    background-color: white;
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    padding: 1.5rem;
    position: sticky;
    top: 1rem;
}

.preview-header-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.preview-header-title {
    font-size: 1.125rem;
    font-weight: 500;
    margin: 0;
}

.preview-confirm-num {
    padding: 0.25rem 0.75rem;
    background-color: var(--bs-main-50);
    color: var(--bs-main-600);
    border-radius: 9999px;
    border: 1px solid var(--bs-main-200);
    font: normal normal 400 var(--s-14);
}

.preview-section-title {
    text-transform: uppercase;
    color: var(--text-secondary);
    font: normal normal 500 var(--s-14);
}

.preview-guest-name {
    font: normal normal 500 var(--s-18);
}

.preview-guest-detail {
    color: var(--text-secondary);
    font: normal normal 400 var(--s-14);
}

    .preview-guest-detail:last-of-type {
        margin-bottom: 0;
    }

.preview-company {
    font-weight: 500;
    color: var(--text-color);
}

.preview-status {
    color: var(--text-secondary);
}

.preview-status-value {
    font-weight: 500;
}

.preview-detail-row {
    font: normal normal 400 var(--s-14);
}

    .preview-detail-row:last-child {
        margin-bottom: 0;
    }

.preview-detail-label {
    color: var(--text-secondary);
}

.preview-detail-value {
    font-weight: 500;
}

.preview-note {
    margin-top: 0.25rem;
    color: var(--text-color);
}

.preview-seller-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.5rem;
    font-size: 0.875rem;
}

.preview-stay-value {
    font-weight: 500;
    margin-top: 4px;
}

.preview-stay-length {
    color: var(--text-secondary);
    font: normal normal 400 var(--s-14);
}

.preview-room-list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.preview-room-item {
    display: flex;
    gap: 4px;
    flex-direction: column;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid rgba(209, 213, 219, 0.5);
}

    .preview-room-item:last-child {
        border-bottom: none;
        padding-bottom: 0;
    }

.preview-room-header {
    display: flex;
    justify-content: space-between;
}

.preview-room-name {
    font-weight: 500;
    font: normal normal 400 var(--s-14);
    color: var(--text-color);
}

.preview-room-price {
    font-weight: 500;
}

.preview-room-details {
    font-size: 0.875rem;
    color: var(--text-secondary);
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    max-width: 28vw;
}

    .preview-room-details .guest-name {
        color: var(--bs-body-color);
        display: inline-flex;
        align-items: center;
        font: normal normal 500 var(--s-12);
        white-space: nowrap;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }

.preview-room-guest {
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin-top: 0.25rem;
}

.preview-totals {
    padding-top: 0.75rem;
    border-top: 1px solid rgba(209, 213, 219, 0.5);
}

.preview-total-row {
    display: flex;
    justify-content: space-between;
    margin-bottom: 0.25rem;
}

.preview-grand-total {
    display: flex;
    justify-content: space-between;
    border-top: 1px solid rgba(209, 213, 219, 0.5);
    font: normal normal 600 var(--s-16);
    padding-top: var(--px-12);
    margin-top: var(--px-12);
}
/* Room Selection Modal */
.room-selection-modal {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0, 0, 0, 0.5);
    z-index: 60;
    display: none;
}

.modal-content {
    position: fixed;
    top: 0;
    right: 0;
    height: 100%;
    width: 100%;
    max-width: 1200px;
    background-color: white;
    box-shadow: -2px 0 8px rgba(0, 0, 0, 0.1);
    display: flex;
    flex-direction: column;
}

.modal-header {
    position: sticky;
    top: 0;
    z-index: 10;
    background-color: white;
    border-bottom: 1px solid var(--border-color);
    padding: 1rem 1.5rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.modal-title {
    font-size: 1.25rem;
    font-weight: 600;
}

.modal-actions {
    display: flex;
    gap: 0.75rem;
}

.modal-body {
    padding: 1rem 1.5rem;
    overflow-y: auto;
    flex: 1;
}

.room-selection-totals {
    display: flex;
    flex-wrap: wrap;
    gap: 1.5rem;
    margin-bottom: 1rem;
}

.room-selection-table-container {
    overflow-y: auto;
    max-height: calc(100vh - 200px);
}

.room-selection-table {
    width: 100%;
    border-collapse: collapse;
}

    .room-selection-table th {
        position: sticky;
        top: 0;
        background-color: var(--secondary-color);
        padding: 0.75rem 1rem;
        text-align: left;
        font-size: 0.875rem;
        font-weight: 500;
        color: var(--text-secondary);
    }

    .room-selection-table td {
        padding: 0.75rem 1rem;
        border-bottom: 1px solid var(--border-color);
    }

    .room-selection-table tr.selected {
        background-color: rgba(37, 99, 235, 0.05);
    }

    .room-selection-table tr.disabled {
        opacity: 0.5;
    }

.room-capacity {
    display: block;
}

.room-capacity-children {
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.quantity-control-end {
    display: flex;
    justify-content: flex-end;
}
/* Delete Confirmation Modal */
.delete-modal {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 70;
    display: none;
}

.delete-modal-content {
    background-color: white;
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    max-width: 28rem;
    width: 100%;
    padding: 1.5rem;
}

.delete-modal-header {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1rem;
}

.delete-icon-container {
    background-color: #fee2e2;
    padding: 0.75rem;
    border-radius: 9999px;
}

.delete-icon {
    color: var(--danger-color);
}

.delete-modal-title {
    font-size: 1.25rem;
    font-weight: 600;
}

.delete-modal-message {
    color: var(--text-secondary);
    margin-bottom: 1.5rem;
}

.delete-modal-actions {
    display: flex;
    justify-content: flex-end;
    gap: 0.75rem;
}

/* Utility Classes */

.drawer-content {
    transition: transform 0.3s ease;
    width: fit-content;
    display: flex;
    flex-direction: column;
    height: 100%;
    overflow: hidden;
    min-width: var(--px-460);
}

.drawer.open .drawer-content {
    transform: translateX(0);
}

.drawer.open .drawer-open-booking {
}

.drawer-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem 1.5rem;
    border-bottom: 1px solid var(--border-color);
}

.drawer-title {
    font-size: 1.25rem;
    font-weight: 600;
}

.drawer-actions {
    display: flex;
    gap: 0.5rem;
}

.drawer-body {
    flex: 1;
    overflow-y: hidden;
    display: flex;
    border-radius: 0 0 8px 8px;
}

.form-group.form--popup {
    border: 1px solid var(--bs-gray-300);
    border-bottom: 2px solid var(--bs-gray-300);
    border-radius: 0;
    background: white;
    padding: var(--px-16);
    grid-gap: var(--px-20) var(--px-16);
    border-radius: 6px;
    min-width: 100%;
    position: relative;
}

    .form-group.form--popup.collapsed {
        overflow: hidden;
        min-height: min-content;
    }

    .form-group.form--popup .form--input label {
        font-weight: 400;
        pointer-events: all;
        color: var(--text-secondary);
    }

    .form-group.form--popup .form--input.option {
        display: flex;
        flex-direction: row;
        align-items: center;
    }

.section-select-room-book .header-start-popup {
    flex-direction: row;
    -webkit-align-items: center;
    align-items: center;
}

.section-select-room-book .search-form {
    min-height: var(--px-48)
}

.group-action-button-form {
    display: flex;
    justify-content: flex-end;
    gap: var(--px-8);
}

    .group-action-button-form .btn {
        padding: var(--px-8) var(--px-16);
        border-radius: 6px;
        border: none;
        font: normal normal 500 var(--s-14);
        font-weight: 500;
        cursor: pointer;
        display: flex;
        gap: 12px;
    }

        .group-action-button-form .btn.cancel {
            background: 0;
        }

        .group-action-button-form .btn.primary {
            background-color: var(--bs-main);
            color: #fff;
        }

        .group-action-button-form .btn span {
            color: white;
            font: normal normal 500 var(--s-14);
        }

.edit-guest-body {
    flex: 1;
    display: flex;
    flex-direction: column;
    padding: var(--px-16);
    gap: var(--px-16);
}

    .edit-guest-body .section-title {
        font: normal normal 500 var(--s-16);
        margin: 0;
        padding: 0;
    }

    .edit-guest-body .guest-type-wrapper {
        display: flex;
        gap: 12px;
        width: 100%;
        align-items: center;
    }

    .edit-guest-body .guest-type-btn {
        flex: 1;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 6px;
        padding: 8px 0;
        border: 1.6px solid #d8d8d8;
        border-radius: 8px;
        font-size: 14px;
        cursor: pointer;
        transition: 0.2s;
        background: #fff;
    }

.guest-type-btn.active {
    border-color: var(--bs-main-400);
    background: var(--bs-main-50);
    color: var(--bs-main-500);
    font-weight: 500;
}

.edit-guest-body .guest-type-btn svg {
    height: var(--px-20);
    width: var(--px-20);
}

.edit-guest-body .guest-type-btn span {
}

.edit-guest-body .form-group {
    background: var(--bg-num-availble);
}

.popup-footer {
    display: flex;
    -webkit-justify-content: end;
    justify-content: end;
    padding: var(--px-16);
}

.edit-guest-body .btn-save-guest {
}

/* === Base structure === */
.special-form-body {
    display: flex;
    flex: 1;
    overflow: hidden;
    border-bottom: 1px solid var(--bs-gray-300);
    width: var(--px-800);
}

/* === Search section === */
.special-search {
    flex: 1;
    display: flex;
    gap: var(--px-12);
    overflow: hidden;
    flex-direction: column;
    max-width: var(--px-320);
    border-right: 6px solid var(--bs-gray-200);
}

    .special-search .search-form {
        padding: var(--px-12);
        background: white;
        margin: var(--px-12);
    }

.search-form i {
}

.search-form input {
}

.list-special-service {
    display: flex;
    flex-direction: column;
    gap: 12px;
    flex: 1;
    border-radius: 6px;
    overflow: auto;
    padding: 2px var(--px-12) var(--px-12);
}

.item-special-search {
    background: var(--bs-white);
    border-radius: 8px;
    padding: var(--px-12);
    border: 1px solid var(--bs-gray-300);
    display: flex;
    flex-direction: column;
    gap: 8px;
    cursor: pointer;
}

    .item-special-search:hover {
        box-shadow: var(--shadow-h);
    }

    .item-special-search.selected {
        box-shadow: var(--shadow-h);
        outline: 1px solid var(--bs-main);
    }

    .item-special-search .special-col {
        display: flex;
        align-items: center;
        gap: 4px;
        font: normal normal 400 var(--s-14);
    }

        .item-special-search .special-col:last-of-type {
            justify-content: end;
        }

    .item-special-search .badge-pms {
        padding: 4px var(--px-12);
        background: var(--bs-gray-100);
        color: var(--bs-gray-700);
        border-radius: 4px;
        font-size: 12px;
        font-weight: 700;
        border: 1px solid var(--bs-gray-300);
    }

    .item-special-search .special-name {
    }

    .item-special-search strong {
    }

    .item-special-search .currency-text {
    }

/* === Selected services section === */
.special-selected-services {
    flex: 1;
}

.header-special-selected {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--px-12);
    border-bottom: 1px solid var(--bs-gray-400);
}

.name-selected {
    display: flex;
    flex-direction: column;
    gap: 8px;
    font: normal normal 400 var(--s-14);
    color: var(--bs-gray-700);
}

    .name-selected p.selected-description {
        color: var(--bs-gray-900);
        font: normal normal 600 var(--s-16);
    }

    .name-selected .stay-date {
        display: flex;
        align-items: center;
        gap: 8px;
    }

.header-special-selected .badge-pms {
    color: var(--bs-main);
    font: normal normal 600 var(--s-20);
}

    .header-special-selected .badge-pms.selected-code {
        width: max-content;
        padding: 4px var(--px-12);
        background: var(--bs-gray-100);
        color: var(--bs-gray-700);
        border-radius: 4px;
        border: 1px solid var(--bs-gray-300);
        font: normal normal 600 var(--s-12);
    }

.special-selected-services .form-group.form--popup {
    grid-template-columns: repeat(6, 1fr);
    border: 0;
}

.special-selected-services .form--input.option {
    display: flex;
    align-items: center;
    flex-direction: row;
}

.special-selected-services .form--input.grid-3 {
}

.special-selected-services .form--input label {
}

.special-selected-services .form--input input {
}

.special-selected-services .total {
    display: flex;
    padding: var(--px-12);
    border: 1px solid var(--bs-main-200);
    border-radius: 8px;
    background: var(--bs-main-50);
    font: normal normal 500 var(--s-16);
    margin: var(--px-12);
}

    .special-selected-services .total strong {
        margin-left: 4px;
    }

.special-selected-services .options {
    display: flex;
    gap: var(--px-12);
    align-items: center;
    padding: var(--px-12);
}

    .special-selected-services .options .toggle {
    }

        .special-selected-services .options .toggle input {
        }

.special-selected-services .notes {
    gap: 8px;
    display: flex;
    flex-direction: column;
    padding: var(--px-12);
}

    .special-selected-services .notes label {
        font: normal normal 600 var(--s-14);
    }

    .special-selected-services .notes textarea {
        border: 1px solid var(--bs-gray-300);
        border-radius: 8px;
        padding: var(--px-8) var(--px-12);
        font: normal normal 400 var(--s-14);
        min-height: var(--px-88);
    }

.special-selected-services .add-btn {
    width: -webkit-fill-available;
    margin: var(--px-12);
    background: white;
    color: var(--bs-main);
    font: normal normal 600 var(--s-14);
    border: 2px dashed var(--bs-gray-300);
}

.special-selected-services .group-name-code {
    display: flex;
    align-items: center;
    gap: 4px;
}

/* === Responsive or state modifiers (if needed) === */
.is-active {
}

.is-disabled {
}

.is-hidden {
}

.popup-container.reservation-edit-guest,
.popup-container.reservation-add-special,
.popup-container.reservation-extra-beds {
    right: var(--px-710) !important
}

.header-toggle {
    display: flex;
    align-items: center;
    flex-direction: row;
    justify-content: space-between;
}

.btn-collapse-form {
    background: none;
    border: none;
    cursor: pointer;
    font-size: var(--px-16);
    color: var(--text-color);
    border-radius: 8px;
}

    .btn-collapse-form:hover {
        background: var(--bs-gray-100);
    }

.option-input-roomtype .title-o {
    display: grid;
    grid-template-columns: var(--px-28) 1fr;
    align-items: center;
}

    .option-input-roomtype .title-o svg {
        height: var(--px-20);
        width: var(--px-20);
        color: var(--bs-gray-500);
    }

    .option-input-roomtype .title-o i {
        font-size: var(--px-16);
        color: var(--bs-gray-500);
    }

    .option-input-roomtype .title-o span {
        color: var(--bs-gray-900);
    }

.group-btn-rt {
    width: 100%;
    display: flex;
    align-items: center;
    padding: 12px 0 0;
    border-top: 1px solid var(--bs-gray-400);
}

    .group-btn-rt button {
        color: white;
        border: 1px solid var(--bs-gray-300);
        font: normal normal 600 var(--s-14);
        margin-left: auto;
        background: var(--bs-main);
    }

button.change-roomtype {
    background: white;
    border: 1px solid var(--bs-gray-300);
    color: black;
    height: var(--px-28);
    gap: 4px;
    padding: 0 6px;
    font: normal normal 500 var(--s-10);
}

    button.change-roomtype i {
        font-size: 14px !important;
        font-weight: 400;
        color: var(--bs-main) !important;
    }

.option-input-roomtype.add-rate-room .title-o {
    display: flex;
    gap: 12px;
}

.option-input-roomtype.add-rate-room input {
    text-align: end;
}

.option-input-roomtype.add-rate-room .container--checkbox {
    pointer-events: all;
    cursor: pointer;
}

.container--checkbox.can-click {
    pointer-events: all;
    cursor: pointer;
}

.form--input input[readonly][name="inp-rate-amount"] {
    background: var(--bs-gray-200);
    border: 1px solid var(--bs-gray-300);
    padding: var(--px-12) var(--px-16);
}

.group-check-amount {
    gap: 4px;
    display: flex;
    flex-direction: row;
    align-items: center;
    border-radius: 8px;
    padding: 4px;
    border: 1px solid var(--bs-gray-300);
}

    .group-check-amount.disabled input {
        opacity: .4;
        pointer-events: none;
    }

.label-required {
    position: relative;
}

    .label-required::after {
        display: inline-block;
        margin-inline-end: 4px;
        color: #ff4d4f;
        font-size: 14px;
        font-family: SimSun, sans-serif;
        line-height: 1;
        content: "*";
        margin-left: 2px;
    }

.btn-add-new-booking {
    background: var(--bs-main);
    color: white;
    font: normal normal 600 var(--s-14);
    border: none;
    padding: var(--px-12);
    border-radius: 8px;
}

.search-form input {
    background: 0;
    border: 0;
    box-shadow: unset;
    padding: 0;
}

.form-extrabed-section .fdc-table.no-mw .extrabed-row:hover {
    cursor: pointer;
    background: var(--bs-gray-100);
}

/* Make rows look clickable */
#fdc-advance-body tr.fdc-booker-row {
    cursor: pointer;
    transition: background .15s;
}

    #fdc-advance-body tr.fdc-booker-row:hover {
        background: var(--bs-gray-100);
    }

.advance-input-body .form--input label {
    pointer-events: all;
}

.section-table-append {
    display: flex;
    flex-direction: column;
    overflow: auto;
}

    .section-table-append.max-h {
        min-height: var(--px-200);
        max-height: var(--px-200);
    }

.highlight-opt {
    display: flex;
    flex-direction: row;
    align-items: center;
    border-radius: 8px;
    padding: 12px 8px;
    border: 1px solid var(--bs-opacity);
}

    .highlight-opt .form--input.option {
        align-items: flex-start !important;
        gap: 4px;
    }

        .highlight-opt .form--input.option label {
            color: var(--bs-gray-900);
            min-width: var(--px-32);
        }

        .highlight-opt .form--input.option p {
            color: var(--bs-gray-600);
        }

    .highlight-opt.no-em {
        border: 1px solid var(--bs-gray-200);
    }

    .highlight-opt.have-bg {
        border: 0;
        background: var(--secondary-color);
    }

.checkbox-desc {
    gap: 8px;
    display: flex;
    flex-direction: column;
}

.section-center-icon {
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 100%;
    width: var(--px-48);
    min-height: var(--px-48);
    background: var(--bs-main);
    box-shadow: var(--shadow-qs-solid);
    position: absolute;
    bottom: calc(-1 * var(--px-32));
    left: 50%;
    transform: translateX(-50%);
    border: 4px solid white;
    outline: 1px solid var( --bs-gray-300);
    z-index: 1;
}

    .section-center-icon i {
        font-size: var(--px-16);
        color: white;
        font-weight: 500;
    }

.section-split.auto-section {
}

.section-split .auto-split-row {
    display: flex;
    gap: var(--px-12);
    align-items: center;
    min-height: var(--px-60);
    border: 1px solid var(--bs-gray-300);
    border-radius: 8px;
    padding: 8px;
}

    .section-split .auto-split-row .auto-label {
        flex: 1;
        font: normal normal 400 var(--s-14);
    }

    .section-split .auto-split-row .auto-part {
        background: var(--bs-main-50);
        border: 1px solid var(--bs-main-200);
        padding: 4px 8px;
        border-radius: 999px;
        font-size: 12px;
    }

    .section-split .auto-split-row .auto-value {
        font: normal normal 600 var(--s-16);
    }

#auto-split-preview {
    display: grid;
    gap: 12px;
    grid-template-columns: 1fr 1fr;
}


/* Base Styles */
:root {
    --primary-color: var(--bs-main);
    --primary-hover: var(--bs-main-700);
    --secondary-color: var();
    --secondary-color: var(0-);
    --secondary-color: var(0);
    --secondary-color: #f6f6f6;
    --text-color: #111827;
    --text-secondary: var();
    --text-secondary: var(--bs-gray-600);
    --background-color: var(--bg-main);
    --card-background: #ffffff;
    --shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
    --radius: var(--px-8);
    --transition: all 0.2s ease-in-out;
}

.required {
    color: var(--danger-color);
}
/* Layout */
.app-container {
    min-height: 100vh;
}


.main-title {
    font-size: 1.5rem;
    font-weight: 700;
    margin-bottom: 1rem;
}
/* Tab Navigation */
.tab-nav {
    margin-bottom: 1.5rem;
}

.tab-border {
    border-bottom: 1px solid var(--border-color);
}

.tab-links {
    display: flex;
    gap: 2rem;
}

.tab-link {
    padding: 1rem 0.25rem;
    border-bottom: 2px solid transparent;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--text-secondary);
    text-decoration: none;
    transition: var(--transition);
}

    .tab-link:hover {
        color: var(--text-color);
        border-bottom-color: var(--border-color);
    }

    .tab-link.active {
        color: var(--primary-color);
        border-bottom-color: var(--primary-color);
    }

/* Drawer Component */
.drawer-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0, 0, 0, 0.5);
    z-index: 50;
    display: none;
    opacity: 0;
    transition: opacity 0.3s ease;
}

    .drawer-overlay.open {
        display: block;
        opacity: 1;
    }


.drawer-header {
    position: sticky;
    top: 0;
    z-index: 10;
    background-color: var(--card-background);
    border-bottom: 1px solid var(--border-color);
    padding: 1rem 1.5rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.drawer-title {
    font-size: 1.25rem;
    font-weight: 600;
}

.drawer-actions {
    display: flex;
    gap: 0.75rem;
    align-items: center;
}

.with-icon {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}

.mb-6 {
    margin-bottom: 1.5rem;
}

/* Form Styles */
.booking-form-container {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    height: calc(100vh - 120px);
}

@media (min-width: 768px) {
    .booking-form-container {
        flex-direction: row;
    }
}

.form-container {
    flex: 1;
    overflow-y: auto;
    padding-right: 1rem;
}

.booking-form {
    padding-bottom: 2rem;
}

.form-section {
    margin-bottom: 2rem;
}

.section-title {
    font-size: 1.125rem;
    font-weight: 500;
    margin-bottom: 1rem;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid var(--border-color);
}

.form-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
}

.form-label {
    display: block;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--text-color);
    margin-bottom: 0.25rem;
}

.form-input,
.form-select,
.form-textarea {
    width: 100%;
    padding: 0.5rem 0.75rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    font-size: 0.875rem;
    transition: var(--transition);
}

    .form-input:focus,
    .form-select:focus,
    .form-textarea:focus {
        outline: none;
        box-shadow: 0 0 0 2px rgba(37, 99, 235, 0.2);
        border-color: var(--primary-color);
    }

    .form-input.readonly {
        background-color: var(--secondary-color);
    }

.input-with-button {
    display: flex;
}

    .input-with-button .form-input {
        flex: 1;
        border-top-right-radius: 0;
        border-bottom-right-radius: 0;
    }

.input-button {
    background-color: var(--secondary-color);
    border: 1px solid var(--border-color);
    border-left: 0;
    border-top-right-radius: var(--radius);
    border-bottom-right-radius: var(--radius);
    padding: 0 0.75rem;
    display: flex;
    align-items: center;
    cursor: pointer;
    transition: var(--transition);
}

    .input-button:hover {
        background-color: var(--secondary-hover);
    }

.input-with-icon {
    position: relative;
}

.input-icon {
    position: absolute;
    right: 0.75rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--text-secondary);
    pointer-events: none;
}

.select-wrapper {
    position: relative;
}

.select-icon {
    position: absolute;
    right: 0.75rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--text-secondary);
    pointer-events: none;
}

.form-select {
    appearance: none;
    padding-right: 2rem;
}

.form-textarea {
    resize: vertical;
    min-height: 100px;
}

.form-checkbox {
    display: flex;
    align-items: center;
    margin-bottom: 2rem;
}

.checkbox-input {
    width: 1rem;
    height: 1rem;
    margin-right: 0.5rem;
    border-radius: 0.25rem;
    border: 1px solid var(--border-color);
}

.checkbox-label {
    font-size: 0.875rem;
    color: var(--text-color);
}

.hidden-submit {
    position: absolute;
    left: -9999px;
    visibility: hidden;
}
/* Search Dropdown */
.search-dropdown {
    position: absolute;
    z-index: 10;
    margin-top: 0.25rem;
    width: 100%;
    background-color: white;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    display: none;
}

.search-header {
    padding: 0.5rem;
    border-bottom: 1px solid var(--border-color);
}

.search-input {
    width: 100%;
    padding: 0.5rem 0.75rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    font-size: 0.875rem;
}

.search-results {
    max-height: 15rem;
    overflow-y: auto;
    list-style: none;
}

.search-result-item {
    padding: 0.75rem;
    cursor: pointer;
    display: flex;
    align-items: center;
}

    .search-result-item:hover {
        background-color: var(--secondary-color);
    }

.search-result-icon {
    margin-right: 0.5rem;
    color: var(--text-secondary);
}

.search-result-empty {
    padding: 0.75rem;
    color: var(--text-secondary);
}

.search-footer {
    padding: 0.5rem;
    border-top: 1px solid var(--border-color);
    display: flex;
    justify-content: flex-end;
}

.search-close-btn {
    padding: 0.25rem 0.75rem;
    font-size: 0.875rem;
    color: var(--text-secondary);
    background: none;
    border: none;
    cursor: pointer;
}

    .search-close-btn:hover {
        color: var(--text-color);
    }
/* Rooms Table */
.rooms-container {
    margin-bottom: 1rem;
}

.rooms-table {
    width: 100%;
    border-collapse: collapse;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    overflow: hidden;
}

    .rooms-table th {
        background-color: var(--secondary-color);
        text-align: left;
        padding: 0.75rem 1rem;
        font-size: 0.875rem;
        font-weight: 500;
        color: var(--text-secondary);
        border-bottom: 1px solid var(--border-color);
    }

    .rooms-table td {
        padding: 0.75rem 1rem;
        border-bottom: 1px solid var(--border-color);
    }

    .rooms-table tr:last-child td {
        border-bottom: none;
    }

.room-name {
    font-weight: 500;
}

.room-code {
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.room-guest-inputs {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.room-guest-input {
    width: 100%;
    padding: 0.375rem 0.75rem;
    font-size: 0.875rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
}

.quantity-control {
    display: flex;
    align-items: center;
}

.quantity-btn {
    padding: 0.25rem;
    border: 1px solid var(--border-color);
    background-color: white;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
}

    .quantity-btn:first-child {
        border-radius: var(--radius) 0 0 var(--radius);
    }

    .quantity-btn:last-child {
        border-radius: 0 var(--radius) var(--radius) 0;
    }

    .quantity-btn:hover {
        background-color: var(--secondary-color);
    }

    .quantity-btn:disabled {
        background-color: var(--secondary-color);
        cursor: not-allowed;
    }

.quantity-input {
    width: 3rem;
    padding: 0.25rem 0;
    border-top: 1px solid var(--border-color);
    border-bottom: 1px solid var(--border-color);
    border-left: 0;
    border-right: 0;
    text-align: center;
}

    .quantity-input:focus {
        outline: none;
    }

.price-input {
    width: 100%;
    padding: 0.375rem 0.75rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
}

.remove-room-btn {
    padding: 0.375rem;
    color: var(--text-secondary);
    border: none;
    background: none;
    border-radius: 9999px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
}

    .remove-room-btn:hover {
        color: var(--danger-color);
        background-color: rgba(220, 38, 38, 0.1);
    }

.no-rooms-message {
    text-align: center;
    padding: 1.5rem;
    border: 1px dashed var(--border-color);
    border-radius: var(--radius);
    background-color: var(--secondary-color);
    color: var(--text-secondary);
}

.room-totals {
    margin-top: 1rem;
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
}

.total-item {
    background-color: var(--secondary-color);
    padding: 0.5rem 1rem;
    border-radius: var(--radius);
}

.total-label {
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.total-value {
    font-weight: 500;
}
/* Preview Container */
.preview-container {
    flex: 1;
    border-left: 1px solid var(--border-color);
    padding-left: 1rem;
    display: none;
}

@media (min-width: 768px) {
    .preview-container {
        display: block;
    }
}

.preview-header {
    position: sticky;
    top: 0;
    background-color: white;
    padding-bottom: 0.5rem;
}

.preview-title {
    font-size: 1.125rem;
    font-weight: 500;
    margin-bottom: 0.5rem;
}

.booking-preview {
    background-color: white;
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    padding: 1.5rem;
    position: sticky;
    top: 1rem;
}

.preview-section {
}

    .preview-section:last-child {
        margin-bottom: 0;
    }

.preview-header-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.preview-header-title {
    font-size: 1.125rem;
    font-weight: 500;
    margin: 0;
}

.preview-confirm-num {
    padding: 0.25rem 0.75rem;
    background-color: var(--bs-main-50);
    color: var(--bs-main-600);
    border-radius: 9999px;
    border: 1px solid var(--bs-main-200);
    font: normal normal 400 var(--s-14);
}

.preview-content {
    background-color: var(--secondary-color);
    border-radius: var(--radius);
    padding: var(--px-16);
    display: flex;
    flex-direction: column;
    gap: var(--px-8);
    margin-bottom: 8px;
}

.preview-guest-name {
    font: normal normal 500 var(--s-18);
}

.preview-guest-detail {
    color: var(--text-secondary);
    font: normal normal 400 var(--s-14);
}

    .preview-guest-detail:last-of-type {
        margin-bottom: 0;
    }

.preview-company {
    font-weight: 500;
    color: var(--text-color);
}

.preview-status {
    color: var(--text-secondary);
}

.preview-status-value {
    font-weight: 500;
}

.preview-detail-row {
    font: normal normal 400 var(--s-14);
}

    .preview-detail-row:last-child {
        margin-bottom: 0;
    }

.preview-detail-label {
    color: var(--text-secondary);
}

.preview-detail-value {
    font-weight: 500;
}

.preview-note {
    margin-top: 0.25rem;
    color: var(--text-color);
}

.preview-seller-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.5rem;
    font-size: 0.875rem;
}

.preview-stay-grid {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 0.5rem;
    margin-bottom: 0.75rem;
    font: normal normal 400 var(--s-14);
}

    .preview-stay-grid .grid-full {
        grid-column: 1 / -1;
    }

.preview-stay-label {
    color: var(--text-secondary);
    font: normal normal 400 var(--s-14);
}

.preview-stay-value {
    font-weight: 500;
    margin-top: 4px;
}

.preview-stay-length {
    color: var(--text-secondary);
    font: normal normal 400 var(--s-14);
}

.preview-room-list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.preview-room-item {
    display: flex;
    gap: 4px;
    flex-direction: column;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid rgba(209, 213, 219, 0.5);
}

    .preview-room-item:last-child {
        border-bottom: none;
        padding-bottom: 0;
    }

.preview-room-header {
    display: flex;
    justify-content: space-between;
}

.preview-room-name {
    font-weight: 500;
    font: normal normal 400 var(--s-14);
    color: var(--text-color);
}

.preview-room-price {
    font-weight: 500;
}

.preview-room-details {
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.preview-room-guest {
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin-top: 0.25rem;
}

.preview-totals {
    padding-top: 0.75rem;
    border-top: 1px solid rgba(209, 213, 219, 0.5);
}

.preview-total-row {
    display: flex;
    justify-content: space-between;
    margin-bottom: 0.25rem;
}

.preview-grand-total {
    display: flex;
    justify-content: space-between;
    border-top: 1px solid rgba(209, 213, 219, 0.5);
    font: normal normal 600 var(--s-16);
    padding-top: var(--px-12);
    margin-top: var(--px-12);
}
/* Room Selection Modal */
.room-selection-modal {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0, 0, 0, 0.5);
    z-index: 60;
    display: none;
}

.modal-content {
    position: fixed;
    top: 0;
    right: 0;
    height: 100%;
    width: 100%;
    max-width: 1200px;
    background-color: white;
    box-shadow: -2px 0 8px rgba(0, 0, 0, 0.1);
    display: flex;
    flex-direction: column;
}

.modal-header {
    position: sticky;
    top: 0;
    z-index: 10;
    background-color: white;
    border-bottom: 1px solid var(--border-color);
    padding: 1rem 1.5rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.modal-title {
    font-size: 1.25rem;
    font-weight: 600;
}

.modal-actions {
    display: flex;
    gap: 0.75rem;
}

.modal-body {
    padding: 1rem 1.5rem;
    overflow-y: auto;
    flex: 1;
}

.room-selection-totals {
    display: flex;
    flex-wrap: wrap;
    gap: 1.5rem;
    margin-bottom: 1rem;
}

.room-selection-table-container {
    overflow-y: auto;
    max-height: calc(100vh - 200px);
}

.room-selection-table {
    width: 100%;
    border-collapse: collapse;
}

    .room-selection-table th {
        position: sticky;
        top: 0;
        background-color: var(--secondary-color);
        padding: 0.75rem 1rem;
        text-align: left;
        font-size: 0.875rem;
        font-weight: 500;
        color: var(--text-secondary);
    }

    .room-selection-table td {
        padding: 0.75rem 1rem;
        border-bottom: 1px solid var(--border-color);
    }

    .room-selection-table tr.selected {
        background-color: rgba(37, 99, 235, 0.05);
    }

    .room-selection-table tr.disabled {
        opacity: 0.5;
    }

.room-capacity {
    display: block;
}

.room-capacity-children {
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.quantity-control-end {
    display: flex;
    justify-content: flex-end;
}
/* Delete Confirmation Modal */
.delete-modal {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 70;
    display: none;
}

.delete-modal-content {
    background-color: white;
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    max-width: 28rem;
    width: 100%;
    padding: 1.5rem;
}

.delete-modal-header {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1rem;
}

.delete-icon-container {
    background-color: #fee2e2;
    padding: 0.75rem;
    border-radius: 9999px;
}

.delete-icon {
    color: var(--danger-color);
}

.delete-modal-title {
    font-size: 1.25rem;
    font-weight: 600;
}

.delete-modal-message {
    color: var(--text-secondary);
    margin-bottom: 1.5rem;
}

.delete-modal-actions {
    display: flex;
    justify-content: flex-end;
    gap: 0.75rem;
}

/* Utility Classes */

.drawer-content {
    transition: transform 0.3s ease;
    width: fit-content;
    display: flex;
    flex-direction: column;
    height: 100%;
    overflow: hidden;
    min-width: var(--px-600);
}

.drawer.open .drawer-content {
    transform: translateX(0);
}

.drawer.open .drawer-open-booking {
}

.drawer-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem 1.5rem;
    border-bottom: 1px solid var(--border-color);
}

.drawer-title {
    font-size: 1.25rem;
    font-weight: 600;
}

.drawer-actions {
    display: flex;
    gap: 0.5rem;
}

.drawer-body {
    flex: 1;
    overflow-y: hidden;
    display: flex;
    border-radius: 0 0 8px 8px;
    max-width: 100vw;
    overflow: auto;
}

    .drawer-body .booking-detail {
        flex: 1;
        display: flex;
        gap: var(--px-20);
        flex-direction: column;
        font: normal normal 400 var(--s-14);
        padding: var(--px-16);
        background: white;
        overflow: auto;
        min-width: 100%;
        max-width: 100%;
    }

.form-group.form--popup {
    border: 1px solid var(--bs-gray-300);
    border-bottom: 2px solid var(--bs-gray-300);
    border-radius: 0;
    background: white;
    padding: var(--px-16);
    grid-gap: var(--px-20) var(--px-16);
    border-radius: 6px;
    min-width: 100%;
    position: relative;
}

    .form-group.form--popup.collapsed {
        overflow: hidden;
    }

        .form-group.form--popup.collapsed .form--input:not(.header-toggle),
        .form-group.form--popup.collapsed .highlight-opt,
        .form-group.form--popup.collapsed .grid-12:not(.header-toggle) {
            display: none;
        }

    .form-group.form--popup .form--input label {
        font-weight: 400;
        pointer-events: all;
        color: var(--text-secondary);
    }

    .form-group.form--popup .form--input.option {
        display: flex;
        flex-direction: row;
        align-items: center;
    }

    .form-group.form--popup.move-to-section {
        border: 3px solid var(--bs-main-300);
        box-shadow: var(--shadow);
    }

.drawer-body .section-select-room-book {
    padding: var(--px-16);
    border-right: 2px solid var(--bs-gray-300);
    display: flex;
    flex-direction: column;
    gap: var(--px-16);
    flex: 1;
    position: absolute;
    right: 0;
    z-index: 111;
    background: white;
    width: max-content;
    height: 100%;
    top: 0px;
    border-radius: 12px;
    box-shadow: var(--shadow-qs-solid);
    border: 1px solid var(--bs-gray-300);
}

    .drawer-body .section-select-room-book .titl-form {
        flex: 1;
        font: normal normal 600 var(--s-20);
    }

.drawer-body .btn-close-form {
    display: flex;
    background: white;
    color: var(--bs-red);
    font-size: var(--px-12);
    font-weight: 500;
    background: #ffe5e8;
}

.section-select-room-book .header-start-popup {
    flex-direction: row;
    -webkit-align-items: center;
    align-items: center;
    flex: 0;
}

.section-select-room-book .body-select-edit {
    flex: 1;
    display: flex;
    flex-direction: column;
    overflow: auto;
    gap: 0px;
}

.section-select-room-book .search-form {
    min-height: var(--px-48)
}

/* Split Bill */
.split-function-ui {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: var(--px-16);
    padding: var(--px-12);
    justify-content: flex-start;
    max-width: var(--px-600);
    overflow: auto;
}

    .split-function-ui .fdc-row-split-options {
        background: var(--bg-num-availble);
        border: 0;
        padding: 0;
        margin: auto;
    }

        .split-function-ui .fdc-row-split-options .active {
            background: white;
            height: var(--px-40);
            border: 1px solid var(--bs-gray-400);
        }

    .split-function-ui .summary-split {
        background-color: var(--bg-num-availble);
        border-radius: 6px;
        padding: var(--px-12);
        font: normal normal 400 var(--s-13);
        line-height: var(--px-20);
    }

    .split-function-ui .split-options {
        display: flex;
        gap: var(--px-16);
        margin-bottom: var(--px-16);
    }

        .split-function-ui .split-options label {
            font: var(--s-14);
            color: #333;
            cursor: pointer;
        }

    .split-function-ui .section-split {
        flex: 1;
        display: none;
        min-width: unset;
        max-width: unset;
        border: 1px solid var(--bs-gray-400);
        border-radius: 8px;
    }

        .split-function-ui .section-split.active {
            display: flex;
            flex-direction: column;
            gap: var(--px-12);
        }

        .split-function-ui .section-split.auto-section {
            border: 0;
        }

    .split-function-ui table {
        width: 100%;
        border-collapse: collapse;
    }

    .split-function-ui th, .split-function-ui td {
        text-align: left;
        padding: var(--px-8) 0;
        font: var(--s-14);
    }

    .split-function-ui th {
        font-weight: 600;
        color: #666;
    }

    .split-function-ui td input {
        width: var(--px-80);
        padding: var(--px-4) var(--px-8);
        border: 1px solid var(--bs-gray-300);
        border-radius: 4px;
        text-align: right;
        font: normal normal 400 var(--s-14);
    }

    .split-function-ui .icon-btn {
        background: none;
        border: none;
        cursor: pointer;
        font-size: var(--px-16);
        margin-left: var(--px-4);
        color: #c0392b;
    }

        .split-function-ui .icon-btn.add {
            color: #2980b9;
        }

    .split-function-ui .auto-split-controls {
        display: flex;
        gap: var(--px-12);
        flex-direction: column;
        align-items: flex-start;
        font: normal normal 500 var(--s-16);
    }

        .split-function-ui .auto-split-controls input {
            width: var(--px-140);
            text-align: center;
            padding: var(--px-8);
            border: 1px solid var(--bs-gray-400);
            border-radius: 6px;
            font: normal normal 400 var(--s-16);
        }

    .split-function-ui .btn-apply {
        background: var(--bs-main-400);
        color: white;
    }

    .split-function-ui .auto-note {
        font: normal normal 400 var(--s-14);
        margin: var(--px-16) 0;
    }

    .split-function-ui textarea {
        width: 100%;
        border: 1px solid #ccc;
        border-radius: 6px;
        padding: var(--px-12);
        resize: none;
        font: normal normal 400 var(--s-14);
        height: var(--px-68);
        margin-bottom: var(--px-16);
    }

    .split-function-ui .totals-split {
        font: normal normal 500 var(--s-16);
        line-height: var(--px-32);
    }

        .split-function-ui .totals-split span {
            float: right;
            font-weight: 600;
        }

        .split-function-ui .totals-split .remaining span {
            color: var(--bs-orange);
        }

.group-action-button-form {
    display: flex;
    justify-content: flex-end;
    gap: var(--px-8);
    flex-direction: row;
}

    .group-action-button-form .btn {
        padding: var(--px-8) var(--px-16);
        border-radius: 6px;
        border: none;
        font: normal normal 500 var(--s-14);
        font-weight: 500;
        cursor: pointer;
        display: flex;
        gap: 12px;
    }

        .group-action-button-form .btn.cancel {
            background: 0;
            color: var(--bs-gray-700);
        }

        .group-action-button-form .btn.primary {
            background-color: var(--bs-main);
            color: #fff;
        }

        .group-action-button-form .btn span {
            color: white;
            font: normal normal 500 var(--s-14);
        }

        .group-action-button-form .btn.cancel span {
            color: var(--bs-gray-700);
            font-weight: 400;
        }

.edit-guest-body {
    flex: 1;
    display: flex;
    flex-direction: column;
    padding: var(--px-16);
    gap: var(--px-16);
}

    .edit-guest-body .section-title {
        font: normal normal 500 var(--s-16);
        margin: 0;
        padding: 0;
    }

    .edit-guest-body .guest-type-wrapper {
        display: flex;
        gap: 12px;
        width: 100%;
        align-items: center;
    }

    .edit-guest-body .guest-type-btn {
        flex: 1;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 6px;
        padding: 8px 0;
        border: 1.6px solid #d8d8d8;
        border-radius: 8px;
        font-size: 14px;
        cursor: pointer;
        transition: 0.2s;
        background: #fff;
    }

.guest-type-btn.active {
    border-color: var(--bs-main-400);
    background: var(--bs-main-50);
    color: var(--bs-main-500);
    font-weight: 500;
}

.edit-guest-body .guest-type-btn svg {
    height: var(--px-20);
    width: var(--px-20);
}

.edit-guest-body .guest-type-btn span {
}

.edit-guest-body .form-group {
    background: var(--bg-num-availble);
}

.popup-footer {
    display: flex;
    -webkit-justify-content: end;
    justify-content: end;
    padding: var(--px-16);
}

.edit-guest-body .btn-save-guest {
}

/* === Base structure === */
.special-form-body {
    display: flex;
    flex: 1;
    overflow: hidden;
    border-bottom: 1px solid var(--bs-gray-300);
    width: var(--px-800);
}

/* === Search section === */
.special-search {
    flex: 1;
    display: flex;
    gap: var(--px-12);
    overflow: hidden;
    flex-direction: column;
    max-width: var(--px-320);
    border-right: 6px solid var(--bs-gray-200);
}

    .special-search .search-form {
        padding: var(--px-12);
        background: white;
        margin: var(--px-12);
    }

.search-form i {
}

.search-form input {
}

.list-special-service {
    display: flex;
    flex-direction: column;
    gap: 12px;
    flex: 1;
    border-radius: 6px;
    overflow: auto;
    padding: 2px var(--px-12) var(--px-12);
}

.item-special-search {
    background: var(--bs-white);
    border-radius: 8px;
    padding: var(--px-12);
    border: 1px solid var(--bs-gray-300);
    display: flex;
    flex-direction: column;
    gap: 8px;
    cursor: pointer;
}

    .item-special-search:hover {
        box-shadow: var(--shadow-h);
    }

    .item-special-search.selected {
        box-shadow: var(--shadow-h);
        outline: 1px solid var(--bs-main);
    }

    .item-special-search .special-col {
        display: flex;
        align-items: center;
        gap: 4px;
        font: normal normal 400 var(--s-14);
    }

        .item-special-search .special-col:last-of-type {
            justify-content: end;
        }

    .item-special-search .badge-pms {
        padding: 4px var(--px-12);
        background: var(--bs-gray-100);
        color: var(--bs-gray-700);
        border-radius: 4px;
        font-size: 12px;
        font-weight: 700;
        border: 1px solid var(--bs-gray-300);
    }

    .item-special-search .special-name {
    }

    .item-special-search strong {
    }

    .item-special-search .currency-text {
    }

/* === Selected services section === */
.special-selected-services {
    flex: 1;
    overflow: auto;
}

.validation-msg {
    padding: 0 var(--px-16);
}

.header-special-selected {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--px-12);
    border-bottom: 1px solid var(--bs-gray-400);
}

.name-selected {
    display: flex;
    flex-direction: column;
    gap: 8px;
    font: normal normal 400 var(--s-14);
    color: var(--bs-gray-700);
}

    .name-selected p.selected-description {
        color: var(--bs-gray-900);
        font: normal normal 600 var(--s-16);
    }

    .name-selected .stay-date {
        display: flex;
        align-items: center;
        gap: 8px;
    }

.header-special-selected .badge-pms {
    color: var(--bs-main);
    font: normal normal 600 var(--s-20);
}

    .header-special-selected .badge-pms.selected-code {
        width: max-content;
        padding: 4px var(--px-12);
        background: var(--bs-gray-100);
        color: var(--bs-gray-700);
        border-radius: 4px;
        border: 1px solid var(--bs-gray-300);
        font: normal normal 600 var(--s-12);
    }

.special-selected-services .form-group.form--popup {
    grid-template-columns: repeat(6, 1fr);
    border: 0;
}

.special-selected-services .form--input.option {
    display: flex;
    align-items: center;
    flex-direction: row;
}

.special-selected-services .form--input.grid-3 {
}

.special-selected-services .form--input label {
}

.special-selected-services .form--input input {
}

.special-selected-services .total {
    display: flex;
    padding: var(--px-12);
    border: 1px solid var(--bs-main-200);
    border-radius: 8px;
    background: var(--bs-main-50);
    font: normal normal 500 var(--s-16);
    margin: var(--px-12);
}

    .special-selected-services .total strong {
        margin-left: 4px;
    }

.special-selected-services .options {
    display: flex;
    gap: var(--px-12);
    align-items: center;
    padding: var(--px-12);
}

    .special-selected-services .options .toggle {
    }

        .special-selected-services .options .toggle input {
        }

.special-selected-services .notes {
    gap: 8px;
    display: flex;
    flex-direction: column;
    padding: var(--px-12);
}

    .special-selected-services .notes label {
        font: normal normal 600 var(--s-14);
    }

    .special-selected-services .notes textarea {
        border: 1px solid var(--bs-gray-300);
        border-radius: 8px;
        padding: var(--px-8) var(--px-12);
        font: normal normal 400 var(--s-14);
        min-height: var(--px-88);
    }

.special-selected-services .add-btn {
    width: -webkit-fill-available;
    margin: var(--px-12);
    background: white;
    color: var(--bs-main);
    font: normal normal 600 var(--s-14);
    border: 2px dashed var(--bs-gray-300);
}

.special-selected-services .group-name-code {
    display: flex;
    align-items: center;
    gap: 4px;
}

/* === Responsive or state modifiers (if needed) === */
.is-active {
}

.is-disabled {
}

.is-hidden {
}

.popup-container.reservation-edit-guest,
.popup-container.reservation-add-special,
.popup-container.reservation-extra-beds {
    right: var(--px-710) !important
}

.header-toggle {
    display: flex;
    align-items: center;
    flex-direction: row;
    justify-content: space-between;
}

.btn-collapse-form {
    background: none;
    border: none;
    cursor: pointer;
    font-size: var(--px-16);
    color: var(--text-color);
    border-radius: 8px;
}

    .btn-collapse-form:hover {
        background: var(--bs-gray-100);
    }

.meal-code-setting {
    display: grid;
    align-items: center;
    grid-template-columns: repeat(12, 1fr);
    border-radius: 8px;
    padding: 8px 8px 8px 0;
    border: 1px solid var(--bs-gray-300);
}

    .meal-code-setting .form--input {
        flex-direction: row;
        align-items: center;
        grid-column: span 3;
        margin-left: var(--px-8);
    }

    .meal-code-setting .dropdown {
        grid-column: span 5;
    }

    .meal-code-setting .container--checkbox {
        grid-column: span 1;
        margin: auto;
        cursor: pointer;
        pointer-events: all;
    }

    .meal-code-setting.unchecked .disable-when-unchecked {
        opacity: .4;
        pointer-events: none;
    }

.option-input-roomtype .title-o {
    display: grid;
    grid-template-columns: var(--px-28) 1fr;
    align-items: center;
}

    .option-input-roomtype .title-o svg {
        height: var(--px-20);
        width: var(--px-20);
        color: var(--bs-gray-500);
    }

    .option-input-roomtype .title-o i {
        font-size: var(--px-16);
        color: var(--bs-gray-500);
    }

    .option-input-roomtype .title-o span {
        color: var(--bs-gray-900);
    }

.option-input-roomtype .adjust-quantity {
}

.group-info-rt {
    gap: 12px;
    display: grid;
    align-items: center;
    padding: 4px var(--px-12);
    border-radius: var(--px-8);
    border: 2px dashed var(--bs-gray-300);
}

.group-btn-rt {
    width: 100%;
    display: flex;
    align-items: center;
    padding: 12px 0 0;
    border-top: 1px solid var(--bs-gray-400);
}

    .group-btn-rt button {
        color: white;
        border: 1px solid var(--bs-gray-300);
        font: normal normal 600 var(--s-14);
        margin-left: auto;
        background: var(--bs-main);
    }

.info-r {
    gap: 4px;
    display: flex;
    align-items: center;
    cursor: pointer;
    position: absolute;
    top: calc(-1 * var(--px-12) - 2px);
}

button.change-roomtype {
    background: white;
    border: 1px solid var(--bs-gray-300);
    color: black;
    height: var(--px-28);
    gap: 4px;
    padding: 0 6px;
    font: normal normal 500 var(--s-10);
}

    button.change-roomtype i {
        font-size: 14px !important;
        font-weight: 400;
        color: var(--bs-main) !important;
    }

.option-input-roomtype.add-rate-room .title-o {
    display: flex;
    gap: 12px;
}

.option-input-roomtype.add-rate-room input {
    text-align: end;
}

.option-input-roomtype.add-rate-room .container--checkbox {
    pointer-events: all;
    cursor: pointer;
}

.form--input input[readonly][name="inp-rate-amount"] {
    background: var(--bs-gray-200);
    border: 1px solid var(--bs-gray-300);
    padding: var(--px-12) var(--px-16);
}

.group-check-amount {
    gap: 4px;
    display: flex;
    flex-direction: row;
    align-items: center;
    border-radius: 8px;
    padding: 4px;
    border: 1px solid var(--bs-gray-300);
}

    .group-check-amount.disabled input {
        opacity: .4;
        pointer-events: none;
    }

.label-required {
    position: relative;
}

    .label-required::after {
        display: inline-block;
        margin-inline-end: 4px;
        color: #ff4d4f;
        font-size: 14px;
        font-family: SimSun, sans-serif;
        line-height: 1;
        content: "*";
        margin-left: 2px;
    }

.btn-add-new-booking {
    background: var(--bs-main);
    color: white;
    font: normal normal 600 var(--s-14);
    border: none;
    padding: var(--px-12);
    border-radius: 6px;
    height: var(--px-40);
    border: 2px solid var(--bs-main-200);
}

.search-form input {
    background: 0 !important;
    border: 0;
    box-shadow: unset;
    padding: 0;
}

.form-advance-input {
}

    /* Existing */
    .form-advance-input .advance-input-body {
        box-sizing: border-box;
        border-radius: 0 0 8px 8px;
        box-shadow: rgba(0, 0, 0, 0.133) 0px 13.4px 14.4px 0px, rgba(0, 0, 0, 0.11) 0px 5.2px 3.6px 0px;
        position: absolute;
        background: white;
        z-index: 10;
        top: var(--px-68);
        width: -webkit-fill-available;
        /* overflow: hidden; */
        display: none;
        max-height: var(--px-440);
    }

    /* Remove (or keep harmless) focus-only visibility */
    .form-advance-input:focus-within .advance-input-body {
        display: flex;
        flex-direction: column;
        gap: 12px;
    }

    /* New: persistent open state */
    .form-advance-input.open .advance-input-body {
        gap: 0;
        display: flex;
        flex-direction: column;
        border: 1px solid var(--bs-main-300);
        border-top: 0;
        overflow: hidden;
    }

    /* Optional: keep open while hovering list (if you keep :focus-within) */
    .form-advance-input .advance-input-body:hover {
        display: flex;
        flex-direction: column;
        cursor: pointer;
    }

    .form-advance-input .fdc-table.no-mw {
        padding: 8px;
        padding-top: 0;
    }

.form-extrabed-section .fdc-table.no-mw .extrabed-row:hover {
    cursor: pointer;
    background: var(--bs-gray-100);
}

/* Make rows look clickable */
#fdc-advance-body tr.fdc-booker-row {
    cursor: pointer;
    transition: background .15s;
}

    #fdc-advance-body tr.fdc-booker-row:hover {
        background: var(--bs-gray-100);
    }

.advance-input-body .form--input label {
    pointer-events: all;
}

.section-table-append {
    display: flex;
    flex-direction: column;
    overflow: auto;
}

    .section-table-append.max-h {
        min-height: var(--px-200);
        max-height: var(--px-200);
    }

.highlight-opt {
    display: flex;
    flex-direction: row;
    align-items: center;
    border-radius: 8px;
    padding: 12px 8px;
    border: 1px solid var(--bs-opacity);
}

    .highlight-opt .form--input.option {
        align-items: flex-start !important;
        gap: 4px;
    }

        .highlight-opt .form--input.option label {
            color: var(--bs-gray-900);
            min-width: var(--px-32);
        }

        .highlight-opt .form--input.option p {
            color: var(--bs-gray-600);
        }

    .highlight-opt.no-em {
        border: 1px solid var(--bs-gray-200);
    }

    .highlight-opt.have-bg {
        border: 0;
        background: var(--secondary-color);
    }

.checkbox-desc {
    gap: 8px;
    display: flex;
    flex-direction: column;
}

.section-body-popup {
    display: flex;
    flex-direction: column;
    gap: var(--px-16);
    padding: var(--px-16);
    flex: 1;
    overflow: auto;
    position: relative;
}

.section-center-icon {
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 100%;
    width: var(--px-48);
    min-height: var(--px-48);
    background: var(--bs-main);
    box-shadow: var(--shadow-qs-solid);
    position: absolute;
    bottom: calc(-1 * var(--px-32));
    left: 50%;
    transform: translateX(-50%);
    border: 4px solid white;
    outline: 1px solid var( --bs-gray-300);
    z-index: 1;
}

    .section-center-icon i {
        font-size: var(--px-16);
        color: white;
        font-weight: 500;
    }

.section-split.auto-section {
}

.section-split .auto-split-row {
    display: flex;
    gap: var(--px-12);
    align-items: center;
    min-height: var(--px-60);
    border: 1px solid var(--bs-gray-300);
    border-radius: 8px;
    padding: 8px;
}

    .section-split .auto-split-row .auto-label {
        flex: 1;
        font: normal normal 400 var(--s-14);
    }

    .section-split .auto-split-row .auto-part {
        background: var(--bs-main-50);
        border: 1px solid var(--bs-main-200);
        padding: 4px 8px;
        border-radius: 999px;
        font-size: 12px;
    }

    .section-split .auto-split-row .auto-value {
        font: normal normal 600 var(--s-16);
    }

#auto-split-preview {
    display: grid;
    gap: 12px;
    grid-template-columns: 1fr 1fr;
}


.void-preview-list {
    display: grid;
    grid-template-columns: 1fr;
    border-radius: 8px;
    overflow: hidden;
}

.void-row {
    display: grid;
    grid-template-columns: var(--px-100) 1fr 1fr 120px;
    align-items: center;
    gap: 12px;
    padding: 12px 20px;
    border-bottom: 1px solid var( --bs-gray-300);
    background: var( --secondary-color);
    transition: background 0.15s ease;
}

    .void-row:hover {
        background: var(--row-hover);
    }

.void-code {
    font-weight: 600;
    color: var(--accent);
    background: var(--badge-bg);
    border-radius: 8px;
    padding: 4px 8px;
    border: 1px solid var(--border);
}

.void-info {
    color: var(--muted);
    font-weight: 500;
}

.void-comment {
    color: var(--text);
    opacity: 0.9;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.void-amount {
    text-align: right;
    font-weight: 700;
    color: var(--amount-text);
    background: var(--amount-bg);
    border-radius: 8px;
    padding: 6px 10px;
    border: 1px solid var(--border);
    min-width: 80px;
}

.grid-t-3 {
    grid-template-columns: 1fr 1fr 1fr;
}

.subcode-row {
    display: flex;
    flex-direction: column;
    gap: 8px;
    color: var(--bs-gray-900);
    font: normal normal 500 var(--s-14);
}

    .subcode-row span {
        color: var(--bs-gray-600);
        font: normal normal 400 var(--s-12);
    }

.misssing-field {
    color: var(--bs-gray-700);
    font: normal normal 400 var(--s-12);
}

    .misssing-field strong {
        color: #ff6b7a;
    }

.titl-form.titl-missing {
    gap: 4px;
    display: flex;
    flex-direction: column;
}

.rate-config-container {
    display: flex;
    flex-direction: column;
    padding: 12px;
    border-radius: 8px;
    gap: 12px;
}

    .rate-config-container.have-value {
        /* background: var(--bg-num-availble); */
    }

.rate-config-form {
    padding: 12px;
    background: var(--secondary-color);
    border-radius: 8px;
    /* border: 1px solid var(--bs-gray-300); */
}

    .rate-config-form .section-room-rate {
        border: 0;
        position: relative;
        /* border-bottom: 1px dashed var(--bs-gray-400); */
        padding-bottom: 12px;
    }


    .rate-config-form .form--input.option {
        display: flex;
        flex-direction: row;
        align-items: center;
    }

    .rate-config-form .container--checkbox {
        pointer-events: all;
    }

.rate-summary {
    display: grid;
    grid-gap: 12px;
    grid-template-columns: 1fr 1fr 1fr;
}

    .rate-summary .rate-line {
        font: normal normal 600 var(--s-14);
        display: flex;
        flex-direction: column;
        gap: 4px;
    }

        .rate-summary .rate-line span.label {
            font-weight: 400;
            color: var(--bs-gray-600);
        }

    .rate-summary .rate-breakdown-table-wrapper {
        grid-column: span 3;
    }

.group-btn-end {
    display: flex;
    justify-content: flex-end;
    gap: var(--px-8);
}

.form-group form--popup.mw-1200 {
    max-width: var(--px-1200);
}

.rate-breakdown-toggle {
    display: flex;
    flex-direction: row;
    align-items: center;
    border: 1px solid var(--bs-gray-300);
    border-radius: 6px;
    padding: 4px;
    min-width: var(--px-96);
    justify-content: space-between;
}

.btn-open-rate-breakdown {
    height: var(--px-28);
    padding: 0px 20px;
    background: white;
    color: var(--bs-gray-900);
    border: 1px solid var(--bs-gray-400);
    border-radius: 6px;
    padding: 6px;
    width: var(--px-32);
}

.rate-breakdown-popup {
    max-width: 98vw;
    overflow: auto;
}

    .rate-breakdown-popup .section-table-append {
        overflow: unset;
        flex: 1;
    }


        .rate-breakdown-popup .section-table-append .date-range {
            display: flex;
            gap: 4px;
            align-items: center;
            min-width: var(--px-120);
        }

    .rate-breakdown-popup .rule-end-label {
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        min-width: var(--px-64);
    }

.group-action-button-form .btn {
    border: 1px solid var(--bs-gray-300);
}

.group-action-button-form .rule-delete {
    color: var(--bs-red);
    border: 0;
}

.total-dis-rate {
    /* flex: 1; */
    gap: 8px;
    justify-content: space-between;
    display: flex;
    padding: var(--px-12);
    border: 1px solid var(--bs-main-200);
    border-radius: 8px;
    background: var(--bs-main-50);
    font: normal normal 500 var(--s-16);
}

/* Rate Breakdown Compact */
.rate-breakdown-compact {
    display: flex;
    flex-direction: column;
    gap: var(--px-16);
    padding: var(--px-16);
    background: var(--bs-gray-50,#f9fafb);
    border: 1px solid var(--bs-gray-300);
    border-radius: 8px;
    font-size: var(--px-12);
    line-height: 1.4;
    position: relative;
    width: 100%;
}

    .rate-breakdown-compact.clean {
        background: linear-gradient(#fdfdfd,#f7f9fa);
    }

    .rate-breakdown-compact .rbc-head {
        display: flex;
        align-items: center;
        gap: 12px;
        font-weight: 500;
        flex-wrap: wrap;
        justify-content: flex-start;
    }

        .rate-breakdown-compact .rbc-head i {
            color: var(--bs-main-500,#2563eb);
            font-size: 16px;
        }

.rbc-title {
    font-size: 14px;
    font-weight: 600;
    letter-spacing: .3px;
}

.rbc-nights {
    padding: 2px 8px;
    background: var(--bs-gray-100,#f3f4f6);
    border: 1px solid var(--bs-gray-200,#e5e7eb);
    border-radius: 12px;
    font-size: 12px;
    font-weight: 500;
}

.rbc-code.badge-pms {
    background: var(--bs-main-100,#dbeafe);
    color: var(--bs-main-600,#1d4ed8);
    border: 1px solid var(--bs-main-200,#bfdbfe);
    font-weight: 600;
    padding: 2px 8px;
    border-radius: 14px;
}

/* Chips */
.rbc-chips {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    justify-content: space-between;
}

.rbc-room-group {
    display: flex;
    gap: 6px;
    flex-direction: column;
}

.rbc-room-chips {
    display: flex;
    gap: 8px;
}

.rbc-room-total {
    font-weight: 600;
}

.rbc-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 10px;
    background: var(--bs-gray-100,#f3f4f6);
    border: 1px solid var(--bs-gray-200,#e5e7eb);
    border-radius: 16px;
    font-size: 12px;
    white-space: nowrap;
    max-width: 100%;
    width: max-content;
}

    .rbc-chip i {
        font-size: 13px;
        color: var(--bs-gray-500,#6b7280);
    }

    .rbc-chip em {
        font-style: normal;
        font-weight: 600;
        color: var(--bs-main-600,#1d4ed8);
        margin-left: 4px;
    }

/* Totals Row */
.rbc-total-row {
    display: flex;
    gap: 20px;
    align-items: center;
    justify-content: end;
    border-top: 2px solid var(--bs-gray-300);
    padding-top: 12px;
}

.rbc-total-col {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.rbc-label {
    font-size: 11px;
    text-transform: uppercase;
    color: var(--bs-gray-600);
    font-weight: 400;
    text-align: end;
}

.rbc-total-col .form--input {
    margin: 0;
    align-items: start;
}

.rbc-total-col input {
    padding: 6px 10px;
    font-size: 16px;
    background: 0 !important;
    border: 0 !important;
    border-radius: 6px;
    font-weight: 600;
    color: var(--bs-gray-900);
    text-align: end;
    opacity: 1 !important;
    max-width: var(--px-160);
}

/* Flags */
.rbc-flags {
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    padding-top: 2px;
}

.rbc-flag {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: .3px;
    padding: 6px 10px;
    border-radius: 16px;
    border: 1px solid var(--bs-gray-200,#e5e7eb);
    background: var(--bs-gray-100,#f3f4f6);
    color: var(--bs-gray-600,#4b5563);
}

    .rbc-flag.on {
        background: var(--bs-main-50,#eff6ff);
        border-color: var(--bs-main-200,#bfdbfe);
        color: var(--bs-main-700,#1d4ed8);
    }

    .rbc-flag.off {
        opacity: .6;
    }

    .rbc-flag i {
        font-size: 14px;
    }

/* Hover / focus states */
.rbc-chip:hover {
    background: #fff;
    border-color: var(--bs-gray-300,#d1d5db);
}

.rbc-flag.on:hover {
    background: var(--bs-main-100,#dbeafe);
}

/* Responsive */
@media (max-width:640px) {
    .rate-breakdown-compact {
        padding: 12px 12px;
    }

    .rbc-total-row {
        grid-template-columns: 1fr 1fr;
    }

    .rbc-flags {
        grid-column: 1 / -1;
        margin-top: 4px;
    }
}

.discount-cell {
    gap: 4px;
    display: flex;
    align-items: center;
    flex-direction: row-reverse;
    border: 1px solid var(--bs-gray-300);
    padding: 2px;
    border-radius: 8px;
    background: var(--bg-main);
}

    .discount-cell .discount-type-toggle {
        display: flex;
        align-items: center;
        border-radius: 8px;
        background: var(--bs-white);
        padding: 2px;
        /* border: 1px solid var(--bs-gray-300); */
    }

.discount-type-toggle .btn-outline-dark {
    background: white;
    color: black;
    border: 0;
    box-shadow: unset !important;
    padding: 4px 12px;
}

    .discount-type-toggle .btn-outline-dark.active {
        color: var(--bs-white);
        border-radius: 6px;
        background: var(--bs-main-200);
        color: var(--bs-main-700);
    }

.discount-cell input {
    min-width: var(--px-44);
}

.section-item-room-generate {
    gap: 12px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

    .section-item-room-generate:not(:last-of-type) {
    }

.room-breakdown-block {
    display: flex;
    gap: var(--px-12);
    flex-direction: column;
    padding: 12px;
    border-radius: 8px;
    box-shadow: var(--shadow-h);
    border: 1px solid var(--bs-gray-200);
    width: max-content;
    flex: 1;
}

.room-block-header {
    display: flex;
    align-items: center;
    flex-direction: row;
    justify-content: space-between;
}

.titl-form {
    font: normal normal 600 var(--s-16);
}

.preview-group-button-detail {
    gap: 8px;
    display: flex;
    align-items: center;
    justify-content: end;
}

    .preview-group-button-detail button {
        flex: 1;
        background: white;
        color: black;
        font: normal normal 500 var(--s-14);
        border: 1px solid var(--bs-gray-300);
        min-height: var(--px-36);
    }

        .preview-group-button-detail button.btn-registraion-card i {
            color: var(--bs-main);
        }

        .preview-group-button-detail button.btn-guest-confirmation i {
            color: var(--bs-orange);
        }

.print-registration-card {
    width: var(--px-800);
    max-width: var(--px-800);
    overflow: auto;
}

.group-btn-left-side-popup {
    display: flex;
    flex-direction: column;
    gap: var(--px-16);
    position: absolute;
    left: calc(var(--px-76) * -1);
    top: var(--px-4);
}

    .group-btn-left-side-popup .btn-left-side {
        display: flex;
        position: unset;
        background: white;
        box-shadow: 0 2px 20px #d1d1d1 !important;
        height: var(--px-60);
        width: var(--px-60);
        border-radius: var(--px-60);
        color: black;
        font-size: var(--px-16);
        flex-direction: column;
        gap: 4px;
        border: 1px solid var(--bs-gray-300);
    }

        .group-btn-left-side-popup .btn-left-side p {
            font-size: 10px;
            color: var(--bs-gray-600);
        }

        .group-btn-left-side-popup .btn-left-side.delete {
            color: var(--bs-red);
        }


.filter-empty-append {
    position: absolute;
    background: white;
    height: 100%;
    width: 100%;
    z-index: 9;
    padding: var(--px-24);
    --bg: #faf7eb;
    --card-bg: #ffffff;
    --border-soft: #f4e6be;
    --accent: #1ba049;
    --accent-soft: #e5f6eb;
    --text-main: #2c2c2c;
    --text-muted: #6b6b6b;
    --warning-bg: #fff8e6;
    --warning-border: #f3e0a4;
    --warning-text: #9a6a10;
    --shadow-soft: 0 18px 45px rgba(15, 23, 42, 0.08);
    --radius-lg: 18px;
    --radius-pill: 999px;
    display: flex;
    flex-direction: column;
    gap: 20px;
}

    .filter-empty-append .banner-warning {
        display: flex;
        align-items: center;
        gap: 8px;
        padding: 12px 16px;
        border-radius: 12px;
        /* background: var(--warning-bg); */
        border: 1px solid var(--bs-gray-300);
        color: var(--warning-text);
        font-size: 14px;
    }

    .filter-empty-append .banner-icon {
        width: 18px;
        height: 18px;
        border-radius: 999px;
        border: 1px solid rgba(250, 204, 21, 0.55);
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 11px;
        font-weight: 700;
    }

    .filter-empty-append .banner-text strong {
        font-weight: 600;
    }

    .filter-empty-append .empty-state {
        flex: 1;
        width: 100%;
        background: var(--card-bg);
        text-align: center;
        position: relative;
        overflow: hidden;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
    }

        .filter-empty-append .empty-state::before {
            content: '';
            position: absolute;
            inset: 0;
            background: radial-gradient(circle at top center, #fbfee8 0, transparent 52%);
            opacity: 0.9;
            pointer-events: none;
        }

    .filter-empty-append .empty-inner {
        position: relative;
        z-index: 1;
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 18px;
    }

    .filter-empty-append .icon-circle {
        width: 78px;
        height: 78px;
        border-radius: 999px;
        background: conic-gradient(from 200deg, var(--bs-main-50), var(--bs-main-100), var(--bs-main-200), var(--bs-main-50));
        display: flex;
        align-items: center;
        justify-content: center;
        box-shadow: 0 14px 30px rgb(127 173 73 / 23%);
        position: relative;
    }

        .filter-empty-append .icon-circle::after {
            content: '';
            position: absolute;
            inset: 11px;
            border-radius: inherit;
            background: #ffffff;
            box-shadow: inset 0 0 0 1px rgba(15, 23, 42, 0.04);
        }

        .filter-empty-append .icon-circle svg {
            position: relative;
            z-index: 1;
        }

            .filter-empty-append .icon-circle svg path {
                stroke: var(--bs-main);
            }

    .filter-empty-append .badge-floating {
        position: absolute;
        top: 18px;
        right: 24px;
        padding: 4px 10px;
        border-radius: var(--radius-pill);
        background: rgba(16, 185, 129, 0.08);
        border: 1px solid rgba(16, 185, 129, 0.35);
        color: #047857;
        font-size: 11px;
        display: flex;
        align-items: center;
        gap: 4px;
    }

    .filter-empty-append .badge-dot {
        width: 6px;
        height: 6px;
        border-radius: 999px;
        background: #16a34a;
        box-shadow: 0 0 0 4px rgba(34, 197, 94, 0.23);
    }

    .filter-empty-append .title {
        letter-spacing: 0.01em;
        font: normal normal 600 var(--s-20);
    }

    .filter-empty-append .subtitle {
        max-width: 360px;
        font: normal normal 400 var(--s-13);
    }

        .filter-empty-append .subtitle strong {
            color: #4b5563;
            font-weight: 600;
        }

    .filter-empty-append .hint-row {
        margin-top: 6px;
        display: flex;
        align-items: center;
        gap: 8px;
        font-size: 11px;
        color: #9ca3af;
    }

    .filter-empty-append .hint-pill {
        padding: 3px 9px;
        border-radius: 999px;
        background: rgba(148, 163, 184, 0.12);
        font-size: 11px;
        color: #6b7280;
    }

    .filter-empty-append .btn-primary {
        margin-top: 10px;
        padding: 9px 22px;
        border-radius: var(--radius-pill);
        border: none;
        outline: none;
        background: radial-gradient(circle at top left, var(--bs-main-300), var(--bs-main-400) 48%, var(--bs-main-500) 100%);
        color: #f9fafb;
        font-size: 14px;
        font-weight: 600;
        letter-spacing: 0.02em;
        display: inline-flex;
        align-items: center;
        gap: 8px;
        cursor: pointer;
        box-shadow: 0 14px 30px rgb(235 255 209);
        transition: transform 0.12s ease-out, box-shadow 0.12s ease-out, filter 0.12s ease-out;
        font: normal normal 600 var(--s-14);
    }

        .filter-empty-append .btn-primary span.icon {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            width: 18px;
            height: 18px;
            border-radius: 999px;
            background: rgba(15, 23, 42, 0.13);
            font-size: 12px;
        }

        .filter-empty-append .btn-primary:hover {
            transform: translateY(-1px);
            filter: brightness(1.04);
            box-shadow: 0 18px 38px rgb(68 128 21 / 42%);
        }

        .filter-empty-append .btn-primary:active {
            transform: translateY(0);
            box-shadow: 0 10px 24px rgba(21, 128, 61, 0.32);
        }

.footer-hint {
    margin-top: 18px;
    padding-top: 12px;
    border-top: 1px dashed rgba(209, 213, 219, 0.8);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    font-size: 11px;
    color: #9ca3af;
}

.footer-pill {
    padding: 4px 9px;
    border-radius: 999px;
    background: rgba(148, 163, 184, 0.15);
}

.footer-hotkey {
    padding: 2px 7px;
    border-radius: 6px;
    border: 1px solid rgba(148, 163, 184, 0.8);
    font-size: 10px;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono', 'Courier New', monospace;
    background: rgba(249, 250, 251, 0.8);
}

.advance-filter-search {
    gap: var(--px-16);
    width: 100%;
    display: grid;
    align-items: center;
    grid-template-columns: repeat(6, 1fr);
    background: #f7f6f9;
    padding: var(--px-16);
    border-radius: 8px;
    border: 1px solid var(--bs-gray-300);
}

    .advance-filter-search .form--input {
        grid-column: span 1;
    }

    .advance-filter-search .group-adv-btn {
        display: flex;
        gap: var(--px-8);
        align-items: end;
        justify-content: flex-end;
        flex-direction: row;
    }

    .advance-filter-search .btn-adv-filter {
        font: normal normal 400 var(--s-14);
        padding: 0 16px;
    }

        .advance-filter-search .btn-adv-filter.clear {
            background: white;
            color: var(--bs-gray-800);
            border: 1px solid var(--bs-gray-200);
        }

        .advance-filter-search .btn-adv-filter.cancel {
            background: white;
            color: var(--bs-gray-800);
            border: 1px solid var(--bs-gray-200);
        }

    .advance-filter-search .grid-title {
        grid-column: span 6;
        display: flex;
        flex-direction: row;
        align-items: center;
        justify-content: space-between
    }

        .advance-filter-search .grid-title label {
            font: normal normal 500 var(--s-18);
        }

.filter-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: #f3f4f6;
    border: 1px solid var(--bs-gray-300);
    border-radius: 8px;
    padding: 0px 12px;
    padding-right: 0;
    font: normal normal 500 var(--s-12);
}

    .filter-chip .chip-remove {
        background: none;
        border: none;
        cursor: pointer;
        color: #111;
        margin: 0;
    }

.lst-chip-filter-append {
    display: flex;
    align-items: center;
    gap: 12px;
}

.no-filters-applied {
    font: normal normal 400 var(--s-14);
    color: var(--bs-gray-700);
}

.popup-container.payment-confirm,
.popup-container.registration-card,
.popup-container.booking-confirm {
    left: 50% !important;
    transform: translateX(-50%);
    right: unset !important;
}

.rate-edit-row {
    display: grid;
    grid-template-columns: repeat(18, 1fr);
    grid-gap: var(--px-12);
}

    .rate-edit-row.disabled {
        opacity: .5;
        pointer-events: none;
    }

    .rate-edit-row .dropdown:not(.no-style) {
        grid-column: span 6;
    }

    .rate-edit-row .form--input {
        display: flex;
        align-items: center;
        flex-direction: row;
    }

    .rate-edit-row .fa-dollar-sign {
        color: var(--bs-gray-600);
    }

.rate-breakdown-toggle span {
    flex: 1;
}

.dropdown:not(.no-style).dropdown-room-number {
    max-width: max-content;
    height: var(--px-32);
    border-color: var(--bs-gray-400);
    border-radius: 6px;
    min-width: var(--px-168);
}

    .dropdown:not(.no-style).dropdown-room-number .dropdown-toggle {
    }

    .dropdown:not(.no-style).dropdown-room-number i {
        font-size: 14px;
    }

.group-filter-navbar {
    display: flex;
    align-items: center;
    gap: 6px;
    flex: 1;
    justify-content: flex-end;
}

.fdc-advance-filter {
    display: flex;
    align-items: center;
    gap: 8px;
    border: 1px solid var(--bs-gray-300);
    background: #f7f6f9;
    border-radius: 8px;
}

.fdc-filter-select {
    flex: 1;
    display: flex;
    align-items: center;
    gap: 8px;
    border: 0;
    background: 0;
    padding: 0;
    margin: 6px;
    margin-right: 0;
}

    .fdc-filter-select::-webkit-scrollbar {
        display: none;
    }

.fdc-filter-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 6px;
    margin-left: 0;
}

.form-append-room-type {
    display: flex;
    flex-direction: column;
}

.detail-selected-rooms {
    display: flex;
    flex-direction: column;
}

.item-roomtype-select {
    display: grid;
    gap: 12px;
    padding: var(--px-12) var(--px-8);
    border-bottom: 1px solid var(--bs-gray-300);
    align-items: center;
    grid-template-columns: 1fr var(--px-56) repeat(2, var(--px-124)) repeat(3, var(--px-80)) var(--px-120) var(--px-88) var(--px-100);
}

    .item-roomtype-select .flex-1 {
        grid-column: initial !important;
    }

    .item-roomtype-select.header {
        position: sticky;
        top: 0;
        z-index: 123;
        background: white;
        background: var(--bg-num-availble);
    }

        .item-roomtype-select.header strong {
            color: var(--fdc-text);
            font: normal normal 600 var(--s-12);
        }

    .item-roomtype-select.out-of-room {
        opacity: .5;
    }

    .item-roomtype-select.selecting-roomtype {
        background: var(--bs-main-50);
    }

        .item-roomtype-select.selecting-roomtype.out-of-room {
            opacity: 1;
            background: rgb(255 240 241);
            border-top: 1px solid var(--bs-gray-300);
        }

    .item-roomtype-select .info-basic-roomtype {
    }

    .item-roomtype-select .more-info-rt {
        text-align: center;
        font: normal normal 400 var(--s-14);
    }

    .item-roomtype-select .roomtype-name {
        gap: 4px;
        display: flex;
        flex-direction: column;
    }

        .item-roomtype-select .roomtype-name .code {
            padding: 2px var(--px-8);
            background: var(--bs-gray-100);
            color: var(--bs-gray-700);
            border-radius: 4px;
            font-size: 10px;
            font-weight: 700;
            border: 1px solid var(--bs-gray-300);
            width: fit-content;
        }

        .item-roomtype-select .roomtype-name .name {
            font: normal normal 500 var(--s-12);
        }

    .item-roomtype-select .option-input-roomtype {
        font: normal normal 400 var(--s-14);
    }

    .item-roomtype-select.collapsed {
        max-height: var(--px-116);
        overflow: hidden;
        min-height: var(--px-64);
        border-top: 1px solid var(--bs-gray-300);
        border-bottom: 1px solid var(--bs-gray-300);
    }

/* Keyboard positional hints — light tone, compact typography, subtle animations */
@keyframes kbHintFadeUp {
    from {
        opacity: 0;
        transform: translateY(4px) scale(.98);
    }

    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

/*.kb-pos-hint {
    position: absolute;
    background: #ffffff;
    color: #1f2937;*/ /* slate-800 */
/*border: 1px solid #e5e7eb;*/ /* gray-200 */
/*border-radius: 8px;
    padding: 6px 8px;
    font-size: 11px;*/ /* smaller text */
/*line-height: 1.2;
    box-shadow: 0 8px 24px rgba(0,0,0,.10);
    white-space: nowrap;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    backdrop-filter: saturate(120%) blur(2px);
    animation: kbHintFadeUp .16s ease-out;
    transition: transform .15s ease, box-shadow .15s ease, opacity .15s ease;
}

    .kb-pos-hint:hover {
        transform: translateY(-1px);
        box-shadow: 0 12px 28px rgba(0,0,0,.12);
    }*/

/* Key chips inside the hint */
/*.kb-pos-hint .kb-chip {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        padding: 2px 8px;
        border: 1px solid #e5e7eb;
        border-bottom-width: 2px;
        background: #f9fafb;*/ /* gray-50 */
/*border-radius: 6px;
        font-weight: 600;
        font-size: 10px;*/ /* slightly smaller */
/*color: #111827;*/ /* gray-900 */
/*min-width: 28px;
    }

    .kb-pos-hint .kb-plus {
        color: #94a3b8;*/ /* slate-400 */
/*font-size: 10px;
        margin: 0 4px;
    }*/

/* Optional: nudge placement when near viewport edge */
/*.kb-pos-hint.edge-bottom {
        transform-origin: top center;
    }

    .kb-pos-hint.edge-top {
        transform-origin: bottom center;
    }

    .kb-pos-hint span:first-of-type,
    .kb-pos-hint span:last-of-type
    {
        padding: 2px 7px;
        border-radius: 6px;
        border: 1px solid rgba(148, 163, 184, 0.8);
        font-size: 10px;
        font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono', 'Courier New', monospace;
        background: rgba(249, 250, 251, 0.8);
    }*/
.kb-pos-hint {
    position: absolute;
    background: #2d2d2d; /* dark background */
    color: #e5e7eb; /* light gray text */
    border: 1px solid #444444; /* dark gray border */
    border-radius: 8px;
    padding: 6px 8px;
    font-size: 11px;
    line-height: 1.2;
    box-shadow: 0 8px 24px rgba(0,0,0,.40); /* darker shadow */
    white-space: nowrap;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    backdrop-filter: saturate(120%) blur(2px);
    animation: kbHintFadeUp .16s ease-out;
    transition: transform .15s ease, box-shadow .15s ease, opacity .15s ease;
}

    .kb-pos-hint:hover {
        transform: translateY(-1px);
        box-shadow: 0 12px 28px rgba(0,0,0,.50); /* stronger shadow on hover */
    }

    /* Key chips inside the hint */
    .kb-pos-hint .kb-chip {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        padding: 2px 8px;
        border: 1px solid #555555; /* darker border */
        border-bottom-width: 2px;
        background: #333333; /* dark background for chips */
        border-radius: 6px;
        font-weight: 600;
        font-size: 10px;
        color: #e5e7eb; /* light text on dark background */
        min-width: 28px;
    }

    .kb-pos-hint .kb-plus {
        color: #9ca3af; /* lighter gray for the plus icon */
        font-size: 10px;
        margin: 0 4px;
    }

    /* Optional: nudge placement when near viewport edge */
    .kb-pos-hint.edge-bottom {
        transform-origin: top center;
    }

    .kb-pos-hint.edge-top {
        transform-origin: bottom center;
    }

    .kb-pos-hint span:first-of-type,
    .kb-pos-hint span:last-of-type {
        padding: 2px 7px;
        border-radius: 6px;
        border: 1px solid rgba(148, 163, 184, 0.5); /* darker border */
        font-size: 10px;
        font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono', 'Courier New', monospace;
        background: rgba(33, 37, 41, 0.8); /* darkened background */
    }

.btn-add-guest-booking {
    width: -webkit-fill-available;
    background: 0;
    color: var(--bs-main);
    overflow: hidden;
    min-height: var(--px-40);
    flex: 1;
}
/* Add/override styles for redesigned client sidebar */
.client-sidebar .profile-card.redesign {
    border: 0;
    border-radius: 8px;
    padding: 24px 24px 20px;
    background: #ffffff;
    box-shadow: 0 6px 24px rgba(27, 43, 65, 0.06);
    border: 1px solid var(--bs-gray-300);
}

.client-sidebar .avatar-area {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.client-sidebar .avatar-circle {
    width: var(--px-140);
    height: var(--px-140);
    border-radius: 50%;
    border: 2px dashed var(--bs-gray-300);
    background: var(--bg-inp);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: #a8b3bf;
    gap: 8px;
    cursor: pointer;
    font: normal normal 500 var(--s-14);
    transition: border-color .2s ease, color .2s ease, background .2s ease;
}

    .client-sidebar .avatar-circle:hover {
        border-color: #bfc9d4;
        color: #8fa0b2;
        background: #eef1f4;
    }

    .client-sidebar .avatar-circle i {
        font-size: 20px;
    }

    .client-sidebar .avatar-circle img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        border-radius: 50%;
    }

.client-sidebar .avatar-title {
    text-align: center;
    margin-top: 16px;
}

    .client-sidebar .avatar-title h4 {
        margin: 0;
        font: normal normal 600 var(--s-16);
    }

    .client-sidebar .avatar-title p {
        margin: 4px 0 0;
        color: #6b7280;
        font: normal normal 400 var(--s-14);
    }

.client-sidebar .avatar-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 16px;
}

    .client-sidebar .avatar-actions .btn-light.btn-sm {
        background: #fff;
        border: 1px solid var(--bs-gray-300);
        border-radius: 8px;
        font: normal normal 500 var(--s-14);
    }

    .client-sidebar .avatar-actions .btn-link.btn-sm {
        text-decoration: none;
        background: #fff;
        border-radius: 8px;
        font: normal normal 500 var(--s-14);
    }

        .client-sidebar .avatar-actions .btn-link.btn-sm:hover {
            text-decoration: underline;
        }

.client-sidebar .sidebar-divider {
    height: 1px;
    width: 100%;
    background: #eef2f7;
    margin: 20px 0;
}

.client-sidebar .quick-summary.modern {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.client-sidebar .qs-title {
    margin: 0 0 4px;
    font-size: 12px;
    letter-spacing: .04em;
    color: #9aa3af;
    font-weight: 600;
}

.client-sidebar .qs-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.client-sidebar .qs-label {
    color: #9aa3af;
    font: normal normal 400 var(--s-14);
}

.client-sidebar .qs-value {
    color: #111827;
    font: normal normal 500 var(--s-14);
    padding: 4px 0;
}

.client-sidebar .qs-badge {
    display: inline-flex;
    align-items: center;
    padding: 4px 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 600;
}

    .client-sidebar .qs-badge.success {
        background: #eafff2;
        color: #10b981;
    }

.add-new-client-body {
    padding: 12px;
    display: flex;
    flex-direction: column;
    min-width: var(--px-950);
    height: 100%;
    background: var(--bg-main);
}

.client-layout {
    display: grid;
    grid-template-columns: 1fr var(--px-288);
    gap: 16px;
    overflow: hidden;
}

.popup-content .client-main {
    display: flex;
    flex-direction: column;
    gap: 12px;
    overflow: auto;
}

.client-sidebar {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.profile-card {
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    padding: 12px;
}

.avatar-preview {
    width: 100%;
    height: 160px;
    border: 1px dashed #cbd5e1;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #64748b;
}

    .avatar-preview img {
        max-width: 100%;
        max-height: 100%;
        object-fit: cover;
        border-radius: 8px;
    }

.upload-row {
    margin-top: 8px;
    display: flex;
    gap: 8px;
}

.quick-summary {
    margin-top: 8px;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.summary-line {
    display: flex;
    justify-content: space-between;
    font-size: 12px;
    color: #374151;
}

.drawer .form-group.form--popup {
    padding-bottom: 8px;
}

.company-paging-row {
    position: sticky;
    bottom: 0;
    background: white;
}

.highlight-opt.no-brd-left {
    margin-left: auto;
    border: 0;
    gap: 4px;
}

.msc-row.msc-selected {
    background: var(--bs-main-50);
}

.msc-fill-remaining {
    padding: 0;
    height: var(--px-28);
    min-width: var(--px-28);
    color: var(--bs-orange);
    border: 1px solid var(--bs-gray-500);
    font-size: 14px;
    font-weight: 700;
}

.btn-filter-roomMap {
    background: white;
    border: 1px solid var(--bs-gray-300);
    color: var(--bs-gray-900);
}

    .btn-filter-roomMap svg {
        height: 20px;
    }

.lst-add-room .item-room-guests.collapsed {
    height: var(--px-92);
    overflow: hidden;
    border: 1px solid #e5e7eb;
}

    .lst-add-room .item-room-guests.collapsed .item-room-add {
        padding: var(--px-12);
    }

    .lst-add-room .item-room-guests.collapsed .info-r {
        position: unset;
    }

.col-first {
    width: 70%;
}

.append-table-company {
    width: 100%;
    max-height: var(--px-300);
    overflow: auto;
}

.lst-add-room .item-room-guests .add-price-edit {
    position: absolute;
    left: var(--px-184);
    top: var(--px-20);
}

.lst-add-room .item-room-guests.collapsed .add-price-edit {
    position: absolute;
    left: var(--px-140);
    top: 8px;
}

.hide-on-desktop {
    display: none;
}

.table-list-item.mw-50 {
    min-width: var(--px-48);
    max-width: var(--px-48);
}

.table-list-item.w-large {
    min-width: var(--px-200);
}

/* Container */
.dropdown-resize {
    width: var(--px-248);
    padding: var(--px-16);
    border-radius: inherit;
    background: rgba(255,255,255,.72);
    backdrop-filter: blur(18px);
    border: 1px solid rgba(15, 23, 42, .12);
}

/* Title */
.title-resize {
    color: #5b6472;
    font: normal normal 700 var(--s-12);
}

/* Row */
.row-resize {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-top: 8px;
}

/* Labels */
.label-resize {
    font-size: 12px;
    color: #5b6472;
    min-width: 52px;
}

/* Percentage */
.pct-resize {
    font-size: 12px;
    font-weight: 700;
    color: #0b1220;
    min-width: 42px;
    text-align: center;
    transition: transform .15s ease;
}

/* Slider wrapper */
.slider-wrap-resize {
    padding: 12px 0 2px;
}

    /* Range base (iOS style) */
    .slider-wrap-resize input {
        -webkit-appearance: none;
        width: 100%;
        height: 10px;
        border-radius: 999px;
        outline: none;
        background: linear-gradient( 90deg, var(--bs-red) 0%, var(--bs-red) 68%, rgba(15, 23, 42, .10) 68% );
        box-shadow: 0 1px 0 rgba(255,255,255,.55) inset;
        transition: background .18s linear, transform .15s cubic-bezier(.16,1,.3,1), box-shadow .18s ease;
    }

        /* WebKit thumb (Chrome / Safari / iOS) */
        .slider-wrap-resize input::-webkit-slider-thumb {
            -webkit-appearance: none;
            width: var(--px-20);
            min-width: var(--px-20);
            height: var(--px-20);
            max-height: var(--px-20);
            border-radius: 999px;
            background: #fff;
            border: 1px solid var(--bs-orange);
            box-shadow: 0 10px 22px rgba(0,0,0,.18), 0 1px 0 rgba(255,255,255,.65) inset;
            cursor: pointer;
            transition: transform .15s ease, box-shadow .15s ease;
        }

        .slider-wrap-resize input:active::-webkit-slider-thumb {
            box-shadow: 0 14px 30px rgba(0,0,0,.22), 0 1px 0 rgb(255 255 255 / 75%) inset;
        }

        .slider-wrap-resize input:focus {
            border: 0;
        }

        /* Firefox thumb */
        .slider-wrap-resize input::-moz-range-thumb {
            width: 20px;
            height: 20px;
            border-radius: 999px;
            background: #fff;
            border: 0;
            box-shadow: 0 10px 22px rgba(0,0,0,.18), 0 1px 0 rgba(255,255,255,.65) inset;
            cursor: pointer;
        }

        .slider-wrap-resize input:active::-webkit-slider-thumb {
            transform: scale(1.1);
            box-shadow: 0 0 0 6px rgb(255 121 45 / 18%), 0 16px 32px rgba(0,0,0,.25), 0 1px 0 rgba(255,255,255,.8) inset;
        }

.preview-content .box-info {
    gap: 8px;
    display: flex;
    flex-direction: column;
}

.preview-content .photo-and-upload-form {
    display: flex;
    align-items: center;
    gap: 12px;
}

    .preview-content .photo-and-upload-form .lst-photo {
        display: flex;
        align-items: center;
        gap: 12px;
    }

        .preview-content .photo-and-upload-form .lst-photo img {
            height: var(--px-68);
            width: var(--px-68);
            border-radius: var(--px-68);
        }

.preview-content.group-img {
    gap: 16px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    width: 100%;
}

.photo-preview-popup {
}

    .photo-preview-popup .photo-preview-body {
        max-width: var(--px-600);
    }

    .photo-preview-popup .preview-canvas-wrap {
    }

    .photo-preview-popup #guest-photo-preview {
    }

    .photo-preview-popup .preview-actions {
        background: var(--bg-main);
        padding: 4px;
        border-radius: 6px;
        display: flex;
        gap: 8px;
        justify-content: space-between;
        margin-top: 12px;
        border: 1px solid var(--bs-gray-200);
    }

    .photo-preview-popup .btn {
        border: 0;
        color: var(--bs-gray-800);
        font: normal normal 500 var(--s-13);
        display: flex;
        align-items: center;
        gap: 5px;
        border: 1px solid var(--bs-gray-300);
        border-radius: 6px;
        background: white;
        flex: 1;
    }

    .photo-preview-popup #btn-save-photo {
        background: var(--bs-main);
        color: white;
    }

    .photo-preview-popup .btn-outline-dark:hover {
    }

    .photo-preview-popup .btn-outline-dark.danger {
    }

        .photo-preview-popup .btn-outline-dark.danger:hover {
        }

    .photo-preview-popup .btn i {
    }

/* ✅ Edit Guest - Photo Upload Section */
.edit-guest-body .photo-upload-section {
    padding: 12px;
    background: var(--bg-main);
    border-radius: 8px;
    border: 1px solid var(--bs-gray-200);
}

    .edit-guest-body .photo-upload-section .lst-photo {
        display: flex;
        align-items: center;
        gap: 12px;
        flex-wrap: wrap;
    }

        .edit-guest-body .photo-upload-section .lst-photo img {
            height: var(--px-68);
            width: var(--px-68);
            border-radius: 8px;
            object-fit: cover;
            cursor: pointer;
            border: 2px solid var(--bs-gray-200);
            transition: all 0.2s ease;
        }

            .edit-guest-body .photo-upload-section .lst-photo img:hover {
                border-color: var(--bs-main-400);
                transform: scale(1.05);
            }

        .edit-guest-body .photo-upload-section .lst-photo .upload {
            height: var(--px-68);
            width: var(--px-68);
            border-radius: 8px;
            border: 2px dashed var(--bs-gray-300);
            background: white;
            display: flex;
            align-items: center;
            justify-content: center;
            cursor: pointer;
            transition: all 0.2s ease;
        }

            .edit-guest-body .photo-upload-section .lst-photo .upload:hover {
                border-color: var(--bs-main-400);
                background: var(--bs-main-50);
            }

            .edit-guest-body .photo-upload-section .lst-photo .upload i {
                font-size: 20px;
                color: var(--bs-gray-400);
            }

                .edit-guest-body .photo-upload-section .lst-photo .upload:hover i {
                    color: var(--bs-main-400);
                }

        .edit-guest-body .photo-upload-section .loading-photos {
            min-height: var(--px-68);
            display: flex;
            align-items: center;
            justify-content: center;
        }

/* Minimal styles for global search overlay; reuse existing tokens/classes */
.global-search-overlay {
    position: absolute;
    z-index: 9999;
    background: transparent;
    box-shadow: none;
    box-shadow: 0 4px 20px var(--bs-gray-400);
    border-radius: 0 0 8px 8px;
    top: var(--px-56);
    left: 2px;
    max-width: calc(100vw - 4px);
    margin: auto;
}

.global-search-panel {
    background: #fff;
    border-radius: 0 0 8px 8px;
    padding: 8px;
    height: 100%;
}

.global-search-body {
    max-height: 420px;
    overflow: auto;
}

.global-search-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px;
    border-radius: 6px;
    cursor: pointer;
}

    .global-search-item .gsi-icon {
        width: 28px;
        text-align: center;
        color: var(--bs-main-600);
    }

    .global-search-item .gsi-title {
        font-weight: 600;
        font-size: 13px;
        display: flex;
        gap: 6px;
        align-items: center;
    }

    .global-search-item .gsi-subtitle {
        font-size: 12px;
        color: #888;
    }

    .global-search-item.active {
        background: #f5f8ff;
    }

.global-search-footer {
    border-top: 1px solid #eee;
    margin-top: 12px;
    padding-top: 8px;
    display: flex;
    justify-content: flex-end;
}

    .global-search-footer .hint {
        display: flex;
        gap: 12px;
        color: #888;
        font-size: 12px;
    }

        .global-search-footer .hint span {
            display: flex;
            align-items: center;
            gap: 2px;
        }

.global-search-panel {
}

.global-search-panel {
    z-index: 9999;
    border: 1px solid #e5e5e5;
}

.global-search-overlay .hint-pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px;
    border-radius: 6px;
    background: #fff;
    font-size: 14px;
    cursor: pointer;
    font: normal normal 400 var(--s-13);
    color: var(--bs-gray-800);
}

    .global-search-overlay .hint-pill:hover {
        background: var(--bs-gray-100);
    }

    .global-search-overlay .hint-pill:not(:hover) i {
        color: var(--bs-gray-500);
    }

    .global-search-overlay .hint-pill strong {
        font-weight: 500;
    }

.global-search-overlay .info-inline {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--px-20) 0 8px;
    font: normal normal 400 var(--s-14);
    color: var(--bs-gray-700);
}

    .global-search-overlay .info-inline i {
        color: var(--bs-gray-500);
    }

.global-search-type-hints {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
}

.global-search-header {
    color: var(--bs-gray-500);
    font: normal normal 600 var(--s-13);
    padding: 6px;
    display: flex;
    align-items: center;
    gap: 12px;
}

.gs-type-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    color: var(--bs-gray-800);
    font: normal normal 400 var(--s-12);
    border: 1px solid var(--bs-gray-300);
    border-radius: 24px;
    padding: 4px 8px;
}

/* Global Search section header: icon + label */
.global-search-section-header {
    display: flex;
    align-items: center;
    gap: 8px;
    font-weight: 600;
    font-size: 12px;
    color: var(--bs-gray-600);
    padding: 6px 8px;
    border-top: 1px solid var(--bs-gray-300);
    margin-top: 8px;
    text-transform: uppercase;
}

    .global-search-section-header i {
        font-size: 14px;
        font-weight: 400;
    }

/* Icon color variants */
.gs-head-icon-main {
    color: var(--bs-main-400);
}

.gs-head-icon-orange {
    color: var(--bs-orange,#f59e0b);
}

.gs-head-icon-green {
    color: #10b981;
}

.gs-head-icon-purple {
    color: #7c3aed;
}

.gs-head-icon-blue {
    color: var(--bs-cyan);
}

.gs-head-icon-gray {
    color: #9ca3af;
}

/* AUTHORIZATION */
/* ============================================
   Authorization Popup Styles
   ============================================ */

.auth-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(4px);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 99999;
    animation: authFadeIn 0.3s ease;
}

    .auth-overlay.auth-closing {
        animation: authFadeOut 0.3s ease;
    }

@keyframes authFadeIn {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

@keyframes authFadeOut {
    from {
        opacity: 1;
    }

    to {
        opacity: 0;
    }
}

.auth-popup {
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
    width: 90%;
    max-width: 450px;
    animation: authSlideUp 0.3s ease;
    overflow: hidden;
}

    .auth-popup.auth-success {
        animation: authSuccess 0.5s ease;
    }

    .auth-popup.auth-shake {
        animation: authShake 0.5s ease;
    }

@keyframes authSlideUp {
    from {
        opacity: 0;
        transform: translateY(30px) scale(0.95);
    }

    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

@keyframes authSuccess {
    0%, 100% {
        transform: scale(1);
    }

    50% {
        transform: scale(1.02);
    }
}

@keyframes authShake {
    0%, 100% {
        transform: translateX(0);
    }

    25% {
        transform: translateX(-10px);
    }

    75% {
        transform: translateX(10px);
    }
}

.auth-header {
    background: linear-gradient(135deg, var(--bs-main-300) 0%, var(--bs-main-700) 100%);
    padding: 32px 24px 24px;
    text-align: center;
    color: #fff;
    position: relative;
}

.auth-icon {
    width: 64px;
    height: 64px;
    margin: 0 auto 16px;
    background: rgba(255, 255, 255, 0.2);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 28px;
    backdrop-filter: blur(10px);
}

.auth-title {
    font-size: 22px;
    font-weight: 600;
    margin: 0 0 8px;
    color: #fff;
}

.auth-subtitle {
    font-size: 14px;
    margin: 0;
    opacity: 0.9;
    color: #fff;
}

.auth-body {
    padding: 24px;
}

.auth-input-wrap {
    position: relative;
}

    .auth-input-wrap input {
        padding-right: 40px !important;
    }

.btn-toggle-password {
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    color: #999;
    cursor: pointer;
    padding: 6px 10px;
    transition: color 0.2s;
}

    .btn-toggle-password:hover {
        color: #667eea;
    }

.auth-error {
    background: #fee;
    border: 1px solid #fcc;
    border-radius: 8px;
    padding: 12px 16px;
    margin-top: 16px;
    display: flex;
    align-items: center;
    gap: 10px;
    color: #c33;
    font-size: 13px;
    animation: authErrorSlide 0.3s ease;
}

@keyframes authErrorSlide {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.auth-error i {
    font-size: 16px;
    flex-shrink: 0;
}

.auth-footer {
    padding: 16px 24px;
    display: flex;
    gap: 12px;
    padding-top: 0;
}

.auth-btn-cancel,
.auth-btn-confirm {
    flex: 1;
    padding: 12px 20px;
    font-size: 15px;
    font-weight: 500;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    background: var(--bs-main);
    color: white;
}

    .auth-btn-confirm:disabled {
        opacity: 0.5;
        cursor: not-allowed;
    }

.auth-btn-cancel {
    background: 0;
    color: var(--bs-text);
}

.auth-hint {
    padding: 12px 24px;
    background: var(--bs-body-bg);
    border-top: 1px solid #e0e8ff;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    color: var(--bs-orange);
    font-size: 13px;
}

    .auth-hint i {
        font-size: 14px;
    }

/* Responsive */
@media (max-width: 576px) {
    .auth-popup {
        width: 95%;
        max-width: none;
    }

    .auth-header {
        padding: 24px 16px 20px;
    }

    .auth-body {
        padding: 16px;
    }

    .auth-footer {
        flex-direction: column;
    }
}
/* Copy Success Animation */
@keyframes pulse-success {
    0% {
        box-shadow: 0 0 0 0 rgba(16, 185, 129, 0.7);
    }

    50% {
        box-shadow: 0 0 0 10px rgba(16, 185, 129, 0);
    }

    100% {
        box-shadow: 0 0 0 0 rgba(16, 185, 129, 0);
    }
}

.copy-success {
    position: relative;
    overflow: visible;
}

/* Optional: Add smooth transitions to buttons */
.btn-left-side.copy {
    transition: all 0.3s ease;
}

    .btn-left-side.copy:hover {
        transform: translateY(-2px);
    }

/* Guest Item Selected State */
.fdc-guest-item.guest-selected {
    background: linear-gradient(135deg, rgba(67, 173, 151, 0.12) 0%, rgba(67, 173, 151, 0.08) 100%);
    border-left: 3px solid var(--bs-main-400);
    padding-left: calc(12px - 3px); /* Compensate for border */
    animation: guestPulse 0.6s ease;
}

    .fdc-guest-item.guest-selected .fdc-guest-avatar-mini {
        background: var(--bs-main-400);
        color: white;
        box-shadow: 0 0 0 3px rgba(67, 173, 151, 0.2);
    }

    .fdc-guest-item.guest-selected .fdc-guest-item-name {
        color: var(--bs-main-500);
        font-weight: 600;
    }

@keyframes guestPulse {
    0%, 100% {
        transform: scale(1);
    }

    50% {
        transform: scale(1.02);
    }
}

/* Guest Item Hover Enhancement */
.fdc-guest-item {
    cursor: pointer;
    transition: all 0.2s ease;
    border-left: 3px solid transparent;
}

    .fdc-guest-item:hover {
        background: rgba(0, 0, 0, 0.02);
        transform: translateX(2px);
    }

    .fdc-guest-item:active {
        transform: scale(0.98);
    }

/* Transaction Detail Popup Customization */
.transaction-detail-popup {
    max-width: 600px;
}

    .transaction-detail-popup .dt-chip {
        display: inline-flex;
        align-items: center;
        gap: 8px;
        padding: 8px 12px;
        border: 1px solid var(--bs-gray-300);
        border-radius: 999px;
        font-size: 13px;
        font-weight: 500;
        color: #374151;
        background: var(--bg-num-availble);
    }

        .transaction-detail-popup .dt-chip b {
            font-weight: 700;
            color: var(--text-color);
        }

    .transaction-detail-popup .preview-stay-value strong {
        color: var(--bs-main-500);
        font-size: 16px;
    }

    /* Loading state animation */
    .transaction-detail-popup .fa-spinner {
        animation: spin 1s linear infinite;
    }

@keyframes spin {
    from {
        transform: rotate(0deg);
    }

    to {
        transform: rotate(360deg);
    }
}

.transaction-detail {
    min-width: var(--px-420);
}

.footer-hint {
    font-size: 14px;
}

.fdc-loading-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    backdrop-filter: blur(2px);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9999;
    pointer-events: all;
}

.loading-container-search {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 40px;
    position: absolute;
    width: 100%;
    height: 100%;
}

.header-conflict-popup {
    position: relative;
    text-align: center;
    padding: 24px 20px 16px;
    border-bottom: 1px solid #e5e7eb;
}

.conflict-icon-wrapper {
    width: 64px;
    height: 64px;
    margin: 0 auto 16px;
    background: linear-gradient(135deg, #fef3c7 0%, #fcd34d 100%);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    animation: pulse-warning 2s infinite;
}

@keyframes pulse-warning {
    0%, 100% {
        box-shadow: 0 0 0 0 rgba(251, 191, 36, 0.4);
    }

    50% {
        box-shadow: 0 0 0 12px rgba(251, 191, 36, 0);
    }
}

.conflict-icon-wrapper i {
    font-size: 32px;
    color: #f59e0b;
}

.conflict-title {
    font-size: 20px;
    font-weight: 600;
    color: #111827;
    margin: 0 0 8px;
}

.conflict-subtitle {
    font-size: 14px;
    color: #6b7280;
    margin: 0;
    line-height: 1.5;
}

.conflict-content {
    padding: 20px;
    max-height: 500px;
    overflow-y: auto;
}

.conflict-section {
    margin-bottom: 20px;
}

.conflict-section-title {
    font-size: 15px;
    font-weight: 600;
    color: #374151;
    margin: 0 0 12px;
    display: flex;
    align-items: center;
    gap: 8px;
}

    .conflict-section-title i {
        color: var(--bs-main);
    }

.guest-conflict-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.guest-conflict-card {
    background: #ffffff;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    padding: 16px;
    transition: all 0.2s ease;
}

    .guest-conflict-card:hover {
        border-color: #6366f1;
        box-shadow: 0 2px 8px rgba(99, 102, 241, 0.1);
    }

.guest-conflict-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 12px;
    padding-bottom: 12px;
    border-bottom: 1px solid #f3f4f6;
}

.guest-info-primary {
    display: flex;
    align-items: center;
    gap: 12px;
    flex: 1;
}

    .guest-info-primary > i {
        font-size: 32px;
        color: var(--bs-main);
    }

.guest-name-block {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.guest-name {
    font-size: 15px;
    font-weight: 600;
    color: #111827;
}

.guest-folio {
    font-size: 13px;
    color: #6b7280;
}

.guest-status-badge {
    padding: 4px 12px;
    border-radius: 12px;
    font-size: 12px;
    font-weight: 500;
    white-space: nowrap;
}

    .guest-status-badge.status-in-house {
        background: #dcfce7;
        color: #166534;
    }

    .guest-status-badge.status-reservation {
        background: #dbeafe;
        color: #1e40af;
    }

    .guest-status-badge.status-check-out {
        background: #f3f4f6;
        color: #374151;
    }

.guest-conflict-details {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 8px;
}

.detail-row {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
}

    .detail-row i {
        color: #6b7280;
        width: 16px;
    }

.detail-label {
    color: #6b7280;
}

.detail-row strong {
    color: #111827;
    margin-left: auto;
}

.no-guest-info {
    text-align: center;
    padding: 32px;
    color: #9ca3af;
}

    .no-guest-info i {
        font-size: 40px;
        margin-bottom: 12px;
        display: block;
    }

.conflict-actions {
    padding-top: 16px;
    border-top: 1px solid #e5e7eb;
}

.conflict-hint {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 12px 16px;
    background: #eff6ff;
    border-radius: 6px;
    margin: 0;
    font-size: 13px;
    color: #1e40af;
    line-height: 1.5;
}

    .conflict-hint i {
        color: #3b82f6;
        margin-top: 2px;
    }

.btn-close-popup-guest {
    background: 0;
    border: 1px solid var(--bs-gray-300);
    color: var(--text-color);
    position: absolute;
    right: 12px;
    top: 12px;
    font-weight: 600;
}

/* ========================================
   MASTER ROOM TOGGLE STYLES
   ======================================== */

.master-room-toggle {
    position: absolute;
    top: -14px;
    right: 12px;
    z-index: 10;
}

.btn-master-room {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: #ffffff;
    border: 1.5px solid var(--bs-gray-400);
    border-radius: 8px;
    padding: 6px 12px;
    cursor: pointer;
    transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
    font-family: 'Sora', sans-serif;
    font-size: 13px;
    font-weight: 500;
    color: #6b7280;
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
    height: 24px;
}

    .btn-master-room:hover:not(.active) {
        border-color: #fbbf24;
        background: #fffbeb;
        transform: translateY(-1px);
        box-shadow: 0 4px 6px -1px rgba(251, 191, 36, 0.1), 0 2px 4px -1px rgba(251, 191, 36, 0.06);
    }

        .btn-master-room:hover:not(.active) i {
            color: #fbbf24;
            transform: rotate(15deg);
        }

    .btn-master-room.active {
        background: linear-gradient(135deg, #fbbf24 0%, #f59e0b 100%);
        border-color: #f59e0b;
        color: #ffffff;
        box-shadow: 0 4px 12px rgba(245, 158, 11, 0.3), 0 0 0 3px rgba(251, 191, 36, 0.1);
    }

        .btn-master-room.active i {
            color: #ffffff;
            filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.2));
        }

        .btn-master-room.active .master-label {
            font-weight: 600;
            display: block;
        }

    .btn-master-room:active {
        transform: scale(0.95);
    }

    .btn-master-room i {
        font-size: 12px;
        transition: all 0.25s ease;
    }

    .btn-master-room .master-label {
        line-height: 1;
        letter-spacing: 0.01em;
        font-size: var(--px-12);
        display: none;
    }

/* Responsive adjustments */
@media (max-width: 768px) {
    .master-room-toggle {
        top: 8px;
        right: 8px;
    }

    .btn-master-room {
        padding: 4px;
        font-size: 12px;
        position: absolute;
        top: 1px;
        right: 1px;
        border-radius: 5px;
        border-width: 1px;
    }

        .btn-master-room i {
            font-size: var(--px-14);
        }

        .btn-master-room .master-label {
            display: none; /* Hide text on mobile, show icon only */
        }
}

/* Disabled state (when only 1 room) */
.master-room-toggle.dis-none {
    display: none !important;
}

/* Animation keyframes */
@keyframes master-glow {
    0%, 100% {
        box-shadow: 0 4px 12px rgba(245, 158, 11, 0.3), 0 0 0 3px rgba(251, 191, 36, 0.1);
    }

    50% {
        box-shadow: 0 4px 16px rgba(245, 158, 11, 0.4), 0 0 0 5px rgba(251, 191, 36, 0.15);
    }
}

.btn-master-room.active:hover {
    animation: master-glow 1.5s ease-in-out infinite;
}

/* Focus state for accessibility */
.btn-master-room:focus-visible {
    outline: 2px solid #fbbf24;
    outline-offset: 2px;
}

/* Icon animation on hover */
.btn-master-room:hover i {
    transition: transform 0.3s ease;
}

.btn-master-room.active:hover i {
    transform: rotate(72deg); /* 1/5 rotation for star */
}

#section-append-rooms {
    gap: var(--px-32);
}
