/* ============================================
   CSS Variablen - Farbkonzept
   ============================================ */
:root {
    --ultramarin: #1E3A8A;
    --karminrot: #B91C1C;
    --saffran-gold: #F59E0B;
    --museums-grau: #E5E7EB;
    --tintenblau: #0F172A;
    --pigment-violett: #6D28D9;
    --white: #FFFFFF;
}

/* ============================================
   Fonts - Lokal gehostet (DSGVO-konform)
   ============================================ */
/* 
 * Fonts - Lokal gehostet (DSGVO-konform)
 * Falls die Font-Dateien nicht vorhanden sind, werden System-Fonts als Fallback verwendet
 */
@font-face {
    font-family: 'Inter';
    font-style: normal;
    font-weight: 100 900;
    font-display: swap;
    src: url('fonts/inter-variable.woff2') format('woff2');
    /* OpenType Features aktivieren für identisches Rendering wie Google Fonts */
    font-feature-settings: 'kern' 1, 'liga' 1, 'calt' 1;
    /* Optical sizing aktivieren für bessere Darstellung */
    font-optical-sizing: auto;
    /* Fallback: System-Fonts werden automatisch verwendet, wenn Font-Datei nicht verfügbar */
}

@font-face {
    font-family: 'Playfair Display';
    font-style: normal;
    font-weight: 400 700;
    font-display: swap;
    src: url('fonts/playfair-display-variable.woff2') format('woff2');
    /* OpenType Features aktivieren für identisches Rendering wie Google Fonts */
    font-feature-settings: 'kern' 1, 'liga' 1;
    /* Fallback: System-Serif-Fonts werden automatisch verwendet, wenn Font-Datei nicht verfügbar */
}

/* ============================================
   Skip-Links für Screen Reader und Keyboard-Navigation
   ============================================ */
.skip-link {
    position: fixed;
    top: -100px;
    /* Versteckt außerhalb des Viewports */
    left: 0;
    background: var(--ultramarin);
    color: var(--white);
    padding: 0.75rem 1.5rem;
    text-decoration: none;
    font-weight: 600;
    font-size: 1rem;
    z-index: 10001;
    /* Höher als Navbar (z-index: 1000) */
    border-radius: 0 0 4px 0;
    transition: top 0.2s ease;
    clip-path: inset(100%);
    /* Zusätzlich verstecken mit clip-path */
    overflow: hidden;
    /* Verhindert Overflow */
}

.skip-link:focus {
    top: 0;
    /* Sichtbar bei Keyboard-Focus */
    clip-path: none;
    /* Sichtbar bei Focus */
    outline: 3px solid var(--saffran-gold);
    outline-offset: 2px;
}

.skip-link:focus:not(:focus-visible) {
    outline: none;
    top: -100px;
    /* Wieder verstecken wenn nicht focus-visible */
    clip-path: inset(100%);
}

/* ============================================
   Reset & Base Styles
   ============================================ */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    color: var(--tintenblau);
    line-height: 1.6;
    background-color: var(--white);
    overflow-x: hidden;
    /* Font-Rendering optimieren für identisches Aussehen wie Google Fonts */
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    /* OpenType Features global aktivieren (kern, liga, calt) */
    font-feature-settings: 'kern' 1, 'liga' 1, 'calt' 1;
    /* Optical sizing für Variable Fonts */
    font-optical-sizing: auto;
}

.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}

/* ============================================
   Typografie
   ============================================ */
h1,
h2,
h3 {
    font-weight: 700;
    line-height: 1.2;
}

.section-title {
    font-family: 'Playfair Display', serif;
    font-size: clamp(2rem, 5vw, 3rem);
    color: var(--tintenblau);
    margin-bottom: 1.5rem;
    text-align: center;
}

.section-description {
    font-size: clamp(1rem, 2.5vw, 1.125rem);
    color: #374151;
    text-align: center;
    max-width: 600px;
    margin: 0 auto 3rem;
    line-height: 1.8;
}

/* ============================================
   Navigation
   ============================================ */
.navbar {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    background-color: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(10px);
    box-shadow: 0 2px 10px rgba(15, 23, 42, 0.1);
    z-index: 1000;
    transition: all 0.3s ease;
}

.nav-wrapper {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1.25rem 0;
}

.logo {
    display: flex;
    align-items: center;
    gap: 30px;
    flex-wrap: wrap;
    text-decoration: none;
    transition: opacity 0.3s ease;
}

.logo:hover {
    opacity: 0.8;
}

/* SVG-Variante (primär) - Konsistente Breite auf allen Devices (3,5 cm auf Desktop) */
.logo-svg {
    display: block;
    width: clamp(210px, 17.3vw, 210px);
    /* Minimum = ViewBox-Breite (210px) - verhindert Unter-Skalierung und textLength-Probleme */
    height: auto;
    flex-shrink: 0;
    max-width: 100%;
    /* Verhindert Overflow auf sehr kleinen Screens */
}

/* Trennstrich auf Mobilgeräten - dunklere Farbe für bessere Sichtbarkeit */
@media (max-width: 768px) {
    .logo-svg .logo-line {
        stroke: #0A0E1A !important;
        /* Dunklerer Farbton für bessere Sichtbarkeit */
        stroke-width: 0.75 !important;
        opacity: 0.9 !important;
        /* Höhere Opacity für dunkleren Strich */
        shape-rendering: auto !important;
    }

    svg.logo-svg line.logo-line {
        stroke: #0A0E1A !important;
        opacity: 0.9 !important;
    }
}

/* Trennstrich auf Tablets (Hochformat und Querformat) - separate Anpassung */
@media (min-width: 769px) and (max-width: 1366px) {
    .logo-svg .logo-line {
        stroke: #0A0E1A !important;
        stroke-width: 0.8 !important;
        opacity: 0.85 !important;
        shape-rendering: auto !important;
    }

    svg.logo-svg line.logo-line {
        stroke: #0A0E1A !important;
        opacity: 0.85 !important;
    }
}

/* HTML-Fallback verstecken, wenn SVG unterstützt wird */
.logo-main.logo-fallback {
    display: none !important;
}

/* Fallback für sehr alte Browser ohne SVG-Support */
@supports not (transform: scale(1)) {
    .logo-svg {
        display: none !important;
    }

    .logo-fallback {
        display: flex !important;
        flex-direction: column;
    }

    /* Fallback: Feste Schriftgrößen (wie alte Version) statt clamp() für Konsistenz */
    .logo-fallback .logo-text {
        font-size: 1.75rem;
    }

    .logo-fallback .logo-subtext {
        font-size: 1.075rem;
    }
}

.logo-main {
    display: flex;
    flex-direction: column;
    line-height: 1.2;
    align-items: flex-start;
    /* Linksbündige Ausrichtung für konsistente Kante */
}

.logo-text {
    font-family: 'Playfair Display', serif;
    font-size: clamp(1.375rem, 3vw, 1.75rem);
    font-weight: 700;
    color: var(--ultramarin);
    letter-spacing: -0.5px;
    line-height: 1.1;
    /* Explizite Line-Height für konsistente Ausrichtung */
    display: block;
    padding-left: 0;
    /* Sicherstellen, dass kein Padding die Ausrichtung stört */
}

.logo-divider {
    width: 100%;
    height: 1px;
    border: 0;
    border-top: 1px solid var(--tintenblau);
    background-color: transparent;
    margin: 0.1rem 0;
    opacity: 0.5;
}

.logo-subtext {
    font-family: 'Inter', sans-serif;
    font-size: clamp(0.875rem, 2.5vw, 1.075rem);
    font-weight: 400;
    color: var(--tintenblau);
    letter-spacing: 0.4px;
    margin-top: 0;
    line-height: 1.2;
    /* Explizite Line-Height für konsistente Ausrichtung */
    display: block;
    padding-left: 0;
    /* Sicherstellen, dass kein Padding die Ausrichtung stört */
    text-indent: 0;
    /* Keine Text-Einrückung */
}


.nav-menu {
    display: flex;
    list-style: none;
    gap: 2.5rem;
}

.nav-menu a {
    text-decoration: none;
    color: var(--tintenblau);
    font-weight: 500;
    font-size: 1rem;
    transition: color 0.3s ease;
    position: relative;
}

.nav-menu a::after {
    content: '';
    position: absolute;
    bottom: -5px;
    left: 0;
    width: 0;
    height: 2px;
    background-color: var(--karminrot);
    transition: width 0.3s ease;
}

.nav-menu a:hover {
    color: var(--karminrot);
}

.nav-menu a:hover::after {
    width: 100%;
}

/* Accessibility: Focus-visible für Tastatur-Navigation */
.nav-menu a:focus-visible {
    outline: 3px solid var(--saffran-gold);
    outline-offset: 4px;
    border-radius: 2px;
}

.nav-menu a:focus:not(:focus-visible) {
    outline: none;
}

.mobile-menu-toggle:focus-visible {
    outline: 3px solid var(--saffran-gold);
    outline-offset: 3px;
    border-radius: 4px;
}

.mobile-menu-toggle:focus:not(:focus-visible) {
    outline: none;
}

.mobile-menu-toggle {
    display: none;
    position: relative;
    /* Für absolute Positionierung der Spans */
    width: 44px;
    /* WCAG: Mindest-Touch-Target */
    height: 44px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    /* Kein Padding mehr, da absolute Positionierung */
}

.mobile-menu-toggle span {
    position: absolute;
    left: 50%;
    width: 25px;
    height: 3px;
    background-color: var(--tintenblau);
    transition: all 0.3s ease;
    transform-origin: center;
    transform: translateX(-50%);
    /* Zentrieren horizontal */
}

.mobile-menu-toggle span:nth-child(1) {
    top: 14px;
    /* Positioniert oben */
}

.mobile-menu-toggle span:nth-child(2) {
    top: 50%;
    transform: translateX(-50%) translateY(-50%);
    /* Zentrieren horizontal und vertikal */
}

.mobile-menu-toggle span:nth-child(3) {
    bottom: 14px;
    /* Positioniert unten */
}

/* ============================================
   Hero Section
   ============================================ */
.hero {
    position: relative;
    height: 100vh;
    height: 100svh;
    /* Small Viewport Height - statisch, verhindert Sprünge beim Scrollen */
    min-height: 600px;
    display: flex;
    align-items: flex-start;
    /* Flex-start für präzise Positionierung */
    justify-content: center;
    padding-top: 15vh;
    /* H1 höher positioniert (oberes Drittel) - responsive angepasst */
    background: linear-gradient(135deg, var(--ultramarin) 0%, var(--tintenblau) 50%, var(--pigment-violett) 100%);
    overflow: hidden;
    margin-top: 70px;
}


/* Hero-Positionierung optimieren für große Screens (Desktop 24 Zoll, 2560x1440) */
/* Bei sehr großen Viewports wirkt der Content zu hoch - erhöhte padding-top für bessere visuelle Balance (Text tiefer) */
@media (min-width: 1600px) {
    .hero {
        padding-top: 17vh;
        /* Erhöht von 15vh für bessere Positionierung auf großen Screens - Text wird tiefer positioniert */
    }
}

/* Hero-Positionierung optimieren für sehr große Screens (4K, Ultra-Wide) */
@media (min-width: 2560px) {
    .hero {
        padding-top: 18vh;
        /* Erhöht für sehr große Screens - Text wird noch tiefer positioniert */
    }
}

.hero::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background:
        radial-gradient(circle at 20% 50%, rgba(245, 158, 11, 0.15) 0%, transparent 50%),
        radial-gradient(circle at 80% 80%, rgba(185, 28, 28, 0.15) 0%, transparent 50%);
    z-index: 1;
}

.hero-image-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(15, 23, 42, 0.45);
    z-index: 2;
}

.hero-content {
    position: relative;
    z-index: 3;
    text-align: center;
    color: var(--white);
    padding: 2rem;
    padding-bottom: 10rem;
    /* Erhöhter Abstand zum Fade-Effekt (hero-accent) - verhindert Überlappung mit CTA-Button */
    max-width: 900px;
}

.hero-title {
    font-family: 'Playfair Display', serif;
    font-size: clamp(2.5rem, 7vw, 4.5rem);
    font-weight: 700;
    margin-bottom: 2rem;
    line-height: 1.1;
    text-shadow: 2px 2px 10px rgba(0, 0, 0, 0.3);
}

.hero-subtitle {
    font-size: clamp(1rem, 2vw, 1.25rem);
    margin-bottom: 2.5rem;
    line-height: 1.7;
    opacity: 0.95;
    max-width: 700px;
    margin-left: auto;
    margin-right: auto;
}

.hero-accent {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 100px;
    background: linear-gradient(to top, var(--museums-grau) 0%, transparent 100%);
    z-index: 2;
}

/* ============================================
   Bild und Text Sektion
   ============================================ */
.bild-text-section {
    position: relative;
    min-height: 80vh;
    padding: 3rem 0 4rem 0;
    /* Fade Grau → Weiß: kürzerer Übergang zur Karten-Section, vermeidet „Abschnitt vorbei“-Eindruck (UX) */
    background: linear-gradient(to bottom, var(--museums-grau) 0%, var(--museums-grau) 94%, var(--white) 100%);
    display: flex;
    align-items: center;
}

.bild-text-section .section-description {
    color: var(--tintenblau);
}

/* Section-Header für diese Sektion nicht benötigt */
.bild-text-section .section-header {
    display: none;
}

/* Fade Grau→Weiß für Smartphones/Tablets: breitere Übergangszone (70%–100%)
   – nur CSS-Gradient; 1366px deckt auch große Tablets (z. B. Samsung im Querformat) ab */
@media (max-width: 1366px) {
    .bild-text-section {
        background: linear-gradient(to bottom, var(--museums-grau) 0%, var(--museums-grau) 70%, var(--white) 100%);
    }
}

.bild-text-wrapper {
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: 4rem;
    align-items: start;
}

/* Figure bündig mit Text: Browser-Standard-Margins (z. B. 40px) entfernen */
.bild-text-wrapper figure.bild-text-image-container {
    margin-left: 0;
    margin-right: 0;
}

.bild-text-image-container {
    position: relative;
    width: 100%;
    margin: 0;
    display: flex;
    flex-direction: column;
    border-radius: 8px;
    /* Vollständig abgerundet für schöne Optik */
    box-shadow: 0 20px 60px rgba(15, 23, 42, 0.15);
    overflow: hidden;
    /* Wichtig: Verhindert, dass beim Zoomen runde Ecken durchscheinen */
    background-color: var(--white);
    /* Hintergrund für die Caption */
}

/* Lightbox-Styles entfernt - nicht mehr benötigt für Hineinzoomen */

/* Keyboard-freundlich: Focus-Indikator (nur bei Keyboard-Navigation, nicht bei Maus-Klick) */
.bild-text-image-wrapper:focus-visible:not(.zoomed) {
    outline: 3px solid var(--ultramarin);
    outline-offset: 4px;
    border-radius: 8px;
}

/* Focus-Indikator bei Maus-Klick oder im gezoomten Zustand entfernen */
.bild-text-image-wrapper:focus:not(:focus-visible),
.bild-text-image-wrapper.zoomed:focus {
    outline: none !important;
}

.bild-text-image-wrapper {
    position: relative;
    width: 100%;
    height: 0;
    padding-bottom: 75%;
    /* Aspect Ratio für das Bild */
    overflow: hidden;
    /* Wichtig: Verhindert, dass beim Zoomen runde Ecken sichtbar werden */
    border-radius: 0;
    /* Kein border-radius, um runde Ecken beim Zoomen zu vermeiden */
    background-color: var(--museums-grau);
}

/* Cursor und Interaktivität nur auf Desktop (Custom Zoom) */
@media (hover: hover) {
    .bild-text-image-wrapper {
        cursor: pointer;
        /* Zeigt an, dass das Bild klickbar ist (Desktop) */
    }
}

/* Mobile: Kein Custom-Zoom, daher kein Pointer-Cursor */
@media (hover: none) and (pointer: coarse) {
    .bild-text-image-wrapper {
        cursor: default;
        /* Native Browser-Zoom nutzen */
    }
}

/* Verfeinerter Fading-Effekt am unteren Bildrand */
.bild-text-image-wrapper::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 12px;
    /* Erhöht für sanfteren Übergang */
    background: linear-gradient(to bottom,
            rgba(255, 255, 255, 0) 0%,
            rgba(255, 255, 255, 0.08) 30%,
            rgba(255, 255, 255, 0.18) 60%,
            rgba(255, 255, 255, 0.32) 100%);
    pointer-events: none;
    z-index: 1;
}

/* Mobile: Kompakterer Fade-Bereich */
@media (max-width: 768px) {
    .bild-text-image-wrapper::after {
        height: 8px;
        /* Reduziert für Mobile, aber sanfterer Gradient */
        background: linear-gradient(to bottom,
                rgba(255, 255, 255, 0) 0%,
                rgba(255, 255, 255, 0.1) 35%,
                rgba(255, 255, 255, 0.25) 70%,
                rgba(255, 255, 255, 0.35) 100%);
    }
}

.bild-text-image {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center 45%;
    transform-origin: center 45%;
    transition: transform 0.6s ease;
    /* Wichtig: Kein border-radius, damit beim Zoomen keine runden Ecken sichtbar werden */
    border-radius: 0 !important;
    /* Maskierung, um sicherzustellen, dass keine runden Ecken am unteren Rand erscheinen */
    clip-path: inset(0 0 0 0);
}

/* Performance-Optimierung und Hover-Effekte: Nur auf Desktop */
@media (hover: hover) {

    /* Performance-Optimierung: will-change nur während Animation */
    .bild-text-image-wrapper:not(.zoomed):hover .bild-text-image,
    .bild-text-image-wrapper.zoomed .bild-text-image {
        will-change: transform;
    }

    /* will-change nach Animation entfernen */
    .bild-text-image-wrapper:not(:hover):not(.zoomed) .bild-text-image {
        will-change: auto;
    }

    /* Hover-Hinweis nur wenn NICHT gezoomt */
    .bild-text-image-wrapper:not(.zoomed):hover .bild-text-image {
        transform: scale(1.05);
        /* Sehr subtile Vergrößerung als visueller Hinweis */
        /* Transition wird von der Basis-Regel übernommen (0.6s ease) */
    }
}

/* Mobile: Keine Hover-Effekte - Native Browser-Zoom nutzen */
@media (hover: none) and (pointer: coarse) {

    /* Keine Hover-Effekte auf Mobile */
    .bild-text-image-wrapper:not(.zoomed):hover .bild-text-image {
        transform: none !important;
    }
}

/* Zoom-Hinweis (visueller Indikator) */
.zoom-hint {
    position: absolute;
    bottom: 1rem;
    left: 50%;
    transform: translateX(-50%);
    background-color: rgba(15, 23, 42, 0.85);
    color: var(--white);
    padding: 0.5rem 1rem;
    border-radius: 20px;
    font-size: 0.875rem;
    font-weight: 500;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s ease;
    z-index: 2;
    white-space: nowrap;
    backdrop-filter: blur(10px);
}

/* Zoom-Hinweis: Nur auf Desktop anzeigen (Mobile nutzt Native Browser-Zoom) */
@media (hover: none) and (pointer: coarse) {

    /* Mobile: Zoom-Hinweis komplett verstecken - Native Browser-Zoom wird genutzt */
    .zoom-hint {
        display: none !important;
    }
}

/* Desktop: Zoom-Hinweis bei Hover anzeigen (nur wenn nicht gezoomt) */
@media (hover: hover) {
    .bild-text-image-wrapper:not(.zoomed):hover .zoom-hint {
        opacity: 1;
    }

    /* Kompakterer Hinweis bei kleineren Desktop-Screens */
    @media (max-width: 768px) {
        .zoom-hint {
            font-size: 0.75rem;
            padding: 0.375rem 0.75rem;
            bottom: 0.75rem;
        }
    }
}

/* Zoom-Hinweis ausblenden wenn gezoomt */
.bild-text-image-wrapper.zoomed .zoom-hint {
    opacity: 0 !important;
}

/* Hineinzoomen beim Klick (aktivierter Zustand) - identisch zur ursprünglichen Hover-Version */
.bild-text-image-wrapper.zoomed .bild-text-image {
    transform: scale(1.85);
    /* Wie ursprünglich beim Hover - hineinzoomen */
    /* Transition wird von der Basis-Regel übernommen (0.6s ease) */
}

/* Hover und Active komplett deaktiviert wenn gezoomt (nur Desktop) */
@media (hover: hover) {

    .bild-text-image-wrapper.zoomed:hover .bild-text-image,
    .bild-text-image-wrapper.zoomed:active .bild-text-image {
        transform: scale(1.85);
        /* Bleibt bei 1.85 auch bei Hover/Active */
    }
}

.bild-text-caption {
    font-size: clamp(0.9375rem, 2.5vw, 1rem);
    /* 15px - 16px für deutlich bessere Lesbarkeit */
    line-height: 1.6;
    /* Optimiert für normale Lesbarkeit */
    color: #6B7280;
    font-style: normal;
    /* Kein Italic - bessere Lesbarkeit und professionelleres Erscheinungsbild */
    text-align: center;
    padding: 0.75rem 1rem;
    margin: 0;
    background-color: transparent;
    /* Transparent, da Container bereits weißen Hintergrund hat */
    border: none;
    /* Border entfernt, da Container den Shadow hat */
    border-radius: 0 0 8px 8px !important;
    /* Wichtig: Nur unten abgerundet, oben eckig für nahtlosen Übergang */
    /* Box-Shadow entfernt, da Container den Shadow hat */
    /* Font-Features für bessere Typografie */
    font-feature-settings: 'kern' 1, 'liga' 1;
}

.bild-text-content {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    padding: 0;
    /* Padding entfernt, da H2 jetzt Teil des Contents ist */
    padding-top: 1rem;
    /* Abstand nach oben, damit H2 nicht zu weit oben beginnt */
}

.bild-text-title {
    font-family: 'Playfair Display', serif;
    font-size: clamp(1.75rem, 4vw, 2.5rem);
    /* Etwas kleiner als normale H2, aber responsive */
    font-weight: 700;
    color: var(--tintenblau);
    margin-bottom: 1.5rem;
    margin-top: 1.5rem;
    /* Sichtbarer Abstand nach oben für bessere optische Hierarchie */
    text-align: left;
    /* Linksbündig, da Teil des Text-Containers */
    line-height: 1.2;
}

.bild-text {
    font-size: clamp(1rem, 2.5vw, 1.125rem);
    line-height: 1.8;
    color: #374151;
    margin: 0 0 1.5rem 0;
    text-align: left;
}

.bild-text:last-child {
    margin-bottom: 0;
}

/* Weniger Abstand vor dem Pfeil, wenn letzte Zeile nur wenige Wörter hat (optisch enger) */
.bild-text:has(+ .bild-text-scroll-hint) {
    margin-bottom: 0.5rem;
}

/* Pfeil als Link: Smooth-Scroll zu Leistungsbereichen (UX + A11y) */
.bild-text-scroll-hint {
    margin: 0;
    padding-top: 0.25rem;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    color: inherit;
    text-decoration: none;
}

.bild-text-scroll-hint:hover,
.bild-text-scroll-hint:focus {
    color: inherit;
    text-decoration: none;
}

.bild-text-scroll-hint:focus-visible {
    outline: 2px solid var(--tintenblau);
    outline-offset: 4px;
    border-radius: 4px;
}

.bild-text-scroll-hint .icon-scroll-hint {
    width: 1.5rem;
    height: 1.5rem;
    color: var(--tintenblau);
    opacity: 0.35;
    display: block;
    transition: opacity 0.2s ease;
}

.bild-text-scroll-hint:hover .icon-scroll-hint,
.bild-text-scroll-hint:focus .icon-scroll-hint {
    opacity: 0.55;
}

/* Pfeil ausblenden bis 1024px: Smartphones/Tablets – Expertise-Boxen sind nah;
   !important verhindert Überschreibung durch gecachte/ältere CSS-Versionen auf dem Gerät */
@media (max-width: 1024px) {
    .bild-text-scroll-hint {
        display: none !important;
    }
}

/* ============================================
   Text Absätze Sektion
   ============================================ */
.text-absaetze-section {
    padding: 4rem 0;
    background-color: var(--white);
}

.text-absaetze-content {
    max-width: 900px;
    margin: 0 auto;
}

.text-absatz {
    font-size: 1.125rem;
    line-height: 1.8;
    color: var(--tintenblau);
    margin: 0 0 2rem 0;
    text-align: left;
}

.text-absatz:last-child {
    margin-bottom: 0;
}

/* ============================================
   CTA Button
   ============================================ */
.cta-button {
    display: inline-block;
    padding: 1rem 2.5rem;
    background-color: var(--karminrot);
    color: var(--white);
    text-decoration: none;
    font-weight: 600;
    font-size: 1.125rem;
    border-radius: 4px;
    transition: all 0.3s ease;
    border: 2px solid var(--karminrot);
    cursor: pointer;
    font-family: inherit;
}

.cta-button:hover {
    background-color: transparent;
    color: var(--karminrot);
    transform: translateY(-2px);
    box-shadow: 0 10px 25px rgba(185, 28, 28, 0.3);
}

.cta-button:active {
    transform: translateY(0);
}

/* Accessibility: Focus-visible für Tastatur-Navigation */
.cta-button:focus-visible {
    outline: 3px solid var(--saffran-gold);
    outline-offset: 3px;
    border-radius: 4px;
}

.cta-button:focus:not(:focus-visible) {
    outline: none;
}

/* ============================================
   Leistungen-Bereich
   ============================================ */
.expertise {
    padding: 4rem 0 5rem 0;
    /* padding-bottom reduziert von 6rem auf 5rem für Desktop */
    background-color: var(--white);
}

.section-header {
    margin-bottom: 4rem;
}

.expertise-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(360px, 1fr));
    /* +60px für optimalen Titel-Platz */
    gap: 2rem;
}

.expertise-card {
    background-color: var(--white);
    padding: 2rem;
    /* Reduziert von 2.5rem für mehr Innen-Platz */
    border-radius: 8px;
    border: 2px solid var(--museums-grau);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    transition: all 0.3s ease;
    position: relative;
    overflow: hidden;
}

.expertise-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--saffran-gold), var(--pigment-violett));
    transform: scaleX(0);
    transition: transform 0.3s ease;
}

.expertise-card:hover {
    border-color: var(--saffran-gold);
    transform: translateY(-5px);
    box-shadow: 0 10px 30px rgba(245, 158, 11, 0.15);
}

.expertise-card:hover::before {
    transform: scaleX(1);
}

/* ============================================
   Icon System - Lokale Icon-Bibliothek (SVG Sprite)
   ============================================ */
/* Basis-Icon-Klasse: Responsive Größen mit clamp() für bessere Barrierefreiheit */
.icon {
    display: inline-block;
    width: 1em;
    height: 1em;
    vertical-align: middle;
    fill: none;
    stroke: currentColor;
    flex-shrink: 0;
}

.icon svg {
    width: 100%;
    height: 100%;
    display: block;
}

/* Expertise Header: Grid-Layout für optimale Platzaufteilung */
.expertise-header {
    display: grid;
    grid-template-columns: 1fr auto;
    /* Titel nimmt maximalen Platz, Icon nur benötigten Platz */
    align-items: center;
    gap: 0.5rem;
    /* Minimiert für maximalen Titel-Platz */
    margin-bottom: 1rem;
}

/* Expertise Icons - Kompakter, rechts neben Titel */
.expertise-icon {
    width: clamp(2.25rem, 2.75vw, 2.5rem);
    /* 36px - 40px responsive (minimal für maximalen Titel-Platz) */
    height: clamp(2.25rem, 2.75vw, 2.5rem);
    color: var(--saffran-gold);
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: rgba(245, 158, 11, 0.1);
    border-radius: clamp(0.5rem, 1vw, 0.625rem);
    /* 8px - 10px responsive */
    transition: all 0.3s ease;
}

.expertise-card:hover .expertise-icon {
    background-color: rgba(245, 158, 11, 0.2);
    transform: scale(1.1);
}

.expertise-icon .icon {
    width: clamp(1.25rem, 1.5vw, 1.5rem);
    /* 20px - 24px responsive (proportional zum minimalen Icon) */
    height: clamp(1.25rem, 1.5vw, 1.5rem);
}

.expertise-title {
    font-size: clamp(1.375rem, 2.5vw, 1.625rem);
    /* 22px - 26px responsive */
    font-weight: 700;
    color: var(--tintenblau);
    margin: 0;
    /* Margin entfernt, da Container margin-bottom hat */
    font-family: 'Playfair Display', serif;
    min-width: 0;
    /* Wichtig: Ermöglicht Text-Overflow und bessere Umbrüche */
    line-height: 1.3;
    /* Grid nimmt automatisch verfügbaren Platz ein, kein flex: 1 nötig */
}

/* Expertise Description Wrapper – Collapsible auf Desktop und Mobile */
.expertise-description-wrapper {
    position: relative;
    max-height: calc(1.8em * 9);
    /* Desktop: ~8 Zeilen lesbar (Fade/Abstand berücksichtigt), dann „Mehr erfahren“ */
    overflow: hidden;
    transition: max-height 0.4s ease;
}

.expertise-description-wrapper.expanded {
    max-height: 2000px;
}

.expertise-description-wrapper:not(.expanded)::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: calc(1.8em * 1.5);
    background: linear-gradient(to bottom,
            rgba(255, 255, 255, 0) 0%,
            rgba(255, 255, 255, 0.8) 50%,
            rgba(255, 255, 255, 1) 100%);
    pointer-events: none;
}

.expertise-description-collapsible {
    display: none;
}

.expertise-description-wrapper.expanded .expertise-description-collapsible {
    display: block;
}

.expertise-description {
    color: #374151;
    line-height: 1.8;
    font-size: clamp(1rem, 2.5vw, 1.125rem);
    margin-bottom: 1rem;
}

.expertise-description:last-child {
    margin-bottom: 0;
}

/* Collapsible-Button – Desktop und Mobile sichtbar */
.expertise-toggle-btn {
    display: block;
    background: none;
    border: none;
    color: var(--saffran-gold);
    font-size: 1rem;
    font-weight: 600;
    cursor: pointer;
    padding: 0.75rem 0;
    margin-top: 0.5rem;
    text-align: left;
    transition: color 0.3s ease;
    font-family: inherit;
    position: relative;
}

.expertise-toggle-btn:hover,
.expertise-toggle-btn:focus {
    color: var(--karminrot);
    outline: none;
}

.expertise-toggle-btn:focus-visible {
    outline: 2px solid var(--saffran-gold);
    outline-offset: 2px;
    border-radius: 4px;
}

.expertise-toggle-btn:active {
    color: var(--karminrot);
}

/* ============================================
   Honorar Section
   ============================================ */
.honorar {
    padding: 4rem 0 5rem 0;
    /* padding-top: 4rem (64px), padding-bottom: 5rem (80px) für Desktop */
    background: linear-gradient(to bottom, var(--museums-grau), var(--white));
}

.honorar-content {
    max-width: 800px;
    margin: 0 auto;
}

.honorar-text {
    text-align: center;
}

.honorar-description {
    font-size: clamp(1rem, 2.5vw, 1.125rem);
    color: #374151;
    line-height: 1.8;
    margin-bottom: 1.5rem;
}

/* ============================================
   Kontakt Section
   ============================================ */
.kontakt {
    padding: 4rem 0 5rem 0;
    /* Desktop: padding-top: 4rem (64px), padding-bottom: 5rem (80px) */
    background-color: var(--museums-grau);
}

.kontakt-wrapper {
    max-width: 1100px;
    margin: 0 auto;
}

.kontakt-header {
    margin-bottom: 4rem;
    /* Desktop/Tablet: 4rem (64px) - konsistent mit .section-header */
}

.kontakt-content {
    display: grid;
    grid-template-columns: 1fr 1.5fr;
    gap: 3rem;
    align-items: start;
}

.kontakt-info {
    display: flex;
    flex-direction: column;
    gap: 2rem;
    padding-top: 2.75rem;
    /* Verschiebt Kontaktdaten nach unten, um auf Höhe des ersten Formular-Labels ("Name") zu stehen (100% des Formular-Paddings) */
}

.kontakt-item {
    display: flex;
    gap: 1.5rem;
    align-items: start;
}

/* Kontakt Icons - Responsive Größen */
.kontakt-icon {
    width: clamp(3rem, 3.5vw, 3.125rem);
    /* 48px - 50px responsive */
    height: clamp(3rem, 3.5vw, 3.125rem);
    min-width: clamp(3rem, 3.5vw, 3.125rem);
    color: var(--saffran-gold);
    background-color: rgba(245, 158, 11, 0.1);
    border-radius: clamp(0.5rem, 1vw, 0.625rem);
    /* 8px - 10px responsive */
    display: flex;
    align-items: center;
    justify-content: center;
}

.kontakt-icon .icon {
    width: clamp(1.375rem, 1.75vw, 1.5rem);
    /* 22px - 24px responsive */
    height: clamp(1.375rem, 1.75vw, 1.5rem);
}

.kontakt-item h3 {
    font-size: clamp(1rem, 2vw, 1.125rem);
    font-weight: 600;
    color: var(--tintenblau);
    margin-bottom: 0.5rem;
}

.kontakt-link {
    color: var(--ultramarin);
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 2px;
    font-size: 1rem;
    transition: color 0.3s ease, text-decoration-thickness 0.3s ease;
}

.kontakt-link:hover {
    color: var(--karminrot);
    text-decoration-thickness: 2px;
}

.kontakt-item p {
    color: #374151;
    line-height: 1.6;
}

.kontakt-cta {
    margin-top: 1rem;
    text-align: center;
}

/* ============================================
   Kontaktformular
   ============================================ */
.kontakt-form {
    background-color: var(--white);
    padding: 2.75rem 1.75rem;
    /* Oben/Unten: 2.75rem (44px), Links/Rechts: 1.75rem für deutlich mehr weiße Fläche */
    border-radius: 8px;
    box-shadow: 0 4px 20px rgba(15, 23, 42, 0.1);
}

.form-group {
    margin-bottom: 1rem;
    /* Reduziert für bessere Konsistenz mit dem restlichen Design */
}

/* Kompakteres Margin für Checkbox-Form-Groups */
.form-group:has(.checkbox-label) {
    margin-bottom: 0.75rem;
    /* Erhöht für besseren Abstand, besonders bei Fehlermeldungen */
    /* Reduzierter Abstand oberhalb der Checkbox-Sektion */
    margin-top: -0.75rem;
    /* Verschiebt Checkbox deutlich nach oben (-12px) */
}

.form-group label {
    display: block;
    margin-bottom: 0.625rem;
    font-weight: 600;
    color: var(--tintenblau);
    font-size: 1rem;
}

/* Required-Fields: Visuelle Kennzeichnung mit rotem Stern */
.form-group:not(.form-group-optional) label::after {
    content: ' *';
    color: var(--karminrot);
    font-weight: 700;
    margin-left: 0.125rem;
}

/* Optional-Felder: Visuelle Kennzeichnung */
.form-group-optional label::after {
    content: ' (optional)';
    color: #6B7280;
    font-weight: 400;
    font-size: 0.9em;
    margin-left: 0.25rem;
}

.form-group input:not([type="checkbox"]):not([type="radio"]),
.form-group textarea {
    width: 100%;
    padding: 1rem;
    border: 2px solid var(--museums-grau);
    border-radius: 4px;
    font-family: inherit;
    font-size: 1rem;
    transition: all 0.3s ease;
    background-color: var(--white);
}

/* Placeholder-Styling */
.form-group input::placeholder,
.form-group textarea::placeholder {
    color: #9CA3AF;
    opacity: 0.7;
}

.form-group input:not([type="checkbox"]):not([type="radio"]):focus,
.form-group textarea:focus {
    outline: none;
    border-color: var(--saffran-gold);
    box-shadow: 0 0 0 3px rgba(245, 158, 11, 0.1);
}

.form-group textarea {
    resize: vertical;
    min-height: 120px;
}

/* Character Counter */
.textarea-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 0.5rem;
    min-height: 1.25rem;
    /* Mindesthöhe für konsistentes Layout auch ohne Fehlermeldung */
}

.character-counter {
    display: flex;
    justify-content: flex-end;
    font-size: 0.875rem;
    color: #6B7280;
    margin-top: 0;
    /* Margin entfernt, da Wrapper margin hat */
}

.character-count {
    font-weight: 600;
}

.character-counter.warning .character-count {
    color: var(--saffran-gold);
}

.character-counter.error .character-count {
    color: var(--karminrot);
}

.error-message {
    display: block;
    color: var(--karminrot);
    font-size: 0.875rem;
    margin-top: 0;
    /* Margin entfernt, da Wrapper margin hat */
    min-height: 1.25rem;
}

/* Spezial-Styling für error-message innerhalb textarea-footer */
.textarea-footer .error-message {
    flex: 1;
    /* Nimmt verfügbaren Platz ein */
    margin-right: 1rem;
    /* Abstand zum character-counter */
}

.form-group input:not([type="checkbox"]):not([type="radio"]).error,
.form-group textarea.error {
    border-color: var(--karminrot);
}

.checkbox-label {
    display: flex;
    align-items: flex-start;
    gap: 0.625rem;
    /* Reduziert von 0.75rem für kompakteres Layout */
    cursor: pointer;
    font-weight: 400;
    color: var(--tintenblau);
    font-size: 1rem;
    line-height: 1.5;
    /* Reduziert von 1.6 für kompaktere Zeilen */
    margin-bottom: 0;
    padding: 0.25rem 0;
    /* Reduziert von 0.5rem für weniger vertikalen Abstand */
    margin: -0.25rem 0;
    /* Angepasst an neues Padding */
    word-wrap: break-word;
    /* Stelle sicher, dass Flex-Items korrekt ausgerichtet sind */
    flex-wrap: nowrap;
}

.checkbox-label input[type="checkbox"] {
    width: 20px;
    height: 20px;
    min-width: 20px;
    max-width: 20px;
    margin: 0;
    margin-top: 0.125rem;
    padding: 0;
    cursor: pointer;
    flex-shrink: 0;
    flex-grow: 0;
    accent-color: var(--saffran-gold);
    box-sizing: border-box;
    align-self: flex-start;
}

.checkbox-label input[type="checkbox"]:focus {
    outline: 2px solid var(--saffran-gold);
    outline-offset: 2px;
    border-radius: 2px;
}

.checkbox-label span {
    flex: 1;
    min-width: 0;
    padding-top: 0;
}

.privacy-link {
    color: var(--ultramarin);
    text-decoration: underline;
    transition: color 0.3s ease;
}

.privacy-link:hover {
    color: var(--karminrot);
}

.checkbox-label input[type="checkbox"].error {
    outline: 2px solid var(--karminrot);
    outline-offset: 2px;
}

.form-submit {
    width: 100%;
    margin-top: 1rem;
    /* Erhöht für besseren Abstand zum Checkbox-Bereich */
}

/* Submit-Button: Loading und Disabled States */
.cta-button:disabled,
.cta-button[data-submitting] {
    opacity: 0.6;
    cursor: not-allowed;
    transform: none !important;
}

.cta-button[data-submitting]::after {
    content: '...';
    margin-left: 0.5rem;
}

/* Hilfsklassen zum Ausblenden (kein inline style) */
.svg-sprite-hidden {
    display: none;
}
.toggle-text-less {
    display: none;
}
.toggle-text-less.toggle-text-visible {
    display: inline;
}
.toggle-text-more.toggle-text-hidden {
    display: none;
}
.expertise-toggle-btn-hidden {
    display: none;
}
.btn-link-appearance {
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
    font-family: inherit;
    font-size: inherit;
}
.visually-hidden {
    position: absolute;
    left: -9999px;
    width: 1px;
    height: 1px;
    overflow: hidden;
}

.form-success {
    margin-top: 1.5rem;
    padding: 1rem;
    background-color: rgba(34, 197, 94, 0.1);
    border: 2px solid #22c55e;
    border-radius: 4px;
    color: #15803d;
    text-align: center;
    font-weight: 500;
}
#formSuccess {
    display: none;
}
/* Spezifität (1,1,0) nötig, damit display:block #formSuccess überschreibt */
#formSuccess.form-success-visible {
    display: block;
}
#formSuccess.form-success-error {
    display: block;
    background-color: rgba(185, 28, 28, 0.1);
    border-color: #B91C1C;
    color: #991B1B;
}

/* ============================================
   Footer
   ============================================ */
.footer {
    background-color: var(--tintenblau);
    color: var(--white);
    padding: 2rem 0;
}

.footer-content {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 1rem;
}

.footer-logo .logo-text {
    color: var(--white);
}

.footer-copyright {
    color: var(--white);
    font-size: 0.95rem;
}

.footer-toggles {
    display: flex;
    gap: 2rem;
    align-items: center;
}

.footer-toggle {
    background: none;
    border: none;
    color: rgba(255, 255, 255, 0.9);
    font-size: 0.95rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem;
    transition: color 0.3s ease;
    font-family: inherit;
}

.footer-toggle:hover {
    color: var(--white);
}

/* Accessibility: Focus-States für Keyboard-Navigation */
.footer-toggle:focus-visible {
    outline: 3px solid var(--saffran-gold);
    outline-offset: 3px;
    border-radius: 4px;
}

.footer-toggle:focus:not(:focus-visible) {
    outline: none;
}

/* Footer Toggle Icons - Responsive Größen */
.footer-toggle-icon {
    width: clamp(0.875rem, 1.2vw, 1rem);
    /* 14px - 16px responsive */
    height: clamp(0.875rem, 1.2vw, 1rem);
    transition: transform 0.3s ease;
    flex-shrink: 0;
}

.footer-toggle[aria-expanded="true"] .footer-toggle-icon {
    transform: rotate(180deg);
}

.footer-details {
    height: 0;
    overflow: hidden;
    transition: height 0.4s ease, padding 0.4s ease;
    padding: 0;
}

.footer-details[aria-hidden="false"] {
    /* height wird via JavaScript gesetzt (scrollHeight-basiert) */
    padding: 2rem 0 0 0;
}

.footer-details[data-animating="true"] {
    /* Während Animation: overflow bleibt hidden */
    overflow: hidden;
}

.footer-details[aria-hidden="false"]:not([data-animating="true"]) {
    /* Nach Animation: height: auto für responsive Verhalten */
    height: auto;
    overflow: visible;
}

.footer-details:not(:last-child)[aria-hidden="false"] {
    margin-bottom: 2rem;
}

.footer-section {
    margin-bottom: 0;
}

.footer-section:last-child {
    margin-bottom: 0;
}

.impressum-columns {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
    margin-top: 1rem;
}

.impressum-column-left,
.impressum-column-right {
    display: flex;
    flex-direction: column;
}

.footer-section h3 {
    font-size: 1.25rem;
    font-weight: 600;
    margin-bottom: 1rem;
    margin-top: 0;
    color: var(--white);
    font-family: 'Playfair Display', serif;
}

.footer-section h3:first-child {
    margin-top: 0;
}

.footer-subheading {
    font-size: 1.25rem;
    font-weight: 600;
    margin-top: 2rem;
    margin-bottom: 1rem;
    color: var(--white);
    font-family: 'Playfair Display', serif;
}

.footer-section p {
    color: rgba(255, 255, 255, 0.85);
    line-height: 1.7;
    margin-bottom: 1rem;
    font-size: 0.95rem;
}

.footer-section p:last-child {
    margin-bottom: 0;
}

.footer-link {
    color: var(--saffran-gold);
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 2px;
    transition: color 0.3s ease, text-decoration-thickness 0.3s ease;
}

.footer-link:hover {
    color: var(--white);
    text-decoration-thickness: 2px;
}

.datenschutz-section {
    max-width: 100%;
}

.datenschutz-section h4.datenschutz-subheading {
    font-size: 1.1rem;
    font-weight: 600;
    margin-top: 2rem;
    margin-bottom: 1rem;
    color: var(--white);
    font-family: 'Inter', sans-serif;
}

.datenschutz-section h4.datenschutz-subheading:first-of-type {
    margin-top: 1.5rem;
}

.datenschutz-list {
    list-style: none;
    padding-left: 0;
    margin: 1rem 0;
}

.datenschutz-list li {
    color: rgba(255, 255, 255, 0.85);
    line-height: 1.7;
    margin-bottom: 0.5rem;
    padding-left: 1.5rem;
    position: relative;
    font-size: 0.95rem;
}

.datenschutz-list li::before {
    content: '•';
    position: absolute;
    left: 0;
    color: var(--saffran-gold);
    font-weight: bold;
}

.datenschutz-section p {
    margin-bottom: 1rem;
}

.datenschutz-section p:last-child {
    margin-bottom: 0;
}

/* ============================================
   Responsive Design
   ============================================ */

/* Tablet-Breakpoint: 769px - 1200px (erweitert für verkleinerte Desktop-Fenster) */
@media (min-width: 769px) and (max-width: 1200px) {
    .bild-text-wrapper {
        gap: 3rem;
        /* Reduziert von 4rem für Tablets und verkleinerte Desktop-Fenster */
    }

    /* Bild-Text-Optimierungen für konsistentes Verhältnis */
    .bild-text {
        font-size: clamp(0.9375rem, 2vw, 1.0625rem);
        /* 15-17px statt 16-18px */
        line-height: 1.7;
        /* Reduziert von 1.8 für kompakteres Layout */
        margin-bottom: 1.25rem;
        /* Reduziert von 1.5rem */
    }

    .bild-text-title {
        margin-bottom: 1.25rem;
        /* Reduziert von 1.5rem */
    }

    /* Expertise-Description: Gleiche Textgröße wie bild-text für konsistente Typografie auf Tablets */
    .expertise-description {
        font-size: clamp(0.9375rem, 2vw, 1.0625rem);
        /* Gleiche Größe wie bild-text */
    }

    .kontakt-content {
        gap: 2rem;
        /* Reduziert von 3rem für Tablets */
    }

    /* .bild-text-section-Regel ENTFERNT - Querformat behält Standardwerte (3rem 0 4rem 0) */

    /* Expertise-Sektion: Padding-top reduziert für konsistenten Abstand zur Bild-/Text-Sektion */
    .expertise {
        padding: 3rem 0 6rem 0;
        /* padding-top reduziert von 4rem auf 3rem für Tablet */
    }
}

/* iPad Portrait und kleine Tablets: 768px - 834px */
@media (min-width: 768px) and (max-width: 834px) {

    /* Logo-Ausrichtung für iPad Portrait - Subtext nach links verschieben */
    .logo-text {
        letter-spacing: -0.3px;
        line-height: 1.1;
        padding-left: 0;
        margin-left: 0;
    }

    .logo-subtext {
        letter-spacing: -0.7px;
        /* Minimal weiter verstärkt für Portrait, damit Subtext kürzer wird */
        line-height: 1.2;
        padding-left: 0;
        margin-left: 0;
        text-indent: 0;
    }

    .logo-main {
        align-items: flex-start;
        padding-left: 0;
        margin-left: 0;
    }

    .honorar {
        padding: 3rem 0 5rem 0;
        /* padding-top: 3rem (48px), padding-bottom: 5rem (80px) für Tablet */
    }

    .kontakt {
        padding: 3rem 0 4rem 0;
        /* Tablet: padding-top: 3rem (48px), padding-bottom: 4rem (64px) */
    }

    .section-description {
        margin-bottom: 2.5rem;
        /* Reduziert von 3rem */
    }

    .hero {
        padding-top: 12vh;
        /* Zurück zu Standard für Tablets */
    }

    .hero-content {
        padding: 1.5rem;
        /* Reduziert für Tablets */
        padding-bottom: 10rem;
        /* Erhöht für Tablets - mehr Platz für CTA-Button */
    }
}

/* Tablets (769px-1200px): Hero-Bereich kompakter gestalten */
/* Hero-Höhe reduziert auf 70vh (statt 100vh) für bessere Balance */
@media (min-width: 769px) and (max-width: 1200px) {
    .hero {
        height: 70vh;
        min-height: 500px;
        padding-top: 12vh;
    }

    .hero-content {
        padding: 1.5rem;
        padding-bottom: 10rem;
        /* Erhöht für Tablets - mehr Abstand zwischen CTA-Button und Fade-Effekt */
    }

    /* Hero-Content: Container-Breite leicht reduziert für mehr Zeilen bei H1 */
    .hero-content .container {
        max-width: 700px;
        /* Leicht reduzierte Container-Breite für natürliche Umbrüche */
    }
}

/* Tablets im Hochformat: Bild-Text-Sektion kompakter */
/* min-height reduziert (80vh → 50vh) für kompakteres Layout im Hochformat */
@media (min-width: 769px) and (max-width: 1200px) and (max-aspect-ratio: 1/1) {
    .bild-text-section {
        min-height: 50vh;
        padding: 2rem 0 1.25rem 0;
    }

    .expertise {
        padding: 1.25rem 0 6rem 0;
    }

    /* Bild und Textblock vertikal zentriert, Textblock leicht nach oben */
    .bild-text-wrapper {
        align-items: center;
    }

    .bild-text-wrapper .bild-text-content {
        margin-top: -1.25rem;
    }

    /* Hero-Content: padding-bottom für Hochformat wieder reduzieren */
    .hero-content {
        padding-bottom: 6rem;
        /* Reduziert für Tablets im Hochformat */
    }
}

/* Tablets im Querformat: Globale 90% Skalierung durch font-size auf html */
/* Skaliert automatisch alle rem-basierten Werte (font-size, padding, margin, etc.) */
/* 90% (14.4px) entspricht Best Practices für Tablet-Lesbarkeit (Minimum: 14-15px) */
/* Hinweis: orientation: landscape basiert auf Viewport-Dimensionen (width > height), nicht physischer Geräteausrichtung */
@media (min-width: 769px) and (max-width: 1200px) and (orientation: landscape) {
    html {
        font-size: 90%;
    }

    /* Hero-Höhe erhöht für Tablets im Querformat - mehr Platz, Fade-Effekt beginnt später */
    .hero {
        height: 95vh;
        /* Erhöht für Tablets im Querformat - CTA-Button vollständig im Weißen */
    }

}

/* iPad Querformat und größere Tablets: 835px - 1200px */
@media (min-width: 835px) and (max-width: 1200px) {

    /* Logo-Ausrichtung für iPad Querformat - Subtext nach links verschieben */
    .logo-text {
        letter-spacing: -0.3px;
        line-height: 1.1;
        padding-left: 0;
        margin-left: 0;
    }

    .logo-subtext {
        letter-spacing: 0.55px;
        /* Minimal weiter verstärkt für Querformat */
        line-height: 1.2;
        padding-left: 0;
        margin-left: 0;
        text-indent: 0;
    }

    .logo-main {
        align-items: flex-start;
        padding-left: 0;
        margin-left: 0;
    }
}

@media (max-width: 768px) {
    .nav-menu {
        position: fixed;
        top: 70px;
        left: 0;
        width: 100%;
        background-color: var(--white);
        flex-direction: column;
        padding: 2rem;
        box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
        transform: translateX(-100%);
        transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
        /* Smooth, performant Animation */
        will-change: transform;
        /* Performance-Optimierung */
    }

    .nav-menu.active {
        transform: translateX(0);
    }

    .mobile-menu-toggle {
        display: flex;
    }

    .mobile-menu-toggle.active span:nth-child(1) {
        top: 50%;
        transform: translateX(-50%) translateY(-50%) rotate(45deg);
        /* Zentrieren und rotieren */
    }

    .mobile-menu-toggle.active span:nth-child(2) {
        opacity: 0;
        transform: translateX(-50%) translateY(-50%);
        /* Bleibt zentriert */
    }

    .mobile-menu-toggle.active span:nth-child(3) {
        bottom: auto;
        top: 50%;
        transform: translateX(-50%) translateY(-50%) rotate(-45deg);
        /* Zentrieren und rotieren */
    }

    /* Logo-Größen responsive für Mobile */
    .logo-text {
        font-size: clamp(1.375rem, 4vw, 1.75rem);
        letter-spacing: -0.3px;
        /* Leicht reduziert auf Mobile für bessere Ausrichtung */
        line-height: 1.1;
        /* Explizit setzen für konsistente Ausrichtung */
        padding-left: 0;
        margin-left: 0;
    }

    .logo-subtext {
        font-size: clamp(0.875rem, 2.5vw, 1.075rem);
        letter-spacing: -0.1px;
        /* Leicht negativ für perfekte Ausrichtung mit oberer Zeile */
        line-height: 1.2;
        /* Explizit setzen für konsistente Ausrichtung */
        padding-left: 0;
        margin-left: 0;
        text-indent: 0;
    }

    .logo-main {
        align-items: flex-start;
        /* Sicherstellen, dass beide Zeilen linksbündig starten */
        padding-left: 0;
        margin-left: 0;
    }

    .nav-wrapper {
        padding: 1rem 0;
        /* Reduziert von 1.25rem */
    }

    .hero {
        height: 100vh;
        height: 100svh;
        /* Small Viewport Height für Mobile - statisch, verhindert Sprünge */
        min-height: 500px;
        margin-top: 70px;
        padding-top: 10vh;
        /* Reduziert für Mobile */
    }

    .hero-content {
        padding: 1.5rem;
        /* Optimiert für Mobile */
        padding-bottom: 6rem;
        /* Reduzierter Abstand auf Mobile, aber immer noch ausreichend */
    }

    /* Section-Paddings optimieren für Mobile (Hochformat iPhone) */
    .bild-text-section {
        padding: 2rem 0 1.25rem 0;
    }

    /* Expertise-Sektion: geringerer Abstand zur Bild-Text-Sektion */
    .expertise {
        padding: 1.25rem 0 2rem 0;
    }

    /* Section-Header: margin-bottom reduziert für bessere Proportionen auf Mobile */
    .section-header {
        margin-bottom: 3rem;
        /* Reduziert von 4rem auf 3rem für Mobile */
    }

    .honorar {
        padding: 3rem 0;
        /* Reduziert von 6rem */
    }

    .kontakt {
        padding: 3rem 0;
        /* Reduziert von 6rem */
    }

    /* Kontakt-Header: margin-bottom reduziert für bessere Proportionen auf Mobile */
    .kontakt-header {
        margin-bottom: 3rem;
        /* Reduziert von 4rem auf 3rem für Mobile - konsistent mit .section-header */
    }

    .section-description {
        margin-bottom: 2rem;
        /* Reduziert von 3rem */
    }

    .bild-text-wrapper {
        grid-template-columns: 1fr;
        gap: 1.5rem;
    }

    /* Figure und Textblock bündig: Browser-Standard-Margins von figure entfernen (Samsung/Chrome) */
    .bild-text-wrapper figure,
    .bild-text-wrapper .bild-text-image-container,
    .bild-text-wrapper .bild-text-content {
        margin-left: 0;
        margin-right: 0;
    }

    .bild-text-image-container {
        margin-bottom: 0;
        /* Kein zusätzlicher Abstand nach dem Bild-Container */
    }

    .bild-text-image-wrapper {
        padding-bottom: 60%;
    }

    .bild-text-content {
        padding: 0;
        /* Kein Padding auf Mobile */
        padding-top: 0.75rem;
        /* Etwas Abstand oben auf Mobile */
    }

    .bild-text-title {
        font-size: clamp(1.5rem, 6vw, 2rem);
        /* Responsive für Mobile */
        margin-bottom: 1rem;
        margin-top: 0.5rem;
        /* Proportionaler Abstand auf Mobile */
        text-align: left;
    }

    .bild-text-caption {
        font-size: clamp(0.9375rem, 3vw, 1rem);
        /* Mobile: 15px - 16px für deutlich bessere Lesbarkeit */
        padding: 0.625rem 0.875rem;
        /* Reduziertes Padding für kompaktere Darstellung */
        margin-bottom: 0;
        /* Sicherstellen, dass kein zusätzlicher Abstand entsteht */
    }

    /* Hineinzoomen auf Mobile: Etwas reduzierter Zoom-Faktor für bessere UX */
    .bild-text-image-wrapper.zoomed .bild-text-image {
        transform: scale(1.6);
        /* Etwas weniger Zoom auf Mobile (statt 1.85) */
    }

    .bild-text {
        font-size: clamp(1rem, 2.5vw, 1.125rem);
        /* 16-18px - konsistent mit anderen gleichrangigen Texten */
    }

    .kontakt-content {
        grid-template-columns: 1fr;
    }

    /* Kontakt-Info: Optimierte vertikale Liste mit horizontalem Layout */
    .kontakt-info {
        display: flex;
        flex-direction: column;
        gap: 1.75rem;
        /* Ausgewogener Abstand zwischen den Items */
        padding-top: 0;
        /* Kein padding-top auf Mobile, da Kontaktdaten oberhalb des Formulars sind */
    }

    .kontakt-item {
        flex-direction: row;
        /* Icon links, Text rechts für platzsparendes Layout */
        gap: 1rem;
        /* Leicht reduziert von 1.5rem */
        align-items: flex-start;
        /* Top-aligned für bessere Lesbarkeit bei mehrzeiligem Text */
    }

    /* Kontakt-Icons: Leicht kleiner auf Mobile, aber noch gut sichtbar */
    .kontakt-icon {
        width: clamp(2.75rem, 5vw, 3rem);
        /* 44-48px statt 48-50px */
        height: clamp(2.75rem, 5vw, 3rem);
        min-width: clamp(2.75rem, 5vw, 3rem);
    }

    .kontakt-icon .icon {
        width: clamp(1.25rem, 2.5vw, 1.5rem);
        /* 20-24px statt 22-24px */
        height: clamp(1.25rem, 2.5vw, 1.5rem);
    }

    /* Normale Schriftgrößen für Konsistenz mit anderen Mobile-Texten */
    .kontakt-item h3 {
        font-size: clamp(1rem, 2vw, 1.125rem);
        /* 16-18px - konsistent mit anderen Mobile-Titeln */
        margin-bottom: 0.375rem;
        /* Leicht reduziert von 0.5rem */
    }

    .kontakt-item p {
        font-size: clamp(0.9375rem, 2.5vw, 1rem);
        /* 15-16px - konsistent mit anderen Mobile-Texten */
        line-height: 1.6;
        /* Standard für bessere Lesbarkeit */
    }

    .expertise-grid {
        grid-template-columns: 1fr;
    }

    .expertise-header {
        gap: 0.75rem;
        /* Kleinerer Gap auf Mobile */
    }

    .expertise-title {
        font-size: clamp(1.25rem, 4vw, 1.5rem);
        /* Etwas kleiner auf Mobile */
    }

    /* Mobile: etwas weniger Zeilen sichtbar als auf Desktop (5,5 statt 6) */
    .expertise-description-wrapper {
        max-height: calc(1.8em * 5.5);
    }

    .footer-content {
        flex-direction: column;
        text-align: center;
    }

    .footer-toggles {
        flex-direction: column;
        gap: 1rem;
        width: 100%;
    }

    .footer-toggle {
        justify-content: center;
        width: 100%;
        padding: 1rem 0.5rem;
        /* Größere Touch-Targets für Mobile (mindestens 44px Höhe) */
        min-height: 44px;
        /* Apple HIG: Mindest-Touch-Target-Größe */
    }

    .impressum-columns {
        grid-template-columns: 1fr;
        gap: 2rem;
    }

    .section-title {
        font-size: clamp(1.75rem, 6vw, 2rem);
        /* Responsive statt fester 2rem */
    }

    /* Textgrößen optimieren für Mobile */
    .section-description {
        font-size: clamp(0.9375rem, 2.5vw, 1.125rem);
    }

    .expertise-description {
        font-size: clamp(0.9375rem, 2.5vw, 1.125rem);
    }

    .honorar-description {
        font-size: clamp(0.9375rem, 2.5vw, 1.125rem);
    }
}

@media (max-width: 480px) {
    .container {
        padding: 0 15px;
    }

    /* Logo noch kleiner auf sehr kleinen Screens */
    .logo-text {
        font-size: clamp(1.25rem, 5vw, 1.5rem);
        letter-spacing: -0.25px;
        /* Noch weiter reduziert für sehr kleine Screens */
        line-height: 1.1;
        padding-left: 0;
        margin-left: 0;
    }

    .logo-subtext {
        font-size: clamp(0.8125rem, 3vw, 1rem);
        letter-spacing: -0.1px;
        /* Leicht negativ für perfekte Ausrichtung */
        line-height: 1.2;
        padding-left: 0;
        margin-left: 0;
        text-indent: 0;
    }

    .nav-wrapper {
        padding: 0.875rem 0;
        /* Noch kompakter */
    }

    .hero {
        height: 105vh;
        height: 105svh;
        /* Erhöht für sehr kleine Mobile-Geräte - mehr Platz zwischen CTA-Button und Fade-Effekt */
        min-height: 400px;
        /* Reduziert von 500px */
        padding-top: 8vh;
        /* Reduziert für sehr kleine Mobile-Geräte */
    }

    .hero-content {
        padding: 1rem;
        /* Minimal für sehr kleine Bildschirme */
        padding-bottom: 5rem;
        /* Angepasster Abstand für sehr kleine Bildschirme */
    }

    /* Section-Paddings weiter reduzieren (kleine iPhones Hochformat) */
    .bild-text-section {
        padding: 1.5rem 0 1rem 0;
    }

    .expertise {
        padding: 1rem 0 2.5rem 0;
    }

    .honorar {
        padding: 2.5rem 0;
    }

    .kontakt {
        padding: 2.5rem 0;
    }

    /* Bild-Text-Optimierungen für kleine Screens */
    .bild-text-title {
        font-size: clamp(1.375rem, 6vw, 1.75rem);
    }

    .bild-text-caption {
        font-size: clamp(0.9375rem, 3vw, 1rem);
        /* Small Mobile: 15px - 16px */
    }

    .expertise-card {
        padding: 1.5rem;
        /* Bleibt unverändert */
    }

    .kontakt-form {
        padding: 2.5rem 1.5rem;
        /* Oben/Unten: 2.5rem (40px), Links/Rechts: 1.5rem für deutlich mehr weiße Fläche */
    }

    .expertise-header {
        gap: 0.5rem;
        /* Noch kompakter auf sehr kleinen Screens */
        margin-bottom: 0.875rem;
    }

    .expertise-icon {
        width: clamp(2.25rem, 6vw, 2.75rem);
        /* Etwas kleiner auf sehr kleinen Screens */
        height: clamp(2.25rem, 6vw, 2.75rem);
    }

    .expertise-icon .icon {
        width: clamp(1.25rem, 4vw, 1.5rem);
        height: clamp(1.25rem, 4vw, 1.5rem);
    }

    /* Kontakt-Info: Weiter optimiert für sehr kleine Screens */
    .kontakt-info {
        gap: 1.5rem;
        /* Ausgewogener Abstand auch auf kleinen Screens */
    }

    .kontakt-item {
        gap: 0.875rem;
        /* Leicht reduziert, aber nicht zu eng */
    }

    .kontakt-icon {
        width: clamp(2.5rem, 5vw, 2.875rem);
        /* 40-46px auf sehr kleinen Screens */
        height: clamp(2.5rem, 5vw, 2.875rem);
        min-width: clamp(2.5rem, 5vw, 2.875rem);
    }

    .kontakt-icon .icon {
        width: clamp(1.125rem, 2.5vw, 1.375rem);
        /* 18-22px */
        height: clamp(1.125rem, 2.5vw, 1.375rem);
    }

    .kontakt-item h3 {
        font-size: clamp(0.9375rem, 2vw, 1.0625rem);
        /* 15-17px - noch lesbar */
    }

    .kontakt-item p {
        font-size: clamp(0.875rem, 2.5vw, 0.9375rem);
        /* 14-15px - noch lesbar */
    }
}

/* ============================================
   Smooth Scroll Animation
   ============================================ */
@media (prefers-reduced-motion: no-preference) {

    .expertise-card,
    .kontakt-item {
        opacity: 0;
        transform: translateY(20px);
        animation: fadeInUp 0.6s ease forwards;
    }

    .expertise-card:nth-child(1) {
        animation-delay: 0.05s;
    }

    .expertise-card:nth-child(2) {
        animation-delay: 0.1s;
    }

    .expertise-card:nth-child(3) {
        animation-delay: 0.15s;
    }

    .expertise-card:nth-child(4) {
        animation-delay: 0.2s;
    }

    .expertise-card:nth-child(5) {
        animation-delay: 0.25s;
    }

    .expertise-card:nth-child(6) {
        animation-delay: 0.3s;
    }
}

@keyframes fadeInUp {
    to {
        opacity: 1;
        transform: translateY(0);
    }
}