/* ==========================================================================
   THE GAROE Group — contact.css
   Page-specific styles for the Contact page. Enqueued for is_page('contact').

   Resets, fonts, header, footer, .container and root tokens come from the
   theme (style.css / main.css) and are not repeated here. Shorthand tokens
   from the prototype have been reconciled to the theme's --color-* properties.

   NOTE: .page-hero here is the prototype's grid/vignette hero; the theme also
   defines a .page-hero band in main.css used by page.php — see handover notes.
   ========================================================================== */

/* ════════════════════════
   PAGE HERO
   ════════════════════════ */
.page-hero {
	background: var(--color-carbon);
	border-bottom: 1px solid var(--color-line-dark);
	padding: 80px 0 72px;
	position: relative;
	overflow: hidden;
}
.page-hero-grid {
	background-image:
		linear-gradient(rgba(200, 169, 110, 0.03) 1px, transparent 1px),
		linear-gradient(90deg, rgba(200, 169, 110, 0.03) 1px, transparent 1px);
	background-size: 60px 60px;
	position: absolute;
	inset: 0;
	pointer-events: none;
}
.page-hero-vignette {
	background: radial-gradient(ellipse 70% 100% at 50% 50%, transparent 20%, rgba(10, 10, 10, 0.70) 100%);
	position: absolute;
	inset: 0;
	pointer-events: none;
}
.page-hero-content {
	position: relative;
	z-index: 2;
	max-width: 640px;
}
.page-eyebrow {
	color: var(--color-gold);
	display: block;
	font-family: var(--font-mono);
	font-size: 10px;
	letter-spacing: 0.26em;
	margin-bottom: 18px;
	opacity: 0.75;
	text-transform: uppercase;
}
.page-hero h1 {
	color: var(--color-white);
	font-family: var(--font-display);
	font-size: 52px;
	font-weight: 400;
	letter-spacing: -0.01em;
	line-height: 1.1;
	margin-bottom: 20px;
}
.page-hero h1 em {
	color: var(--color-gold);
	font-style: italic;
}
.page-hero-sub {
	color: rgba(240, 236, 228, 0.55);
	font-size: 15px;
	line-height: 1.7;
	max-width: 480px;
}

/* ════════════════════════
   MAIN CONTACT LAYOUT
   ════════════════════════ */
.contact-section {
	background: var(--color-carbon-2);
	border-bottom: 1px solid var(--color-line-dark);
	padding: 80px 0;
}
.contact-grid {
	display: grid;
	grid-template-columns: 1fr 440px;
	gap: 80px;
	align-items: start;
}

/* ── FORM COLUMN ── */
.form-col-label {
	color: var(--color-gold);
	font-family: var(--font-mono);
	font-size: 9px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	opacity: 0.7;
	margin-bottom: 28px;
	display: block;
}
.contact-form {
	display: flex;
	flex-direction: column;
	gap: 20px;
}
.form-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
}
.form-field {
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.form-field label {
	color: rgba(200, 169, 110, 0.65);
	font-family: var(--font-mono);
	font-size: 9px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
}
.form-field input,
.form-field select,
.form-field textarea {
	background: rgba(200, 169, 110, 0.04);
	border: 1px solid var(--color-line-dark);
	color: var(--color-white);
	font-family: var(--font-body);
	font-size: 14px;
	outline: none;
	padding: 13px 16px;
	transition: border-color 0.15s, background 0.15s;
	width: 100%;
	-webkit-appearance: none;
	appearance: none;
}
.form-field input::placeholder,
.form-field textarea::placeholder {
	color: #3a3830;
}
.form-field select {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23c8a96e' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 14px center;
	cursor: pointer;
	padding-right: 38px;
}
.form-field select option {
	background: var(--color-carbon-2);
	color: var(--color-white);
}
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus {
	border-color: rgba(200, 169, 110, 0.5);
	background: rgba(200, 169, 110, 0.06);
}
.form-field textarea {
	min-height: 130px;
	resize: vertical;
}
.form-response-note {
	color: var(--color-muted);
	font-family: var(--font-mono);
	font-size: 9px;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	margin-top: 4px;
}
.form-response-note span {
	color: rgba(200, 169, 110, 0.55);
}
.btn-submit {
	background: var(--color-gold);
	border: none;
	color: var(--color-carbon);
	cursor: pointer;
	font-family: var(--font-mono);
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.16em;
	padding: 16px 40px;
	text-transform: uppercase;
	transition: background 0.15s;
	align-self: flex-start;
	margin-top: 8px;
}
.btn-submit:hover { background: var(--color-gold-light); }

/* ── SIDEBAR ── */
.contact-sidebar {
	display: flex;
	flex-direction: column;
	gap: 2px;
}
.sidebar-label {
	color: var(--color-gold);
	font-family: var(--font-mono);
	font-size: 9px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	opacity: 0.7;
	margin-bottom: 28px;
	display: block;
}
.contact-card {
	background: rgba(200, 169, 110, 0.03);
	border: 1px solid var(--color-line-dark);
	padding: 24px 26px;
	margin-bottom: 2px;
}
.contact-card:last-of-type { margin-bottom: 0; }
.contact-card-type {
	color: var(--color-gold);
	font-family: var(--font-mono);
	font-size: 9px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	opacity: 0.65;
	margin-bottom: 8px;
	display: block;
}
.contact-card-value {
	color: var(--color-white);
	font-size: 14px;
	font-weight: 500;
	letter-spacing: 0.01em;
	text-decoration: none;
	display: block;
	transition: color 0.15s;
}
a.contact-card-value:hover { color: var(--color-gold); }
.contact-card-note {
	color: var(--color-muted);
	font-family: var(--font-mono);
	font-size: 9px;
	letter-spacing: 0.1em;
	margin-top: 5px;
	text-transform: uppercase;
}

.sidebar-divider {
	height: 1px;
	background: var(--color-line-dark);
	margin: 22px 0;
}

.programmes-card {
	background: rgba(200, 169, 110, 0.03);
	border: 1px solid var(--color-line-dark);
	border-top: 2px solid rgba(200, 169, 110, 0.35);
	padding: 24px 26px;
}
.programmes-card-label {
	color: var(--color-gold);
	font-family: var(--font-mono);
	font-size: 9px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	opacity: 0.65;
	margin-bottom: 14px;
	display: block;
}
.programme-link {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 12px 0;
	border-bottom: 1px solid var(--color-line-dark);
	text-decoration: none;
	transition: opacity 0.15s;
}
.programme-link:last-child { border-bottom: none; padding-bottom: 0; }
.programme-link:first-of-type { padding-top: 0; }
.programme-link:hover { opacity: 0.75; }
.programme-link-name {
	color: var(--color-white);
	font-size: 13px;
	font-weight: 500;
}
.programme-link-arrow {
	color: var(--color-gold);
	font-family: var(--font-mono);
	font-size: 10px;
	opacity: 0.6;
}

/* ════════════════════════
   MAP SECTION
   ════════════════════════ */
.map-section {
	background: var(--color-carbon);
	border-bottom: 1px solid var(--color-line-dark);
}
.map-header {
	padding: 52px 0 40px;
	border-bottom: 1px solid var(--color-line-dark);
}
.map-header-inner {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 40px;
}
.map-eyebrow {
	color: var(--color-gold);
	font-family: var(--font-mono);
	font-size: 9px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	opacity: 0.65;
	display: block;
	margin-bottom: 10px;
}
.map-heading {
	color: var(--color-white);
	font-family: var(--font-display);
	font-size: 28px;
	font-weight: 400;
	line-height: 1.2;
}
.map-address-block {
	text-align: right;
	flex-shrink: 0;
}
.map-address-line {
	color: var(--color-muted);
	font-family: var(--font-mono);
	font-size: 10px;
	letter-spacing: 0.1em;
	line-height: 1.9;
	text-transform: uppercase;
}
.map-address-line strong {
	color: rgba(200, 169, 110, 0.75);
	font-weight: 600;
}

/* Map wrapper with dark overlay technique */
.map-wrap {
	position: relative;
	height: 420px;
	overflow: hidden;
}
.map-wrap iframe {
	width: 100%;
	height: 100%;
	border: 0;
	display: block;
	filter: grayscale(100%) invert(92%) contrast(83%) hue-rotate(180deg) brightness(0.85) saturate(0.3);
}
/* Dark overlay tinted gold — sits above map but below pointer events */
.map-overlay {
	position: absolute;
	inset: 0;
	background: rgba(10, 8, 4, 0.52);
	mix-blend-mode: multiply;
	pointer-events: none;
	z-index: 2;
}
/* Vignette on top */
.map-vignette {
	position: absolute;
	inset: 0;
	background:
		linear-gradient(to bottom, rgba(10, 10, 10, 0.55) 0%, transparent 18%, transparent 82%, rgba(10, 10, 10, 0.70) 100%),
		linear-gradient(to right, rgba(10, 10, 10, 0.40) 0%, transparent 20%, transparent 80%, rgba(10, 10, 10, 0.40) 100%);
	pointer-events: none;
	z-index: 3;
}
/* Gold rule at top of map */
.map-rule {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 1px;
	background: var(--color-line-dark);
	z-index: 4;
}
/* Location pin badge */
.map-badge {
	position: absolute;
	bottom: 32px;
	left: 48px;
	background: rgba(10, 8, 4, 0.88);
	border: 1px solid rgba(200, 169, 110, 0.3);
	padding: 14px 20px;
	z-index: 5;
	pointer-events: none;
}
.map-badge-label {
	color: var(--color-gold);
	font-family: var(--font-mono);
	font-size: 8px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	opacity: 0.7;
	display: block;
	margin-bottom: 4px;
}
.map-badge-name {
	color: var(--color-white);
	font-family: var(--font-display);
	font-size: 16px;
	font-weight: 400;
	display: block;
}
.map-badge-detail {
	color: var(--color-muted);
	font-family: var(--font-mono);
	font-size: 9px;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	margin-top: 3px;
	display: block;
}

/* ════════════════════════
   RESPONSIVE
   ════════════════════════ */
@media (max-width: 960px) {
	.contact-grid { grid-template-columns: 1fr; gap: 52px; }
	.form-row { grid-template-columns: 1fr; }
	.page-hero h1 { font-size: 38px; }
	.map-header-inner { flex-direction: column; align-items: flex-start; gap: 20px; }
	.map-address-block { text-align: left; }
	.map-badge { left: 24px; }
}
