/* =========================================================
   KRÜMELZWERGE · Kindertagespflege Vira Geys
   Design system — watercolor storybook, sage + wildflower
   ========================================================= */

/* ---------- TOKENS ---------- */
:root{
  /* Greens (preserved from brand) */
  --g50:#f1f8ea;  --g100:#dcefca; --g200:#b6dd95;
  --g300:#8fca6e; --g400:#6dbb52; --g500:#549a3c;
  --g600:#3d8f28; --g700:#2c6e1c; --g800:#1f5212;

  /* Warm neutrals */
  --cream:#fdfaf4; --warm:#f7f1e7; --sand:#efe7d8; --paper:#fffdf8;
  --ink:#2c2a26; --muted:#6f6a60; --faint:#9a948a;
  --line:rgba(40,60,25,.10);

  /* Wildflower accents (soft watercolor) */
  --bloom:oklch(0.80 0.085 18);    /* coral-pink coneflower */
  --bloom-deep:oklch(0.70 0.11 20);
  --sun:oklch(0.88 0.095 88);      /* buttercup yellow */
  --sun-deep:oklch(0.80 0.12 80);
  --lav:oklch(0.76 0.065 295);     /* lupine lavender */
  --sky:oklch(0.84 0.05 230);      /* gentle stream blue */

  /* Type */
  --serif:'Fraunces', Georgia, serif; /* overridden below — using Playfair */
  --display:'Playfair Display', Georgia, serif;
  --body:'Nunito', system-ui, sans-serif;
  --hand:'Caveat', cursive;

  /* Shape & depth */
  --r-sm:14px; --r:20px; --r-lg:30px; --r-xl:42px;
  --shadow-sm:0 4px 18px rgba(60,80,30,.07);
  --shadow:0 18px 50px -18px rgba(50,70,25,.22);
  --shadow-lg:0 40px 90px -30px rgba(40,60,20,.32);

  --maxw:1180px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:clip;}
body{
  font-family:var(--body);
  background:var(--cream);
  color:var(--ink);
  line-height:1.72;
  overflow-x:clip;
}
img{max-width:100%;display:block;}
a{color:inherit;}

::selection{background:var(--g200);color:var(--g800);}

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

/* ---------- SHARED ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px;}
.section{padding:118px 0;position:relative;}
.section-inner{max-width:var(--maxw);margin:0 auto;padding:0 32px;}

.eyebrow{
  font-family:var(--hand);
  font-size:30px;
  color:var(--g500);
  line-height:1;
  margin-bottom:6px;
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:'';width:26px;height:2px;background:var(--g300);border-radius:2px;display:inline-block;}

h2.h{
  font-family:var(--display);
  font-weight:600;
  font-size:clamp(30px,4vw,46px);
  line-height:1.08;
  color:var(--g800);
  letter-spacing:-.5px;
  margin-bottom:22px;
  max-width:18ch;
}
h2.h em{font-style:italic;color:var(--g500);}
.lead{font-size:18px;color:var(--muted);max-width:60ch;line-height:1.78;}

/* buttons */
.btn{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--body);font-weight:800;font-size:15px;
  padding:15px 30px;border-radius:40px;border:none;cursor:pointer;
  text-decoration:none;transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s;
  position:relative;
}
.btn-primary{background:var(--g600);color:#fff;box-shadow:0 12px 26px -10px rgba(45,110,28,.7);}
.btn-primary:hover{background:var(--g700);transform:translateY(-3px);box-shadow:0 20px 36px -12px rgba(45,110,28,.75);}
.btn-ghost{background:rgba(255,255,255,.7);color:var(--g700);border:2px solid var(--g200);}
.btn-ghost:hover{background:#fff;border-color:var(--g300);transform:translateY(-3px);}

/* scroll reveal */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .9s var(--ease),transform .9s var(--ease);}
.reveal.in{opacity:1;transform:none;}
.reveal.d1{transition-delay:.08s;}
.reveal.d2{transition-delay:.16s;}
.reveal.d3{transition-delay:.24s;}
.reveal.d4{transition-delay:.32s;}
.reveal.d5{transition-delay:.40s;}

@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1!important;transform:none!important;}
  *{animation:none!important;}
  html{scroll-behavior:auto;}
}

/* decorative watercolor blobs */
.blob{position:absolute;border-radius:50%;filter:blur(46px);opacity:.5;pointer-events:none;z-index:0;}

/* ---------- NAV ---------- */
nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 40px;
  transition:padding .35s var(--ease),background .35s,box-shadow .35s,border-color .35s;
  border-bottom:1px solid transparent;
}
nav.scrolled{
  background:rgba(253,250,244,.9);
  backdrop-filter:blur(14px) saturate(1.2);
  border-bottom:1px solid var(--line);
  box-shadow:0 6px 30px -16px rgba(40,60,20,.3);
  padding:13px 40px;
}
.nav-logo{display:flex;align-items:center;gap:11px;font-family:var(--display);font-size:22px;color:var(--g800);text-decoration:none;letter-spacing:-.3px;}
.nav-logo .mark{width:34px;height:34px;flex-shrink:0;}
.nav-logo em{font-style:italic;color:var(--g500);}
.nav-links{display:flex;align-items:center;gap:6px;list-style:none;}
.nav-links a{
  text-decoration:none;font-size:14.5px;color:var(--ink);font-weight:700;white-space:nowrap;
  padding:9px 14px;border-radius:30px;transition:color .2s,background .2s;position:relative;
}
.nav-links a:hover{color:var(--g700);background:var(--g50);}
.nav-cta{margin-left:8px;background:var(--g600);color:#fff!important;padding:11px 20px!important;white-space:nowrap;box-shadow:0 10px 22px -10px rgba(45,110,28,.7);}
.nav-cta:hover{background:var(--g700)!important;}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;}
.nav-toggle span{width:24px;height:2.5px;background:var(--g800);border-radius:3px;transition:.3s;}

/* mobile menu */
.mobile-menu{
  position:fixed;inset:0;z-index:999;background:var(--cream);
  display:flex;flex-direction:column;justify-content:center;align-items:center;gap:6px;
  opacity:0;visibility:hidden;transform:translateY(-12px);transition:.4s var(--ease);
}
.mobile-menu.open{opacity:1;visibility:visible;transform:none;}
.mobile-menu a{font-family:var(--display);font-size:30px;color:var(--g800);text-decoration:none;padding:12px;}
.mobile-menu a:hover{color:var(--g500);}

/* ---------- HERO ---------- */
.hero{
  position:relative;min-height:100svh;display:flex;align-items:center;
  padding:120px 0 90px;overflow:hidden;
  background:linear-gradient(180deg,#fdfaf4 0%, #f6f8ee 100%);
}
.hero-art{
  position:absolute;inset:0;background-image:url('assets/hero.png');
  background-size:cover;background-position:center right;background-repeat:no-repeat;
  z-index:0;
}
/* fade the painting into cream on the left so text is readable */
.hero-art::after{
  content:'';position:absolute;inset:0;
  background:
    linear-gradient(100deg, rgba(253,250,244,.97) 0%, rgba(253,250,244,.86) 30%, rgba(253,250,244,.28) 54%, rgba(253,250,244,0) 72%),
    linear-gradient(0deg, rgba(253,250,244,.7) 0%, rgba(253,250,244,0) 24%);
}
@media (max-width:860px){
  .hero-art::after{background:linear-gradient(180deg, rgba(253,250,244,.62) 0%, rgba(253,250,244,.4) 42%, rgba(253,250,244,.9) 100%);}
}
.hero-inner{position:relative;z-index:3;max-width:var(--maxw);margin:0 auto;padding:0 32px;width:100%;}
.hero-col{max-width:620px;}
.hero-badge{
  display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.78);
  border:1px solid var(--g200);color:var(--g700);font-size:13px;font-weight:800;
  padding:8px 18px;border-radius:30px;letter-spacing:.3px;margin-bottom:26px;
  backdrop-filter:blur(4px);box-shadow:var(--shadow-sm);
}
.hero-badge .dot{width:8px;height:8px;border-radius:50%;background:var(--g400);box-shadow:0 0 0 4px rgba(109,187,82,.25);}
.hero h1{
  font-family:var(--display);font-weight:600;
  font-size:clamp(40px,6.2vw,72px);line-height:1.02;color:var(--g800);
  letter-spacing:-1.2px;margin-bottom:22px;
}
.hero h1 em{font-style:italic;color:var(--g500);position:relative;}
.hero h1 .word{display:inline-block;margin-right:.16em;opacity:0;transform:translateY(40px) rotate(2deg);}
.hero.loaded h1 .word{animation:wordIn .9s var(--ease) forwards;}
@keyframes wordIn{to{opacity:1;transform:none;}}
.hero-sub{font-size:18.5px;color:#4f4a40;max-width:50ch;margin-bottom:18px;line-height:1.78;}
.hero-sub strong{color:var(--g700);}
.hero-loc{font-size:15px;color:var(--g600);font-weight:800;margin-bottom:28px;display:flex;align-items:center;gap:8px;}
.hero-meta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:34px;}
.hero-chip{
  background:rgba(255,255,255,.82);border:1px solid var(--g200);border-radius:18px;
  padding:13px 20px;display:flex;align-items:center;gap:13px;backdrop-filter:blur(5px);box-shadow:var(--shadow-sm);
}
.hero-chip .ico{width:38px;height:38px;display:grid;place-items:center;border-radius:12px;background:var(--g50);font-size:20px;}
.hero-chip-label{font-size:10.5px;font-weight:800;color:var(--faint);text-transform:uppercase;letter-spacing:.8px;}
.hero-chip-val{font-size:15px;font-weight:800;color:var(--g800);}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap;}

/* floating petals */
.petal{position:absolute;z-index:2;pointer-events:none;will-change:transform;opacity:.9;}
.petal.p1{top:18%;left:8%;animation:float1 11s ease-in-out infinite;}
.petal.p2{top:64%;left:14%;animation:float2 14s ease-in-out infinite;}
.petal.p3{top:30%;left:40%;animation:float1 13s ease-in-out infinite 1s;}
.petal.p4{top:74%;left:46%;animation:float2 16s ease-in-out infinite .5s;}
@keyframes float1{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-26px) rotate(14deg)}}
@keyframes float2{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(24px) rotate(-12deg)}}

.scroll-cue{
  position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:4;
  display:flex;flex-direction:column;align-items:center;gap:7px;color:var(--g600);
  font-size:11px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;
}
.scroll-cue .mouse{width:23px;height:36px;border:2px solid var(--g400);border-radius:14px;position:relative;}
.scroll-cue .mouse::after{content:'';position:absolute;top:6px;left:50%;width:4px;height:7px;background:var(--g500);border-radius:3px;transform:translateX(-50%);animation:wheel 1.7s infinite;}
@keyframes wheel{0%{opacity:1;top:6px}70%{opacity:0;top:16px}100%{opacity:0}}

/* watercolor section transition */
.edge{display:block;width:100%;height:60px;}

/* ---------- PLÄTZE BAR ---------- */
.plaetze{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:30px 0;position:relative;z-index:5;}
.plaetze-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.pcard{
  display:flex;gap:15px;align-items:flex-start;border-radius:var(--r);padding:20px 22px;
  border:1.5px solid;transition:transform .3s var(--ease),box-shadow .3s var(--ease);
}
.pcard:hover{transform:translateY(-4px);box-shadow:var(--shadow);}
.pcard .pico{width:46px;height:46px;flex-shrink:0;border-radius:14px;display:grid;place-items:center;font-size:23px;}
.pcard h4{font-family:var(--display);font-size:18px;font-weight:600;margin-bottom:3px;color:var(--g800);}
.pcard p{font-size:13.5px;color:var(--muted);line-height:1.55;}
.pcard.warte{background:#fff8e8;border-color:#f3d98a;}
.pcard.warte .pico{background:#fceec2;}
.pcard.frei{background:#eafae6;border-color:#a8d88e;}
.pcard.frei .pico{background:#d4f0c5;}
.pcard.info{background:var(--g50);border-color:var(--g200);}
.pcard.info .pico{background:#fff;}

/* ---------- ABOUT ---------- */
#ueber{background:var(--cream);}
.about-grid{display:grid;grid-template-columns:0.85fr 1.15fr;gap:64px;align-items:start;}
.about-photo-wrap{position:relative;}
.about-photo{
  width:100%;border-radius:160px 160px 24px 24px;object-fit:cover;aspect-ratio:502/640;
  box-shadow:var(--shadow-lg);position:relative;z-index:2;border:7px solid #fff;
}
.about-photo-wrap::before{
  content:'';position:absolute;inset:-22px -22px auto -22px;height:62%;
  background:var(--g100);border-radius:170px 170px 40px 40px;z-index:0;transform:rotate(-3deg);opacity:.7;
}
.about-tag{
  position:absolute;bottom:24px;left:50%;transform:translateX(-50%);z-index:3;
  background:#fff;border-radius:30px;padding:10px 22px;box-shadow:var(--shadow);
  font-weight:800;font-size:14px;color:var(--g700);display:flex;align-items:center;gap:8px;white-space:nowrap;
}
.about-photo-wrap .deco-flower{position:absolute;z-index:3;top:-14px;right:-10px;width:74px;}
.about-text p{font-size:16px;color:#4a463d;margin-bottom:16px;line-height:1.82;}
.about-text strong{color:var(--g700);}
.erlaubnis{
  display:flex;gap:15px;background:var(--g50);border:1px solid var(--g200);border-left:5px solid var(--g400);
  border-radius:var(--r-sm);padding:18px 20px;margin:26px 0;
}
.erlaubnis .ico{font-size:24px;flex-shrink:0;}
.erlaubnis p{font-size:14px;color:var(--muted);line-height:1.6;}
.erlaubnis strong{color:var(--g700);}
.sub-label{font-family:var(--hand);font-size:24px;color:var(--g500);margin:24px 0 12px;}
.qual-tags{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:30px;}
.qual{
  font-size:13.5px;font-weight:700;color:var(--g700);background:#fff;border:1px solid var(--g200);
  padding:8px 16px;border-radius:30px;transition:transform .25s var(--ease),background .25s;
}
.qual:hover{background:var(--g50);transform:translateY(-2px);}
.highlights{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.hcard{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:20px 22px;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s;
}
.hcard:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--g200);}
.hcard-top{display:flex;align-items:center;gap:11px;margin-bottom:8px;}
.hcard-top span{width:44px;height:44px;border-radius:50%;background:var(--g50);display:grid;place-items:center;font-size:22px;flex-shrink:0;}
.hcard h3{font-family:var(--display);font-size:17px;font-weight:600;color:var(--g800);}
.hcard p{font-size:13.5px;color:var(--muted);line-height:1.55;}

/* ---------- ANGEBOTE ---------- */
#angebote{background:var(--warm);}
.extras-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:46px;}
.extra{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:30px 26px;
  text-align:center;transition:transform .35s var(--ease),box-shadow .35s var(--ease);position:relative;overflow:hidden;
}
.extra::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 0%, var(--g50), transparent 70%);opacity:0;transition:.35s;}
.extra:hover{transform:translateY(-7px);box-shadow:var(--shadow);}
.extra:hover::after{opacity:1;}
.extra .ico{width:74px;height:74px;margin:0 auto 16px;border-radius:50%;background:var(--g50);display:grid;place-items:center;font-size:34px;position:relative;z-index:1;transition:transform .35s var(--ease);}
.extra:hover .ico{transform:scale(1.08) rotate(-5deg);}
.extra h4{font-family:var(--display);font-size:20px;font-weight:600;color:var(--g800);margin-bottom:5px;position:relative;z-index:1;}
.extra p{font-size:14px;color:var(--muted);position:relative;z-index:1;}

/* ---------- TAGESABLAUF (timeline) ---------- */
#programm{background:var(--cream);}
.timeline{position:relative;max-width:760px;margin:50px auto 0;padding-left:8px;}
.timeline::before{
  content:'';position:absolute;left:78px;top:8px;bottom:8px;width:3px;
  background:linear-gradient(var(--g300),var(--g200));border-radius:3px;
}
.tl-progress{position:absolute;left:78px;top:8px;width:3px;background:var(--g500);border-radius:3px;height:0;transition:height .2s linear;z-index:1;}
.tl-item{display:grid;grid-template-columns:64px 40px 1fr;gap:0;align-items:start;margin-bottom:30px;position:relative;}
.tl-time{font-family:var(--display);font-size:18px;font-weight:600;color:var(--g600);text-align:right;padding-top:9px;}
.tl-mid{display:flex;justify-content:center;position:relative;z-index:2;padding-top:9px;}
.tl-dot{width:18px;height:18px;border-radius:50%;background:#fff;border:4px solid var(--g400);transition:transform .4s var(--ease),background .4s,border-color .4s;}
.tl-item.in .tl-dot{background:var(--g500);border-color:var(--g600);transform:scale(1.18);}
.tl-card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:18px 24px;
  box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s var(--ease);
}
.tl-card:hover{transform:translateX(6px);box-shadow:var(--shadow);}
.tl-card h4{font-family:var(--display);font-size:18px;font-weight:600;color:var(--g800);margin-bottom:4px;}
.tl-card p{font-size:14px;color:var(--muted);line-height:1.6;}

/* ---------- KOSTEN ---------- */
#kosten{background:var(--warm);}
.kosten-grid{display:grid;grid-template-columns:1fr 1fr;gap:34px;align-items:start;margin-top:42px;}
.kosten-intro{font-size:16px;color:var(--muted);line-height:1.82;margin-bottom:22px;}
.kosten-intro strong{color:var(--g700);}
.beitrag-box{background:var(--paper);border:1.5px solid var(--g200);border-radius:var(--r);padding:24px 26px;box-shadow:var(--shadow-sm);}
.beitrag-box .k-label{font-size:11px;font-weight:800;color:var(--g600);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:9px;}
.beitrag-box p{font-size:14.5px;color:var(--ink);line-height:1.7;}
.k-link{display:inline-flex;align-items:center;gap:7px;margin-top:16px;background:var(--g600);color:#fff;text-decoration:none;padding:12px 22px;border-radius:30px;font-size:14px;font-weight:800;transition:.25s var(--ease);}
.k-link:hover{background:var(--g700);transform:translateY(-2px);}
.k-stack{display:flex;flex-direction:column;gap:14px;}
.k-card{background:var(--paper);border:1px solid var(--line);border-left:4px solid var(--g400);border-radius:var(--r-sm);padding:18px 22px;transition:transform .3s var(--ease),box-shadow .3s;}
.k-card:hover{transform:translateX(5px);box-shadow:var(--shadow-sm);}
.k-card .k-head{display:flex;align-items:center;gap:10px;margin-bottom:6px;}
.k-card .k-head span{font-size:20px;}
.k-card strong{font-size:15px;color:var(--g800);font-family:var(--display);font-weight:600;}
.k-card p{font-size:13.5px;color:var(--muted);line-height:1.65;}
.k-card p b{color:var(--ink);}

/* ---------- GALERIE ---------- */
#galerie{background:linear-gradient(165deg,var(--g700),var(--g800));color:#fff;position:relative;overflow:hidden;}
#galerie .eyebrow{color:var(--g200);}
#galerie .eyebrow::before{background:var(--g300);}
#galerie h2.h{color:#fff;}
#galerie h2.h em{color:var(--g200);}
.gal-sub{font-size:17px;color:rgba(255,255,255,.82);max-width:54ch;margin-bottom:40px;line-height:1.75;}
.masonry{columns:3;column-gap:16px;}
.masonry .ph{
  break-inside:avoid;margin-bottom:16px;border-radius:var(--r);overflow:hidden;position:relative;cursor:pointer;
  box-shadow:0 14px 36px -16px rgba(0,0,0,.5);transform:translateY(0);transition:transform .4s var(--ease),box-shadow .4s;
}
.masonry .ph img{width:100%;display:block;transition:transform .7s var(--ease),filter .4s;}
.masonry .ph::after{content:'⤢';position:absolute;top:12px;right:12px;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.92);color:var(--g700);display:grid;place-items:center;font-size:16px;opacity:0;transform:scale(.7);transition:.3s var(--ease);}
.masonry .ph:hover{transform:translateY(-6px);box-shadow:0 24px 50px -16px rgba(0,0,0,.6);}
.masonry .ph:hover img{transform:scale(1.07);}
.masonry .ph:hover::after{opacity:1;transform:scale(1);}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:3000;background:rgba(20,30,12,.93);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:.35s;}
.lightbox.open{opacity:1;visibility:visible;}
.lb-img{max-width:88vw;max-height:84vh;border-radius:16px;box-shadow:0 30px 80px rgba(0,0,0,.6);transform:scale(.94);transition:transform .35s var(--ease);}
.lightbox.open .lb-img{transform:scale(1);}
.lb-btn{position:absolute;top:50%;transform:translateY(-50%);width:56px;height:56px;border-radius:50%;border:none;background:rgba(255,255,255,.14);color:#fff;font-size:26px;cursor:pointer;transition:background .25s;display:grid;place-items:center;}
.lb-btn:hover{background:rgba(255,255,255,.28);}
.lb-prev{left:24px;}.lb-next{right:24px;}
.lb-close{position:absolute;top:24px;right:24px;width:48px;height:48px;border-radius:50%;border:none;background:rgba(255,255,255,.14);color:#fff;font-size:24px;cursor:pointer;transition:.25s;}
.lb-close:hover{background:rgba(255,255,255,.3);transform:rotate(90deg);}
.lb-counter{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.85);font-size:14px;font-weight:700;letter-spacing:1px;}

/* ---------- EINGEWÖHNUNG ---------- */
#eingewoehnung{background:var(--cream);}
.ew-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:46px;counter-reset:step;}
.ew-step{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:30px 24px;position:relative;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease);
}
.ew-step:hover{transform:translateY(-6px);box-shadow:var(--shadow);}
.ew-num{width:50px;height:50px;border-radius:50%;background:var(--g600);color:#fff;font-family:var(--display);font-size:24px;font-weight:600;display:grid;place-items:center;margin-bottom:16px;box-shadow:0 8px 18px -6px rgba(45,110,28,.6);}
.ew-step h4{font-family:var(--display);font-size:18px;font-weight:600;color:var(--g800);margin-bottom:9px;line-height:1.25;}
.ew-step p{font-size:14px;color:var(--muted);line-height:1.65;}
.ew-step .ew-arrow{position:absolute;top:48px;right:-13px;color:var(--g300);font-size:22px;z-index:2;}
.ew-step:last-child .ew-arrow{display:none;}

/* ---------- KONTAKT ---------- */
#kontakt{background:var(--sand);}
.contact-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:54px;align-items:start;margin-top:42px;}
.contact-intro{font-size:16.5px;color:var(--muted);line-height:1.8;margin-bottom:28px;max-width:46ch;}
.cd-item{display:flex;gap:15px;align-items:flex-start;padding:14px 0;border-bottom:1px solid rgba(40,60,25,.08);}
.cd-item:last-of-type{border-bottom:none;}
.cd-ico{width:46px;height:46px;flex-shrink:0;border-radius:14px;background:var(--g50);display:grid;place-items:center;font-size:21px;}
.cd-label{font-size:11px;font-weight:800;color:var(--faint);text-transform:uppercase;letter-spacing:.8px;margin-bottom:2px;}
.cd-value{font-size:15.5px;color:var(--ink);font-weight:600;line-height:1.45;}
.cd-value a{color:var(--g700);text-decoration:none;font-weight:800;}
.cd-value a:hover{text-decoration:underline;}
.map-note{display:flex;gap:14px;background:var(--g50);border:1px solid var(--g200);border-radius:var(--r);padding:18px 20px;margin-top:18px;}
.map-note .ico{font-size:24px;}
.map-note h4{font-family:var(--display);font-size:16px;font-weight:600;color:var(--g800);margin-bottom:4px;}
.map-note p{font-size:13.5px;color:var(--muted);line-height:1.55;margin-bottom:6px;}
.map-link{font-size:13.5px;font-weight:800;color:var(--g600);text-decoration:none;}
.map-link:hover{text-decoration:underline;}

/* form */
.form-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-xl);padding:36px 36px;box-shadow:var(--shadow);}
.form-card h3{font-family:var(--display);font-size:24px;font-weight:600;color:var(--g800);margin-bottom:6px;}
.form-card .fsub{font-size:14px;color:var(--muted);margin-bottom:22px;}
.contact-form{display:flex;flex-direction:column;gap:16px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.fg{display:flex;flex-direction:column;gap:6px;}
.fg label{font-size:12.5px;font-weight:800;color:var(--g700);letter-spacing:.2px;}
.fg input,.fg select,.fg textarea{
  font-family:var(--body);font-size:15px;color:var(--ink);background:#fff;
  border:1.5px solid var(--g100);border-radius:13px;padding:12px 15px;transition:border-color .2s,box-shadow .2s;
}
.fg input:focus,.fg select:focus,.fg textarea:focus{outline:none;border-color:var(--g400);box-shadow:0 0 0 4px rgba(109,187,82,.16);}
.fg textarea{resize:vertical;min-height:110px;}
.captcha-row{display:flex;align-items:flex-end;gap:14px;background:var(--g50);border:1px solid var(--g100);border-radius:13px;padding:14px 16px;}
.captcha-row .cq{font-family:var(--display);font-size:20px;font-weight:600;color:var(--g700);white-space:nowrap;padding-bottom:8px;}
.captcha-row .fg{flex:1;}
.captcha-row input{max-width:120px;}
.form-msg{font-size:13.5px;font-weight:700;padding:11px 16px;border-radius:12px;display:none;}
.form-msg.ok{background:#eafae6;color:var(--g700);border:1px solid var(--g200);}
.form-msg.err{background:#fde8e8;color:#b3261e;border:1px solid #f3b4b4;}
.form-card .btn-primary{width:100%;justify-content:center;margin-top:4px;}

/* ---------- LEGAL ---------- */
#impressum{background:var(--g800);color:rgba(255,255,255,.85);padding:80px 0;}
.legal-tabs{display:flex;gap:10px;margin-bottom:30px;}
.legal-tab{font-family:var(--body);font-size:14px;font-weight:800;padding:11px 24px;border-radius:30px;border:1.5px solid rgba(255,255,255,.25);background:transparent;color:rgba(255,255,255,.7);cursor:pointer;transition:.25s;}
.legal-tab.active{background:var(--g200);color:var(--g800);border-color:var(--g200);}
.legal-content{display:none;max-width:760px;}
.legal-content.active{display:block;animation:fadeIn .4s var(--ease);}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.legal-content h2{font-family:var(--display);font-size:30px;font-weight:600;color:#fff;margin-bottom:20px;}
.legal-content h3{font-size:15px;font-weight:800;color:var(--g200);margin:20px 0 6px;}
.legal-content p,.legal-content li{font-size:14px;line-height:1.7;color:rgba(255,255,255,.8);}
.legal-content ul{padding-left:20px;margin-top:6px;}
.legal-content a{color:var(--g200);}

/* ---------- FOOTER ---------- */
footer{background:#16400c;color:rgba(255,255,255,.78);padding:54px 0 30px;}
.footer-main{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap;padding-bottom:28px;border-bottom:1px solid rgba(255,255,255,.13);}
.footer-logo{display:flex;align-items:center;gap:11px;font-family:var(--display);font-size:26px;color:#fff;margin-bottom:8px;}
.footer-logo em{font-style:italic;color:var(--g200);}
.footer-logo .mark{width:32px;height:32px;}
.footer-sub{font-size:13.5px;color:rgba(255,255,255,.65);max-width:46ch;line-height:1.6;}
.footer-right{text-align:right;font-size:14px;line-height:1.7;}
.footer-right .fdeco{font-size:22px;margin-top:10px;letter-spacing:4px;}
.footer-legal{display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;padding-top:24px;}
.footer-legal-links{display:flex;gap:22px;flex-wrap:wrap;}
.footer-legal-links a{font-size:13.5px;color:rgba(255,255,255,.72);text-decoration:none;transition:color .2s;}
.footer-legal-links a:hover{color:var(--g200);}
.footer-copy{font-size:12.5px;color:rgba(255,255,255,.5);}

/* ---------- COOKIE ---------- */
#cookieOverlay{position:fixed;inset:0;background:rgba(20,30,12,.4);z-index:4000;display:flex;align-items:flex-end;justify-content:center;padding:20px;backdrop-filter:blur(3px);}
#cookieOverlay.hidden{display:none;}
.cookie-box{background:#fff;border-radius:var(--r-lg);max-width:560px;width:100%;padding:30px 32px 26px;box-shadow:var(--shadow-lg);animation:cookieUp .5s var(--ease);}
@keyframes cookieUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:none}}
.cookie-box h3{font-family:var(--display);font-size:22px;font-weight:600;color:var(--g800);margin-bottom:10px;display:flex;align-items:center;gap:8px;}
.cookie-box>p{font-size:13.5px;color:var(--muted);line-height:1.65;margin-bottom:16px;}
.cookie-box>p a{color:var(--g600);font-weight:800;}
.cookie-zweck{background:var(--g50);border:1px solid var(--g100);border-radius:14px;padding:14px 16px;margin-bottom:18px;}
.cookie-zweck h4{font-size:11px;font-weight:800;color:var(--g700);margin-bottom:8px;text-transform:uppercase;letter-spacing:.6px;}
.ck-row{display:flex;align-items:center;gap:10px;font-size:13.5px;color:var(--muted);padding:4px 0;}
.ck-row .lbl{flex:1;}
.ck-pill{font-size:10px;font-weight:800;padding:4px 11px;border-radius:12px;}
.ck-pill.on{background:var(--g400);color:#fff;}
.ck-pill.off{background:#e2e2e2;color:#888;}
.cookie-btns{display:flex;gap:10px;}
.cookie-btns .btn{flex:1;justify-content:center;padding:13px 18px;}

/* ---------- RESPONSIVE ---------- */
@media (max-width:980px){
  .about-grid{grid-template-columns:1fr;gap:40px;}
  .about-photo{max-width:420px;margin:0 auto;}
  .kosten-grid,.contact-grid{grid-template-columns:1fr;gap:34px;}
  .ew-steps{grid-template-columns:1fr 1fr;}
  .ew-step .ew-arrow{display:none;}
  .extras-grid{grid-template-columns:1fr 1fr;}
  .masonry{columns:2;}
}
@media (max-width:1010px){
  .nav-links{display:none;}
  .nav-toggle{display:flex;}
}
@media (max-width:760px){
  nav,nav.scrolled{padding:14px 22px;}
  .wrap,.section-inner,.hero-inner{padding:0 22px;}
  .section{padding:78px 0;}
  .plaetze-grid{grid-template-columns:1fr;}
  .highlights{grid-template-columns:1fr;}
  .timeline::before,.tl-progress{left:54px;}
  .tl-item{grid-template-columns:48px 32px 1fr;}
  .tl-time{font-size:15px;}
  .footer-main{flex-direction:column;align-items:flex-start;}
  .footer-right{text-align:left;}
  .lb-prev{left:10px;}.lb-next{right:10px;}
  .lb-btn{width:46px;height:46px;}
}
@media (max-width:560px){
  .extras-grid{grid-template-columns:1fr;}
  .ew-steps{grid-template-columns:1fr;}
  .masonry{columns:1;}
  .form-row{grid-template-columns:1fr;}
  .form-card{padding:26px 22px;}
  h2.h{font-size:28px;}
}
