/* =========================================
   SHOP4PROFIS V2 OVERRIDES FINAL
========================================= */

/* ---------- Produktübersicht / Karten ---------- */

.woocommerce ul.products,
.single-product .related.products ul.products{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:22px;
  align-items:stretch;
  margin:0;
  padding:0;
}

.woocommerce ul.products::before,
.woocommerce ul.products::after,
.single-product .related.products ul.products::before,
.single-product .related.products ul.products::after{
  display:none !important;
}

.woocommerce ul.products li.product,
.single-product .related.products ul.products li.product{
  float:none !important;
  width:auto !important;
  margin:0 !important;
  list-style:none;
  height:auto !important;
}

.s4p-product-card{
  height:100%;
  display:flex;
  flex-direction:column;
  background:#fff;
  border:1px solid var(--line);
  border-radius:26px;
  box-shadow:var(--shadow);
  overflow:hidden;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.s4p-product-card:hover{
  transform:translateY(-4px);
  box-shadow:0 18px 38px rgba(9,31,56,.12);
  border-color:#c8d9ee;
}

.s4p-product-card__image-link{
  display:block;
  text-decoration:none;
}

.s4p-product-card__image-stage{
  position:relative;
  min-height:320px;
  background:linear-gradient(180deg,#f8fbff 0%, #edf4fb 100%);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
}

.s4p-product-card__image-stage img{
  max-width:100%;
  max-height:260px;
  width:auto;
  height:auto;
  object-fit:contain;
  display:block;
  margin:0 auto;
}

.s4p-product-card__badge{
  position:absolute;
  top:16px;
  left:16px;
  z-index:2;
  padding:8px 12px;
  border-radius:999px;
  background:var(--accent);
  color:#111827;
  font-size:12px;
  font-weight:800;
  letter-spacing:.04em;
}

.s4p-product-card__content{
  flex:1 1 auto;
  display:flex;
  flex-direction:column;
  padding:20px 20px 22px;
}

.s4p-product-card__eyebrow{
  color:var(--blue-600);
  font-size:12px;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
  margin-bottom:8px;
  min-height:18px;
}

.s4p-product-card__title-link{
  text-decoration:none;
  color:inherit;
}

.s4p-product-card__title{
  margin:0 0 12px;
  font-size:24px;
  line-height:1.08;
  letter-spacing:-.03em;
  color:var(--text);
  min-height:78px;
}

.s4p-product-card__price{
  font-size:28px;
  font-weight:900;
  color:var(--blue-900);
  line-height:1;
  margin-bottom:12px;
  min-height:34px;
}

.s4p-product-card__price del{
  opacity:.45;
  font-size:.7em;
  margin-right:8px;
}

.s4p-product-card__meta{
  color:var(--muted);
  font-size:14px;
  line-height:1.45;
  min-height:42px;
}

.s4p-product-card__footer{
  margin-top:auto;
  padding-top:18px;
}

.woocommerce ul.products li.product .button.s4p-product-card__button,
.single-product .related.products ul.products li.product .button.s4p-product-card__button,
.woocommerce ul.products li.product a.button.s4p-product-card__button{
  width:100%;
  min-height:50px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:14px !important;
  border:0 !important;
  background:linear-gradient(135deg,var(--blue-600),var(--blue-500)) !important;
  color:#fff !important;
  font-weight:800 !important;
  box-shadow:none !important;
  margin:0 !important;
}

.woocommerce ul.products li.product .button.s4p-product-card__button:hover,
.single-product .related.products ul.products li.product .button.s4p-product-card__button:hover,
.woocommerce ul.products li.product a.button.s4p-product-card__button:hover{
  background:linear-gradient(135deg,var(--blue-700),var(--blue-600)) !important;
  color:#fff !important;
}

.woocommerce span.onsale{
  display:none !important;
}

/* ---------- Neue Single Product Struktur ---------- */

.single-product .s4p-single{
  display:block;
}

.single-product .s4p-single__layout{
  display:grid;
  grid-template-columns:minmax(0, 72%) minmax(300px, 28%);
  gap:32px;
  align-items:start;
}

.single-product .s4p-single__left,
.single-product .s4p-single__right{
  min-width:0;
}

.single-product .s4p-single__left{
  display:flex;
  flex-direction:column;
  gap:24px;
}

.single-product .s4p-single__gallery,
.single-product .s4p-single__summary,
.single-product .s4p-single__tabs-left{
  background:#fff;
  border:1px solid var(--line);
  border-radius:28px;
  box-shadow:var(--shadow);
}

.single-product .s4p-single__gallery{
  padding:24px;
}

.single-product .s4p-single__summary{
  padding:26px;
}

.single-product .s4p-single__tabs-left{
  padding:24px;
}

.single-product div.product .woocommerce-product-gallery,
.single-product div.product div.images,
.single-product div.product .summary{
  float:none !important;
  width:100% !important;
  margin:0 !important;
}

.single-product .s4p-single__gallery .woocommerce-product-gallery,
.single-product .s4p-single__gallery .woocommerce-product-gallery__wrapper{
  width:100% !important;
  max-width:none !important;
}

.single-product .s4p-single__gallery .woocommerce-product-gallery__image{
  background:linear-gradient(180deg,#f8fbff 0%, #edf4fb 100%);
  border-radius:22px;
  overflow:hidden;
  min-height:760px;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
}

.single-product .s4p-single__gallery .woocommerce-product-gallery__image a{
  width:100%;
  min-height:760px;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
}

.single-product .s4p-single__gallery .woocommerce-product-gallery__image img,
.single-product .s4p-single__gallery img.wp-post-image{
  width:auto !important;
  max-width:96% !important;
  max-height:700px !important;
  height:auto !important;
  object-fit:contain !important;
  margin:0 auto !important;
  display:block !important;
}

.single-product .s4p-single__gallery .flex-viewport{
  min-height:760px !important;
}

.single-product .s4p-single__gallery .flex-control-thumbs,
.single-product .s4p-single__gallery ol.flex-control-nav.flex-control-thumbs{
  display:grid !important;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
  margin-top:18px !important;
  padding:0 !important;
}

.single-product .s4p-single__gallery .flex-control-thumbs li{
  list-style:none !important;
  margin:0 !important;
}

.single-product .s4p-single__gallery .flex-control-thumbs img{
  width:100% !important;
  max-height:130px !important;
  object-fit:contain !important;
  border:1px solid var(--line) !important;
  border-radius:16px !important;
  background:#fff !important;
  padding:10px !important;
  opacity:1 !important;
}

.single-product .s4p-single__summary .product_title{
  font-size:36px;
  line-height:1.02;
  letter-spacing:-.03em;
  margin:0 0 14px;
}

.single-product .s4p-single__summary p.price,
.single-product .s4p-single__summary span.price{
  font-size:30px;
  line-height:1;
  margin:0 0 18px;
}

.single-product .s4p-single__summary .woocommerce-product-details__short-description{
  color:var(--muted);
  font-size:15px;
  line-height:1.6;
  margin-bottom:16px;
}

.single-product .s4p-single__summary form.cart{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  align-items:end;
  margin-top:16px;
  margin-bottom:16px;
}

.single-product .s4p-single__summary form.cart .variations{
  width:100%;
  margin-bottom:8px;
  border-collapse:separate;
  border-spacing:0 10px;
}

.single-product .s4p-single__summary form.cart .variations th,
.single-product .s4p-single__summary form.cart .variations td{
  display:block;
  width:100%;
  padding:0;
}

.single-product .s4p-single__summary form.cart .variations label{
  display:block;
  margin-bottom:6px;
  font-weight:800;
  color:var(--blue-900);
}

.single-product .s4p-single__summary form.cart .variations select{
  width:100%;
  min-height:48px;
  border:1px solid var(--line);
  border-radius:14px;
  background:#fff;
  padding:0 12px;
}

.single-product .s4p-single__summary .quantity .qty{
  min-width:88px;
}

.single-product .s4p-single__summary .single_add_to_cart_button{
  min-width:180px;
  width:auto !important;
}

.single-product .s4p-single__summary .product_meta{
  margin-top:16px;
  padding-top:16px;
  border-top:1px solid var(--line);
  display:grid;
  gap:8px;
  font-size:14px;
}

.single-product .s4p-single__tabs-left .woocommerce-tabs{
  margin:0;
  width:100%;
}

.single-product .s4p-single__tabs-left .woocommerce-tabs ul.tabs{
  margin:0 0 16px !important;
  padding:0 !important;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.single-product .s4p-single__tabs-left .woocommerce-tabs ul.tabs::before{
  display:none !important;
}

.single-product .s4p-single__tabs-left .woocommerce-tabs ul.tabs li{
  margin:0 !important;
  padding:0 !important;
  background:transparent !important;
  border:0 !important;
}

.single-product .s4p-single__tabs-left .woocommerce-tabs ul.tabs li::before,
.single-product .s4p-single__tabs-left .woocommerce-tabs ul.tabs li::after{
  display:none !important;
}

.single-product .s4p-single__tabs-left .woocommerce-tabs ul.tabs li a{
  display:inline-flex;
  align-items:center;
  min-height:46px;
  padding:0 18px;
  border-radius:14px;
  background:#f8fbff;
  border:1px solid var(--line);
  color:var(--text);
  font-weight:800;
}

.single-product .s4p-single__tabs-left .woocommerce-tabs ul.tabs li.active a{
  background:var(--blue-600);
  color:#fff;
  border-color:var(--blue-600);
}

.single-product .s4p-single__tabs-left .woocommerce-tabs .panel{
  background:transparent;
  border:0;
  box-shadow:none;
  padding:0;
}

.single-product .s4p-single__related-full{
  margin-top:36px;
}

.single-product .related.products{
  margin-top:0;
  width:100%;
}

.single-product .related.products > h2{
  margin-bottom:20px;
}

.single-product .related.products ul.products{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:22px;
}

/* ---------- Responsive ---------- */

@media (max-width: 1200px){
  .woocommerce ul.products,
  .single-product .related.products ul.products{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }

  .single-product .s4p-single__layout{
    grid-template-columns:1fr;
  }

  .single-product .s4p-single__gallery .woocommerce-product-gallery__image,
  .single-product .s4p-single__gallery .woocommerce-product-gallery__image a,
  .single-product .s4p-single__gallery .flex-viewport{
    min-height:520px !important;
  }

  .single-product .s4p-single__gallery .woocommerce-product-gallery__image img,
  .single-product .s4p-single__gallery img.wp-post-image{
    max-height:480px !important;
  }
}

@media (max-width: 700px){
  .woocommerce ul.products,
  .single-product .related.products ul.products{
    grid-template-columns:1fr;
  }

  .single-product .s4p-single__summary .product_title{
    font-size:32px;
  }

  .single-product .s4p-single__gallery,
  .single-product .s4p-single__summary,
  .single-product .s4p-single__tabs-left{
    padding:20px;
  }

  .single-product .s4p-single__gallery .woocommerce-product-gallery__image,
  .single-product .s4p-single__gallery .woocommerce-product-gallery__image a,
  .single-product .s4p-single__gallery .flex-viewport{
    min-height:320px !important;
  }

  .single-product .s4p-single__gallery .woocommerce-product-gallery__image img,
  .single-product .s4p-single__gallery img.wp-post-image{
    max-height:280px !important;
  }

  .single-product .s4p-single__gallery .flex-control-thumbs{
    grid-template-columns:repeat(3,minmax(0,1fr)) !important;
  }

  .single-product .s4p-single__summary .single_add_to_cart_button{
    width:100% !important;
    min-width:0;
  }
}

/* =========================================
   VARIANTEN / SWATCHES FEINSCHLIFF
========================================= */

/* Native Dropdowns */
.single-product .s4p-single__summary .variations select{
  appearance:none;
  -webkit-appearance:none;
  -moz-appearance:none;
  background:
    linear-gradient(45deg, transparent 50%, var(--blue-700) 50%),
    linear-gradient(135deg, var(--blue-700) 50%, transparent 50%),
    linear-gradient(to right, #fff, #fff);
  background-position:
    calc(100% - 20px) calc(50% - 3px),
    calc(100% - 14px) calc(50% - 3px),
    100% 0;
  background-size:6px 6px, 6px 6px, 2.8em 100%;
  background-repeat:no-repeat;
  border:1px solid var(--line) !important;
  border-radius:16px !important;
  min-height:52px !important;
  padding:0 46px 0 14px !important;
  font-weight:700;
  color:var(--text);
  box-shadow:none !important;
}

/* Reset-Link */
.single-product .s4p-single__summary .reset_variations{
  display:inline-flex !important;
  align-items:center;
  margin-top:8px !important;
  color:var(--blue-700) !important;
  font-weight:700;
  font-size:14px;
}

/* Plugin-Swatches: allgemeine Wrapper */
.single-product .s4p-single__summary .variable-items-wrapper,
.single-product .s4p-single__summary ul.variable-items-wrapper{
  display:flex !important;
  flex-wrap:wrap !important;
  gap:10px !important;
  margin:10px 0 0 !important;
  padding:0 !important;
  list-style:none !important;
}

/* Plugin-Swatches: einzelne Elemente */
.single-product .s4p-single__summary .variable-item,
.single-product .s4p-single__summary li.variable-item{
  margin:0 !important;
  padding:0 !important;
  min-width:0 !important;
  border:0 !important;
  box-shadow:none !important;
  background:transparent !important;
  list-style:none !important;
}

/* Button-/Text-Swatches */
.single-product .s4p-single__summary .variable-item.button-variable-item,
.single-product .s4p-single__summary .variable-item-span-button,
.single-product .s4p-single__summary .variable-item:not(.color-variable-item){
  min-width:54px !important;
  min-height:46px !important;
  padding:0 14px !important;
  border-radius:14px !important;
  border:1px solid var(--line) !important;
  background:#f8fbff !important;
  color:var(--text) !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  font-weight:800 !important;
  font-size:14px !important;
  line-height:1 !important;
  transition:.15s ease !important;
}

.single-product .s4p-single__summary .variable-item.button-variable-item:hover,
.single-product .s4p-single__summary .variable-item-span-button:hover,
.single-product .s4p-single__summary .variable-item:not(.color-variable-item):hover{
  border-color:#b7d0ee !important;
  background:#eef5ff !important;
  transform:translateY(-1px);
}

/* Ausgewählte Text-/Button-Swatches */
.single-product .s4p-single__summary .variable-item.selected:not(.color-variable-item),
.single-product .s4p-single__summary .variable-item.selected .variable-item-span-button,
.single-product .s4p-single__summary .variable-item.selected.button-variable-item{
  background:linear-gradient(135deg,var(--blue-600),var(--blue-500)) !important;
  color:#fff !important;
  border-color:var(--blue-600) !important;
}

/* Farb-Swatches */
.single-product .s4p-single__summary .color-variable-item{
  width:42px !important;
  height:42px !important;
  min-width:42px !important;
  min-height:42px !important;
  border-radius:12px !important;
  border:2px solid #d7e3f0 !important;
  overflow:hidden !important;
  background:#fff !important;
  box-shadow:none !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
}

.single-product .s4p-single__summary .color-variable-item:hover{
  border-color:#9fc4f0 !important;
  transform:translateY(-1px);
}

.single-product .s4p-single__summary .color-variable-item.selected{
  border-color:var(--blue-600) !important;
  box-shadow:0 0 0 3px rgba(47,140,255,.16) !important;
}

/* Innenfläche von Plugin-Farbfeldern */
.single-product .s4p-single__summary .color-variable-item span,
.single-product .s4p-single__summary .color-variable-item .variable-item-span{
  width:100% !important;
  height:100% !important;
  border-radius:10px !important;
  display:block !important;
}

/* Komische Standardkreise / Layer entfernen */
.single-product .s4p-single__summary .variable-item::before,
.single-product .s4p-single__summary .variable-item::after,
.single-product .s4p-single__summary .variable-item span::before,
.single-product .s4p-single__summary .variable-item span::after{
  box-shadow:none !important;
}

/* Nicht verfügbare Varianten */
.single-product .s4p-single__summary .variable-item.disabled,
.single-product .s4p-single__summary .variable-item.vs-disabled{
  opacity:.35 !important;
  filter:grayscale(1);
}

/* Label + Abstand besser */
.single-product .s4p-single__summary .variations tr{
  margin-bottom:8px !important;
}

.single-product .s4p-single__summary .variations .label{
  margin-bottom:6px !important;
}

.single-product .s4p-single__summary .variations .value{
  padding-top:2px !important;
}

/* =========================================
   VARIANTEN WRAP / MANY COLORS FIX
========================================= */

.single-product .s4p-single__summary .variations{
  table-layout:fixed;
}

.single-product .s4p-single__summary .variations .value{
  width:100% !important;
  max-width:100% !important;
  overflow:visible !important;
}

.single-product .s4p-single__summary .variable-items-wrapper,
.single-product .s4p-single__summary ul.variable-items-wrapper{
  display:flex !important;
  flex-wrap:wrap !important;
  align-items:flex-start !important;
  gap:10px !important;
  width:100% !important;
  max-width:100% !important;
}

.single-product .s4p-single__summary .variable-item,
.single-product .s4p-single__summary li.variable-item{
  flex:0 0 auto !important;
  max-width:100% !important;
}

.single-product .s4p-single__summary .variable-item.button-variable-item,
.single-product .s4p-single__summary .variable-item-span-button,
.single-product .s4p-single__summary .variable-item:not(.color-variable-item){
  min-width:58px !important;
  min-height:44px !important;
  padding:0 12px !important;
  font-size:13px !important;
  white-space:nowrap !important;
}

.single-product .s4p-single__summary .color-variable-item{
  width:44px !important;
  height:44px !important;
  min-width:44px !important;
  min-height:44px !important;
}

.single-product .s4p-single__summary .variations tr + tr{
  margin-top:10px !important;
}

.single-product .s4p-single__summary .reset_variations{
  margin-left:0 !important;
  margin-top:10px !important;
}

/* =========================================
   FARBEN UNTEREINANDER, GRÖSSEN ALS GRID
========================================= */

.single-product .s4p-single__summary tr:has(.label label[for*="farbe"]),
.single-product .s4p-single__summary tr:has(.label label[for*="color"]),
.single-product .s4p-single__summary tr:has(.label label[for*="pa_farbe"]),
.single-product .s4p-single__summary tr:has(.label label[for*="pa_color"]){
  display:block !important;
}

.single-product .s4p-single__summary tr:has(.label label[for*="farbe"]) .value .variable-items-wrapper,
.single-product .s4p-single__summary tr:has(.label label[for*="color"]) .value .variable-items-wrapper,
.single-product .s4p-single__summary tr:has(.label label[for*="pa_farbe"]) .value .variable-items-wrapper,
.single-product .s4p-single__summary tr:has(.label label[for*="pa_color"]) .value .variable-items-wrapper{
  display:flex !important;
  flex-direction:column !important;
  align-items:stretch !important;
  gap:10px !important;
}

.single-product .s4p-single__summary tr:has(.label label[for*="farbe"]) .value .variable-item,
.single-product .s4p-single__summary tr:has(.label label[for*="color"]) .value .variable-item,
.single-product .s4p-single__summary tr:has(.label label[for*="pa_farbe"]) .value .variable-item,
.single-product .s4p-single__summary tr:has(.label label[for*="pa_color"]) .value .variable-item{
  width:100% !important;
}

.single-product .s4p-single__summary tr:has(.label label[for*="farbe"]) .value .variable-item:not(.color-variable-item),
.single-product .s4p-single__summary tr:has(.label label[for*="color"]) .value .variable-item:not(.color-variable-item),
.single-product .s4p-single__summary tr:has(.label label[for*="pa_farbe"]) .value .variable-item:not(.color-variable-item),
.single-product .s4p-single__summary tr:has(.label label[for*="pa_color"]) .value .variable-item:not(.color-variable-item){
  width:100% !important;
  justify-content:flex-start !important;
  min-height:46px !important;
  padding:0 14px !important;
  border-radius:14px !important;
}

/* Größen bewusst als Raster lassen */
.single-product .s4p-single__summary tr:has(.label label[for*="größe"]) .value .variable-items-wrapper,
.single-product .s4p-single__summary tr:has(.label label[for*="groesse"]) .value .variable-items-wrapper,
.single-product .s4p-single__summary tr:has(.label label[for*="size"]) .value .variable-items-wrapper,
.single-product .s4p-single__summary tr:has(.label label[for*="pa_groesse"]) .value .variable-items-wrapper,
.single-product .s4p-single__summary tr:has(.label label[for*="pa_size"]) .value .variable-items-wrapper{
  display:flex !important;
  flex-direction:row !important;
  flex-wrap:wrap !important;
  gap:10px !important;
}

/* Shop4Profis Mega-Menü */
.s4p-mainnav {
    width: 100%;
}

.s4p-menu {
    display: flex;
    align-items: center;
    gap: 6px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.s4p-menu > li {
    position: relative;
}

.s4p-menu > li > a {
    display: flex;
    align-items: center;
    min-height: 48px;
    padding: 0 14px;
    border-radius: 12px;
    color: #102033;
    font-weight: 700;
    font-size: 14px;
    text-decoration: none;
    white-space: nowrap;
}

.s4p-menu > li > a:hover,
.s4p-menu > li:hover > a {
    background: rgba(20, 88, 170, 0.09);
    color: #0b5ed7;
}

.has-mega > a::after {
    content: "▾";
    margin-left: 7px;
    font-size: 11px;
    opacity: .65;
}

.mega-menu {
    position: absolute;
    top: 100%;
    left: 0;
    z-index: 999;
    display: grid;
    grid-template-columns: repeat(3, minmax(170px, 1fr));
    gap: 22px;
    width: min(760px, calc(100vw - 40px));
    padding: 24px;
    background: #fff;
    border: 1px solid rgba(16, 32, 51, 0.10);
    border-radius: 22px;
    box-shadow: 0 24px 70px rgba(16, 32, 51, 0.18);
    opacity: 0;
    visibility: hidden;
    transform: translateY(12px);
    transition: .18s ease;
}

.mega-menu--small {
    grid-template-columns: minmax(220px, 1fr);
    width: 320px;
}

.has-mega:hover .mega-menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.mega-menu h4 {
    margin: 0 0 12px;
    color: #071525;
    font-size: 14px;
    font-weight: 900;
}

.mega-menu a {
    display: block;
    padding: 8px 0;
    color: #4b5d73;
    font-size: 14px;
    font-weight: 650;
    text-decoration: none;
}

.mega-menu a:hover {
    color: #0b5ed7;
}

@media (max-width: 980px) {
    .navbar__inner {
        align-items: flex-start;
        gap: 12px;
    }

    .s4p-menu {
        flex-wrap: wrap;
    }

    .mega-menu {
        position: static;
        display: none;
        width: 100%;
        margin: 4px 0 12px;
        box-shadow: none;
        transform: none;
    }

    .has-mega:hover .mega-menu {
        display: grid;
    }
}


/* FIX: Hauptmenü wirklich horizontal + Mega Dropdown */
.navbar .s4p-mainnav,
.navbar .s4p-mainnav ul,
.navbar .s4p-mainnav li {
    list-style: none !important;
}

.navbar .s4p-menu {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 8px !important;
    margin: 0 !important;
    padding: 0 !important;
}

.navbar .s4p-menu > li {
    position: relative !important;
    margin: 0 !important;
    padding: 0 !important;
}

.navbar .s4p-menu > li > a {
    display: flex !important;
    align-items: center !important;
    min-height: 44px !important;
    padding: 0 13px !important;
    border-radius: 12px !important;
    color: #ffffff !important;
    font-size: 14px !important;
    font-weight: 800 !important;
    text-decoration: none !important;
}

.navbar .s4p-menu > li:hover > a {
    background: rgba(255,255,255,.14) !important;
}

.navbar .has-mega > a::after {
    content: "▾";
    margin-left: 7px;
    font-size: 11px;
    opacity: .75;
}

.navbar .mega-menu {
    position: absolute !important;
    top: calc(100% + 8px) !important;
    left: 0 !important;
    z-index: 99999 !important;
    display: grid !important;
    grid-template-columns: repeat(3, minmax(170px, 1fr)) !important;
    gap: 24px !important;
    width: min(780px, calc(100vw - 40px)) !important;
    padding: 24px !important;
    margin: 0 !important;
    background: #ffffff !important;
    border: 1px solid rgba(15, 23, 42, .10) !important;
    border-radius: 22px !important;
    box-shadow: 0 28px 80px rgba(2, 8, 23, .24) !important;
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
    transform: translateY(10px) !important;
    transition: .18s ease !important;
}

.navbar .mega-menu--small {
    grid-template-columns: minmax(220px, 1fr) !important;
    width: 340px !important;
}

.navbar .has-mega:hover > .mega-menu {
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    transform: translateY(0) !important;
}

.navbar .mega-menu h4 {
    margin: 0 0 12px !important;
    padding: 0 !important;
    color: #071525 !important;
    font-size: 14px !important;
    font-weight: 900 !important;
}

.navbar .mega-menu a {
    display: block !important;
    min-height: auto !important;
    padding: 8px 0 !important;
    margin: 0 !important;
    border-radius: 0 !important;
    color: #4b5d73 !important;
    font-size: 14px !important;
    font-weight: 650 !important;
    text-decoration: none !important;
    white-space: normal !important;
}

.navbar .mega-menu a:hover {
    color: #0b5ed7 !important;
    background: transparent !important;
}

@media (max-width: 980px) {
    .navbar .s4p-menu {
        flex-wrap: wrap !important;
    }

    .navbar .mega-menu {
        position: static !important;
        display: none !important;
        width: 100% !important;
        box-shadow: none !important;
        transform: none !important;
    }

    .navbar .has-mega:hover > .mega-menu {
        display: grid !important;
    }
}


/* Mega-Menü Feinschliff */
.navbar .has-mega {
    padding-bottom: 14px !important;
    margin-bottom: -14px !important;
}

.navbar .mega-menu {
    top: calc(100% - 2px) !important;
    padding: 30px 32px !important;
}

.navbar .mega-menu h4 {
    display: inline-flex !important;
    align-items: center !important;
    margin: 0 0 18px !important;
    padding: 7px 12px !important;
    border-radius: 999px !important;
    background: rgba(11, 94, 215, .10) !important;
    color: #073763 !important;
    font-size: 13px !important;
    font-weight: 950 !important;
    letter-spacing: .02em !important;
    text-transform: uppercase !important;
}

.navbar .mega-menu a {
    padding: 9px 10px !important;
    border-radius: 10px !important;
    color: #26384f !important;
}

.navbar .mega-menu a:hover {
    background: rgba(11, 94, 215, .08) !important;
    color: #0b5ed7 !important;
}

.navbar .mega-menu div {
    min-width: 0 !important;
}


/* Startseite: Markenlogos und neue Shopflächen */
.s4p-logo-stack {
    display: grid;
    gap: 14px;
    margin-top: 18px;
}

.s4p-logo-stack a,
.s4p-brand-tile {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 96px;
    padding: 22px;
    border-radius: 20px;
    background: #ffffff;
    border: 1px solid rgba(15, 23, 42, .10);
    box-shadow: 0 16px 38px rgba(15, 23, 42, .08);
    text-decoration: none;
}

.s4p-logo-stack img {
    max-width: 220px;
    max-height: 70px;
    object-fit: contain;
}

.hero-panel--brand {
    background: linear-gradient(135deg, #f8fbff 0%, #eef6ff 100%);
}

.category-grid--six {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.s4p-brand-showcase {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 22px;
}

.s4p-brand-tile {
    flex-direction: column;
    min-height: 190px;
    gap: 18px;
    text-align: center;
}

.s4p-brand-tile img {
    max-width: 260px;
    max-height: 95px;
    object-fit: contain;
}

.s4p-brand-tile strong,
.s4p-logo-stack strong {
    color: #0f172a;
    font-size: 28px;
    font-weight: 950;
    letter-spacing: .04em;
}

.s4p-brand-tile span {
    color: #475569;
    font-size: 15px;
    font-weight: 700;
    line-height: 1.45;
}

.promo-grid a.promo-card {
    text-decoration: none;
    color: inherit;
}

@media (max-width: 900px) {
    .category-grid--six,
    .s4p-brand-showcase {
        grid-template-columns: 1fr;
    }
}


/* Startseite Feinschliff: ruhiger, professioneller, weniger Demo-Look */
body {
    background: #f4f7fb !important;
}

.s4p-home-hero .hero-main {
    background:
        radial-gradient(circle at top right, rgba(0, 128, 255, .22), transparent 38%),
        linear-gradient(135deg, #061827 0%, #0b3558 58%, #0d67b5 100%) !important;
    box-shadow: 0 28px 80px rgba(3, 18, 34, .22) !important;
}

.s4p-home-hero .hero-main h1 {
    max-width: 760px !important;
    letter-spacing: -0.045em !important;
}

.s4p-home-hero .hero-main p {
    max-width: 720px !important;
    color: rgba(255,255,255,.86) !important;
}

.hero-stat {
    background: rgba(255,255,255,.10) !important;
    border: 1px solid rgba(255,255,255,.16) !important;
}

.hero-panel {
    background: #ffffff !important;
    border: 1px solid rgba(15, 23, 42, .08) !important;
    box-shadow: 0 18px 55px rgba(15, 23, 42, .08) !important;
}

.hero-panel--brand {
    background: linear-gradient(180deg, #ffffff 0%, #f7fafc 100%) !important;
}

.s4p-logo-stack a,
.s4p-brand-tile {
    background: #ffffff !important;
    border: 1px solid rgba(15, 23, 42, .09) !important;
    box-shadow: 0 16px 44px rgba(15, 23, 42, .07) !important;
}

.category-card {
    background: #ffffff !important;
    border: 1px solid rgba(15, 23, 42, .08) !important;
    box-shadow: 0 14px 38px rgba(15, 23, 42, .055) !important;
}

.category-card:hover,
.s4p-brand-tile:hover {
    transform: translateY(-3px) !important;
    box-shadow: 0 22px 55px rgba(15, 23, 42, .10) !important;
}

.category-card__icon {
    background: #e8f2ff !important;
    color: #075ca8 !important;
}

.s4p-brand-showcase {
    gap: 24px !important;
}

.s4p-brand-tile {
    min-height: 170px !important;
}

.s4p-brand-tile strong,
.s4p-logo-stack strong {
    color: #0b1726 !important;
    font-size: 30px !important;
}

.promo-card--blue {
    background: linear-gradient(135deg, #08243a 0%, #075ca8 100%) !important;
    color: #ffffff !important;
}

.promo-card--dark {
    background: linear-gradient(135deg, #111827 0%, #1f2937 100%) !important;
    color: #ffffff !important;
}

.promo-card--light {
    background: #ffffff !important;
    color: #0f172a !important;
    border: 1px solid rgba(15, 23, 42, .08) !important;
}

.promo-card__tag {
    background: rgba(255,255,255,.14) !important;
    color: inherit !important;
}

.promo-card--light .promo-card__tag {
    background: #e8f2ff !important;
    color: #075ca8 !important;
}

