*, *::before, *::after { box-sizing: border-box; }

body .page .entry-content { padding-top: 0 !important; margin-top: 0 !important; }
.wp-site-blocks { padding-top: 0 !important; }

html { scroll-behavior: smooth; scrollbar-gutter: stable; }

body {
	margin: 0;
	background: var(--bg);
	color: var(--text);
	font-family: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	line-height: 1.55;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
}

img { max-width: 100%; display: block; }
a { text-decoration: none; color: inherit; }
button, input { font: inherit; }

h1, h2, h3, h4, h5, h6 {
	font-family: "Cormorant Garamond", Georgia, serif;
	line-height: .98;
	letter-spacing: -.02em;
	margin: 0;
	font-weight: 600;
	color: var(--text);
}

.container {
	width: min(calc(100% - 48px), var(--max));
	margin: 0 auto;
}

/* Kadence overrides */
body .content-bg { background: transparent !important; box-shadow: none !important; }
body .entry-content-wrap { background: transparent !important; }
body .page .entry-content { max-width: 100% !important; padding: 0 !important; }
section.entry-hero.page-hero-section { display: none !important; }

/* Buttons */
.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	min-height: 50px;
	padding: 0 20px;
	border-radius: 999px;
	border: 1px solid transparent;
	transition: .22s ease;
	cursor: pointer;
	font-family: "Inter", sans-serif;
	font-size: .96rem;
	text-decoration: none;
}

.btn-primary {
	background: var(--accent);
	color: #fff;
	box-shadow: 0 10px 24px rgba(182,84,75,.20);
}

.btn-primary:hover {
	transform: translateY(-1px);
	filter: brightness(.97);
	color: #fff;
}

.btn-secondary {
	border-color: var(--line-strong);
	background: rgba(255,255,255,.45);
	color: var(--text);
}

.btn-secondary:hover {
	background: #fff;
	color: var(--text);
}

.text-link {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	color: var(--accent);
	font-weight: 600;
	text-decoration: none;
}

.text-link::after { content: "↗"; font-size: .95em; }

.eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 8px 12px;
	border: 1px solid var(--line);
	border-radius: 999px;
	color: var(--muted);
	font-size: .83rem;
	letter-spacing: .08em;
	text-transform: uppercase;
	background: rgba(255,255,255,.45);
}

.eyebrow::before {
	content: "";
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: var(--accent);
	display: block;
}

/* ── Contact form (Task 7) ───────────────────────────────────── */

.mmm-contact-wrap {
	max-width: 600px;
	margin: 40px auto;
}

.mmm-contact-intro {
	margin-bottom: 28px;
	color: var(--muted);
	font-family: "Inter", sans-serif;
	line-height: 1.6;
}

.mmm-contact-form {
	display: flex;
	flex-direction: column;
	gap: 32px;
}

.mmm-contact-field {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.mmm-contact-field label {
	font-family: "Inter", sans-serif;
	font-size: .9rem;
	font-weight: 500;
	color: var(--text);
}

.mmm-contact-field input,
.mmm-contact-field textarea {
	border: 1px solid var(--line-strong);
	border-radius: 10px;
	padding: 10px 14px;
	background: rgba(255,255,255,.82);
	color: var(--text);
	font-family: "Inter", sans-serif;
	font-size: .96rem;
	outline: none;
	transition: border-color .2s;
	resize: vertical;
}

.mmm-contact-field input:focus,
.mmm-contact-field textarea:focus {
	border-color: var(--accent);
	box-shadow: 0 0 0 4px rgba(182,84,75,.10);
}

.mmm-contact-status {
	font-family: "Inter", sans-serif;
	font-size: .9rem;
	min-height: 1.4em;
}

.mmm-contact-ok  { color: #2a7a2a; font-weight: 700; }
.mmm-contact-err { color: var(--accent); }

/* ── Cookie consent banner (Task 12) ────────────────────────── */

#mmmCookieBanner {
	position: fixed;
	bottom: 24px;
	left: 50%;
	transform: translateX(-50%);
	z-index: 9999;
	background: var(--text);
	color: var(--bg);
	border-radius: 14px;
	padding: 16px 24px;
	display: flex;
	align-items: center;
	gap: 20px;
	box-shadow: 0 8px 32px rgba(28,28,28,.25);
	max-width: min(calc(100% - 48px), 680px);
	flex-wrap: wrap;
	font-family: "Inter", sans-serif;
	font-size: .9rem;
}

#mmmCookieBanner p {
	margin: 0;
	flex: 1;
	min-width: 200px;
}

#mmmCookieBanner a {
	color: var(--accent);
	text-decoration: underline;
}

.mmm-cookie-actions {
	display: flex;
	gap: 10px;
}

#mmmCookieBanner .btn {
	min-height: 38px;
	padding: 0 16px;
	font-size: .88rem;
}

#mmmCookieBanner .btn-primary {
	background: var(--accent);
	color: #fff;
	border-color: var(--accent);
}

#mmmCookieBanner .btn-secondary {
	background: rgba(255,255,255,.12);
	color: var(--bg);
	border-color: rgba(255,255,255,.2);
}