/*
    Bueren / Sektion "Ausgewählte Projekte"
    =======================================
    Asymmetrisches 12-Spalten-Raster: je nach Feld "groesse" der
    ProjektKarte nimmt eine Kachel 8 oder 4 Spalten und 500px oder 400px
    Höhe ein (siehe GROESSE_CHOICES in models.py – die Werte dort
    entsprechen 1:1 den Modifier-Klassen hier). Beim Hover schiebt sich
    ein Verlaufs-Overlay mit Kategorie, Titel und Detailtext über das Bild.
*/

.projekte {
    padding-block: 80px;
    background: var(--farbe-surface);
}

.projekte__intro {
    max-width: 40rem;
    margin-bottom: 48px;
}

.projekte__headline {
    margin-bottom: 8px;
    font-size: 32px;             /* Skalenstufe "headline-lg" */
    font-weight: 600;
    line-height: 1.2;
    letter-spacing: -0.01em;
    color: var(--farbe-primary);
}

.projekte__text {
    font-size: 16px;             /* Skalenstufe "body-md" */
    line-height: 1.5;
    color: var(--farbe-on-surface-variant);
}

.projekte__raster {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: var(--gutter);
}

.projekt-karte {
    position: relative;
    grid-column: span 12;        /* mobil: jede Karte nimmt die volle Breite ein */
    height: 400px;
    overflow: hidden;
}

.projekt-karte__link {
    display: block;
    width: 100%;
    height: 100%;
    color: inherit;
    text-decoration: none;
}

/* Ab Tablet-Breite greift das asymmetrische Muster der Vorlage:
   "gross" = 8 Spalten, "klein" = 4 Spalten – jeweils mit eigener Höhe.
   Neue Größen-Variante? In models.GROESSE_CHOICES ergänzen und hier
   eine passende Modifier-Regel hinzufügen. */
@media (min-width: 768px) {
    .projekt-karte--gross         { grid-column: span 8; height: 500px; }
    .projekt-karte--klein         { grid-column: span 4; height: 500px; }
    .projekt-karte--klein-niedrig { grid-column: span 4; height: 400px; }
    .projekt-karte--gross-niedrig { grid-column: span 8; height: 400px; }
}

.projekt-karte__bild,
.projekt-karte__video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 450ms var(--ease-ui);
}

@media (hover: hover) and (pointer: fine) {
    .projekt-karte:hover .projekt-karte__bild,
    .projekt-karte:hover .projekt-karte__video {
        transform: scale(1.04);
    }
}

/* Platzhalter für Karten ohne hochgeladenes Foto: nutzt das
   Strukturraster-Muster, damit auch der "Leerzustand" zum Design passt
   und nie ein kaputtes <img> erscheint. */
.projekt-karte__platzhalter {
    width: 100%;
    height: 100%;
    background-color: var(--farbe-surface-container-low);
}

.projekt-karte__overlay {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 32px;
    background: linear-gradient(to top,
        rgba(36, 46, 87, 0.95),
        rgba(36, 46, 87, 0.2) 60%,
        rgba(36, 46, 87, 0));
    opacity: 0;
    transition: opacity 220ms var(--ease-ui);
}

.projekt-karte:hover .projekt-karte__overlay,
.projekt-karte:focus-within .projekt-karte__overlay {
    opacity: 1;
}

@media (hover: none) {
    .projekt-karte__overlay {
        opacity: 1;
    }
}

.projekt-karte__kategorie {
    margin-bottom: 4px;
    font-size: 12px;             /* Skalenstufe "label-md" */
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--farbe-secondary-fixed);
}

.projekt-karte__titel {
    font-size: 24px;             /* Skalenstufe "headline-md" */
    font-weight: 600;
    line-height: 1.3;
    color: var(--farbe-weiss);
}

.projekt-karte__details {
    font-size: 16px;             /* Skalenstufe "body-md" */
    color: var(--farbe-weiss);
    opacity: 0.8;
}

.projekt-karte__mehr {
    margin-top: 16px;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--farbe-secondary-fixed);
}

/* Hinweistext, falls im Admin noch keine Karten angelegt wurden (siehe {% empty %}) */
.projekte__leer {
    grid-column: span 12;
    color: var(--farbe-on-surface-variant);
    font-style: italic;
}


/*
    Projekt-Detailseite
    ===================
    Nutzt dieselben Tokens und Bausteine wie das Projekt-Raster. Die Seite ist
    bewusst ruhig aufgebaut: grosses Bild, kompakter Steckbrief, danach
    wechselnde Text-/Bildbloecke mit viel Weissraum.
*/

.projekt-detail {
    background: var(--farbe-surface);
}

.projekt-detail__hero {
    position: relative;
    height: clamp(360px, 62vh, 620px);
    overflow: hidden;
    background: var(--farbe-primary);
}

.projekt-detail__hero::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(11, 28, 48, 0.78), rgba(11, 28, 48, 0.18));
}

.projekt-detail__hero-bild {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    will-change: transform;
}

.projekt-detail__hero-inhalt {
    position: absolute;
    inset: auto 0 0;
    z-index: 1;
    padding-bottom: 64px;
    color: var(--farbe-weiss);
}

@media (max-width: 767px) {
    .projekt-detail__hero {
        height: clamp(320px, 56vh, 460px);
    }

    .projekt-detail__hero-inhalt {
        padding-bottom: 40px;
    }
}

.projekt-detail__kategorie,
.projekt-detail__label {
    margin-bottom: 12px;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.projekt-detail__kategorie {
    color: var(--farbe-secondary-fixed);
}

.projekt-detail__titel {
    max-width: 820px;
    font-size: clamp(40px, 7vw, 76px);
    font-weight: 700;
    line-height: 0.98;
    letter-spacing: -0.04em;
}

.projekt-detail__ort {
    margin-top: 20px;
    font-size: 18px;
    color: rgba(255, 255, 255, 0.82);
}

.projekt-detail__inhalt {
    padding-block: 72px 88px;
}

.projekt-detail__steckbrief {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0;
    margin-bottom: 88px;
    border-top: 1px solid var(--farbe-outline-variant);
    border-left: 1px solid var(--farbe-outline-variant);
    background: var(--farbe-surface-container-lowest);
}

.projekt-detail__steckbrief div {
    min-height: 128px;
    padding: 24px;
    border-right: 1px solid var(--farbe-outline-variant);
    border-bottom: 1px solid var(--farbe-outline-variant);
}

.projekt-detail__steckbrief dt {
    margin-bottom: 12px;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--farbe-on-surface-variant);
}

.projekt-detail__steckbrief dd {
    margin: 0;
    font-size: 18px;
    line-height: 1.35;
    color: var(--farbe-primary);
}

.projekt-detail__bloecke {
    margin-bottom: 72px;
}

.projekt-detail__block {
    margin-bottom: 88px;
}

.projekt-detail__block:last-child {
    margin-bottom: 0;
}

.projekt-detail__abschnitt {
    display: grid;
    grid-template-columns: 1fr;
    gap: 24px;
    max-width: 1040px;
    margin-bottom: 56px;
}

.projekt-detail__abschnitt--versetzt {
    margin-left: auto;
}

.projekt-detail__abschnitt--abschluss {
    margin-bottom: 72px;
}

.projekt-detail__label {
    color: var(--farbe-secondary);
}

.projekt-detail__abschnitt h2 {
    max-width: 460px;
    font-size: clamp(28px, 4vw, 44px);
    font-weight: 600;
    line-height: 1.12;
    letter-spacing: -0.03em;
    color: var(--farbe-primary);
}

.projekt-detail__text {
    font-size: 18px;
    line-height: 1.7;
    color: var(--farbe-on-surface-variant);
}

.projekt-detail__text p + p {
    margin-top: 18px;
}

.projekt-detail__bildblock {
    height: clamp(320px, 54vw, 680px);
    margin: 0 0 80px;
    overflow: hidden;
    background: var(--farbe-surface-container-low);
}

.projekt-detail__bildblock--schmal {
    max-width: 920px;
    margin-left: auto;
}

.projekt-detail__block .projekt-detail__bildblock {
    margin-bottom: 0;
}

.projekt-detail__bildblock img,
.projekt-detail__platzhalter {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.projekt-detail__navigation {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
    padding-top: 32px;
    border-top: 1px solid var(--farbe-outline-variant);
}

.projekt-detail__nav-link {
    display: flex;
    align-items: center;
    gap: 16px;
    min-height: 80px;
    padding: 20px 24px;
    background: var(--farbe-surface-container-lowest);
    border: 1px solid var(--farbe-outline-variant);
    color: var(--farbe-primary);
    text-decoration: none;
    transition: border-color var(--uebergang), background-color var(--uebergang);
}

.projekt-detail__nav-link:hover {
    background: var(--farbe-surface-container-low);
    border-color: var(--farbe-secondary);
}

.projekt-detail__nav-link--weiter {
    justify-content: flex-end;
    text-align: right;
}

.projekt-detail__nav-pfeil {
    font-size: 28px;
    color: var(--farbe-secondary);
    flex-shrink: 0;
}

.projekt-detail__nav-text {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.projekt-detail__nav-label {
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--farbe-on-surface-variant);
}

.projekt-detail__nav-titel {
    font-size: 16px;
    font-weight: 600;
    line-height: 1.35;
}

@media (min-width: 768px) {
    .projekt-detail__steckbrief {
        grid-template-columns: repeat(2, 1fr);
    }

    .projekt-detail__abschnitt {
        grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
        gap: 72px;
    }

    .projekt-detail__block--klein-rechts,
    .projekt-detail__block--klein-links {
        display: grid;
        grid-template-columns: minmax(0, 1.05fr) minmax(280px, 0.75fr);
        gap: 56px;
        align-items: center;
    }

    .projekt-detail__block--klein-links {
        grid-template-columns: minmax(280px, 0.75fr) minmax(0, 1.05fr);
    }

    .projekt-detail__block--klein-rechts .projekt-detail__abschnitt,
    .projekt-detail__block--klein-links .projekt-detail__abschnitt {
        display: block;
        margin: 0;
    }

    .projekt-detail__block--klein-links .projekt-detail__abschnitt {
        grid-column: 2;
    }

    .projekt-detail__block--klein-links .projekt-detail__bildblock {
        grid-column: 1;
        grid-row: 1;
    }

    .projekt-detail__block--klein-rechts .projekt-detail__bildblock,
    .projekt-detail__block--klein-links .projekt-detail__bildblock {
        height: clamp(300px, 38vw, 520px);
        margin: 0;
    }

    .projekt-detail__block--klein-rechts .projekt-detail__text,
    .projekt-detail__block--klein-links .projekt-detail__text {
        margin-top: 24px;
    }
}

@media (min-width: 1024px) {
    .projekt-detail__steckbrief {
        grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    }
}
