/* Poppins Font Family */
@font-face {
    font-family: 'Poppins';
    src: url('../fonts/Poppins-Thin.ttf') format('truetype');
    font-weight: 100;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Poppins';
    src: url('../fonts/Poppins-ThinItalic.ttf') format('truetype');
    font-weight: 100;
    font-style: italic;
    font-display: swap;
}
@font-face {
    font-family: 'Poppins';
    src: url('../fonts/Poppins-ExtraLight.ttf') format('truetype');
    font-weight: 200;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Poppins';
    src: url('../fonts/Poppins-ExtraLightItalic.ttf') format('truetype');
    font-weight: 200;
    font-style: italic;
    font-display: swap;
}
@font-face {
    font-family: 'Poppins';
    src: url('../fonts/Poppins-Light.ttf') format('truetype');
    font-weight: 300;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Poppins';
    src: url('../fonts/Poppins-LightItalic.ttf') format('truetype');
    font-weight: 300;
    font-style: italic;
    font-display: swap;
}
@font-face {
    font-family: 'Poppins';
    src: url('../fonts/Poppins-Regular.ttf') format('truetype');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Poppins';
    src: url('../fonts/Poppins-Italic.ttf') format('truetype');
    font-weight: 400;
    font-style: italic;
    font-display: swap;
}
@font-face {
    font-family: 'Poppins';
    src: url('../fonts/Poppins-Medium.ttf') format('truetype');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Poppins';
    src: url('../fonts/Poppins-MediumItalic.ttf') format('truetype');
    font-weight: 500;
    font-style: italic;
    font-display: swap;
}
@font-face {
    font-family: 'Poppins';
    src: url('../fonts/Poppins-SemiBold.ttf') format('truetype');
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Poppins';
    src: url('../fonts/Poppins-SemiBoldItalic.ttf') format('truetype');
    font-weight: 600;
    font-style: italic;
    font-display: swap;
}
@font-face {
    font-family: 'Poppins';
    src: url('../fonts/Poppins-Bold.ttf') format('truetype');
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Poppins';
    src: url('../fonts/Poppins-BoldItalic.ttf') format('truetype');
    font-weight: 700;
    font-style: italic;
    font-display: swap;
}
@font-face {
    font-family: 'Poppins';
    src: url('../fonts/Poppins-ExtraBold.ttf') format('truetype');
    font-weight: 800;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Poppins';
    src: url('../fonts/Poppins-ExtraBoldItalic.ttf') format('truetype');
    font-weight: 800;
    font-style: italic;
    font-display: swap;
}
@font-face {
    font-family: 'Poppins';
    src: url('../fonts/Poppins-Black.ttf') format('truetype');
    font-weight: 900;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Poppins';
    src: url('../fonts/Poppins-BlackItalic.ttf') format('truetype');
    font-weight: 900;
    font-style: italic;
    font-display: swap;
}
body{
    font-family: 'Poppins', Arial, sans-serif;
}
.footer-location-item.txt-white.txt-deim-bold, .footer-location-item.txt-white.txt-deim-bold, .menu-search-b::placeholder{
    font-family: 'Poppins', Arial, sans-serif;
}
.contact-test-b .w-slider-dot.w-active {
    height: 0.5em;
    width: 0.5em;
    color: #173d48;
    border: 1px solid #173d48;
    background: #ffffff00;
}

.contact-test-b .w-slider-dot {
    height: 0.5em;
    width: 0.5em;
    color: #ffffffff;
    background: #173d48;
}
img{
    height: auto;
}
/* Fix region page white spacing */
.region-image-row {
    display: flex;
    align-items: stretch;
}
.region-image-col.l {
    display: flex;
    flex-direction: column;
    margin-bottom: 0;
}
.region-image-col.l .image-b {
    flex: 1;
    display: flex;
    flex-direction: column;
}
.region-image-col.l .image-b .region-image-big {
    flex: 1;
    display: flex;
}
.region-image-col.l .image-b .region-image-big img {
    object-fit: cover;
    height: 100%;
    width: 100%;
}
.region-image-col.r {
    align-items: stretch;
    align-content: stretch;
}
.region-image-col.r .image-b.small {
    flex: 1 1 50%;
    display: flex;
    min-height: 0;
}
.region-image-col.r .image-b.small .region-image-small {
    flex: 1;
    display: flex;
}
.region-image-col.r .image-b.small .region-image-small img {
    object-fit: cover;
    height: 100%;
    width: 100%;
}
.places-photo-col .traveller-linkb{
    height: 100%;
}
/* Override Webflow IX2 animation initial state for non-transparent header pages */
.navbar.has-bg .contact-us-link.popup-link {
    border-color: #12313a !important;
    color: #12313a !important;
}
.navbar.has-bg .contact-us-link.popup-link:hover {
    background-color: #173d48 !important;
    border-color: #173d48 !important;
    color: #f5f5f5 !important;
}
.green-bg{
    z-index: 2;
}
.pop-slider-container, .places-image-content, .image-content-b{
    z-index: 3;
}

.blog-explore-img-b img{
    height: 100%;
    width: 100%;
    object-fit: cover;
}

.client-logo-slider-2 {
    animation: moveSlideshow 150s linear infinite;
}
.moblie-menu-02{
    height: auto;
    max-height: 500px;
    padding-left: 40px;
    padding-right: 40px;
    overflow: auto;
}
.moblie-menu-02._01 {
    display: block;
}
/* Country submenu positioning - stack them in the same spot */
.pc-site-list {
    position: relative;
}
.moblie-menu-02[data-index] {
    position: absolute;
    top: 40px;
    left: 66.66%;
    width: 33.33%;
    display: block;
}

@keyframes moveSlideshow {
100% {
    transform: translateX(-50.8%);
}
}
/* .contact-booking-col.l{
    height: auto;
} */
/* Form validation errors */
.form-error {
    color: #dc3545;
    font-size: 12px;
    margin-top: 4px;
    margin-bottom: 8px;
}
.contact-txt-field.error,
.big-txt-area.error,
.w-input.error {
    border-color: #dc3545 !important;
}
.w-form-done {
    background-color: #d4edda;
    color: #155724;
    padding: 15px;
    border-radius: 4px;
    margin-top: 10px;
}
.w-form-fail {
    background-color: #f8d7da;
    color: #721c24;
    padding: 15px;
    border-radius: 4px;
    margin-top: 10px;
}

/* Legal pages (Privacy Policy, Terms & Conditions) */
.legal-page-content {
    padding: 40px 0 60px;
}
.legal-page-header {
    margin-bottom: 40px;
}
.legal-page-header h1 {
    font-size: 2.5rem;
    font-weight: 300;
    color: #173d48;
    margin: 0;
}
.legal-page-body {
    font-size: 1rem;
    line-height: 1.8;
    color: #333;
}
.legal-page-body h2,
.legal-page-body h3,
.legal-page-body h4 {
    margin-top: 30px;
    margin-bottom: 15px;
    color: #173d48;
}
.legal-page-body p {
    margin-bottom: 15px;
}
.legal-page-body ul,
.legal-page-body ol {
    margin-bottom: 15px;
    padding-left: 20px;
}

/* Payment pages */
.payment-page-section {
    padding: 60px 0;
}
.payment-container {
    background: white;
    max-width: 800px;
    margin: 0 auto;
}
.payment-header {
    text-align: center;
    padding: 30px 0;
}
.payment-header h1 {
    font-size: 2.5rem;
    font-weight: 300;
    color: #333;
    margin: 0;
}
.billing-info {
    margin: 40px 0;
}
.billing-header {
    background-color: #c8c8c8;
    padding: 15px 30px;
}
.billing-header h3 {
    margin: 0;
    font-size: 1.1rem;
    font-weight: 500;
    color: #333;
}
.billing-details {
    border: 1px solid #ddd;
    border-top: none;
    padding: 30px;
    background: white;
}
.billing-row {
    display: flex;
    margin-bottom: 15px;
    align-items: center;
}
.billing-row:last-child {
    margin-bottom: 0;
}
.billing-row .label {
    width: 200px;
    color: #333;
    font-weight: 400;
}
.billing-row .colon {
    width: 20px;
    color: #333;
}
.billing-row .value {
    flex: 1;
    color: #333;
    text-align: right;
}
.payment-method-section {
    margin: 40px 0;
}
.payment-method-section h2 {
    font-size: 1.5rem;
    font-weight: 400;
    color: #333;
    margin-bottom: 30px;
}
.payment-methods {
    margin-bottom: 40px;
}
.payment-method-item {
    display: flex;
    align-items: center;
    margin-bottom: 20px;
    padding: 15px;
    border: 1px solid #ddd;
    border-radius: 4px;
    cursor: pointer;
    transition: background-color 0.2s;
}
.payment-method-item:hover {
    background-color: #f8f9fa;
}
.payment-method-item input[type="radio"] {
    margin-right: 15px;
    transform: scale(1.2);
}
.payment-method-label {
    display: flex;
    align-items: center;
    cursor: pointer;
    flex: 1;
}
.payment-logo {
    max-height: 40px;
    object-fit: contain;
}
.continue-payment {
    text-align: center;
    margin-top: 40px;
}
.continue-btn {
    display: inline-block;
    background-color: #173d48;
    color: white;
    border: none;
    padding: 15px 60px;
    font-size: 1.1rem;
    font-weight: 500;
    cursor: pointer;
    transition: background-color 0.2s;
    text-decoration: none;
}
.continue-btn:hover {
    background-color: #0f2a32;
    color: white;
}

/* Payment Success */
.payment-success-container {
    text-align: center;
    padding: 60px 0;
}
.success-icon {
    margin-bottom: 30px;
}
.success-icon svg {
    width: 80px;
    height: 80px;
    color: #28a745;
}
.payment-success-container h2 {
    color: #28a745;
    font-size: 2rem;
    margin-bottom: 15px;
}
.payment-success-container .lead {
    font-size: 1.1rem;
    color: #666;
    margin-bottom: 40px;
}
.payment-details-card {
    background: #f8f9fa;
    border-radius: 8px;
    padding: 30px;
    max-width: 500px;
    margin: 0 auto 30px;
    text-align: left;
}
.payment-details-card h5 {
    margin-bottom: 20px;
    padding-bottom: 10px;
    border-bottom: 1px solid #ddd;
    color: #333;
}
.payment-details-card table {
    width: 100%;
}
.payment-details-card td {
    padding: 8px 0;
}
.payment-details-card td:last-child {
    text-align: right;
}
.payment-email-note {
    color: #666;
    font-size: 0.95rem;
}
.text-truncate {
    display: -webkit-box;
    -webkit-line-clamp: var(--line-clamp, 2);
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.slick-track{
    display: flex;
}
.slick-initialized .slick-slide{
    height: auto;
}
.insp-linkb{
    height: 100%;
    padding-bottom: 60px;
}
.home-inspiration-tag{
    position: absolute;
    bottom: 0;
    left: 0;
}
.country-do-row{
    padding-top: 0;
    justify-content: center;
}
.relative:has(.slick-hidden){
    padding-bottom: 0;
}
.test-linkb{
    cursor: grab;
}
.pc-site-list a:hover .txt-white{
    color: #c9a961;
}
.home-test-content-p{
    padding-right: 5px;
}
.home-test-content-p::-webkit-scrollbar{width:10px;}
.home-test-content-p::-webkit-scrollbar-track{background:#d6d6d6;border-radius:50px;}
.home-test-content-p::-webkit-scrollbar-thumb{background:#505050;border-radius:50px;border:2px solid #d6d6d6;}
.contact-us-btn.out{
    display: flex;
}
.question-block{
    white-space: normal;
}
.wrap-row{
    flex-wrap: wrap;
}
.wrap-row .insp-slider-col{
   margin-bottom: 30px;;
}
.page-b{
    margin-bottom: 0;
}
@media (max-width: 767px) {
    .billing-details {
        padding: 20px;
    }
    .billing-row {
        flex-direction: column;
        align-items: flex-start;
    }
    .billing-row .label {
        width: 100%;
        margin-bottom: 5px;
    }
    .billing-row .colon {
        display: none;
    }
    .billing-row .value {
        text-align: left;
    }
    .payment-header h1 {
        font-size: 2rem;
    }

    .contact-us-btn.out {
        width: 110px;
    }
    .insp-slide-row.wrap-row{
        margin-left: -5px;
        margin-right: -5px;
    }
    .wrap-row .insp-slider-col{
        width: 50%;
        padding-left: 5px;
        padding-right: 5px;
    }
}

@media (max-width: 479px) {
    .region-image-col.r .image-b.small{
        flex: 1 1 100%;
    }
    .contact-us-btn.out {
        width: 95px;
    }
    .wrap-row .insp-slider-col{
        width: 100%;
    }
    
}