/*
Theme Name: Schädlingsbekämpfung – Clean Hygiene
Theme URI: http://localhost/schaedlingsbekaempfung
Description: Wiederverwendbares Branchen-Boilerplate für Schädlingsbekämpfer / Kammerjäger. Klares, hygienisches Design (Teal-Grün + Amber), self-hosted Fonts (Inter + Sora), JSON-LD (LocalBusiness/Breadcrumb/FAQ), an-/abschaltbarer Ratgeber. Inhalte werden separat eingepflegt.
Author: Beratung & Service Thomas
Version: 1.0
Requires at least: 6.0
Tested up to: 7.0
Requires PHP: 7.4
Text Domain: schaedlingsbekaempfung
*/

/* ==========================================================================
   0 · Fonts (self-hosted, DSGVO-konform – keine externen Requests)
   ========================================================================== */
@font-face { font-family: "Inter"; font-style: normal; font-weight: 400; font-display: swap; src: url("fonts/inter-400.woff2") format("woff2"); }
@font-face { font-family: "Inter"; font-style: normal; font-weight: 600; font-display: swap; src: url("fonts/inter-600.woff2") format("woff2"); }
@font-face { font-family: "Inter"; font-style: normal; font-weight: 700; font-display: swap; src: url("fonts/inter-700.woff2") format("woff2"); }
@font-face { font-family: "Inter"; font-style: normal; font-weight: 800; font-display: swap; src: url("fonts/inter-800.woff2") format("woff2"); }
@font-face { font-family: "Sora"; font-style: normal; font-weight: 600; font-display: swap; src: url("fonts/sora-600.woff2") format("woff2"); }
@font-face { font-family: "Sora"; font-style: normal; font-weight: 700; font-display: swap; src: url("fonts/sora-700.woff2") format("woff2"); }
@font-face { font-family: "Sora"; font-style: normal; font-weight: 800; font-display: swap; src: url("fonts/sora-800.woff2") format("woff2"); }

/* ==========================================================================
   1 · Design-Tokens
   ========================================================================== */
:root {
	--green:        #15795f;   /* Primär – Teal-Grün (Hygiene/Vertrauen) */
	--green-deep:   #0f5d49;
	--green-700:    #0c4b3b;
	--green-tint:   #eef6f2;   /* helle Flächen */
	--green-tint-2: #e0efe8;
	--ink:          #0f2a25;   /* Text + dunkle Sektionen */
	--ink-soft:     #284842;
	--muted:        #5c7771;   /* Sekundärtext */
	--amber:        #f08a24;   /* CTA-Akzent */
	--amber-deep:   #d9760f;
	--paper:        #ffffff;
	--line:         #dde8e3;
	--line-strong:  #c4d8d0;
	--ok:           #1f9d6b;
	--err:          #c4453a;

	--radius:       14px;
	--radius-sm:    9px;
	--radius-lg:    22px;
	--container:    1180px;
	--shadow:       0 1px 2px rgba(15,42,37,.04), 0 8px 24px rgba(15,42,37,.06);
	--shadow-lg:    0 18px 50px rgba(15,42,37,.12);

	--sans:    "Inter", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
	--display: "Sora", var(--sans);
}

/* ==========================================================================
   2 · Reset / Base
   ========================================================================== */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

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

h1, h2, h3, h4 { font-family: var(--display); font-weight: 700; line-height: 1.15; color: var(--ink); margin: 0 0 .5em; letter-spacing: -.01em; }
p { margin: 0 0 1em; }
a { color: var(--green-deep); text-decoration: none; }
a:hover { text-decoration: underline; }
img { max-width: 100%; height: auto; }
ul { margin: 0 0 1em; padding-left: 1.2em; }
strong { font-weight: 700; }
:focus-visible { outline: 3px solid var(--amber); outline-offset: 2px; border-radius: 4px; }

/* ==========================================================================
   3 · Icons (CSS-Masken, einfärbbar über currentColor)
   ========================================================================== */
.ico {
	display: inline-block;
	width: 1.15em; height: 1.15em;
	vertical-align: -.18em;
	background: currentColor;
	-webkit-mask-repeat: no-repeat; mask-repeat: no-repeat;
	-webkit-mask-position: center; mask-position: center;
	-webkit-mask-size: contain; mask-size: contain;
	flex: none;
}
.ico--phone  { -webkit-mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M22 16.92v3a2 2 0 0 1-2.18 2 19.8 19.8 0 0 1-8.63-3.07 19.5 19.5 0 0 1-6-6A19.8 19.8 0 0 1 2.12 4.18 2 2 0 0 1 4.11 2h3a2 2 0 0 1 2 1.72c.13.96.36 1.9.7 2.81a2 2 0 0 1-.45 2.11L8.09 9.91a16 16 0 0 0 6 6l1.27-1.27a2 2 0 0 1 2.11-.45c.91.34 1.85.57 2.81.7A2 2 0 0 1 22 16.92z'/></svg>"); mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M22 16.92v3a2 2 0 0 1-2.18 2 19.8 19.8 0 0 1-8.63-3.07 19.5 19.5 0 0 1-6-6A19.8 19.8 0 0 1 2.12 4.18 2 2 0 0 1 4.11 2h3a2 2 0 0 1 2 1.72c.13.96.36 1.9.7 2.81a2 2 0 0 1-.45 2.11L8.09 9.91a16 16 0 0 0 6 6l1.27-1.27a2 2 0 0 1 2.11-.45c.91.34 1.85.57 2.81.7A2 2 0 0 1 22 16.92z'/></svg>"); }
.ico--mail   { -webkit-mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><rect x='2' y='4' width='20' height='16' rx='2'/><path d='m22 7-10 6L2 7'/></svg>"); mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><rect x='2' y='4' width='20' height='16' rx='2'/><path d='m22 7-10 6L2 7'/></svg>"); }
.ico--clock  { -webkit-mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='12' cy='12' r='9'/><path d='M12 7v5l3 3'/></svg>"); mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='12' cy='12' r='9'/><path d='M12 7v5l3 3'/></svg>"); }
.ico--map    { -webkit-mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M21 10c0 7-9 13-9 13s-9-6-9-13a9 9 0 0 1 18 0z'/><circle cx='12' cy='10' r='3'/></svg>"); mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M21 10c0 7-9 13-9 13s-9-6-9-13a9 9 0 0 1 18 0z'/><circle cx='12' cy='10' r='3'/></svg>"); }
.ico--home   { -webkit-mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M3 9.5 12 3l9 6.5V21a1 1 0 0 1-1 1h-5v-7H9v7H4a1 1 0 0 1-1-1z'/></svg>"); mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M3 9.5 12 3l9 6.5V21a1 1 0 0 1-1 1h-5v-7H9v7H4a1 1 0 0 1-1-1z'/></svg>"); }
.ico--up     { -webkit-mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M12 19V5M5 12l7-7 7 7'/></svg>"); mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M12 19V5M5 12l7-7 7 7'/></svg>"); }
.ico--check  { -webkit-mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><path d='M20 6 9 17l-5-5'/></svg>"); mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><path d='M20 6 9 17l-5-5'/></svg>"); }
.ico--shield { -webkit-mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M12 2 4 5v6c0 5 3.4 8.5 8 10 4.6-1.5 8-5 8-10V5z'/><path d='M9 12l2 2 4-4'/></svg>"); mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M12 2 4 5v6c0 5 3.4 8.5 8 10 4.6-1.5 8-5 8-10V5z'/><path d='M9 12l2 2 4-4'/></svg>"); }
.ico--leaf   { -webkit-mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M4 21c0-9 6-15 16-16-1 10-7 16-16 16z'/><path d='M4 21c4-6 8-9 12-11'/></svg>"); mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M4 21c0-9 6-15 16-16-1 10-7 16-16 16z'/><path d='M4 21c4-6 8-9 12-11'/></svg>"); }
.ico--bug    { -webkit-mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M12 8a5 6 0 0 0-5 6 5 6 0 0 0 10 0 5 6 0 0 0-5-6z'/><path d='M9 5 8 3M15 5l1-2M7 12H3M21 12h-4M7 17l-3 2M17 17l3 2M12 8V20'/></svg>"); mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M12 8a5 6 0 0 0-5 6 5 6 0 0 0 10 0 5 6 0 0 0-5-6z'/><path d='M9 5 8 3M15 5l1-2M7 12H3M21 12h-4M7 17l-3 2M17 17l3 2M12 8V20'/></svg>"); }
.ico--star   { -webkit-mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'><path d='M12 3l2.6 5.4 5.9.8-4.3 4.1 1 5.9-5.2-2.8-5.2 2.8 1-5.9-4.3-4.1 5.9-.8z'/></svg>"); mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'><path d='M12 3l2.6 5.4 5.9.8-4.3 4.1 1 5.9-5.2-2.8-5.2 2.8 1-5.9-4.3-4.1 5.9-.8z'/></svg>"); }
.ico--arrow  { -webkit-mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M5 12h14M13 6l6 6-6 6'/></svg>"); mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M5 12h14M13 6l6 6-6 6'/></svg>"); }
.ico--award  { -webkit-mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='12' cy='8' r='5'/><path d='M9 12.5 7 21l5-3 5 3-2-8.5'/></svg>"); mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='12' cy='8' r='5'/><path d='M9 12.5 7 21l5-3 5 3-2-8.5'/></svg>"); }

/* --- Schädling-spezifische Icons (gleicher Strich-Stil) ------------------- */
.ico--wasp   { -webkit-mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round'><ellipse cx='12' cy='14' rx='3.2' ry='4.7'/><path d='M9 12.8h6M9 15.4h6'/><circle cx='12' cy='7.4' r='1.9'/><path d='M11 5.9 9.6 4.2M13 5.9 14.4 4.2'/><path d='M9.2 11.3C5.5 9.6 4.6 11.2 5.5 13.2M14.8 11.3c3.7-1.7 4.6-.1 3.7 1.9'/></svg>"); mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round'><ellipse cx='12' cy='14' rx='3.2' ry='4.7'/><path d='M9 12.8h6M9 15.4h6'/><circle cx='12' cy='7.4' r='1.9'/><path d='M11 5.9 9.6 4.2M13 5.9 14.4 4.2'/><path d='M9.2 11.3C5.5 9.6 4.6 11.2 5.5 13.2M14.8 11.3c3.7-1.7 4.6-.1 3.7 1.9'/></svg>"); }
.ico--rat    { -webkit-mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round'><path d='M3 15.5c0-3 3-5 7-5s6 2 6 4-2 3.5-4 3.5H6c-1.7 0-3-1-3-2.5z'/><circle cx='13.6' cy='11.4' r='1.6'/><circle cx='8' cy='15' r='.5' fill='black'/><path d='M16 12.8c2-1 4.3.2 5.1 2.5'/></svg>"); mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round'><path d='M3 15.5c0-3 3-5 7-5s6 2 6 4-2 3.5-4 3.5H6c-1.7 0-3-1-3-2.5z'/><circle cx='13.6' cy='11.4' r='1.6'/><circle cx='8' cy='15' r='.5' fill='black'/><path d='M16 12.8c2-1 4.3.2 5.1 2.5'/></svg>"); }
.ico--mouse  { -webkit-mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round'><path d='M4 16c0-3 3-5 7-5s6 2 6 4-2 3.5-4 3.5H7c-1.7 0-3-1-3-2.5z'/><circle cx='13' cy='9.6' r='2.6'/><circle cx='8.6' cy='15' r='.5' fill='black'/><path d='M17 14.3c2 0 3 1 3.2 3'/></svg>"); mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round'><path d='M4 16c0-3 3-5 7-5s6 2 6 4-2 3.5-4 3.5H7c-1.7 0-3-1-3-2.5z'/><circle cx='13' cy='9.6' r='2.6'/><circle cx='8.6' cy='15' r='.5' fill='black'/><path d='M17 14.3c2 0 3 1 3.2 3'/></svg>"); }
.ico--bedbug { -webkit-mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><path d='M3 17v-4.5A1.5 1.5 0 0 1 4.5 11h15a1.5 1.5 0 0 1 1.5 1.5V17M3 14.5h18M3 17v2.5M21 17v2.5M7 11V9a1 1 0 0 1 1-1h3a1 1 0 0 1 1 1v2'/></svg>"); mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><path d='M3 17v-4.5A1.5 1.5 0 0 1 4.5 11h15a1.5 1.5 0 0 1 1.5 1.5V17M3 14.5h18M3 17v2.5M21 17v2.5M7 11V9a1 1 0 0 1 1-1h3a1 1 0 0 1 1 1v2'/></svg>"); }
.ico--roach  { -webkit-mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round'><ellipse cx='12' cy='13' rx='4' ry='6'/><path d='M9.5 8 6.5 4M14.5 8 17.5 4'/><path d='M8 11 4 9.5M8 13.5 4 14M8 16 5 18M16 11 20 9.5M16 13.5 20 14M16 16 19 18'/></svg>"); mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round'><ellipse cx='12' cy='13' rx='4' ry='6'/><path d='M9.5 8 6.5 4M14.5 8 17.5 4'/><path d='M8 11 4 9.5M8 13.5 4 14M8 16 5 18M16 11 20 9.5M16 13.5 20 14M16 16 19 18'/></svg>"); }
.ico--ant    { -webkit-mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round'><ellipse cx='12' cy='18' rx='3' ry='3.5'/><circle cx='12' cy='11' r='2.2'/><circle cx='12' cy='5.6' r='1.8'/><path d='M11 4.1 9.5 2.2M13 4.1 14.5 2.2'/><path d='M10 10.5 6 8.5M10 12 5.5 12.5M10.5 13.5 6.5 16M14 10.5 18 8.5M14 12 18.5 12.5M13.5 13.5 17.5 16'/></svg>"); mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round'><ellipse cx='12' cy='18' rx='3' ry='3.5'/><circle cx='12' cy='11' r='2.2'/><circle cx='12' cy='5.6' r='1.8'/><path d='M11 4.1 9.5 2.2M13 4.1 14.5 2.2'/><path d='M10 10.5 6 8.5M10 12 5.5 12.5M10.5 13.5 6.5 16M14 10.5 18 8.5M14 12 18.5 12.5M13.5 13.5 17.5 16'/></svg>"); }
.ico--marten { -webkit-mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'><ellipse cx='8' cy='9.5' rx='1.5' ry='2'/><ellipse cx='12' cy='8' rx='1.5' ry='2'/><ellipse cx='16' cy='9.5' rx='1.5' ry='2'/><path d='M12 11.5c-3 0-5.2 2-5.2 4.4 0 2 2.2 3.1 5.2 3.1s5.2-1.1 5.2-3.1C17.2 13.5 15 11.5 12 11.5z'/></svg>"); mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'><ellipse cx='8' cy='9.5' rx='1.5' ry='2'/><ellipse cx='12' cy='8' rx='1.5' ry='2'/><ellipse cx='16' cy='9.5' rx='1.5' ry='2'/><path d='M12 11.5c-3 0-5.2 2-5.2 4.4 0 2 2.2 3.1 5.2 3.1s5.2-1.1 5.2-3.1C17.2 13.5 15 11.5 12 11.5z'/></svg>"); }
.ico--pigeon { -webkit-mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round'><path d='M15.5 7.4a2.5 2.5 0 1 0-2.4-3'/><path d='M4 13c3.5.5 5.5-.5 8.5-1 3-.5 5.5-1.5 6.5-3l-.5 5c-.7 3-3.5 5-6.5 5-2.8 0-4.8-1.6-5-3.5'/><path d='M6.5 19.5 9 17M10 21l2-3'/></svg>"); mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round'><path d='M15.5 7.4a2.5 2.5 0 1 0-2.4-3'/><path d='M4 13c3.5.5 5.5-.5 8.5-1 3-.5 5.5-1.5 6.5-3l-.5 5c-.7 3-3.5 5-6.5 5-2.8 0-4.8-1.6-5-3.5'/><path d='M6.5 19.5 9 17M10 21l2-3'/></svg>"); }
.ico--flea   { -webkit-mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round'><ellipse cx='13.5' cy='13' rx='3' ry='4.2' transform='rotate(25 13.5 13)'/><path d='M11.6 10 8.6 7M15 11.5 18 9M11 15 9 18M14.6 15.5 16.6 18.5'/><path d='M3 19c1.5-4 4.5-7 8.5-8.5'/></svg>"); mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round'><ellipse cx='13.5' cy='13' rx='3' ry='4.2' transform='rotate(25 13.5 13)'/><path d='M11.6 10 8.6 7M15 11.5 18 9M11 15 9 18M14.6 15.5 16.6 18.5'/><path d='M3 19c1.5-4 4.5-7 8.5-8.5'/></svg>"); }
.ico--wood   { -webkit-mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='8' width='18' height='8' rx='1'/><circle cx='8' cy='12' r='1.1'/><circle cx='13' cy='11' r='.8'/><circle cx='16.5' cy='13' r='1'/></svg>"); mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='8' width='18' height='8' rx='1'/><circle cx='8' cy='12' r='1.1'/><circle cx='13' cy='11' r='.8'/><circle cx='16.5' cy='13' r='1'/></svg>"); }
.ico--moth   { -webkit-mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round'><path d='M12 8.5v8'/><path d='M12 9.5C9.2 4.8 3 6 3 10.4c0 3.8 5 4.6 9 2.6M12 9.5c2.8-4.7 9-3.5 9 .9 0 3.8-5 4.6-9 2.6'/><path d='M11 7 9.5 4.5M13 7 14.5 4.5'/></svg>"); mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round'><path d='M12 8.5v8'/><path d='M12 9.5C9.2 4.8 3 6 3 10.4c0 3.8 5 4.6 9 2.6M12 9.5c2.8-4.7 9-3.5 9 .9 0 3.8-5 4.6-9 2.6'/><path d='M11 7 9.5 4.5M13 7 14.5 4.5'/></svg>"); }
.ico--monitor{ -webkit-mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><rect x='5' y='4' width='14' height='17' rx='2'/><path d='M9 4V3a1 1 0 0 1 1-1h4a1 1 0 0 1 1 1v1z'/><path d='M9 12l2 2 4-4M9 17h6'/></svg>"); mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><rect x='5' y='4' width='14' height='17' rx='2'/><path d='M9 4V3a1 1 0 0 1 1-1h4a1 1 0 0 1 1 1v1z'/><path d='M9 12l2 2 4-4M9 17h6'/></svg>"); }

/* ==========================================================================
   4 · Topbar
   ========================================================================== */
.topbar { background: var(--ink); color: #cfe4dc; font-size: .82rem; }
.topbar__inner { max-width: var(--container); margin: 0 auto; padding: 8px 24px; display: flex; justify-content: space-between; align-items: center; gap: 16px; }
.topbar a { color: #fff; }
.topbar .ico { color: var(--amber); margin-right: 5px; }
.topbar__right { display: flex; gap: 22px; align-items: center; }
@media (max-width: 760px) { .topbar__more, .topbar__right span:first-child { display: none; } }

/* ==========================================================================
   5 · Header / Navigation
   ========================================================================== */
.site-header { position: sticky; top: 0; z-index: 60; background: rgba(255,255,255,.92); backdrop-filter: saturate(160%) blur(8px); border-bottom: 1px solid var(--line); transition: box-shadow .25s; }
.site-header.is-scrolled { box-shadow: 0 6px 22px rgba(15,42,37,.09); }
.header__inner { max-width: var(--container); margin: 0 auto; padding: 12px 24px; display: flex; align-items: center; gap: 22px; }

.brand { display: flex; align-items: center; gap: 12px; flex: none; }
.brand:hover { text-decoration: none; }
.brand__logo { display: block; flex: none; }
.brand__text { display: flex; flex-direction: column; line-height: 1.1; }
.brand__name { font-family: var(--display); font-weight: 800; font-size: 1.12rem; color: var(--ink); letter-spacing: -.02em; }
.brand__claim { font-size: .72rem; color: var(--muted); font-weight: 600; letter-spacing: .01em; }

.nav { margin-left: auto; }
.nav__list { list-style: none; display: flex; gap: 3px; margin: 0; padding: 0; align-items: center; }
.nav__list > li { flex: none; }
.nav__list a { display: block; padding: 9px 12px; border-radius: 8px; color: var(--ink); font-weight: 600; font-size: .95rem; white-space: nowrap; }
.nav__list a:hover { background: var(--green-tint); color: var(--green-deep); text-decoration: none; }
.nav__list .current-menu-item > a, .nav__list .current-page-ancestor > a { color: var(--green-deep); }
.nav__list li { position: relative; }

/* Dropdowns */
.nav__list .sub-menu { list-style: none; position: absolute; top: calc(100% + 8px); left: 0; min-width: 240px; max-height: 76vh; overflow-y: auto; background: #fff; border: 1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow-lg); padding: 8px; margin: 0; opacity: 0; visibility: hidden; transform: translateY(6px); transition: .18s; }
.nav__list li:hover > .sub-menu, .nav__list li:focus-within > .sub-menu { opacity: 1; visibility: visible; transform: translateY(0); }
.nav__list .sub-menu a { padding: 8px 11px; font-size: .9rem; font-weight: 600; border-radius: 7px; }
.menu-item-has-children > a::after { content: "▾"; font-size: .7em; margin-left: 5px; color: var(--muted); }

.header__cta { flex: none; }
@media (max-width: 1080px) { .header__cta { display: none; } }

/* Burger */
.nav-toggle { display: none; margin-left: auto; width: 46px; height: 42px; border: 1px solid var(--line); border-radius: 10px; background: #fff; cursor: pointer; padding: 0; flex-direction: column; justify-content: center; align-items: center; gap: 5px; }
.nav-toggle span { width: 22px; height: 2px; background: var(--ink); border-radius: 2px; transition: .25s; }
body.nav-open .nav-toggle span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
body.nav-open .nav-toggle span:nth-child(2) { opacity: 0; }
body.nav-open .nav-toggle span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

@media (max-width: 1080px) {
	.nav-toggle { display: flex; }
	.nav { position: fixed; inset: 0 0 0 auto; width: min(86vw, 360px); margin: 0; background: #fff; transform: translateX(100%); transition: transform .28s; z-index: 70; box-shadow: var(--shadow-lg); overflow-y: auto; padding: 84px 18px 24px; }
	body.nav-open .nav { transform: translateX(0); }
	.nav__list { flex-direction: column; align-items: stretch; gap: 2px; }
	.nav__list a { padding: 12px 14px; font-size: 1.02rem; }
	.nav__list .sub-menu { position: static; opacity: 1; visibility: visible; transform: none; box-shadow: none; border: none; border-left: 2px solid var(--line); border-radius: 0; margin: 2px 0 6px 12px; max-height: none; padding: 0 0 0 6px; }
}

/* ==========================================================================
   6 · Breadcrumbs
   ========================================================================== */
.breadcrumbs { background: var(--green-tint); border-bottom: 1px solid var(--line); }
.breadcrumbs__inner { max-width: var(--container); margin: 0 auto; padding: 11px 24px; font-size: .85rem; color: var(--muted); display: flex; flex-wrap: wrap; gap: 7px; align-items: center; }
.breadcrumbs a { color: var(--green-deep); font-weight: 600; }
.breadcrumbs__sep { color: var(--line-strong); }
.breadcrumbs__current { color: var(--ink); font-weight: 600; }

/* ==========================================================================
   7 · Buttons
   ========================================================================== */
.btn { display: inline-flex; align-items: center; gap: 9px; padding: 12px 20px; border-radius: 11px; font-family: var(--sans); font-weight: 700; font-size: .98rem; line-height: 1; border: 2px solid transparent; cursor: pointer; transition: transform .12s, box-shadow .2s, background .2s, border-color .2s; text-decoration: none; white-space: nowrap; }
.btn:hover { text-decoration: none; transform: translateY(-1px); }
.btn .ico { width: 1.05em; height: 1.05em; }
.btn--accent { background: var(--amber); color: #fff; box-shadow: 0 6px 16px rgba(240,138,36,.32); }
.btn--accent:hover { background: var(--amber-deep); color: #fff; box-shadow: 0 10px 22px rgba(240,138,36,.36); }
.btn--ghost { background: transparent; color: var(--ink); border-color: var(--line-strong); }
.btn--ghost:hover { border-color: var(--green); color: var(--green-deep); background: var(--green-tint); }
.btn--green { background: var(--green); color: #fff; box-shadow: 0 6px 16px rgba(21,121,95,.28); }
.btn--green:hover { background: var(--green-deep); color: #fff; }
.btn--lg { padding: 15px 26px; font-size: 1.06rem; border-radius: 13px; }
/* Auf dunklem Grund */
.section--dark .btn--ghost, .hero--dark .btn--ghost { color: #fff; border-color: rgba(255,255,255,.34); }
.section--dark .btn--ghost:hover, .hero--dark .btn--ghost:hover { background: rgba(255,255,255,.1); border-color: #fff; }

/* ==========================================================================
   8 · Sektionen
   ========================================================================== */
.section { padding: 72px 0; }
.section--alt { background: var(--green-tint); }
.section--tint2 { background: var(--green-tint-2); }
.section--dark { background: var(--ink); color: #d3e6df; position: relative; overflow: hidden; }
.section--dark h1, .section--dark h2, .section--dark h3, .section--dark h4 { color: #fff; }
.section--dark a { color: #fff; }
.section--dark::after { content: ""; position: absolute; right: -60px; bottom: -60px; width: 320px; height: 320px; background: currentColor; opacity: .04; -webkit-mask: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M4 21c0-9 6-15 16-16-1 10-7 16-16 16z' fill='black'/></svg>") center/contain no-repeat; mask: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M4 21c0-9 6-15 16-16-1 10-7 16-16 16z' fill='black'/></svg>") center/contain no-repeat; pointer-events: none; }
.section__inner { max-width: var(--container); margin: 0 auto; padding: 0 24px; position: relative; }
.section__inner--narrow { max-width: 820px; margin-left: auto; margin-right: auto; padding-left: 24px; padding-right: 24px; }
.section__kicker { font-family: var(--sans); font-weight: 700; font-size: .8rem; letter-spacing: .09em; text-transform: uppercase; color: var(--green); margin: 0 0 .55em; }
.section--dark .section__kicker { color: var(--amber); }
.section__title { font-size: clamp(1.7rem, 3.4vw, 2.4rem); margin: 0 0 .45em; }
.section__lead { font-size: 1.12rem; color: var(--muted); max-width: 60ch; margin: 0 0 1.6em; }
.section--dark .section__lead { color: #b9d4cb; }

/* ==========================================================================
   9 · Hero
   ========================================================================== */
.hero { position: relative; background: var(--paper); padding: 72px 0 64px; overflow: hidden; }
.hero::before { content: ""; position: absolute; inset: 0; background:
	radial-gradient(720px 420px at 88% -8%, var(--green-tint-2), transparent 60%),
	radial-gradient(560px 360px at 5% 108%, var(--green-tint), transparent 55%); pointer-events: none; }
.hero__inner { position: relative; max-width: var(--container); margin: 0 auto; padding: 0 24px; }
.hero__kicker { display: inline-flex; align-items: center; gap: 7px; background: #fff; border: 1px solid var(--line-strong); color: var(--green-deep); font-weight: 700; font-size: .82rem; letter-spacing: .02em; padding: 7px 14px; border-radius: 999px; margin: 0 0 18px; box-shadow: var(--shadow); }
.hero__title { font-size: clamp(2.1rem, 5vw, 3.4rem); font-weight: 800; max-width: 18ch; margin: 0 0 .4em; }
.hero__lead { font-size: clamp(1.08rem, 1.7vw, 1.28rem); color: var(--ink-soft); max-width: 56ch; margin: 0 0 1.8em; }
.hero__ctas { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; }
.hero__badges { display: flex; flex-wrap: wrap; gap: 10px 22px; margin: 26px 0 0; padding: 0; list-style: none; }
.hero__badges li { display: inline-flex; align-items: center; gap: 9px; font-weight: 600; font-size: .95rem; color: var(--ink-soft); }
.hero__badges .ico { color: var(--green); background: var(--green-tint); width: 1.7em; height: 1.7em; padding: .34em; border-radius: 50%; }
/* Dunkle Hero-Variante */
.hero--dark { background: var(--ink); color: #d6e8e1; }
.hero--dark .hero__title { color: #fff; }
.hero--dark .hero__lead { color: #b9d4cb; }
.hero--dark .hero__kicker { background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.18); color: #fff; }
.hero--dark::before { background: radial-gradient(700px 420px at 88% -10%, rgba(21,121,95,.5), transparent 60%); }

/* ==========================================================================
   10 · Grid + Cards
   ========================================================================== */
.grid { display: grid; gap: 22px; }
.grid--2 { grid-template-columns: repeat(2, 1fr); }
.grid--3 { grid-template-columns: repeat(3, 1fr); }
.grid--4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 920px) { .grid--3, .grid--4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .grid--2, .grid--3, .grid--4 { grid-template-columns: 1fr; } }

.card { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 26px; box-shadow: var(--shadow); transition: transform .16s, box-shadow .2s, border-color .2s; }
.card:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); border-color: var(--line-strong); }
.card__icon { display: inline-flex; align-items: center; justify-content: center; width: 52px; height: 52px; border-radius: 14px; background: var(--green-tint); color: var(--green); margin-bottom: 16px; }
.card__icon .ico { width: 1.5em; height: 1.5em; }
.card__title { font-size: 1.2rem; margin: 0 0 .4em; }
.card__text { color: var(--muted); margin: 0 0 1em; font-size: .98rem; }
.card__link { font-weight: 700; color: var(--green-deep); display: inline-flex; align-items: center; gap: 6px; }
.card__link:hover { text-decoration: none; gap: 9px; }
.card--link { display: block; color: inherit; }
.card--link:hover { text-decoration: none; }

/* Pest-Kachel-Auswahl (Schädling wählen) */
.pests { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
@media (max-width: 920px) { .pests { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 600px) { .pests { grid-template-columns: repeat(2, 1fr); } }
.pest { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 10px; padding: 22px 14px; background: #fff; border: 1px solid var(--line); border-radius: var(--radius); color: var(--ink); font-weight: 700; box-shadow: var(--shadow); transition: transform .16s, box-shadow .2s, border-color .2s; }
.pest:hover { transform: translateY(-3px); border-color: var(--green); box-shadow: var(--shadow-lg); text-decoration: none; }
.pest .ico { width: 30px; height: 30px; color: var(--green); }

/* ==========================================================================
   11 · Steps (Ablauf)
   ========================================================================== */
.steps { list-style: none; counter-reset: step; padding: 0; margin: 0; display: grid; gap: 22px; grid-template-columns: repeat(4, 1fr); }
@media (max-width: 920px) { .steps { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .steps { grid-template-columns: 1fr; } }
/* 3-Schritte-Variante (Startseite „So läuft Ihr Anruf"): füllt die Breite statt leerer 4. Spalte */
.steps--3 { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 920px) { .steps--3 { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 760px) { .steps--3 { grid-template-columns: 1fr; } }
.step { position: relative; padding: 26px 22px; background: #fff; border: 1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow); }
.step__num, .step::before { counter-increment: step; }
.step__num { display: inline-flex; align-items: center; justify-content: center; width: 42px; height: 42px; border-radius: 50%; background: var(--green); color: #fff; font-family: var(--display); font-weight: 800; margin-bottom: 14px; }
.step__num::before { content: counter(step); }
.step__title { font-size: 1.1rem; margin: 0 0 .35em; }
.step p { color: var(--muted); font-size: .96rem; margin: 0; }

/* ==========================================================================
   12 · Checklist / Listen
   ========================================================================== */
.checklist { list-style: none; padding: 0; margin: 0 0 1em; display: grid; gap: 12px; }
.checklist li { position: relative; padding-left: 34px; color: var(--ink-soft); }
.checklist li::before { content: ""; position: absolute; left: 0; top: 1px; width: 22px; height: 22px; border-radius: 50%; background: var(--green-tint); color: var(--green); -webkit-mask: none; }
.checklist li::after { content: ""; position: absolute; left: 4px; top: 5px; width: 14px; height: 14px; background: var(--green); -webkit-mask: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><path d='M20 6 9 17l-5-5'/></svg>") center/contain no-repeat; mask: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><path d='M20 6 9 17l-5-5'/></svg>") center/contain no-repeat; }
.section--dark .checklist li { color: #cbe1d9; }
.section--dark .checklist li::before { background: rgba(255,255,255,.12); }
.section--dark .checklist li::after { background: var(--amber); }

/* ==========================================================================
   13 · Badges / Pills (Vertrauen)
   ========================================================================== */
.badges { display: flex; flex-wrap: wrap; gap: 12px; list-style: none; padding: 0; margin: 0; }
.badge { display: inline-flex; align-items: center; gap: 8px; background: #fff; border: 1px solid var(--line); border-radius: 999px; padding: 9px 16px; font-weight: 700; font-size: .9rem; color: var(--ink); box-shadow: var(--shadow); }
.badge .ico { color: var(--green); }
.badge--amber .ico { color: var(--amber); }

/* ==========================================================================
   14 · Stats
   ========================================================================== */
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; text-align: center; }
@media (max-width: 760px) { .stats { grid-template-columns: repeat(2, 1fr); } }
.stat__num { font-family: var(--display); font-weight: 800; font-size: clamp(2rem, 4vw, 2.8rem); color: var(--green); line-height: 1; }
.section--dark .stat__num { color: var(--amber); }
.stat__label { color: var(--muted); font-size: .95rem; font-weight: 600; margin-top: .4em; }
.section--dark .stat__label { color: #b9d4cb; }

/* ==========================================================================
   15 · Split (Text + Medien/Box)
   ========================================================================== */
.split { display: grid; grid-template-columns: 1.1fr .9fr; gap: 48px; align-items: center; }
@media (max-width: 880px) { .split { grid-template-columns: 1fr; gap: 30px; } }
.split__media { background: var(--green-tint); border: 1px solid var(--line); border-radius: var(--radius-lg); min-height: 280px; padding: 32px; display: flex; flex-direction: column; justify-content: center; }

/* ==========================================================================
   16 · Quote / Testimonial
   ========================================================================== */
.quote { background: #fff; border: 1px solid var(--line); border-left: 4px solid var(--green); border-radius: var(--radius); padding: 28px 30px; box-shadow: var(--shadow); }
.quote__text { font-size: 1.18rem; font-family: var(--display); font-weight: 600; color: var(--ink); margin: 0 0 .7em; line-height: 1.45; }
.quote__cite { color: var(--muted); font-weight: 600; font-style: normal; font-size: .92rem; }
.quote__stars { color: var(--amber); display: inline-flex; gap: 2px; margin-bottom: .6em; }

/* ==========================================================================
   17 · Notice / Hinweis
   ========================================================================== */
.notice { border-radius: var(--radius); padding: 22px 26px; margin: 1.6em 0; border: 1px solid var(--line); background: #fff; box-shadow: var(--shadow); }
.notice h3 { margin: 0 0 .35em; }
.notice p:last-child { margin-bottom: 0; }
.notice--info { background: var(--green-tint); border-color: var(--line-strong); }
.notice--warn { background: #fff5ea; border-color: #f3d4a6; }
.notice--warn h3 { color: var(--amber-deep); }

/* ==========================================================================
   18 · FAQ (details/summary)
   ========================================================================== */
.faq { display: grid; gap: 12px; }
.faq__item { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow); }
.faq__item summary { list-style: none; cursor: pointer; padding: 18px 52px 18px 22px; font-family: var(--display); font-weight: 700; font-size: 1.05rem; color: var(--ink); position: relative; }
.faq__item summary::-webkit-details-marker { display: none; }
.faq__item summary::after { content: ""; position: absolute; right: 20px; top: 50%; width: 14px; height: 14px; transform: translateY(-50%); background: var(--green); -webkit-mask: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.4' stroke-linecap='round'><path d='M6 9l6 6 6-6'/></svg>") center/contain no-repeat; mask: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.4' stroke-linecap='round'><path d='M6 9l6 6 6-6'/></svg>") center/contain no-repeat; transition: transform .25s; }
.faq__item[open] summary::after { transform: translateY(-50%) rotate(180deg); }
.faq__body { overflow: hidden; transition: height .28s ease; }
.faq__body > div, .faq__item .faq__body { padding: 0 22px; }
.faq__body p { padding: 0; margin: 0 0 1em; color: var(--ink-soft); }
.faq__item[open] .faq__body { padding-bottom: 6px; }
.faq__body :first-child { margin-top: 0; }
.faq__body { padding: 0 22px 4px; }

/* ==========================================================================
   19 · CTA-Banner
   ========================================================================== */
.cta-banner { background: linear-gradient(120deg, var(--green-deep), var(--green)); color: #fff; border-radius: var(--radius-lg); padding: 44px 40px; text-align: center; position: relative; overflow: hidden; }
.cta-banner h2 { color: #fff; font-size: clamp(1.6rem, 3vw, 2.2rem); margin: 0 0 .4em; }
.cta-banner p { color: #d8efe7; max-width: 56ch; margin: 0 auto 1.4em; }
.cta-banner .hero__ctas, .cta-banner__actions { justify-content: center; display: flex; flex-wrap: wrap; gap: 14px; }
.cta-banner .btn--ghost { color: #fff; border-color: rgba(255,255,255,.4); }
.cta-banner .btn--ghost:hover { background: rgba(255,255,255,.12); border-color: #fff; }

/* ==========================================================================
   20 · Formular
   ========================================================================== */
.form { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; background: #fff; border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 30px; box-shadow: var(--shadow); }
@media (max-width: 640px) { .form { grid-template-columns: 1fr; padding: 22px; } }
.form__field { display: flex; flex-direction: column; gap: 6px; }
.form__field--full { grid-column: 1 / -1; }
.form label { font-weight: 600; font-size: .92rem; color: var(--ink); }
.form input, .form select, .form textarea { font-family: var(--sans); font-size: 1rem; padding: 12px 14px; border: 1px solid var(--line-strong); border-radius: 10px; background: #fcfefd; color: var(--ink); transition: border-color .15s, box-shadow .15s; }
.form input:focus, .form select:focus, .form textarea:focus { outline: none; border-color: var(--green); box-shadow: 0 0 0 3px rgba(21,121,95,.14); }
.form textarea { min-height: 130px; resize: vertical; }
.form__consent { grid-column: 1 / -1; display: flex; gap: 10px; align-items: flex-start; font-weight: 500; font-size: .9rem; color: var(--muted); }
.form__consent input { margin-top: 3px; }
.form__submit { grid-column: 1 / -1; }
.form__hp { position: absolute; left: -9999px; }
.req { color: var(--amber-deep); }
.form-result { grid-column: 1 / -1; padding: 14px 18px; border-radius: 10px; font-weight: 600; margin-bottom: 4px; }
.form-result--ok { background: #e7f6ee; color: #18603f; border: 1px solid #b8e3c9; }
.form-result--error { background: #fdeceb; color: #99332b; border: 1px solid #f3c4bf; }

/* ==========================================================================
   21 · Einsatzgebiete-Verzeichnis + Live-Suche
   ========================================================================== */
.areasearch__field { position: relative; max-width: 460px; margin: 0 0 24px; }
.areasearch__field input { width: 100%; font-size: 1.02rem; padding: 13px 16px 13px 44px; border: 1px solid var(--line-strong); border-radius: 12px; background: #fff; }
.areasearch__field input:focus { outline: none; border-color: var(--green); box-shadow: 0 0 0 3px rgba(21,121,95,.14); }
.areasearch__field .ico { position: absolute; left: 15px; top: 50%; transform: translateY(-50%); color: var(--muted); }
.verzeichnis { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
@media (max-width: 920px) { .verzeichnis { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .verzeichnis { grid-template-columns: 1fr; } }
.verzeichnis a { display: flex; align-items: center; gap: 8px; padding: 12px 16px; background: #fff; border: 1px solid var(--line); border-radius: 10px; font-weight: 600; color: var(--ink); box-shadow: var(--shadow); }
.verzeichnis a:hover { border-color: var(--green); color: var(--green-deep); text-decoration: none; }
.verzeichnis a::before { content: ""; width: 16px; height: 16px; flex: none; background: var(--green); -webkit-mask: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M21 10c0 7-9 13-9 13s-9-6-9-13a9 9 0 0 1 18 0z'/><circle cx='12' cy='10' r='3'/></svg>") center/contain no-repeat; mask: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M21 10c0 7-9 13-9 13s-9-6-9-13a9 9 0 0 1 18 0z'/><circle cx='12' cy='10' r='3'/></svg>") center/contain no-repeat; }
.areasearch__none { color: var(--muted); }

/* ==========================================================================
   22 · Mobile Action-Bar + To-Top
   ========================================================================== */
.actionbar { position: fixed; left: 0; right: 0; bottom: 0; z-index: 55; display: none; align-items: center; gap: 10px; padding: 10px 14px; background: rgba(15,42,37,.97); backdrop-filter: blur(6px); color: #fff; box-shadow: 0 -6px 20px rgba(0,0,0,.18); }
.actionbar__txt { font-weight: 700; font-size: .9rem; display: flex; align-items: center; gap: 7px; flex: 1; }
.actionbar__txt .ico { color: var(--amber); }
.actionbar__call { background: var(--amber); color: #fff; padding: 10px 16px; }
.actionbar__ghost { border: 1px solid rgba(255,255,255,.4); color: #fff; padding: 10px 14px; }
@media (max-width: 820px) { .actionbar { display: flex; } .actionbar__txt { display: none; } body { padding-bottom: 64px; } .actionbar__call, .actionbar__ghost { flex: 1; justify-content: center; } }

.to-top { position: fixed; right: 18px; bottom: 18px; z-index: 50; width: 46px; height: 46px; border-radius: 50%; border: none; background: var(--green); color: #fff; cursor: pointer; opacity: 0; visibility: hidden; transform: translateY(10px); transition: .22s; box-shadow: var(--shadow-lg); display: inline-flex; align-items: center; justify-content: center; }
.to-top.is-visible { opacity: 1; visibility: visible; transform: translateY(0); }
@media (max-width: 820px) { .to-top { bottom: 74px; } }

/* ==========================================================================
   23 · Footer
   ========================================================================== */
.site-footer { background: var(--ink); color: #aecabf; padding: 60px 0 0; }
.footer__grid { max-width: var(--container); margin: 0 auto; padding: 0 24px 48px; display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 40px; }
@media (max-width: 880px) { .footer__grid { grid-template-columns: 1fr 1fr; gap: 32px; } }
@media (max-width: 520px) { .footer__grid { grid-template-columns: 1fr; } }
.site-footer h4 { color: #fff; font-size: 1rem; margin: 0 0 1em; }
.site-footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 9px; }
.site-footer a { color: #aecabf; font-weight: 500; }
.site-footer a:hover { color: #fff; }
.footer__name { font-family: var(--display); font-weight: 800; color: #fff; font-size: 1.15rem; display: block; margin-bottom: .6em; }
.footer__pitch { font-size: .94rem; color: #9bbdb1; margin-bottom: 1.2em; }
.footer__contact { display: grid; gap: 10px; }
.footer__contact li { display: flex; align-items: center; gap: 9px; }
.footer__contact .ico { color: var(--amber); }
.footer__bottom { border-top: 1px solid rgba(255,255,255,.1); }
.footer__bottom-inner { max-width: var(--container); margin: 0 auto; padding: 20px 24px; display: flex; justify-content: space-between; gap: 14px; flex-wrap: wrap; font-size: .85rem; color: #87a99d; }
.footer__legal { display: flex; gap: 18px; list-style: none; padding: 0; margin: 0; }

/* ==========================================================================
   24 · Utilities
   ========================================================================== */
.text-center { text-align: center; }
.mt-0 { margin-top: 0; }
.lead { font-size: 1.14rem; color: var(--ink-soft); }
.muted { color: var(--muted); }
.placeholder { outline: 2px dashed var(--line-strong); outline-offset: 3px; border-radius: 6px; color: var(--muted); }

/* ==========================================================================
   25 · Bausteine für Detail-/Unterseiten
   ========================================================================== */
/* Zentrierter Sektionskopf */
.section__head { text-align: center; max-width: 660px; margin: 0 auto 2.4em; }
.section__head .section__lead { margin-left: auto; margin-right: auto; }

/* Anzeichen-Liste (amber Punkt) */
.signs { list-style: none; padding: 0; margin: 0 0 1em; display: grid; gap: 12px; }
.signs li { position: relative; padding-left: 30px; color: var(--ink-soft); }
.signs li::before { content: ""; position: absolute; left: 0; top: 7px; width: 12px; height: 12px; border-radius: 50%; background: var(--amber); box-shadow: 0 0 0 4px rgba(240,138,36,.16); }

/* Kontakt-/Info-Liste */
.infolist { list-style: none; padding: 0; margin: 0; display: grid; gap: 18px; }
.infolist li { display: flex; gap: 14px; align-items: flex-start; }
.infolist .ico { color: var(--green); width: 1.55em; height: 1.55em; flex: none; margin-top: 2px; }
.infolist strong { display: block; color: var(--ink); }
.infolist span, .infolist a { color: var(--muted); }

/* Platzhalter-Medienbox (Foto / Karte) */
.ph-box { background: var(--green-tint); border: 1px dashed var(--line-strong); border-radius: var(--radius-lg); min-height: 240px; display: flex; flex-direction: column; gap: 8px; align-items: center; justify-content: center; color: var(--muted); font-weight: 600; text-align: center; padding: 24px; }
.ph-box .ico { width: 2em; height: 2em; color: var(--line-strong); }

/* Team-Karten mit Avatar-Platzhalter */
.team { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
@media (max-width: 760px) { .team { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .team { grid-template-columns: 1fr; } }
.team .card { text-align: center; }
.avatar { width: 84px; height: 84px; border-radius: 50%; background: var(--green-tint); border: 1px solid var(--line); margin: 0 auto 14px; display: flex; align-items: center; justify-content: center; color: var(--green); }
.avatar .ico { width: 2.1em; height: 2.1em; }

/* Verwandte Links / Nachbar-Gebiete als Pills */
.tags { display: flex; flex-wrap: wrap; gap: 10px; list-style: none; padding: 0; margin: 0; }
.tags a { display: inline-flex; align-items: center; gap: 7px; padding: 8px 14px; border: 1px solid var(--line); border-radius: 999px; background: #fff; font-weight: 600; font-size: .9rem; color: var(--ink); box-shadow: var(--shadow); }
.tags a:hover { border-color: var(--green); color: var(--green-deep); text-decoration: none; }
.tags .ico { color: var(--green); }

/* Legal-Text (Impressum/Datenschutz) */
.legal h2 { font-size: 1.25rem; margin: 1.6em 0 .4em; }
.legal h2:first-child { margin-top: 0; }
.legal p { color: var(--ink-soft); }

/* ==========================================================================
   26 · UX-Ausbau (gleiches Theme): Micro-Animationen, Split-Hero, Quick-Help,
        Routen, Feature, Mega-Menü, Trust-Band, Detail-Layout, Pre-Footer
   ========================================================================== */

/* --- Micro-Animationen (Progressive Enhancement) --- */
.reveal { will-change: opacity, transform; }
html.anim .reveal { opacity: 0; transform: translateY(22px); transition: opacity .8s ease, transform .8s cubic-bezier(.2,.7,.2,1); }
html.anim .reveal.is-in { opacity: 1; transform: none; }
html.anim .hero-in { opacity: 0; transform: translateY(16px); }
html.anim .hero-in.hero-in--show { opacity: 1; transform: none; transition: opacity 1s ease, transform 1s cubic-bezier(.2,.7,.2,1); }
@media (prefers-reduced-motion: reduce) { html.anim .reveal, html.anim .hero-in { opacity: 1 !important; transform: none !important; transition: none !important; } }

/* --- Asymmetrischer Hero mit Quick-Help-Panel --- */
.hero--split .hero__inner { display: grid; grid-template-columns: 1.15fr .85fr; gap: 52px; align-items: center; }
@media (max-width: 940px) { .hero--split .hero__inner { grid-template-columns: 1fr; gap: 38px; } }
.quickhelp { background: #fff; border: 1px solid var(--line); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); padding: 26px; }
.quickhelp__title { font-family: var(--display); font-weight: 800; font-size: 1.18rem; margin: 0 0 2px; }
.quickhelp__sub { color: var(--muted); font-size: .9rem; margin: 0; }
.quickhelp__call { display: flex; align-items: center; justify-content: center; gap: 10px; background: var(--amber); color: #fff; font-weight: 700; font-size: 1.18rem; padding: 14px; border-radius: 11px; margin: 16px 0; box-shadow: 0 8px 18px rgba(240,138,36,.3); transition: background .2s ease; }
.quickhelp__call:hover { background: var(--amber-deep); color: #fff; text-decoration: none; }
.quickhelp__facts { list-style: none; padding: 0; margin: 0 0 18px; display: grid; gap: 11px; }
.quickhelp__facts li { display: flex; align-items: center; gap: 10px; font-weight: 600; font-size: .93rem; color: var(--ink-soft); }
.quickhelp__facts .ico { color: var(--green); flex: none; }
.quickhelp__router-label { font-size: .74rem; text-transform: uppercase; letter-spacing: .1em; color: var(--muted); font-weight: 700; margin: 0 0 9px; }
.quickhelp__router { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.quickhelp__router a { display: flex; flex-direction: column; align-items: center; gap: 7px; padding: 13px 6px; border: 1px solid var(--line); border-radius: 10px; font-size: .82rem; font-weight: 600; color: var(--ink); text-align: center; transition: border-color .2s ease, background .2s ease, color .2s ease; }
.quickhelp__router a:hover { border-color: var(--green); color: var(--green-deep); background: var(--green-tint); text-decoration: none; }
.quickhelp__router .ico { width: 1.55em; height: 1.55em; color: var(--green); }

/* --- Routen „nach Bedarf" --- */
.routes { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
@media (max-width: 720px) { .routes { grid-template-columns: 1fr; } }
.route { display: block; background: #fff; border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 36px; color: inherit; box-shadow: var(--shadow); transition: transform .25s cubic-bezier(.2,.7,.2,1), box-shadow .25s ease, border-color .25s ease; }
.route:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); text-decoration: none; border-color: var(--line-strong); }
.route__icon { display: inline-flex; align-items: center; justify-content: center; width: 58px; height: 58px; border-radius: 16px; background: var(--green-tint); color: var(--green); margin-bottom: 18px; transition: transform .3s cubic-bezier(.2,.7,.2,1); }
.route:hover .route__icon { transform: scale(1.06); }
.route__icon .ico { width: 1.75em; height: 1.75em; }
.route h3 { font-size: 1.5rem; margin: 0 0 .3em; }
.route p { color: var(--muted); margin: 0 0 1.1em; }
.route__cta { font-weight: 700; color: var(--green-deep); display: inline-flex; align-items: center; gap: 7px; transition: gap .2s ease; }
.route:hover .route__cta { gap: 12px; }
.route--urgent { background: linear-gradient(to bottom right, #fff5ea, #fff 70%); border-color: #f3d4a6; }
.route--urgent .route__icon { background: rgba(240,138,36,.16); color: var(--amber-deep); }
.route--urgent .route__cta { color: var(--amber-deep); }

/* --- Feature-Layout (1 groß + Kachelraster) --- */
.feature { display: grid; grid-template-columns: .92fr 1.08fr; gap: 28px; align-items: stretch; }
@media (max-width: 880px) { .feature { grid-template-columns: 1fr; } }
.feature__hero { background: var(--ink); color: #fff; border-radius: var(--radius-lg); padding: 40px; display: flex; flex-direction: column; justify-content: center; position: relative; overflow: hidden; }
.feature__hero::after { content: ""; position: absolute; right: -34px; bottom: -44px; width: 220px; height: 220px; background: #fff; opacity: .06; -webkit-mask: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M4 21c0-9 6-15 16-16-1 10-7 16-16 16z' fill='black'/></svg>") center/contain no-repeat; mask: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M4 21c0-9 6-15 16-16-1 10-7 16-16 16z' fill='black'/></svg>") center/contain no-repeat; pointer-events: none; }
.feature__hero > * { position: relative; }
.feature__badge { display: inline-flex; align-items: center; gap: 7px; align-self: flex-start; background: rgba(240,138,36,.2); color: #f6d6a8; font-weight: 700; font-size: .76rem; letter-spacing: .08em; text-transform: uppercase; padding: 6px 12px; border-radius: 999px; margin-bottom: 16px; }
.feature__hero .ico--big { width: 44px; height: 44px; color: var(--amber); margin-bottom: 14px; }
.feature__hero h3 { color: #fff; font-size: 1.7rem; margin: 0 0 .3em; }
.feature__hero p { color: #cfe0d9; margin: 0 0 1.5em; }
.feature__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
@media (max-width: 480px) { .feature__grid { grid-template-columns: 1fr; } }

/* --- Mega-Menü (Leistungen) – nur Desktop --- */
@media (min-width: 1081px) {
	.nav__list .menu-item.mega { position: relative; }
	.nav__list .menu-item.mega > .sub-menu { width: 600px; max-height: none; display: grid; grid-template-columns: 1fr 1fr; gap: 2px 8px; padding: 14px; }
	.nav__list .menu-item.mega > .sub-menu a { display: flex; align-items: center; gap: 11px; padding: 11px 12px; }
	.nav__list .menu-item.mega > .sub-menu .ico { width: 1.3em; height: 1.3em; color: var(--green); flex: none; }
}
.nav__list .sub-menu .ico { color: var(--green); }

/* --- Trust-Band --- */
.trustband { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 16px 36px; padding: 28px 30px; background: #fff; border: 1px solid var(--line); border-radius: var(--radius-lg); box-shadow: var(--shadow); }
.trustband__item { display: flex; align-items: center; gap: 10px; font-weight: 700; color: var(--ink-soft); font-size: .96rem; }
.trustband__item .ico { color: var(--amber); width: 1.5em; height: 1.5em; }
.trustband__divider { width: 1px; height: 26px; background: var(--line); }
@media (max-width: 600px) { .trustband__divider { display: none; } }

/* --- In-Page-Navigation (Detailseiten) --- */
.inpage-nav { position: sticky; top: 63px; z-index: 30; background: rgba(255,255,255,.93); backdrop-filter: saturate(150%) blur(9px); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.inpage-nav__inner { max-width: var(--container); margin: 0 auto; padding: 0 24px; display: flex; gap: 4px; overflow-x: auto; scrollbar-width: none; }
.inpage-nav__inner::-webkit-scrollbar { display: none; }
.inpage-nav a { padding: 15px 14px; font-weight: 600; font-size: .92rem; color: var(--muted); white-space: nowrap; border-bottom: 2px solid transparent; transition: color .2s ease, border-color .2s ease; }
.inpage-nav a:hover { color: var(--ink); text-decoration: none; }
.inpage-nav a.is-active { color: var(--green-deep); border-bottom-color: var(--green); }
@media (max-width: 720px) { .inpage-nav { display: none; } }

/* --- Detail-Layout: Inhalt + Sticky-Aside --- */
.detail { display: grid; grid-template-columns: 1fr 340px; gap: 50px; align-items: start; }
@media (max-width: 980px) { .detail { grid-template-columns: 1fr; gap: 30px; } }
.detail__main > .detail-sec { padding: 44px 0; border-bottom: 1px solid var(--line); }
.detail__main > .detail-sec:first-child { padding-top: 6px; }
.detail__main > .detail-sec:last-child { border-bottom: none; }
.detail__main .section__title { font-size: clamp(1.5rem, 2.6vw, 1.9rem); }
.detail .detail-sec > .section__kicker { margin-top: 0; }
.detail .steps { grid-template-columns: repeat(2, 1fr); }
@media (max-width: 560px) { .detail .steps { grid-template-columns: 1fr; } }
.detail__aside { display: grid; gap: 18px; position: sticky; top: 128px; }
@media (max-width: 980px) { .detail__aside { position: static; } }
.aside-card { background: #fff; border: 1px solid var(--line); border-radius: var(--radius-lg); box-shadow: var(--shadow); padding: 24px; }
.aside-card--accent { background: var(--ink); color: #fff; }
.aside-card--accent h3, .aside-card--accent p { color: #fff; }
.aside-card h3 { font-size: 1.15rem; margin: 0 0 .7em; }
.aside-card .btn { width: 100%; justify-content: center; }
/* Ghost-Button auf dunkler Accent-Karte: heller Text/Rahmen (sonst dunkel auf dunkel = unsichtbar) */
.aside-card--accent .btn--ghost { color: #fff; border-color: rgba(255,255,255,.34); }
.aside-card--accent .btn--ghost:hover { color: #fff; background: rgba(255,255,255,.1); border-color: #fff; }
.aside-facts { list-style: none; padding: 0; margin: 0; display: grid; gap: 14px; }
.aside-facts li { display: flex; align-items: flex-start; gap: 12px; }
.aside-facts .ico { color: var(--green); flex: none; margin-top: 2px; }
.aside-facts strong { display: block; color: var(--ink); font-size: .96rem; }
.aside-facts span { color: var(--muted); font-size: .88rem; }

/* --- Pre-Footer-CTA-Band --- */
.prefooter { background: var(--green-tint); border-top: 1px solid var(--line); }
.prefooter__inner { max-width: var(--container); margin: 0 auto; padding: 52px 24px; display: grid; grid-template-columns: 1.5fr auto; gap: 30px; align-items: center; }
@media (max-width: 760px) { .prefooter__inner { grid-template-columns: 1fr; } }
.prefooter__kicker { font-weight: 700; font-size: .78rem; letter-spacing: .12em; text-transform: uppercase; color: var(--amber-deep); margin: 0 0 .5em; }
.prefooter__title { font-size: clamp(1.5rem, 2.7vw, 2.1rem); margin: 0 0 .3em; }
.prefooter__text { color: var(--muted); margin: 0; max-width: 54ch; }
.prefooter__actions { display: flex; flex-wrap: wrap; gap: 12px; }

/* --- Fokus-Politur --- */
.card:focus-visible, .route:focus-visible, .pest:focus-visible, .verzeichnis a:focus-visible, .quickhelp__router a:focus-visible, .tags a:focus-visible { outline: 3px solid var(--amber); outline-offset: 3px; }
