.product-detail {
    padding-bottom: 125.3px;
}

.product-heading {
    position: relative;
    z-index: 2;
    margin-top: 40px;
}

.product-heading .title-tag .product-title {
    margin: 0;
    font-family: 'Noto Sans TC';
}

.product-heading .tag {
    padding: 3.74px 10px 4px;
    background: #F1AB25;
    border-radius: 60px;
    font-size: 14px;
    font-weight: 600;
    line-height: 19.07px;
    color: #000000;
    width: max-content;
    display: inline-flex;
    align-items: center;
}

.product-heading .tag.outofstock {
    color: #fff;
    background-color: #767676;
}

.product-heading .title-tag {
    display: flex;
    gap: 16px;
    align-items: center;
    flex-wrap: wrap;
    margin-bottom: 10px;
}

.product-heading .tax-socials {
    font-size: 18px;
    line-height: 26.06px;
    font-weight: 500;
}

.product-heading .tax-socials .socials .share-social a {
    margin: 20px 0;
    display: block;
}

.product-heading .tax-socials .socials .share-social {
    position: absolute;
    top: calc(100% + 16px);
    right: 0;
    padding: 0 31px;
    background: #ffffff;
    box-shadow: 0px 0px 4px 0px #00000040;
    border-radius: 10px;
    display: none;
}

.product-heading .tax-socials .downloadable-files .file a::before,
.product-heading .tax-socials .socials .label::before {
    content: '';
    width: 24px;
    height: 24px;
    display: inline-block;
    vertical-align: bottom;
    background: url('../images/material-symbols_share-outline.svg');
    background-size: contain;
    background-repeat: no-repeat;
    margin-right: 4px;
}

.product-heading .tax-socials .downloadable-files .file a::before {
    background: url('../images/material-symbols_download.svg');
    background-size: contain;
    background-repeat: no-repeat;
}

.product-heading .tax-socials .downloadable-files .file a:hover {
    color: inherit;
}

.product-heading .tax-socials .tax .country,
.product-heading .tax-socials .downloadable-files .file a:hover,
.product-heading .tax-socials .downloadable-files .file a,
.product-heading .tax-socials .socials .label {
    cursor: pointer;
    position: relative;
    text-decoration-line: underline;
    text-decoration-style: solid;
    text-underline-position: from-font;
    text-decoration-skip-ink: auto;
    transition: all .3s;
}

.product-detail.local-project .product-heading .tax-socials .tax .country {
    cursor: auto;
    text-decoration: none;
}

.related-products .country,
.map-popup .country,
.map-section .country,
.product-heading .tax-socials .socials .share {
    position: relative;
}

.related-products .country::before,
.map-popup .country::before,
.map-section .country::before,
.product-heading .tax-socials .tax .country::before,
.product-heading .tax-socials .tax .type::before {
    content: '';
    width: 20px;
    height: 20px;
    display: inline-block;
    vertical-align: middle;
    background: url('../images/material-symbols_trip.svg');
    background-size: contain;
    background-repeat: no-repeat;
    margin-right: 4px;
    margin-top: -5px;
}

.related-products .country::before,
.map-popup .country::before,
.map-section .country::before,
.product-heading .tax-socials .tax .country::before {
    background: url('../images/mdi_location.svg');
    background-size: contain;
    background-repeat: no-repeat;
}

.related-products .country::before {
    width: 16px;
    height: 16px;
}

.product-heading .tax-socials .socials,
.product-heading .tax-socials .tax,
.product-heading .tax-socials {
    display: flex;
    gap: 20px;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
}

/* product-gallery */
.product-gallery .featured-gallery {
    border-radius: 10px;
    overflow: hidden;
}

.product-gallery .featured-gallery img {
    height: 439px;
    width: 100%;
    object-fit: cover;
    object-position: center;
}

.product-gallery {
    margin-top: 16px;
}

.product-gallery .product-gallery-layout .gallery-image.hide {
    display: none;
}

.product-gallery .product-gallery-layout .gallery-image {
    height: calc(50% - 5px);
}

.product-gallery .product-gallery-layout .gallery-image {
    width: calc(50% - 5px);
}

.product-gallery .product-gallery-layout.international-workcamp .featured-image {
    width: 50%;
}

.product-gallery .product-gallery-layout .gallery-images {
    width: calc(50% - 10px);
}

.product-gallery .product-gallery-layout .gallery-image img,
.product-gallery .product-gallery-layout.international-workcamp .featured-image img {
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
    object-fit: cover;
    object-position: center;
}

.product-gallery .product-gallery-layout .gallery-image,
.product-gallery .product-gallery-layout.international-workcamp .featured-image {
    cursor: pointer;
    height: 0;
    padding-bottom: 34.47%;
    position: relative;
}

.product-gallery .product-gallery-layout .gallery-image {
    padding-bottom: 34.233%;
}

.product-gallery .product-gallery-layout .featured-image img,
.product-gallery .product-gallery-layout .gallery-images img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.product-gallery .product-gallery-layout .gallery-more button svg {
    position: absolute;
    left: 10px;
    top: 50%;
    transform: translateY(-50%);
}

.product-gallery .product-gallery-layout .gallery-more button {
    background: #ffffff;
    color: #000000;
    padding: 11px 10px 9.83px 44px;
    position: relative;
    border-radius: 4px;
    font-size: 16px;
    font-weight: 500;
    line-height: 23.17px;
    border: none;
    outline: none;
    cursor: pointer;
    transition: all .3s;
    height: auto;
}

.product-gallery .product-gallery-layout .gallery-more {
    position: absolute;
    right: 20px;
    bottom: 20px;
}

.product-gallery .product-gallery-layout .gallery-images {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.product-gallery .product-gallery-layout.international-workcamp {
    display: flex;
    gap: 10px;
    border-radius: 10px;
    overflow: hidden;
    position: relative;
}

#product-gallery-items .gallery-click.hide {
    display: none;
}

/* product-informations */
.informations ul li::before {
    content: '';
    position: absolute;
    width: 4px;
    height: 4px;
    background: currentColor;
    left: 10px;
    top: 11px;
    border-radius: 50%;
}

.product-highlights ul li::before,
.product-requirements ul li::before {
    width: 12px;
    height: 12px;
    background: #5F7935;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
}

.informations ul li {
    padding-left: 24px;
    position: relative;
}

.product-highlights ul li {
    padding-left: 28px;
}

.informations ul {
    list-style-type: none;
    margin: 0;
    padding: 0;
}

.admin-bar .product-informations .addtocart-section .product-purchase-section {
    top: 152px;
}

.product-informations .addtocart-section .product-purchase-section {
    position: sticky;
    top: 120px;
    right: 0;
}

.addtocart-section .purchase-wrapper .product-price ins {
    text-decoration: none;
}

.addtocart-section .purchase-wrapper .product-price del {
    color: #979797;
}

.addtocart-section .purchase-wrapper .screen-reader-text {
    display: none;
}

.addtocart-section .purchase-wrapper .product-price {
    margin-top: 10px;
    font-size: 20px;
    line-height: 28.96px;
    font-weight: 500;
    color: #000000;
    display: flex;
    gap: 10px;
    align-items: center;
}

.addtocart-section .purchase-wrapper .product-title {
    margin: 0;
}

.addtocart-section .purchase-wrapper .product-tags {
    margin-bottom: 17px;
}

.product-detail.local-project.product-ended .addtocart-section .purchase-wrapper .product-tag {
    background: #990000;
    color: #ffffff;
}

.addtocart-section .purchase-wrapper .product-tag {
    padding: 3.3px 10px 4.44px;
    background: #F1AB25;
    color: #000000;
    border-radius: 60px;
    font-size: 14px;
    font-weight: 500;
    line-height: 20.27px;
    display: inline-block;
}

.addtocart-section .purchase-wrapper .product-tag.outofstock {
    background: #767676;
    color: #fff;
}

.addtocart-section .quantity-input input.qty::-webkit-inner-spin-button {
    display: none;
}

.addtocart-section .variation-select .current-value.open svg {
    transform: rotate(180deg);
}

.addtocart-section .variation-select .current-value svg {
    position: absolute;
    right: 19px;
    top: 13px;
    transition: all .3s;
}

.addtocart-section .variation-select .date-select .option:hover,
.addtocart-section .variation-select .date-select .option.active {
    background: #F5F5F5;
}

.addtocart-section .variation-select .date-select .option span {
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.addtocart-section .variation-select .date-select .option {
    color: #000000;
    padding: 15px 20px;
    cursor: pointer;
}

.addtocart-section .variation-select .date-select .option.disabled {
    color: #959595;
    pointer-events: none;
}

.addtocart-section .product-purchase-section .terms-link a {
    text-decoration-line: underline;
    text-decoration-style: solid;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
    color: inherit;
}

.addtocart-section .product-purchase-section .terms-link {
    font-size: 15px;
    font-weight: 500;
    line-height: 21.72px;
    text-align: center;
    color: #6A6A6A;
    max-width: 425px;
    margin: 24px auto 0;
}

.product-detail.product-ended .addtocart-section .product-purchase-section .terms-link,
.product-detail.product-ended .addtocart-section .purchase-note {
    display: none;
}

.addtocart-section .purchase-note {
    width: calc(100% - 63px);
    font-size: 15px;
    font-weight: 500;
    line-height: 21.72px;
    color: #6A6A6A;
    margin-top: 20px;
    text-align: center;
}

.addtocart-section .add-to-cart-wrapper {
    display: flex;
    align-items: center;
    margin-top: 20px;
}

.addtocart-section .yith-add-to-wishlist-button-block {
    margin: 0;
}

.addtocart-section .yith-wcwl-add-to-wishlist-button.yith-wcwl-add-to-wishlist-button--added {
    background-image: url('../images/cart-heart-active.svg');
}

.product-detail.product-ended .addtocart-section .yith-wcwl-add-to-wishlist-button {
    pointer-events: none;
}

.addtocart-section .yith-wcwl-add-to-wishlist-button {
    width: 63px;
    height: 52px;
    display: inline-block;
    background-image: url('../images/cart-heart.svg');
    background-position: center;
    background-repeat: no-repeat;
    background-size: 33px 30px;
}

.addtocart-section .yith-wcwl-add-to-wishlist-button .yith-wcwl-add-to-wishlist-button__label,
.addtocart-section .yith-wcwl-add-to-wishlist-button svg {
    display: none;
}

.addtocart-section .variation-select .date-select {
    border: 1px solid #6A6A6A;
    box-shadow: 0px 0px 10px 0px #0000001A;
    z-index: 9;
    position: absolute;
    width: 100%;
    top: calc(100% + 10px);
    background: #ffffff;
    border-radius: 10px;
    display: none;
    overflow: hidden;
    max-height: 170px;
    overflow-y: auto;
}

.addtocart-section .variation-select {
    position: relative;
}

.addtocart-section .variation-select .current-value .text {
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.addtocart-section .variation-select .current-value .text.disabled {
    color: #959595;
}
.addtocart-section .variation-select .current-value.disabled svg path {
    fill: #959595;
}

.product-detail.product-ended .addtocart-section .variation-select .current-value svg path {
    fill: #959595;
}

.product-detail.product-ended .addtocart-section .variation-select .current-value {
    color: #959595;
}

.addtocart-section .variation-select.error .current-value {
    border: 1px solid #990000;
}

.addtocart-section .variation-select .current-value {
    border: 1px solid #6A6A6A;
    border-radius: 10px;
    padding: 13px 53px 13px 20px;
    color: #000000;
    position: relative;
    cursor: pointer;
}

.addtocart-section .product-variations {
    margin-bottom: 16px;
}

.addtocart-section .add-to-cart-wrapper .add-to-cart-button.disabled,
.product-detail.product-ended .addtocart-section .add-to-cart-button {
    background: #767676;
    pointer-events: none;
}

.addtocart-section .add-to-cart-button {
    font-size: 16px;
    font-weight: 500;
    line-height: 23.17px;
    height: 51px;
    width: calc(100% - 63px);
}

.addtocart-section .variation-select .current-value .text.disabled {
    color: #959595;
}

.addtocart-section .quantity-input.disabled .quantity-label,
.addtocart-section .quantity-input.disabled input.qty,
.product-detail.product-ended .addtocart-section .quantity-input .quantity-label,
.product-detail.product-ended .addtocart-section .quantity-input input.qty {
    color: #959595;
    pointer-events: none;
}

.addtocart-section .quantity-input input.qty {
    border: 1px solid #000000;
    color: #000000;
    padding: 13px 27px 13px 50%;
    text-align: right;
}
.addtocart-section .quantity-input input.qty.disabled {
    color: #959595;
}
.addtocart-section .quantity-input .quantity-label.disabled {
    color: #959595;
}



.addtocart-section .quantity-input .quantity-label {
    position: absolute;
    top: 14px;
    left: 20px;
    color: #000000;
}

.addtocart-section .quantity-input {
    position: relative;
}

.addtocart-section label {
    font-size: 16px;
    font-weight: 500;
    line-height: 23.17px;
    margin: 0 0 10px;
    display: block;
}

.addtocart-section form.cart {
    margin-top: 20px;
}

.addtocart-section .purchase-wrapper {
    box-shadow: 0px 0px 10px 0px #0000001A;
    padding: 40px;
    border-radius: 10px;
}

.product-detail.local-project.product-ended .product-heading .tag {
    background: #990000;
    color: #ffffff;
}

.product-informations .addtocart-section {
    max-width: 471px;
    width: 100%;
}

.product-informations>.container {
    position: relative;
    display: flex;
    justify-content: space-between;
    gap: 40px;
}

.product-informations {
    margin-top: 42px;
}

.informations {
    max-width: 684px;
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 40px;
    margin-top: 1px;
}

.informations .sdgs-logos .logos .logo {
    width: 90px;
    height: 90px;
}

.informations .sdgs-logos .logos {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.informations .sdgs-logos .sdgs-logos-title {
    margin: 0 0 18px;
}

.product-description p:not(:last-child) {
    margin-bottom: 27px;
}

/* product-highlights */
.product-highlights .tab-titles .highlights-title.active {
    color: #222222;
}

.product-highlights .tab-titles .highlights-title.active::after {
    opacity: 1;
}

.product-highlights .tab-titles .highlights-title.normal::after {
    display: none;
}

.product-highlights .tab-titles .highlights-title::after {
    content: '';
    width: 100%;
    height: 2px;
    background: currentColor;
    position: absolute;
    bottom: 0;
    left: 0;
    transition: all .3s;
    opacity: 0;
}

.product-highlights .tab-titles .highlights-title.normal {
    padding: 0;
    max-width: initial;
    width: auto;
}

.product-highlights .tab-titles .highlights-title {
    padding: 8px 20px 8.05px;
    text-align: center;
    font-size: 20px;
    font-weight: 500;
    line-height: 28.96px;
    cursor: pointer;
    position: relative;
    max-width: 212px;
    width: 100%;
    color: #959595;
}

.product-highlights .highlights ul li:not(:last-child) {
    margin-bottom: 16px;
}

.product-highlights .highlights .highlight.active {
    opacity: 1;
}

.product-highlights .highlights .highlight {
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
    transition: all .3s;
}

.product-highlights .highlights {
    margin-top: 20px;
    position: relative;
}

.product-highlights .tab-titles {
    display: flex;
    gap: 24px;
    justify-content: flex-start;
}

/* product-requirements */
.product-requirements .requirements-title {
    margin: 0 0 20px;
}

.informations .product-requirements ul li {
    padding-left: 36px;
}

.informations .product-requirements ul li::before {
    width: 10px;
    height: 10px;
    left: 8px;
}

.product-requirements {
    padding-top: 39px;
    border-top: 1px solid #959595;
}

.product-requirements ul li:not(:last-child) {
    margin-bottom: 10px;
}

/* product-fees */
.product-fees .fees .fees-title {
    margin: 0 0 19px;
}

.product-fees .fee .info .content {
    color: #767676;
}

.product-fees .fee .info .title {
    font-size: 16px;
    font-weight: 700;
    line-height: 23.17px;
    margin: 0 0 8px;
}

.product-fees .fee .info .icon {
    width: 24px;
}

.product-fees .fee .info {
    max-width: 464px;

}

.product-fees .fee:not(:first-child) {
    margin-top: 16px;
}

.product-fees:not(.product-fees-popup) .fees .fee.hide {
    display: none;
}

.product-fees .fee {
    border: 1px solid #D9D9D9;
    border-radius: 10px;
    padding: 15px 15px 14.83px;
    display: flex;
    gap: 16px;
}

.product-fees {
    display: flex;
    flex-direction: column;
    gap: 40px;
}

.product-fees .fees .show-all::after {
    content: '';
    margin-left: 4px;
    width: 18px;
    height: 18px;
    background-image: url('../images/arrow-up-bold.svg');
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    display: inline-block;
    /* transform: rotate(90deg); */
}

.product-fees .fees .show-all {
    margin-top: 40px;
    padding: 0;
    border-radius: 0;
    border: none;
    height: auto;
    background: transparent;
    font-size: 16px;
    font-weight: 500;
    line-height: 26px;
    text-decoration-line: underline;
    text-decoration-style: solid;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
    color: #222222;
    position: relative;
}

.has-border-top {
    padding-top: 40px;
    border-top: 1px solid #959595;
}

.product-fees-popup .popup-contents .popup-content-inner {
    padding-right: 24px;
    padding-bottom: 18px;
    max-height: 100%;
    overflow-y: auto;
}

.product-fees-popup .popup-contents {
    margin-top: 20px;
    padding: 0 24px;
    max-height: 476px;
    display: flex;
    flex-direction: column;
}

.product-fees-popup .popup-heading .close-button {
    position: absolute;
    left: 24px;
    top: 23px;
}

.product-fees-popup .popup-heading {
    padding: 22px 24px 21px;
    border-bottom: 1px solid #D9D9D9;
    position: relative;
    text-align: center;
    color: #000000;
}

.product-fees-popup .popup-container {
    max-width: 700px;
    max-height: 100vh;
    background: #FFFFFF;
    border-radius: 10px;
    overflow: hidden;
    margin: 0 auto;
}

/* product-video */
.product-video iframe {
    width: 100%;
}

/* product-registration-details */
.product-registration-details :is(h1, h2, h3, h4, h5, h6) {
    margin: 0 0 20px;
}

.product-registration-details a:hover {
    color: #5f7935;
}

.product-registration-details.local-project {
    padding-top: 40px;
    border-top: 1px solid #959595;
}

.product-registration-details a {
    color: inherit;
    text-decoration-line: underline;
    text-decoration-style: solid;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
}

/* blog-section */
.blog-section {
    margin-top: 40px;
}

.blog-section .term-link:hover {
    color: initial;
}

.blog-section .news-listing .description-detail {
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.blog-section .term-link::after {
    content: '';
    margin-top: -6px;
    margin-left: 4px;
    width: 18px;
    height: 18px;
    background-image: url('../images/arrow-up-bold.svg');
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    display: inline-block;
    vertical-align: middle;
}

.blog-section .term-link {
    display: inline-block;
    margin-top: 58px;
    font-weight: 500;
    text-decoration-line: underline;
    text-decoration-style: solid;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
}

.blog-section .title-section {
    margin: 0 0 20px;
}

.single .blog-section .news-listing {
    padding: 0;
}

/* map-section */
.map-section .map-title {
    margin: 0 0 19px;
}

.map-popup .countries,
.map-section .countries {
    margin-top: 20px;
    font-size: 18px;
    font-weight: 500;
    line-height: 26.06px;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
}

body .yith-wcwl-feedback-messages-container {
    display: none;
}

.map-section .leaflet-container {
    font-family: "Noto Sans TC", serif;
}

.map-section .leaflet-control-container {
    display: none;
}

.map-section .leaflet-map {
    min-height: 451px;
    border-radius: 10px;
    pointer-events: none;
}

.map-section {
    margin-top: 40px;
}

.map-popup .container {
    max-height: 100vh;
}

.map-popup .map-container {
    background: #ffffff;
    border-radius: 10px;
    padding: 24px;
    color: #000000;
}

.map-popup .leaflet-control-container {
    display: none;
}

.map-popup .leaflet-map {
    border-radius: 10px;
}

.map-popup .map-title {
    margin: 0 0 20px;
}

.gallery-popup .close-button,
.product-fees-popup .close-button,
.map-popup .close-button {
    margin-bottom: 40px;
    width: 24px;
    height: 24px;
    cursor: pointer;
    display: inline-block;
    color: #000000;
}

.gallery-popup .close-button {
    margin-bottom: 10px;
}

.gallery-popup.show,
.product-fees-popup.show,
.map-popup.show {
    opacity: 1;
    pointer-events: auto;
    z-index: 9999999;
}

.gallery-popup,
.product-fees-popup,
.map-popup {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #00000066;
    z-index: 9999992;
    display: flex;
    align-items: center;
    flex-direction: unset;
    opacity: 0;
    pointer-events: none;
    /* transition: all .3s; */
    overflow-y: auto;
}

.gallery-popup .container {
    max-height: 100vh;
    width: 100%;
}

.gallery-popup .swiper-pagination {
    position: static;
    padding: 20px 0;
    width: 100%;
}

.gallery-popup .gallery-slider .swiper {
    max-width: 710px;
}

.gallery-popup .gallery-thumbs .swiper-slide.swiper-slide-thumb-active .gallery-item::after {
    opacity: 0;
}

.gallery-popup .gallery-thumbs .swiper-slide .gallery-item::after {
    content: '';
    background: #000000;
    opacity: 0.5;
    width: 100%;
    height: 100%;
    transition: all .3s;
    position: absolute;
    left: 0;
    top: 0;
}

.gallery-popup .gallery-thumbs .swiper-slide .gallery-item {
    position: relative;
    cursor: pointer;
}

.gallery-popup .gallery-thumbs .swiper-slide {
    padding: 0 10px;
    width: 164px;
    height: 100px;
}

.gallery-popup .gallery-thumbs {
    max-width: 1184px;
    width: 100%;
    margin: 0 auto;
    overflow: hidden;
}

.gallery-popup .gallery-slider {
    position: relative;
    padding: 0 60px;
}

.gallery-popup-container .gallery-item img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.gallery-popup-container .gallery-item {
    width: 100%;
    height: 0;
    padding-bottom: 69.86%;
    position: relative;
}

.gallery-popup-container {
    background: #ffffff;
    border-radius: 10px;
    padding: 24px;
    width: 100%;
}

.product-fees-popup {
    overflow: hidden;
}

.product-fees .fee .icon {
    min-width: 24px;
    width: 24px;
}

/* related-products */
.related-products .related-title {
    margin: 0 0 40px;
}

.related-products {
    margin-top: 40px;
    padding-bottom: 0;
}

body.card-detail-show,
body.gallery-popup-show,
body.fees-popup-show,
body.map-popup-show {
    overflow: hidden;
}

/* width */
.addtocart-section .variation-select .date-select::-webkit-scrollbar,
.gallery-popup::-webkit-scrollbar,
.map-popup::-webkit-scrollbar,
.product-fees-popup .popup-contents .popup-content-inner::-webkit-scrollbar {
    width: 4px;
}

.addtocart-section .variation-select .date-select::-webkit-scrollbar-track,
.gallery-popup::-webkit-scrollbar-track,
.map-popup::-webkit-scrollbar-track,
.product-fees-popup .popup-contents .popup-content-inner::-webkit-scrollbar-track {
    background: transparent;
}

.addtocart-section .variation-select .date-select::-webkit-scrollbar-thumb,
.gallery-popup::-webkit-scrollbar-thumb,
.map-popup::-webkit-scrollbar-thumb,
.product-fees-popup .popup-contents .popup-content-inner::-webkit-scrollbar-thumb {
    background: #D9D9D9;
    border-radius: 10px;
}

.lg-outer .lg-inner {
    max-height: calc(100% - 80px);
}

.related-products {
    overflow: hidden;
}

.product-video iframe {
    min-height: 404px;
    height: initial;
}

/* product-content-box */
.product-description :is(h1, h2, h3, h4, h5, h6),
.product-content-box :is(h1, h2, h3, h4, h5, h6) {
    margin: 0 0 20px;
}

.product-content-box p:not(:last-child) {
    margin: 0 0 40px;
}

.product-content-box p+ul {
    margin-top: -40px;
    margin-bottom: 40px;
}

.product-content-box ul li {
    padding-left: 24px;
}

.product-content-box img {
    width: 100%;
    height: 500px;
    object-fit: cover;
    object-position: center;
}

.product-content-box {
    padding-top: 40px;
    border-top: 1px solid #959595;
}

.share-social .copy-link .copy-success {
    position: absolute;
    top: 120%;
    left: 50%;
    transform: translateX(-50%);
    background-color: black;
    color: white;
    padding: 5px 10px;
    border-radius: 5px;
    font-size: 12px;
    white-space: nowrap;
    font-family: var(--font-body);
    font-size: 16px;
    font-weight: 400;
    line-height: 26px;
}

.share-social .copy-link {
    position: relative;
}

@media(min-width: 768px) {

    .fixed-cart-section,
    .gallery-popup .popup-title,
    .screen-mobile {
        display: none !important;
    }

    .gallery-popup .gallery-thumbs .swiper-wrapper {
        justify-content: center;
    }
}

@media(min-width: 1200px) {

    body.card-detail-show .site-header,
    body.gallery-popup-show .site-header,
    body.fees-popup-show .site-header,
    body.map-popup-show .site-header,
    body.card-detail-show,
    body.gallery-popup-show,
    body.fees-popup-show,
    body.map-popup-show {
        padding-right: 17px;
    }

    body.card-detail-show .back-to-top,
    body.gallery-popup-show .back-to-top,
    body.fees-popup-show .back-to-top,
    body.map-popup-show .back-to-top {
        right: 25px;
    }
}

@media(max-width: 1365px) {
    .informations {
        max-width: calc(60% - 40px);
    }

    .product-informations .addtocart-section {
        max-width: 40%;
    }

    .product-video iframe {
        min-height: 380px;
    }
}

@media(max-width: 1199px) {
    .product-detail {
        padding-bottom: 110px;
    }

    .product-video iframe {
        min-height: 350px;
    }

    .product-gallery .featured-gallery img {
        height: 400px;
    }
}

@media(max-width: 1024px) {
    .product-detail {
        padding-bottom: 100px;
    }

    .single .blog-section .news-listing {
        gap: 20px;
    }

    .blog-section .news-listing .news-item {
        width: calc(50% - 10px);
    }

    .addtocart-section .purchase-wrapper {
        padding: 30px;
    }

    .product-video iframe {
        min-height: 300px;
    }

    .product-gallery .featured-gallery img {
        height: 350px;
    }
}

@media(max-width: 991px) {
    .product-gallery .featured-gallery img {
        height: 300px;
    }

    .product-video iframe {
        min-height: 250px;
    }

    .product-informations>.container {
        gap: 30px;
    }

    .informations {
        max-width: calc(60% - 30px);
    }

    .addtocart-section .purchase-wrapper {
        padding: 20px;
    }

    .addtocart-section .purchase-wrapper .product-tags {
        margin-bottom: 16px;
    }

    .addtocart-section .purchase-note,
    .addtocart-section {
        margin-top: 16px;
    }

    .lg-outer .lg {
        padding: 20px 0;
    }

    .lg-components {
        bottom: 20px;
    }

    .lg-outer .lg-thumb-outer,
    .lg-outer .lg-thumb-item {
        max-height: 80px;
    }

    .lg-outer .lg-inner {
        top: 50px !important;
        bottom: 146px !important;
    }

    .lg-sub-html {
        padding: 10px 24px;
    }

    .product-highlights .tab-titles {
        gap: 20px;
    }

    .product-highlights .tab-titles .highlights-title {
        padding: 8px 15px 8.05px;
    }
}

@media(max-width: 767.98px) {
    .product-gallery .featured-gallery img {
        height: 272px;
    }

    .product-gallery .featured-gallery {
        border-radius: 0;
    }

    .addtocart-section .purchase-wrapper .product-tags,
    .addtocart-section .product-purchase-section .terms-link {
        display: none;
    }

    .screen-desktop {
        display: none !important;
    }

    .fixed-cart-section .detail-price-button.disabled {
        pointer-events: none;
    }

    .fixed-cart-section .detail-price-button.disabled,
    .product-detail.product-ended .fixed-cart-section .detail-price-button {
        background: #767676;
    }

    .product-detail:not(.product-ended) .addtocart-section.show-detail .fixed-cart-section.change-color-btn .detail-price-button {
        background: #000000;
    }

    .fixed-cart-section .detail-price-button {
        padding: 14px 20px;
        min-width: 130.48px;
        height: 51px;
    }

    .fixed-cart-section .detail-price-sections,
    .fixed-cart-section .fixed-cart-wrapper {
        display: flex;
        gap: 20px;
        justify-content: space-between;
        align-items: flex-start;
    }

    .fixed-cart-section .product-price>.woocommerce-Price-amount,
    .fixed-cart-section .product-price ins {
        font-size: 20px;
        font-weight: 500;
        line-height: 28.96px;
        text-decoration-line: underline;
        text-decoration-style: solid;
        text-underline-position: from-font;
        text-decoration-skip-ink: none;
        color: #000000;
    }

    .fixed-cart-section .product-price del {
        order: 2;
        font-size: 14px;
        font-weight: 500;
        line-height: 20.27px;
        text-decoration-line: line-through;
        text-underline-position: from-font;
        text-decoration-skip-ink: none;
        color: #979797;
    }

    .fixed-cart-section .product-price {
        display: flex;
        flex-direction: column;
        justify-items: flex-start;
    }

    .fixed-cart-section .detail-price-sections {
        gap: 0;
    }

    .product-informations.fixed-cart .fixed-cart-section {
        transform: translateY(0);
    }

    .fixed-cart-section {
        position: fixed;
        border-top: 1px solid #D9D9D9;
        left: 0;
        bottom: 0;
        z-index: 9999991;
        background: #fff;
        padding: 19px;
        width: 100%;
        transition: all.3s;
        transform: translateY(0);
    }

    .product-gallery .container {
        max-width: 100%;
        padding: 0;
        height: 100%;
    }

    .product-gallery .product-gallery-layout.international-workcamp {
        border-radius: 0;
        display: block;
    }

    .product-gallery .product-gallery-layout .swiper-slide img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: center;
    }

    .informations {
        max-width: 100%;
        width: 100%;
    }

    .product-informations>.container {
        display: block;
    }

    .product-gallery .product-gallery-layout .swiper-pagination {
        background: #00000066;
        width: auto;
        border-radius: 4px;
        right: 20px;
        left: auto;
        bottom: 20px;
        font-size: 14px;
        font-weight: 500;
        line-height: 20.27px;
        color: #fff;
        padding: 3px 16px 2.74px;
        min-width: 62px;
    }

    .product-detail .product-top {
        display: flex;
        flex-direction: column;
        position: relative;
        margin-top: 20px;
    }

    .product-heading {
        order: 2;
    }

    .product-heading .tax-socials .socials {
        position: absolute;
        right: 20px;
        top: 20px;
        gap: 10px;
    }

    .product-heading {
        position: static;
        margin-top: 20px;
    }

    .product-heading .tax-socials .socials .label,
    .product-heading .tax-socials .downloadable-files .file a {
        font-size: 0;
        width: 35px;
        height: 35px;
        display: flex;
        align-items: center;
        justify-content: center;
        border-radius: 50%;
        background: #ffffff;
    }

    .product-heading .tax-socials .downloadable-files .file a::before,
    .product-heading .tax-socials .socials .label::before {
        margin: 0;
        vertical-align: middle;
    }

    .product-informations {
        margin-top: 20px;
    }

    .informations .sdgs-logos .logos .logo {
        width: 60px;
        height: 60px;
    }

    .product-highlights .tab-titles .highlights-title {
        font-size: 18px;
        line-height: 26.06px;
        padding: 8px 10px 8.05px;
        max-width: 101.67px;
    }

    .product-highlights .tab-titles {
        gap: 15px;
    }

    .product-fees-popup .container {
        max-width: 100%;
        padding: 0;
    }

    .product-fees-popup .popup-title {
        line-height: 23.17px;
        font-weight: 500;
    }

    .product-fees-popup .popup-container {
        max-width: 100vw;
        max-height: 100vh;
        width: 100vw;
        height: 100vh;
        border-radius: 0;
    }

    .product-fees-popup .popup-heading {
        padding: 24px 50px 23.83px;
    }

    .product-fees-popup .popup-heading .close-button {
        margin: 0;
        left: 20px;
    }

    .product-fees-popup .popup-heading .close-button::after {
        content: '';
        width: 24px;
        height: 24px;
        display: inline-block;
        background-image: url('../images/arrow-up-bold.svg');
        background-repeat: no-repeat;
        background-size: contain;
        background-position: center;
        transform: rotate(180deg);
    }

    .product-fees-popup .popup-heading .close-button svg {
        display: none;
    }

    .gallery-popup .close-button,
    .map-popup .close-button,
    .lg-toolbar .lg-close {
        background-image: url('../images/arrow-up-bold.svg');
        background-repeat: no-repeat;
        background-size: 24px 24px;
        background-position: center;
        transform: rotate(180deg);
        margin: 0;
        position: absolute;
        left: 20px;
        top: 23px;
    }

    .product-fees-popup .popup-contents {
        margin-top: 40px;
        padding: 0 0 0 20px;
        max-height: calc(100vh - 112px);
    }

    .product-fees-popup .popup-contents .popup-content-inner {
        padding-right: 20px;
        padding-bottom: 40px;
    }

    .lg-outer .lg {
        padding: 0;
        width: 100% !important;
        border-radius: 0;
        min-height: 100vh;
    }

    .product-gallery {
        margin-top: 0;
    }

    .lg-outer .lg-thumb-outer,
    .lg-outer .lg-thumb-item {
        max-height: 100px;
    }

    .lg-outer .lg-inner {
        width: 100%;
        left: 0;
        top: 72px !important;
    }

    .blog-section .news-listing .news-item {
        width: 100%;
    }

    .single .blog-section .news-listing {
        gap: 67px;
        flex-direction: column;
    }

    .map-popup {
        width: 100vw;
        height: 100vh;
        display: block;
        overflow: hidden;
    }

    .map-popup .container,
    .map-popup .map-container {
        border-radius: 0;
        padding: 0;
        height: 100vh;
    }

    .map-popup .leaflet-map {
        min-height: 451px;
    }

    .gallery-popup .close-button svg,
    .map-popup .close-button svg {
        display: none;
    }

    .map-popup .map-bottom {
        height: calc(100vh - 112px);
        overflow-y: auto;
        padding: 0 20px 40px;
    }

    .gallery-popup .popup-title,
    .map-popup .map-title {
        margin: 0 0 40px;
        padding: 24px 50px 23.83px;
        font-size: 16px;
        line-height: 23.17px;
        color: #000000;
        font-weight: 500;
        text-align: center;
        border-bottom: 1px solid #D9D9D9;
    }

    .product-video iframe {
        min-height: 208px;
    }

    .product-heading .title-tag .product-title {
        font-size: 20px;
        line-height: 28.96px;
    }

    .product-heading .tax-socials {
        font-size: 16px;
        line-height: 23.17px;
    }

    .informations .sdgs-logos .sdgs-logos-title {
        font-size: 18px;
        line-height: 26.06px;
        margin: 0 0 20px;
    }

    .product-highlights .highlights {
        margin-top: 19px;
    }

    .product-fees .fee .info .title {
        margin: 0 0 6px;
    }

    .blog-section .news-listing .post-thumbnail {
        padding-bottom: 95.185%;
    }

    .blog-section .news-listing h2.title-post {
        margin-top: 10px;
    }

    .blog-section .term-link {
        margin-top: 38px;
    }

    .related-products .related-title {
        margin: 0 0 20px;
    }

    .product-detail {
        padding-bottom: 40px;
    }

    .gallery-popup-container {
        border-radius: 0;
        padding: 0 0 40px;
        min-height: 100vh;
    }

    .gallery-popup .swiper-button-next,
    .gallery-popup .swiper-button-prev {
        position: static;
        margin: 0;
    }

    .gallery-popup .swiper-navs-dots {
        display: flex;
        align-items: center;
        gap: 20px;
        padding: 20px 0;
        justify-content: center;
    }

    .gallery-popup .swiper-pagination {
        width: auto;
        padding: 0;
    }

    .gallery-popup .gallery-slider {
        padding: 0;
        width: 100%;
    }

    .gallery-popup .gallery-slider .swiper {
        max-width: 100%;
    }

    .gallery-popup-container .gallery-item {
        padding-bottom: 69.568%;
    }

    #product-gallery-items .gallery-click .gallery-item img {
        width: 100%;
        height: 100%;
        position: absolute;
        left: 0;
        top: 0;
        object-fit: cover;
        object-position: center;
    }

    #product-gallery-items .gallery-click .gallery-item {
        width: 100%;
        height: 0;
        padding-bottom: 68.861%;
        position: relative;
    }

    .admin-bar .product-informations .addtocart-section .product-purchase-section,
    .product-informations .addtocart-section .product-purchase-section {
        position: fixed;
        left: 0;
        top: auto;
        bottom: 91px;
        width: 100%;
        height: auto;
        z-index: 9999991;
        background: #ffffff;
        border-top-left-radius: 10px;
        border-top-right-radius: 10px;
        border-top-right-radius: 10px;
        transform: translateY(100%);
        transition: all .3s;
        opacity: 0;
        pointer-events: none;
    }

    .admin-bar.card-detail-show .product-informations .addtocart-section .product-purchase-section,
    .product-informations .addtocart-section.show-detail .product-purchase-section {
        transform: translateY(0);
        opacity: 1;
        pointer-events: auto;
        z-index: 99999991;
    }

    .card-detail-show .addtocart-section .fixed-cart-section {
        z-index: 99999992;
    }

    .card-detail-show .addtocart-section:before {
        opacity: 0.4;
        pointer-events: auto;
        z-index: 9999999;
    }

    .addtocart-section:before {
        content: '';
        width: 100vw;
        height: 100vh;
        position: fixed;
        top: 0;
        left: 0;
        background: #000000;
        opacity: 0;
        pointer-events: none;
        /* transition: all .3s; */
        z-index: 999999;
    }

    .addtocart-section form {
        transition: all .3s;
    }

    .addtocart-section form.cart.select-open {
        padding-bottom: 70px;
    }

    .addtocart-section .purchase-wrapper {
        box-shadow: none;
        max-height: calc(100vh - 148px);
        overflow-y: auto;
    }

    .addtocart-section .purchase-wrapper .product-price,
    .addtocart-section .add-to-cart-wrapper {
        display: none;
    }

    .addtocart-section .product-variations,
    .addtocart-section .purchase-wrapper .product-title {
        margin: 0 0 20px;
    }

    .addtocart-section .purchase-note {
        margin-top: 20px;
        width: 100%;
        font-size: 14px;
        line-height: 20.27px;
    }

    .product-purchase-section .purchase-heading {
        padding: 16px 20px;
        border-bottom: 1px solid #D9D9D9;
    }

    .product-purchase-section .close-button {
        width: 24px;
        height: 24px;
        color: #000000;
    }

    body.single-product {
        padding-bottom: 91px;
    }
}

@media screen and (-webkit-min-device-pixel-ratio: 0) and (orientation: portrait) {
    .product-fees-popup .popup-contents {
        max-height: calc(100dvh - 112px);
    }

    .product-fees-popup .popup-container {
        max-height: 100dvh;
    }

    .addtocart-section .purchase-wrapper {
        max-height: calc(100dvh - 148px);
    }
}