:root {
    --card: #111;
    --gap: clamp(10px, 3vw, 30px);
    --intro-w: min(62vw, 760px);
    --card-w: min(72vw, 680px);
    --card-h: clamp(540px, 78vh, 900px);
    --radius: 18px;
    --intro-spine-offset: 36px;
    --lead: clamp(180px, 20vw, 400px);
    --card-content-offset: clamp(16px, 4vw, 54px);
    --reveal-tail: 100vw;
    --arrow-nudge: -0.05em;
}

.join-hero {
    min-height: 100svh;
    display: grid;
    place-items: center;
    position: relative;
    text-align: left;
    margin: 0;
    padding: 0;
}

.join-inner {
    max-width: clamp(320px, 90vw, 720px);
}

* {
    box-sizing: border-box
}

html, body {
    overflow-x: visible;
    height: auto;
}

body {
    margin: 0;
}

.reveal {
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center; /* vertikal & horizontal mittig */
    pointer-events: none;
    z-index: 0; /* unter dem Track / Blatt */
}


.reveal__inner {
    font-size: clamp(28px, 8vw, 120px);
    font-weight: 800;
    text-align: center;
    line-height: 1.05;
}

    .reveal__inner .headline-xxl {
        display: block; /* macht max-width wirksam */
        max-width: 48ch; /* Zeilenmaß – nach Geschmack anpassen */
        margin-inline: auto; /* zentriert bleiben */
        text-wrap: balance; /* schönere Zeilenumbrüche (falls unterstützt) */
    }

.reasons {
    position: relative;
    height: 100vh;
    margin: 0;
    overflow: hidden;
    background: white;
    clip-path: inset(0 0 100% 0);
    will-change: clip-path;
}

@supports not (clip-path: inset(0 0 100% 0)) {
    .reasons {
        clip-path: none;
    }
}

.reasons__track {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    gap: var(--gap);
    padding: 0 0 0 var(--gap);
    z-index: 2;
    width: auto;
}

    .reasons__track::before {
        content: "";
        position: absolute;
        inset: 0 auto 0 0;
        width: var(--sheet-width, 100vw);
        background: #fff;
        z-index: 0;
        pointer-events: none;
    }

.lead {
    flex: 0 0 var(--lead);
    width: var(--lead);
    height: 1px;
}

.intro {
    flex: 0 0 var(--intro-w);
    align-self: stretch;
    display: flex;
    align-items: center;
    position: relative;
    margin-right: calc(var(--gap) * -6);
    transform: translateX(calc(var(--gap) * -0.5));
}

.intro__inner {
    position: relative;
    width: 100%;
    z-index: 2
}

.kicker {
    display: flex;
    align-items: flex-start;
    gap: clamp(12px, 2vw, 24px);
}

.intro-text {
    flex: 0 0 auto;
    max-inline-size: clamp(180px, 30vw, 400px);
    max-width: clamp(180px, 24vw, 300px);
}

.big5 {
    font-size: clamp(112px,26vw,280px);
    line-height: .8;
    font-weight: 800;
}

.kicker > div:last-child {
    inline-size: clamp(180px, 30vw, 400px);
    text-wrap: balance;
    hyphens: auto;
}

.intro__spine {
    position: absolute;
    left: -120vw;
    right: calc(var(--gap) * -1);
    height: 2px;
    background: #111;
    top: calc(100% + var(--intro-spine-offset));
    z-index: 1;
    display: none;
}

.card {
    display: flex;
    flex-direction: column;
    flex: 0 0 auto;
    height: var(--card-h);
    aspect-ratio: 898 / 1123;
    background: var(--card);
    border-radius: var(--radius);
    position: relative;
    padding: clamp(20px,3vw,40px);
    overflow: hidden;
    z-index: 1;
}

    .card::before {
        content: "";
        position: absolute;
        inset: 0;
        background-repeat: no-repeat;
        background-position: center;
        background-size: cover;
        background-image: var(--bg-svg);
        opacity: .95;
        z-index: 1;
    }

.spine-global {
    position: absolute;
    left: 0;
    height: 2px;
    background: #111;
    z-index: 1;
}

.card--1 {
    --bg-svg: url('../../pictures/join/01_join_gehalt.svg');
}

.card--2 {
    --bg-svg: url('../../pictures/join/02_join_weiterbildung.svg');
}

.card--3 {
    --bg-svg: url('../../pictures/join/03_join_flexibel.svg');
}

.card--4 {
    --bg-svg: url('../../pictures/join/04_join_ehrlich.svg');
}

.card--5 {
    --bg-svg: url('../../pictures/join/05_join_benefits.svg');
}

.card__content {
    margin-left: var(--card-content-offset);
    padding-block: var(--card-content-vpad, clamp(12px, 3vh, 48px));
    max-width: 44ch;
    position: relative;
    z-index: 2
}

.card:nth-of-type(odd) .card__content {
    margin-top: clamp(8px, 5vh, 120px);
    margin-bottom: auto;
}

.card:nth-of-type(even) .card__content {
    margin-top: auto;
    margin-bottom: clamp(8px, 5vh, 120px);
}

.tail {
    flex: 0 0 auto;
    width: auto;
    height: 1px;
}

.num {
    position: absolute;
    right: clamp(14px,2vw,24px);
    bottom: clamp(14px,2vw,24px);
    font-size: clamp(18px,2vw,24px);
    opacity: .9;
    z-index: 2
}

.join-next {
    background: white;
    display: grid;
    place-items: center;
    position: relative;
    text-align: left;
    margin: 0;
    padding: 0;
}

.jn-inner {
    max-width: clamp(460px, 94vw, 880px);
}

/* Grosse Links ------------------------------------------------------------------------ */

:root {
    --ov-max: 880px;
    --ov-hpad: clamp(16px, 2vw, 28px);
    --ov-head-pad: clamp(24px, 2.6vw, 36px);
    --ov-vpad: clamp(16px, 2vh, 32px);
}

.jobs_list {
    list-style: none;
    padding-left: 0;
    display: grid;
    grid-template-columns: 1fr;
    gap: clamp(18px, 2.5vw, 32px);
    margin-block-start: clamp(62px, 10vw, 112px);
    margin-block-end: clamp(76px, 18vw, 200px);
    justify-items: stretch;
    text-align: left;
}

.jobs_trigger {
    font-family: 'Roobert';
    background: transparent;
    border: 0;
    box-shadow: none;
    -webkit-appearance: none;
    appearance: none;
    cursor: pointer;
    display: inline-block;
    font-size: clamp(2.5rem, 5vw, 4rem);
    font-weight: 700;
    line-height: 1.12;
    text-wrap: normal;
    text-decoration: none;
    color: var(--theim-black);
    transition: color .3s ease;
    position: relative;
    hyphens: auto;
    -webkit-hyphens: auto;
    width: 100%; /* NEU: füllt die Spalte */
    text-align: left; /* falls geerbt wurde */
    padding-inline-end: 1.4em; /* Platz für den Pfeil rechts */
    padding-right: 1.1ch;
    overflow-wrap: normal;
    word-break: normal;
}

    .jobs_trigger:hover {
        color: var(--theim-red);
        text-decoration: none;
    }

    .jobs_trigger::after {
        content: "→";
        display: inline-block;
        vertical-align: baseline;
        width: 1.1ch; /* Breite dauerhaft reservieren */
        margin-left: .25ch;
        opacity: 0;
        transform: translateY(var(--arrow-nudge, .06em)) translateX(-.25em);
        transition: opacity .2s ease, transform .2s ease;
        pointer-events: none;
    }

    .jobs_trigger:hover::after,
    .jobs_trigger:focus-visible::after {
        opacity: 1; /* nur Sichtbarkeit/Slide animieren */
        transform: translateY(var(--arrow-nudge, .06em)) translateX(0);
    }

.overlay {
    position: fixed;
    inset: 0;
    z-index: 12000;
    opacity: 1;
    visibility: hidden;
    pointer-events: none;
}

    .overlay.is-open {
        visibility: visible;
        pointer-events: auto;
    }

.overlay__panel {
    position: absolute;
    inset: 0;
    width: 100vw;
    height: 100vh;
    background: var(--theim-black);
    transform: translateX(100%);
    overflow: auto;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
    padding: var(--ov-vpad) var(--ov-hpad);
    will-change: transform;
}

.overlay__inner {
    max-width: var(--ov-max);
    margin-inline: auto;
}

.overlay__header,
.overlay__content {
    max-width: var(--ov-max);
    margin-inline: auto;
    text-align: left;
}

.overlay__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding-block: var(--ov-head-pad);
    padding-inline: 0;
    margin: 0;
}

.overlay__close--floating {
    position: absolute;
    top: 50px;
    right: 50px;
    width: 80px;
    height: 80px;
    padding: 0;
    background: transparent;
    border: 0;
    cursor: pointer;
    z-index: 1001;
    line-height: 0;
    transition: transform .2s ease;
}

    .overlay__close--floating img {
        display: block;
        width: 100%;
        height: 100%;
    }

    .overlay__close--floating:hover {
        transform: scale(1.1);
    }

    .overlay__close--floating:focus-visible {
        outline: 2px solid #111;
        outline-offset: 4px;
    }

.overlay__content {
    padding-block: clamp(16px,2vw,28px);
    padding-inline: 0;
}

    .overlay__content .cookie-btn {
        margin-top: clamp(26px, 3.5vh, 44px);
        margin-bottom: clamp(58px, 4.5vh, 92px);
    }

@media (prefers-reduced-motion: reduce) {
    .overlay, .overlay__panel {
        transition: none !important;
    }
}

.join-linklist {
    list-style: none;
    padding-left: 0;
    margin: clamp(12px, 2vh, 24px) 0;
    display: grid;
    gap: clamp(8px, 1.2vh, 12px);
}

    .join-linklist li {
        margin: 0;
        list-style: none;
    }

        .join-linklist li::marker {
            content: none;
        }

    .join-linklist a {
        display: block;
        font-size: clamp(1.125rem, 2vw, 1.5rem);
        font-weight: 700;
        text-decoration: none;
        color: currentColor;
        transition: color .25s ease;
        background-image: none;
        background-position: 0 100%;
        background-repeat: no-repeat;
        background-size: 0 2px;
    }

        .join-linklist a:hover,
        .join-linklist a:focus-visible {
            text-decoration: none;
            color: var(--theim-red);
            background-size: 100% 2px;
            outline: none;
        }

.overlay__panel .join-linklist {
    color: #fff;
}

.overlay__content .join-linklist,
.join-linklist {
    list-style: none;
    padding-left: 0;
}

.body--lock {
    overflow: hidden;
}

.overlay__content {
    --ov-gap: clamp(18px, 2.5vh, 28px);
    --ov-gap-lg: clamp(42px, 3.8vh, 54px);
}

    .overlay__content > * {
        margin: 0;
    }

        .overlay__content > * + * {
            margin-top: var(--ov-gap);
        }

    .overlay__content :is(h2, h3, h4) + * {
        margin-top: var(--ov-gap-lg);
    }

    .overlay__content :is(p, ul, ol, blockquote) + :is(h2, h3, h4) {
        margin-top: var(--ov-gap-lg);
    }

    .overlay__content p {
        max-width: 68ch;
    }

    .overlay__content > *:last-child {
        margin-bottom: 0;
    }

    .overlay__content ul.trainers-grid {
        padding-left: 0;
        margin-left: 0;
        list-style: none;
    }

        .overlay__content ul.trainers-grid > li {
            list-style: none;
        }

            .overlay__content ul.trainers-grid > li::marker {
                content: none;
            }

.visually-hidden {
    position: absolute !important;
    clip: rect(1px,1px,1px,1px);
    height: 1px;
    width: 1px;
    overflow: hidden;
    white-space: nowrap;
}

.trainers-grid {
    list-style: none;
    padding-left: 0;
    display: grid;
    gap: clamp(14px, 2vw, 24px);
    grid-template-columns: repeat(3, minmax(0,1fr));
    margin: clamp(10px, 2vh, 24px) 0;
}

    .trainers-grid > li {
        list-style: none;
    }

        .trainers-grid > li::marker {
            content: none;
        }

.trainer-card {
    position: relative;
    border-radius: 16px;
}

.trainers .portrait {
    width: 100%;
    aspect-ratio: 4 / 5;
    border: 0;
    border-radius: 16px;
    overflow: hidden;
    background: var(--theim-grey);
    position: relative;
}

    .trainers .portrait img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        display: block;
    }

.trainers .hover-veil {
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0;
    background: linear-gradient(to top, rgba(10,10,10,0.9), rgba(10,10,10,0));
    transition: opacity .25s ease;
}

.trainers .portrait img,
.trainers .hover-veil {
    border-radius: inherit;
}

.trainers .hover-info {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    padding: clamp(20px, 3.2vw, 36px) clamp(16px, 2.4vw, 28px);
    display: flex;
    flex-direction: column;
    gap: 2px;
    pointer-events: none;
    text-align: left;
}

    .trainers .hover-info .line {
        color: #fff;
        transform: translateY(20px);
        opacity: 0;
        display: block;
        transition: transform .28s ease, opacity .28s ease;
    }

        .trainers .hover-info .line.as-h2 {
            font-size: clamp(1.3rem, 2.2vw, 2.2rem);
            font-weight: 700;
            line-height: 1.2;
            margin: 0;
            color: #fff;
        }

        .trainers .hover-info .line.as-p {
            font-size: clamp(1rem, 1.1vw, 1.1rem);
            font-weight: 400;
            line-height: 1.3;
            margin-top: .75rem;
            color: #fff;
        }

.trainers .portrait:hover .hover-veil {
    opacity: 1;
}

.trainers .portrait:hover .hover-info .line {
    opacity: 1;
    transform: translateY(0);
}

    .trainers .portrait:hover .hover-info .line.first {
        transition-delay: .02s;
    }

    .trainers .portrait:hover .hover-info .line.last {
        transition-delay: .08s;
    }

    .trainers .portrait:hover .hover-info .line.role {
        transition-delay: .14s;
    }

#ov5-title {
    hyphens: auto;
    -webkit-hyphens: auto; /* iOS/Safari */
    overflow-wrap: break-word; /* Fallback */
    word-break: normal;
}

/* Kalender -----------------------------------------------------------------------------------------*/

.stage.join-process {
    min-height: 100svh;
    width: min(var(--maxw, 1200px), 100% - 2rem);
    margin-inline: auto;
    display: grid;
    grid-template-columns: minmax(280px, 520px) minmax(320px, 1fr);
    gap: clamp(32px, 6vw, 72px);
    place-items: center;
    padding-block: clamp(48px, 10vh, 96px);
}

.stage {
    width: 100%;
    max-width: var(--maxw);
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: clamp(32px, 6vw, 72px);
    align-items: center;
}

.calendar-wrap {
    position: relative;
    display: grid;
    grid-template-columns: auto minmax(280px, 520px) auto;
    align-items: center;
    gap: 16px;
}

.calendar {
    position: relative;
    width: 100%;
    max-width: 620px;
    min-width: 360px;
    aspect-ratio: 4 / 5;
    border: none;
    border-radius: 0;
    background: none;
    overflow: hidden;
}

#sheetStack {
    position: absolute;
    inset: 0;
}

.calendar:focus-visible {
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--brand) 60%, transparent);
}

.calendar::before,
.calendar::after {
    content: none !important;
}

.sheet {
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    will-change: transform, opacity, filter;
    z-index: 1;
    background: transparent;
    border-radius: 0;
}

    .sheet.is-current {
        z-index: 2;
    }

    .sheet:not(.is-current) .sheet-caption {
        opacity: 0;
    }

    .sheet.is-peek .sheet-caption {
        opacity: 1;
    }

.sheet-media {
    width: 100%;
    height: 100%;
    display: grid;
    place-items: center;
}

    .sheet-media img {
        width: 100%;
        height: 100%;
        object-fit: contain;
        display: block;
        user-select: none;
        -webkit-user-drag: none;
    }

.sheet-caption {
    position: absolute;
    bottom: 12%;
    left: 50%;
    translate: -50% 0;
    font-weight: 700;
    font-size: clamp(12px, 2.6vw, 26px);
    white-space: nowrap;
    text-align: center;
    color: white;
}

.calendar-wrap .carousel__btn--prev {
    grid-column: 1;
    justify-self: end;
    margin-right: var(--btn-gap);
}

.calendar-wrap .carousel__btn--next {
    grid-column: 3;
    justify-self: start;
    margin-left: var(--btn-gap);
}

.services-carousel .carousel__btn:hover {
    color: white;
}

.services-carousel .carousel__btn[aria-disabled="true"],
.carousel__btn[disabled] {
    color: var(--theim-grey);
    pointer-events: none;
}

.services-carousel .carousel__btn:focus-visible {
    outline: 2px solid var(--theim-red);
    outline-offset: 2px;
}

.is-left {
    justify-self: end;
}

.is-right {
    justify-self: start;
}

#fallLayer {
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 50;
}

.copy {
    max-width: 48ch;
    position: relative;
}

.fade-swap {
    will-change: opacity, transform;
}

.copy h1, .copy p {
    will-change: transform, opacity;
}

#textLayer {
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 60;
}

/* Anfahrt --------------------------------------------------------------------- */

.join-location {
    background: #fff;
    color: #111;
    padding-block: clamp(48px,8vw,120px);
}

.join-location__stage {
    --pin-x: 50%; /* << hier ANPASSEN: X-Position des Markers (0–100%) */
    --pin-y: 37.5%; /* << hier ANPASSEN: Y-Position des Markers (0–100%) */
    position: relative;
    max-width: min(1200px, 94vw);
    margin-inline: auto;
    margin-bottom: clamp(32px,6vw,72px);
}

.join-location__map {
    display: block;
    width: 100%;
    height: auto;
}

.join-location__inner {
    max-width: clamp(460px, 94vw, 880px);
    margin-inline: auto;
    width: 100%;
}

.join-location__callout {
    position: absolute;
    left: var(--pin-x);
    top: var(--pin-y);
    transform: translate(-10%, -90%);
    background: #fff;
    border: 1px solid var(--theim-black, #111);
    border-radius: 14px;
    padding: clamp(12px,1.8vw,18px) clamp(14px,2.2vw,22px);
    max-width: min(360px, 70%);
    z-index: 1;
}

    .join-location__callout::after {
        content: none !important;
    }

/* Headline + Lead unter der Karte */
.join-location__headline {
    margin-block: 0 clamp(10px,2vw,16px);
}

.join-location__lead {
    max-width: 900px;
    margin: 0 0 clamp(28px,5vw,48px) 0;
}

/* 3er-Galerie */
.join-location__gallery {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: clamp(14px,2.2vw,22px);
}

    .join-location__gallery li img {
        width: 100%;
        height: auto;
        display: block;
        border-radius: 16px;
        background: #111; /* Fallback-Fläche, wenn Bild kurz fehlt */
    }

    /* Thumbs sollen Zoom-Hinweis bekommen */
    .join-location__gallery img {
        cursor: zoom-in;
    }


/* Scroll-Lock */

.reveal-band {
    margin-block: clamp(56px, 12vw, 180px);
}

/* Breakpoint 1: grosse Desktops */
@media (max-width: 1400px) {
    :root {
        --card-h: clamp(420px, 72vh, 780px);
        --card-content-offset: clamp(18px, 1.8vw, 26px);
    }

    .card__content {
        max-width: 40ch;
    }

    .jn-inner {
        max-width: clamp(320px, 84vw, 740px);
    }

    .stage.join-process {
        width: min(var(--maxw, 1000px), 100% - 2rem);
    }
}

/* Breakpoint 2: kleinere Desktops / große Tablets (≤1200px) */
@media (max-width: 1200px) {
    :root {
        --ov-max: 750px;
        --ov-hpad: clamp(24px, 4vw, 64px);
    }

    .card__content {
        max-width: 32ch;
    }

    .jn-inner {
        max-width: clamp(280px, 82vw, 700px);
    }

    .overlay__close--floating {
        width: 70px;
        height: auto;
        top: 40px;
        right: 40px;
    }

    .stage.join-process {
        width: min(var(--maxw, 950px), 100% - 2rem);
        column-gap: clamp(20px, 3vw, 40px);
        padding-block: clamp(28px, 8vh, 64px);
    }
}

/* Breakpoint 3: Tablets quer (≤992px) */
@media (max-width: 992px) {
    :root {
        --ov-max: 650px;
    }

    .jn-inner {
        max-width: clamp(220px, 74vw, 600px);
    }

    .trainers-grid {
        grid-template-columns: repeat(2, minmax(0,1fr));
    }

    .overlay__close--floating {
        width: 60px;
        height: auto;
    }

    .stage.join-process {
        width: min(var(--maxw, 850px), 100% - 2rem);
        padding-block: clamp(46px, 14vh, 110px);
    }

    .calendar {
        max-width: 360px;
        min-width: 240px;
    }

    .join-location__inner {
        max-width: clamp(260px, 80vw, 720px);
    }
}

/* Breakpoint 4: Tablets hoch / große Smartphones (≤768px) */

@media (max-width: 768px), (hover: none) and (pointer: coarse) {
    :root {
        --card-h: clamp(400px, 62vh, 540px);
        --card-content-offset: clamp(22px, 2vw, 32px);
        --lead: clamp(80px, 18vw, 160px);
        --ov-max: 550px;
    }

    .join-inner {
        max-width: 620px;
        padding: 0 2rem;
    }

    .reasons {
        height: auto;
        min-height: 100svh;
        overflow: hidden;
        clip-path: none;
        background: #fff;
        position: relative;
        --lead: clamp(50px, 15vw, 120px);
    }

    .reasons__track {
        position: relative;
        inset: auto;
        display: flex;
        align-items: center;
        gap: var(--gap);
        padding: 0 var(--gap);
        height: 100svh;
        overflow-x: auto;
        overflow-y: hidden;
        -webkit-overflow-scrolling: touch;
        scroll-snap-type: x mandatory;
        padding-left: 0 !important;
        padding-right: var(--gap);
        scroll-padding-left: 0;
        scroll-padding-right: 0;
        scroll-snap-type: x mandatory;
    }

        .reasons__track::before {
            display: block;
        }

    .lead {
        flex: 0 0 calc(var(--lead) + 0.5 * var(--gap));
        width: calc(var(--lead) + 0.5 * var(--gap));
        scroll-snap-align: none;
        scroll-snap-stop: always;
    }

    .intro__inner {
        padding-left: clamp(60px, 14vw, 140px);
    }

    .spine-global {
        display: block;
    }

    .intro {
        width: clamp(300px, 58vw, 520px);
        height: auto;
        aspect-ratio: auto;
        margin-right: calc(var(--gap) * -1.25);
        transform: none;
        scroll-snap-align: start;
    }

    .card {
        height: var(--card-h);
        width: auto;
        aspect-ratio: 898 / 1123;
        scroll-snap-align: center;
        scroll-snap-stop: always;
        scroll-snap-margin: 0 calc(var(--gap) / 2);
        padding-block: clamp(8px, 1.2vh, 16px);
    }

    .card--1 {
        margin-left: calc(var(--gap) * 2);
    }

    .card:last-of-type {
        scroll-snap-align: center;
        scroll-snap-stop: always;
        scroll-snap-margin-right: calc(var(--gap) * 1.25);
    }

    .card__content {
        max-width: 28ch;
        --card-content-vpad: clamp(4px, 0.8vh, 12px);
        padding-block: var(--card-content-vpad);
    }

    .card:nth-of-type(odd) .card__content {
        margin-top: clamp(6px, 1.2vh, 18px);
        margin-bottom: auto;
    }

    .card:nth-of-type(even) .card__content {
        margin-top: auto;
        margin-bottom: clamp(6px, 1.2vh, 18px);
    }

    .num {
        bottom: clamp(6px, 1vh, 14px);
    }

    .tail {
        display: block;
        scroll-snap-align: end;
        scroll-snap-stop: normal;
    }

    .intro {
        width: clamp(300px, 58vw, 520px);
        margin-right: calc(var(--gap) * -1.25);
        transform: none;
        scroll-snap-align: start;
    }

    .intro__spine {
        display: none;
    }

    .big5 {
        font-size: clamp(88px, 22vw, 220px);
    }

    .intro-text {
        max-width: clamp(200px, 60vw, 420px);
    }

    .overlay__close--floating {
        top: 40px;
        right: 40px;
        width: 50px;
        height: auto;
    }

    .stage.join-process {
        grid-template-columns: 1fr;
        padding-block: clamp(40px, 10vh, 96px);
        row-gap: clamp(32px, 8vh, 52px);
        min-height: 100svh;
        align-content: center;
        align-items: start;
        justify-content: center;
        justify-items: center;
        place-content: center;
    }

    .calendar-wrap {
        display: grid;
        grid-template-columns: auto minmax(0, 1fr) auto;
        justify-content: center;
        justify-items: center;
        align-items: center;
        column-gap: var(--btn-gap-m, clamp(12px, 5vw, 28px));
        width: fit-content;
        margin-inline: auto;
        padding: 0;
        margin: 0;
    }

    .calendar {
        width: clamp(200px, 70vw, 280px);
        min-width: 0;
        max-width: none;
        margin: 0;
    }

    .calendar-wrap .carousel__btn--prev,
    .calendar-wrap .carousel__btn--next {
        margin: 0 !important;
        width: var(--btn-size, 44px);
        height: var(--btn-size, 44px);
        display: grid;
        place-items: center;
        justify-self: center !important;
    }

    .calendar-wrap .carousel__btn--prev {
        grid-column: 1;
    }

    .calendar-wrap .carousel__btn--next {
        grid-column: 3;
    }

    .calendar-wrap .carousel__btn svg {
        width: 100%;
        height: auto;
    }

    .copy {
        justify-self: center;
        max-width: 60ch;
        padding-inline: 1rem;
        text-align: left;
        margin: 0;
    }

        .copy > * {
            margin: 0;
        }

            .copy > * + * {
                margin-top: clamp(6px, 1vh, 12px);
            }
    /* Abstand H1→P */
    #copyTitle {
        margin-top: 0 !important;
    }

    .stage.join-process .copy {
        min-height: var(--copy-min, auto);
        display: grid; /* verhindert Margin-Collapse */
        align-content: start; /* Text sitzt oben in seiner Box */
    }

    .stage.join-process .calendar {
        min-height: var(--cal-min, 0px);
    }
    .join-location__inner {
        max-width: 70%;
    }
    .join-location__gallery {
        grid-template-columns: 1fr;
    }
    .join-location__stage {
        --pin-x: 62%;
        --pin-y: 50%;
    }
    .join-location__callout {
        inline-size: clamp(140px, 60vw, 210px); /* min, fluid, max */
        max-inline-size: none;
        transform: translate(-50%, -105%);
    }
    .join-location__map {
        position: relative;
        left: 50%;
        transform: translateX(-50%);
        width: 135%;
        max-width: none;
    }
}

/* Breakpoint 5: Smartphones (≤576px) */
@media (max-width: 576px) {
    :root {
        --card-h: clamp(440px, 66vh, 580px);
        --card-content-offset: clamp(18px, 1.8vw, 26px);
        --lead: clamp(90px, 10vw, 200px);
        --intro-lift: clamp(10px, 2.5vh, 28px);
        --ov-max: 450px;
        --ov-hpad: clamp(38px, 6vw, 76px);
    }

    .join-inner {
        max-width: 500px;
    }

    .reasons {
        --lead: clamp(180px, 24vw, 400px);
    }

    .reveal__inner .headline-xxl {
        max-width: 500px;
    }

    .reasons .intro__inner {
        position: relative;
        transform: translateY(calc(-1 * var(--intro-lift)));
    }

    .card--1 {
        margin-left: calc(var(--gap) * 4);
    }

    .card__content {
        max-width: 28ch;
    }

    .card__content {
        padding-block: clamp(3px, 1vh, 12px);
    }

    .card:nth-of-type(odd) .card__content {
        margin-top: 3% !important;
        margin-bottom: auto;
    }

    .card:nth-of-type(even) .card__content {
        margin-top: auto;
        margin-bottom: max(0px, env(safe-area-inset-bottom, 0px)) !important;
    }

    .intro {
        margin-right: calc(var(--gap) * -3);
    }

    .trainers-grid {
        grid-template-columns: 1fr;
    }

    .overlay__close--floating {
        top: 25px;
        right: 25px;
        width: 44px;
        height: auto;
    }

    .jobs_trigger {
        font-size: clamp(1.6rem, 2.3vw, 3.3rem);
    }

    #ov5-title {
        overflow-wrap: anywhere;
    }

    .copy {
        max-width: 500px;
        padding-inline: 2rem;
    }
    .join-location__map {
        width: 140%;
    }
    .join-location__stage {
        --pin-x: 65%;
        --pin-y: 70%;
    }
    .join-location__callout {
        inline-size: clamp(100px, 54vw, 160px); /* min, fluid, max */
    }
}

/* Breakpoint 6: sehr schmale Smartphones */
@media (max-width: 420px) {

    :root {
        --ov-max: 320px;
        --ov-hpad: clamp(38px, 6vw, 76px);
        --card-h: clamp(400px, 56vh, 460px);
    }

    .join-inner {
        max-width: 320px;
        padding: 0;
    }

    .reasons {
        --lead: clamp(180px, 32vw, 320px);
    }

    .card--1 {
        margin-left: calc(var(--gap) * 6);
    }

    .reveal__inner .headline-xxl {
        max-width: 380px;
    }

    .calendar {
        width: clamp(180px, 60vw, 240px);
    }

    .sheet-caption {
        font-size: clamp(18px, 3vw, 26px);
    }

    .copy {
        max-width: 320px;
        padding-inline: 0;
    }
    .join-location__inner {
        max-width: 75%;
    }
    .join-location__stage {
        --pin-x: 70%;
        --pin-y: 75%;
    }
    .join-location__map {
        width: 150%;
    }
    .join-location__callout {
        inline-size: clamp(100px, 54vw, 160px); /* min, fluid, max */
    }
}




