/*
Theme Name: LL
Theme URI: https://landmarksandluggage.com
Author: Landmarks & Luggage
Author URI: https://landmarksandluggage.com
Description: Official theme for Landmarks & Luggage, a travel editorial brand.
Requires at least: 6.4
Tested up to: 6.7
Requires PHP: 8.0
Version: 1.2.6
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: ll
Tags: blog, custom-menu, featured-images, full-width-template, wide-blocks
*/

/* ================================
   DESIGN TOKENS
   ================================ */
:root {
	/* ── Figma semantic tokens ── */

	/* Core */
	--color-primary:        #6A87A7;
	--color-primary-hover:  #56687F;
	--color-secondary:      #616A3C;
	--color-secondary-light:#ADB57E;
	--color-beacon:         #D6A664;
	--color-beacon-dark:    #B88A4A;
	--color-beacon-light:   #E7D1A8;
	--color-signal:         #BB6C64;
	--color-signal-soft:    #DCCFC7;
	--color-primary-light:  #A7BDD1;
	--color-primary-mist:   #B8CAD9;

	/* Text */
	--text-strong:  #25313A;
	--text-muted:   #4E6374;
	--text-subtle:  #47576A;

	/* Accents */
	--accent-lightbeam: #E3CD9B;
	--accent-lantern:   #BB6C64;
	--accent-sky:       #7C9CB5;
	--accent-grass:     #9EA66F;

	/* Bright extracted shades */
	--bright-cool-white:      #F7F9FC;
	--bright-lighthouse-white:#F3F6FA;
	--bright-cloud-white:     #EFF3F7;
	--bright-paper-haze:      #EDF1F5;
	--bright-beam-mist:       #F0EAE1;
	--bright-beam-glow:       #ECE0AD;
	--bright-beam-pale:       #E7DBA3;
	--bright-beacon-sand:     #E2C792;
	--bright-sky-chalk:       #DCE5ED;
	--bright-blue-haze:       #D4DEE7;
	--bright-harbor-mist:     #C0CFDA;
	--bright-sky-wash:        #A7BDD1;
	--bright-sea-glass:       #A6C0CB;
	--bright-stone-white:     #E1DDD9;
	--bright-pale-grass:      #ADB57E;
	--bright-grass-haze:      #A6A86F;

	/* Neutral ramp */
	--neutral-000: #F7F9FC;
	--neutral-025: #F3F5F8;
	--neutral-050: #ECEFF3;
	--neutral-100: #E3E7EC;
	--neutral-200: #D6DCE3;
	--neutral-300: #C5CCD4;
	--neutral-400: #AEB7C1;
	--neutral-500: #919CA8;
	--neutral-600: #778290;
	--neutral-700: #5F6873;
	--neutral-800: #464E58;
	--neutral-900: #25313A;

	/* UI surfaces */
	--ui-bg:               #F7F9FC;
	--ui-surface:          #F3F5F8;
	--ui-surface-muted:    #ECEFF3;
	--ui-surface-subtle:   #E3E7EC;
	--ui-surface-warm:     #F6F1E8;
	--ui-surface-warm-mid: #F0E7D8;

	/* UI borders */
	--ui-border:        #D6DCE3;
	--ui-border-strong: #AEB7C1;

	/* UI links */
	--ui-link:       #56687F;
	--ui-link-hover: #47576A;

	/* UI buttons */
	--ui-button-bg:     #6A87A7;
	--ui-button-hover:  #4E6374;
	--ui-button-active: #56687F;
	--ui-button-text:   #F7F9FC;

	/* UI focus & inputs */
	--ui-focus-ring:    #25313A;
	--ui-input-bg:      #F3F5F8;
	--ui-input-border:  #D6DCE3;
	--ui-input-focus:   #6A87A7;
	--ui-selection-bg:  #DCE5ED;

	/* UI disabled */
	--ui-disabled-bg:   #E3E7EC;
	--ui-disabled-text: #919CA8;

	/* UI status */
	--ui-success:      #929A66;
	--ui-success-soft: #ECEFF3;
	--ui-warning:      #D6A664;
	--ui-warning-soft: #F0EAE1;
	--ui-danger:       #BB6C64;
	--ui-danger-soft:  #DCCFC7;
	--ui-info:         #7C9CB5;
	--ui-info-soft:    #DCE5ED;

	/* ── Theme aliases (→ Figma tokens) ── */
	--ll-warm-cream:  var(--ui-surface-warm);
	--ll-warm-sand:   var(--ui-surface-warm-mid);
	--ll-cool-white:  var(--bright-cool-white);
	--ll-charcoal:    var(--text-strong);
	--ll-slate-600:   var(--text-muted);
	--ll-slate-500:   var(--color-primary-hover);
	--ll-slate-400:   var(--color-primary);
	--ll-slate-300:   var(--accent-sky);
	--ll-slate-200:   var(--bright-sea-glass);
	--ll-gold:        var(--color-beacon);
	--ll-gold-dark:   var(--color-beacon-dark);
	--ll-olive:       var(--accent-grass);
	--ll-border:      var(--neutral-100);
	--ll-border-dark: rgba(255,255,255,.12);

	/* Typography */
	--font-serif:   'Source Serif 4', Georgia, 'Times New Roman', serif;
	--font-sans:    'Bricolage Grotesque', system-ui, -apple-system, sans-serif;
	--font-hand:    'Caveat', cursive;
	--font-display: var(--font-sans); /* headlines — swap to --font-serif to revert */

	/* Type scale */
	--text-xs:   0.75rem;   /* 12px */
	--text-sm:   0.875rem;  /* 14px */
	--text-base: 1rem;      /* 16px */
	--text-lg:   1.125rem;  /* 18px */
	--text-xl:   1.25rem;   /* 20px */
	--text-2xl:  1.5rem;    /* 24px */
	--text-3xl:  1.875rem;  /* 30px */
	--text-4xl:  2.25rem;   /* 36px */
	--text-5xl:  3rem;      /* 48px */
	--text-6xl:  3.75rem;   /* 60px */
	--text-7xl:  4.5rem;    /* 72px */
	/* Off-scale intentional sizes */
	--text-hand-eyebrow: 26px;    /* Caveat handwritten eyebrows — sits between 2xl/3xl by design */
	--text-label-sm:     0.8125rem; /* 13px utility labels — between xs/sm, used for view-all links */

	/* Spacing */
	--s1:  0.25rem;
	--s2:  0.5rem;
	--s3:  0.75rem;
	--s4:  1rem;
	--s5:  1.25rem;
	--s6:  1.5rem;
	--s8:  2rem;
	--s10: 2.5rem;
	--s12: 3rem;
	--s16: 4rem;
	--s20: 5rem;
	--s24: 6rem;

	/* Layout */
	--ll-shell:   1200px;
	--ll-content: 700px;
	--ll-gutter:  2rem;

	/* Shape */
	--r-sm:   4px;
	--r-md:   8px;
	--r-lg:   16px;
	--r-xl:   24px;
	--r-2xl:  40px;
	--r-pill: 999px;

	/* Motion */
	--ease-fast: 160ms ease;
	--ease-base: 260ms ease;

	/* Shadow */
	--shadow-sm: 0 1px 3px rgba(37,49,58,.06), 0 1px 2px rgba(37,49,58,.04);
	--shadow-md: 0 4px 16px rgba(37,49,58,.1),  0 2px 6px  rgba(37,49,58,.04);
	--shadow-lg: 0 16px 40px rgba(37,49,58,.14), 0 4px 12px rgba(37,49,58,.06);
}

/* ================================
   RESET
   ================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; background: var(--ll-warm-cream); overflow-x: clip; }
body {
	background: var(--ll-cool-white);
	color: var(--ll-charcoal);
	font-family: var(--font-sans);
	font-size: var(--text-base);
	line-height: 1.65;
	-webkit-font-smoothing: antialiased;
	overflow-x: clip;
}
img, video, svg { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
button { cursor: pointer; font-family: inherit; border: none; background: none; }

/* ================================
   LAYOUT UTILITIES
   ================================ */
.ll-shell {
	width: min(var(--ll-shell), calc(100% - var(--ll-gutter) * 2));
	margin-inline: auto;
}

/* ================================
   BUTTONS
   ================================ */
.ll-btn {
	display: inline-flex;
	align-items: center;
	gap: var(--s2);
	font-family: var(--font-sans);
	font-size: var(--text-sm);
	font-weight: 600;
	letter-spacing: 0.05em;
	padding: 0.65rem 1.4rem;
	border-radius: var(--r-pill);
	transition: background var(--ease-fast), color var(--ease-fast), transform var(--ease-fast), box-shadow var(--ease-fast);
	border: 1.5px solid transparent;
	white-space: nowrap;
}
.ll-btn:active { transform: scale(.98); }

.ll-btn--primary {
	background: var(--ll-charcoal);
	color: var(--ll-warm-cream);
	border-color: var(--ll-charcoal);
}
.ll-btn--primary:hover { background: var(--ll-charcoal); border-color: var(--ll-charcoal); transform: translateY(-1px); box-shadow: var(--shadow-sm); }

.ll-btn--outline {
	background: transparent;
	color: var(--ll-charcoal);
	border-color: var(--ll-charcoal);
}
.ll-btn--outline:hover { background: var(--ll-charcoal); color: var(--ll-warm-cream); }

.ll-btn--gold {
	background: var(--ll-gold);
	color: var(--ll-charcoal);
	border-color: var(--ll-gold);
}
.ll-btn--gold:hover { background: var(--ll-gold-dark); border-color: var(--ll-gold-dark); }

.ll-btn--ghost-light {
	background: transparent;
	color: #fff;
	border-color: rgba(255,255,255,.6);
}
.ll-btn--ghost-light:hover { background: rgba(255,255,255,.1); border-color: #fff; }

/* ================================
   SECTION CHROME
   ================================ */
.ll-section { padding-block: var(--s20) var(--s24); }
.ll-section--warm  { background: var(--ll-warm-sand); }
.ll-section--cream { background: var(--ll-warm-cream); }
.ll-section--cool  { background: var(--ll-cool-white); }
.ll-section--dark  { background: var(--ll-charcoal); color: #fff; }

.ll-section__header {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: var(--s6);
	margin-bottom: var(--s10);
}

.ll-section-heading {
	font-family: var(--font-display);
	font-size: clamp(var(--text-3xl), 4vw, var(--text-5xl));
	font-weight: 400;
	letter-spacing: -0.03em;
	line-height: 1.12;
	color: var(--ll-charcoal);
}
.ll-section--dark .ll-section-heading { color: #fff; }
.ll-section-heading a { color: inherit; transition: color var(--ease-fast); }
.ll-section-heading a:hover { color: var(--ll-gold-dark); }

.ll-section__eyebrow {
	font-family: var(--font-hand);
	font-size: var(--text-2xl);
	color: var(--ll-slate-300);
	margin-bottom: var(--s1);
}

.ll-eyebrow {
	font-family: var(--font-hand);
	font-size: var(--text-hand-eyebrow);
	color: var(--ll-gold);
	margin-bottom: var(--s1);
}

.ll-section__view-all {
	font-family: var(--font-sans);
	font-size: var(--text-label-sm);
	font-weight: 700;
	letter-spacing: 0.02em;
	color: var(--ll-slate-500);
	text-decoration: underline;
	text-underline-offset: 3px;
	white-space: nowrap;
	transition: color var(--ease-fast);
}
.ll-section__view-all:hover { color: var(--ll-charcoal); }

/* ================================
   SITE HEADER
   ================================ */
.site-header {
	position: relative;
	z-index: 200;
	background: var(--ll-warm-cream);
}

body.search .site-header {
	margin-top: 0;
}

.site-header__inner {
	display: flex;
	align-items: center;
	height: 96px;
	position: relative;
}

.site-logo {
	display: inline-flex;
	align-items: center;
	gap: var(--s3);
	flex-shrink: 0;
	position: relative;
	z-index: 2; /* z-index keeps logo above search overlay */
}
.site-header__actions { flex-shrink: 0; margin-left: auto; }

.site-logo__image {
	width: auto;
	max-width: 3rem;
	max-height: 3rem;
	object-fit: contain;
}

.site-logo__text {
	font-family: var(--font-sans);
	font-size: 1.35rem;
	font-weight: 500;
	letter-spacing: 0;
	color: var(--ll-charcoal);
	white-space: nowrap;
	line-height: 1;
}
.site-logo__amp {
	color: var(--ll-gold-dark);
	font-family: var(--font-serif);
	font-style: italic;
	font-weight: 400;
	letter-spacing: 0;
}

.site-logo__text--footer {
	color: rgba(255,255,255,.88);
	display: block;
	margin-bottom: var(--s4);
}
.site-logo__text--footer .site-logo__amp { color: var(--ll-gold); }

.site-nav {
	margin-left: auto;
}
.site-nav__list { display: flex; gap: var(--s6); }
.site-nav__list a {
	font-family: var(--font-sans);
	font-size: var(--text-sm);
	font-weight: 500;
	letter-spacing: 0.04em;
	color: var(--ll-charcoal);
	transition: color var(--ease-fast);
	position: relative;
}
.site-nav__list a::after {
	content: '';
	position: absolute;
	bottom: -3px;
	left: 0;
	width: 0;
	height: 1px;
	background: var(--ll-gold);
	transition: width var(--ease-base);
}
.site-nav__list a:hover { color: var(--ll-gold-dark); }
.site-nav__list a:hover::after { width: 100%; }

/* Keep Destinations link in hover state while mega menu is open */
.site-nav__item--destinations:has([aria-expanded="true"]) > a { color: var(--ll-gold-dark); }
.site-nav__item--destinations:has([aria-expanded="true"]) > a::after { width: 100%; }

.site-header__actions {
	display: flex;
	align-items: center;
	gap: var(--s3);
	margin-left: var(--s6);
	flex-shrink: 0;
}

/* Search */
.site-header__search { display: flex; align-items: center; gap: var(--s2); }

.site-header__search input {
	width: 0;
	padding: 0.4rem 0;
	border: 1.5px solid transparent;
	border-radius: var(--r-pill);
	background: transparent;
	font-family: var(--font-sans);
	font-size: var(--text-sm);
	opacity: 0;
	pointer-events: none;
	transition: width 220ms ease, opacity 160ms ease, padding 220ms ease, border-color 220ms ease, background 220ms ease;
	outline: none;
}
.site-header__search.is-open input {
	width: 11rem;
	padding: 0.4rem 0.85rem;
	border-color: var(--ll-charcoal);
	background: rgba(255,255,255,.55);
	opacity: 1;
	pointer-events: auto;
}

.site-header__search-toggle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 34px;
	height: 34px;
	border: 1.5px solid var(--ll-charcoal);
	border-radius: var(--r-pill);
	background: transparent;
	color: var(--ll-charcoal);
	transition: background var(--ease-fast), color var(--ease-fast);
	flex-shrink: 0;
}
.site-header__search-toggle:hover { background: var(--ll-charcoal); color: var(--ll-warm-cream); }

/* Hamburger (mobile only) */
.site-header__hamburger {
	display: none;
	flex-direction: column;
	gap: 5px;
	width: 34px;
	height: 34px;
	align-items: flex-start;
	justify-content: center;
	padding-left: 7px;
	background: none;
	border: 1.5px solid var(--ll-charcoal);
	border-radius: var(--r-pill);
	flex-shrink: 0;
}
.site-header__hamburger span {
	display: block;
	height: 1.5px;
	border-radius: 1px;
	background: var(--ll-charcoal);
	transition: transform var(--ease-base), width var(--ease-base);
}
.site-header__hamburger span:nth-child(1) { width: 18px; }
.site-header__hamburger span:nth-child(2) { width: 12px; }
.site-header__hamburger.is-open span:nth-child(1) { width: 16px; transform: translateY(3.25px) rotate(45deg); }
.site-header__hamburger.is-open span:nth-child(2) { width: 16px; transform: translateY(-3.25px) rotate(-45deg); }

/* Mobile nav overlay */
.site-mobile-nav {
	display: none;
	position: fixed;
	inset: 0;
	z-index: 210;
	background: var(--ll-warm-cream);
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: var(--s6);
	padding: var(--s16);
}
.site-mobile-nav.is-open { display: flex; }

.site-mobile-nav__list { display: flex; flex-direction: column; align-items: center; gap: var(--s5); }
.site-mobile-nav__list li a {
	font-family: var(--font-display);
	font-size: clamp(var(--text-3xl), 8vw, var(--text-5xl));
	font-weight: 400;
	letter-spacing: -0.03em;
	color: var(--ll-charcoal);
	line-height: 1.2;
	transition: color var(--ease-fast);
}
.site-mobile-nav__list li a:hover { color: var(--ll-gold-dark); }

.site-mobile-nav__close {
	position: fixed; /* top/left set dynamically in openNav() to match hamburger */
	width: 34px;
	height: 34px;
	border: 1.5px solid var(--ll-charcoal);
	border-radius: var(--r-pill);
	background: none;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--ll-charcoal);
	transition: background var(--ease-fast), color var(--ease-fast);
}
.site-mobile-nav__close:hover { background: var(--ll-charcoal); color: var(--ll-warm-cream); }

/* ================================
   MEGA MENU
   ================================ */
body::after {
	content: '';
	position: fixed;
	inset: 0;
	background: rgba(247,249,252,.60);
	opacity: 0;
	pointer-events: none;
	transition: opacity 200ms ease;
	z-index: 180;
}
body.mega-is-open::after {
	opacity: 1;
}

.site-mega-menu {
	position: absolute;
	left: 0;
	right: 0;
	top: 100%;
	z-index: 190;
	background: var(--ll-warm-cream);
	visibility: hidden;
	opacity: 0;
	transform: translateY(-6px);
	transition: opacity 180ms ease, transform 180ms ease, visibility 0s 180ms;
	pointer-events: none;
}
.site-mega-menu::before {
	content: '';
	position: absolute;
	top: -12px;
	left: 0;
	right: 0;
	height: 12px;
}
.site-mega-menu.is-open {
	visibility: visible;
	opacity: 1;
	transform: translateY(0);
	transition: opacity 180ms ease, transform 180ms ease;
	pointer-events: auto;
}

.site-mega-menu__inner {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: var(--s8);
	padding-block: var(--s8);
}

/* Region card */
.site-mega-menu__region-card {
	display: block;
	position: relative;
	overflow: hidden;
	aspect-ratio: 16 / 9;
	background: var(--ll-warm-sand);
	margin-bottom: var(--s4);
}
.site-mega-menu__region-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 500ms ease;
}
.site-mega-menu__region-card:hover .site-mega-menu__region-img { transform: scale(1.04); }
.site-mega-menu__region-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(37,49,58,.72) 0%, transparent 55%);
}
.site-mega-menu__region-name {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	padding: var(--s4) var(--s4);
	font-family: var(--font-display);
	font-size: var(--text-xl);
	font-weight: 400;
	color: #fff;
	line-height: 1.2;
}

/* Place list */
.site-mega-menu__places {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--s3);
}

.site-mega-card {
	display: flex;
	flex-direction: column;
	gap: var(--s2);
	color: var(--ll-charcoal);
	transition: color var(--ease-fast);
}
.site-mega-card:hover { color: var(--ll-gold-dark); }

.site-mega-card__img-wrap {
	overflow: hidden;
	aspect-ratio: 3 / 2;
	background: var(--ll-warm-sand);
}
.site-mega-card__img-wrap img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 500ms ease;
}
.site-mega-card:hover .site-mega-card__img-wrap img { transform: scale(1.04); }
.site-mega-card__img-placeholder { width: 100%; height: 100%; background: var(--ll-warm-sand); }

.site-mega-card__name {
	font-family: var(--font-sans);
	font-size: var(--text-sm);
	font-weight: 600;
	line-height: 1.3;
}

/* Hide mega menu on mobile */
@media (max-width: 1024px) {
	.site-mega-menu { display: none !important; }
}

/* ================================
   HERO SECTION
   ================================ */
.ll-hero {
	background: var(--ll-cool-white);
	padding: var(--s12) 0 var(--s20);
}

.ll-hero__inner {
	display: grid;
	grid-template-columns: 1.05fr 0.95fr;
	gap: var(--s16);
	align-items: center;
}


.ll-hero__image-wrap {
	position: relative;
	overflow: hidden;
	aspect-ratio: 4 / 5;
	background: var(--ll-warm-sand);
}
.ll-hero__image-wrap img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 600ms ease;
}
.ll-hero__image-wrap:hover img { transform: scale(1.03); }

.ll-hero__content { padding-block: var(--s8); }

.ll-hero__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: var(--s3);
	font-family: var(--font-sans);
	font-size: var(--text-xs);
	font-weight: 700;
	letter-spacing: 0.13em;
	text-transform: uppercase;
	color: var(--ll-gold-dark);
	margin-bottom: var(--s5);
}
.ll-hero__eyebrow a {
	color: inherit;
	transition: color var(--ease-fast);
}
.ll-hero__eyebrow a:hover { color: var(--ll-gold); }

.ll-hero__title {
	font-family: var(--font-display);
	font-size: clamp(var(--text-4xl), 5vw, var(--text-7xl));
	font-weight: 400;
	line-height: 1.05;
	letter-spacing: -0.03em;
	color: var(--ll-charcoal);
	margin-bottom: var(--s5);
}

.ll-hero__excerpt {
	font-family: var(--font-sans);
	font-size: var(--text-lg);
	color: var(--ll-slate-600);
	line-height: 1.7;
	margin-bottom: var(--s10);
	max-width: 40ch;
}
.ll-hero__excerpt > p { margin: 0; }

.ll-hero__actions { display: flex; align-items: center; gap: var(--s4); margin-top: var(--s4); }

.ll-hero__scroll-hint {
	font-family: var(--font-hand);
	font-size: var(--text-xl);
	color: var(--ll-slate-400);
}

/* ================================
   FEATURED DESTINATIONS
   ================================ */
.ll-destinations-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--s5);
}

.ll-destination-card {
	position: relative;
	overflow: hidden;
	aspect-ratio: 3 / 4;
	background: var(--ll-warm-sand);
	display: block;
}
.ll-destination-card img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 500ms ease;
}
.ll-destination-card:hover img { transform: scale(1.05); }

.ll-destination-card__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(37,49,58,.78) 0%, rgba(37,49,58,.12) 55%, transparent 100%);
	transition: opacity var(--ease-base);
}
.ll-destination-card:hover .ll-destination-card__overlay { opacity: .85; }

.ll-destination-card__body {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	padding: var(--s5);
	color: #fff;
}

.ll-destination-card__region {
	font-family: var(--font-sans);
	font-size: var(--text-xs);
	font-weight: 700;
	letter-spacing: 0.11em;
	text-transform: uppercase;
	opacity: .75;
	margin-bottom: var(--s1);
}
.ll-destination-card__name {
	font-family: var(--font-display);
	font-size: var(--text-xl);
	font-weight: 400;
	line-height: 1.2;
}

/* ================================
   FEATURED DESTINATIONS — v3
   ================================ */

/* Section header row */
.ll-dest-header {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: var(--s6);
	margin-bottom: var(--s12);
}
.ll-dest-header__eyebrow {
	font-family: var(--font-hand);
	font-size: var(--text-hand-eyebrow);
	font-weight: 400;
	letter-spacing: 0;
	text-transform: none;
	color: var(--ll-gold);
	margin-bottom: var(--s2);
}
.ll-dest-heading {
	font-family: var(--font-sans);
	font-size: clamp(var(--text-3xl), 4vw, var(--text-5xl));
	font-weight: 300;
	letter-spacing: -0.03em;
	line-height: 1.12;
	color: var(--ll-charcoal);
}
.ll-dest-heading em {
	font-family: var(--font-serif);
	font-style: italic;
	font-weight: 400;
	font-size: 1.13em;
	color: var(--ll-slate-400);
	letter-spacing: -0.033em;
}
.ll-dest-header__link {
	font-family: var(--font-sans);
	font-size: var(--text-label-sm);
	font-weight: 700;
	letter-spacing: 0.02em;
	color: var(--ll-slate-500);
	text-decoration: underline;
	text-underline-offset: 3px;
	white-space: nowrap;
	padding-bottom: var(--s1);
	margin-bottom: var(--s8);
	transition: color var(--ease-fast);
}
.ll-dest-header__link:hover { color: var(--ll-charcoal); }

/* Three-column card grid */
.ll-dest-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--s8);
}

/* Individual card */
.ll-dest-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
}

/* Emoji icon bubble */
.ll-dest-card__icon {
	width: 72px;
	height: 72px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--ll-warm-sand);
	border: 1px solid rgba(43, 40, 36, 0.10);
	border-radius: 36px;
	font-size: 1.75rem;
	line-height: 1;
	margin-bottom: var(--s3);
}
.ll-dest-card__icon-img {
	width: 55px;
	height: 55px;
	object-fit: contain;
}
.ll-dest-card__icon:has(.ll-dest-card__icon-img) {
	background: none;
	border: none;
	border-radius: 0;
}

/* Destination label (gold eyebrow) */
.ll-dest-card__label {
	font-family: var(--font-sans);
	font-size: var(--text-xs);
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--ll-gold);
	margin-bottom: var(--s2);
}
.ll-dest-card__label a {
	color: inherit;
	transition: color var(--ease-fast);
}
.ll-dest-card__label a:hover { color: var(--ll-gold-dark); }

/* Two-tone tagline */
.ll-dest-card__title {
	font-family: var(--font-sans);
	font-size: clamp(var(--text-xl), 2vw, 1.75rem);
	font-weight: 500;
	letter-spacing: -0.025em;
	line-height: 1.1;
	margin-bottom: var(--s5);
	max-width: 380px;
}
.ll-dest-card__title-strong { color: var(--ll-charcoal); }
.ll-dest-card__title-light  { color: var(--ll-slate-400); }
.ll-dest-card__title-light em {
	font-family: var(--font-serif);
	font-style: italic;
	font-weight: 400;
}

/* Image wrapper */
.ll-dest-card__image-wrap {
	display: block;
	width: 100%;
	aspect-ratio: 3 / 4;
	background: var(--ll-warm-sand);
	overflow: hidden;
	margin-bottom: var(--s5);
}
.ll-dest-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 500ms ease;
}
.ll-dest-card__image-wrap:hover .ll-dest-card__img { transform: scale(1.04); }
.ll-dest-card__img-placeholder { width: 100%; height: 100%; background: var(--ll-warm-sand); }

/* Excerpt */
.ll-dest-card__excerpt {
	font-family: var(--font-sans);
	font-size: var(--text-base);
	line-height: 1.55;
	color: var(--ll-slate-600);
	margin-bottom: var(--s4);
	max-width: 360px;
	text-align: left;
}

/* Tag pills */
.ll-dest-card__tags {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	justify-content: center;
	margin-bottom: var(--s3);
}
.ll-dest-tag {
	display: inline-flex;
	align-items: center;
	padding: 5px 11px;
	border-radius: var(--r-pill);
	border: 1px solid transparent;
	font-family: var(--font-sans);
	font-size: 0.625rem; /* 10px */
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

/* Content count */
.ll-dest-card__count {
	font-family: var(--font-sans);
	font-size: var(--text-xs);
	font-weight: 500;
	letter-spacing: 0.03em;
	color: var(--ll-slate-600);
}

/* Placeholder content — italic hint, no opacity change so all cards look uniform */
.ll-dest-placeholder { font-style: italic; }

/* ================================
   THE JOURNAL
   ================================ */
.ll-journal-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--s10) var(--s6);
}

.ll-post-card { display: flex; flex-direction: column; }

.ll-post-card__image-wrap {
	position: relative;
	overflow: hidden;
	aspect-ratio: 3 / 2;
	background: var(--ll-warm-sand);
	margin-bottom: var(--s4);
}
.ll-post-card__image-wrap img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 500ms ease;
}
.ll-post-card:hover .ll-post-card__image-wrap img { transform: scale(1.05); }

.ll-post-card__meta {
	display: flex;
	align-items: center;
	gap: var(--s3);
	margin-bottom: var(--s2);
}
.ll-post-card__category {
	font-family: var(--font-sans);
	font-size: var(--text-xs);
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--ll-gold-dark);
}
.ll-post-card__date {
	font-family: var(--font-sans);
	font-size: var(--text-xs);
	color: var(--ll-slate-400);
}

.ll-post-card__title {
	font-family: var(--font-display);
	font-size: var(--text-xl);
	font-weight: 400;
	line-height: 1.3;
	color: var(--ll-charcoal);
	margin-bottom: var(--s2);
}
.ll-post-card__title a { transition: color var(--ease-fast); }
.ll-post-card__title a:hover { color: var(--ll-gold-dark); }

.ll-post-card__excerpt {
	font-family: var(--font-sans);
	font-size: var(--text-sm);
	color: var(--ll-slate-600);
	line-height: 1.65;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* ================================
   WHERE TO NEXT (FEATURE CARDS)
   ================================ */
.ll-feature-row {
	display: grid;
	grid-template-columns: 1.35fr 0.65fr;
	gap: var(--s5);
	align-items: stretch;
}

.ll-feature-column {
	display: flex;
	flex-direction: column;
	gap: var(--s5);
}

.ll-feature-card {
	position: relative;
	overflow: hidden;
	background: var(--ll-warm-sand);
	display: block;
}
.ll-feature-card--tall { aspect-ratio: 5 / 6; flex: 1; }
.ll-feature-card--wide { aspect-ratio: 16 / 9; }
.ll-feature-card--short { flex: 1; aspect-ratio: auto; min-height: 180px; }

.ll-feature-card img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 600ms ease;
}
.ll-feature-card:hover img { transform: scale(1.04); }

.ll-feature-card__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(37,49,58,.82) 0%, rgba(37,49,58,.06) 55%, transparent 100%);
}
.ll-feature-card__body {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	padding: var(--s8) var(--s6);
	color: #fff;
}
.ll-feature-card__eyebrow {
	font-family: var(--font-hand);
	font-size: var(--text-hand-eyebrow);
	color: var(--ll-gold);
	margin-bottom: var(--s2);
}
.ll-feature-card--short .ll-feature-card__eyebrow { font-size: calc(var(--text-hand-eyebrow) * 0.81); } /* ~21px — short card variant */
.ll-feature-card__title {
	font-family: var(--font-display);
	font-size: clamp(var(--text-2xl), 2.5vw, var(--text-4xl));
	font-weight: 400;
	line-height: 1.15;
}

/* ================================
   PLAN YOUR TRIP
   ================================ */
.ll-plan__inner {
	display: grid;
	grid-template-columns: 1fr 0.85fr;
	gap: var(--s20);
	align-items: center;
}

.ll-plan__intro {
	font-family: var(--font-sans);
	font-size: var(--text-lg);
	color: var(--ll-slate-600);
	line-height: 1.75;
	margin-top: var(--s5);
	margin-bottom: var(--s8);
	max-width: 42ch;
}

.ll-plan__pillars { display: flex; flex-direction: column; gap: var(--s3); }

.ll-plan__pillar {
	display: flex;
	align-items: flex-start;
	gap: var(--s4);
	padding: var(--s4);
	border-radius: var(--r-lg);
	transition: background var(--ease-fast);
}
.ll-plan__pillar:hover { background: rgba(214,166,100,.1); }

.ll-plan__pillar-icon {
	width: 40px;
	height: 40px;
	border-radius: var(--r-md);
	background: var(--ll-gold);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	font-size: 1.1rem;
}

.ll-plan__pillar-title {
	font-family: var(--font-sans);
	font-size: var(--text-base);
	font-weight: 700;
	color: var(--ll-charcoal);
	margin-bottom: var(--s1);
}
.ll-plan__pillar-desc {
	font-family: var(--font-sans);
	font-size: var(--text-sm);
	color: var(--ll-slate-600);
	line-height: 1.55;
}

.ll-plan__cta-row { margin-top: var(--s8); display: flex; gap: var(--s4); }

.ll-plan__image-wrap {
	overflow: hidden;
	aspect-ratio: 3 / 4;
	background: var(--ll-warm-sand);
}
.ll-plan__image-wrap img { width: 100%; height: 100%; object-fit: cover; }

/* ================================
   NEWSLETTER
   ================================ */
.ll-newsletter__inner {
	max-width: 600px;
	margin-inline: auto;
	text-align: center;
}

.ll-newsletter__accent {
	font-family: var(--font-hand);
	font-size: var(--text-2xl);
	color: var(--ll-gold-dark);
	margin-bottom: var(--s2);
}

.ll-newsletter__heading {
	font-family: var(--font-display);
	font-size: clamp(var(--text-3xl), 4vw, var(--text-5xl));
	font-weight: 400;
	letter-spacing: -0.03em;
	line-height: 1.12;
	color: var(--ll-charcoal);
	margin-bottom: var(--s4);
}

.ll-newsletter__description {
	font-family: var(--font-sans);
	font-size: var(--text-base);
	color: var(--ll-slate-600);
	line-height: 1.75;
	margin-bottom: var(--s8);
	max-width: 44ch;
	margin-inline: auto;
}

.ll-newsletter__form {
	display: flex;
	gap: var(--s3);
	max-width: 460px;
	margin-inline: auto;
}
.ll-newsletter__form input[type="email"] {
	flex: 1;
	padding: 0.7rem 1rem;
	border: 1.5px solid var(--ll-charcoal);
	border-radius: var(--r-pill);
	font-family: var(--font-sans);
	font-size: var(--text-sm);
	background: rgba(255,255,255,.65);
	outline-offset: 3px;
}
.ll-newsletter__form input[type="email"]::placeholder { color: var(--ll-slate-400); }
.ll-newsletter__form input[type="email"]:focus { outline: 2px solid var(--ll-gold); }

.ll-newsletter__privacy {
	margin-top: var(--s4);
	font-family: var(--font-sans);
	font-size: var(--text-xs);
	color: var(--ll-slate-400);
}

/* ================================
   WORKSHOP / SHOP PLACEHOLDER
   ================================ */
.ll-workshop__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--s5);
}

.ll-product-card {
	background: #fff;
	border-radius: var(--r-lg);
	overflow: hidden;
	box-shadow: var(--shadow-sm);
	transition: box-shadow var(--ease-base), transform var(--ease-base);
}
.ll-product-card:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); }

.ll-product-card__image {
	aspect-ratio: 1;
	background: var(--ll-warm-sand);
	overflow: hidden;
}
.ll-product-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 500ms ease;
}
.ll-product-card:hover .ll-product-card__image img { transform: scale(1.05); }

.ll-product-card__body { padding: var(--s4) var(--s5); }
.ll-product-card__type {
	font-family: var(--font-sans);
	font-size: var(--text-xs);
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--ll-slate-400);
	margin-bottom: var(--s1);
}
.ll-product-card__name {
	font-family: var(--font-display);
	font-size: var(--text-lg);
	font-weight: 400;
	color: var(--ll-charcoal);
	line-height: 1.3;
	margin-bottom: var(--s2);
}
.ll-product-card__price {
	font-family: var(--font-sans);
	font-size: var(--text-sm);
	font-weight: 700;
	color: var(--ll-gold-dark);
}

/* ================================
   ABOUT STRIP
   ================================ */
.ll-about__inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--s16);
	align-items: center;
}
.ll-about__image-wrap {
	overflow: hidden;
	aspect-ratio: 5 / 4;
	background: var(--ll-slate-500);
	order: -1;
}
.ll-about__image-wrap img { width: 100%; height: 100%; object-fit: cover; }

.ll-about__accent {
	font-family: var(--font-hand);
	font-size: var(--text-2xl);
	color: var(--ll-gold);
	margin-bottom: var(--s4);
}
.ll-about__heading {
	font-family: var(--font-display);
	font-size: clamp(var(--text-3xl), 3.5vw, var(--text-5xl));
	font-weight: 400;
	letter-spacing: -0.03em;
	line-height: 1.12;
	color: #fff;
	margin-bottom: var(--s5);
}
.ll-about__body {
	font-family: var(--font-sans);
	font-size: var(--text-base);
	color: var(--ll-slate-200);
	line-height: 1.8;
	margin-bottom: var(--s8);
	max-width: 44ch;
}

/* ================================
   FOOTER
   ================================ */
.site-footer { background: var(--ll-charcoal); }

.site-footer__top {
	padding-block: var(--s16) var(--s12);
	border-bottom: 1px solid rgba(255,255,255,.1);
}
.site-footer__top-inner {
	display: grid;
	grid-template-columns: 1.6fr 1fr 1fr 1fr;
	gap: var(--s10);
}

.site-footer__brand-logo-link {
	display: block;
}

.site-footer__brand-logo {
	height: 30px;
	width: auto;
	filter: brightness(0) invert(1);
	opacity: .85;
	margin-bottom: var(--s4);
}
.site-footer__brand-desc {
	font-family: var(--font-sans);
	font-size: var(--text-sm);
	color: var(--ll-slate-300);
	line-height: 1.75;
	max-width: 26ch;
	margin-bottom: var(--s5);
}
.site-footer__social {
	display: flex;
	gap: var(--s3);
}
.site-footer__social a {
	width: 34px;
	height: 34px;
	border: 1px solid rgba(255,255,255,.18);
	border-radius: var(--r-pill);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: .9rem;
	color: var(--ll-slate-200);
	transition: border-color var(--ease-fast), background var(--ease-fast), color var(--ease-fast);
}
.site-footer__social a:hover { border-color: var(--ll-gold); background: rgba(214,166,100,.15); color: var(--ll-gold); }

.site-footer__col-heading {
	font-family: var(--font-sans);
	font-size: var(--text-xs);
	font-weight: 700;
	letter-spacing: 0.13em;
	text-transform: uppercase;
	color: #fff;
	margin-bottom: var(--s5);
}
.site-footer__col-links { display: flex; flex-direction: column; gap: var(--s3); }
.site-footer__col-links a {
	font-family: var(--font-sans);
	font-size: var(--text-sm);
	color: var(--ll-slate-300);
	transition: color var(--ease-fast);
}
.site-footer__col-links a:hover { color: var(--ll-gold); }

.site-footer__bottom { padding-block: var(--s5); }
.site-footer__bottom-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--s4);
}
.site-footer__copyright {
	font-family: var(--font-sans);
	font-size: var(--text-xs);
	color: var(--ll-slate-400);
}
.site-footer__legal-links { display: flex; gap: var(--s5); }
.site-footer__legal-links a {
	font-family: var(--font-sans);
	font-size: var(--text-xs);
	color: var(--ll-slate-400);
	transition: color var(--ease-fast);
}
.site-footer__legal-links a:hover { color: var(--ll-gold); }

/* ================================
   SINGLE POST
   ================================ */
.post-hero {
	background: #EFF3F7;
	padding-block: var(--s12) var(--s10);
}
.post-hero__image-wrap {
	overflow: hidden;
	aspect-ratio: 3 / 2;
}
.post-hero__image-wrap img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.post-hero__image-caption {
	font-family: var(--font-sans);
	font-size: var(--text-sm);
	font-weight: 400;
	font-style: italic;
	color: var(--ll-slate-400);
	margin-top: var(--s1);
	text-align: right;
}

/* Header text below the image — mirrors post-layout__inner so columns align exactly */
.post-hero__header {
	max-width: min(1080px, calc(100% - var(--ll-gutter) * 2));
	margin-inline: auto;
	display: grid;
	grid-template-columns: 1fr 260px;
	gap: var(--s12);
	padding-top: var(--s8);
}
.post-hero__text { /* sits in the 1fr column, no extra constraints needed */ }
.post-hero__eyebrow {
	display: inline-block;
	font-family: var(--font-sans);
	font-size: var(--text-xs);
	font-weight: 700;
	letter-spacing: 0.13em;
	text-transform: uppercase;
	color: var(--ll-gold-dark);
	margin-bottom: var(--s4);
	transition: color var(--ease-fast);
}
.post-hero__eyebrow:hover { color: var(--ll-charcoal); }
.post-hero__title {
	font-family: var(--font-display);
	font-size: clamp(var(--text-4xl), 5vw, var(--text-7xl));
	font-weight: 400;
	line-height: 1.05;
	letter-spacing: -0.03em;
	color: var(--ll-charcoal);
	max-width: 22ch;
}
.post-hero__excerpt {
	margin-top: var(--s5);
	font-family: var(--font-serif);
	font-size: clamp(var(--text-xl), 2.2vw, var(--text-2xl));
	font-weight: 400;
	line-height: 1.6;
	color: var(--ll-slate-600);
	max-width: 58ch;
}
.post-hero__excerpt > p { margin: 0; }

/* Post layout */
.post-layout {
	padding-block: var(--s12) var(--s20);
}
.post-layout__inner {
	display: grid;
	grid-template-columns: 1fr 260px;
	gap: var(--s12);
	max-width: min(1080px, calc(100% - var(--ll-gutter) * 2));
	margin-inline: auto;
}

/* Article content */
.post-content {
	font-family: var(--font-serif);
	font-size: clamp(var(--text-base), 1.8vw, var(--text-lg));
	line-height: 1.82;
	color: var(--ll-charcoal);
	font-optical-sizing: auto;
}
.post-content > * + * { margin-top: 1.6em; }
.post-content h2 {
	font-family: var(--font-display);
	font-size: clamp(var(--text-2xl), 3vw, var(--text-4xl));
	font-weight: 400;
	letter-spacing: -0.03em;
	line-height: 1.2;
	color: var(--ll-charcoal);
	margin-top: 2.8em;
	margin-bottom: 0.7em;
	scroll-margin-top: 47px;
}
body.admin-bar .post-content h2 {
	scroll-margin-top: calc(47px + 32px); /* +32px for WP admin bar (desktop) */
}
body.admin-bar .post-sidebar {
	top: calc(var(--s6) + 15px + 32px);
}
@media (max-width: 782px) {
	body.admin-bar .post-content h2 {
		scroll-margin-top: calc(47px + 46px); /* +46px for WP admin bar (mobile) */
	}
	body.admin-bar .post-sidebar {
		top: calc(var(--s6) + 15px + 46px);
	}
}
.post-content h3 {
	font-family: var(--font-sans);
	font-size: var(--text-xl);
	font-weight: 700;
	letter-spacing: 0.01em;
	color: var(--ll-charcoal);
	margin-top: 2.2em;
	margin-bottom: 0.5em;
}
.post-content h4 {
	font-family: var(--font-sans);
	font-size: var(--text-base);
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--ll-gold-dark);
	margin-top: 2em;
	margin-bottom: 0.5em;
}
.post-content a {
	color: var(--ll-gold-dark);
	border-bottom: 1px solid var(--ll-gold);
	padding-bottom: 1px;
	transition: color var(--ease-fast), border-color var(--ease-fast);
}
.post-content a:hover { color: var(--ll-charcoal); border-color: var(--ll-charcoal); }

.post-content blockquote {
	border-left: 3px solid var(--ll-gold);
	padding-left: var(--s6);
	margin-left: 0;
	margin-block: 2.4em;
	font-style: italic;
	color: var(--ll-slate-600);
	font-size: 1.08em;
}

.post-content figure { margin-block: 2.8em; }
.post-content figure img { width: 100%; }
.post-content figcaption {
	font-family: var(--font-sans);
	font-size: var(--text-sm);
	font-weight: 400;
	font-style: normal;
	color: var(--ll-slate-400);
	margin-top: var(--s1);
	text-align: left;
	padding-left: 0;
}

.post-content ul { list-style: disc; padding-left: 1.5em; }
.post-content ol { list-style: decimal; padding-left: 1.5em; }
.post-content li + li { margin-top: .5em; }

.post-content hr {
	border: none;
	border-top: 1px solid var(--ll-border);
	margin-block: 2.8em;
}

/* Wide/full-width Gutenberg blocks in post */
.post-content .alignwide {
	width: calc(100% + 6rem);
	margin-inline: -3rem;
}
.post-content .alignfull {
	width: 100vw;
	margin-inline: calc(-1 * (100vw - 100%) / 2);
}
.post-content .alignwide img,
.post-content .alignfull img { }

/* Inline newsletter */
.ll-post-newsletter {
	background: var(--ll-warm-sand);
	border-radius: var(--r-xl);
	padding: var(--s10) var(--s10) calc(var(--s16) + 10px);
	text-align: center;
	margin-top: calc(1.6em + 80px);
	margin-bottom: var(--s12);
}
.ll-post-newsletter__accent {
	font-family: var(--font-hand);
	font-size: var(--text-2xl);
	color: var(--ll-gold-dark);
	margin-bottom: var(--s2);
}
.ll-post-newsletter__heading {
	font-family: var(--font-display);
	font-size: clamp(var(--text-3xl), 4vw, var(--text-5xl));
	font-weight: 400;
	letter-spacing: -0.03em;
	line-height: 1.12;
	color: var(--ll-charcoal);
	margin-bottom: var(--s4);
}
.ll-post-newsletter__desc {
	font-family: var(--font-sans);
	font-size: var(--text-base);
	color: var(--ll-slate-600);
	line-height: 1.75;
	margin-bottom: var(--s8);
	max-width: 44ch;
	margin-inline: auto;
}
.ll-post-newsletter__form {
	display: flex;
	gap: var(--s3);
	max-width: 460px;
	margin-inline: auto;
}
.ll-post-newsletter__form input[type="email"] {
	flex: 1;
	padding: 0.7rem 1rem;
	border: 1.5px solid var(--ll-charcoal);
	border-radius: var(--r-pill);
	font-family: var(--font-sans);
	font-size: var(--text-sm);
	background: rgba(255,255,255,.65);
	outline-offset: 3px;
}
.ll-post-newsletter__form input[type="email"]::placeholder { color: var(--ll-slate-400); }
.ll-post-newsletter__form input[type="email"]:focus { outline: 2px solid var(--ll-gold); }

/* Sidebar */
.post-sidebar {
	padding-top: var(--s2);
	margin-top: calc(-1 * var(--s2));
	position: sticky;
	top: calc(var(--s6) + 15px);
	align-self: start;
}

/* Table of contents */
.post-toc {
	margin-bottom: var(--s6);
	padding-bottom: var(--s6);
	border-bottom: 1px solid var(--ll-border);
}
.post-toc__label {
	font-family: var(--font-hand);
	font-size: var(--text-hand-eyebrow);
	font-weight: 400;
	letter-spacing: 0;
	text-transform: none;
	color: var(--ll-gold);
	margin-bottom: var(--s5);
	margin-left: -2px;
}
.post-toc__list { padding: 0; margin: 0; }
.post-toc__list li { margin-top: var(--s2); }
.post-toc__list a {
	font-family: var(--font-sans);
	font-size: var(--text-sm);
	color: var(--ll-slate-600);
	line-height: 1.4;
	display: block;
	transition: color var(--ease-fast);
}
.post-toc__list a:hover { color: var(--ll-charcoal); }
.post-toc__list a.is-active {
	color: var(--ll-charcoal);
	font-weight: 600;
}

/* Date + read time beneath hero excerpt */
.post-hero__byline {
	display: flex;
	align-items: center;
	gap: var(--s2);
	margin-top: var(--s8);
	font-family: var(--font-sans);
	font-size: var(--text-xs);
	color: var(--ll-slate-400);
}
.post-hero__byline-sep { color: var(--ll-slate-300); }

/* Tags in sidebar */
.post-sidebar__tags {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}

.post-sidebar__heading {
	font-family: var(--font-sans);
	font-size: var(--text-xs);
	font-weight: 700;
	letter-spacing: .1em;
	text-transform: uppercase;
	color: var(--ll-charcoal);
	margin-bottom: var(--s4);
}

.post-sidebar__widget {
	margin-top: var(--s6);
}

.post-sidebar .wp-block-search__label {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

.post-sidebar .search-form,
.post-sidebar .wp-block-search__inside-wrapper {
	display: flex;
	align-items: center;
	gap: var(--s2);
}

.post-sidebar .search-form label,
.post-sidebar .wp-block-search__input {
	flex: 1;
	min-width: 0;
}

.post-sidebar .search-field,
.post-sidebar .wp-block-search__input {
	width: 100%;
	min-height: 34px;
	padding: 0.4rem 0.85rem;
	border: 1.5px solid var(--ll-charcoal);
	border-radius: var(--r-pill);
	background: rgba(255,255,255,.55);
	color: var(--ll-charcoal);
	font-family: var(--font-sans);
	font-size: var(--text-sm);
	outline: none;
}

.post-sidebar .search-field::placeholder,
.post-sidebar .wp-block-search__input::placeholder {
	color: var(--ll-slate-400);
}

.post-sidebar .search-field:focus,
.post-sidebar .wp-block-search__input:focus {
	outline: 2px solid var(--ll-gold);
	outline-offset: 3px;
}

.post-sidebar .search-submit,
.post-sidebar .wp-block-search__button {
	-webkit-appearance: none;
	appearance: none;
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 34px;
	height: 34px;
	margin-left: 0;
	padding: 0;
	border: 1.5px solid var(--ll-charcoal);
	border-radius: var(--r-pill);
	background-color: transparent;
	background-image: url("data:image/svg+xml,%3Csvg width='15' height='15' viewBox='0 0 15 15' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='6.5' cy='6.5' r='5.25' stroke='%2325313A' stroke-width='1.5'/%3E%3Cpath d='M10.5 10.5L13.5 13.5' stroke='%2325313A' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
	background-position: center;
	background-repeat: no-repeat;
	background-size: 15px 15px;
	color: transparent;
	font-size: 0;
	line-height: 0;
	text-indent: -9999px;
	cursor: pointer;
	transition: background-color var(--ease-fast), background-image var(--ease-fast), color var(--ease-fast);
	flex-shrink: 0;
}

.post-sidebar .search-submit:hover,
.post-sidebar .wp-block-search__button:hover {
	background-color: var(--ll-charcoal);
	background-image: url("data:image/svg+xml,%3Csvg width='15' height='15' viewBox='0 0 15 15' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='6.5' cy='6.5' r='5.25' stroke='%23F7F1E8' stroke-width='1.5'/%3E%3Cpath d='M10.5 10.5L13.5 13.5' stroke='%23F7F1E8' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
}

/* Related posts */
.ll-related {
	border-top: 1px solid var(--ll-border);
	padding-block: var(--s16) var(--s20);
	max-width: min(1080px, calc(100% - var(--ll-gutter) * 2));
	margin-inline: auto;
}
.ll-related__heading {
	font-family: var(--font-hand);
	font-size: var(--text-3xl);
	font-weight: 400;
	color: var(--ll-slate-300);
	margin-bottom: var(--s8);
}
.ll-related__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--s8) var(--s5);
}

/* ================================
   ARCHIVE PAGE
   ================================ */
.archive-header {
	background: color-mix(in srgb, var(--ll-slate-200) 25%, white);
	padding-block: var(--s16) var(--s12);
}
.archive-header__eyebrow {
	font-family: var(--font-sans);
	font-size: var(--text-xs);
	font-weight: 700;
	letter-spacing: .13em;
	text-transform: uppercase;
	color: var(--ll-gold-dark);
	margin-bottom: var(--s3);
}
.archive-header__title {
	font-family: var(--font-display);
	font-size: clamp(var(--text-4xl), 5vw, var(--text-6xl));
	font-weight: 400;
	line-height: 1.1;
	color: var(--ll-charcoal);
}
.archive-header__description {
	font-family: var(--font-sans);
	font-size: var(--text-lg);
	color: var(--ll-slate-600);
	margin-top: var(--s4);
	max-width: 52ch;
	line-height: 1.7;
	text-wrap: pretty;
}

.archive-posts { padding-block: var(--s16) var(--s20); }
.archive-posts--below-cats { padding-top: var(--s10); }
.archive-posts__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--s10) var(--s6);
}

/* Archive — empty state */
.archive-empty {
	font-family: var(--font-sans);
	font-size: var(--text-lg);
	color: var(--ll-slate-400);
	padding-block: var(--s12);
}

/* ── Category cards (parent category → child categories) ── */
.ll-cat-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--s5);
}

.ll-cat-card {
	position: relative;
	display: block;
	overflow: hidden;
	aspect-ratio: 4 / 3;
	background: var(--ll-warm-sand);
}
.ll-cat-card__image {
	position: absolute;
	inset: 0;
}
.ll-cat-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 500ms ease;
}
.ll-cat-card:hover .ll-cat-card__image img { transform: scale(1.05); }

.ll-cat-card__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(37,49,58,.82) 0%, rgba(37,49,58,.12) 55%, transparent 100%);
	transition: opacity var(--ease-base);
}
.ll-cat-card:hover .ll-cat-card__overlay { opacity: .9; }

.ll-cat-card__body {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	padding: var(--s6) var(--s5);
	color: #fff;
}
.ll-cat-card__name {
	font-family: var(--font-display);
	font-size: clamp(var(--text-2xl), 2.5vw, var(--text-3xl));
	font-weight: 400;
	line-height: 1.15;
	margin-bottom: var(--s1);
}
.ll-cat-card__count {
	font-family: var(--font-sans);
	font-size: var(--text-xs);
	font-weight: 700;
	letter-spacing: .1em;
	text-transform: uppercase;
	color: var(--ll-gold);
}

/* Breadcrumb link in archive eyebrow */
.archive-header__eyebrow a {
	color: inherit;
	transition: color var(--ease-fast);
}
.archive-header__eyebrow a:hover {
	color: var(--ll-charcoal);
}

/* Archive header — hero image variant */
.archive-header--has-hero {
	position: relative;
	height: clamp(23rem, 55.2vw, 43.7rem);
	padding-block: 0;
	border-bottom: none;
	background: var(--ll-charcoal);
	overflow: hidden;
	display: flex;
	align-items: flex-end;
}
.archive-header__hero-img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}
.archive-header__hero-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to bottom, rgba(37,49,58,.08) 0%, rgba(37,49,58,.72) 100%);
}
.archive-header--has-hero .ll-shell {
	position: relative;
	z-index: 1;
	padding-bottom: var(--s10);
}
.archive-header--has-hero .archive-header__eyebrow {
	color: var(--ll-gold);
}
.archive-header--has-hero .archive-header__eyebrow a {
	color: var(--ll-gold);
}
.archive-header--has-hero .archive-header__eyebrow a:hover {
	color: #fff;
}
.archive-header--has-hero .archive-header__title { color: #fff; }
.archive-header--has-hero .archive-header__description { color: var(--ll-warm-cream); }

/* Pagination */
.ll-pagination {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: var(--s2);
	margin-top: var(--s16);
}
.ll-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: var(--r-pill);
	font-family: var(--font-sans);
	font-size: var(--text-sm);
	font-weight: 600;
	color: var(--ll-charcoal);
	border: 1.5px solid var(--ll-border);
	transition: background var(--ease-fast), color var(--ease-fast), border-color var(--ease-fast);
}
.ll-pagination .page-numbers:hover,
.ll-pagination .page-numbers.current {
	background: var(--ll-charcoal);
	color: #fff;
	border-color: var(--ll-charcoal);
}
.ll-pagination .page-numbers.dots {
	border-color: transparent;
	background: transparent;
}

/* ================================
   STATIC PAGE
   ================================ */
.page-hero {
	background: var(--ll-warm-cream);
	padding-block: var(--s16) var(--s12);
	border-bottom: 1px solid var(--ll-border);
}
.page-hero__title {
	font-family: var(--font-display);
	font-size: clamp(var(--text-4xl), 5vw, var(--text-6xl));
	font-weight: 400;
	line-height: 1.1;
	color: var(--ll-charcoal);
}

.page-body {
	padding-block: var(--s12) var(--s20);
	font-family: var(--font-serif);
	font-size: clamp(var(--text-base), 1.8vw, var(--text-lg));
	line-height: 1.82;
	color: var(--ll-charcoal);
	max-width: var(--ll-content);
	margin-inline: auto;
}
.page-body > * + * { margin-top: 1.6em; }
.page-body h2 { font-family: var(--font-serif); font-size: var(--text-3xl); font-weight: 400; line-height: 1.2; margin-top: 2.5em; margin-bottom: .7em; }
.page-body a { color: var(--ll-gold-dark); border-bottom: 1px solid var(--ll-gold); transition: color var(--ease-fast); }
.page-body a:hover { color: var(--ll-charcoal); }
.page-body ul { list-style: disc; padding-left: 1.5em; }
.page-body ol { list-style: decimal; padding-left: 1.5em; }

/* Legal pages (Privacy Policy, Affiliate Disclosure) */
.page-id-3 .page-hero__title,
.page-id-193 .page-hero__title {
	font-size: clamp(var(--text-2xl), 3vw, var(--text-4xl));
}
.page-id-3 .page-body,
.page-id-193 .page-body {
	font-family: var(--font-sans);
}
.page-id-3 .page-body h2,
.page-id-193 .page-body h2 {
	font-family: var(--font-sans);
}

/* ================================
   DESTINATION MAP
   ================================ */
.ll-dest-map {
	padding-block: var(--s16) var(--s20);
}

.ll-dest-map__regions {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--s6);
	align-items: start;
}

.ll-dest-map__region {}


/* Region body: parent card on top, children below */
.ll-dest-map__region-body {
	display: flex;
	flex-direction: column;
	gap: var(--s5);
}

/* Region card spans its column — standard landscape ratio */
.ll-dest-map__region-body > .ll-cat-card {
	aspect-ratio: 4 / 3;
}

/* Place text list */
.ll-place-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--s3);
}

.ll-place-list__item { line-height: 1.3; }

.ll-place-list__name {
	font-family: var(--font-display);
	font-size: var(--text-xl);
	font-weight: 400;
	color: var(--ll-charcoal);
	transition: color var(--ease-fast);
}
.ll-place-list__name:hover { color: var(--ll-gold-dark); }

.ll-place-list__sub {
	list-style: none;
	margin: var(--s1) 0 0 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: var(--s1) var(--s3);
}
.ll-place-list__sub a {
	font-family: var(--font-sans);
	font-size: var(--text-sm);
	color: var(--ll-slate-500);
	transition: color var(--ease-fast);
}
.ll-place-list__sub a:hover { color: var(--ll-charcoal); }

/* ================================
   SEARCH RESULTS
   ================================ */
.search-header {
	background: var(--ll-warm-cream);
	padding-block: var(--s8) var(--s12);
}
.search-header__title {
	font-family: var(--font-display);
	font-size: clamp(var(--text-3xl), 4vw, var(--text-5xl));
	font-weight: 400;
	margin-bottom: var(--s2);
}
.search-header__subtitle {
	font-family: var(--font-sans);
	font-size: var(--text-base);
	color: var(--ll-slate-600);
}
.search-header__subtitle em {
	font-style: normal;
	font-weight: 700;
	color: var(--ll-charcoal);
}

.search-results { padding-block: var(--s16) var(--s20); }
.search-results__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--s10) var(--s6);
}
.search-no-results { padding-block: var(--s16); }
.search-no-results p {
	font-family: var(--font-sans);
	font-size: var(--text-lg);
	color: var(--ll-slate-600);
	margin-bottom: var(--s6);
}
.search-no-results .search-form,
.not-found .search-form {
	display: flex;
	gap: var(--s3);
	max-width: 460px;
}
.search-no-results .search-form label,
.not-found .search-form label {
	flex: 1;
}
.search-no-results .search-field,
.not-found .search-field {
	width: 100%;
	padding: 0.7rem 1rem;
	border: 1.5px solid var(--ll-charcoal);
	border-radius: var(--r-pill);
	font-family: var(--font-sans);
	font-size: var(--text-sm);
	background: rgba(255,255,255,.65);
	outline-offset: 3px;
}
.search-no-results .search-field::placeholder,
.not-found .search-field::placeholder { color: var(--ll-slate-400); }
.search-no-results .search-field:focus,
.not-found .search-field:focus { outline: 2px solid var(--ll-gold); }
.search-no-results .search-submit,
.not-found .search-submit {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--s2);
	font-family: var(--font-sans);
	font-size: var(--text-sm);
	font-weight: 600;
	letter-spacing: 0.05em;
	padding: 0.65rem 1.4rem;
	border-radius: var(--r-pill);
	transition: background var(--ease-fast), color var(--ease-fast), transform var(--ease-fast), box-shadow var(--ease-fast);
	border: 1.5px solid var(--ll-charcoal);
	background: var(--ll-charcoal);
	color: var(--ll-warm-cream);
	white-space: nowrap;
}
.search-no-results .search-submit:hover,
.not-found .search-submit:hover {
	background: var(--ll-charcoal);
	border-color: var(--ll-charcoal);
	transform: translateY(-1px);
	box-shadow: var(--shadow-sm);
}
.search-no-results .search-submit:active,
.not-found .search-submit:active { transform: scale(.98); }

/* ================================
   404
   ================================ */
.not-found {
	background: var(--ll-warm-cream);
	padding-block: var(--s20) var(--s24);
}
.not-found__inner {
	max-width: 680px;
	text-align: center;
}
.not-found__eyebrow {
	font-family: var(--font-hand);
	font-size: var(--text-2xl);
	color: var(--ll-gold-dark);
	margin-bottom: var(--s2);
}
.not-found__title {
	font-family: var(--font-display);
	font-size: clamp(var(--text-4xl), 6vw, var(--text-6xl));
	font-weight: 400;
	line-height: 1.08;
	color: var(--ll-charcoal);
	margin-bottom: var(--s4);
}
.not-found__copy {
	font-family: var(--font-sans);
	font-size: var(--text-lg);
	line-height: 1.75;
	color: var(--ll-slate-600);
	max-width: 52ch;
	margin-inline: auto;
	margin-bottom: var(--s8);
}
.not-found__search {
	margin-bottom: var(--s6);
}
.not-found .search-form {
	margin-inline: auto;
}
.not-found__home {
	margin-top: var(--s2);
}

/* ================================
   ACCESSIBILITY
   ================================ */
.screen-reader-text {
	clip: rect(1px,1px,1px,1px);
	height: 1px;
	overflow: hidden;
	position: absolute;
	white-space: nowrap;
	width: 1px;
	word-wrap: normal;
}
:focus-visible {
	outline: 2px solid var(--ll-gold);
	outline-offset: 3px;
}

/* ================================
   RESPONSIVE
   ================================ */
@media (max-width: 1100px) {
	.ll-destinations-grid   { grid-template-columns: repeat(2, 1fr); }
	.ll-workshop__grid      { grid-template-columns: repeat(2, 1fr); }
	.site-footer__top-inner { grid-template-columns: 1fr 1fr; gap: var(--s8); }
}

@media (max-width: 900px) {
	:root { --ll-gutter: 1.5rem; }

	/* Featured destinations: 2-col with centered orphan 3rd card */
	.ll-dest-grid          { grid-template-columns: repeat(2, 1fr); gap: var(--s6); }
	.ll-dest-card:last-child:nth-child(odd) {
		grid-column: 1 / -1;
		max-width: calc(50% - var(--s3));
		margin-inline: auto;
	}
	.ll-dest-heading       { font-size: var(--text-4xl); }
	.ll-place-grid         { grid-template-columns: repeat(4, 1fr); }

	.ll-hero__inner        { grid-template-columns: 1fr; gap: var(--s10); }
	.ll-hero__image-wrap   { aspect-ratio: 1 / 1; }
	.ll-hero__content      { padding-block: 0; }

	.ll-feature-row        { grid-template-columns: 1fr; }
	.ll-feature-column     { flex-direction: row; }
	.ll-feature-card--tall { aspect-ratio: 4 / 3; }

	.ll-plan__inner        { grid-template-columns: 1fr; }
	.ll-plan__image-wrap   { display: none; }

	.ll-about__inner       { grid-template-columns: 1fr; gap: var(--s10); }
	.ll-about__image-wrap  { aspect-ratio: 16 / 9; order: 0; }

	.post-hero             { padding-top: 0; }
	.post-hero__image-wrap { margin-inline: calc(-1 * var(--ll-gutter)); aspect-ratio: 1 / 1; }
	.post-hero__header     { grid-template-columns: 1fr; }
	.post-layout__inner    { grid-template-columns: 1fr; max-width: min(720px, calc(100% - var(--ll-gutter) * 2)); }
	.post-sidebar          { display: none; }
	.post-content .alignwide { width: 100%; margin-inline: 0; }

	.ll-related__grid      { grid-template-columns: repeat(2, 1fr); }

	/* Taller archive hero is desktop-only — keep original ratio on mobile */
	.archive-header--has-hero { height: clamp(20rem, 48vw, 38rem); }
}

/* Desktop: search opens as an overlay covering only the nav area.
   `left` is set dynamically in nav.js by measuring .site-nav's position. */
@media (min-width: 1025px) {
	.site-header__search.is-open {
		position: absolute;
		top: 0;
		bottom: 0;
		right: 0;
		/* left injected by JS */
		background: var(--ll-warm-cream);
		z-index: 1;
	}
	.site-header__search.is-open input {
		flex: 1;
		width: auto;
	}
}

@media (max-width: 1024px) {
	.site-nav               { display: none; }
	.site-header__hamburger { display: flex; }
	.site-header__actions   { margin-left: auto; } /* nav is gone, so re-float actions to the right */

	/* Search: expand leftward over the logo, not into the page */
	.site-header__search.is-open {
		position: absolute;
		left: 0;
		top: 0;
		bottom: 0;
		right: calc(34px + var(--s3)); /* leave space for the hamburger */
		background: var(--ll-warm-cream);
		z-index: 5;
	}
	.site-header__search.is-open input {
		flex: 1;
		width: auto;
	}
}

@media (max-width: 768px) {
	:root { --ll-gutter: 1rem; }

	.ll-journal-grid        { grid-template-columns: 1fr 1fr; gap: var(--s8) var(--s4); }
	.archive-posts__grid    { grid-template-columns: repeat(2, 1fr); }
	.search-results__grid   { grid-template-columns: repeat(2, 1fr); }
	.ll-cat-grid            { grid-template-columns: repeat(2, 1fr); }
	.ll-dest-map__regions   { grid-template-columns: 1fr; }

	.ll-newsletter__form    { flex-direction: column; }
	.ll-post-newsletter__form { flex-direction: column; }
	.ll-post-newsletter__form .ll-btn { align-self: center; }
	.search-no-results .search-form,
	.not-found .search-form { flex-direction: column; }

	.site-footer__top-inner { grid-template-columns: 1fr; gap: var(--s8); }
}

@media (max-width: 540px) {
	.ll-dest-grid           { grid-template-columns: 1fr; }
	.ll-dest-card:last-child:nth-child(odd) { grid-column: auto; max-width: 100%; } /* reset orphan rule */
	.ll-dest-header         { flex-direction: column; align-items: flex-start; }
	.ll-dest-card__image-wrap { aspect-ratio: 1 / 1; }
	.ll-destinations-grid   { grid-template-columns: 1fr 1fr; }
	.ll-journal-grid        { grid-template-columns: 1fr; }
	.ll-workshop__grid      { grid-template-columns: 1fr 1fr; }
	.ll-related__grid       { grid-template-columns: 1fr; }
	.archive-posts__grid    { grid-template-columns: 1fr; }
	.search-results__grid   { grid-template-columns: 1fr; }
	.ll-cat-grid            { grid-template-columns: 1fr; }
	.site-footer__bottom-inner { flex-direction: column; text-align: center; }
	.ll-hero__title         { font-size: var(--text-4xl); }

	/* Move view-all links below content on mobile */
	.ll-dest-header .ll-dest-header__link,
	.ll-section__header .ll-section__view-all { display: none; }
	.ll-section-footer-link { display: block; margin-top: var(--s8); text-align: center; }
}

/* Hide footer-only links on desktop */
@media (min-width: 541px) {
	.ll-section-footer-link { display: none; }
}

/* Landscape phones — tall breakpoints don't fire; max-height catches phones but not tablets */
@media (orientation: landscape) and (max-height: 500px) {
	:root { --ll-gutter: 1rem; }

	.ll-hero__inner        { grid-template-columns: 1fr; gap: var(--s8); }
	.ll-hero__image-wrap   { aspect-ratio: 16 / 9; }
	.ll-hero__content      { padding-block: 0; }

	.ll-journal-grid       { grid-template-columns: repeat(2, 1fr); }
	.ll-dest-grid          { grid-template-columns: repeat(2, 1fr); }
	.ll-feature-row        { grid-template-columns: 1fr; }
	.ll-feature-column     { flex-direction: row; }
	.archive-posts__grid   { grid-template-columns: repeat(2, 1fr); }
	.ll-cat-grid           { grid-template-columns: repeat(2, 1fr); }

	.site-mega-menu        { display: none !important; }
}

/* ── Scroll reveal ── */
.ll-reveal {
	opacity: 0;
	transform: translateY(16px);
	transition: opacity 380ms ease, transform 380ms ease;
}
.ll-reveal.is-visible {
	opacity: 1;
	transform: translateY(0);
}
.ll-hero__image-wrap.ll-reveal,
.post-hero__image-wrap.ll-reveal,
.ll-dest-card__image-wrap.ll-reveal,
.ll-post-card__image-wrap.ll-reveal,
.ll-feature-card__img-wrap.ll-reveal,
figure.ll-reveal {
	transition: opacity 620ms ease, transform 380ms ease;
}

@media (prefers-reduced-motion: reduce) {
	html { scroll-behavior: auto; }
	.ll-reveal { opacity: 1; transform: none; transition: none; }
}
