.single-product header >.product, .tax-product_cat header>div, .single-post header>div{
    box-shadow: 0 0 4px rgb(0 0 0 / 30%);
}
.single-product .woocommerce-breadcrumb{
    margin-bottom: 0;
}
.woocommerce:where(body:not(.woocommerce-uses-block-theme)) .woocommerce-breadcrumb a{
    color: var(--et-primary-color);
}
.row{
    margin: 0 -15px;
    display: flex;
    flex-wrap: wrap;
}
.col{
    padding: 0 15px;
}
.col-8{
    width: 66.66666667%;
}
.col-4{
    width: 33.33333333%;
}
.col-3{
    width: 25%;
}
.col-9{
    width: 75%;
}
.col-6{
    width: 50%;
}
.col-12{
    width: 100%;
}
.details .title{
    padding: 12px 24px;
    border-radius: 12px;
    background-color: #E9F6ED;
}
.details h1{
    padding: 0;
    line-height: normal;
    font-size: 32px;
}
.details .reviews{
    margin: 1rem 0;
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}
.details .reviews .score {
    align-items: center;
    display: flex;
    gap: 4px;
    white-space: nowrap;
}
.details .reviews .score svg{
    margin-bottom: 4px;
}
.details .reviews .score .score-value {
    color: #222;
    font-size: 14px;
    font-weight: 700;
}
.details .reviews .reviews-count {    
    font-size: 14px;
}
.details .reviews .tour-code {
    color: #777;
    display: inline-block;
    font-size: 14px;
    white-space: nowrap;
}
.details .reviews .tour-code span{
    color: #222;
    font-weight: 700;
}
.details .my-search-product-card-image-collect{
    align-items: center;
    background-color: #fff;
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    flex-direction: row;
    height: 40px;
    justify-content: center;    
    width: 40px;
    z-index: 2;
    border: 1px solid #D1D1D1;
    margin-left: auto;
}
.details .image{
    padding-top: 500px;
    border-radius: 20px;
    overflow: hidden;
    position: relative;
}
.details .image img{
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.details .infor-basic{
    border: 1px solid #D1D1D1;
    border-radius: 12px;
    padding: 24px;
    height: 100%;
}
.details .infor-basic .sale{
    border-top-right-radius: 20px;
    border-bottom-left-radius: 20px;
    background-color: #E4BA58;
    color: white;
    font-size: 24px;
    font-weight: 600;
    padding: 10px 24px;
    display: inline-block;
}
.details .infor-basic .price-from-to{
    margin-top: 20px;
    margin-bottom: 24px;
    display: flex;
    gap: 12px;
}
.details .infor-basic .price-from-to .group {
    display: flex;
    flex-direction: column;
}
.details .infor-basic .price-from-to .group .price {
    font-weight: 600;
    font-size: 18px;
    color: #E84343;
    position: relative;
    z-index: 9;
}
.details .infor-basic .price-from-to .group .price .unit{
    font-size: 14px;
    color: #3D3D3D;
    font-weight: 400;
}
.details .infor-basic .price-from-to .group .price .notes{
    position: absolute;
    margin-left: 8px;
    left: 100%;
    top: 50%;
    transform: translateY(-44%);    
}
.details .infor-basic .price-from-to .group .price-buy {
    text-decoration: line-through;
}
.details .notes .note_content{
    position: absolute;
    bottom: 125%;
    background: #fff;
    border: 1px solid #ebeef5;
    border-radius: 4px;
    filter: drop-shadow(0 2px 12px rgba(0, 0, 0, .1));
    color: #606266;
    font-size: 14px;
    line-height: 1.4;
    min-width: 250px;
    padding: 12px;
    font-weight: normal;
    left: 50%;
    transform: translateX(-50%);
    opacity: 0;
    transition: opacity .2s ease;
    visibility: hidden;
}
.details .notes .note_content::after {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border-width: 6px;
    border-style: solid;
    border-color: #ffffff transparent transparent transparent;
}
.details .infor-basic .price-from-to .group .price .notes:hover .note_content{
    opacity: 1;
    visibility: visible;
}
.details .popup-content{
    display: none;
}
#guarantee{
    max-width: 600px;
    padding: 1.5rem;
    padding-right: 0.5rem;
    border-radius: 1rem;
}
#guarantee .title-popup{
    font-size: 20px;
    font-weight: bold;
    margin-bottom: 12px;
    text-align: center;
}
#guarantee article{
    max-height: 60vh;
    overflow: auto;
}
.details .flight{
    display: flex;
    gap: 1rem;
}
.details .flight .from{
    flex: 1;
}
.details .flight .from .text{
    display: flex;
    align-items: center;
    gap: 4px;
    font-weight: 600;
    color: #222;
    margin-bottom: 12px;
    text-transform: capitalize;
}
.details .flight .from .from-place{
    width: 100%;
    display: block;
    text-align: center;
    padding: 10px 12px;
    border-radius: 50px;
    border: 1px solid #D1D1D1;
}
.details .check-tour{
    background-color: var(--et-primary-color);
    border-radius: 50px;
    text-align: center;
    color: white;
    padding: 10px 12px;
    margin: 24px 0;
    cursor: pointer;
}
.details .short-description p.show-popup{
    cursor: pointer;
    padding-bottom: 1rem;
}
.details .short-description p svg{    
    vertical-align: sub;
}
#box-second{
    margin-top: 24px;
}
#box-second .image-map{
    padding-top: 250px;
    border-radius: 20px;
    position: relative;
    border: 1px solid #D1D1D1;
    overflow: hidden;
}
#box-second .image-map img{
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.title-head{
    display: flex;
    gap: 12px;
    align-items: center;
    margin-bottom: 1rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid #D1D1D1;
}
.title-head.show{
    cursor: pointer;
}
.title-head.open >i{
    transition: all 0.3s ease-in-out;
}
.title-head.open >i{
    transform: rotate(90deg);
}
.title-head .title-main{
    font-size: 32px;
    font-weight: 500;
    color: #111111;
    line-height: normal;
}
.title-head i{
    margin-left: auto;
    font-size: 1.4rem;
}
.content-overview p{
    color: #000;
}
.content-overview p svg{
    vertical-align: sub;
}
.content-overview p strong{
    color: #111111;
}
#box-third .title-head, #box-four .title-head, #box-five .title-head{
    margin-top: 24px;
}
.timeline {
    border-left: 1px dotted #054A1E;    
}
.timeline-item {
    margin-bottom: 20px;
    position: relative;
    padding-left: 20px;
}
.timeline-item::before {
    content: "";
    position: absolute;
    left: -14px;
    top: 7px;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background-color: #054A1E;
    border: 6px solid #fff;    
}
.timeline-item.active::before {
    box-shadow: 0 0 0 1px #054A1E;
}
.timeline-header {
    background-color: #054A1E;
    color: white;
    padding: 8px 16px;
    font-weight: 600;
    border-radius: 8px;
    font-size: 16px;
    text-transform: uppercase;
    line-height: 24px;
    cursor: pointer;
}
.timeline-content {
    background-color: rgba(228, 186, 88, .15);
    padding: 20px 40px;
    margin-top: 20px;
    border-radius: 20px;
    font-size: 16px;
    display: none;
}
.list-pick-up .item{
    background-color: rgba(228, 186, 88, .15);
    padding: 20px 40px;
    border-radius: 20px;
    font-size: 16px;
}
.list-pick-up .item + .item{
    margin-top: 20px;    
}
.list-pick-up .item .titles{
    font-weight: 600;
    color: #000;
}
.list_own_expenses .own-item {
    margin-bottom: 20px;
    position: relative;
}
.list_own_expenses .own-item .timeline-title{
    background-color: #054A1E;
    color: white;
    padding: 8px 16px;
    font-weight: 600;
    border-radius: 8px;
    font-size: 16px;
    text-transform: uppercase;
    line-height: 24px;
    cursor: pointer;
}
.list_own_expenses .own-item .timeline-contents{
    margin-top: 1rem;
    font-size: 16px;
    display: none;
}
.list_own_expenses .own-item table tr td{
    padding-top: 8px;
    padding-bottom: 8px;
}
.includes-excludes .note-content-item-title{
    font-weight: bold;
    font-size: 16px;
    color: #000;
    margin-bottom: 0.5rem;
}
.includes-excludes .includes ul, .includes-excludes .excludes ul{
    list-style: none;
    padding: 0;
    font-size: 16px;
}
.includes-excludes .includes{
    margin-bottom: 1rem;
}
.includes-excludes ul li {
    background-position: 0 4px;
    background-repeat: no-repeat;
    background-size: 16px;
    padding-left: 24px;
}
.includes-excludes .includes ul li {
    background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAAXNSR0IArs4c6QAAAYNJREFUWEftlU9Og0AUh38PL+AS44ZdbYxmegRO4BHEG9QTWE+gN7A9gd6gR3DsBuNGlhg3bExbk/IM2D9Qpu0AATawJDN83/zemweh4Yca5qMVaBOoNQHhmg4MsOz4o1Xz1yYgXHPAhLsITARnJVGLQBIeCTDBmSxTqFwgAwc/Ts6+bmspwTYchOFbx79JDr/KEtCBx/1QxSjWhWcEVNckr2AeeEoggjPhKX7JuJddf1A1PCVw4ZqOsRQoIpE5OVjSdG7LXhDsO0iqBy5dc0iE6/UV0UyiKFzZhBmJxNRSnaQMXCkgPq1j/p2PwSzWSeyQEO8nfQY/bMT0Yj84B2KJ+ewVgPW/mANahLY8/5arzcmmXa7Rqvl2ijvngHBNiwljlUQWDo+ms96hhlOVcO8gykrAY/ALgfqJj3nEsGXX9/JeW61JqJBIckrBtQSiReLjVHC4eN6UI3YoDdcWiCVc0wqP6IqYBRNJ42c6KlJz7SYsUs8ieyr5G+YRaQXaBBpP4A9aMdsh/i37rgAAAABJRU5ErkJggg==);
}
.includes-excludes .excludes ul li {
    background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAAXNSR0IArs4c6QAAAR1JREFUWEftlt0NwyAMhGE7xsgmTSaJugXbUVkCCVEb+0wjXpq3RIT7OP/gGDY/cbN++AOwDpSUjhBCiTm/fxGi2X5fAHXxXYWvmPO5AlFSov9fdY9jPJQGQP+5IQZx2ksHoFUlJSLuTw5DMOJnzPka3RSrYAXCKk4w0zL0QCDiKgAaDlTcBGCF8IibATQIrzgEIEHUrG51Tq9stku9BL4LmMTs94bEYQeakgABi68A9O21ccHNygXAJFwfAhgCygEu26u6u22bAWal5umYzTYTgKXOvRAqgEV8Uh1qTmiX0ZjtaqmhTsyuY1jc44Q0E7rFUQjLSKbaLvV5Jhz6SDYMpW5xwQkdoN56+8Zyyc6nvqt94ClhqBM+CbHdgQ/7VNQh/EvNTgAAAABJRU5ErkJggg==);
}
.includes-excludes ul li:not(:last-child) {
    margin-bottom: 12px;
}
.list-pick-up, .list_own_expenses, .includes-excludes, .policy{
    display: none;
}
/* MARK: calendar */
.month-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: start;
    margin-bottom: 20px;
}
.month-tab {
    padding: 4px 8px;
    border-radius: 8px;
    background-color: #E9F6ED;
    cursor: pointer;
    color: #000;    
}
.month-tab.active {
    background-color: var(--et-primary-color);
    color: white;
}
.calendar-body {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 32px;
}
.calendar-grid {
    display: grid;
    grid-template-columns: repeat(7, 49px);
    grid-auto-rows: 49px;
    gap: 24px;
    text-align: center;
    background-color: #F6F6F6;
    border-radius: 20px;
    padding: 24px;
    font-size: 20px;
}
.calendar-grid .header {
    font-weight: bold;
    color: #888;
    line-height: 49px;
}
.calendar-grid .day {
    line-height: 49px;
    color: #333;
    cursor: pointer;
    border: 1px solid transparent;
    border-radius: 50%;
    transition: all 0.3s ease;
}
.calendar-grid .day:hover{
    border-color: var(--et-primary-color);
}
.calendar-grid .day.none{
    cursor: not-allowed;
    pointer-events: none;
    color: #c9c9c9;
}
.calendar-grid .day.active {
    background-color: #054A1E;
    color: white;    
}
.calendar-info {
    font-size: 14px;
    max-width: 300px;
    color: #333;
}
.month-swiper-container{
    padding-left: 40px;
    padding-right: 40px;
    position: relative;
    margin-bottom: 20px;
}
.month-swiper-container .swiper-buttons-prev{
    left: 0;
}
.month-swiper-container .swiper-buttons-next{
    right: 0;
}
.month-swiper-container .swiper-buttons-prev.swiper-button-disabled, .month-swiper-container .swiper-buttons-next.swiper-button-disabled{
    opacity: 0.5;
}
.month-swiper-container .swiper-buttons-prev, .month-swiper-container .swiper-buttons-next{
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    max-height: 32px;
    cursor: pointer;
}
.calendar-container{
    position: relative;
}
.custom-tooltip {
    position: absolute;
    background: #fff;
    border-radius: 8px;
    filter: drop-shadow(0px 4px 12px rgba(0,0,0,0.15));
    padding: 1.5rem 12px;
    font-size: 13px;
    z-index: 999;
    min-width: 160px;
    border: 1px solid #eee;
    transition: opacity 0.2s ease;
    pointer-events: none;
}
.custom-tooltip::after {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border-width: 6px;
    border-style: solid;
    border-color: #ffffff transparent transparent transparent;
}
.tooltip-row{
    display: flex;
    gap: 2rem;
    color: #111111;
}
.tooltip-row + .tooltip-row{
    margin-top: 1rem;
}
.tooltip-row .tooltip-new-price{
    color: #000;
    margin-left: auto;
    font-weight: bold;
}
.booking-form{
    margin-top: 24px;
}
.booking-star, .booking-infor{
    background-color: #F6F6F6;
    border-radius: 20px;
    padding: 24px;
    font-size: 16px;
    color: #111111;
}
.booking-infor{
    margin-top: 24px;
}
.booking-form .booking-star-label{
    color: #000;
    font-weight: bold;
    font-size: 16px;
    margin-bottom: 12px;
    display: block;
}
.booking-form .date-star{
    padding: 10px 1rem;
    border-radius: 4px;
    border: 1px solid #E7E7E7;
    display: flex;
    align-items: center;
    gap: 12px;
    background-color: white;
    margin-bottom: 24px;
}
.booking-form .date-star input{
    background-color: transparent;
    border: none;
    font-size: 16px;
    color: #000;
    padding: 0;    
}
.booking-form .group-room{
    display: grid;
    grid-template-columns: repeat(2, 200px);
    gap: 1rem;
}
.booking-form .group-room .form-group{
    display: flex;
    flex-direction: column;
}
.form-group.mt-4{
    margin-top: 1rem;
}
.booking-form .form-group select,.booking-form .form-group input{
    border: 1px solid #E7E7E7;
    background-color: white;
    border-radius: 4px;
    padding: 10px 1rem;
    font-size: 16px;
    margin-top: 8px;
    width: 100%;
}
.booking-form .form-group select:focus, .booking-form .form-group input:focus{
    border-color: #2d3940;
    color: #3e3e3e;
}
.booking-form .add-room-btn{
    background-color: var(--et-primary-color);
    color: white;
    border-radius: 50px;
    border: 0;
    padding: 10px 2.8rem;
    margin-top: 1rem;
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 24px;
    cursor: pointer;
}
.booking-form .minus-room-btn{    
    color: #111111;
    border-radius: 50px;
    border: 1px solid;
    padding: 10px 2.8rem;
    margin-top: 1rem;
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 24px;
    cursor: pointer;
    margin-left: 1rem;
}
.booking-form .group{
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
    margin-top: 12px;
}
.booking-form [class*="person"]{
    margin-bottom: 24px;
}
.booking-form [class*="room"] + [class*="room"]{
    margin-top: 1rem;
}
#product-tour-price-breakdown{
    position: sticky;
    top: 24px;
}
.product-tour-price-wrapper{
    margin-top: calc(77px + 1rem);
    background-color: #E9F6ED;
    border-radius: 24px;
    padding: 24px;
}
.product-tour-price-wrapper .total{
    border-bottom: 1px solid rgba(5, 74, 30, 0.2);
    margin-bottom: 1rem;
}
.product-tour-price-wrapper .total strong{
    display: block;
    font-weight: bold;
    font-size: 16px;
    color: #111111;
}
.product-tour-price-wrapper .total span{
    font-weight: 600;
    font-size: 28px;
    color: #E84343;
    margin-bottom: 16px;
    display: block;
    line-height: normal;
}
.product-tour-price-wrapper .room-detail{
    color: #000000;
    font-size: 16px;
    margin-bottom: 24px;
}
.product-tour-price-wrapper button{
    background-color: var(--et-primary-color);
    color: white;
    width: 100%;
    border-radius: 50px;
    border: 0;
    padding: 10px 2.8rem;    
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
}
#scroll-nav-bar {
    background-color: #fff;
    box-shadow: 0 2px 12px 0 rgba(0, 36, 90, .12);
    left: 0;
    position: fixed;
    right: 0;
    top: 0;
    z-index: 1000;
}
#scroll-nav-bar .et_pb_row {
    overflow: hidden;
}
#scroll-nav-bar .scroll {
    display: flex;    
    position: relative;
    transition: transform 0.3s ease;
    will-change: transform;
}
#scroll-nav-bar .et_pb_row, .my-product-display-price-fix-content .et_pb_row{
    padding: 0;
    max-width: 1272px;
    margin: 0 auto;
}
#scroll-nav-bar .et_pb_row button{
    box-sizing: border-box;    
    display: inline-block;    
    font-weight: 500;
    list-style: none;    
    position: relative;
    color: #777;
    font-size: 16px;
    height: 56px;
    line-height: 56px;
    margin: 0 24px;
    border: 0;
    padding: 0;
    background-color: transparent;
    margin-left: 0;
    cursor: pointer;    
}
#scroll-nav-bar .et_pb_row button::after{
    content: "";
    position: absolute;
    width: 0;
    height: 2px;
    background-color: var(--et-primary-color);
    left: 50%;
    transform: translateX(-50%);
    bottom: 0;
    transition: all 0.3s ease-in-out;
}
#scroll-nav-bar .et_pb_row button.active{
    color: var(--et-primary-color);
    font-weight: bold;
}
#scroll-nav-bar .et_pb_row button.active::after{
    width: 100%;
}
.my-product-display-price-fix-content{
    position: fixed;
    z-index: 9999;
    bottom: 0;
    left: 0;
    width: 100%;
    box-shadow: 0 -4px 50px 0 hsla(0,0%,95%,.8);
    background-color: white;    
}
.my-product-display-price-fix-content .et_pb_row{
    padding: 1rem 0;
}
.my-product-display-price-fix-content .infor-basic{
    border: 0;
    padding: 0;
    display: flex;
    align-items: center;
}
.my-product-display-price-fix-content .infor-basic .sale{
    height: fit-content;
}
.my-product-display-price-fix-content .infor-basic .price-from-to, .my-product-display-price-fix-content .infor-basic .check-tour{
    margin: 0;
}
.my-product-display-price-fix-content .infor-basic .check-tour{
    margin-left: auto;
}
.my-product-display-price-fix-content .infor-price{
    display: flex;
    align-items: end;
}
.my-product-display-price-fix-content .infor-price .price-from-to .group{
    flex-direction: column-reverse;
}
.my-product-display-price-fix-content .infor-price .sale{
    font-size: 12px;    
    padding: 4px 10px;
    margin-left: 2rem;
}
.box-adv {
    align-items: center;
}
.box-adv .star >span{
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 18px;
    font-weight: 600;
    color: #111111;
}
.box-adv .star >span svg{
    margin-bottom: 5px;
}
.box-adv .services{
    list-style: none;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
}
.box-adv .services li span{
    font-weight: 600;
    color: #111111;
    width: 55%;
    display: inline-block;
}
#comment-btn-submit{
    margin-top: 1rem;
    background-color: var(--et-primary-color);
    border-radius: 50px;
    text-align: center;
    color: white;
    padding: 10px 24px;    
    cursor: pointer;
    display: inline-block;
}
.list-comment{
    margin-top: 24px;
}
.item-comment{
    display: flex;
    gap: 1rem;
}
.item-comment+.item-comment{
    margin-top: 24px;
    padding-top: 24px;
    border-top: 1px solid #ccc;
}
.item-comment .avatar{
    flex: 0 0 72px;
    height: 72px;
    border-radius: 50%;
    overflow: hidden;
    text-align: center;
    line-height: 72px;
    background-color: #ccc;
    text-transform: uppercase;
    color: #111111;
    font-weight: bold;
}
.item-comment .avatar img{
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.item-comment .right-comment{
    width: 100%;
}
.item-comment .content-top{
    display: flex;
    align-items: center;
    min-height: 72px;
    margin-bottom: 1rem;
}
.item-comment .content-top .name{
    font-weight: 600;
    color: #111111;
    margin-bottom: 8px;
    text-transform: uppercase;
}
.item-comment .content-top i{
    color: #E4BA58;
}
.item-comment .content-top .date{
    margin-left: auto;
}
.item-comment .content-bot .attachment{
    display: grid;
    flex-wrap: wrap;
    gap: 1rem;
    grid-template-columns: repeat(4, 1fr);
    margin-top: 1rem;
}
.item-comment .content-bot .attachment .item{
    padding-top: 120px;
    position: relative;
    border-radius: 8px;
    overflow: hidden;
}
.item-comment .content-bot .attachment .item img{
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}
#form-comment-contain {
    display: none;
    background-color: #fbf6f6;
    width: 60%;
}
#reply-title {
    font-size: 30px;
    font-weight: 600;
    padding: 0 0 5px 0;
    margin: 0;    
}
#commentform p.stars {
    margin: 0;
    padding: 5px 0;
}
#commentform input[type=text],
#commentform input[type=password],
#commentform input[type=date],
#commentform input[type=datetime],
#commentform input[type=datetime-local],
#commentform input[type=month],
#commentform input[type=week],
#commentform input[type=email],
#commentform input[type=number],
#commentform input[type=search],
#commentform input[type=tel],
#commentform input[type=time],
#commentform input[type=url] {
    display: block;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;    
    height: 2.4375rem;
    margin: 0 0 1rem;    
    border: 1px solid #cacaca;
    border-radius: 0;
    background-color: #FFFFFF;
    -webkit-box-shadow: 0;
    box-shadow: 0;
    font-family: inherit;
    font-size: 1rem;
    font-weight: normal;
    line-height: 1.5;
    color: #000000;
    -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
    transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
    transition: box-shadow 0.5s, border-color 0.25s ease-in-out;
    transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}
#form-comment-contain #commentform input:not([type="checkbox"]), #form-comment-contain #commentform textarea{
    width: 100%;
    font-size: 14px;
}
#form-comment-contain .comment-form-attachment>span:not(.required) {
    display: none;
}
#form-comment-contain #commentform .form-submit {
    text-align: left;
}
#form-comment-contain #commentform .form-submit input{
    border: 0!important;
    color: white!important;
    width: fit-content!important;
    font-size: 18px!important;
}
#tour-feature{
    margin-top: 80px;
}
#tour-feature .title-feature{
    font-size: 32px;
    font-weight: 500;
    color: #111111;
}
.product-featured{
    position: relative;
}
.filter_mb{
    display: none;
}
.booking-form .form-group input.error, .booking-form .form-group select.error {
    border: 1px solid red;
    background-color: #fff0f0;
}
#payment .wc_payment_methods{
    padding-left: 0;
    padding-right: 0;
}
#payment .wc_payment_methods .payment_box{
    display: none!important;
}
.woocommerce-checkout h1{
    font-size: 1.25rem;
    font-weight: bold;
    margin-bottom: 0.625rem;
}
.woocommerce-checkout h3{
    font-size: 1.825rem;
    font-weight: bold;
    padding-bottom: 0;
    margin-bottom: 1rem;
}
.woocommerce-checkout h3::after{
    content: '';
    position: absolute;
    left: 0;
    width: 5px;
    height: 28px;
    background-color: #054a1e;
    border-top-right-radius: 6px;
    border-bottom-right-radius: 6px;
}
.woocommerce-checkout h4{
    font-weight: bold;
}
.woocommerce-checkout .col-1{
    padding: 1rem;
    border-radius: 10px;
    box-shadow: 0 0px 5px rgba(0, 0, 0, .12);
    background-color: #ffffff;
    position: relative;
}
.woocommerce-checkout .col-1 #payment{
    background-color: transparent;
}
.woocommerce-checkout .col-1 .payment-info{
    background-color: rgba(5, 74, 30, 0.1);
    padding: 4px 8px;
    border-radius: 4px;
    color: #054a1e;
    margin-bottom: 1rem;
}
.woocommerce-checkout .col-1 .wc_payment_method{
    padding: 1rem;
    border-radius: 10px;
    box-shadow: 0 0px 5px rgba(0, 0, 0, .12);
    display: flex;
}
.woocommerce-checkout .col-1 .wc_payment_method img{
    height: 30px;
    margin-left: auto !important;
}
.woocommerce-checkout .col-1 .wc_payment_method label{
    width: 100%;
    display: flex;
    justify-content: space-between;
}
.woocommerce-checkout .col-1 .wc_payment_method+.wc_payment_method{
    margin-top: 1rem!important;
}
.woocommerce-checkout .col-1 #place_order{
    width: 100%;
    margin-top: 1rem;
    background-color: #054a1e;
    color: white;
    border-color: #054a1e;
    border-radius: 8px;
    cursor: pointer;
}
.woocommerce-checkout .col-2 .short-description, .woocommerce-checkout .col-2 .booking_summary, .woocommerce-checkout .col-2 .price_breakdown{
    padding: 1rem;
    border-radius: 10px;
    box-shadow: 0 0px 5px rgba(0, 0, 0, .12);
    background-color: #ffffff;
    margin-bottom: 1rem;
}
.woocommerce-checkout .col-2 .price_breakdown{
    margin-bottom: 0;
}
.woocommerce-checkout .col-2 .booking_summary label, .woocommerce-checkout .col-2 .price_breakdown label{
    font-size: 1.625rem;
    font-weight: bold;
    padding-bottom: 0;
    margin-bottom: 1rem;
    color: #000000;
    display: block;
}  
.woocommerce-checkout .col-2 .booking_summary p, .woocommerce-checkout .col-2 .price_breakdown p{
    display: flex;
    justify-content: space-between;
}
.woocommerce-checkout .col-2 .short-description p strong, .woocommerce-checkout .col-2 .booking_summary p strong, .woocommerce-checkout .col-2 .price_breakdown b{
    color: #000;
}
.woocommerce-checkout .col-2 .short-description p.show-popup{
    cursor: pointer;
    padding-bottom: 1rem;
}
.woocommerce-checkout .col-2 .short-description p svg{
    vertical-align: sub;
}
.woocommerce-checkout .col-2 .price_breakdown .payment-amount{
    font-weight: bold;
    font-size: 1rem;
    color: #000000;
}
.woocommerce-checkout .col-2 .price_breakdown .payment-amount b{
    font-size: 1.5rem;
}
.woocommerce-checkout .woocommerce-order .woocommerce-notice{
    font-size: 1.425rem;
    color: #054A1E;
    font-weight: bold;
    margin-bottom: 0.8rem;
}
.woocommerce-checkout .woocommerce-order h3{
    font-size: 1.25rem;
}
.woocommerce-checkout .woocommerce-order h3.miko-title{
    margin-top: 1rem;
}
.woocommerce-checkout .woocommerce-order h3::after{
    height: 20px;
}
.woocommerce-checkout .woocommerce-order p{
    display: flex;
    gap: 4px;
    align-items: center;
    padding-bottom: 0.5rem;
}
.woocommerce-checkout .woocommerce-order p span{
    color: #E84343;
}
.woocommerce-checkout .woocommerce-order ul{
    list-style: none;
    padding-left: 0;
}

.woocommerce-checkout .woocommerce-order a.button{
    font-size: 1rem;
}
.woocommerce-checkout .woocommerce-order a.button::after{
    font-size: 24px;
}

@media screen and (max-width: 1024px) {
    .details h1, .title-head .title-main, #tour-feature .title-feature{
        font-size: 26px;
    }
    .details .image{
        padding-top: 460px;
    }
    .details .infor-basic{
        padding: 1rem;
    }
    .details .notes .note_content{
        transform: translateX(-90%);
    }
    .details .notes .note_content::after{
        left: 90%;
    }
    .calendar-body{
        display: flex;
        flex-wrap: wrap;
    }
    .calendar-info{
        flex: 0 0 100%;
        max-width: 100%;
    }
    .my-product-display-price-fix-content .infor-basic{
        padding: 0;
    }
}
@media screen and (max-width: 823px) {
    .filter_mb{
        align-items: center;
        border: 1px solid #aaa;
        border-radius: 8px;
        color: #222;
        cursor: pointer;
        display: inline-flex;
        font-size: 12px;
        padding: 4px 6px;
        margin-top: 1rem;
    }        
    .filter_mb .icon{        
        background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACgAAAAoCAYAAACM/rhtAAAAAXNSR0IArs4c6QAAAYFJREFUWEftmNtVxCAQhiFpQCswgQa0A+1AO1hLsBJL2GMFbgfagVZA0sGmgTAuno1nJZOcIVySB/LKJR//MPMDnG384xvnYxnQN0KoglVVVWVZ7gHgljF2xTk/9H3/0rZt6/tD1/EjQANXFMWXAbMm67TWd6khR4BSyncAeMRWCgCfTdM8DG1Syh0A3LiqgvXXWpu1v9ltI0AhBMz8sFNKXZv2M9w+BNwwxwlyZ0NigEckvH8cSqnfMasB1nX9wTm/n1DmoJR6WjXEm08So84Z8pUxZpKlOyXNNwA8p85gw5KdxDfLs4KrKpjCsxeHOFU5QgExj7W9MrRnk714zsIuvTKGZ5O82AEwuGeTAC8OAv+OUXYIQns2OcTUsrBqkjhCRvXsxWWGugjffhkwK+irADbexcOT70HX8kT24qVK+ng4euSPfZ2kevggCPayYF4Lol3IhRAkD58EnPLiUCF28fBVbnVBkmSpWtRxLvfu5GWGuojZPeg6Scz+WUFfdX8AEKt8OHJnaw8AAAAASUVORK5CYII=);
        background-size: 100% 100%;
        height: 20px;
        margin-right: 6px;
        width: 20px;
    }
    #my-search-filter{
        display: none;
        width: 98%;
        padding: 1.5rem;
    }
    .et-db #et-boc .et-l .et_pb_column.mb-0{
        margin-bottom: 0!important;
    }
    .col-8, .col-4, .col-6{
        width: 100%;
    }
    .infor-basic{
        margin-top: 1rem;
    }
    #box-second .col-8{
        order: 1;
        margin-top: 1rem;
    }
    #box-second .image-map{
        margin-top: 0.8rem;
    }
    #scroll-nav-bar .et_pb_row button{
        margin-right: 1rem;
        font-size: 14px;
    }
    .my-product-display-price-fix-content .infor-basic{
        padding: 0;
        margin: 0;
    }
    .yith_wcwl_wishlist_footer .yith-wcwl-share{
        list-style: none;
        width: 100%;
        float: none;
    }
    #main-content #left-area ul, #main-content .entry-content ul{
        padding: 0;
        list-style: none;
    }
    .wishlist_table.mobile li .item-details h3{
        font-size: 1rem;
    }
    .wishlist_table.mobile li{
        display: flex;
    }
    .wishlist_table.mobile li .additional-info-wrapper{
        margin-left: auto;
    }
    #form-comment-contain{
        width: 90%;
        padding: 2rem 1rem 1rem;
    }
    #reply-title{
        font-size: 24px;
    }
    .details .notes .note_content{
        transform: translateX(-50%);
    }
    .details .notes .note_content::after{
        left: 50%;
    }
}
@media screen and (max-width: 500px) {
    #scroll-nav-bar{
        white-space: nowrap;
    }
    .details .title{
        padding: 0.5rem;
    }
    .details h1, .title-head .title-main, #tour-feature .title-feature{
        font-size: 18px;
    }
    .details .image{
        padding-top: 100%;
    }
    .details .infor-basic .sale{
        font-size: 1.25rem;
    }
    .timeline-header{
        font-size: 15px;
    }
    .timeline-content, .list-pick-up .item{
        font-size: 14px;
        padding: 1rem;
    }
    .calendar-grid{
        grid-template-columns: repeat(7, 38px);
        grid-auto-rows: 38px;
        gap: 0.8rem;
        font-size: 18px;
    }
    .calendar-grid .header, .calendar-grid .day{
        line-height: 38px;
    }
    .booking-star, .booking-infor{
        padding: 1rem;
    }
    .booking-form .group-room, .booking-form .group{
        grid-template-columns: repeat(1, 1fr);
    }
    .booking-form .minus-room-btn{
        margin-left: 2%;
        margin-top: 0!important;
    }
    .booking-form .minus-room-btn, .booking-form .add-room-btn{
        width: 48%;
        padding-left: 0;
        padding-right: 0;
    }
    .product-tour-price-wrapper{
        margin-top: 2rem;
    }
    .item-comment .content-bot .attachment{
        grid-template-columns: repeat(2, 1fr);
    }
    .col-3{
        margin-bottom: 1rem;
    }
    .col-3, .col-9{
        width: 100%;
    }
    .box-adv .services{
        grid-template-columns: 1fr;
        gap: 0.5rem;
    }
    .box-adv .services li span{
        width: 80%;
    }
    .item-comment .avatar{
        flex: 0 0 50px;
        height: 50px;
        line-height: 50px;
    }
    .booking-form .form-group select, .booking-form .form-group input, .booking-form .date-star input{
        font-size: 14px;
    }
    .my-product-display-price-fix-content .infor-price{
        flex-wrap: wrap;
    }
    .details .infor-basic .sale{
        margin-left: 0;
    }
    .details .infor-basic .price-from-to{
        gap: 8px;
        font-size: 12px;
    }
    .details .infor-basic .price-from-to .group .price{
        font-size: 14px;
    }
    .my-product-display-price-fix-content .infor-price .sale{
        font-size: 12px;
    }
    .my-product-display-price-fix-content .infor-basic .check-tour{
        font-size: 12px;
        white-space: nowrap;        
    }
    .my-product-display-price-fix-content .et_pb_row{
        padding: 0.5rem!important;
    }
    #scroll-nav-bar .et_pb_row{
        padding: 0!important;
        margin: 0 15px;
        overflow: hidden;
    }
}
@media screen and (max-width: 420px) {
    .calendar-grid{
        padding: 0.5rem;
    }
    .calendar-grid{
        grid-template-columns: repeat(7, 42px);
        grid-auto-rows: 42px;
        gap: 0.75rem;
        font-size: 16px;
        border-radius: 8px;
    }
    .calendar-grid .header, .calendar-grid .day{
        line-height: 42px;
    }
}
@media screen and (max-width: 400px) {
    .calendar-grid{
        padding: 0.5rem;
    }
    .calendar-grid{
        grid-template-columns: repeat(7, 36px);
        grid-auto-rows: 36px;
        gap: 0.75rem;
        font-size: 16px;
        border-radius: 8px;
    }
    .calendar-grid .header, .calendar-grid .day{
        line-height: 36px;
    }
}