/* ==========================================================================
   Freitodbegleiter — main.css (Liquid Glass Edition)
   ========================================================================== */

/* Fonts ------------------------------------------------------------------- */
@font-face {
    font-family: 'Inter';
    src: url('../fonts/Inter-Regular.woff2') format('woff2');
    font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
    font-family: 'Inter';
    src: url('../fonts/Inter-SemiBold.woff2') format('woff2');
    font-weight: 600; font-style: normal; font-display: swap;
}
@font-face {
    font-family: 'Inter';
    src: url('../fonts/Inter-Bold.woff2') format('woff2');
    font-weight: 700; font-style: normal; font-display: swap;
}

/* Custom Properties ------------------------------------------------------- */
:root {
    --primary: #7BB3D9;
    --primary-deep: #4A90B8;
    --primary-soft: #B8D4E8;
    --primary-glow: rgba(123,179,217,0.5);

    /* Section background palette */
    --bg-base: #EAF1F6;
    --bg-light: #F4F7FA;
    --bg-tint: #DDE8F1;
    --bg-deep: #1E3A52;
    --bg-deep-2: #0F2233;

    --card-bg: #FFFFFF;
    --text-body: #4B5563;
    --text-muted: #9CA3AF;
    --text-headline: #0F172A;
    --text-on-dark: #E2E8F0;
    --text-on-dark-muted: #94A3B8;
    --border: #DDE3EA;

    /* === LIQUID GLASS TOKENS === */
    --lg-bg: rgba(255, 255, 255, 0.18);
    --lg-bg-strong: rgba(255, 255, 255, 0.28);
    --lg-bg-dark: rgba(15, 23, 42, 0.22);
    --lg-blur: 40px;
    --lg-saturate: 200%;
    --lg-brightness: 1.08;
    --lg-border: 1px solid rgba(255, 255, 255, 0.35);

    /* Specular highlight gradient (light from top-left) */
    --lg-highlight: linear-gradient(135deg,
        rgba(255,255,255,0.55) 0%,
        rgba(255,255,255,0.15) 30%,
        rgba(255,255,255,0)    60%,
        rgba(255,255,255,0.08) 100%);
    /* Refraction tint */
    --lg-refraction: linear-gradient(120deg,
        rgba(123,179,217,0.08) 0%,
        rgba(255,255,255,0)    50%,
        rgba(184,212,232,0.10) 100%);

    --radius-sm: 10px;
    --radius-md: 16px;
    --radius-lg: 24px;
    --radius-xl: 32px;

    --container: 1320px;
    --container-wide: 1480px;
    --container-narrow: 920px;

    --space-1: 8px;  --space-2: 16px; --space-3: 24px; --space-4: 32px;
    --space-5: 48px; --space-6: 64px; --space-7: 96px; --space-8: 128px;
    --space-9: 160px;

    --font-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Helvetica, Arial, sans-serif;

    /* Layered shadows */
    --shadow-glass:
        0 1px 1px rgba(15,23,42,0.04),
        0 8px 24px rgba(15,23,42,0.08),
        0 32px 64px -24px rgba(15,23,42,0.20),
        inset 0 1px 0 rgba(255,255,255,0.6),
        inset 0 -1px 0 rgba(15,23,42,0.05);
    --shadow-glass-hover:
        0 2px 4px rgba(15,23,42,0.06),
        0 18px 40px rgba(15,23,42,0.12),
        0 44px 96px -28px rgba(15,23,42,0.30),
        inset 0 1px 0 rgba(255,255,255,0.7),
        inset 0 -1px 0 rgba(15,23,42,0.05);
    --shadow-soft: 0 4px 16px rgba(15,23,42,0.06);
    --shadow-deep: 0 32px 80px -32px rgba(15,23,42,0.40);
}

/* Reset ------------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html, body { height: 100%; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
    font-family: var(--font-sans);
    font-size: 17px;
    line-height: 1.65;
    color: var(--text-body);
    background-color: var(--bg-base);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
    overflow-x: hidden;
}

img, picture, svg, video { display: block; max-width: 100%; height: auto; }
input, button, textarea, select { font: inherit; color: inherit; }
button { background: none; border: 0; cursor: pointer; padding: 0; }
a { color: var(--primary-deep); text-decoration: none; transition: color .2s ease; }
a:hover, a:focus { color: var(--text-headline); text-decoration: underline; text-underline-offset: 3px; }
:focus-visible { outline: 2px solid var(--primary-deep); outline-offset: 3px; border-radius: 4px; }

.screen-reader-text {
    position: absolute !important;
    clip: rect(1px,1px,1px,1px);
    width: 1px; height: 1px;
    overflow: hidden;
    word-wrap: normal !important;
}

.skip-link {
    position: absolute;
    top: -100px; left: 8px;
    background: var(--text-headline);
    color: #fff;
    padding: 8px 12px;
    border-radius: var(--radius-sm);
    z-index: 100;
    opacity: 0;
    pointer-events: none;
    transition: top .2s, opacity .2s;
}
.skip-link:focus, .skip-link:focus-visible {
    top: 8px;
    opacity: 1;
    pointer-events: auto;
}

/* Typography -------------------------------------------------------------- */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-sans);
    color: var(--text-headline);
    font-weight: 700;
    line-height: 1.18;
    letter-spacing: -0.022em;
}
h1 { font-size: clamp(2rem, 4.5vw, 3.25rem); letter-spacing: -0.03em; }
h2 { font-size: clamp(1.5rem, 2.6vw, 2rem); letter-spacing: -0.02em; }
h3 { font-size: clamp(1.125rem, 1.6vw, 1.375rem); letter-spacing: -0.015em; }
h4 { font-size: 1.125rem; font-weight: 600; }
p  { margin-bottom: 1.1em; }
p:last-child { margin-bottom: 0; }
strong, b { font-weight: 600; color: var(--text-headline); }
ul, ol { margin: 0 0 1.1em 1.4em; padding: 0; }
li { margin-bottom: 0.55em; }
hr { border: 0; border-top: 1px solid var(--border); margin: var(--space-5) 0; }

.eyebrow {
    display: inline-block;
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--primary-deep);
    margin-bottom: var(--space-2);
    padding: 6px 14px;
    background: rgba(123,179,217,0.18);
    border-radius: 999px;
    backdrop-filter: blur(8px);
    border: 1px solid rgba(123,179,217,0.25);
}

/* Layout ------------------------------------------------------------------ */
.container {
    width: 100%;
    max-width: var(--container);
    margin: 0 auto;
    padding-left: var(--space-3);
    padding-right: var(--space-3);
}
.container--narrow { max-width: var(--container-narrow); }
.container--wide   { max-width: var(--container-wide); }

/* Buttons ----------------------------------------------------------------- */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-1);
    padding: 14px 28px;
    border-radius: var(--radius-md);
    font-weight: 600;
    font-size: 0.9375rem;
    line-height: 1.2;
    text-decoration: none !important;
    transition: transform .25s ease, box-shadow .25s ease, background-color .25s ease, color .25s ease;
    cursor: pointer;
    border: 1px solid transparent;
    will-change: transform;
}
.btn--primary {
    background: linear-gradient(135deg, var(--primary) 0%, var(--primary-deep) 100%);
    color: #fff;
    box-shadow: 0 8px 24px -8px rgba(74,144,184,0.55), inset 0 1px 0 rgba(255,255,255,0.25);
}
.btn--primary:hover, .btn--primary:focus {
    transform: translateY(-2px);
    box-shadow: 0 14px 32px -8px rgba(74,144,184,0.7), inset 0 1px 0 rgba(255,255,255,0.3);
    color: #fff;
}
.btn--secondary {
    background: rgba(255,255,255,0.4);
    color: var(--primary-deep);
    border-color: rgba(123,179,217,0.5);
    backdrop-filter: blur(20px);
}
.btn--secondary:hover, .btn--secondary:focus {
    background: var(--primary);
    color: #fff;
    border-color: var(--primary);
    transform: translateY(-2px);
    box-shadow: 0 12px 28px -10px rgba(74,144,184,0.5);
}
.btn--ghost {
    background: rgba(255,255,255,0.3);
    color: var(--text-headline);
    border-color: var(--border);
    backdrop-filter: blur(12px);
}
.btn--ghost:hover { border-color: var(--primary); color: var(--primary-deep); }

/* =========================================================================
   LIQUID GLASS — Apple-inspired (real 3D refraction)
   ========================================================================= */
.glass {
    position: relative;
    background:
        linear-gradient(135deg, rgba(255,255,255,0.10) 0%, rgba(255,255,255,0.04) 100%);
    backdrop-filter: blur(40px) saturate(110%);
    -webkit-backdrop-filter: blur(40px) saturate(110%);
    border-radius: var(--radius-lg);
    border: 1px solid transparent;
    background-clip: padding-box;
    /* 3D inset edges: bright top + sides, subtle bottom */
    box-shadow:
        inset 0 2px 1px rgba(255,255,255,0.7),
        inset 0 -2px 2px rgba(15,23,42,0.08),
        inset 2px 0 2px rgba(255,255,255,0.3),
        inset -2px 0 2px rgba(255,255,255,0.25),
        inset 0 0 0 1px rgba(255,255,255,0.15),
        0 6px 12px rgba(15,23,42,0.06),
        0 30px 60px -16px rgba(15,23,42,0.18),
        0 50px 100px -32px rgba(15,23,42,0.10);
    overflow: hidden;
    isolation: isolate;
    transform: translateZ(0);
}
/* Specular sweep — diagonal light catch (white only) */
.glass::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse 120% 80% at 20% 0%,
            rgba(255,255,255,0.45) 0%,
            rgba(255,255,255,0.08) 28%,
            transparent 55%),
        radial-gradient(ellipse 80% 50% at 100% 100%,
            rgba(255,255,255,0.15) 0%,
            transparent 50%);
    pointer-events: none;
    z-index: 1;
    border-radius: inherit;
    mix-blend-mode: screen;
}
.glass::after { display: none; }
.glass > * { position: relative; z-index: 2; }

.glass--strong {
    background:
        linear-gradient(135deg, rgba(255,255,255,0.22) 0%, rgba(255,255,255,0.08) 100%);
}
.glass--dark {
    background: linear-gradient(135deg, rgba(15,23,42,0.30) 0%, rgba(15,23,42,0.18) 100%);
    box-shadow:
        inset 0 2px 1px rgba(255,255,255,0.18),
        inset 0 -2px 2px rgba(0,0,0,0.30),
        inset 0 0 0 1px rgba(255,255,255,0.08),
        0 30px 60px -16px rgba(0,0,0,0.4);
}
.glass--dark, .glass--dark * { color: var(--text-on-dark); }
.glass--dark h1, .glass--dark h2, .glass--dark h3, .glass--dark h4 { color: #fff; }

/* Header — Premium Glass with shrink on scroll --------------------------- */
.site-header {
    position: sticky;
    top: 0;
    z-index: 70;
    background: rgba(244,247,250,0.65);
    backdrop-filter: blur(32px) saturate(200%);
    -webkit-backdrop-filter: blur(32px) saturate(200%);
    border-bottom: 1px solid rgba(255,255,255,0.5);
    box-shadow:
        0 1px 0 rgba(15,23,42,0.04),
        0 8px 24px -16px rgba(15,23,42,0.10);
    transition: background-color .3s ease, box-shadow .3s ease, padding .3s ease;
}
.site-header.is-scrolled {
    background: rgba(244,247,250,0.85);
    box-shadow:
        0 1px 0 rgba(15,23,42,0.06),
        0 12px 28px -16px rgba(15,23,42,0.18);
}
.site-header__inner {
    max-width: var(--container-wide);
    margin: 0 auto;
    padding: 14px var(--space-3);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
    transition: padding .3s ease;
}
.site-header.is-scrolled .site-header__inner { padding-top: 10px; padding-bottom: 10px; }

.site-header__brand {
    display: inline-flex;
    align-items: center;
    flex-shrink: 0;
    text-decoration: none;
}
.site-header__brand:hover { text-decoration: none; }
.site-header__logo,
.site-header__brand .custom-logo-link img {
    height: 38px;
    width: auto;
    display: block;
    transition: height .3s ease;
}
.site-header.is-scrolled .site-header__logo,
.site-header.is-scrolled .site-header__brand .custom-logo-link img {
    height: 32px;
}

/* Header CTA */
.site-header__cta {
    display: none;
    align-items: center;
    gap: 8px;
    padding: 10px 22px 10px 16px;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--primary), var(--primary-deep));
    color: #fff !important;
    font-weight: 600;
    font-size: 0.875rem;
    text-decoration: none !important;
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,0.3),
        0 6px 14px -4px rgba(74,144,184,0.45);
    transition: transform .25s ease, box-shadow .25s ease;
}
.site-header__cta-icon {
    width: 18px;
    height: 18px;
    display: block;
    flex-shrink: 0;
}
.site-header__cta:hover, .site-header__cta:focus {
    transform: translateY(-1px);
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,0.4),
        0 10px 22px -6px rgba(74,144,184,0.55);
}

/* Burger toggle */
.site-header__toggle {
    display: inline-flex;
    flex-direction: column;
    gap: 5px;
    width: 44px; height: 44px;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-sm);
    transition: background-color .2s;
    z-index: 70;
    position: relative;
}
.site-header__toggle:hover { background: rgba(255,255,255,0.5); }
.site-header__toggle-bar {
    width: 22px; height: 2px;
    background: var(--text-headline);
    border-radius: 2px;
    transition: transform .3s ease, opacity .25s ease;
    transform-origin: center;
}
.site-header__toggle[aria-expanded="true"] .site-header__toggle-bar:nth-child(1) {
    transform: translateY(7px) rotate(45deg);
}
.site-header__toggle[aria-expanded="true"] .site-header__toggle-bar:nth-child(2) { opacity: 0; transform: scaleX(0); }
.site-header__toggle[aria-expanded="true"] .site-header__toggle-bar:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg);
}

/* Desktop nav lives inline in header */
.site-nav--desktop {
    display: none;
    flex: 1;
    justify-content: center;
    align-items: center;
}
@media (min-width: 1024px) {
    .site-nav--desktop { display: flex; }
}

/* Mobile nav: full-screen drawer (sibling of header — escapes header stacking) */
.site-nav--mobile {
    position: fixed;
    inset: 0;
    background: rgba(244,247,250,0.98);
    transform: translateX(100%);
    transition: transform .35s cubic-bezier(.2,.85,.3,1), opacity .25s ease;
    opacity: 0;
    pointer-events: none;
    z-index: 65;
    overflow-y: auto;
    overflow-x: hidden;
    overscroll-behavior: contain;
    touch-action: pan-y;
    display: block;
}
.site-nav--mobile__inner {
    padding: 88px var(--space-4) var(--space-5);
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
    min-height: 100%;
}
.site-nav--mobile.is-open {
    transform: translateX(0);
    opacity: 1;
    pointer-events: auto;
}
.mobile-cta-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    margin: 0 auto;
    margin-top: auto;
    padding: 16px 32px;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--primary), var(--primary-deep));
    color: #fff !important;
    font-weight: 600;
    font-size: 1rem;
    text-decoration: none !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.25), 0 8px 20px -4px rgba(74,144,184,0.5);
    width: 100%;
    max-width: 320px;
}
.mobile-cta-pill:hover, .mobile-cta-pill:focus {
    color: #fff;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.3), 0 12px 28px -6px rgba(74,144,184,0.6);
}
@media (min-width: 1024px) {
    .site-nav--mobile { display: none !important; }
}
.site-nav__menu {
    list-style: none;
    margin: 0; padding: 0;
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    max-width: 480px;
    margin-left: auto;
    margin-right: auto;
}
.site-nav__menu a {
    display: block;
    padding: 14px 18px;
    font-weight: 600;
    color: var(--text-headline);
    text-decoration: none;
    border-radius: var(--radius-md);
    font-size: 1.125rem;
    transition: background-color .2s, color .2s;
    border: 1px solid transparent;
}
.site-nav__menu a:hover, .site-nav__menu .current-menu-item > a {
    color: var(--primary-deep);
    background: rgba(123,179,217,0.15);
    border-color: rgba(123,179,217,0.3);
}

/* Body lock when nav open (mobile) */
body.nav-open { overflow: hidden; }

/* =========================================================================
   MEGA MENU
   ========================================================================= */
.mega-menu {
    list-style: none;
    margin: 0; padding: 0;
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
}
.mega-menu__item { position: relative; }
.mega-menu__item { display: flex; align-items: center; height: 100%; }
.mega-menu__link {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 10px 16px;
    font-weight: 600;
    color: var(--bg-deep);
    text-decoration: none;
    border-radius: var(--radius-sm);
    font-size: 0.9375rem;
    line-height: 1;
    transition: background-color .2s, color .2s;
    white-space: nowrap;
}
.mega-menu__link:hover,
.mega-menu__item--has-panel:hover .mega-menu__link,
.mega-menu__item.current-menu-item .mega-menu__link {
    color: #5BA0CB;
    background: rgba(123,179,217,0.18);
    text-decoration: none;
}
.mega-menu__chevron { opacity: 0.6; transition: transform .25s ease; }
.mega-menu__item--has-panel:hover .mega-menu__chevron,
.mega-menu__item--has-panel:focus-within .mega-menu__chevron { transform: rotate(180deg); opacity: 1; }

/* Mega panel (desktop dropdown) */
.mega-panel {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%) translateY(8px);
    width: min(820px, calc(100vw - 48px));
    padding-top: 14px; /* visual breathing + hover bridge */
    z-index: 80;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity .18s ease, transform .25s cubic-bezier(.2,.85,.3,1), visibility 0s linear .25s;
}
.mega-menu__item--has-panel:hover .mega-panel,
.mega-menu__item--has-panel:focus-within .mega-panel {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateX(-50%) translateY(0);
    transition: opacity .18s ease, transform .25s cubic-bezier(.2,.85,.3,1), visibility 0s linear 0s;
}
.mega-panel__inner {
    display: grid;
    grid-template-columns: 240px 1fr;
    gap: var(--space-3);
    padding: var(--space-2);
    background: #ffffff;
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    box-shadow:
        0 20px 50px -16px rgba(15,23,42,0.22),
        0 40px 80px -24px rgba(15,23,42,0.15);
}
.mega-panel__media {
    border-radius: var(--radius-md);
    overflow: hidden;
    aspect-ratio: 1/1;
    background: var(--bg-tint);
    position: relative;
    align-self: stretch;
}
.mega-panel__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: opacity .35s ease, transform .8s ease;
}
.mega-panel__items {
    list-style: none;
    margin: 0; padding: 0;
    columns: 2;
    column-gap: var(--space-2);
}
.mega-panel__items > li {
    break-inside: avoid;
    margin-bottom: 4px;
}
.mega-panel__item {
    display: block;
    padding: 8px 12px;
    border-radius: var(--radius-sm);
    text-decoration: none !important;
    transition: background-color .2s ease, transform .2s ease;
}
.mega-panel__item:hover {
    background: rgba(123,179,217,0.15);
    transform: translateX(2px);
}
.mega-panel__item-label {
    display: block;
    font-weight: 600;
    color: var(--text-headline);
    font-size: 1rem;
    margin-bottom: 2px;
}
.mega-panel__item-desc {
    display: block;
    font-size: 0.8125rem;
    color: var(--text-body);
    line-height: 1.4;
}

/* Mobile: mega-menu collapses to list; panels stack inline */
@media (max-width: 1023px) {
    .mega-menu {
        gap: var(--space-1);
        flex-direction: column;
        align-items: stretch;
        width: 100%;
        max-width: 480px;
        margin: 0 auto;
    }
    .mega-menu__item {
        display: block;
        align-items: stretch;
        height: auto;
        width: 100%;
    }
    .mega-menu__link {
        display: flex;
        justify-content: space-between;
        align-items: center;
        width: 100%;
        padding: 14px 18px;
        font-size: 1.125rem;
        font-weight: 600;
        border-radius: var(--radius-md);
        border: 1px solid transparent;
        line-height: 1.3;
    }
    .mega-menu__link:hover,
    .mega-menu__item--has-panel.is-open .mega-menu__link {
        border-color: rgba(123,179,217,0.3);
        background: rgba(123,179,217,0.12);
    }
    .mega-menu__chevron { transition: transform .25s ease; }
    .mega-menu__item--has-panel.is-open .mega-menu__chevron { transform: rotate(180deg); }

    .mega-panel {
        position: static !important;
        transform: none !important;
        width: auto !important;
        opacity: 1 !important;
        visibility: hidden;
        pointer-events: auto;
        display: none;
        margin-top: 4px;
        margin-bottom: var(--space-2);
        padding-top: 0;
        left: auto !important;
        top: auto !important;
    }
    .mega-menu__item--has-panel.is-open .mega-panel {
        display: block;
        visibility: visible;
    }
    /* Disable desktop hover-show on mobile (kill stuck :hover after tap) */
    .mega-menu__item--has-panel:hover .mega-panel,
    .mega-menu__item--has-panel:focus-within .mega-panel {
        opacity: 1 !important;
        transform: none !important;
        visibility: hidden;
        display: none;
    }
    .mega-menu__item--has-panel.is-open:hover .mega-panel,
    .mega-menu__item--has-panel.is-open:focus-within .mega-panel,
    .mega-menu__item--has-panel.is-open .mega-panel {
        display: block;
        visibility: visible;
    }
    .mega-panel__inner {
        background: rgba(255,255,255,0.6);
        box-shadow: none;
        padding: var(--space-3);
        border-radius: var(--radius-md);
        border-color: rgba(255,255,255,0.6);
        grid-template-columns: 1fr;
    }
    .mega-panel__media { display: none; }
    .mega-panel__items { columns: 1; }
    .mega-panel__inner { grid-template-columns: 1fr; }
    .mega-panel__media { aspect-ratio: 16/9; }
    .mega-panel__item { padding: 10px 12px; }
}

/* Desktop nav */
@media (min-width: 1024px) {
    .site-header__toggle { display: none; }
    .site-header__cta    { display: inline-flex; align-items: center; }

    .mega-menu__item--mobile-only { display: none !important; }

    .mega-menu { align-items: center; }
    .mega-menu {
        flex-direction: row;
        gap: 4px;
        max-width: none;
        margin: 0;
    }
    .site-nav__menu a {
        padding: 10px 16px;
        font-size: 0.9375rem;
        font-weight: 500;
        border: 0;
    }
    .site-nav__menu a:hover, .site-nav__menu .current-menu-item > a {
        background: rgba(123,179,217,0.12);
        border: 0;
    }
}

/* Footer ------------------------------------------------------------------ */
.site-footer {
    position: relative;
    background: linear-gradient(180deg, var(--bg-deep) 0%, var(--bg-deep-2) 100%);
    color: var(--text-on-dark-muted);
    padding: var(--space-7) 0 0;
    margin-top: 0;
}
.site-footer::before {
    content: "";
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(123,179,217,0.5), transparent);
}
.site-footer__inner {
    max-width: var(--container);
    margin: 0 auto;
    padding: 0 var(--space-3) var(--space-6);
    display: grid;
    gap: var(--space-5);
    grid-template-columns: 1fr;
}
@media (min-width: 700px) { .site-footer__inner { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .site-footer__inner { grid-template-columns: 2fr 1fr 1fr 1.4fr; gap: var(--space-5); } }

.site-footer__col--brand .site-footer__logo { height: 42px; width: auto; margin-bottom: var(--space-3); }
.site-footer__desc { color: var(--text-on-dark-muted); font-size: 0.9375rem; line-height: 1.7; margin-bottom: var(--space-3); }

.site-footer__heading {
    color: #fff;
    font-size: 0.8125rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    margin: 0 0 var(--space-3);
}
.site-footer__links {
    list-style: none;
    margin: 0; padding: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.site-footer__links a {
    color: var(--text-on-dark);
    text-decoration: none;
    font-size: 0.9375rem;
    transition: color .2s ease;
}
.site-footer__links a:hover { color: #fff; }

/* Social icons */
.site-footer__social {
    display: flex;
    gap: 10px;
    margin-top: var(--space-2);
}
.site-footer__social a {
    width: 40px; height: 40px;
    border-radius: 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(255,255,255,0.06);
    color: var(--text-on-dark);
    transition: background-color .25s ease, color .25s ease, transform .25s ease;
    border: 1px solid rgba(255,255,255,0.08);
}
.site-footer__social a:hover {
    background: linear-gradient(135deg, var(--primary), var(--primary-deep));
    color: #fff;
    transform: translateY(-2px);
    border-color: transparent;
}

/* CTA buttons */
.site-footer__cta-desc { color: var(--text-on-dark-muted); font-size: 0.9375rem; line-height: 1.6; margin-bottom: var(--space-3); }
.btn-footer {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 22px;
    border-radius: 999px;
    font-weight: 600;
    font-size: 0.875rem;
    text-decoration: none !important;
    transition: transform .25s ease, box-shadow .25s ease, background-color .25s ease;
    border: 1px solid transparent;
    margin-bottom: 10px;
    width: fit-content;
}
.btn-footer--primary {
    background: linear-gradient(135deg, var(--primary), var(--primary-deep));
    color: #fff;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.25), 0 6px 14px -4px rgba(74,144,184,0.45);
}
.btn-footer--primary:hover { transform: translateY(-2px); color: #fff; box-shadow: inset 0 1px 0 rgba(255,255,255,0.3), 0 10px 22px -6px rgba(74,144,184,0.55); }
.btn-footer--ghost {
    background: rgba(255,255,255,0.06);
    color: #fff;
    border-color: rgba(255,255,255,0.18);
}
.btn-footer--ghost:hover {
    background: rgba(255,255,255,0.12);
    color: #fff;
    border-color: rgba(255,255,255,0.3);
}

/* Bottom bar */
.site-footer__bottom {
    border-top: 1px solid rgba(255,255,255,0.08);
    padding: var(--space-3) 0;
}
.site-footer__bottom-inner {
    max-width: var(--container);
    margin: 0 auto;
    padding: 0 var(--space-3);
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    align-items: center;
    justify-content: space-between;
    text-align: center;
}
@media (min-width: 700px) {
    .site-footer__bottom-inner { flex-direction: row; text-align: left; }
}
.site-footer__legal {
    list-style: none;
    margin: 0; padding: 0;
    display: flex;
    gap: var(--space-3);
    flex-wrap: wrap;
    justify-content: center;
}
.site-footer__legal a {
    color: var(--text-on-dark-muted);
    text-decoration: none;
    font-size: 0.8125rem;
    transition: color .2s;
}
.site-footer__legal a:hover { color: #fff; }
.site-footer__copy { color: #64748b; font-size: 0.8125rem; margin: 0; }

/* Page Fallback ----------------------------------------------------------- */
.page-fallback { padding: var(--space-7) 0; }
.page-fallback__inner {
    max-width: var(--container-narrow);
    margin: 0 auto;
    padding: var(--space-5);
    background: var(--lg-bg-strong);
    backdrop-filter: blur(var(--lg-blur)) saturate(var(--lg-saturate));
    border: var(--lg-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-glass);
}
.page-fallback__title { margin-bottom: var(--space-3); }
.page-fallback__content > * + * { margin-top: 1em; }

/* 404 --------------------------------------------------------------------- */
.error-404 { padding: var(--space-8) 0; text-align: center; background: linear-gradient(180deg, var(--bg-light) 0%, var(--bg-tint) 100%); }
.error-404__inner {
    max-width: 640px;
    margin: 0 auto;
    padding: var(--space-6) var(--space-4);
    background: var(--lg-bg-strong);
    backdrop-filter: blur(var(--lg-blur)) saturate(var(--lg-saturate));
    border: var(--lg-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-glass);
}
.error-404__eyebrow {
    font-size: 5rem;
    font-weight: 700;
    background: linear-gradient(135deg, var(--primary), var(--primary-deep));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    line-height: 1;
    margin-bottom: var(--space-2);
    letter-spacing: -0.04em;
}
.error-404__title { margin-bottom: var(--space-2); }
.error-404__text { margin-bottom: var(--space-4); }

/* =========================================================================
   Sections — alternating backgrounds for visual rhythm
   ========================================================================= */

/* Base section reset — every section can be standalone */
section {
    position: relative;
    scroll-margin-top: 90px;
}
.faq__item, .step, .card {
    scroll-margin-top: 100px;
}

/* Hero -------------------------------------------------------------------- */
.section-hero {
    position: relative;
    padding: var(--space-7) 0 var(--space-6);
    overflow: hidden;
    background: linear-gradient(135deg, var(--bg-light) 0%, var(--bg-tint) 100%);
    height: 860px;
    display: flex;
    align-items: center;
}
.section-hero--has-bg .section-hero__bg {
    position: absolute; inset: 0;
    background-size: cover;
    background-position: center;
    z-index: 0;
    opacity: 0.45;
    filter: saturate(0.95);
    transform: scale(1.05);
    animation: heroBgDrift 30s ease-in-out infinite alternate;
}
.section-hero__video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: 0;
    opacity: 0.85;
}
.section-hero__overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    background: linear-gradient(180deg, rgba(255,255,255,0.55) 0%, rgba(255,255,255,0.40) 100%);
}
.section-hero__video { opacity: 1; filter: brightness(1.15) saturate(0.95); }
.section-hero--has-bg::after {
    content: "";
    position: absolute; inset: 0;
    background:
        radial-gradient(ellipse at 30% 40%, rgba(244,247,250,0.5) 0%, transparent 60%),
        linear-gradient(180deg, transparent 0%, rgba(244,247,250,0.4) 100%);
    z-index: 1;
    pointer-events: none;
}
/* Animated orbs (motion!) */
.section-hero__orbs {
    position: absolute; inset: 0;
    z-index: 1;
    pointer-events: none;
    overflow: hidden;
}
.hero-orb {
    position: absolute;
    border-radius: 50%;
    filter: blur(70px);
    pointer-events: none;
    opacity: 0.7;
}
.hero-orb-1 {
    width: 420px; height: 420px;
    background: radial-gradient(circle, rgba(123,179,217,0.5), transparent 70%);
    top: -120px; left: -100px;
    animation: orbFloat 9s ease-in-out infinite alternate;
}
.hero-orb-2 {
    width: 320px; height: 320px;
    background: radial-gradient(circle, rgba(74,144,184,0.4), transparent 70%);
    top: 30%; right: -80px;
    animation: orbFloat 12s ease-in-out infinite alternate-reverse;
}
.hero-orb-3 {
    width: 260px; height: 260px;
    background: radial-gradient(circle, rgba(184,212,232,0.4), transparent 70%);
    bottom: -60px; left: 35%;
    animation: orbFloat 10s ease-in-out infinite alternate;
}
.hero-orb-4 {
    width: 200px; height: 200px;
    background: radial-gradient(circle, rgba(168,196,219,0.3), transparent 70%);
    top: 20%; left: 45%;
    animation: orbFloat 14s ease-in-out infinite alternate-reverse;
    filter: blur(90px);
}
@keyframes orbFloat {
    0%   { transform: translate(0, 0) scale(1); }
    100% { transform: translate(40px, 50px) scale(1.18); }
}
@keyframes heroBgDrift {
    0%   { transform: scale(1.05) translate(0, 0); }
    100% { transform: scale(1.1) translate(-2%, -1%); }
}

.section-hero__inner {
    position: relative;
    z-index: 3;
    max-width: var(--container);
    margin: 0 auto;
    padding: 0 var(--space-3);
    width: 100%;
}
.section-hero__card {
    max-width: 100%;
    padding: var(--space-6) var(--space-5);
    animation: heroCardIn 1s cubic-bezier(.2,.9,.3,1) both;
}
.section-hero__card-inner {
    max-width: 100%;
}
.section-hero#impressum .section-hero__card-inner {
    text-align: center;
}
.section-hero#impressum .section-hero__card-inner .eyebrow {
    margin-left: auto;
    margin-right: auto;
}
/* Hero Pills (under hero card, always visible) ---------------------------- */
.hero-pills {
    margin-top: var(--space-4);
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    align-items: stretch;
    justify-content: flex-end;
    animation: heroCardIn 1.2s cubic-bezier(.2,.9,.3,1) both;
    animation-delay: .2s;
}
.hero-pill {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    padding: 18px 32px 18px 20px;
    border-radius: 999px;
    min-height: 72px;
    background: linear-gradient(135deg, rgba(255,255,255,0.10) 0%, rgba(255,255,255,0.04) 100%);
    backdrop-filter: blur(40px) saturate(110%);
    -webkit-backdrop-filter: blur(40px) saturate(110%);
    text-decoration: none !important;
    color: var(--text-headline);
    box-shadow:
        inset 0 2px 1px rgba(255,255,255,0.85),
        inset 0 -2px 2px rgba(15,23,42,0.10),
        inset 0 0 0 1px rgba(255,255,255,0.18),
        0 4px 10px rgba(15,23,42,0.06),
        0 16px 40px -12px rgba(15,23,42,0.18);
    overflow: hidden;
    isolation: isolate;
    transition: transform .25s ease, box-shadow .25s ease;
    will-change: transform;
}
.hero-pill::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: radial-gradient(ellipse 100% 80% at 30% 0%, rgba(255,255,255,0.5) 0%, transparent 60%);
    pointer-events: none;
    mix-blend-mode: screen;
}
.hero-pill:hover, .hero-pill:focus {
    transform: translateY(-2px);
    color: var(--text-headline);
    box-shadow:
        inset 0 2px 1px rgba(255,255,255,0.9),
        inset 0 -2px 2px rgba(15,23,42,0.10),
        inset 0 0 0 1px rgba(255,255,255,0.25),
        0 6px 14px rgba(15,23,42,0.08),
        0 22px 50px -16px rgba(74,144,184,0.30);
}
.hero-pill__icon {
    width: 42px; height: 42px;
    border-radius: 50%;
    background: linear-gradient(135deg, rgba(123,179,217,0.4), rgba(184,212,232,0.5));
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    color: var(--primary-deep);
    box-shadow:
        inset 0 1px 1px rgba(255,255,255,0.8),
        0 3px 8px -2px rgba(74,144,184,0.35);
    position: relative;
    z-index: 1;
}
.hero-pill__icon svg { width: 20px; height: 20px; display: block; }
.hero-pill__text {
    line-height: 1.25;
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.hero-pill__title {
    display: block;
    font-weight: 600;
    font-size: 0.9375rem;
    letter-spacing: -0.005em;
}
.hero-pill__sub {
    display: block;
    font-size: 0.75rem;
    color: var(--text-body);
    margin-top: 2px;
}

/* Primary action pill */
.hero-pill--primary {
    background: linear-gradient(135deg, var(--primary) 0%, var(--primary-deep) 100%);
    color: #fff;
    box-shadow:
        inset 0 2px 1px rgba(255,255,255,0.4),
        inset 0 -2px 2px rgba(15,23,42,0.15),
        0 6px 14px -3px rgba(74,144,184,0.5),
        0 22px 50px -16px rgba(74,144,184,0.4);
}
.hero-pill--primary:hover, .hero-pill--primary:focus {
    color: #fff;
    box-shadow:
        inset 0 2px 1px rgba(255,255,255,0.5),
        inset 0 -2px 2px rgba(15,23,42,0.15),
        0 10px 20px -4px rgba(74,144,184,0.6),
        0 30px 60px -16px rgba(74,144,184,0.5);
}
.hero-pill--primary .hero-pill__icon {
    background: rgba(255,255,255,0.25);
    color: #fff;
    box-shadow: inset 0 1px 1px rgba(255,255,255,0.5);
}
.hero-pill--primary .hero-pill__title { color: #fff; }
@keyframes heroCardIn {
    from { opacity: 0; transform: translateY(20px); }
    to   { opacity: 1; transform: translateY(0); }
}
.section-hero__headline {
    margin-bottom: var(--space-3);
    background: linear-gradient(135deg, var(--text-headline) 0%, #334155 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}
.section-hero__sub {
    font-size: 1.0625rem;
    color: var(--text-body);
    margin-bottom: var(--space-4);
    line-height: 1.7;
    display: -webkit-box;
    -webkit-line-clamp: 5;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
@media (min-width: 768px) {
    .section-hero__card { padding: var(--space-7) var(--space-6); }
    .section-hero__sub { font-size: 1.125rem; }
}

/* Generic section base + alternation -------------------------------------- */
.section-split,
.section-text,
.section-cards,
.section-steps,
.section-faq,
.section-quote,
.section-cta {
    padding: var(--space-7) 0;
    position: relative;
}

/* Alternating bg colors as fallback (when no image loads / behind image) */
.section-split             { background: var(--bg-light); }
.section-text              { background: var(--bg-base); }
.section-cards             { background: var(--bg-tint); }
.section-steps             { background: var(--bg-light); }
.section-faq               { background: var(--bg-base); }
.section-quote             { background: var(--bg-tint); }
.section-cta               { background: var(--bg-light); }

/* Each section: ACF-driven bg/overlay (overflow only when bg-image set) -- */
.section-split.has-bg-image,
.section-text.has-bg-image,
.section-cards.has-bg-image,
.section-steps.has-bg-image,
.section-faq.has-bg-image,
.section-quote.has-bg-image,
.section-cta.has-bg-image {
    overflow: hidden;
}

/* ACF-driven background color */
.section-split.has-bg-color,
.section-text.has-bg-color,
.section-cards.has-bg-color,
.section-steps.has-bg-color,
.section-faq.has-bg-color,
.section-quote.has-bg-color,
.section-cta.has-bg-color {
    background-color: var(--freit-bg-color) !important;
}

/* ACF-driven background image */
.section-split.has-bg-image::before,
.section-text.has-bg-image::before,
.section-cards.has-bg-image::before,
.section-steps.has-bg-image::before,
.section-faq.has-bg-image::before,
.section-quote.has-bg-image::before,
.section-cta.has-bg-image::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image: var(--freit-bg-image);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    z-index: 0;
    pointer-events: none;
}

/* Parallax */
.section-split.has-parallax::before,
.section-text.has-parallax::before,
.section-cards.has-parallax::before,
.section-steps.has-parallax::before,
.section-faq.has-parallax::before,
.section-quote.has-parallax::before,
.section-cta.has-parallax::before {
    background-attachment: fixed;
}

/* Overlay element (rendered when overlay_opacity > 0) */
.section-overlay {
    position: absolute;
    inset: 0;
    background-color: var(--freit-overlay-color, rgba(255,255,255,0.5));
    z-index: 1;
    pointer-events: none;
}

/* Default headlines: dark navy (footer color) */
.section-split h1, .section-split h2, .section-split h3, .section-split h4,
.section-text h1, .section-text h2, .section-text h3, .section-text h4,
.section-cards h1, .section-cards h2, .section-cards h3, .section-cards h4,
.section-steps h1, .section-steps h2, .section-steps h3, .section-steps h4,
.section-faq h1, .section-faq h2, .section-faq h3, .section-faq h4,
.section-quote h1, .section-quote h2, .section-quote h3, .section-quote h4,
.section-cta h1, .section-cta h2, .section-cta h3, .section-cta h4 {
    color: var(--bg-deep);
}

/* Light-text mode (dark BG) */
.has-light-text { color: var(--text-on-dark); }
.has-light-text h1, .has-light-text h2, .has-light-text h3, .has-light-text h4 {
    color: var(--primary-soft);
}
.has-light-text p, .has-light-text li, .has-light-text .section-hero__sub,
.has-light-text .section-text__body, .has-light-text .section-split__body,
.has-light-text .section-quote__text, .has-light-text .step__body p,
.has-light-text .card p, .has-light-text .faq__a, .has-light-text .faq__q {
    color: var(--text-on-dark);
}
.has-light-text .eyebrow {
    color: var(--primary-soft);
    background: rgba(184,212,232,0.15);
    border-color: rgba(184,212,232,0.3);
}
.has-light-text .faq__item {
    background: rgba(255,255,255,0.06);
    border-color: rgba(255,255,255,0.12);
}
.has-light-text .faq__q::after {
    color: var(--primary-soft);
    background: rgba(184,212,232,0.15);
}
.has-light-text strong, .has-light-text b { color: #fff; }
.has-light-text a { color: var(--primary-soft); }

/* Content always above bg + overlay */
.section-split > *:not(.section-overlay),
.section-text > *:not(.section-overlay),
.section-cards > *:not(.section-overlay),
.section-steps > *:not(.section-overlay),
.section-faq > *:not(.section-overlay),
.section-quote > *:not(.section-overlay),
.section-cta > *:not(.section-overlay) {
    position: relative;
    z-index: 2;
}

/* Split ------------------------------------------------------------------- */
.section-split__inner {
    max-width: var(--container);
    margin: 0 auto;
    padding: 0 var(--space-3);
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-5);
    align-items: stretch;
}
@media (min-width: 900px) {
    .section-split__inner { grid-template-columns: 1fr 1.1fr; gap: var(--space-6); }
    .section-split--bild-rechts .section-split__media { order: 2; }
    .section-split--bild-rechts .section-split__content { order: 1; }
}
.section-split__media {
    position: relative;
    min-height: 100%;
    display: flex;
}
.section-split__media img {
    width: 100%;
    height: 100%;
    min-height: 320px;
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-deep), 0 0 0 1px rgba(255,255,255,0.4);
    object-fit: cover;
}

/* Trauerbegleitung: Phone-Screenshots zeigen vollständig (contain + Padding) */
.page-id-trauerbegleitung .section-split__media,
body.trauerbegleitung-page .section-split__media,
.page-template-default .section-split:has(img[src*="app-"]) .section-split__media {
    background: transparent;
}
.page-id-trauerbegleitung .section-split__media img,
body.trauerbegleitung-page .section-split__media img,
.section-split__media img[src*="app-"] {
    object-fit: contain !important;
    max-height: 520px;
    min-height: 320px;
    box-shadow: none !important;
    background: transparent !important;
    padding: 0 var(--space-3);
}
.section-split__content {
    padding: var(--space-5);
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.section-split__headline { margin-bottom: var(--space-3); font-size: clamp(1.375rem, 2.2vw, 1.75rem); }
.section-split__body { margin-bottom: var(--space-3); font-size: 1.0625rem; }
.section-split__body > * + * { margin-top: 1em; }

/* Text -------------------------------------------------------------------- */
.section-text__inner {
    max-width: var(--container-narrow);
    margin: 0 auto;
    padding: var(--space-5);
    background: var(--lg-bg-strong);
    backdrop-filter: blur(var(--lg-blur)) saturate(var(--lg-saturate)) brightness(var(--lg-brightness));
    -webkit-backdrop-filter: blur(var(--lg-blur)) saturate(var(--lg-saturate)) brightness(var(--lg-brightness));
    border: var(--lg-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-glass);
    position: relative;
    overflow: hidden;
    isolation: isolate;
}
.section-text__inner::before {
    content: "";
    position: absolute;
    inset: 0;
    background: var(--lg-highlight);
    pointer-events: none;
    border-radius: inherit;
    mix-blend-mode: overlay;
}
.section-text__inner > * { position: relative; z-index: 1; }
.section-text--center { text-align: center; }
.section-text__headline { margin-bottom: var(--space-3); }
.section-text__body { font-size: 1.0625rem; }
.section-text__body > * + * { margin-top: 1em; }
.section-text__body h2, .section-text__body h3 { margin-top: 1.5em; margin-bottom: 0.5em; }

/* Team-Grid: text-block voll Container-breit + transparent wenn Team drin -- */
.section-text:has(.team-grid),
.section-text:has(.hinweise-box),
.section-text:has(.broschuere-feature) {
    padding-top: var(--space-5);
    padding-bottom: var(--space-4);
}
.team-grid { margin-bottom: 0; }
.section-text__inner:has(.team-grid) {
    max-width: var(--container);
    background: transparent !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    border: 0 !important;
    box-shadow: none !important;
    padding: 0 var(--space-3) var(--space-3);
}
.section-text__inner:has(.team-grid)::before { display: none; }
.section-text__inner:has(.team-grid) .team-grid { margin-top: var(--space-4); margin-bottom: 0; }

.team-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-4);
    margin-top: var(--space-5);
    text-align: left;
}
@media (min-width: 700px) {
    .team-grid { grid-template-columns: 1fr 1fr; gap: var(--space-5); }
    .team-grid--3 { grid-template-columns: repeat(3, 1fr); }
}
.team-card {
    margin: 0;
    padding: 0;
    background: transparent;
    border: 0;
    box-shadow: none;
    transition: transform .35s cubic-bezier(.2,.8,.2,1);
}
.team-card:hover {
    transform: translateY(-6px);
}
.team-card__media {
    aspect-ratio: 1/1;
    overflow: hidden;
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-deep), 0 0 0 1px rgba(255,255,255,0.4);
    position: relative;
    line-height: 0;
}
.team-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .8s ease;
}
.team-card:hover .team-card__media img { transform: scale(1.04); }
.team-card__caption {
    padding: var(--space-3) var(--space-2) 0 !important;
    text-align: left;
}
.team-card__name {
    font-size: 1.375rem;
    margin-bottom: 4px;
    color: var(--text-headline);
}
.team-card__role {
    font-size: 0.8125rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--primary-deep);
    margin-bottom: var(--space-2);
}
.team-card__bio {
    font-size: 0.9375rem;
    color: var(--text-body);
    line-height: 1.6;
}

/* TIDE TV feature (text + YouTube) --------------------------------------- */
.tide-feature {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-4);
    margin-top: var(--space-6);
    align-items: center;
    text-align: left;
}
@media (min-width: 900px) {
    .tide-feature { grid-template-columns: 1.25fr 1fr; gap: var(--space-5); }
    .tide-feature--video-left .tide-feature__media   { order: 1; }
    .tide-feature--video-left .tide-feature__text    { order: 2; }
    .tide-feature--video-right .tide-feature__media  { order: 2; }
    .tide-feature--video-right .tide-feature__text   { order: 1; }
}

/* Section-text inner full-width override (used by team_grid + video) */
.section-text__inner--full {
    max-width: var(--container) !important;
    background: transparent !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    border: 0 !important;
    box-shadow: none !important;
    padding: 0 var(--space-3) !important;
}
.section-text__inner--full::before { display: none !important; }
.section-text__inner--full > * { position: relative; z-index: 1; }
.tide-feature__text { padding: var(--space-3); }
.tide-feature__title {
    font-size: clamp(1.25rem, 2vw, 1.625rem);
    margin: var(--space-2) 0 var(--space-2);
    color: var(--text-headline);
}
.tide-feature__text p { font-size: 1rem; color: var(--text-body); line-height: 1.7; }

.responsive-video {
    position: relative;
    aspect-ratio: 16/9;
    border-radius: var(--radius-lg);
    overflow: hidden;
    background: #000;
    box-shadow:
        0 6px 14px rgba(15,23,42,0.10),
        0 24px 48px -12px rgba(15,23,42,0.25),
        0 40px 80px -24px rgba(15,23,42,0.20);
}
.responsive-video iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: 0;
    display: block;
}

/* Broschüre Feature ------------------------------------------------------- */
.broschuere-feature {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-5);
    align-items: center;
    margin-top: var(--space-5);
    text-align: left;
}
@media (min-width: 900px) {
    .broschuere-feature { grid-template-columns: 0.9fr 1.1fr; gap: var(--space-6); }
}
.broschuere-feature__cover {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: var(--space-4);
}
.broschuere-card {
    display: block;
    position: relative;
    width: 100%;
    max-width: 720px;
    background: transparent;
    text-decoration: none !important;
    transition: transform .4s cubic-bezier(.2,.85,.3,1);
}
.broschuere-card img {
    width: 100%;
    height: auto;
    display: block;
    background: transparent;
}
.broschuere-card:hover {
    transform: translateY(-8px) scale(1.02);
}
.broschuere-feature__text { padding: var(--space-3); }
.broschuere-feature__title {
    font-size: clamp(1.5rem, 2.4vw, 1.875rem);
    margin: var(--space-2) 0 var(--space-3);
}
.broschuere-feature__text p {
    font-size: 1rem;
    color: var(--text-body);
    line-height: 1.7;
    margin-bottom: var(--space-4);
}
.broschuere-feature__text .btn {
    margin-top: var(--space-3);
}

/* grievy Features --------------------------------------------------------- */
.grievy-features {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-3);
    margin-top: var(--space-5);
    text-align: left;
}
@media (min-width: 700px) { .grievy-features { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px){ .grievy-features { grid-template-columns: repeat(3, 1fr); } }

.grievy-feature {
    padding: var(--space-4);
    background: var(--lg-bg-strong);
    backdrop-filter: blur(40px) saturate(110%);
    -webkit-backdrop-filter: blur(40px) saturate(110%);
    border: 1px solid rgba(255,255,255,0.5);
    border-radius: var(--radius-lg);
    box-shadow:
        inset 0 2px 1px rgba(255,255,255,0.7),
        inset 0 -2px 2px rgba(15,23,42,0.08),
        0 6px 12px rgba(15,23,42,0.06),
        0 30px 60px -16px rgba(15,23,42,0.18);
    transition: transform .35s cubic-bezier(.2,.8,.2,1), box-shadow .35s ease;
}
.grievy-feature:hover { transform: translateY(-8px) scale(1.02); box-shadow: var(--shadow-glass-hover); }
.grievy-feature__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 56px; height: 56px;
    border-radius: 14px;
    background: linear-gradient(135deg, rgba(123,179,217,0.3), rgba(184,212,232,0.4));
    color: var(--primary-deep);
    margin-bottom: var(--space-2);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.6);
}
.grievy-feature__icon svg { width: 28px; height: 28px; }
.grievy-feature__title { font-size: 1.125rem; margin-bottom: 6px; color: var(--text-headline); }
.grievy-feature__body { font-size: 0.9375rem; color: var(--text-body); line-height: 1.6; margin: 0; }

.grievy-features__cta {
    text-align: center;
    margin-top: var(--space-5);
}

/* grievy Outro (dark CTA) ------------------------------------------------- */
.grievy-outro {
    background: linear-gradient(180deg, var(--bg-deep) 0%, var(--bg-deep-2) 100%);
    color: var(--text-on-dark);
    padding: var(--space-7) var(--space-5);
    border-radius: var(--radius-xl);
    text-align: center;
    margin: var(--space-5) 0;
    box-shadow: 0 30px 60px -20px rgba(15,23,42,0.40);
    position: relative;
    overflow: hidden;
}
.grievy-outro::before {
    content: "";
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(123,179,217,0.5), transparent);
}
.grievy-outro__title {
    color: #fff;
    font-size: clamp(1.875rem, 4vw, 2.75rem);
    margin-bottom: var(--space-3);
    letter-spacing: -0.02em;
}
.grievy-outro__sub {
    max-width: 620px;
    margin: 0 auto var(--space-5);
    color: var(--text-on-dark-muted);
    font-size: 1.0625rem;
    line-height: 1.7;
}
.grievy-outro__socials {
    display: flex;
    justify-content: center;
    gap: var(--space-2);
    margin-bottom: var(--space-5);
    flex-wrap: wrap;
}
.grievy-outro__social {
    width: 48px; height: 48px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(255,255,255,0.08);
    color: var(--text-on-dark);
    transition: background-color .25s ease, transform .25s ease, color .25s ease;
    text-decoration: none !important;
    border: 1px solid rgba(255,255,255,0.10);
}
.grievy-outro__social:hover {
    background: linear-gradient(135deg, var(--primary), var(--primary-deep));
    color: #fff;
    transform: translateY(-2px);
    border-color: transparent;
}
.grievy-outro__social svg { width: 22px; height: 22px; }
.grievy-outro__stores {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: var(--space-2);
    flex-wrap: wrap;
}
.grievy-outro__stores a {
    display: inline-flex;
    align-items: center;
    height: 56px;
    transition: transform .25s ease;
}
.grievy-outro__stores a:hover { transform: translateY(-2px); }
.grievy-outro__stores img {
    height: 56px;
    width: auto;
    display: block;
    object-fit: contain;
}

/* Gallery Slider --------------------------------------------------------- */
.gallery-slider {
    width: 100%;
    margin-top: var(--space-4);
    padding-bottom: var(--space-3);
}
.gallery-slider__viewport {
    overflow-x: clip;
    overflow-y: visible;
    padding: 12px 0 56px;
    margin: -12px 0 -56px;
}
.gallery-slider__track {
    display: flex;
    gap: var(--space-3);
    transition: transform .8s cubic-bezier(.2,.85,.3,1);
    will-change: transform;
}
.gallery-slider__slide {
    flex: 0 0 calc((100% - var(--space-3) * 2) / 3);
    margin: 0;
    aspect-ratio: 4/3;
    overflow: hidden;
    border-radius: var(--radius-lg);
    box-shadow:
        0 6px 14px rgba(15,23,42,0.10),
        0 24px 48px -12px rgba(15,23,42,0.25),
        0 40px 80px -24px rgba(15,23,42,0.20);
    transition: transform .45s cubic-bezier(.2,.85,.3,1), box-shadow .45s ease;
    cursor: pointer;
}
.gallery-slider__slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .7s cubic-bezier(.2,.85,.3,1), filter .35s ease;
}
.gallery-slider__slide:hover {
    transform: translateY(-12px) scale(1.06) rotate(-1.5deg);
    box-shadow:
        0 10px 20px rgba(15,23,42,0.14),
        0 32px 64px -12px rgba(15,23,42,0.32),
        0 60px 100px -24px rgba(15,23,42,0.25);
}
.gallery-slider__slide:hover img {
    transform: scale(1.08);
    filter: saturate(1.1);
}
@media (max-width: 899px) {
    .gallery-slider__slide { flex: 0 0 calc((100% - var(--space-3)) / 2); }
}
@media (max-width: 599px) {
    .gallery-slider__slide { flex: 0 0 100%; }
}

/* Glass Dots */
.gallery-slider__dots {
    display: flex;
    justify-content: center;
    gap: 10px;
    margin-top: var(--space-4);
}
.gallery-slider__dot {
    width: 14px; height: 14px;
    border-radius: 50%;
    border: 1px solid rgba(255,255,255,0.6);
    background: linear-gradient(135deg, rgba(255,255,255,0.18), rgba(255,255,255,0.04));
    backdrop-filter: blur(8px) saturate(160%);
    cursor: pointer;
    padding: 0;
    transition: width .3s ease, background-color .3s ease, transform .25s ease;
    box-shadow:
        inset 0 1px 1px rgba(255,255,255,0.6),
        0 2px 6px rgba(15,23,42,0.10);
}
.gallery-slider__dot:hover { transform: scale(1.2); }
.gallery-slider__dot.is-active {
    width: 36px;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--primary), var(--primary-deep));
    border-color: transparent;
}

/* Lightbox */
.gallery-lightbox {
    position: fixed;
    inset: 0;
    background: rgba(15,23,42,0.85);
    backdrop-filter: blur(20px);
    z-index: 9999;
    display: none;
    align-items: center;
    justify-content: center;
    padding: var(--space-4);
    opacity: 0;
    transition: opacity .3s ease;
}
.gallery-lightbox.is-open { display: flex; opacity: 1; }
.gallery-lightbox img {
    max-width: 92vw;
    max-height: 88vh;
    object-fit: contain;
    border-radius: var(--radius-md);
    box-shadow: 0 30px 80px -20px rgba(0,0,0,0.6);
}
.gallery-lightbox__close,
.gallery-lightbox__prev,
.gallery-lightbox__next {
    position: absolute;
    width: 48px; height: 48px;
    border-radius: 50%;
    background: rgba(255,255,255,0.18);
    border: 1px solid rgba(255,255,255,0.3);
    backdrop-filter: blur(12px);
    color: #fff;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background .25s ease, transform .25s ease;
}
.gallery-lightbox__close { top: 24px; right: 24px; }
.gallery-lightbox__prev  { top: 50%; left: 24px; transform: translateY(-50%); }
.gallery-lightbox__next  { top: 50%; right: 24px; transform: translateY(-50%); }
.gallery-lightbox__close:hover,
.gallery-lightbox__prev:hover,
.gallery-lightbox__next:hover { background: rgba(255,255,255,0.3); }
.gallery-lightbox__prev:hover { transform: translateY(-50%) scale(1.1); }
.gallery-lightbox__next:hover { transform: translateY(-50%) scale(1.1); }

/* Hinweise Box ------------------------------------------------------------ */
.hinweise-box {
    margin-top: var(--space-6);
    margin-bottom: var(--space-6);
    padding: var(--space-5) !important;
    background: var(--lg-bg-strong);
    backdrop-filter: blur(40px) saturate(110%);
    -webkit-backdrop-filter: blur(40px) saturate(110%);
    border: 1px solid rgba(255,255,255,0.5);
    border-radius: var(--radius-lg);
    box-shadow:
        inset 0 2px 1px rgba(255,255,255,0.7),
        inset 0 -2px 2px rgba(15,23,42,0.08),
        0 6px 12px rgba(15,23,42,0.06),
        0 30px 60px -16px rgba(15,23,42,0.20);
    text-align: left;
}
.hinweise-box__head {
    text-align: center;
    margin-bottom: var(--space-4);
}
.hinweise-box__title {
    margin: var(--space-2) 0 0;
    font-size: clamp(1.25rem, 2vw, 1.625rem);
}
.hinweise-box__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-3);
    margin-bottom: var(--space-4);
}
@media (min-width: 700px) {
    .hinweise-box__grid { grid-template-columns: 1fr 1fr; gap: var(--space-4); }
}
.hinweise-item {
    display: grid;
    grid-template-columns: 36px minmax(0, 1fr);
    gap: var(--space-2);
    align-items: start;
}
.hinweise-item__text { min-width: 0; }
.hinweise-item__icon {
    width: 36px; height: 36px;
    border-radius: 50%;
    background: rgba(220,38,38,0.10);
    color: #b91c1c;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    margin-top: 2px;
}
.hinweise-item__title {
    display: block;
    font-weight: 600;
    color: var(--text-headline);
    font-size: 1rem;
    margin-bottom: 4px;
}
.hinweise-item__text p {
    font-size: 0.9375rem;
    color: var(--text-body);
    line-height: 1.6;
    margin: 0;
}
.hinweise-box__crisis {
    margin: 0;
    padding: var(--space-3);
    background: rgba(220,38,38,0.08);
    border-left: 3px solid #b91c1c;
    border-radius: 8px;
    font-size: 0.9375rem;
    color: var(--text-body);
    line-height: 1.6;
}
.hinweise-box__crisis a { color: var(--primary-deep); }

/* Make text_block transparent when it contains tide/broschüre/hinweise/grievy (full width) */
.section-text__inner:has(.tide-feature),
.section-text__inner:has(.broschuere-feature),
.section-text__inner:has(.hinweise-box),
.section-text__inner:has(.grievy-features),
.section-text__inner:has(.grievy-outro),
.section-text__inner:has(.gallery-slider) {
    max-width: var(--container);
    background: transparent !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    border: 0 !important;
    box-shadow: none !important;
    padding: 0 var(--space-3);
}
.section-text__inner:has(.tide-feature)::before,
.section-text__inner:has(.broschuere-feature)::before,
.section-text__inner:has(.hinweise-box)::before,
.section-text__inner:has(.grievy-features)::before,
.section-text__inner:has(.grievy-outro)::before,
.section-text__inner:has(.gallery-slider)::before { display: none; }

/* Cards ------------------------------------------------------------------- */
.section-cards__inner {
    max-width: var(--container);
    margin: 0 auto;
    padding: 0 var(--space-3);
}
.section-cards__head {
    text-align: center;
    margin-bottom: var(--space-6);
    max-width: 760px;
    margin-left: auto;
    margin-right: auto;
}
.section-cards__head h2 { margin-bottom: var(--space-2); }
.section-cards__head p { color: var(--text-body); font-size: 1.0625rem; }
.section-cards__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-3);
}
@media (min-width: 600px) {
    .section-cards__grid--2 { grid-template-columns: repeat(2, 1fr); }
    .section-cards__grid--3 { grid-template-columns: repeat(2, 1fr); }
    .section-cards__grid--4 { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 900px) {
    .section-cards__grid--3 { grid-template-columns: repeat(3, 1fr); }
    .section-cards__grid--4 { grid-template-columns: repeat(4, 1fr); }
}
.card {
    padding: var(--space-4);
    height: 100%;
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    transition: transform .35s cubic-bezier(.2,.8,.2,1), box-shadow .35s ease, background-color .35s ease;
    will-change: transform;
}
.card:hover {
    transform: translateY(-8px) scale(1.02);
    background: var(--lg-bg-strong);
    box-shadow: var(--shadow-glass-hover);
}
.card__icon {
    width: 56px; height: 56px;
    background: linear-gradient(135deg, rgba(123,179,217,0.3), rgba(184,212,232,0.4));
    border-radius: var(--radius-md);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.6);
}
.card__icon img { width: 32px; height: 32px; object-fit: contain; }
.card__title { font-size: 1.125rem; margin-bottom: 4px; }
.card p { font-size: 0.9375rem; line-height: 1.6; }

/* Steps ------------------------------------------------------------------- */
.section-steps__inner {
    max-width: var(--container-narrow);
    margin: 0 auto;
    padding: 0 var(--space-3);
}
.section-steps__head { margin-bottom: var(--space-6); text-align: center; }
.section-steps__head h2 { margin-bottom: var(--space-2); }
.section-steps__head p { color: var(--text-body); font-size: 1.0625rem; }
.section-steps__list {
    list-style: none;
    margin: 0; padding: 0;
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}
.step {
    display: grid;
    grid-template-columns: 64px 1fr;
    gap: var(--space-3);
    padding: var(--space-4);
    align-items: start;
    transition: transform .3s ease, box-shadow .3s ease;
}
.step:hover {
    transform: translateX(4px);
    box-shadow: var(--shadow-glass-hover);
}
.step__num {
    width: 52px; height: 52px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--primary), var(--primary-deep));
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 1.125rem;
    box-shadow: 0 8px 16px -4px rgba(74,144,184,0.4), inset 0 1px 0 rgba(255,255,255,0.3);
    flex-shrink: 0;
}
.step__num svg { width: 24px; height: 24px; display: block; }
.card__icon--svg {
    width: 56px; height: 56px;
    border-radius: 14px;
    background: linear-gradient(135deg, rgba(123,179,217,0.3), rgba(184,212,232,0.4));
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--primary-deep);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.6);
}
.card__icon--svg svg { width: 28px; height: 28px; display: block; }
.step__title { margin-bottom: 6px; font-size: 1.125rem; }
.step__body p { font-size: 1rem; }

/* FAQ --------------------------------------------------------------------- */
.section-faq__inner {
    max-width: var(--container-narrow);
    margin: 0 auto;
    padding: 0 var(--space-3);
}
.section-faq__head { text-align: center; margin-bottom: var(--space-6); }
.section-faq__head h2 { margin-bottom: var(--space-2); }
.section-faq__head p { color: var(--text-body); font-size: 1.0625rem; }
.faq__list { display: flex; flex-direction: column; gap: var(--space-2); }
.faq__item {
    padding: var(--space-2) var(--space-3);
    background: var(--lg-bg);
    backdrop-filter: blur(var(--lg-blur)) saturate(var(--lg-saturate));
    -webkit-backdrop-filter: blur(var(--lg-blur)) saturate(var(--lg-saturate));
    border: var(--lg-border);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-soft);
    transition: border-color .2s, box-shadow .25s ease, background-color .25s;
}
.faq__item:hover { background: var(--lg-bg-strong); }
.faq__item[open] {
    border-color: rgba(123,179,217,0.5);
    background: var(--lg-bg-strong);
    box-shadow: var(--shadow-glass);
}
.faq__q {
    cursor: pointer;
    font-weight: 600;
    color: var(--text-headline);
    list-style: none;
    padding: var(--space-2) 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--space-2);
    font-size: 1.0625rem;
}
.faq__q::-webkit-details-marker { display: none; }
.faq__q::after {
    content: "+";
    font-size: 1.5rem;
    line-height: 1;
    color: var(--primary-deep);
    width: 28px; height: 28px;
    border-radius: 50%;
    background: rgba(123,179,217,0.18);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: transform .25s ease, background-color .2s;
    flex-shrink: 0;
}
.faq__item[open] .faq__q::after { content: "−"; background: rgba(123,179,217,0.35); }
.faq__a { padding: var(--space-2) 0 var(--space-1); border-top: 1px solid rgba(229,231,235,0.7); margin-top: var(--space-1); }
.faq__a > * + * { margin-top: 1em; }

/* Quote ------------------------------------------------------------------- */
.section-quote__inner {
    max-width: var(--container-narrow);
    margin: 0 auto;
    padding: var(--space-6) var(--space-5);
    text-align: center;
    position: relative;
}
.section-quote__inner::after {
    content: "";
    position: absolute;
    top: var(--space-3); left: 50%;
    transform: translateX(-50%);
    width: 48px; height: 48px;
    background: linear-gradient(135deg, var(--primary), var(--primary-deep));
    -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M9 7H5a2 2 0 0 0-2 2v4a2 2 0 0 0 2 2h2v3l5-5V9a2 2 0 0 0-2-2H9zm10 0h-4a2 2 0 0 0-2 2v4a2 2 0 0 0 2 2h2v3l5-5V9a2 2 0 0 0-2-2h-1z'/></svg>") center/contain no-repeat;
            mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M9 7H5a2 2 0 0 0-2 2v4a2 2 0 0 0 2 2h2v3l5-5V9a2 2 0 0 0-2-2H9zm10 0h-4a2 2 0 0 0-2 2v4a2 2 0 0 0 2 2h2v3l5-5V9a2 2 0 0 0-2-2h-1z'/></svg>") center/contain no-repeat;
    opacity: 0.55;
}
.section-quote__text {
    font-size: clamp(1.25rem, 2.2vw, 1.625rem);
    font-style: italic;
    color: var(--text-headline);
    line-height: 1.5;
    margin: var(--space-4) 0 var(--space-3);
    font-weight: 500;
    letter-spacing: -0.01em;
}
.section-quote__author {
    font-size: 0.8125rem;
    color: var(--primary-deep);
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    font-style: normal;
}
.section-quote__author::before { content: "— "; }

/* CTA --------------------------------------------------------------------- */
.section-cta__inner {
    max-width: var(--container-narrow);
    margin: 0 auto;
    padding: 0 var(--space-3);
}
.section-cta__inner--card .section-cta__box {
    padding: var(--space-6) var(--space-5);
    text-align: center;
}
.section-cta__inner--accent_bg .section-cta__box {
    background: linear-gradient(135deg, var(--primary) 0%, var(--primary-deep) 100%);
    color: #fff;
    border-radius: var(--radius-lg);
    padding: var(--space-7) var(--space-5);
    text-align: center;
    position: relative;
    overflow: hidden;
    box-shadow: var(--shadow-deep), 0 0 0 1px rgba(255,255,255,0.2);
}
.section-cta__inner--accent_bg .section-cta__box::before {
    content: "";
    position: absolute;
    top: -50%; left: -50%;
    width: 200%; height: 200%;
    background: radial-gradient(circle, rgba(255,255,255,0.18) 0%, transparent 50%);
    pointer-events: none;
    animation: ctaShimmer 8s ease-in-out infinite alternate;
}
@keyframes ctaShimmer {
    0%   { transform: translate(0, 0); }
    100% { transform: translate(10%, 10%); }
}
.section-cta__inner--accent_bg .section-cta__headline,
.section-cta__inner--accent_bg .section-cta__body { color: #fff; position: relative; }
.section-cta__headline { margin-bottom: var(--space-2); }
.section-cta__body { margin-bottom: var(--space-4); font-size: 1.0625rem; }
.section-cta__inner--accent_bg .btn--primary {
    background: #fff;
    color: var(--primary-deep);
    position: relative;
    box-shadow: 0 12px 28px -8px rgba(0,0,0,0.25);
}
.section-cta__inner--accent_bg .btn--primary:hover {
    background: var(--bg-light);
    color: var(--primary-deep);
    transform: translateY(-2px);
    box-shadow: 0 18px 36px -8px rgba(0,0,0,0.3);
}

/* Utility ----------------------------------------------------------------- */
.text-center { text-align: center; }
.no-js .site-nav { display: block !important; position: static; padding: 0; background: transparent; box-shadow: none; }

/* WPForms — theme-matching styles ----------------------------------------- */
.wpforms-container {
    margin-top: var(--space-3) !important;
}
.wpforms-container .wpforms-form {
    background: var(--lg-bg-strong);
    backdrop-filter: blur(40px) saturate(110%);
    -webkit-backdrop-filter: blur(40px) saturate(110%);
    border: 1px solid rgba(255,255,255,0.5);
    border-radius: var(--radius-lg);
    box-shadow:
        inset 0 2px 1px rgba(255,255,255,0.7),
        inset 0 -2px 2px rgba(15,23,42,0.08),
        0 6px 12px rgba(15,23,42,0.06),
        0 30px 60px -16px rgba(15,23,42,0.18);
    padding: var(--space-5) var(--space-4);
}
.wpforms-container .wpforms-field {
    padding: 0 0 var(--space-3) !important;
    margin: 0 !important;
}
.wpforms-container label.wpforms-field-label {
    font-weight: 600 !important;
    color: var(--text-headline) !important;
    font-size: 0.9375rem !important;
    margin-bottom: 8px !important;
    display: block !important;
}
.wpforms-container .wpforms-field-required-indicator,
.wpforms-container .wpforms-required-label {
    color: var(--primary-deep) !important;
}
.wpforms-container .wpforms-field-sublabel,
.wpforms-container .wpforms-field-description {
    font-size: 0.8125rem !important;
    color: var(--text-body) !important;
    margin-top: 4px !important;
}
.wpforms-container input[type="text"],
.wpforms-container input[type="email"],
.wpforms-container input[type="tel"],
.wpforms-container input[type="url"],
.wpforms-container input[type="number"],
.wpforms-container input[type="password"],
.wpforms-container select,
.wpforms-container textarea {
    width: 100% !important;
    padding: 12px 16px !important;
    background: rgba(255,255,255,0.7) !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--radius-sm) !important;
    font-family: var(--font-sans) !important;
    font-size: 1rem !important;
    color: var(--text-headline) !important;
    transition: border-color .2s, background-color .2s, box-shadow .2s !important;
    box-shadow: inset 0 1px 2px rgba(15,23,42,0.04) !important;
}
.wpforms-container input:focus,
.wpforms-container select:focus,
.wpforms-container textarea:focus {
    outline: none !important;
    border-color: var(--primary) !important;
    background: #fff !important;
    box-shadow: 0 0 0 3px rgba(123,179,217,0.20), inset 0 1px 2px rgba(15,23,42,0.04) !important;
}
.wpforms-container textarea { min-height: 140px !important; resize: vertical !important; }

/* Intl-Tel-Input (Telefonnummer mit Länderfahne) — Platz für Flagge */
.wpforms-container .iti { width: 100%; display: block; }
.wpforms-container .iti input[type="tel"],
.wpforms-container .iti input[type="text"] { padding-left: 56px !important; }
.wpforms-container .iti--separate-dial-code .iti__selected-flag { background-color: transparent !important; }
.wpforms-container .wpforms-field-checkbox label,
.wpforms-container .wpforms-field-radio label {
    display: inline-flex !important;
    align-items: flex-start !important;
    gap: 10px !important;
    color: var(--text-body) !important;
    font-size: 0.9375rem !important;
    cursor: pointer;
}
.wpforms-container .wpforms-field-checkbox input[type="checkbox"],
.wpforms-container .wpforms-field-radio input[type="radio"] {
    width: 18px !important;
    height: 18px !important;
    accent-color: var(--primary-deep);
    margin-top: 2px;
    flex-shrink: 0;
}
.wpforms-container .wpforms-submit-container {
    text-align: left !important;
    margin-top: var(--space-3) !important;
}
.wpforms-container button[type="submit"],
.wpforms-container .wpforms-submit {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    padding: 14px 32px !important;
    background: linear-gradient(135deg, var(--primary), var(--primary-deep)) !important;
    color: #fff !important;
    border: 1px solid transparent !important;
    border-radius: var(--radius-md) !important;
    font-weight: 600 !important;
    font-size: 0.9375rem !important;
    cursor: pointer;
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,0.25),
        0 8px 24px -8px rgba(74,144,184,0.55) !important;
    transition: transform .25s ease, box-shadow .25s ease !important;
}
.wpforms-container button[type="submit"]:hover,
.wpforms-container .wpforms-submit:hover {
    transform: translateY(-2px) !important;
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,0.3),
        0 14px 32px -8px rgba(74,144,184,0.7) !important;
}
.wpforms-container .wpforms-error,
.wpforms-container label.wpforms-error {
    color: #b91c1c !important;
    font-size: 0.8125rem !important;
    margin-top: 4px !important;
}
.wpforms-container .wpforms-confirmation-container {
    background: rgba(123,179,217,0.15) !important;
    border: 1px solid var(--primary) !important;
    color: var(--text-headline) !important;
    border-radius: var(--radius-md) !important;
    padding: var(--space-3) var(--space-4) !important;
}

/* iframe section (Antrag) ------------------------------------------------- */
.section-iframe {
    background: #dbeaef;
    padding: 0;
    margin: 0;
    line-height: 0;
}
.section-iframe iframe {
    display: block;
    width: 100%;
    border: 0;
    background: #dbeaef;
}
/* Footer abuts iframe directly — no margin-top on footer when after iframe */
.section-iframe + .site-footer { margin-top: 0; }

/* =========================================================================
   Mobile-specific overrides
   ========================================================================= */
@media (max-width: 767px) {
    body { font-size: 16px; }

    .container, .container--narrow, .container--wide {
        padding-left: var(--space-2);
        padding-right: var(--space-2);
    }

    /* Hero */
    .section-hero {
        padding: var(--space-6) 0 var(--space-5);
        height: auto;
        min-height: 560px;
    }
    .section-hero__sub { -webkit-line-clamp: unset; overflow: visible; display: block; }
    .section-hero__card { padding: var(--space-4) var(--space-3); }
    .section-hero__sub  { font-size: 1rem; }

    /* Pills stacked, full width, left-aligned on mobile */
    .hero-pills {
        flex-direction: column;
        justify-content: stretch;
        gap: 10px;
        margin-top: var(--space-3);
    }
    .hero-pill {
        width: 100%;
        justify-content: flex-start;
        padding: 14px 22px 14px 16px;
        min-height: 64px;
    }

    /* Sections */
    .section-split,
    .section-text,
    .section-cards,
    .section-steps,
    .section-faq,
    .section-quote,
    .section-cta {
        padding: var(--space-5) 0;
    }
    .section-split__inner { gap: var(--space-3); }
    .section-split__media img { min-height: 240px; }
    .section-split__content { padding: var(--space-3); }

    .section-text__inner { padding: var(--space-3); }

    .section-cards__head { margin-bottom: var(--space-4); }

    .step { grid-template-columns: 48px 1fr; padding: var(--space-3); gap: var(--space-2); }
    .step__num { width: 44px; height: 44px; font-size: 1rem; }

    .faq__item { padding: var(--space-1) var(--space-2); }
    .faq__q { font-size: 1rem; padding: 12px 0; }

    .section-quote__inner { padding: var(--space-4) var(--space-3); }
    .section-quote__text  { font-size: 1.125rem; }

    .section-cta__inner--card .section-cta__box,
    .section-cta__inner--accent_bg .section-cta__box {
        padding: var(--space-4) var(--space-3);
    }

    /* Team-grid stacks */
    .team-card__caption { padding: var(--space-3); }

    /* Footer */
    .site-footer { padding: var(--space-5) 0 var(--space-3); }
    .site-footer__inner { gap: var(--space-4); }

    /* Hero card heading bigger but not crazy */
    .section-hero__headline { font-size: clamp(1.5rem, 7vw, 2.25rem); }
}

/* Tablet tweaks */
@media (min-width: 768px) and (max-width: 1023px) {
    .section-hero__card { padding: var(--space-5) var(--space-4); }
    .hero-pills { justify-content: flex-start; }
}

/* Floating CTA — bottom-right desktop, full-width bar mobile -------------- */
.floating-cta {
    position: fixed;
    z-index: 90;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 14px 26px;
    background: linear-gradient(135deg, var(--primary), var(--primary-deep));
    color: #fff !important;
    font-weight: 600;
    font-size: 0.9375rem;
    text-decoration: none !important;
    border-radius: 999px;
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,0.25),
        0 8px 24px -6px rgba(74,144,184,0.55),
        0 20px 40px -12px rgba(15,23,42,0.30);
    transition: transform .25s ease, box-shadow .25s ease;
    bottom: 24px;
    right: 24px;
}
.floating-cta:hover, .floating-cta:focus {
    transform: translateY(-2px);
    color: #fff;
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,0.3),
        0 14px 32px -6px rgba(74,144,184,0.7),
        0 28px 56px -16px rgba(15,23,42,0.35);
}
.floating-cta__icon { display: block; flex-shrink: 0; }
.floating-cta__label { white-space: nowrap; }

/* Mobile: full-width bottom bar */
@media (max-width: 767px) {
    .floating-cta {
        left: 16px;
        right: 16px;
        bottom: 16px;
        justify-content: center;
        border-radius: 999px;
        padding: 14px 20px;
        font-size: 1rem;
    }
}

/* === CUSTOM DOT CURSOR (Desktop only) ================================== */
@media (hover: hover) and (pointer: fine) {
    html.has-dot, html.has-dot body, html.has-dot * { cursor: none !important; }
    .cursor-dot {
        position: fixed;
        top: 0; left: 0;
        width: 16px; height: 16px;
        border-radius: 50%;
        background: #ffffff;
        pointer-events: none;
        z-index: 99999;
        mix-blend-mode: difference;
        transition: width .25s cubic-bezier(.2,.85,.3,1), height .25s cubic-bezier(.2,.85,.3,1), opacity .15s ease, background-color .2s ease, border-color .2s ease, box-shadow .25s ease, backdrop-filter .25s ease;
        opacity: 0;
        border: 0 solid transparent;
    }
    .cursor-dot.is-active { opacity: 1; }
    .cursor-dot.is-hover {
        width: 80px; height: 80px;
        mix-blend-mode: normal;
        background: rgba(255, 255, 255, 0.04);
        backdrop-filter: url(#cursor-lens) brightness(1.10) saturate(1.3);
        -webkit-backdrop-filter: url(#cursor-lens) brightness(1.10) saturate(1.3);
        border: 1px solid rgba(255, 255, 255, 0.55);
        box-shadow:
            inset 0 4px 8px rgba(255, 255, 255, 0.45),
            inset 0 -6px 14px rgba(15, 23, 42, 0.08),
            inset 6px 0 12px -4px rgba(255, 255, 255, 0.28),
            inset -6px 0 12px -4px rgba(255, 255, 255, 0.28),
            inset 0 0 0 1px rgba(255, 255, 255, 0.18),
            0 8px 18px -4px rgba(15, 23, 42, 0.22),
            0 18px 40px -10px rgba(15, 23, 42, 0.18),
            0 0 0 0.5px rgba(255, 255, 255, 0.7);
        opacity: 1;
    }
    .cursor-dot.is-hover::before {
        content: "";
        position: absolute;
        inset: 0;
        border-radius: inherit;
        background:
            radial-gradient(ellipse 65% 50% at 30% 25%, rgba(255,255,255,0.75) 0%, rgba(255,255,255,0.15) 35%, transparent 60%),
            radial-gradient(ellipse 50% 30% at 70% 80%, rgba(255,255,255,0.20) 0%, transparent 60%);
        pointer-events: none;
    }
    .cursor-dot.is-hover::after {
        content: "";
        position: absolute;
        inset: 0;
        border-radius: inherit;
        background: radial-gradient(circle at 50% 50%, transparent 60%, rgba(15,23,42,0.05) 100%);
        pointer-events: none;
    }
}

/* === Micro hover-effects (with !important to win over earlier rules) === */
.btn:hover, .btn:focus { transform: translateY(-2px) scale(1.03) !important; }
.card { transition: transform .45s cubic-bezier(.2,.85,.3,1), box-shadow .35s ease, background-color .35s ease !important; }
.card:hover { transform: translateY(-12px) scale(1.06) rotate(-1.5deg) !important; }
.grievy-feature { transition: transform .45s cubic-bezier(.2,.85,.3,1), box-shadow .35s ease !important; }
.grievy-feature:hover { transform: translateY(-12px) scale(1.06) rotate(-1.5deg) !important; }
.team-card { transition: transform .45s cubic-bezier(.2,.85,.3,1) !important; }
.team-card:hover { transform: translateY(-12px) scale(1.06) rotate(-1.5deg) !important; }
.broschuere-card { transition: transform .5s cubic-bezier(.2,.85,.3,1) !important; }
.broschuere-card:hover { transform: translateY(-14px) scale(1.06) rotate(-2deg) !important; }
.hero-pill:hover, .hero-pill:focus { transform: translateY(-2px) scale(1.02) !important; }
.mega-menu__link:hover { transform: translateY(-1px) !important; }
.faq__item:hover { transform: translateX(3px) !important; }
.site-footer__social a:hover, .grievy-outro__social:hover { transform: translateY(-3px) scale(1.1) !important; }
.mega-panel__item:hover { transform: translateX(4px) !important; }

/* === SCROLL REVEAL ===================================================== */
[data-reveal] {
    opacity: 0;
    transform: translateY(24px);
    transition:
        opacity .8s cubic-bezier(0.16, 1, 0.3, 1),
        transform .8s cubic-bezier(0.16, 1, 0.3, 1);
    transition-delay: var(--reveal-delay, 0ms);
    will-change: opacity, transform;
}
[data-reveal].is-visible {
    opacity: 1;
    transform: translateY(0);
}
[data-reveal="fade"] { transform: none; }
[data-reveal="left"]  { transform: translateX(-24px); }
[data-reveal="left"].is-visible  { transform: translateX(0); }
[data-reveal="right"] { transform: translateX(24px); }
[data-reveal="right"].is-visible { transform: translateX(0); }

@media (prefers-reduced-motion: reduce) {
    [data-reveal] { opacity: 1; transform: none; transition: none; }
}
@media print {
    [data-reveal] { opacity: 1 !important; transform: none !important; }
}

/* Reduced motion ---------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
}
