:root{--lav:#D6C6E0;--rose:#CD888A;--wine:#A34849;--cream:#FFF8C9;--dark:#33272b;--soft:#fbf6f8;--line:#eadde6}html{scroll-behavior:smooth}body{font-family:Poppins,Arial,sans-serif;color:var(--dark);background:#fff;margin:0}.container{max-width:1180px;margin:auto;padding:0 22px}.topbar{background:var(--lav);font-size:14px}.topbar .container{display:flex;gap:18px;justify-content:center;flex-wrap:wrap;padding:9px 22px}.topbar a{color:var(--dark);font-weight:600}.navbar{position:sticky;top:0;background:rgba(255,255,255,.94);backdrop-filter:blur(12px);z-index:99;border-bottom:1px solid var(--line)}.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:12px 22px}.brand{display:flex;align-items:center;gap:12px;color:var(--dark);font-weight:700}.brand img{height:58px;width:auto}.nav-links{display:flex;gap:18px;flex-wrap:wrap;justify-content:flex-end}.nav-links a{color:var(--dark);font-weight:600;font-size:14px}.nav-links a:hover{color:var(--rose)}.hero{min-height:78vh;display:flex;align-items:center;background:linear-gradient(120deg,rgba(255,255,255,.92) 0%,rgba(255,255,255,.70) 45%,rgba(51,39,43,.18) 100%),url('../images/hero-header.jpg') center top/cover}.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:42px;align-items:center}.kicker{color:var(--wine);font-weight:700;letter-spacing:.06em;text-transform:uppercase}.hero h1{font-size:58px;line-height:1.05;margin:18px 0;color:var(--dark)}.lead{font-size:20px;line-height:1.65;color:#594b50}.btn{display:inline-flex;align-items:center;gap:9px;background:var(--rose);color:white!important;padding:14px 24px;border-radius:999px;border:2px solid var(--rose);font-weight:700;text-decoration:none;transition:.25s}.btn:hover{transform:translateY(-2px);background:var(--wine);border-color:var(--wine);text-decoration:none}.btn.alt{background:#fff;color:var(--wine)!important}.btn.light{background:#fff;color:var(--dark)!important;border-color:#fff}.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px}.hero-card,.card,.price-box,.review,.contact-box{background:rgba(255,255,255,.88);border:1px solid var(--line);box-shadow:0 20px 45px rgba(98,58,73,.12);border-radius:30px;padding:30px}.hero-card{text-align:center}.hero-card img{max-height:260px;object-fit:contain}.quote{font-family:Georgia,serif;font-size:22px;color:var(--wine);line-height:1.5}.color-row{display:flex;justify-content:center;gap:10px;margin-top:20px}.color{width:42px;height:42px;border-radius:999px;border:2px solid white;box-shadow:0 3px 12px rgba(0,0,0,.12)}.section{padding:90px 0}.section.alt{background:var(--soft)}.section-title{text-align:center;max-width:760px;margin:0 auto 46px}.section-title h2{font-size:42px;margin:0 0 12px}.section-title p{font-size:18px;color:#705f65}.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.card h3,.price-box h3{color:var(--wine);font-size:24px;margin-top:0}.service-list,.price-list{list-style:none;padding:0;margin:0}.service-list li,.price-list li{padding:10px 0;border-bottom:1px solid var(--line)}.price-list li{display:flex;justify-content:space-between;gap:12px}.badge-row{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.badge{background:#fff;border:1px solid var(--line);color:var(--wine);padding:10px 14px;border-radius:999px;font-weight:600}.prices{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.gallery a{display:block;border-radius:22px;overflow:hidden;box-shadow:0 12px 28px rgba(0,0,0,.08)}.gallery img{height:230px;width:100%;object-fit:cover;transition:.3s}.gallery a:hover img{transform:scale(1.05)}.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.stars{color:#d09b00;font-size:22px;letter-spacing:2px}.review-author{font-weight:700;color:var(--wine);margin-top:14px}.social-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.social-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px;background:#fff;border:1px solid var(--line);border-radius:24px;padding:24px;text-decoration:none;color:var(--dark);box-shadow:0 12px 24px rgba(0,0,0,.06)}.social-card:hover{color:var(--wine);transform:translateY(-2px);text-decoration:none}.social-card svg{width:34px;height:34px;fill:var(--rose)}.contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:28px}.contact-line{display:flex;gap:12px;margin:14px 0}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-group.full{grid-column:1/-1}label{font-weight:700;font-size:14px;color:var(--wine)}input,select,textarea{width:100%;border:1px solid var(--line);border-radius:16px;padding:13px 14px;background:#fff;font:inherit}textarea{min-height:140px}.form-note{font-size:13px;color:#77696e}.footer{background:var(--dark);color:white;padding:38px 0}.footer a{color:white}.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:24px}.footer img{height:74px;background:white;border-radius:12px;padding:8px}.legal{font-size:13px;opacity:.8;margin-top:22px}.cookie{position:fixed;left:20px;right:20px;bottom:20px;background:#fff;border:1px solid var(--line);box-shadow:0 18px 45px rgba(0,0,0,.18);padding:18px;border-radius:20px;z-index:999;display:none}.cookie.show{display:flex;align-items:center;justify-content:space-between;gap:15px}.whatsapp-float{position:fixed;right:22px;bottom:92px;background:#25D366;color:#fff!important;width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 12px 28px rgba(0,0,0,.2);z-index:100}.whatsapp-float svg{width:28px;height:28px;fill:white}@media(max-width:900px){.hero-grid,.contact-grid,.cards,.prices,.reviews,.social-grid,.footer-grid{grid-template-columns:1fr}.gallery{grid-template-columns:repeat(2,1fr)}.hero h1{font-size:42px}.nav-inner{align-items:flex-start;flex-direction:column}.form-grid{grid-template-columns:1fr}.cookie.show{display:block}.cookie .btn{margin-top:12px}}@media(max-width:520px){.gallery{grid-template-columns:1fr}.hero h1{font-size:34px}.section{padding:60px 0}.section-title h2{font-size:32px}.hero-card img{max-height:190px}}

/* Erweiterte Struktur für Leistungen und Fotogalerie */
.service-cards{grid-template-columns:repeat(3,1fr)}
.service-cards .card p{color:#705f65;line-height:1.65;margin-bottom:16px}
#pflege .card p{font-size:16px;line-height:1.75;color:#594b50}
#galerie .gallery{grid-auto-flow:dense}
#galerie .gallery a:nth-child(1),#galerie .gallery a:nth-child(6),#galerie .gallery a:nth-child(8),#galerie .gallery a:nth-child(10){grid-row:span 2}
#galerie .gallery a:nth-child(1) img,#galerie .gallery a:nth-child(6) img,#galerie .gallery a:nth-child(8) img,#galerie .gallery a:nth-child(10) img{height:476px}
#galerie .gallery a:nth-child(3){grid-column:span 2}
#galerie .gallery a:nth-child(3) img{height:230px}
@media(max-width:900px){.service-cards{grid-template-columns:1fr}#galerie .gallery a:nth-child(n){grid-column:auto;grid-row:auto}#galerie .gallery a:nth-child(n) img{height:260px}}


/* =========================================================
   GESCHENKGUTSCHEIN
   ========================================================= */
.gutschein-section {
  background: linear-gradient(180deg, #ffffff 0%, #faf6fa 100%);
}

.gutschein-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}

.gutschein-images {
  display: grid;
  gap: 24px;
}

.gutschein-card {
  display: block;
  overflow: hidden;
  border-radius: 28px;
  background: #fff;
  box-shadow: 0 16px 45px rgba(0, 0, 0, 0.08);
  transition: transform 0.35s ease, box-shadow 0.35s ease;
}

.gutschein-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 24px 55px rgba(0, 0, 0, 0.13);
}

.gutschein-card img {
  display: block;
  width: 100%;
  height: auto;
}

.gutschein-text h2 {
  margin-bottom: 24px;
}

.gutschein-list {
  margin: 28px 0 0;
}

@media (max-width: 980px) {
  .gutschein-grid {
    grid-template-columns: 1fr;
  }
}


/* =====================================================
   LEGAL PAGES: IMPRESSUM & DATENSCHUTZ
   Clean German legal layout: black text on white background
   ===================================================== */
.legal-page {
  background: #ffffff;
  color: #111111;
  font-family: Arial, Helvetica, sans-serif;
  line-height: 1.75;
}
.legal-page a { color: #111111; text-decoration: underline; }
.legal-page .legal-header {
  background: #ffffff;
  border-bottom: 1px solid #e8e8e8;
  position: sticky;
  top: 0;
  z-index: 20;
}
.legal-page .legal-nav {
  max-width: 1180px;
  margin: 0 auto;
  padding: 18px 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}
.legal-page .legal-logo img {
  max-height: 58px;
  width: auto;
  display: block;
}
.legal-page .legal-menu {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  align-items: center;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: .02em;
}
.legal-page .legal-menu a { text-decoration: none; color: #111111; }
.legal-page .legal-menu a:hover { color: #a34849; }
.legal-page .legal-main {
  max-width: 980px;
  margin: 0 auto;
  padding: 70px 24px 90px;
}
.legal-page .legal-card {
  background: #ffffff;
  border: 1px solid #e6e6e6;
  border-radius: 18px;
  padding: 44px;
  box-shadow: 0 10px 30px rgba(0,0,0,.04);
}
.legal-page h1 {
  font-size: 42px;
  line-height: 1.2;
  margin: 0 0 12px;
  color: #111111;
}
.legal-page h2 {
  font-size: 24px;
  line-height: 1.35;
  margin: 42px 0 14px;
  color: #111111;
  border-top: 1px solid #ececec;
  padding-top: 28px;
}
.legal-page h3 {
  font-size: 18px;
  margin: 28px 0 10px;
  color: #111111;
}
.legal-page p, .legal-page li {
  color: #222222;
  font-size: 16px;
}
.legal-page ul { padding-left: 22px; margin: 10px 0 18px; }
.legal-page .legal-meta {
  color: #555555;
  margin-bottom: 36px;
}
.legal-page .legal-info-box {
  background: #fafafa;
  border: 1px solid #e8e8e8;
  border-radius: 14px;
  padding: 22px;
  margin: 22px 0;
}
.legal-page .legal-note {
  background: #fff8f8;
  border-left: 4px solid #a34849;
  padding: 16px 18px;
  margin: 22px 0;
}
.legal-page .legal-footer {
  background: #ffffff;
  border-top: 1px solid #e8e8e8;
  color: #111111;
}
.legal-page .legal-footer-inner {
  max-width: 1180px;
  margin: 0 auto;
  padding: 32px 24px;
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: 24px;
}
.legal-page .legal-footer h4 {
  margin: 0 0 12px;
  color: #111111;
}
.legal-page .legal-footer p,
.legal-page .legal-footer a {
  color: #222222;
  font-size: 14px;
}
.legal-page .legal-footer-links {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
@media (max-width: 800px) {
  .legal-page .legal-nav,
  .legal-page .legal-footer-inner { grid-template-columns: 1fr; flex-direction: column; align-items: flex-start; }
  .legal-page .legal-card { padding: 28px 22px; }
  .legal-page h1 { font-size: 34px; }
  .legal-page .legal-footer-inner { display: grid; }
}


/* ========================= */
/* STANDORT / GOOGLE MAPS    */
/* ========================= */
.maps-grid {
    display: grid;
    grid-template-columns: 0.85fr 1.15fr;
    gap: 40px;
    align-items: center;
}

.maps-info {
    background: #ffffff;
    border: 1px solid rgba(0,0,0,0.06);
    border-radius: 28px;
    padding: 42px;
    box-shadow: 0 18px 55px rgba(0,0,0,0.07);
}

.maps-info h2 {
    color: #111111;
    margin-bottom: 18px;
}

.maps-info p {
    color: #444444;
    line-height: 1.8;
}

.maps-frame-wrap {
    overflow: hidden;
    border-radius: 28px;
    background: #ffffff;
    border: 1px solid rgba(0,0,0,0.06);
    box-shadow: 0 18px 55px rgba(0,0,0,0.10);
}

.maps-frame-wrap iframe {
    display: block;
    filter: saturate(0.92) contrast(1.02);
}

@media (max-width: 991px) {
    .maps-grid {
        grid-template-columns: 1fr;
    }
    .maps-info {
        padding: 30px;
    }
}


/* =========================================================
   HERO HEADER BACKGROUND
   Usa solo immagine fotografica pulita, non flyer o grafiche.
   ========================================================= */
.hero {
  background: linear-gradient(120deg, rgba(255,255,255,.92) 0%, rgba(255,255,255,.70) 45%, rgba(51,39,43,.18) 100%), url('../images/hero-header.jpg') center top/cover;
}

/* =========================================================
   GALLERY CLEANUP
   La galleria mostra solo fotografie reali da assets/images/gallery.
   Materiali grafici come flyer, loghi, preisliste, terminkarten,
   gutschein e kundenkarten restano nelle loro sezioni dedicate.
   ========================================================= */
#galerie .gallery a {
  background: #fff;
}


/* =========================================================
   LOGO LOADER – uses only Vanessa logo white
   ========================================================= */
body.site-loading { overflow: hidden; }
.site-loader {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 28px;
  background:
    radial-gradient(circle at 50% 38%, rgba(214,198,224,.20), transparent 34%),
    linear-gradient(135deg, #171113 0%, #33272b 52%, #1a1517 100%);
  transition: opacity .75s ease, visibility .75s ease;
}
.site-loader.is-hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}
.loader-logo-wrap {
  position: relative;
  width: min(280px, 58vw);
  aspect-ratio: 1 / 1.7;
  display: flex;
  align-items: center;
  justify-content: center;
  filter: drop-shadow(0 18px 42px rgba(255,255,255,.12));
  animation: loaderFloat 3s ease-in-out infinite;
}
.loader-logo {
  width: 100%;
  height: 100%;
  object-fit: contain;
  opacity: 0;
  animation: logoReveal 1.15s ease forwards .15s, logoGlow 2.6s ease-in-out infinite 1.1s;
}
.loader-shine {
  position: absolute;
  inset: 10% 4%;
  transform: translateX(-130%) rotate(18deg);
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.36), transparent);
  filter: blur(6px);
  animation: shineSweep 2.4s ease-in-out infinite .6s;
  pointer-events: none;
}
.loader-line {
  width: min(360px, 62vw);
  height: 2px;
  background: rgba(255,255,255,.15);
  border-radius: 50px;
  overflow: hidden;
}
.loader-line span {
  display: block;
  width: 42%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, transparent, #FFF8C9, #CD888A, transparent);
  animation: loaderLine 1.55s ease-in-out infinite;
}
@keyframes logoReveal { from { opacity: 0; transform: translateY(16px) scale(.96); } to { opacity: 1; transform: translateY(0) scale(1); } }
@keyframes logoGlow { 0%,100% { filter: drop-shadow(0 0 0 rgba(255,248,201,0)); } 50% { filter: drop-shadow(0 0 20px rgba(255,248,201,.30)); } }
@keyframes loaderFloat { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-10px); } }
@keyframes shineSweep { 0% { transform: translateX(-140%) rotate(18deg); opacity: 0; } 20% { opacity: .8; } 55%,100% { transform: translateX(140%) rotate(18deg); opacity: 0; } }
@keyframes loaderLine { 0% { transform: translateX(-110%); } 100% { transform: translateX(260%); } }

/* =========================================================
   HERO HEADER – clean horizontal background, no flyer, no fake logo
   ========================================================= */
.hero {
  min-height: 86vh;
  background:
    linear-gradient(90deg, rgba(255,255,255,.94) 0%, rgba(255,255,255,.82) 39%, rgba(255,255,255,.36) 66%, rgba(51,39,43,.10) 100%),
    url('../images/hero-header-wide.jpg') center center/cover no-repeat;
}
.hero-logo-card {
  background: rgba(255,255,255,.76);
  backdrop-filter: blur(14px);
}
.hero-logo-card img {
  max-height: 300px;
  width: auto;
}
.navbar .brand img {
  max-height: 62px;
  object-fit: contain;
}
.footer img {
  background: transparent;
  padding: 0;
  height: 92px;
}
@media (max-width: 900px) {
  .hero { background-position: 62% center; }
  .hero-logo-card img { max-height: 220px; }
}


/* =========================================================
   ÜBER MICH – FOTO LINKS, TEXT RECHTS
   ========================================================= */
.about-section {
  background: #ffffff;
}
.about-grid {
  display: grid;
  grid-template-columns: 0.92fr 1.08fr;
  gap: 56px;
  align-items: center;
}
.about-image {
  border-radius: 34px;
  overflow: hidden;
  box-shadow: 0 22px 55px rgba(98, 58, 73, 0.16);
  border: 1px solid var(--line);
  background: #fff;
}
.about-image img {
  width: 100%;
  height: 100%;
  min-height: 460px;
  object-fit: cover;
  display: block;
}
.about-content h2 {
  font-size: 42px;
  margin: 12px 0 22px;
  color: var(--dark);
}
.about-content p {
  font-size: 18px;
  line-height: 1.85;
  color: #5f5056;
  margin-bottom: 18px;
}

/* Footer logo: nur transparentes PNG, kein JPG-Hintergrund, keine weiße Box */
.footer .footer-logo,
.footer img.footer-logo {
  height: 118px;
  width: auto;
  max-width: 180px;
  object-fit: contain;
  background: transparent !important;
  border-radius: 0 !important;
  padding: 0 !important;
  box-shadow: none !important;
}

@media (max-width: 900px) {
  .about-grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .about-image img {
    min-height: 340px;
  }
  .about-content h2 {
    font-size: 34px;
  }
}

/* =========================================================
   HERO + MENU UPDATE
   - Remove color palette card from header/hero
   - Logo left, text right
   - Elegant mobile dropdown menu with arrow/X
   - Active section highlight
   ========================================================= */

.brand-label {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.navbar {
  position: sticky;
  top: 0;
  z-index: 999;
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(214, 198, 224, 0.55);
  box-shadow: 0 8px 28px rgba(51, 39, 43, 0.05);
}

.nav-inner {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 26px;
  padding: 10px 22px;
}

.navbar .brand {
  display: inline-flex;
  align-items: center;
  flex: 0 0 auto;
  min-width: 86px;
}

.navbar .brand img {
  height: 68px;
  width: auto;
  display: block;
  object-fit: contain;
}

.nav-links {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;
  flex-wrap: wrap;
}

.nav-links a {
  position: relative;
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: 8px 12px;
  border-radius: 999px;
  color: var(--dark);
  font-size: 13px;
  line-height: 1;
  font-weight: 700;
  letter-spacing: 0.035em;
  text-transform: uppercase;
  text-decoration: none;
  transition: color .25s ease, background .25s ease, transform .25s ease, box-shadow .25s ease;
}

.nav-links a::after {
  content: "";
  position: absolute;
  left: 16px;
  right: 16px;
  bottom: 4px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--lav), var(--rose), var(--cream));
  transform: scaleX(0);
  transform-origin: center;
  opacity: 0;
  transition: transform .25s ease, opacity .25s ease;
}

.nav-links a:hover,
.nav-links a.is-active {
  color: var(--wine);
  background: rgba(214, 198, 224, 0.26);
  box-shadow: inset 0 0 0 1px rgba(205, 136, 138, 0.18), 0 8px 22px rgba(163, 72, 73, 0.08);
  transform: translateY(-1px);
}

.nav-links a:hover::after,
.nav-links a.is-active::after {
  transform: scaleX(1);
  opacity: 1;
}

.mobile-menu-toggle {
  display: none;
  align-items: center;
  justify-content: center;
  gap: 10px;
  border: 1px solid rgba(205, 136, 138, 0.28);
  background: rgba(255, 255, 255, 0.88);
  color: var(--wine);
  border-radius: 999px;
  padding: 12px 18px;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
  box-shadow: 0 10px 24px rgba(98, 58, 73, 0.10);
}

.mobile-menu-toggle .menu-arrow,
.mobile-menu-toggle .menu-close {
  font-size: 22px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: transform .25s ease, opacity .25s ease;
}

.mobile-menu-toggle .menu-close {
  display: none;
  font-size: 28px;
}

.navbar.menu-open .mobile-menu-toggle .menu-arrow {
  display: none;
}

.navbar.menu-open .mobile-menu-toggle .menu-close {
  display: inline-flex;
}

.hero-logo-layout {
  min-height: 82vh;
  display: flex;
  align-items: center;
  background:
    linear-gradient(90deg, rgba(255, 255, 255, .88) 0%, rgba(255, 255, 255, .78) 38%, rgba(51, 39, 43, .18) 100%),
    url('../images/hero-header-wide.jpg') center center / cover no-repeat;
}

.hero-logo-layout .hero-grid {
  display: grid;
  grid-template-columns: minmax(240px, 0.78fr) minmax(320px, 1.22fr);
  gap: 56px;
  align-items: center;
}

.hero-logo-panel {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 420px;
  padding: 34px;
  border-radius: 34px;
  background: rgba(255, 255, 255, 0.74);
  border: 1px solid rgba(214, 198, 224, 0.62);
  box-shadow: 0 28px 70px rgba(51, 39, 43, 0.12);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.hero-main-logo {
  width: min(100%, 360px);
  max-height: 430px;
  object-fit: contain;
  filter: drop-shadow(0 16px 22px rgba(51, 39, 43, 0.10));
}

.hero-text-panel {
  max-width: 690px;
  padding: 48px;
  border-radius: 34px;
  background: rgba(255, 255, 255, 0.64);
  border: 1px solid rgba(255, 255, 255, 0.72);
  box-shadow: 0 25px 70px rgba(51, 39, 43, 0.10);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.hero-text-panel h1 {
  font-size: clamp(42px, 5.2vw, 72px);
  line-height: 1.02;
  margin: 18px 0 20px;
  letter-spacing: -0.035em;
}

.hero-text-panel .lead {
  max-width: 620px;
}

.hero-card.hero-logo-card,
.color-row,
.color,
.hero-logo-card .quote {
  display: none !important;
}

@media (max-width: 1100px) {
  .nav-links a {
    font-size: 12px;
    padding: 8px 10px;
  }
}

@media (max-width: 900px) {
  .nav-inner {
    flex-direction: row !important;
    align-items: center !important;
    padding: 10px 18px;
  }

  .navbar .brand img {
    height: 62px;
  }

  .mobile-menu-toggle {
    display: inline-flex;
    margin-left: auto;
  }

  .nav-links {
    position: absolute;
    top: calc(100% + 10px);
    left: 18px;
    right: 18px;
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
    padding: 0 14px;
    max-height: 0;
    opacity: 0;
    overflow: hidden;
    pointer-events: none;
    border-radius: 26px;
    background: rgba(255, 255, 255, 0.96);
    border: 1px solid rgba(214, 198, 224, 0.72);
    box-shadow: 0 24px 70px rgba(51, 39, 43, 0.18);
    transform: translateY(-8px);
    transition: max-height .42s ease, opacity .25s ease, padding .32s ease, transform .32s ease;
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
  }

  .navbar.menu-open .nav-links {
    max-height: 80vh;
    opacity: 1;
    padding: 16px 14px;
    pointer-events: auto;
    transform: translateY(0);
  }

  .nav-links a {
    width: 100%;
    justify-content: space-between;
    min-height: 48px;
    padding: 14px 18px;
    border-radius: 18px;
    font-size: 14px;
    background: rgba(251, 246, 248, 0.72);
  }

  .nav-links a::after {
    left: 18px;
    right: auto;
    top: 50%;
    bottom: auto;
    width: 5px;
    height: 22px;
    transform: translateY(-50%) scaleY(0);
  }

  .nav-links a:hover::after,
  .nav-links a.is-active::after {
    transform: translateY(-50%) scaleY(1);
  }

  .hero-logo-layout .hero-grid {
    grid-template-columns: 1fr;
    gap: 26px;
    padding-top: 72px;
    padding-bottom: 72px;
  }

  .hero-logo-panel {
    min-height: 300px;
    padding: 28px;
  }

  .hero-main-logo {
    max-height: 300px;
  }

  .hero-text-panel {
    padding: 34px 26px;
  }
}

@media (max-width: 520px) {
  .topbar .container {
    justify-content: flex-start;
  }

  .mobile-menu-toggle .menu-label {
    display: none;
  }

  .mobile-menu-toggle {
    width: 50px;
    height: 50px;
    padding: 0;
  }

  .hero-logo-panel {
    min-height: 240px;
  }

  .hero-main-logo {
    max-height: 240px;
  }

  .hero-text-panel h1 {
    font-size: 38px;
  }
}

/* =========================================================
   FINAL HEADER + NAVIGATION CLEANUP
   Menu: Home, Über mich, Leistungen, Geschenkgutschein,
   Galerie, Kontakt + Facebook/Instagram/WhatsApp icons only
   ========================================================= */
.topbar,
.hero-card,
.hero-logo-card,
.color-row,
.color,
.brand-label {
  display: none !important;
}

.navbar {
  position: sticky;
  top: 0;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(214,198,224,.55);
  box-shadow: 0 12px 35px rgba(51,39,43,.06);
}

.nav-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 22px;
  min-height: 92px;
}

.navbar .brand {
  display: flex;
  align-items: center;
  flex: 0 0 auto;
}

.navbar .brand img {
  height: 74px;
  width: auto;
  max-width: 220px;
  object-fit: contain;
  background: transparent !important;
}

.nav-links {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: nowrap;
}

.nav-links > a {
  position: relative;
  padding: 11px 13px;
  border-radius: 999px;
  color: var(--dark);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  line-height: 1;
  white-space: nowrap;
}

.nav-links > a::after {
  content: "";
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 2px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, transparent, var(--rose), var(--lav), transparent);
  transform: scaleX(0);
  opacity: 0;
  transition: .28s ease;
}

.nav-links > a:hover,
.nav-links > a.is-active {
  color: var(--wine);
  background: rgba(214,198,224,.24);
  box-shadow: 0 0 22px rgba(205,136,138,.18);
}

.nav-links > a:hover::after,
.nav-links > a.is-active::after {
  transform: scaleX(1);
  opacity: 1;
}

.nav-social-icons {
  display: flex;
  align-items: center;
  gap: 9px;
  margin-left: 10px;
  padding-left: 12px;
  border-left: 1px solid rgba(214,198,224,.8);
}

.nav-social-icon {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--wine);
  background: rgba(255,255,255,.65);
  border: 1px solid rgba(214,198,224,.9);
  box-shadow: 0 8px 22px rgba(51,39,43,.08);
}

.nav-social-icon svg {
  width: 17px;
  height: 17px;
  fill: currentColor;
}

.nav-social-icon:hover {
  color: #fff;
  background: var(--rose);
  border-color: var(--rose);
  transform: translateY(-2px);
}

.hero-logo-layout {
  min-height: 82vh;
  padding: 80px 0;
  display: flex;
  align-items: center;
}

.hero-logo-layout .hero-grid {
  grid-template-columns: minmax(220px, 38%) 1fr;
  gap: clamp(34px, 6vw, 90px);
  align-items: center;
}

.hero-logo-panel {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
}

.hero-main-logo {
  max-height: 430px;
  width: 100%;
  object-fit: contain;
  background: transparent !important;
  filter: drop-shadow(0 20px 40px rgba(51,39,43,.08));
}

.hero-text-panel {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  max-width: 680px;
}

.hero-text-panel h1,
.hero-text-panel .lead,
.hero-text-panel .kicker {
  text-shadow: 0 2px 18px rgba(255,255,255,.85);
}

.mobile-menu-toggle {
  display: none;
  align-items: center;
  gap: 10px;
  border: 1px solid rgba(214,198,224,.95);
  background: rgba(255,255,255,.76);
  color: var(--wine);
  border-radius: 999px;
  padding: 11px 16px;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
  box-shadow: 0 10px 24px rgba(51,39,43,.08);
}

.mobile-menu-toggle .menu-close { display: none; font-size: 22px; line-height: 1; }
.mobile-menu-toggle .menu-arrow { font-size: 20px; line-height: 1; transition: transform .25s ease; }
.navbar.menu-open .mobile-menu-toggle .menu-arrow { display: none; }
.navbar.menu-open .mobile-menu-toggle .menu-close { display: inline-block; }

@media (max-width: 1100px) {
  .nav-inner { min-height: 82px; }
  .navbar .brand img { height: 64px; }
  .mobile-menu-toggle { display: inline-flex; }
  .nav-links {
    position: absolute;
    top: calc(100% + 10px);
    left: 18px;
    right: 18px;
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
    padding: 18px;
    background: rgba(255,255,255,.96);
    border: 1px solid rgba(214,198,224,.75);
    border-radius: 28px;
    box-shadow: 0 28px 70px rgba(51,39,43,.18);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    opacity: 0;
    pointer-events: none;
    visibility: hidden;
    transform: translateY(-12px) scale(.98);
    transition: .28s ease;
  }

  .navbar.menu-open .nav-links {
    opacity: 1;
    pointer-events: auto;
    visibility: visible;
    transform: translateY(0) scale(1);
  }

  .nav-links > a {
    width: 100%;
    padding: 16px 18px;
    font-size: 14px;
    border-radius: 18px;
    background: rgba(251,246,248,.82);
  }

  .nav-links > a.is-active,
  .nav-links > a:hover {
    background: linear-gradient(90deg, rgba(214,198,224,.35), rgba(205,136,138,.18));
  }

  .nav-links > a::after {
    left: 16px;
    right: auto;
    top: 50%;
    bottom: auto;
    width: 4px;
    height: 26px;
    transform: translateY(-50%) scaleY(0);
    background: var(--rose);
  }

  .nav-links > a:hover::after,
  .nav-links > a.is-active::after {
    transform: translateY(-50%) scaleY(1);
  }

  .nav-social-icons {
    justify-content: center;
    border-left: 0;
    margin-left: 0;
    padding-left: 0;
    padding-top: 10px;
  }

  .nav-social-icon {
    width: 46px;
    height: 46px;
  }

  .nav-social-icon svg {
    width: 20px;
    height: 20px;
  }
}

@media (max-width: 760px) {
  .nav-inner { min-height: 76px; }
  .navbar .brand img { height: 58px; }
  .hero-logo-layout .hero-grid {
    grid-template-columns: 1fr;
    gap: 30px;
    text-align: center;
  }
  .hero-main-logo {
    max-height: 260px;
  }
  .hero-logo-layout {
    min-height: auto;
    padding: 70px 0;
  }
  .hero-text-panel {
    margin: 0 auto;
  }
}
