/*
Theme Name:       Stiefelzeit
Theme URI:        https://stiefelzeit.de
Author:           Morsdorf IT
Author URI:       https://morsdorf-it.de
Description:      Designstarke Homepage für Stiefelzeit — Bushcraft, Waldläufer, Präzisionsschießen & Jagd mit Jochen Laukötter. Komplett eingerichtet mit Hero, Kursen, Galerie, Kontaktformular inkl. Spamschutz und Kurs-Detail-Modals.
Version:          1.0.0
Requires at least: 6.0
Tested up to:     6.5
Requires PHP:     7.4
License:          GPL v2 or later
License URI:      https://www.gnu.org/licenses/gpl-2.0.html
Text Domain:      stiefelzeit
Tags:             one-page, custom-colors, custom-logo, custom-menu, featured-images, full-width-template, translation-ready
*/

/* =========================================================
   Jochen Laukötter — Bushcraft · Waldläufer · Jagd
   Homepage Stylesheet
   ========================================================= */

/* --------- Design Tokens --------- */
:root {
    /* Erdige, waldige Palette */
    --c-forest-950: #0f1a14;
    --c-forest-900: #162319;
    --c-forest-800: #1e2f22;
    --c-forest-700: #2a3d2a;
    --c-forest-600: #3a5038;
    --c-moss:       #5a6b46;
    --c-moss-soft:  #8a9b75;

    --c-bark-900:   #241a12;
    --c-bark-700:   #3b2f24;
    --c-bark-500:   #6b5a44;

    --c-cream-50:   #faf6ee;
    --c-cream-100:  #f5efe4;
    --c-cream-200:  #ece4d2;
    --c-cream-300:  #ddd2b8;

    --c-ember:      #c47a3a;
    --c-ember-dark: #9a5a24;
    --c-ember-soft: #e3a976;

    --c-ink:        #1a1f16;
    --c-ink-soft:   #3a3f36;
    --c-stone:      #8a8578;
    --c-rule:       rgba(60, 55, 40, .14);
    --c-rule-light: rgba(245, 239, 228, .18);

    /* Typografie */
    --ff-display: "Fraunces", "Cormorant Garamond", Georgia, serif;
    --ff-body:    "Inter", -apple-system, system-ui, "Segoe UI", sans-serif;

    /* Maße */
    --container: 1240px;
    --radius:    6px;
    --radius-lg: 14px;
    --shadow-sm: 0 2px 10px rgba(20,25,18,.06);
    --shadow-md: 0 18px 50px -18px rgba(15,26,20,.35);
    --shadow-lg: 0 40px 80px -30px rgba(15,26,20,.55);

    --ease:      cubic-bezier(.2,.7,.2,1);
    --ease-out:  cubic-bezier(.16,1,.3,1);
}

/* --------- Reset / Base --------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
    margin: 0;
    font-family: var(--ff-body);
    color: var(--c-ink);
    background: var(--c-cream-50);
    font-size: 17px;
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    overflow-x: hidden;
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: 0; background: none; color: inherit; }
ul { list-style: none; padding: 0; margin: 0; }

/* --------- Container --------- */
.container {
    width: 100%;
    max-width: var(--container);
    margin: 0 auto;
    padding: 0 28px;
}

/* --------- Typography --------- */
.h-display {
    font-family: var(--ff-display);
    font-weight: 500;
    font-size: clamp(2rem, 3.5vw + .5rem, 3.4rem);
    line-height: 1.08;
    letter-spacing: -.015em;
    margin: 0 0 .6em;
    color: var(--c-ink);
    font-variation-settings: "opsz" 144, "SOFT" 50;
}
.h-display--light { color: var(--c-cream-100); }

.eyebrow {
    display: inline-flex;
    align-items: center;
    gap: .5em;
    font-family: var(--ff-body);
    font-size: .78rem;
    font-weight: 600;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--c-ember-dark);
    margin-bottom: 1.2rem;
}
.eyebrow::before {
    content: "";
    width: 28px; height: 1px;
    background: currentColor;
}
.eyebrow--light { color: var(--c-ember-soft); }

.lead {
    font-size: 1.12rem;
    line-height: 1.65;
    color: var(--c-ink-soft);
}
.text--light { color: rgba(245,239,228,.85); }

/* --------- Buttons --------- */
.btn {
    display: inline-flex;
    align-items: center;
    gap: .6em;
    padding: 14px 26px;
    border-radius: 999px;
    font-weight: 600;
    font-size: .95rem;
    letter-spacing: .01em;
    transition: transform .25s var(--ease), background .25s var(--ease), box-shadow .25s var(--ease), color .25s var(--ease);
    will-change: transform;
    border: 1px solid transparent;
    cursor: pointer;
}
.btn svg { transition: transform .25s var(--ease); }
.btn:hover { transform: translateY(-2px); }
.btn:hover svg { transform: translateX(3px); }

.btn--primary {
    background: var(--c-cream-100);
    color: var(--c-forest-900);
    box-shadow: 0 10px 30px -12px rgba(0,0,0,.4);
}
.btn--primary:hover { background: #fff; }

.btn--ghost {
    background: transparent;
    color: var(--c-cream-100);
    border-color: rgba(245,239,228,.4);
}
.btn--ghost:hover { background: rgba(245,239,228,.1); border-color: var(--c-cream-100); }

.btn--ember {
    background: var(--c-ember);
    color: #fff;
    box-shadow: 0 10px 30px -10px rgba(196,122,58,.55);
}
.btn--ember:hover { background: var(--c-ember-dark); }

.btn--small { padding: 10px 20px; font-size: .85rem; }
.btn--block { width: 100%; justify-content: center; }

/* --------- Photo Helper (wrappt Originalfotos mit gleichem Aspect-Verhalten) --------- */
.laukoetter-photo {
    position: relative;
    border-radius: var(--radius-lg);
    overflow: hidden;
    min-height: 260px;
    background: #0f1a14;
}
.laukoetter-photo > img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    position: absolute; inset: 0;
    transition: transform .6s var(--ease-out);
}
.laukoetter-photo:hover > img { transform: scale(1.04); }
.laukoetter-photo.img-placeholder--tall    { aspect-ratio: 3/4; }
.laukoetter-photo.img-placeholder--wide    { aspect-ratio: 16/9; }
.laukoetter-photo.img-placeholder--square  { aspect-ratio: 1/1; }
.laukoetter-photo.img-placeholder--portrait{ aspect-ratio: 4/5; min-height: 420px; }

/* Kurs-Card Bild direkt */
.kurs-card__media { aspect-ratio: 4/3; position: relative; overflow: hidden; background: #0f1a14; }
.kurs-card__media > img {
    width: 100%; height: 100%; object-fit: cover; display: block;
    transition: transform .6s var(--ease-out);
}
.kurs-card:hover .kurs-card__media > img { transform: scale(1.06); }

/* Galerie */
.galerie-item { position: relative; overflow: hidden; background: #0f1a14; }
.galerie-item > img {
    width: 100%; height: 100%; object-fit: cover; display: block;
    transition: transform .6s var(--ease-out);
}
.galerie-item:hover > img { transform: scale(1.08); }

/* --------- Image Placeholders (Fallback) --------- */
.img-placeholder {
    position: relative;
    background:
        linear-gradient(135deg, rgba(58,80,56,.88), rgba(21,35,24,.95)),
        repeating-linear-gradient(45deg, rgba(255,255,255,.025) 0 6px, transparent 6px 12px);
    color: rgba(245,239,228,.65);
    display: grid;
    place-items: center;
    text-align: center;
    font-family: var(--ff-display);
    font-style: italic;
    font-size: 1rem;
    border-radius: var(--radius-lg);
    overflow: hidden;
    min-height: 260px;
}
.img-placeholder::before {
    content: "";
    position: absolute; inset: 0;
    background:
        radial-gradient(ellipse at top left, rgba(196,122,58,.18), transparent 55%),
        radial-gradient(ellipse at bottom right, rgba(138,155,117,.2), transparent 60%);
    pointer-events: none;
}
.img-placeholder::after {
    content: "📷";
    position: absolute;
    top: 18px; left: 18px;
    font-size: 1rem;
    opacity: .6;
}
.img-placeholder span { position: relative; padding: .8em 1.4em; }
.img-placeholder span small { font-family: var(--ff-body); font-style: normal; font-size: .78rem; letter-spacing: .1em; text-transform: uppercase; opacity: .7; display: block; margin-top: .4em; }

.img-placeholder--tall    { aspect-ratio: 3/4; }
.img-placeholder--wide    { aspect-ratio: 16/9; }
.img-placeholder--square  { aspect-ratio: 1/1; }
.img-placeholder--portrait{ aspect-ratio: 4/5; min-height: 420px; }

.img-placeholder--dark { background:
    linear-gradient(135deg, rgba(36,26,18,.92), rgba(15,26,20,.95)),
    repeating-linear-gradient(45deg, rgba(255,255,255,.02) 0 6px, transparent 6px 12px);
}

/* Data-Attribut als Hover-Tooltip */
[data-img-placeholder]:hover::before { opacity: 1.1; }

/* --------- Top Bar --------- */
.topbar {
    background: var(--c-forest-950);
    color: var(--c-cream-200);
    font-size: .82rem;
    padding: 10px 0;
    border-bottom: 1px solid rgba(255,255,255,.05);
}
.topbar__inner { display: flex; justify-content: space-between; align-items: center; gap: 1rem; }
.topbar__left { display: flex; gap: 2rem; }
.topbar__item { display: inline-flex; gap: .5em; align-items: center; opacity: .85; }
.topbar__right { display: flex; gap: 1rem; }
.topbar__right a { opacity: .7; transition: opacity .2s, transform .2s; }
.topbar__right a:hover { opacity: 1; transform: translateY(-1px); }

/* --------- Navigation --------- */
.nav {
    position: sticky;
    top: 0;
    z-index: 100;
    background: rgba(250,246,238,.86);
    -webkit-backdrop-filter: saturate(140%) blur(14px);
    backdrop-filter: saturate(140%) blur(14px);
    border-bottom: 1px solid var(--c-rule);
    transition: background .3s, box-shadow .3s, padding .3s;
}
.nav--scrolled { box-shadow: 0 6px 30px -12px rgba(0,0,0,.12); background: rgba(250,246,238,.96); }
.nav__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 28px;
    gap: 2rem;
}
.nav__logo { display: inline-flex; align-items: center; gap: .7rem; }
.nav__logo-mark { color: var(--c-forest-700); }
.nav__logo-text { line-height: 1.1; }
.nav__logo-text strong { font-family: var(--ff-display); font-weight: 600; font-size: 1.12rem; letter-spacing: .005em; display: block; color: var(--c-forest-900); }
.nav__logo-text small { font-size: .72rem; letter-spacing: .16em; text-transform: uppercase; color: var(--c-ember-dark); font-weight: 500; }

.nav__menu { display: flex; align-items: center; gap: 2rem; }
.nav__menu a {
    position: relative;
    font-weight: 500;
    font-size: .95rem;
    color: var(--c-ink-soft);
    transition: color .2s;
    padding: 6px 0;
}
.nav__menu a::after {
    content: "";
    position: absolute; left: 0; right: 0; bottom: 0;
    height: 2px;
    background: var(--c-ember);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform .3s var(--ease);
}
.nav__menu a:hover { color: var(--c-forest-900); }
.nav__menu a:hover::after { transform: scaleX(1); }

.nav__cta {
    background: var(--c-forest-700);
    color: var(--c-cream-100) !important;
    padding: 10px 22px !important;
    border-radius: 999px;
    transition: background .25s, transform .2s;
}
.nav__cta::after { display: none; }
.nav__cta:hover { background: var(--c-forest-900); transform: translateY(-1px); }

.nav__toggle {
    display: none;
    flex-direction: column;
    gap: 5px;
    padding: 10px;
    width: 44px; height: 44px;
    justify-content: center;
}
.nav__toggle span {
    display: block;
    width: 22px; height: 2px;
    background: var(--c-forest-900);
    border-radius: 2px;
    transition: transform .25s var(--ease), opacity .25s;
}
.nav__toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav__toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav__toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* --------- Hero --------- */
.hero {
    position: relative;
    min-height: clamp(640px, 92vh, 900px);
    display: flex;
    align-items: center;
    overflow: hidden;
    color: var(--c-cream-50);
    isolation: isolate;
}
.hero__media { position: absolute; inset: 0; z-index: -2; overflow: hidden; }
.hero__photo { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 2; }
.hero__svg-fallback { position: absolute; inset: 0; z-index: 1; background:
    radial-gradient(ellipse at 70% 50%, rgba(196,122,58,.4), transparent 55%),
    linear-gradient(180deg, #1a2a20, #241a12 70%, #0a0604); }
.hero__placeholder {
    position: absolute; inset: 0;
    background:
        radial-gradient(ellipse at 30% 20%, rgba(196,122,58,.35), transparent 55%),
        radial-gradient(ellipse at 80% 90%, rgba(90,107,70,.4), transparent 55%),
        linear-gradient(135deg, #0f1a14 0%, #1e2f22 40%, #3a5038 70%, #162319 100%);
}
.hero__placeholder::before {
    /* subtile Baum-Silhouetten */
    content: "";
    position: absolute; inset: 0;
    background-image:
        radial-gradient(circle at 10% 90%, rgba(15,26,20,.7) 0 60px, transparent 120px),
        radial-gradient(circle at 25% 95%, rgba(15,26,20,.9) 0 80px, transparent 140px),
        radial-gradient(circle at 55% 92%, rgba(15,26,20,.85) 0 90px, transparent 150px),
        radial-gradient(circle at 85% 95%, rgba(15,26,20,.9) 0 70px, transparent 130px);
    opacity: .7;
}
.hero__placeholder::after {
    /* Körnung */
    content: "";
    position: absolute; inset: 0;
    background-image: radial-gradient(rgba(255,255,255,.04) 1px, transparent 1px);
    background-size: 3px 3px;
    mix-blend-mode: overlay;
}
.hero__veil {
    position: absolute; inset: 0;
    background:
        /* Lese-Vignette links, damit die Headline überall trägt */
        linear-gradient(90deg, rgba(10,15,12,.78) 0%, rgba(10,15,12,.45) 35%, rgba(10,15,12,.05) 70%, rgba(10,15,12,0) 100%),
        /* Vertikale Tiefen-Vignette */
        linear-gradient(180deg, rgba(15,26,20,.25) 0%, transparent 35%, rgba(10,15,12,.55) 85%, rgba(10,15,12,.88) 100%);
    z-index: -1;
}
.hero__scene { position: absolute; inset: 0; width: 100%; height: 100%; }

.hero__content {
    padding: 100px 28px 120px;
    max-width: 900px;
}
.hero__title {
    font-family: var(--ff-display);
    font-size: clamp(2.8rem, 7vw, 5.8rem);
    line-height: .98;
    font-weight: 500;
    margin: .3em 0 .5em;
    letter-spacing: -.025em;
    font-variation-settings: "opsz" 144, "SOFT" 80;
}
.hero__line { display: block; }
.hero__line--italic {
    font-style: italic;
    color: var(--c-ember-soft);
    font-weight: 400;
}
.hero__lead {
    font-size: clamp(1.05rem, 1.1vw + .8rem, 1.3rem);
    max-width: 620px;
    line-height: 1.55;
    color: rgba(245,239,228,.9);
    margin-bottom: 2.5rem;
}
.hero__actions { display: flex; flex-wrap: wrap; gap: 14px; }

.hero__meta {
    margin-top: 4rem;
    display: flex;
    gap: clamp(2rem, 5vw, 4rem);
    padding-top: 2rem;
    border-top: 1px solid var(--c-rule-light);
    max-width: 620px;
}
.hero__meta div { display: flex; flex-direction: column; }
.hero__meta strong {
    font-family: var(--ff-display);
    font-size: 2rem;
    font-weight: 500;
    color: var(--c-ember-soft);
    line-height: 1;
}
.hero__meta span { font-size: .85rem; letter-spacing: .05em; opacity: .8; margin-top: .4em; }

.hero__scroll {
    position: absolute;
    left: 50%;
    bottom: 30px;
    transform: translateX(-50%);
    display: flex; flex-direction: column; align-items: center; gap: 10px;
    color: rgba(245,239,228,.6);
    font-size: .72rem;
    letter-spacing: .25em;
    text-transform: uppercase;
    transition: color .3s;
}
.hero__scroll span {
    width: 1px; height: 36px;
    background: currentColor;
    position: relative;
    overflow: hidden;
}
.hero__scroll span::before {
    content: "";
    position: absolute;
    left: 0; top: -100%;
    width: 100%; height: 60%;
    background: linear-gradient(180deg, transparent, var(--c-ember-soft));
    animation: scroll-dash 2.6s var(--ease-out) infinite;
}
.hero__scroll:hover { color: var(--c-cream-100); }
@keyframes scroll-dash {
    0% { top: -60%; } 100% { top: 120%; }
}

/* --------- Section Base --------- */
section { padding: clamp(70px, 10vw, 130px) 0; position: relative; }
.section--dark { background: var(--c-forest-900); color: var(--c-cream-100); }
.section--dark p { color: rgba(245,239,228,.8); }
.section--forest { background: var(--c-forest-800); color: var(--c-cream-100); }

.section-head {
    max-width: 760px;
    margin: 0 auto clamp(50px, 7vw, 90px);
    text-align: center;
}
.section-head__lead { color: var(--c-ink-soft); font-size: 1.08rem; }
.section--dark .section-head__lead,
.section--forest .section-head__lead { color: rgba(245,239,228,.75); }
.section-head .eyebrow::before { margin-right: .4em; }

/* --------- Intro --------- */
.intro { padding-top: clamp(90px, 11vw, 150px); }
.intro__grid {
    display: grid;
    grid-template-columns: 1.1fr 1fr;
    gap: clamp(40px, 6vw, 100px);
    align-items: center;
}
.intro__text .lead { margin-bottom: 1.2rem; }
.intro__text p { color: var(--c-ink-soft); }

.feature-list { margin-top: 1.8rem; display: grid; gap: .8rem; }
.feature-list li { display: flex; align-items: center; gap: .8em; font-weight: 500; }
.feature-list__dot {
    width: 10px; height: 10px;
    border-radius: 50%;
    background: var(--c-ember);
    box-shadow: 0 0 0 4px rgba(196,122,58,.18);
    flex-shrink: 0;
}

.intro__media { position: relative; }
.intro__media-frame {
    position: relative;
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-md);
    transform: rotate(-1deg);
}
.intro__media-frame::before {
    content: "";
    position: absolute;
    inset: -12px -12px -12px -12px;
    border: 1px solid var(--c-rule);
    border-radius: calc(var(--radius-lg) + 6px);
    z-index: -1;
    transform: rotate(2deg);
    opacity: .7;
}
.intro__badge {
    position: absolute;
    right: -20px; bottom: 40px;
    background: var(--c-forest-700);
    color: var(--c-cream-100);
    padding: 18px 22px;
    border-radius: var(--radius);
    display: flex; align-items: center; gap: 14px;
    box-shadow: var(--shadow-md);
    max-width: 260px;
}
.intro__badge strong { display: block; font-size: .95rem; }
.intro__badge small { font-size: .78rem; opacity: .8; }
.intro__badge svg { flex-shrink: 0; color: var(--c-ember-soft); }

/* --------- Kurse --------- */
.kurse { background: linear-gradient(180deg, var(--c-forest-900), var(--c-forest-950)); }
.kurs-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(270px, 1fr));
    gap: 30px;
}
.kurs-card {
    background: rgba(255,255,255,.03);
    border: 1px solid rgba(245,239,228,.08);
    border-radius: var(--radius-lg);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: transform .35s var(--ease), border-color .35s, box-shadow .35s;
}
.kurs-card:hover {
    transform: translateY(-6px);
    border-color: rgba(196,122,58,.4);
    box-shadow: 0 30px 60px -20px rgba(0,0,0,.5);
}
.kurs-card__media {
    aspect-ratio: 4/3;
    border-radius: 0;
    min-height: 0;
}
.kurs-card__body { padding: 26px 26px 30px; display: flex; flex-direction: column; flex: 1; }
.kurs-card__tag {
    display: inline-block;
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--c-ember-soft);
    margin-bottom: 1rem;
}
.kurs-card__tag--featured { color: var(--c-cream-100); background: var(--c-ember); padding: 4px 10px; border-radius: 999px; letter-spacing: .1em; }
.kurs-card h3 {
    font-family: var(--ff-display);
    font-size: 1.45rem;
    font-weight: 500;
    margin: 0 0 .6em;
    letter-spacing: -.01em;
    color: var(--c-cream-50);
}
.kurs-card p { color: rgba(245,239,228,.75); font-size: .95rem; margin: 0 0 1.2rem; flex: 1; }
.kurs-card__meta {
    display: flex; flex-wrap: wrap; gap: 14px;
    padding-top: 1rem;
    border-top: 1px solid rgba(245,239,228,.08);
    margin-bottom: 1.2rem;
}
.kurs-card__meta li {
    font-size: .78rem;
    opacity: .75;
    display: inline-flex;
    align-items: center;
    gap: .4em;
}
.kurs-card__link {
    font-weight: 600;
    font-size: .92rem;
    color: var(--c-ember-soft);
    display: inline-flex;
    align-items: center;
    gap: .4em;
    transition: gap .25s, color .25s;
    align-self: flex-start;
}
.kurs-card__link:hover { gap: .8em; color: var(--c-cream-100); }

.kurs-card--featured {
    background: linear-gradient(160deg, rgba(196,122,58,.12), rgba(255,255,255,.03));
    border-color: rgba(196,122,58,.3);
}

.kurse__footer { text-align: center; margin-top: 3rem; color: rgba(245,239,228,.75); }
.kurse__footer a { color: var(--c-ember-soft); font-weight: 600; border-bottom: 1px solid; }

/* --------- Waldläufer --------- */
.waldlaeufer__grid {
    display: grid;
    grid-template-columns: 1fr 1.1fr;
    gap: clamp(40px, 6vw, 80px);
    align-items: center;
}
.waldlaeufer__pillars {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 32px;
    margin-top: 2.5rem;
}
.pillar__num {
    font-family: var(--ff-display);
    font-size: 1.2rem;
    color: var(--c-ember);
    display: block;
    margin-bottom: .4em;
    font-weight: 500;
}
.pillar h4 {
    font-family: var(--ff-display);
    font-size: 1.2rem;
    font-weight: 500;
    margin: 0 0 .4em;
    color: var(--c-forest-900);
}
.pillar p { font-size: .92rem; color: var(--c-ink-soft); margin: 0; }

/* --------- Jagd --------- */
.jagd { overflow: hidden; }
.jagd__bg {
    position: absolute; inset: 0;
    background:
        radial-gradient(ellipse at 10% 0%, rgba(196,122,58,.15), transparent 50%),
        radial-gradient(ellipse at 90% 100%, rgba(90,107,70,.2), transparent 55%);
    pointer-events: none;
}
.jagd__grid {
    position: relative;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: clamp(40px, 6vw, 90px);
    align-items: center;
}
.checklist { margin: 1.5rem 0 2rem; }
.checklist li {
    padding: 10px 0 10px 34px;
    position: relative;
    border-bottom: 1px solid rgba(245,239,228,.1);
    font-size: 1rem;
    color: rgba(245,239,228,.9);
}
.checklist li::before {
    content: "";
    position: absolute;
    left: 0; top: 14px;
    width: 20px; height: 20px;
    border-radius: 50%;
    background: var(--c-ember);
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='3'><polyline points='5 13 10 18 19 7'/></svg>");
    background-size: 12px;
    background-position: center;
    background-repeat: no-repeat;
}

.jagd__stack {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px;
    grid-template-areas:
        "a b"
        "c c";
}
.jagd__stack .img-placeholder:nth-child(1) { grid-area: a; }
.jagd__stack .img-placeholder:nth-child(2) { grid-area: b; }
.jagd__stack .img-placeholder:nth-child(3) { grid-area: c; }

/* --------- Termine --------- */
.termine { background: var(--c-cream-100); }
.termin-list { display: grid; gap: 18px; max-width: 900px; margin: 0 auto; }
.termin {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 24px;
    align-items: center;
    background: #fff;
    padding: 22px 28px;
    border-radius: var(--radius-lg);
    border: 1px solid var(--c-rule);
    transition: transform .25s var(--ease), border-color .25s, box-shadow .25s;
}
.termin:hover {
    transform: translateX(4px);
    border-color: var(--c-ember);
    box-shadow: var(--shadow-md);
}
.termin__date {
    text-align: center;
    padding: 10px 16px;
    background: var(--c-forest-800);
    color: var(--c-cream-100);
    border-radius: var(--radius);
    min-width: 70px;
}
.termin__date strong { font-family: var(--ff-display); font-size: 1.6rem; display: block; line-height: 1; }
.termin__date span { font-size: .72rem; letter-spacing: .12em; text-transform: uppercase; opacity: .8; }
.termin h3 { font-family: var(--ff-display); font-size: 1.25rem; margin: 0 0 .2em; font-weight: 500; }
.termin p { font-size: .9rem; margin: 0; color: var(--c-ink-soft); }

.termin--featured {
    background: linear-gradient(135deg, var(--c-forest-800), var(--c-forest-700));
    color: var(--c-cream-100);
    border-color: var(--c-ember);
}
.termin--featured h3 { color: var(--c-cream-50); }
.termin--featured p { color: rgba(245,239,228,.8); }
.termin--featured .termin__date { background: var(--c-ember); }

/* --------- Über --------- */
.ueber__grid {
    display: grid;
    grid-template-columns: 1fr 1.1fr;
    gap: clamp(40px, 6vw, 90px);
    align-items: center;
}
.ueber__media { position: relative; }
.ueber__media-main { box-shadow: var(--shadow-md); transform: rotate(-1.5deg); }
.ueber__media-sub {
    position: absolute;
    bottom: -40px;
    right: -20px;
    width: 58%;
    min-height: 0;
    aspect-ratio: 1;
    border: 8px solid var(--c-cream-50);
    transform: rotate(3deg);
    box-shadow: var(--shadow-md);
    z-index: 2;
}
.ueber__facts {
    display: flex;
    gap: 2.5rem;
    padding: 1.5rem 0;
    margin: 1.5rem 0;
    border-top: 1px solid var(--c-rule);
    border-bottom: 1px solid var(--c-rule);
}
.ueber__facts strong {
    font-family: var(--ff-display);
    font-size: 1.4rem;
    color: var(--c-forest-900);
    display: block;
    line-height: 1.1;
}
.ueber__facts span { font-size: .82rem; color: var(--c-stone); display: block; }
.pull-quote {
    font-family: var(--ff-display);
    font-style: italic;
    font-size: 1.25rem;
    line-height: 1.5;
    color: var(--c-forest-800);
    padding-left: 1.5rem;
    border-left: 3px solid var(--c-ember);
    margin: 2rem 0 0;
}
.pull-quote cite {
    display: block;
    font-family: var(--ff-body);
    font-style: normal;
    font-size: .9rem;
    color: var(--c-stone);
    margin-top: .6em;
}

/* --------- Galerie --------- */
.galerie { background: var(--c-forest-950); }
.galerie-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 14px;
    grid-auto-flow: dense;
}
.galerie-item {
    aspect-ratio: 1;
    min-height: 0;
    border-radius: var(--radius);
    cursor: pointer;
    transition: transform .4s var(--ease), filter .4s;
}
.galerie-item:hover { transform: scale(1.02); filter: brightness(1.1); }
.galerie-item[style*="--span:2"] { grid-column: span 2; }
.galerie-item[style*="--spanH:2"] { grid-row: span 2; aspect-ratio: 1/2; }

/* --------- Warum jetzt? --------- */
.warum-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 24px;
}
.warum-card {
    background: #fff;
    padding: 36px 32px;
    border-radius: var(--radius-lg);
    border: 1px solid var(--c-rule);
    position: relative;
    overflow: hidden;
    transition: transform .3s var(--ease), box-shadow .3s, border-color .3s;
}
.warum-card::before {
    content: "";
    position: absolute;
    inset: 0 0 auto 0;
    height: 4px;
    background: linear-gradient(90deg, var(--c-ember), var(--c-ember-soft));
    transform: scaleX(0);
    transform-origin: left;
    transition: transform .5s var(--ease-out);
}
.warum-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--c-ember); }
.warum-card:hover::before { transform: scaleX(1); }
.warum-card__num {
    display: block;
    font-family: var(--ff-display);
    font-size: 2.6rem;
    font-weight: 500;
    color: var(--c-ember);
    line-height: 1;
    margin-bottom: .6rem;
    letter-spacing: -.02em;
}
.warum-card h3 {
    font-family: var(--ff-display);
    font-size: 1.32rem;
    font-weight: 500;
    color: var(--c-forest-900);
    margin: 0 0 .6em;
    letter-spacing: -.005em;
}
.warum-card p { color: var(--c-ink-soft); margin: 0; font-size: .97rem; line-height: 1.6; }

.warum__quote {
    margin: 3.5rem auto 0;
    max-width: 780px;
    text-align: center;
    font-family: var(--ff-display);
    font-style: italic;
    font-size: clamp(1.15rem, 1.4vw + .5rem, 1.45rem);
    line-height: 1.5;
    color: var(--c-forest-900);
    padding: 0 2rem;
    position: relative;
}
.warum__quote::before,
.warum__quote::after {
    content: "";
    display: block;
    width: 40px; height: 1px;
    background: var(--c-ember);
    margin: 1.5rem auto;
    opacity: .6;
}
.warum__quote cite {
    display: block;
    font-family: var(--ff-body);
    font-style: normal;
    font-size: .88rem;
    color: var(--c-stone);
    letter-spacing: .06em;
    text-transform: uppercase;
}

/* --------- Kontakt --------- */
.kontakt__grid {
    display: grid;
    grid-template-columns: 1fr 1.1fr;
    gap: clamp(40px, 6vw, 80px);
    align-items: start;
}
.kontakt__list {
    display: grid;
    gap: 16px;
    margin-top: 2rem;
}
.kontakt__list li {
    display: flex; align-items: center; gap: 14px;
    color: rgba(245,239,228,.9);
    font-size: 1rem;
}
.kontakt__list svg { color: var(--c-ember-soft); flex-shrink: 0; }

.kontakt__form {
    background: var(--c-cream-50);
    color: var(--c-ink);
    padding: 38px;
    border-radius: var(--radius-lg);
    display: grid; gap: 18px;
    box-shadow: var(--shadow-lg);
}
.field label {
    display: block;
    font-size: .82rem;
    font-weight: 600;
    margin-bottom: .4em;
    letter-spacing: .02em;
    color: var(--c-forest-900);
}
.field input, .field select, .field textarea {
    width: 100%;
    padding: 13px 16px;
    border: 1px solid var(--c-rule);
    border-radius: var(--radius);
    font: inherit;
    background: #fff;
    color: var(--c-ink);
    transition: border-color .2s, box-shadow .2s;
}
.field input:focus, .field select:focus, .field textarea:focus {
    outline: 0;
    border-color: var(--c-ember);
    box-shadow: 0 0 0 4px rgba(196,122,58,.15);
}
.field--row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.field textarea { resize: vertical; font-family: var(--ff-body); }
.check {
    display: flex; gap: .6em;
    font-size: .85rem;
    color: var(--c-ink-soft);
    align-items: flex-start;
}
.check input { margin-top: 4px; accent-color: var(--c-ember); }
.check a { color: var(--c-ember-dark); text-decoration: underline; }
.kontakt__success {
    background: rgba(90,107,70,.15);
    color: var(--c-forest-900);
    padding: 12px 16px;
    border-radius: var(--radius);
    font-weight: 500;
    text-align: center;
    margin: 0;
}

/* Honeypot: komplett unsichtbar, aber nicht display:none (sonst ignorieren Bots es) */
.hp-field {
    position: absolute !important;
    left: -9999px !important;
    top: auto;
    width: 1px; height: 1px;
    overflow: hidden;
}

/* Mini-Captcha */
.captcha label strong {
    color: var(--c-ember-dark);
    font-family: var(--ff-display);
    font-size: 1rem;
    letter-spacing: .01em;
}
.kontakt__hint {
    display: inline-flex;
    align-items: center;
    gap: .5em;
    font-size: .78rem;
    color: var(--c-stone);
    margin: 0;
    padding: 6px 0 0;
    line-height: 1.4;
}
.kontakt__hint svg { color: var(--c-moss); flex-shrink: 0; }

/* --------- Footer --------- */
.footer {
    background: var(--c-forest-950);
    color: rgba(245,239,228,.75);
    padding: 80px 0 40px;
    font-size: .92rem;
}
.footer__grid {
    display: grid;
    grid-template-columns: 1.5fr 1fr 1fr 1fr;
    gap: 50px;
    padding-bottom: 50px;
    border-bottom: 1px solid rgba(245,239,228,.08);
}
.footer__brand .nav__logo-text strong { color: var(--c-cream-100); }
.footer__brand p { margin-top: 1rem; line-height: 1.6; max-width: 360px; }
.footer__col h4 {
    font-family: var(--ff-display);
    font-size: 1rem;
    font-weight: 600;
    color: var(--c-cream-100);
    margin: 0 0 1.2em;
    text-transform: uppercase;
    letter-spacing: .1em;
}
.footer__col li { margin-bottom: .6em; }
.footer__col a { transition: color .2s; }
.footer__col a:hover { color: var(--c-ember-soft); }
.footer__bottom {
    display: flex;
    justify-content: space-between;
    padding-top: 30px;
    gap: 1rem;
    flex-wrap: wrap;
    font-size: .82rem;
    opacity: .6;
}

/* =========================================================
   Modal — Kurs-Detail (volle Kursbeschreibung)
   ========================================================= */
.modal {
    position: fixed;
    inset: 0;
    z-index: 200;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 30px;
}
.modal[aria-hidden="false"] { display: flex; }
body.modal-open { overflow: hidden; }

.modal__backdrop {
    position: absolute; inset: 0;
    background: rgba(10, 15, 12, .82);
    -webkit-backdrop-filter: blur(6px);
    backdrop-filter: blur(6px);
    opacity: 0;
    animation: modal-fade .3s var(--ease-out) forwards;
}
.modal__dialog {
    position: relative;
    max-width: 820px;
    width: 100%;
    max-height: calc(100vh - 60px);
    overflow-y: auto;
    background: linear-gradient(180deg, var(--c-forest-900) 0%, var(--c-forest-950) 100%);
    color: var(--c-cream-100);
    border-radius: var(--radius-lg);
    border: 1px solid rgba(196,122,58,.2);
    box-shadow: 0 60px 100px -20px rgba(0,0,0,.65);
    padding: clamp(30px, 4vw, 60px);
    opacity: 0;
    transform: translateY(24px) scale(.97);
    animation: modal-pop .45s var(--ease-out) .08s forwards;
    scroll-behavior: smooth;
}
.modal__dialog::-webkit-scrollbar { width: 10px; }
.modal__dialog::-webkit-scrollbar-track { background: transparent; }
.modal__dialog::-webkit-scrollbar-thumb {
    background: rgba(196,122,58,.3);
    border-radius: 10px;
    border: 2px solid var(--c-forest-900);
}

.modal__close {
    position: sticky;
    top: 0;
    float: right;
    z-index: 3;
    width: 44px; height: 44px;
    border-radius: 50%;
    background: rgba(245,239,228,.1);
    color: var(--c-cream-100);
    display: grid;
    place-items: center;
    transition: background .2s, transform .2s;
    margin: -10px -10px 0 0;
}
.modal__close:hover { background: var(--c-ember); transform: rotate(90deg); }

.modal__header {
    margin-bottom: 2rem;
    padding-bottom: 1.5rem;
    border-bottom: 1px solid rgba(245,239,228,.1);
    clear: both;
}
.modal__header .h-display { margin-bottom: 0; font-size: clamp(1.8rem, 3vw + .5rem, 2.8rem); }
.modal__header em { color: var(--c-ember-soft); font-style: italic; font-weight: 400; }

.modal__content { font-size: 1.02rem; line-height: 1.75; }
.modal__content .lead {
    font-family: var(--ff-display);
    font-size: 1.3rem;
    line-height: 1.5;
    color: var(--c-cream-50);
    font-weight: 400;
    margin-bottom: 1.5rem;
}
.modal__content p {
    margin: 0 0 1.2rem;
    color: rgba(245,239,228,.82);
}
.modal__content strong { color: var(--c-cream-50); font-weight: 600; }
.modal__content em { color: var(--c-ember-soft); font-style: italic; }

.modal__h3 {
    font-family: var(--ff-display);
    font-size: 1.5rem;
    font-weight: 500;
    margin: 2.5rem 0 1rem;
    color: var(--c-cream-50);
    letter-spacing: -.005em;
    display: flex;
    align-items: center;
    gap: .7em;
}
.modal__h3::before {
    content: "";
    display: block;
    width: 34px; height: 1px;
    background: var(--c-ember);
}

.modal__callout {
    position: relative;
    margin: 2rem 0 2rem;
    padding: 24px 28px;
    background: rgba(196,122,58,.08);
    border-left: 3px solid var(--c-ember);
    border-radius: 0 var(--radius) var(--radius) 0;
}
.modal__callout p { margin: 0; color: var(--c-cream-50); font-style: italic; font-size: 1.05rem; line-height: 1.6; }
.modal__callout-label {
    display: inline-block;
    font-size: .74rem;
    font-weight: 600;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--c-ember-soft);
    margin-bottom: .8rem;
}
.modal__callout--quiet {
    background: rgba(245,239,228,.05);
    border-left-color: rgba(245,239,228,.25);
}
.modal__callout--quiet .modal__callout-label { color: rgba(245,239,228,.6); }

.modal__checklist { margin: 1rem 0 2rem; padding: 0; }
.modal__checklist li {
    padding: 12px 0 12px 36px;
    position: relative;
    border-bottom: 1px dashed rgba(245,239,228,.1);
    color: rgba(245,239,228,.9);
    font-size: 1rem;
}
.modal__checklist li::before {
    content: "";
    position: absolute;
    left: 0; top: 14px;
    width: 22px; height: 22px;
    border-radius: 50%;
    background: var(--c-ember);
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='3'><polyline points='5 13 10 18 19 7'/></svg>");
    background-size: 13px;
    background-position: center;
    background-repeat: no-repeat;
}

.modal__closing {
    margin-top: 2.5rem;
    padding: 24px 0;
    font-family: var(--ff-display);
    font-size: 1.3rem;
    font-style: italic;
    text-align: center;
    color: var(--c-cream-50);
    border-top: 1px solid rgba(245,239,228,.1);
    border-bottom: 1px solid rgba(245,239,228,.1);
}

.modal__footer {
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
    margin-top: 2rem;
    padding-top: 2rem;
    border-top: 1px solid rgba(245,239,228,.1);
    justify-content: flex-start;
}

.btn--ghost--dark {
    background: transparent;
    color: rgba(245,239,228,.8);
    border-color: rgba(245,239,228,.25);
}
.btn--ghost--dark:hover {
    background: rgba(245,239,228,.08);
    color: var(--c-cream-50);
}

@keyframes modal-fade { to { opacity: 1; } }
@keyframes modal-pop { to { opacity: 1; transform: none; } }

@media (max-width: 640px) {
    .modal { padding: 0; align-items: stretch; }
    .modal__dialog {
        max-height: 100vh;
        border-radius: 0;
        padding: 24px;
    }
    .modal__footer .btn { width: 100%; justify-content: center; }
}

/* =========================================================
   Scroll-Reveal Animation
   ========================================================= */
.reveal {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity .9s var(--ease-out), transform .9s var(--ease-out);
    will-change: opacity, transform;
}
.reveal.is-visible { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
    .reveal { opacity: 1; transform: none; transition: none; }
    *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; }
}

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width: 980px) {
    .intro__grid,
    .waldlaeufer__grid,
    .jagd__grid,
    .ueber__grid,
    .kontakt__grid { grid-template-columns: 1fr; }
    .waldlaeufer__pillars { grid-template-columns: 1fr 1fr; }
    .ueber__media-sub { width: 45%; bottom: -30px; right: -10px; }
    .galerie-grid { grid-template-columns: repeat(3, 1fr); }
    .footer__grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 780px) {
    .topbar__left { display: none; }
    .topbar__inner { justify-content: center; }

    .nav__menu {
        position: fixed;
        inset: 74px 0 0;
        background: var(--c-forest-900);
        flex-direction: column;
        gap: 0;
        padding: 30px 28px;
        color: var(--c-cream-100);
        transform: translateX(100%);
        transition: transform .35s var(--ease);
    }
    .nav__menu.is-open { transform: translateX(0); }
    .nav__menu a {
        color: var(--c-cream-100);
        padding: 18px 0;
        border-bottom: 1px solid rgba(245,239,228,.1);
        font-size: 1.1rem;
        width: 100%;
    }
    .nav__cta { margin-top: 20px; text-align: center; }
    .nav__toggle { display: flex; }

    .hero__content { padding: 70px 28px 100px; }
    .hero__meta { flex-wrap: wrap; gap: 1.5rem; }
    .hero__meta strong { font-size: 1.5rem; }

    .intro__badge { right: 10px; bottom: 20px; padding: 14px 16px; max-width: 220px; }
    .jagd__stack { grid-template-columns: 1fr; grid-template-areas: "a" "b" "c"; }
    .ueber__facts { flex-direction: column; gap: 1rem; }
    .galerie-grid { grid-template-columns: repeat(2, 1fr); }
    .galerie-item[style*="--span:2"] { grid-column: span 2; }
    .galerie-item[style*="--spanH:2"] { grid-row: auto; aspect-ratio: 1; }

    .termin { grid-template-columns: auto 1fr; }
    .termin .btn { grid-column: 1 / -1; justify-self: start; }

    .field--row { grid-template-columns: 1fr; }
    .kontakt__form { padding: 26px; }

    .footer__grid { grid-template-columns: 1fr; gap: 30px; padding-bottom: 30px; }
    .footer__bottom { flex-direction: column; text-align: center; }
}

@media (max-width: 480px) {
    body { font-size: 16px; }
    .container { padding: 0 20px; }
    .waldlaeufer__pillars { grid-template-columns: 1fr; }
    .hero__title { font-size: clamp(2.4rem, 10vw, 4rem); }
}
