.bw-social-share .panel.panel-warning {
  margin-top: 20px;
  background-color: #fcf8e3;
  border: 1px solid transparent;
  border-radius: 4px;
  box-shadow: 0 1px 1px rgba(0, 0, 0, 0.05);
  margin-bottom: 20px;
  font-family: Helvetica, Arial, sans-serif;
  border-color: #faebcc;
  font-size: 11px;
  line-height: 15px;
}

.bw-social-share .panel-warning > .panel-heading {
  background-color: #fcf8e3;
  border-color: #faebcc;
  color: #8a6d3b;
}
.bw-social-share .panel-heading {
  border-bottom: 1px solid transparent;
  border-top-left-radius: 3px;
  border-top-right-radius: 3px;
  padding: 10px 15px;
}
.bw-social-share .panel-body {
  padding: 20px;
}
.bw-social-share .panel-body p b {
  font-weight: bold;
}

/* Verbesserte Typografie im großen Layout - wird dynamisch per JS gesetzt */
.bw-social-share .rrssb-buttons.large-format li a {
  /* Layout wird hauptsächlich per JavaScript gesetzt */
  box-sizing: border-box;
  overflow: hidden;
  /* CSS-Fallback falls JS nicht lädt */
  font-size: 16px;
  line-height: 1.2;
  display: flex;
  align-items: center;
  padding-left: 50px; /* Fallback für Icon-Platz */
}

/* Größere Schrift für große Bildschirme */
@media (min-width: 1200px) {
  .bw-social-share .rrssb-buttons.large-format li a {
    font-size: 18px !important; /* Größere Schrift für große Bildschirme */
    line-height: 1.3 !important; /* Angepasste Zeilenhöhe */
  }
}

@media (min-width: 900px) and (max-width: 1199px) {
  .bw-social-share .rrssb-buttons.large-format li a {
    font-size: 17px !important; /* Mittlere Schriftgröße für mittlere Bildschirme */
    line-height: 1.25 !important;
  }
}

/* Reduziertes bottom padding bei kleineren Bildschirmen */
@media (max-width: 750px) {
  .bw-social-share .rrssb-buttons.large-format {
    margin-bottom: 10px; /* Weniger Abstand nach unten */
  }

  .bw-social-share .rrssb-buttons.large-format li {
    margin-bottom: 2px; /* Weniger Abstand zwischen Buttons */
  }
}

@media (max-width: 600px) {
  .bw-social-share .rrssb-buttons.large-format {
    margin-bottom: 8px; /* Noch weniger Abstand nach unten */
  }

  .bw-social-share .rrssb-buttons.large-format li {
    margin-bottom: 1px; /* Minimaler Abstand zwischen Buttons */
  }
}

/* Icon-Fallback-Positionierung */
.bw-social-share .rrssb-buttons.large-format li a .rrssb-icon {
  flex-shrink: 0;
  /* JavaScript überschreibt diese Werte */
}

/* Text-Fallback-Positionierung */
.bw-social-share .rrssb-buttons.large-format li a .rrssb-text {
  flex: 1;
  min-width: 0; /* Wichtig für text-overflow */
  /* JavaScript überschreibt diese Werte */
}

/* Klein-Layout stabilisieren: Icon-only Buttons - WICHTIG: Überschreibt RRSSB CSS! */
.bw-social-share .rrssb-buttons.small-format {
  display: flex !important;
  flex-wrap: nowrap !important;
  gap: 4px !important;
  padding-right: 4px !important;
  align-items: center !important;
  height: auto !important; /* Überschreibt feste RRSSB Höhe */
}

/* Überschreibt RRSSB clearfix */
.bw-social-share .rrssb-buttons.small-format:after,
.bw-social-share .rrssb-buttons.small-format:before {
  display: none !important;
}

.bw-social-share .rrssb-buttons.small-format li {
  float: none !important; /* Überschreibt RRSSB float */
  display: block !important;
  flex-shrink: 0 !important;
  box-sizing: border-box !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* Icon-only Buttons: Erzwinge quadratische Form - Standard oder dynamisch */
.bw-social-share .rrssb-buttons.small-format li,
.bw-social-share .rrssb-buttons li.small {
  width: var(--button-size, 44px) !important;
  height: var(--button-size, 44px) !important;
  min-width: 44px !important;
  min-height: 44px !important;
}

/* Icon-only Button Links - Robuste Flexbox-Zentrierung */
.bw-social-share .rrssb-buttons.small-format li a,
.bw-social-share .rrssb-buttons li.small a {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  margin: 0 !important;
  width: 100% !important;
  height: 100% !important;
  box-sizing: border-box !important;
  position: relative !important;
  overflow: hidden !important; /* Verhindert Icon-Überlauf */
}

/* Spezielle Behandlung für 720-750px Bereich */
@media (max-width: 749px) and (min-width: 720px) {
  .bw-social-share .rrssb-buttons.small-format li,
  .bw-social-share .rrssb-buttons li.small {
    width: 42px !important; /* Etwas breiter für bessere Proportionen */
    height: 42px !important; /* Etwas höher für bessere Sichtbarkeit */
    min-width: 42px !important;
    min-height: 42px !important;
  }

  /* Verstärkte Zentrierung im 720-750px Bereich */
  .bw-social-share .rrssb-buttons.small-format li a,
  .bw-social-share .rrssb-buttons li.small a {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    margin: 0 !important;
    width: 100% !important;
    height: 100% !important;
    box-sizing: border-box !important;
    position: relative !important;
  }

  /* Icon-Container für 720-750px - Flexbox-Zentrierung */
  .bw-social-share .rrssb-buttons.small-format li a .rrssb-icon,
  .bw-social-share .rrssb-buttons li.small a .rrssb-icon {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    transform: none !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important; /* Volle Button-Breite */
    height: 100% !important; /* Volle Button-Höhe */
    padding: 0 !important;
    margin: 0 !important;
    flex-shrink: 0 !important;
  }

  /* Überschreibe widersprüchliche Regeln für 720-750px - Vollständige Flexbox-Zentrierung */
  .bw-social-share .rrssb-buttons.small-format li a .rrssb-icon {
    position: relative !important;
    top: auto !important;
    left: auto !important;
    transform: none !important;
    width: 100% !important;
    height: 100% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    margin: 0 !important;
  }

  /* SVG einfache Zentrierung für 720-750px - Flexbox macht die Arbeit */
  .bw-social-share .rrssb-buttons.small-format li a .rrssb-icon svg,
  .bw-social-share .rrssb-buttons li.small a .rrssb-icon svg {
    width: 28px !important;
    height: 28px !important;
    display: block !important;
    margin: 0 !important; /* Kein auto margin nötig, Flexbox übernimmt */
    position: static !important; /* Kein relative positioning */
    left: auto !important;
    top: auto !important;
    transform: none !important; /* Kein transform nötig */
    /* SVG-spezifische Eigenschaften zurücksetzen */
    x: 0 !important;
    y: 0 !important;
  }
}

/* Icons in Icon-only Buttons - Einfache Flexbox-Zentrierung */
.bw-social-share .rrssb-buttons.small-format li a .rrssb-icon,
.bw-social-share .rrssb-buttons li.small a .rrssb-icon {
  position: relative !important;
  left: auto !important;
  top: auto !important;
  transform: none !important;
  width: 28px !important; /* Größer für bessere Sichtbarkeit */
  height: 28px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  margin: 0 !important;
  flex-shrink: 0 !important;
}

/* SVG Icons erzwingen - responsive */
.bw-social-share .rrssb-buttons.small-format li a .rrssb-icon svg,
.bw-social-share .rrssb-buttons li.small a .rrssb-icon svg {
  width: 28px !important;
  height: 28px !important;
  display: block !important;
}

/* Responsive Icon-Größen für verschiedene Bildschirmbreiten - feinere Abstufungen */
@media (max-width: 900px) and (min-width: 750px) {
  .bw-social-share .rrssb-buttons.small-format li a .rrssb-icon,
  .bw-social-share .rrssb-buttons li.small a .rrssb-icon {
    width: 32px !important; /* Größer für 750px+ Bereich */
    height: 32px !important;
  }

  .bw-social-share .rrssb-buttons.small-format li a .rrssb-icon svg,
  .bw-social-share .rrssb-buttons li.small a .rrssb-icon svg {
    width: 32px !important;
    height: 32px !important;
  }
}

/* Redundante Regel entfernt - bereits im 720-750px Block oben definiert */
@media (max-width: 719px) and (min-width: 650px) {
  .bw-social-share .rrssb-buttons.small-format li a .rrssb-icon,
  .bw-social-share .rrssb-buttons li.small a .rrssb-icon {
    width: 30px !important; /* Optimal für 650px-720px Bereich */
    height: 30px !important;
  }

  .bw-social-share .rrssb-buttons.small-format li a .rrssb-icon svg,
  .bw-social-share .rrssb-buttons li.small a .rrssb-icon svg {
    width: 30px !important;
    height: 30px !important;
  }
}
@media (max-width: 649px) and (min-width: 550px) {
  .bw-social-share .rrssb-buttons.small-format li a .rrssb-icon,
  .bw-social-share .rrssb-buttons li.small a .rrssb-icon {
    width: 26px !important;
    height: 26px !important;
  }

  .bw-social-share .rrssb-buttons.small-format li a .rrssb-icon svg,
  .bw-social-share .rrssb-buttons li.small a .rrssb-icon svg {
    width: 26px !important;
    height: 26px !important;
  }
}

@media (max-width: 549px) {
  .bw-social-share .rrssb-buttons.small-format li a .rrssb-icon,
  .bw-social-share .rrssb-buttons li.small a .rrssb-icon {
    width: 22px !important;
    height: 22px !important;
  }

  .bw-social-share .rrssb-buttons.small-format li a .rrssb-icon svg,
  .bw-social-share .rrssb-buttons li.small a .rrssb-icon svg {
    width: 22px !important;
    height: 22px !important;
  }
} /* Text in Icon-only Buttons verstecken */
.bw-social-share .rrssb-buttons.small-format li a .rrssb-text,
.bw-social-share .rrssb-buttons li.small a .rrssb-text {
  display: none !important;
}
.bw-social-share .rrssb-buttons.small-format li a {
  padding: 0;
}
.bw-social-share .rrssb-buttons.small-format li a .rrssb-icon {
  height: 100%;
}
.bw-social-share .rrssb-buttons.small-format li a .rrssb-icon svg {
  height: 70%;
  width: 70%;
  position: relative;
  top: 5px;
}

/* Mischfall: einzelne li.small zwischen Text-Buttons */
.bw-social-share .rrssb-buttons li.small a {
  overflow: hidden; /* Clipping innerhalb des quadratischen Buttons */
}
.bw-social-share .rrssb-buttons li.small a .rrssb-icon {
  left: auto !important;
  top: auto !important;
  width: 100% !important;
  height: 100% !important;
  position: relative !important;
  margin: 0 auto !important;
}
.bw-social-share .rrssb-buttons li.small a .rrssb-icon svg {
  display: block;
  width: 70% !important;
  height: 70% !important;
  margin: 0 auto;
  position: relative;
  top: 5px;
}

/* Tiny-Layout: kompakter, falls aktiv */
.bw-social-share .rrssb-buttons.tiny-format {
  height: 22px;
}

/* Exakte Höhen-Anpassung für Text-Buttons zwischen 575px und 720px */
@media (max-width: 720px) and (min-width: 575px) {
  .bw-social-share .rrssb-buttons.large-format,
  .bw-social-share .rrssb-buttons.large-format li {
    height: 44px !important; /* Exakt gleiche Höhe wie icon-only Buttons (var(--button-size, 44px)) */
  }

  .bw-social-share .rrssb-buttons.large-format li a {
    padding: 0 0 0 12% !important; /* Kein vertikales Padding */
    height: 44px !important; /* Explizite Höhe gleich dem Container */
    line-height: 44px !important; /* Line-height = Höhe für perfekte vertikale Zentrierung */
    display: block !important; /* Block statt flex für line-height Zentrierung */
    box-sizing: border-box !important;
  }
}

/* Reduziertes padding-bottom für Text-Buttons zwischen 465px und 574px */
@media (max-width: 574px) and (min-width: 465px) {
  .bw-social-share .rrssb-buttons.large-format li a {
    padding-bottom: 2px !important; /* Deutlich reduziertes bottom-padding */
  }
}

/* Mobile-Optimierungen: Layout wird hauptsächlich per JavaScript gehandhabt */
@media (max-width: 720px) {
  .bw-social-share .rrssb-buttons.large-format li a {
    padding-left: 42px; /* Kleinere Buttons = weniger Icon-Platz */
    font-size: 14px; /* Fallback, wird von JS überschrieben */
  }

  /* gleiche Höhe für Text- und Icon-Buttons */
  .bw-social-share .rrssb-buttons.large-format,
  .bw-social-share .rrssb-buttons.large-format li {
    height: 42px;
  }

  .bw-social-share .rrssb-buttons.large-format li a {
    /* Padding für vertikale Zentrierung reduzieren, Icon-Spalte bleibt links (12%) */
    padding: 0 0 0 12%;
    height: 100%;
    display: flex;
    align-items: center;
    white-space: nowrap;
  }

  /* Icon in Text-Buttons auf gleiche Größe wie Icon-only skalieren */
  .bw-social-share .rrssb-buttons.large-format li a .rrssb-icon {
    height: 100%;
    padding-top: 0;
  }
  .bw-social-share .rrssb-buttons.large-format li a .rrssb-icon svg {
    width: 70%;
    height: 70%;
    position: relative;
    top: 0;
  }
}

/* Robust responsive layout for buttons */

.bw-social-share
  .rrssb-buttons.bw-social-share-buttons.bw-social-share-buttons-large
  li {
  margin-bottom: 5px;
}
.bw-social-share .rrssb-buttons .rrssb-icon svg {
  /*padding-right: 5px;*/
  margin-bottom: 3px;
}
/* @media (max-width: 460px) {
  .bw-social-share .rrssb-buttons {
    min-height: 45px;
  }
  .bw-social-share .rrssb-buttons li {
    height: 45px;
    padding-bottom: 3px;
    margin-bottom: 3px;
  }
  .bw-social-share .rrssb-buttons li .rrssb-icon a {
    padding-bottom: 3px;
  }
  .bw-social-share .rrssb-buttons .rrssb-icon svg {
    margin-bottom: 3px;
  }
} */

/* telegram */
.rrssb-buttons li.rrssb-telegram a {
  background-color: #38aae6;
}
.rrssb-buttons li.rrssb-telegram a:hover {
  background-color: #2982ae;
}
.rrssb-buttons.tiny-format li.rrssb-telegram a .rrssb-icon svg path {
  fill: #38aae6;
}
.rrssb-buttons.tiny-format
  li.rrssb-telegram
  a
  .rrssb-icon:hover
  .rrssb-icon
  svg
  path {
  fill: #2982ae;
}

/* bluesky */
.rrssb-buttons li.rrssb-bluesky a {
  background-color: #0a7aff;
}
.rrssb-buttons li.rrssb-bluesky a:hover {
  background-color: #0862cc;
}
.rrssb-buttons.tiny-format li.rrssb-bluesky a .rrssb-icon svg path {
  fill: #0a7aff;
}
.rrssb-buttons.tiny-format
  li.rrssb-tbluesky
  a
  .rrssb-icon:hover
  .rrssb-icon
  svg
  path {
  fill: #0862cc;
}

/* mastodon */
.rrssb-buttons li.rrssb-mastodon a {
  background-color: #6364ff;
}
.rrssb-buttons li.rrssb-mastodon a:hover {
  background-color: #4f50cc;
}
.rrssb-buttons.tiny-format li.rrssb-mastodon a .rrssb-icon svg path {
  fill: #6364ff;
}
.rrssb-buttons.tiny-format
  li.rrssb-mastodon
  a
  .rrssb-icon:hover
  .rrssb-icon
  svg
  path {
  fill: #4f50cc;
}
