/* 1.1 body */
body { background-color: #ffffff; margin:0px; padding:0px; overflow-x: hidden;  }
:root { --checkbox-size: 14px; }
*:focus {
    outline: none !important;
    box-shadow: none !important;
}
/*navigation*/
.nicdark_navigation ul { margin: 0px; padding: 0px; list-style: none; text-align: center; }
.nicdark_navigation ul li { margin: 0px; padding: 0px; display: inline; }
.nicdark_navigation ul li a { color: #fff;text-decoration: none; font-size: 20px;padding: 0px 20px; }

/*post preview on archive*/
.nicdark_archive_post_preview { text-align: center; padding-bottom: 70px; }
.nicdark_archive_post_preview img {  width: 100%; height: auto; }
.nicdark_archive_post_preview a { color:#000; }

/*sticky*/
.nicdark_archive_post_preview .sticky { background-color: #8fb1a6; padding: 40px; color: #fff;  }
.nicdark_archive_post_preview .sticky a { color: #fff;  }

/*single post*/
body.single-post .nicdark_single_post .has-post-thumbnail img { width:100%; height: auto; padding-bottom: 20px; }
.nicdark_single_post_tag_cat { padding:20px 0px; }
.nicdark_single_post_tag_cat a { text-decoration: none; color: #000; }
.nicdark_single_post_tag, .nicdark_single_post_cat { margin:5px 0px; }
.nicdark_single_post_comments { padding-bottom: 120px; padding-top:10px;  }
.nicdark_single_post_comments label { float: left; width: 100%; box-sizing: border-box; margin:5px 0px; }
.nicdark_single_post_comments a { text-decoration: none; color: #000;  }
.nicdark_single_post_comments input[type="text"],.nicdark_single_post_comments textarea { float: left; width: 100%; box-sizing: border-box; padding:5px 10px; margin:5px 0px;  }
.nicdark_single_post_comments input[type="submit"] { float: left; box-sizing: border-box; padding:10px 20px; margin:5px 0px; background-color:#8fb1a6; color: #fff; border-radius: 0px; border:0px solid #fff; }

/*single page*/
.nicdark_single_page a { text-decoration: underline; color: #000; }

/*container*/
.nicdark_container{ width:1200px; margin:auto; padding: 0px; }

/*wordpress class*/
.wp-caption {  }
.wp-caption-text {  }
.screen-reader-text {  }
.gallery-caption {  }
.bypostauthor {  }
.alignright {  }
.alignleft {  }
.aligncenter {  }

/*class*/
.nicdark_section { float: left; width: 100%; box-sizing: border-box;  }

.nicdark_margin_0 { margin: 0px;  }
.nicdark_margin_top_10 { margin-top: 10px;  }
.nicdark_margin_top_15 { margin-top: 15px;  }
.nicdark_margin_top_15_important { margin-top: 15px !important;  }
.nicdark_margin_top_20 { margin-top: 20px;  }
.nicdark_margin_top_25 { margin-top: 25px;  }
.nicdark_margin_top_30 { margin-top: 30px;  }
.nicdark_margin_bottom_10 { margin-bottom: 10px; }

.nicdark_margin_left_10 { margin-left: 10px; }
.nicdark_margin_left_20_percentage { margin-left: 20%; }

.nicdark_padding_0 { padding: 0px;  }
.nicdark_padding_20 { padding: 20px;  }
.nicdark_padding_8_20 { padding: 8px 20px; }
.nicdark_padding_top_120 { padding-top: 120px;  }

.nicdark_padding_bottom_120 { padding-bottom: 120px;  }
.nicdark_padding_bottom_50 { padding-bottom: 50px;  }

.nicdark_padding_right_20 { padding-right: 20px; }

.nicdark_padding_left_2 { padding-left: 2px; }

.nicdark_background_color_8fb1a6 { background-color: #8fb1a6; }
.nicdark_background_color_E7E7E7 {  background-color: #e7e7e7; }
.nicdark_background_color_1d2327 {  background-color: #1d2327; }
.nicdark_background_color_ffffff { background-color:#fff; }
.nicdark_background_color_2c3338 { background-color:#2c3338; }
.nicdark_background_color_2271b1 { background-color:#2271b1; }
.nicdark_background_color_1bbc9b { background-color:#1bbc9b; }



.nicdark_box_shadow_0_1_1_000_4 { box-shadow: 0 1px 1px rgb(0 0 0 / 4%);  }

.nicdark_display_inline_block { display: inline-block;  }
.nicdark_display_block { display: block;  }

.nicdark_box_sizing_border_box { box-sizing: border-box;  }

.nicdark_text_align_center { text-align: center;  }

.nicdark_float_left { float: left; }


.nicdark_border_1_solid_e5e5e5 { border:1px solid #e5e5e5; }
.nicdark_border_1_solid_e5e5e5 { border:1px solid #e5e5e5; }
.nicdark_border_bottom_1_solid_cccccc { border-bottom: 1px solid #cccccc; }
.nicdark_border_bottom_3_solid_2271b1 { border-bottom:3px solid #2271b1; }
.nicdark_border_top_width_0 { border-top-width:0px;  }
.nicdark_border_left_width_0 { border-left-width:0px;   }


.nicdark_cursor_auto { cursor: auto;  }

.nicdark_color_ffffff { color: #ffffff; }
.nicdark_color_666666 { color: #666666;  }
.nicdark_color_a0a5aa { color: #a0a5aa;  }


.nicdark_width_20_percentage { width: 20%;  }
.nicdark_width_40_percentage { width: 40%;  }
.nicdark_width_50_percentage { width: 50%;  }
.nicdark_width_80_percentage { width: 80%;  }
.nicdark_width_100_percentage { width: 100%;  }

.nicdark_height_1 { height: 1px;  }
.nicdark_min_height_3000 { min-height: 3000px; }

.nicdark_text_decoration_none { text-decoration:none;  }

.nicdark_overflow_hidden { overflow: hidden; }

.nicdark_position_relative { position: relative; }
.nicdark_position_absolute { position: absolute; }

.nicdark_list_style_none { list-style: none; }

.nicdark_font_size_14px { font-size: 14px; }


/* 2 ------------------------------------------------------- ELEMENTOR ------------------------------------------------------- */

/*slides and carousel*/
.elementor-swiper-button-prev { left: 10px; }
.elementor-swiper-button { position: absolute;display: inline-flex;z-index: 1;cursor: pointer;font-size: 25px;color: hsla(0,0%,93.3%,.9);top: 50%;transform: translateY(-50%);}
.elementor-swiper-button-next {right: 10px;}
.swiper-container {margin-left: auto;margin-right: auto;position: relative;overflow: hidden;z-index: 1;}

/* 2 ------------------------------------------------------- CUSTOM ------------------------------------------------------- */
.cover, .cover .elementor-element-populated{
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
}

.overflow-hidden{
    overflow: hidden !important;
}

.a-flow .swiper{
    overflow: visible;
}

.main-footer ul li a{
    padding-left: 0 !important;
    text-align: left;
}
.e-n-accordion-item-title{
    align-items: flex-start !important;
    line-height: 1.2 !important;
}

.e-n-accordion-item-title-text span{
    color: #FFE01C;
}  

.elementor-menu-toggle{
    margin-left: auto !important;
}

@media only screen and (min-width: 1199px) {
    .button{
        font-weight: bold !important;
        padding: 10px 20px !important;
    }

    .button:last-child{
        margin-left: 20px !important;
    }

    .bg-black{
        background-color: #000000;
        color: #ffffff !important;
    }

    .bg-yellow{
        background-color: #FFE01C;
        color: #000000 !important;
    }
}

label.filter-label{
    font-weight: bold;
    color: #000000 !important;
    display: block;
    font-size: 20px;
}

.filter-wrapper select{
    border: none !important;
    width: 100%;
    background-color: #EFEFEF;
}

.filter-wrapper:not(:last-child){
    padding-bottom: 40px;
    margin-bottom: 40px;
    border-bottom: 1px solid #D8D8D8;
}

.filter-levels, .filter-languages, .filter-subjects{ 
    display: grid;
    /* grid-template-columns: repeat(2, 1fr); */
    gap: 10px;
}

.filter-levels label, .filter-languages label, .filter-subjects label{
    display: flex;
    align-items: flex-start; 
    line-height: 1.2;
}
.filter-levels label input[type="checkbox"], .nd_elements_cf7_component input[type="checkbox"], .filter-languages label input[type="checkbox"], .filter-subjects label input[type="checkbox"]{
    margin-right: 10px;
    inline-size: var(--checkbox-size);
    block-size: var(--checkbox-size);
    aspect-ratio: 1 / 1; /* guards against odd UA ratios */
    /* keep native appearance, colors, focus ring, etc. */
    appearance: auto;
    -webkit-appearance: auto;
    line-height: 1.3;
}

nav.elementor-pagination{
    margin-top: 70px;
    text-align: right !important;
}

nav.elementor-pagination span.current{
    color: #FFE01C !important;
}

nav.elementor-pagination > a{
    color: #000000 !important
}

.destination-layout{
    position: relative;
    width: 100% !important;
    padding-bottom: 133.333% !important
}
.destination-layout.single .elementor-container{
    position: absolute;
    width: 100%;
    top: 50% !important;
    transform: translateY(-50%);
    bottom: unset !important;
}

.destination-layout .elementor-container{
    position: absolute;
    width: 100%;
    height: 100%;  /* New */
    /* bottom: 30px; */
}

.people-layout{
    position: relative;
    width: 100% !important;
    padding-bottom: 136% !important
}

.people-layout .elementor-container{
    position: absolute;
    width: 100%;
    bottom: 30px;
}



/* @media only screen and (max-width: 1199px) {
    .main-footer ul li a{
        display: block;
        text-align: center !important;
    }
    
} */
 .elementor-widget .elementor-icon-list-item, .elementor-widget .elementor-icon-list-item a{
    align-items: start !important;
 }

.elementor-widget .elementor-icon-list-item:not(:last-child){
    margin-bottom: 10px !important;
}

.elementor-icon-list-icon{
    top: 5px !important;
}

.atlas-contact-form, .atlas-contact-form div{
    width: 100%;
}

.atlas-contact-form .form-wrap:not(:last-child){
    margin-bottom: 40px !important;
}

.atlas-contact-form p{
    margin: 0 !important;
}

.atlas-contact-form select{
    height: 40px;
}

.atlas-contact-form label{
   font-weight: normal !important;
   font-size: 16px !important;
   color: #000000 !important;
   display: block !important;
   margin-bottom: 16px !important;
}
@media screen and (min-width: 992px) {
    .form-flex input[type="text"], input[type="email"], input[type="tel"]{
        margin-bottom: 0 !important;
    }

    .form-flex .wpcf7-not-valid-tip{
        margin-top: 20px;
    }

    .form-flex div p{
        margin-top: 20px !important;
    }
}

.atlas-contact-form input[type=text], .atlas-contact-form input[type=email], .atlas-contact-form input[type=tel], .atlas-contact-form select, .atlas-contact-form textarea{
    width: 100% !important;
    border-radius: 5px !important;
    margin-bottom: 0 !important; 
    font-family: 'Roboto', sans-serif !important;
}

.atlas-contact-form textarea::placeholder{
    font-family: 'Roboto', sans-serif !important
}


.wpcf7-submit{
    border: none !important;
    transition: .2s ease !important;
    cursor: pointer !important;
    margin-bottom: 0 !important;
}

.wpcf7-submit:hover{
  transform: scale(.9);
  background-color: #FFE01C !important;
  color: #000000 !important;
}

.atlas-contact-form p{
    margin-top: 20px !important;
}

.atlas-contact-form input[type=submit]{
    border: none !important;
    transition: .2s ease !important;
}

.atlas-contact-form input[type=submit]:hover{
    transform: scale(.9);
}

.form-flex{
    display: flex;  
    justify-content: space-between
}

.form-flex div{
    width: calc(50% - 14px);
}

@media only screen and (max-width: 991px) {
    .form-flex{
        flex-direction: column;
    }

    .form-flex div{
        width: 100%;
    }

    .form-flex div:not(:last-child){
        margin-bottom: 40px;
    }

    .effect-col .effect-btn{
        height: auto !important;
        opacity: 1 !important;
    }
    .effect-col{
        bottom: 50% !important;
        transform: translateY(50%);
    }
}

#filter-continent, #filter-country{
    appearance: none; /* Remove native styling */
    -webkit-appearance: none;
    -moz-appearance: none;

    background-color: #EFEFEF;
    color: #6E6E6E;
    border: none;
    border-radius: 0;
    padding: 10px 20px;
    font-size: 16px;
    line-height: 1.2;

    background-image: url("data:image/svg+xml;charset=US-ASCII,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 4 5'%3E%3Cpath fill='%23999' d='M2 0L0 2h4zm0 5L0 3h4z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
    background-size: 12px;

    cursor: pointer;
    width: 100%;
}   

.atlas-contact-form select{
    appearance: none; /* Remove native styling */
    -webkit-appearance: none;
    -moz-appearance: none;

    background-image: url("data:image/svg+xml;charset=US-ASCII,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 4 5'%3E%3Cpath fill='%23999' d='M2 0L0 2h4zm0 5L0 3h4z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
    background-size: 12px;

    background-color: #ffffff;
    padding: 15px 30px 15px 30px;

    border: 1px solid #F1F1F1 !important;

    font-size: 16px;
    height: 50px;

    cursor: pointer;
    width: 100%;
}
@media screen and (min-width: 1200px) {
    .btn-scale{
        transition: .2s ease !important;
    }
    .btn-scale:hover{
        transform: scale(.9);
    }
}



.w-90{
    width: 90% !important;
}

@media screen and (max-width: 1199px) {
    nav.elementor-nav-menu--dropdown ul{
        padding-top: 40px;
        padding-bottom: 40px;
    } 
}

p a{
    color: #FFE01C;
}

p a:hover{
    text-decoration: underline;
}

/* Ensure parent has a relative position */
.elementor-section {
  position: relative;
  overflow: visible;
}

/* Sticky behavior */
.sticky-inside {
  position: sticky;
  top: 100px; /* Adjust for fixed header if needed */
  align-self: flex-start;
}

.d-flex .elementor-widget-wrap{
    display: flex;
}

.flex-column .elementor-widget-wrap{
    flex-direction: column
}

.h-100 .elementor-widget-container, .h-100 .elementor-widget-container .elementor-grid, .h-100 .elementor-widget-container .elementor-grid .e-loop-item{
    height: 100%;
}

.h-100, .h-100 .elementor-container{
    height: 100%
}

.mt-auto{
    margin-top: auto !important;
}

.destination-layout:hover .effect-col{
    bottom: 50%;
    transform: translateY(50%);
}

.effect-col{
    position: absolute;
    bottom: 0;
    transition: .3s ease-in-out;
}

.effect-col .effect-btn{
    transition: .3s ease-in-out;
    opacity: 0;
    height: 0;
}

.destination-layout:hover .effect-col .effect-btn{
    height: auto;
    opacity: 1;
}

@media only screen and (max-width: 756px) {
    .footer-menu ul{
        display: flex !important;
        flex-direction: column !important;

    }
}

@media only screen and (max-width: 1200px) {
    .order-change > .elementor-container{
        display: flex;
        flex-direction: column;
    }

    .order-change > .elementor-container .elementor-top-column:nth-child(1){
        order: 1 !important;
    }   

    .order-change > .elementor-container .elementor-top-column:nth-child(2){
        order: 0 !important;
    } 
}

@media only screen and (max-width: 1200px) {
    .map-img img{
        display: block;
        margin-left: auto !important;
        margin-right: auto !important;
        max-width: 250px;
    }
}

@media only screen and (min-width: 1201px) {
    .map-img img{
        display: block;
        margin-left: auto !important;
        margin-right: unset !important;
        max-width: 250px;
    }
}


/* MOBILE: make gallery swipe horizontally like a slider AND lock spacing */
@media (max-width: 991px) {
  .slider-mob {
    /* Lock Elementor's gap variables too, in case they're referenced elsewhere */
    --grid-column-gap: 12px !important;
    --grid-row-gap: 0px !important;
    --gallery-image-spacing: 12px !important; /* some skins use this alias */
  }

  .slider-mob .elementor-gallery-item__overlay{
    display: none !important;
    visibility: hidden !important;
  }

  .slider-mob .elementor-gallery__container {
    display: flex !important;
    flex-wrap: nowrap !important;

    /* Lock the gap explicitly (not via CSS vars) */
    gap: 12px !important;
    column-gap: 12px !important;
    row-gap: 0 !important;

    /* Scroller behavior */
    overflow-x: auto !important;
    scroll-snap-type: x mandatory !important; /* was 'mandatory' */
    -webkit-overflow-scrolling: touch !important;
    padding: 8px 12px !important;

    /* Neutralize JS layout injections */
    position: static !important;
    height: auto !important;
    transform: none !important;

    /* Reduce layout shift when scrollbar appears */
    scrollbar-gutter: stable both-edges !important;
  }

  .slider-mob .elementor-gallery-item {
    flex: 0 0 85% !important;         /* each “slide” width */
    scroll-snap-align: start !important;

    /* Kill inline margins/gaps Elementor may push on resize */
    margin: 0 !important;
    position: static !important;
    top: auto !important;
    left: auto !important;
    transform: none !important;
    width: auto !important;
    height: auto !important;
  }

    /* optional: hide scrollbar on mobile */
    .slider-mob .elementor-gallery__container::-webkit-scrollbar { display: none !important; }
    .slider-mob .elementor-gallery__container { scrollbar-width: none !important; }

    /* ensure captions don't break layout */
    .slider-mob .elementor-gallery-item__content,
    .slider-mob .elementor-gallery-item__title {
        white-space: normal !important;
    }

    .slider-mob .elementor-gallery__container { cursor: grab; }
      .slider-mob .elementor-gallery__container.is-dragging{
        scroll-snap-type: none !important;
        scroll-behavior: auto !important; /* just in case */
        cursor: grabbing;
        user-select: none; 
        -webkit-user-select: none;
  }
}



/* Mobile accordion */
@media (max-width: 991px){
    .filter-wrapper:not(:last-child){
        padding-bottom: 20px;
        margin-bottom: 20px;
    }
  .filter-label.acc{
    display:flex !important;
    width: 100%;
    align-items:center;
    justify-content:space-between;
    cursor:pointer;
    user-select:none;
  }
  /* Arrow */
  .filter-label.acc::after{
    content:"▸";
    font-size: .9em;
    line-height: 1;
  }
  .filter-wrapper.is-open > .filter-label.acc::after{
    content:"▾";
  }

  /* Collapsible panel */
  .acc-content{
    max-height: 0;
    overflow: hidden;
    transition: max-height .25s ease;
    /* optional: improve perf */
    content-visibility: auto;
  }
  /* When open */
  .filter-wrapper.is-open > .acc-content{
    /* big enough to reveal all options; adjust if needed */
    max-height: 40rem;
  }

  /* Tidy spacing inside the panel */
  .acc-content > label{
    display: flex;
    align-items: flex-start;
  }
}

.flex-grow{
    flex-grow: 1;
}

.flex-shrink{
    flex-shrink: 1;
}

p{
    margin: 0 !important;
}

.nd_elements_cf7_component label{
    background-color: transparent !important;
    font-weight: bold !important;
}

.nd_elements_cf7_component input[type="checkbox"]{
    width: auto;
    margin: 2px 0 0 0 !important;

}

.wpcf7-list-item{
    margin-left: 0;
    display: block;
}

.wpcf7-list-item > label{
    display: inline-flex !important;
    align-items: start !important;;     /* vertical center the box with the text */
    gap: .5rem !important;;              /* space between box and text */
    line-height: 1.3 !important;;    
}

.wpcf7-list-item-label{
    font-weight: normal !important;
    padding-left: 10px;
}

.form-wrap:not(.form-flex) .wpcf7-not-valid-tip{
        margin-bottom: 20px !important;
        margin-top: 20px !important;
    }

.wpcf7-not-valid-tip{
    float: none !important;
}

.dynamic-popup{
    cursor: pointer;
}

.wpcf7-spinner{
    display: none !important;
}

.team-email a{
    color: #000000;
    transition: .3s ease-in-out;
}

.team-email a:hover{
    color: #FFE01C;
    text-decoration: underline;
}

.team-text p:not(:last-child){
    margin-bottom: 20px !important;
}

.elementor-kit-7714 e-page-transition{
    display: none !important;
}