/* ==========================================================================
   FANG · Contact page (template-contact.php)
   ========================================================================== */

.fang-contact-page { padding: 56px 0 96px; background: var(--bone); }

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

/* ----- Left column: address blocks + map ----- */
.contact-info { display: flex; flex-direction: column; gap: 32px; }
.contact-block {
	background: var(--paper);
	border: 1px solid rgba(0, 0, 0, 0.08);
	padding: 28px;
	border-left: 3px solid var(--red);
}
.contact-block h3 { font-size: 22px; }
.contact-address strong { display: block; margin-bottom: 6px; }
.contact-hours { color: var(--gun); }

/* ----- Map ----- */
.fang-map {
	width: 100%;
	height: 360px;
	border: 1px solid rgba(0, 0, 0, 0.10);
	background: var(--bone-2);
	/* Subtle tactical desaturation — keeps OSM readable but matches FANG palette. */
	filter: grayscale(0.35) contrast(1.05);
}
.fang-map .leaflet-marker-icon,
.fang-map .leaflet-popup { filter: grayscale(0); }
.fang-map a { color: var(--red); }
.contact-map-attribution {
	font-family: var(--f-mono);
	font-size: 10px;
	letter-spacing: 0.10em;
	color: var(--fog);
	text-transform: uppercase;
	margin-top: 8px;
}
.contact-map-attribution a { color: var(--gun); border-bottom: 1px dotted var(--fog); }

/* Custom map pin styling */
.fang-map-pin {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px; height: 36px;
	background: var(--red);
	color: #fff;
	font-family: var(--f-display);
	font-weight: 700;
	font-size: 18px;
	border: 3px solid #fff;
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.3);
	transform: translate(-50%, -100%);
	border-radius: 50% 50% 50% 0;
	rotate: -45deg;
}
.fang-map-pin span { rotate: 45deg; }

/* Leaflet popup */
.leaflet-popup-content-wrapper {
	border-radius: 0 !important;
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.18);
}
.leaflet-popup-content {
	font-family: var(--f-body);
	margin: 14px 18px;
}
.leaflet-popup-content strong {
	font-family: var(--f-display);
	font-weight: 700;
	font-size: 14px;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--gun);
	display: block;
	margin-bottom: 6px;
}
.leaflet-popup-content small {
	font-family: var(--f-mono);
	font-size: 11px;
	color: var(--fog);
	letter-spacing: 0.06em;
}
.leaflet-popup-content a {
	color: var(--red);
	font-family: var(--f-mono);
	font-size: 11px;
	letter-spacing: 0.10em;
	text-transform: uppercase;
	display: inline-block;
	margin-top: 8px;
}

/* ----- Right column: form ----- */
.contact-form-wrap {
	background: var(--paper);
	border: 1px solid rgba(0, 0, 0, 0.08);
	padding: 36px;
	border-top: 4px solid var(--red);
	position: sticky;
	top: 120px;
}

.contact-alert {
	padding: 14px 18px;
	margin: 22px 0 0;
	font-size: 14px;
	line-height: 1.5;
	font-family: var(--f-body);
}
.contact-alert--ok  { background: rgba(212, 160, 23, 0.12); color: var(--gun); border-left: 4px solid var(--amber); }
.contact-alert--err { background: rgba(178, 34, 52, 0.10); color: var(--red-deep); border-left: 4px solid var(--red); }

.contact-form { display: flex; flex-direction: column; gap: 18px; margin-top: 24px; }
.contact-row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.contact-field { display: flex; flex-direction: column; gap: 6px; }
.contact-label {
	font-family: var(--f-mono);
	font-size: 11px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--gun);
}
.contact-form input[type="text"],
.contact-form input[type="email"],
.contact-form input[type="tel"],
.contact-form select,
.contact-form textarea {
	padding: 14px 16px;
	border: 1px solid rgba(0, 0, 0, 0.20);
	background: var(--paper);
	color: var(--gun);
	font-family: var(--f-body);
	font-size: 15px;
	border-radius: var(--radius);
	outline: none;
	transition: border-color 0.12s ease, box-shadow 0.12s ease;
	width: 100%;
}
.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus {
	border-color: var(--red);
	box-shadow: 0 0 0 2px rgba(178, 34, 52, 0.15);
}
.contact-form textarea { resize: vertical; min-height: 140px; line-height: 1.5; }
.contact-form select {
	appearance: none;
	-webkit-appearance: none;
	background-image: linear-gradient(45deg, transparent 50%, var(--gun) 50%),
	                  linear-gradient(135deg, var(--gun) 50%, transparent 50%);
	background-position: calc(100% - 18px) 50%, calc(100% - 13px) 50%;
	background-size: 6px 6px, 6px 6px;
	background-repeat: no-repeat;
}
.contact-form button[type="submit"] { align-self: flex-start; }

.contact-extra { margin-top: 64px; padding-top: 48px; border-top: 1px solid rgba(0, 0, 0, 0.08); max-width: 760px; }
.contact-extra h2 { margin-bottom: 16px; }

@media (max-width: 980px) {
	.contact-layout { grid-template-columns: 1fr; gap: 32px; }
	.contact-form-wrap { position: static; padding: 28px; }
}
@media (max-width: 560px) {
	.fang-contact-page { padding: 32px 0 64px; }
	.contact-block { padding: 22px; }
	.contact-form-wrap { padding: 24px; }
	.contact-row { grid-template-columns: 1fr; gap: 14px; }
	.fang-map { height: 280px; }
}
