/* ============ Base ============ */
:root{
  --bg:#0a0a0b;
  --bg-soft:#121214;
  --card:#12100a;          /* warm sheet tone for stacked cards */
  --card-soft:#1a1712;     /* inputs / surfaces sitting on the card */
  --fg:#f4f1ea;
  --muted:#9a958c;
  --accent:#e8c88f;        /* warm golden LA light */
  --line:rgba(244,241,234,.12);
  --maxw:1180px;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--fg);
  font-family:"Inter",system-ui,sans-serif;
  font-weight:300;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,video{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
body.is-loading{overflow:hidden}

/* Lenis smooth scroll */
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-stopped{overflow:hidden}

/* ============ Preloader ============ */
.preloader{
  position:fixed;inset:0;z-index:300;background:var(--bg);
  transition:transform 1s var(--ease) .2s;will-change:transform;
}
.preloader__brand{
  position:absolute;top:18px;left:clamp(18px,4vw,40px);
  font-family:"Cormorant Garamond",serif;font-size:20px;letter-spacing:.06em;
}
.preloader__count{
  position:absolute;right:clamp(18px,4vw,40px);bottom:14px;
  font-family:"Cormorant Garamond",serif;font-weight:500;
  font-size:clamp(70px,14vw,150px);line-height:1;color:var(--fg);
  font-variant-numeric:tabular-nums;
}
body.is-loaded .preloader{transform:translateY(-101%)}

/* ============ Film grain ============ */
.grain{
  position:fixed;inset:0;z-index:120;pointer-events:none;
  overflow:hidden;contain:strict;
}
.grain::before{
  content:"";position:absolute;inset:-100%;opacity:.055;
  will-change:transform;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%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)'/%3E%3C/svg%3E");
  animation:grain 7s steps(8) infinite;
}
@keyframes grain{
  0%,100%{transform:translate(0,0)}
  12%{transform:translate(-6%,3%)}
  25%{transform:translate(4%,-7%)}
  37%{transform:translate(-3%,6%)}
  50%{transform:translate(7%,2%)}
  62%{transform:translate(-5%,-4%)}
  75%{transform:translate(2%,7%)}
  87%{transform:translate(5%,-3%)}
}

/* ============ Custom cursor ============ */
.cursor{position:fixed;left:0;top:0;z-index:500;pointer-events:none;display:none}
body.has-cursor .cursor{display:block}
body.has-cursor,
body.has-cursor a,
body.has-cursor button,
body.has-cursor label,
body.has-cursor .reel{cursor:none}
.cursor__dot{
  display:grid;place-items:center;
  width:10px;height:10px;border-radius:50%;background:var(--accent);
  transform:translate(-50%,-50%);
  transition:width .35s var(--ease),height .35s var(--ease),background .35s,border-color .35s,opacity .3s;
}
.cursor__label{font-size:0;color:#0a0a0b;line-height:1;padding-left:.12em;transition:font-size .25s var(--ease)}
.cursor[data-state="link"] .cursor__dot{
  width:42px;height:42px;background:rgba(232,200,143,.14);
  border:1px solid rgba(232,200,143,.55);
}
.cursor[data-state="play"] .cursor__dot{width:74px;height:74px;background:var(--accent)}
.cursor[data-state="play"] .cursor__label{font-size:17px}
.cursor.is-hidden .cursor__dot{opacity:0}

/* Magnetic elements */
.magnetic{transition:transform .3s var(--ease);will-change:transform}

/* ============ Top bar ============ */
.topbar{
  position:fixed;inset:0 0 auto 0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px clamp(18px,4vw,40px);
  mix-blend-mode:difference;       /* stays legible over any video */
  opacity:0;transition:opacity 1.2s var(--ease) .9s;
}
body.is-loaded .topbar{opacity:1}
.topbar__brand{
  font-family:"Cormorant Garamond",serif;
  font-size:20px;letter-spacing:.06em;color:#fff;
}
.topbar__nav{display:flex;gap:clamp(14px,3vw,30px);font-size:13px;letter-spacing:.08em;text-transform:uppercase}
.topbar__nav a{color:#fff;opacity:.85;transition:opacity .3s}
.topbar__nav a:hover{opacity:1}
@media(max-width:560px){.topbar__nav{display:none}}

/* ============ Split-text reveal ============ */
.sw{
  display:inline-block;overflow:hidden;vertical-align:top;
  padding:.06em .02em .12em;margin:-.06em -.02em -.12em;
}
.sw__i{
  display:inline-block;transform:translateY(118%);
  transition:transform .9s var(--ease);will-change:transform;
}
.reveal.is-visible .sw__i{transform:translateY(0)}

/* ============ HERO (scroll-pinned) ============ */
.hero{
  position:relative;z-index:2;
  background:var(--bg);
  height:300vh;                    /* 200vh scrub (11s clip) + 100vh hold while the sheet covers it */
}
.hero__sticky{
  position:sticky;top:0;
  height:100vh;height:100svh;
  overflow:hidden;
}
.hero__scenes{position:absolute;inset:0}
.scene{
  position:absolute;inset:0;
  opacity:0;transition:opacity .6s var(--ease);
  will-change:opacity;
}
.scene.is-active{opacity:1}
.scene__video{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
}
.hero__overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(10,10,11,.45) 0%,rgba(10,10,11,0) 22%,rgba(10,10,11,0) 55%,rgba(10,10,11,.85) 100%);
  pointer-events:none;
}

/* Hero UI */
.hero__ui{position:absolute;inset:0;z-index:5;pointer-events:none}
.hero__counter{
  position:absolute;top:clamp(70px,12vh,110px);right:clamp(18px,4vw,40px);
  font-size:12px;letter-spacing:.18em;color:var(--accent);
}
.hero__counter-cur{color:#fff}
.hero__center{
  position:absolute;left:clamp(18px,4vw,40px);right:clamp(18px,4vw,40px);
  bottom:clamp(90px,18vh,150px);
  max-width:760px;
}
.hero__title{
  font-family:"Cormorant Garamond",serif;
  font-weight:500;
  font-size:clamp(38px,8vw,78px);
  line-height:1.02;
  letter-spacing:-.01em;
  text-shadow:0 2px 30px rgba(0,0,0,.4);
  transition:opacity .45s var(--ease),transform .45s var(--ease);
}
.hero__title .sw__i{transition:transform .85s var(--ease)}
body.is-loaded .hero__title.is-in .sw__i{transform:translateY(0)}
.hero__title.is-swapping{opacity:0;transform:translateY(14px)}
.hero__sub{margin-top:16px;color:var(--muted);font-size:clamp(13px,1.6vw,16px);letter-spacing:.04em}

.hero__sub,.hero__counter,.hero__hint,.hero__dots{opacity:0;transition:opacity 1.2s var(--ease) 1.1s}
body.is-loaded .hero__sub,
body.is-loaded .hero__counter,
body.is-loaded .hero__hint,
body.is-loaded .hero__dots{opacity:1}

.hero__hint{
  position:absolute;left:50%;bottom:30px;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:6px;
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);
}
.hero__hint-arrow{animation:bob 1.8s var(--ease) infinite}
@keyframes bob{0%,100%{transform:translateY(0);opacity:.5}50%{transform:translateY(6px);opacity:1}}

.hero__dots{position:absolute;right:clamp(18px,4vw,40px);bottom:clamp(90px,18vh,150px);display:flex;flex-direction:column;gap:10px}
.dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.3);transition:all .4s}
.dot.is-active{background:var(--accent);transform:scale(1.5)}

/* ============ Stacked sheet (covers the hero's last frame) ============ */
.sheet{
  position:relative;z-index:10;
  margin-top:-100vh;
  background-color:var(--card);
  background-image:linear-gradient(180deg,rgba(232,200,143,.05),rgba(232,200,143,0) min(28vh,360px));
  border-radius:clamp(20px,3.5vw,36px) clamp(20px,3.5vw,36px) 0 0;
  box-shadow:
    inset 0 1px 0 rgba(232,200,143,.3),
    0 -10px 28px -6px rgba(232,200,143,.12),
    0 -30px 70px rgba(0,0,0,.55);
}

/* ============ Marquee ============ */
.marquee{
  overflow:hidden;contain:paint;
  padding:clamp(26px,4.5vh,44px) 0;
  border-bottom:1px solid var(--line);
}
.marquee__track{display:flex;width:max-content;will-change:transform}
.marquee__chunk{
  display:block;white-space:nowrap;
  font-family:"Cormorant Garamond",serif;font-weight:500;
  font-size:clamp(30px,5vw,58px);line-height:1;color:var(--fg);
}
.marquee__chunk i{font-style:normal;color:var(--accent);padding:0 .3em}

/* ============ Generic section ============ */
.section{
  position:relative;
  max-width:var(--maxw);
  margin:0 auto;
  padding:clamp(80px,14vh,160px) clamp(18px,4vw,40px);
}
.section__eyebrow{
  font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);
  margin-bottom:18px;
}
.section__title{
  font-family:"Cormorant Garamond",serif;font-weight:500;
  font-size:clamp(30px,5vw,52px);line-height:1.08;letter-spacing:-.01em;
  max-width:18ch;
}

/* Reveal on scroll */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.is-visible{opacity:1;transform:none}

/* ============ Stacked covers (full-bleed sheets riding over pinned blocks) ============ */
.cover{
  position:relative;z-index:3;
  margin-top:-100vh;
  background-color:var(--card);
  background-image:linear-gradient(180deg,rgba(232,200,143,.05),rgba(232,200,143,0) min(28vh,360px));
  border-radius:clamp(20px,3.5vw,36px) clamp(20px,3.5vw,36px) 0 0;
  box-shadow:
    inset 0 1px 0 rgba(232,200,143,.3),
    0 -10px 28px -6px rgba(232,200,143,.12),
    0 -30px 70px rgba(0,0,0,.55);
}
/* Work/reels cover gets a viewing zone at the bottom so the manifesto
   slides over empty space, not over the reels strip. */
.cover:not(.cover--glow){padding-bottom:100vh}
.cover--glow{
  z-index:5;            /* rides over the manifesto card (z4) */
  background-image:
    linear-gradient(180deg,rgba(232,200,143,.05),rgba(232,200,143,0) min(28vh,360px)),
    radial-gradient(700px circle at 50% -10%,rgba(232,200,143,.07),transparent 65%);
}

/* ============ Stats (pinned scene with gold-dust canvas) ============ */
.stats{position:relative;height:250vh}  /* ~50vh pinned hold, then the work sheet covers it */
.stats__sticky{
  position:sticky;top:0;
  height:100vh;height:100svh;
  display:flex;align-items:center;
  background:radial-gradient(640px circle at 90% 8%,rgba(232,200,143,.08),transparent 70%);
}
.stats__canvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}
.stats__inner{
  position:relative;width:100%;
  max-width:var(--maxw);margin:0 auto;
  padding:0 clamp(18px,4vw,40px);
  perspective:1200px;                /* 3D depth for the floating plaques */
}
.stats__lead{
  margin-top:24px;max-width:30ch;
  font-family:"Cormorant Garamond",serif;font-weight:500;
  font-size:clamp(21px,2.5vw,31px);line-height:1.34;letter-spacing:.004em;
  color:#d9d4ca;
}
.stats__lead .hl{                      /* gold key phrases with a visible shine sweep */
  font-weight:500;color:#e8c88f;
  background:linear-gradient(100deg,#a9802f 0%,#a9802f 32%,#fff0c4 50%,#a9802f 68%,#a9802f 100%);
  background-size:260% 100%;
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
  animation:leadshine 4.5s linear infinite;
}
@keyframes leadshine{0%{background-position:140% 0}100%{background-position:-40% 0}}
@media(prefers-reduced-motion:reduce){
  .stats__lead .hl{-webkit-text-fill-color:#e8c88f;animation:none}
}
.stats__grid{
  margin-top:46px;display:grid;gap:clamp(14px,1.6vw,22px);
  grid-template-columns:repeat(4,1fr);
  transform-style:preserve-3d;
  transition:transform .35s var(--ease);   /* cursor-parallax tilt easing */
}
.stat{
  position:relative;
  display:flex;flex-direction:column;gap:8px;
  padding:30px 22px 26px;
  border-radius:14px;
  border:1px solid rgba(232,200,143,.16);
  background:linear-gradient(165deg,rgba(232,200,143,.07),rgba(20,17,11,.55) 55%);
  box-shadow:0 20px 44px rgba(0,0,0,.5),inset 0 1px 0 rgba(232,200,143,.28);
  transform-style:preserve-3d;will-change:transform;
  animation:statfloat 8s var(--ease) infinite;
}
.stat::before{                        /* faint gold top bevel for volume */
  content:"";position:absolute;inset:0;border-radius:14px;pointer-events:none;
  background:linear-gradient(180deg,rgba(232,200,143,.10),transparent 30%);
}
.stat:nth-child(2){animation-delay:-2s}
.stat:nth-child(3){animation-delay:-4s}
.stat:nth-child(4){animation-delay:-6s}
@keyframes statfloat{
  0%,100%{transform:translateY(0) translateZ(0) rotateX(3.5deg) rotateY(-7deg)}
  50%{transform:translateY(-12px) translateZ(28px) rotateX(-3deg) rotateY(7deg)}
}
.stat__num{font-family:"Cormorant Garamond",serif;font-size:clamp(34px,4vw,52px);color:#fff;font-variant-numeric:tabular-nums}
.stat__label{font-size:13px;color:rgba(244,241,234,.82);letter-spacing:.03em}
@media(max-width:760px){
  .stats__grid{grid-template-columns:repeat(2,1fr)}
  .stat{animation-duration:9s}
}

/* ============ Work carousel ============ */
.work.reveal{opacity:1;transform:none}  /* the slide-over IS the entrance; words still animate via .is-visible */
.work__head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px}
.carousel__nav{display:flex;gap:12px;flex-shrink:0}
.carousel__btn{
  width:48px;height:48px;border-radius:50%;
  border:1px solid var(--line);background:transparent;color:var(--fg);
  font-size:18px;cursor:pointer;display:grid;place-items:center;
  transition:border-color .3s,background .3s,transform .3s var(--ease);
}
.carousel__btn:hover{border-color:var(--accent);background:rgba(232,200,143,.08)}
@media(max-width:560px){.carousel__nav{display:none}}  /* mobile uses swipe */

.carousel{
  margin-top:40px;position:relative;
  width:100vw;max-width:100vw;left:50%;right:50%;   /* full-bleed, edge to edge */
  margin-left:-50vw;margin-right:-50vw;
}
.carousel__track{
  display:flex;gap:18px;
  overflow-x:auto;overflow-y:hidden;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  scroll-behavior:smooth;
  padding:0 clamp(18px,4vw,40px) 6px;   /* first card aligns with the page gutter */
  scrollbar-width:none;                 /* Firefox */
  cursor:grab;
}
.carousel__track::-webkit-scrollbar{display:none}
.carousel.is-dragging .carousel__track{cursor:grabbing;scroll-behavior:auto}
.carousel.is-dragging .reel{pointer-events:none}

.reel{
  position:relative;flex:0 0 auto;
  width:clamp(240px,72vw,300px);
  aspect-ratio:9/16;
  scroll-snap-align:center;
  border:1px solid var(--line);border-radius:6px;overflow:hidden;background:#000;
  transition:transform .5s var(--ease),border-color .5s;
}
.reel:hover{transform:translateY(-6px) scale(1.015);border-color:rgba(232,200,143,.4)}
.reel video{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none;transition:transform .8s var(--ease)}
.reel:hover video{transform:scale(1.06)}
.reel__cap{
  position:absolute;left:0;right:0;bottom:0;
  padding:18px 16px 16px;
  background:linear-gradient(180deg,rgba(10,10,11,0) 0%,rgba(10,10,11,.85) 100%);
  pointer-events:none;
}
.reel__cap h3{font-family:"Cormorant Garamond",serif;font-weight:500;font-size:22px}
.reel__cap p{color:var(--muted);font-size:12px;margin-top:2px;letter-spacing:.04em}
.reel--placeholder{display:grid;place-items:center;border-style:dashed;background:var(--bg-soft)}
.reel__ph{color:var(--muted);font-size:14px;letter-spacing:.05em}

.carousel__hint{margin-top:18px;color:var(--muted);font-size:13px;letter-spacing:.03em}

/* ============ Viral reels (auto-scrolling strip) ============ */
.reels{padding-top:clamp(36px,6vh,80px)}
.vmarquee{
  margin-top:38px;overflow:hidden;contain:paint;
  position:relative;width:100vw;max-width:100vw;left:50%;right:50%;   /* full-bleed */
  margin-left:-50vw;margin-right:-50vw;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);
}
.vmarquee__track{display:flex;gap:18px;width:max-content;animation:vscroll 64s linear infinite}
.vmarquee:hover .vmarquee__track{animation-play-state:paused}
@keyframes vscroll{to{transform:translateX(-50%)}}
.vreel{
  position:relative;flex:0 0 auto;
  width:clamp(196px,21vw,244px);aspect-ratio:9/16;
  border-radius:12px;overflow:hidden;background:#000;
  border:1px solid var(--line);
}
.vreel video{width:100%;height:100%;object-fit:cover;display:block}
.vreel__top{
  position:absolute;top:0;left:0;right:0;z-index:2;
  display:flex;align-items:center;gap:8px;padding:12px 13px 22px;
  background:linear-gradient(180deg,rgba(0,0,0,.62),transparent);
}
.vreel__ava{
  flex:0 0 auto;width:28px;height:28px;border-radius:50%;
  overflow:hidden;border:1px solid rgba(255,255,255,.55);
}
.vreel__ava img{width:100%;height:100%;object-fit:cover;display:block}
.vreel__handle{font-size:12.5px;font-weight:500;color:#fff;letter-spacing:.01em;text-shadow:0 1px 5px rgba(0,0,0,.55);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vreel__views{
  position:absolute;left:0;right:0;bottom:0;z-index:2;
  display:flex;align-items:center;gap:7px;padding:22px 13px 13px;
  font-size:16px;font-weight:500;color:#fff;letter-spacing:.01em;
  background:linear-gradient(0deg,rgba(0,0,0,.72),transparent);
  text-shadow:0 1px 5px rgba(0,0,0,.5);
}
.vreel__play{color:var(--accent);font-size:11px;transform:translateY(-1px)}
@media(prefers-reduced-motion:reduce){.vmarquee__track{animation:none}}
@media(max-width:560px){.vreel{width:clamp(150px,52vw,190px)}}

/* ============ Manifesto (sticky scrollytelling) ============ */
.manifesto{position:relative;z-index:4;height:300vh;margin-top:-100vh}  /* slides up over the reels, then pins; contact (z5) covers it */
.manifesto__sticky{
  position:sticky;top:0;
  height:100vh;height:100svh;
  display:flex;align-items:center;
  background-color:var(--card);
  background-image:linear-gradient(180deg,rgba(232,200,143,.05),rgba(232,200,143,0) min(28vh,360px));
  border-radius:clamp(20px,3.5vw,36px) clamp(20px,3.5vw,36px) 0 0;
  box-shadow:
    inset 0 1px 0 rgba(232,200,143,.3),
    0 -10px 28px -6px rgba(232,200,143,.12),
    0 -30px 70px rgba(0,0,0,.55);
}
.manifesto__canvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}
.manifesto__inner{
  position:relative;width:100%;
  max-width:var(--maxw);margin:0 auto;
  padding:0 clamp(18px,4vw,40px);
}

/* Award medallion with rotating text ring */
.seal{
  position:absolute;z-index:2;pointer-events:none;
  top:50%;right:clamp(110px,15vw,320px);          /* vertically centred in the right gap */
  width:clamp(156px,18vw,250px);aspect-ratio:1;
  display:grid;place-items:center;
  animation:sealfloatC 6s ease-in-out infinite;
}
.seal__img{
  grid-area:1/1;width:72%;height:auto;
  filter:drop-shadow(0 0 34px rgba(232,200,143,.18));
}
.seal__ring{grid-area:1/1;width:100%;height:100%;overflow:visible}
.seal__rotor{transform-box:view-box;transform-origin:100px 100px;animation:sealspin 26s linear infinite}
.seal__ring-text{fill:var(--accent);font-family:"Inter",sans-serif;font-size:10.5px;letter-spacing:2.6px;font-weight:500}
@keyframes sealfloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes sealfloatC{0%,100%{transform:translateY(-50%)}50%{transform:translateY(calc(-50% - 8px))}}
@keyframes sealspin{to{transform:rotate(360deg)}}
@media(max-width:760px){
  .seal{top:auto;bottom:clamp(34px,9vh,92px);right:8px;width:132px;animation-name:sealfloat}
}
.manifesto__text{
  margin-top:10px;
  font-family:"Cormorant Garamond",serif;font-weight:500;
  font-size:clamp(28px,4.6vw,56px);line-height:1.22;letter-spacing:-.01em;
  max-width:26ch;
}
.mw{color:rgba(244,241,234,.14);transition:color .4s var(--ease)}
.mw.is-on{color:var(--fg)}

/* ============ Contact / Form ============ */
.contact{
  min-height:100vh;min-height:100svh;
  display:flex;flex-direction:column;justify-content:center;
}
.contact.reveal{opacity:1;transform:none}  /* the slide-over IS the entrance; words still animate via .is-visible */
.contact .section__title{font-size:clamp(34px,6vw,74px);max-width:16ch}
.form{margin-top:44px;max-width:680px;display:flex;flex-direction:column;gap:22px}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:22px}
@media(max-width:560px){.form__row{grid-template-columns:1fr}}
.form label{display:flex;flex-direction:column;gap:8px;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.form input,.form textarea,.form select{
  background:var(--card-soft);border:1px solid var(--line);color:var(--fg);
  font-family:inherit;font-size:16px;padding:14px 16px;border-radius:2px;
  transition:border-color .3s;
}
.form textarea{resize:vertical}
.form select{
  appearance:none;-webkit-appearance:none;cursor:pointer;padding-right:42px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23e8c88f' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 16px center;
}
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:var(--accent)}
.btn{
  align-self:flex-start;margin-top:4px;
  background:var(--accent);color:#0a0a0b;border:none;cursor:pointer;
  font-family:inherit;font-size:14px;font-weight:500;letter-spacing:.06em;
  padding:16px 38px;border-radius:2px;transition:transform .3s var(--ease),opacity .3s;
}
.btn:hover{opacity:.92}
.form__status{font-size:14px;color:var(--accent);letter-spacing:.03em;min-height:1.2em;text-transform:none}

/* ============ Footer (compact, social links) ============ */
.footer{
  position:sticky;bottom:0;z-index:1;   /* revealed from underneath as the contact card lifts away */
  background:var(--bg);
  border-top:1px solid rgba(232,200,143,.22);
  padding:32px clamp(18px,4vw,40px) 36px;
  display:flex;flex-direction:column;align-items:center;gap:18px;text-align:center;
}
.footer__social{display:flex;gap:24px}
.footer__social a{
  color:var(--muted);display:grid;place-items:center;
  transition:color .3s var(--ease),transform .3s var(--ease);
}
.footer__social a:hover{color:var(--accent);transform:translateY(-3px)}
.footer__social svg{width:25px;height:25px;display:block}
.footer__copy{font-size:12px;color:var(--muted);letter-spacing:.06em}

/* ============ Reduced motion ============ */
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
  .sw__i{transform:none!important}
  .mw{color:inherit!important}
  .grain,.preloader,.cursor{display:none!important}
  .topbar,.hero__sub,.hero__counter,.hero__hint,.hero__dots{opacity:1!important}
}
