@font-face {
    font-family: 'Banky';
    src: url('fonts/BankyRegular.eot');
    src: url('fonts/BankyRegular.eot?#iefix') format('embedded-opentype'),
        url('fonts/BankyRegular.woff2') format('woff2'),
        url('fonts/BankyRegular.woff') format('woff'),
        url('fonts/BankyRegular.ttf') format('truetype'),
        url('fonts/BankyRegular.svg#BankyRegular') format('svg');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Banky';
    src: url('fonts/BankyRegular_1.eot');
    src: url('fonts/BankyRegular_1.eot?#iefix') format('embedded-opentype'),
        url('fonts/BankyRegular_1.woff2') format('woff2'),
        url('fonts/BankyRegular_1.woff') format('woff'),
        url('fonts/BankyRegular_1.ttf') format('truetype'),
        url('fonts/BankyRegular_1.svg#BankyRegular') format('svg');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

/* Bootstrap Layout Overrides */
.container { position: relative; width: 100%; max-width: 75rem; /* 1200px */ }
.container > .row,
.container > div > .row { padding: 0; }
.container img { margin: 0; }

.pdp-dates-wrap .pdp-dates-arrival-date-clear, .pdp-dates-wrap .pdp-dates-departure-date-clear { display: none !important; }

/* BE - Tooltips Styles */
body .tooltip { display: block; }
body .bs-tooltip-auto[x-placement^=bottom] .arrow::before,
body .bs-tooltip-bottom .arrow::before { border-bottom-color: hsl(var(--siteColor1)); }
body .bs-tooltip-auto[x-placement^=top] .arrow::before,
body .bs-tooltip-top .arrow::before { border-top-color: hsl(var(--siteColor1)); }
body .bs-tooltip-auto[x-placement^=left] .arrow::before,
body .bs-tooltip-left .arrow::before { border-left-color: hsl(var(--siteColor1)); }
body .bs-tooltip-auto[x-placement^=right] .arrow::before,
body .bs-tooltip-right .arrow::before { border-right-color: hsl(var(--siteColor1)); }
body .tooltip-inner { background-color: hsl(var(--siteColor1)); }

/* BE - Alert Styles */
body .alert { padding: 0.75rem 2.5rem 0.75rem 1.25rem; margin-bottom: 1.5rem; }
body .alert .close { position: absolute; top: 0.6rem; right: 1rem; }
body .alert .close:hover,
body .alert .close:active,
body .alert .close:focus { box-shadow: none; outline: none; }
body .alert.alert-sm { padding: 0.5rem 1rem; font-size: 90%; line-height: 1; }
body .alert.alert-sm .close { top: 45%; transform: translateY(-50%); }
body .alert.alert-has-close { padding-right: 2.5rem; }

/* BE - Fancybox Adjustments */
body .fancybox-button { box-shadow: none; }
body .fancybox-thumbs__list a:before { border-color: hsl(var(--siteColor1)); }
body .fancybox-thumbs { background-color: hsla(var(--black), 50%); }

/* Bootstrap Card Overrides */
body .card-title > button { font-weight: inherit; }
body .accordion > .card { border-bottom: 1px solid rgba(0,0,0,0.125) !important; border-radius: 1.5625rem !important; }
body .accordion > .card + .card { margin-top: 0.625rem; }
body .accordion > .card .card-header { margin-bottom: 0; padding: 0; border-radius: 1.875rem 1.875rem 0 0; }
body .accordion > .card .card-header button { display: block; width: 100%; padding: 0.6875rem 2.5rem 0.6875rem 1.875rem; position: relative; background: #f7f7f7; border: none; border-radius: 0; outline: none; line-height: 1; text-align: left; }
body .accordion > .card .card-header button:hover,
body .accordion > .card .card-header button:active,
body .accordion > .card .card-header button:focus { color: hsl(var(--siteColor1)); text-decoration: none; background: #eee; }
body .accordion > .card .card-header button:after { content: ""; font-family: 'FontAwesome'; position: absolute; top: 1.125rem; right: 1.25rem; z-index: 2; font-size: 0.9375rem; color: #ccc; }
body .accordion > .card .card-header button[aria-expanded=true]:after { content: "\f068"; }
body .accordion > .card .card-header button[aria-expanded=false]:after { content: "\f067"; }
body .accordion > .card .card-body p:last-child { margin-bottom: 0; }

/* Content Builder Overrides - match site theme */
.content-builder-wrap { padding: 0; }
.content-builder-wrap > .row { margin: 0 -0.9375rem; }
.content-builder-wrap .column { padding: 0 0.9375rem; }
.content-builder-wrap .btn.site-color-1-bg,
.content-builder-wrap .is-btn.site-color-1-bg { color: hsl(var(--white)) !important; }
.content-builder-wrap .btn.site-color-2-bg,
.content-builder-wrap .is-btn.site-color-2-bg { color: hsl(var(--black)) !important; }
.content-builder-wrap .btn.site-color-1-bg:hover,
.content-builder-wrap .is-btn.site-color-1-bg:hover { background-color: hsl(var(--siteColor2)) !important; color: hsl(var(--black)) !important; }
.content-builder-wrap .btn.site-color-2-bg:hover,
.content-builder-wrap .is-btn.site-color-2-bg:hover { background-color: hsl(var(--siteColor1)) !important; color: hsl(var(--white)) !important; }
.content-builder-wrap .icon { color: hsl(var(--siteColor1)) !important; }
.content-builder-wrap .icon + .h2,
.content-builder-wrap .icon + .h3,
.content-builder-wrap .icon + .h4 { margin-left: 3.125rem; }
.content-builder-wrap .icon ~ p { border-bottom-color: hsl(var(--siteColor1)) !important; }
.content-builder-wrap img,
.content-builder-wrap .container img { margin: 0; border-radius: var(--borderRadiusCheckbox); }
.content-builder-wrap iframe { border-radius: var(--borderRadiusCheckbox) !important; }
.content-builder-wrap .is-card { border: none !important; border-radius: var(--borderRadiusCheckbox) !important; }
.content-builder-wrap .is-card:hover { box-shadow: var(--focusShadow) !important; }
.content-builder-wrap .is-card.is-card-circle { border-radius: 50vw !important; }

/* Swiper Overrides */
body .swiper-container { overflow: hidden; margin: auto; }
body .swiper-pagination-bullet { flex-shrink: 0; margin: 0 0.25rem; background-color: hsl(var(--lightGray)); border-radius: var(--borderRadiusCircle); }
body .swiper-pagination-bullet-active { background-color: hsl(var(--siteColor1)); }
body .swiper-pagination-bullet { opacity: 0.5; width: 0.625rem; height: 0.625rem; transition: all ease-in-out 0.4s; box-shadow: 0.0625rem 0.0625rem 0.125rem hsla(var(--black), 25%); }
body .swiper-pagination-bullet-active { opacity: 1; }

.bootstrap-select .dropdown-menu { max-height: 13rem; font-size: 0.9rem; }
.pdp-template-four .be-main button.btn.be-property-widget-info-subheading-share-send-to-a-friend-btn .icon { display: block !important; color: hsl(var(--white));}
.pdp-template-four .pdp-sidebar button.btn.pdp-sidebar-close { background: transparent !important; color: hsl(var(--siteColor1)) !important; }

.book-section-heading { background: transparent !important; }

@media (max-width: 1024px) {
  .pdp-template-four .be-main { margin-right: 0px !important; }
  button.btn.pdp-header-bar-sub-btn .icon { color: hsl(var(--white)); }
  .i-header-navigation-toggle { background: transparent; }
}

.csaas-i-trigger .csaas-channel { bottom: 60px !important; }

/* Resort PDP Page */
html { scroll-behavior: smooth; } 
section[id], div[id] { scroll-margin-top: 240px; }
#resortTabContent { width: 100% !important; margin: 0 auto; background-color: transparent !important; border: 0 !important; padding: 0 !important; border-radius: 0 !important; }
.nav-resorts { gap: 1.8rem; display: flex; }
.nav-resorts a { font-family: var(--siteFont3); text-transform: uppercase; }
.srp-content h1 { color: hsl(var(--black)) !important; font-size: 3rem; margin-bottom: 1rem; font-weight: var(--wMedium); }
.sections-resorts { margin: 2rem 0 3rem !important; }
.sections-resorts h2,
.resort-sidebar-bar h2 { font-size: 1.5rem; font-family: var(--siteFont2); font-weight: bolder; color: #1D1605; text-transform: initial; }
div#overview { margin-top: 0 !important; }
.resort-detail-nav-tabs, .resorts-info-sidebar { padding: 0 4rem 0 0.5rem !important; }
.resort-sidebar-main-content { background-color: #A0ADA5 !important; border-radius: 0 !important; padding: 1rem 2rem 2rem !important; }
.resort-sidebar-main-content li { color: #1D1605; }  
.resort-sidebar-main-content ul { padding-inline-start: 1.2rem; }
hr { border-top: 1px solid #58623F; }
hr.solid,
.be-header-bar-sub .srp-properties-available-count,
button.srp-map-collapse-btn.map-collapse { display: none; }  
  
/* Footer */
.i-footer { position: relative; padding: 0 0; font-family: var(--siteFont2); color: hsl(var(--white)); text-align: center; background: hsl(var(--siteColor8)); }
.i-footer a { color: hsl(var(--white)) !important; }
.i-footer > .container,
.resort-pdp-srp,
.resort-pdp.container { max-width: 87.5rem !important; margin: 0 auto; }
.i-footer > .container > .row > [class^=col] { min-height: 0; margin-bottom: 3.125rem; position: relative; }
.i-footer .h5 { width: 100%; max-width: 22.5rem; color: hsl(var(--white)); display: block; position: relative; margin: 0 auto 0.9375rem; padding-bottom: 1.25rem; font-size: 1.25rem; font-weight: bold; text-transform: capitalize; font-size: 1.8rem;}
.footer-logo-wrap { display: block; margin: 0; text-align: center; }
.footer-logo-img { width: 100%; height: auto; max-width: 12rem; }
.footer-site-search-form-wrap { max-width: 18.75rem; margin: 0 auto 0.9375rem; }
.footer-site-search-form-wrap .site-search-form { width: 100%; max-width: 100%; }
.footer-site-search-form-wrap .site-search-form label { color: hsl(var(--white)); }
.footer-site-search-form-wrap .site-search-term[type=search] { background: transparent; border: 0.0625rem hsl(var(--white)) solid; color: hsl(var(--black)); }
.footer-site-search-form-wrap .site-search-submit { background: hsl(var(--siteColor1)); border: 0.0625rem hsl(var(--white)) solid; border-left: none; color: hsl(var(--black)); }
.footer-site-search-form-wrap .site-search-submit:hover { background: hsl(var(--siteColor2)); border: 0.0625rem hsl(var(--white)) solid; border-left: none !important; color: hsl(var(--black)); }
.footer-quick-links { margin: 0; padding: 0; line-height: 2; }
.footer-quick-links li { list-style: none; }
.footer-quick-links a { color: hsl(var(--white)); font-size: 1rem; text-decoration: none; padding: 0.5rem 0; }
.footer-contact { line-height: 2; }
.footer-contact .footer-address { margin: 0; }
.footer-contact .footer-email,
.footer-contact .footer-phone { display: block; white-space: normal; word-wrap: break-word; padding: 0.5rem 0; }
.footer-contact .footer-email { text-decoration: underline; font-style: italic; }
.footer-contact .footer-phone { font-weight: var(--wBold); }
.footer-newsletter-form .row { margin: 0 -0.625rem; }
.footer-newsletter-form { display: block; position: relative; }
.footer-newsletter-form:focus-within label:not(.error) { top: -1rem; }
.footer-newsletter-form label:not(.error) { cursor: text; position: absolute; top: 50%; transform: translateY(-50%); left: 1rem; color: hsl(var(--black)); transition: all ease-in-out 0.2s; }
.footer-newsletter-form [class^=col] { padding: 0 0.625rem; }
.footer-newsletter-form:focus-within input { padding: 0.625rem 1rem; }
.footer-newsletter-form input { background-color: transparent; width: 100%; margin: 0 0 0.625rem; padding: 0.625rem 1rem 0.625rem 8rem; border: 0.0625rem hsl(var(--white)) solid; border-radius: var(--borderRadius); font-size: 1rem; color: hsl(var(--white)) !important; }
.footer-newsletter-form input:-webkit-autofill,
.footer-newsletter-form input:-webkit-autofill:hover,
.footer-newsletter-form input:-webkit-autofill:focus { -webkit-text-fill-color: hsl(var(--white)) !important; -webkit-box-shadow: 0 0 0 62.5rem transparent inset; }
.footer-newsletter-form label.error { top: -0.5rem; }
.footer-newsletter-form .col-submit { display: flex; justify-content: flex-end; }
.footer-newsletter-form .btn { width: 100%; max-width: 10rem; padding: 0.875rem 0.1875rem; font-size: 1rem; font-weight: var(--wBold); text-transform: uppercase; }
.footer-newsletter-form .btn:focus { outline: none !important; }
.footer-newsletter-form .fn-email-group { display: block; }
.footer-newsletter-form .recaptcha-wrap { transform: scale(0.9) translate(-0.5rem, -0.5rem); }

.i-footer .return-to-top { opacity: 1; width: 3.125rem; height: 3.125rem; padding: 0.5rem; position: absolute; bottom: 3rem; right: 2rem; z-index: 2; outline: none; border: none; border-radius: var(--borderRadiusCheckbox); color: hsl(var(--white)); }
.i-footer .return-to-top .icon { width: 1.25rem; height: 1.25rem; }
.i-footer .return-to-top:hover { box-shadow: 0 0 0 0.125rem hsla(var(--white), 0.25); }
@media (min-width: 768px) {
  .i-footer { text-align: left; }
  .i-footer > .container > .row > [class^=col] { min-height: 15.625rem; }
  .i-footer .h5 { max-width: 100%; }
    .footer-logo-wrap { text-align: left; }
}
@media (min-width: 992px) {
  .i-footer > .container > .row > [class^=col] { margin-bottom: 0; }
  .footer-quick-links a,
  .footer-contact .footer-email,
  .footer-contact .footer-phone { padding: 0;  }
}
@media (min-width: 1025px) {
	.i-footer > .container,
	.i-footer.home > .container { max-width: calc(100% - 8.125rem); margin: 0 auto; }
	.i-footer:before { content: ''; background: url(/images/layout/Baja-Stays-Top-Img-Footer.png); width: 100%; height: 100%; position: absolute; background-repeat: no-repeat; background-size: contain; }

}
@media (min-width: 1400px) {
	.resort-pdp.container,
    .resort-pdp-srp { max-width: 87.5rem; }	
    .i-footer > .container { max-width: 87.5rem; padding-top: 8%; }
}
@media (min-width: 1920px) {
	.i-footer.home > .container { max-width: 110rem; }
}

.text-center.footer-unique { display: flex; flex-direction: column; align-items: center; }
.footer-unique p { font-family: var(--siteFont1); font-size: 32px; font-weight: 400; text-transform: uppercase; color: hsl(var(--siteColor8)); margin-bottom: 0; }
.footer-unique .i-social-item { background: hsl(var(--siteColor8)); }

/* Baseline */
.i-baseline { margin: 0; padding: 0.9375rem 0; font-size: 1rem; text-align: center; font-family: var(--siteFont3); font-size: 13px; text-transform: uppercase; display: flex; width: 100%; justify-content: space-between; }
.i-baseline .baseline-policy { width: 100%; text-align: start; }
.i-baseline .baseline-links { display: flex; width: 100%; justify-content: end; gap: 50px; }
.i-baseline a,
.i-baseline a:hover { color: hsl(var(--white)) !important; }
.i-footer  hr { margin-top: 0rem; margin-bottom: 0rem; border: 0; border-top: 1px solid rgb(255 255 255); }
@media (min-width: 992px) {
	.i-baseline { margin: 0 0; }
	.i-baseline p { display: flex; flex-wrap: wrap; justify-content: space-between; }
}

.i-footer .footer-title { font-family: var(--siteFont1); font-size: 56px; font-weight: 400;  }
.i-footer .sub { font-family: var(--siteFont3); font-size: 14; font-weight: 400; margin-bottom: 30px; text-transform: uppercase; }
.i-footer .form-row { display: flex; flex-wrap: nowrap; margin-bottom: 15px; }
.i-footer .btn { border-radius: 0; }
.i-footer .footer-newsletter-form input { background-color: transparent; width: 100%; margin: 0 15px 0 0; padding: 0; border:none; border-bottom: 0.0625rem hsl(var(--white)) solid !important; border-radius: 0; font-size: 1rem; color: hsl(var(--white)) !important; }
.i-footer .footer-soc-row { display: flex; width: 100%; justify-content: end; margin-bottom: 10px; }

/* Trusted Logos */
.trusted-partners {	display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; padding: 30px 20px; }
.trusted-partners h2 { font-size: 1.5rem; margin-bottom: 20px; }
.partners-container { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: 60px; max-width: 1200px; width: 100%; }
.partner-logo { height: auto; width: auto; object-fit: contain; }

@media (max-width: 768px) {
	.partners-container { gap: 35px; }
	.partner-logo {	height: 40px; max-width: 120px;	}
}
