/*
Theme Name: Hello Elementor Child — Lidel Sanieren
Theme URI: https://lidel-sanieren.de
Description: Child theme for Hello Elementor. Hosts service landing page design system (lidel-svc scope) and any future PHP/theme overrides for lidel-sanieren.de.
Author: Lidel Sanieren
Template: hello-elementor
Version: 1.4.1
Text Domain: hello-elementor-child
*/

/* ============================================================================
   LIDEL SANIEREN — WERKBLATT (Variant B) Production Style
   ============================================================================
   Aesthetic: German engineering brutalism. Werkstatt clarity.
   Typeface system: IBM Plex Mono (display + technical), IBM Plex Sans (body),
   IBM Plex Serif Italic (accent/contrast).
   Palette: ivory paper #F5F2EB, ink #0A0908, safety-orange #FF6B1F, tape #FFD23F.
   Decoration: graph-paper background, hard rules, datasheet tables,
   bordered photo blocks with filing labels, Q.NN FAQ markers.
   ============================================================================
   Scope: body.page-id-1942, body.page-id-1943, body.lidel-svc.
   Auto-applies to all future service pages via lidel-svc body class
   (set in functions.php for slugs starting with badsanierung-, barrierefreiheit-,
   energetische-sanierung-, denkmalsanierung-, smart-home-).
   ============================================================================ */

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

/* ============================================================================
   1. TOKENS
   ============================================================================ */
body.page-id-1942,
body.page-id-1943,
body.lidel-svc {
  --paper: #F5F2EB;
  --paper-soft: #FAF7F0;
  --ink: #0A0908;
  --ink-soft: #1A1816;
  --gray: #6B6862;
  --gray-soft: #9C9892;
  --line: #1A1816;
  --line-soft: rgba(10, 9, 8, 0.12);
  --line-faint: rgba(10, 9, 8, 0.06);
  --orange: #E84A12;
  --safety: #FF6B1F;
  --tape: #FFD23F;
  --void: #0A0908;

  --font-mono:  'IBM Plex Mono', 'SF Mono', Menlo, monospace;
  --font-sans:  'IBM Plex Sans', system-ui, -apple-system, sans-serif;
  --font-serif: 'IBM Plex Serif', Georgia, serif;

  --t-3xs: 0.65rem;
  --t-2xs: 0.7rem;
  --t-xs:  0.78rem;
  --t-sm:  0.88rem;
  --t-base:0.98rem;
  --t-lg:  1.08rem;
  --t-xl:  1.25rem;
  --t-2xl: clamp(1.5rem, 2vw + 1rem, 1.85rem);
  --t-3xl: clamp(1.875rem, 3vw + 1rem, 2.5rem);
  --t-4xl: clamp(2.25rem, 4vw + 1rem, 3.5rem);
  --t-5xl: clamp(2.75rem, 5vw + 1rem, 4.5rem);
  --t-hero: clamp(2.4rem, 6.5vw + 0.5rem, 6.5rem);

  --gutter: clamp(1rem, 3vw, 2.5rem);
  --max:    1320px;
  --content:1080px;
  --prose:  680px;

  --s-xs:  0.5rem;
  --s-sm:  0.75rem;
  --s-md:  1rem;
  --s-lg:  1.5rem;
  --s-xl:  2rem;
  --s-2xl: 3rem;
  --s-3xl: 4rem;
  --s-4xl: 5rem;
  --s-5xl: 7rem;
}

/* ============================================================================
   2. BASE — body, fonts, antialiasing, graph-paper background
   ============================================================================ */
body.page-id-1942,
body.page-id-1943,
body.lidel-svc {
  font-family: var(--font-sans);
  font-weight: 400;
  background: var(--paper) !important;
  color: var(--ink);
  line-height: 1.55;
  letter-spacing: -0.005em;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-feature-settings: "ss01", "tnum";
}

/* Graph paper — fine + coarse grid */
body.page-id-1942::before,
body.page-id-1943::before,
body.lidel-svc::before {
  content: "";
  position: fixed; inset: 0;
  pointer-events: none; z-index: 1;
  opacity: 0.55;
  background-image:
    linear-gradient(rgba(10, 9, 8, 0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(10, 9, 8, 0.04) 1px, transparent 1px),
    linear-gradient(rgba(10, 9, 8, 0.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(10, 9, 8, 0.07) 1px, transparent 1px);
  background-size: 16px 16px, 16px 16px, 80px 80px, 80px 80px;
}

/* ============================================================================
   3. CONTAINER / SCOPE
   ============================================================================ */
body.page-id-1942 .e-con.e-parent,
body.page-id-1943 .e-con.e-parent,
body.lidel-svc .e-con.e-parent {
  position: relative;
  padding-block: var(--s-4xl);
  border-bottom: 2px solid var(--ink);
  background: transparent !important;
}
body.page-id-1942 .e-con.e-parent:last-of-type,
body.page-id-1943 .e-con.e-parent:last-of-type,
body.lidel-svc .e-con.e-parent:last-of-type { border-bottom: 0 }

body.page-id-1942 .e-con-inner,
body.page-id-1943 .e-con-inner,
body.lidel-svc .e-con-inner {
  max-width: var(--max);
  width: 100%;
  margin-inline: auto;
  padding-inline: var(--gutter);
  position: relative; z-index: 2;
}

/* ============================================================================
   4. TYPOGRAPHY — headings (uppercase mono brutalism)
   ============================================================================ */
body.page-id-1942 .elementor-heading-title,
body.page-id-1943 .elementor-heading-title,
body.lidel-svc .elementor-heading-title {
  font-family: var(--font-mono);
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1;
  text-transform: uppercase;
  color: var(--ink);
  text-wrap: balance;
}

/* H1 — hero — bold mono uppercase, dramatic */
body.page-id-1942 h1.elementor-heading-title,
body.page-id-1943 h1.elementor-heading-title,
body.lidel-svc h1.elementor-heading-title {
  font-size: var(--t-hero);
  line-height: 0.96;
  font-weight: 700;
  letter-spacing: -0.04em;
  margin-block: var(--s-xl) var(--s-lg);
  max-width: 18ch;
}

/* Italic accent in H1 (if user wraps part in <em>) */
body.page-id-1942 h1.elementor-heading-title em,
body.page-id-1943 h1.elementor-heading-title em,
body.lidel-svc h1.elementor-heading-title em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 300;
  text-transform: none;
  letter-spacing: -0.02em;
  color: var(--safety);
}

/* H2 — section heading */
body.page-id-1942 h2.elementor-heading-title,
body.page-id-1943 h2.elementor-heading-title,
body.lidel-svc h2.elementor-heading-title {
  font-size: clamp(1.75rem, 3.5vw + 0.5rem, 3rem);
  font-weight: 700;
  line-height: 1;
  letter-spacing: -0.03em;
  margin-bottom: var(--s-xl);
  position: relative;
  padding-top: var(--s-xl);
  max-width: 24ch;
}

body.page-id-1942 h2.elementor-heading-title em,
body.page-id-1943 h2.elementor-heading-title em,
body.lidel-svc h2.elementor-heading-title em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 300;
  text-transform: none;
  letter-spacing: -0.01em;
  color: var(--safety);
}

/* Numbered eyebrow — § NN -style filing label */
body.page-id-1942 .e-con.e-parent,
body.page-id-1943 .e-con.e-parent,
body.lidel-svc .e-con.e-parent {
  counter-increment: section;
}
body.page-id-1942 .e-con.e-parent:nth-of-type(1),
body.page-id-1943 .e-con.e-parent:nth-of-type(1),
body.lidel-svc .e-con.e-parent:nth-of-type(1) {
  counter-reset: section;
  counter-increment: none;
}

body.page-id-1942 .e-con.e-parent:not(:nth-of-type(1)) .elementor-widget-heading:first-of-type h2.elementor-heading-title::before,
body.page-id-1943 .e-con.e-parent:not(:nth-of-type(1)) .elementor-widget-heading:first-of-type h2.elementor-heading-title::before,
body.lidel-svc .e-con.e-parent:not(:nth-of-type(1)) .elementor-widget-heading:first-of-type h2.elementor-heading-title::before {
  content: "§ " counter(section, decimal-leading-zero);
  display: inline-block;
  font-family: var(--font-mono);
  font-size: var(--t-2xs);
  font-weight: 500;
  letter-spacing: 0.18em;
  color: var(--paper);
  background: var(--ink);
  padding: 0.4em 0.8em;
  margin-bottom: var(--s-lg);
  vertical-align: top;
}

body.page-id-1942 .e-con.e-parent.lidel-no-eyebrow .elementor-heading-title::before,
body.page-id-1943 .e-con.e-parent.lidel-no-eyebrow .elementor-heading-title::before,
body.lidel-svc .e-con.e-parent.lidel-no-eyebrow .elementor-heading-title::before {
  display: none;
}

/* H3 + H4 */
body.page-id-1942 h3.elementor-heading-title,
body.page-id-1943 h3.elementor-heading-title,
body.lidel-svc h3.elementor-heading-title {
  font-family: var(--font-sans);
  font-size: var(--t-2xl);
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: -0.012em;
  text-transform: none;
}

/* ============================================================================
   5. TYPOGRAPHY — body / lists / links
   ============================================================================ */
body.page-id-1942 .elementor-widget-text-editor,
body.page-id-1943 .elementor-widget-text-editor,
body.lidel-svc .elementor-widget-text-editor {
  max-width: var(--prose);
}

body.page-id-1942 .elementor-widget-text-editor p,
body.page-id-1943 .elementor-widget-text-editor p,
body.lidel-svc .elementor-widget-text-editor p {
  font-size: var(--t-lg);
  line-height: 1.62;
  color: var(--ink);
  margin-block: 0 var(--s-md);
  text-wrap: pretty;
  font-weight: 400;
}

/* Lead paragraph — first paragraph in hero */
body.page-id-1942 .e-con.e-parent:nth-of-type(1) .elementor-widget-text-editor p,
body.page-id-1943 .e-con.e-parent:nth-of-type(1) .elementor-widget-text-editor p,
body.lidel-svc .e-con.e-parent:nth-of-type(1) .elementor-widget-text-editor p {
  font-size: clamp(1.05rem, 0.5vw + 1rem, 1.25rem);
  line-height: 1.6;
  font-weight: 400;
  max-width: 36ch;
  opacity: 0.86;
}

body.page-id-1942 .elementor-widget-text-editor strong,
body.page-id-1943 .elementor-widget-text-editor strong,
body.lidel-svc .elementor-widget-text-editor strong {
  font-weight: 600;
  color: var(--ink);
}

body.page-id-1942 .elementor-widget-text-editor a,
body.page-id-1943 .elementor-widget-text-editor a,
body.lidel-svc .elementor-widget-text-editor a {
  color: var(--safety);
  text-decoration: underline;
  text-underline-offset: 0.18em;
  text-decoration-thickness: 1px;
  text-decoration-color: var(--orange);
  transition: all 0.2s;
}
body.page-id-1942 .elementor-widget-text-editor a:hover,
body.page-id-1943 .elementor-widget-text-editor a:hover,
body.lidel-svc .elementor-widget-text-editor a:hover {
  color: var(--ink);
  background: var(--tape);
  text-decoration-color: var(--ink);
}

/* Unordered lists — clean spec list */
body.page-id-1942 .elementor-widget-text-editor ul,
body.page-id-1943 .elementor-widget-text-editor ul,
body.lidel-svc .elementor-widget-text-editor ul {
  list-style: none;
  padding: 0;
  margin: var(--s-lg) 0;
  border-top: 1px solid var(--line-soft);
}

body.page-id-1942 .elementor-widget-text-editor ul li,
body.page-id-1943 .elementor-widget-text-editor ul li,
body.lidel-svc .elementor-widget-text-editor ul li {
  position: relative;
  padding: var(--s-sm) 0 var(--s-sm) 2.4rem;
  font-size: var(--t-base);
  line-height: 1.55;
  color: var(--ink);
  border-bottom: 1px solid var(--line-soft);
}

body.page-id-1942 .elementor-widget-text-editor ul li::before,
body.page-id-1943 .elementor-widget-text-editor ul li::before,
body.lidel-svc .elementor-widget-text-editor ul li::before {
  content: "→";
  position: absolute;
  left: 0.6rem;
  top: var(--s-sm);
  color: var(--safety);
  font-family: var(--font-mono);
  font-weight: 600;
}

/* Ordered lists — schedule rows with mono numbers + dotted leader */
body.page-id-1942 .elementor-widget-text-editor ol,
body.page-id-1943 .elementor-widget-text-editor ol,
body.lidel-svc .elementor-widget-text-editor ol {
  list-style: none;
  padding: 0;
  counter-reset: step;
  margin: var(--s-2xl) 0;
  border: 2px solid var(--ink);
  background: var(--paper-soft);
}

body.page-id-1942 .elementor-widget-text-editor ol li,
body.page-id-1943 .elementor-widget-text-editor ol li,
body.lidel-svc .elementor-widget-text-editor ol li {
  position: relative;
  counter-increment: step;
  padding: var(--s-md) var(--s-lg) var(--s-md) 4.5rem;
  font-size: var(--t-base);
  line-height: 1.55;
  border-bottom: 1px solid var(--line-soft);
  transition: background 0.15s;
}

body.page-id-1942 .elementor-widget-text-editor ol li:last-child,
body.page-id-1943 .elementor-widget-text-editor ol li:last-child,
body.lidel-svc .elementor-widget-text-editor ol li:last-child {
  border-bottom: 0;
}

body.page-id-1942 .elementor-widget-text-editor ol li:hover,
body.page-id-1943 .elementor-widget-text-editor ol li:hover,
body.lidel-svc .elementor-widget-text-editor ol li:hover {
  background: rgba(255, 107, 31, 0.06);
}

body.page-id-1942 .elementor-widget-text-editor ol li::before,
body.page-id-1943 .elementor-widget-text-editor ol li::before,
body.lidel-svc .elementor-widget-text-editor ol li::before {
  content: counter(step, decimal-leading-zero);
  position: absolute;
  left: var(--s-lg);
  top: var(--s-md);
  font-family: var(--font-mono);
  font-size: var(--t-sm);
  font-weight: 600;
  color: var(--safety);
  letter-spacing: 0.05em;
}

/* ============================================================================
   6. KOSTENRAHMEN — datasheet table
   ============================================================================ */
body.page-id-1942 .elementor-widget-text-editor table,
body.page-id-1943 .elementor-widget-text-editor table,
body.lidel-svc .elementor-widget-text-editor table {
  width: 100%;
  border-collapse: collapse;
  margin: var(--s-2xl) 0;
  border: 2px solid var(--ink);
  background: var(--paper-soft);
}

body.page-id-1942 .elementor-widget-text-editor table thead,
body.page-id-1943 .elementor-widget-text-editor table thead,
body.lidel-svc .elementor-widget-text-editor table thead {
  background: var(--ink) !important;
  color: var(--paper);
}

body.page-id-1942 .elementor-widget-text-editor table th,
body.page-id-1943 .elementor-widget-text-editor table th,
body.lidel-svc .elementor-widget-text-editor table th {
  font-family: var(--font-mono);
  font-size: var(--t-2xs);
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--paper);
  padding: var(--s-md) var(--s-lg);
  text-align: left;
  background: var(--ink) !important;
}

body.page-id-1942 .elementor-widget-text-editor table td,
body.page-id-1943 .elementor-widget-text-editor table td,
body.lidel-svc .elementor-widget-text-editor table td {
  padding: var(--s-md) var(--s-lg);
  font-family: var(--font-mono);
  font-size: var(--t-sm);
  color: var(--ink);
  border-bottom: 1px solid var(--line-soft) !important;
  border-right: 1px solid var(--line-soft);
}

body.page-id-1942 .elementor-widget-text-editor table td:last-child,
body.page-id-1943 .elementor-widget-text-editor table td:last-child,
body.lidel-svc .elementor-widget-text-editor table td:last-child {
  border-right: 0;
}

body.page-id-1942 .elementor-widget-text-editor table tr:last-child td,
body.page-id-1943 .elementor-widget-text-editor table tr:last-child td,
body.lidel-svc .elementor-widget-text-editor table tr:last-child td {
  border-bottom: 0 !important;
}

body.page-id-1942 .elementor-widget-text-editor table td:first-child,
body.page-id-1943 .elementor-widget-text-editor table td:first-child,
body.lidel-svc .elementor-widget-text-editor table td:first-child {
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: var(--t-base);
  background: rgba(10, 9, 8, 0.03);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

body.page-id-1942 .elementor-widget-text-editor table tbody tr:hover,
body.page-id-1943 .elementor-widget-text-editor table tbody tr:hover,
body.lidel-svc .elementor-widget-text-editor table tbody tr:hover {
  background: rgba(255, 107, 31, 0.06);
}

/* ============================================================================
   7. BUTTONS — flat safety-orange
   ============================================================================ */
body.page-id-1942 .elementor-button,
body.page-id-1943 .elementor-button,
body.lidel-svc .elementor-button {
  font-family: var(--font-mono) !important;
  font-size: var(--t-2xs) !important;
  font-weight: 500 !important;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  background: var(--ink) !important;
  color: var(--paper) !important;
  border: 2px solid var(--ink);
  border-radius: 0 !important;
  padding: 1.1em 1.8em !important;
  position: relative;
  transition: all 0.2s;
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center;
  gap: var(--s-sm);
}

body.page-id-1942 .elementor-button .elementor-button-text::after,
body.page-id-1943 .elementor-button .elementor-button-text::after,
body.lidel-svc .elementor-button .elementor-button-text::after {
  content: " →";
  margin-left: 0.6em;
  transition: transform 0.2s;
  display: inline-block;
}

body.page-id-1942 .elementor-button:hover,
body.page-id-1943 .elementor-button:hover,
body.lidel-svc .elementor-button:hover {
  background: var(--safety) !important;
  border-color: var(--safety);
  color: var(--paper) !important;
}

body.page-id-1942 .elementor-button:hover .elementor-button-text::after,
body.page-id-1943 .elementor-button:hover .elementor-button-text::after,
body.lidel-svc .elementor-button:hover .elementor-button-text::after {
  transform: translateX(4px);
}

/* ============================================================================
   8. FAQ ACCORDION — Q.NN markers + brutal + / − toggle
   ============================================================================ */
body.page-id-1942 .elementor-widget-accordion,
body.page-id-1943 .elementor-widget-accordion,
body.lidel-svc .elementor-widget-accordion {
  max-width: var(--content);
  margin-top: var(--s-xl);
  border-top: 2px solid var(--ink);
}

body.page-id-1942 .elementor-accordion .elementor-accordion-item,
body.page-id-1943 .elementor-accordion .elementor-accordion-item,
body.lidel-svc .elementor-accordion .elementor-accordion-item {
  border: 0 !important;
  border-bottom: 1px solid var(--line-soft) !important;
  background: transparent !important;
  counter-increment: faq;
}

body.page-id-1942 .elementor-accordion .elementor-accordion-item:last-child,
body.page-id-1943 .elementor-accordion .elementor-accordion-item:last-child,
body.lidel-svc .elementor-accordion .elementor-accordion-item:last-child {
  border-bottom: 2px solid var(--ink) !important;
}

body.page-id-1942 .elementor-accordion .elementor-accordion-item:first-child,
body.page-id-1943 .elementor-accordion .elementor-accordion-item:first-child,
body.lidel-svc .elementor-accordion .elementor-accordion-item:first-child {
  counter-reset: faq;
  counter-increment: faq;
}

body.page-id-1942 .elementor-accordion .elementor-tab-title,
body.page-id-1943 .elementor-accordion .elementor-tab-title,
body.lidel-svc .elementor-accordion .elementor-tab-title {
  background: transparent !important;
  border: 0 !important;
  padding: var(--s-lg) var(--s-md) var(--s-lg) 5rem !important;
  font-family: var(--font-sans);
  font-size: var(--t-lg) !important;
  font-weight: 500 !important;
  color: var(--ink) !important;
  letter-spacing: -0.005em;
  line-height: 1.4;
  position: relative;
  cursor: pointer;
  text-align: left !important;
  justify-content: flex-start !important;
  transition: background 0.15s;
}

body.page-id-1942 .elementor-accordion .elementor-tab-title a,
body.page-id-1943 .elementor-accordion .elementor-tab-title a,
body.lidel-svc .elementor-accordion .elementor-tab-title a,
body.page-id-1942 .elementor-accordion .elementor-tab-title span,
body.page-id-1943 .elementor-accordion .elementor-tab-title span,
body.lidel-svc .elementor-accordion .elementor-tab-title span {
  text-align: left !important;
  justify-content: flex-start !important;
  flex: 1 1 auto;
  color: inherit !important;
}

body.page-id-1942 .elementor-accordion .elementor-tab-title::before,
body.page-id-1943 .elementor-accordion .elementor-tab-title::before,
body.lidel-svc .elementor-accordion .elementor-tab-title::before {
  content: "Q." counter(faq, decimal-leading-zero);
  position: absolute;
  left: var(--s-md);
  top: var(--s-lg);
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  font-weight: 600;
  color: var(--safety);
  letter-spacing: 0.05em;
  padding-top: 0.15em;
}

body.page-id-1942 .elementor-accordion .elementor-tab-title:hover,
body.page-id-1943 .elementor-accordion .elementor-tab-title:hover,
body.lidel-svc .elementor-accordion .elementor-tab-title:hover {
  background: rgba(255, 107, 31, 0.04);
}

/* + / − toggle, no SVG */
body.page-id-1942 .elementor-accordion .elementor-tab-title .elementor-accordion-icon,
body.page-id-1943 .elementor-accordion .elementor-tab-title .elementor-accordion-icon,
body.lidel-svc .elementor-accordion .elementor-tab-title .elementor-accordion-icon {
  width: 24px;
  height: 24px;
  margin-left: auto;
  position: relative;
  flex-shrink: 0;
  align-self: center;
}

body.page-id-1942 .elementor-accordion .elementor-tab-title .elementor-accordion-icon i,
body.page-id-1943 .elementor-accordion .elementor-tab-title .elementor-accordion-icon i,
body.lidel-svc .elementor-accordion .elementor-tab-title .elementor-accordion-icon i,
body.page-id-1942 .elementor-accordion .elementor-tab-title .elementor-accordion-icon svg,
body.page-id-1943 .elementor-accordion .elementor-tab-title .elementor-accordion-icon svg,
body.lidel-svc .elementor-accordion .elementor-tab-title .elementor-accordion-icon svg {
  display: none !important;
}

body.page-id-1942 .elementor-accordion .elementor-tab-title .elementor-accordion-icon::before,
body.page-id-1942 .elementor-accordion .elementor-tab-title .elementor-accordion-icon::after,
body.page-id-1943 .elementor-accordion .elementor-tab-title .elementor-accordion-icon::before,
body.page-id-1943 .elementor-accordion .elementor-tab-title .elementor-accordion-icon::after,
body.lidel-svc .elementor-accordion .elementor-tab-title .elementor-accordion-icon::before,
body.lidel-svc .elementor-accordion .elementor-tab-title .elementor-accordion-icon::after {
  content: "" !important;
  position: absolute;
  background: var(--ink);
  transition: transform 0.25s, background 0.25s;
}

body.page-id-1942 .elementor-accordion .elementor-tab-title .elementor-accordion-icon::before,
body.page-id-1943 .elementor-accordion .elementor-tab-title .elementor-accordion-icon::before,
body.lidel-svc .elementor-accordion .elementor-tab-title .elementor-accordion-icon::before {
  top: 50%; left: 0;
  width: 100%; height: 2px;
  transform: translateY(-50%);
}

body.page-id-1942 .elementor-accordion .elementor-tab-title .elementor-accordion-icon::after,
body.page-id-1943 .elementor-accordion .elementor-tab-title .elementor-accordion-icon::after,
body.lidel-svc .elementor-accordion .elementor-tab-title .elementor-accordion-icon::after {
  top: 0; left: 50%;
  width: 2px; height: 100%;
  transform: translateX(-50%);
}

body.page-id-1942 .elementor-accordion .elementor-tab-title.elementor-active .elementor-accordion-icon::after,
body.page-id-1943 .elementor-accordion .elementor-tab-title.elementor-active .elementor-accordion-icon::after,
body.lidel-svc .elementor-accordion .elementor-tab-title.elementor-active .elementor-accordion-icon::after {
  transform: translateX(-50%) rotate(90deg);
  background: var(--safety);
}

body.page-id-1942 .elementor-accordion .elementor-tab-title.elementor-active::before,
body.page-id-1943 .elementor-accordion .elementor-tab-title.elementor-active::before,
body.lidel-svc .elementor-accordion .elementor-tab-title.elementor-active::before {
  color: var(--safety);
}

body.page-id-1942 .elementor-accordion .elementor-tab-title.elementor-active,
body.page-id-1943 .elementor-accordion .elementor-tab-title.elementor-active,
body.lidel-svc .elementor-accordion .elementor-tab-title.elementor-active {
  background: rgba(255, 107, 31, 0.04);
}

body.page-id-1942 .elementor-accordion .elementor-tab-content,
body.page-id-1943 .elementor-accordion .elementor-tab-content,
body.lidel-svc .elementor-accordion .elementor-tab-content {
  background: transparent !important;
  border: 0 !important;
  padding: 0 var(--s-md) var(--s-xl) 5rem !important;
  max-width: var(--prose);
}

body.page-id-1942 .elementor-accordion .elementor-tab-content p,
body.page-id-1943 .elementor-accordion .elementor-tab-content p,
body.lidel-svc .elementor-accordion .elementor-tab-content p {
  font-size: var(--t-base);
  line-height: 1.65;
  color: var(--ink);
  opacity: 0.86;
}

/* ============================================================================
   9. HERO — first section — bordered photo, specs row
   ============================================================================ */
body.page-id-1942 .e-con.e-parent:nth-of-type(1),
body.page-id-1943 .e-con.e-parent:nth-of-type(1),
body.lidel-svc .e-con.e-parent:nth-of-type(1) {
  background: var(--paper) !important;
  padding-block: var(--s-4xl) var(--s-3xl) !important;
}

/* Hero eyebrow — filing badge style */
body.page-id-1942 .e-con.e-parent:nth-of-type(1) .lidel-eyebrow,
body.page-id-1943 .e-con.e-parent:nth-of-type(1) .lidel-eyebrow,
body.lidel-svc .e-con.e-parent:nth-of-type(1) .lidel-eyebrow {
  font-family: var(--font-mono);
  font-size: var(--t-2xs);
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--paper);
  background: var(--safety);
  padding: 0.4em 0.9em;
  display: inline-block;
  margin-bottom: var(--s-xl);
}

body.page-id-1942 .lidel-eyebrow::before,
body.page-id-1943 .lidel-eyebrow::before,
body.lidel-svc .lidel-eyebrow::before {
  display: none;
}

/* Hero stats — bordered specs row */
body.page-id-1942 .lidel-stats,
body.page-id-1943 .lidel-stats,
body.lidel-svc .lidel-stats {
  margin-top: var(--s-2xl);
  border: 2px solid var(--ink);
  display: grid !important;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  padding: 0;
  background: var(--paper-soft);
  border-radius: 0;
}

body.page-id-1942 .lidel-stat,
body.page-id-1943 .lidel-stat,
body.lidel-svc .lidel-stat {
  padding: var(--s-md) var(--s-lg);
  border-right: 1px solid var(--ink);
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

body.page-id-1942 .lidel-stat:last-child,
body.page-id-1943 .lidel-stat:last-child,
body.lidel-svc .lidel-stat:last-child { border-right: 0 }

body.page-id-1942 .lidel-stat span,
body.page-id-1943 .lidel-stat span,
body.lidel-svc .lidel-stat span {
  font-family: var(--font-mono);
  font-size: var(--t-3xs);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gray);
  opacity: 1;
}

body.page-id-1942 .lidel-stat strong,
body.page-id-1943 .lidel-stat strong,
body.lidel-svc .lidel-stat strong {
  font-family: var(--font-mono);
  font-size: var(--t-xl);
  font-weight: 600;
  color: var(--ink);
  letter-spacing: -0.02em;
  font-variation-settings: normal;
}

body.page-id-1942 .lidel-stat:first-child strong,
body.page-id-1943 .lidel-stat:first-child strong,
body.lidel-svc .lidel-stat:first-child strong {
  color: var(--safety);
}

/* ============================================================================
   10. SERVICE-GEBIET — bordered city link grid
   ============================================================================ */
body.page-id-1942 .lidel-service-area ul,
body.page-id-1943 .lidel-service-area ul,
body.lidel-svc .lidel-service-area ul {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 0;
  border: 2px solid var(--ink);
  background: var(--paper-soft);
  margin: var(--s-2xl) 0;
}

body.page-id-1942 .lidel-service-area ul li,
body.page-id-1943 .lidel-service-area ul li,
body.lidel-svc .lidel-service-area ul li {
  border: 0 !important;
  border-bottom: 1px solid var(--line-soft) !important;
  border-right: 1px solid var(--line-soft) !important;
  padding: 0;
  margin: 0;
}

body.page-id-1942 .lidel-service-area ul li::before,
body.page-id-1943 .lidel-service-area ul li::before,
body.lidel-svc .lidel-service-area ul li::before {
  display: none;
}

body.page-id-1942 .lidel-service-area ul li a,
body.page-id-1943 .lidel-service-area ul li a,
body.lidel-svc .lidel-service-area ul li a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--s-lg) var(--s-md);
  font-family: var(--font-mono);
  font-size: var(--t-sm);
  font-weight: 500;
  color: var(--ink) !important;
  text-decoration: none !important;
  background: transparent !important;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  transition: all 0.15s;
}

body.page-id-1942 .lidel-service-area ul li a::after,
body.page-id-1943 .lidel-service-area ul li a::after,
body.lidel-svc .lidel-service-area ul li a::after {
  content: "→";
  font-family: var(--font-mono);
  color: var(--safety);
  font-weight: 600;
  transition: transform 0.2s;
}

body.page-id-1942 .lidel-service-area ul li a:hover,
body.page-id-1943 .lidel-service-area ul li a:hover,
body.lidel-svc .lidel-service-area ul li a:hover {
  background: var(--ink) !important;
  color: var(--paper) !important;
}

body.page-id-1942 .lidel-service-area ul li a:hover::after,
body.page-id-1943 .lidel-service-area ul li a:hover::after,
body.lidel-svc .lidel-service-area ul li a:hover::after {
  transform: translateX(4px);
  color: var(--tape);
}

/* ============================================================================
   11. CTA SECTION — black gridded
   ============================================================================ */
body.page-id-1942 .lidel-cta,
body.page-id-1943 .lidel-cta,
body.lidel-svc .lidel-cta {
  background: var(--ink) !important;
  color: var(--paper);
  padding-block: var(--s-5xl) !important;
  position: relative;
  overflow: hidden;
}

body.page-id-1942 .lidel-cta::before,
body.page-id-1943 .lidel-cta::before,
body.lidel-svc .lidel-cta::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(245, 242, 235, 0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(245, 242, 235, 0.04) 1px, transparent 1px);
  background-size: 80px 80px;
  pointer-events: none;
}

body.page-id-1942 .lidel-cta .e-con-inner,
body.page-id-1943 .lidel-cta .e-con-inner,
body.lidel-svc .lidel-cta .e-con-inner {
  position: relative;
  z-index: 1;
}

body.page-id-1942 .lidel-cta .elementor-heading-title,
body.page-id-1943 .lidel-cta .elementor-heading-title,
body.lidel-svc .lidel-cta .elementor-heading-title {
  color: var(--paper);
  font-family: var(--font-mono);
  font-weight: 700;
  text-transform: uppercase;
  font-size: clamp(2.5rem, 5vw + 0.5rem, 4.5rem);
  letter-spacing: -0.03em;
  line-height: 0.98;
  max-width: 22ch;
}

body.page-id-1942 .lidel-cta .elementor-heading-title em,
body.page-id-1943 .lidel-cta .elementor-heading-title em,
body.lidel-svc .lidel-cta .elementor-heading-title em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 300;
  text-transform: none;
  color: var(--safety);
}

body.page-id-1942 .lidel-cta .elementor-widget-text-editor p,
body.page-id-1943 .lidel-cta .elementor-widget-text-editor p,
body.lidel-svc .lidel-cta .elementor-widget-text-editor p {
  color: var(--paper);
  opacity: 0.86;
  font-size: var(--t-lg);
  font-weight: 400;
  max-width: 40ch;
}

body.page-id-1942 .lidel-cta .elementor-widget-text-editor a,
body.page-id-1943 .lidel-cta .elementor-widget-text-editor a,
body.lidel-svc .lidel-cta .elementor-widget-text-editor a {
  color: var(--safety);
  text-decoration-color: var(--safety);
}

body.page-id-1942 .lidel-cta .elementor-button,
body.page-id-1943 .lidel-cta .elementor-button,
body.lidel-svc .lidel-cta .elementor-button {
  background: var(--safety) !important;
  color: var(--paper) !important;
  border-color: var(--safety);
}

body.page-id-1942 .lidel-cta .elementor-button:hover,
body.page-id-1943 .lidel-cta .elementor-button:hover,
body.lidel-svc .lidel-cta .elementor-button:hover {
  background: var(--paper) !important;
  color: var(--ink) !important;
  border-color: var(--paper);
}

/* ============================================================================
   12. RESPONSIVE
   ============================================================================ */
@media (max-width: 880px) {
  body.page-id-1942 .e-con.e-parent,
  body.page-id-1943 .e-con.e-parent,
  body.lidel-svc .e-con.e-parent {
    padding-block: var(--s-3xl);
  }

  body.page-id-1942 .lidel-stats,
  body.page-id-1943 .lidel-stats,
  body.lidel-svc .lidel-stats {
    grid-template-columns: repeat(2, 1fr);
  }
  body.page-id-1942 .lidel-stat:nth-child(2),
  body.page-id-1943 .lidel-stat:nth-child(2),
  body.lidel-svc .lidel-stat:nth-child(2) { border-right: 0 }
  body.page-id-1942 .lidel-stat:nth-child(-n+2),
  body.page-id-1943 .lidel-stat:nth-child(-n+2),
  body.lidel-svc .lidel-stat:nth-child(-n+2) { border-bottom: 1px solid var(--ink) }

  body.page-id-1942 h1.elementor-heading-title,
  body.page-id-1943 h1.elementor-heading-title,
  body.lidel-svc h1.elementor-heading-title {
    max-width: 100%;
  }

  body.page-id-1942 .elementor-accordion .elementor-tab-title,
  body.page-id-1943 .elementor-accordion .elementor-tab-title,
  body.lidel-svc .elementor-accordion .elementor-tab-title {
    padding: var(--s-md) var(--s-md) var(--s-md) 4rem !important;
    font-size: var(--t-base) !important;
  }

  body.page-id-1942 .elementor-widget-text-editor table,
  body.page-id-1943 .elementor-widget-text-editor table,
  body.lidel-svc .elementor-widget-text-editor table {
    display: block;
    overflow-x: auto;
    white-space: nowrap;
  }
}

/* ============================================================================
   13. PRINT
   ============================================================================ */
@media print {
  body.page-id-1942::before,
  body.page-id-1943::before,
  body.lidel-svc::before {
    display: none;
  }
  body.page-id-1942 .lidel-cta,
  body.page-id-1943 .lidel-cta,
  body.lidel-svc .lidel-cta {
    background: var(--paper) !important;
    color: var(--ink);
  }
  body.page-id-1942 .lidel-cta::before,
  body.page-id-1943 .lidel-cta::before,
  body.lidel-svc .lidel-cta::before {
    display: none;
  }
}
/* ============================================================================
   WERKBLATT TEMPLATE — Lidel Sanieren Variant B
   ============================================================================
   Scope: body.werkblatt-page (set in template-werkblatt.php).
   Replaces all Elementor-driven styling for service landing pages.
   ============================================================================ */

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

body.werkblatt-page {
  --paper: #F5F2EB;
  --paper-soft: #FAF7F0;
  --ink: #0A0908;
  --line: #1A1816;
  --line-soft: rgba(10, 9, 8, 0.12);
  --gray: #6B6862;
  --orange: #E84A12;
  --safety: #FF6B1F;
  --tape: #FFD23F;

  margin: 0;
  font-family: 'IBM Plex Sans', system-ui, sans-serif;
  font-weight: 400;
  background: var(--paper);
  color: var(--ink);
  line-height: 1.55;
  letter-spacing: -0.005em;
  -webkit-font-smoothing: antialiased;
  font-feature-settings: "ss01", "tnum";
  position: relative;
  overflow-x: hidden;
}

/* Graph paper directly on body so no widget can cover it */
body.werkblatt-page {
  background-color: var(--paper);
  background-image:
    linear-gradient(rgba(10, 9, 8, 0.09) 1px, transparent 1px),
    linear-gradient(90deg, rgba(10, 9, 8, 0.09) 1px, transparent 1px),
    linear-gradient(rgba(10, 9, 8, 0.18) 1px, transparent 1px),
    linear-gradient(90deg, rgba(10, 9, 8, 0.18) 1px, transparent 1px);
  background-size: 16px 16px, 16px 16px, 80px 80px, 80px 80px;
  background-attachment: fixed;
  background-position: 0 0;
}
/* Make widget sections transparent so grid shows through */
body.werkblatt-page main.werkblatt-main,
body.werkblatt-page .werkblatt-section,
body.werkblatt-page .werkblatt-hero {
  background: transparent !important;
}

body.werkblatt-page * { box-sizing: border-box }
body.werkblatt-page a { color: inherit; transition: all 0.15s }
body.werkblatt-page img { max-width: 100%; height: auto; display: block }

.werkblatt-container {
  max-width: 1320px;
  margin-inline: auto;
  padding-inline: clamp(1rem, 3vw, 2.5rem);
  position: relative; z-index: 1;
}

/* ============================================================================
   TOPBAR
   ============================================================================ */
.werkblatt-topbar {
  background: var(--ink); color: var(--paper);
  padding: 0.75rem 0;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase;
  position: relative; z-index: 5;
}
.werkblatt-topbar .topbar-row {
  display: flex; justify-content: space-between; align-items: center; gap: 2rem;
}
.werkblatt-topbar .id { color: var(--safety); font-weight: 600 }
.werkblatt-topbar .meta { display: flex; gap: 2rem; opacity: 0.78 }

/* ============================================================================
   HEADER
   ============================================================================ */
.werkblatt-header {
  padding: 1.25rem 0;
  border-bottom: 2px solid var(--ink);
  position: sticky; top: 0;
  background: var(--paper);
  z-index: 50;
}
.werkblatt-header .header-row {
  display: flex; align-items: center; justify-content: space-between; gap: 2rem;
}
.werkblatt-header .brand {
  display: flex; align-items: baseline; gap: 1rem;
}
.werkblatt-header .logo {
  font-family: 'IBM Plex Mono', monospace;
  font-weight: 700; font-size: 1.4rem;
  letter-spacing: -0.03em;
  text-transform: uppercase;
  text-decoration: none;
  color: var(--ink);
}
.werkblatt-header .sub {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.7rem; opacity: 0.62;
  letter-spacing: 0.1em; text-transform: uppercase;
  padding-left: 1rem; border-left: 1px solid var(--line-soft);
}
.werkblatt-header nav { display: flex; gap: 2rem }
.werkblatt-header nav a {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.75rem; letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink); text-decoration: none;
  padding: 0.5em 0; border-bottom: 1px solid transparent;
}
.werkblatt-header nav a:hover { border-color: var(--safety) }
.werkblatt-header .cta {
  background: var(--safety); color: var(--paper);
  padding: 0.7em 1.4em;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.75rem; letter-spacing: 0.1em; text-transform: uppercase;
  font-weight: 500; text-decoration: none;
  display: inline-flex; align-items: center; gap: 0.4em;
}
.werkblatt-header .cta:hover { background: var(--ink) }

/* ============================================================================
   HERO
   ============================================================================ */
.werkblatt-hero {
  padding: 4rem 0;
  border-bottom: 2px solid var(--ink);
  position: relative;
}
.werkblatt-hero .filing {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.7rem; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--gray);
  margin-bottom: 1.5rem;
  display: flex; align-items: center; gap: 0.75rem; flex-wrap: wrap;
}
.werkblatt-hero .filing .badge {
  display: inline-block;
  background: var(--ink); color: var(--paper);
  padding: 0.3em 0.8em; font-weight: 500;
}
.werkblatt-hero .filing .badge.orange { background: var(--safety) }
.werkblatt-hero .filing .meta-text { opacity: 0.62 }

.werkblatt-hero .hero-grid {
  display: grid; grid-template-columns: 8fr 4fr;
  gap: 3rem; align-items: end;
}
.werkblatt-hero h1 {
  font-family: 'IBM Plex Mono', monospace;
  font-weight: 700;
  font-size: clamp(2.2rem, 6vw + 0.5rem, 6rem);
  line-height: 0.96; letter-spacing: -0.04em;
  text-transform: uppercase;
  margin: 0 0 1.5rem;
  text-wrap: balance;
}
.werkblatt-hero h1 .ital,
.werkblatt-hero h1 em {
  font-family: 'IBM Plex Serif', serif;
  font-style: italic; font-weight: 300;
  text-transform: none;
  letter-spacing: -0.02em;
  color: var(--safety);
  display: block;
  margin-top: 0.2em;
}
.werkblatt-hero .lead-text {
  font-size: 1.05rem; line-height: 1.6;
  max-width: 32ch; opacity: 0.86;
  margin-bottom: 1.5rem;
}
.werkblatt-hero .lead-text p { margin: 0 0 0.75em }
.werkblatt-hero .lead-text p:last-child { margin-bottom: 0 }

.werkblatt-hero .hero-cta-row {
  display: flex; gap: 0.75rem; flex-wrap: wrap;
  margin-top: 1.5rem;
}

.werkblatt-hero .img-block {
  border: 2px solid var(--ink);
  background: var(--paper);
  padding: 0.75rem;
  position: relative;
}
.werkblatt-hero .img-block::before {
  content: attr(data-label);
  position: absolute; top: -0.65rem; left: 1rem;
  background: var(--paper); padding: 0 0.5rem;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.65rem; letter-spacing: 0.18em;
  text-transform: uppercase;
}
.werkblatt-hero .img-block::after {
  content: "1:1 SCALE";
  position: absolute; bottom: -0.65rem; right: 1rem;
  background: var(--paper); padding: 0 0.5rem;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.6rem; letter-spacing: 0.18em;
  color: var(--gray);
}
.werkblatt-hero .img-block img {
  width: 100%; aspect-ratio: 4/5;
  object-fit: cover; display: block;
  filter: contrast(1.05) saturate(0.92);
}

/* SPECS row */
.werkblatt-hero .specs {
  display: grid; grid-template-columns: repeat(4, 1fr);
  border: 2px solid var(--ink);
  margin-top: 3rem;
  background: var(--paper-soft);
}
.werkblatt-hero .specs > div {
  padding: 1.25rem 1.5rem;
  border-right: 1px solid var(--ink);
}
.werkblatt-hero .specs > div:last-child { border-right: 0 }
.werkblatt-hero .specs .key {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.65rem; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--gray);
  margin-bottom: 0.5rem;
}
.werkblatt-hero .specs .val {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 1.4rem; font-weight: 600;
  letter-spacing: -0.02em;
}
.werkblatt-hero .specs .val.orange { color: var(--safety) }

/* ============================================================================
   BUTTONS
   ============================================================================ */
.werkblatt-page .btn {
  display: inline-flex; align-items: center; gap: 0.6em;
  padding: 1.1em 1.8em;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.75rem; font-weight: 500;
  letter-spacing: 0.12em; text-transform: uppercase;
  text-decoration: none;
  border: 2px solid var(--ink);
  background: var(--ink); color: var(--paper);
  transition: all 0.2s;
}
.werkblatt-page .btn:hover {
  background: var(--safety);
  border-color: var(--safety);
}
.werkblatt-page .btn.btn-ghost {
  background: transparent; color: var(--ink);
}
.werkblatt-page .btn.btn-ghost:hover {
  background: var(--ink); color: var(--paper);
}
.werkblatt-page .btn span { transition: transform 0.2s }
.werkblatt-page .btn:hover span { transform: translateX(3px) }

/* ============================================================================
   SECTIONS
   ============================================================================ */
.werkblatt-section {
  padding: 5rem 0;
  border-bottom: 2px solid var(--ink);
}

.werkblatt-section .section-head {
  display: grid; grid-template-columns: auto 1fr auto;
  gap: 2rem; align-items: baseline;
  margin-bottom: 3rem;
}
.werkblatt-section .section-num {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.75rem; letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 0.4em 0.9em;
  background: var(--ink); color: var(--paper);
  align-self: start; justify-self: start;
}
.werkblatt-section h2 {
  font-family: 'IBM Plex Mono', monospace;
  font-weight: 700;
  font-size: clamp(1.75rem, 3.5vw + 0.5rem, 3rem);
  line-height: 1; letter-spacing: -0.03em;
  text-transform: uppercase;
  margin: 0;
}
.werkblatt-section h2 .ital,
.werkblatt-section h2 em {
  font-family: 'IBM Plex Serif', serif;
  font-style: italic; font-weight: 300;
  text-transform: none;
  letter-spacing: -0.01em;
  color: var(--safety);
}
.werkblatt-section .dim {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.7rem; color: var(--gray);
  text-align: right; letter-spacing: 0.05em;
  text-transform: uppercase;
}

/* PROSE */
.werkblatt-section .prose {
  max-width: 760px;
  font-size: 1.05rem; line-height: 1.62;
}
.werkblatt-section .prose p { margin-block: 0 1rem }
.werkblatt-section .prose strong { font-weight: 600 }
.werkblatt-section .prose a {
  color: var(--safety); text-decoration: underline;
  text-underline-offset: 0.18em; text-decoration-thickness: 1px;
}
.werkblatt-section .prose a:hover { background: var(--tape); color: var(--ink) }

.werkblatt-section .prose ul,
.werkblatt-section .prose ol {
  list-style: none; padding: 0;
  margin: 1.5rem 0;
  border-top: 1px solid var(--line-soft);
}
.werkblatt-section .prose ul li,
.werkblatt-section .prose ol li {
  position: relative;
  padding: 0.75rem 0 0.75rem 2.4rem;
  border-bottom: 1px solid var(--line-soft);
  font-size: 1rem; line-height: 1.55;
}
.werkblatt-section .prose ul li::before {
  content: "→";
  position: absolute; left: 0.6rem; top: 0.75rem;
  color: var(--safety);
  font-family: 'IBM Plex Mono', monospace;
  font-weight: 600;
}
.werkblatt-section .prose ol { counter-reset: step }
.werkblatt-section .prose ol li {
  counter-increment: step;
  padding-left: 3.5rem;
}
.werkblatt-section .prose ol li::before {
  content: counter(step, decimal-leading-zero);
  position: absolute; left: 0; top: 0.75rem;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.85rem; font-weight: 600;
  color: var(--safety); letter-spacing: 0.05em;
}

/* ============================================================================
   SCHEDULE
   ============================================================================ */
.schedule {
  border: 2px solid var(--ink);
  background: var(--paper-soft);
}
.schedule-head {
  background: var(--ink); color: var(--paper);
  display: grid; grid-template-columns: 80px 1fr 2fr 120px;
  padding: 0.75rem 1.5rem;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.65rem; letter-spacing: 0.18em;
  text-transform: uppercase;
  gap: 1.5rem;
}
.schedule-row {
  display: grid; grid-template-columns: 80px 1fr 2fr 120px;
  padding: 1.25rem 1.5rem;
  border-bottom: 1px solid var(--line-soft);
  align-items: baseline; gap: 1.5rem;
  transition: background 0.15s;
}
.schedule-row:last-child { border-bottom: 0 }
.schedule-row:hover { background: rgba(232, 74, 18, 0.06) }
.schedule .num {
  font-family: 'IBM Plex Mono', monospace;
  font-weight: 600; color: var(--safety);
  font-size: 0.85rem; letter-spacing: 0.05em;
}
.schedule .title {
  font-family: 'IBM Plex Sans', sans-serif;
  font-weight: 600; font-size: 1.05rem;
}
.schedule .desc {
  font-size: 0.92rem; line-height: 1.55; opacity: 0.84;
}
.schedule .duration {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.75rem; text-align: right;
  letter-spacing: 0.05em; color: var(--gray);
}

/* ============================================================================
   ANNOTATION
   ============================================================================ */
.annotation {
  position: relative;
  border: 2px solid var(--ink);
  background: var(--paper);
  padding: 0.75rem;
  margin: 1rem 0 2.5rem;
}
.annotation img {
  width: 100%; height: 50vh; min-height: 380px;
  object-fit: cover; display: block;
  filter: contrast(1.05) saturate(0.92);
}
.annotation .marker {
  position: absolute;
  background: var(--safety); color: var(--paper);
  padding: 0.4em 0.8em;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.65rem; letter-spacing: 0.18em;
  text-transform: uppercase; font-weight: 600;
}
.annotation .marker.tl { top: 1.5rem; left: 1.5rem }
.annotation .marker.br { bottom: 1.5rem; right: 1.5rem; background: var(--ink) }
.annotation .dim-line {
  position: absolute; bottom: -2rem; left: 0; right: 0;
  display: flex; justify-content: space-between;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.65rem; color: var(--gray);
  letter-spacing: 0.18em; text-transform: uppercase;
}

/* ============================================================================
   DATASHEET
   ============================================================================ */
.datasheet { border: 2px solid var(--ink); overflow-x: auto }
.datasheet table { width: 100%; border-collapse: collapse }
.datasheet thead { background: var(--ink); color: var(--paper) }
.datasheet th {
  padding: 1rem 1.5rem;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.7rem; letter-spacing: 0.18em;
  text-transform: uppercase; text-align: left;
  font-weight: 500;
}
.datasheet td {
  padding: 1.25rem 1.5rem;
  border-bottom: 1px solid var(--line-soft);
  border-right: 1px solid var(--line-soft);
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.9rem;
}
.datasheet tr:last-child td { border-bottom: 0 }
.datasheet td:last-child { border-right: 0 }
.datasheet td.label {
  font-family: 'IBM Plex Sans', sans-serif;
  font-weight: 600; font-size: 1rem;
  background: rgba(10, 9, 8, 0.03);
  text-transform: uppercase; letter-spacing: 0.05em;
}
.datasheet td.amount {
  color: var(--safety); font-weight: 600; font-size: 1.05rem;
}

/* ============================================================================
   FAQ
   ============================================================================ */
.faq {
  border-top: 2px solid var(--ink);
  border-bottom: 2px solid var(--ink);
  counter-reset: faq;
}
.faq details {
  border-bottom: 1px solid var(--line-soft);
  counter-increment: faq;
  position: relative;
}
.faq details:last-child { border-bottom: 0 }
.faq summary {
  list-style: none;
  cursor: pointer;
  padding: 1.5rem 3rem 1.5rem 5rem;
  font-family: 'IBM Plex Sans', sans-serif;
  font-weight: 500; font-size: 1.05rem;
  position: relative;
  transition: background 0.15s;
}
.faq summary::-webkit-details-marker { display: none }
.faq summary::before {
  content: "Q." counter(faq, decimal-leading-zero);
  position: absolute; left: 1.5rem; top: 1.5rem;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.75rem; font-weight: 600;
  color: var(--safety); letter-spacing: 0.05em;
}
.faq summary::after {
  content: "+";
  position: absolute; right: 1.5rem; top: 1.4rem;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 1.4rem; font-weight: 400;
  transition: transform 0.25s;
}
.faq details[open] summary::after { content: "−"; color: var(--safety) }
.faq summary:hover { background: rgba(232, 74, 18, 0.04) }
.faq details[open] summary { background: rgba(232, 74, 18, 0.04) }
.faq .answer {
  padding: 0 1.5rem 1.75rem 5rem;
  font-size: 0.95rem; line-height: 1.62;
  max-width: 65ch; opacity: 0.86;
}
.faq .answer p { margin: 0 0 0.75em }

/* ============================================================================
   SERVICE AREA
   ============================================================================ */
.werkblatt-service-area .city-grid {
  list-style: none; padding: 0; margin: 0;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  border: 2px solid var(--ink);
  background: var(--paper-soft);
}
.werkblatt-service-area .city-grid li {
  border-right: 1px solid var(--line-soft);
  border-bottom: 1px solid var(--line-soft);
}
.werkblatt-service-area .city-grid a {
  display: flex; align-items: center; justify-content: space-between;
  padding: 1.25rem 1.25rem;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.85rem; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.05em;
  color: var(--ink); text-decoration: none;
  transition: all 0.15s;
}
.werkblatt-service-area .city-grid a span {
  color: var(--safety); font-weight: 600;
}
.werkblatt-service-area .city-grid a:hover {
  background: var(--ink); color: var(--paper);
}
.werkblatt-service-area .city-grid a:hover span {
  color: var(--tape); transform: translateX(3px); display: inline-block;
}

/* ============================================================================
   CTA SECTION
   ============================================================================ */
.werkblatt-cta {
  background: var(--ink); color: var(--paper);
  padding: 6rem 0; position: relative;
}
.werkblatt-cta::before {
  content: ""; position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(245, 242, 235, 0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(245, 242, 235, 0.04) 1px, transparent 1px);
  background-size: 80px 80px;
  pointer-events: none;
}
.werkblatt-cta .cta-grid {
  display: grid; grid-template-columns: 2fr 1fr;
  gap: 4rem; align-items: end;
  position: relative; z-index: 1;
}
.werkblatt-cta h2,
.werkblatt-cta h2.cta-title,
body.werkblatt-page .werkblatt-cta h2 {
  font-family: 'IBM Plex Mono', monospace;
  font-weight: 700;
  font-size: clamp(2.2rem, 5vw + 0.5rem, 4.5rem);
  text-transform: uppercase;
  line-height: 0.98; letter-spacing: -0.03em;
  text-wrap: balance;
  margin: 0;
  color: #F5F2EB !important;
}
.werkblatt-cta h2.cta-title .ital,
body.werkblatt-page .werkblatt-cta h2 .ital {
  color: #FF6B1F !important;
}
.werkblatt-cta h2 .ital {
  font-family: 'IBM Plex Serif', serif;
  font-style: italic; font-weight: 300;
  text-transform: none; color: var(--safety);
}
.werkblatt-cta .cta-lead {
  margin-top: 1.5rem; font-size: 1.05rem; line-height: 1.6;
  opacity: 0.86; max-width: 50ch;
}
.werkblatt-cta .cta-lead p { margin: 0 0 0.75em }
.werkblatt-cta .cta-actions {
  display: flex; flex-direction: column; gap: 0.5rem;
}
.werkblatt-cta .cta-actions a {
  display: flex; justify-content: space-between; align-items: center;
  padding: 1.25rem 1.5rem;
  background: transparent;
  border: 1px solid rgba(245, 242, 235, 0.3);
  color: var(--paper); text-decoration: none;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.8rem; letter-spacing: 0.12em; text-transform: uppercase;
  transition: all 0.2s;
}
.werkblatt-cta .cta-actions a:hover,
.werkblatt-cta .cta-actions a.primary {
  background: var(--safety); border-color: var(--safety);
}

/* ============================================================================
   FOOTER
   ============================================================================ */
.werkblatt-footer {
  padding: 1.5rem 0;
  border-top: 2px solid var(--ink);
  background: var(--paper);
}
.werkblatt-footer .footer-row {
  display: flex; justify-content: space-between;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.7rem; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--gray);
}
.werkblatt-footer a {
  color: var(--gray); text-decoration: none;
  margin: 0 0.4em;
}
.werkblatt-footer a:hover { color: var(--safety) }

/* ============================================================================
   STICKY CTA (floating)
   ============================================================================ */
.werkblatt-sticky {
  position: fixed; bottom: 1.25rem; right: 1.25rem;
  z-index: 999;
  display: flex; gap: 0;
  box-shadow: 0 12px 28px rgba(10, 9, 8, 0.18);
  border: 2px solid var(--ink);
  background: var(--paper);
}
.werkblatt-sticky .sticky-call {
  display: flex; flex-direction: column;
  padding: 0.65rem 0.9rem;
  text-decoration: none; color: var(--ink);
  border-right: 1px solid var(--ink);
  transition: background 0.15s;
}
.werkblatt-sticky .sticky-call:hover { background: rgba(255, 107, 31, 0.08) }
.werkblatt-sticky .sticky-eyebrow {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.6rem; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--gray);
}
.werkblatt-sticky .sticky-num {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.85rem; font-weight: 600;
  margin-top: 0.15rem;
}
.werkblatt-sticky .sticky-btn {
  display: inline-flex; align-items: center; gap: 0.5rem;
  background: var(--safety); color: var(--paper);
  padding: 0.65rem 1.1rem; text-decoration: none;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.7rem; font-weight: 600;
  letter-spacing: 0.15em; text-transform: uppercase;
  transition: background 0.2s;
}
.werkblatt-sticky .sticky-btn:hover { background: var(--ink) }
.werkblatt-sticky .sticky-btn span { transition: transform 0.2s }
.werkblatt-sticky .sticky-btn:hover span { transform: translateX(3px) }
.werkblatt-sticky {
  transition: transform 0.25s ease, opacity 0.25s ease;
}
.werkblatt-sticky.is-hidden {
  transform: translateY(140%);
  opacity: 0;
  pointer-events: none;
}

/* ============================================================================
   REFERENCES (lidel-werkblatt-references)
   ============================================================================ */
.references {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px;
  background: var(--ink); border: 1px solid var(--ink);
  margin-top: 2rem;
}
.ref-card {
  background: var(--paper); padding: 1.4rem 1.3rem;
  display: flex; flex-direction: column; gap: 0.5rem;
}
.ref-head {
  display: flex; justify-content: space-between; align-items: baseline;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.7rem; letter-spacing: 0.16em; text-transform: uppercase;
}
.ref-head .ref-idx { color: var(--safety); font-weight: 700 }
.ref-head .ref-jahr { color: var(--gray) }
.ref-stadtteil {
  font-family: 'IBM Plex Mono', monospace;
  font-weight: 700; font-size: 1.4rem; letter-spacing: -0.02em;
  text-transform: uppercase; margin: 0.3rem 0 0;
  color: var(--ink);
}
.ref-typ {
  font-family: 'IBM Plex Serif', serif; font-style: italic;
  font-size: 0.95rem; color: var(--ink); opacity: 0.75;
}
.ref-data {
  display: grid; grid-template-columns: auto 1fr; gap: 0.3rem 1rem;
  margin: 0.6rem 0 0;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.78rem; letter-spacing: 0.05em; text-transform: uppercase;
}
.ref-data dt { color: var(--gray); margin: 0 }
.ref-data dd { color: var(--ink); margin: 0; font-weight: 600 }
.ref-data dd.amount { color: var(--safety) }
.ref-note {
  font-family: 'IBM Plex Sans', sans-serif;
  font-size: 0.85rem; line-height: 1.5; color: var(--ink);
  border-top: 1px solid var(--line); padding-top: 0.8rem;
  margin: 0.8rem 0 0; opacity: 0.85;
}

/* ============================================================================
   DATASHEET .ds-note (city-specific subtitle under linie cell)
   ============================================================================ */
.datasheet td.label .ds-note {
  font-family: 'IBM Plex Sans', sans-serif;
  font-weight: 400;
  font-size: 0.7rem;
  letter-spacing: 0.02em;
  text-transform: none;
  color: var(--gray);
  margin-top: 0.25rem;
  line-height: 1.35;
}

/* ============================================================================
   FÖRDER-TABELLE (inline in prose §03)
   ============================================================================ */
.foerder-table {
  margin-top: 1.5rem;
  border: 1px solid var(--ink);
  border-collapse: collapse;
  width: 100%;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.78rem; letter-spacing: 0.04em;
}
.foerder-table caption {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.7rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--gray); text-align: left; padding: 0 0 0.6rem;
}
.foerder-table th, .foerder-table td {
  padding: 0.7rem 0.9rem;
  border-bottom: 1px solid var(--line);
  vertical-align: top;
}
.foerder-table thead th {
  background: var(--ink); color: var(--paper);
  text-transform: uppercase; font-size: 0.7rem;
  letter-spacing: 0.12em; text-align: left;
}
.foerder-table tbody td.amount { color: var(--safety); font-weight: 700; white-space: nowrap }

/* ============================================================================
   CROSS-TOPIC LINKS (inline in prose)
   ============================================================================ */
.cross-topic {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 0;
  margin-top: 1.5rem;
  border: 1px solid var(--ink);
}
.cross-topic a {
  display: flex; justify-content: space-between; align-items: center;
  padding: 1rem 1.2rem;
  border-right: 1px solid var(--ink); border-bottom: 1px solid var(--ink);
  text-decoration: none; color: var(--ink);
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.82rem; letter-spacing: 0.05em;
  text-transform: uppercase;
  transition: background 0.15s, color 0.15s;
}
.cross-topic a:hover { background: var(--ink); color: var(--paper) }
.cross-topic a:hover .arrow { color: var(--safety) }
.cross-topic a:nth-child(2n) { border-right: 0 }
.cross-topic a:nth-last-child(-n+2) { border-bottom: 0 }
.cross-topic .arrow { color: var(--safety) }

/* ============================================================================
   BAUEPOCHEN-STATS (inline in prose)
   ============================================================================ */
.bauepochen {
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 1px;
  margin-top: 1.5rem;
  background: var(--ink); border: 1px solid var(--ink);
}
.bauepochen-cell {
  background: var(--paper); padding: 1.1rem 0.9rem;
  display: flex; flex-direction: column; gap: 0.3rem;
  font-family: 'IBM Plex Mono', monospace;
}
.bauepochen-cell .epoche {
  font-size: 0.7rem; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--gray); font-weight: 600;
}
.bauepochen-cell .count {
  font-size: 1.6rem; font-weight: 700; color: var(--ink); line-height: 1;
  letter-spacing: -0.02em;
}
.bauepochen-cell .desc {
  font-family: 'IBM Plex Sans', sans-serif;
  font-size: 0.72rem; color: var(--gray); line-height: 1.3;
}

/* ============================================================================
   RESPONSIVE
   ============================================================================ */
/* Reset Elementor container padding inside werkblatt-page so widget sections control spacing */
body.werkblatt-page .elementor-section-wrap > .elementor-section,
body.werkblatt-page .e-con.e-parent,
body.werkblatt-page .e-con-inner {
  padding: 0 !important;
  margin: 0 !important;
}
body.werkblatt-page main.werkblatt-main { padding: 0 }

@media (max-width: 880px) {
  .werkblatt-header { padding: 0.75rem 0 }
  .werkblatt-header .header-row { gap: 1rem }
  .werkblatt-header .brand { flex: 0 1 auto; min-width: 0 }
  .werkblatt-header .logo { font-size: 1.15rem; white-space: nowrap }
  .werkblatt-header .sub { display: none }
  .werkblatt-header .cta { padding: 0.55em 0.9em; font-size: 0.65rem; flex-shrink: 0 }
  .werkblatt-header .cta .phone { display: none }
  .werkblatt-hero { padding: 1.25rem 0 2rem }
  .werkblatt-hero .filing { margin-bottom: 0.75rem; gap: 0.4rem }
  .werkblatt-hero .filing .badge { font-size: 0.6rem; padding: 0.25em 0.6em }
  .werkblatt-hero h1 { margin-bottom: 0.75rem }
  .werkblatt-section { padding: 2.5rem 0 }
  .werkblatt-hero .hero-grid { grid-template-columns: 1fr; gap: 1.25rem }
  .werkblatt-section .section-head { grid-template-columns: 1fr; gap: 1rem }
  .werkblatt-section .section-head .dim { text-align: left }
  .werkblatt-hero .specs { grid-template-columns: repeat(2, 1fr) }
  .werkblatt-hero .specs > div:nth-child(2) { border-right: 0 }
  .werkblatt-hero .specs > div:nth-child(-n+2) { border-bottom: 1px solid var(--ink) }
  .schedule-head, .schedule-row { grid-template-columns: 60px 1fr; gap: 1rem }
  .schedule-row .desc, .schedule-row .duration,
  .schedule-head > *:nth-child(n+3) { display: none }
  .werkblatt-cta .cta-grid { grid-template-columns: 1fr; gap: 2rem }
  .werkblatt-header nav { display: none }
  .werkblatt-header .sub { display: none }
  .werkblatt-footer .footer-row { flex-direction: column; gap: 0.5rem; align-items: center }
  .werkblatt-sticky { bottom: 0; right: 0; left: 0; border-right: 0; border-left: 0 }
  .werkblatt-sticky .sticky-call { flex: 1 }
}
