/* ============================================================
   DK VISUALS — cinematic portfolio
   ============================================================ */
:root{
  --bg:#08080a;
  --bg-2:#0e0e12;
  --bg-3:#14141a;
  --ink:#f4f1ea;
  --ink-2:rgba(244,241,234,.62);
  --ink-3:rgba(244,241,234,.34);
  --line:rgba(244,241,234,.13);
  --accent:#c9a36a;
  --accent-soft:rgba(201,163,106,.16);
  --maxw:1640px;
  --ease:cubic-bezier(.16,1,.3,1);
  --serif:"Cormorant Garamond",Georgia,serif;
  --sans:"Space Grotesk",-apple-system,system-ui,sans-serif;
  --mono:"Space Mono",ui-monospace,monospace;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:auto}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:300;
  -webkit-font-smoothing:antialiased;
  overflow-x:clip;
  line-height:1.5;
  cursor:none;
}
@media (hover:none),(pointer:coarse){ body{cursor:auto} }
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:none}
::selection{background:var(--accent);color:#000}
.skip-link{position:fixed;top:12px;left:12px;z-index:12000;padding:10px 14px;background:var(--ink);color:var(--bg);
  font-size:14px;transform:translateY(-160%);transition:transform .2s var(--ease)}
.skip-link:focus{transform:none}
:focus-visible{outline:2px solid var(--accent);outline-offset:5px}

/* ---------- film grain + vignette overlays ---------- */
.grain{
  position:fixed;inset:-50%;z-index:9000;pointer-events:none;
  opacity:.05;mix-blend-mode:overlay;
  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='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 7s steps(6) infinite;
}
.no-grain .grain{display:none}
@keyframes grain{
  0%{transform:translate(0,0)}10%{transform:translate(-4%,-4%)}
  30%{transform:translate(3%,-2%)}50%{transform:translate(-2%,4%)}
  70%{transform:translate(4%,2%)}90%{transform:translate(-3%,3%)}
  100%{transform:translate(0,0)}
}
.vignette{position:fixed;inset:0;z-index:8000;pointer-events:none;
  box-shadow:inset 0 0 240px 40px rgba(0,0,0,.7);}

/* ---------- custom cursor ---------- */
.cursor,.cursor-dot{position:fixed;top:0;left:0;z-index:10000;pointer-events:none;
  border-radius:50%;will-change:transform;mix-blend-mode:difference;}
.cursor{width:38px;height:38px;border:1px solid var(--ink);
  transform:translate(-50%,-50%);transition:width .35s var(--ease),height .35s var(--ease),background .35s,border-color .35s,opacity .3s;}
.cursor-dot{width:5px;height:5px;background:var(--ink);transform:translate(-50%,-50%);}
.cursor.is-hover{width:64px;height:64px;background:var(--ink);border-color:transparent;}
.cursor.is-view{width:96px;height:96px;background:var(--accent);border-color:transparent;mix-blend-mode:normal;}
.cursor .clabel{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:10px;letter-spacing:.1em;color:#000;text-transform:uppercase;opacity:0;transition:opacity .2s;mix-blend-mode:normal;}
.cursor.is-view .clabel{opacity:1}
@media (hover:none),(pointer:coarse){ .cursor,.cursor-dot{display:none} }
@media (hover:none),(pointer:coarse){ button{cursor:pointer} }

/* ---------- viewfinder corner brackets motif ---------- */
.corners{position:absolute;inset:0;pointer-events:none;z-index:3}
.corners::before,.corners::after,.corners i::before,.corners i::after{
  content:"";position:absolute;width:26px;height:26px;border:1px solid var(--ink-3);}
.corners::before{top:24px;left:24px;border-right:0;border-bottom:0}
.corners::after{top:24px;right:24px;border-left:0;border-bottom:0}
.corners i::before{bottom:24px;left:24px;border-right:0;border-top:0}
.corners i::after{bottom:24px;right:24px;border-left:0;border-top:0}

/* ============================================================
   INTRO LOADER
   ============================================================ */
#intro{position:fixed;inset:0;z-index:11000;background:#000;
  display:flex;align-items:center;justify-content:center;flex-direction:column;}
#intro .ilogo{width:min(360px,52vw);opacity:0;transform:scale(1.08);filter:blur(8px);
  animation:introLogo 2.2s var(--ease) .3s forwards;}
@keyframes introLogo{to{opacity:1;transform:scale(1);filter:blur(0)}}
#intro .iload{position:absolute;bottom:14%;left:0;right:0;text-align:center;
  font-family:var(--mono);font-size:11px;letter-spacing:.35em;color:var(--ink-3);text-transform:uppercase;}
#intro .ibar{position:absolute;bottom:11%;left:50%;transform:translateX(-50%);
  width:min(220px,40vw);height:1px;background:var(--line);overflow:hidden}
#intro .ibar span{display:block;height:100%;width:0;background:var(--accent);transition:width .2s linear}
body.intro-done #intro{pointer-events:none}
.letterbox{position:fixed;left:0;right:0;height:0;background:#000;z-index:10500;pointer-events:none}
.letterbox.top{top:0}.letterbox.bot{bottom:0}

/* ============================================================
   NAV
   ============================================================ */
.nav{position:fixed;top:0;left:0;right:0;z-index:7000;
  display:flex;align-items:center;justify-content:space-between;
  padding:26px clamp(20px,4vw,52px);
  mix-blend-mode:difference;}
.nav .brand{display:flex;align-items:center;gap:14px;font-family:var(--serif);
  font-size:24px;font-weight:600;letter-spacing:.02em;}
.nav .brand img{height:34px;width:auto;filter:invert(1)}
.nav .brand .bt{font-family:var(--mono);font-size:9px;letter-spacing:.3em;color:var(--ink-2);
  text-transform:uppercase;align-self:center;display:block;line-height:1.2}
.nav-right{display:flex;align-items:center;gap:clamp(20px,3vw,40px)}
.nav-links{display:flex;gap:clamp(18px,2.4vw,34px)}
.nav-links a{font-size:12px;letter-spacing:.16em;text-transform:uppercase;font-weight:400;
  position:relative;padding:4px 0;opacity:.85;transition:opacity .3s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--ink);transition:width .4s var(--ease)}
.nav-links a:hover{opacity:1}.nav-links a:hover::after{width:100%}
.lang{display:flex;align-items:center;gap:7px;font-family:var(--mono);font-size:12px;letter-spacing:.1em}
.lang button{opacity:.4;transition:opacity .3s;padding:2px}
.lang button.on{opacity:1;color:var(--accent)}
.lang .sep{opacity:.3}
.burger{display:none;flex-direction:column;gap:5px;width:30px}
.burger span{height:1px;background:var(--ink);width:100%;transition:.3s}
@media(max-width:900px){
  .nav-links{display:none}
  .burger{display:flex}
}

/* mobile menu */
.mmenu{position:fixed;inset:0;z-index:6900;background:var(--bg);transform:translateY(-100%);visibility:hidden;
  transition:transform .7s var(--ease),visibility .7s;display:flex;flex-direction:column;justify-content:center;
  padding:0 8vw;gap:6px;}
.mmenu.open{transform:translateY(0);visibility:visible}
.mmenu a{font-family:var(--serif);font-size:13vw;line-height:1.05;font-weight:500}
.mmenu a span{font-family:var(--mono);font-size:11px;vertical-align:super;color:var(--accent);margin-right:12px}

/* ---------- scroll progress ---------- */
.progress{position:fixed;top:0;left:0;height:2px;width:0;background:var(--accent);z-index:7500}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;height:100svh;overflow:hidden;background:#000}
.hero-media{position:absolute;inset:-8% 0;}
.hero-media img,.hero-media canvas{position:absolute;inset:0;width:100%;height:116%;object-fit:cover;}
.hero-media img{will-change:transform}
.hero-grad{position:absolute;inset:0;z-index:2;
  background:linear-gradient(180deg,rgba(0,0,0,.45) 0%,rgba(0,0,0,.05) 26%,rgba(8,8,10,.35) 55%,rgba(8,8,10,.82) 82%,rgba(8,8,10,.98) 100%);}
.hero-inner{position:absolute;inset:0;z-index:4;display:flex;flex-direction:column;
  justify-content:flex-end;padding:0 clamp(20px,4vw,52px) clamp(60px,9vh,120px);}
.hero-kicker{font-family:var(--mono);font-size:12px;letter-spacing:.34em;text-transform:uppercase;
  color:var(--accent);margin-bottom:22px;overflow:hidden}
.hero-kicker span{display:inline-block}
.hero-title{font-family:var(--serif);font-weight:500;letter-spacing:-.01em;
  font-size:clamp(58px,12vw,200px);line-height:.9;text-transform:uppercase;text-shadow:0 2px 50px rgba(0,0,0,.5);}
.hero-title .ln{display:block;overflow:hidden}
.hero-title .ln>span,.hero-title .ln>em{display:inline-block;transform:translateY(112%)}
body.intro-done .hero-title .ln>span{animation:heroLine 1.2s var(--ease) both}
body.intro-done .hero-title .ln>em{animation:heroLine 1.2s var(--ease) .12s both}
@keyframes heroLine{from{transform:translateY(112%)}to{transform:translateY(0)}}
.hero-title em{font-style:italic;font-weight:300;color:var(--accent)}
.hero-sub{margin-top:30px;max-width:520px;font-size:16px;color:var(--ink-2);letter-spacing:.01em;
  display:flex;align-items:flex-start;gap:16px}
.hero-sub .vline{width:34px;height:1px;background:var(--accent);margin-top:11px;flex:none}
.hero-scroll{position:absolute;bottom:34px;right:clamp(20px,4vw,52px);z-index:5;
  display:flex;align-items:center;gap:12px;font-family:var(--mono);font-size:10px;letter-spacing:.25em;
  text-transform:uppercase;color:var(--ink-2);}
.hero-scroll .ln2{width:54px;height:1px;background:var(--ink-3);position:relative;overflow:hidden}
.hero-scroll .ln2::after{content:"";position:absolute;inset:0;background:var(--accent);transform:translateX(-100%);animation:scin 2.2s var(--ease) infinite}
@keyframes scin{0%{transform:translateX(-100%)}60%,100%{transform:translateX(100%)}}

/* ============================================================
   SECTION SCAFFOLD
   ============================================================ */
section{position:relative}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,4vw,52px)}
.shead{display:flex;align-items:baseline;gap:18px;margin-bottom:48px}
.sidx{font-family:var(--mono);font-size:12px;color:var(--accent);letter-spacing:.1em}
.stitle{font-family:var(--serif);font-size:clamp(34px,5.5vw,82px);font-weight:500;line-height:1;letter-spacing:-.01em}
.stitle em{font-style:italic;font-weight:300;color:var(--ink-2)}
.slabel{font-family:var(--mono);font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--ink-3)}

/* reveal util */
[data-reveal]{opacity:0;transform:translateY(38px);transition:opacity 1.1s var(--ease),transform 1.1s var(--ease)}
[data-reveal].in{opacity:1;transform:none}
[data-reveal][data-d="1"]{transition-delay:.08s}
[data-reveal][data-d="2"]{transition-delay:.16s}
[data-reveal][data-d="3"]{transition-delay:.24s}
.lineup{overflow:hidden}
.lineup>span{display:block;transform:translateY(105%);transition:transform 1s var(--ease)}
.lineup.in>span{transform:none}

/* ============================================================
   MANIFESTO
   ============================================================ */
.manifesto{padding:clamp(120px,18vh,220px) 0}
.manifesto .mtext{font-family:var(--serif);font-weight:300;font-size:clamp(28px,4.4vw,64px);
  line-height:1.18;letter-spacing:-.005em;max-width:18ch;}
.manifesto .mtext em{font-style:italic;color:var(--accent)}
.manifesto .mword{display:inline;opacity:.16;transition:opacity .5s var(--ease)}
.manifesto .mword.lit{opacity:1}
.manifesto .mmeta{margin-top:60px;display:grid;grid-template-columns:repeat(3,1fr);gap:28px;
  border-top:1px solid var(--line);padding-top:34px;max-width:760px}
.manifesto .mmeta .n{font-family:var(--serif);font-size:clamp(30px,3.6vw,52px);color:var(--accent);line-height:1}
.manifesto .mmeta .l{font-family:var(--mono);font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--ink-2);margin-top:10px}

/* ============================================================
   CHAPTER (series)
   ============================================================ */
.chapter{padding:clamp(80px,12vh,150px) 0;position:relative}
.ch-head{display:grid;grid-template-columns:1fr;gap:24px;margin-bottom:54px}
.ch-top{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;flex-wrap:wrap}
.ch-title{font-family:var(--serif);font-size:clamp(46px,9vw,150px);font-weight:500;line-height:.92;letter-spacing:-.01em;text-transform:uppercase}
.ch-title em{font-style:italic;font-weight:300;color:var(--accent)}
.ch-meta{max-width:420px}
.ch-meta p{color:var(--ink-2);font-size:15px}
.ch-tag{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:14px}

/* horizontal filmstrip (drag) */
.strip-wrap{position:relative;margin:0 calc(-1*clamp(20px,4vw,52px))}
.strip{display:flex;gap:18px;padding:0 clamp(20px,4vw,52px);overflow-x:auto;
  scroll-snap-type:x proximity;cursor:none;
  scrollbar-width:none;-ms-overflow-style:none;}
.strip::-webkit-scrollbar{display:none}
.strip.dragging{scroll-snap-type:none}
.strip-item{flex:none;scroll-snap-align:center;position:relative;overflow:hidden;background:var(--bg-2)}
.strip-item img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s var(--ease),filter 1.2s;filter:saturate(.96)}
.strip-item:hover img{transform:scale(1.05)}
.strip-item.p{width:clamp(260px,30vw,420px);aspect-ratio:2/3}
.strip-item.l{width:clamp(420px,48vw,720px);aspect-ratio:3/2}
.strip-cap{position:absolute;left:16px;bottom:16px;z-index:2;font-family:var(--mono);
  font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--ink);
  text-shadow:0 1px 12px rgba(0,0,0,.8);opacity:0;transform:translateY(8px);transition:.5s var(--ease)}
.strip-item:hover .strip-cap{opacity:1;transform:none}
.strip-cap b{color:var(--accent);font-weight:400}

/* chapter split layout (sport/military) */
.ch-split{display:grid;grid-template-columns:1.3fr .9fr;gap:22px;align-items:stretch}
.ch-split .big,.ch-split .col{position:relative;overflow:hidden}
.ch-split .big{aspect-ratio:4/5}
.ch-split .col{display:grid;gap:22px}
.ch-split .col figure{position:relative;overflow:hidden;flex:1;min-height:0}
.ch-img{position:relative;overflow:hidden;height:100%}
.ch-img img{width:100%;height:100%;object-fit:cover;transition:transform 1.6s var(--ease)}
.ch-img:hover img{transform:scale(1.06)}
.ch-fullimg{position:relative;overflow:hidden;height:clamp(60vh,80vh,900px);margin:0 calc(-1*clamp(20px,4vw,52px))}
.ch-fullimg img{position:absolute;inset:-12% 0;width:100%;height:124%;object-fit:cover;will-change:transform}
.ch-fullimg .cap-big{position:absolute;left:clamp(20px,4vw,52px);bottom:40px;z-index:3;
  font-family:var(--serif);font-style:italic;font-size:clamp(28px,4vw,56px);color:var(--ink);text-shadow:0 2px 30px rgba(0,0,0,.7)}

/* ============================================================
   MOMENTS (atmospheric, cursor reveal stack)
   ============================================================ */
.moments{padding:clamp(80px,14vh,180px) 0}
.mom-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:20px;margin-top:50px}
.mom-grid figure{position:relative;overflow:hidden}
.mom-grid figure img{width:100%;height:100%;object-fit:cover;transition:transform 1.8s var(--ease),filter 1s}
.mom-grid figure:hover img{transform:scale(1.05)}
.m1{grid-column:1/7;aspect-ratio:3/2}
.m2{grid-column:7/13;grid-row:1/3;aspect-ratio:auto}
.m3{grid-column:1/7;aspect-ratio:3/2}
.mcap{position:absolute;left:18px;bottom:16px;font-family:var(--mono);font-size:10px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink);text-shadow:0 1px 10px #000;opacity:0;transition:.5s;z-index:2}
.mom-grid figure:hover .mcap{opacity:1}

/* ============================================================
   WORK GALLERY (filterable)
   ============================================================ */
.work{padding:clamp(80px,12vh,150px) 0;background:var(--bg)}
.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:46px}
.filters button{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  padding:9px 18px;border:1px solid var(--line);border-radius:40px;color:var(--ink-2);transition:.4s var(--ease)}
.filters button:hover{border-color:var(--ink-3);color:var(--ink)}
.filters button.on{background:var(--ink);color:#000;border-color:var(--ink)}
.gallery{columns:4;column-gap:16px}
.gallery figure{break-inside:avoid;margin:0 0 16px;position:relative;overflow:hidden;background:var(--bg-2);
  opacity:0;transform:translateY(30px) scale(.98);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.gallery figure.in{opacity:1;transform:none}
.gallery figure.hide{display:none}
.gallery img{width:100%;height:auto;transition:transform 1.4s var(--ease),filter .6s;filter:grayscale(.15)}
.gallery figure:hover img{transform:scale(1.06);filter:grayscale(0)}
body.gallery-bw .gallery img{filter:grayscale(1) contrast(1.05)}
body.gallery-bw .gallery figure:hover img{filter:grayscale(.1)}
.gallery figure::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(0,0,0,.7));opacity:0;transition:.5s}
.gallery figure:hover::after{opacity:1}
.gfig-cap{position:absolute;left:16px;bottom:14px;z-index:2;opacity:0;transform:translateY(10px);transition:.5s var(--ease)}
.gallery figure:hover .gfig-cap{opacity:1;transform:none}
.gfig-cap .t{font-family:var(--serif);font-style:italic;font-size:22px;line-height:1}
.gfig-cap .c{font-family:var(--mono);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-top:6px}
@media(max-width:1100px){.gallery{columns:3}}
@media(max-width:760px){.gallery{columns:2}.mom-grid{grid-template-columns:1fr}.m1,.m2,.m3{grid-column:1/-1;grid-row:auto;aspect-ratio:3/2}}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:10800;background:rgba(4,4,6,.96);
  display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .5s}
.lightbox.open{opacity:1;pointer-events:auto}
.lightbox img{max-width:88vw;max-height:84vh;object-fit:contain;transform:scale(.96);transition:transform .6s var(--ease);box-shadow:0 40px 120px rgba(0,0,0,.7)}
.lightbox.open img{transform:scale(1)}
.lb-close{position:absolute;top:28px;right:34px;font-family:var(--mono);font-size:12px;letter-spacing:.2em;color:var(--ink-2)}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);font-family:var(--mono);font-size:12px;letter-spacing:.2em;color:var(--ink-2);padding:20px}
.lb-prev{left:24px}.lb-next{right:24px}
.lb-meta{position:absolute;bottom:26px;left:0;right:0;text-align:center;font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3)}

/* ============================================================
   SHOWREEL
   ============================================================ */
.reel{padding:clamp(80px,12vh,160px) 0}
.reel-frame{position:relative;aspect-ratio:21/9;overflow:hidden;background:#000;border:1px solid var(--line)}
.reel-frame img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.5;transition:opacity .6s,transform 6s var(--ease);filter:saturate(.9)}
.reel-frame:hover img{opacity:.62;transform:scale(1.05)}
.reel-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0;z-index:5}
.reel-bars::before,.reel-bars::after{content:"";position:absolute;left:0;right:0;height:9%;background:#000;z-index:3;pointer-events:none}
.reel-bars::before{top:0}.reel-bars::after{bottom:0}
.reel-play{position:absolute;inset:0;z-index:4;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:22px}
.reel-play .pcircle{width:clamp(78px,9vw,118px);aspect-ratio:1;border:1px solid var(--ink);border-radius:50%;
  display:flex;align-items:center;justify-content:center;transition:.5s var(--ease)}
.reel-play .pcircle svg{width:26px;height:26px;fill:var(--ink);margin-left:4px;transition:.4s}
.reel-frame:hover .pcircle{background:var(--accent);border-color:var(--accent);transform:scale(1.08)}
.reel-frame:hover .pcircle svg{fill:#000}
.reel-play .ptext{font-family:var(--mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-2)}
.reel-cap{display:flex;justify-content:space-between;flex-wrap:wrap;gap:20px;margin-top:24px;
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3)}

/* ============================================================
   SERVICES
   ============================================================ */
.services{padding:clamp(80px,12vh,160px) 0;background:var(--bg-2)}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line)}
.svc{padding:42px 30px 48px;border-bottom:1px solid var(--line);border-right:1px solid var(--line);
  position:relative;transition:background .5s}
.svc:nth-child(3n){border-right:0}
.svc:hover{background:var(--bg-3)}
.svc .num{font-family:var(--mono);font-size:11px;color:var(--accent);letter-spacing:.1em}
.svc h3{font-family:var(--serif);font-size:clamp(28px,2.8vw,42px);font-weight:500;margin:20px 0 16px;line-height:1.05}
.svc p{color:var(--ink-2);font-size:14.5px;margin-bottom:26px}
.svc ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.svc li{font-size:13px;color:var(--ink-2);display:flex;gap:11px;align-items:baseline}
.svc li::before{content:"";width:5px;height:5px;background:var(--accent);flex:none;transform:translateY(-2px)}
@media(max-width:900px){.svc-grid{grid-template-columns:1fr}.svc{border-right:0}.svc-split{grid-template-columns:1fr}}

/* ============================================================
   ABOUT
   ============================================================ */
.about{padding:clamp(90px,14vh,180px) 0}
.about-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(30px,6vw,90px);align-items:center}
.about-portrait{position:relative;overflow:hidden;aspect-ratio:3/4}
.about-portrait img{width:100%;height:100%;object-fit:cover;filter:grayscale(.2) contrast(1.05)}
.about-body h2{font-family:var(--serif);font-size:clamp(32px,4.4vw,68px);font-weight:500;line-height:1.04;letter-spacing:-.01em;margin-bottom:30px}
.about-body h2 em{font-style:italic;color:var(--accent)}
.about-body p{color:var(--ink-2);font-size:16px;max-width:54ch;margin-bottom:20px}
.about-sign{font-family:var(--serif);font-style:italic;font-size:30px;margin-top:34px;color:var(--ink)}
.about-tags{display:flex;gap:10px;flex-wrap:wrap;margin-top:30px}
.about-tags span{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;
  padding:7px 15px;border:1px solid var(--line);border-radius:30px;color:var(--ink-2)}
@media(max-width:880px){.about-grid{grid-template-columns:1fr}}

/* ============================================================
   CONTACT
   ============================================================ */
.contact{padding:clamp(90px,16vh,200px) 0 0;position:relative;overflow:hidden}
.contact-bg{position:absolute;inset:0;z-index:0;opacity:.16}
.contact-bg img{width:100%;height:100%;object-fit:cover;filter:grayscale(.3)}
.contact .wrap{position:relative;z-index:2}
.contact .cbig{font-family:var(--serif);font-size:clamp(48px,11vw,190px);font-weight:500;line-height:.92;letter-spacing:-.01em;text-transform:uppercase}
.contact .cbig em{font-style:italic;font-weight:300;color:var(--accent)}
.contact .cmail{display:inline-flex;align-items:center;gap:18px;margin-top:40px;
  font-family:var(--serif);font-size:clamp(24px,3.4vw,46px);font-style:italic;border-bottom:1px solid var(--line);padding-bottom:10px;transition:border-color .4s}
.contact .cmail:hover{border-color:var(--accent)}
.contact .cmail svg{width:30px;height:30px;stroke:var(--accent);fill:none}
.contact-socials{display:flex;gap:30px;flex-wrap:wrap;margin-top:54px;border-top:1px solid var(--line);padding-top:36px}
.contact-socials a{font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-2);transition:color .3s;display:flex;gap:8px;align-items:center}
.contact-socials a:hover{color:var(--accent)}
.contact-socials a .ar{transition:transform .3s var(--ease)}
.contact-socials a:hover .ar{transform:translate(3px,-3px)}

footer{position:relative;z-index:2;margin-top:clamp(90px,14vh,160px);border-top:1px solid var(--line);
  padding:34px clamp(20px,4vw,52px);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px;
  font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3)}
footer .ftag{display:flex;align-items:center;gap:12px}
footer img{height:26px;filter:invert(1);opacity:.7}

@media (prefers-reduced-motion: reduce){
  *{animation-duration:.001s!important;transition-duration:.1s!important}
  [data-reveal]{opacity:1;transform:none}
  .hero-title .ln>span,.hero-title .ln>em{transform:none}
}
