/* Legal pages (terms / privacy / cookies) + contact page.
   Enqueued on those templates only. Uses theme tokens. */

.mr-legal { background: var(--bg); }

/* Hero */
.mr-legal-hero {
	background: var(--grad-basalt);
	color: #fff;
	padding: 4.5rem 0 3.5rem;
	text-align: center;
}
.mr-legal-hero .mr-breadcrumb { margin-bottom: 1.1rem; }
.mr-legal-eyebrow {
	font-size: .74rem; font-weight: 600;
	letter-spacing: .14em; text-transform: uppercase;
	color: var(--lagoon-400); margin: 0 0 .7rem;
}
.mr-legal-title {
	font-family: var(--font-display);
	font-size: clamp(2rem, 4.5vw, 3rem);
	font-weight: 700; line-height: 1.15; margin: 0; color: #fff;
}
.mr-legal-updated { font-size: .9rem; color: var(--ink-300, rgba(255,255,255,.7)); margin: .9rem 0 0; }

/* Body */
.mr-legal-wrap { max-width: 820px; margin: 0 auto; padding: 3.5rem 1.5rem 5rem; }
.mr-legal-body { color: var(--fg-soft); font-size: 1.02rem; line-height: 1.75; }
.mr-legal-body > p:first-child {
	font-size: 1.1rem; color: var(--fg); line-height: 1.7;
	padding: 1.1rem 1.25rem; margin: 0 0 2rem;
	background: var(--bg-alt); border-left: 3px solid var(--accent);
	border-radius: var(--r-md);
}
.mr-legal-body h2,
.mr-legal-body h3 {
	font-family: var(--font-display);
	font-size: 1.4rem; font-weight: 700; color: var(--fg);
	margin: 2.5rem 0 .9rem; padding-top: 1.5rem;
	border-top: 1px solid var(--line);
	line-height: 1.3;
}
.mr-legal-body h2:first-of-type,
.mr-legal-body h3:first-of-type { border-top: none; padding-top: 0; margin-top: 0; }
.mr-legal-body p { margin: 0 0 1.15rem; }
.mr-legal-body ul { margin: 0 0 1.3rem 1.3rem; padding: 0; }
.mr-legal-body li { margin-bottom: .55rem; }
.mr-legal-body strong { color: var(--fg); font-weight: 700; }
.mr-legal-body a { color: var(--accent); }
.mr-legal-body a:hover { color: var(--lagoon-600); }

/* ── Contact page ── */
.mr-contact-wrap { max-width: 1100px; margin: 0 auto; padding: 3.5rem 1.5rem 5rem; }
.mr-contact-grid {
	display: grid; gap: 2.5rem;
	grid-template-columns: 1fr;
}
@media (min-width: 900px) {
	.mr-contact-grid { grid-template-columns: 1fr 1.15fr; align-items: start; }
}

/* Contact detail cards */
.mr-contact-intro h2 {
	font-family: var(--font-display); font-size: 1.5rem; font-weight: 700;
	color: var(--fg); margin: 0 0 .6rem;
}
.mr-contact-intro p { color: var(--fg-soft); line-height: 1.7; margin: 0 0 1.75rem; }
.mr-contact-cards { display: flex; flex-direction: column; gap: 1rem; }
.mr-contact-card {
	display: flex; align-items: flex-start; gap: 1rem;
	padding: 1.1rem 1.25rem;
	background: var(--bg-alt); border: 1px solid var(--line);
	border-radius: var(--r-lg); text-decoration: none;
	transition: border-color .15s, box-shadow .15s, transform .15s;
}
a.mr-contact-card:hover { border-color: var(--accent); box-shadow: var(--shadow-sm); transform: translateY(-2px); }
.mr-contact-card-ic {
	flex: 0 0 44px; width: 44px; height: 44px;
	display: inline-flex; align-items: center; justify-content: center;
	border-radius: 50%; background: rgba(11,184,173,.1); color: var(--accent);
}
.mr-contact-card-k { font-size: .76rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--muted); margin: 0 0 .15rem; }
.mr-contact-card-v { font-size: 1rem; font-weight: 600; color: var(--fg); margin: 0; word-break: break-word; }

/* Form */
.mr-contact-form-box {
	background: var(--bg-alt); border: 1px solid var(--line);
	border-radius: var(--r-xl); padding: 2rem;
}
.mr-form-row { display: grid; gap: 1rem; margin-bottom: 1rem; }
@media (min-width: 560px) { .mr-form-row--2 { grid-template-columns: 1fr 1fr; } }
.mr-field label { display: block; font-size: .85rem; font-weight: 600; color: var(--fg); margin-bottom: .4rem; }
.mr-field input, .mr-field textarea, .mr-field select {
	width: 100%; padding: .75rem .9rem;
	font-size: .95rem; font-family: inherit; color: var(--fg);
	background: var(--bg); border: 1px solid var(--line-strong);
	border-radius: var(--r-md); transition: border-color .15s, box-shadow .15s;
}
.mr-field input:focus, .mr-field textarea:focus, .mr-field select:focus {
	outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px rgba(11,184,173,.12);
}
.mr-field textarea { resize: vertical; min-height: 130px; }
.mr-contact-submit { width: 100%; justify-content: center; margin-top: .25rem; }
.mr-form-note { font-size: .8rem; color: var(--muted); margin: .9rem 0 0; text-align: center; }
.mr-form-msg { margin: 1rem 0 0; padding: .85rem 1rem; border-radius: var(--r-md); font-size: .92rem; display: none; }
.mr-form-msg.is-ok { display: block; background: rgba(11,184,173,.12); color: var(--lagoon-600); border: 1px solid rgba(11,184,173,.3); }
.mr-form-msg.is-err { display: block; background: rgba(238,90,48,.1); color: var(--coral-600); border: 1px solid rgba(238,90,48,.3); }

/* Honeypot — off-screen, hidden from real users */
.mr-hp { position: absolute !important; left: -9999px !important; width: 1px; height: 1px; overflow: hidden; }
.mr-hp input { pointer-events: none; }

/* Map */
.mr-contact-map { margin-top: 2.5rem; border-radius: var(--r-xl); overflow: hidden; border: 1px solid var(--line); line-height: 0; }
.mr-contact-map iframe { width: 100%; height: 360px; border: 0; display: block; }
