/*
Theme Name: Lucy Tours
Theme URI: https://lucyethiopiatours.com
Author: Lucy Ethiopia Tours
Description: Standalone, high-performance tour operator theme.
Version: 1.0.4
Requires at least: 6.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: lucy-tours
*/
:root {
    /* Brand — one value, used everywhere */
    --primary:        #6a994e;
    --primary-dark:   #2D6A4F;
    --primary-darker: #1B4332;
    --primary-light:  #74C69D;
    --primary-tint:   #E8F3EC;

    /* Semantic */
    --secondary:      #f39c12;
    --accent:         #F4A261;
    --success:        #00AA6C;   /* primary action conversion color */
    --danger:         #EF4444;

    /* Text */
    --text:           #1A1A1A;
    --text-light:     #6B7280;
    --text-muted:     #9CA3AF;

    /* Surface & border */
    --border:         #E5E7EB;
    --bg-light:       #F9FAFB;
    --white:          #FFFFFF;
    --cream:          #FAF7F0;
    --sand:           #F0E9D6;

    /* Elevation */
    --shadow-card:    0 1px 4px rgba(0,0,0,0.08), 0 4px 12px rgba(0,0,0,0.06);
    --shadow-hover:   0 4px 16px rgba(0,0,0,0.12);
    --lucy-shadow-sm: 0 2px 8px rgba(25, 24, 21, 0.04);
    --lucy-shadow-md: 0 8px 24px rgba(25, 24, 21, 0.06);
    --lucy-shadow-lg: 0 16px 40px rgba(25, 24, 21, 0.08);

    /* Typography scale — 5 sizes, nothing else */
    --t-xs:   12px;
    --t-sm:   14px;
    --t-base: 16px;
    --t-lg:   20px;
    --t-xl:   40px;

    /* Spacing — base-8 */
    --s-1:  4px;
    --s-2:  8px;
    --s-3:  16px;
    --s-4:  24px;
    --s-5:  32px;
    --s-6:  48px;
    --s-7:  64px;

    /* Radius */
    --r-card:  8px;
    --r-badge: 4px;
    --r-pill:  999px;
    --r-lg:    16px;

    /* Aliases for compatibility */
    --brand-green: var(--primary);
    --brand-green-light: var(--primary-tint);
    --text-primary: var(--text);
    --text-secondary: var(--text-light);
    --border-default: var(--border);
    --surface-default: var(--white);
    --surface-subtle: var(--bg-light);
    --text-xs: var(--t-xs);
    --text-sm: var(--t-sm);
    --text-base: var(--t-base);
    --text-lg: var(--t-lg);
    --text-xl: var(--t-xl);
    --card-shadow: var(--shadow-card);
    --card-shadow-hover: var(--shadow-hover);
    --color-white: #ffffff;
    --color-primary: var(--primary);
    --color-text-primary: var(--text);
    --shadow-nav: 0 10px 30px rgba(0, 0, 0, 0.08);
    --radius-full: 9999px;
    --dur-base: 0.25s;
    --ease-out: cubic-bezier(0.25, 0.46, 0.45, 0.94);
    --font-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --font-display: 'Rector', serif;
    --text-6xl: 60px;
    --text-5xl: 52px;
    --text-4xl: 36px;
    --text-xl: 20px;
    --text-sm: 14px;
    --color-star: #ffb800;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; font-size: 16px; }
body { font-family: var(--font-sans); font-size: var(--text-base); font-weight: 400; color: var(--text-primary); background: var(--surface-default); line-height: 1.7; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; overflow-x: hidden; }
h1, h3, h4 { font-family: var(--font-display); }
h2 {
    font-family: var(--font-display), 'Rector', serif;
    font-style: normal;
    font-weight: 500;
    color: rgb(25, 24, 21);
    font-size: 52px;
    line-height: 60px;
}
/* Ensure mobile screens scale down h2 gracefully */
@media (max-width: 768px) {
    h2 { font-size: 36px; line-height: 44px; }
}
img { max-width: 100%; height: auto; }
.skip-link { position: absolute; left: -9999px; }

/* HEADER */
.site-header { background: rgba(255,255,255,0.95); border-bottom: none; position: sticky; top: 0; z-index: 100; box-shadow: 0 2px 12px rgba(0,0,0,0.08); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); }
.site-header .wrap { display: flex; align-items: center; justify-content: space-between; gap: 16px; height: 72px; padding-top: 0; padding-bottom: 0; }
.site-branding { display: flex; align-items: center; height: 100%; }
.site-branding img, .site-logo-img img { display: block; width: 140px; max-height: 60px; height: auto; }
.site-logo-img { display: flex; align-items: center; }
.site-branding .site-title { margin: 0; font-size: 1.4rem; font-weight: 800; }
.site-branding .site-title a { color: var(--text-primary); text-decoration: none; }
.main-nav { margin-left: auto; display: flex; align-items: center; height: 100%; }
.main-menu { display: flex; align-items: center; list-style: none; gap: 0; margin: 0; padding: 0; height: 100%; }
.main-menu > li { position: relative; display: flex; align-items: center; height: 100%; }
.main-menu a { display: inline-flex; align-items: center; gap: 4px; color: var(--text-primary); text-decoration: none; font-size: 15px; font-weight: 500; padding: 0 16px; min-height: 44px; transition: color .2s; white-space: nowrap; }
.main-menu a:hover { color: var(--brand-green); }
.main-menu .current-menu-item > a, .main-menu .current_page_item > a, .main-menu .current-menu-parent > a { color: var(--brand-green); font-weight: 600; }
/* Force highlight active state on tours archive page or single tour pages */
body.post-type-archive-product .main-menu li[class*="product"] > a,
body.tax-tour_phys .main-menu li[class*="product"] > a,
body.single-product .main-menu li[class*="product"] > a,
body.post-type-archive-product .main-menu li[class*="tours"] > a,
body.tax-tour_phys .main-menu li[class*="tours"] > a,
body.single-product .main-menu li[class*="tours"] > a {
	color: var(--brand-green) !important;
	font-weight: 600 !important;
}
@media (min-width: 1025px) {
  .main-menu .menu-item-has-children > a::after, .main-menu li:has(> ul) > a::after { content: ""; display: inline-block; width: 5px; height: 5px; border-right: 1.5px solid currentColor; border-bottom: 1.5px solid currentColor; transform: rotate(45deg); margin-left: 7px; vertical-align: middle; position: relative; top: -1px; opacity: 0.8; transition: transform 0.2s ease, border-color 0.2s ease; }
  .main-menu li ul { position: absolute; top: 100%; left: 0; min-width: 220px; background: var(--surface-default); border: 1px solid var(--border-default); border-radius: 8px; box-shadow: 0 14px 34px rgba(0,0,0,.12); padding: 8px 0; margin: 0; list-style: none; opacity: 0; visibility: hidden; transform: translateY(8px); transition: opacity .2s, transform .2s, visibility .2s; z-index: 50; }
  .main-menu li:hover > ul, .main-menu li:focus-within > ul { opacity: 1; visibility: visible; transform: translateY(0); }
  .main-menu li ul li { width: 100%; position: relative; }
  .main-menu li ul a { display: block; padding: 8px 16px; font-weight: 400; font-size: 14px; }
  .main-menu li ul a:hover { background: var(--surface-subtle); color: var(--brand-green); }
  .main-menu li ul ul { top: 0; left: 100%; }
}
.header-cta { margin-left: 16px; display: flex; align-items: center; }
.btn--header-quote { background: #6a994e !important; color: #fff !important; border-radius: 8px !important; padding: 12px 24px !important; font-size: 15px !important; font-weight: 600 !important; height: auto !important; display: inline-flex !important; align-items: center !important; }
.btn--header-quote:hover { background: #5a8443 !important; }
.nav-toggle { display: none; flex-direction: column; justify-content: center; gap: 5px; width: 42px; height: 42px; flex-shrink: 0; background: none; border: 1px solid var(--border-default); border-radius: 8px; cursor: pointer; }
.nav-toggle span { display: block; width: 22px; height: 2px; background: var(--text-primary); margin: 0 auto; transition: transform .3s, opacity .3s; }
.nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* BUTTONS */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; font-family: inherit; font-weight: 600; font-size: var(--text-sm); line-height: 1.5; border-radius: 8px; padding: 8px 16px; border: 1.5px solid transparent; cursor: pointer; text-decoration: none; transition: all .2s ease; background: var(--brand-green); color: #fff; }
.btn:hover { background: var(--primary-dark); }
.btn--ghost { background: transparent; color: var(--primary); border-color: var(--primary); }
.btn--ghost:hover { background: var(--primary); color: #fff; }
.btn--wide { width: 100%; margin-top: 1rem; }
.btn--wa { background: #25d366; color: #fff; border-color: #25d366; }
.btn--wa:hover { background: #1da851; border-color: #1da851; }

/* FOOTER REDESIGN MOCKUP */
.site-footer {
	background: #1A1A1A !important;
	color: #999999 !important;
	border-top: none !important;
	font-family: 'Inter', sans-serif;
}
.footer-top {
	padding: 5rem 0 !important;
}
.footer-grid {
	display: grid;
	grid-template-columns: 1.5fr 1fr 1fr 1fr 1.8fr;
	gap: 3rem;
	align-items: start;
}
.footer-col h4 {
	font-family: 'Inter', sans-serif;
	font-size: 0.95rem;
	font-weight: 700;
	color: #FFFFFF !important;
	margin: 0 0 1.5rem 0 !important;
	text-transform: none;
	letter-spacing: normal;
	border-bottom: none !important;
	padding-bottom: 0 !important;
}
/* Divider borders for Column 1 and Column 5 */
.footer-col--contact-info {
	border-right: 1px solid #333333;
	padding-right: 3rem;
}
.footer-col--partners-payments {
	border-left: 1px solid #333333;
	padding-left: 3rem;
}

/* Column 1 Contact items */
.footer-contact-item {
	display: flex;
	align-items: flex-start;
	gap: 0.8rem;
	margin-bottom: 1.2rem;
	color: #CCCCCC;
}
.footer-contact-icon {
	color: #FFFFFF !important;
	margin-top: 3px;
	flex-shrink: 0;
}
.footer-contact-item a {
	color: #CCCCCC;
	text-decoration: none;
	font-size: 0.9rem;
	transition: color 0.2s;
}
.footer-contact-item a:hover {
	color: var(--primary);
}
.footer-contact-sublist {
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
}
.footer-address {
	font-style: normal;
	font-size: 0.9rem;
	color: #CCCCCC;
	line-height: 1.6;
	margin: 0;
	white-space: pre-line;
}

/* Social circles */
.footer-social-row {
	display: flex;
	gap: 0.75rem;
	margin-top: 1.5rem;
}
.social-circle-link {
	width: 32px;
	height: 32px;
	border-radius: 50%;
	border: 1.5px solid #FFFFFF;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: #FFFFFF !important;
	transition: background 0.2s, border-color 0.2s;
}
.social-circle-link:hover {
	background: #FFFFFF;
	color: #1A1A1A !important;
}
.social-circle-link--tripadvisor:hover {
	background: #34E0A1 !important;
	border-color: #34E0A1 !important;
	color: #000000 !important;
}

/* Link list */
.footer-link-list {
	list-style: none;
	margin: 0;
	padding: 0;
}
.footer-link-list li {
	margin-bottom: 0.8rem;
}
.footer-link-list a {
	color: #CCCCCC !important;
	text-decoration: none;
	font-size: 0.9rem;
	transition: color 0.2s;
}
.footer-link-list a:hover {
	color: var(--primary) !important;
}

/* Column 5: Partners Row */
.trusted-partners-row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 1.5rem;
	margin-bottom: 2rem;
}
.trusted-partner-img-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 22px; /* Uniform height */
	width: auto;
	background: transparent !important;
	border-radius: 0 !important;
	padding: 0 !important;
	box-shadow: none !important;
	overflow: visible !important;
	transition: transform 0.2s, filter 0.2s, opacity 0.2s;
	cursor: pointer;
	filter: brightness(0) invert(1);
	opacity: 0.5;
}
.trusted-partner-img-link:hover {
	transform: translateY(-2px);
	filter: brightness(0) invert(1);
	opacity: 1;
}
.trusted-partner-img-link img {
	height: 100% !important;
	width: auto !important;
	max-width: 120px !important;
	object-fit: contain !important;
}
.trusted-partner-badge {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	overflow: hidden;
}
.ta-badge-circular {
	background: #E8F5EE !important; /* TripAdvisor Light green tint background */
	color: #004F32 !important; /* TripAdvisor Dark green brand color */
	display: flex;
	flex-direction: column;
	font-size: 5px;
	font-weight: 800;
	text-transform: uppercase;
}
.ta-badge-circular svg {
	width: 20px;
	height: 20px;
	fill: #004F32 !important;
}
.ta-badge-circular .ta-logo-text {
	display: none !important;
}
.ta-badge-inner-label {
	margin-top: -1px;
	color: #004F32 !important;
}
.kayak-badge-full {
	display: inline-flex;
	gap: 1.5px;
	background: transparent !important;
	cursor: pointer;
	align-items: center;
	transition: transform 0.2s, opacity 0.2s;
	opacity: 0.65;
}
.kayak-badge-full:hover {
	transform: translateY(-2px);
	opacity: 1;
}
.kayak-badge-full .kayak-letter {
	background: #FF690F !important;
	color: #FFFFFF !important;
	font-family: 'Montserrat', sans-serif;
	font-weight: 800;
	font-size: 0.85rem;
	width: 22px;
	height: 22px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 1px;
}
.green-earth-badge {
	background: #E8F5EE;
}
.certificate-badge {
	background: #2B2B2B;
}

/* Payment Methods Grid */
.payment-title {
	margin-top: 1.5rem !important;
	margin-bottom: 1rem !important;
}
.payment-methods-grid {
	display: flex;
	gap: 0.6rem;
}
.payment-card-badge {
	background: #FFFFFF;
	border-radius: 4px;
	width: 50px;
	height: 32px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 4px;
	box-shadow: 0 1px 3px rgba(0,0,0,0.1);
}
.payment-card-badge img {
	max-height: 100%;
	max-width: 100%;
	object-fit: contain;
}

/* Footer Bottom (Copyright) */
.footer-bottom {
	border-top: 1px solid #333333 !important;
	background: #1A1A1A !important;
	padding: 2rem 0 !important;
}
.footer-bottom__inner {
	justify-content: center;
	text-align: center;
}
.footer-copyright {
	font-size: 0.85rem;
	color: #999999 !important;
	margin: 0;
	width: 100%;
}


/* PARTNERS */
.partners {
	background: #FFFFFF !important;
	border-top: 1px solid var(--border);
	padding: 3.5rem 0 !important;
}
.partners__head {
	text-align: center;
	margin-bottom: 2rem;
}
.partners__badge {
	display: inline-block;
	background: var(--primary);
	color: #fff;
	font-size: .85rem;
	font-weight: 700;
	letter-spacing: .02em;
	padding: .5rem 1.4rem;
	border-radius: 999px;
}
.partners__grid {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 4rem;
}
.partners__grid a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: transform 0.25s;
}
.partners__grid a:hover {
	transform: translateY(-2px);
}
.partners__grid img {
	height: 44px;
	width: auto;
	max-width: 170px;
	object-fit: contain;
	filter: grayscale(1);
	opacity: 0.5;
	transition: filter .25s, opacity .25s;
}
.partners__grid a:hover img {
	filter: grayscale(0);
	opacity: 1;
}

/* ============================================================
   SINGLE TOUR PAGE
   ============================================================ */
.wrap { max-width: 1200px; margin: 0 auto; padding: 0 24px; }
.tour-page-wrapper { padding-bottom: 0; }
body.single-product .tour-page-wrapper {
    padding-top: 130px !important;
}
nav.wak-breadcrumbs { margin: 1.25rem 0 0; padding: 0 !important; font-size: .82rem; color: #7A7A7A !important; font-family: 'Figtree', sans-serif !important; display: flex !important; align-items: center !important; gap: 6px !important; flex-wrap: wrap !important; }
nav.wak-breadcrumbs .wak-breadcrumb-link { color: #7A7A7A !important; text-decoration: none !important; font-family: 'Figtree', sans-serif !important; font-size: .82rem !important; font-weight: 500 !important; }
nav.wak-breadcrumbs .wak-breadcrumb-link:hover { color: #6a994e !important; }
nav.wak-breadcrumbs span.wak-breadcrumb-link { color: #A09E97 !important; }
nav.wak-breadcrumbs .wak-add-seperator { background: none !important; height: auto !important; width: auto !important; opacity: 1 !important; display: inline-block !important; }
nav.wak-breadcrumbs .wak-add-seperator::after { content: ">" !important; color: #A09E97 !important; font-size: 12px !important; font-family: 'Figtree', sans-serif !important; font-weight: 500 !important; }
.tour-header { display: flex; justify-content: space-between; align-items: flex-start; gap: 2rem; margin: 1rem 0 1.5rem; }
.tour-title { font-family: 'Rector', serif; font-size: 1.95rem; font-weight: 500; line-height: 1.3; margin: 0 0 .6rem; color: #191815; }
.tour-meta-row { display: flex; align-items: center; gap: .6rem; flex-wrap: wrap; font-size: .92rem; color: #4A4A4A; font-family: 'Figtree', sans-serif; }
.tour-rating { display: inline-flex; align-items: center; gap: .35rem; }
.tour-rating__stars { color: #F4B942; font-size: 1.05rem; line-height: 1; }
.tour-rating__val { font-weight: 700; color: #191815; }
.tour-meta-sep { color: #E4E0D8; }
.tour-meta-cat { color: #6a994e; text-decoration: none; font-weight: 600; }
.tour-header__actions { display: flex; gap: .5rem; flex-shrink: 0; }
.tour-action-btn { display: inline-flex; align-items: center; gap: .4rem; background: none; border: none; padding: .4rem .65rem; font-family: 'Figtree', sans-serif; font-size: .88rem; color: #7A7A7A; cursor: pointer; border-radius: 999px; transition: color .2s, background .2s; }
.tour-action-btn:hover { color: #6a994e; background: #FAF7F0; }
.tour-action-btn.is-saved { color: #6a994e; }
.tour-action-btn.is-saved svg { fill: #6a994e !important; }
.tour-gallery-wrapper { margin: 0 0 1.75rem; position: relative; }
.tour-gallery { display: grid; gap: .55rem; height: 440px; grid-template-columns: 2fr 1fr; grid-template-rows: 1fr 1fr; }
.tour-gallery__item { display: block; overflow: hidden; border-radius: 16px; }
.tour-gallery__item img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; display: block; }
.tour-gallery__item:hover img { transform: scale(1.05); }
.tour-gallery--1 { grid-template-columns: 1fr; grid-template-rows: 1fr; }
.tour-gallery--2 { grid-template-columns: 1fr 1fr; grid-template-rows: 1fr; }
.tour-gallery--5 { grid-template-columns: 2fr 1fr 1fr; }
.tour-gallery--4 { grid-template-columns: 2fr 1fr 1fr; }
.tour-gallery--3 .tour-gallery__item:first-child, .tour-gallery--5 .tour-gallery__item:first-child { grid-row: 1 / span 2; }
.tour-gallery--4 .tour-gallery__item:nth-child(1) { grid-row: 1 / span 2; grid-column: 1; }
.tour-gallery--4 .tour-gallery__item:nth-child(2) { grid-column: 2 / span 2; grid-row: 1; }
.tour-gallery--4 .tour-gallery__item:nth-child(3) { grid-column: 2; grid-row: 2; }
.tour-gallery--4 .tour-gallery__item:nth-child(4) { grid-column: 3; grid-row: 2; }
.tour-gallery-btn { position: absolute; top: 50%; transform: translateY(-50%); width: 42px; height: 42px; background: rgba(0,0,0,.5); border: none; border-radius: 50%; color: #fff; cursor: pointer; display: none; align-items: center; justify-content: center; z-index: 10; }
.tour-gallery-btn.prev { left: .75rem; }
.tour-gallery-btn.next { right: .75rem; }
.tour-gallery-dots { position: absolute; bottom: .9rem; left: 50%; transform: translateX(-50%); display: none; gap: .4rem; z-index: 10; }
.dot { width: 8px; height: 8px; border-radius: 50%; background: rgba(255,255,255,.55); }
.dot.active { background: #fff; }
.tour-sub-nav { position: sticky; top: 70px; background: var(--white); border-bottom: 1px solid #E4E0D8; margin-bottom: 1.5rem; z-index: 40; }
.tour-sub-nav .wrap { padding: 0 2rem; }
.tour-sub-nav ul { display: flex; list-style: none; margin: 0; padding: 0; overflow-x: auto; scrollbar-width: none; }
.tour-sub-nav ul::-webkit-scrollbar { display: none; }
.tour-sub-nav a { display: block; padding: .95rem 0; margin-right: 1.75rem; color: #7A7A7A; text-decoration: none; font-weight: 600; font-size: .92rem; border-bottom: 2px solid transparent; white-space: nowrap; transition: color .2s, border-color .2s; font-family: 'Figtree', sans-serif; }
.tour-sub-nav a:hover { color: #6a994e; }
.tour-sub-nav a.active { color: #6a994e; border-bottom-color: #6a994e; }
.tour-infoline { display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; padding-bottom: 1.5rem; margin-bottom: 1.75rem; border-bottom: 1px solid #E4E0D8; }
.tour-infoline__facts { display: flex; align-items: center; gap: 2rem; flex-wrap: wrap; }
.tour-infoline__item { display: inline-flex; align-items: center; gap: .5rem; font-size: .92rem; color: #4A4A4A; font-family: 'Figtree', sans-serif; }
.tour-infoline__item svg, .tour-infoline__item .ico { color: #6a994e; flex-shrink: 0; }
.tour-infoline__item strong { color: #191815; font-weight: 600; }
.tour-pdf-btn { display: inline-flex; align-items: center; gap: .45rem; border: 1px solid #E4E0D8; color: #191815; padding: .55rem 1.1rem; border-radius: 999px; text-decoration: none; font-weight: 600; font-size: .88rem; transition: all .2s; font-family: 'Figtree', sans-serif; }
.tour-pdf-btn:hover { border-color: #6a994e; color: #6a994e; background-color: #FAF7F0; }
.tour-layout { display: grid; grid-template-columns: 1fr 360px; gap: 3rem; align-items: start; margin-bottom: 3rem; }
.tour-main { min-width: 0; }
.tour-sidebar { position: sticky; top: 90px; }
.tour-section { margin-bottom: 2.5rem; padding-bottom: 2.5rem; border-bottom: 1px solid #E4E0D8; scroll-margin-top: 140px; }
.tour-section:last-child { border-bottom: none; }
.tour-section > h2 { font-family: 'Rector', serif; font-size: 1.45rem; font-weight: 500; margin: 0 0 1.25rem; color: #191815; }
.tour-description-content { line-height: 1.8; color: #4A4A4A; font-family: 'Figtree', sans-serif; }
.tour-description-content p { margin-bottom: 1rem; }
.tour-description-content a { color: #6a994e; }
.itinerary-timeline { position: relative; }
.itinerary-day { position: relative; padding-left: 2rem; }
.itinerary-day::before { content: ""; position: absolute; left: 7px; top: 1.6rem; bottom: 0; width: 2px; background: #E4E0D8; }
.itinerary-day:last-child::before { display: none; }
.itinerary-day-marker { position: absolute; left: 0; top: 1.25rem; width: 16px; height: 16px; border-radius: 50%; border: 2px solid #6a994e; background: var(--white); box-sizing: border-box; z-index: 1; }
.itinerary-day.is-open .itinerary-day-marker { background: #6a994e; }
.itinerary-day-toggle { width: 100%; display: flex; align-items: center; gap: .75rem; background: none; border: none; padding: 1rem 0; cursor: pointer; font-family: 'Figtree', sans-serif; text-align: left; color: #191815; }
.itinerary-day-title { flex: 1; font-size: 1rem; }
.itinerary-day-num { font-weight: 700; color: #191815; }
.itinerary-day-num + .itinerary-day-route { margin-left: .35rem; }
.itinerary-day-route { font-weight: 600; color: #191815; }
.itinerary-day-chevron { color: #7A7A7A; transition: transform .3s; flex-shrink: 0; display: inline-flex; }
.itinerary-day.is-open .itinerary-day-chevron { transform: rotate(180deg); }
.itinerary-day__body { max-height: 0; overflow: hidden; transition: max-height .35s ease; }
.itinerary-day__body p { margin: 0; padding: 0 0 1.1rem; color: #4A4A4A; line-height: 1.75; font-family: 'Figtree', sans-serif; }
.inclusions-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2.5rem; }
.inclusion-box h3, .exclusion-box h3 { font-size: 1.25rem; font-weight: 500; margin: 0 0 1.25rem; color: #191815; letter-spacing: -0.3px; font-family: 'Rector', serif; }
.incl-list, .incl-list ul { list-style: none; margin: 0; padding: 0; }
.incl-list li { position: relative; padding: 0.6rem 0 0.6rem 1.8rem; color: #4A4A4A; font-size: 0.95rem; line-height: 1.6; font-family: 'Figtree', sans-serif; list-style: none; }
.incl-list a { color: #6a994e !important; text-decoration: underline !important; font-weight: 500 !important; }
.incl-list a:hover { color: #5a8443 !important; }
.incl-list li::marker { content: ""; }
.incl-list li::before { position: absolute; left: 0; top: 0.65rem; font-size: 0.95rem; font-weight: 400; line-height: 1; display: flex; align-items: center; justify-content: center; }
.incl-list--yes li::before { content: "\2713"; color: #6a994e; }
.incl-list--no li::before { content: "\2715"; color: #A09E97; }
.packing-essentials-box { margin-bottom: 1.75rem; }
.packing-list, .packing-list ul { list-style: none; margin: 0; padding: 0; }
.packing-list li { position: relative; padding: 0.6rem 0 0.6rem 1.4rem; color: #4A4A4A; font-size: 0.95rem; line-height: 1.6; font-family: 'Figtree', sans-serif; list-style: none; }
.packing-list a { color: #6a994e !important; text-decoration: underline !important; font-weight: 500 !important; }
.packing-list a:hover { color: #5a8443 !important; }
.packing-list li::marker { content: ""; }
.packing-list li::before { content: "\2022"; position: absolute; left: 0; top: 0.65rem; color: #6a994e; font-size: 1.1rem; line-height: 1; display: flex; align-items: center; justify-content: center; }
.community-owned-card { background: #FAF7F0; border: 1px solid #E4E0D8; border-radius: 16px; padding: 1.5rem 1.75rem; margin-top: 1.75rem; }
.community-owned-card .community-header { font-size: .72rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: #6a994e; margin-bottom: .4rem; font-family: 'Figtree', sans-serif; }
.community-owned-card h3 { font-size: 1.1rem; font-weight: 500; margin: 0 0 .6rem; color: #191815; font-family: 'Rector', serif; }
.community-owned-card p { font-size: .92rem; color: #4A4A4A; margin: 0 0 .9rem; line-height: 1.6; font-family: 'Figtree', sans-serif; }
.community-features, .community-features ul { list-style: none; margin: 0; padding: 0; }
.community-features li { position: relative; padding: .3rem 0 .3rem 1.5rem; font-size: .92rem; color: #4A4A4A; list-style: none; font-family: 'Figtree', sans-serif; }
.community-features li::marker { content: ""; }
.community-features li::before { content: "\25E6"; position: absolute; left: .35rem; top: .25rem; color: #6a994e; font-size: 1.1rem; line-height: 1; }
.faq-accordion {
	display: flex !important;
	flex-direction: column !important;
	gap: 16px !important;
	margin-top: 24px !important;
}
.faq-accordion details {
	background: #ffffff !important;
	border: 1px solid #E5E7EB !important;
	border-radius: 8px !important;
	margin-bottom: 0 !important;
	overflow: hidden !important;
	transition: background 0.2s ease, border-color 0.2s ease !important;
}
.faq-accordion details[open] {
	background: #F0FDF4 !important; /* Light green tint matching homepage */
	border-color: #D1FAE5 !important;
}
.faq-accordion details summary {
	display: flex !important;
	justify-content: space-between !important;
	align-items: center !important;
	padding: 20px 24px !important;
	cursor: pointer !important;
	font-family: 'Figtree', sans-serif !important;
	font-weight: 600 !important;
	font-size: 16px !important;
	list-style: none !important;
	color: #191815 !important;
	text-align: left !important;
	border-bottom: 1px solid transparent !important;
	transition: background-color 0.2s ease !important;
}
.faq-accordion details summary:hover {
	background-color: #F9FAFB !important;
}
.faq-accordion details[open] summary {
	border-bottom: 1px solid #E5E7EB !important;
}
.faq-accordion details summary::-webkit-details-marker {
	display: none !important;
}
.faq-accordion details summary .icon {
	width: 8px !important;
	height: 8px !important;
	border-right: 2px solid #6a994e !important;
	border-bottom: 2px solid #6a994e !important;
	transform: rotate(45deg) !important;
	transition: transform 0.2s ease, margin-top 0.2s ease !important;
	flex-shrink: 0 !important;
	margin-left: 16px !important;
	display: block !important;
	margin-top: -2px !important;
}
.faq-accordion details[open] summary .icon {
	transform: rotate(-135deg) !important;
	margin-top: 2px !important;
}
.faq-accordion details summary .icon::before,
.faq-accordion details[open] summary .icon::before {
	content: "" !important;
}
.faq-accordion details p.faq-body,
.faq-accordion details .faq-body {
	padding: 20px 24px !important;
	margin: 0 !important;
	font-family: 'Figtree', sans-serif !important;
	font-size: 15px !important;
	font-weight: 400 !important;
	color: #4B5563 !important;
	line-height: 1.7 !important;
}
.quote-card { border: 1px solid #E4E0D8; border-radius: 16px; padding: 1.5rem; background: var(--white); box-shadow: 0 8px 30px rgba(0,0,0,.07); font-family: 'Figtree', sans-serif; }
.quote-card__price { display: flex; align-items: baseline; flex-wrap: wrap; gap: .4rem; margin: 0 0 1.1rem; }
.quote-card__from { width: 100%; font-size: .8rem; color: #7A7A7A; font-weight: 500; }
.quote-card__amount { font-size: 1.7rem; font-weight: 800; color: #00AA6C; }
.quote-card__req { font-size: 1.5rem; font-weight: 800; color: #191815; }
.quote-card__old { font-size: 1rem; color: #7A7A7A; }
.quote-card__per { font-size: .85rem; color: #7A7A7A; }
.quote-card .btn { width: 100%; border-radius: 999px; }
.btn--quote { background: #00AA6C; color: var(--white); border-color: #00AA6C; }
.btn--quote:hover { background: #008C5E; border-color: #008C5E; color: var(--white); }
.btn--wa-outline { background: var(--white); color: #00AA6C; border-color: #00AA6C; margin-top: .65rem; }
.btn--wa-outline:hover { background: #E8F3EC; color: #00AA6C; }
.quote-card__note { text-align: center; font-size: .8rem; color: #7A7A7A; margin: .85rem 0 1rem; }
.quote-card__badges { display: flex; justify-content: center; gap: .9rem; flex-wrap: wrap; border-top: 1px solid #E4E0D8; padding-top: 1rem; }
.quote-badge { display: inline-flex; align-items: center; gap: .3rem; font-size: .72rem; color: #7A7A7A; font-weight: 600; }
.quote-badge svg, .quote-badge .ico { color: #6a994e; }
.quote-modal { position: fixed; inset: 0; z-index: 1000; display: none; font-family: 'Figtree', sans-serif; }
.quote-modal.is-open { display: block; }
.quote-modal__overlay { position: absolute; inset: 0; background: rgba(0,0,0,.55); }
.quote-modal__dialog { position: relative; background: var(--white); max-width: 460px; width: calc(100% - 2rem); margin: 5vh auto; max-height: 90vh; overflow-y: auto; border-radius: 16px; padding: 1.75rem; box-shadow: 0 24px 70px rgba(0,0,0,.35); }
.quote-modal__close { position: absolute; top: .5rem; right: .85rem; background: none; border: none; font-size: 1.9rem; line-height: 1; color: #7A7A7A; cursor: pointer; }
.quote-modal__title { font-family: 'Rector', serif; font-size: 1.25rem; font-weight: 500; margin: 0 0 1rem; color: #191815; }
body.quote-modal-open { overflow: hidden; }
.booking-box__price { font-size: 1.3rem; font-weight: 700; color: #191815; margin: 0 0 .25rem; }
.booking-box__price .from { font-size: .8rem; font-weight: 500; color: #7A7A7A; }
.booking-box__price .amount { color: #00AA6C; }
.booking-box__note { font-size: .82rem; color: #7A7A7A; margin: 0 0 1rem; }
.booking-form label { display: block; font-size: .85rem; font-weight: 600; color: #191815; margin: .8rem 0 .35rem; }
.booking-form input, .booking-form textarea { width: 100%; padding: .65rem .75rem; border: 1px solid #E4E0D8; border-radius: 8px; font-family: inherit; font-size: .92rem; color: #191815; }
.booking-form input:focus, .booking-form textarea:focus { outline: none; border-color: #00AA6C; box-shadow: 0 0 0 3px rgba(0,170,108,.12); }
.hp-field { position: absolute; left: -9999px; height: 0; overflow: hidden; }
.qty-row { display: flex; align-items: center; gap: .5rem; }
.qty-row input { text-align: center; }
.qty-minus, .qty-plus { width: 40px; height: 40px; flex-shrink: 0; border: 1px solid #E4E0D8; background: #FAF7F0; border-radius: 8px; font-size: 1.2rem; cursor: pointer; color: #191815; }
.booking-total { display: flex; justify-content: space-between; align-items: center; margin: 1.1rem 0 .25rem; font-weight: 600; color: #191815; }
.booking-total__amount { color: #00AA6C; font-size: 1.15rem; }
.booking-alt { text-align: center; margin-top: 1rem; }
.booking-alt__or { display: block; font-size: .8rem; color: #7A7A7A; margin: .5rem 0; }
.booking-alt__note { display: block; font-size: .78rem; color: #7A7A7A; margin-top: .5rem; }
.booking-trust-list { display: flex; flex-wrap: wrap; gap: .75rem; justify-content: center; margin-top: 1rem; padding-top: 1rem; border-top: 1px solid #E4E0D8; }
.booking-trust-item { font-size: .75rem; color: #7A7A7A; display: inline-flex; align-items: center; gap: .25rem; }
.booking-trust-item .check-icon { color: #6a994e; font-weight: 700; }
.notice { padding: .75rem 1rem; border-radius: 8px; font-size: .88rem; margin-bottom: 1rem; }
.notice--ok { background: #E8F3EC; color: #1B4332; }
.notice--err { background: #fdecea; color: #c0392b; }
.tour-map { height: 380px; border-radius: 16px; overflow: hidden; margin-bottom: 1rem; }
.tour-map-legend { display: flex; flex-wrap: wrap; gap: .75rem; }
.map-legend-item { display: inline-flex; align-items: center; gap: .35rem; font-size: .85rem; color: #7A7A7A; font-family: 'Figtree', sans-serif; }
.map-legend-num { width: 22px; height: 22px; border-radius: 50%; background: #6a994e; color: #fff; display: inline-flex; align-items: center; justify-content: center; font-size: .75rem; font-weight: 700; }


/* TOUR CARD — OTA style */
.tour-card { position: relative; display: flex; flex-direction: column; height: 100%; background: var(--white); border: 1px solid var(--border); border-radius: var(--r-card); overflow: hidden; transition: box-shadow .25s ease; box-shadow: var(--shadow-card); }
.tour-card:hover { transform: none !important; box-shadow: var(--shadow-hover) !important; }
.tour-card__media { position: relative; display: block; aspect-ratio: 4 / 3; overflow: hidden; }
.tour-card__media img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .5s ease; }
.tour-card:hover .tour-card__media img { transform: scale(1.05); }
.tour-card__ph { display: flex; align-items: center; justify-content: center; width: 100%; height: 100%; background: linear-gradient(135deg, #0c3a24, var(--primary)); color: rgba(255,255,255,.55); }
.tour-card__type { position: static; background: var(--primary); color: #fff; font-size: var(--t-xs); font-weight: 600; padding: 4px 8px; border-radius: var(--r-badge); box-shadow: none; }
.tour-card__save { position: static; background: var(--secondary); color: #fff; font-size: var(--t-xs); font-weight: 700; padding: 4px 8px; border-radius: var(--r-badge); }
.tour-card__body { display: flex; flex-direction: column; gap: 8px; flex: 1; padding: 16px; }
.tour-card__title { font-size: var(--t-base); font-weight: 600; line-height: 1.4; color: var(--text); margin: 0 0 8px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; min-height: 48px; transition: color .2s; }
.tour-card__title a { color: inherit; text-decoration: none; }
.tour-card__title a::after { content: ""; position: absolute; inset: 0; z-index: 1; }
.tour-card:hover .tour-card__title { color: var(--primary-dark); }
.tour-card__meta { display: flex; gap: 16px; align-items: center; }
.tour-card__meta-item { display: inline-flex; align-items: center; gap: 4px; }
.tour-card__meta-item svg, .tour-card__meta-item .ico { width: 16px; height: 16px; color: var(--text-muted); }
.tour-card__meta-item span { font-size: var(--t-xs); color: var(--text-light); }
.tour-card__price { margin-top: auto; }
.tour-card__price .amount { font-size: var(--t-lg) !important; font-weight: 700 !important; color: var(--text) !important; display: block; }
.tour-card__price .from { font-size: var(--t-xs) !important; font-weight: 400 !important; color: var(--text-muted) !important; text-transform: none; letter-spacing: 0; display: block; margin-bottom: 2px; }
.tour-card__price .per { font-size: var(--t-xs); color: var(--text-muted); }
.tour-card__price del { font-size: var(--t-xs); color: var(--text-muted); margin-right: 4px; }
.tour-card__price .req { font-weight: 700; color: var(--text); }
.tour-card__dur { display: inline-flex; align-items: center; gap: .3rem; font-size: .82rem; color: var(--text-light); white-space: nowrap; }
.tour-card__dur svg, .tour-card__dur .ico { width: 14px; height: 14px; color: var(--text-light); }

/* Similar / grids */
.similar, .section--soft { background: var(--bg-light); }
.similar { padding: 3rem 0; margin-top: 1rem; }
.section-head { text-align: center; margin-bottom: 2rem; }
.section-head h2 { font-size: 1.7rem; font-weight: 700; color: var(--text); margin: 0; }
.section-head p { color: var(--text-light); font-size: 1.02rem; margin: .4rem auto 0; max-width: 640px; }
.grid { display: grid; gap: 1.75rem; }
.grid--3 { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
.grid--4 { grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }

/* Mobile sticky bar */
.mobile-sticky-booking-bar { display: none; position: fixed; bottom: 0; left: 0; right: 0; background: var(--white); border-top: 1px solid var(--border); padding: .75rem 1rem; z-index: 60; align-items: center; justify-content: space-between; gap: 1rem; box-shadow: 0 -4px 16px rgba(0,0,0,.08); }
.mobile-sticky-price { font-size: .95rem; }
.mobile-sticky-price .from { font-size: .72rem; color: var(--text-light); display: block; }
.mobile-sticky-price .amount { font-weight: 700; color: var(--primary); }
.btn-sticky-book { white-space: nowrap; }

/* ============================================================
   HOMEPAGE
   ============================================================ */
.section { padding: 4.5rem 0; }
.center { text-align: center; }
.mt-30 { margin-top: 1.875rem; }
.hero { position: relative; min-height: 78vh; display: flex; align-items: center; background: #0c3a24 center/cover no-repeat; color: #fff; text-align: center; }
.hero::before { content: ""; position: absolute; inset: 0; z-index: 1; background: linear-gradient(180deg, rgba(3,40,24,.45), rgba(3,40,24,.78)); }
.hero-slides { position: absolute; inset: 0; z-index: 0; overflow: hidden; }
.hero-slide { position: absolute; inset: 0; background: #0c3a24 center center / cover no-repeat; opacity: 0; transition: opacity 1.1s ease; transform: scale(1.04); }
.hero-slide.is-active { opacity: 1; animation: heroKenBurns 8s ease-out forwards; }
@keyframes heroKenBurns { from { transform: scale(1.04); } to { transform: scale(1.12); } }
.hero-dots { position: absolute; bottom: 1.5rem; left: 50%; transform: translateX(-50%); z-index: 2; display: flex; gap: .5rem; }
.hero-dot { width: 11px; height: 11px; padding: 0; border: none; border-radius: 50%; background: rgba(255,255,255,.5); cursor: pointer; transition: background .2s, transform .2s; }
.hero-dot.is-active { background: #fff; transform: scale(1.25); }
@media (prefers-reduced-motion: reduce) { .hero-slide.is-active { animation: none; transform: none; } }
.hero .wrap { position: relative; z-index: 2; max-width: 880px; padding-top: 4rem; padding-bottom: 4rem; }
.hero h1 { font-size: clamp(2rem, 4.6vw, 3.4rem); font-weight: 800; line-height: 1.12; letter-spacing: -.02em; margin: 0 0 1rem; }
.hero p { font-size: clamp(1rem, 1.6vw, 1.2rem); color: rgba(255,255,255,.92); max-width: 700px; margin: 0 auto 2rem; }
.hero-search { display: flex; gap: .4rem; max-width: 580px; margin: 0 auto; background: #fff; padding: .4rem; border-radius: 999px; box-shadow: 0 18px 44px rgba(0,0,0,.28); }
.hero-search input[type="search"] { flex: 1; min-width: 0; border: none; background: none; padding: .7rem 1.2rem; font-size: 1rem; color: var(--text); outline: none; }
.hero-search button { flex-shrink: 0; background: var(--primary); color: #fff; border: none; border-radius: 999px; padding: .7rem 1.9rem; font-weight: 700; font-size: .95rem; cursor: pointer; transition: background .2s; }
.hero-search button:hover { background: var(--primary-dark); }
.usp-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; }
.usp-grid > div { text-align: center; padding: 1.25rem 1rem; }
.usp-ico { width: 64px; height: 64px; margin: 0 auto 1.1rem; border-radius: 50%; background: #e8f3ee; color: var(--primary); display: flex; align-items: center; justify-content: center; }
.usp-grid h3 { font-size: 1.08rem; font-weight: 700; color: var(--text); margin: 0 0 .5rem; }
.usp-grid p { font-size: .9rem; color: var(--text-light); line-height: 1.6; margin: 0; }
.dest-card { position: relative; display: block; border-radius: .8rem; overflow: hidden; aspect-ratio: 4 / 3; text-decoration: none; box-shadow: 0 6px 18px rgba(0,0,0,.09); }
.dest-card img { width: 100%; height: 100%; object-fit: cover; transition: transform .55s ease; }
.dest-card:hover img { transform: scale(1.08); }
.dest-card__body { position: absolute; inset: 0; display: flex; flex-direction: column; justify-content: flex-end; padding: 1.3rem; color: #fff; background: linear-gradient(180deg, rgba(0,0,0,0) 38%, rgba(0,0,0,.78)); }
.dest-card__body h3 { font-size: 1.3rem; font-weight: 700; margin: 0 0 .2rem; }
.dest-card__body span { font-size: .85rem; opacity: .9; }
.cta-band { position: relative; background: var(--primary-dark) center/cover no-repeat; color: #fff; text-align: center; padding: 5rem 0; }
.cta-band::before { content: ""; position: absolute; inset: 0; background: rgba(3,40,24,.82); }
.cta-band .wrap { position: relative; z-index: 1; max-width: 780px; }
.cta-band h2 { font-size: clamp(1.6rem, 3vw, 2.4rem); font-weight: 800; line-height: 1.2; margin: 0 0 1rem; }
.cta-band p { color: rgba(255,255,255,.92); font-size: 1.05rem; margin: 0 0 1.9rem; }
.cta-band .btn { background: #fff; color: var(--primary-dark); border-color: #fff; }
.cta-band .btn:hover { background: rgba(255,255,255,.88); }
.reviews-carousel { display: grid; grid-template-columns: repeat(auto-fit, minmax(290px, 1fr)); gap: 1.5rem; }
.review-card { background: #fff; border: 1px solid var(--border); border-radius: .8rem; padding: 1.75rem; margin: 0; box-shadow: 0 4px 14px rgba(0,0,0,.05); }
.review-stars { display: inline-flex; gap: 2px; color: #f5a623; margin-bottom: .8rem; }
.review-card p { color: var(--text); line-height: 1.7; font-size: .95rem; margin: 0 0 1rem; }
.review-card cite { font-style: normal; font-weight: 700; color: var(--text); font-size: .9rem; }
.post-card {
	background: #ffffff !important;
	border: 1px solid #E4E0D8 !important;
	border-radius: 20px !important;
	overflow: hidden !important;
	display: flex !important;
	flex-direction: column !important;
	height: 100% !important;
	box-shadow: 0 8px 30px rgba(0,0,0,0.02) !important;
	transition: transform 0.3s cubic-bezier(0.22, 1, 0.36, 1), box-shadow 0.3s cubic-bezier(0.22, 1, 0.36, 1), border-color 0.3s ease !important;
	box-sizing: border-box !important;
}
.post-card:hover {
	transform: translateY(-4px) !important;
	box-shadow: 0 16px 35px rgba(0,0,0,0.08) !important;
	border-color: #6a994e !important;
}
.post-card img {
	width: 100% !important;
	aspect-ratio: 16 / 10 !important;
	object-fit: cover !important;
	display: block !important;
	transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1) !important;
}
.post-card:hover img {
	transform: scale(1.03) !important;
}
.post-card__body {
	padding: 1.5rem !important;
	display: flex !important;
	flex-direction: column !important;
	flex-grow: 1 !important;
	gap: 0.6rem !important;
}
.post-card__body h3 {
	font-family: 'Rector', serif !important;
	font-size: 1.35rem !important;
	font-weight: 500 !important;
	line-height: 1.35 !important;
	color: #191815 !important;
	margin: 0 !important;
}
.post-card__body h3 a {
	color: inherit !important;
	text-decoration: none !important;
}
.post-card__body h3 a:hover {
	color: #6a994e !important;
}
.post-card__date {
	font-size: 0.85rem !important;
	color: #6b7280 !important;
	font-family: 'Figtree', sans-serif !important;
	font-weight: 500 !important;
}

/* Featured Post Card */
.featured-post-card {
	display: grid;
	grid-template-columns: 1.2fr 0.8fr;
	gap: 3.5rem;
	background: #ffffff !important;
	border: 1px solid #E4E0D8 !important;
	border-radius: 20px !important;
	overflow: hidden !important;
	margin-bottom: 3rem !important;
	align-items: stretch !important;
	max-width: 100% !important;
	box-shadow: 0 8px 30px rgba(0,0,0,0.02) !important;
	transition: transform 0.3s cubic-bezier(0.22, 1, 0.36, 1), box-shadow 0.3s cubic-bezier(0.22, 1, 0.36, 1), border-color 0.3s ease !important;
}
@media (max-width: 768px) {
	.featured-post-card {
		grid-template-columns: 1fr !important;
		gap: 1.5rem !important;
		align-items: start !important;
	}
}
.featured-post-card:hover {
	transform: translateY(-4px) !important;
	box-shadow: 0 16px 35px rgba(0,0,0,0.08) !important;
	border-color: #6a994e !important;
}
.featured-post-card__image {
	width: 100% !important;
	height: 100% !important;
	overflow: hidden !important;
}
.featured-post-card__image a {
	display: block !important;
	width: 100% !important;
	height: 100% !important;
}
.featured-post-card__image img {
	width: 100% !important;
	height: 100% !important;
	object-fit: cover !important;
	display: block !important;
	transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1) !important;
}
.featured-post-card:hover .featured-post-card__image img {
	transform: scale(1.03) !important;
}
.featured-post-card__body {
	padding: 2.5rem !important;
	display: flex !important;
	flex-direction: column !important;
	gap: 1rem !important;
	align-items: start !important;
}
@media (max-width: 768px) {
	.featured-post-card__body {
		padding: 1.5rem !important;
	}
}
.featured-tag {
	font-family: 'Figtree', sans-serif !important;
	font-size: 0.72rem !important;
	font-weight: 700 !important;
	color: #6a994e !important;
	background: #E8F3EC !important;
	padding: 6px 14px !important;
	border-radius: 999px !important; /* Pill shape */
	letter-spacing: 0.05em !important;
	display: inline-block !important;
	text-transform: uppercase !important;
}
.featured-post-card__body h2 {
	margin: 0 !important;
	font-family: 'Rector', serif !important;
	font-size: 2rem !important;
	font-weight: 500 !important;
	line-height: 1.25 !important;
	color: #191815 !important;
}
.featured-post-card__body h2 a {
	color: inherit !important;
	text-decoration: none !important;
}
.featured-post-card__body h2 a:hover {
	color: #6a994e !important;
}
.featured-post-card__excerpt {
	font-family: 'Figtree', sans-serif !important;
	font-size: 1.02rem !important;
	line-height: 1.65 !important;
	color: #4b5563 !important;
}
.featured-post-card__excerpt p {
	margin: 0 !important;
}
.btn--hero-cta {
	padding: 10px 20px !important;
	font-size: 0.88rem !important;
	font-weight: 700 !important;
	border-radius: 6px !important;
	text-decoration: none !important;
	display: inline-block !important;
}
.btn-read-more {
	background-color: #6a994e !important;
	color: #ffffff !important;
	font-family: 'Figtree', sans-serif !important;
	font-weight: 600 !important;
	font-size: 0.9rem !important;
	padding: 12px 28px !important;
	border-radius: 999px !important; /* Pill shape */
	text-decoration: none !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	transition: background-color 0.25s ease, transform 0.25s ease, box-shadow 0.25s ease !important;
	box-shadow: 0 4px 14px rgba(106, 153, 78, 0.2) !important;
	cursor: pointer !important;
}
.btn-read-more:hover {
	background-color: #557a3e !important;
	transform: translateY(-2px) !important;
	box-shadow: 0 6px 20px rgba(106, 153, 78, 0.3) !important;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
.hide-on-desktop { display: none !important; }
@media (max-width: 992px) {
	.tour-layout { grid-template-columns: 1fr; }
	.tour-sidebar { position: static; max-width: 480px; }
	.footer-grid { grid-template-columns: repeat(3, 1fr); }
	.footer-brand { grid-column: 1 / -1; max-width: none; }
}
@media (max-width: 768px) {
	.wrap { padding: 0 1rem; }
	.tour-sub-nav .wrap { padding: 0 1rem; }
	.tour-title { font-size: 1.5rem; }
	.tour-header { flex-direction: column; gap: 1rem; }
	.footer-grid { grid-template-columns: 1fr 1fr; gap: 1.75rem; }
	.footer-bottom__inner { flex-direction: column; align-items: flex-start; }

	.tour-gallery { grid-template-columns: 1fr !important; grid-template-rows: none !important; grid-auto-flow: column; grid-auto-columns: 100%; height: 280px; overflow-x: auto; scroll-snap-type: x mandatory; scrollbar-width: none; }
	.tour-gallery::-webkit-scrollbar { display: none; }
	.tour-gallery__item { scroll-snap-align: start; }
	.tour-gallery--3 .tour-gallery__item:first-child, .tour-gallery--4 .tour-gallery__item, .tour-gallery--5 .tour-gallery__item:first-child { grid-row: auto !important; grid-column: auto !important; }
	.tour-gallery-btn, .tour-gallery-dots { display: flex; }
	.tour-infoline { flex-direction: column; align-items: flex-start; gap: 1rem; }
	.tour-pdf-btn { width: 100%; justify-content: center; }
	.inclusions-grid { grid-template-columns: 1fr; gap: 1.5rem; }
	.mobile-sticky-booking-bar { display: flex; }
	.tour-page-wrapper { padding-bottom: 80px; }
	.section { padding: 3rem 0; }
	.hero { min-height: 68vh; }
	.hero-search { flex-direction: column; border-radius: 1rem; padding: .55rem; }
	.hero-search button { border-radius: .65rem; padding: .75rem; }
	.usp-grid { grid-template-columns: 1fr 1fr; gap: 1rem; }
	.cta-band { padding: 3.5rem 0; }
	.partners__grid { gap: 2rem; }
	.partners__grid img { height: 34px; max-width: 120px; }
	.we-accept-logos { justify-content: flex-start; }
}
@media (max-width: 480px) {
	.usp-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   TOURS ARCHIVE
   ============================================================ */
/* Consolidated under modern selectors below */

.tours-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-bottom: 40px; }

@media (max-width: 992px) {
    .tours-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
    .tours-grid { grid-template-columns: 1fr; }
}

.tours-empty { text-align: center; padding: 3rem 1rem 3.5rem; }
.tours-empty p { color: var(--text-light); margin: 0 0 1.25rem; }

.pagination { display: flex; justify-content: center; gap: .4rem; flex-wrap: wrap; margin: 1rem 0 3.5rem; }
.pagination .page-numbers { display: inline-flex; align-items: center; justify-content: center; min-width: 42px; height: 42px; padding: 0 .65rem; border: 1px solid var(--border); border-radius: .55rem; color: var(--text); text-decoration: none; font-weight: 600; font-size: .9rem; transition: all .2s; }
.pagination a.page-numbers:hover { border-color: var(--primary); color: var(--primary); }
.pagination .page-numbers.current { background: var(--primary); border-color: var(--primary); color: #fff; }
.pagination .page-numbers.dots { border-color: transparent; }

.archive-related { margin-top: 3rem; padding-top: 3rem; border-top: 1px solid var(--border); margin-bottom: 3.5rem; }
.archive-related__title { text-align: center; font-size: 1.6rem; font-weight: 800; color: var(--text); margin: 0 0 2rem; }
.archive-related-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 1.5rem; }
.archive-related-card { display: block; text-align: center; padding: 2rem 1.5rem; border: 1px solid var(--border); border-radius: .9rem; text-decoration: none; background: #fff; transition: transform .25s, box-shadow .25s, border-color .25s; }
.archive-related-card:hover { transform: translateY(-4px); box-shadow: 0 16px 34px rgba(3,40,24,.12); border-color: transparent; }
.archive-related-card__icon { width: 64px; height: 64px; margin: 0 auto 1rem; border-radius: 50%; background: #e8f3ee; color: var(--primary); display: flex; align-items: center; justify-content: center; }
.archive-related-card h3 { font-size: 1.1rem; font-weight: 700; color: var(--text); margin: 0 0 .5rem; }
.archive-related-card p { font-size: .9rem; color: var(--text-light); line-height: 1.6; margin: 0; }

@media (max-width: 768px) {
	.archive-hero { padding: 1.75rem 0 1.5rem; margin-bottom: 1.75rem; }
	.archive-stats { gap: 1.5rem 2rem; }
	.tours-toolbar { flex-direction: column; align-items: flex-start; }
	.archive-filters-form { width: 100%; }
	.archive-filters-form input[type="text"], .archive-filters-form select { flex: 1; min-width: 0; }
}

/* ============================================================
   TOURS ARCHIVE — clean / simple / high-contrast / classic
   (scoped to .tours-archive; rest of the site is unaffected)
   ============================================================ */
.tours-archive .archive-hero { position: relative; background: #f9fafb; border-bottom: 1px solid var(--border); padding: var(--s-6) 0; margin-bottom: var(--s-5); color: var(--text); text-align: left; }
.tours-archive .archive-hero::before { display: none; }
.archive-hero__container { display: grid; grid-template-columns: 1.25fr 0.75fr; gap: 5rem; align-items: center; }
.archive-hero__left { display: flex; flex-direction: column; align-items: flex-start; }
.tours-archive .breadcrumbs, .tours-archive .breadcrumbs a { color: var(--text-light) !important; font-size: var(--t-xs); }
.tours-archive .breadcrumbs a:hover { color: var(--primary) !important; }
.tours-archive .archive-hero__title { color: var(--text) !important; font-size: clamp(2.2rem, 4.5vw, 3.2rem) !important; font-weight: 800; line-height: 1.15; letter-spacing: -0.03em; text-shadow: none; margin: 0.5rem 0 1.2rem; }
.tours-archive .archive-hero__desc, .tours-archive .archive-hero__desc p { color: var(--text-light) !important; font-size: 1.05rem; line-height: 1.65; text-shadow: none; margin: 0; }
.tours-archive .archive-hero__desc { max-width: 580px !important; margin: 0 0 1.8rem !important; }
.tours-archive .archive-hero__desc strong { color: var(--text); font-weight: 700; }
.archive-hero__actions { display: flex; flex-direction: column; align-items: flex-start; gap: 1rem; }
.archive-hero__actions .btn { display: inline-block; padding: 0.85rem 1.75rem; font-size: 0.95rem; font-weight: 600; border-radius: var(--r-card); text-decoration: none; transition: background-color 0.2s, transform 0.2s; border: none; cursor: pointer; }
.archive-hero__actions .btn--primary { background: var(--primary); color: #fff; }
.archive-hero__actions .btn--primary:hover { background: var(--primary-dark); }
.archive-hero__image-wrapper { width: 100%; aspect-ratio: 16 / 11; border-radius: 12px; overflow: hidden; box-shadow: 0 10px 30px rgba(0,0,0,0.06); }
.archive-hero__image { width: 100%; height: 100%; object-fit: cover; display: block; }
@media (max-width: 992px) {
	.archive-hero__container { grid-template-columns: 1fr; gap: 2rem; }
	.archive-hero__left { align-items: flex-start; text-align: left; }
	.tours-archive .archive-hero__desc { margin: 0 0 1.8rem !important; }
	.tours-archive .archive-hero { padding: var(--s-5) 0; }
}

/* Pagination — square, high-contrast */
.tours-archive .pagination .page-numbers { border-color: var(--border); color: var(--text); }
.tours-archive .pagination a.page-numbers:hover { background: var(--primary); color: #fff; border-color: var(--primary); }
.tours-archive .pagination .page-numbers.current { background: var(--primary); border-color: var(--primary); color: #fff; }

/* Empty state */
.tours-archive .tours-empty p { color: #333; }

/* ============================================================
   CONSISTENT PAGE HEADER (breadcrumbs + title) — site-wide
   ============================================================ */
.page-header, .tours-archive .archive-hero, .archive-hero { background: #fff; border-bottom: 1px solid var(--border); padding: 3rem 0 2.25rem; margin-bottom: 3rem; padding-bottom: 4rem !important; }
.page-header .breadcrumbs, .archive-hero .breadcrumbs { margin: 0 0 1rem; }
.page-header__title, .page-header h1, .archive-hero__title { font-family: 'Montserrat', 'Inter', sans-serif; font-size: var(--t-xl); font-weight: 700; line-height: 1.2; letter-spacing: -.02em; color: #111; margin: 0; }
.page-header__desc, .archive-hero__desc { color: var(--text-light); max-width: 600px; margin: 16px 0 0; line-height: 1.6; font-size: var(--t-base); }
.page-header__meta { margin-top: .6rem; color: #555; font-size: .9rem; }

/* Body content area — consistent width + rhythm */
.content-area { padding-bottom: 3.5rem; }
.content-area .entry, .content-area > article { max-width: 820px; }
.entry .wp-post-image, .entry > img { border-radius: .5rem; margin-bottom: 1.5rem; display: block; }
.entry-content { font-family: 'Figtree', sans-serif; color: var(--text); line-height: 1.8; font-size: 1.05rem; }
.entry-content > * { margin-bottom: 1.1rem; }
.entry-content > *:last-child { margin-bottom: 0; }
.entry-content h2 { font-family: 'Rector', serif; font-size: 1.75rem; font-weight: 500; color: #191815; margin: 2.5rem 0 1rem; line-height: 1.3; }
.entry-content h3 { font-family: 'Rector', serif; font-size: 1.4rem; font-weight: 500; color: #191815; margin: 2rem 0 .8rem; line-height: 1.3; }
.entry-content a { color: var(--primary); text-decoration: underline; }
.entry-content ul, .entry-content ol { padding-left: 1.3rem; }
.entry-content li { margin-bottom: .4rem; }
.entry-content img { border-radius: .5rem; height: auto; }
.entry-content blockquote { border-left: 3px solid var(--primary); padding-left: 1rem; margin: 1.5rem 0; color: var(--text-light); font-style: italic; }
.entry-meta { color: #555; font-size: .88rem; margin-bottom: 1.25rem; }

/* Error page + inline search */
.error-page { text-align: center; padding: 4rem 1rem 4.5rem; }
.error-page h1 { font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif; font-size: clamp(2rem, 5vw, 3rem); color: #111; margin-bottom: 1rem; }
.error-page p { color: #333; max-width: 520px; margin: 0 auto 1.25rem; }
.search-form-inline { display: flex; gap: .5rem; max-width: 440px; margin: 1.5rem auto 0; }
.search-form-inline input { flex: 1; min-width: 0; border: 1px solid var(--border); border-radius: .5rem; padding: .7rem 1rem; font-family: inherit; font-size: .95rem; }
.search-form-inline input:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px rgba(46,125,79,.12); }
.search-form-inline button { background: var(--primary); color: #fff; border: none; border-radius: .5rem; padding: .7rem 1.25rem; font-weight: 700; cursor: pointer; }
.search-form-inline button:hover { background: var(--primary-dark); }
.content-area .pagination { margin: 2.5rem 0 0; }

/* Breadcrumbs — consistent site-wide (separator: ›) */
.breadcrumbs, nav.wak-breadcrumbs { 
    font-family: 'Figtree', sans-serif !important;
    font-size: 13px !important; 
    color: #7c7976 !important; 
    line-height: 1.4 !important; 
    display: flex !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    gap: 6px !important;
    margin: 1rem 0 !important;
    padding: 0 !important;
}
.breadcrumbs a, nav.wak-breadcrumbs a, nav.wak-breadcrumbs .wak-breadcrumb-link { 
    color: #7c7976 !important; 
    text-decoration: none !important; 
    transition: color 0.2s ease !important;
}
.breadcrumbs a:hover, nav.wak-breadcrumbs a:hover, nav.wak-breadcrumbs .wak-breadcrumb-link:hover { 
    color: #6a994e !important; 
    text-decoration: underline !important; 
}
.breadcrumbs span, nav.wak-breadcrumbs span, nav.wak-breadcrumbs span.wak-breadcrumb-link { 
    color: #191815 !important; 
    font-weight: 600 !important; 
}
.breadcrumbs .wak-add-seperator, nav.wak-breadcrumbs .wak-add-seperator {
    background: none !important;
    height: auto !important;
    width: auto !important;
    opacity: 1 !important;
    display: inline-block !important;
}
.breadcrumbs .wak-add-seperator::after, nav.wak-breadcrumbs .wak-add-seperator::after {
    content: ">" !important;
    color: #A09E97 !important;
    font-size: 12px !important;
    font-family: 'Figtree', sans-serif !important;
    font-weight: 500 !important;
}

/* Card favorite (heart) + rating line */
.tour-card__tags { position: absolute; bottom: 12px; left: 12px; z-index: 2; display: flex; flex-direction: row; align-items: flex-end; gap: 4px; }
.tour-card__type, .tour-card__save { position: static; }
.tour-card__fav { position: absolute; top: 12px; right: 12px; z-index: 3; width: 28px; height: 28px; display: inline-flex; align-items: center; justify-content: center; padding: 0; border: none; border-radius: 50%; background: #ffffff; color: var(--text-muted); cursor: pointer; box-shadow: 0 1px 4px rgba(0,0,0,0.15); transition: transform .15s ease, color .2s, background .2s; }
.tour-card__fav svg { width: 20px; height: 20px; }
.tour-card__fav:hover { transform: scale(1.08); color: var(--danger); background: #fff; }
.tour-card__fav.is-fav { color: var(--danger); }
.tour-card__fav.is-fav svg { fill: var(--danger); stroke: var(--danger); }
.tour-card__body .tour-card__title { margin-bottom: .45rem; }
.tour-card__rating { display: inline-flex; align-items: center; gap: .35rem; font-size: .88rem; color: var(--text); margin: 0 0 .95rem; }
.tour-card__star { color: #f5a623; font-size: 1.1rem; line-height: 1; }
.tour-card__rating strong { font-weight: 700; }
.tour-card__rcount { color: var(--text-light); }

/* Tours sort bar */
.tours-sortbar { display: flex; justify-content: flex-end; margin-bottom: 1.5rem; }
.tours-sort { display: inline-flex; align-items: center; gap: .5rem; }
.tours-sort label { font-size: .85rem; color: var(--text-light); font-weight: 600; }
.tours-sort select { border: 1px solid var(--border); border-radius: .55rem; padding: .55rem 2.2rem .55rem .85rem; font-family: inherit; font-size: .9rem; color: var(--text); background-color: #fff; cursor: pointer; appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%232c3e50' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right .85rem center; }
.tours-sort select:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px rgba(46,125,79,.12); }

/* Archive: SEO heading, filters, sort, card View Tour button */
.tours-section-title { font-size: 1.4rem; font-weight: 800; color: var(--text); margin: 0 0 1.25rem; }
.tours-toolbar { display: flex; flex-direction: column; gap: 16px; background: transparent !important; border-top: 1px solid var(--border) !important; border-bottom: 1px solid var(--border) !important; border-left: none !important; border-right: none !important; padding: 16px 0 !important; margin-bottom: 32px !important; border-radius: 0 !important; box-shadow: none !important; }
.tours-toolbar__main { display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }
.tours-filters { display: flex; align-items: center; gap: .6rem; flex-wrap: wrap; }
.tours-filters select, .tours-sort select { border: 1px solid var(--border); border-radius: .55rem; padding: .55rem 2.2rem .55rem .85rem; font-family: inherit; font-size: .9rem; color: var(--text); background-color: #fff; cursor: pointer; appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%232c3e50' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right .85rem center; }
.tours-filters select:focus, .tours-sort select:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px rgba(46,125,79,.12); }
.tours-filters__reset { font-size: .85rem; color: var(--primary); text-decoration: none; font-weight: 600; white-space: nowrap; margin-left: .5rem; }
.tours-filters__reset:hover { text-decoration: underline; }
.tours-sort { display: inline-flex; align-items: center; gap: .5rem; }
.tours-sort > span { font-size: .85rem; color: var(--text-light); font-weight: 600; white-space: nowrap; }
.tours-toolbar__count { font-size: .9rem; color: var(--text-light); font-weight: 600; margin: 0; }

/* Filter Chips styling */
.tours-toolbar__chips { display: flex; flex-direction: column; gap: .85rem; border-top: 1px solid var(--border); padding-top: 1.1rem; }
.tours-chips-group { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; }
.tours-chips-label { font-size: .82rem; font-weight: 700; color: var(--text); min-width: 110px; text-transform: uppercase; letter-spacing: 0.5px; }
.tours-chips-list { display: flex; align-items: center; gap: .5rem; flex-wrap: wrap; }
.tour-chip { background: #fff; border: 1px solid var(--border); border-radius: var(--r-card); padding: 8px 16px; font-family: inherit; font-size: var(--t-sm); font-weight: 600; color: var(--text-light); cursor: pointer; transition: all .2s; outline: none; }
.tour-chip:hover { border-color: var(--primary); color: var(--primary); }
.tour-chip.is-active { background: var(--primary-tint); border-color: var(--primary); color: var(--primary); box-shadow: none; }
.tour-chip.is-active::before { content: ""; }

/* Tour Card elements styling */
.tour-card__type--private { background: var(--primary) !important; }
.tour-card__type--group { background: var(--secondary) !important; }
.tour-card__dep { display: inline-flex; align-items: center; gap: .35rem; font-size: .78rem; color: var(--success); font-weight: 500; margin-bottom: .6rem; }
.tour-card__dep svg, .tour-card__dep .ico { width: 13px; height: 13px; color: var(--success); }
.tour-card__facts { display: flex; align-items: center; gap: .5rem; flex-wrap: wrap; margin: 0 0 .9rem; }
.tour-card__facts .tour-card__fact:nth-child(n+3),
.tour-card__meta .tour-card__meta-item:nth-child(n+3) {
    display: none !important;
}
.tour-card__fact { display: inline-flex; align-items: center; gap: .3rem; font-size: .76rem; font-weight: 600; color: var(--text); background: var(--bg-light); padding: .25rem .55rem; border-radius: .35rem; border: 1px solid rgba(0,0,0,.04); }
.tour-card__fact svg, .tour-card__fact .ico { width: 13px; height: 13px; color: var(--primary); }
.tour-card__fact--diff-challenging { color: #c0392b; background: #fdedec; }
.tour-card__fact--diff-challenging svg { color: #c0392b; }
.tour-card__fact--diff-moderate { color: #d35400; background: #fdf2e9; }
.tour-card__fact--diff-moderate svg { color: #d35400; }
.tour-card__fact--diff-easy { color: var(--primary); background: var(--primary-tint); }
.tour-card__fact--diff-easy svg { color: var(--primary); }

.tour-card__btn { position: relative; z-index: 2; display: block; text-align: center; margin-top: 12px; background: transparent; color: var(--primary); border: 1.5px solid var(--primary); font-weight: 600; font-size: var(--t-sm); padding: 0; height: 40px; line-height: 40px; border-radius: var(--r-card); text-decoration: none; transition: background .2s, color .2s; }
.tour-card:hover .tour-card__btn, .tour-card__btn:hover { background: var(--primary); color: #fff; border-color: var(--primary); }

/* Social Proof Trust Bar */
.tours-trust-bar { display: flex; align-items: center; justify-content: space-between; background: var(--white); border: 1px solid var(--border); border-radius: .8rem; padding: 1rem 1.75rem; margin-top: 32px !important; margin-bottom: 32px !important; box-shadow: 0 4px 12px rgba(0,0,0,.025); }
.tours-trust-item { display: flex; align-items: center; gap: .55rem; font-size: .88rem; color: var(--text); }
.tours-trust-stars { color: #f5a623; font-size: 1.05rem; letter-spacing: 1px; line-height: 1; }
.tours-trust-text { color: var(--text-light); }
.tours-trust-text strong { color: var(--text); font-weight: 700; }
.tours-trust-item svg, .tours-trust-item .ico { color: var(--primary); width: 16px; height: 16px; display: inline-block; }
.tours-trust-divider { width: 1px; height: 24px; background: var(--border); }

@media (max-width: 768px) {
	.tours-toolbar { padding: 1rem; }
	.tours-toolbar__main { flex-direction: column; align-items: stretch; }
	.tours-filters { gap: .5rem; }
	.tours-filters select { flex: 1 1 45%; min-width: 0; }
	.tours-sort { justify-content: space-between; }
	.tours-chips-label { min-width: 100%; margin-bottom: .2rem; }
	
	.tours-trust-bar { flex-direction: column; align-items: flex-start; gap: .85rem; padding: 1.25rem 1.15rem; }
	.tours-trust-divider { display: none; }
}

/* Split-Screen Hero USPs Columns */
.archive-hero__usps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; margin-top: 1.5rem; margin-bottom: 2rem; width: 100%; }
.archive-hero__usp { display: flex; gap: 0.75rem; align-items: flex-start; }
.archive-hero__usp-icon { color: var(--primary); margin-top: 2px; flex-shrink: 0; }
.archive-hero__usp-content { display: flex; flex-direction: column; }
.archive-hero__usp-content strong { font-size: 0.95rem; font-weight: 700; color: var(--text); margin-bottom: 0.2rem; }
.archive-hero__usp-content span { font-size: 0.85rem; color: var(--text-light); line-height: 1.4; }

/* TripAdvisor Interactive Tooltip */
.tours-trust-item--tripadvisor { position: relative; cursor: pointer; }
.tours-trust-tooltip { position: absolute; bottom: calc(100% + 12px); left: 50%; transform: translateX(-50%) scale(0.95); opacity: 0; pointer-events: none; z-index: 99; width: 280px; background: #1a252f; border: 1px solid #2c3e50; border-radius: 8px; padding: 16px; box-shadow: 0 10px 30px rgba(0,0,0,0.15); transition: opacity 0.2s, transform 0.2s; text-align: left; }
.tours-trust-tooltip::after { content: ""; position: absolute; top: 100%; left: 50%; transform: translateX(-50%); border-width: 6px; border-style: solid; border-color: #1a252f transparent transparent transparent; }
.tours-trust-item--tripadvisor:hover .tours-trust-tooltip { opacity: 1; transform: translateX(-50%) scale(1); pointer-events: auto; }
.tours-trust-tooltip__title { font-size: 13px; font-weight: 700; color: #fff; border-bottom: 1px solid #2c3e50; padding-bottom: 6px; margin-bottom: 10px; text-transform: uppercase; letter-spacing: 0.5px; }
.tours-trust-tooltip__reviews { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.tours-trust-tooltip__reviews li { border-bottom: 1px solid rgba(255,255,255,0.06); padding-bottom: 8px; }
.tours-trust-tooltip__reviews li:last-child { border-bottom: none; padding-bottom: 0; }
.tours-trust-tooltip__meta { display: flex; justify-content: space-between; align-items: center; margin-bottom: 4px; }
.tours-trust-tooltip__meta .stars { color: #f5a623; font-size: 11px; }
.tours-trust-tooltip__meta .author { color: #a5b1c2; font-size: 11px; font-weight: 500; }
.tours-trust-tooltip__reviews .quote { margin: 0; font-size: 12px; line-height: 1.4; color: #fff; font-style: italic; }

/* Tour Card Tags */
.tour-card__body .tour-card__tags { position: static; display: flex; gap: 0.4rem; margin-bottom: 0.5rem; flex-wrap: wrap; }
.tour-card__body .tour-card__tag { font-size: 11px; font-weight: 600; color: var(--primary); background: var(--primary-tint); padding: 2px 8px; border-radius: var(--r-badge); text-transform: uppercase; letter-spacing: 0.5px; display: inline-block; }

/* Tour Card Specifications (AI Structured Data & Humans Scanning) */
.tour-card__specs { border-top: 1px dashed var(--border); border-bottom: 1px dashed var(--border); padding: 0.75rem 0; margin: 0.8rem 0; display: flex; flex-direction: column; gap: 0.35rem; }
.tour-card__spec { display: flex; justify-content: space-between; font-size: 12px; color: var(--text-light); }
.tour-card__spec strong { font-weight: 600; color: var(--text); }
.tour-card__spec span { text-align: right; }

@media (max-width: 768px) {
	.archive-hero__usps { grid-template-columns: 1fr; gap: 1rem; margin-top: 1.25rem; }
}

/* Editorial Magazine Layout & Spacing Options */
.editorial-split { display: grid; grid-template-columns: 1fr; gap: 3rem; align-items: center; }
@media (min-width: 768px) {
	.editorial-split { grid-template-columns: 1.25fr 0.75fr; gap: 5rem; }
}

.premium-editorial-grid { display: grid; grid-template-columns: 1fr; gap: 2.5rem; }
@media (min-width: 768px) {
	.premium-editorial-grid { grid-template-columns: repeat(2, 1fr); }
}



.archive-semantic-highlights { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; margin-top: 1rem; margin-bottom: 3.5rem; border-top: 1px solid var(--border); padding-top: 2.5rem; }
.highlight-node { display: flex; gap: 1rem; align-items: flex-start; }
.node-icon { color: var(--primary); background: var(--primary-tint); width: 38px; height: 38px; border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.node-icon svg, .node-icon .ico { width: 18px; height: 18px; }
.node-content h3 { font-size: 0.95rem; font-weight: 700; color: var(--text); margin: 0 0 0.5rem; }
.node-content p { font-size: 0.88rem; color: var(--text-light); line-height: 1.55; margin: 0; }
@media (max-width: 992px) {
	.archive-semantic-highlights { grid-template-columns: 1fr; gap: 1.5rem; }
}

.body-text-airy, .body-text-airy p { font-size: 1.05rem; line-height: 1.65; color: var(--text-light) !important; }
.h1-editorial { font-size: clamp(2.4rem, 5vw, 3.4rem) !important; }
.section-title-editorial { font-family: 'Montserrat', 'Inter', sans-serif; font-size: 1.85rem; font-weight: 800; color: var(--text); margin: 3.5rem 0 1.5rem; position: relative; padding-bottom: 0.6rem; }
.section-title-editorial::after { content: ""; position: absolute; bottom: 0; left: 0; width: 50px; height: 3px; background: var(--primary); border-radius: 2px; }

/* Editorial Activity and Glance Section Styles */
.archive-editorial-section { margin: 5rem 0; }
.editorial-sec-title { font-family: 'Montserrat', 'Inter', sans-serif; font-size: 1.85rem; font-weight: 800; color: var(--text); margin: 0 0 2rem; position: relative; padding-bottom: 0.6rem; }
.editorial-sec-title::after { content: ""; position: absolute; bottom: 0; left: 0; width: 50px; height: 3px; background: var(--primary); border-radius: 2px; }

/* Glance Section styling */
.glance-container { display: grid; grid-template-columns: 1fr 1.25fr; gap: 3.5rem; align-items: center; background: var(--white); border: 1px solid var(--border); border-radius: 12px; padding: 2.5rem; box-shadow: 0 10px 30px rgba(0,0,0,0.02); }
.glance-image { border-radius: 8px; overflow: hidden; aspect-ratio: 16/10; width: 100%; height: 100%; box-shadow: 0 5px 15px rgba(0,0,0,0.05); }
.glance-image img { width: 100%; height: 100%; object-fit: cover; display: block; }
.glance-text p { font-size: 1rem; line-height: 1.7; color: var(--text-light); margin: 0 0 1rem; }
.glance-text p:last-child { margin-bottom: 0; }
.glance-text strong { color: var(--text); font-weight: 700; }

/* Epic Activities Column Rows */
.activity-nodes { display: flex; flex-direction: column; gap: 4.5rem; }
.activity-node { display: grid; grid-template-columns: 1fr 1fr; gap: 4.5rem; align-items: center; }
.activity-node__image { border-radius: 12px; overflow: hidden; aspect-ratio: 16 / 10; width: 100%; height: 100%; box-shadow: 0 8px 25px rgba(0,0,0,0.05); }
.activity-node__image img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.5s ease; }
.activity-node:hover .activity-node__image img { transform: scale(1.03); }
.activity-node__content { display: flex; flex-direction: column; align-items: flex-start; }
.activity-number { font-size: 2.2rem; font-weight: 800; color: var(--primary-tint); line-height: 1; margin-bottom: 0.5rem; font-family: 'Montserrat', sans-serif; letter-spacing: -1px; }
.activity-node__content h3 { font-family: 'Montserrat', 'Inter', sans-serif; font-size: 1.45rem; font-weight: 800; color: var(--text); margin: 0 0 1rem; }
.activity-node__content p { font-size: 0.98rem; line-height: 1.65; color: var(--text-light); margin: 0; }

/* Stacking and Staggering adjustments */
@media (min-width: 993px) {
	.editorial-row-reverse { grid-template-columns: 1fr 1fr; }
	.editorial-row-reverse .activity-node__image { order: 2; }
	.editorial-row-reverse .activity-node__content { order: 1; }
}

@media (max-width: 992px) {
	.glance-container { grid-template-columns: 1fr; gap: 2rem; padding: 1.5rem; }
	.activity-nodes { gap: 3.5rem; }
	.activity-node { grid-template-columns: 1fr; gap: 1.5rem; }
	.activity-node__content { order: 2; }
	.activity-node__image { order: 1; }
	.archive-editorial-section { margin: 3.5rem 0; }
}

/* Bottom CTA Banner styling (Minimalist White Canvas Redesign) */
.editorial-cta-banner {
	background: transparent !important;
	color: var(--text) !important;
	padding: 6rem 0 !important;
	text-align: center;
	border-radius: 0 !important;
	margin: 5rem 0 0 0 !important;
	box-shadow: none !important;
}
.cta-banner__inner {
	max-width: 960px;
	margin: 0 auto;
	padding: 0 24px;
}
.cta-banner__inner h2 {
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	font-size: clamp(2rem, 4vw, 2.75rem) !important;
	font-weight: 700;
	margin: 0 0 1.25rem !important;
	color: #1A1A1A !important;
	letter-spacing: -0.02em;
}
.cta-banner__subtitle {
	color: #555555 !important;
	font-size: 1.1rem !important;
	line-height: 1.65;
	margin: 0 auto 4rem auto !important;
	max-width: 700px;
}
.editorial-cta-steps {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 3rem;
	margin-bottom: 4rem;
	text-align: center;
}
.cta-step-card {
	background: transparent !important;
	border: none !important;
	padding: 0 !important;
	border-radius: 0 !important;
	box-shadow: none !important;
}
.cta-step-card .step-num {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	border-radius: 50%;
	background: #14171A !important;
	color: #FFFFFF !important;
	font-size: 0.95rem;
	font-weight: 600;
	margin-bottom: 1.5rem;
}
.cta-step-card strong {
	display: block;
	font-family: 'Inter', sans-serif;
	font-size: 1.2rem;
	font-weight: 700;
	color: #1A1A1A !important;
	margin-bottom: 0.75rem;
}
.cta-step-card p {
	font-family: 'Inter', sans-serif;
	font-size: 0.92rem;
	color: #666666 !important;
	line-height: 1.6;
	margin: 0;
}
.cta-banner__action .btn {
	display: inline-block;
	padding: 1rem 2.5rem;
	font-size: 1rem;
	font-weight: 600;
	border-radius: 8px;
	text-decoration: none;
	transition: background-color 0.25s, opacity 0.25s;
	border: none;
}
.cta-banner__action .btn--primary {
	background: #14171A !important;
	color: #FFFFFF !important;
}
.cta-banner__action .btn--primary:hover {
	background: #2C3035 !important;
}

@media (max-width: 768px) {
	.editorial-cta-steps {
		grid-template-columns: 1fr;
		gap: 2.5rem;
		margin-bottom: 3rem;
	}
	.editorial-cta-banner {
		padding: 4rem 0 !important;
	}
}

/* ==========================================================================
   Quiet Luxury & Editorial Archive Redesign Overrides
   ========================================================================== */

/* 1. The Editorial Split-Hero */
.archive-hero {
	background-color: #FAF9F6 !important;
	background-image: none !important;
	padding: 5rem 0 7.5rem 0 !important; /* Extra bottom padding for comfortable spacing */
	border-bottom: none !important;
}
.archive-hero__container.editorial-split {
	display: grid;
	grid-template-columns: 1fr;
	gap: 3rem;
	align-items: center;
}
@media (min-width: 768px) {
	.archive-hero__container.editorial-split {
		grid-template-columns: 1.2fr 0.8fr;
		gap: 6rem; /* Generous gap/padding between text and image */
	}
}
.archive-hero__title.h1-editorial {
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	font-size: clamp(2.5rem, 5vw, 4rem) !important;
	font-weight: 800;
	color: #1A1A1A;
	margin-bottom: 1.5rem;
	line-height: 1.15;
	letter-spacing: -0.03em;
}
.archive-hero__desc.body-text-airy {
	font-family: 'Inter', 'Lora', Georgia, serif;
	font-size: 1.15rem;
	line-height: 1.75;
	color: #4A4A4A !important;
	margin-bottom: 2rem;
}
.archive-hero__usps-checkmark {
	display: flex;
	flex-wrap: wrap;
	gap: 0.65rem;
	margin: 0 0 2.25rem 0;
}
.usp-item {
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	background: #FFFFFF;
	border: 1px solid #E2E8F0;
	padding: 0.4rem 0.85rem;
	border-radius: 9999px;
	font-size: 0.85rem;
	font-weight: 500;
	color: #334155;
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.02);
	transition: all 0.2s ease;
}
.usp-item:hover {
	transform: translateY(-1px);
	border-color: #CBD5E1;
	box-shadow: 0 4px 6px rgba(0, 0, 0, 0.04);
	background: #F8FAFC;
}
.usp-check {
	color: #00AA6C; /* Elegant green */
	font-weight: bold;
	font-size: 0.95rem;
}
/* Compact Trust Pill Above Title */
.archive-hero__trust-pill {
	display: inline-flex;
	align-items: center;
	gap: 0.65rem;
	background: #FFFFFF;
	border: 1px solid #E2E8F0;
	padding: 0.45rem 0.9rem;
	border-radius: 9999px;
	text-decoration: none;
	color: #334155;
	font-size: 0.82rem;
	font-weight: 500;
	transition: all 0.2s ease;
	margin-bottom: 1.25rem;
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.02);
}
.archive-hero__trust-pill:hover {
	transform: translateY(-1px);
	border-color: #CBD5E1;
	box-shadow: 0 4px 6px rgba(0, 0, 0, 0.04);
	background: #F8FAFC;
	color: #1E293B;
}
.trust-pill__logo {
	display: flex;
	align-items: center;
}
.trust-pill__bubbles {
	display: inline-flex;
	align-items: center;
	margin-top: 1px;
}
.trust-pill__rating {
	color: #00AA6C;
}
.trust-pill__count {
	color: #64748B;
}

/* Secondary Ghost Button */
.btn--secondary {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.85rem 1.75rem;
	font-family: 'Inter', sans-serif;
	font-size: 0.95rem;
	font-weight: 700;
	border-radius: 8px;
	text-decoration: none;
	border: 1px solid rgba(26, 26, 26, 0.25) !important;
	color: #1A1A1A;
	background: transparent;
	transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
	cursor: pointer;
}
.btn--secondary:hover {
	background: rgba(26, 26, 26, 0.05);
	color: #1A1A1A;
	border-color: #1A1A1A !important;
	text-decoration: underline;
}

.archive-hero__actions-row {
	display: flex;
	align-items: center;
	gap: 1.25rem;
	flex-wrap: wrap;
	width: 100%;
}
@media (max-width: 480px) {
	.archive-hero__actions-row {
		flex-direction: column;
		align-items: stretch;
	}
	.archive-hero__actions-row .btn {
		width: 100%;
		text-align: center;
	}
}

.archive-hero__right .archive-hero__image-wrapper.framed-portrait {
	width: 100%;
	aspect-ratio: 3 / 4;
	overflow: hidden;
	border-radius: 12px; /* Soft, organically rounded corners */
	position: relative;
}
.archive-hero__right .archive-hero__image-wrapper.framed-portrait img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* Image Metadata Overlay */
.archive-hero__image-overlay {
	position: absolute;
	bottom: 1.25rem;
	left: 1.25rem;
	right: auto; /* Allow overlay to shrink wrap */
	width: calc(100% - 2.5rem);
	max-width: 250px; /* Reduced width */
	background: rgba(255, 255, 255, 0.82);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	border: 1px solid rgba(255, 255, 255, 0.4);
	border-radius: 8px;
	padding: 0.85rem 1.15rem; /* Reduced padding */
	box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08);
	transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
	transform: translateY(0);
}
.archive-hero__image-wrapper.framed-portrait:hover .archive-hero__image-overlay {
	transform: translateY(-4px);
	box-shadow: 0 15px 35px rgba(0, 0, 0, 0.12);
	background: rgba(255, 255, 255, 0.88);
}
.image-overlay__content {
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
}
.image-overlay__tag {
	font-family: 'Inter', sans-serif;
	font-size: 0.7rem;
	font-weight: 700;
	color: #64748B;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}
.image-overlay__title {
	font-family: 'Inter', sans-serif;
	font-size: 1.25rem;
	font-weight: 700;
	color: #1E293B;
	margin: 0;
	line-height: 1.3;
	letter-spacing: -0.01em;
}
.image-overlay__count {
	font-family: 'Inter', sans-serif;
	font-size: 0.85rem;
	font-weight: 500;
	color: #00AA6C;
}

@media (max-width: 768px) {
	.archive-hero__image-overlay {
		bottom: 1rem;
		left: 1rem;
		right: 1rem;
		padding: 0.85rem 1rem;
	}
	.image-overlay__title {
		font-size: 1.15rem;
	}
}

/* 2. The Minimalist Trust Bar */
.tours-trust-bar.minimalist-trust-bar {
	border: none !important;
	background: transparent !important;
	padding: 2.5rem 0 !important;
	margin: 0 !important;
	text-align: center;
}
.tours-trust-bar.minimalist-trust-bar .trust-text-line {
	font-family: 'Inter', sans-serif;
	font-size: 0.85rem;
	color: #7A7A7A;
	letter-spacing: 0.05em;
	line-height: 1.8;
}

/* 3. Core Narrative Pillars */
.archive-semantic-highlights.core-pillars {
	border: none !important;
	background: transparent !important;
	padding: 4rem 0 !important;
	margin: 0 !important;
	display: grid;
	grid-template-columns: 1fr;
	gap: 3rem;
}
@media (min-width: 768px) {
	.archive-semantic-highlights.core-pillars {
		grid-template-columns: repeat(3, 1fr);
		gap: 4rem;
	}
}
.archive-semantic-highlights.core-pillars .highlight-node {
	padding: 0 !important;
	border: none !important;
	background: transparent !important;
	box-shadow: none !important;
}
.archive-semantic-highlights.core-pillars .node-content h3 {
	font-family: 'Inter', sans-serif;
	font-size: 1.3rem;
	font-weight: 700;
	color: #1A1A1A;
	margin-bottom: 1rem;
	letter-spacing: -0.01em;
}
.archive-semantic-highlights.core-pillars .node-content p {
	font-family: 'Inter', sans-serif;
	font-size: 0.95rem;
	line-height: 1.65;
	color: #666666;
}

/* Hide editorial titles that clash with magazine feel */
.tours-section-title.section-title-editorial {
	display: none !important;
}

/* 4. The Journal Tour Grid */
.premium-editorial-grid {
	display: grid !important;
	grid-template-columns: 1fr !important;
	gap: 4rem 3.5rem !important;
	margin-bottom: 5rem;
}
@media (min-width: 768px) {
	.premium-editorial-grid {
		grid-template-columns: repeat(2, 1fr) !important;
	}
}

/* Tour Card Reset - Stripping card aesthetics */
.editorial-card.tour-card {
	background: transparent !important;
	border: none !important;
	box-shadow: none !important;
	border-radius: 0 !important;
	padding: 0 !important;
	margin: 0 !important;
	height: 100% !important;
	display: flex;
	flex-direction: column;
}
.editorial-card.tour-card .tour-card__media {
	width: 100%;
	aspect-ratio: 16 / 10 !important; /* Edge-to-edge landscape photo */
	overflow: hidden;
	border-radius: 8px; /* Organically rounded */
	margin-bottom: 1.5rem;
}
.editorial-card.tour-card .tour-card__media img {
	width: 100% !important;
	height: 100% !important;
	object-fit: cover !important;
	transition: transform 0.6s cubic-bezier(0.25, 1, 0.5, 1);
}
.editorial-card.tour-card:hover .tour-card__media img {
	transform: scale(1.03);
}
.editorial-card.tour-card .tour-card__body {
	padding: 0 !important;
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	flex-grow: 1;
}
.editorial-card.tour-card .tour-card__title {
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	font-size: 1.4rem;
	font-weight: 700;
	line-height: 1.3;
	color: #1A1A1A;
	margin: 0 0 0.75rem 0 !important;
	min-height: auto;
	letter-spacing: -0.02em;
}
.editorial-card.tour-card .tour-card__title a {
	color: inherit;
	text-decoration: none;
}
.editorial-card.tour-card .tour-card__title a::after {
	display: none; /* remove pointer event overlay to allow clean text interaction */
}
.editorial-card.tour-card .tour-card__excerpt {
	font-family: 'Inter', sans-serif;
	font-size: 0.95rem;
	line-height: 1.6;
	color: #555555;
	margin: 0 0 1rem 0;
}
.editorial-card.tour-card .tour-card__action {
	font-family: 'Inter', sans-serif;
	font-size: 0.95rem;
	color: #666666;
	display: flex;
	align-items: center;
	gap: 0.5rem;
	margin-top: auto !important;
	padding-top: 0.5rem;
}
.editorial-card.tour-card .tour-card__action .amount {
	font-weight: 600;
	color: #1A1A1A;
	font-size: 0.95rem !important;
}
.editorial-card.tour-card .tour-card__action .sep {
	color: #CCCCCC;
}
.editorial-card.tour-card .tour-card__action .explore-link {
	color: #1A1A1A;
	text-decoration: none;
	font-weight: 500;
	transition: opacity 0.2s;
}
.editorial-card.tour-card .tour-card__action .explore-link:hover {
	opacity: 0.7;
}

/* 5. The Interstitial Narrative Break */
/* 5. The Interstitial Narrative Break */
.interstitial-brand-strip {
	width: 100% !important;
	background-color: #FFFFFF !important; /* Soft, seamless white block */
	color: #1A1A1A !important;
	padding: 5rem 0 !important; /* Vertical breathing room */
	margin: 5rem 0 !important;
	border-top: 1px solid #E2E8F0 !important;
	border-bottom: 1px solid #E2E8F0 !important;
}
.brand-strip__inner-wrap {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	background-color: transparent !important; /* No background on boxed layout wrapper */
	border-radius: 0;
	overflow: visible;
	padding: 0 !important;
}
.brand-strip__text-side {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	text-align: center;
	gap: 1.5rem;
	width: 100%;
	max-width: 760px;
}
.interstitial-brand-strip .brand-strip__subtitle {
	color: #64748B !important; /* Muted slate gray */
	font-size: 0.75rem !important;
	font-weight: 600;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	display: block;
	margin: 0 !important;
}
.interstitial-brand-strip .brand-strip__title {
	font-family: 'Inter', sans-serif;
	font-size: clamp(2rem, 3.5vw, 2.6rem) !important;
	font-weight: 700;
	line-height: 1.25;
	margin: 0 !important;
	color: #1A1A1A !important;
}
.interstitial-brand-strip .brand-strip__desc {
	font-family: 'Inter', sans-serif;
	font-size: 0.95rem !important;
	line-height: 1.65;
	color: #4A5568 !important;
	margin: 0 auto !important;
	max-width: 620px;
	text-align: center;
}
.interstitial-brand-strip .brand-strip__action {
	margin-top: 1rem;
}
.interstitial-brand-strip .brand-strip__link {
	font-family: 'Inter', sans-serif;
	font-size: 0.88rem !important;
	font-weight: 600;
	color: #FFFFFF !important; /* White text */
	background-color: var(--primary) !important; /* Brand green button */
	text-decoration: none;
	padding: 0.85rem 2.25rem;
	border-radius: 30px; /* Rounded pill button */
	transition: background-color 0.2s, transform 0.2s;
	display: inline-block;
}
.interstitial-brand-strip .brand-strip__link:hover {
	background-color: var(--primary-dark) !important;
	transform: translateY(-1px);
}

/* General Layout cleanup */
.tours-archive {
	background-color: #ffffff !important;
}

/* Redesign Section Separation Overrides */
.archive-hero {
	padding-bottom: 0 !important; /* Spacing handled by inner wrap */
}
/* Container styling to replace the crossed-out section */
.tours-trust-bar-editorial {
    width: 100%;
    background-color: #ffffff; /* Keep it pure white to bleed seamlessly into the grid */
    padding: 2.5rem 0; /* Generous vertical whitespace to give it a luxury cushion */
    border-bottom: 1px solid #f4f4f2; /* Ultra-faint separating baseline */
}

/* Flex layout to keep it beautifully spaced inline */
.tours-trust-bar-editorial__container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap; /* Graceful stacking on smaller mobile screens */
    gap: 1.5rem;
}

/* Individual item typography settings */
.trust-editorial-item {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    font-size: 0.875rem;
    color: #4b5563; /* Soft, readable slate gray */
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.trust-editorial-item strong {
    color: #111827; /* Deep charcoal for critical data numbers */
    font-weight: 600;
}

.trust-icon-wrapper {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--primary-dark); /* Monochromatic style using the brand's green accent */
}

.trust-icon-wrapper.star-icon {
    color: #f59e0b; /* Sophisticated amber tone for star metrics */
}

.trust-icon-wrapper svg {
    display: block;
}



/* Typographic Section Headings */
.section-title-wrapper {
	margin-top: 8rem !important; /* Generous vertical whitespace chapter break */
	margin-bottom: 4.5rem !important;
	text-align: center;
	display: block;
}
.section-title-label {
	display: block;
	font-family: 'Inter', sans-serif;
	font-size: 0.8rem;
	font-weight: 600;
	color: #999999;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	margin-bottom: 0.85rem;
}
.tours-section-title.section-title-editorial {
	display: block !important; /* Re-enable and show editorial titles */
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	font-size: clamp(2rem, 3.5vw, 2.50rem) !important;
	font-weight: 800;
	color: #1A1A1A;
	margin: 0 !important;
	padding-bottom: 0 !important;
	letter-spacing: -0.03em;
}
.tours-section-title.section-title-editorial::after {
	display: none !important; /* remove the old underline style */
}

/* Interstitial spacing alignment */
.interstitial-brand-strip {
	margin: 4.5rem 0 !important; /* Reduced from 8rem for better vertical rhythm */
}

/* Bottom CTA spacing alignment */
.editorial-cta-banner {
	margin: 4.5rem 0 0 0 !important; /* Reduced from 8rem */
	padding: 4.5rem 0 5.5rem 0 !important; /* Reduced from 6rem/8rem */
}

/* Tour Card Upgrades */
.editorial-card.tour-card .tour-card__media {
	position: relative !important;
}
.editorial-card.tour-card .tour-card__badge {
	position: absolute;
	top: 12px;
	left: 12px;
	z-index: 10;
	background: #FFFFFF !important;
	color: #1A1A1A !important;
	font-family: 'Inter', sans-serif;
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	padding: 4px 8px;
	border-radius: 2px;
	box-shadow: 0 2px 4px rgba(0,0,0,0.06);
	text-transform: uppercase;
}
.editorial-card.tour-card .tour-card__review-row {
	display: flex;
	align-items: center;
	gap: 0.35rem;
	font-family: 'Inter', sans-serif;
	font-size: 0.82rem;
	color: #666666;
	margin-bottom: 0.5rem;
	flex-wrap: wrap;
}
.editorial-card.tour-card .tour-card__review-row .star {
	color: #F5A623; /* Classic clean yellow/gold star */
	font-size: 0.9rem;
}
.editorial-card.tour-card .tour-card__review-row .rating {
	font-weight: 700;
	color: #1A1A1A;
}
.editorial-card.tour-card .tour-card__review-row .count {
	color: #888888;
}
.editorial-card.tour-card .tour-card__review-row .sep {
	color: #DDDDDD;
	margin: 0 2px;
}
.editorial-card.tour-card .tour-card__review-row .departure {
	color: #555555;
	font-weight: 500;
}
.editorial-card.tour-card .tour-card__action {
	justify-content: space-between !important;
	width: 100%;
}
.editorial-card.tour-card .twin-links {
	display: flex;
	align-items: center;
	gap: 0.5rem;
}
.editorial-card.tour-card .twin-links .sep {
	color: #CCCCCC;
}
.editorial-card.tour-card .twin-links .explore-link {
	font-family: 'Inter', sans-serif;
	font-size: 0.88rem !important;
	font-weight: 600;
	color: #1A1A1A;
	text-decoration: none;
	transition: opacity 0.2s;
}
.editorial-card.tour-card .twin-links .explore-link:hover {
	opacity: 0.7;
}

/* FAQ Accordion Styling */
.editorial-faq-section {
	width: 100% !important;
	background: #FAF9F6 !important;
	padding: 4.5rem 0 !important; /* Reduced from 8rem */
}
.faq-inner-wrap {
	max-width: 800px !important;
	margin: 0 auto;
	padding: 0 24px;
	text-align: center;
}
.faq-section-label {
	display: block;
	font-family: 'Inter', sans-serif;
	font-size: 0.8rem;
	font-weight: 600;
	color: #999999;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	margin-bottom: 0.85rem;
}
.faq-section-title {
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	font-size: clamp(2rem, 3.5vw, 2.50rem) !important;
	font-weight: 800;
	color: #1A1A1A;
	margin-bottom: 3.5rem !important;
	letter-spacing: -0.03em;
}
.faq-accordion {
	text-align: left;
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}
.faq-item {
	border-bottom: 1px solid #eeeeee;
	padding-bottom: 1.25rem;
	outline: none;
}
.faq-item[open] .faq-icon {
	transform: rotate(45deg);
}
.faq-trigger {
	font-family: 'Inter', sans-serif;
	font-size: 1.15rem;
	font-weight: 600;
	color: #1A1A1A;
	cursor: pointer;
	list-style: none; /* Hide default details marker */
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 0.5rem 0;
	letter-spacing: -0.01em;
}
.faq-trigger::-webkit-details-marker {
	display: none; /* Hide default webkit details marker */
}
.faq-question {
	flex-grow: 1;
	padding-right: 1.5rem;
}
.faq-icon {
	font-family: 'Inter', sans-serif;
	font-size: 1.4rem;
	color: #999999;
	transition: transform 0.25s ease;
	line-height: 1;
}
.faq-answer {
	padding: 0.75rem 0 0 0;
}
.faq-answer p {
	font-family: 'Inter', sans-serif;
	font-size: 0.95rem;
	line-height: 1.65;
	color: #666666;
	margin: 0;
}

/* Custom TripAdvisor rating badge under Explore Journeys */
.hero-tripadvisor-badge {
	display: inline-flex;
	align-items: center;
	gap: 0.75rem;
	row-gap: 0.5rem; /* Better vertical separation when flex items wrap */
	background: #FFFFFF;
	padding: 0.8rem 1.25rem; /* Comfortable padding on all sides */
	border-radius: 6px;
	margin-top: 1.25rem;
	cursor: pointer;
	color: #2D3748;
	font-family: 'Inter', sans-serif;
	font-size: 0.8rem;
	transition: background-color 0.2s, transform 0.2s, box-shadow 0.2s;
	border: 1px solid #E2E8F0;
	flex-wrap: wrap;
	box-shadow: 0 1px 3px rgba(0,0,0,0.02);
}
.hero-tripadvisor-badge:hover {
	background: #F8FAFC;
	border-color: #CBD5E1;
	transform: translateY(-1px);
	box-shadow: 0 4px 6px rgba(0,0,0,0.05);
}
.ta-badge-label {
	color: #64748B;
	font-weight: 400;
}
.ta-badge-rating-text {
	font-weight: 700;
	color: #00AA6C; /* TripAdvisor green for high contrast on white */
}
.ta-bubbles {
	display: inline-flex;
	gap: 3px;
	align-items: center;
}
.ta-bubble {
	width: 12px;
	height: 12px;
	border-radius: 50%;
	border: 2px solid #00AA6C;
	box-sizing: border-box;
	display: inline-block;
	background: transparent;
	position: relative;
}
.ta-bubble--full {
	background: #00AA6C;
	box-shadow: inset 0 0 0 2px #FFFFFF;
}
.ta-bubble--half {
	background: linear-gradient(90deg, #00AA6C 50%, transparent 50%);
	box-shadow: inset 0 0 0 2px #FFFFFF;
}
.ta-bubble--empty {
	background: #FFFFFF;
}
.ta-badge-meta {
	color: #334155;
}
.ta-badge-brand {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	border-left: 1px solid #E2E8F0;
	padding-left: 0.75rem;
	color: #334155;
}
.ta-logo {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
}
.ta-logo svg {
	fill: #00AA6C; /* TripAdvisor Owl logo green */
	width: 16px;
	height: 16px;
}
.ta-logo-text {
	font-weight: 700;
	font-family: 'Inter', sans-serif;
	letter-spacing: -0.03em;
	font-size: 0.85rem;
	color: #2D3748;
}

/* ==========================================================================
   Responsive Mobile Redesign Overrides (max-width: 768px)
   ========================================================================== */
@media (max-width: 768px) {
	/* 1. Hero Layout Overrides */
	.archive-hero {
		padding: 3rem 0 4rem 0 !important;
	}
	.archive-hero__container.editorial-split {
		grid-template-columns: 1fr !important;
		gap: 2.5rem !important;
	}
	.archive-hero__title.h1-editorial {
		font-size: 2.2rem !important;
		margin-bottom: 1rem !important;
	}
	.archive-hero__desc.body-text-airy {
		font-size: 1.05rem !important;
		line-height: 1.65 !important;
		margin-bottom: 2rem !important;
	}
	
	/* Adjust Hero Portrait Image to be more compact on Mobile */
	.archive-hero__right .archive-hero__image-wrapper.framed-portrait {
		aspect-ratio: 16 / 10 !important; /* Switch to landscape to prevent taking too much vertical space */
		max-height: 280px !important;
	}

	/* TripAdvisor Badge Adjustments */
	.hero-tripadvisor-badge {
		padding: 0.6rem 1rem !important;
		font-size: 0.75rem !important;
		gap: 0.5rem !important;
		row-gap: 0.4rem !important;
		width: 100% !important;
		justify-content: center !important;
		box-sizing: border-box !important;
	}
	.ta-badge-meta {
		text-align: center !important;
	}

	/* 2. Core Pillars & Trust Bar Overrides */
	.archive-semantic-highlights.core-pillars {
		padding: 2.5rem 0 !important;
		gap: 2rem !important;
	}
	.archive-semantic-highlights.core-pillars .node-content h3 {
		font-size: 1.25rem !important;
		margin-bottom: 0.75rem !important;
	}
	.tours-trust-bar-editorial {
		padding: 1.5rem 0 !important;
	}
	.tours-trust-bar-editorial__container {
		justify-content: center !important;
		gap: 1.25rem !important;
	}
	.trust-editorial-item {
		font-size: 0.8rem !important;
	}

	/* 3. Tour Grid & Card Overrides */
	.premium-editorial-grid {
		gap: 2.5rem 2rem !important;
		margin-bottom: 3rem !important;
	}
	.editorial-card.tour-card .tour-card__title {
		font-size: 1.35rem !important;
		margin-bottom: 0.5rem !important;
	}
	.editorial-card.tour-card .tour-card__excerpt {
		font-size: 0.9rem !important;
		line-height: 1.5 !important;
		margin-bottom: 0.75rem !important;
	}
	.editorial-card.tour-card .tour-card__action {
		padding-top: 0.35rem !important;
		flex-direction: row !important;
		flex-wrap: wrap !important;
		gap: 0.75rem !important;
	}
	.editorial-card.tour-card .tour-card__review-row {
		font-size: 0.78rem !important;
		gap: 0.25rem !important;
	}

	/* 4. Interstitial Brand Break */
	.interstitial-brand-strip {
		padding: 3.5rem 0 !important;
		margin: 4rem 0 !important;
	}
	.brand-strip__text-side {
		gap: 1.25rem !important;
	}
	.interstitial-brand-strip .brand-strip__title {
		font-size: 1.75rem !important;
	}
	.interstitial-brand-strip .brand-strip__desc {
		font-size: 0.9rem !important;
		line-height: 1.6 !important;
	}
	.interstitial-brand-strip .brand-strip__link {
		padding: 0.7rem 1.75rem !important;
		font-size: 0.8rem !important;
	}

	/* 5. FAQ Accordion */
	.editorial-faq-section {
		padding: 4rem 0 !important;
	}
	.faq-section-title {
		font-size: 1.75rem !important;
		margin-bottom: 2rem !important;
	}
	.faq-trigger {
		font-size: 1.05rem !important;
	}
	.faq-answer p {
		font-size: 0.9rem !important;
	}

	/* 6. Section Title Wrapper */
	.section-title-wrapper {
		margin-top: 4rem !important;
		margin-bottom: 2.5rem !important;
	}
	.tours-section-title.section-title-editorial {
		font-size: 1.65rem !important;
	}

	/* 7. CTA Banner */
	.editorial-cta-banner {
		margin-top: 4rem !important;
		padding: 4rem 0 !important;
	}
	.cta-banner__inner h2 {
		font-size: 1.85rem !important;
	}
	.cta-banner__subtitle {
		font-size: 1rem !important;
		margin-bottom: 2.5rem !important;
	}

	/* 8. Footer Mobile Redesign */
	.site-footer .footer-top {
		padding: 3.5rem 0 2rem 0 !important;
	}
	.site-footer .footer-grid {
		grid-template-columns: 1fr 1fr !important;
		gap: 2rem 1.5rem !important;
	}
	.site-footer .footer-brand {
		grid-column: 1 / -1 !important;
		margin-bottom: 1rem !important;
	}
	.site-footer .footer-col h4 {
		font-size: 0.88rem !important;
		margin-bottom: 0.85rem !important;
		padding-bottom: 0.35rem !important;
	}
	.site-footer .footer-link-list a,
	.site-footer .footer-contact-list a,
	.site-footer .footer-address {
		font-size: 0.85rem !important;
	}
	.site-footer .footer-bottom {
		padding: 1.5rem 0 !important;
	}
	.site-footer .footer-bottom__inner {
		flex-direction: column !important;
		align-items: center !important;
		text-align: center !important;
		gap: 1.25rem !important;
	}
	.site-footer .footer-copyright {
		font-size: 0.8rem !important;
	}
	.site-footer .footer-bottom__right {
		width: 100% !important;
		justify-content: center !important;
		margin: 0 !important;
	}
	.site-footer .we-accept-logos {
		justify-content: center !important;
		width: 100% !important;
	}

	/* 9. Mobile Header Navigation - Native App Drawer */
	.mobile-nav-footer {
		display: block !important;
		margin-top: auto !important;
		padding-top: 2.5rem !important;
		width: 100% !important;
	}
	.btn--mobile-cta {
		width: 100% !important;
		background: var(--brand-green) !important;
		color: #ffffff !important;
		height: 48px !important;
		font-size: 1rem !important;
		font-weight: 600 !important;
		border-radius: 8px !important;
		box-shadow: 0 4px 12px rgba(4,104,57,0.15) !important;
		text-align: center;
	}
}

@media (max-width: 540px) {
	/* Stack footer columns vertically on narrow screens to prevent text overflow */
	.site-footer .footer-grid {
		grid-template-columns: 1fr !important;
		gap: 2rem !important;
	}
	.site-footer .footer-brand {
		margin-bottom: 0.5rem !important;
	}
}

/* Hide mobile CTA and toggle buttons on desktop */
.mobile-nav-footer,
.sub-menu-toggle {
	display: none;
}

/* ==========================================================================
   Homepage UI/UX Layout Styles (Split Hero & Differences)
   ========================================================================== */

/* 1. Header Navigation Cleanup */
.site-header {
	background: rgba(255, 255, 255, 0.85) !important;
	backdrop-filter: blur(10px) !important;
	-webkit-backdrop-filter: blur(10px) !important;
	border-bottom: 1px solid rgba(0, 0, 0, 0.05) !important;
	box-shadow: 0 2px 10px rgba(0,0,0,0.02) !important;
}
.main-menu a {
	font-family: 'Inter', sans-serif !important;
	font-size: 14px !important;
	font-weight: 500 !important;
	color: #2D3748 !important;
	padding: 0 14px !important;
}
.main-menu a:hover {
	color: var(--brand-green) !important;
}
.btn--header-quote {
	border-radius: 6px !important;
	font-size: 13px !important;
	font-weight: 600 !important;
	letter-spacing: 0.02em;
	padding: 8px 18px !important;
	text-transform: uppercase;
}

/* 2. Homepage Split Hero */
.homepage-hero {
	position: relative !important;
	background-position: center right !important;
	background-size: cover !important;
	background-repeat: no-repeat !important;
	min-height: 80vh !important;
	display: flex !important;
	align-items: center !important;
	padding: 6rem 0 !important;
}
.homepage-hero__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(90deg, rgba(17, 27, 36, 0.9) 0%, rgba(17, 27, 36, 0.6) 45%, rgba(17, 27, 36, 0.25) 100%) !important;
	z-index: 1;
}
.homepage-hero__container {
	position: relative;
	z-index: 2;
	width: 100%;
}
.homepage-hero__content {
	max-width: 620px;
	text-align: left;
}
.homepage-hero__title {
	font-family: 'Inter', sans-serif !important;
	font-size: clamp(2.2rem, 4.5vw, 3.4rem) !important;
	font-weight: 700 !important;
	line-height: 1.2 !important;
	color: #ffffff !important;
	margin: 0 0 1.5rem 0 !important;
}
.homepage-hero__desc {
	font-family: 'Inter', sans-serif !important;
	font-size: 1.08rem !important;
	line-height: 1.65 !important;
	color: rgba(255, 255, 255, 0.9) !important;
	margin: 0 0 2.5rem 0 !important;
}
.btn--hero-discover {
	display: inline-block !important;
	background: #3B7A57 !important; /* Premium brand forest green */
	color: #ffffff !important;
	font-family: 'Inter', sans-serif;
	font-size: 0.95rem !important;
	font-weight: 600 !important;
	padding: 1rem 2.25rem !important;
	border-radius: 30px !important; /* Elegant pill button */
	text-decoration: none;
	transition: background-color 0.25s, transform 0.2s;
	box-shadow: 0 4px 14px rgba(0, 0, 0, 0.15);
}
.btn--hero-discover:hover {
	background: #2E5C41 !important;
	transform: translateY(-1px);
}

/* 3. The Lucy Difference Section */
.section-difference {
	background-color: #FAF9F6 !important; /* Soft warm ivory sand background */
	padding: 6rem 0 !important;
}
.difference-section-title {
	font-family: 'Inter', sans-serif !important;
	font-size: clamp(2rem, 3.5vw, 2.5rem) !important;
	font-weight: 700 !important;
	color: #111827;
	text-align: center;
	margin: 0 0 4.5rem 0 !important;
	letter-spacing: -0.02em;
}
.difference-grid {
	display: grid;
	grid-template-columns: 1fr 1fr !important; /* 2 columns design */
	gap: 2rem 2.25rem !important;
	max-width: 1080px;
	margin: 0 auto;
}
.difference-card {
	background: #ffffff !important;
	border: 1px solid #EAEAEA !important;
	border-radius: 24px !important; /* Very round corners */
	padding: 2.5rem 2.25rem !important;
	display: flex !important;
	flex-direction: column !important;
	transition: transform 0.25s ease, box-shadow 0.25s ease !important;
	box-shadow: 0 4px 25px rgba(0,0,0,0.01) !important;
}
.difference-card:hover {
	transform: translateY(-4px) !important;
	box-shadow: 0 12px 30px rgba(0,0,0,0.03) !important;
}
.difference-card__header {
	display: flex !important;
	justify-content: space-between !important;
	align-items: center !important;
	margin-bottom: 1.75rem !important;
	width: 100%;
}
.difference-card__icon-badge {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 52px !important;
	height: 52px !important;
	border-radius: 12px !important;
	background: #E8EFE9 !important; /* Sage green badge background */
	color: #3B7A57 !important;
}
.difference-card__status-badge {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 38px !important;
	height: 38px !important;
	border-radius: 50% !important;
	background: #E8EFE9 !important; /* Circular status background */
	color: #3B7A57 !important;
	border: 1px solid rgba(59, 122, 87, 0.08) !important;
}
.difference-card h3 {
	font-family: 'Inter', sans-serif !important;
	font-size: 1.25rem !important;
	font-weight: 600 !important;
	color: #111827 !important;
	margin: 0 0 0.85rem 0 !important;
	letter-spacing: -0.015em;
}
.difference-card p {
	font-family: 'Inter', sans-serif !important;
	font-size: 0.95rem !important;
	line-height: 1.65 !important;
	color: #4B5563 !important;
	margin: 0 !important;
}

/* 4. Mobile Overrides */
@media (max-width: 992px) {
	.difference-grid {
		grid-template-columns: repeat(2, 1fr) !important;
		gap: 1.5rem !important;
	}
}

@media (max-width: 768px) {
	.homepage-hero {
		min-height: 60vh !important;
		padding: 5rem 0 !important;
	}
	.homepage-hero__overlay {
		background: linear-gradient(180deg, rgba(17, 27, 36, 0.8) 0%, rgba(17, 27, 36, 0.9) 100%) !important;
	}
	.homepage-hero__content {
		text-align: center !important;
		margin: 0 auto !important;
	}
	.homepage-hero__title {
		font-size: 2.2rem !important;
	}
	.homepage-hero__desc {
		font-size: 1rem !important;
		margin-bottom: 2rem !important;
	}
	.section-difference {
		padding: 4rem 0 !important;
	}
	.difference-section-title {
		margin-bottom: 2.5rem !important;
	}
}

@media (max-width: 540px) {
	.difference-grid {
		grid-template-columns: 1fr !important;
		gap: 1.25rem !important;
	}
	.difference-card {
		padding: 1.75rem 1.5rem !important;
	}
}

/* ==========================================================================
   Tour Archive Grid & Card Overrides (Mockup Style)
   ========================================================================== */

@media (min-width: 992px) {
	.premium-editorial-grid {
		grid-template-columns: repeat(3, 1fr) !important;
		gap: 2rem 1.75rem !important;
	}
}

.tour-card.mockup-card {
	background: #ffffff !important;
	border: 1px solid #EAEAEA !important;
	border-radius: 8px !important;
	padding: 0 !important;
	overflow: hidden !important;
	display: flex !important;
	flex-direction: column !important;
	height: 100% !important;
	box-shadow: 0 4px 15px rgba(0,0,0,0.03) !important;
	transition: transform 0.25s ease, box-shadow 0.25s ease !important;
	box-sizing: border-box !important;
}
.tour-card.mockup-card:hover {
	transform: translateY(-4px) !important;
	box-shadow: 0 12px 28px rgba(0,0,0,0.07) !important;
}
.tour-card__media-wrap {
	position: relative !important;
	width: 100% !important;
	aspect-ratio: 1.5 / 1 !important;
	overflow: hidden !important;
	border-radius: 0 !important;
	margin-bottom: 1.25rem !important;
}
.tour-card__image-link {
	display: block !important;
	width: 100% !important;
	height: 100% !important;
}
.tour-card__highlight-badge {
	position: absolute !important;
	top: 12px !important;
	left: 12px !important;
	z-index: 5 !important;
	font-family: 'Inter', sans-serif !important;
	font-size: 0.7rem !important;
	font-weight: 600 !important;
	letter-spacing: 0.03em !important;
	padding: 5px 12px !important;
	border-radius: 20px !important;
	text-transform: uppercase !important;
	transition: all 0.2s ease !important;
}
.tour-card__highlight-badge.badge--featured {
	background: #D4A017 !important;
	color: #FFFFFF !important;
	box-shadow: 0 4px 12px rgba(212, 160, 23, 0.25) !important;
}
.tour-card__highlight-badge.badge--subdued {
	background: rgba(255, 255, 255, 0.85) !important;
	backdrop-filter: blur(8px) !important;
	-webkit-backdrop-filter: blur(8px) !important;
	color: #111827 !important;
	border: 1px solid rgba(255, 255, 255, 0.4) !important;
	box-shadow: 0 4px 10px rgba(0, 0, 0, 0.04) !important;
}
.tour-card__image {
	width: 100% !important;
	height: 100% !important;
	object-fit: cover !important;
	display: block !important;
	transition: transform 0.4s ease !important;
}
.tour-card.mockup-card:hover .tour-card__image {
	transform: scale(1.03) !important;
}
.tour-card__content {
	display: flex !important;
	flex-direction: column !important;
	flex-grow: 1 !important;
	gap: 0.85rem !important;
	padding: 0 1.25rem 1.25rem 1.25rem !important;
}
.tour-card.mockup-card .tour-card__title {
	font-family: 'Inter', sans-serif !important;
	font-size: 1.2rem !important;
	font-weight: 700 !important;
	line-height: 1.35 !important;
	color: #111827 !important;
	margin: 0 !important;
}
.tour-card.mockup-card .tour-card__title a {
	color: inherit !important;
	text-decoration: none !important;
}
/* Tour card rating row */
.tour-card__rating { display: flex; align-items: center; gap: 6px; margin: 8px 0 4px; font-size: 13px; }
.tour-card__stars { color: var(--color-star, #ffb800); letter-spacing: 1px; font-size: 14px; line-height: 1; }
.tour-card__rating-num { font-weight: 700; color: var(--text); }
.tour-card__rating-count { color: var(--text-light); }
.tour-card__meta-pills {
	display: flex !important;
	gap: 0.5rem !important;
	flex-wrap: wrap !important;
	margin-bottom: 0.5rem !important;
}
.meta-pill {
	display: inline-flex !important;
	align-items: center !important;
	gap: 0.35rem !important;
	background: #F3F4F6 !important;
	color: #4B5563 !important;
	font-family: 'Inter', sans-serif !important;
	font-size: 0.78rem !important;
	font-weight: 500 !important;
	padding: 4px 12px !important;
	border-radius: 999px !important;
}
.meta-pill svg {
	color: #6B7280 !important;
}
.tour-card__footer {
	display: flex !important;
	justify-content: space-between !important;
	align-items: center !important;
	margin-top: auto !important;
	padding-top: 1rem !important;
	border-top: 1px dashed #EAEAEA !important;
}
.tour-card__price {
	font-family: 'Inter', sans-serif !important;
	font-size: 0.95rem !important;
	font-weight: 700 !important;
	color: #111827 !important;
}
.btn--tour-view {
	background: #3B7A57 !important;
	color: #ffffff !important;
	font-family: 'Inter', sans-serif !important;
	font-size: 0.82rem !important;
	font-weight: 600 !important;
	padding: 8px 18px !important;
	border-radius: 20px !important;
	text-decoration: none !important;
	transition: background-color 0.2s !important;
	line-height: 1.2 !important;
}
.btn--tour-view:hover {
	background: #2E5C41 !important;
}

/* FAQ Accordion Styles cleaned up and unified globally */

/* Floating Sticky CTA */
.floating-sticky-cta {
	position: fixed !important;
	bottom: 24px !important;
	right: 200px !important; /* Shifted left to clear floating WhatsApp button */
	z-index: 9999 !important;
	opacity: 0 !important;
	visibility: hidden !important;
	transform: translateY(20px) !important;
	transition: opacity 0.3s ease, transform 0.3s ease, visibility 0.3s ease !important;
}
.floating-sticky-cta.is-visible {
	opacity: 1 !important;
	visibility: visible !important;
	transform: translateY(0) !important;
}
.btn--sticky-cta {
	background: #00AA6C !important; /* Elegant TripAdvisor-matched active emerald green */
	color: #FFFFFF !important;
	padding: 0.9rem 1.6rem !important;
	border-radius: 50px !important;
	font-weight: 600 !important;
	font-size: 0.95rem !important;
	display: inline-flex !important;
	align-items: center !important;
	gap: 0.6rem !important;
	box-shadow: 0 10px 25px rgba(0, 170, 108, 0.25) !important;
	text-decoration: none !important;
	border: none !important;
	transition: background-color 0.2s, transform 0.2s, box-shadow 0.2s !important;
}
.btn--sticky-cta:hover {
	background: #008C5E !important;
	transform: translateY(-2px) !important;
	box-shadow: 0 12px 30px rgba(0, 170, 108, 0.35) !important;
}
.cta-pulse-indicator {
	width: 8px !important;
	height: 8px !important;
	background-color: #FFFFFF !important;
	border-radius: 50% !important;
	display: inline-block !important;
	box-shadow: 0 0 0 0 rgba(255, 255, 255, 0.7) !important;
	animation: cta-pulse 1.6s infinite !important;
}
@keyframes cta-pulse {
	0% {
		transform: scale(0.95);
		box-shadow: 0 0 0 0 rgba(255, 255, 255, 0.7);
	}
	70% {
		transform: scale(1);
		box-shadow: 0 0 0 6px rgba(255, 255, 255, 0);
	}
	100% {
		transform: scale(0.95);
		box-shadow: 0 0 0 0 rgba(255, 255, 255, 0);
	}
}

@media (max-width: 768px) {
	.floating-sticky-cta {
		right: 0 !important;
		left: 0 !important;
		bottom: 0 !important;
		padding: 12px 20px !important;
		background: rgba(255, 255, 255, 0.95) !important;
		backdrop-filter: blur(10px) !important;
		border-top: 1px solid #E2E8F0 !important;
		box-shadow: 0 -4px 10px rgba(0,0,0,0.05) !important;
		transform: translateY(100%) !important;
		transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1) !important;
		display: flex !important;
		justify-content: center !important;
	}
	.floating-sticky-cta.is-visible {
		transform: translateY(0) !important;
	}
	.btn--sticky-cta {
		width: 100% !important;
		justify-content: center !important;
		padding: 0.9rem !important;
	}
}

/* Pre-Footer Final CTA */
.footer-final-cta {
	background: #FAF9F6 !important;
	padding: 5.5rem 0 !important;
	text-align: center !important;
	border-top: 1px solid #EAEAEA !important;
}
.footer-final-cta-inner {
	max-width: 680px !important;
	margin: 0 auto !important;
	padding: 0 24px !important;
}
.footer-final-cta h2 {
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	font-size: clamp(1.8rem, 3.5vw, 2.4rem) !important;
	font-weight: 800 !important;
	color: #1A1A1A !important;
	margin-bottom: 1.15rem !important;
	letter-spacing: -0.02em !important;
}
.footer-final-cta p {
	font-family: 'Inter', sans-serif !important;
	font-size: 1.08rem !important;
	color: #5A5A5A !important;
	line-height: 1.65 !important;
	margin-bottom: 2.25rem !important;
}
.footer-final-cta-btn {
	background: #00AA6C !important;
	color: #FFFFFF !important;
	padding: 0.95rem 2.25rem !important;
	border-radius: 50px !important;
	font-size: 0.98rem !important;
	font-weight: 600 !important;
	box-shadow: 0 8px 20px rgba(0, 170, 108, 0.18) !important;
	transition: background-color 0.25s, transform 0.25s, box-shadow 0.25s !important;
	text-decoration: none !important;
	display: inline-block !important;
	border: none !important;
}
.footer-final-cta-btn:hover {
	background: #008C5E !important;
	transform: translateY(-2px) !important;
	box-shadow: 0 12px 28px rgba(0, 170, 108, 0.28) !important;
}

/* Footer Newsletter Block */
.footer-newsletter {
	border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
	padding: 3.5rem 0 !important;
	background: rgba(0, 0, 0, 0.15) !important;
}
.footer-newsletter-inner {
	display: grid !important;
	grid-template-columns: 1fr !important;
	gap: 2rem !important;
	align-items: center !important;
}
@media (min-width: 768px) {
	.footer-newsletter-inner {
		grid-template-columns: 1.2fr 0.8fr !important;
		gap: 4rem !important;
	}
}
.newsletter-text h3 {
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif !important;
	font-weight: 700 !important;
	font-size: 1.45rem !important;
	color: #FFFFFF !important;
	margin-bottom: 0.45rem !important;
	letter-spacing: -0.01em !important;
}
.newsletter-text p {
	font-family: 'Inter', sans-serif !important;
	font-size: 0.92rem !important;
	color: #A0AEC0 !important;
	margin: 0 !important;
	line-height: 1.5 !important;
}
.newsletter-form-wrap {
	width: 100% !important;
}
.footer-newsletter-form {
	display: flex !important;
	gap: 0.5rem !important;
	width: 100% !important;
}
.newsletter-input {
	flex-grow: 1 !important;
	background: rgba(255, 255, 255, 0.06) !important;
	border: 1px solid rgba(255, 255, 255, 0.14) !important;
	padding: 0.75rem 1rem !important;
	border-radius: 4px !important;
	color: #FFFFFF !important;
	font-family: 'Inter', sans-serif !important;
	font-size: 0.88rem !important;
	outline: none !important;
	transition: border-color 0.25s, background-color 0.25s !important;
}
.newsletter-input:focus {
	border-color: #00AA6C !important;
	background: rgba(255, 255, 255, 0.1) !important;
}
.newsletter-btn {
	background: #00AA6C !important;
	color: #FFFFFF !important;
	border: none !important;
	padding: 0.75rem 1.45rem !important;
	font-weight: 600 !important;
	font-family: 'Inter', sans-serif !important;
	font-size: 0.88rem !important;
	border-radius: 4px !important;
	cursor: pointer !important;
	transition: background-color 0.25s !important;
	white-space: nowrap !important;
}
.newsletter-btn:hover {
	background: #008C5E !important;
}

/* Footer Author Link Muting */
/* Footer Author Link Muting */
.footer-bottom__inner {
	display: block !important;
	text-align: center !important;
}
.footer-copyright-combined {
	font-size: 0.72rem !important;
	color: #718096 !important;
	margin: 0 !important;
	width: 100% !important;
	text-align: center !important;
	letter-spacing: 0.03em !important;
}
.footer-copyright-combined a {
	color: #a0aec0 !important;
	font-size: 0.72rem !important;
	text-decoration: none !important;
	transition: color 0.2s !important;
}
.footer-copyright-combined a:hover {
	color: #ffffff !important;
}

/* Float WhatsApp Button Fix & Reposition */
.wa-float {
	position: fixed !important;
	bottom: 30px !important; /* Move WhatsApp button down near corner */
	right: 30px !important; /* Inset from edge */
	z-index: 9999 !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 0.5rem !important;
	background: #25D366 !important;
	color: #FFFFFF !important;
	padding: 0.75rem 1.25rem !important;
	border-radius: 999px !important;
	text-decoration: none !important;
	font-weight: 600 !important;
	font-size: 0.9rem !important;
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2) !important;
	transition: background-color 0.25s, transform 0.25s, box-shadow 0.25s !important;
}
.wa-float:hover {
	transform: translateY(-3px) !important;
	box-shadow: 0 12px 30px rgba(0, 0, 0, 0.3) !important;
	background: #20ba5a !important;
}

@media (max-width: 768px) {
	.wa-float {
		bottom: 30px !important; /* Keep it uniform at 30px */
		right: 20px !important;
		padding: 0.85rem !important;
	}
	.wa-float span {
		display: none !important;
	}
	/* Raise WhatsApp button on pages with bottom sticky elements to avoid overlap */
	body.post-type-archive-product .wa-float,
	body.tax-tour_phys .wa-float,
	body.single-product .wa-float {
		bottom: 95px !important;
	}
}

/* Ratings social proof snippet */
.footer-rating-snippet {
	margin-top: 1.25rem !important;
	display: flex !important;
	flex-direction: column !important;
	gap: 0.25rem !important;
}
.footer-rating-snippet .rating-stars {
	color: #00AA6C !important; /* Elegant TripAdvisor brand emerald green stars */
	font-size: 1.15rem !important;
	letter-spacing: 0.05em !important;
	line-height: 1 !important;
}
.footer-rating-snippet .rating-text {
	font-family: 'Inter', sans-serif !important;
	font-size: 0.82rem !important;
	color: #CBD5E0 !important;
	line-height: 1.4 !important;
}

/* Certifications badges row */
.footer-certifications-row {
	display: flex !important;
	flex-wrap: wrap !important;
	gap: 0.65rem !important;
	margin-bottom: 1.75rem !important;
}
.cert-badge {
	background: rgba(255, 255, 255, 0.04) !important;
	border: 1px solid rgba(255, 255, 255, 0.08) !important;
	padding: 5px 10px !important;
	border-radius: 4px !important;
	display: inline-flex !important;
	align-items: center !important;
	gap: 0.45rem !important;
	font-size: 0.74rem !important;
	color: #E2E8F0 !important;
	font-family: 'Inter', sans-serif !important;
	font-weight: 500 !important;
}
.cert-badge svg {
	color: #00AA6C !important; /* Crisp green check/shield indicators */
	flex-shrink: 0 !important;
}

/* ============================================================
   TOURS ARCHIVE PAGE STYLING CONSISTENCY OVERRIDES
   ============================================================ */
.tours-archive .breadcrumbs {
	padding-bottom: .3125rem !important;
	font-family: inherit !important;
	font-style: normal !important;
	font-weight: 400 !important;
	color: rgb(0, 0, 0) !important;
	font-size: 13px !important;
	line-height: 16px !important;
	margin: 1rem 0 !important;
	overflow-x: auto !important;
	white-space: nowrap !important;
}
.tours-archive .breadcrumbs a, 
.tours-archive .breadcrumbs span {
	color: rgb(0, 0, 0) !important;
	font-size: 13px !important;
	font-family: inherit !important;
	font-style: normal !important;
	font-weight: 400 !important;
	line-height: 16px !important;
}
.tours-archive .archive-hero__title {
	margin: 0 0 14px 0 !important;
	font-family: inherit !important;
	font-size: 28px !important;
	font-weight: 500 !important;
	color: rgb(0,0,0) !important;
	line-height: 32px !important;
	font-style: normal !important;
	letter-spacing: -0.3px !important;
}
.tours-archive .archive-hero {
	background: #ffffff !important;
	border-bottom: none !important;
	padding: 1rem 0 2rem 0 !important;
	margin-bottom: 24px !important;
}
.tours-archive .archive-hero__desc, 
.tours-archive .archive-hero__desc p {
	font-family: 'Inter', sans-serif !important;
	font-size: 14px !important;
	line-height: 20px !important;
	color: #4b5563 !important;
	margin-bottom: 20px !important;
}

/* Blog, Archive, Search, Single Post Page Header Consistency */
.blog .page-header,
.archive .page-header,
.search .page-header,
.single-post .page-header {
	background: #ffffff !important;
	border-bottom: none !important;
	padding: 1rem 0 0.5rem 0 !important;
	margin-bottom: 24px !important;
}
.blog .breadcrumbs,
.archive .breadcrumbs,
.search .breadcrumbs,
.single-post .breadcrumbs {
	padding-bottom: .3125rem !important;
	font-family: inherit !important;
	font-style: normal !important;
	font-weight: 400 !important;
	color: rgb(0, 0, 0) !important;
	font-size: 13px !important;
	line-height: 16px !important;
	margin: 1rem 0 !important;
	overflow-x: auto !important;
	white-space: nowrap !important;
}
.blog .breadcrumbs a, .blog .breadcrumbs span,
.archive .breadcrumbs a, .archive .breadcrumbs span,
.search .breadcrumbs a, .search .breadcrumbs span,
.single-post .breadcrumbs a, .single-post .breadcrumbs span {
	color: rgb(0, 0, 0) !important;
	font-size: 13px !important;
	font-family: inherit !important;
	font-style: normal !important;
	font-weight: 400 !important;
	line-height: 16px !important;
}
.blog .page-header__title,
.archive .page-header__title,
.search .page-header__title,
.single-post .page-header__title {
	margin: 0 0 14px 0 !important;
	font-family: inherit !important;
	font-size: 28px !important;
	font-weight: 500 !important;
	color: rgb(0,0,0) !important;
	line-height: 32px !important;
	font-style: normal !important;
	letter-spacing: -0.3px !important;
}
.single-post .page-header__meta {
	font-family: 'Inter', sans-serif !important;
	font-size: 13px !important;
	color: #6b7280 !important;
	margin-top: 6px !important;
	font-weight: 500 !important;
}
.single-post .entry .wp-post-image {
	border-radius: 20px !important;
	margin-top: 1rem !important;
	margin-bottom: 2rem !important;
	width: 100% !important;
	aspect-ratio: 16 / 9 !important;
	object-fit: cover !important;
}
.single-post .content-area {
	padding-bottom: 80px !important;
}

/* Single Post Grid Layout */
.single-post-layout {
	display: grid;
	grid-template-columns: 260px 1fr;
	gap: 4.5rem;
	align-items: start;
	margin-top: 2rem;
}
@media (max-width: 992px) {
	.single-post-layout {
		grid-template-columns: 1fr;
		gap: 2rem;
	}
}

/* Sticky Table of Contents */
.single-post-sidebar {
	position: sticky;
	top: 32px;
}
@media (max-width: 992px) {
	.single-post-sidebar {
		position: static;
		display: none; /* Collapsed on mobile, or hidden to keep UI clean */
	}
}
.sticky-toc h3 {
	font-family: 'Inter', sans-serif !important;
	font-size: 0.72rem !important;
	font-weight: 700 !important;
	text-transform: uppercase !important;
	letter-spacing: 0.05em !important;
	color: #6b7280 !important;
	margin: 0 0 1rem 0 !important;
}
.toc-list {
	list-style: none !important;
	padding: 0 !important;
	margin: 0 !important;
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}
.toc-link {
	font-family: 'Inter', sans-serif !important;
	font-size: 0.88rem !important;
	font-weight: 500 !important;
	color: #4b5563 !important;
	text-decoration: none !important;
	line-height: 1.4 !important;
	display: block;
	transition: color 0.2s ease, font-weight 0.2s ease;
}
.toc-link:hover {
	color: var(--primary) !important;
}
.toc-link.active {
	color: var(--primary) !important;
	font-weight: 700 !important;
}

/* Single Post Content Area Readability */
.single-post-main {
	max-width: 100% !important;
}
.single-post-main .entry {
	max-width: 100% !important;
}
.single-post .entry-content {
	max-width: 720px !important; /* Optimal line length constraint */
	font-family: 'Figtree', sans-serif !important;
	font-size: 1.05rem !important;
	line-height: 1.75 !important; /* High readability line-height */
	color: #374151 !important;
}
.single-post .entry-content p {
	margin-bottom: 1.5rem !important;
}
.single-post .entry-content h2 {
	font-family: 'Rector', serif !important;
	font-size: 1.75rem !important;
	font-weight: 500 !important;
	color: #191815 !important;
	margin: 2.5rem 0 1rem 0 !important;
	line-height: 1.3 !important;
	scroll-margin-top: 24px; /* Space above targeted sections when jumping from TOC */
}
.single-post .entry-content h3 {
	font-family: 'Rector', serif !important;
	font-size: 1.4rem !important;
	font-weight: 500 !important;
	color: #191815 !important;
	margin: 2rem 0 1rem 0 !important;
}
.single-post .entry-content img {
	border-radius: 12px !important;
	margin: 2rem 0 !important;
	width: 100% !important;
	height: auto !important;
}

/* Visual Tour Promo Card (Inline CTA) */
.tour-promo-card {
	display: grid;
	grid-template-columns: 180px 1fr;
	gap: 1.5rem;
	background: #ffffff;
	border: 1px solid #EAEAEA;
	border-radius: 14px;
	overflow: hidden;
	margin: 2.5rem 0 !important;
	box-shadow: 0 4px 20px rgba(0,0,0,0.01);
	align-items: center;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}
@media (max-width: 576px) {
	.tour-promo-card {
		grid-template-columns: 1fr;
		gap: 0;
	}
}
.tour-promo-card:hover {
	transform: translateY(-2px);
	box-shadow: 0 10px 30px rgba(0,0,0,0.03);
}
.tour-promo-card__media {
	width: 100%;
	height: 100%;
	aspect-ratio: 4 / 3;
	overflow: hidden;
}
@media (max-width: 576px) {
	.tour-promo-card__media {
		aspect-ratio: 16 / 9;
	}
}
.tour-promo-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.tour-promo-card__content {
	padding: 1.25rem;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	align-items: start;
}
.tour-promo-card__label {
	font-size: 0.65rem;
	font-weight: 700;
	color: var(--primary);
	background: #e6f4ea;
	padding: 3px 8px;
	border-radius: 4px;
	letter-spacing: 0.05em;
}
.tour-promo-card__title {
	margin: 0 !important;
	font-size: 1.1rem !important;
	font-weight: 700 !important;
	line-height: 1.35 !important;
	color: #111827;
}
.tour-promo-card__title a {
	color: inherit;
	text-decoration: none !important;
}
.tour-promo-card__title a:hover {
	color: var(--primary);
}
.tour-promo-card__meta {
	display: flex;
	align-items: center;
	gap: 12px;
	font-size: 0.82rem;
	color: #6b7280;
	font-weight: 500;
}
.tour-promo-card__duration {
	display: inline-flex;
	align-items: center;
}
.tour-promo-card__price {
	color: #111827;
	font-weight: 700;
}
.tour-promo-card__btn {
	padding: 8px 16px !important;
	font-size: 0.8rem !important;
	font-weight: 700 !important;
	border-radius: 6px !important;
	text-decoration: none !important;
	margin-top: 4px;
}

/* ============================================================
   COOKIE CONSENT BANNER
   ============================================================ */
.lucy-cookie-consent {
	position: fixed;
	bottom: 24px;
	right: 24px;
	left: 24px;
	max-width: 500px;
	background: rgba(255, 255, 255, 0.98);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	border: 1px solid var(--border);
	border-radius: 12px;
	box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08), 0 1px 3px rgba(0, 0, 0, 0.02);
	z-index: 99999;
	padding: 24px;
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
	animation: lucy-cookie-slide-up 0.4s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

@media (min-width: 768px) {
	.lucy-cookie-consent {
		left: 32px !important;
		right: auto !important;
		bottom: 32px !important;
		width: 440px !important;
	}
}

@keyframes lucy-cookie-slide-up {
	from {
		transform: translateY(30px);
		opacity: 0;
	}
	to {
		transform: translateY(0);
		opacity: 1;
	}
}

.lucy-cookie-consent__banner {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.lucy-cookie-consent__title {
	font-size: 16px;
	font-weight: 700;
	color: var(--text);
	margin: 0 0 8px 0 !important;
	line-height: 1.25;
}

.lucy-cookie-consent__text {
	font-size: 13px;
	color: var(--text-light);
	line-height: 1.5;
	margin: 0 !important;
}

.lucy-cookie-consent__actions {
	display: grid;
	grid-template-columns: 1fr;
	gap: 8px;
	margin-top: 8px;
}

@media (min-width: 480px) {
	.lucy-cookie-consent__actions {
		grid-template-columns: 1fr auto auto;
		align-items: center;
	}
}

.lucy-cookie-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 8px 16px;
	font-size: 13px;
	font-weight: 600;
	border-radius: 6px;
	border: 1px solid transparent;
	cursor: pointer;
	transition: all 0.2s ease;
	text-decoration: none;
	text-align: center;
	min-height: 38px;
}

.lucy-cookie-btn--primary {
	background-color: var(--primary);
	color: var(--white);
}

.lucy-cookie-btn--primary:hover {
	background-color: var(--primary-dark);
}

.lucy-cookie-btn--secondary {
	background-color: transparent;
	border-color: var(--border);
	color: var(--text-light);
}

.lucy-cookie-btn--secondary:hover {
	background-color: var(--bg-light);
	color: var(--text);
	border-color: var(--text-muted);
}

.lucy-cookie-btn--danger {
	background-color: transparent;
	color: var(--text-light);
	border-color: var(--border);
}

.lucy-cookie-btn--danger:hover {
	background-color: #FEF2F2;
	color: var(--danger);
	border-color: #FCA5A5;
}

.lucy-cookie-btn--block {
	width: 100%;
}

/* Preferences Modal / Slide-out Inside the Container */
.lucy-cookie-consent__preferences {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: var(--white);
	border-radius: 12px;
	z-index: 10;
	display: flex;
	flex-direction: column;
	box-sizing: border-box;
	animation: lucy-cookie-fade-in 0.25s ease-out forwards;
}

@keyframes lucy-cookie-fade-in {
	from { opacity: 0; }
	to { opacity: 1; }
}

.lucy-cookie-prefs-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 16px 20px;
	border-bottom: 1px solid var(--border);
}

.lucy-cookie-prefs-header h4 {
	font-size: 15px;
	font-weight: 700;
	color: var(--text);
	margin: 0 !important;
}

.lucy-cookie-close {
	background: none;
	border: none;
	font-size: 24px;
	line-height: 1;
	color: var(--text-light);
	cursor: pointer;
	padding: 4px;
	transition: color 0.2s;
}

.lucy-cookie-close:hover {
	color: var(--text);
}

.lucy-cookie-prefs-body {
	flex: 1;
	overflow-y: auto;
	padding: 16px 20px;
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.lucy-cookie-pref-item {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: 16px;
}

.lucy-cookie-pref-info {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.lucy-cookie-pref-info strong {
	font-size: 13px;
	color: var(--text);
	font-weight: 600;
}

.lucy-cookie-pref-info span {
	font-size: 11px;
	color: var(--text-light);
	line-height: 1.4;
}

/* Switch styling */
.lucy-cookie-toggle {
	position: relative;
	display: inline-block;
	width: 38px;
	height: 20px;
	flex-shrink: 0;
	margin-top: 2px;
}

.lucy-cookie-toggle input {
	opacity: 0;
	width: 0;
	height: 0;
}

.toggle-slider {
	position: absolute;
	cursor: pointer;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background-color: var(--border);
	transition: .25s cubic-bezier(0.4, 0, 0.2, 1);
	border-radius: 20px;
}

.toggle-slider:before {
	position: absolute;
	content: "";
	height: 14px;
	width: 14px;
	left: 3px;
	bottom: 3px;
	background-color: white;
	transition: .25s cubic-bezier(0.4, 0, 0.2, 1);
	border-radius: 50%;
	box-shadow: 0 1px 3px rgba(0,0,0,0.15);
}

.lucy-cookie-toggle input:checked + .toggle-slider {
	background-color: var(--primary);
}

.lucy-cookie-toggle input:focus-visible + .toggle-slider {
	box-shadow: 0 0 0 2px rgba(46, 125, 79, 0.3);
}

.lucy-cookie-toggle input:checked + .toggle-slider:before {
	transform: translateX(18px);
}

.lucy-cookie-toggle input:disabled + .toggle-slider {
	opacity: 0.6;
	cursor: not-allowed;
}

.lucy-cookie-prefs-footer {
	padding: 16px 20px;
	border-top: 1px solid var(--border);
}


/* ============================================================
   RESPONSIBLE TOURISM PAGE
   ============================================================ */
.responsible-tourism-page {
	padding-bottom: var(--s-6);
}

.rt-hero-section {
	background-color: #E8F3EC;
	padding: 4rem 0;
	margin-bottom: 2.5rem;
	text-align: center;
	border-radius: 20px;
	border: 1px solid #E4E0D8;
}

.rt-hero-inner {
	max-width: 800px;
	margin: 0 auto;
}

.rt-label {
	display: inline-block;
	font-size: 0.85rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: #6a994e;
	margin-bottom: 12px;
	font-family: 'Figtree', sans-serif;
}

.rt-hero-title-sub {
	font-family: 'Rector', serif !important;
	font-size: clamp(2rem, 4vw, 2.75rem) !important;
	font-weight: 500 !important;
	color: #191815 !important;
	line-height: 1.25 !important;
	margin-bottom: 20px !important;
}

.rt-hero-lead {
	font-size: 1.1rem;
	color: #4b5563;
	line-height: 1.65;
	margin: 0 !important;
	font-family: 'Figtree', sans-serif;
}

.rt-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2.5rem;
}

@media (min-width: 992px) {
	.rt-grid {
		grid-template-columns: 1.2fr 0.8fr;
	}
}

.rt-card {
	background: #ffffff;
	border: 1px solid #E4E0D8;
	border-radius: 20px;
	padding: 2.25rem;
	margin-bottom: 2rem;
	box-shadow: 0 8px 30px rgba(0,0,0,0.02);
	transition: transform 0.3s cubic-bezier(0.22, 1, 0.36, 1), box-shadow 0.3s cubic-bezier(0.22, 1, 0.36, 1), border-color 0.3s ease;
}

.rt-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 16px 35px rgba(0,0,0,0.08);
	border-color: #6a994e;
}

.rt-card h2 {
	color: #191815;
	font-family: 'Rector', serif;
	font-size: 1.75rem;
	margin: 0 0 1rem 0 !important;
	font-weight: 500;
}

.rt-card p {
	color: #4b5563;
	line-height: 1.65;
	margin-bottom: 0;
	font-family: 'Figtree', sans-serif;
}

.guideline-item {
	display: flex;
	gap: 1.25rem;
	margin-top: 1.5rem;
	padding: 1.5rem;
	border: 1px solid #E4E0D8;
	border-radius: 16px;
	background: #ffffff;
	transition: transform 0.3s cubic-bezier(0.22, 1, 0.36, 1), box-shadow 0.3s cubic-bezier(0.22, 1, 0.36, 1), border-color 0.3s ease;
}

.guideline-item:hover {
	transform: translateY(-3px);
	box-shadow: 0 10px 25px rgba(0,0,0,0.05);
	border-color: #6a994e;
}

.guideline-item:first-of-type {
	margin-top: 1.5rem;
}

.guideline-icon {
	color: #6a994e;
	background: #E8F3EC;
	border-radius: 10px;
	width: 44px;
	height: 44px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.guideline-text h3 {
	font-family: 'Figtree', sans-serif;
	font-size: 1.1rem;
	color: #191815;
	margin: 0 0 8px 0 !important;
	font-weight: 700;
}

.guideline-text p {
	font-size: 0.95rem;
	margin: 0;
	color: #4b5563;
	line-height: 1.5;
	font-family: 'Figtree', sans-serif;
}

/* Sidebar community support card */
.rt-sidebar .community-owned-card {
	margin-top: 0;
	background: #FAF7F0 !important;
	border: 1px solid #E4E0D8;
	border-radius: 20px;
	padding: 2.25rem;
	box-shadow: 0 8px 30px rgba(0,0,0,0.02) !important;
}

.community-intro {
	font-size: 0.95rem !important;
	line-height: 1.6;
	color: #4b5563 !important;
	margin-bottom: 1.25rem !important;
	font-family: 'Figtree', sans-serif;
}

.community-features-heart {
	list-style: none !important;
	padding: 0 !important;
	margin: 0 !important;
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.community-features-heart li {
	position: relative;
	padding-left: 28px;
	color: #4b5563;
	font-size: 0.95rem;
	line-height: 1.5;
	font-family: 'Figtree', sans-serif;
	list-style: none !important;
}

.community-features-heart li::marker {
	content: "" !important;
}

.community-features-heart .heart-icon {
	position: absolute;
	left: 0;
	top: 3px;
	color: #6a994e;
	display: inline-flex;
	align-items: center;
}

/* ============================================================
   TRIPADVISOR FOOTER SECTION
   ============================================================ */
.footer-tripadvisor-section {
	background: #FFFFFF !important;
	border-bottom: 1px solid var(--border) !important;
	border-top: 1px solid var(--border) !important;
	padding: 3.5rem 0 !important;
}

.footer-tripadvisor-inner {
	width: 100%;
}

.footer-ta-reviews-layout {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2.5rem;
	align-items: center;
}

@media (min-width: 992px) {
	.footer-ta-reviews-layout {
		grid-template-columns: 220px 1fr;
		gap: 3.5rem;
	}
}

/* Summary column */
.footer-ta-summary {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
}

@media (min-width: 992px) {
	.footer-ta-summary {
		align-items: flex-start;
		text-align: left;
	}
}

.footer-ta-summary-title {
	font-family: 'Montserrat', 'Inter', sans-serif !important;
	font-size: 1.8rem !important;
	font-weight: 800 !important;
	color: #000000 !important;
	letter-spacing: -0.01em !important;
	margin: 0 0 10px 0 !important;
}

.footer-ta-summary-bubbles {
	margin-bottom: 8px;
}

.ta-bubbles--lg {
	gap: 5px !important;
}

.ta-bubbles--lg .ta-bubble {
	width: 20px !important;
	height: 20px !important;
	border-width: 3.5px !important;
}

.ta-bubbles--lg .ta-bubble--full {
	box-shadow: inset 0 0 0 3px #FFFFFF !important;
}

.ta-bubbles--lg .ta-bubble--half {
	box-shadow: inset 0 0 0 3px #FFFFFF !important;
}

.footer-ta-summary-count {
	font-size: 0.95rem !important;
	color: #111827 !important;
	font-weight: 600 !important;
	margin: 0 0 14px 0 !important;
}

.footer-ta-reviews-link {
	color: #00AA6C !important;
	text-decoration: underline !important;
	font-weight: 700;
}

.footer-ta-reviews-link:hover {
	color: #008C5E !important;
}

.footer-ta-summary-brand a {
	display: inline-flex;
	align-items: center;
	color: #1A1A1A;
	text-decoration: none;
}

.footer-ta-summary-brand .ta-logo-text {
	font-size: 0.92rem;
	color: #000000 !important;
}

.footer-ta-summary-brand svg {
	fill: #00AA6C;
}

/* Slider / Carousel Container */
.footer-ta-slider-wrapper {
	position: relative;
	display: flex;
	align-items: center;
	width: 100%;
}

.footer-ta-slider-viewport {
	overflow: hidden;
	width: 100%;
}

.footer-ta-slider-track {
	display: flex;
	transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
	gap: 16px;
	width: 100%;
}

/* Cards */
.footer-ta-review-card {
	background: #F4F4F5;
	border-radius: 12px;
	padding: 20px;
	flex-shrink: 0;
	width: 100%;
	display: flex;
	flex-direction: column;
	box-shadow: 0 1px 3px rgba(0,0,0,0.02);
	box-sizing: border-box;
}

@media (min-width: 576px) {
	.footer-ta-review-card {
		width: calc(50% - 8px);
	}
}

@media (min-width: 992px) {
	.footer-ta-review-card {
		width: calc(33.333% - 11px);
	}
}

.ta-card-header {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 12px;
	position: relative;
	width: 100%;
}

.ta-card-avatar {
	width: 38px;
	height: 38px;
	border-radius: 50%;
	background: #CBD5E1;
	color: #334155;
	font-weight: 700;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1rem;
	text-transform: uppercase;
}

.ta-card-user-info {
	display: flex;
	flex-direction: column;
}

.ta-card-username {
	font-size: 0.95rem;
	font-weight: 700;
	color: #1A1A1A;
}

.ta-card-date {
	font-size: 0.78rem;
	color: #6B7280;
}

.ta-card-logo-badge {
	position: absolute;
	right: 0;
	top: 0;
	color: #00AA6C;
}

.ta-card-rating {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 12px;
}

.ta-card-checkmark {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: #3B82F6;
}

.ta-card-title {
	font-size: 0.95rem !important;
	font-weight: 700 !important;
	color: #1A1A1A !important;
	margin: 0 0 8px 0 !important;
}

.ta-card-text {
	font-size: 0.88rem !important;
	color: #1A1A1A !important;
	line-height: 1.5 !important;
	margin: 0 0 12px 0 !important;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
	height: 58px;
}

.ta-card-readmore {
	font-size: 0.82rem;
	color: #6B7280 !important;
	text-decoration: none !important;
	font-weight: 600;
	transition: color 0.2s;
}

.ta-card-readmore:hover {
	color: #00AA6C !important;
}

/* Slider Controls */
.footer-ta-slider-btn {
	background: #FFFFFF;
	border: 1px solid #E5E7EB;
	color: #111827;
	width: 32px;
	height: 32px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 10;
	box-shadow: 0 2px 8px rgba(0,0,0,0.06);
	transition: all 0.2s;
}

.footer-ta-slider-btn:hover {
	background: #F3F4F6;
	border-color: #D1D5DB;
	transform: translateY(-50%) scale(1.05);
}

.footer-ta-slider-btn.prev {
	left: -16px;
}

.footer-ta-slider-btn.next {
	right: -16px;
}

@media (max-width: 575px) {
	/* Mobile: native swipe carousel instead of JS arrow slider */
	.footer-tripadvisor-section { overflow-x: hidden; }   /* never let it widen the page */
	.footer-ta-slider-btn { display: none; }
	.footer-ta-slider-wrapper { display: block; width: 100%; }
	.footer-ta-slider-viewport {
		display: block;
		width: 100%;
		min-width: 0;             /* allow the scroll container to clip (flexbox fix) */
		max-width: 100%;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		scroll-snap-type: x mandatory;
		scrollbar-width: none;
		padding-bottom: 4px;
	}
	.footer-ta-slider-viewport::-webkit-scrollbar { display: none; }
	.footer-ta-slider-track {
		transform: none !important;  /* disable JS translate; native scroll drives it */
		width: max-content;
		gap: 12px;
	}
	.footer-ta-review-card {
		width: 78vw !important;
		max-width: 300px;
		scroll-snap-align: start;
	}
}

/* ==========================================================================
   FOOTER TRIPADVISOR REVIEWS — redesigned, fully responsive (auto-fit grid)
   Data comes from Settings → TripAdvisor Sync (manual reviews / live API).
   ========================================================================== */
.ta-rev { max-width: 1100px; margin: 0 auto; font-family: 'Figtree', sans-serif; }
.ta-rev__head { text-align: center; margin-bottom: 1.75rem; }
.ta-rev__brand { display: inline-flex; align-items: center; color: #191815; text-decoration: none; }
.ta-rev__brand .ta-logo { height: 32px !important; gap: 8px !important; }
.ta-rev__brand .ta-logo svg { fill: #00AA6C; width: 32px !important; height: 32px !important; }
.ta-rev__brand .ta-logo-text { color: #191815; font-weight: 700; font-size: 1.6rem !important; font-family: 'Figtree', sans-serif !important; }
.ta-rev__score { display: flex; align-items: center; justify-content: center; gap: 12px; margin: 10px 0 6px; }
.ta-rev__num { font-size: 1.9rem; font-weight: 800; color: #191815; line-height: 1; font-family: 'Figtree', sans-serif; }
.ta-rev__summary { font-size: 14px; color: #4A4A4A; margin: 0; }
.ta-rev__summary strong { color: #191815; font-weight: 700; }
.ta-rev__summary a { color: #00AA6C; font-weight: 700; text-decoration: underline; }

.ta-rev__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 18px;
}
.ta-rev__card {
	display: flex; flex-direction: column;
	background: #FAF7F0; border: 1px solid #E4E0D8; border-radius: 16px; padding: 20px;
}
.ta-rev__card-head { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.ta-rev__avatar {
	flex-shrink: 0; width: 40px; height: 40px; border-radius: 50%;
	background: #E8F3EC; color: #6a994e;
	display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 15px;
}
.ta-rev__who { display: flex; flex-direction: column; min-width: 0; }
.ta-rev__name { font-weight: 700; font-size: 14px; color: #191815; line-height: 1.2; }
.ta-rev__date { font-size: 12px; color: #7A7A7A; margin-top: 2px; }
.ta-rev__owl { margin-left: auto; color: #00AA6C; display: inline-flex; flex-shrink: 0; }
.ta-rev__owl svg { display: block; }
.ta-rev__stars { display: block; margin-bottom: 10px; }
.ta-rev__title { font-family: 'Rector', serif; font-size: 16px; font-weight: 500; color: #191815; margin: 0 0 6px; line-height: 1.3; }
.ta-rev__text {
	font-size: 13.5px; line-height: 1.6; color: #4A4A4A; margin: 0 0 14px;
	display: -webkit-box; -webkit-line-clamp: 4; -webkit-box-orient: vertical; overflow: hidden;
}
.ta-rev__more { margin-top: auto; font-size: 13px; font-weight: 600; color: #00AA6C; text-decoration: none; }
.ta-rev__more:hover { text-decoration: underline; }

.ta-rev__foot { text-align: center; margin-top: 1.75rem; }
.ta-rev__cta {
	display: inline-flex; align-items: center; gap: 8px;
	background: #00AA6C; color: #fff; font-weight: 700; font-size: 14px;
	padding: 12px 26px; border-radius: 999px; text-decoration: none; transition: background .2s;
}
.ta-rev__cta:hover { background: #008C5E; color: #fff; }

@media (max-width: 600px) {
	.ta-rev__num { font-size: 1.6rem; }
	.ta-rev__grid { gap: 14px; }
}

/* ==========================================================================
   HOMEPAGE REDESIGN STYLES
   ========================================================================== */

/* ==========================================================================
   Hero Section Styling Redesign
   ========================================================================== */
.homepage-hero.hero-redesign {
	position: relative !important;
	min-height: 85vh !important;
	display: flex !important;
	align-items: center !important;
	justify-content: flex-start !important;
	text-align: left !important;
	padding-bottom: 80px !important;
	padding-top: 80px !important;
	color: #ffffff !important;
	overflow: hidden !important;
}

/* Background Slideshow layout */
.homepage-hero.hero-redesign .hero-slideshow {
	position: absolute !important;
	inset: 0 !important;
	z-index: 0 !important;
}

.homepage-hero.hero-redesign .hero-slide {
	position: absolute !important;
	inset: 0 !important;
	background-size: cover !important;
	background-position: center !important;
	background-repeat: no-repeat !important;
	opacity: 0 !important;
	transition: opacity 1.5s ease-in-out !important;
}

.homepage-hero.hero-redesign .hero-slide.active {
	opacity: 1 !important;
}

/* Background overlay gradient (left to right for text readability) */
.homepage-hero.hero-redesign .homepage-hero__overlay {
	position: absolute !important;
	inset: 0 !important;
	background: linear-gradient(to bottom, rgba(0,0,0,0.15) 0%, rgba(0,0,0,0.55) 100%) !important;
	z-index: 1 !important;
}

/* Content container */
.homepage-hero.hero-redesign .homepage-hero__container {
	position: relative !important;
	z-index: 2 !important;
	width: 100% !important;
	max-width: 1200px !important;
	margin: 0 auto !important;
	padding: 0 20px !important;
	display: flex !important;
	justify-content: flex-start !important;
}

.homepage-hero.hero-redesign .homepage-hero__content {
	max-width: 720px !important;
	margin: 0 !important;
	display: flex !important;
	flex-direction: column !important;
	align-items: flex-start !important;
	text-align: left !important;
}

/* H1: Inter, heavy weight, oversized */
.homepage-hero.hero-redesign .homepage-hero__title {
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif !important;
	font-weight: 700 !important;
	font-size: clamp(36px, 6vw, 56px) !important;
	color: #ffffff !important;
	line-height: 1.1 !important;
	margin: 0 0 1.5rem 0 !important;
	text-shadow: 0 2px 8px rgba(0, 0, 0, 0.4) !important;
	text-align: left !important;
}

/* Subheadline */
.homepage-hero.hero-redesign .homepage-hero__desc {
	font-family: 'Inter', sans-serif !important;
	font-weight: 400 !important;
	font-size: 18px !important;
	color: rgba(255, 255, 255, 0.85) !important;
	line-height: 1.6 !important;
	max-width: 600px !important;
	margin: 0 0 2rem 0 !important;
	text-shadow: 0 1px 5px rgba(0, 0, 0, 0.2) !important;
	text-align: left !important;
}

/* Social Proof Above CTA */
.homepage-hero.hero-redesign .homepage-hero__trust {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: flex-start !important;
	gap: 6px !important;
	margin-bottom: 24px !important;
	font-family: 'Inter', sans-serif !important;
	font-size: 14px !important;
	font-weight: 500 !important;
	color: #ffffff !important;
	background: rgba(0, 0, 0, 0.45) !important;
	padding: 8px 18px !important;
	border-radius: 30px !important;
	backdrop-filter: blur(8px) !important;
	-webkit-backdrop-filter: blur(8px) !important;
	border: 1px solid rgba(255, 255, 255, 0.15) !important;
}
.homepage-hero.hero-redesign .homepage-hero__trust .stars {
	color: #FBBF24 !important; /* Gold yellow stars */
	font-size: 15px !important;
	letter-spacing: 1px !important;
}
.homepage-hero.hero-redesign .homepage-hero__trust .rating-val {
	font-weight: 700 !important;
}
.homepage-hero.hero-redesign .homepage-hero__trust .sep {
	color: rgba(255, 255, 255, 0.4) !important;
}

/* Actions CTA row */
.homepage-hero.hero-redesign .homepage-hero__actions {
	display: flex !important;
	justify-content: flex-start !important;
	align-items: center !important;
	gap: 16px !important;
	margin-bottom: 0 !important;
}

/* Primary Button */
.homepage-hero.hero-redesign .btn--hero-plan {
	background: #6a994e !important;
	color: #ffffff !important;
	padding: 16px 40px !important;
	border-radius: 8px !important;
	font-family: 'Inter', sans-serif !important;
	font-weight: 600 !important;
	font-size: 17px !important;
	text-decoration: none !important;
	border: none !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	transition: background-color var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out) !important;
}

.homepage-hero.hero-redesign .btn--hero-plan:hover {
	background: #5a8443 !important;
	transform: translateY(-2px) !important;
	box-shadow: 0 6px 20px rgba(217, 119, 6, 0.45) !important;
}

/* Secondary Button */
.homepage-hero.hero-redesign .btn--hero-view {
	background: transparent !important;
	color: #ffffff !important;
	padding: 16px 36px !important;
	border: 2px solid rgba(255, 255, 255, 0.7) !important;
	border-radius: 8px !important;
	font-family: 'Inter', sans-serif !important;
	font-weight: 600 !important;
	font-size: 16px !important;
	text-decoration: none !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	transition: background-color var(--dur-base) var(--ease-out), border-color var(--dur-base) var(--ease-out) !important;
}

.homepage-hero.hero-redesign .btn--hero-view:hover {
	background: rgba(255, 255, 255, 0.15) !important;
	border-color: #ffffff !important;
}

/* Scroll Cue Style */
.homepage-hero.hero-redesign .hero-scroll-cue {
	position: absolute !important;
	bottom: 85px !important;
	left: 50% !important;
	transform: translateX(-50%) !important;
	z-index: 10 !important;
	color: rgba(255, 255, 255, 0.6) !important;
	transition: color 0.3s ease !important;
	text-decoration: none !important;
}
.homepage-hero.hero-redesign .hero-scroll-cue:hover {
	color: #ffffff !important;
}
.homepage-hero.hero-redesign .hero-scroll-cue svg.bounce {
	animation: hero-bounce-key 2s infinite !important;
}

@keyframes hero-bounce-key {
	0%, 20%, 50%, 80%, 100% {
		transform: translateY(0);
	}
	40% {
		transform: translateY(-8px);
	}
	60% {
		transform: translateY(-4px);
	}
}

/* Mobile Hero Breakpoints */
@media (max-width: 768px) {
	.homepage-hero.hero-redesign {
		min-height: 75vh !important;
		padding-bottom: 60px !important;
	}
	.homepage-hero.hero-redesign .homepage-hero__title {
		font-size: var(--text-4xl) !important;
	}
	.homepage-hero.hero-redesign .homepage-hero__desc {
		font-size: 16px !important;
		margin-bottom: 2rem !important;
	}
	.homepage-hero.hero-redesign .homepage-hero__actions {
		flex-direction: column !important;
		width: 100% !important;
		gap: 12px !important;
	}
	.homepage-hero.hero-redesign .btn--hero-plan,
	.homepage-hero.hero-redesign .btn--hero-view {
		width: 100% !important;
		padding: 14px 28px !important;
	}
}

.trust-item {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
}

/* TripAdvisor Redesign */
.trust-item--ta .ta-row {
	display: flex;
	align-items: center;
	gap: 8px;
}

.trust-item--ta .ico--tripadvisor {
	width: 32px !important;
	height: 32px !important;
	fill: #34e0a1 !important;
}

.trust-item--ta .ta-circles {
	display: inline-flex;
	gap: 4px;
}

.trust-item--ta .ta-circle {
	width: 12px;
	height: 12px;
	background: #34e0a1;
	border-radius: 50%;
	display: inline-block;
}

.trust-item--ta .trust-label-text {
	font-weight: 700;
	font-size: 1.4rem !important;
	color: #ffffff;
	letter-spacing: -0.5px;
	text-transform: lowercase;
	line-height: 1;
}

.trust-item--ta .trust-link {
	font-size: 0.95rem !important;
	color: rgba(255, 255, 255, 0.85) !important;
	text-decoration: underline !important;
	font-weight: 600;
}

.trust-item--ta .trust-link:hover {
	color: #ffffff !important;
}

/* Google Reviews Redesign */
.trust-item--google {
	gap: 12px;
}

.trust-item--google .google-text {
	font-size: 2.15rem !important;
	font-weight: 700;
	letter-spacing: -1px;
	color: #ffffff;
	line-height: 1;
}

.g-blue { color: #ffffff !important; }
.g-red { color: #ffffff !important; }
.g-yellow { color: #ffffff !important; }
.g-green { color: #ffffff !important; }

.trust-item--google .trust-stars {
	display: flex;
	align-items: center;
	gap: 8px;
	line-height: 1;
}

.trust-item--google .google-subtext {
	font-size: 0.88rem !important;
	color: rgba(255, 255, 255, 0.9);
	font-weight: 600;
	letter-spacing: 0.5px;
}

.trust-item--google .star-rating {
	color: #FBBC05;
	font-size: 1.15rem !important;
	letter-spacing: 1px;
}

/* Experience Redesign */
.trust-item--experience .experience-layout {
	display: flex;
	align-items: center;
	gap: 12px;
}

.trust-item--experience .experience-icon {
	color: #ffffff;
	display: flex;
	justify-content: center;
	align-items: center;
}

.trust-item--experience .ico--wreath {
	width: 44px !important;
	height: 44px !important;
}

.trust-item--experience .experience-text {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	text-align: left;
	line-height: 1.15;
}

.trust-item--experience .exp-years {
	font-size: 1.25rem !important;
	font-weight: 700;
	color: #ffffff;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.trust-item--experience .exp-label {
	font-size: 0.95rem !important;
	color: rgba(255, 255, 255, 0.9);
	text-transform: uppercase;
	letter-spacing: 0.5px;
	font-weight: 500;
}

/* Quick Tour Search Section */
.quick-search-section {
	margin-top: -70px;
	position: relative;
	z-index: 20;
	padding-bottom: 2rem;
}

.quick-search-container {
	background: #ffffff;
	border-radius: 12px;
	box-shadow: 0 20px 40px rgba(0, 0, 0, 0.08) !important;
	padding: 2.5rem;
	border: 1px solid rgba(0, 0, 0, 0.05);
}

.quick-search-title {
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	text-align: center;
	font-size: 1.85rem;
	font-weight: 700;
	color: #111827;
	margin-bottom: 2rem;
}

.quick-search-form {
	display: grid !important;
	grid-template-columns: repeat(3, 1fr) auto !important;
	gap: 20px !important;
	align-items: end !important;
}

.search-field {
	position: relative;
	display: flex !important;
	flex-direction: column !important;
}

.search-field-label {
	display: block !important;
	font-family: 'Inter', sans-serif !important;
	font-size: 13px !important;
	font-weight: 600 !important;
	color: #4B5563 !important;
	margin-bottom: 6px !important;
	text-align: left !important;
}

.search-field select {
	width: 100%;
	padding: 12px 35px 12px 15px;
	border: 1px solid #e2e8f0;
	border-radius: 6px;
	background-color: #ffffff;
	color: #374151;
	font-family: 'Inter', sans-serif;
	font-size: 0.95rem;
	font-weight: 500;
	appearance: none;
	cursor: pointer;
	transition: border-color 0.2s, box-shadow 0.2s;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%234B5563' stroke-width='2'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M19 9l-7 7-7-7'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 12px center;
	background-size: 16px;
}

.search-field select:hover {
	border-color: #3B7A57;
	box-shadow: 0 0 0 3px rgba(59, 122, 87, 0.08);
}

.search-field select:focus {
	outline: none;
	border-color: #3B7A57;
	box-shadow: 0 0 0 3px rgba(59, 122, 87, 0.15);
}

.btn--search {
	background: var(--color-primary) !important;
	color: #ffffff !important;
	font-family: 'Inter', sans-serif !important;
	font-weight: 600 !important;
	font-size: 15px !important;
	padding: 12px 32px !important;
	border-radius: var(--radius-full) !important;
	border: none !important;
	cursor: pointer !important;
	transition: background-color var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-out) !important;
	white-space: nowrap !important;
	height: 46px !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
}

.btn--search:hover {
	background: var(--color-primary-dark) !important;
}

/* Redesigned Tour Cards on Homepage */
.homepage-featured-section {
	padding: 6rem 0;
	background: #ffffff;
}

.homepage-featured-section .section-head {
	text-align: center;
	margin-bottom: 3.5rem;
}

.homepage-featured-section .section-head h2 {
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	font-size: 2.5rem;
	font-weight: 700;
	color: #111827;
	margin-bottom: 8px;
}

.section-subtitle {
	font-size: 1.1rem;
	color: #6B7280;
	margin: 0;
}

.mockup-card {
	background: #ffffff;
	border-radius: 8px;
	overflow: hidden;
	box-shadow: 0 4px 15px rgba(0, 0, 0, 0.03);
	border: 1px solid #e5e7eb;
	transition: transform 0.3s, box-shadow 0.3s;
	display: flex;
	flex-direction: column;
	height: 100%;
}

.mockup-card:hover {
	transform: translateY(-5px);
	box-shadow: 0 12px 30px rgba(0, 0, 0, 0.08);
}

.mockup-card .tour-card__media-wrap {
	position: relative;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background-color: #f3f4f6;
}

.mockup-card .tour-card__image {
	width: 100% !important;
	height: 100% !important;
	object-fit: cover !important;
	transition: transform 0.5s;
}

.mockup-card:hover .tour-card__image {
	transform: scale(1.06);
}

.wishlist-heart {
	position: absolute;
	top: 15px;
	right: 15px;
	background: rgba(255, 255, 255, 0.9);
	width: 32px;
	height: 32px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #6B7280;
	cursor: pointer;
	z-index: 10;
	transition: all 0.2s;
	border: none;
}

.wishlist-heart:hover {
	background: #ffffff;
	color: #ef4444;
	transform: scale(1.1);
}

.wishlist-heart svg {
	width: 16px;
	height: 16px;
	fill: currentColor;
}

.mockup-card .tour-card__content {
	padding: 1.5rem;
	display: flex;
	flex-direction: column;
	flex-grow: 1;
}

.mockup-card .tour-card__title {
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	font-size: 1.35rem !important;
	font-weight: 700 !important;
	margin: 0 0 10px 0 !important;
	line-height: 1.3;
}

.mockup-card .tour-card__title a {
	color: #111827 !important;
	text-decoration: none !important;
}

.mockup-card .tour-card__title a:hover {
	color: #3B7A57 !important;
}

.tour-card__rating-row {
	display: flex;
	align-items: center;
	gap: 6px;
	margin-bottom: 15px;
}

.tour-card__rating-stars {
	color: #FBBC05;
	font-size: 0.9rem;
	letter-spacing: 1px;
}

.tour-card__rating-text {
	font-size: 0.82rem;
	color: #6b7280;
	font-weight: 600;
}

.tour-card__desc {
	font-size: 0.88rem;
	color: #4B5563;
	line-height: 1.5;
	margin-bottom: 1.5rem;
	flex-grow: 1;
}

.mockup-card .tour-card__meta-pills {
	display: flex;
	gap: 12px;
	margin-bottom: 15px;
}

.mockup-card .meta-pill {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 0.82rem;
	color: #4B5563;
	font-weight: 500;
}

.mockup-card .meta-pill svg {
	color: #3B7A57;
}

.mockup-card .tour-card__footer {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-top: auto;
	padding-top: 15px;
	border-top: 1px solid #f3f4f6;
}

.mockup-card .tour-card__price {
	font-family: 'Inter', sans-serif;
	font-weight: 700 !important;
	font-size: 1.15rem !important;
	color: #111827 !important;
}

.mockup-card .btn--tour-view {
	background: transparent !important;
	color: #3B7A57 !important;
	border: 1px solid #3B7A57 !important;
	font-size: 0.85rem !important;
	font-weight: 600 !important;
	padding: 8px 16px !important;
	border-radius: 4px !important;
	text-decoration: none;
	transition: all 0.2s;
}

.mockup-card .btn--tour-view:hover {
	background: #3B7A57 !important;
	color: #ffffff !important;
}

/* Redesigned Bottom Badges Section */
.bottom-badges-section {
	padding: 5rem 0;
	background: #fafafa;
	border-top: 1px solid #f0f0f0;
	border-bottom: 1px solid #f0f0f0;
}

.badges-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 32px;
}

.badge-card {
	background: #ffffff;
	border: 1px solid #e5e7eb;
	border-radius: 12px;
	padding: 2.25rem 1.5rem;
	text-align: center;
	transition: transform 0.3s, box-shadow 0.3s;
	box-shadow: 0 2px 10px rgba(0, 0, 0, 0.02);
}

.badge-card:hover {
	transform: translateY(-5px);
	box-shadow: 0 10px 25px rgba(0, 0, 0, 0.05);
}

.badge-card__icon-wrap {
	width: 54px;
	height: 54px;
	background: rgba(59, 122, 87, 0.08);
	color: #3B7A57;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 1.25rem auto;
}

.badge-card h3 {
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	font-size: 1.15rem;
	font-weight: 700;
	color: #111827;
	margin: 0 0 10px 0;
}

.badge-card p {
	font-size: 0.88rem;
	color: #6B7280;
	line-height: 1.5;
	margin: 0;
}

/* Media Queries for Redesign responsiveness */
@media (max-width: 1024px) {
	.quick-search-form {
		grid-template-columns: repeat(3, 1fr);
	}
	.badges-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 768px) {
	.hero-redesign .homepage-hero__actions {
		flex-direction: column;
		gap: 12px;
		align-items: center;
	}
	.btn--hero-plan, .btn--hero-view {
		width: 100%;
		max-width: 280px;
	}
	.quick-search-form {
		grid-template-columns: repeat(2, 1fr);
	}
	.homepage-hero__trust {
		gap: 30px;
	}
}

@media (max-width: 1024px) {
	.social-proof-grid {
		grid-template-columns: 1fr !important;
		gap: 20px !important;
	}
	.experience-grid {
		grid-template-columns: repeat(2, 1fr) !important;
	}
	.planning-grid {
		grid-template-columns: repeat(2, 1fr) !important;
		gap: 30px !important;
	}
}

@media (max-width: 1024px) {
	.social-proof-grid {
		grid-template-columns: 1fr !important;
		gap: 20px !important;
	}
	.experience-grid {
		grid-template-columns: repeat(2, 1fr) !important;
	}
	.planning-grid {
		grid-template-columns: repeat(2, 1fr) !important;
		gap: 30px !important;
	}
	.dest-carousel-card {
		flex: 0 0 calc(50% - 12px) !important;
	}
}

@media (max-width: 768px) {
	.dest-carousel-btn {
		display: none !important;
	}
	.dest-carousel-card {
		flex: 0 0 100% !important;
	}
}

@media (max-width: 575px) {
	.quick-search-form {
		grid-template-columns: 1fr;
	}
	.badges-grid {
		grid-template-columns: 1fr;
	}
	.quick-search-container {
		padding: 1.5rem;
	}
	.experience-grid {
		grid-template-columns: 1fr !important;
	}
	.planning-grid {
		grid-template-columns: 1fr !important;
		gap: 20px !important;
	}
	.section-lto .wrap {
		flex-direction: column;
		text-align: center;
		align-items: center !important;
	}
}

/* ==========================================================================
   SaaS-Style Scroll & Sticky Nav Transitions
   ========================================================================== */

/* Fade-In Up Scroll Animations */
.fade-in-hidden {
	opacity: 0;
	transform: translateY(20px);
	transition: opacity 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94), transform 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94) !important;
	will-change: opacity, transform;
}
.fade-in-visible {
	opacity: 1 !important;
	transform: translateY(0) !important;
}

/* -------------------------------------------------- Sticky Nav Design System Updates */
#site-nav {
	position: absolute !important;
	top: 64px !important; /* 40px utility bar + 24px gap */
	left: 0 !important;
	right: 0 !important;
	z-index: 1000 !important;
	height: 72px !important;
	background: transparent !important;
	border-bottom: none !important;
	transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

#site-nav.is-sticky {
	position: fixed !important;
	top: 0 !important;
	height: 56px !important;
	box-shadow: 0 4px 24px rgba(0, 0, 0, 0.05) !important;
	background: rgba(255, 255, 255, 0.98) !important;
	backdrop-filter: blur(10px) !important;
	-webkit-backdrop-filter: blur(10px) !important;
}

#site-nav.is-sticky .pill-wrap {
	margin: 0 auto !important;
	height: 100% !important;
	box-shadow: none !important;
	background: transparent !important;
}

/* Site Branding & Logo height constraint */
.site-header .site-logo-img img {
	height: 44px !important;
	width: auto !important;
	filter: none !important; /* Ensure logo is dark/standard since bg is white */
	transition: height 0.3s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

#site-nav.is-sticky .site-logo-img img {
	height: 28px !important;
}

/* Nav link font and hover styling */
.main-menu a {
	font-family: 'Figtree', sans-serif !important;
	font-weight: 500 !important;
	font-size: 16px !important;
	color: rgb(25, 24, 21) !important;
	letter-spacing: 0.02em !important;
	transition: color 150ms ease !important;
	text-shadow: none !important;
}

.main-menu a:hover {
	color: var(--color-primary) !important;
}

/* Phone number header link styling */
.header-phone-link {
	font-family: 'Inter', sans-serif !important;
	font-weight: 600 !important;
	font-size: 14px !important;
	color: var(--color-text-primary) !important;
	transition: color 150ms ease !important;
	text-shadow: none !important;
	display: inline-flex !important;
	align-items: center !important;
}

.header-phone-link:hover {
	color: var(--color-primary) !important;
}

/* CTA button styling */
.btn--header-quote {
	background: var(--color-primary) !important;
	color: #ffffff !important;
	padding: 10px 22px !important;
	border-radius: var(--radius-full) !important;
	font-family: 'Inter', sans-serif !important;
	font-weight: 600 !important;
	font-size: 14px !important;
	height: auto !important;
	border: none !important;
	box-shadow: none !important;
	text-transform: none !important;
	transition: background var(--dur-base) var(--ease-out) !important;
}

.btn--header-quote:hover {
	background: var(--primary-dark) !important;
}

/* --- Premium Mega-Menu Desktop Styling --- */
@media (min-width: 769px) {
	.main-menu.mega-menu {
		display: flex !important;
		align-items: center !important;
		height: 100% !important;
		gap: 0 !important;
	}
	
	.main-menu.mega-menu > li {
		position: relative !important;
		height: 100% !important;
		display: flex !important;
		align-items: center !important;
	}
	
	.main-menu.mega-menu > li > a {
		padding: 0 20px !important;
		height: 100% !important;
		display: inline-flex !important;
		align-items: center !important;
		color: #1a202c !important;
		font-weight: 500 !important;
		font-size: 14px !important;
		position: relative !important;
		transition: color 0.25s ease !important;
	}
	
	.main-menu.mega-menu > li:hover > a {
		color: var(--color-primary) !important;
	}
	
	.main-menu.mega-menu > li > a::after {
		content: '' !important;
		position: absolute !important;
		bottom: 0 !important;
		left: 20px !important;
		right: 20px !important;
		height: 2px !important;
		background: var(--color-primary) !important;
		transform: scaleX(0) !important;
		transform-origin: right !important;
		transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1) !important;
	}
	
	.main-menu.mega-menu > li:hover > a::after {
		transform: scaleX(1) !important;
		transform-origin: left !important;
	}
	
	.main-menu.mega-menu .mega-dropdown {
		position: absolute !important;
		top: 100% !important;
		left: 50% !important;
		transform: translateX(-50%) translateY(10px) !important;
		width: 580px !important;
		background: #ffffff !important;
		border: 1px solid rgba(0, 0, 0, 0.06) !important;
		border-radius: 12px !important;
		box-shadow: 0 10px 40px rgba(0, 0, 0, 0.08) !important;
		padding: 24px !important;
		opacity: 0 !important;
		visibility: hidden !important;
		transition: opacity 0.3s cubic-bezier(0.16, 1, 0.3, 1), transform 0.3s cubic-bezier(0.16, 1, 0.3, 1), visibility 0.3s !important;
		z-index: 9999 !important;
	}
	
	.main-menu.mega-menu > li:hover .mega-dropdown {
		opacity: 1 !important;
		visibility: visible !important;
		transform: translateX(-50%) translateY(0) !important;
	}
	
	.mega-grid {
		display: grid !important;
		grid-template-columns: 1.2fr 1fr !important;
		gap: 24px !important;
	}
	
	.mega-col h4 {
		font-size: 11px !important;
		text-transform: uppercase !important;
		letter-spacing: 0.05em !important;
		color: #718096 !important;
		margin: 0 0 12px 0 !important;
		font-weight: 700 !important;
	}
	
	.mega-col ul {
		list-style: none !important;
		padding: 0 !important;
		margin: 0 !important;
		display: flex !important;
		flex-direction: column !important;
		gap: 8px !important;
	}
	
	.mega-col ul a {
		display: block !important;
		padding: 4px 0 !important;
		color: #4a5568 !important;
		font-weight: 500 !important;
		font-size: 14px !important;
		text-decoration: none !important;
		transition: color 0.2s ease, transform 0.2s ease !important;
	}
	
	.mega-col ul a:hover {
		color: var(--color-primary) !important;
		transform: translateX(4px) !important;
	}
	
	.mega-featured .mega-card {
		display: block !important;
		position: relative !important;
		border-radius: 8px !important;
		overflow: hidden !important;
		height: 100% !important;
		min-height: 160px !important;
		text-decoration: none !important;
	}
	
	.mega-featured .mega-card img {
		width: 100% !important;
		height: 100% !important;
		object-fit: cover !important;
		transition: transform 0.5s cubic-bezier(0.16, 1, 0.3, 1) !important;
	}
	
	.mega-featured .mega-card:hover img {
		transform: scale(1.06) !important;
	}
	
	.mega-card-content {
		position: absolute !important;
		bottom: 0 !important;
		left: 0 !important;
		right: 0 !important;
		background: linear-gradient(to top, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0) 100%) !important;
		padding: 16px !important;
		color: #ffffff !important;
	}
	
	.mega-card-content .badge {
		display: inline-block !important;
		background: var(--color-primary) !important;
		color: #ffffff !important;
		font-size: 10px !important;
		font-weight: 700 !important;
		text-transform: uppercase !important;
		padding: 3px 8px !important;
		border-radius: 30px !important;
		margin-bottom: 6px !important;
	}
	
	.mega-card-content h5 {
		font-size: 14px !important;
		font-weight: 600 !important;
		margin: 0 0 4px 0 !important;
		color: #ffffff !important;
	}
	
	.mega-card-content p {
		font-size: 11px !important;
		color: rgba(255, 255, 255, 0.8) !important;
		margin: 0 !important;
		line-height: 1.3 !important;
	}
	
	/* Reset inner dropdown list items to avoid conflicts with theme's default ul/li style rules */
	.main-menu.mega-menu .mega-dropdown ul {
		position: static !important;
		opacity: 1 !important;
		visibility: visible !important;
		transform: none !important;
		box-shadow: none !important;
		border: none !important;
		padding: 0 !important;
		margin: 0 !important;
		width: auto !important;
		min-width: 0 !important;
		background: transparent !important;
		display: flex !important;
		flex-direction: column !important;
		gap: 8px !important;
	}
	.main-menu.mega-menu .mega-dropdown li {
		width: 100% !important;
		height: auto !important;
		display: block !important;
		position: static !important;
		border: none !important;
		padding: 0 !important;
	}
}








/* ===== Global Website Width Override ===== */
.wrap {
    max-width: 1300px !important;
}


/* ==========================================================================
   GLOBAL FOOTER REDESIGN STYLES
   ========================================================================== */
.site-footer {
	background: #1F2937 !important;
	color: #D1D5DB !important;
	padding: 0 !important;
	border-top: none !important;
	font-family: 'Inter', sans-serif !important;
}
.footer-top {
	padding: 100px 0 !important;
}
.footer-grid {
	display: grid !important;
	grid-template-columns: 1.5fr 1fr 1fr 1fr 1.8fr !important;
	gap: 48px !important;
	align-items: start !important;
}
@media (max-width: 1024px) {
	.footer-grid {
		grid-template-columns: 1fr 1fr !important;
		gap: 32px !important;
	}
}
@media (max-width: 768px) {
	.footer-grid {
		grid-template-columns: 1fr !important;
		gap: 32px !important;
	}
}
.site-footer .footer-col h4,
.site-footer .payment-title {
	color: #FFFFFF !important;
	font-size: 13px !important;
	font-weight: 700 !important;
	letter-spacing: 0.06em !important;
	text-transform: uppercase !important;
	margin-top: 0 !important;
	margin-bottom: 24px !important;
	border-bottom: none !important;
	padding-bottom: 0 !important;
}
.site-footer .footer-link-list {
	list-style: none !important;
	padding: 0 !important;
	margin: 0 !important;
}
.site-footer .footer-link-list li {
	margin-bottom: 12px !important;
}
.site-footer .footer-link-list a,
.site-footer .footer-contact-item a,
.site-footer .footer-address {
	font-size: 14px !important;
	color: #9CA3AF !important;
	transition: color 150ms ease !important;
	text-decoration: none !important;
	line-height: 1.6 !important;
}
.site-footer .footer-link-list a:hover,
.site-footer .footer-contact-item a:hover,
.site-footer .footer-address:hover {
	color: #FFFFFF !important;
	text-decoration: none !important;
}
.footer-contact-item {
	display: flex !important;
	align-items: flex-start !important;
	gap: 12px !important;
	margin-bottom: 16px !important;
}
.footer-contact-icon {
	color: #6a994e !important;
	flex-shrink: 0 !important;
	margin-top: 2px !important;
}
.footer-contact-sublist {
	display: flex !important;
	flex-direction: column !important;
	gap: 4px !important;
}
.footer-address {
	white-space: pre-line !important;
	text-decoration: underline;
	text-underline-offset: 4px;
}
.footer-social-row {
	display: flex !important;
	gap: 12px !important;
	margin-top: 24px !important;
}
.site-footer .social-circle-link {
	width: 44px !important;
	height: 44px !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	background: rgba(255,255,255,0.12) !important;
	border-radius: 50% !important;
	transition: all 150ms ease !important;
	text-decoration: none !important;
}
.site-footer .social-circle-link .ico {
	width: 20px !important;
	height: 20px !important;
	color: #FFFFFF !important;
}
.site-footer .social-circle-link:hover {
	background: #6a994e !important;
	transform: translateY(-2px) !important;
}

/* Trusted Partners & Payments Grid */
.trusted-partners-row {
	display: flex !important;
	flex-wrap: wrap !important;
	gap: 12px !important;
	margin-bottom: 24px !important;
	align-items: center !important;
}
.trusted-partners-row img,
.trusted-partners-row .kayak-badge-full {
	height: 24px !important;
	width: auto !important;
	opacity: 0.7 !important;
	transition: opacity 150ms ease !important;
}
.trusted-partners-row img:hover,
.trusted-partners-row .kayak-badge-full:hover {
	opacity: 1 !important;
}
.kayak-badge-full {
	background: #FF690F !important;
	color: #fff !important;
	font-family: sans-serif !important;
	font-weight: 900 !important;
	padding: 0 8px !important;
	border-radius: 4px !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
}
.footer-certifications-row {
	display: flex !important;
	gap: 16px !important;
	margin-bottom: 24px !important;
}
.cert-badge {
	display: inline-flex !important;
	align-items: center !important;
	gap: 6px !important;
	background: rgba(255,255,255,0.06) !important;
	padding: 6px 12px !important;
	border-radius: 6px !important;
	font-size: 12px !important;
	color: #D1D5DB !important;
}
.cert-badge .ico--cert {
	color: #6a994e !important;
}
.payment-methods-grid {
	display: flex !important;
	gap: 8px !important;
}
.payment-card-badge {
	background: rgba(255,255,255,0.08) !important;
	padding: 4px 8px !important;
	border-radius: 4px !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
}
.payment-card-badge img {
	height: 20px !important;
	width: auto !important;
}

/* Footer Bottom */
.site-footer .footer-bottom {
	border-top: 1px solid rgba(255,255,255,0.08) !important;
	padding: 24px 0 !important;
	background: rgba(0,0,0,0.15) !important;
}
.footer-bottom__inner {
	display: flex !important;
	justify-content: space-between !important;
	align-items: center !important;
	flex-wrap: wrap !important;
	gap: 16px !important;
}
.site-footer .footer-copyright-combined {
	font-size: 13px !important;
	color: #9CA3AF !important;
	margin: 0 !important;
}
.site-footer .footer-copyright-combined a {
	color: #9CA3AF !important;
	text-decoration: underline !important;
}
.site-footer .footer-copyright-combined a:hover {
	color: #FFFFFF !important;
}
.back-to-top {
	font-size: 13px !important;
	color: #9CA3AF !important;
	transition: color 150ms ease !important;
}
.back-to-top:hover {
	color: #FFFFFF !important;
}


/* ==========================================================================
   GLOBAL HEADER & TOP UTILITY BAR REDESIGN STYLES
   ========================================================================== */

/* 1. Push Subpage Content Down (Prevent absolute header overlap) */
body:not(.home) #content {
    padding-top: 140px !important;
}
@media (max-width: 1024px) {
    body:not(.home) #content {
        padding-top: 120px !important;
    }
}
@media (max-width: 768px) {
    body:not(.home) #content {
        padding-top: 100px !important;
    }
}

/* 2. Top Utility Bar Styles */
.top-utility-bar {
    background: #6a994e !important;
    color: #fff !important;
    font-size: 13px;
    font-weight: 600;
    position: relative;
    z-index: 200;
    margin-bottom: 0 !important;
}
.tub-wrap {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    padding: 8px 24px !important;
}
.tub-links {
    display: flex;
    align-items: center;
    gap: 24px;
}
.tub-links a {
    color: #fff !important;
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 6px;
    transition: opacity 0.2s;
}
.tub-links a:hover { opacity: 0.7; }
.tub-collection svg, .tub-search svg { stroke: #fff !important; }

/* Overlay Search UI */
.tub-search-container {
    position: relative;
    display: flex;
    align-items: center;
    margin-left: 10px;
}
.tub-search-toggle, .tub-search-close {
    background: transparent;
    border: none;
    color: #fff;
    cursor: pointer;
    padding: 4px;
    display: flex;
}
.tub-search-toggle svg, .tub-search-close svg {
    stroke: #fff !important;
}
.tub-search-overlay {
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    background: #6a994e;
    display: flex;
    align-items: center;
    width: 0;
    overflow: hidden;
    opacity: 0;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    z-index: 10;
    pointer-events: none;
}
.tub-search-overlay.active {
    width: 300px;
    opacity: 1;
    pointer-events: auto;
    padding: 4px 0;
}
.tub-search-overlay-input {
    background: #fff;
    border: none;
    color: #000;
    padding: 8px 16px;
    border-radius: 999px;
    flex-grow: 1;
    outline: none;
    font-size: 13px;
    width: 100%;
}
.tub-search-close {
    margin-left: 8px;
    margin-right: 4px;
}

/* 3. Floating Pill Nav Styles */
@media (min-width: 1025px) {
    .site-header {
        background: transparent !important;
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
    }
    .floating-pill-header {
        position: absolute !important;
        top: 64px !important; /* Sitting nicely below the top utility bar */
        left: 0;
        right: 0;
        z-index: 150;
        background: transparent !important;
        box-shadow: none !important;
        border: none !important;
    }
    .floating-pill-header .pill-wrap {
        background: #fff !important;
        border-radius: 999px !important;
        height: 72px !important;
        padding: 0 32px !important;
        max-width: 1300px;
        margin: 20px auto !important;
        display: flex;
        align-items: center;
        justify-content: space-between;
        box-shadow: 0 10px 30px rgba(0,0,0,0.15) !important;
        box-sizing: border-box !important;
    }
    .btn--pill-cta {
        background: #6a994e !important;
        color: #fff !important;
        border-radius: 999px;
        padding: 12px 32px;
        font-weight: 700;
        font-size: 14px;
        text-transform: none;
        display: inline-block;
        transition: all 0.2s;
        text-decoration: none;
    }
    .btn--pill-cta:hover {
        transform: scale(1.05);
        background: #5a8443 !important;
        color: #fff !important;
    }
    .floating-pill-header .site-logo-img { max-width: 180px; }

    /* Main Nav items styling inside pill header */
    .floating-pill-header .site-branding,
    .floating-pill-header .header-cta {
        flex-shrink: 0 !important;
    }
    .floating-pill-header .main-nav {
        flex: 1 !important;
        display: flex !important;
        justify-content: center !important;
        align-items: center !important;
        height: 100% !important;
    }
    .floating-pill-header .main-nav__drawer {
        display: flex !important;
        align-items: center !important;
        height: 100% !important;
    }
    .floating-pill-header .main-menu:not(.hide-on-desktop) {
        display: flex !important;
        justify-content: center !important;
        align-items: center !important;
        height: 100% !important;
    }
    .floating-pill-header .main-menu:not(.hide-on-desktop) > li {
        display: flex !important;
        align-items: center !important;
        height: 100% !important;
    }

.main-menu > li > a {
    font-family: 'Figtree', sans-serif !important;
    font-style: normal !important;
    font-weight: 500 !important;
    color: rgb(25, 24, 21) !important;
    font-size: 16px !important;
    line-height: 21px !important;
    text-decoration: none;
    padding: 0 15px !important;
    display: inline-flex !important;
    align-items: center !important;
    height: 100% !important;
    transition: color 0.2s;
    box-sizing: border-box !important;
}
.main-menu > li > a:hover {
    color: #6a994e !important;
}

/* Ensure dropdown arrows follow link text color dynamically */
.main-menu > li.menu-item-has-children > a::after {
    content: "" !important;
    display: inline-block !important;
    width: 5px !important;
    height: 5px !important;
    border: none !important;
    border-right: 1.5px solid currentColor !important;
    border-bottom: 1.5px solid currentColor !important;
    transform: rotate(45deg) !important;
    margin-left: 7px !important;
    vertical-align: middle !important;
    position: relative !important;
    top: -1px !important;
    margin-top: 0 !important;
}
}

@media (max-width: 1024px) {
    .top-utility-bar {
        display: none !important;
    }
    #site-nav {
        position: fixed !important;
        top: 0 !important;
        margin-top: 0 !important;
        margin-bottom: 0 !important;
        left: 0 !important;
        right: 0 !important;
        z-index: 10000 !important;
        background: rgba(255, 255, 255, 0.96) !important;
        backdrop-filter: blur(16px) !important;
        -webkit-backdrop-filter: blur(16px) !important;
        box-shadow: 0 2px 15px rgba(0, 0, 0, 0.05) !important;
        border-bottom: 1px solid #E4E0D8 !important;
    }
    #site-nav .pill-wrap {
        border-radius: 0 !important;
        margin: 0 auto !important;
        padding: 0 1.5rem !important;
        height: 64px !important;
        box-shadow: none !important;
        max-width: 100% !important;
        background: transparent !important;
    }
    #site-nav .site-logo-img img {
        height: 40px !important;
    }
    #site-nav .header-cta {
        display: none !important;
    }
    .nav-toggle {
        border-color: #E4E0D8 !important;
        background: #ffffff !important;
    }
    .main-nav {
        padding-top: 84px !important;
    }

    /* Mobile Search Inside Drawer */
    .mobile-search-wrapper {
        margin-bottom: 1.75rem !important;
        width: 100% !important;
    }
    .mobile-search-form {
        position: relative !important;
        display: flex !important;
        align-items: center !important;
        width: 100% !important;
    }
    .mobile-search-icon {
        position: absolute !important;
        left: 16px !important;
        color: #718096 !important;
        pointer-events: none !important;
    }
    .mobile-search-input {
        width: 100% !important;
        background: #FAF7F0 !important;
        border: 1px solid #E4E0D8 !important;
        border-radius: 999px !important;
        padding: 12px 16px 12px 42px !important;
        font-family: 'Figtree', sans-serif !important;
        font-size: 15px !important;
        color: #191815 !important;
        outline: none !important;
        transition: border-color 0.25s ease, box-shadow 0.25s ease !important;
    }
    .mobile-search-input:focus {
        border-color: #6a994e !important;
        background: #ffffff !important;
        box-shadow: 0 0 0 3px rgba(106, 153, 78, 0.1) !important;
    }

    /* Mobile Drawer Utility Links */
    .mobile-utility-links {
        margin-top: 2rem !important;
        width: 100% !important;
        display: flex !important;
        flex-direction: column !important;
        gap: 12px !important;
    }
    .mobile-utility-links .utility-label {
        font-family: 'Figtree', sans-serif !important;
        font-size: 11px !important;
        font-weight: 700 !important;
        text-transform: uppercase !important;
        letter-spacing: 0.08em !important;
        color: #6a994e !important;
        margin-bottom: 4px !important;
    }
    .mobile-utility-links .utility-list {
        list-style: none !important;
        padding: 0 !important;
        margin: 0 !important;
        display: flex !important;
        flex-direction: column !important;
        gap: 12px !important;
    }
    .mobile-utility-links .utility-list li {
        width: 100% !important;
        padding: 0 !important;
        border: none !important;
    }
    .mobile-utility-links .utility-list a {
        font-family: 'Figtree', sans-serif !important;
        font-size: 16px !important;
        font-weight: 600 !important;
        color: #4a5568 !important;
        text-decoration: none !important;
        display: flex !important;
        align-items: center !important;
        padding: 4px 0 !important;
        transition: color 0.25s ease !important;
    }
    .mobile-utility-links .utility-list a:hover,
    .mobile-utility-links .utility-list a:active {
        color: #6a994e !important;
    }
    .mobile-utility-links .utility-collection svg {
        stroke: currentColor !important;
    }
}

/* ==========================================================================
   SUBPAGE REDESIGN, ACTIVE NAVIGATION, BUTTONS & SIDEBAR STYLES
   ========================================================================== */

/* 1. Font Faces for Subpages */
@font-face {
    font-family: 'Rector';
    src: url('assets/fonts/Rector-Bold.woff') format('woff');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Rector';
    src: url('assets/fonts/Rector-Medium.woff') format('woff');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

/* 2. Push Content Adjustment for Hero Banners */
body:not(.home) #content {
    padding-top: 0 !important;
}

/* 3. Page Header & Tours Archive Hero (Mini-Hero Style) */
.page-header--has-bg,
.ta-hero--has-bg {
    position: relative;
    padding-top: 160px !important;
    padding-bottom: 160px !important;
    margin-bottom: 0px !important;
    min-height: 72vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #0c2518 !important;
    overflow: hidden;
    color: #ffffff;
    box-sizing: border-box;
}

.page-header__bg-img,
.ta-hero__bg-img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover !important;
    z-index: 1;
}

.page-header__overlay,
.ta-hero__overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.05) !important;
    z-index: 2;
}

.page-header--has-bg .wrap,
.ta-hero--has-bg .wrap {
    position: relative;
    z-index: 3;
    width: 100%;
}

/* Breadcrumbs Color over Hero */
.page-header--has-bg .breadcrumbs,
.ta-hero--has-bg .breadcrumbs {
    color: rgba(255, 255, 255, 0.8) !important;
    margin-bottom: 12px !important;
}
.page-header--has-bg .breadcrumbs a,
.ta-hero--has-bg .breadcrumbs a {
    color: rgba(255, 255, 255, 0.9) !important;
}
.page-header--has-bg .breadcrumbs a:hover,
.ta-hero--has-bg .breadcrumbs a:hover {
    color: var(--brand-green-light) !important;
}

/* WAK Breadcrumbs Color over Hero (for About, Contact, Responsible pages) */
.page-header--has-bg nav.wak-breadcrumbs,
.ta-hero--has-bg nav.wak-breadcrumbs {
    color: rgba(255, 255, 255, 0.8) !important;
    margin-top: 0 !important;
}
.page-header--has-bg nav.wak-breadcrumbs .wak-breadcrumb-link,
.ta-hero--has-bg nav.wak-breadcrumbs .wak-breadcrumb-link {
    color: rgba(255, 255, 255, 0.9) !important;
}
.page-header--has-bg nav.wak-breadcrumbs span.wak-breadcrumb-link,
.ta-hero--has-bg nav.wak-breadcrumbs span.wak-breadcrumb-link {
    color: rgba(255, 255, 255, 0.7) !important;
}
.page-header--has-bg nav.wak-breadcrumbs .wak-add-seperator::after,
.ta-hero--has-bg nav.wak-breadcrumbs .wak-add-seperator::after {
    color: rgba(255, 255, 255, 0.6) !important;
}
.page-header--has-bg nav.wak-breadcrumbs .wak-breadcrumb-link:hover,
.ta-hero--has-bg nav.wak-breadcrumbs .wak-breadcrumb-link:hover {
    color: #FAF7F0 !important;
    text-decoration: underline !important;
}

/* Typography on Hero Headers */
.page-header--has-bg .page-header__title,
.ta-hero--has-bg .ta-hero__title {
    font-family: 'Rector', serif !important;
    font-size: clamp(34px, 5vw, 56px) !important;
    font-weight: 500 !important;
    line-height: 1.25 !important;
    color: #ffffff !important;
    letter-spacing: -0.5px !important;
    margin: 0 auto !important;
    text-align: center !important;
    max-width: 960px;
    text-shadow: 0 2px 10px rgba(0, 0, 0, 0.45) !important;
}
.page-header--has-bg .page-header__meta {
    font-family: 'Figtree', sans-serif !important;
    font-size: 13px !important;
    color: rgba(255, 255, 255, 0.75) !important;
    margin-top: 10px !important;
    font-weight: 500 !important;
}

/* Content spacing adjustments below breadcrumbs */
.subpage-crumbs-wrap + .content-area,
.subpage-crumbs-wrap + .vision-mission-section,
.subpage-crumbs-wrap + .blog-intro-section,
.subpage-crumbs-wrap + .rt-content-wrap,
.subpage-crumbs-wrap + .wrap,
.subpage-crumbs-wrap + div,
.subpage-crumbs-wrap + section {
    margin-top: 32px !important;
    padding-top: 0 !important;
}

@media (max-width: 768px) {
    .page-header--has-bg,
    .ta-hero--has-bg {
        padding-top: 140px !important;
        padding-bottom: 50px !important;
        min-height: 240px;
    }
    .page-header--has-bg .page-header__title,
    .ta-hero--has-bg .ta-hero__title {
        font-size: 28px !important;
        line-height: 34px !important;
    }
}

/* 4. Active Navigation State Underline */
.main-menu > li {
    position: relative;
}
.main-menu > li.current-menu-item > a::before,
.main-menu > li.current_page_item > a::before,
.main-menu > li.current-menu-ancestor > a::before {
    display: none !important;
}

/* 5. Button Shape and Animation Consistency */
.btn, 
.btn--primary,
.btn--outline,
.btn--pill-cta,
.btn-green-solid,
.tour-promo-card__btn,
.submit-contact-btn,
.btn--quote,
.btn--wa-outline,
.tour-pdf-btn,
.tour-btn-pdf {
    border-radius: 999px !important; /* Pill style */
    transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1) !important;
    font-family: 'Figtree', sans-serif !important;
    font-weight: 700 !important;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05) !important;
}

.btn:hover,
.btn--primary:hover,
.btn--outline:hover,
.btn--pill-cta:hover,
.btn-green-solid:hover,
.tour-promo-card__btn:hover,
.submit-contact-btn:hover,
.btn--quote:hover,
.btn--wa-outline:hover,
.tour-pdf-btn:hover,
.tour-btn-pdf:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 16px rgba(106, 153, 78, 0.15) !important;
}

/* 6. Two-Column Sidebar Layout for Content Pages */
.subpage-two-col-layout {
    display: grid;
    grid-template-columns: 2.2fr 1fr;
    gap: 48px;
    align-items: start;
    margin-bottom: 60px;
}

.subpage-main-content {
    min-width: 0; /* Prevents overflow in grid */
}

.subpage-takeaway-sidebar {
    position: sticky;
    top: 120px; /* Limits sticky behavior so it doesn't overlap header or footer */
    z-index: 10;
    max-height: calc(100vh - 160px);
    overflow-y: auto;
}

/* Hide scrollbar of sticky element but keep behavior */
.subpage-takeaway-sidebar::-webkit-scrollbar {
    display: none;
}
.subpage-takeaway-sidebar {
    -ms-overflow-style: none;  /* IE and Edge */
    scrollbar-width: none;  /* Firefox */
}

.takeaway-card {
    background: #FAF8F5;
    border: 1px solid #EAE6DF;
    border-radius: 16px;
    padding: 24px;
    margin-bottom: 24px;
}

.takeaway-card__title {
    font-family: 'Rector', serif !important;
    font-size: 20px !important;
    color: #0c2518 !important;
    margin: 0 0 16px 0 !important;
    font-weight: 600 !important;
    border-bottom: 1px solid #EAE6DF;
    padding-bottom: 10px;
}

.takeaway-card__list {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.takeaway-card__list li {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    font-size: 14px;
    line-height: 20px;
    color: #4b5563;
}

.takeaway-card__list li strong {
    color: #111;
}

.takeaway-icon {
    color: #6a994e;
    flex-shrink: 0;
    margin-top: 2px;
}

.contact-cta-card {
    background: #0c2518;
    color: #ffffff;
    border-radius: 16px;
    padding: 28px 24px;
    text-align: center;
    box-shadow: 0 10px 30px rgba(12, 37, 24, 0.15);
}

.cta-card__title {
    font-family: 'Rector', serif !important;
    font-size: 22px !important;
    color: #ffffff !important;
    margin: 0 0 10px 0 !important;
    font-weight: 600 !important;
}

.cta-card__text {
    font-size: 14px;
    line-height: 20px;
    color: rgba(255, 255, 255, 0.8);
    margin: 0 0 20px 0;
}

.cta-card__rating {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    margin-bottom: 24px;
}

.rating-stars {
    font-size: 16px;
    letter-spacing: 2px;
}

.rating-text {
    font-size: 12px;
    color: rgba(255, 255, 255, 0.6);
}

.btn--cta-sidebar {
    display: block !important;
    width: 100% !important;
    background: #F5A623 !important;
    color: #0c2518 !important;
    border: none !important;
    padding: 12px 24px !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    text-align: center;
    text-decoration: none;
    box-sizing: border-box;
}

.btn--cta-sidebar:hover {
    background: #e09212 !important;
    color: #0c2518 !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 15px rgba(245, 166, 35, 0.3) !important;
}

@media (max-width: 992px) {
    .subpage-two-col-layout {
        grid-template-columns: 1fr;
        gap: 40px;
    }
    .subpage-takeaway-sidebar {
        position: static;
        max-height: none;
    }
}

/* ==========================================================================
   TORN-EDGE HERO TRANSITIONS & BREADCRUMBS REALIGNMENT
   ========================================================================== */

.page-header__content-wrap,
.ta-hero__content-wrap {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    text-align: center !important;
    max-width: 900px !important;
    margin: 0 auto !important;
    padding-bottom: 30px !important;
    position: relative !important;
    z-index: 3 !important;
}

.page-header--has-bg .page-header__title,
.ta-hero--has-bg .ta-hero__title {
    text-align: center !important;
}

.hero-torn-edge {
    position: absolute !important;
    bottom: -1px !important;
    left: 0 !important;
    width: 100% !important;
    height: 30px !important;
    z-index: 5 !important;
    pointer-events: none !important;
}

.subpage-crumbs-wrap {
    padding-top: 24px !important;
    padding-bottom: 16px !important;
    margin-bottom: 0px !important;
    width: 100% !important;
    max-width: 1200px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    box-sizing: border-box !important;
    padding-left: 24px !important;
    padding-right: 24px !important;
    background-color: #ffffff !important;
}

.subpage-crumbs-wrap .breadcrumbs {
    margin: 0 !important;
    font-size: 13px !important;
    color: #8c8985 !important;
    font-family: 'Figtree', sans-serif !important;
    font-weight: 500 !important;
    line-height: 1.5 !important;
    display: flex !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    gap: 6px !important;
}

.subpage-crumbs-wrap .breadcrumbs a {
    color: #7c7976 !important;
    text-decoration: none !important;
    transition: color 0.2s ease !important;
}

.subpage-crumbs-wrap .breadcrumbs a:hover {
    color: var(--brand-green) !important;
    text-decoration: underline !important;
}

.subpage-crumbs-wrap .breadcrumbs span {
    color: #191815 !important;
    font-weight: 600 !important;
}

.ta-hero.ta-hero--has-bg {
    padding: 0 !important;
    margin-bottom: 0px !important;
}

/* Global H2 Override */
h2 {
    font-family: 'Rector', serif !important;
    font-style: normal !important;
    font-weight: 500 !important;
    color: rgb(25, 24, 21) !important;
    font-size: 52px !important;
    line-height: 60px !important;
}

@media (max-width: 768px) {
    h2 {
        font-size: 36px !important;
        line-height: 44px !important;
    }
}

/* ============================================================
   POPULAR TRIPS GRID & CARDS (homepage design replication)
   ============================================================ */
.yz-popular-trips-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
    margin-top: 40px;
}

.yz-trip-card-link {
    display: flex;
    flex-direction: column;
    text-decoration: none;
    color: inherit;
    height: 100%;
}

.yz-trip-image-wrapper {
    position: relative;
    overflow: hidden;
    border-radius: 18px;
    aspect-ratio: 4/3;
    box-shadow: 0 10px 30px rgba(0,0,0,.08);
    transition: box-shadow .4s ease;
}

.yz-trip-card:hover .yz-trip-image-wrapper {
    box-shadow: 0 20px 60px rgba(0,0,0,.15);
}

.yz-trip-image-wrapper::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(to bottom, rgba(0,0,0,0) 50%, rgba(0,0,0,0.4) 100%);
    pointer-events: none;
    z-index: 10;
}

.yz-trip-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .8s cubic-bezier(0.25, 1, 0.5, 1);
}

.yz-trip-card:hover .yz-trip-img {
    transform: scale(1.08);
}

.yz-trip-save-btn {
    position: absolute;
    right: 16px;
    bottom: 16px;
    width: 42px;
    height: 42px;
    border: none;
    border-radius: 50%;
    background: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: 20;
    transition: all .3s ease;
    box-shadow: 0 6px 20px rgba(0,0,0,.15);
}

.yz-trip-save-btn:hover {
    transform: scale(1.1);
}

.yz-trip-save-btn svg {
    width: 18px;
    height: 18px;
    stroke: currentColor;
    fill: none;
    stroke-width: 2;
}

.yz-trip-save-btn.saved {
    background: #ff3b30;
    color: #fff;
}

.yz-trip-save-btn.saved svg {
    fill: currentColor;
}

.yz-trip-info {
    padding-top: 20px;
    text-align: center;
}

.yz-trip-title {
    font-family: 'Rector', serif !important;
    font-size: 20px !important;
    line-height: 24px !important;
    font-weight: 400 !important;
    color: rgb(48, 47, 44);
    margin: 0 0 10px;
    transition: color .3s ease;
}

.yz-trip-card:hover .yz-trip-title {
    color: #6a994e !important;
}

.yz-trip-meta {
    font-family: 'Figtree', sans-serif !important;
    font-size: 13px !important;
    line-height: 17px !important;
    font-weight: 500 !important;
    font-style: normal !important;
    color: rgb(124, 121, 118);
    margin-bottom: 8px;
}

.yz-trip-price {
    font-family: 'Figtree', sans-serif !important;
    font-size: 16px !important;
    line-height: 21px !important;
    font-weight: 500 !important;
    font-style: normal !important;
    color: rgb(25, 24, 21);
}

@media (max-width: 1200px) {
    .yz-popular-trips-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 991px) {
    .yz-popular-trips-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .yz-popular-trips-grid {
        grid-template-columns: 1fr;
    }
    .yz-trip-title {
        font-size: 24px !important;
    }
}

/* ==========================================================================
   BLOG ARCHIVE GRID & CARDS
   ========================================================================== */
.blog-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
    margin-top: 40px;
    margin-bottom: 60px;
}

.blog-card {
    background: transparent !important;
    border: none !important;
    border-radius: 0 !important;
    overflow: visible !important;
    display: flex !important;
    flex-direction: column !important;
    height: 100% !important;
    transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1) !important;
    box-shadow: none !important;
    box-sizing: border-box !important;
}

.blog-card__link {
    display: flex !important;
    flex-direction: column !important;
    height: 100% !important;
    text-decoration: none !important;
    color: inherit !important;
}

.blog-card:hover {
    transform: translateY(-6px) !important;
}

.blog-card__image-wrapper {
    position: relative !important;
    overflow: hidden !important;
    aspect-ratio: 16 / 9 !important; /* Strict 16:9 aspect ratio */
    width: 100% !important;
    border-radius: 16px !important; /* Rounded corners on the image only */
    background-color: #0c2518 !important;
    box-shadow: 0 10px 30px rgba(0,0,0,.04) !important;
    transition: box-shadow 0.4s ease !important;
}

.blog-card:hover .blog-card__image-wrapper {
    box-shadow: 0 16px 40px rgba(0,0,0,.12) !important;
}

.blog-card__img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
    transition: transform 0.8s cubic-bezier(0.25, 1, 0.5, 1) !important;
}

.blog-card:hover .blog-card__img {
    transform: scale(1.05) !important;
}

.blog-card__info {
    padding: 20px 0 0 0 !important; /* Flush left alignment */
    display: flex !important;
    flex-direction: column !important;
    flex-grow: 1 !important;
}

.blog-card__category {
    font-family: 'Figtree', sans-serif !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    color: #6a994e !important;
    letter-spacing: 1.5px !important;
    margin-bottom: 12px !important;
    display: inline-block !important;
}

.blog-card__title {
    font-family: 'Rector', serif !important;
    font-size: 20px !important;
    line-height: 26px !important;
    font-weight: 400 !important;
    color: #191815 !important;
    margin: 0 0 12px 0 !important;
    transition: color 0.3s ease !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    height: 52px !important; /* 2 lines * 26px line-height */
}

.blog-card:hover .blog-card__title {
    color: #6a994e !important;
}

.blog-card__excerpt {
    font-family: 'Figtree', sans-serif !important;
    font-size: 14px !important;
    line-height: 22px !important;
    font-weight: 400 !important;
    color: #4b5563 !important;
    margin-bottom: 20px !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    height: 44px !important; /* 2 lines * 22px line-height */
}

.blog-card__read-more {
    font-family: 'Figtree', sans-serif !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: #191815 !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    margin-top: auto !important;
    transition: color 0.3s ease !important;
}

.blog-card__read-more svg {
    transition: transform 0.3s cubic-bezier(0.25, 1, 0.5, 1) !important;
}

.blog-card:hover .blog-card__read-more {
    color: #6a994e !important;
}

.blog-card:hover .blog-card__read-more svg {
    transform: translateX(4px) !important;
    stroke: #6a994e !important;
}

/* ============================================================
   BLOG FILTERS BAR
   ============================================================ */
.blog-filter-dropdown {
    position: relative;
    display: inline-block;
}

.blog-filter-btn {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    background: #ffffff !important;
    border: 1px solid #191815 !important;
    border-radius: 30px !important;
    padding: 10px 24px !important;
    font-family: 'Figtree', sans-serif !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    color: #191815 !important;
    cursor: pointer !important;
    transition: background-color 0.2s, border-color 0.2s !important;
}

.blog-filter-btn:hover,
.blog-filter-dropdown.is-active .blog-filter-btn {
    background-color: #FAF7F0 !important;
}

.blog-filter-btn .filter-chevron {
    transition: transform 0.3s ease !important;
}

.blog-filter-dropdown.is-active .blog-filter-btn .filter-chevron {
    transform: rotate(180deg) !important;
}

.blog-filter-menu {
    position: absolute !important;
    top: calc(100% + 8px) !important;
    left: 0 !important;
    min-width: 200px !important;
    background: #ffffff !important;
    border: 1px solid #E4E0D8 !important;
    border-radius: 12px !important;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08) !important;
    padding: 8px 0 !important;
    z-index: 100 !important;
    opacity: 0 !important;
    visibility: hidden !important;
    transform: translateY(-10px) !important;
    transition: opacity 0.3s cubic-bezier(0.16, 1, 0.3, 1), 
                transform 0.3s cubic-bezier(0.16, 1, 0.3, 1), 
                visibility 0.3s !important;
}

.blog-filter-dropdown.is-active .blog-filter-menu {
    opacity: 1 !important;
    visibility: visible !important;
    transform: translateY(0) !important;
}

.blog-filter-menu a {
    display: block !important;
    padding: 10px 20px !important;
    font-family: 'Figtree', sans-serif !important;
    font-size: 14px !important;
    color: #4b5563 !important;
    text-decoration: none !important;
    transition: background-color 0.2s, color 0.2s !important;
}

.blog-filter-menu a:hover {
    background-color: #FAF7F0 !important;
    color: #6a994e !important;
}

.no-filter-items {
    display: block !important;
    padding: 10px 20px !important;
    font-family: 'Figtree', sans-serif !important;
    font-size: 13px !important;
    color: #9ca3af !important;
    font-style: italic !important;
}

.blog-clear-filters-btn {
    font-family: 'Figtree', sans-serif !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    color: #191815 !important;
    text-decoration: none !important;
    display: inline-block !important;
    position: relative !important;
    letter-spacing: 0.5px !important;
    margin-left: 8px !important;
    padding-bottom: 2px !important;
    border-bottom: 2px solid #F4B942 !important; /* Brand gold */
    transition: border-color 0.2s, color 0.2s !important;
}

.blog-clear-filters-btn:hover {
    border-color: #6a994e !important;
    color: #6a994e !important;
}

@media (max-width: 1200px) {
    .blog-grid {
        gap: 24px !important;
    }
}

@media (max-width: 991px) {
    .blog-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 24px !important;
    }
}

@media (max-width: 768px) {
    .blog-grid {
        grid-template-columns: 1fr !important;
        gap: 28px !important;
        margin-top: 30px !important;
    }
    .blog-card__info {
        padding: 16px 0 0 0 !important;
    }
}

/* ==========================================================================
   MOBILE NAV — Single consolidated block. Replaces all previous mobile nav
   rules. Desktop pill nav (≥1025px) is untouched above this block.
   ========================================================================== */

/* Sub-menu toggle: hidden on desktop, shown in mobile block below */
.sub-menu-toggle { display: none; }
.mobile-nav-footer { display: none; }
.mobile-search-wrapper { display: none; }
@media (max-width: 1024px) {
  .mobile-search-wrapper { display: block !important; }
  .mobile-nav-footer { display: flex !important; }
  .hide-on-desktop { display: block !important; }
  .hide-on-mobile { display: none !important; }

  /* ── Sticky header on mobile ── */
  #site-nav {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 10000 !important;
    background: #ffffff !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    box-shadow: 0 1px 0 rgba(0,0,0,0.08) !important;
    border: none !important;
  }

  /* Remove pill shape on mobile */
  #site-nav .pill-wrap {
    border-radius: 0 !important;
    margin: 0 auto !important;
    padding: 0 1.25rem !important;
    height: 60px !important;
    box-shadow: none !important;
    background: transparent !important;
    display: flex;
    align-items: center;
    justify-content: space-between;
    max-width: 100% !important;
  }

  /* Logo */
  #site-nav .site-logo-img img {
    height: 36px !important;
    width: auto !important;
  }

  /* Hide desktop CTA button */
  #site-nav .header-cta { display: none !important; }

  /* Show hamburger */
  .nav-toggle {
    display: flex !important;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 5px;
    width: 44px;
    height: 44px;
    border: 1px solid #E4E0D8;
    border-radius: 8px;
    background: #ffffff;
    cursor: pointer;
    z-index: 10001;
    position: relative;
  }
  .nav-toggle span {
    display: block;
    width: 20px;
    height: 2px;
    background: #1a202c;
    transition: transform 0.3s ease, opacity 0.3s ease;
  }
  .nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
  .nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
  .nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

  /* Push page content below fixed header */
  body:not(.home) #content { padding-top: 60px !important; }
  .home #content { padding-top: 0 !important; }

  /* ── Mobile Slide-out Overlay Backdrop ── */
  .main-nav {
    position: fixed !important;
    inset: 0 !important;
    width: 100% !important;
    height: 100vh !important;
    background: rgba(0, 0, 0, 0.4) !important;
    z-index: 9999 !important;
    padding: 0 !important;
    overflow: hidden !important;
    display: block !important;
    /* Hidden by default */
    opacity: 0 !important;
    visibility: hidden !important;
    transition: opacity 0.35s ease, visibility 0.35s !important;
    /* Reset anything set in desktop blocks */
    border: none !important;
    box-shadow: none !important;
    backdrop-filter: blur(4px) !important;
    -webkit-backdrop-filter: blur(4px) !important;
    margin: 0 !important;
    right: 0 !important;
    transform: none !important;
  }
  .main-nav.is-open {
    opacity: 1 !important;
    visibility: visible !important;
  }

  /* ── Mobile Drawer Panel ── */
  .main-nav__drawer {
    position: fixed !important;
    top: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    left: auto !important;
    width: 85% !important;
    max-width: 360px !important;
    height: 100vh !important;
    background: #ffffff !important;
    box-shadow: -8px 0 32px rgba(0, 0, 0, 0.15) !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    padding: 24px 24px 40px 24px !important;
    box-sizing: border-box !important;
    overflow-y: auto !important;
    transform: translateX(100%) !important;
    transition: transform 0.35s cubic-bezier(0.16, 1, 0.3, 1) !important;
    z-index: 10000 !important;
  }
  .main-nav.is-open .main-nav__drawer {
    transform: translateX(0) !important;
  }

  /* ── Mobile Menu Close Header ── */
  .mobile-nav-header {
    display: flex !important;
    justify-content: flex-end !important;
    align-items: center !important;
    width: 100% !important;
    margin-bottom: 16px !important;
  }
  .mobile-nav-close {
    background: none !important;
    border: none !important;
    padding: 8px !important;
    cursor: pointer !important;
    color: #191815 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: color 0.2s !important;
  }
  .mobile-nav-close:hover {
    color: #6a994e !important;
  }
  .mobile-nav-close svg {
    width: 24px !important;
    height: 24px !important;
  }

  /* ── Menu list ── */
  .floating-pill-header .main-menu:not(.hide-on-desktop),
  .floating-pill-header .main-menu,
  .main-menu {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    gap: 0 !important;
    height: auto !important;
    width: 100% !important;
  }
  .floating-pill-header .main-menu:not(.hide-on-desktop) > li,
  .floating-pill-header .main-menu > li,
  .main-menu > li {
    width: 100% !important;
    height: auto !important;
    min-height: unset !important;
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    justify-content: space-between !important;
    position: relative !important;
    border-bottom: 1px solid #f3f4f6 !important;
  }
  .floating-pill-header .main-menu:not(.hide-on-desktop) > li:last-child,
  .floating-pill-header .main-menu > li:last-child,
  .main-menu > li:last-child { border-bottom: none !important; }

  /* Top-level links container */
  .nav-link-wrapper {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    width: 100% !important;
    padding: 12px 0 !important;
    min-height: unset !important;
    cursor: pointer !important;
  }

  .main-menu > li .nav-link,
  .main-menu > li > a {
    font-family: 'Figtree', -apple-system, BlinkMacSystemFont, sans-serif !important;
    font-size: 16px !important;
    font-weight: 500 !important;
    color: #111827 !important;
    text-decoration: none !important;
    height: auto !important;
    min-height: unset !important;
    line-height: 1.3 !important;
    text-shadow: none !important;
    margin: 0 !important;
    padding: 14px 0 !important;
    flex: 1 !important;
    display: flex !important;
    align-items: center !important;
    transition: color 0.2s cubic-bezier(0.4, 0, 0.2, 1) !important;
    border: none !important;
    background: none !important;
    -webkit-tap-highlight-color: transparent !important;
    user-select: none !important;
    -webkit-user-select: none !important;
  }

  /* Strip legacy duplicate pseudo-icons on mobile */
  .main-menu > li.menu-item-has-children > a::after,
  .main-menu .menu-item-has-children > a::after,
  .main-menu li:has(> ul) > a::after,
  .main-menu a::after {
    display: none !important;
    content: none !important;
  }

  .main-menu > li .nav-link:hover,
  .main-menu > li > a:hover { 
    color: #6a994e !important; 
  }

  /* Active/touch state */
  .main-menu > li .nav-link:active,
  .main-menu > li > a:active {
    color: #6a994e !important;
    opacity: 0.7 !important;
  }

  /* ── Sub-menu toggle button ── */
  .sub-menu-toggle {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    position: static !important;
    transform: none !important; /* Reset legacy translateY(-50%) */
    width: 44px !important;
    height: 44px !important;
    background: transparent !important;
    border: none !important;
    color: #9ca3af !important;
    cursor: pointer !important;
    z-index: 5 !important;
    padding: 0 !important;
    margin: 0 0 0 auto !important;
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1), 
                color 0.2s cubic-bezier(0.4, 0, 0.2, 1),
                background-color 0.2s cubic-bezier(0.4, 0, 0.2, 1) !important;
    border-radius: 8px !important;
    -webkit-tap-highlight-color: transparent !important;
  }

  .sub-menu-toggle:active {
    background: rgba(106, 153, 78, 0.08) !important;
    transform: scale(0.95) !important;
  }

  /* Rotate when open */
  .main-menu > li.sub-menu-open .sub-menu-toggle,
  .sub-menu-toggle[aria-expanded="true"] {
    transform: rotate(180deg) !important;
    color: #6a994e !important;
  }

  .main-menu > li.sub-menu-open .sub-menu-toggle:active,
  .sub-menu-toggle[aria-expanded="true"]:active {
    transform: rotate(180deg) scale(0.95) !important;
  }

  /* ── Sub-menus Container ── */
  .main-menu li > ul {
    list-style: none !important;
    padding: 0 0 0.5rem 1rem !important;
    margin: 0 !important;
    width: 100% !important;
    /* Closed state (Accordion Document Flow) */
    max-height: 0 !important;
    overflow: hidden !important;
    opacity: 0 !important;
    visibility: hidden !important;
    position: static !important;
    box-shadow: none !important;
    border: none !important;
    background: transparent !important;
    border-radius: 0 !important;
    transform: none !important;
    display: block !important;
    transition: max-height 0.4s cubic-bezier(0.4, 0, 0.2, 1), 
                opacity 0.3s cubic-bezier(0.4, 0, 0.2, 1), 
                visibility 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
  }

  .main-menu li.sub-menu-open > ul {
    max-height: 600px !important;
    opacity: 1 !important;
    visibility: visible !important;
  }

  /* Sub-menu item styling */
  .main-menu li ul li {
    border: none !important;
    padding: 0 !important;
    width: 100% !important;
    display: block !important;
  }

  .main-menu li ul a {
    display: block !important;
    padding: 11px 0.75rem !important;
    margin: 0.125rem 0 !important;
    font-size: 0.9rem !important;
    font-weight: 500 !important;
    color: #4b5563 !important;
    text-decoration: none !important;
    height: auto !important;
    min-height: unset !important;
    justify-content: flex-start !important;
    transition: color 0.2s cubic-bezier(0.4, 0, 0.2, 1),
                background-color 0.2s cubic-bezier(0.4, 0, 0.2, 1) !important;
    border-radius: 8px !important;
    -webkit-tap-highlight-color: transparent !important;
    user-select: none !important;
    -webkit-user-select: none !important;
  }

  .main-menu li ul a:hover { 
    color: #6a994e !important;
    background: rgba(106, 153, 78, 0.04) !important;
  }

  .main-menu li ul a:active {
    color: #6a994e !important;
    background: rgba(106, 153, 78, 0.12) !important;
    transform: scale(0.98) !important;
  }

  /* Smooth scrolling for iOS Safari */
  .main-menu {
    -webkit-overflow-scrolling: touch !important;
  }

  /* Separator lines between menu items (optional - comment out if not needed) */
  .main-menu > li:not(:last-child) {
    border-bottom: 1px solid rgba(0, 0, 0, 0.05) !important;
  }

  /* ── Mobile footer: phone + CTA ── */
  .mobile-nav-footer {
    display: flex !important;
    flex-direction: column !important;
    gap: 1rem !important;
    margin-top: auto !important;
    padding-top: 2rem !important;
    border-top: 1px solid #E4E0D8 !important;
    width: 100% !important;
  }
  .mobile-nav-phone {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    color: #111827 !important;
    text-decoration: none !important;
  }
  .mobile-nav-phone:hover { color: #6a994e !important; }
  .btn--mobile-cta {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    background: #6a994e !important;
    color: #ffffff !important;
    border: none !important;
    border-radius: 8px !important;
    padding: 14px 24px !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    text-align: center !important;
    cursor: pointer !important;
  }
  .btn--mobile-cta:hover { background: #5a8443 !important; }

  /* Prevent body scroll when nav is open */
  body.nav-open { overflow: hidden !important; }

  /* Force hide desktop elements on mobile */
  .hide-on-mobile { display: none !important; }
}
/* END mobile nav block */

/* ==========================================================================
   GLOBAL FOOTER REFINEMENTS
   ========================================================================== */
/* 1. Footer Widget Titles Spacing, Font Size, Color & Contrast */
.site-footer .footer-col h3,
.site-footer .footer-col h4,
.site-footer .payment-title {
	font-family: 'Rector', serif !important;
	font-size: 1.25rem !important;
	font-weight: 400 !important;
	color: #FFFFFF !important;
	margin: 0 0 1.5rem 0 !important;
	text-transform: none !important;
	letter-spacing: normal !important;
	border-bottom: none !important;
	padding-bottom: 0 !important;
}

/* 2. Partners Logo Alignment, Distribution, and Uniform Color */
.site-footer .trusted-partners-row {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    gap: 20px !important;
    margin-bottom: 24px !important;
}

.site-footer .trusted-partners-row a,
.site-footer .trusted-partners-row .kayak-badge-full {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    height: 24px !important; /* Uniform proportional height constraint */
    text-decoration: none !important;
    box-shadow: none !important;
    border: none !important;
}

.site-footer .trusted-partners-row img {
    max-height: 100% !important;
    width: auto !important;
    object-fit: contain !important;
    filter: brightness(0) invert(1) !important; /* Forces grayscale/white rendering */
    opacity: 0.55 !important;
    transition: opacity 0.2s ease, transform 0.2s ease !important;
}

.site-footer .trusted-partners-row img:hover {
    opacity: 1 !important;
    transform: scale(1.05) !important;
}

/* Make Kayak badge match the uniform outline style rather than solid orange block */
.site-footer .trusted-partners-row .kayak-badge-full {
    background: rgba(255, 255, 255, 0.08) !important;
    color: rgba(255, 255, 255, 0.6) !important;
    border: 1.5px solid rgba(255, 255, 255, 0.3) !important;
    border-radius: 4px !important;
    padding: 0 8px !important;
    font-size: 11px !important;
    letter-spacing: 1px !important;
    opacity: 0.9 !important;
    transition: background-color 0.2s, color 0.2s, border-color 0.2s, transform 0.2s !important;
}

.site-footer .trusted-partners-row .kayak-badge-full:hover {
    background: rgba(255, 255, 255, 0.2) !important;
    color: #ffffff !important;
    border-color: #ffffff !important;
    transform: scale(1.05) !important;
}

/* 3. Footer Bottom Bar: Move Back to Top to the Rightside */
.site-footer .footer-bottom__inner {
    display: flex !important;
    flex-direction: row !important;
    justify-content: space-between !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    width: 100% !important;
    max-width: 1440px !important;
    margin: 0 auto !important;
}

.site-footer .footer-copyright-combined {
    width: auto !important;
    text-align: left !important;
    margin: 0 !important;
}

.site-footer .back-to-top {
    margin-left: auto !important; /* Pushes button to far right */
    background: none !important;
    border: none !important;
    color: #9CA3AF !important;
    cursor: pointer !important;
    font-size: 13px !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    transition: color 0.2s !important;
}

.site-footer .back-to-top:hover {
    color: #ffffff !important;
}

@media (max-width: 768px) {
    .site-footer .footer-bottom__inner {
        flex-direction: column !important;
        text-align: center !important;
        gap: 12px !important;
    }
    .site-footer .footer-copyright-combined {
        width: 100% !important;
        text-align: center !important;
    }
    .site-footer .back-to-top {
        margin-left: 0 !important;
    }
}

/* ==========================================================================
   SINGLE BLOG PAGE & WIDGET / PARTNERS FOOTER REFINEMENTS
   ========================================================================== */

/* 1. Single Blog Layout & Content Centering when Sidebar is Hidden */
.single-post-layout.no-sidebar {
	grid-template-columns: 1fr !important;
}
.single-post-layout.no-sidebar .single-post-main {
	margin: 0 auto !important;
	max-width: 800px !important;
	width: 100% !important;
}

/* 2. Force Footer Bottom Copyright to Left and Back to Top to Right on Desktop */
@media (min-width: 993px) {
    .site-footer .footer-bottom__inner {
        display: flex !important;
        flex-direction: row !important;
        justify-content: space-between !important;
        align-items: center !important;
        flex-wrap: nowrap !important;
        text-align: left !important;
    }
    .site-footer .footer-copyright-combined {
        width: auto !important;
        text-align: left !important;
        margin: 0 !important;
    }
    .site-footer .back-to-top {
        margin-left: auto !important;
        display: inline-flex !important;
        align-items: center !important;
        white-space: nowrap !important;
    }
}

/* 3. Hierarchical Indentation for Table of Contents Subheadings */
.toc-link.toc-link--h3 {
	padding-left: 12px !important;
	font-size: 0.82rem !important;
	color: #6b7280 !important;
	font-weight: 400 !important;
}
.toc-link.toc-link--h3.active {
	color: var(--primary) !important;
	font-weight: 600 !important;
}

/* ============================================================
   GLOBAL FAQ COMPONENT STYLES
   ============================================================ */
.ta-faq { padding: 100px 0 100px; background: var(--white); }
.ta-faq__head { max-width: 720px; margin: 0 auto 30px; text-align: center; }
.ta-faq__head h2 { font-family: var(--font-display); font-size: var(--t-3xl); font-weight: 500; color: var(--text); margin: 0; }
.ta-faq__list { max-width: 820px; margin: 0 auto; }

.ta-faq__item {
  border: 1px solid var(--border); border-radius: var(--r-card);
  background: var(--white); margin-bottom: 12px;
  box-shadow: var(--shadow-1);
  transition: border-color var(--dur-base), box-shadow var(--dur-base), transform var(--dur-base);
}
.ta-faq__item[open] { border-color: var(--primary); }
.ta-faq__item:hover { box-shadow: var(--shadow-2); transform: translateY(-2px); }

.ta-faq__trigger {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  list-style: none; cursor: pointer; padding: 24px;
  font-family: var(--font-sans); font-size: 17px; font-weight: 600; color: var(--text);
  user-select: none; -webkit-user-select: none;
}
.ta-faq__trigger::marker,
.ta-faq__trigger::-webkit-details-marker { display: none !important; }

.ta-faq__icon {
  flex-shrink: 0; width: 10px; height: 10px;
  border-left: 2px solid currentColor; border-bottom: 2px solid currentColor;
  transform: rotate(-45deg); margin-right: 4px; margin-top: -4px;
  transition: transform var(--dur-base);
}
.ta-faq__item[open] .ta-faq__icon { transform: rotate(135deg); }

.ta-faq__answer { padding: 0 24px 24px; }
.ta-faq__answer p { margin: 0; color: var(--text-light); line-height: 1.7; font-size: 15px; }

/* ============================================================
   GLOBAL WISHLIST/SAVE HEART BUTTON STYLES
   ============================================================ */
.yz-trip-save-btn {
    position: absolute; right: 16px; bottom: 16px; width: 42px; height: 42px;
    border: none; border-radius: 50%; background: #ffffff;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer; z-index: 20; transition: all .3s ease; box-shadow: 0 6px 20px rgba(0,0,0,.15);
    color: #1A1A1A;
}
.yz-trip-save-btn:hover { transform: scale(1.1); }
.yz-trip-save-btn svg { width: 18px; height: 18px; stroke: currentColor; fill: none; stroke-width: 2; }
.yz-trip-save-btn.saved,
.yz-trip-save-btn.is-fav { background: #ff3b30 !important; color: #ffffff !important; }
.yz-trip-save-btn.saved svg,
.yz-trip-save-btn.is-fav svg { fill: currentColor !important; stroke: currentColor !important; }

/* Single Tour page save button saved state */
.tour-action-btn.saved svg,
.tour-action-btn.is-fav svg { fill: #ff3b30 !important; stroke: #ff3b30 !important; }
.tour-action-btn.saved .save-btn-text,
.tour-action-btn.is-fav .save-btn-text { color: #ff3b30 !important; }
