/* ==========================================================================
   Atelier im Hof Kakau – Stylesheet
   Helles, warmes & handwerkliches Design · Gradients · Parallax · Slider
   Alle Assets lokal (DSGVO) · keine externen Requests
   ========================================================================== */

/* ----- Lokale Schriftarten (woff2, self-hosted) ----- */
@font-face{font-family:"Fraunces";src:url("../fonts/fraunces-400.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Fraunces";src:url("../fonts/fraunces-400-italic.woff2") format("woff2");font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:"Fraunces";src:url("../fonts/fraunces-500.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Fraunces";src:url("../fonts/fraunces-600.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Fraunces";src:url("../fonts/fraunces-700.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Fraunces";src:url("../fonts/fraunces-900.woff2") format("woff2");font-weight:900;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url("../fonts/inter-400.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url("../fonts/inter-500.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url("../fonts/inter-600.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url("../fonts/inter-700.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}

/* ----- Design-Tokens ----- */
:root{
  /* Basis / Creme */
  --cream:#FAF6F0;
  --cream-2:#F3ECE2;
  --sand:#EADFCF;
  /* Warme Akzente */
  --terracotta:#C8704F;
  --terracotta-dark:#A9542F;
  --peach:#E9A98A;
  --clay:#D98A6A;
  /* Sage / Grün */
  --sage:#8A9A7B;
  --sage-dark:#6E7E5F;
  --sage-light:#B9C4AB;
  /* Text & Linien */
  --walnut:#3A3330;
  --walnut-soft:#5A514B;
  --gold:#C2A14D;
  --line:#E2D7C7;
  --white:#ffffff;

  /* Gradients */
  --grad-warm:linear-gradient(135deg,var(--terracotta) 0%,var(--peach) 100%);
  --grad-warm-soft:linear-gradient(135deg,#F6D9C6 0%,#EFE6D5 100%);
  --grad-sage:linear-gradient(135deg,var(--sage) 0%,var(--sage-light) 100%);
  --grad-hero:linear-gradient(120deg,rgba(58,51,48,.55) 0%,rgba(168,84,47,.35) 55%,rgba(110,126,95,.30) 100%);
  --grad-text:linear-gradient(120deg,var(--terracotta) 0%,var(--sage-dark) 100%);

  /* Typo */
  --font-display:"Fraunces",Georgia,"Times New Roman",serif;
  --font-body:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;

  /* Maße */
  --container:1200px;
  --container-wide:1400px;
  --radius:18px;
  --radius-lg:28px;
  --radius-pill:999px;
  --shadow-sm:0 4px 14px rgba(58,51,48,.07);
  --shadow:0 14px 40px rgba(58,51,48,.10);
  --shadow-lg:0 30px 70px rgba(58,51,48,.16);
  --header-h:76px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ----- Reset / Base ----- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--font-body);color:var(--walnut);
  background:var(--cream);line-height:1.65;font-size:17px;
  overflow-x:hidden;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none}
ul{margin:0;padding:0;list-style:none}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:1.12;color:var(--walnut);margin:0 0 .5em}
h1{font-size:clamp(2.6rem,6vw,4.8rem);font-weight:700;letter-spacing:-.02em}
h2{font-size:clamp(2rem,4vw,3.2rem);letter-spacing:-.015em}
h3{font-size:clamp(1.3rem,2.4vw,1.8rem)}
p{margin:0 0 1.1em}
:focus-visible{outline:3px solid var(--terracotta);outline-offset:3px;border-radius:6px}

/* ----- Layout ----- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:clamp(20px,5vw,40px)}
.container.wide{max-width:var(--container-wide)}
.section{padding:clamp(70px,9vw,130px) 0}
.section--tint{background:var(--cream-2)}
.section--sand{background:linear-gradient(180deg,var(--cream) 0%,var(--sand) 100%)}
.eyebrow{display:inline-block;font-family:var(--font-body);font-weight:600;font-size:.82rem;
  letter-spacing:.18em;text-transform:uppercase;color:var(--terracotta-dark);margin-bottom:1rem}
.section-head{max-width:680px;margin-bottom:clamp(34px,5vw,60px)}
.section-head.center{margin-inline:auto;text-align:center}
.lead{font-size:1.18rem;color:var(--walnut-soft)}
.text-grad{background:var(--grad-text);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.serif-italic{font-family:var(--font-display);font-style:italic;font-weight:400}

/* ----- Buttons ----- */
.btn{display:inline-flex;align-items:center;gap:.55em;padding:.95em 1.7em;border-radius:var(--radius-pill);
  font-weight:600;font-size:.98rem;line-height:1;transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s;
  min-height:48px}
.btn svg{width:1.1em;height:1.1em}
.btn--primary{background:var(--grad-warm);color:#fff;box-shadow:0 10px 24px rgba(168,84,47,.30)}
.btn--primary:hover{transform:translateY(-3px);box-shadow:0 16px 34px rgba(168,84,47,.40)}
.btn--ghost{background:rgba(255,255,255,.14);color:#fff;border:1.5px solid rgba(255,255,255,.6);backdrop-filter:blur(4px)}
.btn--ghost:hover{background:rgba(255,255,255,.26);transform:translateY(-3px)}
.btn--dark{background:var(--walnut);color:var(--cream)}
.btn--dark:hover{background:#2b2522;transform:translateY(-3px)}
.btn--outline{border:1.5px solid var(--line);background:#fff;color:var(--walnut)}
.btn--outline:hover{border-color:var(--terracotta);color:var(--terracotta-dark);transform:translateY(-3px)}

/* ==========================================================================
   Header / Navigation
   ========================================================================== */
.site-header{position:fixed;inset:0 0 auto 0;z-index:1000;height:var(--header-h);
  display:flex;align-items:center;transition:background .35s,box-shadow .35s,backdrop-filter .35s}
.site-header.is-scrolled{background:rgba(250,246,240,.92);backdrop-filter:blur(10px);box-shadow:var(--shadow-sm)}
.nav{display:flex;align-items:center;justify-content:space-between;width:100%}
.brand{display:flex;align-items:center;gap:.65rem;font-family:var(--font-display);font-weight:700;
  font-size:1.25rem;letter-spacing:-.01em;color:#fff;transition:color .35s}
.is-scrolled .brand,.page-light .brand{color:var(--walnut)}
.brand .mark{width:40px;height:40px;border-radius:12px;background:var(--grad-warm);display:grid;place-items:center;
  color:#fff;font-weight:900;flex:none;box-shadow:0 6px 16px rgba(168,84,47,.35)}
.brand small{display:block;font-family:var(--font-body);font-weight:500;font-size:.62rem;letter-spacing:.22em;
  text-transform:uppercase;opacity:.8;margin-top:2px}
.nav-links{display:flex;align-items:center;gap:.35rem}
.nav-links.mobile{display:none} /* nur im mobilen Breakpoint sichtbar */
.nav-links a{position:relative;padding:.55rem .85rem;border-radius:10px;font-weight:500;font-size:.97rem;
  color:rgba(255,255,255,.92);transition:color .3s,background .3s}
.is-scrolled .nav-links a,.page-light .nav-links a{color:var(--walnut-soft)}
.nav-links a::after{content:"";position:absolute;left:.85rem;right:.85rem;bottom:.3rem;height:2px;
  background:var(--terracotta);border-radius:2px;transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
.is-scrolled .nav-links a:hover,.page-light .nav-links a:hover{color:var(--walnut)}
.nav-actions{display:flex;align-items:center;gap:.7rem}
.nav-cta{padding:.7em 1.25em}
.nav-toggle{display:none;width:46px;height:46px;border-radius:12px;align-items:center;justify-content:center}
.nav-toggle span{position:relative;width:22px;height:2px;background:currentColor;color:#fff;transition:background .2s}
.is-scrolled .nav-toggle span,.page-light .nav-toggle span{color:var(--walnut)}
.nav-toggle span::before,.nav-toggle span::after{content:"";position:absolute;left:0;width:22px;height:2px;background:currentColor;transition:transform .3s var(--ease),top .3s}
.nav-toggle span::before{top:-7px}.nav-toggle span::after{top:7px}
body.nav-open .nav-toggle span{background:transparent}
body.nav-open .nav-toggle span::before{top:0;transform:rotate(45deg)}
body.nav-open .nav-toggle span::after{top:0;transform:rotate(-45deg)}

/* ==========================================================================
   Hero + Slider
   ========================================================================== */
.hero{position:relative;min-height:100vh;min-height:100dvh;display:flex;align-items:center;overflow:hidden}
.slider{position:absolute;inset:0;z-index:0}
.slide{position:absolute;inset:0;opacity:0;transition:opacity 1.1s var(--ease);will-change:opacity}
.slide.is-active{opacity:1}
.slide__bg{position:absolute;inset:-8% 0;background-size:cover;background-position:center;
  transform:scale(1.08);transition:transform 6.5s linear;will-change:transform}
.slide.is-active .slide__bg{transform:scale(1.16)} /* langsamer Ken-Burns-Zoom */
.slide::after{content:"";position:absolute;inset:0;background:var(--grad-hero)}
.hero__inner{position:relative;z-index:2;color:#fff;max-width:760px;padding-top:var(--header-h)}
.hero__inner .eyebrow{color:#F6D9C6}
.hero h1{color:#fff;text-shadow:0 2px 30px rgba(0,0,0,.25)}
.hero p{font-size:1.22rem;color:rgba(255,255,255,.92);max-width:54ch}
.hero__cta{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2rem}
/* Slider-Controls */
.slider-dots{position:absolute;left:0;right:0;bottom:38px;z-index:3;display:flex;gap:.6rem;justify-content:center}
.slider-dots button{width:11px;height:11px;border-radius:50%;background:rgba(255,255,255,.45);transition:all .3s}
.slider-dots button[aria-current="true"]{background:#fff;width:34px;border-radius:6px}
.slider-arrow{position:absolute;top:50%;z-index:3;transform:translateY(-50%);width:54px;height:54px;border-radius:50%;
  background:rgba(255,255,255,.16);border:1.5px solid rgba(255,255,255,.45);color:#fff;display:grid;place-items:center;
  backdrop-filter:blur(4px);transition:background .3s,transform .3s}
.slider-arrow:hover{background:rgba(255,255,255,.32)}
.slider-arrow.prev{left:clamp(12px,3vw,34px)}.slider-arrow.next{right:clamp(12px,3vw,34px)}
.slider-arrow svg{width:22px;height:22px}
.scroll-cue{position:absolute;left:50%;bottom:84px;z-index:3;transform:translateX(-50%);color:rgba(255,255,255,.8);
  font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:.5rem}
.scroll-cue::after{content:"";width:1px;height:42px;background:linear-gradient(rgba(255,255,255,.8),transparent);animation:cue 2s var(--ease) infinite}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* Page-Hero (Unterseiten) */
.page-hero{position:relative;padding:calc(var(--header-h) + 70px) 0 70px;background:var(--grad-warm-soft);overflow:hidden}
.page-hero::before{content:"";position:absolute;right:-120px;top:-120px;width:380px;height:380px;border-radius:50%;
  background:var(--grad-sage);opacity:.35;filter:blur(20px)}
.page-hero__inner{position:relative;z-index:1;max-width:720px}
.breadcrumb{font-size:.85rem;color:var(--walnut-soft);margin-bottom:1rem}
.breadcrumb a:hover{color:var(--terracotta-dark)}

/* ==========================================================================
   Intro / Split
   ========================================================================== */
.split{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(32px,5vw,72px);align-items:center}
.split.reverse .split__media{order:2}
.split__media{position:relative}
.split__media img{border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;object-fit:cover}
.split__media .badge{position:absolute;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);
  padding:1rem 1.3rem;display:flex;gap:.8rem;align-items:center}
.split__media .badge.tl{top:-22px;left:-22px}
.split__media .badge.br{bottom:-22px;right:-22px}
.badge .num{font-family:var(--font-display);font-weight:700;font-size:1.7rem;color:var(--terracotta)}
.badge small{color:var(--walnut-soft);font-size:.82rem;line-height:1.3}

/* Stats */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2rem}
.stat .num{font-family:var(--font-display);font-weight:700;font-size:clamp(2rem,4vw,2.8rem);line-height:1;
  background:var(--grad-text);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.stat small{display:block;color:var(--walnut-soft);font-size:.9rem;margin-top:.4rem}

/* ==========================================================================
   Cards / Leistungen
   ========================================================================== */
.grid{display:grid;gap:clamp(20px,2.5vw,32px)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{background:#fff;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);
  transition:transform .4s var(--ease),box-shadow .4s var(--ease);border:1px solid var(--line)}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.card__media{position:relative;aspect-ratio:4/3;overflow:hidden}
.card__media img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.card:hover .card__media img{transform:scale(1.07)}
.card__tag{position:absolute;top:14px;left:14px;background:rgba(255,255,255,.92);color:var(--terracotta-dark);
  font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:.4em .8em;border-radius:var(--radius-pill)}
.card__body{padding:1.5rem 1.6rem 1.8rem}
.card__body p{color:var(--walnut-soft);font-size:.98rem;margin-bottom:0}
.card .icon-badge{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;margin-bottom:1rem;color:#fff}
.icon-badge.warm{background:var(--grad-warm)}.icon-badge.sage{background:var(--grad-sage)}
.icon-badge.gold{background:linear-gradient(135deg,var(--gold),#E4CC86)}
.icon-badge svg{width:26px;height:26px}
.card-link{display:inline-flex;align-items:center;gap:.4em;margin-top:1rem;font-weight:600;color:var(--terracotta-dark)}
.card-link svg{width:1.1em;height:1.1em;transition:transform .3s}
.card-link:hover svg{transform:translateX(4px)}

/* Process steps */
.steps{counter-reset:step;display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(18px,2.5vw,30px)}
.step{position:relative;padding:2rem 1.4rem 1.6rem;background:#fff;border-radius:var(--radius-lg);border:1px solid var(--line)}
.step::before{counter-increment:step;content:counter(step,decimal-leading-zero);font-family:var(--font-display);
  font-weight:700;font-size:1.5rem;color:#fff;background:var(--grad-warm);width:48px;height:48px;border-radius:50%;
  display:grid;place-items:center;margin-bottom:1rem;box-shadow:0 8px 18px rgba(168,84,47,.3)}
.step h3{font-size:1.15rem;margin-bottom:.4rem}
.step p{font-size:.94rem;color:var(--walnut-soft);margin:0}

/* ==========================================================================
   Galerie / Masonry + Lightbox
   ========================================================================== */
.filter-bar{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;margin-bottom:clamp(28px,4vw,48px)}
.filter-bar button{padding:.55em 1.15em;border-radius:var(--radius-pill);background:#fff;border:1px solid var(--line);
  font-weight:500;font-size:.92rem;color:var(--walnut-soft);transition:all .25s}
.filter-bar button:hover{border-color:var(--terracotta)}
.filter-bar button.active{background:var(--grad-warm);color:#fff;border-color:transparent}
.masonry{columns:3;column-gap:clamp(16px,2vw,24px)}
.masonry .tile{break-inside:avoid;margin-bottom:clamp(16px,2vw,24px);border-radius:var(--radius);overflow:hidden;
  position:relative;cursor:zoom-in;box-shadow:var(--shadow-sm)}
.masonry .tile img{width:100%;transition:transform .6s var(--ease)}
.masonry .tile:hover img{transform:scale(1.05)}
.masonry .tile figcaption{position:absolute;inset:auto 0 0 0;padding:1.2rem 1rem .9rem;color:#fff;
  background:linear-gradient(transparent,rgba(58,51,48,.8));font-family:var(--font-display);font-size:1.05rem;
  opacity:0;transform:translateY(8px);transition:all .35s}
.masonry .tile:hover figcaption{opacity:1;transform:none}
.tile.is-hidden{display:none}

.lightbox{position:fixed;inset:0;z-index:2000;background:rgba(34,29,26,.92);display:none;align-items:center;
  justify-content:center;padding:5vw;backdrop-filter:blur(6px)}
.lightbox.open{display:flex}
.lightbox img{max-width:90vw;max-height:84vh;border-radius:12px;box-shadow:var(--shadow-lg)}
.lightbox__close,.lightbox__nav{position:absolute;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.4);
  color:#fff;width:52px;height:52px;border-radius:50%;display:grid;place-items:center;transition:background .25s}
.lightbox__close:hover,.lightbox__nav:hover{background:rgba(255,255,255,.3)}
.lightbox__close{top:24px;right:24px}
.lightbox__nav.prev{left:24px;top:50%;transform:translateY(-50%)}
.lightbox__nav.next{right:24px;top:50%;transform:translateY(-50%)}
.lightbox__nav svg,.lightbox__close svg{width:24px;height:24px}
.lightbox__cap{position:absolute;bottom:24px;left:0;right:0;text-align:center;color:rgba(255,255,255,.85);font-size:.95rem}

/* ==========================================================================
   Vorher / Nachher Slider
   ========================================================================== */
.ba{position:relative;width:100%;aspect-ratio:4/3;border-radius:var(--radius-lg);overflow:hidden;
  user-select:none;box-shadow:var(--shadow);touch-action:none}
.ba img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none}
.ba .after{clip-path:inset(0 0 0 50%)}
.ba__label{position:absolute;top:14px;padding:.35em .85em;border-radius:var(--radius-pill);font-size:.74rem;
  font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#fff;backdrop-filter:blur(3px)}
.ba__label.before{left:14px;background:rgba(58,51,48,.6)}
.ba__label.after{right:14px;background:var(--terracotta)}
.ba__handle{position:absolute;top:0;bottom:0;left:50%;width:3px;background:#fff;transform:translateX(-50%);cursor:ew-resize}
.ba__handle::before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:48px;height:48px;
  border-radius:50%;background:#fff;box-shadow:var(--shadow)}
.ba__handle svg{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:26px;height:26px;color:var(--terracotta);z-index:2}

/* ==========================================================================
   Journal / Blog
   ========================================================================== */
.post-card{display:flex;flex-direction:column;background:#fff;border-radius:var(--radius-lg);overflow:hidden;
  border:1px solid var(--line);box-shadow:var(--shadow-sm);transition:transform .4s var(--ease),box-shadow .4s}
.post-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.post-card__media{aspect-ratio:3/2;overflow:hidden}
.post-card__media img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.post-card:hover img{transform:scale(1.06)}
.post-card__body{padding:1.5rem 1.6rem 1.8rem;flex:1;display:flex;flex-direction:column}
.post-meta{font-size:.8rem;letter-spacing:.05em;text-transform:uppercase;color:var(--terracotta-dark);font-weight:600;margin-bottom:.6rem}
.post-card h3{font-size:1.3rem;margin-bottom:.5rem}
.post-card p{font-size:.96rem;color:var(--walnut-soft);flex:1}

/* ==========================================================================
   CTA / Instagram
   ========================================================================== */
.cta-band{position:relative;border-radius:var(--radius-lg);padding:clamp(40px,6vw,80px);overflow:hidden;
  background:var(--grad-warm);color:#fff;text-align:center}
.cta-band::before,.cta-band::after{content:"";position:absolute;border-radius:50%;background:rgba(255,255,255,.12)}
.cta-band::before{width:280px;height:280px;top:-100px;left:-60px}
.cta-band::after{width:220px;height:220px;bottom:-90px;right:-40px}
.cta-band h2{color:#fff;position:relative}
.cta-band p{color:rgba(255,255,255,.9);position:relative;max-width:56ch;margin-inline:auto}
.cta-band .btn{position:relative;margin-top:1rem}

.insta-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.insta-grid a{position:relative;aspect-ratio:1;border-radius:var(--radius);overflow:hidden}
.insta-grid img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.insta-grid a:hover img{transform:scale(1.08)}
.insta-grid a::after{content:"";position:absolute;inset:0;background:var(--grad-warm);opacity:0;transition:opacity .35s;
  display:grid;place-items:center}
.insta-grid a:hover::after{opacity:.85}
.insta-grid .ig-ico{position:absolute;inset:0;display:grid;place-items:center;color:#fff;opacity:0;transition:opacity .35s;z-index:2}
.insta-grid a:hover .ig-ico{opacity:1}
.insta-grid .ig-ico svg{width:30px;height:30px}
/* Consent-Platzhalter für externe Inhalte */
.consent-box{border:1.5px dashed var(--line);border-radius:var(--radius-lg);padding:clamp(28px,5vw,48px);text-align:center;background:var(--cream-2)}
.consent-box svg{width:40px;height:40px;color:var(--terracotta);margin-bottom:.5rem}
.consent-box p{max-width:48ch;margin-inline:auto;color:var(--walnut-soft)}

/* ==========================================================================
   Forms (Kontakt)
   ========================================================================== */
.form{display:grid;gap:1.1rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.field{display:flex;flex-direction:column;gap:.4rem}
.field label{font-weight:600;font-size:.9rem}
.field .req{color:var(--terracotta)}
.field input,.field textarea,.field select{font-family:inherit;font-size:1rem;padding:.85em 1em;border-radius:14px;
  border:1.5px solid var(--line);background:#fff;color:var(--walnut);transition:border-color .25s,box-shadow .25s}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--terracotta);
  box-shadow:0 0 0 3px rgba(200,112,79,.16)}
.field textarea{resize:vertical;min-height:140px}
.field .hint{font-size:.82rem;color:var(--walnut-soft)}
.check{display:flex;gap:.6rem;align-items:flex-start;font-size:.9rem;color:var(--walnut-soft)}
.check input{margin-top:.2rem;width:18px;height:18px;accent-color:var(--terracotta)}
.info-list{display:grid;gap:1.3rem}
.info-list li{display:flex;gap:1rem;align-items:flex-start}
.info-list .ico{width:46px;height:46px;border-radius:12px;background:var(--cream-2);display:grid;place-items:center;color:var(--terracotta);flex:none}
.info-list .ico svg{width:22px;height:22px}
.info-list strong{display:block;font-family:var(--font-display);font-size:1.05rem}
.info-list span{color:var(--walnut-soft);font-size:.95rem}
.map-placeholder{aspect-ratio:16/10;border-radius:var(--radius-lg);background:var(--grad-sage);display:grid;place-items:center;
  color:#fff;text-align:center;padding:2rem;box-shadow:var(--shadow-sm)}

/* ==========================================================================
   Legal / Prose
   ========================================================================== */
.prose{max-width:760px}
.prose h2{font-size:1.7rem;margin-top:2.4rem}
.prose h3{font-size:1.2rem;margin-top:1.6rem}
.prose p,.prose li{color:var(--walnut-soft)}
.prose ul{list-style:disc;padding-left:1.3rem;margin-bottom:1.1em}
.prose li{margin-bottom:.4em}
.prose a{color:var(--terracotta-dark);text-decoration:underline}
.placeholder-note{background:#FCF3D9;border:1px solid var(--gold);border-radius:12px;padding:1rem 1.2rem;
  font-size:.92rem;color:#7a6526;margin:1.4rem 0}
.placeholder-note strong{color:#5e4d1a}
mark.ph{background:#FBE6CE;color:#8a5a2c;padding:.05em .35em;border-radius:5px;font-weight:600}

/* ==========================================================================
   Footer
   ========================================================================== */
.site-footer{background:var(--walnut);color:rgba(250,246,240,.82);padding:clamp(56px,7vw,90px) 0 0}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:clamp(28px,4vw,52px)}
.site-footer .brand{color:#fff;margin-bottom:1rem}
.site-footer h4{color:#fff;font-family:var(--font-body);font-weight:600;font-size:.85rem;letter-spacing:.14em;
  text-transform:uppercase;margin-bottom:1.1rem}
.site-footer a{color:rgba(250,246,240,.78);transition:color .25s;display:inline-block;padding:.2rem 0}
.site-footer a:hover{color:var(--peach)}
.footer-about p{color:rgba(250,246,240,.7);font-size:.95rem;max-width:34ch}
.social-row{display:flex;gap:.7rem;margin-top:1.2rem}
.social-row a{width:42px;height:42px;border-radius:12px;background:rgba(255,255,255,.08);display:grid;place-items:center}
.social-row a:hover{background:var(--terracotta)}
.social-row svg{width:20px;height:20px}
.footer-bottom{margin-top:clamp(40px,5vw,64px);border-top:1px solid rgba(255,255,255,.12);padding:1.6rem 0;
  display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;font-size:.85rem;color:rgba(250,246,240,.6)}
.footer-bottom a{font-size:.85rem}

/* ==========================================================================
   Cookie Banner
   ========================================================================== */
.cookie{position:fixed;left:50%;bottom:24px;transform:translateX(-50%) translateY(140%);z-index:1500;
  width:min(620px,calc(100% - 32px));background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);
  padding:1.6rem 1.8rem;border:1px solid var(--line);transition:transform .5s var(--ease)}
.cookie.show{transform:translateX(-50%) translateY(0)}
.cookie h3{font-size:1.2rem;margin-bottom:.4rem}
.cookie p{font-size:.92rem;color:var(--walnut-soft);margin-bottom:1rem}
.cookie p a{color:var(--terracotta-dark);text-decoration:underline}
.cookie__actions{display:flex;flex-wrap:wrap;gap:.7rem}
.cookie__actions .btn{flex:1;justify-content:center;min-width:140px}

/* Back to top */
.to-top{position:fixed;right:22px;bottom:22px;z-index:1400;width:50px;height:50px;border-radius:50%;
  background:var(--walnut);color:#fff;display:grid;place-items:center;box-shadow:var(--shadow);
  opacity:0;pointer-events:none;transform:translateY(12px);transition:all .35s var(--ease)}
.to-top.show{opacity:1;pointer-events:auto;transform:none}
.to-top svg{width:22px;height:22px}

/* ==========================================================================
   Scroll-Reveal + Parallax
   ========================================================================== */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}
[data-parallax]{will-change:transform}
/* dekorative Gradient-Blobs */
.blob{position:absolute;border-radius:50%;filter:blur(40px);opacity:.5;z-index:0;pointer-events:none}
.blob.warm{background:var(--grad-warm)}.blob.sage{background:var(--grad-sage)}
.rel{position:relative;z-index:1}

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (max-width:1024px){
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .masonry{columns:2}
  .footer-grid{grid-template-columns:1fr 1fr}
  .insta-grid{grid-template-columns:repeat(4,1fr)}
  /* Navigation in Burger-Menü zusammenklappen */
  .nav-links:not(.mobile),.nav-cta{display:none}
  .nav-toggle{display:flex}
  .nav-links.mobile{display:flex;position:fixed;inset:var(--header-h) 0 0 0;flex-direction:column;align-items:stretch;
    background:var(--cream);padding:1.5rem clamp(20px,5vw,40px);gap:.2rem;transform:translateX(100%);
    transition:transform .4s var(--ease);box-shadow:var(--shadow-lg);overflow-y:auto}
  body.nav-open .nav-links.mobile{transform:none}
  .nav-links.mobile a{color:var(--walnut)!important;font-family:var(--font-display);font-size:1.4rem;padding:.7rem 0;
    border-bottom:1px solid var(--line)}
  .nav-links.mobile a::after{display:none}
  .nav-links.mobile .btn{margin-top:1.2rem;justify-content:center}
}
@media (max-width:760px){
  body{font-size:16px}
  .split{grid-template-columns:1fr}
  .split.reverse .split__media{order:0}
  .split__media .badge.tl{left:12px}.split__media .badge.br{right:12px}
  .grid-3,.grid-2{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .masonry{columns:1}
  .stats{grid-template-columns:repeat(3,1fr);gap:.8rem}
  .form-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .insta-grid{grid-template-columns:repeat(3,1fr)}
  .slider-arrow{display:none}
  .footer-bottom{flex-direction:column;align-items:flex-start}
}

/* Reduced Motion */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important}
  .slide__bg{transform:none!important}
  .reveal{opacity:1;transform:none}
  [data-parallax]{transform:none!important}
}

/* ==========================================================================
   Effekt: Tilted Card-Stack („Im Rampenlicht")
   ========================================================================== */
.showcase{position:relative;overflow:hidden}
.showcase__grid{position:absolute;inset:0;z-index:0;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(to right,var(--line) 1px,transparent 1px);
  background-size:3rem 3rem;opacity:.7}
.showcase__fade{position:absolute;inset:0;z-index:0;
  background:linear-gradient(180deg,var(--cream) 0%,rgba(250,246,240,0) 22%,rgba(250,246,240,0) 78%,var(--cream) 100%)}
.showcase > .container{position:relative;z-index:1}
.card-stack{position:relative;min-height:440px;display:flex;align-items:center;justify-content:center}
.card-stack img{position:absolute;width:min(74%,320px);aspect-ratio:3/4;object-fit:cover;border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);transition:transform .45s var(--ease);background:#fff}
.card-stack .card-back{transform:rotate(-6deg) translateX(24%)}
.card-stack .card-front{transform:rotate(6deg) translateX(-16%)}
.card-stack .card-back:hover{transform:rotate(-4deg) translateX(24%) translateY(-12px);z-index:3}
.card-stack .card-front:hover{transform:rotate(4deg) translateX(-16%) translateY(-12px);z-index:3}
.card-stack__tag{position:absolute;z-index:4;bottom:8%;left:50%;transform:translateX(-50%);
  background:#fff;border-radius:var(--radius-pill);padding:.5em 1.1em;box-shadow:var(--shadow);
  font-weight:600;font-size:.85rem;color:var(--terracotta-dark);white-space:nowrap}

/* ==========================================================================
   Effekt: Scroll-Expand-Media (sticky-basiert)
   ========================================================================== */
.scroll-expand{position:relative}
.scroll-expand__track{height:260vh;position:relative}
.scroll-expand__sticky{position:sticky;top:0;height:100vh;height:100dvh;display:flex;align-items:center;justify-content:center;overflow:hidden}
.scroll-expand__bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:calc(1 - var(--p,0))}
.scroll-expand__bg::after{content:"";position:absolute;inset:0;background:rgba(58,51,48,.25)}
.scroll-expand__media{position:relative;z-index:2;border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,.4);width:var(--w,320px);height:var(--h,420px);max-width:95vw;max-height:85vh}
.scroll-expand__media img{width:100%;height:100%;object-fit:cover}
.scroll-expand__media::after{content:"";position:absolute;inset:0;background:#3A3330;opacity:calc(.5 - var(--p,0)*.4)}
.scroll-expand__title{position:absolute;z-index:3;top:50%;left:0;transform:translateY(-50%);
  display:flex;gap:.35em;flex-wrap:wrap;justify-content:center;width:100%;
  text-align:center;color:#fff;font-family:var(--font-display);font-weight:700;letter-spacing:-.01em;
  text-shadow:0 2px 24px rgba(0,0,0,.45);pointer-events:none;font-size:clamp(2rem,6vw,4.6rem);line-height:1.05}
.scroll-expand__title .w1{transform:translateX(calc(var(--p,0) * -22vw))}
.scroll-expand__title .w2{transform:translateX(calc(var(--p,0) * 22vw))}
.scroll-expand__title.blend{mix-blend-mode:difference;color:#fff}
.scroll-expand__hint{position:absolute;z-index:3;bottom:7%;color:#fff;letter-spacing:.22em;text-transform:uppercase;
  font-size:.72rem;opacity:calc(1 - var(--p,0) * 1.6);display:flex;flex-direction:column;align-items:center;gap:.5rem}
.scroll-expand__hint svg{width:20px;height:20px;animation:cue 2s var(--ease) infinite}
.scroll-expand__content{position:relative;z-index:2;background:var(--cream)}
.scroll-expand__content .inner{max-width:760px;margin-inline:auto;padding:clamp(44px,7vw,90px) clamp(20px,5vw,40px);
  text-align:center;opacity:var(--show,0);transform:translateY(calc((1 - var(--show,0)) * 24px));transition:opacity .6s var(--ease),transform .6s var(--ease)}
/* Reduced-Motion / Fallback: nicht-pinnende, normale Sektion */
.scroll-expand.is-static .scroll-expand__track{height:auto}
.scroll-expand.is-static .scroll-expand__sticky{position:relative;height:auto;padding:clamp(48px,9vw,110px) 0}
.scroll-expand.is-static .scroll-expand__content .inner{opacity:1;transform:none}

@media (max-width:760px){
  .card-stack img{width:min(64%,230px)}
  .card-stack .card-back{transform:rotate(-6deg) translateX(30%)}
  .card-stack .card-front{transform:rotate(6deg) translateX(-22%)}
}

/* ==========================================================================
   Text-Build-Animation (Wort für Wort beim Scrollen)
   ========================================================================== */
.build .bw{display:inline-block;opacity:0;transform:translateY(.6em) rotate(1.5deg);
  transition:opacity .6s var(--ease),transform .6s var(--ease);will-change:transform,opacity}
.build.in .bw{opacity:1;transform:none}

/* ==========================================================================
   Lebendiger Hintergrund – weiche Farbverläufe & Blooms
   ========================================================================== */
body{
  background:
    radial-gradient(58vw 48vh at 88% -5%, rgba(233,169,138,.20), transparent 62%),
    radial-gradient(52vw 46vh at -8% 32%, rgba(138,154,123,.16), transparent 60%),
    radial-gradient(48vw 50vh at 108% 70%, rgba(194,161,77,.13), transparent 60%),
    radial-gradient(46vw 42vh at 20% 104%, rgba(217,138,106,.14), transparent 60%),
    linear-gradient(180deg,#FBF7F2 0%,#F4ECE0 100%);
  background-attachment:fixed;
}
/* Sektions-Tints als sanfte Verläufe (warm <-> salbei für Rhythmus) */
.section--tint{background:linear-gradient(155deg,#FBEDE3 0%,#F6E6D7 55%,#F1E9DC 100%)}
.section--sand{background:linear-gradient(160deg,#EFF1E9 0%,#F5EFE4 60%,#F3E7D7 100%)}
.section--plain{background:transparent} /* zeigt die Body-Blooms */

/* Optionaler weicher Glow in beliebiger Sektion */
.section--glow{position:relative;isolation:isolate}
.section--glow::before{content:"";position:absolute;z-index:-1;width:46vw;height:46vw;max-width:560px;max-height:560px;
  top:-10%;right:-8%;border-radius:50%;background:var(--grad-warm);opacity:.14;filter:blur(60px)}
.section--glow::after{content:"";position:absolute;z-index:-1;width:40vw;height:40vw;max-width:480px;max-height:480px;
  bottom:-12%;left:-10%;border-radius:50%;background:var(--grad-sage);opacity:.16;filter:blur(60px)}

/* ==========================================================================
   Lebendigere Karten & Kacheln
   ========================================================================== */
.card{background:linear-gradient(180deg,#ffffff 0%,#FBF5EE 100%);position:relative;isolation:isolate}
.card::before{content:"";position:absolute;inset:0 0 auto 0;height:4px;z-index:2;background:var(--grad-warm);
  opacity:0;transform:scaleX(.4);transform-origin:left;transition:opacity .4s var(--ease),transform .45s var(--ease)}
.card:hover::before{opacity:1;transform:scaleX(1)}
.card:hover{box-shadow:0 26px 60px rgba(168,84,47,.20)}
.icon-badge{box-shadow:0 10px 22px rgba(58,51,48,.12)}

/* Karten mit abwechselnden Akzentfarben (nth-child) */
.grid-3 .card:nth-child(3n+2)::before{background:var(--grad-sage)}
.grid-3 .card:nth-child(3n)::before{background:linear-gradient(135deg,var(--gold),#E4CC86)}

.post-card{background:linear-gradient(180deg,#ffffff 0%,#FBF5EE 100%)}
.post-card:hover{box-shadow:0 26px 60px rgba(168,84,47,.18)}

.step{background:linear-gradient(180deg,#ffffff 0%,#FAF3EA 100%);transition:transform .35s var(--ease),box-shadow .35s var(--ease)}
.step:hover{transform:translateY(-6px);box-shadow:var(--shadow)}

/* Galerie-Kacheln: sanfter Farbschleier beim Hover */
.masonry .tile::before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(150deg,rgba(200,112,79,0),rgba(138,154,123,0));transition:background .4s var(--ease)}
.masonry .tile:hover::before{background:linear-gradient(150deg,rgba(200,112,79,.22),rgba(138,154,123,.12))}
.masonry .tile{box-shadow:0 6px 18px rgba(58,51,48,.08);transition:box-shadow .4s var(--ease)}
.masonry .tile:hover{box-shadow:0 18px 44px rgba(168,84,47,.18)}
.masonry .tile figcaption{z-index:2}

@media (max-width:760px){
  body{background-attachment:scroll}
}
@media (prefers-reduced-motion:reduce){
  .build .bw{opacity:1;transform:none}
  body{background-attachment:scroll}
}

/* ==========================================================================
   Palette: von Beige -> Weiß & dezentes Grau (Override)
   Warme Töne bleiben nur als Akzent (Buttons, Icons, Verläufe der CTA).
   ========================================================================== */
:root{
  --cream:#FCFCFD;     /* Basis nahezu weiß */
  --cream-2:#F4F5F7;   /* sehr helles Grau */
  --sand:#ECEEF1;      /* helles Grau */
  --line:#E7E9ED;      /* graue Linien/Border */
  --walnut:#2B2E35;    /* neutrales Anthrazit (Text) */
  --walnut-soft:#5C636D;
}
body{
  background:
    radial-gradient(60vw 50vh at 86% -5%, rgba(120,128,140,.06), transparent 60%),
    radial-gradient(55vw 46vh at -6% 34%, rgba(120,128,140,.05), transparent 60%),
    radial-gradient(48vw 48vh at 106% 78%, rgba(120,128,140,.05), transparent 60%),
    linear-gradient(180deg,#FFFFFF 0%,#F4F5F7 100%);
  background-attachment:fixed;
}
.section--tint{background:linear-gradient(180deg,#FFFFFF 0%,#F3F4F6 100%)}
.section--sand{background:linear-gradient(180deg,#F6F7F9 0%,#ECEEF1 100%)}
.page-hero{background:linear-gradient(180deg,#F5F6F8 0%,#FFFFFF 100%)}
.page-hero::before{background:radial-gradient(circle,rgba(120,128,140,.12),transparent 62%);opacity:.7}
.card,.post-card{background:linear-gradient(180deg,#FFFFFF 0%,#F7F8FA 100%)}
.step{background:linear-gradient(180deg,#FFFFFF 0%,#F6F7F9 100%)}
.showcase__fade{background:linear-gradient(180deg,#FFFFFF 0%,rgba(255,255,255,0) 22%,rgba(255,255,255,0) 78%,#FFFFFF 100%)}
.card:hover{box-shadow:0 26px 60px rgba(43,46,53,.16)}
.post-card:hover{box-shadow:0 26px 60px rgba(43,46,53,.14)}
.masonry .tile:hover{box-shadow:0 18px 44px rgba(43,46,53,.16)}

/* ==========================================================================
   Effekt: Scroll-Text – Wörter leuchten beim NORMALEN Scrollen auf
   (nicht fixiert – die Seite läuft durch, wie auf dev.lu4events.de)
   ========================================================================== */
.scroll-text{text-align:center;padding-block:clamp(80px,15vh,190px)}
.scroll-text .eyebrow{margin-bottom:1.4rem}
.scroll-text__copy{max-width:1000px;margin:0 auto;font-family:var(--font-display);font-weight:600;
  letter-spacing:-.01em;line-height:1.32;font-size:clamp(1.7rem,4.2vw,3.3rem)}
.scroll-text__copy .w{color:var(--walnut);opacity:.14;transition:opacity .14s linear}
.scroll-text__copy .accent{color:var(--terracotta-dark)}

/* ==========================================================================
   Bild-Effekt: sanftes Aufblenden + Wipe beim Scrollen ins Bild
   (clip-path & opacity – kollidiert NICHT mit dem Hover-Zoom = transform)
   ========================================================================== */
.io-img{clip-path:inset(14% 0% 14% 0%);opacity:0;
  transition:clip-path .9s var(--ease),opacity .7s var(--ease),transform .7s var(--ease)}
.io-img.in{clip-path:inset(0% 0% 0% 0%);opacity:1}

@media (max-width:760px){
  body{background-attachment:scroll}
}
@media (prefers-reduced-motion:reduce){
  body{background-attachment:scroll}
  .scroll-text__copy .w{opacity:1}
}
