/* ─── RESET & TOKENS ─────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --ink:#0D0D0F;
  --bone:#F3F1EC;
  --stone:#86837E;
  --warm:#C9A87A;
  --e:cubic-bezier(.16,1,.3,1);
}
html{scroll-behavior:smooth}
body{
  background:var(--ink);
  color:var(--bone);
  font-family:'DM Sans',system-ui,sans-serif;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  line-height:1.55;
}

/* ─── NAV ────────────────────────────────────────────────────── */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:20px 48px;
  display:flex;align-items:center;justify-content:space-between;
  transition:background .5s;
}
#nav.bg{
  background:rgba(13,13,15,.92);
  backdrop-filter:blur(24px);
  -webkit-backdrop-filter:blur(24px);
}
.n-logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--bone)}
.n-logo svg{width:28px;height:28px}
.n-logo-txt{font-size:13px;font-weight:600;letter-spacing:.01em}
.n-links{display:flex;gap:36px}
.n-links a{
  font-size:13px;color:var(--stone);text-decoration:none;
  letter-spacing:.03em;transition:color .2s;
}
.n-links a:hover{color:var(--bone)}
@media(max-width:680px){
  #nav{padding:18px 24px}
  .n-links{display:none}
}

@media(max-width:680px){
  .h-name-wrap{width:min(68vw,400px)}
}

/* ─── HERO ───────────────────────────────────────────────────── */
#hero{
  min-height:100vh;
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
}
#hc{
  display:flex;flex-direction:column;align-items:center;text-align:center;
  will-change:opacity,transform;padding-top:40px;
}

/* Monogram draw animations */
.dl {stroke-dasharray:188;stroke-dashoffset:188;animation:drw .75s var(--e) .12s both}
.dl2{stroke-dasharray:188;stroke-dashoffset:188;animation:drw .75s var(--e) .3s  both}
.do {stroke-dasharray:296;stroke-dashoffset:296;animation:drw 1s   var(--e) .68s both}
@keyframes drw{to{stroke-dashoffset:0}}

/* Signature lockup — premium reveal instead of per-letter fade */
.h-name-wrap{
  width:min(46vw,760px);display:flex;align-items:center;justify-content:center;
  margin:18px 0 0;overflow:visible;
}
.h-signature{
  position:relative;width:100%;max-width:760px;
}
.sig-reveal{
  overflow:visible;
}
#hero-signature{
  display:block;width:100%;height:auto;opacity:0;
  transform:translateY(14px);
  animation:fup .7s var(--e) 1.45s both;
}

/* Remaining hero text */
.h-role{
  font-size:13px;color:var(--stone);letter-spacing:.1em;margin-top:12px;
  opacity:0;animation:fup .7s var(--e) 2.05s both;
}
.h-div{
  width:1px;height:28px;background:rgba(134,131,126,.28);margin:18px auto;
  opacity:0;animation:fup .7s var(--e) 2.22s both;
}
.h-tag{
  font-family:'Cormorant',serif;font-size:clamp(19px,2.2vw,26px);
  font-weight:300;font-style:italic;color:rgba(243,241,236,.6);line-height:1.4;
  opacity:0;animation:fup .7s var(--e) 2.39s both;
}

/* Scroll cue */
.scue{
  position:absolute;bottom:32px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:6px;
  opacity:0;animation:fup .7s var(--e) 2.95s both;
}
.scue p{font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--stone)}
.sc-ln{
  width:1px;height:36px;
  background:linear-gradient(to bottom,rgba(134,131,126,.7),transparent);
  animation:sln 2s ease-in-out infinite;
}

@keyframes fup{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@keyframes sln{0%,100%{opacity:.4;transform:scaleY(1)}50%{opacity:1;transform:scaleY(.45)}}

/* ─── STICKY PIN WRAPPER ─────────────────────────────────────── */
.pin{position:relative}
.pin-in{
  position:sticky;top:0;height:100vh;overflow:hidden;background:var(--ink);
  display:flex;align-items:center;justify-content:center;
}

/* ─── STATEMENT ──────────────────────────────────────────────── */
.st-wrap{text-align:center;padding:0 40px;max-width:1060px}
.st-lead,
.st-tail{
  font-family:'Cormorant',serif;font-size:clamp(21px,2.6vw,32px);
  font-weight:300;font-style:italic;color:var(--stone);
}
.st-row{display:flex;flex-wrap:wrap;justify-content:center;gap:.06em .16em;margin:6px 0}
.st-w{
  font-size:clamp(58px,9vw,120px);font-weight:700;letter-spacing:-.04em;
  line-height:1.02;display:inline-block;transition:color .5s var(--e);
}

/* ─── SERVICES ───────────────────────────────────────────────── */
.sv-slot{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;will-change:opacity,transform;
}
.sv-slot.on{pointer-events:auto}
.sv-body{max-width:820px;padding:0 48px;text-align:center}
.sv-no{
  font-size:11px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;
  color:var(--warm);display:block;margin-bottom:24px;
}
.sv-h{font-size:clamp(56px,9.5vw,116px);font-weight:700;letter-spacing:-.04em;line-height:.95}
.sv-desc{
  font-family:'Cormorant',serif;font-size:clamp(19px,2.3vw,27px);
  font-weight:300;font-style:italic;color:var(--stone);line-height:1.55;
  margin-top:22px;max-width:52ch;margin-inline:auto;
}
.sv-dots{
  position:absolute;bottom:44px;left:50%;transform:translateX(-50%);
  display:flex;gap:10px;
}
.sdot{
  width:5px;height:5px;border-radius:50%;
  background:rgba(243,241,236,.18);transition:background .35s,transform .35s;
}
.sdot.on{background:var(--warm);transform:scale(1.6)}

/* ─── WORK ───────────────────────────────────────────────────── */
#work{background:var(--bone);color:var(--ink);padding:120px 0 130px}
.ctr{max-width:1100px;margin:0 auto;padding:0 48px}
@media(max-width:680px){.ctr{padding:0 24px}}

.s-ey{font-size:11px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--stone)}
.s-h{font-size:clamp(34px,5vw,64px);font-weight:700;letter-spacing:-.035em;line-height:1.02;margin-top:14px}
.s-sub{max-width:660px;font-size:17px;color:rgba(13,13,15,.58);line-height:1.75;margin-top:18px}

.wgrid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
  margin-top:62px;
}
@media(max-width:760px){.wgrid{grid-template-columns:1fr}}

.wcard{
  border-radius:26px;
  overflow:hidden;
  background:linear-gradient(180deg,rgba(243,241,236,.055),rgba(243,241,236,.025));
  border:1px solid rgba(243,241,236,.10);
  position:relative;
  cursor:pointer;
  opacity:0;
  transform:translateY(34px);
  transition:opacity .85s var(--e),transform .85s var(--e),border-color .35s,box-shadow .35s;
  box-shadow:0 26px 90px rgba(0,0,0,.28);
}
.wcard.vis{opacity:1;transform:none}
.wcard:nth-child(2){transition-delay:.12s}
.wcard.wide{grid-column:span 2;transition-delay:.18s}
.wcard:nth-child(3){transition-delay:.22s}
@media(max-width:760px){.wcard.wide{grid-column:1}}

.portfolio-card{
  display:flex;
  flex-direction:column;
}
.wshot-link{
  display:block;
  position:relative;
  aspect-ratio:16/9;
  overflow:hidden;
  background:var(--ink);
  text-decoration:none;
}
.wshot-link::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(ellipse at 16% 12%,rgba(243,241,236,.10),transparent 30%),
    linear-gradient(120deg,rgba(255,255,255,.09),transparent 24%,transparent 76%,rgba(255,255,255,.04));
  opacity:.55;
  transition:opacity .35s var(--e);
}
.wshot-link img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  filter:saturate(.98) contrast(.99) brightness(.94);
  transform:scale(1.002);
  transition:transform 1s var(--e),filter .55s var(--e);
}
.wcard:hover{
  border-color:rgba(243,241,236,.20);
  box-shadow:0 32px 110px rgba(0,0,0,.36);
}
.wcard:hover .wshot-link img{
  transform:scale(1.026);
  filter:saturate(1.04) contrast(1.02) brightness(1);
}
.wcard:hover .wshot-link::after{opacity:.32}

.wbody{
  position:relative;
  z-index:2;
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:28px;
  padding:26px 28px 28px;
  background:rgba(13,13,15,.96);
  border-top:1px solid rgba(243,241,236,.08);
}
.wcat{
  font-size:11px;
  font-weight:500;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--warm);
  margin-bottom:7px;
}
.wname{
  font-size:clamp(19px,2.2vw,27px);
  font-weight:700;
  letter-spacing:-.02em;
  color:var(--bone);
}
.wdesc{
  font-size:14px;
  color:rgba(243,241,236,.70);
  line-height:1.62;
  max-width:64ch;
  margin-top:8px;
}
.wmeta{
  display:flex;
  flex-wrap:wrap;
  justify-content:flex-end;
  gap:7px;
  min-width:230px;
}
.wmeta span{
  font-size:10px;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(243,241,236,.68);
  border:1px solid rgba(243,241,236,.14);
  border-radius:999px;
  padding:5px 9px;
  background:rgba(243,241,236,.045);
}
.wloc{font-size:13px;color:var(--stone);margin-top:3px}

.warrow{display:none}

@media(max-width:760px){
  .wbody{
    display:block;
    padding:22px;
  }
  .wdesc{font-size:13px;line-height:1.55}
  .wmeta{
    justify-content:flex-start;
    min-width:0;
    margin-top:14px;
  }
  .wmeta span{font-size:9px;padding:4px 8px}
}

/* ─── ABOUT ──────────────────────────────────────────────────── */
#about{background:var(--ink);padding:140px 0}
.agrid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
@media(max-width:768px){.agrid{grid-template-columns:1fr;gap:48px}}

.a-q{
  font-family:'Cormorant',serif;font-size:clamp(34px,4.5vw,58px);
  font-weight:300;line-height:1.2;letter-spacing:-.01em;
}
.a-q em{font-style:italic;color:var(--warm)}
.a-body{display:flex;flex-direction:column;gap:18px}
.a-body p{font-size:17px;color:var(--stone);line-height:1.75}
.a-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.a-tag{
  font-size:12px;font-weight:500;
  border:1px solid rgba(243,241,236,.14);border-radius:999px;
  padding:7px 16px;color:rgba(243,241,236,.4);
}
.tlink{
  font-size:15px;font-weight:600;color:var(--bone);text-decoration:none;
  display:inline-flex;align-items:center;gap:8px;margin-top:8px;
  transition:gap .3s var(--e),color .2s;
}
.tlink:hover{gap:14px;color:var(--warm)}

/* ─── CTA ────────────────────────────────────────────────────── */
#cta{
  background:var(--ink);padding:160px 48px;text-align:center;
  position:relative;overflow:hidden;
  border-top:1px solid rgba(243,241,236,.05);
}
@media(max-width:680px){#cta{padding:100px 24px}}

.cta-mono{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-52%);
  opacity:.035;pointer-events:none;
}
.cta-ey{
  font-size:11px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;
  color:var(--warm);display:block;margin-bottom:24px;
}
.cta-hd{
  font-family:'Cormorant',serif;font-size:clamp(50px,8vw,100px);
  font-weight:300;font-style:italic;line-height:1.05;margin-bottom:48px;
}
.cta-btn{
  display:inline-flex;align-items:center;gap:12px;
  background:var(--bone);color:var(--ink);
  font-family:'DM Sans',sans-serif;font-size:15px;font-weight:600;letter-spacing:.02em;
  padding:16px 38px;border-radius:999px;text-decoration:none;
  transition:background .25s,gap .3s var(--e),transform .25s;
}
.cta-btn:hover{background:var(--warm);gap:18px;transform:scale(1.04)}

/* ─── FOOTER ─────────────────────────────────────────────────── */
footer{
  background:var(--ink);border-top:1px solid rgba(243,241,236,.07);
  padding:44px 48px;
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:20px;
}
@media(max-width:680px){footer{flex-direction:column;align-items:flex-start;padding:36px 24px}}

.f-logo{display:flex;align-items:center;gap:9px;color:var(--bone);text-decoration:none}
.f-logo svg{width:26px;height:26px}
.f-logo-txt{font-size:13px;font-weight:600}
.f-links{display:flex;gap:28px}
.f-links a{font-size:13px;color:var(--stone);text-decoration:none;transition:color .2s}
.f-links a:hover{color:var(--bone)}
.f-copy{font-size:12px;color:rgba(134,131,126,.45);letter-spacing:.04em}

/* ─── SCROLL REVEALS (IntersectionObserver) ──────────────────── */
.rv{
  opacity:0;transform:translateY(26px);
  transition:opacity .85s var(--e),transform .85s var(--e);
}
.rv.vis{opacity:1;transform:none}
.rv.d1{transition-delay:.1s}
.rv.d2{transition-delay:.2s}

/* ─── REDUCED MOTION ─────────────────────────────────────────── */
@media(prefers-reduced-motion:reduce){
  .dl,.dl2,.do,#hero-signature,.h-role,.h-div,.h-tag,.scue{
    animation:none;stroke-dashoffset:0;opacity:1;transform:none;
  }
  .rv,.wcard{transition:none !important;opacity:1;transform:none}
}

@media(max-width:680px){
  .s-sub{font-size:15px;line-height:1.65}
  .wbody{padding:24px}
  .wdesc{font-size:13px;line-height:1.55}
  .wmeta span{font-size:9px;padding:4px 8px}
}

/* ─── HOMEPAGE WORK TEASER ───────────────────────────────────── */
.work-teaser{
  background:var(--ink);
  padding:90px 0 40px;
}
.teaser-panel{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:34px;
  padding:34px 36px;
  border:1px solid rgba(243,241,236,.10);
  border-radius:28px;
  background:
    radial-gradient(ellipse at 12% 20%,rgba(201,168,122,.12),transparent 42%),
    radial-gradient(ellipse at 88% 70%,rgba(120,168,194,.10),transparent 42%),
    rgba(243,241,236,.035);
  box-shadow:0 26px 90px rgba(0,0,0,.25);
}
.teaser-title{
  margin-top:8px;
  font-size:clamp(28px,4vw,54px);
  line-height:.98;
  letter-spacing:-.045em;
  color:var(--bone);
}
.teaser-copy{
  margin-top:12px;
  max-width:620px;
  color:rgba(243,241,236,.62);
  line-height:1.65;
  font-size:15px;
}
.teaser-link{
  flex:0 0 auto;
  color:var(--ink);
  background:var(--bone);
  border-radius:999px;
  padding:14px 20px;
  font-size:12px;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  transition:transform .25s var(--e), background .25s;
}
.teaser-link:hover{
  transform:translateY(-2px);
  background:var(--warm);
}
@media(max-width:760px){
  .teaser-panel{display:block;padding:28px}
  .teaser-link{display:inline-flex;margin-top:22px}
}

/* ─── DEDICATED WORK PAGE ────────────────────────────────────── */
.page-hero{
  min-height:68vh;
  display:flex;
  align-items:flex-end;
  padding:170px 0 90px;
  background:
    radial-gradient(ellipse at 20% 20%,rgba(201,168,122,.14),transparent 44%),
    radial-gradient(ellipse at 82% 32%,rgba(120,168,194,.12),transparent 46%),
    var(--ink);
}
.page-title{
  margin-top:18px;
  font-size:clamp(64px,11vw,160px);
  line-height:.86;
  letter-spacing:-.075em;
  color:var(--bone);
}
.page-sub{
  margin-top:28px;
  max-width:790px;
  color:rgba(243,241,236,.64);
  font-family:'Cormorant',serif;
  font-size:clamp(22px,2.7vw,36px);
  line-height:1.18;
}
.work-page-section{
  padding-top:90px;
}
