:root{
    --ivory:#F4F0E7;
    --ivory-2:#ECE7DA;
    --paper:#FAF7EF;
    --navy:#1C2133;
    --navy-deep:#161A28;
    --ink:#1C2133;
    --ink-soft:#3D4254;
    --muted:#6E7283;
    --line:#DBD5C7;
    --line-soft:#E7E2D5;
    --line-d:rgba(244,240,231,.16);
    --line-d2:rgba(244,240,231,.08);
    --brass:#9A7B4F;
    --brass-deep:#7C6440;
    --brass-light:#C2A271;
    --serif:"Cormorant Garamond", Georgia, "Times New Roman", serif;
    --sans:"Helvetica Neue", Helvetica, Arial, sans-serif;
    --maxw:1160px;
    --ease:cubic-bezier(.2,.7,.2,1);
  }
  *{box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--ivory);line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 44px}
  a{color:inherit;text-decoration:none}

  h1,h2,h3{font-family:var(--serif);font-weight:600;line-height:1.12;letter-spacing:0;margin:0;color:var(--ink)}
  h1{font-size:clamp(2.9rem,5.7vw,5rem);line-height:1.08}
  h2{font-size:clamp(2.1rem,3.9vw,3.3rem);line-height:1.1}
  h3{font-size:1.55rem;line-height:1.22}
  p{margin:0}

  .label{font-family:var(--sans);font-weight:600;text-transform:uppercase;letter-spacing:.3em;font-size:.68rem;color:var(--brass-deep)}
  .lead{font-size:clamp(1.16rem,1.5vw,1.4rem);color:var(--ink-soft);line-height:1.58;font-weight:400}
  .muted{color:var(--muted)}
  .serif-it{font-family:var(--serif);font-style:italic}

  .ul{position:relative;padding-bottom:3px}
  .ul::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:var(--brass);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
  .ul:hover::after{transform:scaleX(1)}

  /* ============ LOGO LOCKUP ============ */
  .brand{display:inline-flex;align-items:center;gap:16px}
  .brand .mk{font-family:var(--serif);font-weight:600;font-size:2.6rem;line-height:1;color:var(--ink);display:inline-grid;place-items:center;padding:0 17px 0 5px;border-right:1px solid rgba(154,123,79,.5);overflow:visible}
  .brand .wm{display:flex;flex-direction:column;align-items:flex-start;gap:3px}
  .brand .wm .w{font-family:var(--serif);font-weight:500;font-size:1.42rem;letter-spacing:.32em;text-indent:.32em;color:var(--ink);line-height:1}
  .brand .wm .r{display:flex;align-items:center;gap:10px;width:100%}
  .brand .wm .r::before{content:"";height:1px;flex:1;background:var(--brass);opacity:.7}
  .brand .wm .t{font-family:var(--sans);font-weight:600;font-size:.55rem;letter-spacing:.4em;text-indent:.4em;color:var(--muted);text-transform:uppercase}

  /* ============ Header ============ */
  header.site{position:sticky;top:0;z-index:60;background:color-mix(in srgb,var(--ivory) 86%,transparent);backdrop-filter:saturate(140%) blur(11px);border-bottom:1px solid var(--line-soft)}
  .nav{display:flex;align-items:center;justify-content:space-between;height:94px}
  .nav-links{display:flex;align-items:center;gap:40px}
  .nav-links a{display:inline-flex;align-items:center;line-height:1;font-size:.82rem;letter-spacing:.04em;color:var(--ink-soft)}
  .nav-links a.cta{display:inline-flex;align-items:center;gap:9px;font-weight:500;color:var(--ink);padding-bottom:3px}
  .nav-links a.cta::after{content:"";width:7px;height:7px;border-radius:50%;background:var(--brass);transition:transform .3s var(--ease)}
  .nav-links a.cta:hover::after{transform:scale(1.55)}
  .nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px;color:var(--ink)}

  /* ============ Hero (left-aligned) ============ */
  .hero{position:relative;overflow:hidden;padding:118px 0 104px}
  .hero .wrap{position:relative;z-index:2}
  .hero-art{position:absolute;right:-3%;top:50%;transform:translateY(-50%);z-index:1;pointer-events:none;font-family:var(--serif);font-weight:600;font-size:min(46vw,600px);line-height:.7;color:var(--ink);opacity:0;transition:opacity 2s ease;will-change:transform,opacity}
  .hero-art.in{opacity:.05}
  .hero .index{display:flex;align-items:center;gap:16px;font-family:var(--sans);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:40px}
  .hero .index::before{content:"";width:0;height:1px;background:var(--brass);transition:width 1s var(--ease) .15s}
  .hero .index.in::before{width:50px}
  .hero h1{max-width:17ch;margin-bottom:36px}
  .hero h1 .accent{font-style:italic;font-weight:600}
  .hero .lead{max-width:52ch;margin-bottom:46px}
  .hero-cta{display:inline-flex;align-items:center;gap:30px;flex-wrap:wrap}
  .btn{display:inline-flex;align-items:center;gap:12px;font-family:var(--sans);font-weight:600;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ivory);background:var(--ink);padding:18px 34px;transition:background .3s var(--ease),transform .3s var(--ease),gap .3s var(--ease)}
  .btn:hover{background:var(--brass-deep);transform:translateY(-2px);gap:17px}
  .btn svg{width:15px;height:15px}
  .ghost{display:inline-flex;align-items:center;gap:10px;font-size:.92rem;color:var(--ink);border-bottom:1px solid var(--ink);padding-bottom:6px;transition:gap .3s var(--ease),color .3s,border-color .3s}
  .ghost svg{width:15px;height:15px;transition:transform .3s var(--ease)}
  .ghost:hover{gap:15px;color:var(--brass-deep);border-color:var(--brass)}

  /* ============ Credibility ============ */
  .creds{padding:62px 0;border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);background:var(--paper)}
  .creds-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:48px}
  .cred{padding-left:28px;border-left:1px solid var(--line)}
  .cred .k{font-family:var(--serif);font-weight:600;font-size:1.85rem;margin-bottom:12px;line-height:1.08}
  .cred p{font-size:.97rem;color:var(--muted);line-height:1.6}

  /* ============ Section frame ============ */
  section.block{padding:74px 0}
  .head{display:grid;grid-template-columns:1fr 1.05fr;gap:56px;align-items:end;margin-bottom:48px}
  .head .label{display:block;margin-bottom:22px}
  .head h2{max-width:15ch}
  .head .intro{color:var(--muted);font-size:1.06rem;max-width:46ch;align-self:end}

  /* practices - aligned table */
  .practice{display:grid;grid-template-columns:56px minmax(220px,1fr) 1.55fr;gap:40px;align-items:start;padding:40px 0;border-top:1px solid var(--line);position:relative}
  .practice:last-child{border-bottom:1px solid var(--line)}
  .practice::before{content:"";position:absolute;left:0;top:-1px;height:1px;width:0;background:var(--brass);transition:width .55s var(--ease)}
  .practice:hover::before{width:100%}
  .practice .no{font-family:var(--serif);font-style:italic;font-size:1.5rem;color:var(--brass-deep);line-height:1.1}
  .practice h3{transition:color .3s var(--ease)}
  .practice .desc{color:var(--muted);font-size:1.05rem;line-height:1.62}
  .practice:hover h3{color:var(--brass-deep)}

  /* interlude (navy) */
  .interlude{background:var(--navy);color:var(--ivory);padding:130px 0;text-align:center;position:relative;overflow:hidden}
  .sig-N{font-family:var(--serif);font-weight:600;font-size:4.2rem;line-height:.9;color:var(--brass-light);display:inline-block;position:relative;margin-bottom:40px;opacity:0;transform:translateY(18px);transition:opacity 1.1s var(--ease),transform 1.1s var(--ease)}
  .sig-N::after{content:"";position:absolute;left:50%;bottom:-14px;width:0;height:1px;background:var(--brass-light);transform:translateX(-50%);transition:width 1s var(--ease) .35s}
  .sig-N.in{opacity:1;transform:none}
  .sig-N.in::after{width:48px}
  .interlude .label{color:var(--brass-light);display:block;margin-bottom:30px}
  .interlude q{font-family:var(--serif);font-weight:500;font-size:clamp(2rem,4.2vw,3.4rem);line-height:1.22;quotes:none;display:block;max-width:24ch;margin:0 auto;color:var(--ivory)}
  .interlude q .serif-it{color:var(--brass-light)}

  /* engagement */
  .engage{background:var(--ivory-2)}
  .steps{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:6px}
  .step{padding:46px 40px 10px 0;border-top:1px solid var(--line);position:relative}
  .step+.step{padding-left:48px;border-left:1px solid var(--line)}
  .step::before{content:"";position:absolute;left:0;top:-1px;height:1px;width:0;background:var(--brass);transition:width .6s var(--ease)}
  .step.in::before{width:60%}
  .step .sn{font-family:var(--serif);font-style:italic;font-size:1.35rem;color:var(--brass-deep);margin-bottom:22px}
  .step h3{margin-bottom:15px}
  .step p{color:var(--muted);font-size:1rem;line-height:1.62}
  .step+.step::before{left:48px}
  .engage-note{margin-top:56px;font-family:var(--serif);font-style:italic;font-size:clamp(1.05rem,2.6vw,1.7rem);color:var(--ink-soft);text-align:center;white-space:nowrap}

  /* why / proof */
  .why{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
  .why .checks{list-style:none;padding:0;margin:34px 0 0}
  .why .checks li{padding:22px 0;border-top:1px solid var(--line);display:grid;grid-template-columns:160px 1fr;gap:20px;align-items:baseline}
  .why .checks li:last-child{border-bottom:1px solid var(--line)}
  .why .checks .t{font-family:var(--serif);font-weight:600;font-size:1.3rem}
  .why .checks .d{color:var(--muted);font-size:1rem}
  .casestudy{background:var(--paper);border:1px solid var(--line);border-top:2px solid var(--brass);padding:48px}
  .casestudy .label{display:block;margin-bottom:26px}
  .casestudy h3{font-size:1.9rem;line-height:1.2;margin-bottom:20px}
  .casestudy p{color:var(--muted);font-size:1.04rem;line-height:1.64;margin-bottom:30px}

  /* closing (navy) */
  .closing{background:var(--navy);color:var(--ivory);padding:132px 0;text-align:center;position:relative;overflow:hidden}
  .closing .label{color:var(--brass-light);display:block;margin-bottom:28px}
  .closing h2{color:var(--ivory);font-size:clamp(2.5rem,5vw,4.2rem);max-width:18ch;margin:0 auto 26px}
  .closing p{color:rgba(244,240,231,.64);font-size:1.14rem;max-width:46ch;margin:0 auto 16px}
  .closing .byintro{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(244,240,231,.45);margin-bottom:44px}
  .closing .btn{background:var(--brass);color:var(--navy)}
  .closing .btn:hover{background:var(--ivory)}

  /* footer */
  footer.site{background:var(--navy-deep);color:rgba(244,240,231,.7);padding:46px 0 30px}
  .foot-top{display:flex;justify-content:space-between;align-items:flex-start;gap:40px;flex-wrap:wrap;margin-bottom:34px}
  .foot-top .brand .mk{color:var(--ivory);border-right-color:rgba(194,162,113,.5)}
  .foot-top .brand .wm .w{color:var(--ivory)}
  .foot-top .brand .wm .t{color:rgba(244,240,231,.5)}
  .foot-links{display:flex;gap:38px;flex-wrap:wrap}
  .foot-links a{font-size:.85rem;letter-spacing:.04em;color:rgba(244,240,231,.72)}
  .foot-links a.ul::after{background:var(--brass-light)}
  .foot-links a:hover{color:var(--ivory)}
  .foot-bottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-top:26px;border-top:1px solid var(--line-d2);font-size:.8rem;color:rgba(244,240,231,.45);letter-spacing:.02em}
  .foot-bottom a:hover{color:var(--ivory)}

  /* reveal */
  .reveal{opacity:0;transform:translateY(26px);transition:opacity 1.05s var(--ease),transform 1.05s var(--ease)}
  .reveal.in{opacity:1;transform:none}
  .reveal-x{opacity:0;transform:translateX(-22px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
  .reveal-x.in{opacity:1;transform:none}
  html.reveal-done .reveal,html.reveal-done .reveal-x{opacity:1 !important;transform:none !important;transition:none !important}
  html.reveal-done .sig-N{opacity:1 !important;transform:none !important;transition:none !important}
  html.reveal-done .sig-N::after{width:48px !important;transition:none !important}
  html.reveal-done .hero-art{opacity:.05 !important;transition:none !important}
  html.reveal-done .hero .index::before{width:50px !important;transition:none !important}
  html.reveal-done .step::before{width:60% !important;transition:none !important}
  @media(prefers-reduced-motion:reduce){
    .reveal,.reveal-x,.sig-N{opacity:1;transform:none;transition:none}
    .sig-N::after{width:48px}.hero-art{opacity:.05}.hero .index::before{width:50px}.step::before{width:60%}
  }

  @media(max-width:920px){
    .wrap{padding:0 26px}
    .creds-grid,.steps,.why,.head{grid-template-columns:1fr;gap:34px}
    .step+.step{padding-left:0;border-left:0}.step{padding:34px 0 0}.step+.step::before{left:0}
    .practice{grid-template-columns:auto 1fr;gap:16px 24px}.practice .desc{grid-column:1 / -1}
    .why .checks li{grid-template-columns:1fr;gap:5px}
    .nav-links{display:none}.nav-toggle{display:block}
    .hero{padding:78px 0 68px}.hero-art{opacity:.04}
    section.block{padding:74px 0}.interlude,.closing{padding:90px 0}
    .brand .wm .w{font-size:1.26rem}.brand .mk{font-size:2.3rem}
  }


/* ======================= SUB-PAGE SYSTEM (distinct per page) ======================= */

/* hero watermark N (bold, faint, parallax) */
.hero-N{position:absolute;top:50%;left:78%;transform:translate(-50%,-50%);font-family:var(--serif);font-weight:600;font-size:min(38vw,460px);line-height:.7;color:var(--ink);opacity:.05;z-index:0;pointer-events:none;user-select:none}
@media(max-width:860px){.hero-N{opacity:.045;left:86%}}

/* page intro shared bits */
.eyebrow{display:inline-flex;align-items:center;gap:16px;font-family:var(--sans);font-weight:600;font-size:.7rem;letter-spacing:.26em;text-transform:uppercase;color:var(--brass-deep)}
.eyebrow::before{content:"";width:0;height:1px;background:var(--brass);transition:width 1s var(--ease) .15s}
.eyebrow.in::before,html.reveal-done .eyebrow::before{width:46px !important}

/* reveal scale variant */
.reveal-s{opacity:0;transform:translateY(30px) scale(.985);transition:opacity 1.05s var(--ease),transform 1.05s var(--ease)}
.reveal-s.in{opacity:1;transform:none}
html.reveal-done .reveal-s{opacity:1 !important;transform:none !important;transition:none !important}

/* ============ SERVICES - sticky rail + index ============ */
.svc-hero{position:relative;overflow:hidden;padding:60px 0 54px;border-bottom:1px solid var(--line-soft)}
.svc-hero .wrap{position:relative;z-index:2}
.svc-hero .eyebrow{margin-bottom:26px}
.svc-hero .htop{display:grid;grid-template-columns:1.12fr .88fr;gap:58px;align-items:start}
.svc-hero h1{font-size:clamp(2.6rem,5vw,4.6rem);max-width:13ch;line-height:1.04;margin:0}
.svc-hero .hright{padding-top:8px}
.svc-hero .hright .lead{max-width:42ch;margin-bottom:30px}
.svc-hero .toc-label{display:block;font-family:var(--sans);font-weight:600;text-transform:uppercase;letter-spacing:.2em;font-size:.62rem;color:var(--muted);margin-bottom:6px}
.svc-hero .idxlist{list-style:none;margin:0;padding:0}
.svc-hero .idxlist li{border-top:1px solid var(--line)}
.svc-hero .idxlist li:last-child{border-bottom:1px solid var(--line)}
.svc-hero .idxlist li a{display:grid;grid-template-columns:22px 1fr;gap:12px;align-items:baseline;padding:13px 0;color:var(--ink-soft);font-size:.98rem;transition:color .25s var(--ease),padding-left .25s var(--ease)}
.svc-hero .idxlist li a:hover{color:var(--brass-deep);padding-left:7px}
.svc-hero .idxlist .n{font-family:var(--serif);font-style:italic;font-weight:600;color:var(--brass-deep)}
.svc-intro{color:var(--ink-soft);font-size:1.14rem;line-height:1.62;max-width:54ch;margin-bottom:26px}
.svc-build{border-top:1px solid var(--line);padding-top:24px}
.svc-build .mini{display:block;font-family:var(--sans);font-weight:600;text-transform:uppercase;letter-spacing:.16em;font-size:.68rem;color:var(--brass-deep);margin-bottom:12px}
.svc-build p{color:var(--ink-soft);font-size:1.06rem;line-height:1.62;max-width:56ch}
.svc-outcome{display:flex;gap:16px;align-items:baseline;margin-top:26px;font-family:var(--serif);font-style:italic;font-size:1.45rem;line-height:1.3;color:var(--ink);max-width:46ch}
.svc-outcome .arr{flex:0 0 auto;color:var(--brass);font-style:normal}

.svc-layout{display:grid;grid-template-columns:minmax(216px,280px) 1fr;gap:0;align-items:start}
.svc-rail{position:sticky;top:124px;padding:8px 0}
.svc-rail ol{list-style:none;margin:0;padding:0}
.svc-rail li a{display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:baseline;padding:18px 0;border-top:1px solid var(--line);color:var(--muted);transition:color .3s var(--ease),padding-left .3s var(--ease)}
.svc-rail li:last-child a{border-bottom:1px solid var(--line)}
.svc-rail li a .rn{font-family:var(--serif);font-style:italic;font-size:1.05rem;color:var(--brass-deep);transition:color .3s}
.svc-rail li a .rt{font-family:var(--serif);font-size:1.35rem;line-height:1.15;transition:color .3s}
.svc-rail li a.active{color:var(--ink);padding-left:14px}
.svc-rail li a.active .rt{color:var(--ink)}
.svc-rail li a.active .rn{color:var(--brass)}
.svc-rail li a::after{content:"";grid-column:2;height:1px;width:0;background:var(--brass);transition:width .4s var(--ease)}
.svc-rail li a.active::after{width:40px}

.svc-stack{border-left:1px solid var(--line);padding-left:0}
.svc-area{padding:84px 0 84px 52px;border-top:1px solid var(--line);position:relative}
.svc-area:first-child{border-top:0}
.svc-area .big{display:none}
.svc-area .inner{position:relative;z-index:1}
.svc-area h2{font-size:clamp(2rem,3.4vw,3rem);margin-bottom:12px}
.svc-area .model{font-family:var(--serif);font-style:italic;font-size:1.3rem;color:var(--muted);margin-bottom:34px}
.svc-rows{border-top:1px solid var(--line)}
.svc-row{border-bottom:1px solid var(--line);cursor:pointer}
.svc-row .rhead{display:grid;grid-template-columns:1fr auto;gap:20px;align-items:center;padding:22px 0}
.svc-row .rk{font-family:var(--sans);font-weight:600;text-transform:uppercase;letter-spacing:.14em;font-size:.72rem;color:var(--brass-deep)}
.svc-row .ric{width:22px;height:22px;position:relative;flex:0 0 auto}
.svc-row .ric::before,.svc-row .ric::after{content:"";position:absolute;background:var(--brass);transition:transform .35s var(--ease),opacity .35s}
.svc-row .ric::before{top:50%;left:0;width:100%;height:1.5px;transform:translateY(-50%)}
.svc-row .ric::after{left:50%;top:0;height:100%;width:1.5px;transform:translateX(-50%)}
.svc-row.open .ric::after{transform:translateX(-50%) scaleY(0);opacity:0}
.svc-row .rbody{overflow:hidden;max-height:0;transition:max-height .5s var(--ease),opacity .4s var(--ease);opacity:0}
.svc-row.open .rbody{max-height:240px;opacity:1}
.svc-row .rbody p{color:var(--ink-soft);font-size:1.08rem;line-height:1.64;padding-bottom:24px;max-width:60ch}
.svc-area .tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:30px}
.svc-area .tags span{font-size:.8rem;color:var(--muted);border:1px solid var(--line);padding:6px 14px;border-radius:999px;transition:border-color .3s,color .3s}
.svc-area:hover .tags span{border-color:var(--brass)}

/* engagement ladder on navy */
.engage-dark{background:var(--navy);color:var(--ivory);position:relative;overflow:hidden}
.engage-dark .head h2,.engage-dark .head .label{color:var(--ivory)}
.engage-dark .head .label{color:var(--brass-light)}
.engage-dark .head .intro{color:rgba(244,240,231,.6)}
.ladder{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:8px;position:relative;z-index:2}
.ladder .rung{padding:42px 36px 36px 0;border-top:2px solid var(--brass)}
.ladder .rung+.rung{padding-left:40px;border-left:1px solid var(--line-d)}
.ladder .rung .rn{font-family:var(--serif);font-style:italic;font-size:1.2rem;color:var(--brass-light);margin-bottom:18px}
.ladder .rung h3{margin-bottom:12px;color:var(--ivory)}
.ladder .rung p{color:rgba(244,240,231,.62);font-size:.98rem;line-height:1.6;margin-bottom:18px}
.ladder .rung .rng{font-family:var(--serif);font-size:1.5rem;color:var(--ivory)}
.ladder .rung .rng small{font-family:var(--sans);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(244,240,231,.5);display:block;margin-top:4px}
.engage-dark .engage-note{color:rgba(244,240,231,.82)}

/* ============ APPROACH - split hero + manifesto ============ */
.apr-hero{position:relative;overflow:hidden;padding:58px 0 70px;border-bottom:1px solid var(--line-soft)}
.apr-hero .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.15fr .85fr;gap:64px;align-items:center}
.apr-hero .eyebrow{margin-bottom:28px}
.apr-hero h1{font-size:clamp(2.9rem,6vw,5.6rem);line-height:1;margin-bottom:24px}
.apr-hero .lead{max-width:46ch}
.apr-cards{display:grid;gap:18px}
.apr-card{border:1px solid var(--line);border-left:2px solid var(--brass);background:var(--paper);padding:28px 30px;transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.apr-card:hover{transform:translateY(-4px);box-shadow:0 24px 50px -30px rgba(28,33,51,.4)}
.apr-card .ct{font-family:var(--sans);font-weight:600;text-transform:uppercase;letter-spacing:.18em;font-size:.66rem;color:var(--brass-deep);margin-bottom:12px}
.apr-card h3{font-size:1.5rem;margin-bottom:8px}
.apr-card p{color:var(--muted);font-size:.98rem;line-height:1.6}

.apr-split{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start}
.apr-split .colhead{font-family:var(--sans);font-weight:600;text-transform:uppercase;letter-spacing:.26em;font-size:.68rem;color:var(--brass-deep);margin-bottom:18px;display:block}
.apr-split h2{font-size:clamp(1.8rem,2.6vw,2.4rem);margin-bottom:20px}
.apr-split p{color:var(--ink-soft);font-size:1.08rem;line-height:1.72;margin-bottom:18px}

/* manifesto navy */
.manifesto{background:var(--navy);color:var(--ivory);padding:104px 0;position:relative;overflow:hidden;text-align:center}
.manifesto .wrap{position:relative;z-index:2}
.manifesto .sig-N{margin-bottom:34px}
.manifesto .label{color:var(--brass-light);display:block;margin-bottom:28px}
.manifesto q{font-family:var(--serif);font-weight:500;font-size:clamp(2.1rem,4.4vw,3.6rem);line-height:1.18;quotes:none;display:block;max-width:22ch;margin:0 auto;color:var(--ivory)}
.manifesto q .serif-it{color:var(--brass-light)}

/* principles hover-reveal */
.principles{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:8px}
.principle{border:1px solid var(--line);background:var(--paper);padding:38px 32px;position:relative;overflow:hidden;transition:border-color .35s}
.principle::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--brass);transition:width .5s var(--ease)}
.principle:hover{border-color:var(--brass)}
.principle:hover::after{width:100%}
.principle .pn{font-family:var(--serif);font-style:italic;color:var(--brass-deep);font-size:1.3rem;margin-bottom:18px}
.principle h3{margin-bottom:12px}
.principle p{color:var(--muted);font-size:1rem;line-height:1.64;margin-top:10px}

/* ============ RESULTS - counters + horizontal scroll ============ */
.res-hero{position:relative;overflow:hidden;padding:60px 0 56px;border-bottom:1px solid var(--line-soft)}
.res-hero .wrap{position:relative;z-index:2}
.res-hero .eyebrow{margin-bottom:28px}
.res-hero h1{font-size:clamp(2.8rem,6vw,5.4rem);max-width:15ch;margin-bottom:26px;line-height:1.02}
.res-hero .lead{max-width:52ch}

.htrack-head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap;margin-bottom:36px}
.hctrl{display:flex;align-items:center;gap:14px}
.hctrl button{width:50px;height:50px;border:1px solid var(--line);background:transparent;border-radius:50%;cursor:pointer;display:grid;place-items:center;color:var(--ink);transition:background .3s var(--ease),color .3s,border-color .3s}
.hctrl button:hover{background:var(--ink);color:var(--ivory);border-color:var(--ink)}
.hctrl button svg{width:18px;height:18px}
.htrack{display:flex;gap:28px;overflow-x:auto;scroll-snap-type:x mandatory;padding:8px 4px 30px;margin:0 -4px;scrollbar-width:none;cursor:grab}
.htrack::-webkit-scrollbar{display:none}
.htrack.grabbing{cursor:grabbing}
.hcard{scroll-snap-align:start;flex:0 0 min(560px,86vw);background:var(--paper);border:1px solid var(--line);border-top:2px solid var(--brass);padding:44px 44px 40px;display:flex;flex-direction:column}
.hcard .tag{font-family:var(--sans);font-weight:600;text-transform:uppercase;letter-spacing:.16em;font-size:.66rem;color:var(--brass-deep);margin-bottom:22px;display:block}
.hcard h2{font-size:clamp(1.6rem,2.4vw,2.1rem);line-height:1.16;margin-bottom:26px;max-width:20ch}
.hcard .metric{font-family:var(--serif);font-weight:600;font-size:clamp(2.6rem,4vw,3.6rem);line-height:1;color:var(--ink);margin-bottom:6px}
.hcard .munit{font-family:var(--sans);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--brass-deep);margin-bottom:30px}
.hcard .rows{margin-top:auto}
.hcard .row{display:grid;grid-template-columns:108px 1fr;gap:20px;padding:15px 0;border-top:1px solid var(--line-soft)}
.hcard .row .rk{font-weight:600;text-transform:uppercase;letter-spacing:.12em;font-size:.64rem;color:var(--brass-deep);padding-top:3px}
.hcard .row .rv{color:var(--ink-soft);font-size:1rem;line-height:1.55}
.hprog{height:2px;background:var(--line);position:relative;overflow:hidden;margin-top:6px}
.hprog::before{content:"";position:absolute;inset:0;background:var(--line)}
.hbar{position:absolute;inset:0;background:var(--brass);transform-origin:left;transform:scaleX(.06);transition:transform .15s linear;z-index:1}

/* results navy stat band */
.statband{background:var(--navy);color:var(--ivory);position:relative;overflow:hidden}
.statband .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:48px;position:relative;z-index:2}
.statband .stat{border-left:1px solid var(--line-d);padding-left:28px}
.statband .stat .n{font-family:var(--serif);font-weight:600;font-size:clamp(2.6rem,4.4vw,4rem);line-height:1;color:var(--ivory);margin-bottom:14px}
.statband .stat .l{color:rgba(244,240,231,.62);font-size:1rem;line-height:1.5}

/* hairline between adjacent navy sections */
.engage-dark + .closing,.statband + .closing{border-top:1px solid rgba(194,162,113,.28)}

/* ============ CONTACT - immersive ============ */
.con-hero{position:relative;overflow:hidden;padding:60px 0 48px}
.con-hero .wrap{position:relative;z-index:2}
.con-hero .eyebrow{margin-bottom:28px}
.con-hero h1{font-size:clamp(2.8rem,6vw,5.2rem);max-width:16ch;margin-bottom:24px;line-height:1.02}
.con-hero .lead{max-width:50ch}
.contact{display:grid;grid-template-columns:1fr 1.1fr;gap:64px;align-items:start;padding-bottom:30px}
.contact .info h2{font-size:clamp(1.9rem,2.8vw,2.5rem);margin-bottom:18px}
.contact .info p{color:var(--ink-soft);font-size:1.08rem;line-height:1.7;margin-bottom:20px;max-width:44ch}
.contact .info .mail{display:inline-flex;align-items:center;gap:10px;font-size:1.05rem;color:var(--ink);border-bottom:1px solid var(--brass);padding-bottom:4px;transition:color .25s}
.contact .info .mail:hover{color:var(--brass-deep)}
.contact .info .promise{margin-top:30px;padding-top:24px;border-top:1px solid var(--line);font-family:var(--serif);font-style:italic;font-size:1.3rem;color:var(--ink-soft);max-width:32ch}
.contact .steps3{margin-top:34px;display:grid;gap:0}
.contact .s3{display:grid;grid-template-columns:auto 1fr;gap:18px;padding:16px 0;border-top:1px solid var(--line)}
.contact .s3:last-child{border-bottom:1px solid var(--line)}
.contact .s3 .sn{font-family:var(--serif);font-style:italic;color:var(--brass-deep);font-size:1.1rem}
.contact .s3 p{font-size:.98rem;color:var(--muted);margin:0;line-height:1.5}
.cal{border:1px solid var(--line);border-top:2px solid var(--brass);background:var(--paper);overflow:hidden;border-radius:2px}
.cal iframe{width:100%;height:700px;border:0;display:block}

@media(max-width:860px){
  .svc-hero .htop{grid-template-columns:1fr;gap:28px}
  .svc-layout{grid-template-columns:1fr}
  .svc-rail{display:none}
  .svc-stack{border-left:0}
  .svc-area{padding:54px 0;border-top:1px solid var(--line)}
  .svc-area .big{left:0;font-size:6rem}
  .apr-hero .wrap,.apr-split,.principles,.ladder,.statband .grid{grid-template-columns:1fr;gap:30px}
  .ladder .rung+.rung{padding-left:0;border-left:0}
  .ladder .rung{padding:30px 0}
  .contact{grid-template-columns:1fr;gap:30px}
  .statband .stat{border-left:0;padding-left:0;border-top:1px solid var(--line-d);padding-top:22px}
  .motif .drawn{opacity:.5}
  .cal iframe{height:760px}
}
