/* ============= V1.00 – 05.12.2025 ========== */
/* ===== Grundlayout V.005 28.08.2025 ===== */
body {
    margin: 0;
    font-family: Calibri, sans-serif;
    line-height: 1.5;
}

/* ===== Header ===== */
/* Standard: Menü sichtbar */
#mainMenu {
    display: flex;
    gap: 1rem;
}

/* Mobile: Menü verstecken und erst bei .open zeigen */
@media (max-width: 768px) {
    #mainMenu {
        display: none;
        flex-direction: column;
        background: rgba(245,245,245,0.95);
        position: absolute;
        top: 72px;

        /* Höhe deines Headers */
        right: 0;
        padding: 1rem;
        box-shadow: 0 4px 12px rgba(0,0,0,0.15);
    }

    #mainMenu.open {
        display: flex;
    }
}

.main-header {
    display: flex;
    justify-content: space-between;
    align-items: center;

    /* Hintergrund sehr helles Grün + Transparenz */
    background-color: #71AB2B;

    /* #71AB2B mit 5% - 30% */
    backdrop-filter: blur(4px);

    /* sorgt für einen Glass-Effekt */
    /* manuelle Höhensteuerung */
    height: 52px;

    /* hier frei ändern */
    padding: 0.5rem 1rem;
    position: sticky;
    top: 0;
    z-index: 1000;
}

.main-header .logo img {
    height: 40px;

    /* Logo größer */
}

/* Menü-Links */
.main-header nav a {
    color: #131F3C;

    /* Blau */
    margin: 0 0.8rem;
    text-decoration: none;
    font-size: 23px;
    line-height: 52px;

    /* gleiche Höhe wie .main-header */
}

.main-header nav a:hover {
    color: #385a0e;
}

/* Burger-Button */
.burger {
    background: transparent;
    border: 0;
    padding: 8px;
    display: grid;
    place-items: center;
    cursor: pointer;
    color: #131F3C;

    /* Standard: Blau */
}

.burger:hover {
    color: #71AB2B;
}

/* Hover: Grün */
.burger:focus-visible {
    outline: 2px solid #3A6EA5;
    outline-offset: 2px;
}

.burger-icon .line {
    stroke: currentColor;
    stroke-width: 2.5;
    stroke-linecap: round;
    transition: transform 200ms ease, opacity 150ms ease;
    transform-box: fill-box;
    transform-origin: 50% 50%;
}

/* Animation zum X, wenn geöffnet */
.burger.is-open .l1 {
    transform: translateY(6px) rotate(45deg);
}

.burger.is-open .l2 {
    opacity: 0;
}

.burger.is-open .l3 {
    transform: translateY(-6px) rotate(-45deg);
}

/* ===== Hero ===== */
.hero {
    position: relative;
    overflow: hidden;
    min-height: clamp(45vh, 60vh, 72vh);
    color: white;
}

.hero-content {
    position: relative;

    /* bleibt über dem Overlay */
    z-index: 1;
    display: flex;
    align-items: center;
    min-height: clamp(45vh, 60vh, 72vh);
    padding: clamp(1rem, 5vw, 6rem);
    text-align: left;

    /* besser lesbar auf Desktop */
    max-width: 70ch;
    text-shadow: 0 2px 8px rgba(0,0,0,.35);
    display: grid;

    /* bleibt responsiv */
    place-items: start;

    /* linksbündig Desktop */
}

.hero-stack {
    display: flex;
    flex-direction: column;
    gap: clamp(.5rem, 1.5vw, 1rem);
    align-items: flex-start;
}

.hero-logo {
    height: clamp(72px, 14vw, 140px);
    width: auto;
    filter: drop-shadow(0 2px 6px rgba(0,0,0,.35));
}

.hero p {
    font-size: clamp(2.1rem, 2.2vw, 2.4rem);
    margin: 0;
}

.hero-pic {
    position: absolute;
    inset: 0;
}

.hero-pic img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
}

.hero::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(
    to right,
    rgba(19,31,60,.65) 0%,
    rgba(19,31,60,.25) 40%,
    rgba(19,31,60,0) 70%
  );
    pointer-events: none;
}

.hero-logos {
    display: flex;
    gap: 16px;
    align-items: center;
    flex-wrap: wrap;
}

.hero-logos img {
    height: 48px;
}

@media (max-width: 768px) {
    .hero-content {
        place-items: center;
        text-align: center;
    }

    .hero-stack {
        align-items: center;
    }
}

/* H1 und P */
/* Willkommen-Überschrift */
.hero-text h1 {
    font-family: 'Lora', 'Times New Roman', serif;
    font-size: clamp(4rem, 5vw, 6rem);
    font-weight: 700;
    margin-bottom: .5rem;
    margin: 0 0 .25rem 0;
    color: #bad5b4;
    font-style: italic;
}

/* Zitat-Stil für den Untertext */
.hero-text p {
    font-family: 'Merriweather', 'Georgia', serif;
    font-style: italic;
    position: relative;
    padding-left: 1.5em;
    color: rgb(228, 232, 237);
}

/* Anführungszeichen automatisch setzen */
.hero-text p::before {
    content: "“";
    position: absolute;
    left: 0;
    top: 0;
    font-size: 6rem;
    color: #bad5b4;

    /* dein Grün als Akzent */
    line-height: 1;
}

/* ===== Zweispalter ===== */
.locations {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    padding: 2rem 1rem;
    justify-content: center;
}

.location {
    flex: 1 1 400px;
    max-width: 500px;
    background: #f5f5f5;
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 4px 10px rgba(0,0,0,0.1);
}

.location img {
    width: 100%;
    height: auto;
    display: block;
}

.location-text {
    padding: 1rem;
}

.location-text h2 {
    margin-top: 0;
    color: #131F3C;
}

.location-text p {
    color: #333;
}

/* === Zweispalter: Text oben, Bild darunter === */
.location {
    display: flex;
    flex-direction: column;

    /* erzwingt Text->Bild vertikal */
}

.location img {
    width: 100%;
    height: clamp(180px, 26vw, 280px);

    /* einheitliche Höhe */
    object-fit: cover;

    /* schöner Beschnitt */
    object-position: center;
    display: block;
}

/* === Corporate Farben (falls noch nicht gesetzt) === */
:root {
    --accent-green: #71AB2B;
    --accent-blue: #131F3C;
    --neutral: #F5F5F5;
}

/* === Überschrift im Standort-Block === */
.location-text h2 {
    font-family: 'Lora','Times New Roman',serif;
    font-weight: 700;
    color: var(--accent-blue);
    margin: 0 0 .6rem 0;
    letter-spacing: .2px;
}

/* === Liste: clean + mit grünem Check-Icon === */
.location-text ul {
    list-style: none;
    margin: 0 0 1rem 0;
    padding: 0;
    display: grid;
    gap: .5rem;

    /* Abstand zwischen Punkten */
}

.location-text li {
    position: relative;
    padding-left: 1.6em;

    /* Platz fürs Icon */
    line-height: 1.35;
    color: #1a1a1a;
}

/* Check-Icon */
.location-text li::before {
    content: "✔";
    position: absolute;
    left: 0;
    top: 0;
    transform: translateY(0.05em);
    font-weight: 700;
    color: var(--accent-green);
}

/* dezenter Hover für Desktop (optional) */
@media (hover:hover){
    .location-text li:hover {
        color: #0f0f0f;
    }

    .location-text li:hover::before {
        filter: brightness(1.1);
    }
}

/* Abstand zur Bildkante und Konsistenz */
.location img {
    margin-top: .6rem;

    /* Liste über dem Bild → kleiner Abstand */
    border-radius: 12px;

    /* weichere Kante, optional */
    box-shadow: 0 6px 18px rgba(0,0,0,.08);
}

/* ===== Footer ===== */
footer {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    background-color: #131F3C;

    /* Dunkelblau */
    color: #F5F5F5;

    /* Hell */
    padding: 2rem 1rem;
    font-size: 14px;
}

footer h4 {
    margin: 0 0 .5rem;
    color: #71AB2B;

    /* Grün-Akzent */
    font-size: 1rem;
}

footer p {
    margin: 0;
    line-height: 1.5;
}

.footer-left,
.footer-right {
    flex: 1 1 300px;
    margin: .5rem;
}

.socials {
    margin-top: .5rem;
}

.socials a {
    margin-right: .5rem;
    text-decoration: none;
    font-size: 1.2rem;
    color: #F5F5F5;
}

.socials a:hover {
    color: #71AB2B;
}

/* Mobile */
@media (max-width: 768px) {
    footer {
        flex-direction: column;
        text-align: center;
    }

    .footer-left,
    .footer-right {
        flex: 1 1 auto;
        margin: 1rem 0;
    }
}

/* V.018 15.10.2025 */
.footer-grid {
    display: grid;
    gap: 16px;
}

@media (min-width:768px){
    .footer-grid {
        grid-template-columns: 1fr 1fr;
    }
}

.footer-loc {
    display: grid;
    gap: 8px;
}

.loc-logo {
    height: 28px;
}

.map {
    height: 240px;
    border-radius: 10px;
    margin-top: .5rem;
}

.route-actions {
    display: flex;
    gap: .5rem;
}

.btn-route,
.btn-show-map {
    border: 0;
    border-radius: 10px;
    padding: .5rem .8rem;
    cursor: pointer;
}

.route-actions {
    display: flex;
    gap: .5rem;
    margin-top: .5rem;
}

.btn-route {
    appearance: none;
    border: 0;
    border-radius: 10px;
    padding: .5rem .8rem;
    font: inherit;
    cursor: pointer;
    background: var(--accent-green);
    color: #fff;
}

.btn-route:hover {
    filter: brightness(1.05);
}

/* ===== Mobile ===== */
@media (max-width: 768px) {
    .hero {
        padding: 4rem 1rem;
    }

    .hero h1 {
        font-size: 1.8rem;
    }
}

/* =============== SEITENMENU =============== */
/* Kontakt-Dock | V005 */
:root {
    --dock-bg: #131F3C;

    /* Dunkelblau */
    --dock-accent: #71AB2B;

    /* Grün */
    --dock-text: #71AB2B;
    --dock-shadow: 0 6px 22px rgba(0,0,0,.22);
    --dock-size: 46px;

    /* Button-Kante */
    --dock-gap: 10px;
    --dock-radius: 14px;
    --dock-z: 9999;
}

/* Container */
.contact-dock {
    position: fixed;
    inset: auto auto 10vh 0;

    /* links, vertikal ~unten */
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: var(--dock-gap);
    padding: 6px;
    background: transparent;
    z-index: var(--dock-z);
}

/* Toggle-Button (für Mobile) */
.contact-dock .dock-toggle {
    width: var(--dock-size);
    height: var(--dock-size);
    border: 0;
    border-top-right-radius: var(--dock-radius);
    border-bottom-right-radius: var(--dock-radius);
    background: var(--dock-bg);
    color: var(--dock-text);
    box-shadow: var(--dock-shadow);
    cursor: pointer;
    position: relative;
}

.contact-dock .dock-toggle::before,
.contact-dock .dock-toggle::after {
    content: "";
    position: absolute;
    left: 50%;
    translate: -50% -50%;
    width: 18px;
    height: 2px;
    background: currentColor;
    transition: transform .2s ease;
}

.contact-dock .dock-toggle::before {
    top: 43%;
    box-shadow: 0 6px 0 currentColor, 0 -6px 0 currentColor;
}

.contact-dock .dock-toggle[aria-expanded="true"]::before {
    box-shadow: none;
    transform: rotate(90deg);
}

.contact-dock .dock-toggle[aria-expanded="true"]::after {
    top: 50%;
    transform: rotate(90deg);
    opacity: 0;
}

/* Liste */
.dock-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: var(--dock-gap);
    transition: max-height .2s ease;
}

/* Button */
.dock-btn {
    display: inline-grid;
    place-items: center;
    grid-auto-flow: column;
    gap: 10px;
    min-width: var(--dock-size);
    height: var(--dock-size);
    padding: 0 12px 0 10px;
    border-top-right-radius: var(--dock-radius);
    border-bottom-right-radius: var(--dock-radius);
    background: var(--dock-bg);
    color: var(--dock-text);
    box-shadow: var(--dock-shadow);
    text-decoration: none;
    position: relative;
    isolation: isolate;
    outline: none;
}

.dock-btn svg {
    width: 20px;
    height: 20px;
    fill: currentColor;
    stroke: currentColor;

    /* Umriss zusätzlich */
    stroke-width: 2.5;

    /* macht es fetter */
}

/* Normal */
.dock-btn {
    background: var(--dock-bg);

    /* Blau */
    color: var(--dock-accent);

    /* Grün */
}

/* Label als Tooltip-Blase – fährt bei Hover/Focus aus */
.dock-btn::after {
    content: attr(data-label);
    opacity: 0;
    pointer-events: none;
    position: absolute;
    left: calc(100% + 8px);
    top: 50%;
    translate: 0 -50%;
    background: var(--dock-bg);
    color: var(--dock-text);
    padding: 6px 10px;
    border-radius: 10px;
    white-space: nowrap;
    box-shadow: var(--dock-shadow);
    transition: opacity .15s ease, transform .15s ease;
    transform: translateY(-50%) translateX(-6px);
}

.dock-btn:hover::after,
.dock-btn:focus-visible::after {
    opacity: 1;
    transform: translateY(-50%) translateX(0);
}

/* Hover/Fokus 
.dock-btn:hover,
.dock-btn:focus-visible{
  background: linear-gradient(90deg, var(--dock-accent), var(--dock-bg));
} */
.dock-btn:hover,
.dock-btn:focus-visible {
    background: var(--dock-accent);

    /* Grün */
    color: var(--dock-bg);

    /* Blau */
}

/* Kollisionen vermeiden (z.B. mit Burger rechts oben) */
@media (min-width: 901px){
    .contact-dock {
        inset: auto auto 20vh 0;
    }
}

/* Mobile: Dock ist einklappbar, Labels dauerhaft verstecken */
@media (max-width: 900px){
    .dock-btn::after {
        display: none;
    }

    /* keine Blasen auf Mobile */
    .dock-list {
        max-height: 0;
        overflow: hidden;
    }

    .contact-dock .dock-toggle[aria-expanded="true"] + .dock-list {
        max-height: 500px;
    }
}

/* Nutzerpräferenz: reduzierte Bewegung */
@media (prefers-reduced-motion: reduce){
    .dock-btn,
    .dock-btn::after,
    .dock-list {
        transition: none !important;
    }
}

/* Tastatur-Fokus sichtbar */
.dock-btn:focus-visible {
    outline: 2px solid var(--dock-accent);
    outline-offset: 2px;
}

/* ===== EBER PANELS (V6-Prinzip) — Ergänzung V010 ===== */
/* Kompakt-Set: max 1200px, 2-Spalter ohne Bildbeschnitt, 3 Farbthemen, variable vertikale Abstände */
:root {
    --container-max: 1200px;
    --gap: clamp(16px, 2.5vw, 32px);
    --radius: 16px;
}

.container {
    max-width: var(--container-max);
    margin-inline: auto;
    padding-inline: clamp(12px,2vw,24px);
}

/* Panel = Karte mit Rundung + Theme-Variablen */
.panel {
    --panel-bg: #ffffff;

    /* Standard: weiß */
    --panel-fg: #131F3C;

    /* Standard: dunkelblau */
    background: var(--panel-bg);
    color: var(--panel-fg);
    border-radius: var(--radius);

    /* alt  padding: clamp(16px,2.2vw,28px);    V010 30.09.25 */
    padding-block: var(--pad-block, clamp(16px,2.2vw,28px));

    /* oben/unten */
    padding-inline: var(--pad-inline, clamp(16px,2.2vw,28px));

    /* links/rechts */
    margin-top: var(--space-top, 2rem);
    margin-bottom: var(--space-bottom, 2rem);
}

/* Farbvarianten (nutzt Eure Corporate-Farben aus V010) */
.theme-blue {
    --panel-bg: #131F3C;
    --panel-fg: #ffffff;
}

.theme-green {
    --panel-bg: #71AB2B;
    --panel-fg: #ffffff;
}

.theme-white {
    --panel-bg: #ffffff;
    --panel-fg: #131F3C;
}

.theme-gray {
    --panel-bg: #F5F5F5;

    /* = euer --neutral    V.014 */
    --panel-fg: #131F3C;

    /* dunkelblau wie white */
}

/* später ggf. #f5f7fb */
/* Überschriften nur innerhalb der Panels, serifenlos */
.panel h2 {
    font-family: Calibri, "Segoe UI", Roboto, Arial, sans-serif;
    font-weight: 800;
    font-size: 2em;
    line-height: 1.15;
    margin: 0 0 .5em 0;
}

.panel h3 {
    font-family: Calibri, "Segoe UI", Roboto, Arial, sans-serif;
    font-weight: 700;
    font-size: 1.5em;
    line-height: 1.2;
    margin: 0 0 .5em 0;
}

/* 2-Spalter-Grundraster */
.row {
    display: grid;
    grid-template-columns: 1fr 1fr;

    /* 50/50 */
    gap: var(--gap);
    align-items: center;

    /* vertikal mittig */
}

/* Bild: nie beschneiden, wächst nur bei Zoom */
.row img {
    display: block;
    max-width: 100%;
    height: auto;
    object-fit: contain;
    border-radius: calc(var(--radius) - 4px);
}

/* Textspalte */
.text {
    text-align: left;
}

/* Text-only Variante: linksbündig wie 2-Spalter-Textkante */
.row.text-only {
    grid-template-columns: 1fr 1fr;
}

.row.text-only .text {
    grid-column: 2;

    /* startet dort, wo sonst die rechte Spalte beginnt */
}

/* Responsiv stapeln */
@media (max-width: 800px){
    .row,
    .row.text-only {
        grid-template-columns: 1fr;
    }

    .row.text-only .text {
        grid-column: 1;
    }
}

/* Optional: Altes .locations-Layout ohne Beschnitt aktivieren
   → einfach der Wrapper-Klasse .locations zusätzlich .no-crop geben */
.locations.no-crop .location img {
    height: auto !important;
    object-fit: contain !important;
}

/* In Container */
/* Text-only: volle Breite, linke Kante = Start der 2. Spalte */
.row.text-only {
    grid-template-columns: 1fr 1fr;
}

.row.text-only .text {
    grid-column: 1 / -1;

    /* padding-left: calc(50% + var(--gap)/2); */
}

/* Mobil zurück auf normal */
@media (max-width: 800px){
    .row,
    .row.text-only {
        grid-template-columns: 1fr;
    }

    .row.text-only .text {
        grid-column: 1;
        padding-left: 0;
    }
}

/* ======== V.020 - 17.10.2025 ---- */
:root {
    --brand-blue: #131F3C;

    /* euer Blau */
    --accent-green: #71AB2B;

    /* euer Grün */
}

.site-footer {
    background: var(--brand-blue);
    color: #fff;

    /* Lesbarkeit: Weiß als Grundschrift */
    padding: 2.2rem 1rem;
    margin-top: 2rem;
}

.footer-grid {
    display: grid;
    gap: 1.5rem;
}

@media (min-width:768px){
    .footer-grid {
        grid-template-columns: 1fr 1fr 1fr;
    }
}

.footer-col {
    display: grid;
    gap: .6rem;
}

.footer-heading {
    color: var(--accent-green);
    font-size: 1.05rem;
    margin: 0 0 .2rem 0;
}

.footer-address a {
    color: var(--accent-green);
    text-decoration: none;
}

.footer-address a:hover {
    text-decoration: underline;
}

.footer-links {
    list-style: none;
    margin: .2rem 0 0;
    padding: 0;
    display: grid;
    gap: .25rem;
}

.footer-links a {
    color: var(--accent-green);
    text-decoration: none;
}

.footer-links a:hover {
    text-decoration: underline;
}

.route-actions {
    display: flex;
    gap: .5rem;
    flex-wrap: wrap;
}

.btn-route,
.btn-show-map {
    appearance: none;
    border: 0;
    border-radius: 10px;
    padding: .5rem .8rem;
    font: inherit;
    cursor: pointer;
    background: var(--accent-green);
    color: #fff;
}

.btn-route:hover,
.btn-show-map:hover {
    filter: brightness(1.06);
}

.map {
    height: 220px;
    border-radius: 10px;
    margin-top: .5rem;
}

.socials {
    display: flex;
    gap: .6rem;
    margin-top: .6rem;
}

.social-link {
    color: var(--accent-green);
    display: inline-grid;
    place-items: center;
}

.social-link:focus-visible {
    outline: 2px solid #fff;
    outline-offset: 2px;
}

/* Optional: Wenn wirklich ALLE Texte grün sein sollen (Kontrast prüfen!) */
/* .site-footer{ color: var(--accent-green); } */
/* ===== Footer Patch V.017 → V.020 (18.10.2025) – minimal ===== */
/* 3 Spalten je 1/3 Breite ab 768px */
@media (min-width: 768px){
    .site-footer .footer-grid {
        display: grid;
        grid-template-columns: 1fr 1fr 1fr;

        /* 3x 1/3 */
    }
}

/* Innenabstand pro Spalte: links & oben 40px */
.site-footer .footer-col {
    padding-left: 40px;
    padding-top: 40px;
}

/* --------------- V.021 - 19.10.2025 ------------------- */
/* ===== Eberangebot – „table-like“ 3-Spalten, kein Zwischenraum (V.021) ===== */
:root {
    /* falls noch nicht gesetzt, nutzt du bereits in der Datei */
    --neutral: #F5F5F5;
    --accent-blue: #131F3C;
    --accent-green: #71AB2B;
}

/* Sektion grau, Text standardmäßig blau */
.offer.theme-gray {
    background: var(--neutral);
}

.offer {
    color: var(--accent-blue);
}

/* Container auf 90% Breite, zentriert */
.offer-container {
    width: 90%;
    margin-inline: auto;
    padding-block: 24px;

    /* minimaler vertikaler Atem */
    padding-inline: 0;

    /* seitlich bündig zur 90%-Kante */
}

/* H2 über volle Breite, grün */
.offer-title {
    color: var(--accent-green);
    font-weight: 800;
    margin: 0 0 12px 0;

    /* enger Abstand zur 3er-Reihe */
}

/* 3 Spalten, KEIN GAP */
.offer-grid {
    display: grid;
    grid-template-columns: 1fr;

    /* mobil */
    gap: 0;
}

@media (min-width: 1024px){
    .offer-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* Karten: kein Schatten, keine Rundung, transparenter Hintergrund -> „table“-Look */
.offer-card {
    background: transparent;
    padding: 16px;

    /* Innenabstand OK, außen kein Spalt */
    border-radius: 0;
    box-shadow: none;
}

/* Card-Typo: Überschrift grün, Fließtext blau */
.offer-card-title {
    color: var(--accent-green);
    margin: 0 0 6px 0;
    font-weight: 700;
}

.offer-card-text {
    color: var(--accent-blue);
    margin: 0;
    font-size: 1.5em;
    line-height: 1.15;
}

.offer-grid > .offer-card + .offer-card {
    border-left: 1px solid rgba(0,0,0,.06);
}

/* ------- V.022 -------- */
/* Universelle Full-Bleed-Hülle (umgeht Container-Widths & Paddings) */
.bleed {
    width: 100vw;

    /* volle Viewportbreite */
    margin-left: 50%;

    /* zentrieren … */
    transform: translateX(-50%);

    /* … ohne Negativmargins */
}

@supports (width: 100dvw) {
    .bleed {
        width: 100dvw;
    }

    /* korrigiert Scrollbar/OS-Balken auf Mobil */
}

.bleed img {
    display: block;
    width: 100%;
    height: auto;
}

/* Sicherheitsnetz: kein seitliches Panel/Raster-Padding aufs Full-Bleed anwenden */
.panel .row {
    /* dein normales Raster bleibt wie es ist */
}

.panel .bleed {
    /* separat, ohne Abhängigkeit von .row */
}

/* Optionaler Beschnitt (Hero-Look) */
.bleed--cover img {
    height: clamp(240px, 50vh, 560px);
    object-fit: cover;
    object-position: center;
}

/* ===== Quick Actions (Kachel-Buttons) V.024 - 27.10.2025===== */
:root {
    --qa-radius: 14px;

    /* gleiche Ecke wie Dock-Buttons */
    --qa-minh: 22px;

    /* --qa-icon-box: clamp(40px, 4vw, 52px);
    --qa-icon-svg: clamp(28px, 3vw, 36px); */
    --qa-icon-box: 56px;
    --qa-icon-svg: 42px;
}

.quick-actions {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: clamp(.6rem, 2vw, 1rem);
    padding: clamp(1rem, 4vw, 0.5rem) 1rem;
    max-width: 1200px;
    margin-inline: auto;
}

@media (max-width: 1200px){
    .quick-actions {
        grid-template-columns: repeat(6, 1fr);
    }
}

@media (max-width: 700px){
    .quick-actions {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 420px){
    .quick-actions {
        grid-template-columns: 1fr;
    }
}

.qa-btn {
    grid-column: span 4;

    /* 3 pro Reihe auf Desktop */
    display: flex;
    align-items: center;
    gap: 12px;
    min-height: var(--qa-minh);
    padding: 14px 14px;
    border-radius: var(--qa-radius);

    /* viereckig mit runden Ecken */
    background: var(--accent-green);

    /* grüner Hintergrund */
    color: #fff;

    /* gute Lesbarkeit */
    text-decoration: none;
    box-shadow: 0 8px 22px rgba(0,0,0,.08), inset 0 0 0 1px rgba(0,0,0,.04);
    transition: transform .12s ease, box-shadow .15s ease, background .15s ease;
    position: relative;
    isolation: isolate;
}

.qa-btn .qa-icon {
    display: grid;
    place-items: center;
    flex: 0 0 auto;
    width: 34px;
    height: 34px;
    border-radius: 10px;
    background: rgba(255,255,255,.12);

    /* dezentes Icon-Pad */
}

.qa-btn .qa-icon svg {
    width: 26px;
    height: 26px;
    stroke: var(--accent-blue);

    /* blaue Icons */
}

.qa-btn .qa-label {
    font-size: clamp(1.2rem, 1.6vw, 1.1rem);
    line-height: 1.2;
    letter-spacing: .2px;
}

/* Hover/Focus: leicht anheben, gleiche Farbwelt beibehalten */
.qa-btn:hover,
.qa-btn:focus-visible {
    transform: translateY(-1px);
    box-shadow: 0 12px 28px rgba(0,0,0,.12), inset 0 0 0 1px rgba(0,0,0,.06);
    outline: 2px solid color-mix(in oklab, var(--accent-blue) 55%, white);
    outline-offset: 2px;
}

/* Active: kurzer Druckeffekt */
.qa-btn:active {
    transform: translateY(0);
    box-shadow: 0 6px 16px rgba(0,0,0,.10) inset;
}

/* Reduzierte Bewegung respektieren */
@media (prefers-reduced-motion: reduce){
    .qa-btn {
        transition: none;
    }
}

/* Icon-Container größer */
.quick-actions .qa-btn .qa-icon {
    width: var(--qa-icon-box);
    height: var(--qa-icon-box);
    border-radius: 12px;

    /* leicht größerer Radius wirkt stimmig */
}

/* SVG selbst größer + etwas kräftigere Linien */
.quick-actions .qa-btn .qa-icon svg {
    width: var(--qa-icon-svg);
    height: var(--qa-icon-svg);
    stroke-width: 2.4;
}

/* Oswald-Überschriften (flexibel einsetzbar)  V.024 - 27.10.2025 */
:root {
    --heading-color: var(--accent-green);

    /* Standardfarbe – pro Element überschreibbar */
}

.u-heading {
    font-family: ui-sans-serif, system-ui, -apple-system, "Segoe UI",
               Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif;
    font-weight: 500;

    /* Oswald am Anfang raus genommen ab V.029 */
    /* 400/500/600 sind meist ideal */
    line-height: 1.15;
    letter-spacing: .2px;
    color: var(--heading-color);
    margin: 0 0 .35em;
}

/* Größen – wähle je nach Einsatz */
.u-heading--xl {
    font-size: clamp(2.2rem, 4.5vw, 3.2rem);
}

.u-heading--l {
    font-size: clamp(1.8rem, 3.8vw, 2.6rem);
}

.u-heading--m {
    font-size: clamp(1.4rem, 2.8vw, 2rem);
}

.u-heading--s {
    font-size: clamp(1.15rem, 2.2vw, 1.4rem);
}

/* Optional: Varianten */
.u-heading--upper {
    text-transform: uppercase;
    letter-spacing: .6px;
}

.u-heading--tight {
    line-height: 1.05;
}

.u-heading--blue {
    color: var(--accent-blue);
}

.u-heading--green {
    color: var(--accent-green);
}

/* ------------- Aufrufe V.024----------------- */
/* --- Eber-Linien: optionale Chips/Links --- */
/* === Linie-Spalte: Links sehen aus wie normaler Text === */
.offer .line-list {
    /* auf die <p> in der Linie-Card */
    font: inherit;
    line-height: 1.45;
    font-size: 1.3rem;
}

.offer .line-list a,
.offer .line-list button {
    font: inherit;

    /* gleiche Schriftart/-größe wie der Text */
    color: inherit;

    /* gleiche Farbe */
    text-decoration: none;

    /* keine Unterstreichung */
    background: none;
    border: 0;
    padding: 0;
    margin: 0;
    cursor: pointer;

    /* nur relevant für button/detail */
}

/* Tastaturfokus klar sichtbar */
.offer .line-list a:focus-visible,
.offer .line-list button:focus-visible {
    outline: 2px solid var(--accent-green, #71AB2B);
    outline-offset: 2px;
}

/* Kleines, dezentes Icon für "hat Link" (optional) */
.offer .line-list .is-link::after {
    content: "↗";
    font-size: .9em;
    opacity: .6;
    margin-left: .25em;
    transform: translateY(-.05em);
}

/* Kleines Modal für Detailansicht (JS) */
.modal-overlay {
    position: fixed;
    inset: 0;
    display: grid;
    place-items: center;
    background: rgba(0,0,0,.45);
    z-index: 10000;
}

.modal {
    width: min(720px, 92vw);
    background: #fff;
    color: #111;
    border-radius: 16px;
    box-shadow: 0 20px 50px rgba(0,0,0,.25);
    overflow: clip;
}

.modal-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: .8rem 1rem;
    background: var(--neutral, #F5F5F5);
}

.modal-head h3 {
    margin: 0;
    font-size: 1.15rem;
    color: var(--accent-blue, #131F3C);
}

.modal-close {
    border: 0;
    background: none;
    font-size: 1.6rem;
    line-height: 1;
    cursor: pointer;
}

.modal-body {
    padding: 1rem;
}

/* == V.027  Seitenweises Deaktivieren Hero-Shade == */
body.no-hero-shade .hero::after {
    background: none;
}

/* == V.027  Aktiven Menüpunkt deutlich markieren */
.main-header nav a.is-current {
    color: var(--accent-gray);

    /* grün */
    font-weight: 700;
    text-decoration: underline;
    text-underline-offset: 4px;
}

/* ===== Kontakt additions (V.010 – 10.11.2025) ===== */
.contact-form {
    max-width: 720px;
    margin-top: .5rem;
}

.contact-form .field {
    display: grid;
    gap: .5rem;
    margin-bottom: 1rem;
}

.contact-form label {
    font-weight: 600;
}

.contact-form input,
.contact-form textarea {
    width: 100%;
    padding: .75rem .9rem;
    border: 1px solid rgba(0,0,0,.15);
    border-radius: .5rem;
    font: inherit;
}

.contact-form .actions {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.btn-primary {
    appearance: none;
    border: none;
    padding: .75rem 1.1rem;
    border-radius: .75rem;
    cursor: pointer;
    font-weight: 700;
}

.btn-primary:hover {
    filter: brightness(1.05);
}

.form-note {
    font-size: .9rem;
    opacity: .8;
    margin: 0;
}

/* ==== V.1.00 MiniTabelle ===== */
.mini-kontakt {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;

    /* falls es mal eng wird */
}

.mini-kontakt-col {
    flex: 1 1 33.333%;
}

/* Optional: auf schmalen Screens untereinander */
@media (max-width: 600px) {
    .mini-kontakt {
        flex-direction: column;
    }

    .mini-kontakt-col {
        flex: 1 1 auto;
    }
}

.mini-kontakt-mail {
    margin-top: 0.5rem;
}

/* =============== V1.00 =========== */
/* Bilder im Panel mit ca. 15 % Rand links/rechts */
.panel.theme-white .bleed img {
    display: block;
    width: 85%;

    /* 85% Bildbreite */
    margin: 0 auto;

    /* zentriert → links/rechts je ~7,5% */
}

/* Auf dem Handy lieber voll breit */
@media (max-width: 768px) {
    .panel.theme-white .bleed img {
        width: 100%;
    }
}
