.snapweb-community-guest-landing {
	box-sizing: border-box;
	color: #f8fafc;
	min-height: calc(100vh - 78px);
	overflow: hidden;
	position: relative;
	background:
		linear-gradient(115deg, rgba(9, 18, 42, .76) 0%, rgba(23, 37, 84, .34) 44%, rgba(14, 165, 233, .18) 100%),
		radial-gradient(circle at 78% 38%, rgba(45, 212, 191, .28) 0 18%, transparent 42%),
		linear-gradient(135deg, #101827 0%, #1d4ed8 54%, #21d6c8 100%);
}

.snapweb-community-guest-landing--page {
	background: transparent;
	color: inherit;
	min-height: auto;
	overflow: visible;
}

#snapweb-community-guest-landing-template {
	display: none !important;
}

.snapweb-community-not-found-route {
	box-sizing: border-box;
	min-height: 100%;
	width: 100%;
}

.snapweb-community-not-found-body {
	box-sizing: border-box;
	display: flex;
	justify-content: center;
	padding: clamp(32px, 5vw, 72px) clamp(18px, 4vw, 48px);
	width: 100%;
}

.snapweb-community-not-found-card {
	background: var(--fcom-card-bg, rgba(255, 255, 255, .92));
	border: 1px solid var(--fcom-border-color, rgba(148, 163, 184, .28));
	border-radius: 8px;
	box-shadow: 0 18px 50px rgba(15, 23, 42, .08);
	box-sizing: border-box;
	color: var(--fcom-primary-text, #0f172a);
	max-width: 680px;
	padding: clamp(28px, 5vw, 52px);
	text-align: center;
	width: min(100%, 680px);
}

.dark .snapweb-community-not-found-card,
[data-color-mode="dark"] .snapweb-community-not-found-card {
	background: var(--fcom-card-bg, #272b31);
	border-color: var(--fcom-border-color, rgba(255, 255, 255, .12));
	box-shadow: 0 18px 50px rgba(0, 0, 0, .22);
	color: var(--fcom-primary-text, #f8fafc);
}

.snapweb-community-not-found-code {
	color: var(--fcom-secondary-text, #64748b);
	font-size: 13px;
	font-weight: 800;
	letter-spacing: 0;
	line-height: 1;
	margin: 0 0 14px;
	text-transform: uppercase;
}

.snapweb-community-not-found-card h2 {
	color: inherit;
	font-size: clamp(28px, 4vw, 44px);
	line-height: 1.1;
	margin: 0;
}

.snapweb-community-not-found-card p:not(.snapweb-community-not-found-code) {
	color: var(--fcom-secondary-text, #64748b);
	font-size: clamp(17px, 2vw, 21px);
	line-height: 1.55;
	margin: 18px auto 0;
	max-width: 520px;
}

.snapweb-community-not-found-actions {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	justify-content: center;
	margin-top: 30px;
}

.snapweb-community-not-found-button {
	align-items: center;
	background: var(--fcom-accent-color, #4f46e5);
	border: 1px solid transparent;
	border-radius: 8px;
	color: #ffffff;
	display: inline-flex;
	font-size: 16px;
	font-weight: 800;
	justify-content: center;
	min-height: 44px;
	min-width: 128px;
	padding: 10px 18px;
	text-decoration: none;
}

.snapweb-community-not-found-button:hover,
.snapweb-community-not-found-button:focus-visible {
	color: #ffffff;
	filter: brightness(1.04);
	text-decoration: none;
}

.snapweb-community-not-found-button--secondary {
	background: transparent;
	border-color: var(--fcom-border-color, rgba(148, 163, 184, .4));
	color: var(--fcom-primary-text, #0f172a);
}

.snapweb-community-not-found-button--secondary:hover,
.snapweb-community-not-found-button--secondary:focus-visible {
	color: var(--fcom-primary-text, #0f172a);
}

.dark .snapweb-community-not-found-button--secondary,
[data-color-mode="dark"] .snapweb-community-not-found-button--secondary,
.dark .snapweb-community-not-found-button--secondary:hover,
.dark .snapweb-community-not-found-button--secondary:focus-visible,
[data-color-mode="dark"] .snapweb-community-not-found-button--secondary:hover,
[data-color-mode="dark"] .snapweb-community-not-found-button--secondary:focus-visible {
	color: #f8fafc;
}

body.snapweb-community-landing-active .fhr_content_layout_header {
	display: none;
}

body.snapweb-community-landing-active .feed_layout > :where(#fluent_com_portal, #fluent_community_app) .feeds_main,
body.snapweb-community-landing-active .feed_layout > .feeds_main {
	min-width: 0;
}

body.snapweb-community-landing-active :where(#fluent_com_portal, #fluent_community_app) > .fcom_single_layout > :where(.feed_layout, .feeds_main, .fhr_content, .fhr_home),
body.snapweb-community-landing-active :where(#fluent_com_portal, #fluent_community_app) > :where(.snapweb-community-fcom-route-shell, .snapweb-fcom-article-route, .snapweb-fcom-search-route, .cointacted-terminal-layout):not(.snapweb-community-landing-root) {
	display: none !important;
}

body.snapweb-community-landing-active :where(#fluent_com_portal, #fluent_community_app) > .snapweb-community-landing-root {
	box-sizing: border-box;
	display: block !important;
	min-width: 0;
	overflow: visible;
	pointer-events: auto;
	position: relative;
	width: 100%;
}

body.snapweb-community-landing-active .snapweb-community-landing-host {
	overflow: hidden;
}

body.snapweb-community-landing-active .snapweb-community-landing-root.snapweb-community-landing-host {
	overflow: visible;
}

body.snapweb-community-landing-active .snapweb-community-landing-host > :not(.snapweb-community-guest-landing) {
	display: none !important;
}

.snapweb-community-guest-landing *,
.snapweb-community-guest-landing *::before,
.snapweb-community-guest-landing *::after {
	box-sizing: border-box;
}

.snapweb-community-guest-landing__page {
	margin: 0 auto;
	max-width: var(--snapweb-community-shell-width, 1180px);
	padding: clamp(32px, 5vw, 64px) clamp(18px, 4vw, 40px);
	width: 100%;
}

.snapweb-community-guest-landing__hero {
	align-items: center;
	display: grid;
	gap: 48px;
	grid-template-columns: minmax(0, 1.1fr) minmax(280px, .72fr);
	margin: 0 auto;
	max-width: 1180px;
	min-height: calc(100vh - 156px);
	padding: clamp(58px, 8vh, 104px) 32px 40px;
	width: 100%;
}

.snapweb-community-guest-landing__content {
	max-width: 760px;
}

.snapweb-community-guest-landing__eyebrow {
	font-size: clamp(18px, 2vw, 28px);
	font-weight: 600;
	line-height: 1.25;
	margin: 0 0 22px;
	text-shadow: 0 2px 18px rgba(15, 23, 42, .24);
}

.snapweb-community-guest-landing h1 {
	color: inherit;
	font-size: clamp(48px, 7vw, 86px);
	font-weight: 800;
	letter-spacing: 0;
	line-height: .98;
	margin: 0;
	max-width: 900px;
	text-shadow: 0 3px 24px rgba(15, 23, 42, .34);
	text-transform: uppercase;
}

.snapweb-community-guest-landing__lead {
	color: rgba(248, 250, 252, .92);
	font-size: clamp(18px, 2vw, 25px);
	font-weight: 500;
	line-height: 1.45;
	margin: 24px 0 0;
	max-width: 780px;
	text-shadow: 0 2px 16px rgba(15, 23, 42, .24);
}

.snapweb-community-guest-landing__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 18px;
	margin-top: 46px;
}

.snapweb-community-guest-landing__button {
	align-items: center;
	border: 1px solid rgba(255, 255, 255, .24);
	border-radius: 999px;
	box-shadow: 0 18px 40px rgba(15, 23, 42, .24);
	display: inline-flex;
	font-size: clamp(18px, 2vw, 26px);
	font-weight: 800;
	justify-content: center;
	min-height: 58px;
	min-width: 184px;
	padding: 14px 30px;
	text-decoration: none;
	transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}

.snapweb-community-guest-landing__button:hover,
.snapweb-community-guest-landing__button:focus-visible {
	box-shadow: 0 22px 50px rgba(15, 23, 42, .34);
	transform: translateY(-1px);
}

.snapweb-community-guest-landing__button--primary {
	background: #08164f;
	color: #ffffff;
}

.snapweb-community-guest-landing__button--secondary {
	background: linear-gradient(135deg, #27d8ef, #30d26f);
	color: #ffffff;
}

.snapweb-community-guest-landing__panel {
	backdrop-filter: blur(18px);
	background: rgba(8, 22, 79, .34);
	border: 1px solid rgba(255, 255, 255, .18);
	border-radius: 8px;
	box-shadow: 0 28px 80px rgba(15, 23, 42, .28);
	display: grid;
	gap: 14px;
	padding: 22px;
}

.snapweb-community-guest-landing__metric {
	background: rgba(255, 255, 255, .11);
	border: 1px solid rgba(255, 255, 255, .16);
	border-radius: 8px;
	padding: 18px;
}

.snapweb-community-guest-landing__metric strong,
.snapweb-community-guest-landing__metric span {
	display: block;
}

.snapweb-community-guest-landing__metric strong {
	font-size: 28px;
	line-height: 1.1;
}

.snapweb-community-guest-landing__metric span {
	color: rgba(248, 250, 252, .82);
	font-size: 16px;
	margin-top: 6px;
}

.snapweb-community-guest-landing__links {
	align-items: center;
	border-top: 1px solid rgba(255, 255, 255, .16);
	display: flex;
	flex-wrap: wrap;
	gap: 18px 28px;
	justify-content: center;
	margin: 0 auto;
	max-width: 1180px;
	padding: 22px 32px 34px;
}

.snapweb-community-guest-landing__links a {
	color: rgba(248, 250, 252, .9);
	font-size: 17px;
	font-weight: 700;
	text-decoration: none;
}

.snapweb-community-guest-landing__links a:hover,
.snapweb-community-guest-landing__links a:focus-visible {
	color: #ffffff;
	text-decoration: underline;
	text-underline-offset: 4px;
}

@media (max-width: 900px) {
	.snapweb-community-guest-landing__hero {
		grid-template-columns: 1fr;
		min-height: auto;
		padding: 48px 22px 28px;
	}

	.snapweb-community-guest-landing__panel {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 640px) {
	.snapweb-community-guest-landing__actions,
	.snapweb-community-guest-landing__links {
		align-items: stretch;
		flex-direction: column;
	}

	.snapweb-community-guest-landing__button {
		width: 100%;
	}
}
