:root {
	--icon-check: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAxIDEiPjxwYXRoIGQ9Ik0uMDQuNjI3TC4xNDYuNTIuNDMuODA0LjMyMy45MXptLjE3Ny4xNzdMLjg1NC4xNjcuOTYuMjczLjMyMy45MXoiIGZpbGw9IiNmZmYiLz48L3N2Zz4=);
	/*--icon-burger: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMjAiIGhlaWdodD0iMjAiIHZpZXdCb3g9IjAgMCAyMCAyMCIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48cGF0aCBkPSJNMi43NzggNS44MzNoMTQuNDQ0YS41NTYuNTU2IDAgMCAwIC41NTYtLjU1NlYzLjg5YS41NTYuNTU2IDAgMCAwLS41NTYtLjU1NkgyLjc3OGEuNTU2LjU1NiAwIDAgMC0uNTU2LjU1NnYxLjM4OGMwIC4zMDcuMjQ5LjU1Ni41NTYuNTU2Wm0wIDUuNTU2aDE0LjQ0NGEuNTU2LjU1NiAwIDAgMCAuNTU2LS41NTZWOS40NDRhLjU1Ni41NTYgMCAwIDAtLjU1Ni0uNTU1SDIuNzc4YS41NTYuNTU2IDAgMCAwLS41NTYuNTU1djEuMzg5YzAgLjMwNy4yNDkuNTU2LjU1Ni41NTZabTAgNS41NTVoMTQuNDQ0YS41NTYuNTU2IDAgMCAwIC41NTYtLjU1NXYtMS4zOWEuNTU2LjU1NiAwIDAgMC0uNTU2LS41NTVIMi43NzhhLjU1Ni41NTYgMCAwIDAtLjU1Ni41NTZ2MS4zODljMCAuMzA2LjI0OS41NTUuNTU2LjU1NVoiIGZpbGw9IiMwQzVFOTYiLz48L3N2Zz4=);*/

	--color-1: #211212;
	--color-2: #EAE0D5;
	--color-3: #8A7D5C;
	--color-4: #E6C4AA;
	--color-5: #F5F5F5;
	--color-6: #969696;
}

/*
[class*="icon--"] {display: inline-block; vertical-align: middle; flex: none; background-repeat: no-repeat; background-size: contain; background-position: center;}
.icon--burger {width: 20px; height: 20px; background-image: var(--icon-burger);}
*/

@font-face {
	font-family: 'Manrope';
	src: url('../fonts/Manrope-VariableFont_wght.ttf') format('truetype-variations');
	src: url('../fonts/Manrope-VariableFont_wght.ttf') format('truetype') tech('variations');
	font-weight: 100 1000;
}
@font-face {font-family: 'Play'; font-style: normal; font-weight: 400; src: url("../fonts/Play-Regular.ttf") format('truetype');}
@font-face {font-family: 'Play'; font-style: normal; font-weight: 700; src: url("../fonts/Play-Bold.ttf") format('truetype');}



/*-------------------------------- common ---------------------------------------------*/

.flex-center	{display: flex; align-items: center; justify-content: center;}
.flex-between	{display: flex; align-items: center; justify-content: space-between;}
.flex										{display: flex;}
.flex.inline								{display: inline-flex;}
.flex.center, 	.justify-content-center		{justify-content: center;}
.flex.between, 	.justify-content-between	{justify-content: space-between;}
.flex.around, 	.justify-content-around		{justify-content: space-around;}
.flex.start, 	.justify-content-start		{justify-content: flex-start;}
.flex.end, 		.justify-content-end		{justify-content: flex-end;}
.flex.middle, 	.align-items-center			{align-items: center;}
.flex.baseline,	.align-items-baseline		{align-items: baseline;}
.flex.top, 		.align-items-start			{align-items: flex-start;}
.flex.bottom, 	.align-items-end			{align-items: flex-end;}
.flex.stretch, 	.align-items-stretch		{align-items: stretch;}
.align-content-center	{align-content: center;}
.align-content-baseline	{align-content: baseline;}
.align-content-start	{align-content: flex-start;}
.align-content-end		{align-content: flex-end;}
.align-content-stretch	{align-content: stretch;}
.flex.column,			[class*="flex-"].column	{flex-direction: column;}
.flex.wrap,				[class*="flex-"].wrap	{flex-wrap: wrap;}
.flex > .grow,			[class*="flex-"] > .grow,			[class*="v-row-"] > .grow,			.flex-grow			{flex-grow: 1;}
.flex > .self-start,	[class*="flex-"] > .self-start,		[class*="v-row-"] > .self-start,	.align-self-start	{align-self: self-start;}
.flex > .self-middle,	[class*="flex-"] > .self-middle,	[class*="v-row-"] > .self-middle,	.align-self-center	{align-self: center;}
.flex > .self-end,		[class*="flex-"] > .self-end,		[class*="v-row-"] > .self-end,		.align-self-end		{align-self: flex-end;}
.flex > .self-stretch,	[class*="flex-"] > .self-stretch,	[class*="v-row-"] > .self-stretch,	.align-self-stretch	{align-self: stretch;}
.flex > .self-left,		[class*="flex-"] > .self-left,		[class*="v-row-"] > .self-left							{margin-right: auto;}
.flex > .self-center,	[class*="flex-"] > .self-center,	[class*="v-row-"] > .self-center,	.justify-center		{margin-left: auto; margin-right: auto;}
.flex > .self-right,	[class*="flex-"] > .self-right,		[class*="v-row-"] > .self-right							{margin-left: auto;}
.flex > img, [class*="flex-"] > img {flex: none;}
.flex > svg, [class*="flex-"] > svg {flex: none;}

.grid			    {display: grid;}
.grid.inline		{display: inline-grid;}
.grid.flow-column	{grid-auto-flow: column;}
.grid.flow-row		{grid-auto-flow: row;}
.grid > .row-span-2 {grid-row: span 2;}
.grid > .col-span-2	{grid-column: span 2;}

.v-row,
.v-row-2,
.v-row-3,
.v-row-4,
.v-row-5			{display: flex; flex-wrap: wrap; --vgap: 40px; --hgap: 20px; gap: var(--vgap) var(--hgap); width: 100%;}

.v-col-100,
.v-row > .v-col		{flex: 0 0 100%; max-width: 100%;}

.v-row-2 > .v-col	{flex: 0 0 calc(100% / 2 * 1 - (var(--hgap) / 2 * 1)); max-width: calc(100% / 2 * 1 - (var(--hgap) / 2 * 1));}

.v-row-3 > .v-col	{flex: 0 0 calc(100% / 3 * 1 - (var(--hgap) / 3 * 2)); max-width: calc(100% / 3 * 1 - (var(--hgap) / 3 * 2));}
.v-row-3 > .v-col-15{flex: 0 0 calc(100% / 3 * 1.5 - (var(--hgap) / 3 * 1.5)); max-width: calc(100% / 3 * 1.5 - (var(--hgap) / 3 * 1.5));}
.v-row-3 > .v-col-2 {flex: 0 0 calc(100% / 3 * 2 - (var(--hgap) / 3 * 1)); max-width: calc(100% / 3 * 2 - (var(--hgap) / 3 * 1));}

.v-row-4 > .v-col	{flex: 0 0 calc(100% / 4 * 1 - (var(--hgap) / 4 * 3)); max-width: calc(100% / 4 * 1 - (var(--hgap) / 4 * 3));}
.v-row-4 > .v-col-2 {flex: 0 0 calc(100% / 4 * 2 - (var(--hgap) / 4 * 2)); max-width: calc(100% / 4 * 2 - (var(--hgap) / 4 * 2));}
.v-row-4 > .v-col-3 {flex: 0 0 calc(100% / 4 * 3 - (var(--hgap) / 4 * 1)); max-width: calc(100% / 4 * 3 - (var(--hgap) / 4 * 1));}

.v-row-5 > .v-col	{flex: 0 0 calc(100% / 5 * 1 - (var(--hgap) / 5 * 4)); max-width: calc(100% / 5 * 1 - (var(--hgap) / 5 * 4));}
.v-row-5 > .v-col-2 {flex: 0 0 calc(100% / 5 * 2 - (var(--hgap) / 5 * 3)); max-width: calc(100% / 5 * 2 - (var(--hgap) / 5 * 3));}
.v-row-5 > .v-col-3 {flex: 0 0 calc(100% / 5 * 3 - (var(--hgap) / 5 * 2)); max-width: calc(100% / 5 * 3 - (var(--hgap) / 5 * 2));}
.v-row-5 > .v-col-4 {flex: 0 0 calc(100% / 5 * 4 - (var(--hgap) / 5 * 1)); max-width: calc(100% / 5 * 4 - (var(--hgap) / 5 * 1));}

.v-row {flex-wrap: nowrap;}

.gap-10	{gap: 10px; --vgap: 10px; --hgap: 10px;}
.gap-20	{gap: 20px; --vgap: 20px; --hgap: 20px;}

.row-gap-6 {row-gap: 6px; --vgap: 6px;}
.row-gap-10 {row-gap: 10px; --vgap: 10px;}
.row-gap-15 {row-gap: 15px; --vgap: 15px;}
.row-gap-20 {row-gap: 20px; --vgap: 20px;}
.row-gap-25 {row-gap: 25px; --vgap: 25px;}
.row-gap-30 {row-gap: 30px; --vgap: 30px;}
.row-gap-40 {row-gap: 40px; --vgap: 40px;}
.row-gap-45 {row-gap: 45px; --vgap: 45px;}
.row-gap-60 {row-gap: 60px; --vgap: 60px;}

.col-gap-3	{column-gap: 3px; --hgap: 3px;}
.col-gap-5	{column-gap: 5px; --hgap: 5px;}
.col-gap-10	{column-gap: 10px; --hgap: 10px;}
.col-gap-15	{column-gap: 15px; --hgap: 15px;}
.col-gap-20	{column-gap: 20px; --hgap: 20px;}
.col-gap-30	{column-gap: 30px; --hgap: 30px;}
.col-gap-40	{column-gap: 40px; --hgap: 40px;}
.col-gap-50 {column-gap: 50px; --hgap: 50px;}
.col-gap-60 {column-gap: 60px; --hgap: 60px;}
.col-gap-70 {column-gap: 70px; --hgap: 70px;}
.col-gap-90 {column-gap: 90px; --hgap: 90px;}
.col-gap-100 {column-gap: 100px; --hgap: 100px;}

.ml-a {margin-left: auto;}
.mr-a {margin-right: auto;}
.mt-5 {margin-top: 5px;}
.mt-20 {margin-top: 20px;}
.mt-40 {margin-top: 40px;}
.mt-60 {margin-top: 60px;}
.mt-80 {margin-top: 80px;}
.mt--80 {margin-top: -80px;}
.mt-120 {margin-top: 120px;}
.mb-a {margin-bottom: auto;}
.mb-40 {margin-bottom: 40px;}
.mb-60 {margin-bottom: 60px;}
.mb-80 {margin-bottom: 80px;}

.pt-5 {padding-top: 5px;}
.pt-20 {padding-top: 20px;}
.pt-40 {padding-top: 40px;}

[class*="v-row-"] > [class*="v-col"] > img {max-width: 100%;}
[class*="v-row-"] .flex-100 {flex: 0 0 100%; max-width: 100%;}

.d-block {display: block !important;}

.w-100 {width: 100% !important;}
.mxw-500 {width: 100%; max-width: 500px;}
.mxw-1000 {width: 100%; max-width: 1000px;}

.reset-float {clear: both;}

/*-------------------------------- body ---------------------------------------------*/

body {font-family: "Manrope", serif; font-weight: 400; font-size: 14px; line-height: 1.2; color: var(--color-1); background: #fff;}
body.locked {overflow: hidden; position: relative;}
/*body.locked::before {content: ''; width: 100%; height: 100%; position: absolute; left: 0; top: 0; background: rgba(17 18 26 / 0.9); z-index: 1;}*/

/*.main-title {font-family: 'Manrope', serif; font-size: 48px; text-transform: uppercase; letter-spacing: 2px;}
.main-title span {white-space: nowrap;}
.sub-title {font-family: 'Manrope', serif; font-weight: 400; font-size: 20px; color: #fff; max-width: 380px; position: relative; margin-top: 10px;}
.sub-title i {color: #E5C3AA;}
.sub-title img {position: absolute;	top: -17px;	left: 135px;}
.sub-title__num {font-size: 60px; margin-left: 5px;}*/

.title {font-family: 'Play', serif; font-weight: 400; font-size: 96px; color: var(--color-1); text-align: center; position: relative;}
/*.title::after {content: ''; width: 104px; height: 48px; background: url(../img/icon-title.png); position: absolute; left: -150px; top: 0;}
.title-wrapper {margin-bottom: 40px;}
.title-wrapper .title {margin-bottom: 0;}*/

.scroll, .hand {cursor: pointer !important;}
.dn {display: none; !important;}

.float-pic {display: flex; flex-wrap: wrap;}
.float-pic > .pic-wrapper {flex: 0 0 247px; height: 184px;}
.float-pic > .text-wrapper {flex: 0 0 calc(100% - 247px); padding-left: 24px;}
.pic-wrapper {position: relative; overflow: hidden; border-radius: 20px;}
.pic-wrapper img {max-width: 100%; height: auto;}
.video-wrapper {width: 100%; position: relative; height: 0; padding-bottom: 56.25%; overflow: hidden; border-radius: 20px;}
.video-wrapper iframe {position: absolute; top: 0; left: 0; width: 100%; height: 100%; border-width: 0; outline-width: 0; display: block;}
.video-wrapper video {position: absolute; top: 0; left: 0; width: 100%; height: 100%; border-width: 0; outline-width: 0; display: block;}
.video-wrapper .play-icon {position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 19%; height: 132px; cursor: pointer;}
.i-fluid {max-width: 100%; height: auto;}
.fit > img {width: 100%; height: 100%; object-fit: cover; display: block;}
.fit-contain > img {width: 100%; height: 100%; object-fit: contain;}

.relative {position: relative;}
.overflow-hidden {overflow: hidden;}
.round {border-radius: 50%;}
.round-hidden {border-radius: 50%; overflow: hidden;}

h1, h2, h3, h4, h5, h6 {margin: 0; font-size: inherit; font-weight: inherit;}
.t-300 {font-weight: 300 !important;}
.t-400, .regular {font-weight: 400 !important;}
.t-500 {font-weight: 500 !important;}
.t-700, b, strong, .t-bold {font-weight: 700 !important;}
.t-900 {font-weight: 900 !important;}

.uppercase {text-transform: uppercase;}
.t-left {text-align: left;}
.t-right {text-align: right;}
.t-center {text-align: center;}
.b-center {margin-left: auto; margin-right: auto;}
.t-muted {color: var(--color-6) !important;}
.bg-5 {background-color: #f5f5f5 !important;}
.c-light {color: var(--color-5) !important;}
.c-black {color: #000 !important;}
.c-white {color: #fff !important;}
.underline {--color-text: inherit; border-bottom: 1px solid var(--color-text);}
.hr {height: 1px; background: #9D7F64; margin: 16px 0;}
.intro-text {display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 4; overflow: hidden; margin-bottom: 8px;}
.intro-text.full-text {overflow: visible; -webkit-line-clamp: unset;}

.title-plain ,.content-inner__article h2, .content-inner__article h3,.content-inner__service h2{font-family: 'Play', serif; font-size: 30px; margin-bottom: 20px; margin-top: 40px;}
.content-inner__article h3{font-size: 26px;}
.title-plain span {color: #9D7F64;}
.text-plain {font-weight: 500; font-size: 16px; line-height: 1.4; color: #221313;}
.text-plain li {margin-bottom: 10px;}
.text-plain ul,
ul.text-plain {margin-bottom: 20px;}
/*.text-plain li::before,
ul.text-plain li::before {top: 9px;}*/

.toc-plain {margin-bottom: 20px;}
.toc-plain li {font-weight: 500; font-size: 16px; line-height: 1.4; color: #221313; margin-bottom: 10px;}
.toc-plain li::before {content: none;}
.toc-plain li a {text-decoration: none;}
.toc-plain li a:hover {text-decoration: underline;}

.media-plain-right {float: right; margin: 0 0 20px 20px;}
.media-plain-left {float: left; margin: 0 20px 20px 0;}
.media-plain-left ~ ul {clear: both;}
.media-plain-left ~ * ul {clear: both;}

.text-plain__pic {border-radius: 20px; width: 100%; height: auto;}

ul, ol {padding-left: 20px; margin-bottom: 0; list-style-type: none;}
ol {counter-reset: num;}
li {display: block; position: relative; margin-bottom: 20px;}

ul li::before {content: ''; width: 4px; height: 4px; border-radius: 50%; background: #221313; position: absolute; left: -12px; top: 7px;}
ol li::before {content: counter(num) '.'; counter-increment: num; position: absolute; left: -14px; top: 0;}
ul:last-child {margin-bottom: 0;}

p {margin-bottom: 20px;}
p:last-child {margin-bottom: 0;}

svg {vertical-align: middle; max-width: 100%; height: auto;}
.empty-pic {width: 100%; height: 300px;}

.only-mob {display: none !important;}
@media (max-width: 767px){
	.only-pc {display: none !important;}
	.only-mob {display: block !important;}
}


/*-------------------------------- links ---------------------------------------------*/

a {color: inherit;}
a:link {color: inherit; text-decoration: none;}
a:visited {color: inherit;}
a:hover {color: inherit;}

a.link,
.link {color: #9D7F64;}
.link:hover {text-decoration: none;}


/*-------------------------------- inputs ---------------------------------------------*/

input[type="text"], input[type="email"], input[type="password"], input[type="tel"], input[type="date"], select,	textarea, .input-drop-zone {width: 100%;
	font-size: 14px; color: var(--color-1); padding: 18px 40px; background: transparent; border: 0 solid var(--color-1); border-bottom-width: 1px;}
/*input[type="text"], input[type="email"], input[type="password"], input[type="tel"], input[type="date"], select {height: 80px;}*/

select {width: auto;}
select.chosen-select {height: 45px; border: none; box-shadow: none; border-radius: 3px; background: #fff; padding: 14px 24px 14px 9px; min-width: 123px;
	font-size: 14px; font-weight: 400; letter-spacing: .7px; color: #221313;}

input[type="text"]::placeholder,
input[type="email"]::placeholder,
input[type="password"]::placeholder,
input[type="tel"]::placeholder,
input[type="date"]::placeholder,
textarea::placeholder {font-size: 14px; color: var(--color-1);}

input[type="text"]:hover,
input[type="email"]:hover,
input[type="password"]:hover,
input[type="tel"]:hover,
input[type="date"]:hover,
textarea:hover,
select:hover {}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
input[type="tel"]:focus,
input[type="date"]:focus,
textarea:focus,
select:focus {}

input[type="text"]:disabled,
input[type="email"]:disabled,
input[type="password"]:disabled,
input[type="tel"]:disabled,
input[type="date"]:disabled,
textarea:disabled ,
select:disabled {border-color: #C9C9C9;}

/*
input[type="date"]::-webkit-datetime-edit {}
input[type="date"]::-webkit-datetime-edit-fields-wrapper {}
input[type="date"]::-webkit-datetime-edit-text {}
input[type="date"]::-webkit-datetime-edit-month-field {}
input[type="date"]::-webkit-datetime-edit-day-field {}
input[type="date"]::-webkit-datetime-edit-year-field {}
input[type="date"]::-webkit-inner-spin-button {}
input[type="date"]::-webkit-calendar-picker-indicator {opacity: 0; /*background-image: url("../img/icon-calendar.svg"); background-repeat: no-repeat; background-position: 100% center; background-size: 24px; cursor: pointer;}
*/

select {-webkit-appearance: none; -moz-appearance: none; appearance: none; padding-right: 48px; cursor: pointer;}
select option {box-shadow: none;}
.select-wrapper {position: relative;}
.select-wrapper::after {content: ''; background: var(--icon-chevron) center no-repeat; width: 15px; height: 9px; position: absolute; top: calc(50% - 4.5px); right: 9px; pointer-events: none;}

input[type="checkbox"] {width: 20px; height: 20px; background: #ECECEC; border-radius: 0; border: 0; margin-right: 10px;}
[type="submit"] {border: 0;}
input.error, textarea.error, select.error {border-color: #F83939 !important;}
.error-text {font-weight: 500; font-size: 14px; line-height: 18px; color: #F83939; margin-top: 4px;}
input:disabled, textarea:disabled {border-color: #C9C9C9;}

textarea {min-height: 155px; display: block;}
input:focus, textarea:focus {outline: none;}
select:focus {outline: none;}
label {margin: 0;}

*:focus {outline: none;}

.input-icon__wrapper {position: relative;}
.input-icon {position: absolute; width: 46px; height: 46px; left: 30px;	top: calc(50% - 23px);}
.input-icon__wrapper input {padding-left: 86px;}

.js-switch {cursor: pointer;}
.js-slide-list-title {cursor: pointer; position: relative; padding-right: 25px;}
.js-slide-list-title:after {content: ''; width: 15px; height: 9px; background: var(--icon-chevron) center no-repeat; position: absolute; top: calc(50% - 4.5px); right: 0;
	transform: rotate(0deg); transition: transform .2s;}
.js-slide-list-title.expand:after {transform: rotate(-90deg);}
.slide-list-content {display: none;}


/*-------------------------------- fade ---------------------------------------------*/

.fade {-webkit-mask-image: -webkit-gradient(linear, left top, left bottom, from(rgba(0,0,0,1)), to(rgba(0,0,0,.05))); overflow: hidden;}
.fade-60 {-webkit-mask-image: -webkit-gradient(linear, left 60%, left bottom, from(rgba(0,0,0,1)), to(rgba(0,0,0,.05))); overflow: hidden;}


/*-------------------------------- scrollbar ---------------------------------------------*/

.scrollbar {overflow-y: auto;}
.scrollbar::-webkit-scrollbar {width: 4px;}
.scrollbar::-webkit-scrollbar-track {background: transparent;}
.scrollbar::-webkit-scrollbar-thumb {background-color: #9D7F64; border-radius: 10px;}


/*-------------------------------- tabs ---------------------------------------------*/

.tabs-content__item {display: none;}
.tabs-content__item.active {display: block;}


/*-------------------------------- animations ---------------------------------------------*/

.animation-rotation {animation: linear 2s infinite rotation;}
@keyframes rotation {100%{transform: rotate(360deg);}}

@keyframes rotation-counterclockwise {100%{transform: rotate(-360deg);}}


/*-------------------------------- logo ---------------------------------------------*/

/*.logo {display: flex; gap: 0 20px;}*/
a.logo {text-decoration: none;}
/*.logo-text {font-weight: 700; font-size: 14px; color: #fff; line-height: 1;}*/


/*-------------------------------- buttons ---------------------------------------------*/

button.btn,
a.btn,
.btn {height: 52px; width: auto; padding: 0 16px; background: var(--color-1); border-radius: 0; border: none; max-width: 100%; position: relative; text-decoration: none;
	display: inline-flex; align-items: center; justify-content: center; /*flex: none;*/ cursor: pointer; user-select: none; text-align: center;
	color: var(--color-5); font-family: 'Manrope', serif; font-weight: 700; font-size: 14px;}

.btn.transparent {border: 1px solid var(--color-4); background: transparent;}
.btn.transparent.light {color: var(--color-1); font-weight: 400; min-width: 200px;}

.btn.white {background: var(--color-2); color: var(--color-1);}

.btn.btn-form {width: 250px; flex: none;}

.btn.show-more {width: 100%; height: 110px;}

.btn svg {flex: none;}

.border-hover {outline: 1px solid #686868; outline-offset: -1px;}
.border-hover:hover {outline-color: var(--color-4);}

@media (max-width: 575px){.btn {width: 100%;}}


/*-------------------------------- form control input ---------------------------------------------*/

.v-form-control {margin-bottom: 20px; --info-margin: 10px;}

.v-form-control.left {display: flex; align-items: center;}
.v-form-control .label {margin-bottom: 8px; font-weight: 600; font-size: 12px; line-height: 15px;}
.v-form-control.left .label {margin: 0 16px 0 0;}

.textarea-wrapper {position: relative;}
.textarea-wrapper .input-info {position: absolute; right: 8px; bottom: 8px; font-size: 8px; line-height: 10px; color: #999999;}


/*------------------------------- checkboxes --------------------------------------------*/

.v-checkbox-wrapper {display: flex; align-items: center; cursor: pointer; position: relative; width: 100%;}
.v-form-control .v-checkbox-wrapper {margin-bottom: 12px;}
.v-checkbox-inp {position: absolute; top: 0; left: 0; opacity: 0; z-index: -10;}
.v-checkbox {background: #fff; border: 0.5px solid #0C5E96; border-radius: 8px; width: 20px; height: 20px; flex: none; cursor: pointer;}
.v-checkbox-inp:checked + .v-checkbox {background-image: var(--icon-check); background-color: #0C5E96; background-position: 50%; background-repeat: no-repeat;}
.v-checkbox-text {font-size: 12px; line-height: 15px; margin-left: 8px;}
.v-checkbox-text a {text-decoration: underline;}
.v-checkbox-inp:disabled + .v-checkbox {opacity: .5;}
.v-checkbox-inp:disabled ~ .v-checkbox-text {color: #ccc;}


/*------------------------------- radio --------------------------------------------*/

.v-radio-wrapper {display: flex; align-items: center; cursor: pointer; position: relative; width: 100%;}
.flex > .v-radio-wrapper {width: auto; margin-right: 40px;}
.flex > .v-radio-wrapper:last-child { margin-right: 0;}
.v-form-control .flex > .v-radio-wrapper {margin-bottom: 0;}
.v-form-control .v-radio-wrapper {margin-bottom: 24px;}
.v-radio-inp {position: absolute; top: 0; left: 0; opacity: 0; z-index: -10;}
.v-radio {background: #fff; border: 1px solid #C4C4C4; border-radius: 50%; width: 24px; height: 24px; flex: none; display: flex; align-items: center; justify-content: center;}
.v-radio-inp:checked + .v-radio {border-color: #FF4196;}
.v-radio-inp:checked + .v-radio::after {content: ''; width: 16px; height: 16px; background: #FF4196; border-radius: 50%;}
.v-radio-text {margin-left: 12px; font-weight: 500; font-size: 14px; line-height: 18px; color: #678395;}
.v-radio-icon {margin-left: 8px; flex: none;}
.v-radio-icon.wide {margin-left: 7px;}
.v-radio-icon.narrow {margin-left: 11px;}
.v-radio-inp:disabled ~ * {opacity: .5;}


/*------------------------------- carousel-pics --------------------------------------------*/

.js-carousel-pics {position: relative;}
.carousel-pics__inner {position: absolute; left: 0; top: 0; width: 100%; height: 100%; display: flex;}
.carousel-pics__control {width: 100%;}
.carousel-pics__bullets {width: 100%; display: flex; justify-content: center; column-gap: 4px; position: absolute; bottom: 18px; pointer-events: none; z-index: 1;}
.carousel-pics__bullet {width: 27px; height: 3px; border-radius: 5px; background: #D9D9D9;}
.carousel-pics__bullet.active {background: #E5C3AA;}



/*-------------------------------- modal ---------------------------------------------*/

.modal {display: none; position: relative; z-index: 1000;}

.modal__container {padding: 5px; max-width: 1190px;}
.modal__container::-webkit-scrollbar {width: 5px;}
.modal__container::-webkit-scrollbar-track {background: transparent;}
.modal__container::-webkit-scrollbar-thumb {background-color: #e6e6e6; border-radius: 10px;}

.modal__wrapper {padding: 125px 45px; background: #000 url(../img/modal-bg.png) right bottom no-repeat; position: relative; color: var(--color-5); min-height: 730px;}

.modal__title {font-size: 96px; font-family: 'Play', serif; text-align: left; max-width: 790px;}
.modal__sub-title {font-size: 18px; line-height: 1.5; text-align: center; max-width: 790px;}

.modal__close {position: absolute; top: 20px; right: 20px; display: flex; align-items: center; column-gap: 10px; cursor: pointer;}


.modal__wrapper .form-wrapper input {border-color: var(--color-5); color: var(--color-5);}
.modal__wrapper .form-wrapper input::placeholder {color: var(--color-5);}

/*.modal__file-input-wrapper .modal__text {max-width: 200px; word-break: break-word;}*/
/*.modal__file-input-wrapper .btn {width: 210px;}*/

/*.modal-callback .modal__title {font-size: 40px; margin: 18px 0 40px;}*/

/*.modal-order-project .modal__wrapper {padding: 65px 115px;}*/
/*.modal-order-project .modal__title {max-width: 350px; margin: 0 auto 35px;}*/

/*.modal-catalog .modal__wrapper {padding: 65px 115px;}*/
/*.modal-catalog .modal__title {margin-bottom: 15px;}*/

/*.modal-comment .modal__container {max-width: 1135px;}*/
/*.modal-comment .modal__close {color: #E5C3AA;}*/
/*.modal-comment .modal__wrapper {padding: 10px 60px 10px 10px; background: #221313;}*/
/*.comments-item__pic {width: 395px; height: 410px; border-radius: 20px; overflow: hidden; flex: none;}*/
/*.comments-item__pic img {width: 100%; height: 100%; object-fit: cover;}*/
/*.modal-comment .comments-item {padding: 55px 0;}*/
/*.modal-comment .comments-item__name {color: #fff;}*/
/*.modal-comment .comments-item__text {color: #fff; padding-right: 10px;}*/