/* ==========================================================================
   FARBEN & LAYOUT-GRUNDLAGEN
   ========================================================================== */
:root {
    --bg-page: #0A192F;
    --bg-fade-end: #030816;
    --bg-element: #112240;

    --text-main: #E2E8F0;
    --text-muted: #94A3B8;
    --navy-light: #3182CE;

    --font-main: 'Outfit', sans-serif;
    --font-code: 'Space Mono', monospace;
}

/* --- SCROLL SNAPPING SETUP --- */
html {
    scroll-snap-type: y proximity !important; /* Erlaubt freieres Scrollen auf Desktop */
    scroll-behavior: smooth;
}

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

body {
    background-color: var(--bg-page);
    background-image: radial-gradient(rgba(49, 130, 206, 0.15) 1px, transparent 1px),
    linear-gradient(180deg, var(--bg-page) 0%, var(--bg-fade-end) 100%);
    background-size: 32px 32px, 100% 100%;
    background-attachment: fixed;
    min-height: 100vh;
    color: var(--text-main);
    font-family: var(--font-main);
    max-width: 100vw;
    overflow-x: clip;
}

/* ==========================================================================
   NAVIGATION & HERO
   ========================================================================== */
nav {
    position: fixed;
    top: 0;
    width: 100%;
    padding: 1.5rem 5%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-family: var(--font-code);
    font-size: 0.85rem;
    z-index: 1000;

    /* Wichtig: Übergänge für den Hintergrund weich machen */
    background: rgba(10, 25, 47, 0);
    backdrop-filter: blur(0px);
    border-bottom: 1px solid transparent;
    transition: all 0.4s ease-in-out;
}

/* --- NAVIGATION (NACH SCROLL: MIT HINTERGRUND) --- */
nav.nav-scrolled {
    background: rgba(10, 25, 47, 0.85);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid rgba(49, 130, 206, 0.15);
    padding: 1.5rem 5%;
}

.nav-brand {
    font-weight: 500;
    text-transform: uppercase;
}

.nav-links {
    display: flex;
    gap: 2rem;
}

.nav-links a {
    text-decoration: none;
    color: var(--text-main);
    opacity: 0.7;
    transition: opacity 0.3s;
    text-transform: uppercase;
}

.nav-links a:hover {
    opacity: 1;
    color: var(--navy-light);
}

.hero-fullscreen {
    position: relative;
    height: 95vh;
    width: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    overflow: hidden;
    border-radius: 0 0 40px 40px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5);

    scroll-snap-align: start;
    scroll-snap-stop: always;
}

.hero-bg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center 35%;
    z-index: 1;
    animation: slowZoom 20s infinite alternate;
}

@keyframes slowZoom {
    from {
        transform: scale(1);
    }
    to {
        transform: scale(1.1);
    }
}

.hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to bottom, rgba(10, 25, 47, 0.6), rgba(3, 8, 22, 0.4));
    z-index: 2;
}

.hero-content {
    position: relative;
    z-index: 3;
    color: #FFFFFF;
}

.hero-tag {
    font-family: var(--font-code);
    letter-spacing: 2px;
    margin-bottom: 1rem;
}

.hero-content h1 {
    font-size: clamp(3rem, 8vw, 7rem);
    font-weight: 800;
    text-transform: uppercase;
    line-height: 0.95;
}

/* ==========================================================================
   GALERIE GRID
   ========================================================================== */
.gallery {
    justify-content: flex-start !important; /* Nicht mehr starr in der Mitte */
    padding-top: 18vh !important; /* Schiebt den Inhalt deutlich nach unten */
}

.contact-snap-section {
    justify-content: flex-start !important; /* Nicht mehr starr in der Mitte */
    padding-top: 15vh !important; /* Schiebt das Quadrat etwas nach unten */
}

.gallery, .about-section, .contact-snap-section {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    scroll-snap-align: start;
    scroll-snap-stop: always;
    padding: 2rem 5%;
}

.section-header {
    font-family: var(--font-code);
    font-size: 1.25rem;
    margin-bottom: 5rem;
    display: flex;
    justify-content: flex-start;
    color: var(--text-muted);
    letter-spacing: 4px;
    text-transform: uppercase;
    border: none;
}

.gallery-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2rem;
    margin-bottom: 10rem;
}

.fade-in-element {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 1s ease-out, transform 1s ease-out;
    will-change: opacity, transform;
}

.fade-in-element.visible {
    opacity: 1;
    transform: translateY(0);
}

.gallery-column {
    display: flex;
    flex-direction: column;
}

.column-header {
    padding-bottom: 1rem;
    margin-bottom: 1rem;
    border-bottom: 1px solid var(--bg-element);
}

.category-label {
    font-family: var(--font-main);
    font-size: 1.5rem;
    font-weight: 400;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--text-main);
}

.image-box {
    position: relative;
    width: 100%;
    padding-top: 140%;
    border-radius: 4px;
    overflow: hidden;
    background: var(--bg-element);
}

.portfolio-img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: grayscale(100%);
    transition: filter 0.6s ease;
}

.gallery-column:hover .portfolio-img {
    filter: grayscale(0%);
}

.about-section {
    /* Schiebt den Inhalt nach oben, damit das Padding wirkt */
    justify-content: flex-start !important;
    /* Ein Wert zwischen 15vh und 18vh sorgt für eine gute Optik unter der Nav */
    padding-top: 18vh !important;
}



.about-grid {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 4rem;
    max-width: 1200px;
    margin: 0 auto;
    align-items: center;
}

.about-sidebar {
    display: flex;
    flex-direction: column;
    gap: 2rem;
}

.about-image-wrapper {
    width: 100%;
    padding-top: 133%;
    position: relative;
    border-radius: 4px;
    overflow: hidden;
    background: var(--bg-element);
}

.about-portrait {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.tech-label-large {
    font-size: 1.3rem;
    letter-spacing: 2px;
    color: var(--navy-light); /* Das zwingt die Schrift wieder in dein System-Blau */
    font-family: var(--font-code); /* Zur Sicherheit, damit die Terminal-Schriftart bleibt */
    text-transform: uppercase;
}

.tech-label {
    font-family: var(--font-code);
    font-size: 0.9rem;
    color: var(--navy-light);
    text-transform: uppercase;
    letter-spacing: 1px;
}

.about-text h2 {
    font-size: 2.5rem;
    margin-top: 0;
    margin-bottom: 1.5rem;
    color: var(--text-main);
}

.about-text p {
    font-size: 1.1rem;
    color: var(--text-muted);
    line-height: 1.8;
    margin-bottom: 3rem;
}

/* --- LOG (Shot on Location & Impressum) --- */
.location-log {
    font-family: var(--font-code);
    margin-top: 1rem;
}

.log-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.8rem 0;
    border-bottom: 1px dashed rgba(148, 163, 184, 0.3);
    color: var(--text-main);
}

.log-info {
    font-size: 0.85rem;
    color: var(--navy-light);
    letter-spacing: 1px;
}

/* ==========================================================================
   CONTACT SQUARE & SNAPPING
   ========================================================================== */

/* Die Sektion füllt den ganzen Bildschirm und snappt ein */
.contact-snap-section {
    min-height: 100vh;
    display: flex;
    justify-content: center; /* Zentriert unseren unsichtbaren 1200px-Rahmen */
    align-items: center;
    scroll-snap-align: center;
    scroll-snap-stop: always;
    padding: 2rem 5%; /* Exakt das gleiche Seiten-Padding wie bei Gallery und About */
}

.contact-square-container {
    width: 100%;
    max-width: 1200px; /* Exakt die gleiche Breite wie dein about-grid */
    display: flex;
    justify-content: center; /* Schiebt das Quadrat bündig an die linke Kante */
}

/* Der Container für das Quadrat */
.contact-square-box {
    width: 100%;
    max-width: 650px;
    aspect-ratio: 1 / 1;
    background: rgba(17, 34, 64, 0.3);
    border: 1px solid rgba(49, 130, 206, 0.2);
    padding: 4rem;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    backdrop-filter: blur(50px);
}

/* Form Layout Anpassungen */
.form-log-layout {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    margin-top: 2rem;
}

.form-row {
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
    border-bottom: 1px dashed rgba(148, 163, 184, 0.2);
    padding-bottom: 1.5rem;
}

.form-row.no-border {
    border-bottom: none;
}

.form-row label {
    font-family: var(--font-code);
    font-size: 1rem;
    color: var(--navy-light);
}

/* Größere Textfelder */
.contact-form-styled input,
.contact-form-styled textarea {
    background: transparent;
    border: none;
    color: var(--text-main);
    font-family: var(--font-main);
    font-size: 0.9rem; /* Größere Schrift */
    width: 100%;
    outline: none;
    padding: 0.5rem 0;
}

.contact-form-styled textarea {
    resize: none;
}

/* Der massive Button am unteren Ende des Quadrats */
.submit-action-btn {
    width: 100%;
    padding: 1rem;
    background: transparent;
    border: 1px solid var(--navy-light);
    color: var(--text-main);
    font-family: var(--font-code);
    font-size: 1rem;
    letter-spacing: 2px;
    cursor: pointer;
    transition: all 0.3s ease;
}

.submit-action-btn:hover {
    background: var(--navy-light);
    color: var(--bg-page);
    font-weight: bold;
}

/* ==========================================================================
   FOOTER (SEO & GEO OPTIMIZED)
   ========================================================================== */
.system-footer {
    /* Setzt sich mit der dunkleren Element-Farbe vom Hintergrund ab */
    background: var(--bg-element);
    border-top: 1px solid rgba(49, 130, 206, 0.2);
    padding: 4rem 5% 2rem;

    /* Snapping ans Ende der Seite */
    scroll-snap-align: end;
    scroll-snap-stop: always;
}

.footer-grid {
    display: grid;
    /* Macht den Footer automatisch auf dem Handy einspaltig und am PC dreispaltig */
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 3rem;
    max-width: 1200px;
    margin: 0 auto;
    border-bottom: 1px dashed rgba(148, 163, 184, 0.3);
    padding-bottom: 3rem;
}

.footer-col {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

/* --- SEO Text Styling --- */
.footer-address {
    font-family: var(--font-main);
    font-style: normal;
    color: var(--text-muted);
    line-height: 1.8;
    font-size: 0.8rem;
}

.footer-address strong {
    color: var(--text-main);
    font-family: var(--font-code);
    font-size: 0.8rem;
    font-weight: normal;
    display: block;
    margin-bottom: 0.5rem;
}

.geo-tags {
    color: var(--navy-light);
    font-size: 0.85rem;
    font-family: var(--font-code);
}

/* --- Links Styling --- */
.footer-links {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
}

.footer-links a {
    text-decoration: none;
    color: var(--text-muted);
    font-family: var(--font-code);
    font-size: 0.8rem;
    transition: all 0.3s ease;
}

.social-link,
.social-link:visited {
    color: #ffffff !important;
    text-decoration: none !important;
    font-size: 0.8rem !important;
    font-weight: 500 !important;
    letter-spacing: 2px !important;
    margin: 0 3px !important;
    transition: all 0.3s ease !important;
}

/* Cooler Terminal-Hover-Effekt: Text rückt leicht ein und wird blau */
.footer-links a:hover {
    color: var(--navy-light);
    padding-left: 10px;
}

/* --- Bottom Bar --- */
.footer-bottom {
    display: flex;
    justify-content: space-between;
    max-width: 1200px;
    margin: 2rem auto 0;
    font-family: var(--font-code);
    font-size: 0.8rem;
    color: var(--navy-light);
    opacity: 0.6;
}

/* Für sehr kleine Handybildschirme */
@media (max-width: 600px) {
    .footer-bottom {
        flex-direction: column;
        align-items: center;
        gap: 1rem;
    }
}

/* ==========================================================================
   ARCHIVE, BENTO GRID & LIGHTBOX SYSTEM (KOMPLETT & FEHLERFREI)
   ========================================================================== */

/* --- 1. HAUPT-CONTAINER --- */
.archive-container {
    padding-top: 70px !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    overflow: hidden !important;
}

.archive-controls {
    display: flex !important;
    justify-content: space-between !important; /* Label links, Buttons rechts */
    align-items: baseline !important; /* Richtet Text auf der gleichen Linie aus */
    padding-left: 5% !important;
    padding-right: 5% !important;
    margin-top: 6rem !important; /* Schiebt das gesamte Paket weiter runter */
    margin-bottom: 4rem !important;
}

.tech-label-large {
    margin: 0 !important;
    padding: 0 !important;
    white-space: nowrap !important;
}

.system-footer {
    margin-top: 10rem !important; /* <--- Hier steuerst du den Abstand auf dem Desktop (z.B. 12rem oder 15rem für noch mehr Platz) */
}

.category-nav-links {
    margin: 0 !important; /* Entfernt den Abstand nach oben */
    display: flex !important;
    gap: 1.5rem !important;
}

.nav-btn {
    font-family: var(--font-code);
    color: var(--text-muted);
    text-decoration: none;
    font-size: 0.85rem;
    letter-spacing: 2px;
    transition: all 0.3s ease;
    padding: 0.6rem 1.2rem;
    border: 1px solid rgba(49, 130, 206, 0.2);
    background: rgba(17, 34, 64, 0.5);
    text-transform: uppercase;
}

.nav-btn:hover {
    color: var(--navy-light);
    border-color: var(--navy-light);
    background: rgba(49, 130, 206, 0.15);
}

/* --- 3. BENTO WRAPPER & SEKTIONEN (ABSTÄNDE & BLAUE SCHRIFT) --- */
.bento-wrapper {
    display: block; /* Normales Block-Verhalten für korrekte Abstände */
}

.bento-section-header {
    margin-bottom: 2rem; /* Perfekter, enger Abstand von der Überschrift zu den EIGENEN Bildern */
}

.bento-section-header {
    margin-top: 10rem !important;    /* Drückt "Crowd" weiter weg vom MainFloor */
    margin-bottom: 2rem !important; /* <--- DAS HIER vergrößert den Abstand zu den EIGENEN Bildern! */
    width: 100%;
}

.bento-section-header:first-of-type {
    margin-top: 2rem !important;    /* Damit "MainFloor" ganz oben nicht zu weit runterrutscht */
}

/* --- Die dezenteren Kategorien (// Mainfloor) --- */
.bento-section-header h3 {
    font-family: var(--font-code);
    font-size: 1.2rem; /* Jetzt etwas kleiner */
    font-weight: 400; /* Jetzt dünner (normaler Text) */
    color: rgba(49, 130, 206, 1);
    letter-spacing: 2px;
    text-transform: uppercase;
    border-left: 4px solid rgba(49, 130, 206, 1);
    padding-left: 1rem;
}

/* --- 4. BENTO GRID (KLEINES RASTER) --- */
.bento-grid {
    display: grid !important;
    grid-template-columns: repeat(5, 1fr) !important;

    grid-auto-rows: 220px !important;

    gap: 1.5rem !important;
    max-width: 1300px !important; /* Wieder bei 1300px wie gewünscht */
    margin: 0 auto !important;
    width: 100% !important;
    grid-auto-flow: dense !important;
}

.bento-item {
    grid-column: span 1 !important;
    grid-row: span 1 !important;
    width: 100% !important;
    height: 100% !important;
}

.bento-item.bento-tall {
    grid-column: span 1 !important; /* 1 Platz breit */
    grid-row: span 2 !important;    /* 2 Plätze hoch */
}

/* Breite Bilder (z.B. Landschaft) */
.bento-item.bento-wide {
    grid-column: span 2 !important; /* 2 Plätze breit */
    grid-row: span 1 !important;    /* 1 Platz hoch */
}

/* Sehr große Bilder (Falls du das in JS nutzt) */
.bento-item.bento-large {
    grid-column: span 2 !important; /* 2 Plätze breit */
    grid-row: span 2 !important;    /* 2 Plätze hoch */
}

/* Das eigentliche Bild in der Box */
.bento-item img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    border-radius: 8px !important;
    -webkit-user-drag: none !important;
    user-drag: none !important;
    user-select: none !important;

    /* 2. DER WICHTIGSTE BEFEHL: Erlaubt NUR wischen nach links/rechts */
    touch-action: pan-x !important;
}

.bento-item:hover img {
    transform: scale(1.03);
}

/* --- 5. SYSTEM LIGHTBOX (VOLLBILD-GALERIE) --- */
.system-lightbox {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.7); /* Schwarzer, edler Hintergrund */
    z-index: 9999;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s ease;
    backdrop-filter: blur(5px);
}

.system-lightbox.active {
    opacity: 1;
    pointer-events: auto;
}

.lightbox-content {
    order: 2; /* Bild rutscht unter den Text */
    max-width: 90%;
    max-height: 80vh;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.8);
    border: 1px solid rgba(49, 130, 206, 0.3);
}

.lightbox-counter {
    order: 1; /* Text sitzt direkt ÜBER dem Bild */
    position: relative;
    top: auto;
    left: auto;
    bottom: auto;
    width: 90%;
    margin-bottom: 10px;
    font-family: var(--font-code);
    color: rgba(255, 255, 255, 0.7);
    font-size: 0.9rem;
}

.lightbox-btn {
    position: absolute;
    background: rgba(17, 34, 64, 0.8);
    color: var(--navy-light);
    border: 1px solid rgba(49, 130, 206, 0.3);
    font-family: var(--font-code);
    font-size: 1.5rem;
    cursor: pointer;
    border-radius: 50%;
    width: 55px;
    height: 55px;

    display: flex;
    justify-content: center;
    align-items: center;
    padding: 0;
}

.lightbox-close {
    top: 20px;
    right: 20px;
    font-size: 1rem;
    letter-spacing: 2px;
    border-radius: 40px !important;

    width: auto !important;
    height: auto !important;

    padding: 10px 25px !important;
}

.lightbox-prev {
    left: 15px;
    top: 50%;
    transform: translateY(-50%);
}

.lightbox-next {
    right: 15px;
    top: 50%;
    transform: translateY(-50%);
}

/* ==========================================================================
   6. MOBILE OPTIMIERUNG (SCHWEBENDE "PILL" NAVIGATION)
   ========================================================================== */

/* Auf Desktop Mobile-Menü verstecken */
.mobile-menu-trigger, .mobile-overlay {
    display: none;
}

@media (max-width: 768px) {
    /* ==============================================================
         FIX 1: NOT-AUS FÜR EFFEKTE, DIE DIE BUTTONS OBEN EINSPERREN
         ============================================================== */

    * {
        scroll-snap-align: none !important;
        scroll-snap-stop: normal !important;
    }

    body, main, .archive-container, .archive-controls,
    .archive-container.fade-in-element, .archive-controls.fade-in-element,
    .archive-container.visible, .archive-controls.visible {
        transform: none !important;
        will-change: auto !important;
        filter: none !important;
        backdrop-filter: none !important;
        perspective: none !important;
        display: block !important;
    }


    .archive-container {
        padding-top: 70px !important; /* Abstand nach oben halbiert! */
        overflow: visible !important;
    }

    section, .contact-snap-section, .system-footer {
        scroll-snap-align: none !important;
        scroll-snap-stop: normal !important;
    }

    /* DESKTOP-NAV AUSBLENDEN & BUTTON-PANZER */
    .nav-scrolled, nav:not(.mobile-nav-links) {
        display: none !important;
    }

    .archive-controls, .archive-controls.fade-in-element, .archive-controls.visible {
        transform: none !important;
        will-change: auto !important;
        opacity: 1 !important;
        display: block !important;
    }

    .archive-controls {
        padding-left: 5% !important;
        padding-right: 5% !important;
        margin-top: 1rem !important;
    }

    /* ==============================================================
       2. DIE NEUE SCHWEBENDE PILLE (Google Fotos Style)
       ============================================================== */
    .category-nav-links {
        display: flex !important;
        position: fixed !important;
        bottom: 30px !important;
        left: 80px !important;
        right: 25px !important;
        height: 50px !important;
        top: auto !important;

        background: rgba(10, 25, 47, 0.8) !important;
        backdrop-filter: blur(15px) !important;
        border: 1px solid rgba(49, 130, 206, 0.4) !important;
        border-radius: 40px !important;
        z-index: 99999 !important;

        margin: 0 !important;
        box-shadow: 0 15px 35px rgba(0, 0, 0, 0.4) !important;
        padding: 0 10px !important;
        overflow: hidden !important;
    }

    .category-nav-links .nav-btn {
        /* "min-width: 0" zwingt den Button, trotz langem Text bei exakt 50% zu bleiben */
        flex: 1 1 0% !important;
        min-width: 0 !important;

        display: flex !important;
        justify-content: center !important;
        align-items: center !important;

        background: transparent !important;
        border: none !important;
        font-family: var(--font-code) !important;
        color: var(--navy-light) !important;
        height: 100% !important;
        white-space: nowrap !important;

        padding: 0 8px !important;
        box-sizing: border-box !important;

        font-size: clamp(0.65rem, 2.5vw, 0.85rem) !important;

        letter-spacing: 1px !important;
    }

    nav:not(.mobile-nav-links) {
        display: none !important;
        opacity: 0 !important;
        pointer-events: none !important;
    }

    .category-nav-links::after {
        content: "" !important;
        position: absolute !important;
        left: 50% !important;
        top: 50% !important;
        transform: translate(-50%, -50%) !important;
        width: 1px !important;
        height: 30px !important;
        background-color: rgba(49, 130, 206, 0.4) !important;
        pointer-events: none !important;
    }

    .category-nav-links .nav-btn {
        width: 50% !important; /* Zwingt die Box auf exakt die Hälfte, ignoriert Textlänge */
        display: flex !important;
        justify-content: center !important;
        align-items: center !important;

        background: transparent !important;
        border: none !important;
        font-family: var(--font-code) !important;
        font-size: 0.85rem !important;
        font-weight: 500 !important;
        color: var(--navy-light) !important;
        height: 100% !important;
        white-space: nowrap !important;
    }

    .category-nav-links .nav-btn:first-child::after {
        display: none !important;
    }

    /* HAMBURGER BUTTON */
    .mobile-menu-trigger {
        position: fixed !important;
        bottom: 30px !important; /* Exakt auf derselben Höhe wie die Pille */
        left: 20px !important; /* Bündig am linken Rand */
        width: 50px !important;
        height: 50px !important; /* Perfekter Kreis */

        background: rgba(10, 25, 47, 0.7) !important;
        backdrop-filter: blur(15px) !important;
        border: 1px solid rgba(49, 130, 206, 0.4) !important;
        border-radius: 50% !important;

        display: flex !important;
        flex-direction: column !important;
        justify-content: center !important;
        align-items: center !important;
        gap: 5px !important;
        z-index: 100001 !important;
        cursor: pointer !important;
        box-shadow: 0 15px 35px rgba(0, 0, 0, 0.6) !important;
        transition: all 0.4s ease !important;
    }

    /* ============================================================== */
    /* 3. INDEX STARTSEITE: GRID */
    #gallery-root .gallery-grid {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
        gap: 2.5rem 1.2rem !important;
        padding: 0 5% !important;
        overflow-x: hidden !important;

    }

    #gallery-root .gallery-column {
        display: flex !important;
        flex-direction: column-reverse !important;
        width: 100% !important;
    }

    #gallery-root .portfolio-img {
        filter: grayscale(0%) !important;
    }

    #gallery-root .gallery-column h3 {
        margin-bottom: 0.1rem !important;
        font-size: 0.9rem !important;
        letter-spacing: 0.5px !important;
        white-space: nowrap !important;
    }

    .about-section {
        padding-top: 0.25rem !important;
    }

    /* 4. ABOUT ME */
    .about-grid {
        display: flex !important;
        padding-top: 0.25rem !important;
        flex-direction: column !important;
        align-items: flex-start !important;
    }

    .about-sidebar {
        order: 1 !important;
        display: flex !important;
        flex-direction: column !important;
        width: 100% !important;
        align-items: flex-start !important;
    }

    .about-sidebar .tech-label-large {
        order: 1 !important;
        margin-bottom: 2rem !important;
        text-align: left !important;
        width: 100% !important;
    }

    .about-image-wrapper {
        order: 2 !important;
        width: 95% !important;
        margin: 0 auto 3.5rem auto !important;
        padding-top: 0 !important;
        aspect-ratio: 2 / 3 !important;
        display: block !important;
        position: relative !important;
        box-shadow: 0 10px 40px rgba(0, 0, 0, 0.5);
        align-self: center !important;
        padding-bottom: -15px !important;
    }

    .about-text {
        order: 2 !important;
        display: flex !important;
        flex-direction: column !important;
    }

    .about-text h2 {
        order: 1 !important;
        margin-bottom: 1.5rem !important;
    }

    .about-text p {
        order: 2 !important;
        font-size: 1.2rem !important;
        margin-bottom: 4rem !important;
    }

    .about-text .tech-label {
        order: 3 !important;
        margin-top: 0 !important;
    }

    .location-log {
        order: 4 !important;
        margin-bottom: 5.5rem !important;
    }

    /* 5. CONTACT ME */
    .contact-snap-section {
        min-height: auto !important;
        padding: 0 5% !important;
        margin-top: 2rem !important;
        margin-bottom: 8rem !important;
        display: flex !important;
        justify-content: center !important;
    }

    .contact-square-box {
        width: 100% !important;
        padding: 2.5rem !important;
        transform: translateX(-5px) !important;
    }

    .system-footer {
        padding-top: 1rem !important;
        padding-bottom: 100px !important;
    }

    /* 6. CAROUSEL FÜR UNTERSEITEN */
    .bento-grid {
        width: 100vw !important;
        position: relative !important;
        left: 50% !important;
        transform: translateX(-50%) !important; /* Zieht das Grid exakt in die Mitte */

        display: flex !important;
        flex-direction: row !important;
        flex-wrap: nowrap !important;
        overflow-x: auto !important;
        overflow-y: hidden !important;
        -webkit-overflow-scrolling: touch !important;
        scroll-snap-type: x mandatory !important;

        /* Die Mathematik für die Sichtbarkeit: */
        gap: 4vw !important; /* Abstand zwischen Bildern */
        padding: 0 15vw !important; /* Drückt das erste Bild in die Mitte */
        margin-bottom: 7rem !important;

        scrollbar-width: none !important;
        -ms-overflow-style: none !important;
    }


    .bento-grid::-webkit-scrollbar,
    .gallery-grid::-webkit-scrollbar {
        display: none !important;
        width: 0 !important;
        height: 0 !important;
    }
    .bento-grid, .gallery-grid {
        scrollbar-width: none !important;
        -ms-overflow-style: none !important;
    }

    .bento-item, .bento-item.fade-in-element, .bento-item.visible, .bento-large, .bento-wide, .bento-tall {
        flex: 0 0 70vw !important;
        min-width: 70vw !important;
        max-width: 70vw !important;
        height: 60vh !important;
        scroll-snap-align: center !important;
        opacity: 0.3 !important;
        transform: scale(1) !important;
        transition: opacity 0.4s ease, transform 0.4s ease !important;
        display: block !important;
    }

    .bento-item.mobile-focus, .bento-item.fade-in-element.mobile-focus, .bento-item.visible.mobile-focus {
        opacity: 1 !important;
        transform: scale(1) !important;
    }

    .lightbox-prev,
    .lightbox-next {
        display: none !important;
    }

    #gallery-root,
    #gallery-root .bento-grid {
        flex: 0 0 100vw !important;
        min-width: 100vw !important;
        max-width: 100vw !important;
        transform: translateX(-25px) !important;
    }

    .system-footer {
        margin-top: 6rem !important;
    }

    /* ==============================================================
           7. NEUES FLYOUT-MENÜ (Kompakte Karte statt Vollbild)
           ============================================================== */
    .mobile-overlay {
        display: flex !important;
        flex-direction: column !important;
        position: fixed !important;

        top: auto !important;
        right: auto !important;
        bottom: 100px !important; /* Schwebt sicher über dem Hamburger-Button */
        left: 20px !important;

        width: 170px !important; /* Macht daraus eine saubere, feste Karte */
        height: auto !important;

        background: rgba(10, 25, 47, 0.95) !important;
        backdrop-filter: blur(20px) !important;
        border: 1px solid rgba(49, 130, 206, 0.3) !important;

        border-radius: 16px !important;

        padding: 20px !important;
        z-index: 100000 !important;
        box-sizing: border-box !important;

        opacity: 0;
        transform: translateY(20px) scale(0.95);
        pointer-events: none;
        transition: all 0.4s ease !important;
        box-shadow: none !important;
        overflow: visible !important;
    }

    .mobile-overlay::before {
        content: "" !important;
        position: absolute !important;
        top: 0; left: 0; right: 0; bottom: 0;
        z-index: -1 !important;
        border-radius: 16px !important;

        box-shadow: 0 20px 30px -5px rgba(0, 0, 0, 0.2) !important;

        pointer-events: none !important;
    }

    .mobile-menu-trigger .bar {
        width: 22px;
        height: 1.5px;
        background-color: rgba(49, 130, 206, 1);
        transition: all 0.3s ease;
    }

    .mobile-menu-trigger.active {
        background: rgba(49, 130, 206, 0.15) !important;
    }
    .mobile-menu-trigger.active .bar:nth-child(1) {
        transform: translateY(6.5px) rotate(45deg) !important;
    }
    .mobile-menu-trigger.active .bar:nth-child(2) {
        opacity: 0 !important;
    }
    .mobile-menu-trigger.active .bar:nth-child(3) {
        transform: translateY(-6.5px) rotate(-45deg) !important;
    }

    .mobile-overlay.open {
        opacity: 1 !important;
        height: 215px !important;
        transform: translateY(0) scale(1) !important;
        pointer-events: auto !important;
    }

    nav.mobile-nav-links {
        display: flex !important;
        flex-direction: column !important;
        align-items: flex-start !important;
        width: 100% !important;
        margin: 0 !important;
        padding: 8px !important;
        transform: translateX(-20px) !important;
        padding-top: 15px !important;
        gap: 15px !important;
    }

    nav.mobile-nav-links a {
        display: block !important;
        font-family: var(--font-code) !important;
        font-size: 1rem !important;
        color: rgba(49, 130, 206, 1) !important;
        text-decoration: none !important;
        text-transform: uppercase !important;
        text-align: left !important;

        border-bottom: none !important;
        position: relative !important;

        padding-bottom: 2px !important;
        margin-bottom: 13px !important;
    }

    nav.mobile-nav-links a::after {
        content: "" !important;
        position: absolute !important;
        left: 0 !important;
        right: 15px !important;
        width: 150px !important;
        gap: 5px !important;
        height: 1px !important; /* Die Dicke der Linie */
        background: rgba(49, 130, 206, 0.15) !important; /* Die Farbe */

        bottom: -14px !important;
    }

    .mobile-nav-links a:last-child {
        border-bottom: none !important;
        padding-bottom: 0 !important;
    }

    /* ==============================================================
        MOBILE ANPASSUNG (NUR FÜR DAS IMPRESSUM)
        (Dieser Teil ist noch innerhalb deines großen @media Blocks)
        ============================================================== */
    /* Zwingt das Impressum in den Bildschirm und stoppt das Rauszoomen */
    .legal-section {
        padding-top: 6rem !important;
        padding-left: 5% !important;
        padding-right: 5% !important;
        width: 100vw !important;
        max-width: 100% !important;
        overflow-x: hidden !important;
        box-sizing: border-box !important;
    }

    /* Große englische Titel auf Mobile */
    .legal-section .tech-label-large,
    .legal-section h1.scramble-text,
    .legal-section > h1:first-of-type {
        font-size: 2.2rem !important;
        word-wrap: break-word !important;
    }

    /* Bricht extrem lange Wörter und Links sicher um (Datenschutz-Fix!) */
    .legal-section p,
    .legal-section .log-info,
    .legal-section a {
        font-size: 0.9rem !important;
        line-height: 1.6 !important;
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
        hyphens: auto !important;
        max-width: 100% !important;
        text-align: left !important;
        display: block !important;
    }

    /* Stapelt die "Betreiber" Daten sauber übereinander und linksbündig */
    .legal-section .log-row {
        display: flex !important;
        flex-direction: column !important;
        align-items: flex-start !important; /* Alles nach links */
        gap: 5px !important;
        margin-bottom: 1.5rem !important;
        width: 100% !important;
        border-bottom: 1px dashed rgba(148, 163, 184, 0.3) !important;
        padding-bottom: 1rem !important;
    }

} /* <--- DIESE KLAMMER SCHLIESST DEINEN RIESIGEN MOBILE-BEREICH AB */

/* ==============================================================
   IMPRESSUM, DATENSCHUTZ & HAFTUNG (DESKTOP & GLOBAL)
   (Dieser Teil MUSS außerhalb der Mobile-Klammer stehen!)
   ============================================================== */

/* 1. RIESIGE ENGLISCHE HAUPTTITEL (System_Legal, Data_Privacy, >< LIABILITY_INFO) */
.legal-section .tech-label-large,
.legal-section h1.scramble-text,
.legal-section > h1:first-of-type {
    font-size: 4rem !important; /* Sehr groß für Desktop */
    margin-bottom: 2rem !important;
    text-align: left !important;
    display: block !important;
    line-height: 1.2 !important;
    word-wrap: break-word !important;
}

/* 2. Deutsche Titel (Impressum, Angaben gem. § 5 TMG) - bleiben klein! */
.legal-section h2,
.legal-section h1:not(:first-of-type):not(.scramble-text) {
    font-size: 1.2rem !important;
    font-weight: 400 !important;
    letter-spacing: 1px !important;
    margin-bottom: 1.5rem !important;
    text-align: left !important;
}

/* 3. Die "// Betreiber" Labels (Dein Blau & Linksbündig) */
.legal-section .log-label,
.legal-section h3 {
    color: var(--navy-light) !important;
    font-family: var(--font-code) !important;
    font-size: 1.1rem !important;
    margin-top: 2.5rem !important;
    margin-bottom: 0.5rem !important;
    text-transform: uppercase;
    text-align: left !important;
    display: block !important;
    width: 100% !important;
}

/* ==============================================================
   IMPRESSUM, DATENSCHUTZ & HAFTUNG (DESKTOP)
   ============================================================== */
.legal-section {
    padding-top: 15rem !important;
    padding-bottom: 10rem !important;
}

/* 1. Große englische Titel */
.legal-section .tech-label-large {
    font-size: 1.5rem !important;
    margin-bottom: 2rem !important;
    text-align: left !important;
    display: block !important;
    line-height: 1.2 !important;
    color: var(--navy-light) !important;
}

/* 2. Deutsche Titel (Impressum etc.) */
.legal-section h2.german-title {
    font-size: 1.5rem !important;
    font-weight: 400 !important;
    letter-spacing: 1px !important;
    margin-bottom: 0.5rem !important;
    text-align: left !important;
    text-transform: uppercase !important;
    color: var(--text-main) !important;
}

.legal-section p.german-subtitle {
    font-size: 0.9rem !important;
    color: var(--text-muted) !important;
    margin-bottom: 3rem !important;
    letter-spacing: 1px !important;
}

/* 3. Die "// Betreiber" Labels & H3s (Blau & Linksbündig) */
.legal-section .log-label,
.legal-section h3 {
    color: var(--navy-light) !important;
    font-family: var(--font-code) !important;
    font-size: 1.1rem !important;
    margin-top: 1.5rem !important;
    margin-bottom: 0.5rem !important;
    text-transform: uppercase !important;
    text-align: left !important;
    display: block !important;
    width: 100% !important;
}

/* ==============================================================
   MOBILE ANPASSUNG FÜR IMPRESSUM
   ============================================================== */
@media (max-width: 768px) {
    .legal-section {
        padding-top: 6rem !important;
        padding-left: 5% !important;
        padding-right: 5% !important;
        width: 100vw !important;
        max-width: 100% !important;
        overflow-x: hidden !important;
        box-sizing: border-box !important;
    }

    .legal-section .tech-label-large {
        font-size: 1.25rem !important;
        word-wrap: break-word !important;
    }

    .legal-section h2.german-title {
        font-size: 1.2rem !important;
    }

    /* Der Datenschutz-Lebensretter gegen Rauszoomen */
    .legal-section p,
    .legal-section .log-info,
    .legal-section a {
        font-size: 0.9rem !important;
        line-height: 1.6 !important;
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
        hyphens: auto !important;
        max-width: 100% !important;
        text-align: left !important;
        display: block !important;
    }

    .legal-section .log-row {
        display: flex !important;
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 5px !important;
        margin-bottom: 1.5rem !important;
        width: 100% !important;
        border-bottom: 1px dashed rgba(148, 163, 184, 0.3) !important;
        padding-bottom: 1rem !important;
    }
}

/* ==============================================================
   CUSTOM SUCCESS POPUP (NETLIFY FORMULAR)
   ============================================================== */
.system-popup-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background: rgba(0, 0, 0, 0.3); /* Dunkler, halbtransparenter Hintergrund */
    backdrop-filter: blur(5px);
    z-index: 999999;
    display: flex;
    justify-content: center;
    align-items: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.4s ease;
}

.system-popup-overlay.active {
    opacity: 1;
    pointer-events: auto;
}

.system-popup-box {
    background: rgba(17, 34, 64, 0.95); /* Dein Element-Blau */
    border: 1px solid rgba(49, 130, 206, 0.5); /* Dein System-Blau */
    padding: 3rem 2rem;
    max-width: 450px;
    width: 90%;
    text-align: center;
    box-shadow: 0 20px 50px rgba(0,0,0,0.5);
    transform: translateY(30px);
    transition: transform 0.4s ease;
}

.system-popup-overlay.active .system-popup-box {
    transform: translateY(0);
}

.system-popup-box .tech-label-large {
    color: var(--navy-light);
    font-size: 1.2rem !important;
    display: block;
    margin-bottom: 1rem;
    word-wrap: break-word;
}

.system-popup-box h2 {
    font-size: 1.2rem;
    font-weight: 400;
    margin-bottom: 1.5rem;
    color: var(--text-main);
}

.system-popup-box p {
    color: var(--text-muted);
    font-family: var(--font-code);
    font-size: 0.9rem;
    line-height: 1.6;
    margin-bottom: 2rem;
}

@media (max-width: 768px) {
    .system-popup-box .tech-label-large {
        font-size: 1rem !important;
    }
}
