:root{
  --lime:#9DE016; --green:#00A859; --ink:#1D1D1F; --ink2:#292D2B;
  --white:#FFFFFF; --mint:#F6FCEF; --hairline:rgba(29,29,31,.08);
  --maxw:1280px; --pad:clamp(20px,5vw,64px);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--white);color:var(--ink);
  font-family:"DM Sans",system-ui,-apple-system,sans-serif;font-optical-sizing:auto;
  -webkit-font-smoothing:antialiased;line-height:1.5;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit}

/* very faint grain over everything */
body::after{content:"";position:fixed;inset:0;z-index:100;pointer-events:none;opacity:.03;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

.screen-reader-text{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(1px,1px,1px,1px)}
.skip-link{position:fixed;top:-60px;left:10px;z-index:200;background:var(--ink);color:#fff;padding:10px 16px;border-radius:8px;transition:top .2s}
.skip-link:focus{top:10px}
a:focus-visible,button:focus-visible{outline:2px solid var(--green);outline-offset:3px}

/* ---------- Header ---------- */
.site-header{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;
  justify-content:space-between;padding:18px var(--pad);background:var(--white);
  border-bottom:1px solid transparent;transition:border-color .4s cubic-bezier(.4,0,.2,1)}
.site-header.scrolled{border-bottom:1px solid var(--hairline)}
/* clear the WordPress admin bar for logged-in users */
.admin-bar .site-header{top:32px}
.admin-bar .mobile-drawer{top:104px}
@media screen and (max-width:782px){
  .admin-bar .site-header{top:46px}
  .admin-bar .mobile-drawer{top:118px}
}
html{scroll-padding-top:90px}
.brand{display:inline-flex;align-items:center}
.brand img{height:30px;width:auto}
.primary-nav{display:flex;align-items:center;gap:clamp(16px,2.2vw,34px)}
.nav-links{display:flex;align-items:center;gap:clamp(16px,2.2vw,34px);list-style:none;margin:0;padding:0}
.nav-links a{text-decoration:none;font-size:15px;font-weight:500;opacity:.78;transition:opacity .3s}
.nav-links a:hover,.nav-links .current-menu-item a{opacity:1}
.cta{display:inline-block;font-family:"DM Sans";font-size:15px;font-weight:500;color:var(--white);
  background:var(--ink);border:none;border-radius:100px;padding:11px 22px;cursor:pointer;text-decoration:none;
  transition:transform .35s cubic-bezier(.34,1.56,.64,1),background .3s}
.cta:hover{background:var(--green);transform:translateY(-1px)}
.cta-lg{padding:15px 30px;font-size:16px}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:6px}
.nav-toggle span{width:24px;height:2px;background:var(--ink);display:block;transition:.3s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobile-drawer{position:fixed;inset:72px 0 auto 0;z-index:45;background:var(--white);
  border-bottom:1px solid var(--hairline);padding:18px var(--pad) 30px;
  display:flex;flex-direction:column;gap:6px}
.mobile-drawer[hidden]{display:none}
.mobile-drawer .drawer-links{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}
.mobile-drawer a{text-decoration:none;font-family:"Fraunces";font-size:26px;font-weight:500;padding:10px 0;color:var(--ink)}
.mobile-drawer .cta{align-self:flex-start;margin-top:14px;color:#fff}

/* ---------- Hero ---------- */
.site-main{display:block}
.hero{position:relative;min-height:100svh;display:grid;grid-template-columns:1.05fr .95fr;
  align-items:center;gap:30px;padding:120px var(--pad) 60px;
  background:radial-gradient(120% 90% at 78% 30%,var(--mint),var(--white) 60%)}
.hero-copy{position:relative;z-index:10;max-width:560px;will-change:transform,opacity}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:13px;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;color:var(--green);margin-bottom:24px}
.eyebrow::before{content:"";width:26px;height:1.5px;background:var(--lime)}
.hero h1{font-family:"Fraunces",serif;font-weight:500;font-size:clamp(44px,6vw,96px);line-height:.98;
  letter-spacing:-.02em;color:var(--ink);margin:0}
.hero h1 em{font-style:italic;color:var(--green);display:block;margin-top:.1em}
.hero .sub{margin-top:28px;font-size:clamp(16px,1.4vw,20px);line-height:1.55;max-width:460px;color:var(--ink2);opacity:.82}

.scroll-cue{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);z-index:10;
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink2);opacity:.4;
  display:flex;flex-direction:column;align-items:center;gap:10px}
.scroll-cue .line{width:1px;height:34px;background:linear-gradient(var(--ink2),transparent);
  animation:cue 2.4s ease-in-out infinite}
@keyframes cue{0%,100%{opacity:.2;transform:scaleY(.6)}50%{opacity:.7;transform:scaleY(1)}}

/* ---------- The Living Mark ---------- */
.mark-stage{position:relative;z-index:5;display:flex;justify-content:center;align-items:center;will-change:transform,opacity}
.mark-wrap{width:min(48vh,440px);aspect-ratio:504/448;perspective:1100px;
  filter:drop-shadow(0 34px 60px rgba(0,128,70,.16))}
#livingmark{width:100%;height:100%;overflow:visible;transform-style:preserve-3d;
  transition:transform .5s cubic-bezier(.22,.61,.36,1)}
.arch{transform-box:fill-box}
@keyframes assembleDeep{
  0%{transform:translate(-46px,30px) rotate(-17deg) scale(.9);opacity:.20}
  14%{transform:translate(4px,-4px) rotate(2.5deg) scale(1.012);opacity:1}
  20%{transform:translate(0,0) rotate(0) scale(1);opacity:1}
  80%{transform:translate(0,0) rotate(0) scale(1);opacity:1}
  100%{transform:translate(-46px,30px) rotate(-17deg) scale(.9);opacity:.20}
}
@keyframes assembleLime{
  0%{transform:translate(46px,30px) rotate(17deg) scale(.9);opacity:.20}
  16%{transform:translate(-4px,-4px) rotate(-2.5deg) scale(1.012);opacity:1}
  24%{transform:translate(0,0) rotate(0) scale(1);opacity:1}
  80%{transform:translate(0,0) rotate(0) scale(1);opacity:1}
  100%{transform:translate(46px,30px) rotate(17deg) scale(.9);opacity:.20}
}
#deepArch{animation:assembleDeep 15s cubic-bezier(.45,0,.18,1) infinite;transform-origin:100% 100%}
#limeArch{animation:assembleLime 15s cubic-bezier(.45,0,.18,1) infinite;transform-origin:0% 100%}
@keyframes breatheA{0%,100%{transform:scale(1)}50%{transform:translateY(-1%) scale(1.012)}}
#deepBreathe{animation:breatheA 9s ease-in-out infinite;transform-origin:50% 100%}
#limeBreathe{animation:breatheA 11s ease-in-out infinite;transform-origin:50% 100%}
@keyframes sweep{0%,6%{transform:translateX(-240px);opacity:0}11%{opacity:.9}18%{transform:translateX(560px);opacity:0}100%{transform:translateX(560px);opacity:0}}
#ribbon{animation:sweep 15s ease-in-out infinite}
@keyframes nodesIn{0%,16%{opacity:0}30%{opacity:.34}80%{opacity:.34}100%{opacity:0}}
#nodes{animation:nodesIn 15s ease-in-out infinite}

/* ---------- Sections ---------- */
.disciplines{padding:clamp(90px,15vh,180px) var(--pad);max-width:var(--maxw);margin:0 auto}
.section-head{max-width:760px}
.lab,.section-head .lab{font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--green);font-weight:500}
.section-head h2{font-family:"Fraunces",serif;font-weight:500;font-size:clamp(30px,4.4vw,60px);
  line-height:1.05;letter-spacing:-.015em;margin:16px 0 0}
.discipline-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:60px}
.discipline{border-top:1px solid var(--hairline);padding-top:22px}
.discipline .num{font-family:"Fraunces";font-size:15px;color:var(--lime);font-weight:600}
.discipline h3{font-family:"Fraunces",serif;font-weight:500;font-size:24px;line-height:1.1;margin:12px 0 10px;letter-spacing:-.01em}
.discipline p{color:var(--ink2);opacity:.8;font-size:16px;margin:0}
.scaffold-note{margin-top:40px;font-size:13px;color:var(--ink2);opacity:.45}

/* currents divider, a quiet echo of the hero */
.currents-divider{position:relative;height:120px;overflow:hidden;display:flex;align-items:center;justify-content:center;margin:0 var(--pad)}
.currents-divider .c{position:absolute;border-radius:50%;filter:blur(14px);opacity:.5}
.currents-divider .c-green{width:120px;height:120px;background:var(--green);left:46%;animation:drift1 14s ease-in-out infinite}
.currents-divider .c-lime{width:150px;height:150px;background:var(--lime);left:50%;animation:drift2 18s ease-in-out infinite}
.currents-divider .c-sheen{width:90px;height:90px;background:#d6ffb4;left:52%;animation:drift1 11s ease-in-out infinite reverse}
@keyframes drift1{0%,100%{transform:translateX(-40px)}50%{transform:translateX(40px)}}
@keyframes drift2{0%,100%{transform:translateX(30px)}50%{transform:translateX(-30px)}}

/* ---------- Page shells ---------- */
.page-shell{max-width:var(--maxw);margin:0 auto;padding:160px var(--pad) 120px}
.page-hero{max-width:820px;margin-bottom:48px}
.page-hero h1{font-family:"Fraunces",serif;font-weight:500;font-size:clamp(40px,6vw,84px);line-height:1;letter-spacing:-.02em;margin:14px 0 0}
.page-hero .sub{margin-top:20px;font-size:19px;color:var(--ink2);opacity:.82;max-width:560px}
.page-body{max-width:720px;font-size:18px;line-height:1.7;color:var(--ink2)}
.page-body p{margin:0 0 1.2em}
.post-list{display:grid;gap:30px;max-width:820px}
.post-item{border-top:1px solid var(--hairline);padding-top:22px}
.post-item h2{font-family:"Fraunces",serif;font-weight:500;font-size:28px;margin:0 0 8px}
.post-item a{text-decoration:none}
.error-404 .cta{margin-top:24px;color:#fff}

/* ---------- Pre-footer + footer ---------- */
.prefooter{background:var(--ink);color:var(--white);padding:clamp(80px,14vh,150px) var(--pad);text-align:center}
.prefooter-inner{max-width:680px;margin:0 auto}
.prefooter-mark{margin:0 auto 26px;height:56px;width:auto}
.prefooter h2{font-family:"Fraunces",serif;font-weight:500;font-size:clamp(30px,4.6vw,58px);line-height:1.04;letter-spacing:-.02em;margin:0}
.prefooter p{margin:18px 0 32px;opacity:.7;font-size:18px}
.prefooter .cta{background:var(--lime);color:var(--ink)}
.prefooter .cta:hover{background:var(--white)}

.site-footer{background:var(--white);border-top:1px solid var(--hairline);padding:clamp(56px,9vh,96px) var(--pad) 36px}
.footer-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;align-items:start}
.footer-brand img{height:34px;width:auto;margin-bottom:16px}
.footer-brand p{color:var(--ink2);opacity:.7;font-size:14px;max-width:280px;line-height:1.5;margin:0}
.footer-links{list-style:none;margin:0;padding:0;display:grid;gap:10px}
.footer-links a{text-decoration:none;font-size:15px;opacity:.78}
.footer-links a:hover{opacity:1}
.footer-meta{font-size:14px;color:var(--ink2);opacity:.7}
.footer-meta a{text-decoration:none}
.footer-meta p{margin:0 0 6px}
.footer-base{max-width:var(--maxw);margin:40px auto 0;padding-top:24px;border-top:1px solid var(--hairline);font-size:13px;color:var(--ink2);opacity:.55}

/* ---------- Motion: scroll reveals ---------- */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .7s cubic-bezier(.22,.61,.36,1),transform .7s cubic-bezier(.22,.61,.36,1)}
.reveal.is-visible{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .nav-links,.primary-nav .cta{display:none}
  .nav-toggle{display:flex}
  .hero{grid-template-columns:1fr;padding-top:108px}
  .mark-stage{order:-1;margin-bottom:6px}
  .mark-wrap{width:min(40vh,300px)}
  .discipline-grid{grid-template-columns:1fr}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none;transition:none}
  #livingmark{transition:none}
}

/* ===== Home sections (Stage 3) ===== */
.hero-actions{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap}
.cta-ghost{background:transparent;color:var(--ink);border:1px solid rgba(29,29,31,.22)}
.cta-ghost:hover{background:var(--ink);color:#fff;border-color:var(--ink);transform:translateY(-1px)}

.text-link{display:inline-flex;align-items:center;gap:8px;text-decoration:none;font-weight:500;
  color:var(--green);font-size:16px}
.text-link span{transition:transform .3s}
.text-link:hover span{transform:translateX(5px)}
.section-foot{margin-top:48px}

/* Intro statement */
.intro{max-width:var(--maxw);margin:0 auto;padding:clamp(70px,12vh,140px) var(--pad) 0}
.intro-inner{max-width:880px}
.intro h2{font-family:"Fraunces",serif;font-weight:500;font-size:clamp(28px,3.6vw,48px);
  line-height:1.08;letter-spacing:-.015em;margin:0}
.intro p{margin-top:24px;font-size:clamp(17px,1.4vw,21px);line-height:1.6;color:var(--ink2);opacity:.84;max-width:680px}

/* Stats strip */
.stats{max-width:var(--maxw);margin:clamp(60px,10vh,120px) auto 0;padding:0 var(--pad)}
.stats-inner{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
  border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline);padding:48px 0}
.stat{display:flex;flex-direction:column;gap:8px}
.stat-num{font-family:"Fraunces",serif;font-weight:500;font-size:clamp(40px,5vw,68px);line-height:1;
  letter-spacing:-.02em;color:var(--ink)}
.stat-label{font-size:14px;color:var(--ink2);opacity:.7;letter-spacing:.01em}

/* Disciplines additions */
.disciplines{padding-top:clamp(80px,13vh,150px)}

/* Split panels */
.split{max-width:var(--maxw);margin:0 auto;padding:clamp(70px,11vh,130px) var(--pad);
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,80px);align-items:center}
.split-rev .split-text{order:2}
.split-text h2{font-family:"Fraunces",serif;font-weight:500;font-size:clamp(28px,3.6vw,50px);
  line-height:1.06;letter-spacing:-.015em;margin:16px 0 0}
.split-text p{margin:22px 0 26px;font-size:18px;line-height:1.6;color:var(--ink2);opacity:.84;max-width:480px}
.split-media{position:relative;aspect-ratio:4/3;border-radius:18px;overflow:hidden}
.split-media img{width:100%;height:100%;object-fit:cover}
.split-media.brand-panel{background:radial-gradient(120% 120% at 30% 20%,var(--mint),#E8F7D6 60%,#cfeeae);
  display:flex;align-items:center;justify-content:center}
.brand-panel-execution{background:radial-gradient(120% 120% at 70% 30%,#eaffd2,#bfe98f 70%,#9ED45F)}
.brand-panel .bp-mark{width:34%;height:auto;opacity:.9;filter:drop-shadow(0 20px 40px rgba(0,128,70,.22));position:relative;z-index:2}
.brand-panel .bp-c{position:absolute;border-radius:50%;filter:blur(40px);opacity:.5}
.brand-panel .bp-green{width:240px;height:240px;background:var(--green);left:-40px;top:-40px}
.brand-panel .bp-lime{width:260px;height:260px;background:var(--lime);right:-60px;bottom:-50px}

/* Process steps */
.process{max-width:var(--maxw);margin:0 auto;padding:clamp(70px,11vh,140px) var(--pad)}
.step-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;margin-top:60px}
.step{border-top:2px solid var(--lime);padding-top:22px}
.step .num{font-family:"Fraunces";font-size:15px;color:var(--green);font-weight:600}
.step h3{font-family:"Fraunces",serif;font-weight:500;font-size:22px;margin:12px 0 10px;letter-spacing:-.01em}
.step p{color:var(--ink2);opacity:.8;font-size:15px;line-height:1.55;margin:0}

@media (max-width:980px){
  .stats-inner{grid-template-columns:repeat(2,1fr);gap:36px 24px}
  .split{grid-template-columns:1fr;gap:30px}
  .split-rev .split-text{order:0}
  .split-media{aspect-ratio:16/10}
  .step-grid{grid-template-columns:1fr 1fr;gap:26px}
}
@media (max-width:560px){
  .step-grid{grid-template-columns:1fr}
}

/* ===== Interior editorial pages (Stage 4) ===== */
.editorial{max-width:var(--maxw);margin:0 auto;padding:clamp(140px,18vh,200px) var(--pad) 30px}
.page-hero .lead{margin-top:22px;font-size:clamp(17px,1.5vw,21px);line-height:1.55;color:var(--ink2);opacity:.84;max-width:620px}

.ed-block{padding:clamp(50px,8vh,90px) 0;border-top:1px solid var(--hairline)}
.ed-block > .lab{display:block;margin-bottom:16px}
.ed-block > h2{font-family:"Fraunces",serif;font-weight:500;font-size:clamp(26px,3.4vw,46px);
  line-height:1.08;letter-spacing:-.015em;margin:0;max-width:820px}
.ed-prose{max-width:720px;margin-top:24px}
.ed-prose p{font-size:18px;line-height:1.7;color:var(--ink2);opacity:.86;margin:0 0 1.1em}

.ed-panel{background:var(--mint);border-radius:22px;padding:clamp(40px,6vw,72px);margin:clamp(40px,7vh,80px) 0}
.ed-panel > .lab{display:block;margin-bottom:16px}
.ed-panel > h2{font-family:"Fraunces",serif;font-weight:500;font-size:clamp(26px,3.4vw,46px);
  line-height:1.08;letter-spacing:-.015em;margin:0;max-width:760px;color:var(--ink)}
.ed-panel .ed-prose p{opacity:.82}

.value-grid,.diff-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:34px;margin-top:54px}
.value,.diff{border-top:2px solid var(--lime);padding-top:20px}
.value .num,.diff .num{font-family:"Fraunces";font-size:14px;color:var(--green);font-weight:600}
.value h3,.diff h3{font-family:"Fraunces",serif;font-weight:500;font-size:21px;margin:10px 0 10px;letter-spacing:-.01em;line-height:1.12}
.value p,.diff p{color:var(--ink2);opacity:.82;font-size:15px;line-height:1.55;margin:0}

/* Services discipline blocks */
.discipline-block{display:grid;grid-template-columns:1.2fr .8fr;gap:clamp(30px,5vw,70px);
  padding:clamp(50px,8vh,90px) 0;border-top:1px solid var(--hairline);align-items:start}
.db-head .lab{display:block;margin-bottom:14px}
.db-head h2{font-family:"Fraunces",serif;font-weight:500;font-size:clamp(26px,3.2vw,42px);
  line-height:1.06;letter-spacing:-.015em;margin:0 0 18px}
.db-head p{font-size:17px;line-height:1.6;color:var(--ink2);opacity:.84;margin:0;max-width:520px}
.db-list-label{display:block;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--green);font-weight:600;margin-bottom:14px}
.svc-list{list-style:none;margin:0;padding:0;display:grid;gap:11px}
.svc-list li{position:relative;padding-left:20px;font-size:15px;color:var(--ink2);opacity:.86;line-height:1.4}
.svc-list li::before{content:"";position:absolute;left:0;top:8px;width:8px;height:8px;border-radius:50%;
  background:var(--lime)}

/* Approach stages */
.stage{display:grid;grid-template-columns:120px 1fr;gap:clamp(20px,4vw,50px);
  padding:clamp(44px,7vh,80px) 0;border-top:1px solid var(--hairline)}
.stage-num{font-family:"Fraunces",serif;font-weight:500;font-size:clamp(48px,6vw,86px);line-height:1;
  color:var(--lime);letter-spacing:-.02em}
.stage-body{max-width:720px}
.stage-body h2{font-family:"Fraunces",serif;font-weight:500;font-size:clamp(26px,3.2vw,42px);
  line-height:1.05;letter-spacing:-.015em;margin:0 0 18px}
.stage-body p{font-size:17px;line-height:1.65;color:var(--ink2);opacity:.86;margin:0 0 1em}
.stage-list{margin-top:24px}
.stage-list .svc-list{grid-template-columns:repeat(2,1fr);gap:11px 26px}

/* ===== Contact ===== */
.contact-page .page-hero{margin-bottom:30px}
.contact-grid{display:grid;grid-template-columns:1.3fr .7fr;gap:clamp(30px,5vw,70px);
  padding:clamp(30px,5vh,60px) 0 0;align-items:start}
.contact-form{display:grid;gap:18px;max-width:640px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{display:flex;flex-direction:column;gap:8px}
.field span{font-size:13px;font-weight:500;color:var(--ink2);letter-spacing:.02em}
.field input,.field select,.field textarea{font-family:"DM Sans";font-size:16px;color:var(--ink);
  background:#fff;border:1px solid rgba(29,29,31,.16);border-radius:12px;padding:13px 15px;width:100%;
  transition:border-color .25s,box-shadow .25s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--green);
  box-shadow:0 0 0 3px rgba(0,168,89,.12)}
.field textarea{resize:vertical;min-height:120px}
.contact-form .cta{justify-self:start;margin-top:6px}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-note{border-radius:12px;padding:14px 16px;font-size:15px;margin-bottom:20px}
.form-ok{background:#EAF8E8;color:#0d6b34;border:1px solid #b9e6bf}
.form-err{background:#fdecea;color:#a3271b;border:1px solid #f3c4bd}

.contact-aside{display:grid;gap:34px;align-content:start}
.contact-detail .lab{display:block;margin-bottom:12px}
.contact-detail p{margin:0 0 6px;font-size:16px;color:var(--ink2);opacity:.86}
.contact-detail a{color:var(--green);text-decoration:none}
.contact-detail h3{font-family:"Fraunces",serif;font-weight:500;font-size:22px;margin:0 0 10px;letter-spacing:-.01em}

.footer-col h3{font-family:"DM Sans";font-size:13px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink2);opacity:.5;font-weight:600;margin:0 0 16px}
.footer-col ul{list-style:none;margin:0;padding:0;display:grid;gap:11px}
.footer-col a{text-decoration:none;font-size:15px;color:var(--ink2);opacity:.82}
.footer-col a:hover{opacity:1;color:var(--green)}
.footer-col li{font-size:15px;color:var(--ink2);opacity:.82}
.footer-base{display:flex;gap:20px;justify-content:space-between;flex-wrap:wrap}
.legal-link{color:var(--ink2);opacity:.55;text-decoration:none}

@media (max-width:980px){
  .value-grid,.diff-grid{grid-template-columns:1fr 1fr;gap:26px}
  .discipline-block{grid-template-columns:1fr;gap:26px}
  .stage{grid-template-columns:60px 1fr;gap:18px}
  .stage-list .svc-list{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr;gap:40px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:30px}
}
@media (max-width:560px){
  .value-grid,.diff-grid{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
}

/* ===== Wurd index + articles (Stage 5) ===== */
.wurd-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px;margin-top:50px;
  border-top:1px solid var(--hairline)}
.wurd-card{border-bottom:1px solid var(--hairline)}
.wurd-card:nth-child(odd){border-right:1px solid var(--hairline)}
.wurd-card-link{display:block;text-decoration:none;padding:38px clamp(20px,3vw,44px) 38px 0;height:100%;
  transition:opacity .3s}
.wurd-card:nth-child(even) .wurd-card-link{padding-left:clamp(20px,3vw,44px)}
.wurd-card-link:hover{opacity:.7}
.wurd-card .lab{display:block;margin-bottom:16px}
.wurd-card h2{font-family:"Fraunces",serif;font-weight:500;font-size:clamp(22px,2.4vw,30px);
  line-height:1.12;letter-spacing:-.01em;margin:0 0 16px;color:var(--ink)}
.wurd-excerpt{font-size:16px;line-height:1.55;color:var(--ink2);opacity:.78;margin:0 0 20px}
.wurd-meta{font-size:13px;color:var(--green);font-weight:500;letter-spacing:.02em}

.article{max-width:760px;margin:0 auto;padding:clamp(140px,18vh,200px) var(--pad) 40px}
.article-back{display:inline-block;text-decoration:none;color:var(--green);font-weight:500;font-size:14px;
  letter-spacing:.04em;margin-bottom:28px}
.article-hero .lab{display:block;margin-bottom:18px}
.article-hero h1{font-family:"Fraunces",serif;font-weight:500;font-size:clamp(32px,4.6vw,58px);
  line-height:1.05;letter-spacing:-.02em;margin:0 0 20px}
.article-meta{font-size:14px;color:var(--ink2);opacity:.6;letter-spacing:.02em}
.article-body{margin-top:48px;border-top:1px solid var(--hairline);padding-top:40px}
.article-body p{font-size:19px;line-height:1.75;color:var(--ink2);margin:0 0 1.3em}
.article-body h3{font-family:"Fraunces",serif;font-weight:500;font-size:clamp(22px,2.6vw,30px);
  line-height:1.15;letter-spacing:-.01em;margin:2em 0 .7em;color:var(--ink)}
.article-body .pullquote{margin:1.8em 0;padding:6px 0 6px 28px;border-left:3px solid var(--lime)}
.article-body .pullquote p{font-family:"Fraunces",serif;font-style:italic;font-size:clamp(22px,2.6vw,28px);
  line-height:1.3;color:var(--green);margin:0}

@media (max-width:760px){
  .wurd-grid{grid-template-columns:1fr}
  .wurd-card:nth-child(odd){border-right:none}
  .wurd-card-link,.wurd-card:nth-child(even) .wurd-card-link{padding:32px 0}
}

/* ===== Work index + case studies (Stage 6) ===== */
.work-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,4vw,56px);margin-top:54px}
.work-card{display:block;text-decoration:none;color:inherit}
.work-media{position:relative;aspect-ratio:3/2;border-radius:16px;overflow:hidden;margin-bottom:20px}
.work-media img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.22,.61,.36,1)}
.work-card:hover .work-media img{transform:scale(1.04)}
.work-media .brand-panel{position:absolute;inset:0}
.work-index{position:absolute;top:16px;left:18px;font-family:"Fraunces";font-weight:600;font-size:15px;
  color:#fff;mix-blend-mode:difference;z-index:3}
.work-info .lab{display:block;margin-bottom:10px}
.work-info h2{font-family:"Fraunces",serif;font-weight:500;font-size:clamp(22px,2.4vw,30px);
  line-height:1.1;letter-spacing:-.01em;margin:0 0 8px}
.work-year{font-size:14px;color:var(--ink2);opacity:.6}

/* single case study */
.case-hero{background:var(--ink);color:var(--white);padding:clamp(130px,18vh,200px) var(--pad) clamp(50px,8vh,90px)}
.case-hero-inner{max-width:var(--maxw);margin:0 auto}
.case-back{display:inline-block;color:rgba(255,255,255,.7);text-decoration:none;font-weight:500;font-size:14px;
  letter-spacing:.04em;margin-bottom:30px}
.case-back:hover{color:#fff}
.lab-light{color:var(--lime)}
.case-hero h1{font-family:"Fraunces",serif;font-weight:500;font-size:clamp(34px,5vw,72px);line-height:1.02;
  letter-spacing:-.02em;margin:14px 0 0;max-width:14ch}
.case-tagline{margin-top:20px;font-size:clamp(17px,1.6vw,22px);color:rgba(255,255,255,.72);max-width:520px}

.case-meta{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
  transform:translateY(-1px)}
.case-meta{background:var(--ink);color:#fff;padding-bottom:clamp(40px,7vh,70px)}
.meta-item{display:flex;flex-direction:column;gap:8px;border-top:1px solid rgba(255,255,255,.16);padding-top:18px}
.meta-label{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--lime);font-weight:600}
.meta-value{font-size:16px;color:#fff;opacity:.92}

.case-figure{max-width:var(--maxw);margin:clamp(40px,6vh,70px) auto 0;padding:0 var(--pad)}
.case-figure img{width:100%;height:auto;border-radius:18px;display:block}

.case-body{max-width:760px;margin:clamp(50px,8vh,90px) auto 0;padding:0 var(--pad) 20px}
.case-body h3{font-family:"Fraunces",serif;font-weight:500;font-size:clamp(22px,2.6vw,30px);
  line-height:1.12;letter-spacing:-.01em;margin:1.8em 0 .6em;color:var(--ink)}
.case-body h3:first-child{margin-top:0}
.case-body p{font-size:18px;line-height:1.75;color:var(--ink2);margin:0 0 1.2em}
.case-body .scope-label{font-family:"DM Sans";font-size:12px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--green);font-weight:600;margin:1.6em 0 .9em}
.case-body .svc-list{grid-template-columns:repeat(2,1fr);gap:11px 26px;margin-bottom:1.6em}
.case-body .case-quote{margin:2em 0;padding:28px 0 0;border-top:2px solid var(--lime)}
.case-body .case-quote p{font-family:"Fraunces",serif;font-style:italic;font-size:clamp(22px,2.8vw,30px);
  line-height:1.3;color:var(--ink);margin:0 0 14px}
.case-body .case-quote cite{font-style:normal;font-size:14px;color:var(--green);font-weight:500;letter-spacing:.02em}

@media (max-width:860px){
  .work-grid{grid-template-columns:1fr;gap:36px}
  .case-meta{grid-template-columns:1fr 1fr;gap:20px}
  .case-body .svc-list{grid-template-columns:1fr}
}
