/* =============================================================================
   MAIN STYLE.CSS – deferred geladen im Footer
   Enthält alle Sektionen below-the-fold + Villa-Single + Sub-Pages
   ============================================================================= */

/* ---------- CONTAINER & UTILS ---------- */
.dv-container {
	max-width: var(--container);
	margin: 0 auto;
	padding: 0 var(--gutter);
}
.dv-section { padding: 140px var(--gutter); }
.dv-section--tight { padding: 80px var(--gutter); }
.dv-section--sand { background: var(--c-sand); }
.dv-section--ivory { background: var(--c-ivory); }
.dv-section--canal { background: var(--c-canal); color: var(--c-ivory); }
.dv-section--canal-deep { background: var(--c-canal-deep); color: var(--c-ivory); }

.dv-eyebrow {
	font-size: 11px;
	letter-spacing: 0.3em;
	text-transform: uppercase;
	color: var(--c-gold);
	margin-bottom: 18px;
	display: flex;
	align-items: center;
	gap: 12px;
}
.dv-eyebrow::before {
	content: "";
	width: 24px; height: 1px;
	background: var(--c-gold);
}
.dv-eyebrow--center {
	justify-content: center;
}

.dv-h2 {
	font-size: clamp(40px, 5vw, 64px);
	color: var(--c-canal);
	margin: 0;
	letter-spacing: -0.018em;
}
.dv-h2 em {
	color: var(--c-gold);
	font-style: italic;
	font-weight: 400;
}
.dv-h3 {
	font-size: clamp(28px, 3.5vw, 40px);
	color: var(--c-canal);
}

.dv-text-mute { color: var(--c-mute); }
.dv-text-slate { color: var(--c-slate); }

/* ---------- INTRO/WELCOME ---------- */
.dv-welcome {
	display: grid;
	grid-template-columns: 1fr 1.4fr;
	gap: 80px;
	align-items: start;
	max-width: 1180px;
	margin: 0 auto;
}
.dv-welcome__col-left { position: sticky; top: 120px; }
.dv-welcome__lead {
	font-size: 21px;
	line-height: 1.55;
	color: var(--c-slate);
	margin: 0 0 28px;
	text-wrap: pretty;
}
.dv-welcome__text {
	font-size: 17px;
	line-height: 1.7;
	color: var(--c-slate-mid);
	margin: 0 0 40px;
}
.dv-stats {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 32px;
	padding: 36px 0;
	border-top: 1px solid var(--c-line);
	border-bottom: 1px solid var(--c-line);
}
.dv-stat__num {
	font-family: var(--f-serif);
	font-size: 44px;
	line-height: 1;
	color: var(--c-canal);
	margin-bottom: 8px;
}
.dv-stat__num span { color: var(--c-gold); }
.dv-stat__label {
	font-size: 12px;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--c-mute);
}

@media (max-width: 900px) {
	.dv-welcome { grid-template-columns: 1fr; gap: 40px; }
	.dv-welcome__col-left { position: static; }
	.dv-stats { gap: 16px; }
	.dv-stat__num { font-size: 36px; }
}

/* ---------- VILLA-CARDS (Homepage) ---------- */
.dv-villas-header {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 32px;
	margin-bottom: 64px;
	flex-wrap: wrap;
}
.dv-villa-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 28px;
}
@media (max-width: 1024px) { .dv-villa-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px)  { .dv-villa-grid { grid-template-columns: 1fr; } }

.dv-villa-card {
	background: var(--c-ivory);
	border-radius: var(--radius-sm);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: transform 400ms var(--ease-smooth), box-shadow 400ms var(--ease-smooth);
}
.dv-villa-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-card);
}
.dv-villa-card__media {
	position: relative;
	aspect-ratio: 3/2;
	overflow: hidden;
	background: var(--c-canal);
}
.dv-villa-card__media img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform 800ms var(--ease-smooth);
}
.dv-villa-card:hover .dv-villa-card__media img { transform: scale(1.04); }
.dv-villa-card__num {
	position: absolute;
	bottom: 16px; left: 16px;
	font-family: var(--f-mono);
	font-size: 10px;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: rgba(250,246,240,0.7);
}
.dv-villa-card__body {
	padding: 28px;
	display: flex;
	flex-direction: column;
	gap: 14px;
	flex: 1;
}
.dv-villa-card__title {
	font-family: var(--f-serif);
	font-size: 32px;
	color: var(--c-canal);
	font-weight: 500;
}
.dv-villa-card__title em { color: var(--c-gold); font-style: italic; font-weight: 400; }
.dv-villa-card__meta {
	display: flex;
	gap: 14px;
	flex-wrap: wrap;
	font-size: 12px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--c-mute);
}
.dv-villa-card__meta span { display: inline-flex; align-items: center; gap: 6px; }
.dv-villa-card__excerpt {
	font-size: 15px;
	line-height: 1.6;
	color: var(--c-slate-mid);
}
.dv-villa-card__footer {
	margin-top: auto;
	padding-top: 16px;
	border-top: 1px solid var(--c-line);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
}
.dv-villa-card__price {
	font-family: var(--f-serif);
	font-size: 22px;
	color: var(--c-canal);
}
.dv-villa-card__price small {
	font-family: var(--f-sans);
	font-size: 11px;
	color: var(--c-mute);
	letter-spacing: 0.16em;
	text-transform: uppercase;
	margin-left: 6px;
}
.dv-villa-card__cta {
	color: var(--c-gold);
	font-size: 13px;
	font-weight: 600;
	letter-spacing: 0.04em;
}
.dv-villa-card__cta::after {
	content: " →";
	transition: transform 200ms;
	display: inline-block;
}
.dv-villa-card:hover .dv-villa-card__cta::after { transform: translateX(4px); }

.dv-status-pill {
	position: absolute;
	top: 16px; right: 16px;
	padding: 6px 14px;
	border-radius: var(--radius-pill);
	font-size: 10px;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	font-weight: 600;
	background: rgba(70, 180, 80, 0.95);
	color: var(--c-ivory);
}
.dv-status-pill--booked     { background: rgba(220, 50, 50, 0.95); }
.dv-status-pill--last-min   { background: rgba(255, 185, 0, 0.95); color: var(--c-canal); }

/* ---------- AMENITIES GRID ---------- */
.dv-amenities {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 20px;
}
@media (max-width: 900px) { .dv-amenities { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .dv-amenities { grid-template-columns: 1fr; } }

.dv-amenity {
	padding: 32px 24px;
	background: var(--c-ivory);
	border-radius: var(--radius-sm);
	border: 1px solid var(--c-line);
	transition: border-color 200ms, transform 200ms;
}
.dv-amenity:hover {
	border-color: var(--c-gold);
	transform: translateY(-2px);
}
.dv-amenity__icon {
	width: 32px; height: 32px;
	color: var(--c-gold);
	margin-bottom: 16px;
}
.dv-amenity__title {
	font-family: var(--f-serif);
	font-size: 20px;
	color: var(--c-canal);
	margin-bottom: 6px;
	font-weight: 500;
}
.dv-amenity__text {
	font-size: 14px;
	color: var(--c-slate-mid);
	line-height: 1.6;
}

/* ---------- INFO-SEKTION DUNKEL (Cape Coral Teaser, Boats) ---------- */
.dv-info-dark {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 80px;
	align-items: center;
}
@media (max-width: 900px) { .dv-info-dark { grid-template-columns: 1fr; gap: 40px; } }
.dv-info-dark .dv-eyebrow { color: var(--c-gold-light); }
.dv-info-dark .dv-eyebrow::before { background: var(--c-gold-light); }
.dv-info-dark__h2 {
	font-family: var(--f-serif);
	font-size: clamp(36px, 4.5vw, 56px);
	color: var(--c-ivory);
	font-weight: 500;
}
.dv-info-dark__h2 em { color: var(--c-gold-light); font-style: italic; font-weight: 400; }
.dv-info-dark__text {
	font-size: 17px;
	line-height: 1.7;
	color: rgba(250,246,240,0.85);
	margin-bottom: 28px;
}

/* ---------- REVIEWS ---------- */
.dv-reviews {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
}
@media (max-width: 900px) { .dv-reviews { grid-template-columns: 1fr; } }

.dv-review {
	padding: 36px;
	background: var(--c-ivory);
	border-radius: var(--radius-sm);
	border: 1px solid var(--c-line);
	position: relative;
}
.dv-review__stars {
	color: var(--c-gold);
	font-size: 16px;
	letter-spacing: 4px;
	margin-bottom: 18px;
}
.dv-review__text {
	font-family: var(--f-serif);
	font-size: 22px;
	line-height: 1.45;
	color: var(--c-canal);
	margin-bottom: 24px;
	font-style: italic;
}
.dv-review__author {
	font-size: 13px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--c-mute);
	border-top: 1px solid var(--c-line);
	padding-top: 16px;
}
.dv-review__author strong {
	color: var(--c-canal);
	display: block;
	margin-bottom: 4px;
	letter-spacing: normal;
	font-family: var(--f-sans);
	text-transform: none;
	font-size: 15px;
}

/* ---------- FAQ ACCORDION ---------- */
.dv-faq-list {
	max-width: 880px;
	margin: 0 auto;
}
.dv-faq-item {
	border-bottom: 1px solid var(--c-line);
}
.dv-faq-toggle {
	width: 100%;
	padding: 28px 0;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
	text-align: left;
	font-family: var(--f-serif);
	font-size: 22px;
	color: var(--c-canal);
	transition: color 200ms;
}
.dv-faq-toggle:hover { color: var(--c-gold); }
.dv-faq-toggle__icon {
	flex-shrink: 0;
	width: 24px; height: 24px;
	position: relative;
	transition: transform 300ms var(--ease-smooth);
}
.dv-faq-toggle__icon::before,
.dv-faq-toggle__icon::after {
	content: "";
	position: absolute;
	left: 50%;
	top: 50%;
	width: 14px;
	height: 1.5px;
	background: currentColor;
	transform: translate(-50%, -50%);
	transition: transform 300ms var(--ease-smooth);
}
.dv-faq-toggle__icon::after { transform: translate(-50%, -50%) rotate(90deg); }
.dv-faq-item.is-open .dv-faq-toggle__icon::after { transform: translate(-50%, -50%) rotate(0); }
.dv-faq-panel {
	max-height: 0;
	overflow: hidden;
	transition: max-height 400ms var(--ease-smooth);
}
.dv-faq-item.is-open .dv-faq-panel { max-height: 800px; }
.dv-faq-panel__inner {
	padding: 0 0 28px;
	font-size: 16px;
	line-height: 1.7;
	color: var(--c-slate-mid);
	max-width: 760px;
}

/* ---------- SPECIAL OFFER BANNER ---------- */
.dv-banner {
	background: linear-gradient(135deg, var(--c-gold) 0%, var(--c-gold-light) 100%);
	color: var(--c-canal);
	padding: 48px var(--gutter);
}
.dv-banner__inner {
	max-width: var(--container);
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 32px;
	flex-wrap: wrap;
}
.dv-banner__text {
	font-family: var(--f-serif);
	font-size: clamp(24px, 3vw, 36px);
	font-weight: 500;
}
.dv-banner__text strong { color: var(--c-canal-deep); }

/* Body-Bereich unter dem Banner-Streifen: Bild links, Freitext rechts */
.dv-banner__body {
	max-width: var(--container);
	margin: 32px auto 0;
	display: grid;
	grid-template-columns: 2fr 3fr;
	gap: 32px;
	align-items: start;
}
/* Fallback wenn nur eines von beiden vorhanden ist */
.dv-banner__body:has(> :only-child) {
	grid-template-columns: 1fr;
}
.dv-banner__figure {
	margin: 0;
	border-radius: 4px;
	overflow: hidden;
}
.dv-banner__img {
	width: 100%;
	height: auto;
	display: block;
}
.dv-banner__freitext {
	font-family: var(--f-sans);
	font-size: 16px;
	line-height: 1.7;
	color: var(--c-canal);
}
.dv-banner__freitext p { margin-top: 0; }
.dv-banner__freitext p:last-child { margin-bottom: 0; }

@media (max-width: 768px) {
	.dv-banner__body {
		grid-template-columns: 1fr;
		gap: 24px;
		margin-top: 24px;
	}
}

/* ---------- NEWS-TEASER (Homepage) & NEWS-ARCHIV ---------- */
.dv-news__head {
	text-align: center;
	margin-bottom: 56px;
}
.dv-news__head .dv-eyebrow { justify-content: center; }
.dv-news__head .dv-h2 { margin: 0; }

.dv-news-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 32px;
}

.dv-news-card {
	background: var(--c-ivory);
	border-radius: 4px;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	box-shadow: 0 8px 24px -12px rgba(14, 58, 83, 0.18);
	transition: transform 200ms ease, box-shadow 200ms ease;
}
.dv-news-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 16px 32px -16px rgba(14, 58, 83, 0.28);
}

.dv-news-card__media {
	margin: 0;
	aspect-ratio: 3 / 2;
	overflow: hidden;
}
.dv-news-card__img {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: cover;
}

.dv-news-card__body {
	padding: 24px 24px 28px;
	display: flex;
	flex-direction: column;
	gap: 12px;
	flex: 1;
}

.dv-news-card__meta {
	display: flex;
	align-items: center;
	gap: 12px;
	flex-wrap: wrap;
	font-family: var(--f-mono);
	font-size: 11px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--c-slate-mid);
}

.dv-news-card__badge {
	display: inline-block;
	padding: 3px 10px;
	border-radius: 999px;
	font-weight: 600;
	letter-spacing: 0.1em;
}
.dv-news-card__badge--special { background: var(--c-gold);       color: var(--c-canal); }
.dv-news-card__badge--update  { background: var(--c-canal);      color: var(--c-ivory); }
.dv-news-card__badge--event   { background: var(--c-canal-deep); color: var(--c-ivory); }

.dv-news-card__title {
	font-family: var(--f-serif);
	font-size: 22px;
	font-weight: 500;
	line-height: 1.25;
	color: var(--c-canal);
	margin: 0;
}
.dv-news-card__rabatt {
	display: inline-block;
	margin-left: 6px;
	font-family: var(--f-sans);
	font-size: 14px;
	font-weight: 700;
	color: var(--c-gold-dark);
	letter-spacing: 0.02em;
}

.dv-news-card__text {
	font-family: var(--f-sans);
	font-size: 15px;
	line-height: 1.65;
	color: var(--c-slate-mid);
}
.dv-news-card__text p { margin: 0; }

.dv-news-card__cta {
	margin-top: auto;
	align-self: flex-start;
	font-family: var(--f-sans);
	font-size: 14px;
	font-weight: 600;
	color: var(--c-canal);
	border-bottom: 1px solid var(--c-gold);
	padding-bottom: 2px;
	transition: color 200ms ease, border-color 200ms ease;
}
.dv-news-card__cta:hover {
	color: var(--c-gold-dark);
	border-color: var(--c-gold-dark);
}

.dv-news__footer {
	text-align: center;
	margin-top: 48px;
}
.dv-news__archive-link {
	display: inline-block;
	font-family: var(--f-sans);
	font-size: 15px;
	font-weight: 600;
	letter-spacing: 0.02em;
	color: var(--c-canal);
	border-bottom: 1px solid var(--c-gold);
	padding-bottom: 3px;
	transition: color 200ms ease;
}
.dv-news__archive-link:hover { color: var(--c-gold-dark); }

/* Archiv-spezifisch */
.dv-news-archive__head { text-align: center; }
.dv-news-archive__head .dv-eyebrow { justify-content: center; }
.dv-news-archive__empty {
	text-align: center;
	color: var(--c-slate-mid);
	font-size: 16px;
}

@media (max-width: 960px) {
	.dv-news-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
	.dv-news-grid { grid-template-columns: 1fr; gap: 24px; }
	.dv-news__head { margin-bottom: 36px; }
}

/* ---------- CONTACT CTA ---------- */
.dv-contact-cta {
	text-align: center;
	max-width: 720px;
	margin: 0 auto;
}
.dv-contact-cta h2 { color: var(--c-ivory); margin-bottom: 24px; }
.dv-contact-cta__text {
	font-size: 18px;
	color: rgba(250,246,240,0.8);
	margin-bottom: 36px;
}
.dv-contact-cta__buttons {
	display: flex;
	justify-content: center;
	gap: 16px;
	flex-wrap: wrap;
}

/* ---------- FOOTER ---------- */
.dv-footer {
	background: var(--c-canal-deep);
	color: var(--c-ivory);
	padding: 80px var(--gutter) 32px;
}
.dv-footer__grid {
	max-width: var(--container);
	margin: 0 auto;
	display: grid;
	grid-template-columns: 2fr 1fr 1fr 1fr;
	gap: 48px;
	margin-bottom: 56px;
}
@media (max-width: 900px) { .dv-footer__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .dv-footer__grid { grid-template-columns: 1fr; } }

.dv-footer__tagline {
	font-size: 14px;
	line-height: 1.7;
	color: rgba(250,246,240,0.7);
	max-width: 320px;
	margin-top: 20px;
}
.dv-footer__heading {
	font-size: 11px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--c-gold-light);
	margin-bottom: 18px;
}
.dv-footer__links {
	display: flex;
	flex-direction: column;
	gap: 10px;
	font-size: 14px;
}
.dv-footer__links a { color: rgba(250,246,240,0.85); transition: color 200ms; }
.dv-footer__links a:hover { color: var(--c-ivory); }
.dv-footer__bottom {
	max-width: var(--container);
	margin: 0 auto;
	border-top: 1px solid rgba(250,246,240,0.12);
	padding-top: 28px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 24px;
	flex-wrap: wrap;
	font-size: 12px;
	color: rgba(250,246,240,0.45);
}
.dv-footer__bottom-links { display: flex; gap: 24px; }
.dv-footer__bottom-links a:hover { color: var(--c-ivory); }

/* ============================================================================
   VILLA-SINGLE
   ============================================================================ */

/* ---------- VILLA HERO ---------- */
.dv-villa-hero__addr {
	font-family: var(--f-mono);
	font-size: 11px;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: rgba(250,246,240,0.7);
	line-height: 1.8;
	padding-bottom: 14px;
}
.dv-villa-hero__addr span { color: var(--c-gold-light); }

/* ---------- VILLA STORY ---------- */
.dv-story {
	display: grid;
	grid-template-columns: 1fr 1.5fr;
	gap: 80px;
	max-width: 1180px;
	margin: 0 auto;
}
@media (max-width: 900px) { .dv-story { grid-template-columns: 1fr; gap: 40px; } }
.dv-story__col-sticky {
	position: sticky;
	top: 120px;
	background: var(--c-sand);
	padding-bottom: 24px;
}
.dv-story__lead {
	font-size: 22px;
	line-height: 1.55;
	color: var(--c-slate);
	margin: 0 0 28px;
	text-wrap: pretty;
}
.dv-story__text {
	font-size: 17px;
	line-height: 1.7;
	color: var(--c-slate-mid);
	margin: 0 0 24px;
}

/* ---------- SECTION NOTE ---------- */
.dv-section-note {
	font-family: var(--f-mono);
	font-size: 13px;
	line-height: 1.7;
	letter-spacing: 0.04em;
	color: var(--c-slate);
	margin-top: 32px;
}
.dv-section-note--light {
	color: rgba(250,246,240,0.75);
}
/* Prose-Variante: Fließtext aus WYSIWYG (DM Sans, mit Absatzabständen) */
.dv-section-note--prose {
	font-family: var(--f-sans);
	font-size: 17px;
	line-height: 1.7;
	letter-spacing: 0;
	color: var(--c-slate-mid);
}
.dv-section-note--prose p {
	margin: 0 0 20px;
}
.dv-section-note--prose p:last-child {
	margin-bottom: 0;
}

/* ---------- GALLERY ---------- */
.dv-gallery {
	display: grid;
	grid-template-columns: repeat(12, 1fr);
	gap: 16px;
}
.dv-gallery__item {
	overflow: hidden;
	border-radius: var(--radius-sm);
	cursor: pointer;
	background: var(--c-canal);
	aspect-ratio: 4/3;
}
.dv-gallery__item img { width: 100%; height: 100%; object-fit: cover; transition: transform 700ms var(--ease-smooth); }
.dv-gallery__item:hover img { transform: scale(1.05); }
/* Layout-Pattern: 1 großes + kleine */
.dv-gallery__item:nth-child(1) { grid-column: span 8; aspect-ratio: 16/9; }
.dv-gallery__item:nth-child(2),
.dv-gallery__item:nth-child(3) { grid-column: span 4; }
.dv-gallery__item:nth-child(n+4) { grid-column: span 4; }
@media (max-width: 900px) {
	.dv-gallery__item { grid-column: span 6 !important; }
	.dv-gallery__item:nth-child(1) { grid-column: span 12 !important; }
}

/* ---------- MOBILE GALLERY – Option B: Hero + 2er-Grid + Expand ---------- */
@media (max-width: 640px) {
	/* Alle Bilder: volle Breite, 2er-Grid */
	.dv-gallery__item { grid-column: span 6 !important; }
	/* Erstes Bild (Hero) bleibt voll */
	.dv-gallery__item:nth-child(1) { grid-column: span 12 !important; aspect-ratio: 3/2; }

	/* Ab Bild 10: verstecken bis aufgeklappt */
	.dv-gallery__item--hidden-mobile {
		display: none;
	}
	.dv-gallery--expanded .dv-gallery__item--hidden-mobile {
		display: block;
	}
}

/* Expand-Button – nur auf Mobile sichtbar */
.dv-gallery__toggle {
	display: none;
}
@media (max-width: 640px) {
	.dv-gallery__toggle {
		display: flex;
		align-items: center;
		justify-content: center;
		gap: 10px;
		width: 100%;
		margin-top: 12px;
		padding: 18px 24px;
		background: var(--c-canal);
		color: var(--c-ivory);
		border: none;
		border-radius: var(--radius-sm);
		font-family: var(--f-sans);
		font-size: 13px;
		font-weight: 600;
		letter-spacing: 0.08em;
		text-transform: uppercase;
		cursor: pointer;
		transition: background 200ms;
	}
	.dv-gallery__toggle:hover { background: var(--c-canal-mid, #1B5A7A); }
	/* Pfeil-Icon dreht sich beim Öffnen */
	.dv-gallery__toggle-icon {
		display: inline-block;
		width: 10px; height: 10px;
		border-right: 2px solid var(--c-gold);
		border-bottom: 2px solid var(--c-gold);
		transform: rotate(45deg);
		transition: transform 300ms var(--ease-smooth);
		flex-shrink: 0;
		margin-top: -3px;
	}
	.dv-gallery--expanded .dv-gallery__toggle-icon {
		transform: rotate(-135deg);
		margin-top: 3px;
	}
	/* Button verstecken wenn alle sichtbar (kein Restbestand) */
	.dv-gallery__toggle[hidden] { display: none !important; }
}

/* ---------- VILLA LAYOUT-Sektion ---------- */
.dv-layout-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 48px;
	align-items: start;
}
@media (max-width: 900px) { .dv-layout-grid { grid-template-columns: 1fr; } }
.dv-layout-list { list-style: none; padding: 0; margin: 0; }
.dv-layout-list li {
	display: flex;
	justify-content: space-between;
	gap: 24px;
	padding: 18px 0;
	border-bottom: 1px solid var(--c-line);
	font-size: 15px;
}
.dv-layout-list li span:first-child { color: var(--c-slate); }
.dv-layout-list li span:last-child {
	font-family: var(--f-mono);
	font-size: 14px;
	color: var(--c-canal);
	letter-spacing: 0.04em;
}

/* ---------- PRICING TABLE ---------- */
.dv-pricing {
	max-width: 880px;
	margin: 0 auto;
	background: var(--c-ivory);
	border-radius: var(--radius-sm);
	overflow: hidden;
	border: 1px solid var(--c-line);
}
.dv-pricing__header {
	background: var(--c-canal);
	color: var(--c-ivory);
	padding: 28px 32px;
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	gap: 16px;
	font-size: 11px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
}
.dv-pricing__row {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	gap: 16px;
	padding: 22px 32px;
	border-bottom: 1px solid var(--c-line);
	align-items: center;
}
.dv-pricing__row:last-child { border-bottom: 0; }
.dv-pricing__season {
	font-family: var(--f-serif);
	font-size: 20px;
	color: var(--c-canal);
}
.dv-pricing__period {
	font-family: var(--f-mono);
	font-size: 14px;
	color: var(--c-slate-mid);
}
.dv-pricing__price {
	font-family: var(--f-serif);
	font-size: 24px;
	color: var(--c-gold-dark);
	text-align: right;
}

/* ---------- ENQUIRE CARDS (Villa Single) ---------- */
.dv-enquire {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 24px;
	max-width: 1080px;
	margin: 0 auto;
}
@media (max-width: 900px) { .dv-enquire { grid-template-columns: 1fr; } }
.dv-enquire__card {
	padding: 40px;
	background: var(--c-canal);
	color: var(--c-ivory);
	border-radius: var(--radius-sm);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
	transition: background 200ms, transform 200ms;
}
.dv-enquire__card:hover {
	background: var(--c-canal-mid);
	transform: translateY(-2px);
}
.dv-enquire__card--gold {
	background: linear-gradient(135deg, var(--c-gold) 0%, var(--c-gold-light) 100%);
	color: var(--c-canal);
}
.dv-enquire__card--gold:hover { transform: translateY(-2px); }
.dv-enquire__label {
	font-size: 10px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	opacity: 0.7;
	margin-bottom: 6px;
}
.dv-enquire__title {
	font-family: var(--f-serif);
	font-size: 24px;
	font-weight: 500;
}
.dv-enquire__arrow {
	font-size: 22px;
	flex-shrink: 0;
}

/* ---------- CF7 FORM OVERRIDES ---------- */
.dv-form .wpcf7-form { display: flex; flex-direction: column; gap: 18px; }
.dv-form label {
	font-size: 11px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--c-mute);
	display: block;
	margin-bottom: 6px;
}
.dv-form input[type="text"],
.dv-form input[type="email"],
.dv-form input[type="tel"],
.dv-form input[type="date"],
.dv-form input[type="number"],
.dv-form select,
.dv-form textarea {
	width: 100%;
	padding: 14px 18px;
	background: var(--c-ivory);
	border: 1px solid var(--c-line);
	border-radius: var(--radius-sm);
	font-family: var(--f-sans);
	font-size: 15px;
	color: var(--c-canal);
	transition: border-color 200ms, box-shadow 200ms;
}
.dv-form input:focus,
.dv-form select:focus,
.dv-form textarea:focus {
	outline: none;
	border-color: var(--c-gold);
	box-shadow: 0 0 0 3px rgba(201,148,87,0.18);
}
.dv-form .wpcf7-submit {
	padding: 18px 32px;
	background: var(--c-gold);
	color: var(--c-canal);
	border: none;
	border-radius: var(--radius-pill);
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	cursor: pointer;
	transition: background 200ms, transform 200ms;
}
.dv-form .wpcf7-submit:hover {
	background: #D6A368;
	transform: translateY(-1px);
}

/* ---------- NEWS ---------- */
.dv-news-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 28px;
}
@media (max-width: 900px) { .dv-news-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .dv-news-grid { grid-template-columns: 1fr; } }

.dv-news-card {
	background: var(--c-ivory);
	border: 1px solid var(--c-line);
	border-radius: var(--radius-sm);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: transform 200ms, box-shadow 200ms;
}
.dv-news-card:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-card);
}
.dv-news-card__body { padding: 28px; flex: 1; display: flex; flex-direction: column; gap: 12px; }
.dv-news-card__date {
	font-family: var(--f-mono);
	font-size: 11px;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--c-gold-dark);
}
.dv-news-card__title {
	font-family: var(--f-serif);
	font-size: 24px;
	color: var(--c-canal);
}
.dv-news-card__excerpt {
	font-size: 15px;
	line-height: 1.6;
	color: var(--c-slate-mid);
}

/* ---------- MOBILE NAV PANEL ---------- */
.dv-mobile-menu {
	position: fixed;
	top: 72px; left: 0; right: 0;
	background: var(--c-canal-deep);
	color: var(--c-ivory);
	transform: translateY(-100%);
	transition: transform 350ms var(--ease-smooth);
	z-index: 99;
	padding: 32px var(--gutter);
}
.dv-mobile-menu.is-open { transform: translateY(0); }

/* Generischer Reset für alle Listen/Links im Off-Canvas */
.dv-mobile-menu ul { list-style: none; padding: 0; margin: 0; }
.dv-mobile-menu a { color: var(--c-ivory); }

/* ---------- DESKTOP DROPDOWN ---------- */
.dv-nav__item {
	position: relative;
}

/* Toggle-Button (jetzt: gesamter Top-Level-Link mit Text + SVG) */
.dv-nav__toggle {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	color: currentColor;
	opacity: 0.85;
	transition: opacity 200ms;
}
.dv-nav__toggle:hover { opacity: 1; }
.dv-nav__toggle svg { transition: transform 250ms var(--ease-smooth); }
.dv-nav__toggle[aria-expanded="true"] { opacity: 1; }
.dv-nav__toggle[aria-expanded="true"] svg { transform: rotate(180deg); }

/* Dropdown-Panel */
.dv-nav__dropdown {
	position: absolute;
	top: calc(100% + 12px);
	left: 50%;
	transform: translateX(-50%) translateY(-6px);
	min-width: 200px;
	list-style: none;
	margin: 0;
	padding: 8px 0;
	background: var(--c-canal-deep);
	border: 1px solid rgba(255,255,255,0.08);
	border-radius: var(--radius-sm);
	box-shadow: var(--shadow-card);
	opacity: 0;
	pointer-events: none;
	transition: opacity 220ms ease, transform 220ms var(--ease-smooth);
	z-index: 101;
}

/* Kleines Dreieck oben */
.dv-nav__dropdown::before {
	content: "";
	position: absolute;
	top: -6px;
	left: 50%;
	transform: translateX(-50%);
	border-left: 6px solid transparent;
	border-right: 6px solid transparent;
	border-bottom: 6px solid var(--c-canal-deep);
}

/* Geöffnet via JS */
.dv-nav__item--has-sub.is-open > .dv-nav__dropdown {
	opacity: 1;
	pointer-events: auto;
	transform: translateX(-50%) translateY(0);
}

/* Zweite-Ebene-Links */
.dv-nav__sub-link {
	display: block;
	padding: 10px 20px;
	font-size: 13px;
	font-weight: 500;
	letter-spacing: 0.03em;
	color: rgba(250,246,240,0.85);
	white-space: nowrap;
	transition: color 180ms, background 180ms;
}
.dv-nav__sub-link:hover,
.dv-nav__sub-item--current > .dv-nav__sub-link {
	color: var(--c-gold-light);
	background: rgba(255,255,255,0.05);
}

/* ---------- MOBILE DROPDOWN (im Off-Canvas) ---------- */
.dv-mobile-menu__list { list-style: none; padding: 0; margin: 0; }
.dv-mobile-menu__list .dv-nav__item {
	padding: 14px 0;
	border-bottom: 1px solid rgba(255,255,255,0.08);
}
.dv-mobile-menu__list .dv-nav__link {
	font-family: var(--f-serif);
	font-size: 24px;
	color: var(--c-ivory);
}
.dv-mobile-menu__list .dv-nav__toggle {
	width: 32px;
	height: 32px;
	margin-left: 8px;
	color: var(--c-ivory);
}

/* Untermenü im Mobile: Accordion statt absolutes Panel */
.dv-mobile-menu__list .dv-nav__dropdown {
	position: static;
	transform: none;
	min-width: 0;
	background: transparent;
	border: none;
	border-radius: 0;
	box-shadow: none;
	padding: 4px 0 0 16px;
	opacity: 0;
	max-height: 0;
	overflow: hidden;
	pointer-events: none;
	transition: opacity 250ms ease, max-height 300ms var(--ease-smooth);
}
.dv-mobile-menu__list .dv-nav__dropdown::before { display: none; }
.dv-mobile-menu__list .dv-nav__item--has-sub.is-open > .dv-nav__dropdown {
	opacity: 1;
	max-height: 400px;
	pointer-events: auto;
	transform: none;
}
.dv-mobile-menu__list .dv-nav__sub-link {
	padding: 8px 0;
	font-size: 17px;
	color: rgba(250,246,240,0.7);
	background: transparent;
}
.dv-mobile-menu__list .dv-nav__sub-link:hover,
.dv-mobile-menu__list .dv-nav__sub-item--current > .dv-nav__sub-link {
	color: var(--c-gold-light);
	background: transparent;
}

/* ---------- SCREEN READER ---------- */
.dv-sr-only {
	position: absolute !important;
	width: 1px; height: 1px;
	padding: 0; margin: -1px;
	overflow: hidden;
	clip: rect(0,0,0,0);
	white-space: nowrap;
	border: 0;
}

/* ---------- LIGHTBOX ---------- */
.dv-lightbox {
	position: fixed; inset: 0;
	background: rgba(10, 30, 50, 0.96);
	display: none;
	align-items: center;
	justify-content: center;
	z-index: 200;
	padding: 40px;
}
.dv-lightbox.is-open { display: flex; }
.dv-lightbox__img {
	max-width: 100%;
	max-height: 100%;
	object-fit: contain;
}
.dv-lightbox__close {
	position: absolute;
	top: 24px; right: 32px;
	width: 44px; height: 44px;
	border-radius: 50%;
	background: rgba(255,255,255,0.15);
	color: var(--c-ivory);
	font-size: 24px;
}
.dv-lightbox__close:hover { background: rgba(255,255,255,0.25); }
.dv-lightbox__nav {
	position: absolute;
	top: 50%; transform: translateY(-50%);
	width: 56px; height: 56px;
	border-radius: 50%;
	background: rgba(255,255,255,0.15);
	color: var(--c-ivory);
	font-size: 24px;
}
.dv-lightbox__nav--prev { left: 24px; }
.dv-lightbox__nav--next { right: 24px; }

/* =============================================================================
   ETAPPE 2 – PAGES, GUTENBERG, CF7, BOOTE
   ============================================================================= */

/* ---------- PAGE-HERO (kompakt, 60vh) ---------- */
.dv-hero--page {
	height: 60vh;
	min-height: 480px;
}
.dv-hero--page .dv-hero__inner {
	padding-bottom: 60px;
}
.dv-hero__h1--page {
	font-size: clamp(44px, 6vw, 88px);
}
@media (max-width: 640px) {
	.dv-hero--page { min-height: 420px; height: 70vh; }
}

/* ---------- COMPACT PAGE HEADER (ohne Hero-Bild) ---------- */
.dv-page-header {
	padding: 160px var(--gutter) 60px;
	background: var(--c-canal);
	color: var(--c-ivory);
}
.dv-page-header .dv-h2 {
	color: var(--c-ivory);
}
.dv-page-header .dv-eyebrow {
	color: var(--c-gold-light);
}
.dv-page-header .dv-eyebrow::before {
	background: var(--c-gold-light);
}
.dv-page-header__lead {
	font-size: 19px;
	color: rgba(250,246,240,0.85);
	max-width: 720px;
	margin-top: 24px;
	line-height: 1.55;
}

/* ---------- GUTENBERG / PROSE ---------- */
.dv-prose {
	max-width: 780px;
	margin: 0 auto;
	font-size: 17px;
	line-height: 1.75;
	color: var(--c-slate);
}
.dv-prose > * + * { margin-top: 1.4em; }
.dv-prose h2, .dv-prose h3, .dv-prose h4 {
	font-family: var(--f-serif);
	color: var(--c-canal);
	font-weight: 500;
	line-height: 1.2;
	letter-spacing: -0.012em;
}
.dv-prose h2 { font-size: clamp(28px, 3.5vw, 40px); margin-top: 2em; }
.dv-prose h3 { font-size: clamp(22px, 2.5vw, 28px); margin-top: 1.8em; }
.dv-prose h4 { font-size: 19px; margin-top: 1.6em; }
.dv-prose p { text-wrap: pretty; }
.dv-prose a {
	color: var(--c-gold-dark);
	border-bottom: 1px solid var(--c-gold);
	transition: color 200ms, border-color 200ms;
}
.dv-prose a:hover {
	color: var(--c-canal);
	border-bottom-color: var(--c-canal);
}
.dv-prose strong { color: var(--c-canal); font-weight: 600; }
.dv-prose em { font-style: italic; }
.dv-prose ul, .dv-prose ol { padding-left: 1.4em; }
.dv-prose li + li { margin-top: 0.4em; }
.dv-prose blockquote {
	border-left: 3px solid var(--c-gold);
	padding: 4px 0 4px 24px;
	margin-left: 0;
	font-family: var(--f-serif);
	font-style: italic;
	font-size: 22px;
	color: var(--c-canal);
	line-height: 1.45;
}
.dv-prose hr {
	border: none;
	border-top: 1px solid var(--c-line);
	margin: 3em auto;
	max-width: 80px;
}
.dv-prose figure { margin: 2.4em 0; }
.dv-prose figure img { border-radius: var(--radius-sm); }
.dv-prose figcaption {
	font-size: 13px;
	color: var(--c-mute);
	margin-top: 12px;
	text-align: center;
	font-style: italic;
}

/* Gutenberg-Block-Spezifika */
.dv-prose .wp-block-image { margin: 2.4em 0; }
.dv-prose .wp-block-image img { border-radius: var(--radius-sm); }
.dv-prose .wp-block-image.alignwide,
.dv-prose .wp-block-image.alignfull {
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	max-width: 100vw;
}
.dv-prose .wp-block-image.alignwide img,
.dv-prose .wp-block-image.alignfull img {
	width: 100%;
	height: auto;
}
.dv-prose .wp-block-columns {
	gap: 32px;
	margin: 2.4em 0;
}
.dv-prose .wp-block-quote {
	border-left: 3px solid var(--c-gold);
	padding: 4px 0 4px 24px;
	font-family: var(--f-serif);
	font-style: italic;
	font-size: 22px;
	color: var(--c-canal);
	line-height: 1.45;
}
.dv-prose .wp-block-quote cite {
	display: block;
	margin-top: 16px;
	font-family: var(--f-sans);
	font-size: 13px;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	font-style: normal;
	color: var(--c-mute);
}
.dv-prose .wp-block-gallery,
.dv-prose .wp-block-image figcaption { font-size: 13px; }
.dv-prose .wp-block-button .wp-block-button__link {
	background: var(--c-gold);
	color: var(--c-canal);
	padding: 16px 32px;
	border-radius: var(--radius-pill);
	font-weight: 600;
	letter-spacing: 0.04em;
	text-decoration: none;
	border: none;
	display: inline-block;
	transition: background 200ms, transform 200ms;
}
.dv-prose .wp-block-button .wp-block-button__link:hover {
	background: #D6A368;
	transform: translateY(-1px);
}
.dv-prose .wp-block-separator {
	border: none;
	border-top: 1px solid var(--c-line);
	max-width: 80px;
	margin: 3em auto;
}
.dv-prose .wp-block-cover { border-radius: var(--radius-sm); overflow: hidden; }
.dv-prose .wp-block-table {
	margin: 2em 0;
	border-collapse: collapse;
	width: 100%;
}
.dv-prose .wp-block-table th,
.dv-prose .wp-block-table td {
	border: 1px solid var(--c-line);
	padding: 12px 18px;
	font-size: 15px;
	text-align: left;
}
.dv-prose .wp-block-table th {
	background: var(--c-sand);
	color: var(--c-canal);
	font-weight: 600;
	font-family: var(--f-serif);
}

/* ---------- CF7 GLOBAL (greift auf jeder Seite mit CF7-Block) ---------- */
.dv-prose .wpcf7,
.wpcf7 {
	max-width: 720px;
	margin: 2em auto;
}
.dv-prose .wpcf7-form,
.wpcf7-form {
	display: flex;
	flex-direction: column;
	gap: 18px;
}
/* Hint: CF7 wrapped Felder in <p>-Tags. Wir resetten den Abstand. */
.wpcf7-form p { margin: 0; }
.wpcf7-form label {
	display: block;
	font-size: 11px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--c-mute);
	margin-bottom: 8px;
	font-family: var(--f-sans);
}
.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"],
.wpcf7-form input[type="url"],
.wpcf7-form input[type="date"],
.wpcf7-form input[type="number"],
.wpcf7-form select,
.wpcf7-form textarea {
	width: 100%;
	padding: 14px 18px;
	background: var(--c-ivory);
	border: 1px solid var(--c-line);
	border-radius: var(--radius-sm);
	font-family: var(--f-sans);
	font-size: 15px;
	color: var(--c-canal);
	transition: border-color 200ms, box-shadow 200ms;
	box-sizing: border-box;
}
.wpcf7-form input:focus,
.wpcf7-form select:focus,
.wpcf7-form textarea:focus {
	outline: none;
	border-color: var(--c-gold);
	box-shadow: 0 0 0 3px rgba(201,148,87,0.18);
}
.wpcf7-form textarea {
	min-height: 140px;
	resize: vertical;
	font-family: var(--f-sans);
}
.wpcf7-form .wpcf7-submit {
	margin-top: 8px;
	padding: 16px 32px;
	background: var(--c-gold);
	color: var(--c-canal);
	border: none;
	border-radius: var(--radius-pill);
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	cursor: pointer;
	transition: background 200ms, transform 200ms;
	align-self: flex-start;
	font-family: var(--f-sans);
}
.wpcf7-form .wpcf7-submit:hover {
	background: #D6A368;
	transform: translateY(-1px);
}
.wpcf7-form .wpcf7-submit:disabled {
	opacity: 0.5;
	cursor: not-allowed;
	transform: none;
}
.wpcf7-not-valid-tip {
	color: #B22B2B;
	font-size: 13px;
	margin-top: 6px;
}
.wpcf7-response-output {
	border: 1px solid var(--c-line) !important;
	border-radius: var(--radius-sm) !important;
	padding: 16px 20px !important;
	margin-top: 24px !important;
	font-size: 14px;
}
.wpcf7 form.sent .wpcf7-response-output {
	border-color: #46B450 !important;
	background: rgba(70, 180, 80, 0.08);
	color: #2D6E33;
}
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output {
	border-color: #B22B2B !important;
	background: rgba(178, 43, 43, 0.06);
	color: #B22B2B;
}
.wpcf7-spinner { background-color: var(--c-gold); }

/* CF7 in 2-Spalten-Layout für breitere Forms */
.wpcf7-form .dv-form-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 18px;
}
@media (max-width: 640px) { .wpcf7-form .dv-form-row { grid-template-columns: 1fr; } }

/* ---------- BOOTE-KARTEN ---------- */
.dv-boat-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 32px;
	max-width: 1100px;
	margin: 0 auto;
}
@media (max-width: 900px) { .dv-boat-grid { grid-template-columns: 1fr; max-width: 580px; } }

.dv-boat-card {
	background: var(--c-ivory);
	border-radius: var(--radius-sm);
	overflow: hidden;
	border: 1px solid var(--c-line);
	display: flex;
	flex-direction: column;
	transition: transform 400ms var(--ease-smooth), box-shadow 400ms var(--ease-smooth);
}
.dv-boat-card:hover {
	transform: translateY(-3px);
	box-shadow: var(--shadow-card);
}
.dv-boat-card__media {
	position: relative;
	aspect-ratio: 16/10;
	overflow: hidden;
	background: var(--c-canal);
}
.dv-boat-card__media img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform 700ms var(--ease-smooth);
}
.dv-boat-card:hover .dv-boat-card__media img { transform: scale(1.04); }
.dv-boat-card__body {
	padding: 32px;
	display: flex;
	flex-direction: column;
	gap: 18px;
	flex: 1;
}
.dv-boat-card__title {
	font-family: var(--f-serif);
	font-size: 28px;
	color: var(--c-canal);
	font-weight: 500;
	line-height: 1.15;
}
.dv-boat-card__specs {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
	padding: 18px 0;
	border-top: 1px solid var(--c-line);
	border-bottom: 1px solid var(--c-line);
}
.dv-boat-card__specs > div {
	display: flex;
	flex-direction: column;
	gap: 4px;
}
.dv-boat-card__specs span {
	font-size: 10px;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--c-mute);
}
.dv-boat-card__specs strong {
	font-family: var(--f-serif);
	font-size: 18px;
	color: var(--c-canal);
	font-weight: 500;
}
.dv-boat-card__excerpt {
	font-size: 15px;
	line-height: 1.6;
	color: var(--c-slate-mid);
	margin: 0;
}
.dv-boat-card__price {
	font-family: var(--f-serif);
	font-size: 24px;
	color: var(--c-gold-dark);
	margin-top: auto;
	padding-top: 8px;
}
.dv-boat-card__price small {
	font-family: var(--f-sans);
	font-size: 11px;
	color: var(--c-mute);
	letter-spacing: 0.16em;
	text-transform: uppercase;
	margin-left: 6px;
}
/* ===== Villa Amenities ("What's included") ===== */
.villa-amenities { background: #F5EFE6; padding: 140px 28px; }
.villa-amenities__inner { max-width: 1320px; margin: 0 auto; }

.villa-amenities__head { margin-bottom: 64px; max-width: 700px; }
.villa-amenities__eyebrow {
	display: flex; align-items: center; gap: 12px;
	font-size: 11px; letter-spacing: 0.3em; text-transform: uppercase;
	color: #C99457; margin-bottom: 18px;
}
.villa-amenities__rule { width: 24px; height: 1px; background: #C99457; }
.villa-amenities__title {
	font-family: 'Cormorant Garamond', serif; font-weight: 500;
	font-size: 56px; line-height: 1.0; letter-spacing: -0.018em;
	margin: 0; color: #0E3A53;
}

.villa-amenities__grid { display: grid; gap: 56px; }
.villa-amenities__grid--groups { grid-template-columns: repeat(3, 1fr); }
.villa-amenities__grid--flat   { grid-template-columns: repeat(2, 1fr); }

.villa-amenities__cat {
	font-family: 'Cormorant Garamond', serif; font-style: italic; font-weight: 400;
	font-size: 22px; color: #C99457; margin: 0 0 18px;
}
.villa-amenities__list {
	list-style: none; margin: 0; padding: 0;
	display: flex; flex-direction: column; gap: 8px;
	font-size: 15px; line-height: 1.5; color: #2B3A47;
}
.villa-amenities__list li { display: flex; gap: 14px; align-items: baseline; }
.villa-amenities__dot { color: #C99457; font-size: 10px; line-height: 1; }

@media (max-width: 1024px) {
	.villa-amenities { padding: 96px 24px; }
	.villa-amenities__title { font-size: 44px; }
	.villa-amenities__grid--groups { grid-template-columns: repeat(2, 1fr); }
	.villa-amenities__grid { gap: 40px; }
}
@media (max-width: 640px) {
	.villa-amenities { padding: 72px 20px; }
	.villa-amenities__title { font-size: 34px; }
	.villa-amenities__grid--groups,
	.villa-amenities__grid--flat { grid-template-columns: 1fr; }
}

/* =============================================================================
   FAQ PAGE – Accordion + Filter-Tabs
   Verwendet auf: page-faq.php (Template Name: FAQ)
   ============================================================================= */

/* ---------- FAQ FILTER-TABS ---------- */
.dv-faq-filters {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
	margin-bottom: 56px;
}
.dv-faq-filter {
	padding: 10px 22px;
	border-radius: var(--radius-pill);
	border: 1px solid var(--c-line);
	background: transparent;
	font-family: var(--f-sans);
	font-size: 13px;
	font-weight: 500;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--c-slate);
	cursor: pointer;
	transition: background 200ms, border-color 200ms, color 200ms;
}
.dv-faq-filter:hover {
	border-color: var(--c-gold);
	color: var(--c-canal);
}
.dv-faq-filter.is-active {
	background: var(--c-canal);
	border-color: var(--c-canal);
	color: var(--c-ivory);
}

/* ---------- FAQ ACCORDION ---------- */
.dv-faq-list {
	display: flex;
	flex-direction: column;
	gap: 0;
	border-top: 1px solid var(--c-line);
}

.dv-faq-item {
	border-bottom: 1px solid var(--c-line);
	transition: opacity 300ms ease;
}
.dv-faq-item.is-hidden {
	display: none;
}

.dv-faq-item__trigger {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
	padding: 28px 0;
	background: none;
	border: none;
	cursor: pointer;
	font-family: var(--f-serif);
	font-size: clamp(20px, 2.2vw, 26px);
	font-weight: 500;
	color: var(--c-canal);
	text-align: left;
	line-height: 1.25;
	transition: color 200ms;
}
.dv-faq-item__trigger:hover {
	color: var(--c-gold);
}
.dv-faq-item__trigger[aria-expanded="true"] {
	color: var(--c-canal);
}

.dv-faq-item__icon {
	flex-shrink: 0;
	width: 28px;
	height: 28px;
	border-radius: 50%;
	border: 1px solid var(--c-line);
	display: grid;
	place-items: center;
	color: var(--c-gold);
	transition: transform 300ms var(--ease-smooth), background 200ms, border-color 200ms;
}
.dv-faq-item__trigger[aria-expanded="true"] .dv-faq-item__icon {
	transform: rotate(45deg);
	background: var(--c-canal);
	border-color: var(--c-canal);
	color: var(--c-ivory);
}

.dv-faq-item__body {
	display: grid;
	grid-template-rows: 0fr;
	transition: grid-template-rows 350ms var(--ease-smooth);
}
.dv-faq-item__body.is-open {
	grid-template-rows: 1fr;
}
.dv-faq-item__body-inner {
	overflow: hidden;
}
.dv-faq-item__answer {
	padding: 0 0 28px;
	font-size: 17px;
	line-height: 1.75;
	color: var(--c-slate);
	max-width: 820px;
}

/* ---------- FAQ CTA (am Ende der Seite) ---------- */
.dv-faq-cta {
	margin-top: 80px;
	padding: 56px 64px;
	background: var(--c-canal);
	border-radius: var(--radius-sm);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 32px;
	flex-wrap: wrap;
}
.dv-faq-cta__text {
	color: var(--c-ivory);
}
.dv-faq-cta__eyebrow {
	font-size: 11px;
	letter-spacing: 0.3em;
	text-transform: uppercase;
	color: var(--c-gold-light);
	margin-bottom: 10px;
	display: flex;
	align-items: center;
	gap: 10px;
}
.dv-faq-cta__eyebrow::before {
	content: "";
	width: 20px;
	height: 1px;
	background: var(--c-gold-light);
}
.dv-faq-cta__title {
	font-family: var(--f-serif);
	font-size: clamp(28px, 3vw, 40px);
	font-weight: 500;
	color: var(--c-ivory);
	line-height: 1.1;
}
.dv-faq-cta__title em {
	color: var(--c-gold-light);
	font-style: italic;
	font-weight: 400;
}

/* ---------- Responsiv ---------- */
@media (max-width: 900px) {
	.dv-faq-filter { padding: 8px 16px; font-size: 12px; }
	.dv-faq-item__trigger { font-size: 20px; padding: 22px 0; }
	.dv-faq-item__answer { font-size: 16px; }
	.dv-faq-cta { padding: 40px 32px; }
}
@media (max-width: 640px) {
	.dv-faq-filters { gap: 8px; }
	.dv-faq-filter { padding: 8px 14px; font-size: 11px; }
	.dv-faq-item__trigger { font-size: 18px; gap: 16px; }
	.dv-faq-cta { flex-direction: column; align-items: flex-start; padding: 32px 24px; }
}
