/* ============================================================
   Turza – Showcase Startseite
   Grün-betont · Gold-Playfair-Headlines · Premium-Animationen
   Reines CSS, keine externen Requests.
   ============================================================ */

:root{
  /* Grün – tiefer & vielschichtiger als zuvor (mehr Grün) */
  --green-deep:#10271a;
  --green:#1a3d2e;
  --green-mid:#27553f;
  --green-soft:#356b50;
  --green-tint:#eef3ee;
  /* Gold */
  --gold:#c9a962;
  --gold-light:#e6cf8b;
  --gold-deep:#a8863f;
  /* Neutral */
  --cream:#f6f3ea;
  --warm-white:#fffdf7;
  --ink:#23241f;
  --muted:#6a6f64;
  --line:rgba(26,61,46,.12);

  --display:'Playfair Display',Georgia,serif;
  --body:'Jost','Segoe UI',-apple-system,sans-serif;
  --shadow-s:0 4px 20px rgba(16,39,26,.08);
  --shadow-m:0 12px 40px rgba(16,39,26,.14);
  --shadow-l:0 26px 60px rgba(16,39,26,.22);
  --ease:cubic-bezier(.22,1,.36,1);
  --t:all .45s var(--ease);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--ink);background:var(--warm-white);line-height:1.7;font-size:17px;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block;height:auto}
/* ---- Barrierefreiheit: sichtbarer Tastatur-Fokus (WCAG 2.4.7) ---- */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,[tabindex]:focus-visible{
  outline:3px solid var(--gold-deep);outline-offset:2px;border-radius:3px}
/* ---- Skip-Link "Zum Inhalt springen" (WCAG 2.4.1) ---- */
.skip-link{position:fixed;left:12px;top:-60px;z-index:3000;background:var(--green-deep);color:#fff;
  padding:.7rem 1.15rem;border-radius:0 0 10px 10px;font-weight:600;font-size:.95rem;text-decoration:none;
  box-shadow:0 6px 20px rgba(0,0,0,.3);transition:top .18s ease}
.skip-link:focus{top:0;outline:3px solid var(--gold-light);outline-offset:2px}
/* <picture> layout-neutral: der innere <img> übernimmt 1:1 die bestehenden Bild-Styles (AVIF→WebP-Fallback) */
picture{display:contents}
a{color:var(--green);text-decoration:none}
h1,h2,h3,h4{font-family:var(--display);font-weight:700;line-height:1.12;color:var(--green-deep)}
.wrap{max-width:1240px;margin:0 auto;padding:0 28px}

/* Gold-Kursiv-Akzent (die „goldene Schrift" der Grafikerin) */
.gold-i{font-family:var(--display);font-style:italic;font-weight:500;color:var(--gold-deep)}
.script{font-family:var(--display);font-style:italic;font-weight:500;color:var(--gold)}

/* Sektionslabel */
.label{display:inline-flex;align-items:center;gap:10px;font-size:.82rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:.9rem}
.label::before{content:"";width:30px;height:2px;background:linear-gradient(90deg,var(--gold),transparent)}

/* Section heading mit „gezeichneter" Goldlinie */
.shead{max-width:720px;margin:0 auto 3.4rem;text-align:center}
.shead h2{font-size:clamp(2rem,4vw,3rem)}
.shead h2 em{font-style:italic;color:var(--gold-deep)}
.shead .underline{width:0;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);margin:1.1rem auto 0;transition:width 1s var(--ease) .2s}
.reveal-section.revealed .shead .underline,.shead.revealed .underline{width:140px}
.shead p{color:var(--muted);margin-top:1rem;font-size:1.08rem}

/* ---- Scroll-Fortschritt (dünne Goldlinie oben) ---- */
.progress{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--gold-deep),var(--gold-light));z-index:2000;transition:width .1s linear}

/* ============ NAV ============ */
/* Oben: transparent mit dezentem dunkelgrünem Verlauf (kein fades Grau).
   Beim Scrollen: sattes Dunkelgrün. Logo & Links durchgängig hell. */
.nav{position:fixed;inset:0 0 auto 0;z-index:1000;background:linear-gradient(180deg,rgba(16,39,26,.78),rgba(16,39,26,.12) 80%,transparent);transition:var(--t)}
.nav.scrolled{background:rgba(16,39,26,.97);backdrop-filter:blur(16px);border-bottom:1px solid rgba(201,169,98,.3);box-shadow:var(--shadow-m)}
/* Bei offenem Mobil-Menü: KEIN backdrop-filter (sonst wird das fixe Overlay am Header statt am Viewport ausgerichtet) */
.nav.menu-open{backdrop-filter:none!important;-webkit-backdrop-filter:none!important;background:transparent;border-bottom-color:transparent;box-shadow:none}
body.nav-locked{overflow:hidden}
.nav-inner{max-width:1340px;margin:0 auto;padding:0 28px;display:flex;align-items:center;justify-content:space-between;height:88px;transition:var(--t)}
.nav.scrolled .nav-inner{height:72px}
.logo{position:relative;display:inline-block}
.logo img{height:60px;width:auto;transition:var(--t);filter:drop-shadow(0 2px 6px rgba(0,0,0,.35));animation:logoReveal 1.2s var(--ease) .15s both}
.nav.scrolled .logo img{height:48px}
.logo:hover img{transform:scale(1.05);filter:drop-shadow(0 0 9px rgba(230,207,139,.55)) brightness(1.1)}
/* Heller Glanz, der langsam übers Gold-Logo wandert (nur auf der Logo-Form, via Maske) */
.logo::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(115deg,transparent 42%,rgba(255,250,235,.9) 50%,transparent 58%);
  background-size:300% 100%;background-position:160% 0;
  -webkit-mask:url('../images/turza-logo-gold.webp') center/contain no-repeat;
          mask:url('../images/turza-logo-gold.webp') center/contain no-repeat;
  animation:logoSheen 7s ease-in-out infinite;
}
/* Enthüllung von links nach rechts beim Laden (wirkt wie „gezeichnet") */
@keyframes logoReveal{0%{opacity:0;clip-path:inset(0 100% 0 0)}60%{opacity:1}100%{opacity:1;clip-path:inset(0 0 0 0)}}
@keyframes logoSheen{0%,72%,100%{background-position:160% 0}86%{background-position:-60% 0}}
.nav-links{display:flex;gap:2rem;list-style:none;align-items:center}
.nav-links a{display:inline-block;color:rgba(255,255,255,.9);font-size:.92rem;font-weight:500;letter-spacing:.03em;position:relative;padding:.4rem 0;transition:var(--t);text-shadow:0 1px 4px rgba(0,0,0,.25)}
.nav-links a::after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;background:linear-gradient(90deg,var(--gold),var(--gold-light));transform:scaleX(0);transform-origin:center;transition:transform .35s var(--ease)}
.nav-links a:hover::after{transform:scaleX(1)}
.nav-links a:hover{color:var(--gold-light);transform:translateY(-2px);text-shadow:0 2px 12px rgba(230,207,139,.6)}

/* „Wochenmenü" – der Blickfang: goldener Button mit Icon + sanftem Puls */
.nav-menu{display:inline-flex!important;align-items:center;gap:.5rem;background:var(--gold);color:var(--green-deep)!important;
  padding:.62rem 1.25rem!important;border-radius:40px;font-weight:700!important;text-shadow:none!important;
  box-shadow:0 4px 14px rgba(201,169,98,.35);animation:menuPulse 2.8s ease-in-out infinite}
.nav-menu svg{width:17px;height:17px}
.nav-menu::after{display:none!important}
.nav-menu:hover{background:var(--gold-light);transform:translateY(-2px);box-shadow:0 8px 22px rgba(201,169,98,.5)}
@keyframes menuPulse{0%,100%{box-shadow:0 4px 14px rgba(201,169,98,.35),0 0 0 0 rgba(230,207,139,.45)}50%{box-shadow:0 4px 14px rgba(201,169,98,.35),0 0 0 8px rgba(230,207,139,0)}}

/* „Kontakt" – durchgehend GRÜN gefüllt (Blickfang), Hover mit Glanz-Sweep */
.nav-cta{position:relative;overflow:hidden;background:var(--green);border:1.5px solid var(--green);color:#fff!important;padding:.6rem 1.25rem!important;border-radius:40px;font-weight:600;text-shadow:none!important;box-shadow:0 3px 12px rgba(16,39,26,.35)}
/* gleiche vertikale Ausrichtung wie der Wochenmenü-Button (inline-flex statt inline-block) */
.nav-links .nav-cta{display:inline-flex;align-items:center;line-height:1}
.nav-menu{line-height:1}
.nav-cta::after{display:none!important}
/* Glanz-Sweep beim Hover (neue Animation) */
.nav-cta::before{content:"";position:absolute;top:0;left:-130%;width:55%;height:100%;background:linear-gradient(115deg,transparent,rgba(255,255,255,.4),transparent);transform:skewX(-18deg);transition:left .65s var(--ease);pointer-events:none}
.nav-links .nav-cta:hover{background:var(--green-mid);border-color:var(--green-mid);transform:translateY(-2px) scale(1.05);box-shadow:0 9px 24px rgba(16,39,26,.55)}
.nav-cta:hover::before{left:140%}
.nav.scrolled .nav-cta{border-color:var(--green)}

.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;width:44px;height:44px;align-items:center;justify-content:center;position:relative;z-index:1001}
/* „Menü"-Beschriftung links neben dem Burger (nur mobil) */
.burger-label{display:none;align-items:center;margin-left:auto;margin-right:.5rem;font-family:var(--body);font-weight:600;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;color:var(--green);position:relative;z-index:1001;pointer-events:none}
.nav.menu-open .burger-label{opacity:0}
/* Menü-Icons & Kontakt-Leiste: nur im mobilen Overlay sichtbar */
.mnav-ic{display:none}
.nav-contact{display:none}
.burger span{width:24px;height:2px;background:#fff;transition:transform .3s var(--ease),opacity .2s ease}
/* Burger -> X, wenn das mobile Menü offen ist */
#navlinks.open ~ .burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
#navlinks.open ~ .burger span:nth-child(2){opacity:0}
#navlinks.open ~ .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ============ HERO ============ */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;padding:120px 0 80px}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;transform:scale(1.2) translateX(-4%);animation:heropan 24s ease-in-out infinite alternate}
.hero-bg::after{content:"";position:absolute;inset:0;background:
  linear-gradient(100deg,rgba(16,39,26,.92) 0%,rgba(16,39,26,.78) 42%,rgba(16,39,26,.45) 100%),
  radial-gradient(circle at 80% 30%,rgba(201,169,98,.18),transparent 55%)}
@keyframes heropan{from{transform:scale(1.2) translateX(-4%)}to{transform:scale(1.2) translateX(4%)}}
.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center;width:100%}
.hero-content{color:#fff}
.hero-badge{display:inline-flex;align-items:center;gap:.55rem;background:rgba(201,169,98,.14);border:1px solid rgba(201,169,98,.4);color:var(--gold-light);padding:.5rem 1.1rem;border-radius:40px;font-size:.84rem;font-weight:500;letter-spacing:.04em;margin-bottom:1.6rem}
.hero-badge svg{fill:var(--gold-light)}
.hero h1{font-size:clamp(2.8rem,6vw,5rem);color:#fff;letter-spacing:-.01em}
.hero h1 .script{display:block;color:var(--gold-light);font-size:1.06em;margin-top:.1em}
.hero-sub{font-family:var(--display);font-style:italic;font-size:clamp(1.15rem,2vw,1.5rem);color:var(--gold-light);margin:1.1rem 0 .4rem}
.hero-desc{color:rgba(255,255,255,.82);max-width:520px;font-size:1.08rem;margin-bottom:2rem}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}

/* Hero „Medaillen"-Karte */
.hero-card{position:relative;justify-self:end;background:rgba(255,253,247,.07);border:1px solid rgba(201,169,98,.35);backdrop-filter:blur(8px);border-radius:18px;padding:14px;max-width:380px;box-shadow:var(--shadow-l)}
.hero-card img{border-radius:12px;aspect-ratio:4/5;object-fit:cover;width:100%}
.hero-card .tag{position:absolute;left:-16px;bottom:24px;background:var(--gold);color:var(--green-deep);border-radius:13px;padding:13px 20px;box-shadow:0 10px 26px rgba(16,39,26,.26);display:flex;align-items:center;gap:11px}
.hero-card .tag svg{width:26px;height:26px;fill:var(--green-deep);transform-origin:center;animation:starTwinkle 3.4s ease-in-out infinite}
.hero-card .tag b{font-family:var(--display);font-size:1.7rem;line-height:1;display:block}
.hero-card .tag span{font-size:.74rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em}
@keyframes starTwinkle{
  0%,100%{transform:scale(1) rotate(0deg);filter:drop-shadow(0 0 0 rgba(255,248,225,0))}
  50%{transform:scale(1.16) rotate(-7deg);filter:drop-shadow(0 0 4px rgba(255,248,225,.95))}
}
.scrolldown{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:2;color:rgba(255,255,255,.6);font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:8px}
.scrolldown::after{content:"";width:1px;height:34px;background:linear-gradient(var(--gold),transparent);animation:scrolldash 1.8s ease-in-out infinite}
@keyframes scrolldash{0%,100%{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.95rem 1.9rem;border-radius:40px;font-weight:600;font-size:.98rem;transition:var(--t);position:relative;overflow:hidden;border:1px solid transparent;cursor:pointer}
.btn[href^="mailto:"]{font-weight:400}
.btn svg{width:18px;height:18px}
.btn-primary{background:var(--gold);color:var(--green-deep)}
.btn-primary:hover{background:var(--gold-light);transform:translateY(-3px);box-shadow:0 10px 28px rgba(201,169,98,.4)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn-ghost:hover{background:#fff;color:var(--green);transform:translateY(-3px)}
.btn-green{background:var(--green);color:#fff}
.btn-green:hover{background:var(--green-mid);transform:translateY(-3px);box-shadow:var(--shadow-m)}
.btn-light{background:#fff;color:var(--green)}
.btn-light:hover{background:var(--gold);color:var(--green-deep);transform:translateY(-3px)}
/* Glanz-Sweep beim Hover */
.btn::before{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;background:linear-gradient(120deg,transparent,rgba(255,255,255,.35),transparent);transform:skewX(-20deg);transition:left .6s var(--ease)}
.btn:hover::before{left:140%}

/* 🌭 Salami-Button (Form aus DXF): Kapsel mit geflartem „Tie"-Ende an BEIDEN Seiten */
.btn-salami{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  position:relative;cursor:pointer;text-decoration:none;border:0;font:inherit;font-weight:600;font-size:.98rem;
  padding:.95rem 2.2rem;border-radius:999px;background:var(--gold);color:var(--green-deep);
  margin:0 .8em;transition:transform .2s var(--ease),background .2s,box-shadow .2s}
.btn-salami svg{width:18px;height:18px}
.btn-salami:hover{background:var(--gold-light);transform:translateY(-3px);box-shadow:0 10px 28px rgba(201,169,98,.4)}
/* die beiden Tie-Enden – nach außen geflart (außen höher als innen), in Button-Farbe */
.btn-salami::before,.btn-salami::after{content:"";position:absolute;top:50%;transform:translateY(-50%);
  width:.75em;height:86%;background:var(--gold);transition:background .2s}
.btn-salami::before{right:100%;margin-right:-.5em;clip-path:polygon(0 0,0 100%,100% 81%,100% 19%)}
.btn-salami::after{left:100%;margin-left:-.5em;clip-path:polygon(100% 0,100% 100%,0 81%,0 19%)}
.btn-salami:hover::before,.btn-salami:hover::after{background:var(--gold-light)}

/* ============ TRUST-LEISTE ============ */
.trust{background:var(--green-deep);color:#fff;border-top:3px solid var(--gold);border-bottom:3px solid var(--gold)}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;padding:2.4rem 0;text-align:center}
.trust .n{font-family:var(--display);font-size:2.4rem;color:var(--gold-light);line-height:1}
.trust .l{font-size:.88rem;color:rgba(255,255,255,.7);margin-top:.3rem;letter-spacing:.04em}
.trust .div{position:relative}
.trust .div:not(:last-child)::after{content:"";position:absolute;right:0;top:15%;height:70%;width:1px;background:rgba(201,169,98,.3)}

/* ============ FEATURES ============ */
.features{padding:6rem 0;background:var(--warm-white)}
.fgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.fcard{background:var(--cream);border:1px solid var(--line);border-radius:16px;padding:2.6rem 2rem;text-align:center;transition:var(--t);position:relative;overflow:hidden}
.fcard::before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:linear-gradient(90deg,var(--gold),var(--gold-light));transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.fcard:hover{transform:translateY(-8px);box-shadow:var(--shadow-m);background:#fff}
.fcard:hover::before{transform:scaleX(1)}
.fico{width:84px;height:84px;margin:0 auto 1.4rem;border-radius:50%;background:var(--green);display:flex;align-items:center;justify-content:center;transition:var(--t)}
.fcard:hover .fico{background:var(--gold);transform:rotate(-6deg) scale(1.06)}
.fico svg{width:38px;height:38px;stroke:var(--gold-light);fill:none;stroke-width:1.5;transition:var(--t)}
.fcard:hover .fico svg{stroke:var(--green-deep)}
.fcard h3{font-size:1.4rem;margin-bottom:.7rem;color:var(--green)}
.fcard p{color:var(--muted);font-size:.98rem}

/* ============ JOURNEY (grün) ============ */
.journey{padding:6.5rem 0;background:linear-gradient(160deg,var(--green) 0%,var(--green-deep) 100%);color:#fff;position:relative;overflow:hidden}
.journey::before{content:"";position:absolute;inset:0;background:url('../images/verkaufsraum.webp') center/cover;opacity:.06;mix-blend-mode:luminosity}
.journey .shead h2{color:#fff}
.journey .shead h2 em{color:var(--gold-light)}
.journey .shead p{color:rgba(255,255,255,.75)}
.journey .label{color:var(--gold-light)}
.jtimeline{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:3rem;position:relative}
.jtimeline::before{content:"";position:absolute;top:52px;left:16%;right:16%;height:2px;background:linear-gradient(90deg,var(--gold),var(--gold-light),var(--gold));opacity:0;transform:scaleX(0);transform-origin:left;transition:opacity .6s ease .4s,transform 1.2s var(--ease) .4s}
.jtimeline.revealed::before{opacity:.4;transform:scaleX(1)}
.jstep{text-align:center;position:relative}
.jnum{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--gold);color:var(--green-deep);border-radius:50%;font-weight:700;font-size:.85rem;margin-bottom:1rem}
.jico{width:104px;height:104px;margin:0 auto 1.4rem;background:rgba(255,253,247,.06);border:2px solid var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative;z-index:1;transition:var(--t)}
.jstep:hover .jico{background:var(--gold);transform:scale(1.08)}
.jico svg{width:44px;height:44px;stroke:var(--gold-light);fill:none;stroke-width:1.5;transition:var(--t)}
.jstep:hover .jico svg{stroke:var(--green-deep)}
.jstep h3{color:#fff;font-size:1.35rem;margin-bottom:.6rem}
.jstep p{color:rgba(255,255,255,.72);font-size:.95rem;max-width:280px;margin:0 auto}

/* ============ MITTAGSMENÜ (split) ============ */
.menu{display:grid;grid-template-columns:1fr 1fr;align-items:stretch;background:var(--green)}
.menu-img{position:relative;overflow:hidden;min-height:420px}
.menu-img img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.menu:hover .menu-img img{transform:scale(1.05)}
.menu-img .stamp{position:absolute;left:24px;top:24px;background:var(--gold);color:var(--green-deep);padding:.5rem 1rem;border-radius:30px;font-weight:600;font-size:.84rem}
.menu-body{padding:5rem 4rem;color:#fff;display:flex;flex-direction:column;justify-content:center}
.menu-body .label{color:var(--gold-light)}
.menu-body h2{color:#fff;font-size:clamp(1.9rem,3.4vw,2.7rem)}
.menu-body h2 em{font-style:italic;color:var(--gold-light)}
.menu-time{display:inline-flex;align-items:center;gap:.6rem;background:rgba(201,169,98,.16);border:1px solid rgba(201,169,98,.4);color:var(--gold-light);padding:.6rem 1.1rem;border-radius:30px;font-weight:500;margin:1.1rem 0 1.4rem;font-size:.95rem}
.menu-body p{color:rgba(255,255,255,.8);margin-bottom:1rem}
.menu-body .btn{align-self:flex-start;margin-top:.6rem}

/* ============ PRODUKTE ============ */
.products{padding:6.5rem 0;background:var(--cream)}
/* „Produkte aus Tradition“ – einzelne Würstel-Illustration dezent im Hintergrund (skalierend) */
#produkte{position:relative;overflow:hidden}
#produkte>.wrap{position:relative;z-index:1}
#produkte::before{content:"";position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none;opacity:.07;background:none no-repeat right -30px bottom -10px;background-size:min(520px,44%)}
@media(max-width:700px){#produkte::before{opacity:.05;background-size:64%}}
.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.pcard{background:#fff;border-radius:16px;overflow:hidden;box-shadow:var(--shadow-s);transition:var(--t);position:relative}
a.pcard{display:block;color:inherit;text-decoration:none}
.pcard:hover{transform:translateY(-8px);box-shadow:var(--shadow-m)}
.pcard .pimg{position:relative;aspect-ratio:4/3;overflow:hidden}
.pcard .pimg img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.pcard:hover .pimg img{transform:scale(1.07)}
.pcard .pimg::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(16,39,26,.55),transparent 55%);opacity:0;transition:var(--t)}
.pcard:hover .pimg::after{opacity:1}
.pcard .pov{position:absolute;left:0;right:0;bottom:14px;text-align:center;color:var(--gold-light);font-weight:600;font-size:.9rem;opacity:0;transform:translateY(10px);transition:var(--t);z-index:1}
.pcard:hover .pov{opacity:1;transform:translateY(0)}
.pcard .pbody{padding:1.4rem 1.4rem 1.7rem}
.pcard h3{font-size:1.25rem;color:var(--green);margin-bottom:.4rem}
.pcard p{color:var(--muted);font-size:.92rem}

/* ============ ÜBER UNS ============ */
.about{padding:6.5rem 0;background:var(--warm-white)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
.about-media{display:flex;flex-direction:column;gap:1.4rem}
.about-team{position:relative;border-radius:18px;overflow:hidden;box-shadow:var(--shadow-l);margin:0}
.about-team img{width:100%;aspect-ratio:3/2;object-fit:cover;display:block;transition:transform .9s var(--ease)}
.about-team:hover img{transform:scale(1.05)}
.about-img{position:relative;border-radius:18px;overflow:hidden;box-shadow:var(--shadow-l)}
.about-img img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform .9s var(--ease)}
.about-img:hover img{transform:scale(1.05)}
.about-img .estd{position:absolute;right:18px;bottom:18px;background:var(--gold);color:var(--green-deep);width:104px;height:104px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:var(--shadow-m);font-family:var(--display)}
.about-img .estd b{font-size:1.7rem;line-height:1}
.about-img .estd span{font-size:.66rem;letter-spacing:.14em;text-transform:uppercase}
.about-name{position:absolute;left:18px;bottom:18px;background:rgba(16,39,26,.8);color:#fff;padding:.5rem .95rem;border-radius:30px;font-family:var(--display);font-size:1.05rem;font-weight:600;backdrop-filter:blur(3px);box-shadow:var(--shadow-s)}
.about h2{font-size:clamp(1.9rem,3.6vw,2.8rem)}
.about h2 em{font-style:italic;color:var(--gold-deep)}
.about-text{color:var(--muted);margin:1.2rem 0}
.stats{display:flex;gap:2.4rem;margin:1.8rem 0}
.stat .num{font-family:var(--display);font-size:2.4rem;color:var(--green);line-height:1}
.stat .lab{font-size:.85rem;color:var(--muted)}

/* ============ SB-LADEN ============ */
.sb{padding:6.5rem 0;background:var(--warm-white)}
.sb-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:4rem;align-items:center}
.sb-text h2{font-size:clamp(1.9rem,3.6vw,2.8rem)}
.sb-text h2 em{font-style:italic;color:var(--gold-deep)}
.sb-hours{display:inline-flex;align-items:center;gap:.5rem;background:var(--green-tint);color:var(--green);border:1px solid rgba(26,61,46,.14);padding:.5rem 1.05rem;border-radius:40px;font-weight:600;font-size:.92rem;margin:1rem 0 1.2rem}
.sb-hours svg{width:17px;height:17px}
.sb-text p{color:var(--muted);margin-bottom:1.3rem}
.sb-list{list-style:none;display:grid;gap:.65rem}
.sb-list li{position:relative;padding-left:1.7rem;color:var(--ink)}
.sb-list li::before{content:"";position:absolute;left:0;top:.5em;width:10px;height:10px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 3px rgba(201,169,98,.2)}
.sb-gallery{display:flex;flex-direction:column;gap:1rem}
.sb-main{position:relative;border-radius:16px;overflow:hidden;box-shadow:var(--shadow-m)}
.sb-main img{width:100%;aspect-ratio:16/10;object-fit:cover;transition:transform .9s var(--ease)}
.sb-main:hover img{transform:scale(1.04)}
.sb-badge{position:absolute;left:16px;bottom:16px;background:var(--gold);color:var(--green-deep);padding:.5rem 1rem;border-radius:30px;font-weight:700;font-size:.85rem;box-shadow:var(--shadow-s)}
.sb-thumbs{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
/* <picture> als echtes Grid-Item (statt display:contents), sonst versetzen sich die Thumbs */
.sb-thumbs picture,.sb-main picture{display:block}
.sb-thumbs img{width:100%;aspect-ratio:3/2;object-fit:cover;border-radius:12px;box-shadow:var(--shadow-s);transition:transform .5s var(--ease)}
.sb-thumbs img:hover{transform:translateY(-4px)}

/* ============ PARTYSERVICE (grün) ============ */
.party{padding:6.5rem 0;background:linear-gradient(160deg,#f0f4ee,#e7eee7)}
.party .label{color:var(--gold-deep)}
.sgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.8rem}
.scard{background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:var(--t);box-shadow:var(--shadow-s)}
.scard:hover{transform:translateY(-8px);border-color:rgba(201,169,98,.5);box-shadow:var(--shadow-l)}
.scard .simg{aspect-ratio:3/2;overflow:hidden}
.scard .simg img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.scard:hover .simg img{transform:scale(1.07)}
.scard .sbody{padding:1.6rem 1.6rem 1.9rem}
.scard h3{color:var(--green);font-size:1.3rem;margin-bottom:.6rem}
.scard p{color:var(--muted);font-size:.94rem}

/* ============ AUSZEICHNUNGEN ============ */
.awards{padding:6.5rem 0;background:var(--cream)}
.agrid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.acard{background:#fff;border:1px solid var(--line);border-radius:16px;padding:2rem 1.6rem;text-align:center;transition:var(--t)}
.acard:hover{transform:translateY(-6px);box-shadow:var(--shadow-m);border-color:var(--gold)}
.acard .ay{font-family:var(--display);font-size:2rem;color:var(--gold-deep);margin-bottom:.8rem}
.amed{display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:.92rem;color:var(--ink);padding:.25rem 0}
.dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.dot.g{background:linear-gradient(135deg,#e6cf8b,#c9a962)}
.dot.s{background:linear-gradient(135deg,#e8e8e8,#b8b8b8)}
.dot.b{background:linear-gradient(135deg,#d8a878,#b07a45)}
.awards .extra{text-align:center;margin-top:2.4rem;color:var(--muted)}
.awards .extra strong{color:var(--green)}

/* ============ KONTAKT-CTA ============ */
.cta-band{padding:6rem 0;background:linear-gradient(120deg,var(--green) 0%,var(--green-deep) 100%);color:#fff;text-align:center;position:relative;overflow:hidden}
.cta-band::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 0,rgba(201,169,98,.18),transparent 60%)}
.cta-band>*{position:relative;z-index:1}
.cta-band h2{color:#fff;font-size:clamp(2rem,4vw,3rem)}
.cta-band h2 em{font-style:italic;color:var(--gold-light)}
.cta-band p{color:rgba(255,255,255,.82);max-width:560px;margin:1rem auto 2rem}
.cta-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ============ FOOTER ============ */
.footer{background:var(--green-deep);color:rgba(255,255,255,.72);padding:4.5rem 0 2rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem}
.footer img{height:132px;width:auto;margin-bottom:1.2rem}
.footer h4{font-family:var(--display);color:var(--gold-light);font-size:1.15rem;margin-bottom:1.1rem}
.footer ul{list-style:none}
.footer li{margin-bottom:.6rem;font-size:.92rem}
.footer-grid li{display:flex;align-items:flex-start;gap:.55rem}
.footer-grid li svg.fi{width:15px;height:15px;flex-shrink:0;margin-top:.18em;stroke:var(--gold);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.footer a{color:rgba(255,255,255,.72);transition:var(--t)}
.footer a:hover{color:var(--gold-light)}
.footer-bottom{max-width:1240px;margin:3.4rem auto 0;padding:1.8rem 28px 0;border-top:1px solid rgba(255,255,255,.12);display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-size:.86rem}
.footer-bottom a{color:rgba(255,255,255,.8)}
.footer-bottom a:hover{color:var(--gold-light)}

/* ============ BACK TO TOP ============ */
.totop{position:fixed;right:1.6rem;bottom:1.6rem;width:50px;height:50px;border-radius:50%;background:var(--green);color:#fff;border:0;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:var(--t);box-shadow:var(--shadow-m);z-index:900}
.totop.show{opacity:1;visibility:visible}
.totop:hover{background:var(--gold);color:var(--green-deep);transform:translateY(-4px)}

/* Schwebender Kontakt-Button – Kontakt immer sichtbar, nicht nur im Menü */
.contact-fab{position:fixed;left:1.6rem;bottom:1.6rem;display:inline-flex;align-items:center;gap:.5rem;background:var(--gold);color:var(--green-deep);padding:.75rem 1.25rem;border-radius:999px;font-weight:600;font-size:.92rem;letter-spacing:.02em;box-shadow:0 8px 22px rgba(201,169,98,.5);z-index:900;transition:var(--t)}
.contact-fab svg{flex:0 0 auto}
.contact-fab:hover{background:var(--gold-light);transform:translateY(-3px);box-shadow:0 12px 28px rgba(201,169,98,.55)}
@media(max-width:560px){.contact-fab{left:1rem;bottom:1rem;padding:.85rem;border-radius:50%}.contact-fab span{display:none}}

/* "Über 40" – kleiner Präfix vor der Zahl */
.n .pre,.num .pre,.stat .pre{font-size:.5em;font-weight:600;vertical-align:.18em;color:inherit;opacity:.92}

/* ============ REVEAL-ANIMATIONEN ============ */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.revealed{opacity:1;transform:none}
.stagger>*{opacity:0;transform:translateY(24px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.stagger.revealed>*{opacity:1;transform:none}
.stagger.revealed>*:nth-child(1){transition-delay:.05s}
.stagger.revealed>*:nth-child(2){transition-delay:.13s}
.stagger.revealed>*:nth-child(3){transition-delay:.21s}
.stagger.revealed>*:nth-child(4){transition-delay:.29s}
.stagger.revealed>*:nth-child(5){transition-delay:.37s}
.stagger.revealed>*:nth-child(6){transition-delay:.45s}
.stagger.revealed>*:nth-child(7){transition-delay:.53s}
.stagger.revealed>*:nth-child(8){transition-delay:.61s}

/* Hero-Eingangsanimation */
.hero-content>*{opacity:0;transform:translateY(26px);animation:fadeUp .9s var(--ease) forwards}
.hero-content>*:nth-child(1){animation-delay:.2s}
.hero-content>*:nth-child(2){animation-delay:.34s}
.hero-content>*:nth-child(3){animation-delay:.46s}
.hero-content>*:nth-child(4){animation-delay:.56s}
.hero-content>*:nth-child(5){animation-delay:.66s}
.hero-card{opacity:0;animation:fadeIn 1.1s var(--ease) .5s forwards}
@keyframes fadeUp{to{opacity:1;transform:none}}
@keyframes fadeIn{to{opacity:1}}

/* ============ RESPONSIVE ============ */
@media(max-width:1024px){
  .footer-grid{grid-template-columns:1fr 1fr}
  .pgrid,.agrid{grid-template-columns:repeat(2,1fr)}
}
/* Tablet-Querformat: Hero ausgewogener, Bild größer/höher */
@media(min-width:881px) and (max-width:1024px){
  .hero-inner{grid-template-columns:1.1fr .9fr;gap:36px}
  .hero-card{max-width:440px}
}
@media(max-width:880px){
  /* Kein backdrop-filter auf Mobil: teurer Dauer-Blur = Hauptursache für Menü-Ruckler beim Antippen */
  .nav,.nav.scrolled{backdrop-filter:none!important;-webkit-backdrop-filter:none!important}
  /* ---- Mobiles Vollbild-Menü ---- */
  /* Overlay bleibt im Layout (eigene Ebene) und wird nur per Opacity ein-/ausgeblendet
     -> Öffnen ohne Layout-/Paint-Ruckler ("Hänger") */
  .nav-links{position:fixed;inset:0;z-index:999;
    background:radial-gradient(135% 90% at 50% 0%,#1d4c34 0%,var(--green-deep) 60%);
    flex-direction:column;align-items:stretch;justify-content:flex-start;gap:.05rem;padding:5.2rem 1.4rem 2.4rem;overflow-y:auto;
    opacity:0;visibility:hidden;pointer-events:none;transform:translateZ(0);
    transition:opacity .15s ease,visibility 0s linear .15s}
  .nav-links.open{opacity:1;visibility:visible;pointer-events:auto;transition:opacity .15s ease}
  /* Hintergrund-Animationen pausieren, solange das Menü offen ist (entlastet die GPU) */
  body.nav-locked .hero-bg img,body.nav-locked .logo,body.nav-locked .nav-menu{animation-play-state:paused}
  /* Marken-Logo oben im Overlay */
  .nav-links::before{content:"";flex:none;width:128px;height:70px;margin:0 auto 1.2rem;
    background:url(../images/turza-logo-white.webp) center/contain no-repeat}
  /* Menüzeilen mit Icon links */
  .nav-links li{width:100%;max-width:340px;margin:0 auto}
  .nav-links a{display:flex!important;align-items:center;gap:.95rem;justify-content:flex-start;width:100%;
    font-size:1.12rem;font-weight:500;letter-spacing:.01em;color:#f4efe3!important;text-shadow:none!important;
    padding:.92rem .35rem;border-bottom:1px solid rgba(201,169,98,.14);border-radius:0}
  .nav-links a::after{display:none!important}
  .nav-links a:hover,.nav-links a:active{color:var(--gold-light)!important;transform:none;background:none}
  .nav-links .mnav-ic{display:block;width:23px;height:23px;flex:none;stroke:var(--gold);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;transition:stroke .2s}
  .nav-links a:hover .mnav-ic,.nav-links a:active .mnav-ic{stroke:var(--gold-light)}
  /* Wochenmenü hervorgehoben (gold) */
  .nav-links .nav-menu{background:transparent!important;color:var(--gold-light)!important;font-weight:700!important;font-size:1.12rem!important;
    padding:.92rem .35rem!important;box-shadow:none!important;animation:none!important;border-radius:0;letter-spacing:.01em}
  .nav-links .nav-menu svg{width:23px!important;height:23px!important;stroke:var(--gold-light)}
  /* Kontakt als normale Zeile */
  .nav-links .nav-cta{background:transparent!important;border:0!important;color:#f4efe3!important;
    padding:.92rem .35rem!important;box-shadow:none!important;border-radius:0;font-weight:500}
  .nav-links .nav-cta::before{display:none!important}
  .nav-links .nav-cta:hover{background:none!important;color:var(--gold-light)!important;transform:none}
  /* Schnellkontakt-Leiste unten */
  .nav-links .nav-contact{max-width:340px;margin:1.25rem auto 0;display:flex;flex-direction:column;align-items:center;gap:.8rem;
    border-top:1px solid rgba(201,169,98,.22);padding-top:1.3rem}
  .nav-links .nav-contact .nc-actions{display:flex;gap:.7rem;width:100%}
  .nav-links .nav-contact a{flex:1;justify-content:center;gap:.5rem;width:auto;border:1px solid rgba(201,169,98,.55)!important;border-radius:40px;
    padding:.72rem .6rem!important;font-size:.98rem;font-weight:600;color:var(--gold-light)!important}
  .nav-links .nav-contact a:hover{background:var(--gold)!important;color:var(--green-deep)!important}
  .nav-links .nav-contact a .mnav-ic{width:18px;height:18px;stroke:currentColor}
  .nav-links .nav-contact a:hover .mnav-ic{stroke:currentColor}
  /* Hinweis nur bei geschlossenem Geschäft (data-when-closed) */
  .nav-links .nav-contact .nc-hint{display:block;width:100%;margin-top:.1rem;font-size:.86rem;line-height:1.5;
    color:#e7dcc2;background:rgba(201,169,98,.1);border:1px solid rgba(201,169,98,.28);border-radius:12px;padding:.7rem .85rem;text-align:center;font-weight:400}
  .nav-links .nav-contact .nc-hint a{display:inline;flex:none;width:auto;border:0!important;border-radius:0;padding:0!important;background:none!important;color:var(--gold-light)!important;font-weight:700;text-decoration:underline}
  .nav-links .nav-contact .nc-hint a:hover{background:none!important;color:#fff!important}
  .nav-links .nav-contact .nc-hint .open-badge{display:inline-block;margin:0 .1rem .25rem 0;vertical-align:middle}
  .burger{display:flex}
  .burger-label{display:inline-flex}
  /* X (offenes Menü) hell auf dunklem Overlay */
  .nav.menu-open .burger span{background:#f4efe3}
  .hero-inner,.menu,.about-grid,.sb-grid{grid-template-columns:1fr}
  .hero-card{justify-self:center;margin-top:2rem;max-width:300px}
  .menu,.menu-body{min-width:0}
  .menu-body{padding:3rem 1.8rem}
  .menu-body h2{overflow-wrap:break-word}
  .trust-grid,.fgrid,.jtimeline,.sgrid{grid-template-columns:1fr 1fr}
  .jtimeline::before{display:none}
  .stats{gap:1.4rem}
}
@media(max-width:560px){
  .trust-grid,.fgrid,.jtimeline,.sgrid,.pgrid,.agrid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:2.2rem}
  /* Hero-Buttons: volle Breite, gestapelt – nie abgeschnitten */
  .hero-actions{flex-direction:column;align-items:stretch}
  .hero-actions .btn{width:100%;justify-content:center}
  /* Kontakt-CTA-Buttons ebenso sauber stapeln */
  .cta-actions{flex-direction:column;align-items:stretch}
  .cta-actions .btn{width:100%;justify-content:center}
}

/* ============ BARRIEREFREIHEIT: Animationen aus ============ */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001s!important;animation-iteration-count:1!important;transition-duration:.001s!important;scroll-behavior:auto!important}
  .hero-bg img{animation:none;transform:scale(1.05)}
  .reveal,.stagger>*,.hero-content>*,.hero-card{opacity:1;transform:none}
}

/* ---- Footer: Öffnungszeiten-Block + Open-Badge + Made-Zeile ---- */
.foot-oh .oh-c{display:flex;flex-direction:column;gap:.12rem}
.foot-oh b{color:rgba(255,255,255,.92);font-weight:600;display:inline-flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:.15rem}
.open-badge{font-size:.72rem;font-weight:600;padding:.14rem .55rem;border-radius:30px;letter-spacing:.02em;white-space:nowrap}
.open-badge.open{background:rgba(76,175,80,.18);color:#8fd694;border:1px solid rgba(76,175,80,.45)}
.open-badge.open::before{content:"● ";color:#5cc164}
.open-badge.closed{background:rgba(255,255,255,.07);color:rgba(255,255,255,.6);border:1px solid rgba(255,255,255,.18)}
.footer-made{text-align:center;margin-top:1.3rem;color:rgba(255,255,255,.3);font-size:.82rem}
.footer-made .hz{color:rgba(224,107,107,.55)}
.footer-made a{color:rgba(255,255,255,.34)}
.footer-made a:hover{color:var(--gold-light)}

/* ===== Footer: App- & Social-Badges ===== */
.foot-apps{margin-top:18px}
.foot-apps h5{font-size:11.5px;text-transform:uppercase;letter-spacing:.09em;font-weight:700;
  color:var(--gold-light,#d6b36c);margin:0 0 9px}
.foot-apps-row{display:flex;flex-wrap:wrap;gap:8px;max-width:330px}
.foot-apps .fapp{display:inline-flex;align-items:center;gap:7px;text-decoration:none;
  border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.06);border-radius:30px;
  padding:7px 13px;font-size:12.5px;font-weight:600;color:#f0ece2;line-height:1;
  transition:background .16s,border-color .16s,color .16s,transform .16s}
.foot-apps .fapp svg{width:15px;height:15px;fill:currentColor;flex:none}
.foot-apps .fapp:hover{background:var(--gold,#c8a44d);border-color:var(--gold,#c8a44d);color:#1f2a14;transform:translateY(-1px)}
/* „Bewerten Sie uns" – Google-Review-Button hervorgehoben (Gold) */
.foot-apps .fapp-review{background:var(--gold);border-color:var(--gold);color:var(--green-deep);font-weight:700}
.foot-apps .fapp-review svg{fill:var(--green-deep)}
.foot-apps .fapp-review:hover{background:var(--gold-light);border-color:var(--gold-light);color:var(--green-deep);transform:translateY(-1px)}

/* ===== Dezente Deko-Grafiken (locker über die Seite verteilt) ===== */
.deco-host{position:relative;overflow:hidden}
.deco-host>.wrap{position:relative;z-index:1}
.deco{position:absolute;z-index:0;pointer-events:none;user-select:none;opacity:.14;mix-blend-mode:multiply}
@media(max-width:680px){.deco{display:none}}
