/**
 * Contact page.
 */

.neomi-contact {
	--neomi-contact-plum: #4e155f;
	--neomi-contact-text: #272334;
	--neomi-contact-muted: #5f596b;
	--neomi-contact-line: rgba(78, 21, 95, 0.16);
	--neomi-contact-field: rgba(125, 104, 103, 0.2);
	direction: rtl;
	min-height: 100vh;
	padding: clamp(1.35rem, 2.8vw, 2.25rem) clamp(1.25rem, 5.4vw, 6.4rem) clamp(1.65rem, 3.2vw, 2.45rem);
	background:
		radial-gradient(circle at 52% 12%, rgba(255, 255, 255, 0.96), rgba(250, 247, 242, 0.74) 42%, rgba(246, 241, 234, 0.88) 100%),
		#fbfaf8;
	color: var(--neomi-contact-text);
	font-family: var(--neomi-font-body);
}

.neomi-contact :where(h1, h2, h3, p) {
	margin: 0;
}

.neomi-contact-hero {
	max-width: 46rem;
	margin-inline: auto;
	text-align: center;
}

.neomi-contact-hero h1 {
	color: var(--neomi-contact-plum);
	font-family: var(--neomi-font-display);
	font-size: clamp(2.9rem, 5.8vw, 4.45rem);
	font-weight: 700;
	line-height: 1;
	letter-spacing: 0;
}

.neomi-contact-ornament {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
	gap: 1.05rem;
	width: min(13.5rem, 58vw);
	margin: clamp(0.55rem, 1vw, 0.78rem) auto clamp(0.45rem, 0.9vw, 0.68rem);
	color: var(--neomi-contact-plum);
}

.neomi-contact-ornament::before,
.neomi-contact-ornament::after {
	height: 1px;
	content: "";
	background: currentColor;
	opacity: 0.38;
}

.neomi-contact-ornament span {
	font-size: 1.65rem;
	line-height: 1;
}

.neomi-contact-hero p {
	color: var(--neomi-contact-text);
	font-size: clamp(1.08rem, 1.55vw, 1.34rem);
	font-weight: 400;
	line-height: 1.35;
}

.neomi-contact-layout {
	display: grid;
	grid-template-columns: minmax(18rem, 0.9fr) minmax(28rem, 1.35fr);
	gap: clamp(1.4rem, 2.45vw, 1.95rem);
	align-items: stretch;
	justify-content: center;
	max-width: 72rem;
	margin: clamp(1.15rem, 2.25vw, 1.9rem) auto 0;
	direction: ltr;
}

.neomi-contact-info,
.neomi-contact-form-card {
	direction: rtl;
	background: rgba(255, 255, 255, 0.62);
	border: 1px solid rgba(112, 82, 72, 0.15);
	border-radius: 0.9rem;
	box-shadow: 0 1.2rem 3rem rgba(59, 34, 29, 0.055);
}

.neomi-contact-info {
	padding: clamp(1.1rem, 1.8vw, 1.6rem) clamp(1.15rem, 2vw, 1.6rem);
	text-align: center;
}

.neomi-contact-form-card {
	padding: clamp(1.1rem, 1.9vw, 1.65rem) clamp(1.35rem, 2.5vw, 2.35rem);
}

.neomi-contact-info h2,
.neomi-contact-form-card h2 {
	color: var(--neomi-contact-plum);
	font-family: var(--neomi-font-body);
	font-size: clamp(1.2rem, 1.65vw, 1.48rem);
	font-weight: 800;
	line-height: 1.2;
	text-align: center;
}

.neomi-contact-divider {
	display: block;
	width: 4.3rem;
	height: 1px;
	margin: clamp(0.6rem, 1vw, 0.82rem) auto clamp(0.85rem, 1.4vw, 1.15rem);
	background: rgba(78, 21, 95, 0.42);
}

.neomi-contact-info__item h3 {
	color: var(--neomi-contact-plum);
	font-size: clamp(1rem, 1.3vw, 1.13rem);
	font-weight: 800;
	line-height: 1.35;
}

.neomi-contact-info__item a,
.neomi-contact-info__item p {
	display: block;
	color: var(--neomi-contact-text);
	font-size: clamp(0.95rem, 1.2vw, 1.05rem);
	line-height: 1.45;
	text-decoration: none;
}

.neomi-contact-info__item h3 + a,
.neomi-contact-info__item h3 + p {
	margin-block-start: 0.45rem;
}

.neomi-contact-info__item a + p,
.neomi-contact-info__item p + p {
	margin-block-start: 0.1rem;
}

.neomi-contact-rule {
	width: 80%;
	height: 1px;
	margin: clamp(0.65rem, 1.05vw, 0.85rem) auto;
	background: rgba(112, 82, 72, 0.14);
}

.neomi-contact-form {
	display: grid;
	gap: clamp(0.58rem, 0.95vw, 0.78rem);
	max-width: 100%;
}

.neomi-contact-form__row {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: clamp(0.7rem, 1.15vw, 0.95rem);
}

.neomi-contact-form label {
	display: block;
	margin: 0;
}

.neomi-contact-form input,
.neomi-contact-form select,
.neomi-contact-form textarea {
	width: 100%;
	min-height: 2.95rem;
	padding: 0 1.35rem;
	color: var(--neomi-contact-text);
	font-family: var(--neomi-font-body);
	font-size: clamp(0.95rem, 1.18vw, 1.05rem);
	font-weight: 500;
	text-align: right;
	background: rgba(255, 255, 255, 0.7);
	border: 1px solid var(--neomi-contact-field);
	border-radius: 0.45rem;
	box-shadow: none;
	outline: none;
	transition: border-color 180ms ease, box-shadow 180ms ease, background 180ms ease;
}

.neomi-contact-form select {
	appearance: none;
	padding-inline-start: 3.2rem;
	background-image:
		linear-gradient(45deg, transparent 50%, var(--neomi-contact-plum) 50%),
		linear-gradient(135deg, var(--neomi-contact-plum) 50%, transparent 50%);
	background-position:
		left 1.55rem center,
		left 1.15rem center;
	background-size: 0.42rem 0.42rem, 0.42rem 0.42rem;
	background-repeat: no-repeat;
}

.neomi-contact-form textarea {
	min-height: clamp(4.55rem, 6vw, 5.45rem);
	padding-block: 0.85rem;
	resize: vertical;
}

.neomi-contact-form input::placeholder,
.neomi-contact-form textarea::placeholder {
	color: var(--neomi-contact-text);
	opacity: 0.9;
}

.neomi-contact-form input:focus,
.neomi-contact-form select:focus,
.neomi-contact-form textarea:focus {
	background: #fff;
	border-color: rgba(78, 21, 95, 0.58);
	box-shadow: 0 0 0 0.18rem rgba(78, 21, 95, 0.08);
}

.neomi-contact-notice {
	padding: 0.85rem 1.1rem;
	margin-block-end: 1.25rem;
	border-radius: 0.45rem;
	font-size: 0.97rem;
	font-weight: 600;
	line-height: 1.5;
	text-align: center;
}

.neomi-contact-notice--success {
	background: rgba(34, 155, 82, 0.1);
	border: 1px solid rgba(34, 155, 82, 0.35);
	color: #1a6b38;
}

.neomi-contact-notice--error {
	background: rgba(180, 40, 40, 0.08);
	border: 1px solid rgba(180, 40, 40, 0.28);
	color: #8b1a1a;
}

.neomi-contact-submit {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.8rem;
	width: 100%;
	min-height: 3rem;
	margin-block-start: 0.15rem;
	padding: 0 2rem;
	color: #fff;
	font-family: var(--neomi-font-body);
	font-size: clamp(0.95rem, 1.2vw, 1.05rem);
	font-weight: 800;
	background: linear-gradient(135deg, #4c145e 0%, #59156d 52%, #461052 100%);
	border: 0;
	border-radius: 0.45rem;
	box-shadow: 0 0.95rem 1.9rem rgba(78, 21, 95, 0.18);
	cursor: pointer;
	transition: transform 160ms ease, box-shadow 160ms ease, filter 160ms ease;
}

.neomi-contact-submit:hover,
.neomi-contact-submit:focus-visible {
	color: #fff;
	filter: brightness(1.04);
	transform: translateY(-1px);
	box-shadow: 0 1.15rem 2.2rem rgba(78, 21, 95, 0.24);
}

.neomi-contact-submit .neomi-icon {
	width: 1.25rem;
	height: 1.25rem;
}

body:has(.neomi-contact) footer,
body:has(.neomi-contact) #colophon,
body:has(.neomi-contact) .site-footer,
body:has(.neomi-contact) .elementor-location-footer,
body:has(.neomi-contact) [data-elementor-type="footer"],
body:has(.neomi-contact) .hfe-footer {
	display: none !important;
}

@media (max-width: 58rem) {
	.neomi-contact {
		padding-block-start: clamp(3.3rem, 12vw, 5rem);
	}

	.neomi-contact-layout {
		grid-template-columns: 1fr;
		max-width: 44rem;
		margin-block-start: clamp(2.7rem, 9vw, 4.2rem);
		direction: rtl;
	}

	.neomi-contact-form-card {
		order: -1;
	}

	.neomi-contact-form__row {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 38rem) {
	.neomi-contact {
		padding-inline: 0.85rem;
	}

	.neomi-contact-hero h1 {
		font-size: clamp(3.35rem, 16vw, 4.7rem);
	}

	.neomi-contact-info,
	.neomi-contact-form-card {
		border-radius: 0.7rem;
	}

	.neomi-contact-form input,
	.neomi-contact-form select,
	.neomi-contact-form textarea,
	.neomi-contact-submit {
		min-height: 4.15rem;
	}
}
