/**
 * KSM Slider
 *
 * Layout-Idee:
 * - Element gehört in eine FULL-WIDTH Row → .ksm-slider ist 100% breit.
 * - .ksm-slider__slide ist ein 1-Zellen-Grid; Bild (__media) und Text (__inner)
 *   liegen in DERSELBEN Zelle → Slide-Höhe = das Höhere von Bild oder Content.
 * - __media sitzt rechts (justify-self:end) und läuft edge-to-edge zum Rand;
 *   __inner zentriert den Text auf Uncode-Content-Breite (linke Grid-Spalte).
 * - Bild im vollen Original-Seitenverhältnis (height:auto).
 * - Keine Hintergrundfarbe — die liefert die Row.
 *
 * Content-Breite anpassen: --ksm-slider-content-max überschreiben
 * (Default = Uncode-typische 1200px via --ksm-container-max).
 */

.ksm-slider {
    /* ============================================================
       ZENTRALE STELLSCHRAUBEN — jede Variable hat genau EINE Aufgabe.
       Abstände hier anpassen, nicht weiter unten in den Regeln.
       ============================================================ */
    --ksm-slider-content-max:  var(--ksm-container-max);     /* Breite der Textspalte */
    --ksm-slider-pad-x:        var(--ksm-container-padding); /* horizontales Grid-Padding */

    --ksm-slider-space-top:    var(--ksm-spacing-xl);        /* Row-Oberkante → Index */
    --ksm-slider-index-gap:    var(--ksm-spacing-2xl);       /* Index → Headline */
    --ksm-slider-space-bottom: var(--ksm-spacing-4xl);       /* Content → unterer Abstand */
    --ksm-slider-slide-min:    clamp(26rem, 40vw, 38rem);    /* Slide-Mindesthöhe (Desktop) */

    --ksm-slider-index-h:      calc(var(--ksm-spacing-base) * 1);   /* Höhe der Index-Striche */

    --ksm-slider-badge-size:   calc(var(--ksm-spacing-base) * 12);  /* Durchmesser des Badges (Desktop) */
    --ksm-slider-badge-inset:  var(--ksm-spacing-lg);        /* Abstand Badge → Bildkante */
    --ksm-slider-badge-speed:  14s;                          /* Umdrehungsdauer */
    --ksm-slider-headline-size: clamp(2.5rem, 2.29rem + 1.07vw, 3.25rem); /* etwas kleiner als fontsize-xxl */

    position: relative;
    width: 100%;
    overflow: hidden;
    /* oberer Freiraum für den (absolut liegenden) Index */
    padding-top: var(--ksm-slider-space-top);
}

/* ---- Slides / Crossfade ---- */
.ksm-slider__track {
    position: relative;
}

.ksm-slider__slide {
    position: absolute;
    inset: 0;
    opacity: 0;
    visibility: hidden;
    transition: opacity var(--ksm-transition-slow);
    min-height: var(--ksm-slider-slide-min);
    /* Bild + Text liegen in DERSELBEN Grid-Zelle → Zellenhöhe = das höhere
       von beiden. Dadurch folgt die Slide-Höhe dem Bild ODER dem Content. */
    display: grid;
    grid-template-columns: 1fr;
}

.ksm-slider__slide.is-active {
    position: relative;
    opacity: 1;
    visibility: visible;
}

/* ---- Bild rechts (edge-to-edge) ----
   Liegt in derselben Grid-Zelle wie der Text, rechtsbündig (justify-self:end),
   oben angesetzt (align-self:start). Breite fix (45%), Höhe = volles Original-
   Seitenverhältnis (height:auto) → NIE Beschnitt. */
.ksm-slider__media {
    grid-area: 1 / 1;
    align-self: start;
    justify-self: end;
    position: relative;        /* Anker für das Badge (oben links auf dem Bild) */
    width: 45%;                /* Breite des Bild-Rechtecks (anpassbar) */
    overflow: hidden;          /* clippt nur die abgerundeten Ecken */
    /* nur links abgerundet (rechts läuft das Bild edge-to-edge zum Rand) */
    border-top-left-radius: var(--ksm-border-radius-xl);
    border-bottom-left-radius: var(--ksm-border-radius-xl);
    pointer-events: none;
}

.ksm-slider__img {
    display: block;
    width: 100%;
    height: auto;              /* nativer Aspect-Ratio, nichts wird abgeschnitten */
}

/* ---- Badge (rotierender Kreis-Text, oben links auf dem Bild) ---- */
.ksm-slider__badge {
    position: absolute;
    top: var(--ksm-slider-badge-inset);
    left: var(--ksm-slider-badge-inset);
    width: var(--ksm-slider-badge-size);
    height: var(--ksm-slider-badge-size);
    z-index: 4;
    pointer-events: none;
}

.ksm-slider__badge svg {
    width: 100%;
    height: 100%;
    transform-origin: 50% 50%;
    animation: ksm-badge-spin var(--ksm-slider-badge-speed) linear infinite;
}

.ksm-slider__badge text {
    fill: rgba(var(--ksm-color-white), 1);
    font-size: 13px;                       /* SVG-User-Units (viewBox 0 0 100 100) */
    font-family: var(--ksm-font-bold-italic);
    font-weight: var(--ksm-font-weight-bold);
    font-style: italic;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

@keyframes ksm-badge-spin {
    to { transform: rotate(360deg); }
}

@media (prefers-reduced-motion: reduce) {
    .ksm-slider__badge svg {
        animation: none;
    }
}

/* ---- Text-Spalte im Grid ---- */
.ksm-slider__inner {
    grid-area: 1 / 1;          /* gleiche Zelle wie das Bild → Höhe = max(Text, Bild) */
    align-self: start;
    position: relative;
    z-index: 2;
    width: 100%;
    min-width: 0;              /* erlaubt Umbrechen in Grid-Overlay */
    max-width: var(--ksm-slider-content-max);
    margin-inline: auto;
    padding-inline: var(--ksm-slider-pad-x);
    /* oben: Index-Höhe + gewünschter Index-Abstand (entkoppelt vom Top-Freiraum) */
    padding-block:
        calc(var(--ksm-slider-index-h) + var(--ksm-slider-index-gap))
        var(--ksm-slider-space-bottom);
}

.ksm-slider__content {
    max-width: 46%;
    min-width: 0;
}

.ksm-slider .ksm-slider__headline {
    margin: 0 0 var(--ksm-spacing-md);
    color: rgba(var(--ksm-color-white), 1);
    text-transform: uppercase;
    font-family: var(--ksm-font-bold);
    font-weight: var(--ksm-font-weight-bold);
    font-size: var(--ksm-slider-headline-size);
    line-height: 1.05;
    overflow-wrap: break-word;
    word-break: normal;
    -webkit-hyphens: auto;
    hyphens: auto;
    white-space: normal;       /* Uncode-Headline-Klassen können nowrap erzwingen */
}

.ksm-slider__lead {
    margin: 0 0 var(--ksm-spacing-xl);
    color: rgba(var(--ksm-color-white), 0.78);
    font-size: var(--ksm-font-size-lg);
    line-height: var(--ksm-line-height-normal);
    overflow-wrap: break-word;
    word-break: normal;
    -webkit-hyphens: auto;
    hyphens: auto;
}

/* ---- CTA (weißer Pill-Button) ---- */
.ksm-slider__cta {
    display: inline-flex;
    align-items: center;
    gap: var(--ksm-spacing-sm);
    padding: var(--ksm-btn-padding-block) var(--ksm-btn-padding-inline);
    font-size: var(--ksm-btn-font-size);
    background: rgba(var(--ksm-color-white), 1);
    border: 1px solid transparent;   /* Platzhalter → kein Layout-Shift bei Hover-Border */
    font-family: var(--ksm-font-bold-italic);
    font-weight: var(--ksm-font-weight-bold);
    font-style: italic;
    line-height: 1;
    text-decoration: none;
    border-radius: var(--ksm-border-radius-pill);
    transition: background var(--ksm-transition-fast), border-color var(--ksm-transition-fast), color var(--ksm-transition-fast);
}

/* hohe Spezifität, um Uncode-Link-Farben zu überschreiben */
.ksm-slider .ksm-slider__cta,
.ksm-slider .ksm-slider__cta:link,
.ksm-slider .ksm-slider__cta:visited,
.ksm-slider .ksm-slider__cta .ksm-slider__cta-label,
.ksm-slider .ksm-slider__cta .ksm-slider__cta-arrow {
    color: rgba(var(--ksm-color-primary-dark), 1);
}

.ksm-slider .ksm-slider__cta:hover,
.ksm-slider .ksm-slider__cta:focus-visible,
.ksm-slider .ksm-slider__cta:hover .ksm-slider__cta-label,
.ksm-slider .ksm-slider__cta:focus-visible .ksm-slider__cta-label,
.ksm-slider .ksm-slider__cta:hover .ksm-slider__cta-arrow,
.ksm-slider .ksm-slider__cta:focus-visible .ksm-slider__cta-arrow {
    color: rgba(var(--ksm-color-white), 1);
}

.ksm-slider__cta:hover,
.ksm-slider__cta:focus-visible {
    background: transparent;
    border-color: rgba(var(--ksm-color-white), 1);
}

.ksm-slider__cta-arrow {
    transition: transform var(--ksm-transition-fast);
}

.ksm-slider__cta:hover .ksm-slider__cta-arrow,
.ksm-slider__cta:focus-visible .ksm-slider__cta-arrow {
    transform: translateX(3px);
}

/* ---- Navigation / Dots ---- */
.ksm-slider__nav {
    position: absolute;
    top: var(--ksm-slider-space-top);   /* gleicher Ursprung wie der Content-Top → Abstand bleibt stabil */
    left: 0;
    right: 0;
    z-index: 3;
    pointer-events: none;
}

.ksm-slider__nav-inner {
    max-width: var(--ksm-slider-content-max);
    margin-inline: auto;
    padding-inline: var(--ksm-slider-pad-x);
    display: flex;
    align-items: center;
    gap: var(--ksm-spacing-md);
}

.ksm-slider__dots {
    display: flex;
    align-items: center;
    gap: var(--ksm-spacing-xs);
    pointer-events: auto;
}

.ksm-slider__dot {
    width: calc(var(--ksm-spacing-base) * 1.4);
    height: var(--ksm-slider-index-h);
    padding: 0;
    border: 0;
    border-radius: var(--ksm-border-radius-pill);
    background: rgba(var(--ksm-color-white), 0.4);
    cursor: pointer;
    transition: width var(--ksm-transition-normal), background var(--ksm-transition-normal);
}

.ksm-slider__dot.is-active {
    width: calc(var(--ksm-spacing-base) * 4);
    background: rgba(var(--ksm-color-white), 1);
}

.ksm-slider__dot:focus-visible {
    outline: 2px solid rgba(var(--ksm-color-white), 1);
    outline-offset: 3px;
}

.ksm-slider__counter {
    pointer-events: none;
    color: rgba(var(--ksm-color-white), 0.7);
    font-size: var(--ksm-font-size-xs);
    letter-spacing: 0.08em;
}

/* ============================================
   RESPONSIVE — Tablet / Mobile
   ============================================ */
@media (max-width: 959px) {

    .ksm-slider {
        --ksm-slider-badge-size: calc(var(--ksm-spacing-base) * 7);  /* Badge auf Mobile kompakter */
    }

    .ksm-slider__slide {
        min-height: 0;
        display: block;        /* Bild stapelt unter dem Text (kein Overlap) */
    }

    /* Bild läuft im Fluss unter dem Text, linksbündig mit dem Grid, rechts edge-to-edge.
       (position: relative kommt bereits aus der Basis-Regel → Anker fürs Badge) */
    .ksm-slider__media {
        width: 100%;
        margin-top: var(--ksm-spacing-xl);
        padding-left: var(--ksm-slider-pad-x);
        padding-right: 0;
        box-sizing: border-box;
    }

    /* Badge bleibt auf dem Bild oben links → linkes Padding mit einrechnen */
    .ksm-slider__badge {
        left: calc(var(--ksm-slider-pad-x) + var(--ksm-slider-badge-inset));
    }

    .ksm-slider__img {
        /* Media hat links Padding → Radius hier aufs Bild, damit top-left sichtbar wird */
        border-top-left-radius: var(--ksm-border-radius-xl);
    }

    .ksm-slider__content {
        max-width: 100%;
    }
}
