/* ============================================================
   INTERIUS · pre-launch — KINETIC STATEMENT
   Bold, graphic, motion-forward. Paper / espresso / brass.
   ============================================================ */

:root{
  --paper:#efe7d9; --paper-2:#faf6ee; --paper-3:#fdfaf3;
  --espresso:#211d18; --espresso-2:#2a251f; --espresso-deep:#1b1712; --espresso-bg:#161210;
  --ink:#221e18; --ink-soft:#5b5346; --ink-mute:#8c8273; --ink-faint:#a89e8d;
  --brass:#b8956a; --brass-deep:#7a6b52; --brass-light:#d4b896;
  --brass-line:rgba(184,149,106,.5);
  --line:#d9cfbd; --line-2:#cbbfa8;
  --cream:#efe7d9; --cream-soft:rgba(239,231,217,.78); --cream-mid:rgba(239,231,217,.55); --cream-faint:rgba(239,231,217,.38);
  --on-brass:#241d14;

  --display:'Libre Bodoni', Georgia, serif;
  --body:'Outfit', system-ui, sans-serif;
  --label:'Montserrat', system-ui, sans-serif;

  --fs-hero:clamp(2.4rem, 6.1vw, 5.4rem);
  --fs-dx-xl:clamp(2.6rem, 7vw, 6rem);
  --fs-dx-l:clamp(2.1rem, 4.6vw, 3.6rem);
  --fs-lede:clamp(1.04rem, 1.45vw, 1.32rem);
  --fs-body:clamp(0.96rem, 1.15vw, 1.08rem);
  --fs-eye:clamp(.62rem, .82vw, .74rem);

  --gutter:clamp(1.4rem, 5vw, 5.5rem);
  --wrap:1320px;
  --ease:cubic-bezier(.16,.84,.34,1);
  --ease-io:cubic-bezier(.7,0,.3,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto !important}
.lenis.lenis-stopped{overflow:hidden}

body{
  font-family:var(--body);font-weight:300;color:var(--cream);
  background:var(--espresso-bg);font-size:var(--fs-body);line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--brass);color:var(--on-brass)}

.wrap{width:100%;max-width:var(--wrap);margin-inline:auto;padding-inline:var(--gutter)}
.wordmark{font-family:var(--display);font-style:italic;font-weight:400;letter-spacing:.004em}
.display{font-family:var(--display);font-weight:400;line-height:1.0;letter-spacing:-.02em;text-wrap:balance}
/* italic keyword emphasis (brand voice) */
.rail__title em,.detail__title em,.wl__title em,.join__title em{font-style:italic;color:var(--brass-light)}
.ba__title em,.brands__title em{font-style:italic;color:var(--brass-deep)}

.eyebrow{font-family:var(--label);font-weight:600;font-size:var(--fs-eye);letter-spacing:.36em;text-transform:uppercase;color:var(--brass);display:inline-flex;align-items:center;gap:.9em}
.eyebrow::before{content:"";width:30px;height:1px;background:currentColor;flex:none;opacity:.8}
.eyebrow--center{justify-content:center}
.eyebrow--light{color:var(--brass-light)}
.lede{font-weight:300;font-size:var(--fs-lede);line-height:1.58;color:var(--cream-soft);text-wrap:pretty}

/* ============================================================
   Grain + cursor
   ============================================================ */
/* plain overlay (no mix-blend) — fixed full-screen blends are a scroll-perf killer */
.grain{position:fixed;inset:0;z-index:9000;pointer-events:none;opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

.cursor{position:fixed;top:0;left:0;z-index:9500;pointer-events:none;opacity:0;transition:opacity .4s ease}
.cursor.is-active{opacity:1}
.cursor__dot{position:absolute;width:6px;height:6px;margin:-3px 0 0 -3px;border-radius:50%;background:var(--brass)}
.cursor__ring{position:absolute;width:42px;height:42px;margin:-21px 0 0 -21px;border:1px solid var(--brass-line);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:width .3s var(--ease),height .3s var(--ease),margin .3s var(--ease),background .3s ease,border-color .3s ease}
.cursor__label{font-family:var(--label);font-weight:600;font-size:.56rem;letter-spacing:.18em;text-transform:uppercase;color:var(--on-brass);opacity:0;transition:opacity .25s ease}
.cursor.is-hover .cursor__ring{width:66px;height:66px;margin:-33px 0 0 -33px;border-color:var(--brass);background:rgba(184,149,106,.08)}
.cursor.is-label .cursor__ring{width:84px;height:84px;margin:-42px 0 0 -42px;background:var(--brass);border-color:var(--brass)}
.cursor.is-label .cursor__label{opacity:1}
.cursor.is-down .cursor__ring{transform:scale(.82)}

/* ============================================================
   Loader
   ============================================================ */
.loader{position:fixed;inset:0;z-index:9800;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.4rem;background:var(--espresso-bg);transition:transform 1.05s var(--ease-io),opacity .5s ease .6s}
.loader.is-done{transform:translateY(-101%)}
.loader__count{font-family:var(--display);font-size:clamp(3rem,9vw,6rem);line-height:1;color:var(--cream);display:flex;align-items:baseline}
.loader__pct{font-family:var(--label);font-weight:500;font-size:.9rem;letter-spacing:.1em;color:var(--brass);margin-left:.4rem;text-transform:uppercase}
.loader__mark{font-size:clamp(1.1rem,2.4vw,1.5rem);color:var(--brass-light)}
.loader__bar{width:min(240px,46vw);height:2px;background:rgba(212,184,150,.16);overflow:hidden}
.loader__bar span{display:block;height:100%;width:0;background:var(--brass);transition:width .2s linear}

/* ============================================================
   Nav
   ============================================================ */
.nav{position:fixed;top:0;left:0;right:0;z-index:7000;display:flex;align-items:center;justify-content:space-between;
  padding:clamp(1rem,2.3vw,1.7rem) var(--gutter);transition:background .5s ease,padding .5s ease,border-color .5s ease;border-bottom:1px solid transparent;mix-blend-mode:normal}
.nav.is-stuck{background:rgba(22,18,16,.7);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom-color:rgba(212,184,150,.12);padding-block:clamp(.7rem,1.5vw,1rem)}
.nav__mark{font-size:clamp(1.35rem,2.2vw,1.7rem);color:var(--cream);line-height:1}
.nav__cta{position:relative;font-family:var(--label);font-weight:600;font-size:.64rem;letter-spacing:.22em;text-transform:uppercase;color:var(--cream);padding:.85em 1.5em;border:1px solid var(--brass-line);border-radius:40px;overflow:hidden;will-change:transform}
.nav__cta span{position:relative;z-index:2;transition:color .4s var(--ease)}
.nav__cta::before{content:"";position:absolute;inset:0;background:var(--brass);transform:translateY(101%);transition:transform .45s var(--ease);z-index:1}
.nav__cta:hover::before{transform:translateY(0)}
.nav__cta:hover span{color:var(--on-brass)}

/* ============================================================
   CTA (big arrow button)
   ============================================================ */
.cta{position:relative;display:inline-flex;align-items:center;gap:1rem;font-family:var(--label);font-weight:600;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--on-brass);background:var(--brass);padding:1.25em 2em;border-radius:50px;overflow:hidden;will-change:transform}
.cta__label,.cta__arrow{position:relative;z-index:2;transition:transform .5s var(--ease)}
.cta__arrow{font-size:1.1em}
.cta::before{content:"";position:absolute;inset:0;background:var(--brass-light);transform:translateX(-101%);transition:transform .5s var(--ease);z-index:1}
.cta:hover::before{transform:translateX(0)}
.cta:hover .cta__arrow{transform:translateX(6px)}
.cta--solid{background:var(--brass)}

/* ============================================================
   Tickers / marquees
   ============================================================ */
.ticker{overflow:hidden;width:100%}
.ticker__row,.brands__row,.wl__row{display:inline-flex;align-items:center;white-space:nowrap;will-change:transform}
.ticker__row{gap:1.6rem;font-family:var(--label);font-weight:500;font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;color:var(--cream-mid);animation:marquee 38s linear infinite}
.ticker__row i{color:var(--brass);font-style:normal}

@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes marquee-rev{from{transform:translateX(-50%)}to{transform:translateX(0)}}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;overflow:hidden;padding-bottom:clamp(3rem,6vw,5rem)}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__img{width:100%;height:100%;object-fit:cover;object-position:center 40%;will-change:transform;animation:heroZoom 20s ease-out forwards}
@keyframes heroZoom{from{transform:scale(1.09)}to{transform:scale(1)}}
.hero__scrim{position:absolute;inset:0;background:
  linear-gradient(180deg, rgba(22,18,16,.55) 0%, rgba(22,18,16,.08) 22%, rgba(22,18,16,.22) 52%, rgba(22,18,16,.92) 100%),
  linear-gradient(94deg, rgba(22,18,16,.78) 0%, rgba(22,18,16,.3) 40%, rgba(22,18,16,0) 70%)}
.ticker--top{position:relative;z-index:3;margin-top:clamp(5rem,10vw,6.8rem);border-block:1px solid rgba(212,184,150,.16);padding-block:.85rem;background:rgba(22,18,16,.28);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.hero__inner{position:relative;z-index:3;width:100%;flex:1;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-end;padding-top:clamp(2rem,5vw,4rem)}
.hero__eye{margin-bottom:clamp(1.1rem,2.4vw,1.7rem)}
.hero__title{font-family:var(--display);font-weight:400;color:var(--cream);line-height:.97;letter-spacing:-.028em;display:flex;flex-direction:column;font-size:var(--fs-hero)}
.hero__l{display:block}
.hero__title em{font-style:italic;color:var(--brass-light)}
.hero__lede{margin-top:clamp(1.1rem,2vw,1.6rem);max-width:40ch;color:var(--cream);font-weight:300;font-size:clamp(1.2rem,1.95vw,1.7rem);letter-spacing:.005em}
.hero__cta{margin-top:clamp(1.8rem,3.4vw,2.6rem)}
.hero__tag{position:absolute;right:clamp(1.2rem,2.5vw,2.4rem);bottom:clamp(1.5rem,3vw,2.4rem);z-index:3;font-family:var(--label);font-weight:500;font-size:.56rem;letter-spacing:.2em;text-transform:uppercase;color:var(--cream-mid)}

/* ============================================================
   COLLAPSE (paper)
   ============================================================ */
.collapse{background:var(--paper);color:var(--ink);position:relative;padding-block:clamp(5rem,11vw,9rem);text-align:center;overflow:hidden}
.collapse::after{content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;mix-blend-mode:multiply;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E")}
.collapse__wrap{position:relative;z-index:2;max-width:1000px;display:flex;flex-direction:column;align-items:center}
.collapse .eyebrow{color:var(--brass-deep)}
.collapse__stack{margin-top:2rem;display:flex;flex-wrap:wrap;justify-content:center;gap:.7rem 1.5rem;max-width:840px}
.collapse__stack span{position:relative;font-family:var(--body);font-weight:300;font-size:clamp(1rem,1.8vw,1.5rem);color:var(--ink-mute)}
.collapse__stack span::after{content:"";position:absolute;left:-4px;right:-4px;top:55%;height:2px;background:var(--brass);transform:rotate(-2deg) scaleX(0);transform-origin:left;transition:transform .55s var(--ease)}
.collapse__stack.in span::after{transform:rotate(-2deg) scaleX(1)}
.collapse__stack.in span:nth-child(2)::after{transition-delay:.05s}
.collapse__stack.in span:nth-child(3)::after{transition-delay:.1s}
.collapse__stack.in span:nth-child(4)::after{transition-delay:.15s}
.collapse__stack.in span:nth-child(5)::after{transition-delay:.2s}
.collapse__stack.in span:nth-child(6)::after{transition-delay:.25s}
.collapse__stack.in span:nth-child(n+7)::after{transition-delay:.3s}
.collapse__becomes{margin-top:2.6rem;font-family:var(--label);font-weight:600;font-size:.7rem;letter-spacing:.34em;text-transform:uppercase;color:var(--brass-deep)}
.collapse__mark{font-size:clamp(3.4rem,11vw,8rem);color:var(--ink);line-height:1;margin-top:.6rem;display:inline-flex}
.collapse__mark .ltr{display:inline-block;opacity:0;transform:translateY(.5em) rotate(6deg);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.collapse__mark.in .ltr{opacity:1;transform:none}
.collapse__line{margin-top:1.8rem;max-width:48ch;font-family:var(--display);font-style:italic;font-size:clamp(1.1rem,1.9vw,1.45rem);color:var(--brass-deep);line-height:1.4;text-wrap:balance}

/* ============================================================
   RAIL (horizontal scroll · espresso)
   ============================================================ */
.rail{position:relative;background:var(--espresso);color:var(--cream)}
.rail__head{padding-top:clamp(4rem,8vw,7rem);padding-bottom:clamp(1.5rem,3vw,2.5rem)}
.rail__head .eyebrow{color:var(--brass-light)}
.rail__title{font-family:var(--display);font-size:var(--fs-dx-l);color:var(--cream);margin-top:1rem;letter-spacing:-.02em}
.rail__sticky{position:sticky;top:0;height:100vh;height:100svh;overflow:hidden;display:flex;align-items:center}
.rail__track{display:flex;height:100%;will-change:transform}
.panel{position:relative;flex:0 0 100vw;height:100%;display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:clamp(2rem,4vw,5rem);padding:clamp(5rem,8vw,7rem) var(--gutter) clamp(3rem,5vw,4rem)}
.panel__text{display:flex;flex-direction:column;align-items:flex-start}
.panel__n{font-family:var(--label);font-weight:600;font-size:.8rem;letter-spacing:.3em;color:var(--brass-light)}
.panel__verb{font-family:var(--display);font-weight:400;font-size:clamp(3rem,8vw,7rem);line-height:.9;color:var(--cream);margin-top:.6rem;letter-spacing:-.03em}
.panel__line{margin-top:1.6rem;max-width:38ch;font-size:var(--fs-lede);color:var(--cream-soft);line-height:1.55}
.panel__media{position:relative;border-radius:14px;overflow:hidden;border:1px solid rgba(212,184,150,.2);box-shadow:0 40px 80px -40px rgba(0,0,0,.7);background:#0e0b09}
.panel__media img{width:100%;height:auto;display:block}
.panel__media--portrait{max-width:78%;justify-self:center}
.panel__media--sheet{max-width:62%;justify-self:center;background:var(--paper-3)}
.panel__media--detail{max-width:84%;justify-self:center}
.panel__media--pack{background:transparent;border:none;box-shadow:none;overflow:visible;display:flex;align-items:center;justify-content:center}
.pack{position:relative;width:min(60%,350px);aspect-ratio:210/297}
.pack__s{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:8px;border:1px solid rgba(212,184,150,.22);box-shadow:0 30px 60px -28px rgba(0,0,0,.75);background:var(--paper-3)}
.pack__s--1{transform:rotate(-7deg) translate(-17%,5%);z-index:1;filter:brightness(.84)}
.pack__s--2{transform:rotate(6deg) translate(15%,3%);z-index:2;filter:brightness(.92)}
.pack__s--3{transform:rotate(-1.5deg);z-index:3}

/* ============================================================
   BEFORE / AFTER slider (paper)
   ============================================================ */
.ba{background:var(--paper);color:var(--ink);padding-block:clamp(5rem,10vw,8rem);position:relative}
.ba__head{text-align:center;display:flex;flex-direction:column;align-items:center}
.ba .eyebrow{color:var(--brass-deep)}
.ba__title{font-size:var(--fs-dx-xl);color:var(--ink);margin-top:1.2rem}
.ba__sub{margin-top:1.1rem;font-family:var(--label);font-weight:500;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-mute)}
.ba__stage{position:relative;width:min(1180px,92vw);margin:clamp(2.5rem,5vw,4rem) auto 0;aspect-ratio:3/2;border-radius:16px;overflow:hidden;border:1px solid var(--line-2);box-shadow:0 50px 90px -50px rgba(33,29,24,.5);user-select:none;touch-action:pan-y}
.ba__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none}
.ba__before{position:absolute;inset:0;overflow:hidden;clip-path:inset(0 calc(100% - var(--baw,50%)) 0 0);will-change:clip-path}
.ba__before .ba__img{width:100%;height:100%;object-fit:cover}
.ba__tag{position:absolute;top:18px;z-index:3;font-family:var(--label);font-weight:600;font-size:.6rem;letter-spacing:.24em;text-transform:uppercase;padding:.55em 1.1em;border-radius:30px;background:rgba(22,18,16,.6);color:var(--cream);backdrop-filter:blur(6px)}
.ba__tag--l{left:18px}.ba__tag--r{right:18px}
.ba__handle{position:absolute;top:0;bottom:0;left:var(--baw,50%);width:2px;background:var(--brass);transform:translateX(-50%);z-index:4;cursor:ew-resize}
.ba__handle-grip{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:54px;height:54px;border-radius:50%;background:var(--brass);box-shadow:0 8px 24px -6px rgba(33,29,24,.6);display:flex;align-items:center;justify-content:center}
.ba__handle-grip::before,.ba__handle-grip::after{content:"";position:absolute;width:0;height:0;border-block:6px solid transparent}
.ba__handle-grip::before{border-right:8px solid var(--on-brass);left:14px}
.ba__handle-grip::after{border-left:8px solid var(--on-brass);right:14px}

/* ============================================================
   STATS (brass band)
   ============================================================ */
.stats{background:var(--brass);color:var(--on-brass);position:relative;padding-block:clamp(3.5rem,7vw,6rem);overflow:hidden}
.stats::after{content:"";position:absolute;inset:0;pointer-events:none;opacity:.4;mix-blend-mode:multiply;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E")}
.stats__grid{position:relative;z-index:2;display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(1.5rem,3vw,3rem)}
.stat{display:flex;flex-direction:column;gap:.7rem;border-left:1px solid rgba(36,29,20,.2);padding-left:clamp(1rem,2vw,1.6rem)}
.stat:first-child{border-left:none;padding-left:0}
.stat__big{font-family:var(--display);font-weight:500;font-size:clamp(2.6rem,5.5vw,4.6rem);line-height:.9;color:var(--on-brass);letter-spacing:-.02em}
.stat__u{font-size:.42em;font-style:italic}
.stat__plus{font-size:.7em}
.stat__lbl{font-family:var(--label);font-weight:500;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(36,29,20,.72)}

/* ============================================================
   DETAIL (espresso)
   ============================================================ */
.detail{background:var(--espresso-deep);color:var(--cream);padding-block:clamp(5rem,10vw,8rem);display:flex;flex-direction:column;gap:clamp(2.5rem,5vw,4rem)}
.detail__head{text-align:center;display:flex;flex-direction:column;align-items:center}
.detail .eyebrow{color:var(--brass-light)}
.detail__title{font-size:var(--fs-dx-l);color:var(--cream);margin-top:1.2rem}
.detail__row{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1rem,2vw,1.8rem)}
.detail__cell{position:relative;border-radius:12px;overflow:hidden;border:1px solid rgba(212,184,150,.16)}
.detail__cell img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform 1.1s var(--ease)}
.detail__cell:hover img{transform:scale(1.06)}
.detail__line{text-align:center;max-width:50ch;margin-inline:auto;font-family:var(--display);font-style:italic;font-size:clamp(1.1rem,1.9vw,1.4rem);color:var(--cream-soft)}

/* ============================================================
   BRANDS (paper)
   ============================================================ */
.brands{background:var(--paper);color:var(--ink);padding-block:clamp(4rem,8vw,6rem) clamp(5rem,10vw,8rem);overflow:hidden}
.brands__marquee{border-block:1px solid var(--line-2);padding-block:1.4rem;margin-bottom:clamp(3rem,6vw,5rem)}
.brands__row{gap:1.8rem;font-family:var(--display);font-style:italic;font-size:clamp(1.6rem,3.4vw,2.8rem);color:var(--ink);animation:marquee 32s linear infinite}
.brands__row i{color:var(--brass);font-style:normal}
.brands__grid{display:grid;grid-template-columns:1fr 1.05fr;align-items:center;gap:clamp(2.5rem,5vw,5rem)}
.brands .eyebrow{color:var(--brass-deep)}
.brands__title{font-size:var(--fs-dx-l);color:var(--ink);margin-top:1.2rem;max-width:16ch}
.brands__body{margin-top:1.4rem;max-width:44ch;color:var(--ink-soft)}
.brands__media{border-radius:14px;overflow:hidden;border:1px solid var(--line-2);box-shadow:0 40px 80px -45px rgba(33,29,24,.4)}
.brands__media img{width:100%;height:auto;transition:transform 1.2s var(--ease)}
.brands__media:hover img{transform:scale(1.04)}

/* ============================================================
   WHITELABEL (espresso)
   ============================================================ */
.wl{background:var(--espresso);color:var(--cream);padding-block:clamp(5rem,10vw,8rem);overflow:hidden}
.wl__head{text-align:center;display:flex;flex-direction:column;align-items:center;margin-bottom:clamp(3rem,6vw,5rem)}
.wl .eyebrow{color:var(--brass-light)}
.wl__title{font-family:var(--display);font-size:var(--fs-dx-xl);color:var(--cream);margin-top:1.2rem;letter-spacing:-.02em}
.wl__sub{margin-top:1.4rem;max-width:50ch;color:var(--cream-soft);font-size:var(--fs-lede)}
.wl__marquee{padding-block:.4rem}
.wl__row{gap:1.6rem;font-family:var(--display);font-size:clamp(2.2rem,5vw,4.4rem);color:var(--cream);animation:marquee 40s linear infinite}
.wl__row i{color:var(--brass);font-style:normal}
.wl__marquee--rev .wl__row{font-style:italic;font-size:clamp(1.2rem,2.4vw,2rem);color:var(--cream-mid);animation:marquee-rev 46s linear infinite}

/* ============================================================
   PROVENANCE (paper, split)
   ============================================================ */
.prov{background:var(--paper);color:var(--ink);display:grid;grid-template-columns:1fr 1.05fr;align-items:stretch;overflow:hidden}
.prov__media{position:relative;min-height:560px;overflow:hidden}
.prov__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.4s var(--ease)}
.prov__media:hover img{transform:scale(1.05)}
.prov__body{display:flex;flex-direction:column;justify-content:center;padding:clamp(4rem,9vw,7rem) var(--gutter)}
.prov .eyebrow{color:var(--brass-deep)}
.prov__title{font-size:var(--fs-dx-xl);color:var(--ink);margin-top:1.2rem;max-width:14ch}
.prov__line{margin-top:1.5rem;max-width:46ch;color:var(--ink-soft);font-size:var(--fs-lede)}
.prov__sig{margin-top:2.2rem;font-family:var(--label);font-weight:600;font-size:.64rem;letter-spacing:.28em;text-transform:uppercase;color:var(--ink-mute);display:inline-flex;align-items:center;gap:1rem}
.prov__sig::after{content:"";width:60px;height:1px;background:var(--brass-line)}

/* ============================================================
   JOIN (espresso)
   ============================================================ */
.join{background:var(--espresso-bg);color:var(--cream);padding-block:clamp(5rem,11vw,9rem)}
.join__grid{display:grid;grid-template-columns:1.05fr .95fr;align-items:center;gap:clamp(2.5rem,5vw,5.5rem)}
.join .eyebrow{color:var(--brass-light)}
.join__title{font-family:var(--display);font-weight:400;font-size:var(--fs-dx-xl);color:var(--cream);margin-top:1.2rem;line-height:.96;letter-spacing:-.02em}
.join__sub{margin-top:1.5rem;max-width:40ch}
.join__panel{position:relative;background:rgba(0,0,0,.24);border:1px solid rgba(212,184,150,.22);border-radius:18px;padding:clamp(1.8rem,3vw,2.8rem)}
.wform{display:flex;flex-direction:column;gap:1.3rem}
.wform__honey{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
.wform__field{display:flex;flex-direction:column;gap:.5rem}
.wform__field label{font-family:var(--label);font-weight:600;font-size:.58rem;letter-spacing:.26em;text-transform:uppercase;color:var(--brass-light)}
.wform__field input{font-family:var(--body);font-weight:300;font-size:1.05rem;color:var(--cream);background:transparent;border:none;border-bottom:1px solid rgba(212,184,150,.28);padding:.6rem .1rem;transition:border-color .3s ease}
.wform__field input::placeholder{color:rgba(239,231,217,.3)}
.wform__field input:focus{outline:none;border-bottom-color:var(--brass)}
.wform__field input:user-invalid{border-bottom-color:#cf8d6b}
.wform__submit{margin-top:.6rem;align-self:flex-start;border:none;cursor:pointer}
.wform__note{font-family:var(--label);font-weight:400;font-size:.62rem;letter-spacing:.06em;color:var(--cream-faint)}
.wform.is-sending{opacity:.55;pointer-events:none}
.wform__error{color:#e0a583 !important}
.wform__done{display:flex;flex-direction:column;align-items:flex-start;gap:1rem;animation:done-in .7s var(--ease)}
.wform__done[hidden]{display:none}
.wform__done-mark{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;background:var(--brass);color:var(--on-brass);font-size:1.2rem}
.wform__done-title{font-family:var(--display);font-size:clamp(1.6rem,3vw,2.2rem);color:var(--cream)}
.wform__done-line{max-width:34ch;color:var(--cream-soft)}
@keyframes done-in{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

/* ============================================================
   FOOTER
   ============================================================ */
.foot{background:var(--espresso-deep);color:var(--cream);padding-block:clamp(3.5rem,7vw,5.5rem) clamp(1.8rem,3vw,2.4rem)}
.foot__top{display:grid;grid-template-columns:1.4fr 1fr;gap:clamp(2.5rem,5vw,5rem);padding-bottom:clamp(2.5rem,5vw,3.5rem);border-bottom:1px solid rgba(212,184,150,.14)}
.foot__brand{display:flex;flex-direction:column;align-items:flex-start;gap:1.25rem}
.foot__mark{font-size:clamp(2.6rem,5vw,3.8rem);color:var(--cream);line-height:1}
.foot__tagline{max-width:42ch;color:var(--cream-mid);font-size:.95rem;line-height:1.6}
.foot__big-cta{display:inline-flex;align-items:center;gap:.6rem;margin-top:.3rem;font-family:var(--label);font-weight:600;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--brass-light);border-bottom:1px solid var(--brass-line);padding-bottom:.45rem;transition:color .3s ease,border-color .3s ease}
.foot__big-cta span{transition:transform .4s var(--ease)}
.foot__big-cta:hover{color:var(--cream);border-color:var(--cream)}
.foot__big-cta:hover span{transform:translateX(5px)}
.foot__cols{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-content:start}
.foot__col{display:flex;flex-direction:column;gap:.8rem}
.foot__h{font-family:var(--label);font-weight:600;font-size:.6rem;letter-spacing:.26em;text-transform:uppercase;color:var(--brass);margin-bottom:.3rem}
.foot__col a,.foot__col span{font-size:.92rem;color:var(--cream-mid);transition:color .3s ease}
.foot__col a:hover{color:var(--brass-light)}
.foot__base{display:flex;justify-content:space-between;margin-top:clamp(1.6rem,3vw,2.2rem);font-family:var(--label);font-weight:400;font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--cream-faint)}

/* ============================================================
   Reveal
   ============================================================ */
.reveal{opacity:0;transform:translateY(40px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* image clip-reveal (uncovers as it enters the viewport) */
.r-img{position:relative;overflow:hidden;clip-path:inset(0 0 100% 0 round 14px);transition:clip-path 1.15s var(--ease);will-change:clip-path}
.r-img.in{clip-path:inset(0 0 0 0 round 14px)}
.r-img>img{transform:scale(1.14);transition:transform 1.4s var(--ease)}
.r-img.in>img{transform:scale(1)}
.detail__cell.r-img:nth-child(2){transition-delay:.12s}
.detail__cell.r-img:nth-child(3){transition-delay:.24s}
[data-parallax]{will-change:transform}
.reveal:nth-child(2){transition-delay:.08s}
.reveal:nth-child(3){transition-delay:.16s}
.reveal:nth-child(4){transition-delay:.24s}
.detail__cell.reveal:nth-child(1){transition-delay:0s}
.detail__cell.reveal:nth-child(2){transition-delay:.1s}
.detail__cell.reveal:nth-child(3){transition-delay:.2s}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:1000px){
  .hero__scrim{background:linear-gradient(180deg,rgba(22,18,16,.5) 0%,rgba(22,18,16,.16) 30%,rgba(22,18,16,.55) 64%,rgba(22,18,16,.95) 100%)}
  .hero__tag{display:none}
  .brands__grid,.join__grid,.foot__top{grid-template-columns:1fr}
}
@media (max-width:760px){
  /* rail → vertical stack */
  .rail__sticky{position:static;height:auto;display:block;overflow:visible}
  .rail__track{flex-direction:column;height:auto;transform:none !important}
  .panel{flex:0 0 auto;width:100%;height:auto;min-height:auto;grid-template-columns:1fr;gap:1.8rem;padding-block:clamp(3rem,9vw,4.5rem);border-top:1px solid rgba(212,184,150,.12)}
  .panel__media--portrait,.panel__media--sheet,.panel__media--detail{max-width:100%}
  .pack{width:min(64%,300px)}
  .rail__progress{display:none}
  .detail__row{grid-template-columns:1fr}
  .foot__cols{grid-template-columns:1fr 1fr}
}

/* ============================================================
   Reduced motion
   ============================================================ */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important}
  .reveal{opacity:1;transform:none}
  .loader{display:none}
  .cursor{display:none}
  .hero__swap-list{transform:translateY(0)}
  .rail__sticky{position:static;height:auto;overflow:visible}
  .rail__track{flex-direction:column;height:auto;transform:none !important}
  .panel{flex:0 0 auto;width:100%;height:auto;grid-template-columns:1fr 1fr}
}
@media (hover:none),(pointer:coarse){.cursor{display:none}}
