/* =====================================================================
   BLIND PROS — ATELIER
   A premium editorial redesign. Ink, bone, champagne brass.
   Type: Fraunces (variable) + Inter. Motion: GSAP + Lenis.
   ===================================================================== */

/* ---------- Reset & tokens ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;scroll-behavior:smooth}
html,body{height:auto}
img,video,svg{display:block;max-width:100%;height:auto}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}

:root{
  /* Palette */
  --ink:#0B0A0C;
  --ink-soft:#14121A;
  --noir:#1C1A22;
  --shadow:#28242E;
  --bone:#F5F0E7;
  --linen:#EAE1CE;
  --cream:#FBF7EE;
  --champagne:#C9A86A;
  --champagne-bright:#DDBE7A;
  --brass:#A78850;
  --whisper:rgba(245,240,231,.55);
  --whisper-ink:rgba(11,10,12,.55);
  --hairline:rgba(201,168,106,.28);
  --hairline-ink:rgba(11,10,12,.10);

  /* Type */
  --font-display:'Fraunces',Georgia,'Times New Roman',serif;
  --font-sans:'Inter',-apple-system,BlinkMacSystemFont,'Helvetica Neue',Arial,sans-serif;

  /* Scale (fluid) */
  --fs-xs:clamp(.72rem,.7rem + .1vw,.78rem);
  --fs-sm:clamp(.82rem,.78rem + .2vw,.9rem);
  --fs-base:clamp(1rem,.94rem + .25vw,1.08rem);
  --fs-lg:clamp(1.15rem,1rem + .6vw,1.35rem);
  --fs-xl:clamp(1.45rem,1.1rem + 1.5vw,2rem);
  --fs-2xl:clamp(2rem,1.4rem + 3vw,3rem);
  --fs-3xl:clamp(2.6rem,1.8rem + 4.2vw,4.4rem);
  --fs-4xl:clamp(3.4rem,2rem + 6vw,6.8rem);
  --fs-5xl:clamp(4.2rem,2.5rem + 8vw,9rem);
  --fs-mega:clamp(5rem,3rem + 11vw,13rem);

  /* Spacing */
  --space-1:.5rem;
  --space-2:1rem;
  --space-3:1.5rem;
  --space-4:2rem;
  --space-5:3rem;
  --space-6:4.5rem;
  --space-7:6rem;
  --space-8:9rem;

  /* Layout */
  --radius:2px;
  --ease-out:cubic-bezier(.16,1,.3,1);
  --ease-in-out:cubic-bezier(.7,0,.3,1);
  --transition:cubic-bezier(.22,.61,.36,1);
  --container:1320px;
  --container-narrow:960px;
}

body{
  font-family:var(--font-sans);
  font-size:var(--fs-base);
  line-height:1.6;
  color:var(--bone);
  background:var(--ink);
  overflow-x:hidden;
  letter-spacing:.005em;
}

body.lenis-smooth{overflow:hidden}
body.no-scroll{overflow:hidden}

/* ---------- Grain overlay ---------- */
.grain{
  position:fixed;inset:0;pointer-events:none;z-index:80;
  opacity:.06;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 .6 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}

/* ---------- Cursor (desktop only) ---------- */
.cursor,.cursor-dot{position:fixed;top:0;left:0;pointer-events:none;z-index:90;transform:translate(-50%,-50%);mix-blend-mode:difference}
.cursor{width:40px;height:40px;border:1px solid var(--bone);border-radius:50%;transition:transform .18s var(--ease-out),width .25s var(--ease-out),height .25s var(--ease-out),background .2s ease}
.cursor-dot{width:4px;height:4px;background:var(--bone);border-radius:50%}
.cursor.grow{width:74px;height:74px;background:rgba(201,168,106,.15);border-color:var(--champagne)}
@media (hover:none) { .cursor,.cursor-dot{display:none} html{cursor:auto} }
@media (hover:hover){html,a,button{cursor:none}}

/* ---------- Typography ---------- */
h1,h2,h3,h4{font-family:var(--font-display);font-weight:400;line-height:1.04;letter-spacing:-.02em;font-variation-settings:"opsz" 144,"SOFT" 30,"WONK" 0}
h1{font-size:var(--fs-4xl)}
h2{font-size:var(--fs-3xl)}
h3{font-size:var(--fs-xl)}
h4{font-size:var(--fs-lg)}
p{color:inherit}
.display-mega{font-family:var(--font-display);font-size:var(--fs-mega);line-height:.9;letter-spacing:-.04em;font-variation-settings:"opsz" 144}
.italic{font-style:italic;font-variation-settings:"opsz" 144,"SOFT" 100}

.kicker{
  display:inline-flex;align-items:center;gap:.7em;
  font-family:var(--font-sans);font-size:.72rem;
  letter-spacing:.32em;text-transform:uppercase;
  font-weight:500;color:var(--champagne);
}
.kicker::before{content:"";width:2.2rem;height:1px;background:var(--champagne);opacity:.65}
.kicker.center::before{display:none}
.kicker.center{justify-content:center}
.kicker.center::after{content:"";width:2.2rem;height:1px;background:var(--champagne);margin-left:.2rem;opacity:.65}

.eyebrow{
  display:block;font-family:var(--font-sans);font-size:.7rem;
  letter-spacing:.34em;text-transform:uppercase;color:var(--champagne);
  margin-bottom:var(--space-3);font-weight:500;
}

.lede{font-family:var(--font-display);font-size:var(--fs-lg);line-height:1.4;font-style:italic;font-variation-settings:"opsz" 144,"SOFT" 80;color:var(--bone);opacity:.88;max-width:46ch}
.body-sans{font-family:var(--font-sans);color:var(--bone);opacity:.78;line-height:1.7}

/* ---------- Layout helpers ---------- */
.container{max-width:var(--container);margin:0 auto;padding:0 clamp(1.25rem,2vw,2.5rem)}
.container-narrow{max-width:var(--container-narrow);margin:0 auto;padding:0 clamp(1.25rem,2vw,2.5rem)}
.section{padding:var(--space-7) 0;position:relative}
.section-sm{padding:var(--space-5) 0}
.section-xl{padding:var(--space-8) 0}
.section--ink{background:var(--ink);color:var(--bone)}
.section--noir{background:var(--noir);color:var(--bone)}
.section--bone{background:var(--bone);color:var(--ink)}
.section--cream{background:var(--cream);color:var(--ink)}
.divider-brass{width:5rem;height:1px;background:var(--champagne);margin:var(--space-3) 0}
.center{text-align:center}
.hidden{display:none}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.8em;
  padding:1.05em 2.1em;
  font-family:var(--font-sans);font-size:.78rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;
  border:1px solid currentColor;border-radius:999px;
  position:relative;overflow:hidden;
  transition:color .4s var(--ease-out),border-color .4s var(--ease-out),transform .4s var(--ease-out);
  will-change:transform;
}
.btn::before{
  content:"";position:absolute;inset:0;
  background:var(--champagne);border-radius:999px;
  transform:scale(0);transform-origin:center;
  transition:transform .6s var(--ease-out);z-index:-1;
}
.btn:hover::before{transform:scale(1.05)}
.btn--light{color:var(--bone);border-color:var(--bone)}
.btn--light:hover{color:var(--ink);border-color:var(--champagne)}
.btn--dark{color:var(--ink);border-color:var(--ink)}
.btn--dark:hover{color:var(--ink);border-color:var(--champagne)}
.btn--gold{color:var(--ink);border-color:var(--champagne);background:var(--champagne)}
.btn--gold::before{background:var(--champagne-bright)}
.btn--gold:hover{color:var(--ink);border-color:var(--champagne-bright)}
.btn--sm{padding:1em 2em;font-size:.85rem}
.btn .arrow{width:1.1em;height:1.1em;transition:transform .4s var(--ease-out)}
.btn:hover .arrow{transform:translateX(4px)}

.link-arrow{
  display:inline-flex;align-items:center;gap:.65em;
  font-family:var(--font-sans);font-size:.78rem;font-weight:500;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--champagne);padding-bottom:.35em;
  border-bottom:1px solid var(--champagne);
  transition:color .35s var(--ease-out),border-color .35s var(--ease-out),gap .35s var(--ease-out);
}
.link-arrow:hover{gap:.95em;color:var(--champagne-bright);border-color:var(--champagne-bright)}

/* ---------- Header ---------- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:70;
  padding:1.8rem clamp(1.5rem,3vw,3.5rem);
  display:flex;align-items:center;justify-content:space-between;
  transition:padding .45s var(--ease-out),background .45s var(--ease-out),border-color .45s var(--ease-out);
  border-bottom:1px solid transparent;
}
.site-header.shrunk{
  padding:.9rem clamp(1.25rem,2vw,2.5rem);
  background:rgba(11,10,12,.78);
  backdrop-filter:blur(20px) saturate(1.1);
  -webkit-backdrop-filter:blur(20px) saturate(1.1);
  border-bottom-color:var(--hairline);
}
.site-header.light-bg.shrunk{background:rgba(245,240,231,.85);color:var(--ink)}
.site-header.light-bg{color:var(--ink)}
.site-header.scrolled .main-nav a{color:var(--champagne)}
.site-header.scrolled .main-nav a:hover{color:var(--champagne-bright)}
.site-header.scrolled .logo{color:var(--champagne)}
.site-header.scrolled .header-cta .phone{color:var(--champagne)}
.site-header.scrolled .menu-toggle{border-color:var(--champagne);color:var(--champagne)}
.site-header.scrolled .btn--light{color:var(--champagne);border-color:var(--champagne)}
.site-header.scrolled .btn--light:hover{color:var(--ink)}
.site-header .logo{
  font-family:var(--font-display);font-size:2.8rem;font-weight:400;
  letter-spacing:.01em;line-height:1;
  display:flex;align-items:baseline;gap:.4em;
  font-variation-settings:"opsz" 144;
}
.site-header .logo .mark{
  display:inline-block;width:.5em;height:.5em;background:var(--champagne);border-radius:50%;
  margin-right:.35em;transform:translateY(.02em);
}
.site-header .logo em{font-style:italic;color:var(--champagne);font-variation-settings:"opsz" 144,"SOFT" 100}

.main-nav{display:flex;gap:clamp(1rem,2.5vw,2.5rem);align-items:center}
.main-nav a{
  font-family:var(--font-sans);font-size:.95rem;letter-spacing:.2em;text-transform:uppercase;
  font-weight:500;position:relative;padding:.4em 0;
}
.main-nav a::after{
  content:"";position:absolute;left:0;right:100%;bottom:-2px;height:1px;background:var(--champagne);
  transition:right .5s var(--ease-out);
}
.main-nav a:hover::after{right:0}
.main-nav .has-menu{position:relative}
.main-nav .has-menu > a::before{content:"";display:inline-block;width:.35em;height:.35em;border:1px solid currentColor;border-left:0;border-top:0;transform:rotate(45deg) translateY(-.1em);margin-right:.5em;opacity:.55}

.mega-menu{
  position:absolute;top:calc(100% + 1.4rem);left:50%;transform:translateX(-50%) translateY(-6px);
  min-width:min(820px,90vw);background:var(--ink-soft);
  border:1px solid var(--hairline);padding:2rem;
  opacity:0;visibility:hidden;transition:opacity .35s var(--ease-out),visibility .35s,transform .35s var(--ease-out);
  box-shadow:0 40px 80px rgba(0,0,0,.55);
}
.main-nav .has-menu:hover .mega-menu,.main-nav .has-menu:focus-within .mega-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.mega-menu-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem 2.5rem}
.mega-menu-grid a{
  display:flex;gap:1rem;align-items:center;padding:.5em 0;font-size:.95rem;
  letter-spacing:.1em;text-transform:none;color:var(--bone);
}
.mega-menu-grid a .thumb{width:56px;height:56px;background-size:cover;background-position:center;border:1px solid var(--hairline);flex-shrink:0;filter:saturate(.9)}
.mega-menu-grid a::after{display:none}
.mega-menu-grid a:hover{color:var(--champagne)}

.header-cta{display:flex;align-items:center;gap:1.4rem}
.header-cta .phone{
  font-family:var(--font-display);font-size:1.6rem;font-weight:400;letter-spacing:.02em;
  font-variation-settings:"opsz" 144;
}
.header-cta .phone .tel{border-bottom:1px solid transparent;transition:border-color .3s var(--ease-out)}
.header-cta .phone:hover .tel{border-bottom-color:var(--champagne)}

/* Mobile menu */
.menu-toggle{display:none;width:48px;height:48px;align-items:center;justify-content:center;border:1px solid var(--hairline);border-radius:999px;z-index:76}
.menu-toggle span{display:block;width:18px;height:1px;background:currentColor;position:relative;transition:transform .4s var(--ease-out),opacity .3s}
.menu-toggle span::before,.menu-toggle span::after{content:"";position:absolute;width:18px;height:1px;background:currentColor;left:0;transition:transform .4s var(--ease-out),top .3s}
.menu-toggle span::before{top:-6px}
.menu-toggle span::after{top:6px}
body.mobile-open .menu-toggle span{background:transparent}
body.mobile-open .menu-toggle span::before{top:0;transform:rotate(45deg)}
body.mobile-open .menu-toggle span::after{top:0;transform:rotate(-45deg)}

.mobile-nav{
  position:fixed;inset:0;z-index:72;
  background:var(--ink);
  padding:7rem clamp(1.5rem,4vw,3rem) 3rem;
  transform:translateY(-100%);transition:transform .7s var(--ease-in-out);
  overflow-y:auto;
}
body.mobile-open .mobile-nav{transform:translateY(0)}
.mobile-nav ul{display:flex;flex-direction:column;gap:.4rem}
.mobile-nav a{
  font-family:var(--font-display);font-size:clamp(1.8rem,6vw,3.2rem);font-weight:400;
  padding:.25em 0;display:block;line-height:1.2;
  border-bottom:1px solid var(--hairline);
  font-variation-settings:"opsz" 144;
}
.mobile-nav .sub{display:flex;flex-direction:column;padding-left:1.5rem;margin:.5rem 0 1rem}
.mobile-nav .sub a{font-size:1rem;font-family:var(--font-sans);letter-spacing:.15em;text-transform:uppercase;border:0;padding:.4em 0;color:var(--whisper)}
.mobile-nav .sub a:hover{color:var(--champagne)}
.mobile-nav .contact-row{margin-top:2rem;display:flex;flex-direction:column;gap:1rem}
.mobile-nav .contact-row a{font-size:1rem;font-family:var(--font-sans);letter-spacing:.2em;text-transform:uppercase;border:0;padding:0;color:var(--champagne)}

@media (max-width:1080px){
  .main-nav,.header-cta{display:none}
  .menu-toggle{display:inline-flex}
}

/* ---------- HERO ---------- */
.hero{
  position:relative;min-height:100svh;height:100vh;
  display:flex;align-items:flex-end;
  color:var(--bone);overflow:hidden;isolation:isolate;
}
.hero-video{position:absolute;inset:0;z-index:-2}
.hero-video video,.hero-video img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transform:scale(1.06);
  transition:transform 8s linear;
}
.hero-video.loaded video,.hero-video.loaded img{transform:scale(1)}
.hero-video::after{
  content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(to bottom,rgba(11,10,12,.45) 0%,rgba(11,10,12,.15) 35%,rgba(11,10,12,.35) 65%,rgba(11,10,12,.85) 100%);
}
.hero-content{
  position:relative;z-index:2;
  width:100%;max-width:var(--container);margin:0 auto;
  padding:0 clamp(1.25rem,2vw,2.5rem) clamp(4rem,9vh,7rem);
  display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:end;
}
.hero-headline{max-width:16ch}
.hero h1{
  font-size:clamp(3.4rem,2rem + 7vw,8.2rem);
  line-height:.96;letter-spacing:-.03em;
  font-weight:300;
}
.hero h1 .italic-brass{
  font-style:italic;color:var(--champagne);
  font-variation-settings:"opsz" 144,"SOFT" 100,"WONK" 1;
}
.hero h1 .word{display:inline-block;overflow:hidden;vertical-align:top}
.hero h1 .word > span{display:inline-block;transform:translateY(105%);will-change:transform}
.hero.ready h1 .word > span{animation:revealUp 1.2s var(--ease-out) forwards;animation-delay:var(--d,0s)}
@keyframes revealUp{to{transform:translateY(0)}}

.hero-meta{
  align-self:end;text-align:right;display:flex;flex-direction:column;gap:1.2rem;align-items:flex-end;
  max-width:26ch;
}
.hero-meta p{font-family:var(--font-sans);font-size:.95rem;line-height:1.55;color:var(--bone);opacity:.85}

.hero-bottom{
  position:absolute;left:0;right:0;bottom:0;z-index:2;
  border-top:1px solid var(--hairline);
  background:linear-gradient(to bottom,rgba(11,10,12,0),rgba(11,10,12,.55));
  padding:1.2rem clamp(1.25rem,2vw,2.5rem);
  display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;
}
.hero-bottom .scroll-indicator{display:inline-flex;align-items:center;gap:.8rem;font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--whisper)}
.hero-bottom .scroll-indicator .bar{width:1.6rem;height:1px;background:var(--champagne);position:relative;overflow:hidden}
.hero-bottom .scroll-indicator .bar::after{content:"";position:absolute;inset:0;background:var(--bone);animation:scroll-bar 2.4s infinite var(--ease-in-out)}
@keyframes scroll-bar{0%{transform:translateX(-100%)}50%{transform:translateX(0)}100%{transform:translateX(100%)}}
.hero-bottom .hero-tag{display:flex;gap:2rem;font-family:var(--font-sans);font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--whisper)}
.hero-bottom .hero-tag strong{color:var(--champagne);font-weight:500}
.hero-ctas{display:flex;gap:.9rem;flex-wrap:wrap}

@media (max-width:780px){
  .hero-content{grid-template-columns:1fr;gap:1.5rem}
  .hero-meta{text-align:left;align-items:flex-start}
  .hero-bottom .hero-tag{display:none}
}

/* ---------- MARQUEE ---------- */
.marquee{
  overflow:hidden;white-space:nowrap;padding:2rem 0;
  border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline);
  background:var(--ink);
}
.marquee-track{display:inline-flex;gap:3.5rem;animation:marquee 38s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee span{
  font-family:var(--font-display);font-size:clamp(1.3rem,3vw,2.6rem);font-weight:400;
  letter-spacing:-.01em;color:var(--bone);opacity:.35;
  font-variation-settings:"opsz" 144;
  display:inline-flex;align-items:center;gap:3.5rem;
}
.marquee span::after{content:"";display:inline-block;width:.55rem;height:.55rem;background:var(--champagne);border-radius:50%;transform:translateY(-.3em)}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ---------- MANIFESTO ---------- */
.manifesto{
  padding:clamp(5rem,12vh,10rem) 0;
  background:var(--ink);color:var(--bone);
  position:relative;overflow:hidden;
}
.manifesto-inner{
  max-width:var(--container);margin:0 auto;
  padding:0 clamp(1.25rem,2vw,2.5rem);
  display:grid;grid-template-columns:minmax(0,10ch) 1fr;gap:clamp(1.5rem,4vw,4rem);align-items:start;
}
.manifesto-number{
  font-family:var(--font-display);font-size:clamp(2rem,4vw,3.8rem);
  color:var(--champagne);opacity:.6;
  font-variation-settings:"opsz" 144;
  line-height:1;
  padding-top:.35em;
}
.manifesto-body h2{
  font-size:clamp(2.4rem,1.2rem + 5vw,6.5rem);
  line-height:1;letter-spacing:-.025em;
  font-weight:300;
  max-width:18ch;
}
.manifesto-body h2 .italic-brass{font-style:italic;color:var(--champagne);font-variation-settings:"opsz" 144,"SOFT" 100,"WONK" 1}
.manifesto-footer{
  display:grid;grid-template-columns:1fr 1fr;gap:3rem;
  margin-top:clamp(3rem,6vh,5rem);max-width:60rem;
}
.manifesto-footer p{font-family:var(--font-sans);font-size:1rem;line-height:1.8;color:var(--bone);opacity:.75}

@media (max-width:780px){
  .manifesto-inner{grid-template-columns:1fr}
  .manifesto-number{padding:0}
  .manifesto-footer{grid-template-columns:1fr}
}

/* ---------- COLLECTION (horizontal scroll) ---------- */
.collection{
  background:var(--ink);color:var(--bone);
  padding:var(--space-7) 0 0;
  position:relative;
  overflow:hidden;
}
.collection-head{
  max-width:var(--container);margin:0 auto;
  padding:0 clamp(1.25rem,2vw,2.5rem);
  display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;
  margin-bottom:var(--space-5);flex-wrap:wrap;
}
.collection-head h2{font-size:var(--fs-3xl);max-width:14ch}
.collection-head p{max-width:36ch;color:var(--bone);opacity:.7;font-size:.95rem;line-height:1.65}

.collection-scroll{
  display:flex;gap:1.2rem;overflow-x:auto;overflow-y:hidden;
  padding:1rem clamp(1.25rem,2vw,2.5rem) 3.5rem;
  scroll-snap-type:x mandatory;scrollbar-width:none;
}
.collection-scroll::-webkit-scrollbar{display:none}
.collection-card{
  flex:0 0 min(420px,78vw);
  height:clamp(460px,65vh,640px);
  position:relative;overflow:hidden;
  scroll-snap-align:start;
  isolation:isolate;
  will-change:transform;
  background:var(--shadow);
}
.collection-card img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transition:transform 1.2s var(--ease-out),filter .8s;
  filter:saturate(.96) contrast(1.02);
}
.collection-card:hover img{transform:scale(1.05)}
.collection-card::before{
  content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(to top,rgba(11,10,12,.85) 0%,rgba(11,10,12,.15) 45%,rgba(11,10,12,0) 80%);
}
.collection-card-label{
  position:absolute;top:1.5rem;left:1.5rem;z-index:2;
  font-family:var(--font-sans);font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--champagne);
}
.collection-card-meta{
  position:absolute;bottom:1.8rem;left:1.8rem;right:1.8rem;z-index:2;
}
.collection-card-meta h3{
  font-size:clamp(1.7rem,1.1rem + 1.6vw,2.6rem);
  font-weight:300;letter-spacing:-.02em;line-height:1;
  font-family:var(--font-display);margin-bottom:.7rem;
}
.collection-card-meta h3 em{font-style:italic;color:var(--champagne);font-variation-settings:"opsz" 144,"SOFT" 100}
.collection-card-meta p{font-size:.85rem;color:var(--bone);opacity:.75;line-height:1.5;max-width:28ch;margin-bottom:1.1rem}
.collection-card-meta .link-arrow{font-size:.68rem}
.collection-nav{
  display:flex;justify-content:space-between;align-items:center;gap:1rem;
  max-width:var(--container);margin:0 auto;
  padding:0 clamp(1.25rem,2vw,2.5rem) var(--space-7);
}
.collection-nav .hint{font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--whisper)}
.collection-nav .nav-buttons{display:flex;gap:.6rem}
.collection-nav button{
  width:52px;height:52px;border:1px solid var(--hairline);border-radius:999px;
  display:inline-flex;align-items:center;justify-content:center;color:var(--bone);
  transition:background .35s,color .35s,border-color .35s,transform .35s var(--ease-out);
}
.collection-nav button:hover{background:var(--champagne);color:var(--ink);border-color:var(--champagne);transform:translateY(-2px)}

/* ---------- SPLIT SCENES ---------- */
.scene{
  display:grid;grid-template-columns:1.1fr 1fr;gap:0;align-items:stretch;
  min-height:90vh;
}
.scene.reverse{grid-template-columns:1fr 1.1fr}
.scene.reverse .scene-media{order:2}
.scene.reverse .scene-body{order:1}
.scene--bone{background:var(--bone);color:var(--ink)}
.scene--ink{background:var(--ink);color:var(--bone)}
.scene--cream{background:var(--cream);color:var(--ink)}
.scene-media{position:relative;overflow:hidden;min-height:60vh}
.scene-media img,.scene-media video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.8s var(--ease-out)}
.scene:hover .scene-media img{transform:scale(1.04)}
.scene-body{
  padding:clamp(3rem,6vw,6rem) clamp(2rem,5vw,6rem);
  display:flex;flex-direction:column;justify-content:center;gap:1.7rem;
}
.scene-body h2{font-size:var(--fs-3xl);max-width:16ch;font-weight:300}
.scene-body h2 em{font-style:italic;color:var(--champagne);font-variation-settings:"opsz" 144,"SOFT" 100}
.scene-body p{font-family:var(--font-sans);font-size:1rem;line-height:1.8;opacity:.78;max-width:44ch}
.scene--bone .scene-body p{color:var(--ink);opacity:.72}
.scene-body .actions{display:flex;gap:1rem;margin-top:.6rem;flex-wrap:wrap}
.scene-media .media-label{
  position:absolute;bottom:1.5rem;left:1.5rem;z-index:2;
  padding:.6em 1em;background:rgba(11,10,12,.6);backdrop-filter:blur(10px);
  color:var(--bone);font-size:.68rem;letter-spacing:.3em;text-transform:uppercase;
  border:1px solid var(--hairline);
}

@media (max-width:900px){
  .scene,.scene.reverse{grid-template-columns:1fr;min-height:auto}
  .scene.reverse .scene-media{order:0}
  .scene.reverse .scene-body{order:0}
  .scene-media{min-height:62vh}
}

/* ---------- GUARANTEE ---------- */
.guarantee{
  background:var(--cream);color:var(--ink);
  padding:var(--space-7) 0;position:relative;overflow:hidden;
}
.guarantee-inner{
  max-width:var(--container-narrow);margin:0 auto;
  padding:0 clamp(1.25rem,2vw,2.5rem);text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:1.6rem;
}
.guarantee h2{font-size:var(--fs-3xl);max-width:22ch;font-weight:300}
.guarantee h2 em{font-style:italic;color:var(--brass);font-variation-settings:"opsz" 144,"SOFT" 100}
.guarantee p{max-width:56ch;line-height:1.8;font-size:1rem;color:var(--ink);opacity:.78}
.guarantee-chips{display:flex;gap:1.6rem;flex-wrap:wrap;justify-content:center;margin:1.2rem 0 .6rem}
.guarantee-chips span{
  font-family:var(--font-sans);font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--ink);padding:.7em 1.2em;border:1px solid var(--brass);border-radius:999px;
}
.guarantee-chips span strong{color:var(--brass);margin-right:.4em;font-weight:600}
.guarantee .actions{display:flex;gap:.9rem;flex-wrap:wrap;justify-content:center;margin-top:.6rem}

/* ---------- PROCESS ---------- */
.process{
  background:var(--ink);color:var(--bone);padding:var(--space-7) 0;
  position:relative;
}
.process-head{
  max-width:var(--container);margin:0 auto var(--space-5);
  padding:0 clamp(1.25rem,2vw,2.5rem);
  display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;
}
.process-head h2{font-size:var(--fs-3xl);max-width:18ch;font-weight:300}
.process-head p{max-width:36ch;opacity:.65;font-size:.95rem;line-height:1.65}
.process-list{
  max-width:var(--container);margin:0 auto;padding:0 clamp(1.25rem,2vw,2.5rem);
  display:flex;flex-direction:column;
}
.process-step{
  display:grid;grid-template-columns:minmax(0,12rem) minmax(0,22rem) 1fr;gap:clamp(1rem,4vw,3.5rem);
  padding:clamp(2rem,4vh,3rem) 0;
  border-top:1px solid var(--hairline);align-items:start;
  transition:padding-left .6s var(--ease-out);
}
.process-step:last-child{border-bottom:1px solid var(--hairline)}
.process-step:hover{padding-left:1rem}
.process-step .num{
  font-family:var(--font-display);font-size:clamp(2.2rem,1.1rem + 3vw,4.5rem);
  font-weight:300;color:var(--champagne);letter-spacing:-.02em;line-height:1;
  font-variation-settings:"opsz" 144;
}
.process-step h3{font-size:clamp(1.4rem,1.1rem + .8vw,2rem);max-width:16ch;font-weight:300;line-height:1.1}
.process-step h3 em{font-style:italic;color:var(--champagne);font-variation-settings:"opsz" 144,"SOFT" 100}
.process-step p{color:var(--bone);opacity:.72;line-height:1.75;font-size:.95rem;max-width:42ch}

@media (max-width:780px){
  .process-step{grid-template-columns:1fr;gap:.8rem}
  .process-step .num{font-size:2.2rem}
}

/* ---------- AUTOMATION MODULE ---------- */
.automation{
  position:relative;min-height:90vh;overflow:hidden;
  background:var(--noir);color:var(--bone);display:grid;grid-template-columns:1.15fr 1fr;
}
.automation-video{position:relative;overflow:hidden;min-height:60vh}
.automation-video video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.automation-video::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(28,26,34,0) 40%,rgba(28,26,34,.4) 100%)}
.automation-body{
  display:flex;flex-direction:column;justify-content:center;gap:1.4rem;
  padding:clamp(3rem,6vw,6rem) clamp(2rem,5vw,6rem);
}
.automation-body h2{font-size:var(--fs-3xl);max-width:14ch;font-weight:300}
.automation-body h2 em{font-style:italic;color:var(--champagne);font-variation-settings:"opsz" 144,"SOFT" 100}
.automation-body p{opacity:.78;max-width:46ch;line-height:1.8;font-size:1rem}
.automation-integrations{
  display:flex;flex-wrap:wrap;gap:.7rem 1.6rem;margin-top:1rem;
  font-family:var(--font-sans);font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--whisper);
}
.automation-integrations span{display:inline-flex;align-items:center;gap:.6rem}
.automation-integrations span::before{content:"";width:5px;height:5px;background:var(--champagne);border-radius:50%}

@media (max-width:900px){.automation{grid-template-columns:1fr}}

/* ---------- STATS ---------- */
.stats{
  background:var(--bone);color:var(--ink);padding:var(--space-7) 0;position:relative;
}
.stats-inner{
  max-width:var(--container);margin:0 auto;
  padding:0 clamp(1.25rem,2vw,2.5rem);
  display:grid;grid-template-columns:repeat(4,1fr);gap:2rem 3rem;
  align-items:start;
}
.stat{text-align:left;display:flex;flex-direction:column;gap:.6rem;padding-top:1.2rem;border-top:1px solid var(--hairline-ink)}
.stat .value{
  font-family:var(--font-display);font-size:clamp(2.8rem,1.6rem + 4vw,5.5rem);
  font-weight:300;line-height:1;letter-spacing:-.03em;color:var(--ink);
  font-variation-settings:"opsz" 144;
}
.stat .value em{font-style:italic;color:var(--brass);font-variation-settings:"opsz" 144,"SOFT" 100}
.stat .label{font-family:var(--font-sans);font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ink);opacity:.6}
@media (max-width:780px){.stats-inner{grid-template-columns:repeat(2,1fr)}}

/* ---------- GALLERY ---------- */
.gallery{background:var(--ink);color:var(--bone);padding:var(--space-7) 0;overflow:hidden}
.gallery-head{
  max-width:var(--container);margin:0 auto var(--space-5);padding:0 clamp(1.25rem,2vw,2.5rem);
  display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;
}
.gallery-head h2{font-size:var(--fs-3xl);max-width:16ch;font-weight:300}
.gallery-head p{opacity:.7;max-width:36ch;font-size:.95rem;line-height:1.65}
.bento{
  max-width:var(--container);margin:0 auto;padding:0 clamp(1.25rem,2vw,2.5rem);
  display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:minmax(140px,1fr);gap:1rem;
}
.bento-tile{position:relative;overflow:hidden;background:var(--shadow);min-height:180px}
.bento-tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease-out),filter .6s}
.bento-tile:hover img{transform:scale(1.06)}
.bento-tile::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(11,10,12,.75),rgba(11,10,12,0) 60%);pointer-events:none;opacity:.7}
.bento-tile .tile-label{position:absolute;bottom:1rem;left:1rem;z-index:2;font-size:.68rem;letter-spacing:.28em;text-transform:uppercase;color:var(--bone);opacity:0;transform:translateY(6px);transition:opacity .4s,transform .4s}
.bento-tile:hover .tile-label{opacity:.95;transform:translateY(0)}
/* Pattern */
.bento-tile.a{grid-column:span 5;grid-row:span 3}
.bento-tile.b{grid-column:span 4;grid-row:span 2}
.bento-tile.c{grid-column:span 3;grid-row:span 2}
.bento-tile.d{grid-column:span 4;grid-row:span 2}
.bento-tile.e{grid-column:span 3;grid-row:span 3}
.bento-tile.f{grid-column:span 5;grid-row:span 2}
@media (max-width:900px){
  .bento{grid-template-columns:repeat(6,1fr)}
  .bento-tile.a{grid-column:span 6;grid-row:span 2}
  .bento-tile.b{grid-column:span 3;grid-row:span 2}
  .bento-tile.c{grid-column:span 3;grid-row:span 2}
  .bento-tile.d{grid-column:span 3;grid-row:span 2}
  .bento-tile.e{grid-column:span 3;grid-row:span 2}
  .bento-tile.f{grid-column:span 6;grid-row:span 2}
}

/* ---------- TESTIMONIAL ---------- */
.testimonial{
  background:var(--cream);color:var(--ink);
  padding:var(--space-8) 0;position:relative;overflow:hidden;
}
.testimonial::before{
  content:"";position:absolute;left:-2vw;top:8%;
  width:40vw;height:40vw;max-width:320px;max-height:320px;
  border-radius:50%;background:radial-gradient(circle,rgba(201,168,106,.22),transparent 70%);
  pointer-events:none;
}
.testimonial-inner{
  max-width:var(--container-narrow);margin:0 auto;
  padding:0 clamp(1.25rem,2vw,2.5rem);
  position:relative;
  display:flex;flex-direction:column;gap:2.4rem;align-items:flex-start;
}
.testimonial .mark{font-family:var(--font-display);font-size:clamp(4rem,6vw,7rem);line-height:.7;color:var(--brass);margin-bottom:-.2em;font-variation-settings:"opsz" 144,"SOFT" 100}
.testimonial blockquote{
  font-family:var(--font-display);font-weight:300;
  font-size:clamp(1.8rem,1.2rem + 1.8vw,3.2rem);
  line-height:1.15;letter-spacing:-.015em;max-width:24ch;
  font-variation-settings:"opsz" 144,"SOFT" 50;
}
.testimonial blockquote em{font-style:italic;color:var(--brass);font-variation-settings:"opsz" 144,"SOFT" 100}
.testimonial-meta{display:flex;gap:1.2rem;align-items:center;padding-top:1rem;border-top:1px solid var(--brass);padding-right:2rem}
.testimonial-meta .stars{color:var(--brass);letter-spacing:.2em}
.testimonial-meta cite{font-style:normal;font-family:var(--font-sans);font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink);opacity:.7}
.testimonial-dots{display:flex;gap:.5rem;margin-top:1.4rem}
.testimonial-dots button{width:26px;height:2px;background:rgba(11,10,12,.2);border:0;padding:0;transition:background .3s}
.testimonial-dots button.active{background:var(--brass)}

.testimonial-fade{opacity:0;transform:translateY(16px);transition:opacity .6s,transform .6s var(--ease-out);position:absolute;inset:auto;pointer-events:none}
.testimonial-fade.active{opacity:1;transform:translateY(0);position:static;pointer-events:auto}

/* ---------- CTA BAND ---------- */
.cta-band{
  background:var(--ink);color:var(--bone);
  padding:var(--space-8) 0;
  position:relative;overflow:hidden;
}
.cta-band::before{
  content:"";position:absolute;inset:-1px;
  background:radial-gradient(ellipse at center,rgba(201,168,106,.12),transparent 60%);
  pointer-events:none;
}
.cta-band-inner{
  max-width:var(--container);margin:0 auto;
  padding:0 clamp(1.25rem,2vw,2.5rem);
  text-align:center;display:flex;flex-direction:column;gap:1.6rem;align-items:center;
}
.cta-band h2{
  font-size:clamp(2.4rem,1rem + 6vw,6.5rem);
  font-weight:300;line-height:1;letter-spacing:-.03em;max-width:16ch;
}
.cta-band h2 em{font-style:italic;color:var(--champagne);font-variation-settings:"opsz" 144,"SOFT" 100,"WONK" 1}
.cta-band p{opacity:.7;max-width:42ch;line-height:1.7}
.cta-band .actions{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;margin-top:.5rem}
.cta-band .phone-huge{
  font-family:var(--font-display);font-size:clamp(1.3rem,.8rem + 1.2vw,1.8rem);
  letter-spacing:.02em;margin-top:1rem;
  font-variation-settings:"opsz" 144;
}
.cta-band .phone-huge a{border-bottom:1px solid var(--champagne);padding-bottom:.15em}

/* ---------- JOURNAL / BLOG ---------- */
.journal{background:var(--ink);color:var(--bone);padding:var(--space-7) 0}
.journal-head{
  max-width:var(--container);margin:0 auto var(--space-5);padding:0 clamp(1.25rem,2vw,2.5rem);
  display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;
}
.journal-head h2{font-size:var(--fs-3xl);max-width:14ch;font-weight:300}
.journal-grid{
  max-width:var(--container);margin:0 auto;padding:0 clamp(1.25rem,2vw,2.5rem);
  display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;
}
.journal-card{display:flex;flex-direction:column;gap:1rem;position:relative}
.journal-card-image{position:relative;aspect-ratio:4/5;overflow:hidden;background:var(--shadow)}
.journal-card-image img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease-out)}
.journal-card:hover .journal-card-image img{transform:scale(1.05)}
.journal-card-image::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(11,10,12,.5),transparent 50%);pointer-events:none}
.journal-card .cat{font-family:var(--font-sans);font-size:.68rem;letter-spacing:.3em;text-transform:uppercase;color:var(--champagne);margin-top:.6rem}
.journal-card h3{font-size:clamp(1.1rem,1rem + .5vw,1.4rem);font-weight:400;line-height:1.3;max-width:22ch}
.journal-card p{font-family:var(--font-sans);font-size:.92rem;opacity:.7;line-height:1.6;max-width:40ch}
.journal-card .read-more{font-size:.68rem;letter-spacing:.28em;text-transform:uppercase;color:var(--champagne);display:inline-flex;gap:.5em;align-items:center;margin-top:.4rem}

@media (max-width:900px){.journal-grid{grid-template-columns:1fr}}

/* Blog filter bar */
.blog-filters{
  display:flex;gap:.6rem;flex-wrap:wrap;justify-content:center;margin:2rem 0;padding:0 1rem;
}
.blog-filters button{
  font-family:var(--font-sans);font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;
  padding:.8em 1.2em;border:1px solid var(--hairline);border-radius:999px;color:var(--bone);opacity:.7;
  transition:all .3s var(--ease-out);
}
.blog-filters button:hover{opacity:1;border-color:var(--champagne);color:var(--champagne)}
.blog-filters button.active{background:var(--champagne);color:var(--ink);border-color:var(--champagne);opacity:1}

/* ---------- FOOTER ---------- */
.site-footer{
  background:var(--ink-soft);color:var(--bone);
  padding:var(--space-7) 0 var(--space-4);border-top:1px solid var(--hairline);
}
.footer-top{
  max-width:var(--container);margin:0 auto;
  padding:0 clamp(1.25rem,2vw,2.5rem);
  display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:3rem;
  padding-bottom:var(--space-5);border-bottom:1px solid var(--hairline);
}
.footer-brand .logo{
  font-family:var(--font-display);font-size:1.8rem;font-variation-settings:"opsz" 144;
  display:flex;align-items:baseline;gap:.3em;margin-bottom:1rem;
}
.footer-brand .logo .mark{display:inline-block;width:.5em;height:.5em;background:var(--champagne);border-radius:50%;margin-right:.3em}
.footer-brand .logo em{font-style:italic;color:var(--champagne);font-variation-settings:"opsz" 144,"SOFT" 100}
.footer-brand p{font-family:var(--font-sans);opacity:.65;line-height:1.7;font-size:.9rem;max-width:36ch}
.footer-col h5{font-family:var(--font-sans);font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;color:var(--champagne);margin-bottom:1.2rem;font-weight:500}
.footer-col ul{display:flex;flex-direction:column;gap:.7rem}
.footer-col a{font-family:var(--font-sans);font-size:.9rem;opacity:.75;transition:opacity .3s,color .3s}
.footer-col a:hover{opacity:1;color:var(--champagne)}
.footer-bottom{
  max-width:var(--container);margin:0 auto;
  padding:var(--space-4) clamp(1.25rem,2vw,2.5rem) 0;
  display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;
  font-family:var(--font-sans);font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;color:var(--whisper);
}
.footer-bottom .credits{display:flex;gap:1.5rem;flex-wrap:wrap}
.footer-bottom a{opacity:.7;transition:opacity .3s,color .3s}
.footer-bottom a:hover{opacity:1;color:var(--champagne)}
.footer-contact{display:flex;gap:2rem;flex-wrap:wrap;margin-top:1rem;font-size:.92rem;opacity:.85}
.footer-contact a{border-bottom:1px solid transparent;transition:border-color .3s}
.footer-contact a:hover{border-bottom-color:var(--champagne)}

@media (max-width:900px){
  .footer-top{grid-template-columns:1fr 1fr;gap:2rem}
  .footer-brand{grid-column:1/-1}
}

/* ---------- PAGE BANNER (interior pages) ---------- */
.page-banner{
  position:relative;min-height:70vh;display:flex;align-items:flex-end;
  color:var(--bone);overflow:hidden;isolation:isolate;
  background:var(--ink);
}
.page-banner-bg{position:absolute;inset:0;z-index:-2}
.page-banner-bg img,.page-banner-bg video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.85)}
.page-banner-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,rgba(11,10,12,.55),rgba(11,10,12,.25) 40%,rgba(11,10,12,.85) 100%)}
.page-banner-content{
  position:relative;z-index:2;max-width:var(--container);margin:0 auto;
  padding:clamp(6rem,10vh,9rem) clamp(1.25rem,2vw,2.5rem) var(--space-5);
  width:100%;
}
.page-banner h1{
  font-size:clamp(2.8rem,1.6rem + 4.5vw,6.2rem);font-weight:300;max-width:20ch;line-height:1;letter-spacing:-.025em;
}
.page-banner h1 em{font-style:italic;color:var(--champagne);font-variation-settings:"opsz" 144,"SOFT" 100,"WONK" 1}
.page-banner p.lede{margin-top:1.6rem;color:var(--bone);opacity:.88}

/* ---------- FORM ---------- */
.quote-form{
  display:flex;flex-direction:column;gap:1.2rem;
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-row.full{grid-template-columns:1fr}
.form-group{display:flex;flex-direction:column;gap:.4rem;position:relative}
.form-group label{
  font-family:var(--font-sans);font-size:.68rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--bone);opacity:.7;
}
.section--bone .form-group label,.section--cream .form-group label{color:var(--ink);opacity:.7}
.form-group input,.form-group select,.form-group textarea{
  font-family:var(--font-sans);font-size:1rem;padding:1em 0 .9em;
  border:0;border-bottom:1px solid var(--hairline);background:transparent;color:inherit;
  transition:border-color .3s;
}
.section--bone .form-group input,.section--cream .form-group input,
.section--bone .form-group select,.section--cream .form-group select,
.section--bone .form-group textarea,.section--cream .form-group textarea{
  border-bottom-color:rgba(11,10,12,.2);
}
.form-group textarea{min-height:120px;resize:vertical}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:0;border-bottom-color:var(--champagne)}
.form-group option{color:#000}
.form-submit{margin-top:1rem}
.form-thanks{
  padding:2rem;border:1px solid var(--champagne);background:rgba(201,168,106,.08);
  font-family:var(--font-display);font-size:1.3rem;font-weight:300;
}
.form-thanks em{font-style:italic;color:var(--champagne);font-variation-settings:"opsz" 144,"SOFT" 100}

/* ---------- REVEAL SYSTEM ---------- */
.reveal{opacity:0;transform:translateY(30px);transition:opacity 1s var(--ease-out),transform 1s var(--ease-out)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal--stagger > *{opacity:0;transform:translateY(30px);transition:opacity .9s var(--ease-out),transform .9s var(--ease-out)}
.reveal--stagger.in > *{opacity:1;transform:translateY(0)}
.reveal--stagger.in > *:nth-child(1){transition-delay:.05s}
.reveal--stagger.in > *:nth-child(2){transition-delay:.15s}
.reveal--stagger.in > *:nth-child(3){transition-delay:.25s}
.reveal--stagger.in > *:nth-child(4){transition-delay:.35s}
.reveal--stagger.in > *:nth-child(5){transition-delay:.45s}
.reveal--stagger.in > *:nth-child(6){transition-delay:.55s}

.reveal-mask{overflow:hidden;display:inline-block;vertical-align:top}
.reveal-mask > *{display:inline-block;transform:translateY(105%);transition:transform 1.1s var(--ease-out)}
.reveal-mask.in > *{transform:translateY(0)}

.parallax{will-change:transform}

/* ---------- A11Y ---------- */
:focus-visible{outline:2px solid var(--champagne);outline-offset:3px;border-radius:2px}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}
  .hero-video video{transform:none !important}
  .marquee-track{animation:none !important}
}

/* =====================================================================
   ADDITIONS — Parade treatment: preloader, CTA dock, utility bar,
   logo mark, pinned horizontal chapters, scroll-scrubbed hero.
   ===================================================================== */

/* ---------- PRELOADER ---------- */
.preloader{
  position:fixed;inset:0;z-index:200;background:var(--ink);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;
  transition:opacity .9s var(--ease-out),visibility .9s;
}
.preloader .pl-logo{
  width:clamp(120px,18vw,180px);opacity:0;
  transform:scale(.96);filter:blur(4px);
  transition:opacity 1s var(--ease-out),transform 1.2s var(--ease-out),filter 1s var(--ease-out);
}
.preloader .pl-bar{
  width:clamp(180px,22vw,280px);height:1px;background:rgba(201,168,106,.18);overflow:hidden;position:relative;
}
.preloader .pl-bar::after{
  content:"";position:absolute;inset:0;background:var(--champagne);
  transform-origin:left;transform:scaleX(0);
  animation:pl-fill 1.3s .25s var(--ease-out) forwards;
}
.preloader .pl-word{font-family:var(--font-sans);font-size:.72rem;letter-spacing:.4em;text-transform:uppercase;color:var(--whisper);opacity:0;animation:pl-fade-in 1s .4s forwards}
@keyframes pl-fill{to{transform:scaleX(1)}}
@keyframes pl-fade-in{to{opacity:1}}
body.pl-ready .preloader .pl-logo{opacity:1;transform:scale(1);filter:blur(0)}
body.pl-done .preloader{opacity:0;visibility:hidden;pointer-events:none}
body.pl-done .site-header,body.pl-done .utility-bar,body.pl-done .hero h1 .reveal-mask > *{/* allow child reveals */}
.no-js .preloader{display:none}

/* ---------- UTILITY BAR ---------- */
.utility-bar{
  position:fixed;top:0;left:0;right:0;z-index:75;
  display:flex;justify-content:space-between;align-items:center;
  padding:.6rem clamp(1rem,2vw,2.2rem);
  background:rgba(11,10,12,.82);backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--hairline);
  font-family:var(--font-sans);font-size:.68rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--bone);
  transition:transform .5s var(--ease-out),opacity .5s;
}
body.utility-hidden .utility-bar{transform:translateY(-100%)}
.utility-bar .ub-left{display:flex;align-items:center;gap:1.2rem}
.utility-bar .ub-right{display:flex;align-items:center;gap:1.2rem}
.utility-bar .dot{color:var(--champagne);opacity:.6}
.utility-bar a{display:inline-flex;align-items:center;gap:.5em;transition:color .3s}
.utility-bar a:hover{color:var(--champagne)}
.utility-bar .ub-phone strong{color:var(--champagne);letter-spacing:.15em;font-weight:500}
.utility-bar .ub-sep{width:1px;height:10px;background:var(--hairline);display:inline-block}
.utility-bar .ub-live{display:inline-flex;align-items:center;gap:.5em}
.utility-bar .ub-live::before{content:"";width:6px;height:6px;background:#5EE6A6;border-radius:50%;box-shadow:0 0 8px #5EE6A6;animation:live-blink 2.2s infinite}
@keyframes live-blink{0%,100%{opacity:1}50%{opacity:.35}}
@media (max-width:780px){
  .utility-bar{font-size:.62rem;padding:.5rem .9rem;letter-spacing:.2em}
  .utility-bar .ub-hide-sm{display:none}
}

/* Adjust header to sit under utility bar */
.site-header{top:34px}
body.utility-hidden .site-header{top:0}
@media (max-width:780px){
  .site-header{top:30px}
}

/* ---------- LOGO MARK ---------- */
.logo-mark{
  display:inline-flex;align-items:center;gap:.7rem;height:42px;
}
.logo-mark img{height:100%;width:auto;display:block}
.site-header.shrunk .logo-mark{height:36px}
.site-header.shrunk .logo-mark img{height:100%}
@media (max-width:780px){
  .logo-mark{height:36px}
}

/* ---------- PERSISTENT CTA DOCK (floating) ---------- */
.cta-dock{
  position:fixed;z-index:78;
  right:clamp(1rem,1.6vw,1.6rem);bottom:clamp(1rem,2.4vh,1.8rem);
  display:flex;flex-direction:column;gap:.7rem;align-items:flex-end;
  opacity:0;transform:translateY(20px);
  transition:opacity .6s var(--ease-out),transform .6s var(--ease-out);
  pointer-events:none;
}
body.cta-dock-on .cta-dock{opacity:1;transform:translateY(0);pointer-events:auto}
.cta-dock .cd-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.7em;
  width:56px;height:56px;border-radius:50%;
  background:var(--ink);color:var(--bone);border:1px solid var(--hairline);
  box-shadow:0 20px 40px rgba(0,0,0,.35);
  transition:background .35s,color .35s,border-color .35s,transform .35s var(--ease-out),width .35s var(--ease-out);
  overflow:hidden;white-space:nowrap;position:relative;
}
.cta-dock .cd-btn:hover{background:var(--champagne);color:var(--ink);border-color:var(--champagne);transform:translateY(-3px)}
.cta-dock .cd-btn svg{width:20px;height:20px;flex-shrink:0}
.cta-dock .cd-primary{
  width:auto;padding:0 1.6em;border-radius:999px;
  background:var(--champagne);color:var(--ink);border-color:var(--champagne);
  font-family:var(--font-sans);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;font-weight:500;
  height:56px;
}
.cta-dock .cd-primary:hover{background:var(--champagne-bright);border-color:var(--champagne-bright);color:var(--ink);transform:translateY(-3px)}
.cta-dock .cd-primary .cd-full{display:inline}
.cta-dock .cd-primary .cd-short{display:none}
.cta-dock .cd-label{
  opacity:0;width:0;margin-right:0;
  transition:opacity .3s,width .3s,margin-right .3s;
  font-family:var(--font-sans);font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;font-weight:500;
}
.cta-dock .cd-btn:hover .cd-label{opacity:1;width:auto;margin-right:.3em}
.cta-dock .cd-btn:hover:not(.cd-primary){width:auto;padding:0 1.4em;border-radius:999px}

/* Mobile: pinned bottom bar */
@media (max-width:780px){
  .cta-dock{
    right:0;left:0;bottom:0;
    flex-direction:row;gap:0;
    background:var(--ink);
    border-top:1px solid var(--hairline);padding:.55rem;
  }
  .cta-dock .cd-btn{
    width:100%;height:52px;border-radius:0;background:transparent;border:0;flex:1;
    border-right:1px solid var(--hairline);padding:0;
    box-shadow:none;
  }
  .cta-dock .cd-btn:last-child{border-right:0}
  .cta-dock .cd-btn:hover{transform:none;background:rgba(201,168,106,.1)}
  .cta-dock .cd-primary{border-radius:0;background:var(--champagne);color:var(--ink);letter-spacing:.12em;font-size:.65rem;padding:0 .8em}
  .cta-dock .cd-primary:hover{background:var(--champagne-bright)}
  .cta-dock .cd-primary .cd-full{display:none}
  .cta-dock .cd-primary .cd-short{display:inline}
  .cta-dock .cd-label{opacity:1;width:auto;margin:0 0 0 .55rem;font-size:.6rem;letter-spacing:.2em}
}

/* ---------- HERO — scroll-scrubbed variant ---------- */
.hero-scrub{min-height:150vh;position:relative}
.hero-scrub .hero-sticky{
  position:sticky;top:0;height:100vh;height:100svh;
  display:flex;align-items:flex-end;overflow:hidden;color:var(--bone);isolation:isolate;
}
.hero-scrub .hero-video{position:absolute;inset:0;z-index:-2}
.hero-scrub .hero-video video{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transform:scale(1.02);
}
.hero-scrub .hero-video::after{
  content:"";position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(ellipse at 30% 30%,rgba(11,10,12,0) 0%,rgba(11,10,12,.35) 60%),
    linear-gradient(to bottom,rgba(11,10,12,.3) 0%,rgba(11,10,12,.05) 32%,rgba(11,10,12,.35) 65%,rgba(11,10,12,.9) 100%);
}
.hero-scrub .hero-content{
  position:relative;z-index:2;width:100%;max-width:var(--container);margin:0 auto;
  padding:0 clamp(1.25rem,2vw,2.5rem) clamp(3rem,8vh,6rem);
  display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:end;
}

.hero-logo-frame{
  position:absolute;z-index:2;top:clamp(6rem,14vh,9rem);left:50%;transform:translateX(-50%);
  width:clamp(180px,22vw,320px);opacity:0;filter:drop-shadow(0 8px 32px rgba(0,0,0,.55));
  transition:opacity 1.2s .4s var(--ease-out),transform 1.2s .4s var(--ease-out);
}
.hero-scrub.ready .hero-logo-frame{opacity:.96;transform:translateX(-50%) translateY(0)}
.hero-logo-frame img{width:100%;height:auto;display:block}

.hero-scrub h1{
  font-size:clamp(3.2rem,2rem + 7vw,9rem);
  line-height:.96;letter-spacing:-.035em;font-weight:300;max-width:18ch;
}

.hero-scrub .hero-progress{
  position:absolute;left:clamp(1.25rem,2vw,2.5rem);right:clamp(1.25rem,2vw,2.5rem);
  bottom:1.2rem;z-index:3;height:1px;background:rgba(245,240,231,.12);
}
.hero-scrub .hero-progress::after{
  content:"";position:absolute;inset:0;background:var(--champagne);
  transform-origin:left;transform:scaleX(var(--hero-progress,0));
  transition:transform .2s linear;
}

/* ---------- PINNED HORIZONTAL CHAPTERS ---------- */
.chapters{
  position:relative;background:var(--ink);color:var(--bone);
}
.chapters-head{
  max-width:var(--container);margin:0 auto;padding:var(--space-7) clamp(1.25rem,2vw,2.5rem) var(--space-5);
  display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;
}
.chapters-head h2{font-size:var(--fs-3xl);max-width:14ch;font-weight:300}
.chapters-head p{opacity:.7;max-width:36ch;font-size:.95rem;line-height:1.65}

.chapters-pin{
  position:relative;
  /* height = (N-1) * 100vh so we can scroll through N panels */
}
.chapters-sticky{
  position:sticky;top:0;height:100vh;height:100svh;overflow:hidden;
  display:flex;flex-direction:column;
}
.chapters-track{
  display:flex;height:100%;flex:1;
  transform:translate3d(calc(var(--chapters-offset,0) * -1), 0, 0);
  will-change:transform;
}
.chapter-panel{
  flex:0 0 100%;height:100%;
  display:grid;grid-template-columns:1.15fr 1fr;align-items:stretch;
  background:var(--ink);color:var(--bone);position:relative;
}
.chapter-panel .cp-media{position:relative;overflow:hidden}
.chapter-panel .cp-media img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transform:scale(1.08);transition:transform 1.6s var(--ease-out),filter 1s;filter:saturate(.95);
}
.chapter-panel.active .cp-media img{transform:scale(1)}
.chapter-panel .cp-media::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(11,10,12,0) 60%,rgba(11,10,12,.35) 100%);
  pointer-events:none;
}
.chapter-panel .cp-body{
  display:flex;flex-direction:column;justify-content:center;gap:1.2rem;
  padding:clamp(2rem,5vw,5rem) clamp(1.5rem,4vw,5rem);
  position:relative;
}
.chapter-panel .cp-num{
  font-family:var(--font-display);font-size:clamp(1rem,1vw + .6rem,1.2rem);
  color:var(--champagne);letter-spacing:.3em;margin-bottom:.5rem;
  font-variation-settings:"opsz" 12;
}
.chapter-panel .cp-category{font-family:var(--font-sans);font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;color:var(--whisper)}
.chapter-panel h3{
  font-size:clamp(2.6rem,1.5rem + 4vw,5.2rem);
  font-weight:300;line-height:.98;letter-spacing:-.03em;max-width:14ch;
}
.chapter-panel h3 em{font-style:italic;color:var(--champagne);font-variation-settings:"opsz" 144,"SOFT" 100,"WONK" 1}
.chapter-panel p{font-family:var(--font-sans);font-size:1rem;line-height:1.75;opacity:.78;max-width:42ch;margin-top:.4rem}
.chapter-panel .cp-features{
  display:flex;flex-wrap:wrap;gap:1rem;margin-top:.6rem;
  font-family:var(--font-sans);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--whisper);
}
.chapter-panel .cp-features span{display:inline-flex;align-items:center;gap:.5em}
.chapter-panel .cp-features span::before{content:"";width:4px;height:4px;background:var(--champagne);border-radius:50%}
.chapter-panel .cp-actions{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1rem}

/* Chapters footer controls */
.chapters-controls{
  position:absolute;bottom:1.5rem;left:0;right:0;z-index:3;
  display:flex;justify-content:space-between;align-items:center;gap:1rem;
  padding:0 clamp(1.25rem,2vw,2.5rem);pointer-events:none;
}
.chapters-counter{
  font-family:var(--font-display);font-size:clamp(1.2rem,.8rem + 1vw,1.8rem);color:var(--bone);
  font-variation-settings:"opsz" 24;display:flex;align-items:center;gap:.6em;
  pointer-events:auto;
}
.chapters-counter .c-current{color:var(--champagne);font-size:1.5em;line-height:1;font-variation-settings:"opsz" 144}
.chapters-counter .c-sep{opacity:.3;height:1px;background:currentColor;width:2rem;display:inline-block;margin:0 .1em}
.chapters-counter .c-total{opacity:.5}
.chapters-hint{font-family:var(--font-sans);font-size:.68rem;letter-spacing:.3em;text-transform:uppercase;color:var(--whisper);pointer-events:auto}
.chapters-nav{display:flex;gap:.6rem;pointer-events:auto}
.chapters-nav button{
  width:44px;height:44px;border:1px solid var(--hairline);border-radius:999px;
  display:inline-flex;align-items:center;justify-content:center;color:var(--bone);
  transition:all .35s var(--ease-out);background:rgba(11,10,12,.35);backdrop-filter:blur(6px);
}
.chapters-nav button:hover{background:var(--champagne);color:var(--ink);border-color:var(--champagne)}
.chapters-nav button:disabled{opacity:.3;cursor:default}

/* Mobile fallback: stack panels vertically, no pinning */
@media (max-width:900px){
  .chapters-pin{height:auto !important}
  .chapters-sticky{position:static;height:auto}
  .chapters-track{flex-direction:column;transform:none !important;height:auto}
  .chapter-panel{flex:0 0 auto;min-height:90vh;grid-template-columns:1fr}
  .chapter-panel .cp-media{min-height:45vh}
  .chapters-controls{position:static;padding:1rem clamp(1.25rem,2vw,2.5rem) 2rem}
  .chapters-nav{display:none}
}

/* ---------- REFINED SPACING (push everything a bit more cinematic) ---------- */
.section-xl{padding:var(--space-8) 0}
.cta-band{padding:calc(var(--space-8) + 2rem) 0}

/* ---------- LOGO LOCKUP ---------- */
.brand-lockup{display:inline-flex;align-items:center;gap:.9rem}
.brand-lockup img{height:34px;display:block}
.footer-brand .logo-mark{height:48px}
.footer-brand .logo-mark img{height:100%}

/* ---------- MISC ---------- */
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ---------- V3: Chapter panels — full clickable area ---------- */
.chapter-panel .cp-media{cursor:pointer}
.chapter-panel .cp-body h3{cursor:pointer}
.chapter-panel .cp-body h3:hover{color:var(--champagne)}
.chapter-panel .cp-body h3:hover em{color:var(--champagne-bright)}
/* Make cp-media a link wrapper via JS — add visual cue */
.chapter-panel .cp-media::before{
  content:"View Collection";
  position:absolute;bottom:1.5rem;left:1.5rem;
  font-family:var(--font-sans);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--bone);opacity:0;
  transition:opacity .4s var(--ease-out);z-index:3;
}
.chapter-panel .cp-media:hover::before{opacity:1}
