/* ============================================================
   Central Apotheke Düdingen — style.css
   Framework-frei. Eigene Kopie pro Website.
   Apotheken-Grün #009534 · Schrift Aptos / Public Sans.
   Desktop-Layout identisch zur bisherigen Version, mit echten
   Media-Queries für Tablet & Smartphone.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Public+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400&family=JetBrains+Mono:wght@400;500&display=swap');

:root {
  --green: #009534;
  --green-deep: #00772A;
  --mint-100: #D7F0E0;
  --mint-50: #E8F8EE;
  --slate-700: #42525F;
  --slate-500: #6B7A85;
  --slate-100: #EDF1F3;
  --kamille: #F0DC6E;
  --amber: #8B5A00;
  --white: #ffffff;
  --paper: #fbfbf8;
  --black: #111213;
  --ff-display: 'Aptos Display','Aptos','Public Sans','Segoe UI',system-ui,-apple-system,sans-serif;
  --ff-body: 'Aptos','Public Sans','Segoe UI',system-ui,-apple-system,sans-serif;
  --ff-mono: 'Aptos Mono','JetBrains Mono','IBM Plex Mono',ui-monospace,Menlo,monospace;
  --r-sm: 4px; --r-md: 6px; --r-lg: 10px;
}

/* ---------- Reset / Base ---------- */
* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0; background: #fff; color: var(--slate-700);
  font-family: var(--ff-body); font-size: 16px; line-height: 1.5;
  -webkit-font-smoothing: antialiased; overflow-x: hidden;
}
img { max-width: 100%; display: block; }
a { color: inherit; }
h1,h2,h3,p { margin: 0; }
ul { margin: 0; padding: 0; list-style: none; }

.ca-mono { font-family: var(--ff-mono); }
.ca-eyebrow {
  font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--green-deep);
}

/* Container */
.wrap { max-width: 1180px; margin: 0 auto; padding: 0 40px; }
.wrap-wide { max-width: 1320px; margin: 0 auto; padding: 0 40px; }

.section { padding: 80px 0; }
.section--96 { padding: 96px 0; }
.section--88 { padding: 88px 0; }
.bg-mint50 { background: var(--mint-50); }
.bg-mint100 { background: var(--mint-100); }
.bg-slate100 { background: var(--slate-100); }

/* Section heading row */
.sec-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 24px; margin-bottom: 36px; }
.sec-head__aside { font-size: 13px; color: var(--slate-500); max-width: 380px; text-align: right; line-height: 1.5; }
.h2 { font-family: var(--ff-display); font-weight: 700; font-size: 32px; margin: 8px 0 0; line-height: 1.15; }
.h2--green { color: var(--green); }
.h2--deep { color: var(--green-deep); }
.h2--slate { color: var(--slate-700); }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font-family: var(--ff-display); font-weight: 600; font-size: 14px;
  padding: 11px 18px; border: 1px solid transparent; border-radius: var(--r-md);
  cursor: pointer; text-decoration: none; transition: background .15s, border-color .15s, color .15s;
}
.btn--lg { font-size: 15px; padding: 14px 22px; }
.btn--sm { font-size: 13px; padding: 8px 14px; }
.btn--primary { background: var(--green); color: #fff; }
.btn--primary:hover { background: var(--green-deep); }
.btn--deep { background: var(--green-deep); color: #fff; }
.btn--outline { background: transparent; color: var(--slate-700); border-color: var(--slate-100); }
.btn--outline:hover { border-color: var(--green); color: var(--green-deep); }
.btn--ghost { background: transparent; color: var(--slate-700); }
.btn--ghost:hover { color: var(--green-deep); }
.btn--amber { background: var(--amber); color: #fff; }

/* ---------- Topbar ---------- */
.topbar { background: var(--slate-100); border-bottom: 1px solid #e6ebee; font-size: 12px; }
.topbar__in { display: flex; align-items: center; justify-content: space-between; padding: 10px 40px; gap: 16px; }
.topbar__left { display: flex; align-items: center; gap: 18px; }
.topbar__brandline { color: var(--slate-500); letter-spacing: 0.08em; text-transform: uppercase; font-size: 10px; }
.switch { display: flex; gap: 4px; }
.switch__active { padding: 4px 10px; background: #fff; border: 1px solid var(--green); color: var(--green-deep); border-radius: 999px; font-weight: 600; font-size: 11px; }
.switch__link { padding: 4px 10px; color: var(--slate-500); font-size: 11px; text-decoration: none; }
.switch__link:hover { color: var(--green-deep); }
.topbar__right { display: flex; align-items: center; gap: 20px; color: var(--slate-500); }
.topbar__dot { color: var(--slate-100); }

/* ---------- Nav ---------- */
.nav { border-bottom: 1px solid var(--slate-100); background: #fff; position: relative; z-index: 30; }
.nav__in { display: flex; align-items: center; justify-content: space-between; padding: 18px 40px; gap: 20px; }
.nav__logo img { width: 200px; height: auto; mix-blend-mode: multiply; }
.nav__links { display: flex; align-items: center; gap: 22px; font-family: var(--ff-display); font-weight: 500; font-size: 14px; }
.nav__links a { color: var(--slate-700); text-decoration: none; border-bottom: 2px solid transparent; padding-bottom: 2px; white-space: nowrap; }
.nav__links a:hover { color: var(--green-deep); }
.nav__links a.is-active { color: var(--green-deep); font-weight: 700; border-bottom-color: var(--green); }
.nav__cta { display: flex; gap: 8px; }
.nav__burger {
  display: none; width: 44px; height: 44px; border: 1px solid var(--slate-100);
  background: #fff; border-radius: var(--r-md); cursor: pointer;
  align-items: center; justify-content: center; flex-shrink: 0;
}
.nav__burger svg { stroke: var(--slate-700); }

/* ---------- Hero ---------- */
.hero { position: relative; background: #fff; }
.hero__stage { position: relative; height: 620px; overflow: hidden; background: linear-gradient(180deg,#f4f6e8,#e2eed3); }
.hero__img { width: 100%; height: 100%; object-fit: cover; }
.hero__veil { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(255,255,255,.92) 0%, rgba(255,255,255,.55) 35%, rgba(255,255,255,0) 70%); }
.hero__content { position: absolute; inset: 0; display: flex; align-items: center; }
.hero__box { max-width: 600px; }
.hero h1 { font-family: var(--ff-display); font-weight: 700; font-size: 60px; line-height: 1.05; letter-spacing: -0.02em; color: var(--slate-700); }
.hero__lead { margin-top: 22px; font-size: 17px; line-height: 1.55; color: var(--slate-700); max-width: 500px; }
.hero__cta { display: flex; gap: 12px; margin-top: 32px; flex-wrap: wrap; }

/* Info-Strip (überlappt Hero) */
.infostrip-wrap { background: #fff; }
.infostrip {
  margin-top: -80px; position: relative; z-index: 2;
  background: var(--mint-100); border-radius: var(--r-md); padding: 32px 36px;
  display: grid; grid-template-columns: repeat(4,1fr); gap: 32px;
}
.infostrip__label { font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--green-deep); margin-bottom: 6px; }
.infostrip__value { font-family: var(--ff-display); font-size: 18px; font-weight: 600; color: var(--slate-700); margin-bottom: 2px; }
.infostrip__sub { font-size: 13px; color: var(--slate-500); }

/* ---------- Quick ---------- */
.quick-grid { display: grid; grid-template-columns: repeat(5,1fr); gap: 14px; }
.qcard { background: #fff; color: var(--slate-700); border: 1px solid var(--slate-100); border-radius: var(--r-md); padding: 24px 20px; min-height: 220px; display: flex; flex-direction: column; justify-content: space-between; }
.qcard--primary { background: var(--green); color: #fff; border-color: transparent; }
.qcard__top { display: flex; justify-content: space-between; align-items: start; margin-bottom: 12px; gap: 8px; }
.qcard h3 { font-family: var(--ff-display); font-weight: 700; font-size: 16px; }
.qcard__badge { font-size: 10px; font-family: var(--ff-mono); letter-spacing: 0.08em; background: var(--amber); color: #fff; padding: 2px 8px; border-radius: 999px; white-space: nowrap; flex-shrink: 0; }
.qcard p { font-size: 12.5px; line-height: 1.5; color: var(--slate-500); }
.qcard--primary p { color: rgba(255,255,255,.85); }
.qcard__phone { margin-top: 10px; font-size: 13px; font-weight: 600; color: var(--green-deep); white-space: nowrap; }
.qcard__cta { font-family: var(--ff-display); font-weight: 600; font-size: 13px; color: var(--green-deep); margin-top: 16px; }
.qcard--primary .qcard__cta { color: #fff; }
.msg-dots { display: flex; gap: 6px; margin-top: 12px; }
.msg-dots span { width: 18px; height: 18px; border-radius: 50%; border: 2px solid #fff; box-shadow: 0 0 0 1px var(--slate-100); }

/* ---------- News (HC_Pollen) ---------- */
.news-grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: 60px; align-items: center; }
.news-badge { display: inline-block; padding: 5px 12px; background: var(--kamille); color: var(--amber); font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.14em; border-radius: 999px; margin-bottom: 16px; font-weight: 600; }
.news h2 { font-family: var(--ff-display); font-weight: 700; font-size: 40px; line-height: 1.1; color: var(--slate-700); }
.news__body { margin-top: 18px; font-size: 16px; line-height: 1.55; max-width: 480px; }
.news__body2 { margin-top: 14px; font-size: 15px; line-height: 1.55; max-width: 480px; color: var(--slate-500); }
.news__cta { display: flex; gap: 12px; margin-top: 24px; flex-wrap: wrap; }
.news__meta { margin-top: 28px; padding-top: 20px; max-width: 480px; border-top: 1px solid rgba(0,119,42,.14); display: flex; flex-direction: column; gap: 13px; }
.news__metarow { display: grid; grid-template-columns: 94px 1fr; align-items: baseline; column-gap: 16px; text-decoration: none; }
.news__metalabel { font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--slate-500); }
.news__metalink { font-family: var(--ff-display); font-weight: 600; font-size: 15px; color: var(--green-deep); }
.news__imgs { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.news__prod { height: 420px; background: #fff; border-radius: var(--r-md); padding: 24px; display: flex; align-items: center; justify-content: center; }
.news__prod img { max-width: 100%; max-height: 100%; object-fit: contain; }
.news__mood { height: 420px; border-radius: var(--r-md); background-size: cover; background-position: center; }

/* ---------- Dienstleistungen ---------- */
.dl-head { display: grid; grid-template-columns: 1fr 1.3fr; gap: 40px; align-items: start; margin-bottom: 36px; }
.dl-head__img { width: 100%; height: 260px; object-fit: cover; object-position: center 70%; border-radius: var(--r-md); border: 1px solid rgba(0,119,42,.10); }
.dl-grid { display: grid; grid-template-columns: repeat(5,1fr); border-top: 1px solid var(--slate-100); border-left: 1px solid var(--slate-100); border-radius: var(--r-md); overflow: hidden; }
.dl-cell { padding: 26px 22px; border-right: 1px solid var(--slate-100); border-bottom: 1px solid var(--slate-100); background: #fff; }
.dl-cell__head { display: flex; align-items: flex-start; gap: 10px; margin-bottom: 10px; }
.dl-cell h3 { font-family: var(--ff-display); font-weight: 700; font-size: 14px; color: var(--slate-700); line-height: 1.25; }
.dl-cell p { font-size: 13px; color: var(--slate-500); line-height: 1.5; }
.dl-cross { flex-shrink: 0; }

/* ---------- Über uns ---------- */
.about-grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: 60px; align-items: center; }
.about-imgs { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.about-imgs img { width: 100%; height: 245px; object-fit: cover; border-radius: var(--r-md); border: 1px solid rgba(0,119,42,.10); }
.about h2 { font-family: var(--ff-display); font-weight: 700; font-size: 36px; line-height: 1.15; color: var(--slate-700); margin: 8px 0 18px; }
.about p { font-size: 15px; line-height: 1.6; margin-bottom: 16px; }
.about p strong { color: var(--slate-700); }
.about__stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; padding-top: 24px; border-top: 1px solid #d8e0e5; }
.about__statnum { font-family: var(--ff-display); font-size: 44px; font-weight: 700; color: var(--green); line-height: 1; }
.about__statnum--sm { font-size: 36px; }
.about__statlabel { font-size: 12px; color: var(--slate-500); margin-top: 6px; }

/* ---------- Öffnung & Anfahrt ---------- */
.oa-head { display: grid; grid-template-columns: 1fr auto; align-items: end; margin-bottom: 28px; gap: 24px; }
.oa-head__note { font-family: var(--ff-mono); font-size: 11px; color: var(--green-deep); letter-spacing: 0.1em; text-transform: uppercase; text-align: right; }
.oa-grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: 24px; align-items: stretch; }
.oa-card { background: #fff; border-radius: var(--r-md); padding: 28px 30px; border: 1px solid rgba(0,119,42,.18); display: flex; flex-direction: column; gap: 22px; }
.oa-imgs { display: grid; grid-template-rows: 1.25fr 1fr; gap: 24px; }
.oa-imgs > img { width: 100%; height: 100%; object-fit: cover; border-radius: var(--r-md); border: 1px solid rgba(0,119,42,.18); min-height: 200px; }
.oa-einfahrt { position: relative; border-radius: var(--r-md); overflow: hidden; border: 1px solid rgba(0,119,42,.18); min-height: 200px; }
.oa-einfahrt img { width: 100%; height: 100%; object-fit: cover; object-position: center 60%; }
.oa-arrow { position: absolute; left: 16px; bottom: 16px; display: flex; align-items: center; gap: 10px; background: var(--amber); color: #fff; padding: 8px 14px 8px 12px; border-radius: 999px; font-size: 12.5px; font-weight: 600; box-shadow: 0 4px 14px rgba(0,0,0,.25); max-width: calc(100% - 32px); }
.oa-arrow svg { flex-shrink: 0; }

/* Opening hours table */
.oh { background: #fff; border-radius: var(--r-md); overflow: hidden; border: 1px solid rgba(0,119,42,.15); }
.oh__row { display: grid; grid-template-columns: 108px minmax(0,1fr) auto; align-items: center; padding: 13px 18px; border-top: 1px solid var(--slate-100); gap: 14px; }
.oh__row:first-child { border-top: none; }
.oh__row.is-today { background: var(--mint-50); }
.oh__day { font-family: var(--ff-display); font-weight: 600; font-size: 14px; color: var(--slate-700); display: flex; align-items: center; gap: 8px; }
.oh__row.is-today .oh__day { font-weight: 700; }
.oh__day--muted { color: var(--slate-500); }
.oh__dot { display: none; width: 6px; height: 6px; border-radius: 50%; background: var(--green); box-shadow: 0 0 0 3px rgba(0,149,52,.2); }
.oh__row.is-today .oh__dot { display: block; }
.oh__h { font-family: var(--ff-mono); font-size: 13.5px; color: var(--slate-700); font-weight: 500; white-space: nowrap; }
.oh__h--muted { color: var(--slate-500); }
.oh__tag { font-size: 10px; font-family: var(--ff-mono); padding: 3px 9px; border-radius: 999px; letter-spacing: 0.1em; font-weight: 600; text-transform: uppercase; white-space: nowrap; background: var(--slate-100); color: var(--slate-500); }
.oh__tag--green { background: var(--green); color: #fff; }
.oh__tag--amber { background: var(--amber); color: #fff; }

.ferien { margin-top: 12px; display: flex; align-items: center; gap: 10px; padding: 10px 14px; background: var(--mint-50); border: 1px solid rgba(0,119,42,.15); border-radius: var(--r-md); font-size: 12px; line-height: 1.5; color: var(--slate-700); }
.ferien__dot { width: 8px; height: 8px; border-radius: 50%; background: var(--green); flex-shrink: 0; }
.ferien strong { color: var(--green-deep); }

.kontakt { border-top: 1px solid var(--slate-100); padding-top: 18px; }
.kontakt__title { font-family: var(--ff-mono); font-size: 11px; color: var(--green-deep); letter-spacing: 0.12em; text-transform: uppercase; margin-bottom: 12px; }
.kontakt__grid { display: grid; grid-template-columns: 110px 1fr; row-gap: 10px; column-gap: 16px; font-size: 14px; line-height: 1.5; }
.kontakt__label { font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--slate-500); padding-top: 2px; }
.kontakt__val { color: var(--slate-700); }
.kontakt__val .sub { color: var(--slate-500); font-size: 12.5px; margin-top: 4px; line-height: 1.5; }

/* ---------- Newsletter ---------- */
.nl { background: var(--slate-100); border-radius: var(--r-md); padding: 56px 60px; }
.nl-head { display: grid; grid-template-columns: 1.2fr 1fr; gap: 40px; align-items: end; margin-bottom: 32px; }
.nl-head h2 { font-family: var(--ff-display); font-weight: 700; font-size: 30px; color: var(--slate-700); margin: 8px 0 12px; line-height: 1.2; }
.nl-head p { font-size: 14px; color: var(--slate-500); max-width: 460px; line-height: 1.6; }
.nl-head__aside { font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--green-deep); text-align: right; }
.nl-themes { display: grid; grid-template-columns: repeat(3,1fr); gap: 14px; margin-bottom: 22px; }
.nl-theme { background: #fff; border: 1px solid #d8dde1; border-radius: var(--r-md); padding: 20px 22px; display: flex; gap: 14px; cursor: pointer; align-items: flex-start; transition: border-color .15s; }
.nl-theme:has(input:checked) { border: 1.5px solid var(--green); }
.nl-theme input { width: 18px; height: 18px; margin: 2px 0 0; accent-color: var(--green); cursor: pointer; flex-shrink: 0; }
.nl-theme__t { display: block; font-family: var(--ff-display); font-weight: 700; font-size: 16px; color: var(--slate-700); margin-bottom: 4px; }
.nl-theme__d { display: block; font-size: 12.5px; color: var(--slate-500); line-height: 1.5; }
.nl-theme > span { display: block; }
.nl-form { display: flex; gap: 8px; }
.nl-form input[type=email] { flex: 1; padding: 14px 16px; border: 1px solid #d8dde1; border-radius: var(--r-md); font-family: var(--ff-body); font-size: 14px; background: #fff; }
.nl-status { margin-top: 14px; padding: 12px 16px; border-radius: var(--r-md); font-size: 13.5px; line-height: 1.5; }
.nl-status--ok { background: var(--mint-100); color: var(--green-deep); border: 1px solid var(--green); }
.nl-status--err { background: #FCE9DE; color: #8B3A0F; border: 1px solid #E0A88B; }

/* ---------- Footer ---------- */
.footer { background: var(--green-deep); color: #fff; padding: 72px 0 0; }
.footer__cols { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1.1fr; gap: 40px; margin-bottom: 64px; }
.footer__logo { display: inline-block; background: #fff; padding: 14px 20px; border-radius: 12px; }
.footer__logo img { width: 200px; mix-blend-mode: multiply; }
.footer__tagline { font-size: 13px; line-height: 1.6; margin-top: 22px; color: rgba(255,255,255,.85); }
.footer__social { display: flex; gap: 12px; margin-top: 32px; }
.social-badge { width: 38px; height: 38px; border-radius: 50%; display: flex; align-items: center; justify-content: center; color: #fff; font-family: var(--ff-display); font-weight: 700; text-decoration: none; }
.social-badge--fb { background: #1877F2; }
.social-badge--ig { background: linear-gradient(45deg,#F58529,#DD2A7B,#8134AF); }
.footer__coltitle { font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(255,255,255,.5); margin-bottom: 14px; }
.footer__list { font-size: 13px; line-height: 1.9; }
.footer__list li.dim { color: rgba(255,255,255,.75); }
.footer__contact { font-size: 13px; line-height: 1.85; }
.footer__contact .addr { color: rgba(255,255,255,.85); margin-bottom: 8px; }
.footer__contact .dim { color: rgba(255,255,255,.75); }
.footer__trager { border-top: 1px solid rgba(255,255,255,.18); padding: 20px 0 22px; display: grid; grid-template-columns: 1fr auto; gap: 24px; align-items: center; }
.footer__trager .t { font-size: 12px; color: rgba(255,255,255,.75); line-height: 1.55; }
.footer__trager .t strong { color: #fff; }
.footer__trager .uid { font-size: 11px; font-family: var(--ff-mono); color: rgba(255,255,255,.6); letter-spacing: 0.08em; }
.footer__legal { border-top: 1px solid rgba(255,255,255,.18); padding: 20px 0; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px; font-size: 12px; color: rgba(255,255,255,.65); }
.footer__legal .muted { margin-left: 8px; color: rgba(255,255,255,.5); }
.footer__legal a { color: rgba(255,255,255,.85); text-decoration: none; border-bottom: 1px solid rgba(255,255,255,.3); padding-bottom: 1px; }
.footer__legallinks { display: flex; gap: 14px; }

.nl-embed { max-width: 720px; margin: 0 auto; min-height: 220px; }

/* ---------- Subpage Hero + Breadcrumb ---------- */
.phero { padding: 76px 0 64px; border-bottom: 1px solid rgba(0,119,42,.08); }
.phero--mint { background: var(--mint-50); }
.phero h1 { font-family: var(--ff-display); font-weight: 700; font-size: 56px; line-height: 1.08; letter-spacing: -0.02em; color: var(--slate-700); margin: 10px 0 18px; max-width: 760px; }
.phero__lead { font-size: 17px; line-height: 1.55; max-width: 640px; color: var(--slate-500); }
.phero__kicker { margin-top: 24px; }
.crumb { border-bottom: 1px solid var(--slate-100); background: #fff; }
.crumb__in { padding: 14px 40px; font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--slate-500); }
.crumb__in a { color: var(--slate-500); text-decoration: none; }
.crumb__in a:last-child, .crumb__in .cur { color: var(--green-deep); }
.crumb__sep { margin: 0 10px; color: var(--slate-100); }

/* Generic content helpers for subpages */
.lead-narrow { max-width: 720px; }
.cardgrid { display: grid; gap: 20px; }
.cardgrid--2 { grid-template-columns: repeat(2,1fr); }
.cardgrid--3 { grid-template-columns: repeat(3,1fr); }
.cardgrid--4 { grid-template-columns: repeat(4,1fr); }
.tile { background: #fff; border: 1px solid var(--slate-100); border-radius: var(--r-md); padding: 26px 24px; }
.tile h3 { font-family: var(--ff-display); font-weight: 700; font-size: 17px; color: var(--slate-700); margin-bottom: 8px; }
.tile p { font-size: 13.5px; line-height: 1.55; color: var(--slate-500); }

@media (max-width: 900px) {
  .phero { padding: 52px 0 40px; }
  .phero h1 { font-size: clamp(32px, 8vw, 48px); }
  .crumb__in { padding: 12px 22px; }
  .cardgrid--4, .cardgrid--3 { grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 560px) {
  .cardgrid--4, .cardgrid--3, .cardgrid--2 { grid-template-columns: 1fr; }
}

/* ---------- Dienstleistungen-Seite ---------- */
.dlg { display: grid; grid-template-columns: 300px 1fr; gap: 60px; }
.dlg + .dlg { margin-top: 56px; padding-top: 56px; border-top: 1px solid var(--slate-100); }
.dlg__h2 { font-family: var(--ff-display); font-weight: 700; font-size: 26px; line-height: 1.2; color: var(--green); margin: 10px 0 0; }
.svc-grid { display: grid; grid-template-columns: repeat(2,1fr); border-top: 1px solid var(--slate-100); border-left: 1px solid var(--slate-100); border-radius: var(--r-md); overflow: hidden; }
.svc-cell { padding: 24px 26px; background: #fff; border-right: 1px solid var(--slate-100); border-bottom: 1px solid var(--slate-100); }
.svc-cell__head { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }
.svc-cell h3 { font-family: var(--ff-display); font-weight: 700; font-size: 16px; color: var(--slate-700); }
.svc-cell p { font-size: 13px; line-height: 1.55; color: var(--slate-500); margin-bottom: 10px; }
.svc-cell__meta { font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--green-deep); }
.steps { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.step { background: #fff; border-radius: var(--r-md); padding: 32px 28px; }
.step__n { font-family: var(--ff-display); font-weight: 700; font-size: 44px; color: var(--green); line-height: 1; }
.step h3 { font-family: var(--ff-display); font-weight: 700; font-size: 18px; color: var(--slate-700); margin: 18px 0 10px; }
.step p { font-size: 14px; line-height: 1.55; color: var(--slate-500); }
.crosssell { background: var(--mint-100); border-radius: var(--r-md); padding: 44px 48px; display: grid; grid-template-columns: 1.2fr 1fr; gap: 40px; align-items: center; text-decoration: none; color: inherit; }
.crosssell h2 { font-family: var(--ff-display); font-weight: 700; font-size: 26px; color: var(--green-deep); margin: 8px 0 12px; line-height: 1.2; }
.crosssell p { font-size: 14px; color: var(--slate-700); line-height: 1.55; max-width: 520px; }
.crosssell__cta { font-family: var(--ff-display); font-weight: 600; font-size: 15px; color: var(--green-deep); text-align: right; }

@media (max-width: 900px) {
  .dlg { grid-template-columns: 1fr; gap: 22px; }
  .steps { grid-template-columns: 1fr; }
  .crosssell { grid-template-columns: 1fr; gap: 18px; padding: 32px 24px; }
  .crosssell__cta { text-align: left; }
}
@media (max-width: 560px) { .svc-grid { grid-template-columns: 1fr; } }

/* ---------- Hausspezialitäten-Seite ---------- */
.hs-featured { background: var(--mint-50); border-radius: var(--r-md); padding: 48px; display: grid; grid-template-columns: 1fr 1.1fr; gap: 56px; align-items: center; }
.hs-featured__img { background: var(--mint-50); border-radius: var(--r-md); padding: 48px; height: 420px; display: flex; align-items: center; justify-content: center; }
.hs-featured__img img { max-width: 100%; max-height: 100%; object-fit: contain; }
.hs-featured h2 { font-family: var(--ff-display); font-weight: 700; font-size: 36px; color: var(--slate-700); margin: 10px 0 14px; line-height: 1.15; }
.hs-featured p { font-size: 15px; line-height: 1.6; margin-bottom: 16px; }
.hs-featured .sub { font-size: 13px; color: var(--slate-500); margin-bottom: 24px; }
.prodgroup { margin-bottom: 56px; }
.prodgroup h3 { font-family: var(--ff-display); font-weight: 700; font-size: 20px; color: var(--slate-700); margin-bottom: 20px; padding-bottom: 12px; border-bottom: 1px solid var(--slate-100); }
.prodgrid { display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; }
.prodcard { border: 1px solid var(--slate-100); border-radius: var(--r-md); overflow: hidden; background: #fff; }
.prodcard__img { height: 180px; background: #fff; border-bottom: 1px solid var(--slate-100); display: flex; align-items: center; justify-content: center; padding: 16px; }
.prodcard__img img { max-width: 100%; max-height: 100%; object-fit: contain; }
.prodcard__body { padding: 16px 18px; }
.prodcard__row { display: flex; justify-content: space-between; align-items: baseline; gap: 8px; }
.prodcard h4 { font-family: var(--ff-display); font-weight: 700; font-size: 14px; color: var(--slate-700); }
.prodcard__tag { font-family: var(--ff-mono); font-size: 9px; color: var(--slate-500); letter-spacing: 0.1em; text-transform: uppercase; white-space: nowrap; }
.prodcard p { font-size: 12px; color: var(--slate-500); margin-top: 6px; line-height: 1.5; }
.legend { display: flex; gap: 12px; align-items: center; }
.legend__i { display: flex; align-items: center; gap: 6px; font-size: 11px; color: var(--slate-500); font-family: var(--ff-mono); letter-spacing: 0.06em; text-transform: uppercase; }
.legend__dot { width: 10px; height: 10px; border-radius: 50%; border: 1px solid #d0d6d9; }
.spag-grid { display: grid; grid-template-columns: repeat(2,1fr); border-top: 1px solid var(--slate-100); border-left: 1px solid var(--slate-100); border-radius: var(--r-md); overflow: hidden; margin-bottom: 24px; }
.spag-cell { padding: 18px 22px; background: #fff; border-right: 1px solid var(--slate-100); border-bottom: 1px solid var(--slate-100); display: grid; grid-template-columns: 52px 1fr auto; gap: 16px; align-items: center; }
.spag-nr { font-family: var(--ff-mono); font-size: 11px; font-weight: 700; color: #fff; background: var(--green); border-radius: 4px; padding: 4px 8px; text-align: center; }
.spag-cell .nm { font-family: var(--ff-display); font-weight: 700; font-size: 15px; color: var(--slate-700); }
.spag-cell .ds { font-size: 12px; color: var(--slate-500); margin-top: 2px; }
.spag-cell .st { font-family: var(--ff-mono); font-size: 9px; letter-spacing: 0.14em; color: var(--green-deep); text-transform: uppercase; font-weight: 700; }
.spag-anfrage { background: var(--slate-100); border-radius: var(--r-md); padding: 22px 26px; }
.chipwrap { display: flex; flex-wrap: wrap; gap: 8px; }
.chip { background: #fff; border-radius: 999px; padding: 8px 14px; font-size: 13px; color: var(--slate-700); border: 1px solid #e0e6ea; }
.chip .ds { color: var(--slate-500); margin-left: 8px; font-size: 12px; }
.bach { background: var(--mint-50); padding: 80px 0; }
.bach__grid { display: grid; grid-template-columns: 0.9fr 1.4fr; gap: 56px; align-items: start; }
.bach h2 { font-family: var(--ff-display); font-weight: 700; font-size: 30px; color: var(--green-deep); margin: 8px 0 14px; line-height: 1.2; }
.bach p { font-size: 14.5px; line-height: 1.65; margin-bottom: 14px; }
.bach__list { display: flex; flex-direction: column; gap: 6px; font-size: 13px; color: var(--slate-500); }
.bach__list li { padding-left: 16px; position: relative; }
.bach__list li::before { content: ""; position: absolute; left: 0; top: 8px; width: 8px; height: 2px; background: var(--green); }
.bach__cloud { display: grid; grid-template-columns: repeat(4,1fr); gap: 8px; }
.bach__chip { background: #fff; border: 1px solid rgba(0,119,42,0.12); border-radius: 6px; padding: 12px 14px; font-size: 12.5px; color: var(--slate-700); display: flex; align-items: center; gap: 8px; }
.bach__chip i { width: 6px; height: 6px; border-radius: 50%; background: var(--green); opacity: .7; flex-shrink: 0; }
.salz-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 10px; }
.salz { background: #fff; border-radius: var(--r-md); border: 1px solid var(--slate-100); padding: 16px 18px; display: grid; grid-template-columns: auto 1fr; gap: 14px; align-items: center; }
.salz__n { font-family: var(--ff-mono); font-size: 16px; font-weight: 700; color: #fff; background: var(--green-deep); border-radius: 6px; width: 38px; height: 38px; display: flex; align-items: center; justify-content: center; }
.salz .nm { font-family: var(--ff-display); font-weight: 700; font-size: 13px; color: var(--slate-700); line-height: 1.25; }
.salz .ds { font-size: 11.5px; color: var(--slate-500); margin-top: 2px; }
.tipstrip { margin-top: 24px; background: var(--mint-50); border: 1px solid rgba(0,119,42,0.12); border-radius: var(--r-md); padding: 18px 22px; font-size: 13px; color: var(--slate-700); line-height: 1.55; display: flex; align-items: center; gap: 16px; }
.tipstrip__k { font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.14em; color: var(--green-deep); text-transform: uppercase; font-weight: 700; flex-shrink: 0; }
.badge-amber { padding: 5px 12px; background: var(--amber); color: #fff; font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; font-weight: 700; border-radius: 999px; white-space: nowrap; }
.hck { background: #fff; border-radius: 12px; padding: 44px 48px; display: grid; grid-template-columns: 1.3fr 1fr; gap: 48px; align-items: center; border: 1px solid rgba(0,119,42,0.15); }
.hck h2 { font-family: var(--ff-display); font-weight: 700; font-size: 30px; color: var(--slate-700); margin: 0 0 14px; line-height: 1.2; }
.hck p { font-size: 14.5px; line-height: 1.65; margin-bottom: 14px; }
.hck__list { display: flex; flex-direction: column; gap: 6px; font-size: 13px; color: var(--slate-500); margin-bottom: 18px; }
.hck__list li { padding-left: 16px; position: relative; }
.hck__list li::before { content: ""; position: absolute; left: 0; top: 8px; width: 8px; height: 2px; background: var(--green); }
.hck__img { background: #fff; border-radius: var(--r-md); padding: 32px 28px; border: 1px solid rgba(0,119,42,0.15); display: flex; align-items: center; justify-content: center; min-height: 380px; }
.hck__img img { max-width: 100%; max-height: 360px; object-fit: contain; }
.badge-green { padding: 3px 10px; background: var(--green); color: #fff; font-family: var(--ff-mono); font-size: 9px; letter-spacing: 0.14em; text-transform: uppercase; font-weight: 700; border-radius: 999px; white-space: nowrap; }
.numsteps { display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; }
.numstep { background: #fff; border-radius: var(--r-md); padding: 26px 24px; }
.numstep__n { font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.14em; color: var(--green-deep); }
.numstep h3 { font-family: var(--ff-display); font-weight: 700; font-size: 16px; color: var(--slate-700); margin: 14px 0 8px; }
.numstep p { font-size: 13px; line-height: 1.55; color: var(--slate-500); }

@media (max-width: 900px) {
  .hs-featured, .bach__grid, .hck { grid-template-columns: 1fr; gap: 28px; }
  .hs-featured, .hck { padding: 28px; }
  .prodgrid, .bach__cloud, .salz-grid, .numsteps { grid-template-columns: repeat(2,1fr); }
  .spag-grid { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
  .prodgrid, .bach__cloud, .salz-grid, .numsteps { grid-template-columns: 1fr; }
}

/* ---------- Geschichte-Seite ---------- */
.tl { position: relative; }
.tl-line { position: absolute; left: 14px; top: 8px; bottom: 8px; width: 2px; background: var(--mint-100); }
.tl-event { position: relative; padding: 44px 0 44px 60px; border-bottom: 1px solid var(--slate-100); display: grid; grid-template-columns: 140px 1fr; gap: 40px; align-items: start; }
.tl-event:last-child { border-bottom: none; }
.tl-dot { position: absolute; left: 0; top: 50px; width: 30px; height: 30px; border-radius: 50%; background: #fff; border: 3px solid var(--green); box-sizing: border-box; display: flex; align-items: center; justify-content: center; z-index: 1; }
.tl-event.hl .tl-dot { background: var(--green); }
.tl-dot i { width: 8px; height: 8px; border-radius: 50%; background: #fff; }
.tl-year { font-family: var(--ff-display); font-weight: 700; font-size: 48px; color: var(--green); line-height: 1; }
.tl-event.hl .tl-year { color: var(--green-deep); }
.tl-body { display: grid; grid-template-columns: 1.1fr 1fr; gap: 32px; align-items: start; }
.tl-body img { width: 100%; height: 320px; object-fit: cover; border-radius: 6px; border: 1px solid var(--slate-100); }
.tl-body.hist img { filter: sepia(0.18) contrast(1.04) brightness(1.02); border: 1px solid #d8c9a8; box-shadow: 0 6px 24px -12px rgba(120,90,30,.35); }
.tl-body h3 { font-family: var(--ff-display); font-weight: 700; font-size: 24px; color: var(--slate-700); margin-bottom: 14px; line-height: 1.2; }
.tl-body p { font-size: 14.5px; line-height: 1.65; color: var(--slate-500); }
.tl-arch { margin-top: 16px; font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.14em; color: #8B5A00; text-transform: uppercase; }
.media-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; }
.mediacard { background: #fff; border-radius: var(--r-md); border: 1px solid var(--slate-100); overflow: hidden; display: flex; flex-direction: column; }
.mediacard__hd { padding: 14px 18px; border-bottom: 1px solid var(--slate-100); background: var(--mint-50); display: flex; justify-content: space-between; align-items: center; gap: 10px; }
.mediacard__blatt { font-family: var(--ff-display); font-weight: 800; font-size: 13.5px; color: var(--slate-700); line-height: 1.2; }
.mediacard__date { font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--slate-500); text-transform: uppercase; white-space: nowrap; }
.mediacard__img { position: relative; }
.mediacard__img img { width: 100%; height: 180px; object-fit: cover; display: block; }
.mediacard__img.contain { background: #f4f0e9; }
.mediacard__img.contain img { object-fit: contain; }
.mediacard__video { position: absolute; left: 12px; bottom: 12px; background: rgba(0,0,0,.7); color: #fff; padding: 5px 10px 5px 8px; border-radius: 999px; font-size: 10.5px; font-family: var(--ff-mono); display: flex; align-items: center; gap: 6px; }
.mediacard__body { padding: 20px 22px; flex: 1; display: flex; flex-direction: column; gap: 12px; }
.mediacard__typ { font-family: var(--ff-mono); font-size: 9px; letter-spacing: 0.14em; color: var(--green-deep); text-transform: uppercase; font-weight: 700; }
.mediacard h3 { font-family: var(--ff-display); font-weight: 700; font-size: 16px; color: var(--slate-700); line-height: 1.3; }
.mediacard blockquote { margin: 0; padding: 10px 0 10px 14px; border-left: 3px solid var(--green); font-style: italic; font-size: 13px; line-height: 1.55; color: var(--slate-700); }
.mediacard blockquote .by { font-style: normal; font-size: 11px; margin-top: 8px; color: var(--slate-500); font-family: var(--ff-mono); letter-spacing: 0.04em; }
.mediacard__ctx { font-size: 12.5px; line-height: 1.55; color: var(--slate-500); }
.mediacard__link { margin-top: auto; font-size: 12.5px; color: var(--green-deep); font-family: var(--ff-display); font-weight: 600; text-decoration: none; }
.heute { background: var(--mint-100); padding: 72px 0; }
.heute__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
.heute h2 { font-family: var(--ff-display); font-weight: 700; font-size: 30px; color: var(--green-deep); margin: 8px 0 14px; line-height: 1.2; }
.heute p { font-size: 15px; line-height: 1.6; margin-bottom: 22px; }
.heute img { width: 100%; height: 320px; object-fit: cover; border-radius: var(--r-md); }

@media (max-width: 900px) {
  .tl-line { left: 11px; }
  .tl-event { grid-template-columns: 1fr; gap: 16px; padding-left: 44px; }
  .tl-dot { width: 24px; height: 24px; top: 46px; }
  .tl-year { font-size: 36px; }
  .tl-body { grid-template-columns: 1fr; gap: 18px; }
  .tl-body img { height: 240px; }
  .media-grid { grid-template-columns: 1fr; }
  .heute__grid { grid-template-columns: 1fr; gap: 28px; }
}

/* ---------- FAQ-Seite ---------- */
.faq-search { background: #fff; border: 1px solid rgba(0,119,42,0.18); border-radius: var(--r-md); padding: 6px 6px 6px 22px; margin-bottom: 36px; display: flex; align-items: center; gap: 12px; box-shadow: 0 2px 8px -4px rgba(0,0,0,.04); }
.faq-search__icon { font-family: var(--ff-mono); color: var(--slate-500); font-size: 16px; }
.faq-search input { flex: 1; border: none; outline: none; background: transparent; font-family: var(--ff-body); font-size: 15px; padding: 12px 0; color: var(--slate-700); }
.faq-treffer { font-family: var(--ff-mono); font-size: 11px; color: var(--green-deep); letter-spacing: 0.08em; text-transform: uppercase; margin-right: 12px; }
.faq-layout { display: grid; grid-template-columns: 260px 1fr; gap: 56px; }
.faq-side nav { display: flex; flex-direction: column; gap: 4px; position: sticky; top: 24px; }
.faq-side a { padding: 10px 14px; border-radius: 6px; font-family: var(--ff-display); font-weight: 500; font-size: 14px; color: var(--slate-700); text-decoration: none; border-left: 2px solid transparent; display: flex; justify-content: space-between; align-items: center; gap: 10px; }
.faq-side a.is-active { background: var(--mint-50); border-left-color: var(--green); }
.faq-side a.dim { opacity: .5; }
.faq-side a .ct { font-family: var(--ff-mono); font-size: 10px; color: var(--slate-500); }
.faq-theme + .faq-theme { margin-top: 48px; padding-top: 48px; border-top: 1px solid var(--slate-100); }
.faq-theme h2 { font-family: var(--ff-display); font-weight: 700; font-size: 28px; color: var(--green); margin: 8px 0 22px; line-height: 1.2; }
.faq-list { border-top: 1px solid var(--slate-100); }
.faq-item { border-bottom: 1px solid var(--slate-100); padding: 18px 4px; }
.faq-item summary { cursor: pointer; list-style: none; display: flex; justify-content: space-between; align-items: center; font-family: var(--ff-display); font-weight: 600; font-size: 16px; color: var(--slate-700); gap: 16px; }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary .pm { font-family: var(--ff-mono); font-size: 18px; color: var(--green); flex-shrink: 0; transition: transform .15s; }
.faq-item[open] summary .pm { transform: rotate(45deg); }
.faq-item p { font-size: 14px; line-height: 1.65; color: var(--slate-500); margin: 12px 0 4px; max-width: 680px; }
.faq-item p a { color: var(--green-deep); text-decoration: underline; }
.faq-empty { background: var(--mint-50); border-radius: var(--r-md); padding: 32px 36px; text-align: center; }
.faq-empty h3 { font-family: var(--ff-display); font-weight: 700; font-size: 18px; color: var(--slate-700); margin-bottom: 8px; }
.faq-empty p { font-size: 13px; color: var(--slate-500); }
.faq-nf { background: var(--mint-100); padding: 72px 0; }
.faq-nf__grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 48px; align-items: center; }
.faq-nf h2 { font-family: var(--ff-display); font-weight: 700; font-size: 28px; color: var(--green-deep); margin: 8px 0 12px; line-height: 1.2; }
.faq-nf p { font-size: 14px; line-height: 1.6; color: var(--slate-700); max-width: 540px; }
.faq-nf__cta { display: flex; gap: 12px; justify-content: flex-end; flex-wrap: wrap; }

@media (max-width: 900px) {
  .faq-layout { grid-template-columns: 1fr; gap: 24px; }
  .faq-side nav { position: static; flex-direction: row; flex-wrap: wrap; }
  .faq-side a { border-left: none; border: 1px solid var(--slate-100); }
  .faq-nf__grid { grid-template-columns: 1fr; gap: 24px; }
  .faq-nf__cta { justify-content: flex-start; }
}

/* ---------- Impressum / Rechtliches ---------- */
.imp-head { margin-bottom: 32px; }
.imp-head h2 { font-family: var(--ff-display); font-weight: 700; font-size: 30px; color: var(--green); margin-top: 8px; }
.imp-grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; }
.imp-box { background: #fff; border: 1px solid var(--slate-100); border-radius: var(--r-md); padding: 26px 28px; }
.imp-box h3 { font-family: var(--ff-display); font-weight: 700; font-size: 17px; color: var(--slate-700); margin-bottom: 16px; padding-bottom: 12px; border-bottom: 1px solid var(--slate-100); }
.dl { margin: 0; display: grid; grid-template-columns: 120px 1fr; row-gap: 12px; column-gap: 16px; font-size: 13.5px; line-height: 1.5; }
.dl dt { font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--slate-500); padding-top: 2px; }
.dl dd { margin: 0; color: var(--slate-700); }
.dl dd .ca-mono { display: block; margin-top: 6px; }
.imp-src { margin-top: 12px; font-size: 11px; color: var(--slate-500); font-family: var(--ff-mono); letter-spacing: 0.04em; }
.ds-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 16px; }
.ds-card { background: #fff; border: 1px solid rgba(0,119,42,0.12); border-radius: var(--r-md); padding: 24px 26px; }
.ds-card h3 { font-family: var(--ff-display); font-weight: 700; font-size: 16px; color: var(--slate-700); margin-bottom: 10px; }
.ds-card p { font-size: 13.5px; line-height: 1.65; color: var(--slate-500); }
.cp-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 40px; align-items: start; }
.cp-main { background: #fff; border-radius: var(--r-md); border: 1px solid var(--slate-100); padding: 30px 32px; font-size: 14.5px; line-height: 1.7; color: var(--slate-700); }
.cp-main p { margin: 0 0 14px; }
.cp-main p:last-child { margin-bottom: 0; }
.cp-side { background: var(--mint-100); border: 1px solid rgba(0,119,42,0.2); border-radius: var(--r-md); padding: 26px 28px; }
.cp-side h3 { font-family: var(--ff-display); font-weight: 700; font-size: 18px; color: var(--green-deep); margin: 8px 0 12px; line-height: 1.3; }
.cp-side p { font-size: 13px; line-height: 1.6; color: var(--slate-700); margin-bottom: 16px; }
@media (max-width: 900px) { .imp-grid2, .ds-grid, .cp-grid { grid-template-columns: 1fr; gap: 16px; } .dl { grid-template-columns: 100px 1fr; } }

/* ---------- Notfalldienst-Seite ---------- */
.phero--mint100 { background: var(--mint-100); }
.notruf-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; }
.notruf { background: #fff; border: 1px solid var(--slate-100); border-radius: var(--r-md); padding: 28px; display: flex; align-items: center; gap: 24px; }
.notruf__n { font-family: var(--ff-display); font-weight: 700; font-size: 52px; color: var(--green); line-height: 1; flex-shrink: 0; min-width: 92px; }
.notruf__l { font-family: var(--ff-display); font-weight: 700; font-size: 15px; color: var(--slate-700); margin-bottom: 4px; }
.notruf p { font-size: 12.5px; line-height: 1.5; color: var(--slate-500); }
.nd-grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: 48px; align-items: start; }
.nd-banner { background: #fff; border: 2px solid var(--green); border-radius: var(--r-md); padding: 22px 26px; display: flex; align-items: center; gap: 24px; margin-bottom: 16px; flex-wrap: wrap; }
.nd-banner__n { font-family: var(--ff-display); font-weight: 700; font-size: 30px; color: var(--green); line-height: 1; white-space: nowrap; }
.nd-banner__d { border-left: 1px solid var(--slate-100); padding-left: 24px; }
.nd-contacts { background: #fff; border-radius: var(--r-md); padding: 28px 32px; border: 1px solid rgba(0,119,42,0.18); }
.krow { display: grid; grid-template-columns: 1fr auto; gap: 16px; padding: 14px 0; border-top: 1px solid var(--slate-100); align-items: center; }
.krow__l { font-size: 14px; font-family: var(--ff-display); font-weight: 600; color: var(--slate-700); }
.krow.hl .krow__l, .krow.hl .krow__t { color: var(--green-deep); }
.krow__h { font-size: 11px; color: var(--slate-500); margin-top: 2px; }
.krow__t { font-family: var(--ff-mono); font-size: 15px; font-weight: 600; color: var(--slate-700); }
.triage { border-radius: 10px; overflow: hidden; display: grid; grid-template-columns: 240px 1.3fr 1fr 1fr; border: 2px solid; }
.triage + .triage { margin-top: 18px; }
.triage__ribbon { color: #fff; padding: 28px 24px; display: flex; flex-direction: column; justify-content: space-between; gap: 8px; }
.triage__stufe { font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; opacity: .85; }
.triage__level { font-family: var(--ff-display); font-weight: 700; font-size: 42px; line-height: 1; white-space: nowrap; }
.triage__num { font-family: var(--ff-mono); font-size: 17px; font-weight: 600; }
.triage__act { padding: 26px 28px; }
.triage__act .k { font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; margin-bottom: 8px; }
.triage__act h3 { font-family: var(--ff-display); font-weight: 700; font-size: 17px; color: var(--slate-700); margin-bottom: 8px; line-height: 1.35; }
.triage__act .sub { font-size: 12.5px; color: var(--slate-500); margin-top: 4px; line-height: 1.5; }
.triage__list { padding: 26px; }
.triage__list .k { font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; margin-bottom: 12px; }
.triage__list ul { display: flex; flex-direction: column; gap: 6px; }
.triage__list li { font-size: 12.5px; line-height: 1.5; color: var(--slate-700); padding-left: 14px; position: relative; }
.triage__list li i { position: absolute; left: 0; top: 8px; width: 6px; height: 2px; }
.qr-strip { margin-top: 32px; padding: 22px 26px; background: var(--slate-100); border-radius: var(--r-md); display: grid; grid-template-columns: auto 1fr; gap: 24px; align-items: center; }
.qr-strip__box { background: #fff; padding: 8px; border-radius: 6px; border: 1px solid var(--slate-100); width: 92px; height: 92px; display: flex; align-items: center; justify-content: center; }
.qr-strip__box img { width: 100%; height: 100%; }
.lang-box { margin-top: 18px; padding: 26px 28px; background: #fff; border-radius: var(--r-md); border: 1px solid var(--slate-100); }
.lang-head { display: grid; grid-template-columns: 1fr auto; gap: 24px; align-items: start; margin-bottom: 18px; }
.lang-pills { display: flex; flex-wrap: wrap; gap: 8px; }
.lang-pill { display: inline-flex; align-items: baseline; gap: 8px; padding: 8px 14px; border-radius: 999px; background: var(--mint-50); color: var(--green-deep); border: 1px solid rgba(0,119,42,0.18); font-size: 12.5px; font-family: var(--ff-display); font-weight: 600; text-decoration: none; }
.lang-pill .nat { font-weight: 400; font-size: 11.5px; color: var(--slate-500); }
.aerzt-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 18px; }
.aerzt { background: #fff; border: 1px solid var(--slate-100); border-radius: var(--r-md); padding: 26px 28px; display: grid; grid-template-columns: auto 1fr; gap: 22px; align-items: start; }
.aerzt.wide { grid-column: 1/-1; }
.aerzt .k { font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--green-deep); margin-bottom: 4px; }
.aerzt h3 { font-family: var(--ff-display); font-weight: 700; font-size: 18px; color: var(--slate-700); margin-bottom: 12px; }
.aerzt__single { font-family: var(--ff-mono); font-size: 16px; font-weight: 600; color: var(--slate-700); margin-bottom: 10px; }
.aerzt__depts { display: grid; grid-template-columns: 1fr; column-gap: 24px; row-gap: 10px; margin-bottom: 14px; }
.aerzt.wide .aerzt__depts { grid-template-columns: repeat(2,1fr); }
.aerzt__dept { display: flex; flex-direction: column; gap: 2px; padding-top: 8px; border-top: 1px solid var(--slate-100); }
.aerzt__dept .dl2 { font-family: var(--ff-display); font-weight: 600; font-size: 13px; color: var(--slate-700); }
.aerzt__dept .tl2 { font-family: var(--ff-mono); font-size: 14px; font-weight: 600; color: var(--green-deep); white-space: nowrap; }
.aerzt__dept .hl2 { font-size: 11px; color: var(--slate-500); font-style: italic; }
.aerzt p { font-size: 13px; line-height: 1.55; color: var(--slate-500); }
.tox { background: #fff; border: 2px solid var(--green); border-radius: var(--r-md); padding: 40px 44px; display: grid; grid-template-columns: 180px 1fr auto; gap: 32px; align-items: center; }
.tox__n { font-family: var(--ff-display); font-weight: 700; font-size: 84px; color: var(--green); line-height: 1; }
.tox h3 { font-family: var(--ff-display); font-weight: 700; font-size: 22px; color: var(--slate-700); margin: 8px 0; }
.tox p { font-size: 14px; line-height: 1.6; color: var(--slate-500); max-width: 540px; }
.mit-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; }
.mit { background: var(--mint-50); border-radius: var(--r-md); padding: 22px 24px; border: 1px solid rgba(0,119,42,0.12); }
.mit__h { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }
.mit h3 { font-family: var(--ff-display); font-weight: 700; font-size: 15px; color: var(--slate-700); }
.mit p { font-size: 13px; line-height: 1.55; color: var(--slate-500); padding-left: 26px; }

@media (max-width: 900px) {
  .notruf-grid, .mit-grid { grid-template-columns: 1fr; }
  .nd-grid, .aerzt-grid { grid-template-columns: 1fr; gap: 24px; }
  .triage { grid-template-columns: 1fr; }
  .aerzt.wide .aerzt__depts { grid-template-columns: 1fr; }
  .qr-strip, .lang-head { grid-template-columns: 1fr; }
  .tox { grid-template-columns: 1fr; gap: 18px; }
}

/* ---------- Team-Seite ---------- */
.inh-grid { display: grid; grid-template-columns: 1fr 1.3fr; gap: 60px; align-items: stretch; }
.inh-id { background: #E9F2EC; border-radius: 10px; padding: 44px 40px; display: flex; flex-direction: column; gap: 26px; }
.inh-id h2 { font-family: var(--ff-display); font-weight: 700; font-size: 40px; color: var(--green-deep); margin: 12px 0 8px; line-height: 1.04; }
.inh-since { font-family: var(--ff-mono); font-size: 11.5px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--green-deep); opacity: .8; }
.inh-quals { display: flex; flex-direction: column; gap: 13px; }
.inh-qual { display: flex; gap: 11px; align-items: flex-start; }
.inh-qual .tick { width: 18px; height: 18px; border-radius: 50%; background: var(--green); color: #fff; flex-shrink: 0; display: inline-flex; align-items: center; justify-content: center; margin-top: 1px; }
.inh-qual .txt { font-size: 13.5px; line-height: 1.45; color: var(--slate-700); font-weight: 500; }
.inh-langs { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; margin-top: auto; }
.inh-langs .lbl { font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.14em; color: var(--green-deep); text-transform: uppercase; font-weight: 700; margin-right: 4px; }
.inh-langs .pill { font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.06em; padding: 5px 11px; border-radius: 999px; background: #fff; color: var(--green-deep); border: 1px solid rgba(0,119,42,0.18); font-weight: 600; }
.inh-words { display: flex; flex-direction: column; justify-content: center; }
.inh-words > p { font-size: 15px; line-height: 1.65; margin-bottom: 22px; }
.inh-quotes { padding-left: 24px; border-left: 3px solid var(--green); display: flex; flex-direction: column; gap: 16px; }
.inh-quotes p { font-size: 16px; line-height: 1.6; color: var(--slate-700); font-style: italic; margin: 0; }
.vita { background: #fff; border-radius: 8px; border: 1px solid rgba(0,119,42,0.18); }
.vita summary { cursor: pointer; list-style: none; padding: 20px 28px; display: flex; justify-content: space-between; align-items: center; border-bottom: 1px solid var(--slate-100); font-family: var(--ff-display); font-weight: 600; font-size: 15px; color: var(--slate-700); }
.vita summary::-webkit-details-marker { display: none; }
.vita summary .pm { font-family: var(--ff-mono); font-size: 20px; color: var(--green); }
.vita__body { max-height: 540px; overflow-y: auto; padding: 8px 0; }
.vita__row { display: grid; grid-template-columns: 180px 1fr; padding: 10px 28px; gap: 16px; align-items: baseline; border-left: 3px solid transparent; }
.vita__row.hl { background: var(--mint-50); border-left-color: var(--green); }
.vita__y { font-family: var(--ff-mono); font-size: 12px; color: var(--green-deep); letter-spacing: 0.04em; font-weight: 600; }
.vita__t { font-size: 13.5px; line-height: 1.5; color: var(--slate-700); }
.vita__row.hl .vita__t { font-weight: 600; }
.team-headrow { display: flex; justify-content: space-between; align-items: end; margin-bottom: 36px; gap: 24px; }
.team-headrow .cnt { font-size: 13px; color: var(--slate-500); text-align: right; }
.team-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; }
.tcard { background: #fff; border: 1px solid rgba(0,119,42,0.10); border-radius: 10px; overflow: hidden; display: flex; flex-direction: column; }
.tcard.vacant { border: 2px dashed var(--green); }
.tcard.tone-prescription { --tbg: #E9F2EC; --tink: var(--green-deep); --tring: rgba(0,119,42,0.15); }
.tcard.tone-flask { --tbg: #F2EDE2; --tink: #7A5E1F; --tring: rgba(140,110,40,0.18); }
.tcard.tone-heart { --tbg: #F1E8EA; --tink: #8B3A50; --tring: rgba(139,58,80,0.18); }
.tcard.tone-school { --tbg: #E6EEF2; --tink: #2E5A75; --tring: rgba(46,90,117,0.20); }
.tcard__head { position: relative; height: 150px; background: var(--tbg); display: flex; align-items: center; justify-content: center; }
.tcard__mono { font-family: var(--ff-display); font-weight: 700; font-size: 56px; color: var(--tink); letter-spacing: -0.02em; line-height: 1; }
.tcard.vacant .tcard__mono { font-size: 64px; }
.tcard__role { position: absolute; top: 12px; right: 12px; width: 36px; height: 36px; border-radius: 50%; background: #fff; color: var(--tink); border: 1px solid var(--tring); display: inline-flex; align-items: center; justify-content: center; }
.tcard__seit { position: absolute; top: 14px; left: 14px; font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--tink); opacity: .75; }
.tcard__offen { position: absolute; bottom: 14px; left: 0; right: 0; text-align: center; font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.14em; color: var(--green-deep); text-transform: uppercase; }
.tcard__body { padding: 18px 18px 20px; flex: 1; display: flex; flex-direction: column; gap: 10px; }
.tcard__name { font-family: var(--ff-display); font-weight: 700; font-size: 16px; color: var(--slate-700); line-height: 1.2; }
.tcard.vacant .tcard__name { color: var(--green-deep); }
.tcard__r { font-size: 12px; color: var(--slate-500); margin-top: 3px; line-height: 1.4; }
.tcard__fph { display: inline-flex; align-items: center; gap: 6px; font-size: 9.5px; letter-spacing: 0.06em; font-family: var(--ff-mono); font-weight: 600; padding: 4px 9px; border-radius: 999px; background: var(--tbg); color: var(--tink); border: 1px solid var(--tring); align-self: flex-start; }
.tcard__schw { padding-top: 10px; border-top: 1px solid var(--slate-100); font-size: 12.5px; line-height: 1.5; color: var(--slate-700); }
.tcard__schw .k { font-family: var(--ff-mono); font-size: 9px; letter-spacing: 0.12em; color: var(--green-deep); text-transform: uppercase; display: block; margin-bottom: 4px; }
.tcard__auf { font-size: 11.5px; line-height: 1.5; color: var(--slate-500); }
.tcard__auf .k { font-family: var(--ff-mono); font-size: 9px; letter-spacing: 0.12em; color: var(--slate-500); text-transform: uppercase; display: block; margin-bottom: 3px; opacity: .85; }
.tcard__frage { font-size: 12px; line-height: 1.5; color: var(--slate-500); font-style: italic; }
.tcard__zitat { margin-top: auto; font-size: 11.5px; line-height: 1.5; color: var(--slate-500); padding-left: 10px; border-left: 2px solid var(--tring); }
.tcard__langs { display: flex; gap: 6px; flex-wrap: wrap; margin-top: auto; padding-top: 6px; }
.tcard__langs span { font-family: var(--ff-mono); font-size: 9.5px; letter-spacing: 0.08em; padding: 3px 7px; border-radius: 999px; background: var(--tbg); color: var(--tink); border: 1px solid var(--tring); }
.team-legend { margin-top: 36px; padding: 22px 26px; background: #fff; border-radius: 8px; border: 1px solid rgba(0,119,42,0.15); display: grid; grid-template-columns: repeat(5,1fr); gap: 18px; }
.team-legend__i { display: flex; align-items: center; gap: 12px; }
.team-legend__badge { width: 40px; height: 40px; border-radius: 50%; background: var(--mint-100); color: var(--green-deep); display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; }
.team-legend__l { font-size: 12.5px; color: var(--slate-700); line-height: 1.4; }
.werte-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 28px; }
.werte-item { padding-left: 24px; border-left: 2px solid var(--green); }
.werte-item h3 { font-family: var(--ff-display); font-weight: 700; font-size: 22px; color: var(--slate-700); margin-bottom: 8px; line-height: 1.25; }
.werte-item p { font-size: 14px; line-height: 1.6; color: var(--slate-500); }
.stelle-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.stelle { background: #fff; border-radius: 8px; padding: 30px 32px; border: 2px solid var(--green); display: flex; flex-direction: column; gap: 16px; }
.stelle__badge { align-self: flex-start; padding: 5px 12px; background: var(--green); color: #fff; font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; font-weight: 700; border-radius: 999px; }
.stelle h3 { font-family: var(--ff-display); font-weight: 700; font-size: 20px; color: var(--slate-700); margin-bottom: 6px; line-height: 1.2; }
.stelle__eyebrow { font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--green-deep); }
.stelle ul { display: flex; flex-direction: column; gap: 6px; }
.stelle li { font-size: 13px; color: var(--slate-500); padding-left: 16px; position: relative; line-height: 1.55; }
.stelle li::before { content: ""; position: absolute; left: 0; top: 8px; width: 8px; height: 2px; background: var(--green); }
.stelle__more { font-size: 12px; color: var(--slate-500); }
.stelle__more a { color: var(--green-deep); text-decoration: underline; }
.stelle__ctas { display: flex; gap: 10px; flex-wrap: wrap; }
.spontan { margin-top: 28px; display: grid; grid-template-columns: 1.4fr 1fr; gap: 48px; align-items: center; }
.spontan h3 { font-family: var(--ff-display); font-weight: 700; font-size: 20px; color: var(--slate-700); margin-bottom: 10px; }
.spontan p { font-size: 14px; line-height: 1.6; margin-bottom: 6px; }
.spontan__cta { display: flex; gap: 12px; justify-content: flex-end; flex-wrap: wrap; }

@media (max-width: 900px) {
  .inh-grid, .spontan { grid-template-columns: 1fr; gap: 28px; }
  .team-grid, .team-legend, .werte-grid, .stelle-grid { grid-template-columns: repeat(2,1fr); }
  .vita__row { grid-template-columns: 120px 1fr; }
  .team-headrow { flex-direction: column; align-items: flex-start; }
  .team-headrow .cnt { text-align: left; }
}
@media (max-width: 560px) {
  .team-grid, .team-legend, .werte-grid, .stelle-grid { grid-template-columns: 1fr; }
}

/* ---------- Aktuelles-Seite ---------- */
.akt-filter { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 40px; align-items: center; border-bottom: 1px solid var(--slate-100); padding-bottom: 28px; }
.akt-filter .lbl { font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--slate-500); margin-right: 4px; }
.akt-chip { display: inline-flex; align-items: center; gap: 8px; padding: 8px 14px; border-radius: 999px; cursor: pointer; font-family: var(--ff-display); font-weight: 500; font-size: 13.5px; border: 1px solid var(--slate-100); background: #fff; color: var(--slate-700); transition: all .15s; }
.akt-chip.is-active { border-color: var(--green); background: var(--mint-50); color: var(--green-deep); }
.akt-chip .dot { width: 7px; height: 7px; border-radius: 999px; display: inline-block; }
.akt-chip .ct { font-family: var(--ff-mono); font-size: 10px; color: var(--slate-500); }
.akt-chip.is-active .ct { color: var(--green); }
.akt-prev-head { display: flex; align-items: baseline; gap: 12px; margin-bottom: 16px; }
.akt-prev-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; }
.akt-prev { border: 1px dashed rgba(0,119,42,0.30); background: var(--mint-50); border-radius: 10px; padding: 18px 18px 20px; }
.akt-prev__top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.akt-prev__cat { display: inline-flex; align-items: center; gap: 6px; font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--slate-500); }
.akt-prev__cat .dot { width: 7px; height: 7px; border-radius: 999px; }
.akt-prev__tag { font-family: var(--ff-mono); font-size: 9px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--amber); border: 1px solid var(--kamille); background: rgba(240,220,110,0.18); border-radius: 999px; padding: 2px 8px; }
.akt-prev h3 { font-family: var(--ff-display); font-weight: 700; font-size: 18px; color: var(--slate-700); margin-bottom: 6px; line-height: 1.2; }
.akt-prev__when { font-family: var(--ff-mono); display: block; font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; font-weight: 400; color: var(--green-deep); margin-bottom: 6px; }
.akt-prev p { font-size: 13px; line-height: 1.5; color: var(--slate-500); }
.akt-list { display: flex; flex-direction: column; gap: 20px; }
.akt-card { background: #fff; border: 1px solid var(--slate-100); border-radius: 10px; overflow: hidden; }
.akt-card__hd { cursor: pointer; display: grid; grid-template-columns: 200px 1fr auto; gap: 28px; align-items: center; padding: 18px; }
.akt-card__img { height: 150px; border-radius: 8px; background: var(--mint-50) center/cover; }
.akt-card__meta { display: flex; align-items: center; gap: 12px; margin-bottom: 10px; }
.akt-card__date { font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--green-deep); }
.akt-card__cat { display: inline-flex; align-items: center; gap: 6px; font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--slate-500); }
.akt-card__cat .dot { width: 7px; height: 7px; border-radius: 999px; }
.akt-card__hd h2 { font-family: var(--ff-display); font-weight: 700; font-size: 26px; line-height: 1.15; color: var(--slate-700); margin-bottom: 8px; }
.akt-card__lead { font-size: 15px; line-height: 1.55; color: var(--slate-500); max-width: 620px; }
.akt-card__toggle { font-family: var(--ff-mono); font-size: 13px; color: var(--green-deep); white-space: nowrap; align-self: start; margin-top: 6px; font-weight: 600; }
.akt-card__body { display: none; padding: 4px 18px 28px; }
.akt-card.is-open .akt-card__body { display: block; }
.akt-card__grid { display: grid; grid-template-columns: 1fr 280px; gap: 36px; }
.akt-card.no-prod .akt-card__grid { grid-template-columns: 1fr; }
.akt-card__text { padding-left: 228px; }
.akt-card__text .inner { border-top: 1px solid var(--slate-100); padding-top: 22px; }
.akt-card__text p { font-size: 16px; line-height: 1.6; color: var(--slate-700); max-width: 640px; margin-top: 14px; }
.akt-card__text p:first-child { margin-top: 0; }
.akt-prod { align-self: start; }
.akt-prod__box { background: var(--mint-50); border-radius: 8px; padding: 20px; display: flex; align-items: center; justify-content: center; height: 200px; }
.akt-prod__box img { max-width: 100%; max-height: 100%; object-fit: contain; }
.akt-prod__name { font-family: var(--ff-mono); font-size: 11px; color: var(--slate-500); text-align: center; margin-top: 10px; letter-spacing: 0.04em; }
.akt-pollen { padding-left: 228px; margin-top: 28px; }
.akt-pollen__box { background: #fff; border: 1px solid var(--slate-100); border-radius: 8px; padding: 26px 28px; }

/* Pollenkalender */
.pollen-wrap { overflow-x: auto; }
.pollen { width: 100%; min-width: 620px; }
.pollen__head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 18px; gap: 16px; }
.pollen__title { font-family: var(--ff-display); font-weight: 700; font-size: 18px; color: var(--slate-700); }
.pollen__legend { display: flex; gap: 18px; font-size: 11px; color: var(--slate-500); }
.pollen__legend span { display: flex; align-items: center; gap: 6px; }
.pollen__legend i { width: 18px; height: 8px; border-radius: 4px; }
.pollen__months { display: grid; grid-template-columns: 110px 1fr; border-bottom: 1px solid var(--slate-100); padding-bottom: 10px; margin-bottom: 6px; }
.pollen__monthcells { display: grid; grid-template-columns: repeat(12,1fr); font-size: 10px; font-family: var(--ff-mono); color: var(--slate-500); letter-spacing: 0.08em; text-transform: uppercase; }
.pollen__monthcells span { text-align: center; }
.pollen__monthcells span.cur { color: var(--green-deep); font-weight: 700; }
.pollen__rows { position: relative; }
.pollen__grid { position: absolute; inset: 0; margin-left: 110px; display: grid; grid-template-columns: repeat(12,1fr); pointer-events: none; }
.pollen__grid > div { border-left: 1px dashed #eef1f3; }
.pollen__grid > div:first-child { border-left: none; }
.pollen__grid > div.cur { background: rgba(232,248,238,0.5); }
.pollen__row { display: grid; grid-template-columns: 110px 1fr; align-items: center; height: 28px; position: relative; }
.pollen__name { font-family: var(--ff-display); font-size: 13px; font-weight: 500; color: var(--slate-700); }
.pollen__track { position: relative; height: 28px; }
.pollen__bar { position: absolute; height: 14px; top: 7px; border-radius: 7px; }
.pollen__note { margin-top: 16px; font-size: 11px; color: var(--slate-500); font-style: italic; line-height: 1.5; }

@media (max-width: 900px) {
  .akt-prev-grid { grid-template-columns: 1fr; }
  .akt-card__hd { grid-template-columns: 1fr; gap: 14px; }
  .akt-card__img { height: 180px; }
  .akt-card__toggle { margin-top: 0; }
  .akt-card__grid { grid-template-columns: 1fr; gap: 20px; }
  .akt-card__text, .akt-pollen { padding-left: 0; }
}

/* ---------- Kontakt-Seite ---------- */
.kmap-wrap { background: #fff; padding: 40px 0 12px; }
.kmap { position: relative; height: 480px; border-radius: var(--r-md); overflow: hidden; border: 1px solid rgba(0,119,42,0.18); background: #E8F2EC; }
.kmap__frame { width: 100%; height: 100%; border: 0; display: block; }
.kmap__card { position: absolute; left: 24px; bottom: 24px; z-index: 2; background: #fff; border-radius: var(--r-md); padding: 20px 24px; box-shadow: 0 14px 34px -16px rgba(0,0,0,.45); max-width: 360px; }
.kmap__card .addr { font-size: 14px; color: var(--slate-700); line-height: 1.5; margin: 8px 0 16px; }
.kmap__ctas { display: flex; gap: 10px; flex-wrap: wrap; }
.kweg__lines { font-family: var(--ff-mono); font-size: 13px; line-height: 1.6; margin-bottom: 10px; }
.ka-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: start; }
.anfahrt { background: #fff; border-radius: 8px; overflow: hidden; border: 1px solid rgba(0,119,42,0.15); }
.anfahrt__sec { padding: 22px 26px; border-top: 1px solid var(--slate-100); }
.anfahrt__sec:first-child { border-top: none; }
.anfahrt__h { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.anfahrt__h h3 { font-family: var(--ff-display); font-weight: 700; font-size: 15px; color: var(--slate-700); }
.anfahrt ul { display: flex; flex-direction: column; gap: 5px; }
.anfahrt li { font-size: 13px; line-height: 1.55; color: var(--slate-500); padding-left: 26px; position: relative; }
.anfahrt li::before { content: ""; position: absolute; left: 14px; top: 8px; width: 6px; height: 2px; background: var(--green); }

@media (max-width: 900px) {
  .kmap { height: 380px; }
  .kmap__card { left: 14px; right: 14px; bottom: 14px; max-width: none; }
  .ka-grid { grid-template-columns: 1fr; gap: 32px; }
}

/* Portal-Rücklink-Streifen */
.portal-strip { background: #006023; color: rgba(255,255,255,.85); font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.06em; text-align: center; padding: 9px 16px; }
.portal-strip a { color: #fff; }

/* Back-to-top */
.totop { position: fixed; right: 18px; bottom: 18px; z-index: 9999; width: 46px; height: 46px; border-radius: 50%; background: var(--green); color: #fff; border: none; cursor: pointer; box-shadow: 0 6px 18px -6px rgba(0,0,0,.35); display: flex; align-items: center; justify-content: center; opacity: 0; visibility: hidden; transform: translateY(8px); transition: opacity .2s, transform .2s, visibility .2s; }
.totop.is-visible { opacity: 1; visibility: visible; transform: translateY(0); }
.totop:hover { background: var(--green-deep); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  /* Nav → Burger (flex-wrap + order, robust) */
  .nav__in { flex-wrap: wrap; }
  .nav__burger { display: flex; order: 2; }
  .nav__logo { order: 1; }
  .nav__links, .nav__cta { display: none; flex-basis: 100%; }
  .nav.is-open .nav__links {
    display: flex; flex-direction: column; align-items: flex-start; gap: 2px;
    order: 3; padding: 10px 0 4px; margin-top: 8px;
    border-top: 1px solid var(--slate-100);
  }
  .nav.is-open .nav__links a { padding: 11px 0; border-bottom: none; font-size: 16px; }
  .nav.is-open .nav__cta { display: flex; order: 4; gap: 10px; padding-bottom: 6px; }
  .nav.is-open .nav__cta .btn { flex: 1; }
}

@media (max-width: 1080px) {
  .quick-grid { grid-template-columns: repeat(3,1fr); }
  .dl-grid { grid-template-columns: repeat(3,1fr); }
  .infostrip { grid-template-columns: repeat(2,1fr); }
}

@media (max-width: 900px) {
  .wrap, .wrap-wide { padding: 0 22px; }
  /* Topbar verschlanken */
  .topbar__brandline, .topbar__right span:first-child, .topbar__dot { display: none; }
  .topbar__in { padding: 8px 22px; }
  .switch__active, .switch__link, .topbar__right .ca-mono { white-space: nowrap; }
  .topbar { font-size: 11px; }

  /* Hero */
  .hero__stage { height: 520px; }
  .hero__veil { background: linear-gradient(180deg, rgba(255,255,255,.55), rgba(255,255,255,.80)); }
  .hero h1 { font-size: clamp(38px, 11vw, 56px); }
  .infostrip { margin-top: -40px; }

  /* Grids → schmaler */
  .news-grid, .about-grid, .oa-grid, .dl-head, .oa-head, .nl-head { grid-template-columns: 1fr; }
  .oa-head { gap: 10px; } .oa-head__note { text-align: left; }
  .sec-head { flex-direction: column; align-items: flex-start; gap: 10px; }
  .sec-head__aside { text-align: left; }
  .news h2 { font-size: 32px; }
  .about h2 { font-size: 30px; }
  .nl { padding: 36px 24px; }
  .nl-themes { grid-template-columns: 1fr; }
  .footer__cols { grid-template-columns: 1fr 1fr; gap: 28px; }
  .footer__trager, .footer__legal { grid-template-columns: 1fr; }
}

@media (max-width: 560px) {
  .quick-grid { grid-template-columns: 1fr; }
  .dl-grid { grid-template-columns: 1fr 1fr; }
  .infostrip { grid-template-columns: 1fr; gap: 20px; }
  .news__imgs { grid-template-columns: 1fr; }
  .news__prod, .news__mood { height: 300px; }
  .footer__cols { grid-template-columns: 1fr; }
  .footer__legal { flex-direction: column; align-items: flex-start; }
  .section, .section--96, .section--88 { padding: 56px 0; }
}
