/* Content Blocks page: rotating head gallery */
#content-head.content-head--gallery {
	position: relative;
	overflow: hidden;
	background-image: none !important;
	height: 575px;
}

#content-head .content-head__bg-slides {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: 0;
}

#content-head .content-head__bg-slide {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	margin: 0;
	padding: 0;
	opacity: 0;
	transition: opacity 1.2s ease-in-out;
}

#content-head .content-head__bg-slide .content-head__bg-img {
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}

#content-head .content-head__bg-slide.is-active {
	opacity: 1;
	z-index: 1;
}

#content-head .content-head__inner {
	position: relative;
	z-index: 2;
}

/* Itinerary landing / detail: taller hero when using the rotating gallery */
.page-template-itinerary-landing-page #content-head.content-head--gallery,
.page-template-itinerary-detail-page #content-head.content-head--gallery {
	padding-top: 200px;
	padding-bottom: 240px;
}

@media (max-width: 767px) {
	.page-template-itinerary-landing-page #content-head.content-head--gallery,
	.page-template-itinerary-detail-page #content-head.content-head--gallery {
		padding-top: 100px;
		padding-bottom: 150px;
	}
}

/* -------------------------------------------------------------------------
   Expandable Content (Stops)
   ------------------------------------------------------------------------- */

.content-block-expandable-stops {
	padding: 40px 0;
}

.expandable-stops__intro {
	margin-bottom: 28px;
	max-width: 80rem;
	margin-left: auto;
	margin-right: auto;
}

.expandable-stops__intro-headline {
	margin-top: 0;
	margin-bottom: 12px;
}

.expandable-stops__intro-text {
	font-size: 16px;
	line-height: 1.55;
}

.expandable-stops__tab {
	display: inline-block;
	margin: 0;
	padding: 10px 18px;
	background-color: #286a95;
	color: #fff;
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0.02em;
	text-transform: uppercase;
}

.expandable-stops__list {
	display: flex;
	flex-direction: column;
	gap: 5px;
	border: 1px solid #c8c8c8;
	border-top: 4px solid #286a95;
	background: #fff;
}

.expandable-stops__item:last-child .expandable-stops__trigger {
	border-bottom: 0;
}

.expandable-stops__heading {
	margin: 0;
	font-size: 16px;
	font-weight: 600;
	line-height: 1.35;
}

.expandable-stops__trigger {
	width: 100%;
	margin: 0;
	padding: 14px 16px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	text-align: left;
	background: #fff;
	border: 0;
	border-bottom: 1px solid #c8c8c8;
	color: #222;
	cursor: pointer;
}

.expandable-stops__trigger:hover,
.expandable-stops__trigger:focus {
	background: #f7f7f7;
	outline: none;
}

.expandable-stops__trigger:focus {
	box-shadow: inset 0 0 0 2px #286a95;
}

.expandable-stops__trigger-main {
	display: flex;
	align-items: center;
	gap: 10px;
	flex: 1;
	min-width: 0;
}

.expandable-stops__trigger-title {
	flex: 1;
	min-width: 0;
}

.expandable-stops__chevron {
	flex-shrink: 0;
	width: 0;
	height: 0;
	border-left: 5px solid transparent;
	border-right: 5px solid transparent;
	border-top: 7px solid #333;
	transition: transform 0.2s ease;
}

.expandable-stops__item.is-open .expandable-stops__chevron {
	transform: rotate(180deg);
}

.expandable-stops__gallery-icon {
	flex-shrink: 0;
	color: #555;
	font-size: 18px;
}

.expandable-stops__panel[hidden] {
	display: none !important;
}

.expandable-stops__panel-surface {
	position: relative;
	padding: 28px 20px 32px;
	background-color: #ececec;
	border-bottom: 1px solid #c8c8c8;
}

.expandable-stops__close {
	position: absolute;
	top: 6px;
	right: 6px;
	margin: 0;
	padding: 4px 10px;
	border: 0;
	background: transparent;
	font-size: 28px;
	line-height: 1;
	color: #333;
	cursor: pointer;
}

.expandable-stops__close:hover,
.expandable-stops__close:focus {
	color: #000;
	outline: none;
}

.expandable-stops__close:focus {
	box-shadow: 0 0 0 2px #286a95;
}

/* Mobile stack: Bootstrap .visible-xs-block / desktop: .hidden-xs */
.expandable-stops__panel-mobile > .expandable-stops__seg + .expandable-stops__seg {
	margin-top: 16px;
}

.expandable-stops__panel-desktop .expandable-stops__panel-main > * + * {
	margin-top: 16px;
}

.expandable-stops__panel-desktop .expandable-stops__panel-main > .expandable-stops__seg--subhead + * {
	margin-top: 12px;
}

.expandable-stops__panel-desktop .expandable-stops__panel-aside > * + * {
	margin-top: 16px;
}

.expandable-stops__meta-cell {
	word-wrap: break-word;
	overflow-wrap: break-word;
}

.expandable-stops__subhead {
	margin: 0 0 8px;
	font-size: 17px;
	font-weight: 700;
}

.expandable-stops__wysiwyg {
	font-size: 15px;
	line-height: 1.55;
}

.expandable-stops__wysiwyg p:last-child {
	margin-bottom: 0;
}

.expandable-stops__offer-box {
	padding: 14px 16px;
	background: #fff;
	border: 1px solid #c8c8c8;
}

.expandable-stops__offer-headline {
	margin: 0 0 8px;
	font-size: 16px;
	font-weight: 700;
}

.expandable-stops__offer-text {
	font-size: 14px;
	font-style: italic;
	line-height: 1.5;
}

.expandable-stops__figure {
	margin: 0;
}

.expandable-stops__image {
	width: 100%;
	height: auto;
	display: block;
}

/* Expandable stops: custom gallery (no Bootstrap carousel) */
.expandable-stops-gallery {
	position: relative;
	max-width: 100%;
	margin: 0;
	outline: none;
}

.expandable-stops-gallery:focus-visible {
	box-shadow: 0 0 0 2px #286a95;
}

.expandable-stops-gallery__viewport {
	position: relative;
	width: 100%;
	/* Fixed aspect = consistent height at any viewport width; matches medium-3-2 (3:2) */
	aspect-ratio: 3 / 2;
	overflow: hidden;
	background-color: #e2e2e2;
}

.expandable-stops-gallery__slide {
	position: absolute;
	inset: 0;
	margin: 0;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	z-index: 0;
	transition: opacity 0.35s ease, visibility 0.35s ease;
}

.expandable-stops-gallery__slide.is-active {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
	z-index: 1;
}

.expandable-stops-gallery__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	display: block;
}

.expandable-stops-gallery__nav {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 2;
	width: 12%;
	min-width: 40px;
	max-width: 52px;
	padding: 0;
	border: 0;
	background: rgba(0, 0, 0, 0.35);
	color: #fff;
	line-height: 1;
	cursor: pointer;
}

.expandable-stops-gallery__nav:hover,
.expandable-stops-gallery__nav:focus {
	background: rgba(0, 0, 0, 0.55);
	color: #fff;
	outline: none;
}

.expandable-stops-gallery__nav:focus-visible {
	box-shadow: inset 0 0 0 2px #fff;
}

.expandable-stops-gallery__nav--prev {
	left: 0;
	border-radius: 0 4px 4px 0;
}

.expandable-stops-gallery__nav--next {
	right: 0;
	border-radius: 4px 0 0 4px;
}

.expandable-stops-gallery__nav .glyphicon {
	font-size: 18px;
	line-height: 44px;
	display: block;
	text-align: center;
}

.expandable-stops-gallery__dots {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 10px;
	z-index: 2;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 6px;
	margin: 0;
	padding: 0 8px;
	list-style: none;
}

.expandable-stops-gallery__dots li {
	margin: 0;
	padding: 0;
	list-style: none;
}

.expandable-stops-gallery__dot {
	width: 10px;
	height: 10px;
	padding: 0;
	border: 1px solid rgba(255, 255, 255, 0.9);
	border-radius: 50%;
	background: rgba(0, 0, 0, 0.35);
	cursor: pointer;
}

.expandable-stops-gallery__dot:hover,
.expandable-stops-gallery__dot:focus {
	background: rgba(255, 255, 255, 0.45);
	outline: none;
}

.expandable-stops-gallery__dot.is-active {
	background: #fcd16a;
	border-color: #333;
}

.expandable-stops-gallery__dot:focus-visible {
	box-shadow: 0 0 0 2px #286a95;
}

.expandable-stops__cta-wrap {
	margin: 16px 0 0;
	text-align: center;
}

.expandable-stops__cta {
	display: inline-block;
	padding: 10px 24px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	background-color: #111;
	color: #fff !important;
	border-color: #111;
}

.expandable-stops__cta:hover,
.expandable-stops__cta:focus {
	background-color: #000;
	color: #fff !important;
	border-color: #000;
}

.expandable-stops__footer-links {
	list-style: none;
	margin: 0;
	padding: 0;
}

.expandable-stops__footer-links li {
	margin-bottom: 8px;
}

.expandable-stops__footer-links a {
	text-decoration: underline;
}

@media (prefers-reduced-motion: reduce) {
	.expandable-stops__chevron {
		transition: none;
	}

	.expandable-stops-gallery__slide {
		transition: none;
	}
}

/* Itinerary detail page — intro + map block */
.itinerary-detail-intro-wrap {
	margin-bottom: 32px;
	padding: 36px;
	background-color: #fff;
	box-shadow: 0 4px 24px rgba(0, 0, 0, 0.08), 0 1px 3px rgba(0, 0, 0, 0.06);
}

.itinerary-landing-intro-wrap {
	margin-bottom: 32px;
	padding: 36px;
}

.itinerary-detail-intro {
	width: 100%;
	max-width: none;
	margin-left: 0;
	margin-right: 0;
	padding: 0;
	font-size: 16px;
	line-height: 1.6;
	text-align: center;
}

.itinerary-detail-intro > *:first-child {
	margin-top: 0;
}

.itinerary-detail-intro > *:last-child {
	margin-bottom: 0;
}

.itinerary-detail-intro h1,
.itinerary-detail-intro h2,
.itinerary-detail-intro h3 {
	text-align: center;
	font-weight: 700;
	margin-top: 0;
	margin-bottom: 16px;
	line-height: 1.25;
}

.itinerary-detail-intro h2 {
	font-size: 28px;
}

@media (max-width: 767px) {
	.itinerary-detail-intro-wrap {
		padding: 28px 0;
	}

	.itinerary-detail-intro h2 {
		font-size: 22px;
	}
}

.itinerary-detail-map {
	margin-bottom: 36px;
}

.itinerary-detail-map__row {
	display: block;
}

.itinerary-detail-map__headline {
	margin-top: 0;
	margin-bottom: 14px;
	font-size: 24px;
	font-weight: 700;
	text-align: left;
	line-height: 1.25;
}

.itinerary-detail-map__copy {
	text-align: left;
}

.itinerary-detail-map__text {
	font-size: 15px;
	line-height: 1.55;
	margin-bottom: 20px;
	color: #333;
}

.itinerary-detail-map__text > *:last-child {
	margin-bottom: 0;
}

.itinerary-detail-map__img {
	width: 100%;
	height: auto;
	display: block;
	margin-bottom: 20px;
}

.itinerary-detail-map__cta {
	margin: 0;
}

.itinerary-detail-map__btn {
	display: inline-block;
	padding: 12px 28px;
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	text-decoration: none;
	background-color: #111;
	color: #fff !important;
	border: 2px solid #111;
	border-radius: 0;
}

.itinerary-detail-map__btn:hover,
.itinerary-detail-map__btn:focus {
	background-color: #000;
	border-color: #000;
	color: #fff !important;
	text-decoration: none;
}

.itinerary-detail-map__btn:focus {
	outline: 2px solid #286a95;
	outline-offset: 2px;
}

@media (min-width: 768px) {
	.itinerary-detail-map__row {
		display: flex;
		flex-wrap: wrap;
		align-items: flex-start;
	}

	.itinerary-detail-map__media,
	.itinerary-detail-map__copy {
		float: none;
	}

	.itinerary-detail-map__media .itinerary-detail-map__img {
		margin-bottom: 0;
	}

	.itinerary-detail-map__copy {
		display: flex;
		flex-direction: column;
		justify-content: center;
		min-height: 1px;
		padding-left: 24px;
	}
}

.itinerary-detail-panels {
	margin-bottom: 24px;
}

/* Break out of nested .container so #home-panel-1 background spans viewport (itinerary detail). */
.itinerary-detail-panels.itinerary-detail-panels--full-bleed {
	position: relative;
	left: 50%;
	width: 100vw;
	max-width: none;
	margin-left: 0;
	box-sizing: border-box;
	transform: translateX(-50%);
}

/* Photo Bar (three-up strip) */
.content-block-photo-bar {
	padding: 24px 0;
}

.photo-bar__row {
	margin-left: -8px;
	margin-right: -8px;
}

.photo-bar__cell {
	padding-left: 8px;
	padding-right: 8px;
}

.photo-bar__img {
	width: 100%;
	height: auto;
	display: block;
	object-fit: cover;
	aspect-ratio: 4 / 3;
}

.content-block-featured-itinerary-list {
	padding: 30px 0;
}

.content-block-featured-itinerary-list--shaded {
	background-color: #efede1;
}

.featured-itinerary-list__items,
.featured-itinerary-list__mobile {
	display: block;
}

.featured-itinerary-list__item {
	--fit-thumb-overlap: 48px;
	--fit-copy-padding-left: 72px;

	display: flex;
	align-items: center;
	width: 100%;
	margin-bottom: 20px;
	padding: 0;
	border: 0;
	background: transparent;
	text-align: left;
}

.featured-itinerary-list__item:focus {
	outline: none;
}

.featured-itinerary-list__item:focus-visible {
	outline: 3px solid #286a95;
	outline-offset: 2px;
}

.featured-itinerary-list__item-media {
	flex: 0 0 auto;
	width: 120px;
	padding-right: 0;
	margin-right: calc(-1 * var(--fit-thumb-overlap));
	position: relative;
	z-index: 2;
}

.featured-itinerary-list__item-image {
	width: 100%;
	border-radius: 50%;
}

.featured-itinerary-list__item-copy {
	flex: 1 1 0%;
	min-width: 0;
	position: relative;
	z-index: 1;
	padding: 22px 24px 22px var(--fit-copy-padding-left);
	background-color: #f5f5f5;
}

.featured-itinerary-list__item.is-active .featured-itinerary-list__item-copy,
.featured-itinerary-list__item:hover .featured-itinerary-list__item-copy {
	background-color: #efede1;
}

.featured-itinerary-list__item-title {
	display: block;
	font-size: 26px;
	font-weight: 700;
	line-height: 1.15;
	color: #000;
}

.featured-itinerary-list__panel {
	max-width: 100%;
}

.featured-itinerary-list__panel-title {
	margin-top: 0;
	margin-bottom: 25px;
	font-size: 42px;
	font-weight: 700;
	line-height: 1.08;
}

.featured-itinerary-list__panel-image {
	display: block;
	width: 100%;
	margin-bottom: 25px;
}

.featured-itinerary-list__panel-copy a {
	text-decoration: underline;
}

.featured-itinerary-list__panel-copy p:last-child {
	margin-bottom: 0;
}

.featured-itinerary-list__item--mobile {
	text-decoration: none;
}

.featured-itinerary-list__item--mobile:hover .featured-itinerary-list__item-title,
.featured-itinerary-list__item--mobile:focus .featured-itinerary-list__item-title {
	color: #286a95;
}

@media (max-width: 1199px) {
	.featured-itinerary-list__item-title {
		font-size: 26px;
	}

	.featured-itinerary-list__panel-title {
		font-size: 40px;
	}

	.featured-itinerary-list__panel-copy {
		font-size: 18px;
	}
}

@media (max-width: 991px) {
	.featured-itinerary-list__item {
		--fit-thumb-overlap: 40px;
		--fit-copy-padding-left: 58px;
	}

	.featured-itinerary-list__item-media {
		width: 100px;
	}

	.featured-itinerary-list__item-copy {
		padding: 18px 20px 18px var(--fit-copy-padding-left);
	}

	.featured-itinerary-list__item-title {
		font-size: 22px;
	}
}

@media (max-width: 767px) {
	.content-block-featured-itinerary-list {
		padding: 10px 0 20px;
	}

	.featured-itinerary-list__item {
		--fit-thumb-overlap: 34px;
		--fit-copy-padding-left: 50px;
		margin-bottom: 16px;
	}

	.featured-itinerary-list__item-media {
		width: 84px;
	}

	.featured-itinerary-list__item-copy {
		padding: 16px 16px 16px var(--fit-copy-padding-left);
	}

	.featured-itinerary-list__item-title {
		font-size: 18px;
	}
}

.content-block-quiz-callout {
	padding: 30px 0;
}

.quiz-callout {
	padding: 40px 40px 20px;
	background-color: #f5f5f5;
}

.quiz-callout__preheader {
	margin: 0 0 10px;
	font-size: 16px;
	font-weight: 700;
	line-height: 1.2;
}

.quiz-callout__headline {
	margin: 0 0 24px;
	font-size: 56px;
	font-weight: 400;
	line-height: 1.1;
}

.quiz-callout__button-wrap {
	margin: 0 0 40px;
}

.quiz-callout__button {
	padding: 12px 28px;
	border-radius: 8px;
	background-image: none;
	box-shadow: none;
	text-shadow: none;
	font-size: 18px;
	font-weight: 700;
}

.quiz-callout__cards {
	margin-left: -25px;
	margin-right: -25px;
}

.quiz-callout__cards > [class*='col-'] {
	padding-left: 25px;
	padding-right: 25px;
}

.quiz-callout__card {
	max-width: 100%;
}

.quiz-callout__card-image-wrap {
	aspect-ratio: 4 / 3;
	margin-bottom: 20px;
	overflow: hidden;
}

.quiz-callout__card-image-wrap .quiz-callout__card-image {
	display: block;
	width: 100%;
	height: 100%;
	max-height: none;
	object-fit: cover;
	object-position: center;
}

.quiz-callout__card-image {
	display: block;
	width: 100%;
}

.quiz-callout__card-heading {
	margin: 0 0 10px;
	font-size: 24px;
	font-weight: 700;
	line-height: 1.1;
	text-transform: uppercase;
}

.quiz-callout__card-body {
	font-size: 20px;
	line-height: 1.35;
}

.quiz-callout__card-body p:last-child {
	margin-bottom: 0;
}

.feature-logo__row {
    background-color: #e8f4fc; 
    padding: 20px;
    max-width: 860px;
    margin: 0 auto;
}

@media (max-width: 1199px) {
	.quiz-callout__headline {
		font-size: 46px;
	}

	.quiz-callout__card-body {
		font-size: 18px;
	}
}

@media (max-width: 991px) {
	.quiz-callout {
		padding: 35px 30px 15px;
	}

	.quiz-callout__headline {
		font-size: 38px;
	}

	.quiz-callout__cards {
		margin-left: -15px;
		margin-right: -15px;
	}

	.quiz-callout__cards > [class*='col-'] {
		padding-left: 15px;
		padding-right: 15px;
	}

	.quiz-callout__card-heading {
		font-size: 20px;
	}

	.quiz-callout__card-body {
		font-size: 16px;
	}
}

@media (max-width: 767px) {
	.content-block-quiz-callout {
		padding: 10px 0 20px;
	}

	.quiz-callout {
		padding: 28px 20px 12px;
	}

	.quiz-callout__preheader {
		font-size: 15px;
	}

	.quiz-callout__headline {
		font-size: 30px;
		margin-bottom: 20px;
	}

	.quiz-callout__button-wrap {
		margin-bottom: 24px;
	}

	.quiz-callout__cards {
		margin-left: 0;
		margin-right: 0;
	}

	.quiz-callout__cards > [class*='col-'] {
		padding-left: 0;
		padding-right: 0;
	}

	.quiz-callout__card {
		margin-bottom: 18px;
	}

	.quiz-callout__card-heading {
		font-size: 18px;
		margin-bottom: 8px;
	}

	.quiz-callout__card-body {
		font-size: 16px;
	}
}

.content-block-featured-grid-cards {
	padding: 30px 0;
}

.content-block-featured-grid-cards--shaded {
	background-color: #efede1;
	/* Full-bleed background when the block sits inside a constrained column (e.g. .container > main). */
	width: 100vw;
	max-width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	position: relative;
	box-sizing: border-box;
}

.featured-grid-cards {
	padding: 20px 0 30px;
}

.featured-grid-cards__headline {
	max-width: 860px;
	margin: 0 auto 18px;
	font-size: 54px;
	font-weight: 400;
	line-height: 1.1;
}

.featured-grid-cards__subheadline {
	max-width: 760px;
	margin: 0 auto 28px;
	font-size: 20px;
	line-height: 1.45;
}

.featured-grid-cards__subheadline p:last-child {
	margin-bottom: 0;
}

.featured-grid-cards__row {
	margin-left: -10px;
	margin-right: -10px;
}

.featured-grid-cards__row > [class*='col-'] {
	padding-left: 10px;
	padding-right: 10px;
}

.featured-grid-cards__card {
	position: relative;
	margin-bottom: 20px;
	text-align: left;
}

.featured-grid-cards__card-link {
	display: block;
	color: #000;
	text-decoration: none;
}

.featured-grid-cards__card-link:hover,
.featured-grid-cards__card-link:focus {
	text-decoration: none;
}

.featured-grid-cards__image-frame {
	aspect-ratio: 4 / 3;
	margin-bottom: 12px;
	overflow: hidden;
}

.featured-grid-cards__image-frame .featured-grid-cards__image {
	display: block;
	width: 100%;
	height: 100%;
	max-height: none;
	object-fit: cover;
	object-position: center;
}

.featured-grid-cards__image {
	display: block;
	width: 100%;
}

.featured-grid-cards__card-headline {
	margin: 0;
	padding-right: 42px;
	font-size: 20px;
	font-weight: 700;
	line-height: 1.15;
}

.featured-grid-cards__icon-wrap {
	position: absolute;
	right: 8px;
	bottom: 2px;
}

.featured-grid-cards__icon-button {
	padding: 0;
	border: 0;
	background: transparent;
}

.featured-grid-cards__icon-button:focus {
	outline: 3px solid #286a95;
	outline-offset: 2px;
}

.featured-grid-cards__icon-image {
	width: 34px;
	height: 34px;
}

.featured-grid-cards__icon-popup {
	position: absolute;
	right: 0;
	bottom: 44px;
	z-index: 10;
	width: 240px;
	padding: 14px 16px;
	background-color: #fff;
	border: 1px solid #d9d9d9;
	box-shadow: 0 4px 18px rgba(0, 0, 0, 0.14);
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.2s ease;
}

.featured-grid-cards__icon-popup.is-open {
	opacity: 1;
	visibility: visible;
}

.featured-grid-cards__icon-popup.is-dismissed {
	opacity: 0;
	visibility: hidden;
}

.featured-grid-cards__icon-popup-close {
	position: absolute;
	top: 6px;
	right: 8px;
	padding: 0;
	border: 0;
	background: transparent;
	font-size: 24px;
	line-height: 1;
}

.featured-grid-cards__icon-popup-close:focus {
	outline: 3px solid #286a95;
	outline-offset: 2px;
}

.featured-grid-cards__icon-popup p:last-child {
	margin-bottom: 0;
}

.featured-grid-cards__icon-wrap:hover .featured-grid-cards__icon-popup:not(.is-open):not(.is-dismissed),
.featured-grid-cards__icon-wrap:focus-within .featured-grid-cards__icon-popup:not(.is-open):not(.is-dismissed) {
	opacity: 1;
	visibility: visible;
}

.featured-grid-cards__mobile-icon-text {
	margin-top: 12px;
	font-size: 14px;
	line-height: 1.45;
}

.featured-grid-cards__mobile-icon-text p:last-child {
	margin-bottom: 0;
}

.featured-grid-cards__cta-wrap {
	margin: 18px 0 0;
}

.featured-grid-cards__cta {
	padding: 12px 28px;
	border-radius: 8px;
	background-image: none;
	box-shadow: none;
	text-shadow: none;
	font-size: 18px;
	font-weight: 700;
}

@media (max-width: 1199px) {
	.featured-grid-cards__headline {
		font-size: 44px;
	}

	.featured-grid-cards__subheadline {
		font-size: 18px;
	}
}

@media (max-width: 991px) {
	.featured-grid-cards__headline {
		font-size: 36px;
	}

	.featured-grid-cards__card-headline {
		font-size: 18px;
	}

	.featured-grid-cards__icon-popup {
		width: 220px;
	}
}

@media (max-width: 767px) {
	.content-block-featured-grid-cards {
		padding: 10px 0 20px;
	}

	.featured-grid-cards {
		padding: 10px 0 20px;
	}

	.featured-grid-cards__headline {
		font-size: 30px;
		margin-bottom: 14px;
	}

	.featured-grid-cards__subheadline {
		font-size: 16px;
		margin-bottom: 22px;
	}

	.featured-grid-cards__row {
		margin-left: -7px;
		margin-right: -7px;
	}

	.featured-grid-cards__row > [class*='col-'] {
		padding-left: 7px;
		padding-right: 7px;
	}

	.featured-grid-cards__card {
		margin-bottom: 18px;
	}

	.featured-grid-cards__image-frame {
		margin-bottom: 10px;
	}

	.featured-grid-cards__card-headline {
		padding-right: 0;
		font-size: 16px;
	}

	.featured-grid-cards__icon-wrap {
		position: static;
		margin-top: 8px;
	}

	.featured-grid-cards__icon-button {
		display: inline-block;
	}

	.featured-grid-cards__cta-wrap {
		margin-top: 8px;
	}
}

/* Blog feed */
.content-block-blog-feed {
	padding: 30px 0;
}

.blog-feed__header {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-end;
	justify-content: space-between;
	gap: 12px 24px;
	padding-bottom: 16px;
	margin-bottom: 8px;
	border-bottom: 1px solid #ccc;
}

.blog-feed__intro {
	margin: 0;
	font-size: 24px;
	font-weight: 700;
	line-height: 1.2;
	color: #000;
}

.blog-feed__header--view-only {
	justify-content: flex-end;
}

.blog-feed__view-all {
	font-size: 15px;
	font-weight: 400;
	line-height: 1.2;
	color: #286a95;
	text-decoration: underline;
}

.blog-feed__view-all:hover,
.blog-feed__view-all:focus {
	color: #1a4a66;
	text-decoration: underline;
}

.blog-feed__view-all:focus {
	outline: 3px solid #286a95;
	outline-offset: 2px;
}

.blog-feed__list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.blog-feed__item {
	padding: 28px 0;
	border-bottom: 1px solid #ddd;
	text-align: left;
}

.blog-feed__item:last-child {
	border-bottom: 0;
}

.blog-feed__title {
	margin: 0 0 10px;
	font-size: 32px;
	font-weight: 700;
	line-height: 1.15;
	color: #000;
}

.blog-feed__title-link {
	color: inherit;
	text-decoration: none;
}

.blog-feed__title-link:hover,
.blog-feed__title-link:focus {
	text-decoration: underline;
}

.blog-feed__title-link:focus {
	outline: 3px solid #286a95;
	outline-offset: 2px;
}

.blog-feed__date {
	margin: 0 0 14px;
	font-size: 15px;
	font-weight: 700;
	line-height: 1.3;
	color: #000;
}

.blog-feed__excerpt {
	margin: 0;
	font-size: 16px;
	font-weight: 400;
	line-height: 1.5;
	color: #333;
}

.blog-feed__excerpt p {
	margin: 0 0 0.75em;
}

.blog-feed__excerpt p:last-child {
	margin-bottom: 0;
}

@media (max-width: 767px) {
	.content-block-blog-feed {
		padding: 20px 0;
	}

	.blog-feed__header {
		flex-direction: column;
		align-items: flex-start;
	}

	.blog-feed__intro {
		font-size: 20px;
	}

	.blog-feed__title {
		font-size: 22px;
	}

	.blog-feed__item {
		padding: 22px 0;
	}
}

/* 50/50 Spotlight — image + overlapping dark panel, Glide + Alpine */
.content-block-spotlight-50-50 {
	position: relative;
	padding: 0;
	z-index: 0;
}

/* Full-viewport-width light band when ACF “Full-width section background” is on */
.content-block-spotlight-50-50--section-bg::before {
	content: '';
	position: absolute;
	left: 50%;
	top: 0;
	bottom: 0;
	width: 100vw;
	margin-left: -50vw;
	z-index: -1;
	background-color: #f5f5f5;
	pointer-events: none;
}

.spotlight-50-50 {
	padding: 36px 0 44px;
	background-color: transparent;
}

.spotlight-50-50__glide {
	position: relative;
}

.spotlight-50-50__glide--multi {
	padding-bottom: 56px;
}

.spotlight-50-50__slide {
	overflow: visible;
}

.spotlight-50-50__body {
	position: relative;
	display: block;
	min-height: 200px;
}

.spotlight-50-50__media-frame {
	aspect-ratio: 4 / 3;
	overflow: hidden;
	background-color: #e8e8e8;
}

.spotlight-50-50__image {
	display: block;
	width: 100%;
	height: 100%;
	max-height: none;
	object-fit: cover;
	object-position: center;
}

.spotlight-50-50__panel {
	background-color: #286a95;
	color: #fff;
}

.spotlight-50-50__panel-inner {
	max-width: 100%;
}

.spotlight-50-50__eyebrow {
	margin: 0 0 10px;
	font-size: 14px;
	font-weight: 700;
	line-height: 1.2;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.85);
}

.spotlight-50-50__title {
	margin: 0 0 20px;
	font-size: 36px;
	font-weight: 700;
	line-height: 1.12;
	color: #fff;
}

.spotlight-50-50__text {
	margin-bottom: 22px;
	font-size: 17px;
	line-height: 1.5;
	color: rgba(255, 255, 255, 0.92);
}

.spotlight-50-50__text p {
	margin: 0 0 12px;
}

.spotlight-50-50__text p:last-child {
	margin-bottom: 0;
}

.spotlight-50-50__text a {
	color: #e8f4fc;
	text-decoration: underline;
}

.spotlight-50-50__text a:hover,
.spotlight-50-50__text a:focus {
	color: #fff;
}

.spotlight-50-50__cta-wrap {
	margin: 0;
}

.spotlight-50-50__cta {
	display: inline-block;
	padding: 12px 28px;
	border-radius: 999px;
	background-color: #fff;
	color: #286a95;
	font-size: 14px;
	font-weight: 700;
	line-height: 1.2;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	text-decoration: none;
	border: 0;
	box-shadow: none;
}

.spotlight-50-50__cta:hover,
.spotlight-50-50__cta:focus {
	background-color: #f0f0f0;
	color: #1a4a66;
	text-decoration: none;
}

.spotlight-50-50__cta:focus {
	outline: 3px solid #286a95;
	outline-offset: 3px;
}

.spotlight-50-50__arrows {
	display: flex;
	align-items: center;
	gap: 16px;
	margin-top: 20px;
}

.spotlight-50-50__counter {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 16px;
	line-height: 1;
	color: #949494;
}

.spotlight-50-50__counter-sep {
	color: #949494;
}

.spotlight-50-50__arrow {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	padding: 0;
	border: 1px solid #c4c4c4;
	border-radius: 50%;
	background-color: transparent;
	line-height: 1;
	cursor: pointer;
}

.spotlight-50-50__arrow:hover,
.spotlight-50-50__arrow:focus {
	border-color: #286a95;
}

.spotlight-50-50__arrow:focus {
	outline: 3px solid #286a95;
	outline-offset: 2px;
}

.spotlight-50-50__arrow-icon {
	display: block;
	width: 10px;
	height: 10px;
	border-right: 2px solid #949494;
	border-bottom: 2px solid #949494;
}

.spotlight-50-50__arrow--prev .spotlight-50-50__arrow-icon {
	transform: rotate(135deg);
	margin-left: 4px;
}

.spotlight-50-50__arrow--next .spotlight-50-50__arrow-icon {
	transform: rotate(-45deg);
	margin-right: 4px;
	border-color: #286a95;
}

.spotlight-50-50__arrow--next:hover .spotlight-50-50__arrow-icon,
.spotlight-50-50__arrow--next:focus .spotlight-50-50__arrow-icon {
	border-color: #1e5278;
}

@media (min-width: 768px) {
	.page-template-itinerary-detail-page #content-sidebar {
		margin-top: -150px;
	}

	.spotlight-50-50 {
		padding: 48px 0 56px;
	}

	.spotlight-50-50__body {
		display: flex;
		flex-direction: row;
		align-items: center;
		min-height: 280px;
	}

	.spotlight-50-50__media {
		flex: 0 0 74%;
		max-width: 74%;
	}

	.spotlight-50-50__panel {
		flex: 0 0 42%;
		max-width: 460px;
		min-width: 0;
		margin-left: -16%;
		padding: 40px 36px 44px;
		box-shadow: 0 16px 48px rgba(0, 0, 0, 0.28);
		z-index: 2;
	}

	.spotlight-50-50__title {
		font-size: 42px;
	}

	.spotlight-50-50__text {
		font-size: 18px;
	}

	.spotlight-50-50__glide--multi .spotlight-50-50__arrows {
		position: absolute;
		bottom: 0;
		left: 58%;
		right: auto;
		margin-top: 0;
		padding-left: 36px;
	}
}

@media (max-width: 767px) {
	.spotlight-50-50 {
		padding: 24px 0 32px;
	}

	.spotlight-50-50__body {
		display: block;
		min-height: 0;
	}

	.spotlight-50-50__media {
		flex: none;
		max-width: none;
		width: auto;
		margin-bottom: 0;
	}

	.spotlight-50-50__panel {
		position: static;
		flex: none;
		transform: none;
		width: auto;
		max-width: none;
		min-width: 0;
		margin-left: 16px;
		margin-right: 16px;
		padding: 28px 22px 32px;
		box-shadow: 0 12px 32px rgba(0, 0, 0, 0.2);
	}

	.spotlight-50-50__title {
		font-size: 28px;
		margin-bottom: 14px;
	}

	.spotlight-50-50__text {
		font-size: 16px;
		margin-bottom: 18px;
	}

	.spotlight-50-50__glide--multi {
		padding-bottom: 0;
	}

	.spotlight-50-50__arrows {
		justify-content: center;
		margin-top: 24px;
		padding-left: 0;
	}
}

.itinerary-detail-intro__subheadline {
	font-weight: bold;
	font-size: 20px;
}
