/* Elarislove — app layer on top of theme.json */

:root {
	--elaris-max-width: 1440px;
	--elaris-gutter: clamp(1rem, 4vw, 2rem);
	--elaris-gutter-tight: clamp(0.875rem, 3.5vw, 1.5rem);
}

/* Phone / small tablet: shared horizontal inset (used with safe-area below 782px). */
@media (max-width: 782px) {
	:root {
		--elaris-page-inline: clamp(1rem, 4vw, 1.5rem);
	}
}

/* Kill horizontal “phantom” gap (100vw/alignfull/root padding) — drawer lives outside .wp-site-blocks */
html {
	overflow-x: hidden;
}

body {
	margin: 0;
	width: 100%;
	max-width: 100%;
	overflow-x: hidden;
	box-sizing: border-box;
}

*,
*::before,
*::after {
	box-sizing: border-box;
}

/* Layout root: never wider than viewport; no WP root padding bleed */
.wp-site-blocks {
	width: 100%;
	max-width: 100%;
	margin-left: 0;
	margin-right: 0;
	padding-left: 0 !important;
	padding-right: 0 !important;
	overflow-x: clip;
	box-sizing: border-box;
}

/* Wide / full-bleed blocks: avoid core 100vw + negative margin (causes right gap / horizontal scroll) */
.wp-site-blocks .alignfull,
.wp-site-blocks .wp-block-alignfull {
	max-width: 100%;
	width: 100%;
	margin-left: 0 !important;
	margin-right: 0 !important;
}

@media (max-width: 782px) {
	.elaris-header__left .elaris-brand {
		min-width: 0;
		max-width: min(58vw, 12.5rem);
	}
}

/* Site-wide max width for primary shells (header, footer bar, constrained feel) */
.elaris-shell,
.elaris-footer-inner {
	max-width: var(--elaris-max-width);
	margin-left: auto;
	margin-right: auto;
	padding-left: var(--elaris-gutter);
	padding-right: var(--elaris-gutter);
	width: 100%;
	box-sizing: border-box;
}

@media (max-width: 782px) {
	.elaris-shell,
	.elaris-footer-inner {
		padding-left: max(var(--elaris-page-inline), env(safe-area-inset-left, 0px));
		padding-right: max(var(--elaris-page-inline), env(safe-area-inset-right, 0px));
	}

	/*
	 * Block templates (login, register, default page, etc.): one inset for the whole
	 * constrained column so headings and forms align — avoids flush edges without
	 * double-padding .entry-content inside the same group.
	 */
	.wp-site-blocks .wp-block-group.is-layout-constrained {
		padding-left: max(var(--elaris-page-inline), env(safe-area-inset-left, 0px));
		padding-right: max(var(--elaris-page-inline), env(safe-area-inset-right, 0px));
		box-sizing: border-box;
	}
}

.screen-reader-text {
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	width: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
}

.elaris-header {
	border-bottom: 1px solid rgba(233, 30, 140, 0.12);
	background: rgba(255, 255, 255, 0.92);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	position: sticky;
	top: 0;
	z-index: 120;
	width: 100%;
	box-sizing: border-box;
}

@media (max-width: 782px) {
	.elaris-header .elaris-shell {
		max-width: none;
		width: 100%;
		padding-left: max(var(--elaris-page-inline), env(safe-area-inset-left, 0px));
		padding-right: max(var(--elaris-page-inline), env(safe-area-inset-right, 0px));
		box-sizing: border-box;
	}
}

/* Desktop: flex — equal side tracks so nav stays centered; mobile overrides below. */
.elaris-header__wrapper {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	align-items: center;
	gap: 0.75rem 1.25rem;
	min-height: 3.75rem;
	padding-top: 0.5rem;
	padding-bottom: 0.5rem;
	width: 100%;
	box-sizing: border-box;
}

.elaris-header__left {
	flex: 1 1 0;
	min-width: 0;
	display: flex;
	align-items: center;
	justify-content: flex-start;
}

.elaris-header__mid {
	flex: 0 0 auto;
	display: flex;
	align-items: center;
	justify-content: center;
	min-width: 0;
}

.elaris-header__right {
	flex: 1 1 0;
	min-width: 0;
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 0.75rem;
	flex-wrap: nowrap;
}

.elaris-header__btns {
	display: flex;
	align-items: center;
	gap: 0.75rem 1rem;
	flex-wrap: wrap;
	justify-content: flex-end;
}

@media (max-width: 782px) {
	.elaris-header__wrapper {
		display: flex;
		flex-direction: row;
		justify-content: space-between;
		align-items: center;
		gap: 0.75rem;
		min-height: 3.5rem;
		padding-top: 0.625rem;
		padding-bottom: 0.625rem;
	}

	.elaris-header__mid {
		display: none !important;
	}

	.elaris-header__right {
		flex: 0 0 auto;
		justify-content: flex-end;
	}

	.elaris-header__left {
		flex: 1 1 auto;
		min-width: 0;
	}
}

.elaris-brand {
	display: inline-flex;
	align-items: center;
	line-height: 0;
	text-decoration: none;
	flex-shrink: 0;
	-webkit-tap-highlight-color: transparent;
}

.elaris-brand__img {
	display: block;
	height: clamp(2.1rem, 5.5vw, 2.85rem);
	width: auto;
	max-width: min(13.5rem, 100%);
	object-fit: contain;
	object-position: left center;
}

.elaris-brand:hover .elaris-brand__img {
	opacity: 0.9;
}

.elaris-brand:focus-visible {
	outline: 2px solid var(--wp--preset--color--primary, #e91e8c);
	outline-offset: 3px;
	border-radius: 6px;
}

.elaris-menu-toggle {
	display: none;
	align-items: center;
	justify-content: center;
	width: 2.75rem;
	height: 2.75rem;
	padding: 0;
	border: 0;
	border-radius: 12px;
	background: rgba(233, 30, 140, 0.1);
	color: var(--wp--preset--color--contrast, #2d1522);
	cursor: pointer;
	flex-shrink: 0;
	-webkit-tap-highlight-color: transparent;
}

.elaris-menu-toggle:focus-visible {
	outline: 2px solid var(--wp--preset--color--primary, #e91e8c);
	outline-offset: 2px;
}

.elaris-menu-toggle__icon {
	display: flex;
	line-height: 0;
}

@media (max-width: 782px) {
	.elaris-menu-toggle {
		display: inline-flex;
	}
	.elaris-nav--desktop,
	.elaris-header-actions--desktop,
	.elaris-header__btns {
		display: none !important;
	}
}

@media (min-width: 783px) {
	.elaris-menu-toggle {
		display: none !important;
	}

	.elaris-header__mid .elaris-nav--desktop {
		justify-content: center;
	}
}

.elaris-nav {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem 1.25rem;
	align-items: center;
	font-weight: 600;
	font-size: 0.95rem;
}

.elaris-nav a {
	color: var(--wp--preset--color--contrast, #2d1522);
	text-decoration: none;
	padding: 0.35rem 0;
	border-radius: 8px;
}

.elaris-nav a:hover {
	color: var(--wp--preset--color--primary, #e91e8c);
}

.elaris-nav--mobile {
	flex-direction: column;
	align-items: stretch;
	gap: 0.25rem;
	padding: 0.75rem 0 1rem;
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
}

.elaris-nav--mobile a {
	padding: 0.85rem 0.25rem;
	border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}

.elaris-header-link {
	font-weight: 600;
	font-size: 0.95rem;
	color: var(--wp--preset--color--muted, #7a5c6a);
	text-decoration: none;
	white-space: nowrap;
}

.elaris-header-link:hover {
	color: var(--wp--preset--color--primary-dark, #b01263);
}

.elaris-header-link--logout {
	font-size: 0.875rem;
}

.elaris-account-btn {
	position: relative;
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	padding: 0.35rem 0.85rem 0.35rem 0.45rem;
	border-radius: 999px;
	background: rgba(233, 30, 140, 0.1);
	color: var(--wp--preset--color--contrast, #2d1522);
	text-decoration: none;
	font-weight: 600;
	font-size: 0.9rem;
	border: 1px solid transparent;
}

.elaris-account-btn:hover {
	border-color: rgba(233, 30, 140, 0.35);
	color: var(--wp--preset--color--primary-dark, #b01263);
}

.elaris-account-btn__icon {
	display: flex;
	line-height: 0;
	color: var(--wp--preset--color--primary, #e91e8c);
}

@media (max-width: 900px) {
	.elaris-account-btn__label {
		clip: rect(1px, 1px, 1px, 1px);
		clip-path: inset(50%);
		height: 1px;
		width: 1px;
		margin: -1px;
		overflow: hidden;
		padding: 0;
		position: absolute;
		border: 0;
		white-space: nowrap;
	}
	.elaris-account-btn {
		padding: 0.45rem;
		border-radius: 50%;
	}
}

.elaris-nav-cta,
.elaris-nav-cta--header {
	background: linear-gradient(135deg, #e91e8c, #ff6b9d);
	color: #fff !important;
	padding: 0.5rem 1.25rem;
	border-radius: 999px;
	box-shadow: 0 6px 20px rgba(233, 30, 140, 0.35);
	text-decoration: none;
	font-weight: 700;
	font-size: 0.9rem;
	white-space: nowrap;
	border: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	-webkit-tap-highlight-color: transparent;
}

.elaris-nav-cta:hover {
	filter: brightness(1.05);
	color: #fff !important;
}

/* Mobile off-canvas (hamburger) — full viewport; portal lives in wp_footer (outside .wp-site-blocks) */
.elaris-mobile-drawer {
	position: fixed;
	inset: 0;
	width: 100%;
	max-width: 100%;
	/* Above sticky header (120), dock (110), WP admin bar when present */
	z-index: 999990;
	background: rgba(45, 21, 34, 0.45);
	display: none;
	align-items: stretch;
	justify-content: flex-start;
	padding: 0;
	margin: 0;
	box-sizing: border-box;
	visibility: hidden;
	pointer-events: none;
}

.elaris-mobile-drawer.is-open {
	display: flex;
	visibility: visible;
	pointer-events: auto;
}

.elaris-mobile-drawer__panel {
	width: 100%;
	max-width: 100%;
	flex: 1 1 100%;
	min-width: 0;
	height: 100%;
	min-height: 100vh;
	min-height: 100dvh;
	min-height: -webkit-fill-available;
	overflow-x: hidden;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
	overscroll-behavior: contain;
	background: #fff;
	border-radius: 0;
	padding-top: 0;
	padding-bottom: calc(1.25rem + env(safe-area-inset-bottom, 0px));
	padding-left: max(1rem, env(safe-area-inset-left, 0px));
	padding-right: max(1rem, env(safe-area-inset-right, 0px));
	box-sizing: border-box;
	box-shadow: none;
	animation: elarisOffCanvasIn 0.3s cubic-bezier(0.22, 1, 0.36, 1);
}

@keyframes elarisOffCanvasIn {
	from {
		transform: translateX(-100%);
		opacity: 0.85;
	}
	to {
		transform: translateX(0);
		opacity: 1;
	}
}

@media (prefers-reduced-motion: reduce) {
	.elaris-mobile-drawer__panel {
		animation: none;
	}
}

.elaris-mobile-drawer__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem;
	padding: calc(0.75rem + env(safe-area-inset-top, 0px)) 0 0.75rem;
	margin: 0;
	border-bottom: 1px solid rgba(0, 0, 0, 0.06);
	position: sticky;
	top: 0;
	background: #fff;
	z-index: 1;
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	flex-shrink: 0;
}

.elaris-mobile-drawer__title {
	font-family: var(--wp--preset--font-family--fraunces, Fraunces, Georgia, serif);
	font-weight: 700;
	font-size: 1.15rem;
	color: var(--wp--preset--color--contrast, #2d1522);
}

.elaris-drawer-close {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.75rem;
	height: 2.75rem;
	padding: 0;
	border: 0;
	border-radius: 12px;
	background: rgba(233, 30, 140, 0.1);
	color: var(--wp--preset--color--contrast, #2d1522);
	cursor: pointer;
	flex-shrink: 0;
	-webkit-tap-highlight-color: transparent;
}

.elaris-drawer-close:hover {
	background: rgba(233, 30, 140, 0.18);
}

.elaris-drawer-close:focus-visible {
	outline: 2px solid var(--wp--preset--color--primary, #e91e8c);
	outline-offset: 2px;
}

.elaris-mobile-drawer__actions {
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
	padding: 1rem 0 0;
	margin: 0;
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
}

.elaris-mobile-drawer__actions .elaris-btn-block {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	white-space: normal;
	text-align: center;
}

body.elaris-nav-open {
	overflow: hidden;
	touch-action: none;
}

/* Logged-in bottom dock (mobile app style) */
.elaris-dock {
	display: none;
	position: fixed;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 110;
	justify-content: space-around;
	align-items: stretch;
	gap: 0.125rem;
	padding: 0.4rem var(--elaris-gutter-tight) calc(0.5rem + env(safe-area-inset-bottom, 0px));
	background: rgba(255, 255, 255, 0.94);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	border-top: 1px solid rgba(233, 30, 140, 0.15);
	box-shadow: 0 -8px 32px rgba(45, 21, 34, 0.08);
}

@media (max-width: 782px) {
	body.logged-in .elaris-dock {
		display: flex;
		padding-left: max(var(--elaris-page-inline), env(safe-area-inset-left, 0px));
		padding-right: max(var(--elaris-page-inline), env(safe-area-inset-right, 0px));
	}

	body.logged-in {
		padding-bottom: calc(4.25rem + env(safe-area-inset-bottom, 0px));
	}

	body.elaris-hide-footer-mobile .elaris-footer-wrap {
		display: none !important;
	}

	.elaris-discover-page {
		padding-left: max(var(--elaris-page-inline), env(safe-area-inset-left, 0px));
		padding-right: max(var(--elaris-page-inline), env(safe-area-inset-right, 0px));
	}
}

.elaris-dock__item {
	flex: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.15rem;
	min-width: 0;
	padding: 0.35rem 0.2rem;
	font-size: 0.625rem;
	font-weight: 700;
	letter-spacing: 0.02em;
	text-transform: uppercase;
	color: var(--wp--preset--color--muted, #7a5c6a);
	text-decoration: none;
	border-radius: 14px;
	-webkit-tap-highlight-color: transparent;
}

.elaris-dock__item:hover,
.elaris-dock__item:focus-visible {
	color: var(--wp--preset--color--primary-dark, #b01263);
	background: rgba(233, 30, 140, 0.08);
}

.elaris-dock__icon {
	display: flex;
	line-height: 0;
	color: var(--wp--preset--color--primary, #e91e8c);
}

.elaris-dock__icon svg {
	width: 22px;
	height: 22px;
}

.elaris-dock__label {
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	max-width: 100%;
	text-align: center;
}

.elaris-footer-wrap .elaris-footer-inner a {
	color: inherit;
	opacity: 0.95;
}

.elaris-muted {
	color: var(--wp--preset--color--muted, #7a5c6a);
	font-size: 0.95rem;
}

.elaris-center {
	text-align: center;
}

.elaris-surface-card {
	background: var(--wp--preset--color--surface, #fff);
	border-radius: var(--wp--preset--border-radius--large, 24px);
	box-shadow: 0 12px 40px rgba(45, 21, 34, 0.08);
	padding: var(--wp--preset--spacing--5, 1.5rem);
	max-width: 520px;
	margin-left: auto;
	margin-right: auto;
}

/* Logo on theme login / register / change-password (shortcode). */
.elaris-auth-logo {
	margin: 0 auto 1.25rem;
	text-align: center;
	line-height: 0;
}

.elaris-auth-logo__link {
	display: inline-block;
	text-decoration: none;
	line-height: 0;
	border-radius: 8px;
}

.elaris-auth-logo__link:focus-visible {
	outline: 2px solid var(--wp--preset--color--primary, #e91e8c);
	outline-offset: 3px;
}

.elaris-auth-logo__img {
	display: block;
	height: clamp(3rem, 12vw, 4.25rem);
	width: auto;
	max-width: min(280px, 88%);
	margin: 0 auto;
	object-fit: contain;
}

/* Policy / legal templates */
.elaris-legal {
	max-width: 720px;
	margin: 0 auto;
	font-size: 0.95rem;
	line-height: 1.65;
	color: var(--wp--preset--color--contrast, #2d1522);
}

.elaris-legal h1 {
	font-family: var(--wp--preset--font-family--fraunces), Fraunces, Georgia, serif;
	font-size: clamp(1.75rem, 4vw, 2.25rem);
	font-weight: 600;
	margin: 0 0 0.5rem;
	line-height: 1.2;
}

.elaris-legal .elaris-legal__meta {
	color: var(--wp--preset--color--muted, #7a5c6a);
	font-size: 0.875rem;
	margin: 0 0 2rem;
}

.elaris-legal h2 {
	font-family: var(--wp--preset--font-family--fraunces), Fraunces, Georgia, serif;
	font-size: 1.2rem;
	font-weight: 600;
	margin: 2rem 0 0.75rem;
}

.elaris-legal h3 {
	font-family: var(--wp--preset--font-family--dm-sans), "DM Sans", system-ui, sans-serif;
	font-size: 1.05rem;
	font-weight: 700;
	margin: 1.35rem 0 0.5rem;
	color: var(--wp--preset--color--contrast, #2d1522);
}

.elaris-legal p {
	margin: 0 0 1rem;
}

.elaris-legal ul {
	margin: 0 0 1rem 1.15rem;
	padding: 0;
}

.elaris-legal li {
	margin-bottom: 0.35rem;
}

.elaris-legal a {
	color: var(--wp--preset--color--primary-dark, #b01263);
	font-weight: 600;
}

.elaris-form-wrap {
	max-width: 440px;
}

.elaris-form {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

.elaris-label {
	font-weight: 600;
	font-size: 0.9rem;
}

.elaris-input,
.elaris-discover-filters select,
.elaris-discover-filters input {
	width: 100%;
	border: 1px solid rgba(233, 30, 140, 0.25);
	border-radius: 12px;
	padding: 0.65rem 0.85rem;
	font: inherit;
	background: #fff;
}

.elaris-fieldset {
	border: 0;
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem 1rem;
}

.elaris-fieldset legend {
	width: 100%;
}

.elaris-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.35rem;
	border: 0;
	cursor: pointer;
	font-weight: 600;
	border-radius: 999px;
	padding: 0.65rem 1.25rem;
	transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.elaris-btn:active {
	transform: scale(0.98);
}

.elaris-btn-primary {
	background: linear-gradient(135deg, #e91e8c, #ff6b9d);
	color: #fff;
	box-shadow: 0 8px 24px rgba(233, 30, 140, 0.35);
}

.elaris-btn-secondary {
	background: rgba(233, 30, 140, 0.12);
	color: #b01263;
}

.elaris-btn-block {
	display: block;
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
}

.elaris-form-msg {
	min-height: 1.25rem;
	font-size: 0.9rem;
}

/* Landing cards */
.elaris-card-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
	gap: 1rem;
}

.elaris-profile-card {
	border-radius: 20px;
	overflow: hidden;
	background: #fff;
	box-shadow: 0 10px 30px rgba(45, 21, 34, 0.1);
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

@media (prefers-reduced-motion: reduce) {
	.elaris-profile-card {
		transition: none;
	}
}

.elaris-profile-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 16px 40px rgba(45, 21, 34, 0.14);
}

.elaris-profile-card img {
	width: 100%;
	aspect-ratio: 3/4;
	object-fit: cover;
	display: block;
}

.elaris-profile-card .elaris-card-body {
	padding: 0.85rem 1rem 1rem;
}

.elaris-chip {
	display: inline-block;
	font-size: 0.75rem;
	padding: 0.2rem 0.55rem;
	border-radius: 999px;
	background: rgba(233, 30, 140, 0.12);
	color: #b01263;
	margin: 0.15rem 0.25rem 0 0;
}

/* Modal onboarding */
.elaris-modal {
	position: fixed;
	inset: 0;
	z-index: 100;
	background: rgba(45, 21, 34, 0.45);
	display: flex;
	align-items: flex-end;
	justify-content: center;
	padding: 1rem;
}

@media (min-width: 600px) {
	.elaris-modal {
		align-items: center;
	}
}

.elaris-modal[hidden] {
	display: none !important;
}

.elaris-modal-panel {
	width: min(100%, 420px);
	max-height: 90vh;
	overflow: auto;
	background: #fff;
	border-radius: 24px 24px 0 0;
	padding: 1.5rem;
	box-shadow: 0 -8px 40px rgba(0, 0, 0, 0.15);
	animation: elarisSlideUp 0.35s ease;
}

@media (min-width: 600px) {
	.elaris-modal-panel {
		border-radius: 24px;
	}
}

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

.elaris-modal h2 {
	margin-top: 0;
}

.elaris-choice-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0.75rem;
	margin: 1rem 0;
}

.elaris-choice {
	padding: 0.85rem;
	border-radius: 16px;
	border: 2px solid rgba(233, 30, 140, 0.2);
	background: #fff;
	font-weight: 600;
	cursor: pointer;
}

.elaris-choice.is-selected {
	border-color: #e91e8c;
	background: rgba(233, 30, 140, 0.08);
}

/* Discover — mobile-first swipe deck */
.elaris-discover-page {
	width: 100%;
	max-width: 480px;
	margin: 0 auto;
	padding-top: 0.75rem;
	padding-bottom: 2rem;
	padding-left: var(--elaris-gutter, 1rem);
	padding-right: var(--elaris-gutter, 1rem);
	box-sizing: border-box;
	background: #fff5f7;
	min-height: 60vh;
}

.elaris-discover-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	margin-bottom: 0.75rem;
	padding: 0 0.15rem;
}

.elaris-discover-head__title {
	font-family: "Fraunces", Georgia, serif;
	font-size: clamp(1.5rem, 5vw, 1.85rem);
	font-weight: 600;
	margin: 0;
	color: var(--wp--preset--color--contrast, #1a1a1a);
	line-height: 1.15;
}

.elaris-discover-filter-btn {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	border: 1px solid rgba(0, 0, 0, 0.08);
	background: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	box-shadow: 0 4px 14px rgba(45, 21, 34, 0.08);
	transition: background 0.15s ease, box-shadow 0.15s ease;
	flex-shrink: 0;
}

.elaris-discover-filter-btn:hover {
	background: rgba(255, 255, 255, 0.95);
	box-shadow: 0 6px 18px rgba(45, 21, 34, 0.1);
}

.elaris-discover-filter-backdrop {
	position: fixed;
	inset: 0;
	background: rgba(45, 21, 34, 0.45);
	/* Above sticky header, dock, and mobile drawer (999990) */
	z-index: 1000020;
}

body.elaris-discover-filter-open {
	overflow: hidden;
}

.elaris-discover-filters--panel {
	position: fixed;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	width: min(calc(100vw - 2rem), 440px);
	max-width: 440px;
	max-height: min(85vh, 540px);
	margin: 0;
	padding: 0;
	border-radius: 20px;
	box-shadow: 0 20px 56px rgba(45, 21, 34, 0.22);
	border: 1px solid rgba(233, 30, 140, 0.14);
	overflow: auto;
	-webkit-overflow-scrolling: touch;
	z-index: 1000030;
	box-sizing: border-box;
	animation: elarisDiscoverFilterIn 0.22s ease;
}

@keyframes elarisDiscoverFilterIn {
	from {
		opacity: 0;
		transform: translate(-50%, -48%) scale(0.98);
	}
	to {
		opacity: 1;
		transform: translate(-50%, -50%) scale(1);
	}
}

@media (prefers-reduced-motion: reduce) {
	.elaris-discover-filters--panel {
		animation: none;
	}
}

.elaris-discover-filters__heading {
	font-family: "Fraunces", Georgia, serif;
	font-size: 1.2rem;
	font-weight: 600;
	margin: 0 0 0.75rem;
	width: 100%;
	flex: 1 1 100%;
	color: var(--wp--preset--color--contrast, #1a1a1a);
}

.elaris-discover-filters__inner {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem 1rem;
	align-items: flex-end;
	padding: 1.15rem 1.15rem 1.2rem;
}

.elaris-discover-filters__field {
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
	font-size: 0.85rem;
	font-weight: 600;
	flex: 1 1 140px;
	min-width: 0;
}

.elaris-discover-filters__field select,
.elaris-discover-filters__field input {
	width: 100%;
	border: 1px solid rgba(233, 30, 140, 0.22);
	border-radius: 12px;
	padding: 0.6rem 0.8rem;
	font: inherit;
	background: #fff;
	box-sizing: border-box;
}

.elaris-discover-filters__apply {
	flex: 1 1 100%;
	margin-top: 0.25rem;
}

.elaris-discover {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: 1rem;
}

.elaris-card-stack {
	position: relative;
	width: 100%;
	max-width: 420px;
	margin: 0 auto;
	aspect-ratio: 3 / 4;
	max-height: min(72vh, 620px);
	touch-action: none;
	border-radius: 32px;
	filter: drop-shadow(0 16px 36px rgba(45, 21, 34, 0.15));
}

.elaris-discover-empty {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: 1.5rem;
	margin: 0;
	z-index: 0;
	font-size: 0.95rem;
}

.elaris-stack-card {
	position: absolute;
	inset: 0;
	border-radius: 32px;
	overflow: hidden;
	background: #e8e4ec;
	will-change: transform;
	transition: transform 0.08s linear;
}

@media (prefers-reduced-motion: reduce) {
	.elaris-stack-card {
		transition: none;
	}
}

.elaris-stack-card__media {
	position: absolute;
	inset: 0;
}

.elaris-stack-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	display: block;
}

.elaris-stack-card__overlay {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	padding: 2.5rem 1.15rem 1.25rem;
	background: linear-gradient(
		180deg,
		rgba(0, 0, 0, 0) 0%,
		rgba(0, 0, 0, 0.45) 38%,
		rgba(0, 0, 0, 0.78) 100%
	);
	color: #fff;
}

.elaris-stack-card__name {
	font-family: "Fraunces", Georgia, serif;
	font-size: clamp(1.35rem, 4.2vw, 1.65rem);
	font-weight: 600;
	margin: 0 0 0.45rem;
	line-height: 1.15;
	color: #fff;
}

.elaris-stack-card__age {
	font-weight: 600;
	opacity: 0.95;
}

.elaris-stack-card__meta {
	display: flex;
	align-items: center;
	gap: 0.35rem;
	margin: 0 0 0.35rem;
	font-size: 0.88rem;
	line-height: 1.3;
	color: rgba(255, 255, 255, 0.92);
}

.elaris-stack-card__meta img {
	flex-shrink: 0;
	opacity: 0.9;
	filter: brightness(0) invert(1);
}

.elaris-stack-card__bio {
	margin: 0.35rem 0 0.65rem;
	font-size: 0.88rem;
	line-height: 1.4;
	color: rgba(255, 255, 255, 0.9);
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.elaris-stack-card__tags {
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem;
}

.elaris-stack-card__tag {
	font-size: 0.72rem;
	font-weight: 600;
	padding: 0.28rem 0.6rem;
	border-radius: 999px;
	background: rgba(0, 0, 0, 0.5);
	color: #fff;
	line-height: 1.2;
}

.elaris-discover-actions {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 0.45rem;
	margin-top: 0.25rem;
	padding: 0 0.25rem;
	flex-wrap: nowrap;
}

.elaris-disco {
	border: none;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	flex-shrink: 0;
	transition: transform 0.12s ease, box-shadow 0.12s ease;
}

.elaris-disco:active:not(:disabled) {
	transform: scale(0.94);
}

.elaris-disco:disabled {
	opacity: 0.38;
	cursor: not-allowed;
}

.elaris-disco img {
	display: block;
	pointer-events: none;
}

.elaris-disco--undo,
.elaris-disco--boost {
	width: 46px;
	height: 46px;
	background: #ffc629;
	box-shadow: 0 6px 16px rgba(255, 198, 41, 0.45);
}

.elaris-disco--undo img,
.elaris-disco--boost img {
	opacity: 0.9;
}

.elaris-disco--pass {
	width: 58px;
	height: 58px;
	background: #ff4458;
	box-shadow: 0 8px 22px rgba(255, 68, 88, 0.45);
}

.elaris-disco--pass img {
	filter: brightness(0) invert(1);
}

.elaris-disco--super {
	width: 48px;
	height: 48px;
	background: #7c4dff;
	box-shadow: 0 6px 18px rgba(124, 77, 255, 0.42);
}

.elaris-disco--super img {
	filter: brightness(0) invert(1);
}

.elaris-disco--like {
	width: 72px;
	height: 72px;
	background: linear-gradient(145deg, #ff3370 0%, #ff6b35 100%);
	box-shadow: 0 12px 32px rgba(255, 60, 120, 0.5);
}

.elaris-disco--like img {
	filter: brightness(0) invert(1);
}

.elaris-discover-msg {
	margin: 0.25rem 0 0;
	min-height: 1.35rem;
}

@media (min-width: 768px) {
	.elaris-discover-page {
		max-width: 520px;
		padding-top: 1.25rem;
	}

	.elaris-discover-actions {
		gap: 0.65rem;
	}
}

/* Chat — desktop two-pane, mobile list / thread */
.elaris-chat-page {
	width: 100%;
	max-width: var(--elaris-max-width);
	margin: 0 auto;
	padding: 0 var(--elaris-gutter) 2rem;
	box-sizing: border-box;
}

.elaris-chat-app {
	display: grid;
	grid-template-columns: minmax(260px, 32%) minmax(0, 1fr);
	gap: 0;
	min-height: min(78vh, 720px);
	max-height: calc(100vh - 5.5rem);
	background: var(--wp--preset--color--surface);
	border-radius: clamp(16px, 2.5vw, 24px);
	overflow: hidden;
	border: 1px solid rgba(233, 30, 140, 0.1);
	box-shadow: 0 12px 40px rgba(45, 21, 34, 0.06);
}

.elaris-chat-sidebar {
	display: flex;
	flex-direction: column;
	min-width: 0;
	background: #fdf6f8;
	border-right: 1px solid rgba(233, 30, 140, 0.1);
	padding: 1rem 0.85rem 1rem;
	box-sizing: border-box;
}

.elaris-chat-sidebar__title {
	margin: 0 0 1rem;
	padding: 0 0.35rem;
	font-family: var(--wp--preset--font-family--fraunces), Georgia, serif;
	font-size: 1.5rem;
	font-weight: 600;
	color: #111;
}

.elaris-chat-search {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.55rem 1rem;
	margin: 0 0 0.85rem;
	background: rgba(255, 255, 255, 0.85);
	border-radius: 999px;
	border: 1px solid rgba(233, 30, 140, 0.12);
	box-sizing: border-box;
}

.elaris-chat-search__icon {
	flex-shrink: 0;
	opacity: 0.45;
}

.elaris-chat-search__input {
	flex: 1;
	min-width: 0;
	border: none;
	background: transparent;
	font-size: 0.9rem;
	font-family: var(--wp--preset--font-family--dm-sans), system-ui, sans-serif;
	outline: none;
}

.elaris-chat-inbox {
	flex: 1;
	overflow-y: auto;
	min-height: 0;
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
	padding-right: 0.15rem;
}

.elaris-chat-inbox-item {
	display: grid;
	grid-template-columns: auto 1fr auto;
	align-items: center;
	gap: 0.65rem;
	width: 100%;
	padding: 0.65rem 0.55rem;
	margin: 0;
	border: none;
	border-radius: 16px;
	background: transparent;
	cursor: pointer;
	text-align: left;
	font: inherit;
	color: inherit;
	box-sizing: border-box;
}

.elaris-chat-inbox-item:hover {
	background: rgba(255, 255, 255, 0.65);
}

.elaris-chat-inbox-item.is-active {
	background: rgba(233, 30, 140, 0.14);
}

.elaris-chat-inbox-item__avatar-wrap {
	position: relative;
	flex-shrink: 0;
}

.elaris-chat-inbox-item__avatar {
	width: 3rem;
	height: 3rem;
	border-radius: 50%;
	object-fit: cover;
	display: block;
	background: #eee;
}

.elaris-chat-inbox-item__avatar--ph {
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 700;
	color: var(--wp--preset--color--primary-dark);
}

.elaris-chat-inbox-item__dot {
	position: absolute;
	right: 0;
	bottom: 0;
	width: 0.65rem;
	height: 0.65rem;
	border-radius: 50%;
	background: #2ecc71;
	border: 2px solid #fdf6f8;
}

.elaris-chat-inbox-item__mid {
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 0.15rem;
}

.elaris-chat-inbox-item__name {
	font-weight: 700;
	font-size: 0.92rem;
	color: #111;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.elaris-chat-inbox-item__preview {
	font-size: 0.8rem;
	color: #666;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.elaris-chat-inbox-item__meta {
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 0.25rem;
	flex-shrink: 0;
}

.elaris-chat-inbox-item__time {
	font-size: 0.72rem;
	color: #888;
	white-space: nowrap;
}

.elaris-chat-inbox-item__badge {
	min-width: 1.35rem;
	height: 1.35rem;
	padding: 0 0.35rem;
	border-radius: 999px;
	background: var(--wp--preset--color--primary);
	color: #fff;
	font-size: 0.7rem;
	font-weight: 700;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.elaris-chat-thread-panel {
	position: relative;
	display: flex;
	flex-direction: column;
	min-width: 0;
	min-height: 0;
	background: #fff;
}

.elaris-chat-thread-bar {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.65rem 1rem;
	border-bottom: 1px solid rgba(0, 0, 0, 0.06);
	flex-shrink: 0;
}

.elaris-chat-back {
	display: none;
	flex-shrink: 0;
	width: 2.5rem;
	height: 2.5rem;
	align-items: center;
	justify-content: center;
	border: none;
	border-radius: 50%;
	background: rgba(233, 30, 140, 0.08);
	cursor: pointer;
	padding: 0;
}

.elaris-chat-back img {
	opacity: 0.85;
}

.elaris-chat-thread-peer {
	display: flex;
	align-items: center;
	gap: 0.65rem;
	flex: 1;
	min-width: 0;
}

.elaris-chat-thread-peer__avatar-wrap {
	position: relative;
	flex-shrink: 0;
}

.elaris-chat-thread-peer__avatar {
	width: 2.5rem;
	height: 2.5rem;
	border-radius: 50%;
	object-fit: cover;
	background: #f0f0f0;
}

.elaris-chat-thread-peer__dot {
	position: absolute;
	right: 0;
	bottom: 0;
	width: 0.55rem;
	height: 0.55rem;
	border-radius: 50%;
	background: #2ecc71;
	border: 2px solid #fff;
}

.elaris-chat-thread-peer__text {
	display: flex;
	flex-direction: column;
	min-width: 0;
}

.elaris-chat-thread-peer__name {
	font-weight: 700;
	font-size: 1rem;
	color: #111;
}

.elaris-chat-thread-peer__status {
	font-size: 0.78rem;
	color: #666;
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
}

.elaris-chat-thread-peer__status::before {
	content: "";
	width: 0.45rem;
	height: 0.45rem;
	border-radius: 50%;
	background: #2ecc71;
}

.elaris-chat-thread-actions {
	display: flex;
	align-items: center;
	gap: 0.15rem;
	flex-shrink: 0;
}

.elaris-chat-icon-btn {
	width: 2.35rem;
	height: 2.35rem;
	border: none;
	border-radius: 50%;
	background: transparent;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0.65;
}

.elaris-chat-icon-btn:hover {
	background: rgba(0, 0, 0, 0.05);
	opacity: 1;
}

.elaris-chat-thread-scroll {
	flex: 1;
	overflow-y: auto;
	min-height: 0;
	display: flex;
	flex-direction: column;
	background: #fff;
}

.elaris-chat-match-hero {
	text-align: center;
	padding: 1.25rem 1rem 1rem;
	flex-shrink: 0;
	border-bottom: 1px solid rgba(0, 0, 0, 0.04);
}

.elaris-chat-match-hero__avatar {
	width: 4.5rem;
	height: 4.5rem;
	border-radius: 50%;
	object-fit: cover;
	margin: 0 auto 0.65rem;
	display: block;
	border: 3px solid rgba(233, 30, 140, 0.15);
}

.elaris-chat-match-hero__name {
	margin: 0 0 0.35rem;
	font-family: var(--wp--preset--font-family--fraunces), Georgia, serif;
	font-size: 1.25rem;
	font-weight: 600;
	color: #111;
}

.elaris-chat-match-hero__line {
	margin: 0;
	font-size: 0.9rem;
	color: #666;
}

.elaris-chat-messages {
	flex: 1;
	padding: 1rem 1rem 1.25rem;
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
}

.elaris-chat-msg {
	display: flex;
	max-width: 100%;
}

.elaris-chat-msg--them {
	justify-content: flex-start;
}

.elaris-chat-msg--me {
	justify-content: flex-end;
}

.elaris-chat-bubble {
	max-width: min(85%, 22rem);
	padding: 0.65rem 0.9rem 0.5rem;
	border-radius: 22px;
	font-size: 0.95rem;
	line-height: 1.45;
	box-shadow: 0 2px 12px rgba(45, 21, 34, 0.06);
}

.elaris-chat-msg--them .elaris-chat-bubble {
	background: #fff;
	border: 1px solid rgba(0, 0, 0, 0.06);
	color: #1a1a1a;
	border-bottom-left-radius: 6px;
}

.elaris-chat-msg--me .elaris-chat-bubble {
	background: linear-gradient(105deg, #ff3366 0%, #e91e8c 45%, #ff8a65 100%);
	color: #fff;
	border-bottom-right-radius: 6px;
}

.elaris-chat-bubble__text {
	margin: 0;
}

.elaris-chat-bubble__meta {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 0.35rem;
	margin-top: 0.35rem;
	font-size: 0.68rem;
	opacity: 0.85;
}

.elaris-chat-msg--me .elaris-chat-bubble__meta {
	color: rgba(255, 255, 255, 0.9);
}

.elaris-chat-msg--them .elaris-chat-bubble__meta {
	color: #888;
}

.elaris-chat-bubble__ticks {
	font-size: 0.75rem;
	letter-spacing: -0.05em;
}

.elaris-chat-compose {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.75rem 1rem calc(0.75rem + env(safe-area-inset-bottom, 0px));
	border-top: 1px solid rgba(0, 0, 0, 0.06);
	background: #fff;
	flex-shrink: 0;
}

.elaris-chat-compose__tools {
	display: flex;
	align-items: center;
	gap: 0.35rem;
	flex-shrink: 0;
}

.elaris-chat-compose__circle {
	width: 2.5rem;
	height: 2.5rem;
	border-radius: 50%;
	border: none;
	background: rgba(233, 30, 140, 0.1);
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	flex-shrink: 0;
	opacity: 0.85;
}

.elaris-chat-compose__circle:hover {
	opacity: 1;
}

.elaris-chat-compose__input {
	flex: 1;
	min-width: 0;
	min-height: 2.75rem;
	max-height: 6rem;
	resize: none;
	border-radius: 22px;
	border: 1px solid rgba(0, 0, 0, 0.08);
	padding: 0.65rem 1rem;
	font-size: 0.95rem;
	font-family: var(--wp--preset--font-family--dm-sans), system-ui, sans-serif;
	line-height: 1.4;
	box-sizing: border-box;
}

.elaris-chat-compose__input:focus {
	outline: none;
	border-color: rgba(233, 30, 140, 0.35);
}

.elaris-chat-compose__submit {
	width: 2.75rem;
	height: 2.75rem;
	border-radius: 50%;
	border: none;
	cursor: pointer;
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(105deg, #e91e8c, #ff7043);
	box-shadow: 0 4px 14px rgba(233, 30, 140, 0.35);
	padding: 0;
}

.elaris-chat-compose__submit img {
	filter: brightness(0) invert(1);
}

.elaris-chat-empty {
	position: absolute;
	inset: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: 2rem;
	background: #fff;
	pointer-events: none;
}

.elaris-chat-empty__title {
	margin: 0 0 0.5rem;
	font-family: var(--wp--preset--font-family--fraunces), Georgia, serif;
	font-size: 1.35rem;
	font-weight: 600;
	color: #222;
}

.elaris-chat-empty__sub {
	margin: 0;
	font-size: 0.95rem;
	color: #666;
	max-width: 18rem;
	line-height: 1.5;
}

@media (max-width: 782px) {
	.elaris-chat-page {
		padding-left: max(var(--elaris-page-inline), env(safe-area-inset-left, 0px));
		padding-right: max(var(--elaris-page-inline), env(safe-area-inset-right, 0px));
		padding-bottom: calc(0.5rem + env(safe-area-inset-bottom, 0px));
	}

	.elaris-chat-app {
		display: block;
		min-height: calc(100vh - 4.5rem);
		max-height: none;
		border-radius: 0;
		border: none;
		box-shadow: none;
	}

	.elaris-chat-sidebar {
		display: flex;
		min-height: calc(100vh - 4.5rem);
		border-right: none;
		padding-top: 0.5rem;
	}

	.elaris-chat-thread-panel {
		display: none;
		min-height: calc(100vh - 4.5rem);
	}

	.elaris-chat-app.elaris-chat-app--thread-open .elaris-chat-sidebar {
		display: none;
	}

	.elaris-chat-app.elaris-chat-app--thread-open .elaris-chat-thread-panel {
		display: flex;
	}

	.elaris-chat-back {
		display: flex;
	}

	.elaris-chat-empty {
		display: none;
	}
}

@media (min-width: 782px) {
	.elaris-chat-back {
		display: none !important;
	}
}

/* Dashboard */
.elaris-dashboard {
	display: grid;
	gap: 1rem;
	max-width: 720px;
	margin: 0 auto;
}

.elaris-dash-card h2 {
	margin-top: 0;
}

.elaris-progress {
	height: 10px;
	background: rgba(233, 30, 140, 0.12);
	border-radius: 999px;
	overflow: hidden;
	margin: 0.5rem 0 1rem;
}

.elaris-progress-bar {
	height: 100%;
	width: 0;
	background: linear-gradient(90deg, #e91e8c, #ff6b9d);
	border-radius: 999px;
	transition: width 0.4s ease;
}

.elaris-link-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.elaris-wizard-actions {
	display: flex;
	justify-content: space-between;
	margin-top: 1rem;
	gap: 0.75rem;
}

.elaris-notif-list {
	list-style: none;
	padding: 0;
	margin: 0;
}

.elaris-notif-list li {
	padding: 0.75rem 0;
	border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}

/* Notifications page */
.elaris-notifications-page {
	padding-top: clamp(1.25rem, 3vw, 2rem);
	padding-bottom: clamp(2rem, 5vw, 3.5rem);
}

.elaris-notifications {
	background: var(--wp--preset--color--surface, #fff);
	border-radius: 20px;
	padding: clamp(1.25rem, 3vw, 2rem);
	box-shadow: 0 8px 28px rgba(45, 21, 34, 0.06);
	border: 1px solid rgba(0, 0, 0, 0.05);
}

.elaris-notifications__header {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	justify-content: space-between;
	gap: 1rem 1.25rem;
	margin-bottom: 1.25rem;
}

.elaris-notifications__title {
	font-family: "Fraunces", Georgia, serif;
	font-size: clamp(1.65rem, 3.5vw, 2.1rem);
	font-weight: 600;
	margin: 0 0 0.35rem;
	color: var(--wp--preset--color--contrast, #1a1a1a);
	line-height: 1.15;
}

.elaris-notifications__subtitle {
	margin: 0;
	font-size: var(--wp--preset--font-size--medium, 1rem);
	color: var(--wp--preset--color--muted, #5c5c5c);
	line-height: 1.4;
	max-width: 36rem;
}

.elaris-notifications__mark-all {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	min-height: 2.5rem;
	padding: 0 1.1rem;
	border-radius: 999px;
	border: 1px solid rgba(0, 0, 0, 0.14);
	background: #fff;
	color: #4a4a4a;
	font-size: 0.9rem;
	font-weight: 600;
	line-height: 1;
	cursor: pointer;
	transition: border-color 0.15s ease, background 0.15s ease;
	flex-shrink: 0;
	box-sizing: border-box;
}

.elaris-notifications__mark-all-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 18px;
	height: 18px;
	margin: 0;
}

.elaris-notifications__mark-all-icon img {
	display: block;
	width: 18px;
	height: 18px;
	margin: 0;
	opacity: 0.55;
}

.elaris-notifications__mark-all-label {
	display: block;
	line-height: 1.2;
	margin: 0;
	padding: 0;
}

.elaris-notifications__mark-all:hover:not(:disabled) {
	border-color: rgba(233, 30, 140, 0.45);
	background: rgba(233, 30, 140, 0.04);
}

.elaris-notifications__mark-all:disabled {
	opacity: 0.45;
	cursor: not-allowed;
}

.elaris-notifications__tabs {
	display: flex;
	gap: 0.5rem;
	border-bottom: 1px solid rgba(0, 0, 0, 0.08);
	margin-bottom: 1rem;
	flex-wrap: wrap;
}

.elaris-notifications__tab {
	position: relative;
	padding: 0.65rem 0.5rem 0.85rem;
	margin: 0 0.35rem 0 0;
	border: none;
	background: none;
	font-size: 0.95rem;
	font-weight: 600;
	color: var(--wp--preset--color--muted, #6b6b6b);
	cursor: pointer;
	transition: color 0.15s ease;
}

.elaris-notifications__tab:hover,
.elaris-notifications__tab:focus-visible {
	color: #c2186a;
}

.elaris-notifications__tab.is-active {
	color: #e91e8c;
}

.elaris-notifications__tab.is-active::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: -1px;
	height: 2px;
	background: #e91e8c;
	border-radius: 2px 2px 0 0;
}

.elaris-notifications__status {
	margin: 0 0 0.75rem;
	font-size: 0.9rem;
}

.elaris-notifications__status--error {
	color: #b00020;
}

.elaris-notifications__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
}

.elaris-notif-item {
	margin: 0;
	border-radius: 14px;
	transition: background 0.15s ease;
}

.elaris-notif-item--unread {
	background: rgba(233, 30, 140, 0.07);
}

.elaris-notif-item__link {
	display: flex;
	align-items: flex-start;
	gap: 0.85rem;
	padding: 0.85rem 0.85rem 0.85rem 0.75rem;
	text-decoration: none;
	color: inherit;
	border-radius: 14px;
	min-width: 0;
}

.elaris-notif-item__link--static {
	cursor: default;
}

.elaris-notif-item__link:hover:not(.elaris-notif-item__link--static) {
	background: rgba(0, 0, 0, 0.02);
}

.elaris-notif-item--unread .elaris-notif-item__link:hover:not(.elaris-notif-item__link--static) {
	background: rgba(233, 30, 140, 0.1);
}

.elaris-notif-item__avatar-wrap {
	position: relative;
	flex-shrink: 0;
	width: 48px;
	height: 48px;
}

.elaris-notif-item__avatar {
	width: 48px;
	height: 48px;
	border-radius: 50%;
	object-fit: cover;
	display: block;
	background: rgba(0, 0, 0, 0.06);
}

.elaris-notif-item__avatar--ph {
	display: block;
	background: linear-gradient(135deg, #f3e5f0, #fce4ec);
}

.elaris-notif-type {
	position: absolute;
	right: -2px;
	bottom: -2px;
	width: 22px;
	height: 22px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 2px solid #fff;
	box-shadow: 0 1px 4px rgba(0, 0, 0, 0.12);
}

.elaris-notif-type img {
	display: block;
	filter: brightness(0) invert(1);
}

.elaris-notif-type--message {
	background: #2e7d32;
}

.elaris-notif-type--match {
	background: #e91e8c;
}

.elaris-notif-type--like {
	background: #e91e8c;
}

.elaris-notif-type--super {
	background: #1565c0;
}

.elaris-notif-item__body {
	flex: 1;
	min-width: 0;
}

.elaris-notif-item__line {
	margin: 0 0 0.2rem;
	font-size: 0.95rem;
	line-height: 1.35;
	color: var(--wp--preset--color--contrast, #222);
}

.elaris-notif-item__name {
	font-weight: 700;
}

.elaris-notif-item__action {
	font-weight: 400;
	color: var(--wp--preset--color--muted, #555);
}

.elaris-notif-item__preview {
	margin: 0 0 0.15rem;
	font-size: 0.85rem;
	line-height: 1.3;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.elaris-notif-item__time {
	display: block;
	font-size: 0.8rem;
	color: var(--wp--preset--color--muted, #888);
}

.elaris-notif-item__dot {
	flex-shrink: 0;
	width: 8px;
	height: 8px;
	margin-top: 0.45rem;
	margin-left: 0.25rem;
	border-radius: 50%;
	background: #e91e8c;
}

@media (max-width: 520px) {
	.elaris-notifications__header {
		flex-direction: column;
		align-items: stretch;
	}

	.elaris-notifications__mark-all {
		justify-content: center;
		width: 100%;
	}
}

/* Onboarding wizard (profile setup) — mobile-first */
.elaris-onb {
	max-width: 440px;
	margin: 0 auto;
	padding: 0.5rem var(--elaris-gutter-tight, 1rem) calc(1.25rem + env(safe-area-inset-bottom, 0px));
	min-height: min(100vh, 900px);
	box-sizing: border-box;
	background: linear-gradient(180deg, #fff5f7 0%, #ffffff 55%);
}

.elaris-onb__top {
	position: relative;
	margin-bottom: 1.25rem;
}

.elaris-onb-back {
	position: absolute;
	left: 0;
	top: 0;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	border: 1px solid rgba(0, 0, 0, 0.06);
	background: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	box-shadow: 0 4px 14px rgba(45, 21, 34, 0.07);
	z-index: 2;
}

.elaris-onb-progress {
	height: 4px;
	border-radius: 999px;
	background: rgba(233, 30, 140, 0.15);
	margin: 0 52px 0.65rem;
	overflow: hidden;
}

.elaris-onb-progress__fill {
	height: 100%;
	border-radius: 999px;
	background: linear-gradient(90deg, #ff4b8b, #ff9068);
	transition: width 0.35s ease;
}

.elaris-onb-meta {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	padding: 0 0.15rem 0 52px;
	font-size: 0.8rem;
	color: var(--wp--preset--color--muted, #6b6b6b);
}

.elaris-onb-meta__label {
	font-weight: 600;
}

.elaris-onb__stage {
	outline: none;
	min-height: 12rem;
}

.elaris-onb-step {
	animation: elarisOnbFade 0.25s ease;
}

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

@media (prefers-reduced-motion: reduce) {
	.elaris-onb-step {
		animation: none;
	}
}

.elaris-onb-h1 {
	font-family: "Fraunces", Georgia, serif;
	font-size: clamp(1.45rem, 4.5vw, 1.75rem);
	font-weight: 600;
	margin: 0 0 0.5rem;
	line-height: 1.15;
	color: var(--wp--preset--color--contrast, #1a1a1a);
}

.elaris-onb-lead {
	margin: 0 0 1.25rem;
	font-size: 0.95rem;
	color: var(--wp--preset--color--muted, #5c5c5c);
	line-height: 1.4;
}

.elaris-onb-sub {
	font-weight: 600;
	font-size: 0.9rem;
	margin: 1rem 0 0.5rem;
	color: var(--wp--preset--color--contrast, #222);
}

.elaris-onb-field {
	display: block;
	margin-bottom: 1rem;
}

.elaris-onb-field__l {
	display: block;
	font-weight: 700;
	font-size: 0.88rem;
	margin-bottom: 0.4rem;
}

.elaris-onb-input {
	width: 100%;
	box-sizing: border-box;
	padding: 0.75rem 1rem;
	border-radius: 999px;
	border: 1px solid rgba(0, 0, 0, 0.12);
	font: inherit;
	background: #fff;
}

.elaris-onb-date-wrap {
	position: relative;
	display: block;
}

.elaris-onb-date-wrap .elaris-onb-input {
	padding-right: 2.75rem;
}

.elaris-onb-date-ic {
	position: absolute;
	right: 1rem;
	top: 50%;
	transform: translateY(-50%);
	pointer-events: none;
	opacity: 0.45;
}

.elaris-onb-chips {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

.elaris-onb-chip {
	padding: 0.55rem 1rem;
	border-radius: 999px;
	border: 1px solid rgba(0, 0, 0, 0.12);
	background: #fff;
	font: inherit;
	font-weight: 600;
	font-size: 0.88rem;
	cursor: pointer;
	transition: border-color 0.15s ease, color 0.15s ease, box-shadow 0.15s ease;
}

.elaris-onb-chip.is-selected {
	border-color: transparent;
	color: #fff;
	background: linear-gradient(90deg, #ff4b8b, #ff9068);
	box-shadow: 0 6px 18px rgba(255, 75, 139, 0.28);
}

.elaris-onb-photos {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0.65rem;
}

.elaris-onb-photo-cell {
	position: relative;
	aspect-ratio: 3 / 4;
	border-radius: 18px;
	overflow: hidden;
}

.elaris-onb-photo-cell__inp {
	position: absolute;
	width: 0;
	height: 0;
	opacity: 0;
	pointer-events: none;
}

.elaris-onb-photo-face {
	position: absolute;
	inset: 0;
	border: 2px dashed rgba(0, 0, 0, 0.14);
	border-radius: 18px;
	background: rgba(255, 255, 255, 0.85);
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
}

.elaris-onb-photo-face img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.elaris-onb-photo-face--empty {
	background: #faf8fa;
}

.elaris-onb-photo-main {
	position: absolute;
	bottom: 0.5rem;
	left: 50%;
	transform: translateX(-50%);
	z-index: 2;
	font-size: 0.65rem;
	font-weight: 700;
	padding: 0.2rem 0.5rem;
	border-radius: 999px;
	background: #e91e8c;
	color: #fff;
	pointer-events: none;
}

.elaris-onb-interest-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(104px, 1fr));
	gap: 0.5rem;
}

.elaris-onb-interest {
	padding: 0.45rem 0.55rem;
	border-radius: 999px;
	border: 1px solid rgba(0, 0, 0, 0.12);
	background: #fff;
	font: inherit;
	font-size: 0.82rem;
	font-weight: 600;
	cursor: pointer;
	transition: border-color 0.15s ease, color 0.15s ease;
}

.elaris-onb-interest.is-selected {
	border-color: transparent;
	color: #fff;
	background: linear-gradient(90deg, #ff4b8b, #ff9068);
}

.elaris-onb-prompt-card {
	background: #fff;
	border-radius: 18px;
	padding: 1rem 1.1rem 1.15rem;
	margin-bottom: 0.85rem;
	box-shadow: 0 8px 28px rgba(45, 21, 34, 0.07);
	border: 1px solid rgba(0, 0, 0, 0.05);
}

.elaris-onb-prompt-k {
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: #e91e8c;
	margin: 0 0 0.5rem;
}

.elaris-onb-prompt-q {
	margin: 0 0 0.65rem;
}

.elaris-onb-prompt-select {
	width: 100%;
	font-family: "Fraunces", Georgia, serif;
	font-size: 1.05rem;
	font-weight: 600;
	border: none;
	background: transparent;
	color: var(--wp--preset--color--contrast, #1a1a1a);
	cursor: pointer;
	padding: 0.25rem 0;
}

.elaris-onb-textarea {
	width: 100%;
	box-sizing: border-box;
	min-height: 5rem;
	padding: 0.75rem 0.9rem;
	border-radius: 14px;
	border: 1px solid rgba(0, 0, 0, 0.12);
	font: inherit;
	font-size: 0.92rem;
	resize: vertical;
}

.elaris-onb-add-prompt {
	width: 100%;
	padding: 0.85rem 1rem;
	border-radius: 16px;
	border: 2px dashed rgba(0, 0, 0, 0.14);
	background: transparent;
	font: inherit;
	font-size: 0.92rem;
	font-weight: 600;
	color: var(--wp--preset--color--muted, #666);
	cursor: pointer;
	margin-top: 0.25rem;
}

.elaris-onb-slider-block {
	margin-bottom: 1.35rem;
}

.elaris-onb-slider-head {
	display: flex;
	justify-content: space-between;
	font-size: 0.88rem;
	font-weight: 600;
	margin-bottom: 0.5rem;
}

.elaris-onb-slider-val {
	color: var(--wp--preset--color--muted, #555);
	font-weight: 600;
}

.elaris-onb-dual-range {
	display: grid;
	grid-template-rows: 1fr;
	align-items: center;
	height: 2rem;
}

.elaris-onb-dual-range input[type='range'] {
	grid-row: 1;
	grid-column: 1;
	width: 100%;
	height: 0.5rem;
	-webkit-appearance: none;
	appearance: none;
	background: transparent;
	pointer-events: none;
}

.elaris-onb-dual-range input[type='range']::-webkit-slider-thumb {
	-webkit-appearance: none;
	appearance: none;
	width: 22px;
	height: 22px;
	border-radius: 50%;
	background: linear-gradient(145deg, #ff4b8b, #ff9068);
	border: 3px solid #fff;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
	pointer-events: auto;
	cursor: pointer;
}

.elaris-onb-dual-range input[type='range']::-webkit-slider-runnable-track {
	height: 6px;
	border-radius: 999px;
	background: rgba(0, 0, 0, 0.08);
}

.elaris-onb-dual-range input[type='range']:first-of-type::-webkit-slider-runnable-track {
	background: linear-gradient(90deg, #ff4b8b, #ff9068);
	opacity: 0.35;
}

#elaris-onb-distance {
	width: 100%;
	height: 0.5rem;
	-webkit-appearance: none;
	appearance: none;
	border-radius: 999px;
	background: rgba(0, 0, 0, 0.08);
}

#elaris-onb-distance::-webkit-slider-thumb {
	-webkit-appearance: none;
	width: 22px;
	height: 22px;
	border-radius: 50%;
	background: linear-gradient(145deg, #ff4b8b, #ff9068);
	border: 3px solid #fff;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
	cursor: pointer;
}

.elaris-onb-ready {
	margin-top: 0.5rem;
	padding: 1rem 1.1rem;
	border-radius: 16px;
	background: rgba(233, 30, 140, 0.08);
	border: 1px solid rgba(233, 30, 140, 0.12);
}

.elaris-onb-ready__title {
	margin: 0 0 0.35rem;
	font-weight: 700;
	font-size: 0.95rem;
	display: flex;
	align-items: center;
	gap: 0.4rem;
	color: var(--wp--preset--color--contrast, #1a1a1a);
}

.elaris-onb-ready__title img {
	opacity: 0.85;
}

.elaris-onb-ready__sub {
	margin: 0;
	font-size: 0.85rem;
	color: var(--wp--preset--color--muted, #5c5c5c);
	line-height: 1.35;
}

.elaris-onb-footer {
	position: sticky;
	bottom: 0;
	padding-top: 1rem;
	padding-bottom: env(safe-area-inset-bottom, 0px);
	background: linear-gradient(180deg, rgba(255, 245, 247, 0) 0%, #fff5f7 28%);
	margin-top: 1.5rem;
}

.elaris-onb-continue {
	width: 100%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	padding: 0.9rem 1.25rem;
	border: none;
	border-radius: 999px;
	font: inherit;
	font-size: 1rem;
	font-weight: 700;
	color: #fff;
	cursor: pointer;
	background: linear-gradient(90deg, #ff4b8b, #ff9068);
	box-shadow: 0 10px 28px rgba(255, 75, 139, 0.35);
	transition: transform 0.12s ease, box-shadow 0.12s ease;
}

.elaris-onb-continue:active {
	transform: scale(0.98);
}

.elaris-onb-continue__ic {
	filter: brightness(0) invert(1);
}

.elaris-onb-skip {
	display: block;
	width: 100%;
	margin-top: 0.85rem;
	padding: 0.35rem;
	border: none;
	background: none;
	font: inherit;
	font-size: 0.9rem;
	font-weight: 600;
	color: #7b6d8a;
	cursor: pointer;
	text-align: center;
}

.elaris-onb-msg {
	min-height: 1.25rem;
	margin: 0.75rem 0 0;
	font-size: 0.88rem;
	text-align: center;
	color: #b00020;
}

/* Front page hero + inline register */
.elaris-home-hero {
	padding: clamp(2rem, 5vw, 4rem) 0;
	margin: 0 auto;
	background: var(--wp--preset--gradient--hero-pink);
}

.elaris-home-hero__inner {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: clamp(1.5rem, 4vw, 3rem);
}

.elaris-home-hero__copy {
	flex: 1 1 0;
	min-width: 0;
	max-width: none;
}

.elaris-home-hero__title {
	font-family: "Fraunces", Georgia, serif;
	font-size: clamp(1.65rem, 4vw, 2.35rem);
	font-weight: 600;
	line-height: 1.12;
	color: var(--wp--preset--color--contrast);
	margin: 0 0 0.35rem;
}

.elaris-home-hero__lead {
	font-size: var(--wp--preset--font-size--medium);
	color: var(--wp--preset--color--muted);
	margin: 0 0 0.65rem;
	line-height: 1.35;
}

.elaris-home-hero__visual {
	flex: 1 1 0;
	width: 100%;
	max-width: 100%;
	min-width: 0;
	aspect-ratio: 1 / 1;
	position: relative;
	overflow: hidden;
	border-radius: 20px;
}

.elaris-home-hero__img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	display: block;
}

.elaris-hero-form {
	background: var(--wp--preset--color--surface);
	max-width: 540px;
	border-radius: 16px;
	padding: clamp(1rem, 2.5vw, 1.5rem) clamp(1.15rem, 2.75vw, 1.65rem);
	box-shadow: 0 8px 28px rgba(45, 21, 34, 0.07);
}

.elaris-hero-step-title {
	font-size: var(--wp--preset--font-size--large);
	margin: 0 0 0.4rem;
	line-height: 1.2;
	color: var(--wp--preset--color--contrast);
}

.elaris-hero-field {
	margin-bottom: 0.42rem;
}

.elaris-hero-label {
	display: block;
	font-size: 0.8125rem;
	font-weight: 600;
	color: #5c1b2a;
	margin-bottom: 0.2rem;
}

.elaris-hero-row {
	display: flex;
	gap: 0.45rem;
	margin-bottom: 0.3rem;
}

.elaris-hero-row--inputs {
	flex-wrap: wrap;
}

.elaris-hero-field--grow {
	flex: 1 1 120px;
	min-width: 0;
	margin-bottom: 0;
}

.elaris-hero-chip {
	flex: 1 1 0;
	appearance: none;
	font: inherit;
	font-size: 0.875rem;
	font-weight: 600;
	cursor: pointer;
	border: 2px solid #d8365d;
	background: #fff0f3;
	color: #5c1b2a;
	border-radius: 12px;
	padding: 0.32rem 0.55rem;
	transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}

.elaris-hero-chip--full {
	width: 100%;
	flex: none;
}

.elaris-hero-chip:hover {
	border-color: var(--wp--preset--color--primary);
}

.elaris-hero-chip.is-selected {
	background: var(--wp--preset--color--primary);
	border-color: var(--wp--preset--color--primary);
	color: #fff;
}

.elaris-hero-input {
	width: 100%;
	font: inherit;
	font-size: 0.9375rem;
	padding: 0.38rem 0.65rem;
	border: 2px solid #800020;
	border-radius: 12px;
	background: #fff;
	color: var(--wp--preset--color--contrast);
}

.elaris-hero-input::placeholder {
	color: #a08a95;
}

.elaris-hero-input:focus {
	outline: 2px solid rgba(233, 30, 140, 0.35);
	outline-offset: 1px;
}

.elaris-hero-terms {
	display: flex;
	gap: 0.4rem;
	align-items: flex-start;
	font-size: 0.72rem;
	line-height: 1.3;
	color: var(--wp--preset--color--muted);
	margin: 0.2rem 0 0.42rem;
	cursor: pointer;
}

.elaris-hero-terms input {
	margin-top: 0.15rem;
	flex-shrink: 0;
	width: 0.95rem;
	height: 0.95rem;
	accent-color: var(--wp--preset--color--primary);
}

.elaris-hero-terms a {
	color: #5c1b2a;
	text-decoration: underline;
}

.elaris-hero-cta {
	width: 100%;
	border-radius: 12px;
	padding: 0.48rem 0.85rem;
	font-size: 0.9375rem;
	font-weight: 700;
	margin-top: 0.08rem;
}

.elaris-hero-legal {
	font-size: 0.6875rem;
	line-height: 1.32;
	color: var(--wp--preset--color--muted);
	margin: 0 0 0.35rem;
}

.elaris-hero-password-wrap {
	position: relative;
}

.elaris-hero-password-wrap .elaris-hero-input {
	padding-right: 2.4rem;
}

.elaris-hero-pass-toggle {
	position: absolute;
	right: 0.35rem;
	top: 50%;
	transform: translateY(-50%);
	border: 0;
	background: transparent;
	padding: 0.35rem;
	cursor: pointer;
	color: #a08a95;
	line-height: 0;
	border-radius: 8px;
}

.elaris-hero-pass-toggle:hover {
	color: var(--wp--preset--color--muted);
}

.elaris-hero-pass-toggle[data-showing="1"] .elaris-hero-pass-icon path:last-child {
	display: none;
}

.elaris-hero-back {
	display: block;
	width: 100%;
	margin-top: 0.35rem;
	background: none;
	border: none;
	font: inherit;
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--wp--preset--color--primary-dark);
	cursor: pointer;
	text-decoration: underline;
	padding: 0.12rem;
}

.elaris-hero-progress {
	display: flex;
	gap: 0.45rem;
	justify-content: center;
	margin-top: 0.45rem;
}

.elaris-hero-progress__bar {
	flex: 1;
	max-width: 4rem;
	height: 4px;
	border-radius: 999px;
	background: #ffd0e0;
	transition: background 0.2s ease;
}

.elaris-hero-progress__bar.is-active {
	background: #d8365d;
}

.elaris-hero-msg {
	min-height: 1em;
	font-size: 0.875rem;
	margin: 0.45rem 0 0;
	color: var(--wp--preset--color--primary-dark);
}

@media (max-width: 782px) {
	.elaris-home-hero__inner {
		flex-direction: column;
		align-items: stretch;
	}

	.elaris-home-hero__copy {
		flex: 1 1 auto;
		width: 100%;
	}

	.elaris-home-hero__visual {
		order: -1;
		flex: 0 0 auto;
		max-width: min(100%, 420px);
		width: 100%;
		align-self: center;
		border-radius: 16px;
	}
}

/* Full-bleed marquee (home) */
.elaris-marquee {
	--elaris-marquee-duration: 38s;
	position: relative;
	margin: 0 auto;
	width: 100vw;
	max-width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	padding: 0.85rem 0;
	background: linear-gradient(90deg, #fff0f6 0%, #ffe8f0 50%, #fff0f6 100%);
	border-block: 1px solid rgba(216, 54, 93, 0.15);
	overflow: hidden;
	box-sizing: border-box;
}

.elaris-marquee__viewport {
	overflow: hidden;
	justify-content: center;
	align-items: center;
	max-width: 100%;
	margin: 0 auto;
	width: 100%;
	mask-image: linear-gradient(90deg, transparent 0%, #000 4%, #000 96%, transparent 100%);
	-webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 4%, #000 96%, transparent 100%);
}

.elaris-marquee__track {
	display: flex;
	justify-content: center;
	flex-direction: row;
	width: max-content;
	animation: elaris-marquee-scroll var(--elaris-marquee-duration, 38s) linear infinite;
}

.elaris-marquee__seq {
	display: flex;
	flex-direction: row;
	flex-shrink: 0;
	align-items: center;
	gap: 0.5rem 1.25rem;
	padding-inline: 0.75rem;
}

.elaris-marquee__text {
	font-family: "DM Sans", system-ui, sans-serif;
	font-size: clamp(0.8rem, 1.9vw, 0.95rem);
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: #5c1b2a;
	white-space: nowrap;
}

.elaris-marquee__star {
	font-size: 0.65em;
	color: var(--wp--preset--color--primary);
	line-height: 1;
	opacity: 0.9;
}

@keyframes elaris-marquee-scroll {
	from {
		transform: translateX(0);
	}

	to {
		transform: translateX(-50%);
	}
}

@media (prefers-reduced-motion: reduce) {
	.elaris-marquee__track {
		animation: none;
		transform: translateX(0);
		justify-content: center;
		flex-wrap: wrap;
		row-gap: 0.35rem;
		width: 100%;
		max-width: 100%;
	}

	.elaris-marquee__seq[aria-hidden="true"] {
		display: none;
	}

	.elaris-marquee__seq {
		flex-wrap: wrap;
		justify-content: center;
		padding-inline: var(--elaris-gutter);
	}
}

/* Easy process (home) */
.elaris-process {
	padding: clamp(2.5rem, 6vw, 4.5rem) 0;
	margin-block-start: 0;
	background: var(--wp--preset--color--surface);
}

.elaris-process__inner {
	max-width: var(--elaris-max-width);
	margin: 0 auto;
}

.elaris-process__header {
	text-align: center;
	max-width: 36rem;
	margin: 0 auto clamp(1.75rem, 4vw, 2.5rem);
}

.elaris-process__title {
	font-family: "Fraunces", Georgia, serif;
	font-size: clamp(1.5rem, 3.5vw, 2rem);
	font-weight: 600;
	color: var(--wp--preset--color--contrast);
	margin: 0 0 0.5rem;
	line-height: 1.2;
}

.elaris-process__lead {
	font-size: var(--wp--preset--font-size--medium);
	color: var(--wp--preset--color--muted);
	margin: 0;
	line-height: 1.5;
}

.elaris-process__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 15.5rem), 1fr));
	gap: clamp(1rem, 3vw, 1.5rem);
}

.elaris-process__step {
	margin: 0;
	padding: clamp(1rem, 2.5vw, 1.35rem);
	background: linear-gradient(145deg, #fff8fb 0%, #fff0f5 100%);
	border: 1px solid rgba(216, 54, 93, 0.18);
	border-radius: 18px;
	display: flex;
	gap: 0.85rem;
	align-items: flex-start;
	min-height: 100%;
	box-sizing: border-box;
}

.elaris-process__num {
	flex-shrink: 0;
	width: 2.25rem;
	height: 2.25rem;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 0.95rem;
	font-weight: 700;
	color: #fff;
	background: linear-gradient(135deg, var(--wp--preset--color--primary), #ff6b9d);
	border-radius: 12px;
	line-height: 1;
}

.elaris-process__body {
	min-width: 0;
}

.elaris-process__step-title {
	font-size: 1rem;
	font-weight: 700;
	color: #5c1b2a;
	margin: 0 0 0.35rem;
	line-height: 1.3;
}

.elaris-process__step-text {
	font-size: 0.875rem;
	color: var(--wp--preset--color--muted);
	line-height: 1.5;
	margin: 0;
}

@media (min-width: 960px) {
	.elaris-process__list {
		grid-template-columns: repeat(4, 1fr);
	}
}

@media (max-width: 599px) {
	.elaris-process__step {
		flex-direction: row;
		align-items: flex-start;
	}
}

/* FAQ (home) */
.elaris-faq {
	padding: clamp(2.5rem, 6vw, 4.5rem) 0;
	background: var(--wp--preset--color--base);
}

.elaris-faq__inner {
	max-width: min(40rem, 100%);
	margin: 0 auto;
}

.elaris-faq__header {
	text-align: center;
	margin-bottom: clamp(1.5rem, 3vw, 2rem);
}

.elaris-faq__title {
	font-family: "Fraunces", Georgia, serif;
	font-size: clamp(1.5rem, 3.5vw, 2rem);
	font-weight: 600;
	color: var(--wp--preset--color--contrast);
	margin: 0 0 0.5rem;
	line-height: 1.2;
}

.elaris-faq__lead {
	font-size: var(--wp--preset--font-size--medium);
	color: var(--wp--preset--color--muted);
	margin: 0;
	line-height: 1.5;
}

.elaris-faq__list {
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
}

.elaris-faq__item {
	margin: 0;
	border: 1px solid rgba(216, 54, 93, 0.2);
	border-radius: 14px;
	background: var(--wp--preset--color--surface);
	overflow: hidden;
	box-shadow: 0 2px 12px rgba(45, 21, 34, 0.04);
}

.elaris-faq__summary {
	list-style: none;
	cursor: pointer;
	padding: 1rem 2.75rem 1rem 1.1rem;
	font-size: 0.95rem;
	font-weight: 600;
	color: #5c1b2a;
	line-height: 1.4;
	position: relative;
	user-select: none;
}

.elaris-faq__summary::-webkit-details-marker {
	display: none;
}

.elaris-faq__summary::after {
	content: "";
	position: absolute;
	right: 1.1rem;
	top: 50%;
	width: 0.45rem;
	height: 0.45rem;
	border-right: 2px solid var(--wp--preset--color--primary);
	border-bottom: 2px solid var(--wp--preset--color--primary);
	transform: translateY(-65%) rotate(45deg);
	transition: transform 0.2s ease;
}

.elaris-faq__item[open] .elaris-faq__summary::after {
	transform: translateY(-35%) rotate(-135deg);
}

.elaris-faq__summary:hover {
	background: rgba(255, 240, 246, 0.5);
}

.elaris-faq__panel {
	padding: 0 1.1rem 1rem;
	border-top: 1px solid rgba(216, 54, 93, 0.1);
}

.elaris-faq__answer {
	margin: 0;
	padding-top: 0.75rem;
	font-size: 0.9rem;
	line-height: 1.55;
	color: var(--wp--preset--color--muted);
}

@media (prefers-reduced-motion: reduce) {
	.elaris-faq__summary::after {
		transition: none;
	}
}

/* —— Home promo: About / Why us / Safety —— */
.wp-site-blocks .wp-block-shortcode:has(.elaris-promo) {
	margin-block-start: 0;
}

.elaris-promo {
	background: var(--wp--preset--color--surface);
	padding: clamp(2.5rem, 6vw, 4.5rem) 0;
	margin-block-start: 0;
}

.elaris-promo--why{
	background: var(--wp--preset--color--base);
}

.elaris-promo__inner {
	width: 100%;
}

.elaris-promo-eyebrow {
	margin: 0 0 0.75rem;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--wp--preset--color--primary);
}

.elaris-promo-heading {
	margin: 0 0 1rem;
	font-family: var(--wp--preset--font-family--dm-sans), "DM Sans", system-ui, sans-serif;
	font-size: clamp(1.65rem, 4.2vw, 2.35rem);
	font-weight: 700;
	line-height: 1.2;
	color: #000;
}

.elaris-promo-lead {
	margin: 0 0 1.5rem;
	font-size: clamp(0.95rem, 2.2vw, 1.05rem);
	line-height: 1.65;
	color: #666;
	max-width: 34rem;
}

.elaris-promo-cta.elaris-btn {
	border-radius: 999px;
	padding: 0.75rem 1.75rem;
	font-weight: 600;
}

/* About split + collage */
.elaris-about-split {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1.15fr);
	gap: clamp(1.75rem, 4vw, 3.5rem);
	align-items: center;
}

.elaris-about-split__collage {
	position: relative;
	min-height: clamp(220px, 42vw, 420px);
}

.elaris-about-split__img {
	display: block;
	width: 100%;
	height: auto;
	border-radius: clamp(16px, 3vw, 28px);
	object-fit: cover;
	box-shadow: 0 18px 48px rgba(45, 21, 34, 0.12);
}

.elaris-about-split__img--main {
	position: relative;
	z-index: 1;
	aspect-ratio: 3 / 4;
	max-height: min(520px, 70vh);
	margin-left: auto;
	width: 88%;
}

.elaris-about-split__img--inset {
	position: absolute;
	z-index: 2;
	left: 0;
	bottom: 4%;
	width: min(52%, 280px);
	aspect-ratio: 4 / 3;
	border: 4px solid var(--wp--preset--color--surface);
	box-shadow: 0 14px 36px rgba(45, 21, 34, 0.18);
}

@media (max-width: 781px) {
	.elaris-about-split {
		grid-template-columns: 1fr;
	}

	.elaris-about-split__collage {
		order: 2;
		max-width: 28rem;
		margin-inline: auto;
	}

	.elaris-about-split__copy {
		order: 1;
	}

	.elaris-about-split__img--main {
		width: 100%;
		max-height: none;
	}

	.elaris-about-split__img--inset {
		width: 46%;
		bottom: 8%;
		left: 4%;
	}
}

/* Why choose us */
.elaris-promo-section-title {
	margin: 0 0 clamp(1.75rem, 4vw, 2.5rem);
	font-family: var(--wp--preset--font-family--dm-sans), "DM Sans", system-ui, sans-serif;
	font-size: clamp(1.5rem, 3.5vw, 2rem);
	font-weight: 700;
	text-align: center;
	color: #000;
}

.elaris-why-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: clamp(1rem, 2.5vw, 1.5rem);
}

.elaris-why-card {
	margin: 0;
	padding: clamp(1.25rem, 3vw, 1.75rem);
	background: var(--wp--preset--color--surface);
	border-radius: 18px;
	box-shadow: 0 4px 24px rgba(45, 21, 34, 0.07);
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	border: 1px solid rgba(233, 30, 140, 0.08);
}

.elaris-why-card__icon-wrap {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 3.5rem;
	height: 3.5rem;
	border-radius: 14px;
	margin-bottom: 1rem;
}

.elaris-why-card--pink .elaris-why-card__icon-wrap {
	background: #ffe4ef;
}

.elaris-why-card--blue .elaris-why-card__icon-wrap {
	background: #e3f2fd;
}

.elaris-why-card--orange .elaris-why-card__icon-wrap {
	background: #fff3e0;
}

.elaris-why-card--purple .elaris-why-card__icon-wrap {
	background: #ede7f6;
}

.elaris-why-card__icon {
	width: 1.65rem;
	height: 1.65rem;
	object-fit: contain;
}

.elaris-why-card__title {
	margin: 0 0 0.5rem;
	font-size: 1.05rem;
	font-weight: 700;
	color: #000;
	line-height: 1.3;
}

.elaris-why-card__text {
	margin: 0 0 1rem;
	font-size: 0.875rem;
	line-height: 1.55;
	color: #666;
	flex-grow: 1;
}

.elaris-why-card__link {
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--wp--preset--color--primary);
	text-decoration: none;
}

.elaris-why-card__link:hover {
	text-decoration: underline;
}

@media (max-width: 1023px) {
	.elaris-why-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 560px) {
	.elaris-why-grid {
		grid-template-columns: 1fr;
	}
}

/* Safety split */
.elaris-safety-split {
	display: grid;
	grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
	gap: clamp(1.75rem, 4vw, 3.5rem);
	align-items: center;
}

.elaris-safety-frame {
	position: relative;
	border-radius: clamp(16px, 3vw, 28px);
	overflow: visible;
}

.elaris-safety-frame__img {
	display: block;
	width: 100%;
	height: auto;
	border-radius: clamp(16px, 3vw, 28px);
	object-fit: cover;
	aspect-ratio: 4 / 3;
	box-shadow: 0 18px 48px rgba(45, 21, 34, 0.12);
}

.elaris-safety-float {
	position: absolute;
	display: flex;
	gap: 0.65rem;
	align-items: flex-start;
	max-width: min(280px, 86%);
	padding: 0.85rem 1rem;
	background: var(--wp--preset--color--surface);
	border: 1px solid rgba(233, 30, 140, 0.45);
	border-radius: 14px;
	box-shadow: 0 10px 28px rgba(45, 21, 34, 0.1);
	z-index: 2;
}

.elaris-safety-float--tr {
	top: 6%;
	right: -4%;
}

.elaris-safety-float--bl {
	bottom: 8%;
	left: -4%;
}

.elaris-safety-float__icon {
	flex-shrink: 0;
	width: 1.5rem;
	height: 1.5rem;
	object-fit: contain;
}

.elaris-safety-float__title {
	display: block;
	font-size: 0.88rem;
	font-weight: 700;
	color: #000;
	line-height: 1.25;
	margin-bottom: 0.2rem;
}

.elaris-safety-float__text {
	margin: 0;
	font-size: 0.78rem;
	line-height: 1.45;
	color: #666;
}

.elaris-safety-list {
	margin: 1.25rem 0 0;
	padding-left: 1.15rem;
	color: #444;
	font-size: clamp(0.95rem, 2vw, 1.02rem);
	line-height: 1.7;
}

.elaris-safety-list li {
	margin-bottom: 0.35rem;
}

.elaris-safety-list li::marker {
	color: var(--wp--preset--color--primary);
}

@media (max-width: 781px) {
	.elaris-safety-split {
		grid-template-columns: 1fr;
	}

	.elaris-safety-split__visual {
		order: 1;
	}

	.elaris-safety-split__copy {
		order: 2;
	}

	.elaris-safety-float--tr {
		right: 2%;
		top: 4%;
		max-width: 78%;
	}

	.elaris-safety-float--bl {
		left: 2%;
		bottom: 6%;
		max-width: 78%;
	}
}

/* —— About page (story, CTA, why we built) —— */
.wp-site-blocks .wp-block-shortcode:has(.elaris-about-page) {
	margin-block-start: 0;
}

.elaris-about-page {
	width: 100%;
}

/* Story + stats */
.elaris-about-story {
	background: var(--wp--preset--color--surface);
	padding: clamp(2.5rem, 7vw, 5rem) 0 clamp(2rem, 5vw, 3.5rem);
	text-align: center;
}

.elaris-about-story__inner {
	max-width: 56rem;
	margin-inline: auto;
}

.elaris-about-story__badge {
	display: inline-block;
	margin: 0 0 1.25rem;
	padding: 0.4rem 1rem;
	border-radius: 999px;
	background: rgba(233, 30, 140, 0.1);
	color: var(--wp--preset--color--primary);
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

.elaris-about-story__title {
	margin: 0 0 1.25rem;
	font-family: var(--wp--preset--font-family--fraunces), Georgia, "Times New Roman", serif;
	font-size: clamp(2rem, 5.5vw, 3.15rem);
	font-weight: 600;
	line-height: 1.15;
	color: #000;
}

.elaris-about-story__accent {
	color: var(--wp--preset--color--primary);
}

.elaris-about-story__lead {
	margin: 0 auto;
	max-width: 38rem;
	font-size: clamp(0.95rem, 2.2vw, 1.08rem);
	line-height: 1.65;
	color: #666;
}

.elaris-about-stats {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: clamp(0.85rem, 2vw, 1.25rem);
	margin-top: clamp(2rem, 5vw, 3rem);
	text-align: center;
}

.elaris-about-stat {
	padding: clamp(1.15rem, 3vw, 1.65rem) clamp(0.85rem, 2vw, 1.1rem);
	background: var(--wp--preset--color--surface);
	border-radius: 18px;
	box-shadow: 0 4px 28px rgba(233, 30, 140, 0.12);
	border: 1px solid rgba(233, 30, 140, 0.08);
}

.elaris-about-stat__icon-wrap {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 3.25rem;
	height: 3.25rem;
	margin: 0 auto 0.85rem;
	border-radius: 14px;
	background: rgba(233, 30, 140, 0.1);
}

.elaris-about-stat__icon {
	width: 1.65rem;
	height: 1.65rem;
	object-fit: contain;
}

.elaris-about-stat__value {
	margin: 0 0 0.35rem;
	font-family: var(--wp--preset--font-family--fraunces), Georgia, serif;
	font-size: clamp(1.5rem, 3.5vw, 2rem);
	font-weight: 600;
	color: #000;
	line-height: 1.2;
}

.elaris-about-stat__star {
	color: #111;
	font-style: normal;
}

.elaris-about-stat__label {
	margin: 0;
	font-size: 0.68rem;
	font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: #666;
}

@media (max-width: 900px) {
	.elaris-about-stats {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 480px) {
	.elaris-about-stats {
		grid-template-columns: 1fr;
	}
}

/* CTA gradient banner */
.elaris-about-cta {
	padding: clamp(1.5rem, 4vw, 2.5rem) 0 clamp(2.5rem, 6vw, 4rem);
	background: var(--wp--preset--color--surface);
}

.elaris-about-cta__panel {
	margin: 0 auto;
	max-width: min(56rem, 100%);
	padding: clamp(2.25rem, 6vw, 3.75rem) clamp(1.5rem, 5vw, 3rem);
	text-align: center;
	border-radius: clamp(22px, 4vw, 36px);
	background: linear-gradient(105deg, #e91e8c 0%, #ff007f 35%, #ff8c42 100%);
	box-shadow: 0 20px 50px rgba(233, 30, 140, 0.25);
}

.elaris-about-cta__title {
	margin: 0 0 0.75rem;
	font-family: var(--wp--preset--font-family--fraunces), Georgia, serif;
	font-size: clamp(1.65rem, 4.5vw, 2.35rem);
	font-weight: 600;
	color: #fff;
	line-height: 1.2;
}

.elaris-about-cta__sub {
	margin: 0 0 1.5rem;
	font-size: clamp(0.95rem, 2.2vw, 1.05rem);
	line-height: 1.55;
	color: rgba(255, 255, 255, 0.95);
	max-width: 28rem;
	margin-inline: auto;
}

.elaris-about-cta__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.35rem;
	padding: 0.8rem 1.85rem;
	border-radius: 999px;
	background: #fff;
	color: var(--wp--preset--color--primary-dark);
	font-size: 1rem;
	font-weight: 700;
	text-decoration: none;
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
}

.elaris-about-cta__btn:hover {
	filter: brightness(1.03);
}

.elaris-about-cta__btn:focus-visible {
	outline: 2px solid #fff;
	outline-offset: 3px;
}

/* Why we built */
.elaris-about-why {
	background: var(--wp--preset--color--base);
	padding: clamp(2.5rem, 7vw, 5rem) 0;
}

.elaris-about-why__grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	gap: clamp(1.75rem, 4vw, 3.5rem);
	align-items: center;
}

.elaris-about-why__img {
	display: block;
	width: 100%;
	height: auto;
	border-radius: clamp(18px, 3vw, 28px);
	object-fit: cover;
	aspect-ratio: 4 / 3;
	box-shadow: 0 16px 40px rgba(45, 21, 34, 0.1);
}

.elaris-about-why__title {
	margin: 0 0 1.25rem;
	font-family: var(--wp--preset--font-family--fraunces), Georgia, serif;
	font-size: clamp(1.65rem, 3.8vw, 2.25rem);
	font-weight: 600;
	color: #000;
	line-height: 1.2;
}

.elaris-about-why__p {
	margin: 0 0 1rem;
	font-size: clamp(0.95rem, 2.2vw, 1.05rem);
	line-height: 1.65;
	color: #555;
}

.elaris-about-why__p:last-child {
	margin-bottom: 0;
}

@media (max-width: 781px) {
	.elaris-about-why__grid {
		grid-template-columns: 1fr;
	}

	.elaris-about-why__media {
		order: 1;
	}

	.elaris-about-why__copy {
		order: 2;
	}
}

/* —— Account hub & subpages —— */
.wp-site-blocks .wp-block-shortcode:has(.elaris-account-hub),
.wp-site-blocks .wp-block-shortcode:has(.elaris-account-sub),
.wp-site-blocks .wp-block-shortcode:has(.elaris-account-guest) {
	margin-block-start: 0;
}

.elaris-breadcrumb__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	list-style: none;
	margin: 0 0 1.1rem;
	padding: 0;
	font-size: 0.8125rem;
	color: #666;
}

.elaris-breadcrumb__item {
	display: inline-flex;
	align-items: center;
}

.elaris-breadcrumb__item + .elaris-breadcrumb__item::before {
	content: "›";
	margin: 0 0.45rem;
	color: #aaa;
	font-size: 0.9em;
}

.elaris-breadcrumb__link {
	color: #666;
	text-decoration: none;
}

.elaris-breadcrumb__link:hover {
	color: var(--wp--preset--color--primary);
	text-decoration: underline;
}

.elaris-breadcrumb__current {
	color: #333;
	font-weight: 600;
}

.elaris-account-hub {
	/* Block padding only — same element has .elaris-shell; shorthand 0 horizontal was wiping shell gutters. */
	padding-block-start: clamp(0.75rem, 3vw, 1.25rem);
	padding-block-end: clamp(2rem, 5vw, 3rem);
	max-width: 32rem;
	margin-inline: auto;
}

.elaris-account-hero {
	border-radius: clamp(22px, 4vw, 30px);
	overflow: hidden;
	padding: 5px 10px ;
	background: linear-gradient(100deg, #e91e63 0%, #ff3366 38%, #ff7043 100%);
	box-shadow: 0 20px 48px rgba(233, 30, 140, 0.32), 0 4px 16px rgba(255, 87, 34, 0.15);
	margin-bottom: 1.1rem;
}

.elaris-account-hero__main {
	display: flex;
	align-items: center;
	gap: 1rem;
	padding: 1.35rem 1.35rem 1.1rem;
}

.elaris-account-hero__avatar {
	width: 4.75rem;
	height: 4.75rem;
	border-radius: 50%;
	object-fit: cover;
	border: 3px solid #fff;
	box-shadow: 0 0 0 3px rgba(255, 45, 120, 0.95);
	flex-shrink: 0;
	background: rgba(255, 255, 255, 0.2);
}

.elaris-account-hero__text {
	min-width: 0;
	text-align: left;
}

.elaris-account-hero__name {
	margin: 0 0 0.2rem;
	font-family: var(--wp--preset--font-family--fraunces), Georgia, serif;
	font-size: clamp(1.25rem, 3.5vw, 1.5rem);
	font-weight: 600;
	color: #fff;
	line-height: 1.2;
	word-break: break-word;
}

.elaris-account-hero__email {
	margin: 0;
	font-family: var(--wp--preset--font-family--dm-sans), system-ui, -apple-system, sans-serif;
	font-size: 0.875rem;
	font-weight: 500;
	color: rgba(255, 255, 255, 0.9);
	word-break: break-all;
}

.elaris-account-hero__edit {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem;
	width: calc(100% - 1.5rem);
	margin: 0 15px 15px;
	padding: 0.9rem 1rem;
	border-radius: clamp(14px, 3vw, 18px);
	background: rgba(255, 255, 255, 0.28);
	border: 1px solid rgba(255, 255, 255, 0.35);
	color: #fff;
	font-family: var(--wp--preset--font-family--dm-sans), system-ui, sans-serif;
	font-size: 0.9375rem;
	font-weight: 600;
	text-decoration: none;
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	box-sizing: border-box;
}

.elaris-account-hero__edit:hover {
	background: rgba(255, 255, 255, 0.38);
}

.elaris-account-hero__edit img {
	flex-shrink: 0;
	opacity: 1;
	filter: brightness(0) invert(1);
}

.elaris-account-section__label {
	margin: 0 0 0.5rem;
	padding-left: 0.15rem;
	font-family: var(--wp--preset--font-family--fraunces), Georgia, serif;
	font-size: 0.72rem;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: #888;
}

.elaris-account-section + .elaris-account-section {
	margin-top: 1.25rem;
}

.elaris-account-card {
	border-radius: clamp(18px, 3vw, 24px);
	background: var(--wp--preset--color--surface);
	box-shadow: 0 4px 24px rgba(45, 21, 34, 0.06);
	border: 1px solid rgba(0, 0, 0, 0.06);
	overflow: hidden;
}

.elaris-account-row {
	display: flex;
	align-items: center;
	gap: 0.85rem;
	padding: 0.95rem 1rem;
	border-bottom: 1px solid rgba(0, 0, 0, 0.06);
	color: #1a1a1a;
	text-decoration: none;
	font-size: 0.95rem;
	font-weight: 500;
}

.elaris-account-card .elaris-account-row:last-child {
	border-bottom: none;
}

.elaris-account-row:hover {
	background: rgba(255, 240, 246, 0.45);
}

.elaris-account-row__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.elaris-account-row__icon img {
	display: block;
	opacity: 0.85;
}

.elaris-account-row__label {
	flex: 1;
	min-width: 0;
	text-align: left;
}

.elaris-account-row__chev {
	display: flex;
	flex-shrink: 0;
	opacity: 0.35;
}

.elaris-account-row--danger .elaris-account-row__label,
.elaris-account-row--danger .elaris-account-row__icon img {
	color: #c2185b;
}

.elaris-account-row--danger .elaris-account-row__icon img {
	filter: invert(21%) sepia(64%) saturate(2598%) hue-rotate(314deg) brightness(92%) contrast(92%);
}

.elaris-account-row--danger:hover {
	background: rgba(233, 30, 140, 0.06);
}

.elaris-account-guest {
	padding-block: 2rem;
	text-align: center;
	max-width: 24rem;
	margin-inline: auto;
}

.elaris-account-guest__msg {
	margin: 0 0 1.25rem;
	color: var(--wp--preset--color--muted);
}

/* Subpages */
.elaris-account-sub {
	padding-block-start: clamp(0.75rem, 3vw, 1.25rem);
	padding-block-end: clamp(2rem, 5vw, 3rem);
	max-width: 36rem;
	margin-inline: auto;
}

.elaris-account-sub__card {
	background: var(--wp--preset--color--surface);
	border-radius: clamp(18px, 3vw, 24px);
	padding: clamp(1.25rem, 4vw, 1.75rem);
	box-shadow: 0 6px 28px rgba(45, 21, 34, 0.07);
	border: 1px solid rgba(0, 0, 0, 0.06);
}

.elaris-account-sub__title {
	margin: 0 0 1rem;
	font-family: var(--wp--preset--font-family--fraunces), Georgia, serif;
	font-size: clamp(1.35rem, 3.5vw, 1.65rem);
	font-weight: 600;
	color: #111;
}

.elaris-account-sub__content {
	font-size: 0.95rem;
	line-height: 1.65;
	color: #444;
}

.elaris-account-sub__content p {
	margin: 0 0 1rem;
}

.elaris-account-sub__content p:last-child {
	margin-bottom: 0;
}

.elaris-account-sub__muted {
	font-size: 0.88rem;
	color: #777;
}

.elaris-account-sub__list {
	margin: 0.75rem 0 0;
	padding-left: 1.2rem;
}

.elaris-account-sub__list a {
	color: var(--wp--preset--color--primary-dark);
	font-weight: 600;
}

.elaris-account-sub__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.65rem;
	margin-top: 1.25rem !important;
}

/* —— Profile editor (My profile) —— */
.wp-site-blocks .wp-block-shortcode:has(.elaris-pe) {
	margin-block-start: 0;
}

.elaris-pe {
	padding-block-start: clamp(0.5rem, 2vw, 1rem);
	padding-block-end: calc(2rem + env(safe-area-inset-bottom, 0px));
	max-width: 28rem;
	margin-inline: auto;
}

.elaris-pe__page-title {
	margin: 0 0 1.25rem;
	font-family: var(--wp--preset--font-family--fraunces), Georgia, serif;
	font-size: clamp(1.65rem, 4vw, 2rem);
	font-weight: 600;
	color: #111;
}

.elaris-pe-loading {
	margin: 2rem 0;
	text-align: center;
	color: #666;
	font-size: 0.95rem;
}

/* Photo grid: 2:1 columns so one 3:4 main ≈ two 3:4 stacked (+ one internal gap). */
.elaris-pe-photos {
	display: grid;
	grid-template-columns: minmax(0, 2.12fr) minmax(0, 1fr);
	grid-template-rows: auto auto auto;
	column-gap: 0.5rem;
	row-gap: 0.5rem;
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	margin-bottom: 1.25rem;
	align-items: stretch;
	justify-items: stretch;
}

.elaris-pe-photos__main {
	grid-column: 1;
	grid-row: 1 / span 2;
	min-width: 0;
	align-self: stretch;
	display: flex;
	flex-direction: column;
	align-items: stretch;
	justify-content: flex-start;
}

.elaris-pe-photos__main .elaris-pe-slot {
	max-width: 100%;
}

.elaris-pe-photos__col {
	grid-column: 2;
	grid-row: 1 / span 2;
	min-width: 0;
	align-self: stretch;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	justify-content: flex-start;
}

.elaris-pe-photos__col .elaris-pe-slot {
	flex: 0 0 auto;
	width: 100%;
	max-width: 100%;
}

/* Explicit span: line 1 → 3 covers both columns (avoids RTL / implicit track bugs). */
.elaris-pe-photos__row3 {
	grid-column: 1 / 3;
	grid-row: 3;
	width: 100%;
	max-width: 100%;
	min-width: 0;
	box-sizing: border-box;
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 0.5rem;
	align-items: start;
	justify-items: stretch;
}

/* All profile photo cells: portrait 3:4 */
.elaris-pe-slot {
	position: relative;
	width: 100%;
	aspect-ratio: 3 / 4;
	border-radius: 18px;
	overflow: hidden;
	background: #f3f3f5;
}

.elaris-pe-slot__inp {
	position: absolute;
	width: 0.1px;
	height: 0.1px;
	opacity: 0;
	pointer-events: none;
}

.elaris-pe-slot__face {
	position: absolute;
	inset: 0;
	cursor: pointer;
}

.elaris-pe-slot__face--empty {
	display: flex;
	align-items: center;
	justify-content: center;
	border: 2px dashed rgba(0, 0, 0, 0.12);
	background: #fafafa;
	border-radius: 18px;
	box-sizing: border-box;
}

.elaris-pe-slot__img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	display: block;
}

.elaris-pe-slot__plus {
	font-size: 1.75rem;
	font-weight: 300;
	color: #bbb;
	line-height: 1;
}

.elaris-pe-slot__fab {
	position: absolute;
	top: 0.45rem;
	right: 0.45rem;
	width: 2rem;
	height: 2rem;
	border-radius: 50%;
	border: none;
	background: #fff;
	box-shadow: 0 2px 10px rgba(0, 0, 0, 0.12);
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	padding: 0;
}

.elaris-pe-slot__fab:hover {
	filter: brightness(1.05);
}

.elaris-pe-card {
	background: var(--wp--preset--color--surface);
	border-radius: 20px;
	padding: 1.1rem 1.15rem 1.2rem;
	margin-bottom: 1rem;
	border: 1px solid rgba(0, 0, 0, 0.06);
	box-shadow: 0 4px 20px rgba(45, 21, 34, 0.05);
}

.elaris-pe-card__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem;
	margin-bottom: 0.85rem;
}

.elaris-pe-card__title {
	margin: 0;
	font-family: var(--wp--preset--font-family--fraunces), Georgia, serif;
	font-size: 1.1rem;
	font-weight: 600;
	color: #111;
}

.elaris-pe-card__edit {
	border: none;
	background: none;
	padding: 0;
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--wp--preset--color--primary);
	cursor: pointer;
	font-family: var(--wp--preset--font-family--dm-sans), system-ui, sans-serif;
}

.elaris-pe-card__edit:hover {
	text-decoration: underline;
}

.elaris-pe-about-list {
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
}

.elaris-pe-about-row {
	display: flex;
	align-items: center;
	gap: 0.65rem;
}

.elaris-pe-about-row__ic {
	flex-shrink: 0;
	opacity: 0.85;
}

.elaris-pe-about-row__input {
	flex: 1;
	min-width: 0;
	border: none;
	border-bottom: 1px solid rgba(0, 0, 0, 0.1);
	padding: 0.35rem 0;
	font-size: 0.95rem;
	font-family: var(--wp--preset--font-family--dm-sans), system-ui, sans-serif;
	background: transparent;
	border-radius: 0;
}

.elaris-pe-about-row__input:focus {
	outline: none;
	border-bottom-color: var(--wp--preset--color--primary);
}

.elaris-pe-bio {
	width: 100%;
	border: 1px solid rgba(0, 0, 0, 0.08);
	border-radius: 14px;
	padding: 0.85rem 1rem;
	font-size: 0.95rem;
	line-height: 1.55;
	font-family: var(--wp--preset--font-family--dm-sans), system-ui, sans-serif;
	resize: vertical;
	min-height: 5rem;
	box-sizing: border-box;
}

.elaris-pe-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 0.45rem;
	align-items: center;
}

.elaris-pe-tag {
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
	padding: 0.35rem 0.65rem;
	border-radius: 999px;
	border: 1px solid rgba(233, 30, 140, 0.35);
	font-size: 0.82rem;
	font-weight: 500;
	color: #5c1b2a;
	background: #fff;
	font-family: var(--wp--preset--font-family--dm-sans), system-ui, sans-serif;
}

.elaris-pe-tag__rm {
	border: none;
	background: none;
	padding: 0 0 0 0.15rem;
	cursor: pointer;
	font-size: 1rem;
	line-height: 1;
	color: #999;
}

.elaris-pe-tag--add {
	cursor: pointer;
	font-weight: 600;
	color: var(--wp--preset--color--primary);
	border-style: dashed;
}

.elaris-pe-card--prompts .elaris-pe-prompt {
	background: rgba(255, 240, 246, 0.85);
	border-radius: 16px;
	padding: 1rem 1.05rem;
	margin-bottom: 0.65rem;
	border: 1px solid rgba(233, 30, 140, 0.12);
}

.elaris-pe-card--prompts .elaris-pe-prompt:last-of-type {
	margin-bottom: 0;
}

.elaris-pe-prompt__label {
	margin: 0 0 0.5rem;
	font-size: 0.68rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--wp--preset--color--primary);
	font-family: var(--wp--preset--font-family--dm-sans), system-ui, sans-serif;
}

.elaris-pe-prompt__answer {
	width: 100%;
	border: none;
	background: transparent;
	padding: 0;
	font-family: var(--wp--preset--font-family--fraunces), Georgia, serif;
	font-size: 1.02rem;
	font-weight: 600;
	line-height: 1.4;
	color: #222;
	resize: vertical;
	min-height: 2.5rem;
}

.elaris-pe-prompt__answer:focus {
	outline: none;
}

.elaris-pe-save {
	display: block;
	width: 100%;
	margin-top: 0.25rem;
	padding: 1rem 1.25rem;
	border: none;
	border-radius: 999px;
	font-size: 1rem;
	font-weight: 700;
	font-family: var(--wp--preset--font-family--dm-sans), system-ui, sans-serif;
	color: #fff;
	cursor: pointer;
	background: linear-gradient(100deg, #e91e63 0%, #ff3366 45%, #ff7043 100%);
	box-shadow: 0 10px 28px rgba(233, 30, 140, 0.35);
}

.elaris-pe-save:hover {
	filter: brightness(1.03);
}

.elaris-pe-msg {
	margin: 0.85rem 0 0;
	text-align: center;
	font-size: 0.88rem;
	min-height: 1.25rem;
	color: #666;
}

@media (max-width: 400px) {
	.elaris-pe-photos {
		grid-template-columns: minmax(0, 2.12fr) minmax(0, 1fr);
		column-gap: 0.45rem;
		row-gap: 0.45rem;
	}

	.elaris-pe-photos__row3 {
		gap: 0.45rem;
	}

	.elaris-pe-photos__col {
		gap: 0.45rem;
	}
}

/* —— /land full-screen marquee + onboarding modal —— */
body.elaris-land-page .elaris-land {
	margin-left: calc(50% - 50vw);
	margin-block-start:0px !important;

	margin-right: calc(50% - 50vw);
	width: 100vw;
	max-width: 100vw;
}

.elaris-header--land {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 200;
	border-bottom: none;
	background: transparent;
	backdrop-filter: none;
	-webkit-backdrop-filter: none;
	box-shadow: none;
}

.elaris-header-land__inner {
	max-width: var(--elaris-max-width);
	margin: 0 auto;
	padding: 0.65rem max(var(--elaris-gutter), env(safe-area-inset-left, 0px)) 0.85rem max(var(--elaris-gutter), env(safe-area-inset-right, 0px));
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	box-sizing: border-box;
}

.elaris-header-land__logo {
	display: inline-flex;
	line-height: 0;
	text-decoration: none;
	border-radius: 8px;
}

.elaris-header-land__logo:focus-visible {
	outline: 2px solid #e91e8c;
	outline-offset: 3px;
}

.elaris-header-land__logo img {
	display: block;
	height: clamp(2rem, 6vw, 2.65rem);
	width: auto;
	max-width: 200px;
	object-fit: contain;
}

.elaris-header-land__action {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.45rem 1.1rem;
	border-radius: 999px;
	font-size: 0.875rem;
	font-weight: 700;
	text-decoration: none;
	color: #fff;
	background: linear-gradient(135deg, #e91e8c 0%, #ff6b9d 45%, #ff8fb8 100%);
	box-shadow: 0 4px 18px rgba(233, 30, 140, 0.4);
	border: 1px solid rgba(255, 255, 255, 0.35);
}

.elaris-header-land__action:hover {
	filter: brightness(1.05);
	color: #fff;
}

.elaris-land {
	position: relative;
	min-height: 100vh;
	min-height: 100dvh;
	padding-bottom: 0;
	background: #1a1420;
	overflow: hidden;
	box-sizing: border-box;
}

.elaris-land__bg {
	position: absolute;
	inset: 0;
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 0.65rem;
	padding: 0.5rem 0.65rem 4rem;
	box-sizing: border-box;
}

@media (max-width: 782px) {
	.elaris-land__bg {
		gap: 0.45rem;
		padding: 0.35rem 0.45rem 3.5rem;
	}
}

.elaris-land__col {
	overflow: hidden;
	min-height: 0;
	border-radius: 14px;
	mask-image: linear-gradient(180deg, transparent 0%, #000 4%, #000 96%, transparent 100%);
	-webkit-mask-image: linear-gradient(180deg, transparent 0%, #000 4%, #000 96%, transparent 100%);
}

.elaris-land__track {
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
	will-change: transform;
	animation: elarisLandScroll 42s linear infinite;
}

.elaris-land__col--mid .elaris-land__track {
	animation-duration: 56s;
	animation-direction: reverse;
}

.elaris-land__col--fast .elaris-land__track {
	animation-duration: 36s;
}

@keyframes elarisLandScroll {
	from {
		transform: translateY(0);
	}
	to {
		transform: translateY(-50%);
	}
}

@media (prefers-reduced-motion: reduce) {
	.elaris-land__track {
		animation: none;
		transform: translateY(0);
	}
}

.elaris-land-card {
	background: #fff;
	border-radius: 14px;
	overflow: hidden;
	box-shadow: 0 8px 28px rgba(0, 0, 0, 0.2);
	flex-shrink: 0;
}

.elaris-land-card__photo {
	position: relative;
	aspect-ratio: 3 / 4;
	background: #eee;
	overflow: hidden;
}

.elaris-land-card__photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.elaris-land-card__ph {
	width: 100%;
	height: 100%;
	background: linear-gradient(145deg, #f8e8ef 0%, #e8e0f5 100%);
}

.elaris-land-card__photo--ph {
	background: linear-gradient(145deg, #3d2f42 0%, #2a2033 100%);
}

.elaris-land-card--ph {
	opacity: 0.85;
}

.elaris-land-card__cam {
	position: absolute;
	left: 0.45rem;
	bottom: 0.45rem;
	display: inline-flex;
	align-items: center;
	gap: 0.2rem;
	padding: 0.2rem 0.45rem;
	border-radius: 999px;
	background: rgba(0, 0, 0, 0.55);
	color: #fff;
	font-size: 0.7rem;
	font-weight: 600;
}

.elaris-land-card__cam img {
	filter: brightness(0) invert(1);
	opacity: 0.95;
}

.elaris-land-card__foot {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.5rem;
	padding: 0.5rem 0.55rem 0.55rem;
}

.elaris-land-card__who {
	display: flex;
	align-items: center;
	gap: 0.35rem;
	min-width: 0;
	font-size: 0.88rem;
}

.elaris-land-card__who strong {
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.elaris-land-card__dot {
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: #2ecc71;
	flex-shrink: 0;
	box-shadow: 0 0 0 2px rgba(46, 204, 113, 0.35);
}

body.elaris-land-page .elaris-land-card__cta {
	flex-shrink: 0;
	padding: 0.35rem 0.65rem;
	border-radius: 8px;
	font-size: 0.72rem;
	font-weight: 700;
	color: #fff;
	background: linear-gradient(135deg, #e91e8c 0%, #ff6b9d 55%, #ff8fb8 100%);
	box-shadow: 0 2px 10px rgba(233, 30, 140, 0.35);
}

.elaris-land__dim {
	position: absolute;
	inset: 0;
	background: rgba(26, 20, 32, 0.52);
	pointer-events: none;
	z-index: 1;
}

.elaris-land__modal-host {
	position: relative;
	z-index: 2;
	min-height: calc(100vh - 4.25rem);
	min-height: calc(100dvh - 4.25rem);
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 1rem max(var(--elaris-gutter-tight), env(safe-area-inset-left, 0px)) 5rem max(var(--elaris-gutter-tight), env(safe-area-inset-right, 0px));
	pointer-events: none;
	box-sizing: border-box;
}

.elaris-land__modal-host:empty {
	pointer-events: none;
}

.elaris-land-modal {
	pointer-events: auto;
	width: 100%;
	max-width: 420px;
	background: #fff;
	border-radius: 22px;
	padding: 1.35rem 1.35rem 1.5rem;
	box-shadow: 0 24px 64px rgba(0, 0, 0, 0.35);
	box-sizing: border-box;
	text-align: center;
}

.elaris-land-modal__kicker {
	margin: 0 0 0.85rem;
	font-size: 0.8rem;
	font-weight: 600;
	color: #555;
}

.elaris-land-modal__kicker-num {
	color: #111;
	letter-spacing: 0.02em;
}

.elaris-land-modal__kicker-accent {
	color: #e91e63;
	margin: 0 0.15rem;
}

.elaris-land-modal__title {
	margin: 0 0 0.65rem;
	font-family: var(--wp--preset--font-family--fraunces), Fraunces, Georgia, serif;
	font-size: clamp(1.2rem, 4vw, 1.45rem);
	font-weight: 700;
	line-height: 1.25;
	color: #1a1a1a;
}

.elaris-land-modal__lead {
	margin: 0 0 1.25rem;
	font-size: 0.95rem;
	line-height: 1.55;
	color: #444;
}

.elaris-land-modal__hint {
	margin: 0 0 1rem;
	font-size: 0.82rem;
	line-height: 1.45;
	color: #666;
}

.elaris-land-stack {
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
	margin-bottom: 1rem;
}

.elaris-land-split {
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
	margin-bottom: 0.25rem;
}

.elaris-land-btn {
	display: block;
	width: 100%;
	border: none;
	cursor: pointer;
	font-family: var(--wp--preset--font-family--dm-sans), "DM Sans", system-ui, sans-serif;
	font-weight: 700;
	font-size: 1rem;
	padding: 0.85rem 1rem;
	border-radius: 999px;
	transition: transform 0.12s ease, filter 0.12s ease;
}

.elaris-land-btn:active {
	transform: scale(0.99);
}

.elaris-land-btn--hero {
	color: #fff;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	background: linear-gradient(100deg, #e91e8c 0%, #ff6b9d 40%, #ff9ec4 100%);
	box-shadow: 0 10px 28px rgba(233, 30, 140, 0.45);
}

.elaris-land-btn--gradient {
	color: #fff;
	background: linear-gradient(100deg, #d81b7a 0%, #e91e8c 35%, #ff6b9d 70%, #ffb3d0 100%);
	box-shadow: 0 8px 22px rgba(233, 30, 140, 0.42);
	border: 2px solid transparent;
}

.elaris-land-btn--gradient.is-selected {
	box-shadow: 0 0 0 3px rgba(233, 30, 140, 0.45), 0 8px 22px rgba(233, 30, 140, 0.4);
}

.elaris-land-btn--muted {
	color: #5c2d45;
	background: #ffe8f2;
	border: 1px solid rgba(233, 30, 140, 0.18);
}

.elaris-land-btn--next {
	margin-top: 0.35rem;
	color: #fff;
	background: linear-gradient(100deg, #e91e8c 0%, #ff6b9d 55%, #ffc2dd 100%);
	box-shadow: 0 8px 24px rgba(233, 30, 140, 0.42);
}

.elaris-land-intents {
	display: flex;
	flex-wrap: wrap;
	gap: 0.45rem;
	justify-content: center;
	margin-bottom: 1rem;
}

.elaris-land-intent {
	flex: 1 1 calc(50% - 0.25rem);
	min-width: 8rem;
	padding: 0.55rem 0.5rem;
	border-radius: 14px;
	border: 2px solid rgba(233, 30, 140, 0.2);
	background: #fff8fa;
	font-size: 0.82rem;
	font-weight: 700;
	color: #2d1522;
	cursor: pointer;
}

.elaris-land-intent.is-selected {
	border-color: #e91e8c;
	background: rgba(233, 30, 140, 0.1);
	box-shadow: 0 0 0 2px rgba(233, 30, 140, 0.15);
}

.elaris-land-ages {
	display: flex;
	flex-direction: column;
	gap: 0.45rem;
	margin-bottom: 0.75rem;
}

.elaris-land-age {
	padding: 0.65rem 0.85rem;
	border-radius: 999px;
	border: none;
	font-weight: 700;
	font-size: 0.9rem;
	color: #fff;
	cursor: pointer;
	background: linear-gradient(90deg, #d81b7a 0%, #e91e8c 40%, #ff6b9d 100%);
	box-shadow: 0 4px 14px rgba(233, 30, 140, 0.35);
}

.elaris-land-age--warn {
	background: #f0e6e8;
	color: #666;
	border: 1px solid rgba(0, 0, 0, 0.08);
}

.elaris-land-age.is-selected {
	box-shadow: 0 0 0 3px rgba(233, 30, 140, 0.35);
}

.elaris-land-form {
	text-align: left;
	margin-top: 0.25rem;
}

.elaris-land-label {
	display: block;
	font-weight: 700;
	font-size: 0.85rem;
	margin: 0.5rem 0 0.25rem;
}

.elaris-land-input {
	width: 100%;
	box-sizing: border-box;
	padding: 0.65rem 0.85rem;
	border-radius: 12px;
	border: 1px solid rgba(233, 30, 140, 0.25);
	font: inherit;
}

.elaris-land-legal {
	font-size: 0.75rem;
	line-height: 1.5;
	color: #666;
	margin: 0.75rem 0 1rem;
}

.elaris-land-legal a {
	color: #b01263;
	font-weight: 600;
}

.elaris-land-form-msg {
	min-height: 1.25rem;
	margin: 0.65rem 0 0;
	font-size: 0.88rem;
	text-align: center;
	color: #c62828;
}
