/* =====================================================================
   Reza Zardini — Garten- & Landschaftsbau Garbsen
   Design: editorial-natürlich · Fraunces + Inter · Forest / Cream / Ochre
   ===================================================================== */

/* ---------- Tokens ---------- */
:root{
  --ink:#16231a;          /* near-black green, text */
  --forest:#1e3a28;       /* deep forest */
  --moss:#3f6b3a;         /* brand green */
  --leaf:#6b9b46;         /* bright leaf accent */
  --leaf-soft:#e8efdd;    /* pale green wash */
  --ochre:#b9772e;        /* warm accent (soil/wood) */
  --ochre-soft:#f0e2cd;
  --paper:#f6f2e9;        /* cream background */
  --paper-2:#efe9db;      /* deeper cream */
  --card:#fbf9f3;         /* card surface */
  --line:#ddd4c2;         /* hairline */
  --line-strong:#c9bfa8;
  --muted:#5c5a4f;        /* muted text on cream */
  --muted-2:#7a7768;
  --white:#ffffff;

  --serif:"Fraunces",Georgia,"Times New Roman",serif;
  --sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;

  --wrap:1240px;
  --gutter:clamp(1.25rem,5vw,4rem);
  --radius:4px;
  --radius-lg:16px;
  --shadow-sm:0 1px 2px rgba(22,35,26,.06),0 8px 24px -18px rgba(22,35,26,.35);
  --shadow-md:0 18px 50px -28px rgba(22,35,26,.55);
  --shadow-lg:0 40px 90px -50px rgba(22,35,26,.7);
  --ease:cubic-bezier(.22,.61,.36,1);
  --t:.5s var(--ease);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  line-height:1.7;
  font-size:clamp(1rem,.96rem + .2vw,1.075rem);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,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}
ul{list-style:none;padding:0}
h1,h2,h3,h4{font-family:var(--serif);font-weight:430;line-height:1.06;letter-spacing:-.015em;font-optical-sizing:auto}
:focus-visible{outline:2.5px solid var(--moss);outline-offset:3px;border-radius:2px}

/* ---------- Layout helpers ---------- */
.wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:var(--gutter)}
.wrap-wide{max-width:1500px;margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:clamp(4.5rem,9vw,8rem)}
.section--tight{padding-block:clamp(3.5rem,6vw,5.5rem)}
.grain{position:relative}
.grain::after{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:1;opacity:.4;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/%3E%3C/svg%3E");
}

/* ---------- Type utilities ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:var(--sans);font-size:.74rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  color:var(--moss);
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--leaf);display:inline-block}
.eyebrow--center::after{content:"";width:26px;height:1px;background:var(--leaf);display:inline-block}
.eyebrow--light{color:var(--leaf-soft)}
.eyebrow--light::before,.eyebrow--light::after{background:var(--leaf)}
.display{font-size:clamp(2.6rem,1.6rem + 5vw,5.6rem);line-height:.98}
.h-xl{font-size:clamp(2.1rem,1.4rem + 3vw,3.6rem)}
.h-lg{font-size:clamp(1.7rem,1.2rem + 2vw,2.7rem)}
.lead{font-size:clamp(1.12rem,1.02rem + .5vw,1.45rem);line-height:1.55;color:var(--muted);font-weight:400}
.serif-em{font-family:var(--serif);font-style:italic;font-weight:400}
.text-center{text-align:center}
.measure{max-width:64ch}
.measure-sm{max-width:52ch}
.mx-auto{margin-inline:auto}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--forest);--fg:var(--paper);
  display:inline-flex;align-items:center;gap:.65rem;
  padding:1rem 1.7rem;border-radius:100px;
  font-family:var(--sans);font-weight:600;font-size:.95rem;letter-spacing:.01em;
  background:var(--bg);color:var(--fg);
  transition:transform .35s var(--ease),background .35s var(--ease),box-shadow .35s var(--ease),color .35s var(--ease);
  will-change:transform;position:relative;
}
.btn svg{width:1.05em;height:1.05em;transition:transform .35s var(--ease)}
.btn:hover{transform:translateY(-3px);box-shadow:0 16px 30px -14px rgba(30,58,40,.6)}
.btn:hover svg{transform:translateX(4px)}
.btn--accent{--bg:var(--ochre)}
.btn--accent:hover{box-shadow:0 16px 30px -14px rgba(185,119,46,.7)}
.btn--leaf{--bg:var(--leaf);--fg:var(--ink)}
.btn--ghost{--bg:transparent;--fg:var(--ink);border:1.5px solid var(--line-strong)}
.btn--ghost:hover{border-color:var(--forest);background:var(--forest);color:var(--paper)}
.btn--light{--bg:var(--paper);--fg:var(--forest)}
.btn--outline-light{--bg:transparent;--fg:var(--paper);border:1.5px solid rgba(246,242,233,.4)}
.btn--outline-light:hover{background:var(--paper);color:var(--forest);border-color:var(--paper)}
.btn--sm{padding:.7rem 1.2rem;font-size:.85rem}
.link-arrow{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;color:var(--forest);font-size:.95rem}
.link-arrow svg{width:1.1em;height:1.1em;transition:transform .35s var(--ease)}
.link-arrow:hover svg{transform:translateX(5px)}

/* =====================================================================
   HEADER
   ===================================================================== */
.topbar{
  background:var(--forest);color:var(--leaf-soft);
  font-size:.82rem;letter-spacing:.02em;
}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:1rem;min-height:40px}
.topbar a{display:inline-flex;align-items:center;gap:.45rem;transition:color .3s}
.topbar a:hover{color:var(--white)}
.topbar svg{width:15px;height:15px;opacity:.85}
.topbar__right{display:flex;gap:1.6rem}
.topbar__region{opacity:.8}
@media (max-width:820px){.topbar__region,.topbar__right .t-mail{display:none}}

.header{
  position:sticky;top:0;z-index:100;
  background:rgba(246,242,233,.82);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .4s,box-shadow .4s,background .4s;
}
.header.scrolled{border-bottom-color:var(--line);box-shadow:0 10px 30px -24px rgba(22,35,26,.6);background:rgba(246,242,233,.94)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;min-height:78px;transition:min-height .4s}
.header.scrolled .nav{min-height:66px}
.brand{display:flex;align-items:center;gap:.75rem;flex-shrink:0}
.brand img{width:46px;height:46px;object-fit:contain;transition:width .4s,height .4s}
.header.scrolled .brand img{width:40px;height:40px}
.brand__txt{display:flex;flex-direction:column;line-height:1.05}
.brand__name{font-family:var(--serif);font-size:1.16rem;font-weight:500;letter-spacing:-.01em;color:var(--ink)}
.brand__sub{font-size:.62rem;letter-spacing:.24em;text-transform:uppercase;color:var(--moss);font-weight:600}

.nav__menu{display:flex;align-items:center;gap:.35rem}
.nav__item{position:relative}
.nav__link{
  display:inline-flex;align-items:center;gap:.35rem;
  padding:.6rem .85rem;border-radius:100px;font-size:.92rem;font-weight:500;color:var(--ink);
  transition:color .3s,background .3s;
}
.nav__link:hover,.nav__item:hover>.nav__link,.nav__link[aria-current]{color:var(--forest);background:rgba(107,155,70,.12)}
.nav__link[aria-current]{font-weight:600}
.nav__link svg{width:14px;height:14px;transition:transform .3s}
.nav__item:hover .nav__link svg{transform:rotate(180deg)}

/* dropdown */
.dropdown{
  position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%) translateY(8px);
  min-width:300px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);padding:.6rem;
  opacity:0;visibility:hidden;pointer-events:none;transition:opacity .3s var(--ease),transform .3s var(--ease);z-index:120;
}
.dropdown--wide{min-width:560px;display:grid;grid-template-columns:1fr 1fr;gap:.2rem}
.nav__item:hover .dropdown,.nav__item:focus-within .dropdown{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.dropdown a{
  display:flex;flex-direction:column;gap:.1rem;padding:.6rem .8rem;border-radius:8px;transition:background .25s;
}
.dropdown a:hover{background:var(--leaf-soft)}
.dropdown a strong{font-weight:600;font-size:.92rem;color:var(--ink)}
.dropdown a span{font-size:.78rem;color:var(--muted-2)}
.dropdown__head{grid-column:1/-1;padding:.5rem .8rem .2rem;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--moss);font-weight:600}

.nav__cta{display:flex;align-items:center;gap:.6rem}
.nav__phone{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;font-size:.95rem;color:var(--forest)}
.nav__phone svg{width:17px;height:17px}
.burger{display:none;flex-direction:column;gap:5px;padding:.6rem;border-radius:8px}
.burger span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:transform .35s var(--ease),opacity .3s}

@media (max-width:1080px){
  .nav__menu,.nav__phone .np-num{display:none}
  .burger{display:flex}
  .nav__cta .btn{display:none}
}

/* mobile drawer */
.drawer{
  position:fixed;inset:0;z-index:200;visibility:hidden;pointer-events:none;
}
.drawer__scrim{position:absolute;inset:0;background:rgba(22,35,26,.5);opacity:0;transition:opacity .4s}
.drawer__panel{
  position:absolute;top:0;right:0;height:100%;width:min(88vw,400px);
  background:var(--paper);box-shadow:var(--shadow-lg);
  transform:translateX(100%);transition:transform .45s var(--ease);
  display:flex;flex-direction:column;overflow-y:auto;padding:1.5rem;
}
.drawer.open{visibility:visible;pointer-events:auto}
.drawer.open .drawer__scrim{opacity:1}
.drawer.open .drawer__panel{transform:translateX(0)}
.drawer__top{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}
.drawer__close{padding:.5rem;border-radius:8px}
.drawer__close svg{width:26px;height:26px}
.drawer nav{display:flex;flex-direction:column}
.drawer__link{padding:.85rem .4rem;font-size:1.15rem;font-family:var(--serif);border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.drawer details summary{list-style:none;cursor:pointer;padding:.85rem .4rem;font-size:1.15rem;font-family:var(--serif);border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.drawer details summary::-webkit-details-marker{display:none}
.drawer details[open] summary .chev{transform:rotate(180deg)}
.drawer details summary .chev{transition:transform .3s;width:16px;height:16px}
.drawer details .sub{padding:.3rem 0 .6rem .8rem;display:flex;flex-direction:column}
.drawer details .sub a{padding:.5rem .4rem;font-size:.98rem;color:var(--muted);border-bottom:1px dashed var(--line)}
.drawer details .sub a:last-child{border:none}
.drawer__foot{margin-top:auto;padding-top:1.5rem;display:flex;flex-direction:column;gap:.7rem}

/* =====================================================================
   HERO
   ===================================================================== */
.hero{position:relative;background:var(--forest);color:var(--paper);overflow:hidden;isolation:isolate}
.hero__media{position:absolute;inset:0;z-index:-2}
.hero__media img{width:100%;height:100%;object-fit:cover;transform:scale(1.08);animation:heroZoom 14s var(--ease) forwards}
@keyframes heroZoom{to{transform:scale(1)}}
.hero__media::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(20,40,28,.55) 0%,rgba(20,40,28,.45) 40%,rgba(20,40,28,.82) 100%),
             linear-gradient(105deg,rgba(20,40,28,.75) 0%,rgba(20,40,28,.15) 65%);
}
.hero__inner{position:relative;padding-block:clamp(6rem,13vh,10rem) clamp(3.5rem,7vh,6rem);min-height:clamp(600px,88vh,900px);display:flex;flex-direction:column;justify-content:flex-end}
.hero h1{color:var(--paper);max-width:16ch;margin-top:1.5rem}
.hero h1 em{font-style:italic;color:var(--leaf)}
.hero__lead{max-width:52ch;margin-top:1.6rem;color:rgba(246,242,233,.85);font-size:clamp(1.05rem,1rem + .5vw,1.35rem);line-height:1.55}
.hero__actions{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:2.2rem}
.hero__meta{
  display:flex;flex-wrap:wrap;gap:2.4rem;margin-top:clamp(2.5rem,5vh,4rem);
  padding-top:2rem;border-top:1px solid rgba(246,242,233,.2);
}
.hero__meta .m{display:flex;flex-direction:column}
.hero__meta .m b{font-family:var(--serif);font-size:2rem;font-weight:500;color:var(--leaf);line-height:1}
.hero__meta .m span{font-size:.82rem;letter-spacing:.04em;color:rgba(246,242,233,.75);margin-top:.35rem}
.scroll-hint{position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:.5rem;font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(246,242,233,.6)}
.scroll-hint .dot{width:1px;height:38px;background:linear-gradient(var(--leaf),transparent);animation:hint 2s ease-in-out infinite}
@keyframes hint{0%,100%{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}
@media (max-width:640px){.scroll-hint{display:none}}

/* marquee trust strip */
.ticker{background:var(--ink);color:var(--paper);overflow:hidden;border-block:1px solid rgba(255,255,255,.08)}
.ticker__track{display:flex;gap:3rem;padding-block:.9rem;white-space:nowrap;animation:ticker 32s linear infinite;width:max-content}
.ticker span{display:inline-flex;align-items:center;gap:.9rem;font-size:.86rem;letter-spacing:.06em;color:rgba(246,242,233,.72)}
.ticker span::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--leaf)}
@keyframes ticker{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.ticker__track{animation:none}}

/* =====================================================================
   INTRO / SPLIT
   ===================================================================== */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.split--media-right{grid-template-columns:1.05fr .95fr}
@media (max-width:900px){.split{grid-template-columns:1fr;gap:2.5rem}}
.figure{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md)}
.figure img{width:100%;height:100%;object-fit:cover}
.figure--tall{aspect-ratio:4/5}
.figure--wide{aspect-ratio:3/2}
.figure__badge{
  position:absolute;left:1.2rem;bottom:1.2rem;z-index:2;
  background:var(--paper);color:var(--ink);border-radius:12px;padding:.9rem 1.15rem;box-shadow:var(--shadow-md);
  display:flex;align-items:center;gap:.75rem;max-width:78%;
}
.figure__badge .ic{width:40px;height:40px;flex-shrink:0;border-radius:10px;background:var(--leaf-soft);display:grid;place-items:center;color:var(--moss)}
.figure__badge .ic svg{width:22px;height:22px}
.figure__badge b{font-family:var(--serif);font-size:1rem;font-weight:600;display:block;line-height:1.1}
.figure__badge span{font-size:.78rem;color:var(--muted)}
.figure--stack{display:grid;grid-template-columns:1fr;gap:1rem;box-shadow:none;background:none;border-radius:0;overflow:visible}
.prose h2{margin-bottom:1.1rem}
.prose p+p{margin-top:1.1rem}
.prose .lead{margin-bottom:1.4rem}
.section-head{max-width:60ch}
.section-head--center{margin-inline:auto;text-align:center}
.section-head .eyebrow{margin-bottom:1.1rem}
.section-head h2{margin-bottom:1rem}

/* signature */
.signature{margin-top:1.8rem;display:flex;align-items:center;gap:1rem}
.signature__mark{font-family:var(--serif);font-style:italic;font-size:1.5rem;color:var(--forest)}
.signature__meta{font-size:.85rem;color:var(--muted)}
.signature__meta b{display:block;font-family:var(--sans);color:var(--ink);font-size:.92rem}

/* value tiles */
.values{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;margin-top:3rem}
@media (max-width:900px){.values{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.values{grid-template-columns:1fr}}
.value{padding:1.6rem;background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);transition:transform var(--t),box-shadow var(--t),border-color var(--t)}
.value:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);border-color:var(--line-strong)}
.value .ic{width:48px;height:48px;border-radius:12px;background:var(--leaf-soft);color:var(--moss);display:grid;place-items:center;margin-bottom:1rem}
.value .ic svg{width:26px;height:26px}
.value h3{font-size:1.18rem;margin-bottom:.5rem}
.value p{font-size:.92rem;color:var(--muted);line-height:1.55}

/* =====================================================================
   LEISTUNGEN GRID
   ===================================================================== */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem}
@media (max-width:960px){.svc-grid{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.svc-grid{grid-template-columns:1fr}}
.svc-card{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;background:var(--ink);
  min-height:340px;display:flex;flex-direction:column;justify-content:flex-end;
  color:var(--paper);isolation:isolate;box-shadow:var(--shadow-sm);
}
.svc-card__img{position:absolute;inset:0;z-index:-2}
.svc-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.svc-card::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(20,40,28,.05) 30%,rgba(20,40,28,.55) 60%,rgba(16,26,20,.92) 100%)}
.svc-card:hover .svc-card__img img{transform:scale(1.07)}
.svc-card__body{padding:1.5rem;transition:transform .5s var(--ease)}
.svc-card__tag{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--leaf);font-weight:600}
.svc-card h3{font-size:1.5rem;color:var(--paper);margin:.5rem 0 .4rem}
.svc-card__ex{font-size:.9rem;color:rgba(246,242,233,.8);line-height:1.5;max-height:0;opacity:0;overflow:hidden;transition:max-height .5s var(--ease),opacity .4s,margin .5s}
.svc-card__more{display:inline-flex;align-items:center;gap:.5rem;margin-top:.9rem;font-size:.85rem;font-weight:600;color:var(--paper)}
.svc-card__more svg{width:16px;height:16px;transition:transform .35s}
.svc-card:hover .svc-card__ex{max-height:120px;opacity:1;margin-top:.5rem}
.svc-card:hover .svc-card__more svg{transform:translateX(4px)}
@media (hover:none){.svc-card__ex{max-height:120px;opacity:1;margin-top:.5rem}}

/* index list style (numbered) for service overview */
.svc-list{display:grid;grid-template-columns:1fr;gap:0;border-top:1px solid var(--line)}
.svc-row{
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:1.5rem;
  padding:1.6rem .5rem;border-bottom:1px solid var(--line);transition:padding .4s var(--ease),background .4s;position:relative;
}
.svc-row:hover{background:var(--card);padding-inline:1.2rem}
.svc-row__num{font-family:var(--serif);font-size:1.1rem;color:var(--leaf);font-weight:500;width:2.5rem}
.svc-row__main h3{font-size:1.5rem;margin-bottom:.25rem}
.svc-row__main p{font-size:.92rem;color:var(--muted);max-width:60ch}
.svc-row__arrow{width:44px;height:44px;border-radius:50%;border:1.5px solid var(--line-strong);display:grid;place-items:center;transition:background .4s,color .4s,border-color .4s,transform .4s}
.svc-row:hover .svc-row__arrow{background:var(--forest);color:var(--paper);border-color:var(--forest);transform:rotate(-45deg)}
.svc-row__arrow svg{width:20px;height:20px}
@media (max-width:640px){.svc-row{grid-template-columns:auto 1fr;gap:1rem}.svc-row__arrow{display:none}.svc-row__num{width:1.8rem}}

/* =====================================================================
   PROCESS
   ===================================================================== */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:1.3rem;counter-reset:step}
@media (max-width:900px){.process{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.process{grid-template-columns:1fr}}
.step{position:relative;padding:1.8rem 1.5rem;background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden}
.step::before{
  counter-increment:step;content:counter(step,decimal-leading-zero);
  font-family:var(--serif);font-size:3.6rem;font-weight:400;color:var(--leaf-soft);position:absolute;top:.6rem;right:1rem;line-height:1;
}
.step__ic{width:44px;height:44px;color:var(--moss);margin-bottom:1rem;position:relative}
.step__ic svg{width:100%;height:100%}
.step h3{font-size:1.2rem;margin-bottom:.5rem;position:relative}
.step p{font-size:.9rem;color:var(--muted);position:relative}

/* =====================================================================
   FEATURE / CTA BANDS
   ===================================================================== */
.band{position:relative;background:var(--forest);color:var(--paper);overflow:hidden;isolation:isolate}
.band__media{position:absolute;inset:0;z-index:-2;opacity:.24}
.band__media img{width:100%;height:100%;object-fit:cover}
.band::before{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(120deg,var(--forest),rgba(30,58,40,.75))}
.band .wrap{position:relative;text-align:center;display:flex;flex-direction:column;align-items:center}
.band h2{color:var(--paper);max-width:20ch;margin:1.1rem auto 1rem}
.band h2 em{font-style:italic;color:var(--leaf)}
.band p{max-width:56ch;color:rgba(246,242,233,.82);margin-bottom:2rem}
.band__actions{display:flex;flex-wrap:wrap;gap:.9rem;justify-content:center}

/* leaf motif divider */
.leaf-rule{display:flex;align-items:center;justify-content:center;gap:1rem;color:var(--leaf)}
.leaf-rule::before,.leaf-rule::after{content:"";height:1px;width:min(80px,15vw);background:var(--line-strong)}
.leaf-rule svg{width:26px;height:26px}

/* =====================================================================
   STATS
   ===================================================================== */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
@media (max-width:760px){.stats{grid-template-columns:1fr 1fr;gap:1rem}}
.stat{text-align:center;padding:1.5rem 1rem;border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--card)}
.stat b{display:block;font-family:var(--serif);font-size:clamp(2.2rem,1.5rem + 2.5vw,3.4rem);font-weight:500;color:var(--forest);line-height:1}
.stat span{display:block;margin-top:.5rem;font-size:.85rem;color:var(--muted);letter-spacing:.03em}

/* =====================================================================
   TESTIMONIAL / QUOTE
   ===================================================================== */
.quote-block{max-width:70ch;margin-inline:auto;text-align:center}
.quote-block .mark{font-family:var(--serif);font-size:5rem;line-height:.5;color:var(--leaf);display:block;height:2.5rem}
.quote-block p{font-family:var(--serif);font-size:clamp(1.4rem,1.1rem + 1.5vw,2.2rem);line-height:1.35;font-weight:400;letter-spacing:-.01em;color:var(--ink)}
.quote-block cite{display:block;margin-top:1.6rem;font-style:normal;font-size:.9rem;color:var(--muted);letter-spacing:.03em}
.quote-block cite b{color:var(--forest);font-weight:600}

/* =====================================================================
   GALLERY
   ===================================================================== */
.gallery{columns:3;column-gap:1.1rem}
@media (max-width:900px){.gallery{columns:2}}
@media (max-width:560px){.gallery{columns:1}}
.gallery figure{break-inside:avoid;margin-bottom:1.1rem;position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);cursor:pointer}
.gallery img,.gallery video{width:100%;display:block;transition:transform .7s var(--ease)}
.gallery figure:hover img{transform:scale(1.05)}
.gallery figcaption{
  position:absolute;left:0;right:0;bottom:0;padding:1.4rem 1.1rem .9rem;
  background:linear-gradient(transparent,rgba(16,26,20,.85));color:var(--paper);
  font-size:.85rem;font-weight:500;letter-spacing:.02em;opacity:0;transform:translateY(8px);transition:opacity .4s,transform .4s;
}
.gallery figure:hover figcaption{opacity:1;transform:translateY(0)}
.gallery .vid-badge{position:absolute;top:.9rem;right:.9rem;z-index:2;width:38px;height:38px;border-radius:50%;background:rgba(246,242,233,.9);display:grid;place-items:center;color:var(--forest)}
.gallery .vid-badge svg{width:18px;height:18px}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:300;background:rgba(16,26,20,.94);display:grid;place-items:center;padding:2rem;opacity:0;visibility:hidden;transition:opacity .4s}
.lightbox.open{opacity:1;visibility:visible}
.lightbox img,.lightbox video{max-width:92vw;max-height:88vh;border-radius:8px;box-shadow:var(--shadow-lg)}
.lightbox__close{position:absolute;top:1.5rem;right:1.5rem;color:var(--paper);padding:.5rem}
.lightbox__close svg{width:32px;height:32px}

/* =====================================================================
   DETAIL PAGE
   ===================================================================== */
.page-hero{position:relative;background:var(--forest);color:var(--paper);overflow:hidden;isolation:isolate}
.page-hero__media{position:absolute;inset:0;z-index:-2}
.page-hero__media img{width:100%;height:100%;object-fit:cover;transform:scale(1.05)}
.page-hero__media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,40,28,.72),rgba(20,40,28,.6)),linear-gradient(100deg,rgba(20,40,28,.8),rgba(20,40,28,.3))}
.page-hero__inner{position:relative;padding-block:clamp(4.5rem,10vh,7.5rem) clamp(3rem,6vh,5rem);min-height:clamp(360px,52vh,520px);display:flex;flex-direction:column;justify-content:flex-end}
.page-hero .tag{color:var(--leaf)}
.page-hero h1{color:var(--paper);max-width:18ch;margin:1.1rem 0 1.1rem}
.page-hero__lead{max-width:56ch;color:rgba(246,242,233,.85);font-size:clamp(1.05rem,1rem + .4vw,1.3rem)}
.crumbs{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;font-size:.8rem;color:rgba(246,242,233,.7);letter-spacing:.03em}
.crumbs a:hover{color:var(--paper)}
.crumbs .sep{opacity:.5}
.crumbs .cur{color:var(--leaf)}

.detail{display:grid;grid-template-columns:1fr 340px;gap:clamp(2rem,5vw,4.5rem);align-items:start}
@media (max-width:1000px){.detail{grid-template-columns:1fr}}
.article > *+*{margin-top:1.4rem}
.article .lead{margin-bottom:.4rem}
.article h2{font-size:clamp(1.5rem,1.2rem + 1vw,2rem);margin-top:2.6rem}
.article h2:first-child{margin-top:0}
.article p{color:#2c2a22;line-height:1.75}
.article strong{color:var(--ink);font-weight:600}
.article .quote-inline{
  border-left:3px solid var(--leaf);padding:.6rem 0 .6rem 1.5rem;margin-top:2rem;
  font-family:var(--serif);font-style:italic;font-size:1.3rem;line-height:1.4;color:var(--forest);
}
.checklist{display:grid;gap:.8rem;margin-top:1.6rem}
.checklist li{display:flex;gap:.85rem;align-items:flex-start;font-size:.98rem}
.checklist .ck{flex-shrink:0;width:24px;height:24px;border-radius:50%;background:var(--leaf-soft);color:var(--moss);display:grid;place-items:center;margin-top:.15rem}
.checklist .ck svg{width:14px;height:14px}
.feat-cards{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1.8rem}
@media (max-width:560px){.feat-cards{grid-template-columns:1fr}}
.feat-card{padding:1.35rem;background:var(--card);border:1px solid var(--line);border-radius:12px;transition:border-color var(--t),transform var(--t)}
.feat-card:hover{border-color:var(--leaf);transform:translateY(-3px)}
.feat-card .ic{width:38px;height:38px;border-radius:9px;background:var(--forest);color:var(--leaf);display:grid;place-items:center;margin-bottom:.85rem}
.feat-card .ic svg{width:20px;height:20px}
.feat-card h4{font-family:var(--serif);font-size:1.1rem;font-weight:600;margin-bottom:.35rem}
.feat-card p{font-size:.88rem;color:var(--muted);line-height:1.5;margin:0}

/* accordion */
.accordion{margin-top:1.6rem;border-top:1px solid var(--line)}
.acc{border-bottom:1px solid var(--line)}
.acc__q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1.2rem .2rem;text-align:left;font-family:var(--serif);font-size:1.12rem;font-weight:500;color:var(--ink)}
.acc__ic{flex-shrink:0;width:30px;height:30px;border-radius:50%;border:1.5px solid var(--line-strong);display:grid;place-items:center;transition:background .35s,transform .35s,color .35s,border-color .35s}
.acc__ic svg{width:16px;height:16px;transition:transform .35s}
.acc[aria-expanded="true"] .acc__ic{background:var(--forest);color:var(--paper);border-color:var(--forest)}
.acc[aria-expanded="true"] .acc__ic svg{transform:rotate(45deg)}
.acc__a{max-height:0;overflow:hidden;transition:max-height .45s var(--ease)}
.acc__a p{padding:0 .2rem 1.3rem;color:var(--muted);font-size:.95rem;line-height:1.65}

/* sidebar */
.aside{position:sticky;top:100px;display:flex;flex-direction:column;gap:1.2rem}
.aside__card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.6rem;box-shadow:var(--shadow-sm)}
.aside__card--dark{background:var(--forest);color:var(--paper);border-color:var(--forest)}
.aside__card--dark h3{color:var(--paper)}
.aside__card h3{font-size:1.3rem;margin-bottom:.4rem}
.aside__card p{font-size:.9rem;color:var(--muted);margin-bottom:1.2rem}
.aside__card--dark p{color:rgba(246,242,233,.8)}
.aside__contact{display:flex;flex-direction:column;gap:.9rem;margin-bottom:1.3rem}
.aside__contact a{display:flex;align-items:center;gap:.8rem;font-size:.95rem}
.aside__contact .ic{width:38px;height:38px;border-radius:10px;background:rgba(107,155,70,.2);color:var(--leaf);display:grid;place-items:center;flex-shrink:0}
.aside__contact .ic svg{width:19px;height:19px}
.aside__contact b{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:rgba(246,242,233,.6);font-weight:600}
.aside__list a{display:flex;justify-content:space-between;align-items:center;gap:.5rem;padding:.75rem 0;border-bottom:1px solid var(--line);font-size:.93rem;font-weight:500;transition:color .3s,padding .3s}
.aside__list a:last-child{border:none}
.aside__list a:hover{color:var(--forest);padding-left:.4rem}
.aside__list a svg{width:16px;height:16px;color:var(--leaf)}

/* related */
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
@media (max-width:860px){.related-grid{grid-template-columns:1fr}}
.rel-card{display:flex;gap:1rem;align-items:center;padding:1rem;background:var(--card);border:1px solid var(--line);border-radius:12px;transition:transform var(--t),box-shadow var(--t)}
.rel-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.rel-card img{width:76px;height:76px;border-radius:8px;object-fit:cover;flex-shrink:0}
.rel-card h4{font-size:1.02rem;font-family:var(--serif);font-weight:600}
.rel-card span{font-size:.8rem;color:var(--moss);display:inline-flex;align-items:center;gap:.3rem;margin-top:.2rem}
.rel-card span svg{width:14px;height:14px}

/* =====================================================================
   FORMS / CONTACT
   ===================================================================== */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(2rem,5vw,4rem);align-items:start}
@media (max-width:920px){.contact-grid{grid-template-columns:1fr}}
.info-list{display:flex;flex-direction:column;gap:1.4rem;margin-top:2rem}
.info-item{display:flex;gap:1.1rem;align-items:flex-start}
.info-item .ic{width:48px;height:48px;border-radius:12px;background:var(--leaf-soft);color:var(--moss);display:grid;place-items:center;flex-shrink:0}
.info-item .ic svg{width:24px;height:24px}
.info-item b{display:block;font-size:.74rem;text-transform:uppercase;letter-spacing:.14em;color:var(--moss);font-weight:600;margin-bottom:.2rem}
.info-item p,.info-item a{font-size:1.05rem;color:var(--ink)}
.info-item a:hover{color:var(--forest)}

.form-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(1.5rem,3vw,2.5rem);box-shadow:var(--shadow-sm)}
.field{margin-bottom:1.15rem}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media (max-width:520px){.field-row{grid-template-columns:1fr}}
.field label{display:block;font-size:.83rem;font-weight:600;letter-spacing:.02em;margin-bottom:.45rem;color:var(--ink)}
.field label .req{color:var(--ochre)}
.field input,.field textarea,.field select{
  width:100%;padding:.85rem 1rem;font:inherit;font-size:.95rem;color:var(--ink);
  background:var(--white);border:1.5px solid var(--line);border-radius:10px;transition:border-color .3s,box-shadow .3s;
}
.field textarea{resize:vertical;min-height:130px}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--moss);box-shadow:0 0 0 4px rgba(107,155,70,.15)}
.field input:user-invalid,.field textarea:user-invalid{border-color:#c0562f}
.check{display:flex;gap:.7rem;align-items:flex-start;font-size:.85rem;color:var(--muted);line-height:1.5}
.check input{width:20px;height:20px;flex-shrink:0;margin-top:.1rem;accent-color:var(--moss)}
.check a{color:var(--forest);text-decoration:underline;text-underline-offset:2px}
.form-note{margin-top:1rem;font-size:.82rem;color:var(--muted-2);display:flex;gap:.5rem;align-items:flex-start}
.form-note svg{width:16px;height:16px;flex-shrink:0;margin-top:.15rem;color:var(--moss)}

/* map placeholder */
.map-embed{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-sm);margin-top:2rem}
.map-embed iframe{width:100%;height:340px;display:block;border:0;filter:grayscale(.2) saturate(.9)}

/* =====================================================================
   JOB
   ===================================================================== */
.job-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);max-width:820px;margin-inline:auto}
.job-card__head{background:var(--forest);color:var(--paper);padding:clamp(1.5rem,3vw,2.4rem)}
.job-card__head .tag{color:var(--leaf);font-size:.75rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600}
.job-card__head h2{color:var(--paper);margin-top:.6rem;font-size:clamp(1.6rem,1.3rem + 1.5vw,2.3rem)}
.job-card__body{padding:clamp(1.5rem,3vw,2.4rem)}
.job-row{display:grid;grid-template-columns:220px 1fr;gap:1rem;padding:1.1rem 0;border-bottom:1px solid var(--line)}
.job-row:last-of-type{border:none}
.job-row dt{font-weight:600;color:var(--forest);font-size:.95rem}
.job-row dd{color:var(--muted);font-size:.98rem}
@media (max-width:600px){.job-row{grid-template-columns:1fr;gap:.2rem}}

/* =====================================================================
   LEGAL / SIMPLE PAGES
   ===================================================================== */
.legal{max-width:80ch}
.legal h2{font-size:1.5rem;margin:2.4rem 0 .9rem}
.legal h3{font-family:var(--sans);font-size:1rem;font-weight:700;margin:1.6rem 0 .4rem;color:var(--forest)}
.legal p,.legal li{color:#3a382f;line-height:1.7}
.legal p+p{margin-top:.9rem}
.legal ul{list-style:disc;padding-left:1.3rem;margin-top:.6rem;display:grid;gap:.35rem}
.legal a{color:var(--forest);text-decoration:underline;text-underline-offset:2px}
.legal dl{display:grid;grid-template-columns:200px 1fr;gap:.5rem 1.5rem;margin-top:1rem}
.legal dt{font-weight:600;color:var(--forest)}
@media (max-width:560px){.legal dl{grid-template-columns:1fr;gap:.1rem 0}.legal dd{margin-bottom:.7rem}}

/* sitemap */
.sitemap-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
@media (max-width:760px){.sitemap-cols{grid-template-columns:1fr 1fr}}
@media (max-width:480px){.sitemap-cols{grid-template-columns:1fr}}
.sitemap-cols h3{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--moss);margin-bottom:1rem;font-family:var(--sans);font-weight:600}
.sitemap-cols a{display:block;padding:.4rem 0;color:var(--muted);border-bottom:1px solid var(--line);transition:color .3s,padding .3s}
.sitemap-cols a:hover{color:var(--forest);padding-left:.3rem}

/* =====================================================================
   FOOTER
   ===================================================================== */
.footer{background:var(--ink);color:rgba(246,242,233,.72);padding-block:clamp(3.5rem,6vw,5rem) 2rem}
.footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:2.5rem}
@media (max-width:900px){.footer__top{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.footer__top{grid-template-columns:1fr}}
.footer__brand{display:flex;align-items:center;gap:.8rem;margin-bottom:1.2rem}
.footer__brand img{width:52px;height:52px;object-fit:contain}
.footer__brand b{font-family:var(--serif);font-size:1.3rem;color:var(--paper);font-weight:500;line-height:1.1}
.footer__brand span{font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--leaf)}
.footer p{font-size:.9rem;line-height:1.65;max-width:34ch}
.footer h4{font-family:var(--sans);font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;color:var(--leaf);margin-bottom:1.1rem;font-weight:600}
.footer__links a{display:block;padding:.32rem 0;font-size:.92rem;transition:color .3s,padding .3s}
.footer__links a:hover{color:var(--paper);padding-left:.3rem}
.footer__contact a{display:flex;gap:.7rem;align-items:center;padding:.35rem 0;font-size:.92rem;transition:color .3s}
.footer__contact a:hover{color:var(--paper)}
.footer__contact svg{width:17px;height:17px;color:var(--leaf);flex-shrink:0}
.footer__social{display:flex;gap:.6rem;margin-top:1.2rem}
.footer__social a{width:40px;height:40px;border-radius:50%;border:1px solid rgba(246,242,233,.2);display:grid;place-items:center;transition:background .3s,border-color .3s,transform .3s}
.footer__social a:hover{background:var(--moss);border-color:var(--moss);transform:translateY(-3px)}
.footer__social svg{width:18px;height:18px}
.footer__bottom{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;margin-top:3rem;padding-top:1.6rem;border-top:1px solid rgba(246,242,233,.12);font-size:.82rem}
.footer__bottom nav{display:flex;gap:1.4rem;flex-wrap:wrap}
.footer__bottom a:hover{color:var(--paper)}

/* =====================================================================
   REVEAL ANIMATIONS
   ===================================================================== */
[data-reveal]{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
[data-reveal].in{opacity:1;transform:none}
[data-reveal][data-delay="1"]{transition-delay:.08s}
[data-reveal][data-delay="2"]{transition-delay:.16s}
[data-reveal][data-delay="3"]{transition-delay:.24s}
[data-reveal][data-delay="4"]{transition-delay:.32s}
[data-reveal][data-delay="5"]{transition-delay:.4s}
@media (prefers-reduced-motion:reduce){
  [data-reveal]{opacity:1;transform:none;transition:none}
  .hero__media img{animation:none;transform:none}
}

/* misc */
.bg-cream-2{background:var(--paper-2)}
.bg-card{background:var(--card)}
.divider{height:1px;background:var(--line);border:0}
.pill{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .9rem;border-radius:100px;background:var(--leaf-soft);color:var(--moss);font-size:.78rem;font-weight:600;letter-spacing:.02em}
.pill svg{width:14px;height:14px}
