* {
	margin: 0px;
	padding: 0px;
	box-sizing: border-box;
	outline: none;
}
body {
	font-family: "Montserrat", sans-serif;
}
.head_logo {
	font-family: "Forum", serif;
	display: flex;
	align-items: center;
}
.head_logo .text {
	font-size: 48px;
}
.head_logo .and {
	position: relative;
	width: 30px;
	height: 30px;
}
.head_logo .and .symbol {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-40%, -50%) rotateZ(25deg);
	transform-origin: center center;
	font-size: 89px;
	opacity: .1;
}


section.head {
	position: relative;
	width: 100%;

	background: #dcd5dd;
}
section.head .cont {
	padding: 0 20px;
	width: 100%;
	max-width: 960px;
	margin: 0 auto;
	height: 100%;
	display: flex;
	flex-direction: column;
	gap: 40px;
}
section.head .top {
	width: 100%;
	padding-top: 40px;
	display: flex;
	justify-content: center;
}
section.head .middle {
	width: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
	flex: 1;
}
section.head .middle img {
	height: 500px;
	width: auto;
}
section.head .bottom {
	width: 100%;
	padding-bottom: 80px;
}
section.head .bottom h1 {
	font-size: 48px;
	font-weight: 400;
	text-align: center;
	margin-bottom: 20px;
}
section.head .bottom p {
	font-size: 24px;
	text-align: center;
}

section.date {
	position: relative;
	width: 100%;
	background: #262627;
	color: #fff;
}
section.date .cont {
	padding: 80px 20px;
	width: 100%;
	max-width: 960px;
	margin: 0 auto;
}
section.date h2 {
	font-family: "Forum", serif;
	font-weight: 400;
	font-size: 64px;
	text-align: center;
}
section.date .title_date {
	font-size: 24px;
	text-align: center;
	margin: 80px 0px 10px 0px;
}
section.date .calendar {
	margin: 0 auto;
	display: grid;
	grid-template-columns: repeat(7, 1fr);
	grid-template-rows: repeat(6, 1fr);
	gap: 4px;
	max-width: 500px;
	width: 100%;
	height: 400px;
}
section.date .calendar div {
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 18px;
}
section.date .calendar div.op {
	opacity: .2;
}
section.date .calendar div.active {
	font-weight: 600;
	position: relative;
}
section.date .calendar div img {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);

	user-select: none !important;
	pointer-events: none;
}




section.mesto {
	position: relative;
	width: 100%;
	background: #fff;
	color: #000;
}
section.mesto .cont {
	padding: 80px 20px;
	width: 100%;
	max-width: 960px;
	margin: 0 auto;
}
section.mesto h2 {
	font-family: "Forum", serif;
	font-weight: 400;
	font-size: 64px;
	text-align: center;
	margin-bottom: 80px;
}

section.mesto .img img {
	width: 100%;
	height: auto;
}
section.mesto .top {
	font-size: 22px;
	margin-bottom: 40px;
	text-align: center;
}
section.mesto .bottom {
	font-size: 22px;
	margin-top: 40px;
	text-align: center;
}




section.timing {
	position: relative;
	width: 100%;
	background: #262627;
	color: #fff;
}
section.timing .cont {
	padding: 80px 20px;
	width: 100%;
	max-width: 960px;
	margin: 0 auto;
}
section.timing h2 {
	font-family: "Forum", serif;
	font-weight: 400;
	font-size: 64px;
	text-align: center;
	margin-bottom: 80px;
}

section.timing .table {
	display: flex;
	flex-direction: column;
	gap: 40px;
	width: 100%;
	max-width: 500px;
	margin: 0 auto;
}

section.timing .table {
	display: flex;
	flex-direction: column;
	gap: 40px;
	width: 100%;
	max-width: 400px;
	margin: 0 auto;
}
section.timing .line {
	display: flex;
	gap: 40px;
	align-items: center;
}
section.timing .left {
	font-family: "Forum", serif;
	font-weight: 400;
	font-size: 64px;
}
section.timing .right {
	font-weight: 400;
	font-size: 24px;
}




section.dress {
	position: relative;
	width: 100%;
	background: #fff;
	color: #000;
}
section.dress .cont {
	padding: 80px 20px;
	width: 100%;
	max-width: 960px;
	margin: 0 auto;
}
section.dress h2 {
	font-family: "Forum", serif;
	font-weight: 400;
	font-size: 64px;
	text-align: center;
	margin-bottom: 40px;
}
section.dress p {
	font-weight: 400;
	font-size: 24px;
	text-align: center;
	margin-bottom: 80px;
}


section.dress .list {
	margin: 0 auto;
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	grid-template-rows: repeat(2, 1fr);
	gap: 20px;
	width: 100%;
}
section.dress .block {
	padding: 50% 0;
	position: relative;
}
section.dress .block .circ {
	position: absolute;
	left: 0px;
	top: 0px;
	width: 100%;
	height: 100%;
	border-radius: 100%;
}







section.faq {
	position: relative;
	width: 100%;
	background: #262627;
	color: #FFF;
}
section.faq .cont {
	padding: 80px 20px;
	width: 100%;
	max-width: 960px;
	margin: 0 auto;
}
section.faq h2 {
	font-family: "Forum", serif;
	font-weight: 400;
	font-size: 64px;
	text-align: center;
	margin-bottom: 40px;
}
section.faq p {
	font-weight: 400;
	font-size: 24px;
	text-align: center;
	margin-bottom: 80px;
}
section.faq .list {
	display: flex;
	flex-direction: column;
	gap: 40px;
}
section.faq .block .top {
	font-size: 32px;
	font-weight: 500;
}
section.faq .block {
	display: flex;
	flex-direction: row;
	gap: 40px;
}
section.faq .block .img {
	width: 80px;
}
section.faq .block .text {
	flex: 1 0;
}
section.faq .block .img img {
	width: 100%;
	height: auto;
	opacity: .2;
}
section.faq .block .top {
	margin-bottom: 20px;
}
section.faq .block .bottom {
	color: rgba(255, 255, 255, .75);
	line-height: 150%;
}
section.faq a {
	color: #fff;
	font-weight: 500;
}
section.faq a:hover {
	text-decoration: none;
}






section.opros {
	position: relative;
	width: 100%;
	background: #fff;
	color: #000;
}
section.opros .cont {
	padding: 80px 20px;
	width: 100%;
	max-width: 960px;
	margin: 0 auto;
}
section.opros h2 {
	font-family: "Forum", serif;
	font-weight: 400;
	font-size: 64px;
	text-align: center;
	margin-bottom: 40px;
}
section.opros p {
	font-weight: 400;
	font-size: 24px;
	text-align: center;
	margin-bottom: 80px;
	line-height: 150%;
}
section.opros .form {
	width: 100%;
	max-width: 400px;
	margin: 0 auto;
}
section.opros .lime {
	width: 100%;
	margin-bottom: 40px;
}
section.opros .title {
	font-size: 18px;
	color: rgba(0, 0, 0, 1);
	margin-bottom: 20px !important;
}
section.opros input[type="text"] {
	width: 100%;
	height: 40px;
	border: none;
	background: translate;
	border-bottom: 1px solid rgba(0, 0, 0, .1);
	font-size: 18px;
	transition: .2s ease;
}
section.opros input[type="text"]:focus {
	border-bottom: 1px solid rgba(0, 0, 0, 1) !important;
}
section.opros input[type="text"]:hover {
	border-bottom: 1px solid rgba(0, 0, 0, .5);
}
section.opros input[type="text"]::placeholder {
	color: rgba(0, 0, 0, 0.2);
}
.checkbox-group {
	display: flex;
	flex-direction: row;
	gap: 10px;
}
.checkbox-group input {
	width: 20px;
	height: 20px;
}
.checkbox-group label {
	flex: 1 0;
}
section.opros .lime div {
	margin-bottom: 10px;
}
section.opros .lime div:last-child {
	margin-bottom: 0px;
}


section.opros textarea {
	width: 100%;
	height: 40px;
	border: none;
	background: translate;
	border-bottom: 1px solid rgba(0, 0, 0, .1);
	font-size: 18px;
}
section.opros textarea:focus {
	border-bottom: 1px solid rgba(0, 0, 0, 1) !important;
}
section.opros textarea:hover {
	border-bottom: 1px solid rgba(0, 0, 0, .25);
}
section.opros textarea::placeholder {
	color: rgba(0, 0, 0, 0.2);
}


section.opros button {
	width: 100%;
	height: 60px;
	background: #000;
	color: #fff;
	border: none;
	font-size: 18px;
	font-weight: 500;
	cursor: pointer;
	transition: .2s ease;
}
section.opros button:hover {
	background: rgba(0, 0, 0, 0.75);
}
.cf-turnstile {
	display: none;
}


footer {
	position: relative;
	width: 100%;
	background: #262627;
	color: #fff;
}
footer .cont {
	padding: 80px 20px;
	width: 100%;
	max-width: 960px;
	margin: 0 auto;
}
footer h2 {
	font-family: "Forum", serif;
	font-weight: 400;
	font-size: 64px;
	text-align: center;
	margin-bottom: 80px;
}
footer p {
	font-weight: 400;
	font-size: 24px;
	text-align: center;
	margin-bottom: 80px;
	line-height: 150%;
}
footer .tels {
	display: flex;
	flex-direction: row;
	gap: 40px;
	align-items: center;
	justify-content: center;
	font-size: 22px;
	color: rgba(255, 255, 255, .5);
}
footer .tels a {
	color: #fff;
}
footer .tels a:hover {
	text-decoration: none;
}



/* Стили для модального окна */
.modal {
	display: none;
	position: fixed;
	z-index: 1;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0,0,0,0.85);
}
.modal h2 {
	font-family: "Forum", serif;
	font-weight: 400;
	font-size: 32px;
}
.modal-content {
	background-color: #fefefe;
	padding: 20px;
	border: 1px solid #888;
	width: 100%;
	max-width: 500px;
	border-radius: 8px;
	text-align: center;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
}

.close {
	color: #aaa;
	font-size: 28px;
	font-weight: bold;
	position: absolute;
	top: 10px;
	right: 20px;
	cursor: pointer;
}

.close:hover {
	color: black;
}

.success-icon {
	color: #000;
	font-size: 50px;
	margin-bottom: 20px;
}

.modal-body {
	padding: 20px 0;
}