:root{
  /* MJ-Brand-Palette: Beige · Olive-Skala · Dark Green · Akzent */
  --bone:#F6F6EE; --bone-2:#EFEDDE; --paper:#F2F0E2; --card:#FAFAF3;
  --forest:#2F2C19; --forest-2:#2C3A1A; --bark:#222C14;
  --moss:#4A5A22; --fern:#6F7530; --sage:#C5C199;
  --olive:#E2E0CB; --olive-2:#C5C199; --olive-3:#938B43;
  --ink:#1F2412; --muted:#6E6B4E; --brass:#D07A1D; --brass-2:#D9933F;
  --cream:#F6F6EE; --cream-2:#C5C199; --line:#E2E0CB; --line-d:rgba(246,246,238,.14);
  /* MJ Brand-Gradients (reusable backgrounds) */
  --mj-grad-1:linear-gradient(180deg,#2F2C19 0%,#8B8241 100%);
  --mj-grad-2:linear-gradient(180deg,#746D36 0%,#3C3C3C 100%);
  --mj-grad-radial-1:radial-gradient(ellipse at center,#8B8241 0%,#777038 25%,#443F22 75%,#2F2C19 100%);
  --mj-grad-radial-2:radial-gradient(ellipse at center,#F6F6EE 14%,#E2E0CB 53%,#C5C199 82%,#938B43 100%);
  --fd:'Farro','Hanken Grotesk',sans-serif; --fb:'Hanken Grotesk',system-ui,sans-serif; --fm:'JetBrains Mono',ui-monospace,monospace;
  --r:3px; --r-lg:6px; --pill:4px; --ease:cubic-bezier(.2,.7,.2,1);
  --shadow:0 34px 70px -42px rgba(30,22,8,.5);
}
*{box-sizing:border-box;margin:0;padding:0;}
[hidden]{display:none!important;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{background:var(--bone);color:var(--ink);font-family:var(--fb);font-size:15.5px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
::selection{background:var(--forest);color:var(--cream);}
:root{--topbar-h:0px;}
body.home{--topbar-h:34px;}
@media(max-width:600px){body.home{--topbar-h:30px;}}
html.tb-hidden body.home{--topbar-h:0px;}
.wrap{max-width:1280px;margin:0 auto;padding:0 clamp(1.6rem,6vw,2.4rem);}
h1,h2,h3{font-family:var(--fd);font-weight:700;line-height:1.08;letter-spacing:-.02em;}
.it{font-family:var(--fd);font-style:normal;font-weight:inherit;letter-spacing:inherit;}
.lab{font-family:var(--fm);font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);display:inline-flex;align-items:center;gap:.6rem;}
.lab::before{content:"";width:24px;height:1px;background:var(--brass);}
.lab .d{color:var(--brass);}
.tag{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--fm);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;padding:.4rem .8rem;border-radius:var(--pill);border:1px solid rgba(241,234,217,.3);color:var(--cream);background:rgba(20,16,9,.35);backdrop-filter:blur(6px);}
.btn{display:inline-flex;align-items:center;gap:.55rem;font-weight:600;font-size:.88rem;padding:.85rem 1.5rem;border-radius:var(--pill);border:1px solid transparent;cursor:pointer;transition:.3s var(--ease);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:inset 0 1px 0 rgba(255,255,255,.16);}
.btn svg{width:16px;height:16px;transition:.3s var(--ease);}
.btn:hover svg{transform:translateX(4px);}
.btn-brass{background:linear-gradient(180deg,rgba(184,138,60,.92),rgba(160,118,46,.86));color:#fff;border-color:rgba(255,236,200,.35);box-shadow:inset 0 1px 0 rgba(255,255,255,.28),0 8px 22px -10px rgba(120,86,20,.6);}
.btn-brass:hover{background:linear-gradient(180deg,rgba(160,118,46,.98),#8c6524);transform:translateY(-2px);}
.btn-moss{background:linear-gradient(180deg,rgba(72,92,40,.9),rgba(50,66,26,.84));color:var(--cream);border-color:rgba(138,152,104,.5);box-shadow:inset 0 1px 0 rgba(255,255,255,.18),0 8px 22px -10px rgba(30,40,12,.6);}
.btn-moss:hover{background:linear-gradient(180deg,rgba(86,107,44,.96),var(--fern));transform:translateY(-2px);}
.btn-dark{background:linear-gradient(180deg,rgba(42,54,28,.82),rgba(24,32,14,.8));color:var(--cream);border-color:rgba(138,152,104,.32);box-shadow:inset 0 1px 0 rgba(255,255,255,.12),0 8px 22px -10px rgba(0,0,0,.55);}
.btn-dark:hover{background:linear-gradient(180deg,var(--forest-2),var(--forest));transform:translateY(-2px);}
.btn-ghost{background:rgba(241,234,217,.1);border-color:rgba(241,234,217,.42);color:var(--cream);} .btn-ghost:hover{background:rgba(241,234,217,.92);color:var(--ink);border-color:transparent;}
.btn-light{background:linear-gradient(180deg,rgba(255,253,247,.96),rgba(241,234,217,.9));color:var(--ink);border-color:rgba(255,255,255,.6);box-shadow:inset 0 1px 0 rgba(255,255,255,.7),0 8px 22px -12px rgba(0,0,0,.4);} .btn-light:hover{background:#fff;transform:translateY(-2px);}
.btn-line{background:rgba(30,33,19,.04);border-color:rgba(30,33,19,.55);color:var(--ink);} .btn-line:hover{background:var(--ink);color:var(--cream);border-color:var(--ink);}
.lnk{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;font-size:.86rem;}
.lnk svg{width:15px;height:15px;transition:.2s;} .lnk:hover svg{transform:translateX(4px);}

body::after{content:"";position:fixed;inset:0;pointer-events:none;z-index:200;opacity:.04;mix-blend-mode:multiply;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

/* Header */
header{position:fixed;inset:0 0 auto 0;z-index:100;transition:transform .35s var(--ease),background .35s var(--ease),border-color .35s var(--ease);}
header.solid{background:rgba(233,231,210,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);}
html.nav-hidden header{transform:translateY(calc(-100% - var(--topbar-h)));}
html.nav-hidden .topbar{transform:translateY(-100%);}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:.6rem 0;}
.brand img{height:40px;width:auto;display:block;}
@media(max-width:1000px){.brand img{height:38px;}}
.brand .ld{display:none;}
header.solid .brand .ll{display:none;} header.solid .brand .ld{display:block;}
.nav-links{display:flex;gap:1.8rem;list-style:none;}
.nav-links a{font-size:.86rem;font-weight:500;color:var(--cream);opacity:.92;transition:.2s;position:relative;}
header.solid .nav-links a{color:var(--ink);opacity:.85;}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-4px;width:0;height:1px;background:var(--brass-2);transition:.25s;}
.nav-links a:hover::after{width:100%;}
.nav-right{display:flex;align-items:center;gap:.8rem;}
.nav-right .btn{background:rgba(241,234,217,.12);border-color:rgba(241,234,217,.5);color:var(--cream);}
.nav-right .btn:hover{background:var(--cream);color:var(--ink);}
header.solid .nav-right .btn{background:var(--moss);border-color:var(--moss);color:var(--cream);}
header.solid .nav-right .btn:hover{background:var(--fern);border-color:var(--fern);color:var(--cream);}
.burger{display:none;width:44px;height:44px;border:1px solid rgba(241,234,217,.4);border-radius:50%;background:transparent;color:var(--cream);cursor:pointer;align-items:center;justify-content:center;transition:background .2s,border-color .2s,color .2s;}
.burger:active{background:rgba(241,234,217,.08);}
header.solid .burger{border-color:var(--line);color:var(--ink);}
.burger svg{width:20px;height:20px;}
.nav-cta-li{display:none;}
@media(max-width:1000px){.nav-links{display:none;}.burger{display:flex;}
  .nav-right .btn{display:none;}
  .nav-links.open{display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:var(--forest);padding:1.4rem clamp(1.2rem,4vw,2.4rem) 1.6rem;gap:0;box-shadow:0 30px 80px -20px rgba(0,0,0,.55),inset 0 1px 0 rgba(241,234,217,.08);border-top:1px solid rgba(241,234,217,.12);animation:navSlide .38s cubic-bezier(.22,.61,.36,1);}
  .nav-links.open li{list-style:none;}
  .nav-links.open a{color:var(--cream)!important;opacity:1;padding:1.05rem 0;border-bottom:1px solid rgba(241,234,217,.1);font-family:var(--fd);font-size:1.25rem;font-weight:400;letter-spacing:-.01em;display:flex;align-items:center;justify-content:space-between;transition:color .2s;}
  .nav-links.open li:last-of-type:not(.nav-cta-li) a{border-bottom:0;}
  .nav-links.open a::after{content:"\203A";font-family:var(--fd);font-size:1.4rem;color:var(--brass-2);opacity:.7;transition:transform .2s;background:none;height:auto;width:auto;position:static;}
  .nav-links.open a:hover::after,.nav-links.open a:active::after{transform:translateX(4px);}
  .nav-links.open a:hover{color:var(--brass-2)!important;}
  .nav-links.open .nav-cta-li{display:block;margin-top:1.2rem;padding:0;}
  .nav-links.open .nav-cta-li a{display:flex;width:100%;align-items:center;justify-content:center;padding:.95rem 1.2rem;font-family:var(--fb);font-size:1rem;font-weight:600;letter-spacing:.01em;background:var(--brass);border:1px solid var(--brass);color:var(--cream)!important;border-radius:var(--r-pill,999px);}
  .nav-links.open .nav-cta-li a::after{display:none;}
  .nav-links.open .nav-cta-li a:hover{background:var(--brass-2);border-color:var(--brass-2);color:var(--cream)!important;}
}
@keyframes navSlide{from{opacity:0;transform:translateY(-12px);}to{opacity:1;transform:translateY(0);}}

/* HERO */
.hero{position:relative;height:100vh;height:100dvh;min-height:600px;display:flex;align-items:flex-end;overflow:hidden;}
.hero video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.hero .veil{position:absolute;inset:0;background:linear-gradient(to top,rgba(18,14,8,.7),rgba(18,14,8,.05) 50%,rgba(18,14,8,.32)),linear-gradient(105deg,rgba(18,14,8,.34),transparent 60%);}
@media(max-width:720px){.hero .veil{background:linear-gradient(to top,rgba(18,14,8,.95),rgba(18,14,8,.55) 22%,rgba(18,14,8,.18) 50%,rgba(18,14,8,.4)),linear-gradient(105deg,rgba(18,14,8,.34),transparent 60%);}}
.hero-in{position:relative;z-index:3;width:100%;padding-bottom:clamp(1.6rem,4vw,3rem);}
.hero .eyebrow{color:rgba(241,234,217,.8);margin-bottom:1.2rem;}
.hero h1{font-size:clamp(2.2rem,5.6vw,4.8rem);color:var(--cream);font-weight:700;letter-spacing:-.02em;white-space:nowrap;}
@media(max-width:720px){.hero h1{white-space:normal;}}
.hero p{color:rgba(241,234,217,.86);font-size:clamp(1rem,1.5vw,1.2rem);max-width:44ch;margin:1.2rem 0 1.8rem;}
.hero-cta{display:flex;gap:.8rem;flex-wrap:wrap;align-items:center;}
.finder{display:flex;gap:.4rem;background:rgba(243,238,226,.74);backdrop-filter:blur(16px) saturate(1.1);-webkit-backdrop-filter:blur(16px) saturate(1.1);border:1px solid rgba(255,255,255,.4);border-radius:var(--r-lg);padding:.45rem;align-items:center;margin-top:1.8rem;max-width:640px;box-shadow:inset 0 1px 0 rgba(255,255,255,.5),var(--shadow);}
.finder .ff{flex:1;display:flex;flex-direction:column;padding:.35rem .9rem;}
.finder .ff label{font-family:var(--fm);font-size:.54rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:.15rem;}
.finder .ff select{border:0;background:transparent;font:inherit;font-weight:600;font-size:.92rem;color:var(--ink);cursor:pointer;outline:none;}
.finder .sep{width:1px;align-self:stretch;background:var(--line);margin:.3rem 0;}
@media(max-width:600px){.finder{flex-wrap:wrap;}.finder .sep{display:none;}.finder .find{width:100%;justify-content:center;}}
.hero-rail{position:absolute;right:clamp(1rem,3vw,2.4rem);top:0;bottom:0;z-index:3;display:flex;flex-direction:column;justify-content:center;align-items:flex-end;}
.hero-rail span{writing-mode:vertical-rl;font-family:var(--fm);font-size:.6rem;letter-spacing:.28em;text-transform:uppercase;color:rgba(241,234,217,.55);}
.scrollcue{position:absolute;left:50%;bottom:1.4rem;transform:translateX(-50%);z-index:3;font-family:var(--fm);font-size:.58rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(241,234,217,.6);display:flex;flex-direction:column;align-items:center;gap:.5rem;}
.scrollcue i{width:1px;height:34px;background:linear-gradient(var(--brass-2),transparent);animation:cue 1.8s infinite;}
@keyframes cue{0%,100%{opacity:.2;transform:scaleY(.6);}50%{opacity:1;transform:scaleY(1);}}
@media(max-width:760px){.hero-rail,.scrollcue{display:none;}}
.hero-mute{position:absolute;right:clamp(1rem,3vw,2.4rem);top:clamp(6rem,11vh,7.5rem);z-index:4;width:42px;height:42px;border-radius:50%;background:rgba(18,14,8,.42);border:1px solid rgba(241,234,217,.22);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:rgba(241,234,217,.92);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .25s,border-color .25s,color .25s,transform .15s;font-family:var(--fm);}
.hero-mute:hover{background:rgba(168,124,50,.85);border-color:var(--brass);color:#fff;}
.hero-mute:active{transform:scale(.94);}
.hero-mute svg{width:18px;height:18px;display:none;}
.hero-mute[data-muted="true"] .ic-off{display:block;}
.hero-mute[data-muted="false"] .ic-on{display:block;}
@media(max-width:1000px){.hero-mute{top:clamp(5.6rem,12vh,7.2rem);right:clamp(1.4rem,4vw,2.4rem);width:40px;height:40px;}}
@media(max-width:760px){.hero-mute{width:36px;height:36px;}.hero-mute svg{width:15px;height:15px;}}

/* Bekannt durch */
.partners{padding:clamp(2rem,4vh,3rem) 0;border-bottom:1px solid var(--line);}
.partners .wrap{display:flex;align-items:center;gap:clamp(.9rem,2.2vw,2rem);flex-wrap:wrap;justify-content:center;}
.partners .pl{font-family:var(--fm);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);}
.partners img{height:34px;width:auto;filter:grayscale(1);opacity:.65;mix-blend-mode:multiply;transition:.3s;}
.partners img:hover{filter:grayscale(0);opacity:1;}

section{position:relative;}
.pad{padding:clamp(3.6rem,8vh,7rem) 0;}
.head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;margin-bottom:2.4rem;}
.head h2{font-size:clamp(1.9rem,3.6vw,3rem);max-width:18ch;margin-top:.8rem;}
.head .side{max-width:32ch;color:var(--muted);font-size:.95rem;}

/* Teaser / Versprechen split */
.split{display:grid;grid-template-columns:.95fr 1.05fr;gap:clamp(1.6rem,4vw,3.6rem);align-items:center;}
.split.split-r{grid-template-columns:1.05fr .95fr;}
.split.split-r .split-fig{order:2;}
.split-fig{position:relative;}
.split-fig img{width:100%;border-radius:var(--r-lg);box-shadow:var(--shadow);}
.split-fig .stamp{position:absolute;right:-14px;top:-14px;width:96px;height:96px;border-radius:50%;background:var(--brass);color:#fff;display:grid;place-items:center;text-align:center;font-family:var(--fd);font-size:.74rem;line-height:1.1;transform:rotate(7deg);box-shadow:var(--shadow);}
.stamp b{font-size:1.5rem;display:block;}
.split h2{font-size:clamp(1.9rem,3.6vw,3rem);margin:.8rem 0 1.1rem;}
.split p{color:var(--muted);font-size:1rem;margin-bottom:1rem;max-width:46ch;}
.ipoints{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:.6rem 1.4rem;margin:1.3rem 0 1.6rem;}
.ipoints li{display:flex;gap:.5rem;align-items:flex-start;font-size:.92rem;}
.ipoints svg{width:17px;height:17px;color:var(--brass);flex:none;margin-top:.15rem;}
.split .row{display:flex;gap:.7rem;flex-wrap:wrap;}
@media(max-width:840px){.split{grid-template-columns:1fr;}.split-fig{max-width:460px;}.ipoints{grid-template-columns:1fr;}}

/* Dozenten Slider (Pfeil-Nav, kein Drag) */
.slider-nav{display:flex;gap:.5rem;}
.snav{width:44px;height:44px;border:1px solid var(--line);border-radius:50%;background:var(--card);color:var(--ink);display:grid;place-items:center;cursor:pointer;transition:.2s;}
.snav:hover{background:var(--forest);color:var(--cream);border-color:var(--forest);}
.snav svg{width:18px;height:18px;}
.snav[disabled]{opacity:.35;cursor:default;}
.doz-track{display:flex;gap:1rem;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;scrollbar-width:none;padding-bottom:.3rem;}
.doz-track::-webkit-scrollbar{display:none;}
.doz{flex:0 0 clamp(260px,30%,320px);scroll-snap-align:start;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.5rem;}
.doz .av{width:58px;height:58px;border-radius:50%;background:var(--forest);color:var(--cream);display:grid;place-items:center;font-family:var(--fd);font-size:1.4rem;margin-bottom:1rem;}
.doz h3{font-size:1.2rem;}
.doz .role{font-family:var(--fm);font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;color:var(--brass);margin:.2rem 0 .7rem;}
.doz p{color:var(--muted);font-size:.88rem;}

/* Kurse cards */
.kurse{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:1rem;}
.kc{position:relative;border-radius:var(--r-lg);overflow:hidden;min-height:clamp(360px,40vw,500px);display:flex;align-items:flex-end;box-shadow:var(--shadow);}
.kc img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:1s var(--ease);}
.kc:hover img{transform:scale(1.06);}
.kc::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(18,14,8,.9),rgba(18,14,8,.05) 60%);}
.kc .tag{position:absolute;top:1rem;left:1rem;z-index:3;}
.kc .c{position:relative;z-index:2;padding:1.5rem;color:var(--cream);width:100%;}
.kc h3{font-size:clamp(1.4rem,2vw,1.9rem);color:#fff;margin-bottom:.3rem;}
.kc .pr{font-family:var(--fm);font-size:.7rem;letter-spacing:.05em;color:var(--cream-2);}
.kc .reveal-row{display:flex;gap:.5rem;max-height:0;overflow:hidden;opacity:0;transition:.45s var(--ease);}
.kc:hover .reveal-row{max-height:80px;opacity:1;margin-top:1rem;}
.kc .reveal-row .btn{padding:.6rem 1.1rem;font-size:.8rem;}
@media(max-width:860px){.kurse{grid-template-columns:1fr;}.kc{min-height:320px;}.kc .reveal-row{max-height:80px;opacity:1;margin-top:1rem;}}

/* Finanzierung Banner */
.banner{position:relative;overflow:hidden;color:var(--cream);text-align:center;border-radius:var(--r-lg);}
.banner .bg{position:absolute;inset:0;} .banner .bg img{width:100%;height:100%;object-fit:cover;}
.banner .bg::after{content:"";position:absolute;inset:0;background:rgba(18,14,8,.62);}
.banner .in{position:relative;z-index:2;padding:clamp(2.6rem,6vw,4.4rem) 1.5rem;}
.banner h2{font-size:clamp(1.8rem,3.6vw,2.8rem);color:#fff;}
.banner p{color:rgba(241,234,217,.85);max-width:42ch;margin:.9rem auto 1.6rem;}

/* Kursfilter / Termine – grünes Waldband */
.termine{background:var(--forest);color:var(--cream);position:relative;overflow:hidden;}
.termine .bgleaf{position:absolute;inset:0;pointer-events:none;opacity:.5;background:
  radial-gradient(120% 80% at 100% 0%,rgba(86,107,44,.35),transparent 60%),
  radial-gradient(90% 70% at 0% 100%,rgba(56,73,29,.55),transparent 55%);}
.termine .wrap{position:relative;z-index:1;}
.termine .head h2{color:var(--cream);}
.termine .lab{color:var(--cream-2);} .termine .lab::before{background:var(--brass-2);} .termine .lab .d{color:var(--brass-2);}
.termine .side{color:rgba(241,234,217,.72);font-size:.95rem;}
.termine .side b{font-family:var(--fd);font-weight:700;color:var(--cream);font-size:1.05em;}
.tfilter{display:flex;flex-wrap:wrap;gap:.4rem;align-items:flex-end;background:rgba(241,234,217,.06);border:1px solid var(--line-d);border-radius:var(--r-lg);padding:.55rem;margin-bottom:2rem;}
.tf{flex:1;min-width:170px;display:flex;flex-direction:column;padding:.45rem .95rem;}
.tf label{font-family:var(--fm);font-size:.55rem;letter-spacing:.14em;text-transform:uppercase;color:var(--cream-2);margin-bottom:.35rem;}
.tf .sel{position:relative;}
.tf .sel::after{content:"";position:absolute;right:2px;top:50%;width:7px;height:7px;border-right:1.5px solid var(--brass-2);border-bottom:1.5px solid var(--brass-2);transform:translateY(-65%) rotate(45deg);pointer-events:none;}
.tf select{appearance:none;-webkit-appearance:none;width:100%;border:0;background:transparent;font:inherit;font-weight:600;font-size:.95rem;color:var(--cream);cursor:pointer;outline:none;padding-right:1.2rem;}
.tf select option{color:#1E2113;}
.rt-reset{display:inline-flex;align-items:center;gap:.45rem;background:transparent;border:1px solid var(--line-d);color:var(--cream);font-family:var(--fm);font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;padding:.85rem 1.1rem;margin:.2rem;border-radius:var(--pill);cursor:pointer;transition:.25s var(--ease);}
.rt-reset:hover{background:rgba(241,234,217,.1);border-color:var(--brass-2);}
.rt-reset svg{width:14px;height:14px;}
.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;}
@media(max-width:900px){.tgrid{grid-template-columns:1fr;}}
.result-card{background:rgba(241,234,217,.05);border:1px solid var(--line-d);border-radius:var(--r-lg);padding:1.5rem 1.4rem;display:flex;flex-direction:column;gap:.95rem;transition:.3s var(--ease);animation:rIn .5s var(--ease) backwards;}
.result-card:hover{background:rgba(241,234,217,.09);transform:translateY(-3px);border-color:rgba(200,164,88,.45);}
.result-card.is-full{opacity:.55;}
.r-top{display:flex;justify-content:space-between;align-items:center;gap:.6rem;}
.r-type{font-family:var(--fm);font-size:.56rem;letter-spacing:.14em;text-transform:uppercase;padding:.32rem .7rem;border-radius:var(--pill);border:1px solid rgba(138,152,104,.5);color:var(--sage);}
.r-type.t-online{color:var(--brass-2);border-color:rgba(200,164,88,.5);}
.r-type.t-premium{color:#fff;background:var(--moss);border-color:transparent;}
.r-status{font-family:var(--fm);font-size:.55rem;letter-spacing:.1em;text-transform:uppercase;color:var(--brass-2);}
.result-card h3{font-family:var(--fd);font-weight:700;font-size:1.18rem;line-height:1.15;color:var(--cream);}
.r-meta{display:flex;flex-direction:column;gap:.5rem;font-size:.84rem;color:rgba(241,234,217,.8);}
.r-meta span{display:flex;align-items:flex-start;gap:.55rem;}
.r-meta svg{width:15px;height:15px;color:var(--brass-2);flex-shrink:0;margin-top:.1rem;}
.r-foot{margin-top:auto;display:flex;flex-direction:column;gap:.85rem;border-top:1px solid var(--line-d);padding-top:1rem;}
.r-price{font-family:var(--fd);font-weight:700;font-size:1.3rem;color:var(--cream);}
.r-actions{display:flex;flex-direction:column;gap:.55rem;}
.r-actions .btn{justify-content:center;width:100%;padding:.7rem 1rem;font-size:.82rem;}
.link-arrow{display:inline-flex;align-items:center;gap:.45rem;font-weight:600;font-size:.82rem;color:var(--brass-2);justify-content:center;}
.link-arrow svg{width:14px;height:14px;transition:.2s;} .link-arrow:hover svg{transform:translateX(4px);}
.rt-hidden{display:none!important;}
.results-empty{grid-column:1/-1;text-align:center;padding:3rem 1rem;color:rgba(241,234,217,.7);}
.results-empty svg{width:36px;height:36px;margin:0 auto 1rem;color:var(--brass-2);display:block;}
.tactions{display:flex;justify-content:center;gap:.8rem;margin-top:1.8rem;}
.termine .btn-ghost{border-color:rgba(241,234,217,.4);color:var(--cream);}
.termine .btn-ghost:hover{background:var(--cream);color:var(--ink);}
@keyframes rIn{from{opacity:0;transform:translateY(14px);}to{opacity:1;transform:none;}}

/* Termine: Interaktiver Monatskalender mit Detail-Panel */
.kal-legend{display:flex;justify-content:center;flex-wrap:wrap;gap:1.4rem;font-family:var(--fm);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--cream-2);margin:1.1rem auto 2rem;}
.kal-legend span{display:inline-flex;align-items:center;gap:.5rem;}
.kal-legend i{width:10px;height:10px;border-radius:50%;display:inline-block;}
.kal-legend i.praesenz{background:var(--brass);}
.kal-legend i.online{background:var(--fern);}
.kal-legend i.jugend{background:var(--sage);}
.kal-legend i.cancel{background:transparent;border:1px dashed rgba(241,234,217,.55);}

.kal-app{display:grid;grid-template-columns:1.05fr .95fr;gap:1.8rem;align-items:stretch;}
.kal-cal{background:rgba(241,234,217,.05);border:1px solid var(--line-d);border-radius:var(--r-lg);padding:1.4rem 1.4rem 1.6rem;}
.kal-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.2rem;}
.kal-nb{width:38px;height:38px;border-radius:50%;background:rgba(241,234,217,.08);border:1px solid var(--line-d);color:var(--cream);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.2s var(--ease);}
.kal-nb:hover:not(:disabled){background:var(--cream);color:var(--ink);border-color:var(--cream);}
.kal-nb:disabled{opacity:.28;cursor:not-allowed;}
.kal-nb svg{width:18px;height:18px;}
.kal-mlabel{font-family:var(--fd);font-weight:500;font-size:1.4rem;color:var(--cream);}
.kal-mlabel .y{font-family:var(--fm);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--cream-2);margin-left:.5rem;}
.kal-cgrid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;}
.kal-cgrid .wd{font-family:var(--fm);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--cream-2);text-align:center;padding:0 0 .55rem;opacity:.7;}
.kal-cgrid .d{position:relative;aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:.95rem;color:var(--cream);border-radius:4px;background:rgba(241,234,217,.03);transition:background .15s var(--ease),color .15s var(--ease);}
.kal-cgrid .d.out{color:rgba(241,234,217,.18);background:transparent;}
.kal-cgrid .d.course{cursor:pointer;background:rgba(241,234,217,.08);}
.kal-cgrid .d.course:hover{background:rgba(241,234,217,.16);}
.kal-cgrid .d.course.sel{background:var(--brass);color:#fff;box-shadow:0 0 0 1px var(--brass);}
.kal-cgrid .d.course.sel .bars i{filter:brightness(1.5);}
.kal-cgrid .d .bars{position:absolute;left:6px;right:6px;bottom:5px;display:flex;gap:2px;}
.kal-cgrid .d .bars i{flex:1;height:3px;border-radius:2px;}
.kal-cgrid .d .bars i.praesenz{background:var(--brass);}
.kal-cgrid .d .bars i.online{background:var(--fern);}
.kal-cgrid .d .bars i.jugend{background:var(--sage);}
.kal-cgrid .d.cancel-only{text-decoration:line-through;text-decoration-color:rgba(241,234,217,.5);color:rgba(241,234,217,.6);}
.kal-cgrid .d.cancel-only .bars i{opacity:.4;}

.kal-detail{background:var(--card);color:var(--ink);border-radius:var(--r-lg);padding:1.7rem 1.9rem 1.5rem;display:flex;flex-direction:column;gap:.55rem;min-height:380px;}
.kal-detail .top{display:flex;justify-content:space-between;align-items:center;gap:.5rem;}
.kal-detail .chip{display:inline-flex;align-items:center;gap:.45rem;font-family:var(--fm);font-size:.58rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);background:rgba(168,124,50,.16);padding:.36rem .7rem;border-radius:var(--pill);}
.kal-detail .chip i{width:8px;height:8px;border-radius:50%;display:inline-block;}
.kal-detail .chip i.praesenz{background:var(--brass);}
.kal-detail .chip i.online{background:var(--fern);}
.kal-detail .chip i.jugend{background:var(--sage);}
.kal-detail .ctr{display:flex;align-items:center;gap:.5rem;}
.kal-detail .ctr-btn{width:30px;height:30px;border-radius:50%;background:transparent;border:1px solid var(--line);color:var(--ink);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.2s var(--ease);}
.kal-detail .ctr-btn:hover:not(:disabled){background:var(--ink);color:var(--cream);border-color:var(--ink);}
.kal-detail .ctr-btn:disabled{opacity:.3;cursor:not-allowed;}
.kal-detail .ctr-btn svg{width:14px;height:14px;}
.kal-detail .ctr .num{font-family:var(--fm);font-size:.62rem;letter-spacing:.1em;color:var(--muted);}
.kal-detail h3{font-family:var(--fd);font-size:1.5rem;color:var(--forest);line-height:1.15;margin-top:.5rem;letter-spacing:-.01em;}
.kal-detail .dates{font-family:var(--fd);font-style:italic;font-weight:300;font-size:1.1rem;color:var(--moss);margin-top:.15rem;}
.kal-detail .meta{display:flex;flex-wrap:wrap;gap:.45rem 1rem;font-size:.85rem;color:var(--muted);margin-top:.45rem;}
.kal-detail .meta b{color:var(--ink);font-weight:600;}
.kal-detail .meta .bad{color:#b14d2a;font-weight:600;}
.kal-detail .desc{color:var(--muted);font-size:.92rem;line-height:1.55;margin-top:.5rem;}
.kal-detail .actions{display:flex;gap:.6rem;margin-top:auto;flex-wrap:wrap;padding-top:1.1rem;}
.kal-detail .actions .btn{flex:1 1 160px;justify-content:center;}
.kal-detail .actions .btn.disabled{pointer-events:none;opacity:.45;}
.kal-detail .empty{color:var(--muted);font-size:.95rem;line-height:1.6;text-align:center;margin:auto 0;}
.kal-detail .empty b{display:block;font-family:var(--fd);font-weight:600;color:var(--forest);font-size:1.1rem;margin-bottom:.4rem;}

@media(max-width:900px){.kal-app{grid-template-columns:1fr;}.kal-detail{min-height:0;}}
@media(max-width:520px){.kal-mlabel{font-size:1.2rem;}.kal-cgrid .d{font-size:.85rem;}}

/* Eindrücke – Accordion-Galerie */
.acc{display:flex;gap:6px;height:clamp(340px,46vw,520px);}
.acc-item{position:relative;flex:1;border-radius:var(--r-lg);overflow:hidden;cursor:pointer;transition:flex .6s var(--ease);min-width:40px;}
.acc-item img{width:100%;height:100%;object-fit:cover;}
.acc-item::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(18,14,8,.8),transparent 55%);opacity:.85;}
.acc-item.active{flex:4.5;}
.acc-item .cap{position:absolute;left:1.2rem;bottom:1.2rem;right:1.2rem;z-index:2;color:var(--cream);opacity:0;transform:translateY(8px);transition:.4s var(--ease) .15s;white-space:nowrap;}
.acc-item.active .cap{opacity:1;transform:none;}
.acc-item .cap b{font-family:var(--fd);font-size:1.4rem;display:block;}
.acc-item .cap span{font-family:var(--fm);font-size:.6rem;letter-spacing:.08em;text-transform:uppercase;color:var(--cream-2);}
.acc-item .idx{position:absolute;top:1rem;left:1rem;z-index:2;font-family:var(--fm);font-size:.6rem;letter-spacing:.1em;color:var(--cream);opacity:.7;}
@media(max-width:760px){.acc{flex-direction:column;height:auto;}.acc-item{flex:none;height:160px;}.acc-item.active{height:300px;}.acc-item .cap{white-space:normal;opacity:1;transform:none;}}

/* 4 Schritte als gewundener Wanderpfad (SVG) mit Scroll-Animation */
.ablaufpfad{position:relative;max-width:940px;margin:2rem auto 0;}
.ap-svg{position:absolute;inset:0;width:100%;height:100%;overflow:visible;pointer-events:none;z-index:0;}
.ap-base{fill:none;stroke:rgba(120,98,50,.38);stroke-width:2.4;stroke-dasharray:1 9;stroke-linecap:round;}
.ap-prog{fill:none;stroke:var(--brass);stroke-width:3.4;stroke-linecap:round;}
.ap-nodes{position:absolute;inset:0;pointer-events:none;z-index:3;}
.ap-node{position:absolute;width:44px;height:44px;border-radius:50%;background:var(--paper);border:2px solid var(--cream-2);color:var(--muted);font-family:var(--fd);font-weight:500;font-size:1.02rem;display:flex;align-items:center;justify-content:center;transform:translate(-50%,-50%) scale(.84);transition:.5s var(--ease);box-shadow:0 6px 18px -10px rgba(30,22,8,.5);}
.ap-node.on{border-color:var(--brass);color:var(--brass);background:#fff;transform:translate(-50%,-50%) scale(1);box-shadow:0 0 0 6px rgba(168,124,50,.14),0 10px 22px -10px rgba(120,86,20,.5);}
.ap-steps{position:relative;z-index:1;}
.ap-step{position:relative;min-height:152px;}
.ap-card{position:absolute;top:50%;width:33%;transform:translateY(-50%);background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.2rem 1.4rem;box-shadow:0 22px 48px -36px rgba(30,22,8,.55);transition:opacity .6s var(--ease),transform .6s var(--ease);}
.ap-step.left .ap-card{left:0;text-align:right;}
.ap-step.right .ap-card{right:0;text-align:left;}
.ap-card h3{font-size:1.2rem;margin-bottom:.34rem;}
.ap-card p{color:var(--muted);font-size:.9rem;line-height:1.55;}
.ablaufpfad.ready .ap-card{opacity:0;}
.ablaufpfad.ready .ap-step.left .ap-card{transform:translateY(-50%) translateX(-24px);}
.ablaufpfad.ready .ap-step.right .ap-card{transform:translateY(-50%) translateX(24px);}
.ablaufpfad.ready .ap-step.in .ap-card{opacity:1;transform:translateY(-50%);}
@media(max-width:760px){
  .ablaufpfad{max-width:520px;}
  .ap-step{min-height:0;margin-bottom:1.2rem;}
  .ap-card{position:relative;top:auto;width:auto;margin-left:54px;transform:none!important;text-align:left!important;}
  .ablaufpfad.ready .ap-card{opacity:0;transform:translateX(16px)!important;}
  .ablaufpfad.ready .ap-step.in .ap-card{opacity:1;transform:none!important;}
}

/* Stimmen */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;}
.q{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.6rem;display:flex;flex-direction:column;}
.q .st{color:var(--brass);letter-spacing:2px;margin-bottom:.8rem;}
.q blockquote{font-family:var(--fb);font-size:15.5px;line-height:1.6;margin-bottom:1rem;color:var(--ink);}
.q .by{display:flex;align-items:center;gap:.7rem;margin-top:auto;}
.q .by b{display:block;font-size:.82rem;} .q .by span{font-family:var(--fm);font-size:.55rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);}
@media(max-width:820px){.quotes{grid-template-columns:1fr;max-width:480px;margin:0 auto;}}

/* FAQ */
.faq{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:.6rem;}
.faq details{background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;}
.faq summary{list-style:none;cursor:pointer;padding:1rem 1.2rem;font-weight:600;display:flex;justify-content:space-between;gap:1rem;align-items:center;font-size:.96rem;}
.faq summary::-webkit-details-marker{display:none;}
.faq summary .pm{position:relative;width:14px;height:14px;flex:none;}
.faq summary .pm::before,.faq summary .pm::after{content:"";position:absolute;background:var(--brass);transition:.25s;}
.faq summary .pm::before{top:6px;left:0;width:14px;height:2px;}
.faq summary .pm::after{top:0;left:6px;width:2px;height:14px;}
.faq details[open] summary .pm::after{transform:scaleY(0);}
.faq details p{padding:0 1.2rem 1.1rem;color:var(--muted);font-size:.92rem;}

/* Werte */
.werte{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;}
.wert .ic{width:44px;height:44px;border-radius:50%;background:var(--bone-2);display:grid;place-items:center;color:var(--brass);margin-bottom:.9rem;}
.wert .ic svg{width:22px;height:22px;}
.wert h3{font-size:1.1rem;margin-bottom:.3rem;}
.wert p{color:var(--muted);font-size:.85rem;}
@media(max-width:900px){.werte{grid-template-columns:1fr 1fr;}}

/* STÄRKEN — Feature Tabs */
.staerken-lead{max-width:620px;margin:1rem 0 0;color:var(--muted);font-size:1rem;line-height:1.55;}

.st-tabs{display:flex;flex-wrap:wrap;gap:.2rem;margin:2.4rem 0 0;border-bottom:1px solid var(--line);}
.st-tab{appearance:none;border:none;background:transparent;cursor:pointer;padding:1rem 0;margin-right:3rem;font-family:var(--fm);font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;font-weight:600;color:var(--muted);position:relative;transition:color .25s var(--ease);}
.st-tab::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--brass);transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease);}
.st-tab:hover{color:var(--ink);}
.st-tab.active{color:var(--brass);}
.st-tab.active::after{transform:scaleX(1);}

.st-panes{position:relative;margin-top:2.4rem;}
.st-pane{display:none;grid-template-columns:1.05fr 1fr;gap:clamp(1.6rem,3.5vw,3rem);align-items:center;}
.st-pane.active{display:grid;animation:stPaneIn .55s var(--ease);}
.st-fig{position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:4/3;background:var(--bone-2);box-shadow:0 30px 60px -28px rgba(18,14,8,.45);}
.st-fig img{width:100%;height:100%;object-fit:cover;display:block;}
.st-info{padding:.4rem 0;}
.st-info h3{font-family:var(--fd);font-size:clamp(1.5rem,2.4vw,2.1rem);line-height:1.1;margin-bottom:1.1rem;}
.st-info p{font-size:1rem;line-height:1.65;color:var(--ink);max-width:46ch;}

@keyframes stPaneIn{
  from{opacity:0;transform:translateY(10px);}
  to{opacity:1;transform:translateY(0);}
}

@media(max-width:820px){
  .st-tabs{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;justify-content:flex-start;}
  .st-tab{flex-shrink:0;padding:.9rem 1rem;font-size:.62rem;}
  .st-pane{grid-template-columns:1fr;}
  .st-fig{aspect-ratio:16/10;}
}

/* Newsletter */
.news{background:var(--forest);color:var(--cream);border-radius:var(--r-lg);text-align:center;padding:clamp(2.4rem,5vw,4rem) 1.5rem;}
.news h2{color:#fff;font-size:clamp(1.7rem,3.2vw,2.6rem);}
.news p{color:var(--cream-2);max-width:42ch;margin:.8rem auto 1.6rem;}
.news form{display:flex;gap:.5rem;max-width:440px;margin:0 auto;flex-wrap:wrap;}
.news input{flex:1;min-width:200px;padding:.85rem 1rem;border:1px solid var(--line-d);border-radius:var(--r);background:rgba(241,234,217,.08);color:var(--cream);font:inherit;font-size:.9rem;}
.news input::placeholder{color:var(--cream-2);}
.news-socials{display:flex;justify-content:center;flex-wrap:wrap;gap:.7rem;margin-top:1.6rem;}
.ns-link{display:inline-flex;align-items:center;gap:.55rem;padding:.7rem 1.15rem;background:rgba(241,234,217,.1);border:1px solid rgba(241,234,217,.32);border-radius:var(--pill);color:var(--cream);font-size:.86rem;font-weight:500;transition:.25s var(--ease);}
.ns-link:hover{background:var(--cream);color:var(--ink);border-color:transparent;transform:translateY(-2px);}
.ns-link svg{width:18px;height:18px;}

footer{background:var(--bark);color:var(--cream-2);padding:3rem 0 2rem;}
.foot{display:flex;justify-content:space-between;gap:2rem;flex-wrap:wrap;}
.foot .about{max-width:28ch;} .foot .about img{height:38px;filter:brightness(0) invert(1);opacity:.9;margin-bottom:.8rem;}
.foot .about p{font-size:.88rem;}
.foot .col h4{font-family:var(--fm);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--brass-2);margin-bottom:.7rem;}
.foot .col a{display:block;font-size:.88rem;color:var(--cream-2);padding:.2rem 0;} .foot .col a:hover{color:#fff;}
.foot-bottom{margin-top:2.2rem;padding-top:1.3rem;border-top:1px solid var(--line-d);font-size:.78rem;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;}

/* Waldpfad-Navigation (geschwungener Pfad, zeigt Position) */
.trail{position:fixed;left:26px;top:50%;transform:translateY(-50%);height:64vh;width:78px;z-index:90;pointer-events:none;}
.trail svg{position:absolute;inset:0;width:78px;height:100%;overflow:visible;}
.trail-title{position:absolute;left:0;top:0;bottom:0;width:16px;display:flex;align-items:center;justify-content:center;writing-mode:vertical-rl;transform:rotate(180deg);white-space:nowrap;font-family:var(--fm);font-size:.64rem;letter-spacing:.28em;text-transform:uppercase;color:var(--brass);opacity:.95;pointer-events:none;font-weight:500;}
.trail-base{fill:none;stroke:rgba(168,124,50,.34);stroke-width:6;stroke-linecap:round;}
.trail-prog{fill:none;stroke:var(--fern);stroke-width:2.2;stroke-linecap:round;}
.trail-node{position:absolute;width:11px;height:11px;border-radius:50%;background:var(--bone);border:1.5px solid var(--sage);transform:translate(-50%,-50%);cursor:pointer;pointer-events:auto;transition:transform .2s,border-color .2s,background .2s;}
.trail-node:hover{border-color:var(--fern);transform:translate(-50%,-50%) scale(1.3);}
.trail-node.passed{border-color:var(--fern);background:var(--fern);}
.trail-node.active{border-color:var(--fern);background:var(--fern);box-shadow:0 0 0 4px rgba(86,107,44,.22);}
.trail-label{position:absolute;left:20px;top:50%;transform:translateY(-50%);white-space:nowrap;font-family:var(--fm);font-size:.55rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink);background:var(--card);border:1px solid var(--line);border-radius:3px;padding:.22rem .5rem;opacity:0;transition:opacity .2s;pointer-events:none;box-shadow:0 4px 12px -6px rgba(0,0,0,.3);}
.trail-node:hover .trail-label,.trail-node.active .trail-label{opacity:1;}
.trail-marker{position:absolute;width:15px;height:15px;border-radius:50%;background:var(--fern);transform:translate(-50%,-50%);box-shadow:0 0 0 4px rgba(86,107,44,.28),0 2px 8px rgba(0,0,0,.35);z-index:2;}
.trail-marker::after{content:"";position:absolute;inset:4.5px;border-radius:50%;background:var(--cream);}
@media(max-width:1439px){.trail{display:none;}}

.reveal{opacity:0;transform:translateY(26px);transition:.8s var(--ease);}
.reveal.in{opacity:1;transform:none;}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;}.scrollcue i{animation:none;}}

/* ============================================================
   SUB-PAGES (Unterseiten: Kurse, Workshops, Magazin, Seiten …)
   ============================================================ */
.skip-link{position:absolute;left:-999px;top:0;background:var(--forest);color:var(--cream);padding:.6rem 1rem;z-index:300;}
.skip-link:focus{left:.5rem;top:.5rem;}
.eyebrow{font-family:var(--fm);font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--brass);display:inline-block;}
.muted{color:var(--muted);}
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--brass);z-index:101;}
.to-top{position:fixed;right:1.2rem;bottom:5.4rem;width:46px;height:46px;border-radius:50%;background:var(--forest);color:var(--cream);border:0;display:grid;place-items:center;cursor:pointer;opacity:0;visibility:hidden;transform:translateY(10px);transition:.3s var(--ease);z-index:80;box-shadow:var(--shadow);}
.to-top.show{opacity:1;visibility:visible;transform:none;}
.to-top svg{width:20px;height:20px;}

/* Page-Hero (Banner mit Bild) */
.page-hero{position:relative;min-height:clamp(460px,64vh,660px);display:flex;align-items:flex-end;overflow:hidden;color:var(--cream);}
.page-hero-bg{position:absolute;inset:0;} .page-hero-bg img{width:100%;height:100%;object-fit:cover;}
.page-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(18,14,8,.92),rgba(18,14,8,.35) 62%,rgba(18,14,8,.55));}
.page-hero .wrap{position:relative;z-index:2;width:100%;padding-top:7rem;padding-bottom:clamp(2rem,4vw,3.2rem);}
.page-hero .inner{max-width:760px;}
.page-hero .eyebrow{color:var(--brass-2);}
.page-hero h1{font-size:clamp(2.1rem,4.8vw,3.7rem);color:var(--cream);margin:.7rem 0 .8rem;}
.page-hero p{color:rgba(241,234,217,.86);font-size:clamp(1rem,1.4vw,1.15rem);max-width:54ch;}
.breadcrumb{font-family:var(--fm);font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);display:flex;gap:.5rem;align-items:center;flex-wrap:nowrap;white-space:nowrap;overflow-x:auto;-ms-overflow-style:none;scrollbar-width:none;}
.breadcrumb::-webkit-scrollbar{display:none;}
.breadcrumb a{color:var(--muted);} .breadcrumb a:hover{color:var(--ink);}
.breadcrumb .sep{opacity:.5;} .breadcrumb .current{color:var(--brass);}
.breadcrumb-bar{padding:1rem 0;background:var(--bone);border-bottom:1px solid var(--line);}

/* Formulare + Kontakt-Layout (2-Funnel) */
.contact-grid{display:grid;grid-template-columns:1.55fr .85fr;gap:clamp(1.6rem,3.5vw,3rem);align-items:start;}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr;}}
.form{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(1.4rem,3vw,2.2rem);}
.form .h3{font-family:var(--fd);font-weight:700;font-size:1.4rem;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem 1.1rem;}
@media(max-width:560px){.form-row{grid-template-columns:1fr;}}
.field{display:flex;flex-direction:column;min-width:0;}
.field.full{grid-column:1/-1;}
.field>label{font-family:var(--fm);font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:.4rem;font-weight:500;}
.field input,.field select,.field textarea{font:inherit;font-size:.95rem;color:var(--ink);background:var(--bone);border:1px solid var(--line);border-radius:var(--r);padding:.7rem .85rem;outline:none;transition:.2s;width:100%;}
.field textarea{min-height:120px;resize:vertical;}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--fern);box-shadow:0 0 0 3px rgba(86,107,44,.15);}
.field .req{color:var(--brass);}
.field .err{display:none;font-size:.78rem;color:#a23b2b;margin-top:.35rem;}
.field.invalid input,.field.invalid select,.field.invalid textarea{border-color:#c0492f;background:#fbf1ee;}
.field.invalid .err{display:block;}
.field .check{display:flex;gap:.6rem;align-items:flex-start;font-family:var(--fb);font-size:.88rem;font-weight:400;letter-spacing:0;text-transform:none;color:var(--ink);cursor:pointer;margin-bottom:0;}
.field .check input{width:auto;margin-top:.2rem;flex:none;}
.field .check a{text-decoration:underline;}
.form-note{font-size:.78rem;color:var(--muted);margin-top:.9rem;}
.note-box{display:flex;gap:.7rem;background:var(--bone-2);border:1px solid var(--line);border-radius:var(--r);padding:.9rem 1rem;font-size:.86rem;color:var(--ink);line-height:1.5;}
.note-box svg{width:20px;height:20px;color:var(--brass);flex:none;margin-top:.1rem;}
.form-success{display:none;text-align:center;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(2rem,4vw,3rem);}
.form-success.show{display:block;animation:rIn .5s var(--ease);}
.form-success .ok{width:64px;height:64px;border-radius:50%;background:var(--fern);color:var(--cream);display:grid;place-items:center;margin:0 auto 1rem;}
.form-success .ok svg{width:30px;height:30px;}
.contact-aside{display:flex;flex-direction:column;gap:1rem;}
.contact-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.4rem;}
.contact-card h3{font-size:1.1rem;margin-bottom:.5rem;}
.contact-item{display:flex;gap:.6rem;align-items:center;font-size:.9rem;margin-top:.55rem;color:var(--ink);}
.contact-item svg{width:18px;height:18px;color:var(--brass);flex:none;}
.contact-item a:hover{color:var(--fern);}

/* Kurs-/Workshop-Detail */
.kd-grid{display:grid;grid-template-columns:1.55fr .9fr;gap:clamp(1.6rem,3.5vw,3rem);align-items:start;}
@media(max-width:900px){.kd-grid{grid-template-columns:1fr;}}
.prose>p{color:var(--ink);margin-bottom:1rem;font-size:1rem;}
.prose h2{font-size:clamp(1.45rem,2.6vw,2rem);margin:2rem 0 .8rem;}
.prose h3{font-size:1.2rem;margin:1.4rem 0 .5rem;}
.prose ul.ticks{list-style:none;display:flex;flex-direction:column;gap:.6rem;margin:1rem 0;}
.prose ul.ticks li{display:flex;gap:.6rem;align-items:flex-start;font-size:.96rem;}
.prose ul.ticks li svg{width:18px;height:18px;color:var(--fern);flex:none;margin-top:.2rem;}
.facts{display:flex;flex-wrap:wrap;gap:1.4rem 2.6rem;padding:1.3rem 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin:1.5rem 0;}
.fact{display:flex;flex-direction:column;gap:.15rem;} .fact b{font-family:var(--fd);font-weight:700;font-size:1.25rem;} .fact span{font-family:var(--fm);font-size:.56rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);}
.pricebox{position:sticky;top:88px;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.6rem;box-shadow:var(--shadow);}
.pricebox .tag{color:var(--cream);background:var(--moss);border-color:transparent;margin-bottom:1rem;}
.pricebox .price{font-family:var(--fd);font-weight:700;font-size:2.1rem;line-height:1;}
.pricebox .price small{display:block;font-family:var(--fm);font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:400;margin-top:.4rem;}
.pricebox ul{list-style:none;margin:1.2rem 0;display:flex;flex-direction:column;gap:.55rem;font-size:.9rem;}
.pricebox ul li{display:flex;gap:.5rem;align-items:flex-start;} .pricebox ul li svg{width:16px;height:16px;color:var(--fern);flex:none;margin-top:.15rem;}
.pricebox .btn{width:100%;justify-content:center;margin-bottom:.5rem;}
.pricebox .pb-note{font-size:.78rem;color:var(--muted);text-align:center;margin-top:.4rem;}

/* Vergleichstabelle (Kurse-Landing) */
.compare-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--card);}
.compare{width:100%;border-collapse:collapse;font-size:.92rem;min-width:560px;}
.compare th,.compare td{padding:.85rem 1.1rem;text-align:left;border-bottom:1px solid var(--line);}
.compare tr:last-child td,.compare tr:last-child th{border-bottom:0;}
.compare thead th{font-family:var(--fm);font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:500;}
.compare tbody th{font-weight:600;color:var(--ink);}
.compare td{color:var(--muted);}

/* ============================================================
   NEUES DESIGN v04 — GLOBAL (alle Seiten)
   ============================================================ */

/* Headlines: Farro (Serif, via :root --fd), durchgängig bold */
h1,h2,h3{font-weight:700;letter-spacing:-.015em;}
.it{font-weight:inherit;letter-spacing:inherit;}
.head h2,.split h2{font-size:clamp(1.8rem,3vw,2.5rem);}

/* Warmer, dezenter Grund-Verlauf */
body{background:linear-gradient(168deg,#ECEAD6 0%,var(--bone) 22%,var(--paper) 78%,#E7E4CD 100%);}

/* Buttons: solide & dezent (keine Glasoptik), minimale Rundung */
.btn{font-weight:500;font-size:.85rem;padding:.82rem 1.5rem;border-radius:var(--pill);
  backdrop-filter:none;-webkit-backdrop-filter:none;box-shadow:none;}
.btn-moss{background:var(--moss);color:var(--cream);border-color:var(--moss);box-shadow:0 10px 24px -16px rgba(20,28,8,.6);}
.btn-moss:hover{background:var(--fern);border-color:var(--fern);transform:translateY(-2px);}
.btn-brass{background:var(--brass);color:#fff;border-color:var(--brass);box-shadow:0 10px 24px -16px rgba(120,86,20,.5);}
.btn-brass:hover{background:#946a26;border-color:#946a26;transform:translateY(-2px);}
.btn-dark{background:var(--forest-2);color:var(--cream);border-color:var(--forest-2);box-shadow:0 10px 24px -18px rgba(0,0,0,.5);}
.btn-dark:hover{background:var(--forest);border-color:var(--forest);transform:translateY(-2px);}
.btn-ghost{background:rgba(245,240,228,.1);border-color:rgba(245,240,228,.5);color:var(--cream);}
.btn-ghost:hover{background:rgba(245,240,228,.95);color:var(--ink);border-color:transparent;}
.btn-line{background:transparent;border-color:rgba(30,33,19,.4);color:var(--ink);font-weight:500;}
.btn-line:hover{background:var(--ink);color:var(--cream);border-color:var(--ink);}
.btn-light{background:#FBF8EE;color:var(--ink);border-color:#FBF8EE;}
.btn-light:hover{background:#fff;transform:translateY(-2px);}

/* Termine-Filter: definierte Felder, klar (minimale Rundung) */
.tfilter{gap:.5rem;padding:.6rem;border-radius:var(--r-lg);align-items:stretch;
  background:rgba(245,241,230,.05);border:1px solid rgba(245,241,230,.16);}
.tfilter .tf{background:rgba(245,241,230,.05);border:1px solid rgba(245,241,230,.14);
  border-radius:var(--r);padding:.55rem 1rem;transition:.25s var(--ease);}
.tfilter .tf:hover{border-color:rgba(200,164,88,.45);background:rgba(245,241,230,.09);}
.tfilter .tf label{color:var(--brass-2);}
.tf .sel::after{border-color:var(--brass-2);}
.rt-reset{border-radius:var(--pill);align-self:center;}

/* ============================================================
   NUR STARTSEITE (body.home)
   ============================================================ */

/* warme Section-Verläufe */
body.home .tint{background:linear-gradient(180deg,#E4E2C9,var(--bone-2) 55%,#DAD8BD);}
body.home #teaser{background:radial-gradient(90% 70% at 88% -10%,rgba(200,164,88,.07),transparent 55%);}
body.home #kurse{background:radial-gradient(80% 60% at 0% 0%,rgba(86,107,44,.06),transparent 55%);}

/* HERO: Inhalt mittig zentriert, kein Scroll-Cue */
body.home .hero{align-items:center;text-align:center;}
body.home .hero-in{padding-bottom:0;}
body.home .hero h1{margin-left:auto;margin-right:auto;font-weight:700;font-size:clamp(2.4rem,5.4vw,4.6rem);line-height:1.05;max-width:30ch;}
body.home .hero p{margin-left:auto;margin-right:auto;max-width:58ch;}
body.home .hero .veil{background:
  radial-gradient(125% 95% at 50% 46%,rgba(18,14,8,.42),rgba(18,14,8,.74) 92%),
  linear-gradient(to top,rgba(18,14,8,.55),transparent 40%);}

/* Glas-Chip für die Eyebrow im Hero */
body.home .hero .eyebrow{background:rgba(245,240,228,.1);border:1px solid rgba(245,240,228,.3);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  padding:.5rem 1.05rem;border-radius:var(--pill);box-shadow:inset 0 1px 0 rgba(255,255,255,.22);}

/* — Hero-Finder: schlanke Leiste, minimale Rundung, klarer Button — */
body.home .finder{display:flex;align-items:stretch;gap:.3rem;max-width:620px;margin:2rem auto 0;
  border-radius:var(--r-lg);padding:.45rem;
  background:rgba(248,245,236,.86);border:1px solid rgba(255,255,255,.6);
  backdrop-filter:blur(20px) saturate(1.2);-webkit-backdrop-filter:blur(20px) saturate(1.2);
  box-shadow:0 24px 60px -32px rgba(10,8,4,.8),inset 0 1px 0 rgba(255,255,255,.7);}
body.home .finder .ff{flex:1;display:flex;flex-direction:column;justify-content:center;gap:.1rem;padding:.4rem .9rem;position:relative;text-align:left;}
body.home .finder .ff label{font-family:var(--fm);font-size:.52rem;letter-spacing:.14em;text-transform:uppercase;color:var(--brass);margin:0;}
body.home .finder .ff select{appearance:none;-webkit-appearance:none;border:0;background:transparent;font:inherit;font-weight:600;font-size:.92rem;color:var(--ink);cursor:pointer;outline:none;padding-right:1.1rem;}
body.home .finder .ff::after{content:"";position:absolute;right:.5rem;top:56%;width:6px;height:6px;
  border-right:1.6px solid var(--muted);border-bottom:1.6px solid var(--muted);transform:translateY(-50%) rotate(45deg);pointer-events:none;}
body.home .finder .sep{width:1px;align-self:stretch;background:var(--line);flex:none;margin:.35rem 0;}
body.home .finder .find{flex:none;display:inline-flex;align-items:center;gap:.5rem;border-radius:var(--r);
  padding:.85rem 1.4rem;font-weight:600;font-size:.86rem;
  background:linear-gradient(180deg,var(--moss),var(--forest-2));color:var(--cream);border:0;cursor:pointer;
  transition:.25s var(--ease);box-shadow:0 8px 20px -12px rgba(20,28,8,.7);}
body.home .finder .find svg{width:16px;height:16px;}
body.home .finder .find:hover{background:linear-gradient(180deg,var(--fern),var(--moss));transform:translateY(-1px);}
@media(max-width:600px){body.home .finder{flex-wrap:wrap;}
  body.home .finder .sep{display:none;}body.home .finder .ff{flex:1 1 100%;}
  body.home .finder .find{width:100%;justify-content:center;}}

/* — Hero-Microcontent: kleine Kennzahlen — */
body.home .hero-in .wrap{text-align:center;}
body.home .hero-stats{display:flex;justify-content:center;flex-wrap:wrap;gap:clamp(1.6rem,4.5vw,3.2rem);margin-top:2.2rem;}
body.home .hero-stats>div{display:flex;flex-direction:column;align-items:center;gap:.25rem;position:relative;}
body.home .hero-stats>div+div::before{content:"";position:absolute;left:calc(-1*clamp(.8rem,2.25vw,1.6rem));top:15%;bottom:15%;width:1px;background:rgba(241,234,217,.22);}
body.home .hero-stats b{font-family:var(--fd);font-weight:400;font-size:clamp(1.9rem,3.2vw,2.6rem);line-height:1;color:var(--cream);letter-spacing:-.01em;}
body.home .hero-stats span{font-family:var(--fm);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(241,234,217,.78);}
@media(max-width:720px){
  body.home .hero-stats{flex-wrap:nowrap;gap:.5rem;margin-top:1.4rem;width:100%;justify-content:space-between;}
  body.home .hero-stats>div{flex:1;gap:.15rem;min-width:0;}
  body.home .hero-stats>div+div::before{display:none;}
  body.home .hero-stats b{font-size:1.15rem;}
  body.home .hero-stats span{font-size:.5rem;letter-spacing:.1em;line-height:1.2;text-align:center;}
}

/* — Erste Section: Glas-Karte über dem Bild (Card-in-Card) — */
body.home .split-fig .stamp{display:none;}
body.home .fig-glass{position:absolute;left:1.1rem;bottom:1.1rem;width:max-content;max-width:calc(100% - 2.2rem);display:flex;align-items:center;gap:1.5rem;
  padding:1rem 1.6rem;border-radius:var(--r-lg);color:var(--cream);
  background:rgba(24,30,14,.46);border:1px solid rgba(245,240,228,.28);
  backdrop-filter:blur(18px) saturate(1.2);-webkit-backdrop-filter:blur(18px) saturate(1.2);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.18),0 20px 44px -26px rgba(0,0,0,.75);}
body.home .fig-glass .fg-row{display:flex;align-items:baseline;gap:.55rem;}
body.home .fig-glass b{font-family:var(--fd);font-weight:500;font-size:1.7rem;line-height:1;}
body.home .fig-glass span{font-family:var(--fm);font-size:.54rem;letter-spacing:.1em;text-transform:uppercase;color:var(--cream-2);line-height:1.3;}
body.home .fig-glass .fg-line{width:1px;align-self:stretch;background:rgba(245,240,228,.22);}
body.home .ipoints svg{background:rgba(168,124,50,.12);border-radius:var(--r);padding:3px;width:23px;height:23px;}

/* — "So läuft's" CTAs — */
body.home .ablauf-cta{display:flex;justify-content:center;gap:.7rem;flex-wrap:wrap;margin-top:2.6rem;}

/* — Jagdkurse als Akkordeon (gleiche Funktion wie „Eindrücke") — */
.kurse.acc{display:flex;grid-template-columns:none;gap:.6rem;height:clamp(440px,50vw,560px);}
.kurse.acc .kc{flex:1;min-width:72px;min-height:0;align-items:flex-end;transition:flex .6s var(--ease);}
.kurse.acc .kc.active{flex:3.4;}
.kurse.acc .kc::after{background:linear-gradient(to top,rgba(18,14,8,.92),rgba(18,14,8,.06) 72%);}
.kurse.acc .kc .tag{opacity:0;transition:.3s var(--ease);}
.kurse.acc .kc.active .tag{opacity:1;}
.kurse.acc .kc .kc-vtitle{position:absolute;left:1.15rem;bottom:1.3rem;z-index:3;writing-mode:vertical-rl;transform:rotate(180deg);font-family:var(--fd);font-weight:500;font-size:1.15rem;color:#fff;white-space:nowrap;transition:.3s var(--ease);}
.kurse.acc .kc.active .kc-vtitle{opacity:0;}
.kurse.acc .kc .c{width:clamp(260px,34vw,440px);flex:none;opacity:0;transform:translateY(10px);transition:opacity .45s var(--ease),transform .45s var(--ease);pointer-events:none;}
.kurse.acc .kc.active .c{opacity:1;transform:none;pointer-events:auto;}
.kurse.acc .kc .kc-desc{color:rgba(241,234,217,.88);font-size:.94rem;line-height:1.5;margin:.5rem 0 .85rem;max-width:40ch;}
.kurse.acc .kc .pr{display:block;margin-bottom:1rem;}
.kurse.acc .kc-cta{display:flex;gap:.5rem;flex-wrap:wrap;}
@media(max-width:860px){
  .kurse.acc{flex-direction:column;height:auto;}
  .kurse.acc .kc{min-height:300px;flex:1 1 auto;}
  .kurse.acc .kc .c{width:auto;opacity:1;transform:none;pointer-events:auto;}
  .kurse.acc .kc .kc-vtitle{display:none;}
  .kurse.acc .kc .tag{opacity:1;}}

/* ============================================================
   v01-PARITÄT (global, neues Design) — Topbar · Footer-Socials
   Cookie-Consent · Magazin. Ohne Bezahl-/Shop-Elemente.
   ============================================================ */

/* Topbar (über dem fixierten Header; rutscht beim Scrollen weg) */
.topbar{position:fixed;top:0;left:0;right:0;z-index:101;height:var(--topbar-h);display:flex;align-items:center;justify-content:center;background:var(--forest);overflow:hidden;transition:transform .35s var(--ease);}
.topbar .tb-msg{position:absolute;left:0;right:0;text-align:center;padding:0 1rem;font-family:var(--fm);font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--cream-2);opacity:0;transition:opacity .5s var(--ease);}
.topbar .tb-msg.on{opacity:1;}
html.tb-hidden .topbar{transform:translateY(-100%);}
header{top:var(--topbar-h);}
html.tb-hidden header{top:0;}
@media(max-width:600px){.topbar .tb-msg{font-size:.54rem;letter-spacing:.12em;}}

/* Footer-Socials */
.foot .socials{display:flex;gap:.55rem;margin-top:1.1rem;}
.foot .socials a{width:34px;height:34px;border:1px solid var(--line-d);border-radius:var(--r);display:grid;place-items:center;color:var(--cream-2);transition:.2s var(--ease);}
.foot .socials a:hover{color:#fff;border-color:var(--brass-2);background:rgba(241,234,217,.06);}
.foot .socials svg{width:17px;height:17px;}

/* Cookie-Consent */
.cookie-consent{position:fixed;left:1rem;right:1rem;bottom:1rem;z-index:300;max-width:560px;background:var(--bark);color:var(--cream);border:1px solid var(--line-d);border-radius:var(--r-lg);box-shadow:var(--shadow);animation:ccPop .45s var(--ease) both;}
@keyframes ccPop{from{opacity:0;transform:translateY(20px) scale(.98);}to{opacity:1;transform:none;}}
.cc-inner{padding:1.2rem 1.3rem;display:flex;flex-direction:column;gap:1rem;}
.cc-title{font-family:var(--fd);font-weight:500;font-size:1.1rem;margin-bottom:.25rem;}
.cc-text p{font-size:.86rem;color:var(--cream-2);line-height:1.55;}
.cc-text a{color:var(--brass-2);text-decoration:underline;}
.cc-actions{display:flex;gap:.6rem;flex-wrap:wrap;}
.cc-actions .btn{flex:1;justify-content:center;min-width:150px;}
.btn-outline{background:transparent;border-color:rgba(245,240,228,.4);color:var(--cream);}
.btn-outline:hover{background:rgba(245,240,228,.12);}
.btn-primary{background:var(--brass);color:#fff;border-color:var(--brass);}
.btn-primary:hover{background:#946a26;border-color:#946a26;transform:translateY(-2px);}
.cookie-settings-btn{position:fixed;left:1rem;bottom:1rem;z-index:299;width:42px;height:42px;border-radius:50%;background:var(--forest);color:var(--cream);border:0;display:grid;place-items:center;cursor:pointer;box-shadow:var(--shadow);}
.cookie-settings-btn svg{width:20px;height:20px;}

/* Magazin: Featured · Filter · Grid · Cards */
.featured-article{display:grid;grid-template-columns:1.05fr 1fr;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;background:var(--card);margin-bottom:2.4rem;transition:.3s var(--ease);box-shadow:var(--shadow);}
.featured-article:hover{transform:translateY(-3px);}
.fa-media{position:relative;min-height:300px;}
.fa-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.fa-flag{position:absolute;top:1rem;left:1rem;z-index:2;font-family:var(--fm);font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;background:var(--brass);color:#fff;padding:.35rem .75rem;border-radius:var(--pill);}
.fa-body{padding:clamp(1.5rem,3vw,2.6rem);display:flex;flex-direction:column;justify-content:center;}
.fa-body h2{font-size:clamp(1.5rem,2.6vw,2.1rem);margin:.6rem 0 .7rem;}
.fa-body p{color:var(--muted);font-size:.98rem;}
@media(max-width:760px){.featured-article{grid-template-columns:1fr;}.fa-media{min-height:220px;}}
.cat-tag{display:inline-block;width:max-content;font-family:var(--fm);font-size:.56rem;letter-spacing:.12em;text-transform:uppercase;padding:.32rem .7rem;border-radius:var(--pill);background:var(--bone-2);color:var(--moss);}
.cat-tag.c-praxis{background:rgba(86,107,44,.16);color:var(--fern);}
.cat-tag.c-akademie{background:rgba(168,124,50,.16);color:var(--brass);}
.cat-tag.c-wild{background:rgba(56,73,29,.16);color:var(--moss);}
.cat-tag.c-recht{background:rgba(30,33,19,.1);color:var(--ink);}
.cat-tag.c-ausruestung{background:rgba(200,164,88,.18);color:#90692a;}
.ac-meta{display:flex;flex-wrap:wrap;gap:1rem;margin-top:1rem;font-family:var(--fm);font-size:.6rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);}
.ac-meta span{display:inline-flex;align-items:center;gap:.4rem;}
.ac-meta svg{width:14px;height:14px;color:var(--brass);}
.filter-bar{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:1.6rem;}
.chips{display:flex;gap:.5rem;flex-wrap:wrap;}
.chip{font-family:var(--fm);font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;padding:.5rem .95rem;border:1px solid var(--line);border-radius:var(--pill);background:transparent;color:var(--muted);cursor:pointer;transition:.2s var(--ease);}
.chip:hover{border-color:var(--brass);color:var(--ink);}
.chip.active{background:var(--forest);border-color:var(--forest);color:var(--cream);}
.mag-search{position:relative;display:flex;align-items:center;}
.mag-search svg{position:absolute;left:.8rem;width:16px;height:16px;color:var(--muted);}
.mag-search input{font:inherit;font-size:.9rem;padding:.65rem .9rem .65rem 2.3rem;border:1px solid var(--line);border-radius:var(--r);background:var(--card);color:var(--ink);outline:none;min-width:230px;transition:.2s;}
.mag-search input:focus{border-color:var(--fern);box-shadow:0 0 0 3px rgba(86,107,44,.15);}
.mag-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;}
@media(max-width:1240px){.mag-grid{grid-template-columns:repeat(3,1fr);}}
@media(max-width:900px){.mag-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:600px){.mag-grid{grid-template-columns:1fr;}}
.article-card{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;background:var(--card);transition:.3s var(--ease);}
.article-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);}
.ac-media{display:block;aspect-ratio:16/10;overflow:hidden;}
.ac-media img{width:100%;height:100%;object-fit:cover;transition:.6s var(--ease);}
.article-card:hover .ac-media img{transform:scale(1.05);}
.ac-body{padding:1.3rem;display:flex;flex-direction:column;gap:.5rem;flex:1;}
.ac-body h3{font-size:1.2rem;line-height:1.25;}
.ac-body p{color:var(--muted);font-size:.9rem;flex:1;}
.ac-link{margin-top:.4rem;}
.mag-empty{grid-column:1/-1;text-align:center;padding:3rem 1rem;color:var(--muted);}
.mag-empty svg{width:36px;height:36px;margin:0 auto 1rem;color:var(--brass);display:block;}

/* CTA-Band (Newsletter / Schlussaufruf) */
.cta-band{background:var(--forest);color:var(--cream);border-radius:var(--r-lg);text-align:center;padding:clamp(2.4rem,5vw,4rem) 1.5rem;}
.cta-band .eyebrow{color:var(--brass-2);}
.cta-band h2{color:#fff;font-size:clamp(1.7rem,3.2vw,2.6rem);margin-top:.6rem;}
.cta-band p{color:var(--cream-2);max-width:46ch;margin:.8rem auto 1.6rem;}
.cta-band .hero-cta{justify-content:center;}


/* Back-to-top (unten rechts) */
.to-top{right:1.4rem;bottom:5.6rem;}

/* Über-uns: Eindrücke-Galerie (Auto-Marquee, echte Aufnahmen) */
.es-slider{overflow:hidden;position:relative;margin-top:2.4rem;-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);}
.es-track{display:flex;width:max-content;animation:esScroll 55s linear infinite;}
.es-slider:hover .es-track{animation-play-state:paused;}
.es-item{flex:none;width:clamp(240px,28vw,360px);margin:0 1rem 0 0;}
.es-item img{width:100%;height:clamp(180px,22vw,260px);object-fit:cover;border-radius:var(--r-lg);display:block;}
@keyframes esScroll{from{transform:translateX(0);}to{transform:translateX(-50%);}}
@media(prefers-reduced-motion:reduce){.es-track{animation:none;}}

/* Prose: Listen, Links, Lauftext (Magazin-Beiträge + Rechtliches) */
.prose{max-width:760px;}
.prose ul:not(.ticks),.prose ol{margin:1rem 0 1.3rem;padding-left:1.3rem;display:flex;flex-direction:column;gap:.45rem;}
.prose ul:not(.ticks) li,.prose ol li{font-size:1rem;color:var(--ink);line-height:1.65;}
.prose ul:not(.ticks) li::marker{color:var(--brass);}
.prose a{color:var(--fern);text-decoration:underline;text-underline-offset:2px;}
.prose a:hover{color:var(--moss);}
.prose strong,.prose b{font-weight:600;color:var(--ink);}
.prose h2:first-child,.prose h3:first-child{margin-top:0;}

/* ============================================================
   SCROLL JOURNEY (POV-Walk auf Startseite, body.home only)
   ============================================================ */
.sj{position:relative;height:1100vh;background:var(--forest);}
.sj-sticky{position:sticky;top:0;height:100vh;overflow:hidden;}
.sj-portal{position:absolute;inset:0;}
.sj-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.sj-veil{position:absolute;inset:0;background:linear-gradient(to top,rgba(18,14,8,.72),rgba(18,14,8,.22) 55%,rgba(18,14,8,0)),radial-gradient(ellipse at center,rgba(18,14,8,.28) 0%,transparent 65%);pointer-events:none;}
.sj-progress{position:absolute;left:0;right:0;top:0;height:2px;background:rgba(247,242,229,.15);z-index:5;}
.sj-progress i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--brass),var(--brass-2));transition:width .1s linear;}
/* ===== SJ STEP — no card, floating cinema type ===== */
/* ===== SJ WHEEL — Kreis mit 6 Dots, Info-Panel in der Mitte ===== */
.sj-steps{position:absolute;inset:0;z-index:3;pointer-events:none;display:flex;align-items:center;justify-content:center;}

.sj-wheel{
  position:relative;
  width:min(72vh,84vw);
  height:min(72vh,84vw);
  max-width:680px;
  max-height:680px;
}

/* Faint guide-circle */
.sj-wheel::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:50%;
  border:1px dashed rgba(247,242,229,.1);
}

.sj-step{
  position:absolute;
  top:50%;
  left:50%;
  width:78px;
  height:78px;
  margin:-39px;
  transform:rotate(var(--angle)) translateY(calc(-1 * min(34vh,40vw))) rotate(calc(-1 * var(--angle)));
}
.sj-step[data-idx="0"]{--angle:-90deg;}
.sj-step[data-idx="1"]{--angle:-30deg;}
.sj-step[data-idx="2"]{--angle:30deg;}
.sj-step[data-idx="3"]{--angle:90deg;}
.sj-step[data-idx="4"]{--angle:150deg;}
.sj-step[data-idx="5"]{--angle:210deg;}

.sj-pt{
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  width:100%;
  height:100%;
  border-radius:50%;
  border:1px solid rgba(184,148,82,.4);
  background:rgba(18,14,8,.42);
  backdrop-filter:blur(14px) saturate(1.2);
  -webkit-backdrop-filter:blur(14px) saturate(1.2);
  font-family:var(--fd);
  font-weight:500;
  font-size:1.35rem;
  letter-spacing:-.02em;
  color:rgba(247,242,229,.82);
  text-shadow:0 1px 4px rgba(0,0,0,.5);
  transition:background .5s var(--ease),border-color .5s var(--ease),box-shadow .5s var(--ease),color .5s var(--ease),transform .55s var(--ease);
}

.sj-step.active .sj-pt{
  background:var(--brass);
  border-color:var(--brass);
  color:var(--cream);
  text-shadow:0 1px 2px rgba(0,0,0,.35);
  transform:scale(1.18);
  box-shadow:0 0 0 6px rgba(184,148,82,.12),0 0 50px rgba(184,148,82,.55),0 0 18px rgba(184,148,82,.85);
}

/* Connector pulse ring around active dot */
.sj-pt::after{
  content:"";
  position:absolute;
  inset:-6px;
  border-radius:50%;
  border:1px solid rgba(184,148,82,.55);
  opacity:0;
  transform:scale(.9);
  pointer-events:none;
}
.sj-step.active .sj-pt::after{
  animation:sjPulseRing 2.2s var(--ease) infinite;
}

/* CENTER Info-Panel */
.sj-info-wrap{
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
  z-index:2;
  pointer-events:none;
}

.sj-info{
  grid-area:1/1;
  width:clamp(290px,34vw,460px);
  padding:2.2rem 2.4rem 2rem;
  text-align:center;
  background:rgba(18,14,8,.38);
  backdrop-filter:blur(24px) saturate(1.25);
  -webkit-backdrop-filter:blur(24px) saturate(1.25);
  border:1px solid rgba(247,242,229,.1);
  border-radius:6px;
  box-shadow:
    0 30px 80px -22px rgba(0,0,0,.65),
    0 8px 24px -8px rgba(0,0,0,.45),
    inset 0 1px 0 rgba(247,242,229,.1);
  opacity:0;
  transform:translateY(18px) scale(.96);
  transition:opacity .55s var(--ease),transform .6s var(--ease);
  pointer-events:none;
}
.sj-info.active{
  opacity:1;
  transform:translateY(0) scale(1);
}

.sj-info .lab{
  display:inline-block;
  font-family:var(--fm);
  font-size:.72rem;
  letter-spacing:.3em;
  text-transform:uppercase;
  font-weight:600;
  color:var(--brass);
  margin:0 0 1rem 0;
}

.sj-info h3{
  font-family:var(--fd);
  font-size:clamp(1.7rem,2.8vw,2.5rem);
  font-weight:700;
  color:var(--cream);
  line-height:1.08;
  letter-spacing:-.025em;
  margin:0;
}
.sj-info h3 .it{font-style:normal;color:inherit;}

.sj-info p{
  margin:1.2rem auto 0;
  max-width:34ch;
  font-size:clamp(.95rem,1.05vw,1.08rem);
  line-height:1.6;
  color:rgba(247,242,229,.92);
}

@keyframes sjPulseRing{
  0%{opacity:.7;transform:scale(.9);}
  100%{opacity:0;transform:scale(1.6);}
}

.sj-hint{position:absolute;left:50%;bottom:1.6rem;transform:translateX(-50%);z-index:4;font-family:var(--fm);font-size:.58rem;letter-spacing:.24em;text-transform:uppercase;color:rgba(247,242,229,.55);display:flex;flex-direction:column;align-items:center;gap:.55rem;transition:opacity .4s var(--ease);}
.sj-hint i{width:1px;height:30px;background:linear-gradient(rgba(247,242,229,.5),transparent);animation:sjPulse 1.6s ease-in-out infinite;}
.sj.scrolled .sj-hint{opacity:0;}
@keyframes sjPulse{0%,100%{opacity:.25;transform:scaleY(.6);}50%{opacity:1;transform:scaleY(1);}}
@media(max-width:820px){
  .sj{height:820vh;}
  .sj-wheel{width:min(60vh,82vw);height:min(60vh,82vw);}
  .sj-step{width:60px;height:60px;margin:-30px;transform:rotate(var(--angle)) translateY(calc(-1 * min(28vh,38vw))) rotate(calc(-1 * var(--angle)));}
  .sj-pt{font-size:1.05rem;}
  .sj-info-wrap{width:clamp(220px,68vw,340px);}
  .sj-info h3{font-size:clamp(1.5rem,5.4vw,1.95rem);}
}
@media(prefers-reduced-motion:reduce){
  .sj{height:auto;}
  .sj-sticky{position:relative;height:auto;min-height:60vh;display:flex;flex-direction:column;gap:1.2rem;padding:2.4rem 1.4rem;}
  .sj-wheel{display:none;}
  .sj-info-wrap{position:relative;left:auto;top:auto;transform:none;width:100%;max-width:520px;margin:0 auto;}
  .sj-info{position:relative;top:auto;left:auto;transform:none;opacity:1;margin-bottom:2rem;}
}

/* ============================================================
   WhatsApp Floating-Toggle + Lightbox (global)
   ============================================================ */
.wa-fab{position:fixed;right:1.4rem;bottom:1.4rem;z-index:95;}
.wa-fab-btn{appearance:none;border:0;width:46px;height:46px;border-radius:50%;background:var(--forest);color:var(--cream);display:grid;place-items:center;cursor:pointer;box-shadow:var(--shadow);transition:transform .2s var(--ease),background .2s;}
.wa-fab-btn:hover{transform:scale(1.06);background:var(--forest-2);}
.wa-fab-btn:active{transform:scale(.96);}
.wa-fab-btn svg{width:20px;height:20px;}
.wa-fab-pop{position:absolute;right:0;bottom:74px;width:300px;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.3rem 1.4rem 1.4rem;box-shadow:0 28px 60px -20px rgba(0,0,0,.45),0 10px 30px -10px rgba(0,0,0,.25);opacity:0;transform:translateY(12px) scale(.96);transform-origin:bottom right;pointer-events:none;transition:opacity .3s var(--ease),transform .35s var(--ease);}
.wa-fab.open .wa-fab-pop{opacity:1;transform:translateY(0) scale(1);pointer-events:auto;}
.wa-fab-head{display:flex;justify-content:space-between;align-items:flex-start;gap:.8rem;margin-bottom:.6rem;}
.wa-fab-head h3{font-family:var(--fd);font-size:1.05rem;color:var(--forest);letter-spacing:-.01em;}
.wa-fab-close{appearance:none;background:transparent;border:0;width:24px;height:24px;border-radius:50%;color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.2s;}
.wa-fab-close:hover{background:var(--bone-2);color:var(--ink);}
.wa-fab-pop p{color:var(--muted);font-size:.85rem;line-height:1.5;margin-bottom:1rem;}
.wa-fab-pop .actions{display:flex;flex-direction:column;gap:.5rem;}
.wa-fab-pop .actions a{width:100%;justify-content:center;}
.wa-fab-pop .wa-link{background:#25D366;color:#fff;border:0;padding:.7rem 1rem;border-radius:var(--pill);font-family:var(--fb);font-size:.85rem;font-weight:600;display:inline-flex;align-items:center;gap:.5rem;text-decoration:none;justify-content:center;transition:.2s;}
.wa-fab-pop .wa-link:hover{background:#1ebd5b;transform:translateY(-1px);}
.wa-fab-pop .wa-link svg{width:18px;height:18px;}
@media(max-width:600px){.wa-fab{right:1rem;bottom:1rem;}.wa-fab-pop{width:calc(100vw - 2rem);right:0;}}

/* Hero Scroll-Hint (dezent unten Mitte) */
.hero-scroll-hint{position:absolute;left:50%;bottom:1.6rem;transform:translateX(-50%);z-index:5;display:inline-flex;flex-direction:column;align-items:center;gap:.55rem;font-family:var(--fm);font-size:.6rem;letter-spacing:.26em;text-transform:uppercase;color:rgba(247,242,229,.78);text-decoration:none;transition:color .25s,opacity .25s;cursor:pointer;}
.hero-scroll-hint:hover{color:var(--brass-2);}
.hero-scroll-hint i{display:inline-flex;width:22px;height:22px;border-radius:50%;border:1px solid rgba(247,242,229,.4);align-items:center;justify-content:center;animation:heroScrollPulse 2.2s ease-in-out infinite;}
.hero-scroll-hint i svg{width:12px;height:12px;}
@keyframes heroScrollPulse{0%,100%{transform:translateY(0);opacity:.65;}50%{transform:translateY(5px);opacity:1;}}
@media(max-width:720px){.hero-scroll-hint{bottom:1.2rem;font-size:.55rem;}}
