html {
	box-sizing: border-box;
	overflow-anchor: none;
	overflow-x: hidden;
}

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

:root {
	--sm-bg: #f7f8fc;
	--sm-surface: #ffffff;
	--sm-surface-alt: #eef2ff;
	--sm-text: #1c2440;
	--sm-muted: #5f6b8a;
	--sm-border: #dde3f0;
	--sm-primary: #4f46e5;
	--sm-primary-dark: #3730a3;
	--sm-shadow: 0 16px 40px rgba(30, 41, 59, 0.08);
	--sm-radius: 20px;
	--sm-radius-lg: 28px;
	--sm-container: 1180px;
}

body {
	margin: 0;
	background: #ffffff;
	color: var(--sm-text);
	font-family: Inter, sans-serif;
	font-size: 18px;
	line-height: 1.65;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

summary {
	font-weight: inherit;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	color: var(--sm-text);
	font-family: "Plus Jakarta Sans", sans-serif;
	font-weight: 600;
}

p {
	margin-top: 0;
}

a {
	color: #060097;
}

button,
input,
select,
textarea {
	font: inherit;
}

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

.ast-container {
	width: 100%;
	max-width: 1240px;
	margin-right: auto;
	margin-left: auto;
	padding-right: 20px;
	padding-left: 20px;
}

.sm-container {
	width: min(var(--sm-container), calc(100% - 32px));
	margin: 0 auto;
}

.sm-i18n-block {
	display: none;
}

body.sm-lang-en .sm-i18n-block--en,
body.sm-lang-fi .sm-i18n-block--fi,
body.sm-lang-ru .sm-i18n-block--ru,
body.sm-lang-ua .sm-i18n-block--ua {
	display: block;
}

.entry-content > .sm-owner-page.wp-block-columns {
	display: grid;
	grid-template-columns: minmax(0, 1fr) clamp(260px, 28vw, 340px);
	gap: clamp(32px, 5vw, 64px);
	align-items: start;
	width: min(1120px, calc(100vw - 48px));
	max-width: min(1120px, calc(100vw - 48px)) !important;
	margin-right: auto !important;
	margin-left: auto !important;
	padding: 0;
}

.sm-owner-page > .wp-block-column {
	min-width: 0;
	flex-basis: auto !important;
}

.sm-owner-page .wp-block-image {
	justify-self: end;
	width: 100%;
	max-width: 340px;
	margin: 6px 0 0;
	padding: 10px;
	border: 1px solid rgba(79, 70, 229, 0.16);
	border-radius: 18px;
	background: #ffffff;
	box-shadow: 0 18px 44px rgba(30, 41, 59, 0.12);
}

.sm-owner-page .wp-block-image img {
	display: block;
	width: 100%;
	height: auto;
	max-height: 600px;
	object-fit: contain;
	border-radius: 12px;
}

@media (max-width: 781px) {
	.entry-content > .sm-owner-page.wp-block-columns {
		display: block;
		width: calc(100vw - 40px);
		max-width: calc(100vw - 40px) !important;
	}

	.sm-owner-page .wp-block-image {
		width: min(300px, 100%);
		margin: 28px auto 0;
		padding: 8px;
		border-radius: 16px;
		box-shadow: 0 14px 34px rgba(30, 41, 59, 0.12);
	}

	.sm-owner-page .wp-block-image img {
		max-height: none;
		border-radius: 10px;
	}
}

.site-header,
.ast-primary-header-bar,
.ast-above-header-wrap,
.ast-below-header-wrap,
.ast-mobile-header-wrap {
	display: none;
}

/* Astra adds page-level spacing to #primary for non-front-page desktop routes.
   ServiceMap templates own their own section spacing, so keep the wrapper flat. */
#primary[class^="sm-"],
#primary[class*=" sm-"] {
	padding: 0 !important;
	margin-top: 0 !important;
	margin-bottom: 0 !important;
}

#content.site-content {
	padding-top: 0 !important;
	margin-top: 0 !important;
}

#content.site-content .ast-container {
	padding-top: 0 !important;
	padding-bottom: 0 !important;
	margin-top: 0 !important;
}

/* Hide any Astra above-content element regardless of exact class name.
   Wildcard [class*=] catches ast-page-title-wrap, ast-page-title-area, etc. */
.ast-breadcrumbs-container,
.ast-above-content-bar,
header.entry-header,
.ast-single-post-order,
[class*="ast-page-title"],
[class*="ast-breadcrumb"] {
	display: none !important;
	height: 0 !important;
	padding: 0 !important;
	margin: 0 !important;
	overflow: hidden !important;
}

.site-footer {
	display: none;
}

.sm-site-header {
	position: sticky;
	top: 0;
	z-index: 1000;
	background: #ffffff;
	border-bottom: 1px solid var(--sm-border);
	color: var(--sm-text);
}

body.admin-bar .sm-site-header {
	top: 32px;
}

.sm-site-header__inner {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	gap: 24px;
	width: min(var(--sm-container), calc(100% - 32px));
	min-height: 76px;
	margin: 0 auto;
}

.sm-site-header__brand {
	display: flex;
	align-items: center;
	text-decoration: none;
	white-space: nowrap;
}

.sm-logo {
	height: 36px;
	width: auto;
	display: block;
}

.sm-logo--mobile {
	display: none;
}

@media (max-width: 640px) {
	.sm-logo--desktop {
		display: none;
	}

	.sm-logo--mobile {
		display: block;
		height: 32px;
	}
}

.sm-site-header__toggle {
	display: none;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	padding: 0;
	border: 1px solid var(--sm-border);
	border-radius: 14px;
	background: #ffffff;
	color: var(--sm-text);
	cursor: pointer;
}

.sm-site-header__toggle-bar {
	display: block;
	width: 20px;
	height: 2px;
	border-radius: 999px;
	background: currentColor;
	transition: transform 0.2s ease, opacity 0.2s ease;
}

.sm-cookie-banner {
	position: fixed;
	right: 14px;
	bottom: 14px;
	left: auto;
	width: min(560px, calc(100% - 28px));
	z-index: 3000;
	color: var(--sm-text);
}

.sm-cookie-banner[hidden] {
	display: none;
}

.sm-cookie-banner__inner {
	position: relative;
	display: grid;
	grid-template-columns: 1fr;
	gap: 8px;
	width: 100%;
	margin: 0;
	padding: 12px 14px;
	border: 1px solid #f4c56a;
	border-radius: 8px;
	background: #fff8e6;
	box-shadow: 0 20px 60px rgba(217, 119, 6, 0.16), 0 4px 18px rgba(30, 41, 59, 0.08);
}

.sm-cookie-banner__copy h2 {
	margin: 0 0 4px;
	color: var(--sm-text);
	font-size: 0.98rem;
	line-height: 1.25;
}

.sm-cookie-settings h1 {
	margin: 0 0 8px;
	color: var(--sm-text);
	font-size: 1.35rem;
	line-height: 1.25;
}

.sm-cookie-banner__copy p {
	margin: 0;
	color: var(--sm-muted);
	font-size: 0.9rem;
	line-height: 1.35;
}

.sm-cookie-settings__lead,
.sm-cookie-settings__policy {
	margin: 0;
	color: var(--sm-muted);
	line-height: 1.55;
}

.sm-cookie-banner__links {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 4px !important;
	font-size: 0.9rem;
}

.sm-cookie-banner__actions,
.sm-cookie-banner__panel-actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: flex-start;
	gap: 8px;
}

.sm-cookie-settings__actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: flex-end;
	gap: 8px;
}

.sm-cookie-banner__actions .sm-btn,
.sm-cookie-banner__panel-actions .sm-btn {
	min-height: 36px;
	max-width: 100%;
	padding: 8px 14px;
	border-radius: 8px;
	font-size: 0.9rem;
	line-height: 1.2;
	overflow-wrap: anywhere;
}

.sm-cookie-banner__panel {
	grid-column: 1 / -1;
	padding-top: 10px;
	border-top: 1px solid var(--sm-border);
}

.sm-cookie-banner__choices,
.sm-cookie-settings__choices {
	display: grid;
	gap: 8px;
}

.sm-cookie-banner__panel-actions {
	margin-top: 10px;
}

.sm-cookie-choice {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 14px;
	align-items: center;
	padding: 12px;
	border: 1px solid var(--sm-border);
	border-radius: 8px;
	background: #ffffff;
}

.sm-cookie-choice__text {
	display: grid;
	gap: 4px;
	min-width: 0;
}

.sm-cookie-choice__text strong {
	color: var(--sm-text);
	line-height: 1.25;
}

.sm-cookie-choice__text span {
	color: var(--sm-muted);
	font-size: 0.93rem;
	line-height: 1.45;
}

.sm-cookie-choice__switch {
	position: relative;
	display: inline-flex;
	width: 48px;
	height: 28px;
	flex: 0 0 auto;
}

.sm-cookie-choice__switch input {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	margin: 0;
	opacity: 0;
	cursor: pointer;
}

.sm-cookie-choice__switch span {
	display: block;
	width: 100%;
	height: 100%;
	border: 1px solid #c8d1e4;
	border-radius: 999px;
	background: #e8edf7;
	transition: background 0.2s ease, border-color 0.2s ease;
}

.sm-cookie-choice__switch span::after {
	content: "";
	position: absolute;
	top: 4px;
	left: 4px;
	width: 20px;
	height: 20px;
	border-radius: 50%;
	background: #ffffff;
	box-shadow: 0 2px 7px rgba(30, 41, 59, 0.22);
	transition: transform 0.2s ease;
}

.sm-cookie-choice__switch input:checked + span {
	border-color: var(--sm-primary);
	background: var(--sm-primary);
}

.sm-cookie-choice__switch input:checked + span::after {
	transform: translateX(20px);
}

.sm-cookie-banner .sm-cookie-choice {
	gap: 10px;
	padding: 9px 10px;
}

.sm-cookie-banner .sm-cookie-choice__text {
	gap: 2px;
}

.sm-cookie-banner .sm-cookie-choice__text strong {
	font-size: 0.94rem;
}

.sm-cookie-banner .sm-cookie-choice__text span {
	font-size: 0.86rem;
	line-height: 1.35;
}

.sm-cookie-banner .sm-cookie-choice__switch {
	width: 42px;
	height: 24px;
}

.sm-cookie-banner .sm-cookie-choice__switch span::after {
	top: 3px;
	left: 3px;
	width: 16px;
	height: 16px;
}

.sm-cookie-banner .sm-cookie-choice__switch input:checked + span::after {
	transform: translateX(18px);
}

.sm-cookie-choice__switch input:disabled {
	cursor: not-allowed;
}

.sm-cookie-choice--required {
	background: #f8fafc;
}

.sm-cookie-settings {
	padding: clamp(42px, 7vw, 78px) 0;
	background: var(--sm-bg);
}

.sm-cookie-settings__inner {
	display: grid;
	gap: 18px;
}

.sm-cookie-settings__choices {
	max-width: 860px;
}

.sm-cookie-settings__status {
	margin: 0;
	padding: 10px 12px;
	border: 1px solid #b8e6c2;
	border-radius: 8px;
	background: #edfaef;
	color: #0a6b24;
}

@media (max-width: 760px) {
	.sm-cookie-banner {
		right: 10px;
		bottom: 10px;
		left: 10px;
		width: auto;
	}

	.sm-cookie-banner__inner {
		padding: 12px;
		max-height: calc(100vh - 20px);
		overflow: auto;
	}

	.sm-cookie-banner__actions,
	.sm-cookie-banner__panel-actions {
		gap: 6px;
		justify-content: flex-start;
	}

	.sm-cookie-settings__actions {
		justify-content: stretch;
	}

	.sm-cookie-banner__actions .sm-btn,
	.sm-cookie-banner__panel-actions .sm-btn {
		min-height: 34px;
		padding: 7px 12px;
		font-size: 0.87rem;
	}

	.sm-cookie-settings__actions .sm-btn {
		width: 100%;
		justify-content: center;
	}

	.sm-cookie-choice {
		grid-template-columns: 1fr;
	}
}

.sm-site-header__nav {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	flex-wrap: wrap;
	gap: 8px 20px;
}

.sm-site-header__nav-item {
	position: relative;
}

.sm-site-header__nav-toggle {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	min-height: 36px;
	padding: 0 12px;
	border: 1px solid rgba(99, 102, 241, 0.2);
	border-radius: 8px;
	background: rgba(99, 102, 241, 0.06);
	color: var(--sm-text);
	font: inherit;
	cursor: pointer;
}

.sm-site-header__nav-toggle-label {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	min-width: 0;
}

.sm-site-header__nav-toggle-icon {
	width: 17px;
	height: 17px;
	flex: 0 0 17px;
	color: #6366f1;
}

.sm-site-header__nav-caret {
	width: 7px;
	height: 7px;
	border-right: 2px solid currentColor;
	border-bottom: 2px solid currentColor;
	transform: translateY(-2px) rotate(45deg);
	transition: transform 0.18s ease;
}

.sm-site-header__nav-toggle[aria-expanded='true'] .sm-site-header__nav-caret {
	transform: translateY(2px) rotate(225deg);
}

.sm-site-header__nav-menu {
	position: absolute;
	top: calc(100% + 10px);
	left: 0;
	z-index: 25;
	display: grid;
	min-width: 220px;
	padding: 8px;
	border: 1px solid var(--sm-border);
	border-radius: 8px;
	background: #ffffff;
	box-shadow: var(--sm-shadow);
}

.sm-site-header__nav-menu[hidden] {
	display: none;
}

.sm-site-header__nav-menu a {
	display: flex;
	align-items: center;
	gap: 8px;
	min-height: 38px;
	padding: 8px 10px;
	border-radius: 6px;
	font-size: 14px;
}

.sm-site-header__nav-link-icon {
	width: 16px;
	height: 16px;
	flex: 0 0 16px;
	fill: currentColor;
	stroke: none;
}

.sm-site-header__controls {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 12px;
	margin-left: auto;
}

.sm-site-header__languages {
	display: inline-flex;
	align-items: center;
	gap: 2px;
	padding: 3px;
	border: 1px solid var(--sm-border);
	border-radius: 8px;
	background: #f8fafc;
}

.sm-site-header__language {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 32px;
	min-height: 30px;
	padding: 0 8px;
	border-radius: 6px;
	color: var(--sm-muted);
	font-family: Inter, sans-serif;
	font-size: 12px;
	font-weight: 600;
	line-height: 1;
	text-decoration: none;
}

.sm-site-header__language:hover,
.sm-site-header__language:focus,
.sm-site-header__language.is-active {
	background: #ffffff;
	color: var(--sm-primary);
	font-weight: 700;
	box-shadow: 0 1px 3px rgba(15, 23, 42, 0.08);
}

.sm-site-header__auth {
	display: inline-flex;
	align-items: center;
	gap: 12px;
}

.sm-site-header__login {
	display: inline-flex;
	align-items: center;
	gap: 6px;
}

.sm-site-header__login-icon {
	display: none;
	width: 18px;
	height: 18px;
	flex: 0 0 18px;
}

.sm-site-header__nav a,
.sm-site-header__nav-toggle,
.sm-site-header__auth a,
.sm-site-header__account-menu a {
	color: var(--sm-text);
	font-family: Inter, sans-serif;
	font-size: 15px;
	font-weight: 600;
	line-height: 1.3;
	text-decoration: none;
	transition: color 0.2s ease, background-color 0.2s ease, transform 0.2s ease;
}

.sm-site-header__nav a:hover,
.sm-site-header__nav a:focus,
.sm-site-header__nav a:active,
.sm-site-header__nav a[aria-current='page'],
.sm-site-header__nav-toggle:hover,
.sm-site-header__nav-toggle:focus,
.sm-site-header__nav-toggle[aria-expanded='true'],
.sm-site-header__auth a:hover,
.sm-site-header__auth a:focus,
.sm-site-header__auth a:active,
.sm-site-header__account-menu a:hover,
.sm-site-header__account-menu a:focus {
	color: var(--sm-primary);
}

.sm-site-header__nav-toggle:hover,
.sm-site-header__nav-toggle:focus,
.sm-site-header__nav-toggle[aria-expanded='true'] {
	background: rgba(99, 102, 241, 0.12);
	border-color: rgba(99, 102, 241, 0.35);
}

.sm-site-header__brand:focus-visible,
.sm-site-header__toggle:focus-visible,
.sm-site-header__nav a:focus-visible,
.sm-site-header__nav-toggle:focus-visible,
.sm-site-header__auth a:focus-visible,
.sm-site-header__language:focus-visible,
.sm-site-header__account-toggle:focus-visible,
.sm-site-header__account-menu a:focus-visible {
	outline: 2px solid var(--sm-primary);
	outline-offset: 4px;
}

.sm-site-header__cta,
.sm-site-header__nav .sm-site-header__cta,
.sm-site-header__auth .sm-site-header__cta {
	min-height: 42px;
	padding: 11px 18px;
	color: #ffffff;
}

.sm-site-header__nav .sm-site-header__cta:hover,
.sm-site-header__nav .sm-site-header__cta:focus,
.sm-site-header__nav .sm-site-header__cta:active,
.sm-site-header__auth .sm-site-header__cta:hover,
.sm-site-header__auth .sm-site-header__cta:focus,
.sm-site-header__auth .sm-site-header__cta:active {
	color: #ffffff;
}

.sm-site-header__account {
	position: relative;
}

.sm-site-header__account-toggle {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	min-height: 42px;
	max-width: 220px;
	padding: 8px 11px;
	border: 1px solid var(--sm-primary);
	border-radius: 8px;
	background: var(--sm-primary);
	color: #ffffff;
	font: inherit;
	font-size: 14px;
	font-weight: 700;
	cursor: pointer;
}

.sm-site-header__account-toggle:hover,
.sm-site-header__account-toggle[aria-expanded='true'] {
	border-color: var(--sm-primary-dark);
	background: var(--sm-primary-dark);
	color: #ffffff;
}

.sm-site-header__account-icon {
	width: 18px;
	height: 18px;
	flex: 0 0 18px;
}

.sm-site-header__account-name {
	min-width: 0;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.sm-site-header__account-caret {
	width: 7px;
	height: 7px;
	border-right: 2px solid currentColor;
	border-bottom: 2px solid currentColor;
	transform: translateY(-2px) rotate(45deg);
	transition: transform 0.18s ease;
}

.sm-site-header__account-toggle[aria-expanded='true'] .sm-site-header__account-caret {
	transform: translateY(2px) rotate(225deg);
}

.sm-site-header__account-menu {
	position: absolute;
	top: calc(100% + 10px);
	right: 0;
	z-index: 20;
	display: grid;
	min-width: 220px;
	padding: 8px;
	border: 1px solid var(--sm-border);
	border-radius: 8px;
	background: #ffffff;
	box-shadow: var(--sm-shadow);
}

.sm-site-header__account-menu[hidden] {
	display: none;
}

.sm-site-header__account-menu a {
	display: flex;
	align-items: center;
	gap: 8px;
	min-height: 38px;
	padding: 8px 10px;
	border-radius: 6px;
	font-size: 14px;
}

.sm-site-header__nav-menu a:hover,
.sm-site-header__nav-menu a:focus,
.sm-site-header__account-menu a:hover,
.sm-site-header__account-menu a:focus {
	background: #f8fafc;
	text-decoration: none;
}

.sm-site-header__nav-link--highlight {
	color: var(--sm-primary-dark);
	font-weight: 700;
	background: #eef2ff;
}

.sm-site-header__nav-link--highlight:hover,
.sm-site-header__nav-link--highlight:focus {
	background: #e0e7ff !important;
	color: var(--sm-primary-dark) !important;
}

.sm-site-header__account-divider {
	height: 1px;
	margin: 6px 4px;
	background: var(--sm-border);
}

.sm-site-footer {
	margin-top: 64px;
	background: var(--sm-primary-dark);
	border-top: 0;
	color: #ffffff;
}

.sm-site-footer__inner {
	width: min(var(--sm-container), calc(100% - 32px));
	margin: 0 auto;
	padding: 30px 0 20px;
}

.sm-site-footer__brand {
	display: flex;
	align-items: flex-start;
	gap: 16px;
	margin-bottom: 20px;
}

.sm-site-footer__brand-text {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.sm-site-footer__logo-link {
	display: inline-flex;
	align-items: center;
	flex: 0 0 auto;
}

.sm-site-footer__logo {
	display: block;
	width: auto;
	height: 34px;
}

.sm-site-footer__tagline {
	max-width: none;
	margin: 0;
	color: #e0e7ff;
	font-size: 15px;
	line-height: 1.6;
	white-space: nowrap;
}

.sm-site-footer__controller-line {
	margin: 0;
	color: #a5b4fc;
	font-size: 13px;
	line-height: 1.5;
}

.sm-site-footer__controller-line a {
	color: #c7d2fe;
	text-decoration: none;
}

.sm-site-footer__controller-line a:hover,
.sm-site-footer__controller-line a:focus {
	color: #ffffff;
	text-decoration: underline;
	text-underline-offset: 3px;
}

.sm-site-footer__email-icon {
	display: inline-block;
	width: 14px;
	height: 14px;
	flex: 0 0 14px;
	vertical-align: middle;
	margin-right: 4px;
	stroke: currentColor;
	fill: none;
}

.sm-site-footer__nav {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	flex-wrap: wrap;
	gap: 6px 20px;
	padding: 0 0 8px;
	position: relative;
	z-index: 60;
}

.sm-site-footer__contact-links {
	display: inline-flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 6px 10px;
}

.sm-site-footer__links {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 8px;
	min-height: 24px;
}

.sm-site-footer__group {
	display: inline-flex;
	align-items: center;
	min-height: 24px;
	position: relative;
}

.sm-site-footer__group summary {
	list-style: none;
	cursor: pointer;
}

.sm-site-footer__group summary::-webkit-details-marker {
	display: none;
}

.sm-site-footer__links a,
.sm-site-footer__group summary {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	height: 24px;
	min-height: 24px;
	padding: 0;
	border: none;
	background: none;
	color: #c7d2fe;
	font-size: 14px;
	font-weight: 500;
	line-height: 1.4;
	text-decoration: none;
	transition: color 0.2s ease;
}

.sm-site-footer__links a:hover,
.sm-site-footer__links a:focus,
.sm-site-footer__group summary:hover,
.sm-site-footer__group summary:focus {
	background: none;
	color: #ffffff;
	text-decoration: underline;
	text-underline-offset: 3px;
}

.sm-site-footer__group-caret {
	width: 7px;
	height: 7px;
	border-right: 2px solid currentColor;
	border-bottom: 2px solid currentColor;
	transform: translateY(-2px) rotate(45deg);
	transition: transform 0.18s ease;
}

.sm-site-footer__group[open] .sm-site-footer__group-caret {
	transform: translateY(2px) rotate(225deg);
}

.sm-site-footer__group-menu {
	position: absolute;
	right: 0;
	bottom: calc(100% + 10px);
	z-index: 90;
	width: max-content;
	max-width: calc(100vw - 24px);
	padding: 12px;
	border: 1px solid rgba(55, 48, 163, 0.18);
	border-radius: 8px;
	background: #ffffff;
	box-shadow: var(--sm-shadow);
}

.sm-site-footer__group--in-brand .sm-site-footer__group-menu {
	left: 0;
	right: auto;
}

.sm-site-footer__group--legal .sm-site-footer__group-menu {
	left: 0;
	right: auto;
}

.sm-site-footer__browse-link {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	min-height: 24px;
	padding: 0;
	color: #c7d2fe;
	font-size: 14px;
	font-weight: 500;
	line-height: 1.4;
	text-decoration: none;
	transition: color 0.2s ease;
}

.sm-site-footer__browse-link:hover,
.sm-site-footer__browse-link:focus,
.sm-site-footer__add-business-link:hover,
.sm-site-footer__add-business-link:focus,
.sm-site-footer__how-link:hover,
.sm-site-footer__how-link:focus,
.sm-site-footer__email-link:hover,
.sm-site-footer__email-link:focus {
	color: #ffffff;
	text-decoration: underline;
	text-underline-offset: 3px;
}

.sm-site-footer__social-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	color: #c7d2fe;
	text-decoration: none;
	transition: color 0.2s ease;
}

.sm-site-footer__social-link:hover,
.sm-site-footer__social-link:focus {
	color: #ffffff;
}

.sm-site-footer__social-icon {
	width: 18px;
	height: 18px;
	flex-shrink: 0;
	fill: currentColor;
	stroke: none;
}

.sm-site-footer__add-business-link {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	min-height: 24px;
	padding: 0;
	color: #c7d2fe;
	font-size: 14px;
	font-weight: 500;
	line-height: 1.4;
	text-decoration: none;
	transition: color 0.2s ease;
}

.sm-site-footer__how-link,
.sm-site-footer__email-link {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	min-height: 24px;
	padding: 0;
	color: #c7d2fe;
	font-size: 14px;
	font-weight: 500;
	line-height: 1.4;
	text-decoration: none;
	transition: color 0.2s ease;
}

.sm-site-footer__browse-icon,
.sm-site-footer__nav-icon {
	width: 15px;
	height: 15px;
	flex-shrink: 0;
	stroke: currentColor;
	fill: none;
}

.sm-site-footer__group-menu ul {
	display: grid;
	gap: 6px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.sm-site-footer__group--legal .sm-site-footer__group-menu ul {
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 6px 12px;
}

.sm-site-footer__group-menu a {
	display: flex;
	align-items: center;
	min-height: 36px;
	padding: 7px 8px;
	border-radius: 6px;
	color: var(--sm-text);
	font-size: 14px;
	font-weight: 700;
	line-height: 1.35;
	text-decoration: none;
}

.sm-site-footer__group-menu a:hover,
.sm-site-footer__group-menu a:focus {
	background: #eef2ff;
	color: var(--sm-primary-dark);
	text-decoration: none;
}

.sm-site-footer__bottom a {
	color: #eef2ff;
	font-size: 14px;
	line-height: 1.45;
	text-decoration: none;
}

.sm-site-footer__bottom a:hover,
.sm-site-footer__bottom a:focus {
	color: #ffffff;
	text-decoration: underline;
	text-underline-offset: 3px;
}

.sm-site-footer__logo-link:focus-visible,
.sm-site-footer__links a:focus-visible,
.sm-site-footer__browse-link:focus-visible,
.sm-site-footer__add-business-link:focus-visible,
.sm-site-footer__how-link:focus-visible,
.sm-site-footer__email-link:focus-visible,
.sm-site-footer__social-link:focus-visible,
.sm-site-footer__group summary:focus-visible,
.sm-site-footer__group-menu a:focus-visible,
.sm-site-footer__bottom a:focus-visible {
	outline: 2px solid #ffffff;
	outline-offset: 4px;
}

.sm-site-footer__bottom {
	padding-top: 16px;
	border-top: 1px solid rgba(255, 255, 255, 0.1);
	text-align: center;
}

.sm-site-footer__bottom p {
	margin: 0;
	color: #e0e7ff;
	font-size: 13px;
	line-height: 1.5;
}


@media (max-width: 640px) {
	.sm-site-footer__brand {
		flex-direction: column;
		margin-bottom: 12px;
	}
	.sm-site-footer__brand-text {
		width: 100%;
	}
	.sm-site-footer__tagline,
	.sm-site-footer__controller-line {
		white-space: normal;
	}
}

@media (max-width: 640px) {
	.sm-site-footer__inner {
		padding: 26px 0 18px;
	}

	.sm-site-footer__nav {
		display: grid;
		grid-template-columns: 1fr 1fr;
		position: relative;
		z-index: 45;
		gap: 8px 16px;
		padding: 2px 0 8px;
	}

	.sm-site-footer__links a,
	.sm-site-footer__group summary {
		font-size: 13px;
	}

	.sm-site-footer__contact-links {
		grid-column: 1 / -1;
		gap: 8px 12px;
		margin-top: 2px;
		padding-top: 10px;
		border-top: 1px solid rgba(255, 255, 255, 0.1);
	}

	.sm-site-footer__group--legal .sm-site-footer__group-menu ul {
		grid-template-columns: 1fr;
	}

	.sm-site-footer__group--legal .sm-site-footer__group-menu {
		left: auto;
		right: 0;
		z-index: 80;
		max-height: min(68vh, 520px);
		overflow-y: auto;
		box-shadow: 0 22px 55px rgba(15, 23, 42, 0.22);
	}

	.sm-site-footer__bottom {
		padding-top: 12px;
	}
}

.sm-report-content {
	max-width: 760px;
	margin-top: 28px;
}

.sm-report-content__title {
	margin: 0 0 14px;
	color: var(--sm-text);
	font-size: 32px;
	line-height: 1.2;
}

.sm-report-content__intro {
	margin: 0 0 18px;
	color: var(--sm-muted);
	font-size: 16px;
	line-height: 1.6;
}

.sm-report-content__notice {
	margin: 0 0 18px;
	padding: 12px 14px;
	border-radius: 8px;
	font-size: 14px;
	font-weight: 700;
	line-height: 1.45;
}

.sm-report-content__notice--success {
	border: 1px solid #bbf7d0;
	background: #f0fdf4;
	color: #166534;
}

.sm-report-content__notice--error {
	border: 1px solid #fecaca;
	background: #fef2f2;
	color: #991b1b;
}

.sm-report-content__form {
	display: grid;
	gap: 18px;
}

.sm-report-content__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 16px;
}

.sm-report-content__field {
	display: grid;
	gap: 7px;
	margin: 0;
	color: var(--sm-text);
	font-size: 14px;
	font-weight: 700;
	line-height: 1.35;
}

.sm-report-content__field input,
.sm-report-content__field select,
.sm-report-content__field textarea {
	width: 100%;
	border: 1px solid var(--sm-border);
	border-radius: 8px;
	background: #ffffff;
	color: var(--sm-text);
	font: inherit;
	font-size: 15px;
	font-weight: 500;
}

.sm-report-content__field input,
.sm-report-content__field select {
	min-height: 46px;
}

.sm-report-content__field textarea {
	min-height: 150px;
	resize: vertical;
}

.sm-report-content__field input:focus,
.sm-report-content__field select:focus,
.sm-report-content__field textarea:focus {
	border-color: var(--sm-primary);
	box-shadow: 0 0 0 3px rgba(79, 70, 229, 0.14);
	outline: none;
}

.sm-report-content__checkbox {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	margin: 0;
	color: var(--sm-muted);
	font-size: 14px;
	font-weight: 600;
	line-height: 1.5;
}

.sm-report-content__checkbox input {
	width: 18px;
	height: 18px;
	margin-top: 2px;
	flex: 0 0 18px;
}

.sm-report-content__submit {
	justify-self: start;
}

@media (max-width: 640px) {
	.sm-report-content__grid {
		grid-template-columns: 1fr;
	}

	.sm-report-content__submit {
		width: 100%;
	}
}

.sm-feedback-page {
	background: var(--sm-bg);
	color: var(--sm-text);
	padding: 48px 20px 72px;
}

.sm-feedback {
	max-width: 760px;
	margin: 0 auto;
}

.sm-feedback__title {
	margin: 0 0 14px;
	color: var(--sm-text);
	font-size: 32px;
	line-height: 1.2;
}

.sm-feedback__intro {
	margin: 0 0 18px;
	color: var(--sm-muted);
	font-size: 16px;
	line-height: 1.6;
}

.sm-feedback__notice {
	margin: 0 0 18px;
	padding: 12px 14px;
	border-radius: 8px;
	font-size: 14px;
	font-weight: 700;
	line-height: 1.45;
}

.sm-feedback__notice--success {
	border: 1px solid #bbf7d0;
	background: #f0fdf4;
	color: #166534;
}

.sm-feedback__notice--error {
	border: 1px solid #fecaca;
	background: #fef2f2;
	color: #991b1b;
}

.sm-feedback__form {
	display: grid;
	gap: 18px;
}

.sm-feedback__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 16px;
}

.sm-feedback__field {
	display: grid;
	gap: 7px;
	margin: 0;
	color: var(--sm-text);
	font-size: 14px;
	font-weight: 700;
	line-height: 1.35;
}

.sm-feedback__field input,
.sm-feedback__field select,
.sm-feedback__field textarea {
	width: 100%;
	border: 1px solid var(--sm-border);
	border-radius: 8px;
	background: #ffffff;
	color: var(--sm-text);
	font: inherit;
	font-size: 15px;
	font-weight: 500;
}

.sm-feedback__field input,
.sm-feedback__field select {
	min-height: 46px;
}

.sm-feedback__field textarea {
	min-height: 150px;
	resize: vertical;
}

.sm-feedback__field input:focus,
.sm-feedback__field select:focus,
.sm-feedback__field textarea:focus {
	border-color: var(--sm-primary);
	box-shadow: 0 0 0 3px rgba(79, 70, 229, 0.14);
	outline: none;
}

.sm-feedback__checkbox {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	margin: 0;
	color: var(--sm-muted);
	font-size: 14px;
	font-weight: 600;
	line-height: 1.5;
}

.sm-feedback__checkbox input {
	width: 18px;
	height: 18px;
	margin-top: 2px;
	flex: 0 0 18px;
}

.sm-feedback__submit {
	justify-self: start;
}

.sm-feedback__hp {
	position: absolute;
	left: -9999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

.sm-feedback-cta {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
	max-width: 760px;
	margin: 28px 0 0;
	padding: 18px 0 0;
	border-top: 1px solid var(--sm-border);
}

.sm-feedback-cta h2 {
	margin: 0 0 6px;
	color: var(--sm-text);
	font-size: 20px;
	line-height: 1.25;
}

.sm-feedback-cta p {
	margin: 0;
	color: var(--sm-muted);
	font-size: 15px;
	line-height: 1.55;
}

.sm-feedback-cta__button {
	flex: 0 0 auto;
}

.sm-results-feedback-section .sm-feedback-cta {
	margin: 0 auto;
}

@media (max-width: 640px) {
	.sm-feedback-page {
		padding: 32px 16px 52px;
	}

	.sm-feedback__grid {
		grid-template-columns: 1fr;
	}

	.sm-feedback-cta {
		flex-direction: column;
		align-items: stretch;
	}

	.sm-feedback__submit,
	.sm-feedback-cta__button {
		width: 100%;
		justify-content: center;
	}
}

.sm-section {
	padding: 64px 0;
}

.sm-section--alt {
	background: var(--sm-surface-alt);
}

.sm-section__header {
	margin-bottom: 24px;
}

.sm-section__header h2 {
	margin: 0 0 10px;
	font-size: 32px;
	line-height: 1.2;
	color: var(--sm-text);
}

.sm-section__header p {
	margin: 0;
	color: var(--sm-muted);
	font-size: 17px;
}

.sm-card-grid {
	display: grid;
	gap: 20px;
}

.sm-card-grid--3 {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.sm-card-grid--4 {
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.sm-split {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 24px;
}

.sm-card,
.sm-cta-box {
	background: var(--sm-surface);
	border: 1px solid var(--sm-border);
	border-radius: var(--sm-radius-lg);
	box-shadow: var(--sm-shadow);
}

.sm-card {
	padding: 24px;
}

.sm-card h2,
.sm-card h3 {
	margin-top: 0;
	color: var(--sm-text);
}

.sm-card p {
	color: var(--sm-muted);
	margin-bottom: 0;
}

.sm-card--feature {
	height: 100%;
}

.sm-card-icon {
	display: block;
	width: 32px;
	height: 32px;
	margin-bottom: 12px;
	color: var(--sm-primary);
	flex-shrink: 0;
}

/* Icon + heading on the same line */
.sm-card-heading {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 8px;
}

.sm-card-heading h2,
.sm-card-heading h3 {
	margin: 0;
}

.sm-card-heading .sm-card-icon {
	margin-bottom: 0;
}

/* Gap between heading and description on /for-business/ cards */
.sm-business-page .sm-card h3 {
	margin-bottom: 8px;
}

.sm-card--link {
	display: block;
	text-decoration: none;
	color: var(--sm-text);
	font-weight: 700;
	text-align: center;
	transition: border-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.sm-card--link:hover,
.sm-card--link:focus {
	border-color: var(--sm-primary);
	color: var(--sm-primary);
	transform: translateY(-2px);
}

.sm-city-category-card {
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: 6px;
	min-height: 112px;
}

.sm-city-category-card__count {
	color: var(--sm-muted);
	font-size: 13px;
	font-weight: 600;
}

/* ?? Available-categories pill row ??????????????????????????????????????? */
.sm-category-pills-wrap {
	position: relative;
}

.sm-category-pills-wrap::after {
	content: '';
	position: absolute;
	top: 0;
	right: 0;
	bottom: 4px;
	width: 48px;
	background: linear-gradient(to right, transparent, var(--sm-bg));
	pointer-events: none;
	border-radius: 0 var(--sm-radius) var(--sm-radius) 0;
}

.sm-category-pills {
	display: grid;
	grid-template-rows: repeat(3, auto);
	grid-auto-flow: column;
	grid-auto-columns: max-content;
	gap: 8px 10px;
	overflow-x: auto;
	padding-bottom: 4px;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: thin;
	scrollbar-color: var(--sm-border) transparent;
}

.sm-category-pills::-webkit-scrollbar {
	height: 4px;
}

.sm-category-pills::-webkit-scrollbar-track {
	background: transparent;
}

.sm-category-pills::-webkit-scrollbar-thumb {
	background: var(--sm-border);
	border-radius: 2px;
}

.sm-category-pill {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 7px 16px;
	background: var(--sm-surface);
	border: 1px solid var(--sm-border);
	border-radius: 999px;
	color: var(--sm-text);
	font-size: 14px;
	font-weight: 500;
	text-decoration: none;
	white-space: nowrap;
	transition: background 0.2s, border-color 0.2s, color 0.2s;
}

.sm-category-pill:hover,
.sm-category-pill:focus {
	border-color: var(--sm-primary);
	color: var(--sm-primary);
	background: rgba(79, 70, 229, 0.05);
	outline: none;
}

.sm-category-pill__count {
	color: var(--sm-muted);
	font-size: 12px;
	font-weight: 600;
	transition: color 0.2s;
}

.sm-category-pill:hover .sm-category-pill__count,
.sm-category-pill:focus .sm-category-pill__count {
	color: var(--sm-primary);
}

.sm-home-cities-section {
	padding-top: 36px;
	padding-bottom: 36px;
	background: #ffffff;
	border-bottom: 1px solid var(--sm-border);
}

.sm-home-city-list {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

.sm-home-city-link {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	min-height: 42px;
	padding: 9px 14px;
	border: 1px solid var(--sm-border);
	border-radius: 999px;
	background: #ffffff;
	color: var(--sm-text);
	text-decoration: none;
	font-weight: 600;
	transition: border-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.sm-home-city-link:hover,
.sm-home-city-link:focus-visible {
	border-color: var(--sm-primary);
	color: var(--sm-primary);
	transform: translateY(-1px);
	outline: none;
}

.sm-home-city-link__count {
	color: var(--sm-muted);
	font-size: 12px;
	font-weight: 600;
}

.sm-home-categories-section {
	padding-top: 36px;
	padding-bottom: 44px;
}

.sm-home-category-card {
	display: flex;
	flex-direction: column;
	gap: 12px;
	min-height: 190px;
}

.sm-home-category-card__title {
	margin: 0;
	color: var(--sm-text);
	font-size: 18px;
	line-height: 1.25;
}

.sm-home-category-card__count {
	margin: 0;
	color: var(--sm-muted);
	font-size: 14px;
	line-height: 1.4;
}

.sm-home-category-card__cities {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: auto;
}

.sm-home-category-city {
	display: inline-flex;
	align-items: center;
	min-height: 32px;
	padding: 6px 10px;
	border: 1px solid var(--sm-border);
	border-radius: 999px;
	background: #f8fafc;
	color: var(--sm-text);
	font-size: 13px;
	font-weight: 700;
	line-height: 1;
	text-decoration: none;
}

.sm-home-category-city:hover,
.sm-home-category-city:focus-visible {
	border-color: var(--sm-primary);
	color: var(--sm-primary);
	outline: none;
}

.sm-badge {
	display: inline-block;
	padding: 8px 14px;
	border-radius: 999px;
	background: #e0e7ff;
	color: var(--sm-primary-dark);
	font-size: 14px;
	font-weight: 700;
	margin-bottom: 18px;
}

.sm-badge--event,
.sm-event-badge {
	background: #fff7ed;
	border: 1px solid #fed7aa;
	border-color: #fed7aa;
	color: #9a3412;
}

.sm-event-badge {
	display: inline-flex;
	align-items: center;
	min-height: 24px;
	margin-left: 8px;
	padding: 3px 8px;
	border: 1px solid #fed7aa;
	border-radius: 999px;
	font-size: 11px;
	font-weight: 700;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	vertical-align: middle;
}

.sm-field label {
	display: block;
	margin-bottom: 6px;
	color: var(--sm-text);
	font-size: 14px;
	font-weight: 700;
}

.sm-field__label {
	display: block;
	margin-bottom: 6px;
	color: var(--sm-text);
	font-size: 14px;
	font-weight: 700;
}

.sm-field input,
.sm-field select {
	box-sizing: border-box;
	width: 100%;
	min-height: 52px;
	padding: 14px 16px;
	border: 1px solid var(--sm-border);
	border-radius: 14px;
	background: #ffffff;
	color: var(--sm-text);
	font-size: 16px;
	line-height: 1.25;
}

.sm-field select {
	appearance: none;
	background-image: linear-gradient(45deg, transparent 50%, var(--sm-muted) 50%), linear-gradient(135deg, var(--sm-muted) 50%, transparent 50%);
	background-position: calc(100% - 20px) 50%, calc(100% - 14px) 50%;
	background-repeat: no-repeat;
	background-size: 6px 6px, 6px 6px;
	height: 52px;
	padding: 0 44px 0 16px;
}

.sm-field input:focus,
.sm-field select:focus {
	border-color: var(--sm-primary);
	outline: 2px solid rgba(79, 70, 229, 0.16);
	outline-offset: 2px;
}

.sm-picker-trigger {
	display: flex;
	align-items: center;
	justify-content: space-between;
	box-sizing: border-box;
	width: 100%;
	min-height: 52px;
	padding: 0 16px;
	border: 1px solid var(--sm-border);
	border-radius: 14px;
	background: #ffffff;
	color: var(--sm-muted);
	font-family: inherit;
	font-size: 16px;
	font-weight: 600;
	line-height: 1.25;
	text-align: left;
	cursor: pointer;
}

.sm-picker-trigger::after {
	content: "";
	width: 9px;
	height: 9px;
	border-right: 2px solid currentColor;
	border-bottom: 2px solid currentColor;
	transform: rotate(45deg) translateY(-2px);
	flex-shrink: 0;
}

.sm-picker-trigger.has-value {
	color: var(--sm-text);
}

.sm-picker-trigger:focus-visible {
	border-color: var(--sm-primary);
	outline: 2px solid rgba(79, 70, 229, 0.16);
	outline-offset: 2px;
}

.sm-services-search-form.has-search-error .sm-picker-trigger[aria-invalid="true"] {
	border-color: #dc2626;
}

.sm-picker-open {
	overflow: hidden;
}

.sm-picker-modal[hidden] {
	display: none;
}

.sm-picker-modal {
	position: fixed;
	inset: 0;
	z-index: 2000;
	display: grid;
	place-items: center;
	padding: 18px;
}

.sm-picker-modal__backdrop {
	position: absolute;
	inset: 0;
	background: rgba(15, 23, 42, 0.48);
}

.sm-picker-modal__dialog {
	position: relative;
	display: flex;
	flex-direction: column;
	width: min(720px, 100%);
	max-height: min(760px, calc(100vh - 36px));
	overflow: hidden;
	border: 1px solid var(--sm-border);
	border-radius: 18px;
	background: #ffffff;
	box-shadow: 0 24px 70px rgba(15, 23, 42, 0.22);
}

.sm-picker-modal__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 18px 20px;
	border-bottom: 1px solid var(--sm-border);
}

.sm-picker-modal__header h3 {
	margin: 0;
	color: var(--sm-text);
	font-size: 20px;
	line-height: 1.25;
}

.sm-picker-modal__close {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 38px;
	height: 38px;
	padding: 0;
	border: 1px solid var(--sm-border);
	border-radius: 12px;
	background: #ffffff;
	color: var(--sm-text);
	font-size: 24px;
	line-height: 1;
	cursor: pointer;
}

.sm-picker-modal__search {
	padding: 14px 20px;
	border-bottom: 1px solid var(--sm-border);
}

.sm-picker-modal__search input {
	box-sizing: border-box;
	width: 100%;
	min-height: 44px;
	padding: 10px 14px;
	border: 1px solid var(--sm-border);
	border-radius: 12px;
	color: var(--sm-text);
	font-size: 15px;
}

.sm-picker-modal__body {
	overflow-y: auto;
	padding: 18px 20px 20px;
}

.sm-picker-section + .sm-picker-section {
	margin-top: 22px;
}

.sm-picker-section h4 {
	margin: 0 0 10px;
	color: var(--sm-muted);
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.sm-picker-list {
	display: grid;
	gap: 8px;
}

.sm-picker-list--compact {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.sm-picker-option {
	display: flex;
	align-items: center;
	width: 100%;
	min-height: 44px;
	padding: 10px 12px;
	border: 1px solid var(--sm-border);
	border-radius: 10px;
	background: #ffffff;
	color: var(--sm-text);
	font-size: 14px;
	line-height: 1.3;
	text-align: left;
	cursor: pointer;
}

.sm-picker-option[hidden],
.sm-picker-empty[hidden] {
	display: none !important;
}

.sm-picker-option:hover,
.sm-picker-option:focus-visible {
	border-color: var(--sm-primary);
	background: #eef2ff;
	color: var(--sm-primary-dark);
	outline: none;
}

.sm-picker-option.is-selected {
	border-color: var(--sm-primary);
	background: #eef2ff;
	color: var(--sm-primary-dark);
}

.sm-picker-empty {
	padding: 24px 16px;
	text-align: center;
	color: var(--sm-muted);
	font-size: 14px;
}

.sm-picker-modal {
	transition: opacity 0.2s ease, transform 0.2s ease, padding-bottom 0.15s ease;
}

.sm-picker-modal[hidden] {
	opacity: 0;
	transform: translateY(10px);
}

.sm-picker-modal:not([hidden]) {
	opacity: 1;
	transform: translateY(0);
}

@media (max-width: 640px) {
	.sm-picker-modal {
		align-items: end;
		padding: 0;
		padding-bottom: var(--_kbd, 0px);
	}

	.sm-picker-modal__dialog {
		width: 100%;
		max-height: calc(88vh - var(--_kbd, 0px));
		border-radius: 18px 18px 0 0;
	}

.sm-picker-list--compact {
		grid-template-columns: 1fr;
	}
}

.sm-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
	margin-top: 20px;
}

.sm-actions--center {
	justify-content: center;
}

.sm-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 14px 22px;
	border: 0;
	border-radius: 14px;
	text-decoration: none;
	font-family: inherit;
	font-size: 15px;
	font-weight: 700;
	line-height: 1.3;
	min-height: 50px;
	cursor: pointer;
	transition: 0.2s ease;
}

.sm-btn:hover {
	transform: translateY(-1px);
}

.sm-btn:focus-visible {
	outline: 2px solid var(--sm-primary);
	outline-offset: 3px;
}

.sm-btn--primary {
	background: var(--sm-primary);
	color: #ffffff;
}

a.sm-btn--primary,
a.sm-btn--primary:visited,
.sm-btn--primary:visited {
	color: #ffffff;
}

.sm-btn--primary:hover,
a.sm-btn--primary:hover,
a.sm-btn--primary:focus {
	background: var(--sm-primary-dark);
	color: #ffffff;
}

.sm-btn--secondary {
	background: #ffffff;
	color: var(--sm-text);
	border: 1px solid var(--sm-border);
}

a.sm-btn--secondary,
a.sm-btn--secondary:visited,
.sm-btn--secondary:visited {
	color: var(--sm-text);
}

.sm-btn--secondary:hover,
a.sm-btn--secondary:hover,
a.sm-btn--secondary:focus {
	background: #f8fafc;
	color: var(--sm-text);
}

.sm-btn--outline {
	background: transparent;
	color: var(--sm-text);
	border: 1px solid var(--sm-border);
}

.sm-btn--outline:hover {
	background: #f8fafc;
	color: var(--sm-text);
}

.sm-btn--compact {
	min-height: 42px;
	padding: 10px 16px;
	border-radius: 10px;
	font-size: 14px;
}

.sm-btn--full {
	width: 100%;
}

.sm-cta-box {
	padding: 36px;
	text-align: center;
}

.sm-cta-box h2 {
	margin-top: 0;
	margin-bottom: 10px;
}

.sm-cta-box p {
	color: var(--sm-muted);
	margin-bottom: 20px;
}

.sm-services-page {
	background: var(--sm-bg);
	color: var(--sm-text);
}

.sm-services-notice {
	max-width: 640px;
	padding: 16px 0 8px;
}

.sm-services-notice h1 {
	margin: 0 0 16px;
	font-size: clamp(28px, 4vw, 40px);
	line-height: 1.15;
	color: var(--sm-text);
}

.sm-services-notice__text {
	margin: 0 0 8px;
	color: var(--sm-muted);
	font-size: 17px;
	line-height: 1.7;
}

.sm-services-search-card {
	padding: 32px;
	scroll-margin-top: 112px;
}

.sm-services-search-card h2 {
	margin-top: 0;
	margin-bottom: 8px;
}

.sm-services-search-card p {
	color: var(--sm-muted);
	line-height: 1.7;
	margin-bottom: 20px;
}

.sm-services-search-form {
	display: grid;
	gap: 14px;
}

.sm-services-search-card .sm-search-tagline {
	font-size: 12px;
	font-weight: 700;
	color: var(--sm-primary);
	text-align: center;
	margin: 8px 0 0;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.sm-services-search-card .sm-services-search-note {
	margin: 0;
	color: var(--sm-muted);
	font-size: 14px;
	line-height: 1.6;
	text-align: center;
}

.sm-services-search-error {
	margin: -2px 0 0;
	color: #b91c1c;
	font-size: 14px;
	font-weight: 700;
	text-align: center;
}

.sm-services-search-error[hidden] {
	display: none;
}

@media (max-width: 782px) {
	body.admin-bar .sm-site-header {
		top: 46px;
	}
}

/* ??? Category Results Page ???????????????????????????? */

.sm-results-page {
	background: var(--sm-bg);
	color: var(--sm-text);
}

.sm-results-intro {
	padding: 40px 0 32px;
	background: linear-gradient(135deg, #eef2ff 0%, #f7f8fc 60%, #ffffff 100%);
	border-bottom: 1px solid var(--sm-border);
}

.sm-results-intro__title {
	margin: 0 0 10px;
	font-size: clamp(28px, 4vw, 42px);
	line-height: 1.15;
	color: var(--sm-text);
}

.sm-results-intro__subtitle {
	margin: 0 0 20px;
	color: var(--sm-muted);
	font-size: 17px;
	line-height: 1.6;
}

.sm-filter-chips {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 16px;
}

.sm-filter-chip {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 6px 12px;
	background: #ffffff;
	border: 1px solid var(--sm-border);
	border-radius: 999px;
	font-size: 14px;
	color: var(--sm-text);
	line-height: 1;
}

.sm-filter-chip__icon {
	width: 15px;
	height: 15px;
	flex: 0 0 15px;
	color: var(--sm-primary);
}

.sm-filter-chip__label {
	color: var(--sm-muted);
	font-weight: 400;
}

.sm-filter-chip__value {
	font-weight: 700;
}

.sm-filter-chip__remove {
	margin-left: 6px;
	color: var(--sm-muted);
	font-size: 16px;
	line-height: 1;
}

.sm-category-subscribe-form--chip {
	display: inline-flex;
	margin: 0;
}

.sm-category-subscribe-chip {
	display: inline-flex;
}

.sm-filter-chip--subscribe {
	min-width: 34px;
	justify-content: center;
	color: var(--sm-primary);
	cursor: pointer;
	text-decoration: none;
}

button.sm-filter-chip--subscribe {
	font: inherit;
}

.sm-filter-chip--subscribe:hover,
.sm-filter-chip--subscribe:focus-visible,
.sm-filter-chip--subscribe.is-active {
	border-color: var(--sm-primary);
	background: var(--sm-surface-alt);
	color: var(--sm-primary);
	text-decoration: none;
}

.sm-subscribe-top-notice {
	margin-top: 12px;
	padding: 10px 14px;
	border-radius: 8px;
	font-size: 14px;
	font-weight: 600;
	line-height: 1.5;
}

.sm-subscribe-top-notice--success {
	background: #f0fdf4;
	border: 1px solid #bbf7d0;
	color: #166534;
}

.sm-subscribe-top-notice--error {
	background: #fef2f2;
	border: 1px solid #fecaca;
	color: #991b1b;
}

.sm-category-subscribe-cta {
	display: grid;
	grid-template-columns: auto minmax(0, 1fr) auto;
	align-items: center;
	gap: 16px;
	margin-top: 24px;
	padding: 18px;
	border: 1px solid var(--sm-border);
	border-radius: 8px;
	background: #ffffff;
	box-shadow: 0 12px 30px rgba(15, 23, 42, 0.06);
	scroll-margin-top: 96px;
}

.sm-category-subscribe-cta__notice {
	grid-column: 1 / -1;
	margin: 0;
	padding: 10px 12px;
	border: 1px solid #bbf7d0;
	border-radius: 8px;
	background: #f0fdf4;
	color: #166534;
	font-size: 14px;
	font-weight: 700;
}

.sm-category-subscribe-cta__notice--error {
	border-color: #fecaca;
	background: #fef2f2;
	color: #991b1b;
}

.sm-category-subscribe-cta__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 42px;
	border-radius: 8px;
	background: #eef2ff;
	color: var(--sm-primary);
}

.sm-category-subscribe-cta__svg {
	width: 22px;
	height: 22px;
}

.sm-category-subscribe-cta__title {
	margin: 0;
	font-size: 18px;
	line-height: 1.3;
	color: var(--sm-text);
}

.sm-category-subscribe-cta__text {
	margin: 4px 0 0;
	color: var(--sm-muted);
	font-size: 15px;
	line-height: 1.5;
}

.sm-category-subscribe-form {
	margin: 0;
}

@media (max-width: 640px) {
	.sm-category-subscribe-cta {
		grid-template-columns: auto minmax(0, 1fr);
	}

	.sm-category-subscribe-cta__action {
		grid-column: 1 / -1;
	}
}

.sm-filter-bar {
	background: var(--sm-surface);
	border-bottom: 1px solid var(--sm-border);
	padding: 14px 0;
}

.sm-filter-bar__inner {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: 16px;
}

.sm-filter-bar__filters {
	display: grid;
	grid-template-columns: minmax(220px, 300px) minmax(220px, 300px) 1fr;
	align-items: start;
	gap: 0 32px;
	min-width: 0;
}

.sm-filter-bar__group {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.sm-filter-bar__group--voice {
	padding-top: 25px;
}

.sm-filter-bar__group--voice .sm-filter-bar__checkbox-field {
	padding: 0;
	min-height: 0;
}

.sm-filter-bar__actions {
	display: flex;
	align-items: center;
	gap: 16px;
}

.sm-filter-bar .sm-picker-trigger {
	min-height: 40px;
	height: 40px;
	border-radius: 20px;
	font-size: 14px;
}

.sm-filter-bar__title {
	grid-column: 1 / -1;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	margin: 0;
	color: var(--sm-muted);
	font-size: 14px;
	font-weight: 700;
	line-height: 1.2;
}

.sm-filter-bar__title-icon {
	width: 17px;
	height: 17px;
	color: var(--sm-primary);
}

.sm-filter-bar__field {
	display: flex;
	align-items: center;
	gap: 10px;
	min-width: 0;
}

.sm-filter-bar__field label {
	margin: 0;
	font-size: 13px;
	font-weight: 700;
	color: var(--sm-text);
	line-height: 1.2;
	white-space: nowrap;
}

.sm-filter-bar__field select {
	flex: 1 1 0;
	min-width: 0;
	min-height: 40px;
	height: 40px;
	padding: 0 36px 0 12px;
	font-size: 14px;
	border: 1px solid var(--sm-border);
	border-radius: 20px;
	background-color: #ffffff;
}

.sm-filter-bar__change {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 40px;
	padding: 0;
	font-size: 14px;
	font-weight: 700;
	color: var(--sm-primary);
	text-decoration: none;
	white-space: nowrap;
}

.sm-filter-bar__change:hover,
.sm-filter-bar__change:focus-visible {
	color: var(--sm-primary-dark);
	text-decoration: underline;
}

.sm-filter-bar__apply {
	min-height: 36px;
	height: 36px;
	padding: 0 16px;
	border-radius: 18px;
	font-size: 14px;
	white-space: nowrap;
}

.sm-filter-bar__checkbox-field {
	display: flex;
	align-items: center;
	min-width: 0;
	min-height: 40px;
	padding: 22px 0 0;
	border: 0;
	border-radius: 0;
	background: transparent;
}

.sm-filter-bar__checkbox-wrap {
	display: grid;
	gap: 5px;
	min-width: 0;
	max-width: 380px;
}

.sm-filter-bar .sm-field-checkbox {
	align-items: center;
	gap: 8px;
	margin: 0;
	font-size: 14px;
	font-weight: 700;
	line-height: 1;
	white-space: nowrap;
}

.sm-filter-bar .sm-field-checkbox input {
	width: 16px;
	height: 16px;
	margin: 0;
	accent-color: var(--sm-primary);
}

.sm-filter-bar__hint {
	margin: 0;
	color: var(--sm-muted);
	font-size: 12px;
	line-height: 1.35;
}

.sm-results-section {
	padding-top: 32px;
	scroll-margin-top: 64px;
}

body.admin-bar .sm-results-section {
	scroll-margin-top: 96px;
}

.sm-results-actions {
	margin-top: 22px;
}

.sm-results-toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	margin-bottom: 18px;
}

.sm-results-summary {
	margin: 0;
	font-size: 15px;
	color: var(--sm-muted);
	font-weight: 700;
}

.sm-results-list {
	display: flex;
	flex-direction: column;
	gap: 16px;
	min-width: 0;
	max-width: 100%;
}

.sm-results-list--switchable.is-grid-view {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	align-items: stretch;
}

.sm-results-list--switchable.is-grid-view .sm-result-card {
	flex-direction: column;
}

.sm-results-list--switchable.is-grid-view .sm-result-card__body {
	box-sizing: border-box;
	width: 100%;
	max-width: 100%;
}

.sm-result-card {
	display: flex;
	align-items: flex-start;
	gap: 24px;
	min-width: 0;
	max-width: 100%;
}

.sm-result-card__body {
	flex: 1;
	min-width: 0;
}

.sm-result-card__title {
	margin: 0 0 4px;
	font-size: 18px;
	color: var(--sm-text);
}

.sm-result-card__business {
	margin: 0 0 8px;
	font-size: 14px;
	color: var(--sm-primary);
	font-weight: 700;
}

.sm-result-card__meta {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 4px 8px;
	margin-bottom: 12px;
	font-size: 14px;
	color: var(--sm-muted);
	box-sizing: border-box;
	width: 100%;
	min-width: 0;
	max-width: 100%;
	overflow-wrap: anywhere;
}

.sm-result-card__meta-item {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	min-width: 0;
	max-width: 100%;
	overflow-wrap: anywhere;
}

.sm-result-card__meta-item > span {
	min-width: 0;
	overflow-wrap: anywhere;
}

.sm-result-card__meta-item[data-sm-other-languages] {
	align-items: flex-start;
}

.sm-result-card__meta-item[data-sm-other-languages] > span {
	white-space: normal;
}

.sm-result-card__meta-icon {
	width: 15px;
	height: 15px;
	flex: 0 0 15px;
	color: var(--sm-primary);
}

.sm-result-card__category-link--event {
	display: inline-flex;
	align-items: center;
	min-height: 24px;
	padding: 3px 8px;
	border: 1px solid #fed7aa;
	border-radius: 999px;
	background: #fff7ed;
	color: #9a3412;
	font-size: 12px;
	font-weight: 700;
	text-decoration: none;
}

.sm-result-card__category-link--event:hover,
.sm-result-card__category-link--event:focus-visible {
	background: #ffedd5;
	color: #7c2d12;
	text-decoration: none;
}

@media (max-width: 900px) {
	.sm-filter-bar__filters {
		grid-template-columns: minmax(160px, 1fr) minmax(160px, 1fr) auto;
		gap: 0 20px;
	}

	.sm-results-toolbar {
		align-items: flex-start;
		flex-direction: column;
	}
}

@media (max-width: 780px) {
	.sm-filter-bar__inner {
		gap: 12px;
	}

	.sm-filter-bar__filters {
		grid-template-columns: 1fr;
		gap: 12px;
		padding-bottom: 0;
	}

	.sm-filter-bar__group--voice {
		padding-top: 0;
	}

	.sm-filter-bar__group--voice .sm-filter-bar__checkbox-field {
		min-height: 40px;
	}

	.sm-filter-bar__title {
		margin-bottom: -2px;
	}

	.sm-filter-bar__field {
		min-width: 0;
		width: 100%;
	}

	.sm-filter-bar__field select {
		width: auto;
	}

	.sm-filter-bar__actions {
		width: 100%;
	}

	.sm-filter-bar__apply {
		width: 100%;
		height: 40px;
		padding: 0 14px;
	}
}

@media (max-width: 640px) {
	.sm-results-toolbar .sm-view-toggle {
		display: none;
	}

	.sm-result-card__meta {
		align-items: flex-start;
		overflow: visible;
	}
}

@media (max-width: 899px) {
	.sm-results-list--switchable.is-grid-view {
		display: block;
	}
}

.sm-result-card__sep {
	color: var(--sm-border);
}

.sm-result-card__desc {
	margin: 0;
	font-size: 15px;
	color: var(--sm-muted);
	line-height: 1.65;
}

.sm-result-card__footer {
	flex-shrink: 0;
	display: flex;
	align-items: center;
	padding-top: 2px;
}

.sm-results-empty {
	border-top: 2px dashed var(--sm-border);
}

.sm-results-empty__label {
	text-align: center;
	font-size: 13px;
	color: var(--sm-muted);
	font-style: italic;
	margin: 0 0 20px;
}

.sm-results-empty__box {
	max-width: 480px;
	margin: 0 auto;
	text-align: center;
}

.sm-results-empty__text {
	color: var(--sm-muted);
	font-size: 17px;
	margin-bottom: 20px;
}

.sm-business-result-card__title a,
.sm-business-services__link,
.sm-business-profile-service h3 a {
	color: var(--sm-text);
	text-decoration: none;
}

.sm-business-result-card__title {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 8px;
}

.sm-business-result-card__title a:hover,
.sm-business-services__link:hover,
.sm-business-profile-service h3 a:hover {
	color: var(--sm-primary);
	text-decoration: underline;
}

.sm-business-services {
	margin-top: 14px;
	padding-top: 14px;
	border-top: 1px solid var(--sm-border);
	box-sizing: border-box;
	min-width: 0;
	max-width: 100%;
}

details.sm-business-services > summary {
	list-style: none;
}

details.sm-business-services > summary::-webkit-details-marker {
	display: none;
}

.sm-business-services__summary {
	display: grid;
	grid-template-columns: auto minmax(0, 1fr) auto;
	align-items: center;
	column-gap: 8px;
	cursor: pointer;
	user-select: none;
	padding: 6px 10px;
	border: 1px solid var(--sm-border);
	border-radius: var(--sm-radius);
	background: var(--sm-surface);
	box-sizing: border-box;
	width: 100%;
	max-width: 100%;
	overflow: hidden;
	transition: border-color 0.15s, background 0.15s;
}

.sm-business-services__summary:hover {
	border-color: var(--sm-primary);
	background: rgba(79, 70, 229, 0.04);
}

details[open].sm-business-services .sm-business-services__summary {
	border-color: var(--sm-primary);
	background: rgba(79, 70, 229, 0.04);
}

.sm-business-services__label {
	font-size: 13px;
	color: var(--sm-muted);
	text-transform: uppercase;
	letter-spacing: 0.04em;
	flex-shrink: 0;
}

.sm-filter-bar__field-label {
	display: inline-flex;
	align-items: center;
	gap: 6px;
}

.sm-filter-bar__checkbox-icon {
	width: 16px;
	height: 16px;
	flex: 0 0 16px;
	color: var(--sm-primary);
}

.sm-business-services__cats {
	display: flex;
	flex-wrap: wrap;
	gap: 4px;
	min-width: 0;
	max-width: 100%;
	overflow: hidden;
}

.sm-business-services__cat {
	font-size: 12px;
	color: var(--sm-muted);
	background: var(--sm-bg);
	border: 1px solid var(--sm-border);
	border-radius: 4px;
	padding: 1px 7px;
	box-sizing: border-box;
	white-space: nowrap;
	min-width: 0;
	max-width: 100%;
	overflow: hidden;
	text-overflow: ellipsis;
}

.sm-business-services--city .sm-business-services__cat {
	color: var(--sm-primary);
	background: rgba(79, 70, 229, 0.07);
	border-color: rgba(79, 70, 229, 0.25);
}

.sm-business-services__cat--active {
	color: var(--sm-primary);
	background: rgba(79, 70, 229, 0.07);
	border-color: rgba(79, 70, 229, 0.25);
}

.sm-business-services__toggle {
	flex-shrink: 0;
}

.sm-business-services__toggle::after {
	content: '';
	display: block;
	width: 7px;
	height: 7px;
	border-right: 2px solid var(--sm-muted);
	border-bottom: 2px solid var(--sm-muted);
	transform: rotate(45deg);
	transition: transform 0.2s;
	margin-top: -4px;
}

details[open].sm-business-services .sm-business-services__toggle::after {
	transform: rotate(-135deg);
	margin-top: 3px;
}

.sm-business-services__list {
	display: flex;
	flex-direction: column;
	gap: 10px;
	margin: 10px 0 0;
	padding: 0;
	list-style: none;
	min-width: 0;
	max-width: 100%;
	overflow: hidden;
}

.sm-business-services__item {
	padding: 10px 0;
	border-bottom: 1px solid rgba(221, 227, 240, 0.8);
}

.sm-business-services__item:last-child {
	border-bottom: none;
	padding-bottom: 0;
}

.sm-business-services__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	min-width: 0;
}

.sm-business-services__link {
	font-weight: 700;
	min-width: 0;
	overflow-wrap: anywhere;
}

@media (max-width: 640px) {
	.sm-business-services__summary {
		grid-template-columns: auto minmax(0, 1fr) auto;
		align-items: start;
		row-gap: 6px;
		overflow: visible;
	}

	.sm-business-services__cats {
		grid-column: 1 / -1;
		width: 100%;
	}

	.sm-business-services__toggle {
		margin-top: 7px;
	}
}

.sm-business-services__item p {
	margin: 6px 0 0;
	color: var(--sm-muted);
	font-size: 14px;
	line-height: 1.6;
}

.sm-business-services__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 10px;
}

.sm-business-profile-page {
	background: var(--sm-bg);
	color: var(--sm-text);
}

.sm-business-profile-hero {
	padding: 56px 0 44px;
	background: linear-gradient(135deg, #eef2ff 0%, #f7f8fc 60%, #ffffff 100%);
	border-bottom: 1px solid var(--sm-border);
}

.sm-business-profile-hero__title {
	margin: 0;
	font-size: 48px;
	line-height: 1.1;
	color: var(--sm-text);
}

.sm-business-profile-hero__headline {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 14px;
}

.sm-business-profile-hero__rating-row {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 10px;
	margin: 12px 0 16px;
}

.sm-business-profile-hero__cats {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin-bottom: 16px;
}

.sm-business-profile-hero__cat {
	font-size: 13px;
	color: var(--sm-primary);
	background: rgba(79, 70, 229, 0.07);
	border: 1px solid rgba(79, 70, 229, 0.25);
	border-radius: 4px;
	padding: 2px 10px;
	white-space: nowrap;
	text-decoration: none;
	cursor: pointer;
	transition: background 0.15s, border-color 0.15s;
}

.sm-business-profile-hero__cat:hover {
	background: rgba(79, 70, 229, 0.14);
	border-color: rgba(79, 70, 229, 0.45);
	color: var(--sm-primary);
}

.sm-business-rating-badge {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	min-height: 34px;
	padding: 6px 10px;
	border: 1px solid #f59e0b;
	border-radius: 999px;
	background: #fffbeb;
	color: #92400e;
	font-size: 14px;
	font-weight: 700;
	text-decoration: none;
}

.sm-business-rating-badge:hover {
	background: #fef3c7;
	color: #78350f;
	text-decoration: none;
}

.sm-business-rating-badge__icon {
	width: 18px;
	height: 18px;
	color: #f59e0b;
}

.sm-business-rating-badge__count {
	color: #a16207;
	font-weight: 700;
}

.sm-business-rating-badge--compact {
	min-height: 26px;
	padding: 4px 8px;
	font-size: 12px;
	vertical-align: middle;
}

.sm-business-rating-badge--compact .sm-business-rating-badge__icon {
	width: 15px;
	height: 15px;
}

.sm-business-registration-badge {
	display: inline-flex;
	align-items: center;
	flex: 0 0 auto;
	gap: 5px;
	color: var(--sm-primary);
	line-height: 1;
	vertical-align: middle;
}

.sm-business-registration-badge__icon {
	width: 22px;
	height: 22px;
	display: block;
}

.sm-business-registration-badge--icon-only {
	padding: 2px;
	border-radius: 999px;
	background: rgba(79, 70, 229, 0.1);
}

.sm-business-registration-badge__label {
	color: var(--sm-muted);
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 0;
}

.sm-business-registration-badge__number {
	color: var(--sm-text);
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 0;
}

.sm-business-registration-badge--profile {
	min-height: 34px;
}

.sm-business-registration-badge--profile .sm-business-registration-badge__number {
	font-weight: 600;
}

.sm-business-registration-badge--result .sm-business-registration-badge__icon {
	width: 21px;
	height: 21px;
}

.sm-business-registration-badge--listing .sm-business-registration-badge__icon {
	width: 20px;
	height: 20px;
}

.sm-business-registration-badge--listing .sm-business-registration-badge__number {
	color: var(--sm-muted);
	font-size: 14px;
}

.sm-business-profile-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

.sm-business-profile-meta__group {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	min-height: 42px;
	padding: 9px 12px;
	border: 1px solid var(--sm-border);
	border-radius: 14px;
	background: rgba(255, 255, 255, 0.72);
	color: var(--sm-muted);
	font-size: 14px;
	box-shadow: 0 6px 18px rgba(15, 23, 42, 0.04);
}

.sm-business-profile-meta__group--communication {
	background: #f8fafc;
}

.sm-business-profile-meta__icon {
	width: 20px;
	height: 20px;
	flex: 0 0 20px;
	color: var(--sm-primary);
}

.sm-business-profile-meta__icon--location {
	width: 16px;
	height: 16px;
	flex: 0 0 16px;
	opacity: 0.65;
	margin-left: -6px;
}

.sm-business-profile-meta__items {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 6px;
}

.sm-business-profile-meta__items span {
	display: inline-flex;
	align-items: center;
	min-height: 24px;
	padding: 3px 8px;
	border-radius: 999px;
	background: #ffffff;
	color: var(--sm-text);
	font-weight: 700;
}

.sm-business-profile-services {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.sm-business-profile-service {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

/* Has-thumb: 2-col grid - heading full row, thumb+body row, actions row */
.sm-business-profile-service--has-thumb {
	display: grid;
	grid-template-columns: 72px 1fr;
	gap: 6px 12px;
	align-items: start;
}

/* Title heading: spans both columns, always full width */
.sm-business-profile-service__heading {
	grid-column: 1 / -1;
	margin: 0;
}

.sm-business-profile-service__actions {
	display: flex;
	flex-shrink: 0;
	flex-direction: column;
	gap: 8px;
	align-items: stretch;
	grid-column: 1 / -1; /* span full width in grid context */
}

.sm-business-profile-service h3 {
	margin: 0 0 8px;
	font-size: 18px;
}

.sm-business-profile-service p {
	margin: 0;
	line-height: 1.65;
}

.sm-business-profile-service__excerpt {
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.sm-business-profile-service__meta {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 6px;
	margin-bottom: 8px !important;
}

.sm-business-profile-service__category {
	color: var(--sm-primary);
	font-size: 14px;
	font-weight: 700;
}

.sm-business-profile-service__category--event {
	display: inline-flex;
	align-items: center;
	min-height: 24px;
	padding: 3px 8px;
	border: 1px solid #fed7aa;
	border-radius: 999px;
	background: #fff7ed;
	color: #9a3412;
	font-size: 12px;
	font-weight: 700;
}

/* ??? Service card: left thumb column (thumbnail + chat icon below) ??? */

.sm-business-profile-service__thumb-col {
	grid-column: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	pointer-events: none;
	gap: 8px;
	width: 72px;
	position: relative;
	z-index: 1;
}

.sm-business-profile-service__thumb {
	display: block;
	width: 72px;
	height: 72px;
	flex-shrink: 0;
	pointer-events: auto;
	border-radius: 8px;
	overflow: hidden;
	border: 1px solid var(--sm-border);
	background: var(--sm-bg);
	transition: opacity 0.15s;
}

.sm-business-profile-service__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* Icon centred below thumbnail; override inline-icon defaults */
.sm-business-profile-service__thumb-col .sm-service-title-icon {
	margin-left: 0;
	vertical-align: 0;
	justify-content: center;
}

.sm-business-profile-service--has-thumb > div {
	padding-right: 0;
}

.sm-business-profile-service__body {
	grid-column: 2;
	min-width: 0;
}

/* ??? Clickable service cards (stretched-link pattern) ?? */

.sm-business-profile-service,
.sm-business-services__item {
	position: relative;
}

/* Title <a> expands to cover the whole card */
.sm-stretched-link::after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 0;
}

/* Hover: card-level feedback */
.sm-business-profile-service {
	transition: border-color 0.15s, box-shadow 0.15s;
}

.sm-business-profile-service:hover {
	border-color: var(--sm-primary);
	box-shadow: 0 4px 18px rgba(79, 70, 229, 0.10);
}

.sm-business-services__item:hover .sm-business-services__link {
	color: var(--sm-primary);
	text-decoration: underline;
}

/* Keep interactive siblings above the stretched-link overlay */
.sm-listing-favorite-icon,
.sm-listing-favorite-form,
.sm-listing-notice,
.sm-business-profile-service__actions a {
	position: relative;
	z-index: 1;
}

/* Chat icon inline with service title */
.sm-service-title-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	vertical-align: -0.15em;
	margin-left: 6px;
	color: var(--sm-primary);
	opacity: 0.76;
	transition: color 0.18s ease, opacity 0.18s ease, transform 0.18s ease;
}

.sm-service-title-icon__svg {
	width: 18px;
	height: 18px;
}

.sm-service-title-icon__svg--solid {
	display: none;
}

.sm-business-profile-service:hover .sm-service-title-icon,
.sm-business-profile-service:focus-within .sm-service-title-icon,
.sm-business-profile-service:active .sm-service-title-icon,
.sm-business-services__item:hover .sm-service-title-icon,
.sm-business-services__item:focus-within .sm-service-title-icon,
.sm-business-services__item:active .sm-service-title-icon {
	opacity: 1;
	transform: scale(1.12);
}

.sm-business-profile-service:hover .sm-service-title-icon__svg--outline,
.sm-business-profile-service:focus-within .sm-service-title-icon__svg--outline,
.sm-business-profile-service:active .sm-service-title-icon__svg--outline,
.sm-business-services__item:hover .sm-service-title-icon__svg--outline,
.sm-business-services__item:focus-within .sm-service-title-icon__svg--outline,
.sm-business-services__item:active .sm-service-title-icon__svg--outline {
	display: none;
}

.sm-business-profile-service:hover .sm-service-title-icon__svg--solid,
.sm-business-profile-service:focus-within .sm-service-title-icon__svg--solid,
.sm-business-profile-service:active .sm-service-title-icon__svg--solid,
.sm-business-services__item:hover .sm-service-title-icon__svg--solid,
.sm-business-services__item:focus-within .sm-service-title-icon__svg--solid,
.sm-business-services__item:active .sm-service-title-icon__svg--solid {
	display: block;
}

/* ??? Responsive ??????????????????????????????????????? */

@media (max-width: 920px) {
	.sm-site-header__inner {
		display: grid;
		grid-template-columns: minmax(0, 1fr) auto;
		align-items: center;
		gap: 14px;
		min-height: auto;
		padding: 18px 0;
	}

	.sm-site-header__brand {
		grid-column: 1;
		grid-row: 1;
		min-width: 0;
	}

	.sm-site-header__controls {
		grid-column: 2;
		grid-row: 1;
		gap: 8px;
		min-width: 0;
	}

	.sm-site-header__languages {
		flex-shrink: 0;
	}

	.sm-site-header__language {
		min-width: 30px;
		padding: 0 7px;
	}

	.sm-site-header__auth {
		gap: 8px;
	}

	.sm-site-header__auth .sm-site-header__cta {
		min-height: 38px;
		padding: 9px 12px;
		font-size: 13px;
		white-space: nowrap;
	}

	.sm-site-header__account-toggle {
		width: auto;
		min-width: 42px;
		height: 42px;
		padding: 0 10px;
		gap: 5px;
		border-radius: 8px;
	}

	.sm-site-header__account-name {
		display: none;
	}

	.sm-site-header__account-menu {
		right: 0;
		min-width: min(240px, calc(100vw - 32px));
	}

	.sm-site-header__login {
		width: 42px;
		height: 42px;
		justify-content: center;
		border: 1px solid var(--sm-border);
		border-radius: 8px;
		background: #ffffff;
	}

	.sm-site-header__login span {
		position: absolute;
		width: 1px;
		height: 1px;
		overflow: hidden;
		clip: rect(0 0 0 0);
		white-space: nowrap;
	}

	.sm-site-header__login-icon {
		display: block;
	}

	.sm-site-header__auth .sm-site-header__cta {
		display: none;
	}

	.sm-site-header__toggle {
		display: inline-flex;
		flex-direction: column;
		gap: 5px;
	}

	.sm-site-header.is-menu-open .sm-site-header__toggle-bar:nth-child(1) {
		transform: translateY(7px) rotate(45deg);
	}

	.sm-site-header.is-menu-open .sm-site-header__toggle-bar:nth-child(2) {
		opacity: 0;
	}

	.sm-site-header.is-menu-open .sm-site-header__toggle-bar:nth-child(3) {
		transform: translateY(-7px) rotate(-45deg);
	}

	.sm-site-header__nav {
		display: none;
		grid-column: 1 / -1;
		grid-row: 2;
		align-items: stretch;
		flex-direction: column;
		gap: 4px;
		justify-content: flex-start;
		width: 100%;
		padding-top: 14px;
		border-top: 1px solid var(--sm-border);
	}

	.sm-site-header.is-menu-open .sm-site-header__nav {
		display: flex;
	}

	.sm-site-header__nav-item {
		width: 100%;
	}

	.sm-site-header__nav a,
	.sm-site-header__nav-toggle {
		display: flex;
		align-items: center;
		min-height: 42px;
	}

	.sm-site-header__nav-toggle {
		justify-content: space-between;
		width: 100%;
	}

	.sm-site-header__nav-menu {
		position: static;
		min-width: 0;
		margin: 0 0 6px;
		padding: 2px 0 4px 14px;
		border: 0;
		border-left: 2px solid var(--sm-border);
		border-radius: 0;
		background: transparent;
		box-shadow: none;
	}

	.sm-site-header__nav-menu a {
		min-height: 38px;
		padding: 7px 0;
	}

	.sm-site-header__nav .sm-site-header__cta {
		justify-content: center;
		margin-top: 6px;
	}

	.sm-site-header__nav-auth {
		display: flex;
		flex-direction: column;
		align-items: center;
		gap: 10px;
		margin-top: 10px;
	}

	.sm-site-header__nav-cta {
		display: flex;
		justify-content: center;
		width: 100%;
	}

	.sm-site-header__nav-login-link {
		display: block;
		font-size: 14px;
		font-weight: 600;
		color: var(--sm-primary);
		text-decoration: none;
		text-align: center;
	}

	.sm-site-header__nav-login-link:hover {
		text-decoration: underline;
	}

	.sm-card-grid--3,
	.sm-card-grid--4,
	.sm-auth-grid,
	.sm-business-hero__grid,
	.sm-pricing-cards,
	.sm-business-steps,
	.sm-split {
		grid-template-columns: 1fr;
	}

	.sm-auth-hero {
		padding: 56px 0;
	}

	.sm-business-hero {
		padding: 56px 0;
	}

	.sm-pricing-hero {
		padding: 56px 0 36px;
	}

	.sm-pricing-card,
	.sm-pricing-note {
		padding: 24px;
	}

	.sm-result-card {
		flex-direction: column;
		gap: 16px;
	}

	.sm-business-profile-service__actions,
	.sm-business-profile-service__actions .sm-btn {
		width: 100%;
	}

	.sm-business-profile-hero__title {
		font-size: 32px;
	}

	.sm-filter-bar__change {
		margin-left: 0;
		width: 100%;
		justify-content: center;
	}
}

@media (max-width: 640px) {
	.sm-results-intro {
		padding: 28px 0 24px;
	}

	.sm-filter-bar__field {
		width: 100%;
	}

	.sm-filter-bar__inner {
		flex-direction: column;
		align-items: stretch;
	}
}

/* ??? Single Listing Page ?????????????????????????????????? */

.sm-listing-page {
	background: var(--sm-bg);
	color: var(--sm-text);
}

.sm-listing-hero {
	padding: 56px 0 44px;
	background: linear-gradient(135deg, #eef2ff 0%, #f7f8fc 60%, #ffffff 100%);
	border-bottom: 1px solid var(--sm-border);
}

/* On mobile (single column), extend hero bg flush to viewport edges */
@media (max-width: 899px) {
	.sm-listing-hero {
		margin: 0 -16px;
		padding-left: 16px;
		padding-right: 16px;
	}
}

.sm-listing-hero__badges {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-bottom: 18px;
}

.sm-listing-hero__badges .sm-badge {
	margin-bottom: 0;
}

.sm-listing-hero__title {
	margin: 0 0 16px;
	font-size: clamp(28px, 4vw, 44px);
	line-height: 1.1;
	color: var(--sm-text);
}

.sm-listing-hero__title-row {
	display: flex;
	align-items: flex-start;
	flex-wrap: nowrap;
	gap: 12px;
	margin-bottom: 16px;
}

.sm-listing-hero__title-row .sm-listing-hero__title {
	min-width: 0;
	flex: 0 1 auto;
	margin-bottom: 0;
}

.sm-listing-hero__business {
	margin: 0;
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 8px;
	font-size: 15px;
	color: var(--sm-muted);
}

.sm-listing-hero__business-link {
	color: var(--sm-primary);
	font-weight: 700;
	text-decoration: none;
}

.sm-listing-hero__business-link:hover {
	text-decoration: underline;
}

.sm-listing-hero__location {
	max-width: 720px;
	margin-top: 14px;
	padding: 10px 12px;
	border: 1px solid var(--sm-border);
	border-radius: 14px;
	background: #ffffff;
}

.sm-listing-hero__communication {
	max-width: 720px;
	margin-top: 14px;
	padding: 10px 12px;
	border: 1px solid var(--sm-border);
	border-radius: 14px;
	background: #ffffff;
}

.sm-listing-hero__location-summary,
.sm-listing-hero__communication-summary {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	width: 100%;
	color: var(--sm-text);
	font-size: 14px;
	font-weight: 700;
	cursor: pointer;
	list-style: none;
}

.sm-listing-hero__location-summary::-webkit-details-marker,
.sm-listing-hero__communication-summary::-webkit-details-marker {
	display: none;
}

.sm-listing-hero__location-summary::after,
.sm-listing-hero__communication-summary::after {
	content: "";
	width: 8px;
	height: 8px;
	flex: 0 0 8px;
	border-right: 2px solid currentColor;
	border-bottom: 2px solid currentColor;
	transform: rotate(45deg) translateY(-2px);
	transition: transform 0.15s ease;
}

.sm-listing-hero__location[open] .sm-listing-hero__location-summary::after,
.sm-listing-hero__communication[open] .sm-listing-hero__communication-summary::after {
	transform: rotate(225deg) translate(-1px, -1px);
}

.sm-listing-hero__location-summary-label,
.sm-listing-hero__communication-summary-label {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	min-width: 0;
}

.sm-listing-hero__location-summary-label > span,
.sm-listing-hero__communication-summary-label > span:not(.sm-listing-hero__communication-voice) {
	min-width: 0;
	overflow-wrap: anywhere;
}

.sm-listing-hero__location-icon {
	width: 20px;
	height: 20px;
	color: var(--sm-primary);
	flex-shrink: 0;
}

.sm-listing-hero__communication-icon {
	width: 20px;
	height: 20px;
	margin-top: 1px;
	color: var(--sm-primary);
	flex-shrink: 0;
}

.sm-listing-hero__communication-voice-icon {
	width: 17px;
	height: 17px;
	flex: 0 0 17px;
	color: var(--sm-primary);
}

.sm-listing-hero__communication-voice {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 auto;
}

.sm-listing-hero__location-list {
	display: flex;
	flex-direction: column;
	gap: 4px;
	margin-top: 10px;
}

.sm-listing-hero__communication-list {
	display: flex;
	flex-direction: column;
	gap: 4px;
	margin-top: 10px;
}

.sm-listing-hero__location-list p {
	margin: 0;
	color: var(--sm-muted);
	font-size: 14px;
	font-weight: 700;
}

.sm-listing-hero__communication-list p {
	margin: 0;
	color: var(--sm-muted);
	font-size: 14px;
	font-weight: 700;
}

.sm-listing-hero__communication-row {
	display: inline-flex;
	align-items: center;
	gap: 6px;
}

.sm-listing-hero__voice-icon {
	width: 16px;
	height: 16px;
	flex: 0 0 16px;
	color: var(--sm-primary);
}

.sm-listing-hero__location-list strong {
	color: var(--sm-text);
	font-weight: 700;
}

.sm-listing-hero__communication-list strong {
	color: var(--sm-text);
	font-weight: 700;
}

.sm-listing-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 22px;
}

.sm-listing-favorite-form {
	margin: 0;
}

.sm-listing-favorite-form--icon {
	display: inline-flex;
	flex: 0 0 auto;
}

.sm-listing-favorite-form .sm-btn {
	cursor: pointer;
	font-family: inherit;
}

.sm-listing-favorite-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 auto;
	width: 42px;
	height: 42px;
	padding: 0;
	border: 1px solid var(--sm-border);
	border-radius: 999px;
	background: #ffffff;
	color: var(--sm-primary, #4f46e5);
	cursor: pointer;
	font: inherit;
	text-decoration: none;
	transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease, transform 0.15s ease;
}

.sm-listing-favorite-icon:hover,
.sm-listing-favorite-icon:focus-visible {
	border-color: var(--sm-primary);
	background: var(--sm-surface-alt);
	color: var(--sm-primary-dark);
	text-decoration: none;
	transform: translateY(-1px);
}

.sm-listing-favorite-icon--small {
	width: 34px;
	height: 34px;
	flex-shrink: 0;
}

.sm-listing-favorite-icon.is-active {
	border-color: #f9a8d4;
	background: #fff1f2;
	color: #e11d48;
}

.sm-listing-favorite-icon__svg {
	display: block;
	width: 21px;
	height: 21px;
	color: currentColor;
}

.sm-listing-favorite-icon__state {
	display: none;
	line-height: 0;
}

.sm-listing-favorite-icon:not(.is-active) .sm-listing-favorite-icon__state--outline,
.sm-listing-favorite-icon.is-active .sm-listing-favorite-icon__state--solid {
	display: block;
}

.sm-listing-favorite-icon--small .sm-listing-favorite-icon__svg {
	width: 18px;
	height: 18px;
}

.sm-history-confirm[hidden],
.sm-auth-prompt[hidden],
.sm-pricing-modal[hidden],
.sm-feedback-prompt[hidden] {
	display: none;
}

.sm-history-confirm,
.sm-auth-prompt,
.sm-pricing-modal,
.sm-feedback-prompt {
	position: fixed;
	inset: 0;
	z-index: 2200;
	display: grid;
	place-items: center;
	padding: 18px;
}

.sm-history-confirm__backdrop,
.sm-auth-prompt__backdrop,
.sm-pricing-modal__backdrop,
.sm-feedback-prompt__backdrop {
	position: absolute;
	inset: 0;
	background: rgba(15, 23, 42, 0.5);
}

.sm-history-confirm__dialog,
.sm-auth-prompt__dialog,
.sm-pricing-modal__dialog,
.sm-feedback-prompt__dialog {
	position: relative;
	width: min(420px, 100%);
	padding: 22px;
	border: 1px solid var(--sm-border);
	border-radius: 16px;
	background: #ffffff;
	box-shadow: 0 24px 70px rgba(15, 23, 42, 0.24);
}

.sm-history-confirm__title,
.sm-auth-prompt__title,
.sm-pricing-modal__title,
.sm-feedback-prompt__title {
	margin: 0 0 8px;
	color: var(--sm-text);
	font-size: 20px;
	line-height: 1.25;
}

.sm-history-confirm__message,
.sm-auth-prompt__message,
.sm-pricing-modal__message,
.sm-feedback-prompt__message {
	margin: 0;
	color: var(--sm-muted);
	font-size: 15px;
	line-height: 1.6;
}

.sm-history-confirm__actions,
.sm-auth-prompt__actions,
.sm-pricing-modal__actions,
.sm-feedback-prompt__actions {
	display: flex;
	justify-content: flex-end;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 20px;
}

.sm-feedback-prompt__actions a.sm-btn--primary,
.sm-feedback-prompt__actions a.sm-btn--primary:visited,
.sm-feedback-prompt__actions a.sm-btn--primary:hover,
.sm-feedback-prompt__actions a.sm-btn--primary:focus {
	color: #ffffff !important;
}

@media (max-width: 480px) {
	.sm-feedback-prompt__actions {
		flex-direction: column-reverse;
	}

	.sm-feedback-prompt__actions .sm-btn {
		width: 100%;
		justify-content: center;
	}
}

.sm-history-confirm__submit {
	border-color: #111827;
	background: #111827;
	color: #ffffff;
}

.sm-listing-notice {
	max-width: 720px;
	margin: 18px 0 0;
	padding: 12px 16px;
	border-radius: 10px;
	font-size: 14px;
	font-weight: 700;
}

.sm-listing-notice--success {
	background: #f0fdf4;
	border: 1px solid #bbf7d0;
	color: #166534;
}

/* ?? Single listing: page-level 2-col layout when gallery present ???????? */
@media (min-width: 900px) {
	.sm-listing-wrap--has-gallery {
		display: grid;
		grid-template-columns: 1fr 1fr;
		gap: 0 40px;
		align-items: start;
	}
}

/* Text body below hero meta */
.sm-listing-body-section {
	padding: 32px 0;
}

.sm-listing-content {
	max-width: 720px;
}

.sm-listing-wrap--has-gallery .sm-listing-content {
	max-width: none;
}

/* Gallery right column - starts at top of grid on desktop */
.sm-listing-gallery-col {
	padding: 24px 0;
}

@media (min-width: 900px) {
	.sm-listing-gallery-col {
		padding-top: 56px; /* match sm-listing-hero top padding */
		padding-bottom: 0;
	}
}

.sm-listing-gallery-col .sm-listing-gallery {
	columns: 1;
	column-gap: 0;
	margin-top: 0;
}

@media (min-width: 900px) {
	.sm-listing-gallery-col .sm-listing-gallery {
		columns: 2;
		column-gap: 8px;
	}
}

.sm-listing-price-line {
	margin-top: 14px;
	font-size: 15px;
	font-weight: 600;
	color: #1c2440;
}

.sm-listing-price-line__label {
	font-weight: 400;
	color: #6b7280;
}

.sm-listing-price-line__note {
	margin: 4px 0 0;
	font-size: 13px;
	color: #6b7280;
}

.sm-listing-price-line__list-link {
	display: inline-block;
	margin-top: 6px;
	font-size: 14px;
	color: var(--sm-primary, #4f46e5);
	text-decoration: underline;
}

.sm-business-services__price,
.sm-business-profile-service__price {
	color: #15803d;
	font-weight: 600;
}

/* ??? Service location badge ??????????????????????????????? */

.sm-location-badge {
	display: inline-flex;
	align-items: center;
	gap: 3px;
	font-size: 11px;
	font-weight: 500;
	color: #374151;
	background: #f3f4f6;
	border: 1px solid #e5e7eb;
	border-radius: 4px;
	padding: 2px 7px;
	margin-top: 4px;
}

.sm-location-badge--wide {
	color: #1d4ed8;
	background: #eff6ff;
	border-color: #bfdbfe;
}

.sm-location-badge__icon {
	width: 12px;
	height: 12px;
	flex-shrink: 0;
	vertical-align: middle;
}

.sm-result-card__location-icon {
	width: 14px;
	height: 14px;
	flex-shrink: 0;
	opacity: 0.7;
}

.sm-listing-event-cta {
	margin: 26px 0 18px;
	padding: 0;
	border: 0;
	border-radius: 0;
	background: transparent;
}

.sm-listing-event-cta__button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	min-height: 44px;
	padding: 11px 18px;
	border-radius: 10px;
	background: var(--sm-primary);
	color: #ffffff;
	font-weight: 700;
	text-decoration: none;
}

.sm-listing-event-cta__icon {
	width: 20px;
	height: 20px;
	flex: 0 0 20px;
}

.sm-listing-event-cta__button:hover,
.sm-listing-event-cta__button:focus-visible {
	background: var(--sm-primary-dark);
	color: #ffffff;
}

.sm-contact-heading-row {
	display: block;
	width: min(100%, 420px);
	margin: 0 0 12px;
}

.sm-contact-heading-row .sm-contact-heading {
	margin: 0 !important;
}

.sm-contact-heading {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	min-width: 0;
	flex-wrap: nowrap;
	vertical-align: middle;
}

.sm-contact-heading__icon {
	width: 20px;
	height: 20px;
	flex: 0 0 20px;
	color: var(--sm-primary);
}

.sm-contact-intro {
	position: relative;
}

.sm-contact-intro__trigger {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 24px;
	width: 24px;
	height: 24px;
	padding: 0;
	border: 0;
	border-radius: 999px;
	appearance: none;
	background: transparent;
	color: var(--sm-muted);
	cursor: pointer;
	font: inherit;
	transition: color 0.15s ease, transform 0.15s ease;
}

.sm-contact-intro__icon {
	width: 20px;
	height: 20px;
}

.sm-contact-intro__text {
	display: none;
	width: 100%;
	margin: 6px 0 0;
	padding: 10px 12px;
	border: 1px solid var(--sm-border);
	border-radius: 10px;
	background: #ffffff;
	box-sizing: border-box;
	box-shadow: 0 12px 28px rgba(15, 23, 42, 0.12);
	color: var(--sm-muted);
	font-size: 13px;
	line-height: 1.45;
}

.sm-contact-intro__trigger:hover,
.sm-contact-intro__trigger:focus-visible,
.sm-contact-intro.is-open .sm-contact-intro__trigger {
	color: var(--sm-primary);
	transform: scale(1.04);
}

.sm-contact-intro:hover .sm-contact-intro__text,
.sm-contact-intro:focus-within .sm-contact-intro__text,
.sm-contact-intro.is-open .sm-contact-intro__text {
	display: block;
}

@media (max-width: 640px) {
	.sm-contact-heading-row {
		width: 100%;
	}
}

.sm-public-review-list {
	display: grid;
	gap: 14px;
}

@media (min-width: 1024px) {
	.sm-public-review-list {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (min-width: 640px) and (max-width: 1023px) {
	.sm-public-review-list {
		grid-template-columns: repeat(2, 1fr);
	}
}

.sm-public-review-card__top {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 16px;
}

.sm-public-review-card h3 {
	margin: 0 0 4px;
	font-size: 17px;
	color: var(--sm-text);
}

.sm-public-review-card__service-link {
	color: var(--sm-primary);
	text-decoration: none;
}

.sm-public-review-card__service-link:hover,
.sm-public-review-card__service-link:focus-visible {
	color: var(--sm-primary-dark);
	text-decoration: underline;
}

.sm-public-review-card__top p,
.sm-public-review-card__date {
	margin: 0;
	color: var(--sm-muted);
	font-size: 14px;
}

.sm-public-review-card__text {
	margin: 14px 0 10px;
	color: var(--sm-text);
	line-height: 1.65;
}

.sm-user-card__title--icon {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

.sm-user-card__title-icon {
	width: 18px;
	height: 18px;
	color: #e11d48;
	flex-shrink: 0;
}

/* ??? Voice Translator Badge ??????????????????????????????? */

.sm-voice-translator-badge {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	padding: 4px 10px 4px 7px;
	background: linear-gradient(135deg, #e0e7ff 0%, #ede9fe 100%);
	border: 1px solid rgba(99, 102, 241, 0.25);
	border-radius: 999px;
	font-size: 12px;
	color: #4338ca;
	font-weight: 500;
	box-sizing: border-box;
	max-width: 100%;
	white-space: normal;
}

.sm-voice-translator-badge__icon {
	width: 13px;
	height: 13px;
	fill: #6366f1;
	flex-shrink: 0;
	stroke: none;
}

/* ??? Search Form Checkbox ????????????????????????????????? */

.sm-field-checkbox {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 0;
	font-size: 14px;
	color: var(--sm-text);
	cursor: pointer;
	line-height: 1.4;
}

.sm-field-checkbox input[type="checkbox"] {
	width: 16px;
	height: 16px;
	min-height: 16px;
	margin: 0;
	flex-shrink: 0;
	cursor: pointer;
	accent-color: var(--sm-primary);
}

.sm-filter-bar__checkbox-field {
	display: flex;
	align-items: center;
	padding: 4px 0;
}

.sm-filter-bar__checkbox-wrap {
	display: flex;
	flex-direction: column;
	gap: 4px;
	max-width: 320px;
}

.sm-filter-bar__hint {
	margin: 0;
	color: var(--sm-muted);
	font-size: 12px;
	line-height: 1.45;
}

/* ?? Business Cabinet: generic confirm modal ??????????????????????????????? */

.sm-confirm-modal[hidden] {
	display: none;
}

.sm-confirm-modal {
	position: fixed;
	inset: 0;
	z-index: 2200;
	display: grid;
	place-items: center;
	padding: 18px;
	box-sizing: border-box;
}

.sm-confirm-modal__overlay {
	position: absolute;
	inset: 0;
	background: rgba(15, 23, 42, 0.5);
}

.sm-confirm-modal__dialog {
	position: relative;
	box-sizing: border-box;
	width: min(420px, calc(100vw - 32px));
	max-width: 100%;
	padding: 22px;
	border: 1px solid var(--sm-border);
	border-radius: 16px;
	background: #ffffff;
	box-shadow: 0 24px 70px rgba(15, 23, 42, 0.24);
}

.sm-confirm-modal__title {
	margin: 0 0 8px;
	color: var(--sm-text);
	font-size: 20px;
	line-height: 1.25;
}

.sm-confirm-modal__message {
	margin: 0;
	color: var(--sm-muted);
	font-size: 15px;
	line-height: 1.6;
}

.sm-confirm-modal__actions {
	display: flex;
	justify-content: flex-end;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 20px;
}

.sm-confirm-modal__confirm--primary {
	border-color: var(--sm-primary, #4f46e5);
	background: var(--sm-primary, #4f46e5);
	color: #ffffff;
}

.sm-confirm-modal__confirm--neutral,
.sm-confirm-modal__confirm--warning {
	border-color: #111827;
	background: #111827;
	color: #ffffff;
}

.sm-confirm-modal__confirm--danger {
	border-color: #dc2626;
	background: #dc2626;
	color: #ffffff;
}

@media (max-width: 480px) {
	.sm-confirm-modal__actions {
		flex-direction: column-reverse;
	}

	.sm-confirm-modal__actions .sm-btn {
		width: 100%;
		text-align: center;
		justify-content: center;
	}
}

/* ?? Post-registration welcome ?????????????????????????????????????????????? */

@keyframes sm-toast-in {
	from { opacity: 0; transform: translateX(-50%) translateY(16px); }
	to   { opacity: 1; transform: translateX(-50%) translateY(0); }
}
@keyframes sm-toast-out {
	from { opacity: 1; transform: translateX(-50%) translateY(0); }
	to   { opacity: 0; transform: translateX(-50%) translateY(16px); }
}

.sm-reg-toast {
	position: fixed;
	bottom: 24px;
	left: 50%;
	transform: translateX(-50%);
	z-index: 9999;
	display: flex;
	align-items: flex-start;
	gap: 10px;
	width: min(420px, calc(100vw - 32px));
	padding: 16px 16px 16px 20px;
	background: #ffffff;
	border: 1px solid #bbf7d0;
	border-radius: 16px;
	box-shadow: 0 8px 32px rgba(15, 23, 42, 0.14);
	animation: sm-toast-in 0.3s ease;
}

.sm-reg-toast--out {
	animation: sm-toast-out 0.4s ease forwards;
}

.sm-reg-toast__body {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.sm-reg-toast__msg {
	margin: 0;
	font-size: 14px;
	color: var(--sm-text);
	line-height: 1.45;
}

.sm-reg-toast__btn {
	align-self: flex-start;
	font-size: 13px;
	padding: 8px 16px;
}

.sm-reg-toast__close {
	flex-shrink: 0;
	width: 28px;
	height: 28px;
	padding: 0;
	border: none;
	background: none;
	color: var(--sm-muted);
	font-size: 22px;
	line-height: 1;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-top: -2px;
}

/* Pulse ring on the account toggle button */
@keyframes sm-account-pulse {
	0%   { box-shadow: 0 0 0 0 rgba(99, 102, 241, 0.6); }
	70%  { box-shadow: 0 0 0 10px rgba(99, 102, 241, 0); }
	100% { box-shadow: 0 0 0 0 rgba(99, 102, 241, 0); }
}

.sm-account-pulse {
	animation: sm-account-pulse 0.9s ease 4;
}

/* ?? Lead success toast ????????????????????????????????????????????????????? */

.sm-lead-toast {
	position: fixed;
	bottom: 24px;
	left: 50%;
	transform: translateX(-50%);
	z-index: 9999;
	width: min(420px, calc(100vw - 32px));
	padding: 14px 20px;
	background: #ffffff;
	border: 1px solid #bbf7d0;
	border-radius: 12px;
	box-shadow: 0 8px 32px rgba(15, 23, 42, 0.14);
	font-size: 14px;
	color: var(--sm-text);
	line-height: 1.45;
	animation: sm-toast-in 0.3s ease;
}

.sm-lead-toast a {
	color: var(--sm-primary, #4f46e5);
	text-decoration: underline;
	margin-left: 4px;
}

.sm-lead-toast--out {
	animation: sm-toast-out 0.4s ease forwards;
}

/* Burger-nav auth row - visible only in mobile nav, hidden on desktop */
@media (min-width: 921px) {
	.sm-site-header__nav-auth,
	.sm-site-header__nav-login-link,
	.sm-site-header__nav-cta {
		display: none;
	}
}

/* Nav dropdown link icons - indigo-400, lighter than text for harmony */
.sm-site-header__nav-menu a .sm-site-header__nav-link-icon,
.sm-site-header__account-menu .sm-site-header__nav-link-icon,
.sm-site-header__login-icon {
	color: #818cf8;
}

/* Ensure mobile "Create account" CTA text is white over primary bg */
.sm-site-header__nav-cta {
	color: #ffffff !important;
}

/* Password show/hide wrapper */
.sm-pw-wrap {
	position: relative;
	display: flex;
	align-items: center;
}
.sm-pw-wrap .input {
	width: 100%;
	padding-right: 42px;
}
.sm-pw-toggle {
	position: absolute;
	right: 10px;
	top: 50%;
	transform: translateY(-50%);
	display: flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	padding: 0;
	border: none;
	background: transparent;
	color: #94a3b8;
	cursor: pointer;
	border-radius: 4px;
	transition: color 0.15s ease;
}
.sm-pw-toggle:hover,
.sm-pw-toggle:focus {
	color: #4f46e5;
	outline: none;
}
.sm-pw-toggle svg {
	width: 20px;
	height: 20px;
	flex-shrink: 0;
}

/* Footer Legal & policies popup - centered on small screens */
@media (max-width: 640px) {
	.sm-site-footer__group--legal .sm-site-footer__group-menu {
		position: fixed;
		left: 50%;
		bottom: auto;
		top: 50%;
		transform: translate(-50%, -50%);
		width: max-content;
		max-width: calc(100vw - 32px);
		max-height: 70vh;
		overflow-y: auto;
		z-index: 200;
		box-shadow: 0 24px 60px rgba(15, 23, 42, 0.28);
	}
}

/* ?? Listing gallery (masonry) ??????????????????????????????????????????????? */
.sm-section--gallery {
	padding: 0 0 40px;
}
.sm-listing-gallery {
	columns: 2;
	column-gap: 10px;
	margin-top: 0;
}
.sm-listing-gallery__item {
	display: block;
	break-inside: avoid;
	margin-bottom: 10px;
	border-radius: 8px;
	overflow: hidden;
	cursor: zoom-in;
}
.sm-listing-gallery__img {
	display: block;
	width: 100%;
	height: auto;
	transition: transform 0.2s;
}
.sm-listing-gallery__item:hover .sm-listing-gallery__img {
	transform: scale(1.03);
}
@media (min-width: 640px) {
	.sm-listing-gallery {
		columns: 3;
	}
}

/* ?? Gallery lightbox ???????????????????????????????????????????????????????? */
.sm-gallery-lightbox {
	position: fixed;
	inset: 0;
	width: 100%;
	height: 100%;
	max-width: 100%;
	max-height: 100%;
	background: rgba(0, 0, 0, 0.88);
	border: none;
	padding: 0;
	margin: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 9999;
}
.sm-gallery-lightbox:not([open]) {
	display: none;
}
.sm-gallery-lightbox__inner {
	max-width: 92vw;
	max-height: 88vh;
	display: flex;
	align-items: center;
	justify-content: center;
	touch-action: pan-y;
}
.sm-gallery-lightbox__img {
	max-width: 100%;
	max-height: 88vh;
	object-fit: contain;
	border-radius: 6px;
	display: block;
}
.sm-gallery-lightbox__close {
	position: fixed;
	top: 16px;
	right: 20px;
	background: none;
	border: none;
	color: #fff;
	cursor: pointer;
	padding: 4px;
	opacity: 0.8;
	display: flex;
	align-items: center;
	justify-content: center;
}
.sm-gallery-lightbox__close:hover {
	opacity: 1;
}
.sm-gallery-lightbox__nav {
	position: fixed;
	top: 50%;
	transform: translateY(-50%);
	background: rgba(255,255,255,0.12);
	border: none;
	color: #fff;
	cursor: pointer;
	padding: 8px 14px;
	border-radius: 6px;
	opacity: 0.75;
	display: flex;
	align-items: center;
	justify-content: center;
}
.sm-gallery-lightbox__icon {
	width: 28px;
	height: 28px;
	display: block;
	flex-shrink: 0;
}
.sm-gallery-lightbox__nav:hover {
	opacity: 1;
	background: rgba(255,255,255,0.22);
}
.sm-gallery-lightbox__nav--prev {
	left: 12px;
}
.sm-gallery-lightbox__nav--next {
	right: 12px;
}

/* -- Leads: hidden-contact button (looks like a text link) ------------------- */
.sm-leads-hidden-contact-btn {
	display: inline;
	appearance: none;
	background: none;
	border: none;
	padding: 0;
	margin: 0;
	font: inherit;
	font-size: 13px;
	color: var(--sm-primary, #4f46e5);
	cursor: pointer;
	text-decoration: underline;
	text-underline-offset: 2px;
	line-height: inherit;
}
.sm-leads-hidden-contact-btn:hover,
.sm-leads-hidden-contact-btn:focus-visible {
	color: var(--sm-primary-dark, #3730a3);
	outline: none;
}
.sm-leads-hidden-contact-btn:focus-visible {
	outline: 2px solid var(--sm-primary, #4f46e5);
	outline-offset: 2px;
	border-radius: 2px;
}

/* -- Leads: Premium popup body paragraphs ------------------------------------ */
.sm-leads-premium-popup__body {
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.sm-leads-premium-popup__body p {
	margin: 0;
}
.sm-leads-premium-popup .sm-confirm-modal__actions {
	flex-direction: column-reverse;
}
.sm-leads-premium-popup .sm-confirm-modal__actions .sm-btn {
	width: 100%;
	text-align: center;
	text-decoration: none;
}
.sm-leads-premium-popup__learn-more {
	margin: 14px 0 0;
	font-size: 13px;
	color: var(--sm-muted, #5f6b8a);
}
.sm-leads-premium-popup__learn-more-link {
	color: inherit;
}

/* Popup-frame mode: hide site chrome when loaded inside iframe */
body.sm-popup-frame #wpadminbar,
body.sm-popup-frame .sm-site-header,
body.sm-popup-frame .sm-site-footer {
	display: none !important;
}
body.sm-popup-frame {
	padding-top: 0 !important;
}

/* ?? 404 / Not-found page ??????????????????????????????????????????????????? */

.sm-error-page {
	display: flex;
	justify-content: center;
	align-items: center;
	min-height: 55vh;
	padding: 3rem 1.5rem;
}

.sm-error-page__inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1.25rem;
	text-align: center;
	max-width: 480px;
	width: 100%;
}

.sm-error-page__logo {
	width: 160px;
	height: auto;
	display: block;
}

.sm-error-page__icon {
	width: 64px;
	height: 64px;
	color: var(--sm-primary);
	flex-shrink: 0;
}

.sm-error-page__heading {
	font-size: 1.5rem;
	font-weight: 700;
	margin: 0;
	color: var(--sm-text);
}

.sm-error-page__description {
	font-size: 1rem;
	color: var(--sm-muted);
	margin: 0;
	line-height: 1.6;
}

.sm-error-page__actions {
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
	justify-content: center;
	margin-top: 0.5rem;
}

@media (max-width: 480px) {
	.sm-error-page__actions {
		flex-direction: column;
		width: 100%;
	}

	.sm-error-page__actions .sm-btn {
		width: 100%;
		justify-content: center;
	}
}

/* ?? Astra scroll-to-top: replicate Astra styling on service-layout pages ?? */
#ast-scroll-top {
	position: fixed !important;
	right: 30px;
	bottom: 30px;
	z-index: 99;
	width: 2.1em;
	height: 2.1em;
	font-size: 15px;
	line-height: 2.1;
	text-align: center;
	cursor: pointer;
	color: #ffffff;
	background-color: #060097;
	border-radius: 2px;
	display: none;
}

#ast-scroll-top .ast-arrow-svg {
	transform: rotate(180deg);
	width: 14px;
	height: auto;
	vertical-align: middle;
	fill: #ffffff;
}

#ast-scroll-top .ast-arrow-svg path {
	fill: #ffffff;
}
