/**
 * CMS Experts – Single Expert View
 * Stylesheet für die Einzelansicht eines Experten (ex-v2).
 *
 * CSS-Variablen werden via :root{} inline im Template gesetzt.
 *
 * @package CMS_Experts
 */

/* ── Wrapper ─────────────────────────────────────────────────── */
.ex-v2 {
  max-width: var(--max, 1140px);
  margin: 0 auto;
  background: #f8fafc;
  border-left: 1px solid var(--post-column-border, #e2e0d8);
  border-right: 1px solid var(--post-column-border, #e2e0d8);
}

/* ── Breadcrumb ──────────────────────────────────────────────── */
.ex-bc {
  display: flex;
  align-items: center;
  gap: .5rem;
  padding: .7rem 2rem;
  background: #fff;
  border-bottom: 1px solid #f1f5f9;
  font-size: .8rem;
}
.ex-bc a            { color: var(--expert-primary, #5e72e4); text-decoration: none; font-weight: 600; }
.ex-bc a:hover      { opacity: .7; }
.ex-bc__sep         { color: #cbd5e1; }
.ex-bc__cur         { color: #64748b; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 360px; }

/* ── Hero ────────────────────────────────────────────────────── */
.ex-hero {
  position: relative;
  overflow: hidden;
  height: 300px;
  min-height: 300px;
  max-height: 300px;
  background: var(--expert-hdr-bg, linear-gradient(135deg, #fefbf5 0%, #f8f1e4 100%));
  border-bottom: 3px solid var(--expert-primary, #5e72e4);
}
.ex-hero__inner {
  display: flex;
  gap: 1.75rem;
  align-items: center;
  padding: 0.5rem 2.5rem 2.5rem;
  position: relative;
  z-index: 1;
  height: 100%;
  box-sizing: border-box;
}
.ex-hero__av {
  flex-shrink: 0;
  width: 125px;
  height: 125px;
  border-radius: 50%;
  overflow: hidden;
  box-shadow: 0 6px 20px rgba(0,0,0,.14), 0 0 0 4px rgba(255,255,255,.8), 0 0 0 7px color-mix(in srgb, var(--expert-primary, #5e72e4) 20%, transparent);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.25rem;
  font-weight: 900;
  color: #fff;
  letter-spacing: -.02em;
}
.ex-hero__av img        { width: 100%; height: 100%; object-fit: cover; }
.ex-hero__meta          { flex: 1; min-width: 0; padding-top: .25rem; }
.ex-hero__badges        { position: absolute; top: .875rem; right: 15px; display: flex; flex-wrap: wrap; gap: .3rem; justify-content: flex-end; max-width: 55%; z-index: 2; }
.ex-hero__badge {
  display: inline-flex;
  align-items: center;
  gap: .25rem;
  padding: .22rem .65rem;
  border-radius: 50px;
  font-size: .72rem;
  font-weight: 700;
  backdrop-filter: blur(3px);
}
.ex-hero__badge--avail-available { background: #d1fae5; color: #065f46; }
.ex-hero__badge--avail-limited   { background: #fef3c7; color: #92400e; }
.ex-hero__badge--avail-booked    { background: #fee2e2; color: #991b1b; }
.ex-hero__badge--mvp             { background: rgba(251,191,36,.18); color: #d97706; border: 1px solid rgba(251,191,36,.3); }
.ex-hero__badge--cert            { background: #dbeafe; color: #1e40af; }
.ex-hero__badge--premium         { background: #fef3c7; color: #7c2d12; }
.ex-hero__badge--partner         { background: #f3e8ff; color: #6b21a8; }
.ex-hero__name   { margin: 0 0 .15rem; font-size: clamp(1.5rem, 4vw, 2.25rem); font-weight: 800; line-height: 1.2; color: var(--detail-header-color, #1e293b); }
.ex-hero__motto  { font-size: .84rem; font-style: italic; color: var(--detail-header-color, #1e293b); opacity: .6; margin: 0 0 .15rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ex-hero__pos    { font-size: .88rem; color: var(--detail-header-color, #1e293b); opacity: .7; margin: 0 0 .1rem; }
.ex-hero__co     { font-size: .84rem; color: var(--detail-header-color, #1e293b); opacity: .65; margin: 10px 0 .7rem; }
.ex-hero__co a   { color: inherit; text-decoration: underline; text-underline-offset: 2px; }
.ex-hero__co a:hover { opacity: .85; }
.ex-hero__name-row  { display: flex; align-items: flex-start; gap: 15px; flex-wrap: wrap; margin-bottom: .15rem; }
.ex-hero__name-row .ex-hero__name { margin-bottom: 0; }
.ex-hero__spec-pills { display: flex; flex-wrap: wrap; gap: .3rem; padding-top: .45rem; }
.ex-hero__spec-pill {
  display: inline-flex;
  align-items: center;
  padding: .15rem .55rem;
  border-radius: 50px;
  font-size: .68rem;
  font-weight: 700;
  background: rgba(255,255,255,.75);
  color: #334155;
  border: 1px solid rgba(255,255,255,.5);
  backdrop-filter: blur(3px);
  white-space: nowrap;
}
.ex-hero__ev-count {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  padding: .2rem .55rem;
  background: rgba(255,255,255,.18);
  border: 1px solid rgba(255,255,255,.35);
  border-radius: 50px;
  font-size: .76rem;
  font-weight: 700;
  color: #fff;
  white-space: nowrap;
  backdrop-filter: blur(4px);
  margin-top: .45rem;
  cursor: default;
}
.ex-hero__social { display: flex; flex-wrap: wrap; gap: .5rem; }
.ex-hero__si {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: 8px;
  background: rgba(255,255,255,.8);
  color: #334155;
  text-decoration: none;
  backdrop-filter: blur(3px);
  transition: background .15s, transform .15s, box-shadow .15s;
}
.ex-hero__si:hover { background: #fff; transform: translateY(-2px); box-shadow: 0 4px 10px rgba(0,0,0,.12); }

/* ── Bridge Cards (Über mich + Kontakt) ──────────────────────── */
.ex-bridge {
  display: grid;
  grid-template-columns: 3fr 2fr;
  gap: 1.5rem;
  padding: 0 2rem;
  margin-top: -60px;
  position: relative;
  z-index: 3;
  max-width: 1140px;
}
.ex-bridge__about,
.ex-bridge__contact {
  background: #fff;
  border-radius: var(--expert-radius, 8px);
  padding: 1.5rem 1.75rem;
  box-shadow: 0 1px 3px rgba(0,0,0,.05), 0 4px 6px rgba(0,0,0,.02);
  border: 1px solid #e2e8f0;
  overflow: hidden;
}
.ex-bridge__title {
  font-size: .95rem;
  font-weight: 700;
  color: #1e293b;
  margin: 0 0 .75rem;
  padding-bottom: .5rem;
  border-bottom: 2px solid #f1f5f9;
}
.ex-bridge__text {
  font-size: .88rem;
  line-height: 1.65;
  color: #334155;
  max-height: 8.25rem;   /* ~5 Zeilen */
  overflow: hidden;
  position: relative;
}
.ex-bridge__text::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 2.5rem;
  background: linear-gradient(to bottom, transparent, #fff);
  pointer-events: none;
  opacity: 0;
  transition: opacity .2s;
}
.ex-bridge__text.is-overflow::after {
  opacity: 1;
}
.ex-bridge__text p       { margin: 0 0 .35rem; }
.ex-bridge__text p:last-child { margin-bottom: 0; }
.ex-bridge__text ul,
.ex-bridge__text ol      { margin: 0 0 .35rem; padding-left: 1.25rem; }
.ex-bridge__text li      { margin-bottom: .15rem; }
.ex-bridge__contact-body {
  display: flex;
  flex-direction: column;
  gap: .75rem;
}
.ex-bridge__row {
  display: flex;
  width: 100%;
}
.ex-bridge__links {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: .5rem;
}
.ex-bridge__link {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .3rem;
  padding: .45rem .25rem;
  font-size: .72rem;
  font-weight: 600;
  color: var(--expert-primary, #5e72e4);
  background: color-mix(in srgb, var(--expert-primary, #5e72e4) 8%, #fff);
  border-radius: 6px;
  text-decoration: none;
  transition: all .2s ease;
  text-align: center;
  border: 1px solid color-mix(in srgb, var(--expert-primary, #5e72e4) 20%, #e2e8f0);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ex-bridge__link:hover {
  background: var(--expert-primary, #5e72e4);
  color: #fff;
  border-color: var(--expert-primary, #5e72e4);
  box-shadow: 0 4px 12px color-mix(in srgb, var(--expert-primary, #5e72e4) 30%, transparent);
}
.ex-bridge__link--empty {
  color: #cbd5e1;
  background: transparent;
  border: 1px dashed #e2e8f0;
  pointer-events: none;
  opacity: 0.6;
}
.ex-bridge__socials {
  display: flex;
  width: 100%;
  gap: .4rem;
}
.ex-si {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 36px;
  background: color-mix(in srgb, var(--expert-primary, #5e72e4) 8%, #fff);
  border: 1px solid color-mix(in srgb, var(--expert-primary, #5e72e4) 20%, #e2e8f0);
  border-radius: 6px;
  color: var(--expert-primary, #5e72e4);
  transition: all .2s ease;
  text-decoration: none;
}
.ex-si:hover {
  background: var(--expert-primary, #5e72e4);
  color: #fff;
  border-color: var(--expert-primary, #5e72e4);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px color-mix(in srgb, var(--expert-primary, #5e72e4) 30%, transparent);
}
.ex-si--empty {
  color: #cbd5e1;
  background: transparent;
  border: 1px dashed #e2e8f0;
  pointer-events: none;
  opacity: 0.2;
}
.ex-btn--sm {
  padding: .55rem 1rem;
  font-size: .82rem;
}
.ex-btn--block {
  width: 100%;
  justify-content: center;
  text-align: center;
}

/* ── Body Layout ─────────────────────────────────────────────── */
.ex-body {
  display: grid;
  grid-template-columns: 3fr 2fr;
  gap: 1.5rem;
  padding: 1.75rem 2rem 3rem;
  align-items: start;
}
.ex-main  { min-width: 0; }
.ex-aside { position: sticky; top: 1.5rem; display: flex; flex-direction: column; gap: .875rem; }

/* ── Content Sections ────────────────────────────────────────── */
.ex-sec {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: var(--expert-radius, 8px);
  padding: 1.5rem 1.75rem;
  margin-bottom: 1.125rem;
  box-shadow: 0 1px 3px rgba(0,0,0,.03);
}
.ex-sec:last-child { margin-bottom: 0; }
.ex-sec__title {
  font-size: .95rem;
  font-weight: 700;
  color: #1e293b;
  margin: 0 0 1.125rem;
  padding-bottom: .5rem;
  display: flex;
  align-items: center;
  gap: .4rem;
  border-bottom: 2px solid #f1f5f9;
}

/* ── Zähler-Badge (z. B. Anzahl Projekte in Überschrift) ─────── */
.ex-count-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--expert-primary, #5e72e4);
  color: #fff;
  font-size: .72rem;
  font-weight: 700;
  margin-left: .3rem;
}

/* ── Events Grid & Cards ─────────────────────────────────────── */
.ex-ev-subhead {
  font-size: .8rem;
  font-weight: 700;
  letter-spacing: .04em;
  color: #475569;
  text-transform: uppercase;
  margin: .15rem 0 .6rem;
}
.ex-ev-subhead--gap { margin-top: 1.25rem; }
.ex-ev-grid-v2 { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: .75rem; }
.ex-ev-v2 {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  padding: .875rem 1rem;
  font-size: .84rem;
  transition: background .18s, border-color .18s;
}
.ex-ev-v2:hover           { background: #f0f9ff; border-color: #bae6fd; }
.ex-ev-v2--future         { border-left: 3px solid var(--expert-primary, #5e72e4); }
.ex-ev-v2--past           { opacity: .7; }
.ex-ev-v2__date  { font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--expert-primary, #5e72e4); margin-bottom: .25rem; }
.ex-ev-v2__title { font-size: .88rem; font-weight: 700; color: #1e293b; margin-bottom: .3rem; }
.ex-ev-v2__meta  { font-size: .75rem; color: #94a3b8; }
.ex-ev-v2--past .ex-ev-v2__date { color: #94a3b8; }
.ex-ev-v2__badge { display: inline-block; padding: .15rem .5rem; border-radius: 50px; font-size: .7rem; font-weight: 600; margin-top: .35rem; }
.ex-ev-v2__badge--online { background: #dbeafe; color: #1e40af; }

/* ── WYSIWYG / Fließtext ─────────────────────────────────────── */
.ex-wysiwyg-content {
  line-height: 1.75;
  color: #334155;
  font-size: .95rem;
}

/* ── Auszeichnungen ──────────────────────────────────────────── */
.ex-award {
  font-size: .82rem;
  color: #d97706;
  margin-bottom: .3rem;
}

/* ── Abschnitts-Unterüberschriften ──────────────────────────── */
.ex-sub-heading {
  font-size: .78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: #94a3b8;
  margin: .875rem 0 .5rem;
}

/* ── Ausbildungs-Beschreibung ────────────────────────────────── */
.ex-edu-desc {
  font-size: .8rem;
  color: #64748b;
  margin-top: .3rem;
}

/* ── Case-Study Ergebnis ─────────────────────────────────────── */
.ex-cs-result {
  font-size: .8rem;
  color: #16a34a;
  margin-top: .3rem;
  font-weight: 600;
}

/* ── Pills ───────────────────────────────────────────────────── */
.ex-pills          { display: flex; flex-wrap: wrap; gap: .5rem; }
.ex-pills--mb      { margin-bottom: .5rem; }
.ex-pill {
  display: inline-flex;
  align-items: center;
  padding: .35rem .875rem;
  border-radius: 6px;
  font-size: .85rem;
  font-weight: 500;
  background: #ffffff;
  color: #334155;
  border: 1px solid #e2e8f0;
  box-shadow: 0 1px 2px rgba(0,0,0,.02);
  transition: transform .15s, box-shadow .15s;
}
.ex-pill:hover {
  transform: translateY(-1px);
  box-shadow: 0 3px 6px rgba(0,0,0,.04);
}
.ex-pill::before {
  content: "";
  display: block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  margin-right: .5rem;
  background: #cbd5e1;
}
.ex-pill--soft { border-color: #dcfce7; }
.ex-pill--soft::before { background: #22c55e; }
.ex-pill--tech { border-color: #dbeafe; }
.ex-pill--tech::before { background: #3b82f6; }
.ex-pill--spec { border-color: #f3e8ff; }
.ex-pill--spec::before { background: #a855f7; }

/* ── Skills Grid ─────────────────────────────────────────────── */
.ex-skills-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: .75rem;
  margin-bottom: .75rem;
  width: 100%;
}
/* Persönliche Stärken: 2-spaltig */
.ex-skills-grid--soft {
  grid-template-columns: repeat(2, 1fr);
}

/* ── Skill Items ─────────────────────────────────────────────── */
.ex-skill-item {
  display: flex;
  align-items: center;
  padding: .6rem 1rem;
  background: #ffffff;
  border-radius: 8px;
  border: 1px solid #e2e8f0;
  box-shadow: 0 1px 2px rgba(0,0,0,.02);
  transition: transform .15s, box-shadow .15s;
}
.ex-skill-item:hover {
  transform: translateY(-1px);
  box-shadow: 0 3px 8px rgba(0,0,0,.04);
}
.ex-skill-item__name { font-weight: 600; color: #1e293b; font-size: .85rem; }

/* ── Projekt Items ───────────────────────────────────────────── */
.ex-proj-item {
  padding: .875rem 1rem;
  border-radius: 10px;
  background: #fafbfc;
  border: 1px solid #f1f5f9;
  margin-bottom: .625rem;
  transition: background .15s, border-color .15s;
}
.ex-proj-item:last-child       { margin-bottom: 0; }
.ex-proj-item:hover            { background: #f0f4ff; border-color: #c7d2fe; }
.ex-proj-item__name            { font-weight: 700; color: #1e293b; font-size: .9rem; margin-bottom: .25rem; }
.ex-proj-item__meta            { font-size: .75rem; color: #94a3b8; margin-bottom: .375rem; }
.ex-proj-item__meta a          { color: var(--expert-primary, #5e72e4); }
.ex-proj-item__desc            { font-size: .82rem; color: #475569; line-height: 1.65; }
.ex-proj-item__tags            { display: flex; flex-wrap: wrap; gap: .3rem; margin-top: .5rem; }
.ex-proj-item__tag             { padding: .15rem .5rem; border-radius: 4px; font-size: .7rem; background: #eff6ff; color: #1d4ed8; font-weight: 600; }

/* ── Ausbildungs-Items ───────────────────────────────────────── */
.ex-edu-item {
  display: flex;
  flex-direction: column;
  gap: .2rem;
  padding: .75rem .875rem;
  border-radius: 8px;
  background: #f8fafc;
  border-left: 3px solid var(--expert-primary, #5e72e4);
  margin-bottom: .5rem;
}
.ex-edu-item:last-child { margin-bottom: 0; }
.ex-edu-item__deg  { font-weight: 700; font-size: .88rem; color: #1e293b; }
.ex-edu-item__inst { font-size: .8rem; color: #475569; }
.ex-edu-item__meta { font-size: .73rem; color: #94a3b8; }

/* ── Zertifikate Grid ──────────────────────────────────────── */
.ex-cert-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: .75rem;
}
.ex-cert-item {
  display: flex;
  flex-direction: column;
  gap: .3rem;
  padding: .875rem 1rem;
  background: #ffffff;
  border-radius: 10px;
  border: 1px solid #e2e8f0;
  box-shadow: 0 1px 3px rgba(0,0,0,.04);
  transition: transform .15s, box-shadow .15s;
}
.ex-cert-item:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 10px rgba(0,0,0,.06);
}
.ex-cert-item__name { font-weight: 700; font-size: .83rem; color: #1e293b; line-height: 1.3; }
.ex-cert-item__issuer { font-size: .76rem; color: var(--expert-primary, #5e72e4); font-weight: 600; }
.ex-cert-item__meta { font-size: .7rem; color: #94a3b8; margin-top: auto; padding-top: .25rem; }

/* ── Karrierestationen ───────────────────────────────────────── */
.ex-career-item {
  position: relative;
  padding: .875rem 1.125rem .875rem 1.5rem;
  border-left: 2px solid var(--expert-primary, #5e72e4);
  margin-bottom: .75rem;
}
.ex-career-item::before {
  content: '';
  position: absolute;
  left: -5px;
  top: .975rem;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--expert-primary, #5e72e4);
  border: 2px solid #fff;
  box-shadow: 0 0 0 2px var(--expert-primary, #5e72e4);
}
.ex-career-item:last-child   { margin-bottom: 0; }
.ex-career-item__role { font-weight: 700; font-size: .9rem; color: #1e293b; }
.ex-career-item__co   { font-size: .82rem; color: #5e72e4; font-weight: 600; }
.ex-career-item__meta { font-size: .75rem; color: #94a3b8; margin: .2rem 0; }
.ex-career-item__desc { font-size: .82rem; color: #475569; line-height: 1.65; }

/* ── Testimonials ────────────────────────────────────────────── */
.ex-testi-item {
  padding: 1rem 1.125rem;
  background: #fafbfc;
  border-radius: 10px;
  border-left: 3px solid var(--expert-primary, #5e72e4);
  margin-bottom: .625rem;
}
.ex-testi-item:last-child  { margin-bottom: 0; }
.ex-testi-item__text { font-size: .88rem; color: #334155; line-height: 1.7; font-style: italic; margin-bottom: .5rem; }
.ex-testi-item__by   { font-size: .75rem; font-weight: 700; color: #475569; }

/* ── Sprachfortschritt ───────────────────────────────────────── */
.ex-progress-list { display: flex; flex-direction: column; gap: .5rem; }
.ex-progress-item { display: flex; flex-direction: column; gap: .25rem; }
.ex-progress-item__label { font-size: .8rem; font-weight: 600; color: #334155; display: flex; justify-content: space-between; }
.ex-progress-item__bar   { height: 6px; border-radius: 3px; background: #e2e8f0; overflow: hidden; }
.ex-progress-item__fill  { height: 100%; border-radius: 3px; background: linear-gradient(90deg, var(--expert-primary, #5e72e4), var(--expert-accent, #8965e0)); }

/* ── Konferenz-Items ─────────────────────────────────────────── */
.ex-conf-item {
  padding: .625rem .875rem;
  border-radius: 8px;
  background: #fafbfc;
  border: 1px solid #f1f5f9;
  margin-bottom: .375rem;
}
.ex-conf-item:last-child  { margin-bottom: 0; }
.ex-conf-item__title { font-weight: 700; font-size: .85rem; color: #1e293b; }
.ex-conf-item__meta  { font-size: .73rem; color: #94a3b8; margin-top: .2rem; }

/* ── Sidebar Cards (ex-sc) ───────────────────────────────────── */
.ex-sc {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: var(--expert-radius, 8px);
  padding: 1.25rem 1.375rem;
  box-shadow: 0 1px 3px rgba(0,0,0,.03);
}
.ex-sc__title { font-size: .875rem; font-weight: 700; color: #1e293b; margin: 0 0 1rem; border-bottom: 2px solid #f1f5f9; padding-bottom: .4rem; }

/* ── Info-Rows ────────────────────────────────────────────────── */
.ex-info-rows { display: flex; flex-direction: column; }
.ex-info-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: .75rem;
  padding: .45rem 0;
  border-bottom: 1px solid #f8fafc;
}
.ex-info-row:last-child   { border-bottom: none; }
.ex-info-row__lbl { font-size: .8rem; font-weight: 600; color: #64748b; flex-shrink: 0; }
.ex-info-row__val { font-size: .85rem; font-weight: 500; color: #1e293b; text-align: right; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ex-info-row__val a { color: var(--expert-primary, #5e72e4); text-decoration: none; }
.ex-info-row__val a:hover { text-decoration: underline; }

/* ── Buttons ─────────────────────────────────────────────────── */
.ex-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  padding: .875rem 1.5rem;
  width: 100%;
  box-sizing: border-box;
  font-size: .9rem;
  font-weight: 700;
  border-radius: 10px;
  border: none;
  cursor: pointer;
  text-decoration: none;
  color: #fff;
  margin-bottom: .5rem;
  background: linear-gradient(135deg, var(--expert-accent, #8965e0), var(--expert-primary, #5e72e4));
  box-shadow: 0 4px 16px color-mix(in srgb, var(--expert-primary, #5e72e4) 28%, transparent);
  transition: all .2s cubic-bezier(.4,0,.2,1);
}
.ex-btn:last-child  { margin-bottom: 0; }
.ex-btn:hover       { transform: translateY(-2px); box-shadow: 0 8px 24px color-mix(in srgb, var(--expert-primary, #5e72e4) 36%, transparent); }
.ex-btn--ghost      { background: #f5f3ff; color: var(--expert-primary, #5e72e4); box-shadow: none; border: 1.5px solid color-mix(in srgb, var(--expert-primary, #5e72e4) 25%, #fff); }
.ex-btn--ghost:hover { background: #ede9fe; box-shadow: none; }
.ex-btn--no-margin  { margin: 0; }

/* ── Social-Leiste ───────────────────────────────────────────── */
.ex-social-row { display: flex; flex-wrap: wrap; gap: .5rem; }
.ex-si {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 8px;
  background: #f8fafc;
  color: #334155;
  text-decoration: none;
  border: 1px solid #e2e8f0;
  transition: background .15s, transform .15s;
}
.ex-si:hover { background: color-mix(in srgb, var(--expert-primary, #5e72e4) 10%, #fff); transform: translateY(-2px); }

/* ── Services / Checkmarks ───────────────────────────────────── */
.ex-svc-check { display: grid; grid-template-columns: 1fr 1fr; gap: .35rem .75rem; }
.ex-svc-row {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-size: .82rem;
  color: #334155;
}
.ex-svc-row::before { content: '✓'; color: #16a34a; font-weight: 700; flex-shrink: 0; }

/* ── Claim-Banner ───────────────────────────────────────────── */
.ex-claim-banner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
  padding: .75rem 2rem;
  background: #fffbeb;
  border-top: 2px solid #fde68a;
  font-size: .8rem;
  color: #92400e;
}
.ex-claim-banner__text strong { display: block; font-weight: 700; margin-bottom: .1rem; }
.ex-claim-banner__btn {
  white-space: nowrap;
  padding: .4rem 1rem;
  border-radius: 6px;
  font-size: .76rem;
  font-weight: 700;
  background: #d97706;
  color: #fff;
  text-decoration: none;
  transition: background .15s;
  flex-shrink: 0;
}
.ex-claim-banner__btn:hover { background: #b45309; }

/* ── Responsive ──────────────────────────────────────────────── */
@media (max-width: 900px) {
  .ex-skills-grid                          { grid-template-columns: repeat(2, 1fr); }
  .ex-skills-grid.ex-skills-grid--soft     { grid-template-columns: repeat(2, 1fr); }
  .ex-ev-grid-v2                           { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 768px) {
  .ex-bridge        { grid-template-columns: 1fr; margin-top: -40px; padding: 0 1rem; gap: 1rem; }
  .ex-body          { grid-template-columns: 1fr; padding: 1.25rem 1rem 2rem; gap: 1.25rem; }
  .ex-bridge__text::after { background: linear-gradient(to bottom, transparent, #fff); }
  .ex-skills-grid                          { grid-template-columns: repeat(2, 1fr); }
  .ex-skills-grid.ex-skills-grid--soft     { grid-template-columns: repeat(2, 1fr); }
  .ex-ev-grid-v2                           { grid-template-columns: 1fr 1fr; }
  .ex-aside         { position: static; }
  .ex-hero          { height: 300px; min-height: 300px; max-height: 300px; }
  .ex-hero__inner   { padding: 1.25rem 1rem; gap: 1.25rem; }
  .ex-hero__av      { width: 96px; height: 96px; }
  .ex-hero__badges  { top: .5rem; right: 0; max-width: 65%; }
  .ex-hero__name    { font-size: 1.25rem; }
  .ex-hero__spec-pills { gap: .2rem; padding-top: .3rem; }
  .ex-bc            { padding: .6rem 1rem; }
}
@media (max-width: 480px) {
  .ex-bridge        { margin-top: -30px; }
  .ex-ev-grid-v2    { grid-template-columns: 1fr; }
  .ex-hero          { height: auto; min-height: 280px; max-height: none; }
  .ex-hero__inner   { flex-direction: column; align-items: flex-start; padding: 3rem 1rem 1.25rem; }
  .ex-hero__badges  { position: absolute; top: .5rem; right: .75rem; left: .75rem; max-width: none; }
  .ex-hero__av      { width: 80px; height: 80px; }
}
