/**
 * Block: Newsletter-Registrierung
 *
 * 60/40-Layout: Form links, Bild + Person-Badge rechts.
 * Form-Texte aus Theme-Einstellungen, Bild + Badge aus Block-Feldern.
 *
 * Modifier:
 *   .block--pad-{none|normal|lg}
 *   .block--bg-{neongelb|beige|dunkelbeige|white|navy|transparent}
 */

.block--newsletter {
    position: relative;
}

/* Linien-Override: SVG vollflächig, Y kommt direkt in den Polyline-
 * Punkten (siehe assets/js/modules/newsletter-line.js). Strich-Animation
 * läuft ruhig in 4500 ms — analog Hero-Home / News / Stimmen. */
.block--newsletter > .block__line-svg {
    top: 0;
    height: 100%;
}

.block--newsletter .block__line-path {
    transition-duration: 4500ms;
}

/* z-index 3 hebt Inhalt (Eyebrow + Form + Bild + Badge) ÜBER die Linie
 * im SVG (z-index 2 aus scroll-line.css). Die Linie schimmert zwischen
 * den Elementen durch, das Bild deckt den vertikalen Strich vollständig
 * ab, Form-Felder bleiben leserlich. */
.block--newsletter .newsletter__inner {
    position: relative;
    z-index: 3;
}

.block--newsletter.block--pad-none   { padding-block: 0; }
.block--newsletter.block--pad-normal { padding-block: var(--space-16); }
.block--newsletter.block--pad-lg     { padding-block: var(--space-24); }

.block--newsletter.block--bg-neongelb    { background-color: var(--color-neongelb); }
.block--newsletter.block--bg-beige       { background-color: var(--color-beige); }
.block--newsletter.block--bg-dunkelbeige { background-color: var(--color-bg-alt); }
.block--newsletter.block--bg-white       { background-color: var(--color-white); }
.block--newsletter.block--bg-navy {
    background-color: var(--color-bg-premium);
    color: var(--color-text-on-navy);
}
.block--newsletter.block--bg-transparent { background-color: transparent; }

/* ── Inner-Container ──────────────────────────── */

.newsletter__inner {
    position: relative;
    z-index: var(--z-raised);
}

.newsletter__eyebrow {
    margin: 0 0 var(--space-8);
    font-family: var(--font-body);
    font-size: var(--text-base);
    font-weight: var(--fw-bold);
    color: var(--color-text);
}

.block--bg-navy .newsletter__eyebrow { color: var(--color-text-on-navy); }

/* ── Grid 60/40 ───────────────────────────────── */

.newsletter__grid {
    display: grid;
    grid-template-columns: 6fr 4fr;
    gap: var(--space-12);
    align-items: start;
}

.newsletter__content {
    display: flex;
    flex-direction: column;
    gap: var(--space-8);
}

.newsletter__heading {
    margin: 0;
    font-family: var(--font-display);
    font-size: clamp(var(--text-3xl), 3.2vw, var(--text-5xl));
    font-weight: var(--fw-semibold);
    line-height: var(--lh-tight);
    color: var(--color-text);
}

.block--bg-navy .newsletter__heading { color: var(--color-text-on-navy); }

/* ── Form ─────────────────────────────────────── */

.newsletter__form {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

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

.newsletter__field {
    display: block;
    position: relative;
}

.newsletter__input {
    width: 100%;
    padding: var(--space-4) var(--space-6);
    font-family: var(--font-body);
    font-size: var(--text-base);
    color: var(--color-text);
    background-color: var(--color-white);
    border: 1px solid transparent;
    border-radius: 999px;
    outline: none;
    transition: border-color var(--duration-fast) var(--ease-default),
                box-shadow var(--duration-fast) var(--ease-default);
}

.newsletter__input::placeholder {
    color: var(--color-text-muted);
    opacity: 1;
}

.newsletter__input:hover {
    border-color: var(--color-dunkelbeige);
}

.newsletter__input:focus-visible {
    border-color: var(--color-navy);
    box-shadow: 0 0 0 3px rgb(var(--color-navy-rgb) / 0.15);
}

/* ── Optionen (Radios) ────────────────────────── */

.newsletter__options {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    margin: var(--space-2) 0 0;
    padding: 0;
    border: 0;
}

.newsletter__radio {
    display: grid;
    grid-template-columns: auto 1fr;
    align-items: start;
    gap: var(--space-3);
    cursor: pointer;
    font-family: var(--font-body);
    font-size: var(--text-base);
    line-height: var(--lh-snug);
    color: var(--color-text);
}

.block--bg-navy .newsletter__radio { color: var(--color-text-on-navy); }

/* Native Input visuell verstecken, aber fokussierbar lassen. */
.newsletter__radio-input,
.newsletter__consent-input {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.newsletter__radio-control {
    display: block;
    width: 22px;
    height: 22px;
    margin-top: 2px;
    border-radius: 50%;
    border: 2px solid var(--color-navy);
    background-color: var(--color-white);
    transition: box-shadow var(--duration-fast) var(--ease-default);
    flex-shrink: 0;
}

.newsletter__radio-input:checked + .newsletter__radio-control {
    box-shadow: inset 0 0 0 5px var(--color-navy);
}

.newsletter__radio-input:focus-visible + .newsletter__radio-control {
    outline: 2px solid var(--color-navy);
    outline-offset: 3px;
}

.newsletter__radio-text {
    display: block;
}

.newsletter__radio-text > *:first-child { margin-top: 0; }
.newsletter__radio-text > *:last-child  { margin-bottom: 0; }

.newsletter__radio-text strong,
.newsletter__radio-text b {
    font-weight: var(--fw-bold);
}

/* ── Consent-Checkbox ─────────────────────────── */

.newsletter__consent {
    display: grid;
    grid-template-columns: auto 1fr;
    align-items: start;
    gap: var(--space-3);
    margin-top: var(--space-2);
    cursor: pointer;
    font-family: var(--font-body);
    font-size: var(--text-sm);
    line-height: var(--lh-snug);
    color: var(--color-text);
}

.block--bg-navy .newsletter__consent { color: var(--color-text-on-navy); }

.newsletter__consent-control {
    display: block;
    width: 20px;
    height: 20px;
    margin-top: 2px;
    background-color: var(--color-white);
    border: 2px solid var(--color-navy);
    flex-shrink: 0;
    position: relative;
}

.newsletter__consent-input:checked + .newsletter__consent-control::after {
    content: "";
    position: absolute;
    left: 4px;
    top: 0;
    width: 6px;
    height: 11px;
    border: solid var(--color-navy);
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}

.newsletter__consent-input:focus-visible + .newsletter__consent-control {
    outline: 2px solid var(--color-navy);
    outline-offset: 3px;
}

.newsletter__consent-text > *:first-child { margin-top: 0; }
.newsletter__consent-text > *:last-child  { margin-bottom: 0; }

.newsletter__consent-text a {
    color: inherit;
    text-decoration: underline;
}

/* ── Button ───────────────────────────────────── */

.newsletter__cta {
    align-self: flex-start;
    margin-top: var(--space-4);
}

/* ── Media (rechts) ───────────────────────────── */

.newsletter__media {
    position: relative;
    align-self: stretch;
}

.newsletter__image {
    display: block;
    width: 100%;
    height: auto;
    max-width: 100%;
}

.newsletter__badge {
    position: absolute;
    left: 0;
    right: 0;
    bottom: var(--space-8);
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
    padding: var(--space-3) var(--space-6);
    background-color: var(--color-navy);
    color: var(--color-text-on-navy);
    font-family: var(--font-body);
    font-size: var(--text-sm);
    line-height: var(--lh-snug);
}

.newsletter__badge-role { font-weight: var(--fw-regular); }
.newsletter__badge-name { font-weight: var(--fw-semibold); }

/* ── Responsive ───────────────────────────────── */

/* bis einschl. Tablet: stacked Layout */
@media (max-width: 1024px) {
    .newsletter__grid {
        grid-template-columns: 1fr;
        gap: var(--space-8);
    }

    .newsletter__media {
        max-width: 480px;
        margin-inline: auto;
    }
}

/* bis einschl. Mobile-Large: Felder untereinander, kleinere Headline */
@media (max-width: 768px) {
    .newsletter__row {
        grid-template-columns: 1fr;
    }

    .newsletter__heading {
        font-size: clamp(var(--text-2xl), 6vw, var(--text-3xl));
    }
}
