*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background: #e8ede4;
  color: #1c2418;
  font-family: 'Epilogue', sans-serif;
  font-size: 15px;
  line-height: 1.5;
  overflow-x: hidden;
}
:root {
  --ink:    #1c2418;
  --ink2:   #3a4535;
  --muted:  #7a8a72;
  --bg:     #e8ede4;
  --bg2:    #d6dfd0;
  --sky:    #7cb8d4;
  --sky2:   #a8d4e8;
  --grass:  #3a6b2e;
  --grass2: #5a9448;
  --sage:   #8aab7e;
  --leaf:   #2d5223;
  --ochre:  #c8973a;
  --ochre2: #e4b85a;
  --bark:   #7a5a38;
  --cream:  #f4f0e4;
  --stone:  #c4bfb0;
  --mono:   'DM Mono', monospace;
  --display:'Unbounded', sans-serif;
  --body:   'Epilogue', sans-serif;
}

/* ========= NAV ========= */
nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 200;
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 52px; height: 58px;
  background: rgba(28,36,24,0.82);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.nav-logo {
  font-family: var(--display); font-weight: 900; font-size: 15px;
  letter-spacing: -0.02em; color: var(--cream); text-decoration: none;
}
.nav-logo sup {
  font-family: var(--mono); font-size: 8px; font-weight: 400;
  letter-spacing: 0.1em; color: var(--ochre2); vertical-align: super; margin-left: 3px;
}
.nav-right {
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: rgba(244,240,228,0.45);
}

/* ========= HERO ========= */
.hero {
  position: relative; min-height: 100vh;
  padding-top: 58px; overflow: hidden;
  display: flex; flex-direction: column; justify-content: flex-end;
}
.hero-park {
  position: absolute; inset: 0; z-index: 0;
  width: 100%; height: 100%;
}
/* overlay gradient so text reads over park */
.hero-overlay {
  position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(
    to bottom,
    rgba(28,36,24,0.08) 0%,
    rgba(28,36,24,0.0) 35%,
    rgba(28,36,24,0.55) 70%,
    rgba(28,36,24,0.88) 100%
  );
}
.hero-content {
  position: relative; z-index: 2;
  padding: 0 56px 48px;
  max-width: 820px;
}
.hero-kicker {
  font-family: var(--mono); font-size: 10px; font-weight: 400;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--ochre2); margin-bottom: 14px;
  display: flex; align-items: center; gap: 10px;
}
.hero-kicker::before { content:''; display:block; width:24px; height:1.5px; background:var(--ochre2); }
h1 {
  font-family: var(--display); font-weight: 900;
  font-size: clamp(52px, 8vw, 110px);
  line-height: 0.92; letter-spacing: -0.04em;
  color: var(--cream); margin-bottom: 18px;
}
h1 .g { color: var(--grass2); }
h1 .b { color: var(--sky2); }
.hero-sub {
  font-size: 15px; font-weight: 300;
  color: rgba(244,240,228,0.78); line-height: 1.6;
  max-width: 520px;
}
.hero-motto-top {
  position: absolute; top: 58px; left: 0; right: 0; z-index: 3;
  display: flex; align-items: baseline; gap: 20px;
  padding: 14px 56px;
  background: rgba(28,36,24,0.55);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid rgba(244,240,228,0.08);
}
.hero-motto-fi {
  font-family: var(--display); font-size: 13px; font-weight: 700;
  letter-spacing: 0.01em; color: var(--ochre2); white-space: nowrap;
}
.hero-motto-nl {
  font-family: var(--mono); font-size: 10px; font-weight: 300;
  letter-spacing: 0.06em; color: rgba(244,240,228,0.45);
  font-style: italic;
}

/* floating tags over hero */
.hero-float-tags {
  position: absolute; z-index: 2;
  top: 100px; right: 56px;
  display: flex; flex-direction: column; gap: 10px; align-items: flex-end;
}
.float-tag {
  font-family: var(--mono); font-size: 9px;
  letter-spacing: 0.12em; text-transform: uppercase;
  background: rgba(28,36,24,0.7);
  border: 1px solid rgba(255,255,255,0.15);
  color: rgba(244,240,228,0.7);
  padding: 6px 12px;
  backdrop-filter: blur(6px);
}
.float-tag.lit { background: var(--grass); color: var(--cream); border-color: transparent; }

/* ========= MARQUEE ========= */
.marquee-band {
  background: var(--leaf); border-top: 1.5px solid rgba(255,255,255,0.08);
  border-bottom: 2px solid var(--ochre);
  padding: 12px 0; overflow: hidden; white-space: nowrap; position: relative; z-index: 10;
}
.marquee-inner { display: inline-flex; animation: marquee 32s linear infinite; }
.marquee-item {
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.14em; text-transform: uppercase;
  padding: 0 30px; color: rgba(244,240,228,0.5);
}
.marquee-item.hot { color: var(--ochre2); }
@keyframes marquee { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ========= VISIE ========= */
.visie {
  background: var(--ink);
  border-bottom: 2px solid rgba(255,255,255,0.08);
}
.visie-inner { padding: 52px 56px 44px; }
.visie-top {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 48px; align-items: start;
  margin-bottom: 28px;
}
.eyebrow {
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.16em; text-transform: uppercase; margin-bottom: 14px;
  color: var(--ochre2);
}
.big-quote {
  font-family: var(--display); font-size: clamp(22px, 3vw, 40px);
  font-weight: 900; letter-spacing: -0.035em; line-height: 1.08; color: var(--cream);
}
.big-quote em { font-style: normal; color: var(--grass2); }
.big-quote-sub {
  font-size: 14px; font-weight: 300; color: var(--muted);
  line-height: 1.75; margin-top: 0; max-width: 420px;
}
.big-quote-sub p { margin-bottom: 10px; }
.big-quote-sub p:last-child { margin-bottom: 0; }
.principles {
  display: grid; grid-template-columns: repeat(4,1fr);
  border-top: 1px solid rgba(244,240,228,0.1);
}
.pr {
  padding: 16px 20px 16px 0; border-right: 1px solid rgba(244,240,228,0.1);
  display: flex; flex-direction: column; gap: 8px;
}
.pr:last-child { border-right: none; padding-right: 0; }
.pr-num { font-family: var(--mono); font-size: 10px; color: var(--ochre2); }
.pr-text { font-size: 12px; font-weight: 300; line-height: 1.6; color: rgba(244,240,228,0.6); }

/* ========= LEIDENDE PRINCIPES ========= */
.principes {
  padding: 60px 56px;
  background: var(--bg);
  border-bottom: 2px solid var(--ink);
}
.section-eyebrow { font-family: var(--mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; margin-bottom: 28px; }
.section-title { font-family: var(--display); font-size: clamp(20px,3vw,34px); font-weight: 900; letter-spacing: -0.03em; color: var(--ink); margin-bottom: 36px; }
.principes-grid { display: grid; grid-template-columns: repeat(3,1fr); border: 2px solid var(--ink); }
.pc {
  padding: 24px 20px; border-right: 2px solid var(--ink); border-bottom: 2px solid var(--ink);
  position: relative; overflow: hidden; transition: background 0.2s;
  background: var(--cream);
}
.pc:nth-child(3n) { border-right: none; }
.pc:nth-child(4),.pc:nth-child(5),.pc:nth-child(6) { border-bottom: none; }
.pc:hover { background: var(--bg2); }
.pc-stripe { position: absolute; top: 0; left: 0; width: 4px; height: 100%; }
.s1{background:var(--grass)}.s2{background:var(--ochre)}.s3{background:var(--sky)}
.s4{background:var(--leaf)}.s5{background:var(--bark)}.s6{background:var(--sage)}
.pc-icon { font-family: var(--mono); font-size: 16px; color: var(--muted); margin-bottom: 10px; margin-left: 10px; }
.pc-name { font-family: var(--display); font-size: 13px; font-weight: 700; letter-spacing: -0.02em; color: var(--ink); margin-bottom: 6px; margin-left: 10px; }
.pc-desc { font-size: 12px; font-weight: 300; color: var(--ink2); line-height: 1.6; margin-left: 10px; }

/* ========= ATELIER ========= */
.atelier {
  display: grid; grid-template-columns: 5fr 4fr;
  border-bottom: 2px solid var(--ink);
}
.atelier-left {
  padding: 64px 56px;
  background: var(--grass); color: var(--cream);
  border-right: 2px solid var(--ink);
  position: relative; overflow: hidden;
}
.atelier-left .eyebrow { color: rgba(244,240,228,0.55); }
.atelier-left h2 {
  font-family: var(--display); font-size: clamp(24px,3.5vw,44px);
  font-weight: 900; letter-spacing: -0.03em; line-height: 1.08;
  color: var(--cream); margin-bottom: 16px;
}
.atelier-left p { font-size: 14px; font-weight: 300; color: rgba(244,240,228,0.82); line-height: 1.65; margin-bottom: 12px; max-width: 460px; }
.atelier-bg-char {
  position: absolute; bottom: -50px; right: -20px;
  font-family: var(--display); font-size: 240px; font-weight: 900;
  color: rgba(255,255,255,0.06); line-height: 1;
  pointer-events: none; user-select: none; letter-spacing: -0.05em;
}
.atelier-right { padding: 64px 44px; background: var(--cream); }
.atelier-right .eyebrow { color: var(--grass); }
.atelier-right h3 {
  font-family: var(--display); font-size: 18px; font-weight: 700;
  letter-spacing: -0.02em; color: var(--ink); margin-bottom: 24px;
}
.af { display: flex; gap: 16px; align-items: flex-start; padding: 18px 0; border-bottom: 1.5px solid rgba(28,36,24,0.12); }
.af:first-of-type { border-top: 1.5px solid rgba(28,36,24,0.12); }
.af-dot { width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0; margin-top: 4px; }
.da{background:var(--grass)}.db{background:var(--sky)}.dc{background:var(--ochre)}
.af-title { font-family: var(--display); font-size: 13px; font-weight: 700; color: var(--ink); margin-bottom: 4px; }
.af-desc { font-size: 12px; font-weight: 300; color: var(--ink2); line-height: 1.6; }

/* ========= PARK STRIP ========= */
.park-strip {
  position: relative; height: 260px; overflow: hidden;
  border-bottom: 2px solid var(--ink);
}
.park-strip svg { width: 100%; height: 100%; display: block; }
.park-strip-overlay {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  gap: 48px; padding: 0 56px;
}
.park-strip-stat {
  text-align: center; color: var(--cream);
}
.park-strip-num {
  font-family: var(--display); font-size: 48px; font-weight: 900;
  line-height: 1; letter-spacing: -0.04em;
  text-shadow: 0 2px 8px rgba(28,36,24,0.5);
}
.park-strip-label {
  font-family: var(--mono); font-size: 9px; letter-spacing: 0.14em;
  text-transform: uppercase; color: rgba(244,240,228,0.7);
  margin-top: 6px;
  text-shadow: 0 1px 4px rgba(28,36,24,0.6);
}



/* ========= CONTACT ========= */
.contact {
  background: var(--ink); padding: 56px 56px;
  display: flex; align-items: center; justify-content: space-between;
  gap: 40px; flex-wrap: wrap;
}
.contact h2 {
  font-family: var(--display); font-size: clamp(28px,4.5vw,58px);
  font-weight: 900; letter-spacing: -0.04em;
  color: var(--cream); line-height: 1.0;
}
.contact h2 em { font-style: normal; color: var(--ochre2); }
.contact-link {
  font-family: var(--mono); font-size: 15px; letter-spacing: 0.04em;
  color: var(--ochre2); text-decoration: none;
  border-bottom: 1px solid var(--ochre2); padding-bottom: 2px;
  transition: color 0.2s, border-color 0.2s;
}
.contact-link:hover { color: var(--cream); border-color: var(--cream); }

/* ========= FOOTER ========= */
footer {
  background: var(--leaf); border-top: 1px solid rgba(255,255,255,0.08);
  padding: 28px 56px;
  display: flex; align-items: center; justify-content: space-between;
}
.footer-logo { font-family: var(--display); font-weight: 900; font-size: 15px; letter-spacing: -0.02em; color: rgba(244,240,228,0.45); text-decoration: none; }
.footer-copy { font-family: var(--mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(244,240,228,0.28); }

/* ========= ANIMATIONS ========= */
@keyframes fadeUp { from{opacity:0;transform:translateY(22px)} to{opacity:1;transform:translateY(0)} }
.fu  { animation: fadeUp 0.7s cubic-bezier(0.22,1,0.36,1) both; }
.d1x { animation-delay: 0.05s } .d2x { animation-delay: 0.2s }
.d3x { animation-delay: 0.35s } .d4x { animation-delay: 0.5s }

/* gentle sway on park trees */
@keyframes sway { 0%,100%{transform:rotate(-1deg)} 50%{transform:rotate(1.2deg)} }
@media(prefers-reduced-motion:no-preference){
  .tree-sway { transform-origin: bottom center; animation: sway 5s ease-in-out infinite; }
  .tree-sway-2 { transform-origin: bottom center; animation: sway 6.5s ease-in-out infinite 0.8s; }
  .tree-sway-3 { transform-origin: bottom center; animation: sway 7.2s ease-in-out infinite 1.5s; }
}

/* ========= RESPONSIVE ========= */
@media(max-width:1024px){
  nav { padding: 0 28px; }
  .hero-content { padding: 0 28px 40px; }
  .hero-float-tags { right: 28px; }
  .visie-inner { padding: 40px 28px 32px; }
  .visie-top { grid-template-columns: 1fr; gap: 16px; }
  .principles { grid-template-columns: 1fr 1fr; }
  .pr { border-right: 1px solid rgba(244,240,228,0.1); border-bottom: 1px solid rgba(244,240,228,0.1); padding: 14px 16px 14px 0; }
  .pr:nth-child(2n) { border-right: none; }
  .pr:nth-child(3),.pr:nth-child(4) { border-bottom: none; }
  .principes { padding: 44px 28px; }
  .principes-grid { grid-template-columns: 1fr 1fr; }
  .pc:nth-child(3n) { border-right: 2px solid var(--ink); }
  .pc:nth-child(2n) { border-right: none; }
  .pc:nth-child(4) { border-bottom: 2px solid var(--ink); }
  .pc:nth-child(5) { border-bottom: 2px solid var(--ink); }
  .pc:nth-child(6) { border-bottom: none; }
  .atelier { grid-template-columns: 1fr; }
  .atelier-left { border-right: none; border-bottom: 2px solid var(--ink); padding: 44px 28px; }
  .atelier-right { padding: 44px 28px; }
  .tech-strip { flex-direction: column; align-items: flex-start; gap: 16px; padding: 32px 28px; }
  .contact { padding: 44px 28px; }
  footer { padding: 20px 28px; }
}
@media(max-width:640px){
  nav { padding: 0 18px; }
  h1 { font-size: 44px; }
  .hero-content { padding: 0 18px 36px; }
  .hero-float-tags { display: none; }
  .visie-inner { padding: 32px 18px 24px; }
  .principles { grid-template-columns: 1fr 1fr; }
  .principes-grid { grid-template-columns: 1fr; }
  .pc { border-right: none !important; }
  .pc:not(:last-child) { border-bottom: 2px solid var(--ink) !important; }
  .contact { flex-direction: column; align-items: flex-start; padding: 36px 18px; }
  footer { flex-direction: column; gap: 8px; text-align: center; padding: 18px 18px; }
  .park-strip { height: 160px; }
  .park-strip-num { font-size: 32px; }
  .park-strip-overlay { gap: 20px; padding: 0 18px; }
}