/* ===================================================================
   STADT LOHR A. MAIN — Markendesign "Die Schönste im ganzen Land."
   Design tokens + base styles for the TYPO3 14 theme prototype
   =================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Fredoka:wght@400;500;600;700&family=Hanken+Grotesk:ital,wght@0,400;0,500;0,600;0,700;1,400&family=Baloo+2:wght@500;600;700&family=Quicksand:wght@500;600;700&display=swap');

:root {
  /* ---- Brand palette (sampled from new corporate design) ---- */
  --green-deep:  #133f35;   /* tiefes Tannengrün — dark sections */
  --green-deep2: #0e2f28;   /* even darker */
  --green:       #3a9a74;   /* Lohr-Grün — primary mid green */
  --green-600:   #2f805f;
  --green-700:   #266c50;
  --lime:        #c3d91b;   /* Limette — apple / highlight */
  --lime-soft:   #eef3c8;
  --lilac:       #b488dd;   /* helles Violett — arrows */
  --purple:      #5a3f8f;   /* tiefes Violett */
  --purple-deep: #3a2a6e;
  --coral:       #ed3b52;   /* Fachwerk-Rot / Akzent */
  --coral-soft:  #f8d3d8;
  --yellow:      #f4d24e;   /* Sonnengelb — squiggle */
  --sky:         #6fb4d8;   /* Turmdach-Blau */
  --steel:       #214f66;   /* Wirtschaft-Portal Dunkelblau — SubBar, Kontakt-Sektion */
  --steel-mid:   #2f6f8f;   /* Wirtschaft-Portal Akzentblau — Chips/Icons/Eyebrows */

  /* ---- Neutrals (warm, green-tinted) ---- */
  --paper:    #f7f5ec;      /* warm off-white page bg */
  --paper-2:  #efece0;      /* card alt */
  --cream:    #fbfaf4;      /* card surface */
  --ink:      #16241f;      /* near-black green text */
  --ink-soft: #41544c;      /* secondary text */
  --line:     #dcd8c8;      /* hairlines on paper */
  --line-dark: rgba(255,255,255,.16);

  /* ---- Tweakable tokens (overridden by Tweaks panel) ---- */
  --brand:        var(--green);     /* primary action color */
  --brand-ink:    #ffffff;          /* text on brand */
  --brand-deep:   var(--green-700);
  --accent:       var(--coral);
  --radius:       16px;             /* corner radius scale */
  --radius-sm:    10px;
  --radius-pill:  999px;
  --density:      1;                /* spacing multiplier */
  --font-display: 'Fredoka', system-ui, sans-serif;
  --font-body:    'Hanken Grotesk', system-ui, sans-serif;

  /* ---- Derived spacing ---- */
  --gap:    calc(24px * var(--density));
  --pad-sec: calc(96px * var(--density));
  --container: 1240px;

  --shadow-sm: 0 1px 2px rgba(19,63,53,.06), 0 2px 8px rgba(19,63,53,.05);
  --shadow:    0 4px 14px rgba(19,63,53,.10), 0 16px 40px rgba(19,63,53,.08);
  --shadow-lg: 0 10px 30px rgba(19,63,53,.14), 0 30px 70px rgba(19,63,53,.12);
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: var(--font-body);
  background: var(--paper);
  color: var(--ink);
  font-size: 17px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 600;
  line-height: 1.04;
  letter-spacing: -0.01em;
  margin: 0;
  color: var(--ink);
  text-wrap: balance;
}

p { margin: 0; text-wrap: pretty; }

a { color: inherit; text-decoration: none; }

button { font-family: inherit; cursor: pointer; }

img { display: block; max-width: 100%; }

:focus-visible {
  outline: 3px solid var(--purple);
  outline-offset: 2px;
  border-radius: 4px;
}

/* ---- Layout helpers ---- */
.container {
  width: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: 32px;
}
@media (max-width: 720px){ .container{ padding-inline: 20px; } }

.section { padding-block: var(--pad-sec); }
.section--alt { background: var(--paper-2); }

.eyebrow {
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--green-700);
}

/* ---- Buttons ---- */
.btn {
  --b: var(--brand);
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--font-display);
  font-weight: 600; font-size: 16px;
  padding: 13px 22px;
  border-radius: var(--radius-pill);
  border: 2px solid transparent;
  background: var(--b);
  color: var(--brand-ink);
  transition: transform .15s ease, box-shadow .2s ease, background .2s ease;
  white-space: nowrap;
}
.btn:hover { transform: translateY(-2px); box-shadow: var(--shadow); }
.btn:active { transform: translateY(0); }
.btn--ghost {
  background: transparent; color: var(--ink);
  border-color: var(--ink);
}
.btn--ghost:hover { background: var(--ink); color: var(--paper); }
.btn--lime { background: var(--lime); color: var(--green-deep); }
.btn--coral { background: var(--coral); color: #fff; }
.btn--on-dark { background: var(--lime); color: var(--green-deep); }
.btn--on-dark.btn--ghost { background: transparent; color: #fff; border-color: rgba(255,255,255,.5); }
.btn--on-dark.btn--ghost:hover { background: #fff; color: var(--green-deep); }

/* ---- Chips / tags ---- */
.chip {
  display: inline-flex; align-items: center; gap: 6px;
  font-weight: 600; font-size: 13px;
  padding: 6px 13px;
  border-radius: var(--radius-pill);
  background: var(--paper-2);
  color: var(--ink-soft);
  border: 1px solid var(--line);
}
.chip--lime { background: var(--lime); color: var(--green-deep); border-color: transparent; }
.chip--coral { background: var(--coral-soft); color: #b5273b; border-color: transparent; }
.chip--lilac { background: #ece1f7; color: var(--purple); border-color: transparent; }
.chip--sky { background: #e3f1f8; color: var(--sky); border-color: transparent; }
.chip--yellow { background: #fdf3d6; color: #8a6d1a; border-color: transparent; }
.chip--on-dark { background: rgba(255,255,255,.1); color: #fff; border-color: rgba(255,255,255,.2); }

/* ---- Card ---- */
.card {
  background: var(--cream);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
  transition: transform .18s ease, box-shadow .25s ease, border-color .2s ease;
}
.card--link:hover { transform: translateY(-4px); box-shadow: var(--shadow); border-color: var(--brand); }

/* ---- Fachwerk pattern (CSS) — half-timbered diagonal lattice ----
   A nod to Lohr's historic timber-frame facades + the brand stamp. */
.fachwerk {
  background-color: var(--coral);
  background-image:
    repeating-linear-gradient( 45deg, transparent 0 13px, rgba(255,255,255,.85) 13px 17px),
    repeating-linear-gradient(-45deg, transparent 0 13px, rgba(255,255,255,.85) 13px 17px);
  background-size: 100% 100%;
}
.fachwerk--green { background-color: var(--green-deep); }
.fachwerk--lime  { background-color: var(--green-deep); background-image:
    repeating-linear-gradient( 45deg, transparent 0 13px, var(--lime) 13px 17px),
    repeating-linear-gradient(-45deg, transparent 0 13px, var(--lime) 13px 17px); }

/* thin decorative wavy rule (brand "squiggle") */
.squiggle {
  width: 120px; height: 12px; display: block;
  background:
    radial-gradient(circle at 10px -4px, transparent 8px, var(--yellow) 9px 11px, transparent 12px),
    radial-gradient(circle at 30px 16px, transparent 8px, var(--yellow) 9px 11px, transparent 12px);
  background-size: 40px 24px;
  background-repeat: repeat-x;
}

/* visually hidden (a11y) */
.vh {
  position: absolute !important; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}

/* skip link */
.skiplink {
  position: absolute; left: 12px; top: -60px;
  background: var(--ink); color: #fff; padding: 12px 18px;
  border-radius: 8px; z-index: 200; font-weight: 600;
  transition: top .2s ease;
}
.skiplink:focus { top: 12px; }

/* ===== Header / Navigation ===== */
.util-link { transition: color .15s ease; }
.util-link:hover { color: var(--lime); }

.navlink {
  display: inline-flex; align-items: center; gap: 4px;
  font-family: var(--font-display); font-weight: 500; font-size: 15.5px;
  padding: 9px 13px; border-radius: var(--radius-pill);
  color: var(--ink); white-space: nowrap;
  transition: background .15s ease, color .15s ease;
}
.navlink:hover { background: var(--paper-2); }
.navlink--active { color: var(--green-700); }
.navlink--active::after {
  content: ''; position: absolute;
}
.navlink svg { opacity: .5; transform: rotate(90deg); }

.mega {
  position: absolute; left: 0; right: 0; top: 100%;
  background: var(--cream);
  border-bottom: 3px solid var(--lime);
  box-shadow: var(--shadow-lg);
  animation: megaIn .18s ease;
}
@keyframes megaIn { from { opacity: 0; transform: translateY(-6px); } to { opacity: 1; transform: none; } }
.megalink {
  display: inline-flex; align-items: center; gap: 9px;
  font-size: 15px; font-weight: 500; color: var(--ink-soft);
  transition: color .14s ease, gap .14s ease;
}
.megalink:hover { color: var(--green-700); gap: 13px; }

.iconbtn {
  width: 44px; height: 44px; display: grid; place-items: center;
  border-radius: var(--radius-pill); border: 1px solid var(--line);
  background: var(--cream); color: var(--ink);
  transition: background .15s ease, border-color .15s ease;
}
.iconbtn:hover { background: var(--paper-2); border-color: var(--brand); }
.burger { display: none; }

.search-ov {
  position: absolute; left: 0; right: 0; top: 100%;
  background: var(--cream); box-shadow: var(--shadow-lg);
  border-bottom: 3px solid var(--lime); animation: megaIn .18s ease;
}

.drawer {
  position: fixed; inset: 0; z-index: 300; background: var(--paper);
  overflow: auto; animation: megaIn .2s ease;
}
.drawer-head { display: flex; align-items: center; justify-content: space-between; padding: 18px 20px; border-bottom: 1px solid var(--line); }
.drawer-link {
  display: flex; align-items: center; justify-content: space-between;
  font-family: var(--font-display); font-weight: 500; font-size: 19px;
  padding: 16px 14px; border-radius: var(--radius-sm); color: var(--ink);
}
.drawer-link:hover { background: var(--paper-2); }
.drawer-link svg { opacity: .4; }

.foot-link { color: rgba(255,255,255,.82); transition: color .14s ease; }
.foot-link:hover { color: var(--lime); }

/* secondary page link styles */
.svc-link { display: flex; align-items: center; gap: 10px; padding: 9px 8px; border-radius: 8px; font-size: 15.5px; color: var(--ink); transition: background .14s ease, color .14s ease; }
.svc-link:hover { background: var(--lime-soft); color: var(--green-700); }
.toc-link { transition: color .14s ease; }
.toc-link:hover { color: var(--green-700); }

/* sub-portal local nav */
.subnav-link {
  font-family: var(--font-display); font-weight: 500; font-size: 15px;
  padding: 7px 12px; border-radius: var(--radius-pill);
  transition: background .15s ease; white-space: nowrap;
}
.subnav-link:hover { background: rgba(255,255,255,.16); }

/* tourism mood grid + photo mosaic */
.mood-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: var(--gap); }
.mosaic { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; grid-auto-flow: dense; }
.mosaic__tile {
  border-radius: var(--radius); overflow: hidden; min-height: 180px;
  display: grid; place-items: center; color: rgba(255,255,255,.9); aspect-ratio: 1 / 1;
}
.mosaic__tile--span-1 { grid-column: span 1; }
.mosaic__tile--span-2 { grid-column: span 2; aspect-ratio: 16 / 9; }
.mosaic__tile img { width: 100%; height: 100%; object-fit: cover; }
.mosaic__cta { text-align: center; margin-top: 28px; }

/* tourism Ebene-0 service module strip */
.icon-cards-section--modules { background: var(--cream); border-bottom: 1px solid var(--line); padding-block: calc(28px * var(--density)); }
.module-row { display: grid; grid-template-columns: repeat(7, 1fr); gap: 12px; }
.module-tile {
  display: flex; flex-direction: column; align-items: center; gap: 10px;
  padding: 16px 8px; border-radius: var(--radius-sm); color: var(--ink);
  transition: background .15s ease, transform .15s ease;
}
.module-tile:hover { background: var(--coral-soft); transform: translateY(-3px); }
.module-ico {
  width: 52px; height: 52px; border-radius: 50%;
  background: var(--coral-soft); color: #b5273b;
  display: grid; place-items: center; transition: background .15s ease, color .15s ease;
}
.module-tile:hover .module-ico { background: var(--coral); color: #fff; }
@media (max-width: 980px) { .module-row { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 560px) { .module-row { grid-template-columns: repeat(2, 1fr); } }

@media (max-width: 1080px) {
  .mood-grid { grid-template-columns: repeat(2, 1fr); }
  .mosaic { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .mood-grid { grid-template-columns: 1fr; }
}
.discover-card {
  display: block; position: relative; border-radius: var(--radius); overflow: hidden;
  aspect-ratio: 3 / 4; background: var(--paper-2);
  transition: transform .2s ease, box-shadow .25s ease;
}
.discover-card img { width: 100%; height: 100%; object-fit: cover; display: block; }
.discover-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-lg); }
.tiles-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: var(--gap); }
.tile {
  padding: 22px; display: grid; gap: 16px; align-content: space-between; min-height: 138px;
}
.tile-ico {
  width: 50px; height: 50px; border-radius: 14px;
  background: var(--lime-soft); color: var(--green-700);
  display: grid; place-items: center;
  transition: background .18s ease, color .18s ease;
}
.card--link:hover .tile-ico { background: var(--lime); color: var(--green-deep); }
.tile-label {
  font-family: var(--font-display); font-weight: 500; font-size: 17.5px;
  display: flex; justify-content: space-between; align-items: center; gap: 8px;
}
.foot-soc {
  width: 40px; height: 40px; border-radius: 50%; background: var(--lime);
  display: grid; place-items: center; transition: transform .15s ease;
}
.foot-soc:hover { transform: translateY(-3px); }

@media (max-width: 720px) {
  .util-extra { display: none; }
}
@media (max-width: 520px) {
  .util-tagline { display: none !important; }
}
/* responsive nav collapse */
@media (max-width: 1080px) {
  .mainnav { display: none !important; }
  .burger { display: grid; place-items: center; width: 44px; height: 44px;
    border-radius: var(--radius-pill); border: 1px solid var(--line); background: var(--cream); }
  .head-actions .btn { display: none; }
}
/* Online-Rathaus CTA in the header bar is redundant (every mega panel has it);
   keep it hidden on desktop so logo + 8-item nav + search fit on one row. */
.head-actions .btn { display: none; }
@media (max-width: 1180px) and (min-width: 1081px) {
  .navlink { font-size: 14px; padding: 8px 9px; }
}
@media (max-width: 860px) {
  .footer-cols { grid-template-columns: 1fr 1fr !important; }
}

/* scrollbar-free reveal animation, gated for reduced motion */
@media (prefers-reduced-motion: no-preference) {
  .reveal { animation: rise .6s cubic-bezier(.2,.7,.2,1) forwards; }
  @keyframes rise { from { transform: translateY(16px); } to { transform: none; } }
}

/* =====================================================================
   Veranstaltungskalender (Content-Elemente lohr_veranstaltungsliste/-detail)
   ===================================================================== */
.section-head { max-width: 680px; margin-bottom: 34px; }
.section-head h2 { font-size: clamp(28px, 3.4vw, 44px); margin-top: 10px; }
.section-head .lead { font-size: 18.5px; color: var(--ink-soft); margin-top: 12px; }
.container--narrow { max-width: 820px; }

.event-filter { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 26px; }
.chip--active { background: var(--green); color: #fff; border-color: transparent; }

.event-layout { display: grid; grid-template-columns: 1fr 300px; gap: 40px; align-items: start; }
@media (max-width: 900px) { .event-layout { grid-template-columns: 1fr; } }
.event-sidebar { display: grid; gap: 20px; position: sticky; top: 130px; }
.event-sidebar__card { padding: 22px; }
.event-sidebar__card h3 { font-size: 18px; margin-bottom: 14px; }
.event-sidebar__chips { display: flex; flex-wrap: wrap; gap: 8px; }
.event-sidebar__cta { background: var(--lime); border-radius: var(--radius); padding: 22px; color: var(--green-deep); }
.event-sidebar__cta h3 { font-size: 19px; margin-bottom: 8px; }
.event-sidebar__cta p { font-size: 14.5px; margin-bottom: 14px; }
.event-sidebar__cta .btn { background: var(--green-deep); color: #fff; }

.event-list { display: grid; gap: 14px; }
.event-list--cards { grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); }

.event-card {
  position: relative;
  display: flex; align-items: center; gap: 18px;
  background: var(--cream); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 18px; color: var(--ink);
  transition: transform .18s ease, box-shadow .25s ease, border-color .2s ease;
}
.event-card:hover { transform: translateY(-3px); box-shadow: var(--shadow); border-color: var(--brand); }
.event-list--cards .event-card { flex-direction: column; align-items: stretch; padding: 0; overflow: hidden; }

.event-date {
  flex: 0 0 auto; width: 64px; text-align: center;
  background: var(--coral); color: #fff; border-radius: 14px; padding: 10px 0;
  font-family: var(--font-display); line-height: 1;
}
.event-date--lime { background: var(--lime); color: var(--green-deep); }
.event-date--coral { background: var(--coral); color: #fff; }
.event-date--lilac { background: var(--lilac); color: #fff; }
.event-date--sky { background: var(--sky); color: #fff; }
.event-date__day { font-size: 26px; font-weight: 700; display: block; }
.event-date__mon { font-size: 12px; font-weight: 600; text-transform: uppercase; }
.event-list--cards .event-date { position: absolute; margin: 14px; box-shadow: var(--shadow-sm); }

.event-card__media { display: block; position: relative; }
.event-card__media img { width: 100%; height: auto; display: block; }
.event-card__media--placeholder { aspect-ratio: 16 / 9; display: grid; place-items: center; color: rgba(255,255,255,.9); }
.event-card__body { display: grid; gap: 6px; flex: 1; }
.event-list--cards .event-card__body { padding: 18px; }
.event-card__title { font-family: var(--font-display); font-weight: 600; font-size: 20px; }
.event-card__meta { font-size: 14px; color: var(--ink-soft); }
.event-card__arrow { color: var(--lilac); font-weight: 700; font-size: 20px; }
.event-list--cards .event-card__arrow { display: none; }

.event-empty {
  background: var(--paper-2); border-radius: var(--radius);
  padding: 28px; text-align: center; color: var(--ink-soft); font-size: 17px;
}

.event-detail__head { margin-bottom: 22px; }
.event-detail__head h1 { font-size: clamp(30px, 4vw, 50px); margin: 10px 0; }
.event-detail__sub { font-size: 19px; color: var(--ink-soft); }
.event-detail__meta { font-size: 15.5px; color: var(--green-700); font-weight: 600; }
.event-detail__media { border-radius: var(--radius); overflow: hidden; margin: 18px 0 26px; }
.event-detail__media img { width: 100%; height: auto; display: block; }
.event-detail__body { font-size: 18px; color: var(--ink-soft); display: grid; gap: 16px; margin-bottom: 24px; }
.breadcrumb { font-size: 14px; color: var(--ink-soft); margin-bottom: 18px; }
.breadcrumb a { color: var(--green-700); font-weight: 600; }

/* news detail (Meldung) — prose article, 1:1 zu static/news-detail.html */
.news-article h1 { font-size: clamp(30px, 4.4vw, 50px); margin: 6px 0 20px; }
.news-article__meta { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; margin: 22px 0 14px; }
.news-article__meta-date { font-size: 14px; color: var(--ink-soft); }
.news-article__media { border-radius: var(--radius); overflow: hidden; margin: 12px 0 28px; }
.news-article__media img { width: 100%; height: auto; display: block; }
.news-article__media .teaser-media { border-radius: var(--radius); }
.news-article__lead { font-size: 21px; color: var(--ink); margin-bottom: 18px; }
.news-article__body { font-size: 18px; color: var(--ink-soft); display: grid; gap: 18px; }
.news-article__body p { margin: 0; }
.news-article__body h2, .news-article__body h3 { color: var(--ink); margin: 8px 0 0; }
.news-article__body a { color: var(--green-700); font-weight: 600; text-decoration: underline; }
.news-article__actions { display: flex; gap: 12px; margin-top: 32px; flex-wrap: wrap; }

/* generic helpers used by content-block templates */
.cards-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(290px, 1fr)); gap: var(--gap); }
.card__ico { width: 52px; height: 52px; border-radius: 13px; background: var(--lime-soft);
  color: var(--green-700); display: grid; place-items: center; }
.icon-cards--icon-solid .card__ico { background: var(--steel-mid); color: #fff; }
.discover-card__overlay {
  position: absolute; inset: 0; display: flex; flex-direction: column; justify-content: flex-end;
  padding: 22px; background: linear-gradient(180deg, transparent 45%, rgba(13,47,40,.86)); color: #fff;
}
.discover-card__overlay h3 { color: #fff; font-size: 23px; }
.discover-card__cta { color: var(--lime); font-weight: 600; margin-top: 10px; }

/* section-head with an inline CTA link (right-aligned "Alle …"/"Zum Kalender") */
.section-head-row {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 20px; flex-wrap: wrap; max-width: none;
}
.section-head-row .btn { flex: 0 0 auto; }

/* image-placeholder box for teaser cards without an uploaded image */
.teaser-media {
  color: rgba(255,255,255,.9); width: 100%; height: 100%;
}
.fachwerk--purple { background-color: var(--purple); }
.fachwerk--coral { background-color: var(--coral); }
.fachwerk--sky { background-color: var(--sky); }
.fachwerk--yellow { background-color: var(--yellow); }
.fachwerk--green-700 { background-color: var(--green-700); }
.fachwerk--lilac { background-color: var(--lilac); }

/* themen-teaser "news" layout (16:9 image + chip/date + title) */
.teaser-news-card { display: grid; grid-template-rows: auto 1fr; }
.teaser-date { font-size: 13px; color: var(--ink-soft); }
.teaser-title { font-family: var(--font-display); font-weight: 500; font-size: 21px; }
.teaser-more { display: inline-flex; align-items: center; gap: 8px; color: var(--green-700); font-weight: 600; font-size: 15px; }

/* themen-teaser dark (inverted) section variant, e.g. "Lohr entdecken" */
.themen-teaser-section--dark {
  background: var(--green-deep); color: #fff; position: relative; overflow: hidden;
}
.themen-teaser-section--dark .eyebrow { color: var(--lime); }
.themen-teaser-section--dark .section-head h2 { color: #fff; }
.themen-teaser-section--dark .section-head .lead { color: rgba(255,255,255,.82); }
.kennzahlen__grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 1px; background: var(--line); border-radius: 12px; overflow: hidden; }
.kennzahlen__item { background: var(--cream); padding: 20px 18px; }
.kennzahlen__item strong { font-family: var(--font-display); font-size: clamp(28px, 3vw, 40px); display: block; line-height: 1; }
.kennzahlen__item span { font-size: 14px; color: var(--ink-soft); margin-top: 4px; display: block; }
.logo-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 14px; }
.logo-grid__item { aspect-ratio: 3 / 2; display: grid; place-items: center; background: var(--cream);
  border: 1px solid var(--line); border-radius: var(--radius-sm); }
.logo-grid__placeholder { font-family: var(--font-display); font-weight: 600; opacity: .5; }

/* sub-portal bar (server-rendered) */
.subportal-bar { position: sticky; top: 0; z-index: 40; color: #fff; }
.subportal-bar__inner { display: flex; align-items: center; justify-content: space-between; gap: 16px; min-height: 52px; flex-wrap: wrap; }
.subportal-bar__brand { display: inline-flex; align-items: center; gap: 10px; color: #fff; }
.subportal-bar__ico { width: 30px; height: 30px; border-radius: 9px; background: rgba(255,255,255,.2); display: grid; place-items: center; }
.subportal-bar__nav { display: flex; gap: 4px; flex-wrap: wrap; }

/* Wirtschaft-Portal: eigener Akzent (steel-mid) statt Standard-Grün auf hellen Sektionen */
.portal--wirtschaft .section .eyebrow { color: var(--steel-mid); }
.portal--wirtschaft .section .chip--active { background: var(--steel-mid); }
.portal--wirtschaft .section .card__ico { background: rgba(47,111,143,.12); color: var(--steel-mid); }

/* Tourismus-Portal: eigener Akzent (Koralle) statt Standard-Grün auf hellen Sektionen */
.portal--tourismus .section .eyebrow { color: var(--coral); }
.portal--tourismus .section .chip--active { background: var(--coral); }
.portal--tourismus .section .card__ico { background: var(--coral-soft); color: var(--coral); }

/* decorative rainbow divider strip (PatternStrip aus brand.jsx) — named "rainbow-strip"
   to avoid colliding with the pre-existing (unused) .pattern-strip rule near the footer styles */
.rainbow-strip {
  height: 14px;
  background: repeating-linear-gradient(90deg, var(--coral) 0 2.5%, var(--lime) 2.5% 5%, var(--purple) 5% 7.5%, var(--yellow) 7.5% 10%, var(--green) 10% 12.5%, var(--lilac) 12.5% 15%, var(--sky) 15% 17.5%);
}

/* =====================================================================
   CTA-Banner (Content-Element lohr/cta-banner) — schlanke Abschluss-CTA
   ===================================================================== */
.cta-banner { position: relative; overflow: hidden; padding-block: var(--pad-sec); }
.cta-banner--green-deep { background: var(--green-deep); color: rgba(255,255,255,.88); }
.cta-banner--green-700 { background: var(--green-700); color: rgba(255,255,255,.88); }
.cta-banner--lime { background: var(--lime); color: var(--green-700); }
.cta-banner--green-deep .eyebrow, .cta-banner--green-700 .eyebrow { color: var(--lime); }
.cta-banner--lime .eyebrow { color: var(--green-700); }
.cta-banner__title { font-size: clamp(24px, 3vw, 40px); margin: 0 0 10px; }
.cta-banner--green-deep .cta-banner__title, .cta-banner--green-700 .cta-banner__title { color: #fff; }
.cta-banner--lime .cta-banner__title { color: var(--green-deep); }
.cta-banner__text-body { font-size: 17px; max-width: 520px; }
.cta-banner--stacked { padding-block: var(--pad-sec); }
.cta-banner--stacked .cta-banner__inner { display: grid; gap: 18px; max-width: 620px; }
.cta-banner--row { padding-block: calc(56px * var(--density)); }
.cta-banner--row .cta-banner__inner { display: flex; align-items: center; justify-content: space-between; gap: 24px; flex-wrap: wrap; }
.cta-banner__actions { display: flex; gap: 12px; flex-wrap: wrap; }

/* =====================================================================
   Story-Split (Content-Element lohr/story-split) — 2-spaltige Storytelling-Sektion
   ===================================================================== */
.story-split { position: relative; overflow: hidden; color: #fff; }
.story-split--purple-deep { background: var(--purple-deep); }
.story-split--green-deep { background: var(--green-deep); }
.story-split--coral { background: var(--coral); }
.story-split .eyebrow { color: var(--lime); }
.story-split__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 0; align-items: stretch; }
.story-split--image-left .story-split__text { order: 2; }
.story-split--image-left .story-split__media { order: 1; }
.story-split__text { padding-block: var(--pad-sec); padding-right: 48px; display: grid; align-content: center; }
.story-split__title { font-size: clamp(30px, 4vw, 52px); margin: 12px 0 16px; color: #fff; }
.story-split__body { color: rgba(255,255,255,.85); font-size: 18.5px; max-width: 460px; margin-bottom: 22px; }
.story-split__media { position: relative; min-height: 420px; }
.story-split__media img { width: 100%; height: 100%; object-fit: cover; display: block; }
@media (max-width: 860px) {
  .story-split__inner { grid-template-columns: 1fr; }
  .story-split--image-left .story-split__text, .story-split--image-left .story-split__media { order: initial; }
  .story-split__text { padding-right: 0; }
}

/* =====================================================================
   Kontakt-Teaser (Content-Element lohr/kontakt-teaser) — Netzwerk & Kontakt
   ===================================================================== */
.kontakt-teaser { background: var(--steel); color: rgba(255,255,255,.85); padding-block: var(--pad-sec); }
.kontakt-teaser .eyebrow { color: var(--lime); }
.kontakt-teaser__inner { display: grid; grid-template-columns: 1.2fr .8fr; gap: 48px; align-items: center; }
.kontakt-teaser__title { color: #fff; font-size: clamp(28px, 3.6vw, 46px); margin: 12px 0 16px; }
.kontakt-teaser__text { font-size: 18px; margin-bottom: 22px; max-width: 520px; }
.kontakt-teaser__chips { display: flex; gap: 12px; flex-wrap: wrap; }
.kontakt-teaser__card {
  background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.14);
  border-radius: var(--radius); padding: 28px;
}
.kontakt-teaser__org { display: flex; gap: 16px; align-items: center; margin-bottom: 16px; }
.kontakt-teaser__org-ico {
  width: 64px; height: 64px; border-radius: 50%; background: var(--steel-mid);
  display: grid; place-items: center; flex: 0 0 auto; color: #fff;
}
.kontakt-teaser__org strong { font-family: var(--font-display); font-size: 20px; display: block; }
.kontakt-teaser__org-sub { color: rgba(255,255,255,.72); font-size: 14.5px; }
.kontakt-teaser__meta { display: grid; gap: 10px; font-size: 15.5px; }
.kontakt-teaser__meta span { display: flex; gap: 10px; align-items: center; }
.kontakt-teaser__meta svg { color: var(--lime); flex: 0 0 auto; }
.kontakt-teaser__cta { margin-top: 18px; justify-content: center; width: 100%; }
@media (max-width: 860px) { .kontakt-teaser__inner { grid-template-columns: 1fr; } }

/* =====================================================================
   Unternehmensliste (lohr_unternehmensliste/-detail)
   ===================================================================== */
.company-card { display: grid; gap: 12px; align-content: start; padding: 24px; }
.company-card__logo { height: 56px; display: flex; align-items: center; }
.company-card__logo img { max-height: 56px; width: auto; }
.company-card__monogram {
  width: 56px; height: 56px; border-radius: 14px; background: var(--lime-soft);
  color: var(--green-700); display: grid; place-items: center;
  font-family: var(--font-display); font-weight: 700; font-size: 22px; text-transform: uppercase;
}
.company-card__title { font-size: 21px; }
.company-card__teaser { font-size: 15px; color: var(--ink-soft); }
.company-card__cta { color: var(--green-700); font-weight: 600; font-size: 14.5px; }
.company-detail__head { display: grid; gap: 12px; margin-bottom: 18px; }
.company-detail__logo img { max-height: 80px; width: auto; }
.company-detail__tags { display: flex; gap: 8px; flex-wrap: wrap; }

.facts { display: grid; grid-template-columns: max-content 1fr; gap: 8px 20px; margin: 20px 0; }
.facts dt { font-weight: 600; color: var(--green-700); }
.facts dd { margin: 0; color: var(--ink-soft); }

/* =====================================================================
   Dienstleistungen A–Z (lohr_dienstleistungsliste/-detail)
   ===================================================================== */
.service-search {
  display: flex; align-items: center; gap: 10px; background: var(--cream);
  border: 2px solid var(--green); border-radius: var(--radius-pill);
  padding: 8px 8px 8px 18px; margin-bottom: 18px; box-shadow: var(--shadow-sm);
}
.service-search input { flex: 1; border: none; outline: none; background: transparent; font-size: 17px; font-family: var(--font-body); }
.service-search svg { color: var(--green); }

.az-index { display: flex; flex-wrap: wrap; gap: 6px; margin: 8px 0 28px; }
.az-index__item {
  width: 38px; height: 38px; display: grid; place-items: center;
  border-radius: 10px; background: var(--paper-2); color: var(--green-700);
  font-family: var(--font-display); font-weight: 600; transition: background .14s ease, color .14s ease;
}
.az-index__item:hover { background: var(--green); color: #fff; }

.service-group { margin-bottom: 28px; scroll-margin-top: 90px; }
.service-group__letter {
  font-family: var(--font-display); font-size: 26px; color: var(--green);
  border-bottom: 2px solid var(--line); padding-bottom: 6px; margin-bottom: 10px;
}
.service-group__list { list-style: none; margin: 0; padding: 0; display: grid; gap: 2px; }
.service-link {
  display: flex; align-items: center; gap: 10px; padding: 11px 10px;
  border-radius: var(--radius-sm); color: var(--ink); font-size: 16.5px;
  transition: background .14s ease, color .14s ease;
}
.service-link:hover { background: var(--lime-soft); color: var(--green-700); }
.service-link__arrow { color: var(--lilac); font-weight: 700; }
.service-link__title { flex: 1; }
.service-link__badge {
  font-size: 12px; font-weight: 700; color: var(--green-deep); background: var(--lime);
  padding: 3px 9px; border-radius: var(--radius-pill);
}
.service-detail__downloads { margin: 22px 0; }
.service-detail__downloads ul { list-style: none; margin: 8px 0 0; padding: 0; display: grid; gap: 2px; }
.service-detail__body { font-size: 18px; color: var(--ink-soft); display: grid; gap: 16px; }

/* Dienstleistungsliste, Layout "categories" (service.html) */
.service-cat-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: var(--gap); margin-bottom: 40px; }
.service-cat-card { padding: 24px; }
.service-cat-card h3 { font-size: 20px; margin-bottom: 16px; display: flex; align-items: center; gap: 10px; }
.service-cat-card__bullet { width: 10px; height: 10px; border-radius: 3px; flex: 0 0 auto; }
.service-cat-card__bullet--green { background: var(--green); }
.service-cat-card__bullet--coral { background: var(--coral); }
.service-cat-card__bullet--purple { background: var(--purple); }
.service-cat-card__bullet--lime { background: var(--lime); }
.service-quick-actions {
  background: var(--green-deep); border-radius: var(--radius); color: #fff;
  padding: clamp(28px, 4vw, 48px); display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 24px;
}
.service-quick-actions__item { display: flex; gap: 14px; align-items: center; color: #fff; }
.service-quick-actions__ico {
  width: 50px; height: 50px; border-radius: 14px; background: var(--lime); color: var(--green-deep);
  display: grid; place-items: center; flex: 0 0 auto;
}
.service-quick-actions__item strong { font-family: var(--font-display); font-size: 18px; display: block; }
.service-quick-actions__item span span { font-size: 14px; color: rgba(255,255,255,.78); }

/* =====================================================================
   Chrome-Layout (Header · Utility-Bar · Logo · Mega · Footer)
   Aus den Inline-Styles des Prototyps (design-reference/chrome.jsx) als
   CSS portiert — die Fluid-Partials nutzen diese Struktur-Klassen.
   ===================================================================== */

/* Header-Schale */
.site-head { position: sticky; top: 0; z-index: 100; background: var(--paper); border-bottom: 1px solid var(--line); }

/* Utility-Bar (dunkelgrüner Streifen oben) */
.util-bar { background: var(--green-deep); color: rgba(255,255,255,.85); font-size: 13.5px; }
.util-bar__inner { display: flex; align-items: center; justify-content: space-between; min-height: 38px; white-space: nowrap; }
.util-tagline { display: inline-flex; gap: 8px; align-items: center; font-weight: 500; overflow: hidden; text-overflow: ellipsis; }
.util-tagline .dot { color: var(--lime); }
.util-nav { display: flex; gap: 18px; align-items: center; font-weight: 600; }

/* Haupt-Headerleiste */
.head-bar { display: flex; align-items: center; gap: 18px; min-height: 84px; }
.head-actions { display: flex; gap: 10px; align-items: center; flex: 0 0 auto; }

/* Wortmarke */
.lohr-logo { display: inline-flex; align-items: baseline; gap: 7px; flex: 0 0 auto; }
.lohr-logo__mark { position: relative; font-family: var(--font-display); font-weight: 700; font-size: 30px; letter-spacing: -.01em; color: var(--green-deep); line-height: 1; }
.lohr-logo__sprout { display: inline-block; width: 9px; height: 9px; margin: 0 1px; border-radius: 0 50% 50% 50%; background: var(--lime); transform: translateY(-2px) rotate(45deg); }
.lohr-logo__suffix { font-family: var(--font-display); font-weight: 500; font-size: 14px; color: var(--ink-soft); }
.lohr-logo--dark .lohr-logo__mark { color: #fff; }
.lohr-logo--dark .lohr-logo__suffix { color: rgba(255,255,255,.7); }

/* Hauptnavigation (Desktop) */
.mainnav { position: static; display: flex; align-items: center; margin-left: auto; }
.mainnav__list { display: flex; gap: 3px; align-items: center; flex-wrap: wrap; list-style: none; margin: 0; padding: 0; }
.mainnav__item { position: static; }

/* Mega-Menü: nur per CSS-Hover (kein JS) */
.mainnav__item .mega { display: none; }
.mainnav__item:hover > .mega, .mainnav__item:focus-within > .mega { display: block; }
.mega__inner { padding-block: 24px; }
.mega__title { font-size: 22px; display: inline-flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.mega__cols { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)) 220px; gap: 28px; }
.mega__cols > div { display: grid; gap: 9px; align-content: start; }
.mega__cols h4 { font-family: var(--font-body); font-weight: 700; font-size: 14px; text-transform: uppercase; letter-spacing: .08em; color: var(--green-700); margin-bottom: 3px; }
.mega__cta { background: var(--green-deep); border-radius: var(--radius); padding: 20px; color: #fff; display: grid; align-content: space-between; gap: 6px; }
.mega__cta strong { font-family: var(--font-display); font-size: 19px; line-height: 1.1; }
.mega__cta p { font-size: 14px; color: rgba(255,255,255,.8); }
.megalink__arrow { color: var(--lilac); font-weight: 700; }

/* Seitenkopf (sub-hero banner for inner pages, Content-Element lohr_seitenkopf) */
.page-header { position: relative; overflow: hidden; color: #fff; padding-block: 28px 0; }
.page-header .container { padding-block: 28px 48px; }
.page-header--green { background: var(--green-deep); }
.page-header--purple { background: var(--purple-deep); }
.page-header--coral { background: var(--coral); }
.page-header--sky { background: var(--sky); }
.page-header .eyebrow { color: var(--lime); }
.page-header__crumb { font-size: 14px; color: rgba(255,255,255,.7); margin-bottom: 22px; }
.page-header__crumb ol { list-style: none; display: flex; flex-wrap: wrap; gap: 8px; padding: 0; margin: 0; }
.page-header__crumb li { display: flex; gap: 8px; align-items: center; }
.page-header__crumb a { color: var(--lime); font-weight: 600; }
.page-header__crumb li[aria-hidden] { opacity: .4; }
.page-header__crumb li[aria-current] { color: #fff; }
.page-header__headline { color: #fff; font-size: clamp(34px, 4.6vw, 60px); margin: 12px 0 0; max-width: 820px; }
.page-header__lead { color: rgba(255,255,255,.85); font-size: 19px; max-width: 600px; margin-top: 16px; }

/* Footer */
.site-foot { background: var(--green-deep); color: rgba(255,255,255,.82); }
.pattern-strip { height: 14px; background-image: repeating-linear-gradient(45deg, transparent 0 13px, var(--lime) 13px 17px), repeating-linear-gradient(-45deg, transparent 0 13px, var(--lime) 13px 17px); }
.site-foot__grid { padding-block: 64px; display: grid; grid-template-columns: 1.3fr 1fr 1fr 1fr; gap: 40px; }
.site-foot__brand p { margin-top: 18px; max-width: 280px; font-size: 14.5px; }
.site-foot__col h4 { font-family: var(--font-body); font-weight: 700; font-size: 14px; text-transform: uppercase; letter-spacing: .08em; color: var(--lime); margin-bottom: 14px; }
.site-foot__col ul { list-style: none; margin: 0; padding: 0; display: grid; gap: 10px; font-size: 14.5px; }
.site-foot__bar { border-top: 1px solid var(--line-dark); }
.site-foot__bar-inner { padding-block: 20px; display: flex; justify-content: space-between; flex-wrap: wrap; gap: 12px; font-size: 13.5px; }
.site-foot__legal { display: flex; gap: 20px; flex-wrap: wrap; }

@media (max-width: 980px) { .site-foot__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .site-foot__grid { grid-template-columns: 1fr; } .head-bar { min-height: 64px; } }

/* =====================================================================
   Hero (Content-Element lohr/hero) — aus home.jsx portiert
   ===================================================================== */
.hero { position: relative; overflow: hidden; }
.hero__inner { position: relative; padding-block: 72px; }
.hero__headline { font-size: clamp(44px, 8vw, 116px); line-height: .94; letter-spacing: -.02em; margin: 16px 0 0; }
.hero__subline { font-size: 20px; max-width: 540px; margin: 22px 0 0; }
.sprout { display: inline-block; width: 14px; height: 14px; border-radius: 0 50% 50% 50%; background: var(--lime); transform: rotate(45deg); }

/* Stil "color" (Default) — dunkelgrün, typografisch */
.hero--color { background: var(--green-deep); color: #fff; }
.hero--color::before { content: ''; position: absolute; inset: 0; opacity: .05; pointer-events: none;
  background-image: repeating-linear-gradient(45deg, transparent 0 13px, rgba(255,255,255,.85) 13px 17px), repeating-linear-gradient(-45deg, transparent 0 13px, rgba(255,255,255,.85) 13px 17px); }
.hero--color .hero__headline { color: #fff; }
.hero--color .eyebrow { color: var(--lime); }
.hero--color .hero__subline { color: rgba(255,255,255,.85); }

/* Stil "image" — Vollbild mit Scrim */
.hero--image { min-height: min(74vh, 640px); display: grid; align-items: end; }
.hero__bg { position: absolute; inset: 0; }
.hero__bg img { width: 100%; height: 100%; object-fit: cover; }
.hero__scrim { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(13,47,40,.15) 0%, rgba(13,47,40,.78) 78%); }
.hero--image .hero__inner { padding-block: 48px 56px; }
.hero--image .hero__headline { color: #fff; }
.hero--image .eyebrow { color: var(--lime); }
.hero--image .hero__subline { color: rgba(255,255,255,.9); }

.hero__actions { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 26px; }

.hero__search {
  display: flex; align-items: center; gap: 10px;
  background: var(--cream); border-radius: var(--radius-pill);
  padding: 8px 8px 8px 22px; box-shadow: var(--shadow);
  max-width: 540px; margin: 0 0 56px;
}
.hero__search svg { color: var(--green); flex: 0 0 auto; }
.hero__search input {
  flex: 1; border: none; outline: none; background: transparent;
  font-size: 16.5px; color: var(--ink); font-family: var(--font-body);
}
.hero__search .btn { padding: 11px 20px; }

/* Kennzahlen-Panel neben dem Text (hero_stats gesetzt) */
.hero__inner--split { display: grid; grid-template-columns: 1.15fr .85fr; gap: 48px; align-items: center; }
.hero__main { min-width: 0; }
.hero__statspanel {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: var(--radius);
  padding: clamp(20px, 2.5vw, 30px);
}
.hero__statspanel-title {
  color: var(--lime); font-size: 18px; font-family: var(--font-body);
  font-weight: 700; text-transform: uppercase; letter-spacing: .06em; margin-bottom: 18px;
}
.hero__statspanel-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 1px;
  background: rgba(255,255,255,.12); border-radius: 12px; overflow: hidden;
}
.hero__statspanel-item { background: var(--green-deep); padding: 20px 18px; }
.hero__statspanel-item strong {
  font-family: var(--font-display); font-size: clamp(28px, 3vw, 40px); color: #fff; display: block; line-height: 1;
}
.hero__statspanel-item span { font-size: 14px; color: rgba(255,255,255,.7); margin-top: 4px; display: block; }
@media (max-width: 860px) { .hero__inner--split { grid-template-columns: 1fr; } }
