/*
Theme Name: lindaNovia
Theme URI: https://lindanovia.com
Author: Linda Novia	Marketing and Branding Agency
Author URI: https://lindanovia.com
Description: WordPress theme for Linda Novia Marketing and Branding Agency			
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: lindanovia
*/

/* Main styles are loaded from assets/css/main.css and responsive.css via functions.php */

/* ============================================
   LINDA NOVIA – shared palette (use across home sections)
   ============================================ */
:root {
	--ln-rose: #ff8da1;
	--ln-rose-deep: #e8748a;
	--ln-blush: #ffc0cb;
	--ln-white: #ffffff;
	--ln-plum: #6b2d3d;
	--ln-plum-600: #5c2f3d;
	--ln-text: #5c3d45;
	--ln-text-body: #5c4d54;
	--ln-text-soft: #6b5a62;
	--ln-muted: rgba(107, 45, 61, 0.55);
	--ln-hairline-dark: rgba(0, 0, 0, 0.05);
	--ln-hairline-rose: rgba(255, 192, 203, 0.22);
	--ln-surface-0: #ffffff;
	--ln-surface-1: #fafafa;
	--ln-surface-soft: #fbf9fa;
	--ln-surface-rose: #fff8fa;
	--ln-surface-blush: #ffeef2;
	--ln-shadow-plum: rgba(107, 45, 61, 0.08);
	--ln-shadow-rose: rgba(255, 141, 161, 0.1);
	--ln-font-sans: 'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

body {
	font-family: var(--ln-font-sans);
}

/* ============================================
   Preloader — Linda Novia (replaces generic .circle in header)
   ============================================ */
.loader.ln-loader {
	background: radial-gradient(
		ellipse 95% 85% at 50% 32%,
		rgba(92, 47, 61, 0.97) 0%,
		rgba(45, 20, 31, 1) 58%,
		#12070a 100%
	) !important;
	overflow: hidden;
}
.ln-loader__inner {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	text-align: center;
	width: min(92vw, 340px);
	padding: 0 1rem;
	box-sizing: border-box;
}
.ln-loader__mark {
	position: relative;
	width: 132px;
	height: 132px;
	margin: 0 auto 0.75rem;
}
.ln-loader__ring {
	position: absolute;
	z-index: 0;
	inset: 4px;
	border-radius: 50%;
	border: 2px solid rgba(255, 255, 255, 0.12);
	border-top-color: var(--ln-rose);
	border-right-color: rgba(255, 141, 161, 0.45);
	animation: ln-loader-orbit 0.95s linear infinite;
	box-sizing: border-box;
}
.ln-loader__ring--outer {
	inset: -8px;
	border-color: rgba(255, 255, 255, 0.08);
	border-top-color: rgba(255, 255, 255, 0.35);
	border-bottom-color: var(--ln-rose);
	border-right-color: transparent;
	animation-duration: 1.45s;
	animation-direction: reverse;
	opacity: 0.9;
}
.ln-loader__word {
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	height: 100%;
	gap: 0.05rem;
	pointer-events: none;
}
.ln-loader__linda {
	font-family: var(--ln-font-sans);
	font-weight: 600;
	font-size: clamp(1.15rem, 4.2vw, 1.35rem);
	letter-spacing: -0.03em;
	color: #ffffff;
	line-height: 1.05;
	text-shadow:
		0 1px 0 rgba(0, 0, 0, 0.35),
		0 1px 2px rgba(0, 0, 0, 0.28);
}
.ln-loader__accent {
	font-family: var(--ln-font-sans);
	font-weight: 700;
	font-size: clamp(1.2rem, 4.5vw, 1.45rem);
	letter-spacing: -0.03em;
	color: var(--ln-rose) !important;
	line-height: 1.05;
	text-shadow:
		0 1px 0 rgba(45, 22, 31, 0.35),
		0 1px 1px rgba(0, 0, 0, 0.22);
}
.ln-loader__tagline {
	margin: 0;
	font-family: var(--ln-font-sans);
	font-weight: 500;
	font-size: clamp(0.68rem, 2.4vw, 0.8rem);
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.78);
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.35);
}
.ln-loader__amp {
	color: var(--ln-rose);
	font-weight: 700;
}
@keyframes ln-loader-orbit {
	to {
		transform: rotate(360deg);
	}
}
@media (prefers-reduced-motion: reduce) {
	.ln-loader__ring {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
	}
}

/* Shared home section typography (same rhythm as hero accents) */
.ln-kicker {
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--ln-muted);
	margin: 0 0 0.5rem;
}
.ln-about-section .ln-kicker,
.ln-about-faq .ln-kicker {
	text-align: left;
}
/* Portfolio / Magazine intro: kicker centered (overrides .ln-about-section .ln-kicker) */
.ln-about-section .ln-about-section__titles--magazine-kicker > .ln-kicker {
	text-align: center;
}
/* Magazine page intro — wordmark like header/footer, tuned for light about-section background */
.ln-about-section .ln-magazine-intro-wordmark {
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	font-size: clamp(1.5rem, 4.2vw, 2.35rem);
	font-weight: 600;
	letter-spacing: -0.04em;
	line-height: 1.2;
	margin: 0;
	color: var(--ln-plum);
	text-align: center;
}
.ln-about-section .ln-magazine-intro-wordmark__link {
	color: inherit;
	text-decoration: none;
	display: inline-block;
	max-width: 100%;
	transition: opacity 0.2s ease;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
.ln-about-section .ln-magazine-intro-wordmark__link:hover {
	opacity: 0.88;
}
.ln-about-section .ln-magazine-intro-wordmark__link:focus-visible {
	outline: 2px solid var(--ln-rose);
	outline-offset: 3px;
	border-radius: 4px;
}
.ln-about-section .ln-magazine-intro-wordmark .hero-headline__accent {
	color: var(--ln-rose) !important;
	font-weight: 700 !important;
	letter-spacing: -0.03em !important;
	text-shadow: none !important;
}
.ln-section-heading {
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	font-weight: 700;
	font-size: clamp(1.35rem, 3.5vw, 2rem);
	line-height: 1.22;
	letter-spacing: -0.02em;
	color: var(--ln-plum);
	margin: 0 0 0.65rem;
}
.ln-section-lead {
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	font-size: 0.9375rem;
	line-height: 1.62;
	color: var(--ln-text-soft);
	margin: 0;
}

/* ============================================
   HEADER / MENU – professional, lighter type
   ============================================ */
/* Linda Novia — header: logo → nav + CTA; meanmenu needs full-width .mobile-menu on small screens */
.top-header-area.ln-top-header {
	padding: 0;
}
.top-header-area.ln-top-header .main-menu-wrap.ln-header-main {
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.25rem;
	padding: 0.45rem 0 1rem;
	width: 100%;
}
.top-header-area.ln-top-header .ln-header__nav-wrap {
	position: relative;
	width: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
	min-height: 2.75rem;
	overflow: visible;
}
.top-header-area.ln-top-header .site-logo.ln-header__logo {
	float: none;
	max-width: 100%;
	width: 100%;
	text-align: center;
	position: relative;
	left: auto !important;
	top: auto !important;
	right: auto !important;
	transform: none !important;
	padding: 0.15rem 0 0.1rem;
	margin: 0;
}
.top-header-area.ln-top-header .ln-header__wordmark-link {
	text-decoration: none;
	display: inline-block;
	max-width: 100%;
	overflow-wrap: anywhere;
	word-break: normal;
	-webkit-tap-highlight-color: rgba(255, 141, 161, 0.22);
	touch-action: manipulation;
}
.top-header-area.ln-top-header .ln-header__wordmark.hero-headline,
.top-header-area.ln-top-header .site-logo .hero-headline {
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif !important;
	font-size: clamp(1.15rem, 3.2vw, 1.65rem) !important;
	font-weight: 600 !important;
	letter-spacing: -0.04em !important;
	line-height: 1.18 !important;
	margin: 0 !important;
	color: #ffffff !important;
	text-shadow: 0 1px 0 rgba(0, 0, 0, 0.32), 0 1px 1px rgba(0, 0, 0, 0.28);
}
.top-header-area.ln-top-header .ln-header__wordmark .hero-headline__accent {
	color: var(--ln-rose) !important;
	font-weight: 700 !important;
	text-shadow: 0 1px 0 rgba(36, 18, 24, 0.42), 0 1px 1px rgba(0, 0, 0, 0.28) !important;
}
.top-header-area.ln-top-header nav.main-menu {
	flex: none;
	width: 100%;
	text-align: center;
}
.top-header-area.ln-top-header nav.main-menu > ul {
	justify-content: center;
	flex-wrap: wrap;
	row-gap: 0.25rem;
	column-gap: 0.1rem;
}
.top-header-area.ln-top-header nav.main-menu > ul > li {
	float: none !important;
}
.top-header-area.ln-top-header nav.main-menu > ul > li:last-child {
	float: none !important;
}
@media (max-width: 991.98px) {
	.sticky-wrapper:has(.ln-top-header),
	.top-header-area.ln-top-header,
	.top-header-area.ln-top-header > .container,
	.top-header-area.ln-top-header .main-menu-wrap.ln-header-main {
		overflow: visible;
	}
	.top-header-area.ln-top-header .main-menu-wrap.ln-header-main {
		padding-left: 0 !important;
		align-items: stretch;
	}
	.top-header-area.ln-top-header .site-logo.ln-header__logo {
		text-align: center;
		padding: 0.25rem 0.75rem 0.35rem;
	}
	.top-header-area.ln-top-header .ln-header__nav-wrap {
		justify-content: center;
		min-height: 48px;
		padding-right: max(3.25rem, calc(2.75rem + env(safe-area-inset-right, 0px)));
		padding-left: max(0.25rem, env(safe-area-inset-left, 0px));
		box-sizing: border-box;
	}
	/* Meanmenu mounts here: span full nav row (absolute + width:auto was shrink-wrapping the drawer) */
	.top-header-area.ln-top-header .mobile-menu {
		position: absolute;
		left: 0;
		right: max(0px, env(safe-area-inset-right, 0px));
		top: 0;
		width: 100%;
		max-width: 100%;
		min-height: 48px;
		z-index: 100;
		transform: none;
	}
	.top-header-area.ln-top-header > .container {
		padding-left: max(0.75rem, env(safe-area-inset-left, 0px));
		padding-right: max(0.75rem, env(safe-area-inset-right, 0px));
	}
	/* Meanmenu hamburger — 44px tap target; bars must stack (flex column), not row */
	.top-header-area.ln-top-header .mean-container a.meanmenu-reveal {
		min-width: 44px;
		min-height: 44px;
		width: auto !important;
		height: auto !important;
		display: flex !important;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		gap: 5px;
		padding: 10px 12px !important;
		box-sizing: border-box;
		color: #ffffff !important;
		background-color: var(--ln-rose) !important;
		border-radius: 10px;
		overflow: hidden;
	}
	.top-header-area.ln-top-header .mean-container a.meanmenu-reveal span {
		display: block !important;
		width: 20px !important;
		height: 2px !important;
		min-height: 2px !important;
		margin: 0 !important;
		padding: 0 !important;
		border: 0 !important;
		border-radius: 1px;
		background-color: #ffffff !important;
		flex-shrink: 0;
	}
	.top-header-area.ln-top-header .mean-container a.meanmenu-reveal.meanclose {
		background-color: #3a1c26 !important;
		color: #ffffff !important;
		font-size: 1.35rem !important;
		line-height: 1 !important;
		font-weight: 600 !important;
		text-indent: 0 !important;
		gap: 0;
	}
	.top-header-area.ln-top-header .mean-container a.meanmenu-reveal.meanclose span {
		display: none !important;
	}
	.top-header-area.ln-top-header .mean-container .mean-bar {
		background: transparent !important;
		border: none !important;
		box-shadow: none !important;
		outline: none !important;
	}
	/* Drawer — same plum palette as sticky header (replaces default meanmenu navy #0c1923) */
	.top-header-area.ln-top-header .mean-container .mean-nav {
		max-height: min(72vh, 28rem);
		overflow-y: auto;
		overflow-x: hidden;
		-webkit-overflow-scrolling: touch;
		touch-action: pan-y;
		background: linear-gradient(180deg, #4f2a36 0%, #3a1c26 50%, #2d161f 100%) !important;
		background-color: #3a1c26 !important;
		border: none !important;
		border-top: none !important;
		box-shadow: 0 14px 36px rgba(20, 8, 12, 0.42);
	}
	.top-header-area.ln-top-header .mean-container .mean-nav > ul > li:first-child > a {
		border-top: none !important;
	}
	.top-header-area.ln-top-header .mean-container .mean-nav ul li a {
		padding: 0.85rem 5% !important;
		color: #ffffff !important;
		border-color: rgba(255, 192, 203, 0.12) !important;
		font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif !important;
		font-weight: 500 !important;
	}
	.top-header-area.ln-top-header .mean-container .mean-nav ul li a:hover {
		color: var(--ln-rose) !important;
		background: rgba(255, 255, 255, 0.06) !important;
	}
	.top-header-area.ln-top-header .mean-container .mean-nav ul li a.mean-expand {
		color: #ffffff !important;
		border-color: rgba(255, 192, 203, 0.18) !important;
	}
	.top-header-area.ln-top-header .mean-container .mean-nav ul ul li a {
		color: rgba(255, 255, 255, 0.92) !important;
		border-color: rgba(255, 192, 203, 0.08) !important;
		background: rgba(0, 0, 0, 0.12) !important;
	}
	.top-header-area.ln-top-header .mean-container .mean-nav ul li a.ln-menu__cta {
		justify-content: center;
		width: calc(100% - 10%);
		max-width: 18rem;
		margin-left: auto;
		margin-right: auto;
		box-sizing: border-box;
	}
	.top-header-area.ln-top-header .mean-container .mean-nav ul li a.ln-menu__cta:hover {
		color: var(--ln-rose-deep) !important;
		background: var(--ln-blush) !important;
	}
}

@media (max-width: 575.98px) {
	.top-header-area.ln-top-header .ln-header__wordmark.hero-headline,
	.top-header-area.ln-top-header .site-logo .hero-headline {
		font-size: clamp(0.92rem, 4.5vw, 1.3rem) !important;
		line-height: 1.22 !important;
	}
}

/* Floating contact — template-parts/float-contact.php (fixed; tap-to-call) */
.ln-float-contact {
	position: fixed;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	z-index: 1020;
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
}
.ln-float-contact__link {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.12rem;
	min-height: 44px;
	min-width: 2.85rem;
	padding: 0.7rem 0.45rem 0.7rem 0.55rem;
	text-align: center;
	text-decoration: none !important;
	color: #ffffff !important;
	background: linear-gradient(180deg, #5c3140 0%, #3a1c26 52%, #2d161f 100%);
	border: 1px solid rgba(255, 192, 203, 0.22);
	border-right: none;
	border-radius: 12px 0 0 12px;
	box-shadow: -6px 6px 28px rgba(10, 4, 6, 0.35);
	transition: background 0.2s ease, box-shadow 0.2s ease;
	-webkit-tap-highlight-color: rgba(255, 141, 161, 0.25);
	touch-action: manipulation;
}
.ln-float-contact__label {
	font-size: 0.625rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.92) !important;
	line-height: 1.15;
}
.ln-float-contact__phone {
	font-size: 0.8125rem;
	font-weight: 600;
	letter-spacing: 0.02em;
	color: #ffffff !important;
	line-height: 1.2;
}
@media (hover: hover) {
	.ln-float-contact__link:hover {
		background: linear-gradient(180deg, #6a3a4a 0%, #4a2832 52%, #352028 100%);
		box-shadow: -8px 8px 32px rgba(10, 4, 6, 0.45);
	}
}
.ln-float-contact__link:focus-visible {
	outline: 2px solid var(--ln-rose);
	outline-offset: 2px;
}
.ln-float-contact__mobile {
	display: none;
}
.ln-float-contact__btn {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.1rem;
	flex: 1 1 0;
	min-width: 0;
	min-height: 48px;
	padding: 0.55rem 0.65rem;
	text-align: center;
	text-decoration: none !important;
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	border-radius: 14px;
	border: 1px solid rgba(255, 192, 203, 0.28);
	box-shadow: 0 4px 18px rgba(10, 4, 6, 0.28);
	transition: background 0.2s ease, color 0.2s ease, transform 0.15s ease;
	-webkit-tap-highlight-color: rgba(255, 141, 161, 0.25);
	touch-action: manipulation;
}
.ln-float-contact__btn-kicker {
	font-size: 0.625rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	line-height: 1.1;
	opacity: 0.92;
}
.ln-float-contact__btn-text {
	font-size: 0.8125rem;
	font-weight: 600;
	line-height: 1.2;
	letter-spacing: -0.01em;
}
.ln-float-contact__btn--call {
	color: #ffffff !important;
	background: linear-gradient(180deg, #5c3140 0%, #3a1c26 52%, #2d161f 100%);
}
.ln-float-contact__btn--plan {
	color: var(--ln-plum-600) !important;
	background: var(--ln-blush);
	border-color: rgba(255, 141, 161, 0.45);
}
.ln-float-contact__btn--plan .ln-float-contact__btn-text {
	font-size: 0.875rem;
}
.ln-float-contact__btn:focus-visible {
	outline: 2px solid var(--ln-rose);
	outline-offset: 2px;
}
@media (hover: hover) {
	.ln-float-contact__btn--call:hover {
		background: linear-gradient(180deg, #6a3a4a 0%, #4a2832 52%, #352028 100%);
	}
	.ln-float-contact__btn--plan:hover {
		background: #ffffff;
		color: var(--ln-rose) !important;
	}
}
@media (max-width: 991.98px) {
	.ln-float-contact {
		top: auto;
		left: 0;
		right: 0;
		bottom: 0;
		transform: none;
		width: 100%;
		max-width: none;
		padding: 0.5rem max(0.65rem, env(safe-area-inset-right, 0px)) max(0.65rem, env(safe-area-inset-bottom, 0px)) max(0.65rem, env(safe-area-inset-left, 0px));
		box-sizing: border-box;
		background: linear-gradient(180deg, rgba(45, 22, 31, 0) 0%, rgba(45, 22, 31, 0.88) 35%, rgba(29, 14, 20, 0.96) 100%);
		pointer-events: none;
	}
	.ln-float-contact__link--desktop {
		display: none !important;
	}
	.ln-float-contact__mobile {
		display: flex;
		gap: 0.5rem;
		width: 100%;
		max-width: 28rem;
		margin: 0 auto;
		pointer-events: auto;
	}
	.ln-float-contact__btn--call .ln-float-contact__btn-text {
		font-size: 0.75rem;
	}
}
@media (min-width: 992px) {
	.ln-float-contact__mobile {
		display: none !important;
	}
}
@media print {
	.ln-float-contact {
		display: none !important;
	}
}

/* Sticky menu – lower height + Linda Novia plum (override main.css #051922 navy) */
.sticky-wrapper.is-sticky .top-header-area.ln-top-header {
	padding: 0 !important;
	background: linear-gradient(180deg, #4f2a36 0%, #3a1c26 48%, #2d161f 100%) !important;
	background-color: #3a1c26 !important;
	box-shadow: 0 10px 36px rgba(20, 8, 12, 0.42);
	border-bottom: 1px solid rgba(255, 192, 203, 0.16);
}
.sticky-wrapper.is-sticky .top-header-area.ln-top-header .main-menu-wrap.ln-header-main {
	padding-top: 0.35rem;
	padding-bottom: 0.5rem;
	gap: 0.15rem;
}
.sticky-wrapper.is-sticky .top-header-area.ln-top-header .ln-header__wordmark.hero-headline,
.sticky-wrapper.is-sticky .top-header-area.ln-top-header .site-logo .hero-headline {
	font-size: clamp(1rem, 3.5vw, 1.35rem) !important;
}
.sticky-wrapper.is-sticky nav.main-menu ul li a {
	padding: 8px 15px !important;
}
.sticky-wrapper.is-sticky .site-logo img {
	max-height: 36px;
	width: auto;
}
.sticky-wrapper.is-sticky .lang-switcher .lang-flag {
	height: 26px;
}
nav.main-menu ul li a {
	color: #ffffff;
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif !important;
	font-weight: 400 !important;
	font-size: 1.0625rem !important;
	letter-spacing: 0.02em !important;
	display: block;
	padding: 15px;
}
nav.main-menu ul ul.sub-menu li a {
	font-weight: 400 !important;
	font-size: 0.9375rem !important;
}
.top-header-area .header-icons a {
	font-weight: 400 !important;
}

/* Last nav item — primary CTA (pill button) */
nav.main-menu ul li.ln-menu-cta-item {
	margin-left: 0.35rem;
}
nav.main-menu ul li a.ln-menu__cta {
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	font-weight: 600 !important;
	font-size: 0.875rem !important;
	letter-spacing: 0.04em !important;
	text-decoration: none !important;
	color: #ffffff !important;
	background: var(--ln-rose) !important;
	padding: 0.5rem 1.2rem !important;
	min-height: 44px;
	box-sizing: border-box;
	border-radius: 100px;
	box-shadow: 0 2px 14px rgba(255, 141, 161, 0.35);
	transition: background 0.2s ease, box-shadow 0.2s ease, color 0.2s ease, transform 0.15s ease;
	-webkit-tap-highlight-color: rgba(255, 141, 161, 0.25);
	touch-action: manipulation;
}
@media (hover: hover) {
	nav.main-menu ul li a.ln-menu__cta:hover {
		background: var(--ln-blush) !important;
		color: var(--ln-rose-deep) !important;
		box-shadow: 0 4px 18px rgba(255, 141, 161, 0.4);
		transform: translateY(-1px);
	}
}
nav.main-menu ul li.ln-menu-cta-item.current-list-item > a.ln-menu__cta {
	background: var(--ln-blush) !important;
	color: var(--ln-rose-deep) !important;
	box-shadow: 0 2px 12px rgba(255, 141, 161, 0.45);
}
@media (prefers-reduced-motion: reduce) {
	nav.main-menu ul li a.ln-menu__cta {
		transition: background 0.2s ease, box-shadow 0.2s ease, color 0.2s ease;
	}
	@media (hover: hover) {
		nav.main-menu ul li a.ln-menu__cta:hover {
			transform: none;
		}
	}
}
.sticky-wrapper.is-sticky nav.main-menu ul li a.ln-menu__cta {
	padding: 0.4rem 1rem !important;
	font-size: 0.8125rem !important;
	min-height: 40px;
}

/* Align nav row and flags vertically */
.main-menu-wrap {
	align-items: center;
}
.main-menu-wrap nav.main-menu > ul {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	justify-content: center;
}
.main-menu-wrap nav.main-menu > ul > li {
	display: inline-flex;
	align-items: center;
}
.main-menu-wrap .lang-switcher {
	align-self: center;
	display: flex;
	align-items: center;
}

/* ============================================
   HERO – modern 2024 design
   ============================================ */
/* Hero video background – responsive, resizes with screen */
.hero-area.hero-bg {
	position: relative;
	min-height: 100vh;
	overflow: hidden;
	display: flex;
	align-items: center;
}
.hero-area .hero-video-bg {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	min-width: 100%;
	min-height: 100%;
	object-fit: cover;
	object-position: center;
	z-index: 0;
}
.hero-area.hero-bg .container {
	position: relative;
	z-index: 1;
}

/* Get Started page: soften video behind form (plum vignette, Linda Novia scheme) */
.hero-area.hero-bg.hero-get-started::after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 1;
	pointer-events: none;
	background: radial-gradient(
		ellipse 110% 75% at 50% 40%,
		rgba(45, 22, 31, 0.38) 0%,
		rgba(30, 12, 18, 0.62) 55%,
		rgba(14, 5, 9, 0.78) 100%
	);
}
.hero-area.hero-bg.hero-get-started .container {
	z-index: 2;
}

/* Get Started: keep .container high (not vertically centered in viewport); top padding clears absolute Back link */
body.template-get-started .hero-area.hero-bg.hero-get-started {
	align-items: flex-start;
	box-sizing: border-box;
}
body.template-get-started .hero-area.hero-get-started .container {
	padding-top: calc(env(safe-area-inset-top, 0px) + 3.25rem);
	box-sizing: border-box;
}
body.template-get-started .hero-area.hero-get-started .hero-text {
	height: auto !important;
}
body.template-get-started .hero-area.hero-get-started .hero-text-tablecell {
	vertical-align: top !important;
}

.hero-area .hero-flag {
	display: block;
	width: 48px;
	height: auto;
	margin: 0 auto 0.75rem;
}
.hero-area .hero-text-with-bg {
	/*background: rgba(255, 255, 255, 0.94) !important; */
	backdrop-filter: blur(20px);
	-webkit-backdrop-filter: blur(20px);
	padding: 3rem 3.5rem 3.25rem !important;
	border-radius: 34px !important;
	max-width: 640px !important;
	margin: 0 auto !important;
	box-shadow:
		0 0 0 1px rgba(0, 0, 0, 0.04),
		0 2px 4px rgba(0, 0, 0, 0.04),
		0 12px 24px rgba(0, 0, 0, 0.06),
		0 32px 64px rgba(0, 0, 0, 0.08) !important;
	border: none !important;
	text-align: center !important;
}

/* Get Started: progress + titles stay on video; plum panel only on each step section */
.template-get-started .hero-text-with-bg {
	max-width: 720px !important;
	padding: 0.65rem 1.25rem 2.25rem !important;
	background: transparent !important;
	backdrop-filter: none !important;
	-webkit-backdrop-filter: none !important;
	box-shadow: none !important;
	border: none !important;
}

/* Get Started — tighter title stack + smaller subline */
body.template-get-started .hero-text-with-bg .hero-headline,
body.template-get-started .hero-text-with-bg h1.hero-headline {
	line-height: 1.02 !important;
	margin-bottom: 0.06rem !important;
}
body.template-get-started .hero-text-with-bg .hero-headline-sub {
	font-size: 0.875rem !important;
	line-height: 1.3 !important;
	font-weight: 400 !important;
	margin: 0 auto 0 !important;
	max-width: 34rem;
}

.template-get-started .gs-slide {
	margin-top: 0.5rem;
	padding: 1.35rem 1.1rem 1.45rem;
	border-radius: 22px;
	box-sizing: border-box;
	
	border: 1px solid rgba(255, 192, 203, 0.22);
	box-shadow: 0 16px 46px rgba(12, 4, 8, 0.4);
	backdrop-filter: blur(18px);
	-webkit-backdrop-filter: blur(18px);
}

.template-get-started .gs-wizard > .gs-error:not([hidden]) {
	margin-top: 0.65rem;
}

.template-get-started .gs-back-home {
	position: absolute;
	top: max(12px, env(safe-area-inset-top, 0px));
	left: max(12px, env(safe-area-inset-left, 0px));
	z-index: 20;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 10px 14px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.16);
	border: 1px solid rgba(255, 192, 203, 0.35);
	backdrop-filter: blur(18px);
	-webkit-backdrop-filter: blur(18px);
	color: #ffffff !important;
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif !important;
	font-size: 0.95rem !important;
	font-weight: 600 !important;
	letter-spacing: -0.01em !important;
	text-decoration: none !important;
	text-shadow: 0 1px 3px rgba(0, 0, 0, 0.35);
	transition: transform 0.15s ease, background 0.2s ease, border-color 0.2s ease;
}
.template-get-started .gs-back-home:hover {
	transform: translateY(-1px);
	background: rgba(255, 255, 255, 0.22);
	border-color: rgba(255, 192, 203, 0.6);
	color: #ffffff !important;
}
.get-started-form-wrap {
	display: flex;
	justify-content: center;
}
.get-started-lead-form {
	width: 100%;
	max-width: 760px;
	margin: 0 auto;
	position: relative;
}
/* Bot honeypot: off-screen; leave unfilled by real visitors */
.ln-honeypot {
	position: absolute !important;
	left: -10000px !important;
	width: 1px !important;
	height: 1px !important;
	overflow: hidden !important;
	clip: rect(0, 0, 0, 0) !important;
	white-space: nowrap !important;
	border: 0 !important;
	padding: 0 !important;
	margin: 0 !important;
}

.gs-form-disabled-banner {
	margin: 0 0 1rem;
	padding: 0.85rem 1rem;
	border-radius: 12px;
	background: rgba(20, 24, 30, 0.55);
	border: 1px solid rgba(255, 200, 210, 0.35);
	color: #fff;
	font-size: 0.95rem;
	line-height: 1.45;
	text-align: left;
}

.get-started-form-slot {
	display: grid;
	gap: 14px;
}

/* Standalone shell + Get-started page (clears sticky header; natural document height) */
.hero-area.hero-bg.hero-get-started.ln-get-started-single.ln-get-started-shell {
	align-items: flex-start;
	box-sizing: border-box;
	min-height: auto;
	height: auto !important;
	padding-top: clamp(5.5rem, 3.25rem + 6vw, 7.75rem);
	padding-bottom: clamp(2.25rem, 4vw, 3.5rem);
}
.hero-area.hero-bg.hero-get-started.ln-get-started-shell > .container.ln-get-started-page-inner {
	position: relative;
	z-index: 2;
	height: auto !important;
	min-height: 0 !important;
	padding-top: 0.35rem;
	box-sizing: border-box;
}
.ln-get-started-shell.hero-area.hero-bg [class*="col-"] {
	height: auto !important;
	min-height: 0 !important;
}
.ln-get-started-shell .hero-text.ln-get-started-hero-text {
	display: block !important;
	height: auto !important;
	width: 100%;
}
.ln-get-started-shell .hero-text-tablecell {
	display: block !important;
	height: auto !important;
	vertical-align: top !important;
}
.ln-get-started-shell .hero-text-with-bg {
	max-width: 920px !important;
	padding: 0.65rem 1rem 2rem !important;
	margin-left: auto !important;
	margin-right: auto !important;
	background: transparent !important;
	backdrop-filter: none !important;
	-webkit-backdrop-filter: none !important;
	box-shadow: none !important;
	border: none !important;
}

.ln-get-started-back.gs-back-home {
	position: relative;
	top: auto;
	left: auto;
	z-index: 3;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	align-self: flex-start;
	margin: 0 0 1rem;
	padding: 10px 14px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.16);
	border: 1px solid rgba(255, 192, 203, 0.35);
	backdrop-filter: blur(18px);
	-webkit-backdrop-filter: blur(18px);
	color: #ffffff !important;
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif !important;
	font-size: 0.95rem !important;
	font-weight: 600 !important;
	letter-spacing: -0.01em !important;
	text-decoration: none !important;
	text-shadow: 0 1px 3px rgba(0, 0, 0, 0.35);
	transition: transform 0.15s ease, background 0.2s ease, border-color 0.2s ease;
}
.ln-get-started-back.gs-back-home:hover {
	transform: translateY(-1px);
	background: rgba(255, 255, 255, 0.22);
	border-color: rgba(255, 192, 203, 0.6);
	color: #ffffff !important;
}

.gs-category-field.gs-field {
	max-width: 100% !important;
	width: 100%;
}
.gs-field--flush {
	width: 100%;
	justify-self: stretch;
}
.gs-fields--notes {
	margin-top: 0;
	max-width: 100%;
	justify-items: stretch;
}
.gs-fields--notes .gs-field {
	max-width: 100% !important;
}
.gs-category-detail {
	margin-top: 0.75rem;
	padding: 0.9rem 1rem;
	border-radius: 16px;
	text-align: left;
	background: rgba(0, 0, 0, 0.24);
	border: 1px solid rgba(255, 192, 203, 0.38);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
}
.gs-category-detail__text {
	margin: 0;
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif !important;
	font-size: 0.9rem !important;
	line-height: 1.5 !important;
	font-weight: 500 !important;
	color: rgba(255, 255, 255, 0.93) !important;
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.22);
}

@media (max-width: 575.98px) {
	.hero-area.hero-bg.hero-get-started.ln-get-started-single.ln-get-started-shell {
		padding-top: clamp(5rem, 6vh + 4rem, 6.75rem);
	}
}

.gs-single-lead {
	margin: 0.35rem auto 0 !important;
	max-width: 38rem;
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif !important;
	font-size: 0.95rem !important;
	line-height: 1.45 !important;
	font-weight: 500 !important;
	color: rgba(255, 255, 255, 0.88) !important;
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.28);
	text-align: center;
}

.gs-single-stack {
	display: grid;
	gap: 1rem;
	width: 100%;
	margin-top: 0.35rem;
	text-align: left;
}

.gs-single-section {
	margin-top: 0.35rem;
	padding: 1.35rem 1.1rem 1.45rem;
	border-radius: 22px;
	box-sizing: border-box;
	border: 1px solid rgba(255, 192, 203, 0.22);
	box-shadow: 0 16px 46px rgba(12, 4, 8, 0.4);
	backdrop-filter: blur(18px);
	-webkit-backdrop-filter: blur(18px);
	width: 100%;
	max-width: 760px;
	margin-left: auto;
	margin-right: auto;
}

.gs-single-section-title {
	margin: 0 0 0.35rem !important;
	font-family: 'Cormorant Garamond', Georgia, 'Times New Roman', serif !important;
	font-size: 1.35rem !important;
	font-weight: 600 !important;
	letter-spacing: 0.02em !important;
	color: rgba(255, 255, 255, 0.96) !important;
	text-shadow: 0 1px 3px rgba(0, 0, 0, 0.35);
	text-align: left;
}

.gs-question.gs-question--inline {
	margin-top: 0 !important;
	margin-bottom: 0.35rem !important;
	font-size: 0.92rem !important;
	font-weight: 500 !important;
	opacity: 0.95;
}

.gs-single-actions {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: 0.65rem;
	margin-top: 0.35rem;
	max-width: 760px;
	margin-left: auto;
	margin-right: auto;
	width: 100%;
}

.gs-single-submit {
	width: 100%;
	min-width: 0 !important;
	justify-content: center;
}

.gs-single-submit:disabled {
	opacity: 0.62;
	cursor: not-allowed;
}

.gs-single-hint {
	margin: 0 !important;
	font-size: 0.82rem !important;
	line-height: 1.45 !important;
	color: rgba(255, 255, 255, 0.85) !important;
	text-align: center;
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.25);
}

.gs-success {
	margin-top: 1rem;
	padding: 1.5rem 1.25rem 1.65rem;
	border-radius: 22px;
	text-align: center;
	max-width: 560px;
	margin-left: auto;
	margin-right: auto;
	border: 1px solid rgba(186, 232, 208, 0.55);
	background: rgba(12, 42, 28, 0.42);
	backdrop-filter: blur(18px);
	-webkit-backdrop-filter: blur(18px);
	box-shadow: 0 16px 46px rgba(12, 4, 8, 0.35);
}

.gs-success__title {
	margin: 0 0 0.5rem !important;
	font-family: 'Cormorant Garamond', Georgia, 'Times New Roman', serif !important;
	font-size: 1.65rem !important;
	font-weight: 600 !important;
	color: rgba(255, 255, 255, 0.96) !important;
}

.gs-success__text {
	margin: 0 0 1.15rem !important;
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif !important;
	font-size: 0.98rem !important;
	line-height: 1.5 !important;
	color: rgba(255, 255, 255, 0.9) !important;
}

.gs-success__home {
	display: inline-flex !important;
	justify-content: center;
	align-items: center;
	min-width: 200px;
	text-decoration: none !important;
}

/* (gs-title/gs-subtitle removed in favor of hero heading styles) */

/* Compact bar + % at end (no step labels in UI) */
.gs-progress {
	padding: 5px 10px;
	border-radius: 10px;
	background: rgba(255, 255, 255, 0.1);
	border: 1px solid rgba(255, 192, 203, 0.22);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	box-shadow: 0 6px 20px rgba(0, 0, 0, 0.14);
	text-align: left;
}
.gs-progress__row {
	display: flex;
	align-items: center;
	gap: 8px;
	min-width: 0;
}
.gs-progress__pct {
	flex-shrink: 0;
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif !important;
	font-weight: 700 !important;
	font-size: 0.75rem !important;
	letter-spacing: 0.02em !important;
	font-variant-numeric: tabular-nums;
	color: rgba(255, 255, 255, 0.9) !important;
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.35);
	line-height: 1;
	min-width: 2.25rem;
	text-align: right;
}
/* Native <progress> — slim inline track */
.gs-native-progress {
	-webkit-appearance: none;
	appearance: none;
	flex: 1 1 auto;
	min-width: 0;
	width: auto;
	display: block;
	height: 3px;
	margin: 0;
	border: none;
	border-radius: 999px;
	overflow: hidden;
	background: rgba(255, 255, 255, 0.32);
	box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.28);
}
.gs-native-progress::-webkit-progress-bar {
	background: rgba(255, 255, 255, 0.35);
	border-radius: 999px;
}
.gs-native-progress::-webkit-progress-value {
	background: var(--ln-rose);
	border-radius: 999px;
	box-shadow: 0 0 4px rgba(255, 141, 161, 0.35);
}
.gs-native-progress::-moz-progress-bar {
	background: var(--ln-rose);
	border-radius: 999px;
	box-shadow: 0 0 4px rgba(255, 141, 161, 0.35);
}

.gs-categories {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 350px));
	column-gap: 12px;
	row-gap: 12px;
	margin-top: 8px;
	align-items: stretch;
	justify-content: center;
	width: 100%;
	max-width: 712px;
	margin-left: auto;
	margin-right: auto;
}

.gs-wizard {
	display: grid;
	gap: 12px;
	width: 100%;
	overflow: hidden; /* prevents the 300% slide track from stretching layout */
}
.gs-question {
	margin: 0 0 2px !important;
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif !important;
	font-size: 1rem !important;
	font-weight: 600 !important;
	letter-spacing: -0.01em !important;
	color: rgba(255, 255, 255, 0.92) !important;
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
	text-align: left;
	max-width: 712px;
	margin-left: auto !important;
	margin-right: auto !important;
}
.gs-slides {
	display: block;
}
.gs-slide {
	display: none;
	width: 100%;
}
.gs-slide.is-active {
	display: block;
	animation: gsFadeUp 220ms ease both;
}
.gs-slide > * {
	width: 100%;
	max-width: 712px;
	margin-left: auto;
	margin-right: auto;
}

@keyframes gsFadeUp {
	from { opacity: 0; transform: translateY(8px); }
	to { opacity: 1; transform: translateY(0); }
}

.gs-fields {
	display: grid;
	gap: 12px;
	margin-top: 8px;
	max-width: 712px;
	width: 100%;
	margin-left: auto;
	margin-right: auto;
	justify-items: center;
}
.gs-fields--two {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}
.gs-field,
.gs-fieldset {
	padding: 14px 14px;
	border-radius: 16px;
	background: rgba(255, 255, 255, 0.14);
	border: 1px solid rgba(255, 192, 203, 0.35);
	backdrop-filter: blur(18px);
	-webkit-backdrop-filter: blur(18px);
	box-shadow: 0 18px 50px rgba(0, 0, 0, 0.22);
	text-align: left;
	width: 100%;
}
.gs-field {
	max-width: 712px;
}
.gs-fields .gs-field:first-child {
	max-width: 380px;
}
.gs-fieldset {
	margin: 0;
	max-width: 380px;
}
.gs-label {
	display: block;
	margin: 0 0 8px;
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif !important;
	font-weight: 700 !important;
	font-size: 0.95rem !important;
	letter-spacing: -0.01em !important;
	color: #ffffff !important;
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
}
.gs-input {
	width: 100%;
	height: 46px;
	padding: 10px 14px;
	border-radius: 12px;
	border: 1px solid rgba(255, 255, 255, 0.35);
	background: rgba(0, 0, 0, 0.18);
	color: #ffffff;
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	outline: none;
}
.gs-input:focus {
	border-color: rgba(255, 192, 203, 0.85);
	box-shadow: 0 0 0 4px rgba(255, 192, 203, 0.35);
}
.gs-input::placeholder {
	color: rgba(255, 255, 255, 0.7);
}
textarea.gs-input.gs-textarea {
	min-height: 7rem;
	height: auto;
	resize: vertical;
	line-height: 1.45;
	padding-top: 12px;
	padding-bottom: 12px;
}

.gs-choice-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 10px;
}
.gs-choice {
	display: inline-flex;
	align-items: center;
	justify-content: flex-start;
	gap: 10px;
	padding: 12px 12px;
	border-radius: 14px;
	border: 1px solid rgba(255, 255, 255, 0.28);
	background: rgba(0, 0, 0, 0.16);
	cursor: pointer;
	transition: transform 0.15s ease, border-color 0.2s ease, background 0.2s ease;
	user-select: none;
}
.gs-choice:hover {
	transform: translateY(-1px);
	border-color: rgba(255, 192, 203, 0.65);
}
.gs-choice input {
	accent-color: var(--ln-rose);
}
.gs-choice span {
	color: rgba(255, 255, 255, 0.92);
	font-weight: 600;
	text-align: left;
}
.gs-choice:has(input:checked) {
	background: rgba(255, 141, 161, 0.2);
	border-color: rgba(255, 141, 161, 0.75);
}

.gs-actions {
	margin-top: 10px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 12px;
}
.gs-back {
	min-width: 120px;
	height: 48px;
	padding: 0 16px;
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, 0.35);
	background: rgba(255, 255, 255, 0.12);
	color: #ffffff;
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	font-weight: 700;
	cursor: pointer;
	backdrop-filter: blur(18px);
	-webkit-backdrop-filter: blur(18px);
}
.gs-back:disabled {
	opacity: 0.55;
	cursor: not-allowed;
}
.gs-next,
.gs-submit {
	min-width: 220px;
}

.gs-error {
	margin: 0 !important;
	padding: 10px 12px;
	border-radius: 14px;
	background: rgba(255, 141, 161, 0.18);
	border: 1px solid rgba(255, 141, 161, 0.55);
	color: #ffffff;
	text-align: left;
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
}

@media (max-width: 992px) {
	.gs-fields--two { grid-template-columns: 1fr; }
	.gs-choice-grid { grid-template-columns: 1fr; }
	.gs-actions { flex-direction: column; align-items: stretch; }
	.gs-back, .gs-next, .gs-submit { width: 100%; }
	.gs-question, .gs-fields { max-width: 100%; }
	.gs-slide > * { max-width: 100%; }
}
.gs-card {
	position: relative;
	display: grid;
	grid-template-columns: 22px 1fr;
	column-gap: 12px;
	row-gap: 4px;
	align-items: start;
	padding: 9px 9px;
	box-sizing: border-box;
	border-radius: 16px;
	width: 100%;
	max-width: 350px;
	background: rgba(255, 255, 255, 0.14);
	border: 1px solid rgba(255, 192, 203, 0.35);
	backdrop-filter: blur(18px);
	-webkit-backdrop-filter: blur(18px);
	box-shadow: 0 18px 50px rgba(0, 0, 0, 0.22);
	cursor: pointer;
	transition: transform 0.15s ease, box-shadow 0.2s ease, border-color 0.2s ease;
	user-select: none;
	text-align: left;
}
.gs-card:hover {
	transform: translateY(-2px);
	border-color: rgba(255, 192, 203, 0.7);
	box-shadow: 0 22px 60px rgba(0, 0, 0, 0.26);
}
.gs-checkbox {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}
.gs-check {
	width: 22px;
	height: 22px;
	border-radius: 8px;
	border: 2px solid rgba(255, 255, 255, 0.7);
	background: rgba(255, 255, 255, 0.12);
	box-shadow: inset 0 0 0 3px rgba(0, 0, 0, 0.08);
	margin-top: 2px;
}
.gs-card__title {
	grid-column: 2;
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif !important;
	font-weight: 700 !important;
	font-size: 1.02rem !important;
	letter-spacing: -0.02em !important;
	color: #ffffff !important;
	line-height: 1.2 !important;
}
.gs-card__subs {
	grid-column: 2;
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif !important;
	font-weight: 400 !important;
	font-size: 0.86rem !important;
	line-height: 1.4 !important;
	color: rgba(255, 255, 255, 0.86) !important;
	text-wrap: balance;
}
.gs-checkbox:focus-visible + .gs-check {
	outline: none;
	box-shadow: 0 0 0 4px rgba(255, 192, 203, 0.55), inset 0 0 0 3px #ffffff;
}
.gs-checkbox:checked + .gs-check {
	background: #ff8da1;
	border-color: rgba(255, 255, 255, 0.9);
	box-shadow: inset 0 0 0 3px rgba(0, 0, 0, 0.12), 0 12px 26px rgba(255, 141, 161, 0.28);
}
.gs-checkbox:checked + .gs-check::after {
	content: "";
	position: absolute;
	width: 6px;
	height: 10px;
	border: solid #ffffff;
	border-width: 0 2px 2px 0;
	transform: translate(7px, 4px) rotate(45deg);
}
.gs-checkbox:checked ~ .gs-card__title {
	color: #ffffff !important;
}
.gs-card:has(.gs-checkbox:checked) {
	border-color: rgba(255, 141, 161, 0.75);
	background: rgba(255, 141, 161, 0.18);
}

.gs-actions {
	margin-top: 6px;
	display: flex;
	justify-content: center;
}
.gs-submit {
	min-width: 220px;
	justify-content: center;
}

@media (max-width: 992px) {
	.gs-categories { grid-template-columns: repeat(2, minmax(0, 1fr)); justify-content: stretch; }
}
@media (max-width: 576px) {
	.gs-categories { grid-template-columns: 1fr; }
}
.hero-badge {
	display: inline-block;
	font-family: 'DM Sans', sans-serif !important;
	font-size: 0.75rem !important;
	font-weight: 500 !important;
	letter-spacing: 0.08em !important;
	text-transform: uppercase;
	color: #ff8da1 !important;
	background: rgba(255, 141, 161, 0.12) !important;
	padding: 0.4rem 0.85rem !important;
	border-radius: 100px !important;
	margin-bottom: 1.25rem !important;
}
.hero-area .hero-text-with-bg .hero-headline,
.hero-area .hero-text h1.hero-headline {
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif !important;
	font-size: clamp(1.75rem, 4.5vw, 2.5rem) !important;
	font-weight: 600 !important;
	letter-spacing: -0.04em !important;
	line-height: 1.2 !important;
	margin-bottom: 0.85rem !important;
	color: #ffffff !important;
	/* Thin letter edge only — no large glow */
	text-shadow: 0 1px 0 rgba(0, 0, 0, 0.32), 0 1px 1px rgba(0, 0, 0, 0.28);
}
.hero-headline__accent {
	color: var(--ln-rose) !important;
	font-weight: 700 !important;
	letter-spacing: -0.03em !important;
	text-shadow: 0 1px 0 rgba(45, 22, 31, 0.35), 0 1px 1px rgba(0, 0, 0, 0.22) !important;
}
.hero-headline-sub {
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif !important;
	font-size: clamp(1.05rem, 2.8vw, 1.25rem) !important;
	font-weight: 500 !important;
	letter-spacing: -0.02em !important;
	line-height: 1.35 !important;
	margin: 0.35rem 0 0 !important;
	color: rgba(255, 255, 255, 0.92) !important;
	text-shadow: 0 1px 0 rgba(0, 0, 0, 0.28), 0 1px 1px rgba(0, 0, 0, 0.22) !important;
}
.hero-area .hero-text-with-bg .hero-description {
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif !important;
	font-size: 1.0625rem !important;
	font-weight: 400 !important;
	letter-spacing: -0.01em !important;
	line-height: 1.55 !important;
	color: #475569 !important;
	margin-bottom: 2rem !important;
	max-width: 100% !important;
	margin-left: auto !important;
	margin-right: auto !important;
}
/* Zip form – pill style, modern */
.hero-zip-form {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	max-width: 400px;
	margin: 0 auto 1rem;
}
.hero-zip-form input {
	flex: 1;
	min-width: 0;
	padding: 0.9rem 1.25rem;
	font-size: 1rem;
	font-weight: 400;
	font-family: 'DM Sans', sans-serif;
	border: 2px solid #cbd5e1;
	background: #f8fafc;
	color: #0f172a;
	border-radius: 100px;
	transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}
.hero-zip-form input::placeholder {
	color: #64748b;
}
.hero-zip-form input:focus {
	outline: none;
	border-color: var(--ln-rose);
	background: var(--ln-white);
	box-shadow: 0 0 0 3px rgba(255, 192, 203, 0.45);
}
a.hero-zip-btn {
	text-decoration: none;
}
.hero-zip-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.35rem;
	padding: 0.9rem 1.5rem;
	font-size: 1rem;
	font-weight: 600;
	font-family: 'DM Sans', sans-serif;
	letter-spacing: -0.01em;
	border: none;
	background: var(--ln-rose);
	color: var(--ln-white);
	border-radius: 100px;
	cursor: pointer;
	white-space: nowrap;
	text-align: center;
	transition: background 0.2s ease, color 0.2s ease, transform 0.15s ease, box-shadow 0.2s ease;
	box-shadow: 0 2px 8px rgba(255, 141, 161, 0.35);
	-webkit-appearance: none;
	appearance: none;
	-webkit-tap-highlight-color: transparent;
}
.hero-zip-btn:focus,
.hero-zip-btn:active {
	outline: none;
	border: none;
	box-shadow: 0 2px 8px rgba(255, 141, 161, 0.35);
}
.hero-zip-btn:focus-visible {
	outline: 2px solid rgba(255, 255, 255, 0.95);
	outline-offset: 3px;
	box-shadow: 0 0 0 3px rgba(255, 141, 161, 0.4), 0 2px 8px rgba(255, 141, 161, 0.35);
}
.hero-zip-btn:hover {
	outline: none;
	border: none;
	background: var(--ln-blush);
	color: var(--ln-rose);
	transform: translateY(-1px);
	box-shadow: 0 4px 12px rgba(255, 141, 161, 0.3);
}
.hero-zip-btn:disabled {
	opacity: 0.6;
	cursor: not-allowed;
	transform: none;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.18);
}
.hero-zip-arrow {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	opacity: 0.92;
	vertical-align: middle;
	transition: transform 0.25s ease;
}
.hero-zip-rose {
	display: block;
	flex-shrink: 0;
	overflow: visible;
}
.hero-zip-btn:hover .hero-zip-arrow {
	transform: translateX(3px);
}
.hero-trust {
	font-family: 'DM Sans', sans-serif !important;
	font-size: 0.8125rem !important;
	font-weight: 400 !important;
	color: #ffffff !important;
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.35), 0 2px 12px rgba(0, 0, 0, 0.2);
	margin: 0 !important;
}

/* About template — thin image banner (≤25vh); optional --banner-only = image only, no hero card / CTA */
.hero-area.hero-bg.ln-about-hero.ln-about-hero--image {
	height: min(25vh, 220px);
	max-height: 25vh;
	min-height: 5.5rem;
	display: flex;
	align-items: center;
	overflow: hidden;
	background-size: cover;
	background-position: center center;
	background-repeat: no-repeat;
	background-color: #3a1c26;
}
.hero-area.hero-bg.ln-about-hero.ln-about-hero--image.ln-about-hero--banner-only {
	display: block;
	position: relative;
}
.hero-area.hero-bg.ln-about-hero.ln-about-hero--image::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 0;
	background: linear-gradient(180deg, rgba(45, 22, 31, 0.35) 0%, rgba(14, 5, 9, 0.72) 100%);
	pointer-events: none;
}
@media (max-width: 768px) {
	.hero-area.hero-bg.ln-about-hero.ln-about-hero--image {
		height: min(22vh, 180px);
		max-height: 25vh;
		min-height: 5rem;
	}
}

/* Home – Linda Novia about strip (replaces generic Bootstrap block) */
.ln-about-section {
	position: relative;
	background: linear-gradient(180deg, var(--ln-surface-0) 0%, var(--ln-surface-rose) 40%, var(--ln-surface-blush) 100%);
	border-top: 1px solid var(--ln-hairline-rose);
	border-bottom: 1px solid rgba(255, 192, 203, 0.18);
	overflow-x: clip;
}
/* Contact page: dusty gray–rose band (stronger contrast than white-on-blush) */
.ln-about-section.ln-about-section--contact {
	background: linear-gradient(
		180deg,
		#d4c9ce 0%,
		#dfd4d8 22%,
		#e8dfe3 50%,
		#efe7ea 100%
	);
	border-top: 1px solid rgba(92, 47, 61, 0.14);
	border-bottom: 1px solid rgba(92, 47, 61, 0.12);
}
.ln-about-section.ln-about-section--contact .ln-kicker {
	color: var(--ln-plum-600);
}
.ln-about-section.ln-about-section--contact .ln-section-heading {
	color: #261018;
}
.ln-about-section.ln-about-section--contact .ln-section-lead {
	color: #3a3034;
}
.ln-about-section.ln-about-section--contact .ln-about-section__heading-accent {
	color: #d94868;
}
.ln-about-section__fluid {
	padding-left: 0;
	padding-right: 0;
}
.ln-about-section .title {
	margin-bottom: 0;
}
.ln-about-section__titles {
	text-align: left;
}
.ln-about-section__heading-accent {
	color: var(--ln-rose);
}
.ln-about-section__lead {
	margin-top: 1.15rem;
	margin-bottom: 1.35rem;
	max-width: 40rem;
}
.ln-about-section__lead-group {
	margin-top: 1.15rem;
	margin-bottom: 1.35rem;
	max-width: 42rem;
}
.ln-about-section__lead-group .ln-section-lead {
	margin: 0;
}
.ln-about-section__lead-group .ln-section-lead + .ln-section-lead {
	margin-top: 1.05rem;
}
.ln-about-section__lead-group .ln-section-lead strong {
	font-weight: 700;
	color: var(--ln-plum-600);
}
/* About strip – FAQ toggles (native <details>, SEO + FAQPage JSON-LD) */
.ln-about-faq {
	margin: 0 0 1.5rem;
}
.ln-about-faq__intro {
	margin: 0 0 0.65rem;
}
.ln-about-faq__list {
	display: grid;
	gap: 0.55rem;
}
.ln-about-faq__item {
	border-radius: 14px;
	border: none;
	background: rgba(255, 255, 255, 0.94);
	box-shadow:
		0 0 0 1px var(--ln-hairline-rose),
		0 4px 18px var(--ln-shadow-rose);
	overflow: hidden;
	transition: box-shadow 0.2s ease;
}
.ln-about-faq__item[open] {
	box-shadow:
		0 0 0 1px rgba(255, 141, 161, 0.32),
		0 8px 26px var(--ln-shadow-rose);
}
.ln-about-faq__summary {
	list-style: none;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem;
	min-height: 48px;
	padding: 0.95rem 1rem;
	box-sizing: border-box;
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	font-weight: 600;
	font-size: 0.9375rem;
	line-height: 1.35;
	color: var(--ln-plum);
	-webkit-user-select: none;
	user-select: none;
	touch-action: manipulation;
	-webkit-tap-highlight-color: rgba(255, 141, 161, 0.18);
}
.ln-about-faq__summary::-webkit-details-marker {
	display: none;
}
.ln-about-faq__summary::marker {
	content: '';
}
.ln-about-faq__summary:hover {
	color: var(--ln-rose);
}
.ln-about-faq__summary:focus {
	outline: none;
}
.ln-about-faq__summary:focus-visible {
	outline: 1px solid rgba(255, 141, 161, 0.55);
	outline-offset: 1px;
	border-radius: 10px;
}
.ln-about-faq__q {
	flex: 1;
	min-width: 0;
	text-align: left;
	overflow-wrap: break-word;
	word-wrap: break-word;
}
.ln-about-faq__toggle {
	flex-shrink: 0;
	width: 2.75rem;
	height: 2.75rem;
	min-width: 2.75rem;
	min-height: 2.75rem;
	border-radius: 50%;
	background: rgba(255, 192, 203, 0.35);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: background 0.2s ease, transform 0.25s ease;
}
.ln-about-faq__toggle::after {
	content: '';
	width: 0.45rem;
	height: 0.45rem;
	border-right: 1.5px solid var(--ln-rose);
	border-bottom: 1.5px solid var(--ln-rose);
	transform: translateY(-1px) rotate(45deg);
	transition: transform 0.25s ease;
}
.ln-about-faq__item[open] .ln-about-faq__toggle {
	background: rgba(255, 141, 161, 0.25);
}
.ln-about-faq__item[open] .ln-about-faq__toggle::after {
	transform: translateY(1px) rotate(-135deg);
}
.ln-about-faq__answer {
	padding: 0 1rem 1rem;
	border-top: 1px solid rgba(255, 192, 203, 0.14);
	background: linear-gradient(180deg, rgba(255, 248, 250, 0.65) 0%, rgba(255, 255, 255, 0.4) 100%);
}
.ln-about-faq__answer p {
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	font-size: 0.9375rem;
	line-height: 1.62;
	color: var(--ln-text);
	margin: 0.75rem 0 0;
	overflow-wrap: break-word;
	word-wrap: break-word;
}
.ln-about-faq__answer a {
	color: var(--ln-rose);
	font-weight: 600;
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 0.15em;
}
.ln-about-faq__answer a:hover {
	color: var(--ln-plum);
}
@media (prefers-reduced-motion: reduce) {
	.ln-about-faq__item,
	.ln-about-faq__toggle,
	.ln-about-faq__toggle::after {
		transition: none;
	}
}

/* Contact page form — template-contact.php */
.ln-contact-form-wrap {
	max-width: 100%;
	margin-top: 0.35rem;
	padding: 1.2rem 1.1rem 1.35rem;
	background: #ffffff;
	border: 1px solid rgba(92, 47, 61, 0.14);
	border-radius: 18px;
	box-shadow:
		0 1px 0 rgba(255, 255, 255, 0.75) inset,
		0 14px 42px rgba(45, 20, 31, 0.1);
	box-sizing: border-box;
}
.ln-contact-form-wrap > .ln-kicker {
	color: var(--ln-plum);
	margin-bottom: 0.5rem;
}
.ln-contact-form {
	display: grid;
	gap: 1rem;
	max-width: 100%;
	margin-top: 0.35rem;
	box-sizing: border-box;
}
.ln-contact-form__grid2 {
	display: grid;
	gap: 1rem;
}
@media (min-width: 576px) {
	.ln-contact-form__grid2 {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}
.ln-contact-form__field {
	min-width: 0;
}
.ln-contact-form__label {
	display: block;
	margin: 0 0 0.35rem;
	font-family: var(--ln-font-sans);
	font-weight: 700;
	font-size: 0.875rem;
	letter-spacing: -0.01em;
	color: #2a1f24;
}
.ln-contact-form__input,
.ln-contact-form__textarea,
.ln-contact-form__select {
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	min-height: 48px;
	padding: 0.65rem 0.85rem;
	font-family: var(--ln-font-sans);
	font-size: 16px;
	line-height: 1.4;
	color: #2a1f24;
	background: #faf8f9;
	border: 1px solid rgba(92, 47, 61, 0.28);
	border-radius: 12px;
	outline: none;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
	-webkit-tap-highlight-color: rgba(255, 141, 161, 0.2);
	touch-action: manipulation;
}
.ln-contact-form__select {
	padding-right: 2.25rem;
	cursor: pointer;
	appearance: none;
	-webkit-appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='9' viewBox='0 0 14 9'%3E%3Cpath fill='none' stroke='%235c2f3d' stroke-width='2' stroke-linecap='round' d='M1 1.5l6 6 6-6'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: calc(100% - 0.85rem) 50%;
	background-size: 14px 9px;
}
#lead-category-detail.ln-contact-form__category-detail,
.ln-contact-form__category-detail {
	margin: 0.85rem 0 0;
	padding: 1.25rem 1.35rem;
	text-align: center;
	border-radius: var(--ln-radius-md, 12px);
	background: rgba(92, 47, 61, 0.08);
	border: 1px solid rgba(92, 47, 61, 0.18);
}
#lead-category-detail .ln-contact-form__category-detail__label,
.ln-contact-form__category-detail__label {
	margin: 0 0 0.35rem;
	font-family: var(--ln-font-sans);
	font-size: 0.8125rem !important;
	font-weight: 700;
	line-height: 1.2;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--ln-plum-600, #7a3d4f);
}
#lead-category-detail .ln-contact-form__category-detail__name,
.ln-contact-form__category-detail__name {
	margin: 0 0 0.65rem;
	font-family: var(--ln-font-sans);
	font-size: 1.875rem !important;
	font-weight: 700 !important;
	line-height: 1.15 !important;
	letter-spacing: -0.02em;
	color: var(--ln-burgundy, #5c2f3d) !important;
}
#lead-category-detail .ln-contact-form__category-detail__types,
.ln-contact-form__category-detail__types {
	margin: 0;
	font-family: var(--ln-font-sans);
	font-size: 1.25rem !important;
	font-weight: 500 !important;
	line-height: 1.45 !important;
	color: #3a3034 !important;
}
@media (min-width: 576px) {
	#lead-category-detail .ln-contact-form__category-detail__name,
	.ln-contact-form__category-detail__name {
		font-size: 2.125rem !important;
	}
	#lead-category-detail .ln-contact-form__category-detail__types,
	.ln-contact-form__category-detail__types {
		font-size: 1.3125rem !important;
	}
}
.ln-contact-form__consent {
	margin: 0.15rem 0 0;
}
.ln-contact-form__consent-label {
	display: flex;
	align-items: flex-start;
	gap: 0.65rem;
	margin: 0;
	cursor: pointer;
	font-family: var(--ln-font-sans);
	font-size: 0.875rem;
	line-height: 1.5;
	color: #3a3034;
}
.ln-contact-form__consent-input {
	flex: 0 0 auto;
	width: 1.125rem;
	height: 1.125rem;
	margin: 0.2rem 0 0;
	accent-color: var(--ln-burgundy, #5c2f3d);
	cursor: pointer;
}
.ln-contact-form__consent-text {
	flex: 1;
	min-width: 0;
}
.ln-get-started-form-wrap .ln-contact-form__consent-label {
	font-size: 0.9rem;
}
.ln-contact-form .lead-form-error:not([hidden]) {
	margin-top: 0.25rem;
}
.ln-contact-form .lead-form-success:not([hidden]) {
	margin-top: 0.75rem;
}

/* Get-started — looser vertical rhythm between fields */
.ln-get-started-form-wrap .ln-contact-form,
.ln-get-started-form-wrap #lead-form-fields {
	display: grid;
	gap: 1.65rem;
}
.ln-get-started-form-wrap .ln-contact-form__grid2 {
	gap: 1.65rem;
}
.ln-get-started-form-wrap .ln-contact-form__label {
	margin-bottom: 0.55rem;
}
.ln-get-started-form-wrap #lead-category-detail.ln-contact-form__category-detail {
	margin-top: 0.75rem;
	padding: 1.35rem 1.5rem;
}
.ln-get-started-form-wrap #lead-category-detail .ln-contact-form__category-detail__name {
	font-size: 2rem !important;
}
.ln-get-started-form-wrap #lead-category-detail .ln-contact-form__category-detail__types {
	font-size: 1.3125rem !important;
}
@media (min-width: 576px) {
	.ln-get-started-form-wrap #lead-category-detail .ln-contact-form__category-detail__name {
		font-size: 2.25rem !important;
	}
	.ln-get-started-form-wrap #lead-category-detail .ln-contact-form__category-detail__types {
		font-size: 1.375rem !important;
	}
}
.ln-get-started-form-wrap .ln-contact-form__submit {
	margin-top: 0.35rem;
}

html {
	scroll-behavior: smooth;
}

.ln-home-lead-section {
	scroll-margin-top: calc(5.5rem + env(safe-area-inset-top, 0px));
}

.ln-get-started-section .ln-get-started__intro {
	margin-bottom: 1.35rem;
	max-width: 40rem;
}
.ln-get-started-section .ln-get-started__main {
	align-items: stretch;
}
.ln-get-started-section .ln-get-started__form-col {
	display: flex;
	flex-direction: column;
}
.ln-get-started-section .ln-get-started__form-col .ln-get-started-form-wrap {
	flex: 1 1 auto;
	width: 100%;
}
.ln-get-started-section .ln-get-started__media-col {
	display: flex;
	align-self: stretch;
}
.ln-get-started__figure {
	flex: 1 1 auto;
	width: 100%;
	margin: 0;
	min-height: clamp(280px, 52vw, 520px);
	border-radius: 24px;
	overflow: hidden;
	box-shadow:
		0 0 0 1px rgba(255, 141, 161, 0.2),
		0 20px 48px var(--ln-shadow-plum);
	background: var(--ln-blush);
}
.ln-get-started__figure-img {
	display: block;
	width: 100%;
	height: 100%;
	min-height: inherit;
	object-fit: cover;
	object-position: center center;
}
@media (max-width: 991.98px) {
	.ln-get-started-section .ln-get-started__media-col {
		margin-top: 0.25rem;
	}
	.ln-get-started__figure {
		min-height: clamp(220px, 55vw, 360px);
		max-width: 420px;
		margin-left: auto;
		margin-right: auto;
	}
}

/* Lead form + home hero — phones & notches */
@media (max-width: 767.98px) {
	.hero-area.hero-bg.ln-home-hero {
		min-height: min(82dvh, 540px);
		padding-top: env(safe-area-inset-top, 0px);
		align-items: center;
	}
	.hero-area.hero-bg.ln-home-hero .container {
		padding-left: max(1rem, env(safe-area-inset-left, 0px));
		padding-right: max(1rem, env(safe-area-inset-right, 0px));
	}
	.hero-area.hero-bg.ln-home-hero .hero-text-with-bg {
		padding: 1.65rem 1.15rem 1.85rem !important;
		border-radius: 18px !important;
		max-width: 100% !important;
	}
	.hero-area.hero-bg.ln-home-hero .hero-trust {
		font-size: 0.875rem;
		line-height: 1.5;
		margin-top: 0.35rem;
	}

	.ln-home-lead-section,
	.ln-get-started-section {
		scroll-margin-top: calc(4.75rem + env(safe-area-inset-top, 0px));
		padding-bottom: max(5.75rem, calc(4.25rem + env(safe-area-inset-bottom, 0px)));
	}
	.ln-get-started-section .container.py-4.py-lg-5,
	.ln-home-lead-section .container.py-4.py-lg-5 {
		padding-top: 1.2rem;
		padding-bottom: 1.25rem;
		padding-left: max(1rem, env(safe-area-inset-left, 0px));
		padding-right: max(1rem, env(safe-area-inset-right, 0px));
	}
	.ln-get-started-section .ln-section-heading {
		font-size: clamp(1.32rem, 5.5vw, 1.8rem);
		line-height: 1.22;
		overflow-wrap: break-word;
	}
	.ln-get-started-section .ln-get-started__intro {
		margin-bottom: 0.95rem;
	}
	.ln-get-started-section .row.g-4.g-lg-5 {
		--bs-gutter-x: 0.85rem;
		--bs-gutter-y: 1rem;
	}
	.ln-get-started-form-wrap.ln-contact-form-wrap {
		padding: 1rem 0.85rem 1.1rem;
		border-radius: 16px;
	}
	.ln-get-started-form-wrap .ln-contact-form__submit,
	.ln-contact-form-wrap .ln-contact-form__submit {
		width: 100%;
		min-height: 48px;
		padding: 0.95rem 1.15rem;
		font-size: 1rem;
		justify-content: center;
	}
	.ln-contact-form__notice {
		font-size: 0.9rem;
		line-height: 1.5;
	}
}

@media (max-width: 575.98px) {
	.ln-get-started__figure {
		min-height: clamp(180px, 50vw, 280px);
		border-radius: 16px;
	}
	.ln-home-cards__btn {
		min-height: 48px;
		padding: 0.75rem 1.25rem;
	}
	.ln-services-picker__select {
		font-size: 16px;
		min-height: 48px;
		padding-top: 0.75rem;
		padding-bottom: 0.75rem;
	}
}

.ln-contact-form__textarea {
	min-height: 8.5rem;
	height: auto;
	resize: vertical;
	padding-top: 0.75rem;
	padding-bottom: 0.75rem;
}
.ln-contact-form__input::placeholder,
.ln-contact-form__textarea::placeholder {
	color: rgba(74, 58, 64, 0.55);
}
.ln-contact-form__input:focus,
.ln-contact-form__textarea:focus,
.ln-contact-form__select:focus {
	border-color: rgba(255, 141, 161, 0.85);
	box-shadow: 0 0 0 3px rgba(255, 141, 161, 0.25);
}
.ln-contact-form__submit {
	margin-top: 0.15rem;
	cursor: pointer;
	border: none;
	appearance: none;
	-webkit-appearance: none;
}
.ln-contact-form__submit:disabled {
	opacity: 0.65;
	cursor: not-allowed;
	transform: none;
	box-shadow: none;
}
.ln-contact-form__notice {
	margin: 0 0 0.75rem;
	padding: 0.75rem 1rem;
	border-radius: 12px;
	font-family: var(--ln-font-sans);
	font-size: 0.9375rem;
	line-height: 1.45;
}
.ln-contact-form__notice--success {
	background: rgba(34, 139, 34, 0.1);
	color: #1b5e20;
	border: 1px solid rgba(34, 139, 34, 0.28);
}
.ln-contact-form__notice--error {
	background: rgba(176, 0, 32, 0.08);
	color: #7f1d1d;
	border: 1px solid rgba(176, 0, 32, 0.22);
}
.ln-contact-form__alt {
	font-family: var(--ln-font-sans);
	font-size: 0.9rem;
	color: #4a3f44;
	text-align: center;
}
@media (min-width: 576px) {
	.ln-contact-form__alt {
		text-align: left;
	}
}
.ln-contact-form__alt-link {
	color: var(--ln-rose);
	font-weight: 600;
	text-decoration: none;
}
.ln-contact-form__alt-link:hover {
	text-decoration: underline;
	color: var(--ln-rose-deep);
}
.ln-contact-form__alt-sep {
	color: var(--ln-muted);
}

.ln-about-section__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 48px;
	min-width: 0;
	width: 100%;
	padding: 0.85rem 1rem;
	touch-action: manipulation;
	-webkit-tap-highlight-color: rgba(255, 141, 161, 0.2);
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	font-size: 1rem;
	font-weight: 600;
	letter-spacing: -0.01em;
	text-decoration: none;
	border-radius: 100px;
	transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease, transform 0.15s ease, box-shadow 0.2s ease;
	text-align: center;
	box-sizing: border-box;
}
.ln-about-section__btn--primary {
	background: var(--ln-rose);
	color: var(--ln-white);
	border: 1px solid rgba(255, 255, 255, 0.35);
	box-shadow: 0 2px 10px rgba(255, 141, 161, 0.28);
}
.ln-about-section__btn--primary:hover {
	background: var(--ln-blush);
	color: var(--ln-rose);
	border-color: rgba(255, 255, 255, 0.5);
	transform: translateY(-1px);
	box-shadow: 0 4px 14px rgba(255, 141, 161, 0.22);
}
.ln-about-section__btn--outline {
	background: var(--ln-white);
	color: var(--ln-rose);
	border: 1px solid rgba(255, 141, 161, 0.45);
}
.ln-about-section__btn--outline:hover {
	background: var(--ln-surface-rose);
	color: var(--ln-rose-deep);
	border-color: rgba(232, 116, 138, 0.55);
}
.ln-about-section__media {
	width: 100%;
	max-width: 420px;
	margin-left: auto;
	margin-right: auto;
	border-radius: 24px;
	min-height: clamp(220px, 52vw, 380px);
	aspect-ratio: 4 / 5;
	background: linear-gradient(150deg, var(--ln-blush) 0%, var(--ln-white) 45%, var(--ln-rose) 105%);
	border: none;
	box-shadow:
		0 0 0 1px rgba(255, 141, 161, 0.2),
		0 20px 48px var(--ln-shadow-plum);
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}
.ln-about-section__media--has-bg {
	background-color: var(--ln-blush);
}
@media (min-width: 992px) {
	.ln-about-section__media {
		margin-left: auto;
		margin-right: 0;
		max-width: none;
	}
	.ln-about-faq__toggle {
		width: 1.75rem;
		height: 1.75rem;
		min-width: 1.75rem;
		min-height: 1.75rem;
	}
}

/* About + FAQ: phones & small tablets, notches, thumb-friendly taps */
@media (max-width: 767.98px) {
	.ln-about-section .container.py-4.py-lg-5 {
		padding-top: 1.35rem;
		padding-bottom: 1.35rem;
		padding-left: max(1rem, env(safe-area-inset-left, 0px));
		padding-right: max(1rem, env(safe-area-inset-right, 0px));
	}
	.ln-about-section .ln-section-heading {
		font-size: clamp(1.28rem, 5.5vw, 1.75rem);
		line-height: 1.24;
		overflow-wrap: break-word;
	}
	.ln-about-section .ln-section-lead {
		font-size: 0.9375rem;
		line-height: 1.66;
		margin-top: 1rem;
		margin-bottom: 1.15rem;
		overflow-wrap: break-word;
	}
	.ln-about-faq {
		margin-bottom: 1.35rem;
	}
	.ln-about-faq__list {
		gap: 0.5rem;
	}
	.ln-about-faq__item {
		border-radius: 12px;
	}
	.ln-about-faq__summary {
		min-height: 52px;
		padding: 0.875rem 0.75rem;
		font-size: 0.9rem;
		line-height: 1.4;
		gap: 0.65rem;
	}
	.ln-about-faq__answer {
		padding: 0 0.75rem 0.95rem;
		padding-bottom: max(0.95rem, env(safe-area-inset-bottom, 0px));
	}
	.ln-about-faq__answer p {
		font-size: 0.9rem;
		line-height: 1.65;
	}
	.ln-about-section .row.g-2.g-sm-3 {
		--bs-gutter-y: 0.75rem;
	}
	.ln-about-section__btn {
		min-height: 48px;
		padding: 0.9rem 0.85rem;
		font-size: 0.9375rem;
	}
	.ln-about-section__media {
		border-radius: 18px;
		min-height: 200px;
	}
}

/* Home – portfolio grid (matches ln-home-cards: white cards, hairline shadow, muted type) */
.ln-team-section {
	position: relative;
	overflow-x: clip;
	background: linear-gradient(180deg, var(--ln-surface-blush) 0%, var(--ln-surface-0) 22%, var(--ln-surface-1) 52%, var(--ln-surface-0) 100%);
	border-top: 1px solid var(--ln-hairline-rose);
}
.ln-team-section__fluid {
	padding-left: 0;
	padding-right: 0;
}
.ln-team-section__intro {
	max-width: 38rem;
	margin-left: auto;
	margin-right: auto;
}
.ln-team-section__subhead {
	max-width: 38rem;
	margin-left: auto;
	margin-right: auto;
}
/* Magazine / portfolio page — multi-paragraph history under team heading */
.ln-magazine-history__copy {
	max-width: 44rem;
}
/* Magazine (portfolio) template: intro + copy use full container width like the card grid */
.ln-team-section--magazine .ln-team-section__intro {
	max-width: none;
	width: 100%;
	margin-left: 0;
	margin-right: 0;
}
.ln-team-section--magazine .ln-magazine-history__copy {
	max-width: none;
	width: 100%;
}
.ln-team-section--magazine .ln-team-section__subhead {
	max-width: none;
	width: 100%;
	margin-left: 0;
	margin-right: 0;
}

/* Online magazine flipbook (views/pages/online-magazine.php) */
.ln-magazine-intro {
	max-width: 46rem;
	margin-left: auto;
	margin-right: auto;
}
.ln-magazine-alert {
	border: 1px solid rgba(226, 69, 146, 0.35);
	border-radius: 14px;
	padding: 1.25rem;
	background: rgba(226, 69, 146, 0.06);
	color: #3a3a3a;
}
.ln-magazine-alert code {
	font-size: 0.85em;
	word-break: break-all;
}
.ln-magazine-toolbar {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem 0.75rem;
	align-items: center;
	justify-content: center;
	margin-bottom: 1.25rem;
}
.ln-magazine-btn {
	border: 1px solid rgba(226, 69, 146, 0.35);
	border-radius: 999px;
	padding: 0.45rem 0.9rem;
	background: #fff;
	color: #232323;
	font-weight: 600;
	font-size: 0.875rem;
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	cursor: pointer;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
	text-decoration: none;
}
.ln-magazine-btn:hover,
.ln-magazine-btn:focus {
	outline: none;
	border-color: rgba(226, 69, 146, 0.55);
	box-shadow: 0 0 0 3px rgba(226, 69, 146, 0.12);
}
.ln-magazine-btn--ghost {
	background: transparent;
}
.ln-magazine-btn--link {
	color: inherit;
}
.ln-magazine-btn__text {
	font-size: inherit;
}
@media (max-width: 575.98px) {
	.ln-magazine-btn .ln-magazine-btn__text {
		display: none;
	}
}
.ln-magazine-page-indicator {
	min-width: 5.5rem;
	text-align: center;
	font-weight: 700;
	color: #333;
}
.ln-magazine-stage-wrap {
	position: relative;
	background: linear-gradient(180deg, rgba(226, 69, 146, 0.06), transparent 38%);
	border: 1px solid rgba(226, 69, 146, 0.12);
	border-radius: 18px;
	padding: clamp(0.75rem, 2vw, 1.5rem);
	overflow: hidden;
}
.ln-magazine-flip-root {
	min-height: min(70vh, 640px);
}
.ln-magazine-flip-root:focus {
	outline: none;
	box-shadow: 0 0 0 3px rgba(226, 69, 146, 0.2);
	border-radius: 8px;
}
.ln-magazine-loading {
	position: absolute;
	inset: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.75rem;
	background: rgba(255, 255, 255, 0.92);
	z-index: 5;
	transition: opacity 0.35s ease;
}
.ln-magazine-loading.is-hidden {
	opacity: 0;
	pointer-events: none;
}
.ln-magazine-loading__ring {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	border: 3px solid rgba(226, 69, 146, 0.2);
	border-top-color: rgba(226, 69, 146, 0.85);
	animation: ln-mag-spin 0.9s linear infinite;
}
.ln-magazine-loading__text {
	margin: 0;
	font-weight: 600;
	color: #444;
}
@keyframes ln-mag-spin {
	to {
		transform: rotate(360deg);
	}
}
.ln-magazine-stage-wrap.ln-magazine--fullscreen {
	position: fixed;
	inset: 0;
	z-index: 9999;
	border-radius: 0;
	padding: 1rem;
	background: #1a1a1a;
}
.ln-magazine-stage-wrap.ln-magazine--fullscreen .ln-magazine-flip-root {
	min-height: calc(100vh - 6rem);
}

.ln-team-section__card {
	display: flex;
	flex-direction: column;
	height: 100%;
	background: var(--ln-surface-0);
	border: none;
	border-radius: 16px;
	overflow: hidden;
	box-shadow:
		0 0 0 1px var(--ln-hairline-dark),
		0 10px 36px var(--ln-shadow-plum);
	transition: box-shadow 0.2s ease, transform 0.2s ease;
}
.ln-team-section__card:hover {
	box-shadow:
		0 0 0 1px var(--ln-hairline-rose),
		0 16px 44px var(--ln-shadow-plum);
	transform: translateY(-3px);
}
.ln-team-section__media {
	position: relative;
	overflow: hidden;
	aspect-ratio: 4 / 5;
	background: var(--ln-surface-soft);
}
.ln-team-section__img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.45s ease;
}
.ln-team-section__card:hover .ln-team-section__img,
.ln-team-section__card:focus-within .ln-team-section__img {
	transform: scale(1.03);
}
.ln-team-section__body {
	padding: 1rem 1.15rem 1.2rem;
	border-top: 1px solid var(--ln-hairline-dark);
	flex: 1;
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: 0.2rem;
}
.ln-team-section__name {
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	font-weight: 700;
	font-size: 1.05rem;
	line-height: 1.3;
	letter-spacing: -0.02em;
	color: var(--ln-plum);
	margin: 0;
}
.ln-team-section__tag {
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	font-size: 0.75rem;
	font-weight: 500;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--ln-muted);
	margin: 0;
}
.ln-team-section__fineprint {
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	font-size: 0.75rem;
	line-height: 1.5;
	color: var(--ln-muted);
	text-align: center;
	max-width: 28rem;
	margin: 2rem auto 0;
	padding-top: 1.25rem;
	border-top: 1px solid var(--ln-hairline-dark);
}
@media (prefers-reduced-motion: reduce) {
	.ln-team-section__card,
	.ln-team-section__card:hover,
	.ln-team-section__img {
		transition: none;
		transform: none;
	}
}
@media (max-width: 767.98px) {
	.ln-team-section .container {
		padding-left: max(1rem, env(safe-area-inset-left, 0px));
		padding-right: max(1rem, env(safe-area-inset-right, 0px));
	}
	.ln-team-section__card:hover {
		transform: none;
	}
	.ln-team-section__card:active {
		box-shadow:
			0 0 0 1px rgba(0, 0, 0, 0.06),
			0 12px 32px rgba(107, 45, 61, 0.08);
	}
}

/* Home – three feature cards (replaces inline “shop banner”; calm, readable, hairline edges) */
.ln-home-cards {
	position: relative;
	overflow-x: clip;
	background: linear-gradient(180deg, var(--ln-surface-0) 0%, var(--ln-surface-1) 50%, var(--ln-surface-0) 100%);
	border-top: 1px solid var(--ln-hairline-rose);
}
.ln-home-cards__intro {
	max-width: 36rem;
	margin-left: auto;
	margin-right: auto;
}
.ln-home-cards__section-lead {
	max-width: 36rem;
	margin-left: auto;
	margin-right: auto;
}
.ln-home-cards__item {
	height: 100%;
	padding: 1.5rem 1.5rem 1.6rem;
	border-radius: 16px;
	background: var(--ln-surface-0);
	border: none;
	box-shadow:
		0 0 0 1px var(--ln-hairline-dark),
		0 10px 36px var(--ln-shadow-plum);
	transition: box-shadow 0.2s ease, transform 0.2s ease;
}
.ln-home-cards__item:hover {
	box-shadow:
		0 0 0 1px var(--ln-hairline-rose),
		0 14px 40px var(--ln-shadow-plum);
	transform: translateY(-2px);
}
.ln-home-cards__item--soft {
	background: var(--ln-surface-soft);
	box-shadow:
		0 0 0 1px var(--ln-hairline-rose),
		0 10px 36px var(--ln-shadow-plum);
}
.ln-home-cards__item--soft:hover {
	box-shadow:
		0 0 0 1px rgba(255, 141, 161, 0.28),
		0 14px 40px var(--ln-shadow-plum);
}
.ln-home-cards__item--cta {
	background: linear-gradient(165deg, var(--ln-surface-0) 0%, var(--ln-surface-rose) 55%, var(--ln-surface-soft) 100%);
	box-shadow:
		0 0 0 1px var(--ln-hairline-rose),
		0 10px 36px var(--ln-shadow-plum);
}
.ln-home-cards__item--cta:hover {
	box-shadow:
		0 0 0 1px rgba(255, 141, 161, 0.28),
		0 14px 40px var(--ln-shadow-plum);
}
.ln-home-cards__item:focus-within {
	box-shadow:
		0 0 0 1px var(--ln-hairline-rose),
		0 14px 40px var(--ln-shadow-plum);
	transform: translateY(-2px);
}
.ln-home-cards__media {
	border-radius: 14px;
	overflow: hidden;
	background: var(--ln-surface-soft);
	box-shadow: 0 0 0 1px var(--ln-hairline-dark);
	aspect-ratio: 16 / 10;
	margin: 0 0 1.05rem;
}
.ln-home-cards__img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.35s ease;
}
.ln-home-cards__item:hover .ln-home-cards__img,
.ln-home-cards__item:focus-within .ln-home-cards__img {
	transform: scale(1.03);
}
.ln-home-cards__title {
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	font-weight: 700;
	font-size: 1.2rem;
	line-height: 1.3;
	letter-spacing: -0.02em;
	color: var(--ln-plum);
	margin: 0 0 0.75rem;
}
.ln-home-cards__title--on-cta {
	color: var(--ln-plum-600);
}
.ln-home-cards__text {
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	font-size: 0.9375rem;
	line-height: 1.62;
	color: var(--ln-text-body);
	margin: 0;
}
.ln-home-cards__text--on-cta {
	color: var(--ln-text-body);
}
.ln-home-cards__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-top: 1.15rem;
	min-height: 46px;
	padding: 0.65rem 1.35rem;
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	font-size: 0.9375rem;
	font-weight: 600;
	letter-spacing: -0.01em;
	color: var(--ln-white);
	text-decoration: none;
	border-radius: 100px;
	border: none;
	background: var(--ln-rose);
	box-shadow: 0 2px 12px rgba(255, 141, 161, 0.28);
	transition: background 0.2s ease, color 0.2s ease, transform 0.15s ease, box-shadow 0.2s ease;
	touch-action: manipulation;
	opacity: 0;
	transform: translateY(6px);
	pointer-events: none;
}
.ln-home-cards__btn:focus {
	outline: none;
}
.ln-home-cards__btn:focus-visible {
	outline: 2px solid rgba(255, 141, 161, 0.6);
	outline-offset: 3px;
}
.ln-home-cards__item:hover .ln-home-cards__btn,
.ln-home-cards__item:focus-within .ln-home-cards__btn {
	opacity: 1;
	transform: translateY(0);
	pointer-events: auto;
}
.ln-home-cards__btn:hover {
	background: var(--ln-blush);
	color: var(--ln-rose);
	transform: translateY(-1px);
	box-shadow: 0 4px 16px rgba(255, 141, 161, 0.22);
}
@media (hover: none) {
	.ln-home-cards__btn {
		opacity: 1;
		transform: none;
		pointer-events: auto;
	}
}
@media (prefers-reduced-motion: reduce) {
	.ln-home-cards__item,
	.ln-home-cards__item:hover,
	.ln-home-cards__btn,
	.ln-home-cards__btn:hover,
	.ln-home-cards__img {
		transition: none;
		transform: none;
	}
}
@media (max-width: 767.98px) {
	.ln-home-cards .container {
		padding-left: max(1rem, env(safe-area-inset-left, 0px));
		padding-right: max(1rem, env(safe-area-inset-right, 0px));
	}
	.ln-home-cards__btn {
		min-height: 48px;
	}
	.ln-team-section .container {
		padding-left: max(1rem, env(safe-area-inset-left, 0px));
		padding-right: max(1rem, env(safe-area-inset-right, 0px));
	}
}

/* Home – vendor category bento (matches ln-* tokens) */
.ln-categories-section {
	position: relative;
	overflow-x: clip;
	background: linear-gradient(185deg, var(--ln-surface-0) 0%, var(--ln-surface-rose) 42%, var(--ln-surface-0) 100%);
	border-top: 1px solid var(--ln-hairline-rose);
}
.ln-categories-section__intro {
	max-width: 40rem;
	margin-left: auto;
	margin-right: auto;
}
.ln-categories-section__lead {
	max-width: 36rem;
	margin-left: auto;
	margin-right: auto;
}
.ln-categories-section__intro--wide {
	max-width: 52rem;
}
.ln-categories-section__lead--wide {
	max-width: 48rem;
}

/* Services page — tabbed category content (SEO long-form) */
.ln-services-tabs {
	margin-top: 0.25rem;
	min-width: 0;
	width: 100%;
}

.ln-services-picker {
	max-width: 32rem;
	margin: 0 auto 1.35rem;
	text-align: center;
}
.ln-services-picker__label {
	display: block;
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	font-weight: 700;
	font-size: 0.95rem;
	letter-spacing: -0.01em;
	color: var(--ln-plum);
	margin-bottom: 0.5rem;
}
.ln-services-picker__control {
	position: relative;
	max-width: 100%;
}
.ln-services-picker__select {
	display: block;
	width: 100%;
	max-width: 100%;
	margin: 0;
	padding: 0.65rem 2.35rem 0.65rem 1rem;
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	font-size: 0.9375rem;
	font-weight: 600;
	line-height: 1.35;
	color: var(--ln-plum);
	background-color: var(--ln-surface-0);
	border: 1px solid var(--ln-hairline-dark);
	border-radius: 14px;
	box-shadow: 0 1px 0 var(--ln-hairline-rose);
	cursor: pointer;
	appearance: none;
	-webkit-appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='9' viewBox='0 0 14 9'%3E%3Cpath fill='none' stroke='%235c2f3d' stroke-width='2' stroke-linecap='round' d='M1 1.5l6 6 6-6'/%3E%3C/svg%3E");
	background-position: calc(100% - 1rem) 50%;
	background-size: 14px 9px;
	background-repeat: no-repeat;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.ln-services-picker__select:hover {
	border-color: var(--ln-hairline-rose);
	box-shadow: 0 2px 12px var(--ln-shadow-plum);
}
.ln-services-picker__select:focus {
	outline: none;
	border-color: var(--ln-rose);
	box-shadow: 0 0 0 4px rgb(255 141 161 / 28%);
}
.ln-services-picker__hint {
	margin: 0.65rem 0 0;
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	font-size: 0.875rem;
	line-height: 1.45;
	color: rgb(74 54 67 / 88%);
	max-width: 28rem;
	margin-left: auto;
	margin-right: auto;
}

.ln-services-tabs__nav {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	justify-content: center;
	margin-bottom: 1.25rem;
	min-width: 0;
}
/* Mobile: show ALL tabs by wrapping into rows (no horizontal scrolling). */
@media (max-width: 991.98px) {
	.ln-services-tabs__nav {
		flex-wrap: wrap;
		justify-content: center;
		overflow: visible;
		padding-bottom: 0;
		gap: 0.45rem;
	}
	.ln-services-tabs__tab {
		flex: 1 1 calc(50% - 0.45rem);
		justify-content: center;
		min-height: 44px;
		padding: 0.5rem 0.75rem;
	}
}

@media (max-width: 420px) {
	.ln-services-tabs__tab {
		flex-basis: 100%;
	}
}
.ln-services-tabs__tab {
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	padding: 0.5rem 0.85rem;
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	font-size: 0.8125rem;
	font-weight: 600;
	letter-spacing: -0.01em;
	color: var(--ln-plum);
	background: var(--ln-surface-0);
	border: 1px solid var(--ln-hairline-dark);
	border-radius: 999px;
	cursor: pointer;
	box-shadow: 0 1px 0 var(--ln-hairline-rose);
	transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
	touch-action: manipulation;
	-webkit-tap-highlight-color: transparent;
	appearance: none;
	-webkit-appearance: none;
}
/* Override Bootstrap Reboot `button:focus` (webkit focus ring reads as a black border on click). */
.ln-services-tabs__tab:focus {
	outline: none;
}
.ln-services-tabs__tab::-moz-focus-inner {
	border: 0;
	padding: 0;
}
.ln-services-tabs__tab i {
	font-size: 0.85rem;
	color: var(--ln-rose);
	opacity: 0.9;
}
.ln-services-tabs__tab:hover {
	border-color: var(--ln-hairline-rose);
	box-shadow: 0 2px 10px var(--ln-shadow-plum);
}
.ln-services-tabs__tab:focus-visible {
	outline: 2px solid var(--ln-rose);
	outline-offset: 2px;
}
.ln-services-tabs__tab.is-active {
	color: var(--ln-white);
	background: var(--ln-rose);
	border-color: var(--ln-rose);
	box-shadow: 0 2px 14px rgba(255, 141, 161, 0.35);
}
.ln-services-tabs__tab.is-active i {
	color: var(--ln-white);
	opacity: 1;
}
.ln-services-tabs__panels {
	background: var(--ln-surface-0);
	border-radius: 20px;
	padding: 1.35rem 1.25rem 1.5rem;
	border: none;
	border-top: 3px solid var(--ln-rose);
	box-shadow:
		0 0 0 1px var(--ln-hairline-dark),
		0 14px 40px var(--ln-shadow-plum);
}
@media (min-width: 768px) {
	.ln-services-tabs__panels {
		padding: 1.75rem 1.85rem 2rem;
	}
}
.ln-services-tabs__panel[hidden] {
	display: none !important;
}
.ln-services-tabs__panel-title {
	display: flex;
	align-items: flex-start;
	gap: 0.65rem;
	margin: 0 0 1rem;
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	font-weight: 700;
	font-size: clamp(1.05rem, 2.8vw, 1.2rem);
	line-height: 1.3;
	letter-spacing: -0.02em;
	color: var(--ln-plum);
	min-width: 0;
	flex-wrap: wrap;
}
.ln-services-tabs__panel-icon {
	flex-shrink: 0;
	width: 2.5rem;
	height: 2.5rem;
	border-radius: 12px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: rgba(255, 141, 161, 0.12);
	color: var(--ln-rose);
	font-size: 1rem;
}
.ln-services-tabs__p {
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	font-size: 0.9375rem;
	line-height: 1.65;
	color: var(--ln-text-soft);
	margin: 0 0 0.85rem;
}
.ln-services-tabs__subhead {
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	font-size: 0.8125rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--ln-muted);
	margin: 1.25rem 0 0.5rem;
}
.ln-services-tabs__list {
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	font-size: 0.875rem;
	line-height: 1.55;
	color: var(--ln-text);
	margin: 0;
	padding-left: 1.2rem;
}
.ln-services-tabs__list li {
	margin-bottom: 0.35rem;
}
.ln-services-tabs__list li:last-child {
	margin-bottom: 0;
}

.ln-services-tabs__gallery {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 0.65rem;
	margin-top: 1.65rem;
	padding-top: 1.35rem;
	border-top: 1px solid var(--ln-hairline-rose);
}
@media (min-width: 768px) {
	.ln-services-tabs__gallery {
		grid-template-columns: repeat(4, minmax(0, 1fr));
		gap: 0.85rem;
	}
}
.ln-services-tabs__gallery-item {
	margin: 0;
	padding: 0;
	border-radius: 12px;
	overflow: hidden;
	background: var(--ln-surface-rose);
	box-shadow: 0 0 0 1px var(--ln-hairline-dark);
}
.ln-services-tabs__gallery-img {
	display: block;
	width: 100%;
	max-width: 100%;
	height: auto;
	aspect-ratio: 255 / 388;
	object-fit: cover;
}

.ln-categories-section__bento {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1rem;
}
@media (min-width: 576px) {
	.ln-categories-section__bento {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}
@media (min-width: 1200px) {
	.ln-categories-section__bento {
		grid-template-columns: repeat(4, minmax(0, 1fr));
		gap: 1.15rem;
	}
}
.ln-cat-card {
	display: flex;
	flex-direction: column;
	min-height: 100%;
	background: var(--ln-surface-0);
	border-radius: 16px;
	padding: 1.25rem 1.2rem 1.4rem;
	border: none;
	border-top: 3px solid var(--ln-rose);
	box-shadow:
		0 0 0 1px var(--ln-hairline-dark),
		0 12px 36px var(--ln-shadow-plum);
	transition: box-shadow 0.2s ease, transform 0.2s ease;
}
.ln-cat-card:hover {
	transform: translateY(-3px);
	box-shadow:
		0 0 0 1px var(--ln-hairline-rose),
		0 18px 44px var(--ln-shadow-plum);
}
.ln-cat-card__top {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	margin-bottom: 0.85rem;
}
.ln-cat-card__icon {
	flex-shrink: 0;
	width: 2.5rem;
	height: 2.5rem;
	border-radius: 12px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: rgba(255, 141, 161, 0.12);
	color: var(--ln-rose);
	font-size: 1rem;
}
.ln-cat-card__title {
	flex: 1;
	min-width: 0;
	margin: 0;
	padding-top: 0.15rem;
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	font-weight: 700;
	font-size: 1.05rem;
	line-height: 1.28;
	letter-spacing: -0.02em;
	color: var(--ln-plum);
}
.ln-cat-card__desc {
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	font-size: 0.875rem;
	line-height: 1.58;
	color: var(--ln-text-soft);
	margin: 0 0 1rem;
	flex: 1;
}
.ln-cat-card__subs-label {
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	font-size: 0.6875rem;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--ln-muted);
	margin: 0 0 0.45rem;
}
.ln-cat-card__subs {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.45rem;
}
.ln-cat-card__subs li {
	margin: 0;
}
.ln-cat-card__pill {
	display: inline-block;
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	font-size: 0.75rem;
	font-weight: 500;
	line-height: 1.35;
	padding: 0.35rem 0.6rem;
	border-radius: 999px;
	color: var(--ln-text);
	background: var(--ln-surface-rose);
	border: 1px solid var(--ln-hairline-rose);
}
.ln-categories-section__cta {
	margin-top: 2.5rem;
}
.ln-categories-section__cta-inner {
	max-width: 40rem;
	margin: 0 auto;
	text-align: center;
	padding: 1.75rem 1.5rem;
	border-radius: 20px;
	background: linear-gradient(145deg, var(--ln-surface-0) 0%, var(--ln-surface-blush) 55%, var(--ln-surface-rose) 100%);
	box-shadow:
		0 0 0 1px var(--ln-hairline-rose),
		0 14px 40px var(--ln-shadow-plum);
}
.ln-categories-section__cta-title {
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	font-weight: 700;
	font-size: 1.15rem;
	color: var(--ln-plum);
	margin: 0 0 0.5rem;
}
.ln-categories-section__cta-text {
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	font-size: 0.9375rem;
	line-height: 1.6;
	color: var(--ln-text-soft);
	margin: 0 0 1.15rem;
}
.ln-categories-section__cta-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 48px;
	padding: 0.65rem 1.5rem;
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	font-size: 0.9375rem;
	font-weight: 600;
	letter-spacing: -0.01em;
	color: var(--ln-white);
	text-decoration: none;
	border-radius: 100px;
	background: var(--ln-rose);
	border: none;
	box-shadow: 0 2px 14px rgba(255, 141, 161, 0.3);
	transition: background 0.2s ease, color 0.2s ease, transform 0.15s ease, box-shadow 0.2s ease;
	touch-action: manipulation;
}
.ln-categories-section__cta-btn:hover {
	background: var(--ln-blush);
	color: var(--ln-rose);
	transform: translateY(-1px);
	box-shadow: 0 4px 18px rgba(255, 141, 161, 0.22);
}
@media (prefers-reduced-motion: reduce) {
	.ln-cat-card,
	.ln-cat-card:hover,
	.ln-categories-section__cta-btn,
	.ln-categories-section__cta-btn:hover,
	.ln-services-tabs__tab,
	.ln-services-tabs__tab:hover {
		transition: none;
		transform: none;
	}
	.ln-services-tabs__nav {
		scroll-snap-type: none;
	}
}
@media (max-width: 767.98px) {
	.ln-categories-section .container {
		padding-left: max(1rem, env(safe-area-inset-left, 0px));
		padding-right: max(1rem, env(safe-area-inset-right, 0px));
	}
	.ln-categories-section__intro--wide {
		max-width: 100%;
	}
	.ln-categories-section__lead--wide {
		max-width: 100%;
	}
	.ln-categories-section .ln-section-heading,
	.ln-categories-section .ln-section-lead {
		overflow-wrap: break-word;
	}
	.ln-services-tabs__panels {
		padding: 1.1rem 0.9rem 1.35rem;
		border-radius: 16px;
	}
	.ln-services-tabs__panel-title {
		font-size: clamp(1.02rem, 4.2vw, 1.15rem);
	}
	.ln-services-tabs__panel-icon {
		width: 2.35rem;
		height: 2.35rem;
		font-size: 0.95rem;
	}
	.ln-services-tabs__p,
	.ln-services-tabs__list {
		overflow-wrap: break-word;
	}
	.ln-services-tabs__list {
		padding-inline-start: 1.1rem;
	}
	.ln-services-tabs__gallery {
		gap: 0.5rem;
		margin-top: 1.35rem;
		padding-top: 1.1rem;
	}
	.ln-services-picker {
		padding-left: max(0.25rem, env(safe-area-inset-left, 0px));
		padding-right: max(0.25rem, env(safe-area-inset-right, 0px));
	}
	.ln-services-picker__select {
		font-size: 16px;
		min-height: 48px;
	}
	.ln-categories-section__cta-inner {
		padding-left: max(1.25rem, env(safe-area-inset-left, 0px));
		padding-right: max(1.25rem, env(safe-area-inset-right, 0px));
		padding-bottom: max(1.75rem, env(safe-area-inset-bottom, 0px));
	}
	.ln-cat-card:hover {
		transform: none;
	}
}

/* Footer — Poseify-style centered block, Linda Novia tokens */
.ln-footer.footer {
	background: linear-gradient(180deg, #4a2430 0%, #3a1c26 45%, #2d161f 100%);
	border-top: 1px solid rgba(255, 192, 203, 0.12);
	color: rgba(255, 255, 255, 0.92);
}
/* Footer wordmark — same clean letter edge as home hero (thin text-shadow, DM Sans) */
.ln-footer .hero-headline,
.ln-footer h1.hero-headline {
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif !important;
	font-size: clamp(1.75rem, 4.5vw, 2.5rem) !important;
	font-weight: 600 !important;
	letter-spacing: -0.04em !important;
	line-height: 1.2 !important;
	margin-bottom: 0.85rem !important;
	color: #ffffff !important;
}
.ln-footer .ln-footer__wordmark-link {
	color: #ffffff !important;
	text-decoration: none;
	transition: opacity 0.2s ease;
	display: inline-block;
	max-width: 100%;
	overflow-wrap: anywhere;
	word-break: normal;
	-webkit-tap-highlight-color: rgba(255, 141, 161, 0.22);
	touch-action: manipulation;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-shadow: 0 1px 0 rgba(0, 0, 0, 0.32), 0 1px 1px rgba(0, 0, 0, 0.28);
}
.ln-footer .ln-footer__wordmark-link .hero-headline__accent {
	color: var(--ln-rose) !important;
	font-weight: 700 !important;
	letter-spacing: -0.03em !important;
	text-shadow: 0 1px 0 rgba(45, 22, 31, 0.35), 0 1px 1px rgba(0, 0, 0, 0.22) !important;
}
.ln-footer .ln-footer__wordmark-link:hover {
	opacity: 0.92;
}
.ln-footer .ln-footer__wordmark-link:focus-visible {
	outline: 2px solid var(--ln-rose);
	outline-offset: 4px;
	border-radius: 4px;
}
.ln-footer__brand {
	text-decoration: none;
	line-height: 0;
}
.ln-footer__brand:focus-visible {
	outline: 2px solid var(--ln-rose);
	outline-offset: 4px;
	border-radius: 8px;
}
.ln-footer__logo {
	max-width: min(200px, 52vw);
	height: auto;
	display: block;
	margin: 0 auto;
	filter: brightness(1.05);
}
.ln-footer__tagline {
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	font-size: 0.9375rem;
	font-weight: 500;
	line-height: 1.5;
	color: rgba(255, 255, 255, 0.78);
	max-width: 26rem;
	margin-left: auto;
	margin-right: auto;
	overflow-wrap: anywhere;
	hyphens: auto;
	-webkit-hyphens: auto;
}
.ln-footer__social {
	gap: 0.65rem;
	row-gap: 0.75rem;
}
.ln-footer__social-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	min-width: 3rem;
	height: 3rem;
	padding: 0 1rem;
	border-radius: 999px;
	border: 2px solid rgba(255, 141, 161, 0.55);
	background: rgba(255, 255, 255, 0.04);
	color: #ffffff;
	font-size: 1.1rem;
	text-decoration: none;
	transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, transform 0.15s ease;
	touch-action: manipulation;
}
.ln-footer__social-label {
	font-size: 0.875rem;
	font-weight: 600;
	letter-spacing: 0.02em;
}

/* HTML site map page */
.ln-sitemap-section__lead {
	max-width: 36rem;
}
.ln-sitemap-list {
	list-style: none;
	margin: 0 auto;
	padding: 0;
	max-width: 42rem;
	display: grid;
	gap: 0.75rem;
}
.ln-sitemap-list__link {
	display: block;
	padding: 1rem 1.15rem;
	border: 1px solid rgba(226, 69, 146, 0.14);
	border-radius: 12px;
	background: #fff;
	text-decoration: none;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.ln-sitemap-list__link:hover {
	border-color: rgba(226, 69, 146, 0.35);
	box-shadow: 0 10px 28px rgba(226, 69, 146, 0.1);
}
.ln-sitemap-list__title {
	display: block;
	font-weight: 700;
	color: #2a2a2a;
	font-size: 1.05rem;
}
.ln-sitemap-list__path {
	display: block;
	margin-top: 0.25rem;
	font-size: 0.8rem;
	color: #7a7a7a;
	word-break: break-all;
}
.ln-sitemap-note {
	margin-top: 2rem;
	font-size: 0.875rem;
	color: #5b5b5b;
}
.ln-sitemap-note a {
	color: var(--ln-rose, #e24592);
}
@media (hover: hover) {
	.ln-footer__social-btn:hover {
		background: rgba(255, 141, 161, 0.18);
		border-color: var(--ln-blush);
		color: #ffffff;
		transform: translateY(-2px);
	}
}
.ln-footer__social-btn:active {
	background: rgba(255, 141, 161, 0.22);
	border-color: var(--ln-blush);
	color: #ffffff;
}
.ln-footer__social-btn:focus-visible {
	outline: 2px solid var(--ln-blush);
	outline-offset: 2px;
}
.ln-footer__links {
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	font-size: 0.875rem;
	font-weight: 500;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	column-gap: 0.2rem;
	row-gap: 0.35rem;
	max-width: 100%;
}
.ln-footer__links a {
	color: rgba(255, 255, 255, 0.88);
	text-decoration: none;
	margin: 0;
	padding: 0.5rem 0.45rem;
	min-height: 44px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: color 0.2s ease;
	-webkit-tap-highlight-color: rgba(255, 141, 161, 0.2);
	touch-action: manipulation;
	box-sizing: border-box;
}
.ln-footer__links a:hover {
	color: var(--ln-blush);
}
.ln-footer__links a:active {
	color: var(--ln-blush);
	opacity: 0.95;
}
.ln-footer__sep {
	color: rgba(255, 255, 255, 0.35);
	margin: 0;
	padding: 0 0.05rem;
	user-select: none;
	flex-shrink: 0;
	align-self: center;
	line-height: 1;
}
.ln-footer__copy {
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	font-size: 0.875rem;
	line-height: 1.55;
	color: rgba(255, 255, 255, 0.65);
	max-width: 100%;
	overflow-wrap: anywhere;
	padding: 0 0.25rem;
}
.ln-footer__copy-link {
	color: rgba(255, 255, 255, 0.92);
	text-decoration: none;
	border-bottom: 1px solid rgba(255, 141, 161, 0.45);
	padding: 0.15rem 0.1rem 2px;
	transition: color 0.2s ease, border-color 0.2s ease;
	-webkit-tap-highlight-color: rgba(255, 141, 161, 0.2);
	touch-action: manipulation;
	display: inline;
}
.ln-footer__copy-link:hover {
	color: var(--ln-blush);
	border-bottom-color: var(--ln-blush);
}

@media (min-width: 769px) {
	.ln-footer__links a {
		min-height: 0;
		padding: 0.2rem 0.35rem;
	}
}

@media (prefers-reduced-motion: reduce) {
	.ln-footer__social-btn {
		transition: none;
	}
	@media (hover: hover) {
		.ln-footer__social-btn:hover {
			transform: none;
		}
	}
	.ln-footer .ln-footer__wordmark-link {
		transition: none;
	}
}

.screen-reader-text {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}
@media (max-width: 992px) {
	body.template-get-started .hero-area.hero-get-started .container {
		padding-top: calc(env(safe-area-inset-top, 0px) + 3rem);
	}
	body.template-get-started .get-started-form-slot {
		gap: 10px;
	}
	body.template-get-started .gs-progress {
		padding: 4px 8px;
	}
	body.template-get-started .gs-progress__row {
		gap: 6px;
	}
	body.template-get-started .gs-native-progress {
		height: 3px;
	}
	body.template-get-started .gs-wizard {
		gap: 10px;
	}
	body.template-get-started .gs-categories {
		column-gap: 10px;
		row-gap: 10px;
	}
	body.template-get-started .gs-card__subs {
		line-height: 1.32 !important;
	}
}

@media (max-width: 768px) {
	.hero-area.hero-bg {
		min-height: 100vh;
		min-height: 100dvh; /* dynamic viewport for mobile browsers */
	}
	.hero-area .hero-video-bg {
		width: 100%;
		height: 100%;
		object-fit: cover;
		object-position: center;
	}
	.hero-area .hero-text-with-bg {
		padding: 2.25rem 1.5rem 2.5rem !important;
		border-radius: 20px !important;
	}
	body.template-get-started .hero-area.hero-get-started .container {
		padding-top: calc(env(safe-area-inset-top, 0px) + 2.85rem);
	}
	body.template-get-started .hero-area .hero-text-with-bg {
		padding: 0.45rem 0.65rem 1.25rem !important;
	}
	/* Get Started — tighter layout on small viewports */
	body.template-get-started .get-started-form-slot {
		gap: 8px;
	}
	body.template-get-started .gs-progress {
		padding: 4px 7px;
		border-radius: 8px;
	}
	body.template-get-started .gs-progress__row {
		gap: 5px;
	}
	body.template-get-started .gs-progress__pct {
		font-size: 0.7rem !important;
		min-width: 1.9rem;
	}
	body.template-get-started .gs-native-progress {
		height: 3px;
		box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.26);
	}
	body.template-get-started .gs-wizard {
		gap: 8px;
	}
	body.template-get-started .hero-text-with-bg .hero-headline,
	body.template-get-started .hero-text-with-bg h1.hero-headline {
		line-height: 1.02 !important;
		margin-bottom: 0.04rem !important;
	}
	body.template-get-started .hero-text-with-bg .hero-headline-sub {
		margin: 0 auto 0 !important;
		font-size: clamp(0.8rem, 2.9vw, 0.88rem) !important;
		line-height: 1.28 !important;
	}
	body.template-get-started .gs-slide {
		padding: 0.75rem 0.6rem 0.85rem;
		margin-top: 0.2rem;
		border-radius: 16px;
	}
	body.template-get-started .gs-question {
		font-size: 0.9rem !important;
		line-height: 1.3 !important;
		margin-bottom: 4px !important;
	}
	body.template-get-started .gs-categories {
		column-gap: 8px;
		row-gap: 8px;
		margin-top: 4px;
	}
	body.template-get-started .gs-card {
		column-gap: 9px;
		row-gap: 2px;
		border-radius: 12px;
	}
	body.template-get-started .gs-card__title {
		font-size: 0.92rem !important;
		line-height: 1.15 !important;
	}
	body.template-get-started .gs-card__subs {
		font-size: 0.78rem !important;
		line-height: 1.28 !important;
	}
	body.template-get-started .gs-fields {
		gap: 8px;
		margin-top: 4px;
	}
	body.template-get-started .gs-field,
	body.template-get-started .gs-fieldset {
		padding: 10px 10px;
		border-radius: 12px;
	}
	body.template-get-started .gs-label {
		margin: 0 0 5px;
		font-size: 0.86rem !important;
		line-height: 1.25 !important;
	}
	body.template-get-started .gs-choice-grid {
		gap: 6px;
	}
	body.template-get-started .gs-choice {
		padding: 9px 10px;
		border-radius: 12px;
	}
	body.template-get-started .gs-actions {
		margin-top: 6px;
		gap: 8px;
	}
	.hero-area .hero-text-with-bg .hero-headline,
	.hero-area .hero-text h1.hero-headline {
		font-size: clamp(1.5rem, 6vw, 1.875rem) !important;
	}
	.ln-footer .hero-headline,
	.ln-footer h1.hero-headline {
		font-size: clamp(1.5rem, 6vw, 1.875rem) !important;
	}
	.ln-footer.footer .container {
		padding-left: max(1rem, env(safe-area-inset-left, 0px));
		padding-right: max(1rem, env(safe-area-inset-right, 0px));
		padding-bottom: max(5.5rem, calc(1.25rem + env(safe-area-inset-bottom, 0px)));
	}
	.ln-footer__tagline {
		font-size: 0.9rem;
		max-width: 100%;
	}
	.hero-zip-form {
		flex-direction: column;
		max-width: 100%;
		gap: 0.5rem;
		margin-bottom: 1rem;
	}
	.hero-zip-form input,
	.hero-zip-btn {
		width: 100%;
		justify-content: center;
		padding: 0.95rem 1.25rem;
	}
	.lang-switcher {
		font-size: 13px;
		margin-right: 50px; /* clear mobile menu hamburger */
	}
}
