/*!
Theme Name: SV Ehret 2026
Theme URI: https://sv-ehret.de
Author: Andreas Ehret Sachverstaendigenbuero
Author URI: https://sv-ehret.de
Description: Custom Theme fuer das Sachverstaendigenbuero Ehret. Single-Page-Architektur mit Anker-Navigation. Design-Tokens basieren auf dem Hi-Fi-Mockup-Handoff vom 2026-05-02. Drei Schriften (Source Serif 4 / Inter Tight / JetBrains Mono), OKLCH-Farben, gedaempfte Slate-Blau-Akzentfarbe.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
Tested up to: 6.9
License: GPL v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: sv-ehret-2026
*/

/* Lokal gehostete Schriften — keine externen Requests, DSGVO-konform */

@font-face {
  font-family: 'Inter Tight';
  font-weight: 300;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/inter-tight-w300-normal-91662.woff2') format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
@font-face {
  font-family: 'Inter Tight';
  font-weight: 300;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/inter-tight-w300-normal-83117.woff2') format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Inter Tight';
  font-weight: 300;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/inter-tight-w300-normal-68257.woff2') format('woff2');
  unicode-range: U+1F00-1FFF;
}
@font-face {
  font-family: 'Inter Tight';
  font-weight: 300;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/inter-tight-w300-normal-7897.woff2') format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
@font-face {
  font-family: 'Inter Tight';
  font-weight: 300;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/inter-tight-w300-normal-33536.woff2') format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'Inter Tight';
  font-weight: 300;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/inter-tight-w300-normal-96552.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Inter Tight';
  font-weight: 300;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/inter-tight-w300-normal-16592.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Inter Tight';
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/inter-tight-w400-normal-91662.woff2') format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
@font-face {
  font-family: 'Inter Tight';
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/inter-tight-w400-normal-83117.woff2') format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Inter Tight';
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/inter-tight-w400-normal-68257.woff2') format('woff2');
  unicode-range: U+1F00-1FFF;
}
@font-face {
  font-family: 'Inter Tight';
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/inter-tight-w400-normal-7897.woff2') format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
@font-face {
  font-family: 'Inter Tight';
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/inter-tight-w400-normal-33536.woff2') format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'Inter Tight';
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/inter-tight-w400-normal-96552.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Inter Tight';
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/inter-tight-w400-normal-16592.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Inter Tight';
  font-weight: 500;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/inter-tight-w500-normal-91662.woff2') format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
@font-face {
  font-family: 'Inter Tight';
  font-weight: 500;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/inter-tight-w500-normal-83117.woff2') format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Inter Tight';
  font-weight: 500;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/inter-tight-w500-normal-68257.woff2') format('woff2');
  unicode-range: U+1F00-1FFF;
}
@font-face {
  font-family: 'Inter Tight';
  font-weight: 500;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/inter-tight-w500-normal-7897.woff2') format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
@font-face {
  font-family: 'Inter Tight';
  font-weight: 500;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/inter-tight-w500-normal-33536.woff2') format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'Inter Tight';
  font-weight: 500;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/inter-tight-w500-normal-96552.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Inter Tight';
  font-weight: 500;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/inter-tight-w500-normal-16592.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Inter Tight';
  font-weight: 600;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/inter-tight-w600-normal-91662.woff2') format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
@font-face {
  font-family: 'Inter Tight';
  font-weight: 600;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/inter-tight-w600-normal-83117.woff2') format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Inter Tight';
  font-weight: 600;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/inter-tight-w600-normal-68257.woff2') format('woff2');
  unicode-range: U+1F00-1FFF;
}
@font-face {
  font-family: 'Inter Tight';
  font-weight: 600;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/inter-tight-w600-normal-7897.woff2') format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
@font-face {
  font-family: 'Inter Tight';
  font-weight: 600;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/inter-tight-w600-normal-33536.woff2') format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'Inter Tight';
  font-weight: 600;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/inter-tight-w600-normal-96552.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Inter Tight';
  font-weight: 600;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/inter-tight-w600-normal-16592.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Inter Tight';
  font-weight: 700;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/inter-tight-w700-normal-91662.woff2') format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
@font-face {
  font-family: 'Inter Tight';
  font-weight: 700;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/inter-tight-w700-normal-83117.woff2') format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Inter Tight';
  font-weight: 700;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/inter-tight-w700-normal-68257.woff2') format('woff2');
  unicode-range: U+1F00-1FFF;
}
@font-face {
  font-family: 'Inter Tight';
  font-weight: 700;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/inter-tight-w700-normal-7897.woff2') format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
@font-face {
  font-family: 'Inter Tight';
  font-weight: 700;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/inter-tight-w700-normal-33536.woff2') format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'Inter Tight';
  font-weight: 700;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/inter-tight-w700-normal-96552.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Inter Tight';
  font-weight: 700;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/inter-tight-w700-normal-16592.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/jetbrains-mono-w400-normal-73962.woff2') format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/jetbrains-mono-w400-normal-35658.woff2') format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/jetbrains-mono-w400-normal-57942.woff2') format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/jetbrains-mono-w400-normal-46527.woff2') format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/jetbrains-mono-w400-normal-86754.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/jetbrains-mono-w400-normal-27761.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-weight: 500;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/jetbrains-mono-w500-normal-73962.woff2') format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-weight: 500;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/jetbrains-mono-w500-normal-35658.woff2') format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-weight: 500;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/jetbrains-mono-w500-normal-57942.woff2') format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-weight: 500;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/jetbrains-mono-w500-normal-46527.woff2') format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-weight: 500;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/jetbrains-mono-w500-normal-86754.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-weight: 500;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/jetbrains-mono-w500-normal-27761.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Source Serif 4';
  font-weight: 400;
  font-style: italic;
  font-display: swap;
  src: url('assets/fonts/source-serif-4-w400-italic-25565.woff2') format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
@font-face {
  font-family: 'Source Serif 4';
  font-weight: 400;
  font-style: italic;
  font-display: swap;
  src: url('assets/fonts/source-serif-4-w400-italic-13434.woff2') format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Source Serif 4';
  font-weight: 400;
  font-style: italic;
  font-display: swap;
  src: url('assets/fonts/source-serif-4-w400-italic-19697.woff2') format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
@font-face {
  font-family: 'Source Serif 4';
  font-weight: 400;
  font-style: italic;
  font-display: swap;
  src: url('assets/fonts/source-serif-4-w400-italic-81612.woff2') format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'Source Serif 4';
  font-weight: 400;
  font-style: italic;
  font-display: swap;
  src: url('assets/fonts/source-serif-4-w400-italic-8310.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Source Serif 4';
  font-weight: 400;
  font-style: italic;
  font-display: swap;
  src: url('assets/fonts/source-serif-4-w400-italic-79261.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Source Serif 4';
  font-weight: 300;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/source-serif-4-w300-normal-27520.woff2') format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
@font-face {
  font-family: 'Source Serif 4';
  font-weight: 300;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/source-serif-4-w300-normal-15681.woff2') format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Source Serif 4';
  font-weight: 300;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/source-serif-4-w300-normal-4308.woff2') format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
@font-face {
  font-family: 'Source Serif 4';
  font-weight: 300;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/source-serif-4-w300-normal-17598.woff2') format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'Source Serif 4';
  font-weight: 300;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/source-serif-4-w300-normal-55399.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Source Serif 4';
  font-weight: 300;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/source-serif-4-w300-normal-97597.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Source Serif 4';
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/source-serif-4-w400-normal-27520.woff2') format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
@font-face {
  font-family: 'Source Serif 4';
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/source-serif-4-w400-normal-15681.woff2') format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Source Serif 4';
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/source-serif-4-w400-normal-4308.woff2') format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
@font-face {
  font-family: 'Source Serif 4';
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/source-serif-4-w400-normal-17598.woff2') format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'Source Serif 4';
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/source-serif-4-w400-normal-55399.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Source Serif 4';
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/source-serif-4-w400-normal-97597.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Source Serif 4';
  font-weight: 500;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/source-serif-4-w500-normal-27520.woff2') format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
@font-face {
  font-family: 'Source Serif 4';
  font-weight: 500;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/source-serif-4-w500-normal-15681.woff2') format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Source Serif 4';
  font-weight: 500;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/source-serif-4-w500-normal-4308.woff2') format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
@font-face {
  font-family: 'Source Serif 4';
  font-weight: 500;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/source-serif-4-w500-normal-17598.woff2') format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'Source Serif 4';
  font-weight: 500;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/source-serif-4-w500-normal-55399.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Source Serif 4';
  font-weight: 500;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/source-serif-4-w500-normal-97597.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Source Serif 4';
  font-weight: 600;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/source-serif-4-w600-normal-27520.woff2') format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
@font-face {
  font-family: 'Source Serif 4';
  font-weight: 600;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/source-serif-4-w600-normal-15681.woff2') format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Source Serif 4';
  font-weight: 600;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/source-serif-4-w600-normal-4308.woff2') format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
@font-face {
  font-family: 'Source Serif 4';
  font-weight: 600;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/source-serif-4-w600-normal-17598.woff2') format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'Source Serif 4';
  font-weight: 600;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/source-serif-4-w600-normal-55399.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Source Serif 4';
  font-weight: 600;
  font-style: normal;
  font-display: swap;
  src: url('assets/fonts/source-serif-4-w600-normal-97597.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

:root {
  --bg: oklch(0.985 0.003 250);
  --bg-2: oklch(0.965 0.005 250);
  --bg-deep: #1f2933;
  --bg-deep-2: oklch(0.27 0.012 250);     /* abgesetzte Karten auf dunklem Grund */
  --bg-deep-3: oklch(0.225 0.012 250);    /* noch tiefer abgesetzt */
  --bg-deep-hover: oklch(0.31 0.013 250); /* Hover-Tint dunkle Karten */
  --rule-deep: oklch(0.34 0.012 250);     /* Trennlinien auf dunklem Grund */
  --ink-on-deep: #e7eaee;                 /* Primärtext auf dunkel (Kontrast ~12:1) */
  --ink-on-deep-2: #b9bfc7;               /* Sekundärtext auf dunkel (~7:1) */
  --ink-on-deep-3: #8a929c;               /* nur Deko/Großschrift auf dunkel (~3.3:1) */
  --ink: #2b3038;
  --ink-2: #4a4f57;
  --ink-3: #6b7079;  /* WCAG-AA: ~4.85:1 auf --bg (vorher #90949c ~2.5:1) */
  --rule: oklch(0.88 0.005 250);
  --rule-2: oklch(0.93 0.004 250);
  --accent: #407aa4;
  --accent-ink: #2f5d80;
  --serif: "Source Serif 4", "Iowan Old Style", Georgia, serif;
  --sans: "Inter Tight", "Helvetica Neue", Helvetica, Arial, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, monospace;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 88px; }
html, body { margin: 0; padding: 0; }

/* Globaler Fokus-Ring (WCAG 2.1 SC 2.4.7). Komponenten mit eigenem :focus-visible-Style überschreiben das. */
:where(a, button, input, select, textarea, summary, [tabindex]):focus-visible {
  outline: 2px solid var(--accent-ink);
  outline-offset: 3px;
  border-radius: 2px;
}
body { background: var(--bg); color: var(--ink); font-family: var(--sans); font-size: 17px; line-height: 1.55; -webkit-font-smoothing: antialiased; }
.wrap { max-width: 1280px; margin: 0 auto; padding: 0 40px; }
a { color: inherit; }
img { max-width: 100%; height: auto; display: block; }

/* Screenreader-only + Skip-Link (WCAG 2.4.1 Bypass Blocks) */
.screen-reader-text { position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.skip-link:focus { position: fixed; top: 12px; left: 12px; z-index: 200; width: auto; height: auto; clip: auto; margin: 0; padding: 12px 18px; background: var(--ink); color: var(--bg); border-radius: 4px; font-family: var(--sans); font-size: 14px; }
:where(#main):focus { outline: none; }

/* nav */
.nav { position: sticky; top: 0; z-index: 50; background: color-mix(in oklab, var(--bg) 88%, transparent); backdrop-filter: saturate(140%) blur(14px); border-bottom: 1px solid var(--rule-2); }
.nav-inner { display: flex; align-items: center; justify-content: space-between; height: 72px; max-width: 1280px; margin: 0 auto; padding: 0 40px; }
.brand { display: flex; align-items: center; gap: 14px; text-decoration: none; color: inherit; }
.brand-logo { height: 44px; width: auto; display: block; }
.brand-text { display: flex; flex-direction: column; line-height: 1.1; }
.brand-name { font-family: var(--serif); font-weight: 500; font-size: 18px; line-height: 1.1; }
.brand-sub { font-size: 11px; color: var(--ink-3); letter-spacing: 0.08em; text-transform: uppercase; font-weight: 500; margin-top: 2px; }
.nav-right { display: flex; align-items: center; gap: 28px; }
.nav-links { display: flex; align-items: center; gap: 28px; font-size: 14px; font-weight: 500; }
.nav-links a { color: var(--ink-2); text-decoration: none; }
.nav-links a:hover { color: var(--accent-ink); }
.nav-links a[aria-current="page"] { color: var(--accent-ink); }
.nav-links a[aria-current="page"]::after { content: ""; display: block; height: 1.5px; background: var(--accent); margin-top: 3px; }

/* Leistungen-Dropdown */
.nav-dd { position: relative; }
.nav-dd-toggle { font: inherit; font-size: 14px; font-weight: 500; color: var(--ink-2); background: none; border: none; padding: 0; margin: 0; cursor: pointer; display: inline-flex; align-items: center; gap: 6px; }
.nav-dd-toggle:hover, .nav-dd.is-active .nav-dd-toggle { color: var(--accent-ink); }
.nav-dd.is-active .nav-dd-toggle::after { content: ""; display: block; position: absolute; left: 0; right: 18px; bottom: -6px; height: 1.5px; background: var(--accent); }
.nav-dd-caret { font-size: 10px; transition: transform .15s ease; }
.nav-dd-menu { position: absolute; top: calc(100% + 12px); left: 50%; transform: translateX(-50%); min-width: 250px; background: var(--bg); border: 1px solid var(--rule); border-radius: 10px; padding: 8px; flex-direction: column; gap: 0; display: none; z-index: 60; }
/* unsichtbare Hover-Brücke über die 12px-Lücke, damit der Hover nicht abreißt */
.nav-dd-menu::before { content: ""; position: absolute; left: 0; right: 0; top: -16px; height: 16px; }
.nav-dd:hover .nav-dd-menu, .nav-dd:focus-within .nav-dd-menu, .nav-dd.open .nav-dd-menu { display: flex; }
.nav-dd:hover .nav-dd-caret, .nav-dd.open .nav-dd-caret { transform: rotate(180deg); }
.nav-dd-menu a { padding: 10px 14px; border-radius: 6px; white-space: nowrap; color: var(--ink-2); }
.nav-dd-menu a:hover { background: var(--bg-2); color: var(--accent-ink); }
.nav-dd-menu a[aria-current="page"] { color: var(--accent-ink); }
.nav-dd-menu a[aria-current="page"]::after { display: none; }
@media (max-width: 980px) {
  .nav-dd, .nav-dd-toggle { width: 100%; }
  .nav-dd-toggle { justify-content: space-between; padding: 14px 20px; font-size: 16px; border-bottom: 1px solid var(--rule-2); }
  .nav-dd.is-active .nav-dd-toggle::after { display: none; }
  .nav-dd-menu { position: static; transform: none; border: none; border-radius: 0; padding: 0; min-width: 0; background: var(--bg-2); }
  .nav-dd-menu::before { display: none; }
  .nav-dd-menu a { padding: 12px 20px 12px 36px; border-bottom: 1px solid var(--rule-2); border-radius: 0; font-size: 15px; }
  .nav-dd:hover .nav-dd-menu, .nav-dd:focus-within .nav-dd-menu { display: none; }
  .nav-dd.open .nav-dd-menu { display: flex; }
}

/* Sticky Sub-Navigation (lange Detailseiten, z. B. Gutachten) */
.subnav { position: sticky; top: 72px; z-index: 40; background: color-mix(in oklab, var(--bg) 92%, transparent); backdrop-filter: saturate(140%) blur(10px); border-bottom: 1px solid var(--rule-2); }
.subnav .wrap { display: flex; gap: 28px; padding-top: 13px; padding-bottom: 13px; overflow-x: auto; scrollbar-width: none; }
.subnav .wrap::-webkit-scrollbar { display: none; }
.subnav a { font-family: var(--mono); font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink-2); text-decoration: none; white-space: nowrap; padding: 4px 0; border-bottom: 2px solid transparent; }
.subnav a:hover { color: var(--accent-ink); }
.subnav a.is-active { color: var(--accent-ink); border-bottom-color: var(--accent); }
html.has-subnav { scroll-padding-top: 124px; }
@media (max-width: 600px) {
  .subnav { top: 64px; }
  html.has-subnav { scroll-padding-top: 112px; }
}
.nav-cta { background: var(--ink); color: var(--bg); padding: 10px 18px; border-radius: 999px; font-size: 14px; font-weight: 500; text-decoration: none; display: inline-flex; align-items: center; gap: 8px; }
.nav-cta .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--accent); }
.nav-cta:hover { background: var(--accent-ink); }
/* Burger-Toggle: nur mobil sichtbar */
.nav-toggle { display: none; align-items: center; justify-content: center; width: 44px; height: 44px; padding: 0; background: none; border: none; cursor: pointer; color: var(--ink); }
.nav-toggle-box { position: relative; width: 22px; height: 16px; display: block; }
.nav-toggle-bar, .nav-toggle-bar::before, .nav-toggle-bar::after { content: ""; position: absolute; left: 0; width: 22px; height: 2px; background: currentColor; transition: transform 0.2s ease, opacity 0.2s ease; }
.nav-toggle-bar { top: 7px; }
.nav-toggle-bar::before { top: -7px; }
.nav-toggle-bar::after { top: 7px; }
.nav-toggle[aria-expanded="true"] .nav-toggle-bar { background: transparent; }
.nav-toggle[aria-expanded="true"] .nav-toggle-bar::before { transform: translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] .nav-toggle-bar::after { transform: translateY(-7px) rotate(-45deg); }
@media (max-width: 980px) {
  .nav-toggle { display: inline-flex; }
  .nav-links { position: absolute; top: 100%; left: 0; right: 0; flex-direction: column; align-items: stretch; gap: 0; background: var(--bg); border-bottom: 1px solid var(--rule); padding: 8px 0; display: none; }
  .nav-links.open { display: flex; }
  .nav-links a { padding: 14px 20px; font-size: 16px; border-bottom: 1px solid var(--rule-2); }
  .nav-links a:last-child { border-bottom: none; }
}
@media (max-width: 600px) {
  html { scroll-padding-top: 72px; }
  .brand-text { display: none; }
  .nav-right { gap: 12px; }
  .nav-cta { display: none; }
  .nav-inner { padding: 0 16px; height: 64px; }
}

/* Mobile: lange deutsche Komposita brechen lassen + Hero-Text-Skalierung */
@media (max-width: 600px) {
  body { font-size: 16px; }
  .wrap, .nav-inner { padding: 0 20px !important; }
  .hero { padding: 48px 0 56px; }
  /* Universelle Wortumbrüche für alle Text-Container im Mobile */
  body, body h1, body h2, body h3, body h4, body p, body li, body a, body span, body strong, body em,
  .hero h1, .section-title, .focus-card h3, .svc h3, .principle-name,
  .hero-lede, .section-lede, .svc-desc, .principle-desc, .aud p,
  .pkg h3, .sit-title, .voice-quote, .scenario-body,
  .footer p, .footer ul li, .contact h2, .contact p {
    overflow-wrap: break-word;
    word-wrap: break-word;
    hyphens: auto;
    -webkit-hyphens: auto;
    -ms-hyphens: auto;
  }
  .hero h1 { font-size: clamp(34px, 8.5vw, 52px) !important; }
  .section-title { font-size: clamp(26px, 6.5vw, 40px) !important; }
  .hero-lede { font-size: 16px; max-width: 100%; }
  .section-lede { font-size: 15px; max-width: 100%; }
  .section { padding: 60px 0; }
  .section-head { margin-bottom: 32px; gap: 24px; }
  .hero-cta-row { flex-direction: column; align-items: stretch; }
  .hero-cta-row .btn { justify-content: center; }
  .springboard { padding: 32px 24px; }
  .springboard-text { font-size: 18px; max-width: 100%; }
  .clients-grid { grid-template-columns: repeat(2, 1fr); }
  .footer-grid { grid-template-columns: 1fr; gap: 32px; }
  .footer-bottom { flex-direction: column; gap: 12px; align-items: flex-start; }
  .portrait-tag { right: -8px; bottom: -16px; padding: 16px 18px; max-width: calc(100% - 24px); }
  .portrait-tag .label { font-size: 9px; }
  .portrait-tag .name { font-size: 18px; }
  .portrait-tag .role { font-size: 11px; }
  /* Forminator mobile */
  .forminator-custom-form input, .forminator-custom-form select, .forminator-custom-form textarea { font-size: 16px !important; /* verhindert iOS-Zoom */ }
  /* Kontakt + Hero-Meta layouts */
  .contact, .vg-hero-grid, .trust-grid, .contact-row { grid-template-columns: 1fr !important; gap: 16px; }
  .contact-card { padding: 24px; }
  .hero-meta { padding: 24px; }
  .hero-meta .row { grid-template-columns: 1fr; gap: 4px; }
  /* Standards-Liste 1-spaltig */
  .standards-list { grid-template-columns: 1fr !important; }
  /* Audience-Cards 1-spaltig statt 2x2 */
  .audience-grid { grid-template-columns: 1fr !important; }
  .principles { grid-template-columns: 1fr !important; }
  .principle { border-right: none; }
  /* Services-Container vertikal */
  .services-v2 { grid-template-columns: 1fr !important; }
  .col-side { grid-template-rows: auto auto !important; }
  /* svc-split Doppel-Disziplin: vertical stack */
  .svc-split { grid-template-columns: 1fr !important; gap: 16px; }
  .svc-bridge { flex-direction: row; padding: 4px 0; }
  .svc-bridge-line { width: auto; height: 1px; }
  /* Padding der Karten kleiner */
  .svc, .focus-card, .svc-hero { padding: 24px; }
  .svc-hero h3 { font-size: 28px; }
}

/* Defensiver Schutz vor horizontalem Overflow. Nur auf html (nicht body),
   damit body nicht zum Scroll-Container wird und die Sticky-Nav/Scroll-Anchoring
   nicht gestört werden. Bekannte Overhang-Quelle: .portrait-tag (right:-28px),
   per Breakpoint-Overrides unten auf den Gutter begrenzt. */
html { overflow-x: hidden; }

/* buttons */
.btn { display: inline-flex; align-items: center; gap: 10px; padding: 14px 22px; border-radius: 999px; font-size: 15px; font-weight: 500; text-decoration: none; transition: all .18s; cursor: pointer; border: none; }
.btn-primary { background: var(--ink); color: var(--bg); }
.btn-primary:hover { background: var(--accent-ink); transform: translateY(-1px); }
.btn-ghost { background: transparent; color: var(--ink); border: 1px solid var(--rule); }
.btn-ghost:hover { border-color: var(--ink); }
.btn .arrow { transition: transform .18s; }
.btn:hover .arrow { transform: translateX(3px); }

/* hero */
.hero { padding: 80px 0 100px; }
.hero-grid { display: grid; grid-template-columns: 1.15fr 1fr; gap: 80px; align-items: end; }
.eyebrow { display: inline-flex; align-items: center; gap: 10px; font-family: var(--mono); font-size: 12px; letter-spacing: 0.06em; color: var(--ink-3); text-transform: uppercase; margin-bottom: 28px; }
.eyebrow::before { content: ""; width: 28px; height: 1px; background: var(--ink-3); }
.hero h1 { font-family: var(--serif); font-size: clamp(48px, 6.4vw, 92px); font-weight: 400; line-height: 0.98; letter-spacing: -0.025em; margin: 0 0 32px; text-wrap: balance; }
.hero h1 em { font-style: italic; font-weight: 400; color: var(--accent-ink); }
.hero-lede { font-size: 19px; line-height: 1.55; color: var(--ink-2); max-width: 52ch; margin: 0 0 32px; }
.hero-cta-row { display: flex; gap: 14px; align-items: center; flex-wrap: wrap; }
.hero-fineprint { margin-top: 18px; font-family: var(--mono); font-size: 12px; color: var(--ink-3); letter-spacing: 0.04em; }
.portrait { aspect-ratio: 4/5; width: 100%; border-radius: 4px; overflow: hidden; border: 1px solid var(--rule); }
.portrait img { width: 100%; height: 100%; object-fit: cover; display: block; }
.portrait-stack { position: relative; }
.portrait-tag { position: absolute; bottom: -28px; right: -28px; background: var(--ink); color: var(--bg); padding: 22px 26px; border-radius: 4px; max-width: 320px; }
.portrait-tag .label { font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; opacity: 0.6; margin-bottom: 10px; line-height: 1.3; }
.portrait-tag .name { font-family: var(--serif); font-size: 22px; line-height: 1.15; font-weight: 400; }
.portrait-tag .role { font-size: 12px; color: oklch(0.78 0.005 80); margin-top: 8px; line-height: 1.4; }

/* generic section header */
.section { padding: 110px 0; }
.section-bg { background: var(--bg-2); border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); }
.section-deep { background: var(--bg-deep); color: var(--bg); }
.section-deep .section-tag { color: var(--ink-on-deep-3); }
.section-deep .section-title { color: var(--bg); }
.section-deep .section-lede { color: var(--ink-on-deep-2); }
.section-head { display: grid; grid-template-columns: 1fr 2fr; gap: 80px; margin-bottom: 56px; align-items: end; }
/* Section-Head ohne Lede: Headline darf die volle Breite nutzen statt in der 1fr-Spalte zu klemmen. */
.section-head--solo { grid-template-columns: 1fr; }
.section-tag { font-family: var(--mono); font-size: 12px; letter-spacing: 0.08em; color: var(--ink-3); text-transform: uppercase; }
.section-title { font-family: var(--serif); font-size: clamp(36px, 4.5vw, 60px); font-weight: 400; line-height: 1.02; letter-spacing: -0.02em; margin: 16px 0 0; text-wrap: balance; }
.section-lede { font-size: 18px; color: var(--ink-2); line-height: 1.55; max-width: 50ch; }

/* audience */
.audience-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; border-top: 1px solid var(--rule); border-left: 1px solid var(--rule); }
.aud { padding: 36px 28px 32px; border-right: 1px solid var(--rule); border-bottom: 1px solid var(--rule); background: var(--bg); display: flex; flex-direction: column; text-decoration: none; color: inherit; min-height: 360px; transition: background .25s; }
.aud:hover { background: var(--bg-2); }
.aud-prio { background: var(--bg-deep); color: var(--bg); }
.aud-prio:hover { background: var(--bg-deep-2); }
.aud-rank { font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-3); margin-bottom: 24px; display: inline-flex; align-items: center; gap: 8px; }
.aud-rank::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--ink-3); }
.aud-prio .aud-rank { color: var(--accent); }
.aud-prio .aud-rank::before { background: var(--accent); }
.aud-num { font-family: var(--serif); font-size: 14px; color: var(--ink-3); letter-spacing: 0.04em; margin-bottom: 18px; }
.aud-prio .aud-num { color: var(--ink-on-deep-3); }
.aud-icon { width: 36px; height: 36px; color: var(--accent-ink); margin-bottom: 16px; flex-shrink: 0; align-self: flex-start; display: block; }
.aud-icon svg { width: 36px !important; height: 36px !important; display: block; }
.aud-prio .aud-icon { color: var(--accent); }
.aud h3 { font-family: var(--serif); font-size: 30px; font-weight: 400; line-height: 1.05; letter-spacing: -0.015em; margin: 0 0 18px; }
.aud-prio h3 { color: var(--bg); }
.aud p { font-size: 14px; color: var(--ink-2); line-height: 1.6; margin: 0 0 24px; flex: 1; }
.aud-prio p { color: oklch(0.82 0.008 250); }
.aud-prio p strong { color: var(--bg); }
.aud-marker { display: flex; align-items: center; gap: 10px; padding-top: 14px; border-top: 1px solid var(--rule-2); font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-3); font-weight: 500; }
.aud-prio .aud-marker { border-color: var(--rule-deep); color: var(--ink-on-deep-2); }
.aud-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--ink-3); }
.aud-prio .aud-dot { background: var(--accent); }

/* Sprungbrett-CTA-Bar */
.springboard { background: var(--ink); color: var(--bg); padding: 56px 64px; border-radius: 6px; margin-top: 48px; display: grid; grid-template-columns: 1.4fr auto; gap: 48px; align-items: center; position: relative; overflow: hidden; }
.springboard::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 4px; background: var(--accent); }
.springboard-text { font-family: var(--serif); font-size: 28px; line-height: 1.2; letter-spacing: -0.015em; font-weight: 400; max-width: 32ch; }
.springboard-text strong { font-style: italic; color: var(--accent); font-weight: 400; }
.springboard-cta { display: flex; flex-direction: column; gap: 14px; align-items: flex-end; }
.springboard-meta { font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-on-deep-3); }
.springboard-btn { display: inline-flex; align-items: center; gap: 12px; background: var(--accent); color: var(--bg); padding: 16px 26px; border-radius: 999px; font-size: 16px; font-weight: 500; text-decoration: none; transition: background .2s, transform .2s; }
.springboard-btn:hover { background: oklch(0.6 0.1 240); transform: translateY(-1px); }
.springboard-btn .arrow { transition: transform .18s; }
.springboard-btn:hover .arrow { transform: translateX(3px); }
@media (max-width: 980px) {
  .springboard { grid-template-columns: 1fr; padding: 40px 32px; gap: 28px; }
  .springboard-cta { align-items: flex-start; }
  .springboard-text { font-size: 22px; }
}

/* principles */
.principles { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border-top: 1px solid var(--rule); border-left: 1px solid var(--rule); }
.principles-quad { grid-template-columns: repeat(4, 1fr); }
.principles-recap .principle { min-height: auto; padding: 28px 24px; gap: 12px; }
.principles-recap .principle-num { font-size: 14px; line-height: 1.3; color: var(--ink); }
.principles-recap .principle-foot { padding-top: 8px; }
@media (max-width: 1100px) { .principles-quad { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 700px) { .principles, .principles-quad { grid-template-columns: 1fr; } }
.principle { padding: 40px 32px; border-right: 1px solid var(--rule); border-bottom: 1px solid var(--rule); background: var(--bg); display: flex; flex-direction: column; gap: 16px; min-height: 240px; }
.principle:last-child { border-right: none; }
.principle-icon { width: 40px; height: 40px; color: var(--accent-ink); margin-bottom: 4px; }
.principle-icon svg { width: 100%; height: 100%; }
.principle-num { font-family: var(--mono); font-size: 11px; color: var(--accent); letter-spacing: 0.1em; }
.principle-name { font-family: var(--serif); font-size: 30px; font-weight: 400; line-height: 1.05; letter-spacing: -0.015em; }
.principle-name em { font-style: italic; color: var(--accent-ink); }
.principle-desc { font-size: 15px; color: var(--ink-2); line-height: 1.6; }
.principle-list { list-style: none; padding: 0; margin: 8px 0 0; }
.principle-list li { font-size: 13px; line-height: 1.5; color: var(--ink); padding: 8px 0 8px 18px; border-bottom: 1px solid var(--rule-2); position: relative; }
.principle-list li:last-child { border-bottom: none; }
.principle-list li::before { content: "—"; position: absolute; left: 0; top: 8px; color: var(--accent); font-family: var(--mono); }
.principle-foot { margin-top: auto; padding-top: 16px; font-family: var(--mono); font-size: 11px; letter-spacing: 0.06em; color: var(--accent-ink); text-transform: uppercase; }

/* services — asymmetric: 1 dominant + 2 flanking */
.services-v2 { display: grid; grid-template-columns: 1.55fr 1fr; gap: 24px; align-items: stretch; }
.services-v2 .col-side { display: grid; grid-template-rows: 1fr 1fr; gap: 24px; }

.svc { background: var(--bg); border: 1px solid var(--rule); border-radius: 6px; padding: 36px; display: flex; flex-direction: column; text-decoration: none; color: inherit; transition: border-color .2s, transform .2s, box-shadow .2s; position: relative; overflow: hidden; }
.svc-icon { width: 40px; height: 40px; color: var(--accent-ink); flex-shrink: 0; align-self: flex-start; display: block; margin-bottom: 12px; }
.svc-icon svg { width: 40px !important; height: 40px !important; display: block; }
.svc:hover { border-color: var(--ink); }
.svc-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 20px; }
.svc-num { font-family: var(--mono); font-size: 11px; color: var(--ink-3); letter-spacing: 0.1em; text-transform: uppercase; }
.svc-tag { font-family: var(--mono); font-size: 10px; color: var(--accent-ink); letter-spacing: 0.1em; text-transform: uppercase; padding: 4px 10px; background: oklch(0.94 0.025 240); border-radius: 999px; }
.svc h3 { font-family: var(--serif); font-size: 30px; font-weight: 400; line-height: 1.05; letter-spacing: -0.015em; margin: 0 0 14px; }
.svc h3 em { font-style: italic; color: var(--accent-ink); }
.svc-desc { font-size: 15px; color: var(--ink-2); line-height: 1.55; margin: 0 0 24px; }
.svc-foot { margin-top: auto; padding-top: 20px; border-top: 1px solid var(--rule-2); display: flex; justify-content: space-between; align-items: baseline; }
.svc-price { font-family: var(--serif); font-size: 22px; color: var(--ink); letter-spacing: -0.01em; }
.svc-price .from { font-family: var(--mono); font-size: 10px; color: var(--ink-3); letter-spacing: 0.1em; text-transform: uppercase; margin-right: 6px; }
.svc-price-add { font-family: var(--mono); font-size: 12px; color: var(--accent-ink); letter-spacing: 0.04em; white-space: nowrap; }
.svc-link { font-family: var(--mono); font-size: 11px; color: var(--ink); letter-spacing: 0.08em; text-transform: uppercase; display: inline-flex; align-items: center; gap: 8px; }
.svc:hover .svc-link { color: var(--accent-ink); }
.svc-link .arr { transition: transform .15s; }
.svc:hover .svc-link .arr { transform: translateX(3px); }

/* dominant card */
.svc-hero { background: var(--bg-deep); color: var(--bg); border-color: var(--bg-deep); padding: 48px; }
.svc-hero:hover { border-color: var(--bg-deep); transform: translateY(-2px); }
.svc-hero .svc-num { color: var(--ink-on-deep-3); }
.svc-hero h3 { font-size: 44px; line-height: 1.02; margin-bottom: 18px; max-width: 14ch; }
.svc-hero h3 em { color: var(--accent); }
.svc-hero .svc-desc { color: var(--ink-on-deep); font-size: 16px; max-width: 42ch; }
.svc-hero .svc-foot { border-color: var(--rule-deep); }
.svc-hero .svc-price { color: var(--bg); font-size: 26px; }
.svc-hero .svc-price .from { color: var(--ink-on-deep-3); }
.svc-hero .svc-link { color: var(--bg); }
.svc-hero:hover .svc-link { color: var(--accent); }

/* feature row inside hero card */
.svc-features { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; margin: 0 0 28px; padding: 24px 0; border-top: 1px solid var(--rule-deep); border-bottom: 1px solid var(--rule-deep); }
.svc-feat { padding: 0 18px; border-right: 1px solid var(--rule-deep); }
.svc-feat:first-child { padding-left: 0; }
.svc-feat:last-child { border-right: none; padding-right: 0; }
.svc-feat-k { font-family: var(--mono); font-size: 10px; color: var(--ink-on-deep-3); letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 6px; display: block; }
.svc-feat-v { font-family: var(--serif); font-size: 17px; color: var(--bg); line-height: 1.25; display: block; }

/* doppel-disziplin split */
.svc-split { display: grid; grid-template-columns: 1fr 56px 1fr; gap: 0; margin: 28px 0 24px; }
.svc-half { background: var(--bg-deep-2); border: 1px solid var(--rule-deep); border-radius: 4px; padding: 24px 22px; display: flex; flex-direction: column; gap: 12px; text-decoration: none; color: var(--bg); transition: background .2s, transform .2s; position: relative; }
.svc-half:hover { background: var(--bg-deep-hover); transform: translateY(-2px); }
.svc-half-num { position: absolute; top: 16px; right: 18px; font-family: var(--mono); font-size: 11px; color: var(--accent); letter-spacing: 0.1em; }
.svc-half-name { font-family: var(--serif); font-size: 24px; font-weight: 400; line-height: 1.05; letter-spacing: -0.015em; color: var(--bg); }
.svc-half-list { font-size: 13px; color: var(--ink-on-deep-2); line-height: 1.5; flex: 1; }
.svc-half-meta { display: flex; justify-content: space-between; align-items: baseline; padding-top: 12px; border-top: 1px solid var(--rule-deep); font-family: var(--serif); font-size: 18px; color: var(--bg); }
.svc-half-meta .from { font-family: var(--mono); font-size: 10px; color: var(--ink-on-deep-3); letter-spacing: 0.1em; text-transform: uppercase; margin-right: 6px; }
.svc-half-meta .arr { font-size: 16px; color: var(--accent); transition: transform .15s; }
.svc-half:hover .svc-half-meta .arr { transform: translateX(3px); }

.svc-bridge { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px; padding: 0 8px; }
.svc-bridge-line { width: 1px; flex: 1; background: var(--rule-deep); }
.svc-bridge-label { width: 36px; height: 36px; border-radius: 50%; background: var(--accent); color: var(--bg-deep); display: grid; place-items: center; font-family: var(--serif); font-size: 22px; font-weight: 500; font-style: italic; }

.svc-price-note { display: flex; flex-direction: column; gap: 4px; }
.svc-hero .svc-price-note .svc-feat-k { color: var(--ink-on-deep-3); }
.svc-hero .svc-price-note .svc-feat-v { color: var(--ink-on-deep); }

/* small pills inside flanking cards */
.svc-pills { display: flex; flex-wrap: wrap; gap: 6px; margin: 0 0 24px; }
.svc-pill { font-size: 12px; color: var(--ink-2); padding: 5px 11px; background: var(--bg-2); border-radius: 999px; border: 1px solid var(--rule); }

@media (max-width: 980px) {
  .services-v2 { grid-template-columns: 1fr; }
  .svc-hero { padding: 32px; }
  .svc-hero h3 { font-size: 34px; }
  .svc-features { grid-template-columns: 1fr; gap: 16px; }
  .svc-feat { border-right: none; border-bottom: 1px solid var(--rule-deep); padding: 0 0 14px; }
  .svc-feat:last-child { border-bottom: none; padding-bottom: 0; }
  .svc-split { grid-template-columns: 1fr; gap: 16px; }
  .svc-bridge { flex-direction: row; padding: 4px 0; }
  .svc-bridge-line { width: auto; height: 1px; }
}

/* focus block — Verw./Gerichte */
.focus { padding: 110px 0; background: var(--bg-deep); color: var(--bg); }
.focus .section-tag { color: var(--ink-on-deep-3); }
.focus h2 { color: var(--bg); }
.focus-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; margin-top: 32px; }
.focus-card { background: var(--bg-deep-2); border: 1px solid var(--rule-deep); border-radius: 6px; padding: 36px; display: flex; flex-direction: column; gap: 18px; text-decoration: none; color: var(--bg); transition: background .2s, transform .2s; }
.focus-card:hover { background: var(--bg-deep-hover); }
.focus-card .label { font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; color: var(--accent); text-transform: uppercase; }
.focus-card .focus-icon { width: 40px; height: 40px; color: var(--accent); flex-shrink: 0; align-self: flex-start; display: block; }
.focus-card .focus-icon svg { width: 40px !important; height: 40px !important; display: block; }
.focus-card h3 { font-family: var(--serif); font-size: 32px; font-weight: 400; letter-spacing: -0.015em; margin: 0; line-height: 1.05; }
.focus-card p { font-size: 15px; color: var(--ink-on-deep); margin: 0; line-height: 1.55; }
.focus-card .link { font-family: var(--mono); font-size: 12px; letter-spacing: 0.06em; color: var(--bg); text-transform: uppercase; padding-top: 16px; border-top: 1px solid var(--rule-deep); display: flex; justify-content: space-between; }

/* trust */
.trust-grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: 64px; margin-top: 24px; }
.standards { background: var(--bg); border: 1px solid var(--rule); border-radius: 6px; padding: 36px; }
.standards h4 { font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-3); margin: 0 0 24px; font-weight: 500; }
.standards-list { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: var(--rule); border: 1px solid var(--rule); }
.std { background: var(--bg); padding: 18px 20px; }
.std-icon { width: 24px; height: 24px; color: var(--accent-ink); flex-shrink: 0; display: block; margin-bottom: 8px; }
.std-icon svg { width: 24px !important; height: 24px !important; display: block; }
.client-icon { width: 22px; height: 22px; color: var(--accent-ink); flex-shrink: 0; display: block; margin-bottom: 4px; }
.client-icon svg { width: 22px !important; height: 22px !important; display: block; }
.std-name { font-family: var(--serif); font-size: 18px; line-height: 1.15; font-weight: 400; letter-spacing: -0.01em; }
.std-desc { font-size: 12px; color: var(--ink-2); margin-top: 4px; line-height: 1.4; }
.scenarios { display: flex; flex-direction: column; gap: 16px; }
.scenario { background: var(--bg); border: 1px solid var(--rule); border-radius: 6px; padding: 24px 26px; }
.scenario-tag { font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; color: var(--accent); text-transform: uppercase; margin-bottom: 8px; }
.scenario-body { font-family: var(--serif); font-style: italic; font-size: 18px; line-height: 1.4; color: var(--ink); }
.scenario-body strong { font-style: normal; }

/* product */
.product-card { display: grid; grid-template-columns: 1fr 1.3fr; gap: 0; border: 1px solid var(--rule); border-radius: 6px; overflow: hidden; }
.product-visual { background: var(--bg-deep); color: var(--bg); padding: 48px 40px; }
.product-chip { display: inline-flex; align-items: center; gap: 8px; font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; padding: 8px 14px; background: var(--bg-deep-2); border-radius: 999px; text-transform: uppercase; color: var(--accent); margin-bottom: 32px; }
.product-chip .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--accent); }
.product-name { font-family: var(--serif); font-size: 56px; font-weight: 400; letter-spacing: -0.02em; line-height: 1; margin: 0 0 32px; }
.product-name em { font-style: italic; color: var(--accent); }
.product-meta { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; padding-top: 24px; border-top: 1px solid var(--rule-deep); }
.product-meta .k { font-family: var(--mono); font-size: 10px; letter-spacing: 0.1em; color: var(--ink-on-deep-3); text-transform: uppercase; margin-bottom: 6px; }
.product-meta .v { font-size: 14px; color: var(--bg); line-height: 1.4; }
.product-text { padding: 48px 40px; background: var(--bg); }
.product-text h3 { font-family: var(--serif); font-size: 32px; font-weight: 400; line-height: 1.1; letter-spacing: -0.015em; margin: 16px 0 20px; }
.product-text p { font-size: 16px; color: var(--ink-2); line-height: 1.6; margin: 0 0 24px; }

/* timeline */
.timeline { border-top: 1px solid var(--rule); margin-top: 32px; }
.tl-row { display: grid; grid-template-columns: 140px 1fr 1fr; gap: 48px; padding: 32px 0; border-bottom: 1px solid var(--rule-2); align-items: baseline; }
.tl-year { font-family: var(--serif); font-size: 32px; font-weight: 400; color: var(--accent); letter-spacing: -0.02em; }
.tl-title { font-family: var(--serif); font-size: 22px; font-weight: 400; color: var(--ink); line-height: 1.2; }
.tl-desc { font-size: 15px; color: var(--ink-2); line-height: 1.5; }

/* clients */
.clients-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 1px; background: var(--rule); border: 1px solid var(--rule); }
.client { background: var(--bg); padding: 22px 18px; min-height: 100px; display: flex; flex-direction: column; gap: 6px; justify-content: center; }
.client-num { font-family: var(--mono); font-size: 10px; color: var(--ink-3); letter-spacing: 0.08em; }
.client-name { font-family: var(--serif); font-size: 17px; line-height: 1.15; }
.clients-note { margin-top: 28px; font-size: 14px; color: var(--ink-2); max-width: 70ch; line-height: 1.55; font-style: italic; }

/* contact */
.contact { display: grid; grid-template-columns: 1.3fr 1fr; gap: 64px; align-items: start; }
.contact h2 { font-family: var(--serif); font-size: clamp(40px, 5vw, 64px); font-weight: 400; line-height: 1.02; letter-spacing: -0.025em; margin: 16px 0 24px; text-wrap: balance; }
.contact p { font-size: 17px; color: var(--ink-2); line-height: 1.6; margin: 0 0 28px; max-width: 50ch; }
.contact-card { background: var(--bg-2); border: 1px solid var(--rule); padding: 36px; border-radius: 4px; }
.contact-card h3 { font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-3); margin: 0 0 24px; font-weight: 500; }
/* Datenschutz-Hinweis unter dem Kontaktformular (Art. 13 DSGVO) */
.form-privacy-note { margin: 16px 0 0; font-size: 12px; line-height: 1.5; color: var(--ink-2); }
.form-privacy-note a { color: var(--accent-ink); }

/* Widerruf (§ 356a BGB) */
.widerruf-intro { max-width: 65ch; color: var(--ink-2); font-size: 17px; line-height: 1.6; margin-bottom: 32px; }
.widerruf-status { max-width: 65ch; border: 1px solid var(--rule); border-left: 4px solid var(--accent); border-radius: 4px; padding: 20px 24px; margin-bottom: 32px; }
.widerruf-status p { margin: 0; line-height: 1.55; }
.widerruf-ok { border-left-color: var(--accent); background: var(--bg-2); }
.widerruf-error { border-left-color: #b4453a; background: var(--bg-2); }
.widerruf-form { max-width: 560px; }
.widerruf-form .wf-field { margin: 0 0 20px; }
.widerruf-form label { display: block; font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-2); font-weight: 500; margin-bottom: 8px; }
.widerruf-form .wf-opt { text-transform: none; letter-spacing: 0; font-family: var(--sans); color: var(--ink-3); }
.widerruf-form input { width: 100%; background: var(--bg); border: 1px solid var(--rule); border-radius: 4px; padding: 14px 16px; font-family: var(--sans); font-size: 15px; color: var(--ink); }
.widerruf-form input:focus { border-color: var(--accent-ink); outline: none; }
.widerruf-form .btn { margin-top: 8px; }
.widerruf-note { margin-top: 16px; font-size: 12px; line-height: 1.5; color: var(--ink-2); max-width: 60ch; }
.widerruf-belehrung { max-width: 70ch; margin-bottom: 48px; padding-bottom: 40px; border-bottom: 1px solid var(--rule); }
.widerruf-belehrung h2 { font-size: 22px; margin: 0 0 8px; }
.widerruf-belehrung h3 { font-family: var(--mono); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-2); margin: 28px 0 8px; }
.widerruf-belehrung p { font-size: 15px; line-height: 1.65; color: var(--ink-2); margin: 0 0 12px; }
.widerruf-belehrung .wb-adresse { color: var(--ink); }
.widerruf-muster { border: 1px solid var(--rule); border-radius: 4px; padding: 20px 24px; background: var(--bg-2); margin-top: 12px; }
.widerruf-muster p { margin: 0 0 10px; font-size: 14px; }
/* FAQ-Akkordeon (Leistungsseiten) + verwandte Links */
.faq-list { max-width: 72ch; margin-top: 8px; border-top: 1px solid var(--rule); }
.faq-item { border-bottom: 1px solid var(--rule); }
.faq-item summary { cursor: pointer; list-style: none; padding: 18px 0; font-family: var(--serif); font-size: 19px; line-height: 1.3; color: var(--ink); display: flex; justify-content: space-between; gap: 16px; align-items: baseline; }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after { content: "+"; font-family: var(--mono); color: var(--accent-ink); font-size: 22px; line-height: 1; flex-shrink: 0; }
.faq-item[open] summary::after { content: "3"; }
.faq-item p { margin: 0 0 18px; font-size: 15px; line-height: 1.65; color: var(--ink-2); max-width: 66ch; }
.related-links { margin-top: 32px; font-size: 14px; line-height: 1.6; color: var(--ink-3); max-width: 72ch; }
.related-links a { color: var(--accent-ink); text-decoration: none; }
.related-links a:hover { text-decoration: underline; }
.hp-field { position: absolute !important; left: -9999px !important; width: 1px; height: 1px; overflow: hidden; }
/* Footer-Widerruf-Button — hervorgehoben, ständig erreichbar */
.footer-widerruf { display: inline-flex; align-items: center; gap: 8px; margin-top: 16px; padding: 10px 18px; border: 1px solid var(--ink-on-deep-2); border-radius: 999px; font-size: 13px; color: var(--ink-on-deep); text-decoration: none; }
.footer-widerruf:hover { background: var(--bg-deep-hover); border-color: var(--ink-on-deep); }

/* Buchungsformular */
.buchung-form select,
.buchung-form textarea { width: 100%; background: var(--bg); border: 1px solid var(--rule); border-radius: 4px; padding: 14px 16px; font-family: var(--sans); font-size: 15px; color: var(--ink); }
.buchung-form select:focus,
.buchung-form textarea:focus { border-color: var(--accent-ink); outline: none; }
.buchung-form .wf-check { display: flex; align-items: flex-start; gap: 10px; font-family: var(--sans); font-size: 15px; text-transform: none; letter-spacing: 0; color: var(--ink); font-weight: 400; }
.buchung-form .wf-check input { width: auto; margin-top: 3px; }
.buchung-estimate { display: flex; flex-direction: column; gap: 4px; background: var(--bg-2); border: 1px solid var(--rule); border-left: 4px solid var(--accent); border-radius: 4px; padding: 18px 22px; margin: 4px 0 24px; }
.be-label { font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-2); }
.be-amount { font-family: var(--serif); font-size: 34px; line-height: 1; color: var(--ink); }
.be-note { font-size: 13px; color: var(--ink-2); line-height: 1.5; }
.modal-buchen { margin-top: 20px; }
.svc-buchen { margin-top: 18px; align-self: flex-start; }

/* Abrechnungsgutachten — „serienmäßig enthalten"-Umfang */
.abr-umfang-wrap { margin: 32px 0 8px; padding: 28px 32px; background: var(--bg-2); border: 1px solid var(--rule); border-radius: 4px; }
.abr-umfang-tag { font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-2); margin-bottom: 18px; }
.abr-umfang-intro { font-size: 14px; line-height: 1.55; color: var(--ink-2); margin: 0 0 18px; max-width: 64ch; }
.abr-umfang { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 10px 32px; }
.abr-umfang li { position: relative; padding-left: 18px; font-size: 14px; line-height: 1.5; color: var(--ink); }
.abr-umfang li::before { content: ""; position: absolute; left: 0; top: 8px; width: 6px; height: 6px; border-radius: 50%; background: var(--accent); }

/* Querverweis Abrechnung <-> Messgeräte */
.crosslink { background: var(--bg-2); border: 1px solid var(--rule); border-left: 4px solid var(--accent); border-radius: 4px; padding: 24px 32px; }
.crosslink-tag { font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--accent-ink); margin-bottom: 10px; }
.crosslink p { margin: 0; font-size: 16px; line-height: 1.6; color: var(--ink); max-width: 80ch; }
.crosslink a { color: var(--accent-ink); text-decoration: underline; text-underline-offset: 2px; }

/* A3 — Sondergutachten (Preis auf Anfrage) */
.variant-anfrage { margin-top: 24px; background: var(--bg); border: 1px solid var(--rule); border-left: 4px solid var(--accent); border-radius: 6px; padding: 32px; display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 24px; }
.variant-anfrage .va-text { flex: 1 1 460px; }
.variant-anfrage h3 { font-family: var(--serif); font-size: 26px; font-weight: 400; letter-spacing: -0.015em; line-height: 1.1; margin: 8px 0 12px; }
.variant-anfrage p { margin: 0; font-size: 15px; line-height: 1.6; color: var(--ink-2); max-width: 70ch; }
.variant-anfrage .va-foot { display: flex; flex-direction: column; align-items: flex-start; gap: 14px; }
.variant-anfrage .device-price { font-family: var(--serif); font-size: 26px; color: var(--ink); }

/* Flächen-Kontrollaufmaß (dunkle Zusatzleistung-Sektion) */
.flaeche-body { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 40px; }
.flaeche-body p { margin: 0; font-size: 16px; line-height: 1.7; color: var(--ink-2); }
.flaeche-body strong { color: var(--ink); font-weight: 600; }
.section-deep .btn-primary { background: var(--accent); color: #fff; }
.section-deep .btn-primary:hover { background: #fff; color: var(--ink); transform: translateY(-1px); }
.contact-row { display: grid; grid-template-columns: 90px 1fr; gap: 16px; padding: 14px 0; border-bottom: 1px solid var(--rule); align-items: baseline; }
.contact-row:last-child { border-bottom: none; }
.contact-row .k { font-family: var(--mono); font-size: 11px; color: var(--ink-3); letter-spacing: 0.06em; text-transform: uppercase; }
.contact-row .v { font-size: 15px; color: var(--ink); }
.contact-row .v a { color: var(--accent-ink); text-decoration: none; }
.contact-row .v .contact-note { display: block; margin-top: 6px; font-size: 12px; line-height: 1.45; color: var(--ink-3); }

/* explainer list (kontakt) */
.explain { list-style: none; margin: 28px 0 28px; padding: 0; display: flex; flex-direction: column; gap: 0; border-top: 1px solid var(--rule); }
.explain li { display: grid; grid-template-columns: 60px 1fr; gap: 18px; align-items: baseline; padding: 18px 0; border-bottom: 1px solid var(--rule); }
.ex-num { font-family: var(--mono); font-size: 11px; color: var(--accent-ink); letter-spacing: 0.1em; }
.ex-text { font-size: 15px; color: var(--ink-2); line-height: 1.5; }
.ex-text strong { color: var(--ink); font-weight: 500; }

/* howto (privatkunden) */
.howto { background: var(--bg); border: 1px solid var(--rule); border-radius: 6px; padding: 40px; margin-bottom: 56px; }
.howto-head { display: flex; flex-direction: column; gap: 8px; margin-bottom: 32px; }
.howto-tag { font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; color: var(--accent-ink); text-transform: uppercase; }
.howto h3 { font-family: var(--serif); font-size: 32px; font-weight: 400; line-height: 1.05; letter-spacing: -0.015em; margin: 0; }
.howto-steps { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border-top: 1px solid var(--rule); }
.howto-steps-5 { grid-template-columns: repeat(5, 1fr); }
.howto-steps-4 { grid-template-columns: repeat(4, 1fr); }
.howto-steps li { padding: 28px 24px 28px 0; border-right: 1px solid var(--rule); border-bottom: 1px solid var(--rule); padding-left: 24px; display: flex; flex-direction: column; gap: 10px; }
.howto-steps li:first-child { padding-left: 0; }
.howto-steps li:last-child { border-right: none; padding-right: 0; }
.hs-icon { width: 36px; height: 36px; color: var(--accent-ink); flex-shrink: 0; align-self: flex-start; display: block; }
.hs-icon svg { width: 36px !important; height: 36px !important; display: block; }
.hs-num { width: 28px; height: 28px; border-radius: 50%; background: var(--accent); color: var(--bg); display: grid; place-items: center; font-family: var(--mono); font-size: 12px; font-weight: 500; }
.hs-title { font-family: var(--serif); font-size: 19px; line-height: 1.2; letter-spacing: -0.01em; }
.hs-when { font-style: italic; font-size: 12px; color: var(--ink-3); display: block; margin-top: 4px; font-family: var(--mono); letter-spacing: 0.04em; }
.hs-desc { font-size: 13px; color: var(--ink-2); line-height: 1.55; }
@media (max-width: 1100px) {
  .howto-steps-5 { grid-template-columns: repeat(2, 1fr); }
  .howto-steps-4 { grid-template-columns: repeat(2, 1fr); }
  .howto-steps-5 li { border-right: 1px solid var(--rule); }
  .howto-steps-5 li:nth-child(2n) { border-right: none; }
}
.howto-foot { padding-top: 20px; font-size: 14px; color: var(--ink-2); font-style: italic; }
@media (max-width: 980px) {
  .howto-steps { grid-template-columns: 1fr; }
  .howto-steps li { padding: 20px 0; border-right: none; }
}

/* footer */
.footer { background: var(--bg-deep); color: var(--ink-on-deep); padding: 64px 0 32px; }
.footer-grid { display: grid; grid-template-columns: 1.2fr 1fr 1fr 1fr; gap: 48px; padding-bottom: 48px; border-bottom: 1px solid var(--bg-deep-3); }
.footer h2 { font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-on-deep-2); margin: 0 0 16px; font-weight: 500; }
.footer ul { list-style: none; padding: 0; margin: 0; }
.footer ul li { padding: 6px 0; font-size: 14px; }
.footer a { color: var(--ink-on-deep); text-decoration: none; }
.footer a:hover { color: var(--bg); }
.footer-brand { font-family: var(--serif); font-size: 24px; font-weight: 400; letter-spacing: -0.01em; margin-bottom: 8px; color: var(--bg); }
.footer-bottom { display: flex; justify-content: space-between; align-items: center; padding-top: 32px; font-family: var(--mono); font-size: 12px; color: oklch(0.6 0.012 250); }

/* responsive */
@media (max-width: 980px) {
  .wrap, .nav-inner { padding: 0 24px; }
  .hero-grid, .section-head, .product-card, .contact, .trust-grid, .focus-grid { grid-template-columns: 1fr; gap: 40px; }
  .audience-grid, .principles, .standards-list { grid-template-columns: repeat(2, 1fr); }
  .principle:nth-child(2) { border-right: none; }
  .clients-grid, .footer-grid { grid-template-columns: repeat(2, 1fr); }
  .tl-row { grid-template-columns: 1fr; gap: 8px; }
}

/* ============================================================
   Verwaltungen / Gerichte Detail-Page (page-verwaltungen-gerichte.php)
   ============================================================ */

.crumb { padding: 28px 0 0; font-family: var(--mono); font-size: 12px; letter-spacing: 0.05em; color: var(--ink-3); text-transform: uppercase; }
.crumb a { text-decoration: none; color: var(--ink-3); }
.crumb a:hover { color: var(--accent-ink); }
.crumb .sep { margin: 0 10px; opacity: 0.5; }

.vg-hero { padding: 36px 0 80px; }
.vg-hero-grid { display: grid; grid-template-columns: 1.15fr 1fr; gap: 80px; align-items: end; }
.hero-meta { background: var(--bg-2); border: 1px solid var(--rule); padding: 32px; border-radius: 4px; }
.hero-meta .row { display: grid; grid-template-columns: 130px 1fr; gap: 20px; padding: 14px 0; border-bottom: 1px solid var(--rule); align-items: baseline; }
.hero-meta .row:last-child { border-bottom: none; }
.hero-meta .k { font-family: var(--mono); font-size: 11px; color: var(--ink-3); letter-spacing: 0.06em; text-transform: uppercase; }
.hero-meta .v { font-size: 15px; color: var(--ink); }

.pull { font-family: var(--serif); font-size: 28px; line-height: 1.25; font-style: italic; font-weight: 400; color: var(--ink); border-left: 2px solid var(--accent); padding: 8px 0 8px 28px; margin: 32px 0; max-width: 56ch; }

.situations { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border-top: 1px solid var(--rule); }
.sit { padding: 36px 28px; border-right: 1px solid var(--rule); border-bottom: 1px solid var(--rule); background: var(--bg); display: flex; flex-direction: column; gap: 14px; min-height: 220px; }
.sit-icon { width: 36px; height: 36px; color: var(--accent-ink); flex-shrink: 0; align-self: flex-start; display: block; margin-bottom: 4px; }
.sit-icon svg { width: 36px !important; height: 36px !important; display: block; }
.sit:last-child { border-right: none; }
.sit-num { font-family: var(--mono); font-size: 11px; color: var(--accent); letter-spacing: 0.08em; }
.sit-title { font-family: var(--serif); font-size: 22px; font-weight: 400; line-height: 1.2; letter-spacing: -0.01em; }
.sit-desc { font-size: 14px; color: var(--ink-2); line-height: 1.6; }

.pkgs { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.pkg { background: var(--bg); border: 1px solid var(--rule); border-radius: 6px; padding: 36px; display: flex; flex-direction: column; }
.pkg-icon { width: 40px; height: 40px; color: var(--accent-ink); flex-shrink: 0; align-self: flex-start; display: block; margin-bottom: 12px; }
.pkg-icon svg { width: 40px !important; height: 40px !important; display: block; }
.pkg.featured { background: var(--bg-deep); color: var(--bg); border-color: var(--bg-deep); }
.pkg.featured h3, .pkg.featured .pkg-price { color: var(--bg); }
.pkg.featured ul li { border-color: var(--rule-deep); color: oklch(0.88 0.008 250); }
.pkg.featured .pkg-foot { border-color: var(--rule-deep); }
.pkg.featured .pkg-cta { background: var(--accent); color: var(--bg); }
.pkg-tag { display: inline-flex; align-items: center; gap: 8px; font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; color: var(--ink-3); text-transform: uppercase; margin-bottom: 18px; }
.pkg.featured .pkg-tag { color: var(--accent); }
.pkg h3 { font-family: var(--serif); font-size: 32px; font-weight: 400; letter-spacing: -0.02em; line-height: 1.05; margin: 0 0 8px; color: var(--ink); }
.pkg-sub { font-size: 13px; color: var(--ink-3); margin-bottom: 22px; }
.pkg.featured .pkg-sub { color: oklch(0.78 0.005 250); }
.pkg-price { font-family: var(--serif); font-size: 44px; font-weight: 400; letter-spacing: -0.025em; line-height: 1; color: var(--ink); display: flex; align-items: baseline; gap: 8px; }
.pkg-price .from { font-family: var(--sans); font-size: 13px; font-weight: 500; color: var(--accent); letter-spacing: 0; }
.pkg-price .unit { font-family: var(--sans); font-size: 13px; font-weight: 400; color: var(--ink-3); margin-left: 4px; }
.pkg ul { list-style: none; padding: 0; margin: 24px 0; }
.pkg ul li { font-size: 14px; color: var(--ink-2); line-height: 1.5; padding: 10px 0 10px 22px; border-bottom: 1px solid var(--rule); position: relative; }
.pkg ul li::before { content: ""; position: absolute; left: 0; top: 16px; width: 12px; height: 1px; background: var(--accent); }
.pkg ul li:last-child { border-bottom: none; }
.pkg-foot { margin-top: auto; padding-top: 24px; border-top: 1px solid var(--rule); }
.pkg-cta { display: inline-flex; align-items: center; gap: 10px; padding: 14px 22px; border-radius: 999px; background: var(--ink); color: var(--bg); font-size: 14px; font-weight: 500; text-decoration: none; }
.pkg-cta:hover { background: var(--accent-ink); }

.voices { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; margin-top: 32px; }
.voice { background: var(--bg); border: 1px solid var(--rule); border-radius: 6px; padding: 32px; }
.voice-quote { font-family: var(--serif); font-style: italic; font-size: 22px; line-height: 1.4; color: var(--ink); margin: 0 0 20px; }
.voice-byline { font-family: var(--mono); font-size: 12px; letter-spacing: 0.06em; color: var(--ink-3); text-transform: uppercase; }

.cta-large { padding: 120px 0; text-align: center; }
.cta-large h2 { font-family: var(--serif); font-size: clamp(40px, 5vw, 72px); font-weight: 400; line-height: 1.02; letter-spacing: -0.025em; margin: 0 auto 20px; max-width: 18ch; text-wrap: balance; }
.cta-large h2 em { font-style: italic; color: var(--accent-ink); }
.cta-large p { font-size: 18px; color: var(--ink-2); max-width: 60ch; margin: 0 auto 32px; }
.cta-row { display: flex; justify-content: center; gap: 14px; flex-wrap: wrap; }

@media (max-width: 980px) {
  .vg-hero-grid { grid-template-columns: 1fr; gap: 40px; }
  .situations { grid-template-columns: 1fr; }
  .sit { border-right: none; }
  .pkgs { grid-template-columns: 1fr; }
  .voices { grid-template-columns: 1fr; }
}

/* ============================================================
   Gutachten-Page — HKA-Karten + Messgeraete-Grid + Format-Block
   ============================================================ */

/* Nummerierte Checklisten in HKA-Karten */
.svc-checklist { list-style: none; counter-reset: chk; padding: 0; margin: 16px 0 24px; }
.svc-checklist li { counter-increment: chk; position: relative; padding: 8px 0 8px 32px; font-size: 14px; color: var(--ink-2); line-height: 1.55; border-bottom: 1px solid var(--rule-2); }
.svc-checklist li:last-child { border-bottom: none; }
.svc-checklist li::before { content: counter(chk, decimal-leading-zero); position: absolute; left: 0; top: 8px; font-family: var(--mono); font-size: 10px; letter-spacing: 0.08em; color: var(--accent); }
.svc-checklist li strong { color: var(--ink); font-weight: 500; }

/* Mini-Tabelle in GA-Karte */
.price-table { width: 100%; border-collapse: collapse; margin: 16px 0 20px; font-size: 13px; color: var(--ink-2); }
.price-table tr { border-bottom: 1px solid var(--rule-2); }
.price-table tr:last-child { border-bottom: none; }
.price-table td { padding: 6px 0; }
.price-table td:last-child { text-align: right; font-family: var(--serif); color: var(--ink); }

/* 2x2 Geraete-Grid (heller Bg, mit Icon) */
.device-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; margin-top: 32px; }
.device-card { background: var(--bg); border: 1px solid var(--rule-2); border-radius: 6px; padding: 32px; display: flex; flex-direction: column; gap: 16px; text-decoration: none; color: var(--ink); transition: border-color .2s, transform .2s, box-shadow .2s; cursor: pointer; }
.device-card:hover { border-color: var(--accent-ink); transform: translateY(-2px); }
.device-card:focus-visible { outline: 2px solid var(--accent-ink); outline-offset: 2px; }
.device-icon { width: 48px; height: 48px; color: var(--accent-ink); margin-bottom: 4px; flex-shrink: 0; display: block; }
.device-icon svg { width: 48px !important; height: 48px !important; display: block; }
.device-icon img { width: 48px !important; height: 48px !important; display: block; object-fit: contain; }
.device-lede { font-size: 14px; line-height: 1.55; color: var(--ink-2); margin: 0; }
.device-more { padding-top: 14px; font-family: var(--mono); font-size: 11px; color: var(--accent-ink); letter-spacing: 0.06em; text-transform: uppercase; display: flex; align-items: center; gap: 8px; }
.device-more::after { content: "→"; transition: transform 0.15s ease; }
.device-card:hover .device-more::after { transform: translateX(4px); }
.device-tag { font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; color: var(--accent); text-transform: uppercase; }
.device-card h3 { font-family: var(--serif); font-size: 28px; font-weight: 400; line-height: 1.05; letter-spacing: -0.015em; margin: 0; color: var(--ink); }
.device-foot { margin-top: auto; padding-top: 18px; border-top: 1px solid var(--rule-2); display: flex; justify-content: space-between; align-items: baseline; }
.device-price { font-family: var(--serif); font-size: 24px; color: var(--ink); letter-spacing: -0.01em; }
.device-price .from { font-family: var(--mono); font-size: 10px; color: var(--ink-3); letter-spacing: 0.1em; text-transform: uppercase; margin-right: 6px; }
.device-meta { font-family: var(--mono); font-size: 11px; color: var(--ink-3); letter-spacing: 0.05em; }

/* Format-Block (3x2 Grid) */
.format-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border-top: 1px solid var(--rule); border-left: 1px solid var(--rule); }
.format-item { padding: 32px 28px; border-right: 1px solid var(--rule); border-bottom: 1px solid var(--rule); background: var(--bg); display: flex; flex-direction: column; gap: 12px; }
.format-num { font-family: var(--mono); font-size: 11px; color: var(--accent); letter-spacing: 0.1em; }
.format-title { font-family: var(--serif); font-size: 22px; font-weight: 400; line-height: 1.2; letter-spacing: -0.01em; color: var(--ink); }
.format-desc { font-size: 14px; color: var(--ink-2); line-height: 1.6; }

@media (max-width: 980px) {
  .format-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .device-grid { grid-template-columns: 1fr; gap: 16px; }
  .device-card { padding: 24px; }
  .device-card h3 { font-size: 24px; }
  .format-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   Audit-Cluster-Grid (»Was wird forensisch geprueft«)
   ============================================================ */

.audit-clusters { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0; border-top: 1px solid var(--rule); border-left: 1px solid var(--rule); margin-top: 32px; }
.audit-cluster { padding: 32px 28px; border-right: 1px solid var(--rule); border-bottom: 1px solid var(--rule); background: var(--bg); display: flex; flex-direction: column; gap: 12px; cursor: pointer; transition: background 0.15s ease; position: relative; }
.audit-cluster:hover { background: var(--bg-2, #f8f8f6); }
.audit-cluster:focus-visible { outline: 2px solid var(--accent-ink); outline-offset: -2px; }
.audit-cluster-more { margin-top: auto; padding-top: 16px; font-family: var(--mono); font-size: 11px; color: var(--accent-ink); letter-spacing: 0.06em; text-transform: uppercase; display: flex; align-items: center; gap: 8px; }
.audit-cluster-more::after { content: "→"; transition: transform 0.15s ease; }
.audit-cluster:hover .audit-cluster-more::after { transform: translateX(4px); }
.audit-cluster-num { font-family: var(--mono); font-size: 11px; color: var(--accent); letter-spacing: 0.1em; }
.audit-cluster-title { font-family: var(--serif); font-size: 24px; font-weight: 400; line-height: 1.15; letter-spacing: -0.01em; margin: 0; color: var(--ink); }
.audit-cluster-title em { font-style: italic; color: var(--accent-ink); font-weight: 400; }
.audit-cluster-list { list-style: none; padding: 0; margin: 8px 0 0; }
.audit-cluster-list li { font-size: 13px; color: var(--ink-2); line-height: 1.55; padding: 10px 0 10px 16px; border-bottom: 1px solid var(--rule-2); position: relative; }
.audit-cluster-list li:last-child { border-bottom: none; }
.audit-cluster-list li::before { content: ""; position: absolute; left: 0; top: 18px; width: 8px; height: 1px; background: var(--accent); }
.audit-cluster-list li strong { color: var(--ink); font-weight: 500; }

@media (max-width: 980px) {
  .audit-clusters { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .audit-clusters { grid-template-columns: 1fr; }
}

/* HERO-SPLIT — zwei Karten mit Bild oben, Text-Box darunter (Abrechnung / Messgerät) */
.hero-split { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 32px; align-items: stretch; }
.hero-split-single { grid-template-columns: 1fr; }
.hero-half-c { aspect-ratio: 1661 / 631; }
.hero-half { display: flex; flex-direction: column; text-decoration: none; color: var(--ink); border-radius: 4px; overflow: hidden; background: var(--bg); border: 1px solid var(--rule-2); transition: transform 0.25s ease, border-color 0.25s ease; cursor: pointer; }
.hero-half:hover { transform: translateY(-2px); border-color: var(--accent-ink); }
.hero-half:focus-visible { outline: 3px solid var(--accent-ink); outline-offset: 2px; }
.hero-half-image { position: relative; aspect-ratio: 3 / 2; overflow: hidden; filter: saturate(1.12) contrast(1.06); background-image: var(--bg-img); background-size: cover; background-position: center center; background-repeat: no-repeat; transition: transform 0.6s ease; }
.hero-half-c .hero-half-image { aspect-ratio: 1661 / 631; }
.hero-half-d .hero-half-image { aspect-ratio: 2560 / 1657; }
.hero-half:hover .hero-half-image { transform: scale(1.03); }
.hero-half-content { padding: 22px 28px 24px; }
.hero-half-tag { font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-3); margin-bottom: 10px; }
.hero-half-row { display: flex; justify-content: space-between; align-items: center; gap: 24px; }
.hero-half-question { font-family: var(--serif); font-size: clamp(22px, 2.6vw, 32px); font-weight: 400; line-height: 1.15; letter-spacing: -0.015em; color: var(--ink); margin: 0; }
.hero-half-question em { font-style: italic; color: var(--accent-ink); font-weight: 400; }
.hero-half-arr { font-family: var(--mono); font-size: 28px; line-height: 1; color: var(--accent-ink); transition: transform 0.25s ease; flex-shrink: 0; }
.hero-half:hover .hero-half-arr { transform: translateX(6px); }
/* Quint-Variante: 5 Bildkarten in einer Reihe (Front-Page Mein-Angebot). Alle Bilder werden auf 3:2 normiert, damit die Karten gleich hoch sind. */
.hero-split-quint { grid-template-columns: repeat(5, 1fr); gap: 12px; }
.hero-split-quint .hero-half-image,
.hero-split-quint .hero-half-c .hero-half-image,
.hero-split-quint .hero-half-d .hero-half-image { aspect-ratio: 3 / 2; }
.hero-split-quint .hero-half-content { padding: 18px 18px 20px; }
.hero-split-quint .hero-half-question { font-size: clamp(16px, 1.25vw, 21px); }
.hero-split-quint .hero-half-arr { font-size: 22px; }
@media (max-width: 1100px) {
  .hero-split-quint { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 820px) {
  .hero-split-quint { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
  .hero-split { grid-template-columns: 1fr; gap: 12px; }
  .hero-split-single .hero-half-image { aspect-ratio: 3 / 2; }
  .hero-half-content { padding: 18px 22px 20px; }
}
@media (max-width: 520px) {
  .hero-split-quint { grid-template-columns: 1fr; }
}

/* SVC-PRUEF-LIST — klickbare Prüfumfang-Liste innerhalb der Varianten-Karten */
.svc-section-tag { font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-3); margin: 24px 0 10px; }
.svc-section-tag:first-of-type { margin-top: 12px; }
.svc-pruef-list { list-style: none; padding: 0; margin: 0 0 8px; border-top: 1px solid var(--rule-2); }
.svc-pruef-list li { display: flex; align-items: center; gap: 12px; padding: 12px 0; border-bottom: 1px solid var(--rule-2); font-size: 14px; color: var(--ink); cursor: pointer; transition: color 0.15s ease, padding-left 0.15s ease; position: relative; }
.svc-pruef-list li:hover { color: var(--accent-ink); padding-left: 6px; }
.svc-pruef-list li:focus-visible { outline: 2px solid var(--accent-ink); outline-offset: 2px; }
.svc-pruef-list li::after { content: "→"; margin-left: auto; font-family: var(--mono); font-size: 13px; color: var(--ink-3); transition: transform 0.15s ease, color 0.15s ease; }
.svc-pruef-list li:hover::after { transform: translateX(4px); color: var(--accent-ink); }
.svc-pruef-list li.pf-plus-item { cursor: default; color: var(--ink-2); font-style: italic; }
.svc-pruef-list li.pf-plus-item:hover { color: var(--ink-2); padding-left: 0; }
.svc-pruef-list li.pf-plus-item::after { content: ""; }
.pf-num { font-family: var(--mono); font-size: 11px; letter-spacing: 0.06em; color: var(--accent); min-width: 22px; }
.pf-plus { font-style: italic; color: var(--ink-3); font-size: 13px; font-weight: 400; }

/* TOPIC-BAR — kompakte Themen-Leiste (z.B. Beratung: Heizkosten / Betriebskosten / Nebenkosten / WEG) */
.topic-bar { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; margin-top: 48px; padding: 22px 28px; background: var(--bg); border: 1px solid var(--rule-2); border-radius: 4px; }
.topic { display: flex; align-items: center; gap: 14px; padding: 6px 14px; }
.topic + .topic { border-left: 1px solid var(--rule-2); }
.topic-icon { width: 30px; height: 30px; color: var(--accent-ink); flex-shrink: 0; display: block; }
.topic-icon svg { width: 30px !important; height: 30px !important; display: block; }
.topic-name { font-family: var(--mono); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink); font-weight: 500; }

/* AUDIENCE-BAR — reduzierte Erkennungs-Anker (Front-Page Sektion „Zielgruppen"). Deklaratorisch, nicht klickbar. */
.audience-bar { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; margin-top: 32px; padding: 22px 28px; background: var(--bg); border: 1px solid var(--rule-2); border-radius: 4px; }
.aud-anchor { display: flex; align-items: center; gap: 14px; padding: 10px 14px; }
.aud-anchor + .aud-anchor { border-left: 1px solid var(--rule-2); }
.aud-anchor-icon { width: 30px; height: 30px; color: var(--accent-ink); flex-shrink: 0; display: block; }
.aud-anchor-icon svg { width: 30px !important; height: 30px !important; display: block; }
.aud-anchor-name { font-family: var(--mono); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink); font-weight: 500; }
@media (max-width: 768px) {
  .audience-bar { grid-template-columns: 1fr 1fr; padding: 14px; }
  .aud-anchor { padding: 14px 10px; }
  .aud-anchor + .aud-anchor { border-left: none; }
  .aud-anchor:nth-child(2n) { border-left: 1px solid var(--rule-2); }
  .aud-anchor:nth-child(n+3) { border-top: 1px solid var(--rule-2); }
}
@media (max-width: 768px) {
  .topic-bar { grid-template-columns: repeat(2, 1fr); padding: 16px 12px; }
  .topic + .topic { border-left: none; }
  .topic:nth-child(2n+1) { border-right: 1px solid var(--rule-2); }
  .topic:nth-child(n+3) { border-top: 1px solid var(--rule-2); padding-top: 14px; }
}

/* DISCIPLINE-BLOCK — zweispaltige Disziplin-Positionierung (Original-Andreas-Texte) */
.discipline-block { display: grid; grid-template-columns: 0.85fr 1fr; gap: 80px; padding: 24px 0 48px; align-items: start; }
.discipline-tag { font-family: var(--mono); font-size: 11px; color: var(--accent); letter-spacing: 0.12em; text-transform: uppercase; margin-bottom: 24px; }
.discipline-title { font-family: var(--serif); font-size: clamp(40px, 5vw, 64px); font-weight: 400; line-height: 1.02; letter-spacing: -0.02em; margin: 0 0 28px; color: var(--ink); text-transform: uppercase; }
.discipline-lede { font-family: var(--serif); font-size: 18px; line-height: 1.55; color: var(--ink); margin: 0; }
.discipline-lede strong { font-weight: 500; color: var(--ink); }
.discipline-body { display: flex; flex-direction: column; gap: 18px; }
.discipline-body p { font-size: 15px; line-height: 1.7; color: var(--ink-2); margin: 0; }
.discipline-body p strong { color: var(--ink); font-weight: 500; }
.discipline-body p.credo { font-style: italic; font-weight: 500; color: var(--ink); font-size: 16px; padding: 8px 0; border-top: 1px solid var(--rule-2); border-bottom: 1px solid var(--rule-2); padding: 14px 0; margin: 6px 0; }
@media (max-width: 900px) {
  .discipline-block { grid-template-columns: 1fr; gap: 32px; padding: 16px 0 32px; }
  .discipline-title { font-size: 36px; margin-bottom: 20px; }
  .discipline-lede { font-size: 17px; }
}

/* MODAL — Detail-Ansicht für Cluster-Karten */
.modal-overlay { position: fixed; inset: 0; background: rgba(20, 28, 38, 0.78); display: none; align-items: center; justify-content: center; z-index: 1000; padding: 20px; opacity: 0; transition: opacity 0.2s ease; }
.modal-overlay.is-open { display: flex; opacity: 1; }
.modal-content { background: var(--bg); max-width: 840px; width: 100%; max-height: 90vh; overflow-y: auto; border-radius: 6px; padding: 48px 56px; position: relative; border: 1px solid var(--rule); }
.modal-close { position: absolute; top: 20px; right: 24px; background: none; border: none; font-size: 24px; line-height: 1; color: var(--ink-3); cursor: pointer; padding: 8px; border-radius: 4px; transition: background 0.15s, color 0.15s; }
.modal-close:hover { background: var(--rule-2); color: var(--ink); }
.modal-content .modal-num { font-family: var(--mono); font-size: 11px; color: var(--accent); letter-spacing: 0.1em; }
.modal-content .modal-title-row { display: flex; align-items: center; gap: 18px; margin: 12px 0 32px; }
.modal-content .modal-title-icon { width: 56px; height: 56px; flex-shrink: 0; display: block; }
.modal-content .modal-title-icon img { width: 56px !important; height: 56px !important; display: block; object-fit: contain; }
.modal-content .modal-title-row .modal-title { margin: 0; }
.modal-content .modal-title { font-family: var(--serif); font-size: 32px; font-weight: 400; line-height: 1.15; letter-spacing: -0.01em; margin: 8px 0 32px; color: var(--ink); }
.modal-content .modal-title em { font-style: italic; color: var(--accent-ink); font-weight: 400; }
.modal-content h4 { font-family: var(--serif); font-size: 19px; font-weight: 500; margin: 28px 0 10px; color: var(--ink); line-height: 1.3; }
.modal-content h4:first-of-type { margin-top: 0; }
.modal-content p { font-size: 14px; line-height: 1.65; color: var(--ink-2); margin: 0 0 16px; }
.modal-content .modal-foot { margin-top: 32px; padding-top: 20px; border-top: 1px solid var(--rule-2); font-family: var(--mono); font-size: 11px; color: var(--ink-3); letter-spacing: 0.05em; }
.modal-content .modal-block { margin-top: 24px; }
.modal-content .modal-block:first-of-type { margin-top: 0; }
.modal-content .modal-block-title { font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent-ink); margin-bottom: 12px; }
.modal-content ul.modal-list { list-style: none; padding: 0; margin: 0; }
.modal-content ul.modal-list li { font-size: 14px; line-height: 1.55; color: var(--ink); padding: 8px 0 8px 18px; border-bottom: 1px solid var(--rule-2); position: relative; }
.modal-content ul.modal-list li:last-child { border-bottom: none; }
.modal-content ul.modal-list li::before { content: "—"; position: absolute; left: 0; top: 8px; color: var(--accent); font-family: var(--mono); }
.modal-content ul.modal-list-icons li { padding: 12px 0 12px 0; display: flex; align-items: center; gap: 14px; }
.modal-content ul.modal-list-icons li::before { content: ""; }
.modal-li-icon { display: inline-flex; width: 28px; height: 28px; color: var(--accent-ink); flex-shrink: 0; }
.modal-li-icon svg { width: 100%; height: 100%; }
.modal-li-num { font-family: var(--mono); font-size: 11px; color: var(--accent); letter-spacing: 0.06em; min-width: 22px; }
.modal-content ul.modal-list-icons li.modal-li-plus { color: var(--ink-3); font-style: italic; padding-left: 42px; }
.modal-content ol.modal-list-numbered { list-style: none; counter-reset: ml; padding: 0; margin: 0; }
.modal-content ol.modal-list-numbered > li { counter-increment: ml; display: grid; grid-template-columns: 28px 36px 1fr; gap: 14px; align-items: start; padding: 16px 0 18px; border-bottom: 1px solid var(--rule-2); font-size: 13.5px; line-height: 1.6; color: var(--ink-2); }
.modal-content ol.modal-list-numbered > li:last-child { border-bottom: none; }
.modal-content ol.modal-list-numbered > li::before { content: counter(ml, decimal-leading-zero); font-family: var(--mono); font-size: 11px; letter-spacing: 0.06em; color: var(--accent); font-weight: 500; padding-top: 10px; }
.ml-icon { width: 36px; height: 36px; color: var(--accent-ink); padding-top: 2px; }
.ml-icon svg { width: 100%; height: 100%; }
.ml-body strong { display: block; font-family: var(--serif); font-size: 16px; font-weight: 500; color: var(--ink); margin-bottom: 6px; line-height: 1.3; }
@media (max-width: 600px) {
  .modal-content ol.modal-list-numbered > li { grid-template-columns: 24px 28px 1fr; gap: 10px; }
  .ml-icon { width: 28px; height: 28px; }
}
body.modal-open { overflow: hidden; }
@media (max-width: 600px) {
  .modal-content { padding: 36px 24px; max-height: 95vh; }
  .modal-content .modal-title { font-size: 24px; margin-bottom: 24px; }
}

/* Forminator-Override fuer das Theme (Form-ID via SVEHRET_FORM_ID eingebunden) */
.forminator-custom-form { max-width: 100% !important; margin-top: 24px; }
.forminator-custom-form .forminator-label,
.forminator-custom-form label { font-family: var(--mono) !important; font-size: 11px !important; letter-spacing: 0.08em !important; text-transform: uppercase !important; color: var(--ink-2) !important; font-weight: 500 !important; }
.forminator-custom-form input[type="text"],
.forminator-custom-form input[type="email"],
.forminator-custom-form input[type="tel"],
.forminator-custom-form input[type="number"],
.forminator-custom-form select,
.forminator-custom-form textarea { background: var(--bg) !important; border: 1px solid var(--rule) !important; border-radius: 4px !important; padding: 14px 16px !important; font-family: var(--sans) !important; font-size: 15px !important; color: var(--ink) !important; box-shadow: none !important; }
.forminator-custom-form input:focus,
.forminator-custom-form select:focus,
.forminator-custom-form textarea:focus { border-color: var(--accent-ink) !important; outline: none !important; box-shadow: none !important; }
.forminator-custom-form button[type="submit"],
.forminator-custom-form .forminator-button-submit { background: var(--ink) !important; color: var(--bg) !important; padding: 14px 22px !important; border-radius: 999px !important; font-family: var(--sans) !important; font-size: 15px !important; font-weight: 500 !important; border: none !important; cursor: pointer !important; }
.forminator-custom-form button[type="submit"]:hover,
.forminator-custom-form .forminator-button-submit:hover { background: var(--accent-ink) !important; }

/* =============================================================
 * Print — Onepager / PDF-Export. Sticky-Nav weg, dunkle Flächen
 * auf weiß + dunklen Text, keine Hover-/Blur-Reste, saubere Umbrüche.
 * ============================================================= */
@media print {
  *, *::before, *::after { box-shadow: none !important; text-shadow: none !important; }
  html { overflow-x: visible; }
  body { background: #fff !important; color: #000 !important; font-size: 11pt; }
  .nav, .nav-toggle, .skip-link, .modal-overlay, .springboard .springboard-btn, .hero-half-arr, .nav-cta { display: none !important; }
  .section, .hero { padding: 16px 0 !important; }
  .wrap { max-width: 100% !important; padding: 0 !important; }
  /* Dunkle Sektionen druckfreundlich umkehren */
  .section-deep, .footer, .svc-hero, .focus-card, .aud-prio, .springboard, .timeline, .modal-content {
    background: #fff !important;
    color: #000 !important;
    border: 1px solid #999 !important;
  }
  .section-deep .section-title, .footer h2, .footer a, .section-deep .section-lede,
  .springboard, .springboard-text, .footer-brand { color: #000 !important; }
  a { color: #000 !important; text-decoration: underline; }
  /* Linkziele ausschreiben, damit Papierausdruck nachvollziehbar bleibt */
  .footer a[href^="http"]::after, .crumb a[href^="http"]::after { content: " (" attr(href) ")"; font-size: 9pt; color: #555; }
  /* Umbrüche steuern */
  .principle, .svc, .device-card, .hero-half, .tl-row, .client, .std, .scenario { break-inside: avoid; }
  h1, h2, h3 { break-after: avoid; }
  img { max-width: 100% !important; }
}

/* =============================================================
 * Reduced Motion — respektiert die System-Einstellung (WCAG 2.3.3).
 * Schaltet Transitions/Animationen/Hover-Transforms + Smooth-Scroll ab.
 * ============================================================= */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  html { scroll-behavior: auto !important; }
}
