/* ===== KÜX — REFINED DESIGN SYSTEM ===== */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,400;1,500&display=swap');
@import url('https://fonts.cdnfonts.com/css/gilgan');

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --white:#ffffff;
  --offwhite:#f5f5f5;
  --cream:#ececec;
  --sand:#d6d6d6;

  --olive:#1a1a1a;
  --olive-dark:#111111;
  --olive-light:#444444;

  --text:#111111;
  --text-mid:#444;
  --text-light:#666;
  --text-lighter:#999;

  --border:rgba(0,0,0,0.08);

  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --heading:'Gilgan','Inter',sans-serif;
  --serif:'Cormorant Garamond',Georgia,serif;

  --expo:cubic-bezier(0.16,1,0.3,1);
  --smooth:cubic-bezier(0.4,0,0.2,1);
}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font);background:var(--white);color:var(--text);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
::selection{background:rgba(74,90,58,0.14);color:var(--text)}

/* Grain overlay */
body::after{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:9998;opacity:.022;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
a{color:inherit;text-decoration:none}img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer;border:none;background:none}
.container{max-width:1140px;margin:0 auto;padding:0 28px}

/* ===== NAV ===== */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;transition:all .55s var(--expo)}
.nav-bar{height:68px;display:flex;align-items:center;transition:all .55s var(--expo)}
.nav.scrolled .nav-bar{height:56px}
.nav--light .nav-bar{background:rgba(255,255,255,0.92);backdrop-filter:blur(24px) saturate(1.8);-webkit-backdrop-filter:blur(24px) saturate(1.8);border-bottom:1px solid var(--border)}
.nav--dark .nav-bar{background:rgba(40,52,30,0.88);backdrop-filter:blur(24px) saturate(1.5);-webkit-backdrop-filter:blur(24px) saturate(1.5);border-bottom:1px solid rgba(255,255,255,0.04)}
.nav-inner{max-width:1200px;margin:0 auto;padding:0 32px;width:100%;display:flex;align-items:center;justify-content:space-between;height:100%}
.nav-logo{display:flex;align-items:center;cursor:pointer;transition:all .4s var(--expo)}
.nav-logo:hover{opacity:.6}
.nav-logo img{height:24px;width:auto;transition:all .4s var(--expo)}
.nav.scrolled .nav-logo img{height:20px}
.nav--dark .nav-logo img{filter:invert(1)}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a{font-size:.74rem;font-weight:500;transition:all .3s;cursor:pointer;letter-spacing:.5px;position:relative;text-transform:uppercase}
.nav-links a:not(.nav-cta)::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1.5px;background:var(--olive);transition:width .4s var(--expo)}
.nav-links a:not(.nav-cta):hover::after{width:100%}
.nav--light .nav-links a{color:var(--text-light)}
.nav--dark .nav-links a{color:rgba(255,255,255,0.6)}
.nav--light .nav-links a:hover{color:var(--text)}
.nav--dark .nav-links a:hover{color:#fff}
.nav-cta{background:var(--olive)!important;color:#fff!important;padding:10px 22px;border-radius:2px;font-size:.72rem!important;letter-spacing:.8px;transition:all .4s var(--expo);font-weight:600!important;text-transform:uppercase}
/*.nav--dark .nav-cta{background:rgba(255,255,255,0.08)!important;border:1px solid rgba(255,255,255,0.15)}*/
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 8px 24px rgba(74,90,58,0.25)}
.nav--dark .nav-cta:hover{background:rgba(255,255,255,0.14)!important}
.nav-burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px}
.nav-burger span{display:block;width:22px;height:1.5px;transition:all .35s var(--expo);transform-origin:center}
.nav--light .nav-burger span{background:var(--text)}.nav--dark .nav-burger span{background:#fff}
.nav-burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.mobile-menu{position:fixed;top:68px;left:0;right:0;bottom:0;background:var(--white);z-index:999;padding:40px 32px;flex-direction:column;display:flex;opacity:0;pointer-events:none;transform:translateY(-10px);transition:all .4s var(--expo)}
.mobile-menu.open{opacity:1;pointer-events:auto;transform:none}
.mobile-menu a{font-size:1rem;color:var(--text);padding:16px 0;border-bottom:1px solid var(--border);cursor:pointer;font-weight:500;transition:all .3s var(--expo);opacity:0;transform:translateX(-10px);letter-spacing:.5px}
.mobile-menu.open a{opacity:1;transform:none}
.mobile-menu.open a:nth-child(1){transition-delay:.05s}
.mobile-menu.open a:nth-child(2){transition-delay:.1s}
.mobile-menu.open a:nth-child(3){transition-delay:.15s}
.mobile-menu.open a:nth-child(4){transition-delay:.2s}
.mobile-menu.open a:nth-child(5){transition-delay:.25s}
.mobile-menu.open a:nth-child(6){transition-delay:.3s}
.mobile-menu a:hover{padding-left:12px;color:var(--olive)}
.mobile-menu a:last-child{border:none;color:var(--olive);font-weight:700;margin-top:20px}

/* ===== BUTTONS ===== */
.btn-primary{display:inline-flex;align-items:center;gap:8px;background:var(--text);color:#fff;padding:14px 30px;font-size:.79rem;font-weight:600;letter-spacing:.3px;border-radius:2px;transition:all .45s var(--expo);cursor:pointer;border:none;position:relative;overflow:hidden}
.btn-primary::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.06),transparent);transition:left .7s var(--expo)}
.btn-primary:hover::before{left:100%}
.btn-primary:hover{background:#2a2a2a;transform:translateY(-2px);box-shadow:0 10px 30px rgba(0,0,0,0.12)}
.btn-primary:active{transform:translateY(0);transition-duration:.1s}
.btn-primary svg{transition:transform .35s var(--expo)}.btn-primary:hover svg{transform:translateX(3px)}

.btn-ghost{display:inline-flex;align-items:center;gap:8px;background:transparent;color:var(--text);padding:14px 30px;font-size:.79rem;font-weight:500;letter-spacing:.3px;border:1px solid var(--border);border-radius:2px;transition:all .4s var(--expo);cursor:pointer}
.btn-ghost:hover{border-color:var(--text);background:rgba(0,0,0,0.01)}

.btn-white{display:inline-flex;align-items:center;gap:8px;background:#fff;color:var(--text);padding:14px 30px;font-size:.79rem;font-weight:600;letter-spacing:.3px;border-radius:2px;transition:all .45s var(--expo);cursor:pointer}
.btn-white:hover{background:var(--offwhite);transform:translateY(-2px);box-shadow:0 10px 28px rgba(0,0,0,0.1)}

.btn-outline-white{display:inline-flex;align-items:center;gap:8px;background:transparent;color:#fff;padding:14px 30px;font-size:.79rem;font-weight:500;letter-spacing:.3px;border:1px solid rgba(255,255,255,0.22);border-radius:2px;transition:all .45s var(--expo);cursor:pointer}
.btn-outline-white:hover{border-color:rgba(255,255,255,0.6);background:rgba(255,255,255,0.05);transform:translateY(-1px)}

.btn-link{display:inline-flex;align-items:center;gap:6px;color:var(--text);font-size:.79rem;font-weight:600;letter-spacing:.3px;cursor:pointer;transition:all .35s var(--expo);text-transform:uppercase;border:none;background:none;padding:0;position:relative}
.btn-link::after{content:'';position:absolute;bottom:-3px;left:0;width:0;height:1px;background:var(--text);transition:width .45s var(--expo)}
.btn-link:hover::after{width:calc(100% - 20px)}.btn-link:hover{gap:10px}
.arrow-sm{width:14px;height:14px;transition:transform .35s var(--expo)}

/* ===== SECTIONS ===== */
.section{padding:104px 0}
.section--cream{background:var(--offwhite)}
.section--dark{background:var(--olive-dark);color:#fff;position:relative;overflow:hidden}
.section--dark::before{content:'';position:absolute;top:-30%;right:-10%;width:50%;height:160%;background:radial-gradient(ellipse,rgba(255,255,255,0.02) 0%,transparent 70%);pointer-events:none}
.section--dark::after{content:'';position:absolute;bottom:-20%;left:-10%;width:40%;height:120%;background:radial-gradient(ellipse,rgba(255,255,255,0.015) 0%,transparent 70%);pointer-events:none}

.label{font-size:.67rem;letter-spacing:2.8px;text-transform:uppercase;color:var(--olive);margin-bottom:12px;font-weight:600}
.label--bracket::before{content:'[ '}.label--bracket::after{content:' ]'}
.section--dark .label{color:rgba(255,255,255,0.35)}
.title{font-family:var(--heading);font-size:clamp(1.8rem,3.5vw,2.6rem);font-weight:400;line-height:1.18;margin-bottom:14px;color:var(--text);letter-spacing:-0.3px}
.title em{font-family:var(--serif);font-style:italic}.section--dark .title{color:#fff}
.desc{font-size:.92rem;color:var(--text-light);line-height:1.78;max-width:500px}
.section--dark .desc{color:rgba(255,255,255,0.58)}
.text-center{text-align:center}.mx-auto{margin-left:auto;margin-right:auto}

/* Decorative elements */
.line-deco{width:36px;height:1px;background:var(--olive);opacity:.25;margin:16px 0}
.text-center .line-deco{margin:16px auto}
.corner-accent{position:absolute;width:40px;height:40px;pointer-events:none;opacity:.12}
.corner-accent--tl{top:0;left:0;border-top:1px solid var(--olive);border-left:1px solid var(--olive)}
.corner-accent--br{bottom:0;right:0;border-bottom:1px solid var(--olive);border-right:1px solid var(--olive)}

/* ===== PARTNERS MARQUEE ===== */
.partners{padding:0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);overflow:hidden;height:60px;position:relative}
.partners::before,.partners::after{content:'';position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none}
.partners::before{left:0;background:linear-gradient(90deg,var(--white),transparent)}
.partners::after{right:0;background:linear-gradient(-90deg,var(--white),transparent)}
.partners-track{display:flex;align-items:center;height:100%;gap:56px;animation:marquee 25s linear infinite;width:max-content}
.partners-track img{height:20px;width:auto;opacity:.25;filter:grayscale(1);transition:all .5s;flex-shrink:0}
.partners-track img:hover{opacity:.5}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ===== PROCESS STEPS ===== */
.steps-grid{display:grid;grid-template-columns:repeat(2,1fr);border:1px solid var(--border);border-radius:3px;overflow:hidden;margin-top:44px}
.step{padding:42px;border-bottom:1px solid var(--border);border-right:1px solid var(--border);transition:all .5s var(--expo);position:relative;overflow:hidden}
.step:nth-child(2n){border-right:none}.step:nth-last-child(-n+2){border-bottom:none}
.step:hover{background:rgba(74,90,58,0.01)}
.step::before{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--olive);opacity:.15;transition:width .6s var(--expo)}
.step:hover::before{width:100%}
.step-num{font-family:var(--serif);font-size:2.8rem;color:var(--cream);margin-bottom:16px;line-height:1;transition:all .5s var(--expo);font-weight:300}
.step:hover .step-num{color:var(--olive);opacity:.25;transform:translateX(4px)}
.step h4{font-size:.92rem;font-weight:600;margin-bottom:8px}.step p{font-size:.85rem;color:var(--text-light);line-height:1.72}
.step-tag{display:inline-block;margin-top:14px;font-size:.67rem;letter-spacing:.9px;text-transform:uppercase;color:var(--olive);background:rgba(74,90,58,0.05);padding:5px 12px;border-radius:2px;font-weight:600;transition:all .4s var(--expo)}
.step:hover .step-tag{background:rgba(74,90,58,0.1);transform:translateX(2px)}

/* ===== FAQ ===== */
.faq-list{max-width:720px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--border);position:relative;transition:border-color .3s}
.faq-item::before{content:'';position:absolute;left:-16px;top:0;bottom:0;width:2px;background:var(--olive);transform:scaleY(0);transform-origin:top;transition:transform .45s var(--expo)}
.faq-item.open::before{transform:scaleY(1)}
.faq-q{width:100%;padding:21px 0;display:flex;justify-content:space-between;align-items:center;background:none;color:var(--text);font-size:.9rem;font-weight:500;text-align:left;line-height:1.4;cursor:pointer;font-family:var(--font);gap:16px;transition:all .3s}
.faq-q:hover{color:var(--olive)}
.faq-q .faq-arrow{min-width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:.82rem;color:var(--text-lighter);transition:all .45s var(--expo);border:1px solid var(--border);border-radius:50%;flex-shrink:0}
.faq-item.open .faq-q .faq-arrow{transform:rotate(45deg);border-color:var(--olive);color:var(--olive);background:rgba(74,90,58,0.04)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .5s var(--expo)}
.faq-a-inner{padding:0 0 22px;font-size:.86rem;color:var(--text-light);line-height:1.78}

/* ===== FOOTER ===== */
.footer{background:var(--text);color:#fff;padding:64px 0 28px;position:relative}
.footer::before{content:'';position:absolute;top:0;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.06),transparent)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:48px}
.footer-logo{margin-bottom:14px}
.footer-logo img{height:20px;width:auto;filter:brightness(0) invert(1);opacity:.7}
.footer-desc{font-size:.79rem;color:rgba(255,255,255,0.25);line-height:1.75;max-width:260px}
.footer-col h5{font-size:.67rem;letter-spacing:2.2px;text-transform:uppercase;color:rgba(255,255,255,0.16);margin-bottom:16px;font-weight:600}
.footer-col a{display:block;font-size:.79rem;color:rgba(255,255,255,0.35);margin-bottom:10px;transition:all .35s var(--expo);cursor:pointer;position:relative;padding-left:0}
.footer-col a::before{content:'';position:absolute;left:-8px;top:50%;width:0;height:1px;background:#fff;transition:width .35s var(--expo)}
.footer-col a:hover{color:#fff;padding-left:12px}
.footer-col a:hover::before{width:8px}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:20px;border-top:1px solid rgba(255,255,255,0.04);font-size:.72rem;color:rgba(255,255,255,0.18)}
.footer-bottom a{color:rgba(255,255,255,0.18);margin-left:20px;transition:color .3s}.footer-bottom a:hover{color:rgba(255,255,255,0.5)}

/* ===== ANIMATIONS ===== */
.fade{opacity:0;transform:translateY(28px);transition:opacity .8s var(--expo),transform .8s var(--expo)}
.fade.show{opacity:1;transform:none}
/* Stagger children */
.stagger>*{opacity:0;transform:translateY(16px);transition:opacity .6s var(--expo),transform .6s var(--expo)}
.stagger.show>*{opacity:1;transform:none}
.stagger.show>*:nth-child(1){transition-delay:.05s}
.stagger.show>*:nth-child(2){transition-delay:.12s}
.stagger.show>*:nth-child(3){transition-delay:.19s}
.stagger.show>*:nth-child(4){transition-delay:.26s}
.stagger.show>*:nth-child(5){transition-delay:.33s}
.stagger.show>*:nth-child(6){transition-delay:.4s}
/* Image wipe reveal */
.img-reveal{position:relative;overflow:hidden;border-radius:3px}
.img-reveal::after{content:'';position:absolute;inset:0;background:var(--cream);transform-origin:right;transition:transform 1s var(--expo) .15s;z-index:1}
.img-reveal.show::after{transform:scaleX(0)}
.img-reveal img{transition:transform 1.4s var(--expo) .2s;transform:scale(1.08)}
.img-reveal.show img{transform:scale(1)}
/* Slide variants */
.slide-l{opacity:0;transform:translateX(-32px);transition:opacity .8s var(--expo),transform .8s var(--expo)}
.slide-l.show{opacity:1;transform:none}
.slide-r{opacity:0;transform:translateX(32px);transition:opacity .8s var(--expo),transform .8s var(--expo)}
.slide-r.show{opacity:1;transform:none}
/* Scale up */
.scale-in{opacity:0;transform:scale(0.95);transition:opacity .7s var(--expo),transform .7s var(--expo)}
.scale-in.show{opacity:1;transform:none}
/* Text clip reveal for hero */
.text-reveal{overflow:hidden;display:inline-block}
.text-reveal>*{transform:translateY(105%);transition:transform .8s var(--expo)}
.text-reveal.show>*{transform:none}

/* ===== RESPONSIVE ===== */
@media(max-width:900px){
  .steps-grid{grid-template-columns:1fr}.step{border-right:none!important}.step:last-child{border-bottom:none}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .nav-links{display:none}.nav-burger{display:flex}
  .section{padding:68px 0}
  .footer-grid{grid-template-columns:1fr;gap:24px}
  .footer-bottom{flex-direction:column;gap:10px;text-align:center}
  .faq-item::before{left:-8px}
}

/* ===== NAV MONOCHROME OVERRIDE ===== */

/* helle navbar */
.nav--light .nav-bar{
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(24px) saturate(1.8);
  -webkit-backdrop-filter: blur(24px) saturate(1.8);
  border-bottom: 1px solid rgba(0,0,0,0.08);
}

/* dunkle navbar neutralisieren falls irgendwo verwendet */
.nav--dark .nav-bar{
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(24px) saturate(1.8);
  -webkit-backdrop-filter: blur(24px) saturate(1.8);
  border-bottom: 1px solid rgba(0,0,0,0.08);
}

/* logo auf heller navbar normal */
.nav--dark .nav-logo img,
.nav--light .nav-logo img{
  filter: none;
}

/* links schwarz/grau statt olive */
.nav--light .nav-links a,
.nav--dark .nav-links a{
  color: #444;
}

.nav--light .nav-links a:hover,
.nav--dark .nav-links a:hover{
  color: #111;
}

/* underline schwarz statt olive */
.nav-links a:not(.nav-cta)::after{
  background: #111;
}

/* erstgespräch button schwarz/weiß statt olive */
.nav-cta{
  background: #111 !important;
  color: #fff !important;
  border: 1px solid #111 !important;
  box-shadow: none !important;
}

.nav-cta:hover{
  background: #2a2a2a !important;
  border-color: #2a2a2a !important;
  transform: translateY(-1px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.12) !important;
}

/* burger icon schwarz */
.nav--light .nav-burger span,
.nav--dark .nav-burger span{
  background: #111;
}

/* mobile menu neutral */
.mobile-menu{
  background: #fff;
}

.mobile-menu a{
  color: #111;
  border-bottom: 1px solid rgba(0,0,0,0.08);
}

.mobile-menu a:hover{
  color: #111;
  padding-left: 12px;
}

.mobile-menu a:last-child{
  color: #111;
  font-weight: 700;
}

.nav-cta{
  background:#111 !important;
  color:#fff !important;
  border:1px solid #111 !important;
}

.nav-cta:hover{
  background:#2a2a2a !important;
  border-color:#2a2a2a !important;
}

.process-section{
  position:relative;
}

.process-section::before{
  content:'';
  position:absolute;
  bottom:-110px;
  color:#f5f5f5;
  width:420px;
  height:420px;

  background:url("img/watermark.svg") no-repeat center;
  background-size:contain;

  pointer-events:none;
  z-index:0;
}

.process-section .container{
  position:relative;
  z-index:1;
}

@media (max-width:420px){

  .process-section::before{
    display:none;
  }

}

.hero-main{
  width: 100%;
}

.nav-inner{
  position:relative;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  height:80px;
}

.nav-logo{
  grid-column:1;
  justify-self:start;
  z-index:3;
}

.nav-links{
  grid-column:2;
  display:flex;
  justify-content:center;
  align-items:center;
  gap:40px;
  position:relative;
}

.nav-links .nav-cta{
  position:absolute;
  right:-120px;
  top:50%;
  transform:translateY(-50%);
  white-space:nowrap;
}

.nav-burger{
  grid-column:3;
  justify-self:end;
}

@media (max-width:720px){

.nav-links{
  display:none;
}

.nav-burger{
  display:flex;
}

}