/* Страница контактов (contacts.html) */

.hero-contact {
	position: relative;
	background-color: var(--c-navy);
	padding: 8rem 0 6rem;
	min-height: 500px;
	display: flex;
	align-items: center;
	overflow: hidden;
}

.hero-contact-img {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center;
	opacity: 0.15;
	z-index: 0;
}

.hero-contact-gradient {
	position: absolute;
	inset: 0;
	background: linear-gradient(to bottom right, rgba(16, 37, 66, 0.95), rgba(16, 24, 32, 0.9));
	z-index: 1;
}

.page-contacts .grid-4 {
	display: grid;
	gap: 1.5rem;
	grid-template-columns: 1fr;
}

@media (min-width: 640px) {
	.page-contacts .grid-4 {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1024px) {
	.page-contacts .grid-4 {
		grid-template-columns: repeat(4, 1fr);
	}
}

.page-contacts .grid-3 {
	display: grid;
	gap: 2rem;
	grid-template-columns: 1fr;
}

@media (min-width: 768px) {
	.page-contacts .grid-3 {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1024px) {
	.page-contacts .grid-3 {
		grid-template-columns: repeat(3, 1fr);
		gap: 2.5rem;
	}
}

.ct-card {
	background-color: var(--c-gray-50);
	padding: 2rem;
	border-top: 4px solid var(--c-red);
	transition: all 0.3s ease;
}

.ct-card:hover {
	box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1);
}

.ct-icon-box {
	width: 4rem;
	height: 4rem;
	background-color: var(--c-navy);
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 1.5rem;
}

.ct-icon-box i {
	color: var(--c-white);
	font-size: 1.5rem;
}

.reg-card {
	background: var(--c-white);
	padding: 2.5rem;
	border-left: 4px solid var(--c-navy);
	transition: all 0.3s ease;
	box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05);
}

.reg-card:hover {
	box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
	transform: translateY(-4px);
}

.reg-badge {
	padding: 0.35rem 0.75rem;
	background: var(--c-red);
	color: var(--c-white);
	font-size: 0.75rem;
	font-weight: 800;
	text-transform: uppercase;
}

.reg-badge.secondary {
	background: rgba(16, 37, 66, 0.1);
	color: var(--c-navy);
}

.contacts-map-frame {
	width: 100%;
	height: 500px;
	background-color: var(--c-navy);
	padding: 5px;
	border-radius: 4px;
	box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1);
	position: relative;
	overflow: hidden;
}

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

.contacts-form-section {
	background-color: var(--c-gray-50);
}

/* Contact Form 7 в блоке обратной связи */
.contacts-form-embed .wpcf7 {
	margin: 0;
}

.contacts-form-embed .wpcf7-form label {
	display: block;
	margin-bottom: 0.5rem;
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--c-navy);
}

.contacts-form-embed .wpcf7-form .form-input,
.contacts-form-embed .wpcf7-form input[type="text"],
.contacts-form-embed .wpcf7-form input[type="email"],
.contacts-form-embed .wpcf7-form input[type="tel"],
.contacts-form-embed .wpcf7-form textarea {
	width: 100%;
}

.contacts-form-embed .wpcf7-form p {
	margin: 0 0 1rem;
}

.contacts-form-embed .wpcf7-not-valid-tip {
	margin-top: 0.25rem;
	font-size: 0.8125rem;
	color: #c00;
}

.contacts-form-embed .wpcf7-form input[type="submit"] {
	width: 100%;
	justify-content: center;
	margin-top: 0.5rem;
}
