:root {
    --font-ui: 'Plus Jakarta Sans', 'Segoe UI', Arial, sans-serif;
    --font-ui-modern: 'Plus Jakarta Sans', 'Segoe UI', Arial, sans-serif;
    --font-display: 'Plus Jakarta Sans', 'Segoe UI', Arial, sans-serif;
    --font-weight-body: 500;
    --font-weight-label: 600;
    --font-weight-heading: 700;
    --section-tone-a: #d7efed;
    --section-tone-b: #bfdfdd;
    --color-white: #fff;
    --color-text: #222;
    --color-accent: #35c4c7;
    --color-accent-dark: #24898e;
    --color-accent-deep: #23676d;
    --color-bg-soft: #f7ede0;
    --surface-card: rgba(255, 250, 241, 0.95);
    --surface-card-soft: rgba(251, 245, 235, 0.92);
    --border-soft: rgba(18, 62, 70, 0.10);
    --border-soft-strong: rgba(18, 62, 70, 0.14);
    --radius-card: 24px;
    --radius-card-large: 32px;
    --radius-card-inner: 18px;
    --glass-dark-bg: rgba(10, 21, 29, 0.74);
    --glass-dark-bg-strong: rgba(8, 18, 26, 0.9);
    --glass-dark-border: rgba(235, 246, 243, 0.18);
    --glass-dark-shadow: none;
    --shadow-soft: none;
    --shadow-soft-strong: none;
    --shadow-surface: none;
    --shadow-surface-strong: none;
    --focus-ring-soft: none;
    --shadow-image: none;
}

/* --- Dedicated Responsive Design for Rückblick Image (charity-svg-hero-container) --- */
.charity-svg-hero-container#review {
    width: 100vw;
    max-width: 100vw;
    margin: 0 auto;
    padding: 22px 18px 8px;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    background: #d2ebe8;
    box-sizing: border-box;
    overflow-x: hidden;
}

.charity-svg-hero-container#review::before {
    content: "";
    position: absolute;
    inset: 18px auto auto 50%;
    width: min(72vw, 540px);
    height: clamp(120px, 24vw, 190px);
        --interaction-transform: translateX(-50%);
    transform: translateX(-50%);
    border-radius: 999px;
    background: none;
    pointer-events: none;
}

.charity-svg-hero-container#review img {
    display: block;
    width: 100%;
    max-width: min(82vw, 560px);
    height: auto;
    max-height: none;
    object-fit: contain;
    object-position: center center;
    margin: 0 auto;
    padding: clamp(10px, 1.6vw, 14px);
    box-shadow: none;
    border-radius: 28px;
    border: 1px solid rgba(18, 62, 70, 0.08);
    background: rgba(255, 255, 255, 0.96);
}
@media (max-width: 900px) {
    .charity-svg-hero-container#review {
        margin-bottom: 0;
    }
    .charity-svg-hero-container#review img {
        max-width: min(88vw, 470px);
    }
}
@media (max-width: 600px) {
    .charity-svg-hero-container#review {
        margin-bottom: 0;
    }
    .charity-svg-hero-container#review img {
        max-width: min(92vw, 390px);
        padding: 10px;
        border-radius: 22px;
    }
}
@media (max-width: 400px) {
    .charity-svg-hero-container#review {
        margin-bottom: 0;
    }
    .charity-svg-hero-container#review img {
        max-width: min(94vw, 320px);
    }
}
/* Modern External Link Design */
.external-link {
    color: var(--color-accent);
    font-weight: 700;
    background: var(--color-white);
    border-radius: 8px;
    padding: 4px 12px;
    box-shadow: var(--shadow-soft);
    display: inline-flex;
    align-items: center;
    transition: transform 0.2s ease, box-shadow 0.2s ease, color 0.2s ease, text-decoration-color 0.2s ease;
    text-decoration: none;
    position: relative;
}
.external-link:hover,
.external-link:focus-visible {
    color: var(--color-accent-deep);
    transform: translateY(-1px);
    box-shadow: var(--shadow-soft-strong), var(--focus-ring-soft);
    text-decoration: underline;
    text-decoration-color: currentColor;
    outline: none;
}

.charity-description .external-link,
.event-section .event-description .external-link {
    display: inline;
    padding: 0;
    margin: 0;
    background: none;
    border-radius: 0;
    box-shadow: none;
    color: var(--inline-link-color, #159b8c);
    font-weight: var(--inline-link-weight, 600);
    text-decoration: underline;
    text-decoration-color: var(--inline-link-decoration-color, rgba(21, 155, 140, 0.65));
    text-decoration-thickness: var(--inline-link-thickness, 0.08em);
    text-underline-offset: var(--inline-link-offset, 0.12em);
}

.charity-description .external-link:hover,
.charity-description .external-link:focus,
.event-section .event-description .external-link:hover,
.event-section .event-description .external-link:focus {
    color: var(--inline-link-hover-color, #123e46);
    background: none;
    box-shadow: none;
    transform: none;
    text-decoration-color: currentColor;
    outline: none;
}

/* Footer-Link-Container immer im Vordergrund, keine Überlagerung durch Overlays/Modals/Cookie-Banner */
@media (max-width: 1024px) {
    .site-footer > div {
        position: relative;
        z-index: 10000 !important;
    }

    .site-footer {
        position: relative;
        z-index: 10000 !important;
    }

    /* Footer-Links auf mobilen Geräten immer anklickbar */
    footer a,
    a[href*="impressum"],
    a[href*="datenschutz"],
    a[data-lang="de"],
    a[data-lang="en"],
    a[data-lang="it"] {
        position: relative;
        z-index: 10;
    }

    footer {
        position: relative;
        z-index: 9;
    }
}

@media (max-width: 600px) {
    .charity-description {
        padding-left: 0vw !important;
        padding-right: 0vw !important;
        max-width: 100vw !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        margin-bottom: 2px !important;
    }
}

/* Make all SVG icons in contact info section white */
.contact-info-section img[src$=".svg"] {
    filter: invert(1) brightness(1000%) grayscale(1) !important;
}

.contact-info-section {
    --contact-heading-color: #12333a;
    --contact-title-color: #14353b;
    --contact-copy-color: #18363b;
    --contact-link-color: #0f9184;
    --contact-copy-size: 1.02rem;
    --contact-info-card-border-color: rgba(13, 92, 99, 0.14);
    background: var(--section-tone-a);
    padding: 56px 0 40px;
    text-align: center !important;
    font-family: var(--font-ui-modern);
    color: #173941;
}

.contact-info-container {
    max-width: 860px;
    margin: 0 auto;
    padding: 0 22px;
    text-align: left;
}

.contact-info-title {
    margin: 0 0 10px;
    color: var(--contact-heading-color);
    font-size: clamp(2rem, 3.4vw, 2.6rem);
    font-family: var(--font-display);
    font-weight: 700;
    line-height: 1.02;
    letter-spacing: -0.025em;
    text-wrap: balance;
}

.contact-info-intro {
    max-width: 44ch;
    margin: 0 auto 30px !important;
    color: #173941;
    font-size: 1.05rem;
    font-weight: 520;
    line-height: 1.65;
    letter-spacing: 0.004em;
}

.contact-info-title,
.contact-info-intro {
    text-align: center !important;
}

.contact-info-subtitle {
    margin: 0 0 22px;
    color: var(--contact-title-color);
    font-family: var(--font-ui-modern);
    font-size: clamp(1.22rem, 2vw, 1.44rem);
    font-weight: 800;
    line-height: 1.12;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.contact-info-grid {
    display: grid;
    gap: 22px;
}

.contact-info-card {
    --contact-info-card-gap: 22px;
    --contact-info-card-bg: rgba(255, 255, 255, 0.94);
    --contact-info-card-radius: 22px;
    --contact-info-card-shadow: none;
    --contact-info-card-padding: 24px 28px;
    display: flex;
    align-items: center;
    gap: var(--contact-info-card-gap);
    background: var(--contact-info-card-bg);
    border: 1px solid var(--contact-info-card-border-color);
    border-radius: var(--contact-info-card-radius);
    box-shadow: var(--contact-info-card-shadow);
    padding: var(--contact-info-card-padding);
    text-align: left;
}

.contact-info-card--mail {
    --contact-info-card-shadow: none;
}

.contact-info-icon-wrap {
    --contact-info-icon-wrap-size: 62px;
    --contact-info-icon-wrap-radius: 18px;
    --contact-info-icon-wrap-bg: #176f73;
    --contact-info-icon-wrap-shadow: none;
    --contact-info-icon-wrap-inner-radius: 17px;
    position: relative;
    flex: 0 0 var(--contact-info-icon-wrap-size);
    width: var(--contact-info-icon-wrap-size);
    height: var(--contact-info-icon-wrap-size);
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--contact-info-icon-wrap-bg);
    box-shadow: var(--contact-info-icon-wrap-shadow);
    border-radius: var(--contact-info-icon-wrap-radius);
}

.contact-info-icon-wrap::after {
    content: "";
    position: absolute;
    inset: 1px;
    border-radius: var(--contact-info-icon-wrap-inner-radius);
    background: none;
    pointer-events: none;
}

.contact-info-icon-wrap--time {
    --contact-info-icon-wrap-bg: #1c7f81;
}

.contact-info-icon-wrap--location {
    --contact-info-icon-wrap-bg: #18877f;
}

.contact-info-icon-wrap--mail {
    --contact-info-icon-wrap-bg: #11958a;
}

.contact-info-card-body {
    min-width: 0;
}

.contact-info-icon {
    --contact-info-icon-size: 29px;
    width: var(--contact-info-icon-size);
    height: var(--contact-info-icon-size);
    position: relative;
    z-index: 1;
}

.contact-info-card--time .contact-info-icon {
    --contact-info-icon-size: 27px;
}

.contact-info-card--location .contact-info-icon {
    --contact-info-icon-size: 28px;
}

.contact-info-card--mail .contact-info-icon {
    --contact-info-icon-size: 30px;
}

.contact-info-subtitle,
.contact-info-card,
.contact-info-card-text,
.contact-info-card-link {
    text-align: left !important;
}

.contact-info-card-title {
    margin: 0 0 6px;
    color: var(--contact-title-color);
    font-size: clamp(1.08rem, 1.1vw, 1.2rem);
    font-family: var(--font-ui-modern);
    font-weight: 800;
    line-height: 1.2;
    letter-spacing: -0.01em;
}

.contact-info-card-text,
.contact-info-card-link {
    font-size: var(--contact-copy-size);
    line-height: 1.5;
    letter-spacing: 0.002em;
    word-break: break-word;
}

.contact-info-card-text {
    color: var(--contact-copy-color);
    font-weight: 500;
    text-decoration: none;
}

.contact-info-card-link {
    color: var(--contact-link-color);
    font-weight: 620;
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 0.18em;
}

@media (max-width: 900px) {
    .contact-info-section {
        padding: 46px 0 32px;
    }

    .contact-info-intro {
        margin-bottom: 24px !important;
    }

    .contact-info-subtitle {
        margin-bottom: 18px;
    }

    .contact-info-card {
        --contact-info-card-padding: 22px 22px;
        --contact-info-card-gap: 18px;
        --contact-info-card-radius: 20px;
    }
}

@media (max-width: 600px) {
    .contact-info-section {
        padding: 40px 0 28px;
    }

    .contact-info-container {
        padding: 0 14px;
    }

    .contact-info-title {
        font-size: clamp(1.72rem, 8vw, 2.16rem);
    }

    .contact-info-intro {
        max-width: 32ch;
        font-size: 1rem;
        line-height: 1.52;
        margin-bottom: 20px !important;
    }

    .contact-info-subtitle {
        font-size: clamp(1.16rem, 5vw, 1.38rem);
        margin-bottom: 16px;
    }

    .contact-info-grid {
        gap: 16px;
    }

    .contact-info-card {
        --contact-info-card-padding: 18px 16px;
        --contact-info-card-gap: 14px;
        --contact-info-card-radius: 18px;
        align-items: flex-start;
    }

    .contact-info-icon-wrap {
        --contact-info-icon-wrap-size: 52px;
        --contact-info-icon-wrap-radius: 14px;
        --contact-info-icon-wrap-inner-radius: 13px;
    }

    .contact-info-icon {
        --contact-info-icon-size: 24px;
    }

    .contact-info-card--time .contact-info-icon {
        --contact-info-icon-size: 23px;
    }

    .contact-info-card--location .contact-info-icon {
        --contact-info-icon-size: 22px;
    }

    .contact-info-card--mail .contact-info-icon {
        --contact-info-icon-size: 25px;
    }

    .contact-info-card-title {
        font-size: 1.08rem;
    }

    .contact-info-card-text,
    .contact-info-card-link {
        font-size: 1.01rem;
        line-height: 1.44;
    }
}
@media (min-width: 1200px) {
    #langSwitcher {
        padding-right: 2.5vw;
    }
}
/* Responsive style for music-family-benefits list */
.music-family-section {
    --music-family-heading: #123e46;
    --music-family-accent: #0e8c82;
    --music-family-copy: #173941;
    --music-family-copy-soft: #244e57;
    --music-family-card-border: rgba(17, 52, 58, 0.12);
    --music-family-card-shadow: 0 22px 52px rgba(18, 62, 70, 0.12);
    --music-family-card-highlight: rgba(255, 255, 255, 0.94);
    position: relative;
    overflow: hidden;
    isolation: isolate;
    font-family: var(--font-ui-modern);
    background: var(--section-tone-b);
    padding: 56px 0 50px;
    border-bottom: 1px solid rgba(17, 52, 58, 0.1);
}

.music-family-section::before,
.music-family-section::after {
    content: '';
    position: absolute;
    border-radius: 999px;
    pointer-events: none;
    filter: blur(8px);
}

.music-family-section::before {
    top: -110px;
    right: -80px;
    width: 320px;
    height: 320px;
    background: none;
}

.music-family-section::after {
    left: -120px;
    bottom: -120px;
    width: 340px;
    height: 340px;
    background: none;
}

.music-family-container {
    max-width: 1040px;
    margin: 0 auto;
    padding: 0 24px;
    position: relative;
    z-index: 1;
}

.music-family-title {
    margin: 0 auto 16px;
    color: var(--music-family-heading) !important;
    font-family: var(--font-display) !important;
    font-size: clamp(2.35rem, 4.9vw, 3.95rem) !important;
    font-weight: 700 !important;
    letter-spacing: -0.04em !important;
    text-align: center;
    text-shadow: 0 6px 16px rgba(17, 50, 58, 0.05);
    text-wrap: balance;
}

.music-family-title-accent {
    color: var(--music-family-accent);
}

.music-family-intro {
    max-width: 820px;
    margin: 0 auto 26px;
    display: flex;
    justify-content: center;
}

.music-family-desc {
    margin: 0;
    color: var(--music-family-copy-soft);
    font-family: var(--font-ui-modern);
    font-size: 1.05rem;
    font-weight: 560;
    line-height: 1.68;
    letter-spacing: -0.008em;
    text-align: center;
    text-wrap: balance;
}

.music-family-benefits-row {
    --music-family-benefits-gap: 18px;
    --music-family-benefits-margin-bottom: 28px;
    --music-family-benefits-columns: minmax(0, 1fr) auto minmax(0, 1fr);
    --music-family-benefits-padding: 14px 18px;
    display: grid;
    grid-template-columns: var(--music-family-benefits-columns);
    align-items: center;
    justify-content: center;
    gap: var(--music-family-benefits-gap);
    max-width: 980px;
    margin: 0 auto var(--music-family-benefits-margin-bottom);
}

.music-family-benefits {
    grid-column: 1;
    grid-row: 1;
    margin: 0;
    padding-left: 0 !important;
    list-style: none;
    display: grid;
    gap: 12px;
}

.music-family-benefits li {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 12px;
    align-items: center;
    color: var(--music-family-copy);
    font-family: var(--font-ui-modern);
    text-align: left;
    font-size: 1.05rem !important;
    font-weight: 560;
    line-height: 1.56 !important;
    padding-right: 0 !important;
    padding-left: 0 !important;
    word-break: break-word !important;
    overflow-wrap: break-word !important;
    white-space: normal !important;
    hyphens: auto !important;
}

.music-family-benefit-check {
    width: 1.7rem;
    height: 1.7rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    color: #fff;
    background: #0e8c82;
    box-shadow: none;
    font-size: 0.94rem;
    font-weight: 800;
    line-height: 1;
}

.music-family-logo-mobile {
    --music-family-logo-mobile-padding: 14px 16px;
    --music-family-logo-mobile-radius: 20px;
    --music-family-logo-mobile-bg: rgba(255, 255, 255, 0.72);
    --music-family-logo-mobile-shadow: 0 10px 22px rgba(18, 62, 70, 0.08);
    grid-column: 2;
    grid-row: 1;
    justify-self: center;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--music-family-logo-mobile-padding);
    border-radius: var(--music-family-logo-mobile-radius);
    background: var(--music-family-logo-mobile-bg);
    box-shadow: var(--music-family-logo-mobile-shadow);
    border: 1px solid rgba(17, 52, 58, 0.08);
    position: relative;
    overflow: hidden;
}

.music-family-logo-mobile img {
    display: block;
    width: 100%;
    max-width: 112px;
    height: auto;
}

.music-family-groups {
    --music-family-groups-gap: 22px;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--music-family-groups-gap);
}

.music-family-group {
    --music-family-group-padding: 24px 22px 20px;
    --music-family-group-radius: 24px;
    --music-family-group-bg: var(--music-family-card-highlight);
    background: var(--music-family-group-bg);
    padding: var(--music-family-group-padding);
    border-radius: var(--music-family-group-radius);
    border: 1px solid var(--music-family-card-border);
    box-shadow: var(--music-family-card-shadow);
    position: relative;
    overflow: hidden;
    transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
}

.music-family-group:hover,
.music-family-group:focus-within {
    transform: translateY(-3px);
    box-shadow: var(--shadow-surface-strong);
    border-color: rgba(17, 52, 58, 0.18);
}

.music-family-group::after {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 4px;
    background: #0e8c82;
}

.music-family-group-title {
    --music-family-group-title-margin-bottom: 16px;
    --music-family-group-title-font-size: clamp(1.28rem, 2.08vw, 1.68rem);
    --music-family-group-title-line-height: 1.02;
    margin: 0 0 var(--music-family-group-title-margin-bottom);
    color: var(--music-family-heading);
    font-family: var(--font-display);
    font-size: var(--music-family-group-title-font-size);
    font-weight: 700 !important;
    line-height: 1.1 !important;
    letter-spacing: -0.025em;
    text-wrap: balance;
}

.music-family-group-details {
    margin: 0;
    padding: 0;
    list-style: none;
}

.music-family-group-details li {
    --music-family-group-detail-padding-block: 10px;
    --music-family-group-detail-font-size: 1.02rem;
    --music-family-group-detail-line-height: 1.62;
    padding: var(--music-family-group-detail-padding-block) 0;
    color: var(--music-family-copy);
    font-family: var(--font-ui-modern);
    font-size: var(--music-family-group-detail-font-size);
    font-weight: 530;
    line-height: var(--music-family-group-detail-line-height);
    border-bottom: 1px solid rgba(17, 52, 58, 0.08);
}

.music-family-group-details li:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.music-family-group-details li b {
    color: var(--music-family-heading);
    font-weight: 800;
}

.music-family-contact {
    --music-family-contact-margin-top: 28px;
    margin-top: var(--music-family-contact-margin-top);
    display: flex;
    flex-direction: column;
    align-items: center;
}

.music-family-contact-title {
    --music-family-contact-title-margin-bottom: 10px;
    --music-family-contact-title-font-size: 1.05rem;
    margin-bottom: var(--music-family-contact-title-margin-bottom);
    color: var(--music-family-heading);
    font-family: var(--font-display);
    font-size: var(--music-family-contact-title-font-size);
    font-weight: 800;
    letter-spacing: -0.04em;
    text-align: center;
}

.music-family-contact-card {
    --music-family-contact-card-width: min(100%, 420px);
    --music-family-contact-card-padding: 16px 20px;
    --music-family-contact-card-radius: 22px;
    --music-family-contact-card-bg: rgba(255, 255, 255, 0.96);
    --music-family-contact-card-shadow: 0 20px 36px rgba(18, 62, 70, 0.12);
    width: var(--music-family-contact-card-width);
    min-width: 0;
    padding: var(--music-family-contact-card-padding);
    border-radius: var(--music-family-contact-card-radius);
    background: var(--music-family-contact-card-bg);
    border: 1px solid var(--music-family-card-border);
    box-shadow: var(--music-family-contact-card-shadow);
    text-align: center;
    position: relative;
    overflow: hidden;
    transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
}

.music-family-contact-card:hover,
.music-family-contact-card:focus-within {
    transform: translateY(-2px);
    box-shadow: var(--shadow-surface);
    border-color: rgba(17, 52, 58, 0.18);
}

.music-family-contact-card::before {
    content: none;
    position: absolute;
    inset: 0;
    pointer-events: none;
}

.music-family-contact-name {
    --music-family-contact-name-font-size: 1.14rem;
    display: inline-block;
    margin-bottom: 6px;
    color: var(--music-family-heading);
    font-family: var(--font-display);
    font-size: var(--music-family-contact-name-font-size);
    font-weight: 800;
    letter-spacing: -0.04em;
    position: relative;
    z-index: 1;
}

.music-family-contact-link {
    --music-family-contact-link-font-size: 1rem;
    --music-family-contact-link-line-height: 1.5;
    color: var(--music-family-accent);
    font-family: var(--font-ui-modern);
    font-size: var(--music-family-contact-link-font-size);
    font-weight: 700;
    line-height: var(--music-family-contact-link-line-height);
    text-decoration: underline;
    text-underline-offset: 0.18em;
    word-break: break-word;
    position: relative;
    z-index: 1;
}

@media (max-width: 900px) {
    .music-family-benefits-row {
        --music-family-benefits-columns: minmax(0, 1fr);
    }

    .music-family-benefits,
    .music-family-logo-mobile {
        grid-column: auto;
        grid-row: auto;
    }

    .music-family-logo-mobile {
        width: fit-content;
        justify-self: center;
    }

    .music-family-groups {
        grid-template-columns: minmax(0, 1fr);
    }
}

@media (max-width: 600px) {
    .music-family-section {
        padding: 36px 0 30px;
    }

    .music-family-section::before {
        width: 220px;
        height: 220px;
        top: -80px;
        right: -90px;
    }

    .music-family-section::after {
        width: 220px;
        height: 220px;
        left: -90px;
        bottom: -90px;
    }

    .music-family-container {
        padding: 0 10px;
    }

    .music-family-title {
        font-size: clamp(1.72rem, 8vw, 2.2rem) !important;
    }

    .music-family-desc {
        max-width: 32ch;
        font-size: 1.06rem;
        line-height: 1.46;
    }

    .music-family-benefits-row {
        --music-family-benefits-gap: 12px;
        --music-family-benefits-margin-bottom: 16px;
    }

    .music-family-benefit-check {
        width: 1rem;
        height: 1rem;
        font-size: 0.72rem;
    }

    .music-family-logo-mobile {
        --music-family-logo-mobile-padding: 10px 12px;
        --music-family-logo-mobile-radius: 16px;
    }

    .music-family-groups {
        --music-family-groups-gap: 12px;
    }

    .music-family-group {
        --music-family-group-padding: 14px 14px 12px;
        --music-family-group-radius: 18px;
    }

    .music-family-group-title {
        --music-family-group-title-font-size: 1.2rem;
        --music-family-group-title-margin-bottom: 10px;
    }

    .music-family-group-details li {
        --music-family-group-detail-padding-block: 7px;
        --music-family-group-detail-font-size: 1.08rem;
        --music-family-group-detail-line-height: 1.36;
    }

    .music-family-group-details li b {
        display: inline;
        margin-bottom: 0;
    }

    .music-family-contact {
        --music-family-contact-margin-top: 20px;
    }

    .music-family-contact-title {
        --music-family-contact-title-margin-bottom: 8px;
        --music-family-contact-title-font-size: 1.04rem;
    }

    .music-family-contact-card {
        --music-family-contact-card-width: 100%;
        --music-family-contact-card-padding: 12px 14px;
        --music-family-contact-card-radius: 16px;
    }

    .music-family-contact-name {
        --music-family-contact-name-font-size: 1.03rem;
    }

    .music-family-contact-link {
        --music-family-contact-link-font-size: 0.99rem;
        --music-family-contact-link-line-height: 1.38;
    }
}
/* Inline list: no gaps between ensemble names */
.ensemble-inline-list {
    --ensemble-inline-list-gap: 0.5em;
    display: flex;
    flex-wrap: wrap;
    gap: var(--ensemble-inline-list-gap);
    align-items: baseline;
    list-style: none;
    padding-left: 0;
    margin: 0;
}
.ensemble-inline-list span {
    display: inline-block;
    white-space: nowrap;
}
/* Modern responsive layout for About Me section */
.about-me-section-modern {
    --about-me-accent: #587773;
    --about-me-panel-bg: rgba(255, 255, 255, 0.96);
    --about-me-image-shadow: none;
    --about-me-section-bg: var(--section-tone-a);
    --about-me-section-padding: 6px 0 64px 0;
    --about-me-panel-border: rgba(18, 62, 70, 0.12);
    --about-me-panel-shadow: none;
    position: relative;
    overflow: hidden;
    isolation: isolate;
    width: 100%;
    background: var(--about-me-section-bg);
    padding: var(--about-me-section-padding);
    font-family: var(--font-ui);
}
.about-me-section-modern::before,
.about-me-section-modern::after {
    content: none;
    position: absolute;
    border-radius: 999px;
    pointer-events: none;
}

.about-me-section-modern::before {
    top: -140px;
    right: -120px;
    width: 360px;
    height: 360px;
    background: none;
}

.about-me-section-modern::after {
    left: -120px;
    bottom: -140px;
    width: 360px;
    height: 360px;
    background: none;
}

.about-me-section-modern-inner {
    --about-me-inner-gap: 24px;
    --about-me-inner-width: min(98vw, 1680px);
    --about-me-inner-max-width: 1680px;
    --about-me-inner-padding: 0 18px;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(520px, 1fr);
    align-items: center;
    justify-content: center;
    gap: var(--about-me-inner-gap);
    width: var(--about-me-inner-width);
    max-width: var(--about-me-inner-max-width);
    margin: 0 auto;
    padding: var(--about-me-inner-padding);
    position: relative;
    z-index: 1;
}
.about-me-text-modern,
.about-me-image-modern {
    width: 100%;
    min-width: 0;
}
.about-me-text-modern {
    display: flex;
    flex-direction: column;
    justify-content: center;
    max-width: none;
    --about-me-text-padding: 40px 42px 38px;
    --about-me-text-margin-bottom: 0;
    --about-me-text-align: left;
    position: relative;
    padding: var(--about-me-text-padding);
    margin-bottom: var(--about-me-text-margin-bottom);
    letter-spacing: -0.006em;
    text-align: var(--about-me-text-align);
    background: var(--about-me-panel-bg);
    border: 1px solid var(--about-me-panel-border);
    border-radius: var(--radius-card-large);
    box-shadow: var(--about-me-panel-shadow);
    overflow: hidden;
}
.about-me-text-modern::before {
    content: '';
    display: block;
    width: 58px;
    height: 2px;
    margin-bottom: 20px;
    border-radius: 999px;
    background: rgba(88, 119, 115, 0.72);
}
.about-me-modern-title {
    --about-me-title-font-size: clamp(2.2rem, 4vw, 3rem);
    --about-me-title-line-height: 1.08;
    --about-me-title-color: #11323a;
    margin: 0 0 0.24em;
    color: var(--about-me-title-color);
    font-family: var(--font-display);
    font-size: var(--about-me-title-font-size);
    font-weight: 610;
    line-height: var(--about-me-title-line-height);
    letter-spacing: -0.018em;
    text-wrap: balance;
}
.about-me-modern-subtitle {
    --about-me-subtitle-font-size: clamp(1.02rem, 1.38vw, 1.18rem);
    --about-me-subtitle-margin-bottom: 1.5em;
    --about-me-subtitle-text-align: left;
    display: inline-flex;
    align-items: center;
    gap: 0.55em;
    padding: 0.5em 0.82em;
    border-radius: 999px;
    background: rgba(88, 119, 115, 0.08);
    border: 1px solid rgba(88, 119, 115, 0.16);
    font-family: var(--font-ui);
    font-size: var(--about-me-subtitle-font-size);
    font-weight: 650;
    color: var(--about-me-accent);
    margin-bottom: var(--about-me-subtitle-margin-bottom);
    letter-spacing: 0.05em;
    text-transform: uppercase;
    text-align: var(--about-me-subtitle-text-align);
}
.about-me-modern-bio {
    max-width: 78ch;
    margin-top: 0.4em;
}

.about-me-mobile-image {
    --about-me-mobile-image-display: none;
    --about-me-mobile-image-width: auto;
    --about-me-mobile-image-margin: 0;
    display: var(--about-me-mobile-image-display);
    width: var(--about-me-mobile-image-width);
    margin: var(--about-me-mobile-image-margin);
    overflow: hidden;
    border-radius: var(--radius-card-inner);
}

.about-me-mobile-image img {
    --about-me-mobile-image-radius: var(--radius-card-inner);
    --about-me-mobile-image-object-position: center top;
    width: 100%;
    display: block;
    border-radius: var(--about-me-mobile-image-radius);
    object-fit: cover;
    object-position: var(--about-me-mobile-image-object-position);
    box-shadow: var(--about-me-image-shadow);
}

.about-me-bio-text {
    --about-me-bio-font-size: clamp(1.04rem, 1.42vw, 1.18rem);
    --about-me-bio-line-height: 1.86;
    --about-me-bio-color: #173941;
    --about-me-bio-margin-bottom: 0.8em;
    font-family: var(--font-ui);
    font-size: var(--about-me-bio-font-size);
    line-height: var(--about-me-bio-line-height);
    color: var(--about-me-bio-color);
    font-weight: 450;
    letter-spacing: -0.01em;
    margin-bottom: var(--about-me-bio-margin-bottom);
    text-align: justify !important;
    text-justify: inter-word;
    text-wrap: pretty;
    hyphens: auto !important;
    -webkit-hyphens: auto !important;
    -ms-hyphens: auto !important;
    hyphens: auto;
    word-break: normal;
    overflow-wrap: break-word;
}
.about-me-image-modern {
    --about-me-image-display: flex;
    --about-me-image-padding: 0;
    max-width: none;
    display: var(--about-me-image-display);
    align-items: center;
    justify-content: center;
    align-self: center;
    position: relative;
    background: var(--about-me-panel-bg);
    padding: var(--about-me-image-padding);
    box-sizing: border-box;
    min-height: 0;
    border: 1px solid var(--about-me-panel-border);
    border-radius: var(--radius-card-large);
    box-shadow: var(--about-me-panel-shadow);
    overflow: hidden;
}

.about-me-image-modern::before {
    content: none;
    position: absolute;
    inset: 0;
    pointer-events: none;
}
.about-me-mobile-image img,
.about-me-image-modern img {
    width: 100%;
    display: block;
}
.about-me-mobile-image img {
    height: auto;
    object-fit: contain;
}
.about-me-image-modern img {
    --about-me-image-max-height: none;
    --about-me-image-object-position: center top;
    height: auto;
    max-width: 100%;
    max-height: min(78vh, 840px);
    object-fit: contain;
    object-position: var(--about-me-image-object-position);
    margin: 0 auto;
    background: var(--about-me-panel-bg);
    border-radius: calc(var(--radius-card-large) - 8px);
}

/* Shared responsive layout for the Astrid section */
@media (max-width: 1024px) {
    .about-me-section-modern {
        --about-me-section-padding: 28px 0;
    }

    .about-me-section-modern-inner {
        grid-template-columns: 1fr;
        --about-me-inner-width: 100%;
        --about-me-inner-max-width: 100%;
        --about-me-inner-padding: 0 16px;
        box-sizing: border-box;
    }

    .about-me-text-modern,
    .about-me-image-modern {
        box-sizing: border-box;
    }

    .about-me-modern-title {
        width: 100%;
        text-align: left !important;
        margin: 0 0 0.25em !important;
    }

    .about-me-modern-subtitle {
        width: 100%;
        --about-me-subtitle-text-align: left;
        --about-me-subtitle-margin-bottom: 1em;
        text-align: left !important;
        margin: 0 0 var(--about-me-subtitle-margin-bottom) !important;
    }

    .about-me-modern-bio {
        width: 100%;
    }

    .about-me-bio-text {
        padding-left: 0 !important;
        padding-right: 0 !important;
        --about-me-bio-margin-bottom: 0.75em;
        margin-bottom: var(--about-me-bio-margin-bottom) !important;
    }

    .about-me-image-modern {
        --about-me-image-padding: 8px;
        padding: var(--about-me-image-padding) !important;
        overflow: hidden;
        border-radius: 24px;
        background: var(--about-me-panel-bg);
        max-width: none;
        min-height: 0;
        margin: 0 auto;
    }

    .about-me-image-modern img {
        max-width: 100% !important;
        height: auto !important;
        max-height: min(62vh, 720px) !important;
        object-fit: contain;
    }
}

@media (max-width: 600px) {
    .about-me-section-modern-inner {
        grid-template-columns: 1fr;
        --about-me-inner-padding: 0 12px;
        --about-me-inner-gap: 14px;
    }

    .about-me-text-modern,
    .about-me-image-modern {
        width: 100%;
        max-width: 720px;
        margin: 0 auto;
    }

    .about-me-text-modern {
        display: flex;
        flex-direction: column;
        background: var(--about-me-panel-bg);
        --about-me-text-padding: 22px 18px 18px;
        border-radius: 18px;
        box-shadow: none;
    }

    .about-me-text-modern::before {
        width: 64px;
        height: 5px;
        margin-bottom: 16px;
    }

    .about-me-modern-title {
        font-size: 1.7em !important;
    }

    .about-me-modern-subtitle {
        --about-me-subtitle-font-size: 1em;
        font-size: var(--about-me-subtitle-font-size) !important;
        padding: 0.52em 0.78em;
    }

    .about-me-image-modern img {
        --about-me-image-max-height: 52vh;
        border-radius: 18px;
        height: auto !important;
        max-height: var(--about-me-image-max-height);
        object-fit: cover;
    }

    .about-me-bio-text {
        --about-me-bio-font-size: 1.04rem;
        font-size: var(--about-me-bio-font-size) !important;
    }

    .about-me-mobile-image {
        --about-me-mobile-image-display: block;
        --about-me-mobile-image-width: 100%;
        --about-me-mobile-image-margin: 0 0 14px;
    }

    .about-me-image-modern {
        --about-me-image-display: none;
        display: var(--about-me-image-display);
    }
}

@media (min-width: 601px) and (max-width: 900px) {
    .about-me-section-modern-inner {
        grid-template-columns: 1fr;
        align-items: start;
        --about-me-inner-gap: 12px;
    }

    .about-me-text-modern {
        width: auto;
        max-width: none;
        margin: 0;
        --about-me-text-padding: 26px 24px;
        border-radius: 24px;
        background: var(--about-me-panel-bg);
        box-shadow: none;
        --about-me-text-align: left;
    }

    .about-me-image-modern {
        width: 100%;
        max-width: 760px;
        margin: 0 auto;
        align-self: start;
        box-shadow: none;
    }

    .about-me-image-modern img {
        width: 100%;
        height: auto;
        max-height: min(62vh, 720px) !important;
        object-fit: contain;
        --about-me-image-object-position: center top;
        object-position: var(--about-me-image-object-position);
    }
}

/* Charity & Benefiz Card Layout */
.charity-card {
    --charity-card-text-color: #14353b;
    --charity-card-list-color: #16383e;
    --charity-card-surface: #fff;
    --charity-card-bg: var(--surface-card-soft);
    --charity-card-border-color: var(--border-soft);
    --charity-card-radius: var(--radius-card);
    --charity-card-margin-bottom: 28px;
    --charity-card-shadow: var(--shadow-surface);
    --charity-card-image-radius: var(--radius-card-inner);
    display: flex;
    flex-direction: row;
    align-items: stretch;
    background: var(--charity-card-bg);
    border: 1px solid var(--charity-card-border-color);
    border-radius: var(--charity-card-radius);
    margin-bottom: var(--charity-card-margin-bottom);
    padding: 0;
    overflow: hidden;
    box-shadow: var(--charity-card-shadow);
    transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
}

.charity-card:hover,
.charity-card:focus-within {
    transform: translateY(-2px);
    box-shadow: var(--shadow-surface-strong);
    border-color: var(--border-soft-strong);
}
.charity-card-text {
    --charity-card-text-padding: 28px 26px;
    flex: 1 1 0;
    padding: var(--charity-card-text-padding);
}
.charity-card-main-text {
    --charity-card-main-text-max-width: 38ch;
    --charity-card-main-text-line-height: 1.68;
    max-width: var(--charity-card-main-text-max-width);
    margin: 0;
    color: var(--charity-card-text-color);
    font-size: clamp(1.04rem, 1.08vw, 1.1rem);
    line-height: var(--charity-card-main-text-line-height);
    font-weight: 500;
    letter-spacing: 0.004em;
    text-wrap: pretty;
}
.charity-card-image {
    --charity-card-image-basis: 264px;
    --charity-card-image-padding: 22px 24px 22px 8px;
    flex: 0 0 var(--charity-card-image-basis);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--charity-card-image-padding);
}
.charity-card-image img {
    --charity-card-image-max-width: 220px;
    --charity-card-image-border-color: rgba(91, 135, 129, 0.12);
    --charity-card-image-shadow: none;
    max-width: var(--charity-card-image-max-width);
    width: 100%;
    border-radius: var(--charity-card-image-radius);
    border: 1px solid var(--charity-card-image-border-color);
    box-shadow: var(--charity-card-image-shadow);
    background: var(--charity-card-surface);
}
.charity-list-item {
    --charity-list-item-max-width: 66ch;
    --charity-list-item-line-height: 1.62;
    max-width: var(--charity-list-item-max-width);
    color: var(--charity-card-list-color) !important;
    font-size: clamp(1rem, 1.02vw, 1.06rem) !important;
    font-weight: 450 !important;
    line-height: var(--charity-list-item-line-height) !important;
    letter-spacing: 0.003em !important;
    text-wrap: pretty;
    display: block !important;
    min-width: 0;
    word-break: normal !important;
    overflow-wrap: break-word !important;
    hyphens: auto;
}
.charity-list-item + .charity-list-item {
    margin-top: 0.28em;
}
.charity-list-item::before {
    top: 0.82em;
    --interaction-transform: translateY(-50%);
    transform: translateY(-50%);
}
.charity-card-main-text,
.charity-list-item > span {
    color: var(--charity-card-text-color);
}
.charity-list-item > span {
    display: block;
    margin-bottom: 0.1em;
    font-weight: 540;
    max-width: 100%;
    white-space: normal;
    word-break: normal;
    overflow-wrap: break-word;
}

.kinshasa-card-img {
    --kinshasa-card-img-width: min(100%, 280px);
    --kinshasa-card-img-margin-top: 16px;
    --kinshasa-card-img-margin-bottom: 4px;
    --kinshasa-card-img-radius: 10px;
    --kinshasa-card-img-border-color: transparent;
    --kinshasa-card-img-shadow: none;
    --kinshasa-card-img-bg: transparent;
    --kinshasa-card-img-padding: 0;
    --kinshasa-card-img-object-position: center;
    --kinshasa-card-img-transition: border-color 0.2s ease;
    display: block;
    width: var(--kinshasa-card-img-width);
    max-width: 100%;
    aspect-ratio: 4 / 3;
    height: auto;
    margin: var(--kinshasa-card-img-margin-top) 0 var(--kinshasa-card-img-margin-bottom);
    border-radius: var(--kinshasa-card-img-radius);
    border: 1px solid var(--kinshasa-card-img-border-color);
    box-shadow: var(--kinshasa-card-img-shadow);
    background: var(--kinshasa-card-img-bg);
    padding: var(--kinshasa-card-img-padding);
    object-fit: cover;
    object-position: var(--kinshasa-card-img-object-position);
    transition: var(--kinshasa-card-img-transition);
}

.charity-list-item--project {
    padding-bottom: 4px;
}

@media (max-width: 900px) {
    .kinshasa-card-img {
        --kinshasa-card-img-width: min(100%, 260px);
        --kinshasa-card-img-margin-top: 14px;
        --kinshasa-card-img-radius: 14px;
    }
}

@media (max-width: 600px) {
    .kinshasa-card-img {
        --kinshasa-card-img-width: min(100%, 220px);
        --kinshasa-card-img-margin-top: 12px;
        --kinshasa-card-img-radius: 12px;
    }
}

@media (max-width: 900px) {
    .charity-card {
        flex-direction: column;
    }
    .charity-card-image {
        --charity-card-image-padding: 0 22px 22px;
    }
    .charity-card-image img {
        --charity-card-image-max-width: 250px;
        border-radius: 12px;
    }
    .charity-card-text {
        --charity-card-text-padding: 24px 22px 20px 22px;
    }
    .charity-card-main-text {
        --charity-card-main-text-max-width: none;
        --charity-card-main-text-line-height: 1.58;
    }
    .charity-list-item {
        --charity-list-item-max-width: none;
    }
}
@media (max-width: 600px) {
    .charity-card {
        --charity-card-radius: 22px;
    }
    .charity-card-text {
        --charity-card-text-padding: 22px 18px 18px 18px;
    }
    .charity-card-image {
        --charity-card-image-padding: 6px 18px 0 18px;
    }
    .charity-card-image img {
        --charity-card-image-max-width: 210px;
    }
    .charity-card-main-text {
        --charity-card-main-text-line-height: 1.56;
    }
    .charity-list-item {
        --charity-list-item-line-height: 1.54;
    }
}
/* Hero-Background Blur für mehr Kontrast */
.hero-bg-fade,
.hero-bg-fade-current {
    position: relative;
}
.hero-bg-fade::after,
.hero-bg-fade-current::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: transparent;
 
    z-index: 1;
    border-radius: inherit;
}

/* Mint Section Styles */
.mint-section-dark {
    --mint-section-bg: var(--section-tone-b);
    --musik-bruecken-surface: rgba(255, 255, 255, 0.92);
    --musik-bruecken-accent: #239b96;
    --musik-bruecken-heading: #20373b;
    --musik-bruecken-copy: #42595d;
    --musik-bruecken-copy-strong: #314a4f;
    --musik-bruecken-border: rgba(32, 55, 59, 0.12);
    --musik-bruecken-shadow: none;
    --mint-section-padding: 88px 0;
    background: var(--mint-section-bg);
    font-family: var(--font-ui);
    position: relative;
    overflow: hidden;
    padding: var(--mint-section-padding);
}
.mint-section-dark-flex,
.musik-bruecken-card {
    display: flex;
    justify-content: center;
    align-items: center;
}
.mint-section-dark-flex {
    --musik-bruecken-flex-min-height: 420px;
    min-height: var(--musik-bruecken-flex-min-height);
}
.musik-bruecken-card {
    --musik-bruecken-card-width: min(92vw, 940px);
    --musik-bruecken-card-radius: 30px;
    --musik-bruecken-card-min-height: 220px;
    --musik-bruecken-card-padding: 40px clamp(28px, 4vw, 46px) 42px;
    background: var(--musik-bruecken-surface);
    border: 1px solid var(--musik-bruecken-border);
    border-radius: var(--musik-bruecken-card-radius);
    box-shadow: var(--musik-bruecken-shadow);
    width: var(--musik-bruecken-card-width);
    max-width: 940px;
    margin: 0 auto;
    min-width: 0;
    min-height: var(--musik-bruecken-card-min-height);
    padding: var(--musik-bruecken-card-padding);
    flex-direction: column;
    height: auto;
    box-sizing: border-box;
}

.musik-bruecken-media {
    width: min(100%, 620px);
    margin: 0 auto 22px;
    padding: 4px;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.24);
    border: 1px solid rgba(32, 55, 59, 0.05);
    box-shadow: none;
}

.musik-bruecken-image {
    display: block;
    width: 100%;
    max-width: 100%;
    border-radius: 16px;
    box-shadow: none;
}

.musik-bruecken-kicker {
    color: #56756f;
    font-family: var(--font-ui);
    font-size: 0.84rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    text-align: center;
    margin-bottom: 12px;
}

.musik-bruecken-title {
    margin: 0 0 14px;
    color: var(--musik-bruecken-heading);
    font-family: var(--font-display);
    font-size: clamp(1.78rem, 2.9vw, 2.28rem);
    font-weight: 580;
    line-height: 1.12;
    letter-spacing: -0.012em;
    text-align: center;
    text-wrap: balance;
}

.musik-bruecken-divider {
    --musik-bruecken-divider-width: 52px;
    --musik-bruecken-divider-height: 2px;
    --musik-bruecken-divider-radius: 999px;
    --musik-bruecken-divider-margin-bottom: 24px;
    width: var(--musik-bruecken-divider-width);
    height: var(--musik-bruecken-divider-height);
    background: rgba(35, 155, 150, 0.8);
    border-radius: var(--musik-bruecken-divider-radius);
    margin-bottom: var(--musik-bruecken-divider-margin-bottom);
}

.musik-bruecken-copy-group {
    width: min(100%, 660px);
    display: grid;
    gap: 12px;
}

.musik-bruecken-text {
    --musik-bruecken-text-width: 100%;
    --musik-bruecken-text-max-width: 100%;
    --musik-bruecken-text-margin: 0;
    --musik-bruecken-text-padding: 0;
    --musik-bruecken-text-font-size: clamp(1rem, 1.45vw, 1.1rem);
    --musik-bruecken-text-line-height: 1.74;
    width: var(--musik-bruecken-text-width);
    max-width: var(--musik-bruecken-text-max-width);
    box-sizing: border-box;
    margin: var(--musik-bruecken-text-margin);
    padding: var(--musik-bruecken-text-padding);
    display: block;
    color: var(--musik-bruecken-copy);
    font-size: var(--musik-bruecken-text-font-size);
    font-weight: 430;
    text-align: center;
    line-height: var(--musik-bruecken-text-line-height);
    word-break: break-word;
    hyphens: auto;
    overflow-wrap: break-word;
}

.musik-bruecken-text--lead {
    color: var(--musik-bruecken-copy-strong);
    font-size: clamp(1.04rem, 1.55vw, 1.16rem);
    font-weight: 510;
}

@media (max-width: 900px) {
    .musik-bruecken-text {
        text-align: left !important;
        hyphens: auto !important;
        overflow-wrap: anywhere !important;
        word-break: break-word !important;
    }
}

@media (min-width: 700px) and (max-width: 900px) {
    .musik-bruecken-text {
        --musik-bruecken-text-font-size: clamp(0.85rem, 1vw, 0.98rem);
    }
}

@media (max-width: 700px) {
    .mint-section-dark {
        --mint-section-padding: 48px 0 38px;
    }
    .mint-section-dark-flex {
        --musik-bruecken-flex-min-height: 220px;
    }
    .musik-bruecken-card {
        --musik-bruecken-card-width: calc(100vw - 28px);
        --musik-bruecken-card-radius: 22px;
        --musik-bruecken-card-min-height: 180px;
        --musik-bruecken-card-padding: 24px 18px 28px;
    }
    .musik-bruecken-media {
        margin-bottom: 18px;
        padding: 3px;
        border-radius: 16px;
    }
    .musik-bruecken-image {
        border-radius: 13px;
    }
    .musik-bruecken-divider {
        --musik-bruecken-divider-width: 32px;
        --musik-bruecken-divider-height: 3px;
        --musik-bruecken-divider-margin-bottom: 14px;
    }
    .musik-bruecken-kicker {
        font-size: 0.78rem;
        margin-bottom: 8px;
    }
    .musik-bruecken-title {
        font-size: clamp(1.34rem, 5.1vw, 1.74rem);
        margin-bottom: 10px;
    }
    .musik-bruecken-copy-group {
        gap: 10px;
        justify-items: center;
    }
    .musik-bruecken-text {
        --musik-bruecken-text-width: 100%;
        --musik-bruecken-text-max-width: 98vw;
        --musik-bruecken-text-margin: 0;
        --musik-bruecken-text-padding: 0;
        --musik-bruecken-text-font-size: 1rem;
        --musik-bruecken-text-line-height: 1.62;
        text-align: center !important;
        overflow-wrap: break-word !important;
        word-break: normal !important;
    }
}

@media (max-width: 600px) {
    .musik-bruecken-card {
        --musik-bruecken-card-width: calc(100vw - 24px);
        --musik-bruecken-card-min-height: 120px;
        --musik-bruecken-card-padding: 22px 16px 24px;
    }

    .musik-bruecken-text {
        --musik-bruecken-text-width: 100%;
        --musik-bruecken-text-margin: 0;
        --musik-bruecken-text-padding: 0;
        --musik-bruecken-text-font-size: 1.02rem;
        --musik-bruecken-text-max-width: 100%;
    }
}
.musikalisches-repertoire-section {
    --repertoire-bg: var(--section-tone-a);
    --repertoire-surface: rgba(255, 255, 255, 0.78);
    --repertoire-title-color: #17363c;
    --repertoire-accent: #259c98;
    --repertoire-copy-color: #24434a;
    --repertoire-copy-soft: #587075;
    --repertoire-bullet-color: #1cbdb2;
    --repertoire-bullet-shadow: none;
    --repertoire-section-min-height: auto;
    --repertoire-section-padding: 76px 0 82px;
    font-family: var(--font-ui);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    background: var(--repertoire-bg);
    border-top: 1px solid rgba(23, 54, 60, 0.16);
    min-height: var(--repertoire-section-min-height);
    padding: var(--repertoire-section-padding);
    display: flex;
    justify-content: center;
    align-items: flex-start;
    box-sizing: border-box;
    overflow-x: clip;
}

.musikalisches-repertoire-cards-wrapper {
    --repertoire-cards-gap: 30px;
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--repertoire-cards-gap);
    align-items: start;
    width: 100%;
    max-width: 1120px;
    margin: 0 auto;
    padding: 0 22px;
    min-width: 0;
    box-sizing: border-box;
}

.musikalisches-repertoire-card {
    --repertoire-card-radius: var(--radius-card);
    --repertoire-card-width: 100%;
    --repertoire-card-padding: 34px 34px 32px;
    --repertoire-card-font-size: clamp(1rem, 2vw, 1.13rem);
    background: var(--repertoire-surface);
    border: 1px solid var(--border-soft);
    border-radius: var(--repertoire-card-radius);
    max-width: none;
    width: var(--repertoire-card-width);
    margin: 0 auto;
    padding: var(--repertoire-card-padding);
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    box-sizing: border-box;
    font-size: var(--repertoire-card-font-size);
    line-height: 1.7;
    align-self: start;
    min-width: 0;
}

.musikalisches-repertoire-card--repertoire {
    background: rgba(244, 252, 251, 0.82);
    border-color: rgba(23, 54, 60, 0.12);
    box-shadow: none;
}

.musikalisches-repertoire-card--engagement {
    background: rgba(238, 249, 248, 0.82);
    border-color: rgba(91, 135, 129, 0.12);
    --repertoire-bullet-color: #25a8a0;
    --repertoire-bullet-shadow: 0 0 0 4px rgba(37, 168, 160, 0.14);
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
    column-gap: 34px;
    row-gap: 18px;
    align-items: start;
}

.musikalisches-repertoire-card-header {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
}

.musikalisches-repertoire-title {
    --repertoire-title-font-size: clamp(1.7rem, 2.1vw, 2.15rem);
    --repertoire-title-margin-bottom: 10px;
    --repertoire-title-line-height: 1.1;
    color: var(--repertoire-title-color);
    font-size: var(--repertoire-title-font-size);
    margin-bottom: var(--repertoire-title-margin-bottom);
    font-family: var(--font-display);
    font-weight: 620;
    line-height: var(--repertoire-title-line-height);
    letter-spacing: -0.018em;
    text-wrap: balance;
}

.musikalisches-repertoire-divider {
    --repertoire-divider-width: 56px;
    --repertoire-divider-height: 2px;
    --repertoire-divider-radius: 999px;
    --repertoire-divider-margin-bottom: 20px;
    width: var(--repertoire-divider-width);
    height: var(--repertoire-divider-height);
    background: var(--repertoire-accent);
    border-radius: var(--repertoire-divider-radius);
    margin-bottom: var(--repertoire-divider-margin-bottom);
}

.musikalisches-repertoire-intro {
    margin: 0 0 22px;
    max-width: 54ch;
    color: var(--repertoire-copy-soft);
    font-size: clamp(1rem, 1.1vw, 1.08rem);
    line-height: 1.7;
    font-weight: 450;
    text-align: justify !important;
    text-justify: auto !important;
    text-wrap: pretty !important;
    hyphens: auto !important;
    -webkit-hyphens: auto !important;
    -ms-hyphens: auto !important;
    word-break: normal !important;
    overflow-wrap: break-word !important;
}

.musikalisches-repertoire-card--repertoire .musikalisches-repertoire-intro {
    max-width: 50ch;
}

.musikalisches-repertoire-list {
    --repertoire-list-margin: 0;
    --repertoire-list-font-size: clamp(0.98rem, 1vw, 1.06rem);
    --repertoire-list-max-width: 100%;
    margin: var(--repertoire-list-margin);
    padding-left: 0;
    color: var(--repertoire-copy-color);
    font-size: var(--repertoire-list-font-size);
    line-height: 1.64;
    font-weight: 450;
    letter-spacing: 0.003em;
    list-style: none;
    max-width: var(--repertoire-list-max-width);
    display: grid;
    gap: 14px;
    min-width: 0;
}

.musikalisches-repertoire-card--repertoire .musikalisches-repertoire-list {
    --repertoire-list-max-width: 58ch;
    gap: 12px;
}

.musikalisches-repertoire-list li {
    position: relative;
    list-style: none;
    padding-left: 30px;
    margin: 0;
    font-size: inherit;
    line-height: 1.6;
    word-break: normal !important;
    overflow-wrap: break-word !important;
    hyphens: auto !important;
    text-align: justify !important;
    text-justify: auto !important;
    text-wrap: pretty !important;
    -webkit-hyphens: auto !important;
    -ms-hyphens: auto !important;
}

.musikalisches-repertoire-list li:last-child {
    margin-bottom: 0;
}

.musikalisches-repertoire-list li.charity-list-item {
    display: block !important;
    align-items: flex-start !important;
    min-width: 0;
}

.musikalisches-repertoire-list li.ensemble-inline-list {
    padding-left: 34px;
}

.musikalisches-repertoire-list li.ensemble-inline-list,
.musikalisches-repertoire-list li.ensemble-inline-list span,
.musikalisches-repertoire-list .ensemble-inline-list__label,
.musikalisches-repertoire-list .ensemble-chip-list,
.musikalisches-repertoire-list .ensemble-chip {
    max-width: 100%;
    min-width: 0;
}

.musikalisches-repertoire-list li.ensemble-inline-list {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    align-items: start;
}

.ensemble-inline-list__label {
    display: block;
    margin-bottom: 12px;
    color: var(--repertoire-title-color);
    font-weight: 560;
}

.musikalisches-repertoire-list .ensemble-inline-list__label {
    white-space: normal;
}

.ensemble-chip-list {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    width: 100%;
    max-width: 100%;
}

.ensemble-chip {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    justify-content: center;
    padding: 6px 11px;
    border-radius: 999px;
    background: rgba(37, 156, 152, 0.08);
    border: 1px solid rgba(37, 156, 152, 0.14);
    color: var(--repertoire-copy-color);
    font-size: 0.92em;
    line-height: 1.35;
    max-width: 100%;
}

.musikalisches-repertoire-card--repertoire .ensemble-chip {
    background: rgba(255, 255, 255, 0.72);
    border-color: rgba(91, 135, 129, 0.12);
}

.musikalisches-repertoire-list li.charity-list-item > span {
    display: block;
    max-width: 100%;
}

.musikalisches-repertoire-list li.charity-list-item .kinshasa-card-img {
    display: block;
    margin-top: 16px;
}

.musikalisches-repertoire-list li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.74em;
    --interaction-transform: translateY(-50%);
    transform: translateY(-50%);
    width: 10px;
    height: 10px;
    border-radius: 999px;
    background: var(--repertoire-bullet-color);
    box-shadow: var(--repertoire-bullet-shadow);
}

.musikalisches-repertoire-card--engagement .musikalisches-repertoire-list {
    margin-top: 6px;
}

.musikalisches-repertoire-card--engagement .musikalisches-repertoire-card-header {
    grid-column: 1 / -1;
    margin-bottom: 4px;
}

.musikalisches-repertoire-card--engagement .charity-card {
    grid-column: 1;
    display: grid;
    grid-template-columns: 1fr;
    align-items: stretch;
    background: transparent;
    border-color: transparent;
    border-radius: 0;
    box-shadow: none;
    margin-bottom: 0;
    min-width: 0;
}

.musikalisches-repertoire-card--engagement .charity-card-image {
    order: -1;
    padding: 0;
    min-height: auto;
}

.musikalisches-repertoire-card--engagement .charity-card-image img {
    max-width: min(100%, 360px);
    width: min(100%, 360px);
    height: auto;
    max-height: clamp(280px, 31vw, 420px);
    min-height: auto;
    border: 0;
    border-radius: 0;
    box-shadow: none;
    background: transparent;
    object-fit: contain;
    object-position: center center;
}

.musikalisches-repertoire-card--engagement .musikalisches-repertoire-list li::before {
    width: 10px;
    height: 10px;
    top: 0.84em;
    box-shadow: var(--repertoire-bullet-shadow);
}

.musikalisches-repertoire-card--engagement .charity-card-text {
    display: flex;
    align-items: center;
    padding: 24px 28px 28px;
}

.musikalisches-repertoire-card--engagement .charity-card-main-text {
    max-width: 42ch;
}

.musikalisches-repertoire-card--engagement > .musikalisches-repertoire-list {
    grid-column: 2;
    align-self: start;
    margin-top: 0;
    max-width: none;
    min-width: 0;
}

.musikalisches-repertoire-card--engagement .charity-list-item--project {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(200px, 240px);
    gap: 20px;
    align-items: start;
}

.musikalisches-repertoire-card--engagement .charity-list-item--project > span {
    margin-bottom: 0;
}

.musikalisches-repertoire-card--engagement .charity-list-item--project .kinshasa-card-img {
    width: 100%;
    max-width: none;
    margin: 0;
}

@media (max-width: 1180px) {
    .musikalisches-repertoire-cards-wrapper {
        --repertoire-cards-gap: 24px;
        align-items: center;
        max-width: 960px;
    }

    .musikalisches-repertoire-card {
        width: 100%;
        max-width: 100%;
    }

    .musikalisches-repertoire-card--repertoire .musikalisches-repertoire-list {
        --repertoire-list-max-width: 100%;
    }
}

@media (max-width: 980px) {
    .musikalisches-repertoire-card--engagement {
        grid-template-columns: 1fr;
        row-gap: 22px;
    }

    .musikalisches-repertoire-card--engagement > .musikalisches-repertoire-list {
        grid-column: 1;
    }
}

@media (max-width: 700px) {
    .musikalisches-repertoire-section {
        --repertoire-section-min-height: auto;
        --repertoire-section-padding: 34px 0 38px;
        align-items: flex-start;
        overflow-y: visible;
    }

    .musikalisches-repertoire-card {
        --repertoire-card-padding: 16px 14px 14px;
        --repertoire-card-radius: 20px;
        --repertoire-card-font-size: 1.08rem;
        align-items: stretch;
        border-color: transparent;
    }

    .musikalisches-repertoire-cards-wrapper {
        padding: 0 8px;
    }

    .musikalisches-repertoire-title {
        --repertoire-title-font-size: clamp(1.58rem, 5.6vw, 1.86rem);
        --repertoire-title-margin-bottom: 8px;
        --repertoire-title-line-height: 1.12;
    }

    .musikalisches-repertoire-divider {
        --repertoire-divider-width: 32px;
        --repertoire-divider-height: 3px;
        white-space: normal !important;
        word-break: break-word !important;
        overflow-wrap: anywhere !important;
        hyphens: auto !important;
    }

    .musikalisches-repertoire-list {
        --repertoire-list-font-size: clamp(1.02rem, 3.45vw, 1.08rem);
        --repertoire-list-max-width: 100%;
        width: 100%;
        gap: 8px;
    }

    .musikalisches-repertoire-list li {
        width: 100%;
        max-width: 100%;
        padding-left: 20px;
        line-height: 1.5;
    }

    .musikalisches-repertoire-intro {
        margin-bottom: 12px;
        font-size: 1.04rem;
        line-height: 1.56;
    }

    .ensemble-chip-list {
        display: flex !important;
        flex-wrap: wrap !important;
        gap: 6px;
        width: 100%;
        max-width: 100%;
        min-width: 0;
        white-space: normal !important;
    }

    .ensemble-chip {
        display: inline-flex;
        min-height: 0;
        padding: 5px 8px;
        font-size: 0.8em;
        line-height: 1.18;
        white-space: normal;
        text-align: center;
    }

    .ensemble-inline-list {
        display: block !important;
        width: 100%;
        max-width: 100%;
    }

    .musikalisches-repertoire-list li.ensemble-inline-list {
        display: grid !important;
        grid-template-columns: minmax(0, 1fr);
        gap: 8px;
        width: 100%;
        max-width: 100%;
        box-sizing: border-box;
    }

    .musikalisches-repertoire-list li.ensemble-inline-list span,
    .musikalisches-repertoire-list .ensemble-inline-list__label,
    .musikalisches-repertoire-list .ensemble-chip-list {
        width: 100%;
        max-width: 100%;
        white-space: normal !important;
        box-sizing: border-box;
    }

    .musikalisches-repertoire-card--engagement .charity-card-text {
        padding: 8px 4px 10px;
    }

    .musikalisches-repertoire-card--engagement .charity-card-main-text {
        font-size: clamp(1.13rem, 4.4vw, 1.24rem);
        line-height: 1.58;
        max-width: none;
    }

    .musikalisches-repertoire-card--engagement .charity-card-image {
        padding: 0 4px 2px;
    }

    .musikalisches-repertoire-card--engagement .charity-card-image img {
        width: min(100%, 300px);
        max-width: min(100%, 300px);
    }

    .musikalisches-repertoire-card--engagement {
        row-gap: 14px;
    }

    .musikalisches-repertoire-card--engagement .musikalisches-repertoire-card-header {
        margin-bottom: 0;
    }

    .musikalisches-repertoire-card--engagement > .musikalisches-repertoire-list {
        margin-top: 0;
    }

    .musikalisches-repertoire-card--engagement .charity-list-item {
        font-size: clamp(1.03rem, 3.5vw, 1.1rem) !important;
        line-height: 1.5 !important;
    }

    .musikalisches-repertoire-card--engagement .charity-list-item--project {
        gap: 10px;
    }

    .musikalisches-repertoire-card--engagement .charity-list-item--project .kinshasa-card-img {
        width: min(100%, 250px);
        max-width: min(100%, 250px);
        justify-self: center;
    }
}

@media (max-width: 900px) {
    .musikalisches-repertoire-cards-wrapper {
        grid-template-columns: 1fr;
        --repertoire-cards-gap: 24px;
        align-items: center;
        padding: 0 12px;
    }

    .musikalisches-repertoire-card {
        width: 100%;
        max-width: 100%;
        min-width: 0;
    }

    .musikalisches-repertoire-card--engagement .charity-card {
        grid-template-columns: 1fr;
    }

    .musikalisches-repertoire-card--engagement .charity-card-image {
        order: 0;
        min-height: auto;
        display: flex;
        justify-content: center;
        padding: 0 22px 4px;
    }

    .musikalisches-repertoire-card--engagement .charity-card-image img {
        min-height: auto;
        height: auto;
        width: min(100%, 300px);
        max-width: min(100%, 300px);
        border-radius: 0;
    }

    .musikalisches-repertoire-card--engagement .charity-card-text {
        padding: 12px 14px 14px;
    }

    .musikalisches-repertoire-card--engagement .charity-card-main-text {
        max-width: none;
        font-size: clamp(1.08rem, 2.5vw, 1.16rem);
        line-height: 1.6;
    }

    .musikalisches-repertoire-card--engagement .charity-list-item--project {
        grid-template-columns: 1fr;
        gap: 12px;
    }

    .musikalisches-repertoire-card--engagement > .musikalisches-repertoire-list {
        grid-column: 1;
    }
}

/* Charity Card: Bild rechts, Text links (nur Desktop) */
.charity-flex-row {
    --charity-review-surface: #fff;
    --charity-review-image-radius: 28px;
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    gap: clamp(24px, 3vw, 44px);
    width: 100%;
    min-height: 340px;
}
.charity-flex-left,
.charity-flex-right,
.charity-flex-row > .gruppenbild-container {
    flex-direction: column;
    justify-content: flex-start;
    padding: 0;
}
.charity-flex-left {
    flex: 1 1 0;
    max-width: none;
    min-width: 0;
    display: flex;
}
.charity-flex-right,
.charity-flex-row > .gruppenbild-container {
    flex: 0 1 42%;
    max-width: clamp(320px, 42vw, 640px);
    min-width: 280px;
    width: auto !important;
    margin: 0 !important;
    display: flex !important;
    align-items: stretch;
    align-self: flex-start;
    box-sizing: border-box;
    gap: 8px;
}
.charity-flex-row > .gruppenbild-container img,
.charity-flex-right img {
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    max-height: none !important;
    object-fit: contain;
    border-radius: var(--charity-review-image-radius) !important;
    display: block;
    margin: 0 auto;
    background: var(--charity-review-surface);
}
.charity-flex-row > .gruppenbild-container > div {
    width: 100%;
    max-width: 100% !important;
    margin: 8px auto 0 !important;
    text-align: center !important;
    box-sizing: border-box;
}

.review-media-block {
    --review-media-narrow-width: 70%;
    --review-media-surface: #fff;
    --review-media-caption-color: #222;
    --review-media-frame-bg: rgba(255, 255, 255, 0.94);
    --review-media-frame-border: rgba(18, 62, 70, 0.08);
    --review-media-frame-shadow: none;
    --review-media-frame-padding: clamp(10px, 1.3vw, 14px);
    --review-media-frame-radius: 28px;
    width: 100% !important;
}

.charity-flex-row > .gruppenbild-container.review-media-block--top-28,
.charity-flex-row > .gruppenbild-container.review-media-block--top-88,
.charity-flex-row > .gruppenbild-container.review-media-block--top-128 {
    margin: calc(var(--review-media-margin-top) + var(--review-media-desktop-offset, 0px)) auto 0 !important;
}

.review-media-block--top-28 {
    --review-media-margin-top: 28px;
}

.review-media-block--top-88 {
    --review-media-margin-top: 88px;
}

.review-media-block--top-128 {
    --review-media-margin-top: 128px;
}

.review-media-caption {
    margin: 8px auto 18px !important;
    color: #48636d;
    font-family: var(--font-ui-modern);
    font-size: 0.92rem !important;
    font-weight: 600;
    letter-spacing: 0.02em;
    text-align: center !important;
    font-style: italic;
}

.charity-projects-section[id^="review-"] .review-media-caption {
    width: fit-content;
    max-width: 100% !important;
    margin: 2px auto 0 !important;
    padding: 0.46em 0.92em;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.68);
    border: 1px solid rgba(79, 141, 135, 0.14);
}

.review-media-caption--narrow {
    max-width: var(--review-media-narrow-width) !important;
}

.review-media-image-card {
    height: auto !important;
    display: block;
    background: var(--review-media-surface, #fff);
    box-shadow: 0 4px 18px rgba(0,0,0,0.12);
}

.charity-projects-section[id^="review-"] .review-media-image-card,
.charity-projects-section[id^="review-"] .charity-flex-row > .gruppenbild-container img,
.charity-projects-section[id^="review-"] .charity-flex-right img {
    box-shadow: none !important;
    background: transparent !important;
}

.review-media-image-card--narrow {
    max-width: var(--review-media-narrow-width) !important;
}

.charity-projects-section[id^="review-"] .charity-flex-row > .gruppenbild-container {
    padding: var(--review-media-frame-padding);
    background: var(--review-media-frame-bg);
    border: 1px solid var(--review-media-frame-border);
    border-radius: var(--review-media-frame-radius);
    box-shadow: var(--review-media-frame-shadow);
}

.event-social-actions.review-social-actions {
    justify-content: flex-start;
    align-self: flex-start;
    width: 100%;
    margin-top: 8px;
    margin-bottom: 18px;
}
/* Charity Projects Section (Material Design) */
.charity-projects-section {
    --charity-projects-bg: #f6edde;
    --charity-projects-surface: rgba(255, 250, 241, 0.95);
    --charity-title-color: #11323a;
    --charity-meta-color: #208b91;
    --charity-copy-color: #173941;
    --charity-card-border: rgba(18, 62, 70, 0.12);
    --charity-card-shadow: var(--shadow-surface-strong);
    --charity-card-topline: #35c4c7;
    background: var(--charity-projects-bg);
    padding: 40px 0 32px;
    width: 100vw;
    display: flex;
    justify-content: center;
    margin-bottom: 0;
}

.charity-projects-section[id^="review-"] {
    --charity-projects-bg: var(--section-tone-b);
    --charity-projects-surface: rgba(255, 255, 255, 0.92);
    --charity-card-shadow: var(--shadow-surface);
    --charity-card-topline: rgba(53, 196, 199, 0.78);
    --review-title-size: clamp(2rem, 3.2vw, 2.45rem);
    --review-meta-bg: rgba(249, 243, 233, 0.94);
    --review-meta-border: rgba(53, 196, 199, 0.22);
}

#review-masterclass-florian-meierott {
    padding-top: 16px;
}

.charity-projects-container {
    max-width: 2800px;
    width: 85vw;
    margin: 0 auto 18px;
    background: var(--charity-projects-surface);
    border-radius: var(--radius-card-large);
    box-shadow: var(--charity-card-shadow);
    border: 1px solid var(--border-soft);
    padding: 38px 28px 30px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    position: relative;
    overflow: hidden;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

.charity-projects-section[id^="review-"] .charity-projects-container {
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
}

.charity-projects-container::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 5px;
    background: var(--charity-card-topline);
    pointer-events: none;
}

.charity-projects-section[id^="review-"] .charity-projects-container::before {
    height: 2px;
}

.charity-title,
.charity-meta,
.charity-description {
    font-family: var(--font-ui-modern);
}
.charity-title {
    font-family: var(--font-display);
    font-weight: 700;
    color: var(--charity-title-color);
    font-size: clamp(2.2rem, 4.2vw, 2.9rem);
    line-height: 1.02;
    margin-bottom: 18px;
    letter-spacing: -0.035em;
    text-align: left;
    text-wrap: balance;
}

.charity-projects-section[id^="review-"] .charity-title {
    font-size: var(--review-title-size);
    font-weight: 600;
    line-height: 1.1;
    letter-spacing: -0.018em;
}

.charity-meta {
    color: var(--charity-meta-color);
    font-size: clamp(0.96rem, 0.78rem + 0.45vw, 1.08rem);
    font-weight: 800;
    margin-bottom: 18px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    text-align: left;
    display: inline-flex;
    align-items: center;
    gap: 0.5em;
    padding: 0.56em 0.9em;
    border-radius: 999px;
    background: rgba(13, 136, 126, 0.08);
    border: 1px solid rgba(13, 136, 126, 0.16);
}

.charity-projects-section[id^="review-"] .charity-meta {
    display: inline-block;
    width: fit-content;
    max-width: min(100%, 42rem);
    padding: 0;
    line-height: 1.45;
    letter-spacing: 0.015em;
    text-transform: none;
    border-radius: 0;
    background: transparent;
    border-color: transparent;
    box-shadow: none;
}

.charity-projects-section[id^="review-"] .charity-title--compact {
    margin-bottom: 0.28em;
}

.charity-projects-section[id^="review-"] .event-social-actions.review-social-actions {
    gap: 12px;
    margin-top: 6px;
    margin-bottom: 16px;
}

.charity-projects-section[id^="review-"] .event-social-actions.review-social-actions .event-social-button {
    width: 44px;
    height: 44px;
}
@media (max-width: 600px) {
    .charity-meta {
        font-size: 0.9rem;
        line-height: 1.35;
        letter-spacing: 0.035em;
        padding: 0.5em 0.78em;
        border-radius: 18px;
        max-width: 100%;
        white-space: normal;
        text-wrap: pretty;
        text-align: left;
    }
}
.charity-description {
    color: var(--charity-copy-color);
    font-size: clamp(1.03rem, 1.02vw + 0.3rem, 1.16rem);
    line-height: 1.82;
    font-weight: 520;
    word-break: break-word;
    hyphens: auto !important;
    -webkit-hyphens: auto !important;
    -ms-hyphens: auto !important;
    overflow-wrap: anywhere;
    margin-bottom: 18px;
    letter-spacing: -0.01em;
    text-align: left !important;
    text-wrap: pretty;
}

@media (min-width: 1301px) {
    .charity-description {
        font-size: 1.14rem;
    }
}

@media (max-width: 1300px) {
    .charity-title {
        font-size: 1.5em !important;
    }

    .charity-projects-section[id^="review-"] .charity-title {
        font-size: clamp(1.72rem, 3vw, 2rem) !important;
    }

    .charity-meta,
    .charity-description,
    .charity-card-main-text {
        font-size: 0.98em !important;
    }
}
@media (max-width: 1200px) {
    .charity-title {
        margin-bottom: 14px;
    }

    .charity-projects-section[id^="review-"] .charity-title {
        margin-bottom: 12px;
    }
}
@media (max-width: 600px) {
    .charity-title {
        margin-bottom: 10px;
    }

    .charity-projects-section[id^="review-"] .charity-title {
        font-size: clamp(1.48rem, 5.2vw, 1.82rem) !important;
        line-height: 1.16;
        letter-spacing: -0.01em;
        margin-bottom: 10px;
    }
}

.charity-title--compact {
    margin-bottom: 0.2em;
}

.charity-title--flush-top {
    margin-top: 0;
}

.charity-description--left {
    text-align: left !important;
}

/* Refined Timeline Section Design */
.timeline-section {
    --timeline-section-padding: 88px 0;
    --timeline-section-bg: var(--section-tone-b);
    --timeline-title-color: #0f3640;
    --timeline-intro-color: #425c61;
    --timeline-copy-color: #263f45;
    --timeline-intro-max-width: 62ch;
    --timeline-orb-top-size: 420px;
    --timeline-orb-top-offset-block-start: -180px;
    --timeline-orb-top-offset-inline-end: -140px;
    --timeline-orb-bottom-size: 360px;
    --timeline-orb-bottom-offset-block-end: -180px;
    --timeline-orb-bottom-offset-inline-start: -120px;
    --timeline-container-width: min(92vw, 980px);
    --timeline-container-max-width: 980px;
    --timeline-container-padding: 44px 34px 38px;
    --timeline-container-radius: 36px;
    --timeline-container-surface: rgba(255, 255, 255, 0.94);
    --timeline-container-shadow: var(--shadow-surface);
    --timeline-container-blur: 0px;
    --timeline-border-color: rgba(18, 62, 70, 0.10);
    --timeline-accent: #5b8781;
    --timeline-section-orb-top-bg: none;
    --timeline-section-orb-bottom-bg: none;
    --timeline-header-max-width: 760px;
    --timeline-header-margin-bottom: 34px;
    --timeline-header-accent-width: 62px;
    --timeline-header-accent-height: 2px;
    --timeline-header-accent-margin-top: 22px;
    --timeline-header-accent-bg: rgba(91, 135, 129, 0.75);
    --timeline-eyebrow-bg: rgba(91, 135, 129, 0.08);
    --timeline-eyebrow-border-color: rgba(91, 135, 129, 0.16);
    --timeline-eyebrow-color: #35545a;
    --timeline-eyebrow-padding: 8px 14px;
    --timeline-eyebrow-margin-bottom: 14px;
    --timeline-eyebrow-font-size: 0.88rem;
    --timeline-eyebrow-letter-spacing: 0.08em;
    --timeline-title-font-size: clamp(2.05rem, 3.7vw, 2.7rem);
    --timeline-title-margin: 0 0 14px;
    --timeline-intro-font-size: 1.03rem;
    --timeline-intro-line-height: 1.75;
    --timeline-list-gap: 22px;
    --timeline-bar-left: 50px;
    --timeline-bar-width: 2px;
    --timeline-bar-bg: rgba(91, 135, 129, 0.28);
    --timeline-item-gap: 26px;
    --timeline-item-padding: 24px 26px;
    --timeline-item-radius: 24px;
    --timeline-item-shadow: 0 10px 26px rgba(25, 48, 55, 0.05);
    --timeline-item-before-bg: rgba(91, 135, 129, 0.55);
    --timeline-item-surface: #ffffff;
    --timeline-item-surface-alt: #ffffff;
    --timeline-item-overlay-bg: transparent;
    --timeline-item-border-color-hover: rgba(18, 62, 70, 0.10);
    --timeline-item-hover-translate-y: 0px;
    --timeline-item-before-top: 18px;
    --timeline-item-before-bottom: 18px;
    --timeline-item-before-width: 2px;
    --timeline-year-flex-basis: 96px;
    --timeline-year-width: 96px;
    --timeline-year-height: 60px;
    --timeline-year-min-width: 96px;
    --timeline-year-min-height: 60px;
    --timeline-year-radius: 18px;
    --timeline-year-padding: 0 16px;
    --timeline-year-font-size: 1.02em;
    --timeline-year-justify: center;
    --timeline-year-gap: 10px;
    --timeline-year-shadow: none;
    --timeline-year-bg: #f4f7f5;
    --timeline-year-border-color: rgba(91, 135, 129, 0.18);
    --timeline-year-color: #244148;
    --timeline-dot-size: 13px;
    --timeline-dot-border-width: 3px;
    --timeline-dot-bg: #ffffff;
    --timeline-dot-border-color: rgba(91, 135, 129, 0.42);
    --timeline-dot-ring-shadow: none;
    --timeline-link-color: #244148;
    --timeline-link-color-hover: #162d34;
    --timeline-link-bg: transparent;
    --timeline-link-bg-hover: transparent;
    --timeline-link-padding: 0;
    --timeline-link-radius: 0;
    --timeline-link-transition: color 0.2s ease, text-decoration-color 0.2s ease;
    --timeline-highlight-link-color: #244148;
    --timeline-highlight-link-color-hover: #162d34;
    --timeline-highlight-link-font-size: 0.98em;
    --timeline-highlight-link-bg: transparent;
    --timeline-highlight-link-bg-hover: transparent;
    --timeline-highlight-link-radius: 0;
    --timeline-highlight-link-padding: 0;
    --timeline-highlight-link-margin: 0;
    --timeline-highlight-link-decoration-color: rgba(36, 65, 72, 0.42);
    --timeline-highlight-link-decoration-color-hover: rgba(22, 45, 52, 0.56);
    --timeline-highlight-link-decoration-thickness: 0.08em;
    --timeline-highlight-link-underline-offset: 0.14em;
    --timeline-item-title-font-size: 1.12em;
    --timeline-item-title-max-width: 38ch;
    --timeline-item-title-margin: 2px 0 0;
    --timeline-item-text-font-size: 1em;
    --timeline-item-text-line-height: 1.75;
    --timeline-item-text-max-width: 64ch;
    --timeline-content-gap: 8px;
    background: var(--timeline-section-bg) !important;
    padding: var(--timeline-section-padding) !important;
    width: 100% !important;
    display: flex;
    justify-content: center;
    box-sizing: border-box;
    position: relative;
    overflow: hidden;
}

.timeline-section::before,
.timeline-section::after {
    content: "";
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    z-index: 0;
    filter: blur(4px);
}

.timeline-section::before {
    width: var(--timeline-orb-top-size);
    height: var(--timeline-orb-top-size);
    top: var(--timeline-orb-top-offset-block-start);
    right: var(--timeline-orb-top-offset-inline-end);
    background: var(--timeline-section-orb-top-bg);
}

.timeline-section::after {
    width: var(--timeline-orb-bottom-size);
    height: var(--timeline-orb-bottom-size);
    bottom: var(--timeline-orb-bottom-offset-block-end);
    left: var(--timeline-orb-bottom-offset-inline-start);
    background: var(--timeline-section-orb-bottom-bg);
}

.timeline-container {
    position: relative;
    z-index: 1;
    max-width: var(--timeline-container-max-width);
    width: var(--timeline-container-width);
    margin: 0 auto;
    background: var(--timeline-container-surface);
    border: 1px solid var(--timeline-border-color);
    border-radius: var(--timeline-container-radius);
    box-shadow: var(--timeline-container-shadow);
    backdrop-filter: blur(var(--timeline-container-blur));
    -webkit-backdrop-filter: blur(var(--timeline-container-blur));
    padding: var(--timeline-container-padding);
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

.timeline-header {
    max-width: var(--timeline-header-max-width);
    margin-bottom: var(--timeline-header-margin-bottom);
    position: relative;
}

.timeline-header::after {
    content: "";
    display: block;
    width: var(--timeline-header-accent-width);
    height: var(--timeline-header-accent-height);
    margin-top: var(--timeline-header-accent-margin-top);
    border-radius: 999px;
    background: var(--timeline-header-accent-bg);
}

.timeline-eyebrow {
    display: inline-flex;
    align-items: center;
    padding: var(--timeline-eyebrow-padding);
    margin-bottom: var(--timeline-eyebrow-margin-bottom);
    border-radius: 999px;
    background: var(--timeline-eyebrow-bg);
    border: 1px solid var(--timeline-eyebrow-border-color);
    color: var(--timeline-eyebrow-color);
    font-size: var(--timeline-eyebrow-font-size);
    font-family: var(--font-ui);
    font-weight: 650;
    letter-spacing: var(--timeline-eyebrow-letter-spacing);
    text-transform: uppercase;
    box-shadow: none;
}

.timeline-title,
.timeline-item-title {
    font-family: var(--font-display) !important;
}

.timeline-intro,
.timeline-item-text {
    font-family: var(--font-ui-modern) !important;
}

.timeline-title,
.timeline-item-title {
    color: var(--timeline-title-color) !important;
}

.timeline-title {
    font-weight: 620 !important;
    font-size: var(--timeline-title-font-size) !important;
    line-height: 1.08 !important;
    letter-spacing: -0.018em !important;
    margin: var(--timeline-title-margin) !important;
    text-align: left !important;
    text-shadow: none;
    text-wrap: balance;
}

.timeline-intro {
    max-width: var(--timeline-intro-max-width);
    margin: 0;
    color: var(--timeline-intro-color);
    font-size: var(--timeline-intro-font-size);
    line-height: var(--timeline-intro-line-height);
    font-weight: 470;
    text-align: justify;
    text-justify: inter-word;
    text-wrap: pretty;
    hyphens: auto;
    overflow-wrap: break-word;
}

.timeline-list {
    display: flex;
    flex-direction: column;
    width: 100%;
    gap: var(--timeline-list-gap);
}

.timeline-list.timeline-has-bar {
    position: relative;
}

.timeline-bar {
    position: absolute;
    top: 0;
    bottom: 0;
    left: var(--timeline-bar-left);
    width: var(--timeline-bar-width);
    background: var(--timeline-bar-bg);
    border-radius: 999px;
    opacity: 0.75;
    z-index: 0;
}

.timeline-item {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    gap: var(--timeline-item-gap);
    padding: var(--timeline-item-padding);
    position: relative;
    z-index: 1;
    overflow: hidden;
    border-radius: var(--timeline-item-radius);
    background: var(--timeline-item-surface);
    border: 1px solid var(--timeline-border-color);
    box-shadow: var(--timeline-item-shadow);
    transition: border-color 0.2s ease;
}

.timeline-item:hover,
.timeline-item:focus-within {
    transform: none;
    border-color: var(--timeline-item-border-color-hover);
    box-shadow: var(--shadow-surface);
}

.timeline-item::before {
    content: "";
    position: absolute;
    left: 0;
    top: var(--timeline-item-before-top);
    bottom: var(--timeline-item-before-bottom);
    width: var(--timeline-item-before-width);
    border-radius: 999px;
    background: var(--timeline-item-before-bg);
    opacity: 0.9;
}

.timeline-item::after {
    content: "";
    position: absolute;
    inset: 0;
    background: var(--timeline-item-overlay-bg);
    pointer-events: none;
}

.timeline-list > .timeline-item:nth-child(odd) {
    background: var(--timeline-item-surface-alt);
}

.timeline-year {
    flex: 0 0 var(--timeline-year-flex-basis);
    position: relative;
    display: flex;
    align-items: center;
    width: var(--timeline-year-width);
    height: var(--timeline-year-height);
    min-width: var(--timeline-year-min-width) !important;
    min-height: var(--timeline-year-min-height) !important;
    margin-right: 0 !important;
    border-radius: var(--timeline-year-radius) !important;
    padding: var(--timeline-year-padding) !important;
    background: var(--timeline-year-bg) !important;
    box-shadow: var(--timeline-year-shadow) !important;
    border: 1px solid var(--timeline-year-border-color) !important;
    color: var(--timeline-year-color) !important;
    font-size: var(--timeline-year-font-size) !important;
    font-weight: 700 !important;
    font-family: var(--font-ui);
    letter-spacing: 0.01em;
    line-height: 1;
    white-space: nowrap;
    flex-wrap: nowrap;
    gap: var(--timeline-year-gap);
    font-variant-numeric: tabular-nums;
    z-index: 2;
    justify-content: var(--timeline-year-justify) !important;
}

.timeline-dot {
    display: inline-block;
    width: var(--timeline-dot-size);
    height: var(--timeline-dot-size);
    margin-right: 4px;
    background: var(--timeline-dot-bg);
    border: var(--timeline-dot-border-width) solid var(--timeline-dot-border-color);
    box-shadow: var(--timeline-dot-ring-shadow);
    border-radius: 999px;
}

.timeline-content {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    gap: var(--timeline-content-gap);
    position: relative;
    z-index: 1;
    align-items: flex-start !important;
}

.timeline-item-title {
    font-size: var(--timeline-item-title-font-size) !important;
    font-weight: 620 !important;
    line-height: 1.14 !important;
    margin: var(--timeline-item-title-margin) !important;
    max-width: var(--timeline-item-title-max-width);
    letter-spacing: -0.02em;
    text-wrap: pretty;
}

.timeline-item-title a {
    display: inline-block;
    color: var(--timeline-link-color);
    font-weight: 600;
    font-family: var(--font-ui);
    text-decoration: underline;
    background: var(--timeline-link-bg);
    padding: var(--timeline-link-padding);
    border-radius: var(--timeline-link-radius);
    cursor: pointer;
    transition: var(--timeline-link-transition);
    text-decoration-color: rgba(53, 82, 88, 0.34);
}

.timeline-item-title a:hover,
.timeline-item-title a:focus {
    color: var(--timeline-link-color-hover);
    background: var(--timeline-link-bg-hover);
    text-decoration: underline;
    text-decoration-color: rgba(34, 57, 61, 0.46);
    outline: none;
}

.timeline-item-title a[href="https://www.mbonda-lokito.org/home.html"] {
    font-size: var(--timeline-highlight-link-font-size) !important;
    color: var(--timeline-highlight-link-color) !important;
    background: var(--timeline-highlight-link-bg) !important;
    border-radius: var(--timeline-highlight-link-radius) !important;
    padding: var(--timeline-highlight-link-padding) !important;
    margin: var(--timeline-highlight-link-margin) !important;
    vertical-align: baseline;
    text-decoration-line: underline !important;
    text-decoration-color: var(--timeline-highlight-link-decoration-color) !important;
    text-decoration-thickness: var(--timeline-highlight-link-decoration-thickness) !important;
    text-underline-offset: var(--timeline-highlight-link-underline-offset) !important;
    box-decoration-break: clone;
    -webkit-box-decoration-break: clone;
    white-space: nowrap !important;
}

.timeline-item-title a[href="https://www.mbonda-lokito.org/home.html"]:hover,
.timeline-item-title a[href="https://www.mbonda-lokito.org/home.html"]:focus {
    background: var(--timeline-highlight-link-bg-hover) !important;
    color: var(--timeline-highlight-link-color-hover) !important;
    text-decoration-color: var(--timeline-highlight-link-decoration-color-hover) !important;
}

.timeline-item-text {
    color: var(--timeline-copy-color) !important;
    font-size: var(--timeline-item-text-font-size) !important;
    line-height: var(--timeline-item-text-line-height) !important;
    margin-top: 0.2em !important;
    max-width: var(--timeline-item-text-max-width);
    text-align: justify;
    text-justify: inter-word;
    word-break: normal;
    overflow-wrap: break-word;
    hyphens: auto;
    text-wrap: pretty;
}

@media (max-width: 900px) {
    .timeline-section {
        --timeline-section-padding: 62px 0;
        --timeline-container-width: min(94vw, 980px);
        --timeline-container-padding: 32px 22px 28px;
        --timeline-container-radius: 28px;
        --timeline-bar-left: 44px;
        --timeline-item-gap: 18px;
        --timeline-item-padding: 20px 20px 18px;
        --timeline-item-radius: 24px;
        --timeline-item-before-top: 16px;
        --timeline-item-before-bottom: 16px;
        --timeline-year-flex-basis: 84px;
        --timeline-year-width: 84px;
        --timeline-year-height: 54px;
        --timeline-year-min-width: 84px;
        --timeline-year-min-height: 54px;
        --timeline-year-radius: 18px;
        --timeline-year-padding: 0 14px;
        --timeline-year-font-size: 0.94em;
    }
}

@media (max-width: 600px) {
    .timeline-section {
        --timeline-section-padding: 48px 0;
        --timeline-container-width: 94vw;
        --timeline-container-padding: 26px 16px 22px;
        --timeline-container-radius: 24px;
        --timeline-header-margin-bottom: 24px;
        --timeline-header-accent-width: 72px;
        --timeline-header-accent-margin-top: 18px;
        --timeline-title-font-size: clamp(1.66rem, 7vw, 2.08rem);
        --timeline-intro-font-size: 1.05rem;
        --timeline-intro-line-height: 1.65;
        --timeline-list-gap: 16px;
        --timeline-item-gap: 10px;
        --timeline-item-padding: 18px 16px;
        --timeline-item-radius: 22px;
        --timeline-item-shadow: none;
        --timeline-item-before-top: 14px;
        --timeline-item-before-bottom: 14px;
        --timeline-item-before-width: 3px;
        --timeline-year-flex-basis: auto;
        --timeline-year-width: auto;
        --timeline-year-height: 42px;
        --timeline-year-min-width: 78px;
        --timeline-year-min-height: 42px;
        --timeline-year-radius: 999px;
        --timeline-year-padding: 0 14px;
        --timeline-year-font-size: 0.9em;
        --timeline-year-justify: center;
        --timeline-year-shadow: none;
        --timeline-dot-size: 12px;
        --timeline-dot-border-width: 2px;
        --timeline-link-padding: 0;
        --timeline-link-font-size-mobile: 1em;
        --timeline-link-radius: 0;
        --timeline-link-mobile-margin: 2px 0;
        --timeline-highlight-link-font-size: 1em;
        --timeline-highlight-link-bg: transparent;
        --timeline-highlight-link-bg-hover: transparent;
        --timeline-item-title-font-size: 1.06em;
        --timeline-item-title-max-width: 100%;
        --timeline-item-text-font-size: 1.02em;
        --timeline-item-text-line-height: 1.68;
    }

    .timeline-item {
        flex-direction: column;
        align-items: flex-start;
    }

    .timeline-year {
        align-self: flex-start;
    }

    .timeline-content {
        width: 100%;
    }

    .timeline-item-title a {
        font-size: var(--timeline-link-font-size-mobile) !important;
        padding: var(--timeline-link-padding) !important;
        border-radius: var(--timeline-link-radius) !important;
        margin: var(--timeline-link-mobile-margin) !important;
    }
}


.brand-text {
    display: block;
    font-family: var(--font-display);
    font-size: clamp(0.84rem, 0.72rem + 0.34vw, 1.02rem);
    font-weight: 700;
    color: #fff;
    line-height: 1.02;
    letter-spacing: -0.02em;
    padding-left: 8px;
    padding-right: 8px;
    text-align: left;
    white-space: normal;
    text-shadow: 0 6px 16px rgba(0, 0, 0, 0.16);
}

.brand-text .brand-main {
    display: block;
    font-weight: 700;
}

.brand-text .brand-sub {
    display: block;
    font-size: 0.62em;
    font-weight: 700;
    letter-spacing: 0.22em;
    margin-top: 0.36em;
    color: #fff;
    opacity: 0.72;
    text-transform: uppercase;
}
@media (max-width: 600px) {
    .brand-text {
        font-size: clamp(0.72rem, 0.66rem + 0.48vw, 0.86rem);
        padding-left: 2px;
        padding-right: 2px;
        text-align: left;
    }
    .brand-text .brand-sub {
        font-size: 0.66em;
        letter-spacing: 0.13em;
    }
}
/* Event Section Styles */
/* Material Design Event Section */
.event-section {
    --event-lightbox-modal-padding: 28px;
    --event-lightbox-modal-bg: rgba(18, 26, 38, 0.76);
    --event-lightbox-modal-blur: 6px;
    --event-lightbox-dialog-gap: 16px;
    --event-lightbox-dialog-max-width: min(92vw, 1120px);
    --event-lightbox-dialog-max-height: calc(100dvh - 56px);
    --event-lightbox-dialog-padding: 20px 18px 18px;
    --event-lightbox-image-max-width: min(90vw, 1100px);
    --event-lightbox-image-max-height: calc(100dvh - 210px);
    --event-lightbox-image-radius: 24px;
    --event-lightbox-image-bg: #fff;
    --event-lightbox-image-shadow: 0 26px 64px rgba(0, 0, 0, 0.34);
    --event-lightbox-caption-gap: 4px;
    --event-lightbox-caption-max-width: min(82vw, 860px);
    --event-lightbox-caption-padding: 12px 18px 14px;
    --event-lightbox-caption-radius: 18px;
    --event-lightbox-caption-bg: rgba(255, 255, 255, 0.92);
    --event-lightbox-caption-shadow: 0 14px 32px rgba(0, 0, 0, 0.16);
    --event-lightbox-kicker-color: #5d7680;
    --event-lightbox-title-color: #1f3038;
    --event-lightbox-meta-color: #516872;
    --event-lightbox-close-top: 12px;
    --event-lightbox-close-right: 8px;
    --event-lightbox-close-size: 48px;
    --event-lightbox-close-border-color: rgba(255, 255, 255, 0.18);
    --event-lightbox-close-bg: rgba(18, 26, 38, 0.64);
    --event-lightbox-close-bg-hover: rgba(13, 92, 99, 0.84);
    --event-lightbox-close-color: #fff;
    --event-lightbox-close-blur: 10px;
    --event-lightbox-close-shadow: 0 10px 24px rgba(0, 0, 0, 0.18);
    --event-lightbox-close-shadow-hover: 0 14px 30px rgba(0, 0, 0, 0.24);
    --event-lightbox-close-border-color-hover: rgba(255, 255, 255, 0.28);
    --event-lightbox-close-transition: transform 0.2s ease, background 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
    --event-list-gap: 36px;
    --event-card-bg: rgba(255, 255, 255, 0.96);
    --event-card-border-color: rgba(13, 92, 99, 0.12);
    --event-card-border-color-hover: rgba(13, 92, 99, 0.12);
    --event-card-radius: 24px;
    --event-card-shadow: var(--shadow-surface);
    --event-card-shadow-hover: var(--shadow-surface-strong);
    --event-card-max-width: 700px;
    --event-card-min-width: 280px;
    --event-card-hover-translate-y: -3px;
    --event-card-overlay-bg: transparent;
    --event-card-topline: rgba(88, 119, 115, 0.74);
    --event-card-transition: transform 0.22s ease, border-color 0.22s ease, box-shadow 0.22s ease;
    --event-title-color: #0f3640;
    --event-title-font-size: clamp(2rem, 3.4vw, 2.55rem);
    --event-title-margin-bottom: 0.8em;
    --event-title-letter-spacing: -0.02em;
    --event-badge-bg: #5b8781;
    --event-badge-bg-alt: #697f97;
    --event-badge-color: #fff;
    --event-badge-min-width: 118px;
    --event-badge-padding: 30px 16px;
    --event-badge-font-size: 1.1em;
    --event-badge-letter-spacing: 0.02em;
    --event-badge-radius: 0 28px 28px 0;
    --event-badge-shadow: none;
    --event-badge-divider-top: 14px;
    --event-badge-divider-inline: 16px;
    --event-badge-divider-bg: rgba(255, 255, 255, 0.22);
    --event-date-margin-bottom: 8px;
    --event-date-margin-right: 0;
    --event-date-text-align: center;
    --event-content-padding: 32px 28px 28px;
    --event-headline-color: #0f3640;
    --event-headline-font-size: clamp(1.22rem, 1.8vw, 1.52rem);
    --event-headline-margin-bottom: 0.5em;
    --event-headline-letter-spacing: -0.015em;
    --event-headline-line-height: 1.12;
    --event-location-color: #35545a;
    --event-location-font-size: clamp(1em, 2vw, 1.15em);
    --event-location-margin-bottom: 0.5em;
    --event-description-font-size: clamp(0.98em, 1.7vw, 1.13em);
    --event-description-line-height: 1.72;
    --event-description-margin-bottom: 1em;
    --event-description-letter-spacing: -0.01em;
    --event-description-font-size-de: 1em;
    --event-poster-image-max-width: min(100%, 340px);
    --event-poster-image-radius: 24px;
    --event-poster-image-shadow: none;
    --event-poster-image-transform: none;
    --event-poster-image-transform-hover: none;
    --event-poster-image-shadow-hover: none;
    --event-poster-image-filter-hover: none;
    --event-poster-image-transition: border-color 0.2s ease;
    --event-poster-stage-width: min(100%, 390px);
    --event-poster-stage-margin-top: 22px;
    --event-poster-controls-margin-top: 12px;
    --event-poster-hint-padding: 8px 14px;
    --event-poster-hint-bg: rgba(255, 255, 255, 0.96);
    --event-poster-hint-color: #48636d;
    --event-poster-hint-font-size: 0.84rem;
    --event-poster-hint-shadow: none;
    --event-poster-download-min-height: 42px;
    --event-poster-download-padding: 10px 16px;
    --event-poster-download-border-color: rgba(13, 92, 99, 0.14);
    --event-poster-download-bg: rgba(255, 255, 255, 0.96);
    --event-poster-download-bg-hover: #ffffff;
    --event-poster-download-color: #16464d;
    --event-poster-download-color-hover: #0d5c63;
    --event-poster-download-font-size: 0.92rem;
    --event-poster-download-shadow: 0 8px 18px rgba(25, 48, 55, 0.06);
    --event-poster-download-shadow-hover: var(--shadow-surface);
    --event-poster-download-transition: transform 0.2s ease, background 0.2s ease, color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
    --event-social-gap: 14px;
    --event-social-button-size: 50px;
    --event-social-button-min-height: 42px;
    --event-social-button-padding: 10px 16px;
    --event-social-button-radius: 999px;
    --event-social-button-bg: rgba(255, 255, 255, 0.94);
    --event-social-button-border-color: rgba(13, 92, 99, 0.18);
    --event-social-button-shadow: 0 8px 18px rgba(25, 48, 55, 0.06);
    --event-social-button-shadow-hover: 0 14px 30px rgba(25, 48, 55, 0.10);
    --event-social-button-transition: transform 0.2s ease, background 0.2s ease, border-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
    --event-social-icon-size: 24px;
    --event-social-whatsapp-color: #147a57;
    --event-social-whatsapp-color-hover: #0f6a4b;
    --event-social-whatsapp-bg: rgba(20, 122, 87, 0.12);
    --event-social-whatsapp-bg-hover: rgba(20, 122, 87, 0.18);
    --event-social-instagram-color: #9a2f69;
    --event-social-instagram-color-hover: #7f2356;
    --event-social-instagram-bg: rgba(154, 47, 105, 0.12);
    --event-social-instagram-bg-hover: rgba(154, 47, 105, 0.18);
    position: relative;
    overflow: hidden;
    isolation: isolate;
    background: var(--section-tone-a);
    padding: 64px 0 64px 0;
}

.event-title,
.event-headline,
.event-location,
.event-description,
.event-date,
.event-time {
    font-family: var(--font-ui-modern);
}

.event-lightbox-modal {
    position: fixed;
    inset: 0;
    z-index: 30000;
    align-items: center;
    justify-content: center;
    padding: var(--event-lightbox-modal-padding);
    overflow-x: hidden;
    overflow-y: auto;
    background: var(--event-lightbox-modal-bg);
    backdrop-filter: blur(var(--event-lightbox-modal-blur));
    -webkit-backdrop-filter: blur(var(--event-lightbox-modal-blur));
}

.event-lightbox-dialog {
    position: relative;
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--event-lightbox-dialog-gap);
    width: fit-content;
    max-width: var(--event-lightbox-dialog-max-width);
    max-height: var(--event-lightbox-dialog-max-height);
    margin: auto;
    padding: var(--event-lightbox-dialog-padding);
    box-sizing: border-box;
}

.event-lightbox-image {
    display: block;
    max-width: var(--event-lightbox-image-max-width);
    max-height: var(--event-lightbox-image-max-height);
    width: auto;
    border-radius: var(--event-lightbox-image-radius);
    background: var(--event-lightbox-image-bg);
    box-shadow: var(--event-lightbox-image-shadow);
}

.event-lightbox-caption {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    gap: var(--event-lightbox-caption-gap);
    max-width: var(--event-lightbox-caption-max-width);
    padding: var(--event-lightbox-caption-padding);
    border-radius: var(--event-lightbox-caption-radius);
    background: var(--event-lightbox-caption-bg);
    box-shadow: var(--event-lightbox-caption-shadow);
    text-align: center;
}

.event-lightbox-caption-kicker {
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--event-lightbox-kicker-color);
}

.event-lightbox-caption-title {
    font-size: 1rem;
    line-height: 1.38;
    font-weight: 700;
    color: var(--event-lightbox-title-color);
}

.event-lightbox-caption-meta {
    font-size: 0.9rem;
    line-height: 1.4;
    color: var(--event-lightbox-meta-color);
}

.event-lightbox-close {
    position: absolute;
    top: var(--event-lightbox-close-top);
    right: var(--event-lightbox-close-right);
    width: var(--event-lightbox-close-size);
    height: var(--event-lightbox-close-size);
    border: 1px solid var(--event-lightbox-close-border-color);
    border-radius: 50%;
    background: var(--event-lightbox-close-bg);
    color: var(--event-lightbox-close-color);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    backdrop-filter: blur(var(--event-lightbox-close-blur));
    -webkit-backdrop-filter: blur(var(--event-lightbox-close-blur));
    box-shadow: var(--event-lightbox-close-shadow);
    transition: var(--event-lightbox-close-transition);
}

.event-lightbox-close svg {
    width: 20px;
    height: 20px;
    stroke: currentColor;
    stroke-width: 2.2;
    stroke-linecap: round;
    fill: none;
}

.event-lightbox-close:hover,
.event-lightbox-close:focus-visible {
    background: var(--event-lightbox-close-bg-hover);
    border-color: var(--event-lightbox-close-border-color-hover);
    transform: scale(1.04);
    box-shadow: var(--event-lightbox-close-shadow-hover);
    outline: none;
}

.event-title {
    color: var(--event-title-color);
    font-size: var(--event-title-font-size);
    font-weight: 620;
    font-family: var(--font-display);
    line-height: 1.1;
    margin-bottom: var(--event-title-margin-bottom);
    text-align: center;
    letter-spacing: var(--event-title-letter-spacing);
    text-wrap: balance;
}
.event-list {
    display: flex;
    flex-wrap: wrap;
    gap: var(--event-list-gap);
    justify-content: center;
    align-items: stretch;
}
.event-card {
    position: relative;
    background: var(--event-card-bg);
    border: 1px solid var(--event-card-border-color);
    border-radius: var(--event-card-radius);
    box-shadow: var(--event-card-shadow);
    width: 100%;
    max-width: var(--event-card-max-width);
    min-width: var(--event-card-min-width);
    margin-left: auto;
    margin-right: auto;
    display: flex;
    flex-direction: row;
    align-items: stretch;
    padding: 0;
    overflow: hidden;
    isolation: isolate;
    box-sizing: border-box;
    transition: var(--event-card-transition);
}

.event-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background: var(--event-card-overlay-bg);
    pointer-events: none;
}

.event-card::after {
    content: none;
}

.event-card:hover,
.event-card:focus-within {
    transform: translateY(var(--event-card-hover-translate-y));
    box-shadow: var(--event-card-shadow-hover);
    border-color: var(--event-card-border-color-hover);
}

.event-badge {
    position: relative;
    background: var(--event-badge-bg);
    color: var(--event-badge-color);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-width: var(--event-badge-min-width);
    padding: var(--event-badge-padding);
    font-weight: 650;
    font-size: var(--event-badge-font-size);
    letter-spacing: var(--event-badge-letter-spacing);
    border-radius: var(--event-badge-radius);
    box-shadow: var(--event-badge-shadow);
}

.event-badge::after {
    content: "";
    position: absolute;
    top: var(--event-badge-divider-top);
    left: var(--event-badge-divider-inline);
    right: var(--event-badge-divider-inline);
    height: 1px;
    background: var(--event-badge-divider-bg);
}

#event-galakonzert-giebelstadt-2026 .event-badge {
    background: var(--event-badge-bg-alt);
}

.event-date {
    font-size: clamp(1em, 2vw, 1.15em);
    font-weight: 600;
    margin-bottom: var(--event-date-margin-bottom);
    margin-right: var(--event-date-margin-right);
    line-height: 1.25;
    text-align: var(--event-date-text-align);
}

.event-time {
    font-size: clamp(1em, 2vw, 1.15em);
    font-weight: 600;
    opacity: 0.95;
}

.event-content {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: var(--event-content-padding);
    min-width: 0;
}

.event-headline {
    color: var(--event-headline-color);
    font-size: var(--event-headline-font-size);
    font-family: var(--font-display);
    font-weight: 620;
    margin-bottom: var(--event-headline-margin-bottom);
    text-align: left;
    letter-spacing: var(--event-headline-letter-spacing);
    line-height: 1.12;
    text-wrap: balance;
}

.event-location {
    color: var(--event-location-color);
    font-size: var(--event-location-font-size);
    font-weight: 600;
    margin-bottom: var(--event-location-margin-bottom);
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.event-description {
    color: #18373f;
    font-size: var(--event-description-font-size);
    line-height: var(--event-description-line-height);
    text-align: justify;
    text-justify: inter-word;
    hyphens: auto;
    -webkit-hyphens: auto;
    -ms-hyphens: auto;
    margin-bottom: var(--event-description-margin-bottom);
    letter-spacing: var(--event-description-letter-spacing);
}


@media (min-width: 701px) {
    .event-description[data-lang="de"] {
        font-size: var(--event-description-font-size-de);
    }
}

.event-poster-stage {
    position: relative;
    width: var(--event-poster-stage-width);
    margin: var(--event-poster-stage-margin-top) auto 0;
}

.event-poster-actions,
.event-poster-hint {
    display: flex;
    justify-content: center;
    margin-top: var(--event-poster-controls-margin-top);
}

.event-poster-hint-text {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: var(--event-poster-hint-padding);
    border-radius: 999px;
    background: var(--event-poster-hint-bg);
    color: var(--event-poster-hint-color);
    font-size: var(--event-poster-hint-font-size);
    font-weight: 700;
    line-height: 1.2;
    text-align: center;
    box-shadow: var(--event-poster-hint-shadow);
}

.event-poster-download {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: var(--event-poster-download-min-height);
    padding: var(--event-poster-download-padding);
    border-radius: 999px;
    border: 1px solid var(--event-poster-download-border-color);
    background: var(--event-poster-download-bg);
    color: var(--event-poster-download-color);
    font-size: var(--event-poster-download-font-size);
    font-weight: 700;
    line-height: 1.2;
    text-decoration: none;
    text-align: center;
    box-shadow: var(--event-poster-download-shadow);
    transition: var(--event-poster-download-transition);
}

.event-poster-download:hover,
.event-poster-download:focus-visible {
    background: var(--event-poster-download-bg-hover);
    color: var(--event-poster-download-color-hover);
    box-shadow: var(--event-poster-download-shadow-hover);
    transform: translateY(-1px);
    outline: none;
}

.event-social-actions {
    --event-poster-controls-margin-top: 12px;
    --event-poster-download-color: #16464d;
    --event-social-gap: 18px;
    --event-social-button-size: 58px;
    --event-social-button-bg: rgba(255, 255, 255, 0.98);
    --event-social-button-border-color: rgba(13, 92, 99, 0.14);
    --event-social-button-shadow: 0 12px 24px rgba(16, 47, 54, 0.1), inset 0 1px 0 rgba(255, 255, 255, 0.78);
    --event-social-button-shadow-hover: 0 14px 28px rgba(16, 47, 54, 0.14), inset 0 1px 0 rgba(255, 255, 255, 0.84);
    --event-social-button-transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
    --event-social-icon-size: 28px;
    --event-social-whatsapp-color: #147a57;
    --event-social-whatsapp-color-hover: #0f6a4b;
    --event-social-whatsapp-bg: rgba(20, 122, 87, 0.14);
    --event-social-whatsapp-bg-hover: rgba(20, 122, 87, 0.2);
    --event-social-instagram-color: #9a2f69;
    --event-social-instagram-color-hover: #7f2356;
    --event-social-instagram-bg: rgba(154, 47, 105, 0.14);
    --event-social-instagram-bg-hover: rgba(154, 47, 105, 0.2);
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--event-social-gap);
    margin-top: var(--event-poster-controls-margin-top);
}

.event-social-button {
    --interaction-transform: translateY(-1px);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    position: relative;
    isolation: isolate;
    flex-wrap: nowrap;
    flex: 0 0 var(--event-social-button-size);
    gap: 0;
    width: var(--event-social-button-size);
    height: var(--event-social-button-size);
    min-width: var(--event-social-button-size);
    min-height: var(--event-social-button-size);
    max-width: var(--event-social-button-size);
    max-height: var(--event-social-button-size);
    aspect-ratio: 1 / 1;
    padding: 0;
    border: 1px solid var(--event-social-button-border-color);
    border-radius: 999px;
    background: var(--event-social-button-bg);
    color: var(--event-poster-download-color);
    font-size: 0;
    font-weight: 700;
    line-height: 1.2;
    text-align: center;
    text-decoration: none;
    box-shadow: var(--event-social-button-shadow);
    transition: var(--event-social-button-transition);
    overflow: hidden;
    white-space: nowrap;
    word-break: normal;
    overflow-wrap: normal;
    hyphens: manual;
    -webkit-hyphens: manual;
    -ms-hyphens: manual;
}

.event-social-button::before {
    content: "";
    position: absolute;
    inset: 1px;
    border-radius: inherit;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.58), rgba(255, 255, 255, 0.18));
    pointer-events: none;
    z-index: 0;
}

.event-social-button svg {
    width: var(--event-social-icon-size);
    height: var(--event-social-icon-size);
    position: relative;
    z-index: 1;
    flex: 0 0 auto;
    stroke: currentColor;
    stroke-width: 2.05;
    stroke-linecap: round;
    stroke-linejoin: round;
    fill: none;
}

.event-social-button span {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    clip-path: inset(50%);
    border: 0;
    white-space: nowrap;
}

.event-social-button--whatsapp {
    background: var(--event-social-whatsapp-bg);
    color: var(--event-social-whatsapp-color);
}

.event-social-button--instagram {
    background: var(--event-social-instagram-bg);
    color: var(--event-social-instagram-color);
}

.event-social-button:hover,
.event-social-button:focus-visible {
    background: #ffffff;
    border-color: rgba(13, 92, 99, 0.28);
    box-shadow: var(--event-social-button-shadow-hover);
    transform: translateY(-1px);
    outline: none;
}

.event-social-button--whatsapp:hover,
.event-social-button--whatsapp:focus-visible {
    background: var(--event-social-whatsapp-bg-hover);
    color: var(--event-social-whatsapp-color-hover);
}

.event-social-button--instagram:hover,
.event-social-button--instagram:focus-visible {
    background: var(--event-social-instagram-bg-hover);
    color: var(--event-social-instagram-color-hover);
}

.event-poster-stage::before {
    content: none;
}

.event-poster-image {
    position: relative;
    z-index: 1;
    width: 100%;
    max-width: var(--event-poster-image-max-width);
    height: auto;
    margin: 0 auto;
    border-radius: var(--event-poster-image-radius);
    background: transparent;
    box-shadow: var(--event-poster-image-shadow);
    transform: var(--event-poster-image-transform);
    transform-origin: center center;
    transition: var(--event-poster-image-transition);
    cursor: zoom-in;
}

.event-card:hover .event-poster-image,
.event-card:focus-within .event-poster-image {
    transform: var(--event-poster-image-transform-hover);
    box-shadow: var(--event-poster-image-shadow-hover);
    filter: var(--event-poster-image-filter-hover);
}

@media (max-width: 700px) {
    .event-section {
        --event-title-font-size: clamp(1.2em, 6vw, 2em);
        --event-headline-font-size: clamp(1.1em, 4.2vw, 1.26em);
        --event-location-font-size: clamp(1em, 3.2vw, 1.08em);
        --event-description-font-size: clamp(1em, 2.7vw, 1.08em);
        --event-poster-image-max-width: 100%;
        --event-poster-image-radius: 14px;
    }

    .event-date,
    .event-time {
        font-size: clamp(1em, 2.6vw, 1.08em);
    }
}

@media (max-width: 900px) {
    .event-section {
        --event-list-gap: 32px;
        --event-card-max-width: 98vw;
        --event-card-min-width: 0;
    }

    .event-list {
        flex-direction: column;
        padding: 0 10px;
    }
    .event-card {
        margin: 12px auto;
        transform: none;
    }
}
@media (max-width: 600px) {
    .event-lightbox-modal {
        padding: var(--event-lightbox-modal-padding);
    }

    .event-lightbox-dialog {
        width: 100%;
        max-width: 100%;
        max-height: var(--event-lightbox-dialog-max-height);
        padding: var(--event-lightbox-dialog-padding);
        gap: var(--event-lightbox-dialog-gap);
    }

    .event-lightbox-image {
        max-width: 100%;
        max-height: var(--event-lightbox-image-max-height);
        border-radius: var(--event-lightbox-image-radius);
    }

    .event-lightbox-caption {
        width: min(100%, 420px);
        padding: var(--event-lightbox-caption-padding);
        border-radius: var(--event-lightbox-caption-radius);
    }

    .event-lightbox-caption-title {
        font-size: 0.94rem;
    }

    .event-lightbox-caption-meta {
        font-size: 0.84rem;
        line-height: 1.35;
    }

    .event-lightbox-close {
        width: var(--event-lightbox-close-size);
        height: var(--event-lightbox-close-size);
        top: var(--event-lightbox-close-top);
        right: var(--event-lightbox-close-right);
    }

    .event-section {
        --event-lightbox-modal-padding: 14px;
        --event-lightbox-dialog-gap: 12px;
        --event-lightbox-dialog-max-height: calc(100dvh - 28px);
        --event-lightbox-dialog-padding: 16px 12px 12px;
        --event-lightbox-image-max-height: calc(100dvh - 176px);
        --event-lightbox-image-radius: 18px;
        --event-lightbox-caption-padding: 10px 14px 12px;
        --event-lightbox-caption-radius: 16px;
        --event-lightbox-close-top: 6px;
        --event-lightbox-close-right: 4px;
        --event-card-radius: 18px;
        --event-card-max-width: 100%;
        --event-card-shadow: none;
        --event-badge-min-width: 0;
        --event-badge-padding: 16px 14px 12px 16px;
        --event-badge-font-size: 1em;
        --event-badge-radius: 16px 16px 0 0;
        --event-badge-shadow: none;
        --event-badge-divider-inline: 14px;
        --event-date-margin-bottom: 0;
        --event-date-margin-right: 18px;
        --event-date-text-align: left;
        --event-content-padding: 18px 14px 16px;
        --event-title-margin-bottom: 18px;
        --event-poster-image-radius: 20px;
        --event-poster-image-transform: none;
        --event-poster-stage-width: min(100%, 360px);
        --event-poster-stage-margin-top: 18px;
        --event-poster-controls-margin-top: 10px;
        --event-poster-hint-padding: 8px 12px;
        --event-poster-hint-font-size: 0.8rem;
        --event-poster-download-padding: 10px 14px;
        --event-poster-download-font-size: 0.9rem;
        padding: 28px 0 28px 0;
    }
    .event-card {
        flex-direction: column;
        border-color: transparent;
    }

    .event-badge {
        flex-direction: row;
        justify-content: flex-start;
        align-items: center;
        width: 100%;
    }

    .event-poster-stage {
        width: var(--event-poster-stage-width);
    }

    .event-poster-hint-text {
        max-width: 320px;
    }

    .event-poster-download {
        width: 100%;
        max-width: 320px;
    }

    .event-social-button {
        width: var(--event-social-button-size);
        max-width: none;
    }

    .event-poster-stage::before {
        content: none;
    }
}

@media (max-width: 400px) {
    .event-section {
        --event-title-font-size: 1.1em;
        --event-headline-font-size: 1em;
        --event-location-font-size: 1em;
        --event-description-font-size: 1em;
        --event-poster-image-radius: 10px;
    }

    .event-location,
    .event-description,
    .event-date,
    .event-time {
        font-size: 1em;
    }
}
.image-caption-section {
    --image-caption-section-bg: var(--section-tone-a);
    --image-caption-section-padding: 18px 0 36px;
    --image-caption-section-min-height: auto;
    --image-caption-card-max-width: 1040px;
    --image-caption-card-width: min(92vw, 1040px);
    --image-caption-card-padding: clamp(18px, 3vw, 34px);
    --image-caption-card-radius: var(--radius-card-large);
    --image-caption-card-shadow: none;
    --image-caption-card-border-color: transparent;
    --image-caption-card-bg: transparent;
    --image-caption-title-color: #12333a;
    --image-caption-title-size: clamp(1.9rem, 3vw, 2.75rem);
    --image-caption-title-margin-bottom: 8px;
    --image-caption-title-letter-spacing: -0.07em;
    --image-caption-lead-color: #178d81;
    --image-caption-lead-size: clamp(1rem, 1.25vw, 1.2rem);
    --image-caption-lead-margin-bottom: 12px;
    --image-caption-image-max-width: 760px;
    --image-caption-image-radius: 22px;
    --image-caption-image-margin-top: 0;
    --image-caption-image-margin-bottom: 18px;
    --image-caption-footer-color: #1b4a50;
    --image-caption-footer-size: clamp(1rem, 1.4vw, 1.14rem);
    --image-caption-link-overlay-bg: rgba(9, 18, 27, 0.48);
    --image-caption-link-overlay-bg-hover: rgba(9, 18, 27, 0.62);
    --image-caption-link-overlay-padding: 18px 22px;
    --image-caption-link-shadow: none;
    background: var(--image-caption-section-bg);
    position: relative;
    overflow: hidden;
    padding: var(--image-caption-section-padding);
    min-height: var(--image-caption-section-min-height);
    display: flex;
    align-items: center;
    justify-content: center;
}

.image-caption-card {
    background: var(--image-caption-card-bg);
    border: 0;
    border-radius: var(--image-caption-card-radius);
    max-width: var(--image-caption-card-max-width);
    width: var(--image-caption-card-width);
    margin: 0 auto;
    padding: var(--image-caption-card-padding);
    display: flex;
    flex-direction: column;
    align-items: center;
    box-shadow: none;
    position: relative;
    overflow: visible;
}
/* Bildunterschrift Section ohne Card-Wrapper */
.image-caption-card-h1,
.image-caption-card-lead,
.image-caption-card-img,
.image-caption-card-footer {
    font-family: var(--font-ui-modern) !important;
}
/* Modernes, responsives Layout für image-caption-section */
.image-caption-card-h1 {
    color: var(--image-caption-title-color);
    font-size: var(--image-caption-title-size);
    font-weight: 700;
    font-family: var(--font-display) !important;
    line-height: 0.98;
    text-align: center;
    margin-bottom: var(--image-caption-title-margin-bottom);
    letter-spacing: var(--image-caption-title-letter-spacing);
    margin-top: 0;
    text-wrap: balance;
    text-shadow: 0 6px 16px rgba(17, 50, 58, 0.05);
}
.image-caption-card-lead {
    color: var(--image-caption-lead-color);
    font-size: var(--image-caption-lead-size);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    text-align: center;
    margin-bottom: var(--image-caption-lead-margin-bottom);
}

.image-caption-card-link {
    display: inline-block;
    position: relative;
    border-radius: var(--image-caption-image-radius);
    overflow: visible;
    border: 0;
    background: transparent;
    box-shadow: var(--image-caption-link-shadow);
    transition: transform 0.24s ease;
}

.image-caption-card-link:hover,
.image-caption-card-link:focus-visible {
    transform: translateY(-2px);
    box-shadow: none;
    outline: none;
}

.image-caption-card-play {
    position: absolute;
    top: 50%;
    left: 50%;
    --interaction-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    background: var(--image-caption-link-overlay-bg);
    border-radius: 50%;
    padding: var(--image-caption-link-overlay-padding);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.25s ease, transform 0.25s ease;
}

.image-caption-card-link:hover .image-caption-card-play,
.image-caption-card-link:focus-visible .image-caption-card-play {
    background: var(--image-caption-link-overlay-bg-hover);
    transform: translate(-50%, -50%) scale(1.04);
}

.image-caption-card-img {
    width: 100%;
    max-width: var(--image-caption-image-max-width);
    min-width: 0;
    height: auto;
    border-radius: var(--image-caption-image-radius);
    box-shadow: none;
    margin-bottom: var(--image-caption-image-margin-bottom);
    margin-top: var(--image-caption-image-margin-top);
    aspect-ratio: 16/7;
    object-fit: cover;
    display: block;
}
.image-caption-card-footer {
    color: var(--image-caption-footer-color);
    font-size: var(--image-caption-footer-size);
    font-weight: 700;
    letter-spacing: -0.02em;
    text-align: center;
    text-wrap: balance;
}
@media (max-width: 600px) {
    .image-caption-section {
        --image-caption-section-padding: 8px 0 22px;
    }
    .image-caption-card {
        --image-caption-card-padding: 12px 14px 14px;
        --image-caption-card-radius: 16px;
    }
}



.hero-bg {
    position: relative;
    width: 100%;
    height: 100vh;
    overflow: hidden;
    isolation: isolate;
    background: #1d484b;
}

.hero-bg::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    background: rgba(7, 11, 16, 0.34);
}

.hero-gallery-ui {
    --hero-gallery-ui-bottom: clamp(18px, 2vw, 28px);
    --hero-gallery-ui-translate-y: 0px;
    --interaction-transform: translateX(-50%);
    --hero-gallery-ui-width: min(92vw, 860px);
    --hero-gallery-ui-gap: 10px;
    --hero-gallery-ui-padding: 10px 12px 12px;
    --hero-gallery-ui-radius: 26px;
    --hero-gallery-ui-bg: var(--glass-dark-bg);
    --hero-gallery-ui-border-color: var(--glass-dark-border);
    --hero-gallery-ui-shadow: var(--glass-dark-shadow);
    --hero-gallery-ui-backdrop-blur: 16px;
    --hero-gallery-ui-backdrop-saturate: 128%;
    --hero-gallery-ui-transition: none;
    --hero-gallery-ui-z-index: 20;
    --hero-gallery-meta-columns: auto 1fr;
    --hero-gallery-meta-gap: 12px;
    --hero-gallery-counter-gap: 6px;
    --hero-gallery-counter-min-width: 58px;
    --hero-gallery-counter-color: rgba(244, 251, 251, 0.92);
    --hero-gallery-counter-font-size: 0.86rem;
    --hero-gallery-counter-letter-spacing: 0.08em;
    --hero-gallery-counter-value-letter-spacing: -0.05em;
    --hero-gallery-counter-separator-opacity: 0.42;
    --hero-gallery-counter-separator-letter-spacing: -0.04em;
    --hero-gallery-progress-height: 4px;
    --hero-gallery-progress-bg: rgba(255, 255, 255, 0.13);
    --hero-gallery-progress-bar-bg: #8cf5cf;
    --hero-gallery-controls-columns: auto 1fr auto;
    --hero-gallery-controls-gap: 8px;
    --hero-gallery-control-size: 42px;
    --hero-gallery-control-border-color: rgba(255, 255, 255, 0.15);
    --hero-gallery-control-bg: rgba(255, 255, 255, 0.07);
    --hero-gallery-control-bg-hover: rgba(255, 255, 255, 0.14);
    --hero-gallery-control-color: rgba(246, 255, 255, 0.92);
    --hero-gallery-control-color-hover: #ffffff;
    --hero-gallery-control-border-color-hover: rgba(255, 255, 255, 0.22);
    --hero-gallery-control-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.10), 0 10px 22px rgba(0, 0, 0, 0.12);
    --hero-gallery-control-transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
    --hero-gallery-control-icon-size: 16px;
    --hero-gallery-pagination-gap: 7px;
    --hero-gallery-dot-size: 7px;
    --hero-gallery-dot-bg: rgba(255, 255, 255, 0.30);
    --hero-gallery-dot-focus-color: rgba(158, 243, 234, 0.88);
    --hero-gallery-dot-selected-width: 24px;
    --hero-gallery-dot-selected-bg: rgba(158, 243, 234, 0.96);
    --hero-gallery-dot-selected-shadow: 0 0 0 1px rgba(255, 255, 255, 0.14);
    position: absolute;
    left: 50%;
    bottom: var(--hero-gallery-ui-bottom);
    transform: translateX(-50%);
    width: var(--hero-gallery-ui-width);
    display: grid;
    gap: var(--hero-gallery-ui-gap);
    padding: var(--hero-gallery-ui-padding);
    border-radius: var(--hero-gallery-ui-radius);
    background: var(--hero-gallery-ui-bg);
    border: 1px solid var(--hero-gallery-ui-border-color);
    box-shadow: var(--hero-gallery-ui-shadow);
    backdrop-filter: blur(var(--hero-gallery-ui-backdrop-blur)) saturate(var(--hero-gallery-ui-backdrop-saturate));
    -webkit-backdrop-filter: blur(var(--hero-gallery-ui-backdrop-blur)) saturate(var(--hero-gallery-ui-backdrop-saturate));
    opacity: 1;
    pointer-events: auto;
    visibility: visible;
    transition: var(--hero-gallery-ui-transition);
    z-index: var(--hero-gallery-ui-z-index);
}

.hero-gallery-ui.hero-gallery-ui--active,
.hero-bg:focus-within .hero-gallery-ui {
    transform: translateX(-50%);
}

.hero-gallery-meta {
    display: grid;
    grid-template-columns: var(--hero-gallery-meta-columns);
    gap: var(--hero-gallery-meta-gap);
    align-items: center;
}

.hero-gallery-counter {
    display: inline-flex;
    align-items: baseline;
    gap: var(--hero-gallery-counter-gap);
    min-width: var(--hero-gallery-counter-min-width);
    color: var(--hero-gallery-counter-color);
    font-family: var(--font-ui-modern);
    font-size: var(--hero-gallery-counter-font-size);
    font-weight: 800;
    letter-spacing: var(--hero-gallery-counter-letter-spacing);
    font-variant-numeric: tabular-nums;
    font-feature-settings: 'tnum' 1, 'ss01' 1;
    text-transform: uppercase;
}

.hero-gallery-counter > span {
    font-family: var(--font-ui-modern);
}

#heroGalleryCurrent,
#heroGalleryTotal {
    font-family: var(--font-display);
    font-weight: 800;
    letter-spacing: var(--hero-gallery-counter-value-letter-spacing);
}

.hero-gallery-counter-separator {
    opacity: var(--hero-gallery-counter-separator-opacity);
    font-weight: 600;
    letter-spacing: var(--hero-gallery-counter-separator-letter-spacing);
}

.hero-gallery-progress {
    position: relative;
    height: var(--hero-gallery-progress-height);
    border-radius: 999px;
    overflow: hidden;
    background: var(--hero-gallery-progress-bg);
}

.hero-gallery-progress-bar {
    display: block;
    width: 100%;
    height: 100%;
    transform: scaleX(0);
    transform-origin: left center;
    border-radius: inherit;
    background: var(--hero-gallery-progress-bar-bg);
}

.hero-gallery-controls {
    display: grid;
    grid-template-columns: var(--hero-gallery-controls-columns);
    gap: var(--hero-gallery-controls-gap);
    align-items: center;
}

.hero-gallery-control {
    width: var(--hero-gallery-control-size);
    height: var(--hero-gallery-control-size);
    border: 1px solid var(--hero-gallery-control-border-color);
    border-radius: 50%;
    background: var(--hero-gallery-control-bg);
    color: var(--hero-gallery-control-color);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    box-shadow: var(--hero-gallery-control-shadow);
    transition: var(--hero-gallery-control-transition);
}

.hero-gallery-control svg {
    width: var(--hero-gallery-control-icon-size);
    height: var(--hero-gallery-control-icon-size);
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
    fill: none;
}

.hero-gallery-control:hover,
.hero-gallery-control:focus-visible {
    background: var(--hero-gallery-control-bg-hover);
    border-color: var(--hero-gallery-control-border-color-hover);
    color: var(--hero-gallery-control-color-hover);
    transform: none;
    outline: none;
}

.hero-gallery-pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0;
    padding: 0;
    position: static;
    left: auto;
    right: auto;
    bottom: auto;
    justify-content: center;
    gap: var(--hero-gallery-pagination-gap);
    padding-bottom: 0;
}

.hero-gallery-dot {
    cursor: pointer;
    outline: none;
    position: relative;
    width: var(--hero-gallery-dot-size);
    height: var(--hero-gallery-dot-size);
    border-radius: 999px;
    border: 0;
    background: var(--hero-gallery-dot-bg);
    box-shadow: none;
    transition: none;
}

.hero-gallery-dot:focus-visible {
    outline: 2px solid var(--hero-gallery-dot-focus-color);
    outline-offset: 2px;
}

.hero-gallery-dot[aria-selected="true"] {
    width: var(--hero-gallery-dot-selected-width);
    background: var(--hero-gallery-dot-selected-bg);
    transform: none;
    box-shadow: var(--hero-gallery-dot-selected-shadow);
}

.fadein-text {
    --hero-fadein-left: clamp(18px, 4vw, 42px);
    --hero-fadein-bottom: clamp(116px, 12vw, 142px);
    --hero-fadein-max-width: min(70vw, 820px);
    --interaction-transform: translateY(var(--hero-fadein-translate-y));
    --hero-fadein-padding: 16px 20px 17px;
    --hero-fadein-radius: 24px 24px 24px 8px;
    --hero-fadein-bg: var(--glass-dark-bg);
    --hero-fadein-color: rgba(255, 255, 255, 0.96);
    --hero-fadein-font-size: clamp(1.16rem, 1.7vw, 1.56rem);
    --hero-fadein-line-height: 1.02;
    --hero-fadein-letter-spacing: -0.05em;
    --hero-fadein-shadow: 0 24px 58px rgba(0, 0, 0, 0.22);
    --hero-fadein-border-color: var(--glass-dark-border);
    --hero-fadein-backdrop-blur: 16px;
    --hero-fadein-backdrop-saturate: 128%;
    --hero-fadein-translate-y: 0px;
    --hero-fadein-transition: none;
    position: absolute;
    z-index: 6;
    left: var(--hero-fadein-left);
    right: auto;
    bottom: var(--hero-fadein-bottom);
    max-width: var(--hero-fadein-max-width);
    padding: var(--hero-fadein-padding);
    border-radius: var(--hero-fadein-radius);
    background: var(--hero-fadein-bg);
    color: var(--hero-fadein-color);
    font-family: var(--font-display);
    font-size: var(--hero-fadein-font-size);
    font-weight: 800;
    line-height: var(--hero-fadein-line-height);
    letter-spacing: var(--hero-fadein-letter-spacing);
    text-align: left;
    box-shadow: var(--hero-fadein-shadow);
    border: 1px solid var(--hero-fadein-border-color);
    backdrop-filter: blur(var(--hero-fadein-backdrop-blur)) saturate(var(--hero-fadein-backdrop-saturate));
    -webkit-backdrop-filter: blur(var(--hero-fadein-backdrop-blur)) saturate(var(--hero-fadein-backdrop-saturate));
    text-wrap: pretty;
    transform: translateY(var(--hero-fadein-translate-y));
    opacity: 1;
    transition: var(--hero-fadein-transition);
    will-change: auto;
    text-shadow: 0 10px 28px rgba(0, 0, 0, 0.26);
}

@media (max-width: 700px) {
    .hero-bg {
        --hero-bg-height: min(62vh, calc(100vw * 0.68));
        min-height: 260px;
        background: #1b4144;
    }

    .hero-bg::after {
        background: rgba(7, 11, 16, 0.24);
    }

    .hero-bg-fade {
        --hero-fade-image-size: contain;
        --hero-fade-image-focus-position: center center;
        background-color: #0f1720;
    }

    .hero-gallery-ui {
        --hero-gallery-ui-width: min(94vw, 430px);
        --hero-gallery-ui-bottom: 12px;
        --hero-gallery-ui-translate-y: 0px;
        --hero-gallery-ui-gap: 8px;
        --hero-gallery-ui-padding: 8px 10px 10px;
        --hero-gallery-ui-radius: 18px;
        --hero-gallery-ui-bg: rgba(12, 19, 28, 0.46);
        --hero-gallery-meta-gap: 10px;
        --hero-gallery-counter-min-width: 52px;
        --hero-gallery-counter-font-size: 0.74rem;
        --hero-gallery-controls-columns: 38px 1fr 38px;
        --hero-gallery-control-size: 38px;
        --hero-gallery-control-icon-size: 14px;
        --hero-gallery-pagination-gap: 6px;
        --hero-gallery-dot-size: 6px;
        --hero-gallery-dot-selected-width: 18px;
    }

    .fadein-text {
        --hero-fadein-left: 14px;
        right: auto !important;
        --hero-fadein-bottom: 112px;
        --hero-fadein-max-width: min(68vw, 300px);
        --hero-fadein-padding: 8px 11px 9px;
        --hero-fadein-font-size: 0.92rem;
        --hero-fadein-line-height: 1.04;
        --hero-fadein-letter-spacing: -0.035em;
        --hero-fadein-radius: 14px 14px 14px 5px;
        --hero-fadein-bg: rgba(17, 25, 37, 0.34);
        --hero-fadein-translate-y: 26px;
        display: -webkit-box !important;
        line-clamp: 2;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden !important;
        text-align: left !important;
    }
}

@media (max-width: 400px) {
    .hero-bg {
        --hero-bg-height: min(56vh, calc(100vw * 0.72));
        min-height: 220px;
    }

    .hero-gallery-ui {
        --hero-gallery-ui-width: min(96vw, 360px);
        --hero-gallery-ui-bottom: 10px;
        --hero-gallery-ui-translate-y: 0px;
        --hero-gallery-ui-padding: 7px 8px 9px;
        --hero-gallery-meta-columns: 1fr;
        --hero-gallery-meta-gap: 8px;
        --hero-gallery-counter-min-width: 0;
    }

    .hero-gallery-counter {
        justify-content: center;
    }

    .fadein-text {
        --hero-fadein-bottom: 120px;
        --hero-fadein-max-width: min(72vw, 260px);
        --hero-fadein-font-size: 0.82rem;
        --hero-fadein-line-height: 1.14;
        --hero-fadein-translate-y: 22px;
    }
}

.hero-bg-fade-container {
    --hero-fade-layer-inset: 0;
    --hero-fade-layer-bg: #0f1720;
    --hero-fade-layer-z-index: 10;
    position: absolute;
    inset: var(--hero-fade-layer-inset);
    background: var(--hero-fade-layer-bg);
    z-index: var(--hero-fade-layer-z-index);
}

.hero-bg-fade {
    --hero-fade-image-inset: 0;
    --hero-fade-image-z-index: 10;
    --hero-fade-image-repeat: no-repeat;
    --hero-fade-image-size: cover;
    --hero-fade-image-position: center center;
    --hero-fade-image-focus-position: center 10%;
    position: absolute;
    inset: var(--hero-fade-image-inset);
    z-index: var(--hero-fade-image-z-index);
    background-repeat: var(--hero-fade-image-repeat);
    background-position: var(--hero-fade-image-position);
    background-size: var(--hero-fade-image-size);
    background-position: var(--hero-fade-image-focus-position);
}

.hero-bg-fade-current {
    opacity: 1;
    z-index: var(--hero-fade-layer-z-index);
}
.hero-bg-fade-next {
    z-index: var(--hero-fade-layer-z-index);
}


/* Globale Textfluss- und Responsive-Regel fuer Haupttextbereiche */
article, p, .contact-info-section, .site-footer {
    --global-copy-padding-inline-tablet: 2vw;
    --global-copy-padding-inline-mobile: 1vw;
    text-align: left;
    word-break: break-word;
    hyphens: auto;
}

@media (max-width: 900px) {
    article, p, .contact-info-section, .site-footer {
        font-size: 1em;
    }
}

@media (max-width: 600px) {
    article, p, .contact-info-section, .site-footer {
        font-size: 1.05em;
    }
}

@media (max-width: 1200px) {
    html {
        --mobile-navbar-offset: 56px;
    }
    .navbar {
        background: rgba(10, 18, 24, 0.08) !important;
        border-bottom-color: rgba(255, 255, 255, 0.22);
        box-shadow: none;
        color: #fff;
    }
    .menu-icon {
        filter: var(--menu-icon-filter-mobile);
    }
    .hero-bg {
        margin-top: 0;
        padding-top: 0;
    }
    .hero-bg-fade-container {
        top: 0 !important;
        height: 100% !important;
    }
}
/* Hero background image layer */
.hero-bg {
    --hero-bg-height: 100vh;
    position: relative;
    width: 100%;
    height: var(--hero-bg-height);
    overflow: hidden;
}

html, body {
    --page-shell-width: 100vw;
    --page-shell-min-height: 100%;
    --page-shell-bg: #f6edde;
    margin: 0;
    padding: 0;
    width: var(--page-shell-width);
    min-height: var(--page-shell-min-height);
    background: var(--page-shell-bg);
    box-sizing: border-box;
    overflow-x: hidden;
}

.site-footer {
    --site-footer-padding: 42px 0 18px;
    --site-footer-padding-bottom: 16px;
    --site-footer-surface: #0e1618;
    --site-footer-border-color: rgba(255, 255, 255, 0.08);
    --site-footer-heading-color: #ffffff;
    --site-footer-copy-color: rgba(255, 255, 255, 0.78);
    --site-footer-copy-soft: rgba(255, 255, 255, 0.58);
    --site-footer-link-bg: rgba(255, 255, 255, 0.05);
    --site-footer-link-bg-hover: rgba(127, 232, 219, 0.12);
    --site-footer-link-border-color: rgba(255, 255, 255, 0.10);
    --site-footer-link-border-color-hover: rgba(127, 232, 219, 0.24);
    --site-footer-link-color: #ffffff;
    --site-footer-link-shadow: 0 10px 22px rgba(0, 0, 0, 0.16);
    margin-bottom: 0 !important;
    padding: var(--site-footer-padding) !important;
    padding-bottom: var(--site-footer-padding-bottom) !important;
    background: var(--site-footer-surface) !important;
    border-top: 1px solid var(--site-footer-border-color);
    box-shadow: none;
    text-align: center;
    font-family: var(--font-ui-modern);
    position: relative;
    z-index: 2;
}

.site-footer::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 100%;
    height: 100svh;
    background: var(--site-footer-surface);
    pointer-events: none;
}

.site-footer__inner {
    max-width: 980px;
    margin: 0 auto;
    padding: 0 16px;
}

.site-footer__brand {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    margin-bottom: 22px;
}

.site-footer__logo {
    display: block;
    width: auto;
    height: 52px;
}

.site-footer__title {
    color: var(--site-footer-heading-color);
    font-family: var(--font-display);
    font-size: clamp(1.18rem, 1rem + 0.5vw, 1.42rem);
    font-weight: 800;
    letter-spacing: -0.04em;
    line-height: 1;
    text-wrap: balance;
}

.site-footer__subtitle {
    color: var(--site-footer-copy-color);
    font-size: 0.98rem;
    font-weight: 520;
    line-height: 1.5;
}

.site-footer__links {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
    margin-bottom: 16px;
}

.site-footer__link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 10px 16px;
    border-radius: 999px;
    border: 1px solid var(--site-footer-link-border-color);
    background: var(--site-footer-link-bg);
    color: var(--site-footer-link-color);
    font-size: 0.96rem;
    font-weight: 700;
    text-decoration: none;
    box-shadow: var(--site-footer-link-shadow);
    transition: transform 0.2s ease, background 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.site-footer__link:hover,
.site-footer__link:focus-visible {
    transform: translateY(-1px);
    background: var(--site-footer-link-bg-hover);
    border-color: var(--site-footer-link-border-color-hover);
    box-shadow: 0 14px 28px rgba(0, 0, 0, 0.22);
    outline: none;
}

.site-footer__meta {
    display: flex;
    flex-direction: column;
    gap: 6px;
    align-items: center;
}

.site-footer__meta-line {
    color: var(--site-footer-copy-soft);
    font-size: 0.92rem;
    line-height: 1.5;
}

@media (max-width: 600px) {
    .site-footer {
        --site-footer-padding: 34px 0 14px;
    }

    .site-footer__logo {
        height: 46px;
    }

    .site-footer__title {
        font-size: clamp(1.04rem, 4.8vw, 1.22rem);
    }

    .site-footer__subtitle {
        font-size: 0.94rem;
    }

    .site-footer__links {
        gap: 8px;
    }

    .site-footer__link {
        width: 100%;
        max-width: 320px;
        font-size: 0.94rem;
    }

    .site-footer__meta-line {
        font-size: 0.9rem;
    }
}

@media (prefers-color-scheme: dark) {
    .mobile-menu.active {
        background: var(--mobile-menu-bg-dark-active) !important;
        padding: var(--mobile-menu-dark-padding);
        font-size: var(--mobile-menu-dark-font-size);
        max-width: var(--mobile-menu-dark-max-width);
    }
}

/* Flaches Design für Desktop-Dropdown-Menüs */
.nav-menu {
    box-shadow: none !important;
}

.navbar {
    --navbar-z-index: 50000;
    --navbar-gap: clamp(10px, 1.4vw, 20px);
    --navbar-padding: 12px clamp(14px, 2.4vw, 28px);
    --navbar-bg: rgba(9, 21, 28, 0.26);
    --navbar-border-color: rgba(235, 246, 243, 0.16);
    --navbar-shadow: 0 10px 28px rgba(3, 10, 14, 0.12);
    --navbar-backdrop-blur: 12px;
    --nav-brand-gap: clamp(8px, 1vw, 14px);
    --nav-brand-padding: 0.28em 0.62em;
    --nav-brand-bg: rgba(255, 255, 255, 0.08);
    --nav-brand-border-color: rgba(235, 246, 243, 0.12);
    --nav-brand-shadow: 0 8px 20px rgba(3, 10, 14, 0.12);
    --nav-brand-logo-size: clamp(40px, 2.6vw, 50px);
    --nav-brand-logo-max-width: 12vw;
    --nav-brand-logo-min-size: 32px;
    --nav-menu-gap: clamp(4px, 0.7vw, 12px);
    --nav-menu-padding: 2px 0 0;
    --nav-link-color: rgba(255, 255, 255, 0.86);
    --nav-link-color-hover: #ffffff;
    --nav-link-font-size: clamp(0.82rem, 0.74rem + 0.22vw, 0.92rem);
    --nav-link-letter-spacing: 0.06em;
    --nav-link-padding: 0.82em 1.02em;
    --nav-link-line-height: 1.1;
    --nav-link-hover-bg: rgba(127, 232, 219, 0.20);
    --nav-link-active-bg: rgba(127, 232, 219, 0.26);
    --nav-link-border-color: rgba(255, 255, 255, 0.1);
    --nav-link-transition: color 0.2s ease, background 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
    --nav-link-active-underline-width: 32px;
    --nav-link-active-underline-height: 3px;
    --nav-link-active-underline-bg: #7fe8db;
    --nav-link-active-underline-radius: 2px;
    --nav-link-active-underline-margin-top: 4px;
    --mobile-menu-btn-size: 48px;
    --mobile-menu-btn-color: #ffffff;
    --mobile-menu-btn-font-size: 2em;
    --mobile-menu-btn-bg: rgba(255, 255, 255, 0.08);
    --mobile-menu-btn-border-color: rgba(235, 246, 243, 0.14);
    --mobile-menu-btn-border-radius: 50%;
    --mobile-menu-btn-transition: color var(--transition-fast);
    --mobile-menu-btn-mobile-min-size: 56px;
    --mobile-menu-btn-mobile-padding: 0.5em;
    --mobile-menu-btn-mobile-margin-left: 2vw;
    --mobile-menu-btn-mobile-radius: 16px;
    --mobile-menu-btn-mobile-shadow: none;
    --mobile-menu-btn-mobile-bg-active: rgba(255, 255, 255, 0.12);
    --mobile-menu-btn-mobile-shadow-active: none;
    --menu-icon-size: 24px;
    --menu-icon-size-mobile: 22px;
    --menu-icon-filter-mobile: brightness(0) invert(1);
    --mobile-menu-bg: var(--glass-dark-bg-strong);
    --mobile-menu-bg-dark-active: #23272a;
    --mobile-menu-top: 64px;
    --mobile-menu-shadow: none;
    --mobile-menu-shadow-mobile: none;
    --mobile-menu-radius: 0 0 32px 32px;
    --mobile-menu-transition: max-height 0.35s cubic-bezier(.4,0,.2,1), opacity 0.25s, padding 0.2s;
    --mobile-menu-open-max-height: 480px;
    --mobile-menu-open-min-height: 100dvh;
    --mobile-menu-open-padding: 1.2em 0 1.6em;
    --mobile-menu-dark-padding: 10px 4px;
    --mobile-menu-dark-font-size: 0.97em;
    --mobile-menu-dark-max-width: 99vw;
    --mobile-nav-link-padding: 0.9em 2.3vw;
    --mobile-nav-link-color: rgba(255, 255, 255, 0.9);
    --mobile-nav-link-radius: 14px;
    --mobile-nav-link-margin: 0.2em 1vw 0.8em;
    --mobile-nav-link-font-size: clamp(0.98rem, 0.8rem + 0.54vw, 1.08rem);
    --mobile-nav-link-bg: rgba(255, 255, 255, 0.06);
    --mobile-nav-link-shadow: none;
    --mobile-nav-link-hover-color: #fff;
    --mobile-nav-link-hover-bg: #00a88b;
    --mobile-nav-link-hover-shadow: none;
    --mobile-nav-link-focus-shadow: none;
    --lang-switcher-gap: 8px;
    --lang-switcher-padding: 4px;
    --lang-switcher-bg: rgba(255, 255, 255, 0.08);
    --lang-switcher-border-color: rgba(235, 246, 243, 0.14);
    --lang-button-width: 40px;
    --lang-button-height: 34px;
    --lang-button-svg-width: 21px;
    --lang-button-svg-height: 14px;
    --lang-button-border-color: rgba(255, 255, 255, 0.1);
    --lang-button-bg: rgba(255, 255, 255, 0.08);
    --lang-button-color: #ffffff;
    --lang-button-letter-spacing: 0.04em;
    --lang-button-transition: background 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
    --lang-button-hover-bg: rgba(255, 255, 255, 0.12);
    --lang-button-hover-border-color: rgba(255, 255, 255, 0.2);
    --lang-button-active-bg: rgba(127, 232, 219, 0.26);
    --lang-button-active-border-color: rgba(127, 232, 219, 0.42);
    position: fixed;
    top: 0;
    width: 100vw;
    left: 0;
    right: 0;
    z-index: var(--navbar-z-index) !important;
    isolation: isolate;
    transform: translateZ(0);
    align-items: center;
    gap: var(--navbar-gap);
    padding: var(--navbar-padding);
    background: var(--navbar-bg);
    border-bottom: 1px solid var(--navbar-border-color);
    box-shadow: var(--navbar-shadow);
    backdrop-filter: blur(var(--navbar-backdrop-blur)) saturate(124%);
    -webkit-backdrop-filter: blur(var(--navbar-backdrop-blur)) saturate(124%);
    display: flex;
    justify-content: center;
    font-family: var(--font-ui-modern);
    transition: background 0.22s ease, border-color 0.22s ease, box-shadow 0.22s ease;
}

.navbar.navbar-scrolled {
    background: rgba(8, 18, 24, 0.86) !important;
    border-bottom-color: rgba(235, 246, 243, 0.16) !important;
    box-shadow: 0 18px 38px rgba(3, 10, 14, 0.22);
}

.navbar.navbar-scrolled .nav-brand,
.navbar.navbar-scrolled #langSwitcher,
.navbar.navbar-scrolled .mobile-menu-btn {
    background: rgba(255, 255, 255, 0.07) !important;
    border-color: rgba(235, 246, 243, 0.12) !important;
}

@media (min-width: 901px) {
    .navbar {
        justify-content: space-between;
    }

    .nav-brand {
        flex: 0 0 auto;
        margin-right: 2vw;
    }

    .nav-menu {
        flex: 1 1 auto;
        display: flex;
        --interaction-transform: translateZ(0);
        flex-wrap: nowrap;
        justify-content: center;
        align-items: center;
        gap: var(--nav-menu-gap);
        min-width: 0;
        width: auto;
        padding: var(--nav-menu-padding);
    }

    .mobile-menu-btn {
        display: none !important;
    }

    .nav-link {
        font-size: var(--nav-link-font-size);
        letter-spacing: var(--nav-link-letter-spacing);
        font-weight: 650;
        text-transform: none;
        transition: var(--nav-link-transition);
        border-radius: 999px;
        padding: var(--nav-link-padding);
        white-space: nowrap;
        line-height: var(--nav-link-line-height);
    }

    .nav-link:hover {
        background: var(--nav-link-hover-bg);
        color: var(--nav-link-color-hover);
    }

    #langSwitcher {
        flex: 0 0 auto;
        margin-left: auto;
    }
}

@media (min-width: 901px) and (max-width: 1280px) {
    .navbar {
        --navbar-gap: clamp(8px, 1vw, 12px);
        --navbar-padding: 10px clamp(10px, 1.5vw, 16px);
        --nav-brand-gap: 6px;
        --nav-brand-padding: 0.24em 0.5em;
        --nav-brand-logo-size: clamp(34px, 2vw, 40px);
        --nav-brand-logo-min-size: 30px;
        --nav-menu-gap: clamp(2px, 0.35vw, 6px);
        --nav-link-font-size: clamp(0.74rem, 0.7rem + 0.12vw, 0.82rem);
        --nav-link-letter-spacing: 0.03em;
        --nav-link-padding: 0.68em 0.72em;
        --lang-switcher-gap: 4px;
        --lang-switcher-padding: 3px;
        --lang-button-width: 34px;
        --lang-button-height: 30px;
        --lang-button-svg-width: 18px;
        --lang-button-svg-height: 12px;
    }

    .brand-text {
        font-size: clamp(0.76rem, 0.68rem + 0.18vw, 0.9rem);
        line-height: 0.98;
        padding-left: 5px;
        padding-right: 4px;
    }

    .brand-text .brand-sub {
        margin-top: 0.24em;
        letter-spacing: 0.12em;
    }
}

.nav-brand {
    display: flex;
    align-items: center;
    gap: var(--nav-brand-gap);
    min-width: 0;
    padding: var(--nav-brand-padding);
    flex-shrink: 1;
    background: var(--nav-brand-bg);
    border: 1px solid var(--nav-brand-border-color);
    border-radius: 999px;
    box-shadow: var(--nav-brand-shadow);
}

.nav-brand a {
    display: flex;
    align-items: center;
    line-height: 0;
}

.nav-brand img {
    width: var(--nav-brand-logo-size);
    height: var(--nav-brand-logo-size);
    object-fit: contain;
    display: block;
    transition: width 0.2s, height 0.2s;
    max-width: var(--nav-brand-logo-max-width);
    min-width: var(--nav-brand-logo-min-size);
    min-height: var(--nav-brand-logo-min-size);
}

.nav-link {
    color: var(--nav-link-color);
    font-family: var(--font-ui-modern);
    text-decoration: none;
    font-weight: 800;
    position: relative;
    transition: color var(--transition-fast), background 0.2s;
    box-shadow: none;
    background: none;
    text-transform: uppercase;
    border: 1px solid transparent;
}

.nav-link:hover {
    color: var(--nav-link-color-hover);
    background: var(--nav-link-hover-bg);
    border-color: var(--nav-link-border-color);
    box-shadow: 0 10px 24px rgba(3, 10, 14, 0.14);
    transform: translateY(-1px);
}

.nav-link.active {
    color: var(--nav-link-color-hover);
    font-weight: 800;
    border-bottom: none;
    background: var(--nav-link-active-bg);
    border-color: var(--nav-link-border-color);
    box-shadow: 0 10px 24px rgba(3, 10, 14, 0.12);
}

.nav-link.active::after {
    content: none;
}

.mobile-menu-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: var(--mobile-menu-btn-size);
    height: var(--mobile-menu-btn-size);
    color: var(--mobile-menu-btn-color);
    font-size: var(--mobile-menu-btn-font-size);
    cursor: pointer;
    transition: var(--mobile-menu-btn-transition);
    border-radius: var(--mobile-menu-btn-border-radius);
    background: var(--mobile-menu-btn-bg);
    border: 1px solid var(--mobile-menu-btn-border-color);
    position: relative;
    z-index: 6;
    pointer-events: auto;
    touch-action: manipulation;
}

.menu-icon {
    width: var(--menu-icon-size);
    height: var(--menu-icon-size);
    display: block;
    object-fit: contain;
    transition: width 0.2s, height 0.2s;
}

@media (max-width: 600px) {
    .menu-icon {
        width: var(--menu-icon-size-mobile);
        height: var(--menu-icon-size-mobile);
    }
}

.mobile-menu {
    display: block;
    background: var(--mobile-menu-bg);
    border-top: none;
    position: absolute;
    top: var(--mobile-menu-top);
    left: 0;
    width: 100vw;
    box-shadow: var(--mobile-menu-shadow);
    border-radius: var(--mobile-menu-radius);
    transition: var(--mobile-menu-transition);
    max-height: 0;
    min-height: 0;
    overflow-y: hidden;
    opacity: 0;
    z-index: 2;
    padding-bottom: 0;
    pointer-events: none;
    animation: none;
}

@keyframes menuDropFadeIn {
    0% { opacity: 0; transform: translateY(-40px) scale(0.98); }
    100% { opacity: 1; transform: translateY(0) scale(1); }
}

.mobile-menu.active {
    display: block;
    max-height: var(--mobile-menu-open-max-height);
    min-height: var(--mobile-menu-open-min-height);
    opacity: 1;
    padding: var(--mobile-menu-open-padding);
    pointer-events: auto;
    overflow-y: auto;
    animation: menuDropFadeIn 0.4s cubic-bezier(.77,0,.18,1);
}

.mobile-nav-link {
    display: block;
    padding: var(--mobile-nav-link-padding);
    color: var(--mobile-nav-link-color);
    font-family: var(--font-ui-modern);
    text-decoration: none;
    font-weight: 800;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    border-radius: var(--mobile-nav-link-radius);
    margin: var(--mobile-nav-link-margin);
    font-size: var(--mobile-nav-link-font-size);
    position: relative;
    outline: none;
    transition: color 0.18s, background 0.18s, box-shadow 0.18s;
    box-shadow: var(--mobile-nav-link-shadow);
    background: var(--mobile-nav-link-bg);
}

#langSwitcher {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: var(--lang-switcher-gap) !important;
    margin-left: auto;
    padding: var(--lang-switcher-padding);
    border-radius: 999px;
    background: var(--lang-switcher-bg);
    border: 1px solid var(--lang-switcher-border-color);
    position: relative;
    z-index: 3;
}

.lang-switch-button {
    font-family: var(--font-ui-modern);
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: var(--lang-button-width);
    height: var(--lang-button-height);
    padding: 0 !important;
    border-radius: 999px !important;
    border: 1px solid var(--lang-button-border-color) !important;
    background: var(--lang-button-bg) !important;
    color: var(--lang-button-color) !important;
    box-shadow: none !important;
    letter-spacing: var(--lang-button-letter-spacing);
    transition: var(--lang-button-transition) !important;
}

.lang-switch-button:hover,
.lang-switch-button:focus-visible {
    background: var(--lang-button-hover-bg) !important;
    border-color: var(--lang-button-hover-border-color) !important;
    transform: translateY(-1px);
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.18);
    outline: none;
}

.lang-switch-button svg {
    display: block;
    width: var(--lang-button-svg-width);
    height: var(--lang-button-svg-height);
    flex: 0 0 auto;
}

html[lang="de"] #langDe,
html[lang="en"] #langEn,
html[lang="it"] #langIt {
    background: var(--lang-button-active-bg) !important;
    border-color: var(--lang-button-active-border-color) !important;
}

.mobile-nav-link:hover {
    color: var(--mobile-nav-link-hover-color);
    background: var(--mobile-nav-link-hover-bg);
    box-shadow: var(--mobile-nav-link-hover-shadow);
}

.mobile-nav-link:focus {
    background: var(--mobile-nav-link-hover-bg);
    color: var(--mobile-nav-link-hover-color);
    border-radius: var(--mobile-nav-link-radius);
    box-shadow: var(--mobile-nav-link-focus-shadow);
}

@media (max-width: 900px) {
    .nav-menu {
        display: none !important;
    }

    .nav-brand {
        transform: translateY(2px);
    }

    .mobile-menu-btn {
        display: flex !important;
        min-width: var(--mobile-menu-btn-mobile-min-size);
        min-height: var(--mobile-menu-btn-mobile-min-size);
        padding: var(--mobile-menu-btn-mobile-padding);
        margin-left: var(--mobile-menu-btn-mobile-margin-left);
        background: var(--mobile-menu-btn-bg);
        border-radius: var(--mobile-menu-btn-mobile-radius);
        box-shadow: var(--mobile-menu-btn-mobile-shadow);
        align-items: center;
        justify-content: center;
        border: 1px solid var(--mobile-menu-btn-border-color);
        cursor: pointer;
        transition: background 0.2s, box-shadow 0.2s;
    }

    .mobile-menu-btn:active {
        background: var(--mobile-menu-btn-mobile-bg-active);
        box-shadow: var(--mobile-menu-btn-mobile-shadow-active);
    }

    .mobile-menu {
        border-top: 1px solid var(--navbar-border-color);
        box-shadow: var(--mobile-menu-shadow-mobile);
        overflow: hidden;
    }
}

@media (max-width: 900px) {
    html {
        --mobile-navbar-offset: 54px;
    }

    .navbar {
        --navbar-gap: 8px;
        --navbar-padding: 8px 10px;
        --nav-brand-gap: 6px;
        --nav-brand-padding: 0.24em 0.56em;
        --nav-brand-logo-size: 36px;
        --nav-brand-logo-min-size: 30px;
        --mobile-menu-btn-size: 42px;
        --mobile-menu-btn-mobile-min-size: 44px;
        --mobile-menu-btn-mobile-padding: 0.35em;
        --mobile-menu-btn-mobile-margin-left: 0;
        --mobile-menu-btn-mobile-radius: 14px;
        --mobile-menu-btn-mobile-shadow: 0 8px 20px rgba(0, 0, 0, 0.14);
        --menu-icon-size-mobile: 20px;
        --lang-switcher-gap: 3px;
        --lang-switcher-padding: 3px 4px;
        --lang-button-width: 32px;
        --lang-button-height: 26px;
        --lang-button-svg-width: 18px;
        --lang-button-svg-height: 12px;
        --mobile-menu-top: 56px;
        --mobile-menu-open-padding: 0.95em 0 1.25em;
        display: grid;
        grid-template-columns: auto minmax(0, 1fr) auto;
        align-items: center;
    }

    .mobile-menu-btn {
        grid-column: 1;
        justify-self: start;
    }

    .nav-brand {
        grid-column: 2;
        flex: 1 1 auto;
        min-width: 0;
        max-width: none;
        margin-right: 0;
        justify-self: stretch;
        position: relative;
        z-index: 1;
        pointer-events: none;
    }

    .nav-brand a {
        pointer-events: auto;
    }

    #langSwitcher {
        grid-column: 3;
        justify-self: end;
        flex: 0 0 auto;
        min-width: 0;
        overflow: visible;
    }

    .brand-text {
        font-size: clamp(0.74rem, 0.66rem + 0.38vw, 0.9rem);
        line-height: 0.98;
        padding-left: 5px;
        padding-right: 0;
    }

    .brand-text .brand-sub {
        margin-top: 0.24em;
        letter-spacing: 0.11em;
    }
}

@media (max-width: 600px) {
    html {
        --mobile-navbar-offset: 50px;
    }

    .navbar {
        --navbar-gap: 6px;
        --navbar-padding: 6px 8px;
        --nav-brand-gap: 5px;
        --nav-brand-padding: 0.2em 0.5em;
        --nav-brand-logo-size: 32px;
        --nav-brand-logo-min-size: 28px;
        --mobile-menu-btn-size: 40px;
        --mobile-menu-btn-mobile-min-size: 40px;
        --mobile-menu-btn-mobile-padding: 0.28em;
        --mobile-menu-btn-mobile-radius: 12px;
        --mobile-menu-btn-mobile-shadow: 0 6px 16px rgba(0, 0, 0, 0.14);
        --menu-icon-size-mobile: 18px;
        --lang-switcher-gap: 2px;
        --lang-switcher-padding: 2px 3px;
        --lang-button-width: 29px;
        --lang-button-height: 24px;
        --lang-button-svg-width: 17px;
        --lang-button-svg-height: 11px;
        --mobile-menu-top: 50px;
    }

    .nav-brand {
        min-width: 0;
    }

    .brand-text {
        font-size: clamp(0.66rem, 0.6rem + 0.44vw, 0.8rem);
        line-height: 0.96;
        padding-left: 3px;
        padding-right: 0;
    }

    .brand-text .brand-sub {
        font-size: 0.62em;
        letter-spacing: 0.1em;
        margin-top: 0.2em;
    }
}
/* Rückblick/Masterclass nutzt das Charity-Layout mit wenigen Abweichungen. */
.rueckblick-flex {
    --review-masterclass-image-shadow: 0 4px 18px rgba(0, 0, 0, 0.12);
    --masterclass-media-basis: 48%;
    --masterclass-media-max-width: min(48vw, 760px);
    --masterclass-credit-margin-top: 8px;
    --masterclass-credit-font-size: 0.98em;
    --masterclass-credit-line-height: 1.4;
    --masterclass-credit-color: #222;
    flex-wrap: wrap;
}

.charity-projects-section[id^="review-"] .rueckblick-flex {
    --review-masterclass-image-shadow: none;
}

.event-card .event-social-button--instagram,
.charity-projects-section[id^="review-"] .event-social-button--instagram {
    display: none;
}

.rueckblick-flex img {
    box-shadow: var(--review-masterclass-image-shadow);
}

.masterclass-flex .masterclass-flex__media {
    flex-basis: var(--masterclass-media-basis);
    max-width: var(--masterclass-media-max-width);
}

.masterclass-flex .masterclass-flex__image {
    width: 100%;
    max-width: 100%;
    height: auto;
}

.masterclass-flex .masterclass-flex__credit {
    margin-top: var(--masterclass-credit-margin-top);
    font-size: var(--masterclass-credit-font-size);
    line-height: var(--masterclass-credit-line-height);
    color: var(--masterclass-credit-color);
    text-align: center;
    font-style: italic;
}
/* Unified responsive spacing for all review cards */
@media (max-width: 1200px) {
    .charity-projects-section[id^="review-"] {
        --review-section-padding: 24px 0 18px;
        --review-container-padding: 18px 8vw 14px;
        --review-container-radius: 20px;
        --review-container-margin-bottom: 10px;
        --review-flex-gap: 20px;
        padding: var(--review-section-padding);
    }

    .charity-projects-section[id^="review-"] .charity-projects-container {
        padding: var(--review-container-padding);
        border-radius: var(--review-container-radius);
        margin-bottom: var(--review-container-margin-bottom);
        box-sizing: border-box;
    }

    .charity-projects-section[id^="review-"] .charity-flex-row {
        flex-direction: column;
        align-items: stretch;
        gap: var(--review-flex-gap);
    }

    .charity-projects-section[id^="review-"] .charity-flex-left,
    .charity-projects-section[id^="review-"] .charity-flex-right,
    .charity-projects-section[id^="review-"] .charity-flex-row > .gruppenbild-container {
        max-width: 100% !important;
        flex: 1 1 100%;
        width: 100% !important;
        min-width: 0;
        box-sizing: border-box;
    }

    .charity-projects-section[id^="review-"] .charity-flex-left,
    .charity-projects-section[id^="review-"] .charity-flex-right {
        padding: 0 !important;
    }

    .charity-projects-section[id^="review-"] .charity-flex-row > .gruppenbild-container {
        padding: var(--review-media-frame-padding) !important;
    }

    .charity-projects-section[id^="review-"] .charity-flex-right,
    .charity-projects-section[id^="review-"] .charity-flex-row > .gruppenbild-container {
        margin: 0 auto !important;
    }

    .charity-projects-section[id^="review-"] .charity-title,
    .charity-projects-section[id^="review-"] .charity-meta,
    .charity-projects-section[id^="review-"] .charity-description {
        width: 100%;
        padding-left: 0 !important;
        padding-right: 0 !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        box-sizing: border-box;
    }

    .charity-projects-section[id^="review-"] .charity-flex-row > .gruppenbild-container img,
    .charity-projects-section[id^="review-"] .charity-flex-right img {
        margin: 0 auto !important;
    }

    #review-masterclass-florian-meierott .masterclass-flex {
        min-height: 0;
    }

    #review-masterclass-florian-meierott .masterclass-flex .charity-flex-left,
    #review-masterclass-florian-meierott .masterclass-flex .masterclass-flex__media {
        flex: 0 0 auto !important;
    }
}

@media (max-width: 900px) {
    .masterclass-flex {
        --masterclass-image-width: min(100%, 560px);
    }

    .masterclass-flex .masterclass-flex__image {
        width: var(--masterclass-image-width);
    }

    .charity-projects-section[id^="review-"] {
        --review-section-padding: 20px 0 16px;
        --review-container-width: min(calc(100vw - 32px), 720px);
        --review-container-padding: 22px 22px 18px;
        --review-flex-gap: 16px;
        --review-media-mobile-margin-top: 14px;
        --review-title-size: clamp(1.68rem, 4.6vw, 1.98rem);
        padding: var(--review-section-padding);
    }

    .charity-projects-section[id^="review-"] .charity-projects-container {
        width: var(--review-container-width);
        padding: var(--review-container-padding);
    }

    .charity-projects-section[id^="review-"] .charity-flex-row {
        gap: var(--review-flex-gap);
    }

    .charity-projects-section[id^="review-"] .charity-meta {
        max-width: min(100%, 34rem);
    }

    .charity-projects-section[id^="review-"] .review-media-caption {
        font-size: 0.86rem !important;
        line-height: 1.42;
        padding: 0.42em 0.82em;
    }

    .charity-projects-section[id^="review-"] .charity-flex-row > .gruppenbild-container {
        margin-top: var(--review-media-mobile-margin-top) !important;
    }
}

@media (max-width: 600px) {
    .masterclass-flex {
        --masterclass-image-width: 100%;
        gap: 12px;
        align-items: stretch;
    }

    .masterclass-flex .masterclass-flex__image {
        width: var(--masterclass-image-width);
        margin: 0;
    }

    .charity-projects-section[id^="review-"] {
        --review-section-padding: 18px 0 10px;
        --review-container-width: calc(100vw - 24px);
        --review-container-padding: 18px 16px 14px;
        --review-container-radius: 18px;
        --review-container-margin-bottom: 8px;
        --review-flex-gap: 12px;
        --review-title-margin-bottom: 8px;
        --review-meta-margin-bottom: 10px;
        --review-description-margin-bottom: 0;
        --review-media-mobile-margin-top: 10px;
        --review-title-size: clamp(1.48rem, 5.4vw, 1.82rem);
        padding: var(--review-section-padding);
    }

    .charity-projects-section[id^="review-"] .charity-projects-container {
        width: var(--review-container-width);
        padding: var(--review-container-padding);
        border-radius: var(--review-container-radius);
        margin-bottom: var(--review-container-margin-bottom);
    }

    .charity-projects-section[id^="review-"] .charity-flex-row {
        gap: var(--review-flex-gap);
    }

    .charity-projects-section[id^="review-"] .charity-title {
        margin-bottom: var(--review-title-margin-bottom) !important;
        line-height: 1.1;
        letter-spacing: -0.014em;
        text-wrap: balance;
    }

    .charity-projects-section[id^="review-"] .charity-meta {
        margin-bottom: var(--review-meta-margin-bottom) !important;
        display: block;
        width: 100%;
        max-width: 100%;
        padding: 0.78em 1.05em;
        border-radius: 16px;
        font-size: clamp(0.92rem, 3.25vw, 0.99rem) !important;
        line-height: 1.42;
        letter-spacing: 0.01em;
        box-shadow: none;
        text-wrap: pretty;
        text-align: left;
    }

    .charity-projects-section[id^="review-"] .charity-description {
        margin-bottom: var(--review-description-margin-bottom) !important;
        font-size: clamp(0.95rem, 3.15vw, 1rem) !important;
        line-height: 1.58;
        text-align: justify !important;
        text-justify: inter-word;
        text-wrap: pretty;
    }

    .charity-projects-section[id^="review-"] .event-social-actions.review-social-actions {
        gap: 10px;
        margin-top: 4px;
        margin-bottom: 12px;
        align-items: center;
    }

    .charity-projects-section[id^="review-"] .event-social-actions.review-social-actions .event-social-button {
        width: 50px;
        height: 50px;
        min-height: 50px;
        aspect-ratio: 1 / 1;
        border-radius: 999px;
        padding: 0;
        flex: 0 0 50px;
    }

    .charity-projects-section[id^="review-"] .event-social-actions.review-social-actions .event-social-button svg {
        width: 24px;
        height: 24px;
        flex: 0 0 24px;
    }

    .charity-projects-section[id^="review-"] .review-media-caption {
        width: 100%;
        font-size: 0.82rem !important;
        line-height: 1.44;
        padding: 0.52em 0.74em;
        border-radius: 14px;
        text-align: center !important;
    }

    .charity-projects-section[id^="review-"] .charity-flex-row > .gruppenbild-container {
        padding: 10px !important;
    }

    .charity-projects-section[id^="review-"] .charity-flex-row > .gruppenbild-container img,
    .charity-projects-section[id^="review-"] .charity-flex-right img {
        max-width: 96% !important;
        border-radius: 20px !important;
    }

    .charity-projects-section[id^="review-"] .charity-flex-row > .gruppenbild-container {
        margin-top: var(--review-media-mobile-margin-top) !important;
    }
}

@media (min-width: 1201px) {
    .charity-projects-section[id^="review-"] {
        --review-media-desktop-offset: 44px;
    }

    .charity-projects-section[id^="review-"] .charity-flex-row > .gruppenbild-container:not(.review-media-block) {
        margin-top: var(--review-media-desktop-offset) !important;
    }

    #review-masterclass-florian-meierott {
        --review-masterclass-media-margin-top-desktop: 42px;
    }

    #review-masterclass-florian-meierott .masterclass-flex .masterclass-flex__media {
        margin-top: calc(var(--review-masterclass-media-margin-top-desktop) + var(--review-media-desktop-offset, 0px)) !important;
    }

    #review-wir-musizieren-gemeinsam-2025 {
        --review-wir-musizieren-media-margin-top-desktop: 168px;
    }

    #review-wir-musizieren-gemeinsam-2025 .charity-flex-row > .gruppenbild-container {
        margin-top: calc(var(--review-wir-musizieren-media-margin-top-desktop) + var(--review-media-desktop-offset, 0px)) !important;
    }
}

/* Specific sizing for Nikolausfeier image */
#review-nikolausfeier-2025 {
    --review-nikolaus-media-width: min(39%, 430px);
    --review-nikolaus-media-flex: 0 0 min(39%, 430px);
    --review-nikolaus-media-margin-top: 28px;
    --review-nikolaus-image-max-width: min(78%, 420px);
    --review-nikolaus-image-max-height: 390px;
    --review-nikolaus-image-margin-bottom: 10px;
    --review-nikolaus-caption-font-size: 0.92em;
}

#review-nikolausfeier-2025 .charity-flex-row > .gruppenbild-container {
    width: var(--review-nikolaus-media-width) !important;
    flex: var(--review-nikolaus-media-flex) !important;
    margin-top: calc(var(--review-nikolaus-media-margin-top) + var(--review-media-desktop-offset, 0px)) !important;
    align-self: flex-start;
}

#review-nikolausfeier-2025 .gruppenbild-img-nikolaus {
    max-width: var(--review-nikolaus-image-max-width) !important;
    max-height: var(--review-nikolaus-image-max-height) !important;
    width: auto !important;
    height: auto !important;
    object-fit: contain !important;
    display: block !important;
    margin: 0 auto var(--review-nikolaus-image-margin-bottom) !important;
    box-shadow: none !important;
    background: transparent !important;
    border: 0 !important;
    cursor: default !important;
    pointer-events: none;
}

#review-nikolausfeier-2025 .charity-flex-row > .gruppenbild-container > div {
    font-size: var(--review-nikolaus-caption-font-size) !important;
}

@media (max-width: 1200px) {
    #review-nikolausfeier-2025 {
        --review-nikolaus-media-width: min(66%, 420px);
        --review-nikolaus-media-flex: 1 1 auto;
        --review-nikolaus-media-margin-top: 18px;
    }
}

@media (max-width: 900px) {
    #review-nikolausfeier-2025 {
        --review-nikolaus-media-width: min(80%, 360px);
        --review-nikolaus-image-max-width: min(86%, 360px);
        --review-nikolaus-image-max-height: 320px;
    }
}

@media (max-width: 600px) {
    #review-nikolausfeier-2025 {
        --review-nikolaus-media-width: min(100%, 300px);
        --review-nikolaus-media-margin-top: 12px;
        --review-nikolaus-image-max-width: min(100%, 300px);
        --review-nikolaus-image-max-height: 280px;
    }
}

/* Einheitlicher Schriftschnitt fuer die gesamte Seite */
.contact-info-title,
.music-family-title,
.music-family-group-title,
.music-family-contact-title,
.about-me-modern-title,
.musik-bruecken-title,
.musikalisches-repertoire-title,
.charity-title,
.timeline-title,
.timeline-item-title,
.event-title,
.event-headline,
.image-caption-card-h1,
.site-footer__title,
.brand-text .brand-main,
#heroGalleryCurrent,
#heroGalleryTotal,
.fadein-text {
    font-weight: var(--font-weight-heading) !important;
}

.contact-info-intro,
.contact-info-card-text,
.contact-info-card-link,
.music-family-desc,
.music-family-group-details li,
.music-family-contact-link,
.about-me-bio-text,
.musik-bruecken-text,
.musikalisches-repertoire-intro,
.musikalisches-repertoire-list,
.musikalisches-repertoire-list li,
.charity-description,
.timeline-intro,
.timeline-item-text,
.event-description,
.event-location,
.review-media-caption,
.site-footer__meta-line {
    font-weight: var(--font-weight-body) !important;
}

.contact-info-intro,
.contact-info-card-text,
.contact-info-card-link,
.music-family-group-details li,
.about-me-bio-text,
.musikalisches-repertoire-intro,
.musikalisches-repertoire-list li,
.charity-card-main-text,
.charity-list-item,
.charity-description,
.timeline-intro,
.timeline-item-text,
.event-description,
.review-media-caption,
.site-footer__meta-line {
    text-align: justify !important;
    text-justify: inter-word;
    hyphens: auto !important;
    -webkit-hyphens: auto !important;
    -ms-hyphens: auto !important;
    overflow-wrap: break-word !important;
}

.nav-link,
.mobile-nav-link,
.lang-switch-button,
.contact-info-card-title,
.contact-info-subtitle,
.music-family-contact-name,
.about-me-modern-subtitle,
.charity-meta,
.timeline-eyebrow,
.event-badge,
.event-date,
.event-time,
.site-footer__link,
.brand-text .brand-sub {
    font-weight: var(--font-weight-label) !important;
}

html body *,
html body *::before,
html body *::after {
    --interaction-transform: initial;
    box-shadow: none !important;
    text-shadow: none !important;
    transition: none !important;
    animation: none !important;
}

html body *:hover,
html body *:focus-visible,
html body *:active,
html body *:hover::before,
html body *:hover::after,
html body *:focus-visible::before,
html body *:focus-visible::after,
html body *:active::before,
html body *:active::after {
    transform: var(--interaction-transform, none) !important;
}

html body .event-social-button {
    box-shadow: var(--event-social-button-shadow) !important;
    transition: var(--event-social-button-transition) !important;
}

html body .event-social-button:hover,
html body .event-social-button:focus-visible,
html body .event-social-button:active {
    box-shadow: var(--event-social-button-shadow-hover) !important;
}


