/* ============================================================
   PAUL BAUT — Design System
   Warm, editorial (Timberly-inspired) base + bold lime accent.
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  --green:#95C11F;          /* brand lime */
  --green-600:#84ad17;
  --green-700:#6f9112;
  --green-tint:#eef4dc;

  --ink:#16150F;            /* warm near-black */
  --ink-2:#2b2a22;
  --muted:#6a6759;
  --muted-2:#8c887a;

  --paper:#F7F4EC;          /* warm off-white */
  --paper-2:#FBF9F3;
  --sand:#EEE8DA;
  --card:#FFFFFF;
  --line:#E6DFCE;           /* warm hairline */
  --line-strong:#d9d0ba;
  --night:#141309;          /* dark sections */
  --night-2:#211f15;

  --shadow-sm:0 1px 2px rgba(20,19,9,.05), 0 2px 8px rgba(20,19,9,.05);
  --shadow:0 10px 30px -12px rgba(20,19,9,.18), 0 4px 12px -6px rgba(20,19,9,.10);
  --shadow-lg:0 30px 60px -20px rgba(20,19,9,.28);

  --r-sm:10px; --r:16px; --r-lg:24px; --r-xl:34px; --r-pill:999px;

  --container:1180px;
  --pad:clamp(20px,5vw,40px);

  --ff-sans:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --ff-serif:"Fraunces",Georgia,"Times New Roman",serif;

  --step--1:clamp(.82rem,.78rem + .2vw,.9rem);
  --step-0:clamp(1rem,.96rem + .2vw,1.075rem);
  --step-1:clamp(1.15rem,1.05rem + .5vw,1.35rem);
  --step-2:clamp(1.5rem,1.25rem + 1.2vw,2.1rem);
  --step-3:clamp(2rem,1.5rem + 2.4vw,3.1rem);
  --step-4:clamp(2.6rem,1.7rem + 4.2vw,4.8rem);
}

/* ---------- Reset / base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;font-family:var(--ff-sans);color:var(--ink);
  background:var(--paper);font-size:var(--step-0);line-height:1.62;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,video{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,textarea,select{font:inherit;color:inherit}
ul{margin:0;padding:0;list-style:none}
:focus-visible{outline:3px solid var(--green-700);outline-offset:2px;border-radius:6px}
::selection{background:var(--green);color:var(--ink)}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--pad)}
.section{padding-block:clamp(64px,9vw,128px);position:relative}
.section--tight{padding-block:clamp(48px,6vw,80px)}
.section--sand{background:var(--sand)}
.section--paper2{background:var(--paper-2)}
.section--dark{background:var(--night);color:var(--paper)}
.section--dark .muted, .section--dark .lead{color:#c9c4b4}

.eyebrow{
  display:inline-flex;align-items:center;gap:.55em;
  font-size:var(--step--1);font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--muted);margin:0 0 1rem;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--green);border-radius:2px}
.section--dark .eyebrow{color:#b6b1a0}

h1,h2,h3,h4{margin:0;line-height:1.07;font-weight:800;letter-spacing:-.018em}
h2.h-display{font-size:var(--step-3)}
h3{font-size:var(--step-1);letter-spacing:-.01em}
.h-display{font-size:var(--step-3)}
.accent-serif{font-family:var(--ff-serif);font-weight:500;font-style:italic;letter-spacing:-.01em}
.text-green{color:var(--green-700)}
.section--dark .text-green{color:var(--green)}

.lead{font-size:var(--step-1);color:var(--ink-2);line-height:1.55;font-weight:420}
.muted{color:var(--muted)}
.section-head{max-width:760px;margin-bottom:clamp(36px,5vw,60px)}
.section-head--center{margin-inline:auto;text-align:center}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--ink);--fg:var(--paper);
  display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  background:var(--bg);color:var(--fg);font-weight:650;font-size:var(--step-0);
  padding:.92em 1.5em;border-radius:var(--r-pill);
  border:1.5px solid transparent;transition:transform .18s ease,box-shadow .25s ease,background .2s ease,color .2s ease;
  text-align:center;line-height:1;min-height:52px;
}
.btn svg{width:1.1em;height:1.1em;flex:none}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn--primary{--bg:var(--green);--fg:var(--ink);box-shadow:0 8px 20px -8px rgba(149,193,31,.7)}
.btn--primary:hover{--bg:var(--green-600);box-shadow:0 12px 26px -8px rgba(149,193,31,.85)}
.btn--ink{--bg:var(--ink);--fg:var(--paper)}
.btn--ink:hover{--bg:#000}
.btn--ghost{--bg:transparent;--fg:var(--ink);border-color:var(--line-strong)}
.btn--ghost:hover{--bg:var(--ink);--fg:var(--paper);border-color:var(--ink)}
.section--dark .btn--ghost,.hero .btn--ghost{--fg:var(--paper);border-color:rgba(255,255,255,.32)}
.section--dark .btn--ghost:hover,.hero .btn--ghost:hover{--bg:var(--paper);--fg:var(--ink);border-color:var(--paper)}
.btn--lg{padding:1.05em 1.8em;font-size:var(--step-1);min-height:60px}
.btn--block{display:flex;width:100%}

.chip{
  display:inline-flex;align-items:center;gap:.5em;
  padding:.6em 1.05em;border-radius:var(--r-pill);border:1.5px solid var(--line-strong);
  background:var(--card);color:var(--ink);font-weight:550;font-size:var(--step--1);
  transition:border-color .18s,background .18s,color .18s,transform .15s;
  min-height:44px;
}
.chip:hover{border-color:var(--green);transform:translateY(-1px)}
.chip[aria-pressed="true"],.chip.is-active{background:var(--green);border-color:var(--green);color:var(--ink)}
.chip .dot{width:7px;height:7px;border-radius:50%;background:var(--green)}
.chip[aria-pressed="true"] .dot,.chip.is-active .dot{background:var(--ink)}

.link-arrow{display:inline-flex;align-items:center;gap:.45em;font-weight:650;color:var(--ink)}
.link-arrow svg{width:1.05em;height:1.05em;transition:transform .2s}
.link-arrow:hover svg{transform:translateX(4px)}
.text-link{color:var(--green-700);font-weight:600;border-bottom:1.5px solid var(--green);padding-bottom:1px}

/* ---------- Wordmark ---------- */
.wordmark{font-weight:800;letter-spacing:-.03em;font-size:1.32rem;line-height:1;display:inline-flex}
.wordmark b{font-weight:800}
.wordmark .w1{color:var(--ink)}
.wordmark .w2{color:var(--green-700)}
.section--dark .wordmark .w1,.nav.is-dark .wordmark .w1,.footer .wordmark .w1,.mobile-menu .wordmark .w1{color:#fff}
.section--dark .wordmark .w2,.nav.is-dark .wordmark .w2,.footer .wordmark .w2,.mobile-menu .wordmark .w2{color:var(--green)}

/* ---------- Nav ---------- */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:60;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:14px var(--pad);transition:background .3s,box-shadow .3s,padding .3s,border-color .3s;
  border-bottom:1px solid transparent;
}
.nav.is-dark{color:#fff}
.nav.is-stuck{background:rgba(247,244,236,.86);backdrop-filter:saturate(150%) blur(14px);
  -webkit-backdrop-filter:saturate(150%) blur(14px);border-bottom-color:var(--line);box-shadow:var(--shadow-sm);color:var(--ink)}
.nav.is-stuck .wordmark .w1{color:var(--ink)}
.nav.is-stuck .wordmark .w2{color:var(--green-700)}
.nav__links{display:none;align-items:center;gap:2px}
.nav__links a{padding:.5em .85em;border-radius:var(--r-pill);font-weight:550;font-size:.97rem;color:inherit;opacity:.9;transition:background .2s,opacity .2s}
.nav__links a:hover{opacity:1;background:rgba(0,0,0,.05)}
.nav.is-dark:not(.is-stuck) .nav__links a:hover{background:rgba(255,255,255,.12)}
.nav__right{display:flex;align-items:center;gap:.6rem}
.nav__cta{display:none}
.nav__phone{display:none;align-items:center;gap:.5em;font-weight:600;font-size:.95rem}
.nav__phone svg{width:1.05em;height:1.05em;color:var(--green-700)}
.nav.is-dark:not(.is-stuck) .nav__phone svg{color:var(--green)}
.nav__burger{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:var(--r-pill);border:1.5px solid currentColor;opacity:.85}
.nav__burger span{width:18px;height:2px;background:currentColor;position:relative;border-radius:2px}
.nav__burger span::before,.nav__burger span::after{content:"";position:absolute;left:0;width:18px;height:2px;background:currentColor;border-radius:2px}
.nav__burger span::before{top:-6px}.nav__burger span::after{top:6px}

@media (min-width:920px){
  .nav__links{display:flex}
  .nav__cta{display:inline-flex}
  .nav__phone{display:inline-flex}
  .nav__burger{display:none}
}

/* mobile menu */
.mobile-menu{position:fixed;inset:0;z-index:70;background:var(--night);color:var(--paper);
  display:flex;flex-direction:column;padding:24px var(--pad);
  transform:translateY(-100%);transition:transform .42s cubic-bezier(.7,0,.2,1),visibility .42s;visibility:hidden}
.mobile-menu.is-open{transform:translateY(0);visibility:visible}
.mobile-menu__top{display:flex;align-items:center;justify-content:space-between}
.mobile-menu__close{width:48px;height:48px;border-radius:var(--r-pill);border:1.5px solid rgba(255,255,255,.3);font-size:1.4rem;display:grid;place-items:center}
.mobile-menu nav{margin-top:8vh;display:flex;flex-direction:column;gap:.2rem}
.mobile-menu nav a{font-size:clamp(1.8rem,8vw,2.6rem);font-weight:800;letter-spacing:-.02em;padding:.25em 0;border-bottom:1px solid rgba(255,255,255,.1)}
.mobile-menu nav a .text-green{color:var(--green)}
.mobile-menu__foot{margin-top:auto;display:flex;flex-direction:column;gap:1rem;padding-top:24px}

/* ---------- Hero ---------- */
.hero{position:relative;padding-top:clamp(108px,16vh,160px);padding-bottom:clamp(48px,7vw,84px);
  background:
    radial-gradient(120% 90% at 88% -10%, #20231a 0%, var(--night) 55%) ,
    var(--night);
  color:var(--paper);overflow:clip}
.hero__grid{display:grid;gap:clamp(34px,5vw,56px);align-items:center}
.hero__eyebrow{color:#bcd27a !important}
.hero__eyebrow::before{background:var(--green)}
.hero h1{font-size:var(--step-4);letter-spacing:-.025em;font-weight:800}
.hero h1 .accent-serif{color:var(--green)}
.hero__sub{margin-top:1.35rem;font-size:var(--step-1);color:#cfcaba;max-width:34ch;line-height:1.5;font-weight:400}
.hero__cta{margin-top:2rem;display:flex;flex-wrap:wrap;gap:.8rem}
.hero__trust{margin-top:2.2rem;display:flex;flex-wrap:wrap;gap:1.3rem 1.8rem;align-items:center}
.hero__trust .ht{display:flex;align-items:center;gap:.55em;font-size:.92rem;color:#cfcaba}
.hero__trust .ht strong{color:#fff;font-weight:700}
.hero__trust svg{width:1.15em;height:1.15em;color:var(--green)}
.hero__stars{color:var(--green);letter-spacing:1px}

.hero__media{position:relative;z-index:2}
.hero__photo{position:relative;z-index:1;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-lg);
  aspect-ratio:1/1;background:#222;border:1px solid rgba(255,255,255,.08)}
.hero__photo img{width:100%;height:100%;object-fit:cover}
.hero__badge{position:absolute;left:16px;bottom:16px;right:16px;display:flex;align-items:center;gap:.8rem;
  background:rgba(20,19,9,.62);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.14);border-radius:var(--r);padding:.7rem .9rem;color:#fff}
.hero__badge .pill{width:42px;height:42px;border-radius:50%;background:var(--green);color:var(--ink);
  display:grid;place-items:center;font-weight:800;flex:none;font-size:1.1rem}
.hero__badge b{display:block;font-size:.98rem}
.hero__badge span{font-size:.82rem;color:#cfcaba}
.hero__floatcard{position:absolute;z-index:5;top:-16px;right:6px;background:var(--card);color:var(--ink);
  border-radius:var(--r);padding:.7rem .95rem;box-shadow:var(--shadow-lg);border:1px solid var(--line);
  display:flex;align-items:center;gap:.6rem;font-weight:650;font-size:.88rem;line-height:1.3;max-width:210px}
.hero__floatcard .q{color:var(--green-700);font-size:1.4rem;line-height:0;font-family:var(--ff-serif)}

@media (min-width:880px){
  .hero__grid{grid-template-columns:1.05fr .95fr}
  .hero__media{margin-left:1rem}
}

/* ---------- Marquee ---------- */
.marquee{background:var(--green);color:var(--ink);overflow:hidden;border-block:1px solid var(--green-700)}
.marquee__track{display:flex;gap:2.4rem;width:max-content;padding-block:.85rem;animation:marquee 32s linear infinite}
.marquee__track span{font-weight:700;font-size:1.02rem;letter-spacing:.01em;display:inline-flex;align-items:center;gap:2.4rem;white-space:nowrap}
.marquee__track span::after{content:"✦";color:var(--green-700)}
@keyframes marquee{to{transform:translateX(-50%)}}
.no-anim .marquee__track,.nomotion .marquee__track{animation:none}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);
  border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.stat{background:var(--paper-2);padding:clamp(20px,3.5vw,34px)}
.stat__num{font-size:clamp(2rem,1.4rem + 2.6vw,3.2rem);font-weight:800;letter-spacing:-.03em;line-height:1;color:var(--ink)}
.stat__num .u{color:var(--green-700)}
.stat__label{margin-top:.5rem;color:var(--muted);font-size:.96rem;font-weight:500}
@media (min-width:760px){.stats{grid-template-columns:repeat(4,1fr)}}

/* ---------- Services ---------- */
.svc-grid{display:grid;gap:clamp(16px,2.4vw,24px);grid-template-columns:1fr}
@media (min-width:640px){.svc-grid{grid-template-columns:repeat(2,1fr)}}
@media (min-width:1000px){.svc-grid{grid-template-columns:repeat(3,1fr)}}
.svc{position:relative;border-radius:var(--r-lg);overflow:hidden;background:var(--card);
  border:1px solid var(--line);box-shadow:var(--shadow-sm);transition:transform .3s,box-shadow .3s;display:flex;flex-direction:column}
.svc:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.svc__media{aspect-ratio:16/11;overflow:hidden;background:var(--sand)}
.svc__media img{width:100%;height:100%;object-fit:cover;transition:transform .7s cubic-bezier(.2,.7,.2,1)}
.svc:hover .svc__media img{transform:scale(1.06)}
.svc__body{padding:clamp(18px,2.4vw,26px);display:flex;flex-direction:column;gap:.6rem;flex:1}
.svc__icon{position:absolute;top:14px;left:14px;width:40px;height:40px;border-radius:12px;background:var(--green);
  color:var(--ink);display:grid;place-items:center;box-shadow:var(--shadow-sm)}
.svc__icon svg{width:22px;height:22px}
.svc h3{font-size:1.22rem}
.svc p{margin:0;color:var(--muted);font-size:.97rem;line-height:1.55}
.svc__foot{margin-top:auto;padding-top:.4rem}

/* ---------- About ---------- */
.about{display:grid;gap:clamp(34px,5vw,64px);align-items:center}
@media (min-width:900px){.about{grid-template-columns:.92fr 1.08fr}}
.about__media{position:relative}
.about__media .ph{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);aspect-ratio:4/5}
.about__media .ph img{width:100%;height:100%;object-fit:cover}
.about__media .ph--2{position:absolute;width:46%;right:-14px;bottom:-22px;aspect-ratio:1/1;border:5px solid var(--paper);box-shadow:var(--shadow-lg)}
.about__sig{font-family:var(--ff-serif);font-style:italic;font-size:1.4rem;color:var(--ink);margin-top:.4rem}
.about blockquote{margin:1.6rem 0;padding-left:1.2rem;border-left:3px solid var(--green);
  font-family:var(--ff-serif);font-style:italic;font-size:var(--step-1);color:var(--ink-2);line-height:1.5}
.about ul.ticks{margin-top:1.4rem;display:grid;gap:.7rem}
.about ul.ticks li{display:flex;gap:.7rem;align-items:flex-start;color:var(--ink-2)}
.about ul.ticks svg{flex:none;width:1.4em;height:1.4em;color:var(--green-700);margin-top:.1em}

/* ---------- Projects gallery ---------- */
.gallery{columns:1;column-gap:clamp(14px,2vw,20px)}
@media (min-width:620px){.gallery{columns:2}}
@media (min-width:1000px){.gallery{columns:3}}
.gcard{break-inside:avoid;margin-bottom:clamp(14px,2vw,20px);position:relative;border-radius:var(--r);overflow:hidden;
  box-shadow:var(--shadow-sm);border:1px solid var(--line);display:block;background:var(--sand)}
.gcard img{width:100%;display:block;transition:transform .7s cubic-bezier(.2,.7,.2,1)}
.gcard:hover img{transform:scale(1.05)}
.gcard__cap{position:absolute;inset:auto 0 0 0;padding:1.4rem .9rem .8rem;color:#fff;
  background:linear-gradient(to top,rgba(15,14,8,.82),transparent);font-weight:600;
  display:flex;align-items:center;gap:.5rem;opacity:0;transform:translateY(8px);transition:opacity .3s,transform .3s;font-size:.92rem}
.gcard:hover .gcard__cap{opacity:1;transform:translateY(0)}
.gcard__tag{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--green);font-weight:700}

/* ---------- Process ---------- */
.steps{display:grid;gap:clamp(20px,3vw,28px);counter-reset:step}
@media (min-width:820px){.steps{grid-template-columns:repeat(3,1fr)}}
.step{position:relative;padding:clamp(24px,3vw,34px);border-radius:var(--r-lg);background:var(--card);
  border:1px solid var(--line);box-shadow:var(--shadow-sm)}
.step__n{width:50px;height:50px;border-radius:14px;background:var(--green-tint);color:var(--green-700);
  display:grid;place-items:center;font-weight:800;font-size:1.3rem;margin-bottom:1.1rem}
.step h3{font-size:1.18rem;margin-bottom:.5rem}
.step p{margin:0;color:var(--muted);font-size:.97rem}

/* ---------- Testimonials ---------- */
.quotes{display:grid;gap:clamp(16px,2.2vw,22px)}
@media (min-width:760px){.quotes{grid-template-columns:repeat(3,1fr)}}
.quote{background:var(--night-2);border:1px solid rgba(255,255,255,.08);border-radius:var(--r-lg);padding:clamp(22px,3vw,30px);display:flex;flex-direction:column;gap:1rem}
.quote .stars{color:var(--green);letter-spacing:2px}
.quote p{margin:0;font-size:1.08rem;color:#ece8da;line-height:1.5;font-weight:450}
.quote .by{margin-top:auto;display:flex;align-items:center;gap:.7rem;color:#b6b1a0;font-size:.9rem}
.quote .av{width:38px;height:38px;border-radius:50%;background:var(--green);color:var(--ink);display:grid;place-items:center;font-weight:800;flex:none}
.quote .by b{color:#fff;font-weight:650}

/* ---------- FAQ ---------- */
.faq{max-width:820px;margin-inline:auto}
.faq__item{border-bottom:1px solid var(--line);}
.faq__q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:1.3rem 0;text-align:left;font-weight:700;font-size:var(--step-1);color:var(--ink)}
.faq__q .ic{flex:none;width:34px;height:34px;border-radius:50%;border:1.5px solid var(--line-strong);
  display:grid;place-items:center;transition:transform .3s,background .3s,border-color .3s;position:relative}
.faq__q .ic::before,.faq__q .ic::after{content:"";position:absolute;background:var(--ink);border-radius:2px}
.faq__q .ic::before{width:14px;height:2px}.faq__q .ic::after{width:2px;height:14px;transition:transform .3s}
.faq__item.is-open .faq__q .ic{background:var(--green);border-color:var(--green)}
.faq__item.is-open .faq__q .ic::after{transform:scaleY(0)}
.faq__a{overflow:hidden;height:0;transition:height .35s cubic-bezier(.4,0,.2,1)}
.faq__a-inner{padding:0 0 1.4rem;color:var(--muted);max-width:62ch;line-height:1.62}
.no-anim .faq__a,.nomotion .faq__a{transition:none}

/* ---------- Funnel ---------- */
.funnel{background:var(--card);border:1px solid var(--line);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);
  overflow:hidden;max-width:720px;margin-inline:auto}
.funnel__head{padding:clamp(22px,3vw,32px) clamp(22px,3.4vw,38px) 0}
.funnel__progress{display:flex;align-items:center;gap:.5rem;margin-bottom:1.2rem}
.funnel__progress .pdot{height:6px;border-radius:3px;background:var(--line-strong);flex:1;transition:background .35s}
.funnel__progress .pdot.is-done{background:var(--green)}
.funnel__step-label{font-size:.86rem;color:var(--muted);font-weight:600;letter-spacing:.04em}
.funnel__body{padding:clamp(8px,2vw,14px) clamp(22px,3.4vw,38px) clamp(24px,3.4vw,38px)}
.fstep{display:none;animation:fade .4s ease}
.fstep.is-active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.fstep h3{font-size:var(--step-2);margin-bottom:.4rem;letter-spacing:-.02em}
.fstep .hint{color:var(--muted);margin:0 0 1.4rem;font-size:.98rem}
.chip-grid{display:flex;flex-wrap:wrap;gap:.65rem}
.field{margin-bottom:1rem}
.field label{display:block;font-weight:600;font-size:.92rem;margin-bottom:.45rem}
.field .req{color:var(--green-700)}
.input,textarea.input,select.input{
  width:100%;padding:.9em 1em;border:1.5px solid var(--line-strong);border-radius:var(--r-sm);
  background:var(--paper-2);transition:border-color .2s,box-shadow .2s,background .2s;font-size:1rem}
.input:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 4px var(--green-tint);background:#fff}
textarea.input{min-height:110px;resize:vertical}
.input.is-invalid{border-color:#cc3b3b;box-shadow:0 0 0 4px #f6dada}
.field__err{display:none;color:#bf2f2f;font-size:.85rem;margin-top:.4rem;font-weight:500}
.field.is-invalid .field__err{display:block}
.funnel__nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-top:1.6rem}
.funnel__nav .spacer{flex:1}
.funnel__reassure{display:flex;flex-wrap:wrap;gap:.4rem 1.2rem;margin-top:1.3rem;color:var(--muted);font-size:.85rem}
.funnel__reassure span{display:inline-flex;align-items:center;gap:.4em}
.funnel__reassure svg{width:1em;height:1em;color:var(--green-700)}
.funnel__success{display:none;text-align:center;padding:clamp(30px,5vw,54px) clamp(22px,3.4vw,40px)}
.funnel.is-done .funnel__head,.funnel.is-done .funnel__body{display:none}
.funnel.is-done .funnel__success{display:block}
.funnel__success .check{width:74px;height:74px;border-radius:50%;background:var(--green);color:var(--ink);
  display:grid;place-items:center;margin:0 auto 1.3rem;box-shadow:0 10px 26px -8px rgba(149,193,31,.8)}
.funnel__success .check svg{width:38px;height:38px}
.funnel__success h3{font-size:var(--step-2);margin-bottom:.6rem}
.funnel__success p{color:var(--muted);max-width:42ch;margin:0 auto 1.6rem}
.summary-line{display:inline-flex;flex-wrap:wrap;gap:.4rem;justify-content:center;margin-bottom:1.4rem}
.summary-line .tagk{background:var(--green-tint);color:var(--green-700);border-radius:var(--r-pill);padding:.3em .9em;font-size:.85rem;font-weight:650}
.funnel__filehint{background:var(--green-tint);color:var(--green-700);border-radius:var(--r-sm);padding:.7rem .9rem;font-size:.9rem;max-width:none;margin:0 auto 1.4rem}
.funnel__success-actions{display:flex;flex-wrap:wrap;gap:.7rem;justify-content:center}
.btn[disabled]{opacity:.65;pointer-events:none}

/* ---------- Modal (Anfrage pop-up) ---------- */
.modal{position:fixed;inset:0;z-index:120;display:flex;align-items:center;justify-content:center;
  padding:clamp(10px,3vw,28px);visibility:hidden;opacity:0;transition:opacity .28s ease,visibility .28s}
.modal.is-open{visibility:visible;opacity:1}
.modal__overlay{position:absolute;inset:0;background:rgba(12,11,6,.64);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.modal__dialog{position:relative;width:100%;max-width:640px;max-height:92vh;overflow:auto;
  background:var(--card);border:1px solid var(--line);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);
  transform:translateY(18px) scale(.98);transition:transform .32s cubic-bezier(.2,.8,.2,1);-webkit-overflow-scrolling:touch}
.modal.is-open .modal__dialog{transform:none}
.modal__close{position:absolute;top:12px;right:12px;z-index:3;width:42px;height:42px;border-radius:50%;
  display:grid;place-items:center;background:var(--paper-2);border:1px solid var(--line);color:var(--ink);transition:background .2s,transform .25s}
.modal__close:hover{background:var(--sand);transform:rotate(90deg)}
.modal__close svg{width:20px;height:20px}
.modal .funnel{box-shadow:none;border:0;border-radius:0;max-width:none;margin:0;background:transparent}
body.modal-open{overflow:hidden}
.nomotion .modal,.no-anim .modal,.nomotion .modal__dialog,.no-anim .modal__dialog{transition:none}

.chip--lg{padding:.82em 1.2em;font-size:.98rem;min-height:50px}

/* ---------- File upload ---------- */
.filedrop{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.3rem;
  text-align:center;padding:1.3rem 1rem;border:1.6px dashed var(--line-strong);border-radius:var(--r-sm);
  background:var(--paper-2);cursor:pointer;transition:border-color .2s,background .2s}
.filedrop:hover,.filedrop.is-drag{border-color:var(--green);background:var(--green-tint)}
.filedrop svg{width:26px;height:26px;color:var(--green-700)}
.filedrop__text{font-size:.95rem;color:var(--ink-2)}
.filedrop__text b{color:var(--green-700)}
.filedrop__hint{font-size:.8rem;color:var(--muted)}
.filedrop__input{position:absolute;width:1px;height:1px;opacity:0;overflow:hidden;inset:0;margin:auto}
.filelist{margin:.7rem 0 0;display:flex;flex-direction:column;gap:.4rem}
.filelist li{display:flex;align-items:center;gap:.5rem;background:var(--paper-2);border:1px solid var(--line);
  border-radius:var(--r-sm);padding:.45rem .55rem .45rem .7rem;font-size:.86rem}
.filelist li svg{width:1.1em;height:1.1em;color:var(--green-700);flex:none}
.filelist li .fl-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.filelist li .fl-rm{flex:none;width:26px;height:26px;border-radius:50%;display:grid;place-items:center;background:var(--sand);color:var(--ink);font-size:1.1rem;line-height:1;border:0}
.filelist li .fl-rm:hover{background:var(--green)}

/* ---------- CTA band ---------- */
.cta-band{background:var(--green);color:var(--ink);border-radius:var(--r-xl);padding:clamp(34px,5vw,64px);
  text-align:center;position:relative;overflow:hidden}
.cta-band h2{font-size:var(--step-3);max-width:18ch;margin:0 auto .9rem}
.cta-band p{max-width:46ch;margin:0 auto 1.8rem;color:#3c4a14;font-size:var(--step-1)}
.cta-band .btn--ink:hover{--bg:#000}
.cta-band__big{position:absolute;right:-4%;bottom:-40%;font-weight:800;font-size:24vw;color:rgba(255,255,255,.16);line-height:1;pointer-events:none;letter-spacing:-.04em}

/* ---------- Footer ---------- */
.footer{background:var(--night);color:#c9c4b4;padding-block:clamp(54px,7vw,84px) 28px}
.footer a{color:#c9c4b4}
.footer .btn{color:var(--fg)}            /* keep button text on its own colour (black on green), not the grey link colour */
.footer .btn--primary{--fg:var(--ink)}
.footer__grid{display:grid;gap:clamp(28px,4vw,48px);grid-template-columns:1fr}
@media (min-width:760px){.footer__grid{grid-template-columns:1.4fr 1fr 1fr}}
.footer__brand .wordmark{font-size:1.6rem}
.footer__brand p{margin:1rem 0 1.4rem;max-width:34ch;color:#a39f90;font-size:.96rem}
.footer h4{font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;color:#86826f;margin-bottom:1rem;font-weight:700}
.footer__col a{display:block;padding:.32em 0;transition:color .2s}
.footer__col a:hover{color:var(--green)}
.footer__contact a{display:flex;align-items:center;gap:.6em}
.footer__contact svg{width:1.1em;height:1.1em;color:var(--green);flex:none}
.footer__bar{margin-top:clamp(36px,5vw,56px);padding-top:24px;border-top:1px solid rgba(255,255,255,.1);
  display:flex;flex-wrap:wrap;gap:.8rem 1.4rem;align-items:center;justify-content:space-between;color:#86826f;font-size:.85rem}
.footer__bar a:hover{color:var(--green)}
.footer__bar .nocookie{display:inline-flex;align-items:center;gap:.4em}
.footer__bar .nocookie svg{width:1em;height:1em;color:var(--green)}

/* ---------- Sticky mobile CTA ---------- */
.sticky-cta{position:fixed;left:12px;right:12px;bottom:12px;z-index:55;display:flex;gap:.6rem;
  transform:translateY(160%);transition:transform .4s cubic-bezier(.6,0,.2,1)}
.sticky-cta.is-visible{transform:translateY(0)}
.sticky-cta .btn{flex:1;box-shadow:var(--shadow-lg)}
.sticky-cta .btn--call{flex:none;width:54px;padding:0}
@media (min-width:920px){.sticky-cta{display:none}}

/* ---------- Reveal animations ---------- */
.is-js [data-reveal]{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.is-js [data-reveal].is-in{opacity:1;transform:none}
.is-js [data-reveal][data-delay="1"]{transition-delay:.08s}
.is-js [data-reveal][data-delay="2"]{transition-delay:.16s}
.is-js [data-reveal][data-delay="3"]{transition-delay:.24s}
.is-js [data-reveal][data-delay="4"]{transition-delay:.32s}
.is-js [data-reveal][data-delay="5"]{transition-delay:.40s}

.nomotion [data-reveal],.no-anim [data-reveal],
.nomotion .is-js [data-reveal]{opacity:1 !important;transform:none !important;transition:none !important}
@media (prefers-reduced-motion:reduce){
  [data-reveal]{opacity:1 !important;transform:none !important;transition:none !important}
  .marquee__track{animation:none}
  .svc:hover .svc__media img,.gcard:hover img{transform:none}
}

/* ---------- Legal pages ---------- */
.legal{padding-top:clamp(120px,16vh,170px)}
.legal__wrap{max-width:760px;margin-inline:auto}
.legal h1{font-size:var(--step-3);margin-bottom:.6rem}
.legal h2{font-size:var(--step-1);margin:2.4rem 0 .7rem}
.legal p,.legal address{color:var(--ink-2);margin:.5rem 0;font-style:normal;line-height:1.7}
.legal a{color:var(--green-700);border-bottom:1px solid var(--green)}
.legal .back{display:inline-flex;align-items:center;gap:.5em;margin-bottom:2rem;font-weight:600;color:var(--muted)}

.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.nobr{white-space:nowrap}
