/* ═══════════════════════════════════════════════════════════════
   ERZPFERD — Design System v2.0
   Ponyschule "Am Blauen Stein" & erzpferd e.V.
   Built with UI/UX Pro Max + Designelemente Library
   ═══════════════════════════════════════════════════════════════ */

/* ── Custom Properties — Masterplan v3 ── */
:root {
  /* Zwei Grüntöne dominieren */
  --forest: #4A7C2E;
  --forest-light: #7CB342;
  --forest-dark: #2E5E1A;

  /* Hintergründe: Weiß + dezent grünlich */
  --bg: #FFFFFF;
  --bg-alt: #F3F7F0;
  --surface: #FFFFFF;

  /* Text: Dunkles Grün statt Braun */
  --charcoal: #1C2B14;
  --warmgray: #5A6B50;
  --muted: #7D8F74;

  /* Rahmen: Grünlich statt beige */
  --border: #D8E4D0;

  /* Akzent: Nur sparsam (Spenden, Quotes) */
  --amber: #C8883A;
  --amber-dark: #8B5E1D;

  /* Legacy-Aliase für Kompatibilität */
  --cream: var(--bg-alt);
  --cream-light: var(--bg);
  --cream-dark: #E8EDE4;
  --moss: #1C3A10;

  --font-serif: 'DM Serif Display', Georgia, serif;
  --font-sans: 'Inter', system-ui, -apple-system, sans-serif;

  --max-site: 1200px;
  --header-h: 72px;
  --radius: 16px;
  --radius-sm: 10px;
  --radius-full: 9999px;

  /* Schatten: Grünlich statt bräunlich */
  --shadow-sm: 0 2px 8px rgba(30,60,20,.06);
  --shadow: 0 4px 24px rgba(30,60,20,.08);
  --shadow-lg: 0 12px 40px rgba(30,60,20,.14);
  --shadow-float: 0 20px 50px rgba(30,60,20,.06);
  --shadow-glow: 0 0 30px rgba(124,179,66,.2);

  --ease-out: cubic-bezier(.16,1,.3,1);
  --ease-spring: cubic-bezier(.34,1.56,.64,1);
  --dur: .35s;
  --dur-slow: .6s;
  --dur-fast: .2s;
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{font-family:var(--font-sans);font-size:16px;line-height:1.7;color:var(--charcoal);background:var(--bg)}
img{max-width:100%;height:auto;display:block}
a{color:var(--forest);text-decoration:none;transition:color var(--dur-fast) ease}
a:hover{color:var(--forest-dark)}

/* ── Typography ── */
h1,h2,h3{font-family:var(--font-serif);color:var(--charcoal);font-weight:400;letter-spacing:-.01em}
h4,h5,h6{font-family:var(--font-sans);font-weight:600}
h1{font-size:clamp(2.25rem,5vw,3.5rem);line-height:1.1}
h2{font-size:clamp(1.75rem,3.5vw,2.5rem);line-height:1.15}
h3{font-size:clamp(1.125rem,2vw,1.5rem);line-height:1.3;font-family:var(--font-sans);font-weight:600}
h4{font-size:1.125rem;line-height:1.4}
p+p{margin-top:1.25em}
.text-center{text-align:center}
.text-large{font-size:1.125rem;color:var(--warmgray);line-height:1.8}
.text-large+.text-large{margin-top:1em}
.text-secondary{color:var(--warmgray)}
.text-small{font-size:.875rem;line-height:1.5}

/* ── Layout ── */
.site-container{max-width:var(--max-site);margin:0 auto;padding:0 clamp(20px,4vw,64px)}
.section{padding:clamp(64px,10vw,120px) 0}
.section--cream{background:var(--bg-alt)}
.section--green{background:var(--forest-dark);color:#fff}
.section--green h2,.section--green h3,.section--green h4{color:#fff}
.section--green .text-secondary{color:rgba(255,255,255,.7)}
.section__header{text-align:center;max-width:720px;margin:0 auto clamp(32px,5vw,56px)}
.section__header p{margin-top:12px;color:var(--warmgray);font-size:1.0625rem}

/* ── Grid System ── */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
@media(max-width:1024px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

/* ══════════════════════════════════════
   BUTTONS
   ══════════════════════════════════════ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 32px;border-radius:var(--radius-sm);
  font-family:var(--font-sans);font-size:.9375rem;font-weight:600;
  line-height:1;text-decoration:none;cursor:pointer;border:2px solid transparent;
  transition:all var(--dur) var(--ease-out);position:relative;overflow:hidden;
}
.btn::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.15),transparent);
  opacity:0;transition:opacity var(--dur-fast) ease;
}
.btn:hover::after{opacity:1}
.btn--primary{background:var(--forest);color:#fff;border-color:var(--forest)}
.btn--primary:hover{background:var(--forest-dark);color:#fff;transform:translateY(-2px);box-shadow:0 8px 25px rgba(74,124,46,.3)}
.btn--secondary{background:transparent;color:var(--forest);border-color:var(--forest)}
.btn--secondary:hover{background:var(--forest);color:#fff;transform:translateY(-2px)}
.btn--amber{background:var(--amber);color:#fff;border-color:var(--amber)}
.btn--amber:hover{background:var(--amber-dark);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-glow)}
.btn--white-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn--white-outline:hover{background:#fff;color:var(--forest-dark);border-color:#fff}

/* ══════════════════════════════════════
   SCROLL EXPANSION HERO
   Image starts centered, expands to fullscreen on scroll.
   Title text splits apart. Based on Designelemente/Scroll media expansion hero.
   ══════════════════════════════════════ */
.scroll-hero{
  position:relative;height:100vh;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  background:#1E3A12;
}
.scroll-hero__bg{
  position:absolute;inset:0;background-size:cover;background-position:center;
  filter:blur(20px) brightness(.4);transform:scale(1.1);
  transition:opacity .6s ease;
}
.scroll-hero__media{
  position:relative;z-index:2;
  width:340px;height:420px;border-radius:20px;overflow:hidden;
  transition:width .05s,height .05s,border-radius .3s;
  box-shadow:0 20px 60px rgba(0,0,0,.4);
}
.scroll-hero__media img{width:100%;height:100%;object-fit:cover}
.scroll-hero__media-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(30,58,18,.6),transparent 50%);
  transition:opacity .3s ease;
}
.scroll-hero__text{
  position:absolute;z-index:3;display:flex;flex-direction:column;align-items:center;
  gap:0;pointer-events:none;
}
.scroll-hero__title-left,.scroll-hero__title-right{
  font-family:var(--font-serif);color:#fff;
  font-size:clamp(2rem,5vw,3.5rem);line-height:1.15;
  text-shadow:0 4px 30px rgba(0,0,0,.5);
  transition:transform .05s,opacity .3s;
  white-space:nowrap;
}
.scroll-hero__subline{
  position:absolute;bottom:20%;z-index:3;
  font-size:clamp(.875rem,1.5vw,1.125rem);color:rgba(255,255,255,.8);
  text-align:center;max-width:500px;padding:0 24px;
  transition:opacity .3s ease;pointer-events:none;
}
.scroll-hero__buttons{
  position:absolute;bottom:12%;z-index:4;
  display:flex;gap:16px;flex-wrap:wrap;justify-content:center;
  transition:opacity .3s ease;
}
.scroll-hero__scroll-hint{
  position:absolute;bottom:24px;left:50%;transform:translateX(-50%);z-index:5;
  color:rgba(255,255,255,.5);text-align:center;font-size:.7rem;
  letter-spacing:.15em;text-transform:uppercase;
  transition:opacity .3s ease;
}
.scroll-hero__scroll-hint svg{animation:hero-bounce 2s var(--ease-out) infinite;margin-top:6px}
@keyframes hero-bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(8px)}}
@media(max-width:768px){
  .scroll-hero__media{width:260px;height:340px}
  .scroll-hero__buttons{bottom:8%;flex-direction:column;align-items:center;padding:0 24px}
}

/* ══════════════════════════════════════
   HERO — Static (subpages)
   ══════════════════════════════════════ */
.hero{
  position:relative;display:flex;align-items:center;justify-content:center;
  overflow:hidden;isolation:isolate;
}
.hero--full{min-height:100vh}
.hero--medium{min-height:70vh}
.hero--small{min-height:50vh}
.hero__bg{position:absolute;inset:0;z-index:-2}
.hero__bg img,.hero__video{width:100%;height:100%;object-fit:cover;object-position:center 30%}
.hero__overlay{
  position:absolute;inset:0;z-index:-1;
  background:linear-gradient(160deg,rgba(30,58,18,.75) 0%,rgba(30,58,18,.5) 40%,rgba(75,53,32,.4) 100%);
}
.hero__content{position:relative;text-align:center;max-width:800px;padding:40px 24px;z-index:1}
.hero__title{color:#fff;margin-bottom:20px;text-shadow:0 2px 30px rgba(0,0,0,.3)}
.hero__subline{font-size:clamp(1rem,2vw,1.25rem);color:rgba(255,255,255,.85);line-height:1.6;max-width:600px;margin:0 auto}
.hero__buttons{display:flex;gap:16px;margin-top:32px;justify-content:center;flex-wrap:wrap}

/* Split hero: top/bottom positioned separately */
.hero__split{position:absolute;left:0;right:0;z-index:2;text-align:center;padding:0 24px;transition:transform .05s linear,opacity .3s ease;will-change:transform,opacity}
.hero__split--top{top:20%;display:flex;flex-direction:column;align-items:center}
.hero__split--bottom{bottom:12%;display:flex;flex-direction:column;align-items:center}
@media(max-width:768px){.hero__split--top{top:25%}.hero__split--bottom{bottom:8%}}

/* Mouse parallax on hero image */
.hero__bg--parallax{transition:transform .15s ease-out}
.hero__bg--parallax img{transform:scale(1.08)}

/* ══════════════════════════════════════
   HEADER — Glassmorphism
   ══════════════════════════════════════ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  height:var(--header-h);
  background:transparent;
  transition:background .4s ease,box-shadow .4s ease,backdrop-filter .4s ease;
}
/* Default = transparent with white text (over hero) */
.site-header .site-header__title{color:#fff;transition:color .4s ease}
.site-header .nav-menu li a{color:rgba(255,255,255,.9);transition:color .3s ease}
.site-header .nav-menu li a:hover{color:#fff}
.site-header .nav-menu li a::after{background:#fff}
.site-header .hamburger,.site-header .hamburger::before,.site-header .hamburger::after{background:#fff;transition:all .4s ease}
.site-header .site-header__cta{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.4);color:#fff;transition:all .4s ease}
.site-header .site-header__cta:hover{background:#fff;color:var(--forest-dark);border-color:#fff}
/* Scrolled state — solid white background, dark text */
.site-header--scrolled{
  background:rgba(255,255,255,.97) !important;
  backdrop-filter:blur(20px) saturate(1.5);-webkit-backdrop-filter:blur(20px) saturate(1.5);
  box-shadow:0 1px 20px rgba(44,36,24,.08);
}
.site-header--scrolled .site-header__title{color:var(--charcoal)}
.site-header--scrolled .nav-menu li a{color:var(--charcoal)}
.site-header--scrolled .nav-menu li a:hover{color:var(--forest)}
.site-header--scrolled .nav-menu li a::after{background:var(--forest)}
.site-header--scrolled .hamburger,.site-header--scrolled .hamburger::before,.site-header--scrolled .hamburger::after{background:var(--charcoal)}
.site-header--scrolled .site-header__cta{background:var(--forest);border-color:var(--forest);color:#fff}
.site-header--scrolled .site-header__cta:hover{background:var(--forest-dark)}
.site-header__inner{
  max-width:var(--max-site);margin:0 auto;
  padding:0 clamp(20px,4vw,64px);height:100%;
  display:flex;align-items:center;justify-content:space-between;gap:32px;
}
.site-header__logo a,.site-header__title{
  font-family:var(--font-serif);font-size:1.35rem;
  color:var(--charcoal);text-decoration:none;
}
.site-header__logo-link{display:flex;align-items:center;}
.site-header__logo-img{height:56px;width:auto;transition:opacity .3s ease, filter .4s ease;}
.site-header__logo-img:hover{opacity:.8;}
.site-header .site-header__logo-img{filter:brightness(0) invert(1);}
.site-header--scrolled .site-header__logo-img{filter:none;}
.site-header__nav{flex:1;display:flex;justify-content:center}
.nav-menu{display:flex;gap:36px;list-style:none}
.nav-menu li a{
  font-size:.9rem;font-weight:500;color:var(--charcoal);
  text-decoration:none;position:relative;padding:4px 0;
  transition:color var(--dur-fast) ease;
}
.nav-menu li a::after{
  content:'';position:absolute;bottom:-2px;left:0;
  width:0;height:2px;border-radius:1px;
  background:var(--forest);transition:width var(--dur) var(--ease-out);
}
.nav-menu li a:hover{color:var(--forest)}
.nav-menu li a:hover::after,.nav-menu li.current-menu-item a::after{width:100%}
.site-header__cta{padding:10px 24px;font-size:.8125rem;border-radius:var(--radius-sm)}
@media(max-width:1024px){.site-header__nav,.site-header__cta{display:none}}

/* Hamburger */
.site-header__toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;width:44px;height:44px;align-items:center;justify-content:center}
@media(max-width:1024px){.site-header__toggle{display:flex}}
.hamburger{width:22px;height:2px;background:var(--charcoal);position:relative;transition:all var(--dur) var(--ease-out)}
.hamburger::before,.hamburger::after{content:'';position:absolute;left:0;width:22px;height:2px;background:var(--charcoal);transition:all var(--dur) var(--ease-out)}
.hamburger::before{top:-7px}
.hamburger::after{top:7px}
[aria-expanded="true"] .hamburger{background:transparent}
[aria-expanded="true"] .hamburger::before{transform:translateY(7px) rotate(45deg);background:var(--charcoal)}
[aria-expanded="true"] .hamburger::after{transform:translateY(-7px) rotate(-45deg);background:var(--charcoal)}
.site-header.menu-open,
.site-header.menu-open.site-header--scrolled{
  background:#fff !important;
  box-shadow:0 1px 20px rgba(44,36,24,.08) !important;
  backdrop-filter:none !important;-webkit-backdrop-filter:none !important;
}
.site-header.menu-open .site-header__logo-img{filter:none !important;}
.site-header.menu-open .hamburger::before,
.site-header.menu-open .hamburger::after{background:var(--charcoal) !important;}

/* Mobile Menu — Slide In */
.mobile-menu{
  position:fixed;top:var(--header-h);left:0;right:0;bottom:0;
  background:#fff;padding:48px 24px;
  display:flex;flex-direction:column;gap:32px;
  transform:translateX(100%);
  transition:transform .5s var(--ease-out);z-index:1001;
}
.mobile-menu--open{transform:translateX(0)}
.mobile-menu__list{list-style:none;display:flex;flex-direction:column;gap:28px}
.mobile-menu__list li a{font-family:var(--font-serif);font-size:1.75rem;color:var(--charcoal);text-decoration:none}

/* No header padding on template pages */
.site-main{padding-top:var(--header-h)}
.page-template-template-startseite .site-main,
.page-template-template-ponyschule .site-main,
.page-template-template-reittherapie .site-main,
.page-template-template-ueber-uns .site-main,
.page-template-template-karriere .site-main,
.page-template-template-kontakt .site-main{padding-top:0}

/* ══════════════════════════════════════
   CARDS — Spotlight Glow Effect
   ══════════════════════════════════════ */
.card{
  --x:50%;--y:50%;
  position:relative;background:#fff;border-radius:var(--radius);
  border:1px solid var(--border);padding:32px;
  transition:all var(--dur) var(--ease-out);
  overflow:hidden;
}
.card::before{
  content:'';position:absolute;inset:0;z-index:0;
  background:radial-gradient(600px circle at var(--x) var(--y),
    rgba(200,136,58,.07),rgba(74,124,46,.04) 40%,transparent 70%);
  opacity:0;transition:opacity var(--dur) ease;pointer-events:none;
}
.card:hover{
  box-shadow:var(--shadow-lg);transform:translateY(-4px);
  border-color:rgba(200,136,58,.2);
}
.card:hover::before{opacity:1}
.card>*{position:relative;z-index:1}
.card--image{padding:0;overflow:hidden}
.card--image .card__image-placeholder{border-radius:var(--radius) var(--radius) 0 0}
.card--image>div:last-child{padding:28px}
.card--flat{background:transparent;border:none;box-shadow:none}
.card--flat:hover{background:var(--cream);transform:none;box-shadow:none}
.card--partner{text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px;padding:28px 20px;}
.card__partner-logo{height:56px;width:auto;max-width:180px;object-fit:contain;}

/* ══════════════════════════════════════
   WELCOME GRID — Text with flanking images
   ══════════════════════════════════════ */
/* Welcome Split — Text links, Bilder rechts */
.welcome-split{
  display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;
}
.welcome-split__text{text-align:left}
.welcome-split__images{
  display:grid;grid-template-columns:1fr 1fr;gap:16px;
}
.welcome-split__img img{
  width:100%;height:100%;object-fit:cover;border-radius:var(--radius);
  box-shadow:var(--shadow-lg);
}
.welcome-split__img--top{
  animation:welcome-float-1 6s ease-in-out infinite;
}
.welcome-split__img--bottom{
  margin-top:32px;
  animation:welcome-float-2 7s ease-in-out infinite;
}
@keyframes welcome-float-1{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes welcome-float-2{0%,100%{transform:translateY(0)}50%{transform:translateY(10px)}}
@media(max-width:768px){
  .welcome-split{grid-template-columns:1fr;gap:40px}
  .welcome-split__images{grid-template-columns:1fr 1fr;gap:12px}
  .welcome-split__img--bottom{margin-top:20px}
}
@media(prefers-reduced-motion:reduce){
  .welcome-split__img--top,.welcome-split__img--bottom{animation:none}
}

/* ══════════════════════════════════════
   SPOTLIGHT GLOW CARDS
   Mouse-following radial gradient with hue shift.
   Based on Designelemente/Spotlight Cards Effekt.
   ══════════════════════════════════════ */
.spotlight-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.spotlight-grid--4{grid-template-columns:repeat(4,1fr)}
@media(max-width:1024px){.spotlight-grid,.spotlight-grid--4{grid-template-columns:repeat(2,1fr) !important}}
@media(max-width:768px){.spotlight-grid,.spotlight-grid--4{grid-template-columns:1fr !important}}
.spotlight-card{
  --x:50%;--y:50%;--glow-h:120;--glow-s:60%;--glow-l:50%;
  position:relative;border-radius:var(--radius);overflow:hidden;
  background:rgba(255,255,255,.8);backdrop-filter:blur(8px);
  border:1px solid var(--border);
  transition:transform var(--dur) var(--ease-out),box-shadow var(--dur) var(--ease-out);
}
.spotlight-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.spotlight-card[data-glow="green"]{--glow-h:100;--glow-s:65%;--glow-l:45%}
.spotlight-card[data-glow="amber"]{--glow-h:90;--glow-s:55%;--glow-l:50%}
.spotlight-card__glow{
  position:absolute;inset:0;z-index:0;opacity:0;
  background:radial-gradient(250px circle at var(--x) var(--y),
    hsla(var(--glow-h),var(--glow-s),var(--glow-l),.12),
    transparent 70%);
  transition:opacity .3s ease;pointer-events:none;
}
.spotlight-card:hover .spotlight-card__glow{opacity:1}
.spotlight-card__border{
  position:absolute;inset:0;z-index:0;opacity:0;
  border-radius:var(--radius);
  border:1px solid hsla(var(--glow-h),var(--glow-s),var(--glow-l),.25);
  transition:opacity .3s ease;pointer-events:none;
}
.spotlight-card:hover .spotlight-card__border{opacity:1}
.spotlight-card__content{position:relative;z-index:1;padding:40px 28px;text-align:center}

/* ══════════════════════════════════════
   ICON CIRCLES
   ══════════════════════════════════════ */
.icon-circle{
  width:64px;height:64px;border-radius:50%;
  background:linear-gradient(135deg,var(--bg-alt),var(--cream-dark));
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 20px;color:var(--forest);
  transition:all var(--dur) var(--ease-out);
}
.card:hover .icon-circle,.spotlight-card:hover .icon-circle{
  background:linear-gradient(135deg,var(--forest),var(--forest-light));
  color:#fff;transform:scale(1.1);
  box-shadow:0 8px 25px rgba(74,124,46,.25);
}

/* ══════════════════════════════════════
   SHIMMER TEXT — Headlines
   ══════════════════════════════════════ */
.shimmer-text{
  background:linear-gradient(110deg,
    var(--charcoal) 35%,
    var(--forest-light) 50%,
    var(--charcoal) 65%
  );
  background-size:200% 100%;
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  animation:shimmer 3s ease-in-out infinite;
}
@keyframes shimmer{
  0%{background-position:200% 0}
  100%{background-position:-200% 0}
}

/* ══════════════════════════════════════
   EXPANDING CARDS — Two Pillars
   ══════════════════════════════════════ */
.expanding-cards{display:flex;gap:12px;height:500px}
.expanding-card{
  flex:1;position:relative;border-radius:var(--radius);overflow:hidden;
  cursor:pointer;transition:flex var(--dur-slow) var(--ease-out);
  min-width:0;
}
.expanding-card.active{flex:5}
.expanding-card img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  filter:grayscale(.3);transition:filter var(--dur-slow) var(--ease-out);
}
.expanding-card.active img{filter:grayscale(0)}
.expanding-card::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to top,rgba(30,58,18,.85) 0%,rgba(30,58,18,.2) 50%,transparent);
}
.expanding-card__content{
  position:absolute;bottom:0;left:0;right:0;padding:36px;
  z-index:2;color:#fff;
  opacity:0;transform:translateY(20px);
  transition:all var(--dur-slow) var(--ease-out);
}
.expanding-card.active .expanding-card__content{opacity:1;transform:translateY(0)}
.expanding-card__title-vertical{
  position:absolute;bottom:24px;left:50%;z-index:2;
  color:#fff;font-family:var(--font-serif);font-size:.875rem;
  writing-mode:vertical-rl;text-orientation:mixed;
  transform:translateX(-50%);opacity:.8;
  transition:opacity var(--dur) ease;
}
.expanding-card.active .expanding-card__title-vertical{opacity:0}
@media(max-width:768px){
  .expanding-cards{flex-direction:column;height:auto !important}
  .expanding-card{min-height:200px;flex:none}
  .expanding-card.active{min-height:350px}
  .expanding-card__title-vertical{display:none}
  .expanding-card__content{opacity:1;transform:none}
}

/* ══════════════════════════════════════
   IMAGE ACCORDION — Interactive Panels
   ══════════════════════════════════════ */
.image-accordion{display:flex;gap:8px;height:450px;overflow:visible;justify-content:center;margin:0 auto;max-width:1000px;}
.image-accordion__panel{
  position:relative;flex:0 0 60px;overflow:hidden;cursor:pointer;
  transition:flex var(--dur-slow) var(--ease-out);
  border-radius:var(--radius);transform:none !important;
}
.image-accordion__panel.active{flex:0 0 400px}
.image-accordion__panel img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transform:scale(1.3);transition:transform var(--dur-slow) var(--ease-out);}
.image-accordion__panel.active img{transform:scale(1);}
.image-accordion__panel::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to top,rgba(30,58,18,.7) 0%,transparent 60%);
  transition:background var(--dur) ease;
}
.image-accordion__panel.active::after{background:linear-gradient(to top,rgba(30,58,18,.5) 0%,transparent 40%)}
.image-accordion__label{
  position:absolute;bottom:20px;left:50%;z-index:2;
  color:#fff;font-family:var(--font-serif);font-size:.8125rem;
  writing-mode:vertical-rl;transform:translateX(-50%) rotate(0);
  transition:all var(--dur-slow) var(--ease-out);white-space:nowrap;
}
.image-accordion__panel.active .image-accordion__label{
  writing-mode:horizontal-tb;bottom:auto;top:20px;left:24px;
  transform:none;font-size:1.25rem;
  text-shadow:0 2px 8px rgba(0,0,0,.5);
}
.image-accordion__text{
  position:absolute;bottom:24px;left:24px;right:24px;z-index:2;
  color:#fff;font-size:.875rem;line-height:1.6;
  opacity:0;transform:translateY(10px);
  transition:all var(--dur-slow) var(--ease-out);
}
.image-accordion__panel.active .image-accordion__text{opacity:1;transform:translateY(0)}
@media(max-width:768px){
  .image-accordion{flex-direction:column;height:auto}
  .image-accordion__panel{flex:none;height:60px;transition:height var(--dur-slow) var(--ease-out)}
  .image-accordion__panel.active{height:300px}
  .image-accordion__label{writing-mode:horizontal-tb;bottom:16px;left:16px;transform:none}
}

/* ══════════════════════════════════════
   FAQ ACCORDION
   ══════════════════════════════════════ */
.accordion{display:flex;flex-direction:column;gap:8px;max-width:800px;margin:0 auto}
.accordion__item{
  background:#fff;border-radius:var(--radius-sm);
  border:1px solid var(--border);overflow:hidden;
  transition:border-color var(--dur-fast) ease,box-shadow var(--dur) ease;
}
.accordion__item--open{border-color:rgba(74,124,46,.2);box-shadow:var(--shadow)}
.accordion__toggle{
  width:100%;display:flex;align-items:center;justify-content:space-between;
  padding:20px 24px;background:none;border:none;cursor:pointer;
  font-family:var(--font-sans);font-weight:600;font-size:1rem;
  color:var(--charcoal);text-align:left;gap:16px;
  transition:color var(--dur-fast) ease;
}
.accordion__toggle:hover{color:var(--forest)}
.accordion__toggle svg{
  flex-shrink:0;transition:transform var(--dur) var(--ease-out);color:var(--warmgray);
}
.accordion__item--open .accordion__toggle svg{transform:rotate(180deg);color:var(--forest)}
.accordion__content{
  max-height:0;overflow:hidden;
  transition:max-height var(--dur) var(--ease-out),padding var(--dur) var(--ease-out);
  padding:0 24px;
}
.accordion__item--open .accordion__content{max-height:600px;padding:0 24px 24px}
.accordion__content p{color:var(--warmgray);font-size:.9375rem;line-height:1.7}
.accordion__content p+p{margin-top:12px}

/* ══════════════════════════════════════
   QUOTE / HIGHLIGHT BOX
   ══════════════════════════════════════ */
.quote-box{
  max-width:800px;margin:0 auto;
  background:var(--bg-alt);
  border-radius:var(--radius);padding:clamp(28px,4vw,48px);
  border-left:4px solid var(--forest-light);
  position:relative;overflow:hidden;
}
.quote-box::before{
  content:'\201C';position:absolute;top:-10px;left:20px;
  font-family:var(--font-serif);font-size:8rem;line-height:1;
  color:var(--forest-light);opacity:.12;pointer-events:none;
}
.quote-text{
  font-family:var(--font-serif);font-size:clamp(1.0625rem,2vw,1.25rem);
  line-height:1.7;color:var(--charcoal);font-style:italic;
  position:relative;z-index:1;
}
.quote-author{display:block;margin-top:16px;font-style:normal;font-size:.9375rem;color:var(--warmgray)}

/* ══════════════════════════════════════
   TIMELINE — Steps
   ══════════════════════════════════════ */
.timeline{display:flex;flex-direction:column;max-width:700px;margin:0 auto}
.timeline__step{display:flex;gap:24px;align-items:flex-start;padding:28px 0;position:relative}
.timeline__step:not(:last-child)::after{
  content:'';position:absolute;left:23px;top:76px;bottom:0;
  width:2px;background:linear-gradient(to bottom,var(--forest-light),var(--border));
}
.timeline__number{
  flex-shrink:0;width:48px;height:48px;border-radius:50%;
  background:linear-gradient(135deg,var(--forest),var(--forest-light));
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-family:var(--font-serif);font-size:1.25rem;
  box-shadow:0 4px 15px rgba(74,124,46,.25);
  transition:transform var(--dur) var(--ease-spring);
}
.timeline__step:hover .timeline__number{transform:scale(1.1)}
.timeline__content h3{margin-bottom:6px}
.timeline__content p{line-height:1.7;color:var(--warmgray)}

/* ══════════════════════════════════════
   PROFILE CARD
   ══════════════════════════════════════ */
.profile{display:grid;grid-template-columns:auto 1fr;gap:48px;align-items:start}
@media(max-width:768px){.profile{grid-template-columns:1fr;gap:32px}.profile__image{margin:0 auto}}
.profile__image{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg)}
.profile__image img{width:280px;height:350px;object-fit:cover}
@media(max-width:768px){.profile__image img{width:200px;height:250px}}
.profile__role{color:var(--forest);font-weight:600;margin-bottom:20px;font-size:.9375rem}
.profile__table{
  width:100%;border-collapse:collapse;margin-top:24px;
  border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border);
}
.profile__table td{padding:12px 16px;border-bottom:1px solid var(--border);font-size:.9375rem}
.profile__table tr:last-child td{border-bottom:none}
.profile__table td:first-child{font-weight:600;color:var(--charcoal);width:35%;background:var(--cream)}
.profile__table td:last-child{color:var(--warmgray)}

/* ══════════════════════════════════════
   TAGS / PILLS
   ══════════════════════════════════════ */
.tag-list{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.tag{
  display:inline-block;padding:8px 20px;
  background:#fff;border:1px solid var(--border);
  border-radius:var(--radius-full);
  font-size:.875rem;color:var(--charcoal);
  transition:all var(--dur) var(--ease-out);cursor:default;
}
.tag:hover{
  background:var(--forest-light);color:#fff;border-color:var(--forest-light);
  transform:translateY(-2px);box-shadow:0 4px 12px rgba(124,179,66,.3);
}

/* ══════════════════════════════════════
   PARTNER LOGOS
   ══════════════════════════════════════ */
.partner-logos{display:flex;flex-wrap:wrap;gap:16px;justify-content:center}
.partner-logos__item{
  padding:20px 32px;background:#fff;
  border:1px solid var(--border);border-radius:var(--radius-sm);
  text-align:center;font-size:.875rem;font-weight:600;
  color:var(--charcoal);
  transition:all var(--dur) var(--ease-out);
}
.partner-logos__item:hover{border-color:var(--forest);box-shadow:var(--shadow);transform:translateY(-2px)}
.partner-logos__item small{font-weight:400;color:var(--warmgray);display:block;margin-top:4px;font-size:.75rem}

/* ══════════════════════════════════════
   PARALLAX IMAGE SECTION
   Background scrolls slower than content
   ══════════════════════════════════════ */
/* Parallax image section (standalone) */
.parallax-section{
  position:relative;height:45vh;min-height:300px;overflow:hidden;
}
.parallax-section__bg{
  position:absolute;inset:-20% 0;height:140%;
  background-size:cover;background-position:center 30%;
  background-attachment:fixed;
}
@media(max-width:768px){
  .parallax-section{height:35vh;min-height:220px}
  .parallax-section__bg{background-attachment:scroll;inset:0;height:100%}
}

/* Parallax Quote — Zitat mit Hintergrundbild */
.parallax-quote{
  position:relative;overflow:hidden;
  padding:clamp(80px,12vw,140px) 0;
}
.parallax-quote__bg{
  position:absolute;inset:-20% 0;height:140%;
  background-size:cover;background-position:center 30%;
  background-attachment:fixed;
}
.parallax-quote__overlay{
  position:absolute;inset:0;
  background:rgba(255,255,255,.15);
}
@media(max-width:768px){
  .parallax-quote__bg{background-attachment:scroll;inset:0;height:100%}
}

/* ══════════════════════════════════════
   LOGO CLOUD — Infinite Scroll
   Based on Designelemente/Logo Cloud
   ══════════════════════════════════════ */
.logo-cloud{
  overflow:hidden;padding:24px 0;
  -webkit-mask-image:linear-gradient(to right,transparent,black 10%,black 90%,transparent);
  mask-image:linear-gradient(to right,transparent,black 10%,black 90%,transparent);
}
.logo-cloud__track{
  display:flex;gap:48px;width:max-content;
  animation:logo-scroll 30s linear infinite;
}
.logo-cloud:hover .logo-cloud__track{animation-duration:60s}
.logo-cloud__item{
  white-space:nowrap;font-size:.9375rem;font-weight:600;
  color:var(--charcoal);opacity:.6;
  transition:opacity .3s ease;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
}
.logo-cloud__item img{
  height:72px !important;width:auto !important;max-width:200px;object-fit:contain;
  filter:grayscale(100%);opacity:.7;
  transition:filter .3s ease, opacity .3s ease;
}
.logo-cloud__item:hover img{filter:grayscale(0%);opacity:1}
.logo-cloud__item:hover{opacity:1}
.logo-cloud__divider{
  height:1px;max-width:400px;margin:0 auto;
  background:linear-gradient(to right,transparent,var(--border),transparent);
}
@keyframes logo-scroll{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
@media(prefers-reduced-motion:reduce){
  .logo-cloud__track{animation:none;flex-wrap:wrap;justify-content:center;width:auto}
}

/* ══════════════════════════════════════
   CONTACT GRID
   ══════════════════════════════════════ */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
@media(max-width:768px){.contact-grid{grid-template-columns:1fr;gap:32px}}
.contact-info{font-size:.9375rem;line-height:2}
.contact-info p+p{margin-top:16px}
.contact-info a{color:var(--forest);font-weight:500}
.contact-info a:hover{color:var(--forest-light)}

/* ══════════════════════════════════════
   PORTFOLIO GALLERY — 3D Overlapping
   Based on Designelemente/Portfolio Gallery
   ══════════════════════════════════════ */
.portfolio-gallery{
  position:relative;overflow:hidden;height:420px;margin-bottom:-160px;
}
.portfolio-gallery__track{
  display:flex;align-items:flex-end;justify-content:center;
  padding:40px 0 0;height:100%;
  gap:0;/* negative margin per card */
}
.portfolio-gallery__card{
  flex-shrink:0;width:clamp(200px,22vw,360px);
  aspect-ratio:16/10;border-radius:var(--radius-sm);overflow:hidden;
  transform:perspective(5000px) rotateY(-45deg) translateY(0px);
  transition:transform .25s var(--ease-out),box-shadow .25s ease;
  cursor:pointer;position:relative;
  margin-left:-70px;
  box-shadow:
    rgba(0,0,0,.01) .8px 0 .8px,
    rgba(0,0,0,.03) 2.4px 0 2.4px,
    rgba(0,0,0,.08) 6.4px 0 6.4px,
    rgba(0,0,0,.2) 16px 0 20px;
}
.portfolio-gallery__card:first-child{margin-left:0}
.portfolio-gallery__card img{width:100%;height:100%;object-fit:cover;object-position:center 30%}

/* Stagger: middle cards higher */
.portfolio-gallery__card[data-offset="0"]{transform:perspective(5000px) rotateY(-45deg) translateY(-20px);z-index:10}
.portfolio-gallery__card[data-offset="1"]{transform:perspective(5000px) rotateY(-45deg) translateY(-50px);z-index:9}
.portfolio-gallery__card[data-offset="2"]{transform:perspective(5000px) rotateY(-45deg) translateY(-80px);z-index:8}
.portfolio-gallery__card[data-offset="3"]{transform:perspective(5000px) rotateY(-45deg) translateY(-110px);z-index:7}
.portfolio-gallery__card[data-offset="4"]{transform:perspective(5000px) rotateY(-45deg) translateY(-120px);z-index:6}
.portfolio-gallery__card[data-offset="5"]{transform:perspective(5000px) rotateY(-45deg) translateY(-110px);z-index:5}
.portfolio-gallery__card[data-offset="6"]{transform:perspective(5000px) rotateY(-45deg) translateY(-80px);z-index:4}
.portfolio-gallery__card[data-offset="7"]{transform:perspective(5000px) rotateY(-45deg) translateY(-50px);z-index:3}
.portfolio-gallery__card[data-offset="8"]{transform:perspective(5000px) rotateY(-45deg) translateY(-20px);z-index:2}
.portfolio-gallery__card[data-offset="9"]{transform:perspective(5000px) rotateY(-45deg) translateY(0px);z-index:1}
.portfolio-gallery__card[data-offset="10"]{transform:perspective(5000px) rotateY(-45deg) translateY(20px);z-index:0}
.portfolio-gallery__card[data-offset="11"]{transform:perspective(5000px) rotateY(-45deg) translateY(40px);z-index:0}

/* Hover: lift card up */
.portfolio-gallery__card.gallery-hover{
  transform:perspective(5000px) rotateY(-45deg) translateY(-140px) scale(1.05) !important;
  z-index:20 !important;
  box-shadow:rgba(0,0,0,.15) 0 20px 40px,rgba(0,0,0,.08) 0 8px 16px;
}
/* Others shrink when one is hovered */
.portfolio-gallery.has-hover .portfolio-gallery__card:not(.gallery-hover){
  transform:perspective(5000px) rotateY(-45deg) translateY(0px) !important;
  opacity:.7;
}

@media(max-width:768px){.portfolio-gallery{display:none}}

/* Mobile: Marquee */
.portfolio-marquee{display:none;overflow:hidden;padding:16px 0;
  -webkit-mask-image:linear-gradient(to right,transparent,black 5%,black 95%,transparent);
  mask-image:linear-gradient(to right,transparent,black 5%,black 95%,transparent);
}
@media(max-width:768px){.portfolio-marquee{display:block}}
.portfolio-marquee__track{
  display:flex;gap:16px;width:max-content;
  animation:marquee-scroll 25s linear infinite;
}
.portfolio-marquee__track img{
  width:240px;height:160px;object-fit:cover;border-radius:var(--radius-sm);
  box-shadow:var(--shadow);flex-shrink:0;
}
@keyframes marquee-scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.portfolio-marquee__track{animation:none;flex-wrap:wrap}}

/* ══════════════════════════════════════
   CONTACT FORM
   ══════════════════════════════════════ */
.contact-form{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:32px;box-shadow:var(--shadow);
}
.form-group{margin-bottom:20px}
.form-group label{
  display:block;margin-bottom:6px;font-size:.875rem;font-weight:600;color:var(--charcoal);
}
.form-group input,.form-group select,.form-group textarea{
  width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:var(--radius-sm);
  font-family:var(--font-sans);font-size:.9375rem;color:var(--charcoal);
  background:var(--bg);transition:border-color var(--dur-fast) ease,box-shadow var(--dur-fast) ease;
  outline:none;resize:vertical;
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
  border-color:var(--forest-light);box-shadow:0 0 0 3px rgba(124,179,66,.15);
}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--muted)}
.form-group select{cursor:pointer;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%235A6B50' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;padding-right:40px;
}

/* ══════════════════════════════════════
   FADE IN ANIMATIONS
   ══════════════════════════════════════ */
.fade-in{opacity:0;transform:translateY(24px);transition:opacity var(--dur-slow) var(--ease-out),transform var(--dur-slow) var(--ease-out)}
.fade-in--visible{opacity:1;transform:translateY(0)}
.fade-in-stagger>*{opacity:0;transform:translateY(24px);transition:opacity var(--dur-slow) var(--ease-out),transform var(--dur-slow) var(--ease-out)}
.fade-in-stagger>*.fade-in--visible{opacity:1;transform:translateY(0)}
@media(prefers-reduced-motion:reduce){
  .fade-in,.fade-in-stagger>*{opacity:1;transform:none;transition:none}
  .shimmer-text{animation:none;-webkit-text-fill-color:var(--charcoal)}
  .hero__scroll-hint svg{animation:none}
}

/* ══════════════════════════════════════
   FOOTER
   ══════════════════════════════════════ */
.site-footer{background:var(--forest-dark);color:#fff;padding:80px 0 0}
.site-footer__inner{
  max-width:var(--max-site);margin:0 auto;
  padding:0 clamp(20px,4vw,64px) 48px;
  display:grid;grid-template-columns:1fr 2fr;gap:64px;
}
@media(max-width:768px){.site-footer__inner{grid-template-columns:1fr;gap:40px}}
.site-footer__logo-link{font-family:var(--font-serif);font-size:1.35rem;color:#fff;transition:color var(--dur-fast) ease}
.site-footer__logo-link:hover{color:var(--forest-light)}
.site-footer__tagline{margin-top:8px;color:var(--forest-light);font-size:.9375rem}
.site-footer__nav{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
@media(max-width:768px){.site-footer__nav{grid-template-columns:1fr 1fr}}
.site-footer__heading{
  font-size:.75rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.12em;color:var(--forest-light);margin-bottom:16px;
}
.site-footer__col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.site-footer__col ul li,.site-footer__col ul li a{font-size:.9rem;color:rgba(255,255,255,.6);transition:color var(--dur-fast) ease}
.site-footer__col ul li a:hover{color:#fff}
.site-footer__bottom{
  border-top:1px solid rgba(255,255,255,.08);
  max-width:var(--max-site);margin:0 auto;
  padding:20px clamp(20px,4vw,64px);
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;
}
.site-footer__bottom p{font-size:.8125rem;color:rgba(255,255,255,.35)}
.site-footer__certs{display:flex;align-items:center;gap:20px;}
.site-footer__certs img{height:40px;width:auto;opacity:.7;transition:opacity .3s ease;border-radius:4px;background:rgba(255,255,255,.9);padding:4px;}
.site-footer__certs img:hover{opacity:1;}

/* ══════════════════════════════════════
   UTILITY
   ══════════════════════════════════════ */
::selection{background:var(--forest-light);color:#fff}
:focus-visible{outline:2px solid var(--forest);outline-offset:2px;border-radius:4px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* Custom cursor removed */

/* ══════════════════════════════════════
   3D TILT IMAGES
   ══════════════════════════════════════ */
.tilt-image{
  transition:transform .2s var(--ease-out);
  will-change:transform;
}

/* ══════════════════════════════════════
   LEGAL CONTENT — Impressum / Datenschutz
   ══════════════════════════════════════ */
.legal-content h2{font-family:var(--font-serif);font-size:1.75rem;margin:48px 0 16px;color:var(--charcoal);}
.legal-content h2:first-child{margin-top:0;}
.legal-content h3{font-size:1.125rem;font-weight:600;margin:32px 0 12px;color:var(--charcoal);}
.legal-content p{font-size:.9375rem;line-height:1.8;color:var(--muted);margin-bottom:16px;}
.legal-content a{color:var(--forest);font-weight:500;}
.legal-content a:hover{color:var(--forest-light);}

/* ══════════════════════════════════════
   IMAGE ZOOM ON HOVER (Cards)
   ══════════════════════════════════════ */
.card img,.spotlight-card img{transition:transform .5s var(--ease-out)}
.card:hover img,.spotlight-card:hover img{transform:scale(1.06)}
.card--partner:hover .card__partner-logo{transform:none}

/* ══════════════════════════════════════
   ANIMAL CARDS — Tier-Karten Grid
   ══════════════════════════════════════ */
.animal-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
}
.animal-card{
  position:relative;border-radius:var(--radius);overflow:hidden;
  aspect-ratio:3/4;cursor:pointer;
}
.animal-card__img{position:absolute;inset:0;}
.animal-card__img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .6s var(--ease-out);
}
.animal-card:hover .animal-card__img img{transform:scale(1.08)}
.animal-card__info{
  position:absolute;bottom:0;left:0;right:0;z-index:2;
  padding:20px;
  background:linear-gradient(to top,rgba(0,0,0,.65) 0%,rgba(0,0,0,.2) 60%,transparent 100%);
  transition:background .4s ease;
}
.animal-card:hover .animal-card__info{
  background:linear-gradient(to top,rgba(0,0,0,.75) 0%,rgba(0,0,0,.35) 70%,transparent 100%);
}
.animal-card__name{
  font-family:var(--font-serif);font-size:1.125rem;color:#fff;
  margin:0;
}
.animal-card__details{
  font-size:.8125rem;color:rgba(255,255,255,.85);
  margin:0;line-height:1.5;
  max-height:0;opacity:0;overflow:hidden;
  transition:max-height .4s ease, opacity .4s ease, margin .4s ease;
}
.animal-card:hover .animal-card__details{
  max-height:60px;opacity:1;margin-top:6px;
}
@media(max-width:1024px){.animal-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:768px){.animal-grid{grid-template-columns:repeat(2,1fr);gap:12px}}
@media(max-width:480px){.animal-grid{grid-template-columns:repeat(2,1fr);gap:8px}}

/* ══════════════════════════════════════
   PHOTO GRID — Compact Gallery with Hover Zoom
   ══════════════════════════════════════ */
.photo-grid{
  display:grid;grid-template-columns:repeat(6,1fr);gap:4px;
}
.photo-grid__item{
  overflow:hidden;border-radius:4px;aspect-ratio:1/1;
  cursor:pointer;position:relative;
}
.photo-grid__item img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .5s var(--ease-out), filter .3s ease;
  filter:brightness(.9);
}
.photo-grid__item:hover img{
  transform:scale(1.15);filter:brightness(1);
}
.photo-grid__item:hover{z-index:10;box-shadow:0 8px 30px rgba(0,0,0,.3);}
@media(max-width:1024px){.photo-grid{grid-template-columns:repeat(4,1fr)}}
@media(max-width:768px){.photo-grid{grid-template-columns:repeat(3,1fr)}}

/* ══════════════════════════════════════
   JOB SLIDER — Animated Slideshow
   ══════════════════════════════════════ */
.job-slider{
  display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;
  min-height:400px;
}
.job-slider__titles{display:flex;flex-direction:column;gap:8px;}
.job-slider__title{
  all:unset;cursor:pointer;
  font-family:var(--font-serif);font-size:clamp(1.25rem,2.5vw,1.75rem);
  color:var(--charcoal);opacity:.35;
  padding:16px 0;border-bottom:1px solid transparent;
  transition:opacity .4s ease, border-color .4s ease, padding-left .4s ease;
  position:relative;
}
.job-slider__title:hover{opacity:.6}
.job-slider__title.active{
  opacity:1;border-bottom-color:var(--forest);padding-left:16px;
}
.job-slider__title.active::before{
  content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:4px;height:60%;background:var(--forest);border-radius:2px;
}
.job-slider__cards{position:relative;min-height:420px;}
.job-slider__card{
  position:absolute;inset:0;
  background:#fff;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-lg);
  opacity:0;transform:translateY(20px);
  transition:opacity .5s ease, transform .5s ease;
  pointer-events:none;
  display:flex;flex-direction:column;
}
.job-slider__card.active{
  opacity:1;transform:translateY(0);pointer-events:auto;
  position:relative;
}
.job-slider__card img{
  width:100%;height:220px;object-fit:cover;
}
.job-slider__card-content{
  padding:24px;
}
.job-slider__card-content h3{
  font-family:var(--font-serif);font-size:1.25rem;margin-bottom:12px;
  color:var(--charcoal);
}
.job-slider__card-content p{
  font-size:.875rem;line-height:1.7;color:var(--muted);margin-bottom:8px;
}
.job-slider__card-content p:last-child{margin-bottom:0}
@media(max-width:768px){
  .job-slider{grid-template-columns:1fr;gap:24px;min-height:auto;}
  .job-slider__titles{flex-direction:column;gap:4px;}
  .job-slider__title{font-size:1.125rem;padding:12px 0;}
  .job-slider__title.active{padding-left:12px;}
  .job-slider__cards{min-height:auto;}
  .job-slider__card{position:relative;opacity:0;max-height:0;overflow:hidden;transform:none;transition:max-height .4s ease, opacity .4s ease;}
  .job-slider__card.active{opacity:1;max-height:600px;position:relative;}
}

/* ══════════════════════════════════════
   MAGNETIC BUTTONS — reset transition
   ══════════════════════════════════════ */
.btn{transition:all var(--dur) var(--ease-out),transform .15s ease-out}

/* ══════════════════════════════════════
   VISUAL ENHANCEMENTS v2.1
   ══════════════════════════════════════ */

/* 1. Animated Hero Gradient */
.hero { background-size: 300% 300%; animation: hero-gradient 12s ease infinite; }
@keyframes hero-gradient { 0%{background-position:0% 50%} 50%{background-position:100% 50%} 100%{background-position:0% 50%} }

/* 2. Grain Texture Overlay */
body::before { content:''; position:fixed; inset:0; z-index:9999; pointer-events:none; opacity:.03;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
}

/* 3. SVG Wave Separators */
.wave-separator { position:relative; height:80px; overflow:hidden; margin-top:-1px; }
.wave-separator svg { position:absolute; bottom:0; width:100%; height:80px; }
.wave-separator--cream svg { fill: #F5F0E8; }
.wave-separator--white svg { fill: #FDFBF7; }
.wave-separator--green svg { fill: #2E5E1A; }

/* 4. Enhanced Cards */
.card { background: linear-gradient(135deg, #fff 0%, #FDFBF7 100%); }
.card:hover { border-color: transparent; background: linear-gradient(135deg, #fff 0%, #F5F0E8 100%); box-shadow: 0 20px 50px rgba(44,36,24,.15), 0 0 0 1px rgba(200,136,58,.15); }

/* 5. Hero Decorative Elements */
.hero__decoration { position:absolute; border-radius:50%; opacity:.08; z-index:0; }
.hero__decoration--1 { width:400px; height:400px; top:-100px; right:-100px; background:radial-gradient(circle,var(--forest-light),transparent 70%); animation: float 8s ease-in-out infinite; }
.hero__decoration--2 { width:300px; height:300px; bottom:-80px; left:-80px; background:radial-gradient(circle,var(--forest-light),transparent 70%); animation: float 10s ease-in-out infinite reverse; }
@keyframes float { 0%,100%{transform:translate(0,0)} 50%{transform:translate(20px,-20px)} }

/* 6. Section Divider Line */
.section-divider { width:80px; height:3px; margin:0 auto 32px; background:linear-gradient(to right,var(--forest-light),var(--forest)); border-radius:3px; }

/* 7. Enhanced Icon Circles */
.icon-circle { box-shadow: 0 0 0 8px rgba(74,124,46,.06); }
.card:hover .icon-circle { box-shadow: 0 0 0 12px rgba(74,124,46,.1), 0 8px 25px rgba(74,124,46,.2); }

/* 8. Tag Hover Animation */
.tag { backdrop-filter: blur(4px); background: rgba(255,255,255,.8); }

/* 9. Timeline Enhanced Connector Glow */
.timeline__step:not(:last-child)::after { box-shadow: 0 0 8px rgba(107,143,113,.3); }

/* 10. Quote Box Enhanced */
.quote-box { background: linear-gradient(135deg, var(--cream) 0%, rgba(200,136,58,.05) 100%); box-shadow: var(--shadow); }

/* 11. Partner Logos Enhanced */
.partner-logos__item { background: linear-gradient(135deg, #fff, var(--cream-light)); backdrop-filter: blur(4px); }

/* 12. Contact Info Enhanced */
.contact-info { background: #fff; padding: 32px; border-radius: var(--radius); border: 1px solid var(--border); box-shadow: var(--shadow-sm); }

/* 13. Accordion Enhanced Hover */
.accordion__toggle:hover { background: var(--cream); border-radius: var(--radius-sm); }

/* 14. Footer Enhanced */
.site-footer { background: linear-gradient(180deg, #2E5E1A 0%, #142018 100%); position:relative; }
.site-footer::before { content:''; position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(to right,transparent,var(--forest-light),transparent); }

/* 15. Button Ripple Effect */
.btn { position:relative; overflow:hidden; }
.btn::before { content:''; position:absolute; inset:0; background:radial-gradient(circle at var(--x,50%) var(--y,50%),rgba(255,255,255,.3),transparent 60%); opacity:0; transition:opacity .3s; }
.btn:active::before { opacity:1; }
