/**
 * ToursZoom Destination Override — hub styles (temporary pre-launch).
 * Brand: navy #103d62, gold #e8a84e, cream #e8dece.
 */

.tzdo-hub {
	width: 100%;
}

/* Hero ------------------------------------------------------------------ */
.tzdo-hero {
	position: relative;
	min-height: 260px;
	display: flex;
	align-items: flex-end;
	background: #103d62;
	overflow: hidden;
}

.tzdo-hero__img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.tzdo-hero__overlay {
	position: relative;
	z-index: 1;
	width: 100%;
	padding: 48px 24px 28px;
	background: linear-gradient( to top, rgba( 16, 61, 98, 0.85 ) 0%, rgba( 16, 61, 98, 0 ) 100% );
}

.tzdo-hero--image .tzdo-hero__title,
.tzdo-hero__title {
	margin: 0 auto;
	max-width: 1100px;
	color: #fff;
	font-size: clamp( 28px, 5vw, 44px );
	line-height: 1.15;
	text-shadow: 0 1px 12px rgba( 0, 0, 0, 0.35 );
}

/* Container ------------------------------------------------------------- */
.tzdo-container {
	max-width: 1100px;
	margin: 0 auto;
	padding: 40px 24px 56px;
}

/* Framed widget section (heading + context + body) --------------------- */
.tzdo-section {
	margin: 0 0 48px;
}

.tzdo-section__heading {
	margin: 0 0 10px;
	color: #103d62;
	font-size: clamp( 20px, 3vw, 27px );
	border-bottom: 3px solid #e8a84e;
	padding-bottom: 10px;
}

.tzdo-section__intro {
	margin: 0 0 20px;
	max-width: 760px;
	color: #4a5963;
	font-size: 16.5px;
	line-height: 1.65;
}

.tzdo-section__body {
	width: 100%;
}

/* Let embedded TP widgets use the full container width. */
.tzdo-section__body iframe,
.tzdo-section__body > div {
	max-width: 100% !important;
	width: 100% !important;
}

/* Lede (destination description as magazine intro) --------------------- */
.tzdo-lede {
	font-size: 19px;
	line-height: 1.75;
	color: #243b4a;
	margin: 0 0 40px;
	padding-bottom: 8px;
}

.tzdo-lede p {
	margin: 0 0 1em;
}

.tzdo-lede p:last-child {
	margin-bottom: 0;
}

/* Guides --------------------------------------------------------------- */
.tzdo-guides__heading {
	margin: 0 0 22px;
	color: #103d62;
	font-size: clamp( 22px, 3vw, 28px );
	border-bottom: 3px solid #e8a84e;
	padding-bottom: 10px;
}

.tzdo-grid {
	display: grid;
	grid-template-columns: repeat( auto-fill, minmax( 280px, 1fr ) );
	gap: 24px;
}

.tzdo-card {
	border: 1px solid #e3e3e3;
	border-radius: 12px;
	overflow: hidden;
	background: #fff;
	transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.tzdo-card:hover {
	box-shadow: 0 10px 28px rgba( 16, 61, 98, 0.14 );
	transform: translateY( -3px );
}

.tzdo-card__link {
	display: block;
	color: inherit;
	text-decoration: none;
}

.tzdo-card__media {
	aspect-ratio: 16 / 10;
	overflow: hidden;
	background: #f1efea;
}

.tzdo-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.tzdo-card__body {
	padding: 16px 18px 20px;
}

.tzdo-card__title {
	margin: 0 0 8px;
	color: #103d62;
	font-size: 18px;
	line-height: 1.3;
}

.tzdo-card__excerpt {
	margin: 0 0 12px;
	color: #51606b;
	font-size: 14.5px;
	line-height: 1.55;
}

.tzdo-card__more {
	color: #c8862a;
	font-weight: 600;
	font-size: 14.5px;
}

/* Related destinations -------------------------------------------------- */
.tzdo-related {
	margin: 0 0 48px;
}

.tzdo-grid--compact {
	grid-template-columns: repeat( auto-fill, minmax( 200px, 1fr ) );
	gap: 18px;
}

.tzdo-card--dest .tzdo-card__media {
	aspect-ratio: 4 / 3;
}

.tzdo-card--dest .tzdo-card__body {
	padding: 12px 14px 16px;
}

/* Best time to visit ---------------------------------------------------- */
.tzdo-besttime {
	margin: 0 0 48px;
}

.tzdo-bt-grid {
	display: grid;
	grid-template-columns: repeat( auto-fit, minmax( 200px, 1fr ) );
	gap: 16px;
	margin: 0 0 18px;
}

.tzdo-bt-card {
	background: #f7f5f0;
	border: 1px solid #e7e1d4;
	border-left-width: 5px;
	border-radius: 10px;
	padding: 14px 18px;
	display: flex;
	flex-direction: column;
	gap: 5px;
}

.tzdo-bt-card--best {
	border-left-color: #1f9d55;
}

.tzdo-bt-card--shoulder {
	border-left-color: #e8a84e;
}

.tzdo-bt-card--avoid {
	border-left-color: #c0563f;
}

.tzdo-bt-label {
	font-size: 13px;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: #6a7680;
	font-weight: 700;
}

.tzdo-bt-val {
	font-size: 18px;
	font-weight: 700;
	color: #103d62;
}

.tzdo-bt-summary {
	font-size: 16.5px;
	line-height: 1.65;
	color: #3a4954;
}

.tzdo-bt-summary p {
	margin: 0 0 1em;
}

.tzdo-bt-summary p:last-child {
	margin-bottom: 0;
}

/* Top attractions ------------------------------------------------------- */
.tzdo-attractions {
	margin: 0 0 48px;
}

.tzdo-attr-grid {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
}

.tzdo-attr {
	display: inline-flex;
	align-items: center;
	gap: 9px;
	background: #f7f5f0;
	border: 1px solid #e7e1d4;
	border-radius: 999px;
	padding: 9px 16px;
	color: #103d62;
	font-size: 15px;
	font-weight: 600;
	line-height: 1.2;
}

.tzdo-attr::before {
	content: "";
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: #e8a84e;
	flex: 0 0 auto;
}

/* FAQ ------------------------------------------------------------------- */
.tzdo-faq__item {
	border: 1px solid #e3e3e3;
	border-radius: 10px;
	margin: 0 0 12px;
	background: #fff;
	overflow: hidden;
}

.tzdo-faq__q {
	cursor: pointer;
	padding: 16px 46px 16px 18px;
	position: relative;
	font-weight: 600;
	color: #103d62;
	font-size: 17px;
	line-height: 1.4;
	list-style: none;
}

.tzdo-faq__q::-webkit-details-marker {
	display: none;
}

.tzdo-faq__q::after {
	content: "+";
	position: absolute;
	right: 18px;
	top: 50%;
	transform: translateY( -50% );
	color: #e8a84e;
	font-size: 22px;
	line-height: 1;
}

.tzdo-faq__item[open] .tzdo-faq__q::after {
	content: "\2212"; /* minus */
}

.tzdo-faq__item[open] .tzdo-faq__q {
	border-bottom: 1px solid #eee;
}

.tzdo-faq__a {
	padding: 14px 18px 18px;
	color: #3a4954;
	font-size: 16px;
	line-height: 1.65;
}

.tzdo-faq__a p {
	margin: 0 0 1em;
}

.tzdo-faq__a p:last-child {
	margin-bottom: 0;
}

/* Map ------------------------------------------------------------------- */
.tzdo-map__wrap {
	position: relative;
	width: 100%;
	aspect-ratio: 16 / 7;
	border-radius: 12px;
	overflow: hidden;
	border: 1px solid #e3e3e3;
}

.tzdo-map__frame {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	border: 0;
}

@media ( max-width: 600px ) {
	.tzdo-hero {
		min-height: 200px;
	}
	.tzdo-container {
		padding: 28px 16px 40px;
	}
	.tzdo-map__wrap {
		aspect-ratio: 4 / 3;
	}
}
