/* ============================================================
   SEOGEO Performance — Feste Blog-Werbebanner (640 × 213)
   Bild-Banner nach Vorbild der Match-Me-Medical-Beispiele.
   Eigenständig & kollisionsfrei: alle Klassen mit .adb…
   Als PNG exportierbar (feste Pixelmaße).
   ============================================================ */

.adb {
  --adb-dark:  var(--color-dark-1, #0D2B1A);
  --adb-dark2: var(--color-dark-2, #1B7A4A);
  --adb-neon:  var(--color-neon-1, #3DE029);
  --adb-neon2: var(--color-neon-2, #00FF00);
  --adb-light: var(--color-light-3, #EDFAEB);
  --adb-light2:var(--color-light-2, #D4F5D4);
  --adb-line:  var(--color-light-1, #B8F5B0);
  --adb-muted: var(--color-muted, #4a5b54);
  --adb-head:  var(--font-headline, "Archivo Black", system-ui, sans-serif);
  --adb-body:  var(--font-body, "Inter", system-ui, sans-serif);

  box-sizing: border-box;
  position: relative;
  width: 640px;
  height: 213px;
  overflow: hidden;
  border-radius: 14px;
  background: #fff;
  background-image: radial-gradient(circle, rgba(13,43,26,.07) 1px, transparent 1px);
  background-size: 18px 18px;
  font-family: var(--adb-body);
  display: flex;
  box-shadow: var(--shadow-sm, 0 2px 8px rgba(13,43,26,.08));
  border: 1px solid var(--adb-line);
}
.adb *, .adb *::before, .adb *::after { box-sizing: border-box; }

/* ---- Textspalte (links) ---- */
.adb__text {
  position: relative; z-index: 3;
  flex: 1 1 auto;
  padding: 13px 12px 13px 20px;
  display: flex; flex-direction: column;
  min-width: 0;
}
.adb__eyebrow {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--adb-head);
  font-size: 9.5px; letter-spacing: .14em; text-transform: uppercase;
  color: var(--adb-dark2); margin-bottom: 4px;
}
.adb__eyebrow img { height: 13px; width: auto; display: block; }

.adb__headline {
  font-family: var(--adb-head);
  font-size: 21px; line-height: 1.03; letter-spacing: -.015em;
  color: var(--adb-dark); margin: 0 0 4px; max-width: 23ch;
}
.adb__headline .hl {
  color: var(--adb-dark2); white-space: nowrap;
  box-shadow: inset 0 -.26em 0 var(--adb-neon);   /* Neon-Marker unter Akzentwort */
  -webkit-box-decoration-break: clone; box-decoration-break: clone;
  padding: 0 .02em;
}
.adb__sub {
  font-family: var(--adb-body); font-weight: 600;
  font-size: 11px; line-height: 1.18; color: var(--adb-muted);
  margin: 0 0 6px; max-width: none;
}

/* ---- Bullets ---- */
.adb__list { list-style: none; margin: 0 0 7px; padding: 0; display: grid; gap: 3.5px; }
.adb__list li {
  position: relative; padding-left: 20px;
  font-size: 10.8px; font-weight: 600; line-height: 1.2; color: var(--adb-dark);
}
.adb__list li::before {
  content: ""; position: absolute; left: 0; top: 50%; transform: translateY(-50%);
  width: 15px; height: 15px; border-radius: 50%;
  background-color: var(--adb-neon);
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230D2B1A' stroke-width='4.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='5 13 10 18 19 7'/></svg>");
  background-position: center; background-repeat: no-repeat; background-size: 64%;
  border: 1.5px solid var(--adb-dark);
}

/* ---- CTA-Pill ---- */
.adb__cta {
  margin-top: auto;
  display: inline-flex; align-items: center; gap: 7px; align-self: flex-start;
  font-family: var(--adb-head); font-size: 11px; letter-spacing: .005em;
  color: var(--adb-dark); background: var(--adb-neon);
  padding: 8px 14px; border-radius: 999px;
  border: 2px solid var(--adb-dark);
  box-shadow: 0 3px 0 var(--adb-dark);
  text-decoration: none; line-height: 1;
  transition: transform .12s ease, box-shadow .15s ease, background-color .15s ease;
}
.adb__cta:hover { background: var(--adb-neon2); color: var(--adb-dark); transform: translateY(-2px); box-shadow: 0 5px 0 var(--adb-dark); }
.adb__cta svg { width: 14px; height: 14px; }

/* ---- Fotospalte (rechts) mit Bogen-Trennung ---- */
.adb__media {
  position: relative; flex: 0 0 228px; width: 228px;
  background: var(--adb-light);
  overflow: hidden;
}
.adb__media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center top; }
/* weißer Bogen, der ins Foto schneidet (mimt die Beispiele) */
.adb__media::before {
  content: ""; position: absolute; top: -20%; left: -64px; z-index: 2;
  width: 120px; height: 140%;
  background: #fff;
  border-radius: 0 100% 100% 0 / 0 50% 50% 0;
}
/* Neon-Deko-Kreis hinter dem Foto */
.adb__media::after {
  content: ""; position: absolute; z-index: 1; bottom: -46px; right: -46px;
  width: 150px; height: 150px; border-radius: 50%;
  background: var(--adb-neon); opacity: .16;
}

/* ---- Eckbadge „100% KOSTENLOS" ---- */
.adb__badge {
  position: absolute; top: 12px; right: 12px; z-index: 5;
  width: 60px; height: 60px; border-radius: 50%;
  background: var(--adb-neon); color: var(--adb-dark);
  border: 2px solid var(--adb-dark);
  box-shadow: 0 3px 0 var(--adb-dark);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center; transform: rotate(8deg);
}
.adb__badge b { font-family: var(--adb-head); font-size: 15px; line-height: 1; }
.adb__badge span { font-family: var(--adb-head); font-size: 7.5px; letter-spacing: .08em; text-transform: uppercase; margin-top: 1px; }

/* ---- Dunkle Banner-Variante ---- */
.adb--dark {
  background: var(--adb-dark);
  background-image: radial-gradient(circle, rgba(255,255,255,.05) 1px, transparent 1px);
  border-color: var(--adb-dark);
}
.adb--dark .adb__eyebrow { color: var(--adb-neon); }
.adb--dark .adb__headline { color: #fff; }
.adb--dark .adb__headline .hl { color: var(--adb-neon); box-shadow: none; }
.adb--dark .adb__sub { color: var(--adb-light2); }
.adb--dark .adb__list li { color: #fff; }
.adb--dark .adb__list li::before { border-color: #fff; }
.adb--dark .adb__media { background: #0a2316; }
.adb--dark .adb__media::before { background: var(--adb-dark); }

/* ============================================================
   SCHUTZ-REGELN — verhindern, dass Artikel-CSS (z. B. .prose h2,
   .prose a) ins Banner durchschlägt. Höhere Spezifität (.adb …)
   gewinnt gegen .prose h2 / .prose a. NICHT entfernen.
   ============================================================ */
.adb .adb__headline {
  font-family: var(--adb-head);
  font-size: 21px; line-height: 1.03; letter-spacing: -.015em;
  margin: 0 0 4px; color: var(--adb-dark);
}
.adb--dark .adb__headline { color: #fff; }
.adb .adb__sub { font-size: 11px; line-height: 1.18; margin: 0 0 6px; }
.adb a.adb__cta,
.adb a.adb__cta:hover,
.adb a.adb__cta:visited {
  text-decoration: none; color: var(--adb-dark);
}

/* ============================================================
   EMBED-WRAPPER — skaliert das feste 640×213-Banner proportional
   in jede Artikelspalte (auch < 640px). Höhe + Skalierung setzt
   das Mini-Skript ad-banner.js per ResizeObserver (--adb-scale).
   Im Artikel: <div class="adb-embed"> … <aside class="adb"> … </div>
   ============================================================ */
.adb-embed {
  width: 100%;
  max-width: 760px;           /* volle Artikelspalte — so breit wie die Bilder */
  margin: 2.25rem auto;       /* Luft im Lesefluss */
  overflow: hidden;           /* Sicherheitsnetz, falls JS fehlt */
}
.adb-embed .adb {
  transform-origin: top left;
  transform: scale(var(--adb-scale, 1));
}
