/* ================================================================
   In Frame · Marquee Design — portiert aus dem Claude-Design.
   Tokens kommen zentral aus theme.json; hier nur die Brücke
   (--c-* / --f-*  →  --wp--preset--*) + Layout/Komponenten.
   KEINE Google-Fonts (DSGVO) — Fonts werden via theme.json lokal geladen.
   ================================================================ */

:root {
	--c-ink:        var(--wp--preset--color--ink);
	--c-paper:      var(--wp--preset--color--paper);
	--c-cream:      var(--wp--preset--color--cream);
	--c-soft:       var(--wp--preset--color--soft);
	--c-line:       var(--wp--preset--color--line);
	--c-line-soft:  var(--wp--preset--color--line-soft);
	--c-copper:     var(--wp--preset--color--copper);
	--c-copper-2:   var(--wp--preset--color--copper-2);
	--c-rose:       var(--wp--preset--color--rose);

	--f-display: var(--wp--preset--font-family--display);
	--f-title:   var(--wp--preset--font-family--title);
	--f-ui:      var(--wp--preset--font-family--ui);
	--f-body:    var(--wp--preset--font-family--body);
	--f-script:  var(--wp--preset--font-family--script);
}

/* --- Basis-Reset (aus dem Design portiert, auf mq-Komponenten begrenzt,
       damit normaler Seiteninhalt unberührt bleibt) --- */
html, body { margin: 0; padding: 0; }
body { -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }
/* WordPress-Block-Gap zwischen den obersten Elementen (Header-Part → .mq-root →
   Footer) abschalten – sonst entsteht eine weiße Lücke über dem Hero. */
.wp-site-blocks > * { margin-block-start: 0; margin-block-end: 0; }
.wp-site-blocks { padding: 0; }
/* :where() → Spezifität 0, damit Komponenten-Regeln (z. B. margin:0 auto zum
   Zentrieren) immer gewinnen und der Reset nur Defaults setzt. */
:where(.mq-root, .mq-header, .mq-footer, .mq-menu) * { box-sizing: border-box; }
:where(.mq-root, .mq-header, .mq-footer, .mq-menu) a { color: inherit; text-decoration: none; }
:where(.mq-root, .mq-header, .mq-footer, .mq-menu) ul,
:where(.mq-root) ol { list-style: none; margin: 0; padding: 0; }
:where(.mq-root, .mq-header, .mq-footer) img { display: block; max-width: 100%; }
:where(.mq-root) p, :where(.mq-root) h1, :where(.mq-root) h2, :where(.mq-root) h3, :where(.mq-root) h4, :where(.mq-root) figure { margin: 0; }
:where(.mq-root, .mq-header, .mq-menu) button { font: inherit; cursor: pointer; background: transparent; border: 0; padding: 0; color: inherit; }

/* --- Photo component (robuster als im Prototyp: Bild immer sichtbar) --- */
.if-img {
	position: relative; overflow: hidden;
	background: linear-gradient(135deg, #c8a373 0%, #9F603A 55%, #6b3f24 100%);
}
.if-img img {
	position: absolute; inset: 0;
	width: 100%; height: 100%;
	object-fit: cover; display: block;
	z-index: 1;
}
/* Optionaler cineastischer Fade-in, nur wenn JS aktiv ist */
.js .if-img img { opacity: 0; transition: opacity 700ms ease; }
.js .if-img[data-loaded="1"] img { opacity: 1; }

/* ================================================================
   Concept · Marquee  (verbatim portiert)
   ================================================================ */

.mq-root { background: var(--c-paper); color: var(--c-ink); overflow-x: clip; }
.mq-root section { position: relative; }
/* Positionierungs-Kontext je Sektion – unabhängig vom .mq-root-Wrapper,
   damit auch die Editor-Einzelvorschau (ServerSideRender) korrekt sitzt. */
.mq-hero, .mq-statement, .mq-pair, .mq-cats, .mq-biz, .mq-style,
.mq-fullbleed, .mq-team, .mq-moments, .mq-faq, .mq-quotes,
.mq-showcases, .mq-closing { position: relative; }
/* post-content (Blöcke) im mq-root: keine Breitenbegrenzung / kein Block-Gap,
   damit die Full-Bleed-Sektionen voll greifen. */
.mq-root, .mq-root > .wp-block-post-content, .mq-root .entry-content { margin: 0; padding: 0; max-width: none; }
.mq-root .wp-block-post-content { display: block; }
/* nur Block-Gap entfernen – KEIN max-width-Override (sonst verlieren zentrierte
   Sektionen wie .mq-style/.mq-pair/.mq-showcases ihre 1500px-Begrenzung). */
.mq-root .wp-block-post-content > * { margin-block: 0; }

/* --- Type primitives ----------------------------------------- */
.mq-kicker {
	font-family: var(--f-title); font-weight: 500;
	font-size: 11px; letter-spacing: 0.28em;
	text-transform: uppercase; color: var(--c-soft);
}
.mq-kicker--light { color: rgba(255,255,255,0.78); }
.mq-kicker--small { font-size: 10px; opacity: 0.65; }
.mq-kicker--center { display: block; text-align: center; margin-bottom: 22px; }
.mq-tc {
	font-family: var(--f-ui); font-weight: 600;
	font-size: 10.5px; letter-spacing: 0.22em;
	text-transform: uppercase; color: var(--c-ink);
}
.mq-tc--soft { color: rgba(255,255,255,0.65); }

.mq-h2 {
	font-family: var(--f-display); font-weight: 400;
	font-size: clamp(40px, 5.5vw, 88px);
	line-height: 1.02; letter-spacing: -0.015em;
	color: var(--c-ink);
	text-wrap: balance;
}
.mq-h2 em { font-style: italic; font-weight: 500; color: var(--c-copper); }
.mq-h2--light { color: var(--c-paper); }
.mq-h2--light em { color: #f3d8b8; }

.mq-lead {
	font-family: var(--f-body); font-weight: 400;
	font-size: 20px; line-height: 1.75;
	color: var(--c-soft); max-width: 600px;
	margin: 22px auto 0;
	text-align: center;
}
.mq-lead--light { color: rgba(255,255,255,0.85); }

/* --- Header (overlay) ---------------------------------------- */
.mq-header {
	position: fixed; top: 0; left: 0; right: 0;
	z-index: 80;
	padding: 22px 40px;
	display: grid; grid-template-columns: 1fr auto 1fr;
	align-items: center; gap: 24px;
	color: #fbf7ee;
	transition: color 350ms ease, background 350ms ease, padding 350ms ease, border-color 350ms ease;
}
.mq-header::before {
	content: ""; position: absolute; inset: 0;
	background: linear-gradient(180deg, rgba(0,0,0,0.35) 0%, rgba(0,0,0,0) 100%);
	pointer-events: none; z-index: -1;
	transition: opacity 350ms ease;
}
.mq-header.is-solid {
	background: rgba(251,247,238,0.92);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	border-bottom: 1px solid var(--c-line);
	padding-top: 16px; padding-bottom: 16px;
	color: #14110e;
}
.mq-header.is-solid::before { opacity: 0; }
/* Unterseiten: Header nimmt Platz ein (sticky), überlagert den Inhalt nicht. */
.mq-header--static { position: sticky; }
.mq-header.is-solid .mq-mark img { filter: none; }
/* Logo: weiß über Hero, schwarz wenn solid */
.mq-mark { justify-self: start; line-height: 0; }
.mq-mark img { height: 48px; filter: brightness(1.2); }
.mq-header .mq-mark .logo-black { display: none; }
.mq-header .mq-mark .logo-white { display: block; }
.mq-header.is-solid .mq-mark .logo-black { display: block; }
.mq-header.is-solid .mq-mark .logo-white { display: none; }
/* Eigenes Logo (Custom Logo): über dem Hero weiß gefärbt, solid im Original. */
.mq-mark .logo-custom { height: 36px; width: auto; display: block; }
.mq-header:not(.is-solid) .mq-mark .logo-custom { filter: brightness(0) invert(1); }
/* WP-Adminbar nicht über den fixen Header legen (nur eingeloggt sichtbar). */
.admin-bar .mq-header { top: 32px; }
@media (max-width: 782px) { .admin-bar .mq-header { top: 46px; } }
.mq-nav { display: flex; gap: 4px; justify-self: center; }
.mq-nav__lnk {
	font-family: var(--f-ui); font-weight: 500;
	font-size: 14px; letter-spacing: 0.16em;
	text-transform: uppercase;
	padding: 8px 14px;
	color: inherit; opacity: 0.85;
	transition: opacity 200ms ease;
}
.mq-nav__lnk:hover { opacity: 1; }
.mq-cta {
	justify-self: end;
	display: inline-flex; align-items: center; gap: 8px;
	font-family: var(--f-ui); font-weight: 600;
	font-size: 12.5px; letter-spacing: 0.22em;
	text-transform: uppercase;
	border: 1px solid currentColor;
	padding: 10px 18px; border-radius: 999px;
	opacity: 0.92;
	transition: all 250ms ease;
}
.mq-cta:hover { background: currentColor; }
.mq-cta:hover { color: var(--c-ink); }
.mq-header:not(.is-solid) .mq-cta:hover { color: var(--c-ink); }
.mq-cta__arr { width: 15px; height: 15px; display: inline-block; flex: 0 0 auto; }
.mq-menu__cta .mq-cta__arr { width: 18px; height: 18px; vertical-align: middle; }

/* --- Burger + mobile menu ------------------------------------ */
.mq-burger {
	display: none;
	justify-self: end;
	width: 40px; height: 40px;
	background: none; border: none; cursor: pointer;
	padding: 0;
	flex-direction: column; justify-content: center; align-items: flex-end; gap: 6px;
	color: inherit;
}
.mq-burger span {
	display: block; width: 26px; height: 1.5px;
	background: currentColor;
	transition: transform 300ms ease, opacity 200ms ease, width 300ms ease;
}
.mq-header.is-menu .mq-burger span:nth-child(1) { transform: translateY(7.5px) rotate(45deg); width: 26px; }
.mq-header.is-menu .mq-burger span:nth-child(2) { opacity: 0; }
.mq-header.is-menu .mq-burger span:nth-child(3) { transform: translateY(-7.5px) rotate(-45deg); width: 26px; }
.mq-burger span:nth-child(3) { width: 18px; }

.mq-menu {
	position: fixed; inset: 0; z-index: 70;
	background: var(--c-paper);
	display: flex; flex-direction: column; justify-content: center;
	padding: 90px 32px 48px;
	opacity: 0; pointer-events: none;
	transform: translateY(-8px);
	transition: opacity 360ms ease, transform 360ms ease;
}
.mq-menu.is-open { opacity: 1; pointer-events: auto; transform: none; }
.mq-menu__nav { display: flex; flex-direction: column; gap: 4px; }
.mq-menu__lnk {
	font-family: var(--f-display); font-style: italic; font-weight: 400;
	font-size: clamp(38px, 11vw, 56px); line-height: 1.18;
	color: var(--c-ink);
	transition: color 200ms ease;
}
.mq-menu__lnk:hover, .mq-menu__lnk:active { color: var(--c-copper); }
.mq-menu__foot {
	margin-top: auto; padding-top: 40px;
	border-top: 1px solid var(--c-line);
	display: flex; flex-direction: column; gap: 18px;
}
.mq-menu__cta {
	align-self: flex-start;
	font-family: var(--f-ui); font-weight: 700;
	font-size: 12px; letter-spacing: 0.22em; text-transform: uppercase;
	background: var(--c-ink); color: var(--c-paper);
	padding: 16px 28px; border-radius: 999px;
}
.mq-menu__contact {
	font-family: var(--f-display); font-style: italic;
	font-size: 17px; color: var(--c-soft);
}

/* --- Hero ----------------------------------------------------- */
.mq-hero {
	height: 100vh; min-height: 620px;
	overflow: hidden;
	background: #14110e;
	color: #fff;
}
.mq-hero__frame {
	position: absolute; inset: 0;
	opacity: 0;
	transition: opacity 1300ms cubic-bezier(.16,1,.3,1), transform 9000ms ease-out;
	transform: scale(1.04);
}
.mq-hero__frame[data-active="1"] { opacity: 1; transform: scale(1); }
.mq-hero__veil {
	position: absolute; inset: 0;
	background:
		linear-gradient(180deg, rgba(0,0,0,0.45) 0%, rgba(0,0,0,0) 22%, rgba(0,0,0,0) 40%, rgba(0,0,0,0.65) 78%, rgba(0,0,0,0.85) 100%),
		radial-gradient(140% 70% at 50% 100%, rgba(0,0,0,0.45) 0%, rgba(0,0,0,0) 60%);
	z-index: 2; pointer-events: none;
}
.mq-hero__chrome {
	position: absolute; inset: 0; z-index: 3;
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	grid-template-rows: 110px 1fr auto 60px;
	grid-template-areas:
		".    .       .   "
		".    .       .   "
		"lower lower lower"
		"dots dots   scrl";
	padding: 0 56px 32px;
	align-items: center;
	pointer-events: none;
}
.mq-hero__chrome > * { pointer-events: auto; }
.mq-hero__lower {
	grid-area: lower;
	align-self: end; justify-self: center;
	text-align: center;
	padding-bottom: 8px;
}
.mq-headline {
	display: flex; flex-direction: column; align-items: center;
	gap: 2px; margin: 0;
}
.mq-headline__pre {
	font-family: var(--f-title); font-weight: 400;
	font-size: 11px; letter-spacing: 0.42em;
	text-transform: uppercase;
	color: rgba(255,255,255,0.7);
	margin-bottom: 6px;
}
.mq-headline__main {
	font-family: var(--f-display); font-weight: 500; font-style: italic;
	font-size: clamp(56px, 8.4vw, 132px);
	line-height: 0.94;
	letter-spacing: -0.028em;
	color: #fff;
	text-shadow: 0 4px 30px rgba(0,0,0,0.5);
}
.mq-headline__main em { font-style: italic; font-weight: 500; }
.mq-headline__post {
	font-family: var(--f-title); font-weight: 400;
	font-size: 12px; letter-spacing: 0.34em;
	text-transform: uppercase;
	color: rgba(255,255,255,0.78);
	margin-top: 14px;
}
.mq-hero__dots {
	grid-area: dots; display: flex; gap: 8px; align-self: end;
	align-items: center;
}
.mq-hero__dot {
	width: 36px; height: 24px;
	display: flex; align-items: center;
	padding: 0;
}
.mq-hero__dot-bar {
	width: 100%; height: 1px; background: rgba(255,255,255,0.35);
	transition: all 400ms ease;
}
.mq-hero__dot:hover .mq-hero__dot-bar { background: rgba(255,255,255,0.75); }
.mq-hero__dot.is-active .mq-hero__dot-bar { background: #fff; height: 2px; }
.mq-hero__scroll {
	grid-area: scrl; justify-self: end; align-self: end;
	font-family: var(--f-ui); font-weight: 500;
	font-size: 11px; letter-spacing: 0.28em;
	text-transform: uppercase;
	color: rgba(255,255,255,0.75);
	display: inline-flex; align-items: center; gap: 10px;
}
.mq-hero__scroll span { animation: mqDown 2.2s ease-in-out infinite; display: inline-block; }
@keyframes mqDown {
	0%,100% { transform: translateY(-2px); opacity: 0.5; }
	50%     { transform: translateY(4px);  opacity: 1; }
}

/* --- Statement ------------------------------------------------ */
.mq-statement { padding: 140px 0 100px; background: var(--c-paper); }
.mq-statement__inner { max-width: 980px; margin: 0 auto; padding: 0 56px; text-align: center; }
.mq-statement .mq-kicker--center { display: block; text-align: center; margin-bottom: 22px; }
.mq-h1 {
	font-family: var(--f-display); font-weight: 500;
	font-size: clamp(40px, 5.2vw, 78px);
	line-height: 1.06; letter-spacing: -0.018em;
	color: var(--c-ink); margin: 0 auto;
	max-width: 16ch; text-wrap: balance;
}
.mq-h1 em { font-style: italic; color: var(--c-copper); font-weight: 500; }
.mq-statement__sub {
	font-family: var(--f-display); font-style: italic;
	font-size: clamp(20px, 1.8vw, 26px);
	color: var(--c-soft); margin: 18px 0 0;
}
.mq-statement__editorial {
	max-width: 1180px; margin: 72px auto 0; padding: 0 56px;
	display: grid; grid-template-columns: 0.82fr 1.18fr;
	gap: 72px; align-items: center; text-align: left;
}
.mq-statement__photo { margin: 0; position: relative; }
.mq-statement__photo .if-img { aspect-ratio: 3/4; }
.mq-statement__photo figcaption {
	position: absolute; left: -18px; bottom: 26px;
	background: var(--c-paper); padding: 10px 22px 6px;
}
.mq-statement__photo figcaption .mq-script {
	font-family: var(--f-script); font-size: 30px; color: var(--c-copper);
	line-height: 1; white-space: nowrap;
}
.mq-statement__body { display: flex; flex-direction: column; gap: 20px; }
.mq-statement__body .mq-lead { margin: 0; text-align: left; max-width: 540px; }
.mq-statement__body strong { color: var(--c-ink); font-weight: 600; }
.mq-statement__awards {
	margin: 100px 0 0; padding: 64px 56px 0;
	border-top: 1px solid var(--c-line);
	display: flex; flex-direction: column; align-items: center; gap: 36px;
}
.mq-statement__awards .mq-kicker { color: var(--c-copper); }
.mq-statement__awards-row {
	display: flex; justify-content: center; align-items: flex-end; gap: 36px;
	width: 100%; max-width: 1500px; flex-wrap: nowrap;
}
.mq-statement__awards-row .awa-seal {
	filter: drop-shadow(0 2px 6px rgba(0,0,0,0.04));
	transition: transform 350ms cubic-bezier(.16,1,.3,1);
	flex: 0 0 auto;
}
.mq-statement__awards-row .awa-seal:hover { transform: translateY(-3px); }

/* award seal helpers (aus shared.jsx) */
.awa-seal { height: auto; }
.awa-seal--framed { display: inline-block; background: #fff; padding: 7px; }

/* --- Big pair ------------------------------------------------- */
.mq-pair { padding: 110px 56px 100px; max-width: 1500px; margin: 0 auto; }
.mq-pair__head { display: grid; grid-template-columns: 1.4fr 1fr; align-items: end; gap: 56px; margin-bottom: 56px; }
.mq-pair__headline { display: flex; flex-direction: column; }
.mq-pair__head .mq-kicker { color: var(--c-copper); margin-bottom: 18px; }
.mq-pair__head .mq-h2 { text-align: left; margin: 0; font-size: clamp(34px, 4.4vw, 64px); }
.mq-pair__sub { font-family: var(--f-body); font-size: 18px; line-height: 1.7; color: var(--c-soft); margin: 0 0 8px; max-width: 440px; }
.mq-pair__gallery { display: grid; grid-template-columns: 0.92fr 1.3fr 0.92fr; align-items: start; gap: 36px; }
.mq-pair__gallery figure { margin: 0; position: relative; }
.mq-pair__a { margin-top: 70px; }
.mq-pair__c { margin-top: 70px; }
.mq-pair__a .if-img, .mq-pair__c .if-img { aspect-ratio: 3/4; }
.mq-pair__b .if-img { aspect-ratio: 3/2; }
.mq-pair figcaption { margin-top: 16px; display: flex; flex-direction: column; }
.mq-pair figcaption em { font-family: var(--f-display); font-style: italic; font-size: 16px; color: var(--c-soft); }

/* --- Categories ----------------------------------------------- */
.mq-cats { padding: 100px 56px 100px; background: var(--c-paper); }
.mq-cats__head { text-align: center; margin-bottom: 64px; }
.mq-cats__head .mq-h2 { margin-top: 10px; }
.mq-cats__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; max-width: 1500px; margin: 0 auto; }
.mq-cat { position: relative; overflow: hidden; cursor: pointer; display: block; background: #000; }
.mq-cat .if-img { transition: transform 800ms cubic-bezier(.16,1,.3,1); }
.mq-cat:hover .if-img { transform: scale(1.04); }
.mq-cat__veil {
	position: absolute; inset: 0; z-index: 2;
	background: linear-gradient(180deg, rgba(0,0,0,0.05) 0%, rgba(0,0,0,0.55) 100%);
	transition: background 400ms ease;
}
.mq-cat:hover .mq-cat__veil { background: linear-gradient(180deg, rgba(0,0,0,0.1) 0%, rgba(0,0,0,0.7) 100%); }
.mq-cat__txt { position: absolute; left: 36px; bottom: 30px; z-index: 3; color: #fff; display: flex; flex-direction: column; gap: 6px; }
.mq-cat__txt .mq-tc { color: rgba(255,255,255,0.75); }
.mq-cat h3 { font-family: var(--f-display); font-weight: 500; font-style: italic; font-size: clamp(40px, 4vw, 64px); letter-spacing: -0.01em; margin: 0; color: #fff; }
.mq-cat__sub { font-family: var(--f-ui); font-weight: 500; font-size: 13px; color: rgba(255,255,255,0.85); letter-spacing: 0.04em; }
.mq-cat__arr { font-family: var(--f-ui); font-weight: 600; font-size: 11px; letter-spacing: 0.24em; text-transform: uppercase; color: rgba(255,255,255,0.85); margin-top: 14px; display: inline-flex; gap: 8px; transition: gap 250ms ease; }
.mq-cat:hover .mq-cat__arr { gap: 14px; color: #f3d8b8; }

/* --- Showcases ------------------------------------------------ */
.mq-showcases { padding: 110px 56px; background: var(--c-paper); max-width: 1500px; margin: 0 auto; }
.mq-showcases__head { display: flex; justify-content: space-between; align-items: flex-end; gap: 32px; margin-bottom: 56px; }
.mq-showcases__head .mq-kicker { color: var(--c-copper); display: block; margin-bottom: 12px; }
.mq-showcases__head .mq-h2 { text-align: left; margin: 0; font-size: clamp(36px, 4vw, 60px); }
.mq-showcases__all { font-family: var(--f-ui); font-weight: 600; font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--c-ink); white-space: nowrap; border-bottom: 1px solid var(--c-copper); padding-bottom: 5px; transition: color 200ms ease; }
.mq-showcases__all:hover { color: var(--c-copper); }
.mq-showcases__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 48px 36px; }
.mq-showcase { display: flex; flex-direction: column; cursor: pointer; }
.mq-showcase__img { overflow: hidden; }
.mq-showcase__img .if-img { transition: transform 800ms cubic-bezier(.16,1,.3,1); aspect-ratio: 3/2; }
.mq-showcase:hover .mq-showcase__img .if-img { transform: scale(1.045); }
.mq-showcase__cat { color: var(--c-copper); margin: 22px 0 10px; }
.mq-showcase__title { font-family: var(--f-display); font-weight: 400; font-size: 22px; line-height: 1.32; letter-spacing: -0.01em; color: var(--c-ink); margin: 0; text-wrap: pretty; transition: color 200ms ease; }
.mq-showcase:hover .mq-showcase__title { color: var(--c-copper); }

/* --- Business ------------------------------------------------- */
.mq-biz { padding: 120px 56px; background: #1a1612; color: #fbf7ee; }
.mq-biz__inner { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: 80px; align-items: start; max-width: 1400px; margin: 0 auto; }
.mq-biz__lead { display: flex; flex-direction: column; align-items: flex-start; }
.mq-biz__lead .mq-kicker { color: var(--c-copper); margin-bottom: 18px; }
.mq-biz__lead .mq-h2 { text-align: left; margin: 0; font-size: clamp(40px, 4.4vw, 66px); }
.mq-biz__lead .mq-h2 em { color: #f3d8b8; }
.mq-biz__btn { margin-top: 34px; }
.mq-biz__body { display: flex; flex-direction: column; gap: 44px; padding-top: 8px; }
.mq-biz__body p { font-family: var(--f-body); font-size: 19.5px; line-height: 1.8; color: rgba(251,247,238,0.78); margin: 0; max-width: 640px; }
.mq-biz__body p strong { color: #fbf7ee; font-weight: 600; }
.mq-biz__partners { display: flex; flex-direction: column; gap: 22px; }
.mq-biz__partners .mq-tc--soft { color: rgba(251,247,238,0.5); }
.mq-biz__logos { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; max-width: 520px; }
.mq-biz__logo { background: rgba(251,247,238,0.06); border: 1px solid rgba(251,247,238,0.14); min-height: 54px; display: flex; align-items: center; justify-content: center; color: rgba(251,247,238,0.6); font-family: var(--f-ui); font-size: 12px; letter-spacing: 0.1em; }

/* --- Full-bleed quote ---------------------------------------- */
.mq-fullbleed { height: 80vh; min-height: 540px; overflow: hidden; background: #14110e; }
.mq-fullbleed__veil { position: absolute; inset: 0; z-index: 2; background: linear-gradient(180deg, rgba(0,0,0,0.55) 0%, rgba(0,0,0,0.25) 50%, rgba(0,0,0,0.7) 100%); }
.mq-fullbleed__quote { position: absolute; inset: 0; z-index: 3; display: flex; flex-direction: column; justify-content: center; align-items: center; text-align: center; padding: 0 48px; }
.mq-fullbleed__quote p { font-family: var(--f-display); font-weight: 400; font-style: italic; font-size: clamp(28px, 3.4vw, 52px); line-height: 1.3; color: #fff; max-width: 1000px; text-shadow: 0 4px 30px rgba(0,0,0,0.4); text-wrap: balance; margin: 0 0 28px; }

/* --- Quotes --------------------------------------------------- */
.mq-quotes { position: relative; height: 90vh; min-height: 620px; background: #14110e; overflow: hidden; }
.mq-quotes__photo { position: absolute; inset: 0; }
.mq-quotes__veil { position: absolute; inset: 0; z-index: 2; background: linear-gradient(90deg, rgba(0,0,0,0.6) 0%, rgba(0,0,0,0.1) 60%); }
.mq-quotes__card { position: absolute; left: 56px; top: 50%; transform: translateY(-50%); z-index: 3; background: var(--c-paper); padding: 48px 44px 38px; max-width: 540px; display: flex; flex-direction: column; gap: 22px; }
.mq-quotes__slide { display: none; }
.mq-quotes__slide.is-active { display: block; }
.mq-quotes__card blockquote { margin: 0; }
.mq-quotes__card blockquote p { font-family: var(--f-display); font-style: italic; font-weight: 500; font-size: clamp(20px, 1.7vw, 26px); line-height: 1.45; color: var(--c-ink); margin: 0 0 26px; }
.mq-quotes__card blockquote footer { display: flex; flex-direction: column; gap: 4px; }
.mq-quotes__card blockquote footer em { font-family: var(--f-display); font-style: italic; font-size: 17px; color: var(--c-ink); }
.mq-quotes__dots { display: flex; gap: 8px; }
.mq-quotes__dots button { width: 22px; height: 2px; background: rgba(28,17,14,0.25); transition: all 350ms ease; }
.mq-quotes__dots button.is-active { background: var(--c-copper); width: 40px; }

/* --- Closing -------------------------------------------------- */
.mq-closing { height: 90vh; min-height: 640px; overflow: hidden; background: #14110e; }
.mq-closing__veil { position: absolute; inset: 0; z-index: 2; background: linear-gradient(180deg, rgba(20,17,14,0.3) 0%, rgba(20,17,14,0.7) 100%); }
.mq-closing__txt { position: absolute; inset: 0; z-index: 3; display: flex; flex-direction: column; justify-content: center; align-items: center; text-align: center; padding: 0 48px; }
.mq-closing__txt .mq-h2 { margin-top: 10px; }
.mq-closing__txt .mq-lead { margin: 26px auto 36px; }
.mq-closing__cta { display: flex; gap: 28px; align-items: center; flex-wrap: wrap; justify-content: center; }
.mq-btn { display: inline-flex; align-items: center; gap: 10px; font-family: var(--f-ui); font-weight: 700; font-size: 12px; letter-spacing: 0.24em; text-transform: uppercase; background: #fbf7ee; color: var(--c-ink); padding: 18px 32px; border-radius: 999px; transition: all 250ms ease; }
.mq-btn:hover { background: var(--c-copper); color: #fbf7ee; }
.mq-link { font-family: var(--f-display); font-style: italic; font-size: 19px; color: rgba(255,255,255,0.92); border-bottom: 1px solid rgba(255,255,255,0.5); padding-bottom: 4px; transition: all 200ms ease; }
.mq-link:hover { color: #f3d8b8; border-color: #f3d8b8; }

/* --- Footer --------------------------------------------------- */
.mq-footer { background: var(--c-paper); padding: 80px 56px 28px; border-top: 1px solid var(--c-line); }
.mq-footer__inner { display: grid; grid-template-columns: 1fr 2fr; gap: 60px; max-width: 1500px; margin: 0 auto; padding-bottom: 50px; border-bottom: 1px solid var(--c-line); }
.mq-footer__brand img { height: 48px; }
.mq-script { font-family: var(--f-script); font-size: 36px; color: var(--c-copper); display: block; margin-top: 14px; line-height: 1; }
.mq-footer__cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: 36px; }
.mq-footer__cols > div > span { display: block; margin-bottom: 16px; }
.mq-footer__cols ul { display: flex; flex-direction: column; gap: 10px; }
.mq-footer__cols ul li { font-family: var(--f-display); font-style: italic; font-size: 18px; color: var(--c-ink); }
.mq-footer__cols ul li a { transition: color 200ms ease; }
.mq-footer__cols ul li a:hover { color: var(--c-copper); }
.mq-footer__legal { display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap; padding-top: 24px; font-family: var(--f-ui); font-size: 12px; color: var(--c-soft); max-width: 1500px; margin: 0 auto; }
.mq-footer__legal div { display: flex; gap: 14px; }

/* --- StyleNote ------------------------------------------------ */
.mq-style { padding: 120px 56px; background: var(--c-paper); display: grid; grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr); gap: 80px; align-items: center; max-width: 1500px; margin: 0 auto; }
.mq-style__txt { max-width: 520px; }
.mq-style__txt .mq-kicker { color: var(--c-copper); }
.mq-style__txt .mq-h2 { text-align: left; margin: 14px 0 24px; font-size: clamp(36px, 4.2vw, 64px); }
.mq-style__txt .mq-lead { text-align: left; margin: 0; max-width: none; }
.mq-style__list { margin: 32px 0 0; padding: 0; list-style: none; display: flex; flex-direction: column; border-top: 1px solid var(--c-line); }
.mq-style__list li { padding: 18px 0; border-bottom: 1px solid var(--c-line); font-family: var(--f-body); font-size: 17px; color: var(--c-soft); line-height: 1.55; }
.mq-style__list li em { font-family: var(--f-display); font-style: italic; color: var(--c-ink); font-size: 19px; margin-right: 10px; }
.mq-style__pix { display: grid; grid-template-columns: 1fr 1fr; grid-template-rows: auto auto; grid-template-areas: "p1 p2" "p3 p2"; gap: 18px; min-width: 0; }
.mq-style__pix > * { min-width: 0; }
.mq-style__pix > :nth-child(1) { grid-area: p1; }
.mq-style__pix > :nth-child(2) { grid-area: p2; align-self: stretch; }
/* Breite kommt aus der Grid-Spalte, nicht aus der Höhe (sonst Überlauf). */
.mq-style__pix > :nth-child(2) .if-img { aspect-ratio: auto; width: 100%; height: 100%; }
.mq-style__pix > :nth-child(3) { grid-area: p3; }
.mq-style__pix .if-img { aspect-ratio: 3/2; }

/* --- AboutUs -------------------------------------------------- */
.mq-team { padding: 120px 56px; background: var(--c-cream); }
.mq-team__head { max-width: 760px; margin: 0 auto 72px; text-align: center; }
.mq-team__head .mq-kicker { color: var(--c-copper); }
.mq-team__head .mq-h2 { margin: 12px 0 18px; }
.mq-team__head .mq-lead { margin: 0 auto; }
.mq-team__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; max-width: 1300px; margin: 0 auto; }
.mq-team__person { display: flex; flex-direction: column; gap: 24px; }
.mq-team__person .if-img { aspect-ratio: 3/4; background: var(--c-paper); border: 1px solid var(--c-line); }
.mq-team__body { display: flex; flex-direction: column; gap: 10px; }
.mq-team__name { font-family: var(--f-display); font-weight: 500; font-style: italic; font-size: clamp(32px, 3.4vw, 48px); margin: 0; color: var(--c-ink); line-height: 1; }
.mq-team__role { font-family: var(--f-ui); font-weight: 600; font-size: 12px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--c-copper); margin-bottom: 4px; }
.mq-team__person p { font-family: var(--f-body); font-size: 17.5px; line-height: 1.75; color: var(--c-soft); margin: 0; max-width: 480px; }
.mq-team__person p strong { color: var(--c-ink); font-weight: 600; }

/* --- MagicMoments --------------------------------------------- */
.mq-moments { padding: 120px 56px; background: var(--c-paper); }
.mq-moments__head { max-width: 700px; margin: 0 auto 64px; text-align: center; }
.mq-moments__head .mq-kicker { color: var(--c-copper); }
.mq-moments__head .mq-h2 { margin-top: 12px; }
.mq-moments__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 28px; max-width: 1500px; margin: 0 auto; }
.mq-moment { margin: 0; display: flex; flex-direction: column; gap: 18px; }
.mq-moment .if-img { aspect-ratio: 3/4; }
.mq-moment figcaption { display: flex; flex-direction: column; gap: 8px; }
.mq-moment figcaption .mq-tc { font-family: var(--f-ui); font-weight: 600; font-size: 10.5px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--c-copper); }
.mq-moment figcaption em { font-family: var(--f-display); font-style: italic; font-weight: 400; font-size: 18px; line-height: 1.4; color: var(--c-ink); text-wrap: balance; }

/* --- FAQ ------------------------------------------------------ */
.mq-faq { padding: 120px 56px; background: var(--c-cream); }
.mq-faq__head { max-width: 760px; margin: 0 auto 56px; text-align: center; }
.mq-faq__head .mq-kicker { color: var(--c-copper); }
.mq-faq__head .mq-h2 { margin-top: 12px; }
.mq-faq__list { list-style: none; padding: 0; margin: 0 auto; max-width: 900px; border-top: 1px solid var(--c-line); }
.mq-faq__item { border-bottom: 1px solid var(--c-line); }
.mq-faq__q { width: 100%; display: grid; grid-template-columns: auto 1fr auto; align-items: baseline; gap: 24px; padding: 34px 8px; background: none; border: none; cursor: pointer; text-align: left; font: inherit; color: var(--c-ink); transition: color 200ms ease; }
.mq-faq__q:hover { color: var(--c-copper); }
.mq-faq__num { font-family: var(--f-ui); font-weight: 600; font-size: 11px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--c-soft); }
.mq-faq__qtext { font-family: var(--f-display); font-weight: 400; font-style: italic; font-size: clamp(20px, 1.6vw, 26px); line-height: 1.3; }
.mq-faq__plus { font-family: var(--f-ui); font-weight: 300; font-size: 24px; line-height: 1; color: var(--c-copper); width: 22px; text-align: center; transition: transform 250ms ease; }
.mq-faq__a { overflow: hidden; max-height: 0; transition: max-height 350ms cubic-bezier(.16,1,.3,1), padding 250ms ease; padding: 0 8px; }
.mq-faq__a p { font-family: var(--f-body); font-size: 17.5px; line-height: 1.75; color: var(--c-soft); margin: 0; max-width: 760px; }
.mq-faq__item.is-open .mq-faq__a { max-height: 600px; padding: 4px 8px 36px; }

/* --- Responsive ----------------------------------------------- */
@media (max-width: 1100px) {
	.mq-nav { display: none; }
	.mq-cta { display: none; }
	.mq-burger { display: flex; }
	.mq-pair { padding: 64px 24px 72px; }
	.mq-pair__head { grid-template-columns: 1fr; gap: 20px; align-items: start; margin-bottom: 40px; }
	.mq-pair__sub { max-width: 520px; margin-bottom: 0; }
	.mq-pair__gallery { grid-template-columns: 1fr 1fr; gap: 24px; }
	.mq-pair__a, .mq-pair__c { margin-top: 0; }
	.mq-pair__b { grid-column: 1 / -1; order: 3; }
	.mq-cats__grid { grid-template-columns: 1fr; }
	.mq-quotes__card { left: 24px; right: 24px; max-width: none; }
	.mq-statement__awards-row { gap: 22px; }
	.mq-statement__awards-row .awa-seal { width: 84px; height: auto; }
	.mq-statement__awards-row .awa-seal--framed img { width: 80px; }
	.mq-pair { padding: 56px 24px 64px; }
	.mq-style { grid-template-columns: 1fr; gap: 56px; padding: 80px 24px; }
	.mq-team__grid { grid-template-columns: 1fr; gap: 64px; max-width: 560px; }
	.mq-moments__grid { grid-template-columns: 1fr 1fr; gap: 24px; }
	.mq-team, .mq-moments, .mq-faq { padding-left: 24px; padding-right: 24px; padding-top: 80px; padding-bottom: 80px; }
	.mq-showcases { padding: 80px 24px; }
	.mq-showcases__grid { grid-template-columns: 1fr 1fr; gap: 40px 28px; }
	.mq-biz { padding: 90px 24px; }
	.mq-biz__inner { grid-template-columns: 1fr; gap: 44px; }
	.mq-biz__logos { max-width: none; }
}
@media (max-width: 720px) {
	.mq-header { padding: 14px 18px; }
	.mq-pair__gallery { grid-template-columns: 1fr; gap: 18px; }
	.mq-pair__b { grid-column: 1; order: 0; }
	.mq-mark img { height: 36px; }
	.mq-hero__chrome { padding: 0 20px 24px; grid-template-rows: 76px 1fr auto 44px; }
	.mq-headline__main { font-size: clamp(48px, 14vw, 88px); }
	.mq-headline__post { font-size: 10px; letter-spacing: 0.24em; }
	.mq-statement__awards { margin-top: 64px; padding-top: 40px; padding-left: 24px; padding-right: 24px; }
	.mq-statement__awards-row { gap: 14px; flex-wrap: wrap; }
	.mq-statement__awards-row .awa-seal { width: 56px; height: auto; }
	.mq-statement__awards-row .awa-seal--framed img { width: 52px; }
	.mq-statement__body .mq-lead { font-size: 16px; max-width: none; }
	.mq-statement__editorial { grid-template-columns: 1fr; gap: 36px; padding: 0 24px; margin-top: 48px; }
	.mq-statement__photo { max-width: 360px; }
	.mq-statement__photo figcaption { left: 0; }
	.mq-moments__grid { grid-template-columns: 1fr; gap: 32px; }
	.mq-faq__q { padding: 22px 4px; column-gap: 14px; }
	.mq-faq__num { display: none; }
	.mq-statement, .mq-cats { padding-left: 24px; padding-right: 24px; }
	.mq-statement { padding-top: 80px; padding-bottom: 64px; }
	.mq-cats { padding-top: 64px; padding-bottom: 64px; }
	.mq-cat__txt { left: 18px; bottom: 18px; }
	.mq-footer { padding: 56px 24px 24px; }
	.mq-footer__inner { grid-template-columns: 1fr; gap: 36px; }
	.mq-footer__cols { grid-template-columns: 1fr 1fr; }
	.mq-showcases__grid { grid-template-columns: 1fr; gap: 36px; }
	.mq-showcases__head { flex-direction: column; align-items: flex-start; gap: 16px; }
}
