/* =========================================================
   Odi-Builder – Widgets CSS  (Frontend & Backend identisch)
   Nutzt :root-Variablen (werden vom Plugin gesetzt)
   ========================================================= */

:root {
  --odib-brand-color: var(--wp--preset--color--primary, #111111);

  /* Palette mit Fallbacks */
  --odib-primary: #c00000;
  --odib-secondary: var(--odib-brand-color);

	--odib-text: #111111;
	--odib-bg: #ffffff;
	--odib-border: #dddddd;
    --odib-silver: #f2f2f2;

  /* Links */
  --odib-link: var(--odib-link, #111111);
  --odib-link-hover: var(--odib-link-hover, #111111);

/* Buttons */
--odib-btn-fg: #ffffff; /* Textfarbe */
--odib-btn-bg: #c00000; /* Standard-Farbe */
--odib-btn-gradient: linear-gradient(135deg, #c00000, #000000);

  /* States / Shadow */
  --odib-focus: rgba(0,0,0,.2);
  --odib-shadow: 0 6px 18px rgba(0,0,0,.04);
  --odib-btn-shadow-h: 0 6px 16px rgba(0,0,0,.12);
  --odib-btn-shadow-a: 0 2px 8px rgba(0,0,0,.12);

  /* Logo */
  --odib-logo-url: var(--odib-logo-url, url('/pfad/zum/logo.svg'));
}

/* 🎨 Grundfarbe – globale Textfarbe */
.odib-widget { color: var(--odib-text); }
/* 🎨 Fix: Inline-Editorfarben respektieren */

/* ✅ Editor-Farbe gewinnt */
.odib-title[style*="color"],
.odib-title-wrap[style*="color"],
.odib-text[style*="color"],
.odib-block-rt[style*="color"],
.odib-text--blocks[style*="color"] {
  color: unset !important; /* Entfernt Theme-Überschreibung, aber belässt Inline-Styles */
}

/* 🔁 Fallback nur, wenn KEINE Editor-Farbe gesetzt wurde */
.odib-title:not([style*="color"]),
.odib-title-wrap:not([style*="color"]),
.odib-text:not([style*="color"]),
.odib-block-rt:not([style*="color"]),
.odib-text--blocks:not([style*="color"]) {
  color: var(--odib-text, #222);
}

/* 📰 Headlines erben immer currentColor */
.odib-text h1,
.odib-text h2,
.odib-text h3 {
  color: currentColor;
}
/* ---------------------------
   Basiskomponenten & Helpers
--------------------------- */

.odib-widget {
  color: var(--odib-text);
  font: inherit;
  line-height: 1.5;
}

.odib-card {
  width: 100%;
  max-width: 1040px;
  margin: 0 auto;
  background: var(--odib-bg);
  border: 1px solid var(--odib-border);
  border-radius: 14px;
  box-shadow: var(--odib-shadow);
  overflow: hidden;
}

.odib-section--silver { background: var(--odib-silver); }

/* Spacing between widgets rendered via [odib-cat] */
.odib-category-wrap { display:flex; flex-direction:column; gap: var(--odib-cat-gap, 32px); }
.odib-category-wrap > .odib-widget { margin: 0; }
.odib-widget + .odib-widget { margin-top: var(--odib-cat-gap, 32px); }

/* Category-level styling options */
.odib-category-wrap.odib-cat-card-border-off .odib-card {
  border-color: transparent;
}
.odib-category-wrap.odib-cat-card-border-custom .odib-card {
  border-color: var(--odib-cat-card-border-color, var(--odib-border));
}
.odib-category-wrap.odib-cat-clean .odib-card { box-shadow: none; }
.odib-category-wrap.odib-cat-no-btn-hover .odib-btn:hover,
.odib-category-wrap.odib-cat-no-btn-hover .odib-btn--secondary:hover {
  box-shadow: none;
}
.odib-category-wrap.odib-cat-lines > .odib-widget { position: relative; }
.odib-category-wrap.odib-cat-lines > .odib-widget:not(:first-child)::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: calc(-1 * var(--odib-cat-gap, 32px) / 2);
  height: 1px;
  background: var(--odib-cat-line-color, rgba(0,0,0,.15));
}
.odib-category-wrap.odib-cat-line-dashed > .odib-widget:not(:first-child)::before {
  background: none;
  border-top: 1px dashed var(--odib-cat-line-color, rgba(0,0,0,.15));
  height: 0;
}
.odib-category-wrap.odib-cat-line-glassy > .odib-widget:not(:first-child)::before {
  background: linear-gradient(90deg, transparent, var(--odib-cat-line-color, rgba(255,255,255,.55)), transparent);
}

/* Extended category design system (keeps theme defaults unless custom enabled) */
.odib-category-wrap.odib-cat-container-bg {
  position: relative;
  padding: var(--odib-cat-container-padding, 0px);
  border-radius: calc(var(--odib-cat-border-radius, 14px) + 2px);
  background: var(--odib-cat-container-bg-color, transparent);
}
.odib-category-wrap.odib-cat-container-bg.odib-cat-container-gradient {
  background: linear-gradient(135deg, var(--odib-cat-container-bg-color, #f8fafc), var(--odib-cat-container-bg-color2, #e2e8f0));
}
.odib-category-wrap.odib-cat-container-bg.odib-cat-container-transparent {
  background: transparent;
}
.odib-category-wrap.odib-cat-container-bg.odib-cat-container-glassy {
  backdrop-filter: blur(var(--odib-cat-container-blur, 0px));
  -webkit-backdrop-filter: blur(var(--odib-cat-container-blur, 0px));
  border: 1px solid rgba(255,255,255,0.45);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.5), 0 12px 30px rgba(15,23,42,.12);
}

.odib-category-wrap.odib-cat-card-design-custom .odib-card {
  border-radius: var(--odib-cat-card-radius, 14px);
}
.odib-category-wrap.odib-cat-card-bg-custom .odib-card {
  background: var(--odib-cat-card-bg-color, var(--odib-bg));
}
.odib-category-wrap.odib-cat-card-bg-transparent .odib-card {
  background: transparent;
}
.odib-category-wrap.odib-cat-card-shadow-none .odib-card { box-shadow: none; }
.odib-category-wrap.odib-cat-card-shadow-soft .odib-card { box-shadow: 0 10px 26px rgba(15,23,42,.10); }
.odib-category-wrap.odib-cat-card-shadow-strong .odib-card { box-shadow: 0 18px 40px rgba(15,23,42,.22); }
.odib-category-wrap.odib-cat-card-design-custom .odib-card.odib-cta,
.odib-category-wrap.odib-cat-card-design-custom .odib-card.odib-feature {
  padding: var(--odib-cat-card-padding, 24px);
}

.odib-category-wrap.odib-cat-typography-custom .odib-title {
  font-size: var(--odib-cat-title-size, inherit);
  font-weight: var(--odib-cat-title-weight, inherit);
  line-height: var(--odib-cat-title-lh, inherit);
}
.odib-category-wrap.odib-cat-typography-custom .odib-text,
.odib-category-wrap.odib-cat-typography-custom .odib-text p,
.odib-category-wrap.odib-cat-typography-custom .odib-text li {
  font-size: var(--odib-cat-text-size, inherit);
  font-weight: var(--odib-cat-text-weight, inherit);
  line-height: var(--odib-cat-text-lh, inherit);
}
.odib-category-wrap.odib-cat-title-color-custom .odib-title { color: var(--odib-cat-title-color, inherit); }
.odib-category-wrap.odib-cat-text-color-custom .odib-text,
.odib-category-wrap.odib-cat-text-color-custom .odib-text p,
.odib-category-wrap.odib-cat-text-color-custom .odib-text li { color: var(--odib-cat-text-color, inherit); }

.odib-category-wrap.odib-cat-button-custom .odib-btn {
  border-radius: var(--odib-cat-btn-radius, var(--odib-btn-radius, 10px));
  background: var(--odib-cat-btn-bg, var(--odib-btn-fill, var(--odib-btn-gradient)));
  color: var(--odib-cat-btn-text, var(--odib-btn-fg, #fff)) !important;
  border: 1px solid var(--odib-cat-btn-border, transparent);
}
.odib-category-wrap.odib-cat-button-custom .odib-btn:hover {
  background: var(--odib-cat-btn-hover, var(--odib-cat-btn-bg, var(--odib-btn-fill, var(--odib-btn-gradient))));
}
.odib-category-wrap.odib-cat-link-custom .odib-text a:not(.odib-btn),
.odib-category-wrap.odib-cat-link-custom .odib-cta a:not(.odib-btn) {
  color: var(--odib-cat-link, var(--odib-link));
}
.odib-category-wrap.odib-cat-link-custom .odib-text a:not(.odib-btn):hover,
.odib-category-wrap.odib-cat-link-custom .odib-cta a:not(.odib-btn):hover {
  color: var(--odib-cat-link-hover, var(--odib-link-hover));
}

.odib-category-wrap.odib-cat-hover .odib-card {
  transition: transform var(--odib-cat-hover-duration, 260ms) ease, box-shadow var(--odib-cat-hover-duration, 260ms) ease, border-color var(--odib-cat-hover-duration, 260ms) ease;
}
.odib-category-wrap.odib-cat-hover.odib-cat-hover-lift .odib-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 42px rgba(15,23,42,.2);
}
.odib-category-wrap.odib-cat-hover.odib-cat-hover-glow .odib-card:hover {
  box-shadow: 0 0 0 2px rgba(59,130,246,.25), 0 18px 42px rgba(37,99,235,.28);
}
.odib-category-wrap.odib-cat-hover.odib-cat-hover-scale .odib-card:hover {
  transform: scale(1.02);
  box-shadow: 0 16px 34px rgba(15,23,42,.18);
}
.odib-category-wrap.odib-cat-hover.odib-cat-hover-tilt .odib-card:hover {
  transform: translateY(-4px) rotate(-1.5deg);
  box-shadow: 0 18px 38px rgba(15,23,42,.20);
}

/* Typografie */
.odib-text h1, .odib-text h2, .odib-text h3 {
  margin: 0 0 .5rem;
  line-height: 1.2;
  color: currentColor;
}
.odib-text p { margin: 0 0 .75rem; }

/* Links erben – Buttons explizit ausnehmen */
.odib-text a:not(.odib-btn),
.odib-cta a:not(.odib-btn) {
  color: var(--odib-link);
  text-decoration: none;
}
.odib-text a:not(.odib-btn):hover,
.odib-cta a:not(.odib-btn):hover {
  color: var(--odib-link-hover);
  /*text-decoration: underline;*/
}
.odib-widget a:focus,
.odib-cta a:focus {
  outline: 2px solid var(--odib-focus);
  outline-offset: 2px;
}

/* Utilities – Ausrichtungen */
.odib-align-left   { text-align: left; }
.odib-align-center { text-align: center; }
.odib-align-right  { text-align: right; }
/* 🔧 Ausrichtung für Button-Gruppen */
.odib-align-left.odib-actions   { justify-content: flex-start; }
.odib-align-center.odib-actions { justify-content: center; }
.odib-align-right.odib-actions  { justify-content: flex-end; }

/* Container-JUSTIFY (für äußere Ausrichtung) */
.odib-justify { display: flex; }
.odib-justify--left   { justify-content: flex-start; }
.odib-justify--center { justify-content: center; }
.odib-justify--right  { justify-content: flex-end; }
/* =========================
   Media/Sticker Alignment Fix (final)
   ========================= */

/* Basis: Container im Grid immer Block-Level */
.odib-cta__grid .odib-media {
  display: flex;
  flex-direction: column;
  gap: .75rem;
  align-items: flex-start;
  justify-content: flex-start; /* Default: top/left */
  justify-self: start;         /* Default: left */
  width: 100%;                 /* darf ganze Spalte nutzen */
}

/* Modifikatoren erzwingen Position */
.odib-cta__grid .odib-media.odib-align-left {
  align-items: flex-start !important;
  justify-self: start !important;
  text-align: left;
}
.odib-cta__grid .odib-media.odib-align-center {
  align-items: center !important;
  justify-self: center !important;
  text-align: center;
}
.odib-cta__grid .odib-media.odib-align-right {
  align-items: flex-end !important;
  justify-self: end !important;
  text-align: right;
}

/* Bilder/Stickers skalieren sauber */
.odib-media img { 
  display: block; 
  max-width: 100%; 
  height: auto; 
  object-fit: contain;
}
.odib-media .odib-sticker { line-height: 1; }
/* Medien (Bild/Sticker) */
.odib-media img {
  max-width: 100%;
  height: auto;
  display: block;
  border-radius: 12px;
}
.odib-media-label-wrap {
  display:flex;
  gap: var(--odib-label-gap, .6rem);
  align-items:center;
  position: relative;
}
.odib-media-label-wrap.pos-left { flex-direction: row; }
.odib-media-label-wrap.pos-right { flex-direction: row-reverse; }
.odib-media-label-wrap.pos-above { flex-direction: column; align-items:flex-start; }
.odib-media-label-wrap.pos-below { flex-direction: column-reverse; align-items:flex-start; }
.odib-media-label-wrap.align-left { align-items:flex-start; }
.odib-media-label-wrap.align-center { align-items:center; }
.odib-media-label-wrap.align-right { align-items:flex-end; }
.odib-media-label-wrap.is-overlay { display:block; }
.odib-media-label-wrap.is-overlay > .odib-media-label { position:absolute; z-index:2; }
.odib-media-label-wrap.is-overlay.pos-above > .odib-media-label { top: var(--odib-label-offset, 8px); left: var(--odib-label-offset, 8px); }
.odib-media-label-wrap.is-overlay.pos-below > .odib-media-label { bottom: var(--odib-label-offset, 8px); left: var(--odib-label-offset, 8px); }
.odib-media-label-wrap.is-overlay.pos-left > .odib-media-label { left: var(--odib-label-offset, 8px); top: 50%; transform: translateY(-50%); }
.odib-media-label-wrap.is-overlay.pos-right > .odib-media-label { right: var(--odib-label-offset, 8px); top: 50%; transform: translateY(-50%); }
.odib-media-label-wrap.is-overlay.pos-above.align-center > .odib-media-label,
.odib-media-label-wrap.is-overlay.pos-below.align-center > .odib-media-label { left:50%; transform: translate(-50%,0); right:auto; }
.odib-media-label-wrap.is-overlay.pos-above.align-right > .odib-media-label,
.odib-media-label-wrap.is-overlay.pos-below.align-right > .odib-media-label { right: var(--odib-label-offset, 8px); left:auto; }
.odib-media-label {
  font-size:12px;
  padding:4px 8px;
  border-radius:8px;
  background: var(--odib-label-bg, #111);
  color: var(--odib-label-color, #fff);
  line-height:1.2;
  white-space:nowrap;
}
.odib-media-label.odib-label--pill { border-radius:999px; }
.odib-media-label.odib-label--outline { background: transparent; border:1px solid currentColor; }
.odib-media-label.odib-label--glass { backdrop-filter: blur(6px); border:1px solid rgba(255,255,255,0.25); }
.odib-price-wrap { display:flex; margin:6px 0 10px; }
.odib-price-wrap.odib-align-left { justify-content:flex-start; }
.odib-price-wrap.odib-align-center { justify-content:center; }
.odib-price-wrap.odib-align-right { justify-content:flex-end; }
.odib-price-label { display:inline-flex; align-items:center; gap:6px; }
.odib-meter-wrap { display:flex; margin:6px 0 10px; width:100%; }
.odib-meter-wrap.odib-align-left { justify-content:flex-start; }
.odib-meter-wrap.odib-align-center { justify-content:center; }
.odib-meter-wrap.odib-align-right { justify-content:flex-end; }
.odib-cta-meter { display:grid; gap:6px; width:min(100%, 340px); }
.odib-cta-meter--grid { grid-template-columns:repeat(auto-fit,minmax(88px,112px)); }
.odib-cta-meter--list { grid-template-columns:1fr; }
.odib-cta-meter--tiny { gap:4px; }
.odib-cta-meter--compact { gap:5px; }
.odib-cta-meter--cozy { gap:6px; }
.odib-cta-meter--large { gap:8px; }
.odib-cta-meter--xl { gap:10px; }
.odib-cta-meter-item { display:grid; gap:5px; min-width:0; padding:8px; border-radius:14px; border:1px solid rgba(148,163,184,.2); background:rgba(255,255,255,.12); backdrop-filter:blur(8px); }
.odib-cta-meter-item--tiny { padding:5px; gap:3px; border-radius:10px; }
.odib-cta-meter-item--compact { padding:6px; gap:4px; border-radius:12px; }
.odib-cta-meter-item--cozy { padding:8px; gap:5px; border-radius:14px; }
.odib-cta-meter-item--large { padding:10px; gap:6px; border-radius:16px; }
.odib-cta-meter-item--xl { padding:12px; gap:7px; border-radius:18px; }
.odib-cta-meter-item--chips { display:flex; align-items:center; justify-content:space-between; gap:6px; flex-wrap:wrap; border-radius:999px; }
.odib-cta-meter-item--chips .odib-cta-meter-track { display:none; }
.odib-cta-meter-item--cards { aspect-ratio:1 / 1; align-content:space-between; }
.odib-cta-meter-item--cards .odib-cta-meter-value { font-size:clamp(.9rem,1.2vw,1.2rem); }
.odib-cta-meter-top { display:flex; align-items:flex-start; justify-content:space-between; gap:6px; }
.odib-cta-meter-label { font-size:10px; font-weight:800; line-height:1.1; letter-spacing:.01em; color:var(--odib-text,#0f172a); }
.odib-cta-meter-value { font-size:.86rem; line-height:1; white-space:nowrap; color:var(--odib-text,#0f172a); }
.odib-cta-meter-track { position:relative; overflow:hidden; height:5px; border-radius:999px; background:rgba(148,163,184,.16); border:1px solid rgba(148,163,184,.14); }
.odib-cta-meter-fill { display:block; height:100%; border-radius:999px; background:var(--odib-btn-gradient, linear-gradient(135deg,#0f172a,#334155)); box-shadow:0 4px 10px rgba(15,23,42,.10); }
.odib-sticker {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: .6rem .9rem;
  border-radius: 999px;
  background: var(--odib-silver);
  font-weight: 600;
}
/* ---------------------------
   Buttons (mit eigener Textfarbe)
--------------------------- */
.odib-btn,
a.odib-btn,
button.odib-btn {
  background: var(--odib-btn-fill, var(--odib-btn-gradient));
  color: var(--odib-btn-fg, #fff) !important;
  border: var(--odib-btn-border, 0);
  border-radius: var(--odib-btn-radius, 10px);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  padding: .7rem 1rem;
  text-decoration: none;
  cursor: pointer;
  white-space: nowrap;
  transition: transform .15s ease, box-shadow .15s ease;
}

.odib-btn--secondary {
  background: var(--odib-btn2-fill, var(--odib-btn2-gradient, transparent));
  color: var(--odib-btn2-fg, #111) !important;
  border: var(--odib-btn2-border, 1px solid rgba(15,23,42,.18));
  box-shadow: none;
  border-radius: var(--odib-btn2-radius, var(--odib-btn-radius, 10px));
}

.odib-btn--secondary:hover {
  transform: translateY(-1px);
  box-shadow: var(--odib-btn-shadow-h);
}

.odib-btn:hover {
  transform: translateY(-1px);
  box-shadow: var(--odib-btn-shadow-h);
}

.odib-btn:active {
  transform: translateY(0);
  box-shadow: var(--odib-btn-shadow-a);
}

.odib-btn:focus-visible {
  outline: 2px solid var(--odib-focus);
  outline-offset: 2px;
}

.odib-actions .odib-btn {
  transform: scale(var(--odib-btn-scale, 1));
  transform-origin: center center;
}
.odib-actions.odib-actions--custom { justify-content: flex-start; }
.odib-actions { display:flex; flex-wrap: wrap; gap: 12px 14px; }
.odib-btn--align-left { margin-right: auto; }
.odib-btn--align-right { margin-left: auto; }
.odib-btn--align-center { margin-left: auto; margin-right: auto; }
.odib-btn--align-full { width: 100%; flex: 1 1 100%; }


/* ---------------------------
   CTA Layouts (image_pos)
--------------------------- */


.odib-widget.no-media .odib-cta__grid { display:block; }
.odib-widget.no-media .odib-media { display:none !important; }

/* Card innen paddings */
.odib-card.odib-cta { 
  padding-inline: var(--odib-card-pad, 24px);
  width:100%;
  max-width: var(--odib-card-max,1200px);
  margin-inline:auto;
  box-sizing: border-box;
}

/* Grid padding */
.odib-cta__grid {
  display: grid;
  grid-template-columns: minmax(240px,420px) minmax(0,1fr);
  gap: 1rem 1.25rem;
  align-items: center;
  padding-inline: var(--odib-grid-pad, 12px);
}
.odib-cta { padding: 1.25rem; }

.odib-cta--left  .odib-cta__grid,
.odib-cta--right .odib-cta__grid { grid-template-columns: 1fr 1fr; }

.odib-cta--top .odib-cta__grid,
.odib-cta--bottom .odib-cta__grid { grid-template-columns: 1fr; }

/* Order */
.odib-cta--left  .odib-media   { order: 1; }
.odib-cta--left  .odib-content { order: 2; }
.odib-cta--right .odib-media   { order: 2; }
.odib-cta--right .odib-content { order: 1; }
.odib-cta--top   .odib-media   { order: 1; }
.odib-cta--top   .odib-content { order: 2; }
.odib-cta--bottom .odib-media  { order: 2; }
.odib-cta--bottom .odib-content{ order: 1; }

/* Bereiche */
.odib-cta__top-actions    { margin: 0 0 .75rem; }
.odib-cta__bottom-actions { margin: .75rem 0 0; }
.odib-cta__image-actions  { margin-top: .75rem; }
.odib-cta__content-actions{ margin-top: .75rem; }
.odib-cta__top-actions,
.odib-cta__bottom-actions,
.odib-cta__image-actions,
.odib-cta__content-actions { width:100%; }
.odib-cta__content-actions--inline,
.odib-cta__image-actions--inline {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.odib-cta__content-actions--inline > .odib-price-wrap,
.odib-cta__image-actions--inline > .odib-price-wrap,
.odib-cta__content-actions--inline > .odib-meter-wrap,
.odib-cta__image-actions--inline > .odib-meter-wrap {
  margin: 0;
  width: auto;
}
.odib-cta__content-actions--inline > .odib-meter-wrap .odib-cta-meter,
.odib-cta__image-actions--inline > .odib-meter-wrap .odib-cta-meter {
  width: auto;
  max-width: 320px;
}
.odib-cta__content-actions--inline > .odib-actions,
.odib-cta__image-actions--inline > .odib-actions {
  margin-top: 0;
}

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

@media (max-width: 1024px) {
  .odib-category-wrap.odib-cat-responsive {
    gap: var(--odib-cat-gap-tablet, var(--odib-cat-gap, 24px));
  }
  .odib-category-wrap.odib-cat-responsive > .odib-widget + .odib-widget {
    margin-top: var(--odib-cat-gap-tablet, var(--odib-cat-gap, 24px));
  }
  .odib-category-wrap.odib-cat-responsive.odib-cat-card-design-custom .odib-card {
    border-radius: var(--odib-cat-card-radius-tablet, var(--odib-cat-card-radius, 12px));
  }
  .odib-category-wrap.odib-cat-responsive.odib-cat-card-design-custom .odib-card.odib-cta,
  .odib-category-wrap.odib-cat-responsive.odib-cat-card-design-custom .odib-card.odib-feature {
    padding: var(--odib-cat-card-padding-tablet, var(--odib-cat-card-padding, 20px));
  }
}

@media (max-width: 768px) {
  .odib-category-wrap.odib-cat-responsive {
    gap: var(--odib-cat-gap-mobile, var(--odib-cat-gap-tablet, 16px));
  }
  .odib-category-wrap.odib-cat-responsive > .odib-widget + .odib-widget {
    margin-top: var(--odib-cat-gap-mobile, var(--odib-cat-gap-tablet, 16px));
  }
  .odib-category-wrap.odib-cat-responsive.odib-cat-card-design-custom .odib-card {
    border-radius: var(--odib-cat-card-radius-mobile, var(--odib-cat-card-radius-tablet, 10px));
  }
  .odib-category-wrap.odib-cat-responsive.odib-cat-card-design-custom .odib-card.odib-cta,
  .odib-category-wrap.odib-cat-responsive.odib-cat-card-design-custom .odib-card.odib-feature {
    padding: var(--odib-cat-card-padding-mobile, var(--odib-cat-card-padding-tablet, 16px));
  }
}

@media (max-width: 1024px) {
  .odib-card { border-radius: 12px; }
}
@media (max-width: 768px) {
  .odib-cta--left  .odib-cta__grid,
  .odib-cta--right .odib-cta__grid { grid-template-columns: 1fr; }
  .odib-actions { flex-wrap: wrap; }
  .odib-btn { width: auto; }
}
@media (max-width: 480px) {
  .odib-card { border-radius: 10px; }
  .odib-cta  { padding: .9rem; }
  .odib-btn--lg { padding: .85rem 1.1rem; font-size: 1rem; }
}

/* Motion-Respect */
@media (prefers-reduced-motion: reduce) {
  .odib-btn { transition: none; }
}
@media (max-width:680px){
  .odib-cta__grid { grid-template-columns:1fr !important; }
  .odib-media { justify-self:center; }
}
/* =========================================================
   🎯 TITLE + ICON (shared: frontend & admin)
   Struktur und Ausrichtung – identisches Verhalten in allen Modi
   ========================================================= */

/* 🧱 Grundausrichtung (Standard) */
.odib-title-wrap { 
  text-align: inherit; 
}
.odib-title-wrap.odib-align-left   { text-align: left; }
.odib-title-wrap.odib-align-center { text-align: center; }
.odib-title-wrap.odib-align-right  { text-align: right; }

/* =========================================================
   🔁 INLINE-MODUS: Icon neben dem Titel (links oder rechts)
   → Gleiches Verhalten wie Block-Modus: bleibt immer zentriert
   ========================================================= */
.odib-title-wrap.odib-title--inline {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center; /* 🧭 bleibt mittig */
  gap: .5em;
  width: 100%; /* block-level für echte Zentrierung */
}

/* 🎯 Inline-Ausrichtung */
.odib-title-wrap.odib-title--inline.odib-align-left {
  align-items: flex-start;
  justify-content: flex-start;
  text-align: left;
}
.odib-title-wrap.odib-title--inline.odib-align-center {
  align-items: center;
  justify-content: center;
  text-align: center;
}
.odib-title-wrap.odib-title--inline.odib-align-right {
  align-items: flex-end;
  justify-content: flex-end;
  text-align: right;
}

/* 🔄 Reihenfolge der Elemente (Icon links/rechts) */
/* ✅ Reihenfolge unabhängig vom DOM – robust in Export & Frontend */
.odib-title--inline .odib-title-icon { order: 0; }  /* Standard: Icon links */
.odib-title--inline .odib-title      { order: 1; }

.odib-title--inline.odib-icon-right .odib-title      { order: 0; } /* Titel zuerst */
.odib-title--inline.odib-icon-right .odib-title-icon { order: 1; } /* Icon rechts */

/* ✨ Abstände zwischen Icon und Titel */
.odib-title--inline.odib-icon-left  .odib-title-icon { margin-inline: 0 0.35em; }
.odib-title--inline.odib-icon-right .odib-title-icon { margin-inline: 0.35em 0; }

/* 🧩 Allgemeine Titel-Ausrichtung */
.odib-title-wrap.odib-title--inline .odib-title { min-width: 0; }
.odib-title { text-align: inherit; }

/* =========================================================
   ⬆️⬇️ BLOCK-MODUS: Icon über oder unter dem Titel
   ========================================================= */
.odib-title-wrap.odib-title--block {
  display: flex;
  flex-direction: column;
  gap: .35em;
}

/* 📐 Block-Ausrichtung */
.odib-title-wrap.odib-title--block.odib-align-left   { align-items: flex-start; }
.odib-title-wrap.odib-title--block.odib-align-center { align-items: center; }
.odib-title-wrap.odib-title--block.odib-align-right  { align-items: flex-end; }

/* 🧱 Abstände im Block-Modus */
.odib-title--block .odib-title-icon { margin-bottom: 0.4em; }

/* =========================================================
   💠 ICON-BASIS: Größe, Skalierung und Inhalt
   ========================================================= */
.odib-title-icon {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  width:  calc(1em * var(--odib-title-icon-scale, 1));
  height: calc(1em * var(--odib-title-icon-scale, 1));
}

/* 🖼️ Icon-Inhalt (SVG, IMG, Emoji) */
.odib-title-icon img,
.odib-title-icon svg {
  width: auto;
  height: 100%;
  display: block;
}
.odib-title-icon .emoji {
  font-size: calc(1em * var(--odib-title-icon-scale, 1));
  line-height: 1;
}

/* =========================================================
   🧾 TITEL-INHALT & TYPOGRAFIE
   ========================================================= */
.odib-title h1,
.odib-title h2,
.odib-title h3,
.odib-title h4,
.odib-title h5,
.odib-title h6 {
  margin: 0 0 .3em 0;
  color: inherit; /* 🎨 übernimmt Editor-/Theme-Farbe */
}

/* 🩶 Fallback-Farbe, falls keine Editorfarbe gesetzt */
.odib-title:not([style*="color"]) {
  color: var(--odib-text, #111);
}

/* =========================================================
   ✅ ENDE: TITLE + ICON (shared: frontend & admin)
   ========================================================= */
/* ===== Ende Title Anpassung (Frontend) ===== */
/* =========================
   CTA Frontend-Layout (widgets.css)
   ========================= */

/* Content */
.odib-content { width:100%; max-width:none; }
.odib-content > .odib-title-wrap,
.odib-content > .odib-text,
.odib-content > .odib-text--blocks {
  max-width: var(--odib-content-max,1100px);
  margin-left:auto;
  margin-right:auto;
}

/* Text / Links */
.odib-text, .odib-text * { color:inherit; }

.odib-text a:not(.odib-btn),
.odib-cta a:not(.odib-btn) {
  color:var(--odib-link);
  text-decoration:none;
}
.odib-text a:not(.odib-btn):hover,
.odib-cta a:not(.odib-btn):hover {
  color:var(--odib-link-hover);
  text-decoration:underline;
}
.odib-text a:not(.odib-btn):focus,
.odib-cta a:not(.odib-btn):focus {
  outline:2px solid var(--odib-focus);
  outline-offset:2px;
}
/* ===== TEST MARKER ===== 
.odib-cta::after {
  content: "✅ WIDGETS.CSS AKTIV111";
  display: block;
  margin-top: 5px;
  padding: 5px 5px;
  background: black;
  color: white;
  font-weight: bold;
  text-align: center;
  border: 2px solid red;
}*/
/* Erzwinge Branding-Gradient */
a.odib-btn,
a.odib-btn:visited {
  background: var(--odib-btn-fill, var(--odib-btn-gradient)) !important;
  color: var(--odib-btn-fg) !important;
}
a.odib-btn.odib-btn--secondary,
a.odib-btn.odib-btn--secondary:visited {
  background: var(--odib-btn2-fill, var(--odib-btn2-gradient, transparent)) !important;
  color: var(--odib-btn2-fg, #111) !important;
  border: var(--odib-btn2-border, 1px solid rgba(15,23,42,.18));
}
/* FRONTEND-ONLY: Stelle sicher, dass sichtbare Textfüllung der berechneten 'color' folgt */
body:not(.wp-admin) .odib-widget * {
  -webkit-text-fill-color: currentColor !important;
}

/* FRONTEND-ONLY: Falls irgendwer die Farbe per !important überschreibt,
   gewinnen Inline-Styles trotzdem (weil inline + !important > Stylesheet) */
body:not(.wp-admin) .odib-widget [style*="color:"] {
  color: inherit; /* kein !important hier nötig, inline regelt das */
}

/* === FIX: Erlaube Inline-Farben im Frontend === */
body:not(.wp-admin) .odib-widget *[style*="color"] {
  -webkit-text-fill-color: inherit !important;
}

/* =========================
   CTA Button Modals (Gallery/Video)
   ========================= */
body.odib-lightbox-open { overflow: hidden; }
.odib-lightbox {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: none;
  align-items: center;
  justify-content: center;
}
.odib-lightbox.is-open { display: flex; }
.odib-lightbox__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(6, 10, 18, 0.72);
  backdrop-filter: blur(5px);
}
.odib-lightbox__dialog {
  position: relative;
  z-index: 1;
  width: min(980px, 94vw);
  max-height: 90vh;
  background:
    radial-gradient(120% 140% at 10% 0%, rgba(120, 180, 255, 0.12), rgba(0,0,0,0) 55%),
    radial-gradient(120% 140% at 100% 0%, rgba(150, 120, 255, 0.10), rgba(0,0,0,0) 60%),
    linear-gradient(160deg, rgba(11, 18, 32, 0.96), rgba(6, 12, 24, 0.93));
  color: #fff;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.14);
  box-shadow: 0 24px 70px rgba(0,0,0,0.42);
}
.odib-lightbox__dialog::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.08), rgba(255,255,255,0) 35%),
    radial-gradient(80% 60% at 80% 20%, rgba(255,255,255,0.12), rgba(255,255,255,0) 60%);
  mix-blend-mode: screen;
}
.odib-lightbox__dialog::after {
  content: "";
  position: absolute;
  inset: 1px;
  border-radius: 17px;
  border: 1px solid rgba(255,255,255,0.08);
  pointer-events: none;
}
.odib-lightbox__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 13px 16px;
  border-bottom: 1px solid rgba(255,255,255,0.12);
  background: linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0));
  font-weight: 700;
}
.odib-lightbox__title { font-size: 14px; opacity: 0.95; }
.odib-lightbox__close {
  position: absolute;
  top: 11px;
  right: 12px;
  z-index: 5;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(255,255,255,0.035);
  box-shadow: 0 8px 18px rgba(0,0,0,0.24), inset 0 1px 0 rgba(255,255,255,0.16);
  -webkit-backdrop-filter: blur(22px) saturate(160%);
  backdrop-filter: blur(22px) saturate(160%);
  color: #fff;
  font-size: 22px;
  line-height: 1;
  display: grid;
  place-items: center;
  padding: 0;
  text-shadow: 0 1px 2px rgba(0,0,0,0.45);
  cursor: pointer;
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.odib-lightbox__close:hover {
  transform: translateY(-1px);
  border-color: rgba(255,255,255,0.24);
  background: rgba(255,255,255,0.06);
  box-shadow: 0 10px 22px rgba(0,0,0,0.28), inset 0 1px 0 rgba(255,255,255,0.24);
}
.odib-lightbox__body { padding: 14px; }
.odib-lightbox__gallery { position: relative; }
.odib-lightbox__viewport {
  overflow: hidden;
  border-radius: 14px;
  background: rgba(10, 15, 28, 0.75);
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.06), 0 16px 40px rgba(0,0,0,0.45);
}
.odib-lightbox__track {
  display: flex;
  transition: transform 0.35s ease;
}
.odib-lightbox__slide {
  min-width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.odib-lightbox__slide img {
  max-width: 100%;
  max-height: 70vh;
  object-fit: contain;
  border-radius: 12px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.35);
}
.odib-lightbox__nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 6;
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(255,255,255,0.035);
  box-shadow: 0 10px 20px rgba(0,0,0,0.24), inset 0 1px 0 rgba(255,255,255,0.16);
  -webkit-backdrop-filter: blur(22px) saturate(160%);
  backdrop-filter: blur(22px) saturate(160%);
  color: #fff;
  width: 42px;
  height: 42px;
  font-size: 24px;
  line-height: 1;
  display: grid;
  place-items: center;
  font-weight: 700;
  text-shadow: 0 1px 2px rgba(0,0,0,0.45);
  border-radius: 50%;
  cursor: pointer;
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.odib-lightbox__nav:hover {
  transform: translateY(-50%) translateY(-1px);
  border-color: rgba(255,255,255,0.24);
  background: rgba(255,255,255,0.06);
  box-shadow: 0 12px 24px rgba(0,0,0,0.28), inset 0 1px 0 rgba(255,255,255,0.24);
}
.odib-lightbox__nav.prev { left: 12px; }
.odib-lightbox__nav.next { right: 12px; }
.odib-lightbox__dots {
  position: relative;
  display: grid;
  grid-auto-flow: column;
  gap: 0;
  justify-content: stretch;
  margin-top: 12px;
  width: min(420px, 86%);
  margin-left: auto;
  margin-right: auto;
  height: 10px;
  border-radius: 999px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.1);
  box-shadow: inset 0 1px 2px rgba(255,255,255,0.1), inset 0 -2px 6px rgba(0,0,0,0.14);
  overflow: hidden;
  --odib-gallery-progress: 0%;
}
.odib-lightbox__dots::before {
  content: "";
  position: absolute;
  inset: 0;
  width: var(--odib-gallery-progress);
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(255,255,255,0.5), rgba(208,242,255,0.36));
  transition: width .22s ease;
  pointer-events: none;
  box-shadow: 0 0 16px rgba(198,238,255,0.5);
}
.odib-lightbox__dots::after {
  content: "";
  position: absolute;
  top: 50%;
  left: var(--odib-gallery-progress);
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: radial-gradient(circle at 32% 32%, rgba(255,255,255,0.7), rgba(230,246,255,0.38));
  box-shadow: 0 0 8px rgba(207,239,255,0.32);
  transform: translate(-50%, -50%);
  pointer-events: none;
}
.odib-lightbox__dot {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 10px;
  border-radius: 0;
  border: none;
  background: transparent;
  cursor: pointer;
  padding: 0;
  margin: 0;
  outline: none;
}
.odib-lightbox__video-wrap {
  background: #000;
  border-radius: 14px;
  overflow: hidden;
}
.odib-lightbox__iframe,
.odib-lightbox__video {
  display: block;
  width: 100%;
  height: 60vh;
  border: 0;
}
@media (max-width: 768px) {
  .odib-lightbox__dialog {
    width: min(96vw, 96vw);
    max-height: 94dvh;
    border-radius: 14px;
    border-left: 1px solid rgba(255,255,255,0.14);
    border-right: 1px solid rgba(255,255,255,0.14);
  }
  .odib-lightbox__head {
    padding: 12px 14px;
  }
  .odib-lightbox__close {
    top: 8px;
    right: 10px;
    width: 42px;
    height: 42px;
  }
  .odib-lightbox__body {
    padding: 10px;
  }
  .odib-lightbox__slide img {
    max-height: 64dvh;
  }
  .odib-lightbox__nav {
    top: 50%;
    bottom: auto;
    transform: translateY(-50%);
  }
  .odib-lightbox__nav:hover {
    transform: translateY(-50%) translateY(-1px);
  }
  .odib-lightbox__nav.prev {
    left: 8px;
  }
  .odib-lightbox__nav.next {
    right: 8px;
  }
  .odib-lightbox__nav {
    width: 44px;
    height: 44px;
    font-size: 24px;
  }
  .odib-lightbox__dots {
    width: min(92%, 420px);
    margin-top: 10px;
  }
  .odib-lightbox__iframe,
  .odib-lightbox__video {
    height: 52dvh;
  }
}
/* CSS Start 🧰 Fein-Tuning Tools (Akkordeon + Effekte) */
/* ===== Visual FX (Shine + Shadow) ===== */

/* 🔆 Glanz-Effekte (multi-style) */
/* =========================================================
   - Mehrere Stile via data-shine-style:
     lux | sweep | soft | glow | prism
   ========================================================= */

/* 🔹 Ziel-Elemente: erlauben Shine & isolieren eigene Ebene */
.odib-card[data-shine-targets*="title"] .odib-title,
.odib-card[data-shine-targets*="icon"] .odib-title-icon,
.odib-card[data-shine-targets*="image"] img,
.odib-card[data-shine-targets*="container"],
.odib-card[data-shine-targets*="button"] .odib-btn {
  position: relative;
  overflow: hidden;           /* Kanten verstecken */
  isolation: isolate;         /* verhindert Blend mit Nachbarn */
  z-index: 0;                 /* Shine bleibt unter evtl. Text-Overlays */
}

/* Default Shine Vars */
.odib-card[data-shine-targets]{
  --odib-shine-bg: linear-gradient(120deg,
    rgba(255,255,255,0) 0%,
    rgba(255,255,255,.05) 35%,
    rgba(255,255,255,.35) 50%,
    rgba(255,255,255,.05) 65%,
    rgba(255,255,255,0) 100%);
  --odib-shine-anim: odibLux;
  --odib-shine-dur: 3.5s;
  --odib-shine-blur: 6px;
  --odib-shine-opacity: .9;
  --odib-shine-mix: screen;
}

/* Style: sweep */
.odib-card[data-shine-style="sweep"]{
  --odib-shine-bg: linear-gradient(110deg,
    rgba(255,255,255,0) 0%,
    rgba(255,255,255,.15) 40%,
    rgba(255,255,255,.55) 50%,
    rgba(255,255,255,.15) 60%,
    rgba(255,255,255,0) 100%);
  --odib-shine-anim: odibSweep;
  --odib-shine-dur: 2.4s;
  --odib-shine-blur: 2px;
}

/* Style: soft */
.odib-card[data-shine-style="soft"]{
  --odib-shine-bg: linear-gradient(120deg,
    rgba(255,255,255,0) 0%,
    rgba(255,255,255,.04) 35%,
    rgba(255,255,255,.18) 50%,
    rgba(255,255,255,.04) 65%,
    rgba(255,255,255,0) 100%);
  --odib-shine-anim: odibLux;
  --odib-shine-dur: 4.6s;
  --odib-shine-blur: 8px;
  --odib-shine-opacity: .6;
}

/* Style: glow */
.odib-card[data-shine-style="glow"]{
  --odib-shine-bg: radial-gradient(circle at 30% 20%,
    rgba(255,255,255,.45) 0%,
    rgba(255,255,255,.15) 35%,
    rgba(255,255,255,0) 70%);
  --odib-shine-anim: odibGlow;
  --odib-shine-dur: 3.2s;
  --odib-shine-blur: 10px;
  --odib-shine-mix: screen;
}

/* Style: prism */
.odib-card[data-shine-style="prism"]{
  --odib-shine-bg: linear-gradient(120deg,
    rgba(255,255,255,0) 0%,
    rgba(255,0,128,.18) 35%,
    rgba(0,200,255,.22) 50%,
    rgba(255,255,255,.2) 65%,
    rgba(255,255,255,0) 100%);
  --odib-shine-anim: odibSweep;
  --odib-shine-dur: 3.0s;
  --odib-shine-blur: 4px;
  --odib-shine-mix: screen;
}

/* Per-target Shine Style Overrides */
.odib-card[data-shine-title="lux"] .odib-title,
.odib-card[data-shine-icon="lux"] .odib-title-icon,
.odib-card[data-shine-image="lux"] img,
.odib-card[data-shine-button="lux"] .odib-btn,
.odib-card[data-shine-container="lux"]{
  --odib-shine-bg: linear-gradient(120deg,
    rgba(255,255,255,0) 0%,
    rgba(255,255,255,.05) 35%,
    rgba(255,255,255,.35) 50%,
    rgba(255,255,255,.05) 65%,
    rgba(255,255,255,0) 100%);
  --odib-shine-anim: odibLux;
  --odib-shine-dur: 3.5s;
  --odib-shine-blur: 6px;
  --odib-shine-opacity: .9;
  --odib-shine-mix: screen;
}

.odib-card[data-shine-title="sweep"] .odib-title,
.odib-card[data-shine-icon="sweep"] .odib-title-icon,
.odib-card[data-shine-image="sweep"] img,
.odib-card[data-shine-button="sweep"] .odib-btn,
.odib-card[data-shine-container="sweep"]{
  --odib-shine-bg: linear-gradient(110deg,
    rgba(255,255,255,0) 0%,
    rgba(255,255,255,.15) 40%,
    rgba(255,255,255,.55) 50%,
    rgba(255,255,255,.15) 60%,
    rgba(255,255,255,0) 100%);
  --odib-shine-anim: odibSweep;
  --odib-shine-dur: 2.4s;
  --odib-shine-blur: 2px;
}

.odib-card[data-shine-title="soft"] .odib-title,
.odib-card[data-shine-icon="soft"] .odib-title-icon,
.odib-card[data-shine-image="soft"] img,
.odib-card[data-shine-button="soft"] .odib-btn,
.odib-card[data-shine-container="soft"]{
  --odib-shine-bg: linear-gradient(120deg,
    rgba(255,255,255,0) 0%,
    rgba(255,255,255,.04) 35%,
    rgba(255,255,255,.18) 50%,
    rgba(255,255,255,.04) 65%,
    rgba(255,255,255,0) 100%);
  --odib-shine-anim: odibLux;
  --odib-shine-dur: 4.6s;
  --odib-shine-blur: 8px;
  --odib-shine-opacity: .6;
}

.odib-card[data-shine-title="glow"] .odib-title,
.odib-card[data-shine-icon="glow"] .odib-title-icon,
.odib-card[data-shine-image="glow"] img,
.odib-card[data-shine-button="glow"] .odib-btn,
.odib-card[data-shine-container="glow"]{
  --odib-shine-bg: radial-gradient(circle at 30% 20%,
    rgba(255,255,255,.45) 0%,
    rgba(255,255,255,.15) 35%,
    rgba(255,255,255,0) 70%);
  --odib-shine-anim: odibGlow;
  --odib-shine-dur: 3.2s;
  --odib-shine-blur: 10px;
  --odib-shine-mix: screen;
}

.odib-card[data-shine-title="prism"] .odib-title,
.odib-card[data-shine-icon="prism"] .odib-title-icon,
.odib-card[data-shine-image="prism"] img,
.odib-card[data-shine-button="prism"] .odib-btn,
.odib-card[data-shine-container="prism"]{
  --odib-shine-bg: linear-gradient(120deg,
    rgba(255,255,255,0) 0%,
    rgba(255,0,128,.18) 35%,
    rgba(0,200,255,.22) 50%,
    rgba(255,255,255,.2) 65%,
    rgba(255,255,255,0) 100%);
  --odib-shine-anim: odibSweep;
  --odib-shine-dur: 3.0s;
  --odib-shine-blur: 4px;
  --odib-shine-mix: screen;
}

/* ✨ Glanz-Layer für alle Ziel-Elemente */
.odib-card[data-shine-targets*="title"] .odib-title::after,
.odib-card[data-shine-targets*="icon"] .odib-title-icon::after,
.odib-card[data-shine-targets*="image"] img::after,
.odib-card[data-shine-targets*="container"]::after,
.odib-card[data-shine-targets*="button"] .odib-btn::after {
  content: "";
  position: absolute;
  inset: 0;                   /* deckt das Element exakt ab */
  background: var(--odib-shine-bg);
  pointer-events: none;
  opacity: var(--odib-shine-opacity, .9);
  transform: translateX(-120%);
  animation: var(--odib-shine-anim, odibLux) var(--odib-shine-dur, 3.5s) linear infinite;
  mix-blend-mode: var(--odib-shine-mix, screen);     /* Lichtwirkung statt deckender Fläche */
  filter: blur(var(--odib-shine-blur, 6px));          /* Rand weich & unsichtbar */
  border-radius: inherit;     /* übernimmt die Rundungen (Buttons etc.) */
  mask-image: radial-gradient(circle at 50% 50%, #000 80%, transparent 100%);
  -webkit-mask-image: radial-gradient(circle at 50% 50%, #000 80%, transparent 100%);
  z-index: 2;                 /* Shine über Inhalt, aber unter Text */
}

/* 🖼️ Bild-spezifische Korrektur (Shine innerhalb der Box halten) */
.odib-card[data-shine-targets*="image"] img {
  display: block;
  border-radius: inherit;
  overflow: hidden;
  backface-visibility: hidden;
}

/* 🎞️ Bewegung des Glanzes */
@keyframes odibLux {
  0%   { opacity: 0; transform: translateX(-120%) rotate(0deg); }
  30%  { opacity: .9; transform: translateX(0) rotate(5deg); }
  70%  { opacity: .9; transform: translateX(120%) rotate(-5deg); }
  100% { opacity: 0; transform: translateX(200%) rotate(0deg); }
}

@keyframes odibSweep {
  0%   { opacity: 0; transform: translateX(-160%) skewX(-8deg); }
  35%  { opacity: .9; transform: translateX(-20%) skewX(-6deg); }
  65%  { opacity: .9; transform: translateX(120%) skewX(6deg); }
  100% { opacity: 0; transform: translateX(220%) skewX(8deg); }
}

@keyframes odibGlow {
  0%   { opacity: .2; transform: scale(1); }
  50%  { opacity: .6; transform: scale(1.02); }
  100% { opacity: .2; transform: scale(1); }
}

/* 🌑 Schatten */
.odib-card[data-shadow-targets*="title"] .odib-title { text-shadow: 0 3px 8px rgba(0,0,0,.25); }
.odib-card[data-shadow-targets*="icon"] .odib-title-icon { filter: drop-shadow(0 3px 8px rgba(0,0,0,.3)); }
.odib-card[data-shadow-targets*="image"] img { filter: drop-shadow(0 6px 12px rgba(0,0,0,.3)); }
.odib-card[data-shadow-targets*="container"] { box-shadow: 0 6px 18px rgba(0,0,0,.15); }

/*CSS Ende  🧰 Fein-Tuning Tools (Akkordeon + Effekte) */
/* =========================================================
   📱 MOBILE-FEINTUNING für CTA & Widgets
   (ergänzend, nicht überschreibend)
   ========================================================= */

@media (max-width: 768px) {

  /* Card: Weniger Rand, kompakter */
  .odib-card.odib-cta {
    padding-inline: 16px;
    border-radius: 10px;
    box-shadow: none; /* optional für Flat Look */
  }

  /* Grid: Immer einspaltig auf Handy */
  .odib-cta__grid {
    grid-template-columns: 1fr !important;
    gap: 0.75rem;
  }

  /* Media oben, Content unten */
  .odib-media {
    order: 1;
    justify-content: center !important;
    margin-bottom: 1rem;
  }

  .odib-content {
    order: 2;
    text-align: center;
  }

  /* Text: Größerer Zeilenabstand, bessere Lesbarkeit */
  .odib-text {
    font-size: 1rem;
    line-height: 1.6;
    word-break: break-word;
  }

  /* Titel-Box mittig und angenehm luftig */
  .odib-title-wrap {
    text-align: center !important;
    margin-bottom: 0.6rem;
  }

  /* Titelgröße skalieren */
  .odib-title h1,
  .odib-title h2,
  .odib-title h3 {
    font-size: clamp(1.1rem, 4vw, 1.4rem);
    line-height: 1.3;
  }

  /* Buttons: Full-Width für mobile Fingerfreundlichkeit */
  .odib-card.odib-cta .odib-actions {
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.85rem;
  }

  .odib-card.odib-cta .odib-btn {
    width: 100%;
    max-width: 320px;
    flex: 1 1 100%;
    font-size: 1rem;
    padding: 0.9rem 1.1rem;
    border-radius: 12px;
  }

  /* Sticker oder Icons leicht verkleinern */
  .odib-sticker,
  .odib-title-icon {
    transform: scale(0.9);
  }
}

@media (max-width: 480px) {

  /* Noch kompaktere Darstellung */
  .odib-card.odib-cta {
    padding: 0.8rem 1rem;
  }

  .odib-title h1,
  .odib-title h2 {
    font-size: clamp(1rem, 4.5vw, 1.3rem);
  }

  .odib-text {
    font-size: 0.95rem;
  }

  .odib-btn {
    font-size: 0.95rem;
    padding: 0.8rem 1rem;
  }
}
/* =========================================================
   CTA SHOWCASE - Grid/Slider/Kompakt Layout
   ========================================================= */

.odib-showcase {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 20px;
  color: var(--odib-text);
}

/* Grid Layout (Standard) */
.odib-showcase--grid .odib-showcase__grid {
  display: grid;
  gap: 24px;
}

.odib-showcase--grid .odib-showcase__grid--2 { grid-template-columns: repeat(2, 1fr); }
.odib-showcase--grid .odib-showcase__grid--3 { grid-template-columns: repeat(3, 1fr); }
.odib-showcase--grid .odib-showcase__grid--4 { grid-template-columns: repeat(4, 1fr); }
.odib-showcase--grid .odib-showcase__grid--5 { grid-template-columns: repeat(5, 1fr); }
.odib-showcase--grid .odib-showcase__grid--6 { grid-template-columns: repeat(6, 1fr); }

/* Slider Layout */
.odib-showcase--slider {
  position: relative;
  overflow: hidden;
}

.odib-showcase--slider .odib-showcase__grid {
  display: flex;
  transition: transform 0.3s ease-in-out;
}

.odib-showcase--slider .odib-showcase__item {
  flex: 0 0 100%;
  min-width: 100%;
}

/* Kompakt Layout */
.odib-showcase--compact .odib-showcase__grid {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.odib-showcase--compact .odib-showcase__item {
  flex: 1 1 calc(33.333% - 8px);
  min-width: 240px;
}

/* Showcase Item & Card */
.odib-showcase__item {
  width: 100%;
}

.odib-showcase__card {
  background: var(--odib-bg);
  border: 1px solid var(--odib-border);
  border-radius: 12px;
  box-shadow: var(--odib-shadow);
  overflow: hidden;
  height: 100%;
  display: flex;
  flex-direction: column;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.odib-showcase__card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.08);
}

/* Media-Bereich */
.odib-showcase__media {
  width: 100%;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--odib-silver);
  min-height: 160px;
}

.odib-showcase__media img {
  width: 100%;
  height: auto;
  object-fit: cover;
  display: block;
}

.odib-showcase__media .odib-cta__media-sticker {
  font-size: 48px;
  padding: 20px;
}

/* Content-Bereich */
.odib-showcase__content {
  padding: 16px;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.odib-showcase__title {
  margin-bottom: 8px;
  color: var(--odib-text);
  font-weight: 600;
  font-size: 18px;
  line-height: 1.3;
}

.odib-showcase__title h1,
.odib-showcase__title h2,
.odib-showcase__title h3 {
  margin: 0;
  color: inherit;
  font-size: inherit;
}

.odib-showcase__desc {
  margin-bottom: 12px;
  color: var(--odib-text);
  font-size: 14px;
  line-height: 1.5;
  flex: 1;
}

.odib-showcase__desc p {
  margin: 0 0 8px;
}

.odib-showcase__buttons {
  margin-top: auto;
}

.odib-showcase__buttons .odib-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.odib-showcase__buttons .odib-btn {
  font-size: 14px;
  padding: 8px 16px;
}

/* Slider Navigation */
.odib-showcase__nav {
  position: absolute;
  top: 50%;
  width: 100%;
  display: flex;
  justify-content: space-between;
  transform: translateY(-50%);
  pointer-events: none;
  padding: 0 16px;
  z-index: 10;
}

.odib-showcase__nav-btn {
  background: var(--odib-bg);
  border: 1px solid var(--odib-border);
  border-radius: 50%;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  pointer-events: all;
  font-size: 24px;
  color: var(--odib-text);
  box-shadow: var(--odib-shadow);
  transition: all 0.2s ease;
}

.odib-showcase__nav-btn:hover {
  background: var(--odib-btn-bg);
  color: var(--odib-btn-fg);
  transform: scale(1.1);
}

/* Slider Dots */
.odib-showcase__dots {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 16px;
}

.odib-showcase__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--odib-border);
  cursor: pointer;
  transition: all 0.2s ease;
}

.odib-showcase__dot.active {
  background: var(--odib-btn-bg);
  transform: scale(1.2);
}

.odib-showcase__dot:hover {
  background: var(--odib-btn-bg);
  opacity: 0.7;
}

/* Empty State */
.odib-showcase-empty {
  text-align: center;
  padding: 40px 20px;
  color: #999;
  font-size: 14px;
}

/* =========================================================
   Responsive: Mobile Optimierung für Showcase
   ========================================================= */

@media (max-width: 768px) {
  .odib-showcase--grid .odib-showcase__grid--3,
  .odib-showcase--grid .odib-showcase__grid--4,
  .odib-showcase--grid .odib-showcase__grid--5,
  .odib-showcase--grid .odib-showcase__grid--6 {
    grid-template-columns: repeat(2, 1fr);
  }
  
  .odib-showcase--compact .odib-showcase__item {
    flex: 1 1 calc(50% - 6px);
  }
}

@media (max-width: 480px) {
  .odib-showcase {
    padding: 12px;
  }
  
  .odib-showcase--grid .odib-showcase__grid {
    grid-template-columns: 1fr !important;
    gap: 16px;
  }
  
  .odib-showcase--compact .odib-showcase__item {
    flex: 1 1 100%;
  }
  
  .odib-showcase__content {
    padding: 12px;
  }
  
  .odib-showcase__title {
    font-size: 16px;
  }
  
  .odib-showcase__desc {
    font-size: 13px;
  }
  
  .odib-showcase__nav-btn {
    width: 32px;
    height: 32px;
    font-size: 20px;
  }
}

/* ---------------------------
   Feature Widget
--------------------------- */

.odib-card.odib-feature {
  padding: var(--odib-feature-card-p, 20px);
}

.odib-feature__grid {
  display: grid;
  row-gap: var(--odib-feature-grid-rgap, 14px);
  column-gap: var(--odib-feature-grid-cgap, 18px);
  align-items: start;
}

.odib-feature .odib-content {
  padding: var(--odib-feature-content-p, 0);
}

.odib-feature .odib-text {
  font-size: var(--odib-feature-text-fs, 16px);
  line-height: var(--odib-feature-lh, 1.5);
}

.odib-feature .odib-text h1,
.odib-feature .odib-text h2,
.odib-feature .odib-text h3 {
  font-size: var(--odib-feature-title-fs, 22px);
}

.odib-feature-benefits ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: .5rem;
}

.odib-feature-benefits li {
  display: flex;
  gap: .5rem;
  align-items: flex-start;
}

.odib-feature-benefits li > span {
  font-size: var(--odib-feature-bicon-fs, 18px);
  line-height: 1.2;
}

.odib-feature__aside {
  min-height: 60px;
}

.odib-feature .odib-actions {
  margin-top: .9rem;
}

/* =========================
   Modern Accordion (CTA)
   ========================= */
.odib-card {
  --odib-acc-border: rgba(0,0,0,.08);
  --odib-acc-bg: #fff;
  --odib-acc-summary-bg: linear-gradient(180deg, #f8fafc 0%, #f1f5f9 100%);
  --odib-acc-summary-open: linear-gradient(180deg, #eef2ff 0%, #e2e8f0 100%);
  --odib-acc-shadow: 0 2px 8px rgba(0,0,0,.06);
  --odib-acc-radius: 12px;
  --odib-acc-divider: rgba(0,0,0,.06);
}

/* Themes */
.odib-card[data-accordion-theme="soft"] {
  --odib-acc-bg: #f8fafc;
  --odib-acc-summary-bg: #fff;
  --odib-acc-summary-open: #eef2f7;
  --odib-acc-shadow: 0 6px 18px rgba(15,23,42,.08);
  --odib-acc-radius: 14px;
}
.odib-card[data-accordion-theme="minimal"] {
  --odib-acc-bg: transparent;
  --odib-acc-summary-bg: transparent;
  --odib-acc-summary-open: transparent;
  --odib-acc-shadow: none;
  --odib-acc-border: rgba(0,0,0,.12);
  --odib-acc-divider: rgba(0,0,0,.12);
}
.odib-card[data-accordion-theme="bold"] {
  --odib-acc-bg: #fff;
  --odib-acc-summary-bg: linear-gradient(180deg,#fff 0%,#f8fafc 100%);
  --odib-acc-summary-open: linear-gradient(180deg,#e0f2fe 0%,#e2e8f0 100%);
  --odib-acc-shadow: 0 10px 24px rgba(2,6,23,.12);
  --odib-acc-border: rgba(2,6,23,.12);
  --odib-acc-radius: 16px;
}
.odib-card[data-accordion-theme="line"] {
  --odib-acc-bg: transparent;
  --odib-acc-summary-bg: transparent;
  --odib-acc-summary-open: transparent;
  --odib-acc-shadow: none;
  --odib-acc-border: transparent;
  --odib-acc-divider: rgba(0,0,0,.12);
}

.odib-acc,
.odib-accordion {
  display: grid;
  gap: 10px;
  margin: .6rem 0;
}

.odib-accordion .odib-acc-item,
.odib-acc .odib-acc-item {
  border: 1px solid var(--odib-acc-border);
  border-radius: var(--odib-acc-radius);
  background: var(--odib-acc-bg);
  box-shadow: var(--odib-acc-shadow);
  overflow: hidden;
}

.odib-card[data-accordion-theme="line"] .odib-acc-item {
  border: 0;
  border-bottom: 1px solid var(--odib-acc-divider);
  border-radius: 0;
  box-shadow: none;
}

.odib-accordion .odib-acc-item summary,
.odib-acc .odib-acc-item summary {
  list-style: none;
  cursor: pointer;
  padding: 12px 14px;
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 600;
  background: var(--odib-acc-summary-bg);
}

.odib-accordion .odib-acc-item[open] summary,
.odib-acc .odib-acc-item[open] summary {
  background: var(--odib-acc-summary-open);
}

.odib-accordion .odib-acc-item summary::-webkit-details-marker,
.odib-acc .odib-acc-item summary::-webkit-details-marker { display:none; }

/* Default Icon: Chevron */
.odib-accordion .odib-acc-item summary::after,
.odib-acc .odib-acc-item summary::after {
  content: "";
  margin-left: auto;
  width: 10px;
  height: 10px;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(45deg);
  opacity: .7;
  transition: transform .2s ease;
}

.odib-accordion .odib-acc-item[open] summary::after,
.odib-acc .odib-acc-item[open] summary::after {
  transform: rotate(-135deg);
}

/* Icon: Plus / Minus */
.odib-card[data-accordion-icon="plus"] .odib-acc-item summary::after {
  content: "+";
  width: auto;
  height: auto;
  border: 0;
  font-size: 18px;
  line-height: 1;
  transform: none;
}
.odib-card[data-accordion-icon="plus"] .odib-acc-item[open] summary::after {
  content: "–";
}

/* Icon: Arrow */
.odib-card[data-accordion-icon="arrow"] .odib-acc-item summary::after {
  content: "›";
  width: auto;
  height: auto;
  border: 0;
  font-size: 20px;
  line-height: 1;
  transform: rotate(0deg);
}
.odib-card[data-accordion-icon="arrow"] .odib-acc-item[open] summary::after {
  transform: rotate(90deg);
}

.odib-accordion .odib-acc-body,
.odib-acc .odib-acc-body {
  padding: 12px 14px 14px;
  border-top: 1px solid var(--odib-acc-divider);
  background: var(--odib-acc-bg);
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  transform: translateY(-4px);
  transition: max-height .25s ease, opacity .25s ease, transform .25s ease;
}

.odib-accordion .odib-acc-item[open] .odib-acc-body,
.odib-acc .odib-acc-item[open] .odib-acc-body {
  max-height: 1200px;
  opacity: 1;
  transform: translateY(0);
}

/* FX: fold / slide / fade (data-accordion on card) */
.odib-card[data-accordion="fold"] .odib-acc-body { transform: scaleY(0); transform-origin: top; }
.odib-card[data-accordion="fold"] .odib-acc-item[open] .odib-acc-body { transform: scaleY(1); }

.odib-card[data-accordion="slide"] .odib-acc-body { transform: translateY(-6px); }
.odib-card[data-accordion="slide"] .odib-acc-item[open] .odib-acc-body { transform: translateY(0); }

.odib-card[data-accordion="fade"] .odib-acc-body { opacity: 0; }
.odib-card[data-accordion="fade"] .odib-acc-item[open] .odib-acc-body { opacity: 1; }

@media (max-width: 768px) {
  .odib-feature__grid { grid-template-columns: 1fr !important; }
}

/* Category border should wrap the whole category, not each card */
.odib-category-wrap.odib-cat-border {
  border-width: var(--odib-cat-border-width, 1px);
  border-style: var(--odib-cat-border-style, solid);
  border-color: var(--odib-cat-border-color, var(--odib-border));
  border-radius: var(--odib-cat-border-radius, 14px);
  padding: calc(var(--odib-cat-gap, 32px) / 2);
}
.odib-category-wrap.odib-cat-border-gradient {
  border-color: transparent;
  border-image: var(--odib-cat-border-gradient) 1;
}

/* Gradient border with radius for category wrapper */
.odib-category-wrap.odib-cat-border-gradient {
  position: relative;
  border: none;
}
.odib-category-wrap.odib-cat-border-gradient::before {
  content: "";
  position: absolute;
  inset: 0;
  padding: var(--odib-cat-border-width, 1px);
  border-radius: var(--odib-cat-border-radius, 14px);
  background: var(--odib-cat-border-gradient);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
}
.odib-category-wrap.odib-cat-border-gradient > * { position: relative; }

/* ===========================
   Bewertung / Rating Widget
   =========================== */
.odib-rating { width:100%; }
.odib-rating__card {
  display:block;
  padding:22px;
  background:var(--odib-bg);
  color:var(--odib-text);
  width:100%;
  max-width:100%;
  border:1px solid var(--odib-border);
  border-radius:22px;
}
.odib-rating__inner {
  display:grid;
  gap:18px;
  width:100%;
  max-width:100%;
}
.odib-rating--badge .odib-rating__card {
  padding:16px 18px;
}
.odib-rating--badge .odib-rating__inner {
  grid-template-columns:minmax(0,1.15fr) minmax(200px,.85fr);
  align-items:center;
}
.odib-rating--compact .odib-rating__card {
  padding:18px 20px;
}
.odib-rating--compact .odib-rating__inner {
  grid-template-columns:minmax(0,1fr) minmax(220px,.78fr);
  align-items:center;
  gap:14px;
}
.odib-rating--box .odib-rating__inner {
  grid-template-columns:1fr;
  gap:18px;
}
.odib-rating--spotlight .odib-rating__card {
  padding:34px 32px;
  border-radius:28px;
  background:
    radial-gradient(circle at 50% 0%, rgba(255,255,255,.72), transparent 38%),
    linear-gradient(145deg,var(--odib-bg),rgba(255,255,255,.98));
  box-shadow:0 28px 70px rgba(15,23,42,.16);
}
.odib-rating--spotlight .odib-rating__inner {
  grid-template-columns:1fr;
  gap:20px;
}
.odib-rating--align-left .odib-rating__inner { width:min(100%, 760px); margin-right:auto; }
.odib-rating--align-center .odib-rating__inner { width:min(100%, 760px); margin-inline:auto; }
.odib-rating--align-right .odib-rating__inner { width:min(100%, 760px); margin-left:auto; margin-right:0; }
.odib-rating--box.odib-rating--align-left .odib-rating__inner,
.odib-rating--spotlight.odib-rating--align-left .odib-rating__inner { width:min(100%, 860px); }
.odib-rating--box.odib-rating--align-center .odib-rating__inner,
.odib-rating--spotlight.odib-rating--align-center .odib-rating__inner { width:min(100%, 860px); }
.odib-rating--box.odib-rating--align-right .odib-rating__inner,
.odib-rating--spotlight.odib-rating--align-right .odib-rating__inner { width:min(100%, 860px); }
.odib-rating--align-left .odib-rating__card { text-align:left; }
.odib-rating--align-center .odib-rating__card { text-align:center; }
.odib-rating--align-right .odib-rating__card { text-align:right; }
.odib-rating--align-left .odib-rating__summary { justify-items:start; }
.odib-rating--align-center .odib-rating__summary { justify-items:center; }
.odib-rating--align-right .odib-rating__summary { justify-items:end; }
.odib-rating--align-left .odib-rating__topline,
.odib-rating--align-left .odib-rating__scoreline,
.odib-rating--align-left .odib-rating__review-head { justify-content:flex-start; }
.odib-rating--align-center .odib-rating__topline,
.odib-rating--align-center .odib-rating__scoreline,
.odib-rating--align-center .odib-rating__review-head { justify-content:center; }
.odib-rating--align-right .odib-rating__topline,
.odib-rating--align-right .odib-rating__scoreline,
.odib-rating--align-right .odib-rating__review-head { justify-content:flex-end; }
.odib-rating--align-left .odib-rating__count,
.odib-rating--align-left .odib-rating__headline,
.odib-rating--align-left .odib-rating__text { margin-right:auto; }
.odib-rating--align-center .odib-rating__count,
.odib-rating--align-center .odib-rating__headline,
.odib-rating--align-center .odib-rating__text { margin-inline:auto; }
.odib-rating--align-right .odib-rating__count,
.odib-rating--align-right .odib-rating__headline,
.odib-rating--align-right .odib-rating__text { margin-left:auto; margin-right:0; }
.odib-rating--align-left .odib-rating__breakdown { width:min(100%, 560px); margin-right:auto; }
.odib-rating--align-center .odib-rating__breakdown { width:min(100%, 560px); margin-inline:auto; }
.odib-rating--align-right .odib-rating__breakdown { width:min(100%, 560px); margin-left:auto; margin-right:0; }
.odib-rating--align-left .odib-rating__reviews { width:100%; justify-items:start; }
.odib-rating--align-center .odib-rating__reviews { width:100%; justify-items:center; }
.odib-rating--align-right .odib-rating__reviews { width:100%; justify-items:end; }
.odib-rating--align-left .odib-rating__review { text-align:left; }
.odib-rating--align-center .odib-rating__review { text-align:center; }
.odib-rating--align-right .odib-rating__review { text-align:right; }
.odib-rating__summary { display:grid; gap:10px; min-width:0; }
.odib-rating__topline { display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.odib-rating__topline.is-empty { min-height:0; }
.odib-rating__badge,
.odib-rating__source {
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 12px;
  border-radius:999px;
  border:1px solid var(--odib-border);
  background:rgba(255,255,255,.7);
  font-size:11px;
  font-weight:800;
  letter-spacing:.06em;
  text-transform:uppercase;
}
.odib-rating__scoreline { display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.odib-rating__scoregroup { display:flex; align-items:flex-end; gap:4px; }
.odib-rating__score { font-size:clamp(2rem,4vw,3.4rem); line-height:.95; color:var(--odib-title-bg); }
.odib-rating__scale { font-size:1rem; color:var(--odib-text); opacity:.72; padding-bottom:.28rem; }
.odib-rating__count { font-size:13px; color:var(--odib-text); opacity:.72; }
.odib-rating__headline {
  margin:0;
  font-size:clamp(1.2rem,2vw,1.8rem);
  line-height:1.1;
  color:var(--odib-title-bg);
}
.odib-rating__text { margin:0; line-height:1.65; color:var(--odib-text); }
.odib-rating__stars {
  position:relative;
  display:inline-block;
  font-size:18px;
  line-height:1;
  letter-spacing:.18em;
}
.odib-rating__stars-base { color:rgba(148,163,184,.32); }
.odib-rating__stars-fill {
  position:absolute;
  inset:0 auto 0 0;
  overflow:hidden;
  white-space:nowrap;
  color:#f59e0b;
}
.odib-rating__breakdown {
  display:grid;
  gap:10px;
  align-content:start;
}
.odib-rating__break-row {
  display:grid;
  grid-template-columns:92px minmax(0,1fr) 48px;
  align-items:center;
  gap:10px;
}
.odib-rating__break-label,
.odib-rating__break-value { font-size:12px; font-weight:700; }
.odib-rating__break-bar {
  position:relative;
  height:10px;
  border-radius:999px;
  overflow:hidden;
  background:rgba(148,163,184,.16);
  border:1px solid rgba(148,163,184,.14);
}
.odib-rating__break-bar > span {
  display:block;
  height:100%;
  border-radius:999px;
  background:var(--odib-btn-gradient);
}
.odib-rating__reviews {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:12px;
}
.odib-rating__reviews--list {
  grid-template-columns:1fr;
  gap:10px;
}
.odib-rating__reviews--cards {
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
}
.odib-rating__reviews--modal-list {
  grid-template-columns:1fr;
  gap:12px;
}
.odib-rating__review {
  display:grid;
  gap:10px;
  padding:14px;
  border:1px solid var(--odib-border);
  border-radius:16px;
  background:rgba(255,255,255,.72);
}
.odib-rating__review-head {
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
}
.odib-rating__review-name { display:block; font-size:14px; color:var(--odib-title-bg); }
.odib-rating__review-role { display:block; font-size:12px; color:var(--odib-text); opacity:.7; margin-top:2px; }
.odib-rating__review-text { margin:0; font-size:14px; line-height:1.6; color:var(--odib-text); }
.odib-rating__review-score { font-size:13px; font-weight:700; color:var(--odib-title-bg); }
.odib-rating__reviews-trigger-wrap { display:flex; }
.odib-rating__reviews-trigger { display:inline-flex; align-items:center; gap:10px; justify-content:space-between; min-width:220px; max-width:100%; padding:10px 14px; border-radius:999px; border:1px solid var(--odib-border); background:rgba(255,255,255,.76); color:var(--odib-title-bg); font:inherit; font-weight:700; cursor:pointer; box-shadow:0 12px 28px rgba(15,23,42,.08); }
.odib-rating__reviews-trigger strong { display:inline-flex; min-width:24px; height:24px; align-items:center; justify-content:center; padding:0 7px; border-radius:999px; background:var(--odib-btn-gradient); color:var(--odib-btn-fg); font-size:12px; }
.odib-rating-modal { position:fixed; inset:0; z-index:999999; display:none; }
.odib-rating-modal[aria-hidden="false"] { display:block; }
.odib-rating-modal__backdrop { position:absolute; inset:0; background:rgba(15,23,42,.34); backdrop-filter:blur(4px); }
.odib-rating-modal__dialog { position:relative; width:min(760px, calc(100vw - 32px)); max-height:min(80vh, 920px); overflow:auto; margin:8vh auto 0; padding:18px; border-radius:22px; border:1px solid var(--odib-border); background:var(--odib-bg); color:var(--odib-text); box-shadow:0 32px 80px rgba(15,23,42,.24); }
.odib-rating-modal__head { display:flex; align-items:flex-start; justify-content:space-between; gap:14px; margin-bottom:14px; }
.odib-rating-modal__eyebrow { display:block; font-size:11px; letter-spacing:.08em; text-transform:uppercase; opacity:.65; margin-bottom:4px; }
.odib-rating-modal__title { margin:0; font-size:1.2rem; color:var(--odib-title-bg); }
.odib-rating-modal__close { display:inline-flex; align-items:center; justify-content:center; width:36px; height:36px; border-radius:999px; border:1px solid var(--odib-border); background:rgba(255,255,255,.78); color:var(--odib-title-bg); font-size:22px; line-height:1; cursor:pointer; }
.odib-rating--badge .odib-rating__headline,
.odib-rating--badge .odib-rating__text { display:none; }
.odib-rating--badge .odib-rating__breakdown {
  gap:8px;
}
.odib-rating--badge .odib-rating__score { font-size:clamp(1.6rem,2vw,2.2rem); }
.odib-rating--compact .odib-rating__headline,
.odib-rating--compact .odib-rating__text { display:none; }
.odib-rating--compact .odib-rating__summary { gap:8px; }
.odib-rating--badge .odib-rating__reviews,
.odib-rating--compact .odib-rating__reviews { margin-top:4px; }
.odib-rating--badge .odib-rating__reviews--list .odib-rating__review,
.odib-rating--compact .odib-rating__reviews--list .odib-rating__review { padding:10px 12px; gap:8px; border-radius:12px; }
.odib-rating--badge .odib-rating__reviews--cards,
.odib-rating--compact .odib-rating__reviews--cards { grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:10px; }
.odib-rating--badge .odib-rating__reviews-trigger,
.odib-rating--compact .odib-rating__reviews-trigger { min-width:0; width:auto; padding:9px 12px; }
.odib-rating--compact .odib-rating__breakdown {
  padding-left:14px;
  border-left:1px solid rgba(148,163,184,.18);
}
.odib-rating--compact.odib-rating--align-center .odib-rating__breakdown,
.odib-rating--compact.odib-rating--align-right .odib-rating__breakdown {
  padding-left:0;
  border-left:0;
  padding-top:10px;
  border-top:1px solid rgba(148,163,184,.16);
}
.odib-rating--badge.odib-rating--align-left .odib-rating__inner,
.odib-rating--compact.odib-rating--align-left .odib-rating__inner {
  width:100%;
  grid-template-columns:minmax(0,1fr) minmax(220px,.78fr);
  margin:0;
}
.odib-rating--badge.odib-rating--align-center .odib-rating__inner,
.odib-rating--compact.odib-rating--align-center .odib-rating__inner {
  width:min(100%, 760px);
  grid-template-columns:1fr;
  margin-inline:auto;
}
.odib-rating--badge.odib-rating--align-right .odib-rating__inner,
.odib-rating--compact.odib-rating--align-right .odib-rating__inner {
  width:min(100%, 760px);
  grid-template-columns:1fr;
  margin-left:auto;
  margin-right:0;
}
.odib-rating--badge.odib-rating--align-left .odib-rating__summary,
.odib-rating--compact.odib-rating--align-left .odib-rating__summary { justify-items:start; }
.odib-rating--badge.odib-rating--align-center .odib-rating__summary,
.odib-rating--compact.odib-rating--align-center .odib-rating__summary { justify-items:center; }
.odib-rating--badge.odib-rating--align-right .odib-rating__summary,
.odib-rating--compact.odib-rating--align-right .odib-rating__summary { justify-items:end; }
.odib-rating--badge.odib-rating--align-left .odib-rating__breakdown,
.odib-rating--compact.odib-rating--align-left .odib-rating__breakdown {
  justify-self:start;
  width:min(100%, 320px);
  margin-right:auto;
}
.odib-rating--badge.odib-rating--align-center .odib-rating__breakdown,
.odib-rating--compact.odib-rating--align-center .odib-rating__breakdown {
  justify-self:center;
  width:min(100%, 320px);
  margin-inline:auto;
}
.odib-rating--badge.odib-rating--align-right .odib-rating__breakdown,
.odib-rating--compact.odib-rating--align-right .odib-rating__breakdown {
  justify-self:end;
  width:min(100%, 320px);
  margin-left:auto;
  margin-right:0;
}
.odib-rating--badge.odib-rating--align-left .odib-rating__topline,
.odib-rating--badge.odib-rating--align-left .odib-rating__scoreline,
.odib-rating--compact.odib-rating--align-left .odib-rating__topline,
.odib-rating--compact.odib-rating--align-left .odib-rating__scoreline { justify-content:flex-start; }
.odib-rating--badge.odib-rating--align-center .odib-rating__topline,
.odib-rating--badge.odib-rating--align-center .odib-rating__scoreline,
.odib-rating--compact.odib-rating--align-center .odib-rating__topline,
.odib-rating--compact.odib-rating--align-center .odib-rating__scoreline { justify-content:center; }
.odib-rating--badge.odib-rating--align-right .odib-rating__topline,
.odib-rating--badge.odib-rating--align-right .odib-rating__scoreline,
.odib-rating--compact.odib-rating--align-right .odib-rating__topline,
.odib-rating--compact.odib-rating--align-right .odib-rating__scoreline { justify-content:flex-end; }
.odib-rating--badge.odib-rating--align-left .odib-rating__count,
.odib-rating--badge.odib-rating--align-left .odib-rating__headline,
.odib-rating--badge.odib-rating--align-left .odib-rating__text,
.odib-rating--compact.odib-rating--align-left .odib-rating__count,
.odib-rating--compact.odib-rating--align-left .odib-rating__headline,
.odib-rating--compact.odib-rating--align-left .odib-rating__text { margin-right:auto; }
.odib-rating--badge.odib-rating--align-center .odib-rating__count,
.odib-rating--badge.odib-rating--align-center .odib-rating__headline,
.odib-rating--badge.odib-rating--align-center .odib-rating__text,
.odib-rating--compact.odib-rating--align-center .odib-rating__count,
.odib-rating--compact.odib-rating--align-center .odib-rating__headline,
.odib-rating--compact.odib-rating--align-center .odib-rating__text { margin-inline:auto; }
.odib-rating--badge.odib-rating--align-right .odib-rating__count,
.odib-rating--badge.odib-rating--align-right .odib-rating__headline,
.odib-rating--badge.odib-rating--align-right .odib-rating__text,
.odib-rating--compact.odib-rating--align-right .odib-rating__count,
.odib-rating--compact.odib-rating--align-right .odib-rating__headline,
.odib-rating--compact.odib-rating--align-right .odib-rating__text { margin-left:auto; margin-right:0; }
.odib-rating--box .odib-rating__breakdown {
  padding-top:6px;
  border-top:1px solid rgba(148,163,184,.16);
}
.odib-rating--spotlight .odib-rating__summary {
  align-content:center;
  justify-items:center;
  gap:14px;
  text-align:center;
}
.odib-rating--spotlight .odib-rating__topline {
  justify-content:center;
}
.odib-rating--spotlight .odib-rating__badge,
.odib-rating--spotlight .odib-rating__source {
  padding:8px 14px;
  font-size:12px;
  background:rgba(255,255,255,.82);
}
.odib-rating--spotlight .odib-rating__scoreline {
  flex-direction:column;
  justify-content:center;
  align-items:center;
  gap:10px;
}
.odib-rating--spotlight .odib-rating__stars {
  font-size:22px;
}
.odib-rating--spotlight .odib-rating__scoregroup {
  align-items:flex-end;
  justify-content:center;
}
.odib-rating--spotlight .odib-rating__score {
  font-size:clamp(3.4rem,8vw,5.8rem);
}
.odib-rating--spotlight .odib-rating__scale {
  font-size:1.15rem;
  padding-bottom:.45rem;
}
.odib-rating--spotlight .odib-rating__count {
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.odib-rating--spotlight .odib-rating__headline {
  max-width:18ch;
  font-size:clamp(1.7rem,2.8vw,2.5rem);
}
.odib-rating--spotlight .odib-rating__text {
  max-width:62ch;
  margin:0 auto;
  font-size:1rem;
}
.odib-rating--spotlight .odib-rating__breakdown {
  width:min(100%,560px);
  margin:0 auto;
  align-self:stretch;
  padding:18px;
  border:1px solid rgba(148,163,184,.18);
  border-radius:20px;
  background:rgba(255,255,255,.7);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.55);
  backdrop-filter:blur(6px);
}
.odib-rating--spotlight .odib-rating__reviews {
  grid-column:1 / -1;
  margin-top:4px;
}
.odib-rating--tiny .odib-rating__card { padding:10px 12px; gap:8px; border-radius:16px; }
.odib-rating--tiny .odib-rating__summary { gap:6px; }
.odib-rating--tiny .odib-rating__badge,
.odib-rating--tiny .odib-rating__source { padding:4px 8px; font-size:10px; }
.odib-rating--tiny .odib-rating__scoreline { gap:8px; }
.odib-rating--tiny .odib-rating__stars { font-size:14px; letter-spacing:.12em; }
.odib-rating--tiny .odib-rating__score { font-size:1.4rem; }
.odib-rating--tiny .odib-rating__scale { font-size:.85rem; padding-bottom:.18rem; }
.odib-rating--tiny .odib-rating__count { font-size:11px; }
.odib-rating--tiny .odib-rating__headline { font-size:.92rem; }
.odib-rating--tiny .odib-rating__text { font-size:.9rem; line-height:1.45; }
.odib-rating--tiny .odib-rating__breakdown { gap:6px; }
.odib-rating--tiny .odib-rating__break-row { grid-template-columns:72px minmax(0,1fr) 38px; gap:8px; }
.odib-rating--tiny .odib-rating__break-label,
.odib-rating--tiny .odib-rating__break-value { font-size:11px; }
.odib-rating--tiny .odib-rating__break-bar { height:8px; }
.odib-rating--tiny .odib-rating__review { padding:10px; gap:8px; border-radius:12px; }
.odib-rating--tiny .odib-rating__review-name { font-size:13px; }
.odib-rating--tiny .odib-rating__review-role,
.odib-rating--tiny .odib-rating__review-score { font-size:11px; }
.odib-rating--tiny .odib-rating__review-text { font-size:13px; line-height:1.45; }
.odib-rating--large .odib-rating__card { padding:28px; gap:22px; }
.odib-rating--large .odib-rating__score { font-size:clamp(2.4rem,4.8vw,4rem); }
@media (max-width: 820px) {
  .odib-rating--badge .odib-rating__inner,
  .odib-rating--compact .odib-rating__inner,
  .odib-rating--spotlight .odib-rating__inner { grid-template-columns:1fr; }
  .odib-rating--badge .odib-rating__inner,
  .odib-rating--compact .odib-rating__inner { width:100%; margin-inline:0; }
  .odib-rating-modal__dialog { width:min(100vw - 20px, 760px); margin-top:5vh; padding:14px; }
  .odib-rating--spotlight .odib-rating__card { padding:24px 20px; }
  .odib-rating--spotlight .odib-rating__score { font-size:clamp(2.8rem,10vw,4.3rem); }
  .odib-rating--compact .odib-rating__breakdown {
    padding-left:0;
    border-left:0;
    padding-top:10px;
    border-top:1px solid rgba(148,163,184,.16);
  }
  .odib-rating--tiny .odib-rating__break-row { grid-template-columns:64px minmax(0,1fr) 34px; }
  .odib-rating__break-row { grid-template-columns:80px minmax(0,1fr) 42px; }
}
