
:root {
  --brand-cream: #fcf9f4; --brand-cream-2: #f6f0e6;
  --brand-text: #1c1c19; --brand-muted: #626265;
  --brand-gold: #705742; --brand-gold-light: #8a6f58;
  --brand-gold-soft: rgba(112, 87, 66, 0.08);
  --shadow-card: 0 4px 18px rgba(28, 28, 25, 0.06);
  --shadow-soft: 0 10px 28px rgba(112, 87, 66, 0.18);
  --r-card: 18px; --r-btn: 12px; --r-pill: 999px;
  --topbar-h: 60px;
}
* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body { margin: 0; font-family: 'Work Sans', system-ui, sans-serif; font-size: 16px; line-height: 1.55; color: var(--brand-text); background: var(--brand-cream); -webkit-font-smoothing: antialiased; }
img { display: block; max-width: 100%; height: auto; }
a { color: inherit; }
button { font: inherit; color: inherit; }
h1, h2, h3 { font-family: 'Noto Serif', Georgia, serif; font-weight: 300; letter-spacing: -0.005em; line-height: 1.1; margin: 0 0 0.6em; }
h1 em, h2 em, h3 em { color: var(--brand-gold); font-style: italic; font-weight: 400; }
.eyebrow { margin: 0 0 8px; color: var(--brand-gold); font-size: 11px; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; }
.skip { position: absolute; left: -1000px; top: -1000px; }
.skip:focus { left: 12px; top: 12px; background: var(--brand-text); color: var(--brand-cream); padding: 8px 12px; border-radius: var(--r-btn); z-index: 99; }
.topbar { position: sticky; top: 0; z-index: 30; display: flex; align-items: center; justify-content: space-between; padding: 10px 16px; height: var(--topbar-h); background: rgba(252, 249, 244, 0.94); border-bottom: 1px solid rgba(112, 87, 66, 0.12); backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); }
.topbar-actions { display: flex; align-items: center; gap: 8px; }
.brand img { height: 36px; width: auto; }
.cta { display: inline-flex; align-items: center; justify-content: center; min-height: 44px; padding: 12px 22px; border-radius: var(--r-btn); background: var(--brand-gold); color: #fff; text-decoration: none; font-weight: 500; font-size: 15px; box-shadow: var(--shadow-soft); transition: background-color .25s, transform .25s; }
.cta:hover, .cta:focus-visible { background: var(--brand-gold-light); transform: translateY(-1px); }
.cta-compact { min-height: 38px; padding: 8px 14px; font-size: 13px; box-shadow: 0 6px 16px rgba(112, 87, 66, 0.16); }
.cta-ghost { background: transparent; color: var(--brand-gold); box-shadow: none; border: 1px solid var(--brand-gold); }
.cta-ghost:hover { background: var(--brand-gold-soft); }
.filter-bar { position: sticky; top: var(--topbar-h); z-index: 25; background: rgba(252, 249, 244, 0.94); backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); border-bottom: 1px solid rgba(112, 87, 66, 0.10); }
.filter-scroll { display: flex; gap: 6px; padding: 8px 12px; overflow-x: auto; scrollbar-width: none; scroll-snap-type: x proximity; -webkit-overflow-scrolling: touch; }
.filter-scroll::-webkit-scrollbar { display: none; }
.filter-scroll a { flex: 0 0 auto; padding: 8px 14px; border-radius: var(--r-pill); color: var(--brand-muted); text-decoration: none; font-size: 13px; font-weight: 500; white-space: nowrap; transition: background-color .2s, color .2s; }
.filter-scroll a:hover { color: var(--brand-text); background: var(--brand-gold-soft); }
.filter-scroll a[aria-current="page"] { color: #fff; background: var(--brand-gold); font-weight: 600; }
/* P3: Sub-Reihe (Unterkategorien der aktiven Gruppe). Sitzt unter der Hauptreihe,
   bewusst NICHT sticky — beim Scrollen reicht die Top-Reihe als Orientierung. */
.filter-bar-sub { position: relative; top: 0; background: rgba(252, 249, 244, 0.85); border-bottom: 1px solid rgba(112, 87, 66, 0.08); }
.filter-scroll-sub { padding: 6px 12px; gap: 4px; }
.filter-scroll-sub::before { content: "↳"; color: var(--brand-gold); font-size: 14px; align-self: center; padding: 0 6px 0 2px; opacity: 0.6; }
.filter-scroll-sub a { padding: 6px 12px; font-size: 12.5px; color: var(--brand-muted); background: transparent; }
.filter-scroll-sub a:hover { background: var(--brand-gold-soft); }
.filter-scroll-sub a[aria-current="page"] { color: #fff; background: var(--brand-gold); }
.page { padding-bottom: 80px; }
.hero { padding: 36px 18px 18px; }
.hero-copy h1 { font-size: clamp(40px, 9.5vw, 72px); line-height: 1; margin-bottom: 16px; }
.hero-copy .lede { color: var(--brand-muted); font-size: 17px; line-height: 1.65; max-width: 56ch; margin: 0 0 20px; }
.hero .cta { margin-bottom: 28px; }
.hero-media { margin: 0; border-radius: var(--r-card); overflow: hidden; background: var(--brand-cream-2); aspect-ratio: 4 / 5; }
.hero-media img { width: 100%; height: 100%; object-fit: cover; object-position: center top; }
.cat-hero { padding: 28px 18px 14px; }
.cat-hero h1 { font-size: clamp(36px, 8vw, 60px); margin-bottom: 12px; }
.cat-hero .lede { color: var(--brand-muted); font-size: 16px; max-width: 56ch; margin: 0 0 18px; }
.section-head { padding: 28px 18px 8px; }
.section-head h2 { font-size: clamp(30px, 6.5vw, 46px); }
.cat-section { padding-bottom: 16px; }
.cat-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; padding: 0 12px; }
.cat-card { display: block; text-decoration: none; color: var(--brand-text); background: #fff; border: 1px solid rgba(112, 87, 66, 0.10); border-radius: var(--r-card); overflow: hidden; box-shadow: var(--shadow-card); transition: transform .25s, box-shadow .25s; }
.cat-card:hover { transform: translateY(-2px); box-shadow: 0 12px 30px rgba(28, 28, 25, 0.10); }
.cat-img { aspect-ratio: 4 / 5; overflow: hidden; background: var(--brand-cream-2); }
.cat-img img { width: 100%; height: 100%; object-fit: cover; object-position: center top; transition: transform .5s; }
.cat-card:hover .cat-img img { transform: scale(1.04); }
.cat-meta { padding: 12px 14px 16px; }
.cat-count { display: inline-block; margin-bottom: 6px; padding: 3px 8px; background: var(--brand-gold-soft); color: var(--brand-gold); font-size: 11px; font-weight: 600; letter-spacing: 0.04em; border-radius: var(--r-pill); }
.cat-name { font-family: 'Noto Serif', serif; font-weight: 400; font-size: 19px; line-height: 1.2; margin: 0; }
.atelier-note { margin: 32px 16px 8px; padding: 28px 22px; background: #fff; border: 1px solid rgba(112, 87, 66, 0.10); border-radius: var(--r-card); box-shadow: var(--shadow-card); }
.atelier-note h2 { font-size: clamp(26px, 6vw, 38px); }
.atelier-note p { color: var(--brand-muted); margin: 0 0 18px; }
.grid-section { padding: 8px 0 24px; }
.grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; padding: 0 12px; }
.card { position: relative; background: #fff; border: 1px solid rgba(112, 87, 66, 0.10); border-radius: var(--r-card); overflow: hidden; box-shadow: var(--shadow-card); display: flex; flex-direction: column; }
/* P3: card-body ist jetzt ein <a> auf die Detail-Seite. Bleibt visuell wie vorher,
   bekommt aber Hover-Feedback, damit Bräute spüren: "hier kann ich klicken". */
a.card-body, .card-body { display: block; padding: 12px 14px 16px; color: inherit; text-decoration: none; transition: background-color .2s; }
a.card-body:hover .card-title,
a.card-body:focus-visible .card-title { color: var(--brand-gold); text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 3px; }
a.card-body:focus-visible { outline: 2px solid var(--brand-gold); outline-offset: -2px; border-radius: 0 0 var(--r-card) var(--r-card); }
.card-title { font-family: 'Noto Serif', serif; font-weight: 400; font-size: 22px; line-height: 1.15; margin: 0 0 6px; transition: color .2s; }
.card-desc { margin: 0 0 8px; color: var(--brand-muted); font-size: 13.5px; line-height: 1.5; }
.card-meta { margin: 0; font-size: 12px; color: var(--brand-gold); font-weight: 500; }
.gallery { position: relative; background: var(--brand-cream-2); aspect-ratio: 4 / 5; overflow: hidden; }
.slides { list-style: none; margin: 0; padding: 0; display: flex; width: 100%; height: 100%; overflow-x: auto; scroll-snap-type: x mandatory; scroll-behavior: smooth; scrollbar-width: none; -webkit-overflow-scrolling: touch; }
.slides::-webkit-scrollbar { display: none; }
.slide { flex: 0 0 100%; height: 100%; scroll-snap-align: start; scroll-snap-stop: always; position: relative; }
.slide img { width: 100%; height: 100%; object-fit: cover; object-position: center top; }
.dots { position: absolute; left: 50%; bottom: 8px; transform: translateX(-50%); display: flex; gap: 6px; padding: 6px 8px; background: rgba(252, 249, 244, 0.78); border-radius: var(--r-pill); backdrop-filter: blur(8px); }
.dot { width: 6px; height: 6px; padding: 0; border: 0; border-radius: 50%; background: rgba(28, 28, 25, 0.25); cursor: pointer; transition: background-color .25s, transform .25s; }
.dot.is-active { background: var(--brand-gold); transform: scale(1.3); }
.dot:hover { background: rgba(28, 28, 25, 0.55); }
/* Desktop mit echter Maus: größere Klick-Trefferflächen + mehr Abstand */
@media (hover: hover) and (pointer: fine) {
  .dots { gap: 10px; padding: 7px 12px; }
  .dot { width: 9px; height: 9px; }
  .dot:hover { transform: scale(1.25); }
}
.img-count { position: absolute; top: 10px; left: 10px; padding: 4px 10px; border-radius: var(--r-pill); background: rgba(252, 249, 244, 0.92); color: var(--brand-gold); font-size: 11px; font-weight: 600; letter-spacing: 0.04em; backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); border: 1px solid rgba(112, 87, 66, 0.12); z-index: 4; }

.wish-btn { position: absolute; top: 10px; right: 10px; z-index: 5; width: 38px; height: 38px; display: grid; place-items: center; background: rgba(252, 249, 244, 0.92); border: 1px solid rgba(112, 87, 66, 0.15); border-radius: 50%; color: var(--brand-gold); cursor: pointer; backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); transition: background-color .2s, transform .2s, color .2s, border-color .2s; box-shadow: 0 4px 10px rgba(28, 28, 25, 0.08); }
.wish-btn:hover { transform: scale(1.05); background: #fff; border-color: var(--brand-gold); }
.wish-btn[aria-pressed="true"] { background: var(--brand-gold); border-color: var(--brand-gold); color: #fff; }
.wish-btn[aria-pressed="true"] svg { fill: #fff; }
.wish-btn:focus-visible { outline: 2px solid var(--brand-gold); outline-offset: 2px; }
@keyframes wishPop { 0%{transform:scale(1);} 35%{transform:scale(1.25);} 70%{transform:scale(0.95);} 100%{transform:scale(1);} }
.wish-btn.just-added { animation: wishPop .5s cubic-bezier(.2,.7,.2,1); }

.mix-badge { display: inline-block; margin: 0 0 8px; padding: 4px 10px; background: var(--brand-gold-soft); color: var(--brand-gold); font-size: 11px; font-weight: 600; letter-spacing: 0.06em; border-radius: var(--r-pill); text-transform: uppercase; }
.card[data-cat="mix-match"] { cursor: pointer; }
.card[data-cat="mix-match"] .gallery::after { content: "▸"; position: absolute; bottom: 12px; right: 12px; width: 36px; height: 36px; display: grid; place-items: center; background: rgba(252, 249, 244, 0.92); color: var(--brand-gold); border-radius: 50%; font-size: 16px; font-weight: 600; pointer-events: none; backdrop-filter: blur(8px); box-shadow: 0 4px 10px rgba(28, 28, 25, 0.10); z-index: 4; }

.mix-lightbox { position: fixed; inset: 0; z-index: 80; display: none; align-items: center; justify-content: center; padding: 16px; background: rgba(28, 28, 25, 0.65); backdrop-filter: blur(8px); opacity: 0; transition: opacity .3s; }
.mix-lightbox.is-open { display: flex; opacity: 1; }
.mix-lightbox-card { position: relative; display: grid; grid-template-columns: 1fr; width: 100%; max-width: 980px; max-height: calc(100vh - 32px); background: #fff; border-radius: 18px; overflow: hidden; box-shadow: 0 30px 80px rgba(28, 28, 25, 0.30); }
@media (min-width: 720px) { .mix-lightbox-card { grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr); max-height: 86vh; } }
.mix-photo { background: var(--brand-cream-2); aspect-ratio: 4 / 5; overflow: hidden; }
@media (min-width: 720px) { .mix-photo { aspect-ratio: auto; } }
.mix-photo img { width: 100%; height: 100%; object-fit: cover; object-position: center top; }
.mix-details { padding: 24px 22px 26px; overflow-y: auto; }
@media (min-width: 720px) { .mix-details { padding: 36px 32px; } }
.mix-title { font-family: 'Noto Serif', serif; font-weight: 300; font-size: clamp(26px, 4vw, 36px); margin: 8px 0 14px; }
.mix-intro { font-size: 14px; line-height: 1.55; color: var(--brand-muted); margin: 0 0 18px; }
.mix-parts { list-style: none; margin: 0; padding: 0; display: grid; gap: 8px; }
.mix-parts a { display: grid; grid-template-columns: 64px 1fr auto; gap: 14px; align-items: center; padding: 10px; background: #fff; border: 1px solid rgba(112, 87, 66, 0.12); border-radius: 14px; text-decoration: none; color: var(--brand-text); transition: background-color .2s, border-color .2s, transform .2s; }
.mix-parts a:hover { background: rgba(112, 87, 66, 0.05); border-color: var(--brand-gold); transform: translateY(-1px); }
.mix-parts img { width: 64px; height: 64px; object-fit: cover; object-position: center top; border-radius: 10px; background: var(--brand-cream-2); }
.mix-parts .pt-meta { display: flex; flex-direction: column; gap: 2px; }
.mix-parts .pt-label { font-size: 11px; font-weight: 600; color: var(--brand-gold); letter-spacing: 0.12em; text-transform: uppercase; }
.mix-parts .pt-name { font-family: 'Noto Serif', serif; font-size: 18px; font-weight: 400; }
.mix-parts .pt-arrow { color: var(--brand-gold); font-size: 18px; font-weight: 600; padding-right: 4px; }
.mix-close { position: absolute; top: 12px; right: 12px; z-index: 2; width: 36px; height: 36px; border-radius: 50%; background: rgba(252, 249, 244, 0.92); border: 1px solid rgba(112, 87, 66, 0.15); color: var(--brand-text); font-size: 22px; display: grid; place-items: center; cursor: pointer; backdrop-filter: blur(8px); transition: background-color .2s; }
.mix-close:hover { background: #fff; }

/* Mix-Lightbox: Bild-Navigation + Counter (nur bei mehreren Combo-Bildern) */
.mix-photo { position: relative; }
.mix-nav-wrap { position: absolute; inset: 0; pointer-events: none; }
.mix-nav { pointer-events: auto; position: absolute; top: 50%; transform: translateY(-50%); width: 40px; height: 40px; border-radius: 50%; background: rgba(252, 249, 244, 0.85); border: 1px solid rgba(112, 87, 66, 0.20); color: var(--brand-text); font-size: 22px; line-height: 1; display: grid; place-items: center; cursor: pointer; backdrop-filter: blur(6px); transition: background-color .2s; }
.mix-nav:hover { background: #fff; }
.mix-prev { left: 10px; }
.mix-next { right: 10px; }
.mix-counter { pointer-events: none; position: absolute; left: 12px; top: 12px; padding: 4px 10px; background: rgba(28, 28, 25, 0.55); color: #fff; font-size: 12px; border-radius: 999px; backdrop-filter: blur(6px); }

/* Video-Variant-Toggle (Standard | Plus Size) in der Video-Lightbox */
.video-variant-toggle { position: fixed; top: 16px; left: 50%; transform: translateX(-50%); display: inline-flex; gap: 4px; padding: 4px; background: rgba(252, 249, 244, 0.18); border: 1px solid rgba(252, 249, 244, 0.30); border-radius: 999px; backdrop-filter: blur(8px); z-index: 95; }
.vvt-pill { padding: 6px 14px; border: 0; background: transparent; color: rgba(252, 249, 244, 0.75); font-size: 12px; font-weight: 600; letter-spacing: 0.04em; border-radius: 999px; cursor: pointer; transition: background-color .2s, color .2s; }
.vvt-pill:hover { color: #fff; }
.vvt-pill.is-active { background: rgba(252, 249, 244, 0.95); color: var(--brand-text); }

/* === Bild-Lightbox (mit Swipe + Pfeile) === */
.img-lightbox { position: fixed; inset: 0; z-index: 90; display: none; align-items: center; justify-content: center; padding: 0; background: rgba(28, 28, 25, 0.94); backdrop-filter: blur(10px); opacity: 0; transition: opacity .3s; overflow: hidden; }
.img-lightbox.is-open { display: flex; opacity: 1; }

/* Multi-Slide-Stage: scroll-snap horizontal */
.img-lightbox-stage { position: relative; width: 100vw; height: 100vh; overflow: hidden; }
.img-lightbox-track { display: flex; width: 100%; height: 100%; overflow-x: auto; scroll-snap-type: x mandatory; scroll-behavior: smooth; scrollbar-width: none; -webkit-overflow-scrolling: touch; }
.img-lightbox-track::-webkit-scrollbar { display: none; }
.img-lightbox-slide { flex: 0 0 100vw; height: 100vh; display: flex; align-items: center; justify-content: center; padding: 14px; scroll-snap-align: center; scroll-snap-stop: always; }
.img-lightbox-slide img, .img-lightbox-slide video { max-width: 92vw; max-height: 88vh; border-radius: 6px; background: #000; box-shadow: 0 40px 80px rgba(0,0,0,0.5); object-fit: contain; }
.img-lightbox-slide video { width: auto; height: auto; }

/* Schließen */
.img-lightbox-close { position: fixed; top: 14px; right: 14px; z-index: 100; width: 42px; height: 42px; border-radius: 50%; background: rgba(252, 249, 244, 0.92); border: 0; color: var(--brand-text); font-size: 26px; line-height: 1; display: grid; place-items: center; cursor: pointer; backdrop-filter: blur(8px); transition: background-color .2s ease, transform .2s ease; box-shadow: 0 6px 20px rgba(0,0,0,0.3); padding: 0; }
.img-lightbox-close:hover { background: #fff; transform: scale(1.05); }
@media (max-width: 600px) { .img-lightbox-close { top: 8px; right: 8px; width: 38px; height: 38px; font-size: 22px; } }

/* Navigations-Pfeile (Desktop) */
.img-lightbox-nav { position: fixed; top: 50%; transform: translateY(-50%); z-index: 99; width: 48px; height: 48px; border-radius: 50%; background: rgba(252, 249, 244, 0.85); border: 0; color: var(--brand-text); font-size: 22px; display: grid; place-items: center; cursor: pointer; backdrop-filter: blur(8px); transition: background-color .2s ease, transform .2s ease, opacity .2s ease; box-shadow: 0 6px 20px rgba(0,0,0,0.3); padding: 0; }
.img-lightbox-nav:hover { background: #fff; transform: translateY(-50%) scale(1.06); }
.img-lightbox-nav.is-prev { left: 18px; }
.img-lightbox-nav.is-next { right: 18px; }
.img-lightbox-nav.is-hidden { opacity: 0; pointer-events: none; }
@media (max-width: 700px) {
  /* Auf Mobile: Pfeile dezenter, Touch-Swipe ist primär */
  .img-lightbox-nav { width: 38px; height: 38px; font-size: 18px; opacity: 0.55; }
  .img-lightbox-nav.is-prev { left: 10px; }
  .img-lightbox-nav.is-next { right: 10px; }
}

/* Counter-Pille unten */
.img-lightbox-info { position: fixed; bottom: 18px; left: 50%; transform: translateX(-50%); z-index: 99; padding: 8px 18px; border-radius: 999px; background: rgba(252, 249, 244, 0.92); color: var(--brand-text); font-size: 13px; font-weight: 500; letter-spacing: 0.02em; backdrop-filter: blur(8px); white-space: nowrap; max-width: 90vw; overflow: hidden; text-overflow: ellipsis; box-shadow: 0 6px 20px rgba(0,0,0,0.3); }

/* Galerie-Bild als klickbar markieren */
.slides .slide { cursor: zoom-in; }

/* Video-Indikator auf der Galerie — unten rechts, auf Dot-Höhe */
.video-flag { position: absolute; bottom: 6px; right: 8px; z-index: 4; width: 32px; height: 32px; display: grid; place-items: center; background: rgba(252, 249, 244, 0.92); border: 1px solid rgba(112, 87, 66, 0.15); border-radius: 50%; color: var(--brand-gold); cursor: pointer; backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); transition: background-color .2s ease, transform .2s ease; box-shadow: 0 4px 10px rgba(28, 28, 25, 0.18); padding: 0; border: 0; }
.video-flag:hover { background: #fff; transform: scale(1.08); }
.video-flag svg { width: 14px; height: 14px; margin-left: 2px; }
/* Mix-Match-Karten: ▸-Pseudo-Element ausblenden — Play-Button (.video-flag) ist der
   eindeutige Klick-Indikator. Das zusätzliche ▸ wirkte verwirrend (zwei Icons stapelnd).
   .video-flag bleibt an Standard-Position (bottom: 6, right: 8) — rechts ausgerichtet,
   die Slide-Punkte sind zentriert, kein echter Overlap. */
.card[data-cat="mix-match"] .gallery::after { display: none; }

.wishlist-section { margin: 0 12px 8px; padding: 22px 22px 24px; background: #fff; border: 1px solid rgba(112, 87, 66, 0.18); border-radius: var(--r-card); box-shadow: var(--shadow-card); display: none; }
.wishlist-section.is-active { display: block; }
.wishlist-head { display: flex; flex-wrap: wrap; align-items: baseline; justify-content: space-between; gap: 10px; margin-bottom: 14px; }
.wishlist-head h2 { font-family: 'Noto Serif', serif; font-weight: 400; font-size: clamp(22px, 4vw, 30px); margin: 0; }
.wishlist-head h2 em { color: var(--brand-gold); font-style: italic; }
.wishlist-meta { font-size: 12.5px; color: var(--brand-muted); }
.wishlist-list { list-style: none; margin: 0 0 16px; padding: 0; display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
@media (min-width: 720px) { .wishlist-list { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1080px) { .wishlist-list { grid-template-columns: repeat(4, 1fr); } }
.wishlist-item { display: flex; align-items: center; gap: 10px; padding: 8px 10px; background: var(--brand-cream-2); border: 1px solid rgba(112, 87, 66, 0.12); border-radius: 12px; font-size: 13.5px; }
.wishlist-item .wl-name { font-family: 'Noto Serif', serif; font-size: 15px; flex: 1; min-width: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.wishlist-item .wl-cat { font-size: 11px; color: var(--brand-muted); }
.wishlist-item .wl-rm { width: 26px; height: 26px; border: 0; background: transparent; color: var(--brand-muted); font-size: 18px; line-height: 1; border-radius: 50%; cursor: pointer; transition: background-color .2s, color .2s; }
.wishlist-item .wl-rm:hover { background: rgba(112, 87, 66, 0.10); color: var(--brand-text); }
.wishlist-actions { display: flex; flex-wrap: wrap; gap: 8px; }
.wishlist-actions .btn { padding: 10px 16px; border-radius: var(--r-btn); font-size: 13.5px; font-weight: 500; cursor: pointer; text-decoration: none; border: 1px solid var(--brand-gold); background: var(--brand-gold); color: #fff; display: inline-flex; align-items: center; gap: 8px; }
.wishlist-actions .btn-outline { background: #fff; color: var(--brand-gold); }

.wish-counter { display: none; margin-left: 8px; padding: 2px 8px; background: var(--brand-gold); color: #fff; border-radius: 999px; font-size: 11px; font-weight: 600; }
.wish-counter.is-active { display: inline-flex; }

.grid-cta { margin: 28px 16px 0; padding: 22px; text-align: center; background: #fff; border: 1px solid rgba(112, 87, 66, 0.10); border-radius: var(--r-card); }
.grid-cta p { font-family: 'Noto Serif', serif; font-weight: 300; font-style: italic; font-size: 22px; margin: 0 0 14px; }

.footer { margin-top: 48px; padding: 28px 18px 36px; background: var(--brand-text); color: #b8aea4; font-size: 13px; }
.footer-inner { max-width: 720px; margin: 0 auto; text-align: center; }
.footer-line { margin: 0 0 8px; }
.footer a { color: var(--brand-cream); text-decoration: none; border-bottom: 1px dotted rgba(252, 249, 244, .35); }
.footer .cta-ghost { margin-top: 14px; color: var(--brand-cream); border-color: var(--brand-cream); }
.footer-social { display: flex; gap: 10px; justify-content: center; margin: 14px 0 8px; }
.footer-social a { display: grid; place-items: center; width: 36px; height: 36px; border: 1px solid rgba(252, 249, 244, 0.20); border-radius: 50%; color: rgba(252, 249, 244, 0.78); text-decoration: none; transition: background-color .2s ease, color .2s ease, border-color .2s ease; }
.footer-social a:hover { background: rgba(252, 249, 244, 0.08); color: var(--brand-cream); border-color: rgba(252, 249, 244, 0.45); }
.footer-social a { border-bottom: 1px solid rgba(252, 249, 244, 0.20); }
.footer-social svg { width: 16px; height: 16px; }

@media (min-width: 720px) {
  :root { --topbar-h: 68px; }
  .topbar { padding: 12px 28px; }
  .brand img { height: 40px; }
  .cta-compact { min-height: 42px; padding: 10px 18px; font-size: 14px; }
  /* P3: Filter-Bar visuell in die Topbar-Zeile reinziehen — überlagert Topbar, mittig */
  .filter-bar-top {
    position: sticky; top: 0; z-index: 31;
    margin-top: calc(var(--topbar-h) * -1);
    height: var(--topbar-h);
    background: transparent; border-bottom: 0;
    backdrop-filter: none; -webkit-backdrop-filter: none;
    pointer-events: none;  /* nichts an dieser Bar fängt Klicks ab — */
    display: flex; align-items: center; justify-content: center;
  }
  .filter-bar-top .filter-scroll {
    pointer-events: none;  /* auch der innere Scroll-Container nicht — */
    justify-content: center;
    width: auto; max-width: 100%;
    padding: 0; gap: 4px;
    overflow: visible;
  }
  .filter-bar-top .filter-scroll a {
    pointer-events: auto;  /* nur die Pillen selbst sind klickbar */
  }
  /* Sub-Reihe direkt unter Topbar, sticky + zentriert */
  .filter-bar-sub {
    position: sticky; top: var(--topbar-h); z-index: 24;
    background: rgba(252, 249, 244, 0.92);
    border-top: 1px solid rgba(112, 87, 66, 0.06);
    backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
  }
  .filter-bar-sub .filter-scroll-sub { justify-content: center; }
  .filter-scroll { padding: 10px 24px; gap: 8px; }
  .filter-scroll a { padding: 9px 16px; font-size: 14px; }
  .hero { padding: 56px 28px 36px; display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: 40px; align-items: center; }
  .hero-media { aspect-ratio: 5 / 6; }
  .cat-hero { padding: 44px 28px 24px; }
  .cat-grid, .grid { grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; padding: 0 24px; }
  .card-title { font-size: 24px; }
  .cat-name { font-size: 22px; }
  .atelier-note { margin: 48px 28px 8px; padding: 36px; }
}
@media (min-width: 1080px) {
  .hero { padding: 80px 56px 48px; gap: 64px; }
  .cat-grid, .grid { grid-template-columns: repeat(4, minmax(0, 1fr)); padding: 0 40px; }
  .section-head { padding: 36px 40px 12px; }
  .footer { padding: 40px 56px 56px; }
}
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; scroll-behavior: auto !important; }
}

/* ============ P3: Produkt-Detail-Seiten ============ */
.product-detail { padding-bottom: 100px; }

.breadcrumb { padding: 14px 18px 0; font-size: 12.5px; color: var(--brand-muted); }
.breadcrumb ol { list-style: none; margin: 0; padding: 0; display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.breadcrumb li { display: inline-flex; align-items: center; gap: 6px; }
.breadcrumb li + li::before { content: "›"; color: var(--brand-gold); font-weight: 600; }
.breadcrumb a { color: var(--brand-muted); text-decoration: none; border-bottom: 1px dotted transparent; transition: color .2s, border-color .2s; }
.breadcrumb a:hover, .breadcrumb a:focus-visible { color: var(--brand-text); border-bottom-color: var(--brand-gold); }
.breadcrumb [aria-current="page"] { color: var(--brand-text); font-weight: 500; }

.detail-hero { padding: 18px 18px 8px; }
.detail-gallery { aspect-ratio: 4 / 5; border-radius: var(--r-card); box-shadow: var(--shadow-card); }
.detail-gallery .slide img { object-position: center top; }

.detail-head { padding: 18px 22px 4px; max-width: 60ch; }
.detail-head h1 { font-size: clamp(34px, 8vw, 56px); line-height: 1.05; margin: 4px 0 12px; }
.detail-head .lede { margin: 0; color: var(--brand-muted); font-size: 16px; line-height: 1.65; }

.specs-block { margin: 18px 22px 0; padding: 20px 22px; background: #fff; border: 1px solid rgba(112, 87, 66, 0.10); border-radius: var(--r-card); box-shadow: var(--shadow-card); }
.specs-block dl { margin: 0; display: grid; grid-template-columns: 1fr; gap: 10px 16px; }
.spec-row { display: grid; grid-template-columns: 9em 1fr; gap: 8px 14px; padding: 8px 0; border-bottom: 1px dashed rgba(112, 87, 66, 0.10); }
.spec-row:last-child { border-bottom: none; }
.spec-row dt { margin: 0; font-size: 12px; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; color: var(--brand-gold); align-self: center; }
.spec-row dd { margin: 0; color: var(--brand-text); font-size: 15px; line-height: 1.45; }

.price-note { margin: 20px 22px 0; padding: 18px 20px; background: #f0f6e6; border: 1px solid #c8dba6; border-radius: var(--r-card); }
.price-note .eyebrow { color: #6b8c4a; margin-bottom: 6px; }
.price-note p { margin: 0; color: var(--brand-text); font-size: 15px; line-height: 1.55; }

.detail-cta-row { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; padding: 22px 22px 6px; }
.wish-btn-detail { position: static; width: auto; height: auto; padding: 10px 18px 10px 14px; border-radius: var(--r-btn); display: inline-flex; align-items: center; gap: 8px; background: #fff; border: 1px solid rgba(112, 87, 66, 0.18); color: var(--brand-gold); cursor: pointer; font-weight: 500; transition: background-color .2s, color .2s, border-color .2s; box-shadow: var(--shadow-card); }
.wish-btn-detail:hover { background: var(--brand-gold-soft); border-color: var(--brand-gold); transform: none; }
.wish-btn-detail[aria-pressed="true"] { background: var(--brand-gold); border-color: var(--brand-gold); color: #fff; }
.wish-btn-detail[aria-pressed="true"] svg { fill: #fff; }
.wish-btn-detail .wish-btn-label { font-size: 14px; }

.manufacturer-note { margin: 18px 22px 0; color: var(--brand-muted); font-size: 12px; }
.manufacturer-note a { color: var(--brand-muted); text-decoration: underline; text-underline-offset: 2px; }
.manufacturer-note a:hover { color: var(--brand-text); }

/* Verwandte Modelle + Mix-Einzelteile-Slider */
.related-head { padding: 36px 22px 4px; }
.related-head h2 { font-size: clamp(24px, 5vw, 32px); margin-bottom: 4px; }
.related-head .lede { color: var(--brand-muted); margin: 4px 0 0; font-size: 14.5px; }

.related-models { margin-top: 8px; }
.related-track { display: flex; gap: 14px; padding: 14px 22px 8px; overflow-x: auto; scroll-snap-type: x proximity; scrollbar-width: none; -webkit-overflow-scrolling: touch; }
.related-track::-webkit-scrollbar { display: none; }
.related-slide { flex: 0 0 48%; display: block; text-decoration: none; color: inherit; scroll-snap-align: start; transition: transform .25s; }
.related-slide:hover { transform: translateY(-2px); }
.related-img { aspect-ratio: 4 / 5; overflow: hidden; border-radius: 14px; background: var(--brand-cream-2); box-shadow: var(--shadow-card); }
.related-img img { width: 100%; height: 100%; object-fit: cover; object-position: center top; transition: transform .35s; }
.related-slide:hover .related-img img { transform: scale(1.03); }
.related-name { display: block; padding: 8px 4px 0; font-size: 14px; font-weight: 500; }

/* "Verfügbar als" — Brücke von Limited-Story zu Standard/Plus-Size-Detail-Seiten */
.variant-links { margin-top: 8px; }
.variant-cards { display: grid; grid-template-columns: 1fr; gap: 14px; padding: 14px 22px 8px; }
.variant-card { display: flex; flex-direction: column; gap: 4px; padding: 22px 24px; background: #fff; border: 1px solid rgba(112, 87, 66, 0.16); border-radius: var(--r-card); text-decoration: none; color: inherit; box-shadow: var(--shadow-card); transition: transform .2s, border-color .2s, box-shadow .2s; }
.variant-card:hover, .variant-card:focus-visible { transform: translateY(-2px); border-color: var(--brand-gold); box-shadow: var(--shadow-soft); }
.variant-card .eyebrow { margin: 0 0 4px; }
.variant-card-name { font-family: 'Noto Serif', serif; font-weight: 400; font-size: 24px; line-height: 1.15; }
.variant-card-meta { color: var(--brand-muted); font-size: 14px; margin-top: 2px; }
.variant-card-cta { margin-top: 12px; color: var(--brand-gold); font-size: 13px; font-weight: 600; letter-spacing: 0.02em; }

.mix-parts-section { margin-top: 8px; }
.mix-parts-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; padding: 14px 22px 8px; }
.mix-part-card { display: block; background: #fff; border: 1px solid rgba(112, 87, 66, 0.10); border-radius: var(--r-card); overflow: hidden; box-shadow: var(--shadow-card); text-decoration: none; color: inherit; transition: transform .25s; }
.mix-part-card:hover { transform: translateY(-2px); }
.mix-part-img { aspect-ratio: 4 / 5; background: var(--brand-cream-2); overflow: hidden; }
.mix-part-img img { width: 100%; height: 100%; object-fit: cover; object-position: center top; }
.mix-part-meta { padding: 10px 12px 14px; }
.mix-part-meta .eyebrow { margin: 0 0 4px; font-size: 10.5px; }
.mix-part-name { font-family: 'Noto Serif', serif; font-size: 18px; line-height: 1.2; }

/* "Alle Details ansehen"-Link in der Bild-Lightbox.
   Platziert oben links — kollisionsfrei zu:
   - Close-Button (oben rechts)
   - Pfeil-Navigation (Mitte links/rechts)
   - Counter-Pille "1 / X" (unten zentriert) */
.img-lightbox-detail-link {
  position: fixed; top: 14px; left: 14px;
  display: inline-flex; align-items: center; gap: 6px;
  padding: 10px 16px; border-radius: var(--r-pill);
  background: rgba(252, 249, 244, 0.95); color: var(--brand-gold);
  text-decoration: none; font-size: 13.5px; font-weight: 600;
  letter-spacing: 0.02em;
  border: 1px solid rgba(112, 87, 66, 0.18);
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 6px 14px rgba(28, 28, 25, 0.18);
  z-index: 100;
  transition: background-color .2s, transform .2s, color .2s;
  max-width: calc(100vw - 70px); /* Platz für den Close-Button rechts */
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.img-lightbox-detail-link:hover, .img-lightbox-detail-link:focus-visible {
  background: var(--brand-gold); color: #fff;
  transform: translateY(-1px);
}
.img-lightbox-detail-link[hidden] { display: none; }
@media (max-width: 600px) {
  /* Mobile: kleinere Pille, näher zum Rand — analog zum Close-Button */
  .img-lightbox-detail-link { top: 8px; left: 8px; padding: 8px 12px; font-size: 12.5px; max-width: calc(100vw - 56px); }
}

.mix-detail-link {
  display: inline-flex; align-items: center; gap: 6px;
  margin-top: 14px; padding: 10px 16px;
  border-radius: var(--r-btn);
  background: var(--brand-gold-soft); color: var(--brand-gold);
  text-decoration: none; font-size: 13.5px; font-weight: 600;
  border: 1px solid rgba(112, 87, 66, 0.18);
  transition: background-color .2s, color .2s;
}
.mix-detail-link:hover, .mix-detail-link:focus-visible {
  background: var(--brand-gold); color: #fff;
}
.mix-detail-link[hidden] { display: none; }

/* Detail-Seiten — Layout-Anpassung auf Tablet/Desktop */
@media (min-width: 760px) {
  .breadcrumb { padding: 18px 28px 0; }
  .detail-hero { padding: 20px 28px 8px; }
  .detail-head { padding: 22px 32px 4px; }
  .specs-block { margin: 22px 32px 0; padding: 26px 30px; }
  .specs-block dl { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px 28px; }
  .spec-row { grid-template-columns: 11em 1fr; }
  .price-note { margin: 24px 32px 0; padding: 22px 26px; }
  .detail-cta-row { padding: 28px 32px 6px; gap: 14px; }
  .related-head { padding: 44px 32px 4px; }
  .related-track { padding: 16px 32px 12px; gap: 18px; }
  .related-slide { flex: 0 0 30%; }
  .mix-parts-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); padding: 18px 32px 12px; }
  .variant-cards { grid-template-columns: repeat(2, minmax(0, 1fr)); padding: 18px 32px 12px; gap: 18px; }
}
@media (min-width: 1080px) {
  .breadcrumb { padding: 22px 56px 0; }
  .detail-hero { padding: 24px 56px 12px; }
  .detail-gallery { max-width: 920px; margin: 0 auto; }
  .detail-head { padding: 28px 56px 4px; max-width: 920px; margin: 0 auto; }
  .specs-block { margin: 28px auto 0; max-width: 920px; }
  .price-note { margin: 28px auto 0; max-width: 920px; }
  .detail-cta-row { max-width: 920px; margin: 0 auto; padding: 28px 0 6px; }
  .manufacturer-note { max-width: 920px; margin: 18px auto 0; }
  .related-head { padding: 48px 56px 4px; max-width: 920px; margin: 0 auto; }
  .related-track { padding: 18px 56px 16px; }
  .related-slide { flex: 0 0 22%; }
  .mix-parts-grid { padding: 20px 56px 14px; }
  .variant-cards { max-width: 920px; margin: 0 auto; padding: 20px 0 14px; }
}

/* ============================================================
   Phase 5 · Cross-Promotion zu brautkleidxxl.de
   ============================================================ */

/* Eyebrow-Label — wird von .curvy-crossref-mini geteilt */
.curvy-crossref-eyebrow {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--brand-gold);
  margin: 0 0 10px;
}

/* Katalog-Übersicht + Plus-Size-Kategorie-Pages: dezenter Hinweis */
.curvy-crossref-mini {
  margin: 12px 12px 28px;
  padding: 18px 22px;
  background: var(--brand-cream-2);
  border-left: 3px solid var(--brand-gold);
  border-radius: 6px;
}
.curvy-crossref-mini p {
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--brand-muted);
  margin: 0 0 6px;
}
.curvy-crossref-mini p:last-child { margin-bottom: 0; }
.curvy-crossref-mini .curvy-crossref-eyebrow {
  margin-bottom: 4px;
}
.curvy-crossref-mini a {
  color: var(--brand-gold);
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 2px;
}
@media (min-width: 760px) {
  .curvy-crossref-mini {
    margin: 16px auto 32px;
    max-width: 920px;
  }
}

/* Produktseiten: Sekundär-Hinweis unter dem „In größeren Größen"-Block */
.product-cross-hint {
  margin: 8px 16px 0;
  font-size: 13.5px;
  color: var(--brand-muted);
  line-height: 1.5;
  text-align: center;
}
.product-cross-hint a {
  color: var(--brand-gold);
  font-weight: 500;
  text-decoration: underline;
  text-underline-offset: 2px;
}
@media (min-width: 760px) {
  .product-cross-hint {
    margin: 8px auto 0;
    max-width: 920px;
  }
}
