.hepo-blitzer-embed {
  position: relative;
  overflow: hidden;
  padding: 24px;
  border: 1px solid #d7d0c8;
  border-radius: 18px;
  background:
    radial-gradient(circle at top right, rgba(233, 89, 43, 0.12), transparent 34%),
    linear-gradient(180deg, #fffaf5 0%, #f4efe7 100%);
  color: #241f1a;
  box-shadow: 0 18px 40px rgba(36, 31, 26, 0.08);
}

.hepo-blitzer-embed__hero {
  margin-bottom: 18px;
}

.hepo-blitzer-embed__eyebrow {
  margin: 0 0 6px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 12px;
  color: #8a4b2f;
}

.hepo-blitzer-embed h2,
.hepo-blitzer-embed h3 {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
}

.hepo-blitzer-embed h2 {
  font-size: clamp(28px, 4vw, 42px);
  line-height: 1.05;
}

.hepo-blitzer-embed__meta {
  margin: 10px 0 0;
  color: #6c6259;
}

.hepo-blitzer-embed__intro,
.hepo-blitzer-embed__closing,
.hepo-blitzer-embed__fallback,
.hepo-blitzer-embed__fixed {
  font-size: 17px;
  line-height: 1.6;
}

.hepo-blitzer-embed__intro {
  margin: 0 0 18px;
  font-weight: 600;
}

.hepo-blitzer-embed__card {
  margin: 0 0 18px;
  padding: 18px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.82);
  border: 1px solid rgba(138, 75, 47, 0.12);
}

.hepo-blitzer-embed__card--locations,
#standorte.hepo-blitzer-location-box {
  background: linear-gradient(180deg, #eef8ff 0%, #dff0ff 100%);
  border: 1px solid #bfdcf1;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.75);
}

#standorte.hepo-blitzer-location-box {
  margin: 20px 0;
  padding: 18px 20px;
  border-radius: 16px;
}

#standorte.hepo-blitzer-location-box h3 {
  margin: 0 0 14px;
  color: #0f4c75;
}

#standorte.hepo-blitzer-location-box ul {
  margin: 0;
  padding-left: 22px;
  display: grid;
  gap: 8px;
}

.hepo-blitzer-embed__card h3 {
  margin-bottom: 14px;
  font-size: 22px;
  color: #0f4c75;
}

.hepo-blitzer-embed__list {
  margin: 0;
  padding-left: 20px;
  display: grid;
  gap: 10px;
}

.hepo-blitzer-embed__list li::marker {
  color: #1174b8;
}

.hepo-blitzer-embed__closing {
  margin: 0 0 16px;
  color: #3c332d;
}

.hepo-blitzer-embed__fixed {
  padding-top: 14px;
  border-top: 1px solid rgba(36, 31, 26, 0.12);
}

.hepo-blitzer-empty {
  padding: 16px;
  border: 1px dashed #c5bdb4;
  background: #f7f3ee;
}

.hepo-blitzer-fab {
  position: fixed;
  top: calc(50% - 90px);
  left: 0;
  transform: translateY(-50%);
  z-index: 2147483646;
  opacity: 0;
  animation: hepoBlitzerFabFadeIn 320ms ease forwards;
}

.hepo-blitzer-fab,
.hepo-blitzer-fab * {
  box-sizing: border-box;
}

.hepo-blitzer-fab__link {
  width: 75px;
  height: 75px;
  min-width: 75px;
  min-height: 75px;
  max-width: 75px;
  max-height: 75px;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex: 0 0 auto !important;
  cursor: pointer;
  overflow: visible !important;
  padding: 0 !important;
}

.hepo-blitzer-fab__image {
  width: 100% !important;
  height: 100% !important;
  min-width: 100% !important;
  min-height: 100% !important;
  max-width: 100% !important;
  max-height: 100% !important;
  object-fit: contain !important;
  display: block !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
}

@keyframes hepoBlitzerFabFadeIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

@media (max-width: 640px) {
  .hepo-blitzer-embed {
    padding: 18px;
    border-radius: 14px;
  }

  .hepo-blitzer-embed__card {
    padding: 14px;
  }

  .hepo-blitzer-fab {
    top: calc(50% - 90px);
  }

  .hepo-blitzer-fab__link {
    width: calc(75px * (var(--hepo-blitzer-fab-scale-mobile, 80) / 100));
    height: calc(75px * (var(--hepo-blitzer-fab-scale-mobile, 80) / 100));
    min-width: calc(75px * (var(--hepo-blitzer-fab-scale-mobile, 80) / 100));
    min-height: calc(75px * (var(--hepo-blitzer-fab-scale-mobile, 80) / 100));
    max-width: calc(75px * (var(--hepo-blitzer-fab-scale-mobile, 80) / 100));
    max-height: calc(75px * (var(--hepo-blitzer-fab-scale-mobile, 80) / 100));
  }

  .hepo-blitzer-fab.hide-mobile {
    display: none;
  }
}

@media (min-width: 641px) {
  .hepo-blitzer-fab.hide-desktop {
    display: none;
  }
}
