/* =========================================================================
   Göllner Garten- und Landschaftsbau — Design System
   Editorial heritage-luxury: Playfair Display + Inter, pine/stone/cream
   ========================================================================= */

/* ---------- Tokens ---------- */
:root{
  --ink:#23281f;
  --ink-soft:#4c5245;
  --muted:#727a68;
  --paper:#faf8f2;
  --paper-2:#f2ede2;
  --cream:#efe9db;
  --pine:#1b3a2c;
  --pine-deep:#132a20;
  --green:#2f6b52;
  --accent:#0e7c63;      /* logo teal-green */
  --accent-deep:#0a5f4c;
  --sand:#d9cdb5;
  --gold:#a98a4e;
  --line:rgba(35,40,31,.13);
  --line-soft:rgba(35,40,31,.08);
  --on-dark:#eef2ea;
  --on-dark-soft:rgba(238,242,234,.72);

  --ff-display:"Playfair Display",Georgia,serif;
  --ff-body:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;

  --container:1240px;
  --gutter:clamp(1.25rem,4vw,3.5rem);
  --radius:2px;

  --shadow-sm:0 1px 3px rgba(20,30,22,.06),0 6px 18px rgba(20,30,22,.05);
  --shadow-md:0 10px 30px rgba(20,30,22,.10),0 30px 60px rgba(20,30,22,.08);
  --ease:cubic-bezier(.2,.6,.2,1);
}

/* ---------- Reset ---------- */
*,*::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-body);
  color:var(--ink);
  background:var(--paper);
  font-size:clamp(1rem,.97rem + .2vw,1.075rem);
  line-height:1.7;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
h1,h2,h3,h4{font-family:var(--ff-display);font-weight:500;line-height:1.12;letter-spacing:-.01em;color:var(--ink);margin:0}
p{margin:0 0 1.1em}
::selection{background:var(--accent);color:#fff}

/* ---------- Layout helpers ---------- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:clamp(4.5rem,9vw,8rem)}
.section--tight{padding-block:clamp(3rem,6vw,5rem)}
.bg-cream{background:var(--cream)}
.bg-paper2{background:var(--paper-2)}
.bg-pine{background:var(--pine);color:var(--on-dark)}
.bg-pine h1,.bg-pine h2,.bg-pine h3,.bg-pine h4{color:#fff}

/* ---------- Typography utilities ---------- */
.kicker{
  font-family:var(--ff-body);
  font-size:.74rem;font-weight:600;
  letter-spacing:.24em;text-transform:uppercase;
  color:var(--accent);
  display:inline-flex;align-items:center;gap:.7rem;margin:0 0 1.25rem;
}
.kicker::before{content:"";width:34px;height:1px;background:var(--accent);opacity:.6}
.bg-pine .kicker{color:#9ad9be}
.bg-pine .kicker::before{background:#9ad9be}
.display{font-size:clamp(2.3rem,1.4rem + 4vw,4.3rem);letter-spacing:-.02em}
.h2{font-size:clamp(1.9rem,1.3rem + 2.6vw,3.1rem)}
.h3{font-size:clamp(1.35rem,1.05rem + 1.1vw,1.85rem)}
.lead{font-size:clamp(1.1rem,1.02rem + .5vw,1.35rem);line-height:1.6;color:var(--ink-soft);font-weight:400}
.muted{color:var(--muted)}
.serif-italic{font-family:var(--ff-display);font-style:italic}
.measure{max-width:62ch}
.center{text-align:center}
.center .kicker{justify-content:center}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--accent);--fg:#fff;
  display:inline-flex;align-items:center;justify-content:center;gap:.6rem;
  padding:.95rem 1.9rem;min-height:48px;
  font-family:var(--ff-body);font-size:.82rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  background:var(--bg);color:var(--fg);border:1px solid var(--bg);
  border-radius:var(--radius);cursor:pointer;
  transition:transform .3s var(--ease),background .3s var(--ease),color .3s var(--ease),border-color .3s var(--ease),box-shadow .3s var(--ease);
}
.btn:hover{background:var(--accent-deep);border-color:var(--accent-deep);transform:translateY(-2px);box-shadow:0 12px 26px rgba(14,124,99,.28)}
.btn svg{width:16px;height:16px}
.btn--ghost{--bg:transparent;--fg:var(--ink);border-color:var(--line)}
.btn--ghost:hover{background:var(--ink);color:#fff;border-color:var(--ink);box-shadow:none}
.btn--light{--bg:transparent;--fg:#fff;border-color:rgba(255,255,255,.5)}
.btn--light:hover{background:#fff;color:var(--pine);border-color:#fff;box-shadow:none}
.btn--lg{padding:1.1rem 2.4rem}

.link-arrow{
  display:inline-flex;align-items:center;gap:.55rem;
  font-weight:600;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);
  transition:gap .3s var(--ease),color .3s var(--ease);
}
.link-arrow svg{width:15px;height:15px;transition:transform .3s var(--ease)}
.link-arrow:hover{gap:.9rem;color:var(--accent-deep)}
.link-arrow:hover svg{transform:translateX(4px)}
.bg-pine .link-arrow{color:#9ad9be}

/* ---------- Header ---------- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  transition:background .4s var(--ease),box-shadow .4s var(--ease),border-color .4s var(--ease);
  border-bottom:1px solid transparent;
}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;height:84px;transition:height .4s var(--ease)}
.brand{display:flex;align-items:center;gap:.75rem;z-index:2}
.brand img{height:38px;width:auto;transition:height .4s var(--ease),filter .4s var(--ease)}
.brand__tag{font-family:var(--ff-body);font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--on-dark-soft);white-space:nowrap}

/* transparent over hero */
.site-header--transparent{background:transparent}
.site-header--transparent .nav__link{color:var(--on-dark)}
.site-header--transparent .brand img{filter:brightness(0) invert(1)}
.site-header--transparent .nav__toggle span{background:#fff}
.site-header--transparent .brand__tag{color:var(--on-dark-soft)}

/* scrolled / solid */
.site-header.is-solid{background:rgba(250,248,242,.92);backdrop-filter:blur(10px);border-color:var(--line);box-shadow:0 1px 0 var(--line-soft)}
.site-header.is-solid .site-header__inner{height:70px}
.site-header.is-solid .nav__link{color:var(--ink)}
.site-header.is-solid .brand img{filter:none;height:34px}
.site-header.is-solid .brand__tag{color:var(--muted)}
.site-header.is-solid .nav__toggle span{background:var(--ink)}

.nav{display:flex;align-items:center;gap:2rem}
.nav__list{display:flex;align-items:center;gap:1.9rem;list-style:none;margin:0;padding:0}
.nav__link{
  position:relative;font-size:.83rem;font-weight:500;letter-spacing:.04em;padding:.4rem 0;
  transition:color .25s var(--ease);white-space:nowrap;
}
.nav__link::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1.5px;background:var(--accent);transition:width .3s var(--ease)}
.nav__link:hover::after,.nav__link.is-active::after{width:100%}
.nav__link.is-active{color:var(--accent)}
.site-header--transparent .nav__link.is-active{color:#fff}
.site-header--transparent .nav__link.is-active::after{background:#fff}

.nav__toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;background:none;border:0;cursor:pointer;z-index:2}
.nav__toggle span{width:24px;height:2px;background:var(--ink);transition:transform .35s var(--ease),opacity .3s var(--ease)}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;color:#fff;overflow:hidden}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media img{width:100%;height:100%;object-fit:cover;transform:scale(1.06)}
.hero__media::after{content:"";position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(15,28,20,.42) 0%,rgba(15,28,20,.12) 34%,rgba(15,28,20,.55) 100%)}
.hero__inner{position:relative;z-index:1;width:100%;padding-bottom:clamp(3.5rem,7vw,6rem);padding-top:8rem}
.hero__eyebrow{
  font-size:.76rem;font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.85);
  display:flex;align-items:center;gap:.8rem;margin-bottom:1.5rem;
}
.hero__eyebrow::before{content:"";width:42px;height:1px;background:rgba(255,255,255,.7)}
.hero__title{font-size:clamp(2.7rem,1.5rem + 5vw,5.6rem);line-height:1.04;color:#fff;font-weight:500;max-width:16ch;letter-spacing:-.02em}
.hero__title em{font-style:italic;color:#cfe8d9}
.hero__sub{max-width:52ch;font-size:clamp(1.05rem,1rem + .5vw,1.3rem);color:rgba(255,255,255,.9);margin-top:1.6rem;line-height:1.6}
.hero__actions{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2.4rem}
.hero__scroll{position:absolute;left:var(--gutter);bottom:1.6rem;z-index:1;display:flex;align-items:center;gap:.7rem;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.7)}
.hero__scroll .dot{width:1px;height:38px;background:rgba(255,255,255,.5);position:relative;overflow:hidden}
.hero__scroll .dot::after{content:"";position:absolute;top:-100%;left:0;width:100%;height:100%;background:#fff;animation:scrolldot 2.2s var(--ease) infinite}
@keyframes scrolldot{0%{top:-100%}60%,100%{top:100%}}

/* page hero (subpages) */
.pagehero{position:relative;padding-top:clamp(9rem,14vw,13rem);padding-bottom:clamp(3.5rem,7vw,6rem);color:#fff;overflow:hidden;isolation:isolate}
.pagehero__media{position:absolute;inset:0;z-index:-1}
.pagehero__media img{width:100%;height:100%;object-fit:cover}
.pagehero__media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,28,20,.5),rgba(15,28,20,.62))}
.pagehero__title{font-size:clamp(2.3rem,1.5rem + 3.6vw,4rem);color:#fff;max-width:20ch}
.pagehero .breadcrumb{margin-bottom:1.2rem}
.breadcrumb{font-size:.76rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.72);display:flex;gap:.6rem;flex-wrap:wrap}
.breadcrumb a:hover{color:#fff}
.breadcrumb span{opacity:.5}

/* ---------- Generic grid ---------- */
.grid{display:grid;gap:clamp(1.5rem,3vw,2.5rem)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.split--wide-img{grid-template-columns:1.15fr .85fr}

/* ---------- Intro / statement ---------- */
.statement{max-width:56rem}
.statement .h2{margin-bottom:1.5rem}
.dropcap::first-letter{
  font-family:var(--ff-display);float:left;font-size:4.4rem;line-height:.82;padding:.28rem .6rem 0 0;color:var(--accent);font-weight:500;
}

/* ---------- Figure ---------- */
.figure{position:relative;overflow:hidden;border-radius:var(--radius);box-shadow:var(--shadow-md)}
.figure img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease)}
.figure:hover img{transform:scale(1.045)}
.figure--tall{aspect-ratio:4/5}
.figure--land{aspect-ratio:16/10}
.figure--wide{aspect-ratio:16/7}
.figure__cap{position:absolute;left:0;bottom:0;padding:1rem 1.2rem;color:#fff;font-size:.8rem;letter-spacing:.05em;background:linear-gradient(0deg,rgba(15,28,20,.7),transparent);width:100%}

/* ---------- Service cards (homepage) ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.25rem,2.4vw,2rem)}
.svc{position:relative;display:block;overflow:hidden;border-radius:var(--radius);isolation:isolate;background:var(--pine);min-height:340px}
.svc img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;transition:transform 1.1s var(--ease),opacity .5s;opacity:.92}
.svc::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,28,20,.05) 25%,rgba(15,28,20,.8));z-index:1;transition:background .4s}
.svc:hover img{transform:scale(1.06);opacity:1}
.svc:hover::after{background:linear-gradient(180deg,rgba(15,28,20,.12) 10%,rgba(12,42,30,.86))}
.svc__body{position:relative;z-index:2;height:100%;display:flex;flex-direction:column;justify-content:flex-end;padding:1.6rem;color:#fff}
.svc__num{font-size:.72rem;letter-spacing:.2em;color:rgba(255,255,255,.72);margin-bottom:.5rem}
.svc__title{font-size:1.4rem;color:#fff;margin-bottom:.35rem}
.svc__title--sm{font-size:1.2rem}
.svc__desc{font-size:.92rem;color:rgba(255,255,255,.82);margin:0;max-height:0;opacity:0;overflow:hidden;transition:max-height .5s var(--ease),opacity .4s var(--ease),margin .4s}
.svc:hover .svc__desc{max-height:6rem;opacity:1;margin-top:.4rem}
.svc__go{position:absolute;top:1.4rem;right:1.4rem;z-index:2;width:40px;height:40px;border:1px solid rgba(255,255,255,.4);border-radius:50%;display:grid;place-items:center;color:#fff;transform:translateY(-6px);opacity:0;transition:opacity .4s var(--ease),transform .4s var(--ease),background .3s}
.svc:hover .svc__go{opacity:1;transform:none}
.svc__go:hover{background:#fff;color:var(--pine)}
.svc__go svg{width:16px;height:16px}

/* ---------- Feature rows (leistungen) ---------- */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.feature + .feature{margin-top:clamp(4rem,8vw,7rem)}
.feature__media{overflow:hidden;border-radius:var(--radius);box-shadow:var(--shadow-md);aspect-ratio:16/11}
.feature__media img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease)}
.feature__media:hover img{transform:scale(1.05)}
.feature:nth-child(even) .feature__text{order:-1}
.feature__index{font-family:var(--ff-display);font-size:1rem;color:var(--accent);letter-spacing:.1em;margin-bottom:1rem}
.feature ul{list-style:none;margin:1.4rem 0 0;padding:0;display:grid;gap:.7rem}
.feature ul li{position:relative;padding-left:1.7rem;color:var(--ink-soft);font-size:.98rem}
.feature ul li::before{content:"";position:absolute;left:0;top:.62em;width:8px;height:8px;border:1.5px solid var(--accent);transform:rotate(45deg)}

/* ---------- Feature band (full-width triptych) ---------- */
.band{position:relative;overflow:hidden}
.band__img{aspect-ratio:16/5;min-height:280px}
.band__img img{width:100%;height:100%;object-fit:cover}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(1.5rem,3vw,2.5rem);text-align:center}
.stat__num{font-family:var(--ff-display);font-size:clamp(2.4rem,1.6rem + 2.6vw,3.6rem);color:var(--accent);line-height:1;font-weight:500}
.bg-pine .stat__num{color:#9ad9be}
.stat__label{margin-top:.6rem;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.bg-pine .stat__label{color:var(--on-dark-soft)}

/* ---------- Timeline (Chronik) ---------- */
.timeline{position:relative;max-width:840px;margin-inline:auto}
.timeline::before{content:"";position:absolute;left:110px;top:8px;bottom:8px;width:1px;background:var(--line)}
.tl{position:relative;padding-left:150px;padding-bottom:2.8rem}
.tl:last-child{padding-bottom:0}
.tl__year{position:absolute;left:0;top:-4px;width:96px;text-align:right;font-family:var(--ff-display);font-size:1.5rem;color:var(--accent);font-weight:500}
.tl__dot{position:absolute;left:105px;top:6px;width:11px;height:11px;border-radius:50%;background:var(--paper);border:2px solid var(--accent);z-index:1}
.tl__body{color:var(--ink-soft)}
.tl__body strong{color:var(--ink);font-weight:600;display:block;margin-bottom:.2rem;font-family:var(--ff-body)}

/* ---------- Gallery (Rundgang) ---------- */
.gallery{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(.75rem,1.4vw,1.15rem);grid-auto-flow:dense}
.gallery a{position:relative;overflow:hidden;border-radius:var(--radius);display:block}
.gallery img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.gallery a::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(15,28,20,.55),transparent 55%);opacity:0;transition:opacity .4s}
.gallery a:hover img{transform:scale(1.05)}
.gallery a:hover::after{opacity:1}
.gallery figcaption{position:absolute;left:0;bottom:0;z-index:2;padding:.9rem 1rem;color:#fff;font-size:.82rem;letter-spacing:.04em;opacity:0;transform:translateY(6px);transition:opacity .4s,transform .4s}
.gallery a:hover figcaption{opacity:1;transform:none}
.g-6{grid-column:span 6}.g-4{grid-column:span 4}.g-8{grid-column:span 8}.g-12{grid-column:span 12}
.g-tall{aspect-ratio:3/4}.g-land{aspect-ratio:3/2}.g-wide{aspect-ratio:2/1}

/* ---------- Botanik / product cards ---------- */
.prod{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.prod:hover{transform:translateY(-5px);box-shadow:var(--shadow-md)}
.prod__media{aspect-ratio:4/3;overflow:hidden}
.prod__media img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.prod:hover .prod__media img{transform:scale(1.06)}
.prod__body{padding:1.6rem}
.prod__body h3{font-size:1.3rem;margin-bottom:.5rem}

/* ---------- Quote ---------- */
.quote{max-width:900px;margin-inline:auto;text-align:center}
.quote blockquote{font-family:var(--ff-display);font-size:clamp(1.5rem,1.1rem + 1.9vw,2.5rem);line-height:1.3;font-style:italic;color:var(--ink);margin:0}
.bg-pine .quote blockquote{color:#fff}
.quote cite{display:block;margin-top:1.6rem;font-family:var(--ff-body);font-style:normal;font-size:.82rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.bg-pine .quote cite{color:var(--on-dark-soft)}
.quote__mark{font-family:var(--ff-display);font-size:4rem;color:var(--accent);line-height:.4;opacity:.5}

/* ---------- Values ---------- */
.value{padding:2rem 0}
.value + .value{border-top:1px solid var(--line)}
.value__row{display:grid;grid-template-columns:80px 1fr;gap:1.5rem;align-items:start}
.value__ico{width:52px;height:52px;border:1px solid var(--accent);border-radius:50%;display:grid;place-items:center;color:var(--accent)}
.value__ico svg{width:24px;height:24px}
.value h3{font-size:1.4rem;margin-bottom:.5rem}

/* ---------- Contact ---------- */
.info-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(1.6rem,3vw,2.4rem)}
.info-row{display:flex;gap:1rem;padding:1.1rem 0}
.info-row + .info-row{border-top:1px solid var(--line-soft)}
.info-row__ico{flex:none;width:42px;height:42px;border-radius:50%;background:var(--cream);color:var(--accent);display:grid;place-items:center}
.info-row__ico svg{width:19px;height:19px}
.info-row h4{font-family:var(--ff-body);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin:0 0 .25rem;font-weight:600}
.info-row p{margin:0;color:var(--ink)}
.info-row a:hover{color:var(--accent)}

.hours{list-style:none;margin:0;padding:0}
.hours li{display:flex;justify-content:space-between;gap:1rem;padding:.6rem 0;border-bottom:1px solid var(--line-soft);font-size:.95rem}
.hours li:last-child{border-bottom:0}
.hours .d{color:var(--ink-soft)}
.hours .t{color:var(--ink);font-weight:500}

/* Form */
.form{display:grid;gap:1.25rem}
.form__grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
.field{display:flex;flex-direction:column;gap:.45rem}
.field label{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600;color:var(--ink-soft)}
.field label .req{color:var(--accent)}
.field input,.field textarea{
  font-family:inherit;font-size:1rem;color:var(--ink);
  padding:.85rem 1rem;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  transition:border-color .25s,box-shadow .25s;width:100%;
}
.field textarea{min-height:150px;resize:vertical}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(14,124,99,.12)}
.form__note{font-size:.82rem;color:var(--muted)}
.form__ok{display:none;padding:1rem 1.2rem;background:rgba(14,124,99,.1);border:1px solid rgba(14,124,99,.35);border-radius:var(--radius);color:var(--accent-deep);font-size:.95rem}
.form__ok.is-visible{display:block}

/* ---------- CTA band ---------- */
.cta{position:relative;overflow:hidden;isolation:isolate;text-align:center;color:#fff}
.cta__media{position:absolute;inset:0;z-index:-1}
.cta__media img{width:100%;height:100%;object-fit:cover}
.cta__media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(19,42,32,.86),rgba(19,42,32,.9))}

/* ---------- Footer ---------- */
.footer{background:var(--pine-deep);color:var(--on-dark-soft);padding-block:clamp(3.5rem,6vw,5rem) 2rem}
.footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:clamp(2rem,4vw,3rem)}
.footer h4{font-family:var(--ff-body);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:#fff;margin:0 0 1.2rem;font-weight:600}
.footer__brand img{height:40px;margin-bottom:1.2rem;filter:brightness(0) invert(1)}
.footer__list{list-style:none;margin:0;padding:0;display:grid;gap:.7rem}
.footer__list a,.footer address a{color:var(--on-dark-soft);font-size:.92rem;transition:color .25s;font-style:normal}
.footer__list a:hover,.footer address a:hover{color:#fff}
.footer address{font-style:normal;font-size:.92rem;line-height:1.9;color:var(--on-dark-soft)}
.footer__social{display:flex;gap:.75rem;margin-top:1.2rem}
.footer__social a{width:40px;height:40px;border:1px solid rgba(255,255,255,.22);border-radius:50%;display:grid;place-items:center;transition:background .3s,border-color .3s}
.footer__social a:hover{background:var(--accent);border-color:var(--accent)}
.footer__social svg{width:18px;height:18px;color:#fff}
.footer__bottom{margin-top:clamp(2.5rem,4vw,3.5rem);padding-top:1.6rem;border-top:1px solid rgba(255,255,255,.12);display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.82rem}
.footer__bottom a:hover{color:#fff}
.footer__legal{display:flex;gap:1.4rem;flex-wrap:wrap}

/* ---------- Legal / prose ---------- */
.legal{max-width:760px;margin-inline:auto}
.legal h2{font-size:clamp(1.4rem,1.1rem + 1.2vw,1.9rem);margin:2.6rem 0 1rem}
.legal h2:first-child{margin-top:0}
.legal h3{font-size:1.15rem;margin:1.8rem 0 .6rem;font-family:var(--ff-body);font-weight:600}
.legal p,.legal address{color:var(--ink-soft);margin:0 0 1rem;font-style:normal}
.legal a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}
.legal a:hover{color:var(--accent-deep)}
.legal ul{margin:0 0 1.2rem;padding-left:1.2rem;color:var(--ink-soft)}
.legal ul li{margin-bottom:.4rem}
.legal strong{color:var(--ink)}

/* ---------- Reveal animations ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.is-in{opacity:1;transform:none}
.reveal[data-delay="1"]{transition-delay:.08s}
.reveal[data-delay="2"]{transition-delay:.16s}
.reveal[data-delay="3"]{transition-delay:.24s}
.reveal[data-delay="4"]{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .hero__media img,.figure img,.svc img,.feature__media img,.prod__media img,.gallery img{transition:none}
  .hero__scroll .dot::after{animation:none}
}

/* ---------- Responsive ---------- */
@media (max-width:1024px){
  .footer__top{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:repeat(2,1fr);gap:2.5rem 1.5rem}
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .grid-4{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:860px){
  .nav__toggle{display:flex}
  .nav{
    position:fixed;inset:0 0 0 auto;width:min(86vw,360px);
    background:var(--pine-deep);flex-direction:column;justify-content:center;align-items:flex-start;
    padding:5rem var(--gutter) 3rem;gap:0;
    transform:translateX(100%);transition:transform .45s var(--ease);box-shadow:var(--shadow-md);
  }
  .nav.is-open{transform:none}
  .nav__list{flex-direction:column;align-items:flex-start;gap:0;width:100%}
  .nav__list li{width:100%}
  .nav__link{display:block;width:100%;padding:1rem 0;color:var(--on-dark)!important;font-size:1.05rem;border-bottom:1px solid rgba(255,255,255,.1)}
  .nav__link::after{display:none}
  .nav__cta{margin-top:1.6rem}
  .site-header--transparent .nav__toggle span,.is-solid .nav__toggle span{background:var(--ink)}
  .nav-open .nav__toggle span{background:#fff!important}
  .nav-open .nav__toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-open .nav__toggle span:nth-child(2){opacity:0}
  .nav-open .nav__toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  body.nav-open{overflow:hidden}
}
@media (max-width:760px){
  .split,.feature,.value__row{grid-template-columns:1fr;gap:2rem}
  .split--wide-img{grid-template-columns:1fr}
  .feature:nth-child(even) .feature__text{order:0}
  .grid-2,.grid-3{grid-template-columns:1fr}
  .svc-grid{grid-template-columns:1fr}
  .svc{min-height:300px}
  .svc__desc{max-height:6rem;opacity:1;margin-top:.4rem}
  .svc__go{opacity:1;transform:none}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .g-6,.g-4,.g-8,.g-12{grid-column:span 1}
  .g-tall,.g-land,.g-wide{aspect-ratio:3/2}
  .timeline::before{left:60px}
  .tl{padding-left:84px}
  .tl__year{width:52px;font-size:1.1rem}
  .tl__dot{left:55px}
  .form__grid{grid-template-columns:1fr}
  .footer__top{grid-template-columns:1fr}
  .footer__bottom{flex-direction:column}
  .value__row{grid-template-columns:1fr}
}
@media (max-width:420px){
  .gallery{grid-template-columns:1fr}
}
