/* Variables *//* #region */
:root {
    /* Fonts */
    --font-family-base: "Source Sans 3", sans-serif;
    --font-family-accent: "Annie Use Your Telescope", cursive;

    /* Font-size */
        --scale-factor: 1.333; /* Perfect Fourth - sorgt für starke Hierarchie */

        --font-size-base: 1rem; /* Entspricht 16px, wenn Standard-Browser-Einstellung */

        --font-size-s: calc(var(--font-size-base) / var(--scale-factor));      /* ~0.75rem */
        --font-size-xs: calc(var(--font-size-s) / var(--scale-factor));        /* ~0.56rem */

        --font-size-m: calc(var(--font-size-base) * var(--scale-factor));      /* ~1.333rem */
        --font-size-l: calc(var(--font-size-m) * var(--scale-factor));         /* ~1.777rem */
        --font-size-xl: calc(var(--font-size-l) * var(--scale-factor));        /* ~2.369rem */
        --font-size-xxl: calc(var(--font-size-xl) * var(--scale-factor));      /* ~3.157rem */
        --font-size-xxxl: calc(var(--font-size-xxl) * var(--scale-factor));    /* ~4.209rem */

    /* Font-weight */

        /* Dünn, extraleicht (für spezielle Akzente) */
        --font-weight-extralight: 200;

        /* Dünn, leicht (für spezielle Akzente) */
        --font-weight-light: 300;

        /* Standard-Fließtext (Body Copy) */
        --font-weight-regular: 400;

        /* Mittel, zwischen Regular und Semibold */
        --font-weight-medium: 500;

        /* Halb-Fett (oft für Hauptüberschriften) */
        --font-weight-semibold: 600;

        /* Standard-Fett (Das, was <b> oder <strong> im Browser auslöst) */
        --font-weight-bold: 700;

        /* Extra Fett (für H1 oder große Titel) */
        --font-weight-extrabold: 800;

        /* Optional: Max. Fett */
        --font-weight-black: 900;

    /* Spacing */
        --spacing-unit: 0.5rem; /* Die meisten Werte sind Vielfache der 8-Punkt-Regel (0.5rem) */

        /* 4px - Kleiner Trenner oder interne Abstände */
        --spacing-xxs: calc(var(--spacing-unit) * 0.5); /* 0.25rem */

        /* 8px - Kleinster Standardabstand, z.B. zwischen Icon und Text */
        --spacing-xs: var(--spacing-unit); /* 0.5rem */

        /* 12px - Kleine Abstände, z.B. zwischen zwei Listenelementen */
        --spacing-s: calc(var(--spacing-unit) * 1.5); /* 0.75rem */

        /* 16px - Standard-Padding für Komponenten, Basis-Fließtextabstand */
        --spacing-m: calc(var(--spacing-unit) * 2); /* 1rem */

        /* 24px - Mittelgroße Abstände, z.B. zwischen Absätzen oder Sektionen */
        --spacing-l: calc(var(--spacing-unit) * 3); /* 1.5rem */

        /* 32px - Große Abstände, z.B. zwischen Komponenten */
        --spacing-xl: calc(var(--spacing-unit) * 4); /* 2rem */

        /* 48px - Hauptabschnitte oder Abstände für große Überschriften */
        --spacing-xxl: calc(var(--spacing-unit) * 6); /* 3rem */

        /* 64px - Sehr große vertikale Abstände zwischen Hauptsektionen */
        --spacing-xxxl: calc(var(--spacing-unit) * 8); /* 4rem */

    /* Colors */
        /* Hintergrundfarbe (Ihr aktuelles Color Primary: Helles Grau/Weiß) */
        --color-background-default: hsl(0, 0%, 98%); /* Etwas Heller als 95% */

        /* Haupttextfarbe (Ihr aktuelles Color Secondary: Dunkles Grau/Schwarz) */
        --color-text-default: hsl(0, 0%, 10%);

        /* Gedämpfter/Hinweis-Text, Icons (Ihr Color Tertiary/Disabled) */
        --color-text-muted: hsl(0, 0%, 45%);

        /* --- Brand Farben --- */

        /* Hauptakzentfarbe (Ihr Color Accent: Rot/Orange) */
        --color-brand-primary: hsl(7, 86%, 36%);

    /* Border Radius */
        /* Kein Radius */
        --border-radius-none: 0;

        /* Kleine, konsistente Abrundung (8px) */
        --border-radius-s: 0.5rem;

        /* Standard-Abrundung für Buttons, Inputfelder (12px) */
        --border-radius-m: 1rem;

        /* Größere Abrundung für Container oder Panels (24px) */
        --border-radius-l: 1.5rem;

        /* Stark abgerundete Ecken (32px), wenn Sie wirklich große Abrundungen wollen */
        --border-radius-xl: 2rem;

        /* Für Pillen- oder Kreisformen (z.B. Tags oder Avatare) */
        --border-radius-full: 50%;

    /* Shadows */
        --box-shadow: 0px 0px 16px 8px rgba(0, 0, 0, 0.05);


    /* Breakpoints */
        --breakpoint-mobile: 480px;
        --breakpoint-tablet: 768px;
        --breakpoint-desktop: 1024px;
}

/* #endregion */

/* Transition *//* #region */

/* 1. Opt-in for Cross-Document Transitions (MPA) */
@view-transition {
  navigation: auto;
}

/* 2. Define Custom Keyframes */

@keyframes fade-in {
    /* (0% to 75% is the Fade Out + White Flash period) */
    0%, 50% {
        opacity: 0;
    }

    /* Start the fade-in after the white flash period (25%) */
    100% {
        opacity: 1;
    }
}

/* Keep the old view completely invisible after it fades out */
@keyframes fade-out {
    0% {
        opacity: 1;
    }

    50%, 100% {
        opacity: 0;
    }
}

/* 3. Customize the Transition Timing (The "White Screen" Effect) */

/* Set the overall transition duration on the view-transition-group */
::view-transition-group(main, footer) {
    background: var(--color-background-default);
}


/* Old Page Snapshot: Fades out quickly (0.25s) */
:root::view-transition-old(main, footer) {
    animation: fade-out 0.6s ease-in-out forwards;
}

/* New Page Snapshot: Runs over the full 0.65s timeline */
:root::view-transition-new(main, footer) {
    animation: fade-in 0.6s ease-in-out forwards;
    opacity: 0;
}

/* Boilerplate fixes */
::view-transition-old(root),
::view-transition-new(root) {
    backface-visibility: hidden;
}

/* #endregion */

/* Base *//* #region */

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    outline: none;
}

html, body {
    min-height: 100%;
    width: 100%;
    scroll-behavior: smooth;
}

/* #endregion */

/* Scrollbar *//* #region */

::-webkit-scrollbar {
    width: 10px;
    height: 10px;
}

::-webkit-scrollbar-track {
    background: none;
    border-radius: 100px;
    margin-block: 12px;
}

::-webkit-scrollbar-thumb {
    background: var(--color-brand-primary);
    border-radius: 100px;
}

/* #endregion */

/* Message *//* #region */

.message {
    position: fixed;
    width: max-content;
    max-width: 90vw;
    top: 75vh;
    left: 50%;
    transform: translateX(-50%) scale(0.9);
    transform-origin: center;
    background-color: var(--color-brand-primary);
    color: var(--color-background-default);
    padding: var(--spacing-l) var(--spacing-xl);
    text-align: center;
    text-wrap: pretty;
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-xl);
    line-height: 1.2;
    border-radius: var(--border-radius-l);
    box-shadow: var(--box-shadow);
    opacity: 0;
    z-index: 999;
    animation: message--opacity 6s ease forwards, message--scale 6s ease-out forwards;
}

@keyframes message--opacity {
    0% {
        opacity: 0;
    }
    15% {
        opacity: 1;
    }
    58% {
        opacity: 1;
    }
    100% {
        opacity: 0;
    }
}

@keyframes message--scale {
    0% {
        transform: translateX(-50%) scale(0.9);
    }
    100% {
        transform: translateX(-50%) scale(1.0);
    }
}

/* #endregion */



/* Layout *//* #region */

body {
    display: grid;
    /* * Erklärt das Layout in Reihen:
    * 1. auto: Header (nimmt nur so viel Platz ein, wie er braucht)
    * 2. 1fr:  Hauptinhalt (nimmt den gesamten freien, verbleibenden Platz ein)
    * 3. auto: Footer (nimmt nur so viel Platz ein, wie er braucht)
    */
    grid-template-rows: auto 1fr auto;
    gap: var(--spacing-xxl) 0;
    font-size: var(--font-size-base);
    font-family: var(--font-family-base);
    color: var(--color-text-default);
    background: var(--color-background-default);
    min-height: 100vh;
    /* overflow-x: hidden; */
}

header {
    grid-row: 1;
}

main {
    view-transition-name: main;
    grid-row: 2;
    width: clamp(240px, 100%, 1440px);
    margin: var(--spacing-xxl) auto 0 auto;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-l);
}

footer {
    grid-row: 3;
}

section {
    margin: var(--spacing-xl) auto;
    max-width: 90vw;
}

/* #endregion */

/* Header *//* #region */

.header {
    width: 100%;
    height: clamp(96px, 128px, 128px);
    box-shadow: var(--box-shadow);
    position: sticky;
    top: 0;
    background-color: var(--color-background-default);
    z-index: 9;
}

.header_wrapper {
    max-width: 1280px;
    height: 100%;
    display: flex;
    justify-content: space-between;
    margin: auto;
    padding: 0 var(--spacing-s);
    gap: var(--spacing-l);
}

.header__logo {
    max-width: 192px;
    padding: var(--spacing-xxs) var(--spacing-m);
    cursor: pointer;
    margin-top: 24px;
    transform: scale(1) rotate(0deg);
    transition: all 0.5s ease;

    &:hover {
        transform: scale(1.05) rotate(-2deg);
    }
}

.header__nav {
    position: relative;
    margin-top: 36px;
    margin: auto 0;
}

.header__nav ul {
    list-style: none;
    display: flex;
    flex-wrap: nowrap;
    gap: var(--spacing-m);
}

.header__nav ul li a, .header__nav ul li button {
    padding: var(--spacing-xxs) var(--spacing-m) var(--spacing-xxs) var(--spacing-m);
    margin: 0;
    color: var(--color-brand-primary);
    border-radius: var(--border-radius-l);
    font-family: var(--font-family-accent);
    font-weight: var(--font-weight-regular);
    font-size: var(--font-size-xl);
    cursor: pointer;
    transition: all 0.25s ease;

    &:hover, &:focus  {
        color: var(--color-background-default);
        background-color: var(--color-brand-primary);
    }

    & span {
        font-size: var(--font-size-xl);
        display: inline-block;
        vertical-align: middle;
        padding-bottom: 8px;
    }

    &.is-active {
        color: var(--color-background-default);
        background-color: var(--color-brand-primary);
    }

}

.nav__item {
    display: inline-block;
    transform-origin: center;
    transform: scale(1);


    &:hover, &:focus {
        transform: scale(1.1);
        margin: 0 var(--spacing-xs);
    }
}

#nav__quartalsplaene {
    position: absolute;
    bottom: -68px;
    right: 50%;
    transform: translateX(50%);

    display: flex;
    flex-direction: row;
    align-items: center;
    gap: var(--spacing-xs);


    color: var(--color-brand-primary);
    background-color: var(--color-background-default);
    padding: var(--spacing-xxs) var(--spacing-m) var(--spacing-xxs) var(--spacing-m);
    border: solid 1px var(--color-brand-primary);
    border-radius: var(--border-radius-l);
    font-family: var(--font-family-accent);
    font-weight: var(--font-weight-regular);
    font-size: var(--font-size-l);
    cursor: pointer;
    transition: all 0.25s ease;

    &:hover, &:focus  {
        color: var(--color-background-default);
        background-color: var(--color-brand-primary);
    }
}

#nav__quartalsplaene--mobile {
    padding: var(--spacing-xxs) var(--spacing-m) var(--spacing-xxs) var(--spacing-m);
    font-size: var(--font-size-l);
}

/* Mobile Navigation */
.nav__mobile {
    display: none;
    /* position: sticky;
    top: 0; */
}

#nav__mobile--menu {
    display: none;
}

.nav__mobile .nav__mobile--open span {
    color: var(--color-brand-primary);
    font-size: var(--font-size-xxl);
    font-weight: 700;
    padding: var(--spacing-l);
    margin: auto;
    border-radius: var(--border-radius-l);
    cursor: pointer;
}


.nav__mobile--menu {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-l);
    position: fixed;
    top: 0;
    right: -100%;
    padding: var(--spacing-l);
    z-index: 9;
    width: clamp(240px, 384px, 97.5vw);
    height: fit-content;
    border-radius: 0 0 0 var(--border-radius-xl);
    background-color: var(--color-background-default);
    box-shadow: var(--box-shadow);
    transition: all 0.5s ease-out;
}

.nav__mobile--icons {
    display: flex;
    justify-content: space-around;
    width: 100%;
}

.nav__mobile--icon span {
    color: var(--color-background-default);
    background-color: var(--color-brand-primary);
    font-size: var(--font-size-xxl);
    font-weight: 500;
    padding: var(--spacing-m);
    border-radius: var(--border-radius-xl);
    cursor: pointer;
    top: 0;
    right: var(--spacing-xl);
}

.nav__mobile--buttons {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-l);
    width: 90%;

    & a {
        width: 100%;
    }
}

#nav__mobile--menu:checked ~ .nav__mobile--menu {
    right: 0%;
    transition: all 0.5s ease-out;
}


#nav__mobile--menu:checked ~ #nav__mobile--overlay {
    height: 100%;
    width: 100%;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 8;
    backdrop-filter: blur(4px);
    transition: backdrop-filter 0.5s ease-out;
    transition: all 0.5s ease-out;
}
/* #endregion */

/* Footer *//* #region */

.footer {
    view-transition-name: footer;
    background-color: var(--color-brand-primary);
    color: var(--color-background-default);
    box-shadow: var(--box-shadow);
}

.footer__wrapper {
    display: grid;
    grid-template-rows: auto 42px;
    gap: var(--spacing-l);
    padding: var(--spacing-xl) var(--spacing-m) var(--spacing-s) var(--spacing-m);
    max-width: 1280px;
    margin: auto;
}

.footer__content {
    display: flex;
    gap: var(--spacing-xxl);
    flex-wrap: wrap;
    justify-content: space-between;
}

.footer__logos {
    display: flex;
    gap: var(--spacing-xxxl);
    align-items: center;
    flex-wrap: wrap;

    & a {
        transform: scale(1);
        transition: all 0.25s ease;
    }

    & a:hover {
        transform: scale(1.05);
    }
}

.footer__buttons {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-m);

    & .button {
        width: 192px;
        text-align: center;
    }
}

.footer__meta {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    font-weight: var(--font-weight-light);

    & .footer__meta--links {
        display: flex;
        gap: var(--spacing-m);
    }

    & a:hover, &:focus {
        text-decoration: underline;
    }
}

/* #endregion */

/* Dialog *//* #region */

@starting-style {
    dialog[open] {
        opacity: 0!important;
        transform: scale(0.95)!important;
    }
    dialog[open]::backdrop {
        backdrop-filter: blur(0px)!important;
        -webkit-backdrop-filter: blur(0px)!important;
        background-color: rgba(0, 0, 0, 0)!important;
    }
}

dialog {
    width: 100%;
    height: 100%;
    margin: auto;
    padding: 0;
    overflow: hidden;
    border: 0px solid;
    background: none;
    outline: none;
    opacity: 0;
    box-shadow: none;
    transform: scale(0.9);
    transition: all 0.25s ease allow-discrete;

    &[open] {
        opacity: 1;
        transform: scale(1);
    }

    &::backdrop {
        backdrop-filter: blur(0px);
        -webkit-backdrop-filter: blur(0px);
        background-color: rgba(0, 0, 0, 0);
        transition: all 0.25s ease allow-discrete;
    }

    &[open]::backdrop {
        backdrop-filter: blur(3px);
        -webkit-backdrop-filter: blur(3px);
        background-color: rgba(0, 0, 0, 0.01);
    }

    & .dialog {
        position: absolute;
        left: 50%;
        top: 50%;
        transform: translate(-50%, -50%);
        max-height: 92.5svh;
    }

}

.dialog {
    display: flex;
    flex-direction: column;
    padding: var(--spacing-s) var(--spacing-m);
    box-shadow: var(--box-shadow);
    border-radius: var(--border-radius-l);
    background-color: var(--color-background-default);
}

.dialog__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--spacing-m);
    padding: var(--spacing-m) var(--spacing-l) 0 var(--spacing-l);

    & .dialog__title {
        font-family: var(--font-family-accent);
        font-size: var(--font-size-xl);
        font-weight: var(--font-weight-bold);
        color: var(--color-brand-primary);
    }

    & .dialog__closebutton {
        font-size: var(--font-size-xxl);
        width: clamp(64px, 64px, 64px);
        height: clamp(64px, 64px, 64px);
        border-radius: var(--border-radius-l);
        display: flex;
        justify-content: center;
        align-items: center;
        transition: all 0.25s ease;
        color: var(--color-brand-primary);
        margin-right: calc(-1 * var(--spacing-s));
        padding-top: 2px;

        &:hover,
        &:focus {
            background-color: var(--color-brand-primary);
            color: var(--color-background-default);
        }
    }
}

.dialog__body {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-m);
    overflow: auto;
    padding: var(--spacing-m) var(--spacing-l);
    color: var(--color-text-default);
}

.dialog__footer {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: var(--spacing-m) var(--spacing-l);
    gap: var(--spacing-m);
}

.dialog--width-s {
    max-width: 90vw;
    width: 512px;
}

.dialog--width-m {
    max-width: 95vw;
    width: 640px;
}

/* #endregion */



/* Typography *//* #region */

.text--link {
    color: var(--color-brand-primary);
    font-weight: 600;
    cursor: pointer;

    &:hover, &:focus  {
        text-decoration: underline;
    }
}

a {
    text-decoration: none;
    color: inherit;
    cursor: pointer;
}

p, span {
    line-height: 1.5;
    text-wrap: pretty;
}

b {
    font-weight: var(--font-weight-semibold);
}

li::marker {
    color: var(--color-brand-primary);
}

/* #endregion */

/* Buttons *//* #region */

button {
    border: 0px solid;
    outline: none;
    font-family: inherit;
    color: inherit;
    background-color: transparent;
    cursor: pointer;
}

.button {
    display: flex;
    justify-content: center;
    align-items: center;
    text-wrap: nowrap;
    gap: var(--spacing-xs);
    width: fit-content;

    & .material-symbols-outlined {
        font-size: var(--font-size-xl);
        transition: all 0.25s ease;
    }

    &:hover .material-symbols-outlined {
        transform: scale(1.15);
    }
}

.button--s {
    padding: var(--spacing-xs) var(--spacing-s);
    border-radius: var(--border-radius-m);
    font-size: var(--font-size-l);
    font-weight: var(--font-weight-bold);
}

.button--m {
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-regular);
    padding: var(--spacing-xs) var(--spacing-l);
    border-radius: var(--border-radius-l);
}

.button--primary {
    font-family: var(--font-family-accent);
    letter-spacing: 1px;
    color: var(--color-background-default);
    background-color: var(--color-brand-primary);
    transform-origin: center;
    transition: all 0.25s ease;

    &:hover,
    &:focus {
        transform: scale(1.025);
    }

    &:hover #pfeil-schnuppern, &:focus #pfeil-schnuppern {
        transform: scale(1) rotate(-2deg) translate(0, -4px);
    }
}

.button--secondary {
    font-family: var(--font-family-accent);
    letter-spacing: 1px;
    background-color: var(--color-background-default);
    color: var(--color-brand-primary);
    border: solid 2px var(--color-brand-primary);
    transition: all 0.25s ease;
    &:hover,
    &:focus {
        background-color: var(--color-brand-primary);
        color: var(--color-background-default);
    }
}

.button--tertiary {
    font-family: var(--font-family-accent);
    letter-spacing: 1px;
    background-color: var(--color-background-default);
    color: var(--color-brand-primary);
    transition: all 0.25s ease;
    &:hover,
    &:focus {
        transform: scale(1.025);
    }
}

.button--quaternary {
    font-family: var(--font-family-accent);
    letter-spacing: 1px;
    background-color: var(--color-brand-primary);
    color: var(--color-background-default);
    border: solid 2px var(--color-background-default);
    transition: all 0.25s ease;
    &:hover,
    &:focus {
        background-color: var(--color-background-default);
        color: var(--color-brand-primary);
    }
}

.button--disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

/* #endregion */

/* Form *//* #region */

.form__column {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-m);
    width: 100%;
}

.form__row {
    display: flex;
    flex-direction: row;
    gap: var(--spacing-s);
    align-items: flex-end;
}

input, textarea {
    border: 0;
    border-radius: 0%;
    outline: none;
    width: clamp(64px, 100%, 960px);
    font-family: var(--font-family-base);
    font-size: var(--font-size-m);
    vertical-align: sub;
    border-bottom: 1px solid var(--color-text-muted);
    color: var(--color-text-default);
    background-color: var(--color-background-default);
}

select {
    -webkit-appearance: none; /* For Chrome/Safari */
    -moz-appearance: none;    /* For Firefox */
    appearance: none;         /* Standard property */
    border-radius: var(--border-radius-m);
    border: 2px solid var(--color-brand-primary);
    padding: var(--spacing-xs) var(--spacing-m);
    outline: none;
    width: clamp(64px, 100%, 960px);
    margin-bottom: var(--spacing-s);
    font-family: var(--font-family-base);
    font-size: var(--font-size-m);
    vertical-align: sub;
    color: var(--color-text-default);
    background-color: var(--color-background-default);
    cursor: pointer;
}

.custom-select-wrapper {
    position: relative;

    &::after {
        content: '\25BC';
        position: absolute;
        top: 10%; /* Center vertically */
        right: var(--spacing-s); /* Position from the right */
        font-size: var(--font-size-l);
        color: var(--color-brand-primary);
        pointer-events: none; /* Allows clicks to pass through to the select */
    }

}

textarea {
    padding: 0.75rem 0rem 0rem 0.25rem;
    min-height: 2.5rem;
    height: 6rem;
    max-height: 9rem;
    resize: vertical;
    field-sizing: content;
}

form label {
    margin-left: 2px;
    font-size: var(--font-size-base);
    font-family: var(--font-family-accent);
    color: var(--color-text-muted);
    letter-spacing: 1px;
    transition: all 0.25s ease;
}

input:focus ~ label, textarea:focus ~ label, select:focus ~ label {
    color: var(--color-text-default);
}

input[type="checkbox"] {
    margin: 0 2px 0 0;
    width: clamp(16px, 16px, 16px);
    height: clamp(16px, 16px, 16px);
    accent-color: var(--color-brand-primary);
}

.grecaptcha-badge {
    display: none!important;
}

/* #endregion */



/* Hero *//* #region */

.hero {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--spacing-xl);
}

.hero__content {
    display: flex;
    flex-direction: column;
    max-width: min(544px, 90vw);
    gap: var(--spacing-m);
    opacity: 0;
    z-index: 2;
    animation: fade-right-hero-content 1s ease-out forwards;
    animation-delay: 0.4s;
}

    @keyframes fade-right-hero-content {
        from {
            opacity: 0;
            translate: -64px 0;
        }
        to {
            opacity: 1;
            translate: 0 0;
        }
    }

.hero__title {
    font-family: var(--font-family-accent);
    font-size: clamp(2.5rem, 8vw + 1.25rem, 4rem);
    word-break: break-word;
    line-height: 1.2;
    text-wrap: balance;
    letter-spacing: 2px;
    color: var(--color-brand-primary);
}

.hero__description {
    font-size: var(--font-size-l);
    font-family: var(--font-family-accent);
    line-height: 1.5;
    color: var(--color-text-muted);
}

.hero__buttons {
    display: flex;
    gap: var(--spacing-m);
    align-items: flex-end;
}

.hero__image {
    z-index: 1;
    overflow: hidden;
    margin-top: var(--spacing-s);
    flex: 1;
    rotate: -3deg;
    border-radius: var(--border-radius-xl);
    opacity: 0;
    animation: ZoomIn 1.2s ease 0.2s forwards;
    transition: all 0.25s ease;

    & img {
        animation: hero__image 7.5s infinite alternate ease;
        object-fit: cover;
    }
    &:hover {
        transform: scale(1);
        rotate: 3deg;
    }
}

    @keyframes hero__image {
        0% {
            transform: scale(1.05);
        }
        100% {
            transform: scale(1.15);
        }
    }

    @keyframes ZoomIn {
        from {
            opacity: 0;
            transform: scale(0.85) rotate(6deg);
        }
        to {
            opacity: 1;
            transform: scale(1) rotate(0deg);
        }
    }

.hero__image--stufen {
    /* margin-top: -64px; */
    scale: 1;
    rotate: 4deg;
    flex: 1;
    opacity: 0;
    animation: ZoomIn 1.2s ease 0.2s forwards;
    transition: all 0.25s ease;

    & img {
        max-height: min(608px, 80vh);
        object-fit: contain;
        animation: hero__image--stufen 7.5s infinite alternate ease;
    }

    &:hover {
        scale: 1.1;
        rotate: -1deg;
    }
}

    @keyframes hero__image--stufen {
        0% {
            transform: scale(1);
        }
        100% {
            transform: scale(1.05);
        }
    }

.hero:has(.hero__image--stufen) {
    margin-top: -32px;
    gap: var(--spacing-xxl);
}

#pfeil-schnuppern {
    position: absolute;
    width: 256px;
    top: 92px;
    right: 112px;
    rotate: -47.5deg;
    z-index: 2;
    opacity: 0;
    transform-origin: center;
    transition: all 0.25s ease;
    overflow: hidden;
    animation: arrow-bounce 1s ease-in-out 1s forwards;
}

@keyframes arrow-bounce {
    0% {
        opacity: 0;
        transform: scale(0.7) translate(-32px, 0px) rotate(6deg);
    }
    40% {
        opacity: 1;
    }
    45% {
        transform: scale(1.08);
    }
    60% {
        transform: scale(0.96);
    }
    80% {
        transform: scale(1.03);
    }
    100% {
        opacity: 1;
        transform: scale(1) translate(0, 0) rotate(0);
    }
}

#kontakt {
    opacity: 0;
    animation: fade-top 1s ease forwards!important;
    animation-timeline: view()!important;
    animation-range: entry 00% entry 80%!important;
}

    @keyframes fade-top {
        from {
            opacity: 0;
            translate: 0 64px;
        }
        to {
            opacity: 1;
            translate: 0 0;
        }
    }

/* #endregion */

/* Cards *//* #region */


.cards {
    width: 100%;
    max-width: 95vw;
    display: grid;
    justify-content: center;
    grid-template-columns: repeat(auto-fit, 256px);
    gap: var(--spacing-xxl);
    opacity: 0;
    animation: fade-top-cards 1.25s ease forwards;
    animation-delay: 0.6s;
    animation-range: entry 0% entry 80%;
    transition: rotate 0.25s ease-in;

    &:hover {
        rotate: 0deg;
    }
}

@keyframes fade-top-cards {
    from {
        opacity: 0;
        translate: 0 64px;
    }
    to {
        opacity: 1;
        translate: 0 0;
    }
}

@media (max-width: 1230px) {
    .cards {
        max-width: min(640px, 95vw);
        gap: var(--spacing-xl);
    }
}

.cards--shop {
    grid-template-columns: repeat(auto-fit, minmax(384px, 448px));
    row-gap: var(--spacing-xxxl);
}

.card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-m);
    padding: var(--spacing-m) var(--spacing-xxl);
    box-shadow: var(--box-shadow);
    border-radius: var(--border-radius-xl);
    background-color: var(--color-background-default);
    text-align: center;
    outline: none;
    transition: 0.1s ease;

    transform-style: preserve-3d;
    transform:
        perspective(1000px)
        rotateY(var(--rotateY))
        rotateX(var(--rotateX));

    & .card__image {
        transform:
            translateZ(32px)
    }
}

a .card__image img {
    width: auto;
    height: 128px;
}

.card__title {
    font-family: var(--font-family-accent);
    font-size: var(--font-size-xl);
    color: var(--color-brand-primary);
}

.card__image {

    & img {
        max-width: 144px;
        transform: scale(0.95);
        transition: transform 0.3s ease;
    }
}

.card:hover .card__image img,
.card:focus .card__image img {
    /* Scale the image up by 10% */
    transform: scale(1.05);
}

.card__description {
    margin-top: var(--spacing-xs);
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-light);
    color: var(--color-text-default);
}

.card__description--shop {
    text-align: left;
    padding-bottom: var(--spacing-l);
}

.card__price {
    position: absolute;
    background: var(--color-brand-primary);
    color: var(--color-background-default);
    padding: var(--spacing-xs) var(--spacing-m);
    border-radius: var(--border-radius-m);
    font-family: var(--font-family-accent);
    font-size: var(--font-size-l);
    font-weight: var(--font-weight-bold);
    bottom: -32px;
    left: 50%;
    transform: translateX(-50%);
}

/* #endregion */

/* Stack *//* #region */

.stack {
    width: 90%;
    display: flex;
    align-items: center;
}

.stack__card {
    flex: 2;
    padding: var(--spacing-xl) var(--spacing-xxl) var(--spacing-xxl) var(--spacing-xxl);
    box-shadow: var(--box-shadow);
    border-radius: var(--border-radius-xl);
    background-color: var(--color-brand-primary);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-m);

    & h2 {
        color: var(--color-background-default);
        font-family: var(--font-family-accent);
        font-weight: var(--font-weight-regular);
        font-size: clamp(1.5rem, 5vw + 1.1rem, 2.5rem);
    }

    & h3 {
        color: var(--color-background-default);
        font-family: var(--font-family-accent);
        font-weight: var(--font-weight-bold);
        letter-spacing: 1px;
        font-size: clamp(1.25rem, 5vw + 1.1rem, 1.5rem);
    }

    & img {
        border-radius: var(--border-radius-l);
        margin-top: var(--spacing-m);
        width: 100%;
    }

    & p {
        color: var(--color-background-default);
        font-size: var(--font-size-m);
        font-weight: var(--font-weight-light);
    }
}

.stack__sidecard {
    flex: 3;
    padding: var(--spacing-xl) var(--spacing-xxl);
    box-shadow: var(--box-shadow);
    border-radius: var(--border-radius-xl);
    background-color: var(--color-background-default);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-m);

    & h2 {
        color: var(--color-brand-primary);
        font-family: var(--font-family-accent);
        font-weight: var(--font-weight-regular);
        font-size: var(--font-size-xxl);
    }

    & p {
        color: var(--color-text-default);
        font-size: var(--font-size-m);
        font-weight: var(--font-weight-light);
    }
}

.stack__card--right {
    margin-left: calc(-1 * var(--spacing-m));
    rotate: 2deg;
    opacity: 0;
    animation: fade-left-card linear forwards;
    animation-timeline: view();
    animation-range: entry 0% entry 80%;
    transition: rotate 0.25s ease;

    &:hover {
        rotate: 0deg;
    }
}

.stack__card--left {
    margin-right: calc(-1 * var(--spacing-m));
    rotate: -2deg;
    opacity: 0;
    animation: fade-right-card linear forwards;
    animation-timeline: view();
    animation-range: entry 0% entry 80%;
    transition: rotate 0.25s ease;

    &:hover {
        rotate: 0deg;
    }
}

@keyframes fade-right-card {
    from {
        opacity: 0;
        translate: -128px 0;
    }
    to {
        opacity: 1;
        translate: 0 0;
    }
}

@keyframes fade-left-card {
    from {
        opacity: 0;
        translate: 128px 0;
    }
    to {
        opacity: 1;
        translate: 0 0;
    }
}

.stack__buttongroup {
    display: flex;
    gap: var(--spacing-m);
    transform: translateX(-4px);
    margin-top: var(--spacing-s);
    flex-wrap: wrap;
}

.stack__leitende {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
    border-radius: var(--border-radius-l);
    gap: var(--spacing-s);
    max-height: 448px;
    overflow: auto;
    margin: 0 -16px 0 -16px;

    & .leitende {
        display: grid;
        overflow: hidden;
        border-radius: var(--border-radius-m);
        width: 216px;
        height: 288px;

        & img {
            grid-column: 1;
            grid-row: 1;
            transform: scale(1.5) translateX(6px);
            transition: transform 0.3s ease;
            transform-origin: 47.5% 50%;
            z-index: 1;
        }

        & span {
            grid-column: 1;
            grid-row: 1;
            width: 216px;
            text-align: center;
            align-self: start;
            background-color: rgba(0, 0, 0, 0.35);
            color: var(--color-background-default);
            padding: var(--spacing-xxs) var(--spacing-xs);
            font-size: var(--font-size-l);
            font-family: var(--font-family-accent);
            font-weight: var(--font-weight-bold);
            letter-spacing: 1px;
            z-index: 2;
        }

        &:hover img {
            transform: scale(2) translateX(4px);
        }
    }
}

.stack__image {
    padding: 8px;

    & img {
        margin: 0!important;
    }
}

/* #endregion */



/* *Media *//* #region */

@media (max-width: 1024px) {

    section {
        max-width: 95vw;
    }
    main {
        gap: 0;
    }

    .header {
        max-height: 96px;
    }
    .header_wrapper {
        gap: 0;
    }
    .header__nav {
        display: none;
    }
    .nav__mobile, .nav__mobile--menu {
        display: flex;
    }

    .hero {
        flex-direction: column;
        align-items: center;
    }
    .hero__content {
        text-align: center;
    }
    #kontakt .hero__content {
        text-align: left!important;
    }


    .hero__image {
        max-width: min(768px, 95vw);
    }
    .hero__buttons {
        justify-content: center;
    }

    .stack {
        max-width: min(768px, 95vw);
        flex-direction: column;
    }
    .stack__card--left, .stack__card--right  {
        margin-left: 0;
        margin-right: 0;
    }

    .form__row {
        flex-direction: column;
        width: 100%;

        & div  {
            width: 100%;
        }
    }

    .footer__content {
        flex-direction: column;
        align-items: center;
        gap: var(--spacing-l);
    }

    .footer__logos {
        justify-content: center;
        gap: var(--spacing-m);
    }


}

@media (max-width: 576px) {
    .header__logo {
        max-width: 128px;
        transform: translateY(-8px);
    }
    .hero__buttons {
        flex-direction: column;
        align-items: center;
    }
    #pfeil-schnuppern {
    position: absolute;
        width: 128px;
        top: 76px;
        right: 184px;
        rotate: -45deg;
        z-index: 2;
        transition: all 0.25s ease;
        overflow: hidden;
    }
    .cards--shop {
        grid-template-columns: repeat(auto-fit, minmax(240px, 100%));
    }
    .footer__meta {
        flex-direction: column;
        align-items: center;
    }
}

@media (max-width: 384px) {
    :root {
        --spacing-xxs: 0.250rem;
        --spacing-xs: 0.500rem;
        --spacing-s: 0.750rem;
        --spacing-m: 1.000rem;
        --spacing-l: 1.125rem;
        --spacing-xl: 1.250rem;
        --spacing-xxl: 1.500rem;
        --spacing-xxxl: 2rem;
    }
    .header__logo {
        max-width: 112px;
        transform: translateY(-12px);
    }
    .footer__metalinks, .footer__copyright {
        font-size: var(--font-size-s);
    }
}

/* #endregion */