@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;1,300;1,400&family=Figtree:wght@300;400;500;600&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}

:root{
  --blue:#003DFF;
  --blue-dk:#0019FF;
  --ink:#000;
  --gray:#6B6B6B;
  --muted:#A8A8A2;
  --bg:#F7F6F5;
  --bg2:#EEECEA;
  --line:rgba(0,0,0,.09);
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Figtree',system-ui,sans-serif;
  --ease:cubic-bezier(.16,1,.3,1);
  --spring:cubic-bezier(.34,1.56,.64,1);
}

html,body{background:var(--bg);color:var(--ink)}
body{font-family:var(--sans);font-weight:300;-webkit-font-smoothing:antialiased;overflow-x:hidden;cursor:none}
a,button{text-decoration:none;color:inherit;cursor:none;border:0;background:none;font-family:inherit}
img{display:block;width:100%;height:100%;object-fit:cover}
::selection{background:var(--blue);color:#fff}
::-webkit-scrollbar{width:2px}
::-webkit-scrollbar-thumb{background:var(--blue)}

#sp{position:fixed;top:0;left:0;height:2px;background:var(--blue);z-index:9998;width:0%;pointer-events:none;transition:width .1s linear}

#cur{position:fixed;pointer-events:none;z-index:9999}
.cd{position:fixed;width:8px;height:8px;background:var(--blue);border-radius:50%;transform:translate(-50%,-50%);pointer-events:none;opacity:0;transition:width .15s,height .15s,opacity .3s}
.cr{position:fixed;width:36px;height:36px;border:1px solid rgba(0,61,255,.35);border-radius:50%;transform:translate(-50%,-50%);pointer-events:none;opacity:0;transition:width .4s var(--ease),height .4s var(--ease),border-color .3s,opacity .3s}
.cl{position:fixed;transform:translate(14px,14px);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--blue);pointer-events:none;opacity:0;white-space:nowrap;transition:opacity .2s;font-family:var(--sans)}
body.cur-rdy .cd,body.cur-rdy .cr{opacity:1}
body.ch .cr{width:54px;height:54px;border-color:var(--blue)}
body.ch .cl{opacity:1}
body.ck .cd{width:12px;height:12px}

#loader{position:fixed;inset:0;background:var(--bg);z-index:10000;display:flex;flex-direction:column;justify-content:flex-end;padding:52px;transition:opacity .9s var(--ease),visibility .9s}
#loader.out{opacity:0;visibility:hidden;pointer-events:none}
.lb{position:absolute;top:0;left:0;right:0;height:1px;background:var(--line)}
.lf{height:100%;background:var(--blue);width:0%}
.lw{font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(52px,7vw,96px);line-height:1;letter-spacing:-.02em}
.ln{font-size:11px;color:var(--muted);letter-spacing:.2em;margin-top:6px;font-variant-numeric:tabular-nums}

#nav{position:fixed;top:0;left:0;right:0;z-index:1000;border-bottom:1px solid transparent;transition:background .4s,border-color .4s}
#nav.on{background:rgba(247,246,245,.94);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-color:var(--line)}
.ni{position:relative;display:flex;align-items:center;justify-content:space-between;height:64px;padding:0 clamp(24px,3vw,44px)}
.nl{display:flex;align-items:center;gap:32px}
.nr{display:flex;align-items:center;gap:18px}
.nl a,.nr a{font-size:13px;font-weight:400;color:rgba(0,0,0,.72);letter-spacing:.01em;white-space:nowrap;position:relative;transition:color .2s}
.nl a:hover,.nr a:hover{color:var(--ink)}
.nl a.is-active{color:var(--blue)}
.nl a.is-active::after{content:'';position:absolute;bottom:-8px;left:50%;transform:translateX(-50%);width:5px;height:5px;border-radius:50%;background:var(--blue)}
.nlogo-wrap{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);pointer-events:auto}
.nlogo{font-family:var(--serif);font-style:italic;font-weight:300;font-size:18px;letter-spacing:.01em;color:var(--ink);white-space:nowrap;display:block;transition:opacity .2s}
.nlogo:hover{opacity:.5}
.nlogo .dot{color:var(--blue);font-style:normal}
.navail{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--blue)}
.nad{width:5px;height:5px;border-radius:50%;background:var(--blue);flex-shrink:0;animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
#clk{font-size:12px;color:rgba(0,0,0,.36)}

/* ── Language toggle ── */
.lang-btn {
  font-size: 11px; letter-spacing: .1em; font-weight: 400;
  color: var(--gray); border: 1px solid var(--line);
  border-radius: 999px; padding: 5px 11px;
  transition: color .2s, border-color .2s, background .2s;
}
.lang-btn:hover { color: var(--blue); border-color: var(--blue); }

.btn-build{background:var(--blue);color:#fff;padding:10px 22px;border-radius:999px;font-size:12px;letter-spacing:.04em;font-weight:500;border:none;white-space:nowrap;transition:background .2s,transform .15s}
.btn-build:hover{background:var(--blue-dk);transform:scale(1.04)}
.nham{display:none;flex-direction:column;gap:5px;width:36px;height:36px;padding:6px;flex-shrink:0}
.nham span{display:block;height:1px;background:var(--ink);transition:transform .3s var(--ease),opacity .25s}
.nham span:nth-child(2){width:65%}
.nham[aria-expanded="true"] span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.nham[aria-expanded="true"] span:nth-child(2){opacity:0}
.nham[aria-expanded="true"] span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
.nmob{position:fixed;top:64px;left:0;right:0;background:var(--bg);border-bottom:1px solid var(--line);padding:0 24px;max-height:0;overflow:hidden;transition:max-height .4s var(--ease);display:none;z-index:999}
.nmob.open{max-height:280px;padding:20px 24px 28px}
.nmob a{display:block;font-family:var(--serif);font-style:italic;font-weight:300;font-size:36px;color:var(--ink);padding:5px 0;border-bottom:1px solid var(--line);transition:color .2s,padding-left .3s var(--ease)}
.nmob a:hover{color:var(--blue);padding-left:8px}

.sec-label{padding:16px clamp(28px,5vw,88px);font-size:12px;font-weight:300;color:var(--gray);border-bottom:1px solid var(--line);background:var(--bg)}

.home-page #nav:not(.on) .nl a,
.home-page #nav:not(.on) .nlogo,
.home-page #nav:not(.on) #clk{color:rgba(255,255,255,.72)}
.home-page #nav:not(.on) .nl a:hover,
.home-page #nav:not(.on) .nlogo:hover{color:#fff}
.home-page #nav:not(.on) .navail{color:rgba(100,150,255,.95)}
.home-page #nav:not(.on) .nham span{background:#fff}

#hero{position:relative;width:100%;height:100vh;min-height:600px;overflow:hidden;background:#111}
.hmedia{position:absolute;inset:0}
.hmedia video,.hmedia img{
  position:absolute;inset:0;
  width:100%;height:100%;object-fit:cover;
  /* tame saturated colors so text is always readable */
  filter:saturate(.65) brightness(.88);
  transition:filter 1.5s ease,opacity .6s ease;
}
#hero-img{z-index:0;opacity:1}
#hv{z-index:1;opacity:0;background:url('assets/reel-poster.jpg') center/cover no-repeat}
#hv.is-ready{opacity:1}
#hv.is-fallback{display:none}
.hov{
  position:absolute;inset:0;
  z-index:2;
  background:
    /* main bottom-up gradient — stronger where title lives */
    linear-gradient(
      to top,
      rgba(0,0,0,.97) 0%,
      rgba(0,0,0,.82) 28%,
      rgba(0,0,0,.52) 50%,
      rgba(0,0,0,.22) 72%,
      rgba(0,0,0,.06) 88%,
      transparent 100%
    ),
    /* global tint so no color ever overpowers text */
    linear-gradient(rgba(0,0,0,.18),rgba(0,0,0,.18));
}
/* left vignette so left-edge text never bleeds */
.hov::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to right, rgba(0,0,0,.45) 0%, transparent 55%);
}
.hcontent{position:absolute;inset:0;z-index:3;display:flex;flex-direction:column;justify-content:flex-end;padding:0 24px 52px}
.heyebrow{
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:rgba(255,255,255,.6);margin-bottom:18px;
  opacity:0;transform:translateY(12px);
  transition:opacity .5s ease,transform .6s var(--ease);
  text-shadow:0 1px 12px rgba(0,0,0,.6);
}
.heyebrow.in{opacity:1;transform:none}
.heyebrow b{color:rgba(100,150,255,.95);font-weight:300}
.htitle{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(80px,13vw,210px);line-height:.86;letter-spacing:-.03em;
  color:#fff;
  /* strong shadow so text reads on any background frame */
  text-shadow:
    0 2px 32px rgba(0,0,0,.55),
    0 8px 80px rgba(0,0,0,.4),
    0 0 120px rgba(0,0,0,.3);
  opacity:0;transform:translateY(40px);
  transition:opacity .9s ease,transform 1.1s var(--ease);
}
.htitle.in{opacity:1;transform:none}
/* blue "real." — add outline so it's visible on any color */
.htitle em{
  font-style:italic;
  color:var(--blue);
  text-shadow:0 0 40px rgba(0,0,80,.6), 0 2px 24px rgba(0,0,0,.8);
}
.hfooter{display:flex;align-items:flex-end;justify-content:space-between;margin-top:24px;gap:32px;opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .8s var(--ease)}
.hfooter.in{opacity:1;transform:none}
.hdesc{
  font-size:13px;color:rgba(255,255,255,.55);line-height:1.8;max-width:340px;
  text-shadow:0 1px 12px rgba(0,0,0,.6);
}
.hcta{
  font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  color:#fff;border-bottom:1px solid rgba(255,255,255,.3);
  padding-bottom:4px;white-space:nowrap;
  text-shadow:0 1px 8px rgba(0,0,0,.5);
  transition:border-color .2s,color .2s;
}
.hcta:hover{border-color:var(--blue);color:rgba(100,150,255,.9)}
.hscroll{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);z-index:4;display:flex;flex-direction:column;align-items:center;gap:8px;opacity:0;transition:opacity .8s ease}
.hscroll.in{opacity:1}
.hsl{width:1px;height:40px;background:linear-gradient(to bottom,var(--blue),transparent);animation:sl 2s ease-in-out infinite}
@keyframes sl{0%{transform:scaleY(0);transform-origin:top;opacity:0}40%{opacity:1}70%{transform:scaleY(1);transform-origin:top}71%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom;opacity:0}}
.hscroll span{font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.28)}
.hprog{position:absolute;bottom:0;left:0;right:0;height:2px;background:rgba(255,255,255,.05);z-index:5}
.hprogf{height:100%;background:var(--blue);width:0%;transition:width .1s linear}

.page-hero{padding-top:64px}
.page-hero-media{width:100%;aspect-ratio:16/7;overflow:hidden;position:relative;background:var(--bg2)}
.page-hero-media img{width:100%;height:100%;object-fit:cover;z-index:1;position:relative;image-rendering:high-quality;-webkit-image-rendering:-webkit-optimize-contrast;transition:transform 6s ease}
.page-hero-media:hover img{transform:scale(1.04)}
.page-hero-ph{position:absolute;inset:0;z-index:0;display:flex;align-items:center;justify-content:center;font-family:var(--sans);font-size:clamp(80px,14vw,200px);font-weight:500;color:rgba(0,0,0,.05);background-image:linear-gradient(rgba(0,0,0,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.025) 1px,transparent 1px);background-size:44px 44px}
.page-hero-info{padding:56px 24px 64px;display:grid;grid-template-columns:1fr 1fr;gap:40px;border-bottom:1px solid var(--line)}
.page-title{font-family:var(--sans);font-weight:500;font-size:clamp(56px,9vw,130px);line-height:.88;letter-spacing:-.05em;color:var(--ink)}
.page-meta{display:flex;flex-direction:column;justify-content:flex-end}
.page-meta-row{display:flex;align-items:baseline;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--line);font-size:13px;transition:background .2s}
.page-meta-row:first-child{border-top:1px solid var(--line)}
.page-meta-row:hover{padding-left:8px}
.page-meta-lbl{font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.page-meta-val{color:var(--ink)}

.mq{border-bottom:1px solid var(--line);overflow:hidden;padding:12px 0;background:var(--bg)}
.mqi{display:flex;overflow:hidden}
.mq-row{display:flex;flex-shrink:0;animation:mqa 30s linear infinite}
.mq:hover .mq-row{animation-play-state:paused}
@keyframes mqa{from{transform:translateX(0)}to{transform:translateX(-100%)}}
.mq span{display:flex;align-items:center;gap:14px;padding:0 22px;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);white-space:nowrap;transition:color .2s}
.mq span:hover{color:var(--ink)}
.mq span em{width:4px;height:4px;background:var(--blue);border-radius:50%;font-style:normal;flex-shrink:0}

#work{background:var(--bg)}
.portfolio-page{margin-top:64px}
.work-head{padding:116px clamp(28px,5vw,88px) 72px;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:0}
.work-intro{max-width:min(920px,100%)}
.work-title{font-family:var(--sans);font-weight:500;font-size:clamp(76px,10.5vw,148px);line-height:.96;letter-spacing:-.035em;color:var(--ink)}
.work-copy{max-width:680px;margin-top:30px;font-size:16px;line-height:1.75;color:var(--gray);font-weight:300}
.work-filters{display:flex;align-items:center;gap:26px;flex-wrap:wrap;margin-top:42px}
.wf-lbl{font-size:13px;color:var(--muted)}
.wf-tag{font-size:13px;color:var(--muted);transition:color .2s;cursor:none}
.wf-tag.active{color:var(--blue)}
.wf-tag:hover{color:var(--ink)}
.pgrid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));border-top:0}
.portfolio-grid{margin:0 clamp(28px,5vw,88px) 104px;gap:clamp(16px,2vw,28px);background:var(--bg)}
.pcard{position:relative;overflow:hidden;aspect-ratio:3/4;display:block;border:0;background:var(--bg2);transition:opacity .35s ease,transform .35s var(--ease);--mx:0px;--my:0px;--scroll:0px}
.pcard.is-hidden{display:none}
.pcard img{position:absolute;inset:-4%;z-index:1;width:108%;height:108%;transition:transform .8s var(--ease),filter .5s;filter:saturate(.86);transform:translate3d(var(--mx),calc(var(--my) + var(--scroll)),0) scale(1)}
.pcard:hover img{transform:translate3d(var(--mx),calc(var(--my) + var(--scroll)),0) scale(1.12);filter:saturate(1.04)}
.pcard:hover{transform:translateY(-4px)}
.pcard-ov{position:absolute;inset:0;z-index:2;background:linear-gradient(to top,rgba(0,0,0,.75) 0%,transparent 55%);opacity:0;transition:opacity .4s;display:flex;flex-direction:column;justify-content:flex-end;padding:32px 28px}
.pcard:hover .pcard-ov{opacity:1}
.pcard-cat{font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:rgba(0,61,255,.9);margin-bottom:8px}
.pcard-name{font-family:var(--serif);font-style:italic;font-weight:300;font-size:36px;line-height:1;color:#fff;margin-bottom:14px}
.pcard-arrow{font-size:20px;color:rgba(255,255,255,.65);transition:transform .3s var(--ease)}
.pcard:hover .pcard-arrow{transform:translate(4px,-4px)}
.pcard-ph{position:absolute;inset:0;z-index:0;display:flex;align-items:center;justify-content:center;font-family:var(--sans);font-size:clamp(56px,8vw,96px);font-weight:500;color:rgba(0,0,0,.05);background:var(--bg2);background-image:linear-gradient(rgba(0,0,0,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.025) 1px,transparent 1px);background-size:40px 40px}

.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);border-left:1px solid var(--line)}
.gallery-grid.two-col{grid-template-columns:repeat(2,1fr)}
.gallery-item{position:relative;overflow:hidden;aspect-ratio:1;background:var(--bg2);border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
.gallery-item.tall{aspect-ratio:2/3;grid-row:span 2}
.gallery-item.wide{grid-column:span 2;aspect-ratio:2/1}
.gallery-item img{position:absolute;inset:0;z-index:1;transition:transform .8s var(--ease);width:100%;height:100%;object-fit:cover;image-rendering:high-quality;-webkit-image-rendering:-webkit-optimize-contrast}
.gallery-item:hover img{transform:scale(1.04)}
.gallery-ph{position:absolute;inset:0;z-index:0;display:flex;align-items:center;justify-content:center;font-family:var(--sans);font-size:48px;font-weight:500;color:rgba(0,0,0,.06);background:var(--bg2)}

#services{background:var(--bg)}
.sv-stmt{display:grid;grid-template-columns:1fr 1fr;gap:0;padding:96px 24px 80px;align-items:end;border-bottom:1px solid var(--line)}
.sv-stmt-txt{grid-column:2;font-family:var(--sans);font-weight:300;font-size:clamp(22px,2.8vw,38px);line-height:1.4;color:var(--ink)}
.sv-stmt-txt em{font-style:normal;color:var(--blue)}
.sv-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr))}
.sv-item{border-right:1px solid var(--line);overflow:hidden;min-width:0;display:flex;flex-direction:column;transition:background .25s}
.sv-item:last-child{border-right:0}
.sv-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:24px;border-bottom:1px solid var(--line);min-width:0}
.sv-name{font-family:var(--sans);font-weight:300;font-size:clamp(18px,1.9vw,26px);line-height:1.2;color:var(--ink);min-width:0}
.sv-toggle{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:999px;flex-shrink:0;border:1px solid var(--line);background:transparent;font-size:20px;line-height:1;color:var(--blue);transition:background .3s,border-color .3s,transform .35s var(--ease);cursor:none}
.sv-toggle::after{content:'+';display:block}
.sv-item:not(.open):hover .sv-toggle{border-color:var(--blue)}
.sv-item.open .sv-toggle{background:var(--blue);border-color:var(--blue);color:#fff}
.sv-item.open .sv-toggle::after{content:'—';font-size:13px}
.sv-content{position:relative;width:100%;aspect-ratio:1;overflow:hidden;background:var(--bg2);flex:1}
.sv-img{position:absolute;inset:0;transition:opacity .5s var(--ease)}
.sv-img img{position:absolute;inset:0;z-index:1;width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.sv-item:not(.open):hover .sv-img img{transform:scale(1.04)}
.sv-img-inner{position:absolute;inset:0;z-index:0;display:flex;align-items:center;justify-content:center;background:var(--bg2)}
.sv-glyph{font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(48px,5vw,80px);color:rgba(0,0,0,.07);letter-spacing:-.03em;user-select:none;transition:color .3s}
.sv-item:not(.open):hover .sv-glyph{color:rgba(0,61,255,.1)}
.sv-desc{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:28px 24px;opacity:0;pointer-events:none;transition:opacity .45s var(--ease);background:var(--bg)}
.sv-desc-headline{font-family:var(--sans);font-weight:300;font-size:clamp(30px,1.7vw,26px);line-height:1.3;color:var(--ink);margin-bottom:18px}
.sv-desc-headline em{font-style:normal;color:var(--blue)}
.sv-desc-body{font-size:15px;color:var(--gray);line-height:1.75;font-weight:300}
.sv-item.open .sv-img{opacity:0;pointer-events:none}
.sv-item.open .sv-desc{opacity:1;pointer-events:auto}
.sv-sub{padding:14px 24px;font-size:11px;color:var(--muted);line-height:1.6;border-top:1px solid var(--line);word-break:break-word;transition:color .3s}
.sv-item.open .sv-sub{color:var(--blue)}

#statement{background:var(--bg);border-top:1px solid var(--line);padding:140px 24px 160px;position:relative;overflow:hidden}
.stmt-bg{position:absolute;right:-1%;bottom:-6%;font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(160px,22vw,380px);line-height:1;color:rgba(0,0,0,.03);pointer-events:none;user-select:none;letter-spacing:-.04em}
.stmt{font-family:var(--sans);font-weight:300;font-size:clamp(26px,3.4vw,52px);line-height:1.42;color:var(--ink);max-width:1060px;position:relative;z-index:2}
.stmt em{font-style:normal;color:var(--blue)}
.stmt-aux{margin-top:64px;margin-left:auto;max-width:440px;display:block;font-size:13px;color:var(--gray);line-height:1.75;position:relative;z-index:2}
.stmt-aux strong{font-weight:500;color:var(--ink)}

#stats{border-top:1px solid var(--line);background:var(--bg2)}
.stgrid{display:grid;grid-template-columns:repeat(4,1fr);border-bottom:1px solid var(--line)}
.st{padding:80px 28px;border-right:1px solid var(--line);position:relative;overflow:hidden;transition:background .25s}
.st:last-child{border-right:0}
.st:hover{background:var(--bg)}
.st::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--blue);transform:scaleX(0);transition:transform .4s var(--ease)}
.st:hover::after{transform:scaleX(1)}
.stn{font-family:var(--serif);font-weight:300;font-size:clamp(64px,8vw,104px);color:var(--blue);line-height:1;margin-bottom:8px;font-variant-numeric:tabular-nums;letter-spacing:-.03em;transition:color .25s}
.st:hover .stn{color:var(--ink)}
.stl{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}

.socials-strip{border-top:1px solid var(--line);background:var(--bg)}
.socials-head{
  padding:20px 24px;
  display:flex;align-items:center;justify-content:space-between;
  border-bottom:1px solid var(--line);
}
.socials-label{
  display:flex;align-items:center;gap:12px;
  font-size:18px;font-weight:400;color:var(--ink);
}
.socials-dot{width:10px;height:10px;border-radius:50%;background:var(--blue);flex-shrink:0;animation:pulse 2s ease-in-out infinite}
.socials-link{
  font-size:12px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--blue);border-bottom:1px solid rgba(0,61,255,.3);
  padding-bottom:2px;transition:border-color .2s;
}
.socials-link:hover{border-color:var(--blue)}
.socials-scroll{display:flex;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;cursor:grab}
.socials-scroll:active{cursor:grabbing}
.socials-scroll::-webkit-scrollbar{display:none}
.socials-item{
  flex-shrink:0;
  width:calc(100vw / 6.5);min-width:140px;max-width:220px;
  aspect-ratio:1;overflow:hidden;
  border-right:1px solid var(--line);
  background:var(--bg2);position:relative;
  transition:opacity .3s;
}
.socials-item:hover{opacity:.8}
.socials-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.socials-item:hover img{transform:scale(1.06)}
.socials-ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--sans);font-size:28px;font-weight:400;color:rgba(0,0,0,.08);user-select:none}
/* ── Behold.so Instagram widget ── */
behold-widget {
  display: block;
  --behold-column-count: 6;
  --behold-gap: 1px;
  --behold-border-radius: 0px;
}
@media (max-width: 768px) {
  behold-widget { --behold-column-count: 3; }
}
@media (max-width: 480px) {
  behold-widget { --behold-column-count: 2; }
}
/* Instagram feed loading skeleton */
.socials-loading{
  background: linear-gradient(90deg, var(--bg2) 25%, var(--bg) 50%, var(--bg2) 75%);
  background-size: 200% 100%;
  animation: shimmer 1.4s infinite;
}
@keyframes shimmer{
  0%{background-position:200% 0}
  100%{background-position:-200% 0}
}
.socials-item img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .6s var(--ease), opacity .4s ease;
  opacity:0;
}
.socials-item img.loaded{ opacity:1; }


/* ══════════════════════════════════════
   FOOTER  — compact, no center object
══════════════════════════════════════ */
.footer-cta{
  background:#050505;
  display:flex;flex-direction:column;
  padding:0 24px;
}
.footer-headline{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(72px,13vw,220px);
  line-height:.86;letter-spacing:-.03em;
  color:#fff;text-align:center;
  padding:56px 0 48px;
  opacity:0;transform:translateY(32px);
  transition:opacity .9s ease,transform 1.1s var(--ease);
  display:block;
}
.footer-headline.v{opacity:1;transform:none}
.footer-headline:hover{opacity:.8}
.footer-mid{
  display:grid;grid-template-columns:1fr 1fr;
  border-top:1px solid rgba(255,255,255,.15);
}
.footer-links{display:flex;flex-direction:column;border-right:1px solid rgba(255,255,255,.15);padding-right:32px}
.footer-links a{
  font-size:13px;font-weight:300;
  color:rgba(255,255,255,.65);
  padding:14px 0;border-bottom:1px solid rgba(255,255,255,.1);
  letter-spacing:.02em;
  transition:color .2s,padding-left .3s var(--ease);
}
.footer-links a:hover{color:#fff;padding-left:10px}
.footer-clocks{display:flex;flex-direction:column;padding-left:32px;justify-content:center}
.fck{font-size:13px;color:rgba(255,255,255,.65);padding:14px 0;border-bottom:1px solid rgba(255,255,255,.1);display:flex;gap:16px;align-items:center}
.fck:last-child{border-bottom:0}
.fck span:first-child{font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.35);min-width:36px}
.footer-bar{
  background:rgba(0,0,0,.2);
  padding:18px 0;margin-top:40px;
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;
}
.footer-bar-logo{font-family:var(--serif);font-style:italic;font-weight:300;font-size:17px;color:rgba(255,255,255,.55)}
.footer-bar-logo .dot{color:var(--blue);font-style:normal}
.footer-bar-copy{font-size:10px;color:rgba(255,255,255,.3);text-align:center}
.footer-bar-nav{display:flex;gap:20px;justify-content:flex-end}
.footer-bar-nav a{font-size:10px;color:rgba(255,255,255,.35);letter-spacing:.12em;text-transform:uppercase;transition:color .2s}
.footer-bar-nav a:hover{color:rgba(255,255,255,.8)}

.drawer-overlay{position:fixed;inset:0;z-index:2000;background:rgba(0,0,0,.28);opacity:0;pointer-events:none;transition:opacity .4s ease;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px)}
.drawer-overlay.open{opacity:1;pointer-events:auto}
.drawer{position:fixed;top:0;right:0;bottom:0;width:min(640px,94vw);background:#fff;border-radius:12px 0 0 12px;z-index:2001;transform:translateX(100%);transition:transform .52s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column;overflow:hidden;box-shadow:-8px 0 60px rgba(0,0,0,.12)}
.drawer.open{transform:translateX(0)}
.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid rgba(0,0,0,.08);flex-shrink:0}
.drawer-title{font-size:14px;font-weight:400;color:#000}
.drawer-close{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:1px solid rgba(0,0,0,.14);font-size:15px;color:#000;line-height:1;transition:background .2s}
.drawer-close:hover{background:rgba(0,0,0,.06)}
.drawer-warn{padding:9px 24px;font-size:11px;color:rgba(0,0,0,.38);border-bottom:1px solid rgba(0,0,0,.06);flex-shrink:0}
.drawer-body{flex:1;overflow-y:auto;padding:40px 32px 56px;scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.12) transparent}
.drawer-body::-webkit-scrollbar{width:3px}
.drawer-body::-webkit-scrollbar-thumb{background:rgba(0,0,0,.12)}
.df-headline{font-size:clamp(22px,3.5vw,34px);font-weight:600;line-height:1.1;letter-spacing:-.02em;color:#000;margin-bottom:12px;text-transform:uppercase}
.df-headline em{font-style:normal;color:var(--blue)}
.df-sub{font-size:13px;color:rgba(0,0,0,.45);line-height:1.65;margin-bottom:36px;font-weight:300}
.df-field{margin-bottom:18px}
.df-label{font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:rgba(0,0,0,.38);margin-bottom:7px;display:flex;gap:4px}
.df-req{color:var(--blue)}
.df-input,.df-textarea,.df-select{width:100%;border:1px solid rgba(0,0,0,.14);border-radius:6px;padding:13px 14px;font-size:13px;color:#000;font-family:var(--sans);font-weight:300;background:#fff;outline:none;transition:border-color .2s}
.df-input:focus,.df-textarea:focus,.df-select:focus{border-color:var(--blue)}
.df-input::placeholder,.df-textarea::placeholder{color:rgba(0,0,0,.25)}
.df-textarea{resize:none;min-height:96px}
.df-select{appearance:none;-webkit-appearance:none;cursor:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23999' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}
.df-phone-row{display:flex;gap:8px}
.df-country{display:flex;align-items:center;gap:6px;border:1px solid rgba(0,0,0,.14);border-radius:6px;padding:0 12px;background:#fff;flex-shrink:0;min-width:96px}
.df-country select{border:none;background:transparent;outline:none;font-size:12px;color:#000;cursor:none;padding:13px 0;font-family:var(--sans)}
.df-services-lbl{font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:rgba(0,0,0,.38);margin-bottom:4px;display:flex;gap:4px}
.df-svc-item{display:flex;align-items:flex-start;gap:16px;padding:18px 0;border-bottom:1px solid rgba(0,0,0,.07);cursor:none;transition:background .15s}
.df-svc-item:first-of-type{border-top:1px solid rgba(0,0,0,.07)}
.df-svc-item:hover{background:rgba(0,61,255,.02)}
.df-radio-btn{width:20px;height:20px;border-radius:50%;border:1.5px solid rgba(0,0,0,.2);flex-shrink:0;margin-top:2px;transition:border-color .2s,border-width .15s}
.df-radio-btn.on{border-color:var(--blue);border-width:6px}
.df-svc-name{font-size:15px;font-weight:500;color:#000;margin-bottom:5px;letter-spacing:-.01em}
.df-svc-desc{font-size:12px;color:rgba(0,0,0,.48);line-height:1.65;margin-bottom:6px;font-weight:300}
.df-svc-price{font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--blue)}
.df-send{display:inline-flex;align-items:center;justify-content:center;min-width:140px;height:52px;border-radius:999px;background:#000;color:#fff;font-size:12px;letter-spacing:.1em;text-transform:uppercase;font-weight:500;border:none;margin-top:28px;transition:background .2s,transform .15s;cursor:none;font-family:var(--sans);padding:0 28px}
.df-send:hover{background:#222;transform:scale(1.03)}
.df-ok{font-size:12px;color:var(--blue);margin-top:14px;letter-spacing:.06em;display:none;font-weight:300}
.df-ok.on{display:block}

.rv{opacity:0;transform:translateY(28px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.rv.v{opacity:1;transform:none}

@media(max-width:1100px){
  .sv-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .sv-item:nth-child(2){border-right:0}
  .sv-item:nth-child(3),.sv-item:nth-child(4){border-top:1px solid var(--line)}
  .sv-item:nth-child(4){border-right:0}
  .sv-content{aspect-ratio:4/3}
  .stgrid{grid-template-columns:1fr 1fr}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-item.wide{grid-column:span 2}
}
@media(max-width:768px){
  .nl{display:none}
  #clk{display:none}
  .navail{display:none}
  .nham{display:flex}
  .nmob{display:block}
  .ni{height:60px;padding:0 16px;gap:12px}
  .nlogo-wrap{position:static;left:auto;top:auto;transform:none;flex:0 1 auto;min-width:0}
  .nlogo{font-size:18px}
  .nr{gap:8px;margin-left:auto;min-width:0}
  .nmob{top:60px}
  .hcontent{padding:0 20px 40px}
  .htitle{font-size:clamp(64px,16vw,110px)}
  .hfooter{flex-direction:column;align-items:flex-start;gap:16px;margin-top:16px}
  .portfolio-page{margin-top:64px}
  .work-head{flex-direction:column;align-items:flex-start;padding:72px 24px 48px}
  .work-copy{font-size:15px;margin-top:22px}
  .work-filters{gap:18px;margin-top:32px}
  .pgrid{grid-template-columns:1fr}
  .portfolio-grid{margin:0 24px 72px;gap:18px}
  .pcard{border-right:0;border-bottom:1px solid var(--line);aspect-ratio:4/3}
  .pcard:last-child{border-bottom:0}
  .sv-stmt{grid-template-columns:1fr;padding:52px 20px 44px}
  .sv-stmt-txt{grid-column:1;font-size:clamp(20px,5vw,28px)}
  .sv-grid{grid-template-columns:minmax(0,1fr)}
  .sv-item{border-right:0;border-top:1px solid var(--line)}
  .sv-item:first-child{border-top:0}
  .sv-content{aspect-ratio:4/3}
  #statement{padding:80px 20px 100px}
  .stmt{font-size:clamp(20px,5vw,32px)}
  .stmt-aux{margin-left:0;max-width:100%;margin-top:40px}
  .stgrid{grid-template-columns:1fr 1fr}
  .st{padding:52px 20px}
  .socials-item{width:calc(100vw / 2.2);min-width:140px;max-width:220px}
  .footer-mid{grid-template-columns:1fr;gap:0}
  .footer-links{border-right:0;border-bottom:1px solid rgba(255,255,255,.15)}
  .footer-clocks{padding-left:0;padding-top:8px}
  .footer-bar{grid-template-columns:1fr;gap:10px;text-align:center;padding:16px 20px}
  .footer-bar-nav{justify-content:center}
  .footer-arr{display:none}
  .page-hero-info{grid-template-columns:1fr;padding:40px 20px 48px}
  .gallery-grid{grid-template-columns:1fr}
  .gallery-item.wide,.gallery-item.tall{grid-column:span 1;grid-row:span 1;aspect-ratio:4/3}
  .sec-label{padding:13px 20px}
  .drawer-body{padding:32px 20px 48px}
}
@media(max-width:480px){
  .stgrid{grid-template-columns:1fr 1fr}
  .work-title{font-size:clamp(58px,18vw,92px)}
  .drawer{width:100vw;border-radius:0}
  .ni{padding:0 12px}
  .btn-build{font-size:10px;padding:8px 12px;letter-spacing:.02em}
  .nlogo{font-size:17px}
  .nham{width:32px;height:32px;padding:6px 4px}
}
@media(max-width:360px){
  .stgrid{grid-template-columns:1fr}
  .pgrid{grid-template-columns:1fr}
  .btn-build{font-size:9px;padding:7px 10px}
  .nlogo{font-size:16px}
}
@media (pointer:coarse){
  body,a,button,.wf-tag,.sv-toggle,.df-select,.df-country select,.df-svc-item,.df-send{cursor:auto}
  #cur{display:none}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}
}
