/*
Theme Name: BBdP (NAL-Base)
Template: twentytwentyfive
Version: 1.0.0
Text Domain: bbdp
*/

/* =========================================================
   FONT FALLBACKS
   ========================================================= */

.has-eb-garamond-font-family {
	font-family: "EB Garamond", serif;
}

.has-alex-brush-font-family {
	font-family: "Alex Brush", cursive;
}

/* =========================================================
   BONS BAISERS DE PARIS
   ========================================================= */

.bons-baisers-block {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.1em;
	width: 100%;
	text-align: center;
	box-sizing: border-box;
}

.bons-baisers-title {
	margin: 0;
	line-height: 1;
	text-align: center;
	font-size: clamp(2rem, 6vw, 5.5rem);
	letter-spacing: 0.04em;
	white-space: nowrap;
	width: 100%;
	box-sizing: border-box;
}

.bons-baisers-title .bons-main {
	display: inline-block;
}

.bons-baisers-title .bons-tail {
	display: inline-block;
	white-space: nowrap;
}

.bons-baisers-title .bons-de {
	display: inline-block;
	font-size: 1.12em;
	line-height: 1;
	vertical-align: baseline;
	margin: 0;
	padding: 0;
	position: relative;
	top: 0.02em;
	color: #ff0000;
}

.bons-baisers-subtitle {
	margin: 0 auto;
	padding: 0;
	line-height: 1.05;
	text-align: center;
	color: #ff0000;
	font-size: clamp(1.6rem, 4.8vw, 7rem);
	white-space: nowrap;
	width: auto;
	max-width: 100%;
	box-sizing: border-box;
}

/* Tablet */
@media (max-width: 1024px) {
	.bons-baisers-title {
		font-size: clamp(1.8rem, 6vw, 4.2rem);
	}

	.bons-baisers-title .bons-de {
		font-size: 1.03em;
		top: 0.01em;
	}

	.bons-baisers-subtitle {
		font-size: clamp(1.5rem, 4.6vw, 2.8rem);
	}
}

/* Mobile */
@media (max-width: 640px) {
	.bons-baisers-title {
		white-space: normal;
		line-height: 1.02;
		font-size: clamp(1.8rem, 9vw, 3rem);
	}

	.bons-baisers-title .bons-main:first-child {
		display: block;
	}

	.bons-baisers-title .bons-tail {
		display: block;
	}

	.bons-baisers-title .bons-de {
		font-size: 1em;
		top: 0;
	}

	.bons-baisers-subtitle {
		white-space: nowrap;
		font-size: clamp(1.6rem, 8vw, 2.5rem);
		line-height: 1.05;
	}
}

/* =========================================================
   BON BAISERS DE PARIS – GLOBAL CSS
   vorsichtig optimiert, Struktur beibehalten
   ========================================================= */

/* =========================================================
   HEADER / WRAPPER
   ========================================================= */

header .wp-block-group.alignwide,
header .wp-block-group.is-layout-constrained {
	width: 100%;
	max-width: 1340px;
	margin-inline: auto;
	box-sizing: border-box;
}

.nal-justified {
	text-align: justify;
	hyphens: auto;
}

#head-frame-menu {
	margin: 0 !important;
}

/* Cover braucht eine definierte Höhe, sonst gibt es kein "unten" */
body .wp-block-cover.cover-btn-bottom {
	min-height: clamp(300px, 30vw, 560px) !important;
	display: flex !important;
}

/* Inner-Container an den unteren Rand */
body .wp-block-cover.cover-btn-bottom > .wp-block-cover__inner-container {
	margin-top: auto !important;
	width: 100%;
	padding: 0 1rem 1rem;
}

/* Buttons: keine Extra-Margins, damit es sauber sitzt */
body .wp-block-cover.cover-btn-bottom .wp-block-buttons {
	margin: 0 !important;
}

.gold-text {
	color: #b79a5a;
	text-shadow: 0 1px 0 rgba(255, 255, 255, 0.35), 0 2px 3px rgba(177, 152, 111, 0.35);
}

.french-swing {
	color: #ff0000;
	font-size: clamp(2.2rem, 2.2rem + ((1vw - 0.2rem) * 2.824), 5rem);
	font-style: normal;
	font-weight: 400;
	margin-top: -0.5rem;
}

.bons-baisers {
	font-size: clamp(1.837rem, 1.837rem + ((1vw - 0.2rem) * 2.138), 7.2rem);
	text-transform: none;
}

/* =========================================================
   HERO
   ========================================================= */

#hero1 {
	min-height: 200px !important;
	transition: min-height 0.3s ease;
}

/* =========================================================
   MOBILE SPACING
   ========================================================= */

.bbdp-footer-menu {
	margin-bottom: 45px !important;
}

.bbdp-headline-group {
	margin: 0 0 -52px -30px !important;
}

.bbdp-head-button-group {
	margin-left: 5em !important;
}

/* =========================================================
   NAV (Mobile Overlay)
   ========================================================= */

@media (max-width: 767px) {
	.wp-block-navigation__responsive-container.is-menu-open {
		background: linear-gradient(
			180deg,
			rgba(255, 255, 255, 0.95) 0%,
			rgba(255, 255, 255, 0.8) 12%,
			rgba(0, 85, 164, 0.55) 28%,
			rgba(255, 255, 255, 0.7) 50%,
			rgba(239, 65, 53, 0.55) 72%,
			rgba(255, 255, 255, 0.8) 88%,
			rgba(255, 255, 255, 0.95) 100%
		) !important;
		backdrop-filter: blur(8px) !important;
		-webkit-backdrop-filter: blur(8px) !important;
	}
}

/* =========================================================
   LOGO
   ========================================================= */

.bbdp-logo {
	width: clamp(70px, 15vw, 80px) !important;
	height: auto !important;
	max-width: 100% !important;
}

.bbdp-logo img {
	display: block;
	max-width: 100%;
	height: auto;
}

/* =========================================================
   HEADLINE
   ========================================================= */

.bbdp-headline,
.bbdp-headline-paris {
	text-shadow: 0 4px 14px rgba(0, 0, 0, 0.45) !important;
}

.bbdp-headline {
	margin-top: 100px !important;
	margin-bottom: 0 !important;
}

.bbdp-headline-paris {
	margin: 0 !important;
	margin-top: -0.1rem !important;
	font-size: 2.5rem !important;
	line-height: 0.9 !important;
}

/* =========================================================
   BUTTON (Mobile small)
   ========================================================= */

@media (max-width: 767px) {
	.wp-block-button.bbdp-head-button .wp-element-button,
	.wp-block-button.bbdp-head-button .wp-block-button__link {
		padding: 0.5em 0.9em !important;
		font-size: 0.85rem !important;
		line-height: 1.2 !important;
	}
}

/* =========================================================
   TABLET / DESKTOP
   ========================================================= */

@media (min-width: 768px) {
	#hero1 {
		min-height: clamp(350px, 35vw, 650px) !important;
	}

	.bbdp-headline {
		margin: 0 !important;
		font-size: 3.5rem !important;
	}

	.bbdp-headline-group {
		margin: 0 !important;
	}

	.bbdp-head-button-group {
		margin-left: -8em !important;
	}

	.bbdp-headline-paris {
		margin-top: -0.8rem !important;
		font-size: 8rem !important;
		line-height: 0.85 !important;
	}

	.bbdp-footer-menu {
		margin-bottom: 0 !important;
	}
}

/* =========================================================
   ULTRA-WIDE / VERY LARGE DISPLAYS
   ========================================================= */

@media (min-width: 1600px) {
	#hero1 {
		min-height: clamp(600px, 38vw, 1020px) !important;
	}

	.bbdp-head-button-group {
		margin-left: -18em !important;
	}
}

/* =========================================================
   AUDIO IN BACKGROUND GROUP
   ========================================================= */

.wp-block-group.has-background {
	position: relative;
	padding-bottom: 90px;
}

.wp-block-group.has-background > figure.wp-block-audio {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 1rem;
	margin: 0;
	padding: 0;
	border: 0;
	background: transparent;
	box-shadow: none;
}

.wp-block-group.has-background > figure.wp-block-audio > audio {
	width: 100%;
	display: block;
}

/* =========================================================
   HEADER: WPML + Navigation Fix
   ========================================================= */

#head-frame-menu .wp-block-group.is-content-justification-right.is-layout-constrained {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 12px;
	flex-wrap: nowrap;
	min-width: 0;
}

#head-frame-menu .wpml-language-switcher-block {
	width: auto !important;
	flex: 0 0 auto;
}

#head-frame-menu .wpml-language-switcher-block > .wp-block-navigation-item,
#head-frame-menu .wpml-language-switcher-block > .wp-block-navigation-item > div {
	width: auto !important;
}

#head-frame-menu nav.wp-block-navigation {
	flex: 0 0 auto;
	min-width: 0;
}

#head-frame-menu nav.wp-block-navigation .wp-block-navigation__container {
	flex-wrap: nowrap;
	white-space: nowrap;
}

/* =========================================================
   WPML DROPDOWN
   ========================================================= */

#head-frame-menu .wpml-language-switcher-block .wp-block-navigation-submenu__toggle {
	padding: 6px 10px;
	background: rgb(251, 250, 243);
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
}

#head-frame-menu .wpml-language-switcher-block ul.wp-block-navigation__submenu-container {
	background: rgb(251, 250, 243) !important;
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	border: 1px solid rgba(0, 0, 0, 0.1);
	padding: 6px !important;
	box-shadow: 0 12px 28px rgba(0, 0, 0, 0.18);
	min-width: 64px;
}

#head-frame-menu .wpml-language-switcher-block ul.wp-block-navigation__submenu-container a.wp-block-navigation-item__content {
	display: flex;
	align-items: center;
	padding: 6px 8px;
	background: transparent !important;
}

#head-frame-menu .wpml-language-switcher-block ul.wp-block-navigation__submenu-container a.wp-block-navigation-item__content:hover {
	background: rgba(0, 0, 0, 0.06) !important;
}

/* =========================================================
   CONTACT FORM
   ========================================================= */

.kontakt_from_input {
	appearance: none;
	border: 1px solid #949494;
	flex-grow: 1;
	font-family: inherit;
	font-size: inherit;
	font-style: inherit;
	font-weight: inherit;
	letter-spacing: inherit;
	line-height: inherit;
	margin-left: 0;
	margin-right: 0;
	min-width: 3rem;
	padding: 8px;
	text-decoration: unset !important;
	text-transform: inherit;
}

.wpcf7-list-item {
	margin: 0 !important;
}

#kontakt_form-acceptance {
	font-size: small;
}

.wpcf7-form-control:not(.wpcf7-acceptance) {
	box-sizing: border-box;
	width: 100%;
	max-width: 100%;
	display: block;
}

.subscribe {
	background-color: var(--wp--preset--color--contrast);
	border-width: 0;
	color: var(--wp--preset--color--base);
	font-family: var(--wp--preset--font-family--montserrat);
	font-size: var(--wp--preset--font-size--medium);
	font-style: inherit;
	font-weight: inherit;
	letter-spacing: -0.36px;
	line-height: inherit;
	padding-top: 1rem;
	padding-right: 2.25rem;
	padding-bottom: 1rem;
	padding-left: 2.25rem;
	text-decoration: none;
	text-transform: inherit;
}

/* =========================================================
   EVENTCAL
   ========================================================= */

div.qem-masonry {
	background: transparent !important;
	padding: 6px;
	margin: 0 0 1em 0;
	-webkit-column-break-inside: avoid;
	page-break-inside: avoid;
	break-inside: avoid;
}

.bbdp-event-list.format-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 2rem;
}

.bbdp-event-card {
	display: flex;
	flex-direction: column;
	border: 1px solid rgba(0, 0, 0, 0.08);
	border-radius: 16px;
	overflow: hidden;
	background: #fff;
	height: 100%;
}

.bbdp-event-image {
	aspect-ratio: 4 / 3;
	overflow: hidden;
}

.bbdp-event-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.bbdp-event-image--placeholder {
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, 0.04);
}

.bbdp-event-content {
	padding: 1.2rem;
	display: flex;
	flex-direction: column;
	gap: 0.6rem;
	flex: 1;
}

.bbdp-event-meta {
	font-size: 0.9rem;
	opacity: 0.75;
	margin: 0;
}

.bbdp-event-more {
	margin-top: auto;
	text-decoration: underline;
	font-size: 0.9rem;
}

/* =========================================================
   TEXT + BILD (MOA)
   ========================================================= */

.moa-row > .wp-block-columns {
	align-items: stretch !important;
}

.moa-row > .wp-block-columns > .wp-block-column {
	display: flex;
	flex-direction: column;
}

.moa-row .wp-block-image.alignleft,
.moa-row .wp-block-image.alignright {
	float: none !important;
	margin: 0 !important;
}

.moa-row .moa-media {
	padding: 0 !important;
}

.moa-row .wp-block-image {
	flex: 1 1 auto;
	display: flex;
	width: 100%;
	margin: 0 !important;
}

.moa-row .wp-block-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.moa-row .wp-block-cover {
	min-height: 100%;
}

@media (max-width: 781px) {
	.moa-row > .wp-block-columns {
		flex-wrap: wrap !important;
	}

	.moa-row > .wp-block-columns > .wp-block-column {
		width: 100% !important;
	}

	.moa-row.moa-img-left > .wp-block-columns > .wp-block-column:first-child {
		order: 2;
	}

	.moa-row.moa-img-left > .wp-block-columns > .wp-block-column:last-child {
		order: 1;
	}

	.moa-row.moa-img-right > .wp-block-columns > .wp-block-column:first-child {
		order: 1;
	}

	.moa-row.moa-img-right > .wp-block-columns > .wp-block-column:last-child {
		order: 2;
	}

	.moa-row .wp-block-image img {
		height: auto !important;
		max-height: 60vh;
	}
}

/* =========================================================
   MOA – Bildhöhen-Varianten (Desktop)
   ========================================================= */

@media (min-width: 782px) {
	.moa-row.moa-h-600 .wp-block-image,
	.moa-row.moa-h-600 .wp-block-image img {
		max-height: 600px;
	}

	.moa-row.moa-h-700 .wp-block-image,
	.moa-row.moa-h-700 .wp-block-image img {
		max-height: 700px;
	}

	.moa-row.moa-h-800 .wp-block-image,
	.moa-row.moa-h-800 .wp-block-image img {
		max-height: 800px;
	}
}