/**
 * Opal Tour - Frontend Stylesheet
 * Thiết kế editorial premium travel, kế thừa accent #ffaa00 của theme Aventour.
 */

/* ============================================================
   1. DESIGN TOKENS
   ============================================================ */
:root {
	--opal-accent:        #ffaa00;
	--opal-accent-dark:   #d98e00;
	--opal-accent-soft:   #fff4dc;
	--opal-ink:           #1a2332;
	--opal-ink-soft:      #4a5568;
	--opal-muted:         #718096;
	--opal-line:          #e8eaed;
	--opal-bg:            #fafbfc;
	--opal-card:          #ffffff;
	--opal-success:       #10b981;
	--opal-danger:        #ef4444;
	--opal-warning:       #f59e0b;
	--opal-radius-sm:     8px;
	--opal-radius-md:     14px;
	--opal-radius-lg:     20px;
	--opal-shadow-sm:     0 1px 3px rgba(15, 23, 42, 0.06), 0 1px 2px rgba(15, 23, 42, 0.04);
	--opal-shadow-md:     0 8px 24px rgba(15, 23, 42, 0.08);
	--opal-shadow-lg:     0 20px 60px rgba(15, 23, 42, 0.12);
	--opal-font-display:  'Be Vietnam Pro', 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
	--opal-font-body:     'Be Vietnam Pro', 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}

/* Import 1 font duy nhất - hỗ trợ tiếng Việt đầy đủ, hiện đại, dễ đọc */
@import url('https://fonts.googleapis.com/css2?family=Be+Vietnam+Pro:wght@400;500;600;700;800&display=swap');

/* ============================================================
   2. WRAPPER & BREADCRUMB
   ============================================================ */
.opal-tour-wrap,
.opal-tour-wrap * {
	font-family: var(--opal-font-body) !important;
}
.opal-tour-wrap {
	color: var(--opal-ink);
	line-height: 1.65;
	background: var(--opal-bg);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

.opal-tour-wrap *,
.opal-tour-wrap *::before,
.opal-tour-wrap *::after { box-sizing: border-box; }

.opal-container {
	max-width: 1320px;
	margin: 0 auto;
	padding: 0 24px;
}

@media (max-width: 768px) {
	.opal-container { padding: 0 14px; }
}

/* ============================================================
   3. HERO HEADER + VIDEO
   ============================================================ */
.opal-hero {
	position: relative;
	padding: 24px 0 0;
}

/* Video link card (Douyin/TikTok không embed iframe được) */
.opal-video-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 16px;
	text-decoration: none;
	color: #fff;
	overflow: hidden;
	transition: transform .3s;
	width: 100%;
	height: 100%;
}
.opal-video-card:hover { transform: scale(1.02); }

.opal-video-card .opal-vc-overlay {
	position: absolute;
	inset: 0;
	background:
		linear-gradient(135deg, rgba(0,0,0,.4) 0%, rgba(0,0,0,.6) 100%),
		url('https://images.unsplash.com/photo-1493246507139-91e8fad9978e?w=600&q=80&auto=format');
	background-size: cover;
	background-position: center;
	z-index: 0;
	transition: transform .5s;
}
.opal-video-card:hover .opal-vc-overlay { transform: scale(1.06); }

/* Background tùy platform */
.opal-vc-bg-douyin .opal-vc-overlay {
	background-image: linear-gradient(135deg, rgba(0,0,0,.5) 0%, rgba(0,0,0,.65) 100%);
	background-color: #000;
}
.opal-vc-bg-douyin {
	background: linear-gradient(135deg, #fe2c55 0%, #25f4ee 100%);
}
.opal-vc-bg-tiktok {
	background: linear-gradient(135deg, #000 0%, #25f4ee 50%, #fe2c55 100%);
}
.opal-vc-bg-tiktok .opal-vc-overlay,
.opal-vc-bg-video .opal-vc-overlay,
.opal-vc-bg-link .opal-vc-overlay {
	background-image: linear-gradient(135deg, rgba(0,0,0,.45) 0%, rgba(0,0,0,.6) 100%);
}

.opal-video-card .opal-vc-play {
	position: relative;
	z-index: 1;
	width: 78px;
	height: 78px;
	filter: drop-shadow(0 6px 20px rgba(0,0,0,.4));
	transition: transform .3s;
}
.opal-video-card:hover .opal-vc-play { transform: scale(1.08); }

.opal-vc-meta {
	position: relative;
	z-index: 1;
	text-align: center;
	padding: 0 24px;
}
.opal-vc-platform {
	display: block;
	font-size: 28px;
	font-weight: 800;
	letter-spacing: -0.02em;
	margin-bottom: 4px;
	text-shadow: 0 2px 8px rgba(0,0,0,.4);
}
.opal-vc-cta {
	display: inline-block;
	font-size: 13px;
	font-weight: 600;
	padding: 8px 18px;
	background: rgba(255,255,255,0.95);
	color: var(--opal-ink);
	border-radius: 100px;
	margin-top: 4px;
	text-shadow: none;
}

/* Mobile: video card nhỏ lại */
@media (max-width: 768px) {
	.opal-video-card .opal-vc-play { width: 60px; height: 60px; }
	.opal-vc-platform { font-size: 20px; }
	.opal-vc-cta { font-size: 12px; padding: 7px 14px; }
}

.opal-breadcrumb {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	font-size: 13px;
	color: var(--opal-muted);
	margin-bottom: 18px;
}
.opal-breadcrumb a {
	color: var(--opal-muted);
	text-decoration: none;
	transition: color .2s;
}
.opal-breadcrumb a:hover { color: var(--opal-accent-dark); }
.opal-breadcrumb .sep { color: #cbd5e0; }

.opal-tour-title {
	font-family: var(--opal-font-display);
	font-size: clamp(22px, 3.6vw, 38px);
	line-height: 1.22;
	font-weight: 800;
	color: var(--opal-ink);
	margin: 0 0 14px;
	letter-spacing: -0.02em;
	word-wrap: break-word;
	overflow-wrap: break-word;
	hyphens: auto;
}

.opal-tour-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 24px;
	align-items: center;
	margin-bottom: 24px;
	padding-bottom: 24px;
	border-bottom: 1px solid var(--opal-line);
}
.opal-tour-meta-item {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 14px;
	color: var(--opal-ink-soft);
	font-weight: 500;
}
.opal-tour-meta-item i,
.opal-tour-meta-item svg { color: var(--opal-accent); font-size: 16px; }
.opal-tour-meta-item strong { color: var(--opal-ink); font-weight: 600; }
.opal-tour-meta-item .stars { color: var(--opal-accent); }

/* Vibe chips */
.opal-vibe-chips {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin-bottom: 18px;
}
.opal-vibe-chip {
	display: inline-block;
	padding: 4px 12px;
	background: var(--opal-accent-soft);
	color: var(--opal-accent-dark);
	border-radius: 100px;
	font-size: 12px;
	font-weight: 600;
	text-decoration: none;
	transition: all .2s;
	border: 1px solid transparent;
}
.opal-vibe-chip:hover {
	background: var(--opal-accent);
	color: #fff;
	transform: translateY(-1px);
}

/* Route text (lộ trình) */
.opal-route-text {
	display: inline-block;
	font-size: 14px;
	color: var(--opal-ink-soft);
	background: var(--opal-accent-soft);
	padding: 8px 16px;
	border-radius: 100px;
	margin-bottom: 16px;
	font-weight: 500;
}

/* Overview lead (đoạn mô tả ngắn) */
.opal-overview-lead {
	font-size: 16px;
	line-height: 1.7;
	color: var(--opal-ink);
	font-weight: 500;
	padding: 16px 20px;
	background: linear-gradient(135deg, var(--opal-accent-soft) 0%, #fff 100%);
	border-left: 4px solid var(--opal-accent);
	border-radius: 0 var(--opal-radius-md) var(--opal-radius-md) 0;
	margin: 0 0 24px;
}

/* Recurring banner */
.opal-recurring-banner {
	background: linear-gradient(135deg, var(--opal-accent-soft) 0%, #fff7e0 100%);
	border: 1px dashed var(--opal-accent);
	border-radius: var(--opal-radius-sm);
	padding: 12px 14px;
	margin-bottom: 12px;
	font-size: 13.5px;
	color: var(--opal-accent-dark);
	text-align: center;
}
.opal-recurring-banner strong { color: var(--opal-ink); }

/* Price note */
.opal-price-note {
	margin-top: 12px;
	padding: 10px 12px;
	background: #fafbfc;
	border-radius: var(--opal-radius-sm);
	font-size: 12px;
	color: var(--opal-muted);
	line-height: 1.5;
}

/* ============================================================
   4. HERO GALLERY (asymmetric grid — video hoặc ảnh ở ô main)
   ============================================================ */
.opal-hero-gallery {
	display: grid;
	grid-template-columns: 2fr 1fr 1fr;
	grid-template-rows: 220px 220px;
	gap: 8px;
	margin-bottom: 28px;
	border-radius: var(--opal-radius-md);
	overflow: hidden;
}
.opal-hero-gallery img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	cursor: pointer;
	transition: transform .5s cubic-bezier(.2,.8,.2,1);
	display: block;
}
.opal-hero-gallery img:hover { transform: scale(1.04); }

/* Ô MAIN: ảnh đầu hoặc video - chiếm grid-column 1, span 2 rows */
.opal-hero-gallery .opal-img-main,
.opal-hero-gallery .opal-hero-main-video {
	grid-row: 1 / 3;
	grid-column: 1 / 2;
}

/* Khi có video, ô main là div chứa iframe/card */
.opal-hero-gallery .opal-hero-main-video {
	position: relative;
	background: #000;
	overflow: hidden;
}
.opal-hero-gallery .opal-hero-main-video iframe,
.opal-hero-gallery .opal-hero-main-video video {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	border: 0;
	display: block;
}

/* Video card link (Douyin/TikTok không embed iframe được) */
.opal-hero-gallery .opal-hero-main-video .opal-video-card {
	position: absolute;
	inset: 0;
}

.opal-hero-gallery .opal-img-more {
	position: relative;
}
.opal-hero-gallery .opal-img-more::after {
	content: '+' attr(data-count) ' ảnh';
	position: absolute;
	inset: 0;
	background: rgba(15, 23, 42, 0.55);
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 700;
	font-size: 18px;
	pointer-events: none;
}

/* Mobile: scroll-snap horizontal slider hiện hết tất cả ảnh */
@media (max-width: 768px) {
	.opal-hero-gallery {
		display: flex;
		grid-template-columns: none;
		grid-template-rows: none;
		gap: 8px;
		overflow-x: auto;
		overflow-y: hidden;
		scroll-snap-type: x mandatory;
		-webkit-overflow-scrolling: touch;
		scrollbar-width: none;
		padding: 0 14px;
		margin: 0 -14px 24px;
		border-radius: 0;
	}
	.opal-hero-gallery::-webkit-scrollbar { display: none; }
	.opal-hero-gallery > img,
	.opal-hero-gallery > .opal-hero-main-video {
		flex: 0 0 88%;
		height: 240px;
		width: auto;
		scroll-snap-align: center;
		border-radius: var(--opal-radius-md);
		display: block !important;
		grid-row: auto;
		grid-column: auto;
	}
	.opal-hero-gallery > img { object-fit: cover; }
	.opal-hero-gallery > .opal-hero-main-video {
		flex-basis: 88%;
		position: relative;
		background: #000;
	}
	.opal-hero-gallery .opal-img-more::after {
		border-radius: var(--opal-radius-md);
		font-size: 16px;
	}
}

/* ============================================================
   5. LAYOUT 2 CỘT
   ============================================================ */
.opal-tour-layout {
	display: grid;
	grid-template-columns: 1fr 320px;
	gap: 28px;
	align-items: start;
	padding-bottom: 60px;
}

@media (max-width: 1024px) {
	.opal-tour-layout {
		grid-template-columns: 1fr;
		gap: 20px;
		padding-bottom: 90px; /* room cho mobile booking bar */
	}
}

/* ============================================================
   6. STICKY TABS NAV
   ============================================================ */
.opal-tabs-nav {
	position: sticky;
	top: 0;
	z-index: 50;
	background: var(--opal-bg);
	padding: 10px 0;
	margin-bottom: 20px;
	border-bottom: 1px solid var(--opal-line);
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
}
.opal-tabs-nav::-webkit-scrollbar { display: none; }
.opal-tabs-nav-inner {
	display: flex;
	gap: 4px;
	min-width: max-content;
	padding: 0 24px;
}
.opal-tab-link {
	padding: 9px 16px;
	background: transparent;
	border: 0;
	border-radius: var(--opal-radius-sm);
	font-size: 13.5px;
	font-weight: 600;
	color: var(--opal-ink-soft);
	cursor: pointer;
	white-space: nowrap;
	transition: all .2s;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 6px;
}
.opal-tab-link:hover { background: var(--opal-accent-soft); color: var(--opal-accent-dark); }
.opal-tab-link.is-active {
	background: var(--opal-ink);
	color: #fff;
}

/* ============================================================
   7. SECTION CARDS
   ============================================================ */
.opal-section {
	background: var(--opal-card);
	border-radius: var(--opal-radius-lg);
	padding: 28px 32px;
	margin-bottom: 20px;
	box-shadow: var(--opal-shadow-sm);
	scroll-margin-top: 80px;
}

.opal-section-head {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 18px;
	padding-bottom: 14px;
	border-bottom: 2px solid var(--opal-accent-soft);
}
.opal-section-head h2 {
	font-family: var(--opal-font-display);
	font-size: 22px;
	font-weight: 800;
	margin: 0;
	color: var(--opal-ink);
	letter-spacing: -0.01em;
}
.opal-section-head .opal-section-icon {
	width: 36px;
	height: 36px;
	background: var(--opal-accent-soft);
	border-radius: var(--opal-radius-sm);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--opal-accent-dark);
	font-size: 18px;
}

/* ============================================================
   8. OVERVIEW + FEATURES GRID
   ============================================================ */
.opal-overview-text {
	font-size: 16px;
	line-height: 1.85;
	color: var(--opal-ink-soft);
}
.opal-overview-text p { margin: 0 0 16px; }
.opal-overview-text strong { color: var(--opal-ink); }
.opal-overview-text ul { padding-left: 22px; margin: 16px 0; }
.opal-overview-text ul li { list-style: disc; margin-bottom: 8px; }
.opal-overview-text img {
	width: 100%;
	border-radius: var(--opal-radius-md);
	margin: 20px 0;
	box-shadow: var(--opal-shadow-md);
}

.opal-features-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 12px;
	margin-top: 24px;
	padding-top: 24px;
	border-top: 1px dashed var(--opal-line);
}
.opal-feature-card {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 14px 16px;
	background: linear-gradient(135deg, #fafbfc 0%, var(--opal-accent-soft) 200%);
	border-radius: var(--opal-radius-sm);
	border: 1px solid var(--opal-line);
	transition: all .25s;
}
.opal-feature-card:hover {
	transform: translateY(-2px);
	border-color: var(--opal-accent);
	box-shadow: var(--opal-shadow-md);
}
.opal-feature-card img {
	width: 36px;
	height: 36px;
	object-fit: contain;
	flex-shrink: 0;
}
.opal-feature-card .opal-feature-text {
	font-size: 13.5px;
	line-height: 1.4;
}
.opal-feature-card .opal-feature-text strong {
	display: block;
	color: var(--opal-ink);
	font-weight: 700;
	margin-bottom: 2px;
}
.opal-feature-card .opal-feature-text span {
	color: var(--opal-muted);
	font-size: 12.5px;
}

/* ============================================================
   9. ITINERARY TIMELINE
   ============================================================ */
.opal-itinerary {
	position: relative;
}
.opal-itinerary::before {
	content: '';
	position: absolute;
	left: 18px;
	top: 0;
	bottom: 0;
	width: 2px;
	background: linear-gradient(to bottom, var(--opal-accent), transparent);
	opacity: .35;
}

.opal-itinerary-day {
	position: relative;
	padding-left: 56px;
	margin-bottom: 18px;
}
.opal-itinerary-day:last-child { margin-bottom: 0; }

.opal-day-marker {
	position: absolute;
	left: 0;
	top: 14px;
	width: 38px;
	height: 38px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--opal-accent) 0%, var(--opal-accent-dark) 100%);
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 800;
	font-size: 13px;
	box-shadow: 0 4px 12px rgba(255, 170, 0, 0.35);
	z-index: 2;
	border: 4px solid var(--opal-card);
}

.opal-day-toggle {
	width: 100%;
	background: #fff;
	border: 1px solid var(--opal-line);
	border-radius: var(--opal-radius-md);
	padding: 16px 50px 16px 20px;
	cursor: pointer;
	font-family: inherit;
	font-size: 16px;
	font-weight: 700;
	color: var(--opal-ink);
	text-align: left;
	position: relative;
	transition: all .2s;
}
.opal-day-toggle:hover,
.opal-day-toggle.is-open {
	border-color: var(--opal-accent);
	background: var(--opal-accent-soft);
}
.opal-day-toggle .opal-day-chevron {
	position: absolute;
	right: 20px;
	top: 50%;
	transform: translateY(-50%);
	color: var(--opal-accent);
	font-size: 14px;
	transition: transform .3s;
}
.opal-day-toggle.is-open .opal-day-chevron { transform: translateY(-50%) rotate(180deg); }
.opal-day-toggle small {
	display: block;
	color: var(--opal-muted);
	font-size: 13px;
	font-weight: 500;
	margin-top: 2px;
}

.opal-day-body {
	display: none;
	padding: 20px 24px;
	margin-top: 4px;
	background: #fff;
	border: 1px solid var(--opal-line);
	border-top: 0;
	border-radius: 0 0 var(--opal-radius-md) var(--opal-radius-md);
	font-size: 15px;
	line-height: 1.75;
	color: var(--opal-ink-soft);
}

/* Khi có ảnh: layout 2 cột (ảnh trái, text phải) */
.opal-day-body.has-image {
	display: none;
	grid-template-columns: 280px 1fr;
	gap: 20px;
	align-items: start;
}
.opal-day-body.has-image.is-shown,
.opal-day-toggle.is-open + .opal-day-body.has-image {
	display: grid;
}
.opal-day-image {
	border-radius: var(--opal-radius-sm);
	overflow: hidden;
	box-shadow: var(--opal-shadow-sm);
	position: sticky;
	top: 80px;
}
.opal-day-image img {
	width: 100%;
	height: auto;
	display: block;
	transition: transform .5s;
}
.opal-day-image:hover img { transform: scale(1.04); }
.opal-day-text { min-width: 0; }

/* ============================================================
   ITINERARY MOBILE - bỏ layout timeline để tận dụng full width
   ============================================================ */
@media (max-width: 768px) {
	/* Bỏ đường timeline dọc */
	.opal-itinerary::before { display: none; }

	/* Day item: dùng full width, không thụt 56px */
	.opal-itinerary-day {
		padding-left: 0;
		margin-bottom: 14px;
	}

	/* Day marker: từ tròn lớn lệch trái → badge nhỏ inline ở góc trái-trên của button */
	.opal-day-marker {
		position: absolute;
		left: 12px;
		top: 50%;
		transform: translateY(-50%);
		width: 32px;
		height: 32px;
		font-size: 12px;
		border-width: 2px;
		box-shadow: 0 3px 8px rgba(255, 170, 0, 0.3);
	}

	/* Day toggle: tăng padding-left để chừa chỗ cho badge nằm trong */
	.opal-day-toggle {
		padding: 14px 44px 14px 56px;
		font-size: 14.5px;
		line-height: 1.35;
	}
	.opal-day-toggle small {
		font-size: 12px;
		margin-top: 3px;
	}
	.opal-day-toggle .opal-day-chevron {
		right: 14px;
	}

	/* Day body: padding gọn hơn, font hơi nhỏ lại nhưng line-height thoáng */
	.opal-day-body {
		padding: 16px 16px;
		font-size: 14.5px;
		line-height: 1.7;
	}
	.opal-day-body.has-image {
		grid-template-columns: 1fr;
		gap: 14px;
	}
	.opal-day-body p { margin: 0 0 10px; }

	/* Ảnh trong day body: full width, bo nhẹ */
	.opal-day-image,
	.opal-day-body img {
		position: static;
		margin: 8px 0 12px;
		border-radius: var(--opal-radius-sm);
	}
	.opal-day-image img {
		max-height: 260px;
		object-fit: cover;
	}
}

@media (max-width: 480px) {
	.opal-itinerary-day { margin-bottom: 12px; }
	.opal-day-marker {
		left: 10px;
		width: 28px;
		height: 28px;
		font-size: 11px;
	}
	.opal-day-toggle {
		padding: 12px 38px 12px 48px;
		font-size: 14px;
	}
	.opal-day-toggle small { font-size: 11.5px; }
	.opal-day-body {
		padding: 14px 14px;
		font-size: 14px;
	}
	.opal-day-image img { max-height: 220px; }
}

.opal-day-body p { margin: 0 0 12px; }
.opal-day-body p:last-child { margin: 0; }
.opal-day-body img { width: 100%; border-radius: var(--opal-radius-sm); margin: 12px 0; }
.opal-day-body strong { color: var(--opal-ink); }
.opal-day-body ul { padding-left: 20px; margin: 8px 0; }
.opal-day-body ul li { list-style: disc; margin-bottom: 4px; }

/* ============================================================
   10. INCLUDES / EXCLUDES (2 cột)
   ============================================================ */
.opal-includes-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 24px;
}
@media (max-width: 720px) {
	.opal-includes-grid { grid-template-columns: 1fr; }
}

.opal-includes-col h3 {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 17px;
	font-weight: 700;
	margin: 0 0 14px;
	color: var(--opal-ink);
}
.opal-includes-col.is-include h3 { color: var(--opal-success); }
.opal-includes-col.is-exclude h3 { color: var(--opal-danger); }

.opal-includes-list { list-style: none; padding: 0; margin: 0; }
.opal-includes-list li {
	position: relative;
	padding: 10px 0 10px 32px;
	font-size: 14.5px;
	color: var(--opal-ink-soft);
	border-bottom: 1px dashed #f0f1f3;
}
.opal-includes-list li:last-child { border-bottom: 0; }
.opal-includes-list li::before {
	position: absolute;
	left: 0;
	top: 11px;
	width: 22px;
	height: 22px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 11px;
	font-weight: 800;
}
.opal-includes-col.is-include .opal-includes-list li::before {
	content: '✓';
	background: rgba(16, 185, 129, 0.12);
	color: var(--opal-success);
}
.opal-includes-col.is-exclude .opal-includes-list li::before {
	content: '✕';
	background: rgba(239, 68, 68, 0.12);
	color: var(--opal-danger);
}

/* Phụ thu list */
.opal-surcharge-list {
	margin-top: 20px;
	padding-top: 20px;
	border-top: 1px dashed var(--opal-line);
}
.opal-surcharge-list h4 {
	font-size: 15px;
	font-weight: 700;
	color: var(--opal-warning);
	margin: 0 0 12px;
}
.opal-surcharge-row {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	padding: 8px 0;
	font-size: 14px;
	border-bottom: 1px dashed #f0f1f3;
}
.opal-surcharge-row .opal-surcharge-amount {
	font-weight: 700;
	color: var(--opal-warning);
}
.opal-surcharge-row small {
	display: block;
	color: var(--opal-muted);
	font-size: 12px;
	margin-top: 2px;
}

/* ============================================================
   11. POLICIES (Cancel / Visa / Notes)
   ============================================================ */
.opal-policy-block { margin-bottom: 24px; }
.opal-policy-block:last-child { margin-bottom: 0; }
.opal-policy-block h3 {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 17px;
	font-weight: 700;
	color: var(--opal-ink);
	margin: 0 0 12px;
}
.opal-policy-content {
	font-size: 15px;
	line-height: 1.75;
	color: var(--opal-ink-soft);
	padding: 16px 20px;
	background: #fafbfc;
	border-left: 3px solid var(--opal-accent);
	border-radius: 0 var(--opal-radius-sm) var(--opal-radius-sm) 0;
}

/* ============================================================
   12. SIDEBAR PRICING WIDGET
   ============================================================ */
.opal-sidebar { position: sticky; top: 80px; }

.opal-pricing-card {
	background: linear-gradient(180deg, #fff 0%, #fffbf2 100%);
	border-radius: var(--opal-radius-lg);
	padding: 20px 22px;
	margin-bottom: 16px;
	box-shadow: var(--opal-shadow-md);
	border: 1px solid var(--opal-accent-soft);
}

.opal-pricing-label {
	font-size: 12px;
	color: var(--opal-muted);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	font-weight: 700;
	margin-bottom: 4px;
}
.opal-pricing-from {
	font-size: 13px;
	color: var(--opal-muted);
}
.opal-price-main {
	display: flex;
	align-items: baseline;
	flex-wrap: wrap;
	gap: 6px;
	margin: 4px 0;
}
.opal-price-current {
	font-family: var(--opal-font-display);
	font-size: 28px;
	font-weight: 800;
	color: var(--opal-accent-dark);
	line-height: 1.1;
	letter-spacing: -0.02em;
}
.opal-price-orig {
	font-size: 14px;
	color: var(--opal-muted);
	text-decoration: line-through;
}
.opal-price-per { color: var(--opal-muted); font-size: 13px; }

/* Bảng giá NL/TE/EB */
.opal-price-table {
	margin-top: 16px;
	border-top: 1px dashed var(--opal-line);
	padding-top: 16px;
}
.opal-price-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 8px 0;
	font-size: 14px;
	border-bottom: 1px dashed #f0f1f3;
}
.opal-price-row:last-child { border-bottom: 0; }
.opal-price-row span:first-child { color: var(--opal-ink-soft); font-weight: 500; }
.opal-price-row span:last-child { color: var(--opal-ink); font-weight: 700; }

/* Trust badges */
.opal-trust-row {
	display: flex;
	justify-content: space-between;
	gap: 8px;
	margin-top: 16px;
	padding-top: 16px;
	border-top: 1px dashed var(--opal-line);
	font-size: 11.5px;
	color: var(--opal-muted);
	text-align: center;
}
.opal-trust-item { flex: 1; }
.opal-trust-item i {
	display: block;
	margin-bottom: 4px;
	color: var(--opal-accent);
	font-size: 16px;
}

/* CTA Booking */
.opal-cta-booking {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: 100%;
	margin-top: 18px;
	padding: 15px;
	background: linear-gradient(135deg, var(--opal-accent) 0%, var(--opal-accent-dark) 100%);
	color: #fff;
	border-radius: var(--opal-radius-md);
	font-weight: 700;
	font-size: 16px;
	text-decoration: none;
	transition: all .25s;
	box-shadow: 0 6px 20px rgba(255, 170, 0, 0.35);
	border: 0;
	cursor: pointer;
}
.opal-cta-booking:hover {
	transform: translateY(-2px);
	box-shadow: 0 10px 28px rgba(255, 170, 0, 0.45);
	color: #fff;
}

.opal-cta-secondary {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	width: 100%;
	margin-top: 10px;
	padding: 12px;
	background: #fff;
	color: var(--opal-ink);
	border: 1.5px solid var(--opal-line);
	border-radius: var(--opal-radius-md);
	font-weight: 600;
	font-size: 14px;
	text-decoration: none;
	transition: all .2s;
}
.opal-cta-secondary:hover {
	border-color: var(--opal-accent);
	color: var(--opal-accent-dark);
}

/* ============================================================
   13. DEPARTURES WIDGET (mini-calendar)
   ============================================================ */
.opal-departures-card {
	background: var(--opal-card);
	border-radius: var(--opal-radius-lg);
	padding: 20px;
	margin-bottom: 20px;
	box-shadow: var(--opal-shadow-sm);
}
.opal-departures-card h3 {
	font-size: 15px;
	font-weight: 700;
	margin: 0 0 14px;
	display: flex;
	align-items: center;
	gap: 6px;
}
.opal-dep-list { list-style: none; padding: 0; margin: 0; }
.opal-dep-item {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 12px 14px;
	background: #fafbfc;
	border-radius: var(--opal-radius-sm);
	margin-bottom: 8px;
	border: 1px solid transparent;
	transition: all .2s;
}
.opal-dep-item:hover { border-color: var(--opal-accent); background: var(--opal-accent-soft); }
.opal-dep-date {
	font-weight: 700;
	color: var(--opal-ink);
	font-size: 14px;
}
.opal-dep-date small {
	display: block;
	color: var(--opal-muted);
	font-weight: 500;
	font-size: 12px;
	margin-top: 2px;
}
.opal-dep-status {
	font-size: 11px;
	font-weight: 700;
	padding: 4px 10px;
	border-radius: 100px;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}
.opal-dep-status.is-open      { background: rgba(16,185,129,.12); color: var(--opal-success); }
.opal-dep-status.is-few_left  { background: rgba(245,158,11,.15); color: var(--opal-warning); }
.opal-dep-status.is-sold_out  { background: rgba(239,68,68,.12);  color: var(--opal-danger); }
.opal-dep-status.is-guaranteed{ background: rgba(255,170,0,.15);  color: var(--opal-accent-dark); }

/* ============================================================
   14. BANNER WIDGET (giữ tương thích contact-widget cũ)
   ============================================================ */
.opal-banner-widget {
	position: relative;
	padding: 28px 24px;
	border-radius: var(--opal-radius-lg);
	overflow: hidden;
	color: #fff;
	margin-bottom: 20px;
	background-color: #023b5e;
	background-size: cover;
	background-position: center;
}
.opal-banner-widget::before {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, rgba(2,59,94,0.85) 0%, rgba(2,59,94,0.65) 100%);
}
.opal-banner-widget > * { position: relative; z-index: 1; }
.opal-banner-widget h4 {
	font-size: 13px;
	font-weight: 600;
	color: var(--opal-accent);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	margin: 0 0 4px;
}
.opal-banner-widget h3 {
	font-family: var(--opal-font-display);
	font-size: 24px;
	font-weight: 700;
	margin: 0 0 8px;
	color: #fff;
}
.opal-banner-widget p { font-size: 14px; opacity: .9; margin: 0 0 12px; }
.opal-banner-widget .opal-phone-text { font-size: 13px; opacity: .8; }
.opal-banner-widget .opal-phone-no {
	display: inline-block;
	font-size: 22px;
	font-weight: 800;
	color: var(--opal-accent);
	text-decoration: none;
	margin-top: 6px;
	letter-spacing: 0.02em;
}

/* ============================================================
   15. RELATED TOURS
   ============================================================ */
.opal-related-card {
	background: var(--opal-card);
	border-radius: var(--opal-radius-lg);
	padding: 18px 20px;
	box-shadow: var(--opal-shadow-sm);
}
.opal-related-card h3 {
	font-size: 15px;
	font-weight: 700;
	margin: 0 0 12px;
	padding-bottom: 10px;
	border-bottom: 2px solid var(--opal-accent-soft);
}
.opal-related-item {
	display: flex;
	gap: 12px;
	padding: 10px 0;
	border-bottom: 1px dashed var(--opal-line);
	text-decoration: none;
	color: inherit;
	transition: transform .15s;
}
.opal-related-item:last-child { border-bottom: 0; padding-bottom: 0; }
.opal-related-item:hover { transform: translateX(2px); }

.opal-related-thumb {
	width: 76px;
	height: 76px;
	flex-shrink: 0;
	border-radius: var(--opal-radius-sm);
	overflow: hidden;
	background: var(--opal-accent-soft);
}
.opal-related-thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.opal-related-item:hover .opal-related-thumb img { transform: scale(1.08); }
.opal-related-content {
	flex: 1;
	min-width: 0;
}
.opal-related-content h5 {
	font-size: 13.5px;
	line-height: 1.4;
	margin: 0 0 6px;
	font-weight: 600;
	color: var(--opal-ink);
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.opal-related-item:hover .opal-related-content h5 { color: var(--opal-accent-dark); }
.opal-related-content .opal-related-price {
	color: var(--opal-accent-dark);
	font-weight: 700;
	font-size: 13px;
}

/* ============================================================
   16. FAQ ACCORDION
   ============================================================ */
.opal-faq-list { display: flex; flex-direction: column; gap: 8px; }
.opal-faq-item {
	background: #fafbfc;
	border: 1px solid var(--opal-line);
	border-radius: var(--opal-radius-md);
	overflow: hidden;
	transition: all .2s;
}
.opal-faq-item.is-open {
	border-color: var(--opal-accent);
	background: #fff;
}
.opal-faq-q {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 16px 20px;
	cursor: pointer;
	font-weight: 600;
	color: var(--opal-ink);
	font-size: 15px;
}
.opal-faq-q .opal-faq-toggle {
	width: 24px;
	height: 24px;
	border-radius: 50%;
	background: var(--opal-accent-soft);
	color: var(--opal-accent-dark);
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 700;
	font-size: 16px;
	flex-shrink: 0;
	transition: transform .25s;
}
.opal-faq-item.is-open .opal-faq-toggle { transform: rotate(45deg); }
.opal-faq-a {
	display: none;
	padding: 0 20px 18px;
	font-size: 14.5px;
	color: var(--opal-ink-soft);
	line-height: 1.7;
}
.opal-faq-item.is-open .opal-faq-a { display: block; }

/* ============================================================
   17. ENQUIRY FORM (CF7) - COLLAPSIBLE
   ============================================================ */

/* Khi collapsed: ẩn section-head mặc định + form body, chỉ hiện trigger */
.opal-enquiry-collapsed.opal-section {
	padding: 0 !important;
	overflow: hidden;
	background: transparent;
	box-shadow: none;
}
.opal-enquiry-collapsed.opal-section.is-open {
	background: var(--opal-card);
	box-shadow: var(--opal-shadow-sm);
}

/* TRIGGER button: card lớn gradient, click để mở */
.opal-enquiry-trigger {
	display: flex;
	align-items: center;
	gap: 18px;
	width: 100%;
	padding: 22px 28px;
	background: linear-gradient(135deg, #fff8e7 0%, #fff 60%, var(--opal-accent-soft) 100%);
	border: 2px solid var(--opal-accent-soft);
	border-radius: var(--opal-radius-lg);
	cursor: pointer;
	font-family: inherit;
	text-align: left;
	transition: all .25s ease;
	color: var(--opal-ink);
	box-shadow: var(--opal-shadow-sm);
}
.opal-enquiry-trigger:hover {
	transform: translateY(-2px);
	border-color: var(--opal-accent);
	box-shadow: 0 12px 28px rgba(255, 170, 0, 0.18);
}
.opal-enquiry-collapsed.is-open .opal-enquiry-trigger {
	border-radius: var(--opal-radius-lg) var(--opal-radius-lg) 0 0;
	border-bottom-color: var(--opal-accent-soft);
	background: linear-gradient(135deg, var(--opal-accent-soft) 0%, #fff8e7 100%);
}

.opal-et-icon {
	flex-shrink: 0;
	width: 56px;
	height: 56px;
	background: linear-gradient(135deg, var(--opal-accent) 0%, var(--opal-accent-dark) 100%);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 26px;
	box-shadow: 0 6px 16px rgba(255, 170, 0, 0.35);
}

.opal-et-text {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 2px;
}
.opal-et-text strong {
	font-family: var(--opal-font-display);
	font-size: 18px;
	font-weight: 800;
	color: var(--opal-ink);
	letter-spacing: -0.01em;
	line-height: 1.3;
}
.opal-et-text span {
	font-size: 13.5px;
	color: var(--opal-ink-soft);
	font-weight: 500;
}

.opal-et-arrow {
	flex-shrink: 0;
	width: 38px;
	height: 38px;
	background: #fff;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--opal-accent-dark);
	transition: transform .3s ease;
	box-shadow: 0 2px 6px rgba(0,0,0,.06);
}
.opal-enquiry-collapsed.is-open .opal-et-arrow {
	transform: rotate(180deg);
}

/* BODY: ẩn mặc định, slide xuống */
.opal-enquiry-body {
	max-height: 0;
	overflow: hidden;
	transition: max-height .4s cubic-bezier(.4,0,.2,1);
}
.opal-enquiry-collapsed.is-open .opal-enquiry-body {
	max-height: 2000px; /* đủ để fit form lớn */
	transition: max-height .6s cubic-bezier(.4,0,.2,1);
}

.opal-enquiry-body-inner {
	padding: 24px 28px 28px;
	border-top: 1px dashed var(--opal-line);
}

/* Form head trong body collapsible (khác opal-section-head bên ngoài) */
.opal-enquiry-form-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 18px;
	padding-bottom: 14px;
	border-bottom: 2px solid var(--opal-accent-soft);
}
.opal-enquiry-form-head h2 {
	font-family: var(--opal-font-display);
	font-size: 18px;
	font-weight: 800;
	margin: 0;
	color: var(--opal-ink);
}

.opal-enquiry-close {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 6px 12px;
	background: transparent;
	border: 1px solid var(--opal-line);
	border-radius: 100px;
	font-size: 12.5px;
	font-weight: 600;
	color: var(--opal-muted);
	cursor: pointer;
	transition: all .2s;
	font-family: inherit;
}
.opal-enquiry-close:hover {
	background: var(--opal-line);
	color: var(--opal-ink);
}

/* CF7 form root: grid 2 cột full width */
.opal-enquiry-wrap .wpcf7-form {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 12px 18px;
	max-width: 100%;
	margin: 0;
}

.opal-enquiry-wrap .wpcf7-form > p {
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.opal-enquiry-wrap .wpcf7-form > p:has(textarea),
.opal-enquiry-wrap .wpcf7-form > p:has(input[type="submit"]),
.opal-enquiry-wrap .wpcf7-form > p:has(input[name*="tour"]),
.opal-enquiry-wrap .wpcf7-form > p:has(input[name*="message"]),
.opal-enquiry-wrap .wpcf7-form > p:has(input[name*="detail"]) {
	grid-column: 1 / -1;
}

.opal-enquiry-wrap .wpcf7-form > p > label,
.opal-enquiry-wrap .wpcf7-form label {
	display: block;
	font-size: 13px;
	font-weight: 600;
	color: var(--opal-ink);
	margin-bottom: 4px;
	letter-spacing: 0.01em;
}

.opal-enquiry-wrap .wpcf7-form-control:not([type="submit"]):not([type="checkbox"]):not([type="radio"]) {
	width: 100%;
	padding: 10px 14px;
	border: 1.5px solid var(--opal-line);
	border-radius: var(--opal-radius-sm);
	font-size: 14px;
	font-family: inherit;
	background: #fff;
	color: var(--opal-ink);
	transition: all .2s;
	box-sizing: border-box;
	min-height: 42px;
}
.opal-enquiry-wrap .wpcf7-form-control::placeholder {
	color: #aab1bc;
	font-weight: 400;
}
.opal-enquiry-wrap .wpcf7-form-control:focus {
	border-color: var(--opal-accent);
	background: #fff;
	outline: none;
	box-shadow: 0 0 0 3px var(--opal-accent-soft);
}

.opal-enquiry-wrap textarea.wpcf7-form-control {
	min-height: 90px;
	resize: vertical;
	line-height: 1.6;
}

.opal-enquiry-wrap input[readonly],
.opal-enquiry-wrap input[name*="tour"][type="text"]:not([name*="tour-name"]) {
	background: linear-gradient(90deg, var(--opal-accent-soft) 0%, #fff8f0 100%) !important;
	border-color: var(--opal-accent-soft) !important;
	font-weight: 600;
	color: var(--opal-accent-dark);
	cursor: default;
}

.opal-enquiry-wrap .wpcf7-submit {
	background: linear-gradient(135deg, var(--opal-accent) 0%, var(--opal-accent-dark) 100%) !important;
	color: #fff !important;
	border: 0 !important;
	padding: 13px 28px !important;
	border-radius: var(--opal-radius-md) !important;
	font-weight: 700 !important;
	font-size: 15px !important;
	cursor: pointer;
	transition: all .25s !important;
	width: 100%;
	letter-spacing: 0.02em;
	min-height: 48px;
	box-shadow: 0 4px 14px rgba(255, 170, 0, 0.25);
	margin-top: 4px;
}
.opal-enquiry-wrap .wpcf7-submit:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 20px rgba(255, 170, 0, 0.4);
}
.opal-enquiry-wrap .wpcf7-submit:active {
	transform: translateY(0);
}

.opal-enquiry-wrap .wpcf7-spinner {
	margin: 0 0 0 10px;
	vertical-align: middle;
}
.opal-enquiry-wrap .wpcf7-response-output {
	grid-column: 1 / -1;
	margin: 12px 0 0 !important;
	padding: 12px 16px !important;
	border-radius: var(--opal-radius-sm) !important;
	font-size: 13.5px !important;
	border-width: 1.5px !important;
}
.opal-enquiry-wrap .wpcf7 form.sent .wpcf7-response-output {
	border-color: var(--opal-success) !important;
	background: rgba(16, 185, 129, 0.08);
	color: var(--opal-success);
}
.opal-enquiry-wrap .wpcf7 form.invalid .wpcf7-response-output {
	border-color: var(--opal-danger) !important;
	background: rgba(239, 68, 68, 0.08);
	color: var(--opal-danger);
}

.opal-enquiry-wrap .wpcf7-not-valid-tip {
	font-size: 12px !important;
	margin-top: 4px !important;
	color: var(--opal-danger) !important;
}

.opal-enquiry-wrap .wpcf7-list-item {
	margin: 0 16px 0 0 !important;
	display: inline-flex;
	align-items: center;
	gap: 6px;
}
.opal-enquiry-wrap .wpcf7-list-item-label {
	font-size: 13px;
	color: var(--opal-ink-soft);
}

@media (max-width: 900px) {
	.opal-enquiry-wrap .wpcf7-form { gap: 10px 14px; }
}

@media (max-width: 640px) {
	.opal-enquiry-trigger {
		padding: 18px 18px;
		gap: 14px;
	}
	.opal-et-icon {
		width: 46px; height: 46px; font-size: 22px;
	}
	.opal-et-text strong { font-size: 16px; }
	.opal-et-text span { font-size: 12.5px; }
	.opal-et-arrow { width: 32px; height: 32px; }

	.opal-enquiry-body-inner { padding: 20px 18px 22px; }
	.opal-enquiry-form-head h2 { font-size: 16px; }

	.opal-enquiry-wrap .wpcf7-form {
		grid-template-columns: 1fr;
		gap: 10px;
	}
}

/* ============================================================
   18. ANIMATIONS - Page Load Stagger
   ============================================================ */
@keyframes opalFadeUp {
	from { opacity: 0; transform: translateY(16px); }
	to   { opacity: 1; transform: translateY(0); }
}
.opal-animate-in { animation: opalFadeUp .6s cubic-bezier(.2,.8,.2,1) both; }
.opal-section.opal-animate-in:nth-child(1) { animation-delay: .05s; }
.opal-section.opal-animate-in:nth-child(2) { animation-delay: .15s; }
.opal-section.opal-animate-in:nth-child(3) { animation-delay: .25s; }
.opal-section.opal-animate-in:nth-child(4) { animation-delay: .35s; }
.opal-section.opal-animate-in:nth-child(5) { animation-delay: .45s; }

/* ============================================================
   19. MOBILE STICKY BOOKING BAR
   ============================================================ */
.opal-mobile-booking-bar {
	display: none;
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: 100;
	background: #fff;
	border-top: 1px solid var(--opal-line);
	padding: 8px 12px;
	padding-bottom: calc(8px + env(safe-area-inset-bottom, 0px));
	box-shadow: 0 -8px 24px rgba(15, 23, 42, 0.08);
	align-items: center;
	gap: 10px;
}
.opal-mobile-booking-bar .opal-mb-price {
	flex: 1 1 auto;
	min-width: 0;
	display: flex !important;
	flex-direction: column;
	justify-content: center;
}
.opal-mobile-booking-bar .opal-mb-price-amount {
	font-family: var(--opal-font-display);
	font-size: 17px;
	font-weight: 800;
	color: var(--opal-accent-dark);
	line-height: 1.15;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	letter-spacing: -0.01em;
}
.opal-mobile-booking-bar .opal-mb-price-label {
	font-size: 10.5px;
	color: var(--opal-muted);
	display: block;
	margin-top: 2px;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	font-weight: 600;
}

/* Override .opal-cta-booking khi nó nằm trong mobile bar */
.opal-mobile-booking-bar .opal-mb-cta,
.opal-mobile-booking-bar .opal-cta-booking.opal-mb-cta {
	margin: 0 !important;
	flex: 0 0 auto !important;
	width: auto !important;
	padding: 11px 22px !important;
	font-size: 14px !important;
	min-height: 44px !important;
	min-width: 130px !important;
	max-width: 50vw !important;
	gap: 4px !important;
	box-shadow: 0 4px 12px rgba(255, 170, 0, 0.3) !important;
	white-space: nowrap;
}

@media (max-width: 1024px) {
	.opal-mobile-booking-bar { display: flex; }
	.opal-tour-wrap { padding-bottom: 80px; }
}

@media (max-width: 768px) {
	.opal-section { padding: 18px 16px; }
	.opal-section-head h2 { font-size: 19px; }
	.opal-tour-meta { gap: 10px 14px; padding-bottom: 16px; margin-bottom: 16px; }
	.opal-tour-meta-item { font-size: 13px; gap: 6px; }
	.opal-tabs-nav { padding: 8px 0; }
	.opal-tabs-nav-inner { padding: 0 14px; }
	.opal-tab-link { padding: 8px 12px; font-size: 12.5px; gap: 4px; }
	.opal-overview-text { font-size: 15px; }
	.opal-overview-lead { font-size: 14.5px; padding: 14px 16px; }
}

@media (max-width: 480px) {
	.opal-tour-title { font-size: 22px; line-height: 1.25; }
	.opal-mobile-booking-bar { padding: 7px 10px; padding-bottom: calc(7px + env(safe-area-inset-bottom, 0px)); gap: 8px; }
	.opal-mobile-booking-bar .opal-mb-price-amount { font-size: 15.5px; }
	.opal-mobile-booking-bar .opal-mb-price-label { font-size: 9.5px; }
	.opal-mobile-booking-bar .opal-mb-cta {
		padding: 10px 16px !important;
		min-width: 100px !important;
		max-width: 45vw !important;
		font-size: 13px !important;
	}
}

/* ============================================================
   20. PRINT
   ============================================================ */
@media print {
	.opal-sidebar, .opal-tabs-nav, .opal-mobile-booking-bar, .opal-cta-booking { display: none !important; }
	.opal-tour-layout { grid-template-columns: 1fr; }
	.opal-section { box-shadow: none; border: 1px solid #ddd; break-inside: avoid; }
}
