/* Mon Debut — Quiet Luxury */
:root{
  --cream:#f4efe7;
  --cream-2:#ebe5da;
  --paper:#faf6ef;
  --ink:#1a1612;
  --ink-2:#2a241e;
  --muted:#8a7e6f;
  --gold:#97785c;
  --gold-soft:#b89c7e;
  --line:rgba(26,22,18,.14);
  --line-soft:rgba(26,22,18,.08);
  --serif:'Cormorant', 'Cormorant Garamond', serif;
  --sans:'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
html,body{
  background:var(--cream);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:300;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
body.has-cursor{cursor:none}
@media (max-width:760px), (pointer:coarse){body.has-cursor{cursor:auto}}

img,video{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}

/* —————— Custom cursor —————— */
.cursor-dot,.cursor-ring{
  position:fixed;
  top:0;left:0;
  pointer-events:none;
  z-index:9999;
  mix-blend-mode:difference;
  transform:translate3d(-50%,-50%,0);
  will-change:transform;
}
.cursor-dot{
  width:6px;height:6px;
  background:#f4efe7;
  border-radius:50%;
  transition:transform .25s ease, opacity .2s ease;
}
.cursor-ring{
  width:38px;height:38px;
  border:1px solid #f4efe7;
  border-radius:50%;
  transition:width .35s cubic-bezier(.2,.7,.2,1), height .35s cubic-bezier(.2,.7,.2,1), opacity .25s ease, border-color .25s ease;
}
.cursor-ring.hover{width:64px;height:64px}
.cursor-ring.text{width:6px;height:6px;background:#f4efe7}
@media (max-width:760px), (pointer:coarse){
  .cursor-dot,.cursor-ring{display:none}
}

/* —————— Loader —————— */
.loader{
  position:fixed;inset:0;
  background:var(--cream);
  z-index:10000;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  gap:36px;
  transition:opacity .8s ease, visibility 0s linear .8s;
}
.loader.done{opacity:0;visibility:hidden;pointer-events:none}
.loader__mark{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(48px,7vw,96px);
  letter-spacing:.18em;
  color:var(--ink);
  text-transform:uppercase;
  display:flex;gap:.04em;
  overflow:hidden;
}
.loader__mark span{
  display:inline-block;
  transform:translateY(110%);
  animation:rise .9s cubic-bezier(.2,.8,.2,1) forwards;
}
@keyframes rise{to{transform:translateY(0)}}
.loader__bar{
  width:min(46vw,440px);
  height:1px;
  background:var(--line);
  position:relative;overflow:hidden;
}
.loader__bar::after{
  content:'';position:absolute;inset:0;
  background:var(--ink);
  transform:scaleX(0);transform-origin:left;
  animation:fill 1.6s cubic-bezier(.65,.05,.36,1) forwards;
}
@keyframes fill{to{transform:scaleX(1)}}
.loader__pct{
  font-family:var(--sans);
  font-size:11px;letter-spacing:.3em;
  color:var(--muted);
  font-variant-numeric:tabular-nums;
}

/* —————— Nav —————— */
.nav{
  position:fixed;top:0;left:0;right:0;
  z-index:90;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px clamp(20px,4vw,56px);
  transition:transform .55s cubic-bezier(.2,.8,.2,1), background .35s ease, color .35s ease, border-color .35s ease;
  border-bottom:1px solid transparent;
  color:#fff;
}
.nav.solid{
  background:rgba(244,239,231,.88);
  backdrop-filter:blur(14px) saturate(120%);
  -webkit-backdrop-filter:blur(14px) saturate(120%);
  color:var(--ink);
  border-color:var(--line-soft);
}
.nav.hidden{transform:translateY(-110%)}
.nav__brand{
  font-family:var(--serif);
  font-weight:300;
  font-size:18px;
  letter-spacing:.32em;
  text-transform:uppercase;
}
.nav__list{
  display:flex;gap:clamp(20px,3.5vw,52px);
  list-style:none;
}
.nav__link{
  font-family:var(--sans);
  font-weight:300;
  font-size:11px;
  letter-spacing:.28em;
  text-transform:uppercase;
  position:relative;
  padding:8px 2px;
}
.nav__link::after{
  content:'';position:absolute;left:0;right:0;bottom:0;
  height:1px;background:currentColor;
  transform:scaleX(0);transform-origin:right;
  transition:transform .5s cubic-bezier(.6,.05,.2,.95);
}
.nav__link:hover::after{transform:scaleX(1);transform-origin:left}
.nav__cta{
  font-family:var(--sans);
  font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  border:1px solid currentColor;
  padding:10px 18px;border-radius:99px;
  transition:background .3s ease, color .3s ease;
}
.nav__cta:hover{background:currentColor}
.nav__cta:hover span{color:var(--cream)}
.nav.solid .nav__cta:hover span{color:var(--cream)}

.nav__menu{display:none}
@media (max-width:880px){
  .nav__list,.nav__cta{display:none}
  .nav__menu{display:flex;flex-direction:column;gap:5px;width:28px;cursor:none}
  .nav__menu i{display:block;height:1px;background:currentColor;transition:transform .3s ease, opacity .3s ease}
  .nav.menu-open .nav__menu i:nth-child(1){transform:translateY(6px) rotate(45deg)}
  .nav.menu-open .nav__menu i:nth-child(2){opacity:0}
  .nav.menu-open .nav__menu i:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
}

.mobile-menu{
  position:fixed;inset:0;
  background:var(--cream);
  z-index:80;
  display:flex;align-items:center;justify-content:center;
  flex-direction:column;gap:24px;
  opacity:0;visibility:hidden;
  transition:opacity .5s ease, visibility 0s linear .5s;
}
.mobile-menu.open{opacity:1;visibility:visible;transition-delay:0s}
.mobile-menu a{
  font-family:var(--serif);
  font-size:38px;font-weight:300;
  color:var(--ink);
}

/* —————— Hero —————— */
.hero{
  position:relative;
  height:100vh;min-height:620px;
  width:100%;
  overflow:hidden;
  background:#0a0908;
}
.hero__video{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  filter:saturate(.85) contrast(1.02) brightness(.95);
  transform:scale(1.06);
  transition:transform 1.4s cubic-bezier(.2,.8,.2,1), opacity .9s ease;
  opacity:0;
}
.hero__video.ready{opacity:1;transform:scale(1)}
.hero__veil{
  position:absolute;inset:0;
  background:
    radial-gradient(120% 80% at 50% 50%, rgba(0,0,0,0) 30%, rgba(0,0,0,.45) 100%),
    linear-gradient(180deg, rgba(0,0,0,.25) 0%, rgba(0,0,0,0) 35%, rgba(0,0,0,.55) 100%);
}
.hero__inner{
  position:absolute;inset:0;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  text-align:center;color:#f4efe7;
  padding:0 24px;
}
.hero__eyebrow{
  font-family:var(--sans);
  font-weight:300;
  font-size:11px;letter-spacing:.5em;text-transform:uppercase;
  opacity:0;transform:translateY(20px);
  animation:hero-up 1s .9s cubic-bezier(.2,.8,.2,1) forwards;
}
.hero__mark{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(72px,17vw,260px);
  letter-spacing:.04em;
  line-height:.92;
  margin:24px 0 18px;
  display:flex;justify-content:center;gap:.02em;
  overflow:hidden;
}
.hero__mark .word{display:flex;overflow:hidden}
.hero__mark span{
  display:inline-block;
  transform:translateY(110%);
  animation:rise 1.2s cubic-bezier(.2,.85,.2,1) forwards;
}
.hero__sub{
  font-family:var(--serif);
  font-style:italic;
  font-weight:300;
  font-size:clamp(16px,2vw,22px);
  letter-spacing:.04em;
  opacity:0;transform:translateY(20px);
  animation:hero-up 1.2s 1.2s cubic-bezier(.2,.8,.2,1) forwards;
}
@keyframes hero-up{to{opacity:.85;transform:translateY(0)}}

.hero__meta{
  position:absolute;bottom:32px;left:0;right:0;
  display:flex;justify-content:space-between;align-items:flex-end;
  padding:0 clamp(20px,4vw,56px);
  color:rgba(244,239,231,.72);
  font-size:10px;letter-spacing:.32em;text-transform:uppercase;
  opacity:0;animation:hero-up 1s 1.6s cubic-bezier(.2,.8,.2,1) forwards;
}
.hero__scroll{
  display:flex;flex-direction:column;align-items:center;gap:10px;
}
.hero__scroll-line{
  width:1px;height:48px;background:rgba(244,239,231,.5);
  position:relative;overflow:hidden;
}
.hero__scroll-line::after{
  content:'';position:absolute;top:0;left:0;right:0;height:50%;
  background:#f4efe7;
  animation:scroll-line 2.4s ease-in-out infinite;
}
@keyframes scroll-line{
  0%{transform:translateY(-100%)}
  60%,100%{transform:translateY(200%)}
}

/* —————— Section atoms —————— */
.section{padding:clamp(80px,11vw,180px) clamp(20px,4vw,56px);position:relative}
.container{max-width:1280px;margin:0 auto}
.eyebrow{
  font-family:var(--sans);
  font-weight:400;
  font-size:11px;letter-spacing:.4em;text-transform:uppercase;
  color:var(--gold);
  display:inline-flex;align-items:center;gap:14px;
}
.eyebrow::before{
  content:'';width:32px;height:1px;background:currentColor;display:inline-block;
}
.eyebrow.center::before{display:none}
.eyebrow--num{
  font-family:var(--sans);
  font-weight:400;
  font-size:10px;letter-spacing:.4em;color:var(--muted);
  font-variant-numeric:tabular-nums;
}
.h-display{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(40px,6.4vw,108px);
  line-height:.96;
  letter-spacing:-.005em;
  color:var(--ink);
  text-wrap:balance;
}
.h-display em{font-style:italic;color:var(--gold)}
.h-display .it{font-style:italic;color:var(--gold)}
.body-lg{
  font-size:16px;line-height:1.75;
  color:var(--ink-2);max-width:54ch;
  font-weight:300;
  text-wrap:pretty;
}
.body{
  font-size:14px;line-height:1.7;
  color:var(--ink-2);
  font-weight:300;
}

.rule{height:1px;background:var(--line);width:100%;transform-origin:left;transform:scaleX(0);transition:transform 1.2s cubic-bezier(.2,.8,.2,1)}
.in-view .rule, .rule.in-view{transform:scaleX(1)}

/* link with arrow */
.cta{
  display:inline-flex;align-items:center;gap:18px;
  font-family:var(--sans);
  font-size:11px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--ink);
  padding:14px 0;position:relative;
}
.cta::before{
  content:'';position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--ink);
  transform-origin:right;transform:scaleX(1);
  transition:transform .55s cubic-bezier(.6,0,.3,1);
}
.cta:hover::before{transform-origin:left;transform:scaleX(0)}
.cta__arrow{
  position:relative;display:inline-flex;align-items:center;justify-content:center;
  width:14px;height:1px;background:currentColor;
  transition:width .4s ease;
}
.cta__arrow::after{
  content:'';position:absolute;right:0;top:50%;
  width:7px;height:7px;border-top:1px solid currentColor;border-right:1px solid currentColor;
  transform:translate(0,-50%) rotate(45deg);
}
.cta:hover .cta__arrow{width:28px}

/* —————— Reveal —————— */
.reveal-line{display:block;overflow:hidden}
.reveal-line > *{display:inline-block;transform:translateY(110%);transition:transform 1.1s cubic-bezier(.2,.85,.2,1)}
.in-view .reveal-line > *{transform:translateY(0)}

.reveal-word{display:inline-flex;flex-wrap:wrap;gap:0 .25em}
.reveal-word .w{display:inline-block;overflow:hidden;line-height:1.05}
.reveal-word .w span{display:inline-block;transform:translateY(110%);transition:transform .9s cubic-bezier(.2,.85,.2,1)}
.in-view .reveal-word .w:nth-child(1) span{transition-delay:.05s}
.in-view .reveal-word .w:nth-child(2) span{transition-delay:.12s}
.in-view .reveal-word .w:nth-child(3) span{transition-delay:.19s}
.in-view .reveal-word .w:nth-child(4) span{transition-delay:.26s}
.in-view .reveal-word .w:nth-child(5) span{transition-delay:.33s}
.in-view .reveal-word .w:nth-child(6) span{transition-delay:.4s}
.in-view .reveal-word .w:nth-child(7) span{transition-delay:.47s}
.in-view .reveal-word .w:nth-child(8) span{transition-delay:.54s}
.in-view .reveal-word .w span{transform:translateY(0)}

.fade-up{opacity:0;transform:translateY(30px);transition:opacity 1s ease .1s, transform 1s cubic-bezier(.2,.8,.2,1) .1s}
.in-view .fade-up, .fade-up.in-view{opacity:1;transform:translateY(0)}
.fade-up.d1{transition-delay:.15s}
.fade-up.d2{transition-delay:.3s}
.fade-up.d3{transition-delay:.45s}

/* —————— About —————— */
.about{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:clamp(40px,7vw,140px);
  align-items:flex-end;
}
@media (max-width:880px){.about{grid-template-columns:1fr}}
.about__media{
  position:relative;
  aspect-ratio:4/5;
  overflow:hidden;
  background:#222;
}
.about__media img{
  width:100%;height:120%;
  object-fit:cover;
  position:absolute;top:-10%;left:0;
  filter:sepia(.18) saturate(.92) brightness(.96);
  will-change:transform;
}
.about__index{
  position:absolute;top:18px;left:18px;
  color:#f4efe7;font-size:10px;letter-spacing:.4em;text-transform:uppercase;
  font-variant-numeric:tabular-nums;
}
.about__txt{display:flex;flex-direction:column;gap:36px;padding-bottom:24px}
.about__chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.about__chip{
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  border:1px solid var(--line);
  padding:8px 14px;border-radius:99px;color:var(--ink-2);
  transition:background .3s ease, color .3s ease, border-color .3s ease;
}
.about__chip:hover{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.about__pair{
  margin-top:64px;
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:clamp(24px,4vw,72px);
}
@media (max-width:680px){.about__pair{grid-template-columns:1fr 1fr}}
.about__cell h4{
  font-family:var(--serif);font-weight:300;
  font-size:48px;line-height:1;color:var(--ink);
  font-variant-numeric:tabular-nums;
}
.about__cell h4 sup{font-size:.4em;vertical-align:top;color:var(--gold);margin-left:4px}
.about__cell p{
  margin-top:10px;font-size:11px;letter-spacing:.24em;
  text-transform:uppercase;color:var(--muted);
}

/* —————— Marquee logos —————— */
.maison{
  padding:clamp(60px,8vw,120px) 0;
  border-top:1px solid var(--line-soft);
  border-bottom:1px solid var(--line-soft);
  background:var(--paper);
}
.maison__head{
  display:flex;justify-content:space-between;align-items:center;
  padding:0 clamp(20px,4vw,56px);margin-bottom:48px;
}
.maison__title{
  font-family:var(--serif);font-weight:300;font-style:italic;
  font-size:clamp(22px,3vw,40px);
  letter-spacing:.01em;color:var(--ink);
}
.marquee{
  position:relative;width:100%;overflow:hidden;
  mask-image:linear-gradient(90deg,transparent 0,#000 8%,#000 92%,transparent 100%);
  -webkit-mask-image:linear-gradient(90deg,transparent 0,#000 8%,#000 92%,transparent 100%);
}
.marquee__track{
  display:flex;align-items:center;gap:clamp(48px,7vw,120px);
  animation:marquee 50s linear infinite;
  width:max-content;
}
.marquee:hover .marquee__track{animation-play-state:paused}
@keyframes marquee{to{transform:translateX(-50%)}}
.marquee__item{
  flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  height:clamp(32px,4vw,56px);
  filter:grayscale(1) contrast(.9) brightness(.4);
  opacity:.7;
  transition:filter .4s ease, opacity .4s ease, transform .4s ease;
}
.marquee__item:hover{filter:grayscale(0) contrast(1);opacity:1;transform:scale(1.06)}
.marquee__item img{height:100%;width:auto;max-width:none}
.marquee__name{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:clamp(18px,2.4vw,32px);
  color:var(--ink-2);letter-spacing:.02em;
  white-space:nowrap;
}

/* —————— Atelier (grid of products) —————— */
.atelier{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:24px;
  align-items:end;
}
@media (max-width:880px){.atelier{grid-template-columns:repeat(6,1fr);gap:16px}}
.atelier__head{grid-column:1/13;display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:24px;margin-bottom:24px}
@media (max-width:880px){.atelier__head{grid-column:1/7}}
.card{
  position:relative;overflow:hidden;
  background:#211d18;
  cursor:none;
}
.card__media{position:relative;width:100%;aspect-ratio:3/4;overflow:hidden}
.card__img{
  width:100%;height:100%;object-fit:cover;
  filter:sepia(.12) saturate(.9);
  transition:transform 1.4s cubic-bezier(.2,.8,.2,1), filter .6s ease;
  will-change:transform;
}
.card:hover .card__img{transform:scale(1.06);filter:sepia(0) saturate(1)}
.card__veil{
  position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,0) 50%, rgba(20,16,12,.55) 100%);
  opacity:1;transition:opacity .5s ease;
}
.card__meta{
  position:absolute;left:18px;right:18px;bottom:18px;
  display:flex;justify-content:space-between;align-items:flex-end;
  color:#f4efe7;
}
.card__meta h4{
  font-family:var(--serif);font-weight:300;font-size:22px;letter-spacing:.02em;
}
.card__meta small{font-size:10px;letter-spacing:.3em;text-transform:uppercase;opacity:.75}
.card__num{
  position:absolute;top:14px;left:14px;
  color:#f4efe7;font-size:10px;letter-spacing:.3em;text-transform:uppercase;
  opacity:.75;
}

.a-1{grid-column:1/5}
.a-2{grid-column:5/9;transform:translateY(60px)}
.a-3{grid-column:9/13}
.a-4{grid-column:1/7;transform:translateY(40px)}
.a-5{grid-column:7/13}
@media (max-width:880px){
  .a-1{grid-column:1/4}
  .a-2{grid-column:4/7;transform:none}
  .a-3{grid-column:1/4}
  .a-4{grid-column:4/7;transform:none}
  .a-5{grid-column:1/7}
}

/* —————— Accessoires (sticky horizontal feel) —————— */
.access{
  display:grid;grid-template-columns:1fr 1fr;
  gap:0;align-items:stretch;
  background:var(--cream);
}
@media (max-width:880px){.access{grid-template-columns:1fr}}
.access__media{
  position:relative;aspect-ratio:4/5;overflow:hidden;
  background:#1a1612;
}
.access__media img{
  width:100%;height:115%;object-fit:cover;position:absolute;top:-7%;left:0;
  filter:sepia(.15) saturate(.92);
  will-change:transform;
}
.access__txt{
  display:flex;flex-direction:column;justify-content:center;
  padding:clamp(48px,7vw,120px);
  gap:36px;
  background:var(--paper);
}
.access__list{display:flex;flex-direction:column;gap:0}
.access__row{
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 0;
  border-top:1px solid var(--line);
  font-size:14px;
  transition:padding-left .5s cubic-bezier(.2,.8,.2,1), color .35s ease;
}
.access__row:last-child{border-bottom:1px solid var(--line)}
.access__row:hover{padding-left:18px;color:var(--gold)}
.access__row span:first-child{
  font-family:var(--serif);font-size:22px;font-weight:300;letter-spacing:.02em;
}
.access__row .num{
  font-size:10px;letter-spacing:.3em;color:var(--muted);font-variant-numeric:tabular-nums;
}

/* —————— Coffee —————— */
.coffee{
  position:relative;height:80vh;min-height:520px;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  background:#0d0a08;
  text-align:center;color:#f4efe7;
}
.coffee__bg{
  position:absolute;inset:0;
  background-image:url('assets/coffeebg.jpg');
  background-size:cover;background-position:center;
  filter:sepia(.4) brightness(.55) contrast(1.05);
  transform:scale(1.08);
  will-change:transform;
}
.coffee__veil{position:absolute;inset:0;background:linear-gradient(180deg, rgba(10,8,6,.4), rgba(10,8,6,.55))}
.coffee__inner{position:relative;z-index:2;max-width:920px;padding:0 24px}
.coffee h2{
  font-family:var(--serif);font-weight:300;font-style:italic;
  font-size:clamp(36px,6vw,84px);line-height:1.05;letter-spacing:.005em;
  text-wrap:balance;
}
.coffee small{
  display:inline-block;margin-bottom:30px;
  font-size:11px;letter-spacing:.4em;text-transform:uppercase;color:rgba(244,239,231,.7);
}

/* —————— News (journal) —————— */
.journal{display:flex;flex-direction:column;gap:0}
.journal__row{
  display:grid;grid-template-columns:90px 1fr 320px 90px;
  gap:32px;align-items:center;
  padding:34px 0;
  border-top:1px solid var(--line);
  cursor:none;
  transition:padding .5s cubic-bezier(.2,.8,.2,1);
}
.journal__row:last-child{border-bottom:1px solid var(--line)}
.journal__row:hover{padding-left:24px;padding-right:24px}
@media (max-width:880px){
  .journal__row{grid-template-columns:1fr;gap:14px;padding:28px 0}
  .journal__row:hover{padding-left:0;padding-right:0}
}
.journal__date{
  font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);
}
.journal__title{
  font-family:var(--serif);font-weight:300;font-size:clamp(22px,2.6vw,34px);
  line-height:1.15;color:var(--ink);
}
.journal__excerpt{font-size:13px;color:var(--ink-2);line-height:1.65;font-weight:300}
.journal__media{
  width:100%;aspect-ratio:4/3;overflow:hidden;position:relative;background:#222;
}
.journal__media img{
  width:100%;height:100%;object-fit:cover;
  filter:sepia(.1);
  transition:transform 1s cubic-bezier(.2,.8,.2,1);
}
.journal__row:hover .journal__media img{transform:scale(1.05)}
.journal__arrow{
  display:flex;justify-content:flex-end;align-items:center;
  font-size:18px;
}

/* —————— Footer —————— */
.foot{
  background:var(--ink);
  color:var(--cream);
  padding:clamp(80px,9vw,140px) clamp(20px,4vw,56px) 32px;
}
.foot__grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:60px;
  margin-bottom:80px;
}
@media (max-width:880px){.foot__grid{grid-template-columns:1fr 1fr;gap:40px}.foot__brand{grid-column:1/3}}
.foot__brand h3{
  font-family:var(--serif);font-weight:300;font-size:48px;letter-spacing:.04em;
  margin-bottom:16px;
}
.foot__brand p{font-size:13px;line-height:1.7;color:rgba(244,239,231,.65);max-width:38ch}
.foot__col h5{
  font-size:10px;letter-spacing:.4em;text-transform:uppercase;
  color:var(--gold-soft);margin-bottom:24px;font-weight:400;
}
.foot__col ul{list-style:none;display:flex;flex-direction:column;gap:14px}
.foot__col a, .foot__col li{font-size:13px;color:rgba(244,239,231,.85);line-height:1.5}
.foot__col a:hover{color:var(--gold-soft)}
.foot__bottom{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:24px;border-top:1px solid rgba(244,239,231,.12);
  font-size:11px;letter-spacing:.2em;color:rgba(244,239,231,.5);text-transform:uppercase;
}
.foot__wordmark{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(80px,18vw,260px);
  line-height:.9;letter-spacing:.02em;
  color:rgba(244,239,231,.06);
  text-align:center;
  padding:40px 0 0;
  pointer-events:none;
  user-select:none;
  white-space:nowrap;
  overflow:hidden;
}
@media (max-width:880px){
  .foot__bottom{flex-direction:column;gap:14px;text-align:center}
}

/* —————— Floating CTA —————— */
.float-cta{
  position:fixed;right:20px;bottom:20px;z-index:60;
  display:flex;flex-direction:column;gap:10px;
  transition:opacity .5s ease, transform .5s ease;
}
.float-cta.hide{opacity:0;transform:translateX(20px);pointer-events:none}
.float-btn{
  width:52px;height:52px;border-radius:99px;
  display:flex;align-items:center;justify-content:center;
  background:var(--ink);color:var(--cream);
  transition:background .3s ease, transform .3s ease;
}
.float-btn:hover{background:var(--gold);transform:scale(1.06)}
.float-btn--ghost{background:transparent;color:var(--ink);border:1px solid var(--ink)}
.float-btn--ghost:hover{background:var(--ink);color:var(--cream)}
.float-btn svg{width:18px;height:18px}

/* utility */
.italic{font-style:italic}
.tab-num{font-variant-numeric:tabular-nums}

/* prefers-reduced-motion */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}
}
