/* Moulin de la Fayolle — custom utility styles */

/* Header */
.site-header .contact-band a,
.site-header .lang-switcher a,
.site-header .wordmark a {
	color: inherit;
	text-decoration: none;
}
.site-header .contact-band a:hover,
.site-header .lang-switcher a:hover { text-decoration: underline; }

.site-header__main { gap: 2rem; }
.site-header .primary-nav a { color: inherit; text-decoration: none; }
.site-header .primary-nav a:hover { color: var(--wp--preset--color--primary-500); }

/* Footer link inherit */
footer.wp-block-group a { color: inherit; text-decoration: none; }
footer.wp-block-group .footer-nav a:hover,
footer.wp-block-group p a:hover { text-decoration: underline; }
footer.wp-block-group ul { list-style: none; }

/* Trust strip */
.trust-strip { border-top: 1px solid var(--wp--preset--color--sand-200); border-bottom: 1px solid var(--wp--preset--color--sand-200); }

/* Surroundings tile hover */
.surroundings-tile { overflow: hidden; }
.surroundings-tile img { transition: transform 0.7s ease; }
.surroundings-tile:hover img { transform: scale(1.05); }

/* Pricing table polish */
.prijzen-table table { width: 100%; border-collapse: collapse; }
.prijzen-table th, .prijzen-table td { padding: 0.7rem 0.5rem; border-bottom: 1px solid var(--wp--preset--color--sand-200); text-align: left; font-size: 0.95rem; }
.prijzen-table th { font-family: "Playfair Display", serif; font-weight: 400; color: var(--wp--preset--color--primary-900); }
.prijzen-table td:last-child, .prijzen-table th:last-child { text-align: right; white-space: nowrap; }

/* Hero scroll cue */
.hero-scroll-cue { display:inline-block; width:1px; height:48px; background: rgba(255,255,255,0.7); margin: 4rem auto 0; animation: heroScroll 1.8s ease-in-out infinite; }
@keyframes heroScroll { 0%,100% { opacity:0.3; transform: translateY(0); } 50% { opacity:1; transform: translateY(8px); } }



.eyebrow {
	text-transform: uppercase;
	letter-spacing: 0.2em;
	font-size: 0.8125rem;
	font-weight: 500;
}

.tracking-widest {
	letter-spacing: 0.3em;
}

.hero-section {
	position: relative;
	min-height: 100vh;
	display: flex;
	align-items: center;
	justify-content: center;
}

.hero-section .wp-block-cover__image-background {
	filter: brightness(0.75);
}

.blockquote-accent {
	border-left: 4px solid var(--wp--preset--color--primary-500);
	padding-left: 1.5rem;
	font-style: italic;
	color: var(--wp--preset--color--stone-500);
}

.room-card img,
.wp-block-image.is-style-soft img {
	border-radius: 2px;
	transition: transform 0.7s ease;
}

.room-card:hover img {
	transform: scale(1.05);
}

.wp-block-button.is-style-outline .wp-block-button__link {
	background: transparent !important;
	border: 1px solid currentColor;
}

.wp-block-button.is-style-light .wp-block-button__link {
	background: var(--wp--preset--color--white);
	color: var(--wp--preset--color--primary-900);
}

.wp-block-button.is-style-light .wp-block-button__link:hover {
	background: var(--wp--preset--color--primary-800);
	color: var(--wp--preset--color--white);
}

body { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }

input, select, textarea, button {
	font-family: inherit;
}

.contact-card .wpcf7 {
	color: var(--wp--preset--color--primary-900);
}

.contact-card .contact-form-panel {
	padding: 1.5rem;
	border: 1px solid rgba(110, 85, 48, 0.12);
	border-radius: 2px;
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.9) 0%, rgba(255, 255, 255, 0.72) 100%);
	box-shadow: 0 18px 40px -32px rgba(44, 57, 36, 0.45);
}

.contact-card .wpcf7 form {
	display: grid;
	gap: 1rem;
}

.contact-card .wpcf7 p {
	margin: 0;
	font-size: 0.95rem;
	line-height: 1.7;
	color: var(--wp--preset--color--stone-600);
}

.contact-card .wpcf7 p label {
	display: block;
	color: var(--wp--preset--color--primary-900);
	font-size: 0.8125rem;
	font-weight: 500;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.contact-card .wpcf7 :is(input:not([type="submit"]), select, textarea) {
	display: block;
	width: 100%;
	margin-top: 0.45rem;
	padding: 0.8rem 0.9rem;
	border: 1px solid var(--wp--preset--color--sand-200);
	border-radius: 2px;
	background: rgba(255, 255, 255, 0.96);
	color: var(--wp--preset--color--stone-800);
	font-size: 1rem;
	line-height: 1.5;
	box-sizing: border-box;
	box-shadow: inset 0 1px 2px rgba(44, 57, 36, 0.03);
	transition: border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease, transform 0.2s ease;
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
}

.contact-card .wpcf7 select {
	background-image: linear-gradient(45deg, transparent 50%, var(--wp--preset--color--primary-900) 50%), linear-gradient(135deg, var(--wp--preset--color--primary-900) 50%, transparent 50%);
	background-position: calc(100% - 1rem) calc(50% - 3px), calc(100% - 0.7rem) calc(50% - 3px);
	background-size: 6px 6px, 6px 6px;
	background-repeat: no-repeat;
	padding-right: 2.5rem;
	cursor: pointer;
}

.contact-card .wpcf7 textarea {
	min-height: 9rem;
	resize: vertical;
}

.contact-card .wpcf7 :is(input:not([type="submit"]), select, textarea):focus {
	outline: none;
	border-color: var(--wp--preset--color--accent-500);
	box-shadow: 0 0 0 3px rgba(139, 110, 62, 0.14), inset 0 1px 2px rgba(44, 57, 36, 0.03);
	background: #fff;
	transform: translateY(-1px);
}

.contact-card .wpcf7 input[type="date"] {
	min-height: 3rem;
	color-scheme: light;
}

.contact-card .wpcf7 .wpcf7-spinner {
	margin: 0 0 0 0.75rem;
	vertical-align: middle;
}

.contact-card .wpcf7 input[type="submit"] {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 3.25rem;
	padding: 0.9rem 2.25rem;
	border: none;
	border-radius: 2px;
	background: var(--wp--preset--color--primary-900);
	color: var(--wp--preset--color--white);
	font-size: 0.8125rem;
	font-weight: 500;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	cursor: pointer;
	box-shadow: 0 14px 30px -22px rgba(44, 57, 36, 0.8);
	transition: background-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
	appearance: none;
	-webkit-appearance: none;
}

.contact-card .wpcf7 input[type="submit"]:hover,
.contact-card .wpcf7 input[type="submit"]:focus {
	background: var(--wp--preset--color--primary-800);
	transform: translateY(-1px);
	box-shadow: 0 18px 34px -24px rgba(44, 57, 36, 0.85);
	outline: none;
}

.contact-card .wpcf7 .wpcf7-not-valid-tip {
	margin-top: 0.45rem;
	font-size: 0.8125rem;
	color: #a4382b;
	letter-spacing: 0.01em;
	text-transform: none;
}

.contact-card .wpcf7 form .wpcf7-response-output {
	margin: 0.5rem 0 0;
	padding: 0.9rem 1rem;
	border: 1px solid var(--wp--preset--color--sand-200);
	border-radius: 2px;
	font-size: 0.95rem;
	line-height: 1.6;
	color: var(--wp--preset--color--stone-600);
	background: rgba(255, 255, 255, 0.8);
}

.contact-card .wpcf7 form.invalid .wpcf7-response-output,
.contact-card .wpcf7 form.unaccepted .wpcf7-response-output,
.contact-card .wpcf7 form.failed .wpcf7-response-output,
.contact-card .wpcf7 form.aborted .wpcf7-response-output {
	border-color: rgba(164, 56, 43, 0.25);
	background: rgba(164, 56, 43, 0.06);
	color: #7f2d22;
}

.contact-card .wpcf7 form.sent .wpcf7-response-output {
	border-color: rgba(94, 122, 78, 0.3);
	background: rgba(94, 122, 78, 0.08);
	color: var(--wp--preset--color--primary-800);
}

@media (max-width: 781px) {
	.contact-card .contact-form-panel {
		padding: 1.1rem;
	}

	.contact-card .wpcf7 form {
		gap: 0.9rem;
	}

	.contact-card .wpcf7 input[type="submit"] {
		width: 100%;
	}
}

::selection {
	background: var(--wp--preset--color--primary-500);
	color: #fff;
}
