/* ============================================================
   NOYAN CAPITAL — "Tide & Horizon" cinematic layer (Direction A)
   Full-bleed imagery, scroll parallax, transparent→solid nav.
   Loads AFTER site.css. Reuses site.css utilities for paper
   content (eyebrow, h2/h3, prose, principle, faq, form, register).
   ============================================================ */

body.tide{background:var(--forest-deep);color:var(--ink)}
body.tide main{background:var(--paper)}

/* ---------- NAV: transparent over hero, solid on scroll ---------- */
.tide .nav{
  position:fixed;left:0;right:0;top:0;z-index:60;
  background:transparent;border-bottom-color:transparent;
  backdrop-filter:none;-webkit-backdrop-filter:none;
  transition:background .45s ease,border-color .45s ease,backdrop-filter .45s ease,height .3s ease;
}
.tide .nav .wm-main{color:var(--paper);transition:color .45s ease}
.tide .nav .wm-main .y{color:var(--copper-light)}
.tide .nav .wm-sub{color:var(--copper-light);transition:color .45s ease}
.tide .nav-links a{color:rgba(244,241,232,.82)}
.tide .nav-links a:hover,.tide .nav-links a.active{color:#fff}
.tide .nav-links a.active::after{background:var(--copper-light)}
.tide .nav-links a.cta{color:var(--paper);border-color:rgba(244,241,232,.42)}
.tide .nav-links a.cta:hover{background:var(--paper);color:var(--forest);border-color:var(--paper)}
.tide .nav-toggle{color:var(--paper)}

.tide .nav.solid{
  background:color-mix(in srgb,var(--paper) 88%,transparent);
  backdrop-filter:blur(14px) saturate(1.1);-webkit-backdrop-filter:blur(14px) saturate(1.1);
  border-bottom-color:var(--line-soft);
}
.tide .nav.solid .wm-main{color:var(--forest)}
.tide .nav.solid .wm-main .y{color:var(--copper)}
.tide .nav.solid .wm-sub{color:var(--teal)}
.tide .nav.solid .nav-links a{color:var(--sage)}
.tide .nav.solid .nav-links a:hover,.tide .nav.solid .nav-links a.active{color:var(--forest)}
.tide .nav.solid .nav-links a.active::after{background:var(--copper)}
.tide .nav.solid .nav-links a.cta{color:var(--forest);border-color:var(--line)}
.tide .nav.solid .nav-links a.cta:hover{background:var(--forest);color:var(--paper);border-color:var(--forest)}
.tide .nav.solid .nav-toggle{color:var(--forest)}
@media(max-width:900px){
  .tide .nav-links{background:var(--forest-deep)}
  .tide .nav-links a{color:rgba(244,241,232,.9);border-bottom-color:var(--line-cream)}
  .tide .nav.solid .nav-links{background:var(--paper)}
  .tide .nav.solid .nav-links a{color:var(--forest)}
}

/* ---------- CINEMATIC HERO ---------- */
.tide-hero{position:relative;overflow:hidden;isolation:isolate;color:var(--paper);
  min-height:100vh;display:flex;align-items:flex-end}
.tide-hero.banner{min-height:74vh}
.tide-hero .bg{position:absolute;inset:-8% 0;z-index:0;background-size:cover;background-position:center;
  will-change:transform;transform:scale(1.12)}
.tide-hero .scrim{position:absolute;inset:0;z-index:1}
.tide-hero .scrim{background:
  linear-gradient(180deg,rgba(14,23,20,.58) 0%,rgba(14,23,20,.14) 40%,rgba(14,23,20,.92) 100%),
  linear-gradient(92deg,rgba(14,23,20,.62) 0%,rgba(14,23,20,0) 58%)}
.tide-hero .inner{position:relative;z-index:2;width:100%;max-width:var(--maxw);margin:0 auto;
  padding:0 var(--pad) clamp(3rem,9vh,6rem)}
.tide-hero.banner .inner{padding-bottom:clamp(2.6rem,7vh,4.4rem)}
.tide-hero .h1mark{font-family:var(--mono);font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--copper-light);display:flex;align-items:center;gap:1em;margin-bottom:1.6rem}
.tide-hero .h1mark::before{content:"";width:46px;height:1px;background:var(--copper-light)}
.tide-hero h1{font-family:var(--serif);font-weight:500;letter-spacing:-.01em;line-height:.98;
  font-size:clamp(2.8rem,1.9rem + 6.4vw,7.6rem);max-width:18ch;text-wrap:balance}
.tide-hero.banner h1{font-size:clamp(2.6rem,1.8rem + 4.6vw,5.4rem);max-width:15ch}
.tide-hero h1 em,.tide-hero h1 .amp{font-style:italic;color:var(--copper-light)}
.tide-hero .subhead{margin-top:1.8rem;font-size:clamp(1.05rem,.95rem + .6vw,1.4rem);
  color:rgba(244,241,232,.85);max-width:52ch;line-height:1.5}
.tide-hero .subhead.serif{font-family:var(--serif);font-style:italic;font-size:clamp(1.4rem,1.1rem + 1.4vw,2.2rem);color:var(--copper-light);line-height:1.3}

.scroll-cue{position:absolute;left:50%;bottom:1.8rem;transform:translateX(-50%);z-index:3;
  font-family:var(--mono);font-size:.6rem;letter-spacing:.24em;text-transform:uppercase;
  color:rgba(244,241,232,.6);display:flex;flex-direction:column;align-items:center;gap:8px}
.scroll-cue .l{width:1px;height:38px;background:linear-gradient(var(--copper-light),transparent)}
@media(prefers-reduced-motion:no-preference){.scroll-cue .l{animation:tcue 2.2s ease-in-out infinite}}
@keyframes tcue{0%,100%{opacity:.3;transform:scaleY(.55);transform-origin:top}50%{opacity:1;transform:scaleY(1);transform-origin:top}}

/* ---------- DARK IMAGE SCENE (split copy / parallax media) ---------- */
.tide-scene{position:relative;display:grid;grid-template-columns:1fr 1fr;min-height:88vh;
  align-items:stretch;background:var(--forest-deep);color:var(--paper);isolation:isolate}
.tide-scene .media{position:relative;overflow:hidden}
.tide-scene .media .bg{position:absolute;inset:-12% 0;background-size:cover;background-position:center;will-change:transform}
.tide-scene .media .tint{position:absolute;inset:0;background:linear-gradient(90deg,rgba(14,23,20,.35),rgba(14,23,20,.05))}
.tide-scene .copy{display:flex;flex-direction:column;justify-content:center;
  padding:clamp(3rem,8vw,7rem) clamp(2rem,6vw,6rem)}
.tide-scene.flip .media{order:2}.tide-scene.flip .copy{order:1}
.tide-scene .eyb{font-family:var(--mono);font-size:.7rem;letter-spacing:.26em;text-transform:uppercase;
  color:var(--copper-light);margin-bottom:1.4rem;display:flex;align-items:center;gap:.8em}
.tide-scene .eyb::before{content:"";width:30px;height:1px;background:var(--copper-light)}
.tide-scene h2{font-family:var(--serif);font-weight:500;font-size:clamp(2.1rem,1.5rem + 2.4vw,3.6rem);
  line-height:1.06;letter-spacing:-.01em;margin-bottom:1.4rem}
.tide-scene h2 em{font-style:italic;color:var(--copper-light)}
.tide-scene p{color:rgba(244,241,232,.8);max-width:48ch;line-height:1.6;font-size:1.05rem}
.tide-scene p + p{margin-top:1.1rem}
.tide-scene .btn{margin-top:2rem;align-self:flex-start;border-color:rgba(244,241,232,.4);color:var(--paper)}
.tide-scene .btn:hover{background:var(--copper);border-color:var(--copper);color:var(--forest-deep)}
@media(max-width:860px){
  .tide-scene{grid-template-columns:1fr}
  .tide-scene .media{min-height:52vh;order:0 !important}
  .tide-scene .copy{order:0 !important;padding-block:clamp(2.6rem,8vw,4rem)}
}

/* ---------- FULL-BLEED IMAGE QUOTE / FEATURE BAND ---------- */
.imgband{position:relative;overflow:hidden;isolation:isolate;color:var(--paper);
  min-height:64vh;display:flex;align-items:center}
.imgband .bg{position:absolute;inset:-10% 0;z-index:0;background-size:cover;background-position:center;will-change:transform}
.imgband .scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(14,23,20,.9),rgba(14,23,20,.5) 60%,rgba(14,23,20,.25))}
.imgband .inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:clamp(3.5rem,9vh,6rem) var(--pad);width:100%}
.imgband .eyb{font-family:var(--mono);font-size:.7rem;letter-spacing:.26em;text-transform:uppercase;color:var(--copper-light);margin-bottom:1.6rem}
.imgband .q{font-family:var(--serif);font-weight:500;font-size:clamp(2rem,1.4rem + 2.8vw,3.8rem);line-height:1.1;letter-spacing:-.01em;max-width:18ch;text-wrap:balance}
.imgband .q em{font-style:italic;color:var(--copper-light)}
.imgband .sub{margin-top:1.6rem;color:rgba(244,241,232,.82);max-width:54ch;line-height:1.6}

/* ---------- image figure (for paper sections) ---------- */
.tide-fig{position:relative;width:100%;aspect-ratio:4/3;overflow:hidden;border-radius:3px}
.tide-fig.tall{aspect-ratio:3/4}
.tide-fig img{width:100%;height:100%;object-fit:cover;display:block}
.tide-fig figcaption{position:absolute;left:0;bottom:0;font-family:var(--mono);font-size:.62rem;
  letter-spacing:.14em;text-transform:uppercase;color:var(--paper);background:rgba(14,23,20,.62);padding:.5rem .8rem}
/* honest portrait placeholder */
.portrait-ph{position:relative;width:100%;aspect-ratio:3/4;border-radius:3px;overflow:hidden;
  background:#1d2c27;background-image:repeating-linear-gradient(135deg,transparent 0,transparent 13px,rgba(198,138,77,.10) 13px,rgba(198,138,77,.10) 14px);
  border:1px solid var(--line-cream);display:flex;align-items:flex-end;padding:1.2rem}
.portrait-ph span{font-family:var(--mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(244,241,232,.6)}

/* ---------- FOOTER ---------- */
.tide-foot{background:var(--forest-deep);color:var(--paper);position:relative;overflow:hidden}
.tide-foot .glow{position:absolute;inset:auto -8% -50% auto;width:50%;aspect-ratio:1;
  background:radial-gradient(circle,rgba(198,138,77,.16),transparent 65%);z-index:0;pointer-events:none}
.tide-foot .inner{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;padding:clamp(3.5rem,8vh,5.5rem) var(--pad) 2.4rem;
  display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:clamp(2rem,5vw,4rem)}
.tide-foot .ff-brand .wordmark{margin-bottom:1.4rem}
.tide-foot .ff-brand .wordmark .wm-main{color:var(--paper);font-size:2.2rem}
.tide-foot .ff-brand .wordmark .wm-main .y{color:var(--copper-light)}
.tide-foot .ff-brand .wordmark .wm-sub{color:var(--copper-light);font-size:0.64rem;letter-spacing:0.5em}
.tide-foot .ff-base a{color:inherit;font-size:inherit;letter-spacing:inherit;text-decoration:none}
.tide-foot .ff-base a:hover{text-decoration:underline}
.tide-foot .tagline{font-family:var(--serif);font-size:clamp(1.5rem,1.2rem + 1.2vw,2.1rem);line-height:1.1;max-width:14ch;color:var(--paper)}
.tide-foot .tagline em{font-style:italic;color:var(--copper-light)}
.tide-foot h4{font-family:var(--mono);font-size:.66rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--copper-light);margin-bottom:1.2rem}
.tide-foot ul{list-style:none}
.tide-foot li{margin-bottom:.7rem}
.tide-foot a{color:rgba(244,241,232,.78);font-size:.92rem;transition:color .2s;border-bottom:1px solid transparent;padding-bottom:1px}
.tide-foot a:hover{color:#fff;border-color:var(--copper-light)}
.tide-foot .ff-base{position:relative;z-index:1;border-top:1px solid var(--line-cream);
  max-width:var(--maxw);margin:0 auto;padding:1.6rem var(--pad);display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;
  font-family:var(--mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(244,241,232,.5)}
@media(max-width:760px){.tide-foot .inner{grid-template-columns:1fr 1fr}.tide-foot .ff-brand{grid-column:1/-1}}

/* ============================================================
   COMPOUNDING SPINE (Direction C) — used on Approach
   ============================================================ */
body.spine-page{background:var(--forest-deep);color:var(--paper)}
.spine-wrap{position:relative}
.spine{position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none;overflow:visible}
.spine .track{fill:none;stroke:rgba(244,241,232,.12);stroke-width:1.5;vector-effect:non-scaling-stroke}
.spine .draw{fill:none;stroke:var(--copper-light);stroke-width:2;vector-effect:non-scaling-stroke;
  filter:drop-shadow(0 0 8px rgba(198,138,77,.6));stroke-linecap:round}
.spine .tip{fill:var(--copper-light);filter:drop-shadow(0 0 10px rgba(198,138,77,.9))}
.spine .node{fill:var(--forest-deep);stroke:rgba(244,241,232,.3);stroke-width:1.5;vector-effect:non-scaling-stroke;transition:stroke .4s}
.spine .node.lit{stroke:var(--copper-light)}
.spine .nodefill{fill:var(--copper-light);opacity:0;transition:opacity .4s}
.spine .nodefill.lit{opacity:1}
.spine-sec{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad)}
.spine-sec .pad{padding-left:clamp(0px,14vw,220px)}
@media(max-width:820px){.spine-sec .pad{padding-left:42px}}

.spine-node-sec{padding-block:clamp(3rem,8vh,6rem)}
.spine-node-sec .no{font-family:var(--mono);font-size:.8rem;letter-spacing:.16em;color:var(--copper-light);margin-bottom:.9rem}
.spine-node-sec h2{font-family:var(--serif);font-weight:500;font-size:clamp(2rem,1.4rem + 2.6vw,3.8rem);line-height:1.04;letter-spacing:-.01em;margin-bottom:1rem}
.spine-node-sec h2 em{font-style:italic;color:var(--copper-light)}
.spine-node-sec p{font-size:clamp(1.02rem,.98rem + .4vw,1.25rem);color:rgba(244,241,232,.78);max-width:48ch;line-height:1.55}
.spine-node-sec .stat{font-family:var(--serif);font-size:clamp(2.6rem,1.8rem + 3vw,4.6rem);font-weight:500;color:var(--copper-light);line-height:1;margin-top:.8rem}

/* ---------- reveal tuning for dark scenes (uses site.css .reveal) ---------- */
.tide-scene .reveal,.imgband .reveal,.spine-wrap .reveal{}

/* ============================================================
   Button animations — copper CTA + theme-green running sweep,
   and the contact-link pills (mail / phone). Kept from earlier work.
   ============================================================ */
.tide .nav-links a.cta,.tide .nav.solid .nav-links a.cta{
  color:#fff;background:var(--copper);border-color:var(--copper);
  position:relative;overflow:hidden;
}
.tide .nav-links a.cta:hover,.tide .nav.solid .nav-links a.cta:hover{background:#8a5524;border-color:#8a5524;color:#fff}
@keyframes glint-sweep{0%{left:-60%}40%,100%{left:120%}}
.glint{position:relative;overflow:hidden}
.tide .nav-links a.cta::before,.glint::before{
  content:"";position:absolute;top:-20%;left:-60%;width:40%;height:140%;
  background:linear-gradient(90deg,transparent,rgba(60,88,82,0.55),transparent);
  transform:skewX(-20deg);animation:glint-sweep 2.4s ease-in-out infinite;pointer-events:none;
}
.contact-link{
  display:inline-block;color:var(--teal);border:1px solid rgba(60,88,82,0.5);
  padding:0.62rem 1.25rem;border-radius:2px;
  font-family:var(--sans);font-size:0.9rem;letter-spacing:0.04em;font-weight:500;
  text-decoration:none;cursor:pointer;background:transparent;
  transition:all .2s ease;position:relative;overflow:hidden;
}
.contact-link::before{
  content:"";position:absolute;top:-20%;left:-60%;width:40%;height:140%;
  background:linear-gradient(90deg,transparent,rgba(60,88,82,0.45),transparent);
  transform:skewX(-20deg);animation:glint-sweep 2s ease-in-out infinite;pointer-events:none;
}
.contact-link:last-of-type::before{animation-delay:-1.5s}
.contact-link:hover{color:var(--paper);background:var(--teal);border-color:var(--teal)}
@media(prefers-reduced-motion:reduce){.tide .nav-links a.cta::before,.glint::before,.contact-link::before{animation:none;display:none}}

/* ============================================================
   Language toggle — flag + dropdown (copper caret, green when active/open)
   ============================================================ */
.lang{position:relative;margin-left:.7rem}
.lang>summary{list-style:none;cursor:pointer;display:inline-flex;align-items:center;gap:.42rem;padding:.3rem .1rem}
.lang>summary::-webkit-details-marker{display:none}
.lang>summary::marker{content:""}
.lang .flag{width:24px;height:16px;border-radius:2px;object-fit:cover;display:block;box-shadow:0 0 0 1px rgba(255,255,255,.35),0 1px 3px rgba(0,0,0,.25)}
.lang .caret{width:10px;height:7px;transition:transform .2s ease}
.lang .caret path{fill:none;stroke:var(--copper);stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;transition:stroke .2s ease}
.lang[open] .caret{transform:rotate(180deg)}
.lang[open] .caret path{stroke:var(--teal)}            /* greenish when open */
.tide .nav.solid .lang .caret path{stroke:var(--copper)}
.tide .nav.solid .lang[open] .caret path{stroke:var(--teal)}
.lang-menu{position:absolute;right:0;top:calc(100% + .55rem);min-width:58px;
  background:color-mix(in srgb,var(--paper) 97%,transparent);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border:1px solid var(--line);border-radius:7px;padding:.32rem;
  display:flex;flex-direction:column;gap:.22rem;
  box-shadow:0 14px 34px -14px rgba(14,23,20,.45);z-index:80}
.lang-menu a{display:flex;align-items:center;justify-content:center;padding:.36rem .5rem;
  border-radius:5px;border:1px solid transparent;transition:background .15s,border-color .15s}
.lang-menu a:hover{background:var(--paper-2)}
.lang-menu a.cur{border-color:var(--teal);background:color-mix(in srgb,var(--teal) 14%,transparent)} /* greenish = active language */
@media(max-width:900px){
  .lang{margin-left:0;width:100%;border-top:1px solid var(--line-soft);margin-top:.4rem;padding-top:.4rem}
  .lang>summary{justify-content:flex-start;padding:.6rem 0}
  .lang-menu{position:static;right:auto;left:auto;flex-direction:row;gap:.5rem;box-shadow:none;background:transparent;border:0;backdrop-filter:none;-webkit-backdrop-filter:none;padding:.2rem 0 .4rem;margin-top:.2rem}
  .lang-menu a{padding:.4rem .6rem}
}

/* ============================================================
   REGISTER — pinned horizontal gallery (Businesses page)
   Section pins; three company panels glide sideways on scroll.
   Falls back to a vertical stack on mobile / reduced-motion.
   ============================================================ */
.reg-pin{position:relative;background:var(--forest-deep);color:var(--paper)}
.reg-stage{position:relative}
.reg-track{display:flex;flex-direction:column}
.reg-panel{position:relative;overflow:hidden;isolation:isolate;width:100%;min-height:86vh;display:flex;align-items:flex-end}
.reg-panel .bg{position:absolute;inset:-8% -6%;background-size:cover;background-position:center;z-index:0;will-change:transform}
.reg-panel .scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(14,23,20,.25) 0%,rgba(14,23,20,.55) 55%,rgba(14,23,20,.9) 100%)}
.reg-panel .ghost{position:absolute;right:var(--pad);top:12%;z-index:1;font-family:var(--serif);font-weight:500;
  font-size:clamp(8rem,30vh,26rem);line-height:.8;color:rgba(244,241,232,.07);pointer-events:none}
.reg-panel .pc{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;width:100%;padding:0 var(--pad) clamp(3rem,8vh,5.5rem)}
.reg-panel .rn{font-family:var(--mono);font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--copper-light);
  margin-bottom:1rem;display:flex;align-items:center;gap:.8em}
.reg-panel .rn::before{content:"";width:34px;height:1px;background:var(--copper-light)}
.reg-panel h2{font-family:var(--serif);font-weight:500;font-size:clamp(2.6rem,1.8rem + 4vw,6rem);line-height:.98;letter-spacing:-.01em;margin-bottom:.5rem}
.reg-panel .sub{font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(244,241,232,.6);margin-bottom:1.1rem}
.reg-panel .sector{font-size:clamp(1.05rem,1rem + .4vw,1.32rem);color:rgba(244,241,232,.86);max-width:42ch;line-height:1.5;margin-bottom:1.5rem}
.reg-panel .lnk{font-family:var(--mono);font-size:.78rem;letter-spacing:.06em;color:var(--copper-light);
  border-bottom:1px solid rgba(244,241,232,.3);padding-bottom:2px;transition:border-color .25s}
.reg-panel .lnk:hover{border-color:var(--copper-light)}
.reg-rail,.reg-cue{display:none}

@media(prefers-reduced-motion:no-preference){
  .reg-pin{height:340vh}
  .reg-stage{position:sticky;top:0;height:100vh;height:100dvh;overflow:hidden}
  .reg-track{flex-direction:row;width:max-content;height:100%}
  .reg-panel{flex:0 0 100vw;width:100vw;min-height:0;height:100%}
  .reg-rail{display:flex;position:absolute;left:50%;transform:translateX(-50%);bottom:2.2rem;z-index:5;align-items:center;
    background:rgba(14,23,20,.42);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
    border:1px solid var(--line-cream);border-radius:999px;padding:.4rem .5rem}
  .reg-rail .seg{display:flex;align-items:center;gap:.6em;padding:.35rem 1rem;font-family:var(--mono);font-size:.7rem;
    letter-spacing:.14em;color:rgba(244,241,232,.5);transition:color .3s;cursor:pointer;border-radius:999px}
  .reg-rail .seg .d{width:7px;height:7px;border-radius:50%;border:1px solid currentColor;transition:background .3s}
  .reg-rail .seg.act{color:var(--copper-light)}
  .reg-rail .seg.act .d{background:var(--copper-light)}
  .reg-cue{display:flex;position:absolute;left:var(--pad);bottom:2.5rem;z-index:5;align-items:center;gap:.7em;
    font-family:var(--mono);font-size:.6rem;letter-spacing:.24em;text-transform:uppercase;color:rgba(244,241,232,.55)}
  .reg-cue .arr{width:34px;height:1px;background:rgba(244,241,232,.5);position:relative}
  .reg-cue .arr::after{content:"";position:absolute;right:0;top:-2px;width:5px;height:5px;border-top:1px solid rgba(244,241,232,.5);border-right:1px solid rgba(244,241,232,.5);transform:rotate(45deg)}
}
/* mobile: keep the pinned horizontal gallery but compact the chrome */
@media(max-width:600px) and (prefers-reduced-motion:no-preference){
  .reg-panel .pc{padding-bottom:5.6rem}
  .reg-panel .ghost{font-size:clamp(7rem,24vh,13rem);top:9%}
  .reg-panel h2{font-size:clamp(2.3rem,1.6rem + 5vw,3.4rem)}
  .reg-rail .nm{display:inline}
  .reg-rail{padding:.32rem .38rem}
  .reg-rail .seg{padding:.28rem .55rem;gap:.4em;font-size:.56rem;letter-spacing:.08em}
  .reg-rail .seg .d{width:5px;height:5px}
  .reg-cue{display:none}
}

/* ---------- THE GROUP · "why we exist" editorial lead ---------- */
.why-lead{font-family:var(--serif);font-weight:500;letter-spacing:-.015em;line-height:1.05;
  font-size:clamp(2.15rem,1.25rem + 3.5vw,4.3rem);max-width:19ch;color:var(--forest);margin-top:1.6rem}
.why-lead em{font-style:italic;color:var(--copper)}
.why-rule{border:0;border-top:1px solid var(--line);max-width:none;
  margin:clamp(2.2rem,5vw,3.6rem) 0 clamp(1.6rem,3vw,2.4rem)}
.why-approach{display:grid;grid-template-columns:minmax(7rem,1fr) 3fr;gap:1rem clamp(1.4rem,4vw,3.2rem);align-items:start}
.why-approach .eyebrow{margin:.15rem 0 0}
.why-approach .prose{max-width:60ch;margin:0}
@media(max-width:720px){.why-approach{grid-template-columns:1fr;gap:.55rem}}

/* ---------- Businesses register on mobile: native horizontal swipe ---------- */
/* Replace the pinned scroll-jacking with a real left/right swipe carousel. The
   gallery is a normal block in the page flow, so vertical scroll resumes after it. */
@media(max-width:760px){
  .reg-pin{height:auto}
  .reg-stage{position:static;height:auto;overflow:visible}
  .reg-track{flex-direction:row;width:auto;height:auto;transform:none!important;
    overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;
    scrollbar-width:none;overscroll-behavior-x:contain}
  .reg-track::-webkit-scrollbar{display:none}
  .reg-panel{flex:0 0 100%;width:100vw;height:84vh;min-height:0;scroll-snap-align:center}
  .reg-panel .bg{transform:none!important}
  .reg-rail{display:flex;position:static;left:auto;transform:none;margin:1rem auto 0;
    width:max-content;max-width:calc(100% - 2*var(--pad))}
  .reg-cue{display:none}
}
