/* =============================================================================
   SevenReal Solutions — Main Stylesheet
   Mobile-first, BEM-Konvention, alle Werte über CSS Custom Properties.
   Quelle der Wahrheit: Projekt_Guideline_Landingpage.md (Section 2)
   ============================================================================= */

/* -----------------------------------------------------------------------------
   1. Tokens (Design-System)
   ----------------------------------------------------------------------------- */
:root {
    /* Primärfarben */
    --color-black: #181a20;
    --color-gold: #5e4b3d;
    --color-gold-dark: #756254;
    --color-gold-light: #a88464;
    --color-gold-lightXX: #d9b686;

    /* Hintergründe */
    --color-bg: #FFFFFF;
    --color-bg-cream: #FAF7F0;
    --color-bg-grid: #EEE8D8;

    /* Text */
    --color-text: #1A1A1A;
    --color-text-muted: #6A6A6A;
    --color-text-light: #8A8A8A;
    --color-text-fade: #A8A8A8;
    --color-text-on-dark: #FFFFFF;

    /* Form / Status */
    --color-error: #B45248;
    --color-success: #6B8E5A;

    /* Fonts */
    --font-serif: 'Plus Jakarta Sans', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --font-sans: Arial, Helvetica, sans-serif;

    /* Type Scale */
    --fs-eyebrow: 0.6875rem;     /* 11px */
    --fs-label:   0.75rem;       /* 12px */
    --fs-body:    0.8125rem;     /* 13px */
    --fs-h3: clamp(1rem,    1.5vw,  1.25rem);
    --fs-h2: clamp(1.25rem, 2.5vw,  1.75rem);
    --fs-h1: clamp(1.75rem, 4vw,    2.5rem);
    --fs-stat: clamp(2rem,  6vw,    3.75rem);

    /* Letter-Spacing */
    --ls-tight:   1px;
    --ls-medium:  2px;
    --ls-wide:    3px;
    --ls-widest:  4px;

    /* Spacing */
    --space-xs:  0.5rem;
    --space-sm:  1rem;
    --space-md:  1.5rem;
    --space-lg:  2.5rem;
    --space-xl:  4rem;
    --space-2xl: 6rem;

    /* Radien */
    --radius-sm: 2px;
    --radius-md: 4px;
    --radius-lg: 16px;

    /* Layout */
    --container-max: 1280px;
    --container-padding: clamp(1rem, 4vw, 2.5rem);

    /* Section vertikales Padding */
    --section-py: var(--space-xl);
}

@media (min-width: 960px) {
    :root {
        --section-py: var(--space-2xl);
    }
}

/* -----------------------------------------------------------------------------
   2. Reset / Base
   ----------------------------------------------------------------------------- */
*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    -webkit-text-size-adjust: 100%;
    scroll-behavior: smooth;
}

body {
    margin: 0;
    font-family: var(--font-sans);
    font-size: var(--fs-body);
    line-height: 1.6;
    color: var(--color-text);
    background: var(--color-bg);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

img,
svg,
video {
    max-width: 100%;
    height: auto;
    display: block;
}

a {
    color: inherit;
    text-decoration: none;
}

button {
    font: inherit;
    border: none;
    background: none;
    cursor: pointer;
    padding: 0;
}

ul,
ol {
    margin: 0;
    padding: 0;
    list-style: none;
}

h1, h2, h3, h4, h5, h6 {
    margin: 0;
    font-family: var(--font-serif);
    font-weight: normal;
    line-height: 1.2;
    color: var(--color-text);
}

p {
    margin: 0;
}

/* -----------------------------------------------------------------------------
   3. Utilities
   ----------------------------------------------------------------------------- */
.u-container {
    max-width: var(--container-max);
    margin: 0 auto;
    padding-left: var(--container-padding);
    padding-right: var(--container-padding);
}

.u-visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* -----------------------------------------------------------------------------
   4. Reusable Patterns
       Zentrale visuelle Bausteine, die Component-CSS wiederverwendet.
   ----------------------------------------------------------------------------- */

/* Goldlinie unter Headlines */
.eyebrow {
    display: inline-block;
    font-family: var(--font-sans);
    font-size: var(--fs-eyebrow);
    text-transform: uppercase;
    letter-spacing: var(--ls-widest);
    color: var(--color-gold-lightXX);
    margin: 0 0 var(--space-sm);
}

.headline {
    font-family: var(--font-serif);
    font-size: var(--fs-h1);
    letter-spacing: var(--ls-wide);
    color: var(--color-text);
    margin: 0 0 var(--space-sm);
}

.divider-gold {
    display: block;
    width: 140px;
    height: 1.5px;
    background: var(--color-gold-lightXX);
    border: 0;
    margin: 0 0 var(--space-xs);
}

/* Section-Wrapper */
.section {
    padding-top: var(--section-py);
    padding-bottom: var(--section-py);
}

.section--cream {
    background: var(--color-bg-cream);
}

.section--dark {
    background: var(--color-black);
    color: var(--color-text-on-dark);
}

/* Karten-Primitive */
.card {
    background: var(--color-bg-cream);
    border: 1px solid var(--color-gold);
    border-radius: var(--radius-md);
    padding: var(--space-md);
}

.card--dark {
    background: var(--color-black);
    color: var(--color-text-on-dark);
}

.card--accent-top {
    border-top-width: 4px;
    border-top-color: var(--color-gold);
}

.card--placeholder {
    border-style: dashed;
}

/* Buttons */
.btn {
    display: inline-flex;
    align-items: center;
    gap: var(--space-xs);
    padding: 1rem 2rem;
    font-family: var(--font-sans);
    font-size: var(--fs-label);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: var(--ls-medium);
    border-radius: var(--radius-sm);
    transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
    cursor: pointer;
}

.btn--primary {
    background: var(--color-gold);
    color: var(--color-text-on-dark);
    border-radius: 33px;
}

.btn--primary:hover {
    background: var(--color-gold-light);
    transform: translateY(-1px);
}

.btn--ghost-light {
    background: transparent;
    color: var(--color-text-on-dark);
    border: 1px solid var(--color-gold);
}

.btn--ghost-light:hover {
    background: var(--color-gold);
    color: var(--color-black);
}

/* Platzhalter-Badge */
.badge-placeholder {
    display: inline-block;
    background: var(--color-gold-dark);
    color: var(--color-bg);
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: var(--ls-medium);
    padding: 4px 12px;
    border-radius: var(--radius-sm);
}

.placeholder-note {
    font-size: 10px;
    font-style: italic;
    color: var(--color-text-fade);
    text-transform: uppercase;
    letter-spacing: var(--ls-medium);
    text-align: center;
    margin-top: var(--space-md);
}

/* -----------------------------------------------------------------------------
   5. Header
   Default = transparent + weiße Schrift (passt zum Hero auf der Home-Page).
   Solid-Mode greift auf:
     - Sub-Pages: body:not(.page-home) .site-header
     - Home-Page nach Scroll-Vorbei: .site-header.is-scrolled (toggle via JS)
   Modifier-Klassen überschreiben nur die CSS-Custom-Props, nicht jede Property.
   ----------------------------------------------------------------------------- */
.site-header {
    /* Theme-Variablen — werden von Modifiern überschrieben */
    --hd-bg:         transparent;
    --hd-text:       var(--color-text-on-dark);
    --hd-text-muted: rgba(255, 255, 255, 0.8);
    --hd-burger:     var(--color-text-on-dark);
    --hd-border:     transparent;

    /* Fixed (statt sticky), damit Hero/Page-Header hinter den Header rutschen.
       Sticky reservierte 72px im Flow → weißer Body-Bg blitzte durch. */
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 100;
    background: var(--hd-bg);
    border-bottom: 1px solid var(--hd-border);
    transition: background 0.3s ease, border-color 0.3s ease;
}

/* Solid-Mode:
   - Pages OHNE Hero / page-header--with-image (z. B. /rechner)
   - Jede Page sobald über den Image-Header hinausgescrollt (toggle via JS)

   Der :has()-Selektor stellt sicher, dass Pages mit einem Hero oder
   Image-Header per Default transparent starten — egal welche Body-Klasse
   sie tragen. */
body:not(:has(.hero)):not(:has(.page-header--with-image)):not(:has(.services-hero)) .site-header,
.site-header.is-scrolled {
    --hd-bg:         rgba(255, 255, 255, 0.94);
    --hd-text:       var(--color-text);
    --hd-text-muted: var(--color-text-muted);
    --hd-burger:     var(--color-text);
    --hd-border:     rgba(201, 169, 97, 0.2);
    /* Achtung: kein backdrop-filter auf .site-header selbst — würde
       Containing-Block für position:fixed children erzeugen und das
       .site-header__mobile-nav an die 72px Header-Höhe binden. Daher etwas
       höhere alpha (0.94) als Ausgleich für den fehlenden Blur. */
}

/* Mobile-Menü offen → Burger-Linien immer dunkel (Off-Canvas hat helle Bg) */
.site-header.is-menu-open {
    --hd-burger: var(--color-text);
}

.site-header__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 72px;
}

.site-header__logo {
    display: inline-flex;
    align-items: center;
    line-height: 0;
    transition: opacity 0.2s ease;
}
.site-header__logo:hover {
    opacity: 0.85;
}

.site-header__logo-img {
    display: block;
    height: clamp(36px, 4.2vw, 56px);
    width: auto;
    max-width: 220px;
    object-fit: contain;
}

/* Logo-Variante: hell (default, über Hero) vs. dunkel (Solid-Header).
   Beide Bilder liegen übereinander; CSS schaltet je nach Header-Zustand
   sichtbar. Damit der Slot keine doppelte Breite einnimmt, ist die
   dunkle Variante absolut über der hellen positioniert. */
.site-header__logo {
    position: relative;
}
.site-header__logo-img--dark {
    position: absolute;
    inset: 0;
    margin: auto;
    opacity: 0;
}
/* Im Solid-Mode (Sub-Pages ohne Hero ODER scrolled) wechseln die Logos */
body:not(:has(.hero)):not(:has(.page-header--with-image)):not(:has(.services-hero)) .site-header .site-header__logo-img--light,
.site-header.is-scrolled .site-header__logo-img--light {
    opacity: 0;
}
body:not(:has(.hero)):not(:has(.page-header--with-image)):not(:has(.services-hero)) .site-header .site-header__logo-img--dark,
.site-header.is-scrolled .site-header__logo-img--dark {
    opacity: 1;
}
.site-header__logo-img {
    transition: opacity 0.3s ease;
}

@media (max-width: 600px) {
    .site-header__logo-img {
        height: 36px;
        max-width: 160px;
    }
}

.site-header__nav {
    display: none;
}

.site-header__nav-list {
    display: flex;
    align-items: center;
    gap: var(--space-lg);
}

.site-header__nav-link {
    font-size: var(--fs-label);
    text-transform: uppercase;
    letter-spacing: var(--ls-medium);
    color: var(--hd-text-muted);
    padding: 0.5rem 0;
    position: relative;
    transition: color 0.2s ease;
}

.site-header__nav-link:hover,
.site-header__nav-link--active {
    color: var(--hd-text);
}

.site-header__nav-link::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    width: 0;
    height: 1.5px;
    background: var(--color-gold);
    transition: width 0.2s ease;
}

.site-header__nav-link:hover::after,
.site-header__nav-link--active::after {
    width: 100%;
}

.site-header__burger {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 40px;
    height: 40px;
    gap: 5px;
}

.site-header__burger span {
    display: block;
    width: 22px;
    height: 1.5px;
    background: var(--hd-burger);
    transition: transform 0.2s ease, opacity 0.2s ease, background 0.2s ease;
}

.site-header.is-menu-open .site-header__burger span:nth-child(1) {
    transform: translateY(6.5px) rotate(45deg);
}

.site-header.is-menu-open .site-header__burger span:nth-child(2) {
    opacity: 0;
}

.site-header.is-menu-open .site-header__burger span:nth-child(3) {
    transform: translateY(-6.5px) rotate(-45deg);
}

/* Mobile Off-Canvas */
.site-header__mobile-nav {
    position: fixed;
    top: 72px;
    left: 0;
    right: 0;
    /* Volle Viewport-Höhe abzüglich Header. dvh als Fallback für iOS Safari
       (Bottom-Toolbar — vh würde zu kleines/zu großes Menü ergeben). */
    height: calc(100vh - 72px);
    height: calc(100dvh - 72px);
    background: var(--color-bg);
    transform: translateX(100%);
    transition: transform 0.3s ease;
    padding: clamp(20px, 4vw, 32px) var(--container-padding);
    overflow-y: auto;
    overscroll-behavior: contain;
}

.site-header.is-menu-open .site-header__mobile-nav {
    transform: translateX(0);
}

.site-header__mobile-nav-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
}

.site-header__mobile-nav-link {
    font-family: var(--font-serif);
    font-size: 1.5rem;
    letter-spacing: var(--ls-tight);
    color: var(--color-text);
    padding: var(--space-sm) 0;
    border-bottom: 1px solid rgba(201, 169, 97, 0.2);
}

@media (min-width: 960px) {
    .site-header__nav {
        display: block;
    }
    .site-header__burger,
    .site-header__mobile-nav {
        display: none;
    }
}

/* -----------------------------------------------------------------------------
   6. Hero
   ----------------------------------------------------------------------------- */
.hero {
    position: relative;
    min-height: 80vh;
    display: flex;
    align-items: center;
    overflow: hidden;
    color: var(--color-text-on-dark);
}

@media (min-width: 960px) {
    .hero {
        min-height: 100vh;
    }
}

.hero__media {
    position: absolute;
    inset: 0;
    z-index: 0;
}

.hero__video,
.hero__poster {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.hero__overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
    background: linear-gradient(
        to bottom,
        rgba(26, 26, 26, 0.55) 0%,
        rgba(26, 26, 26, 0.7) 100%
    );
}

.hero__inner {
    position: relative;
    z-index: 2;
    width: 100%;
    text-align: center;
    padding-top: var(--space-xl);
    padding-bottom: var(--space-xl);
}

.hero__eyebrow {
    color: var(--color-gold-light);
}

.hero__headline {
    font-family: var(--font-serif);
    font-size: clamp(2.25rem, 5vw, 3.5rem);
    line-height: 1.15;
    color: var(--color-text-on-dark);
    letter-spacing: var(--ls-medium);
    max-width: 38ch;
    margin: 0 auto var(--space-md);
}
.hero__headline-accent {
    color: var(--color-gold, #C9A961);
}
.hero__headline strong {
    font-weight: 700;
}

.hero__subheadline {
    font-family: var(--font-sans);
    font-size: 1rem;
    color: rgba(255, 255, 255, 0.85);
    max-width: 50ch;
    margin: 0 auto var(--space-lg);
    line-height: 1.6;
}

.hero__cta {
    /* Erbt vom .btn .btn--primary Pattern, mit etwas weicherer Rundung */
    border-radius: 7px;
}

/* Scroll-Hint unten rechts -------------------------------------------------- */
.hero__scroll-hint {
    position: absolute;
    right: clamp(16px, 3vw, 40px);
    bottom: clamp(20px, 4vh, 48px);
    z-index: 3;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 14px;
    pointer-events: none;
}
.hero__scroll-hint-label {
    writing-mode: vertical-rl;
    transform: rotate(180deg);
    font-family: var(--font-sans);
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.32em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.72);
}
.hero__scroll-hint-line {
    position: relative;
    width: 1px;
    height: 64px;
    background: rgba(255, 255, 255, 0.18);
    overflow: hidden;
}
.hero__scroll-hint-line::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 40%;
    background: var(--color-gold, #C9A961);
    animation: hero-scroll-drop 2.2s cubic-bezier(0.6, 0, 0.4, 1) infinite;
}
@keyframes hero-scroll-drop {
    0%   { transform: translateY(-100%); opacity: 0; }
    20%  { opacity: 1; }
    80%  { opacity: 1; }
    100% { transform: translateY(250%); opacity: 0; }
}

/* Auf schmalen Screens dezenter — nur die Linie, kein Label */
@media (max-width: 640px) {
    .hero__scroll-hint-label { display: none; }
    .hero__scroll-hint-line { height: 48px; }
}

/* Reduced motion: Video durch Poster ersetzen, Scroll-Hint statisch */
@media (prefers-reduced-motion: reduce) {
    .hero__video {
        display: none;
    }
    .hero__scroll-hint-line::before {
        animation: none;
        height: 100%;
        opacity: 0.6;
    }
}

/* Reveal-on-Scroll (global) --------------------------------------------------
   Elemente mit [data-reveal] starten unsichtbar, bekommen .is-visible
   sobald sie im Viewport sind (siehe main.js). Verzögerung über
   data-reveal-delay (in ms). */
[data-reveal] {
    opacity: 0;
    transform: translateY(28px);
    transition: opacity 0.8s cubic-bezier(0.22, 1, 0.36, 1),
                transform 0.8s cubic-bezier(0.22, 1, 0.36, 1);
    will-change: opacity, transform;
}
[data-reveal].is-visible {
    opacity: 1;
    transform: translateY(0);
}
@media (prefers-reduced-motion: reduce) {
    [data-reveal] {
        opacity: 1;
        transform: none;
        transition: none;
    }
}

/* Promise — Leistungsversprechen --------------------------------------------- */
.promise {
    padding: clamp(60px, 9vw, 120px) 0;
    background: var(--color-bg, #FAF7F0);
    overflow: hidden;
}
.promise__inner {
    display: grid;
    grid-template-columns: minmax(0, 2fr) minmax(0, 3fr);
    gap: clamp(40px, 6vw, 96px);
    align-items: center;
}

/* Visuelle Spalte: Bild + überlagernde Shapes ---------------------------------*/
.promise__visual {
    position: relative;
    aspect-ratio: 4 / 5;
    width: 100%;
    max-width: 320px;
    margin: 0 auto;
}
.promise__image-wrap {
    position: relative;
    z-index: 2;
    width: 100%;
    height: 100%;
    border-radius: 15px;
    overflow: hidden;
    box-shadow: 0 30px 60px rgba(26, 26, 26, 0.18);
}
.promise__image {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}
.promise__shape {
    position: absolute;
    border-radius: 15px;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    transition: transform 1.2s cubic-bezier(0.22, 1, 0.36, 1) 0.2s;
}
.promise__shape--gold {
    width: 58%;
    aspect-ratio: 1 / 1;
    top: -7%;
    right: -10%;
    background: rgba(201, 169, 97, 0.55);
    z-index: 1;
    transform: translate(-12px, 12px);
}
.promise__shape--dark {
    width: 46%;
    aspect-ratio: 1 / 1;
    bottom: -6%;
    left: -8%;
    background: rgba(26, 26, 26, 0.55);
    z-index: 2;
    transform: translate(12px, -12px);
}
/* Bei eingeblendeter Visual-Spalte: Shapes wandern an ihre Endposition */
.promise__visual.is-visible .promise__shape--gold,
.promise__visual.is-visible .promise__shape--dark {
    transform: translate(0, 0);
}

/* Text-Spalte ---------------------------------------------------------------- */
.promise__text {
    max-width: 70ch;
}
.promise__eyebrow {
    color: var(--color-gold-dark, #A8894A);
    font-weight: 700;
    letter-spacing: 0.18em;
    font-size: 12px;
    text-transform: uppercase;
    margin: 0 0 14px;
}
.promise__headline {
    font-family: var(--font-serif);
    font-size: clamp(1.75rem, 3.6vw, 2.6rem);
    line-height: 1.2;
    margin: 0 0 22px;
    color: var(--color-text, #1A1A1A);
}
.promise__body {
    font-family: var(--font-sans);
    font-size: 1rem;
    line-height: 1.7;
    color: var(--color-text-muted, #4A4A4A);
    margin: 0;
}

/* Mobile --------------------------------------------------------------------- */
@media (max-width: 860px) {
    .promise__inner {
        grid-template-columns: 1fr;
        gap: 56px;
    }
    .promise__visual {
        max-width: 200px;
    }
}

/* Partners — Bauträger-Marquee ----------------------------------------------- */
.partners {
    padding: clamp(60px, 9vw, 120px) 0;
    background: #FFFFFF;
    overflow: hidden;
}
.partners__header {
    text-align: center;
    max-width: 720px;
    margin: 0 auto clamp(40px, 6vw, 64px);
}
.partners__eyebrow {
    color: var(--color-gold-dark, #A8894A);
    font-weight: 700;
    letter-spacing: 0.18em;
    font-size: 12px;
    text-transform: uppercase;
    margin: 0 0 14px;
}
.partners__headline {
    font-family: var(--font-serif);
    font-size: clamp(1.75rem, 3.6vw, 2.6rem);
    line-height: 1.2;
    margin: 0 0 16px;
    color: var(--color-text, #1A1A1A);
}
.partners__sub {
    font-size: 1rem;
    line-height: 1.6;
    color: var(--color-text-muted, #6A6A6A);
    margin: 0;
}

/* Featured-Partner — prominent ganz oben (Text links, Logo rechts) -------- */
.partners__featured {
    margin: 0 auto clamp(40px, 5vw, 64px);
    max-width: 1000px;
}
.partners__featured-card {
    display: grid;
    grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
    gap: clamp(28px, 4vw, 64px);
    align-items: center;
    text-decoration: none;
    color: var(--color-text, #1A1A1A);
    transition: transform 0.3s ease;
}
a.partners__featured-card:hover {
    transform: translateY(-2px);
}
.partners__featured-text {
    min-width: 0;
}
.partners__featured-eyebrow {
    color: var(--color-gold-dark, #A8894A);
    font-weight: 700;
    letter-spacing: 0.18em;
    font-size: 12px;
    text-transform: uppercase;
    margin: 0 0 18px;
}
.partners__featured-headline {
    font-family: var(--font-serif);
    font-size: clamp(1.5rem, 2.6vw, 2rem);
    font-weight: 700;
    line-height: 1.2;
    color: var(--color-text, #1A1A1A);
    margin: 0 0 14px;
    max-width: 22ch;
}
.partners__featured-tagline {
    margin: 0;
    font-family: var(--font-serif);
    font-style: italic;
    font-size: clamp(1rem, 1.4vw, 1.15rem);
    line-height: 1.4;
    color: var(--color-text-muted, #4A4A4A);
}
.partners__featured-logo {
    display: flex;
    align-items: center;
    justify-content: center;
}
.partners__featured-logo img {
    width: 100%;
    height: auto;
    max-width: 320px;
    max-height: 140px;
    object-fit: contain;
}

/* Subtiler Trenner zwischen Featured und Marquee-Header */
.partners__divider {
    border: 0;
    height: 1px;
    background: rgba(168, 137, 74, 0.25);
    margin: clamp(36px, 5vw, 56px) auto;
    max-width: 1000px;
}

@media (max-width: 720px) {
    .partners__featured-card {
        grid-template-columns: 1fr;
        gap: 28px;
    }
    .partners__featured-logo {
        order: -1;
        justify-content: flex-start;
    }
    .partners__featured-logo img {
        max-width: 200px;
    }
}

/* Marquee-Wrapper mit Edge-Fade über Mask */
.partners__marquee {
    position: relative;
    overflow: hidden;
    /* Soft-fade an den Rändern */
    -webkit-mask-image: linear-gradient(to right, transparent, #000 8%, #000 92%, transparent);
            mask-image: linear-gradient(to right, transparent, #000 8%, #000 92%, transparent);
}
.partners__track {
    display: flex;
    align-items: center;
    gap: clamp(40px, 5vw, 80px);
    width: max-content;
    animation: partners-scroll 45s linear infinite;
}
.partners__marquee:hover .partners__track {
    animation-play-state: paused;
}

@keyframes partners-scroll {
    from { transform: translateX(0); }
    to   { transform: translateX(-50%); }
}

/* Einzelner Logo-Slot */
.partners__logo {
    flex: 0 0 auto;
    width: clamp(140px, 14vw, 180px);
    height: 80px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.partners__logo img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    filter: grayscale(1);
    opacity: 0.7;
    transition: filter 0.25s, opacity 0.25s;
}
.partners__logo:hover img {
    filter: grayscale(0);
    opacity: 1;
}

/* Platzhalter-Box, solange keine echten Logos vorliegen */
.partners__logo-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    background: #F5F2EA;
    border: 1px dashed #D8CFB8;
    border-radius: 8px;
    color: #A8894A;
    font-family: var(--font-sans);
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    text-align: center;
    padding: 0 12px;
}

.partners__note {
    text-align: center;
    margin: 32px 0 0;
    font-size: 12px;
    color: var(--color-text-muted, #6A6A6A);
    font-style: italic;
}

/* Reduced motion: Marquee statisch */
@media (prefers-reduced-motion: reduce) {
    .partners__track {
        animation: none;
        flex-wrap: wrap;
        justify-content: center;
        width: 100%;
    }
    .partners__marquee {
        -webkit-mask-image: none;
                mask-image: none;
    }
}

/* System — Split-Scroll: links sticky Intro, rechts scrollende Steps -------- */
.system {
    position: relative;
    padding: clamp(72px, 10vw, 140px) 0;
    background: linear-gradient(180deg, #F2EBD9 0%, #ECE3CC 100%);
    color: var(--color-text, #1A1A1A);
    /* clip statt hidden: clippt ohne den scrolling-context zu werden,
       damit das sticky-Element in der linken Spalte weiter funktioniert */
    overflow: clip;
}

.system__cols {
    position: relative;
    z-index: 2;
}
.system__cols {
    display: grid;
    grid-template-columns: minmax(0, 5fr) minmax(0, 7fr);
    gap: clamp(40px, 6vw, 96px);
    /* KEIN align-items: start — sonst wird .system__left nur so hoch wie sein Inhalt
       und das sticky Child verliert seinen Halt, sobald das aside vorbei ist.
       Default 'stretch' lässt das aside auf die volle Grid-Höhe wachsen. */
}

/* Sticky-Intro links — wichtig: kein overflow:hidden auf .system, sonst greift sticky nicht */
.system__intro-sticky {
    position: sticky;
    top: 96px;
}

/* Typografie */
.system__eyebrow {
    color: var(--color-gold-dark, #A8894A);
    font-weight: 700;
    letter-spacing: 0.18em;
    font-size: 12px;
    text-transform: uppercase;
    margin: 0 0 14px;
}
.system__headline,
.system__subheadline {
    font-family: var(--font-serif);
    line-height: 1.2;
    color: var(--color-text, #1A1A1A);
    margin: 0;
}
.system__headline {
    font-size: clamp(1.85rem, 3.8vw, 2.75rem);
    margin-bottom: 20px;
}
.system__subheadline {
    font-size: clamp(1.5rem, 2.8vw, 2rem);
    margin-bottom: 8px;
}
.system__body {
    font-size: 1.05rem;
    line-height: 1.7;
    color: var(--color-text-muted, #4A4A4A);
    margin: 0;
    max-width: 44ch;
}

/* Rechte Spalte */
.system__right {
    display: flex;
    flex-direction: column;
    gap: clamp(40px, 5vw, 64px);
}
.system__process-header {
    margin-bottom: clamp(8px, 1vw, 16px);
}

/* Steps untereinander */
.system__steps {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: clamp(28px, 3.5vw, 48px);
}
.system__step {
    background: rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(168, 137, 74, 0.22);
    border-radius: 15px;
    padding: clamp(28px, 3.5vw, 40px);
    display: flex;
    gap: clamp(20px, 2.5vw, 28px);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    /* Genug Höhe, damit jeder Step beim Scrollen "atmet" */
    min-height: 220px;
    align-items: center;
}
.system__step:hover {
    transform: translateY(-2px);
    box-shadow: 0 18px 40px rgba(26, 26, 26, 0.06);
}
.system__step-number {
    flex: 0 0 auto;
    font-family: var(--font-serif);
    font-size: clamp(2.4rem, 4vw, 3.4rem);
    font-weight: 700;
    line-height: 1;
    color: var(--color-gold, #C9A961);
    letter-spacing: 0.02em;
    min-width: 72px;
}
.system__step-text { flex: 1 1 auto; min-width: 0; }
.system__step-title {
    font-family: var(--font-serif);
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--color-text, #1A1A1A);
    margin: 0 0 10px;
    line-height: 1.3;
}
.system__step-body {
    font-size: 0.98rem;
    line-height: 1.65;
    color: var(--color-text-muted, #4A4A4A);
    margin: 0;
}

/* System-Volume — eigener dunkler Block ------------------------------------ */
.system-volume {
    padding: clamp(72px, 10vw, 140px) 0;
    /* Mehrschichtiger Background:
       - Radialer Goldschimmer von oben mittig
       - Sekundärer Schimmer aus der unteren Ecke
       - Vertikaler Verlauf als Basis */
    background:
        radial-gradient(ellipse 80% 60% at 50% 0%, rgba(201, 169, 97, 0.14) 0%, transparent 60%),
        radial-gradient(ellipse 60% 40% at 80% 100%, rgba(201, 169, 97, 0.08) 0%, transparent 60%),
        linear-gradient(180deg, #1A1A1A 0%, #0E0E0E 100%);
    color: var(--color-text-on-dark, #FFFFFF);
    position: relative;
    overflow: hidden;
}
.system-volume__header {
    text-align: center;
    max-width: 760px;
    margin: 0 auto clamp(40px, 5vw, 64px);
    position: relative;
}
.system-volume__eyebrow {
    color: var(--color-gold, #C9A961);
    font-weight: 700;
    letter-spacing: 0.18em;
    font-size: 12px;
    text-transform: uppercase;
    margin: 0 0 14px;
}
.system-volume__headline {
    font-family: var(--font-serif);
    font-size: clamp(1.85rem, 3.8vw, 2.75rem);
    line-height: 1.2;
    margin: 0;
    color: #FFFFFF;
}
.system-volume__stats {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: clamp(16px, 2vw, 24px);
    position: relative;
}
.system-volume__stat {
    background:
        radial-gradient(ellipse 90% 70% at 100% 100%, rgba(201, 169, 97, 0.10) 0%, transparent 70%),
        rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(201, 169, 97, 0.22);
    border-radius: 15px;
    padding: clamp(28px, 3.2vw, 36px) clamp(22px, 2.4vw, 28px);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}
.system-volume__stat:hover {
    border-color: rgba(201, 169, 97, 0.4);
}

/* Reveal-Override für die Stats: langsamer + größerer Slide von unten */
.system-volume__stat[data-reveal] {
    transform: translateY(56px);
    transition: opacity 1.4s cubic-bezier(0.22, 1, 0.36, 1),
                transform 1.4s cubic-bezier(0.22, 1, 0.36, 1);
}
.system-volume__stat[data-reveal].is-visible {
    transform: translateY(0);
}
.system-volume__stat-value {
    font-family: var(--font-serif);
    font-size: clamp(1.85rem, 3.2vw, 2.5rem);
    font-weight: 700;
    color: var(--color-gold, #C9A961);
    line-height: 1.05;
    margin: 0 0 12px;
    letter-spacing: 0.01em;
}
.system-volume__stat-label {
    font-size: 0.9rem;
    line-height: 1.5;
    color: rgba(255, 255, 255, 0.72);
    margin: 0;
}

/* Mobile ---------------------------------------------------------------------*/
@media (max-width: 860px) {
    .system__cols {
        grid-template-columns: 1fr;
        gap: 40px;
    }
    /* Sticky deaktivieren auf mobile — alles linear lesen */
    .system__intro-sticky {
        position: static;
    }
    .system-volume__stats {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}
@media (max-width: 480px) {
    .system__step {
        flex-direction: column;
        gap: 12px;
        min-height: auto;
    }
    .system-volume__stats {
        grid-template-columns: 1fr;
    }
}

/* Rechner-Promo — CTA-Block (2-Spalten: Bild links, Text rechts) ----------- */
.rechner-promo {
    position: relative;
    padding: clamp(72px, 10vw, 140px) 0;
    background:
        radial-gradient(ellipse 80% 60% at 50% 0%, rgba(201, 169, 97, 0.10) 0%, transparent 60%),
        radial-gradient(ellipse 50% 40% at 100% 100%, rgba(201, 169, 97, 0.06) 0%, transparent 70%),
        var(--color-bg, #FAF7F0);
    overflow: hidden;
}
.rechner-promo__inner {
    display: grid;
    grid-template-columns: minmax(0, 2fr) minmax(0, 3fr);
    gap: clamp(40px, 6vw, 96px);
    align-items: center;
}

/* Bild + Shapes (links) */
.rechner-promo__visual {
    position: relative;
    width: 100%;
    max-width: 460px;
    margin: 0 auto;
}
.rechner-promo__image-wrap {
    position: relative;
    z-index: 2;
    width: 100%;
    height: 100%;
}
.rechner-promo__image {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}
.rechner-promo__shape {
    position: absolute;
    border-radius: 15px;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    transition: transform 1.2s cubic-bezier(0.22, 1, 0.36, 1) 0.2s;
}
.rechner-promo__shape--gold {
    width: 22.9%;
    aspect-ratio: 1 / 1;
    top: -7%;
    right: -10%;
    background: rgba(201, 169, 97, 0.55);
    z-index: 1;
    transform: translate(-12px, 12px);
}
.rechner-promo__shape--dark {
    width: 27.3%;
    aspect-ratio: 1 / 1;
    bottom: -6%;
    left: -8%;
    background: rgba(26, 26, 26, 0.55);
    z-index: 2;
    transform: translate(12px, -12px);
}
.rechner-promo__visual.is-visible .rechner-promo__shape--gold,
.rechner-promo__visual.is-visible .rechner-promo__shape--dark {
    transform: translate(0, 0);
}

/* Text (rechts) */
.rechner-promo__text {
    max-width: 70ch;
}
.rechner-promo__eyebrow {
    color: var(--color-gold-dark, #A8894A);
    font-weight: 700;
    letter-spacing: 0.18em;
    font-size: 12px;
    text-transform: uppercase;
    margin: 0 0 18px;
}
.rechner-promo__headline {
    font-family: var(--font-serif);
    font-size: clamp(1.85rem, 4vw, 2.85rem);
    line-height: 1.2;
    margin: 0 0 20px;
    color: var(--color-text, #1A1A1A);
}
.rechner-promo__sub {
    font-size: 1.05rem;
    line-height: 1.65;
    color: var(--color-text-muted, #4A4A4A);
    margin: 0 0 36px;
}
.rechner-promo__cta-wrap {
    display: flex;
}
.rechner-promo__cta {
    border-radius: 7px;
    padding: 1rem 2.4rem;
}

/* Mobile */
@media (max-width: 860px) {
    .rechner-promo__inner {
        grid-template-columns: 1fr;
        gap: 48px;
    }
    .rechner-promo__visual {
        max-width: 320px;
    }
    .rechner-promo__cta-wrap {
        justify-content: center;
    }
    .rechner-promo__text {
        text-align: center;
        margin: 0 auto;
    }
}

/* Warum Kapitalanleger — Featured Card (01) + 3 Compact Cards (02–04) ------ */
.investors {
    padding: clamp(72px, 10vw, 140px) 0;
    background: #FFFFFF;
    position: relative;
}
.investors__header {
    text-align: center;
    margin: 0 auto clamp(48px, 6vw, 72px);
}
.investors__eyebrow {
    color: var(--color-gold-dark, #A8894A);
    font-weight: 700;
    letter-spacing: 0.18em;
    font-size: 12px;
    text-transform: uppercase;
    margin: 0 0 14px;
}
.investors__headline {
    font-family: var(--font-serif);
    font-size: clamp(1.85rem, 3.8vw, 2.75rem);
    line-height: 1.2;
    margin: 0 0 18px;
    color: var(--color-text, #1A1A1A);
}
.investors__sub {
    font-size: 1.05rem;
    line-height: 1.6;
    color: var(--color-text-muted, #4A4A4A);
    margin: 0;
}

/* Grid: Featured Card spannt erste Reihe komplett, 3 Compact in zweiter Reihe */
.investors__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(20px, 2.5vw, 28px);
}
.investors__card {
    position: relative;
    background: #FFFFFF;
    border: 1px solid #ECE7DB;
    border-radius: 15px;
    padding: clamp(28px, 3vw, 40px);
    overflow: hidden;
    transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
}
/* Goldene Akzent-Linie oben — alle Cards */
.investors__card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--color-gold, #C9A961) 0%, rgba(201, 169, 97, 0.3) 100%);
}
.investors__card:hover {
    transform: translateY(-4px);
    border-color: rgba(201, 169, 97, 0.4);
    box-shadow: 0 18px 40px rgba(26, 26, 26, 0.06);
}

/* Icon-Circle — runde Goldsand-Fläche um das SVG */
.investors__icon-circle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    border-radius: 50%;
    background: rgba(201, 169, 97, 0.12);
    color: var(--color-gold-dark, #A8894A);
    flex-shrink: 0;
}
.investors__icon-circle svg {
    width: 28px;
    height: 28px;
}
.investors__icon-circle--lg {
    width: 92px;
    height: 92px;
}
.investors__icon-circle--lg svg {
    width: 40px;
    height: 40px;
}

/* Number-Marker (klein, gold) */
.investors__card-number {
    display: inline-block;
    font-family: var(--font-serif);
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.12em;
    color: var(--color-gold-dark, #A8894A);
}

/* Title */
.investors__card-title {
    font-family: var(--font-serif);
    line-height: 1.3;
    color: var(--color-text, #1A1A1A);
    margin: 0;
}

/* Body-Text */
.investors__card-text {
    font-size: 0.95rem;
    line-height: 1.65;
    color: var(--color-text-muted, #4A4A4A);
    margin: 0;
}

/* Goldlinie unter Title (Compact Cards) */
.investors__card-divider {
    display: block;
    width: 40px;
    height: 2px;
    background: var(--color-gold, #C9A961);
    margin: 4px 0;
}

/* === Featured Card (01) — voll-breit, 3 interne Spalten === */
.investors__card--featured {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: auto minmax(0, 1.2fr) minmax(0, 1fr);
    gap: clamp(28px, 4vw, 56px);
    align-items: center;
    padding: clamp(36px, 4vw, 56px);
}
.investors__card--featured .investors__card-icon { display: flex; }
.investors__card--featured .investors__card-main {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.investors__card--featured .investors__card-title {
    font-size: clamp(1.5rem, 2.6vw, 2.1rem);
}
.investors__card--featured .investors__card-text { font-size: 1rem; }

.investors__card-details {
    border-left: 1px solid #ECE7DB;
    padding-left: clamp(24px, 3vw, 36px);
    display: flex;
    flex-direction: column;
    gap: 22px;
}
.investors__detail {
    display: flex;
    gap: 14px;
    align-items: flex-start;
}
.investors__detail-icon {
    color: var(--color-gold, #C9A961);
    flex-shrink: 0;
    display: inline-flex;
    margin-top: 2px;
}
.investors__detail-icon svg {
    width: 22px;
    height: 22px;
}
.investors__detail-text { min-width: 0; }
.investors__detail-title {
    font-family: var(--font-sans);
    font-size: 1rem;
    font-weight: 700;
    color: var(--color-text, #1A1A1A);
    margin: 0 0 4px;
}
.investors__detail-body {
    font-size: 0.9rem;
    line-height: 1.5;
    color: var(--color-text-muted, #4A4A4A);
    margin: 0;
}

/* === Compact Cards (02–04) === */
.investors__card--compact {
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.investors__card--compact .investors__card-head {
    display: flex;
    align-items: center;
    gap: 18px;
    margin-bottom: 4px;
}
.investors__card--compact .investors__card-title {
    font-size: clamp(1.15rem, 1.6vw, 1.35rem);
}

/* Mobile ----------------------------------------------------------------- */
@media (max-width: 960px) {
    .investors__card--featured {
        grid-template-columns: 1fr;
        gap: 28px;
    }
    .investors__card-details {
        border-left: none;
        border-top: 1px solid #ECE7DB;
        padding-left: 0;
        padding-top: 24px;
    }
}
@media (max-width: 720px) {
    .investors__grid {
        grid-template-columns: 1fr;
    }
}

/* Services-Hero — Vollbild mit Foto-BG + zentrierten Text + 2 Buttons ------ */
.services-hero {
    position: relative;
    min-height: 80vh;
    min-height: 80dvh;
    display: flex;
    align-items: center;
    overflow: hidden;
    color: var(--color-text-on-dark, #FFFFFF);
    padding: clamp(72px, 10vh, 140px) 0;
}
.services-hero__media {
    position: absolute;
    inset: 0;
    z-index: 0;
}
.services-hero__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.services-hero__overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
    background: linear-gradient(
        180deg,
        rgba(26, 26, 26, 0.45) 0%,
        rgba(26, 26, 26, 0.75) 100%
    );
}
.services-hero__inner {
    position: relative;
    z-index: 2;
    width: 100%;
    text-align: center;
    padding-top: 72px;     /* Platz für fixed Header */
}
.services-hero__eyebrow {
    color: var(--color-gold-light, #D4B97A);
    max-width: 80%;
    margin: 0 auto 18px;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    line-height: 1.5;
}
.services-hero__headline {
    font-family: var(--font-serif);
    font-size: clamp(2rem, 4.6vw, 3.4rem);
    line-height: 1.15;
    color: #FFFFFF;
    max-width: 28ch;
    margin: 0 auto 24px;
    font-weight: 700;
}
.services-hero__sub {
    color: rgba(255, 255, 255, 0.85);
    font-size: clamp(1rem, 1.4vw, 1.15rem);
    line-height: 1.6;
    max-width: 56ch;
    margin: 0 auto 32px;
}
.services-hero__actions {
    display: flex;
    justify-content: center;
    gap: 14px;
    flex-wrap: wrap;
}
.services-hero__btn {
    border-radius: 7px;
}

@media (max-width: 640px) {
    .services-hero { min-height: 70vh; min-height: 70dvh; }
    .services-hero__actions .btn { flex: 1 1 220px; }
}

/* Services-Stats — heller Block mit transparenten Kacheln ------------------ */
.services-stats {
    padding: clamp(60px, 9vw, 120px) 0;
    background:
        radial-gradient(ellipse 90% 60% at 50% 0%, rgba(201, 169, 97, 0.10) 0%, transparent 60%),
        var(--color-bg, #FAF7F0);
}
.services-stats__header {
    text-align: center;
    max-width: 760px;
    margin: 0 auto clamp(40px, 5vw, 64px);
}
.services-stats__headline {
    font-family: var(--font-serif);
    font-size: clamp(1.75rem, 3.4vw, 2.5rem);
    line-height: 1.2;
    margin: 0;
    color: var(--color-text, #1A1A1A);
}
.services-stats__grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: clamp(16px, 2vw, 24px);
}
.services-stats__tile {
    background:
        radial-gradient(ellipse 90% 70% at 100% 100%, rgba(201, 169, 97, 0.16) 0%, transparent 70%),
        rgba(255, 255, 255, 0.55);
    border: 1px solid rgba(201, 169, 97, 0.28);
    border-radius: 15px;
    padding: clamp(28px, 3.2vw, 36px) clamp(22px, 2.4vw, 28px);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    transition: border-color 0.3s ease, transform 0.3s ease;
}
.services-stats__tile:hover {
    border-color: rgba(201, 169, 97, 0.5);
    transform: translateY(-2px);
}
.services-stats__value {
    font-family: var(--font-serif);
    font-size: clamp(1.85rem, 3.2vw, 2.5rem);
    font-weight: 700;
    color: var(--color-gold-dark, #A8894A);
    line-height: 1.05;
    margin: 0 0 12px;
}
.services-stats__label {
    margin: 0;
    color: var(--color-text-muted, #4A4A4A);
    font-size: 0.9rem;
    line-height: 1.5;
}

/* Reveal-Override: Kacheln slidern langsamer von unten ein */
.services-stats__tile[data-reveal] {
    transform: translateY(56px);
    transition: opacity 1.4s cubic-bezier(0.22, 1, 0.36, 1),
                transform 1.4s cubic-bezier(0.22, 1, 0.36, 1);
}
.services-stats__tile[data-reveal].is-visible {
    transform: translateY(0);
}

@media (max-width: 860px) {
    .services-stats__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 480px) {
    .services-stats__grid { grid-template-columns: 1fr; }
}

/* Services-Transparency — 2 Spalten Text + Dashboard-Bild ------------------ */
.services-transparency {
    padding: clamp(72px, 10vw, 140px) 0;
    background: #FFFFFF;
}
.services-transparency__inner {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: clamp(40px, 6vw, 88px);
    align-items: center;
}
.services-transparency__text { min-width: 0; }
.services-transparency__eyebrow {
    color: var(--color-gold-dark, #A8894A);
    font-weight: 700;
    letter-spacing: 0.18em;
    font-size: 12px;
    text-transform: uppercase;
    margin: 0 0 14px;
}
.services-transparency__headline {
    font-family: var(--font-serif);
    font-size: clamp(1.85rem, 3.6vw, 2.6rem);
    line-height: 1.2;
    margin: 0 0 28px;
    color: var(--color-text, #1A1A1A);
    max-width: 22ch;
}
.services-transparency__list {
    list-style: none;
    margin: 0 0 32px;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.services-transparency__list li {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    color: var(--color-text-muted, #4A4A4A);
    font-size: 0.98rem;
    line-height: 1.55;
}
.services-transparency__check {
    flex-shrink: 0;
    display: inline-flex;
    color: var(--color-gold, #C9A961);
    margin-top: 2px;
}
.services-transparency__check svg {
    width: 22px;
    height: 22px;
}
.services-transparency__cta { border-radius: 7px; }

/* Visual mit Shape-Overlays */
.services-transparency__visual {
    position: relative;
    aspect-ratio: 4 / 3;
    width: 100%;
    max-width: 560px;
    margin: 0 auto;
}
.services-transparency__image-wrap {
    position: relative;
    z-index: 2;
    width: 100%;
    height: 100%;
    border-radius: 15px;
    overflow: hidden;
    background: #ffffff;
    box-shadow: 0 30px 60px rgba(26, 26, 26, 0.14);
}
.services-transparency__image-wrap img {
    width: 90%;
    height: 90%;
    display: block;
    object-fit: cover;
}
.services-transparency__image-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    color: #B8AC8B;
    font-style: italic;
    border: 1.5px dashed #D8CFB8;
    border-radius: 15px;
}
.services-transparency__shape {
    position: absolute;
    border-radius: 15px;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    transition: transform 1.2s cubic-bezier(0.22, 1, 0.36, 1) 0.2s;
}
.services-transparency__shape--gold {
    width: 50%;
    aspect-ratio: 1 / 1;
    top: -8%;
    right: -8%;
    background: rgba(201, 169, 97, 0.55);
    z-index: 1;
    transform: translate(-12px, 12px);
}
.services-transparency__shape--dark {
    width: 38%;
    aspect-ratio: 1 / 1;
    bottom: -7%;
    left: -7%;
    background: rgba(26, 26, 26, 0.55);
    z-index: 2;
    transform: translate(12px, -12px);
}
.services-transparency__visual.is-visible .services-transparency__shape--gold,
.services-transparency__visual.is-visible .services-transparency__shape--dark {
    transform: translate(0, 0);
}

@media (max-width: 860px) {
    .services-transparency__inner {
        grid-template-columns: 1fr;
        gap: 56px;
    }
    .services-transparency__visual { max-width: 420px; }
}

/* Services-Why — kompakter zentrierter Block ------------------------------- */
.services-why {
    padding: clamp(60px, 8vw, 100px) 0;
    background: linear-gradient(180deg, #F2EBD9 0%, #ECE3CC 100%);
    text-align: center;
}
.services-why__inner {
    max-width: 80%;
    margin: 0 auto;
}
.services-why__eyebrow {
    color: var(--color-gold-dark, #A8894A);
    font-weight: 700;
    letter-spacing: 0.18em;
    font-size: 12px;
    text-transform: uppercase;
    margin: 0 0 14px;
}
.services-why__headline {
    font-family: var(--font-serif);
    font-size: clamp(1.6rem, 3vw, 2.2rem);
    line-height: 1.25;
    margin: 0 0 18px;
    color: var(--color-text, #1A1A1A);
}
.services-why__body {
    font-size: 1rem;
    line-height: 1.7;
    color: var(--color-text-muted, #4A4A4A);
    margin: 0 0 28px;
}
.services-why__cta { border-radius: 7px; }

/* Services-Comparison — 2 Cards Andere vs. Seven Real --------------------- */
.services-comparison {
    padding: clamp(72px, 10vw, 140px) 0;
    background: #FFFFFF;
}
.services-comparison__header {
    text-align: center;
    max-width: 760px;
    margin: 0 auto clamp(40px, 5vw, 64px);
}
.services-comparison__eyebrow {
    color: var(--color-gold-dark, #A8894A);
    font-weight: 700;
    letter-spacing: 0.18em;
    font-size: 12px;
    text-transform: uppercase;
    margin: 0 0 14px;
}
.services-comparison__headline {
    font-family: var(--font-serif);
    font-size: clamp(1.85rem, 3.6vw, 2.6rem);
    line-height: 1.2;
    margin: 0;
    color: var(--color-text, #1A1A1A);
}
.services-comparison__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(20px, 2.5vw, 28px);
}
.services-comparison__card {
    position: relative;
    border-radius: 15px;
    padding: clamp(28px, 3vw, 40px);
    overflow: hidden;
}
.services-comparison__card--others {
    background: #F5F4F0;
    border: 1px solid #E5E1D8;
    color: var(--color-text-muted, #4A4A4A);
}
.services-comparison__card--us {
    background:
        radial-gradient(ellipse 90% 60% at 100% 0%, rgba(201, 169, 97, 0.16) 0%, transparent 65%),
        #FFFFFF;
    border: 1px solid rgba(201, 169, 97, 0.4);
    box-shadow: 0 18px 50px rgba(201, 169, 97, 0.12);
}
.services-comparison__card--us::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--color-gold, #C9A961) 0%, rgba(201,169,97,0.3) 100%);
}
.services-comparison__card-head {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 20px;
    padding-bottom: 16px;
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
}
.services-comparison__card--us .services-comparison__card-head {
    border-bottom-color: rgba(201, 169, 97, 0.25);
}
.services-comparison__card-icon {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: rgba(0, 0, 0, 0.06);
    color: var(--color-text-muted, #6A6A6A);
    font-size: 1.25rem;
    font-weight: 600;
    line-height: 1;
}
.services-comparison__card-icon--check {
    background: rgba(201, 169, 97, 0.18);
    color: var(--color-gold-dark, #A8894A);
}
.services-comparison__card-icon--check svg {
    width: 18px;
    height: 18px;
}
.services-comparison__card-title {
    font-family: var(--font-serif);
    font-size: clamp(1.2rem, 1.8vw, 1.4rem);
    margin: 0;
    color: var(--color-text, #1A1A1A);
}
.services-comparison__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 14px;
    font-size: 0.95rem;
    line-height: 1.6;
}
.services-comparison__list li {
    position: relative;
    padding-left: 22px;
}
.services-comparison__list li::before {
    content: '';
    position: absolute;
    left: 4px;
    top: 0.55em;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: rgba(0, 0, 0, 0.25);
}
.services-comparison__list--accent li::before {
    background: var(--color-gold, #C9A961);
}

@media (max-width: 860px) {
    .services-comparison__grid { grid-template-columns: 1fr; }
}

/* Services-CTA — dunkler Schluss-Banner ------------------------------------ */
.services-cta {
    padding: clamp(72px, 10vw, 140px) 0;
    background:
        radial-gradient(ellipse 80% 60% at 50% 0%, rgba(201, 169, 97, 0.16) 0%, transparent 60%),
        radial-gradient(ellipse 60% 50% at 100% 100%, rgba(201, 169, 97, 0.08) 0%, transparent 60%),
        linear-gradient(180deg, #1A1A1A 0%, #0E0E0E 100%);
    color: var(--color-text-on-dark, #FFFFFF);
    text-align: center;
}
.services-cta__inner {
    max-width: 820px;
    margin: 0 auto;
}
.services-cta__eyebrow {
    color: var(--color-gold, #C9A961);
    font-weight: 700;
    letter-spacing: 0.18em;
    font-size: 12px;
    text-transform: uppercase;
    margin: 0 0 16px;
}
.services-cta__headline {
    font-family: var(--font-serif);
    font-size: clamp(1.85rem, 3.8vw, 2.75rem);
    line-height: 1.2;
    margin: 0 0 20px;
    color: #FFFFFF;
}
.services-cta__sub {
    color: rgba(255, 255, 255, 0.78);
    font-size: 1rem;
    line-height: 1.7;
    margin: 0 0 32px;
    max-width: 56ch;
    margin-left: auto;
    margin-right: auto;
}
.services-cta__btn { border-radius: 7px; }

/* Splash-Landingpage --------------------------------------------------------- */
.landing {
    position: relative;
    min-height: 100vh;
    min-height: 100dvh;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    background: var(--color-black, #1A1A1A);
    color: var(--color-text-on-dark, #FFFFFF);
}
.landing__media {
    position: absolute;
    inset: 0;
    z-index: 0;
}
.landing__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transform: scale(1.05);
    animation: landing-zoom 18s ease-in-out infinite alternate;
}
.landing__overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
    background: radial-gradient(
        ellipse at center,
        rgba(26, 26, 26, 0.45) 0%,
        rgba(26, 26, 26, 0.85) 100%
    );
}
.landing__content {
    position: relative;
    z-index: 2;
    padding: 0 24px;
    text-align: center;
    animation: landing-fade-in 1.4s ease-out both;
}
.landing__brand {
    font-family: var(--font-serif);
    font-size: clamp(2.25rem, 7vw, 5rem);
    line-height: 1.05;
    letter-spacing: 0.02em;
    margin: 0;
    font-weight: 700;
    color: var(--color-text-on-dark, #FFFFFF);
}
.landing__brand-mark {
    color: var(--color-gold, #C9A961);
}
.landing__caption {
    margin: 18px auto 0;
    max-width: 56ch;
    font-family: var(--font-sans);
    font-size: clamp(12px, 1.3vw, 14px);
    letter-spacing: 0.04em;
    color: rgba(255, 255, 255, 0.72);
    line-height: 1.5;
}

@keyframes landing-zoom {
    from { transform: scale(1.05); }
    to   { transform: scale(1.15); }
}
@keyframes landing-fade-in {
    from { opacity: 0; transform: translateY(10px); }
    to   { opacity: 1; transform: translateY(0); }
}

@media (prefers-reduced-motion: reduce) {
    .landing__image {
        animation: none;
        transform: none;
    }
    .landing__content {
        animation: none;
    }
}

/* -----------------------------------------------------------------------------
   7. Footer
   ----------------------------------------------------------------------------- */
.site-footer {
    background: var(--color-black);
    color: var(--color-text-on-dark);
    padding-top: var(--space-2xl);
    padding-bottom: var(--space-lg);
}

.site-footer__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-xl);
}

@media (min-width: 768px) {
    .site-footer__grid {
        grid-template-columns: repeat(3, 1fr);
        gap: var(--space-lg);
    }
}

.site-footer__col {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
}

.site-footer__logo {
    display: inline-flex;
    align-items: center;
    line-height: 0;
    transition: opacity 0.2s ease;
}
.site-footer__logo:hover {
    opacity: 0.85;
}

.site-footer__logo-img {
    display: block;
    height: clamp(40px, 4.5vw, 60px);
    width: auto;
    max-width: 240px;
    object-fit: contain;
}

@media (max-width: 600px) {
    .site-footer__logo-img {
        height: 40px;
        max-width: 180px;
    }
}

.site-footer__address {
    font-style: normal;
    color: var(--color-text-fade);
    line-height: 1.8;
    font-size: var(--fs-label);
}
.site-footer__address-label {
    color: var(--color-text-fade);
    margin-right: 6px;
    opacity: 0.75;
}
.site-footer__tagline {
    margin: 16px 0 0;
    color: var(--color-text-fade);
    line-height: 1.6;
    font-size: var(--fs-label);
    max-width: 36ch;
}

.site-footer__address a {
    color: var(--color-text-fade);
    transition: color 0.15s ease;
}

.site-footer__address a:hover {
    color: var(--color-gold-light);
}

.site-footer__socials {
    display: flex;
    gap: var(--space-sm);
}

.site-footer__social-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border: 1px solid var(--color-gold-dark);
    border-radius: var(--radius-sm);
    color: var(--color-gold);
    transition: background 0.15s ease, color 0.15s ease;
}

.site-footer__social-link:hover {
    background: var(--color-gold);
    color: var(--color-black);
}

.site-footer__social-link svg {
    width: 18px;
    height: 18px;
}

.site-footer__col-title {
    font-family: var(--font-sans);
    font-size: var(--fs-eyebrow);
    text-transform: uppercase;
    letter-spacing: var(--ls-widest);
    color: var(--color-gold-dark);
    margin: 0;
}

.site-footer__nav-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
}

.site-footer__nav-link {
    color: var(--color-text-fade);
    font-size: var(--fs-body);
    transition: color 0.15s ease;
}

.site-footer__nav-link:hover {
    color: var(--color-gold-light);
}

.site-footer__placeholder {
    font-size: var(--fs-label);
    color: var(--color-text-light);
    font-style: italic;
}

.site-footer__bottom {
    margin-top: var(--space-xl);
    padding-top: var(--space-md);
    border-top: 1px solid rgba(201, 169, 97, 0.2);
    display: flex;
    flex-direction: column;
    gap: var(--space-xs);
    font-size: 11px;
    color: var(--color-text-light);
    letter-spacing: var(--ls-tight);
}

@media (min-width: 768px) {
    .site-footer__bottom {
        flex-direction: row;
        justify-content: space-between;
    }
}

/* -----------------------------------------------------------------------------
   8. Component: kpi-cards   (Mockup: srs_03)
   ----------------------------------------------------------------------------- */
.kpi-cards__heading {
    margin-bottom: var(--space-lg);
}

.kpi-cards__badge {
    margin-bottom: var(--space-md);
}

.kpi-cards__headline {
    margin-bottom: 0;
}

.kpi-cards__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-md);
}

@media (min-width: 600px) {
    .kpi-cards__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 960px) {
    .kpi-cards__grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

.kpi-cards__card {
    display: flex;
    flex-direction: column;
    padding: var(--space-lg) var(--space-md);
    background: var(--color-bg-cream);
    border: 1px solid var(--color-gold);
    border-radius: var(--radius-md);
    color: var(--color-text);
    min-height: 260px;
}

.kpi-cards__card--placeholder {
    border-style: dashed;
}

.kpi-cards__card--dark {
    background: var(--color-black);
    color: var(--color-text-on-dark);
    border: none;
}

.kpi-cards__icon {
    color: var(--color-gold-dark);
    margin-bottom: var(--space-md);
    width: 32px;
    height: 32px;
    display: inline-flex;
    align-items: center;
}

.kpi-cards__card--dark .kpi-cards__icon {
    color: var(--color-gold-light);
}

.kpi-cards__icon svg {
    width: 100%;
    height: 100%;
}

.kpi-cards__value {
    font-family: var(--font-serif);
    font-style: italic;
    font-size: var(--fs-stat);
    line-height: 1;
    color: var(--color-text);
    margin: var(--space-md) 0 var(--space-xs);
    word-break: break-word;
}

.kpi-cards__card--dark .kpi-cards__value {
    /* Dunkle Karte hat oft längeren Wert (€ X,X Mio.) — eine Stufe kleiner */
    color: var(--color-gold-light);
    font-size: clamp(1.75rem, 4vw, 2.875rem);
}

.kpi-cards__divider {
    display: block;
    width: 60px;
    height: 1.5px;
    background: var(--color-gold);
    margin-bottom: var(--space-sm);
}

.kpi-cards__label {
    font-family: var(--font-sans);
    font-size: var(--fs-label);
    text-transform: uppercase;
    letter-spacing: var(--ls-medium);
    margin: 0 0 4px;
}

.kpi-cards__sublabel {
    font-family: var(--font-sans);
    font-size: 11px;
    color: var(--color-text-muted);
    margin: 0;
}

.kpi-cards__card--dark .kpi-cards__sublabel {
    color: var(--color-text-fade);
}

.kpi-cards__delta {
    font-family: var(--font-serif);
    font-style: italic;
    font-size: 1.375rem;
    color: var(--color-gold-dark);
    margin: auto 0 4px;
}

.kpi-cards__card--dark .kpi-cards__delta {
    color: var(--color-gold-light);
}

.kpi-cards__delta-label {
    font-family: var(--font-sans);
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: var(--ls-tight);
    color: var(--color-text-light);
    margin: 0;
}

.kpi-cards__footnote {
    margin-top: var(--space-lg);
}

/* -----------------------------------------------------------------------------
   8b. Component: services-grid   (Mockup: srs_12)
   ----------------------------------------------------------------------------- */
.services-grid__heading {
    margin-bottom: var(--space-xl);
}

.services-grid__subline {
    color: var(--color-text-muted);
    max-width: 60ch;
    margin-top: var(--space-sm);
    line-height: 1.6;
}

.services-grid__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-md);
}

@media (min-width: 600px) {
    .services-grid__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 960px) {
    .services-grid__grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

.services-grid__card {
    position: relative;
    display: flex;
    flex-direction: column;
    background: var(--color-bg-cream);
    border: 1px solid var(--color-gold);
    border-radius: var(--radius-md);
    padding: var(--space-lg) var(--space-md) var(--space-md);
    overflow: hidden;
    color: var(--color-text);
    min-height: 240px;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.services-grid__card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(26, 26, 26, 0.08);
}

.services-grid__card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 4px;
    background: var(--color-gold);
}

.services-grid__card--dark {
    background: var(--color-black);
    color: var(--color-text-on-dark);
    border: none;
}

.services-grid__card--dark::before {
    background: var(--color-gold-light);
}

.services-grid__icon {
    color: var(--color-gold-dark);
    margin: var(--space-sm) 0 var(--space-lg);
    width: 40px;
    height: 40px;
}

.services-grid__card--dark .services-grid__icon {
    color: var(--color-gold-light);
}

.services-grid__icon svg {
    width: 100%;
    height: 100%;
}

.services-grid__title {
    font-family: var(--font-serif);
    font-size: 1rem;
    color: var(--color-text);
    margin: 0 0 var(--space-xs);
}

.services-grid__card--dark .services-grid__title {
    color: var(--color-text-on-dark);
}

.services-grid__divider {
    display: block;
    width: 60px;
    height: 1.5px;
    background: var(--color-gold);
    margin-bottom: var(--space-sm);
}

.services-grid__description {
    font-family: var(--font-sans);
    font-size: var(--fs-body);
    color: var(--color-text-muted);
    line-height: 1.5;
    margin: 0;
}

.services-grid__card--dark .services-grid__description {
    color: var(--color-text-fade);
}

/* -----------------------------------------------------------------------------
   8c. Component: team   (Mockup: srs_16)
   ----------------------------------------------------------------------------- */
.team__heading {
    margin-bottom: var(--space-xl);
}

.team__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-md);
}

@media (min-width: 600px) {
    .team__grid { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 960px) {
    .team__grid { grid-template-columns: repeat(3, 1fr); }
}

@media (min-width: 1280px) {
    .team__grid { grid-template-columns: repeat(5, 1fr); }
}

.team__card {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    background: var(--color-bg-cream);
    border: 1px solid var(--color-gold);
    border-radius: var(--radius-md);
    padding: var(--space-xl) var(--space-md) var(--space-lg);
    min-height: 360px;
}

.team__card--placeholder {
    border-style: dashed;
}

.team__badge {
    position: absolute;
    top: 14px;
    left: 14px;
}

.team__avatar {
    width: 112px;
    height: 112px;
    border-radius: 50%;
    background: var(--color-black);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: var(--space-md);
    flex-shrink: 0;
}

.team__avatar--empty {
    background: transparent;
    border: 1.5px dashed var(--color-gold);
    color: var(--color-gold-dark);
}

.team__avatar--empty svg {
    width: 60%;
    height: 60%;
}

.team__initials {
    font-family: var(--font-serif);
    font-size: 2.25rem;
    color: var(--color-gold-light);
    letter-spacing: 1px;
    line-height: 1;
}

.team__name {
    font-family: var(--font-serif);
    font-size: 1.25rem;
    color: var(--color-text);
    margin: 0 0 var(--space-xs);
    letter-spacing: 1px;
}

.team__name--muted {
    color: var(--color-text-muted);
    font-style: italic;
}

.team__divider {
    display: block;
    width: 60px;
    height: 1px;
    background: var(--color-gold);
    margin-bottom: var(--space-sm);
}

.team__role {
    font-family: var(--font-sans);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: var(--ls-wide);
    color: var(--color-gold-dark);
    margin: 0 0 var(--space-sm);
}

.team__tagline {
    font-family: var(--font-sans);
    font-size: 11px;
    color: var(--color-text-muted);
    line-height: 1.5;
    margin: 0 0 var(--space-md);
}

.team__linkedin {
    margin-top: auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    background: var(--color-black);
    border-radius: var(--radius-sm);
    color: var(--color-gold-light);
    transition: transform 0.15s ease, background 0.15s ease;
}

.team__linkedin:hover {
    background: var(--color-gold-dark);
    color: var(--color-black);
    transform: translateY(-1px);
}

.team__linkedin svg {
    width: 16px;
    height: 16px;
}

.team__placeholder-note {
    margin-top: auto;
    font-size: 9px;
    text-transform: uppercase;
    letter-spacing: var(--ls-medium);
    color: var(--color-text-fade);
    font-style: italic;
}

/* -----------------------------------------------------------------------------
   8d. Component: testimonial   (Mockup: srs_11)
   ----------------------------------------------------------------------------- */
.testimonial__card {
    position: relative;
    background: var(--color-bg-cream);
    border: 1px solid var(--color-gold);
    border-radius: var(--radius-lg);
    padding: var(--space-xl) var(--space-lg) var(--space-lg);
    overflow: hidden;
}

.testimonial__card--placeholder {
    border-style: dashed;
}

.testimonial__badge {
    position: absolute;
    top: 20px;
    left: 20px;
}

.testimonial__layout {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-lg);
    align-items: start;
}

@media (min-width: 768px) {
    .testimonial__layout {
        grid-template-columns: 1fr auto;
        gap: var(--space-xl);
    }
}

.testimonial__main {
    position: relative;
    padding-top: var(--space-lg);
}

.testimonial__quote-mark {
    position: absolute;
    top: -1.5rem;
    left: -0.5rem;
    font-family: var(--font-serif);
    font-size: 9rem;
    line-height: 1;
    color: var(--color-gold);
    opacity: 0.35;
    pointer-events: none;
    user-select: none;
}

.testimonial__quote {
    font-family: var(--font-serif);
    font-style: italic;
    font-size: 1.125rem;
    line-height: 1.55;
    color: var(--color-text);
    margin: 0;
    position: relative;
    z-index: 1;
    quotes: none;
}

@media (min-width: 768px) {
    .testimonial__quote {
        font-size: 1.25rem;
    }
}

.testimonial__divider {
    display: block;
    width: 100px;
    height: 1.5px;
    background: var(--color-gold);
    margin: var(--space-md) 0;
}

.testimonial__author {
    display: flex;
    align-items: center;
    gap: var(--space-md);
}

.testimonial__avatar {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    background: var(--color-black);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.testimonial__avatar--empty {
    background: transparent;
    border: 1.5px dashed var(--color-gold);
    color: var(--color-gold-dark);
}

.testimonial__avatar--empty svg {
    width: 60%;
    height: 60%;
}

.testimonial__initials {
    font-family: var(--font-serif);
    font-size: 1.25rem;
    color: var(--color-gold-light);
    line-height: 1;
}

.testimonial__author-meta {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.testimonial__author-name {
    font-family: var(--font-serif);
    font-size: 1.125rem;
    font-style: italic;
    color: var(--color-text-muted);
    letter-spacing: 1px;
    margin: 0;
}

.testimonial__author-position {
    font-family: var(--font-sans);
    font-size: 12px;
    font-style: italic;
    color: var(--color-text-muted);
    letter-spacing: 1px;
    margin: 0;
}

.testimonial__author-project {
    font-family: var(--font-sans);
    font-size: 11px;
    font-style: italic;
    color: var(--color-gold-dark);
    letter-spacing: var(--ls-medium);
    text-transform: uppercase;
    margin: 0;
}

.testimonial__stats {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
    flex-shrink: 0;
}

.testimonial__stat {
    text-align: center;
    padding: var(--space-sm) var(--space-md);
    border-radius: var(--radius-sm);
    min-width: 140px;
}

.testimonial__stat--light {
    background: var(--color-bg);
    border: 1px dashed var(--color-gold);
}

.testimonial__stat--dark {
    background: var(--color-black);
}

.testimonial__stat-value {
    font-family: var(--font-serif);
    font-style: italic;
    font-size: 1.5rem;
    margin: 0 0 4px;
    line-height: 1;
}

.testimonial__stat--light .testimonial__stat-value {
    color: var(--color-gold-dark);
}

.testimonial__stat--dark .testimonial__stat-value {
    color: var(--color-gold-light);
}

.testimonial__stat-label {
    font-family: var(--font-sans);
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: var(--ls-medium);
    margin: 0;
}

.testimonial__stat--light .testimonial__stat-label {
    color: var(--color-text-muted);
}

.testimonial__stat--dark .testimonial__stat-label {
    color: var(--color-bg-cream);
}

.testimonial__footnote {
    margin-top: var(--space-lg);
}

/* -----------------------------------------------------------------------------
   8e. Component: cta-strategie   (Mockup: srs_08)
   ----------------------------------------------------------------------------- */
.cta-strategie__card {
    background: var(--color-black);
    border: 1px solid var(--color-gold);
    border-radius: var(--radius-lg);
    padding: var(--space-lg);
    color: var(--color-text-on-dark);
}

@media (min-width: 768px) {
    .cta-strategie__card {
        padding: var(--space-xl);
    }
}

.cta-strategie__top {
    display: flex;
    align-items: flex-start;
    gap: var(--space-md);
    margin-bottom: var(--space-lg);
}

@media (min-width: 768px) {
    .cta-strategie__top {
        gap: var(--space-lg);
    }
}

.cta-strategie__icon {
    color: var(--color-gold-lightXX);
    flex-shrink: 0;
    width: 40px;
    height: 44px;
    margin-top: 4px;
}

.cta-strategie__icon svg {
    width: 100%;
    height: 100%;
}

.cta-strategie__text {
    flex: 1;
    min-width: 0;
}

.cta-strategie__headline {
    font-family: var(--font-serif);
    font-size: clamp(1.125rem, 2.2vw, 1.5rem);
    letter-spacing: 1px;
    line-height: 1.4;
    color: var(--color-text-on-dark);
    margin: 0 0 var(--space-sm);
}

.cta-strategie__headline-accent {
    display: block;
    color: var(--color-gold-lightXX);
}

.cta-strategie__divider {
    display: block;
    width: 130px;
    height: 1px;
    background: var(--color-gold);
    margin-bottom: var(--space-sm);
}

.cta-strategie__subline {
    font-family: var(--font-sans);
    font-size: var(--fs-label);
    color: var(--color-text-fade);
    line-height: 1.6;
    margin: 0;
}

.cta-strategie__cta {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-sm);
    width: 100%;
    padding: 1.125rem 1.5rem;
    background: var(--color-gold-lightXX);
    color: var(--color-black);
    font-family: var(--font-sans);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: var(--ls-medium);
    font-size: var(--fs-label);
    border-radius: var(--radius-sm);
    text-align: center;
    transition: background 0.15s ease, transform 0.15s ease;
    max-width: 70%;
    border-radius: 33px;
}

.cta-strategie__cta:hover {
    background: var(--color-gold-light);
    transform: translateY(-1px);
}

.cta-strategie__cta svg {
    flex-shrink: 0;
}

/* -----------------------------------------------------------------------------
   8f. Component: project-pitch   (Mockup: srs_05)
   ----------------------------------------------------------------------------- */
.project-pitch__layout {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-xl);
    align-items: center;
}

@media (min-width: 960px) {
    .project-pitch__layout {
        grid-template-columns: 1fr 1fr;
        gap: var(--space-2xl);
    }
}

.project-pitch__visual {
    width: 100%;
}

.project-pitch__visual svg {
    width: 100%;
    height: auto;
    display: block;
    border-radius: var(--radius-md);
}

.project-pitch__headline {
    font-family: var(--font-serif);
    font-size: clamp(1.5rem, 3vw, 2rem);
    text-transform: uppercase;
    letter-spacing: 1px;
    line-height: 1.3;
    color: var(--color-text);
    margin: 0 0 var(--space-md);
}

.project-pitch__headline-line {
    display: block;
}

.project-pitch__headline-line--accent {
    color: var(--color-gold-dark);
}

.project-pitch__benefits {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
    list-style: none;
    padding: 0;
    margin: var(--space-lg) 0 0;
}

.project-pitch__benefit {
    display: flex;
    align-items: center;
    gap: var(--space-md);
}

.project-pitch__check {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    flex-shrink: 0;
}

.project-pitch__check svg {
    width: 100%;
    height: 100%;
    fill: none;
}

.project-pitch__check-circle {
    stroke: var(--color-gold);
    stroke-width: 1.5;
    fill: none;
}

.project-pitch__check-mark {
    stroke: var(--color-gold-dark);
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
    fill: none;
}

.project-pitch__benefit-text {
    font-family: var(--font-sans);
    font-size: 1rem;
    color: var(--color-text);
    line-height: 1.4;
}

/* -----------------------------------------------------------------------------
   8g. Component: timeline   (Mockup: srs_14)
   Desktop: horizontaler Track mit Linie hinter den Punkten.
   Mobile : vertikaler Stack mit Linie links der Punkte.
   ----------------------------------------------------------------------------- */
.timeline__heading {
    margin-bottom: var(--space-2xl);
    text-align: left;
}

.timeline__subline {
    color: var(--color-text-muted);
    max-width: 60ch;
    margin-top: var(--space-sm);
    line-height: 1.6;
}

.timeline__track {
    list-style: none;
    padding: 0;
    margin: 0;
    position: relative;
}

.timeline__line {
    /* Wird auf Desktop sichtbar, auf Mobile versteckt */
    display: none;
}

.timeline__phase {
    display: grid;
    grid-template-columns: 36px 1fr;
    grid-template-rows: auto auto;
    column-gap: var(--space-md);
    text-align: left;
    position: relative;
    padding-bottom: var(--space-xl);
}

.timeline__phase:last-child {
    padding-bottom: 0;
}

/* Mobile: Vertikale Verbindungslinie zwischen den Punkten */
.timeline__phase:not(:last-child)::after {
    content: '';
    position: absolute;
    left: 17px; /* (36px Dot - 1.5px Linie) / 2 */
    top: 36px;
    bottom: var(--space-md);
    width: 1.5px;
    background: var(--color-gold);
}

.timeline__meta {
    grid-column: 2;
    grid-row: 1;
    margin-bottom: var(--space-xs);
}

.timeline__period {
    font-family: var(--font-serif);
    font-style: italic;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: var(--ls-wide);
    color: var(--color-gold-dark);
    margin: 0 0 4px;
}

.timeline__title {
    font-family: var(--font-serif);
    font-size: 1.125rem;
    color: var(--color-text);
    margin: 0;
    line-height: 1.2;
}

.timeline__dot {
    grid-column: 1;
    grid-row: 1 / span 2;
    align-self: start;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--color-bg);
    border: 2px solid var(--color-gold);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    z-index: 1;
    position: relative;
}

.timeline__dot::after {
    content: '';
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: var(--color-gold);
}

.timeline__dot--goal {
    width: 44px;
    height: 44px;
    background: var(--color-gold);
    border-color: var(--color-gold-dark);
}

.timeline__dot--goal::after {
    display: none;
}

.timeline__check {
    width: 22px;
    height: 22px;
    fill: none;
    stroke: var(--color-bg);
    stroke-width: 2.5;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.timeline__description {
    grid-column: 2;
    grid-row: 2;
    font-family: var(--font-sans);
    font-size: 12px;
    color: var(--color-text-muted);
    line-height: 1.5;
    margin: 0;
}

.timeline__footnote {
    margin-top: var(--space-xl);
    padding-top: var(--space-md);
    border-top: 1px solid rgba(201, 169, 97, 0.3);
    font-family: var(--font-sans);
    font-size: 11px;
    color: var(--color-gold-dark);
    text-transform: uppercase;
    letter-spacing: var(--ls-wide);
}

/* Desktop: Horizontaler Track */
@media (min-width: 768px) {
    .timeline__track {
        display: flex;
        align-items: stretch;
        gap: 0;
        padding: 0 var(--space-md);
    }

    .timeline__line {
        display: block;
        position: absolute;
        top: 96px; /* Höhe Meta + halbe Dot-Höhe */
        left: calc(100% / 12);   /* Mitte der ersten Phase */
        right: calc(100% / 12);  /* Mitte der letzten Phase */
        height: 1.5px;
        background: var(--color-gold);
        z-index: 0;
    }

    .timeline__phase {
        flex: 1;
        display: flex;
        flex-direction: column;
        align-items: center;
        text-align: center;
        padding: 0 var(--space-xs);
    }

    .timeline__phase:not(:last-child)::after {
        /* Vertikale Mobile-Linie wird auf Desktop versteckt */
        display: none;
    }

    .timeline__meta {
        height: 78px;  /* Fixe Höhe, damit alle Dots auf gleicher Linie sitzen */
        margin-bottom: var(--space-md);
        display: flex;
        flex-direction: column;
        justify-content: flex-end;
        align-items: center;
        text-align: center;
    }

    .timeline__dot {
        align-self: center;
    }

    .timeline__description {
        margin-top: var(--space-md);
        max-width: 18ch;
        text-align: center;
    }

    .timeline__footnote {
        text-align: left;
    }
}

/* -----------------------------------------------------------------------------
   8h. Component: digital-marketing   (Mockup: srs_06)
   ----------------------------------------------------------------------------- */
.digital-marketing__layout {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-xl);
    align-items: center;
}

@media (min-width: 960px) {
    .digital-marketing__layout {
        grid-template-columns: 1fr 1fr;
        gap: var(--space-2xl);
    }
}

.digital-marketing__subline {
    color: var(--color-text-muted);
    max-width: 50ch;
    line-height: 1.6;
    margin: 0 0 var(--space-lg);
}

.digital-marketing__services {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
}

.digital-marketing__service {
    display: flex;
    align-items: center;
    gap: var(--space-md);
}

.digital-marketing__service-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: var(--color-bg-cream);
    border: 1px solid var(--color-gold);
    color: var(--color-gold-dark);
    flex-shrink: 0;
}

.digital-marketing__service-icon svg {
    width: 18px;
    height: 18px;
}

.digital-marketing__service-label {
    font-family: var(--font-sans);
    font-size: 1rem;
    color: var(--color-text);
}

.digital-marketing__visual {
    width: 100%;
}

.digital-marketing__visual svg {
    width: 100%;
    height: auto;
    display: block;
}

/* -----------------------------------------------------------------------------
   8i. Component: case-study   (Mockup: srs_13)
   ----------------------------------------------------------------------------- */
.case-study__card {
    position: relative;
    background: var(--color-bg);
    border: 1px solid var(--color-gold);
    border-radius: var(--radius-lg);
    padding: var(--space-xl) var(--space-lg) var(--space-lg);
}

.case-study__card--placeholder {
    border-style: dashed;
}

.case-study__badge {
    position: absolute;
    top: 20px;
    left: 20px;
}

.case-study__header {
    margin-bottom: var(--space-xl);
}

.case-study__eyebrow {
    margin-bottom: var(--space-sm);
}

.case-study__title {
    font-family: var(--font-serif);
    font-style: italic;
    font-size: clamp(1.5rem, 3vw, 1.875rem);
    letter-spacing: var(--ls-medium);
    color: var(--color-text);
    margin: 0 0 var(--space-xs);
}

.case-study__meta {
    font-family: var(--font-serif);
    font-style: italic;
    font-size: 1rem;
    color: var(--color-gold-dark);
    letter-spacing: var(--ls-wide);
    margin: 0 0 var(--space-sm);
}

.case-study__layout {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-xl);
    align-items: start;
}

@media (min-width: 960px) {
    .case-study__layout {
        grid-template-columns: minmax(0, 5fr) minmax(0, 6fr);
        gap: var(--space-2xl);
    }
}

.case-study__visual {
    width: 100%;
}

.case-study__visual svg {
    width: 100%;
    height: auto;
    display: block;
}

.case-study__sold-banner {
    background: var(--color-black);
    color: var(--color-gold-light);
    font-family: var(--font-serif);
    font-style: italic;
    font-size: 0.875rem;
    text-align: center;
    letter-spacing: var(--ls-wide);
    padding: var(--space-md);
    border-radius: var(--radius-sm);
    margin-top: var(--space-md);
}

.case-study__results-eyebrow {
    font-family: var(--font-sans);
    font-size: var(--fs-eyebrow);
    text-transform: uppercase;
    letter-spacing: var(--ls-wide);
    color: var(--color-text-muted);
    margin: 0 0 var(--space-xs);
}

.case-study__results-divider {
    display: block;
    width: 80px;
    height: 1px;
    background: var(--color-gold);
    margin-bottom: var(--space-lg);
}

.case-study__metrics {
    display: flex;
    flex-direction: column;
    gap: var(--space-lg);
    margin-bottom: var(--space-xl);
}

.case-study__metric-title {
    font-family: var(--font-sans);
    font-size: var(--fs-body);
    color: var(--color-text);
    letter-spacing: 1px;
    margin: 0 0 var(--space-xs);
}

.case-study__metric-row {
    display: flex;
    align-items: center;
    gap: var(--space-md);
}

.case-study__metric-bar {
    position: relative;
    flex: 1;
    height: 36px;
    background: var(--color-bg-cream);
    border: 1px dashed var(--color-gold);
    border-radius: var(--radius-sm);
    overflow: hidden;
}

.case-study__metric-fill {
    position: absolute;
    top: 0;
    bottom: 0;
    width: var(--fill, 0%);
    background: var(--color-gold);
    border-radius: var(--radius-sm);
}

.case-study__metric-fill--left {
    left: 0;
}

.case-study__metric-fill--right {
    right: 0;
}

.case-study__metric-text {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    font-family: var(--font-serif);
    font-style: italic;
    font-size: 0.9375rem;
    z-index: 1;
    white-space: nowrap;
}

.case-study__metric-text--left {
    left: var(--space-sm);
    color: var(--color-text);
}

.case-study__metric-text--right {
    right: var(--space-sm);
    color: var(--color-text);
}

.case-study__metric-delta {
    font-family: var(--font-serif);
    font-style: italic;
    font-size: 1.125rem;
    color: var(--color-gold-dark);
    flex-shrink: 0;
    min-width: 3.5rem;
    text-align: right;
}

.case-study__total {
    padding-top: var(--space-md);
    border-top: 1px solid rgba(201, 169, 97, 0.3);
}

.case-study__total-value {
    font-family: var(--font-serif);
    font-style: italic;
    font-size: clamp(2.25rem, 5vw, 3.125rem);
    color: var(--color-text);
    line-height: 1;
    margin: 0 0 var(--space-sm);
}

.case-study__total-unit {
    font-size: 0.6em;
    color: var(--color-gold-dark);
    margin-left: 0.25em;
}

.case-study__total-label {
    font-family: var(--font-sans);
    font-size: var(--fs-eyebrow);
    text-transform: uppercase;
    letter-spacing: var(--ls-wide);
    color: var(--color-text-muted);
    margin: var(--space-sm) 0 0;
}

.case-study__footnote {
    margin-top: var(--space-xl);
}

/* -----------------------------------------------------------------------------
   8j. Component: leads-chart   (Mockup: srs_09)
   ----------------------------------------------------------------------------- */
.leads-chart__heading {
    margin-bottom: var(--space-lg);
}

.leads-chart__subline {
    color: var(--color-text-light);
    font-size: var(--fs-label);
    text-transform: uppercase;
    letter-spacing: var(--ls-tight);
    margin: 0;
}

.leads-chart__chart {
    width: 100%;
}

.leads-chart__svg {
    width: 100%;
    height: auto;
    display: block;
    overflow: visible;
}

.leads-chart__summary {
    display: flex;
    flex-direction: column;
    gap: var(--space-xs);
    padding-top: var(--space-md);
    border-top: 1px solid rgba(201, 169, 97, 0.3);
    margin-top: var(--space-lg);
}

@media (min-width: 600px) {
    .leads-chart__summary {
        flex-direction: row;
        align-items: baseline;
        gap: var(--space-md);
    }
}

.leads-chart__summary-label {
    font-family: var(--font-sans);
    font-size: var(--fs-eyebrow);
    text-transform: uppercase;
    letter-spacing: var(--ls-medium);
    color: var(--color-text-light);
}

.leads-chart__summary-text {
    font-family: var(--font-serif);
    font-size: 0.9375rem;
    color: var(--color-text);
}

.leads-chart__footnote {
    margin-top: var(--space-md);
}

/* -----------------------------------------------------------------------------
   8k. Component: about   (Brief-basiert, kein Mockup)
   ----------------------------------------------------------------------------- */
.about__heading {
    text-align: center;
    max-width: 60ch;
    margin: 0 auto var(--space-xl);
}

.about__heading .divider-gold {
    margin-left: auto;
    margin-right: auto;
}

.about__headline {
    font-family: var(--font-serif);
    font-size: clamp(1.5rem, 3vw, 2rem);
    letter-spacing: var(--ls-medium);
    line-height: 1.3;
    color: var(--color-text);
    margin: 0 0 var(--space-md);
}

.about__headline-line {
    display: block;
}

.about__headline-line--accent {
    color: var(--color-gold-dark);
    font-style: italic;
}

.about__statement {
    font-family: var(--font-serif);
    font-style: italic;
    font-size: clamp(1.0625rem, 2vw, 1.25rem);
    line-height: 1.6;
    color: var(--color-text);
    text-align: center;
    max-width: 64ch;
    margin: 0 auto var(--space-2xl);
}

.about__pillars {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-xl);
}

@media (min-width: 768px) {
    .about__pillars {
        grid-template-columns: repeat(3, 1fr);
        gap: var(--space-lg);
    }
}

.about__pillar {
    text-align: center;
}

.about__pillar-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: var(--color-bg);
    border: 1px solid var(--color-gold);
    color: var(--color-gold-dark);
    margin-bottom: var(--space-md);
}

.about__pillar-icon svg {
    width: 28px;
    height: 28px;
}

.about__pillar-title {
    font-family: var(--font-serif);
    font-size: 1.25rem;
    color: var(--color-text);
    margin: 0 0 var(--space-xs);
    letter-spacing: 1px;
}

.about__pillar-text {
    font-family: var(--font-sans);
    font-size: var(--fs-body);
    color: var(--color-text-muted);
    line-height: 1.6;
    max-width: 36ch;
    margin: 0 auto;
}

/* -----------------------------------------------------------------------------
   8l. Component: contact-form   (kein Mockup — sicher + Brand-konform)
   ----------------------------------------------------------------------------- */
.contact-form__heading {
    margin-bottom: var(--space-xl);
    text-align: center;
}

.contact-form__headline {
    margin: 0 auto var(--space-sm);
}

.contact-form__heading .divider-gold {
    margin-left: auto;
    margin-right: auto;
}

.contact-form__subline {
    color: var(--color-text-muted);
    max-width: 60ch;
    margin: 0 auto;
}

.contact-form__form {
    max-width: 720px;
    margin: 0 auto;
}

.contact-form__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-md);
    margin-bottom: var(--space-md);
}

@media (min-width: 600px) {
    .contact-form__grid {
        grid-template-columns: 1fr 1fr;
    }
}

.contact-form__field {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-bottom: var(--space-md);
}

.contact-form__label {
    font-family: var(--font-sans);
    font-size: var(--fs-eyebrow);
    text-transform: uppercase;
    letter-spacing: var(--ls-medium);
    color: var(--color-gold-dark);
}

.contact-form__required {
    color: var(--color-error);
    margin-left: 2px;
}

.contact-form__input,
.contact-form__textarea {
    font-family: var(--font-sans);
    font-size: 1rem;
    color: var(--color-text);
    background: var(--color-bg);
    border: 1px solid var(--color-gold);
    border-radius: 10px;
    padding: 0.875rem 1rem;
    transition: border-color 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
    width: 100%;
    -webkit-appearance: none;
    appearance: none;
}

.contact-form__input::placeholder,
.contact-form__textarea::placeholder {
    color: var(--color-text-fade);
    font-style: italic;
}

.contact-form__input:focus,
.contact-form__textarea:focus {
    outline: none;
    border-color: var(--color-gold-dark);
    box-shadow: 0 0 0 3px rgba(201, 169, 97, 0.18);
    background: var(--color-bg-cream);
}

.contact-form__textarea {
    min-height: 140px;
    resize: vertical;
    font-family: var(--font-sans);
    line-height: 1.5;
}

.contact-form__field--error .contact-form__input,
.contact-form__field--error .contact-form__textarea {
    border-color: var(--color-error);
    background: rgba(180, 82, 72, 0.04);
}

.contact-form__field--error .contact-form__input:focus,
.contact-form__field--error .contact-form__textarea:focus {
    box-shadow: 0 0 0 3px rgba(180, 82, 72, 0.18);
}

.contact-form__error-message {
    font-family: var(--font-sans);
    font-size: var(--fs-label);
    color: var(--color-error);
    margin: 0;
}

/* Honeypot — unsichtbar für Menschen, sichtbar für Bots */
.contact-form__honeypot {
    position: absolute;
    left: -9999px;
    top: -9999px;
    height: 0;
    width: 0;
    overflow: hidden;
    opacity: 0;
    pointer-events: none;
}

/* Consent-Checkbox */
.contact-form__field--consent {
    margin-top: var(--space-sm);
    margin-bottom: var(--space-lg);
}

.contact-form__consent {
    display: flex;
    align-items: flex-start;
    gap: var(--space-sm);
    cursor: pointer;
    font-family: var(--font-sans);
    font-size: var(--fs-body);
    color: var(--color-text-muted);
    line-height: 1.5;
}

.contact-form__consent input[type="checkbox"] {
    margin-top: 3px;
    width: 18px;
    height: 18px;
    accent-color: var(--color-gold-dark);
    cursor: pointer;
    flex-shrink: 0;
}

.contact-form__consent-text a {
    color: var(--color-gold-dark);
    text-decoration: underline;
}

.contact-form__consent-text a:hover {
    color: var(--color-text);
}

/* Submit-Button + Hint */
.contact-form__submit {
    width: 100%;
    justify-content: center;
}

@media (min-width: 600px) {
    .contact-form__submit {
        width: auto;
        min-width: 240px;
    }
}

.contact-form__hint {
    font-family: var(--font-sans);
    font-size: var(--fs-label);
    color: var(--color-text-fade);
    margin: var(--space-md) 0 0;
    text-align: center;
    line-height: 1.5;
}

/* Notices: Success / Error nach Submit */
.contact-form__notice {
    max-width: 720px;
    margin: 0 auto;
    padding: var(--space-lg);
    border-radius: var(--radius-md);
    border: 1px solid;
    text-align: center;
    font-family: var(--font-serif);
    font-style: italic;
    font-size: 1.125rem;
    line-height: 1.5;
}

.contact-form__notice--success {
    background: rgba(107, 142, 90, 0.08);
    border-color: var(--color-success);
    color: var(--color-success);
}

.contact-form__notice--error {
    background: rgba(180, 82, 72, 0.06);
    border-color: var(--color-error);
    color: var(--color-error);
    margin-bottom: var(--space-lg);
}

.contact-form__notice p {
    margin: 0;
}

/* -----------------------------------------------------------------------------
   9. Component-Stub-Style
       Sichtbares Placeholder-Render für Bausteine, die noch nicht implementiert
       sind. Wird vom render-Helper im Dev-Modus erzeugt.
   ----------------------------------------------------------------------------- */
.stub {
    border: 1.5px dashed var(--color-gold);
    border-radius: var(--radius-md);
    padding: var(--space-lg);
    text-align: center;
    background: var(--color-bg-cream);
}

.stub__slug {
    font-family: var(--font-sans);
    font-size: var(--fs-eyebrow);
    text-transform: uppercase;
    letter-spacing: var(--ls-widest);
    color: var(--color-gold-dark);
    margin-bottom: var(--space-sm);
}

.stub__title {
    font-family: var(--font-serif);
    font-size: var(--fs-h3);
    color: var(--color-text);
    margin: 0 0 var(--space-sm);
}

.stub__hint {
    font-size: var(--fs-label);
    color: var(--color-text-muted);
}

/* -----------------------------------------------------------------------------
   10. Pages — schmale Sub-Hero für /impressum, /datenschutz, /kontakt
   ----------------------------------------------------------------------------- */
.page-header {
    padding-top: calc(72px + var(--space-2xl));
    padding-bottom: var(--space-lg);
    background: var(--color-bg-cream);
    border-bottom: 1px solid rgba(201, 169, 97, 0.3);
}

/* Page-Header mit Hintergrund-Bild + 15% dunklem Overlay
   (Impressum, Kontakt, Datenschutz, Karriere) */
.page-header--with-image {
    position: relative;
    padding-top: calc(72px + var(--space-2xl));
    padding-bottom: var(--space-2xl);
    background-color: var(--color-black, #1A1A1A);
    background-image: url('/assets/img/fc-hh.jpg');
    background-size: cover;
    background-position: center;
    color: var(--color-text-on-dark, #FFFFFF);
    border-bottom: none;
    overflow: hidden;
}
.page-header--with-image::before {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    pointer-events: none;
}
.page-header--with-image > .u-container {
    position: relative;
    z-index: 1;
}
.page-header--with-image .eyebrow {
    color: var(--color-gold-light, #D4B97A);
}
.page-header--with-image .headline {
    color: #FFFFFF;
}
.page-header--with-image p {
    color: rgba(255, 255, 255, 0.85);
}
.page-header--with-image .divider-gold {
    background: var(--color-gold, #C9A961);
}

/* Lead-Paragraph im Page-Header — ersetzt die alten inline-styles auf <p> */
.page-header__lead {
    max-width: 60ch;
    margin-top: var(--space-sm);
    color: var(--color-text-muted);
    line-height: 1.6;
    font-size: 1rem;
}
.page-header--with-image .page-header__lead {
    color: rgba(255, 255, 255, 0.88);
}

/* CTA-Button im Page-Header (z. B. /ueber-uns) */
.page-header__cta {
    margin-top: var(--space-md);
}
.page-header--with-cta {
    padding-bottom: calc(var(--space-2xl) + var(--space-md));
}

/* Pro-Seite-Hintergrundbild via Body-Class — fallback ist fc-hh.jpg
   (siehe .page-header--with-image oben). Bilder einfach unter
   /assets/img/page-<slug>.jpg ablegen, dann werden sie automatisch geladen. */
.page-impressum   .page-header--with-image { background-image: url('/assets/img/page-impressum.jpg'); }
.page-kontakt     .page-header--with-image { background-image: url('/assets/img/page-kontakt.jpg'); }
.page-datenschutz .page-header--with-image { background-image: url('/assets/img/page-datenschutz.jpg'); }
.page-karriere    .page-header--with-image { background-image: url('/assets/img/page-karriere.jpg'); }
.page-ueber-uns   .page-header--with-image { background-image: url('/assets/img/page-ueber-uns.jpg'); }
.page-leistungen  .page-header--with-image { background-image: url('/assets/img/page-leistungen.jpg'); }
.page-referenzen  .page-header--with-image { background-image: url('/assets/img/page-referenzen.jpg'); }

.page-content {
    padding-top: var(--space-xl);
    padding-bottom: var(--space-2xl);
    max-width: 760px;
}

/* Kontakt — Quick-Contact-Tiles (zwischen Header und Grid) ----------------- */
.contact-tiles {
    /* Negativer Margin lässt die Tiles in den Page-Header ragen — um 50px
       nach unten verschoben gegenüber dem Original-Stand. */
    margin-top: clamp(-50px, calc(-8vw + 50px), -14px);
    position: relative;
    z-index: 5;
    padding-bottom: clamp(40px, 5vw, 64px);
}
.contact-tiles__inner {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(16px, 2vw, 24px);
}
.contact-tile {
    position: relative;
    border-radius: 18px;
    padding: clamp(20px, 2.4vw, 28px) clamp(22px, 2.6vw, 32px);
    display: flex;
    flex-direction: column;
    gap: 8px;
    box-shadow: 0 24px 60px rgba(26, 26, 26, 0.12);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.contact-tile__head {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 4px;
}
.contact-tile:hover {
    transform: translateY(-3px);
    box-shadow: 0 30px 70px rgba(26, 26, 26, 0.16);
}
.contact-tile--light {
    background: #FFFFFF;
    color: var(--color-text, #1A1A1A);
}
.contact-tile--dark {
    background: var(--color-gold-dark, #A8894A);
    color: #FFFFFF;
}

.contact-tile__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: rgba(168, 137, 74, 0.18);
    color: var(--color-gold-dark, #A8894A);
    flex-shrink: 0;
}
.contact-tile--dark .contact-tile__icon {
    background: rgba(255, 255, 255, 0.16);
    color: #FFFFFF;
}
.contact-tile__icon svg {
    width: 20px;
    height: 20px;
}

.contact-tile__title {
    font-family: var(--font-serif);
    font-size: clamp(1.05rem, 1.4vw, 1.2rem);
    font-weight: 700;
    margin: 0;
    line-height: 1.2;
}
.contact-tile__sub {
    margin: 0;
    font-size: 0.9rem;
    line-height: 1.45;
    opacity: 0.78;
}
.contact-tile__action {
    margin-top: 8px;
    align-self: flex-start;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 9px 18px;
    border-radius: 999px;
    font-weight: 600;
    font-size: 0.9rem;
    text-decoration: none;
    transition: background 0.2s ease, color 0.2s ease, transform 0.2s ease;
}
.contact-tile--light .contact-tile__action {
    background: transparent;
    color: var(--color-text, #1A1A1A);
    border: 1px solid rgba(0, 0, 0, 0.15);
}
.contact-tile--light .contact-tile__action:hover {
    background: var(--color-text, #1A1A1A);
    color: #FFFFFF;
    border-color: var(--color-text, #1A1A1A);
}
.contact-tile--dark .contact-tile__action {
    background: #FFFFFF;
    color: var(--color-text, #1A1A1A);
}
.contact-tile--dark .contact-tile__action:hover {
    transform: translateX(2px);
}
.contact-tile__action svg {
    width: 14px;
    height: 14px;
    flex-shrink: 0;
}

@media (max-width: 720px) {
    .contact-tiles {
        margin-top: 18px;
    }
    .contact-tiles__inner {
        grid-template-columns: 1fr;
    }
}

/* Kontakt — 2-Spalten-Layout (Intro links, Formular rechts) ---------------- */
.contact-grid {
    padding: clamp(60px, 8vw, 96px) 0;
}
.contact-grid__inner {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: clamp(40px, 6vw, 96px);
    align-items: start;
}
.contact-grid__eyebrow {
    color: var(--color-gold-dark, #A8894A);
    font-weight: 700;
    letter-spacing: 0.18em;
    font-size: 12px;
    text-transform: uppercase;
    margin: 0 0 18px;
    position: relative;
    padding-left: 36px;
}
.contact-grid__eyebrow::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    width: 24px;
    height: 1px;
    background: var(--color-gold-dark, #A8894A);
}
.contact-grid__headline {
    font-family: var(--font-serif);
    font-size: clamp(2rem, 4vw, 3rem);
    line-height: 1.15;
    margin: 0 0 24px;
    color: var(--color-text, #1A1A1A);
}
.contact-grid__body {
    font-size: 1rem;
    line-height: 1.7;
    color: var(--color-text-muted, #4A4A4A);
    margin: 0 0 32px;
    max-width: 52ch;
}
.contact-grid__usps {
    list-style: none;
    padding: 0;
    margin: 0 0 32px;
    display: flex;
    flex-direction: column;
    gap: 18px;
}
.contact-grid__usp {
    display: flex;
    align-items: flex-start;
    gap: 16px;
}
.contact-grid__usp-icon {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: rgba(168, 137, 74, 0.18);
    color: var(--color-gold-dark, #A8894A);
}
.contact-grid__usp-icon svg {
    width: 18px;
    height: 18px;
}
.contact-grid__usp-title {
    display: block;
    font-family: var(--font-sans);
    font-weight: 700;
    font-size: 1rem;
    color: var(--color-text, #1A1A1A);
    margin-bottom: 2px;
}
.contact-grid__usp-text {
    margin: 0;
    color: var(--color-text-muted, #4A4A4A);
    font-size: 0.92rem;
    line-height: 1.5;
}
.contact-grid__socials {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}
.contact-grid__socials-label {
    font-weight: 600;
    color: var(--color-text, #1A1A1A);
    margin-right: 4px;
}
.contact-grid__social {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: rgba(0, 0, 0, 0.05);
    color: var(--color-text, #1A1A1A);
    transition: background 0.2s, color 0.2s;
}
.contact-grid__social:hover {
    background: var(--color-gold, #C9A961);
    color: #FFFFFF;
}
.contact-grid__social svg {
    width: 18px;
    height: 18px;
}

/* Embedded-Variante des Contact-Forms — kein Section-Wrapper, kein Header */
.contact-form--embedded {
    background: #FFFFFF;
    border: 1px solid #ECE7DB;
    border-radius: 14px;
    padding: clamp(28px, 3vw, 40px);
    box-shadow: 0 8px 30px rgba(26, 26, 26, 0.04);
}
.contact-form--embedded .contact-form__form {
    margin: 0;
}

/* Mobile */
@media (max-width: 860px) {
    .contact-grid__inner {
        grid-template-columns: 1fr;
        gap: 48px;
    }
}

/* Karriere — Intro + Job-Accordion ------------------------------------------ */
/* Full-width Cream-Section vor den Stellen. Lead-Typo, schmale Goldlinie
   als Akzent, breiter Inhalts-Container (960px) statt page-content (760px). */
.career-intro {
    padding-top: clamp(48px, 6vw, 80px);
    padding-bottom: clamp(48px, 6vw, 80px);
}
.career-intro__inner {
    max-width: 960px;
}
.career-intro__eyebrow {
    margin: 0 0 var(--space-sm);
}
.career-intro__lead {
    margin: 0;
    position: relative;
    padding-top: var(--space-md);
    font-family: var(--font-serif);
    font-size: clamp(0.9rem, 1.28vw, 1.12rem);
    line-height: 1.65;
    color: var(--color-text);
    letter-spacing: -0.005em;
}
.career-intro__lead::before {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 56px;
    height: 2px;
    background: var(--color-gold);
}

.career-jobs__title {
    margin: 0 0 24px;
}
.career-jobs {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: clamp(16px, 2vw, 28px);
}
.career-jobs__item {
    display: flex;
}

/* Job-Card --------------------------------------------------------------- */
.career-card {
    position: relative;
    display: flex;
    flex-direction: column;
    width: 100%;
    background: #FFFFFF;
    border: 1px solid #ECE7DB;
    border-radius: 14px;
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    transition: border-color 0.25s ease, box-shadow 0.25s ease, transform 0.25s ease;
}
.career-card:hover,
.career-card:focus-visible {
    border-color: rgba(201, 169, 97, 0.55);
    box-shadow: 0 18px 38px rgba(26, 26, 26, 0.08);
    transform: translateY(-2px);
    outline: none;
}
.career-card__media {
    position: relative;
    aspect-ratio: 16 / 10;
    overflow: hidden;
    background: var(--color-bg-cream, #FAF7F0);
}
.career-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.career-card__media--gradient {
    background:
        radial-gradient(120% 80% at 0% 0%, rgba(217, 182, 134, 0.55) 0%, transparent 60%),
        radial-gradient(140% 90% at 100% 100%, rgba(24, 26, 32, 0.85) 0%, transparent 70%),
        linear-gradient(135deg, var(--color-gold-light, #a88464) 0%, var(--color-gold, #5e4b3d) 55%, var(--color-black, #181a20) 100%);
}
.career-card__media-mark {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-serif);
    font-size: clamp(3.5rem, 8vw, 5.5rem);
    font-weight: 700;
    color: rgba(255, 255, 255, 0.18);
    letter-spacing: 0.04em;
    user-select: none;
}
.career-card__body {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 22px clamp(18px, 2vw, 26px) 24px;
    flex: 1;
}
.career-card__title {
    margin: 0;
    font-family: var(--font-serif);
    font-size: clamp(1.1rem, 1.6vw, 1.3rem);
    font-weight: 700;
    color: var(--color-text, #1A1A1A);
    line-height: 1.3;
}
.career-card__meta {
    margin: 0;
    font-size: 0.85rem;
    color: var(--color-text-muted, #6A6A6A);
    letter-spacing: 0.02em;
}
.career-card__cta {
    margin-top: auto;
    padding-top: 14px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: var(--font-serif);
    font-size: 0.9rem;
    font-weight: 700;
    color: var(--color-gold-dark, #756254);
    letter-spacing: 0.02em;
}
.career-card__cta svg {
    width: 16px;
    height: 16px;
    transition: transform 0.25s ease;
}
.career-card:hover .career-card__cta svg,
.career-card:focus-visible .career-card__cta svg {
    transform: translateX(4px);
}

/* Job-Detail-Seite ------------------------------------------------------- */
.career-job-detail {
    padding: clamp(40px, 6vw, 80px) 0 clamp(60px, 8vw, 100px);
}
.career-job-detail__back {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: var(--font-serif);
    font-size: 0.9rem;
    color: var(--color-text-muted, #6A6A6A);
    text-decoration: none;
    margin-bottom: clamp(20px, 3vw, 32px);
    letter-spacing: 0.02em;
}
.career-job-detail__back:hover {
    color: var(--color-gold-dark, #756254);
}
.career-job-detail__header {
    max-width: 760px;
    margin-bottom: clamp(24px, 3vw, 36px);
}
.career-job-detail__title {
    margin: 8px 0 0;
}
.career-job-detail__meta {
    margin: 18px 0 0;
    font-size: 0.95rem;
    color: var(--color-text-muted, #6A6A6A);
    letter-spacing: 0.02em;
}
.career-job-detail__hero {
    position: relative;
    aspect-ratio: 21 / 9;
    border-radius: 16px;
    overflow: hidden;
    margin-bottom: clamp(28px, 4vw, 44px);
    background: var(--color-bg-cream, #FAF7F0);
}
.career-job-detail__hero img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.career-job-detail__hero--gradient {
    background:
        radial-gradient(120% 80% at 0% 0%, rgba(217, 182, 134, 0.55) 0%, transparent 60%),
        radial-gradient(140% 90% at 100% 100%, rgba(24, 26, 32, 0.85) 0%, transparent 70%),
        linear-gradient(135deg, var(--color-gold-light, #a88464) 0%, var(--color-gold, #5e4b3d) 55%, var(--color-black, #181a20) 100%);
}
.career-job-detail__description {
    margin: 0 0 clamp(28px, 4vw, 40px);
    max-width: 760px;
    font-size: 1.05rem;
    line-height: 1.7;
    color: var(--color-text, #1A1A1A);
}
.career-job-detail__section {
    max-width: 760px;
    margin-bottom: clamp(24px, 3vw, 32px);
}
.career-job-detail__section-title {
    font-family: var(--font-serif);
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--color-gold-dark, #756254);
    margin: 0 0 12px;
}
.career-job-detail__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.career-job-detail__list li {
    position: relative;
    padding-left: 22px;
    color: var(--color-text-muted, #4A4A4A);
    font-size: 1rem;
    line-height: 1.6;
}
.career-job-detail__list li::before {
    content: '';
    position: absolute;
    left: 4px;
    top: 0.7em;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--color-gold, #5e4b3d);
}
.career-job-detail__cta-row {
    margin-top: clamp(32px, 4vw, 44px);
    display: flex;
}
.career-job-detail__cta-row .btn {
    border-radius: 7px;
}

/* Karriere — Was uns antreibt ------------------------------------------------ */
.career-stance__inner {
    max-width: 880px;
}
.career-stance__headline {
    font-family: var(--font-serif);
    font-size: clamp(1.5rem, 2.8vw, 2.1rem);
    line-height: 1.25;
    margin: 8px 0 0;
    color: var(--color-text);
}
.career-stance__body {
    margin: 22px 0 18px;
    color: var(--color-text-muted);
    line-height: 1.7;
    font-size: 1rem;
}
.career-stance__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.career-stance__list li {
    position: relative;
    padding-left: 22px;
    color: var(--color-text);
    font-size: 1rem;
    line-height: 1.6;
}
.career-stance__list li::before {
    content: '';
    position: absolute;
    left: 4px;
    top: 0.7em;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--color-gold, #5e4b3d);
}

/* Karriere — Was dich bei uns erwartet (9 Kacheln) -------------------------- */
.career-perks__head {
    max-width: 760px;
    margin-bottom: clamp(28px, 4vw, 44px);
}
.career-perks__headline {
    font-family: var(--font-serif);
    font-size: clamp(1.5rem, 2.8vw, 2.1rem);
    line-height: 1.25;
    margin: 8px 0 0;
    color: var(--color-text);
}
.career-perks__grid {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: clamp(16px, 2vw, 24px);
}
.career-perks__tile {
    position: relative;
    background: linear-gradient(180deg, #FFFFFF 0%, #FBF6EA 100%);
    border: 1px solid rgba(201, 169, 97, 0.18);
    border-radius: 18px;
    padding: 34px clamp(20px, 2.2vw, 28px) 28px;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    isolation: isolate;
    transition:
        transform 0.4s cubic-bezier(0.22, 1, 0.36, 1),
        box-shadow 0.4s ease,
        border-color 0.4s ease;
}

/* Animierte Gold-Akzent-Linie oben — wächst auf voller Breite beim Hover */
.career-perks__tile::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    height: 3px;
    width: 36px;
    background: linear-gradient(90deg, var(--color-gold-light, #a88464), var(--color-gold, #5e4b3d));
    border-radius: 0 0 3px 0;
    transition: width 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}

/* Soft Glow im Hintergrund — nur beim Hover sichtbar */
.career-perks__tile::after {
    content: '';
    position: absolute;
    inset: -1px;
    border-radius: inherit;
    background: radial-gradient(120% 90% at 100% 0%, rgba(217, 182, 134, 0.18) 0%, transparent 55%);
    opacity: 0;
    z-index: -1;
    transition: opacity 0.4s ease;
}

.career-perks__tile:hover {
    transform: translateY(-4px);
    border-color: rgba(201, 169, 97, 0.5);
    box-shadow: 0 24px 50px rgba(26, 26, 26, 0.1);
}
.career-perks__tile:hover::before {
    width: 100%;
}
.career-perks__tile:hover::after {
    opacity: 1;
}

/* Nummer als Editorial-Watermark — groß, transparent, oben rechts */
.career-perks__number {
    position: absolute;
    top: 14px;
    right: 22px;
    font-family: var(--font-serif);
    font-size: clamp(2.8rem, 4.2vw, 3.6rem);
    font-weight: 800;
    line-height: 1;
    color: rgba(94, 75, 61, 0.09);
    letter-spacing: -0.02em;
    pointer-events: none;
    transition: color 0.4s ease, transform 0.4s ease;
}
.career-perks__tile:hover .career-perks__number {
    color: rgba(94, 75, 61, 0.18);
    transform: translateY(-2px);
}

.career-perks__title {
    margin: 32px 0 0;
    font-family: var(--font-serif);
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--color-text);
    line-height: 1.3;
    position: relative;
}
.career-perks__body {
    margin: 12px 0 0;
    font-size: 0.95rem;
    line-height: 1.65;
    color: var(--color-text-muted);
    position: relative;
}

@media (prefers-reduced-motion: reduce) {
    .career-perks__tile,
    .career-perks__tile::before,
    .career-perks__tile::after,
    .career-perks__number {
        transition: none;
    }
}

/* Karriere — Entwicklung & Perspektive -------------------------------------- */
.career-development__inner {
    max-width: 880px;
}
.career-development__headline {
    font-family: var(--font-serif);
    font-size: clamp(1.5rem, 2.8vw, 2.1rem);
    line-height: 1.25;
    margin: 8px 0 0;
    color: var(--color-text);
}
.career-development__body {
    margin: 22px 0 0;
    color: var(--color-text-muted);
    line-height: 1.7;
    font-size: 1rem;
}

/* Karriere — Standort ------------------------------------------------------- */
.career-location__inner {
    max-width: 880px;
}
.career-location__headline {
    font-family: var(--font-serif);
    font-size: clamp(1.5rem, 2.8vw, 2.1rem);
    line-height: 1.25;
    margin: 8px 0 0;
    color: var(--color-text);
}
.career-location__body {
    margin: 22px 0 18px;
    color: var(--color-text-muted);
    line-height: 1.7;
    font-size: 1rem;
}
.career-location__address {
    font-style: normal;
    font-family: var(--font-serif);
    font-size: 1.05rem;
    color: var(--color-text);
    line-height: 1.6;
    padding-left: 16px;
    border-left: 2px solid var(--color-gold, #5e4b3d);
}

/* Karriere — Anfahrt (2-Spalten) -------------------------------------------- */
.career-directions__inner {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr);
    gap: clamp(28px, 4vw, 56px);
    align-items: stretch;
}
.career-directions__headline {
    font-family: var(--font-serif);
    font-size: clamp(1.5rem, 2.8vw, 2.1rem);
    line-height: 1.25;
    margin: 8px 0 0;
    color: var(--color-text);
}
.career-directions__address {
    font-style: normal;
    font-family: var(--font-serif);
    font-size: 1.05rem;
    color: var(--color-text);
    line-height: 1.6;
    margin: 22px 0 24px;
    padding-left: 16px;
    border-left: 2px solid var(--color-gold, #5e4b3d);
}
.career-directions__group {
    margin-bottom: 18px;
}
.career-directions__group-title {
    font-family: var(--font-serif);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--color-gold-dark, #756254);
    margin: 0 0 10px;
}
.career-directions__group-body {
    margin: 0;
    color: var(--color-text-muted);
    line-height: 1.65;
    font-size: 0.95rem;
}
.career-directions__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.career-directions__list li {
    position: relative;
    padding-left: 22px;
    color: var(--color-text-muted);
    font-size: 0.95rem;
    line-height: 1.6;
}
.career-directions__list li::before {
    content: '';
    position: absolute;
    left: 4px;
    top: 0.7em;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--color-gold, #5e4b3d);
}
.career-directions__cta {
    margin-top: 8px;
    border-radius: 7px;
}
.career-directions__map {
    position: relative;
    min-height: 360px;
    aspect-ratio: 4 / 3;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 18px 38px rgba(26, 26, 26, 0.08);
    border: 1px solid #ECE7DB;
}
.career-directions__map iframe {
    width: 100%;
    height: 100%;
    border: 0;
    display: block;
}

@media (max-width: 860px) {
    .career-directions__inner {
        grid-template-columns: 1fr;
    }
    .career-directions__map {
        aspect-ratio: 16 / 11;
        min-height: 280px;
    }
}

/* Karriere — Initiativbewerbung --------------------------------------------- */
.career-initiative__inner {
    max-width: 760px;
    text-align: center;
}
.career-initiative__inner .divider-gold {
    margin-left: auto;
    margin-right: auto;
}
.career-initiative__headline {
    font-family: var(--font-serif);
    font-size: clamp(1.5rem, 2.8vw, 2.1rem);
    line-height: 1.25;
    margin: 8px 0 0;
    color: var(--color-text);
}
.career-initiative__body {
    margin: 22px auto 24px;
    color: var(--color-text-muted);
    line-height: 1.7;
    font-size: 1rem;
}
.career-initiative__cta {
    border-radius: 7px;
}

/* Karriere — Abschluss-CTA (dunkler Block) ---------------------------------- */
.career-final-cta {
    background: var(--color-black, #181a20);
    color: var(--color-text-on-dark, #FFFFFF);
    padding: clamp(60px, 9vw, 110px) 0;
}
.career-final-cta__inner {
    max-width: 760px;
    text-align: center;
}
.career-final-cta .divider-gold {
    margin-left: auto;
    margin-right: auto;
}
.career-final-cta__eyebrow {
    color: var(--color-gold-light, #a88464);
}
.career-final-cta__headline {
    font-family: var(--font-serif);
    font-size: clamp(1.75rem, 3.6vw, 2.6rem);
    line-height: 1.2;
    margin: 8px 0 0;
    color: var(--color-text-on-dark, #FFFFFF);
}
.career-final-cta__sub {
    margin: 22px auto 28px;
    color: rgba(255, 255, 255, 0.78);
    line-height: 1.6;
    font-size: 1rem;
}
.career-final-cta__cta {
    border-radius: 7px;
}

.page-content h2 {
    font-size: var(--fs-h3);
    margin-top: var(--space-lg);
    margin-bottom: var(--space-sm);
}

.page-content p {
    margin-bottom: var(--space-sm);
    color: var(--color-text-muted);
    line-height: 1.7;
}

/* -----------------------------------------------------------------------------
   11. Print (rudimentär)
   ----------------------------------------------------------------------------- */
@media print {
    .site-header,
    .site-footer,
    .hero__media,
    .hero__overlay {
        display: none !important;
    }
}


/* ============================================================================
   Cookie-Consent — DSGVO/TTDSG-konformes 2-Stufen-System (global)
   Stufe 1: Banner (unten) · Stufe 2: Settings-Modal mit Kategorien-Toggles
   ============================================================================ */

/* Stage 1 — Banner ---------------------------------------------------------- */
.sr-consent {
    position: fixed;
    bottom: 16px;
    left: 16px;
    right: 16px;
    max-width: 980px;
    margin: 0 auto;
    background: #FFFFFF;
    color: #1A1A1A;
    padding: 22px 26px;
    z-index: 200;
    border-radius: 14px;
    box-shadow: 0 24px 60px rgba(0, 0, 0, 0.18);
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    font-size: 14px;
    border: 1px solid #ECE7DB;
}
.sr-consent[hidden] { display: none; }
.sr-consent__inner {
    display: flex;
    flex-wrap: wrap;
    gap: 18px;
    align-items: center;
    justify-content: space-between;
}
.sr-consent__text-wrap {
    flex: 1 1 320px;
    min-width: 0;
}
.sr-consent__title {
    margin: 0 0 6px;
    font-family: var(--font-serif, Georgia), serif;
    font-size: 1.05rem;
    font-weight: 700;
}
.sr-consent__text {
    margin: 0;
    line-height: 1.55;
    color: #4A4A4A;
}
.sr-consent__text a {
    color: #A8894A;
    text-decoration: underline;
}
.sr-consent__buttons {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    align-items: center;
}

/* Buttons (geteilt mit Modal) */
.sr-consent__btn {
    padding: 10px 18px;
    border: 1px solid #ECE7DB;
    background: transparent;
    color: #1A1A1A;
    cursor: pointer;
    border-radius: 7px;
    font: inherit;
    font-size: 0.9rem;
    font-weight: 500;
    transition: background 0.15s, border-color 0.15s, color 0.15s;
}
.sr-consent__btn--text {
    border-color: transparent;
    color: #6A6A6A;
}
.sr-consent__btn--text:hover {
    color: #1A1A1A;
    background: rgba(0, 0, 0, 0.04);
}
.sr-consent__btn--ghost { border-color: #1A1A1A; }
.sr-consent__btn--ghost:hover {
    background: #1A1A1A;
    color: #FFFFFF;
}
.sr-consent__btn--primary {
    background: #C9A961;
    border-color: #C9A961;
    color: #1A1A1A;
    font-weight: 600;
}
.sr-consent__btn--primary:hover {
    background: #B89954;
    border-color: #B89954;
}

/* Stage 2 — Settings-Modal -------------------------------------------------- */
.sr-consent-modal {
    position: fixed;
    inset: 0;
    z-index: 210;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 16px;
}
.sr-consent-modal[hidden] { display: none; }
.sr-consent-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(26, 26, 26, 0.55);
    cursor: pointer;
}
.sr-consent-modal__panel {
    position: relative;
    background: #FFFFFF;
    border-radius: 14px;
    padding: 28px;
    max-width: 580px;
    width: 100%;
    max-height: calc(100vh - 32px);
    overflow-y: auto;
    box-shadow: 0 24px 80px rgba(0, 0, 0, 0.35);
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}
.sr-consent-modal__head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;
    margin-bottom: 8px;
}
.sr-consent-modal__head h2 {
    margin: 0;
    font-family: var(--font-serif, Georgia), serif;
    font-size: 1.5rem;
    color: #1A1A1A;
}
.sr-consent-modal__close {
    background: none;
    border: none;
    cursor: pointer;
    color: #6A6A6A;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    font-size: 28px;
    line-height: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.15s, color 0.15s;
}
.sr-consent-modal__close:hover {
    background: #FAF7F0;
    color: #1A1A1A;
}
.sr-consent-modal__intro {
    margin: 0 0 20px;
    font-size: 0.92rem;
    line-height: 1.55;
    color: #6A6A6A;
}

/* Kategorie */
.sr-consent-cat {
    background: #FAF7F0;
    border: 1px solid #ECE7DB;
    border-radius: 10px;
    padding: 16px 18px;
    margin-bottom: 12px;
}
.sr-consent-cat__head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;
}
.sr-consent-cat__info { flex: 1 1 auto; min-width: 0; }
.sr-consent-cat__title {
    margin: 0 0 6px;
    font-size: 1rem;
    font-weight: 700;
    color: #1A1A1A;
}
.sr-consent-cat__desc {
    margin: 0;
    font-size: 0.85rem;
    line-height: 1.5;
    color: #4A4A4A;
}

/* Toggle-Switch */
.sr-consent-toggle {
    flex-shrink: 0;
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    user-select: none;
}
.sr-consent-toggle input {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
}
.sr-consent-toggle__track {
    width: 44px;
    height: 24px;
    background: #D8CFB8;
    border-radius: 999px;
    position: relative;
    transition: background 0.2s;
    flex-shrink: 0;
}
.sr-consent-toggle__track::before {
    content: "";
    position: absolute;
    top: 3px;
    left: 3px;
    width: 18px;
    height: 18px;
    background: #FFFFFF;
    border-radius: 50%;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);
    transition: transform 0.2s;
}
.sr-consent-toggle input:checked + .sr-consent-toggle__track {
    background: #C9A961;
}
.sr-consent-toggle input:checked + .sr-consent-toggle__track::before {
    transform: translateX(20px);
}
.sr-consent-toggle input:focus-visible + .sr-consent-toggle__track {
    box-shadow: 0 0 0 3px rgba(201, 169, 97, 0.3);
}
.sr-consent-toggle--locked { cursor: default; }
.sr-consent-toggle--locked .sr-consent-toggle__track {
    background: #C9A961;
    opacity: 0.5;
}
.sr-consent-toggle--locked .sr-consent-toggle__track::before {
    transform: translateX(20px);
}
.sr-consent-toggle__label {
    font-size: 0.78rem;
    color: #6A6A6A;
    font-weight: 500;
}

/* Modal-Footer */
.sr-consent-modal__foot {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    margin-top: 20px;
    flex-wrap: wrap;
}
.sr-consent-modal__link {
    font-size: 0.85rem;
    color: #A8894A;
    text-decoration: underline;
}
.sr-consent-modal__actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

/* Mobile */
@media (max-width: 720px) {
    .sr-consent {
        bottom: 8px;
        left: 8px;
        right: 8px;
        padding: 18px;
    }
    .sr-consent__inner {
        flex-direction: column;
        align-items: stretch;
    }
    .sr-consent__buttons { justify-content: stretch; }
    .sr-consent__buttons .sr-consent__btn {
        flex: 1 1 calc(50% - 4px);
        text-align: center;
        padding: 12px 14px;
    }
    .sr-consent-modal__panel { padding: 22px; }
    .sr-consent-modal__foot {
        flex-direction: column;
        align-items: stretch;
    }
    .sr-consent-modal__actions { justify-content: stretch; }
    .sr-consent-modal__actions .sr-consent__btn { flex: 1; }
}

/* =============================================================================
   Unternehmens-Historie — vertikale Timeline mit Goldlinie und -punkten
   (Über-Uns-Seite). Desktop: zwei Spalten (Jahr | Inhalt) mit Linie zwischen
   den Spalten. Mobile: Linie ganz links, Jahr stackt oberhalb des Inhalts.
   ========================================================================== */
.history__heading {
    text-align: center;
    margin-bottom: var(--space-xl);
}
.history__heading .eyebrow {
    margin-bottom: var(--space-xs);
}
.history__headline {
    margin: 0 auto;
    max-width: 32ch;
}
.history__heading .divider-gold {
    margin: var(--space-sm) auto 0;
}

.history__list {
    list-style: none;
    margin: 0 auto;
    padding: 0;
    position: relative;
    max-width: 880px;
}

/* Goldene Verbindungslinie zwischen den Spalten */
.history__list::before {
    content: '';
    position: absolute;
    top: 0.5rem;
    bottom: 0.5rem;
    left: 160px;
    width: 1px;
    background: var(--color-gold);
    opacity: 0.45;
}

.history__item {
    display: grid;
    grid-template-columns: 140px 1fr;
    column-gap: var(--space-lg);
    padding-bottom: var(--space-xl);
    position: relative;
}
.history__item:last-child {
    padding-bottom: 0;
}

.history__year {
    margin: 0;
    padding-top: 0.15rem;
    text-align: right;
    font-family: var(--font-serif);
    font-size: var(--fs-h3);
    font-weight: 700;
    color: var(--color-gold-light);
    letter-spacing: 0.02em;
    line-height: 1.2;
    align-self: start;
}

.history__dot {
    position: absolute;
    left: 160px;
    top: 0.65rem;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: var(--color-gold);
    transform: translateX(-50%);
    box-shadow: 0 0 0 4px var(--color-bg-cream);
}

.history__body {
    align-self: start;
}
.history__title {
    margin: 0 0 var(--space-sm);
    font-family: var(--font-serif);
    font-size: var(--fs-h3);
    font-weight: 700;
    color: var(--color-text);
    line-height: 1.3;
}
.history__paragraph {
    margin: 0 0 var(--space-sm);
    color: var(--color-text-muted);
    line-height: 1.75;
    font-size: 1rem;
}
.history__paragraph:last-child {
    margin-bottom: 0;
}

@media (max-width: 768px) {
    .history__list::before {
        left: 7px;
    }
    .history__item {
        grid-template-columns: 1fr;
        padding-left: 32px;
        padding-bottom: var(--space-lg);
        row-gap: var(--space-xs);
    }
    .history__year {
        text-align: left;
        padding-top: 0;
        font-size: 0.95rem;
        color: var(--color-gold);
    }
    .history__dot {
        left: 7px;
        top: 0.4rem;
        box-shadow: 0 0 0 3px var(--color-bg-cream);
    }
}

/* =============================================================================
   Team-Experten — Sektion mit Headline, Body, Foto-Kacheln und CTA-Modal
   (Leistungen-Seite). Modal lädt Calendly per Iframe erst bei Open.
   ========================================================================== */
.team-experts__heading {
    text-align: center;
    margin: 0 auto var(--space-md);
    max-width: 760px;
}
.team-experts__headline {
    margin: 0 auto;
}
.team-experts__heading .divider-gold {
    margin: var(--space-sm) auto;
}
.team-experts__body {
    margin: var(--space-md) auto 0;
    color: var(--color-text-muted);
    line-height: 1.7;
    font-size: 1rem;
}

.team-experts__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-md);
}
@media (min-width: 768px) {
    .team-experts__grid { grid-template-columns: repeat(4, 1fr); gap: var(--space-lg); }
}

.team-experts__card {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    background: var(--color-bg-cream);
    border: 1px solid rgba(94, 75, 61, 0.18);
    border-radius: var(--radius-md);
    padding: var(--space-lg) var(--space-md);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.team-experts__card:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.06);
}

.team-experts__photo {
    width: 100%;
    aspect-ratio: 1 / 1;
    max-width: 180px;
    border-radius: 50%;
    overflow: hidden;
    background: var(--color-bg);
    margin-bottom: var(--space-md);
    display: flex;
    align-items: center;
    justify-content: center;
}
.team-experts__photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.team-experts__photo--empty {
    border: 1.5px dashed var(--color-gold);
    color: var(--color-gold-dark);
    background: transparent;
}
.team-experts__photo--empty svg {
    width: 50%;
    height: 50%;
    opacity: 0.7;
}

.team-experts__name {
    margin: 0 0 var(--space-xs);
    font-family: var(--font-serif);
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--color-text);
    letter-spacing: 0.02em;
}
.team-experts__divider {
    display: block;
    width: 40px;
    height: 1px;
    background: var(--color-gold);
    margin-bottom: var(--space-sm);
    opacity: 0.6;
}
.team-experts__role {
    margin: 0;
    font-family: var(--font-sans);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: var(--ls-wide);
    color: var(--color-gold-dark);
}

.team-experts__cta-row {
    margin-top: var(--space-xl);
    display: flex;
    justify-content: center;
}
.team-experts__cta {
    border: none;
    cursor: pointer;
}

/* Modal --------------------------------------------------------------------- */
.team-modal {
    position: fixed;
    inset: 0;
    z-index: 1000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: clamp(12px, 2vw, 32px);
}
.team-modal[hidden] { display: none; }

.team-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(4px);
}
.team-modal__panel {
    position: relative;
    background: var(--color-bg);
    border-radius: var(--radius-md);
    width: 100%;
    max-width: 1040px;
    max-height: min(90vh, 820px);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    box-shadow: 0 30px 80px rgba(0, 0, 0, 0.35);
}
.team-modal__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-md) var(--space-lg);
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
    background: var(--color-bg-cream);
    flex-shrink: 0;
}
.team-modal__title {
    margin: 0;
    font-family: var(--font-serif);
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--color-text);
}
.team-modal__close {
    background: transparent;
    border: none;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    font-size: 1.4rem;
    color: var(--color-text);
    cursor: pointer;
    transition: background 0.15s ease;
}
.team-modal__close:hover { background: rgba(0, 0, 0, 0.06); }
.team-modal__close:focus-visible {
    outline: 2px solid var(--color-gold);
    outline-offset: 2px;
}

.team-modal__body {
    flex: 1;
    min-height: 0;
    position: relative;
    background: var(--color-bg);
    overflow: hidden;
}
.team-modal__iframe {
    width: 100%;
    height: 100%;
    min-height: 600px;
    border: 0;
    display: block;
}
.team-modal__fallback {
    margin: 0;
    padding: var(--space-xl);
    text-align: center;
    color: var(--color-text-muted);
    line-height: 1.6;
}
.team-modal__fallback code {
    background: var(--color-bg-cream);
    padding: 2px 6px;
    border-radius: 4px;
    font-size: 0.9em;
}
