/* ============================================================
   CAPTURE ARTISANAL — Design System v2 (overlay)
   Cinematic scrollytelling · loaded AFTER styles.css
   ============================================================ */

/* ── Tokens (override) ── */
:root{
  --black:#070707;
  --gold:#C9A84C;
  --gold-light:#E2C275;
  --gold-dim:rgba(201,168,76,.1);
  --white:#F2EDE3;
  --white-dim:rgba(242,237,227,.5);
  --dark-1:#0f0f0f;
  --dark-2:#161616;
  --dark-3:#1e1e1e;
  --border:rgba(201,168,76,.14);
  --e:cubic-bezier(0.16,1,0.3,1);
  --e2:cubic-bezier(0.76,0,0.24,1);
}
body{background:var(--black);color:var(--white)}
::selection{background:var(--gold);color:var(--black)}
em{color:var(--gold);font-style:italic}

h1,h2,h3{font-weight:300}

/* ════════ LOGO LOCKUP ════════ */
.lkWrap{display:inline-block;line-height:0}
.lk{display:block}
.lkCap{font-family:var(--font-display);font-weight:300;font-size:92px;letter-spacing:24px;fill:var(--white)}
.lkArt{font-family:var(--font-display);font-weight:400;font-size:40px;letter-spacing:13px;fill:var(--white)}
.lkTag{font-family:var(--font-body);font-weight:300;font-size:17px;letter-spacing:9px;fill:var(--white);opacity:.55}
.lkLine{stroke:var(--white);stroke-width:1.4;opacity:.85}
.lkBr{stroke:var(--white);stroke-width:2;fill:none;opacity:.9}
.lkAp{stroke:var(--gold);fill:none}
.lkApC{fill:var(--gold)}

/* ════════ PRELOADER (logo build-in + shutter) ════════ */
#loader{
  position:fixed;inset:0;z-index:100000;
  display:flex;align-items:center;justify-content:center;
  background:var(--black);
  transform:none!important;
}
#loader .loader-logo,#loader .loader-bar{display:none}
#preLogo{width:min(72vw,340px);overflow:visible}
body.loaded #preLogo{animation:lgBreathe 3.2s ease-in-out infinite}
#preLogo .pBr{stroke-dasharray:80;stroke-dashoffset:80;animation:lgDraw 1s var(--e) forwards}
#preLogo .pBr:nth-of-type(1){animation-delay:.1s}
#preLogo .pBr:nth-of-type(2){animation-delay:.22s}
#preLogo .pBr:nth-of-type(3){animation-delay:.34s}
#preLogo .pBr:nth-of-type(4){animation-delay:.46s}
@keyframes lgDraw{to{stroke-dashoffset:0}}
@keyframes lgBreathe{0%,100%{transform:scale(1)}50%{transform:scale(1.02)}}
#preLogo .pCap{opacity:0;animation:lgUp 1s var(--e) .4s forwards}
#preLogo .pRule{transform-box:fill-box;transform-origin:center;transform:scaleX(0);animation:lgRule .9s var(--e) .85s forwards}
@keyframes lgRule{to{transform:scaleX(1)}}
#preLogo .pArt{opacity:0;animation:lgUp .9s var(--e) 1.05s forwards}
#preLogo .pTag{opacity:0;animation:lgFade .9s ease 1.45s forwards}
@keyframes lgUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
@keyframes lgFade{to{opacity:.55}}
#preLogo .pAp{transform-box:fill-box;transform-origin:center;opacity:0;animation:lgApIn 1s var(--e) .95s forwards,lgSpin 7s linear .95s infinite}
@keyframes lgApIn{to{opacity:1}}
@keyframes lgSpin{from{rotate:0deg}to{rotate:360deg}}
#preBar{position:absolute;bottom:0;left:0;height:2px;width:100%;background:var(--gold);transform-origin:left;transform:scaleX(0)}
.shutter{position:fixed;left:0;width:100%;height:50.5vh;background:#0d0d0d;z-index:99999;display:none}
#shT{top:0;border-bottom:1px solid rgba(201,168,76,.2)}
#shB{bottom:0}

/* ════════ CURSOR (restyle legacy .cursor/.cursor-ring) ════════ */
.cursor{
  width:6px!important;height:6px!important;
  background:var(--gold)!important;
}
.cursor-ring{
  width:34px!important;height:34px!important;
  border:1px solid rgba(201,168,76,.45)!important;
  transition:width .45s var(--e),height .45s var(--e),border-color .3s,background .3s,opacity .35s!important;
}
.cursor.expand{width:10px!important;height:10px!important;background:var(--gold-light)!important}
.cursor-ring.expand{
  width:64px!important;height:64px!important;
  border-color:var(--gold)!important;
  background:rgba(201,168,76,.06)!important;
  opacity:1!important;
}

/* ════════ FILM GRAIN + PROGRESS ════════ */
#grain{position:fixed;inset:-50%;width:200%;height:200%;pointer-events:none;z-index:9990;opacity:.045;
background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.84' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='220' height='220' filter='url(%23n)'/%3E%3C/svg%3E");
animation:grainMove .4s steps(4) infinite}
@keyframes grainMove{0%{transform:translate(0)}25%{transform:translate(-1%,1%)}50%{transform:translate(1%,-1%)}75%{transform:translate(-1%,-1%)}}
#scroll-progress{
  height:2px!important;
  background:linear-gradient(90deg,var(--gold),var(--gold-light))!important;
  box-shadow:0 0 10px rgba(201,168,76,.5);
  z-index:9991!important;
}

/* ════════ NAV (restyle legacy markup) ════════ */
.nav{
  height:76px;padding:0 4%;
  background:transparent;
  border-bottom:1px solid transparent;
  backdrop-filter:none;
  transition:background .45s,border-color .45s,transform .5s var(--e),backdrop-filter .45s;
}
.nav.stuck{
  background:rgba(7,7,7,.74);
  backdrop-filter:blur(22px);
  border-bottom:1px solid rgba(201,168,76,.1);
}
.nav.hidden{transform:translateY(-100%)}
.nav-logo{display:inline-block;line-height:0}
.nav-logo svg{overflow:visible}
.nav-links a{
  font-size:.55rem;font-weight:600;letter-spacing:.24em;
  color:var(--white-dim);
  position:relative;padding:.3rem 0;
}
.nav-links a::after{
  content:'';position:absolute;left:0;bottom:0;width:100%;height:1px;
  background:var(--gold);transform:scaleX(0);transform-origin:right;
  transition:transform .45s var(--e);
}
.nav-links a:hover{color:var(--white)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1);transform-origin:left}
.nav-links a.active{color:var(--white)}
.nav-book{
  font-size:.55rem;letter-spacing:.22em;
  padding:.8rem 1.8rem;
  background:transparent;
  border:1px solid rgba(201,168,76,.35);
  color:var(--gold);
  position:relative;overflow:hidden;
  transition:color .35s;
  z-index:1;
}
.nav-book::before{
  content:'';position:absolute;inset:0;background:var(--gold);
  transform:translateY(101%);transition:transform .45s var(--e2);
  z-index:-1;
}
.nav-book:hover{color:var(--black)}
.nav-book:hover::before{transform:translateY(0)}

/* ════════ BUTTONS (legacy .btn restyle) ════════ */
.btn{
  position:relative;overflow:hidden;
  font-size:.58rem;letter-spacing:.2em;
  padding:1.05rem 2.4rem;
  z-index:1;
  transition:color .35s,border-color .35s;
}
.btn::before{
  content:'';position:absolute;inset:0;
  transform:translateY(101%);transition:transform .5s var(--e2);
  z-index:-1;
}
.btn-gold{background:var(--gold);color:var(--black)}
.btn-gold::before{background:var(--white)}
.btn-gold:hover{background:var(--gold);color:var(--black)}
.btn-gold:hover::before{transform:translateY(0)}
.btn-outline{border:1px solid rgba(242,237,227,.22);color:var(--white)}
.btn-outline::before{background:var(--gold)}
.btn-outline:hover{color:var(--black);border-color:var(--gold)}
.btn-outline:hover::before{transform:translateY(0)}
.btn-wa::before{background:#1ebf5c}

/* ════════ PAGE HERO (inner pages) ════════ */
.page-hero{
  padding:13rem 4% 6rem;
  position:relative;
}
.page-hero::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 60% 50% at 70% 20%,rgba(201,168,76,.05) 0%,transparent 65%);
}
.page-hero h1{
  font-size:clamp(3.6rem,9vw,9.5rem);
  line-height:.95;letter-spacing:-.025em;
}

/* ════════ FOOTER (restyle legacy) ════════ */
.footer{border-top:1px solid var(--border);background:var(--black)}
.footer-brand .lk{margin-bottom:1rem}

/* ════════ MARQUEE band (restyle: gold→bordered editorial) ════════ */
.marquee-band{
  background:transparent;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:.9rem 0;
}
.marquee-track span{color:var(--white-dim)}
.marquee-track .dot{color:var(--gold)}

/* ============================================================
   HOMEPAGE CINEMATIC COMPONENTS
   ============================================================ */

/* ── HERO ── */
#hero2{height:100svh;position:relative;overflow:hidden}
#hero2 .hLayer{position:absolute;inset:0;will-change:transform}
#hImg{position:absolute;inset:-6%;background-position:center 30%;background-size:cover;background-repeat:no-repeat;will-change:transform;transform:scale(1.15);filter:brightness(.85)}
#hVeil{position:absolute;inset:0;background:
 linear-gradient(105deg,rgba(7,7,7,.92) 0%,rgba(7,7,7,.55) 45%,rgba(7,7,7,.15) 75%,rgba(7,7,7,.35) 100%),
 linear-gradient(to top,rgba(7,7,7,.9) 0%,transparent 35%)}
#hVignette{position:absolute;inset:0;box-shadow:inset 0 0 28vw rgba(0,0,0,.75)}
.hContent{position:absolute;left:4%;right:4%;top:96px;bottom:7vh;z-index:3;display:flex;flex-direction:column;justify-content:flex-end}
.hKicker{display:flex;align-items:center;gap:1rem;margin-bottom:2.6rem}
.hKicker>span{font-family:var(--font-label);font-size:.55rem;font-weight:600;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);display:inline-block;transform:translateY(140%);transition:transform 1s var(--e) .1s}
.hKicker::before{content:'';width:0;height:1px;background:var(--gold);transition:width 1.1s var(--e) .2s}
body.in .hKicker::before{width:3.4rem}
body.in .hKicker>span{transform:none}
.hTitle{font-family:var(--font-display);font-weight:300;font-size:clamp(4.2rem,12vw,12.5rem);line-height:.94;letter-spacing:-.03em}
.hLine{display:block;overflow:hidden;padding-bottom:.06em;margin-bottom:-.06em}
.hWord{display:inline-block;transform:translateY(118%) rotate(4deg);transform-origin:left top;transition:transform 1.3s var(--e)}
body.in .hWord{transform:none}
body.in .hLine:nth-child(1) .hWord{transition-delay:.15s}
body.in .hLine:nth-child(2) .hWord{transition-delay:.28s}
body.in .hLine:nth-child(3) .hWord{transition-delay:.41s}
.hBottom{display:flex;align-items:flex-end;justify-content:space-between;gap:3rem;margin-top:3.4rem;flex-wrap:wrap}
.hSub{max-width:42ch;font-size:.92rem;line-height:2;color:var(--white-dim);opacity:0;transform:translateY(24px);transition:opacity 1s var(--e) .85s,transform 1s var(--e) .85s}
body.in .hSub{opacity:1;transform:none}
.hCtas{display:flex;gap:1rem;opacity:0;transform:translateY(24px);transition:opacity 1s var(--e) 1s,transform 1s var(--e) 1s}
body.in .hCtas{opacity:1;transform:none}
.hMeta{position:absolute;right:4%;top:50%;transform:translateY(-50%);z-index:3;display:flex;flex-direction:column;gap:2.2rem;text-align:right;opacity:0;transition:opacity 1.2s var(--e) 1.3s}
body.in .hMeta{opacity:1}
.hMeta .m b{display:block;font-family:var(--font-display);font-size:1.25rem;font-weight:300;color:var(--white)}
.hMeta .m span{font-family:var(--font-label);font-size:.5rem;font-weight:600;letter-spacing:.26em;text-transform:uppercase;color:var(--gold)}
.hScroll{position:absolute;left:50%;bottom:3vh;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:.6rem;opacity:0;transition:opacity 1s 1.6s}
body.in .hScroll{opacity:1}
.hScroll i{width:1px;height:46px;background:linear-gradient(to bottom,var(--gold),transparent);display:block;animation:hsLine 2.2s var(--e) infinite}
@keyframes hsLine{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}55%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}
.hScroll span{font-family:var(--font-label);font-size:.48rem;font-weight:600;letter-spacing:.34em;text-transform:uppercase;color:var(--white-dim)}
@media(max-height:800px){
  .hKicker{margin-bottom:1.4rem}
  .hTitle{font-size:clamp(3rem,9vw,8.5rem)}
  .hBottom{margin-top:1.8rem}
  .hSub{font-size:.82rem;line-height:1.75}
}

/* ── SECTION PRIMITIVES ── */
.k2{font-family:var(--font-label);font-size:.55rem;font-weight:600;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);display:flex;align-items:center;gap:1rem;margin-bottom:1.2rem}
.k2::before{content:'';width:3rem;height:1px;background:var(--gold);flex-shrink:0}
.h2x{font-family:var(--font-display);font-weight:300;font-size:clamp(2.6rem,5.4vw,5.8rem);line-height:1.02}

/* ── INTRO STATEMENT ── */
#intro2{padding:22vh 4%;position:relative}
.iText{font-family:var(--font-display);font-weight:300;font-size:clamp(2rem,4.4vw,5rem);line-height:1.32;letter-spacing:-.01em;max-width:1200px}
.iText .ch{opacity:.12;transition:opacity .4s}
.iText .ch.on{opacity:1}

/* ── ZOOM SEQUENCE ── */
#zoom{position:relative;height:300vh}
.zStick{position:sticky;top:0;height:100svh;overflow:hidden;display:flex;align-items:center;justify-content:center}
#zFrame{position:relative;width:38vw;height:52vh;overflow:hidden;will-change:width,height}
#zImg{position:absolute;inset:-10%;background-position:center;background-size:cover;will-change:transform;transform:scale(1.2);transition:opacity .45s ease}
#zVeil{position:absolute;inset:0;background:rgba(7,7,7,0)}
.zCap{position:absolute;z-index:2;left:4%;bottom:10vh;max-width:480px;opacity:0}
.zCap .n{font-family:var(--font-label);font-size:.55rem;font-weight:600;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:1.2rem;display:block}
.zCap h3{font-family:var(--font-display);font-weight:300;font-size:clamp(2.4rem,4.4vw,4.6rem);line-height:1.02;margin-bottom:1.3rem}
.zCap p{font-size:.9rem;line-height:1.95;color:var(--white-dim);max-width:38ch}
.zTitle{position:absolute;z-index:2;text-align:center;font-family:var(--font-display);font-weight:300;font-size:clamp(3rem,7vw,8rem);line-height:1;pointer-events:none;mix-blend-mode:difference}
@media(max-width:900px){#zFrame{width:80vw;height:46vh}}

/* ── HORIZONTAL GALLERY ── */
#gallery2{position:relative}
.gStick{position:sticky;top:0;height:100svh;overflow:hidden}
.gHead{position:absolute;top:11vh;left:4%;z-index:3}
.gTrack{position:absolute;top:0;left:0;height:100svh;display:flex;align-items:flex-end;gap:4vw;padding:0 8vw 12vh;will-change:transform}
.gItem{flex-shrink:0;position:relative}
.gItem .frame{overflow:hidden;position:relative;background:var(--dark-1)}
.gItem img{object-fit:cover;width:100%;height:100%;transform:scale(1.12);transition:transform 1s var(--e),filter .6s,opacity .5s ease;filter:grayscale(28%) brightness(.92);will-change:transform}
.gItem:hover img{transform:scale(1.02);filter:grayscale(0%) brightness(1)}
.gItem .meta{position:absolute;left:0;bottom:-3.2rem;display:flex;align-items:baseline;gap:1rem;white-space:nowrap}
.gItem .meta .gi{font-family:var(--font-display);font-size:1rem;color:var(--gold)}
.gItem .meta .gt{font-family:var(--font-display);font-size:1.4rem;font-weight:300}
.gItem .meta .gc{font-family:var(--font-label);font-size:.5rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--white-dim)}
.g1 .frame{width:30vw;height:60vh}
.g2 .frame{width:22vw;height:47vh}
.g3 .frame{width:34vw;height:66vh}
.g4 .frame{width:24vw;height:51vh}
.g5 .frame{width:30vw;height:60vh}
.gEnd{flex-shrink:0;width:30vw;display:flex;align-items:center;justify-content:center;height:60vh}
.gEnd a{display:flex;flex-direction:column;align-items:center;gap:1.4rem;text-align:center}
.gEnd .circ{width:120px;height:120px;border:1px solid rgba(201,168,76,.4);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:var(--gold);transition:background .4s,transform .5s var(--e)}
.gEnd a:hover .circ{background:rgba(201,168,76,.1);transform:scale(1.1)}
.gEnd span{font-family:var(--font-label);font-size:.55rem;font-weight:600;letter-spacing:.26em;text-transform:uppercase;color:var(--white)}
.gProg{position:absolute;bottom:5vh;left:4%;right:4%;height:1px;background:rgba(201,168,76,.15);z-index:3}
.gProg i{display:block;height:100%;background:var(--gold);transform-origin:left;transform:scaleX(0)}
@media(max-width:900px){.g1 .frame,.g2 .frame,.g3 .frame,.g4 .frame,.g5 .frame{width:72vw;height:50vh}.gEnd{width:72vw}}

/* ── CHAPTERS ── */
.chap{position:relative;height:100svh;overflow:hidden;display:flex;align-items:center}
.chap .bg{position:absolute;inset:-8%;background-size:cover;background-position:center;will-change:transform;filter:brightness(.8)}
.chap .veil{position:absolute;inset:0}
.chap.L .veil{background:linear-gradient(100deg,rgba(7,7,7,.93) 0%,rgba(7,7,7,.55) 45%,rgba(7,7,7,.08) 80%)}
.chap.R .veil{background:linear-gradient(-100deg,rgba(7,7,7,.93) 0%,rgba(7,7,7,.55) 45%,rgba(7,7,7,.08) 80%)}
.chap .inner{position:relative;z-index:2;padding:0 4%;width:100%;display:flex}
.chap.R .inner{justify-content:flex-end;text-align:right}
.chap .box{max-width:560px}
.chap .num{font-family:var(--font-label);font-size:.55rem;font-weight:600;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:1.6rem;display:block}
.chap h2{font-family:var(--font-display);font-weight:300;font-size:clamp(2.6rem,5.4vw,6.2rem);line-height:1.02;margin-bottom:1.5rem}
.chap p{font-size:.9rem;line-height:2;color:var(--white-dim);max-width:40ch;margin-bottom:2.2rem}
.chap.R p{margin-left:auto}
.chLink{font-family:var(--font-label);font-size:.55rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);display:inline-flex;align-items:center;gap:.8rem;transition:gap .35s}
.chLink:hover{gap:1.4rem}

/* ── VELOCITY MARQUEE ── */
#mq2{padding:8rem 0;overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.mqRow{display:flex;white-space:nowrap;will-change:transform}
.mqRow span{font-family:var(--font-display);font-weight:300;font-size:clamp(4rem,9vw,9rem);line-height:1.05;padding:0 2.4rem;letter-spacing:-.02em}
.mqRow .o{color:transparent;-webkit-text-stroke:1px rgba(201,168,76,.55)}

/* ── STATS ── */
#stats2{padding:13vh 4%;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(201,168,76,.09)}
#stats2 .st{background:var(--black);padding:4rem 2.4rem;position:relative;overflow:hidden}
#stats2 .st::after{content:'';position:absolute;left:0;bottom:0;width:100%;height:2px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .6s var(--e)}
#stats2 .st:hover::after{transform:scaleX(1)}
#stats2 .st b{font-family:var(--font-display);font-weight:300;font-size:clamp(3.2rem,6vw,6.5rem);line-height:1;color:var(--gold);display:block;font-variant-numeric:tabular-nums}
#stats2 .st span{font-family:var(--font-label);font-size:.55rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--white-dim);margin-top:1rem;display:block}
@media(max-width:900px){#stats2{grid-template-columns:repeat(2,1fr)}}

/* ── SERVICES ROWS ── */
#svcs2{padding:14vh 4%}
.sHead{display:flex;align-items:flex-end;justify-content:space-between;gap:3rem;flex-wrap:wrap;margin-bottom:6rem}
.sHead p{max-width:38ch;font-size:.9rem;line-height:2;color:var(--white-dim)}
.sRow{position:relative;border-top:1px solid rgba(201,168,76,.09);overflow:hidden;display:block;color:inherit}
.sRow:last-of-type{border-bottom:1px solid rgba(201,168,76,.09)}
.sFill{position:absolute;inset:0;background:var(--gold);transform:scaleY(0);transform-origin:bottom;transition:transform .55s var(--e2)}
.sRow:hover .sFill{transform:scaleY(1)}
.sIn{position:relative;display:grid;grid-template-columns:5rem 1fr auto 4rem;align-items:center;gap:2rem;padding:2.8rem 0;transition:color .4s}
.sRow:hover .sIn{color:var(--black)}
.sIn .i{font-family:var(--font-label);font-size:.6rem;font-weight:600;letter-spacing:.12em;color:var(--gold);transition:color .4s}
.sRow:hover .sIn .i{color:rgba(7,7,7,.6)}
.sIn h3{font-family:var(--font-display);font-weight:300;font-size:clamp(1.8rem,3.6vw,3.8rem);line-height:1;transition:transform .55s var(--e)}
.sRow:hover .sIn h3{transform:translateX(16px)}
.sIn .p{font-family:var(--font-label);font-size:.6rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--white-dim);transition:color .4s}
.sRow:hover .sIn .p{color:rgba(7,7,7,.75)}
.sIn .a{font-size:1.3rem;color:var(--gold);transform:rotate(-45deg);transition:transform .5s var(--e),color .4s;text-align:center}
.sRow:hover .sIn .a{transform:rotate(0);color:var(--black)}
@media(max-width:900px){.sIn{grid-template-columns:3rem 1fr auto}.sIn .a{display:none}}

/* ── QUOTE ── */
#quote2{min-height:88vh;display:flex;align-items:center;justify-content:center;padding:14vh 4%;position:relative;overflow:hidden}
#qBg{position:absolute;font-family:var(--font-display);font-size:clamp(16rem,36vw,42rem);line-height:.72;color:transparent;-webkit-text-stroke:1px rgba(201,168,76,.07);pointer-events:none;user-select:none;white-space:nowrap;will-change:transform}
.qBody{max-width:1000px;text-align:center;position:relative;z-index:1}
.qBody blockquote{font-family:var(--font-display);font-weight:300;font-style:italic;font-size:clamp(2rem,4.4vw,4.8rem);line-height:1.28;letter-spacing:-.01em}
.qBy{margin-top:3.2rem;display:inline-flex;align-items:center;gap:1.6rem}
.qBy i{width:3.4rem;height:1px;background:rgba(201,168,76,.5)}
.qBy span{font-family:var(--font-label);font-size:.56rem;font-weight:600;letter-spacing:.26em;text-transform:uppercase;color:var(--gold)}

/* ── CLIENTS ── */
#clients2{padding:0 4% 14vh}
.cGrid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(201,168,76,.09);margin-top:3.4rem}
.cI{background:var(--black);padding:2.5rem 2rem;transition:background .4s}
.cI:hover{background:#0d0c09}
.cI b{font-family:var(--font-display);font-size:1.45rem;font-weight:300;display:block;margin-bottom:.4rem}
.cI span{font-family:var(--font-label);font-size:.52rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--white-dim)}
@media(max-width:900px){.cGrid{grid-template-columns:repeat(2,1fr)}}

/* ── FINAL CTA ── */
#cta2{position:relative;min-height:96svh;display:flex;align-items:center;overflow:hidden;border-top:1px solid var(--border)}
#ctaBg{position:absolute;inset:-8%;background-size:cover;background-position:center;will-change:transform;filter:brightness(.55)}
#cta2 .veil{position:absolute;inset:0;background:linear-gradient(120deg,rgba(7,7,7,.93),rgba(7,7,7,.5) 70%)}
#cta2 .inner{position:relative;z-index:2;padding:0 4%}
#cta2 h2{font-family:var(--font-display);font-weight:300;font-size:clamp(3.6rem,10.5vw,11.5rem);line-height:.95;letter-spacing:-.03em;margin-bottom:3.4rem}
#cta2 h2 em{color:transparent;-webkit-text-stroke:1.2px var(--gold)}
#cta2 .row{display:flex;gap:1.2rem;flex-wrap:wrap}

/* ── CONTACT STRIP ── */
.contact-strip{padding:2.6rem 4%;background:var(--dark-1);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1.6rem;border-top:1px solid var(--border)}
.contact-strip .csi{display:flex;flex-direction:column;gap:.3rem}
.contact-strip .csi .l{font-family:var(--font-label);font-size:.52rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--gold)}
.contact-strip .csi .v{font-family:var(--font-display);font-size:1.05rem;font-weight:300;color:var(--white)}

/* ── NEW REVEAL CLASSES ── */
.rv{opacity:0;transform:translateY(50px);transition:opacity 1s var(--e),transform 1s var(--e)}
.rv.on{opacity:1;transform:none}
.rv.d1{transition-delay:.1s}.rv.d2{transition-delay:.2s}.rv.d3{transition-delay:.3s}

/* touch devices: native cursor */
@media(pointer:coarse){
  body,a,button{cursor:auto!important}
  #grain{opacity:.03}
}
