/* --- Hero Section --- */
.hero {
    display: flex;
    height: 100vh;
    width: 100%;
}

.hero,
.hero * {
    font-family: var(--font-base);
}

.left {
    background: linear-gradient(-90deg,
            #030303 5%,
            #333333 100%);
    width: 50vw;
    height: 100vh;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    /* statt column: alles überlagert in einem Layer */
    flex-direction: column;
    gap: 8px;
}

/* Wrapper für Logo und Text übereinander */
.hero-left-logo-wrapper,
.hero-left-text-wrapper {
    position: absolute;
    inset: 0;
    display: flex;
    justify-content: center;
    align-items: center;
}

/* Logo: Standard sichtbar, mit Transition + kleinem Scale-Effekt */
.hero-left-logo-wrapper {
    opacity: 1;
    transform: scale(1);
    transition: opacity 280ms ease, transform 280ms ease;
}

.hero-logo {
    max-width: 1485px;
    /* vorher 495px */
    width: 100%;
    /* vorher 60% */
    height: auto;
    object-fit: contain;
    padding: 1.5rem;
    /* neues Padding rund um das Logo */
}

/* Text: Standard unsichtbar, mit Transition + Scale-Effekt */
.hero-left-text-wrapper {
    opacity: 0;
    transform: scale(0.96);
    transition: opacity 280ms ease, transform 280ms ease;
    flex-direction: column;
    gap: 2px;
    /* vorher 8px – Abstand zwischen ANDREAS und BAUMBACH verringert */
}

/* Hero-Texte – wieder wie früher: Position, Animationen etc. */
.vertical-text {
    rotate: 0deg;
    font-size: clamp(2.4rem, 3.5vw, 4.2rem);
    color: #ffffff;
    font-family: "Inter Tight", sans-serif;
    margin: 0;
    position: relative;
    opacity: 0;
    will-change: translate, opacity;
    animation: flyDown 900ms cubic-bezier(.22, .9, .3, 1) 100ms forwards;
}

.horizontal-text {
    font-size: clamp(3.4rem, 5.5vw, 6rem);
    color: #ffffff;
    font-family: "Inter Tight", sans-serif;
    font-weight: 900;
    margin: 0;
    position: relative;
    top: 0;
    opacity: 0;
    will-change: translate, opacity;
    animation: flyRight 900ms cubic-bezier(.22, .9, .3, 1) 250ms forwards;
}

/* Zustand: rechter Bereich wird gehovert -> links Text anzeigen, Logo ausblenden
   + Animierter Übergang (Fade + Scale) */
.left.left--show-text .hero-left-logo-wrapper {
    opacity: 0;
    transform: scale(0.96);
}

.left.left--show-text .hero-left-text-wrapper {
    opacity: 1;
    transform: scale(1);
}

/* rechter Teil bleibt Bild pur, bekommt aber Hover-Overlay */
.right {
    width: 50vw;
    height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background-image: url('../Pictures/888A4327 Kopie Black and White.jpg');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    position: relative;
    overflow: hidden;
}

/* halbtransparenter, geblurrter Overlay-Layer über dem Bild */
.right::before {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.45);
    backdrop-filter: blur(0px);
    opacity: 0;
    transition: opacity 220ms ease, backdrop-filter 220ms ease;
    pointer-events: none;
}

/* Text-Overlay in der Mitte, zunächst unsichtbar */
.right-overlay-text {
    position: absolute;
    inset: 10%;
    padding: 20px;
    overflow: auto;
    color: #ffffff;
    font-family: var(--font-base);
    font-size: 0.9rem;
    line-height: 1.6;
    opacity: 0;
    transform: translateY(8px);
    transition: opacity 220ms ease, transform 220ms ease;
    pointer-events: none;
}

/* Absätze im Overlay: sichtbare Abstände */
.right-overlay-text p {
    margin: 0 0 0.9rem 0;
}

/* Motto etwas absetzen und hervorheben */
.right-overlay-motto {
    margin-top: 0.5rem;
    text-align: center;
    font-weight: 700;
    letter-spacing: 0.06em;
}

/* Hover/Fokus: Blur und Text anzeigen */
.right:hover::before,
.right:focus-within::before {
    opacity: 1;
    backdrop-filter: blur(8px);
}

.right:hover .right-overlay-text,
.right:focus-within .right-overlay-text {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}

.hero-image {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

/* Animationen */
@keyframes flyDown {
    from {
        translate: 0 -120vh;
        opacity: 0;
    }

    to {
        translate: 0 0;
        opacity: 1;
    }
}

@keyframes flyRight {
    from {
        translate: -120vw 0;
        opacity: 0;
    }

    to {
        translate: 0 0;
        opacity: 1;
    }
}

@media (prefers-reduced-motion: reduce) {

    .vertical-text,
    .horizontal-text {
        animation: none !important;
        opacity: 1 !important;
        translate: 0 0 !important;
    }

    .right::before,
    .right-overlay-text {
        transition: none;
    }
}

/* Hero & Layout auf kleinen Screens */
@media (max-width: 900px) {
    .hero {
        flex-direction: column;
    }

    .left,
    .right {
        width: 100vw;
        height: 50vh;
    }

    .left {
        gap: 4px;
    }

    .vertical-text {
        font-size: clamp(2rem, 5vw, 3rem);
    }

    .horizontal-text {
        font-size: clamp(2.8rem, 8vw, 4.2rem);
    }

    /* auf Mobil etwas mehr Innenabstand für Text */
    .right-overlay-text {
        inset: 8%;
        padding: 16px;
        font-size: 0.95rem;
        line-height: 1.7;
    }

    /* auf kleineren Screens Logo entsprechend größer, aber begrenzt */
    .hero-logo {
        top: 12px;
        left: 12px;
        max-width: 810px;
        /* vorher 270px */
        width: 100%;
        /* vorher 52.5% */
        height: auto;
        transform: none;
        padding: 1rem;
        /* etwas kleineres Padding auf Mobile */
    }
}