﻿:root {
    --cc-z-index: 1000;
    --color-button: #1aa7ee
}
body{
    font-family: 'Montserrat', sans-serif;
    margin: 0;
    padding: 0;
    overflow: hidden;
    user-select: none;
}
*:hover{
    -webkit-transition: all .3s ease;
    transition: all .3s ease;
}

::-webkit-scrollbar {
    width: 5px;
}

::-webkit-scrollbar-track {
    background: #f1f1f1;
}

::-webkit-scrollbar-thumb {
    background: var(--color-button);
}

.hidden{
    display: none !important;
}

.disabled {
    pointer-events: none;
    opacity: 0.4;
}
.noselect {
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}
#cesiumContainer {
    width: 100%;
    height: 100vh;
    margin: 0;
    padding: 0;
}
.cesium-baseLayerPicker-dropDown {
    width: 150px;
    background-color: transparent;
    border: none;
}
.cesium-baseLayerPicker-sectionTitle, .cesium-baseLayerPicker-categoryTitle, .cesium-baseLayerPicker-itemLabel {
    display: none;
}
.cesium-baseLayerPicker-choices {
    border: none;
    padding: 0;
    margin-bottom: 0;
}
.cesium-viewer .cesium-widget-credits {
    position: absolute;
    bottom: 10px;
    left: 10px;
    font-size: 9px;
    width: 280px;
}
.cesium-credit-expand-link {
    text-decoration: none;
}
.cesium-credit-logoContainer {
    pointer-events: none;
    cursor: default;
}
.cesium-credit-logoContainer img {
    width: 80px;
}
#loading {
    position: absolute;
    z-index: 10;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    pointer-events: none;
}
.vt-card {
    position: absolute;
    display: none;
    bottom: 0;
    right: 0;
    transform: translateX(50%);
    width: 300px;
    text-align: center;
    cursor: default;
    opacity: 0;
    z-index: 12;
}
.vt-card:after {
    content: "";
    display: block;
    border-width: 10px 10px 0;
    border-style: solid;
    border-color: #ffffff transparent transparent;
    margin-left: -10px;
    position: absolute;
    bottom: -10px;
    left: 50%;
}
.vt-card:hover {
    border: 1px solid rgba(0,0,0,.5);
}
.vt-card .card-img-block {
    width: 91%;
    margin: 0 auto;
    position: relative;
    top: -20px;
}
.vt-card .card-img-block img{
    border-radius: 5px;
    box-shadow: 0 0 10px rgba(0,0,0,0.65);
}
.vt-card h5{
    color: #303c5e;
    font-weight: 600;
    font-size: 14px;
}
.vt-card p{
    font-size: 12px;
    font-weight: 300;
}
.ripple-wrap {
    display: none;
    overflow: hidden;
    position: fixed;
    font-size: 0;
    z-index: 1000;
    top: 0; left: 0; right: 0; bottom: 0;
}
.card-title {
    text-transform: uppercase;
    margin-bottom: 0;
}
.card-author {
    margin: 0;
    font-style: italic;
}
.card-access {
    position: absolute;
    top: 10px;
    right: 0;
    padding: 2px 6px;
    background-color: white;
    font-size: 10px;
}
.card-text {
    margin-top: 10px;
}
#vt_viewer {
    position: absolute;
    top: 0;
    left: 0;
    display: none;
    width: 100%;
    height: 100vh;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
}
#vt_viewer iframe {
    width: 100%;
    height: 100%;
    background: transparent;
    opacity: 0;
}
#btn_return_globe {
    position: absolute;
    z-index: 11;
    bottom: 150px;
    right: 10px;
    width: max-content;
    display: flex;
    align-items: center;
    flex-direction: row;
    gap: 7px;
    padding: 9px 16px 9px 12px;
    border-radius: 50px;
    background: var(--color-button);
    color: #ffffff;
    font-family: 'Roboto', sans-serif;
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 0.2px;
    box-shadow: 0 3px 10px rgba(26,167,238,0.45);
    cursor: move;
    user-select: none;
}
#btn_return_globe:hover {
    background: #0f8ecf;
    box-shadow: 0 5px 16px rgba(26,167,238,0.6);
}
#btn_return_globe i {
    font-size: 15px;
    color: #ffffff;
    flex-shrink: 0;
}
#btn_return_globe span {
    background: transparent;
    color: #ffffff;
    padding: 0;
    border-radius: 0;
    white-space: nowrap;
}
.logo {
    position: absolute;
    top: 10px;
    left: 10px;
    z-index: 9;
    pointer-events: none;
}
.logo img {
    height: 40px;
}
.vt-card .card-body {
    padding: 15px;
}
.panorama_preview {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 0px;
    opacity: 0;
    pointer-events: none;
    -webkit-transition: opacity 0.3s ease-in-out;
    -moz-transition: opacity 0.3s ease-in-out;
    transition: opacity 0.3s ease-in-out;
}
@media (max-width: 540px) {
    .vt-card {
        width: 200px;
    }
    .vt-card h5 {
        font-size: 12px;
    }
    .vt-card p {
        font-size: 10px;
    }
    .vt-card .card-text {
        margin-top: 5px;
    }
    .vt-card .card-body {
        padding: 10px;
    }
}
#cookie_consent_preferences {
    position: fixed;
    bottom: 16px;
    right: 0;
    padding: 2px 6px;
    background: white;
    color: black;
    cursor: pointer;
    font-size: 12px;
    border-radius: 10px 0 0 10px;
}
#cookie_consent_preferences span {
    display: none;
}
#cookie_consent_preferences:hover span {
    display: inline-block;
}
/* custom */

#map {
    width: 100%;
    height: 100vh;
}

/*#controls {*/
/*    position: absolute;*/
/*    top: 10px;*/
/*    left: 10px;*/
/*    z-index: 1;*/
/*    background: white;*/
/*    padding: 10px;*/
/*    border-radius: 5px;*/
/*}*/

/*#controls label,*/
/*#controls select,*/
/*#controls input,*/
/*#controls button {*/
/*    margin: 5px 0;*/
/*    display: block;*/
/*}*/

/*button {*/
/*    padding: 8px;*/
/*    cursor: pointer;*/
/*    background: #f0f0f0;*/
/*    border: 1px solid #ccc;*/
/*    border-radius: 3px;*/
/*}*/

/*button:hover {*/
/*    background: #e0e0e0;*/
/*}*/

.custom-marker {
    width: 30px;
    height: 41px;
    background-size: cover;
    cursor: pointer;
}

.cluster-marker {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    color: white;
    font-weight: bold;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: 14px;
}

/* Ẩn logo và thông tin bản quyền của Mapbox */
.mapboxgl-ctrl-logo,
.mapboxgl-ctrl-attrib {
    display: none !important;
}

.control-top .left{
    position: absolute;
    left: 15px;
    top: 15px;
}

.control-top .center{
    position: absolute;
    top: 15px;
    left: 70px;
    display: flex;
    gap: 10px;
    align-items: center;
}

.control-top .right{
    position: absolute;
    right: 15px;
    top: 15px;

    display: flex;
    flex-direction: column;
    gap: 10px;
    align-items: anchor-center;
}

.control-center .left {
    position: absolute;
    left: 15px;
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.btn-control{
    cursor: pointer;
    padding: 10px;
    border-radius: 10px;
}

.btn-blue{
    background: var(--color-button);
}

.control-bottom .left {
    position: absolute;
    left: 15px;
    bottom: 15px;
}

.control-bottom .right{
    right: -35px;
    bottom: 0;
    position: absolute;
}

.control-bottom .center{
    position: absolute;
    bottom: 15px;
    left: 50%;
    transform: translateX(-50%);
}

.btn-menu{
    background: #ffffff;
    cursor: pointer;
}

.btn-layer{
    width: 44px;
    height: 44px;
    cursor: pointer;
    position: relative;
}

.btn-layer img {
    width: 100%;
    height: 100%;
    border-radius: 10px;
    border: 2px solid #ffffff;
}

.group-control-2d{
    display: flex;
    gap: 5px;
}

.btn-group-zoom{
    display: flex;
    background: var(--color-button);
    border-radius: 10px;
}

.group-control-2d div{
    height: 44px;
}

.group-control-3d{
    display: flex;
    gap: 5px;
}

.btn-group-rotate{
    display: flex;
    background: var(--color-button);
    border-radius: 10px;
    height: 44px;
}

.btn-group-viewpoint{
    background: var(--color-button);
    border-radius: 10px;
    display: flex;
    flex-direction: column;
}


.control-center .right{
    position: absolute;
    right: 15px;
    top: 50%;
    transform: translateY(-50%);
}

.btn-sidebar{
    background: #ffffff;
    border-radius: 50px;
    width: 44px;
    height: 44px;
}

.btn-group-menu-bottom .btn-control{
    padding: 5px;
}

.btn-home{
    background: var(--color-button);
}

.btn-group-menu-bottom{
    display: flex;
    gap: 30px;
    padding: 10px;
    background: #ffffff;
    border-radius: 15px;
    filter: drop-shadow(0px 5px 15px rgba(0, 0, 0, 0.13));
    position: relative;
    align-items: center;
}

.btn-group-menu-bottom img{
    width: 30px;
}

.btn-space{
    position: absolute;
    left: 0;
    bottom: 0;
    width: 80px;
    height: 80px;
    padding: 0;
}

.btn-space img{
    width: 100%;
    height: 100%;
}

.input-search{
    display: flex;
    background: #ffffff;
    border-radius: 10px;
    width: 300px;
}

.input-search img{
    padding: 10px;
}

.input-search input{
    background: none;
    border: none;
    height: 44px;
    padding-left: 0;
}

.input-search input:focus{
    outline: none;
    box-shadow: none;
}

#province-city, #district{
    width: 220px;
    height: 44px;
    border: 1px solid var(--color-button);
    border-radius: 10px;
    color: var(--color-button);
}

.item_category_view, .show_more_categories{
    display: flex;
    gap: 5px;
    background: #ffffff;
    color: var(--color-button);
    padding: 5px;
    box-shadow: 0px 5px 13px 0px rgba(0, 0, 0, 0.10);
    border-radius: 10px;
    cursor: pointer;
    font-weight: bold;
}

.item_category_view.active{
    background: #9cdeff;
    color: #037ebc;
}

.categories{
    position: relative;
    user-select: none;
}

.view_home{
    display: flex;
    gap: 10px;
}

.popup_category{
    position: absolute;
    right: 0;
    margin-top: 5px;
}

.showMoreSuggestPlace {
    background-color: #fff;
    width: 18.75rem;
    height: 25.625rem;
    font-size: 0.875rem;
    line-height: 1.1875rem;
    box-shadow: 0px 0px 4px #9E9E9E;
    border-radius: 10px 10px 0 0;
    display: flex;
    flex-direction: column;
}
.showMoreSuggestPlace .boxSearchContainer {
    display: flex;
    flex-direction: column;
}
.showMoreSuggestPlace .boxSearchContainer .searchInput {
    background-color: #fff;
    width: 100%;
    border-radius: 10px 10px 0 0;
    border-bottom: 1px solid var(--color-button);
}
.showMoreSuggestPlace .boxSearchContainer .horizontalLine {
    width: 100%;
}
.showMoreSuggestPlace .notFoundSearch {
    margin-top: 3.0625rem;
    padding: 2rem;
    text-align: center;
}
.showMoreSuggestPlace .listGroupPlaceType {
    display: flex;
    flex-direction: column;
    overflow: auto;
}
.showMoreSuggestPlace .listGroupPlaceType .itemGroupPlaceType {
    cursor: pointer;
    display: flex;
    font-size: 0.875rem;
    padding: 0.75rem 1rem;
}
.showMoreSuggestPlace .listGroupPlaceType .itemGroupPlaceType .itemIcon {
    width: 1.5rem;
    height: 1.5rem;
    margin-right: 1rem;
}
.showMoreSuggestPlace .listGroupPlaceType .itemGroupPlaceType .itemName {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    color: var(--color-button);
}
.showMoreSuggestPlace .listGroupPlaceType .itemGroupPlaceType:hover {
    background-color: #f5f7fa;
}
.showMoreSuggestPlace .listPlaceType {
    display: flex;
    flex-direction: column;
    overflow: auto;
}
.showMoreSuggestPlace .listPlaceType .itemPlaceType {
    cursor: pointer;
    padding: 0.90625rem 0.25rem 0.90625rem 1rem;
    color: #5ec6ce;
}
.showMoreSuggestPlace .listPlaceType .itemPlaceType:hover {
    background-color: #f5f7fa;
}
.iconBackShowMoreSuggest {
    cursor: pointer;
}

.itemGroupPlaceType img{
    padding-right: 10px;
    max-width: 32px;
}

.itemGroupPlaceType.active{
    background: #d9d9d9;
}

#close_category{
    display: flex;
    margin: 0 5px;
    cursor: pointer;
}
.popup_categories {
    position: fixed;
    background-color: #fff;
    border-radius: 0.5rem;
    box-shadow: 0px 1.25rem 1.6875rem rgba(0,0,0,.1607843137);
    animation: main .2s;
    overflow: auto;
    right: 462px;
    top: 60px;
    transform-origin: right top;
    max-height: calc(100% - 60px);
    max-width: calc(100% - 460px);
    display: none;
}
.group_search_more {
    position: relative;
    width: 100%;
    display: flex;
    align-items: center;
}
.textInput_search_more {
    width: 100%;
    padding: 0.9375rem 1.125rem;
    outline: none;
    background-color: transparent;
    border: none;
    font-size: .875rem;
    line-height: 1.125rem;
    color: var(--color-button);
}
input.textInput_search_more::placeholder{
    color: var(--color-button);
}
.g_icon_search_more {
    padding-right: 0.8125rem;
    display: flex;
    align-items: center;
    justify-content: center;
}

.list-layer-map{
    display: flex;
    gap: 5px;
    position: fixed;
    right: 15px;
    top: 65px;
    cursor: pointer;
    z-index: 1;
    flex-direction: column;
}

.list-layer-map div{
    width: 44px;
    height: 44px;
    border: 2px solid #ffffff;
    border-radius: 10px;
    position: relative;
}

.list-layer-map img{
    width: 100%;
    height: 100%;
    border-radius: 8px;
}

.list-layer-map span, .btn-layer span{
    position: absolute;
    left: 0;
    bottom: 0;
    font-size: 10px;
    background: #9e9e9ec2;
    color: #ffffff;
    width: 100%;
    text-align: center;
    border-radius: 0 0 8px 8px;
}

/*menu*/

.menu-left{
    position: fixed;
    z-index: 999;
    left: -250px;
    right: 0;
    bottom: 0;
    top: 0;
    transition: all 0.5s ease;
    display: none;
}

.overlay{
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    right: 0;
    background: #9e9e9e38;
}

.sidebar ul {
    list-style: none;
    padding: 0;
    color: var(--color-button);
    overflow: auto;
}

.sidebar {
    width: 300px;
    background: #ffffff;
    color: #555;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    padding: 0.25rem;

    position: absolute;
    left: 0;
    height: 100%;
    z-index: 9991;
}

.list {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.list li {
    cursor: pointer;
    letter-spacing: 1px;
}

.list-title {
    display: flex;
    gap: 0.5rem;
    align-items: center;
    width: 100%;
    padding: 0.5rem;
    border-radius: 0.25rem;
}

.list-title > * {
    pointer-events: none;
}

.list-title .chevron {
    margin-left: auto;
    color: var(--color-button);
}

.list-title:hover,
.list-title.active,
.list.inner li:hover {
    background: #ddd;
}

.list.inner {
    height: 0;
    overflow: hidden;
    transition: height 200ms ease;
}

.list.inner li {
    padding: 0.5rem;
    border-radius: 0.25rem;
    padding-left: 1rem;
    display: flex;
    gap: 5px;
    align-items: center;
}

.list-title.active .chevron {
    transform: rotate(90deg);
}

.logo-menu{
    padding: 10px;
    font-weight: bold;
    color: var(--color-button);
    font-size: 24px;
    display: flex;
    align-items: center;
    gap: 10px;
}

.logo-menu img{
    width: 50px;
}

.btn-close-menu{
    position: absolute;
    top: 15px;
    left: 300px;
    background: var(--color-button);
    padding: 5px;
    border-radius: 0 5px 5px 0;
    cursor: pointer;
}

.modal-popup{
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.25);
    display: none;
    z-index: 800;
}

.modal-popup-content {
    aspect-ratio: 1.6 / 1;
    width: 50%;
    background: #ffffff;
    overflow: hidden;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    border-radius: 15px;
}

.modal-popup-header {
    display: flex;
    padding: 15px;
    justify-content: space-between;
    align-items: center;
}

.modal-popup-title {
    text-align: center;
    width: 100%;
    text-transform: uppercase;
    font-weight: bold;
    font-size: 20px;
}

.btn-close-popup{
    cursor: pointer;
    width: 30px;
}

.modal-popup-body{
    height: calc(100% - 60px);
}

.item-game{
    box-shadow: 0px 5px 15px 0px rgba(0, 0, 0, 0.13);
    background: var(--color-button);
    border-radius: 15px;
}

.item-game img{
    width: 100%;
    border-radius: 15px 15px 0 0;
}

.g-name {
    display: flex;
    padding: 10px;
    justify-content: space-between;
    align-items: center;
}

.g-name .name-game{
    color: #ffffff;
}

.g-name .play-now{
    background: #ffffff;
    color: var(--color-button);
    padding: 5px 10px;
    border-radius: 15px;
    cursor: pointer;
}

.g-name .play-now:hover{
    scale: 1.1
}

#close-while{
    display: none;
}

.btn-back-list-game{
    position: absolute;
    left: 15px;
    top: 15px;
    background: var(--color-button);
    padding: 5px 4px;
    border-radius: 5px;
    cursor: pointer;
}

/* Instruct popup — S4 style */
.popup-instruct .modal-popup-content{
    background:linear-gradient(150deg,#0b3d60 0%,#1A6FA8 55%,#1e88c8 100%);
}
.popup-instruct .modal-popup-title{color:#fff;font-size:15px}
.popup-instruct #close-while{display:block}
.popup-instruct #close-black{display:none}
.popup-instruct .modal-popup-body{padding:16px 20px 12px}

.group-instruct{
    display:flex;gap:0;color:#fff;
}
.instruct-col-left{
    flex:0 0 230px;
    padding:16px 14px;
    border-right:1px solid rgba(255,255,255,.1);
}
.instruct-col-right{
    flex:1;padding:16px 14px;
}
.instruct-col-title{
    font-size:10px;font-weight:700;letter-spacing:1.2px;
    text-transform:uppercase;color:rgba(255,255,255,.5);
    margin-bottom:12px;padding-left:4px;
}

/* Left column — horizontal list */
.instruct-left{display:flex;flex-direction:column;gap:4px}
.instruct-left .item-instruct{
    display:flex;align-items:center;gap:11px;
    padding:7px 8px;border-radius:10px;
    transition:background .15s;cursor:default;
}
.instruct-left .item-instruct:hover{background:rgba(255,255,255,.08)}
.instruct-left .item-instruct:last-child{margin-top:6px;opacity:.45}
.ig-ico{
    width:36px;height:36px;border-radius:9px;flex-shrink:0;
    background:rgba(255,255,255,.15);
    display:flex;align-items:center;justify-content:center;
}
.ig-ico svg{width:18px;height:18px}
.ig-ico img{width:26px;height:26px;object-fit:contain}
.instruct-left .item-instruct > span{
    font-size:12.5px;font-weight:500;line-height:1.3;
}

/* Right column — icon grid */
.instruct-right{
    display:grid;grid-template-columns:repeat(4,1fr);
    gap:14px 8px;text-align:center;
}
.instruct-right .item-instruct{
    display:flex;flex-direction:column;align-items:center;gap:8px;
}
.ig-ico-lg{
    width:52px;height:52px;border-radius:13px;
    background:rgba(255,255,255,.15);
    display:flex;align-items:center;justify-content:center;
    transition:background .15s;cursor:default;
}
.ig-ico-lg:hover{background:rgba(255,255,255,.25)}
.ig-ico-lg svg{width:24px;height:24px}
.ig-ico-lg img{width:36px;height:36px;object-fit:contain}
.instruct-right .item-instruct > span{
    font-size:11px;font-weight:500;color:rgba(255,255,255,.9);
    line-height:1.3;
}
.ig-mode-badge{
    width:52px;height:52px;border-radius:13px;
    background:rgba(255,255,255,.15);
    border:1.5px solid rgba(255,255,255,.4);
    display:flex;align-items:center;justify-content:center;
    font-weight:800;font-size:14px;letter-spacing:.5px;color:#fff;
    transition:background .15s;
}
/* Mobile: bỏ double background/border khi nằm trong ig-row-ico */
.ig-row-ico .ig-mode-badge{
    width:18px;height:18px;border-radius:4px;
    background:transparent;border:none;
    font-size:12px;padding:0;
}

@media(max-width:600px){
    .group-instruct{flex-direction:column}
    .instruct-col-left{flex:none;border-right:none;border-bottom:1px solid rgba(255,255,255,.1)}
    .instruct-right{grid-template-columns:repeat(3,1fr)}
}

/* Mobile instruct — single column list */
.ig-mobile-list{
    display:flex;flex-direction:column;
    color:#fff;padding:12px 16px;
    min-height:100%;box-sizing:border-box;
}
.ig-row{
    display:flex;align-items:center;gap:14px;
    padding:10px 8px;border-radius:10px;
    transition:background .15s;
}
.ig-row:hover{background:rgba(255,255,255,.08)}
.ig-row-ico{
    width:36px;height:36px;flex-shrink:0;border-radius:9px;
    background:rgba(255,255,255,.15);
    display:flex;align-items:center;justify-content:center;
}
.ig-row-ico svg{width:18px;height:18px}
.ig-row-ico img{width:24px;height:24px;object-fit:contain}
.ig-row-lbl{
    font-size:13px;font-weight:500;line-height:1.3;
    flex:1;
}
.ig-copyright{
    margin-top:auto;padding-top:20px;
    display:flex;justify-content:center;opacity:.5;
}

/*------------------*/

.popup-event {
    position:fixed;
    left:calc(var(--s4-sb-w) + var(--s4-sb-m) * 2);
    top:10px;
    bottom:8px;
    width:300px;
    background:rgba(255,255,255,.95);
    backdrop-filter:blur(14px);
    -webkit-backdrop-filter:blur(14px);
    border-radius:16px;
    border:1px solid rgba(255,255,255,.6);
    box-shadow:0 4px 24px rgba(0,0,0,.12);
    z-index:600;
    display:none;
    flex-direction:column;
    overflow:hidden;
}
#s4-sidebar.closed ~ .popup-event{
    left:calc(var(--s4-sb-m) + 22px + var(--s4-sb-m));
}
.popup-event .popup-header {
    display:flex;align-items:center;gap:10px;
    padding:14px 14px 0;flex-shrink:0;
}
.popup-event .popup-body{
    flex:1;min-height:0;overflow:hidden;
    display:flex;flex-direction:column;
    padding:0 14px 14px;margin-top:10px;
}


.tabs-wrapper{height:100%;display:flex;flex-direction:column}

.btn-close-event{
    padding: 8px;flex-shrink:0;
    display:flex;align-items:center;justify-content:center;
    background:rgba(0,0,0,.06);border-radius:50%;cursor:pointer;
    color:#555;transition:background .15s,color .15s;
}
.btn-close-event:hover{background:rgba(220,50,50,.1);color:#e53935}

.g-popup-title{display:flex;align-items:baseline;justify-content:space-between;flex:1;min-width:0;gap:8px}
.popup-title{font-weight:700;font-size:16px;color:#1a1a2e;white-space:nowrap}
.popup-time{font-size:11px;color:#999;white-space:nowrap}

.tabs{list-style:none;padding:0;margin:10px 0 0;display:flex;border-bottom:1px solid rgba(0,0,0,.08);flex-shrink:0}
.tabs li{cursor:pointer;flex:1;text-align:center;padding:8px 0;display:flex;align-items:center;justify-content:center;gap:5px;color:#aaa;font-weight:600;font-size:13px;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .2s,border-color .2s}
.tabs li:hover{color:var(--s4-primary,#1A6FA8)}
.tabs li.active{color:var(--s4-primary,#1A6FA8);border-bottom-color:var(--s4-primary,#1A6FA8)}

#tab-news:before{content:url('/globe/img/icons/news.svg')}
#tab-news.active:before{content:url('/globe/img/icons/news_active.svg')}
#tab-event:before{content:url('/globe/img/icons/event.svg')}
#tab-event.active:before{content:url('/globe/img/icons/event_active.svg')}

.tab-content-wrapper{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding-top:10px}
.tab-content-wrapper::-webkit-scrollbar{width:4px}
.tab-content-wrapper::-webkit-scrollbar-thumb{background:rgba(0,0,0,.12);border-radius:4px}

.item-event-news{display:flex;gap:10px;margin-bottom:10px;align-items:flex-start;border:1px solid rgba(0,0,0,.07);border-radius:12px;padding:8px;background:#fff;transition:box-shadow .15s}
.item-event-news:hover{box-shadow:0 2px 12px rgba(0,0,0,.08)}
.item-event-news:last-child{margin-bottom:0}
.item-event-news img{width:72px;height:72px;object-fit:cover;border-radius:8px;flex-shrink:0}
.g-info-event-news{flex:1;min-width:0}
.title-event-news{color:var(--s4-primary,#1A6FA8);font-weight:600;font-size:13px;margin-bottom:5px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}
.desc-event-news{font-size:11px;color:#666;line-height:1.4;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}

.group-instruct .left{
    border-right: 1px solid var(--color-button);
}
/*-----------------------------*/
/* ===== S4 LIST PANEL ===== */
.popup-list-tour{
    position:fixed;
    right:10px;
    top:10px;
    bottom:8px;
    height:auto;
    width:300px;
    background:rgba(255,255,255,0.95);
    backdrop-filter:blur(14px);
    -webkit-backdrop-filter:blur(14px);
    border-radius:16px;
    border:1px solid rgba(255,255,255,0.6);
    box-shadow:0 4px 24px rgba(0,0,0,0.12);
    display:flex;
    flex-direction:column;
    overflow:hidden;
    z-index:200;
    transform:translateX(calc(100% + 20px));
    opacity:0;
    pointer-events:none;
    transition:transform .25s ease,opacity .25s ease;
}
.popup-list-tour.s4-open{
    transform:translateX(0);
    opacity:1;
    pointer-events:auto;
}
.s4-lt-header{
    display:flex;
    align-items:center;
    gap:8px;
    padding:14px 14px 0;
}
.s4-lt-title-wrap{
    flex:1;
    display:flex;
    align-items:center;
    gap:8px;
    min-width:0;
}
.title-list-tour,.s4-lt-title{
    font-size:15px;
    font-weight:700;
    color:#1a1a2e;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
}
.s4-lt-count{
    background:var(--s4-primary,#1A6FA8);
    color:#fff;
    font-size:10px;
    font-weight:600;
    padding:2px 7px;
    border-radius:20px;
    white-space:nowrap;
    flex-shrink:0;
}
.s4-lt-close{
    width:26px;height:26px;
    border:none;background:rgba(0,0,0,0.06);
    border-radius:50%;cursor:pointer;
    display:flex;align-items:center;justify-content:center;
    flex-shrink:0;color:#555;
    transition:background .15s;
    -webkit-appearance:none;appearance:none;outline:none;
    padding:0;
}
.s4-lt-close:hover{background:rgba(0,0,0,0.12)}
.s4-lt-sub{
    font-size:11px;color:#888;
    padding:2px 14px 8px;
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.s4-lt-search{
    margin:0 10px 8px;
    display:flex;align-items:center;gap:6px;
    background:rgba(0,0,0,0.05);
    border-radius:8px;padding:6px 10px;
}
.s4-lt-search input{
    border:none;background:transparent;outline:none;
    font-size:12px;width:100%;color:#333;
}
.s4-lt-search svg{flex-shrink:0;color:#999}
.s4-lt-search-clear{
    border:none;background:transparent;padding:3px;cursor:pointer;
    display:flex;align-items:center;justify-content:center;
    color:#999;flex-shrink:0;
    border-radius:50%;transition:color .15s,background .15s;
}
.s4-lt-search-clear:hover{color:#333;background:rgba(0,0,0,0.1)}
.popup-list-tour-content{
    height:calc(100% - 105px);
    overflow-y:auto;
    overflow-x:hidden;
    padding:0 10px 10px;
}
.popup-list-tour-content .item-tour{
    margin-bottom:8px;
}
.popup-list-tour-content .item-tour:last-child{
    margin-bottom:0;
}
.popup-list-tour-content::-webkit-scrollbar{width:4px}
.popup-list-tour-content::-webkit-scrollbar-thumb{background:rgba(0,0,0,0.15);border-radius:4px}

/* S4 Tour Card */
.item-tour{
    background:#fff;
    border:1px solid rgba(0,0,0,0.08);
    border-radius:12px;
    padding:10px;
    display:flex;gap:10px;
    align-items:flex-start;
    cursor:pointer;
    transition:box-shadow .15s,border-color .15s;
}
.item-tour:hover{box-shadow:0 2px 12px rgba(26,111,168,.12);border-color:rgba(26,111,168,.25)}
.info-tour{flex:1;min-width:0;display:flex;flex-direction:column;gap:5px}
.tour-meta{display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.cat-label{
    font-size:9px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;
    color:var(--s4-primary,#1A6FA8);
}
.vr-badge{
    font-size:9px;font-weight:700;
    background:var(--s4-primary,#1A6FA8);color:#fff;
    padding:1px 5px;border-radius:4px;letter-spacing:.3px;
}
.title-tour{
    font-size:13px;font-weight:600;color:#1a1a2e;
    display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
    overflow:hidden;text-overflow:ellipsis;line-height:1.35;
}
.rating-tour{
    display:flex;align-items:center;gap:4px;font-size:11px;color:#555;
}
.rating-stars{color:#f5a623;font-size:11px;letter-spacing:1px}
.button-location{display:flex;align-items:center;gap:6px;margin-top:2px}
.btn-view-location{
    display:flex;align-items:center;gap:5px;
    border:1.5px solid var(--s4-primary,#1A6FA8);
    color:var(--s4-primary,#1A6FA8);
    background:rgba(26,111,168,.06);
    border-radius:20px;padding:4px 10px;
    font-size:11px;font-weight:600;cursor:pointer;
    transition:background .15s,color .15s;
    white-space:nowrap;
}
.btn-view-location:hover{background:var(--s4-primary,#1A6FA8);color:#fff}
.btn-view-location svg{flex-shrink:0}
.btn-direction{
    width:28px;height:28px;border-radius:50%;
    border:1.5px solid rgba(0,0,0,0.15);
    display:flex;align-items:center;justify-content:center;
    cursor:pointer;color:#555;
    transition:border-color .15s,color .15s;
    flex-shrink:0;
}
.btn-direction:hover{border-color:var(--s4-primary,#1A6FA8);color:var(--s4-primary,#1A6FA8)}
.btn-visit-vr360{
    display:flex;align-items:center;gap:4px;
    background:var(--s4-primary,#1A6FA8);color:#fff;
    border-radius:20px;padding:4px 10px;
    font-size:11px;font-weight:600;cursor:pointer;
    transition:background .15s;white-space:nowrap;
}
.btn-visit-vr360:hover{background:#155e8f}
.img-tour{
    width:56px;height:56px;
    border-radius:10px;
    object-fit:cover;
    flex-shrink:0;
    background:#e8eef3;
}
.img-tour-placeholder{
    width:56px;height:56px;border-radius:10px;
    background:linear-gradient(135deg,#e8eef3,#d0dde8);
    display:flex;align-items:center;justify-content:center;
    flex-shrink:0;font-size:22px;
}
.btn-close-list-tour{display:none}
/*-------------------*/
/* ── Popup list vrtour – redesign ── */
.popup-list-vrtour .modal-popup-content{
    aspect-ratio: unset !important;
    width: 900px;
    max-width: 96vw;
    height: 88vh;
    max-height: 760px;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    box-shadow: 0 24px 64px rgba(0,0,0,.22);
}

.popup-list-vrtour .modal-popup-header{
    padding: 16px 20px;
    border-bottom: 1px solid #f0f0f0;
    background: #fff;
    flex-shrink: 0;
}
.popup-list-vrtour .modal-popup-body{
    height: 0;
    flex: 1;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.popup-list-vrtour .modal-popup-title{
    font-size: 15px;
    font-weight: 700;
    text-transform: none;
    letter-spacing: 0;
    color: var(--s4-text);
    text-align: left;
}

.header-list-vrtour{
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 20px;
    flex-shrink: 0;
    border-bottom: 1px solid #f0f0f0;
    background: #fafafa;
    height: 56px;
    box-sizing: border-box;
}

.vrtour-search-wrap{
    flex: 1;
    display: flex;
    align-items: center;
    gap: 8px;
    background: #fff;
    border: 1px solid #e0e0e0;
    border-radius: 8px;
    padding: 0 12px;
    height: 34px;
    min-height: 34px;
    max-height: 34px;
    box-sizing: border-box;
    align-self: center;
}
.vrtour-search-wrap svg{color: #aaa;flex-shrink:0}
.vrtour-search-clear{
    border:none;background:transparent;padding:3px;cursor:pointer;
    display:flex;align-items:center;justify-content:center;
    color:#aaa;flex-shrink:0;
    border-radius:50%;transition:color .15s,background .15s;
}
.vrtour-search-clear:hover{color:#333;background:#f0f0f0}
.vrtour-search-wrap input{
    border: none;outline: none;background: transparent;
    font-size: 13px;width: 100%;color: #333;height: 100%;line-height:1;
}

select#filter-vrtour{display:none}

/* Custom dropdown */
.vrtour-dd{position:relative;flex-shrink:0;width:160px}
.vrtour-dd-btn{
    display:flex;align-items:center;justify-content:space-between;gap:6px;
    height:34px;min-height:34px;max-height:34px;width:100%;padding:0 10px;
    border:1px solid #e0e0e0;border-radius:8px;background:#fff;
    font-size:13px;color:#555;cursor:pointer;user-select:none;
    box-sizing:border-box;align-self:center;
}
.vrtour-dd-btn:hover{border-color:#bbb}
.vrtour-dd-drop{
    display:none;position:absolute;top:calc(100% + 4px);right:0;
    width:200px;background:#fff;border:1px solid #e0e0e0;border-radius:10px;
    box-shadow:0 6px 20px rgba(0,0,0,.12);z-index:999;overflow:hidden;
}
.vrtour-dd-drop.open{display:block}
.vrtour-dd-search-wrap{
    display:flex;align-items:center;gap:6px;padding:8px 10px;
    border-bottom:1px solid #f0f0f0;
}
.vrtour-dd-search-wrap svg{color:#aaa;flex-shrink:0}
.vrtour-dd-search-wrap input{
    border:none;outline:none;font-size:12px;width:100%;color:#333;
}
.vrtour-dd-opts{max-height:220px;overflow-y:auto}
.vrtour-dd-opts::-webkit-scrollbar{width:3px}
.vrtour-dd-opts::-webkit-scrollbar-thumb{background:rgba(0,0,0,.12);border-radius:3px}
.vrtour-dd-opt{
    padding:7px 12px;font-size:13px;color:#444;cursor:pointer;
}
.vrtour-dd-opt:hover{background:#f5f5f5}
.vrtour-dd-opt.active{background:#eef4ff;color:var(--s4-primary);font-weight:600}

.vrtour-count{
    font-size: 12px;color: #999;white-space: nowrap;flex-shrink:0;
}

.body-list-vrtour {
    flex: 1;
    overflow-y: auto;
    padding: 16px 20px;
}
.body-list-vrtour::-webkit-scrollbar{width:4px}
.body-list-vrtour::-webkit-scrollbar-thumb{background:rgba(0,0,0,.12);border-radius:4px}

.body-list-vrtour .container{max-width:100%;padding:0}
.body-list-vrtour .row{margin:0 -6px}

.body-list-vrtour .col-md-4{
    padding: 6px;
}

.item-vrtour {
    border-radius: 12px;
    position: relative;
    overflow: hidden;
    box-shadow: 0 2px 10px rgba(0,0,0,.1);
    cursor: pointer;
    transition: transform .2s, box-shadow .2s;
}
.item-vrtour:hover{
    transform: translateY(-3px);
    box-shadow: 0 8px 24px rgba(0,0,0,.18);
}

.item-vrtour img{
    width: 100%;
    border-radius: 12px;
    aspect-ratio: 4/3;
    object-fit: cover;
    display: block;
}

.name-vrtour {
    position: absolute;
    bottom: 0;left: 0;right: 0;
    color: #ffffff;
    padding: 20px 10px 8px;
    background: linear-gradient(to top, rgba(0,0,0,.65) 0%, transparent 100%);
    border-radius: 0 0 12px 12px;
    font-size: 13px;
    font-weight: 600;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* category badge on card */
.vrtour-cat-badge{
    position: absolute;
    top: 8px;left: 8px;
    background: rgba(0,0,0,.45);
    backdrop-filter: blur(4px);
    color: #fff;font-size: 10px;
    padding: 2px 7px;border-radius: 20px;
}

/* VR360 badge on grid card */
.vrtour-vr-badge{
    position: absolute;
    top: 8px;right: 8px;
    background: var(--s4-primary);
    color: #fff;font-size: 10px;font-weight: 600;
    padding: 2px 7px;border-radius: 20px;
}

/* Pagination */
.vrtour-footer{
    display: flex;align-items: center;justify-content: space-between;
    padding: 8px 16px;border-top: 1px solid #f0f0f0;
    background: #fafafa;flex-shrink: 0;gap:10px;
}
.vrtour-count{font-size:12px;color:#999;white-space:nowrap;flex-shrink:0}
.vrtour-footer .pagination-vrtour{margin-left:auto}
.paginationjs{margin:0}
.paginationjs .paginationjs-pages li{border:none !important}
.paginationjs .paginationjs-pages li:last-child{border-right:none !important}
.paginationjs .paginationjs-pages li.active>a{
    background:var(--s4-primary) !important;border-radius:6px;color:#fff;
}
.paginationjs-nav{font-size:12px;color:#999}

.paginationjs {
    margin-right: 5px;
    flex-direction: row-reverse;
}

.paginationjs .paginationjs-pages li {
    border: none !important;
}

.paginationjs .paginationjs-pages li:last-child {
    border-right: none !important;
}

.paginationjs .paginationjs-pages li.active>a{
    background: var(--color-button) !important;
}

.no-data{
    width: 100%;
    text-align: center;
    position: absolute;
    top: 50%;
}

.body-list-vrtour .container{
    height: 100%;
}

/*#copyright{*/
/*    width: 100%;*/
/*}*/
/*-------------------------------*/

.popup-play-game iframe{
    border: none;
}

.province-district-mobile {
    gap: 10px;
    margin-bottom: 10px;
    display: none;
}

.province-district-mobile select {
    border-color: var(--color-button);
    color: var(--color-button);
}
/*-------------------------------*/
.mapboxgl-popup-close-button{
    display: none;
}

.mapboxgl-popup{
    top: -25px !important;
}

.mapboxgl-popup-content {
    width: 300px;
    padding: 1px !important;
    border-radius: 0px !important;
}

.marker-tour{
    font-size: 16px;
}

.img-tour-marker{
    width: 100%;
    position: relative;
}

.img-tour-marker img{
    width: 100%;
    aspect-ratio: 1.7 / 1;
    object-fit: cover;
}

.view-marker{
    position: absolute;
    background: var(--color-button);
    color: #ffffff;
    text-align: right;
    padding: 7px 10px;
    top: 10px;
    right: 0;
    border-radius: 10px 0 0 10px;
    font-size: 16px;
    display: flex;
    align-items: center;
    justify-content: space-around;
    gap: 10px;
}

.group-info-marker {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 10px;
}

.name-marker{
    font-weight: 600;
    font-size: 20px;
    line-height: 1.3;
}

.name-marker, .desc-marker {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.rating-marker{
    display: flex;
    gap: 5px;
}

.rating-marker span{
    width: 2px;
    background: var(--color-button);
}

.total-rate{
    font-weight: 600;
    color: #5c5c5c;
}

.btn-marker {
    display: flex;
    gap: 10px;
    justify-content: space-between;
    align-items: center;
}

.btn-join-tour-marker {
    background: var(--color-button);
    padding: 10px 15px;
    display: flex;
    align-items: center;
    gap: 10px;
    color: #ffffff;
    border-radius: 10px;
    cursor: pointer;
}

.btn-join-tour-marker:hover{
    color: #ffffff;
    text-decoration: none;
}

.btn-view-location-marker, .btn-direct-marker {
    border: 1px solid var(--color-button);
    padding: 7px;
    border-radius: 10px;
    cursor: pointer;
}

.color-default{
    color: var(--color-button);
}

/*-------------------------------*/
.star-rate{
    color: var(--color-button);
    font-weight: bold;
}

.starsEl{
    color: #cdcdcd;
    font-weight: unset;
    cursor: pointer;
}

.starsEl.active{
    font-weight: 900;
    color: var(--color-button);
}
/*-----------------*/
.map_background {
    display: flex;
    align-items: center;
    gap: 10px;
}

.map_background img{
    width: 40px;
    object-fit: cover;
}

.language-menu{
    display: flex;
    gap: 10px;
    align-items: center;
}

.language-menu img{
    width: 20px;
    object-fit: cover;
}

.item_category_view img{
    width: 20px;
    height: 20px;
}

.list.inner li.active {
    background: #dddddd;
}

.group-input-search{
    position: relative;
}

.list-vt-search {
    position: absolute;
    background: #ffffff;
    width: 100%;
    color: var(--color-button);
    top: 44px;
    border-radius: 10px;
}

.item-vt-search {
    padding: 8px 15px;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 5px;
}

.item-vt-search:last-child{
    border-radius: 0 0 10px 10px;
}

.item-vt-search:hover{
    background: var(--color-button);
    color: #ffffff;
}

.icon-search-location{
    content: url("/globe/img/icons/location_search.svg");
}

.item-vt-search:hover .icon-search-location{
    content: url("/globe/img/icons/location_search_w.svg");
}

.list-vt-search{
    display: none;
}

.group-input-search.active .input-search{
    border-radius: 10px 10px 0 0;
}

.group-input-search.active .list-vt-search{
    border-radius: 0 0 10px 10px;
    border-top: 1px solid var(--color-button);
}
/*----------------------------------------*/
.group-rating {
    width: min-content;
    font-size: 16px;
    color: #a9a9a9;
    position: relative;
}

.star {
    display: flex;
}

.star.yellow {
    color: var(--color-button);
}

.rating {
    width: var(--percent, 0%);
    height: 100%;
    overflow: hidden;
}

.grey {
    position: absolute;
    left: 50%;
    top: 50%;
    translate: -50% -50%;
    z-index: -1;
}

.rating-tour {
    display: flex;
    align-items: center;
    justify-content: space-between;
}
/*-----------------------------------------------------*/
#background_loading{
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1000;
    background-size: cover;
}

#background_loading img.bg_img{
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.btn_join_globe{
    background: var(--background17);
    width: max-content;
    padding: 10px 15px;
    border-radius: 50px;
    font-weight: 600;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    bottom: 50px;
    cursor: pointer;
    font-size: 24px;
    box-shadow: 0 0 5px 1px #0d60a6;
    border: 2px solid #51C1FA;
    background: linear-gradient(84deg, #1AA7EE 1.01%, #29C5DE 102.12%);
    color: #ffffff;

    display: flex;
    align-items: center;
    gap: 10px;
}

.logo_vr{
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    top: 20px;
}

.group_logo{
    position: absolute;
    left: 60px;
    bottom: 30px;
    display: flex;
    align-items: center;
    gap: 10px;
}

.group_logo div{
    font-size: 28px;
    font-weight: 700;
    text-shadow: 0px 4px 3px rgba(0,0,0,0.4), 0px 8px 13px rgba(0,0,0,0.1), 0px 18px 23px rgba(0,0,0,0.1);
    color: #02427f;
    text-transform: uppercase;
}

/*custom select 2*/
.province-city .select2-selection,
.district .select2-selection,
.header-list-vrtour .select2-selection{
    border: 1px solid var(--color-button);
    border-radius: 10px;
    height: 44px;
    outline: none;
}

.select2-container--open .select2-selection{
    border-radius: 10px 10px 0 0;
}

.select2-selection__rendered{
    color: var(--color-button) !important;
    line-height: 44px !important;
    outline: none !important;
}

.select2-selection__arrow{
    height: 44px !important;
}

.select2-selection__arrow b{
    border-color: var(--color-button) transparent transparent transparent !important;
}

.select2-container--open .select2-selection__arrow b{
    border-color: transparent transparent var(--color-button) transparent !important;
}

.select2-search__field:focus-visible{
    outline: none;
}

.select2-container--default .select2-search--dropdown .select2-search__field{
    border: 1px solid var(--color-button);
}

.select2-dropdown{
    border: 1px solid var(--color-button);
    border-top: 0;
}

.select2-results__option--selectable {
    color: var(--color-button);
}

.select2-container--default .select2-results>.select2-results__options{
    max-height: 400px;
}
/*end select 2*/

/* directions */
#sidebar-directions{
    position: absolute;
    min-width: 300px;
    max-width: 350px;
    max-height: 350px;
    background: #ffffff;
    top: 50%;
    left: 15px;
    z-index: 9;
    transform: translateY(-50%);
    padding: 10px;
    border-radius: 10px;
    display: none;
}

#sidebar-directions.active{
    display: block;
}

.start-directions input:focus-visible{
    outline: none !important;
}

.start-directions input,
.end-directions input{
    border: 1px solid #9E9E9E;
    padding: 5px;
    border-radius: 5px;
    width: 100%;
}

.header-directions {
    display: flex;
    justify-content: space-between;
    margin-bottom: 15px;
}

.header-directions .title{
    color: var(--color-button);
    font-weight: bold;
}

#exitDirections {
    cursor: pointer;
}

.content-directions {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.start-directions,
.end-directions {
    display: flex;
    flex-direction: column;
}

#moveBtn{
    background: var(--color-button);
    color: #ffffff;
    padding: 5px 10px;
    border-radius: 5px;
    box-shadow: 0px 0px 3px #607D8B;
    text-align: center;
    cursor: pointer;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    gap: 10px;
}

.circle-marker {
    width: 14px;
    height: 14px;
    background-color: green;
    border: 2px solid white;
    border-radius: 50%;
    box-shadow: 0 0 2px rgba(0, 0, 0, 0.5);
}

/* tooltip */
.tooltip-custom {
    position: relative;
    display: inline-block;
}

.tooltip-custom .tooltiptext {
    visibility: hidden;
    position: absolute;
    width: 130px;
    background-color: var(--color-button);
    color: #fff;
    text-align: center;
    padding: 5px;
    border-radius: 6px;
    z-index: 1;
    opacity: 0;
    transition: opacity .6s;
}

.tooltip-top {
    bottom: 125%;
    left: 50%;
    margin-left: -65px;
}

.tooltip-top::after {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    margin-left: -5px;
    border-width: 5px;
    border-style: solid;
    border-color: var(--color-button) transparent transparent transparent;
}

.tooltip-right {
    top: 50%;
    left: 125%;
    transform: translateY(-50%);
}

.tooltip-right::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 100%;
    margin-top: -5px;
    border-width: 5px;
    border-style: solid;
    border-color: transparent var(--color-button) transparent transparent;
}

.tooltip-bottom {
    top: 135%;
    left: 50%;
    margin-left: -60px;
}

.tooltip-bottom::after {
    content: "";
    position: absolute;
    bottom: 100%;
    left: 50%;
    margin-left: -5px;
    border-width: 5px;
    border-style: solid;
    border-color: transparent transparent var(--color-button) transparent;
}

.tooltip-left {
    top: 50%;
    bottom: auto;
    right: 128%;
    transform: translateY(-50%);
}

.tooltip-left::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 100%;
    margin-top: -5px;
    border-width: 5px;
    border-style: solid;
    border-color: transparent transparent transparent var(--color-button);
}

.tooltip-custom:hover .tooltiptext {
    visibility: visible;
    opacity: 1;
}
/*end tooltip*/



.message.bot p * {
    color: #000 !important;
    font-size: 14px !important;
    line-height: 1.6 !important;
    margin: 0;
    padding: 0;
    text-decoration: none !important;
    box-shadow: none;
    border: none;
}

.message.bot a{
    color: #0056b3 !important;
}

.message li{
    list-style: none;
}

#copyright{
    right: 40px;
    position: absolute;
    bottom: 5px;
    opacity: .7;
}

.btn-contribute{
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    top: -40px;
}

.btn-contribute img{
    width: 70px;
    height: 70px;
}

.g-contribute{
    display: flex;
    flex-direction: column;
    color: var(--color-button);
}

.g-btn-contribute{
    display: flex;
    position: absolute;
    top: -40px;
    left: 50%;
    gap: 20px;
    align-items: center;
    justify-content: center;
    transform: translateX(-52%);
}

.g-btn-contribute div{
    box-shadow: 0 0 4px 0 #607D8B;
    border-radius: 50%;
}

.g-btn-contribute img{
    width: 45px;
    height: 45px;
}

.content-ticket{
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
    font-size: 30px;
    color: var(--color-button);
}

.contribute-ideas .modal-popup-content{
    width: 400px;
    aspect-ratio: 1/1.3
}

.form-contribute-ideas {
    overflow: auto;
    height: calc(100% - 10px);
    padding: 0 10px;
}

.required:after{
    content: ' (*)';
    color: red;
}

.custom-marker-tooltip {
    position: absolute;
    left: 40px;
    top: 50%;
    padding: 4px 10px;
    background: linear-gradient(to right, var(--color-button), #1aa7eebd);
    color: white;
    border-radius: 10px;
    font-size: 12px;
    white-space: nowrap;
    pointer-events: none;
    transform: translateY(-50%);
    display: none;
}

.custom-marker:hover .custom-marker-tooltip:not(.always-show) {
    display: block;
}

.custom-marker-tooltip.always-show {
    display: block !important;
}

.custom-marker-tooltip::after {
    content: "";
    position: absolute;
    left: -5px;
    top: 7px;
    width: 14px;
    height: 14px;
    background: var(--color-button);
    border-radius: 0 0 0 10px;
    transform: rotate(225deg);
    z-index: -1;
}

.g_start_point{
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.g_start_point img{
    border: 1px solid #9e9e9e;
    padding: 5px;
    border-radius: 5px;
    cursor: pointer;
}

#change_route{
    border: 1px solid #9e9e9e;
    padding: 10px;
    border-radius: 50px;
    cursor: pointer;
    margin-bottom: .5rem;
}

.cat_show_map{
    display: none !important;
}

html, body, #cesiumContainer { width: 100%; height: 100%; margin: 0; padding: 0; overflow: hidden; }
#cesiumContainer .cesium-viewer-bottom { display: none }
#toolbar {position: absolute; top: 15px; left: 15px; z-index: 10;background: rgba(0, 0, 0, 0.85); padding: 10px; border-radius: 8px;display: flex; align-items: center; border: 1px solid #444; backdrop-filter: blur(4px); gap: 10px;}
button {cursor: pointer; padding: 8px 14px; background: #222; color: #fff;border: 1px solid #555; border-radius: 4px; font-family: sans-serif; transition: 0.2s;}
button:hover{background: #333;}
.active { border-color: #fff; font-weight: bold; }
/* Popup Styling — S4 */
.cesium-popup{
    position:fixed;
    bottom:80px;
    left:50%;transform:translateX(-50%);
    display:none;z-index:500;width:320px;
    background:#fff;border-radius:16px;
    box-shadow:0 8px 32px rgba(0,0,0,.18),0 2px 8px rgba(0,0,0,.1);
    font-family:'Be Vietnam Pro','Montserrat',Arial,sans-serif;
    pointer-events:auto;overflow:hidden;
}
/* Popup S4 */
.popup-body{padding:0;color:#222}

/* Image */
.mp-img-wrap{position:relative;width:100%;overflow:hidden;border-radius:16px 16px 0 0}
.mp-img-wrap img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block}
.mp-views{
    position:absolute;bottom:8px;left:10px;
    background:rgba(0,0,0,.45);color:#fff;
    font-size:11px;padding:3px 8px;border-radius:20px;
    display:flex;align-items:center;gap:5px;
}
.mp-close{
    position:absolute;top:8px;right:8px;
    width:26px;height:26px;border-radius:50%;
    background:rgba(0,0,0,.4);border:none;cursor:pointer;
    display:flex;align-items:center;justify-content:center;
    color:#fff;transition:background .15s;padding:0;
}
.mp-close:hover{background:rgba(0,0,0,.65)}

/* Content */
.mp-body{padding:12px 14px 14px;display:flex;flex-direction:column;gap:7px}
.mp-badges{display:flex;gap:6px;flex-wrap:wrap}
.mp-badge{
    font-size:11px;font-weight:600;border-radius:20px;
    padding:3px 9px;display:inline-flex;align-items:center;gap:4px;
}
.mp-badge-cat{background:rgba(26,111,168,.12);color:var(--s4-primary)}
.mp-badge-vr{background:var(--s4-primary);color:#fff}
.mp-title{font-size:16px;font-weight:700;color:#111;line-height:1.3}
.mp-address{display:flex;align-items:center;gap:5px;font-size:12px;color:#888}
.mp-rating{display:flex;align-items:center;gap:5px}
.mp-rating-score{font-weight:700;font-size:13px;color:#f5a623}
.mp-stars .starsEl{font-size:12px;color:#ddd}
.mp-stars .starsEl.active,.mp-stars .starsEl:hover{color:#f5a623}
.mp-rating-count{font-size:11px;color:#999}
.mp-desc{
    font-size:12px;color:#666;line-height:1.5;
    white-space: pre-wrap;
    display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
}

/* Actions */
.mp-actions{display:flex;gap:7px;align-items:center;margin-top:2px}
.mp-btn-primary{
    flex:1;background:var(--s4-primary);color:#fff;border:1.5px solid transparent;
    border-radius:9px;padding:0 10px;height:36px;box-sizing:border-box;
    font-size:12.5px;font-weight:600;
    cursor:pointer;display:flex;align-items:center;justify-content:center;gap:5px;
    transition:background .15s;white-space:nowrap;
}
.mp-btn-primary:hover{background:#155e8f}
.mp-btn-secondary{
    flex:1;background:transparent;color:var(--s4-primary);
    border:1.5px solid var(--s4-primary);border-radius:9px;
    padding:0 9px;height:36px;box-sizing:border-box;
    font-size:12.5px;font-weight:600;cursor:pointer;
    display:flex;align-items:center;justify-content:center;gap:5px;
    transition:background .15s;white-space:nowrap;
}
.mp-btn-secondary:hover{background:rgba(26,111,168,.07)}
.mp-btn-icon{
    width:36px;height:36px;flex-shrink:0;border-radius:9px;
    border:1.5px solid #e0e0e0;background:transparent;cursor:pointer;
    display:flex;align-items:center;justify-content:center;color:#666;
    transition:border-color .15s,color .15s;padding:0;box-sizing:border-box;
}
.mp-btn-icon:hover{border-color:var(--s4-primary);color:var(--s4-primary);background:rgba(26,111,168,.08)}
.mp-article-btn{padding:6px 0 10px;border-top:1px solid #f0f0f0;margin-top:4px}
.mp-btn-article{
    width:100%;background:#f5f7fa;color:#555;
    border:1.5px solid #e0e0e0;border-radius:9px;
    padding:0 10px;height:36px;box-sizing:border-box;font-size:12px;font-weight:500;
    cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;
    transition:border-color .15s,color .15s,background .15s;
}
.mp-btn-article:hover{background:#eef4ff;border-color:var(--s4-primary);color:var(--s4-primary)}

/* ── Article iframe panel ── */
#s4-article-panel{
    position:fixed;
    right:10px;top:10px;bottom:8px;
    width:500px;max-width:calc(100vw - 20px);
    background:#fff;
    border-radius:16px;
    border:1px solid rgba(255,255,255,.6);
    box-shadow:0 4px 32px rgba(0,0,0,.18);
    display:flex;flex-direction:column;
    overflow:hidden;
    z-index:9999;
    transform:translateX(calc(100% + 20px));
    opacity:0;pointer-events:none;
    transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .3s;
}
#s4-article-panel.s4-open{
    transform:translateX(0);opacity:1;pointer-events:auto;
}
.s4-ap-header{
    display:flex;align-items:center;justify-content:space-between;
    padding:12px 16px;border-bottom:1px solid #f0f0f0;
    background:#fff;flex-shrink:0;gap:10px;
}
.s4-ap-title{
    font-size:13px;font-weight:600;color:#333;
    flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.s4-ap-ext{
    color:#888;display:flex;align-items:center;
    transition:color .15s;
}
.s4-ap-ext:hover{color:var(--s4-primary)}
.s4-ap-close{
    width:26px;height:26px;border-radius:50%;border:none;
    background:#f5f5f5;cursor:pointer;
    display:flex;align-items:center;justify-content:center;
    color:#666;transition:background .15s,color .15s;padding:0;flex-shrink:0;
}
.s4-ap-close:hover{background:#ff5050;color:#fff}
#s4-ap-iframe{flex:1;width:100%;border:none}

@media(max-width:767px){
    #s4-article-panel{
        width:100%;right:0;left:0;top:auto;bottom:0;
        border-radius:20px 20px 0 0;
        height:80vh;max-width:100%;
        transform:translateY(calc(100% + 20px));
    }
    #s4-article-panel.s4-open{transform:translateY(0)}
}

.popup-pointer{display:none}
#marker-tooltip {display: none;position: absolute;background: #03A9F4;color: white;padding: 6px 15px;border-radius: 10px 5px 5px 10px;font-family: sans-serif;font-size: 14px;font-weight: bold;pointer-events: none; z-index: 9999;white-space: nowrap;box-shadow: 2px 2px 8px rgba(0,0,0,0.3);transform: translateY(-100%); margin-left: 20px;}
#marker-tooltip::after {content: "";position: absolute;right: 100%;top: 50%;transform: translateY(-50%);border-width: 5px;border-style: solid;border-color: transparent #03A9F4 transparent transparent;}

/* Route Panel — S4 */
#route-panel{
    display:none;position:fixed;
    top:50%;transform:translateY(-50%);
    left:calc(var(--s4-sb-w) + var(--s4-sb-m)*2 + 8px);
    width:288px;
    background:#fff;border-radius:16px;
    box-shadow:0 8px 32px rgba(0,0,0,.15),0 2px 8px rgba(0,0,0,.08);
    z-index:600;padding:18px;
    font-family:'Be Vietnam Pro','Montserrat',Arial,sans-serif;
}
#s4-sidebar.closed ~ #s4-sb-tab ~ #route-panel{
    left:calc(var(--s4-sb-m) + 22px + var(--s4-sb-m) + 8px);
}
.rp-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.rp-title{display:flex;align-items:center;gap:7px;font-size:14px;font-weight:700;color:var(--s4-primary)}
.rp-close{width:28px;height:28px;border-radius:50%;border:none;background:var(--s4-surface);cursor:pointer;display:flex;align-items:center;justify-content:center;color:#666;padding:0;transition:background .15s}
.rp-close:hover{background:var(--s4-border)}
.rp-field{margin-bottom:12px}
.rp-label{display:block;font-size:11px;color:var(--s4-text2);font-weight:600;margin-bottom:5px;text-transform:uppercase;letter-spacing:.4px}
.rp-input-row{display:flex;gap:6px}
.rp-input{flex:1;padding:8px 10px;border:1.5px solid var(--s4-border);border-radius:9px;font-size:12.5px;outline:none;cursor:pointer;font-family:inherit;transition:border-color .15s;min-width:0}
.rp-input:focus{border-color:var(--s4-primary)}
.rp-input-dest{background:var(--s4-surface);color:var(--s4-text);cursor:default;width:100%;box-sizing:border-box}
.rp-loc-btn{width:36px;height:36px;flex-shrink:0;border:1.5px solid var(--s4-border);border-radius:9px;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:border-color .15s}
.rp-loc-btn:hover{border-color:var(--s4-primary)}
.rp-btn-go{width:100%;background:var(--s4-primary);color:#fff;border:none;padding:10px;border-radius:10px;font-size:13px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:7px;transition:background .15s;font-family:inherit}
.rp-btn-go:hover{background:#155e8f}
.rp-status{margin-top:10px;font-size:12px;text-align:center;font-weight:600;color:var(--s4-text2);line-height:1.5}
.map-dropdown-selected {background: rgba(30, 30, 30, 0.9);color: white;border: 2px solid #ffffff;border-radius: 6px;cursor: pointer;display: flex;justify-content: space-between;align-items: center;font-size: 14px;width: max-content;}
#currentMapImg{width: 40px;aspect-ratio:1/1;border-radius: 3px}
.map-dropdown-options {display: none;margin-top: 10px}
.map-dropdown-options.show {display: flex;flex-direction: column;gap: 10px;}
.map-option {cursor: pointer;transition: background 0.2s;width: 44px;aspect-ratio: 1 / 1;border: 2px solid #ffffff;border-radius: 3px;position: relative}
.map-option:hover {background: #0078d7;color: white;}
.arrow-down {border: solid white;border-width: 0 2px 2px 0;display: inline-block;padding: 3px;transform: rotate(45deg);}
.map-dropdown-selected{position: relative}
.map-dropdown-selected small{position: absolute;left: 0;bottom: 0;background: #aaaaaa7a;border-radius: 0 0 3px 3px;font-size: 10px;width: 100%;text-align: center;}
.map-option img{width: 100%;height: 100%;object-fit: cover}

/* ══════════════════════════════════════════
   S4 UI — Glassmorphism Sidebar & Controls
   ══════════════════════════════════════════ */
:root {
    --s4-primary:#1A6FA8; --s4-primary-light:#EBF4FB;
    --s4-text:#1C2B3A; --s4-text2:#5E7080;
    --s4-border:#E8EDF2; --s4-surface:#F7F9FC;
    --s4-sb-w:280px; --s4-sb-m:10px; --s4-rp-w:268px; --s4-bb-h:52px; --s4-bb-bottom:60px;
}

/* ── NEW SIDEBAR ── */
#s4-sidebar {
    position:fixed;left:var(--s4-sb-m);top:var(--s4-sb-m);
    bottom:8px;
    width:var(--s4-sb-w);z-index:500;
    background:rgba(255,255,255,.94);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
    border:1px solid rgba(255,255,255,.6);border-radius:14px;
    box-shadow:0 4px 24px rgba(28,43,58,.18);
    display:flex;flex-direction:column;overflow:hidden;
    transition:transform .3s cubic-bezier(.4,0,.2,1);
    font-family:'Be Vietnam Pro','Montserrat',sans-serif;font-size:13px;color:var(--s4-text)
}
#s4-sidebar.closed{transform:translateX(calc(-1 * (var(--s4-sb-w) + var(--s4-sb-m) + 4px)))}

#s4-sb-tab {
    position:fixed;left:calc(var(--s4-sb-w) + var(--s4-sb-m));top:50%;transform:translateY(-50%);
    width:26px;height:68px;z-index:501;
    background:var(--s4-primary);border-radius:0 8px 8px 0;
    display:flex;align-items:center;justify-content:center;
    cursor:pointer;box-shadow:3px 0 12px rgba(26,111,168,.3);
    transition:left .3s cubic-bezier(.4,0,.2,1);overflow:visible;
}
#s4-sb-tab[data-tip]::before{
    content:attr(data-tip);position:absolute;left:calc(100% + 8px);top:50%;transform:translateY(-50%);
    background:rgba(28,43,58,.88);color:#fff;font-size:11px;
    padding:4px 9px;border-radius:6px;white-space:nowrap;
    pointer-events:none;opacity:0;transition:opacity .15s;
}
#s4-sb-tab[data-tip]:hover::before{opacity:1}
#s4-sidebar.closed ~ #s4-sb-tab{left:0}
.s4-tab-ico{width:8px;height:8px;border-right:2px solid #fff;border-top:2px solid #fff;
    transform:rotate(225deg);transition:transform .3s;margin-left:2px}
#s4-sidebar.closed ~ #s4-sb-tab .s4-tab-ico{transform:rotate(45deg);margin-left:-2px}

/* List panel tab */
#s4-lt-tab{
    position:fixed;right:0;top:50%;transform:translateY(-50%);
    width:26px;height:68px;z-index:201;
    background:#fff;border-radius:8px 0 0 8px;
    display:flex;align-items:center;justify-content:center;
    cursor:pointer;box-shadow:-3px 0 12px rgba(0,0,0,.15);
    transition:right .25s ease;overflow:visible;
}
#s4-lt-tab[data-tip]::before{
    content:attr(data-tip);position:absolute;right:calc(100% + 8px);top:50%;transform:translateY(-50%);
    background:rgba(28,43,58,.88);color:#fff;font-size:11px;
    padding:4px 9px;border-radius:6px;white-space:nowrap;
    pointer-events:none;opacity:0;transition:opacity .15s;
}
#s4-lt-tab[data-tip]:hover::before{opacity:1}
.popup-list-tour.s4-open ~ #s4-lt-tab{right:calc(10px + 300px)}
.s4-lt-tab-ico{width:8px;height:8px;border-right:2px solid var(--s4-primary);border-top:2px solid var(--s4-primary);
    transform:rotate(225deg);transition:transform .25s;margin-right:-2px}
.popup-list-tour.s4-open ~ #s4-lt-tab .s4-lt-tab-ico{transform:rotate(45deg);margin-right:2px}

/* Brand */
.s4-brand{padding:20px 14px 16px;text-align:center;border-bottom:1px solid var(--s4-border);flex-shrink:0}
.s4-brand img{width:80px;height:80px;object-fit:contain;display:block;margin:0 auto 10px}
.s4-brand-title{font-size:13.5px;font-weight:700;color:var(--s4-primary);letter-spacing:.2px}
.s4-brand-sub{font-size:11px;color:var(--s4-text2);margin-top:3px}

/* Search */
.s4-search{padding:9px 12px 6px;flex-shrink:0}
.s4-search-box{
    display:flex;align-items:center;gap:7px;
    background:var(--s4-surface);border:1px solid var(--s4-border);
    border-radius:20px;padding:7px 12px
}
.s4-search-box svg{flex-shrink:0;color:var(--s4-text2)}
.s4-search-box input{border:none;background:transparent;outline:none;
    font-family:inherit;font-size:12px;color:var(--s4-text);width:100%}
.s4-search-box input::placeholder{color:var(--s4-text2)}
.s4-search-clear{
    border:none;background:transparent;padding:3px;cursor:pointer;
    display:flex;align-items:center;justify-content:center;
    color:var(--s4-text2);flex-shrink:0;
    border-radius:50%;transition:color .15s,background .15s;
}
.s4-search-clear:hover{color:var(--s4-text);background:var(--s4-border)}

/* Location filter */
.s4-loc{padding:0 12px 8px;display:flex;gap:5px;flex-shrink:0}
.s4-csel{flex:1;min-width:0;position:relative}
.s4-csel-btn{
    display:flex;align-items:center;justify-content:space-between;gap:4px;
    background:var(--s4-surface);border:1px solid var(--s4-border);border-radius:8px;
    padding:5px 8px;cursor:pointer;font-size:11px;color:var(--s4-text);
    user-select:none;transition:border-color .15s
}
.s4-csel-btn:hover{border-color:rgba(26,111,168,.4);background:#f0f6fb}
.s4-csel.open .s4-csel-btn{border-color:var(--s4-primary);background:#f0f6fb}
.s4-csel-val{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.s4-csel-arr{flex-shrink:0;color:var(--s4-text2);transition:transform .2s;font-size:9px}
.s4-csel.open .s4-csel-arr{transform:rotate(180deg)}
.s4-csel-drop{
    position:absolute;top:calc(100% + 5px);left:0;right:0;z-index:600;
    background:#fff;border:1px solid var(--s4-border);border-radius:10px;
    box-shadow:0 6px 22px rgba(28,43,58,.13);overflow:hidden;display:none
}
.s4-csel.open .s4-csel-drop{display:block}
.s4-csel-scroll{max-height:180px;overflow-y:auto}
.s4-csel-opt{
    padding:8px 11px;font-size:11.5px;cursor:pointer;color:var(--s4-text);
    transition:background .12s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis
}
.s4-csel-opt:hover{background:var(--s4-surface)}
.s4-csel-opt.active{color:var(--s4-primary);font-weight:600;background:var(--s4-primary-light)}
.s4-csel-search{
    display:flex;align-items:center;gap:6px;
    padding:7px 10px;border-bottom:1px solid var(--s4-border);
}
.s4-csel-search svg{flex-shrink:0;color:var(--s4-text2)}
.s4-csel-search-input{
    flex:1;border:none;outline:none;font-size:11.5px;
    color:var(--s4-text);background:transparent;
}
.s4-csel-opt.s4-hidden{display:none}

/* Nav */
.s4-nav{flex:1;overflow-y:auto;padding-bottom:4px}
.s4-nav::-webkit-scrollbar{width:3px}
.s4-nav::-webkit-scrollbar-thumb{background:var(--s4-border);border-radius:2px}

/* L1 */
/* L1 — section header */
.s4-l1{
    display:flex;align-items:center;gap:8px;padding:10px 14px;
    cursor:pointer;font-size:13px;font-weight:600;color:var(--s4-text);
    border-bottom:1px solid rgba(232,237,242,.6);transition:background .15s;
}
.s4-l1:hover{background:var(--s4-surface)}
.s4-l1.open{background:var(--s4-surface)}
.s4-l1-lbl{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.s4-l1-cnt{
    font-size:10px;font-weight:600;padding:2px 8px;border-radius:20px;
    background:rgba(26,111,168,.12);color:var(--s4-primary);flex-shrink:0;
}
.s4-l1.open .s4-l1-cnt{background:var(--s4-primary);color:#fff}
.s4-l1-arr{
    width:5px;height:5px;flex-shrink:0;transition:transform .2s;
    color:var(--s4-text2);border-right:1.5px solid currentColor;border-top:1.5px solid currentColor;
    transform:rotate(135deg);
}
.s4-l1.open .s4-l1-arr{transform:rotate(315deg)}

/* L2 */
.s4-l2-group{display:none;background:rgba(247,249,252,.8)}
.s4-l2-group.open{display:block}
.s4-l2{
    display:flex;align-items:center;gap:10px;padding:8px 14px 8px 18px;
    cursor:pointer;font-size:12.5px;font-weight:500;color:var(--s4-text);
    transition:background .15s;
}
.s4-l2:hover{background:#eef4fa}
.s4-l2.active,.s4-l2.s4-active{background:var(--s4-primary-light);color:var(--s4-primary);font-weight:600}
.s4-lang-flag{
    width:22px;height:auto;border-radius:3px;flex-shrink:0;
    object-fit:cover;box-shadow:0 1px 3px rgba(0,0,0,.2)
}
.s4-l2-dot{
    width:10px;height:10px;border-radius:50%;flex-shrink:0;
    background:var(--s4-primary);
}
.s4-l1-dot{
    width:10px;height:10px;border-radius:3px;flex-shrink:0;display:inline-block;
}
.s4-l1-img{
    width:18px;height:18px;object-fit:contain;border-radius:3px;
}
.s4-l2-ico{
    width:18px;height:18px;object-fit:contain;flex-shrink:0;border-radius:3px;
}
.s4-l2-lbl{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.s4-l2-arr{
    width:5px;height:5px;flex-shrink:0;transition:transform .2s;
    color:var(--s4-text2);border-right:1.5px solid currentColor;border-top:1.5px solid currentColor;
    transform:rotate(45deg);
}
.s4-l2.open .s4-l2-arr{transform:rotate(135deg)}

/* L3 */
.s4-l3-group{display:none}
.s4-l3-group.open{display:block}
.s4-l3{
    display:flex;align-items:center;gap:8px;padding:6px 14px 6px 38px;
    cursor:pointer;font-size:12px;color:var(--s4-text2);transition:background .15s;
}
.s4-l3:hover{background:#eef4fa;color:var(--s4-text)}
.s4-l3.active,.s4-l3.s4-active{background:#ddf0fa;color:var(--s4-primary);font-weight:600}
.s4-l3-dash{color:var(--s4-text2);font-size:13px;flex-shrink:0;line-height:1}
.s4-l3.active .s4-l3-dash,.s4-l3.s4-active .s4-l3-dash{color:var(--s4-primary)}
.s4-l3-ico{width:16px;height:16px;object-fit:contain;flex-shrink:0;border-radius:3px}
.s4-l3-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}

/* Sidebar footer */
.s4-foot{
    padding:8px 14px;border-top:1px solid var(--s4-border);flex-shrink:0;
    display:flex;align-items:center;justify-content:space-between;font-size:10px;
    background:linear-gradient(135deg,#0a2a4a 0%,#1a4a7a 100%)
}
.s4-foot span{color:#ffffffaa}
.s4-foot-dot{width:6px;height:6px;border-radius:50%;background:#22c55e;box-shadow:0 0 5px rgba(34,197,94,.5);flex-shrink:0}

/* ── MAP CONTROLS (right side) ── */
#s4-map-controls {
    position:fixed;right:10px;
    top:10px;
    z-index:490;display:flex;flex-direction:column;gap:6px;
    transition:right .25s ease;
}
#s4-list-panel.s4-open ~ #s4-map-controls,
body.list-open #s4-map-controls {
    right:320px;
}
.s4-mc-card{
    background:rgba(255,255,255,.94);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
    border:1px solid rgba(255,255,255,.6);border-radius:10px;
    box-shadow:0 2px 12px rgba(28,43,58,.14);width:32px;overflow:visible
}
.s4-mc-btn{
    width:100%;height:32px;display:flex;align-items:center;justify-content:center;
    background:transparent;border:none;cursor:pointer;color:var(--s4-text2);
    transition:color .15s,background .15s;position:relative;font-family:inherit;line-height:0;padding:0;
    -webkit-appearance:none;appearance:none;outline:none;border-radius:9px;
}
.s4-mc-btn:hover{color:var(--s4-primary);background:rgba(26,111,168,.08)}
.s4-mc-sep{height:1px;background:var(--s4-border)}
.s4-mc-btn::before{
    content:attr(data-tip);position:absolute;left:42px;top:50%;transform:translateY(-50%);
    background:rgba(28,43,58,.88);color:#fff;font-size:11px;
    padding:4px 10px;border-radius:6px;white-space:nowrap;
    pointer-events:none;opacity:0;transition:opacity .15s
}
.s4-mc-btn:hover::before{opacity:1}

/* ── BOTTOM BAR ── */
#s4-bottom-bar{
    position:fixed;bottom:8px;left:50%;transform:translateX(-50%);
    height:var(--s4-bb-h);z-index:495;
    background:rgba(255,255,255,.96);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
    border:1px solid var(--s4-border);border-radius:20px;
    box-shadow:0 4px 24px rgba(0,0,0,0.12);
    display:inline-flex;align-items:center;justify-content:center;
    padding:0 6px;
    white-space:nowrap;
}
.s4-bbtn{
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    gap:3px;padding:0 14px;height:100%;cursor:pointer;
    color:var(--s4-text2);font-size:10px;font-weight:500;transition:color .15s;
    font-family:'Be Vietnam Pro','Montserrat',sans-serif;flex-shrink:0;
    position:relative;
}
.s4-bbtn svg{width:18px;height:18px}
.s4-bbtn:hover,.s4-bbtn.active{color:var(--s4-primary)}
.s4-bbtn[data-tip]::before{
    content:attr(data-tip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);
    background:rgba(28,43,58,.88);color:#fff;font-size:11px;
    padding:4px 9px;border-radius:6px;white-space:nowrap;
    pointer-events:none;opacity:0;transition:opacity .15s;font-weight:400;
}
.s4-bbtn[data-tip]:hover::before{opacity:1}
.s4-bb-fab[data-tip]{position:relative}
.s4-bb-fab[data-tip]::before{
    content:attr(data-tip);position:absolute;bottom:calc(100% + 10px);left:50%;transform:translateX(-50%);
    background:rgba(28,43,58,.88);color:#fff;font-size:11px;
    padding:4px 9px;border-radius:6px;white-space:nowrap;
    pointer-events:none;opacity:0;transition:opacity .15s;font-weight:400;
}
.s4-bb-fab[data-tip]:hover::before{opacity:1}
.s4-bbtn-mob-only{display:none}
/* Guide floating button — mobile only */
#s4-mob-guide-btn{
    display:none;
    position:fixed;top:58px;left:10px;
    width:36px;height:36px;border-radius:50%;
    background:rgba(255,255,255,.94);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
    border:1px solid rgba(255,255,255,.6);
    box-shadow:0 2px 12px rgba(28,43,58,.18);
    display:none;align-items:center;justify-content:center;
    cursor:pointer;color:var(--s4-text2);z-index:496;
}
.s4-bb-sp{width:8px;flex-shrink:0}
.s4-bb-fab{
    position:relative;bottom:6px;
    width:44px;height:44px;background:var(--s4-primary);border-radius:12px;
    display:flex;align-items:center;justify-content:center;color:#fff;
    cursor:pointer;box-shadow:0 4px 16px rgba(26,111,168,.4);transition:all .2s;
    flex-shrink:0;
}
.s4-bb-fab:hover{box-shadow:0 6px 22px rgba(26,111,168,.55);transform:translateY(-2px)}

/* ── UTIL BUTTONS ── */
#s4-util-btns{
    position:fixed;left:calc(var(--s4-sb-w) + var(--s4-sb-m)*2 + 4px);
    bottom:8px;z-index:490;
    display:flex;gap:6px;transition:left .3s cubic-bezier(.4,0,.2,1)
}
#s4-sidebar.closed ~ #s4-util-btns{left:calc(var(--s4-sb-m) + 22px)}
.s4-util-btn{
    width:32px;height:32px;
    background:rgba(255,255,255,.94);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
    border:1px solid rgba(255,255,255,.6);border-radius:10px;
    box-shadow:0 2px 12px rgba(28,43,58,.14);
    display:flex;align-items:center;justify-content:center;
    cursor:pointer;color:var(--s4-text2);position:relative;transition:color .15s
}
.s4-util-btn:hover{color:var(--s4-primary)}
.s4-util-btn::before{
    content:attr(data-tip);position:absolute;bottom:38px;left:50%;transform:translateX(-50%);
    background:rgba(28,43,58,.9);color:#fff;font-size:11px;
    padding:4px 8px;border-radius:6px;white-space:nowrap;
    pointer-events:none;opacity:0;transition:opacity .15s
}
.s4-util-btn:hover::before{opacity:1}

/* ── BREADCRUMB ── */
#s4-map-title{
    position:fixed;left:calc(var(--s4-sb-w) + var(--s4-sb-m)*2 + 4px);top:14px;
    z-index:490;pointer-events:none;
    transition:left .3s cubic-bezier(.4,0,.2,1)
}
#s4-sidebar.closed ~ #s4-map-title{left:calc(var(--s4-sb-m) + 22px)}
.map-breadcrumb{display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.s4-bc-chip{
    background:#fff;
    border:1px solid rgba(0,0,0,.1);border-radius:20px;
    padding:4px 10px;font-size:11.5px;font-weight:500;color:#555;
    pointer-events:auto;white-space:nowrap;
    box-shadow:0 1px 4px rgba(0,0,0,.1)
}
.s4-bc-chip.active{
    background:#F4874B;color:#fff;font-weight:700;border-color:#F4874B;
    box-shadow:0 2px 8px rgba(244,135,75,.35)
}
.s4-bc-sep{color:#888;font-size:14px;line-height:1;padding:0 1px}
.s4-bc-clear{
    background:#fff;
    border:1px solid rgba(0,0,0,.12);border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    color:#888;cursor:pointer;pointer-events:auto;
    padding:5px;margin:0;line-height:1;flex-shrink:0;
    box-shadow:0 1px 4px rgba(0,0,0,.1);
    transition:background .15s,color .15s
}
.s4-bc-clear svg{display:block;flex-shrink:0}
.s4-bc-clear:hover{background:#ff5050;color:#fff;border-color:#ff5050}

/* ══════════ MOBILE RESPONSIVE ══════════ */
@media(max-width:767px){

    /* ── Sidebar: 80% width overlay, starts closed ── */
    #s4-sidebar{
        width:80vw!important;
        top:0;left:0!important;
        bottom:0;border-radius:0 12px 12px 0;
        z-index:600;
        background:#fff!important;
        backdrop-filter:none!important;-webkit-backdrop-filter:none!important;
    }
    #s4-sidebar.closed{
        transform:translateX(-80vw)!important;
    }
    /* Overlay tối phía sau sidebar — click để đóng */
    #s4-mob-overlay{
        display:none;
        position:fixed;inset:0;
        background:rgba(0,0,0,.45);
        z-index:599; /* dưới sidebar (600) */
        cursor:pointer;
    }
    #s4-mob-overlay.active{display:block}

    /* ── Sidebar tab: top-left, always visible ── */
    #s4-sb-tab{
        left:10px!important;
        top:10px!important;transform:none!important;
        border-radius:8px;width:36px;height:36px;
    }
    .s4-tab-ico{transform:rotate(225deg)!important;margin-left:2px!important}
    #s4-sidebar.closed ~ #s4-sb-tab .s4-tab-ico{transform:rotate(45deg)!important;margin-left:-2px!important}

    /* ── Bottom bar ── */
    #s4-bottom-bar{display:flex}
    /* Ẩn bottom bar khi list mở để list chiếm toàn bộ */
    body.list-open #s4-bottom-bar{display:none!important}
    /* Guide button floating */
    #s4-mob-guide-btn{display:flex}

    /* Popup modal: full screen trên mobile, nổi trên tất cả */
    .modal-popup{z-index:900!important}
    .modal-popup-content{
        width:100%!important;
        height:100%!important;
        max-height:100%!important;
        top:0!important;left:0!important;
        transform:none!important;
        border-radius:0!important;
        aspect-ratio:unset!important;
        overflow-y:auto;
    }

    /* ── Util buttons: ẩn ── */
    #s4-util-btns{display:none!important}

    /* ── Breadcrumb ── */
    #s4-map-title{left:56px!important;top:12px}
    #s4-sidebar.closed ~ #s4-map-title{left:56px!important}

    /* ── Map controls: cố định, không dịch chuyển khi list mở ── */
    #s4-map-controls{right:10px!important;transition:none!important}
    body.list-open #s4-map-controls{right:10px!important}

    /* ── Popup marker: 88% width, centered ── */
    .cesium-popup{
        width:88%;max-width:380px;
        bottom:72px;
        left:50%;transform:translateX(-50%);
    }
    .mp-img-wrap img{aspect-ratio:16/8}

    /* ── Route panel: bottom sheet ── */
    #route-panel{
        left:10px!important;right:10px;width:auto;
        top:auto;bottom:72px;transform:none;
        border-radius:16px 16px 10px 10px;
        max-height:75vh;overflow-y:auto;
    }
    #s4-sidebar.closed ~ #s4-sb-tab ~ #route-panel{left:10px!important}

    /* ── Event popup: full width ── */
    .popup-event{left:10px!important;right:10px;width:auto;top:56px;bottom:72px}
    #s4-sidebar.closed ~ .popup-event{left:10px!important}

    /* ── Tour list: bottom sheet, ẩn hoàn toàn / mở full ── */
    .popup-list-tour{
        left:0!important;right:0;width:100%!important;
        top:auto;bottom:0!important;
        height:90vh;
        border-radius:20px 20px 0 0;
        transform:translateY(100%)!important; /* ẩn hoàn toàn xuống dưới */
    }
    .popup-list-tour.s4-open{transform:translateY(0)!important}

    /* ── Chat popup ── */

    /* ── Share panel: giữa màn hình ── */
    #s4-share-panel{
        left:50%!important;right:auto;
        transform:translateX(-50%) translateY(10px);
        width:calc(100vw - 40px);max-width:340px;
        bottom:50%;
    }
    #s4-share-panel.s4-open{transform:translateX(-50%) translateY(0)}

    /* ── Instruction panel ── */
    .group-instruct{flex-direction:column}
    .instruct-col-left{flex:none;border-right:none;border-bottom:1px solid rgba(255,255,255,.1)}
    .instruct-col-right .instruct-right{grid-template-columns:repeat(3,1fr)}

    /* ── Tour card compact ── */
    .item-tour .img-tour{width:72px;height:72px}

    /* ── Breadcrumb chip ── */
    .s4-bc-chip{font-size:10.5px;padding:3px 8px}

    /* ── List tab: ẩn trên mobile ── */
    #s4-lt-tab{display:none}

    /* ── Popup list vrtour: mobile ── */
    .popup-list-vrtour .modal-popup-content{
        width:100%!important;max-width:100%!important;
        height:100%!important;max-height:100%!important;
        border-radius:0!important;
        top:0!important;left:0!important;
        transform:none!important;
    }
    .header-list-vrtour{
        flex-wrap:nowrap!important;gap:8px;padding:8px 12px;height:auto!important;
        align-items:center;
    }
    .vrtour-search-wrap{
        flex:1 1 0!important;min-width:0;order:0;
    }
    .vrtour-dd{flex:1 1 0!important;min-width:0;width:auto!important}
    .vrtour-dd-btn{width:100%}
    .vrtour-dd-drop{width:180px;right:0;left:auto}
    .body-list-vrtour{padding:10px 12px}
    .body-list-vrtour .col-md-4{
        width:50%!important;flex:0 0 50%!important;max-width:50%!important;
    }
    .vrtour-footer{padding:8px 12px;flex-wrap:wrap;gap:6px}
}

.map-option small{position: absolute;left: 0;bottom: 0;color: #ffffff;background: #aaaaaa7a;width: 100%;font-size: 10px;text-align: center;}
.map-dropdown-selected.disabled {opacity: 0.5;cursor: not-allowed;pointer-events: none;filter: grayscale(1);}.s4-l2.s4-active,.s4-l3.s4-active{background:rgba(26,111,168,.12);color:var(--s4-primary);font-weight:600}
.s4-l2.s4-active .s4-l2-dot,.s4-l3.s4-active .s4-l3-dot{background:var(--s4-primary)!important}

/* S4 2D/3D button */
.s4-btn-3d{font-size:12px;font-weight:700;letter-spacing:.5px;color:var(--s4-primary)!important}
/* S4 map style dropdown */
.s4-map-opts{
    position:absolute;right:40px;top:0;
    display:none;flex-direction:column;gap:6px;
    background:rgba(255,255,255,.96);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
    border:1px solid rgba(255,255,255,.6);border-radius:10px;
    box-shadow:0 4px 20px rgba(0,0,0,.15);
    padding:6px;min-width:80px;z-index:600;margin-top:0;
}
.s4-map-opts.show{display:flex}
.s4-map-opts .map-option{
    width:auto;aspect-ratio:unset;border:1.5px solid rgba(0,0,0,.1);border-radius:7px;
    display:flex;align-items:center;gap:7px;padding:4px 8px 4px 4px;
    background:#fff;transition:border-color .15s,background .15s;
    white-space:nowrap;overflow:hidden;
}
.s4-map-opts .map-option:hover{border-color:var(--s4-primary);background:var(--s4-primary-light,#EBF4FB)}
.s4-map-opts .map-option img{width:36px;height:36px;object-fit:cover;border-radius:4px;flex-shrink:0}
.s4-map-opts .map-option small{
    position:static;background:transparent;color:#333;
    font-size:11px;font-weight:500;width:auto;text-align:left;
}
.s4-map-opts .map-option.active{border-color:var(--s4-primary);background:var(--s4-primary-light,#EBF4FB)}

/* Sidebar map list */
.s4-map-grid{display:flex;flex-direction:column}
.s4-map-row.active .s4-l2-lbl{color:var(--s4-primary);font-weight:600}
.s4-map-dot{
    width:18px;height:18px;flex-shrink:0;
    display:flex;align-items:center;justify-content:center;
}
.s4-map-dot img{width:16px;height:16px;object-fit:cover;border-radius:3px}

/* ===== S4 SHARE PANEL ===== */
#s4-share-panel{
    position:fixed;bottom:calc(8px + var(--s4-bb-h) + 12px);
    left:50%;transform:translateX(-50%) translateY(10px);
    background:rgba(255,255,255,.97);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
    border:1px solid rgba(255,255,255,.6);border-radius:16px;
    box-shadow:0 8px 32px rgba(0,0,0,.15);
    padding:16px;width:320px;z-index:600;
    opacity:0;pointer-events:none;
    transition:opacity .2s,transform .2s;
}
#s4-share-panel.s4-open{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.s4-share-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.s4-share-title{font-size:15px;font-weight:700;color:#1a1a2e}
.s4-share-close{
    width:28px;height:28px;border:none;background:rgba(0,0,0,.06);
    border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;
    color:#555;transition:background .15s,color .15s;
    -webkit-appearance:none;appearance:none;outline:none;padding:0;
}
.s4-share-close:hover{background:rgba(220,50,50,.1);color:#e53935}
.s4-share-url{
    display:flex;align-items:center;gap:8px;
    background:rgba(0,0,0,.04);border-radius:10px;
    padding:8px 10px;margin-bottom:14px;
}
#s4-share-url-text{
    flex:1;font-size:11px;color:#555;
    overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.s4-share-copy{
    display:flex;align-items:center;gap:5px;flex-shrink:0;
    border:1.5px solid var(--s4-primary,#1A6FA8);
    background:rgba(26,111,168,.06);color:var(--s4-primary,#1A6FA8);
    border-radius:8px;padding:4px 10px;font-size:11px;font-weight:600;
    cursor:pointer;transition:background .15s,color .15s;white-space:nowrap;
}
.s4-share-copy:hover{background:var(--s4-primary,#1A6FA8);color:#fff}
.s4-share-providers{
    display:flex;flex-wrap:wrap;gap:8px;justify-content:center;
}
.s4-share-item{
    display:flex;flex-direction:column;align-items:center;gap:5px;
    width:64px;text-decoration:none;cursor:pointer;
}
.s4-share-ico{
    width:44px;height:44px;border-radius:12px;
    background:var(--sc,#555);
    display:flex;align-items:center;justify-content:center;
    color:#fff;font-size:18px;
    transition:transform .15s,box-shadow .15s;
}
.s4-share-item:hover .s4-share-ico{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.2)}
.s4-share-lbl{font-size:10px;color:#555;font-weight:500;text-align:center;line-height:1.2}

/* ── Extracted from inline styles ── */
#chat-icon{position:fixed;bottom:70px;right:10px}
#s4-csel-prov{max-width:90px}
.s4-foot img{height:18px;opacity:.7}
.s4-map-style-card{position:relative}
.btn-close-event img{width:13px;height:13px;display:block}
.s4-ap-actions{display:flex;align-items:center;gap:6px}
#modal_cookie_policy_b .modal-dialog{max-width:1280px}
.s4-bc-clear img{width:11px;height:11px;display:block}

/* ── Cesium 3D full-screen overlay ── */
#cesium3d-overlay{
    display:none;
    position:fixed;inset:0;
    z-index:9000;
    flex-direction:column;
    background:#0f1923;
}
#cesium3d-container{
    flex:1;
    width:100%;
    min-height:0;
}
#cesium3d-container canvas{width:100%!important;height:100%!important}
#cesium3d-close{
    position:absolute;top:14px;right:14px;z-index:9001;
    display:flex;align-items:center;gap:6px;
    background:rgba(255,255,255,.12);backdrop-filter:blur(12px);
    border:1px solid rgba(255,255,255,.2);border-radius:10px;
    color:#fff;font-size:13px;font-weight:500;
    padding:7px 14px;cursor:pointer;
    transition:background .15s;
}
#cesium3d-close:hover{background:rgba(255,255,255,.22)}
#cesium3d-overlay .cesium-widget-credits,
#cesium3d-overlay .cesium-performanceDisplay-defaultContainer{display:none!important}

/* ── Loading indicator inside 3D overlay ── */
#cesium3d-loading{
    display:flex;flex-direction:column;align-items:center;gap:14px;
    position:absolute;inset:0;z-index:9002;
    justify-content:center;
    background:rgba(15,25,35,.75);backdrop-filter:blur(4px);
    color:#fff;font-size:14px;font-weight:500;letter-spacing:.3px;
    pointer-events:none;
}
#cesium3d-loading.hidden{display:none}
.cesium3d-spinner{
    width:36px;height:36px;border-radius:50%;
    border:3px solid rgba(255,255,255,.2);
    border-top-color:#fff;
    animation:s4-spin .7s linear infinite;
}

/* ── 3D Model button states ── */
@keyframes s4-spin{to{transform:rotate(360deg)}}
#s4-btn-3d-model.loading{pointer-events:none;opacity:.6;animation:s4-spin .8s linear infinite}
#s4-btn-3d-model.active{color:var(--s4-primary);background:rgba(26,111,168,.1)}
