/* ============================================================
   site.css — Daniel Harth · EventProducing
   Layout, Komponenten, Bänder, Footer, Responsive.
   ============================================================ */

/* ---------- Reset / Base ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--fs-body);
  line-height: var(--lh-normal);
  color: var(--text-body);
  background: var(--surface-page);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
h1, h2, h3, h4, p { margin: 0; }
button { font-family: inherit; }
:focus-visible { outline: 2px solid var(--dh-orange); outline-offset: 2px; border-radius: 2px; }

/* ---------- Layout helpers ---------- */
.container { max-width: var(--container); margin: 0 auto; padding: 0 var(--gutter); }
.container-narrow { max-width: var(--container-narrow); margin: 0 auto; padding: 0 var(--gutter); }
.section { padding: var(--section-y) 0; }
.section--page { background: var(--surface-page); }
.section--card { background: var(--surface-card); }
.section--dark { background: var(--dh-anthracite); }
.visually-hidden {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}

/* ---------- Eyebrow ---------- */
.eyebrow {
  font-family: var(--font-body);
  font-size: var(--fs-eyebrow);
  text-transform: uppercase;
  letter-spacing: var(--ls-eyebrow);
  font-weight: var(--fw-medium);
  color: var(--dh-orange);
}

/* ---------- Section heading ---------- */
.section-heading { text-align: center; max-width: 720px; margin: 0 auto; }
.section-heading--left { text-align: left; margin: 0; }
.section-heading .eyebrow { display: block; margin-bottom: 14px; }
.section-heading h2 {
  font-family: var(--font-display);
  font-weight: var(--fw-light);
  font-size: var(--fs-h2);
  line-height: var(--lh-snug);
  letter-spacing: var(--ls-tight);
  color: var(--text-strong);
}
.section-heading .lead {
  font-size: var(--fs-lead);
  line-height: var(--lh-normal);
  color: var(--text-muted);
  margin-top: 18px;
}

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  font-family: var(--font-body);
  font-weight: var(--fw-semibold);
  line-height: 1;
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  cursor: pointer;
  text-align: center;
  transition: background var(--dur-base) var(--ease-standard),
              color var(--dur-base) var(--ease-standard),
              border-color var(--dur-base) var(--ease-standard),
              box-shadow var(--dur-base) var(--ease-standard);
}
.btn--sm { padding: 8px 16px;  font-size: 0.8125rem; }
.btn--md { padding: 12px 24px; font-size: 0.9375rem; }
.btn--lg { padding: 16px 32px; font-size: 1.0625rem; }

.btn--primary { background: var(--dh-orange); color: var(--text-on-accent); border-color: var(--dh-orange); }
.btn--primary:hover { background: var(--dh-orange-600); border-color: var(--dh-orange-600); box-shadow: var(--shadow-accent); }

.btn--secondary { background: transparent; color: var(--text-strong); border-color: var(--border-strong); }
.btn--secondary:hover { background: var(--dh-anthracite); color: var(--text-on-dark); }

/* on dark surfaces: light-outline ghost */
.btn--ghost-light {
  background: transparent; color: var(--text-on-dark);
  border-color: rgba(246, 244, 239, 0.5);
}
.btn--ghost-light:hover { background: var(--dh-offwhite); color: var(--dh-anthracite); border-color: var(--dh-offwhite); }

.link-arrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-weight: var(--fw-semibold); color: var(--dh-orange);
  background: none; border: none; cursor: pointer; padding: 8px 0;
}
.link-arrow svg { transition: transform var(--dur-base) var(--ease-standard); }
.link-arrow:hover svg { transform: translateX(4px); }

/* ---------- Header ---------- */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(246, 244, 239, 0.92);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--border-subtle);
}
.site-header__inner {
  max-width: var(--container); margin: 0 auto; padding: 0 var(--gutter);
  height: 76px; display: flex; align-items: center; justify-content: space-between; gap: 24px;
}
.site-header__logo img { height: 46px; width: auto; }
.site-nav { display: flex; gap: 30px; align-items: center; }
.site-nav a {
  font-size: 13px; text-transform: uppercase; letter-spacing: var(--ls-caps);
  font-weight: var(--fw-medium); color: var(--text-strong);
  transition: color var(--dur-base) var(--ease-standard);
}
.site-nav a:hover, .site-nav a[aria-current="page"] { color: var(--dh-orange); }
.site-header__cta { display: inline-flex; }
.nav-toggle {
  display: none; align-items: center; justify-content: center;
  width: 48px; height: 48px; border: none; background: transparent;
  color: var(--text-strong); cursor: pointer; margin-right: -12px;
}
.mobile-nav { display: none; border-top: 1px solid var(--border-subtle); background: var(--surface-page); }
.mobile-nav.is-open { display: block; }
.mobile-nav nav {
  max-width: var(--container); margin: 0 auto; padding: 8px var(--gutter) 18px;
  display: flex; flex-direction: column;
}
.mobile-nav a {
  font-size: 14px; text-transform: uppercase; letter-spacing: var(--ls-caps);
  font-weight: var(--fw-medium); color: var(--text-strong);
  padding: 14px 0; border-bottom: 1px solid var(--border-subtle);
}
.mobile-nav .btn { margin-top: 18px; }

/* ---------- Hero ---------- */
.hero {
  position: relative; min-height: 644px; display: flex; align-items: center;
  overflow: hidden; background: var(--dh-anthracite);
}
.hero__slideshow { position: absolute; inset: 0; }
.hero__slideshow img {
  position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover;
  opacity: 0; transition: opacity 1.2s var(--ease-standard);
}
.hero__slideshow img.is-active { opacity: 1; }
.hero__scrim {
  position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(90deg, rgba(26,26,26,.9) 0%, rgba(26,26,26,.55) 52%, rgba(26,26,26,.12) 100%);
}
.hero__inner { position: relative; max-width: var(--container); margin: 0 auto; padding: 0 var(--gutter); width: 100%; }
.hero__content { max-width: 680px; }
.hero .eyebrow { display: block; margin-bottom: 22px; letter-spacing: var(--ls-eyebrow); }
.hero h1 {
  font-family: var(--font-display); font-weight: var(--fw-light);
  font-size: var(--fs-display); line-height: 1.06; letter-spacing: var(--ls-display);
  color: var(--text-on-dark); margin-bottom: 20px;
}
.hero__lead {
  font-size: 1.25rem; line-height: var(--lh-normal);
  color: var(--text-on-dark-muted); margin-bottom: 36px; max-width: 48ch;
}
.hero__actions { display: flex; gap: 14px; flex-wrap: wrap; }

/* ---------- Stat rows ---------- */
.stats-inline { display: flex; gap: 48px; margin-top: 52px; flex-wrap: wrap; }
.stat__num { font-family: var(--font-display); font-weight: var(--fw-light); font-size: 2.5rem; color: var(--dh-orange); line-height: 1; }
.stat__label { font-size: 12px; text-transform: uppercase; letter-spacing: var(--ls-caps); color: var(--text-on-dark-muted); margin-top: 8px; }

.stats-band .container { display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; text-align: center; }
.stats-band { padding: 64px 0; }
.stats-band .stat__num { font-size: 3rem; }
.stats-band .stat__label { margin-top: 10px; }

/* ---------- Feature items (pillars / services) ---------- */
.feature-grid { display: grid; gap: 48px; margin-top: 48px; }
.feature-grid--3 { grid-template-columns: repeat(3, 1fr); }
.feature-grid--4 { grid-template-columns: repeat(4, 1fr); gap: 40px; margin-top: 56px; }
.feature-item { text-align: center; }
.feature-item__icon {
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--dh-orange); margin-bottom: 18px;
}
.feature-item h3 {
  font-family: var(--font-display); font-weight: var(--fw-medium);
  font-size: var(--fs-h4); color: var(--text-strong); margin-bottom: 10px;
}
.feature-item p { font-size: 1rem; line-height: 1.55; color: var(--text-muted); }

/* ---------- Pain → Solution ---------- */
.pain-list { display: flex; flex-direction: column; gap: 14px; margin-top: 48px; }
.pain-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.pain-cell { display: flex; gap: 14px; align-items: flex-start; border-radius: var(--radius-md); padding: 20px 22px; }
.pain-cell--problem { background: var(--dh-lightgray); }
.pain-cell--problem .pain-icon { color: var(--dh-ink-400); }
.pain-cell--problem span:last-child { color: var(--text-body); }
.pain-cell--solution { background: var(--dh-orange-050); border: 1px solid var(--dh-orange-200); }
.pain-cell--solution .pain-icon { color: var(--dh-orange); }
.pain-cell--solution span:last-child { color: var(--text-strong); }
.pain-icon { display: inline-flex; flex: none; margin-top: 1px; }
.pain-cell span:last-child { font-size: 1rem; line-height: 1.55; }

/* ---------- Gallery (bento) ---------- */
.gallery {
  display: grid; grid-template-columns: repeat(3, 1fr);
  grid-auto-rows: 240px; gap: 14px; margin-top: 48px;
}
.gallery figure { margin: 0; overflow: hidden; border-radius: 8px; background: #000; }
.gallery figure img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--dur-slow) var(--ease-out); }
.gallery figure:hover img { transform: scale(1.04); }
.gallery .gallery--feature { grid-column: span 2; grid-row: span 2; }

/* ---------- Reference cards ---------- */
.ref-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 56px; }
.ref-card {
  display: block; border-radius: var(--radius-lg); overflow: hidden;
  border: 1px solid var(--border-subtle); background: var(--surface-card);
  transition: box-shadow var(--dur-base) var(--ease-standard), transform var(--dur-base) var(--ease-standard);
}
.ref-card:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); }
.ref-card__media { position: relative; height: 220px; background: #000; overflow: hidden; }
.ref-card__media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.ref-card__body { padding: 22px 24px; }
.ref-card__kicker { font-size: 11px; font-weight: var(--fw-semibold); text-transform: uppercase; letter-spacing: .1em; color: var(--dh-orange); margin-bottom: 8px; }
.ref-card h3 { font-family: var(--font-display); font-weight: var(--fw-medium); font-size: 1.1875rem; line-height: var(--lh-snug); color: var(--text-strong); }

/* ---------- Testimonials ---------- */
.testimonial {
  margin-top: 48px; background: var(--surface-card);
  border: 1px solid var(--border-subtle); border-radius: 8px; padding: 48px;
}
.testimonial__mark { display: inline-flex; color: var(--dh-orange); }
.testimonial__quote { font-size: 1.25rem; line-height: var(--lh-relaxed); color: var(--text-body); margin: 18px 0 28px; min-height: 3.5em; }
.testimonial__foot { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 16px; }
.testimonial__name { font-weight: var(--fw-semibold); color: var(--text-strong); }
.testimonial__role { font-size: var(--fs-small); color: var(--text-muted); }
.testimonial__dots { display: flex; gap: 8px; align-items: center; }
.dot { height: 9px; width: 9px; border: none; border-radius: var(--radius-pill); background: var(--dh-ink-300); cursor: pointer; padding: 0; transition: all var(--dur-base) var(--ease-standard); }
.dot.is-active { width: 26px; background: var(--dh-orange); }

/* ---------- CTA band ---------- */
.cta-band { padding: var(--section-y) 0; }
.cta-band .container-narrow { text-align: center; }
.cta-band h2 { font-family: var(--font-display); font-weight: var(--fw-light); font-size: clamp(2rem, 4vw, 2.75rem); line-height: 1.12; color: var(--text-on-dark); margin-bottom: 18px; }
.cta-band p { font-size: 1.1875rem; line-height: var(--lh-normal); color: var(--text-on-dark-muted); margin-bottom: 32px; }
.cta-band__actions { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }

.center-actions { text-align: center; margin-top: 52px; }

/* ---------- Footer ---------- */
.site-footer { background: var(--dh-anthracite); color: var(--text-on-dark-muted); padding: 44px 0 24px; }
.site-footer__grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 48px; }
.site-footer__logo img { height: 36px; width: auto; margin-bottom: 12px; }
.site-footer__tag { font-size: 0.95rem; line-height: var(--lh-normal); max-width: 36ch; color: var(--text-on-dark-muted); }
.site-footer h4 { font-size: 12px; text-transform: uppercase; letter-spacing: var(--ls-caps); color: var(--text-on-dark); margin-bottom: 12px; font-weight: var(--fw-semibold); }
.site-footer ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 8px; font-size: 0.95rem; }
.site-footer a { color: var(--text-on-dark-muted); transition: color var(--dur-base) var(--ease-standard); }
.site-footer a:hover { color: var(--dh-orange-400); }
.site-footer__bottom {
  margin-top: 32px; padding-top: 18px; border-top: 1px solid var(--border-on-dark);
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: 12px;
  font-size: var(--fs-small); color: var(--dh-ink-500);
}
.site-footer__bottom a { color: var(--dh-ink-300); }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 960px) {
  .site-nav, .site-header__cta { display: none; }
  .nav-toggle { display: inline-flex; }
  .feature-grid--4 { grid-template-columns: repeat(2, 1fr); }
  .ref-grid { grid-template-columns: repeat(2, 1fr); }
  .stats-band .container { grid-template-columns: repeat(2, 1fr); gap: 40px 24px; }
  .site-footer__grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 640px) {
  .hero { min-height: 560px; }
  .feature-grid--3, .feature-grid--4, .ref-grid { grid-template-columns: 1fr; }
  .pain-row { grid-template-columns: 1fr; gap: 10px; }
  .gallery { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 180px; }
  .gallery .gallery--feature { grid-column: span 2; grid-row: span 1; }
  .testimonial { padding: 32px 24px; }
  .stats-inline { gap: 28px 36px; }
  .site-footer__grid { grid-template-columns: 1fr; gap: 36px; }
  .stats-band .container { grid-template-columns: repeat(2, 1fr); }
}

/* ============================================================
   Phase B — Unterseiten (Hero, Artikel, Referenzen, Kontakt, Recht)
   Gleiches Token-System, gleiche Designsprache wie oben.
   ============================================================ */

/* ---------- Seiten-Hero (kompakt, mit Bild) ---------- */
.page-hero {
  position: relative; min-height: 480px; display: flex; align-items: flex-end;
  overflow: hidden; background: var(--dh-anthracite);
  padding-top: 56px;
}
.page-hero__media { position: absolute; inset: 0; }
.page-hero__media img { width: 100%; height: 100%; object-fit: cover; }
.page-hero__scrim {
  position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(180deg, rgba(26,26,26,.6) 0%, rgba(26,26,26,.42) 40%, rgba(26,26,26,.93) 100%);
}
.page-hero__inner {
  position: relative; width: 100%; max-width: var(--container);
  margin: 0 auto; padding: 0 var(--gutter) 52px;
}
.page-hero .eyebrow { display: block; margin-bottom: 18px; color: var(--dh-orange-400); }
.page-hero h1 {
  font-family: var(--font-display); font-weight: var(--fw-light);
  font-size: clamp(2.5rem, 5vw, 4rem); line-height: 1.08; letter-spacing: var(--ls-display);
  color: var(--text-on-dark); margin-bottom: 18px; max-width: 22ch;
}
.page-hero__lead { font-size: 1.1875rem; line-height: var(--lh-normal); color: var(--text-on-dark-muted); max-width: 60ch; }

/* Heller Seiten-Hero ohne Bild (z. B. Recht, Kontakt) */
.page-head { background: var(--surface-page); padding: 72px 0 0; }
.page-head .container { max-width: 820px; }
.page-head .eyebrow { display: block; margin-bottom: 14px; }
.page-head h1 {
  font-family: var(--font-display); font-weight: var(--fw-light);
  font-size: var(--fs-h1); line-height: var(--lh-snug); letter-spacing: var(--ls-tight);
  color: var(--text-strong); margin-bottom: 18px;
}
.page-head__lead { font-size: var(--fs-lead); line-height: var(--lh-normal); color: var(--text-muted); max-width: 60ch; }

/* ---------- Service-Detailkarten (Leistungen) ---------- */
.service-list { display: flex; flex-direction: column; gap: 28px; max-width: 1100px; margin: 0 auto; }
.service-card {
  background: var(--surface-card); border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg); padding: 40px; display: grid;
  grid-template-columns: 56px 1fr; gap: 28px; box-shadow: var(--shadow-xs);
}
.service-card__icon { color: var(--dh-orange); }
.service-card h2 {
  font-family: var(--font-display); font-weight: var(--fw-medium); font-size: 1.5rem;
  line-height: var(--lh-snug); color: var(--text-strong); margin-bottom: 6px;
}
.service-card__lead { font-size: 1.0625rem; color: var(--dh-orange); font-weight: var(--fw-medium); margin-bottom: 16px; }
.service-card p { font-size: 1.0625rem; line-height: var(--lh-relaxed); color: var(--text-body); }
.service-card__points { list-style: none; margin: 18px 0 0; padding: 0; display: flex; flex-wrap: wrap; gap: 10px 18px; }
.service-card__points li {
  display: inline-flex; align-items: center; gap: 9px;
  font-size: 0.95rem; color: var(--text-strong);
}
.service-card__points li::before {
  content: ""; width: 7px; height: 7px; border-radius: 50%;
  background: var(--dh-orange); flex: none;
}
.service-card__einsatz {
  margin-top: 20px; padding: 16px 20px; background: var(--dh-orange-050);
  border: 1px solid var(--dh-orange-200); border-radius: var(--radius-md);
  font-size: 0.98rem; line-height: var(--lh-normal); color: var(--text-strong);
}
.service-card__einsatz strong { color: var(--dh-orange-700); }

/* ---------- Referenz-Übersicht (volle Liste) ---------- */
.ref-grid--all { grid-template-columns: repeat(2, 1fr); }
.ref-card__tags { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 12px; }
.ref-card__tags span {
  font-size: 11px; letter-spacing: .04em; color: var(--text-muted);
  background: var(--dh-lightgray); border-radius: var(--radius-pill); padding: 4px 11px;
}
.ref-card__lead { font-size: 0.98rem; line-height: var(--lh-normal); color: var(--text-muted); margin-top: 12px; }

/* ---------- Referenz-Detail / Artikel-Typografie ---------- */
.article { max-width: 760px; margin: 0 auto; padding: 0; }
.article__meta { display: flex; gap: 14px; align-items: center; flex-wrap: wrap; margin-bottom: 16px; }
.article__cat { font-size: 11px; font-weight: var(--fw-semibold); text-transform: uppercase; letter-spacing: .1em; color: var(--dh-orange); }
.article__date { font-size: var(--fs-small); color: var(--text-muted); }
.article__tags { display: flex; flex-wrap: wrap; gap: 8px; margin: 8px 0 26px; }
.article__tags span {
  font-size: 12px; color: var(--text-muted);
  background: var(--dh-lightgray); border-radius: var(--radius-pill); padding: 5px 13px;
}
.article__lead { font-size: 1.1875rem; line-height: var(--lh-normal); color: var(--text-strong); margin-bottom: 8px; }

.prose { color: var(--text-body); }
.prose > * + * { margin-top: 18px; }
.prose p { font-size: 1.0625rem; line-height: var(--lh-relaxed); color: var(--text-body); }
.prose h2 {
  font-family: var(--font-display); font-weight: var(--fw-medium); font-size: 1.5rem;
  line-height: var(--lh-snug); letter-spacing: -.01em; color: var(--text-strong);
  margin-top: 40px;
}
.prose h3 {
  font-family: var(--font-display); font-weight: var(--fw-semibold); font-size: 1.3125rem;
  line-height: var(--lh-snug); color: var(--text-strong); margin-top: 30px;
}
.prose h4 {
  font-family: var(--font-body); font-weight: var(--fw-bold); font-size: 1.0625rem;
  color: var(--text-strong); margin-top: 22px;
}
.prose ul { list-style: none; margin: 0; padding: 0; }
.prose ul li {
  display: flex; gap: 12px; align-items: flex-start; margin-top: 10px;
  font-size: 1.0625rem; line-height: var(--lh-normal); color: var(--text-body);
}
.prose ul li::before { content: "–"; color: var(--dh-orange); font-weight: var(--fw-bold); flex: none; margin-top: 1px; }
.prose ul li strong { color: var(--text-strong); }
.prose blockquote {
  margin: 0; padding: 14px 22px; border-left: 3px solid var(--dh-orange);
  background: var(--dh-orange-050); font-size: 1.0625rem; line-height: var(--lh-normal);
  color: var(--text-strong); font-style: italic;
}
.prose a { color: var(--dh-orange); text-decoration: underline; text-underline-offset: 2px; }
.prose a:hover { color: var(--dh-orange-600); }

.article__quote {
  margin: 36px 0 0; padding: 28px 32px; background: var(--dh-orange-050);
  border: 1px solid var(--dh-orange-200); border-radius: var(--radius-lg);
}
.article__quote blockquote { margin: 0; font-size: 1.125rem; line-height: var(--lh-normal); color: var(--text-strong); font-style: italic; }
.article__quote figcaption { margin-top: 14px; font-size: var(--fs-small); }
.article__quote .qn { font-weight: var(--fw-semibold); color: var(--text-strong); }
.article__quote .qr { color: var(--text-muted); }

.article__nav {
  max-width: 760px; margin: 0 auto; padding: 28px 0 0;
  display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap;
  border-top: 1px solid var(--border-subtle);
}

/* ---------- Kontakt ---------- */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; max-width: 1000px; margin: 0 auto; align-items: start; }
.contact-methods { display: flex; flex-direction: column; gap: 16px; }
.contact-method {
  display: flex; gap: 16px; align-items: flex-start; padding: 20px 22px;
  background: var(--surface-card); border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg); transition: box-shadow var(--dur-base) var(--ease-standard), transform var(--dur-base) var(--ease-standard);
}
a.contact-method:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.contact-method__icon {
  flex: none; width: 44px; height: 44px; border-radius: 50%;
  background: var(--dh-orange-050); color: var(--dh-orange);
  display: inline-flex; align-items: center; justify-content: center;
}
.contact-method__label { font-size: 12px; text-transform: uppercase; letter-spacing: var(--ls-caps); font-weight: var(--fw-semibold); color: var(--text-muted); margin-bottom: 3px; }
.contact-method__value { font-size: 1.0625rem; color: var(--text-strong); font-weight: var(--fw-medium); }
.contact-method__sub { font-size: var(--fs-small); color: var(--text-muted); }

.contact-form { display: flex; flex-direction: column; gap: 18px; }
.contact-form .field { display: flex; flex-direction: column; gap: 8px; }
.contact-form label { font-family: var(--font-body); font-size: 13px; font-weight: var(--fw-semibold); text-transform: uppercase; letter-spacing: .1em; color: var(--text-strong); }
.contact-form input, .contact-form textarea {
  font-family: var(--font-body); font-size: 1rem; color: var(--text-strong);
  background: var(--surface-card); border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md); padding: 13px 15px; width: 100%;
  transition: border-color var(--dur-base) var(--ease-standard), box-shadow var(--dur-base) var(--ease-standard);
}
.contact-form input:focus, .contact-form textarea:focus { outline: none; border-color: var(--dh-orange); box-shadow: 0 0 0 3px var(--focus-ring); }
.contact-form textarea { resize: vertical; min-height: 120px; }

/* ---------- Rechtstexte ---------- */
.legal { max-width: 820px; margin: 0 auto; padding: 48px 0 var(--section-y); }
.legal__updated { font-size: var(--fs-small); color: var(--text-muted); margin-bottom: 8px; }
.legal h2 {
  font-family: var(--font-display); font-weight: var(--fw-medium); font-size: 1.375rem;
  color: var(--text-strong); margin: 36px 0 12px;
}
.legal h3 { font-family: var(--font-body); font-weight: var(--fw-bold); font-size: 1.0625rem; color: var(--text-strong); margin: 22px 0 8px; }
.legal p { font-size: 1rem; line-height: var(--lh-relaxed); color: var(--text-body); margin-bottom: 14px; }
.legal ul { margin: 0 0 14px; padding-left: 22px; }
.legal ul li { font-size: 1rem; line-height: var(--lh-relaxed); color: var(--text-body); margin-bottom: 6px; }
.legal a { color: var(--dh-orange); text-decoration: underline; text-underline-offset: 2px; }
.legal address { font-style: normal; line-height: var(--lh-relaxed); color: var(--text-body); margin-bottom: 14px; }

@media (max-width: 960px) {
  .ref-grid--all { grid-template-columns: repeat(2, 1fr); }
  .contact-grid { grid-template-columns: 1fr; gap: 36px; }
}
@media (max-width: 640px) {
  .page-hero { min-height: 360px; }
  .service-card { grid-template-columns: 1fr; gap: 16px; padding: 28px 22px; }
  .ref-grid--all { grid-template-columns: 1fr; }
  .article__nav { flex-direction: column; }
}

/* ---------- Startseite: Intro-Fließtext ---------- */
.intro-lead { max-width: 760px; margin: 0 auto; text-align: center; }
.intro-lead p { font-size: 1.1875rem; line-height: var(--lh-relaxed); color: var(--text-body); }
.intro-lead p + p { margin-top: 18px; }

/* ---------- Startseite: "Für wen?" (zwei Zielgruppen) ---------- */
.audience-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-top: 48px; }
.audience-card {
  background: var(--surface-card); border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg); padding: 36px; box-shadow: var(--shadow-xs);
  display: flex; flex-direction: column;
}
.audience-card__icon {
  width: 48px; height: 48px; border-radius: 50%;
  background: var(--dh-orange-050); color: var(--dh-orange);
  display: inline-flex; align-items: center; justify-content: center; margin-bottom: 18px;
}
.audience-card h3 {
  font-family: var(--font-display); font-weight: var(--fw-medium); font-size: 1.3125rem;
  color: var(--text-strong); margin-bottom: 8px;
}
.audience-card__role { font-size: 12px; text-transform: uppercase; letter-spacing: var(--ls-caps); font-weight: var(--fw-semibold); color: var(--dh-orange); margin-bottom: 12px; }
.audience-card p { font-size: 1.0625rem; line-height: var(--lh-relaxed); color: var(--text-body); }
.audience-card ul { list-style: none; margin: 16px 0 0; padding: 0; }
.audience-card ul li { display: flex; gap: 10px; align-items: flex-start; margin-top: 9px; font-size: 0.98rem; line-height: var(--lh-normal); color: var(--text-strong); }
.audience-card ul li::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--dh-orange); flex: none; margin-top: 8px; }

/* ---------- Startseite: Über-mich-Teaser ---------- */
.about-teaser .container { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: 56px; align-items: center; max-width: 1100px; }
.about-teaser__media { border-radius: var(--radius-lg); overflow: hidden; background: #000; box-shadow: var(--shadow-md); }
.about-teaser__media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.about-teaser h2 {
  font-family: var(--font-display); font-weight: var(--fw-light); font-size: var(--fs-h2);
  line-height: var(--lh-snug); letter-spacing: var(--ls-tight); color: var(--text-strong); margin-bottom: 18px;
}
.about-teaser p { font-size: 1.0625rem; line-height: var(--lh-relaxed); color: var(--text-body); }
.about-teaser p + p { margin-top: 14px; }
.about-teaser .link-arrow { margin-top: 22px; }

@media (max-width: 760px) {
  .audience-grid { grid-template-columns: 1fr; }
  .about-teaser .container { grid-template-columns: 1fr; gap: 32px; }
}

/* ---------- Leistungen als hervorgehobene Karten (Startseite) ---------- */
.feature-grid--cards { gap: 24px; }
.feature-grid--cards .feature-item {
  background: var(--surface-card);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  padding: 38px 26px 32px;
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--dur-base) var(--ease-standard),
              transform var(--dur-base) var(--ease-standard),
              border-color var(--dur-base) var(--ease-standard);
}
.feature-grid--cards .feature-item:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-4px);
  border-color: var(--dh-orange-200);
}
.feature-grid--cards .feature-item__icon {
  width: 64px; height: 64px; border-radius: 50%;
  background: var(--dh-orange-050);
  display: inline-flex; align-items: center; justify-content: center;
  margin-bottom: 20px;
}

/* ---------- Scroll-Reveal (sanfte Einblendungen) ---------- */
.reveal {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity .6s var(--ease-out), transform .6s var(--ease-out);
  will-change: opacity, transform;
}
.reveal.is-visible { opacity: 1; transform: none; }

/* Hook-Zeile in den Leistungskarten */
.feature-item__lead { color: var(--text-strong); font-weight: var(--fw-medium); font-size: 1.0625rem; margin-bottom: 10px; }

/* ---------- Lightbox (Galerie vergrößern) ---------- */
.gallery figure img { cursor: zoom-in; }
.lightbox {
  position: fixed; inset: 0; z-index: 200;
  display: none; align-items: center; justify-content: center;
  background: rgba(26, 26, 26, 0.92); padding: 24px; cursor: zoom-out;
  opacity: 0; transition: opacity var(--dur-base) var(--ease-standard);
}
.lightbox.is-open { display: flex; opacity: 1; }
.lightbox img { max-width: 95vw; max-height: 92vh; border-radius: var(--radius-md); box-shadow: var(--shadow-lg); }
.lightbox__close {
  position: absolute; top: 18px; right: 22px; width: 44px; height: 44px;
  border: none; background: rgba(246, 244, 239, 0.12); color: var(--dh-offwhite);
  border-radius: 50%; cursor: pointer; font-size: 24px; line-height: 1;
  display: inline-flex; align-items: center; justify-content: center;
  transition: background var(--dur-base) var(--ease-standard);
}
.lightbox__close:hover { background: rgba(246, 244, 239, 0.25); }

/* ---------- "Weiterlesen" / "Projekt ansehen" in Karten ---------- */
.ref-card__body { display: flex; flex-direction: column; }
.ref-card__more {
  display: inline-flex; align-items: center; gap: 7px; margin-top: 16px;
  font-size: 0.9rem; font-weight: var(--fw-semibold); color: var(--dh-orange);
}
.ref-card__more svg { transition: transform var(--dur-base) var(--ease-standard); }
.ref-card:hover .ref-card__more svg { transform: translateX(4px); }

/* ---------- Moderne Vor/Zurück-Navigation (Artikel & Referenzen) ---------- */
.post-nav {
  max-width: 760px; margin: 0 auto; padding: 28px 0 0;
  border-top: 1px solid var(--border-subtle);
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
}
.post-nav__item {
  display: flex; align-items: center; gap: 14px; padding: 18px 22px;
  background: var(--surface-card); border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg); box-shadow: var(--shadow-xs);
  transition: box-shadow var(--dur-base) var(--ease-standard),
              transform var(--dur-base) var(--ease-standard),
              border-color var(--dur-base) var(--ease-standard);
}
.post-nav__item:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); border-color: var(--dh-orange-200); }
.post-nav__item svg { color: var(--dh-orange); flex: none; }
.post-nav__item--next { justify-content: flex-end; text-align: right; }
.post-nav__label { display: block; font-size: 11px; text-transform: uppercase; letter-spacing: .12em; color: var(--text-muted); margin-bottom: 3px; }
.post-nav__title { display: block; font-weight: var(--fw-semibold); color: var(--text-strong); font-size: .98rem; line-height: 1.3; }
@media (max-width: 640px) {
  .post-nav { grid-template-columns: 1fr; }
  .post-nav__item--next { flex-direction: row-reverse; justify-content: flex-end; text-align: left; }
}

/* ---------- "Was Sie davon haben" – visuelle Nutzen-Kacheln ---------- */
.benefits { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; margin-top: 28px; }
.benefit {
  display: flex; align-items: center; gap: 14px; padding: 18px 20px;
  background: var(--surface-card); border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg); box-shadow: var(--shadow-xs);
  transition: box-shadow var(--dur-base) var(--ease-standard), transform var(--dur-base) var(--ease-standard);
}
.benefit:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.benefit__icon {
  flex: none; width: 44px; height: 44px; border-radius: 50%;
  background: var(--dh-orange-050); color: var(--dh-orange);
  display: inline-flex; align-items: center; justify-content: center;
}
.benefit__txt { font-size: 1rem; font-weight: var(--fw-medium); color: var(--text-strong); line-height: 1.35; }
@media (max-width: 640px) { .benefits { grid-template-columns: 1fr; } }

/* ---------- Aufgaben-Liste (Referenzen) – CI-Kacheln mit Häkchen ---------- */
.prose ul.task-list { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; margin: 24px 0 0; padding: 0; }
.prose ul.task-list li {
  display: flex; gap: 13px; align-items: flex-start; margin: 0; padding: 18px 20px;
  background: var(--surface-card); border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg); box-shadow: var(--shadow-xs);
}
.prose ul.task-list li::before { content: none; }
.task-list__check {
  flex: none; width: 30px; height: 30px; border-radius: 50%;
  background: var(--dh-orange-050); color: var(--dh-orange);
  display: inline-flex; align-items: center; justify-content: center; margin-top: 1px;
}
.task-list__body { display: flex; flex-direction: column; gap: 3px; }
.task-list__title { font-weight: var(--fw-semibold); color: var(--text-strong); font-size: 1rem; line-height: 1.3; }
.task-list__desc { font-size: 0.95rem; color: var(--text-muted); line-height: 1.5; }
@media (max-width: 640px) { .prose ul.task-list { grid-template-columns: 1fr; } }

/* ---------- "Mein Anspruch"-Karten (Über-Seite) ---------- */
.anspruch-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 48px; }
.anspruch-card {
  background: var(--surface-card); border: 1px solid var(--border-subtle);
  border-top: 3px solid var(--dh-orange); border-radius: var(--radius-lg);
  padding: 30px 28px; box-shadow: var(--shadow-xs);
}
.anspruch-card h3 { font-family: var(--font-display); font-weight: var(--fw-medium); font-size: 1.25rem; color: var(--text-strong); margin-bottom: 12px; }
.anspruch-card p { font-size: 1rem; line-height: var(--lh-relaxed); color: var(--text-body); }
@media (max-width: 760px) { .anspruch-grid { grid-template-columns: 1fr; } }

/* ---------- "Passt das?"-Liste (Über-Seite) – verkaufsstark ---------- */
.fit-list { list-style: none; margin: 44px 0 0; padding: 0; display: grid; grid-template-columns: 1fr 1fr; gap: 16px 24px; }
.fit-list li {
  display: flex; gap: 15px; align-items: center; padding: 18px 22px;
  background: var(--surface-card); border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg); box-shadow: var(--shadow-xs);
  font-size: 1.0625rem; color: var(--text-strong); font-weight: var(--fw-medium); line-height: 1.4;
  transition: box-shadow var(--dur-base) var(--ease-standard), transform var(--dur-base) var(--ease-standard);
}
.fit-list li:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.fit-list__icon {
  flex: none; width: 36px; height: 36px; border-radius: 50%;
  background: var(--dh-orange); color: #fff;
  display: inline-flex; align-items: center; justify-content: center; box-shadow: var(--shadow-accent);
}
@media (max-width: 760px) { .fit-list { grid-template-columns: 1fr; } }

/* ---------- Bilder im Artikel (Impulse / Referenzen) ---------- */
.prose .article__figure { margin: 32px 0; }
.prose .article__figure img { width: 100%; border-radius: var(--radius-lg); display: block; box-shadow: var(--shadow-sm); }

/* ---------- Kontaktformular: Status, Honeypot, Einwilligung ---------- */
.hp-field { position: absolute !important; left: -9999px !important; width: 1px; height: 1px; overflow: hidden; }
.form-status { padding: 14px 18px; border-radius: var(--radius-md); font-size: 0.98rem; line-height: 1.5; margin-bottom: 6px; }
.form-status--ok { background: #E8F3E8; border: 1px solid #B7DCB7; color: #1f6b2e; }
.form-status--err { background: var(--dh-orange-050); border: 1px solid var(--dh-orange-200); color: var(--dh-orange-700); }
.consent { display: flex; gap: 11px; align-items: flex-start; font-size: 0.9rem; line-height: 1.45; color: var(--text-muted); cursor: pointer; }
.consent input { margin-top: 2px; flex: none; width: 18px; height: 18px; accent-color: var(--dh-orange); }
.consent a { color: var(--dh-orange); text-decoration: underline; }

/* ---------- Sticky Kontakt-Leiste (mobil) ---------- */
.mobile-cta { display: none; }
@media (max-width: 760px) {
  .mobile-cta {
    position: fixed; left: 0; right: 0; bottom: 0; z-index: 80;
    display: grid; grid-template-columns: 1fr 1fr; gap: 1px;
    background: var(--border-on-dark);
    box-shadow: 0 -4px 16px rgba(26, 26, 26, 0.16);
  }
  .mobile-cta a {
    display: flex; align-items: center; justify-content: center; gap: 8px;
    padding: 15px 10px; font-family: var(--font-body); font-weight: var(--fw-semibold);
    font-size: 0.95rem; text-decoration: none;
  }
  .mobile-cta__primary { background: var(--dh-orange); color: #fff; }
  .mobile-cta__wa { background: var(--dh-anthracite); color: var(--dh-offwhite); }
  body { padding-bottom: 58px; }
}

/* ---------- Cookie-/Consent-Banner ---------- */
.consent-banner {
  position: fixed; left: 16px; right: 16px; bottom: 16px; z-index: 120;
  max-width: 560px; margin: 0 auto;
  background: var(--dh-anthracite); color: var(--text-on-dark);
  border: 1px solid var(--border-on-dark); border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg); padding: 24px 26px; display: none;
}
.consent-banner.is-open { display: block; }
.consent-banner h2 { font-family: var(--font-display); font-weight: var(--fw-medium); font-size: 1.15rem; color: var(--text-on-dark); margin-bottom: 8px; }
.consent-banner p { font-size: 0.9rem; line-height: 1.55; color: var(--text-on-dark-muted); margin-bottom: 16px; }
.consent-banner a { color: var(--dh-orange-400); text-decoration: underline; }
.consent-banner__actions { display: flex; gap: 10px; flex-wrap: wrap; }
.consent-banner__actions .btn { flex: 1 1 auto; }
.btn--ghost-dark { background: transparent; color: var(--text-on-dark); border-color: rgba(246, 244, 239, 0.4); }
.btn--ghost-dark:hover { background: rgba(246, 244, 239, 0.1); border-color: rgba(246, 244, 239, 0.6); }
@media (max-width: 760px) { .consent-banner { bottom: 72px; } }

/* ---------- "So arbeite ich" – 3 Schritte ---------- */
.process-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; margin-top: 48px; }
.process-step { position: relative; }
.process-step__num { font-family: var(--font-display); font-weight: var(--fw-light); font-size: 2.75rem; color: var(--dh-orange); line-height: 1; margin-bottom: 14px; }
.process-step h3 { font-family: var(--font-display); font-weight: var(--fw-medium); font-size: 1.25rem; color: var(--text-strong); margin-bottom: 10px; }
.process-step p { font-size: 1rem; line-height: var(--lh-normal); color: var(--text-muted); }
@media (max-width: 760px) { .process-grid { grid-template-columns: 1fr; gap: 26px; } }

/* ---------- PDF-Download-Box (Lead-Magnet) ---------- */
.download-box {
  display: flex; gap: 18px; align-items: flex-start;
  margin: 40px 0 0; padding: 28px 30px;
  background: var(--dh-orange-050); border: 1px solid var(--dh-orange-200);
  border-radius: var(--radius-lg);
}
.download-box__icon { flex: none; width: 48px; height: 48px; border-radius: 50%; background: var(--dh-orange); color: #fff; display: inline-flex; align-items: center; justify-content: center; }
.download-box__body { flex: 1 1 auto; min-width: 0; }
.dl-frame { display: none; width: 0; height: 0; border: 0; }
.download-form__status { margin: 0 0 14px; }
.download-box h3 { font-family: var(--font-display); font-weight: var(--fw-medium); font-size: 1.25rem; color: var(--text-strong); margin-bottom: 6px; }
.download-box p { font-size: 1rem; line-height: 1.5; color: var(--text-body); margin-bottom: 16px; }
.download-form__row { display: flex; gap: 10px; margin-bottom: 12px; }
.download-form input[type="email"] {
  flex: 1 1 auto; min-width: 0; font-family: var(--font-body); font-size: 1rem; color: var(--text-strong);
  background: var(--surface-card); border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md); padding: 12px 15px;
}
.download-form input[type="email"]:focus { outline: none; border-color: var(--dh-orange); box-shadow: 0 0 0 3px var(--focus-ring); }
.download-form .consent { font-size: 0.85rem; }
@media (max-width: 560px) {
  .download-box { flex-direction: column; gap: 14px; padding: 24px 22px; }
  .download-form__row { flex-direction: column; }
}

/* ---------- "PDF verfügbar"-Badge auf Impulse-Karten ---------- */
.card-pdf {
  position: absolute; top: 12px; right: 12px; z-index: 1;
  display: inline-flex; align-items: center; gap: 5px;
  background: var(--dh-orange); color: #fff;
  font-size: 11px; font-weight: var(--fw-semibold); letter-spacing: .05em;
  padding: 5px 10px; border-radius: var(--radius-pill); box-shadow: var(--shadow-sm);
}
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1 !important; transform: none !important; transition: none !important; }
}

/* ===== EventOperating: Technik-Stack ===== */
.stack { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; margin-top: 8px; }
.stack-group { background: var(--surface-card); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); padding: 26px 26px 28px; }
.stack-group__title { margin: 0 0 18px; }
.stack-group__tag { display: inline-block; font-family: var(--font-body); font-weight: 600; font-size: 0.74rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--dh-orange-700); background: var(--dh-orange-050); border: 1px solid var(--dh-orange-200); border-radius: 999px; padding: 6px 14px; }
.stack-chips { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.chip { display: flex; flex-wrap: wrap; align-items: baseline; gap: 4px 12px; padding: 12px 16px; background: var(--surface-page); border: 1px solid var(--border-subtle); border-left: 3px solid var(--dh-orange); border-radius: var(--radius-md); }
.chip__name { font-family: var(--font-body); font-weight: 600; color: var(--text-strong); font-size: 1.02rem; }
.chip__desc { color: var(--text-muted); font-size: 0.92rem; }
@media (max-width: 760px) { .stack { grid-template-columns: 1fr; gap: 20px; } }
