@font-face {
	font-family: "Vlasne Inter";
	font-style: normal;
	font-weight: 100 900;
	font-display: swap;
	src: url("../fonts/inter/Inter-VariableFont_wght.ttf") format("truetype");
}

:root {
	--vl-red: #d90812;
	--vl-red-soft: rgba(217, 8, 18, 0.07);
	--vl-black: #08090a;
	--vl-muted: #222428;
	--vl-border: #d5d6d8;
	--vl-header-height: 68px;
}

body {
	margin: 0;
	padding: 0 !important;
	background: #fff;
	color: var(--vl-black);
}

.wp-site-blocks {
	padding: 0 !important;
}

body.elementor-page-20 .elementor > .elementor-element.vl-page,
.elementor > .elementor-element.vl-page {
	width: 100% !important;
	max-width: none !important;
	margin: 0;
	padding: 0;
}

body.elementor-page-20 .vl-page .elementor-widget-container,
.vl-page .elementor-widget-container {
	margin: 0;
	padding: 0;
}

.vl-page,
.vl-page * {
	box-sizing: border-box;
}

.vl-page {
	min-height: 100vh;
	overflow: hidden;
	color: var(--vl-black);
	font-family: "Vlasne Inter", Arial, sans-serif;
	-webkit-font-smoothing: antialiased;
}

.vl-page a {
	color: inherit;
	text-decoration: none;
}

.vl-page a:focus-visible {
	outline: 2px solid var(--vl-red);
	outline-offset: 4px;
}

.vl-header {
	position: relative;
	z-index: 20;
	height: var(--vl-header-height);
	border-bottom: 1px solid #e6e6e6;
	background: #fff;
}

.vl-header__inner {
	position: relative;
	z-index: 1;
	display: flex;
	align-items: center;
	height: 100%;
	padding-left: max(38px, calc((100vw - 1572px) / 2));
	padding-right: max(38px, calc((100vw - 1554px) / 2));
}

.vl-brand {
	display: inline-flex;
	flex: 0 0 auto;
	align-items: center;
	gap: 20px;
	font-size: 31px;
	font-weight: 735;
	letter-spacing: -0.065em;
	line-height: 1;
	transition: color 0.24s ease, transform 0.24s ease;
}

.vl-brand__mark {
	display: block;
	width: 34px;
	height: 43px;
	fill: var(--vl-red);
	transition: transform 0.28s ease;
}

.vl-brand:hover,
.vl-brand:focus-visible {
	color: var(--vl-red);
	transform: translateY(-1px);
}

.vl-brand:hover .vl-brand__mark,
.vl-brand:focus-visible .vl-brand__mark {
	transform: scale(1.06);
}

.vl-nav {
	display: flex;
	gap: 38px;
	align-items: center;
	margin-left: clamp(72px, 10vw, 150px);
	font-size: 16.5px;
	font-weight: 520;
	letter-spacing: -0.025em;
}

.vl-nav a {
	position: relative;
	padding: 9px 0;
	transition: color 0.2s ease, transform 0.2s ease;
}

.vl-nav a::after {
	position: absolute;
	right: 0;
	bottom: 2px;
	left: 0;
	height: 2px;
	background: var(--vl-red);
	content: "";
	transform: scaleX(0);
	transform-origin: center;
	transition: transform 0.22s ease;
}

.vl-nav a:hover,
.vl-nav a:focus-visible {
	color: var(--vl-red);
	transform: translateY(-1px);
}

.vl-nav a:hover::after,
.vl-nav a:focus-visible::after {
	transform: scaleX(1);
}

.vl-contact {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: auto;
	min-width: 0;
	height: 44px;
	margin-left: auto;
	padding: 0 13px 0 17px;
	border: 1.5px solid var(--vl-red);
	border-radius: 12px;
	box-sizing: border-box;
	background: #fff;
	font-size: 15.5px;
	font-weight: 600;
	letter-spacing: 0;
	overflow: hidden;
	transition: color 0.24s ease, background-color 0.24s ease, box-shadow 0.24s ease, transform 0.24s ease;
	white-space: nowrap;
}

.vl-contact svg {
	width: 18px;
	height: 18px;
	fill: none;
	stroke: var(--vl-red);
	stroke-width: 2.6;
	stroke-linecap: square;
	stroke-linejoin: miter;
	transition: stroke 0.24s ease, transform 0.24s ease;
}

.vl-contact:hover,
.vl-contact:focus-visible {
	background: var(--vl-red);
	box-shadow: 0 12px 22px rgba(217, 8, 18, 0.18);
	color: #fff;
	transform: translateY(-2px);
}

.vl-contact:hover svg,
.vl-contact:focus-visible svg {
	stroke: #fff;
	transform: translate(2px, -2px);
}

.vl-main {
	position: relative;
	z-index: 0;
	overflow: hidden;
	padding: 54px max(42px, calc((100% - 1472px) / 2)) 34px;
}

.vl-orbits {
	position: absolute;
	z-index: 0;
	top: -9px;
	right: -157px;
	width: 500px;
	height: 324px;
	border: 1px solid #e6e6e6;
	border-radius: 50%;
	pointer-events: none;
}

.vl-orbits::before {
	position: absolute;
	top: -126px;
	right: 70px;
	width: 484px;
	height: 391px;
	border: 1px solid #e6e6e6;
	border-radius: 50%;
	content: "";
}

.vl-orbits::after {
	position: absolute;
	top: 205px;
	left: 65px;
	width: 17px;
	height: 17px;
	border-radius: 50%;
	background: var(--vl-red);
	content: "";
}

.vl-dots {
	position: absolute;
	z-index: 0;
	top: 76px;
	right: 456px;
	width: 112px;
	height: 105px;
	background-image: radial-gradient(circle, var(--vl-red) 2.5px, transparent 3px);
	background-position: 0 0;
	background-size: 24px 24px;
	pointer-events: none;
}

.vl-intro,
.vl-cards,
.vl-benefits {
	position: relative;
	z-index: 1;
}

.vl-kicker {
	display: flex;
	align-items: center;
	gap: 18px;
	height: 22px;
	margin: 0 0 20px;
	font-size: 16.5px;
	font-weight: 530;
	letter-spacing: -0.025em;
}

.vl-kicker span {
	display: inline-block;
	width: 26px;
	height: 3px;
	background: var(--vl-red);
}

.vl-intro h1 {
	max-width: 820px;
	margin: 0 0 22px;
	font-size: clamp(47px, 3.54vw, 59.5px);
	font-weight: 705;
	letter-spacing: -0.064em;
	line-height: 0.98;
}

.vl-lead {
	margin: 0;
	color: var(--vl-muted);
	font-size: 17.5px;
	font-weight: 450;
	letter-spacing: -0.035em;
	line-height: 1.42;
}

.vl-cards {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) minmax(0, 1.072fr);
	gap: 36px;
	max-width: 1440px;
	margin-top: 38px;
}

.vl-card {
	position: relative;
	height: 369px;
	padding: 25px 27px 28px;
	border: 1px solid var(--vl-border);
	border-radius: 16px;
	background: #fff;
	transition: border-color 0.24s ease, box-shadow 0.24s ease, transform 0.24s ease;
}

.vl-card:hover {
	border-color: var(--vl-red);
	box-shadow: 0 15px 34px rgba(18, 18, 18, 0.07);
	transform: translateY(-5px);
}

.vl-icon-circle {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100px;
	height: 100px;
	border-radius: 50%;
	background: var(--vl-red-soft);
	transition: background-color 0.24s ease, transform 0.24s ease;
}

.vl-card:hover .vl-icon-circle {
	background: rgba(217, 8, 18, 0.12);
	transform: scale(1.04);
}

.vl-icon-circle svg {
	width: 61px;
	height: 61px;
	fill: none;
	stroke: var(--vl-red);
	stroke-width: 2.8;
	stroke-linecap: round;
	stroke-linejoin: round;
}

.vl-icon-circle .vl-icon-fill {
	fill: var(--vl-red);
	stroke: none;
}

.vl-icon-circle .vl-icon-stroke {
	fill: none;
	stroke: var(--vl-red);
	stroke-width: 4.5;
}

.vl-card__dash {
	display: block;
	width: 44px;
	height: 2px;
	margin: 14px 0 18px;
	background: var(--vl-red);
}

.vl-card h2 {
	margin: 0 0 10px;
	font-size: clamp(25px, 1.82vw, 29.5px);
	font-weight: 700;
	letter-spacing: -0.058em;
	line-height: 1.12;
}

.vl-card p {
	margin: 0;
	color: var(--vl-muted);
	font-size: 17.2px;
	font-weight: 450;
	letter-spacing: -0.04em;
	line-height: 1.39;
}

.vl-more {
	position: absolute;
	bottom: 28px;
	left: 27px;
	display: inline-flex;
	align-items: center;
	justify-content: space-between;
	width: 199px;
	height: 45px;
	padding: 0 18px 0 21px;
	border-radius: 8px;
	background: var(--vl-red);
	color: #fff !important;
	font-size: 14.5px;
	font-weight: 610;
	letter-spacing: -0.035em;
	transition: background-color 0.22s ease, box-shadow 0.22s ease, transform 0.22s ease;
}

.vl-more svg {
	width: 21px;
	height: 21px;
	fill: none;
	stroke: #fff;
	stroke-width: 2;
	stroke-linecap: round;
	stroke-linejoin: round;
	transition: transform 0.22s ease;
}

.vl-more:hover,
.vl-more:focus-visible {
	background: #b90009;
	box-shadow: 0 11px 22px rgba(217, 8, 18, 0.24);
	transform: translateY(-2px);
}

.vl-more:hover svg,
.vl-more:focus-visible svg {
	transform: translateX(5px);
}

.vl-more:active,
.vl-contact:active {
	box-shadow: none;
	transform: translateY(0);
}

.vl-benefits {
	display: grid;
	grid-template-columns: 338px 405px 379px minmax(0, 1fr);
	max-width: 1440px;
	margin-top: 51px;
}

.vl-benefit {
	display: flex;
	align-items: center;
	gap: 20px;
	min-height: 53px;
	padding-left: 25px;
	border-left: 1px solid #dbdbdb;
	transition: color 0.22s ease, transform 0.22s ease;
}

.vl-benefit:first-child {
	padding-left: 22px;
	border-left: 0;
}

.vl-benefit:nth-child(2),
.vl-benefit:nth-child(3) {
	padding-left: 60px;
}

.vl-benefit:nth-child(4) {
	padding-left: 51px;
}

.vl-benefit svg {
	flex: 0 0 52px;
	width: 52px;
	height: 52px;
	fill: none;
	stroke: var(--vl-red);
	stroke-width: 2.5;
	stroke-linecap: round;
	stroke-linejoin: round;
	transition: transform 0.22s ease;
}

.vl-benefit:hover {
	color: var(--vl-red);
	transform: translateY(-2px);
}

.vl-benefit:hover svg {
	transform: scale(1.07);
}

.vl-benefit p {
	display: grid;
	gap: 5px;
	margin: 0;
	font-size: 15.5px;
	font-weight: 440;
	letter-spacing: -0.03em;
	line-height: 1.18;
}

.vl-benefit strong {
	font-size: 16.6px;
	font-weight: 560;
}

.vl-contact-plaque-widget {
	position: relative;
	z-index: 1;
	width: 100% !important;
	margin-top: 36px !important;
}

.vl-contacts-page {
	min-height: calc(100vh - var(--vl-header-height));
}

.vl-contacts-main {
	min-height: calc(100vh - var(--vl-header-height));
	padding-top: 76px;
}

.vl-contacts-page .vl-intro {
	max-width: 840px;
}

.vl-contacts-page .vl-contact-plaque-widget {
	margin-top: 48px !important;
}

.vl-contacts-page .vl-contact-plaque {
	max-width: 620px;
	grid-template-columns: 1fr;
}

.vl-contact-plaque {
	display: grid;
	grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
	gap: 18px;
	max-width: 960px;
}

.vl-contact-plaque__link {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 22px;
	min-height: 76px;
	padding: 18px 22px;
	border: 1px solid var(--vl-border);
	border-radius: 12px;
	background: #fff;
	color: var(--vl-black);
	text-decoration: none;
	transition: border-color 0.22s ease, box-shadow 0.22s ease, color 0.22s ease, transform 0.22s ease;
}

.vl-contact-plaque__link:hover,
.vl-contact-plaque__link:focus-visible {
	border-color: var(--vl-red);
	box-shadow: 0 14px 26px rgba(217, 8, 18, 0.12);
	color: var(--vl-red);
	transform: translateY(-2px);
}

.vl-contact-plaque__text {
	display: grid;
	gap: 5px;
	min-width: 0;
}

.vl-contact-plaque__label {
	color: var(--vl-red);
	font-size: 13px;
	font-weight: 740;
	letter-spacing: 0;
	line-height: 1;
	text-transform: uppercase;
}

.vl-contact-plaque__value {
	font-size: 20px;
	font-weight: 650;
	letter-spacing: 0;
	line-height: 1.16;
	overflow-wrap: anywhere;
}

.vl-contact-plaque__arrow {
	display: none;
}

.vl-contact-plaque__link::after {
	flex: 0 0 auto;
	color: var(--vl-red);
	content: "\2197";
	font-family: Arial, sans-serif;
	font-size: 22px;
	font-weight: 300;
	line-height: 1;
	transform: translateY(-1px);
	transition: color 0.22s ease, transform 0.22s ease;
}

.vl-contact-plaque__link:hover::after,
.vl-contact-plaque__link:focus-visible::after {
	transform: translate(2px, -3px);
}

.vl-map-card {
	position: relative;
	z-index: 1;
	display: grid;
	gap: 18px;
	max-width: 1060px;
	margin-top: 24px;
}

.vl-map-frame {
	position: relative;
	width: 100%;
	aspect-ratio: 16 / 8;
	min-height: 360px;
	overflow: hidden;
	border: 1px solid var(--vl-border);
	border-radius: 12px;
	background: #f6f6f6;
	box-shadow: 0 18px 38px rgba(18, 18, 18, 0.06);
}

.vl-map-frame iframe {
	display: block;
	width: 100%;
	height: 100%;
	border: 0;
}

.vl-map-actions {
	display: flex;
}

.vl-map-link {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	min-height: 44px;
	padding: 0 18px;
	border-radius: 8px;
	background: var(--vl-red);
	color: #fff;
	font-size: 15px;
	font-weight: 650;
	letter-spacing: 0;
	text-decoration: none;
	transition: background-color 0.22s ease, box-shadow 0.22s ease, transform 0.22s ease;
}

.vl-map-link::after {
	color: #fff;
	content: "\2197";
	font-family: Arial, sans-serif;
	font-size: 20px;
	font-weight: 300;
	line-height: 1;
	transform: translateY(-1px);
	transition: transform 0.22s ease;
}

.vl-map-link:hover::after,
.vl-map-link:focus-visible::after {
	transform: translate(2px, -3px);
}

.vl-map-link:hover,
.vl-map-link:focus-visible {
	background: #b90009;
	box-shadow: 0 12px 22px rgba(217, 8, 18, 0.2);
	color: #fff;
	transform: translateY(-2px);
}

.vl-profile-grid {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 24px;
	max-width: 1440px;
	margin-top: 52px;
}

.vl-profile-card {
	position: relative;
	display: grid;
	grid-template-columns: auto minmax(0, 1fr);
	gap: 42px;
	min-height: 518px;
	padding: 31px;
	border: 1px solid var(--vl-border);
	border-radius: 16px;
	background: #fff;
	overflow: hidden;
	transition: border-color 0.24s ease, box-shadow 0.24s ease, transform 0.24s ease;
}

.vl-profile-card:hover {
	border-color: var(--vl-red);
	box-shadow: 0 15px 34px rgba(18, 18, 18, 0.07);
	transform: translateY(-5px);
}

.vl-profile-avatar {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 112px;
	height: 112px;
	border: 1px solid rgba(217, 8, 18, 0.24);
	border-radius: 50%;
	background: var(--vl-red-soft);
	color: var(--vl-red);
	font-size: 30px;
	font-weight: 760;
	letter-spacing: 0;
	line-height: 1;
}

.vl-profile-photo {
	width: 132px;
	aspect-ratio: 3 / 4;
	margin: 0;
	overflow: hidden;
	border: 1px solid rgba(217, 8, 18, 0.2);
	border-radius: 16px;
	background: var(--vl-red-soft);
}

.vl-profile-photo img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center 35%;
}

.vl-profile-content {
	min-width: 0;
}

.vl-profile-name .elementor-heading-title,
.vl-profile-name h3 {
	margin: 0 0 8px;
	color: var(--vl-black) !important;
	font-size: clamp(24px, 1.7vw, 31px);
	font-weight: 720;
	letter-spacing: 0;
	line-height: 1.12;
}

.vl-profile-copy p {
	margin: 0 0 13px;
	color: var(--vl-muted);
	font-size: 15.8px;
	font-weight: 430;
	letter-spacing: 0;
	line-height: 1.48;
}

.vl-profile-copy p:last-child {
	margin-bottom: 0;
}

.vl-profile-copy .vl-profile-role {
	margin-bottom: 17px;
	color: var(--vl-red);
	font-size: 16.2px;
	font-weight: 700;
	line-height: 1.35;
}

.vl-profile-card--empty {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 360px;
	background: #fcfcfc;
}

.vl-profile-card--empty:hover {
	border-color: var(--vl-border);
	box-shadow: none;
	transform: none;
}

.vl-profile-empty-shape {
	position: relative;
	width: min(72%, 320px);
	height: 188px;
	border: 1px dashed rgba(217, 8, 18, 0.28);
	border-radius: 16px;
	background: linear-gradient(#fff, #fff) padding-box;
}

.vl-profile-empty-shape::before {
	position: absolute;
	top: 31px;
	left: 50%;
	width: 86px;
	height: 86px;
	border: 1px solid rgba(217, 8, 18, 0.22);
	border-radius: 50%;
	background: var(--vl-red-soft);
	content: "";
	transform: translateX(-50%);
}

.vl-profile-empty-shape::after {
	position: absolute;
	right: 36px;
	bottom: 33px;
	left: 36px;
	height: 30px;
	border-top: 1px solid rgba(8, 9, 10, 0.11);
	border-bottom: 1px solid rgba(8, 9, 10, 0.08);
	content: "";
}

/* Elementor widget structure. All copy remains editable in the visual editor. */
.vl-page.e-con,
.vl-page .e-con {
	--widgets-spacing: 0px 0px;
	gap: 0 !important;
	margin: 0;
}

.vl-page.e-con {
	display: flex !important;
	flex-direction: column !important;
	padding: 0 !important;
}

.vl-page .elementor-widget {
	margin: 0;
	max-width: none;
}

.vl-header.e-con {
	position: relative !important;
	z-index: 20 !important;
	display: block !important;
	flex: 0 0 var(--vl-header-height) !important;
	height: var(--vl-header-height) !important;
	width: 100% !important;
	padding: 0 !important;
}

.vl-header__inner.e-con {
	display: flex !important;
	align-items: center !important;
	flex-direction: row !important;
	flex-wrap: nowrap !important;
	height: var(--vl-header-height) !important;
	width: 100% !important;
	padding: 0 max(38px, calc((100vw - 1554px) / 2)) 0 max(38px, calc((100vw - 1572px) / 2)) !important;
}

.vl-brand.e-con {
	display: flex !important;
	flex: 0 0 auto !important;
	flex-direction: row !important;
	gap: 0 !important;
	width: auto !important;
	padding: 0 !important;
}

.vl-brand-icon,
.vl-brand-text {
	flex: 0 0 auto !important;
	width: auto !important;
}

.vl-brand-icon {
	line-height: 0;
}

.vl-brand-logo-link {
	display: block;
	width: 226px;
	line-height: 0;
}

.vl-brand-logo {
	display: block;
	width: 100%;
	height: auto;
	max-height: 58px;
	object-fit: contain;
}

.vl-brand-text {
	display: none !important;
}

.vl-brand-text .elementor-heading-title {
	color: var(--vl-black) !important;
	font-size: inherit;
	font-weight: inherit;
	letter-spacing: inherit;
	line-height: inherit;
}

.vl-nav.e-con {
	display: flex !important;
	flex: 0 0 auto !important;
	flex-direction: row !important;
	flex-wrap: nowrap !important;
	gap: 38px !important;
	margin-left: clamp(72px, 10vw, 150px) !important;
	width: auto !important;
	padding: 0 !important;
}

.vl-nav-item {
	flex: 0 0 auto !important;
	width: auto !important;
}

.vl-nav-item .elementor-button {
	padding: 9px 0 !important;
	background: transparent !important;
	border-radius: 0;
	color: var(--vl-black) !important;
	font: inherit;
}

.vl-nav-item .elementor-button:hover,
.vl-nav-item .elementor-button:focus-visible {
	color: var(--vl-red) !important;
}

.vl-contact {
	display: block;
	flex: 0 0 auto !important;
	width: auto !important;
	min-width: 0;
	height: 44px;
	margin-left: auto !important;
	padding: 0;
	border: 0;
	background: none;
}

.vl-contact .elementor-button {
	position: relative;
	z-index: 2;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: 100%;
	height: 100%;
	padding: 0 13px 0 17px !important;
	border: 1.5px solid var(--vl-red);
	border-radius: 12px;
	background: #fff !important;
	color: var(--vl-black) !important;
	font: inherit;
	letter-spacing: 0;
	white-space: nowrap;
	transition: color 0.24s ease, background-color 0.24s ease, box-shadow 0.24s ease, transform 0.24s ease;
}

.vl-contact .elementor-button::after {
	color: var(--vl-red);
	content: "\2197";
	font-family: Arial, sans-serif;
	font-size: 22px;
	font-weight: 300;
	line-height: 1;
	transition: color 0.24s ease, transform 0.24s ease;
}

.vl-contact:hover {
	background: none;
	box-shadow: none;
	transform: none;
}

.vl-contact .elementor-button:hover,
.vl-contact .elementor-button:focus-visible {
	background: var(--vl-red) !important;
	box-shadow: 0 12px 22px rgba(217, 8, 18, 0.18);
	color: #fff !important;
	transform: translateY(-2px);
}

.vl-contact .elementor-button:hover::after,
.vl-contact .elementor-button:focus-visible::after {
	color: #fff;
	transform: translate(2px, -2px);
}

.vl-template-header {
	width: 100%;
	color: var(--vl-black);
	font-family: "Vlasne Inter", Arial, sans-serif;
	-webkit-font-smoothing: antialiased;
}

.vl-template-header * {
	box-sizing: border-box;
}

.vl-template-header a {
	color: inherit;
	text-decoration: none;
}

.vl-template-header a:focus-visible {
	outline: 2px solid var(--vl-red);
	outline-offset: 4px;
}

.vl-template-contact {
	position: relative;
	z-index: 2;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 auto;
	gap: 8px;
	width: auto;
	min-width: 0;
	height: 44px;
	margin-left: auto;
	padding: 0 13px 0 17px;
	border: 1.5px solid var(--vl-red);
	border-radius: 12px;
	background: #fff;
	box-sizing: border-box;
	color: var(--vl-black);
	font-size: 15.5px;
	font-weight: 600;
	letter-spacing: 0;
	overflow: hidden;
	transition: color 0.24s ease, background-color 0.24s ease, box-shadow 0.24s ease, transform 0.24s ease;
	white-space: nowrap;
}

.vl-template-contact .vl-contact-arrow {
	display: none;
}

.vl-template-contact::after {
	color: var(--vl-red);
	content: "\2197";
	font-family: Arial, sans-serif;
	font-size: 22px;
	font-weight: 300;
	line-height: 1;
	transform: translateY(-1px);
	transition: color 0.24s ease, transform 0.24s ease;
}

.vl-template-contact:hover,
.vl-template-contact:focus-visible {
	background: var(--vl-red);
	box-shadow: 0 12px 22px rgba(217, 8, 18, 0.18);
	color: #fff;
	transform: translateY(-2px);
}

.vl-template-contact:hover::after,
.vl-template-contact:focus-visible::after {
	color: #fff;
	transform: translate(2px, -2px);
}

.vl-main.e-con {
	position: relative !important;
	z-index: 0 !important;
	display: block !important;
	width: 100% !important;
	padding: 54px max(42px, calc((100% - 1472px) / 2)) 34px !important;
}

.vl-orbits-widget,
.vl-dots-widget {
	height: 0;
}

.vl-intro.e-con {
	display: block !important;
	width: auto !important;
	padding: 0 !important;
}

.vl-kicker {
	height: auto;
	margin: 0 0 20px !important;
}

.vl-kicker p {
	display: flex;
	align-items: center;
	gap: 18px;
	height: 22px;
	margin: 0;
	font-size: 16.5px;
	font-weight: 530;
	letter-spacing: -0.025em;
	color: var(--vl-black) !important;
}

.vl-kicker p::before {
	display: inline-block;
	width: 26px;
	height: 3px;
	background: var(--vl-red);
	content: "";
}

.vl-media-page .vl-kicker p {
	display: block;
}

.vl-media-page .vl-kicker p::before {
	display: none;
}

.vl-media-page .vl-kicker a {
	display: inline-flex;
	align-items: center;
	gap: 14px;
	color: var(--vl-black);
	transition: color 0.22s ease, transform 0.22s ease;
}

.vl-media-page .vl-kicker a::before {
	display: inline-flex;
	align-items: center;
	color: var(--vl-red);
	content: "\2190";
	font-size: 25px;
	font-weight: 300;
	line-height: 1;
	transform: translateY(-1px);
	transition: transform 0.22s ease;
}

.vl-media-page .vl-kicker a:hover,
.vl-media-page .vl-kicker a:focus-visible {
	color: var(--vl-red);
	transform: translateY(-1px);
}

.vl-media-page .vl-kicker a:hover::before,
.vl-media-page .vl-kicker a:focus-visible::before {
	transform: translate(-4px, -1px);
}

.vl-title h1 {
	max-width: 820px;
	margin: 0 0 22px;
	font-size: clamp(47px, 3.54vw, 59.5px);
	font-weight: 705;
	letter-spacing: -0.064em;
	line-height: 0.98;
	color: var(--vl-black) !important;
}

.vl-lead {
	margin: 0;
}

.vl-lead p {
	margin: 0;
	color: var(--vl-muted);
	font-size: 17.5px;
	font-weight: 450;
	letter-spacing: -0.035em;
	line-height: 1.42;
}

.vl-cards.e-con {
	display: grid !important;
	gap: 36px !important;
	margin-top: 38px !important;
	width: 100% !important;
	padding: 0 !important;
}

.vl-card.e-con {
	display: block !important;
	width: auto !important;
	height: 369px !important;
	padding: 25px 27px 28px !important;
}

.vl-card-icon {
	height: 100px;
}

.vl-card-dash {
	height: 34px;
}

.vl-card-title .elementor-heading-title {
	margin: 0 0 10px;
	font-size: clamp(25px, 1.82vw, 29.5px);
	font-weight: 700;
	letter-spacing: -0.058em;
	line-height: 1.12;
	color: var(--vl-black) !important;
}

.vl-card-copy p {
	margin: 0;
	color: var(--vl-muted);
	font-size: 17.2px;
	font-weight: 450;
	letter-spacing: -0.04em;
	line-height: 1.39;
}

.vl-more {
	position: absolute !important;
	bottom: 28px !important;
	left: 27px !important;
	width: 199px !important;
	padding: 0;
	background: none;
}

.vl-more .elementor-button {
	display: inline-flex;
	align-items: center;
	justify-content: space-between;
	width: 199px;
	height: 45px;
	padding: 0 18px 0 21px !important;
	border-radius: 8px;
	background: var(--vl-red) !important;
	color: #fff !important;
	font-size: 14.5px;
	font-weight: 610;
	letter-spacing: -0.035em;
	transition: background-color 0.22s ease, box-shadow 0.22s ease, transform 0.22s ease;
}

.vl-more .elementor-button::after {
	content: "\2192";
	font-size: 25px;
	font-weight: 300;
	line-height: 1;
	transform: translateY(-2px);
	transition: transform 0.22s ease;
}

.vl-more:hover {
	background: none;
	box-shadow: none;
	transform: none;
}

.vl-more .elementor-button:hover,
.vl-more .elementor-button:focus-visible {
	background: #b90009 !important;
	box-shadow: 0 11px 22px rgba(217, 8, 18, 0.24);
	transform: translateY(-2px);
}

.vl-more .elementor-button:hover::after,
.vl-more .elementor-button:focus-visible::after {
	transform: translate(5px, -2px);
}

.vl-benefits.e-con {
	display: grid !important;
	margin-top: 51px !important;
	width: 100% !important;
	padding: 0 !important;
}

.vl-benefit.e-con {
	display: flex !important;
	flex-direction: row !important;
	gap: 26px !important;
	width: auto !important;
}

.vl-benefit-icon {
	flex: 0 0 52px !important;
	width: 52px !important;
}

.vl-benefit-copy.e-con {
	display: flex !important;
	flex: 0 0 auto !important;
	flex-direction: column !important;
	gap: 5px !important;
	width: auto !important;
	padding: 0 !important;
}

.vl-benefit-title .elementor-heading-title {
	color: var(--vl-black) !important;
	font-size: 16.6px;
	font-weight: 560;
	letter-spacing: -0.03em;
	line-height: 1.18;
}

.vl-benefit-description p {
	margin: 0;
	font-size: 15.5px;
	font-weight: 440;
	letter-spacing: -0.03em;
	line-height: 1.18;
}

.vl-profile-grid.e-con {
	display: grid !important;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 24px !important;
	margin-top: 52px !important;
	width: 100% !important;
	padding: 0 !important;
}

.vl-profile-card.e-con {
	display: grid !important;
	grid-template-columns: auto minmax(0, 1fr);
	gap: 42px !important;
	width: auto !important;
	padding: 31px !important;
}

.vl-profile-card--empty.e-con {
	display: flex !important;
}

.vl-profile-avatar-widget,
.vl-profile-media-widget,
.vl-profile-empty-widget {
	width: auto !important;
}

.vl-profile-content.e-con {
	display: block !important;
	width: auto !important;
	padding: 0 !important;
}

/* Media page. */
.vl-media-main.e-con {
	display: block !important;
	width: 100% !important;
	min-height: calc(100vh - var(--vl-header-height));
	overflow: hidden;
	padding: 56px max(42px, calc((100% - 1472px) / 2)) 58px !important;
}

.vl-media-hero.e-con {
	display: block !important;
	width: auto !important;
	padding: 0 !important;
}

.vl-media-title .elementor-heading-title {
	max-width: 850px;
	margin: 0 0 20px;
	color: var(--vl-black) !important;
	font-size: clamp(45px, 3.5vw, 58px);
	font-weight: 705;
	letter-spacing: -0.064em;
	line-height: 1.01;
}

.vl-media-lead p {
	max-width: 530px;
	margin: 0;
	color: var(--vl-muted);
	font-size: 17.5px;
	font-weight: 450;
	letter-spacing: -0.035em;
	line-height: 1.42;
}

.vl-media-tabs.e-con {
	display: flex !important;
	flex-direction: row !important;
	gap: 12px !important;
	width: auto !important;
	margin-top: 43px !important;
	padding: 0 !important;
}

.vl-media-tab {
	width: auto !important;
}

.vl-media-tab .elementor-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 51px;
	padding: 0 29px !important;
	border: 1px solid var(--vl-border);
	border-radius: 12px;
	background: #fff !important;
	color: var(--vl-black) !important;
	font-size: 16px;
	font-weight: 560;
	letter-spacing: -0.03em;
	transition: border-color 0.22s ease, background-color 0.22s ease, color 0.22s ease, transform 0.22s ease;
}

.vl-media-tab .elementor-button-content-wrapper,
.vl-media-tab .elementor-button-text {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 100%;
	line-height: 1;
}

.vl-media-tab.is-active .elementor-button,
.vl-media-tab .elementor-button:hover,
.vl-media-tab .elementor-button:focus-visible {
	border-color: var(--vl-red);
	background: var(--vl-red) !important;
	color: #fff !important;
	transform: translateY(-2px);
}

.vl-media-panels.e-con {
	display: block !important;
	width: auto !important;
	margin-top: 27px !important;
	padding: 0 !important;
}

.vl-media-scroll-controls {
	display: none;
	justify-content: flex-end;
	gap: 10px;
	margin: 0 0 16px;
}

.vl-media-scroll-controls.is-active.has-overflow {
	display: flex;
}

.vl-media-scroll-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	border: 1px solid var(--vl-border);
	border-radius: 50%;
	background: #fff;
	color: var(--vl-red);
	font-size: 26px;
	font-weight: 300;
	line-height: 1;
	cursor: pointer;
	transition: border-color 0.22s ease, background-color 0.22s ease, color 0.22s ease, transform 0.22s ease;
}

.vl-media-scroll-button:hover:not(:disabled),
.vl-media-scroll-button:focus-visible:not(:disabled) {
	border-color: var(--vl-red);
	background: var(--vl-red);
	color: #fff;
	transform: translateY(-2px);
}

.vl-media-scroll-button:disabled {
	opacity: 0.35;
	cursor: default;
}

.vl-media-panel.e-con {
	display: none !important;
	flex-direction: row !important;
	flex-wrap: nowrap !important;
	gap: 26px !important;
	width: auto !important;
	overflow-x: auto;
	padding: 0 !important;
	scroll-snap-type: x mandatory;
	scrollbar-width: none;
	-webkit-overflow-scrolling: touch;
}

.vl-media-panel.e-con::-webkit-scrollbar {
	display: none;
}

.vl-media-panel.is-active.e-con {
	display: flex !important;
}

.vl-media-story.e-con {
	position: relative;
	display: flex !important;
	flex: 0 0 calc((100% - 52px) * 0.295) !important;
	flex-direction: column !important;
	gap: 0 !important;
	min-height: 294px;
	padding: 28px 28px 27px !important;
	border: 1px solid var(--vl-border);
	border-radius: 16px;
	background: #fff;
	scroll-snap-align: start;
	transition: border-color 0.24s ease, box-shadow 0.24s ease, transform 0.24s ease;
}

.vl-media-story:hover {
	border-color: var(--vl-red);
	box-shadow: 0 15px 34px rgba(18, 18, 18, 0.07);
	transform: translateY(-5px);
}

.vl-media-story--telegram {
	cursor: pointer;
}

.vl-media-story--telegram:focus-visible {
	outline: 2px solid var(--vl-red);
	outline-offset: 4px;
}

.vl-media-story--notice.e-con {
	flex-basis: min(720px, 100%) !important;
}

.vl-media-story--notice .vl-media-summary p {
	max-width: 560px;
}

.vl-media-story--featured.e-con {
	flex-basis: calc((100% - 52px) * 0.41) !important;
	min-height: 324px;
	padding: 33px 33px 31px !important;
	border-color: var(--vl-red);
}

.vl-media-label p {
	display: flex;
	align-items: center;
	gap: 13px;
	margin: 0 0 25px;
	color: var(--vl-red);
	font-size: 13.5px;
	font-weight: 610;
	letter-spacing: -0.02em;
	text-transform: uppercase;
}

.vl-media-label p::before {
	width: 26px;
	height: 2px;
	background: var(--vl-red);
	content: "";
}

.vl-media-story-title .elementor-heading-title {
	margin: 0 0 11px;
	color: var(--vl-black) !important;
	font-size: clamp(22px, 1.72vw, 28px);
	font-weight: 680;
	letter-spacing: -0.055em;
	line-height: 1.14;
}

.vl-media-story--featured .vl-media-story-title .elementor-heading-title {
	font-size: clamp(29px, 2.2vw, 36px);
	line-height: 1.11;
}

.vl-media-summary p {
	margin: 0 0 30px;
	color: var(--vl-muted);
	font-size: 15.8px;
	font-weight: 430;
	letter-spacing: -0.03em;
	line-height: 1.4;
}

.vl-media-story--featured .vl-media-summary p {
	max-width: 530px;
	font-size: 17px;
}

.vl-media-read {
	width: auto !important;
	margin-top: auto !important;
}

.vl-media-read .elementor-button {
	display: inline-flex;
	align-items: center;
	gap: 20px;
	padding: 0 !important;
	background: transparent !important;
	color: var(--vl-red) !important;
	font-size: 14.5px;
	font-weight: 620;
	letter-spacing: -0.03em;
}

.vl-media-read .elementor-button::after {
	content: "\2192";
	font-size: 25px;
	font-weight: 300;
	line-height: 1;
	transform: translateY(-2px);
	transition: transform 0.22s ease;
}

.vl-media-read .elementor-button:hover::after,
.vl-media-read .elementor-button:focus-visible::after {
	transform: translate(5px, -2px);
}

.vl-media-signup.e-con {
	display: flex !important;
	flex-direction: row !important;
	align-items: center !important;
	justify-content: space-between !important;
	gap: 30px !important;
	margin-top: 39px !important;
	padding: 29px 33px !important;
	border: 1px solid #ececed;
	border-radius: 16px;
}

.vl-media-signup-copy.e-con {
	display: block !important;
	width: auto !important;
	padding: 0 !important;
}

.vl-media-signup-title .elementor-heading-title {
	margin: 0 0 5px;
	color: var(--vl-black) !important;
	font-size: 24px;
	font-weight: 680;
	letter-spacing: -0.05em;
	line-height: 1.16;
}

.vl-media-signup-text p {
	margin: 0;
	color: var(--vl-muted);
	font-size: 15.5px;
	letter-spacing: -0.03em;
}

.vl-media-signup-button {
	flex: 0 0 199px !important;
	width: 199px !important;
}

.vl-media-signup-button .elementor-button {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 199px;
	height: 45px;
	padding: 0 18px 0 21px !important;
	border-radius: 8px;
	background: var(--vl-red) !important;
	color: #fff !important;
	font-size: 14.5px;
	font-weight: 610;
	letter-spacing: -0.035em;
}

.vl-media-signup-button .elementor-button::after {
	content: "\2192";
	font-size: 25px;
	line-height: 1;
	transform: translateY(-2px);
}

.vl-media-signup-button .elementor-button:hover,
.vl-media-signup-button .elementor-button:focus-visible {
	background: #b90009 !important;
	transform: translateY(-2px);
}

/* Telegram story pages. */
.vl-story-body {
	margin: 0;
	background: #fff;
	color: var(--vl-black);
	font-family: Inter, Arial, sans-serif;
}

.vl-story-header {
	display: flex;
	align-items: center;
	box-sizing: border-box;
	justify-content: space-between;
	flex-wrap: nowrap;
	gap: 0;
	width: 100%;
	height: var(--vl-header-height);
	min-height: var(--vl-header-height);
	padding: 0 max(38px, calc((100vw - 1554px) / 2)) 0 max(38px, calc((100vw - 1572px) / 2));
	border-bottom: 1px solid #ededed;
	background: #fff;
}

.vl-story-logo-link {
	display: block;
	flex: 0 0 auto;
	width: 226px;
	line-height: 0;
	text-decoration: none;
}

.vl-story-logo {
	display: block;
	width: 100%;
	height: auto;
	max-height: 58px;
	object-fit: contain;
}

.vl-story-nav {
	display: flex;
	align-items: center;
	flex: 0 0 auto;
	flex-wrap: nowrap;
	gap: 38px;
	margin-left: clamp(72px, 10vw, 150px);
}

.vl-story-nav a,
.vl-story-contact,
.vl-story-back,
.vl-story-button {
	color: var(--vl-black);
	font-size: 15px;
	font-weight: 680;
	letter-spacing: -0.03em;
	text-decoration: none;
}

.vl-story-nav a:hover,
.vl-story-nav a:focus-visible,
.vl-story-back:hover,
.vl-story-back:focus-visible {
	color: var(--vl-red);
}

.vl-story-contact {
	position: relative;
	z-index: 2;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 auto;
	gap: 8px;
	width: auto;
	min-width: 0;
	height: 44px;
	margin-left: auto;
	padding: 0 13px 0 17px;
	border: 1.5px solid var(--vl-red);
	border-radius: 12px;
	background: #fff;
	box-sizing: border-box;
	letter-spacing: 0;
	transition: color 0.24s ease, background-color 0.24s ease, box-shadow 0.24s ease, transform 0.24s ease;
	white-space: nowrap;
}

.vl-story-contact::after {
	color: var(--vl-red);
	content: "\2197";
	font-family: Arial, sans-serif;
	font-size: 22px;
	font-weight: 300;
	line-height: 1;
	transition: color 0.24s ease, transform 0.24s ease;
}

.vl-story-contact:hover,
.vl-story-contact:focus-visible {
	background: var(--vl-red);
	box-shadow: 0 12px 22px rgba(217, 8, 18, 0.18);
	color: #fff;
	transform: translateY(-2px);
}

.vl-story-contact:hover::after,
.vl-story-contact:focus-visible::after {
	color: #fff;
	transform: translate(2px, -2px);
}

.vl-story-page {
	position: relative;
	min-height: calc(100vh - var(--vl-header-height));
	overflow: hidden;
	padding: 58px max(42px, calc((100% - 1472px) / 2)) 70px;
}

.vl-story-page::before,
.vl-story-page::after {
	position: absolute;
	z-index: 0;
	border: 1px solid rgba(8, 9, 10, 0.08);
	border-radius: 50%;
	content: "";
	pointer-events: none;
}

.vl-story-page::before {
	top: -86px;
	right: 96px;
	width: 470px;
	height: 330px;
	transform: rotate(9deg);
}

.vl-story-page::after {
	top: 76px;
	right: -34px;
	width: 520px;
	height: 300px;
	transform: rotate(-8deg);
}

.vl-story-back {
	position: relative;
	z-index: 1;
	display: inline-flex;
	margin-bottom: 30px;
}

.vl-story-shell {
	position: relative;
	z-index: 1;
	max-width: 980px;
	padding: 46px 48px 48px;
	border: 1px solid var(--vl-red);
	border-radius: 16px;
	background: #fff;
}

.vl-story-meta {
	display: flex;
	align-items: center;
	gap: 14px;
	margin-bottom: 28px;
	color: var(--vl-red);
	font-size: 14px;
	font-weight: 700;
	letter-spacing: -0.02em;
	text-transform: uppercase;
}

.vl-story-meta span {
	width: 30px;
	height: 2px;
	background: var(--vl-red);
}

.vl-story-shell h1 {
	max-width: 850px;
	margin: 0 0 26px;
	color: var(--vl-black);
	font-size: clamp(38px, 4.4vw, 64px);
	font-weight: 740;
	letter-spacing: -0.064em;
	line-height: 1.04;
}

.vl-story-source {
	margin: -8px 0 22px;
	color: var(--vl-red);
	font-size: 16px;
	font-weight: 720;
	letter-spacing: -0.02em;
}

.vl-story-content {
	max-width: 760px;
	color: var(--vl-muted);
	font-size: 20px;
	font-weight: 470;
	letter-spacing: -0.035em;
	line-height: 1.48;
}

.vl-story-content p {
	margin: 0 0 18px;
}

.vl-story-content a {
	color: var(--vl-red);
	font-weight: 650;
}

.vl-story-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
	margin-top: 40px;
}

.vl-story-button {
	display: inline-flex;
	align-items: center;
	gap: 28px;
	min-height: 48px;
	padding: 0 23px;
	border-radius: 8px;
	background: var(--vl-red);
	color: #fff;
}

.vl-story-button:hover,
.vl-story-button:focus-visible {
	background: #b90009;
	color: #fff;
	transform: translateY(-2px);
}

@media (max-width: 1020px) {
	.vl-header.e-con {
		flex-basis: auto !important;
		height: auto !important;
	}

	.vl-header__inner.e-con {
		flex-wrap: wrap !important;
		gap: 22px !important;
		height: auto !important;
		min-height: 82px;
		padding-block: 18px !important;
	}

	.vl-nav.e-con {
		order: 3;
		gap: 28px !important;
		width: 100% !important;
		margin-left: 0 !important;
		overflow-x: auto;
		padding-top: 4px !important;
		border-top: 1px solid #ededed;
	}

	.vl-media-main.e-con {
		padding-top: 45px !important;
		padding-inline: 32px !important;
	}

	.vl-media-tabs.e-con {
		overflow-x: auto;
		flex-wrap: nowrap !important;
		padding-bottom: 8px !important;
		scrollbar-width: thin;
		-webkit-overflow-scrolling: touch;
	}

	.vl-media-tab {
		flex: 0 0 auto !important;
	}

	.vl-media-panel.is-active.e-con {
		gap: 18px !important;
		padding-bottom: 12px !important;
	}

	.vl-media-scroll-controls.is-active.has-overflow {
		display: none;
	}

	.vl-media-story.e-con {
		flex: 0 0 min(78vw, 470px) !important;
		width: min(78vw, 470px) !important;
		scroll-snap-align: start;
	}

	.vl-media-story--featured.e-con {
		flex-basis: min(86vw, 540px) !important;
		width: min(86vw, 540px) !important;
	}

	.vl-media-signup.e-con {
		flex-direction: column !important;
		align-items: flex-start !important;
	}
}

@media (max-width: 700px) {
	.vl-media-main.e-con {
		padding: 38px 22px 45px !important;
	}

	.vl-media-title .elementor-heading-title {
		font-size: clamp(36px, 11vw, 46px);
	}

	.vl-media-tabs.e-con {
		margin-top: 33px !important;
	}

	.vl-media-tab .elementor-button {
		min-height: 47px;
		padding-inline: 24px !important;
	}

	.vl-media-story.e-con {
		flex-basis: 72vw !important;
		width: 72vw !important;
		min-height: 300px;
	}

	.vl-media-story--featured.e-con {
		flex-basis: 76vw !important;
		width: 76vw !important;
	}
}

@media (max-width: 1420px) {
	.vl-header__inner {
		padding-inline: 36px;
	}

	.vl-story-header {
		padding-inline: 36px;
	}

	.vl-brand {
		font-size: 28px;
	}

	.vl-brand-logo-link,
	.vl-story-logo-link {
		width: 196px;
	}

	.vl-nav,
	.vl-story-nav {
		gap: 35px;
		margin-left: clamp(44px, 8vw, 112px);
	}

	.vl-main {
		padding-inline: 48px;
	}

	.vl-card {
		padding-inline: 24px;
	}

	.vl-card p {
		font-size: 16px;
	}

	.vl-wide-only {
		display: none;
	}
}

@media (max-width: 1020px) {
	.vl-header,
	.vl-story-header {
		height: auto;
	}

	.vl-header__inner {
		flex-wrap: wrap;
		gap: 22px;
		min-height: 82px;
		padding-block: 18px;
	}

	.vl-story-header {
		flex-wrap: wrap;
		gap: 22px;
		min-height: 82px;
		padding-block: 18px;
	}

	.vl-nav,
	.vl-story-nav {
		flex-basis: 100%;
		order: 3;
		width: 100%;
		margin-left: 0;
		padding-top: 4px;
		border-top: 1px solid #ededed;
		justify-content: space-between;
	}

	.vl-main {
		padding-top: 45px;
	}

	.vl-orbits,
	.vl-dots {
		opacity: 0.45;
	}

	.vl-cards,
	.vl-benefits {
		grid-template-columns: 1fr 1fr;
	}

	.vl-profile-grid,
	.vl-profile-grid.e-con {
		grid-template-columns: 1fr;
	}

	.vl-card {
		height: auto;
		min-height: 350px;
	}

	.vl-benefits {
		gap: 30px 0;
	}

	.vl-benefit:nth-child(3) {
		border-left: 0;
		padding-left: 22px;
	}

	.vl-benefit:nth-child(2),
	.vl-benefit:nth-child(4) {
		padding-left: 25px;
	}

	.vl-contact-plaque {
		grid-template-columns: 1fr;
		max-width: 100%;
	}
}

@media (max-width: 700px) {
	.vl-header__inner,
	.vl-main,
	.vl-story-header,
	.vl-story-page {
		padding-inline: 22px;
	}

	.vl-brand__mark {
		width: 29px;
		height: 37px;
	}

	.vl-brand {
		font-size: 27px;
	}

	.vl-brand-logo-link,
	.vl-story-logo-link {
		width: 170px;
	}

	.vl-contact,
	.vl-template-contact,
	.vl-story-contact {
		flex: 0 0 auto;
		width: auto;
		height: 44px;
		gap: 8px;
		padding-inline: 17px 13px;
	}

	.vl-nav,
	.vl-story-nav {
		overflow-x: auto;
		gap: 15px;
		padding-bottom: 4px;
	}

	.vl-nav.e-con {
		gap: 15px !important;
	}

	.vl-orbits,
	.vl-dots {
		display: none;
	}

	.vl-main {
		padding-top: 38px;
	}

	.vl-intro h1 {
		font-size: clamp(37px, 11vw, 47px);
		line-height: 1.04;
	}

	.vl-desktop {
		display: none;
	}

	.vl-cards,
	.vl-benefits {
		grid-template-columns: 1fr;
		gap: 18px;
	}

	.vl-profile-grid,
	.vl-profile-grid.e-con {
		gap: 18px !important;
		margin-top: 34px !important;
	}

	.vl-card {
		min-height: 356px;
	}

	.vl-profile-card,
	.vl-profile-card.e-con {
		grid-template-columns: 1fr;
		gap: 22px !important;
		min-height: auto;
		padding: 24px !important;
	}

	.vl-profile-card--empty {
		min-height: 250px;
	}

	.vl-profile-avatar {
		width: 88px;
		height: 88px;
		font-size: 24px;
	}

	.vl-profile-photo {
		width: min(210px, 100%);
		max-width: 100%;
	}

	.vl-profile-name .elementor-heading-title,
	.vl-profile-name h3 {
		font-size: 24px;
	}

	.vl-profile-copy p {
		font-size: 15px;
		line-height: 1.46;
	}

	.vl-benefit,
	.vl-benefit:nth-child(2),
	.vl-benefit:nth-child(3),
	.vl-benefit:nth-child(4) {
		gap: 20px;
		padding: 18px 0 0;
		border-top: 1px solid #dbdbdb;
		border-left: 0;
	}

	.vl-benefit.e-con {
		gap: 20px !important;
	}

	.vl-benefit:first-child {
		padding-top: 0;
		border-top: 0;
	}

	.vl-contact-plaque-widget {
		margin-top: 28px !important;
	}

	.vl-contact-plaque__link {
		align-items: flex-start;
		min-height: 70px;
		padding: 16px;
	}

	.vl-contact-plaque__value {
		font-size: 17px;
	}

	.vl-map-frame {
		aspect-ratio: 1 / 1;
		min-height: 300px;
	}

	.vl-map-link {
		width: 100%;
		justify-content: center;
	}
}

@media (prefers-reduced-motion: reduce) {
	.vl-page *,
	.vl-page *::before,
	.vl-page *::after {
		animation-duration: 0.001ms !important;
		animation-iteration-count: 1 !important;
		scroll-behavior: auto !important;
		transition-duration: 0.001ms !important;
	}
}
