﻿/*--------------------------------------------------------------
# General
--------------------------------------------------------------*/

/*--------------------------------------------------------------
# Destination Drop Down (Hotel)
--------------------------------------------------------------*/
#HotelDestinationDropDown {
    opacity: 0;
    visibility: hidden;
    pointer-events: none; /* Prevent interaction when hidden */
    display: none;
}

    #HotelDestinationDropDown.expanded {
        opacity: 1;
        visibility: visible;
        pointer-events: auto; /* Enable interaction when visible */
        display: block;
    }

.search-panel #dest-searchfound-data-hotel {
    display: none;
}

.search-panel .select-hotel .search-found-container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    height: 65px;
    background: #FFF;
    border-radius: 8px;
    color: var(--text-secondary);
    padding: 0 30px;
    margin-bottom: 1.5rem;
    cursor: pointer;
}

    .search-panel .select-hotel .search-found-container span {
        flex: 1;
        margin-left: 1.5rem;
    }

.search-panel .select-hotel .route-container {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 14px;
    padding-left: 10px;
    padding-right: 10px;
    margin-bottom: 25px;
}

.search-panel .select-hotel .dest-container {
    display: flex;
    width: 292px;
    height: 100%;
    overflow: hidden;
    border-radius: 8px;
    background: #FFF;
    cursor: pointer;
}

.search-panel .select-hotel .dest-container:hover .country-img {
    transform: scale(1.05);
}

.search-panel .select-hotel .dest-container .country-img {
    width: 65px;
    height: 65px;
    border-radius: 8px;
    margin-right: 15px;
    object-fit: cover;
    transition: transform .3s ease 0s;
}

    .search-panel .select-hotel .dest-item-container {
        flex: 1;
        line-height: normal;
        padding: 3px 0;
    }

.search-panel .select-hotel .dest-container .dest-item-container .dest-name {
    margin-bottom: 0;
    width: 201px;
    color: #444;
    font-size: 14px;
    font-weight: 600;
    line-height: normal;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.search-panel .select-hotel .dest-container .dest-item-container .country-name {
    margin-bottom: 0;
    width: 186px;
    color: #ACACAC;
    font-size: 12px;
    font-weight: 400;
    line-height: normal;
}

.search-panel .select-hotel .dest-container .dest-item-container .hotel-kind {
    width: 84px;
    height: 18px;
    border-radius: 6px;
    background: #EEF5FD;
    text-align: center;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.search-panel .select-hotel .dest-container .dest-item-container .kind-name {
    font-size: 12px;
    font-weight: 500;
    line-height: normal;
    color: #2E6499;
}

.search-panel .select-hotel .dest-container .dest-item-container .flag-icon {
    width: 21px;
    height: 12px;
    border-radius: 3px;
    margin-right: 9px;
}

.search-panel .select-hotel .city-box {
    width: auto;
    height: 28px;
    border-radius: 16px;
    background: #FFF;
    cursor: pointer;
    position: relative;
}

.search-panel .select-hotel .path-container {
    position: absolute;
    left: 8px;
    top: 2px;
}

.search-panel .select-hotel .city-box .city-name {
    font-size: 15px;
    line-height: normal;
    padding: 5px 33px;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex: 1;
}

.search-panel .select-hotel .kind-boxs {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 12px;
}

    .search-panel .select-hotel .kind-boxs .ctgr-box {
        position: relative;
        background: #EEF5FD;
        color: #2E6499;
        width: auto;
        height: 28px;
        border-radius: 16px;
        padding-top: 3px;
        padding-left: 40px;
        padding-bottom: 3px;
        padding-right: 10px;
        text-align: center;
        font-weight: 500;
        line-height: normal;
        cursor: pointer;
        transition: all .3s;
    }

    .search-panel .select-hotel .kind-boxs .path-container {
        position: absolute;
        top: 3px;
        left: 10px;
    }

.search-panel .select-hotel .state-box-hotel {
    height: 28px;
    border-radius: 16px;
    background: #FFF;
    padding: 3px 20px;
    cursor: pointer;
    color: #444444;
    font-size: 15px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    display: flex;
    align-items: center;
}

    .search-panel .select-hotel .state-box-hotel .bxs-map {
        color: var(--background-primary);
        margin-right: 10px;
    }

.search-panel .route-container .hotel-item-container .country-lbl {
    color: #ACACAC;
    font-size: 12px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
}

.search-panel .select-hotel .place-boxs {
    width: 292px;
    padding-left: 26px;
    padding-right: 12px;
}

    .search-panel .select-hotel .place-boxs .path-container {
        width: 65px;
        height: 65px;
        display: flex;
        align-items: center;
        justify-content: center;
        margin-right: 30px;
    }

    .search-panel .select-hotel .place-boxs .dest-item-container {
        flex: 1;
    }

    .search-panel .select-hotel .place-boxs .flag-icon {
        width: 21px;
        height: 12px;
        border-radius: 3px;
        margin-right: 6px;
    }

    .search-panel .select-hotel .place-boxs .hotel-icon {
        width: 18px;
        height: 20px;
        border-radius: 0;
    }

    .search-panel .select-hotel .place-boxs .cname {
        font-size: 12px;
        color: #ACACAC;
        overflow: visible;
        text-overflow: unset;
        white-space: normal;
        width: 100%;
    }

    .search-panel .select-hotel .place-boxs .acount {
        color: #ACACAC;
        font-size: 12px;
        line-height: normal;
    }

    .search-panel .select-hotel .place-boxs:hover {
        background: var(--background-primary);
    }

        .search-panel .select-hotel .place-boxs:hover .dest-name,
        .search-panel .select-hotel .place-boxs:hover .acount,
        .search-panel .select-hotel .place-boxs:hover .cname {
            color: #FFF;
        }

        .search-panel .select-hotel .place-boxs:hover img {
            transform: unset;
        }

.search-panel .select-hotel .hotel-boxs {
    width: 292px;
}

    .search-panel .select-hotel .hotel-boxs span {
        color: #ACACAC;
        font-size: 12px;
        line-height: normal;
        margin-bottom: 3px;
        display: flex;
        align-items: center;
    }

    .search-panel .select-hotel .hotel-boxs .hotel-name {
        font-size: 14px;
        line-height: normal;
        font-weight: 600;
        width: 190px;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .search-panel .select-hotel .hotel-boxs img {
        margin-right: 15px;
    }

    .search-panel .select-hotel .hotel-boxs:hover .flag-icon {
        transform: unset;
    }

    .search-panel .select-hotel .hotel-boxs .hotel-item-container {
        display: flex;
        align-items: center;
    }

    .search-panel .select-hotel .hotel-boxs .flag-icon {
        width: 21px;
        height: 12px;
        border-radius: 3px;
        margin-right: 6px;
    }

.search-panel .select-hotel .tag-box {
    border-radius: 6px;
    background: #DAFEFF;
    font-size: 12px;
    font-weight: 500;
    color: var(--text-secondary);
    width: 84px;
    height: 18px;
    padding: 1px 4px;
    text-align: center;
}

#searchHotelModify .select-dp {
    position: absolute;
    top: 7.5rem;
    left: 7rem;
    width: 80%;
    background: #FFF;
    box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);
    border-radius: 12px;
    display: none;
    list-style: none;
    z-index: 2;
    padding: 1rem 2rem;
    margin-bottom: 0;
    max-height: 345px;
    overflow-y: scroll;
    user-select: none;
}

.search-modify-wrapper .search-panel .input-box {
    padding: 10px 20px 10px 45px;
}

#HotelDestinationDropDown .dest-title {
    font-size: 14px;
    font-weight: 700;
    color: #444;
}

#HotelDestinationDropDown .properties-wrapper {
    width: 100%;
    display: flex;
    cursor: pointer;
}

#HotelDestinationDropDown .hotel-item-desc {
    font-size: 14px;
    margin-bottom: 0.5rem;
    display: flex;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
}

    #HotelDestinationDropDown .hotel-item-desc.additional {
        font-size: 12px;
        color: var(--fourth-text-color);
    }

#HotelDestinationDropDown .properties-wrapper .hotel-img {
    min-width: 75px;
    max-width: 75px;
    height: 75px;
    border-radius: 12px;
    object-fit: cover;
}

#HotelDestinationDropDown .properties-wrapper .region-img {
    width: 80px;
    height: 25px;
    margin: 1rem 0;
}

#HotelDestinationDropDown .kind-wrap {
    width: max-content;
    padding: .1rem 1rem;
    background: #DAFEFF;
    border-radius: 6px;
    font-size: 12px;
    color: #00CBCF;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: .3rem;
    font-weight: 500;
}

#hotel .rooms-container .option-wrapper {
    border-radius: 12px;
    border: 1px solid var(--third-background);
    background: var(--third-background);
    padding: 1rem;
}

#hotel .search-panel .select-guest-wrap .input-box,
#hotel .search-panel .select-wrap-guest-nationality .input-box {
    padding: 10px 13px 10px 50px
}


    #hotel .search-panel .select-wrap-guest-nationality .input-box img {
        position: absolute;
        top: 22px;
        left: 16px;
        border-radius: 4px;
    }

#hotel .rooms-container .option-wrapper .h-sel-childage,
#hotel-listing-search .rooms-container .option-wrapper .h-sel-childage {
    height: 58px;
}

.h-sel-childage option {
    color: #000000;
}

#hotel .rooms-container .option-wrapper .btn-minus .btn:disabled {
    color: var(--fourth-text-color);
    background: #AAAAAA;
    border-radius: 5px 0px 0px 5px;
    font-weight: 700;
    letter-spacing: .15px;
    font-size: 18px;
    width: 29px;
    opacity: 1;
    height: 39px;
    padding: 0;
}

#hotel .rooms-container .option-wrapper .btn-plus .btn:disabled {
    color: var(--fourth-text-color);
    background: #AAAAAA;
    border-radius: 0px 5px 5px 0px;
    font-weight: 700;
    letter-spacing: .15px;
    font-size: 18px;
    width: 29px;
    opacity: 1;
    height: 39px;
    padding: 0;
}

.select-guest-wrap .select-guest {
    position: absolute;
    top: 57px;
    left: 0;
    width: 395px;
    background: #FFF;
    box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);
    border-radius: 12px;
    display: none;
    list-style: none;
    z-index: 2;
    padding: 0;
    margin-bottom: 0;
    max-height: 345px;
    overflow-y: scroll;
    user-select: none;
}

.select-wrap-guest-nationality.active #guest-nationality {
    display: block;
}

.guest-option .guest-dropdown {
    overflow-y: scroll;
    max-height: 345px;
}

.select-guest-wrap,
.select-wrap-guest-nationality {
    position: relative;
}

    .select-guest-wrap .btn-confirm-h-guest {
        background: var(--background-primary);
        color: #FCFCFC;
        border-radius: 12px;
        font-weight: 700;
        width: 222px;
        height: 45px;
        margin-top: 1.5rem;
        transition: color .3s;
        border: 0;
    }

        .select-guest-wrap .btn-confirm-h-guest:hover {
            background-color: transparent;
            color: var(--text-secondary);
            border: 1px solid var(--background-primary);
        }

        .select-guest-wrap .btn-confirm-h-guest:disabled {
            background: #AAA;
            color: #FCFCFC;
        }

.select-guest .guest-option-icon {
    position: absolute;
    top: 13px;
    left: 7px;
    font-weight: 900;
}

.select-guest-wrap .option::-webkit-scrollbar,
.guest-option .dropdown::-webkit-scrollbar {
    width: 5px;
}

.select-guest-wrap .option::-webkit-scrollbar-track,
.guest-option .dropdown::-webkit-scrollbar-track {
    border-radius: 6px;
}

.select-guest-wrap .option::-webkit-scrollbar-thumb,
.guest-option .dropdown::-webkit-scrollbar-thumb {
    background-color: #CCC;
    border-radius: 6px;
    background-clip: padding-box;
}

.select-guest-wrap.active .select-guest {
    display: block;
    overflow-y: auto;
    max-height: 745px;
}

.hotel-guest-minus-btn {
    border-bottom-left-radius: 6px;
    border-top-left-radius: 6px;
}

.hotel-guest-plus-btn {
    border-bottom-right-radius: 6px;
    border-top-right-radius: 6px;
}

#guest-nationality {
    position: absolute;
    top: 57px;
    left: 0;
    width: 365px;
    background: #FFF;
    box-shadow: 0px -1px 4px 0px rgba(0, 0, 0, 0.10), 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
    border-radius: 12px;
    display: none;
    z-index: 2;
    padding-top: 1rem;
    padding-left: 2rem;
    padding-bottom: 1rem;
    padding-right: 1rem;
    max-height: 345px;
    overflow: hidden;
    user-select: none;
}

    #guest-nationality .nationality-desc {
        font-size: 14px;
        text-align: justify;
        line-height: 21px;
    }

    #guest-nationality .citizenship-wrapper {
        margin: 0 1rem;
        display: flex;
        cursor: pointer;
    }

        #guest-nationality .citizenship-wrapper .nationality-img {
            width: 40px;
            margin: 1rem 0;
        }

    #guest-nationality .nationality-scrollable-content {
        max-height: calc(345px - 2rem);
        overflow-y: auto;
        padding-right: 20px;
    }

    #guest-nationality .citizenship-input-box {
        width: 100%;
        border-radius: 12px;
        background: #F5F5F5;
        height: 58px;
        position: relative;
        padding: 17px 52px;
    }

        #guest-nationality .citizenship-input-box input {
            width: 100%;
            border: 0;
            outline: 0;
            background-color: transparent;
        }

        #guest-nationality .citizenship-input-box .icon {
            position: absolute;
            top: 20px;
            left: 14px;
        }

/*--------------------------------------------------------------
# SubPage
--------------------------------------------------------------*/
.hotel-hero {
    background-image: url(/assets/img_V2/hotel/bg-hero-w.png);
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: cover;
    position: relative;
    width: 100%;
    height: 500px;
}

    .hotel-hero .h-service-type {
        color: #FFF;
        text-shadow: 0 2px 3px rgb(60 60 60 / 100%);
        font-size: 32px;
        font-style: normal;
        font-weight: 700;
    }

    .hotel-hero .h-sub-service {
        color: #FFF;
        text-shadow: 0px 2px 5px rgba(6, 90, 90, 0.75);
        font-size: 24px;
        font-style: normal;
        font-weight: 400;
        margin-bottom: .5rem;
    }

    .hotel-hero .search-panel {
        border-radius: 16px;
    }

        .hotel-hero .search-panel .select-hotel .place-boxs:hover {
            background: var(--background-primary);
        }

    .hotel-hero .rooms-container .option-wrapper {
        border-radius: 12px;
        border: 1px solid var(--third-background);
        background: var(--third-background);
        padding: 1rem;
    }

        .hotel-hero .rooms-container .option-wrapper .h-sel-childage {
            height: 58px;
        }

.h-popular-container {
    margin-bottom: 3.5rem;
}

.h-content .content-title {
    color: var(--text-primary);
    font-size: 20px;
    font-style: normal;
    font-weight: 700;
}

.h-hotel-container,
.h-bnb-container,
.h-aprt-container {
    margin-bottom: 3.5rem;
}

    .h-hotel-container .see-more-wrap,
    .h-bnb-container .see-more-wrap,
    .h-aprt-container .see-more-wrap {
        position: relative;
        cursor: pointer;
    }

        .h-hotel-container .see-more-wrap .see-more-btn,
        .h-bnb-container .see-more-wrap .see-more-btn,
        .h-aprt-container .see-more-wrap .see-more-btn {
            color: #FB8D20;
            font-family: Roboto;
            font-size: 18px;
            font-style: normal;
            font-weight: 400;
            line-height: normal;
            margin-right: 2rem;
        }

        .h-hotel-container .see-more-wrap i,
        .h-bnb-container .see-more-wrap i,
        .h-aprt-container .see-more-wrap i {
            color: #FB8D20;
            position: absolute;
            right: 0px;
            top: 1px;
        }

.h-hotel-item,
.h-bnb-item,
.h-aprt-item {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 26px;
    margin: 1rem 0;
}

    .h-hotel-item .h-hotel-card,
    .h-bnb-item .h-bnb-card,
    .h-aprt-item .h-aprt-card {
        position: relative;
        display: flex;
        flex-direction: column;
        width: 238px;
        word-wrap: break-word;
        border-radius: 12px;
        border: 1px solid #DDD;
        background: #FFF;
        overflow: hidden;
        transition: box-shadow .3s ease 0s;
        height: 235px;
    }

        .h-hotel-item .h-hotel-card .h-sub-img,
        .h-bnb-item .h-bnb-card .h-sub-img,
        .h-aprt-item .h-aprt-card .h-sub-img {
            -webkit-user-select: none;
            -moz-user-select: none;
            user-select: none;
            width: 100%;
            height: 133px;
            -o-object-fit: cover;
            object-fit: cover;
            transition: transform .3s ease 0s;
            border-radius: 12px 12px 0px 0px;
        }

        .h-hotel-item .h-hotel-card:hover,
        .h-bnb-item .h-bnb-card:hover,
        .h-aprt-item .h-aprt-card:hover {
            box-shadow: 0px 4px 16px 1px rgba(0,0,0,0.12);
        }

            .h-hotel-item .h-hotel-card:hover img,
            .h-bnb-item .h-bnb-card:hover img,
            .h-aprt-item .h-aprt-card:hover img {
                transform: scale(1.05);
            }

        .h-hotel-item .h-hotel-card .h-hotel-card-body,
        .h-bnb-item .h-bnb-card .h-bnb-card-body,
        .h-aprt-item .h-aprt-card .h-aprt-card-body {
            position: relative;
            padding: 5px 15px 10px;
            height: 100%;
            background: #FFF;
            display: flex;
            flex-direction: column;
            -webkit-box-flex: 1;
            -ms-flex: 1;
            flex: 1;
            justify-content: space-between;
        }

            .h-hotel-item .h-hotel-card .h-hotel-card-body .card-body-name,
            .h-bnb-item .h-bnb-card .h-bnb-card-body .card-body-name,
            .h-aprt-item .h-aprt-card .h-aprt-card-body .card-body-name {
                color: #444;
                font-size: 16px;
                font-weight: 700;
                line-height: normal;
                margin-bottom: 0;
                overflow: hidden;
                text-overflow: ellipsis;
                display: -webkit-box;
                -webkit-box-orient: vertical;
                -webkit-box-align: start;
                -webkit-line-clamp: 2;
                margin-bottom: .3rem;
            }

            .h-hotel-item .h-hotel-card .h-hotel-card-body .card-body-address,
            .h-bnb-item .h-bnb-card .h-bnb-card-body .card-body-address,
            .h-aprt-item .h-aprt-card .h-aprt-card-body .card-body-address {
                overflow: hidden;
                text-overflow: ellipsis;
                display: -webkit-box;
                -webkit-box-orient: vertical;
                -webkit-box-align: start;
                -webkit-line-clamp: 2;
                line-height: normal;
                font-style: italic;
                color: #AAA;
                font-size: 12px;
                font-style: italic;
                font-weight: 400;
            }

            .h-hotel-item .h-hotel-card .h-hotel-card-body .star-box,
            .h-bnb-item .h-bnb-card .h-bnb-card-body .star-box,
            .h-aprt-item .h-aprt-card .h-aprt-card-body .star-box {
                border-radius: 6px;
                background: rgba(255, 242, 210, 0.50);
                width: 107px;
                height: 20px;
                display: flex;
                align-items: center;
                padding: 6px 10px;
                color: #FFBE2C;
            }

                .h-hotel-item .h-hotel-card .h-hotel-card-body .star-box .bxs-star,
                .h-bnb-item .h-bnb-card .h-bnb-card-body .star-box .bxs-star,
                .h-aprt-item .h-aprt-card .h-aprt-card-body .star-box .bxs-star {
                    font-size: 9px;
                    margin-right: 6px;
                }

            .h-hotel-item .h-hotel-card .h-hotel-card-body span,
            .h-bnb-item .h-bnb-card .h-bnb-card-body span,
            .h-aprt-item .h-aprt-card .h-aprt-card-body span {
                color: #FF9E2C;
                font-size: 12px;
                font-style: normal;
                font-weight: 500;
            }
