/* ==========================================================================
   Lqueenwrites — Main Stylesheet
   Design system: light, airy, professional.
   Variables are defined in /style.css (:root).
   ========================================================================== */

/* --------------------------------------------------------------------------
   1. Reset & Base
   -------------------------------------------------------------------------- */
*,
*::before,
*::after {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
}

body {
	margin: 0;
	font-family: var(--lq-font-body);
	font-size: 16px;
	line-height: 1.7;
	color: var(--lq-text);
	background-color: var(--lq-bg-soft);
	-webkit-font-smoothing: antialiased;
}

img {
	max-width: 100%;
	display: block;
	height: auto;
}

a {
	color: var(--lq-primary);
	text-decoration: none;
	transition: color 0.2s ease;
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--lq-font-heading);
	color: var(--lq-primary);
	line-height: 1.2;
	margin: 0 0 0.6em;
	font-weight: 600;
}

h1 { font-size: clamp(2.2rem, 4.5vw, 3.4rem); }
h2 { font-size: clamp(1.8rem, 3.2vw, 2.6rem); }
h3 { font-size: clamp(1.2rem, 2vw, 1.5rem); }

p { margin: 0 0 1.2em; }

ul { margin: 0; padding: 0; }

.screen-reader-text {
	position: absolute !important;
	clip: rect(1px, 1px, 1px, 1px);
	width: 1px;
	height: 1px;
	overflow: hidden;
}

.lq-skip-link {
	position: absolute;
	left: -9999px;
	top: 1rem;
	z-index: 999;
	background: var(--lq-primary);
	color: var(--lq-on-primary);
	padding: 0.6em 1.2em;
	border-radius: var(--lq-radius-sm);
}
.lq-skip-link:focus {
	left: 1rem;
}

/* --------------------------------------------------------------------------
   2. Layout
   -------------------------------------------------------------------------- */
.lq-container {
	width: 100%;
	max-width: var(--lq-container);
	margin-left: auto;
	margin-right: auto;
	padding-left: clamp(1.5rem, 5vw, 2.5rem);
	padding-right: clamp(1.5rem, 5vw, 2.5rem);
}

.lq-main {
	display: block;
}

.lq-layout {
	padding: var(--lq-gap) 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--lq-gap);
}

.lq-layout--with-sidebar {
	grid-template-columns: minmax(0, 1fr);
}

@media (min-width: 980px) {
	.lq-layout--with-sidebar {
		grid-template-columns: minmax(0, 2.2fr) minmax(280px, 1fr);
		align-items: start;
	}
}

.lq-layout__main--full {
	max-width: 820px;
	margin: 0 auto;
}

/* --------------------------------------------------------------------------
   3. Buttons & shared bits
   -------------------------------------------------------------------------- */
.lq-eyebrow {
	font-family: var(--lq-font-body);
	font-size: 0.8rem;
	font-weight: 600;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--lq-primary);
	opacity: 0.7;
	margin: 0 0 0.8em;
}

.lq-eyebrow--warm {
	color: #b8863f;
}

.lq-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5em;
	font-family: var(--lq-font-body);
	font-weight: 600;
	font-size: 0.95rem;
	padding: 0.9em 1.8em;
	border-radius: 999px;
	border: 2px solid transparent;
	cursor: pointer;
	transition: all 0.25s ease;
	line-height: 1.2;
}

.lq-btn--primary {
	background-color: var(--lq-primary);
	color: var(--lq-on-primary);
	border-color: var(--lq-primary);
}
.lq-btn--primary:hover {
	background-color: var(--lq-primary-light);
	border-color: var(--lq-primary-light);
	color: var(--lq-blush);
	transform: translateY(-2px);
}

.lq-btn--ghost {
	background-color: transparent;
	color: var(--lq-primary);
	border-color: var(--lq-primary);
}
.lq-btn--ghost:hover {
	background-color: var(--lq-primary);
	color: var(--lq-blush);
	transform: translateY(-2px);
}

.lq-btn--outline {
	background-color: var(--lq-card);
	color: var(--lq-primary);
	border-color: var(--lq-sage);
}
.lq-btn--outline:hover {
	border-color: var(--lq-primary);
	transform: translateY(-2px);
}

/* Light variants — for use on the deep-green CTA band */
.lq-btn--light {
	background-color: var(--lq-blush);
	color: var(--lq-primary);
	border-color: var(--lq-blush);
}
.lq-btn--light:hover {
	background-color: var(--lq-yellow);
	border-color: var(--lq-yellow);
	transform: translateY(-2px);
}

.lq-btn--outline-light {
	background-color: transparent;
	color: var(--lq-on-primary);
	border-color: rgba(249, 250, 248, 0.5);
}
.lq-btn--outline-light:hover {
	background-color: var(--lq-on-primary);
	color: var(--lq-primary);
	border-color: var(--lq-on-primary);
	transform: translateY(-2px);
}

.lq-btn--block {
	display: flex;
	width: 100%;
}

/* --------------------------------------------------------------------------
   4. Header & Navigation
   -------------------------------------------------------------------------- */
.lq-header {
	background-color: transparent;
	position: fixed;
	width: 100%;
	top: 0;
	z-index: 100;
	border-bottom: 1px solid transparent;
	transition: background-color 0.3s ease, border-color 0.3s ease;
}

.lq-header.is-scrolled {
	background-color: var(--lq-bg-soft);
	border-bottom: 1px solid var(--lq-bg-alt);
}

.lq-header__bar {
	padding: 1rem 0;
}

.lq-header__row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1.5rem;
}

.lq-header__brand img {
	max-height: 56px;
	width: 200px;
}

.lq-header__sitename {
	font-family: var(--lq-font-heading);
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--lq-primary);
}

.lq-nav {
	flex: 1;
	display: flex;
	justify-content: center;
}

.lq-nav__list {
	display: flex;
	align-items: center;
	gap: clamp(1rem, 2vw, 2.2rem);
	list-style: none;
	margin: 0;
	padding: 0;
}

.lq-nav__link,
.lq-nav__list a {
	font-weight: 500;
	color: var(--lq-text);
	font-size: 0.85rem;
	position: relative;
	padding-bottom: 4px;
}

.lq-nav__link::after,
.lq-nav__list a::after {
	content: '';
	position: absolute;
	left: 0;
	right: 0;
	bottom: -4px;
	height: 2px;
	border-radius: 999px;
	background-color: var(--lq-primary);
	opacity: 0;
	transform: scaleX(0);
	transition: transform 0.2s ease, opacity 0.2s ease;
}

.lq-nav__link:hover,
.lq-nav__list a:hover {
	color: var(--lq-primary);
}

.lq-nav__link:hover::after,
.lq-nav__list a:hover::after {
	opacity: 1;
	transform: scaleX(1);
}

/* Active state: current page in the primary nav. */
.lq-nav__list a.is-active,
.lq-nav__list .current-menu-item > a,
.lq-nav__list .current_page_item > a,
.lq-nav__list .current-menu-ancestor > a,
.lq-nav__list .current_page_parent > a {
	color: var(--lq-primary);
}

.lq-nav__list a.is-active::after,
.lq-nav__list .current-menu-item > a::after,
.lq-nav__list .current_page_item > a::after,
.lq-nav__list .current-menu-ancestor > a::after,
.lq-nav__list .current_page_parent > a::after {
	opacity: 1;
	transform: scaleX(1);
}

.lq-header__actions {
	display: flex;
	align-items: center;
	gap: 1rem;
}

.lq-header__cta {
	padding: 0.75em 1.5em;
	font-size: 0.9rem;
}

.lq-nav-toggle {
	display: none;
	flex-direction: column;
	justify-content: center;
	gap: 5px;
	width: 42px;
	height: 42px;
	border: none;
	background: transparent;
	cursor: pointer;
	padding: 0;
}

.lq-nav-toggle__bar {
	display: block;
	width: 18px;
	height: 2px;
	margin: 0 auto;
	background-color: var(--lq-primary);
	transition: transform 0.25s ease, opacity 0.25s ease;
}

.lq-ad-header-wrap {
	background-color: var(--lq-bg-alt);
	padding: 0.75rem 0;
}

@media (max-width: 900px) {
	.lq-nav-toggle {
		display: flex;
	}

	.lq-header__cta {
		display: none;
	}

	.lq-nav {
		position: absolute;
		top: 100%;
		left: 0;
		right: 0;
		background-color: var(--lq-bg-soft);
		border-bottom: 1px solid var(--lq-bg-alt);
		max-height: 0;
		overflow: hidden;
		transition: max-height 0.3s ease;
	}

	.lq-nav.is-open {
		max-height: 420px;
	}

	.lq-nav__list {
		flex-direction: column;
		align-items: flex-start;
		gap: 0;
		padding: 1rem clamp(1.25rem, 4vw, 2.5rem) 1.5rem;
	}

	.lq-nav__list li {
		width: 100%;
		border-bottom: 1px solid var(--lq-bg-alt);
	}

	.lq-nav__list a {
		display: block;
		padding: 0.85em 0;
	}

	.lq-nav.is-open ~ .lq-header__actions .lq-nav-toggle .lq-nav-toggle__bar:nth-child(1) {
		transform: translateY(7px) rotate(45deg);
	}
	.lq-nav.is-open ~ .lq-header__actions .lq-nav-toggle .lq-nav-toggle__bar:nth-child(2) {
		opacity: 0;
	}
	.lq-nav.is-open ~ .lq-header__actions .lq-nav-toggle .lq-nav-toggle__bar:nth-child(3) {
		transform: translateY(-7px) rotate(-45deg);
	}

	/* Mobile: submenus become inline accordions */
	.lq-nav__item--has-children {
		flex-wrap: wrap;
		justify-content: space-between;
	}
	.lq-nav__item--has-children > .lq-nav__link {
		flex: 1;
	}
	.lq-nav__sub-toggle {
		width: 44px;
		height: 44px;
		color: var(--lq-primary);
	}
	.lq-nav__item--has-children.is-open > .lq-nav__sub-toggle {
		transform: rotate(180deg);
	}
	.lq-nav__submenu {
		position: static;
		transform: none;
		width: 100%;
		min-width: 0;
		opacity: 1;
		visibility: visible;
		border: none;
		box-shadow: none;
		background-color: transparent;
		padding: 0 0 0.5rem;
		max-height: 0;
		overflow: hidden;
		transition: max-height 0.3s ease;
	}
	.lq-nav__item--has-children.is-open > .lq-nav__submenu {
		max-height: 340px;
		transform: none;
	}
	.lq-nav__submenu::before { display: none; }
	.lq-nav__sub-item {
		border-bottom: none !important;
	}
	.lq-nav__sub-link {
		padding-left: 1rem;
		color: var(--lq-text-muted);
	}
}

/* --------------------------------------------------------------------------
   4b. Navigation dropdowns
   -------------------------------------------------------------------------- */
.lq-nav__item {
	position: relative;
}
.lq-nav__item--has-children {
	display: flex;
	align-items: center;
	gap: 0.15em;
}
.lq-nav__sub-toggle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	border: none !important;
	background: transparent !important;
	color: var(--lq-text);
	cursor: pointer;
	transition: transform 0.25s ease, color 0.2s ease;
}
.lq-nav__item--has-children:hover .lq-nav__sub-toggle,
.lq-nav__item--has-children:focus-within .lq-nav__sub-toggle {
	color: var(--lq-primary);
}

.lq-nav__submenu {
	list-style: none;
	margin: 0;
	padding: 0.5rem;
	position: absolute;
	top: calc(100% + 0.9rem);
	left: 50%;
	transform: translateX(-50%) translateY(8px);
	min-width: 230px;
	background-color: var(--lq-card);
	border: 1px solid var(--lq-bg-alt);
	border-radius: var(--lq-radius-md);
	box-shadow: var(--lq-shadow-hover);
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.22s ease, transform 0.22s ease, visibility 0.22s;
	z-index: 120;
}
.lq-nav__submenu::before {
	/* hover bridge so the menu doesn't close in the gap */
	content: '';
	position: absolute;
	top: -0.9rem;
	left: 0;
	right: 0;
	height: 0.9rem;
}
.lq-nav__item--has-children:hover > .lq-nav__submenu,
.lq-nav__item--has-children:focus-within > .lq-nav__submenu,
.lq-nav__item--has-children.is-open > .lq-nav__submenu {
	opacity: 1;
	visibility: visible;
	transform: translateX(-50%) translateY(0);
}
.lq-nav__sub-link {
	display: block;
	padding: 0.6em 0.9em;
	border-radius: var(--lq-radius-sm);
	font-size: 0.85rem;
	font-weight: 500;
	color: var(--lq-primary);
	white-space: nowrap;
	transition: background-color 0.18s ease, color 0.18s ease;
}
.lq-nav__sub-link::after { display: none; }
.lq-nav__sub-link:hover,
.lq-nav__sub-link:focus,
.lq-nav__sub-link.is-active {
	background-color: var(--lq-blush);
	color: var(--lq-primary);
}

/* Depth-1 items that have children — flex row so toggle sits at the end */
.lq-nav__sub-item.lq-nav__item--has-children {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
}
.lq-nav__sub-item.lq-nav__item--has-children > .lq-nav__sub-link {
	flex: 1;
}

/* Desktop: fly-out second-level submenu */
@media (min-width: 901px) {
	.lq-nav__sub-toggle--flyout {
		transform: rotate(-90deg);
		padding: 0 0.4em;
		color: var(--lq-text-muted);
	}
	.lq-nav__submenu .lq-nav__submenu {
		top: -0.5rem;
		left: 100%;
		transform: translateX(8px);
	}
	.lq-nav__submenu .lq-nav__item--has-children:hover > .lq-nav__submenu,
	.lq-nav__submenu .lq-nav__item--has-children:focus-within > .lq-nav__submenu,
	.lq-nav__submenu .lq-nav__item--has-children.is-open > .lq-nav__submenu {
		transform: translateX(0);
	}
	/* Hover bridge: side-opening submenu needs a left bridge instead of top */
	.lq-nav__submenu .lq-nav__submenu::before {
		top: 0;
		bottom: 0;
		left: -0.9rem;
		right: auto;
		width: 0.9rem;
		height: 100%;
	}
}

/* Mobile: second-level expands as indented accordion */
@media (max-width: 900px) {
	.lq-nav__sub-toggle--flyout {
		width: 44px;
		height: 44px;
	}
	.lq-nav__submenu .lq-nav__sub-link {
		padding-left: 2rem;
	}
	/* Give enough room for both levels to expand */
	.lq-nav__item--has-children.is-open > .lq-nav__submenu {
		max-height: 800px;
	}
}

/* --------------------------------------------------------------------------
   5. Section heading utility
   -------------------------------------------------------------------------- */
.lq-section-heading {
	max-width: 720px;
	margin: 0 auto 3rem;
	text-align: center;
}

.lq-section-heading__lead {
	color: var(--lq-text-muted);
	font-size: 1.05rem;
}

/* --------------------------------------------------------------------------
   6. Hero
   -------------------------------------------------------------------------- */
.lq-hero {
	position: relative;
	background: linear-gradient(135deg, var(--lq-bg-soft) 0%, var(--lq-blush) 65%, var(--lq-bg-soft) 100%);
	padding: clamp(2.5rem, 6vw, 5rem) 0;
	overflow: hidden;
}

.lq-hero__decor {
	position: absolute;
	border-radius: 50%;
	filter: blur(70px);
	opacity: 0.55;
	z-index: 0;
	pointer-events: none;
}
.lq-hero__decor--1 {
	width: 480px;
	height: 480px;
	background-color: var(--lq-teal);
	top: -200px;
	right: -140px;
}
.lq-hero__decor--2 {
	width: 380px;
	height: 380px;
	background-color: var(--lq-yellow);
	bottom: -180px;
	left: -120px;
}

.lq-hero__row {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--lq-gap);
	align-items: center;
}

@media (min-width: 980px) {
	.lq-hero__row {
		grid-template-columns: 1.1fr 0.9fr;
	}
}

.lq-hero__trust {
	display: inline-flex;
	align-items: center;
	gap: 0.6em;
	font-size: 0.82rem;
	font-weight: 500;
	color: var(--lq-primary);
	background-color: var(--lq-card);
	border: 1px solid var(--lq-sage);
	padding: 0.45em 1.1em;
	border-radius: 999px;
	margin-bottom: 1.1rem;
	box-shadow: var(--lq-shadow);
}
.lq-hero__trust-dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background-color: var(--lq-sage);
	flex-shrink: 0;
}

.lq-hero__title {
	font-size: clamp(3rem, 6.5vw, 5rem);
	font-weight: 700;
	letter-spacing: -0.025em;
	line-height: 1.08;
	margin-bottom: 0.6em;
}

.lq-hero__highlight {
	font-family: var(--lq-font-heading);
	font-style: italic;
	color: var(--lq-primary);
	padding: 0 0.15em;
	background-image: linear-gradient(transparent 62%, var(--lq-yellow) 62%);
	background-repeat: no-repeat;
	box-decoration-break: clone;
	-webkit-box-decoration-break: clone;
}

.lq-hero__lead {
	color: var(--lq-text-muted);
	font-size: 1.1rem;
	max-width: 56ch;
}

.lq-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	margin: 1.5rem 0 2.5rem;
}

.lq-hero__stats {
	display: flex;
	flex-wrap: wrap;
	gap: clamp(1.5rem, 4vw, 3rem);
	margin: 0;
}

.lq-hero__stat dt {
	font-family: var(--lq-font-heading);
	font-size: clamp(1.8rem, 3vw, 2.4rem);
	font-weight: 700;
	color: var(--lq-primary);
}

.lq-hero__stat dd {
	margin: 0;
	font-size: 0.85rem;
	color: var(--lq-text-muted);
	letter-spacing: 0.04em;
}

.lq-hero__visual {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 380px;
	padding: 2rem 0;
}

.lq-hero__blob {
	position: absolute;
	border-radius: 50%;
	filter: blur(2px);
	opacity: 0.7;
	z-index: 0;
}
.lq-hero__blob--sage {
	width: 280px;
	height: 280px;
	background-color: var(--lq-sage);
	top: -20px;
	right: 6%;
}
.lq-hero__blob--yellow {
	width: 200px;
	height: 200px;
	background-color: var(--lq-yellow);
	bottom: -10px;
	left: 2%;
}

.lq-hero__frame {
	position: relative;
	z-index: 1;
	width: 100%;
	max-width: 380px;
	margin: 0 auto;
}
.lq-hero__frame::before {
	content: '';
	position: absolute;
	inset: -16px;
	border: 2px solid var(--lq-sage);
	border-radius: 999px 999px calc(var(--lq-radius-lg) + 16px) calc(var(--lq-radius-lg) + 16px);
	z-index: -1;
}

.lq-hero__badge {
	position: absolute;
	bottom: 8%;
	right: 2%;
	background-color: var(--lq-card);
	box-shadow: var(--lq-shadow);
	border-radius: var(--lq-radius-md);
	padding: 0.8rem 1.2rem;
	display: flex;
	align-items: center;
	gap: 0.7rem;
	z-index: 2;
}
.lq-hero__badge-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background-color: var(--lq-primary);
	color: var(--lq-on-primary);
	font-size: 1rem;
}
.lq-hero__badge-title {
	display: block;
	font-family: var(--lq-font-heading);
	font-weight: 700;
	color: var(--lq-primary);
	font-size: 1rem;
}
.lq-hero__badge-sub {
	display: block;
	font-size: 0.8rem;
	color: var(--lq-text-muted);
}

/* --------------------------------------------------------------------------
   6b. Hero — Bold Statement (film-poster variant)
   -------------------------------------------------------------------------- */
.lq-hero--poster {
	position: relative;
	display: flex;
	align-items: flex-end;
	min-height: clamp(580px, 92vh, 880px);
	padding: 0;
	background: var(--lq-primary);
	overflow: hidden;
	isolation: isolate;
}
.lq-hero--poster .lq-hero__media {
	position: absolute;
	inset: 0;
	z-index: 0;
}
.lq-hero__photo {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: 50% 18%;
	display: block;
}
.lq-hero__scrim {
	position: absolute;
	inset: 0;
	background:
		linear-gradient(180deg, rgba(3, 50, 43, 0.30) 0%, rgba(3, 50, 43, 0) 28%, rgba(3, 50, 43, 0.12) 55%, rgba(3, 50, 43, 0.82) 100%),
		linear-gradient(265deg, rgba(3, 50, 43, 0.55) 0%, rgba(3, 50, 43, 0.12) 45%, rgba(3, 50, 43, 0) 70%);
}
.lq-hero__inner {
	position: relative;
	z-index: 1;
	width: 100%;
	padding-top: clamp(4rem, 12vh, 9rem);
	padding-bottom: clamp(3.5rem, 9vh, 7rem);
	max-width: var(--lq-container);
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	text-align: right;
}
.lq-hero__eyebrow {
	font-size: 0.78rem;
	font-weight: 600;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--lq-yellow);
	margin: 0 0 1.1rem;
}
.lq-hero__headline {
	font-family: var(--lq-font-heading);
	color: var(--lq-on-primary);
	font-size: clamp(3.2rem, 9vw, 7rem);
	font-weight: 700;
	line-height: 0.98;
	letter-spacing: -0.02em;
	margin: 0 0 1.5rem;
	text-shadow: 0 2px 40px rgba(3, 50, 43, 0.4);
	max-width: 16ch;
}
.lq-hero__headline em {
	font-style: italic;
	font-weight: 500;
	color: var(--lq-yellow);
}
.lq-hero__sub {
	color: rgba(249, 250, 248, 0.92);
	font-size: clamp(1.05rem, 1.6vw, 1.3rem);
	line-height: 1.6;
	max-width: 44ch;
	margin: 0 0 2.25rem;
	text-shadow: 0 1px 16px rgba(3, 50, 43, 0.45);
}
.lq-hero__cta {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	align-items: center;
	justify-content: flex-end;
}
.lq-hero__btn {
	padding: 1.05em 2.3em;
	font-size: 1.02rem;
	box-shadow: 0 14px 38px rgba(3, 50, 43, 0.4);
}
.lq-hero__proof {
	display: inline-flex;
	align-items: center;
	gap: 0.6em;
	margin: 2.25rem 0 0;
	font-size: 0.9rem;
	font-weight: 500;
	color: rgba(249, 250, 248, 0.9);
	letter-spacing: 0.01em;
}
.lq-hero__proof-dot {
	width: 9px;
	height: 9px;
	border-radius: 50%;
	background-color: var(--lq-yellow);
	box-shadow: 0 0 0 4px rgba(255, 223, 166, 0.25);
	flex-shrink: 0;
}
.lq-hero__scroll {
	position: absolute;
	z-index: 2;
	left: clamp(1.5rem, 5vw, 3.5rem);
	bottom: clamp(1.75rem, 4vh, 3rem);
	display: inline-flex;
	flex-direction: column;
	align-items: center;
	gap: 0.6rem;
	color: rgba(249, 250, 248, 0.85);
}
.lq-hero__scroll-text {
	font-size: 0.7rem;
	font-weight: 600;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	writing-mode: vertical-rl;
}
.lq-hero__scroll-line {
	width: 1px;
	height: 48px;
	background: linear-gradient(180deg, rgba(249, 250, 248, 0.7) 0%, rgba(249, 250, 248, 0) 100%);
	position: relative;
	overflow: hidden;
}
.lq-hero__scroll-line::after {
	content: '';
	position: absolute;
	top: -50%;
	left: 0;
	width: 100%;
	height: 50%;
	background-color: var(--lq-yellow);
}
@media (prefers-reduced-motion: no-preference) {
	.lq-hero__scroll-line::after {
		animation: lq-scroll-cue 1.8s cubic-bezier(0.65, 0, 0.35, 1) infinite;
	}
}
@keyframes lq-scroll-cue {
	0%   { transform: translateY(0); }
	100% { transform: translateY(300%); }
}
@media (max-width: 720px) {
	.lq-hero--poster {
		align-items: flex-end;
		min-height: clamp(560px, 88vh, 760px);
	}
	.lq-hero__photo {
		object-position: 50% 12%;
	}
	.lq-hero__scroll {
		display: none;
	}
	.lq-hero__scrim {
		background:
			linear-gradient(180deg, rgba(3, 50, 43, 0.25) 0%, rgba(3, 50, 43, 0) 30%, rgba(3, 50, 43, 0.5) 62%, rgba(3, 50, 43, 0.9) 100%);
	}
}

/* --------------------------------------------------------------------------
   7. Image placeholders
   -------------------------------------------------------------------------- */
.lq-img--placeholder {
	width: 100%;
	border-radius: var(--lq-radius-lg);
	background: linear-gradient(135deg, var(--lq-sage) 0%, var(--lq-bg-alt) 50%, var(--lq-teal) 100%);
	position: relative;
}
.lq-img--placeholder::after {
	content: '';
	position: absolute;
	inset: 0;
	border-radius: inherit;
	background-image: radial-gradient(circle at 30% 30%, rgba(255,255,255,0.35), transparent 60%);
}
.lq-img--hero { aspect-ratio: 4 / 5; }
.lq-img--portrait { aspect-ratio: 900 / 1100; }
img.lq-img--hero,
img.lq-img--portrait {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: var(--lq-radius-lg);
}
img.lq-img--hero {
	object-position: top center;
}
.lq-hero__frame img.lq-img--hero {
	border-radius: 999px 999px var(--lq-radius-lg) var(--lq-radius-lg);
	box-shadow: var(--lq-shadow-hover);
}
.lq-img.lq-img--card,
.lq-post-card__media .lq-img { aspect-ratio: 4 / 3; object-fit: cover; border-radius: var(--lq-radius-md); }
.lq-post-card__media .lq-img--placeholder { aspect-ratio: 4 / 3; border-radius: var(--lq-radius-md); }

/* --------------------------------------------------------------------------
   8. Services
   -------------------------------------------------------------------------- */
.lq-services {
	padding: clamp(3rem, 6vw, 6rem) 0;
	background-color: var(--lq-yellow);
}

.lq-services__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(1.5rem, 3vw, 2rem);
}

@media (min-width: 720px) {
	.lq-services__grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

.lq-service-card {
	background-color: var(--lq-card);
	border-radius: var(--lq-radius-lg);
	padding: clamp(1.75rem, 3vw, 2.5rem);
	box-shadow: var(--lq-shadow);
	display: flex;
	flex-direction: column;
	transition: transform 0.25s ease, box-shadow 0.25s ease;
	border: 1px solid var(--lq-bg-alt);
}
.lq-service-card:hover {
	transform: translateY(-6px);
	box-shadow: var(--lq-shadow-hover);
	border-color: var(--lq-sage);
}

.lq-service-card__icon {
	width: 56px;
	height: 56px;
	border-radius: 50%;
	background-color: var(--lq-bg-alt);
	color: var(--lq-primary);
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 1.2rem;
}
.lq-services__grid .lq-service-card:nth-child(1) { border-top: 4px solid var(--lq-sage); }
.lq-services__grid .lq-service-card:nth-child(2) { border-top: 4px solid var(--lq-yellow); }
.lq-services__grid .lq-service-card:nth-child(3) { border-top: 4px solid var(--lq-teal); }
.lq-services__grid .lq-service-card:nth-child(1) .lq-service-card__icon { background-color: var(--lq-sage); }
.lq-services__grid .lq-service-card:nth-child(2) .lq-service-card__icon { background-color: var(--lq-blush); }
.lq-services__grid .lq-service-card:nth-child(3) .lq-service-card__icon { background-color: var(--lq-teal); }

.lq-service-card__title {
	margin-bottom: 0.2em;
}

.lq-service-card__tag {
	font-size: 0.85rem;
	font-weight: 600;
	color: var(--lq-teal);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	margin-bottom: 1em;
}

.lq-service-card__desc {
	color: var(--lq-text-muted);
}

.lq-service-card__list {
	list-style: none;
	margin: 0 0 1.5em;
	display: flex;
	flex-direction: column;
	gap: 0.5em;
}
.lq-service-card__list li {
	padding-left: 1.6em;
	position: relative;
	font-size: 0.95rem;
	color: var(--lq-text);
}
.lq-service-card__list li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0.6em;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background-color: var(--lq-sage);
}

.lq-service-card__link {
	margin-top: auto;
	font-weight: 600;
	color: var(--lq-primary);
	display: inline-flex;
	align-items: center;
	gap: 0.4em;
}
.lq-service-card__link span {
	transition: transform 0.2s ease;
}
.lq-service-card__link:hover span {
	transform: translateX(4px);
}

/* --------------------------------------------------------------------------
   9. Booking CTA + Shortcode embeds
   -------------------------------------------------------------------------- */
/* "Take the Next Step" CTA band */
.lq-cta {
	padding: clamp(3rem, 6vw, 6rem) 0;
	background-color: var(--lq-bg-soft);
}

.lq-cta__card {
	position: relative;
	overflow: hidden;
	background: linear-gradient(135deg, var(--lq-primary) 0%, var(--lq-primary-light) 100%);
	border-radius: var(--lq-radius-lg);
	padding: clamp(2.5rem, 6vw, 5rem) clamp(1.5rem, 5vw, 4rem);
	text-align: center;
}

.lq-cta__decor {
	position: absolute;
	border-radius: 50%;
	filter: blur(50px);
	opacity: 0.35;
	pointer-events: none;
}
.lq-cta__decor--1 {
	width: 280px;
	height: 280px;
	background-color: var(--lq-teal);
	top: -90px;
	left: -70px;
}
.lq-cta__decor--2 {
	width: 240px;
	height: 240px;
	background-color: var(--lq-yellow);
	bottom: -80px;
	right: -50px;
}

.lq-cta__content {
	position: relative;
	z-index: 1;
	max-width: 640px;
	margin: 0 auto;
}
.lq-cta__content h2 {
	color: var(--lq-on-primary);
}
.lq-eyebrow--light {
	color: var(--lq-yellow);
	opacity: 1;
}
.lq-cta__lead {
	color: var(--lq-sage);
	font-size: 1.05rem;
	margin-bottom: 0;
}
.lq-cta__actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 1rem;
	margin-top: 2rem;
}

.lq-booking {
	max-width: 760px;
	margin: 0 auto;
	background-color: var(--lq-card);
	border-radius: var(--lq-radius-lg);
	box-shadow: var(--lq-shadow);
	overflow: hidden;
}

.lq-booking__tabs {
	display: flex;
}

.lq-booking__tab {
	flex: 1;
	padding: 1.1rem 1rem;
	background-color: var(--lq-bg-alt);
	border: none;
	font-family: var(--lq-font-body);
	font-weight: 600;
	font-size: 0.95rem;
	color: var(--lq-text-muted);
	cursor: pointer;
	transition: all 0.2s ease;
}

.lq-booking__tab.is-active {
	background-color: var(--lq-card);
	color: var(--lq-primary);
	box-shadow: inset 0 -3px 0 var(--lq-primary);
}

.lq-booking__panel {
	padding: clamp(1.5rem, 3vw, 2.5rem);
}

.lq-booking-embed__title {
	margin-bottom: 0.3em;
}

.lq-booking-embed__subtitle {
	color: var(--lq-text-muted);
	margin-bottom: 1.5em;
}

.lq-booking-embed__frame {
	width: 100%;
	height: var(--lq-embed-height, 700px);
	border-radius: var(--lq-radius-md);
	overflow: hidden;
	border: 1px solid var(--lq-bg-alt);
	background-color: var(--lq-bg-soft);
}
.lq-booking-embed__frame iframe {
	width: 100%;
	height: 100%;
	border: 0;
	display: block;
}

/* --------------------------------------------------------------------------
   10. Insights / Post cards
   -------------------------------------------------------------------------- */
.lq-insights {
	padding: clamp(3rem, 6vw, 6rem) 0;
	background-color: var(--lq-blush);
}

.lq-insights__grid,
.lq-archive__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(1.5rem, 3vw, 2rem);
}

@media (min-width: 640px) {
	.lq-insights__grid,
	.lq-archive__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}
@media (min-width: 980px) {
	.lq-insights__grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

.lq-post-card {
	background-color: var(--lq-card);
	border-radius: var(--lq-radius-lg);
	overflow: hidden;
	box-shadow: var(--lq-shadow);
	display: flex;
	flex-direction: column;
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.lq-post-card:hover {
	transform: translateY(-6px);
	box-shadow: var(--lq-shadow-hover);
}

.lq-post-card__media {
	position: relative;
	display: block;
}

.lq-post-card__tag {
	position: absolute;
	top: 1rem;
	left: 1rem;
	background-color: var(--lq-card);
	color: var(--lq-primary);
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	padding: 0.35em 0.9em;
	border-radius: 999px;
	box-shadow: var(--lq-shadow);
}

.lq-post-card__body {
	padding: 1.5rem;
	display: flex;
	flex-direction: column;
	flex: 1;
}

.lq-post-card__meta {
	font-size: 0.8rem;
	color: var(--lq-text-muted);
	margin-bottom: 0.5em;
	text-transform: uppercase;
	letter-spacing: 0.06em;
}

.lq-post-card__title {
	font-size: 1.2rem;
	margin-bottom: 0.5em;
}
.lq-post-card__title a {
	color: var(--lq-primary);
}
.lq-post-card__title a:hover {
	color: var(--lq-teal);
}

.lq-post-card__excerpt {
	color: var(--lq-text-muted);
	font-size: 0.95rem;
	flex: 1;
}
.lq-post-card__excerpt p {
	margin: 0;
}

.lq-post-card__link {
	margin-top: 1em;
	font-weight: 600;
	display: inline-flex;
	align-items: center;
	gap: 0.4em;
}

.lq-insights__empty {
	text-align: center;
	color: var(--lq-text-muted);
}

.lq-insights__more {
	text-align: center;
	margin-top: 3rem;
}

/* --------------------------------------------------------------------------
   11. Community CTA
   -------------------------------------------------------------------------- */
.lq-community-cta {
	background-color: var(--lq-bg-soft);
	padding: clamp(3rem, 6vw, 5rem) 0;
}

.lq-community-cta__row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 2rem;
	background-color: var(--lq-blush);
	border-radius: var(--lq-radius-lg);
	padding: clamp(2rem, 4vw, 3.5rem);
}

.lq-community-cta__text {
	max-width: 540px;
}
.lq-community-cta__text h2 {
	margin-bottom: 0.4em;
}
.lq-community-cta__text p {
	margin: 0;
	color: var(--lq-text-muted);
}

.lq-community-cta__action {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
}

/* --------------------------------------------------------------------------
   12. About page — Editorial
   -------------------------------------------------------------------------- */
.lq-about-hero {
	position: relative;
	overflow: hidden;
	padding: clamp(3.5rem, 7vw, 6rem) 0;
	background: linear-gradient(135deg, var(--lq-blush) 0%, var(--lq-bg-soft) 60%);
}
.lq-about-hero::before {
	content: '';
	position: absolute;
	width: 520px;
	height: 520px;
	border-radius: 50%;
	background-color: var(--lq-sage);
	opacity: 0.2;
	filter: blur(70px);
	top: -200px;
	right: -120px;
	pointer-events: none;
}
.lq-about-hero__row {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--lq-gap);
	align-items: center;
}
@media (min-width: 980px) {
	.lq-about-hero__row {
		grid-template-columns: 1.1fr 0.9fr;
	}
}
.lq-about-hero__text h1 {
	font-size: clamp(2.4rem, 5vw, 3.8rem);
	line-height: 1.08;
	letter-spacing: -0.02em;
}
.lq-about-hero__lead {
	font-size: 1.1rem;
	color: var(--lq-text-muted);
	line-height: 1.7;
	max-width: 56ch;
}

/* Arch-framed portrait + floating stat badge */
.lq-about-hero__image {
	position: relative;
	align-self: flex-start;
}
.lq-about-hero__frame {
	position: relative;
	max-width: 420px;
	margin: 0 auto;
}
.lq-about-hero__frame::before {
	content: '';
	position: absolute;
	inset: -14px;
	border: 2px solid var(--lq-sage);
	border-radius: 999px 999px var(--lq-radius-lg) var(--lq-radius-lg);
	z-index: 0;
}
.lq-about-hero__img-wrap {
	position: relative;
	z-index: 1;
	overflow: hidden;
	border-radius: 999px 999px var(--lq-radius-lg) var(--lq-radius-lg);
	box-shadow: var(--lq-shadow-hover);
}
.lq-about-hero__frame img {
	display: block;
	width: 100%;
	height: auto;
	aspect-ratio: 4 / 5;
	object-fit: cover;
	object-position: top center;
}
.lq-about-hero__badge {
	position: absolute;
	bottom: 7%;
	left: clamp(-0.5rem, 1vw, 1rem);
	background: linear-gradient(160deg, var(--lq-primary) 0%, var(--lq-primary-light) 100%);
	color: var(--lq-on-primary);
	border-radius: var(--lq-radius-md);
	padding: 0.9rem 1.4rem;
	box-shadow: var(--lq-shadow-hover);
	text-align: center;
	z-index: 2;
}
.lq-about-hero__badge-num {
	display: block;
	font-family: var(--lq-font-heading);
	font-size: 1.7rem;
	font-weight: 700;
	line-height: 1;
	color: var(--lq-yellow);
}
.lq-about-hero__badge-label {
	display: block;
	font-size: 0.72rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: rgba(249, 250, 248, 0.85);
	margin-top: 0.25rem;
}

.lq-story-pillars {
	padding: clamp(3rem, 6vw, 5rem) 0;
	background-color: var(--lq-bg-soft);
}
.lq-pillars__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
	margin-top: clamp(2rem, 4vw, 3rem);
}
@media (min-width: 720px) {
	.lq-pillars__grid {
		grid-template-columns: repeat(3, 1fr);
	}
}
.lq-pillar {
	border-radius: var(--lq-radius-lg);
	padding: clamp(1.75rem, 3vw, 2.25rem);
	display: flex;
	flex-direction: column;
}
.lq-pillar--blush { background-color: var(--lq-blush); }
.lq-pillar--sage  { background-color: var(--lq-sage);  }
.lq-pillar--teal  { background-color: var(--lq-teal);  }
.lq-pillar__icon {
	width: 52px;
	height: 52px;
	border-radius: 50%;
	background-color: var(--lq-primary);
	color: var(--lq-on-primary);
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 1.25rem;
	flex-shrink: 0;
}
.lq-pillar__era {
	font-size: 0.78rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--lq-primary);
	opacity: 0.75;
	margin: 0 0 0.5em;
}
.lq-pillar h3 {
	font-size: clamp(1rem, 2vw, 1.15rem);
	margin-bottom: 0.75em;
	color: var(--lq-primary);
}
.lq-pillar p {
	color: var(--lq-text);
	font-size: 0.95rem;
	line-height: 1.65;
	margin: 0 0 1.5rem;
	flex: 1;
}
.lq-pillar__cta {
	margin-top: auto;
	align-self: flex-start;
}

.lq-stats {
	background-color: var(--lq-primary);
	padding: clamp(2.5rem, 5vw, 4rem) 0;
}
.lq-stats__grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 2rem;
	text-align: center;
}
@media (min-width: 720px) {
	.lq-stats__grid {
		grid-template-columns: repeat(4, 1fr);
	}
}
.lq-stats__number {
	display: block;
	font-family: var(--lq-font-heading);
	font-size: clamp(2rem, 4vw, 2.8rem);
	font-weight: 700;
	color: var(--lq-on-primary);
}
.lq-stats__label {
	display: block;
	color: var(--lq-sage);
	font-size: 0.85rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	margin-top: 0.4em;
}

.lq-featured {
	padding: clamp(2.5rem, 5vw, 4rem) 0;
	background-color: var(--lq-bg-alt);
	text-align: center;
}
.lq-featured__label {
	font-size: 0.8rem;
	font-weight: 600;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--lq-text-muted);
	margin-bottom: 1.5rem;
}
.lq-featured__logos {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: clamp(1.5rem, 4vw, 3rem);
}
.lq-featured__logo {
	font-family: var(--lq-font-heading);
	font-weight: 600;
	font-size: 1.1rem;
	color: var(--lq-primary);
	opacity: 0.6;
}

.lq-fun-facts {
	padding: clamp(3rem, 6vw, 5rem) 0;
	background-color: var(--lq-sage);
}
.lq-fun-facts__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}
@media (min-width: 720px) {
	.lq-fun-facts__grid {
		grid-template-columns: repeat(3, 1fr);
	}
}
.lq-fun-fact {
	background-color: var(--lq-card);
	border-radius: var(--lq-radius-lg);
	padding: 2rem;
	text-align: center;
	box-shadow: var(--lq-shadow);
}
.lq-fun-fact__icon {
	font-size: 2rem;
	margin-bottom: 0.6rem;
}
.lq-fun-fact p {
	color: var(--lq-text-muted);
	margin: 0;
}

/* --------------------------------------------------------------------------
   13. Foundation page (Innovation TOD 165)
   -------------------------------------------------------------------------- */
.lq-found-hero {
	position: relative;
	overflow: hidden;
	padding: clamp(3.5rem, 7vw, 6rem) 0;
	background: linear-gradient(135deg, var(--lq-blush) 0%, var(--lq-bg-soft) 60%);
}
.lq-found-hero::before {
	content: '';
	position: absolute;
	width: 500px;
	height: 500px;
	border-radius: 50%;
	background-color: var(--lq-yellow);
	opacity: 0.22;
	filter: blur(70px);
	top: -200px;
	right: -120px;
	pointer-events: none;
}
.lq-found-hero__row {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--lq-gap);
	align-items: center;
}
@media (min-width: 980px) {
	.lq-found-hero__row {
		grid-template-columns: 1.1fr 0.9fr;
	}
}
.lq-found-hero__content h1 {
	font-size: clamp(2.3rem, 5vw, 3.6rem);
	line-height: 1.1;
	letter-spacing: -0.02em;
}
.lq-found-hero__lead {
	font-size: 1.1rem;
	color: var(--lq-text-muted);
	line-height: 1.7;
	max-width: 56ch;
}
.lq-found-hero__visual {
	position: relative;
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

.lq-mission {
	padding: clamp(3rem, 6vw, 5rem) 0;
	background-color: var(--lq-bg-soft);
}
.lq-mission__row {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
	max-width: 820px;
	margin: 0 auto;
	text-align: center;
	align-items: center;
}
.lq-mission__badge {
	width: 64px;
	height: 64px;
	border-radius: 50%;
	background-color: var(--lq-yellow);
	color: var(--lq-primary);
	display: flex;
	align-items: center;
	justify-content: center;
}
.lq-mission__content p {
	color: var(--lq-text-muted);
}

.lq-girltalk {
	padding: clamp(3rem, 6vw, 5rem) 0;
	background-color: var(--lq-bg-alt);
}
.lq-girltalk__row {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--lq-gap);
	align-items: center;
}
@media (min-width: 900px) {
	.lq-girltalk__row {
		grid-template-columns: 0.9fr 1.1fr;
	}
}
.lq-girltalk__content p {
	color: var(--lq-text-muted);
}
.lq-girltalk__list {
	list-style: none;
	margin: 0 0 1.8em;
	display: flex;
	flex-direction: column;
	gap: 0.8em;
}
.lq-girltalk__list li {
	padding: 0.9em 1.2em;
	background-color: var(--lq-card);
	border-radius: var(--lq-radius-sm);
	border-left: 4px solid var(--lq-yellow);
	font-size: 0.95rem;
	color: var(--lq-text);
}
.lq-girltalk__list strong {
	color: var(--lq-primary);
}

.lq-topics {
	padding: clamp(3rem, 6vw, 5rem) 0;
	background-color: var(--lq-bg-soft);
}
.lq-topics__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}
@media (min-width: 640px) {
	.lq-topics__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}
@media (min-width: 980px) {
	.lq-topics__grid {
		grid-template-columns: repeat(3, 1fr);
	}
}
.lq-topic-card {
	background-color: var(--lq-card);
	border: 1px solid var(--lq-blush);
	border-radius: var(--lq-radius-lg);
	padding: 1.8rem;
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.lq-topic-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--lq-shadow);
}
.lq-topic-card__icon {
	font-size: 1.8rem;
	margin-bottom: 0.6rem;
}
.lq-topic-card h3 {
	margin-bottom: 0.4em;
}
.lq-topic-card p {
	color: var(--lq-text-muted);
	margin: 0;
	font-size: 0.95rem;
}

.lq-donate {
	padding: clamp(3rem, 6vw, 5rem) 0;
	background-color: var(--lq-yellow);
}
.lq-donate__card {
	max-width: 860px;
	margin: 0 auto;
	text-align: center;
	background-color: var(--lq-card);
	border-radius: var(--lq-radius-lg);
	padding: clamp(2rem, 5vw, 3.5rem);
	box-shadow: var(--lq-shadow);
}
.lq-donate__card p {
	color: var(--lq-text-muted);
}
.lq-donate__options {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.25rem;
	margin: 2rem 0;
	text-align: left;
}
@media (min-width: 720px) {
	.lq-donate__options {
		grid-template-columns: repeat(3, 1fr);
	}
}
.lq-donate__option {
	background-color: var(--lq-blush);
	border-radius: var(--lq-radius-md);
	padding: 1.4rem;
}
.lq-donate__option h3 {
	margin-bottom: 0.3em;
	font-size: 1.05rem;
}
.lq-donate__option p {
	margin: 0;
	font-size: 0.9rem;
}
.lq-donate__actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 1rem;
	margin-bottom: 1rem;
}
.lq-donate__note {
	font-size: 0.8rem;
	color: var(--lq-text-muted);
	opacity: 0.8;
	margin: 0;
}

/* --------------------------------------------------------------------------
   14. Single post / Page / Prose
   -------------------------------------------------------------------------- */
.lq-prose {
	font-size: 1.05rem;
	color: var(--lq-text);
}
.lq-prose h2, .lq-prose h3, .lq-prose h4 {
	margin-top: 1.6em;
}
.lq-prose img {
	border-radius: var(--lq-radius-md);
}
.lq-prose blockquote {
	margin: 1.5em 0;
	padding: 1em 1.5em;
	border-left: 4px solid var(--lq-sage);
	background-color: var(--lq-bg-alt);
	border-radius: var(--lq-radius-sm);
	font-style: italic;
}
.lq-prose a {
	text-decoration: underline;
	text-decoration-color: var(--lq-sage);
}

.lq-single__header,
.lq-page__header {
	margin-bottom: 1.5rem;
}
.lq-single__cat {
	display: inline-block;
	background-color: var(--lq-bg-alt);
	color: var(--lq-primary);
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	padding: 0.35em 0.9em;
	border-radius: 999px;
	margin-bottom: 0.8em;
}
.lq-single__title,
.lq-page__title {
	margin-bottom: 0.4em;
}
.lq-single__meta {
	color: var(--lq-text-muted);
	font-size: 0.9rem;
}
.lq-single__sep {
	margin: 0 0.4em;
}

.lq-single__thumb,
.lq-page__thumb {
	margin: 1.5rem 0;
	border-radius: var(--lq-radius-lg);
	overflow: hidden;
}

.lq-single__ad,
.lq-incontent-ad {
	margin: 2rem 0;
}

.lq-page-links {
	margin-top: 2rem;
	font-weight: 600;
}

.lq-single__tags {
	margin-top: 2rem;
	display: flex;
	flex-wrap: wrap;
	gap: 0.6rem;
}
.lq-tag {
	background-color: var(--lq-bg-alt);
	color: var(--lq-primary);
	font-size: 0.8rem;
	padding: 0.4em 1em;
	border-radius: 999px;
}
.lq-tag:hover {
	background-color: var(--lq-sage);
}

.lq-author-box {
	display: flex;
	gap: 1.2rem;
	align-items: flex-start;
	margin-top: 3rem;
	padding: 1.5rem;
	background-color: var(--lq-bg-alt);
	border-radius: var(--lq-radius-lg);
}
.lq-author-box__avatar img {
	border-radius: 50%;
}
.lq-author-box__name {
	font-weight: 700;
	color: var(--lq-primary);
	margin: 0 0 0.3em;
}
.lq-author-box__bio {
	margin: 0;
	color: var(--lq-text-muted);
	font-size: 0.95rem;
}

.lq-post-nav {
	display: flex;
	justify-content: space-between;
	gap: 1rem;
	margin-top: 2rem;
	padding-top: 1.5rem;
	border-top: 1px solid var(--lq-bg-alt);
	font-weight: 600;
}
.lq-post-nav a {
	color: var(--lq-primary);
}

/* --------------------------------------------------------------------------
   15. Sidebar & widgets
   -------------------------------------------------------------------------- */
.lq-sidebar {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}
.lq-widget,
.lq-footer-widget,
.lq-ad-slot {
	background-color: var(--lq-card);
	border-radius: var(--lq-radius-lg);
	padding: 1.5rem;
}
.lq-sidebar .lq-widget {
	box-shadow: var(--lq-shadow);
}
.lq-widget__title,
.lq-footer-widget__title {
	font-size: 1.05rem;
	margin-bottom: 0.8em;
}
.lq-widget__list {
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: 0.6em;
	font-size: 0.95rem;
}
.lq-widget--cta {
	background-color: var(--lq-primary);
	color: var(--lq-on-primary);
}
.lq-widget--cta .lq-widget__title,
.lq-widget--cta p {
	color: var(--lq-on-primary);
}
.lq-widget--cta p {
	opacity: 0.85;
	font-size: 0.9rem;
}

/* Search form */
.search-form {
	display: flex;
	align-items: stretch;
	gap: 0.5rem;
}
/* WordPress wraps the input in a <label> — reset it so it doesn't
   render as a visible box behind the actual input field. */
.search-form label {
	flex: 1;
	display: flex;
	align-items: stretch;
	margin: 0;
	padding: 0;
	background: transparent;
	border: none;
}
.search-form .search-field {
	flex: 1;
	width: 100%;
	padding: 0.7em 1em;
	border: 1px solid var(--lq-bg-alt);
	border-radius: var(--lq-radius-sm);
	background: var(--lq-card);
	font-family: var(--lq-font-body);
	font-size: 0.95rem;
	color: var(--lq-text);
}
.search-form .search-field:focus {
	outline: 2px solid var(--lq-primary);
	outline-offset: 2px;
	border-color: var(--lq-primary);
}
.search-form .search-submit {
	padding: 0.7em 1.4em;
	border: none;
	border-radius: var(--lq-radius-sm);
	background-color: var(--lq-primary);
	color: var(--lq-on-primary);
	font-weight: 600;
	cursor: pointer;
	white-space: nowrap;
	transition: background-color 0.2s;
}
.search-form .search-submit:hover {
	background-color: var(--lq-primary-light);
}

/* --------------------------------------------------------------------------
   16. Archive / Pagination / No results
   -------------------------------------------------------------------------- */
.lq-archive-header {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-end;
	justify-content: space-between;
	gap: 1.25rem;
	margin-bottom: 2rem;
}
.lq-archive-header__text {
	flex: 1 1 auto;
}
.lq-archive-title {
	margin-bottom: 0.3em;
}
.lq-archive-desc {
	color: var(--lq-text-muted);
}

/* Category filter dropdown */
.lq-category-filter {
	flex-shrink: 0;
	margin-left: auto;
}
.lq-category-filter__select {
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	font-family: var(--lq-font-body);
	font-size: 0.9rem;
	font-weight: 500;
	color: var(--lq-primary);
	background-color: var(--lq-card);
	border: 1px solid var(--lq-bg-alt);
	border-radius: 999px;
	padding: 0.7em 2.6em 0.7em 1.4em;
	cursor: pointer;
	box-shadow: var(--lq-shadow);
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%2303322B' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 1.2em center;
	transition: border-color 0.2s ease;
}
.lq-category-filter__select:hover,
.lq-category-filter__select:focus {
	border-color: var(--lq-sage);
	outline: none;
}

@media (max-width: 640px) {
	.lq-category-filter {
		width: 100%;
		margin-left: 0;
	}
	.lq-category-filter__select {
		width: 100%;
	}
}

.lq-pagination {
	display: flex;
	justify-content: center;
	gap: 0.6rem;
	margin-top: 3rem;
	flex-wrap: wrap;
}
.lq-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 42px;
	height: 42px;
	padding: 0 0.6em;
	border-radius: var(--lq-radius-sm);
	background-color: var(--lq-card);
	color: var(--lq-primary);
	font-weight: 600;
	border: 1px solid var(--lq-bg-alt);
}
.lq-pagination .page-numbers.current {
	background-color: var(--lq-primary);
	color: var(--lq-on-primary);
	border-color: var(--lq-primary);
}
.lq-pagination .page-numbers:hover {
	border-color: var(--lq-primary);
}

.lq-no-results {
	text-align: center;
	color: var(--lq-text-muted);
	padding: 3rem 0;
}
.lq-no-results .search-form {
	max-width: 420px;
	margin: 1.5rem auto 0;
}

/* --------------------------------------------------------------------------
   17. Footer
   -------------------------------------------------------------------------- */
.lq-footer {
	background-color: var(--lq-primary);
	color: var(--lq-on-primary);
}
.lq-footer a {
	color: var(--lq-on-primary);
	opacity: 0.85;
}
.lq-footer a:hover {
	opacity: 1;
	color: var(--lq-yellow);
}

.lq-footer__top {
	padding: clamp(3rem, 6vw, 5rem) 0;
}
.lq-footer__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2.5rem;
}
@media (min-width: 720px) {
	.lq-footer__grid {
		grid-template-columns: 1.4fr 1fr 1fr 1fr;
	}
}
.lq-footer__sitename {
	font-family: var(--lq-font-heading);
	font-size: 1.4rem;
	font-weight: 700;
	margin: 0 0 0.6em;
}
.lq-footer__logo img {
	max-height: 50px;
	width: auto;
	margin-bottom: 0.6em;
}
.lq-footer__logo--fallback {
	display: block;
	width: fit-content;
	max-width: 100%;
	background-color: var(--lq-card);
	padding: 0.4rem 0.85rem;
	border-radius: var(--lq-radius-sm);
	margin-bottom: 0.8em;
}
.lq-footer__logo--fallback img {
	display: block;
	max-height: 38px;
	width: auto;
	max-width: 180px;
	margin-bottom: 0;
}
.lq-footer__tagline {
	opacity: 0.8;
	max-width: 32ch;
}
.lq-footer__social {
	display: flex;
	gap: 0.8rem;
	margin-top: 1rem;
}
.lq-social-link {
	width: 38px;
	height: 38px;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 1px solid rgba(249, 250, 248, 0.25);
	border-radius: 50%;
	opacity: 1;
}
.lq-footer .lq-social-link:hover {
	background-color: var(--lq-yellow);
	border-color: var(--lq-yellow);
	color: var(--lq-primary);
}

.lq-footer-widget__title,
.lq-footer__col h3 {
	color: var(--lq-on-primary);
	font-size: 1.05rem;
}
.lq-footer__links {
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: 0.6em;
	font-size: 0.95rem;
}
.lq-footer__note {
	opacity: 0.8;
	font-size: 0.9rem;
}

.lq-footer__bottom {
	border-top: 1px solid rgba(249, 250, 248, 0.15);
	padding: 1.5rem 0;
}
.lq-footer__bottom-row {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	gap: 1rem;
}
.lq-footer__nav-list {
	list-style: none;
	display: flex;
	gap: 1.5rem;
	font-size: 0.9rem;
}
.lq-footer__copy {
	margin: 0;
	font-size: 0.85rem;
	opacity: 0.75;
}

/* --------------------------------------------------------------------------
   18. Ad slots
   -------------------------------------------------------------------------- */
.lq-ad-slot {
	border: 1px dashed var(--lq-bg-alt);
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	min-height: 90px;
}
.lq-ad-slot--header {
	min-height: 60px;
}

/* --------------------------------------------------------------------------
   19. 404 page
   -------------------------------------------------------------------------- */
.lq-404 {
	max-width: 600px;
	margin: 0 auto;
	padding: clamp(4rem, 10vw, 8rem) 0;
	text-align: center;
}
.lq-404__lead {
	color: var(--lq-text-muted);
}
.lq-404__search {
	max-width: 420px;
	margin: 0 auto 2rem;
}
.lq-404__links {
	display: flex;
	justify-content: center;
	gap: 1rem;
	flex-wrap: wrap;
}

/* --------------------------------------------------------------------------
   20. Contact page
   -------------------------------------------------------------------------- */
.lq-contact-hero {
	padding: clamp(3rem, 6vw, 5rem) 0 clamp(1.5rem, 3vw, 2rem);
	background-color: var(--lq-bg-soft);
	text-align: center;
}
.lq-contact-hero__row {
	display: flex;
	justify-content: center;
}
.lq-contact-hero__content {
	max-width: 680px;
}
.lq-contact-hero__lead {
	color: var(--lq-text-muted);
	font-size: 1.05rem;
}

.lq-contact-booking {
	padding: clamp(2rem, 5vw, 4rem) 0 clamp(3rem, 6vw, 6rem);
	background-color: var(--lq-bg-soft);
}

.lq-contact-info {
	padding: clamp(3rem, 6vw, 6rem) 0;
	background-color: var(--lq-bg-alt);
}
.lq-contact-info__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}
@media (min-width: 720px) {
	.lq-contact-info__grid {
		grid-template-columns: repeat(3, 1fr);
	}
}
.lq-contact-info__card {
	background-color: var(--lq-card);
	border-radius: var(--lq-radius-lg);
	padding: 2rem;
	text-align: center;
	box-shadow: var(--lq-shadow);
}
.lq-contact-info__icon {
	width: 56px;
	height: 56px;
	border-radius: 50%;
	background-color: var(--lq-bg-alt);
	color: var(--lq-primary);
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 1rem;
}
.lq-contact-info__card h3 {
	margin-bottom: 0.3em;
}
.lq-contact-info__card p {
	color: var(--lq-text-muted);
	margin: 0;
}
.lq-contact-info__card a {
	font-weight: 600;
}
.lq-contact-info__social {
	justify-content: center;
	margin-top: 1rem;
}
.lq-contact-info__social .lq-social-link {
	color: var(--lq-primary);
	border-color: var(--lq-bg-alt);
}
.lq-contact-info__social .lq-social-link:hover {
	background-color: var(--lq-primary);
	border-color: var(--lq-primary);
	color: var(--lq-on-primary);
}

/* Send a message form */
.lq-contact-form-section {
	padding: clamp(3rem, 6vw, 5rem) 0 clamp(3rem, 6vw, 6rem);
	background-color: var(--lq-blush);
}
.lq-contact-form-wrap {
	max-width: 720px;
	margin: 0 auto;
	background-color: var(--lq-card);
	border-radius: var(--lq-radius-lg);
	box-shadow: 0 12px 48px rgba(3, 50, 43, 0.1), 0 2px 8px rgba(3, 50, 43, 0.06);
	padding: clamp(2rem, 5vw, 3.5rem);
	border-top: 4px solid var(--lq-primary);
	position: relative;
	overflow: hidden;
}
.lq-contact-form-wrap::after {
	content: '';
	position: absolute;
	width: 220px;
	height: 220px;
	border-radius: 50%;
	background-color: var(--lq-bg-soft);
	top: -80px;
	right: -60px;
	pointer-events: none;
	z-index: 0;
}
.lq-contact-form {
	display: flex;
	flex-direction: column;
	gap: 1.4rem;
	position: relative;
	z-index: 1;
}
.lq-form-row {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.4rem;
}
@media (min-width: 560px) {
	.lq-form-row {
		grid-template-columns: 1fr 1fr;
	}
}
.lq-form-group {
	display: flex;
	flex-direction: column;
	gap: 0.45rem;
}
.lq-form-label {
	font-weight: 600;
	font-size: 0.85rem;
	color: var(--lq-primary);
	letter-spacing: 0.02em;
	text-transform: uppercase;
}
.lq-form-input,
.lq-form-select,
.lq-form-textarea {
	width: 100%;
	font-family: var(--lq-font-body);
	font-size: 1rem;
	color: var(--lq-text);
	background-color: var(--lq-bg-soft);
	border: 1.5px solid var(--lq-bg-alt);
	border-radius: var(--lq-radius-sm);
	padding: 0.85em 1.1em;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.lq-form-input:focus,
.lq-form-select:focus,
.lq-form-textarea:focus {
	outline: none;
	border-color: var(--lq-primary);
	box-shadow: 0 0 0 3px rgba(3, 50, 43, 0.1);
	background-color: var(--lq-card);
}
.lq-form-textarea {
	resize: vertical;
	min-height: 150px;
	line-height: 1.6;
}
.lq-form-select {
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	cursor: pointer;
	padding-right: 2.6em;
	background-repeat: no-repeat;
	background-position: right 1em center;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%2303322B' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
}
.lq-contact-form .lq-btn {
	align-self: stretch;
	text-align: center;
	justify-content: center;
	padding: 1em 2em;
	font-size: 1rem;
}
.lq-form-honeypot {
	position: absolute;
	left: -9999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
}
.lq-form-notice {
	margin-bottom: 1.5rem;
	padding: 1em 1.25em;
	border-radius: var(--lq-radius-sm);
	font-weight: 500;
	line-height: 1.5;
}
.lq-form-notice--success {
	background-color: var(--lq-sage);
	color: var(--lq-primary);
}
.lq-form-notice--error {
	background-color: var(--lq-blush);
	color: var(--lq-primary);
}
.lq-form-notice--error a {
	color: var(--lq-primary);
	font-weight: 600;
	text-decoration: underline;
}

/* --------------------------------------------------------------------------
   21. "Who this is for" — scenario cards
   -------------------------------------------------------------------------- */
.lq-for-you {
	padding: clamp(3rem, 6vw, 6rem) 0;
	background-color: var(--lq-bg-soft);
}
.lq-for-you__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.25rem;
	margin-top: clamp(2rem, 4vw, 3rem);
}
@media (min-width: 720px) {
	.lq-for-you__grid {
		grid-template-columns: repeat(3, 1fr);
	}
}
.lq-scenario-card {
	display: flex;
	flex-direction: column;
	padding: clamp(1.75rem, 3vw, 2.5rem);
	border-radius: var(--lq-radius-lg);
	border: 1.5px solid var(--lq-bg-alt);
	background-color: var(--lq-card);
	text-decoration: none;
	transition: transform 0.3s ease, box-shadow 0.3s ease, background-color 0.3s ease, border-color 0.3s ease;
}
.lq-scenario-card:hover {
	transform: translateY(-6px);
	box-shadow: var(--lq-shadow-hover);
	border-color: transparent;
}
.lq-scenario-card--1:hover { background-color: var(--lq-blush); }
.lq-scenario-card--2:hover { background-color: var(--lq-sage); }
.lq-scenario-card--3:hover { background-color: var(--lq-teal); }
.lq-scenario-card__num {
	font-family: var(--lq-font-heading);
	font-size: 4.5rem;
	font-weight: 700;
	font-style: italic;
	color: var(--lq-primary);
	opacity: 0.08;
	line-height: 1;
	margin-bottom: 0.25rem;
}
.lq-scenario-card__text {
	font-size: 1.05rem;
	color: var(--lq-text);
	line-height: 1.65;
	margin: 0 0 1.75rem;
	flex: 1;
}
.lq-scenario-card__cta {
	font-weight: 600;
	font-size: 0.9rem;
	color: var(--lq-primary);
	display: inline-flex;
	align-items: center;
	gap: 0.4em;
	margin-top: auto;
	transition: gap 0.2s ease;
}
.lq-scenario-card:hover .lq-scenario-card__cta {
	gap: 0.7em;
}

/* --------------------------------------------------------------------------
   22. Testimonials
   -------------------------------------------------------------------------- */
.lq-testimonials {
	background-color: var(--lq-primary);
	padding: clamp(4rem, 8vw, 7rem) 0;
	position: relative;
	overflow: hidden;
}
.lq-testimonials::before {
	content: '';
	position: absolute;
	width: 500px;
	height: 500px;
	border-radius: 50%;
	background-color: var(--lq-teal);
	opacity: 0.06;
	top: -200px;
	right: -150px;
	pointer-events: none;
}
.lq-testimonials::after {
	content: '';
	position: absolute;
	width: 380px;
	height: 380px;
	border-radius: 50%;
	background-color: var(--lq-yellow);
	opacity: 0.07;
	bottom: -160px;
	left: -120px;
	pointer-events: none;
}
.lq-section-heading--light h2 {
	color: var(--lq-on-primary);
}
.lq-section-heading--light .lq-section-heading__lead {
	color: rgba(249, 250, 248, 0.7);
}
.lq-eyebrow--gold {
	color: var(--lq-yellow);
	opacity: 1;
}
.lq-testimonials__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
	margin-top: clamp(2.5rem, 5vw, 3.5rem);
	position: relative;
	z-index: 1;
}
@media (min-width: 760px) {
	.lq-testimonials__grid {
		grid-template-columns: repeat(3, 1fr);
	}
}
.lq-testimonial {
	background-color: rgba(249, 250, 248, 0.06);
	border: 1px solid rgba(249, 250, 248, 0.12);
	border-radius: var(--lq-radius-lg);
	padding: clamp(1.75rem, 3vw, 2.25rem);
	position: relative;
	margin: 0;
	display: flex;
	flex-direction: column;
}
.lq-testimonial::before {
	content: '\201C';
	font-family: var(--lq-font-heading);
	font-size: 5rem;
	line-height: 0.8;
	color: var(--lq-yellow);
	opacity: 0.55;
	display: block;
	margin-bottom: 0.5rem;
}
.lq-testimonial__text {
	color: rgba(249, 250, 248, 0.9);
	font-size: 1rem;
	line-height: 1.75;
	font-style: italic;
	margin: 0 0 1.5rem;
	flex: 1;
}
.lq-testimonial__author {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	font-style: normal;
}
.lq-testimonial__author::before {
	content: '';
	display: block;
	width: 28px;
	height: 2px;
	background-color: var(--lq-yellow);
	flex-shrink: 0;
}
.lq-testimonial__author cite {
	font-size: 0.88rem;
	font-weight: 600;
	color: var(--lq-sage);
	font-style: normal;
}

/* --------------------------------------------------------------------------
   23. Final CTA (personal closing section)
   -------------------------------------------------------------------------- */
.lq-final-cta {
	background: linear-gradient(135deg, var(--lq-primary) 0%, var(--lq-primary-light) 100%);
	padding: clamp(4rem, 8vw, 7rem) 0;
	text-align: center;
	position: relative;
	overflow: hidden;
}
.lq-final-cta__inner {
	position: relative;
	z-index: 1;
	max-width: 720px;
	margin: 0 auto;
}
.lq-final-cta__decor {
	position: absolute;
	width: 600px;
	height: 600px;
	border-radius: 50%;
	border: 1px solid rgba(191, 213, 199, 0.12);
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	pointer-events: none;
}
.lq-final-cta__title {
	color: var(--lq-on-primary);
	font-size: clamp(2rem, 4vw, 3rem);
	font-weight: 700;
	line-height: 1.2;
	margin-bottom: 1rem;
}
.lq-final-cta__title span {
	color: var(--lq-yellow);
}
.lq-final-cta__lead {
	color: rgba(249, 250, 248, 0.8);
	font-size: 1.1rem;
	max-width: 52ch;
	margin: 0 auto 2.5rem;
	line-height: 1.75;
}
.lq-final-cta__actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 1rem;
	margin-bottom: 2rem;
}
.lq-final-cta__sig {
	font-family: var(--lq-font-heading);
	font-style: italic;
	color: var(--lq-sage);
	font-size: 1.1rem;
	margin: 0;
	opacity: 0.85;
}

/* --------------------------------------------------------------------------
   25. Scroll & page-load animations
   -------------------------------------------------------------------------- */
@keyframes lq-fade-up {
	from { opacity: 0; transform: translateY(24px); }
	to   { opacity: 1; transform: none; }
}
@keyframes lq-fade-right {
	from { opacity: 0; transform: translateX(32px); }
	to   { opacity: 1; transform: none; }
}
@keyframes lq-fade-in {
	from { opacity: 0; }
	to   { opacity: 1; }
}
@keyframes lq-hero-zoom {
	from { transform: scale(1.08); }
	to   { transform: scale(1); }
}

@media (prefers-reduced-motion: no-preference) {
	/* Hero (poster) — staged reveal on page load */
	.lq-hero__photo {
		animation: lq-hero-zoom 9s ease-out 0.1s both;
	}
	.lq-hero__eyebrow {
		animation: lq-fade-up 0.7s cubic-bezier(0.22, 1, 0.36, 1) 0.25s both;
	}
	.lq-hero__headline {
		animation: lq-fade-up 0.8s cubic-bezier(0.22, 1, 0.36, 1) 0.4s both;
	}
	.lq-hero__sub {
		animation: lq-fade-up 0.8s cubic-bezier(0.22, 1, 0.36, 1) 0.55s both;
	}
	.lq-hero__cta {
		animation: lq-fade-up 0.8s cubic-bezier(0.22, 1, 0.36, 1) 0.7s both;
	}
	.lq-hero__proof {
		animation: lq-fade-in 0.7s ease 0.95s both;
	}
	.lq-hero__scroll {
		animation: lq-fade-in 0.7s ease 1.2s both;
	}

	/* Legacy split-hero (kept for any inner pages still using it) */
	.lq-hero__content {
		animation: lq-fade-up 0.7s cubic-bezier(0.22, 1, 0.36, 1) 0.1s both;
	}
	.lq-hero__frame {
		animation: lq-fade-right 0.75s cubic-bezier(0.22, 1, 0.36, 1) 0.35s both;
	}
	.lq-hero__badge {
		animation: lq-fade-in 0.55s ease 0.85s both;
	}

	/* Scroll-reveal — JS adds .lq-reveal, then .lq-reveal--visible on intersection */
	.lq-reveal {
		opacity: 0;
		transform: translateY(30px);
		transition:
			opacity 0.65s cubic-bezier(0.22, 1, 0.36, 1) var(--lq-reveal-delay, 0s),
			transform 0.65s cubic-bezier(0.22, 1, 0.36, 1) var(--lq-reveal-delay, 0s);
	}
	.lq-reveal--visible {
		opacity: 1;
		transform: none;
	}
}

/* --------------------------------------------------------------------------
   26. About page — hero enhancements
   -------------------------------------------------------------------------- */
.lq-about-hero__highlight {
	display: inline;
	background-image: linear-gradient(transparent 60%, var(--lq-yellow) 60%);
	box-decoration-break: clone;
	-webkit-box-decoration-break: clone;
}
.lq-about-hero__cta {
	margin-top: 2rem;
}

/* --------------------------------------------------------------------------
   27. Contact page — redesigned hero & steps strip
   -------------------------------------------------------------------------- */
.lq-contact-hero {
	/* Overrides the plain bg-soft from section 20 — dark premium hero */
	position: relative;
	overflow: hidden;
	padding: clamp(4rem, 8vw, 7rem) 0 clamp(3rem, 6vw, 5rem);
	background: linear-gradient(135deg, var(--lq-primary) 0%, var(--lq-primary-light) 100%);
	text-align: center;
}
.lq-contact-hero__blob {
	position: absolute;
	border-radius: 50%;
	pointer-events: none;
	filter: blur(40px);
}
.lq-contact-hero__blob--1 {
	width: 480px;
	height: 480px;
	background-color: var(--lq-teal);
	opacity: 0.18;
	top: -200px;
	right: -120px;
}
.lq-contact-hero__blob--2 {
	width: 320px;
	height: 320px;
	background-color: var(--lq-yellow);
	opacity: 0.12;
	bottom: -140px;
	left: -80px;
}
.lq-contact-hero__inner {
	position: relative;
	z-index: 1;
	max-width: 720px;
	margin: 0 auto;
}
.lq-contact-hero__inner h1 {
	color: var(--lq-on-primary);
	font-size: clamp(2.4rem, 5.5vw, 4rem);
	font-weight: 700;
	line-height: 1.12;
	letter-spacing: -0.02em;
	margin-bottom: 1.25rem;
}
.lq-contact-hero__inner h1 span {
	font-family: var(--lq-font-heading);
	font-style: italic;
	font-weight: 500;
	color: var(--lq-yellow);
}
.lq-contact-hero__lead {
	color: rgba(249, 250, 248, 0.85);
	font-size: 1.1rem;
	line-height: 1.7;
	max-width: 52ch;
	margin-left: auto;
	margin-right: auto;
}
.lq-contact-hero__trust {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0.75rem;
	margin-top: 2rem;
}
.lq-contact-trust-pill {
	display: inline-flex;
	align-items: center;
	gap: 0.5em;
	background-color: rgba(249, 250, 248, 0.1);
	border: 1px solid rgba(249, 250, 248, 0.2);
	border-radius: 999px;
	padding: 0.55em 1.15em;
	font-size: 0.88rem;
	font-weight: 500;
	color: var(--lq-on-primary);
}
.lq-contact-trust-pill svg {
	color: var(--lq-yellow);
	flex-shrink: 0;
}

/* Steps strip — light cards (sits below the dark hero) */
.lq-contact-steps {
	background-color: var(--lq-bg-soft);
	padding: clamp(3rem, 6vw, 4.5rem) 0;
}
.lq-contact-steps__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}
@media (min-width: 720px) {
	.lq-contact-steps__grid {
		grid-template-columns: repeat(3, 1fr);
	}
}
.lq-contact-step {
	background-color: var(--lq-card);
	border-radius: var(--lq-radius-lg);
	box-shadow: var(--lq-shadow);
	padding: clamp(1.5rem, 3vw, 2.2rem);
	border-top: 4px solid var(--lq-sage);
}
.lq-contact-steps__grid > .lq-contact-step:nth-child(2) { border-top-color: var(--lq-yellow); }
.lq-contact-steps__grid > .lq-contact-step:nth-child(3) { border-top-color: var(--lq-teal); }
.lq-contact-step__num {
	display: block;
	font-family: var(--lq-font-heading);
	font-size: 2.6rem;
	font-weight: 700;
	font-style: italic;
	color: var(--lq-primary);
	opacity: 0.18;
	line-height: 1;
	margin-bottom: 0.5rem;
}
.lq-contact-step h3 {
	color: var(--lq-primary);
	font-size: 1.1rem;
	margin-bottom: 0.5rem;
}
.lq-contact-step p {
	color: var(--lq-text-muted);
	font-size: 0.95rem;
	margin: 0;
	line-height: 1.6;
}

/* --------------------------------------------------------------------------
   28. Foundation page — hero card, impact strip
   -------------------------------------------------------------------------- */
.lq-found-hero__visual {
	position: relative;
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}
.lq-found-hero__img-wrap {
	position: relative;
	isolation: isolate;
}
.lq-found-hero__img-wrap::after {
	content: '';
	position: absolute;
	bottom: -12px;
	left: -12px;
	width: 50%;
	height: 50%;
	border-radius: var(--lq-radius-lg);
	background-color: var(--lq-yellow);
	opacity: 0.55;
	z-index: -1;
}
.lq-found-hero__img-wrap .lq-img-clip {
	position: relative;
	z-index: 1;
	overflow: hidden;
	border-radius: var(--lq-radius-lg);
	box-shadow: 0 16px 40px rgba(3, 50, 43, 0.16);
}
.lq-found-hero__img-wrap img {
	display: block;
	width: 100%;
	aspect-ratio: 16/10;
	object-fit: cover;
}
.lq-found-hero__card {
	background: var(--lq-card);
	border-radius: var(--lq-radius-lg);
	padding: clamp(1.75rem, 3vw, 2.5rem);
	box-shadow: var(--lq-shadow-hover);
	position: relative;
	z-index: 1;
}
.lq-found-hero__card-top {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	margin-bottom: 1.5rem;
}
.lq-found-hero__card-badge {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background-color: var(--lq-yellow);
	color: var(--lq-primary);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.lq-found-hero__card-label {
	font-size: 0.8rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--lq-text-muted);
	line-height: 1.4;
}
.lq-found-hero__card-stats {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1.25rem;
	margin-bottom: 1.5rem;
	padding-bottom: 1.5rem;
	border-bottom: 1px solid var(--lq-bg-alt);
}
.lq-found-hero__stat-num {
	display: block;
	font-family: var(--lq-font-heading);
	font-size: clamp(1.3rem, 2.5vw, 1.75rem);
	font-weight: 700;
	color: var(--lq-primary);
	line-height: 1.2;
}
.lq-found-hero__stat-label {
	display: block;
	font-size: 0.8rem;
	color: var(--lq-text-muted);
	line-height: 1.4;
	margin-top: 0.2em;
}
.lq-found-hero__card-quote {
	margin: 0;
	font-family: var(--lq-font-heading);
	font-style: italic;
	font-size: 0.95rem;
	color: var(--lq-primary);
	line-height: 1.65;
	opacity: 0.75;
}
.lq-found-hero__ring {
	position: absolute;
	width: 260px;
	height: 260px;
	border-radius: 50%;
	border: 2px dashed var(--lq-sage);
	bottom: -90px;
	right: -90px;
	opacity: 0.45;
	z-index: 0;
}

/* Impact stats strip */
.lq-found-impact {
	background-color: var(--lq-yellow);
	padding: clamp(2.5rem, 5vw, 4rem) 0;
}
.lq-found-impact__grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 2rem;
	text-align: center;
}
@media (min-width: 720px) {
	.lq-found-impact__grid {
		grid-template-columns: repeat(4, 1fr);
	}
}
.lq-found-impact__item {
	display: flex;
	flex-direction: column;
	align-items: center;
}
.lq-found-impact__num {
	font-family: var(--lq-font-heading);
	font-size: clamp(1.4rem, 2.5vw, 2rem);
	font-weight: 700;
	color: var(--lq-primary);
	line-height: 1.2;
	margin-bottom: 0.4rem;
}
.lq-found-impact__label {
	font-size: 0.85rem;
	color: var(--lq-primary);
	opacity: 0.65;
	line-height: 1.5;
	max-width: 18ch;
}

/* --------------------------------------------------------------------------
   29. Single post — post banner & post-end CTA
   -------------------------------------------------------------------------- */
.lq-post-banner {
	background: linear-gradient(135deg, var(--lq-bg-alt) 0%, var(--lq-blush) 100%);
	padding: clamp(3rem, 6vw, 5rem) 0 clamp(2rem, 4vw, 3rem);
	border-bottom: 1px solid rgba(3, 50, 43, 0.07);
}
.lq-post-banner__inner {
	max-width: 800px;
}
.lq-post-banner__cat {
	display: inline-block;
	background-color: var(--lq-primary);
	color: var(--lq-on-primary);
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	padding: 0.35em 0.9em;
	border-radius: 999px;
	margin-bottom: 1rem;
	transition: background-color 0.2s ease;
}
.lq-post-banner__cat:hover {
	background-color: var(--lq-primary-light);
	color: var(--lq-on-primary);
}
.lq-post-banner__title {
	font-size: clamp(1.8rem, 4vw, 3rem);
	font-weight: 700;
	line-height: 1.2;
	color: var(--lq-primary);
	margin-bottom: 1rem;
}
.lq-post-banner__meta {
	color: var(--lq-text-muted);
	font-size: 0.9rem;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.35em;
}
.lq-post-banner__sep {
	opacity: 0.45;
}

/* Post-end CTA */
.lq-post-end-cta {
	background: linear-gradient(135deg, var(--lq-primary) 0%, var(--lq-primary-light) 100%);
	padding: clamp(3.5rem, 7vw, 6rem) 0;
	text-align: center;
	position: relative;
	overflow: hidden;
}
.lq-post-end-cta__decor {
	position: absolute;
	width: 420px;
	height: 420px;
	border-radius: 50%;
	background-color: var(--lq-teal);
	opacity: 0.06;
	top: -170px;
	right: -120px;
	pointer-events: none;
}
.lq-post-end-cta__inner {
	position: relative;
	z-index: 1;
	max-width: 640px;
	margin: 0 auto;
}
.lq-post-end-cta__inner h2 {
	font-size: clamp(1.6rem, 3.5vw, 2.5rem);
	color: var(--lq-on-primary);
	font-weight: 700;
	line-height: 1.25;
	margin-bottom: 1rem;
}
.lq-post-end-cta__inner h2 span {
	color: var(--lq-yellow);
}
.lq-post-end-cta__inner p {
	color: rgba(249, 250, 248, 0.8);
	font-size: 1.05rem;
	line-height: 1.75;
	max-width: 50ch;
	margin: 0 auto 2rem;
}
.lq-btn--on-dark {
	background-color: var(--lq-yellow);
	color: var(--lq-primary);
	font-weight: 700;
	padding: 0.9em 2.2em;
	border-radius: var(--lq-radius-md);
	display: inline-block;
	transition: transform 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}
.lq-btn--on-dark:hover {
	background-color: #f5d08a;
	transform: translateY(-2px);
	box-shadow: 0 8px 24px rgba(3, 50, 43, 0.35);
	color: var(--lq-primary);
}

/* --------------------------------------------------------------------------
   30. Archive banner
   -------------------------------------------------------------------------- */
.lq-archive-banner {
	background: linear-gradient(135deg, var(--lq-primary) 0%, var(--lq-primary-light) 100%);
	padding: clamp(3rem, 6vw, 5rem) 0 clamp(2rem, 4vw, 3.5rem);
	position: relative;
	overflow: hidden;
}
.lq-archive-banner__ring {
	position: absolute;
	width: 420px;
	height: 420px;
	border-radius: 50%;
	border: 1px solid rgba(191, 213, 199, 0.15);
	top: -160px;
	right: -100px;
	pointer-events: none;
}
.lq-archive-banner__inner {
	max-width: 700px;
	position: relative;
	z-index: 1;
}
.lq-archive-banner__title {
	font-size: clamp(1.8rem, 4vw, 3rem);
	color: var(--lq-on-primary);
	font-weight: 700;
	line-height: 1.2;
	margin-bottom: 0.5rem;
}
.lq-archive-banner__desc {
	color: rgba(249, 250, 248, 0.75);
	font-size: 1.05rem;
	margin: 0;
}
.lq-archive-controls {
	display: flex;
	justify-content: flex-end;
	margin-bottom: 2rem;
}
@media (max-width: 640px) {
	.lq-archive-controls {
		justify-content: flex-start;
	}
}

/* --------------------------------------------------------------------------
   31. Blog page & single post — mobile responsiveness
   -------------------------------------------------------------------------- */

@media (max-width: 767px) {
	/* Reduce general container gap for mobile blog layouts */
	.lq-layout {
		padding: 1.5rem 0;
		gap: 1.5rem;
	}

	/* Post card — cap image height on mobile and tighten body padding */
	.lq-post-card__media .lq-img,
	.lq-post-card__media img {
		max-height: 200px;
		object-fit: cover;
	}
	.lq-post-card__body {
		padding: 1.25rem;
	}
	.lq-post-card__title {
		font-size: 1.2rem;
	}
	
	/* Tighter grids */
	.lq-archive__grid {
		gap: 1.25rem;
	}

	/* Blog archive banner — tighter on mobile */
	.lq-archive-banner {
		padding: 2.5rem 0 2rem;
	}
	.lq-archive-banner__title {
		font-size: clamp(1.6rem, 7vw, 2.2rem);
	}

	/* Archive controls — full-width select on mobile */
	.lq-archive-controls {
		margin-bottom: 1.25rem;
	}
	.lq-category-filter,
	.lq-category-filter__select {
		width: 100%;
	}

	/* Single post — banner adjustments on mobile */
	.lq-post-banner {
		padding: 2rem 0 1.5rem;
	}
	.lq-post-banner__title {
		font-size: clamp(1.4rem, 6.5vw, 2.2rem);
		word-break: break-word;
	}
	.lq-post-banner__meta {
		font-size: 0.85rem;
		gap: 0.4em;
	}

	/* Single post — content adjustments */
	.lq-single__content.lq-prose {
		font-size: 1rem; /* Slightly smaller text for better reading on mobile */
		line-height: 1.65;
	}
	
	/* Full bleed featured image on mobile */
	.lq-single__thumb {
		margin: 0 calc(-1 * clamp(1.5rem, 5vw, 2.5rem)) 1.5rem;
		border-radius: 0;
	}
	.lq-single__thumb img {
		border-radius: 0;
		width: 100%;
	}

	/* Author box stacks on mobile */
	.lq-author-box {
		flex-direction: column;
		align-items: center;
		text-align: center;
		gap: 1rem;
		padding: 1.5rem 1rem;
		margin-top: 2rem;
	}
	.lq-author-box__avatar img {
		width: 80px;
		height: 80px;
	}

	/* Post nav wraps gracefully and adds background for touch targets */
	.lq-post-nav {
		flex-direction: column;
		gap: 0.8rem;
		border: none;
		padding-top: 0;
	}
	.lq-post-nav__prev,
	.lq-post-nav__next {
		background-color: var(--lq-bg-alt);
		border-radius: var(--lq-radius-sm);
		padding: 0.8rem 1rem;
		text-align: center;
		width: 100%;
	}
	.lq-post-nav__prev a,
	.lq-post-nav__next a {
		display: block;
		width: 100%;
	}

	/* Post-end CTA tightens on mobile */
	.lq-post-end-cta {
		padding: 2.5rem 0;
	}
	.lq-post-end-cta__inner h2 {
		font-size: clamp(1.4rem, 6vw, 1.8rem);
	}
	.lq-post-end-cta__decor {
		display: none; /* Hide decor on mobile to save performance and space */
	}
}

/* Single post — author box on very narrow screens */
@media (max-width: 480px) {
	.lq-author-box__avatar img {
		width: 64px;
		height: 64px;
	}
}

/* Layout — remove excessive top gap directly after banners */
.lq-archive-banner + .lq-container,
.lq-post-banner + .lq-container {
	padding-top: var(--lq-gap);
}

/* Sidebar — hide on mobile if empty (no widgets added yet) */
.lq-sidebar:empty {
	display: none;
}

/* Prose images — constrain within the content column */
.lq-prose img {
	max-width: 100%;
	height: auto;
}

/* Tags — allow graceful wrapping on narrow screens */
.lq-single__tags {
	row-gap: 0.5rem;
}
.lq-tag {
	white-space: nowrap;
}

/* Prevent any element from causing a horizontal scrollbar */
html,
body {
	overflow-x: hidden;
}

/* Blog / archive — give the content zone a coloured tray on mobile so the
   side padding reads as visible space rather than blending into the page. */
@media (max-width: 767px) {
	.lq-archive-banner ~ .lq-container.lq-layout,
	.lq-post-banner ~ .lq-container.lq-layout {
		background-color: var(--lq-bg-alt);
		padding-top: 1.5rem;
		padding-bottom: 2rem;
		padding-left: 1rem;
		padding-right: 1rem;
	}
	/* Cards keep their white background so they visually float on the tray */
	.lq-post-card {
		background-color: var(--lq-card);
	}
	/* Sidebar widgets blend into the tray */
	.lq-sidebar .lq-widget {
		background-color: var(--lq-card);
	}
}

/* Post card titles — break long words cleanly */
.lq-post-card__title,
.lq-post-banner__title {
	overflow-wrap: break-word;
	word-break: break-word;
}

/* Archive grid — never collapse to zero gap on any screen */
.lq-archive__grid {
	gap: clamp(1rem, 3vw, 2rem);
}

/* Single post — prose max-width keeps long text readable */
.lq-single__content.lq-prose {
	max-width: 72ch;
}

/* ==========================================================================
   32. Service pages (Work With Me hub + Coaching/Counselling/Speaking/Workshops)
   ========================================================================== */
.lq-svc-hero {
	position: relative;
	overflow: hidden;
	padding: clamp(3.5rem, 7vw, 6rem) 0;
	background: linear-gradient(135deg, var(--lq-blush) 0%, var(--lq-bg-soft) 60%);
}
.lq-svc-hero__glow {
	position: absolute;
	width: 460px;
	height: 460px;
	border-radius: 50%;
	background-color: var(--lq-teal);
	opacity: 0.18;
	filter: blur(60px);
	top: -180px;
	right: -120px;
	pointer-events: none;
}
.lq-svc-hero--coaching .lq-svc-hero__glow { background-color: var(--lq-teal); }
.lq-svc-hero--counselling .lq-svc-hero__glow { background-color: var(--lq-sage); }
.lq-svc-hero--speaking .lq-svc-hero__glow { background-color: var(--lq-yellow); opacity: 0.28; }
.lq-svc-hero--workshops .lq-svc-hero__glow { background-color: var(--lq-sage); }
.lq-svc-hero--hub .lq-svc-hero__glow { background-color: var(--lq-yellow); opacity: 0.22; }

.lq-svc-hero__row {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(2rem, 4vw, 3.5rem);
	align-items: center;
}
@media (min-width: 900px) {
	.lq-svc-hero__row {
		grid-template-columns: 1.15fr 0.85fr;
	}
}
.lq-svc-hero__inner {
	position: relative;
	z-index: 1;
}
.lq-svc-hero__inner--center {
	max-width: 760px;
	margin: 0 auto;
	text-align: center;
}
.lq-svc-hero__inner h1 {
	font-size: clamp(2.2rem, 5vw, 3.6rem);
	line-height: 1.1;
	margin-bottom: 1rem;
}
.lq-svc-hero__lead {
	color: var(--lq-text-muted);
	font-size: 1.1rem;
	line-height: 1.7;
	max-width: 56ch;
}
.lq-svc-hero__inner--center .lq-svc-hero__lead {
	margin-left: auto;
	margin-right: auto;
}
.lq-svc-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	margin-top: 2rem;
}
/* Right-column wrapper: framed image on top, facts card below */
.lq-svc-hero__aside {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

/* Decorative image frame with offset accent block */
.lq-svc-hero__img-wrap {
	position: relative;
	isolation: isolate;
}
.lq-svc-hero__img-wrap::after {
	content: '';
	position: absolute;
	bottom: -12px;
	right: -12px;
	width: 50%;
	height: 50%;
	border-radius: var(--lq-radius-lg);
	background-color: var(--lq-yellow);
	opacity: 0.6;
	z-index: -1;
}
.lq-svc-hero__img-wrap .lq-img-clip {
	position: relative;
	z-index: 1;
	overflow: hidden;
	border-radius: var(--lq-radius-lg);
	box-shadow: 0 16px 40px rgba(3, 50, 43, 0.16);
}
.lq-svc-hero__img-wrap img {
	display: block;
	width: 100%;
	aspect-ratio: 16/10;
	object-fit: cover;
}

.lq-svc-hero__card {
	background: linear-gradient(160deg, var(--lq-primary) 0%, var(--lq-primary-light) 100%);
	color: var(--lq-on-primary);
	border-radius: var(--lq-radius-lg);
	padding: clamp(1.75rem, 3vw, 2.5rem);
	box-shadow: var(--lq-shadow-hover);
}
.lq-svc-hero__card-title {
	font-family: var(--lq-font-body);
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--lq-yellow);
	margin: 0 0 1.25rem;
}
.lq-svc-facts {
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 1rem;
}
.lq-svc-facts > div {
	display: flex;
	flex-direction: column;
	gap: 0.15rem;
	padding-bottom: 1rem;
	border-bottom: 1px solid rgba(249, 250, 248, 0.15);
}
.lq-svc-facts > div:last-child {
	padding-bottom: 0;
	border-bottom: none;
}
.lq-svc-facts dt {
	font-size: 0.72rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--lq-sage);
}
.lq-svc-facts dd {
	margin: 0;
	font-family: var(--lq-font-heading);
	font-size: 1.1rem;
	color: var(--lq-on-primary);
}

/* Service content sections */
.lq-svc-section {
	padding: clamp(3rem, 6vw, 5.5rem) 0;
}
.lq-svc-section--alt {
	background-color: var(--lq-bg-alt);
}
.lq-svc-points {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: 1rem;
	max-width: 880px;
	margin: 0 auto;
}
@media (min-width: 680px) {
	.lq-svc-points {
		grid-template-columns: 1fr 1fr;
	}
}
.lq-svc-points li {
	position: relative;
	padding: 1.1rem 1.25rem 1.1rem 3.2rem;
	background-color: var(--lq-card);
	border-radius: var(--lq-radius-md);
	box-shadow: var(--lq-shadow);
	font-size: 1rem;
	line-height: 1.55;
}
.lq-svc-points li::before {
	content: '';
	position: absolute;
	left: 1.1rem;
	top: 1.2rem;
	width: 22px;
	height: 22px;
	border-radius: 50%;
	background-color: var(--lq-sage);
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none'%3E%3Cpath d='M20 6L9 17l-5-5' stroke='%2303322B' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: center;
}
.lq-svc-cards {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}
@media (min-width: 760px) {
	.lq-svc-cards {
		grid-template-columns: repeat(3, 1fr);
	}
}
.lq-svc-card {
	background-color: var(--lq-card);
	border-radius: var(--lq-radius-lg);
	padding: clamp(1.5rem, 3vw, 2.2rem);
	box-shadow: var(--lq-shadow);
	border-top: 4px solid var(--lq-sage);
}
.lq-svc-card h3 {
	margin-bottom: 0.5rem;
}
.lq-svc-card p {
	color: var(--lq-text-muted);
	margin: 0;
	font-size: 0.97rem;
	line-height: 1.6;
}
.lq-svc-card__badge {
	display: inline-block;
	background-color: var(--lq-yellow);
	color: var(--lq-primary);
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	padding: 0.3em 0.8em;
	border-radius: 999px;
	margin-bottom: 0.9rem;
}
.lq-svc-note {
	text-align: center;
	color: var(--lq-text-muted);
	font-style: italic;
	margin: 2rem auto 0;
	max-width: 52ch;
}
.lq-svc-quote {
	padding: clamp(3rem, 6vw, 5rem) 0;
	background-color: var(--lq-blush);
}
.lq-svc-quote blockquote {
	max-width: 800px;
	margin: 0 auto;
	text-align: center;
}
.lq-svc-quote p {
	font-family: var(--lq-font-heading);
	font-style: italic;
	font-size: clamp(1.3rem, 2.6vw, 1.9rem);
	line-height: 1.5;
	color: var(--lq-primary);
	margin-bottom: 1.25rem;
}
.lq-svc-quote cite {
	font-style: normal;
	font-weight: 600;
	color: var(--lq-text-muted);
	font-size: 0.95rem;
}

/* Shared dark CTA band (services, resources, testimonials) */
.lq-svc-cta {
	background: linear-gradient(135deg, var(--lq-primary) 0%, var(--lq-primary-light) 100%);
	padding: clamp(3.5rem, 7vw, 6rem) 0;
	text-align: center;
	position: relative;
	overflow: hidden;
}
.lq-svc-cta__decor {
	position: absolute;
	width: 460px;
	height: 460px;
	border-radius: 50%;
	background-color: var(--lq-teal);
	opacity: 0.07;
	top: -180px;
	left: -120px;
	pointer-events: none;
}
.lq-svc-cta__inner {
	position: relative;
	z-index: 1;
	max-width: 620px;
	margin: 0 auto;
}
.lq-svc-cta__inner h2 {
	color: var(--lq-on-primary);
	font-size: clamp(1.6rem, 3.5vw, 2.4rem);
	margin-bottom: 1rem;
}
.lq-svc-cta__inner p {
	color: rgba(249, 250, 248, 0.82);
	font-size: 1.05rem;
	line-height: 1.7;
	margin: 0 auto 2rem;
	max-width: 48ch;
}

/* Process steps (hub + service pages) */
.lq-process {
	padding: clamp(3rem, 6vw, 5.5rem) 0;
}
.lq-process__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}
@media (min-width: 760px) {
	.lq-process__grid {
		grid-template-columns: repeat(3, 1fr);
	}
}
.lq-process__step {
	background-color: var(--lq-card);
	border-radius: var(--lq-radius-lg);
	padding: clamp(1.5rem, 3vw, 2.2rem);
	box-shadow: var(--lq-shadow);
	position: relative;
}
.lq-process__num {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 46px;
	height: 46px;
	border-radius: 50%;
	background-color: var(--lq-primary);
	color: var(--lq-on-primary);
	font-family: var(--lq-font-heading);
	font-size: 1.3rem;
	font-weight: 700;
	margin-bottom: 1rem;
}
.lq-process__step h3 {
	margin-bottom: 0.4rem;
}
.lq-process__step p {
	color: var(--lq-text-muted);
	margin: 0;
	font-size: 0.97rem;
	line-height: 1.6;
}

/* Work With Me hub — the four paths */
.lq-paths {
	padding: clamp(3rem, 6vw, 5.5rem) 0;
	background-color: var(--lq-bg-soft);
}
.lq-paths__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}
@media (min-width: 720px) {
	.lq-paths__grid {
		grid-template-columns: 1fr 1fr;
	}
}
.lq-path-card {
	position: relative;
	display: flex;
	flex-direction: column;
	padding: clamp(1.75rem, 3vw, 2.5rem);
	background-color: var(--lq-card);
	border-radius: var(--lq-radius-lg);
	border: 1.5px solid var(--lq-bg-alt);
	box-shadow: var(--lq-shadow);
	overflow: hidden;
	transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
}
.lq-path-card:hover {
	transform: translateY(-6px);
	box-shadow: var(--lq-shadow-hover);
	border-color: transparent;
}
.lq-path-card__num {
	position: absolute;
	top: 0.5rem;
	right: 1.25rem;
	font-family: var(--lq-font-heading);
	font-style: italic;
	font-size: 4.5rem;
	font-weight: 700;
	color: var(--lq-primary);
	opacity: 0.06;
	line-height: 1;
}
.lq-path-card__icon {
	width: 56px;
	height: 56px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--lq-primary);
	margin-bottom: 1.1rem;
}
.lq-path-card--1 .lq-path-card__icon { background-color: var(--lq-teal); }
.lq-path-card--2 .lq-path-card__icon { background-color: var(--lq-blush); }
.lq-path-card--3 .lq-path-card__icon { background-color: var(--lq-yellow); }
.lq-path-card--4 .lq-path-card__icon { background-color: var(--lq-sage); }
.lq-path-card__title {
	margin-bottom: 0.5rem;
}
.lq-path-card__desc {
	color: var(--lq-text-muted);
	font-size: 0.98rem;
	line-height: 1.6;
	flex: 1;
	margin-bottom: 1.25rem;
}
.lq-path-card__cta {
	font-weight: 600;
	font-size: 0.92rem;
	color: var(--lq-primary);
	display: inline-flex;
	align-items: center;
	gap: 0.4em;
	transition: gap 0.2s ease;
}
.lq-path-card:hover .lq-path-card__cta {
	gap: 0.75em;
}

/* ==========================================================================
   33. Resources page
   ========================================================================== */
.lq-res-hero {
	position: relative;
	overflow: hidden;
	padding: clamp(3.5rem, 7vw, 6rem) 0 clamp(2.5rem, 5vw, 4rem);
	background: linear-gradient(135deg, var(--lq-primary) 0%, var(--lq-primary-light) 100%);
	text-align: center;
}
.lq-res-hero__glow {
	position: absolute;
	width: 480px;
	height: 480px;
	border-radius: 50%;
	background-color: var(--lq-teal);
	opacity: 0.12;
	top: -200px;
	right: -120px;
	pointer-events: none;
}
.lq-res-hero__inner {
	position: relative;
	z-index: 1;
	max-width: 720px;
	margin: 0 auto;
}
.lq-res-hero__inner h1 {
	color: var(--lq-on-primary);
	font-size: clamp(2.2rem, 5vw, 3.4rem);
	margin-bottom: 1rem;
}
.lq-res-hero__lead {
	color: rgba(249, 250, 248, 0.82);
	font-size: 1.1rem;
	line-height: 1.7;
	margin: 0 auto 2rem;
	max-width: 52ch;
}
.lq-res-nav {
	display: inline-flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0.6rem;
}
.lq-res-nav__link {
	color: var(--lq-on-primary);
	font-size: 0.88rem;
	font-weight: 600;
	padding: 0.5em 1.2em;
	border-radius: 999px;
	border: 1px solid rgba(249, 250, 248, 0.3);
	transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}
.lq-res-nav__link:hover {
	background-color: var(--lq-yellow);
	border-color: var(--lq-yellow);
	color: var(--lq-primary);
}

.lq-res-section {
	padding: clamp(3rem, 6vw, 5rem) 0;
}
.lq-res-section--alt {
	background-color: var(--lq-bg-alt);
}
.lq-res-head {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 1rem;
	flex-wrap: wrap;
	margin-bottom: 2rem;
}
.lq-res-head h2 {
	margin: 0;
}
.lq-res-head__link {
	font-weight: 600;
	font-size: 0.92rem;
	color: var(--lq-primary);
	white-space: nowrap;
}
.lq-res-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}
@media (min-width: 640px) {
	.lq-res-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}
@media (min-width: 920px) {
	.lq-res-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

/* Video cards */
.lq-res-card {
	display: flex;
	flex-direction: column;
	background-color: var(--lq-card);
	border-radius: var(--lq-radius-lg);
	overflow: hidden;
	box-shadow: var(--lq-shadow);
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.lq-res-card:hover {
	transform: translateY(-5px);
	box-shadow: var(--lq-shadow-hover);
}
.lq-res-card__media {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	aspect-ratio: 16 / 9;
	background: linear-gradient(135deg, var(--lq-sage) 0%, var(--lq-teal) 100%);
}
.lq-res-card__play {
	width: 54px;
	height: 54px;
	border-radius: 50%;
	background-color: var(--lq-card);
	color: var(--lq-primary);
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: var(--lq-shadow);
	transition: transform 0.25s ease;
}
.lq-res-card:hover .lq-res-card__play {
	transform: scale(1.08);
}
.lq-res-card__body {
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
	padding: 1.4rem;
}
.lq-res-card__kicker {
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--lq-text-muted);
}
.lq-res-card__title {
	font-family: var(--lq-font-heading);
	font-size: 1.15rem;
	font-weight: 600;
	color: var(--lq-primary);
	line-height: 1.3;
}
.lq-res-card__meta {
	font-size: 0.85rem;
	color: var(--lq-text-muted);
}

/* Course cards */
.lq-res-card--course {
	padding: clamp(1.5rem, 3vw, 2.2rem);
}
.lq-res-card--course .lq-res-card__kicker {
	color: var(--lq-primary);
	opacity: 0.65;
	margin-bottom: 0.6rem;
}
.lq-res-card__desc {
	color: var(--lq-text-muted);
	font-size: 0.97rem;
	line-height: 1.6;
	margin: 0.3rem 0 1rem;
	flex: 1;
}
.lq-res-card__foot {
	font-size: 0.82rem;
	color: var(--lq-text-muted);
	margin-bottom: 1.25rem;
}
.lq-res-card__btn {
	align-self: flex-start;
}

/* Ebook covers */
.lq-res-grid--books {
	gap: 2rem;
}
.lq-res-book {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 0.3rem;
}
.lq-res-book__cover {
	position: relative;
	width: 100%;
	max-width: 200px;
	aspect-ratio: 3 / 4;
	border-radius: 6px 10px 10px 6px;
	background: linear-gradient(135deg, var(--lq-primary) 0%, var(--lq-primary-light) 100%);
	box-shadow: var(--lq-shadow-hover);
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 1.5rem 1.25rem 1.5rem 1.6rem;
	margin-bottom: 0.9rem;
	overflow: hidden;
	transition: transform 0.3s ease;
}
.lq-res-book:hover .lq-res-book__cover {
	transform: translateY(-5px) rotate(-1deg);
}
.lq-res-book__spine {
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	width: 8px;
	background-color: rgba(0, 0, 0, 0.18);
}
.lq-res-book__cover-title {
	font-family: var(--lq-font-heading);
	font-size: 1.05rem;
	font-weight: 600;
	color: var(--lq-on-primary);
	line-height: 1.35;
}
.lq-res-book__title {
	font-weight: 600;
	color: var(--lq-primary);
}
.lq-res-book__meta {
	font-size: 0.82rem;
	color: var(--lq-text-muted);
}

/* Podcast episodes */
.lq-res-pods {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	max-width: 760px;
}
.lq-res-pod {
	display: flex;
	align-items: center;
	gap: 1.25rem;
	background-color: var(--lq-card);
	border-radius: var(--lq-radius-md);
	padding: 1.1rem 1.5rem;
	box-shadow: var(--lq-shadow);
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.lq-res-pod:hover {
	transform: translateX(4px);
	box-shadow: var(--lq-shadow-hover);
}
.lq-res-pod__no {
	font-family: var(--lq-font-heading);
	font-style: italic;
	font-size: 1.6rem;
	font-weight: 700;
	color: var(--lq-primary);
	opacity: 0.25;
	flex-shrink: 0;
}
.lq-res-pod__play {
	width: 42px;
	height: 42px;
	border-radius: 50%;
	background-color: var(--lq-blush);
	color: var(--lq-primary);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	transition: background-color 0.2s ease;
}
.lq-res-pod:hover .lq-res-pod__play {
	background-color: var(--lq-yellow);
}
.lq-res-pod__body {
	display: flex;
	flex-direction: column;
	gap: 0.15rem;
}
.lq-res-pod__title {
	font-family: var(--lq-font-heading);
	font-size: 1.1rem;
	font-weight: 600;
	color: var(--lq-primary);
}
.lq-res-pod__meta {
	font-size: 0.82rem;
	color: var(--lq-text-muted);
}

/* ==========================================================================
   34. Testimonials page
   ========================================================================== */
.lq-tst-hero {
	position: relative;
	overflow: hidden;
	padding: clamp(3.5rem, 7vw, 6rem) 0;
	background: linear-gradient(135deg, var(--lq-primary) 0%, var(--lq-primary-light) 100%);
	text-align: center;
}
.lq-tst-hero__glow {
	position: absolute;
	border-radius: 50%;
	pointer-events: none;
}
.lq-tst-hero__glow--1 {
	width: 460px;
	height: 460px;
	background-color: var(--lq-teal);
	opacity: 0.1;
	top: -180px;
	right: -120px;
}
.lq-tst-hero__glow--2 {
	width: 360px;
	height: 360px;
	background-color: var(--lq-yellow);
	opacity: 0.09;
	bottom: -160px;
	left: -100px;
}
.lq-tst-hero__inner {
	position: relative;
	z-index: 1;
	max-width: 720px;
	margin: 0 auto;
}
.lq-tst-hero__inner h1 {
	color: var(--lq-on-primary);
	font-size: clamp(2.4rem, 5.5vw, 3.8rem);
	margin-bottom: 1rem;
}
.lq-tst-hero__lead {
	color: rgba(249, 250, 248, 0.82);
	font-size: 1.1rem;
	line-height: 1.7;
	margin: 0 auto 2.5rem;
	max-width: 56ch;
}
.lq-tst-hero__stats {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: clamp(1.5rem, 5vw, 3.5rem);
}
.lq-tst-hero__stats > div {
	display: flex;
	flex-direction: column;
}
.lq-tst-hero__num {
	font-family: var(--lq-font-heading);
	font-size: clamp(1.8rem, 3vw, 2.6rem);
	font-weight: 700;
	color: var(--lq-yellow);
}
.lq-tst-hero__label {
	font-size: 0.85rem;
	color: rgba(249, 250, 248, 0.75);
	letter-spacing: 0.03em;
}

.lq-tst-featured {
	padding: clamp(3rem, 6vw, 5rem) 0 0;
	background-color: var(--lq-bg-soft);
}
.lq-tst-featured__quote {
	max-width: 880px;
	margin: 0 auto;
	background-color: var(--lq-blush);
	border-radius: var(--lq-radius-lg);
	padding: clamp(2rem, 5vw, 3.5rem);
	text-align: center;
	position: relative;
}
.lq-tst-featured__quote::before {
	content: '\201C';
	font-family: var(--lq-font-heading);
	font-size: 5rem;
	line-height: 0.7;
	color: var(--lq-primary);
	opacity: 0.18;
	display: block;
	margin-bottom: 0.5rem;
}
.lq-tst-featured__quote p {
	font-family: var(--lq-font-heading);
	font-style: italic;
	font-size: clamp(1.3rem, 2.6vw, 1.9rem);
	line-height: 1.5;
	color: var(--lq-primary);
	margin-bottom: 1.5rem;
}
.lq-tst-featured__quote cite {
	display: block;
	font-style: normal;
	font-weight: 700;
	color: var(--lq-primary);
	font-size: 1rem;
}
.lq-tst-featured__quote footer span {
	display: block;
	font-size: 0.88rem;
	color: var(--lq-text-muted);
	margin-top: 0.2rem;
}

.lq-tst-wall {
	padding: clamp(3rem, 6vw, 5rem) 0;
	background-color: var(--lq-bg-soft);
}
.lq-tst-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}
@media (min-width: 640px) {
	.lq-tst-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}
@media (min-width: 980px) {
	.lq-tst-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}
.lq-tst-card {
	background-color: var(--lq-card);
	border-radius: var(--lq-radius-lg);
	padding: clamp(1.5rem, 3vw, 2.1rem);
	box-shadow: var(--lq-shadow);
	margin: 0;
	display: flex;
	flex-direction: column;
	border-top: 4px solid var(--lq-yellow);
}
.lq-tst-card__stars {
	color: var(--lq-yellow);
	letter-spacing: 0.1em;
	font-size: 0.95rem;
	margin-bottom: 0.9rem;
}
.lq-tst-card__text {
	margin: 0 0 1.5rem;
	color: var(--lq-text);
	font-size: 0.98rem;
	line-height: 1.7;
	flex: 1;
}
.lq-tst-card__author {
	display: flex;
	flex-direction: column;
	gap: 0.15rem;
	border-top: 1px solid var(--lq-bg-alt);
	padding-top: 1rem;
}
.lq-tst-card__name {
	font-weight: 700;
	color: var(--lq-primary);
}
.lq-tst-card__role {
	font-size: 0.82rem;
	color: var(--lq-text-muted);
}

/* Service / resources / testimonials — mobile tightening */
@media (max-width: 720px) {
	.lq-svc-hero__aside {
		order: -1;
	}
	.lq-res-head {
		align-items: flex-start;
	}
	.lq-res-pod {
		gap: 0.9rem;
		padding: 1rem 1.1rem;
	}
	.lq-res-pod__no {
		display: none;
	}
}

/* ==========================================================================
   35. Nav — WordPress .sub-menu alias (belt-and-suspenders fallback)
   ========================================================================== */
.lq-nav__list .sub-menu {
	list-style: none;
	margin: 0;
	padding: 0.5rem;
	position: absolute;
	top: calc(100% + 0.9rem);
	left: 50%;
	transform: translateX(-50%) translateY(8px);
	min-width: 230px;
	background-color: var(--lq-card);
	border: 1px solid var(--lq-bg-alt);
	border-radius: var(--lq-radius-md);
	box-shadow: var(--lq-shadow-hover);
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.22s ease, transform 0.22s ease, visibility 0.22s;
	z-index: 120;
}
.lq-nav__list .sub-menu::before {
	content: '';
	position: absolute;
	top: -0.9rem;
	left: 0;
	right: 0;
	height: 0.9rem;
}
.lq-nav__list .menu-item-has-children:hover > .sub-menu,
.lq-nav__list .menu-item-has-children:focus-within > .sub-menu,
.lq-nav__list .menu-item-has-children.is-open > .sub-menu {
	opacity: 1;
	visibility: visible;
	transform: translateX(-50%) translateY(0);
}
.lq-nav__list .sub-menu a {
	display: block;
	padding: 0.6em 0.9em;
	border-radius: var(--lq-radius-sm);
	font-size: 0.92rem;
	font-weight: 500;
	color: var(--lq-text);
	white-space: nowrap;
	transition: background-color 0.18s ease, color 0.18s ease;
}
.lq-nav__list .sub-menu a::after { display: none; }
.lq-nav__list .sub-menu a:hover,
.lq-nav__list .sub-menu .current-menu-item > a {
	background-color: var(--lq-blush);
	color: var(--lq-primary);
}

@media (max-width: 900px) {
	.lq-nav__list .sub-menu {
		position: static;
		transform: none;
		opacity: 1;
		visibility: visible;
		border: none;
		box-shadow: none;
		background-color: transparent;
		padding: 0 0 0.5rem;
		max-height: 0;
		overflow: hidden;
		transition: max-height 0.3s ease;
		min-width: 0;
		width: 100%;
		flex-basis: 100%;
	}
	.lq-nav__list .menu-item-has-children.is-open > .sub-menu {
		max-height: 340px;
	}
	.lq-nav__list .sub-menu::before { display: none; }
	.lq-nav__list .sub-menu a {
		padding-left: 1rem;
		color: var(--lq-text-muted);
	}
	.lq-nav.is-open {
		max-height: 620px;
	}
}

/* ==========================================================================
   36. Homepage redesign — "Who This Is For", Services, Mid-CTA
   ========================================================================== */

/* WHO THIS IS FOR — dark premium section */
.lq-for-you {
	background-color: var(--lq-primary);
	padding: clamp(3.5rem, 7vw, 6rem) 0;
	position: relative;
	overflow: hidden;
}
.lq-for-you__intro {
	text-align: center;
	max-width: 620px;
	margin: 0 auto clamp(2.5rem, 5vw, 3.5rem);
}
.lq-for-you__intro h2 {
	color: var(--lq-on-primary);
	font-size: clamp(1.9rem, 3.8vw, 2.8rem);
}
.lq-for-you__lead {
	color: rgba(249, 250, 248, 0.72);
	font-size: 1.05rem;
	margin: 0;
}
/* Override scenario card styles for dark section */
.lq-for-you .lq-scenario-card {
	background-color: rgba(249, 250, 248, 0.06);
	border-color: rgba(249, 250, 248, 0.14);
}
.lq-for-you .lq-scenario-card:hover {
	border-color: transparent;
	background-color: rgba(249, 250, 248, 0.12);
}
.lq-for-you .lq-scenario-card__text {
	color: rgba(249, 250, 248, 0.88);
}
.lq-for-you .lq-scenario-card__cta {
	color: var(--lq-yellow);
}
.lq-for-you .lq-scenario-card--1:hover { background-color: rgba(243,234,229,0.12); }
.lq-for-you .lq-scenario-card--2:hover { background-color: rgba(191,213,199,0.12); }
.lq-for-you .lq-scenario-card--3:hover { background-color: rgba(154,191,196,0.12); }

/* SERVICES — dark section, link-cards */
.lq-services {
	background-color: var(--lq-primary);
	padding: clamp(3.5rem, 7vw, 6rem) 0;
	position: relative;
	overflow: hidden;
}
.lq-services__glow {
	position: absolute;
	width: 500px;
	height: 500px;
	border-radius: 50%;
	background-color: var(--lq-teal);
	opacity: 0.08;
	filter: blur(60px);
	bottom: -200px;
	right: -150px;
	pointer-events: none;
}
.lq-services__header {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 1.5rem;
	flex-wrap: wrap;
	margin-bottom: clamp(2rem, 4vw, 3rem);
	position: relative;
	z-index: 1;
}
.lq-services__header h2 {
	color: var(--lq-on-primary);
	margin: 0;
	font-size: clamp(1.9rem, 3.8vw, 2.8rem);
}
.lq-services__see-all {
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--lq-yellow);
	white-space: nowrap;
}
.lq-services__see-all:hover {
	color: var(--lq-on-primary);
}
.lq-services__grid {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.25rem;
}
@media (min-width: 760px) {
	.lq-services__grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

/* Service card — full rewrite for dark section */
.lq-service-card {
	display: flex;
	flex-direction: column;
	background-color: rgba(249, 250, 248, 0.06);
	border: 1.5px solid rgba(249, 250, 248, 0.12);
	border-radius: var(--lq-radius-lg);
	padding: clamp(1.75rem, 3vw, 2.25rem);
	text-decoration: none;
	position: relative;
	overflow: hidden;
	transition: background-color 0.28s ease, border-color 0.28s ease, transform 0.28s ease;
}
.lq-service-card:hover {
	background-color: rgba(249, 250, 248, 0.1);
	border-color: rgba(249, 250, 248, 0.22);
	transform: translateY(-4px);
}
.lq-service-card__num {
	position: absolute;
	top: 0.75rem;
	right: 1.1rem;
	font-family: var(--lq-font-heading);
	font-style: italic;
	font-size: 3.5rem;
	font-weight: 700;
	color: var(--lq-on-primary);
	opacity: 0.07;
	line-height: 1;
}
.lq-service-card__icon {
	width: 54px;
	height: 54px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--lq-primary);
	margin-bottom: 1.1rem;
}
.lq-services__grid .lq-service-card:nth-child(1) .lq-service-card__icon { background-color: var(--lq-blush); }
.lq-services__grid .lq-service-card:nth-child(2) .lq-service-card__icon { background-color: var(--lq-sage); }
.lq-services__grid .lq-service-card:nth-child(3) .lq-service-card__icon { background-color: var(--lq-blush); }
.lq-service-card__title {
	font-family: var(--lq-font-heading);
	font-size: clamp(1.15rem, 2vw, 1.4rem);
	font-weight: 700;
	color: var(--lq-on-primary);
	line-height: 1.25;
	margin: 0 0 0.4rem;
}
.lq-service-card__tag {
	font-size: 0.72rem;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--lq-yellow);
	margin: 0 0 0.9rem;
}
.lq-service-card__desc {
	font-size: 0.97rem;
	color: rgba(249, 250, 248, 0.75);
	line-height: 1.65;
	flex: 1;
	margin: 0 0 1.5rem;
}
.lq-service-card__list {
	list-style: none;
	padding: 0;
	display: none;
}
.lq-service-card__link {
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--lq-yellow);
	display: inline-flex;
	align-items: center;
	gap: 0.4em;
	margin-top: auto;
	transition: gap 0.2s ease;
}
.lq-service-card:hover .lq-service-card__link {
	gap: 0.7em;
}

/* MID-PAGE CTA — full-bleed dark */
.lq-midcta {
	background: linear-gradient(135deg, var(--lq-primary-light) 0%, var(--lq-primary) 100%);
	padding: clamp(4rem, 8vw, 7rem) 0;
	text-align: center;
	position: relative;
	overflow: hidden;
}
.lq-midcta__glow {
	position: absolute;
	border-radius: 50%;
	pointer-events: none;
}
.lq-midcta__glow--1 {
	width: 450px;
	height: 450px;
	background-color: var(--lq-teal);
	opacity: 0.12;
	top: -180px;
	right: -120px;
	filter: blur(40px);
}
.lq-midcta__glow--2 {
	width: 360px;
	height: 360px;
	background-color: var(--lq-yellow);
	opacity: 0.08;
	bottom: -150px;
	left: -100px;
	filter: blur(40px);
}
.lq-midcta__inner {
	position: relative;
	z-index: 1;
	max-width: 680px;
	margin: 0 auto;
}
.lq-midcta__inner h2 {
	color: var(--lq-on-primary);
	font-size: clamp(1.8rem, 4vw, 3rem);
	line-height: 1.2;
	margin-bottom: 1rem;
}
.lq-midcta__inner p {
	color: rgba(249, 250, 248, 0.8);
	font-size: 1.1rem;
	line-height: 1.7;
	margin: 0 auto 2.25rem;
	max-width: 50ch;
}
.lq-midcta__actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 1rem;
}

/* ==========================================================================
   37. About page — dark stats band
   ========================================================================== */
.lq-stats--dark {
	background: linear-gradient(135deg, var(--lq-primary) 0%, var(--lq-primary-light) 100%);
	padding: clamp(3.5rem, 7vw, 6rem) 0;
	position: relative;
	overflow: hidden;
}
.lq-stats__glow {
	position: absolute;
	width: 500px;
	height: 500px;
	border-radius: 50%;
	background-color: var(--lq-teal);
	opacity: 0.1;
	filter: blur(60px);
	top: -200px;
	right: -130px;
	pointer-events: none;
}
.lq-stats--dark .lq-stats__grid {
	position: relative;
	z-index: 1;
}
.lq-stats--dark .lq-stats__number {
	color: var(--lq-yellow);
	font-size: clamp(2.6rem, 5vw, 4rem);
}
.lq-stats--dark .lq-stats__label {
	color: rgba(249, 250, 248, 0.7);
}

.lq-svc-cta__btns {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 1rem;
	margin-top: 0;
}

/* ==========================================================================
   38. Foundation page — mission dark, girltalk visual, donate full-bleed
   ========================================================================== */
.lq-mission--dark {
	background: linear-gradient(135deg, var(--lq-primary) 0%, var(--lq-primary-light) 100%);
	padding: clamp(3.5rem, 7vw, 6rem) 0;
	text-align: center;
	position: relative;
	overflow: hidden;
}
.lq-mission__glow {
	position: absolute;
	width: 460px;
	height: 460px;
	border-radius: 50%;
	background-color: var(--lq-yellow);
	opacity: 0.08;
	filter: blur(60px);
	top: -180px;
	left: -130px;
	pointer-events: none;
}
.lq-mission--dark > .lq-container {
	position: relative;
	z-index: 1;
	max-width: 820px;
}
.lq-mission__statement {
	margin: 0 auto 2rem;
}
.lq-mission__statement p {
	font-family: var(--lq-font-heading);
	font-style: italic;
	font-size: clamp(1.6rem, 3.5vw, 2.5rem);
	line-height: 1.35;
	color: var(--lq-on-primary);
}
.lq-mission__body {
	max-width: 680px;
	margin: 0 auto;
}
.lq-mission__body p {
	color: rgba(249, 250, 248, 0.78);
	font-size: 1.05rem;
	line-height: 1.75;
}

/* Girl Talk visual card */
.lq-girltalk__visual {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}
.lq-girltalk__img-wrap {
	position: relative;
	isolation: isolate;
}
.lq-girltalk__img-wrap::after {
	content: '';
	position: absolute;
	bottom: -12px;
	left: -12px;
	width: 50%;
	height: 50%;
	border-radius: var(--lq-radius-lg);
	background-color: var(--lq-yellow);
	opacity: 0.55;
	z-index: -1;
}
.lq-girltalk__img-wrap .lq-img-clip {
	position: relative;
	z-index: 1;
	overflow: hidden;
	border-radius: var(--lq-radius-lg);
	box-shadow: 0 16px 40px rgba(3, 50, 43, 0.16);
}
.lq-girltalk__img-wrap img {
	display: block;
	width: 100%;
	aspect-ratio: 16/10;
	object-fit: cover;
}
.lq-girltalk__card {
	background: linear-gradient(160deg, var(--lq-primary) 0%, var(--lq-primary-light) 100%);
	border-radius: var(--lq-radius-lg);
	padding: clamp(1.75rem, 3vw, 2.5rem);
	box-shadow: var(--lq-shadow-hover);
	width: 100%;
}
.lq-girltalk__card-label {
	font-family: var(--lq-font-body);
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--lq-yellow);
	margin: 0 0 1.5rem;
}
.lq-girltalk__card .lq-svc-facts dt {
	color: var(--lq-sage);
}
.lq-girltalk__card .lq-svc-facts dd {
	color: var(--lq-on-primary);
}
.lq-girltalk__card .lq-svc-facts > div {
	border-bottom-color: rgba(249, 250, 248, 0.15);
}

/* Topic cards — use svc-card base + icon override */
.lq-topics__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}
@media (min-width: 640px) { .lq-topics__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 980px) { .lq-topics__grid { grid-template-columns: repeat(3, 1fr); } }

.lq-topic-card {
	border-top-color: var(--lq-sage);
}
.lq-topics__grid .lq-topic-card:nth-child(2) { border-top-color: var(--lq-blush); }
.lq-topics__grid .lq-topic-card:nth-child(3) { border-top-color: var(--lq-teal); }
.lq-topics__grid .lq-topic-card:nth-child(4) { border-top-color: var(--lq-yellow); }
.lq-topics__grid .lq-topic-card:nth-child(5) { border-top-color: var(--lq-sage); }
.lq-topics__grid .lq-topic-card:nth-child(6) { border-top-color: var(--lq-teal); }
.lq-topic-card__icon {
	width: 46px;
	height: 46px;
	border-radius: 50%;
	background-color: var(--lq-bg-alt);
	color: var(--lq-primary);
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 1rem;
}

/* Donate — full-bleed dark */
.lq-donate {
	background: linear-gradient(135deg, var(--lq-primary) 0%, var(--lq-primary-light) 100%);
	padding: clamp(4rem, 8vw, 7rem) 0;
	text-align: center;
	position: relative;
	overflow: hidden;
}
.lq-donate__glow {
	position: absolute;
	border-radius: 50%;
	pointer-events: none;
}
.lq-donate__glow--1 {
	width: 460px; height: 460px;
	background-color: var(--lq-teal);
	opacity: 0.1;
	filter: blur(50px);
	top: -180px; right: -120px;
}
.lq-donate__glow--2 {
	width: 360px; height: 360px;
	background-color: var(--lq-yellow);
	opacity: 0.08;
	filter: blur(50px);
	bottom: -150px; left: -100px;
}
.lq-donate > .lq-container {
	position: relative;
	z-index: 1;
}
.lq-donate > .lq-container > h2 {
	color: var(--lq-on-primary);
	font-size: clamp(1.8rem, 4vw, 3rem);
	max-width: 18ch;
	margin: 0.5rem auto 1rem;
}
.lq-donate__lead {
	color: rgba(249, 250, 248, 0.8);
	font-size: 1.1rem;
	max-width: 52ch;
	margin: 0 auto 3rem;
	line-height: 1.7;
}
.lq-donate__options {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.25rem;
	max-width: 900px;
	margin: 0 auto 2.5rem;
}
@media (min-width: 720px) {
	.lq-donate__options {
		grid-template-columns: repeat(3, 1fr);
	}
}
.lq-donate__option {
	background-color: rgba(249, 250, 248, 0.07);
	border: 1px solid rgba(249, 250, 248, 0.14);
	border-radius: var(--lq-radius-lg);
	padding: clamp(1.5rem, 3vw, 2rem);
	text-align: center;
}
.lq-donate__option-icon {
	width: 50px;
	height: 50px;
	border-radius: 50%;
	background-color: rgba(249, 250, 248, 0.1);
	color: var(--lq-yellow);
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 1rem;
}
.lq-donate__option h3 {
	color: var(--lq-on-primary);
	font-size: 1.1rem;
	margin-bottom: 0.5rem;
}
.lq-donate__option p {
	color: rgba(249, 250, 248, 0.7);
	font-size: 0.95rem;
	margin: 0;
	line-height: 1.6;
}
.lq-donate__actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 1rem;
	margin-bottom: 1.5rem;
}
.lq-donate__note {
	color: rgba(249, 250, 248, 0.45);
	font-size: 0.82rem;
	font-style: italic;
	margin: 0;
}

/* --------------------------------------------------------------------------
   Header Transparent Overrides (Not Scrolled)
   -------------------------------------------------------------------------- */
/* Logo background when not scrolled */
.lq-header.lq-header--over-dark:not(.is-scrolled) .lq-header__brand {
	background-color: rgba(255, 255, 255, 0.95);
	padding: 0.05rem 0.07rem;
	border-radius: var(--lq-radius-sm);
	transition: background-color 0.3s ease, padding 0.3s ease;
}
.lq-header.is-scrolled .lq-header__brand {
	background-color: transparent;
	padding: 0;
	transition: background-color 0.3s ease, padding 0.3s ease;
}

/* Nav links when not scrolled */
@media (min-width: 901px) {
	.lq-header.lq-header--over-dark:not(.is-scrolled) .lq-nav__link,
	.lq-header.lq-header--over-dark:not(.is-scrolled) .lq-nav__list > .lq-nav__item > a {
		color: var(--lq-on-primary);
	}
	.lq-header.lq-header--over-dark:not(.is-scrolled) .lq-nav__link:hover,
	.lq-header.lq-header--over-dark:not(.is-scrolled) .lq-nav__list > .lq-nav__item > a:hover {
		color: var(--lq-yellow);
	}
	.lq-header.lq-header--over-dark:not(.is-scrolled) .lq-nav__link::after,
	.lq-header.lq-header--over-dark:not(.is-scrolled) .lq-nav__list > .lq-nav__item > a::after {
		background-color: var(--lq-yellow);
	}
	.lq-header.lq-header--over-dark:not(.is-scrolled) .lq-nav__sub-toggle {
		color: var(--lq-on-primary);
	}
	.lq-header.lq-header--over-dark:not(.is-scrolled) .lq-nav__item--has-children:hover .lq-nav__sub-toggle,
	.lq-header.lq-header--over-dark:not(.is-scrolled) .lq-nav__item--has-children:focus-within .lq-nav__sub-toggle {
		color: var(--lq-yellow);
	}
}

/* Mobile Hamburger Menu */
.lq-header.lq-header--over-dark:not(.is-scrolled) .lq-nav-toggle__bar {
	background-color: var(--lq-on-primary);
}

/* =============================================================
   Workshops — Programs & Classes widget
   ============================================================= */
.lq-workshops-programs {
	padding: clamp(3rem, 6vw, 5.5rem) 0;
}

/* Program cards grid */
.lq-program-cards {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 1.5rem;
	margin-top: 2.5rem;
}

.lq-program-card {
	display: flex;
	flex-direction: column;
	background: var(--lq-white, #fff);
	border: 1px solid var(--lq-bg-alt);
	border-radius: var(--lq-radius-md);
	padding: 2rem;
	box-shadow: var(--lq-shadow);
	transition: box-shadow 0.25s ease, transform 0.25s ease;
}

.lq-program-card:hover {
	box-shadow: var(--lq-shadow-hover);
	transform: translateY(-3px);
}

.lq-program-card__body {
	flex: 1;
	margin-bottom: 1.5rem;
}

.lq-program-card__title {
	font-size: clamp(1.1rem, 1.8vw, 1.3rem);
	margin-bottom: 0.6em;
}

.lq-program-card__desc {
	font-size: 0.95rem;
	color: var(--lq-text-muted, #6b7280);
	line-height: 1.6;
	margin-bottom: 0;
}

.lq-program-card__price {
	font-size: 1.4rem;
	font-weight: 700;
	color: var(--lq-primary);
	margin-top: 1rem;
	margin-bottom: 0;
}

.lq-program-card__cta {
	width: 100%;
	text-align: center;
}

/* Quarterly group classes */
.lq-workshops-classes {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(2rem, 5vw, 4rem);
	align-items: center;
	margin-top: clamp(3rem, 6vw, 5rem);
	padding-top: clamp(3rem, 6vw, 5rem);
	border-top: 1px solid var(--lq-bg-alt);
}

.lq-workshops-classes__content {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}

.lq-workshops-classes__heading {
	margin-bottom: 0;
}

.lq-workshops-classes__desc {
	color: var(--lq-text-muted, #6b7280);
	margin-bottom: 0;
}

.lq-workshops-classes__flyer-clip {
	border-radius: var(--lq-radius-md);
	overflow: hidden;
	box-shadow: var(--lq-shadow-hover);
}

.lq-workshops-classes__flyer-clip img {
	display: block;
	width: 100%;
	height: auto;
}

@media (max-width: 768px) {
	.lq-workshops-classes {
		grid-template-columns: 1fr;
	}

	.lq-workshops-classes__flyer {
		order: -1;
	}
}

/* =============================================================
   ELEMENTOR — LQueenwrites widget integration
   ============================================================= */

/* 1. Hide WordPress page title output by the default Hello Elementor template.
      The correct fix is using the "Elementor Full Width" page template, but
      this CSS acts as a fallback for either template. */
.elementor-page .entry-header,
.elementor-page .entry-title {
	display: none;
}

/* 2. Reset Elementor's default widget-container padding so LQ sections
      sit flush against their edges. Elementor's Advanced margin/padding
      controls write inline styles to .elementor-widget-container, so we
      only touch padding here — never left/width — to avoid conflicts. */
.elementor-widget[class*="elementor-widget-lq-"] > .elementor-widget-container {
	padding: 0;
}

/* 3. Full-bleed escape: target the <section> rendered INSIDE the widget
      container, not the container itself. Elementor's Advanced margin
      controls write to .elementor-widget-container, so they never touch
      the inner <section> and cannot break this rule.
        left: 50%              → shifts left edge to viewport centre
        translateX(-50%)       → pulls back by half the element's width (50vw)
        result: element starts at viewport left edge, spans full viewport */
.elementor-widget-container > section[class*="lq-"] {
	position: relative;
	left: 50%;
	transform: translateX(-50%);
	width: 100vw;
	max-width: 100vw;
}

/* 4. Prevent the 100vw width from creating a horizontal scrollbar */
body.elementor-page {
	overflow-x: hidden;
}

/* 5. Kill every source of gap between LQ section widgets and their
      Elementor wrappers. Elementor adds these in several layers:
      (a) section padding — top/bottom on the elementor-section wrapper
      (b) widget spacing — margin-bottom on every widget via --widgets-spacing
      (c) column wrap padding — elementor-widget-wrap inner padding
      (d) Flexbox container gap — on .e-con (Elementor 3.6+ Container mode) */

/* (a) Section padding — classic section/column layout */
.elementor-section:has(.elementor-widget[class*="elementor-widget-lq-"]) {
	padding-top: 0 !important;
	padding-bottom: 0 !important;
	margin-top: 0 !important;
	margin-bottom: 0 !important;
}

/* (b) Widget spacing margin — Elementor adds margin-bottom via --widgets-spacing */
.elementor-widget[class*="elementor-widget-lq-"] {
	margin-top: 0 !important;
	margin-bottom: 0 !important;
}

/* (c) Column wrap padding */
.elementor-column:has(.elementor-widget[class*="elementor-widget-lq-"]) > .elementor-widget-wrap {
	padding: 0 !important;
}

/* (d) Flexbox Container mode (Elementor 3.6+) */
.e-con:has(.elementor-widget[class*="elementor-widget-lq-"]) {
	padding: 0 !important;
	gap: 0 !important;
}
.e-con-inner:has(.elementor-widget[class*="elementor-widget-lq-"]) {
	padding: 0 !important;
	gap: 0 !important;
}

/* 6. Remove any bottom gap between the last LQ widget and the footer.
      Hello Elementor wraps Elementor content in .site-main which may
      carry bottom padding; zero it out on Elementor-edited pages. */
.elementor-page .site-main,
.elementor-page #main,
.elementor-page .elementor-section-wrap {
	padding-bottom: 0 !important;
	margin-bottom: 0 !important;
}
