/*!
Theme Name: remontokon
Theme URI: http://underscores.me/
Author: Underscores.me
Author URI: http://underscores.me/
Description: Description
Version: 1.0.0
Tested up to: 5.4
Requires PHP: 5.6
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: remontokon
Tags: custom-background, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready
*/

/* Base */
:root {
	--brand-red: #BD1D36;
	--brand-blue: #2E5077;
	--brand-green-900: #0F2A1E;
	--brand-green-800: #143625;
	--brand-green-700: #1B4A32;
	--brand-green-600: #246143;
	--bg-surface: #F2F7F4;
	--bg-surface-2: #E7F0EA;
}

html, body {
	margin: 0;
	padding: 0;
	width: 100%;
	min-width: 360px;
	position: relative;
	font-family: 'Gilroy', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
	background: var(--bg-surface);
	font-size: 16px;
	font-weight: 400;
	line-height: 150%;
	color: #3D3D3D;
	overflow-x: hidden;
}

.error_main_page p{
	margin:20px 0;
}

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

 a { text-decoration: none; color: var(--brand-blue); }



h1, .h1 { color: var(--brand-green-800); font-size: 37px; font-weight: 700; line-height: 1.1; margin: 0 0 12px; }
h2, .h2 { color: var(--brand-green-800); margin: 20px 0; font-size: 27px; font-weight: 700; line-height: 145%; }

/* Unified section headings */
.section-title {
	color: var(--brand-green-800);
	font-weight: 950;
	letter-spacing: .2px;
	line-height: 1.15;
	margin: 26px 0 14px;
	font-size: clamp(20px, 2.1vw, 30px);
}
h3, .h3 { color: var(--brand-green-800); margin: 16px 0 10px; }

body img { max-width: 100%; }

.hidden { display: none; }
.mobile-show { display: none; }

button, input { outline: none; }

.button {
	border-radius: 30px;
	min-width: 240px;
	color: #fff;
	background-color: var(--brand-blue);
	font-size: 16px;
	line-height: 1.2;
	font-weight: 700;
	display: inline-flex;
	min-height: 43px;
	padding: 8px 18px;
	text-align: center;
	align-items: center;
	justify-content: center;
	transition: .3s ease;
	transform: scale(1);
	border: 0;
	cursor: pointer;
}
.button:hover { transform: scale(1.05); }

/* Primary actions (call / request) */
.button.call-modal,
a.call-modal.button,
button.call-modal.button,
#mos_header_newmsk .button,
.forms.mosquito_form button.button,
.form-wrapper .form-button {
	background: var(--brand-red);
	box-shadow: 0 16px 30px rgba(189, 29, 54, .22);
}

/* Layout */
main {
	margin-top: 70px;
	width: calc(100% - 315px);
	margin-left: 315px;
	display: block;
	background: linear-gradient(to bottom, #fff 0%, var(--bg-surface-2) 240px, var(--bg-surface) 100%);
	padding: 20px;
}

/* HEADER (header.php) */


.mos_header_newmsk {
	width: 100%;
	padding: 0 20px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: 70px;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	background: #fff;
	z-index: 1000;
	box-shadow: 0 8px 18px rgba(17, 24, 39, .06);
}

.mos_header_newmsk-logo {
	width: 315px;
	padding-left: 0;
	display: flex;
}

.brand-logo {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	text-decoration: none;
}

.brand-logo__vertical {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 1px;
	padding: 4px 7px;
	border-radius: 10px;
	background: linear-gradient(165deg, rgba(46, 80, 119, .11), rgba(36, 97, 67, .08));
	border: 1px solid rgba(46, 80, 119, .2);
	box-shadow: 0 8px 20px rgba(17, 24, 39, .08);
	transition: transform .18s ease;
}

.brand-logo__vertical > span {
	display: block;
	font-weight: 900;
	font-size: 18px;
	line-height: .95;
	letter-spacing: .04em;
	color: var(--brand-blue);
}

.brand-logo__words {
	display: grid;
	gap: 0;
}

.brand-logo__line {
	display: flex;
	align-items: baseline;
	line-height: 1;
}

.brand-logo__line-initial {
	font-weight: 950;
	font-size: 20px;
	line-height: .86;
	color: #BD1D36;
	letter-spacing: .02em;
	text-shadow: 0 2px 12px rgba(46, 80, 119, .16);
}

.brand-logo__line-rest {
	font-weight: 900;
	font-size: 18px;
	line-height: 1;
	letter-spacing: .01em;
	color: var(--brand-blue);
}

.brand-logo--footer .brand-logo__vertical {
	background: rgba(255, 255, 255, .12);
	border-color: rgba(255, 255, 255, .28);
	box-shadow: none;
}

.brand-logo--footer .brand-logo__vertical > span,
.brand-logo--footer .brand-logo__line-initial,
.brand-logo--footer .brand-logo__line-rest {
	color: #fff;
}

.brand-logo:hover .brand-logo__vertical {
	transform: translateY(-1px);
}

.mos_header_newmsk-description {
	width: 280px;
	font-size: 14px;
	color: #2E5077;
	line-height: 16px;
	display: flex;
	align-items: center;
	gap: 8px;
}

.mos_header_newmsk-description svg {
	width: 30px;
	height: 30px;
}

.mos_header_newmsk-phone {
	display: flex;
	align-items: center;
	gap: 8px;
}

.mos_header_newmsk-phone svg {
	width: 30px;
	height: 30px;
}

.mos_header_newmsk-phone, .mos_footer_new-phone { font-size: 25px; font-weight: 700; }
.mos_header_newmsk-phone span, .mos_footer_new-phone span { color: var(--brand-red); }

.mos_header_newmsk-sites {
	width: 100%;
	margin: 0;
	overflow-x: hidden;
	overflow-y: hidden;
}

.mos_header_newmsk-sites-content {
	border-radius: 14px;
	border: 1px solid rgba(15, 42, 30, .12);
	display: flex;
	width: calc(100% - 40px);
	min-width: 768px;
	max-width: calc(100% - 40px);
	margin: 0 20px;
	overflow: hidden;
	background: linear-gradient(180deg, rgba(255,255,255,.94) 0%, rgba(255,255,255,.86) 100%);
	box-shadow: 0 14px 34px rgba(17, 24, 39, .08);
	padding: 8px;
	gap: 8px;
}

.mos_header_newmsk-sites-block {
	width: max-content;
	margin-right: 20px;
	min-width: 100%;
	max-width: 100%;
}

.mos_header_newmsk-sites-item {
	font-size: calc((100vw - 768px)/(1280 - 768) * (16 - 12) + 12px);
	display: flex;
	flex: 1;
	min-width: 120px;
	width: 100%;
	height: 40px;
	align-items: center;
	justify-content: center;
	text-align: center;
	font-weight: 700;
	border-left: 0;
	border-radius: 12px;
	color: rgba(15, 42, 30, .78);
	background: transparent;
	transition: background-color .18s ease, color .18s ease, transform .18s ease, box-shadow .18s ease;
}

.mos_header_newmsk-sites-item:hover {
	background: rgba(36, 97, 67, .10);
	color: var(--brand-green-900);
}
.mos_header_newmsk-sites-item:active { transform: translateY(1px); }

.breadcrumbs { display: block; }
.breadcrumbs-list { list-style: none; padding: 0; margin: 0 0 10px; display: flex; flex-wrap: wrap; gap: 8px; }
.breadcrumbs-item { display: inline-flex; align-items: center; gap: 8px; color: rgba(255,255,255,.82); font-size: 13px; }
.breadcrumbs-item a { color: rgba(255,255,255,.92); text-decoration: none; border-bottom: 1px solid rgba(255,255,255,.25); }
.breadcrumbs-item a:hover { border-bottom-color: rgba(255,255,255,.55); }
.breadcrumbs-item + .breadcrumbs-item:before { content: "›"; color: rgba(255,255,255,.55); }

.mos_header_newmsk-sites-item.current-host {
	background: linear-gradient(135deg, var(--brand-green-700) 0%, var(--brand-green-900) 100%);
	color: #fff;
	box-shadow: 0 12px 22px rgba(15, 42, 30, .22);
}

#hamburger { display: none; }

/* Mobile menu overlay (hamburger drawer) */
#mobile-menu-overlay {
	position: fixed;
	inset: 0;
	background: rgba(17, 24, 39, 0.55);
	opacity: 0;
	pointer-events: none;
	transition: opacity 220ms ease;
	z-index: 1000;
}

body.menu-open #mobile-menu-overlay {
	opacity: 1;
	pointer-events: auto;
}

/* Left nav (header.php) */
#mos_header_newmsk_nav {
	--nav-accent: var(--brand-green-600);
	--nav-accent-2: var(--brand-green-900);
	--nav-text: var(--brand-green-900);
	--nav-muted: rgba(15, 42, 30, .74);
	--nav-border: rgba(15, 42, 30, .12);
	--nav-hover: rgba(36, 97, 67, .10);
	--nav-surface: rgba(255, 255, 255, .92);

	width: 315px;
	position: fixed;
	top: 70px;
	bottom: 0;
	left: 0;
	padding:20px 12px 12px 12px;
	margin: 0;
	overflow: auto;
	list-style: none;
	background: var(--nav-surface);
	border-right: 1px solid var(--nav-border);
	box-shadow: 0 18px 44px rgba(17, 24, 39, .10);
	backdrop-filter: blur(10px) saturate(150%);
	-webkit-backdrop-filter: blur(10px) saturate(150%);
	z-index: 1001;
}

#mos_header_newmsk_nav ul {
	margin: 6px 0 0;
	padding: 0;
	list-style: none;
	background: transparent;
}

/* Submenus (modern panel style) */
#mos_header_newmsk_nav li > ul {
	/* override inline `display:none` in legacy markup */
	display: none;
	overflow: hidden;

	margin-top: 6px;
	padding: 6px;
	border-radius: 14px;
	border: 1px solid rgba(36, 97, 67, .18);
	border-left: 3px solid #BD1D36;
	background: linear-gradient(180deg, rgba(232, 244, 238, .92) 0%, rgba(245, 251, 247, .88) 100%);
	box-shadow: 0 12px 28px rgba(15, 42, 30, .10);
}

#mos_header_newmsk_nav li > ul > li {
	margin: 2px 0;
}

#mos_header_newmsk_nav li > ul > li > a {
	min-height: 38px;
	padding: 9px 12px;
	border-radius: 10px;
	background: rgba(255, 255, 255, .72);
	border: 1px solid rgba(36, 97, 67, .16);
	box-shadow: none;
}

#mos_header_newmsk_nav li > ul > li > a:hover {
	background: rgba(189, 29, 54, .08);
	border-color: rgba(189, 29, 54, .28);
}

#mos_header_newmsk_nav li > ul > li > a:active {
	box-shadow: none;
}

#mos_header_newmsk_nav li > ul > li > ul {
	margin-top: 6px;
	background: rgba(239, 248, 243, .84);
}

#mos_header_newmsk_nav li > ul > li > ul > li > a {
	background: rgba(255, 255, 255, .62);
}

#mos_header_newmsk_nav li { display: block; position: relative; }
#mos_header_newmsk_nav > li + li { margin-top: 2px; }

#mos_header_newmsk_nav li a {
	color: var(--nav-text);
	min-height: 42px;
	display: flex;
	width: 100%;
	align-items: center;
	padding: 10px 12px;
	padding-right: 44px;
	border-radius: 12px;
	background: transparent;
	cursor: pointer;
	transition: background-color .18s ease, color .18s ease, transform .18s ease, box-shadow .18s ease;
}

#mos_header_newmsk_nav > li > a { font-size: 15px; font-weight: 800; letter-spacing: .1px; }
#mos_header_newmsk_nav li ul li a { font-size: 14px; font-weight: 700; color: var(--nav-muted); padding-left: 14px; }
#mos_header_newmsk_nav li ul li ul li a { padding-left: 22px; }

#mos_header_newmsk_nav li a:hover { background: var(--nav-hover); box-shadow: 0 10px 24px rgba(17, 24, 39, .06); }
#mos_header_newmsk_nav li a:active { box-shadow: none; }

#mos_header_newmsk_nav li.selected > a {
	background: linear-gradient(135deg, var(--nav-accent) 0%, var(--nav-accent-2) 100%);
	color: #fff;
	box-shadow: 0 12px 22px rgba(15, 42, 30, .22);
}

/* Active item hover: keep it clean */
#mos_header_newmsk_nav li.selected > a:hover,
#mos_header_newmsk_nav li.selected > a:focus,
#mos_header_newmsk_nav li.selected > a:focus-visible {
	background: linear-gradient(135deg, var(--nav-accent) 0%, var(--nav-accent-2) 100%);
	color: #fff;
	box-shadow: 0 12px 22px rgba(15, 42, 30, .22);
	transform: none;
}

#mos_header_newmsk_nav .next-level {
	width: 32px;
	height: 32px;
	position: absolute;
	top: 5px;
	right: 6px;
	z-index: 5;
	display: block;
	cursor: pointer;
	border-radius: 10px;
	border: 1px solid rgba(189, 29, 54, .35) !important;
	background: #fff;
	transition: background-color .18s ease, border-color .18s ease, box-shadow .18s ease;
}

#mos_header_newmsk_nav .next-level:before {
	content: '';
	display: block;
	position: absolute;
	left: 50%;
	top: 50%;
	width: 8px;
	height: 8px;
	border-right: 2px solid #BD1D36 !important;
	border-bottom: 2px solid #BD1D36 !important;
	transform: translate(-50%, -50%) rotate(-45deg);
	transition: transform .22s ease;
}

#mos_header_newmsk_nav .next-level:hover {
	background: rgba(189, 29, 54, .12) !important;
	border-color: rgba(189, 29, 54, .55) !important;
	box-shadow: 0 8px 18px rgba(189, 29, 54, .18);
}

/* Keep arrow visible on active/selected branch */
#mos_header_newmsk_nav li.selected > .next-level {
	background: rgba(255, 255, 255, .22) !important;
	border-color: rgba(255, 255, 255, .85) !important;
}
#mos_header_newmsk_nav li.selected > .next-level:before {
	border-right-color: #ffffff !important;
	border-bottom-color: #ffffff !important;
}

#mos_header_newmsk_nav .opened > .next-level:before { transform: translate(-50%, -50%) rotate(45deg); }
/* Keep submenu visibility controlled by jQuery slideDown/slideUp. */

/* FRONT PAGE (front-page.php) */
.gradient-left-right { background: linear-gradient(135deg, var(--brand-green-700), var(--brand-green-900)); color: #fff; }

.instance_newmsk { transition: .5s ease-out; }

/* Hero */
.hero { margin-bottom: 22px; }
.hero-block {
	border-radius: 18px;
	overflow: hidden;
	box-shadow: 0 18px 44px rgba(17, 24, 39, .10);
	min-height: 420px;
	position: relative;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}
.hero-block:before {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(90deg, rgba(17,24,39,.82) 0%, rgba(17,24,39,.55) 40%, rgba(17,24,39,.12) 75%, rgba(17,24,39,0) 100%);
	filter: saturate(1.05) contrast(1.02);
}
.hero-content {
	width: 100% !important;
	padding: 34px 24px !important;
	position: relative !important;
	bottom: auto !important;
	top: auto !important;
	display: flex;
	align-items: flex-end;
	min-height: 420px;
}
.hero-topline { margin-bottom: 14px; }
.hero-badges { display: flex; flex-wrap: wrap; gap: 10px; }
.hero-badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 8px 12px;
	border-radius: 999px;
	background: rgba(255,255,255,.14);
	border: 1px solid rgba(255,255,255,.18);
	color: rgba(255,255,255,.92);
	font-weight: 800;
	font-size: 12px;
	letter-spacing: .2px;
	backdrop-filter: blur(8px);
}
.hero-badge-primary {
	background: rgba(189,29,54,.18);
	border-color: rgba(189,29,54,.28);
}
.hero-inner { max-width: 100%; position: relative; }
.hero-title {
	color: #fff;
	font-size: clamp(28px, 3.1vw, 44px);
	line-height: 1.05;
	margin: 0 0 12px;
	letter-spacing: .2px;
}
.hero-lead {
	color: rgba(255,255,255,.88);
	font-size: 16px;
	line-height: 1.5;
	margin: 0 0 18px;
	max-width: 100%;
}
.hero-actions { display: flex; gap: 12px; flex-wrap: wrap; margin:20px 0; }
.hero-actions .button { min-width: 0; }
.hero-primary { background: var(--brand-red); box-shadow: 0 16px 30px rgba(189,29,54,.22); }
.hero-secondary { background: rgba(255,255,255,.14); border: 1px solid rgba(255,255,255,.20); }
.hero-secondary:hover { transform: scale(1.03); }
.hero-points {
	margin: 20px 0;
	padding: 0;
	list-style: none;
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
}
.hero-points li {
	padding: 10px 12px;
	border-radius: 999px;
	background: rgba(255,255,255,.12);
	color: rgba(255,255,255,.92);
	font-weight: 700;
}
.hero-points b { color: #fff; }

.check-list { margin: 0; padding: 0 0 0 30px; }
.check-list li { display: block; position: relative; line-height: 150%; }
.check-list li:before {
	position: absolute;
	width: 16px;
	height: 12px;
	top: calc(.5em - 6px);
	left: calc(8px - 30px);
	content: '';
	background: url('img/check.svg') center no-repeat;
}

.block-links {
	width: 100%;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	margin: 20px 0 0;
	padding: 0;
}
.block-links li {
	width: calc(100% / 3 - 20px);
	display: flex;
	margin-bottom: 20px;
	list-style: none;
}
.block-links li a {
	min-height: 80px;
	display: flex;
	border-radius: 10px;
	padding: 20px;
	width: 100%;
	color: #2E5077;
	font-weight: 700;
	align-items: center;
	justify-content: space-between;
	background-color: #EFEEEE;
	box-shadow: -6px -6px 16px #FFF, 6px 6px 16px rgba(209, 205, 199,.5);
	transform: scale(1);
	transition: .3s ease;
}
.block-links li a:hover { transform: scale(1.05); }

.block-links svg { width: 50px; height: 50px; display: block; }

/* Services showcase (front-page.php) */
.services-layout {
	display: grid;
	grid-template-columns: minmax(0, 380px) minmax(0, 1fr);
	gap: 16px;
	align-items: start;
	margin-top: 10px;
}
.services-intro {
	border-radius: 18px;
	background:
		radial-gradient(700px 260px at 15% 10%, rgba(36, 97, 67, .12) 0%, rgba(36, 97, 67, 0) 55%),
		radial-gradient(700px 260px at 95% 0%, rgba(189, 29, 54, .10) 0%, rgba(189, 29, 54, 0) 55%),
		#fff;
	border: 1px solid rgba(15, 42, 30, .12);
	box-shadow: 0 18px 54px rgba(17, 24, 39, .10);
	padding: 16px;
	height: 100%;
}
.services-kicker {
	width: fit-content;
	padding: 8px 12px;
	border-radius: 999px;
	background: rgba(189,29,54,.10);
	border: 1px solid rgba(189,29,54,.20);
	color: var(--brand-red);
	font-weight: 900;
	font-size: 12px;
	letter-spacing: .25px;
}
.services-intro .section-title { margin: 14px 0 10px; }
.services-subtitle { margin: 0; color: rgba(15, 42, 30, .74); font-weight: 650; line-height: 1.55; }
.services-points {
	margin: 14px 0 0;
	padding: 0;
	list-style: none;
	display: grid;
	gap: 10px;
}
.services-points li {
	position: relative;
	padding: 10px 10px 10px 38px;
	border-radius: 14px;
	background: rgba(15, 42, 30, .04);
	border: 1px solid rgba(15, 42, 30, .08);
	color: rgba(15, 42, 30, .86);
	font-weight: 650;
	line-height: 1.45;
}
.services-points li:before {
	content: '';
	position: absolute;
	left: 12px;
	top: 12px;
	width: 18px;
	height: 18px;
	border-radius: 999px;
	background: rgba(36, 97, 67, .12);
	border: 1px solid rgba(36, 97, 67, .24);
}
.services-points li:after {
	content: '';
	position: absolute;
	left: 17px;
	top: 17px;
	width: 8px;
	height: 5px;
	border-left: 2px solid var(--brand-green-600);
	border-bottom: 2px solid var(--brand-green-600);
	transform: rotate(-45deg);
}
.services-actions { margin-top: 14px; display: flex; flex-wrap: wrap; gap: 12px; }
.services-actions .button { min-width: 0; }

.services-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 14px;
}
.service-card {
	border-radius: 18px;
	background: #fff;
	border: 1px solid rgba(15, 42, 30, .12);
	box-shadow: 0 14px 34px rgba(17, 24, 39, .08);
	padding: 14px 14px;
	color: inherit;
	text-decoration: none;
	transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
	display: grid;
	grid-template-columns: 56px 1fr;
	grid-template-rows: auto auto auto;
	column-gap: 12px;
	row-gap: 6px;
	min-height: 155px;
}
.service-card:hover {
	transform: translateY(-2px);
	border-color: rgba(15, 42, 30, .18);
	box-shadow: 0 18px 44px rgba(17, 24, 39, .10);
}
.service-card-icon {
	grid-row: 1 / span 3;
	width: 56px;
	height: 56px;
	border-radius: 16px;
	display: grid;
	place-items: center;
	color: var(--brand-green-900);
	background: rgba(36, 97, 67, .10);
	border: 1px solid rgba(36, 97, 67, .18);
	padding:10px;
}
.service-card-title { font-weight: 950; color: var(--brand-green-900); letter-spacing: .2px; line-height: 1.2;  font-size:22px;}
.service-card-desc { color: rgba(15, 42, 30, .70); font-weight: 650; line-height: 1.45; font-size: 18px; }
.service-card-more {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-weight: 900;
	color: rgba(15, 42, 30, .66);
	letter-spacing: .2px;
	width: fit-content;
}
.service-card-more:after {
	content: "→";
	font-size: 14px;
	line-height: 1;
	font-weight: 700;
	color: currentColor;
	transform: translateY(1px);
}
.service-card--accent { border-color: rgba(189,29,54,.22); box-shadow: 0 14px 34px rgba(189,29,54,.10); }
.service-card--accent .service-card-icon {
	color: var(--brand-red);
	background: rgba(189,29,54,.10);
	border-color: rgba(189,29,54,.18);
}
.service-card--accent .service-card-more { color: var(--brand-red); }

@media (max-width: 1139px) {
	.services-layout { grid-template-columns: 1fr; }
	.services-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 620px) {
	.services-grid { grid-template-columns: 1fr; }

	.hero-points li {
		background:rgba(0, 0, 0, 0.3);
	}
}

/* Benefits (front-page.php) */
.benefits-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 14px; }
.benefits-subtitle { margin: 0 0 6px; color: rgba(15, 42, 30, .72); font-weight: 650; max-width: 520px; }
.benefits-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 14px;
	margin-top: 14px;
}
.benefit-card {
	border-radius: 18px;
	background: #fff;
	border: 1px solid rgba(15, 42, 30, .12);
	box-shadow: 0 14px 34px rgba(17, 24, 39, .08);
	padding: 16px 16px;
	min-height: 170px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.benefit-card:hover {
	transform: translateY(-2px);
	border-color: rgba(15, 42, 30, .18);
	box-shadow: 0 18px 44px rgba(17, 24, 39, .10);
}
.benefit-icon {
	width: 56px;
	height: 56px;
	border-radius: 16px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 900;
	letter-spacing: .2px;
	color: var(--brand-green-900);
	background: rgba(36, 97, 67, .10);
	border: 1px solid rgba(36, 97, 67, .18);
}
.benefit-title { font-weight: 900; color: var(--brand-green-900); line-height: 1.15; }
.benefit-text { color: rgba(15, 42, 30, .72); font-weight: 650; line-height: 1.45; font-size: 14px; }
.benefit-card--accent {
	border-color: rgba(189,29,54,.22);
	box-shadow: 0 14px 34px rgba(189,29,54,.10);
}
.benefit-card--accent .benefit-icon {
	color: var(--brand-red);
	background: rgba(189,29,54,.10);
	border-color: rgba(189,29,54,.18);
}

/* Why repair (front-page.php) */
.why-repair-head { display: grid; gap: 10px; }
.why-repair-lead {
	margin: 0;
	color: rgba(15, 42, 30, .76);
	font-weight: 700;
	line-height: 1.55;
	max-width: 980px;
}
.why-repair-grid {
	margin-top: 14px;
	display: grid;
	grid-template-columns: minmax(0, 1.1fr) minmax(0, .9fr);
	gap: 16px;
	align-items: start;
}
.why-repair-text {
	border-radius: 18px;
	background: #fff;
	border: 1px solid rgba(15, 42, 30, .12);
	box-shadow: 0 14px 34px rgba(17, 24, 39, .08);
	padding: 16px 16px;
	color: rgba(15, 42, 30, .78);
	font-weight: 650;
	line-height: 1.6;
	height: 100%;
}
.why-repair-text p { margin: 0 0 10px; }
.why-repair-text p:last-child { margin-bottom: 0; }
.why-repair-callout {
	margin-top: 12px;
	border-radius: 16px;
	background: rgba(36, 97, 67, .08);
	border: 1px solid rgba(36, 97, 67, .16);
	padding: 12px 12px;
	position: relative;
}
.why-repair-callout:before {
	content: '';
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	width: 6px;
	border-top-left-radius: 16px;
	border-bottom-left-radius: 16px;
	background: var(--brand-red);
}
.why-repair-callout-title { font-weight: 950; color: var(--brand-green-900); letter-spacing: .2px; margin-left: 10px; }
.why-repair-callout-text { margin-left: 10px; color: rgba(15, 42, 30, .74); font-weight: 650; }

.why-repair-card {
	border-radius: 18px;
	background: #fff;
	border: 1px solid rgba(15, 42, 30, .12);
	box-shadow: 0 14px 34px rgba(17, 24, 39, .08);
	padding: 16px 16px;
}
.why-repair-card-title { font-weight: 950; color: var(--brand-green-900); letter-spacing: .2px; }
.why-repair-list {
	margin: 12px 0 0;
	padding: 0;
	list-style: none;
	display: grid;
	gap: 10px;
}
.why-repair-list li {
	position: relative;
	padding: 10px 10px 10px 38px;
	border-radius: 14px;
	background: rgba(15, 42, 30, .04);
	border: 1px solid rgba(15, 42, 30, .08);
	color: rgba(15, 42, 30, .86);
	font-weight: 650;
	line-height: 1.45;
}
.why-repair-list li:before {
	content: '';
	position: absolute;
	left: 12px;
	top: 12px;
	width: 18px;
	height: 18px;
	border-radius: 999px;
	background: rgba(36, 97, 67, .12);
	border: 1px solid rgba(36, 97, 67, .24);
}
.why-repair-list li:after {
	content: '';
	position: absolute;
	left: 17px;
	top: 17px;
	width: 8px;
	height: 5px;
	border-left: 2px solid var(--brand-green-600);
	border-bottom: 2px solid var(--brand-green-600);
	transform: rotate(-45deg);
}
.why-repair-actions { margin-top: 14px; display: flex; flex-wrap: wrap; gap: 12px; }
.why-repair-actions .button { min-width: 0; }

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

@media (max-width: 1139px) {
	.benefits-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 800px) {
	.benefits-head { flex-direction: column; align-items: flex-start; }
	.benefits-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 480px) {
	.benefits-grid { grid-template-columns: 1fr; }
}

/* Quote/CTA after urgent section (front-page.php) */
.text_buqote { margin-top: 18px; }
.text_buqote-card {
	border-radius: 18px;
	background: #fff;
	border: 1px solid rgba(15, 42, 30, .12);
	box-shadow: 0 14px 34px rgba(17, 24, 39, .08);
	padding: 18px 18px;
	position: relative;
	overflow: hidden;
}
.text_buqote-card:before {
	content: '';
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	width: 6px;
	background: var(--brand-red);
}
.text_buqote-title {
	font-weight: 900;
	color: var(--brand-green-900);
	letter-spacing: .2px;
	font-size: 16px;
	margin-left: 12px;
}
.text_buqote-text {
	margin: 10px 0 0;
	color: rgba(15, 42, 30, .78);
	line-height: 1.55;
	font-weight: 650;
	margin-left: 12px;
}
.text_buqote-actions { margin-top: 14px; display: flex; flex-wrap: wrap; gap: 12px; margin-left: 12px; }
.text_buqote-actions .button { min-width: 0; }

@media (max-width: 800px) {
	.text_buqote { margin-top: 14px; }
	.text_buqote-card { padding: 16px; }
}

.block_two_col { display: flex; min-height: 280px; border-radius: 10px; overflow: hidden; position: relative; align-items: center; margin: 20px 0; }
.block_two_col > * { width: 50%; display: block; padding: 20px; }
.block_two_col-background {
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	background-position: center;
	background-repeat: no-repeat;
	background-color: #fff;
	background-size: cover;
}
.block_two_col-text { color: #fff; font-size: 27px; font-weight: 700; line-height: 145%; margin-left: 50%; }
.block_two_col .button { margin-top: 30px; }

/* CTA banner (front-page.php) */
.block_two_col--cta {
	min-height: 320px;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}
.block_two_col--cta:before {
	content: '';
	position: absolute;
	inset: 0;
	z-index: 2;
	background:
		radial-gradient(700px 340px at 12% 40%, rgba(255,255,255,.14) 0%, rgba(255,255,255,0) 65%),
		linear-gradient(95deg, rgba(15,42,30,.86) 0%, rgba(15,42,30,.62) 42%, rgba(15,42,30,.24) 70%, rgba(15,42,30,0) 100%);
	pointer-events: none;
}
.block_two_col--cta .block_two_col-text {
	position: relative;
	z-index: 3;
	margin-left: 0;
	width: 100%;
	max-width: 820px;
	padding: 26px 26px;
}
.block_two_col-cta { max-width: 760px; }
.block_two_col-cta-badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0px 12px;
	border-radius: 999px;
	background: rgba(189,29,54,.18);
	border: 1px solid rgba(189,29,54,.28);
	color: rgba(255,255,255,.92);
	font-weight: 800;
	font-size: 12px;
	letter-spacing: .2px;
	backdrop-filter: blur(8px);
}
.block_two_col-cta-title {
	margin-top: 12px;
	font-size: clamp(22px, 2.2vw, 34px);
	line-height: 1.12;
	font-weight: 900;
	color: #fff;
	letter-spacing: .2px;
}
.block_two_col-cta-subtitle {
	margin-top: 10px;
	max-width: 680px;
	color: rgba(255,255,255,.88);
	font-size: 16px;
	line-height: 1.5;
	font-weight: 600;
}

.block_two_col-cta-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 18px; }
.block_two_col-cta-actions .button { min-width: 0; margin-top: 0; }

@media (max-width: 800px) {
	.block_two_col--cta { min-height: 360px; }
	.block_two_col--cta .block_two_col-text { padding: 22px 16px; }
}

.costs { width: 100%; margin-bottom: 40px; }
.costs-container { display: block; width: 100%; overflow: visible; }
.costs-content {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
}
.cost-item {
	position: relative;
	display: flex;
	flex-direction: column;
	border-radius: 16px;
	overflow: hidden;
	background: #fff;
	border: 1px solid rgba(15, 42, 30, .12);
	box-shadow: 0 14px 34px rgba(17, 24, 39, .10);
	transform: translateY(0);
	transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
	text-decoration: none;
	color: inherit;
}
.cost-item:hover {
	transform: translateY(-2px);
	box-shadow: 0 20px 54px rgba(17, 24, 39, .14);
}
.cost-item-media {
	position: relative;
	height: 150px;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	background-color: var(--bg-surface-2);
}
.cost-item-media:after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(0,0,0,.00) 0%, rgba(0,0,0,.30) 100%);
}
.cost-item-inner {
	padding: 14px 14px 16px;
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.cost-item-title {
	font-weight: 900;
	line-height: 1.18;
	letter-spacing: .2px;
	font-size: 22px;
	color: var(--brand-green-900);
}
.cost-item-price {
	width: fit-content;
	padding: 10px 12px;
	border-radius: 12px;
	background: rgba(15, 42, 30, .06);
	border: 1px solid rgba(15, 42, 30, .14);
	font-weight: 900;
	font-size: 18px;
	color: var(--brand-green-900);
}
.cost-item-note {
	font-size: 13px;
	line-height: 1.35;
	color: rgba(15, 42, 30, .74);
	font-weight: 700;
}

.cost-item--cta {
	border-color: rgba(189,29,54,.35);
	box-shadow: 0 14px 34px rgba(189,29,54,.10);
}
.cost-item--cta:hover { box-shadow: 0 20px 54px rgba(189,29,54,.14); }
.cost-item--cta .cost-item-price {
	background: rgba(189,29,54,.10);
	border-color: rgba(189,29,54,.20);
	color: var(--brand-red);
}

@media (max-width: 960px) {
	.costs-content { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 620px) {
	.costs-content { grid-template-columns: 1fr; }
	.cost-item-media { height: 160px; }
}

.block_text-two_col { display: flex; }
.block_text-two_col > .block_text-two_col-col { display: block; width: 40%; max-width: 300px; padding-bottom: 20px; }
.block_text-two_col > .block_text-two_col-col:last-of-type { width: 60%; padding: 20px; min-width: calc(100% - 300px); }
.block_text-two_col img { width: 100%; }

/* Urgent repair panel (front-page.php) */
.urgent-repair {
	display: grid;
	grid-template-columns: minmax(0, 360px) minmax(0, 1fr);
	gap: 0;
	border-radius: 18px;
	overflow: hidden;
	background: #fff;
	border: 1px solid rgba(15, 42, 30, .12);
	box-shadow: 0 14px 34px rgba(17, 24, 39, .10);
}
.urgent-repair-aside {
	padding: 20px 20px;
	background: linear-gradient(135deg, rgba(15, 42, 30, .96), rgba(20, 54, 37, .96));
	color: #fff;
	position: relative;
}
.urgent-repair-aside:before {
	content: '';
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	width: 6px;
	background: var(--brand-red);
}
.urgent-repair-badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 8px 12px;
	border-radius: 999px;
	background: rgba(189,29,54,.18);
	border: 1px solid rgba(189,29,54,.30);
	color: rgba(255,255,255,.96);
	font-weight: 900;
	font-size: 12px;
	letter-spacing: .25px;
}
.urgent-repair-title {
	margin-top: 12px;
	font-size: 18px;
	line-height: 1.22;
	font-weight: 900;
	letter-spacing: .2px;
}
.urgent-repair-note {
	margin-top: 10px;
	color: rgba(255,255,255,.84);
	font-weight: 650;
	line-height: 1.45;
	font-size: 14px;
}
.urgent-repair-body { padding: 20px 20px; }
.urgent-repair-list {
	margin: 0;
	padding: 0;
	list-style: none;
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px;
}
.urgent-repair-list li {
	position: relative;
	padding: 12px 12px 12px 40px;
	border-radius: 14px;
	background: rgba(15, 42, 30, .04);
	border: 1px solid rgba(15, 42, 30, .08);
	color: rgba(15, 42, 30, .88);
	font-weight: 650;
	line-height: 1.45;
}
.urgent-repair-list li:before {
	content: '';
	position: absolute;
	left: 12px;
	top: 12px;
	width: 18px;
	height: 18px;
	border-radius: 999px;
	background: rgba(36, 97, 67, .12);
	border: 1px solid rgba(36, 97, 67, .24);
}
.urgent-repair-list li:after {
	content: '';
	position: absolute;
	left: 17px;
	top: 17px;
	width: 8px;
	height: 5px;
	border-left: 2px solid var(--brand-green-600);
	border-bottom: 2px solid var(--brand-green-600);
	transform: rotate(-45deg);
}

@media (max-width: 960px) {
	.urgent-repair-list { grid-template-columns: 1fr; }
}
@media (max-width: 800px) {
	.urgent-repair { grid-template-columns: 1fr; }
}

.contests.blog {
	margin: 26px 0;
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 16px;
}
.contests.blog .contest_item {
	width: auto;
	margin: 0;
	display: flex;
	flex-direction: column;
	border-radius: 18px;
	overflow: hidden;
	background: #fff;
	border: 1px solid rgba(15, 42, 30, .12);
	box-shadow: 0 14px 34px rgba(17, 24, 39, .10);
	color: inherit;
	transform: translateY(0);
	transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.contests.blog .contest_item:hover {
	transform: translateY(-2px);
	border-color: rgba(15, 42, 30, .18);
	box-shadow: 0 20px 54px rgba(17, 24, 39, .14);
}
.contests.blog .contest_item-media {
	height: 160px;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	background-color: var(--bg-surface-2);
	position: relative;
}
.contests.blog .contest_item-media:after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,.26) 100%);
}
.contests.blog .contest_item-body { padding: 14px 14px 16px; display: grid; gap: 8px; }
.contests.blog .contest_item-title {
	transform: none;
	padding: 0;
	min-height: 0;
	background: none;
	color: var(--brand-green-900);
	font-weight: 900;
	text-transform: none;
	font-size: 16px;
	line-height: 1.15;
	max-width: none;
}
.contests.blog .contest_item-title:after { display: none; }
.contests.blog .contest_item-text {
	padding: 0;
	color: rgba(15, 42, 30, .74);
	font-size: 14px;
	line-height: 1.45;
	font-weight: 650;
}
.contests.blog .contest_item-more {
	margin-top: 2px;
	font-weight: 900;
	color: var(--brand-red);
	letter-spacing: .2px;
}
.contests.blog .contest_item-more:after {
	content: '';
	display: inline-block;
	margin-left: 8px;
	width: 8px;
	height: 8px;
	border-right: 2px solid var(--brand-red);
	border-bottom: 2px solid var(--brand-red);
	transform: rotate(-45deg);
	vertical-align: middle;
}

@media (max-width: 1139px) {
	.contests.blog { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 620px) {
	.contests.blog { grid-template-columns: 1fr; margin: 18px 0; }
	.contests.blog .contest_item-media { height: 170px; }
}

.contests { display: flex; justify-content: space-between; margin-bottom: 20px; flex-wrap: wrap; }
.contest_item {
	background-color: #EFEEEE;
	box-shadow: -6px -6px 16px #FFF, 6px 6px 16px rgba(209, 205, 199,.5);
	width: calc(100% / 3 - 20px);
	border-radius: 10px;
	position: relative;
	overflow: hidden;
	margin-bottom: 20px;
	transition: .3s ease;
	transform: scale(1);
	color: inherit;
	display: block;
}
.contest_item:hover { transform: scale(1.05); }
.contest_item-background { height: 200px; width: 100%; background-color: #fff; background-size: cover; background-position: center; }
.contest_item-title, .block-category {
	position: relative;
	font-size: 16px;
	font-weight: 700;
	text-transform: uppercase;
	line-height: 20px;
	transform: translateY(-50%);
	color: #fff;
	border-top-right-radius: 5px;
	border-bottom-right-radius: 5px;
	background: linear-gradient(135deg, var(--brand-green-700), var(--brand-green-900));
	padding: 8px 20px;
	min-height: 36px;
	display: inline-flex;
	max-width: calc(100% - 20px);
}
.contest_item-text { padding: 0 20px 20px; color: #2E5077; line-height: 20px; font-size: 16px; font-weight: 700; }

.block { padding: 40px 100px; border: 1px solid var(--brand-green-600); border-radius: 10px; margin: 20px 0; }

.block-text { margin-top: 15px; }

/* Tip card (front-page.php) */
.tip-card {
	border-radius: 18px;
	padding: 18px 18px;
	background:
		radial-gradient(700px 220px at 15% 10%, rgba(36, 97, 67, .12) 0%, rgba(36, 97, 67, 0) 55%),
		radial-gradient(700px 220px at 95% 0%, rgba(189, 29, 54, .10) 0%, rgba(189, 29, 54, 0) 55%),
		#fff;
	border: 1px solid rgba(15, 42, 30, .12);
	box-shadow: 0 18px 54px rgba(17, 24, 39, .10);
}
.tip-card-top { display: flex; justify-content: space-between; align-items: center; gap: 12px; flex-wrap: wrap; }
.tip-card-badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 8px 12px;
	border-radius: 999px;
	background: rgba(189,29,54,.10);
	border: 1px solid rgba(189,29,54,.20);
	color: var(--brand-red);
	font-weight: 900;
	font-size: 12px;
	letter-spacing: .25px;
}
.tip-card-meta { color: rgba(15, 42, 30, .62); font-weight: 700; font-size: 13px; }
.tip-card-title {
	margin-top: 12px;
	color: var(--brand-green-900);
	font-weight: 950;
	font-size: clamp(18px, 1.8vw, 26px);
	line-height: 1.15;
	letter-spacing: .2px;
}
.tip-card-text { margin-top: 10px; color: rgba(15, 42, 30, .78); font-weight: 650; line-height: 1.55; }
.tip-card-text p { margin: 0; }
.tip-card-points {
	margin: 14px 0 0;
	padding: 0;
	list-style: none;
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 12px;
}
.tip-card-points li {
	position: relative;
	padding: 12px 12px 12px 40px;
	border-radius: 14px;
	background: rgba(15, 42, 30, .04);
	border: 1px solid rgba(15, 42, 30, .08);
	color: rgba(15, 42, 30, .86);
	font-weight: 650;
	line-height: 1.45;
}
.tip-card-points li:before {
	content: '';
	position: absolute;
	left: 12px;
	top: 12px;
	width: 18px;
	height: 18px;
	border-radius: 999px;
	background: rgba(36, 97, 67, .12);
	border: 1px solid rgba(36, 97, 67, .24);
}
.tip-card-points li:after {
	content: '';
	position: absolute;
	left: 17px;
	top: 17px;
	width: 8px;
	height: 5px;
	border-left: 2px solid var(--brand-green-600);
	border-bottom: 2px solid var(--brand-green-600);
	transform: rotate(-45deg);
}
.tip-card-actions { margin-top: 16px; display: flex; flex-wrap: wrap; gap: 12px; }
.tip-card-actions .button { min-width: 0; }

@media (max-width: 1139px) {
	.tip-card-points { grid-template-columns: 1fr; }
}
@media (max-width: 800px) {
	.tip-card { padding: 16px; }
}

/* Process (front-page.php) */
.process { margin-top: 26px; }
.process-inner { display: block; }
.process-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 14px; flex-wrap: wrap; }
.process-head h2 { margin: 0; }
.process-subtitle { margin: 0 0 6px; color: rgba(15, 42, 30, .72); font-weight: 650; max-width: 620px; }
.process-grid {
	margin-top: 14px;
	display: grid;
	grid-template-columns: minmax(0, 420px) minmax(0, 1fr);
	gap: 16px;
}
.process-cta {
	border-radius: 18px;
	overflow: hidden;
	position: relative;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	min-height: 360px;
	box-shadow: 0 18px 54px rgba(17, 24, 39, .10);
	border: 1px solid rgba(15, 42, 30, .12);
}
.process-cta:before {
	content: '';
	position: absolute;
	inset: 0;
	background:
		radial-gradient(700px 280px at 15% 20%, rgba(255,255,255,.14) 0%, rgba(255,255,255,0) 60%),
		linear-gradient(105deg, rgba(15,42,30,.86) 0%, rgba(15,42,30,.64) 48%, rgba(15,42,30,.22) 80%, rgba(15,42,30,0) 100%);
	pointer-events: none;
}
.process-cta-card {
	position: relative;
	z-index: 2;
	padding: 18px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	justify-content: flex-end;
	min-height: 360px;
}
.process-cta-badge {
	width: fit-content;
	padding: 8px 12px;
	border-radius: 999px;
	background: rgba(189,29,54,.18);
	border: 1px solid rgba(189,29,54,.28);
	color: rgba(255,255,255,.96);
	font-weight: 900;
	font-size: 12px;
	letter-spacing: .25px;
}
.process-cta-title { color: #fff; font-weight: 950; letter-spacing: .2px; font-size: 22px; line-height: 1.12; margin-top: 2px; }
.process-cta-text { color: rgba(255,255,255,.88); font-weight: 650; line-height: 1.5; max-width: 360px; }
.process-cta-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 8px; }
.process-cta-actions .button { min-width: 0; }

.process-steps {
	margin: 0;
	padding: 0;
	list-style: none;
	counter-reset: process-steps;
	display: grid;
	gap: 12px;
}
.process-step {
	counter-increment: process-steps;
	border-radius: 18px;
	background: #fff;
	border: 1px solid rgba(15, 42, 30, .12);
	box-shadow: 0 14px 34px rgba(17, 24, 39, .08);
	padding: 16px 16px 16px 54px;
	position: relative;
}
.process-step:before {
	content: counter(process-steps);
	position: absolute;
	left: 16px;
	top: 16px;
	width: 28px;
	height: 28px;
	border-radius: 10px;
	display: grid;
	place-items: center;
	background: rgba(36, 97, 67, .10);
	border: 1px solid rgba(36, 97, 67, .18);
	color: var(--brand-green-900);
	font-weight: 950;
}
.process-step-title { font-weight: 950; color: var(--brand-green-900); line-height: 1.15; }
.process-step p { margin: 8px 0 0; color: rgba(15, 42, 30, .74); font-weight: 650; line-height: 1.5; }

@media (max-width: 960px) {
	.process-grid { grid-template-columns: 1fr; }
	.process-cta, .process-cta-card { min-height: 320px; }
	.process-cta-text { max-width: none; }
}

/* Swiper minimal (front-page gallery) */
.swiper-slide { text-align: center; }
.swiper-slide > * { text-align: initial; }
.block-slider-container { width: 100%; }
.block-slider-item { display: block; background: #fff; border-radius: 10px; overflow: hidden; padding: 20px; }

/* FOOTER (footer.php) */
footer#mos_footer_new.site-footer {
	width: calc(100% - 315px);
    margin-left: 315px;
	display: block;
	padding: 20px;
	background: linear-gradient(135deg, var(--brand-green-900), var(--brand-green-700));
	color: rgba(255,255,255,.92);
}

.site-footer-top {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 14px;
	flex-wrap: wrap;
}
.site-footer-title { font-weight: 950; letter-spacing: .2px; font-size: 18px; color: #fff; }
.site-footer-subtitle { margin-top: 6px; color: rgba(255,255,255,.82); font-weight: 650; line-height: 1.5; max-width: 620px; }
.site-footer-cta .button { min-width: 0; }

.site-footer-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
	padding:15px 0;
}
.site-footer-col {
	border-radius: 18px;
	background: rgba(255,255,255,.08);
	border: 1px solid rgba(255,255,255,.12);
	padding: 16px 16px;
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
}
.site-footer-col-title { font-weight: 950; color: #fff; letter-spacing: .2px; margin-bottom: 10px; }
.site-footer-phone {
	display: inline-block;
	font-size: 22px;
	font-weight: 950;
	letter-spacing: .2px;
	color: #fff;
}
.site-footer-phone span { color: rgba(255,255,255,.72); }
.site-footer-muted { color: rgba(255,255,255,.76); font-weight: 650; }
.site-footer-list { display: grid; gap: 10px; }
.site-footer-links { display: grid; gap: 10px; }
.site-footer-links a { color: rgba(255,255,255,.88); text-decoration: none; font-weight: 700; }
.site-footer-links a:hover { color: #fff; text-decoration: underline; }

.site-footer-bottom {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 12px;
	flex-wrap: wrap;
	padding-top: 4px;
	border-top: 1px solid rgba(255,255,255,.14);
	margin-top: 4px;
}

@media (max-width: 960px) {
	.site-footer-grid { grid-template-columns: 1fr; }
}

/* Responsive */
@media (max-width: 1139px) {
	.block-links li { width: calc(100% / 2 - 10px); }
}

@media (max-width: 800px) {
	main { margin-left: 0; width: 100%; margin-top: 70px; }
	footer#mos_footer_new { margin-left: 0; width: 100%; }
	.block-links li { width: 100%; }
	.hero-content { padding: 22px 16px !important; }
	.hero-content { min-height: 360px; align-items: flex-end; }
	.hero-block { min-height: 360px; }
	.hero-block:before {
		background: linear-gradient(180deg, rgba(17,24,39,.82) 0%, rgba(17,24,39,.50) 55%, rgba(17,24,39,.18) 100%);
	}

	#hamburger {
		background: var(--brand-blue);
		border-radius: 50%;
		width: 40px;
		height: 40px;
		display: flex;
		flex-direction: column;
		justify-content: center;
		float: right;
	}

	footer#mos_footer_new.site-footer {
		width: 100%;
		margin-left: 0;
	}
	#hamburger span { width: 18px; margin: 2px auto; height: 3px; background: #fff; }

	#mos_header_newmsk_nav { left: -315px; transition: left 260ms cubic-bezier(0.2, 0.8, 0.2, 1); }
	body.menu-open #mos_header_newmsk_nav { left: 0; top:0; }
	body.menu-open { overflow: hidden; }

	header#mos_header_newmsk {  transition: .1s ease; }
	.mos_header_newmsk-sites-content { height: 0; border-width: 0; transition: .1s ease; }
	
	/* Drawer menu overlay должен открываться без влияния на раскладку контента */
	body.menu-open .mos_header_newmsk-sites-content { height: 0; border-width: 0; }
}

@media (max-width: 620px) {
	
	.service-card-title {
		font-size: 18px;
	}
	.service-card-desc {
		font-size: 14px;
	}
	.block_text-two_col { flex-wrap: wrap; }
	.block_text-two_col > .block_text-two_col-col,
	.block_text-two_col > .block_text-two_col-col:last-of-type {
		width: 100%;
		max-width: none;
		min-width: 0;
	}
}

@media (max-width: 400px) {
	#mos_header_newmsk_nav { width: calc(100vw - 40px); left: calc(40px - 100vw); }
	.mos_header_newmsk-logo { width: 170px; padding: 4px 0; }
}



/* FORM */

.forms h3 {
	padding: 0;
	margin: 0 0 20px;
	color: var(--brand-green-800);
	font-weight: 700;
	font-size: 21px;
}

.form-wrapper .field-wrapper.telephoneinput input.telephoneinput,
.form-wrapper .field-wrapper.textinput input.textinput,
.form-wrapper .field-wrapper.emailinput input.emailinput {
	line-height: 50px;
	width: 100%;
	background: #EFEEEE;
	padding: 0 20px;
	border: 0;
	border-bottom: 1px solid var(--brand-green-600);
	outline: none;
	height: 50px;
}

.form-wrapper form div.textinput:first-of-type input.textinput {
	border-top-left-radius: 8px;
	border-top-right-radius: 8px;
}

.form-wrapper form div.textinput:last-of-type input.textinput {
	border-bottom-left-radius: 8px;
	border-bottom-right-radius: 8px;
	border-bottom: none;
}

.form-wrapper form div.textarea textarea {
	width: 100%;
	background: #EFEEEE;
	padding: 20px;
	border: 0;
	font-family: 'Gilroy';
}

.form-wrapper form div.textarea textarea:last-of-type {
	border-bottom-left-radius: 8px;
	border-bottom-right-radius: 8px;
	border-bottom: none;
}

.form-wrapper .form-button {
	font-size: 16px;
	font-weight: 700;
	display: block;
	margin: 20px auto 0;
	border: 0;
	height: 42px;
	color: white;
	border-radius: 21px;
	background: var(--brand-red);
	padding: 0 20px;
	box-shadow: -6px -6px 16px rgba(255,255,255,.25), 6px 6px 16px rgba(189,29,54,.35);
}

.form-wrapper .checkboxinput {
	position: relative;
	margin-top: 20px;
}

.form-wrapper .checkboxinput input {
	width: 40px;
	height: 40px;
	display: inline-block;
	opacity: 0;
	top: 0;
	left: 0;
	position: absolute;
	z-index: 5;
}

.form-wrapper .checkboxinput label {
	width: 40px;
	height: 40px;
	background-color: #EFEEEE;
	display: inline-block;
	border-radius: 7px;
	position: absolute;
	left: 0;
	top: 0;
	z-index: 4;
}

.form-wrapper .checkboxinput input:checked + label {
	background: #EFEEEE url('img/check.svg') center no-repeat;
}

.form-wrapper .checkboxinput .help-text {
	padding-left: 60px;
	display: block;
	font-size: 12px;
	line-height: 1.5;
}

.form-wrapper .clearablefileinput {
	position: relative;
	margin-top: 10px;
}

.form-wrapper .field-wrapper.clearablefileinput label {
	border: 3px solid white;
	border-radius: 8px;
	font-size: 16px;
	text-align: center;
	padding: 10px 20px;
	position: relative;
	z-index: 2;
	display: block;
	cursor: pointer;
}

.form-wrapper .field-wrapper.clearablefileinput label:hover {
	background: white;
	color: var(--brand-green-600);
}

.form-wrapper .filefield {
	opacity: 0;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 1;
}

.form-wrapper .filefield::-webkit-file-upload-button {
	visibility: hidden;
}

.form-wrapper .filefield:before {
	content: '';
}

.form-wrapper .field-wrapper.select label {
	font-size: 16px;
	margin: 10px 0 2px;
	display: block;
}

.form-wrapper .field-wrapper.select select {
	line-height: 50px;
	height: 50px;
	width: 100%;
	padding: 0 20px;
	border: 0;
	border-bottom: 1px solid var(--brand-green-600);
	background: #EFEEEE url('img/dropdown.svg') calc(100% - 20px) 50% no-repeat;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}

.mos-modal .form-wrapper label {
	font-size: 0;
}

.mos-modal .help-text {
	display: inline;
}

/* Fancybox / mos-modal: callback & callmaster */
.mos-modal.forms {
	padding: 24px 24px 26px;
	background: #ffffff;
	border-radius: 18px;
	box-shadow: 0 22px 48px rgba(15, 42, 30, .32);
	border: 1px solid rgba(36, 97, 67, .16);
}

.mos-modal .form-wrapper {
	margin: 0;
}

.mos-modal-title {
	text-align: center;
	font-size: 22px;
	font-weight: 800;
	color: var(--brand-green-900);
	margin: 0 0 10px;
}

.mos-modal-subtitle {
	text-align: center;
	font-size: 14px;
	color: rgba(15, 42, 30, .72);
	margin: 0 0 18px;
}

.mos-modal .wpcf7 {
	margin: 0;
}

.wpcf7-not-valid-tip {
	font-size:14px;
}

.mos-modal .wpcf7-form-control.wpcf7-text,
.mos-modal .wpcf7-form-control.wpcf7-tel,
.mos-modal .wpcf7-form-control.wpcf7-email,
.mos-modal .wpcf7-form-control.wpcf7-textarea {
	width: 100%;
	box-sizing: border-box;
	border-radius: 10px;
	border: 1px solid rgba(36, 97, 67, .28);
	background: #f4f7f5;
	padding: 10px 14px;
	font-size: 15px;
	margin:10px 0;
}

.mos-modal .wpcf7-form-control.wpcf7-textarea {
	min-height: 90px;
	resize: vertical;
}

.forms br {
	display: none;
}
.mos-modal .wpcf7-submit {
	margin-top: 10px;
}

.mos-modal .wpcf7-submit,
.mos-modal .form-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 100%;
	height: 44px;
	border-radius: 22px;
	border: 0;
	background: var(--brand-red);
	color: #fff;
	font-weight: 700;
	font-size: 18px;
	cursor: pointer;
	padding: 0 24px;
	box-shadow: -6px -6px 16px rgba(255,255,255,.18), 6px 6px 16px rgba(189,29,54,.35);
	transition: transform .18s ease, box-shadow .18s ease;
}

.mos-modal .wpcf7-submit:hover,
.mos-modal .form-button:hover {
	transform: translateY(-1px);
	box-shadow: 0 10px 22px rgba(189,29,54,.35);
}

.mos-modal .wpcf7-submit:active,
.mos-modal .form-button:active {
	transform: translateY(0);
	box-shadow: none;
}

main>.forms {
	background: linear-gradient(135deg, var(--brand-green-700), var(--brand-green-900));
	padding: 20px;
	border-radius: 8px;
	margin-bottom: 20px;
}

main>.forms label {
	font-size: 0;
}

#callmaster.mos-modal,
#callback.mos-modal,
#valueofaphoto.mos-modal,
#mosquito_form-modal,
#assessquality.mos-modal {
	max-width: 420px;
	width: 100%;
}

#callmaster.mos-modal form div.textinput:nth-child(2n) input.textinput,
#callback.mos-modal form div.textinput:nth-child(2n) input.textinput,
#assessquality.mos-modal form div.textinput:nth-child(5) input.textinput {
	border-bottom-left-radius: 8px;
	border-bottom-right-radius: 8px;
	border-bottom: none;
}


/* MOSQUITO FORM */
.forms.mosquito_form {
	background: #EFEEEE;
	display: flex;
	padding: 0;
	overflow: hidden;
	box-shadow: -6px -6px 16px rgba(255,255,255,1), 6px 6px 16px rgb(209,205,199, .5);
}

.forms.mosquito_form .field-radioselector-heading {
	display: none;
}

.forms.mosquito_form .field-wrapper {
	margin-bottom: 10px;
}

.forms.mosquito_form .description {
	width: 100%;
	padding: 13px 10px;
}

.forms.mosquito_form .form-wrapper {
	width: 100%;
	padding: 0 10px;
}

.forms.mosquito_form .mosquito_form-col {
	padding: 10px;
	width: 50%;
	float: left;
}

.forms.mosquito_form button.button {
	float: right;
	margin: 0 10px;
}

.forms.mosquito_form .mosquito_form-item:after {
	display: table;
	width: 100%;
	clear: both;
	float: none;
	content: '';
}

.forms.mosquito_form .mosquito_form-item {
	position: relative;
}

.forms.mosquito_form .mosquito_form-item .delete_position {
	position: absolute;
	top: 0;
	right: 10px;
	width: 32px;
	height: 32px;
	display: block;
	border: 0;
	padding: 0;
	outline-offset: none;
	margin: 0;
	cursor: pointer;
	transition: .3s;
	transform: rotateZ(0deg);
}

.forms.mosquito_form .mosquito_form-item .delete_position:before,
.forms.mosquito_form .mosquito_form-item .delete_position:after {
	content: '';
	background: var(--brand-green-600);
	width: 100%;
	height: 4px;
	display: block;
	position: absolute;
	transform: rotateZ(45deg);
	top: calc(50% - 2px);
	left: 0;
}

.forms.mosquito_form .mosquito_form-item .delete_position:after {
	transform: rotateZ(-45deg);
}

.forms.mosquito_form .mosquito_form-item .delete_position:hover {
	transform: rotateZ(180deg);
}

#mosquito_form select,
#mosquito_form input {
	border-bottom: 0;
	border-radius: 8px;
	margin: 0;
	background: white;
}

#mosquito_form label {
	font-size: 16px;
	margin: 10px 0 2px;
	display: none;
}

#mosquito_form .checkboxinput label {
	margin: 0;
	display: inline-block;
	font-size: 0;
}

#mosquito_form select {
	background: white url('img/dropdown_black.svg') calc(100% - 20px) 50% no-repeat;
}

#mosquito_form .call-mosquito-modal {
	background: var(--brand-red);
	color: white;
	margin: 0;
	display: flex;
	align-items: center;
	box-shadow: -6px -6px 16px rgba(255,255,255,.18), 6px 6px 16px rgba(189,29,54,.35);
}

#mosquito_form .field-radioselector {
	display: flex;
	align-items: stretch;
	border-radius: 10px;
	border: 2px solid white;
	overflow: hidden;
}

#mosquito_form .field-radioselector label {
	display: block;
	width: 100%;
	position: relative;
	display: flex;
	border-right: 2px solid white;
	margin: 0;
	align-items: center;
	justify-content: center;
}

#mosquito_form .field-radioselector label:last-of-type {
	border-right: none;
}

#mosquito_form .field-radioselector label input {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	opacity: 0;
	display: block;
	width: 100%;
	height: 100%;
}

#mosquito_form .field-radioselector label input:checked {
	opacity: 0;
}

#mosquito_form .field-radioselector label .radio {
	width: 100%;
	height: 106px;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 20px;
	flex-wrap: wrap;
	cursor: pointer;
}

#mosquito_form .field-radioselector label .radio b {
	color: var(--brand-green-600);
	font-size: 27px;
	line-height: 145%;
	display: block;
	width: 100%;
}

#mosquito_form .field-radioselector label input:checked ~ span {
	background: white;
}

#mosquito_form_tsvet_ramka .field-radioselector label .radio {
	padding-top: 0;
	padding-bottom: 0;
	flex-wrap: nowrap;
	flex-direction: column;
}

#mosquito_form_tsvet_ramka .field-radioselector label .radio:before {
	display: block;
	width: 38px;
	height: 38px;
	border-radius: 50%;
	content: '';
	margin-bottom: 10px;
}

#mosquito_form_tsvet_ramka .field-radioselector label:nth-of-type(1) .radio:before {
	border: 3px solid #BDBDBD;
	background: white;
}

#mosquito_form_tsvet_ramka .field-radioselector label:nth-of-type(2) .radio:before {
	background: #9D8769;
}

#mosquito_form_tsvet_ramka .field-radioselector label:nth-of-type(3) .radio:before {
	background: conic-gradient(red, yellow, lime, aqua, blue, magenta, red);
}

#mosquito_form_delivery .field-radioselector {
	margin: 10px;
	border: 1px solid var(--brand-green-600);
}

#mosquito_form_delivery .field-radioselector label {
	border-right: 1px solid var(--brand-green-600);
}

#mosquito_form_delivery .field-radioselector label .radio {
	justify-content: flex-start;
	font-size: 16px;
}

#mosquito_form_delivery_address {
	margin: 0 10px;
}

.forms.mosquito_form .field-wrapper h3,
.forms.mosquito_form .mosquito_form-item-position_heading {
	color: var(--brand-green-800);
	margin: 30px 10px 20px;
}

.forms.mosquito_form .form-success {
	padding: 48px;
	text-align: center;
	min-height: 420px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.forms.mosquito_form .button-wrapper.to-modal {
	background: linear-gradient(to right, rgb(34,193,201), rgb(70,108,140));
	color: white;
	padding: 20px;
	margin: 10px -10px 0;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

@media(max-width:1140px) {
	#mosquito_form_tsvet_ramka .field-radioselector label .radio {
		padding-left: 10px;
		padding-right: 10px;
		font-size: 14px;
	}

	#mosquito_form_delivery .field-radioselector label .radio {
		font-size: 14px;
	}

	#mosquito_form .field-radioselector label .radio b {
		font-size: 18px;
	}
}

@media(max-width:980px) {
	.forms.mosquito_form .mosquito_form-col {
		width: 100%;
		padding-top: 0;
		padding-bottom: 0;
	}
}

@media(max-width:620px) {

	#mosquito_form .field-radioselector {
		flex-wrap: wrap;
	}

	#mosquito_form .field-radioselector label {
		border-right: 0;
		border-bottom: 1px solid white;
	}

	#mosquito_form_delivery .field-radioselector label {
		border-right: 0;
		border-bottom: 1px solid var(--brand-green-600);
	}

	#mosquito_form .field-radioselector label:last-of-type {
		border-bottom: 0;
	}

	#mosquito_form_delivery .field-radioselector label .radio {
		text-align: center;
		justify-content: center;
	}

	.forms.mosquito_form .button-wrapper.to-modal {
		flex-wrap: wrap;
		justify-content: flex-end;
	}

	#mosquito_form .call-mosquito-modal {
		margin-top: 10px;
	}
}

/* MAP */
#map_canvas {
	width: 100%;
	min-height: 400px;
}

.map_container {
	background: linear-gradient(135deg, var(--brand-green-700), var(--brand-green-900));
	color: white;
	border-radius: 8px;
	overflow: hidden;
	position: relative;
	margin: 20px 0;
}


/* CONTENT */


.check-list {
	margin: 0;
	padding: 0 0 0 30px;
}

.check-list li {
	display: block;
	position: relative;
	line-height: 150%;
}

.check-list li:before {
	position: absolute;
	width: 16px;
	height: 12px;
	top: calc(.5em - 6px);
	left: calc(8px - 30px);
	content: '';
	background: url('img/check.svg') center no-repeat;
	font-size: 24px;
}

.block-links {
	width: 100%;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	margin: 20px 0 0;
	padding: 0;
}

.block-links li {
	width: calc(100% / 3 - 20px);
	display: flex;
	margin-bottom: 20px;
}

.block-links li:before {
	display: none;
}

.block-links li a {
	min-height: 80px;
	display: flex;
	border-radius: 10px;
	padding: 20px;
	width: 100%;
	color: #2E5077;
	font-weight: 700;
	align-items: center;
	justify-content: space-between;
	background-color: #EFEEEE;
	box-shadow: -6px -6px 16px #FFF, 6px 6px 16px rgba(209, 205, 199,.5);
	transform: scale(1);
	transition: .3s ease;
}

.block-links li a:hover {
	transform: scale(1.05);
}

/* Icon size inside block-links */
.block-links svg {
	width: 50px;
	height: 50px;
	display: block;
}


.main-top_block-content .block-links li {
	width: calc(100% / 2 - 20px);
}

@media(max-width:1139px) {
	main>.block-links li {
		width: calc(100% / 2 - 10px);
	}
}

@media(max-width:800px) {
	.main-top_block-content .block-links li {
		width: calc(100% / 2 - 10px);
	}

	main {
		margin-left: 0;
		width: 100%;
		margin-top: 70px;
	}

	body.menu-open main {
		/* Не меняем отступы: чтобы контент не прыгал */
		margin-top: 70px;
		transition: none;
	}

	footer#mos_footer_new {
		margin-left: 0;
		width: 100%;
	}

	main>.block-links li {
		width: calc(100%);
	}
}

.block-steps {
	width: 100%;
	margin: 20px 0;
}

.block-steps-container {
	display: flex;
	counter-reset: block-steps;
	justify-content: space-between;
	margin: 0;
	padding: 0;
}

.block-steps li {
	width: calc(100% / 3 - 20px);
	counter-increment: block-steps;
	display: block;
}

.block-steps li:before {
	display: none;
}

.block-steps img {
	display: block;
	margin: 10px auto;
}

.block-steps-text {
	border-top: 1px solid var(--brand-green-600);
	position: relative;
	padding: 20px 0;
}

.block-steps-text:before {
	content: counter(block-steps);
	padding: 0 20px 0 0;
	color: var(--brand-green-600);
	background: rgba(239, 238, 238, 1);
	display: inline-block;
	position: absolute;
	top: -12px;
	font-size: 16px;
	font-weight: 700;
}

@media(max-width:800px) {
	.block-steps-container {
		flex-wrap: wrap;
	}

	.block-steps li {
		width: 100%;
	}

	.block-steps img {
		margin-bottom: 20px;
	}

	.block-steps-text {
		border-top: 0;
		padding: 0 20px 0 35px;
	}

	.block-steps-text:before {
		left: 0;
		padding: 12px 5px;
		z-index: 10;
	}

	.block-steps-text:after {
		display: block;
		position: absolute;
		top: 0;
		left: 10px;
		bottom: -70px;
		width: 1px;
		background-color: var(--brand-green-600);
		content: '';
	}

	.block-steps li:last-of-type .block-steps-text:after {
		display: none;
	}
}

.gradient-left-right {
	background: linear-gradient(135deg, var(--brand-green-700), var(--brand-green-900));
	color: #fff;
}

.main-top_block {
	min-height: 320px;
	width: 100%;
	display: block;
	position: relative;
	margin-bottom: 40px;
}

.main-top_block.fullwidth {
	min-height: 400px;
}

.main-top_block-background {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 55%;
	z-index: 5;
	overflow: hidden;
	background-size: cover;
	background-position: center;
}

.main-top_block.fullwidth .main-top_block-background {
	left: 0;
}

.main-top_block-background video {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	min-width: 100%;
}

.main-top_block-content {
	padding: 40px 20px;
	z-index: 10;
	width: 55%;
	overflow: auto;
	position: relative;
	bottom: 20px;
	top: 0;
}

.main-top_block-content .button-block {
	margin-top: 25px;
}

.main-top_block .block-links {
	min-width: 925px;
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	margin: 0;
	padding: 0;
}

.main-top_block .block-links li {
	margin: 0;
}

.main-top_block .block-links li a {
	display: block;
	background: white;
	box-shadow: none;
	margin-bottom: 0;
	background: rgba(255,255,255,.8);
	transform: scale(1);
	transition: .3s ease;
}

.main-top_block .block-links li a:hover {
	background: rgba(255,255,255,1);
	box-shadow: 0 0 8px rgba(0,0,0,.2);
	transform: scale(1.05);
}

.main-top_block .block-links li a:before {
	width: 24px;
	height: 24px;
	content: '';
	display: block;
	background: url('img/arrow.svg') center left no-repeat;
}

.main-top_block.fullwidth .main-top_block-background.video video {
	transform: translateY(-50%);
	top: 50%;
}

@media(min-width:1400px) {
	.main-top_block.fullwidth {
		min-height: 25vw;
	}
}

@media(max-width:800px) {
	.main-top_block-background {
		width: 100%;
		position: relative;
		left: 0;
		min-height: 400px;
	}

	.main-top_block-content {
		width: 100%;
		padding-top: 20px;
	}

	.main-top_block.fullwidth .main-top_block-background.video video {
		min-height: 400px;
		width: auto;
		top: 0;
		left: 50%;
		transform: translateX(-50%);
	}
}

@media(max-width:480px) {
	.main-top_block-background,
    .main-top_block.fullwidth .main-top_block-background.video video,
    .main-top_block.fullwidth {
		min-height: 340px;
	}

	.main-top_block .block-links {
		min-width: calc(100vw * 3 - 120px);
	}

	.main-top_block-content .block-links li {
		width: calc(100% / 3 - 10px);
	}
}

.contests {
	display: flex;
	justify-content: space-between;
	margin-bottom: 20px;
	flex-wrap: wrap;
}

.contest_item {
	background-color: #EFEEEE;
	box-shadow: -6px -6px 16px #FFF, 6px 6px 16px rgba(209, 205, 199,.5);
	width: calc(100% / 3 - 20px);
	border-radius: 10px;
	position: relative;
	overflow: hidden;
	margin-bottom: 20px;
	transition: .3s ease;
	transform: scale(1);
}

.contest_item:hover {
	transform: scale(1.05);
}

.contest_item-background {
	height: 200px;
	width: 100%;
	background-color: white;
	background-size: cover;
	background-position: center;
}

.contest_item-title, .block-category {
	position: relative;
	font-size: 16px;
	font-weight: 700;
	text-transform: uppercase;
	line-height: 20px;
	transform: translateY(-50%);
	color: white;
	border-top-right-radius: 5px;
	border-bottom-right-radius: 5px;
	background: linear-gradient(135deg, var(--brand-green-700), var(--brand-green-900));
	padding: 8px 20px;
	min-height: 36px;
	display: inline-flex;
	max-width: calc(100% - 20px);
}

.contest_item-title:after, .block-category:after {
	content: '';
	display: block;
	position: absolute;
	left: calc(100% - 1px);
	top: 0;
	bottom: 0;
	width: 36px;
	background: url('img/endtitle.svg') -2px center no-repeat;
	background-size: contain;
}

.contest_item-text {
	padding: 0 20px 20px;
	color: #2E5077;
	line-height: 20px;
	font-size: 16px;
	font-weight: 700;
}

@media(max-width:800px) {
	.contest_item {
		width: 100%;
	}
}

.block_two_col {
	display: flex;
	min-height: 280px;
	border-radius: 10px;
	overflow: hidden;
	position: relative;
	align-items: center;
	margin: 20px 0;
}

.block_two_col > * {
	width: 50%;
	display: block;
	padding: 20px;
}

.block_two_col-background {
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	background-position: center;
	background-repeat: no-repeat;
	background-color: white;
	background-size: cover;
}

.block_two_col-text {
	color: white;
	font-size: 27px;
	font-weight: 700;
	line-height: 145%;
	margin-left: 50%;
}

.block_two_col .button {
	margin-top: 30px;
}

.block_two_col.soft {
	min-height: unset;
}

.block_two_col.soft .block_two_col-background {
	position: relative;
	padding: 0;
	max-width: 600px;
	width: 50%;
}

.block_two_col.soft .block_two_col-background img {
	display: block;
}

.block_two_col.soft .block_two_col-text {
	margin: 0;
	width: calc(100% - 600px);
	min-width: 50%;
}

.block_text-two_col {
	display: flex;
}

.block_text-two_col.reverse {
	flex-direction: row-reverse;
}

.block_text-two_col > .block_text-two_col-col {
	display: block;
	width: 40%;
	max-width: 300px;
	padding-bottom: 20px;
}

.block_text-two_col > .block_text-two_col-col:last-of-type {
	width: 60%;
	padding: 20px;
	min-width: calc(100% - 300px);
}

.block_text-two_col.reverse > .block_text-two_col-col:last-of-type {
	padding-left: 0;
}

.block_text-two_col img {
	width: 100%;
}

main h2 ~ .block_text-two_col > .block_text-two_col-col:last-of-type {
	padding-top: 0;
}

@media(max-width:960px) {
	.block_two_col.soft .block_two_col-text {
		font-size: 21px;
		text-align: center;
	}

	.block_two_col.soft .button {
		margin-top: 12px;
	}
}

@media(max-width:860px) {
	.block_two_col.soft {
		flex-wrap: wrap;
	}

	.block_two_col.soft .block_two_col-background,
	.block_two_col.soft .block_two_col-background img,
	.block_two_col.soft .block_two_col-text {
		width: 100%;
		max-width: unset;
	}
}

@media(max-width:800px) {
	.block_two_col, .block_text-two_col {
		flex-wrap: wrap;
	}

	.block_two_col-background {
		position: relative;
		width: 100%;
		min-height: 280px;
	}

	.block_two_col-text {
		width: 100%;
		margin-left: 0;
	}

	.block_text-two_col > .block_text-two_col-col {
		width: 100%;
		max-width: unset;
	}

	.block_text-two_col > .block_text-two_col-col:last-of-type {
		width: 100%;
	}
}

@media(max-width:400px) {
	.block_two_col .button {
		font-size: 14px;
	}
}

.block {
	padding: 40px 100px;
	border: 1px solid var(--brand-green-600);
	border-radius: 10px;
	margin: 20px 0;
}

.block-category {
	transform: none;
}



.block-text {
	margin-top: 15px;
}

.block-text+table,.block-text+.table_wrap {
	margin-top: 15px;
}

@media(max-width:800px) {
	.block {
		padding: 40px 20px;
	}
}


.swiper-slide {
	text-align: center;
}

.swiper-slide > * {
	text-align: initial;
}

.table_wrap:after {
	content: '';
	position: absolute;
	right: -20px;
	top: 0px;
	width: 25%;
	height: 100%;
	background: linear-gradient(
    90deg
    , rgba(192,192,192,0.0) 0%, rgb(239 238 238) 100%);
	transition: 0.3s all;
	opacity: 0;
	display: none;
}

.table_wrap.done:after {
	opacity: 0;
}

.table_wrap_effect {
	position: relative;
}

@media (max-width: 600px) {
	.table_wrap td {
		text-align: center;
	}
}

.block-prices tbody tr td.price {
	text-align: center;
}

.customer_trust_new {
	margin: 20px 0;
}

.customer_trust_new h2, .customer_trust_new .h2 {
	margin-bottom: 0;
}

.customer_trust_new-container {
	border-radius: 10px;
	overflow: hidden;
	display: flex;
	align-items: center;
}

.customer_trust_new-container-col {
	width: 40%;
	padding: 20px;
	float: left;
}

.customer_trust_new-container .customer_trust_new-container-col:last-of-type {
	width: 60%;
}

.customer_trust_new-container-col .button, .customer_trust_new-container-col button {
	margin-right: 20px;
}

.customer_trust_new-badges {
	width: 440px;
	height: 220px;
	margin: 0 auto 30px;
}

.customer_trust_new-badge {
	background: url("img/badge.svg") center no-repeat;
	width: 220px;
	height: 220px;
	text-align: center;
	color: #2E5077;
	display: inline-flex;
	flex-direction: column;
	justify-content: center;
	float: left;
	position: relative;
	line-height: 150%;
}

.customer_trust_new-badges .customer_trust_new-badge:nth-of-type(2n-1) {
	background-image: url("img/badge_yandex.svg");
	z-index: 1;
}

.customer_trust_new-badges .customer_trust_new-badge:nth-of-type(2n) {
	background-image: url("img/badge_google.svg");
	margin-left: -40px;
	z-index: 0;
}

.customer_trust_new-badge span {
	color: var(--brand-green-600);
	font-size: 67px;
	font-weight: 700;
	line-height: 1;
}

.customer_trust_new-badge span:after {
	display: block;
	margin: 0 auto 5px;
	content: '';
	width: 136px;
	height: 20px;
	background: url('img/stars.svg') center no-repeat;
}

.customer_trust_new-badge b {
	display: block;
}

.customer_trust_new-badge a {
	text-decoration: underline;
}

.customer_trust_new-title {
	text-align: center;
	color: #2E5077;
	line-height: 24px;
	padding: 0 40px;
}

.customer_trust_new-title b {
	display: block;
	font-size: 27px;
	line-height: 113%;
	font-weight: 700;
}

.customer_trust_new-title i {
	display: block;
	font-size: 16px;
	font-weight: 700;
	font-style: normal;
}

@media(max-width:1294px) {
	.customer_trust_new-container-col .button:first-of-type {
		margin-bottom: 10px;
	}

	.customer_trust_new-container.gradient-left-right .customer_trust_new-container-col:last-of-type {
		text-align: center;
	}
}

@media(max-width:850px) {
	.customer_trust_new-container {
		flex-wrap: wrap;
	}

	.customer_trust_new-container-col, .customer_trust_new-container .customer_trust_new-container-col:last-of-type {
		width: 100%;
		padding: 20px 0 0;
	}

	.customer_trust_new-container.gradient-left-right .customer_trust_new-container-col {
		padding: 20px 20px 0;
	}

	.customer_trust_new-container-col .button, .customer_trust_new-container-col button {
		margin-bottom: 20px;
	}
}

.our_masters {
	position: relative;
}

.our_masters:after {
	content: '';
	position: absolute;
	right: -20px;
	top: 0;
	bottom: 0;
	background: linear-gradient(to left, rgba(239, 238, 238, 1), rgba(229,229,229,0));
	pointer-events: none;
	width: calc(100% / 3);
	min-width: 60px;
}

.our_masters h2, .our_masters .h2 {
	max-width: 480px;
	height: 100px;
}

.our_masters h2 span, .our_masters .h2 span {
	font-size: 87px;
	color: var(--brand-green-600);
	float: left;
	line-height: 1;
	margin-right: 20px;
}

.our_masters-content {
	width: calc(100% + 40px);
	overflow-x: auto;
	margin-left: -20px;
	margin-right: -20px;
	position: relative;
	width: initial;
	overflow: hidden;
}

.our_masters-content::-webkit-scrollbar {
	height: 2px;
}

.our_masters-content::-webkit-scrollbar-track {
	box-shadow: inset 0 0 6px rgba(0, 0, 0, 0.3);
}

.our_masters-content::-webkit-scrollbar-thumb {
	background-color: #2E5077;
	opacity: .2;
	outline: 1px solid slategrey;
}

.our_masters-container {
/*min-width:925px;*//*width:max-content;*/
	padding: 30px 20px 20px;
/*display:flex;*/
	padding-bottom: 40px;
}

.our_master-item {
	width: calc(100% / 3 - 20px);
	min-width: 400px;
	display: block;
	float: left;
	margin-right: 20px;
	width: initial;
	cursor: pointer;
	float: initial;
	user-select: none;
}

.our_master-head {
	display: flex;
	align-items: center;
}

.our_master-title b {
	display: block;
}

.our_master-avatar {
	width: 160px;
	height: 160px;
	border-radius: 50%;
	margin-right: 20px;
	background-position: center;
	background-size: cover;
}

.our_master-title {
	width: calc(100% - 160px);
}

.our_master-content {
	padding: 10px 0 0;
}

@media(max-width:560px) {
	.our_masters h2, .our_masters .h2 {
		height: unset;
	}

	.our_masters h2 span, .our_masters .h2 span {
		display: block;
		width: 100%;
	}
}

.block-slider-container {
	margin-left: -20px;
	margin-right: -20px;
	width: calc(100% + 40px);
	margin-left: 0;
	margin-right: 0;
	width: 100%;
}

.block-slider-container .slick-slide {
	padding: 20px 10px;
}

.slick-arrow {
	top: 0;
	bottom: 0;
	transform: none;
	-webkit-transform: none;
	width: calc(20%);
	max-width: 400px;
	min-width: 60px;
	height: unset;
	z-index: 90;
	opacity: 0;
}

.slick-arrow.slick-prev {
	left: 0;
}

.slick-arrow.slick-next {
	right: 0;
}

.block-slider-item {
	height: 340px;
	width: auto;
	padding: 20px;
	background: white;
	box-shadow: 0 0 9px rgba(0,0,0,.1), 6px 6px 16px rgba(209, 205, 199,.5);
	position: relative;
	font-size: 0;
	display: inline-block;
	width: 100%;
	height: auto;
	user-select: none;
	outline: none;
	border: none;
	outline: none;
}

.block-slider-item img {
	width: 100%;
	height: auto;
}

.swiper img {
	display: block;
}

.block-slider-container .swiper-wrapper {
	padding-bottom: 30px;
}

.youtube_video {
	position: relative;
}

.youtube_video:before {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateX(-50%) translateY(-50%);
	width: 70px;
	height: 70px;
	border-radius: 50%;
	content: '';
	background: var(--brand-green-600) url('img/play.svg') 80% 20% no-repeat;
	background-size: 90%;
	opacity: 70%;
}

.block-prices {
	margin: 20px 0 10px;
}

.block-prices tbody tr td.price {
	font-weight: 700;
	color: #2E5077;
	width: 160px;
}

.block-prices tbody tr td.price span.old_price {
	font-weight: 300;
	color: #3D3D3D;
	width: 160px;
	position: relative;
	display: inline-block;
	padding-top: 0;
	font-size: 80%;
}

.block-prices tbody tr td.price span.old_price .value {
	position: relative;
	display: inline-block;
	width: auto;
	padding: 0 8px;
	line-height: 16px;
}

.block-prices tbody tr td.price span.old_price .value::after {
	content: '';
	position: absolute;
	left: 0;
	top: 0;
	right: 0;
	bottom: 0;
	width: 100%;
	height: 100%;
	background-image: url('data:image/svg+xml;utf-8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22100%25%22%20height%3D%22100%25%22%3E%0A%20%20%20%20%3Cline%20x1%3D%220%22%20y1%3D%22100%25%22%20x2%3D%22100%25%22%20y2%3D%220%22%20stroke%3D%22%23FFA630%22%20stroke-width%3D%222%22%2F%3E%0A%3C%2Fsvg%3E');
	background-size: cover;
}

body.compensate-for-scrollbar {
	overflow: initial !important;
}

@media(max-width:600px) {
	.block-prices tbody {
		display: block;
	}

	.block-prices tbody tr {
		display: block;
		border-top: 1px solid rgba(34,193,201,.2);
		width: 100%;
		padding: 16px 0;
	}

	.block-prices tbody tr:first-of-type {
		border-top: 1px solid rgba(34,193,201,1);
	}

	.block-prices tbody tr td:first-of-type,
    .block-prices tbody tr td:last-of-type {
		display: block;
		width: 100%;
		border: none;
		padding: 0;
	}
}

@media(max-width:480px) {
    /*.block-slider-item {height:auto;padding:0;}*/
	.block-slider-item img {
		height: auto;
		width: calc(100vw - 80px);
	}

	.slick-track {
		display: flex;
		align-items: center;
	}
}


.block-tables tbody tr td:last-of-type {
	font-weight: 700;
	color: #2E5077;
}

.block-services-list {
	padding: 0;
	margin: 20px 0;
	display: flex;
	flex-wrap: wrap;
}

.block-services-item {
	width: calc(100% / 3 - 15px);
	display: block;
	margin-right: 20px;
	-webkit-perspective: 800px;
	-moz-perspective: 800px;
	-o-perspective: 800px;
	perspective: 800px;
	margin-bottom: 30px;
}

.block-services .block-services-item:nth-of-type(3n) {
	margin-right: 0;
}

.block-services-item:before {
	display: none;
}

.block-services-item:not(.manual-flip):hover .block-services-card,
.block-services-item.hover.manual-flip .block-services-card {
	-webkit-transform: rotateY( 180deg );
	-moz-transform: rotateY( 180deg );
	-o-transform: rotateY( 180deg );
	transform: rotateY( 180deg );
}

.block-services-item.static:hover .block-services-card,
.block-services-item.static.hover .block-services-card {
	-webkit-transform: none;
	-moz-transform: none;
	-o-transform: none;
	transform: none;
}

.block-services-card {
	-webkit-transition: -webkit-transform .5s;
	-moz-transition: -moz-transform .5s;
	-o-transition: -o-transform .5s;
	transition: transform .5s;
	-webkit-transform-style: preserve-3d;
	-moz-transform-style: preserve-3d;
	-o-transform-style: preserve-3d;
	transform-style: preserve-3d;
	position: relative;
	display: block;
}

.block-services-card .front, .block-services-card .back {
	width: 100%;
	color: #2E5077;
	overflow: hidden;
	-webkit-backface-visibility: hidden;
	-moz-backface-visibility: hidden;
	-o-backface-visibility: hidden;
	backface-visibility: hidden;
	position: absolute;
	top: 0;
	left: 0;
	background-color: #EFEEEE;
	box-shadow: 0 0 6px rgba(0, 0, 0, 0.05);
}

.block-services-card .front {
	z-index: 2;
}

.block-services-card .back {
	-webkit-transform: rotateY( 180deg );
	-moz-transform: rotateY( 180deg );
	-o-transform: rotateY( 180deg );
	transform: rotateY( 180deg );
	z-index: 3;
	padding: 20px;
}

.block-services-card {
	background: none repeat scroll 0 0 #FFFFFF;
	border-radius: 10px;
	color: #444444;
}

.block-services-item, .block-services-card .front, .block-services-card .back {
	height: 280px;
	border-radius: 10px;
}

.block-services-img {
	height: 200px;
	width: 100%;
	display: block;
	background-size: cover;
	background-position: center;
}

.block-services-title {
	padding: 0 20px;
	display: flex;
	height: calc(280px - 200px);
	align-items: center;
	font-size: 16px;
	font-weight: 700;
}

.block-services-semititle {
	font-size: 16px;
	font-weight: 700;
	margin-bottom: 40px;
	display: block;
}

@media(max-width:1024px) {
	.block-services-item {
		width: calc(100% / 2 - 10px);
	}

	.block-services .block-services-item:nth-of-type(3n) {
		margin-right: 20px;
	}

	.block-services .block-services-item:nth-of-type(2n) {
		margin-right: 0;
	}
}

@media(max-width:620px) {
	.block-services-item {
		width: 100%;
		margin-right: 0 !important;
	}
}

.page-as-app-post {
	width: 100%;
	display: flex;
	overflow: hidden;
	margin-bottom: 20px;
	border-radius: 10px;
	background-color: #EFEEEE;
	box-shadow: -6px -6px 16px #FFF, 6px 6px 16px rgba(209, 205, 199,.5);
}

.page-as-app-post > * {
	flex: 1;
	min-height: 280px;
}

.page-as-app-post-img {
	display: flex;
	background-position: center;
	background-size: cover;
}

.page-as-app-video {
	display: flex;
}

.page-as-app-video .page-as-app-post-img {
	width: 100%;
}

.page-as-app-desc {
	padding: 30px 20px;
	display: flex;
	flex-direction: column;
}

.page-as-app-title {
	font-size: 21px;
	font-weight: 700;
	margin-bottom: 10px;
}

.page-as-app-text {
	flex: 1;
}


.page-as-blog-instance_newmsk{
	border-radius: 10px;
	background-color: #EFEEEE;
	box-shadow: -6px -6px 16px #FFF, 6px 6px 16px rgba(209, 205, 199,.5);
	position: relative;
	overflow: hidden;
	margin-bottom: 20px;
}

.page-as-blog-title {
	margin-top: 0;
}

.page-as-blog-instance_newmsk-thumb {
	width: 100%;
	min-height: 440px;
	background-position: center;
	background-color: #c7e2e9;
	background-size: contain;
	background-repeat: no-repeat;
}

.page-as-blog-instance_newmsk-video {
	position: relative;
	display: block;
}

.page-as-blog-instance_newmsk-text {
	width: calc(100% - 200px);
	min-width: 320px;
	max-width: 820px;
	margin: 0 auto;
	padding: 30px 20px;
}

@media(max-width:620px) {
	.page-as-blog-instance_newmsk-text {
		width: 100%;
	}

	.page-as-app-post {
		display: block;
	}

	.page-as-app-post .page-as-app-desc {
		min-height: auto;
	}

	.page-as-blog-instance_newmsk-thumb {
		background-size: cover;
	}
}

#HTTP404_ERROR_PAGE > img {
	display: block;
	max-width: 100%;
	margin: 60px auto 30px;
	float: none;
	clear: both;
}

#HTTP404_ERROR_PAGE > span {
	font-size: 21px;
	font-weight: 700;
	text-align: center;
	display: block;
	color: #2E5077;
	letter-spacing: .1;
}

#HTTP404_ERROR_PAGE > a.button {
	background-color: var(--brand-blue);
	margin: 20px auto 60px;
	display: flex;
	max-width: 100px;
}

.form-wrapper .form-button:hover {
	cursor: pointer;
}



@media(min-width:620px) {
	.swiper-button-next,
    .swiper-button-prev {
		display: none !important;
	}
}


/*  Переверстка страницы блога  */
@media(min-width:1700px) {
	.page-as-app {
		display: flex;
		flex-flow: wrap;
	}

	.page-as-app-post {
		margin-left: 15px;
		margin-right: 15px;
		margin-bottom: 30px;
	}

	.page-as-app-post {
		flex: 46%;
	}
}

@media(min-width:2800px) {
	.page-as-app {
		display: flex;
		flex-flow: wrap;
	}

	.page-as-app-post {
		margin-left: 15px;
		margin-right: 15px;
		margin-bottom: 30px;
	}

	.page-as-app-post {
		flex: 30%;
	}
}

/*  Фикс позиции номера телефона в модальном окне  */
.mos-modal-title {
	text-align: center;
}

/*  Фикс модального окна  */
.form-wrapper .form-button {
	box-shadow: none;
	transition: .3s ease-out;
	border: 1px solid var(--brand-red);
}

.form-wrapper .form-button:hover {
	transition: .3s ease-out;
	transform: scale(1.1);
	box-shadow: 0px 0px 10px rgb(0 0 0 / 25%);
}

.form-wrapper .form-button:active {
	transform: scale(1);
	box-shadow: none;
	transition: .3s ease-out;
	border: 1px solid var(--brand-red);
}

.form-wrapper .checkboxinput input:hover {
	cursor: pointer;
}

@media(max-width:800px) {
	.form-wrapper form input.textinput,
    .form-wrapper form textarea.textarea {
		font-size: 16px;
	}
}




/* Активность блоков на странице */
.instance_newmsk{
	transition: .5s ease-out;
}

.instance_newmsk.diactivated {
	opacity: .6;
	cursor: not-allowed !important;
}

.instance_newmsk.diactivated * {
	cursor: not-allowed !important;
}

@media all and (max-width: 1400px) {
	.customer_trust_new-container-col,
    .customer_trust_new-container .customer_trust_new-container-col:last-of-type {
		width: 100%;
	}
}

@media all and (max-width: 1050px) {
	.customer_trust_new-container {
		flex-wrap: wrap;
	}
}

@media all and (max-width: 768px) {
	.block-links li {
		width: calc(100% / 2 - 15px);
	}

	.block-prices table tr td:nth-child(2) {
		border-bottom: none;
	}

	.block-prices table tr:first-of-type td {
		border-top: none;
	}

	.customer_trust_new-container {
		margin-top: 15px;
	}

	.block_text-two_col p {
		word-break: break-word;
	}

	table.mos-price-calculator {
		min-width: 100%;
	}

	table.mos-price-calculator tbody tr td:nth-child(2) {
		width: 100%;
	}

	.mos-price-calculator-row {
		width: 100%;
		display: flex;
		flex-direction: row;
		align-items: center;
		flex-wrap: wrap;
	}

	.mos-price-calculator tbody tr td:first-of-type {
		width: 100%;
		padding-left: 0px !important;
		padding-right: 0px !important;
		background-color: #e3e3e3 !important;
	}

	table.mos-price-calculator thead tr {
		display: inline-block;
	}

	.mos-price-calculator tbody tr td:nth-child(3),
    .mos-price-calculator tbody tr td:nth-child(4),
    .mos-price-calculator tbody tr td:nth-child(5) {
		width: 50%;
	}

	.mos-price-calculator tbody tr td:nth-child(6) {
		width: 50%;
		height: 52px;
		line-height: 43px;
	}

	table.mos-price-calculator tbody tr td.mos-price-calculator-title:first-of-type {
		background-color: transparent !important;
	}

	table.mos-price-calculator tfoot tr td {
		font-size: 20px;
		padding: 30px 10px;
		text-align: center;
	}

	.mos-price-calculator-wrap {
		margin-left: -15px;
		width: calc(100% + 30px);
	}

	.table_wrap:after {
		display: block;
		opacity: 1;
	}

	.table_wrap.done:after {
		opacity: 0;
	}

	.table_wrap {
		overflow-y: scroll;
	}
    /*.table_wrap table td {
        text-align: center;
    }*/
	.table_wrap table th {
		min-width: 130px;
		padding-left: 5px;
		padding-right: 5px;
	}

	.table_wrap table th br {
		display: none;
	}
}

@media all and (max-width: 550px) {
	.block-links li {
		width: 100%;
	}
}

@media all and (max-width: 480px) {
	.customer_trust_new-badges {
		display: flex;
		width: 100%;
		justify-content: space-between;
	}

	.customer_trust_new-badge {
		width: 100%;
		transform: scale(0.85);
		background-size: 100%;
	}
}

.socials img {
	max-width: 50px;
	max-height: 50px;
}

.schema-contacts {
	display: none;
}


.fancybox-slide--html {
	padding: 10px !important;
}




/*--------------------------------------------------- play game buttons in menu -------------------------*/
.button.mos_header_newmsk-game-pc img {
	max-width: 28px;
	margin-left: 10px;
	margin-top: -3px;
}

@media (min-width: 595px) {
	.button.mos_header_newmsk-game-pc {
		min-width: auto;
		padding-left: 25px;
		padding-right: 25px;
	}

	.customer_trust_new-container-col .button:last-child {
		margin-right: 0;
	}
}

.mos_header_newmsk .mos_header_newmsk-game .mos_header_newmsk-game-pc {
	color: white;
	font-size: 19px;
	font-weight: bold;
	border: 4px solid yellow;
	background-color: #227d9c;
	border-radius: 17px;
	border-color: #ffa919;
	padding: 8px 26px 8px 28px;
	letter-spacing: 0.05em;
	position: relative;
	top: -3px;
	transition: 0.3s all;
	white-space: nowrap;
}

.mos_header_newmsk .mos_header_newmsk-game .mos_header_newmsk-game-pc img {
	max-width: 28px;
	height: auto;
	position: relative;
	top: 6px;
	left: 2px;
}

.mos_header_newmsk .mos_header_newmsk-game .mos_header_newmsk-game-mobile {
	border-radius: 50px;
	border: 2px solid yellow;
	background-color: #227d9c;
	border-color: #ffa919;
	position: fixed;
	bottom: 10px;
	left: 10px;
	display: none;
	transition: 0.3s all;
	z-index: 9999;
	width: 65px;
	height: 65px;
	background-image: url('img/play_game_present1.png');
	background-repeat: no-repeat;
	background-position: center center;
	background-size: 30px 30px;
}

.mos_header_newmsk .mos_header_newmsk-game > a:hover {
	filter: brightness(1.15);
}

@media (max-width: 1500px) {
	.mos_header_newmsk-logo {
		width: 228px;
	}
}



@media (max-width: 1180px) {
	.mos_header_newmsk-rating {
		display: none;
	}

	#mos_header_newmsk .button {
		width: 40px;
		height: 40px;
		min-height: unset;
		margin-right: 20px;
		font-size: 0;
		background: var(--brand-red) url('img/phone.svg') center no-repeat;
		min-width: unset;
		float: right;
	}
}

@media (max-width: 800px) {
	.mos_header_newmsk-description, .mos_header_newmsk-phone {
		display: none;
	}

	.brand-logo {
		gap: 8px;
	}

	.brand-logo__vertical {
		padding: 3px 6px;
	}

	.brand-logo__vertical > span {
		font-size: 14px;
	}

	.brand-logo__line-initial {
		font-size: 18px;
	}

	.brand-logo__line-rest {
		font-size: 13px;
	}
}

@media (max-width: 536px) {
	h2 {
		font-size:20px;
	}
	p {
		font-size:14px;
	}
	.mos_header_newmsk-logo {
		margin-right: 0;
	}
}

@media (max-width: 496px) {
	.mos_header_newmsk-logo {
		margin-right: 10px;
		width: 170px;
	}
}

@media (max-width: 452px) {
	.mos_header_newmsk-logo {
		width: 100px;
		margin-top: 10px;
	}
}

@media (max-width: 400px) {
	.mos_header_newmsk-logo {
		margin-top: 6px;
	}
}


.wpcf7-spinner {
	display: none !important;
}


iframe {
	border: 0;
	width: 100%;
	height: fill-available;
	height: -webkit-fill-available;
	height: -moz-available;
}

/* Landing polish: category + single templates */
.single-uslugi-landing .hero-block,
.single-staty .hero-block,
.single-sale-landing .hero-block,
body.category .hero-block {
	position: relative;
	overflow: hidden;
	border-radius: 24px;
	box-shadow: 0 24px 56px rgba(12, 30, 22, .26);
}

.single-uslugi-landing .hero-block:before,
.single-staty .hero-block:before,
.single-sale-landing .hero-block:before,
body.category .hero-block:before {
	content: "";
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.5);
}

.single-uslugi-landing .hero-content,
.single-staty .hero-content,
.single-sale-landing .hero-content,
body.category .hero-content {
	position: relative;
	z-index: 2;
}

.single-uslugi-landing .hero-title,
.single-staty .hero-title,
.single-sale-landing .hero-title,
body.category .hero-title {
	font-size: clamp(30px, 4.2vw, 56px);
	line-height: 1.06;
	letter-spacing: -.02em;
	text-wrap: balance;
}

.single-uslugi-landing .hero-lead,
.single-staty .hero-lead,
.single-sale-landing .hero-lead,
body.category .hero-lead {
	max-width: 760px;
	color: rgba(255, 255, 255, .92);
}

.single-uslugi-landing .hero-points li,
.single-staty .hero-points li,
.single-sale-landing .hero-points li,
body.category .hero-points li {
	background: rgba(255, 255, 255, .10);
	border: 1px solid rgba(255, 255, 255, .18);
	border-radius: 999px;
	padding: 8px 14px;
	backdrop-filter: blur(2px);
}
.single-post-block {
	margin:40px 0;
}

.single-post-block ul li {
	list-style: none;
}
.single-post-block ul li img {
	margin-right: 5px;
}
.single-uslugi-landing .single-post-block .container,
.single-staty .single-post-block .container,
.single-sale-landing .single-post-block .container {
	background: linear-gradient(180deg, #ffffff 0%, #f7fbf8 100%);
	border: 1px solid rgba(36, 97, 67, .12);
	border-radius: 20px;
	padding: 5px 20px 20px 20px;
	box-shadow: 0 14px 40px rgba(15, 42, 30, .08);
}

.single-uslugi-landing .single-post-block h2,
.single-staty .single-post-block h2,
.single-sale-landing .single-post-block h2 {
	color: var(--brand-green-900);
	margin:15px 0;
}

.single-uslugi-landing .contest_item,
.single-staty .contest_item,
.single-sale-landing .contest_item,
body.category .contest_item,
body.category .service-card {
	border-radius: 18px;
	border: 1px solid rgba(36, 97, 67, .12);
	box-shadow: 0 10px 28px rgba(15, 42, 30, .08);
	transition: transform .24s ease, box-shadow .24s ease, border-color .24s ease;
}

.single-uslugi-landing .contest_item:hover,
.single-staty .contest_item:hover,
.single-sale-landing .contest_item:hover,
body.category .contest_item:hover,
body.category .service-card:hover {
	transform: translateY(-4px);
	border-color: rgba(36, 97, 67, .28);
	box-shadow: 0 20px 42px rgba(15, 42, 30, .14);
}

.single-uslugi-landing .contest_item-media,
.single-staty .contest_item-media,
.single-sale-landing .contest_item-media,
body.category .contest_item-media {
	border-radius: 16px 16px 0 0;
}

.single-uslugi-landing .benefit-card,
.single-staty .benefit-card,
.single-sale-landing .benefit-card,
body.category .benefit-card {
	background: linear-gradient(165deg, #ffffff 0%, #f4faf6 100%);
	border: 1px solid rgba(36, 97, 67, .13);
	box-shadow: 0 12px 30px rgba(15, 42, 30, .08);
}

.single-uslugi-landing .benefit-icon,
.single-staty .benefit-icon,
.single-sale-landing .benefit-icon,
body.category .benefit-icon {
	background: linear-gradient(135deg, var(--brand-green-700) 0%, var(--brand-green-900) 100%);
	color: #fff;
	box-shadow: 0 10px 20px rgba(24, 74, 48, .32);
}

.single-uslugi-landing .tip-card,
.single-staty .tip-card,
.single-sale-landing .tip-card,
body.category .tip-card {
	border-radius: 20px;
	border: 1px solid rgba(36, 97, 67, .16);
	box-shadow: 0 18px 40px rgba(15, 42, 30, .10);
	background: linear-gradient(165deg, #ffffff 0%, #f5faf7 100%);
}

.single-uslugi-landing .block_two_col--cta,
.single-staty .block_two_col--cta,
.single-sale-landing .block_two_col--cta {
	overflow: hidden;
	border-radius: 22px;
	box-shadow: 0 24px 52px rgba(15, 42, 30, .24);
}

.single-uslugi-landing .block_two_col--cta:before,
.single-staty .block_two_col--cta:before,
.single-sale-landing .block_two_col--cta:before {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(90deg, rgba(15, 42, 30, .72) 0%, rgba(15, 42, 30, .36) 46%, rgba(15, 42, 30, .72) 100%);
}

.single-uslugi-landing .block_two_col-cta,
.single-staty .block_two_col-cta,
.single-sale-landing .block_two_col-cta {
	position: relative;
	z-index: 2;
}

@media (max-width: 980px) {
	.single-uslugi-landing .hero-block,
	.single-staty .hero-block,
	.single-sale-landing .hero-block,
	body.category .hero-block {
		border-radius: 18px;
	}

	.single-uslugi-landing .hero-points li,
	.single-staty .hero-points li,
	.single-sale-landing .hero-points li,
	body.category .hero-points li {
		border-radius: 12px;
	}
}

@media (max-width: 640px) {
	.single-uslugi-landing .hero-title,
	.single-staty .hero-title,
	.single-sale-landing .hero-title,
	body.category .hero-title {
		font-size: clamp(26px, 8.2vw, 36px);
	}

	.single-uslugi-landing .single-post-block .container,
	.single-staty .single-post-block .container,
	.single-sale-landing .single-post-block .container {
		border-radius: 14px;
		padding: 18px 16px;
	}
}

/* Breadcrumbs in .bread */
.bread {
	display: block;
	margin: 0 0 18px;
}

.bread .mos-breadcrumbs {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 0;
	margin: 0;
	width:max-content;
	padding: 10px 14px;
	border-radius: 14px;
	background: rgba(11, 24, 18, .42);
	border: 1px solid rgba(255, 255, 255, .22);
	backdrop-filter: blur(4px);
	box-shadow: 0 8px 18px rgba(0, 0, 0, .14);
}

.bread .mos-breadcrumbs li {
	display: inline-flex;
	align-items: center;
	margin: 0;
	padding: 0 10px 0 0;
	color: rgba(255, 255, 255, .92);
	font-size: 14px;
	font-weight: 600;
	line-height: 1.2;
}

.bread .mos-breadcrumbs li:not(:last-child)::after {
	content: "→";
	margin: 0 0 0 10px;
	color: #ffffff;
	opacity: .8;
	font-size: 12px;
	font-weight: 700;
	line-height: 1;
}

.bread .mos-breadcrumbs li a {
	color: #fff;
	text-decoration: none;
	border-bottom: 1px solid rgba(255, 255, 255, .42);
	transition: border-color .18s ease, opacity .18s ease;
}

.bread .mos-breadcrumbs li a:hover {
	color: #fff;
	border-bottom-color: #fff;
	opacity: .95;
}

.bread .mos-breadcrumbs li span {
	color: #ffffff;
	opacity: .95;
	border-bottom: 1px solid transparent;
}

@media (max-width: 640px) {
	.bread .mos-breadcrumbs {
		padding: 8px 10px;
		border-radius: 12px;
	}

	.bread .mos-breadcrumbs li {
		font-size: 12px;
		padding-right: 8px;
	}

	.bread .mos-breadcrumbs li:not(:last-child)::after {
		margin-left: 8px;
		font-size: 11px;
	}

	.bread .mos-breadcrumbs {
		width:100%;
	}
	.bread .mos-breadcrumbs li {
		padding-bottom: 5px;
	}
}

/* Flexible block: contacts + Yandex map */
.fp-contacts {
	margin: 24px 0;
}

.fp-contacts-grid {
	display: grid;
	grid-template-columns: minmax(320px, 460px) 1fr;
	gap: 16px;
}

.fp-contacts-card {
	background: linear-gradient(155deg, #ffffff 0%, #f4faf7 55%, #eef7f2 100%);
	border: 1px solid rgba(36, 97, 67, .15);
	border-radius: 20px;
	box-shadow: 0 22px 48px rgba(15, 42, 30, .12);
	padding: 28px;
}

.fp-contacts-kicker {
	display: inline-flex;
	padding: 6px 10px;
	border-radius: 999px;
	background: rgba(36, 97, 67, .12);
	color: var(--brand-green-900);
	font-size: 12px;
	font-weight: 800;
	letter-spacing: .3px;
	text-transform: uppercase;
}

.fp-contacts-title {
	margin: 12px 0 8px;
	font-size: clamp(24px, 3vw, 34px);
	line-height: 1.1;
	color: var(--brand-green-900);
}

.fp-contacts-lead {
	margin: 0 0 16px;
	color: rgba(15, 42, 30, .74);
}

.fp-contacts-list {
	display: grid;
	gap: 10px;
	margin-bottom: 18px;
}

.fp-contacts-phone {
	font-size: 26px;
	font-weight: 900;
	color: var(--brand-green-900);
	text-decoration: none;
}

.fp-contacts-phone:hover {
	color: var(--brand-red);
}

.fp-contacts-row {
	display: flex;
	gap: 8px;
	color: rgba(15, 42, 30, .88);
	line-height: 1.45;
	align-items: flex-start;
}

.fp-contacts-label {
	color: rgba(15, 42, 30, .62);
	font-weight: 700;
	min-width: 84px;
}

.fp-contacts-mail {
	color: var(--brand-green-900);
	font-weight: 700;
	text-decoration: none;
	border-bottom: 1px solid rgba(36, 97, 67, .3);
}

.fp-contacts-mail:hover {
	color: var(--brand-red);
	border-bottom-color: rgba(189, 29, 54, .42);
}

.fp-contacts-points {
	list-style: none;
	margin: 0 0 22px;
	padding: 0;
	display: grid;
	gap: 10px;
	border-top: 1px solid rgba(36, 97, 67, .14);
	padding-top: 14px;
}

.fp-contacts-points li {
	position: relative;
	padding: 0 0 0 18px;
	margin: 0;
	color: rgba(15, 42, 30, .88);
	line-height: 1.5;
	font-weight: 600;
	border-left: 2px solid rgba(36, 97, 67, .18);
}

.fp-contacts-points li:before {
	content: "";
	position: absolute;
	left: -5px;
	top: 9px;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: var(--brand-red);
	box-shadow: 0 0 0 3px rgba(189, 29, 54, .12);
}

.fp-contacts-points li:after { content: none; }

.fp-contacts-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 2px;
}

.fp-contacts-actions .button {
	min-width: 240px;
}

.fp-contacts-map-wrap {
	overflow: hidden;
	border-radius: 20px;
	border: 1px solid rgba(36, 97, 67, .16);
	box-shadow: 0 22px 48px rgba(15, 42, 30, .12);
	min-height: 560px;
	background: #e9f1ed;
}

.fp-contacts-map {
	width: 100%;
	height: 100%;
	min-height: 560px;
	border: 0;
	display: block;
}

@media (max-width: 980px) {
	.fp-contacts-grid {
		grid-template-columns: 1fr;
	}

	.fp-contacts-map-wrap,
	.fp-contacts-map {
		min-height: 420px;
	}
}

/* FAQ accordion block (fp_faq.php) */
.faq {
	padding: 52px 0;
}

.faq-accordion-wrap {
	margin-top: 18px;
	display: grid;
	gap: 12px;
}

.faq-acc-item {
	border: 1px solid rgba(16, 24, 40, 0.12);
	border-radius: 14px;
	background: #fff;
	overflow: hidden;
	transition: border-color 180ms ease, box-shadow 180ms ease, transform 180ms ease, background 180ms ease;
}

.faq-acc-item.is-open {
	border-color: rgba(0, 120, 255, 0.35);
	background: linear-gradient(180deg, rgba(0, 120, 255, 0.04), rgba(255, 255, 255, 0) 70%);
	box-shadow: 0 14px 40px rgba(0, 120, 255, 0.12);
}

.faq-acc-item:hover {
	border-color: rgba(16, 24, 40, 0.18);
	box-shadow: 0 12px 28px rgba(16, 24, 40, 0.06);
	transform: translateY(-1px);
}

.faq-acc-question {
	margin: 0;
}

.faq-acc-toggle {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;

	padding: 20px 22px;
	cursor: pointer;
	background: transparent;

	font-family: inherit;
	color: inherit;
	text-align: left;
}

.faq-acc-text {
	font-size: 16.5px;
	font-weight: 650;
	line-height: 1.3;
	letter-spacing: -0.01em;
	color: rgba(16, 24, 40, 0.98);
}

.faq-acc-arrow {
	width: 26px;
	height: 26px;
	flex: 0 0 26px;
	position: relative;
	border-radius: 10px;
	background: rgba(0, 120, 255, 0.08);
}

.faq-acc-arrow::before {
	content: "";
	position: absolute;
	left: 50%;
	top: 50%;
	width: 9px;
	height: 9px;
	border-right: 2px solid rgba(0, 120, 255, 0.95);
	border-bottom: 2px solid rgba(0, 120, 255, 0.95);
	transform: translate(-50%, -60%) rotate(45deg);
	transition: transform 220ms ease;
}

.faq-acc-item.is-open .faq-acc-arrow::before {
	transform: translate(-50%, -45%) rotate(-135deg);
}

.faq-acc-toggle:focus-visible {
	outline: 3px solid rgba(0, 120, 255, 0.35);
	outline-offset: 4px;
	border-radius: 12px;
}

.faq-acc-panel {
	max-height: 0;
	opacity: 0;
	overflow: hidden;
	transition: opacity 180ms ease, max-height 260ms cubic-bezier(0.2, 0.8, 0.2, 1);
	will-change: max-height;
}

.faq-acc-item.is-open .faq-acc-panel {
	opacity: 1;
	max-height: 1000px; /* временно, чтобы первый открытый пункт был виден сразу до JS */
}

.faq-acc-answer {
	padding: 0 22px 22px 22px;
	color: rgba(16, 24, 40, 0.92);
	font-size: 15.5px;
	line-height: 1.6;
	border-top: 1px solid rgba(16, 24, 40, 0.08);
	padding-top: 16px;
}

@media (prefers-reduced-motion: reduce) {
	.faq-acc-panel {
		transition: none;
	}

	.faq-acc-arrow::before {
		transition: none;
	}
}

/* Scroll to top button */
.scroll-to-top {
	position: fixed;
	right: 18px;
	bottom: 18px;
	width: 52px;
	height: 52px;
	border-radius: 50%;
	border: 0;
	background: var(--brand-blue);
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	z-index: 9999;
	box-shadow: 0 16px 38px rgba(46, 80, 119, 0.28);
	transform: translateY(12px);
	opacity: 0;
	visibility: hidden;
	transition: opacity 180ms ease, transform 180ms ease, box-shadow 180ms ease;
}

.scroll-to-top:hover {
	box-shadow: 0 22px 52px rgba(46, 80, 119, 0.35);
	transform: translateY(10px);
}

.scroll-to-top:active {
	transform: translateY(12px) scale(0.98);
}

.scroll-to-top.is-visible {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

@media (max-width: 800px) {
	.scroll-to-top {
		right: 14px;
		bottom: 14px;
		width: 48px;
		height: 48px;
	}
}

/* FP table block (fp_table.php) */
.fp-table-wrap {
	margin-top: 20px;
	overflow-x: auto;
}

.fp-table {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0;
	border-radius: 16px;
	overflow: hidden;
	box-shadow: 0 18px 46px rgba(15, 42, 30, 0.10);
	background: #fff;
	font-size: 15px;
}

.fp-table-caption {
	caption-side: top;
	text-align: left;
	padding: 16px 18px 0 18px;
	font-weight: 800;
	color: #2E5077;
	line-height: 1.25;
}

.fp-table-head {
	background: linear-gradient(180deg, rgba(36, 97, 67, 0.10) 0%, rgba(36, 97, 67, 0.04) 100%);
}

.fp-table-th {
	padding: 14px 18px;
	font-weight: 900;
	color: #2E5077;
	border-bottom: 1px solid rgba(15, 42, 30, 0.10);
	white-space: nowrap;
	text-align: left;
}

.fp-table-tr:nth-child(odd) .fp-table-td {
	background: rgba(239, 238, 238, 0.28);
}

.fp-table-td {
	padding: 13px 18px;
	border-bottom: 1px solid rgba(15, 42, 30, 0.08);
	color: rgba(15, 42, 30, 0.88);
	vertical-align: top;
	word-break: break-word;
}

/* When the table has no <thead>, the first row in <tbody> acts like a header. */
.fp-table tbody tr:first-child .fp-table-td {
	color: #2E5077;
	font-weight: 900;
	background: linear-gradient(180deg, rgba(36, 97, 67, 0.10) 0%, rgba(36, 97, 67, 0.03) 100%);
	border-bottom-color: rgba(15, 42, 30, 0.12);
}

.fp-table-tr:hover .fp-table-td {
	background: rgba(36, 97, 67, 0.07);
}

.fp-table tr:last-child td {
	border-bottom: 0;
}

@media (max-width: 640px) {
	.fp-table-tr .fp-table-td:nth-child(2) {
		width:135px;
	}
	.fp-table-th,
	.fp-table-td {
		padding: 12px 14px;
		font-size:13px;
	}

	.fp-table-caption {
		padding-left: 14px;
		padding-right: 14px;
	}
}
section.instance_newmsk.single-post-block ul li img {
    margin-left: -23px;
    margin-bottom: -3px;
    width: 15px;
}
section.instance_newmsk.single-post-block ul.numbers li img{
	width: 23px;
    margin-bottom: -7px;
}
.content li a,
.entry-content li a,
.spisok li a {
    text-decoration: underline !important;
}
.single-post-block p a,
.single-post-block li a {
    color: #2b6cb0;
    text-decoration: underline !important;
    text-underline-offset: 3px;
    transition: color 0.2s ease;
}

.single-post-block p a:hover,
.single-post-block li a:hover {
    color: #1e4f85;
}
.gift-offer-widget {
    position: fixed;
    right: 22px;
    top: 58%;
    bottom: auto;
    width: 108px;
    z-index: 99999;
    opacity: 0;
    visibility: hidden;
    transform: translateX(140px) translateY(-50%) scale(0.92);
    transition: opacity 0.45s ease, transform 0.55s ease, visibility 0.45s ease;
    pointer-events: none;
}

.gift-offer-widget.is-visible {
    opacity: 1;
    visibility: visible;
    transform: translateX(0) translateY(-50%) scale(1);
    pointer-events: auto;
}

.gift-offer-widget__link {
    position: relative;
    display: block;
    text-decoration: none;
    outline: none;
}

.gift-offer-widget__img {
    display: block;
    width: 100%;
    height: auto;
    border-radius: 18px;
    animation: giftFloat 2.8s ease-in-out infinite;
    filter: drop-shadow(0 12px 24px rgba(23, 58, 99, 0.18));
    transition: transform 0.25s ease;
}

.gift-offer-widget__link:hover .gift-offer-widget__img {
    transform: scale(1.06);
}

.gift-offer-widget__pulse {
    position: absolute;
    inset: 12px;
    border-radius: 22px;
    pointer-events: none;
    animation: giftPulse 2.2s ease-out infinite;
    border: 2px solid rgba(39, 174, 96, 0.28);
}

.gift-offer-widget__hint {
    margin-top: 8px;
    padding: 8px 10px;
    font-size: 13px;
    line-height: 1.2;
    font-weight: 600;
    text-align: center;
    color: #173A63;
    background: rgba(255, 255, 255, 0.96);
    border: 1px solid rgba(23, 58, 99, 0.08);
    border-radius: 12px;
    box-shadow: 0 8px 20px rgba(23, 58, 99, 0.08);
    animation: hintBlink 2.8s ease-in-out infinite;
}

.gift-offer-widget__close {
    position: absolute;
    top: -8px;
    right: -8px;
    width: 28px;
    height: 28px;
    border: none;
    border-radius: 50%;
    background: #ffffff;
    color: #173A63;
    font-size: 18px;
    line-height: 28px;
    text-align: center;
    cursor: pointer;
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.15);
    transition: transform 0.2s ease, background 0.2s ease;
}

.gift-offer-widget__close:hover {
    transform: scale(1.08);
    background: #f4f8fb;
}

@keyframes giftFloat {
    0% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-8px);
    }
    100% {
        transform: translateY(0);
    }
}

@keyframes giftPulse {
    0% {
        transform: scale(0.92);
        opacity: 0.75;
    }
    70% {
        transform: scale(1.16);
        opacity: 0;
    }
    100% {
        transform: scale(1.16);
        opacity: 0;
    }
}

@keyframes hintBlink {
    0%, 100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-2px);
    }
}

@media (max-width: 768px) {
    .gift-offer-widget {
        right: 10px;
        top: 58%;
        bottom: auto;
        width: 68px;
    }

    .gift-offer-widget__hint {
        font-size: 10px;
        padding: 5px 6px;
    }

    .gift-offer-widget__close {
        width: 20px;
        height: 20px;
        font-size: 14px;
        line-height: 20px;
    }
}