.elementor-426 .elementor-element.elementor-element-a1051b2{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}/* Start custom CSS for html, class: .elementor-element-bb8828b *//* =================================================================
   TOP-PHYSIO NRW · RECHTSTEXTE CSS  (Impressum · Datenschutz ·
   Widerruf · Cookie-Richtlinie)
   =================================================================
   ELEMENTOR: Site Settings → Custom CSS (an Header/Footer anhängen)
   NUR Aufbau & Design – der Rechtstext selbst bleibt UNVERÄNDERT.
   Nutzt .tpn-container-wide weiter. Markengrün #008c45 · Prefix .tpn-legal-
   ================================================================= */

.tpn-legal { font-family: 'Manrope', -apple-system, system-ui, sans-serif; color: #3b3b3b; background-color: #ffffff; }
.tpn-legal *, .tpn-legal *::before { box-sizing: border-box; }

/* ── KOPF ── */
.tpn-legal-header { background: linear-gradient(180deg, #f3f8f5 0%, #ffffff 100%); padding: 48px 0 28px; }
.tpn-legal-eyebrow {
  font-size: 0.8rem; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase;
  color: #008c45; margin: 0 0 10px;
}
.tpn-legal-title {
  font-family: 'Fraunces', 'Georgia', serif; font-weight: 700;
  font-size: clamp(1.9rem, 4vw, 2.7rem); line-height: 1.15; color: #1f2a24; margin: 0 0 10px;
}
.tpn-legal-meta { font-size: 0.9rem; color: #8a938f; }

/* Doppelten Theme-Seitentitel ausblenden (Royal Elementor Kit:
   <header class="post-header"><h1 class="page-title">…</h1></header>) –
   NUR auf Seiten mit unserem .tpn-legal-Block, damit der gestylte Titel
   stehen bleibt. Die Theme-Option "Titel ausblenden" dann AUS lassen. */
body:has(.tpn-legal) .post-header { display: none !important; }
/* Fallback ohne :has() – Seiten-ID der jeweiligen Rechtsseite ergänzen:
   .page-id-426 .post-header { display: none !important; }  (426 = Cookie-Richtlinie) */

/* ── LAYOUT: Inhaltsverzeichnis + Text ── */
.tpn-legal-layout { display: grid; grid-template-columns: 260px 1fr; gap: 48px; padding: 36px 0 16px; align-items: start; }
.tpn-legal-layout.no-toc { grid-template-columns: 1fr; }
.tpn-legal-layout.no-toc .tpn-legal-body { max-width: 820px; margin: 0; }

.tpn-legal-toc {
  position: sticky; top: 110px; align-self: start;
  background: #f5f7f5; border: 1px solid #e8ece9; border-radius: 14px; padding: 20px;
}
.tpn-legal-toc h4 {
  font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.1em; color: #008c45;
  margin: 0 0 12px; font-weight: 700;
}
.tpn-legal-toc ul { list-style: none; margin: 0; padding: 0; display: grid; gap: 3px; }
.tpn-legal-toc a {
  display: block; padding: 6px 10px; border-left: 2px solid transparent; border-radius: 0 6px 6px 0;
  color: #5b6168; text-decoration: none; font-size: 0.88rem; line-height: 1.4; transition: all 0.2s;
}
.tpn-legal-toc a:hover { color: #008c45; background: #ecf7f0; }
.tpn-legal-toc a.is-active { color: #00733a; font-weight: 700; border-left-color: #008c45; background: #ecf7f0; }

/* ── TEXT-TYPOGRAFIE (gilt für den unveränderten Rechtstext) ── */
.tpn-legal-body { font-size: 1.02rem; line-height: 1.75; color: #2f3733; max-width: 820px; margin-inline: 0; }
.tpn-legal-body h2 {
  font-family: 'Fraunces', 'Georgia', serif; font-weight: 700; font-size: 1.5rem; line-height: 1.3;
  color: #1f2a24; margin: 38px 0 14px; padding-bottom: 8px; border-bottom: 2px solid #e6eee9; scroll-margin-top: 110px;
}
.tpn-legal-body h2:first-child { margin-top: 0; }
.tpn-legal-body h3 { font-size: 1.18rem; font-weight: 700; color: #1f2a24; margin: 26px 0 10px; scroll-margin-top: 110px; }
.tpn-legal-body h4 { font-size: 1.02rem; font-weight: 700; color: #2f3733; margin: 20px 0 8px; }
.tpn-legal-body p { margin: 0 0 15px; }
.tpn-legal-body a { color: #008c45; text-decoration: underline; text-underline-offset: 2px; overflow-wrap: anywhere; }
.tpn-legal-body a:hover { color: #005c2f; }
.tpn-legal-body ul, .tpn-legal-body ol { margin: 0 0 16px; padding-left: 24px; }
.tpn-legal-body li { margin-bottom: 7px; }
.tpn-legal-body ul li::marker { color: #008c45; }
.tpn-legal-body ol li::marker { color: #008c45; font-weight: 700; }
.tpn-legal-body strong, .tpn-legal-body b { color: #1f2a24; }
.tpn-legal-body blockquote {
  margin: 20px 0; padding: 14px 20px; border-left: 4px solid #008c45; background: #f3f8f5; border-radius: 0 10px 10px 0;
}
.tpn-legal-body hr { border: none; border-top: 1px solid #e8ece9; margin: 28px 0; }
.tpn-legal-body address { font-style: normal; }

/* Tabellen (z. B. Cookie-Liste) */
.tpn-legal-body table { width: 100%; border-collapse: collapse; margin: 20px 0; font-size: 0.92rem; display: block; overflow-x: auto; }
.tpn-legal-body th, .tpn-legal-body td { padding: 10px 12px; text-align: left; border: 1px solid #e8ece9; vertical-align: top; }
.tpn-legal-body thead th { background: #008c45; color: #fff; font-weight: 700; }
.tpn-legal-body tbody tr:nth-child(even) { background: #f5f7f5; }

/* ── QUERLINKS RECHTSSEITEN ── */
.tpn-legal-nav { border-top: 1px solid #e8ece9; padding: 28px 0 8px; display: flex; flex-wrap: wrap; gap: 10px; }
.tpn-legal-nav a {
  padding: 9px 16px; border-radius: 999px; border: 1px solid #e0e4e1; background: #fff;
  color: #3b3b3b; font-weight: 600; font-size: 0.88rem; text-decoration: none; transition: all 0.2s;
}
.tpn-legal-nav a:hover { border-color: #008c45; color: #008c45; background: #f3f8f5; }
.tpn-legal-nav a[aria-current="page"] { background: #008c45; border-color: #008c45; color: #fff; }

/* ── RESPONSIVE ── */
@media (max-width: 900px) {
  .tpn-legal-layout { grid-template-columns: 1fr; gap: 20px; }
  .tpn-legal-toc { position: static; top: auto; }
}
@media (max-width: 560px) {
  .tpn-legal-header { padding: 32px 0 20px; }
  .tpn-legal-body table { font-size: 0.86rem; }
}/* End custom CSS */