/*
Theme Name: Huizen in Marbella
Theme URI: https://huizeninmarbella.nl
Author: Samautomation
Author URI: https://huizeninmarbella.nl
Description: Eigen block-thema voor huizeninmarbella.nl — mediterraan editorial design-systeem (Hallmark). Fraunces + Mulish, zee-blauw/oker/terracotta palet. YMYL-content-autoriteit over wonen en kopen in Marbella.
Requires at least: 6.5
Tested up to: 6.9
Requires PHP: 8.0
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: huizeninmarbella
Tags: full-site-editing, block-theme, editorial, custom-colors

Hallmark · macrostructure: Editorial Magazine · genre: editorial · tone: editorial-luxe mediterraan
theme: custom (paper oklch(97% .012 75) · accent oker oklch(76% .12 75) warm · Fraunces + Mulish)
pre-emit critique: P5 H5 E4 S5 R4 V4
*/

/* ===== Globale verfijning ===== */
:root {
	--hm-shadow-sm: 0 1px 2px rgba(36, 31, 27, 0.06), 0 2px 8px rgba(36, 31, 27, 0.05);
	--hm-shadow-md: 0 6px 24px rgba(14, 58, 87, 0.10);
	--hm-ease-out: cubic-bezier(0.22, 1, 0.36, 1);
}
html { scroll-behavior: smooth; }
body { -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }
::selection { background: var(--wp--preset--color--accent); color: var(--wp--preset--color--primary-deep); }
:focus-visible { outline: 3px solid var(--wp--preset--color--primary); outline-offset: 2px; }

a { text-underline-offset: 0.18em; }

/* Vloeiende opmaak van koppen */
h1, h2, h3, h4 { overflow-wrap: anywhere; }

/* Kicker / eyebrow (terracotta caps) */
.hm-kicker {
	font-family: var(--wp--preset--font-family--body);
	text-transform: uppercase;
	letter-spacing: 0.14em;
	font-size: 0.8rem;
	font-weight: 700;
	color: var(--wp--preset--color--terracotta);
}

/* ===== HERO ===== */
.hm-hero {
	position: relative;
	min-height: 72vh;
	display: flex;
	align-items: flex-end;
	overflow: clip;
	isolation: isolate;
}
.hm-hero .hm-hero__media {
	position: absolute; inset: 0; z-index: -2;
	background-size: cover; background-position: center;
	animation: hmHeroZoom 18s var(--hm-ease-out) forwards;
}
.hm-hero::after {
	content: ""; position: absolute; inset: 0; z-index: -1;
	background: linear-gradient(180deg, rgba(14,58,87,0.15) 0%, rgba(14,58,87,0.55) 60%, rgba(14,58,87,0.82) 100%);
}
.hm-hero__inner { padding: clamp(2rem, 6vw, 5rem) 0; max-width: 760px; }
.hm-hero h1, .hm-hero p { color: var(--wp--preset--color--white); }
.hm-hero h1 { text-shadow: 0 2px 24px rgba(14,58,87,0.4); }
@keyframes hmHeroZoom { from { transform: scale(1.08); } to { transform: scale(1); } }

/* ===== Gebieds-/cluster-cards ===== */
.hm-card {
	background: var(--wp--preset--color--white);
	border: 1px solid var(--wp--preset--color--line);
	border-radius: 14px;
	overflow: clip;
	box-shadow: var(--hm-shadow-sm);
	transition: transform 0.4s var(--hm-ease-out), box-shadow 0.4s var(--hm-ease-out);
	height: 100%;
}
.hm-card:hover { transform: translateY(-5px); box-shadow: var(--hm-shadow-md); }
.hm-card__media { aspect-ratio: 16 / 10; overflow: clip; }
.hm-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s var(--hm-ease-out); }
.hm-card:hover .hm-card__media img { transform: scale(1.06); }
.hm-card__body { padding: 1.25rem 1.4rem 1.6rem; }
.hm-card__body h3 { margin: 0 0 0.4rem; font-size: 1.4rem; }
.hm-card__body p { color: var(--wp--preset--color--ink-soft); font-size: 1rem; margin: 0 0 0.8rem; }
.hm-card__link { font-weight: 700; color: var(--wp--preset--color--primary); text-decoration: none; }
.hm-card__link::after { content: " →"; transition: margin 0.3s var(--hm-ease-out); }
.hm-card:hover .hm-card__link::after { margin-left: 0.2rem; }

/* ===== Sectiekop met accent-underline ===== */
.hm-section-head h2 { position: relative; display: inline-block; margin-bottom: 0.6rem; }
.hm-section-head h2::after {
	content: ""; display: block; width: 64px; height: 4px; margin-top: 0.6rem;
	background: var(--wp--preset--color--terracotta); border-radius: 2px;
}

/* ===== Stappenplan (genummerd koopproces) ===== */
.hm-steps { list-style: none; margin: 0; padding: 0; counter-reset: hmstep; }
.hm-steps > li {
	position: relative; padding: 0 0 1.8rem 4rem; counter-increment: hmstep;
}
.hm-steps > li::before {
	content: counter(hmstep); position: absolute; left: 0; top: 0;
	width: 2.6rem; height: 2.6rem; border-radius: 50%;
	background: var(--wp--preset--color--primary); color: #fff;
	font-family: var(--wp--preset--font-family--display); font-weight: 600;
	display: grid; place-items: center; font-size: 1.2rem;
}
.hm-steps > li:not(:last-child)::after {
	content: ""; position: absolute; left: 1.3rem; top: 2.9rem; bottom: 0.3rem;
	width: 2px; background: var(--wp--preset--color--line);
}
.hm-steps > li strong { font-family: var(--wp--preset--font-family--display); font-size: 1.2rem; color: var(--wp--preset--color--primary-deep); display: block; margin-bottom: 0.2rem; }

/* ===== FAQ-accordeon (details/summary) ===== */
.hm-faq details {
	border-bottom: 1px solid var(--wp--preset--color--line);
	padding: 0.4rem 0;
}
.hm-faq summary {
	cursor: pointer; list-style: none; padding: 0.9rem 2.5rem 0.9rem 0;
	position: relative; font-family: var(--wp--preset--font-family--display);
	font-size: 1.2rem; font-weight: 500; color: var(--wp--preset--color--primary-deep);
}
.hm-faq summary::-webkit-details-marker { display: none; }
.hm-faq summary::after {
	content: "+"; position: absolute; right: 0; top: 50%; transform: translateY(-50%);
	font-size: 1.6rem; color: var(--wp--preset--color--accent); transition: transform 0.3s var(--hm-ease-out);
	line-height: 1;
}
.hm-faq details[open] summary::after { transform: translateY(-50%) rotate(45deg); }
.hm-faq details > div, .hm-faq details > p { padding: 0 0 1rem; color: var(--wp--preset--color--ink-soft); }

/* ===== CTA-blok ===== */
.hm-cta {
	background: var(--wp--preset--gradient--deep-sea);
	border-radius: 18px; padding: clamp(2rem, 5vw, 3.5rem); text-align: center; color: #fff;
}
.hm-cta h2, .hm-cta p { color: #fff; }
.hm-cta h2::after { display: none; }

/* ===== Auteur-bio (E-E-A-T) ===== */
.hm-author {
	display: flex; gap: 1.2rem; align-items: flex-start;
	background: var(--wp--preset--color--paper-2);
	border: 1px solid var(--wp--preset--color--line);
	border-left: 4px solid var(--wp--preset--color--primary);
	border-radius: 12px; padding: 1.4rem 1.6rem;
}
.hm-author__avatar { flex: 0 0 56px; width: 56px; height: 56px; border-radius: 50%; background: var(--wp--preset--gradient--deep-sea); display: grid; place-items: center; color: #fff; font-family: var(--wp--preset--font-family--display); font-size: 1.4rem; }
.hm-author__body { font-size: 0.98rem; color: var(--wp--preset--color--ink-soft); }
.hm-author__body strong { color: var(--wp--preset--color--ink); display: block; font-size: 1.05rem; }

/* ===== Bron-citatie ===== */
.hm-source {
	font-size: 0.88rem; color: var(--wp--preset--color--ink-soft); font-style: italic;
	border-left: 3px solid var(--wp--preset--color--line); padding-left: 0.9rem; margin: 1rem 0;
}
.hm-source strong { font-style: normal; color: var(--wp--preset--color--ink); }

/* ===== Disclaimer-kader ===== */
.hm-disclaimer {
	background: color-mix(in srgb, var(--wp--preset--color--olive) 10%, var(--wp--preset--color--paper));
	border: 1px solid color-mix(in srgb, var(--wp--preset--color--olive) 35%, transparent);
	border-radius: 12px; padding: 1.2rem 1.4rem; font-size: 0.95rem; color: var(--wp--preset--color--ink-soft);
}
.hm-disclaimer strong { color: var(--wp--preset--color--ink); }

/* ===== Vergelijkingstabel ===== */
.hm-table table, table.hm-table { width: 100%; border-collapse: collapse; font-size: 1rem; }
.hm-table th { background: var(--wp--preset--color--primary-deep); color: #fff; text-align: left; padding: 0.8rem 1rem; font-family: var(--wp--preset--font-family--body); }
.hm-table td { padding: 0.75rem 1rem; border-bottom: 1px solid var(--wp--preset--color--line); }
.hm-table tbody tr:nth-child(even) { background: var(--wp--preset--color--paper-2); }

/* ===== USP-balk ===== */
.hm-usp { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(220px,100%), 1fr)); gap: 1.2rem; }
.hm-usp__item { text-align: center; }
.hm-usp__item .hm-usp__icon { font-size: 1.8rem; color: var(--wp--preset--color--primary); }

/* ===== Header / Footer ===== */
.hm-header { border-bottom: 1px solid var(--wp--preset--color--line); background: color-mix(in srgb, var(--wp--preset--color--paper) 92%, transparent); position: sticky; top: 0; z-index: 100; backdrop-filter: saturate(1.2) blur(8px); }
.hm-footer { background: var(--wp--preset--color--primary-deep); color: #d9e6ef; }
.hm-footer a { color: #fff; }
.hm-footer .wp-block-heading { color: #fff; }

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
	html { scroll-behavior: auto; }
	.hm-hero .hm-hero__media { animation: none; }
	.hm-card, .hm-card__media img, .hm-faq summary::after { transition-duration: 0.001ms; }
}
