/* ==========================================================================
   ARRELUNA — Contact page
   ========================================================================== */

/* ────────────────────────────────────────
   HERO
──────────────────────────────────────── */
.contact-hero {
	background: var(--arl-moon-sand);
	padding: 96px 0 72px;
	position: relative;
	overflow: hidden;
}

.contact-hero::before {
	content: '';
	position: absolute;
	right: -180px;
	top: 50%;
	transform: translateY(-50%);
	width: 560px;
	height: 560px;
	border: 2px solid var(--arl-deep-teal);
	border-radius: 50%;
	opacity: 0.05;
	pointer-events: none;
}

.contact-hero::after {
	content: '';
	position: absolute;
	right: 120px;
	top: 26%;
	width: 24px;
	height: 24px;
	background: var(--arl-luna-accent);
	border-radius: 50%;
	opacity: 0.4;
	pointer-events: none;
}

.contact-hero__inner {
	position: relative;
	z-index: 1;
	max-width: 760px;
	margin: 0 auto;
}

.contact-hero h1 {
	font-size: clamp(2.2rem, 4.5vw, 3.2rem);
	margin-bottom: 24px;
}

.contact-hero__kicker {
	font-family: var(--font-display);
	font-size: 14px;
	font-weight: 600;
	color: var(--arl-luna-accent);
	text-transform: uppercase;
	letter-spacing: 0.15em;
	margin-bottom: 22px;
	display: flex;
	align-items: center;
	gap: 12px;
}

.contact-hero__kicker::before {
	content: '';
	width: 32px;
	height: 2px;
	background: var(--arl-luna-accent);
	display: inline-block;
}

.contact-hero h1 { margin-bottom: 24px; }

.contact-hero__lead {
	font-size: clamp(1.1rem, 1.6vw, 1.3rem);
	color: var(--arl-slate-ink);
	max-width: 620px;
	line-height: 1.6;
	margin: 0;
}

@keyframes contact-fade-up {
	from { opacity: 0; transform: translateY(20px); }
	to   { opacity: 1; transform: translateY(0); }
}
.contact-hero__kicker { animation: contact-fade-up .7s ease-out backwards; }
.contact-hero h1      { animation: contact-fade-up .7s ease-out backwards; animation-delay: .1s; }
.contact-hero__lead   { animation: contact-fade-up .7s ease-out backwards; animation-delay: .22s; }

/* ────────────────────────────────────────
   BODY GRID
──────────────────────────────────────── */
.contact-body { padding: 96px 0; }

.contact-grid {
	display: grid;
	grid-template-columns: 1.45fr 1fr;
	gap: 56px;
	align-items: start;
}

.contact-grid--form-only {
	grid-template-columns: 1fr;
	max-width: 760px;
	margin: 0 auto;
}

@media (max-width: 880px) {
	.contact-grid { grid-template-columns: 1fr; gap: 44px; }
}

/* ────────────────────────────────────────
   FORM CARD
──────────────────────────────────────── */
.contact-form-card {
	background: var(--arl-white);
	border: 1px solid var(--arl-border);
	border-radius: var(--radius-lg);
	padding: 44px;
	box-shadow: var(--shadow-md);
}

@media (max-width: 640px) { .contact-form-card { padding: 28px 22px; } }

.contact-form-card__head {
	margin-bottom: 28px;
}

.contact-form-card__head h2 {
	font-size: 1.5rem;
	margin-bottom: 8px;
}

.contact-form-card__head p {
	font-size: 15px;
	color: var(--arl-slate-ink);
	opacity: 0.8;
	margin-bottom: 0;
}

/* CF7 field styling */
.contact-cf7-wrap .wpcf7-form .form-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 20px;
}

@media (max-width: 540px) {
	.contact-cf7-wrap .wpcf7-form .form-grid { grid-template-columns: 1fr; }
}

.contact-cf7-wrap .field {
	display: flex;
	flex-direction: column;
	gap: 7px;
}

.contact-cf7-wrap .field.full { grid-column: 1 / -1; }

.contact-cf7-wrap label,
.contact-cf7-wrap .field label {
	font-family: var(--font-display);
	font-size: 13.5px;
	font-weight: 600;
	color: var(--arl-deep-teal);
	letter-spacing: 0.01em;
}

.contact-cf7-wrap label .opt {
	font-family: var(--font-body);
	font-weight: 400;
	font-size: 12.5px;
	color: var(--arl-slate-ink);
	opacity: 0.5;
	margin-left: 4px;
}

.contact-cf7-wrap input[type="text"],
.contact-cf7-wrap input[type="email"],
.contact-cf7-wrap input[type="url"],
.contact-cf7-wrap select,
.contact-cf7-wrap textarea {
	font-family: var(--font-body);
	font-size: 15.5px;
	color: var(--arl-slate-ink);
	background: var(--arl-moon-sand-light);
	border: 1.5px solid var(--arl-border);
	border-radius: var(--radius-sm);
	padding: 13px 15px;
	transition: border-color var(--dur) var(--ease-out), background var(--dur) var(--ease-out), box-shadow var(--dur) var(--ease-out);
	width: 100%;
}

.contact-cf7-wrap textarea {
	resize: vertical;
	min-height: 140px;
	line-height: 1.6;
}

.contact-cf7-wrap input::placeholder,
.contact-cf7-wrap textarea::placeholder {
	color: var(--arl-slate-ink);
	opacity: 0.4;
}

.contact-cf7-wrap input:focus,
.contact-cf7-wrap select:focus,
.contact-cf7-wrap textarea:focus {
	outline: none;
	border-color: var(--arl-bright-cyan);
	background: var(--arl-white);
	box-shadow: 0 0 0 3px var(--arl-luna-accent-soft);
}

.contact-cf7-wrap select {
	appearance: none;
	-webkit-appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%230A4759' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 14px center;
	padding-right: 42px;
	cursor: pointer;
}

.contact-cf7-wrap .field-hint {
	font-size: 12.5px;
	color: var(--arl-slate-ink);
	opacity: 0.6;
	line-height: 1.5;
}

/* Consent checkbox */
.contact-cf7-wrap .consent {
	grid-column: 1 / -1;
	display: flex;
	align-items: flex-start;
	gap: 11px;
	margin-top: 4px;
}

.contact-cf7-wrap .consent input[type="checkbox"] {
	width: 18px;
	height: 18px;
	min-width: 18px;
	margin-top: 3px;
	accent-color: var(--arl-deep-teal);
	cursor: pointer;
	flex-shrink: 0;
}

.contact-cf7-wrap .consent label {
	font-family: var(--font-body);
	font-weight: 400;
	font-size: 13.5px;
	color: var(--arl-slate-ink);
	line-height: 1.55;
}

/* Form footer */
.contact-cf7-wrap .form-footer {
	margin-top: 28px;
	display: flex;
	align-items: center;
	gap: 18px;
	flex-wrap: wrap;
}

.contact-cf7-wrap .btn-submit,
.contact-cf7-wrap input[type="submit"] {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-family: var(--font-body);
	font-size: 16px;
	font-weight: 600;
	color: var(--arl-white);
	background: var(--arl-deep-teal);
	padding: 15px 32px;
	border-radius: var(--radius-md);
	border: none;
	cursor: pointer;
	transition: all var(--dur) var(--ease-out);
	box-shadow: var(--shadow-md);
}

.contact-cf7-wrap .btn-submit:hover,
.contact-cf7-wrap input[type="submit"]:hover {
	background: var(--arl-deep-teal-dark);
	transform: translateY(-2px);
	box-shadow: var(--shadow-lg);
}

.contact-cf7-wrap .privacy-note {
	font-size: 12.5px;
	color: var(--arl-slate-ink);
	opacity: 0.6;
	line-height: 1.5;
	max-width: 280px;
	margin-bottom: 0;
}

/* CF7 validation / response */
.contact-cf7-wrap .wpcf7-spinner { display: none; }

.contact-cf7-wrap .wpcf7-not-valid-tip {
	font-size: 12px;
	color: #d14a6a;
	margin-top: 4px;
	display: block;
}

.contact-cf7-wrap .wpcf7-mail-sent-ok,
.contact-cf7-wrap .wpcf7-validation-errors {
	margin-top: 16px;
	padding: 14px 18px;
	border-radius: var(--radius-sm);
	font-size: 14px;
}

.contact-cf7-wrap .wpcf7-mail-sent-ok {
	background: rgba(46, 166, 107, 0.1);
	border: 1px solid rgba(46, 166, 107, 0.3);
	color: #1d7a47;
}

.contact-cf7-wrap .wpcf7-validation-errors {
	background: rgba(209, 74, 106, 0.08);
	border: 1px solid rgba(209, 74, 106, 0.3);
	color: #b03050;
}

/* ────────────────────────────────────────
   ASIDE CARDS
──────────────────────────────────────── */
.contact-aside {
	display: flex;
	flex-direction: column;
	gap: 20px;
	position: sticky;
	top: 100px;
}

@media (max-width: 880px) { .contact-aside { position: static; } }

.contact-aside-card {
	background: var(--arl-moon-sand-light);
	border: 1px solid var(--arl-border);
	border-radius: var(--radius-md);
	padding: 26px;
}

.contact-aside-card__icon {
	width: 44px;
	height: 44px;
	border-radius: 11px;
	background: var(--arl-white);
	border: 1px solid var(--arl-border);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--arl-bright-cyan);
	margin-bottom: 16px;
}

.contact-aside-card h3 {
	font-size: 1.1rem;
	margin-bottom: 8px;
}

.contact-aside-card p {
	font-size: 14.5px;
	color: var(--arl-slate-ink);
	line-height: 1.6;
	margin-bottom: 0;
	opacity: 0.85;
}

.contact-aside-card__mail {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	margin-top: 14px;
	font-family: var(--font-display);
	font-weight: 600;
	font-size: 15px;
	color: var(--arl-deep-teal);
	text-decoration: none;
	transition: color var(--dur) var(--ease-out);
}

.contact-aside-card__mail:hover { color: var(--arl-bright-cyan); }

/* Response time */
.contact-response-row {
	display: flex;
	align-items: center;
	gap: 14px;
	margin-top: 12px;
}

.contact-response-dot {
	width: 10px;
	height: 10px;
	min-width: 10px;
	border-radius: 50%;
	background: #2ea66b;
	box-shadow: 0 0 0 4px rgba(46, 166, 107, 0.18);
}

.contact-response-text {
	font-size: 14.5px;
	color: var(--arl-slate-ink);
	line-height: 1.5;
}

/* Featured service card */
.contact-aside-card--featured {
	background: var(--arl-deep-teal);
	border-color: var(--arl-deep-teal);
}

.contact-aside-card--featured .contact-aside-card__icon {
	background: rgba(255, 255, 255, 0.1);
	border-color: rgba(255, 255, 255, 0.18);
	color: var(--arl-white);
}

.contact-aside-card--featured h3 { color: var(--arl-white); }
.contact-aside-card--featured p  { color: rgba(255, 255, 255, 0.82); }

.contact-aside-card__price {
	font-family: var(--font-display);
	font-weight: 800;
	font-size: 1.6rem;
	color: var(--arl-white);
	margin: 14px 0 4px;
	display: block;
}

.contact-aside-card__price span {
	font-size: 13px;
	font-weight: 500;
	opacity: 0.7;
	margin-left: 4px;
}

.contact-service-cta {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	margin-top: 14px;
	font-family: var(--font-body);
	font-weight: 600;
	font-size: 14.5px;
	color: var(--arl-deep-teal);
	background: var(--arl-white);
	padding: 11px 20px;
	border-radius: var(--radius-sm);
	text-decoration: none;
	transition: all var(--dur) var(--ease-out);
}

.contact-service-cta:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-md);
	color: var(--arl-deep-teal);
}

/* ────────────────────────────────────────
   FAQ
──────────────────────────────────────── */
.contact-faq {
	background: var(--arl-moon-sand);
	padding: 96px 0;
}

.contact-faq__list {
	max-width: 760px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	gap: 14px;
}

.contact-faq__item {
	background: var(--arl-white);
	border: 1px solid var(--arl-border);
	border-radius: var(--radius-md);
	padding: 24px 28px;
	transition: box-shadow var(--dur) var(--ease-out);
}

.contact-faq__item:hover { box-shadow: var(--shadow-md); }

.contact-faq__item h4 {
	margin-bottom: 9px;
	display: flex;
	align-items: flex-start;
	gap: 11px;
}

.contact-faq__item h4::before {
	content: '';
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: var(--arl-luna-accent);
	margin-top: 9px;
	flex-shrink: 0;
}

.contact-faq__item p {
	font-size: 15px;
	color: var(--arl-slate-ink);
	line-height: 1.65;
	margin-bottom: 0;
	padding-left: 18px;
	opacity: 0.88;
}

@media (max-width: 640px) {
	.contact-hero { padding: 72px 0 56px; }
	.contact-body { padding: 72px 0; }
	.contact-faq  { padding: 72px 0; }
}
