:root{
  --bg:#050608;
  --bg-soft:#090b0f;
  --panel:#0d1016;
  --text:#f4f2ec;
  --muted:rgba(244,242,236,.62);
  --faint:rgba(244,242,236,.34);
  --line:rgba(244,242,236,.12);
  --line-strong:rgba(244,242,236,.24);
  --accent:#bfc7d7;
  --sans:'Inter Tight', system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
  --serif:'Instrument Serif', Georgia, serif;
  --mono:'IBM Plex Mono', monospace;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--text);font-family:var(--sans);overflow-x:hidden;cursor:none}
a,button,input,select,textarea{font:inherit}
a{color:inherit;text-decoration:none;cursor:none}
img{display:block;max-width:100%}
button{cursor:none}
.mono{font-family:var(--mono);font-size:11px;line-height:1.4;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.noise{position:fixed;inset:0;z-index:80;pointer-events:none;opacity:.10;background-image:radial-gradient(rgba(255,255,255,.7) .45px,transparent .45px);background-size:3px 3px;mix-blend-mode:overlay}
.page-grid{position:fixed;inset:0;z-index:-2;pointer-events:none;background-image:linear-gradient(to right,rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(to bottom,rgba(255,255,255,.026) 1px,transparent 1px);background-size:84px 84px;mask-image:linear-gradient(to bottom,rgba(0,0,0,.8),rgba(0,0,0,.24) 75%,transparent)}
.cursor-dot{position:fixed;left:0;top:0;width:14px;height:14px;border:1px solid rgba(244,242,236,.72);border-radius:50%;z-index:100;pointer-events:none;transform:translate(-50%,-50%);transition:width .22s ease,height .22s ease,border-color .22s ease,background .22s ease,opacity .22s ease;mix-blend-mode:difference}.cursor-dot.is-hover{width:34px;height:34px;background:rgba(244,242,236,.08);border-color:rgba(244,242,236,.95)}
.site-header{position:fixed;top:22px;left:24px;right:24px;height:58px;z-index:60;display:flex;align-items:center;justify-content:space-between;padding:0 20px;border:1px solid var(--line);background:rgba(5,6,8,.62);backdrop-filter:blur(18px);border-radius:999px}.brand{display:flex;align-items:center;gap:12px;font-weight:800;font-size:13px;letter-spacing:.12em}.brand-mark{display:grid;place-items:center;width:24px;height:24px;border:1px solid var(--line-strong);border-radius:50%;font-family:var(--mono);font-size:10px;color:var(--accent)}nav{display:flex;align-items:center;gap:26px}nav a{font-size:13px;color:var(--muted);transition:color .25s ease}nav a:hover{color:var(--text)}
.side-index{position:fixed;left:24px;top:50%;z-index:40;transform:translateY(-50%);display:grid;gap:16px}.side-index span{writing-mode:vertical-rl;font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:rgba(244,242,236,.28)}
.hero{min-height:100vh;position:relative;padding:130px 28px 30px;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden;border-bottom:1px solid var(--line)}.hero-gradient{position:absolute;inset:-18%;z-index:-1;background:radial-gradient(circle at 18% 18%,rgba(217,226,240,.20),transparent 26%),radial-gradient(circle at 72% 36%,rgba(91,103,126,.28),transparent 30%),radial-gradient(circle at 48% 86%,rgba(130,119,107,.13),transparent 36%);filter:blur(34px);animation:gradientDrift 17s ease-in-out infinite alternate;opacity:.86}.hero:after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(to bottom,rgba(5,6,8,.14),rgba(5,6,8,.88) 80%,rgba(5,6,8,1))}.hero-topline{display:flex;justify-content:space-between;gap:20px;border-bottom:1px solid var(--line);padding-bottom:18px}.hero-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(260px,410px);gap:clamp(28px,5vw,90px);align-items:end}.hero h1{margin:0;max-width:1120px;font-size:clamp(72px,11vw,178px);line-height:.82;letter-spacing:-.083em;font-weight:900;text-wrap:balance}.hero-note{border-left:1px solid var(--line);padding-left:24px;margin-bottom:8px}.hero-note p{margin:0 0 28px;color:var(--muted);font-size:clamp(18px,1.55vw,26px);line-height:1.15;max-width:390px}.inline-link{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--text);padding-bottom:6px;border-bottom:1px solid var(--line-strong)}.inline-link:hover{color:var(--accent)}
@keyframes gradientDrift{0%{transform:translate3d(-2%,-1%,0) scale(1)}100%{transform:translate3d(4%,2%,0) scale(1.08)}}
section{position:relative;padding:104px 28px}.section-label{display:flex;justify-content:space-between;gap:18px;border-bottom:1px solid var(--line);padding-bottom:18px;margin-bottom:34px}.work-section h2,.studio h2,.workflows h2,.contact h2{margin:0;letter-spacing:-.065em;font-weight:850}.work-section h2{font-size:clamp(46px,8vw,118px);line-height:.86;margin-bottom:60px}.work-index{border-top:1px solid var(--line)}.work-line{position:relative;min-height:116px;display:grid;grid-template-columns:74px minmax(230px,.9fr) minmax(260px,1fr) 150px;align-items:center;gap:26px;border-bottom:1px solid var(--line);transition:background .25s ease,border-color .25s ease,padding .25s ease}.work-line:before{content:"";position:absolute;left:0;top:0;bottom:0;width:0;background:rgba(244,242,236,.04);transition:width .26s ease}.work-line:hover:before{width:100%}.work-line:hover{border-color:var(--line-strong);padding-left:10px}.line-title{position:relative;font-size:clamp(34px,4.8vw,70px);line-height:.92;font-weight:850;letter-spacing:-.055em}.line-type{position:relative;color:var(--muted);font-size:18px}.line-action{position:relative;justify-self:end;color:var(--faint)}.work-line:hover .line-action,.work-line:hover .line-type{color:var(--text)}.hover-stage{margin-top:34px;border:1px solid var(--line);height:clamp(280px,52vw,760px);background:rgba(255,255,255,.025);position:relative;overflow:hidden}.hover-stage:before{content:"PREVIEW / SELECTED PROJECT";position:absolute;top:18px;left:18px;z-index:2;font-family:var(--mono);font-size:10px;letter-spacing:.12em;color:rgba(244,242,236,.52)}.preview-img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;padding:52px 22px 22px;background:#07080b;opacity:0;transform:scale(.985);transition:opacity .42s ease,transform .7s cubic-bezier(.16,1,.3,1)}.preview-img.active{opacity:1;transform:scale(1)}
.project-strip{padding-top:0}.project-item{display:grid;grid-template-columns:minmax(260px,400px) minmax(0,1fr);gap:54px;align-items:start;padding:76px 0;border-top:1px solid var(--line)}.project-copy{position:sticky;top:112px}.project-copy h3{margin:18px 0 18px;font-size:clamp(30px,4vw,60px);line-height:.9;letter-spacing:-.055em}.project-copy p{margin:0 0 26px;color:var(--muted);font-size:18px;line-height:1.3}.project-copy a{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;border-bottom:1px solid var(--line-strong);padding-bottom:5px}.project-screen{margin:0;border:1px solid var(--line);background:#06070a;padding:12px;min-height:330px;display:flex;align-items:center}.project-screen img{width:100%;height:auto;object-fit:contain;background:#050608;transition:filter .45s ease}.project-screen:hover{border-color:var(--line-strong)}.project-screen:hover img{filter:brightness(1.05)}
.studio,.workflows,.contact{border-top:1px solid var(--line)}.studio-grid,.workflow-grid{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(280px,.7fr);gap:58px;align-items:start}.studio h2,.workflows h2{font-size:clamp(44px,7vw,110px);line-height:.86;max-width:940px}.studio-text,.workflow-grid p{color:var(--muted);font-size:clamp(20px,2.1vw,34px);line-height:1.12}.studio-text p{margin:0 0 28px}.workflows{background:linear-gradient(135deg,rgba(255,255,255,.04),transparent)}.workflow-grid p{align-self:end;margin:0}.contact{display:grid;grid-template-columns:minmax(0,.85fr) minmax(330px,1fr);gap:64px}.contact h2{font-size:clamp(50px,7vw,120px);line-height:.82;margin-top:18px}.contact-copy p{max-width:440px;color:var(--muted);font-size:19px;line-height:1.35}.mail{display:inline-block;margin-top:18px;color:var(--accent);border-bottom:1px solid var(--line-strong);padding-bottom:6px}.contact-form{display:grid;gap:0;border-top:1px solid var(--line)}label{display:grid;gap:10px;padding:18px 0;border-bottom:1px solid var(--line);font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}input,select,textarea{width:100%;border:0;background:transparent;color:var(--text);outline:0;font:500 20px var(--sans);padding:6px 0 2px}input::placeholder,textarea::placeholder{color:rgba(244,242,236,.24)}select{appearance:none;color:var(--text)}textarea{resize:vertical;min-height:130px}button{justify-self:start;margin-top:24px;border:1px solid var(--line-strong);background:var(--text);color:#050608;border-radius:999px;padding:15px 24px;font:800 13px var(--sans);letter-spacing:.02em;transition:transform .2s ease,background .2s ease}button:hover{transform:translateY(-2px);background:var(--accent)}footer{display:flex;justify-content:space-between;gap:20px;padding:26px 28px;border-top:1px solid var(--line);color:var(--muted)}
.reveal{opacity:0;transform:translateY(22px);transition:opacity .75s ease,transform .75s cubic-bezier(.16,1,.3,1)}.reveal.visible{opacity:1;transform:translateY(0)}
@media(max-width:1000px){body{cursor:auto}a,button{cursor:pointer}.cursor-dot{display:none}.side-index{display:none}.site-header{left:14px;right:14px;top:14px}.site-header nav{gap:14px}.hero{padding:112px 18px 28px}.hero-layout,.studio-grid,.workflow-grid,.contact,.project-item{grid-template-columns:1fr}.hero h1{font-size:clamp(70px,18vw,132px);line-height:.84}.hero-note{border-left:0;border-top:1px solid var(--line);padding:18px 0 0}.work-line{grid-template-columns:48px 1fr;gap:12px;padding:24px 0}.line-title{font-size:42px}.line-type,.line-action{grid-column:2}.line-action{justify-self:start}.hover-stage{height:58vw;min-height:250px}.project-copy{position:static}.project-item{gap:26px}.project-screen{min-height:0}section{padding:78px 18px}.section-label{flex-direction:column}.site-header nav a:nth-child(2),.site-header nav a:nth-child(3){display:none}}
@media(max-width:560px){.brand span:last-child{font-size:12px}.site-header{height:54px}.hero-topline{flex-direction:column}.hero h1{font-size:clamp(60px,20vw,96px);letter-spacing:-.088em}.work-section h2{font-size:58px}.preview-img{padding:42px 10px 10px}.contact h2{font-size:62px}input,select,textarea{font-size:18px}}


/* v5 refinements */
.hero h1{
  max-width:1040px;
  font-size:clamp(72px,9.3vw,156px);
  line-height:.88;
  letter-spacing:-.055em;
  font-weight:900;
}
.hero-layout{
  grid-template-columns:minmax(0,1fr) minmax(280px,420px);
  align-items:end;
}
.hero-note p{line-height:1.22;}

.work-index-v3{border-top:1px solid var(--line);}
.section-head-v3{display:grid;grid-template-columns:240px 1fr;gap:40px;margin-bottom:38px;}
.section-head-v3 h2{margin:0;max-width:850px;font-size:clamp(36px,5vw,84px);line-height:.92;letter-spacing:-.045em;font-weight:800;}
.work-list-v3{border-top:1px solid var(--line);}
.work-row-v3{position:relative;display:grid;grid-template-columns:80px 1.2fr 1fr 150px;gap:24px;align-items:center;min-height:108px;border-bottom:1px solid var(--line);padding:28px 0;transition:background .25s ease, padding .25s ease, border-color .25s ease;}
.work-row-v3:hover{background:rgba(255,255,255,.025);border-color:var(--line-strong);padding-left:8px;}
.work-title-v3{font-size:clamp(38px,5vw,76px);letter-spacing:-.045em;font-weight:800;line-height:.95;}
.work-type-v3{color:var(--muted);font-size:18px;}
.work-year{justify-self:end;text-align:right;}
.row-preview-v3{pointer-events:none;position:absolute;right:130px;top:50%;width:min(460px,33vw);aspect-ratio:16/9;border:1px solid var(--line);background:#050506;padding:8px;opacity:0;transform:translateY(-46%) scale(.97);transition:opacity .35s ease,transform .35s ease;z-index:5;box-shadow:0 24px 80px rgba(0,0,0,.55);}
.row-preview-v3 img{width:100%;height:100%;object-fit:cover;object-position:center;background:#0b0b0c;}
.work-row-v3:hover .row-preview-v3{opacity:1;transform:translateY(-50%) scale(1);}

.showcase-v3{padding-top:20px;}
.project-card-v3{display:grid;grid-template-columns:360px 1fr;gap:56px;align-items:start;border-top:1px solid var(--line);padding:70px 0;}
.project-card-v3.reverse{grid-template-columns:1fr 360px;}
.project-card-v3.reverse .project-meta-v3{order:2;}
.project-card-v3.reverse .screen-v3{order:1;}
.project-meta-v3{position:sticky;top:110px;}
.project-meta-v3 h3{font-family:var(--serif);font-size:clamp(34px,4.2vw,72px);font-weight:400;line-height:1;letter-spacing:-.02em;margin:18px 0 16px;}
.project-meta-v3 p{margin:0 0 24px;color:var(--muted);font-size:18px;line-height:1.35;}
.project-meta-v3 a{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.08em;border-bottom:1px solid var(--faint);padding-bottom:4px;}
.screen-v3{border:1px solid var(--line);background:#0c0d10;padding:12px;}
.screen-v3 img{width:100%;height:auto;object-fit:contain;background:#111;}
.screen-v3:hover{border-color:rgba(255,255,255,.28);}

select{color:var(--text);background:#0a0b0d;}
select option{background:#0a0b0d;color:#f4f2ec;}

@media(max-width:1000px){
  .hero h1{font-size:clamp(58px,16vw,116px);line-height:.9;letter-spacing:-.05em;}
  .section-head-v3{grid-template-columns:1fr;gap:14px;}
  .work-row-v3{grid-template-columns:44px 1fr;gap:14px;}
  .work-type-v3,.work-year{grid-column:2;}
  .work-year{justify-self:start;text-align:left;}
  .row-preview-v3{display:none;}
  .project-card-v3,.project-card-v3.reverse{grid-template-columns:1fr;gap:26px;}
  .project-card-v3.reverse .project-meta-v3,.project-card-v3.reverse .screen-v3{order:initial;}
  .project-meta-v3{position:static;}
  .work-title-v3{font-size:42px;}
}
@media(max-width:560px){
  .hero h1{font-size:clamp(54px,18vw,90px);}
  .project-meta-v3 h3{font-size:42px;}
  .work-row-v3{min-height:130px;}
}

/* v7 focused fixes */
.hero h1{
  max-width:980px;
  font-size:clamp(58px,8.2vw,132px);
  line-height:.94;
  letter-spacing:-.038em;
  word-spacing:.02em;
  text-wrap:balance;
}
.hero-layout{
  gap:clamp(28px,5vw,78px);
  align-items:end;
}
.hero-note{
  max-width:440px;
}
.hero-note p{
  font-size:clamp(16px,1.28vw,22px);
  line-height:1.36;
}
.section-head-v3 h2{
  letter-spacing:-.032em;
  line-height:1;
  max-width:900px;
}
.work-title-v3{
  letter-spacing:-.028em;
}
.project-card-v3{
  grid-template-columns:minmax(250px,330px) minmax(0,1fr);
  gap:clamp(34px,4vw,68px);
}
.project-card-v3.reverse{
  grid-template-columns:minmax(0,1fr) minmax(250px,330px);
}
.project-meta-v3{
  padding-top:6px;
}
.project-meta-v3 h3{
  font-family:var(--sans);
  font-size:clamp(28px,3.4vw,54px);
  line-height:1.02;
  letter-spacing:-.035em;
  font-weight:800;
  max-width:320px;
}
.project-meta-v3 p{
  max-width:300px;
  font-size:16px;
  line-height:1.48;
}
.screen-v3{
  overflow:hidden;
}
.screen-v3 img{
  display:block;
  width:100%;
  height:auto;
  object-fit:contain;
}
select,
select:focus{
  color:#f4f2ec;
  background-color:#090b0f;
}
select option{
  color:#f4f2ec;
  background-color:#090b0f;
}
@media(max-width:1000px){
  .hero h1{font-size:clamp(52px,14vw,102px);line-height:.98;letter-spacing:-.035em;}
  .project-card-v3,.project-card-v3.reverse{grid-template-columns:1fr;}
  .project-meta-v3 h3,.project-meta-v3 p{max-width:none;}
}
@media(max-width:560px){
  .hero h1{font-size:clamp(46px,16vw,76px);line-height:1;letter-spacing:-.028em;}
  .project-meta-v3 h3{font-size:34px;}
}


/* v13 project screenshot galleries */
.project-visual-v3{
  min-width:0;
}
.project-card-v3.reverse .project-visual-v3{
  order:1;
}
.project-card-v3.reverse .project-meta-v3{
  order:2;
}
.project-gallery-v3{
  margin-top:14px;
  overflow:hidden;
  border:1px solid var(--line);
  background:#06070a;
  padding:12px;
}
.project-gallery-track{
  display:flex;
  gap:12px;
  width:max-content;
  will-change:transform;
  animation:galleryLoop 58s linear infinite;
}
.gallery-shot{
  flex:0 0 auto;
  width:clamp(280px,34vw,620px);
  aspect-ratio:16/9;
  margin:0;
  border:1px solid rgba(244,242,236,.10);
  background:#0a0b0f;
  overflow:hidden;
}
.gallery-shot img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  filter:brightness(.94);
  transition:none;
}
.gallery-shot:hover img{
  filter:brightness(.94);
}
@keyframes galleryLoop{
  from{transform:translate3d(0,0,0)}
  to{transform:translate3d(calc(-50% - 6px),0,0)}
}
@media(max-width:1000px){
  .project-card-v3.reverse .project-meta-v3,.project-card-v3.reverse .project-visual-v3{order:initial;}
  .project-gallery-v3{
    overflow-x:auto;
    overscroll-behavior-x:contain;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
  }
  .project-gallery-v3::-webkit-scrollbar{display:none;}
  .project-gallery-track{
    animation:none;
  }
  .gallery-shot{
    width:min(82vw,520px);
    scroll-snap-align:start;
  }
}

/* v15 mobile refinements + workflow type polish */
@media (min-width:1001px){
  .workflows h2{
    font-size:clamp(42px,6.2vw,96px);
    line-height:.92;
    letter-spacing:-.042em;
    max-width:1040px;
  }
}

@media (max-width:1000px){
  .hero{
    min-height:auto;
    display:block;
    padding:112px 18px 70px;
  }
  .hero-layout{
    display:block;
  }
  .hero h1{
    max-width:100%;
    margin-top:clamp(190px,38vh,330px);
    font-size:clamp(52px,16.4vw,88px);
    line-height:1.02;
    letter-spacing:-.035em;
    text-wrap:balance;
  }
  .hero-note{
    margin-top:24px;
    padding-top:20px;
    border-top:1px solid var(--line);
    border-left:0;
    padding-left:0;
    max-width:100%;
    position:relative;
    z-index:1;
  }
  .hero-note p{
    max-width:92%;
    font-size:17px;
    line-height:1.38;
  }

  .work-list-v3{
    display:flex;
    overflow-x:auto;
    gap:14px;
    border-top:0;
    scroll-snap-type:x mandatory;
    overscroll-behavior-x:contain;
    -webkit-overflow-scrolling:touch;
    padding:0 18px 16px 0;
    margin-right:-18px;
  }
  .work-list-v3::-webkit-scrollbar{display:none;}
  .work-row-v3{
    flex:0 0 min(82vw,420px);
    display:grid;
    grid-template-columns:1fr;
    align-content:start;
    gap:14px;
    min-height:0;
    padding:22px 18px 18px;
    border:1px solid var(--line);
    background:rgba(255,255,255,.018);
    scroll-snap-align:start;
  }
  .work-row-v3:hover{
    padding-left:18px;
  }
  .work-no,
  .work-title-v3,
  .work-type-v3,
  .work-year{
    grid-column:auto;
  }
  .work-no{order:1;}
  .work-title-v3{order:2;font-size:clamp(42px,13vw,72px);line-height:.9;}
  .work-type-v3{order:3;font-size:18px;line-height:1.25;}
  .work-year{order:4;justify-self:start;text-align:left;}
  .row-preview-v3{
    display:block;
    order:5;
    position:relative;
    inset:auto;
    right:auto;
    top:auto;
    width:100%;
    aspect-ratio:16/10;
    margin-top:8px;
    opacity:1;
    transform:none;
    padding:7px;
    box-shadow:none;
  }
  .work-row-v3:hover .row-preview-v3{
    opacity:1;
    transform:none;
  }
  .row-preview-v3 img{
    object-fit:cover;
  }

  .project-gallery-v3{
    overflow:hidden;
    scroll-snap-type:none;
  }
  .project-gallery-track{
    animation:galleryLoop 48s linear infinite;
    will-change:transform;
  }
  .gallery-shot{
    width:min(84vw,520px);
    scroll-snap-align:none;
  }
}

@media (max-width:560px){
  .hero h1{
    margin-top:clamp(180px,36vh,300px);
    font-size:clamp(50px,15.8vw,76px);
    line-height:1.03;
    letter-spacing:-.028em;
  }
  .hero-note p{
    font-size:16px;
    line-height:1.42;
  }
  .section-head-v3 h2{
    font-size:clamp(44px,13.5vw,64px);
    line-height:1.02;
  }
  .work-title-v3{
    font-size:clamp(40px,12vw,62px);
  }
}

/* v18 mobile work reveal: true left-drag reveal */
@media (max-width:1000px){
  .work-list-v3{
    display:block;
    overflow:visible;
    border-top:1px solid var(--line);
    padding:0;
    margin:0;
  }
  .work-row-v3{
    position:relative;
    display:grid;
    grid-template-columns:44px minmax(0,1fr);
    gap:12px 18px;
    align-items:center;
    min-height:164px;
    padding:30px 0;
    border:0;
    border-bottom:1px solid var(--line);
    background:transparent;
    overflow:hidden;
    scroll-snap-align:none;
    touch-action:pan-y;
    -webkit-tap-highlight-color:transparent;
    --reveal-progress:0;
    --preview-x:108%;
    --text-x:0px;
    --text-opacity:1;
  }
  .work-row-v3:hover{
    background:transparent;
    border-color:var(--line);
    padding-left:0;
  }
  .work-row-v3.is-revealing{
    border-color:rgba(244,242,236,.20);
  }
  .work-row-v3::after{
    content:"";
    position:absolute;
    inset:0;
    z-index:1;
    pointer-events:none;
    opacity:0;
    background:linear-gradient(90deg,
      rgba(5,6,8,.98) 0%,
      rgba(5,6,8,.88) 35%,
      rgba(5,6,8,.40) 68%,
      rgba(5,6,8,.04) 100%);
    transition:opacity .28s cubic-bezier(.16,1,.3,1);
  }
  .work-row-v3.is-revealing::after{
    opacity:calc(var(--reveal-progress) * .72);
  }
  .work-row-v3.is-dragging::after{transition:none;}
  .work-row-v3 > span:not(.row-preview-v3){
    position:relative;
    z-index:2;
    transform:translateX(var(--text-x));
    opacity:var(--text-opacity);
    transition:transform .32s cubic-bezier(.16,1,.3,1), opacity .28s ease;
  }
  .work-row-v3.is-dragging > span:not(.row-preview-v3){
    transition:none;
  }
  .work-no{
    grid-column:1;
    grid-row:1 / span 4;
    align-self:start;
    padding-top:8px;
  }
  .work-title-v3{
    grid-column:2;
    order:initial;
    font-size:clamp(48px,13vw,72px);
    line-height:.92;
  }
  .work-type-v3{
    grid-column:2;
    order:initial;
    font-size:clamp(19px,5vw,28px);
    line-height:1.18;
    color:rgba(244,242,236,.58);
  }
  .work-year{
    grid-column:2;
    order:initial;
    justify-self:start;
    text-align:left;
    margin-top:4px;
  }
  .row-preview-v3{
    display:block;
    pointer-events:none;
    position:absolute;
    right:0;
    top:50%;
    width:min(78vw,520px);
    height:calc(100% - 24px);
    aspect-ratio:auto;
    margin:0;
    padding:8px;
    border:1px solid rgba(244,242,236,.18);
    background:#050608;
    opacity:0;
    transform:translate(var(--preview-x), -50%) scale(.985);
    transition:opacity .28s ease, transform .32s cubic-bezier(.16,1,.3,1);
    box-shadow:0 22px 70px rgba(0,0,0,.54);
    z-index:3;
  }
  .work-row-v3.is-revealing .row-preview-v3{
    opacity:calc(var(--reveal-progress) * 1);
  }
  .work-row-v3.is-dragging .row-preview-v3{
    transition:none;
  }
  .row-preview-v3 img{
    width:100%;
    height:100%;
    object-fit:cover;
    object-position:center;
  }
}

@media (max-width:560px){
  .work-row-v3{
    min-height:166px;
    padding:32px 0;
    grid-template-columns:42px minmax(0,1fr);
  }
  .work-title-v3{
    font-size:clamp(46px,12.4vw,64px);
  }
  .row-preview-v3{
    width:min(84vw,390px);
    height:calc(100% - 26px);
  }
}

/* v19 fixes: clean mobile swipe reveal, legal section, no sticky hover preview on touch */
html{scroll-behavior:smooth;}
.legal{border-top:1px solid var(--line);}
.legal-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1px;background:var(--line);border:1px solid var(--line);}
.legal-card{background:var(--bg);padding:28px;min-height:320px;}
.legal-card h2{font-family:var(--serif);font-size:clamp(32px,3vw,54px);font-weight:400;line-height:1;margin:18px 0 22px;letter-spacing:-.02em;}
.legal-card p{color:var(--muted);font-size:15px;line-height:1.55;margin:0 0 16px;}
.legal-card strong{color:var(--text);font-weight:600;}
.legal-card a{color:var(--text);border-bottom:1px solid var(--line-strong);}
.footer-links{display:flex;gap:18px;flex-wrap:wrap;justify-content:flex-end;}
.footer-links a{color:var(--muted);}
.footer-links a:hover{color:var(--text);}

@media (min-width:1001px){
  .workflows h2{font-size:clamp(42px,5.7vw,88px);line-height:.96;letter-spacing:-.034em;max-width:1080px;}
}

@media (max-width:1000px){
  .legal-grid{grid-template-columns:1fr;}
  footer{align-items:flex-start;}
  .footer-links{justify-content:flex-start;}

  .work-list-v3{display:block;overflow:visible;border-top:1px solid var(--line);padding:0;margin:0;}
  .work-row-v3{
    --drag-x:0px;
    --preview-x:106%;
    --preview-opacity:0;
    position:relative;
    display:grid;
    grid-template-columns:44px minmax(0,1fr);
    gap:12px 18px;
    align-items:center;
    min-height:166px;
    padding:30px 0;
    border:0;
    border-bottom:1px solid var(--line);
    background:transparent;
    overflow:hidden;
    touch-action:pan-y;
    -webkit-user-select:none;
    user-select:none;
    -webkit-tap-highlight-color:transparent;
  }
  .work-row-v3:hover{background:transparent;border-color:var(--line);padding-left:0;}
  .work-row-v3 > span:not(.row-preview-v3){
    position:relative;
    z-index:2;
    transform:translate3d(var(--drag-x),0,0);
    transition:transform .34s cubic-bezier(.16,1,.3,1),opacity .24s ease;
  }
  .work-row-v3.is-swiping > span:not(.row-preview-v3){transition:none;}
  .work-row-v3.is-swiped > span:not(.row-preview-v3){opacity:.22;}
  .work-no{grid-column:1;grid-row:1 / span 4;align-self:start;padding-top:8px;}
  .work-title-v3{grid-column:2;order:initial;font-size:clamp(46px,12.4vw,70px);line-height:.92;}
  .work-type-v3{grid-column:2;order:initial;font-size:clamp(19px,5vw,28px);line-height:1.18;color:rgba(244,242,236,.58);}
  .work-year{grid-column:2;order:initial;justify-self:start;text-align:left;margin-top:4px;}
  .row-preview-v3,
  .work-row-v3:hover .row-preview-v3{
    display:block;
    pointer-events:none;
    position:absolute;
    right:0;
    top:50%;
    width:min(80vw,520px);
    height:calc(100% - 24px);
    aspect-ratio:auto;
    margin:0;
    padding:8px;
    border:1px solid rgba(244,242,236,.18);
    background:#050608;
    opacity:var(--preview-opacity);
    transform:translate3d(var(--preview-x),-50%,0) scale(.985);
    transition:opacity .26s ease, transform .34s cubic-bezier(.16,1,.3,1);
    box-shadow:0 22px 70px rgba(0,0,0,.54);
    z-index:3;
  }
  .work-row-v3.is-swiping .row-preview-v3{transition:none;}
  .row-preview-v3 img{width:100%;height:100%;object-fit:cover;object-position:center;}
}

@media (max-width:560px){
  .work-row-v3{min-height:164px;padding:30px 0;grid-template-columns:42px minmax(0,1fr);}
  .row-preview-v3,.work-row-v3:hover .row-preview-v3{width:min(86vw,390px);height:calc(100% - 26px);}
  .footer-links{gap:12px;}
}


/* v21 legal overlay + footer cleanup */
.legal-overlay{
  position:fixed;
  inset:0;
  z-index:80;
  display:grid;
  place-items:center;
  padding:24px;
  background:rgba(2,3,5,.76);
  backdrop-filter:blur(18px);
  opacity:0;
  pointer-events:none;
  transition:opacity .24s ease;
}
.legal-overlay.active{
  opacity:1;
  pointer-events:auto;
}
.legal-panel{
  position:relative;
  width:min(920px,calc(100vw - 36px));
  max-height:min(760px,calc(100vh - 48px));
  overflow:auto;
  border:1px solid var(--line-strong);
  background:rgba(5,6,8,.94);
  box-shadow:0 34px 120px rgba(0,0,0,.58);
  padding:clamp(28px,5vw,62px);
}
.legal-close{
  position:absolute;
  top:18px;
  right:18px;
  margin:0;
  padding:9px 14px;
  background:transparent;
  color:var(--muted);
  border:1px solid var(--line);
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.legal-content{
  display:none;
}
.legal-content.active{
  display:block;
}
.legal-content h2{
  margin:18px 0 26px;
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(44px,7vw,86px);
  line-height:.92;
  letter-spacing:-.035em;
}
.legal-content p{
  max-width:680px;
  color:var(--muted);
  font-size:18px;
  line-height:1.55;
}
.legal-content a{
  color:var(--text);
  border-bottom:1px solid var(--line-strong);
}
body.legal-open{
  overflow:hidden;
}
.footer-links{
  display:flex;
  gap:18px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.footer-links a{
  color:var(--muted);
}
.footer-links a:hover{
  color:var(--text);
}

@media(max-width:700px){
  footer{
    align-items:flex-start;
    flex-direction:column;
  }
  .footer-links{
    justify-content:flex-start;
    gap:14px;
  }
  .legal-overlay{
    padding:14px;
  }
  .legal-panel{
    width:calc(100vw - 28px);
    max-height:calc(100vh - 28px);
    padding:54px 22px 28px;
  }
  .legal-content p{
    font-size:15px;
  }
}


/* v22 real contact form states */
.form-overlay{
  position:fixed;
  inset:0;
  z-index:90;
  display:grid;
  place-items:center;
  padding:24px;
  background:rgba(2,3,5,.58);
  backdrop-filter:blur(16px);
  opacity:0;
  pointer-events:none;
  transition:opacity .22s ease;
}
.form-overlay.active{
  opacity:1;
  pointer-events:auto;
}
.form-overlay-panel{
  width:min(460px,calc(100vw - 40px));
  border:1px solid var(--line-strong);
  background:rgba(5,6,8,.94);
  padding:34px;
  box-shadow:0 30px 100px rgba(0,0,0,.54);
}
.form-overlay-panel p{
  margin:16px 0 0;
  color:var(--text);
  font-size:22px;
  line-height:1.25;
}
.site-toast{
  position:fixed;
  top:28px;
  left:50%;
  z-index:120;
  width:min(520px,calc(100vw - 36px));
  border:1px solid var(--line-strong);
  background:rgba(5,6,8,.92);
  backdrop-filter:blur(14px);
  box-shadow:0 24px 80px rgba(0,0,0,.48);
  padding:18px 22px;
  opacity:0;
  transform:translate(-50%,-140%);
  pointer-events:none;
  transition:opacity .28s ease, transform .42s cubic-bezier(.16,1,.3,1);
}
.site-toast.active{
  opacity:1;
  transform:translate(-50%,0);
}
.site-toast p{
  margin:8px 0 0;
  color:var(--text);
  font-size:15px;
  line-height:1.35;
}
.site-toast.is-error p::before{
  content:"Something went wrong. Please try again or email StudioNULL@gmail.com. ";
}
.submit-button:disabled{
  opacity:.65;
  transform:none;
  cursor:wait;
}
@media(max-width:700px){
  .site-toast{
    top:18px;
  }
  .form-overlay-panel{
    padding:26px;
  }
  .form-overlay-panel p{
    font-size:18px;
  }
}
