:root {
  --paper:      #ebe4d4;   /* dominant warm beige */
  --paper-lite: #f3eee2;
  --paper-deep: #e2d8c3;   /* subtle panel */
  --ink:        #1c1e1a;   /* warm near-black */
  --ink-soft:   #43463d;
  --muted:      #71746a;
  --accent:     #2e5446;   /* deep pine */
  --accent-soft:#5e8073;
  --line:       rgba(28,30,26,0.14);
  --line-soft:  rgba(28,30,26,0.08);
  --dark:       #18211c;   /* deep pine-charcoal */
  --dark-2:     #1f2a23;
  --on-dark:    #eae0cc;
  --on-dark-dim:rgba(234,224,204,0.62);
  --on-dark-faint:rgba(234,224,204,0.40);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: 'Hanken Grotesk', system-ui, sans-serif;
  background: var(--paper);
  color: var(--ink-soft);
  line-height: 1.65; font-weight: 300;
  overflow-x: hidden; -webkit-font-smoothing: antialiased;
}
::selection { background: var(--accent); color: var(--paper-lite); }

/* ── TYPE ── */
.serif { font-family: 'Cormorant Garamond', Georgia, serif; }
h1, h2, h3 { font-family: 'Cormorant Garamond', Georgia, serif; font-weight: 300; line-height: 1.06; color: var(--ink); letter-spacing: -0.005em; }
h2 { font-size: clamp(2.1rem, 4.6vw, 3.7rem); }
h3 { font-weight: 400; }
.em { color: var(--accent); }            /* upright emphasis — no italics */
.lead { font-size: clamp(1.02rem, 1.4vw, 1.18rem); color: var(--ink-soft); line-height: 1.75; font-weight: 300; }

.kicker {
  font-family: 'Hanken Grotesk', sans-serif; font-weight: 500;
  font-size: 0.72rem; letter-spacing: 0.24em; text-transform: uppercase;
  color: var(--accent); display: inline-block;
}
.num {
  font-family: 'Cormorant Garamond', serif; font-weight: 400;
  font-size: 1.1rem; color: var(--accent-soft);
}

/* ── LAYOUT ── */
section { padding: clamp(5rem, 9vw, 9rem) 7vw; position: relative; }
.wrap { max-width: 1200px; margin: 0 auto; }
.head { max-width: 820px; }
.head .kicker { margin-bottom: 1.4rem; }
.head h2 { margin-bottom: 1.4rem; }
.rule { height: 1px; background: var(--line); width: 100%; }
a { color: inherit; }

/* ── NAV ── */
nav {
  position: fixed; inset: 0 0 auto 0; z-index: 100;
  display: flex; align-items: center; justify-content: space-between;
  padding: 1.35rem 7vw;
  background: rgba(235,228,212,0.92); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line);
  transition: background .4s ease, padding .4s ease, border-color .4s ease;
}
nav.transparent { background: transparent; border-bottom-color: transparent; }
nav.transparent.scrolled { background: rgba(235,228,212,0.92); border-bottom-color: var(--line); padding-top: .95rem; padding-bottom: .95rem; }
.logo { font-family:'Cormorant Garamond',serif; font-size: 1.6rem; font-weight: 600; letter-spacing: .16em; color: var(--ink); text-decoration: none; }
.logo b { color: var(--accent); font-weight: 600; }
.nav-links { display: flex; gap: 2rem; list-style: none; }
.nav-links a { font-size: .76rem; letter-spacing: .12em; text-transform: uppercase; font-weight: 500; color: var(--ink-soft); text-decoration: none; transition: color .2s; padding-bottom: 2px; border-bottom: 1px solid transparent; }
.nav-links a:hover { color: var(--accent); }
.nav-links a.active { color: var(--accent); border-bottom-color: var(--accent); }
.nav-cta { font-size: .74rem; letter-spacing: .1em; text-transform: uppercase; font-weight: 500; color: var(--ink); text-decoration: none; padding: .6rem 1.3rem; border: 1px solid var(--accent); transition: background .25s, color .25s; }
.nav-cta:hover { background: var(--accent); color: var(--paper-lite); }

/* ── BUTTONS / LINKS ── */
.btn { font-size: .78rem; letter-spacing: .1em; text-transform: uppercase; font-weight: 500; padding: 1rem 2rem; text-decoration: none; display: inline-flex; align-items: center; gap: .6rem; transition: transform .2s, background .25s, border-color .25s, color .25s; }
.btn-solid { background: var(--accent); color: var(--paper-lite); }
.btn-solid:hover { background: var(--ink); transform: translateY(-2px); }
.btn-line { border: 1px solid var(--line); color: var(--ink); }
.btn-line:hover { border-color: var(--accent); color: var(--accent); transform: translateY(-2px); }
.arrow-link { text-decoration: none; font-weight: 500; font-size: .82rem; letter-spacing: .08em; text-transform: uppercase; color: var(--accent); display: inline-flex; align-items: center; gap: .5rem; transition: gap .25s; }
.arrow-link:hover { gap: .9rem; }

/* ── HOME HERO ── */
#hero { min-height: 100vh; display: flex; flex-direction: column; justify-content: center; padding: 9rem 7vw 4rem; background: var(--paper); }
.hero-inner { max-width: 1080px; }
#hero .kicker { margin-bottom: 2rem; }
#hero h1 { font-size: clamp(2.9rem, 7.5vw, 6.2rem); font-weight: 300; color: var(--ink); margin-bottom: 2rem; max-width: 14ch; }
.hero-sub { font-size: clamp(1.05rem, 1.6vw, 1.32rem); color: var(--ink-soft); line-height: 1.7; max-width: 60ch; font-weight: 300; margin-bottom: 2.8rem; }
.hero-actions { display: flex; gap: 1.2rem; flex-wrap: wrap; align-items: center; }
.hero-facts { display: flex; flex-wrap: wrap; gap: 0; margin-top: clamp(3.5rem, 8vw, 6rem); border-top: 1px solid var(--line); }
.fact { padding: 1.6rem 2.4rem 1.6rem 0; border-right: 1px solid var(--line); margin-right: 2.4rem; }
.fact:last-child { border-right: none; margin-right: 0; }
.fact .ft { font-family:'Cormorant Garamond',serif; font-size: 1.5rem; color: var(--ink); line-height: 1.1; }
.fact .fl { font-size: .68rem; letter-spacing: .16em; text-transform: uppercase; color: var(--muted); margin-top: .4rem; font-weight: 500; }

/* ── SUB-PAGE HERO ── */
.page-hero { padding: clamp(9rem, 16vw, 12rem) 7vw clamp(3rem, 6vw, 4.5rem); background: var(--paper); border-bottom: 1px solid var(--line); }
.page-hero .kicker { margin-bottom: 1.4rem; }
.page-hero h1 { font-size: clamp(2.6rem, 6vw, 4.6rem); font-weight: 300; color: var(--ink); margin-bottom: 1.4rem; max-width: 18ch; }
.page-hero .lead { max-width: 64ch; }
.crumb { font-size: .68rem; letter-spacing: .16em; text-transform: uppercase; font-weight: 500; color: var(--muted); margin-bottom: 1.6rem; }
.crumb a { color: var(--muted); text-decoration: none; }
.crumb a:hover { color: var(--accent); }

/* ── HOME OVERVIEW GRID ── */
.ov-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border-top: 1px solid var(--line); }
.ov { display: block; text-decoration: none; padding: 2.3rem 2.2rem 2.5rem; border-bottom: 1px solid var(--line); border-right: 1px solid var(--line); transition: background .3s; }
.ov-grid .ov:nth-child(3n) { border-right: none; }
.ov:hover { background: var(--paper-lite); }
.ov .num { display: block; margin-bottom: 1.1rem; }
.ov h3 { font-size: 1.55rem; margin-bottom: .65rem; color: var(--ink); }
.ov p { font-size: .92rem; color: var(--ink-soft); line-height: 1.66; font-weight: 300; }
.ov .more { display: inline-block; margin-top: 1.1rem; font-size: .72rem; letter-spacing: .12em; text-transform: uppercase; font-weight: 500; color: var(--accent); }

/* ── EDITORIAL GRID ── */
.egrid { display: grid; margin-top: 3.4rem; border-top: 1px solid var(--line); }
.egrid.cols-3 { grid-template-columns: repeat(3, 1fr); }
.egrid.cols-2 { grid-template-columns: repeat(2, 1fr); }
.ecell { padding: 2.3rem 2.2rem 2.5rem; border-bottom: 1px solid var(--line); border-right: 1px solid var(--line); transition: background .3s; }
.egrid.cols-3 .ecell:nth-child(3n), .egrid.cols-2 .ecell:nth-child(2n) { border-right: none; padding-right: 0; }
.egrid.cols-3 .ecell:nth-child(3n+1), .egrid.cols-2 .ecell:nth-child(2n+1) { padding-left: 0; }
.ecell:hover { background: var(--paper-lite); }
.ecell .num { display: block; margin-bottom: 1.1rem; }
.ecell h3 { font-size: 1.55rem; margin-bottom: .65rem; color: var(--ink); }
.ecell p { font-size: .92rem; color: var(--ink-soft); line-height: 1.66; font-weight: 300; }
.ecell .tags { display: flex; flex-wrap: wrap; gap: .4rem; margin-top: 1.1rem; }
.tag { font-size: .62rem; letter-spacing: .1em; text-transform: uppercase; font-weight: 500; color: var(--accent); border: 1px solid var(--line); padding: .28rem .6rem; }

/* ── PHILOSOPHY ── */
.phil-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: clamp(2.5rem, 6vw, 6rem); align-items: start; margin-top: 1rem; }
.phil-body p { font-size: 1.04rem; line-height: 1.85; color: var(--ink-soft); margin-bottom: 1.3rem; font-weight: 300; }
.phil-body strong { font-weight: 500; color: var(--ink); }
.phil-points { margin-top: 2.2rem; display: grid; gap: 0; }
.ppt { padding: 1.3rem 0; border-top: 1px solid var(--line); display: grid; grid-template-columns: auto 1fr; gap: 1.4rem; align-items: baseline; }
.ppt:last-child { border-bottom: 1px solid var(--line); }
.ppt .pt { font-weight: 500; color: var(--ink); font-size: .92rem; letter-spacing: .02em; }
.ppt .pd { font-size: .9rem; color: var(--muted); line-height: 1.6; }
.phil-aside { position: sticky; top: 7rem; border-left: 2px solid var(--accent); padding-left: 1.8rem; }
.phil-aside .q { font-family:'Cormorant Garamond',serif; font-weight: 300; font-size: clamp(1.5rem, 2.6vw, 2.05rem); line-height: 1.4; color: var(--ink); margin-bottom: 1.4rem; }
.phil-aside .src { font-size: .7rem; letter-spacing: .18em; text-transform: uppercase; font-weight: 500; color: var(--accent); }
.phil-aside .ex { margin-top: 1.8rem; padding-top: 1.6rem; border-top: 1px solid var(--line); font-size: .9rem; color: var(--ink-soft); line-height: 1.7; }
.phil-aside .ex b { color: var(--accent); font-weight: 600; }

/* ── NOTE BANNER ── */
.note { margin-top: 1.4rem; padding: 1.1rem 1.4rem; border: 1px solid var(--line); background: var(--paper-lite); font-size: .92rem; color: var(--ink-soft); max-width: 820px; }
.note b { color: var(--accent); font-weight: 600; }

/* ── EPC TIMELINE ── */
.epc-track { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; margin-top: 3.2rem; }
.epc-step { padding: 2.2rem 1.4rem 1.6rem 0; border-top: 2px solid var(--line); position: relative; }
.epc-step::before { content:''; position: absolute; top: -2px; left: 0; height: 2px; width: 38px; background: var(--accent); }
.epc-step .en { font-family:'Cormorant Garamond',serif; font-size: 1rem; color: var(--accent-soft); }
.epc-step h3 { font-size: 1.3rem; margin: .5rem 0 .4rem; color: var(--ink); }
.epc-step p { font-size: .84rem; color: var(--muted); line-height: 1.55; font-weight: 300; }
.epc-banner { margin-top: 3.4rem; padding-top: 2.4rem; border-top: 1px solid var(--line); display: flex; align-items: baseline; justify-content: space-between; gap: 1.5rem; flex-wrap: wrap; }
.epc-banner .bt { font-family:'Cormorant Garamond',serif; font-size: clamp(1.5rem, 3vw, 2.3rem); font-weight: 300; color: var(--ink); max-width: 24ch; }
.epc-banner .bs { font-size: .72rem; letter-spacing: .18em; text-transform: uppercase; font-weight: 500; color: var(--accent); }

/* ── KENOP (dark) ── */
.dark { background: var(--dark); color: var(--on-dark); }
.dark h2 { color: var(--on-dark); }
.dark .kicker { color: var(--accent-soft); }
.kenop-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2.5rem, 6vw, 6rem); align-items: center; }
.kenop-grid .lead { color: var(--on-dark-dim); }
.kenop-tag { font-family:'Cormorant Garamond',serif; font-size: 1.15rem; color: var(--accent-soft); margin-bottom: 1rem; }
.kenop-list { display: grid; gap: 0; }
.kl { padding: 1.3rem 0; border-top: 1px solid rgba(234,224,204,0.14); display: grid; grid-template-columns: auto 1fr; gap: 1.3rem; align-items: baseline; }
.kl:last-of-type { border-bottom: 1px solid rgba(234,224,204,0.14); }
.kl .kn { font-family:'Cormorant Garamond',serif; color: var(--accent-soft); font-size: 1rem; }
.kl .kt { font-weight: 500; color: var(--on-dark); font-size: .96rem; }
.kl .kd { font-size: .86rem; color: var(--on-dark-dim); line-height: 1.6; margin-top: .2rem; }
.kenop-foot { margin-top: 2rem; font-size: .8rem; color: var(--on-dark-faint); letter-spacing: .04em; }

/* ── SERVICES ── */
.svc-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; margin-top: 3.2rem; border-top: 1px solid var(--line); }
.svc { padding: 2rem 2rem 2.2rem; border-bottom: 1px solid var(--line); border-right: 1px solid var(--line); }
.svc-grid .svc:nth-child(3n) { border-right: none; padding-right: 0; }
.svc-grid .svc:nth-child(3n+1) { padding-left: 0; }
.svc .num { display: block; margin-bottom: .9rem; }
.svc h3 { font-size: 1.4rem; margin-bottom: .4rem; color: var(--ink); }
.svc p { font-size: .9rem; color: var(--muted); line-height: 1.6; font-weight: 300; }

/* ── PLANT ── */
.plant-grid { display: grid; grid-template-columns: .92fr 1.08fr; gap: clamp(2.5rem, 6vw, 5.5rem); align-items: center; }
.plant-panel { background: var(--dark); color: var(--on-dark); padding: clamp(2.2rem, 4vw, 3.2rem); min-height: 340px; display: flex; flex-direction: column; justify-content: space-between; }
.plant-panel .pk { font-size: .68rem; letter-spacing: .2em; text-transform: uppercase; color: var(--accent-soft); font-weight: 500; }
.plant-panel .pv { font-family:'Cormorant Garamond',serif; font-size: clamp(2rem, 3.4vw, 3rem); font-weight: 300; line-height: 1.12; margin-top: 1.2rem; }
.plant-panel .pm { display: flex; gap: 2.6rem; margin-top: auto; padding-top: 2.4rem; flex-wrap: wrap; }
.pm .n { font-family:'Cormorant Garamond',serif; font-size: 1.4rem; color: var(--accent-soft); }
.pm .l { font-size: .62rem; letter-spacing: .16em; text-transform: uppercase; color: var(--on-dark-faint); margin-top: .3rem; font-weight: 500; }
.plant-body p { font-size: 1.02rem; line-height: 1.8; color: var(--ink-soft); margin-bottom: 1.1rem; font-weight: 300; }

/* ── CONTACT ── */
.contact-grid { display: grid; grid-template-columns: .8fr 1.2fr; gap: clamp(2.5rem, 6vw, 6rem); align-items: start; }
.ci { padding: 1.4rem 0; border-top: 1px solid var(--line); }
.ci:last-of-type { border-bottom: 1px solid var(--line); }
.ci .cl { font-size: .66rem; letter-spacing: .18em; text-transform: uppercase; font-weight: 500; color: var(--accent); margin-bottom: .4rem; }
.ci .cv { font-size: 1.02rem; color: var(--ink); font-weight: 300; line-height: 1.5; }
.ci .cv a { text-decoration: none; transition: color .2s; }
.ci .cv a:hover { color: var(--accent); }
.form { display: grid; grid-template-columns: 1fr 1fr; gap: 1.1rem; }
.fg { display: flex; flex-direction: column; gap: .45rem; }
.fg.full { grid-column: 1 / -1; }
label { font-size: .64rem; letter-spacing: .16em; text-transform: uppercase; font-weight: 500; color: var(--accent); }
input, select, textarea {
  background: var(--paper-lite); border: 1px solid var(--line); color: var(--ink);
  padding: .9rem 1rem; font-family: 'Hanken Grotesk', sans-serif; font-size: .95rem; font-weight: 300;
  outline: none; transition: border-color .2s, background .2s; width: 100%; border-radius: 0;
}
input::placeholder, textarea::placeholder { color: var(--muted); }
input:focus, select:focus, textarea:focus { border-color: var(--accent); background: #fff; }
textarea { resize: vertical; min-height: 120px; }
.btn-submit {
  grid-column: 1 / -1; background: var(--accent); color: var(--paper-lite); border: none; cursor: pointer;
  font-family: 'Hanken Grotesk', sans-serif; font-size: .78rem; letter-spacing: .1em; text-transform: uppercase; font-weight: 500;
  padding: 1.1rem; transition: background .25s, transform .2s; margin-top: .2rem;
}
.btn-submit:hover { background: var(--ink); transform: translateY(-2px); }

/* ── CTA BAND ── */
.cta-band { background: var(--paper-deep); border-top: 1px solid var(--line); }
.cta-inner { display: flex; align-items: center; justify-content: space-between; gap: 2rem; flex-wrap: wrap; }
.cta-inner h2 { font-size: clamp(1.8rem, 3.4vw, 2.8rem); max-width: 20ch; }

/* ── FOOTER ── */
footer { background: var(--dark); color: var(--on-dark); padding: 3.4rem 7vw; }
.foot-top { display: flex; justify-content: space-between; align-items: flex-start; gap: 2.5rem; flex-wrap: wrap; }
.foot-logo { font-family:'Cormorant Garamond',serif; font-size: 1.45rem; font-weight: 600; letter-spacing: .16em; color: var(--on-dark); text-decoration: none; display: inline-block; }
.foot-logo b { color: var(--accent-soft); }
.foot-tag { font-size: .9rem; color: var(--on-dark-dim); max-width: 340px; margin-top: .7rem; line-height: 1.6; font-weight: 300; }
.foot-links { display: flex; gap: 1.8rem; flex-wrap: wrap; list-style: none; }
.foot-links a { font-size: .68rem; letter-spacing: .12em; text-transform: uppercase; font-weight: 500; color: var(--on-dark-dim); text-decoration: none; transition: color .2s; }
.foot-links a:hover { color: var(--accent-soft); }
.foot-bottom { margin-top: 2.6rem; padding-top: 1.6rem; border-top: 1px solid rgba(234,224,204,0.12); display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }
.foot-copy { font-size: .68rem; letter-spacing: .04em; color: var(--on-dark-faint); }

/* ── REVEAL ── */
.reveal { opacity: 0; transform: translateY(18px); transition: opacity .8s ease, transform .8s ease; }
.reveal.in { opacity: 1; transform: none; }

/* ── RESPONSIVE ── */
@media (max-width: 1000px) {
  .egrid.cols-3, .ov-grid { grid-template-columns: repeat(2, 1fr); }
  .egrid.cols-3 .ecell, .ov-grid .ov { border-right: 1px solid var(--line); padding-left: 2.2rem; padding-right: 2.2rem; }
  .egrid.cols-3 .ecell:nth-child(2n), .ov-grid .ov:nth-child(2n) { border-right: none; }
  .egrid.cols-3 .ecell:nth-child(3n+1) { padding-left: 2.2rem; }
  .svc-grid { grid-template-columns: repeat(2, 1fr); }
  .svc-grid .svc:nth-child(3n) { border-right: 1px solid var(--line); padding-right: 2rem; }
  .svc-grid .svc:nth-child(2n) { border-right: none; padding-right: 0; }
  .svc-grid .svc:nth-child(3n+1) { padding-left: 2rem; }
  .svc-grid .svc:nth-child(2n+1) { padding-left: 0; }
  .phil-grid, .kenop-grid, .plant-grid, .contact-grid { grid-template-columns: 1fr; }
  .phil-aside { position: static; }
  .epc-track { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 860px) { .nav-links { display: none; } }
@media (max-width: 600px) {
  .egrid.cols-3, .egrid.cols-2, .svc-grid, .ov-grid { grid-template-columns: 1fr; }
  .egrid .ecell, .svc, .ov { border-right: none !important; padding-left: 0 !important; padding-right: 0 !important; }
  .epc-track { grid-template-columns: 1fr; }
  .fact { border-right: none; margin-right: 0; padding-right: 0; }
  #hero h1, .page-hero h1 { font-size: 2.6rem; }
}
@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; scroll-behavior: auto; }
  .reveal { opacity: 1; transform: none; }
}
