:root {
    --green-950: #092f28;
    --green-900: #0e4438;
    --green-800: #155947;
    --green-100: #eaf4ef;
    --cream: #fbf7ef;
    --sand: #eadcc6;
    --gold: #c99a45;
    --text: #24312d;
    --muted: #66736f;
    --white: #ffffff;
    --shadow: 0 18px 45px rgba(9, 47, 40, 0.12);
    --radius: 22px;
}

* { box-sizing: border-box; }
html, body { min-height: 100%; margin: 0; }
body {
    font-family: 'EB Garamond', Georgia, serif;
    background: var(--cream);
    color: var(--text);
    line-height: 1.6;
}
img { max-width: 100%; height: auto; }
a { color: var(--green-800); }
main { flex: 1; }
.wrapper { min-height: 100vh; display: flex; flex-direction: column; }
.hidden { display: none !important; }
.skip-link { position: absolute; left: -999px; top: 0; background: var(--white); padding: 8px 12px; z-index: 9999; }
.skip-link:focus { left: 12px; top: 12px; }

.site-header {
    position: sticky;
    top: 0;
    z-index: 1000;
    background: rgba(251, 247, 239, 0.96);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid rgba(14, 68, 56, 0.12);
    box-shadow: 0 8px 28px rgba(9, 47, 40, 0.08);
}
.topbar {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 18px;
    padding: 7px 20px;
    background: var(--green-900);
    color: var(--cream);
    font-size: 0.98rem;
    text-align: center;
}
.topbar a { color: var(--sand); font-weight: 700; text-decoration: none; }
.header-inner {
    max-width: 1180px;
    margin: 0 auto;
    padding: 14px 22px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
}
.brand {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    color: var(--green-950);
    text-decoration: none;
    min-width: 255px;
}
.brand img {
    width: auto;
    height: 58px;
    max-width: 58px;
    object-fit: contain;
    display: block;
    flex: 0 0 auto;
}
.brand-text {
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: 58px;
}
.brand strong { display: block; font-size: 1.52rem; line-height: 1.05; }
.brand small { display: block; font-size: 0.93rem; line-height: 1.15; color: var(--muted); margin-top: 3px; }
.navigation ul {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 7px;
    list-style: none;
    padding: 0;
    margin: 0;
    flex-wrap: wrap;
}
.navigation a {
    display: inline-flex;
    align-items: center;
    min-height: 40px;
    padding: 8px 11px;
    border-radius: 999px;
    color: var(--green-950);
    text-decoration: none;
    font-size: 1.02rem;
    font-weight: 600;
    transition: background-color .2s ease, color .2s ease, transform .2s ease;
}
.navigation a:hover,
.navigation a.is-active { background: var(--green-100); color: var(--green-900); }
.navigation a.is-highlight { color: var(--green-900); background: rgba(201,154,69,.14); }
.navigation a.nav-cta {
    background: var(--green-900);
    color: var(--white);
    padding-inline: 18px;
    box-shadow: 0 8px 20px rgba(14,68,56,.2);
}
.navigation a.nav-cta:hover { transform: translateY(-1px); background: var(--green-800); color: var(--white); }
.menu-toggle {
    display: none;
    width: 44px;
    height: 44px;
    border: 1px solid rgba(14,68,56,.22);
    border-radius: 12px;
    background: var(--white);
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 5px;
    cursor: pointer;
}
.menu-toggle span { display: block; width: 23px; height: 2px; background: var(--green-900); border-radius: 10px; transition: .2s ease; }
.menu-toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.menu-toggle.open span:nth-child(2) { opacity: 0; }
.menu-toggle.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.btn, .contact-form button, button[type="submit"], .service-text a[href*="shop"] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 20px;
    border-radius: 999px;
    border: 0;
    font: inherit;
    font-weight: 700;
    text-decoration: none;
    cursor: pointer;
}
.btn-primary, .contact-form button, button[type="submit"], .service-text a[href*="shop"] { background: var(--green-900); color: var(--white); }
.btn-primary:hover, .contact-form button:hover, button[type="submit"]:hover, .service-text a[href*="shop"]:hover { background: var(--green-800); color: var(--white); }
.btn-secondary { background: var(--white); color: var(--green-900); border: 1px solid rgba(14,68,56,.18); }
.eyebrow { text-transform: uppercase; letter-spacing: .08em; color: var(--gold); font-weight: 700; font-size: .9rem; margin: 0 0 8px; }

.hero {
    max-width: 1180px;
    margin: 0 auto;
    padding: 70px 22px 44px;
    display: grid;
    grid-template-columns: 1.05fr .95fr;
    gap: 42px;
    align-items: center;
}
.hero-card, #services-container, .content-card, .contact-form, .partner-card {
    background: rgba(255,255,255,.9);
    border: 1px solid rgba(14,68,56,.11);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
}
.hero h1 { font-size: clamp(2.45rem, 6vw, 5rem); line-height: .98; margin: 0 0 20px; color: var(--green-950); }
.hero .lead { font-size: 1.35rem; color: var(--muted); max-width: 700px; margin: 0 0 26px; }
.hero-actions { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 22px; }
.trust-points { display: flex; gap: 10px; flex-wrap: wrap; padding: 0; margin: 0; list-style: none; }
.trust-points li { background: var(--green-100); color: var(--green-900); padding: 8px 12px; border-radius: 999px; font-weight: 700; }
.hero-media { position: relative; }
.hero-media img { width: 100%; border-radius: 28px; box-shadow: var(--cream); object-fit: contain; max-height: 560px; }
.hero-card { position: absolute; left: -24px; bottom: 22px; padding: 18px; max-width: 320px; }
.hero-card strong { display: block; color: var(--green-900); font-size: 1.25rem; }

.section { max-width: 1120px; margin: 0 auto; padding: 42px 22px; }
.section h2, .welcome-text h2, .service-text h2, .about-text h2, .partner-section h2 { font-size: clamp(2rem, 4vw, 3.2rem); line-height: 1.05; color: var(--green-950); margin-top: 0; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.card { background: var(--white); border-radius: var(--radius); padding: 24px; box-shadow: var(--shadow); border: 1px solid rgba(14,68,56,.1); }
.card h3 { color: var(--green-900); font-size: 1.5rem; margin-top: 0; }
.card ul { padding-left: 20px; }

.carousel-container { width: min(920px, calc(100% - 32px)); height: clamp(360px, 52vw, 640px); margin: 32px auto; overflow: hidden; border-radius: 28px; background: var(--cream); box-shadow: var(--cream); }
.carousel { display: flex; width: 100%; height: 100%; transition: transform .6s ease; }
.slide { flex: 0 0 100%; height: 100%; display: flex; align-items: center; justify-content: center; padding: 14px; box-sizing: border-box; }
.slide img { max-width: 100%; max-height: 100%; width: auto; height: auto; object-fit: contain; border-radius: 20px; }
.welcome-text { text-align: center; max-width: 960px; margin: 0 auto; padding: 38px 22px; }
.welcome-text p { font-size: 1.2rem; color: var(--muted); }
.cursive-text { font-family: 'Dancing Script', cursive; font-size: 1.55rem; color: var(--gold); }

#services-container, #about-container, #about-carlo, #about-Pagnol, .partner-section { max-width: 1080px; margin: 32px auto; padding: 36px 24px; }
.service-text, .about-text, .about-textCarlo, .about-textPagnol { text-align: center; max-width: 900px; margin: 0 auto; }
.service-text p, .about-text p, .about-textCarlo p, .about-textPagnol p { font-size: 1.18rem; color: var(--text); }
.about-image, .horses-image, .zertifikat-image { max-width: 560px; height: auto; margin: 0 auto 24px; overflow: hidden; border-radius: 24px; }
.about-image img, .horses-image img, .zertifikat-image img { width: 100%; height: auto; object-fit: contain; border-radius: 24px; }
.work-image { display: flex; justify-content: center; align-items: center; gap: 16px; flex-wrap: wrap; margin: 26px auto; }
.work-image img { width: 140px; height: 110px; object-fit: contain; border-radius: 16px; box-shadow: 0 8px 20px rgba(9,47,40,.12); }
.photo { cursor: pointer; transition: transform .2s; }
.photo:hover { transform: scale(1.04); }

.contact-container { display: flex; justify-content: center; padding: 44px 20px; }
.contact-form { padding: 28px; width: min(100%, 640px); }
.contact-form label { display: block; font-weight: 700; margin: 14px 0 6px; }
.contact-form input, .contact-form textarea { width: 100%; padding: 13px 14px; border: 1px solid rgba(14,68,56,.18); border-radius: 14px; background: var(--cream); font: inherit; }
.privacy { text-align: center; }
.success-message { color: var(--green-900); background: var(--green-100); border: 1px solid rgba(14,68,56,.2); padding: 14px; margin: 20px auto; text-align: center; max-width: 740px; border-radius: 14px; }

.partner-section { background: transparent; text-align: center; }
.partner-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; padding: 0; }
.partner-card { padding: 22px; transition: transform .2s ease, box-shadow .2s ease; }
.partner-card:hover { transform: translateY(-4px); }
.partner-card img { max-width: 120px; max-height: 95px; object-fit: contain; margin-bottom: 12px; }
.partner-card h3 { color: var(--green-900); margin: 8px 0; }

.modal { display: none; position: fixed; z-index: 2000; padding-top: 60px; inset: 0; overflow: auto; background: rgba(0,0,0,.9); }
.modal-content { margin: auto; display: block; width: 90%; max-width: 820px; }
.close { position: absolute; top: 15px; right: 35px; color: #fff; font-size: 40px; font-weight: bold; cursor: pointer; }

.site-footer { margin-top: auto; background: var(--green-950); color: var(--cream); }
.footer-cta { max-width: 1120px; margin: 0 auto; padding: 42px 22px; display: flex; justify-content: space-between; gap: 26px; align-items: center; border-bottom: 1px solid rgba(255,255,255,.12); }
.footer-cta h2 { color: var(--white); margin: 0 0 8px; font-size: clamp(1.8rem, 4vw, 3rem); line-height: 1.05; }
.footer-cta p { margin: 0; color: rgba(251,247,239,.78); }
.footer-actions { display: flex; gap: 12px; flex-wrap: wrap; justify-content: flex-end; }
.footer-main { max-width: 1120px; margin: 0 auto; padding: 32px 22px; display: grid; grid-template-columns: 1.4fr .8fr .8fr; gap: 28px; }
.footer-brand { display: flex; gap: 14px; align-items: center; }
.footer-brand img { width: 76px; height: 76px; object-fit: contain; background: rgba(255,255,255,.08); border-radius: 18px; }
.footer-column { display: flex; flex-direction: column; gap: 8px; }
.footer-column h3 { margin: 0 0 6px; color: var(--white); }
.site-footer a { color: var(--sand); text-decoration: none; }
.site-footer a:hover { color: var(--white); }
.social-links { display: flex; gap: 12px; align-items: center; }
.social-links a { font-size: 1.6rem; }
.footer-bottom { max-width: 1120px; margin: 0 auto; padding: 18px 22px 24px; display: flex; justify-content: space-between; gap: 16px; border-top: 1px solid rgba(255,255,255,.12); color: rgba(251,247,239,.75); }

@media (max-width: 980px) {
    .header-inner { align-items: center; }
    .menu-toggle { display: flex; margin-left: auto; }
    .navigation { display: none; position: absolute; left: 0; right: 0; top: 100%; background: var(--cream); border-bottom: 1px solid rgba(14,68,56,.12); box-shadow: 0 14px 30px rgba(9,47,40,.12); }
    .navigation.active { display: block; }
    .navigation ul { display: grid; grid-template-columns: 1fr; gap: 0; padding: 12px 22px 18px; }
    .navigation a { width: 100%; justify-content: center; border-radius: 14px; }
    .hero { grid-template-columns: 1fr; padding-top: 42px; }
    .hero-card { position: static; margin-top: 12px; max-width: none; }
    .grid-3, .partner-grid, .footer-main { grid-template-columns: 1fr; }
    .footer-cta { flex-direction: column; align-items: flex-start; }
    .footer-actions { justify-content: flex-start; }
}
@media (max-width: 640px) {
    .topbar { flex-direction: column; gap: 2px; font-size: .9rem; }
    .header-inner { padding: 12px 16px; }
    .brand { min-width: 0; gap: 9px; }
    .brand img { height: 46px; max-width: 46px; }
    .brand-text { min-height: 46px; }
    .brand strong { font-size: 1.16rem; line-height: 1.05; }
    .brand small { font-size: .78rem; line-height: 1.1; margin-top: 2px; }
    .hero { padding: 34px 16px 24px; }
    .hero .lead { font-size: 1.15rem; }
    .carousel-container { height: clamp(320px, 85vw, 520px); border-radius: 18px; }
    .slide { padding: 10px; }
    .slide img { border-radius: 14px; }
    #services-container, #about-container, #about-carlo, #about-Pagnol, .partner-section { margin: 18px 12px; padding: 24px 16px; }
    .work-image img { width: 92px; height: 82px; }
    .footer-bottom { flex-direction: column; }
}

/* Futtermittelberatung */
.nutrition-hero { max-width: 1180px; margin: 0 auto; padding: 70px 22px 34px; display: grid; grid-template-columns: minmax(0, 1.15fr) minmax(280px, .85fr); gap: 34px; align-items: stretch; }
.nutrition-hero__content, .nutrition-hero__card, .nutrition-section { background: rgba(255,255,255,.92); border: 1px solid rgba(14,68,56,.11); border-radius: 28px; box-shadow: var(--shadow); }
.nutrition-hero__content { padding: clamp(28px, 5vw, 54px); display: flex; flex-direction: column; justify-content: center; }
.nutrition-hero h1 { font-size: clamp(2.45rem, 5.4vw, 4.9rem); line-height: .98; color: var(--green-950); margin: 0 0 20px; max-width: 830px; }
.nutrition-hero .lead { font-size: 1.28rem; color: var(--muted); max-width: 760px; margin: 0 0 26px; }
.nutrition-points { margin-top: 4px; }
.nutrition-hero__card { padding: 18px; display: flex; flex-direction: column; justify-content: space-between; gap: 18px; overflow: hidden; }
.nutrition-hero__card img { width: 100%; max-height: 430px; object-fit: contain; background: var(--cream); border-radius: 22px; padding: 10px; }
.nutrition-hero__card div { background: var(--green-100); border-radius: 20px; padding: 18px; }
.nutrition-hero__card strong { display: block; color: var(--green-900); font-size: 1.45rem; line-height: 1.1; margin-bottom: 6px; }
.nutrition-hero__card span { color: var(--text); font-size: 1.05rem; }
.nutrition-section { max-width: 1120px; margin: 28px auto; padding: clamp(26px, 4vw, 44px); }
.section-heading { max-width: 820px; margin: 0 auto 26px; text-align: center; }
.section-heading h2, .nutrition-split h2, .nutrition-cta-box h2 { font-size: clamp(2rem, 4vw, 3.3rem); line-height: 1.05; color: var(--green-950); margin: 0 0 14px; }
.section-heading p, .nutrition-split p, .nutrition-cta-box p { font-size: 1.17rem; color: var(--muted); }
.nutrition-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.nutrition-card { background: linear-gradient(180deg, var(--white), var(--green-100)); border: 1px solid rgba(14,68,56,.1); border-radius: 22px; padding: 24px; }
.nutrition-card h3 { color: var(--green-900); font-size: 1.45rem; margin: 0 0 10px; }
.nutrition-card p { margin: 0; color: var(--text); font-size: 1.08rem; }
.nutrition-split { display: grid; grid-template-columns: .9fr 1.1fr; gap: 34px; align-items: center; }
.nutrition-note { background: var(--cream); border-left: 4px solid var(--gold); border-radius: 16px; padding: 14px 16px; color: var(--text) !important; }
.process-list { display: grid; gap: 14px; }
.process-list div { display: grid; grid-template-columns: 54px 1fr; column-gap: 16px; row-gap: 2px; padding: 18px; background: var(--cream); border: 1px solid rgba(14,68,56,.1); border-radius: 20px; }
.process-list span { grid-row: span 2; width: 48px; height: 48px; display: inline-flex; align-items: center; justify-content: center; border-radius: 50%; background: var(--green-900); color: var(--white); font-weight: 700; }
.process-list strong { color: var(--green-950); font-size: 1.2rem; }
.process-list p { margin: 0; font-size: 1.04rem; }
.nutrition-cta-box { display: flex; align-items: center; justify-content: space-between; gap: 26px; background: var(--green-950); color: var(--cream); }
.nutrition-cta-box h2 { color: var(--white); }
.nutrition-cta-box p { color: rgba(251,247,239,.82); max-width: 760px; }
.nutrition-cta-actions { display: flex; gap: 12px; flex-wrap: wrap; justify-content: flex-end; min-width: 260px; }
.nutrition-cta-box .btn-secondary { border-color: rgba(255,255,255,.25); }
@media (max-width: 900px) { .nutrition-hero, .nutrition-split { grid-template-columns: 1fr; } .nutrition-grid { grid-template-columns: 1fr; } .nutrition-cta-box { flex-direction: column; align-items: flex-start; } .nutrition-cta-actions { justify-content: flex-start; min-width: 0; } }
@media (max-width: 640px) { .nutrition-hero { padding: 32px 14px 18px; } .nutrition-section { margin: 18px 12px; padding: 22px 16px; border-radius: 22px; } .nutrition-hero__content, .nutrition-hero__card { border-radius: 22px; } .process-list div { grid-template-columns: 1fr; } .process-list span { grid-row: auto; margin-bottom: 6px; } }

/* Leistungen */
.services-hero { max-width: 1180px; margin: 0 auto; padding: 70px 22px 34px; display: grid; grid-template-columns: minmax(0, 1.08fr) minmax(300px, .92fr); gap: 34px; align-items: stretch; }
.services-hero__content, .services-hero__media, .services-section, .services-cta { background: rgba(255,255,255,.92); border: 1px solid rgba(14,68,56,.11); border-radius: 28px; box-shadow: var(--shadow); }
.services-hero__content { padding: clamp(28px, 5vw, 54px); display: flex; flex-direction: column; justify-content: center; }
.services-hero h1 { font-size: clamp(2.35rem, 5.2vw, 4.7rem); line-height: .98; color: var(--green-950); margin: 0 0 20px; max-width: 850px; }
.services-hero .lead { font-size: 1.28rem; color: var(--muted); max-width: 760px; margin: 0 0 26px; }
.services-hero__media { padding: 18px; overflow: hidden; display: flex; align-items: center; justify-content: center; }
.services-hero__media img { width: 100%; height: 100%; min-height: 420px; object-fit: contain; border-radius: 22px; }
.services-section { max-width: 1120px; margin: 28px auto; padding: clamp(26px, 4vw, 44px); }
.services-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.service-card { background: linear-gradient(180deg, var(--white), var(--green-100)); border: 1px solid rgba(14,68,56,.1); border-radius: 22px; padding: 24px; display: flex; flex-direction: column; gap: 10px; }
.service-card--featured { background: linear-gradient(180deg, #fffaf0, var(--green-100)); border-color: rgba(201,154,69,.35); }
.service-tag { align-self: flex-start; display: inline-flex; padding: 7px 12px; border-radius: 999px; background: rgba(201,154,69,.14); color: var(--green-900); font-weight: 700; font-size: .95rem; }
.service-card h3 { color: var(--green-900); font-size: 1.55rem; line-height: 1.1; margin: 6px 0 0; }
.service-card p { margin: 0; color: var(--text); font-size: 1.08rem; }
.service-card ul, .service-info-box ul { margin: 8px 0 0; padding-left: 20px; color: var(--text); }
.service-card li, .service-info-box li { margin: 6px 0; }
.services-split-section { display: grid; grid-template-columns: 1fr .9fr; gap: 30px; align-items: center; }
.services-split-section h2, .services-cta h2 { font-size: clamp(2rem, 4vw, 3.3rem); line-height: 1.05; color: var(--green-950); margin: 0 0 14px; }
.services-split-section p, .services-cta p { font-size: 1.17rem; color: var(--muted); }
.service-info-box { background: var(--cream); border-left: 4px solid var(--gold); border-radius: 20px; padding: 24px; }
.service-info-box h3 { color: var(--green-900); font-size: 1.5rem; margin: 0 0 10px; }
.services-cta { max-width: 1120px; margin: 28px auto 42px; padding: clamp(26px, 4vw, 44px); display: flex; align-items: center; justify-content: space-between; gap: 26px; background: var(--green-950); color: var(--cream); }
.services-cta h2 { color: var(--white); }
.services-cta p { color: rgba(251,247,239,.82); max-width: 780px; }
.services-cta .btn-secondary { border-color: rgba(255,255,255,.25); }
@media (max-width: 980px) { .services-hero, .services-split-section { grid-template-columns: 1fr; } .services-grid { grid-template-columns: repeat(2, 1fr); } .services-cta { flex-direction: column; align-items: flex-start; } .services-hero__media img { min-height: 320px; } }
@media (max-width: 640px) { .services-hero { padding: 32px 14px 18px; } .services-section, .services-cta { margin: 18px 12px; padding: 22px 16px; border-radius: 22px; } .services-hero__content, .services-hero__media { border-radius: 22px; } .services-grid { grid-template-columns: 1fr; } .services-hero__media img { min-height: 260px; } }

/* Unsere Arbeit */
.work-hero {
    max-width: 1180px;
    margin: 0 auto;
    padding: 70px 22px 34px;
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(300px, .92fr);
    gap: 34px;
    align-items: stretch;
}
.work-hero__content,
.work-hero__media,
.work-section,
.work-cta {
    background: rgba(255,255,255,.92);
    border: 1px solid rgba(14,68,56,.11);
    border-radius: 28px;
    box-shadow: var(--shadow);
}
.work-hero__content {
    padding: clamp(28px, 5vw, 54px);
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.work-hero h1 {
    font-size: clamp(2.35rem, 5.2vw, 4.7rem);
    line-height: .98;
    color: var(--green-950);
    margin: 0 0 20px;
    max-width: 880px;
}
.work-hero .lead {
    font-size: 1.28rem;
    color: var(--muted);
    max-width: 760px;
    margin: 0 0 26px;
}
.work-hero__media {
    padding: 18px;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}
.work-hero__media img {
    width: 100%;
    height: 100%;
    min-height: 420px;
    object-fit: cover;
    border-radius: 22px;
}
.work-section {
    max-width: 1120px;
    margin: 28px auto;
    padding: clamp(26px, 4vw, 44px);
}
.work-principles {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
}
.work-principle-card {
    background: linear-gradient(180deg, var(--white), var(--green-100));
    border: 1px solid rgba(14,68,56,.1);
    border-radius: 22px;
    padding: 24px;
}
.work-principle-card span {
    display: inline-flex;
    width: 42px;
    height: 42px;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: var(--green-900);
    color: var(--white);
    font-weight: 700;
    margin-bottom: 14px;
}
.work-principle-card h3 {
    color: var(--green-900);
    font-size: 1.45rem;
    line-height: 1.1;
    margin: 0 0 10px;
}
.work-principle-card p {
    margin: 0;
    color: var(--text);
    font-size: 1.08rem;
}
.work-split-section {
    display: grid;
    grid-template-columns: 1fr .9fr;
    gap: 30px;
    align-items: center;
}
.work-split-section h2,
.work-cta h2 {
    font-size: clamp(2rem, 4vw, 3.3rem);
    line-height: 1.05;
    color: var(--green-950);
    margin: 0 0 14px;
}
.work-split-section p,
.work-cta p {
    font-size: 1.17rem;
    color: var(--muted);
}
.work-info-box {
    background: var(--cream);
    border-left: 4px solid var(--gold);
    border-radius: 20px;
    padding: 24px;
}
.work-info-box h3 {
    color: var(--green-900);
    font-size: 1.5rem;
    margin: 0 0 10px;
}
.work-info-box ul {
    margin: 8px 0 0;
    padding-left: 20px;
    color: var(--text);
}
.work-info-box li { margin: 6px 0; }
.work-gallery {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
}
.work-gallery figure {
    margin: 0;
    border-radius: 22px;
    background: rgba(255, 255, 255, .92);
    overflow: hidden;
}
.work-gallery img {
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: contain;
    display: block;
    transition: transform .25s ease;
}
.work-gallery img:hover { transform: scale(1.035); }
.work-cta {
    max-width: 1120px;
    margin: 28px auto 42px;
    padding: clamp(26px, 4vw, 44px);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 26px;
    background: var(--green-950);
    color: var(--cream);
}
.work-cta h2 { color: var(--white); }
.work-cta p { color: rgba(251,247,239,.82); max-width: 780px; }
.work-cta .btn-secondary { border-color: rgba(255,255,255,.25); }
.work-section code {
    background: var(--green-100);
    border-radius: 8px;
    padding: 2px 6px;
    color: var(--green-900);
}
@media (max-width: 980px) {
    .work-hero,
    .work-split-section { grid-template-columns: 1fr; }
    .work-principles,
    .work-gallery { grid-template-columns: repeat(2, 1fr); }
    .work-cta { flex-direction: column; align-items: flex-start; }
    .work-hero__media img { min-height: 320px; }
}
@media (max-width: 640px) {
    .work-hero { padding: 32px 14px 18px; }
    .work-section,
    .work-cta { margin: 18px 12px; padding: 22px 16px; border-radius: 22px; }
    .work-hero__content,
    .work-hero__media { border-radius: 22px; }
    .work-principles,
    .work-gallery { grid-template-columns: 1fr; }
    .work-hero__media img { min-height: 260px; }
    .work-gallery img { aspect-ratio: 3 / 2; }
}

/* -------------------------------------- */
/* Über uns Redesign – nur neue About-Seite */

.about-page { background: #f6f3ec; }
.about-page .section-shell { width: min(1120px, calc(100% - 32px)); margin: 0 auto; }
.about-page .eyebrow, .about-page .section-kicker { display: inline-block; margin-bottom: 10px; color: #0e4438; font-size: 0.95rem; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; }
.about-hero { width: min(1180px, calc(100% - 32px)); margin: 40px auto 0; display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.95fr); gap: 34px; align-items: center; padding: 34px; border-radius: 28px; background: linear-gradient(135deg, #ffffff 0%, #efe7da 100%); box-shadow: 0 18px 50px rgba(14, 68, 56, 0.14); }
.about-hero__content h1 { margin: 0 0 16px; color: #0e4438; font-size: clamp(2.2rem, 4vw, 4.4rem); line-height: 1.02; }
.about-hero__content p { max-width: 680px; margin: 0 0 24px; color: #2f2f2f; font-size: clamp(1.1rem, 2vw, 1.35rem); line-height: 1.55; }
.about-hero__image { overflow: hidden; border-radius: 24px; background: #e8e1d4; }
.about-hero__image img, .about-feature__image img { display: block; width: 100%; object-fit: contain; }
.about-page .btn-primary { display: inline-flex; align-items: center; justify-content: center; min-height: 46px; padding: 12px 22px; border-radius: 999px; background: #0e4438; color: #fff !important; text-decoration: none; font-weight: 700; box-shadow: 0 10px 24px rgba(14, 68, 56, 0.22); transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease; }
.about-page .btn-primary:hover { background: #123f35; transform: translateY(-2px); box-shadow: 0 14px 30px rgba(14, 68, 56, 0.28); }
.about-intro { padding: 70px 0 24px; text-align: center; }
.about-intro h2, .values-section h2, .about-feature__text h2, .about-cta h2 { margin: 0 0 16px; color: #0e4438; font-size: clamp(1.9rem, 3vw, 3rem); line-height: 1.1; }
.about-intro p { max-width: 860px; margin: 0 auto; font-size: 1.25rem; line-height: 1.7; color: #343434; }
.about-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 22px; padding: 34px 0; }
.about-page .info-card { padding: 28px; border-radius: 22px; background: #ffffff; box-shadow: 0 12px 34px rgba(14, 68, 56, 0.1); }
.about-page .info-card--highlight { background: #0e4438; color: #fff; }
.about-page .info-card h3 { margin: 0 0 12px; color: inherit; font-size: 1.55rem; }
.about-page .info-card p { margin: 0; font-size: 1.08rem; line-height: 1.65; }
.about-feature { display: grid; grid-template-columns: minmax(280px, 0.85fr) minmax(0, 1.15fr); gap: 32px; align-items: center; padding: 54px 0; }
.about-feature__image { height: 430px; overflow: hidden; border-radius: 24px; background: #e8e1d4; box-shadow: 0 16px 40px rgba(14, 68, 56, 0.12); }
.about-feature__text { padding: 26px 0; }
.about-feature__text p { margin: 0 0 14px; font-size: 1.18rem; line-height: 1.7; }
.values-section { padding: 40px 0 72px; text-align: center; }
.values-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 16px; margin-top: 26px; }
.value-item { padding: 22px; border-radius: 18px; background: #fff; text-align: left; box-shadow: 0 10px 26px rgba(14, 68, 56, 0.08); }
.value-item strong, .value-item span { display: block; }
.value-item strong { margin-bottom: 8px; color: #0e4438; font-size: 1.15rem; }
.value-item span { line-height: 1.55; }
.about-cta { width: min(1120px, calc(100% - 32px)); margin: 0 auto 58px; display: flex; gap: 24px; align-items: center; justify-content: space-between; padding: 34px; border-radius: 26px; background: #ffffff; box-shadow: 0 18px 44px rgba(14, 68, 56, 0.12); }
.about-cta p { margin: 0; max-width: 720px; font-size: 1.15rem; line-height: 1.6; }
@media (max-width: 980px) { .about-hero, .about-feature { grid-template-columns: 1fr; } .about-hero { padding: 24px; } .about-hero__image { min-height: 300px; } .about-grid, .values-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } .about-cta { align-items: flex-start; flex-direction: column; } }
@media (max-width: 640px) { .about-page .section-shell, .about-hero, .about-cta { width: min(100% - 22px, 1120px); } .about-hero { margin-top: 22px; padding: 18px; border-radius: 20px; } .about-hero__content h1 { font-size: 2.2rem; } .about-hero__content p, .about-intro p, .about-feature__text p, .about-cta p { font-size: 1.05rem; } .about-hero__image, .about-feature__image { height: auto; min-height: 0; aspect-ratio: 4 / 3; border-radius: 18px; } .about-grid, .values-grid { grid-template-columns: 1fr; } .about-intro { padding: 46px 0 18px; } .about-feature, .values-section { padding: 34px 0; } .about-page .info-card, .value-item, .about-cta { padding: 22px; } .about-page .btn-primary { width: 100%; } }

/* Unsere Pferde */
.horses-page { background: var(--cream); }

.horses-hero {
    max-width: 1180px;
    margin: 0 auto;
    padding: 70px 22px 34px;
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(300px, .92fr);
    gap: 34px;
    align-items: stretch;
}

.horses-hero__content,
.horses-hero__media,
.horses-section,
.horses-cta {
    background: rgba(255,255,255,.92);
    border: 1px solid rgba(14,68,56,.11);
    border-radius: 28px;
    box-shadow: var(--shadow);
}

.horses-hero__content {
    padding: clamp(28px, 5vw, 54px);
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.horses-hero h1 {
    font-size: clamp(1.35rem, 4.2vw, 3.7rem);
    line-height: .98;
    color: var(--green-950);
    margin: 0 0 20px;
    max-width: 880px;
}

.horses-hero .lead {
    font-size: 1.28rem;
    color: var(--muted);
    max-width: 760px;
    margin: 0 0 26px;
}

.horses-hero__media {
    padding: 18px;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}

.horses-hero__media img {
    width: 100%;
    height: 100%;
    min-height: 420px;
    object-fit: contain;
    background: var(--cream);
    border-radius: 22px;
}

.horses-section {
    max-width: 1120px;
    margin: 28px auto;
    padding: clamp(26px, 4vw, 44px);
}

.horses-values {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
}

.horse-value-card {
    background: linear-gradient(180deg, var(--white), var(--green-100));
    border: 1px solid rgba(14,68,56,.1);
    border-radius: 22px;
    padding: 24px;
}

.horse-value-card span {
    display: inline-flex;
    width: 42px;
    height: 42px;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: var(--green-900);
    color: var(--white);
    font-weight: 700;
    margin-bottom: 14px;
}

.horse-value-card h3,
.horse-profile__content h2,
.horses-cta h2 {
    color: var(--green-950);
}

.horse-value-card h3 {
    font-size: 1.45rem;
    line-height: 1.1;
    margin: 0 0 10px;
}

.horse-value-card p {
    margin: 0;
    color: var(--text);
    font-size: 1.08rem;
}

.horse-profile {
    display: grid;
    grid-template-columns: minmax(280px, .85fr) minmax(0, 1.15fr);
    gap: 30px;
    align-items: center;
}

.horse-profile--reverse .horse-profile__image { order: 2; }
.horse-profile--reverse .horse-profile__content { order: 1; }
.horse-profile--reverse .horse-gallery { order: 3; }

.horse-profile__image {
    overflow: hidden;
    border-radius: 24px;
    background: var(--cream);
}

.horse-profile__image img {
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: contain;
    display: block;
    border-radius: 24px;
}

.horse-profile__content h2 {
    font-size: clamp(2rem, 4vw, 3.3rem);
    line-height: 1.05;
    margin: 0 0 16px;
}

.horse-profile__content p {
    font-size: 1.15rem;
    color: var(--text);
    margin: 0 0 14px;
}

.horse-gallery {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 14px;
    margin-top: 4px;
}

.horse-gallery figure {
    margin: 0;
    overflow: hidden;
    border-radius: 18px;
    background: var(--cream);
    border: 1px solid rgba(14,68,56,.09);
}

.horse-gallery img {
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: contain;
    display: block;
    border-radius: 18px;
    cursor: pointer;
    transition: transform .25s ease;
}

.horse-gallery img:hover { transform: scale(1.035); }

.horses-cta {
    max-width: 1120px;
    margin: 28px auto 42px;
    padding: clamp(26px, 4vw, 44px);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 26px;
    background: var(--green-950);
    color: var(--cream);
}

.horses-cta h2 {
    color: var(--white);
    font-size: clamp(2rem, 4vw, 3.3rem);
    line-height: 1.05;
    margin: 0 0 14px;
}

.horses-cta p {
    color: rgba(251,247,239,.82);
    max-width: 780px;
    font-size: 1.17rem;
    margin: 0;
}

.horses-cta .eyebrow { color: var(--sand); margin-bottom: 8px; }

@media (max-width: 980px) {
    .horses-hero,
    .horse-profile {
        grid-template-columns: 1fr;
    }

    .horse-profile--reverse .horse-profile__image,
    .horse-profile--reverse .horse-profile__content,
    .horse-profile--reverse .horse-gallery {
        order: initial;
    }

    .horses-values { grid-template-columns: repeat(2, 1fr); }
    .horse-gallery { grid-template-columns: repeat(2, 1fr); }
    .horses-cta { flex-direction: column; align-items: flex-start; }
    .horses-hero__media img { min-height: 320px; }
}

@media (max-width: 640px) {
    .horses-hero { padding: 32px 14px 18px; }

    .horses-section,
    .horses-cta {
        margin: 18px 12px;
        padding: 22px 16px;
        border-radius: 22px;
    }

    .horses-hero__content,
    .horses-hero__media {
        border-radius: 22px;
    }

    .horses-values,
    .horse-gallery {
        grid-template-columns: 1fr;
    }

    .horses-hero__media img { min-height: 260px; }
    .horse-profile__image img,
    .horse-gallery img { aspect-ratio: 3 / 2; }
    .horses-cta .btn { width: 100%; }
}


/* Partner-Seite */
.partners-page {
    padding-bottom: 42px;
}

.partners-hero {
    max-width: 1180px;
    margin: 0 auto;
    padding: 70px 22px 34px;
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(280px, .92fr);
    gap: 34px;
    align-items: stretch;
}

.partners-hero__content,
.partners-hero__note,
.partners-section,
.partners-cta {
    background: rgba(255,255,255,.92);
    border: 1px solid rgba(14,68,56,.11);
    border-radius: 28px;
    box-shadow: var(--shadow);
}

.partners-hero__content {
    padding: clamp(28px, 5vw, 54px);
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.partners-hero h1 {
    font-size: clamp(1.35rem, 4.2vw, 3.7rem);
    line-height: .98;
    color: var(--green-950);
    margin: 0 0 20px;
}

.partners-hero .lead {
    font-size: 1.28rem;
    color: var(--muted);
    max-width: 760px;
    margin: 0 0 26px;
}

.partners-hero__note {
    padding: clamp(26px, 4vw, 42px);
    background: linear-gradient(180deg, var(--white), var(--green-100));
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 12px;
}

.partners-hero__note strong {
    display: block;
    color: var(--green-900);
    font-size: clamp(1.8rem, 3vw, 2.6rem);
    line-height: 1.05;
}

.partners-hero__note span {
    color: var(--text);
    font-size: 1.15rem;
}

.partners-section {
    max-width: 1120px;
    margin: 28px auto;
    padding: clamp(26px, 4vw, 44px);
}

.partners-section code {
    background: var(--green-100);
    border-radius: 8px;
    padding: 2px 6px;
    color: var(--green-900);
}

.partners-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}

.partners-grid .partner-card {
    display: flex;
    flex-direction: column;
    overflow: hidden;
    background: var(--white);
    border: 1px solid rgba(14,68,56,.1);
    border-radius: 24px;
    box-shadow: 0 12px 30px rgba(9,47,40,.1);
    transition: transform .2s ease, box-shadow .2s ease;
}

.partners-grid .partner-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 18px 38px rgba(9,47,40,.14);
}

.partners-grid .partner-card--featured {
    background: linear-gradient(180deg, #fffaf0, var(--white));
    border-color: rgba(201,154,69,.32);
}

.partner-logo {
    min-height: 160px;
    padding: 22px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
}

.partner-logo img {
    width: 100%;
    max-width: 190px;
    max-height: 120px;
    object-fit: contain;
    display: block;
}

.partner-logo--placeholder {
    background: linear-gradient(135deg, var(--green-100), var(--sand));
    color: var(--green-900);
    font-weight: 700;
    font-size: 1.45rem;
    text-align: center;
}

.partner-card__content {
    padding: 22px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    flex: 1;
}

.partner-tag {
    align-self: flex-start;
    display: inline-flex;
    padding: 7px 12px;
    border-radius: 999px;
    background: rgba(201,154,69,.14);
    color: var(--green-900);
    font-weight: 700;
    font-size: .95rem;
}

.partner-card__content h3 {
    color: var(--green-900);
    font-size: 1.55rem;
    line-height: 1.1;
    margin: 4px 0 0;
}

.partner-card__content p {
    margin: 0;
    color: var(--text);
    font-size: 1.08rem;
}

.partner-code {
    background: var(--green-100);
    border-radius: 14px;
    padding: 10px 12px;
}

.partner-link {
    margin-top: auto;
    color: var(--green-900);
    font-weight: 700;
    text-decoration: none;
}

.partner-link:hover {
    color: var(--green-800);
    text-decoration: underline;
}

.partners-cta {
    max-width: 1120px;
    margin: 28px auto 42px;
    padding: clamp(26px, 4vw, 44px);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 26px;
    background: var(--green-950);
    color: var(--cream);
}

.partners-cta h2 {
    font-size: clamp(2rem, 4vw, 3.3rem);
    line-height: 1.05;
    color: var(--white);
    margin: 0 0 14px;
}

.partners-cta p {
    color: rgba(251,247,239,.82);
    max-width: 780px;
    margin: 0;
    font-size: 1.17rem;
}

.partners-cta .btn-secondary {
    border-color: rgba(255,255,255,.25);
    white-space: nowrap;
}

@media (max-width: 980px) {
    .partners-hero {
        grid-template-columns: 1fr;
    }

    .partners-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .partners-cta {
        flex-direction: column;
        align-items: flex-start;
    }
}

@media (max-width: 640px) {
    .partners-hero {
        padding: 32px 14px 18px;
    }

    .partners-section,
    .partners-cta {
        margin: 18px 12px;
        padding: 22px 16px;
        border-radius: 22px;
    }

    .partners-hero__content,
    .partners-hero__note {
        border-radius: 22px;
    }

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

    .partner-logo {
        min-height: 130px;
        padding: 18px;
    }

    .partners-cta .btn-secondary {
        width: 100%;
        white-space: normal;
    }
}

/* Kontakt-Seite */
.contact-page { padding-bottom: 42px; }
.contact-hero { max-width: 1180px; margin: 0 auto; padding: 70px 22px 34px; display: grid; grid-template-columns: minmax(0, 1.08fr) minmax(280px, .92fr); gap: 34px; align-items: stretch; }
.contact-hero__content, .contact-hero__note, .contact-section, .contact-info-card, .contact-form--redesign { background: rgba(255,255,255,.92); border: 1px solid rgba(14,68,56,.11); border-radius: 28px; box-shadow: var(--shadow); }
.contact-hero__content { padding: clamp(28px, 5vw, 54px); display: flex; flex-direction: column; justify-content: center; }
.contact-hero h1 { font-size: clamp(2.35rem, 5.2vw, 4.7rem); line-height: .98; color: var(--green-950); margin: 0 0 20px; max-width: 880px; }
.contact-hero .lead { font-size: 1.28rem; color: var(--muted); max-width: 760px; margin: 0 0 26px; }
.contact-points { margin-top: 4px; }
.contact-hero__note { padding: clamp(26px, 4vw, 42px); background: linear-gradient(180deg, var(--white), var(--green-100)); display: flex; flex-direction: column; justify-content: center; gap: 12px; }
.contact-hero__note strong { display: block; color: var(--green-900); font-size: clamp(1.8rem, 3vw, 2.6rem); line-height: 1.05; }
.contact-hero__note span { color: var(--text); font-size: 1.15rem; }
.contact-section { max-width: 1120px; margin: 28px auto; padding: clamp(26px, 4vw, 44px); }
.contact-layout { display: grid; grid-template-columns: .85fr 1.15fr; gap: 24px; align-items: stretch; }
.contact-info-card { padding: 28px; background: linear-gradient(180deg, #fffaf0, var(--green-100)); }
.contact-info-card h2 { font-size: clamp(2rem, 4vw, 3rem); line-height: 1.05; color: var(--green-950); margin: 0 0 14px; }
.contact-info-card p { color: var(--text); font-size: 1.12rem; margin: 0 0 18px; }
.contact-checklist { display: grid; gap: 12px; margin-top: 22px; }
.contact-checklist div { display: grid; grid-template-columns: 44px 1fr; gap: 12px; align-items: center; background: rgba(255,255,255,.72); border: 1px solid rgba(14,68,56,.1); border-radius: 18px; padding: 12px; }
.contact-checklist span { width: 38px; height: 38px; border-radius: 50%; background: var(--green-900); color: var(--white); display: inline-flex; align-items: center; justify-content: center; font-weight: 700; }
.contact-checklist p { margin: 0; font-size: 1.05rem; }
.contact-form--redesign { width: 100%; padding: 28px; }
.contact-form--redesign .form-row { margin-bottom: 16px; }
.contact-form--redesign label { display: block; font-weight: 700; margin: 0 0 6px; color: var(--green-950); }
.contact-form--redesign input, .contact-form--redesign textarea { width: 100%; padding: 13px 14px; border: 1px solid rgba(14,68,56,.18); border-radius: 14px; background: var(--cream); color: var(--text); font: inherit; }
.contact-form--redesign textarea { resize: vertical; min-height: 170px; }
.contact-form--redesign input:focus, .contact-form--redesign textarea:focus { outline: 2px solid rgba(201,154,69,.45); border-color: rgba(14,68,56,.36); background: var(--white); }
.contact-privacy { text-align: left; }
.contact-privacy label { display: flex; gap: 10px; align-items: flex-start; font-weight: 500; color: var(--text); margin-bottom: 18px; }
.contact-privacy input[type="checkbox"] { width: auto; margin-top: 5px; flex: 0 0 auto; }
.contact-form--redesign button[type="submit"] { width: auto; min-width: 190px; }
@media (max-width: 980px) { .contact-hero, .contact-layout { grid-template-columns: 1fr; } }
@media (max-width: 640px) { .contact-hero { padding: 32px 14px 18px; } .contact-section { margin: 18px 12px; padding: 22px 16px; border-radius: 22px; } .contact-hero__content, .contact-hero__note, .contact-info-card, .contact-form--redesign { border-radius: 22px; } .contact-info-card, .contact-form--redesign { padding: 22px 16px; } .contact-checklist div { grid-template-columns: 1fr; } .contact-form--redesign button[type="submit"] { width: 100%; } }

/* Rechtliches: Impressum & Datenschutz */
.legal-page {
    padding-bottom: 42px;
}

.legal-hero {
    max-width: 1180px;
    margin: 0 auto;
    padding: 70px 22px 34px;
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(280px, .92fr);
    gap: 34px;
    align-items: stretch;
}

.legal-hero__content,
.legal-hero__note,
.legal-section {
    background: rgba(255,255,255,.92);
    border: 1px solid rgba(14,68,56,.11);
    border-radius: 28px;
    box-shadow: var(--shadow);
}

.legal-hero__content {
    padding: clamp(28px, 5vw, 54px);
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.legal-hero h1 {
    font-size: clamp(1.15rem, 4.0vw, 3.5rem);
    line-height: .98;
    color: var(--green-950);
    margin: 0 0 20px;
    max-width: 880px;
}

.legal-hero .lead {
    font-size: 1.28rem;
    color: var(--muted);
    max-width: 760px;
    margin: 0;
}

.legal-hero__note {
    padding: clamp(26px, 4vw, 42px);
    background: linear-gradient(180deg, var(--white), var(--green-100));
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 12px;
}

.legal-hero__note strong {
    display: block;
    color: var(--green-900);
    font-size: clamp(1.8rem, 3vw, 2.6rem);
    line-height: 1.05;
}

.legal-hero__note span {
    color: var(--text);
    font-size: 1.15rem;
}

.legal-section {
    max-width: 1120px;
    margin: 28px auto;
    padding: clamp(26px, 4vw, 44px);
}

.legal-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}

.legal-card {
    background: linear-gradient(180deg, var(--white), var(--green-100));
    border: 1px solid rgba(14,68,56,.1);
    border-radius: 22px;
    padding: 24px;
}

.legal-card--highlight {
    background: linear-gradient(180deg, #fffaf0, var(--green-100));
    border-color: rgba(201,154,69,.35);
}

.legal-card h2,
.legal-content h2 {
    color: var(--green-900);
    line-height: 1.1;
    margin: 0 0 12px;
}

.legal-card h2 {
    font-size: 1.55rem;
}

.legal-content h2 {
    font-size: clamp(1.6rem, 3vw, 2.25rem);
    margin-top: 30px;
}

.legal-content h2:first-child {
    margin-top: 0;
}

.legal-card p,
.legal-content p,
.legal-content li {
    color: var(--text);
    font-size: 1.08rem;
}

.legal-card p,
.legal-content p {
    margin: 0 0 14px;
}

.legal-content ul {
    margin: 0 0 18px;
    padding-left: 22px;
}

.legal-content li {
    margin: 6px 0;
}

.legal-content a,
.legal-card a {
    color: var(--green-900);
    font-weight: 700;
    word-break: break-word;
}

@media (max-width: 980px) {
    .legal-hero {
        grid-template-columns: 1fr;
    }

    .legal-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 640px) {
    .legal-hero {
        padding: 32px 14px 18px;
    }

    .legal-section {
        margin: 18px 12px;
        padding: 22px 16px;
        border-radius: 22px;
    }

    .legal-hero__content,
    .legal-hero__note {
        border-radius: 22px;
    }

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

    .legal-card {
        padding: 22px 16px;
    }
}

/* DSGVO / Consent */
.cookie-consent {
    position: fixed;
    left: 18px;
    right: 18px;
    bottom: 18px;
    z-index: 3000;
    max-width: 980px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 22px;
    padding: 18px;
    background: rgba(9, 47, 40, .98);
    color: var(--cream);
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 22px;
    box-shadow: 0 18px 45px rgba(0,0,0,.22);
}
.cookie-consent[hidden] { display: none !important; }
.cookie-consent strong { display: block; color: var(--white); font-size: 1.15rem; margin-bottom: 4px; }
.cookie-consent p { margin: 0; color: rgba(251,247,239,.82); }
.cookie-consent__actions { display: flex; align-items: center; justify-content: flex-end; gap: 10px; flex-wrap: wrap; }
.cookie-consent__actions a { color: var(--sand); font-weight: 700; text-decoration: none; }
.cookie-consent__actions a:hover { color: var(--white); }
.recaptcha-consent-note {
    display: none;
    margin: 0 0 16px;
    padding: 12px 14px;
    border-radius: 14px;
    background: var(--green-100);
    border: 1px solid rgba(14,68,56,.18);
    color: var(--green-950);
}
.recaptcha-consent-note.is-visible { display: block; }
@media (max-width: 760px) {
    .cookie-consent {
        left: 10px;
        right: 10px;
        bottom: 10px;
        flex-direction: column;
        align-items: stretch;
        padding: 16px;
    }
    .cookie-consent__actions { justify-content: stretch; }
    .cookie-consent__actions .btn { flex: 1 1 140px; }
}
