/* ===========================================================
   TDM Insights — site stylesheet  ·  Direction A "The Brief"
   Cream canvas · deep forest · lime accent · heavy rounded Figtree
   =========================================================== */

:root{
  --cream:#F4F2EC;
  --paper:#FBFAF6;
  --forest:#38431D;
  --forest-d:#2C3614;
  --lime:#8FBE3C;
  --lime-d:#7CA830;
  --sand:#E8E5D4;
  --ink:#33332B;
  --muted:#6E6E60;
  --rule:#D7D4C4;
  --rule-soft:#E4E1D2;
  --maxw:1180px;
  --pad:48px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--cream);
  color:var(--ink);
  font-family:'Figtree',system-ui,-apple-system,sans-serif;
  font-size:18px;line-height:1.55;font-weight:450;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit}

/* ---- layout helpers ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}
.section{padding-top:72px;padding-bottom:72px}
.section--tight{padding-top:38px;padding-bottom:38px}
.divider{height:1px;background:var(--rule);border:0}
.center{text-align:center}

/* ---- type ---- */
.eyebrow{font-size:13px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--forest)}
.eyebrow--muted{color:var(--muted)}
h1,h2,h3{font-weight:800;color:var(--forest);letter-spacing:-.02em;line-height:1.04;text-wrap:balance}
.display{font-size:clamp(54px,7vw,96px);line-height:.98;letter-spacing:-.025em}
h2{font-size:clamp(34px,4.4vw,48px)}
h3{font-size:24px;letter-spacing:-.01em}
.hl{font-style:italic;color:var(--lime)}
.lede{font-size:clamp(19px,2.1vw,24px);line-height:1.5;color:var(--ink);font-weight:450;max-width:60ch}
.lede b{font-weight:700;color:var(--forest)}
.muted{color:var(--muted)}
.kicker{font-size:15px;color:var(--muted)}
p+p{margin-top:1em}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:10px;background:var(--forest);color:var(--cream);
  font-weight:700;font-size:16px;padding:14px 24px;border-radius:100px;text-decoration:none;
  white-space:nowrap;border:0;cursor:pointer;transition:background .2s ease,transform .2s ease,box-shadow .2s ease}
.btn:hover{background:var(--forest-d);transform:translateY(-2px);box-shadow:0 12px 26px -10px rgba(56,67,29,.55)}
.btn:active{transform:translateY(0);box-shadow:0 4px 12px -7px rgba(56,67,29,.5)}
.btn--lg{font-size:19px;padding:18px 32px}
.btn--lime{background:var(--lime);color:var(--forest-d)}
.btn--lime:hover{background:var(--lime-d);box-shadow:0 12px 26px -10px rgba(143,190,60,.6)}
.btn--ghost{background:transparent;color:var(--forest);border:1.5px solid var(--rule)}
.btn--ghost:hover{background:transparent;border-color:var(--forest);transform:translateY(-2px);box-shadow:0 10px 22px -12px rgba(56,67,29,.4)}
.arrow{transition:transform .2s ease}
.btn:hover .arrow{transform:translateX(5px)}
@media(prefers-reduced-motion:reduce){
  .btn,.btn:hover,.btn:active,.arrow,.btn:hover .arrow{transition:none;transform:none}
}
.textlink{color:var(--forest);font-weight:700;text-decoration:none;border-bottom:2px solid var(--lime);padding-bottom:1px;white-space:nowrap}
.textlink:hover{border-bottom-color:var(--forest)}
.ilink{color:inherit;text-decoration:underline;text-decoration-color:var(--lime);text-decoration-thickness:2px;
  text-underline-offset:2px;transition:text-decoration-color .15s}
.ilink:hover{text-decoration-color:var(--forest)}

/* ---- nav ---- */
.nav{position:sticky;top:0;z-index:50;background:rgba(244,242,236,.88);
  backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--rule)}
.nav__in{max-width:var(--maxw);margin:0 auto;padding:20px var(--pad);
  display:flex;align-items:center;justify-content:space-between;gap:24px}
.wm{font-size:23px;font-weight:800;color:var(--forest);letter-spacing:-.01em;text-decoration:none;white-space:nowrap}
.wm span{color:var(--lime);font-style:italic}
.nav__links{display:flex;gap:34px;align-items:center}
.nav__links a{font-size:16px;font-weight:600;color:var(--ink);text-decoration:none;opacity:.82;
  white-space:nowrap;transition:opacity .15s,color .15s}
.nav__links a:hover{opacity:1;color:var(--forest)}
.nav__links a[aria-current="page"]{opacity:1;color:var(--forest);border-bottom:2px solid var(--lime);padding-bottom:3px}
.nav__cta{display:flex;align-items:center;gap:18px}
.nav__toggle{display:none;background:transparent;border:0;cursor:pointer;width:42px;height:42px;
  align-items:center;justify-content:center;border-radius:8px}
.nav__toggle span,.nav__toggle span::before,.nav__toggle span::after{display:block;width:22px;height:2px;
  background:var(--forest);border-radius:2px;transition:.2s}
.nav__toggle span{position:relative}
.nav__toggle span::before,.nav__toggle span::after{content:"";position:absolute;left:0}
.nav__toggle span::before{top:-7px}
.nav__toggle span::after{top:7px}
.nav--open .nav__toggle span{background:transparent}
.nav--open .nav__toggle span::before{top:0;transform:rotate(45deg)}
.nav--open .nav__toggle span::after{top:0;transform:rotate(-45deg)}

/* ---- nav dropdown (Services) ---- */
.nav__item{position:relative;display:flex;align-items:center}
.nav__top{display:inline-flex;align-items:center;gap:6px;font-size:16px;font-weight:600;color:var(--ink);
  text-decoration:none;opacity:.82;cursor:pointer;transition:opacity .15s,color .15s;white-space:nowrap}
.nav__top:hover{opacity:1;color:var(--forest)}
.nav__chev{width:10px;height:10px;transition:transform .2s;opacity:.7}
.nav__item:hover .nav__chev{transform:rotate(180deg)}
.nav__item:has(.nav__sub a[aria-current="page"]) .nav__top{opacity:1;color:var(--forest)}
.nav__sub{position:absolute;top:100%;left:-14px;display:none;padding-top:14px;z-index:60}
.nav__item:hover .nav__sub,.nav__item:focus-within .nav__sub{display:block}
.nav__sub-inner{display:flex;flex-direction:column;min-width:196px;background:var(--cream);
  border:1px solid var(--rule);border-radius:14px;padding:8px;box-shadow:0 18px 44px rgba(56,67,29,.16)}
.nav__sub a{padding:11px 14px;border-radius:8px;font-size:15px;font-weight:600;color:var(--ink);
  text-decoration:none;opacity:.92;white-space:nowrap;transition:background .12s,color .12s}
.nav__sub a:hover{background:var(--sand);color:var(--forest);opacity:1}
.nav__sub a[aria-current="page"]{background:var(--sand);color:var(--forest)}
.nav__sub-sep{border-top:1px solid var(--rule);margin:8px 0}

/* ---- hero ---- */
.hero{padding-top:64px;padding-bottom:36px}
.hero .lede{margin-top:32px}
.cta-row{display:flex;align-items:center;gap:24px;margin-top:44px;flex-wrap:wrap}
.cta-row .muted{font-size:16px;max-width:30ch}

/* ---- stat band ---- */
.statband{display:grid;grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.stat{padding:38px 32px;border-left:1px solid var(--rule)}
.stat:first-child{border-left:0;padding-left:0}
.stat__num{font-size:clamp(40px,5vw,58px);font-weight:800;color:var(--forest);letter-spacing:-.02em;line-height:1}
.stat__lbl{font-size:12px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--forest);margin-top:14px}
.stat__sub{font-size:15px;color:var(--muted);margin-top:5px}
.proof-cap{color:var(--muted);font-size:15px;margin-top:22px}
.proof-cap b{color:var(--forest);font-weight:700}

/* ---- section head ---- */
.sec-head .eyebrow{display:block}
.sec-head h2{margin-top:16px;max-width:18ch}
.sec-head .lede{margin-top:22px}

/* ---- lanes (services grid) ---- */
.lanes{display:grid;grid-template-columns:1fr 1fr;margin-top:54px;border-top:1px solid var(--rule)}
.lane{padding:40px 48px 40px 0;border-bottom:1px solid var(--rule);border-right:1px solid var(--rule)}
.lane:nth-child(even){padding-left:48px;padding-right:0;border-right:0}
.lane__no{font-size:14px;font-weight:800;color:var(--lime);letter-spacing:.08em}
.lane h3{margin:14px 0 10px}
.lane p{font-size:17px;color:var(--muted);line-height:1.5;max-width:46ch}
.lane__more{display:inline-block;margin-top:16px;font-size:15px;font-weight:700;color:var(--forest);
  text-decoration:none;border-bottom:2px solid var(--lime);padding-bottom:1px;white-space:nowrap}

/* ---- mode/tier cards ---- */
.cards{display:grid;gap:22px;margin-top:50px}
.cards--3{grid-template-columns:repeat(3,1fr)}
.cards--2{grid-template-columns:1fr 1fr}
.card{background:var(--paper);border:1px solid var(--rule);border-radius:14px;padding:36px 34px}
.card--sand{background:var(--sand);border-color:transparent}
.card__tag{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--lime-d)}
.card h3{margin:16px 0 12px}
.card p{font-size:16.5px;color:var(--muted);line-height:1.5}
.card ul{list-style:none;margin:18px 0 0;display:flex;flex-direction:column;gap:11px}
.card li{position:relative;padding-left:26px;font-size:16px;color:var(--ink);line-height:1.4}
.card li::before{content:"";position:absolute;left:0;top:9px;width:11px;height:11px;border-radius:50%;
  background:var(--lime);box-shadow:0 0 0 3px rgba(143,190,60,.2)}
.card--feature{position:relative}
.badge{position:absolute;top:-12px;right:24px;background:var(--forest);color:var(--cream);
  font-size:12px;font-weight:700;letter-spacing:.04em;padding:6px 14px;border-radius:100px;white-space:nowrap}

/* ---- cta band ---- */
.ctaband{background:var(--sand);border-radius:8px;padding:84px 64px;text-align:center}
.ctaband h2{font-size:clamp(38px,4.6vw,54px);max-width:18ch;margin:0 auto}
.ctaband .lede{margin:22px auto 0;color:var(--muted)}
.ctaband .btn{margin-top:38px}

/* ---- footer ---- */
.foot{border-top:1px solid var(--rule);margin-top:0}
.foot__in{max-width:var(--maxw);margin:0 auto;padding:44px var(--pad) 30px;
  display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px}
.foot__brand .wm{font-size:21px}
.foot__brand p{margin-top:16px;color:var(--muted);font-size:15.5px;max-width:34ch}
.foot__col h4{font-size:12px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--forest);margin-bottom:12px}
.foot__col a{display:block;color:var(--muted);text-decoration:none;font-size:15.5px;line-height:1.3;margin-bottom:6px;transition:color .15s}
.foot__col a:hover{color:var(--forest)}
.foot__bar{border-top:1px solid var(--rule)}
.foot__bar .wrap{display:flex;justify-content:space-between;align-items:center;padding-top:20px;padding-bottom:28px;
  color:var(--muted);font-size:14px}

/* ---- chart ---- */
.chart{background:var(--paper);border:1px solid var(--rule);border-radius:14px;padding:34px 36px 28px}
.chart__head{display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:8px}
.chart__head .t{font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--forest)}
.chart__head .t2{font-size:13px;color:var(--muted)}
.chart svg{display:block;width:100%;height:auto;margin-top:18px;overflow:visible}
.chart__axis{font-size:12px;fill:var(--muted);font-weight:600}
.chart__delta{display:flex;align-items:baseline;gap:16px;flex-wrap:wrap;margin-top:8px}
.chart__big{font-size:46px;font-weight:800;color:var(--forest);letter-spacing:-.02em;line-height:1}
.chart__from{font-size:15px;color:var(--muted);white-space:nowrap}
.chart__mult{margin-left:auto;background:var(--lime);color:var(--forest-d);font-weight:800;font-size:15px;
  padding:7px 14px;border-radius:6px;white-space:nowrap}

/* ---- tables ---- */
.tbl{width:100%;border-collapse:collapse;font-size:15px}
.tbl caption{text-align:left;font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--forest);margin-bottom:14px}
.tbl th{text-align:right;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--muted);padding:0 0 12px;border-bottom:1px solid var(--rule)}
.tbl th:first-child{text-align:left}
.tbl td{padding:13px 0;border-bottom:1px solid var(--rule-soft);text-align:right;color:var(--ink);
  font-variant-numeric:tabular-nums}
.tbl td:first-child{text-align:left;font-weight:600;color:var(--forest)}
.tbl tr:last-child td{border-bottom:0}

/* ---- steps ---- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:50px;border-top:1px solid var(--rule)}
.step{padding:34px 32px 34px 0;border-right:1px solid var(--rule)}
.step:last-child{border-right:0;padding-right:0}
.step:not(:first-child){padding-left:32px}
.step__k{font-size:12px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--lime-d)}
.step h3{margin:12px 0 8px;font-size:21px}
.step p{font-size:16px;color:var(--muted);line-height:1.5}

/* ---- faq ---- */
.faq{margin-top:44px;border-top:1px solid var(--rule)}
.faq details{border-bottom:1px solid var(--rule)}
.faq summary{list-style:none;cursor:pointer;padding:26px 48px 26px 0;position:relative;
  font-size:21px;font-weight:700;color:var(--forest);letter-spacing:-.01em}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:8px;top:24px;font-size:26px;font-weight:600;
  color:var(--lime-d);transition:transform .2s}
.faq details[open] summary::after{content:"–"}
.faq p{padding:0 48px 28px 0;color:var(--muted);font-size:17px;line-height:1.55;max-width:72ch}

/* ---- about ---- */
.profile{display:grid;grid-template-columns:.85fr 1.15fr;gap:64px;align-items:center}
.portrait{position:relative}
.portrait img{border-radius:14px;width:100%;height:auto;display:block}
.portrait::before{content:"";position:absolute;inset:18px -18px -18px 18px;background:var(--sand);
  border-radius:14px;z-index:-1}
.facts{display:grid;grid-template-columns:repeat(2,1fr);gap:0;margin-top:54px;border-top:1px solid var(--rule)}
.fact{padding:28px 28px 28px 0;border-bottom:1px solid var(--rule);border-right:1px solid var(--rule)}
.fact:nth-child(even){padding-left:28px;padding-right:0;border-right:0}
.fact__n{font-size:34px;font-weight:800;color:var(--forest);letter-spacing:-.02em;line-height:1}
.fact__l{font-size:15px;color:var(--muted);margin-top:7px}

/* ---- prose ---- */
.prose{max-width:64ch}
.prose p{font-size:18.5px;line-height:1.62;color:var(--ink);margin-bottom:1.1em}
.prose p b{color:var(--forest);font-weight:700}

/* ---- form ---- */
.formwrap{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.field{margin-bottom:22px}
.field label{display:block;font-size:14px;font-weight:700;color:var(--forest);margin-bottom:8px;letter-spacing:.01em}
.field input,.field textarea,.field select{width:100%;background:var(--paper);border:1.5px solid var(--rule);
  border-radius:10px;padding:14px 16px;font-family:inherit;font-size:16px;color:var(--ink);transition:border-color .15s}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--forest)}
.field textarea{min-height:120px;resize:vertical}
.choices{display:flex;gap:10px;flex-wrap:wrap}
.choice{position:relative}
.choice input{position:absolute;opacity:0;inset:0;cursor:pointer}
.choice span{display:block;border:1.5px solid var(--rule);border-radius:100px;padding:11px 18px;font-size:15px;
  font-weight:600;color:var(--ink);transition:all .15s;cursor:pointer}
.choice input:checked+span{background:var(--forest);color:var(--cream);border-color:var(--forest)}
.form-success{display:none;background:var(--sand);border-radius:14px;padding:44px 40px}
.form-success h3{margin-bottom:10px}

/* ---- misc ---- */
.tag-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:28px}
.tag{background:var(--sand);color:var(--forest);font-size:14px;font-weight:600;padding:8px 15px;border-radius:100px}
.note{background:var(--paper);border:1px solid var(--rule);border-left:3px solid var(--lime);
  border-radius:10px;padding:26px 30px;color:var(--muted);font-size:16.5px;line-height:1.55}
.note b{color:var(--forest)}

/* ===========================================================
   responsive
   =========================================================== */
@media(max-width:960px){
  :root{--pad:32px}
  .section{padding-top:62px;padding-bottom:62px}
  .section--tight{padding-top:32px;padding-bottom:32px}
  .hero{padding-top:48px;padding-bottom:30px}
  .nav__in{position:relative;flex-wrap:wrap}
  .nav__toggle{display:flex;order:2;margin-left:2px}
  .nav__links{display:none;position:absolute;top:calc(100% + 8px);right:var(--pad);left:auto;min-width:200px;
    flex-direction:column;gap:0;align-items:stretch;
    background:var(--cream);border:1px solid var(--rule);border-radius:14px;padding:8px;overflow:hidden;
    box-shadow:0 18px 44px rgba(56,67,29,.16)}
  .nav--open .nav__links{display:flex}
  .nav__links a{padding:11px 16px;width:100%;opacity:.92;border-radius:8px}
  .nav__links a:hover{background:var(--sand)}
  .nav__links a[aria-current="page"]{border-bottom:0;color:var(--forest);background:var(--sand)}
  .nav__item{display:block;width:100%}
  .nav__top{width:100%;padding:11px 16px;border-radius:8px;justify-content:space-between}
  .nav__chev{opacity:.5}
  .nav__sub{position:static;display:block;padding-top:0}
  .nav__sub-inner{background:transparent;border:0;box-shadow:none;padding:0 0 4px 14px;min-width:0;border-radius:0}
  .nav__sub a{font-size:14.5px;opacity:.82;padding:9px 14px}
  .lanes,.cards--3,.cards--2,.steps,.formwrap,.profile,.facts,.foot__in{grid-template-columns:1fr}
  .lane,.lane:nth-child(even){padding:32px 0;border-right:0}
  .step,.fact,.fact:nth-child(even){padding:28px 0;border-right:0}
  .statband{grid-template-columns:1fr 1fr}
  .stat:nth-child(3){padding-left:0;border-left:0}
  .stat{border-top:1px solid var(--rule)}
  .stat:first-child,.stat:nth-child(2){border-top:0}
  .profile{gap:40px}
  .portrait{max-width:380px}
  .ctaband{padding:60px 32px}
  .foot__in{gap:36px}
}
@media(max-width:560px){
  :root{--pad:22px}
  .section{padding-top:46px;padding-bottom:46px}
  .section--tight{padding-top:28px;padding-bottom:28px}
  .hero{padding-top:34px;padding-bottom:26px}
  .display{font-size:clamp(38px,11vw,52px)}
  h2{font-size:clamp(30px,8vw,38px)}
  .lede{font-size:18px}
  .statband{grid-template-columns:1fr 1fr}
  .stat{padding:22px 18px}
  .stat__num{font-size:42px}
  .ctaband{padding:46px 24px;border-radius:6px}
  .why{padding:42px 26px}
  .card{padding:30px 26px}
  .form-card{border-radius:14px}
  .cta-row{gap:16px}
  .foot__bar .wrap{flex-direction:column;gap:8px;align-items:flex-start}
}


/* =========================================================
   Page-specific styles (merged from the per-page templates)
   ========================================================= */

/* ===== services.html ===== */
.svc-row{display:grid;grid-template-columns:.8fr 1.2fr;gap:56px;padding:56px 0;border-top:1px solid var(--rule)}
  .svc-row:last-of-type{border-bottom:1px solid var(--rule)}
  .svc-row__head .no{font-size:15px;font-weight:800;color:var(--lime);letter-spacing:.08em}
  .svc-row__head h3{font-size:32px;margin:14px 0 0}
  .svc-row__head .what{margin-top:18px;font-size:13px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--muted)}
  .svc-row__body p{font-size:18.5px;line-height:1.6;color:var(--ink)}
  .svc-list{list-style:none;margin:24px 0 0;display:grid;grid-template-columns:1fr 1fr;gap:12px 28px}
  .svc-list li{position:relative;padding-left:24px;font-size:16px;color:var(--muted);line-height:1.4}
  .svc-list li::before{content:"";position:absolute;left:0;top:8px;width:9px;height:9px;border-radius:50%;background:var(--lime)}
  @media(max-width:880px){.svc-row{grid-template-columns:1fr;gap:24px}.svc-list{grid-template-columns:1fr}}

/* ===== growth-engine.html ===== */
.opts{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:50px}
  .modgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:50px}
  .mod{background:var(--paper);border:1px solid var(--rule);border-radius:14px;padding:28px 26px}
  .mod__lane{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);
    display:flex;justify-content:space-between;align-items:center;gap:8px}
  .mod__lane .ct{background:var(--sand);color:var(--forest);border-radius:100px;padding:3px 10px;font-size:11px}
  .mod h3{font-size:21px;margin:16px 0 9px;font-family:'Figtree';letter-spacing:0}
  .mod h3 code{font-family:inherit}
  .mod p{font-size:15px;color:var(--muted);line-height:1.5}
  .mod--core{background:var(--forest);border-color:var(--forest)}
  .mod--core .mod__lane{color:rgba(244,242,236,.7)}
  .mod--core .mod__lane .ct{background:rgba(244,242,236,.16);color:var(--cream)}
  .mod--core h3{color:var(--cream)}
  .mod--core p{color:rgba(244,242,236,.8)}
  .tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:50px;align-items:start}
  .forged{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:50px;border-top:1px solid var(--rule)}
  .forged>div{padding:34px 30px 34px 0;border-right:1px solid var(--rule)}
  .forged>div:last-child{border-right:0;padding-right:0}
  .forged>div:not(:first-child){padding-left:30px}
  .forged .fno{font-size:14px;font-weight:800;color:var(--lime);letter-spacing:.08em}
  .forged h3{margin:12px 0 9px;font-size:22px}
  .forged p{font-size:16px;color:var(--muted);line-height:1.5}
  @media(max-width:880px){.opts,.modgrid,.tiers{grid-template-columns:1fr}.forged{grid-template-columns:1fr}.forged>div,.forged>div:not(:first-child){padding:28px 0;border-right:0}}

/* ===== case-studies.html ===== */
.feature{display:block;text-decoration:none;color:inherit;border:1px solid var(--rule);border-radius:18px;
    overflow:hidden;background:var(--paper);transition:transform .2s,box-shadow .2s;margin-top:8px}
  .feature:hover{transform:translateY(-3px);box-shadow:0 24px 60px rgba(56,67,29,.12)}
  .feature__grid{display:grid;grid-template-columns:1fr 1fr}
  .feature__body{padding:48px 46px}
  .feature__tag{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;letter-spacing:.12em;
    text-transform:uppercase;color:var(--lime-d)}
  .feature__tag .dot{width:8px;height:8px;border-radius:50%;background:var(--lime);box-shadow:0 0 0 3px rgba(143,190,60,.22)}
  .feature__body h3{font-size:38px;margin:18px 0 14px;letter-spacing:-.02em}
  .feature__body p{font-size:17.5px;color:var(--muted);line-height:1.55;max-width:46ch}
  .feature__stats{display:flex;gap:30px;margin-top:28px;flex-wrap:wrap}
  .feature__stat .n{font-size:30px;font-weight:800;color:var(--forest);letter-spacing:-.02em;line-height:1;white-space:nowrap}
  .feature__stat .l{font-size:13px;color:var(--muted);margin-top:5px;letter-spacing:.04em}
  .feature__cta{display:inline-flex;align-items:center;gap:9px;margin-top:32px;font-size:16px;font-weight:700;
    color:var(--forest);border-bottom:2px solid var(--lime);padding-bottom:2px}
  .feature__panel{background:var(--sand);padding:40px 42px;display:flex;flex-direction:column;justify-content:center}
  .feature__panel .ph{font-size:12px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--forest);margin-bottom:16px}
  .feature__panel svg{width:100%;height:auto;overflow:visible}
  .feature__delta{display:flex;align-items:baseline;gap:14px;margin-top:18px;flex-wrap:wrap}
  .feature__delta .big{font-size:38px;font-weight:800;color:var(--forest);letter-spacing:-.02em;line-height:1}
  .feature__delta .from{font-size:14px;color:var(--muted)}

  .up-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:50px}
  .up-card{border:1px solid var(--rule);border-radius:16px;padding:34px 32px;background:var(--cream);position:relative}
  .up-card__status{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);
    display:inline-flex;align-items:center;gap:8px}
  .up-card__status .dot{width:7px;height:7px;border-radius:50%;background:var(--rule)}
  .up-card__type{font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--lime-d);margin-top:0}
  .up-card h3{font-size:23px;margin:10px 0 12px}
  .up-card p{font-size:16px;color:var(--muted);line-height:1.5}
  @media(max-width:880px){.feature__grid{grid-template-columns:1fr}.feature__panel{order:-1}.up-grid{grid-template-columns:1fr}.feature__body{padding:36px 28px}}

/* ===== case-tgh.html ===== */
.method{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:50px;border-top:1px solid var(--rule)}
  .method>div{padding:30px 30px 30px 0;border-right:1px solid var(--rule);border-bottom:1px solid var(--rule)}
  .method>div:nth-child(3n){border-right:0}
  .method>div:nth-child(3n+2){padding-left:30px}
  .method>div:nth-child(3n){padding-left:30px}
  .method .mno{font-size:13px;font-weight:800;color:var(--lime);letter-spacing:.08em}
  .method h3{margin:11px 0 8px;font-size:20px}
  .method p{font-size:15.5px;color:var(--muted);line-height:1.5}
  .casegrid{display:grid;grid-template-columns:1.25fr .75fr;gap:48px;align-items:start;margin-top:48px}
  @media(max-width:880px){.method{grid-template-columns:1fr}.method>div,.method>div:nth-child(3n+2),.method>div:nth-child(3n){padding:26px 0;border-right:0}.casegrid{grid-template-columns:1fr;gap:32px}}

/* ===== about.html ===== */
.about-head .eyebrow{letter-spacing:.22em}
  .about-name{font-size:clamp(54px,7vw,92px);line-height:.95;margin-top:18px}
  .about-name .ital{font-style:italic;font-weight:800;color:var(--forest)}
  .about-role{font-size:19px;color:var(--muted);margin-top:18px}
  .about-role b{color:var(--forest);font-weight:700}
  .why{background:var(--forest);border-radius:8px;padding:72px 64px;color:var(--cream)}
  .why .eyebrow{color:var(--lime)}
  .why h2{color:var(--cream);margin-top:16px}
  .why p{font-size:20px;line-height:1.6;color:rgba(244,242,236,.85);max-width:60ch;margin-top:22px}
  .why p b{color:var(--lime);font-weight:700}
  @media(max-width:880px){.why{padding:48px 32px}}
  /* milestone timeline */
  .tl-head{margin-top:64px}
  .timeline{display:grid;grid-template-columns:repeat(5,1fr);margin-top:30px;position:relative}
  .timeline::before{content:"";position:absolute;top:8px;left:8px;right:8px;height:2px;background:var(--rule)}
  .tl{position:relative;padding-right:24px}
  .tl__dot{width:17px;height:17px;border-radius:50%;background:var(--lime);position:relative;z-index:1;
    box-shadow:0 0 0 4px var(--cream),0 0 0 6px rgba(143,190,60,.35)}
  .tl:last-child .tl__dot{background:var(--forest);box-shadow:0 0 0 4px var(--cream),0 0 0 6px rgba(56,67,29,.3)}
  .tl__date{font-size:13px;font-weight:800;letter-spacing:.13em;text-transform:uppercase;color:var(--forest);margin-top:22px}
  .tl__label{font-size:18px;font-weight:700;color:var(--ink);line-height:1.3;margin-top:8px;max-width:15ch;letter-spacing:-.01em}
  @media(max-width:760px){
    .timeline{grid-template-columns:1fr}
    .timeline::before{top:8px;bottom:8px;left:8px;right:auto;width:2px;height:auto}
    .tl{padding:0 0 30px 38px}
    .tl:last-child{padding-bottom:0}
    .tl__dot{position:absolute;left:0;top:2px}
    .tl__date{margin-top:0}
    .tl__label{max-width:none}
  }

/* ===== contact.html ===== */
.contact-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:64px;align-items:start}
  .name-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
  .form-card{background:var(--paper);border:1px solid var(--rule);border-radius:18px;padding:44px 42px}
  /* steps read as a vertical list inside the narrow pitch column */
  .contact-grid .steps{grid-template-columns:1fr;margin-top:40px;border-top:1px solid var(--rule)}
  .contact-grid .step{padding:22px 0;border-right:0;border-bottom:1px solid var(--rule)}
  .contact-grid .step:last-child{border-bottom:0}
  .contact-grid .step h3{font-size:20px;margin-top:6px}
  .contact-grid .step p{max-width:46ch}
  /* stack pitch over form before the columns get cramped */
  @media(max-width:1040px){.contact-grid{grid-template-columns:1fr;gap:44px}}
  @media(max-width:880px){.form-card{padding:32px 24px}.name-row{grid-template-columns:1fr}}
  @media(max-width:560px){.choices{gap:8px}.choice span{padding:10px 15px;font-size:14px}}


/* ---- footer legal links ---- */
.foot__legal{display:flex;gap:20px;align-items:center;flex-wrap:wrap}
.foot__legal a{color:var(--muted);text-decoration:none;transition:color .15s}
.foot__legal a:hover{color:var(--forest)}
/* ---- legal documents ---- */
.legal{max-width:68ch}
.legal h2{font-size:23px;color:var(--forest);letter-spacing:-.01em;margin:38px 0 12px}
.legal h2:first-child{margin-top:0}
.legal p{font-size:17.5px;line-height:1.62;color:var(--ink);margin-bottom:1.1em}
.legal p b{color:var(--forest);font-weight:700}
.legal ul{margin:0 0 1.2em;padding-left:22px}
.legal li{font-size:17.5px;line-height:1.6;color:var(--ink);margin-bottom:.55em}
.legal a{color:var(--forest);text-decoration:underline;text-decoration-color:var(--lime);text-decoration-thickness:2px;text-underline-offset:2px}
.legal a:hover{text-decoration-color:var(--forest)}
/* ---- targeted spacing trims ---- */
.section--tight:has(.legal){padding-top:18px}
[data-screen-label="Case studies / featured"]{padding-top:24px;padding-bottom:22px}
