/* Self-hosted Playfair Display + Manrope (latin + latin-ext). */
/* DSGVO-konform: keine Drittanbieter-Anfragen, kein IP-Transfer. */

@font-face{font-family:'Playfair Display';font-style:normal;font-weight:400;font-display:swap;
  src:url('../fonts/playfair-display-400-latin.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Playfair Display';font-style:italic;font-weight:400;font-display:swap;
  src:url('../fonts/playfair-display-400i-latin.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}

@font-face{font-family:'Manrope';font-style:normal;font-weight:100 900;font-display:swap;
  src:url('../fonts/manrope-400-latin-ext.woff2') format('woff2');
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Manrope';font-style:normal;font-weight:100 900;font-display:swap;
  src:url('../fonts/manrope-400-latin.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}

/* ================================================================
   Sequel-style baseline: Manrope sans + Playfair serif on dark canvas.
   Tokens (--bg-deep, --bone, etc.) come from the inline critical CSS.
   ================================================================ */
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
html.lenis{height:auto}
html.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-stopped,
.lenis.lenis-locked{overflow:clip}
body{
  font-family:'Manrope',system-ui,sans-serif;
  background:var(--bg-deep);
  color:var(--ink);
  font-size:17px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  -webkit-tap-highlight-color:transparent;
}
a,button{-webkit-tap-highlight-color:transparent;touch-action:manipulation}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}

.serif{font-family:'Playfair Display',Georgia,serif;font-weight:400;letter-spacing:-0.025em;line-height:1.05}
.eyebrow{
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:600;
  color:var(--green-deep);
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:24px;height:1px;background:currentColor;opacity:.6}
.eyebrow.center{justify-content:center}
.eyebrow.center::before{display:none}

/* ======================== GLASS PRIMITIVE ========================
   Light-theme frosted glass — used on hero pill, badges, contact
   cards, ba-tags, FAQ side button. */
/* iOS-style frosted noise texture — applied via ::before to any glass surface.
   Reusable: opacity, blend-mode, and border-radius:inherit clip it correctly. */
:root{
  --glass-noise:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.92' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1   0 0 0 0 1   0 0 0 0 1   0 0 0 1 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/></svg>");
}
.glass{
  position:relative;
  background:rgba(255,255,255,.28);
  backdrop-filter:blur(40px) saturate(200%);
  -webkit-backdrop-filter:blur(40px) saturate(200%);
  border:1px solid rgba(255,255,255,.4);
  box-shadow:0 8px 32px rgba(45,74,47,0.08), inset 0 1px 0 0 rgba(255,255,255,.5);
  isolation:isolate;
}
.glass::before{
  content:"";
  position:absolute;inset:0;
  background-image:var(--glass-noise);
  background-size:240px 240px;
  opacity:.07;
  mix-blend-mode:overlay;
  pointer-events:none;
  border-radius:inherit;
  z-index:0;
}
.glass > *{position:relative;z-index:1}
.glass.badge{
  display:inline-flex;align-items:center;
  padding:6px 14px;border-radius:9999px;
  color:var(--green-deep);font-size:11px;font-weight:600;letter-spacing:.07em;
  text-transform:uppercase;
  white-space:nowrap;
}

/* ======================== NAV ========================
   Floating glass-pill — inset 16px from the viewport edges, max-width
   centred, frosted-light backdrop for the green theme. */
.nav{
  position:fixed;
  top:16px;left:16px;right:16px;z-index:60;
  padding:10px 24px;
  display:flex;align-items:center;justify-content:space-between;
  /* Same glass formula as the (now-removed) hero-eyebrow pill. */
  background:rgba(255,255,255,.18);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  border:1px solid rgba(255,255,255,.32);
  border-radius:9999px;
  box-shadow:rgba(0,0,0,0.18) 0px 10px 30px 0px, rgba(255,255,255,0.18) 0px 1px 0px 0px inset;
  transition:padding .35s ease, top .35s ease, background .35s ease, box-shadow .35s ease;
  max-width:calc(1200px + 32px);
  margin-inline:auto;
  isolation:isolate;
}
.nav::before{
  content:"";
  position:absolute;inset:0;
  background-image:var(--glass-noise);
  background-size:240px 240px;
  opacity:.06;
  mix-blend-mode:overlay;
  pointer-events:none;
  border-radius:inherit;
  z-index:-1;
}
.nav.scrolled{
  background:rgba(255,255,255,.32);
  padding:8px 22px;
  top:12px;
  box-shadow:rgba(0,0,0,0.22) 0px 12px 32px 0px, rgba(255,255,255,0.24) 0px 1px 0px 0px inset;
}
.nav-logo{display:flex;align-items:center;gap:10px;color:var(--green-deep);transition:color .4s}
.nav-logo img{height:30px;width:auto}
.nav-logo-txt{font-family:'Playfair Display',serif;font-size:16px;font-weight:500;letter-spacing:-0.01em;color:var(--green-deep)}
.nav-logo-txt small{display:block;font-family:'Manrope',sans-serif;font-size:8px;letter-spacing:0.18em;text-transform:uppercase;font-weight:600;opacity:.7;margin-top:1px}

.nav-links{display:flex;gap:4px;align-items:center}
.nav-links a{
  font-family:'Manrope',sans-serif;
  font-size:13px;font-weight:500;letter-spacing:0;
  color:var(--green-deep);
  position:relative;padding:8px 14px;
  border-radius:9999px;
  transition:background .3s, color .3s;
}
.nav-links a:hover{background:rgba(92,139,95,.10);color:var(--green)}

.nav-cta{
  padding:9px 20px;border-radius:9999px;
  background:var(--green);color:var(--white)!important;
  border:1px solid transparent;
  font-family:'Manrope',sans-serif;
  font-weight:500;font-size:13px;letter-spacing:0;
  transition:background .3s, transform .3s, box-shadow .3s;
}
.nav-cta:hover{background:var(--green-deep);transform:translateY(-1px);box-shadow:0 8px 20px rgba(45,74,47,.18)}
.nav-cta-mobile{display:none}

/* Skip-Link (WCAG 2.4.1) */
.skip-link{
  position:absolute;left:-9999px;top:0;z-index:200;
  background:var(--green);color:var(--white);
  padding:12px 18px;font-weight:600;font-size:14px;
  border-radius:0 0 6px 0;
}
.skip-link:focus{left:0;top:0;outline:2px solid var(--green-deep);outline-offset:2px}

/* Global focus-visible (WCAG 2.4.7) */
a:focus-visible,
button:focus-visible,
summary:focus-visible{outline:2px solid var(--green);outline-offset:3px;border-radius:3px}

/* Hamburger toggle */
.nav-toggle{
  display:none;
  width:40px;height:40px;
  align-items:center;justify-content:center;
  border-radius:50%;
  background:transparent;color:var(--green-deep);
  transition:background .3s, color .3s, opacity .25s;
  margin-left:6px;
  position:relative;z-index:62;
}
body.nav-open .nav-toggle{color:var(--green-deep)}
body.nav-open .nav-toggle:hover{background:rgba(92,139,95,.12)}
.nav-toggle:hover{background:rgba(92,139,95,.12)}
.nav-toggle-bars{display:inline-block;width:22px;height:14px;position:relative}
.nav-toggle-bars span{
  position:absolute;left:0;right:0;height:2px;
  background:currentColor;border-radius:1px;
  transition:transform .35s cubic-bezier(.7,0,.2,1), opacity .25s, top .35s cubic-bezier(.7,0,.2,1);
}
.nav-toggle-bars span:nth-child(1){top:0}
.nav-toggle-bars span:nth-child(2){top:6px}
.nav-toggle-bars span:nth-child(3){top:12px}
.nav-toggle[aria-expanded="true"] .nav-toggle-bars span:nth-child(1){top:6px;transform:rotate(45deg)}
.nav-toggle[aria-expanded="true"] .nav-toggle-bars span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] .nav-toggle-bars span:nth-child(3){top:6px;transform:rotate(-45deg)}

.nav-backdrop{
  position:fixed;inset:0;z-index:59;
  background:rgba(45,74,47,.35);
  opacity:0;pointer-events:none;
  transition:opacity .35s ease;
  -webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);
}
body.nav-open .nav-backdrop{opacity:1;pointer-events:auto}
body.nav-open{overflow:hidden}

@media (max-width:900px){
  /* Mobile: nav becomes a vertically expanding glass-pill that grows
     downward when the burger is tapped. Links sit inside the same surface. */
  .nav{
    padding:8px 18px;top:12px;left:12px;right:12px;
    flex-wrap:wrap;
    overflow:hidden;
    will-change:max-height,border-radius,background;
    /* default (closed): height clamps to the logo+toggle row */
    max-height:60px;
    /* Apple-style ease-out-expo for a graceful settle */
    transition:padding .35s ease, top .35s ease,
               background .55s cubic-bezier(.16,1,.3,1),
               box-shadow .55s cubic-bezier(.16,1,.3,1),
               max-height .58s cubic-bezier(.16,1,.3,1),
               border-radius .58s cubic-bezier(.16,1,.3,1);
  }
  .nav.scrolled{padding:6px 16px;top:10px;max-height:54px}
  .nav-cta-desktop{display:none}
  .nav-toggle{display:inline-flex}
  .nav-logo-txt{font-size:14px}
  .nav-logo-txt small{font-size:8px}

  /* Links: in-flow inside the nav, hidden by default.
     order:99 forces them to wrap to row 2 so logo+toggle stay on row 1. */
  .nav-links{
    order:99;
    display:flex;flex-direction:column;gap:0;
    position:static;
    width:100%;flex-basis:100%;
    background:transparent;
    backdrop-filter:none;
    -webkit-backdrop-filter:none;
    padding:6px 8px 8px;
    margin-top:8px;
    border-top:1px solid rgba(45,74,47,.10);
    transform:none;
    box-shadow:none;
    overflow-y:auto;
    border-radius:0;
    visibility:hidden;
    opacity:0;
    pointer-events:none;
    transition:opacity .25s ease, visibility 0s linear .25s;
  }

  /* Open state: nav expands, links reveal. */
  body.nav-open .nav{
    max-height:420px;
    border-radius:28px;
    background:rgba(255,255,255,.55);
  }
  body.nav-open .nav.scrolled{
    background:rgba(255,255,255,.62);
  }
  body.nav-open .nav-links{
    visibility:visible;
    opacity:1;
    pointer-events:auto;
    transition:opacity .4s cubic-bezier(.16,1,.3,1) .08s, visibility 0s linear 0s;
  }

  .nav-links a{
    color:var(--green-deep)!important;
    font-size:16px;font-weight:500;
    padding:14px 8px;
    border-bottom:1px solid rgba(45,74,47,.08);
    border-radius:0;
    width:100%;
    /* subtle stagger fade-in per item */
    opacity:0;transform:translateY(-8px);
    transition:opacity .42s cubic-bezier(.16,1,.3,1),
               transform .55s cubic-bezier(.16,1,.3,1),
               color .25s, background .25s;
  }
  .nav-links a:last-child{border-bottom:0}
  body.nav-open .nav-links a{opacity:1;transform:none}
  body.nav-open .nav-links a:nth-child(1){transition-delay:.10s}
  body.nav-open .nav-links a:nth-child(2){transition-delay:.13s}
  body.nav-open .nav-links a:nth-child(3){transition-delay:.16s}
  body.nav-open .nav-links a:nth-child(4){transition-delay:.19s}
  body.nav-open .nav-links a:nth-child(5){transition-delay:.22s}
  .nav-links a:hover{background:transparent!important;color:var(--green)!important}

  a.nav-cta-mobile,
  .nav-links a.nav-cta-mobile{
    display:inline-flex;align-items:center;justify-content:center;
    margin-top:14px;width:100%;
    padding:14px 20px;border-radius:9999px;
    background:var(--green)!important;color:var(--white)!important;
    border:none!important;
    font-size:15px;font-weight:500;
    border-bottom:0!important;
  }
  a.nav-cta-mobile:hover,
  .nav-links a.nav-cta-mobile:hover{
    background:var(--green-deep)!important;color:var(--white)!important;
  }
}

/* ======================== SECTION SCAFFOLDING ======================== */
.section{
  position:relative;
  padding:96px 40px;
  background:var(--bg-deep);
  color:var(--ink);
}
.section-inner{
  max-width:1280px;margin:0 auto;
  display:flex;flex-direction:column;gap:64px;
}
#leistungen,
#prinzipien,
#projekte,
#vorher-nachher,
#region,
#faq,
#kontakt{
  scroll-margin-top:118px;
}
@media (max-width:900px){
  #leistungen,
  #prinzipien,
  #projekte,
  #vorher-nachher,
  #region,
  #faq,
  #kontakt{scroll-margin-top:92px}
}
.section-head{display:flex;flex-direction:column;gap:16px;max-width:640px}
.section-head h2{
  font-family:'Playfair Display',serif;font-weight:400;
  font-size:clamp(40px,6vw,80px);line-height:1;letter-spacing:-0.04em;
  color:var(--green-deep);
}
.section-head h2 .ital{font-style:italic;color:var(--green)}
.section-head p{
  font-size:16px;line-height:1.55;
  color:var(--mute);max-width:560px;
}
.section-head-center{margin:0 auto;text-align:center;align-items:center}
.section-head-center p{margin:0 auto}

/* Reusable button variants */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:12px 24px;border-radius:9999px;
  font-family:'Manrope',sans-serif;
  font-weight:500;font-size:14px;letter-spacing:0;
  transition:all .35s cubic-bezier(.2,.8,.2,1);
  white-space:nowrap;line-height:1.4;
}
.btn-primary,
.btn-default{background:var(--green);color:var(--white)}
.btn-primary:hover,
.btn-default:hover{background:var(--green-deep);color:var(--white);transform:translateY(-1px);box-shadow:0 8px 24px rgba(45,74,47,.28)}
.btn-glass{
  background:rgba(255,255,255,.6);color:var(--green-deep);
  border:1px solid rgba(255,255,255,.5);
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  box-shadow:0 8px 32px rgba(45,74,47,0.08), rgba(255,255,255,0.5) 0px 1px 0px 0px inset;
}
.btn-glass:hover{background:rgba(255,255,255,.85);transform:translateY(-1px)}
.btn .arrow{display:inline-flex;width:14px;height:14px}

/* ======================== SECTION 1 — HERO ======================== */
.hero{
  position:relative;
  min-height:100svh;
  background:var(--bg-deep);
  color:var(--white);
  overflow:hidden;
  isolation:isolate;
  padding:0;
}
.hero-bg{
  position:absolute;inset:0;z-index:0;
  background-image:url('../hero-bg.webp');
  background-size:cover;background-position:55% 60%;
  transform:scale(1.06);
  filter:saturate(1.05) contrast(1.05);
}
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.05) 0%,rgba(0,0,0,.15) 50%,rgba(0,0,0,.55) 100%);
}
@media (max-width:1100px){
  .hero-bg{
    background-image:url('../hero-bg-mobile.webp?v=20260508l');
    background-position:50% 35%;
  }
}
.hero-grain{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.45 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/></svg>");
  opacity:.18;mix-blend-mode:overlay;
}

/* Foreground bush cutouts that frame the hero from the bottom corners.
   GSAP scrolls them outward (xPercent ±60) as you scroll past the hero,
   creating a "split-curtain" reveal of the section below. */
.hero-bush{
  position:absolute;
  bottom:-22%;
  z-index:2;
  width:52%;max-width:720px;
  height:auto;
  pointer-events:none;
  user-select:none;
  filter:drop-shadow(0 12px 24px rgba(0,0,0,.18));
  will-change:transform;
}
.hero-bush-left{ left:-22%; transform-origin:bottom left; }
.hero-bush-right{ right:-22%; transform-origin:bottom right; }
@media (max-width:900px){
  .hero-bush{ width:68%; bottom:-26%; }
  .hero-bush-left{ left:-28%; }
  .hero-bush-right{ right:-28%; }
}
@media (max-width:600px){
  .hero-bush{ width:78%; bottom:-30%; }
}
.hero-inner{
  position:relative;z-index:2;
  min-height:100svh;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;
  padding:128px 32px 96px;
  gap:24px;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:14px;
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--white);font-weight:500;
  padding:8px 16px;border-radius:9999px;
  background:rgba(255,255,255,.18);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  border:1px solid rgba(255,255,255,.32);
  box-shadow:rgba(0,0,0,0.18) 0px 10px 30px 0px, rgba(255,255,255,0.18) 0px 1px 0px 0px inset;
}
.hero-eyebrow .dot{
  width:6px;height:6px;border-radius:50%;background:var(--white);
  box-shadow:0 0 0 4px rgba(255,255,255,.28);
}
.hero h1{
  font-family:'Playfair Display',serif;
  font-weight:400;
  font-size:clamp(48px,9vw,128px);
  line-height:1;
  letter-spacing:-0.04em;
  margin:0;
  color:var(--white);
  max-width:14ch;
}
.hero h1 .ital{font-style:italic;font-weight:400;color:rgba(255,255,255,.82)}
.hero h1 .line{display:block;overflow:hidden;padding-bottom:.06em;animation:revealOverflow 0s 1.5s forwards}
.hero h1 .line span{display:inline-block;animation:lineUp 1s cubic-bezier(.2,.8,.2,1) backwards}
.hero h1 .line:nth-child(1) span{animation-delay:.1s}
.hero h1 .line:nth-child(2) span{animation-delay:.25s}
@keyframes lineUp{from{transform:translateY(110%);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes revealOverflow{to{overflow:visible}}

.hero-sub{
  font-size:17px;line-height:1.55;
  max-width:560px;color:rgba(255,255,255,.85);
  margin:0 auto;
  opacity:0;animation:fadeUp 1s .7s cubic-bezier(.2,.8,.2,1) forwards;
}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

.hero-actions{
  display:flex;gap:12px;flex-wrap:wrap;align-items:center;justify-content:center;
  margin-top:8px;
}

.hero-pill{
  position:absolute;right:32px;bottom:40px;z-index:3;
  display:inline-flex;align-items:center;gap:10px;
  padding:10px 18px;border-radius:9999px;
  background:rgba(255,255,255,.18);color:var(--white);
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-weight:500;
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  border:1px solid rgba(255,255,255,.32);
  box-shadow:rgba(0,0,0,0.18) 0px 10px 30px 0px, rgba(255,255,255,0.18) 0px 1px 0px 0px inset;
  opacity:0;animation:fadeUp .8s 1.6s cubic-bezier(.2,.8,.2,1) forwards;
}
.hero-pill .dot{width:6px;height:6px;border-radius:50%;background:var(--white);box-shadow:0 0 0 4px rgba(255,255,255,.28)}

@media (max-width:900px){.hero-pill{display:none}}
@media (max-width:600px){
  .hero-inner{padding:120px 22px 64px;gap:18px}
  .hero h1{font-size:clamp(40px,12vw,68px);letter-spacing:-.03em}
  .hero-sub{font-size:15px}
  .hero-actions{width:100%}
  .hero-actions .btn{flex:1 1 auto;justify-content:center}
}

/* ======================== SECTION 2 — TWO HOMECARD FEATURES ======================== */
.section2{position:relative;padding:96px 40px;overflow:hidden}
/* Decorative side patterns flanking the polaroid stack — subtle dotted
   leaf-grid in sage green, fades out toward the centre. */
.section2::before,
.section2::after{
  content:"";position:absolute;top:0;bottom:0;width:18%;
  pointer-events:none;z-index:0;
  background-image:
    radial-gradient(circle at 50% 50%, rgba(92,139,95,.32) 1.5px, transparent 2.2px),
    radial-gradient(circle at 50% 50%, rgba(92,139,95,.18) 1.5px, transparent 2.2px);
  background-size:28px 28px, 28px 28px;
  background-position:0 0, 14px 14px;
}
.section2::before{
  left:0;
  -webkit-mask-image:linear-gradient(to right, rgba(0,0,0,.95) 0%, rgba(0,0,0,0) 100%);
          mask-image:linear-gradient(to right, rgba(0,0,0,.95) 0%, rgba(0,0,0,0) 100%);
}
.section2::after{
  right:0;
  -webkit-mask-image:linear-gradient(to left, rgba(0,0,0,.95) 0%, rgba(0,0,0,0) 100%);
          mask-image:linear-gradient(to left, rgba(0,0,0,.95) 0%, rgba(0,0,0,0) 100%);
}
.section2 > .section-inner{position:relative;z-index:1;gap:24px}
@media (max-width:760px){
  .section2::before,.section2::after{width:10%;background-size:20px 20px,20px 20px}
}
/* On-photo glass badges/buttons (founders, ba-tag) keep white text. */
.founders-card .glass.badge,
.ba-tag.glass{
  background:rgba(255,255,255,.18);
  color:var(--white);
  border:1px solid rgba(255,255,255,.32);
  box-shadow:rgba(0,0,0,0.18) 0px 10px 30px 0px, rgba(255,255,255,0.18) 0px 1px 0px 0px inset;
}

/* ======================== SERVICES SWIPE STACK ========================
   6 photo cards stacked like a deck. Top card is interactive — drag/swipe
   left or right to dismiss it; the next card slides forward. Buttons +
   dots provide non-touch / accessibility navigation. */
.svc-stack-wrap{
  display:flex;flex-direction:column;align-items:center;gap:20px;
  padding:8px 0 24px;
}
.svc-stack{
  position:relative;
  width:min(82vw,360px);
  max-height:62svh;
  aspect-ratio:4/5;
  perspective:1200px;
}
.svc-photo{
  /* CSS-only polaroid frame: white card, photo inset at cutout coords,
     caption in the bottom white strip. No PNG overlay. */
  position:absolute;inset:0;
  background:#fff;
  border-radius:4px;
  box-shadow:0 18px 32px rgba(45,74,47,.22), 0 4px 8px rgba(45,74,47,.14);
  transform-origin:50% 50%;
  user-select:none;
  -webkit-user-select:none;
  touch-action:pan-y;
  cursor:grab;
  transition:transform .55s cubic-bezier(.16,1,.3,1), opacity .35s ease;
  will-change:transform;
  overflow:hidden;
}
.svc-photo.is-dragging{ transition:none; cursor:grabbing }
.svc-photo-img{
  position:absolute;
  top:5%; left:5%; right:5%; bottom:26%;
  background-size:cover;background-position:center;
  z-index:0;
}
.svc-photo-frame{ display:none } /* PNG overlay removed; frame is now pure CSS */
.svc-photo-meta{
  position:absolute;
  left:5%;right:5%;bottom:0;height:26%;
  z-index:2;
  display:flex;flex-direction:column;justify-content:center;align-items:center;
  text-align:center;color:var(--ink);padding:0 6%;
}
.svc-photo-num{font-size:9px;letter-spacing:.18em}
.svc-photo h3{
  font-size:clamp(14px,2vw,17px);line-height:1.15;
  margin:3px 0 2px;word-wrap:break-word;
}
.svc-photo p{font-size:10.5px;letter-spacing:.04em;line-height:1.3}
.svc-photo-num{
  font-family:'Manrope',sans-serif;font-size:9px;font-weight:600;
  letter-spacing:.22em;text-transform:uppercase;color:var(--ash);
}
.svc-photo h3{
  font-family:'Playfair Display',serif;font-weight:400;letter-spacing:-.01em;
  font-size:clamp(16px,2.4vw,22px);line-height:1.1;margin:4px 0 2px;color:var(--green-deep);
}
.svc-photo p{
  font-size:11px;letter-spacing:.04em;color:var(--mute);margin:0;
}

/* Scattered "unsorted stack" — each card has slightly different rotation
   + offset, so they look like polaroids dropped on a table. */
.svc-photo[data-state="future"]:nth-child(1){ transform:translate3d(0,0,0) rotate(-2.5deg) scale(1) }
.svc-photo[data-state="future"]:nth-child(2){ transform:translate3d(-6px,8px,0) rotate(4deg) scale(.985) }
.svc-photo[data-state="future"]:nth-child(3){ transform:translate3d(8px,12px,0) rotate(-7deg) scale(.97) }
.svc-photo[data-state="future"]:nth-child(4){ transform:translate3d(-4px,16px,0) rotate(8deg) scale(.955) }
.svc-photo[data-state="future"]:nth-child(5){ transform:translate3d(10px,20px,0) rotate(-5deg) scale(.94) }
.svc-photo[data-state="future"]:nth-child(6){ transform:translate3d(-8px,22px,0) rotate(6deg) scale(.93) }
.svc-photo[data-state="gone"]{ opacity:0; pointer-events:none }
.svc-photo[data-state="future"]{ pointer-events:none }
.svc-photo[data-state="top"]{ pointer-events:auto; cursor:pointer }

/* Photo backgrounds — kept in CSS (not inline style="") so the strict CSP
   style-src can stay clean. Inline style attributes would require
   'unsafe-hashes' or 'unsafe-inline'. */
.svc-photo[data-idx="0"] .svc-photo-img{ background-image:url('../pflasterbau-feat.webp'); background-position:50% 75% }
.svc-photo[data-idx="1"] .svc-photo-img{ background-image:url('../gallery/fruehling-pflasterbau-gartenbau-ingolstadt-4.jpg'); background-position:center 80% }
.svc-photo[data-idx="2"] .svc-photo-img{ background-image:url('../terrasse-balkon-holz.webp') }
.svc-photo[data-idx="3"] .svc-photo-img{ background-image:url('../rasen-streifen.webp') }
.svc-photo[data-idx="4"] .svc-photo-img{ background-image:url('../weg-platten-lang.webp') }
.svc-photo[data-idx="5"] .svc-photo-img{ background-image:url('../abbruch.webp'); background-position:center }

/* Controls below the stack */
.svc-stack-controls{
  display:flex;align-items:center;gap:18px;
}
.svc-stack-btn{
  display:none; /* arrow buttons removed by request — scroll/swipe + dots only */
  width:46px;height:46px;border-radius:50%;
  background:rgba(255,255,255,.6);
  border:1px solid var(--rule);
  color:var(--green-deep);
  align-items:center;justify-content:center;
  cursor:pointer;
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  transition:background .25s, transform .25s, border-color .25s;
}
.svc-stack-btn:hover{ background:rgba(255,255,255,.85); transform:translateY(-2px); border-color:var(--green) }
.svc-stack-btn:disabled{ opacity:.35; cursor:not-allowed; transform:none; background:rgba(255,255,255,.5) }
.svc-stack-dots{ display:flex; gap:8px }
.svc-stack-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--rule);border:0;cursor:pointer;
  transition:background .25s, transform .25s;
  padding:0;
}
.svc-stack-dot.is-active{ background:var(--green); transform:scale(1.4) }
.svc-stack-hint{ display:none } /* hint hidden — arrow-buttons removed */
@media (max-width:600px){
  .svc-stack{ aspect-ratio:3/4; }
  .svc-photo h3{ font-size:28px; }
  .svc-photo-meta{ padding:18px 22px; }
  .svc-stack-hint{ font-size:10px; }
}

/* Secondary services — orbiting bubbles around a center axis.
   .svc-orbit-ring rotates 60s slow; each bubble counter-rotates so the
   text stays upright. Hover halts the spin (animation-play-state). */
/* iPhone-style horizontal pill marquee — bubbles flow right→left
   continuously through a fixed-width strip with edge-fades. Track
   is doubled (12 pills = 6 unique × 2) so loop seams aren't visible. */
.svc-strip{
  position:relative;
  margin:48px auto 0;
  width:100%;
  overflow-x:hidden;
  overflow-y:visible;
  padding:18px 0;
  -webkit-mask-image:linear-gradient(to right, transparent 0%, #000 8%, #000 92%, transparent 100%);
          mask-image:linear-gradient(to right, transparent 0%, #000 8%, #000 92%, transparent 100%);
  pointer-events:none;
}
.svc-strip-track{
  display:flex;gap:14px;
  width:max-content;
  animation:svc-strip-flow 32s linear infinite;
  will-change:transform;
}
.svc-pill{
  display:inline-flex;align-items:center;gap:10px;
  padding:10px 18px 10px 10px;
  border-radius:9999px;
  /* Bluish frosted glass tint — pale ice-blue over backdrop blur */
  background:linear-gradient(135deg, rgba(220,235,250,.18), rgba(195,220,240,.10));
  border:1px solid rgba(255,255,255,.45);
  backdrop-filter:blur(36px) saturate(220%) brightness(1.08);
  -webkit-backdrop-filter:blur(36px) saturate(220%) brightness(1.08);
  box-shadow:0 6px 18px rgba(80,120,160,.12), inset 0 1px 0 0 rgba(255,255,255,.7), inset 0 0 0 1px rgba(255,255,255,.10);
  flex-shrink:0;
  white-space:nowrap;
}
.svc-pill img{
  width:32px;height:32px;border-radius:50%;
  object-fit:cover;flex-shrink:0;
}
.svc-pill span{
  font-family:'Manrope',sans-serif;font-weight:500;
  font-size:13px;color:var(--green-deep);
  letter-spacing:.02em;
}
@keyframes svc-strip-flow{
  from{transform:translate3d(0,0,0)}
  to{transform:translate3d(-50%,0,0)}
}
@media (prefers-reduced-motion:reduce){
  .svc-strip-track{animation:none}
}

/* ======================== SECTION 3 — PRINCIPLES ======================== */
.section3{padding:96px 40px;background:var(--bg-soft)}
.principles-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:64px;
  align-items:center;
}
.principles-image{
  border-radius:10px;overflow:hidden;
  aspect-ratio:4/5;
  background:var(--bg-soft);
}
.principles-image img{
  width:100%;height:100%;object-fit:cover;
  filter:saturate(1.05) contrast(1.05);
}
.principles-text h2{
  font-family:'Playfair Display',serif;font-weight:400;
  font-size:clamp(36px,5vw,64px);line-height:1;letter-spacing:-0.04em;
  color:var(--green-deep);
  margin:0 0 32px;
}
.principles-text h2 .ital{font-style:italic;color:var(--green)}
.principles-list{
  list-style:none;padding:0;margin:0;
  display:flex;flex-direction:column;
}
.principles-list li{
  font-family:'Manrope',sans-serif;
  font-size:16px;line-height:1.6;
  color:var(--ink);
  padding:18px 0;
  border-top:1px solid var(--rule);
}
.principles-list li:last-child{border-bottom:1px solid var(--rule)}
.principles-list li strong{
  color:var(--green-deep);font-weight:600;
  display:inline;
}

@media (max-width:900px){
  .principles-grid{grid-template-columns:1fr;gap:32px}
  .principles-image{aspect-ratio:3/4;max-height:560px}
}

/* ======================== SECTION 4 — PROJECTS / FOUNDERS-STYLE ======================== */
.section4{padding:96px 40px}
.founders-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
}
.founders-col{display:flex;flex-direction:column;gap:24px}
.founders-col-shift{margin-top:80px}

.founders-card{
  position:relative;display:block;
  border-radius:10px;overflow:hidden;
  background:var(--bg-soft);
  aspect-ratio:4/5;
  isolation:isolate;
  transition:transform .55s cubic-bezier(.2,.8,.2,1);
}
.founders-card:hover{transform:translateY(-4px)}
.founders-card img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  filter:saturate(1.05) contrast(1.05) brightness(1.0);
  transition:filter .8s cubic-bezier(.2,.8,.2,1), transform 1.2s cubic-bezier(.2,.8,.2,1);
}
.founders-card:hover img{filter:saturate(1.1) contrast(1.05) brightness(1.02);transform:scale(1.04)}
.founders-card::after{
  content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.72) 100%);
  pointer-events:none;
}
.founders-card-meta{
  position:relative;z-index:2;
  margin-top:auto;padding:24px;
  display:flex;flex-direction:column;gap:8px;
  align-items:flex-start;
  height:100%;justify-content:flex-end;
}
.founders-card-meta h3{
  font-family:'Playfair Display',serif;font-weight:400;
  font-size:20px;letter-spacing:-.015em;line-height:1.15;
  color:var(--white);
  margin:0;
}
.founders-card-meta p{
  font-size:13px;line-height:1.45;
  color:rgba(255,255,255,.85);margin:0;
}

@media (max-width:900px){
  .founders-grid{grid-template-columns:1fr;gap:18px}
  .founders-col-shift{margin-top:0}
  .founders-card{aspect-ratio:3/4}
}

.center-row{margin-top:48px;text-align:center}

/* ======================== BEFORE / AFTER ======================== */
.ba-section{
  background:var(--bg-deep);color:var(--ink);
  padding:96px 40px 64px;position:relative;overflow:hidden;
}
.ba-head{
  display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:end;
  margin-bottom:48px;
}
.ba-head h2{
  font-family:'Playfair Display',serif;font-weight:400;
  font-size:clamp(36px,5vw,64px);letter-spacing:-.04em;line-height:1;
  color:var(--green-deep);
}
.ba-head h2 .ital{font-style:italic;color:var(--green)}
.ba-head p{font-size:16px;color:var(--mute);line-height:1.55;max-width:480px}
.ba-stage{
  position:relative;width:100%;max-width:1100px;margin:0 auto;
  aspect-ratio:3/4;
  overflow:hidden;
  background:var(--bg-soft);
  border-radius:10px;
  border:1px solid var(--rule);
  touch-action:pan-y pinch-zoom;
  user-select:none;
  cursor:ew-resize;
  opacity:0;transform:scale(.97);
  transition:opacity 1.2s cubic-bezier(.22,1,.36,1), transform 1.2s cubic-bezier(.22,1,.36,1);
}
.ba-stage.in{opacity:1;transform:none}
.ba-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none;filter:saturate(1.05) contrast(1.05)}
.ba-after{clip-path:inset(0 0 0 50%);transition:clip-path .12s linear}
.ba-handle{
  position:absolute;top:0;bottom:0;left:50%;width:2px;
  background:var(--green);
  transform:translateX(-1px);
  transition:left .05s linear;
  pointer-events:none;
  box-shadow:0 0 0 1px rgba(45,74,47,.10), 0 0 30px rgba(45,74,47,.25);
  outline:none;
}
.ba-handle:focus-visible .knob{
  box-shadow:0 0 0 4px var(--green-soft), 0 14px 40px rgba(45,74,47,.4);
  outline:none;
}
.ba-handle .knob{
  position:absolute;top:50%;left:50%;
  width:56px;height:56px;border-radius:50%;
  background:var(--green);
  border:2px solid var(--white);
  transform:translate(-50%,-50%);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 0 1px rgba(255,255,255,.6), 0 18px 50px rgba(45,74,47,.4);
  color:var(--white);
  pointer-events:auto;cursor:ew-resize;touch-action:none;
}
.ba-handle .knob::before,.ba-handle .knob::after{
  content:"";width:0;height:0;
  border-top:6px solid transparent;border-bottom:6px solid transparent;
}
.ba-handle .knob::before{border-right:8px solid currentColor;margin-right:6px}
.ba-handle .knob::after{border-left:8px solid currentColor;margin-left:6px}
.ba-tag{
  position:absolute;top:20px;
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  font-weight:600;color:var(--white);
  padding:6px 14px;border-radius:9999px;
  pointer-events:none;
}
.ba-tag.left{left:20px}
.ba-tag.right{right:20px}
.ba-foot{
  margin-top:24px;
  display:flex;justify-content:space-between;gap:24px;
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ash);
  max-width:1100px;margin-left:auto;margin-right:auto;padding-top:16px;
}

@media (max-width:900px){
  .ba-section{padding:64px 20px 40px}
  .ba-head{grid-template-columns:1fr;gap:16px;margin-bottom:24px}
  .ba-stage{aspect-ratio:4/5}
  .ba-foot{flex-direction:column;gap:8px}
  .ba-handle .knob{width:48px;height:48px}
}

/* BA labels initial state — pop in once the stage enters viewport. */
.ba-tag{opacity:0;transform:translateY(-8px)}
.ba-stage.in .ba-tag{opacity:1;transform:translateY(0);transition:opacity .8s .5s cubic-bezier(.22,1,.36,1), transform .8s .5s cubic-bezier(.22,1,.36,1)}
.ba-handle .knob{transition:transform .4s cubic-bezier(.22,1,.36,1), box-shadow .4s}
.ba-stage:hover .ba-handle .knob{transform:translate(-50%,-50%) scale(1.08);box-shadow:0 0 0 1px rgba(255,255,255,.7), 0 22px 60px rgba(45,74,47,.45)}

/* ======================== SECTION 5 — REGION & STATS ======================== */
.section5{padding:96px 40px;background:var(--bg-soft)}

.leagues-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:24px;
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  padding:48px 0;
}
.league-stat{display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center}
.league-num{
  font-family:'Playfair Display',serif;font-weight:400;
  font-size:clamp(48px,7vw,96px);line-height:1;
  letter-spacing:-.04em;color:var(--green);
  display:inline-flex;align-items:baseline;gap:4px;
}
.league-num .suffix{
  font-size:.4em;color:var(--green-soft);font-style:italic;letter-spacing:0;
  font-family:'Playfair Display',serif;
}
.league-lbl{
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ash);font-weight:600;
}

.region-block{
  display:grid;grid-template-columns:1fr 1fr;gap:48px;
  align-items:center;
}
.region-map{
  position:relative;aspect-ratio:1/1;
  border-radius:10px;overflow:hidden;
  background:var(--bg-elev);
  border:1px solid var(--rule);
}
.region-map svg{width:100%;height:100%;display:block}
.region-map .map-label{
  position:absolute;font-family:'Manrope',sans-serif;
  font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ash);font-weight:600;
  pointer-events:none;
}
.region-map .map-label.is-ingolstadt{color:var(--green-deep);font-weight:700}
.region-cities{
  list-style:none;padding:0;margin:0;
  display:grid;grid-template-columns:1fr 1fr;gap:0 24px;
}
.region-cities li{
  list-style:none;font-size:15px;color:var(--ink);
  padding:14px 0;border-bottom:1px solid var(--rule);
  display:flex;align-items:center;gap:12px;
}
.region-cities li::before{
  content:"";width:6px;height:6px;border-radius:50%;background:var(--green);
}

@media (max-width:900px){
  .leagues-grid{grid-template-columns:repeat(2,1fr);gap:32px;padding:32px 0}
  .region-block{grid-template-columns:1fr;gap:32px}
  .region-cities{grid-template-columns:1fr}
}
@media (max-width:560px){
  .leagues-grid{grid-template-columns:repeat(2,1fr);gap:24px}
  .league-num{font-size:48px}
}

.map-label.is-ingolstadt  {top:46%;left:54%}
.map-label.is-manching    {top:60%;left:30%}
.map-label.is-gaimersheim {top:34%;left:62%}
.map-label.is-neuburg     {top:30%;left:30%}
.map-label.is-pfaffenhofen{top:72%;left:60%}

/* ======================== SECTION 6 — TRUST / MEMBERSHIPS ======================== */
.section6{padding:96px 40px 128px}
.memberships{
  display:flex;flex-wrap:wrap;justify-content:center;
  gap:14px;
  max-width:880px;margin:0 auto;
}
.statBadge{
  font-size:13px;
  padding:12px 22px;
  letter-spacing:.05em;
  text-transform:none;
}

/* ======================== FAQ ======================== */
.faq{background:var(--bg-deep);padding:96px 40px}
.faq .section-inner{gap:0}
.faq-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:64px;align-items:start}
.faq-side .eyebrow{color:var(--green-deep)}
.faq-side h2{
  font-family:'Playfair Display',serif;font-weight:400;
  font-size:clamp(36px,5vw,64px);letter-spacing:-.04em;line-height:1;
  margin-bottom:20px;color:var(--green-deep);
}
.faq-side h2 .ital{font-style:italic;color:var(--green)}
.faq-side p{font-size:16px;line-height:1.55;color:var(--mute);max-width:340px;margin-bottom:24px}

.faq-list{display:flex;flex-direction:column;gap:8px}
.faq-item{
  background:var(--bg-soft);
  border:1px solid var(--rule);
  border-radius:10px;
  color:var(--ink);
  overflow:hidden;
  transition:background .3s, border-color .3s;
}
.faq-item[open]{background:var(--bg-elev);border-color:rgba(45,74,47,.22)}
.faq-q{
  color:var(--green-deep);
  font-family:'Manrope',sans-serif;font-weight:600;font-size:16px;
  padding:18px 22px;
  cursor:pointer;
  display:flex;justify-content:space-between;align-items:center;
  list-style:none;gap:16px;
}
.faq-q::-webkit-details-marker{display:none}
.faq-q .ico{
  width:18px;height:18px;
  border:1px solid rgba(45,74,47,.4);border-radius:50%;
  color:var(--green-deep);
  position:relative;
  flex-shrink:0;
  transition:border-color .3s, background .3s;
}
.faq-item[open] .faq-q .ico{background:var(--green);border-color:var(--green)}
.faq-q .ico::before,.faq-q .ico::after{content:"";position:absolute;background:currentColor}
.faq-item[open] .faq-q .ico::before,
.faq-item[open] .faq-q .ico::after{background:var(--white)}
.faq-q .ico::before{top:50%;left:25%;right:25%;height:1px;transform:translateY(-50%)}
.faq-q .ico::after{left:50%;top:25%;bottom:25%;width:1px;transform:translateX(-50%);transition:transform .3s}
.faq-item[open] .ico::after{transform:translateX(-50%) scaleY(0)}
.faq-a{padding:0 22px}
.faq-a-inner{
  padding:0 0 18px;
  color:var(--ink);
  border-top:1px solid var(--rule);padding-top:16px;
  font-size:15px;line-height:1.6;
}

@media (max-width:1000px){
  .faq{padding:64px 24px}
  .faq-grid{grid-template-columns:1fr;gap:32px}
  .faq-q{font-size:15px;padding:16px 18px}
}

/* ======================== CONTACT ======================== */
.contact{
  background:var(--bg-soft);color:var(--ink);
  padding:96px 40px 128px;position:relative;overflow:hidden;
}
.contact .eyebrow,.contact .color-warm{color:var(--green-deep)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start;position:relative;z-index:1}
.contact h2{
  font-family:'Playfair Display',serif;font-weight:400;
  font-size:clamp(40px,6vw,80px);letter-spacing:-.04em;line-height:1;
  color:var(--green-deep);
}
.contact h2 .ital{font-style:italic;color:var(--green)}
.contact-lead{font-size:16px;line-height:1.55;color:var(--mute);margin:24px 0 32px;max-width:480px}

.contact-cards{display:flex;flex-direction:column;gap:10px;margin-top:32px}
.contact-card{
  display:flex;align-items:center;gap:14px;
  padding:14px 18px;border-radius:9999px;
  color:var(--green-deep);
  transition:background .3s, transform .3s;
}
.contact-card:hover{background:rgba(255,255,255,.95);transform:translateY(-1px)}
.contact-card .ico{
  width:40px;height:40px;border-radius:50%;
  background:transparent;color:var(--green);
  border:1px solid rgba(45,74,47,.25);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.contact-card .lbl{
  color:var(--ash);
  font-size:10px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;
}
.contact-card .val{
  color:var(--green-deep);font-family:'Manrope',sans-serif;font-weight:500;font-size:15px;
}

.form{
  background:var(--bg-elev);
  border:1px solid var(--rule);
  border-radius:10px;
  padding:32px 28px;
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-field{margin-bottom:18px;position:relative}
.form label,.form-field label{
  color:var(--green-deep);
  font-family:'Manrope',sans-serif;
  font-size:11px;letter-spacing:.07em;text-transform:uppercase;font-weight:600;
  display:block;margin-bottom:8px;
}
.form-label-opt{color:var(--ash);font-weight:400;letter-spacing:0;text-transform:none}
.form-field input:not([type="checkbox"]),
.form-field select,
.form-field textarea{
  width:100%;
  background:var(--white);
  border:1px solid var(--rule);
  color:var(--ink);
  font-family:'Manrope',sans-serif;font-size:14px;
  padding:13px 14px;border-radius:6px;
  transition:border-color .3s, background .3s;outline:none;
}
.form-field input::placeholder,
.form-field textarea::placeholder{color:rgba(26,43,28,.4)}
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus{
  outline:none;
  border-color:var(--green);background:var(--white);
  box-shadow:0 0 0 3px rgba(92,139,95,.18);
}
.form-field textarea{resize:vertical;min-height:80px}
.form-field select option{background:var(--white);color:var(--ink)}

.form-foot{
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;margin-top:24px;flex-wrap:wrap;
}
.form-priv{font-size:12px;color:var(--mute);max-width:280px;line-height:1.5}
.btn-submit{
  background:var(--green);color:var(--white);
  border:none;border-radius:9999px;
  padding:14px 28px;
  font-family:'Manrope',sans-serif;
  font-size:14px;letter-spacing:0;font-weight:500;
  display:inline-flex;align-items:center;gap:10px;cursor:pointer;
  transition:background .3s, box-shadow .3s, transform .3s;
}
.btn-submit:hover{background:var(--green-deep);box-shadow:0 8px 24px rgba(45,74,47,.28);transform:translateY(-1px)}
.btn-submit:disabled{opacity:.6;cursor:wait}
.btn-submit:focus-visible,
.contact-card:focus-visible,
.form-field input:focus-visible,
.form-field select:focus-visible,
.form-field textarea:focus-visible,
.form input[type="checkbox"]:focus-visible{outline:2px solid var(--green);outline-offset:2px;border-radius:6px}
.form-err{
  display:block;margin-top:6px;
  font-size:11px;color:#A85A4F;
  letter-spacing:.07em;line-height:1.4;
}
.form-field input[aria-invalid="true"],
.form-field select[aria-invalid="true"],
.form-field textarea[aria-invalid="true"]{border-color:#A85A4F}

@media (max-width:1000px){
  .contact{padding:64px 20px}
  .contact-grid{grid-template-columns:1fr;gap:48px}
  .form{padding:24px 18px}
  .form-row{grid-template-columns:1fr}
  .form-foot{flex-direction:column;align-items:stretch;gap:16px}
  .form-priv{max-width:none;font-size:12px}
  .btn-submit{width:100%;justify-content:center}
  .form-field.form-privacy-row{gap:12px}
  .form-priv-label{font-size:12.5px;line-height:1.45}
}

/* ======================== FOOTER ======================== */
.footer{
  background:var(--bg-soft);color:var(--ink);
  border-top:1px solid var(--rule);
  padding:64px 40px 40px;
}
.footer .section-inner{gap:48px}
.footer-top{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;
  border-bottom:1px solid var(--rule);
  padding-bottom:48px;
}
.footer-brand{display:flex;align-items:center;gap:14px;margin-bottom:18px;min-width:0}
.footer-brand img{height:38px;width:auto;max-width:140px;flex:none;object-fit:contain}
.footer-brand-txt{color:var(--green-deep);font-family:'Playfair Display',serif;font-size:18px;font-weight:500}
.footer-brand-txt small{color:var(--ash);display:block;font-family:'Manrope',sans-serif;font-size:10px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;margin-top:2px}
.footer p{color:var(--mute);font-size:14px;line-height:1.6;max-width:340px;margin-bottom:16px}
.footer h3{
  color:var(--green-deep);font-family:'Manrope',sans-serif;
  font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  margin-bottom:18px;
}
.footer ul{list-style:none}
.footer li{padding:5px 0}
.footer ul li a,.footer-address{
  color:var(--mute);font-size:13px;
  transition:color .3s;
}
.footer ul li a:hover{color:var(--green)}
.footer-bot{
  color:var(--ash);
  display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;
  font-size:11px;letter-spacing:.07em;
}
@media (max-width:900px){
  .footer{padding:48px 24px 32px}
  .footer-top{grid-template-columns:1fr 1fr;gap:32px}
}
@media (max-width:600px){
  .footer-top{grid-template-columns:1fr;gap:36px}
  .footer-brand img{height:34px;max-width:130px}
  .footer p{max-width:none}
}

/* ======================== STICKY MOBILE CTA + FAB ======================== */
.sticky-mobile{
  display:none;position:fixed;
  right:16px;bottom:calc(16px + env(safe-area-inset-bottom, 0px));
  z-index:80;
  width:64px;height:64px;
  align-items:center;justify-content:center;
  opacity:0;visibility:hidden;pointer-events:none;
  transform:translateY(20px);
  transition:opacity .35s ease, transform .4s cubic-bezier(.22,1,.36,1), visibility .35s;
  -webkit-tap-highlight-color:transparent;
}
.sticky-mobile,.fab-wapp{transition:opacity .3s,transform .3s}
.sticky-mobile img,.fab-wapp img{width:100%;height:100%;display:block;object-fit:contain}
.sticky-mobile:active{transform:scale(.96)}
body:not(.app-ready) .sticky-mobile{
  opacity:0 !important;visibility:hidden !important;pointer-events:none !important;
  transform:translateY(20px) !important;transition:none !important;
}
body.past-hero .sticky-mobile{opacity:1;visibility:visible;pointer-events:auto;transform:none}
body.in-contact .sticky-mobile{opacity:0;visibility:hidden;pointer-events:none;transform:translateY(20px)}

@media (max-width:768px){
  .sticky-mobile{display:flex}
  body.past-hero .footer{padding-bottom:calc(96px + env(safe-area-inset-bottom, 0px))}
}
@media (prefers-reduced-motion:reduce){
  .sticky-mobile{transition-duration:.01ms !important}
}

.fab-wapp{
  position:fixed;right:20px;bottom:20px;z-index:70;
  width:64px;height:64px;
  display:flex;align-items:center;justify-content:center;
  transition:transform .3s;
}
.fab-wapp:hover{transform:scale(1.08)}
@media (max-width:768px){.fab-wapp{display:none}}

@keyframes wapp-breathe{
  0%,100%{transform:scale(1)}
  50%{transform:scale(1.07)}
}
@keyframes wapp-pulse-ring{
  0%{transform:scale(.9);opacity:.55}
  100%{transform:scale(1.65);opacity:0}
}
.sticky-mobile img,.fab-wapp img{
  animation:wapp-breathe 2.6s ease-in-out infinite;
  transform-origin:center;
}
.sticky-mobile::before,.fab-wapp::before{
  content:"";
  position:absolute;inset:0;
  border-radius:50%;
  background:radial-gradient(circle at center,rgba(255,255,255,.45) 0%,rgba(255,255,255,0) 65%);
  animation:wapp-pulse-ring 2.6s cubic-bezier(.4,0,.6,1) infinite;
  pointer-events:none;
  z-index:-1;
}
.sticky-mobile::after,.fab-wapp::after{
  content:"";
  position:absolute;inset:0;
  border-radius:50%;
  background:radial-gradient(circle at center,rgba(255,255,255,.35) 0%,rgba(255,255,255,0) 65%);
  animation:wapp-pulse-ring 2.6s cubic-bezier(.4,0,.6,1) 1.3s infinite;
  pointer-events:none;
  z-index:-1;
}
@media (prefers-reduced-motion:reduce){
  .sticky-mobile img,.fab-wapp img,
  .sticky-mobile::before,.fab-wapp::before,
  .sticky-mobile::after,.fab-wapp::after{animation:none}
}

/* Lazy-loaded images: sanftes Fade-in via IntersectionObserver. */
img.img-fade{
  opacity:0;
  transform:scale(1.03) translateY(12px);
  transition:opacity 1.1s cubic-bezier(.22,1,.36,1), transform 1.2s cubic-bezier(.22,1,.36,1);
  will-change:opacity,transform;
}
img.img-fade.img-loaded{
  opacity:1;
  transform:none;
}
.reveal img[loading="lazy"],
.reveal-stagger img[loading="lazy"]{
  opacity:0;
  transition:opacity 1.2s cubic-bezier(.22,1,.36,1) .2s;
}
.reveal.is-visible img[loading="lazy"],
.reveal-stagger.is-visible img[loading="lazy"]{
  opacity:1;
}
@media (prefers-reduced-motion:reduce){
  img.img-fade,img.img-fade.img-loaded{opacity:1;transform:none;transition:none;will-change:auto}
  .reveal img[loading="lazy"],.reveal-stagger img[loading="lazy"]{opacity:1;transition:none}
}

/* ======================== REVEAL (IntersectionObserver) ======================== */
.reveal{opacity:0;transform:translateY(48px);transition:opacity .9s cubic-bezier(.22,1,.36,1), transform .9s cubic-bezier(.22,1,.36,1)}
.reveal.is-visible{opacity:1;transform:none}

.reveal-stagger > *{
  opacity:0;transform:translateY(36px);
  transition:opacity .85s cubic-bezier(.22,1,.36,1), transform .85s cubic-bezier(.22,1,.36,1);
  transition-delay:calc(var(--i,0) * 70ms);
}
.reveal-stagger.is-visible > *{opacity:1;transform:none}

.tr-line{display:block;overflow:hidden;line-height:1.05;padding-bottom:.15em}
.tr-line > span{
  display:inline-block;transform:translateY(110%);
  transition:transform 1.1s cubic-bezier(.22,1,.36,1);
}
.tr.is-visible .tr-line{overflow:visible;transition:overflow 0s 1.4s}
.tr.is-visible .tr-line > span{transform:translateY(0)}
.tr.is-visible .tr-line:nth-child(2) > span{transition-delay:.12s}
.tr.is-visible .tr-line:nth-child(3) > span{transition-delay:.24s}

/* ======================== HERO ENTRANCE (CSS-only) ======================== */
/* Hero intro Ken-Burns moved to motion.js (GSAP) so parallax + zoom share
   the same transform pipeline; no CSS-to-GSAP handoff snap at end of intro. */
.hero-eyebrow{animation:fadeUp .8s .2s backwards}
.hero h1 .ital   {animation:fadeUp .7s 1.05s backwards}

@keyframes navIntro{from{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:none}}
.nav{animation:navIntro 1s .05s cubic-bezier(.22,1,.36,1) backwards}

/* ======================== LIGHTBOX ======================== */
.lightbox{
  position:fixed;inset:0;z-index:300;
  background:rgba(0,0,0,.95);
  display:none;align-items:center;justify-content:center;
  padding:clamp(12px,4vw,40px);
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  opacity:0;transition:opacity .25s ease;
}
.lightbox.open{display:flex;opacity:1}
.lightbox-figure{position:relative;max-width:1400px;max-height:100%;width:100%;display:flex;flex-direction:column;align-items:center;gap:14px}
.lightbox-figure img{filter:none}
.lightbox-img{
  max-width:100%;max-height:calc(100dvh - 140px);
  object-fit:contain;
  border-radius:10px;
  box-shadow:0 30px 80px rgba(0,0,0,.5);
  cursor:zoom-out;
}
.lightbox-caption{
  color:var(--white);font-family:'Manrope',sans-serif;font-weight:400;
  font-size:13px;letter-spacing:.02em;
  text-align:center;max-width:80ch;line-height:1.5;
  padding:0 12px;
}
.lightbox-counter{color:rgba(255,255,255,.6);font-size:10px;letter-spacing:.18em;text-transform:uppercase;font-weight:500}
.lightbox-btn{
  position:absolute;
  width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.10);color:var(--white);
  display:flex;align-items:center;justify-content:center;
  transition:background .3s, color .3s, transform .25s;
  -webkit-backdrop-filter:blur(14px) saturate(140%);backdrop-filter:blur(14px) saturate(140%);
  border:1px solid rgba(255,255,255,.16);
  box-shadow:rgba(0,0,0,0.35) 0px 10px 30px 0px, rgba(255,255,255,0.08) 0px 1px 0px 0px inset;
}
.lightbox-btn:hover{background:rgba(255,255,255,.22);transform:scale(1.05)}
.lightbox-btn:focus-visible{outline:2px solid var(--white);outline-offset:3px}
.lightbox-close{top:clamp(12px,3vw,24px);right:clamp(12px,3vw,24px)}
.lightbox-prev{top:50%;left:clamp(12px,2vw,24px);transform:translateY(-50%)}
.lightbox-next{top:50%;right:clamp(12px,2vw,24px);transform:translateY(-50%)}
.lightbox-prev:hover,.lightbox-next:hover{transform:translateY(-50%) scale(1.05)}
.lightbox-prev[hidden],.lightbox-next[hidden]{display:none}

/* Trigger-Affordance auf Galerie-Karten */
.proj{cursor:zoom-in}
.founders-card{cursor:zoom-in}

@media (max-width:600px){
  .lightbox-prev,.lightbox-next{width:44px;height:44px}
  .lightbox-img{max-height:calc(100dvh - 110px)}
}

@media (prefers-reduced-motion: reduce){
  *,::before,::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .reveal,.reveal-stagger > *,.tr-line > span,.hero h1 .line span{opacity:1!important;transform:none!important}
}

/* ======================== INLINE-HOOK UTILITIES ========================
   1:1 Mappings, da Inline-Styles aus dem Markup extrahiert wurden (CSP). */
.serif.mt-14{margin-top:14px}
.serif.mt-18{margin-top:18px}
.serif.mt-24{margin-top:24px}

.proj img.obj-pos-c80{object-position:center 80%}

.eyebrow.color-warm{color:var(--green-deep)}

.honeypot{position:absolute;left:-9999px}

.form-field.form-privacy-row{display:flex;gap:10px;align-items:flex-start;margin-top:6px}
.form-priv-checkbox{margin-top:3px;flex:none;width:24px;height:24px;accent-color:var(--green)}
.form-field .form-priv-label,
.form-priv-label{
  display:block!important;
  font-size:12px!important;line-height:1.5!important;
  color:var(--mute)!important;font-weight:400!important;
  letter-spacing:0!important;text-transform:none!important;
  margin-bottom:0!important;
  flex:1 1 0!important;min-width:0!important;
}
.form-priv-label a{color:var(--green);border-bottom:1px solid rgba(92,139,95,.35);text-decoration:none}
.form-priv-label a:hover{color:var(--green-deep)}

.form-priv a.tel-inline,.tel-inline{color:var(--green);border-bottom:1px solid rgba(92,139,95,.35);text-decoration:none}

.form-success{
  margin-top:18px;
  background:rgba(92,139,95,.10);
  border:1px solid rgba(92,139,95,.30);
  color:var(--green-deep);
  padding:16px 18px;border-radius:10px;font-size:14px;
}
.form-success a{color:var(--green-deep);border-bottom:1px solid rgba(45,74,47,.25);text-decoration:none}
.form-error{
  margin-top:18px;
  background:rgba(168,90,79,.08);
  border:1px solid rgba(168,90,79,.4);
  color:#A85A4F;
  padding:16px 18px;border-radius:10px;font-size:14px;
}
.form-error a{color:#A85A4F;border-bottom:1px solid rgba(168,90,79,.4);text-decoration:none}

.footer-address{font-style:normal;margin-bottom:10px;line-height:1.5}

/* Mobile-Perf: backdrop-filter ist auf Mobile-GPUs der teuerste Paint-Op,
   verursacht jank beim Scroll. Auf <=768px deaktivieren — die rgba-Hintergruende
   der Komponenten bleiben durch Alpha-Compositing weiterhin sichtbar. */
@media (max-width:768px){
  .nav.scrolled,.hero-eyebrow,.hero-pill,.glass,.glass.badge,.btn-glass,
  .sticky-mobile,.lightbox,.lightbox-btn,.nav-backdrop,.contact-card{
    backdrop-filter:none!important;-webkit-backdrop-filter:none!important;
  }
}
