/* =========================================================================
   GERLACH WATCHES – Base (Reset, Typo, Buttons, Header, Spotlight, Footer)
   Weißer Header, Gold als einziger Akzent, dunkler Footer – wie die
   Originalseite, Komponenten in Shopify-Design-Sprache.
   ========================================================================= */

*, *::before, *::after { box-sizing: border-box; }

body.gw {
  margin: 0;
  font-family: var(--gw-font);
  font-size: var(--gw-fs-400);
  line-height: var(--gw-lh);
  color: var(--gw-ink);
  background: var(--gw-bg);
  -webkit-font-smoothing: antialiased;
  /* Elementor-Vollbreite-Sektionen nutzen 100vw → horizontaler Überlauf.
     clip kappt ihn, ohne position:sticky (Header) zu beeinträchtigen. */
  overflow-x: clip;
}

img { max-width: 100%; height: auto; }

body.gw a { color: var(--gw-gold-dark); text-decoration: none; transition: color var(--gw-transition); }
body.gw a:hover { color: var(--gw-gold); }

h1, h2, h3, h4 { font-weight: var(--gw-weight-bold); line-height: 1.2; color: var(--gw-ink); }

.gw-container {
  width: 100%;
  max-width: var(--gw-container);
  margin-inline: auto;
  padding-inline: var(--gw-gutter);
}

.gw-site-content { min-height: 40vh; }
.gw-page { padding-block: var(--gw-space-6); }
.gw-empty { color: var(--gw-muted); padding: var(--gw-space-6) 0; text-align: center; }

.screen-reader-text {
  position: absolute; width: 1px; height: 1px; overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px); clip-path: inset(50%); word-wrap: normal !important;
}
.screen-reader-text:focus {
  position: fixed; top: 8px; left: 8px; z-index: 1000;
  width: auto; height: auto; clip: auto; clip-path: none;
  background: var(--gw-bg); color: var(--gw-ink);
  padding: var(--gw-space-3) var(--gw-space-4);
  border-radius: var(--gw-radius); box-shadow: var(--gw-shadow-lg);
}

/* --- Theme-Buttons ---------------------------------------------------------
   !important auf den Farb-Zuständen: Elementor-Kits stylen sonst Buttons/Links
   global um. */
.gw-btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: var(--gw-space-2);
  min-height: var(--gw-tap);
  padding: 0.7em 1.6em;
  border: 1px solid transparent;
  border-radius: var(--gw-radius);
  font-family: var(--gw-font);
  font-size: var(--gw-fs-400);
  font-weight: var(--gw-weight-semibold);
  line-height: 1.1;
  text-align: center;
  text-decoration: none;
  cursor: pointer;
  transition: background var(--gw-transition), color var(--gw-transition),
              border-color var(--gw-transition), box-shadow var(--gw-transition),
              transform var(--gw-transition);
}
.gw-btn--primary { background: var(--gw-gold) !important; color: #fff !important; }
.gw-btn--primary:hover,
.gw-btn--primary:focus { background: var(--gw-gold-dark) !important; color: #fff !important; transform: translateY(-1px); box-shadow: var(--gw-shadow-lg); }
.gw-btn--primary:active { background: var(--gw-gold-deep) !important; transform: translateY(0); box-shadow: var(--gw-shadow); }
.gw-btn--outline { background: var(--gw-bg) !important; color: var(--gw-ink) !important; border-color: var(--gw-border) !important; }
.gw-btn--outline:hover,
.gw-btn--outline:focus { border-color: var(--gw-gold) !important; color: var(--gw-gold-dark) !important; background: var(--gw-gold-soft) !important; }
.gw-btn--block { width: 100%; }
.gw-btn:disabled, .gw-btn[disabled] { opacity: 0.5; cursor: not-allowed; }

/* =========================================================================
   HEADER – weiß, sticky, drei Zonen (Logo / Nav / Tools)
   ========================================================================= */
.gw-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: var(--gw-bg);
  border-bottom: 1px solid var(--gw-border);
}
.gw-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--gw-space-5);
  padding-block: var(--gw-space-3);
}
.gw-logo { display: inline-flex; flex: 0 0 auto; }
.gw-logo img { max-height: 56px; width: auto; }
.gw-logo__text {
  font-size: var(--gw-fs-600);
  font-weight: var(--gw-weight-bold);
  letter-spacing: 0.16em;
  color: var(--gw-ink) !important;
}
.gw-logo__text span { color: var(--gw-gold); font-weight: var(--gw-weight-normal); margin-left: 0.35em; }

/* Navigation (Desktop) */
.gw-nav ul { display: flex; gap: var(--gw-space-5); margin: 0; padding: 0; list-style: none; }
.gw-header .gw-nav a,
.gw-header .gw-nav a:link,
.gw-header .gw-nav a:visited {
  display: inline-flex;
  align-items: center;
  min-height: var(--gw-tap);
  font-weight: var(--gw-weight-medium);
  letter-spacing: 0.02em;
  color: var(--gw-ink) !important;
}
.gw-header .gw-nav a:hover,
.gw-header .gw-nav .current-menu-item > a { color: var(--gw-gold) !important; }

/* Mobile-Overlay-Teile auf Desktop ausblenden (inkl. Akkordeon-Toggle) */
.gw-nav__head, .gw-nav-backdrop, .gw-nav .gw-submenu-toggle { display: none; }

/* =========================================================================
   DROPDOWNS & MEGA-MENÜ (Desktop)
   Standard: kompaktes Dropdown unter dem Menüpunkt.
   Vollbreites Mega-Panel NUR für „Hersteller" (auto) oder Menüpunkte mit
   der CSS-Klasse „mega". Tastatur: :focus-within.
   ========================================================================= */
@media (min-width: 901px) {
  .gw-header .gw-nav > ul > li { position: relative; }

  /* Pfeil-Indikator am Eltern-Link */
  .gw-header .gw-nav > ul > li.menu-item-has-children > a::after {
    content: "";
    width: 7px; height: 7px;
    margin-left: 8px; margin-top: -4px;
    border-right: 1.7px solid currentColor;
    border-bottom: 1.7px solid currentColor;
    transform: rotate(45deg);
    transition: transform var(--gw-transition);
  }
  .gw-header .gw-nav > ul > li.menu-item-has-children:hover > a::after,
  .gw-header .gw-nav > ul > li.menu-item-has-children:focus-within > a::after {
    transform: rotate(225deg); margin-top: 2px;
  }

  /* Gemeinsam: verstecken/öffnen mit sanfter Bewegung.
     Schließ-VERZÖGERUNG (0.18s): die Maus muss vom Link über die Header-
     Unterkante zum Panel – ohne Delay klappt es auf dem Weg zu. */
  .gw-header .gw-nav > ul > li > .sub-menu {
    position: absolute; top: 100%;
    opacity: 0; visibility: hidden;
    transform: translateY(8px);
    transition: opacity var(--gw-transition), transform var(--gw-transition), visibility var(--gw-transition);
    transition-delay: 0.18s;
    z-index: 110;
    list-style: none; margin: 0;
    background: var(--gw-bg);
  }
  /* Unsichtbare Hover-Brücke über dem Panel (überdeckt den Spalt zum Header) */
  .gw-header .gw-nav > ul > li > .sub-menu::before {
    content: ""; position: absolute;
    left: 0; right: 0; bottom: 100%; height: 18px;
  }
  .gw-header .gw-nav > ul > li.menu-item-has-children:hover > .sub-menu,
  .gw-header .gw-nav > ul > li.menu-item-has-children:focus-within > .sub-menu {
    opacity: 1; visibility: visible; transform: none;
    transition-delay: 0s;
  }

  /* STANDARD: kompakte Dropdown-Karte unter dem Punkt */
  .gw-header .gw-nav > ul > li > .sub-menu {
    left: 0;
    min-width: 260px;
    padding: var(--gw-space-2);
    border: 1px solid var(--gw-border);
    border-radius: var(--gw-radius-lg);
    box-shadow: var(--gw-shadow-lg);
  }

  /* MEGA: vollbreites Panel (auto-„Hersteller" oder Klasse „mega" im Menü) */
  .gw-header .gw-nav > ul > li.gw-mega-auto,
  .gw-header .gw-nav > ul > li.mega { position: static; }
  .gw-header .gw-nav > ul > li.gw-mega-auto > .sub-menu,
  .gw-header .gw-nav > ul > li.mega > .sub-menu {
    left: 0; right: 0;
    min-width: 0;
    border: none; border-radius: 0;
    border-bottom: 1px solid var(--gw-border);
    /* Inhalt fluchtet mit dem Seiten-Container */
    padding: var(--gw-space-5) max(var(--gw-gutter), calc((100% - var(--gw-container)) / 2 + var(--gw-gutter))) var(--gw-space-6);
  }
  /* Manuelles Mega (normale Menü-Unterpunkte): Mehrspalten-Raster */
  .gw-header .gw-nav > ul > li.mega > ul.sub-menu {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: var(--gw-space-2) var(--gw-space-5);
  }

  /* Links in Dropdown & Panel: ruhige Zeilen, Gold beim Hover */
  .gw-header .gw-nav .sub-menu li { width: 100%; }
  .gw-header .gw-nav .sub-menu a,
  .gw-header .gw-nav .sub-menu a:link,
  .gw-header .gw-nav .sub-menu a:visited {
    display: flex; width: 100%;
    min-height: 42px; align-items: center;
    padding: var(--gw-space-1) var(--gw-space-3);
    border-radius: var(--gw-radius);
    font-weight: var(--gw-weight-normal);
    color: var(--gw-ink) !important;
  }
  .gw-header .gw-nav .sub-menu a:hover { background: var(--gw-gold-soft); color: var(--gw-gold-dark) !important; }

  /* Dritte Ebene: Gruppe unter Spalten-Überschrift (kein weiteres Overlay) */
  .gw-header .gw-nav .sub-menu .sub-menu {
    position: static;
    display: block;
    padding: 0; margin: 0; min-width: 0;
    background: none; border: none; box-shadow: none;
    opacity: 1; visibility: visible; transform: none;
  }
  .gw-header .gw-nav .sub-menu li.menu-item-has-children > a {
    font-size: var(--gw-fs-300);
    font-weight: var(--gw-weight-semibold);
    letter-spacing: 0.08em; text-transform: uppercase;
    color: var(--gw-muted) !important;
  }
}

/* Tools rechts */
.gw-header__tools { display: flex; align-items: center; gap: var(--gw-space-2); }
.gw-icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--gw-tap);
  height: var(--gw-tap);
  background: none !important;
  border: none !important;
  box-shadow: none !important;
  color: var(--gw-ink) !important;
  cursor: pointer;
  border-radius: var(--gw-radius);
  padding: 0;
  transition: background var(--gw-transition), color var(--gw-transition);
}
.gw-icon-btn:hover { background: var(--gw-gold-soft) !important; color: var(--gw-gold-dark) !important; }
.gw-icon-btn svg { width: 24px; height: 24px; }
.gw-ic { display: block; flex: 0 0 auto; }

/* Warenkorb-Link mit Badge */
.gw-cart-link {
  position: relative; display: inline-flex; align-items: center;
  padding: 10px; border-radius: var(--gw-radius);
  color: var(--gw-ink) !important;
  transition: color var(--gw-transition);
}
.gw-cart-link:hover { color: var(--gw-gold-dark) !important; }
.gw-cart-link__icon { position: relative; display: inline-flex; align-items: center; justify-content: center; }
.gw-cart-link__count {
  position: absolute;
  top: -8px; right: -10px;
  min-width: 18px; height: 18px;
  padding: 0 4px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--gw-gold);
  color: #fff;
  font-size: 11px; font-weight: var(--gw-weight-bold);
  line-height: 1;
  border: 2px solid var(--gw-bg);
  border-radius: var(--gw-radius-pill);
}
.gw-cart-link__count[data-count="0"] { display: none; } /* leer → kein Badge */

/* Burger (nur mobil) */
.gw-burger { display: none; }

/* =========================================================================
   SPOTLIGHT-SUCHE (Overlay)
   ========================================================================= */
.gw-spotlight {
  position: fixed; inset: 0; z-index: 300;
  display: flex; align-items: flex-start; justify-content: center;
  padding: 14vh var(--gw-space-4) var(--gw-space-4);
  background: rgba(16, 16, 16, 0.45);
  -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px);
  opacity: 0; visibility: hidden; transition: opacity 0.2s ease;
}
.gw-spotlight.is-open { opacity: 1; visibility: visible; }
.gw-spotlight__box {
  width: 100%; max-width: 640px;
  transform: translateY(-12px) scale(0.98);
  transition: transform 0.22s cubic-bezier(0.4, 0, 0.2, 1);
}
.gw-spotlight.is-open .gw-spotlight__box { transform: none; }
.gw-spotlight__form {
  display: flex; align-items: center; gap: var(--gw-space-3);
  background: var(--gw-bg);
  border-radius: var(--gw-radius-lg);
  box-shadow: var(--gw-shadow-lg);
  padding: var(--gw-space-3) var(--gw-space-4);
}
.gw-spotlight__icon { display: inline-flex; color: var(--gw-muted); flex: 0 0 auto; }
.gw-spotlight__input {
  flex: 1 1 auto; min-width: 0;
  border: none !important; outline: none; background: none;
  font-family: var(--gw-font); font-size: var(--gw-fs-500); color: var(--gw-ink);
  padding: var(--gw-space-2) 0;
  text-overflow: ellipsis;
}
.gw-spotlight__input::placeholder {
  color: var(--gw-muted); font-size: var(--gw-fs-400);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.gw-spotlight__input::-webkit-search-cancel-button,
.gw-spotlight__input::-webkit-search-decoration { -webkit-appearance: none; appearance: none; }
.gw-spotlight__close {
  flex: 0 0 auto; cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
  width: 36px; height: 36px; padding: 0;
  background: var(--gw-bg-soft) !important; border: 1px solid var(--gw-border) !important;
  color: var(--gw-muted); border-radius: 50%;
}
.gw-spotlight__close:hover { color: var(--gw-ink); background: var(--gw-bg) !important; }

/* Live-Ergebnisse: Spinner zentriert IM Ergebnis-Container (kein Springen) */
.gw-spotlight__results-wrap { position: relative; }
.gw-spotlight__results { display: none; margin-top: var(--gw-space-3); }
.gw-spotlight__results.is-visible {
  display: block;
  background: var(--gw-bg); border-radius: var(--gw-radius-lg); box-shadow: var(--gw-shadow-lg);
  max-height: 56vh; overflow-y: auto;
}
/* Lade-Zustand: dünne goldene Laufleiste an der Unterkante des Suchfelds
   (kein Spinner, keine Extra-Box, kein Layout-Sprung). Alte Treffer bleiben
   stehen und werden nur kurz gedimmt. */
.gw-spotlight__form { position: relative; overflow: hidden; }
.gw-spotlight__form::after {
  content: "";
  position: absolute; left: 0; bottom: 0;
  width: 45%; height: 3px;
  border-radius: var(--gw-radius-pill);
  background: linear-gradient(90deg, transparent, var(--gw-gold), var(--gw-gold-light), transparent);
  transform: translateX(-110%);
  opacity: 0;
  pointer-events: none;
}
.gw-spotlight.is-loading .gw-spotlight__form::after {
  opacity: 1;
  animation: gw-loadbar 0.8s linear infinite;
}
@keyframes gw-loadbar {
  from { transform: translateX(-110%); }
  to   { transform: translateX(330%); }
}
.gw-spotlight__results.is-visible { transition: opacity 0.1s ease; }
.gw-spotlight.is-loading .gw-spotlight__results.is-visible { opacity: 0.55; pointer-events: none; }
@keyframes gw-spin { to { transform: rotate(360deg); } }

.gw-sres-list { list-style: none; margin: 0; padding: var(--gw-space-2); }
.gw-sres a {
  display: flex; align-items: center; gap: var(--gw-space-3);
  min-height: 62px;
  padding: var(--gw-space-2) var(--gw-space-3); border-radius: var(--gw-radius);
  color: var(--gw-ink) !important; text-decoration: none !important;
}
.gw-sres a:hover { background: var(--gw-gold-soft); }
.gw-sres__media { flex: 0 0 46px; width: 46px; height: 46px; }
.gw-sres__media img {
  width: 100% !important; height: 100% !important; max-width: none;
  object-fit: contain; background: var(--gw-bg);
  border: 1px solid var(--gw-border); border-radius: var(--gw-radius);
  padding: 2px; display: block;
}
.gw-sres__info { display: flex; flex-direction: column; gap: 1px; min-width: 0; flex: 1 1 auto; }
.gw-sres__name {
  font-weight: var(--gw-weight-medium); line-height: 1.35;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.gw-sres__price { color: var(--gw-gold-dark); font-size: var(--gw-fs-300); font-weight: var(--gw-weight-semibold); }
/* Ganze Preiszeile EINE Farbe – WC färbt sonst nur die Zahl (.amount) */
.gw-sres__price .amount,
.gw-sres__price .woocommerce-Price-amount,
.gw-sres__price bdi { color: var(--gw-gold-dark) !important; }
.gw-sres-all {
  display: block; text-align: center; padding: var(--gw-space-3);
  border-top: 1px solid var(--gw-border); color: var(--gw-gold-dark) !important;
  font-weight: var(--gw-weight-semibold); text-decoration: none;
}
.gw-sres-all:hover { background: var(--gw-gold-soft); }
.gw-sres-empty { color: var(--gw-muted); text-align: center; padding: var(--gw-space-5); margin: 0; }

@media (max-width: 560px) {
  .gw-spotlight { padding-top: 8vh; }
}

/* Fallback-Suchformular (Widgets) */
.gw-searchform { display: flex; gap: var(--gw-space-2); }
.gw-searchform__input {
  flex: 1 1 auto; min-height: var(--gw-tap);
  padding: 0.4em var(--gw-space-3);
  border: 1px solid var(--gw-border); border-radius: var(--gw-radius);
  font-family: var(--gw-font); font-size: var(--gw-fs-400);
}
.gw-searchform__input:focus { border-color: var(--gw-gold); box-shadow: 0 0 0 3px var(--gw-gold-soft); outline: none; }

/* =========================================================================
   ARCHIV-/SEITEN-BANNER (Sub-Hero) – dunkles Band, Titel weiß & zentriert
   ========================================================================= */
.gw-banner {
  background: var(--gw-ink-2);
  padding-block: var(--gw-space-7);
  text-align: center;
}
.gw-banner__title {
  margin: 0;
  font-size: var(--gw-fs-800);
  font-weight: var(--gw-weight-bold);
  color: #fff;
}

/* =========================================================================
   FOOTER – dunkel (Ink), mehrspaltig (Marke · Kollektion · Service · Kontakt),
   darunter die Legal-Zeile. Gold beim Hover.
   ========================================================================= */
.gw-footer {
  background: var(--gw-ink);
  color: rgba(255, 255, 255, 0.75);
  font-size: var(--gw-fs-400);
}
.gw-footer a,
.gw-footer a:link,
.gw-footer a:visited { color: rgba(255, 255, 255, 0.75) !important; text-decoration: none !important; transition: color var(--gw-transition); }
.gw-footer a:hover,
.gw-footer a:focus { color: var(--gw-gold-light) !important; }

/* Inhalts-Spalten */
.gw-footer__main {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1.2fr;
  gap: var(--gw-space-6) var(--gw-space-7);
  padding-block: var(--gw-space-8) var(--gw-space-7);
}
.gw-footer__col ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--gw-space-2); }
.gw-footer__heading {
  margin: 0 0 var(--gw-space-4);
  font-size: var(--gw-fs-300); font-weight: var(--gw-weight-semibold);
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--gw-gold-light);
}
.gw-footer__logo {
  display: inline-block;
  font-size: var(--gw-fs-500); font-weight: var(--gw-weight-bold);
  letter-spacing: 0.16em; color: #fff;
}
.gw-footer__logo span { color: var(--gw-gold-light); font-weight: var(--gw-weight-normal); margin-left: 0.35em; }
.gw-footer__brand img { max-height: 48px; width: auto; }
.gw-footer__claim {
  margin: var(--gw-space-4) 0 0;
  max-width: 36ch;
  font-size: var(--gw-fs-300); line-height: 1.7;
  color: rgba(255, 255, 255, 0.6);
}
.gw-footer__contact a { display: inline-flex; align-items: center; gap: var(--gw-space-2); }
.gw-footer__contact .gw-ic { color: var(--gw-gold-light); }
.gw-footer__address, .gw-footer__hours { line-height: 1.7; color: rgba(255, 255, 255, 0.6); }
.gw-footer__hours { font-size: var(--gw-fs-300); }

@media (max-width: 900px) {
  .gw-footer__main { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px) {
  .gw-footer__main { grid-template-columns: 1fr; padding-block: var(--gw-space-7) var(--gw-space-6); }
}

/* Legal-Zeile */
.gw-footer__bottom { border-top: 1px solid rgba(255, 255, 255, 0.12); font-size: var(--gw-fs-300); }
.gw-footer__inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--gw-space-4); flex-wrap: wrap;
  padding-block: var(--gw-space-4);
}
.gw-footer__copy { color: rgba(255, 255, 255, 0.5); }
.gw-footer__legal { display: flex; gap: var(--gw-space-4); flex-wrap: wrap; list-style: none; margin: 0; padding: 0; }

/* =========================================================================
   RESPONSIVE – Mobile-Navigation als vollflächiges Overlay
   ========================================================================= */
@media (max-width: 900px) {
  .gw-burger { display: inline-flex; }
  .gw-header__inner { gap: var(--gw-space-3); }
  .gw-header__account { display: none; } /* mobil: Konto über das Menü/Footer */
  .gw-banner__title { font-size: var(--gw-fs-600); }

  .gw-nav-backdrop {
    display: block;
    position: fixed; inset: 0;
    background: rgba(16, 16, 16, 0.55);
    -webkit-backdrop-filter: blur(2px); backdrop-filter: blur(2px);
    opacity: 0; visibility: hidden; transition: opacity 0.28s ease;
    z-index: 200;
  }
  .gw-nav-backdrop.is-open { opacity: 1; visibility: visible; }

  /* Menü als VOLLFLÄCHIGES Overlay */
  .gw-nav {
    position: fixed; inset: 0;
    width: 100%; max-width: none;
    margin: 0; padding: 0;
    background: var(--gw-bg);
    transform: translateX(100%);
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    z-index: 201;
    display: flex; flex-direction: column;
    overflow-y: auto;
  }
  .gw-nav.is-open { transform: translateX(0); }

  .gw-nav__head {
    display: flex; align-items: center; justify-content: space-between;
    padding: var(--gw-space-4) var(--gw-space-5);
    border-bottom: 1px solid var(--gw-border);
  }
  .gw-nav__brand {
    font-weight: var(--gw-weight-bold); font-size: var(--gw-fs-500);
    letter-spacing: 0.1em; text-transform: uppercase; color: var(--gw-gold);
  }

  /* Links vertikal zentriert, großzügig */
  .gw-nav ul { flex-direction: column; gap: var(--gw-space-1); margin: 0; padding: var(--gw-space-5); flex: 1 1 auto; justify-content: center; }
  .gw-nav li { width: 100%; }
  .gw-header .gw-nav a {
    width: 100%; min-height: 56px;
    padding: var(--gw-space-3) var(--gw-space-4);
    font-size: var(--gw-fs-600); font-weight: var(--gw-weight-semibold);
    border-radius: var(--gw-radius);
    justify-content: flex-start;
  }
  .gw-header .gw-nav a:hover,
  .gw-header .gw-nav a:active,
  .gw-header .gw-nav .current-menu-item > a {
    background: var(--gw-gold-soft); color: var(--gw-gold-dark) !important;
  }

  /* Mega-Menü mobil als Akkordeon: Untermenü eingeklappt, Toggle-Button
     (theme.js injiziert ihn) klappt auf. */
  .gw-nav li.menu-item-has-children { position: relative; }
  .gw-nav .gw-submenu-toggle {
    position: absolute; top: 6px; right: var(--gw-space-2);
    width: var(--gw-tap); height: var(--gw-tap);
    display: inline-flex; align-items: center; justify-content: center;
    background: none !important; border: none !important; box-shadow: none !important;
    cursor: pointer; color: var(--gw-ink); border-radius: var(--gw-radius);
  }
  .gw-nav .gw-submenu-toggle::after {
    content: "";
    width: 9px; height: 9px; margin-top: -4px;
    border-right: 1.7px solid currentColor;
    border-bottom: 1.7px solid currentColor;
    transform: rotate(45deg);
    transition: transform var(--gw-transition);
  }
  .gw-nav li.is-open > .gw-submenu-toggle::after { transform: rotate(225deg); margin-top: 4px; }
  .gw-nav .sub-menu {
    display: none;
    list-style: none;
    margin: 0; padding: 0 0 var(--gw-space-2) var(--gw-space-4);
  }
  .gw-nav li.is-open > .sub-menu { display: block; }
  .gw-header .gw-nav .sub-menu a {
    min-height: var(--gw-tap);
    font-size: var(--gw-fs-400);
    font-weight: var(--gw-weight-normal);
  }
}

@media (max-width: 560px) {
  .gw-logo img { max-height: 44px; }
  .gw-logo__text { font-size: var(--gw-fs-500); }
}

/* Body-Scroll-Lock bei offenem Panel/Drawer */
body.gw-no-scroll { overflow: hidden; }

/* =========================================================================
   AUTO-MEGA-PANEL „Hersteller" – Marken-Raster + Produkt-Highlight.
   Positionierung/Öffnen erbt es von .sub-menu (siehe Mega-Menü oben).
   ========================================================================= */
.gw-mega-head {
  margin: 0 0 var(--gw-space-3);
  font-size: var(--gw-fs-300); font-weight: var(--gw-weight-semibold);
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--gw-gold);
}
@media (min-width: 901px) {
  /* Eigenes Layout statt des generischen auto-fill-Rasters */
  .gw-header .gw-nav > ul > li > .gw-mega-panel {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 300px;
    gap: var(--gw-space-7);
    align-items: start;
  }
  /* Markenbereich: Kopfzeile auf gleicher Höhe wie die Promo-Karte
     (die hat eigenes Innen-Padding) → wirkt als EINE Zeile */
  .gw-mega-brands { padding-top: var(--gw-space-5); }
  /* Spezifität > .gw-nav ul (display:flex) – sonst läuft alles in EINE Zeile */
  .gw-header .gw-nav ul.gw-mega-brands__list {
    list-style: none; margin: 0; padding: 0;
    display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 0 var(--gw-space-6);
  }
  .gw-header .gw-nav .gw-mega-panel a.gw-mega-brand {
    display: flex; align-items: center; justify-content: flex-start; gap: var(--gw-space-2);
    width: 100%; min-height: 38px;
    padding: var(--gw-space-1) var(--gw-space-2);
    margin-left: calc(-1 * var(--gw-space-2)); /* Text fluchtet mit der Überschrift */
    border-radius: var(--gw-radius);
    font-weight: var(--gw-weight-normal);
    color: var(--gw-ink) !important;
  }
  .gw-header .gw-nav .gw-mega-panel a.gw-mega-brand:hover { background: var(--gw-gold-soft); color: var(--gw-gold-dark) !important; }
  .gw-mega-brand__count {
    font-size: 12px; color: var(--gw-muted);
    background: var(--gw-bg-soft);
    border: 1px solid var(--gw-border);
    border-radius: var(--gw-radius-pill);
    min-width: 24px; height: 20px; padding: 0 6px;
    display: inline-flex; align-items: center; justify-content: center;
  }
  /* Promo-Karte rechts */
  .gw-header .gw-nav .gw-mega-panel a.gw-mega-promo {
    display: flex; flex-direction: column; align-items: flex-start; gap: var(--gw-space-2);
    background: var(--gw-bg-soft);
    border: 1px solid var(--gw-border);
    border-radius: var(--gw-radius-lg);
    padding: var(--gw-space-4) var(--gw-space-5) var(--gw-space-5);
    color: var(--gw-ink) !important;
    transition: box-shadow var(--gw-transition), transform var(--gw-transition);
  }
  .gw-header .gw-nav .gw-mega-panel a.gw-mega-promo:hover { box-shadow: var(--gw-shadow-lg); transform: translateY(-2px); background: var(--gw-bg-soft); }
  .gw-mega-promo__media { align-self: center; }
  .gw-mega-promo__media img {
    width: 132px !important; height: 132px !important;
    object-fit: contain; background: var(--gw-bg);
    border: 1px solid var(--gw-border); border-radius: var(--gw-radius);
    padding: var(--gw-space-2);
  }
  .gw-mega-promo__name { font-weight: var(--gw-weight-semibold); line-height: 1.35; }
  .gw-mega-promo__price { color: var(--gw-gold); font-weight: var(--gw-weight-bold); }
  .gw-mega-promo__price .amount { color: var(--gw-gold); }
  .gw-mega-promo__cta { font-size: var(--gw-fs-300); font-weight: var(--gw-weight-semibold); color: var(--gw-gold-dark); }
}
@media (max-width: 900px) {
  /* Mobil: schlanke Markenliste im Akkordeon, ohne Promo */
  .gw-mega-panel .gw-mega-head, .gw-mega-promo { display: none; }
  .gw-header .gw-nav ul.gw-mega-brands__list {
    list-style: none; margin: 0; padding: 0;
    display: flex; flex-direction: column; gap: 0;
  }
  .gw-header .gw-nav .gw-mega-panel a.gw-mega-brand {
    display: flex; align-items: center; justify-content: space-between;
    min-height: var(--gw-tap); padding: var(--gw-space-2) var(--gw-space-4);
    font-size: var(--gw-fs-400); font-weight: var(--gw-weight-normal);
    border-radius: var(--gw-radius);
  }
  .gw-mega-brand__count { font-size: 12px; color: var(--gw-muted); }
}

/* =========================================================================
   KONTAKT-WIDGET (FAB) – runder Gold-Button unten RECHTS, startet
   eingeklappt; „Anrufen"/„E-Mail" klappen als Bubbles nach oben auf.
   (Die Erfolgs-Toast weicht nach oben aus, siehe woocommerce.css.)
   ========================================================================= */
.gw-fab {
  position: fixed; right: 24px; bottom: 24px; z-index: 290;
  display: flex; flex-direction: column; align-items: flex-end; gap: var(--gw-space-3);
}
.gw-fab__toggle {
  width: 60px; height: 60px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--gw-gold) !important;
  color: #fff !important;
  border: none !important; border-radius: 50%;
  box-shadow: var(--gw-shadow-lg);
  cursor: pointer;
  transition: background var(--gw-transition), transform var(--gw-transition);
}
.gw-fab__toggle:hover { background: var(--gw-gold-dark) !important; transform: translateY(-1px); }
.gw-fab__icon-open, .gw-fab__icon-close { display: inline-flex; align-items: center; justify-content: center; }
/* Optische Zentrierung: der Blasen-Schwanz unten links zieht das Glyph
   aus der Mitte – minimal nach rechts/unten ausgleichen. */
.gw-fab__icon-open svg { transform: translate(1.5px, 1px); }
.gw-fab__icon-close { display: none; }
.gw-fab.is-open .gw-fab__icon-open { display: none; }
.gw-fab.is-open .gw-fab__icon-close { display: inline-flex; }
.gw-fab.is-open .gw-fab__toggle { background: var(--gw-ink) !important; color: #fff !important; border: none !important; }

/* Eingeklappt: display:none — eine display-Regel würde das hidden-Attribut
   überschreiben, daher nur im geöffneten Zustand flex. */
.gw-fab__actions { display: none; }
.gw-fab.is-open .gw-fab__actions { display: flex; flex-direction: column; align-items: flex-end; gap: var(--gw-space-3); }
.gw-fab__action {
  display: flex; align-items: center; gap: var(--gw-space-2);
  text-decoration: none !important;
  opacity: 0; transform: translateY(8px);
  animation: gw-fab-in 0.22s ease forwards;
}
.gw-fab__action:nth-child(2) { animation-delay: 0.06s; }
@keyframes gw-fab-in { to { opacity: 1; transform: none; } }
.gw-fab__bubble {
  width: 52px; height: 52px; flex: 0 0 auto;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--gw-gold); color: #fff;
  border-radius: 50%; box-shadow: var(--gw-shadow-lg);
  transition: background var(--gw-transition);
}
.gw-fab__action:hover .gw-fab__bubble { background: var(--gw-gold-dark); }
.gw-fab__label {
  background: var(--gw-bg); color: var(--gw-ink);
  font-size: var(--gw-fs-400); font-weight: var(--gw-weight-medium);
  padding: var(--gw-space-2) var(--gw-space-4);
  border-radius: var(--gw-radius-pill);
  box-shadow: var(--gw-shadow-lg);
  white-space: nowrap;
}
.gw-fab__action { flex-direction: row; }
.gw-fab__bubble { order: 2; }
.gw-fab__label { order: 1; }
@media (max-width: 600px) {
  .gw-fab { right: 16px; bottom: 16px; }
  .gw-fab__toggle { width: 54px; height: 54px; }
}

/* =========================================================================
   ACCESSIBILITY
   ========================================================================= */
/* Sichtbarer Tastatur-Fokus (:focus-visible: Maus löst ihn nicht aus).
   Eingabefelder behalten ihren Gold-Soft-Glow. */
a:focus-visible,
button:focus-visible,
[tabindex]:focus-visible,
.gw-btn:focus-visible,
.gw-icon-btn:focus-visible,
.gw-nav a:focus-visible,
.gw-sticky-cta__btn:focus-visible,
.woocommerce a.button:focus-visible,
.woocommerce button.button:focus-visible,
.single_add_to_cart_button:focus-visible {
  outline: 2px solid var(--gw-gold);
  outline-offset: 2px;
}

/* „prefers-reduced-motion" respektieren */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
}
