/* ── RESET & ROOT ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:auto}
html.no-lenis{scroll-behavior:smooth}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-stopped{overflow:hidden}
:focus{outline:none}
:focus-visible{outline:2px solid rgba(200,175,100,0.7);outline-offset:3px;border-radius:2px}

:root{
  --bg:#060606;
  --bg2:#09100d;
  --bg3:#0c1410;
  --green:#0e2218;
  --live:#1aff7a;
  --white:#f0ede6;
  --muted:rgba(240,237,230,0.55);
  --muted2:rgba(240,237,230,0.25);
  --muted3:rgba(236,234,228,0.07);
  --accent:rgba(200,175,100,0.5);
  --accentbright:rgba(218,192,118,0.95);
  --border:rgba(236,234,228,0.07);
  --ease:cubic-bezier(0.16,1,0.3,1);
  --ease-out:cubic-bezier(0.23,1,0.32,1);
  --ease-in-out:cubic-bezier(0.77,0,0.175,1);
}

body{
  background:var(--bg);
  color:var(--white);
  font-family:'Space Grotesk',sans-serif;
  font-weight:300;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}


::-webkit-scrollbar{width:1px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:rgba(200,175,100,0.2)}

/* ── CURSOR ── */
#cur{
  width:5px;height:5px;background:var(--white);border-radius:50%;
  position:fixed;top:0;left:0;pointer-events:none;z-index:99999;
  transform:translate(-50%,-50%);
  transition:width 0.18s var(--ease-out),height 0.18s var(--ease-out);
  mix-blend-mode:difference;
}
#cur.big{width:40px;height:40px;background:transparent;border:1px solid rgba(236,234,228,0.22)}
@media(hover:none){#cur{display:none}}

/* ── LOADER ── */
#loader{
  position:fixed;inset:0;background:var(--bg);z-index:99998;
  display:flex;align-items:center;justify-content:center;flex-direction:column;gap:2.5rem;
  transition:opacity 0.55s var(--ease),visibility 0.55s;
}
#loader.out{opacity:0;visibility:hidden;pointer-events:none}
.l-name{
  font-family:'Syne',sans-serif;font-weight:800;
  font-size:clamp(1.4rem,4vw,2rem);letter-spacing:0.22em;
  text-transform:uppercase;color:var(--white);
  opacity:0;animation:fadeUp 0.5s var(--ease) 0.08s forwards;
}
.l-bar{width:80px;height:1px;background:var(--muted3);overflow:hidden}
.l-fill{height:100%;width:0;background:var(--accentbright);animation:fillBar 0.55s var(--ease) 0.1s forwards}
@keyframes fillBar{to{width:100%}}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* ── MENU BUTTON ── */
#mbtn{
  position:fixed;top:1.6rem;right:1.8rem;z-index:10001;
  display:flex;flex-direction:column;gap:5px;
  padding:0.6rem;cursor:pointer;background:none;border:none;
}
#mbtn span{
  display:block;width:20px;height:1px;
  background:rgba(236,234,228,0.4);
  transition:transform 0.4s var(--ease),opacity 0.3s var(--ease),background-color 0.3s ease-out;
  transform-origin:center;
}
#mbtn.open span:nth-child(1){transform:translateY(6px) rotate(45deg);background:var(--white)}
#mbtn.open span:nth-child(2){opacity:0;transform:scaleX(0)}
#mbtn.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg);background:var(--white)}

/* ── NAV OVERLAY ── */
#nav-ov{
  position:fixed;top:0;left:0;right:0;bottom:0;background:#0e1f14;
  z-index:9999;display:flex;align-items:center;justify-content:center;flex-direction:column;
  visibility:hidden;transition:visibility 0s 0.38s;
}
#nav-ov.open{visibility:visible;transition:visibility 0s}
.nav-list{
  display:flex;flex-direction:column;gap:0.15rem;text-align:center;
  opacity:0;transform:translateY(14px);
  transition:opacity 0.35s cubic-bezier(0.23,1,0.32,1),transform 0.35s cubic-bezier(0.23,1,0.32,1);
}
#nav-ov.open .nav-list{opacity:1;transform:translateY(0)}
.nav-list a{
  font-family:'Cormorant Garamond',serif;font-weight:300;
  font-size:clamp(2.2rem,6vw,4rem);letter-spacing:0.04em;
  color:rgba(236,234,228,0.78);text-decoration:none;
  transition:color 0.2s ease-out;display:block;padding:0.2rem 0;
}
.nav-list a:hover{color:#fff}
.nav-list a.active{color:rgba(236,234,228,0.35)}
.nav-sub{
  position:absolute;bottom:2rem;left:0;right:0;
  display:flex;justify-content:center;gap:3rem;
  opacity:0;transform:translateY(8px);
  transition:opacity 0.3s cubic-bezier(0.23,1,0.32,1) 0.08s,transform 0.3s cubic-bezier(0.23,1,0.32,1) 0.08s;
}
#nav-ov.open .nav-sub{opacity:1;transform:translateY(0)}
.nav-sub a{
  font-size:0.68rem;letter-spacing:0.22em;text-transform:uppercase;
  color:rgba(236,234,228,0.38);text-decoration:none;transition:color 0.2s ease-out;
}
.nav-sub a:hover{color:var(--accentbright)}

/* ── SHARED LAYOUT ── */
.sw{
  padding:clamp(5rem,11vh,9rem) clamp(1.4rem,5vw,4.5rem);
  max-width:1120px;margin:0 auto;
}
.sw-narrow{
  padding:clamp(5rem,11vh,9rem) clamp(1.4rem,5vw,4.5rem);
  max-width:780px;margin:0 auto;
}
.tl{
  width:100%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(236,234,228,0.06),transparent);
  max-width:1120px;margin:0 auto;
}

/* Labels */
.slabel{
  font-size:0.57rem;letter-spacing:0.36em;text-transform:uppercase;
  color:var(--accentbright);opacity:0.6;
  display:flex;align-items:center;gap:0.7rem;margin-bottom:2.5rem;
}
.slabel::before{content:'';width:14px;height:1px;background:var(--accent)}

/* Reveal */
.r{opacity:0;transform:translateY(32px);transition:opacity 0.8s var(--ease),transform 0.8s var(--ease)}
.r.in{opacity:1;transform:none}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}
.d3{transition-delay:.3s}.d4{transition-delay:.4s}.d5{transition-delay:.5s}

/* ── BUTTONS ── */
.btn{
  display:inline-flex;align-items:center;gap:0.6rem;
  font-family:'Space Grotesk',sans-serif;font-weight:400;
  font-size:0.63rem;letter-spacing:0.18em;text-transform:uppercase;
  text-decoration:none;border-radius:100px;
  transition:color 0.22s ease-out,border-color 0.22s ease-out,transform 0.14s ease-out;
  cursor:pointer;background:none;border:none;
}
.btn:active{transform:scale(0.97)}
.btn-ghost{
  color:rgba(236,234,228,0.42);border:1px solid rgba(236,234,228,0.1);
  padding:0.82rem 1.6rem;
}
@media(hover:hover) and (pointer:fine){
  .btn-ghost:hover{border-color:rgba(236,234,228,0.28);color:var(--white)}
}
.btn-green{
  color:rgba(26,255,122,0.52);border:1px solid rgba(26,255,122,0.11);
  padding:0.82rem 1.6rem;
}
@media(hover:hover) and (pointer:fine){
  .btn-green:hover{border-color:rgba(26,255,122,0.28);color:rgba(26,255,122,0.88)}
}
.btn-gold{
  color:rgba(210,185,110,0.7);border:1px solid rgba(210,185,110,0.18);
  padding:0.82rem 1.6rem;
}
@media(hover:hover) and (pointer:fine){
  .btn-gold:hover{border-color:rgba(210,185,110,0.4);color:var(--accentbright)}
}

/* Pill CTA (hero style) */
.pill-cta{
  display:inline-flex;align-items:center;gap:0.55rem;
  background:rgba(8,18,12,0.85);
  border:1px solid rgba(26,255,122,0.11);
  border-radius:100px;padding:0.45rem 1rem;
  backdrop-filter:blur(14px);
  transition:border-color 0.3s;cursor:pointer;
  font-size:0.61rem;letter-spacing:0.12em;text-transform:uppercase;
  color:rgba(236,234,228,0.6);text-decoration:none;
}
.pill-cta:hover{border-color:rgba(26,255,122,0.26);color:var(--white)}
.pill-cta .ldot{
  width:5px;height:5px;border-radius:50%;background:var(--live);
  box-shadow:0 0 7px rgba(26,255,122,0.9);flex-shrink:0;
  animation:lpulse 2s ease infinite;
}
@keyframes lpulse{
  0%,100%{box-shadow:0 0 5px rgba(26,255,122,0.55)}
  50%{box-shadow:0 0 11px rgba(26,255,122,1),0 0 22px rgba(26,255,122,0.28)}
}

/* CTA row */
.cta-row{
  display:flex;flex-wrap:wrap;align-items:center;gap:0.8rem;
  margin-top:2.5rem;
}

/* ── IMAGE COMPONENTS ── */
.img-box{
  border-radius:2px;overflow:hidden;
  border:1px solid var(--border);position:relative;
}
.img-box img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 2.2s var(--ease);
  display:block;
}
@media(hover:hover) and (pointer:fine){.img-box:hover img{transform:scale(1.06)}}
.img-ov{
  position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 45%,rgba(6,6,6,0.65) 100%);
  pointer-events:none;
}

/* ── FOOTER ── */
footer{
  padding:2rem clamp(1.4rem,5vw,4.5rem);
  border-top:1px solid rgba(236,234,228,0.05);
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:1rem;background:var(--bg);
}
.footer-wm{
  font-family:'Syne',sans-serif;font-weight:700;
  font-size:0.68rem;letter-spacing:0.22em;text-transform:uppercase;
  color:rgba(236,234,228,0.35);text-decoration:none;
}
.footer-links{display:flex;gap:2rem;list-style:none}
.footer-links a{
  font-size:0.68rem;letter-spacing:0.2em;text-transform:uppercase;
  color:rgba(236,234,228,0.35);text-decoration:none;transition:color 0.2s ease-out;
}
.footer-links a:hover{color:rgba(236,234,228,0.7)}
.footer-copy{font-size:0.68rem;color:rgba(236,234,228,0.25)}

/* ── SUBPAGE: PAGE HERO ── */
.page-hero{
  position:relative;
  min-height:55svh;
  display:flex;flex-direction:column;
  justify-content:flex-end;
  overflow:hidden;
  background:var(--bg);
}
.page-hero-img{
  position:absolute;inset:0;
}
.page-hero-img img{
  width:100%;height:100%;
  object-fit:cover;
  filter:grayscale(0.4) brightness(0.32) contrast(1.1);
}
.page-hero-ov{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(6,6,6,0.5) 0%,transparent 30%,rgba(6,6,6,0.85) 100%);
}
.page-hero-content{
  position:relative;z-index:2;
  padding:0 clamp(1.4rem,5vw,4.5rem) clamp(3rem,6vh,5rem);
  max-width:900px;
}
.page-back{
  display:inline-flex;align-items:center;gap:0.6rem;
  font-size:0.57rem;letter-spacing:0.22em;text-transform:uppercase;
  color:rgba(236,234,228,0.3);text-decoration:none;
  margin-bottom:2rem;transition:color 0.3s;
}
.page-back:hover{color:rgba(236,234,228,0.7)}
.page-chapter{
  font-size:0.57rem;letter-spacing:0.36em;text-transform:uppercase;
  color:var(--accentbright);opacity:0.6;
  display:flex;align-items:center;gap:0.7rem;margin-bottom:1.2rem;
}
.page-chapter::before{content:'';width:14px;height:1px;background:var(--accent)}
.page-title{
  font-family:'Cormorant Garamond',serif;font-weight:300;
  font-size:clamp(2.8rem,7vw,6rem);
  letter-spacing:0.01em;
  color:var(--white);line-height:0.95;
  margin-bottom:1.2rem;
}
.page-subtitle{
  font-size:clamp(0.78rem,1.2vw,0.9rem);
  color:rgba(236,234,228,0.35);
  line-height:1.9;max-width:520px;
}

/* ── SUBPAGE: BODY TEXT ── */
.prose{
  font-size:clamp(0.88rem,1.3vw,1rem);
  color:rgba(240,237,230,0.58);
  line-height:2.1;font-weight:300;
}
.prose p{margin-bottom:1.5rem}
.prose p:last-child{margin-bottom:0}

.pull-quote{
  font-family:'Cormorant Garamond',serif;font-weight:300;font-style:italic;
  font-size:clamp(1.4rem,2.8vw,2rem);
  letter-spacing:0.01em;
  color:rgba(240,237,230,0.82);
  line-height:1.45;
  border-left:2px solid rgba(200,175,100,0.35);
  padding-left:1.5rem;
  margin:3rem 0;
}
.pull-quote em{font-style:normal;color:var(--white)}

.chapter-title{
  font-family:'Syne',sans-serif;font-weight:700;
  font-size:clamp(0.85rem,1.5vw,1.05rem);
  letter-spacing:0.1em;text-transform:uppercase;
  color:rgba(236,234,228,0.55);
  margin-bottom:1rem;margin-top:3.5rem;
  display:flex;align-items:center;gap:0.8rem;
}
.chapter-title::before{
  content:'';width:20px;height:1px;
  background:var(--accent);flex-shrink:0;
}

/* ── SUBPAGE: 2-COL TEXT+IMAGE ── */
.split-block{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(2rem,5vw,5rem);
  align-items:center;
  margin:clamp(3rem,6vh,5rem) 0;
}
.split-block.reverse{direction:rtl}
.split-block.reverse > *{direction:ltr}
.split-img{
  aspect-ratio:3/4;
  border-radius:2px;overflow:hidden;
  border:1px solid var(--border);position:relative;
}
.split-img.wide{aspect-ratio:4/3}
.split-img img{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(0.2) brightness(0.45) contrast(1.08);
  transition:transform 2.2s var(--ease);
}
@media(hover:hover) and (pointer:fine){.split-img:hover img{transform:scale(1.06)}}
.split-img-ov{position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(6,6,6,0.6) 100%)}

/* ── SUBPAGE: PHOTO GRID ── */
.photo-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:0.6rem;
  margin:clamp(3rem,5vh,4rem) 0;
}
.photo-grid .img-box{aspect-ratio:3/4}
.photo-grid.two-col{grid-template-columns:repeat(2,1fr)}
.photo-grid .img-box img{
  filter:grayscale(0.2) brightness(0.42) contrast(1.08);
}

/* ── SUBPAGE: STAT ROW ── */
.stat-row{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1px;background:var(--border);
  border:1px solid var(--border);border-radius:2px;overflow:hidden;
  margin:clamp(3rem,5vh,4rem) 0;
}
.stat-cell{
  background:var(--bg);padding:2rem 1.5rem;text-align:center;
}
.stat-n{
  font-family:'Syne',sans-serif;font-weight:800;
  font-size:clamp(1.8rem,3.5vw,2.8rem);
  color:rgba(200,175,100,0.6);line-height:1;margin-bottom:0.5rem;
}
.stat-l{
  font-size:0.58rem;letter-spacing:0.2em;text-transform:uppercase;
  color:rgba(236,234,228,0.2);
}

/* ── SUBPAGE: WIDE IMAGE ── */
.wide-img{
  width:100%;aspect-ratio:21/9;
  border-radius:2px;overflow:hidden;
  border:1px solid var(--border);position:relative;
  margin:clamp(3rem,5vh,4rem) 0;
}
.wide-img img{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(0.2) brightness(0.4) contrast(1.1);
  transition:transform 2.8s var(--ease);
}
@media(hover:hover) and (pointer:fine){.wide-img:hover img{transform:scale(1.05)}}
.wide-img-ov{
  position:absolute;inset:0;
  background:
    linear-gradient(to right,rgba(6,6,6,0.4) 0%,transparent 20%,transparent 80%,rgba(6,6,6,0.4) 100%),
    linear-gradient(180deg,transparent 40%,rgba(6,6,6,0.65) 100%);
}

/* ── SUBPAGE: CTA SECTION ── */
.cta-section{
  background:var(--bg3);
  padding:clamp(4rem,8vh,7rem) clamp(1.4rem,5vw,4.5rem);
  text-align:center;
  border-top:1px solid rgba(236,234,228,0.05);
  position:relative;overflow:hidden;
}
.cta-section::before{
  content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:500px;height:400px;
  background:radial-gradient(ellipse,rgba(14,34,24,0.5) 0%,transparent 65%);
  pointer-events:none;
}
.cta-section h2{
  font-family:'Syne',sans-serif;font-weight:700;
  font-size:clamp(1rem,2vw,1.5rem);
  letter-spacing:0.08em;text-transform:uppercase;
  color:rgba(236,234,228,0.55);
  margin-bottom:0.8rem;
  position:relative;z-index:1;
}
.cta-section p{
  font-size:clamp(0.76rem,1.1vw,0.84rem);
  color:rgba(236,234,228,0.25);
  line-height:1.9;margin-bottom:2rem;
  max-width:480px;margin-left:auto;margin-right:auto;
  position:relative;z-index:1;
}
.cta-btns{
  display:flex;align-items:center;justify-content:center;
  gap:0.8rem;flex-wrap:wrap;
  position:relative;z-index:1;
}


/* ── PAGE TRANSITION OVERLAY ── */
#page-transition{
  position:fixed;inset:0;
  background:var(--bg);
  z-index:99995;
  pointer-events:none;
  opacity:1;
  transition:opacity 0.4s var(--ease);
}
#page-transition.out{
  opacity:0;
  pointer-events:none;
}

/* ── TEXT REVEAL (word by word) ── */
.reveal-text .rw{
  display:inline-block;
  opacity:0;
  transform:translateY(14px);
  transition:opacity 0.55s var(--ease), transform 0.55s var(--ease);
}
.reveal-text .rw.rw-in{
  opacity:1;
  transform:none;
}

/* ── QUOTE SECTION ── */
.quote-section{
  min-height:100svh;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  background:#142018;
  position:relative;overflow:hidden;
  padding:clamp(2.5rem,6vh,5rem) clamp(1.4rem,6vw,6rem);
  text-align:center;
}
.quote-section::before{
  content:'';
  position:absolute;inset:0;
  background:radial-gradient(ellipse at 50% 50%,#142018 0%,#0a1610 70%);
  pointer-events:none;
}
.quote-section::after{
  content:'';
  position:absolute;
  top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(236,234,228,0.06),transparent);
}
.qs-inner{
  position:relative;z-index:2;
  max-width:820px;
}
.qs-label{
  font-size:0.55rem;letter-spacing:0.4em;text-transform:uppercase;
  color:rgba(210,185,110,0.5);margin-bottom:3.5rem;
  display:flex;align-items:center;justify-content:center;gap:0.8rem;
}
.qs-label::before,.qs-label::after{
  content:'';width:24px;height:1px;background:rgba(210,185,110,0.25);
}
/* Each line of the quote */
.rl{
  display:block;
  font-family:'Syne',sans-serif;font-weight:700;
  font-size:clamp(1.8rem,5.5vw,4.2rem);
  letter-spacing:0.02em;text-transform:none;
  color:rgba(236,234,228,0.08);
  line-height:1.1;
  opacity:0;
  transform:translateY(24px);
  transition:color 0.9s var(--ease),
             opacity 0.9s var(--ease),
             transform 0.9s var(--ease);
}
.rl.rl-in{
  color:rgba(236,234,228,0.82);
  opacity:1;
  transform:none;
}
.rl em{
  font-style:normal;
  color:rgba(210,185,110,0.75);
}
.rl.rl-small{
  font-size:clamp(0.9rem,2vw,1.3rem);
  font-weight:400;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:rgba(236,234,228,0.04);
  margin-top:2.5rem;
}
.rl.rl-small.rl-in{
  color:rgba(236,234,228,0.3);
}
.qs-cta{
  margin-top:3.5rem;
  opacity:0;
  transform:translateY(12px);
  transition:opacity 0.8s var(--ease) 1.2s, transform 0.8s var(--ease) 1.2s;
}
.qs-cta.rl-in{
  opacity:1;transform:none;
}

/* ── VERTICAL SCROLL NAV ── */
#scroll-nav{
  position:fixed;
  right:0;
  top:50%;
  transform:translateY(-50%);
  z-index:500;
  display:flex;
  flex-direction:column;
  align-items:center;
  width:28px;
  pointer-events:none;
  touch-action:none; /* nav itself never blocks scroll */
}
/* Track line behind dots */
.sn-track{
  position:absolute;
  top:0;left:50%;
  transform:translateX(-50%);
  width:1px;height:100%;
  background:rgba(200,175,100,0.1);
  pointer-events:none;
}
/* Animated fill */
.sn-fill{
  position:absolute;
  top:0;left:50%;
  transform:translateX(-50%);
  width:1px;height:0%;
  background:linear-gradient(180deg,
    rgba(200,175,100,0.7) 0%,
    rgba(200,175,100,0.2) 100%);
  transition:height 0.12s linear;
  box-shadow:0 0 4px rgba(200,175,100,0.3);
  pointer-events:none;
}
/* Dot wrapper */
.sn-dot-wrap{
  position:relative;
  width:28px;height:28px;
  display:flex;align-items:center;justify-content:center;
  pointer-events:all;
  cursor:pointer;flex-shrink:0;
  touch-action:manipulation; /* tap = click, no scroll interference */
  -webkit-tap-highlight-color:transparent;
}
/* The dot */
.sn-dot{
  width:3px;height:3px;border-radius:50%;
  background:rgba(200,175,100,0.2);
  border:1px solid rgba(200,175,100,0.15);
  transition:
    width 0.18s var(--ease-out),height 0.18s var(--ease-out),
    background 0.18s ease-out,border-color 0.18s ease-out,
    box-shadow 0.22s ease-out;
  pointer-events:none;
}
.sn-dot-wrap:hover .sn-dot,
.sn-dot-wrap.active .sn-dot{
  width:6px;height:6px;
  background:rgba(200,175,100,0.95);
  border-color:rgba(200,175,100,0.8);
  box-shadow:0 0 8px rgba(200,175,100,0.6),0 0 18px rgba(200,175,100,0.2);
}
/* Label tooltip — desktop only */
.sn-dot-wrap::before{
  content:attr(data-label);
  position:absolute;
  right:calc(100% + 6px);
  font-size:0.48rem;letter-spacing:0.18em;text-transform:uppercase;
  color:rgba(200,175,100,0.65);white-space:nowrap;
  opacity:0;transform:translateX(4px);
  transition:opacity 0.18s ease-out,transform 0.18s ease-out;
  pointer-events:none;
  font-family:'Space Grotesk',sans-serif;
}
.sn-dot-wrap[data-label]:hover::before{
  opacity:1;transform:translateX(0);
}
/* Mobile — thinner, less intrusive */
@media(max-width:720px){
  #scroll-nav{
    right:0;
    width:16px;
  }
  .sn-dot-wrap{
    width:16px;height:16px;
    pointer-events:none; /* on mobile dots are visual only — no tap needed */
  }
  .sn-dot-wrap::before{display:none}
  .sn-dot{width:2px;height:2px}
  .sn-dot-wrap.active .sn-dot{
    width:4px;height:4px;
  }
}
/* Offset right edge of content so nav doesn't overlap text */
@media(min-width:721px){
  .sw,.sw-narrow{padding-right:clamp(2.5rem,5vw,5rem)}
}
@media(max-width:720px){
  .sw,.sw-narrow{padding-right:clamp(1.6rem,4vw,2.5rem)}
}

/* ── MOBILE ── */
@media(max-width:720px){
  .split-block{grid-template-columns:1fr}
  .split-block.reverse{direction:ltr}
  .photo-grid{grid-template-columns:repeat(2,1fr)}
  .stat-row{grid-template-columns:1fr}
  .wide-img{aspect-ratio:5/4}
  .footer-links{display:none}
  .page-title{font-size:clamp(1.6rem,7vw,2.5rem);line-height:1.05}
  .page-subtitle{font-size:0.78rem}
  .pull-quote{font-size:clamp(0.95rem,3.5vw,1.2rem)}
  .nav-list{gap:0.05rem}

  /* Quote sections compact on mobile */
  .quote-section{min-height:0!important}

  /* No backdrop blur on mobile (compositing cost) */
  .hero-pill-top{-webkit-backdrop-filter:none;backdrop-filter:none}
}
@media(max-width:480px){
  .photo-grid{grid-template-columns:1fr}
  .cta-btns{flex-direction:column;align-items:stretch}
  .cta-btns .btn{justify-content:center}
  .page-title{font-size:clamp(1.5rem,6.5vw,2.2rem)}
  .nav-list a{font-size:clamp(1.3rem,5.5vw,2rem);letter-spacing:0.05em}
}

/* ── IMAGE SCALE REVEAL ── */
.story-img.r,.weg-img-wrap.r,.split-img.r,.wphoto.r,.wide-img.r{
  transform:translateY(32px) scale(0.97);
}
.story-img.r.in,.weg-img-wrap.r.in,.split-img.r.in,.wphoto.r.in,.wide-img.r.in{
  transform:translateY(0) scale(1);
}
@media(max-width:720px){
  .story-img.r,.weg-img-wrap.r,.split-img.r,.wphoto.r,.wide-img.r{
    transform:translateY(16px) scale(0.99);
  }
}

/* ── WORD BLUR ANIMATION ── */
.word-blur{
  filter:blur(5px);
  transition:filter 0.55s var(--ease);
}
.word-blur.in{filter:blur(0)}
.word-blur .wb{
  display:inline-block;
  opacity:0;
  transform:translateY(6px);
  transition:opacity 0.45s var(--ease), transform 0.45s var(--ease);
}
.word-blur.in .wb{
  opacity:1;transform:none;
}

/* Mobile: simpler fade only */
@media(max-width:720px){
  .word-blur{filter:none}
  .word-blur .wb{transform:translateY(4px)}
  .r{transform:translateY(20px)}
}

/* ── REDUCED MOTION ── */
/* ── ULTRAWIDE ── */
@media(min-width:1600px){
  .sw{max-width:1360px}
  .tl{max-width:1360px}
}
@media(min-width:2000px){
  .sw{max-width:1680px}
  .tl{max-width:1680px}
}

@media(prefers-reduced-motion:reduce){
  .r{transition:opacity 0.4s ease;transform:none !important}
  .rl{transition:opacity 0.4s ease;transform:none !important}
  .reveal-text .rw{transition:opacity 0.3s ease;transform:none !important}
  .word-blur{filter:none;transition:none}
  .word-blur .wb{transform:none;transition:opacity 0.3s ease}
  .sbar{animation:none}
  .l-fill{animation:fillBar 0.6s ease forwards}
  .hero-wm,.hero-pill-top,.hero-content,.hero-scroll{animation:fadeIn 0.4s ease forwards}
  .story-img img,.weg-img-wrap img,.split-img img{transition:none}
  .ldot{animation:none}
  .scard,.scard.fly-out{transition:opacity 0.15s ease}
  #page-transition{transition:none}
  .acc-body{transition:none}
}
