@font-face{font-family:'Mark';src:url('assets/fonts/mark-black.woff2') format('woff2');font-weight:900;font-style:normal;font-display:swap}
@font-face{font-family:'Mark';src:url('assets/fonts/mark-medium.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Mark';src:url('assets/fonts/mark-book.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
:root{--site-max:2100px;--ink:#0a0a0b;--surface:#121214;--line:#232326;--text:#eae6de;--muted:#8a867e;--tungsten:#bea76c;--display:'Mark',Helvetica,Arial,sans-serif;--mono:'Archivo',system-ui,sans-serif}
*{margin:0;padding:0;box-sizing:border-box}
    html{background:#0a0a0b}
    .bg-shield{position:fixed;inset:0;background:#0a0a0b;z-index:-1}
html{scroll-behavior:smooth;overflow-x:hidden}
body{background:var(--ink);color:var(--text);font-family:var(--display);font-weight:400;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
a:focus-visible,button:focus-visible{outline:2px solid var(--tungsten);outline-offset:3px}
.grain{position:fixed;inset:0;width:100%;height:100%;pointer-events:none;z-index:50;opacity:.05}
header{position:fixed;top:0;left:50%;transform:translateX(-50%);width:100%;max-width:var(--site-max);z-index:40;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:1.1rem 2rem;background:linear-gradient(to bottom,rgba(10,10,11,.85),transparent)}
.wordmark{display:flex;align-items:center;justify-self:start}
.wis-logo{height:12px;width:auto;display:block;opacity:0;transition:opacity .3s}
header.scrolled .wis-logo{opacity:1}
.masthead{display:block;position:relative;max-width:var(--site-max);margin:0 auto;padding:4.2rem 2rem .9rem}
.mast-stack{position:relative;display:block}
.mast-mark{display:block;width:100%;height:auto;transition:opacity .35s ease}
.mast-mark.s2{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;object-position:top;opacity:0}
.masthead:hover .s2,.masthead:focus-visible .s2{opacity:1}
.masthead:hover .s1,.masthead:focus-visible .s1{opacity:0}
.mast-ver{position:absolute;right:.5rem;top:38%;writing-mode:vertical-rl;font-family:var(--mono);font-size:.6rem;letter-spacing:.12em;color:#AFA27E;opacity:.8}
nav{grid-column:2;justify-self:center;display:flex;flex-wrap:wrap;justify-content:center;gap:1.4rem;row-gap:.35rem;font-family:var(--mono);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase}
nav a{color:var(--muted);transition:color .2s}
nav a:hover,nav a.here{color:var(--tungsten)}
.tc{font-family:var(--mono);font-size:.72rem;color:var(--muted);letter-spacing:.06em;font-variant-numeric:tabular-nums;justify-self:end;display:none}
@media(min-width:880px){.tc{display:block}}
.hero{position:relative;height:calc(100vh - 13rem);height:calc(100svh - 13rem);min-height:520px;display:flex;align-items:flex-end;max-width:var(--site-max);margin:0 auto}
body.home .hero{height:100vh;height:100svh;min-height:560px}
body.home .masthead{position:absolute;top:0;left:50%;transform:translateX(-50%);width:100%;z-index:6;padding-top:4.2rem}
body.home .mast-stack{filter:none}
.scroll-cue{position:absolute;bottom:1.6rem;right:2rem;z-index:5;font-family:var(--mono);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text);opacity:.85}
.scroll-cue::after{content:'';display:block;width:1px;height:26px;background:var(--text);margin:.5rem auto 0;animation:cue 1.8s ease-in-out infinite}
@keyframes cue{0%,100%{transform:scaleY(.4);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}}
.hero-still{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-frame{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,10,11,.78) 0%,rgba(10,10,11,.15) 45%,rgba(10,10,11,.25) 100%)}

.hero-inner{position:relative;z-index:2;width:100%;padding:0 2rem 12vh;display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap}
h1{font-weight:900;text-transform:uppercase;font-size:clamp(2.4rem,8vw,6.8rem);line-height:.95;letter-spacing:-.025em}
h1 em{font-style:normal;color:var(--tungsten)}
.hero-meta{font-family:var(--mono);font-size:.72rem;color:var(--muted);letter-spacing:.08em;text-transform:uppercase;max-width:300px}
.intro{max-width:var(--site-max);padding:5rem 0 4rem;margin:0 auto;text-align:center}
.intro-roll{position:relative;display:block;margin:0 auto;padding:0 18px;max-width:var(--site-max)}
.intro-roll .ir-hover{display:block;width:100%;height:auto;opacity:0;transform:scale(.5);transform-origin:center center;transition:opacity .5s ease}
.intro-roll .ir-rest{position:absolute;top:0;bottom:0;left:0;right:0;margin:auto;height:80%;width:auto;opacity:1;transition:opacity .5s ease}
.intro-roll:hover .ir-hover,.intro-roll:focus-within .ir-hover{opacity:1}
.intro-roll:hover .ir-rest,.intro-roll:focus-within .ir-rest{opacity:0}
.statement{font-weight:900;text-transform:uppercase;font-size:clamp(1.5rem,3.6vw,3.2rem);line-height:1.08;letter-spacing:-.02em;color:var(--text);margin-bottom:1.6rem}
.intro p:not(.statement){max-width:62ch;margin:0 auto}
.intro strong{color:var(--text);font-weight:500}
.work{position:relative;padding:2rem 0 6rem;max-width:var(--site-max);margin:0 auto}
.tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding:0 18px}
@media(max-width:1280px){.tiles{grid-template-columns:repeat(3,1fr)}}
@media(max-width:880px){.tiles{grid-template-columns:repeat(2,1fr);gap:12px;padding:0 12px}}
@media(max-width:560px){.tiles{grid-template-columns:1fr}}
.tile{position:relative;display:block;aspect-ratio:21/9;overflow:hidden;background:var(--surface)}
a.tile{outline:2px solid transparent;outline-offset:-2px;transition:outline-color .25s ease}
a.tile:hover,a.tile:focus-visible{outline-color:#fff}
.tile-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s ease,opacity .3s}
.tile-slides{position:absolute;inset:0;z-index:0;overflow:hidden}
.tile-slides .slide{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 1s ease}
.tile-slides .slide.is-active{opacity:1}
.tile:hover .tile-slides .slide.is-active{transform:scale(1.03)}
/* desktop: elastic tile-focus — hovered tile grows, the rest recede (subtle) */
@media (hover:hover) and (min-width:761px){
  .work{overflow-x:clip}
  .tiles .tile{transition:transform .5s cubic-bezier(.34,1.35,.64,1),outline-color .25s ease}
  .tiles:has(.tile:hover) .tile:not(:hover){transform:scale(.985)}
  .tiles .tile:hover{transform:scale(1.03);z-index:5}
}
.tile-img-m{display:none}
.tile-cap{position:absolute;bottom:.7rem;z-index:2;max-width:48%;font-family:var(--mono);font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:opacity .3s ease;pointer-events:none}
.tile-cap.l{left:.95rem}
.tile-cap.r{right:.95rem;text-align:right}
.tile-brand{height:20px;width:auto;max-width:42vw;display:block}
.tile:hover .tile-cap,.tile:focus-visible .tile-cap{opacity:0}
.tile-soon{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.4rem;text-align:center;padding:1rem;border:1px solid var(--line)}
.tile-soon::after{display:none}
.soon-eyebrow{font-family:var(--mono);font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--tungsten)}
.soon-title{font-weight:800;text-transform:uppercase;font-size:clamp(.95rem,1.5vw,1.25rem);letter-spacing:.01em;line-height:1.05}
.soon-client{font-family:var(--mono);font-size:.62rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
/* coming-soon two-state image tiles (rest: frame+caption / hover: logo) — v38.8 */
.tile-soon.soon-img{display:block;padding:0;border:0;position:relative;background:#0c0c0e;overflow:hidden}
.soon-img .soon-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.soon-img::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(to top,rgba(0,0,0,.6),rgba(0,0,0,0) 42%),linear-gradient(to bottom,rgba(0,0,0,.5),rgba(0,0,0,0) 34%)}
.soon-img .soon-cap{position:absolute;bottom:.7rem;z-index:3;max-width:48%;font-family:var(--mono);font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:opacity .3s ease;pointer-events:none}
.soon-img .soon-cap-l{left:.95rem}
.soon-img .soon-cap-r{right:.95rem;text-align:right}
.soon-img .soon-badge{position:absolute;top:.72rem;right:.95rem;z-index:3;font-family:var(--mono);font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--tungsten);pointer-events:none}
.soon-img .soon-logo{position:absolute;inset:0;margin:auto;width:62%;height:62%;object-fit:contain;z-index:2;opacity:0;transform:scale(.97);transition:opacity .3s ease,transform .4s ease;filter:drop-shadow(0 3px 16px rgba(0,0,0,.55));pointer-events:none}
.soon-img:hover .soon-bg{transform:scale(1.03)}
.soon-img:hover .soon-cap{opacity:0}
.soon-img:hover .soon-logo{opacity:1;transform:none}

.tile:hover .tile-img{transform:scale(1.03)}
.tile video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .3s}
.tile.playing video{opacity:1}
.tile-logo{position:absolute;inset:0;margin:auto;width:50%;height:50%;object-fit:contain;z-index:2;transition:transform .4s ease;pointer-events:none}
.tile-logo img{display:block;width:100%;height:100%;object-fit:contain}
.tile:hover .tile-logo{transform:scale(1.04)}
.tile-logo.l1,.tile-logo.l2{transition:opacity .3s ease,transform .4s ease}
.tile-logo.l2{opacity:0}
.tile-logo.l1{opacity:0}
.tile::after{content:"";position:absolute;inset:0;background:#000;opacity:0;transition:opacity .3s ease;z-index:1;pointer-events:none}
.tile:hover::after,.tile:focus-visible::after{opacity:.5}
.tile:hover .tile-logo.l2,.tile:focus-visible .tile-logo.l2{opacity:1}
.tile:hover .tile-logo.l1,.tile:focus-visible .tile-logo.l1{opacity:0}
.tile-title{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;text-align:center;padding:0 1rem;z-index:2;font-weight:900;text-transform:uppercase;font-size:clamp(.95rem,1.4vw,1.35rem);letter-spacing:-.01em;line-height:1.1;text-shadow:0 2px 10px rgba(10,10,11,.65);pointer-events:none}
.work-sign{text-align:right;padding:1.4rem 18px 0;font-family:var(--mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--text);opacity:.85}

.archive{padding:3rem 2rem 6rem;max-width:900px;margin:0 auto}
.archive h2{font-family:var(--mono);font-weight:400;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--tungsten);margin-bottom:1.2rem}
.arch-row{display:flex;justify-content:space-between;gap:1rem;padding:.55rem 0;border-bottom:1px solid var(--line);font-size:.95rem;color:var(--muted)}
.arch-row a:hover{color:var(--tungsten)}
.arch-row .c{font-family:var(--mono);font-size:.68rem;letter-spacing:.06em;text-transform:uppercase;flex-shrink:0;text-align:right}
/* Also Directed — click the heading to reveal the list */
.arch-toggle{display:inline-flex;align-items:center;gap:.55rem;cursor:pointer;user-select:none;-webkit-user-select:none}
.arch-toggle:hover{color:var(--text)}
.arch-caret{width:.46rem;height:.46rem;border-right:1.6px solid currentColor;border-bottom:1.6px solid currentColor;transform:translateY(-2px) rotate(45deg);transition:transform .4s cubic-bezier(.34,1.4,.64,1)}
.archive.open .arch-caret{transform:translateY(1px) rotate(-135deg)}
.arch-list{display:grid;grid-template-rows:0fr;opacity:0;transition:grid-template-rows .55s cubic-bezier(.4,0,.2,1),opacity .45s ease}
.arch-inner{overflow:hidden;min-height:0}
.archive.open .arch-list{grid-template-rows:1fr;opacity:1}
.page{padding:3.5rem 2rem 4rem;max-width:1100px;margin:0 auto;text-align:center}
.eyebrow{font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--tungsten);margin-bottom:1rem}
.page h1{font-size:clamp(2.2rem,6vw,5rem);margin-bottom:1rem}
.proj-meta{font-family:var(--mono);font-size:.72rem;color:var(--muted);letter-spacing:.08em;text-transform:uppercase;margin-bottom:3rem}
.player{position:relative;aspect-ratio:16/9;background:var(--surface);margin-bottom:1rem;overflow:hidden}
.page .player:not(.small){width:100vw;margin-left:calc(50% - 50vw);width:min(100vw,2100px);margin-left:calc(50% - min(50vw,1050px))}
.page .stills-strip{width:100vw;margin-left:calc(50% - 50vw);padding-left:2rem;padding-right:2rem}
.pf-vid{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-vid{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.player .pf{position:absolute;inset:0}
.player iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.play{position:absolute;inset:0;z-index:3;width:100%;background:transparent;border:0;cursor:pointer;display:flex;align-items:center;justify-content:center}
.play-btn{width:92px;height:92px;border-radius:50%;border:1px solid rgba(234,230,222,.4);display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px);transition:transform .25s,border-color .25s;font-family:var(--mono);font-size:.65rem;letter-spacing:.14em;color:var(--text)}
.play:hover .play-btn{transform:scale(1.08);border-color:var(--tungsten)}
.player.small .play-btn{width:60px;height:60px;font-size:.55rem}
.player .tbc{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.copy{max-width:62ch;color:var(--muted);font-size:1.08rem;padding:2rem 0 3rem;margin:0 auto}
.copy p+p{margin-top:1.2rem}
.cutdowns{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));padding-bottom:3rem}
.cut-label{font-family:var(--mono);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-top:.5rem;text-align:center}
.pn{display:flex;justify-content:space-between;align-items:center;gap:2rem;border-top:1px solid var(--line);padding:2rem 0 1rem;font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase}
.pn a{color:var(--muted)}.pn a:hover{color:var(--tungsten)}
.pn-prev,.pn-next{display:flex;align-items:center;gap:.7rem}
.pn-logo{height:clamp(44px,5.5vw,64px);width:auto;display:block}
.pn-arrow{font-size:1.05rem;line-height:1;color:inherit;transition:transform .25s ease}
.pn-prev:hover .pn-arrow{transform:translateX(-4px)}
.pn-next:hover .pn-arrow{transform:translateX(4px)}
@media(max-width:600px){.pn{gap:1rem}.pn-logo{height:34px;max-width:34vw}.pn-arrow{font-size:.9rem}}
.about-grid{display:grid;gap:2.5rem;text-align:left}
@media(min-width:880px){.about-grid{grid-template-columns:1fr 2fr}}
.about-grid h2{font-weight:900;text-transform:uppercase;font-size:1rem;letter-spacing:.06em;color:var(--tungsten)}
.about-grid p{color:var(--muted);font-size:1.05rem;max-width:62ch}
.about-grid p+p{margin-top:1.2rem}
.about-grid strong{color:var(--text);font-weight:500}
.stills-grid{display:grid;gap:4px;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));padding-bottom:4rem}
.ig-grid{display:grid;gap:4px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));padding-bottom:4rem}
.ig-cell{aspect-ratio:1;background:var(--surface);border:1px solid var(--line)}
.stills-grid img.g{width:100%;height:100%;object-fit:cover;aspect-ratio:3/2;display:block;background:var(--surface)}
footer{border-top:1px solid var(--line);padding:5rem 2rem 3rem}
body.home #contact{text-align:center}
body.home #contact .footer-mark{margin-inline:auto}
.footer-mark{display:none}
@media(max-width:760px){
  body.home .work-sign{text-align:center;padding:1.4rem 1rem 0}
  body.home #contact{padding:2.6rem 1.2rem 2.4rem}
  body.home #contact .email{display:inline-block;max-width:100%;overflow-wrap:anywhere}
  body.home #contact .fine{line-height:2.1}
}
.contact-grid{max-width:var(--site-max);margin:0 auto}
.contact-grid{display:flex;flex-direction:column;align-items:center;text-align:center;gap:1.6rem}
.email{font-weight:900;text-transform:uppercase;font-size:clamp(1.2rem,3.2vw,2.2rem);letter-spacing:-.01em}
.email:hover{color:var(--tungsten)}
.fine{font-family:var(--mono);font-size:.68rem;color:var(--muted);letter-spacing:.08em;text-transform:uppercase;line-height:2.2}
.fine a:hover{color:var(--tungsten)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.proj-logo{display:block;max-width:min(640px,86vw);width:100%;height:auto;margin:0 auto 1.2rem}
.proj-slate{display:block;max-width:min(560px,82vw);width:100%;height:auto;margin:0 auto 1.4rem}
.credits{max-width:min(1100px,90vw);margin:2.6rem auto 0;border-top:1px solid var(--line);padding-top:1.8rem}
.credits-label{font-family:var(--mono);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--tungsten)}
.credits-key{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:.9rem 2.4rem;margin-top:1.3rem}
.cr-row{font-size:.95rem;line-height:1.4}
.cr-role{font-family:var(--mono);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:.15rem}
.cr-name{font-weight:600;color:var(--tungsten)}
.credits-ext{margin-top:1.6rem;border-top:1px solid var(--line)}
.credits-ext summary{cursor:pointer;font-family:var(--mono);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);padding:1.2rem 0;list-style:none}
.credits-ext summary::-webkit-details-marker{display:none}
.credits-ext summary::after{content:" +";color:var(--tungsten);font-weight:700}
.credits-ext[open] summary::after{content:" –"}
.credits-ext-body{font-family:var(--mono);font-size:.72rem;line-height:1.95;color:var(--muted);letter-spacing:.01em;padding-bottom:2.4rem;max-width:78ch}
.credits-ext-body b{color:var(--text);font-weight:400}
.proj-stack{position:relative;display:block;max-width:min(640px,86vw);margin:0 auto 1.2rem}
.proj-stack .proj-logo{max-width:100%;margin:0;transition:opacity .35s ease}
.proj-stack .p2{position:absolute;inset:0;opacity:0}
.proj-stack:hover .p2{opacity:1}
.proj-stack:hover .p1{opacity:0}
.player .pf-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.stills-strip{display:flex;gap:6px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:3rem;-webkit-overflow-scrolling:touch}
.stills-strip img{height:min(420px,52vw);width:auto;flex-shrink:0;scroll-snap-align:start;display:block}
.stills-strip::-webkit-scrollbar{height:4px}
.stills-strip::-webkit-scrollbar-thumb{background:var(--line)}
.row-still{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
@media(prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}html{scroll-behavior:auto}}

/* --- Mobile header: masthead on top, clean legible nav below (matches V.33 reference) --- */
@media(max-width:760px){
  body{display:flex;flex-direction:column;min-height:100svh}
  .masthead,body.home .masthead{order:-2;position:static;transform:none;left:auto;width:100%;
    padding:calc(2.4rem + env(safe-area-inset-top,0px)) 1rem .3rem;background:var(--ink)}
  .mast-ver{display:none}
  header{order:-1;position:static;transform:none;left:auto;width:100%;display:flex;justify-content:center;
    background:var(--ink);padding:.15rem 1rem 1rem;box-shadow:none}
  .wordmark,.tc{display:none}
  nav{justify-content:center;gap:1.15rem;row-gap:.5rem;font-size:.8rem}
  nav a{color:var(--text)}
  nav a.here{color:var(--tungsten)}
  /* mobile-only: tiles-only home — no hero showreel, no intro/archive (matches reference) */
  body.home .hero,body.home .intro,body.home .archive{display:none}
  /* mobile-only: drop the two extra nav links, keep them on desktop */
  nav a[href*="falseprofits"],nav a[href$="instagram.html"]{display:none}
  /* === mobile homepage v37.1: cinemascope rest, grow to 16:9 on play === */
  body.home .tiles{display:grid;grid-template-columns:1fr;gap:11px;padding:0 6px}
  /* job tiles: 2.66:1 (24:9) at rest -> grow to 16:9 when playing; Settle entrance */
  body.home a.tile{aspect-ratio:auto;height:0;padding-top:37.5%;border-radius:4px;overflow:hidden;outline:none;
    transition:opacity .6s cubic-bezier(.34,1.56,.64,1),transform .6s cubic-bezier(.34,1.56,.64,1),padding-top .6s cubic-bezier(.4,0,.2,1)}
  body.home a.tile.playing{padding-top:56.25%}
  body.home.mload a.tile{opacity:0;transform:translateY(40px)}
  body.home.mload a.tile.in{opacity:1;transform:none}
  /* coming-soon cards: same cinemascope height, no playback */
  body.home .tile-soon{aspect-ratio:24/9;border-radius:4px;
    transition:opacity .6s cubic-bezier(.34,1.56,.64,1),transform .6s cubic-bezier(.34,1.56,.64,1)}
  body.home.mload .tile-soon{opacity:0;transform:translateY(40px)}
  body.home.mload .tile-soon.in{opacity:1;transform:none}
  /* hide desktop / old-mobile internals */
  body.home .tile-slides,body.home .tile-img,body.home .tile-img-m,
  body.home .tile-logo,body.home .tile-cap{display:none!important}
  body.home .tile>video{display:none!important}
  body.home .tile::after{display:none}
  /* rollover layer */
  body.home .mtile{display:block;position:absolute;inset:0;z-index:1}
  body.home .mtile .m-base,body.home .mtile .m-loop{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
  body.home .mtile .m-loop{opacity:0;transition:opacity .5s ease}
  body.home .tile.playing .mtile .m-loop{opacity:1}
  body.home .mtile::after{content:"";position:absolute;inset:0;pointer-events:none;z-index:2;
    background:radial-gradient(120% 90% at 50% 52%,rgba(0,0,0,.26) 0%,rgba(0,0,0,0) 55%),
      linear-gradient(180deg,rgba(0,0,0,.10) 0%,rgba(0,0,0,0) 30%,rgba(0,0,0,.34) 100%)}
  /* logo: width-driven (stable as the tile grows) -> single smooth shrink + slide to lower third on play */
  body.home .mtile .m-logo{position:absolute;left:0;top:50%;width:100%;height:auto;z-index:3;pointer-events:none;
    transform-origin:center center;opacity:1;transform:translateY(-50%) scale(1);
    transition:transform .6s cubic-bezier(.4,0,.2,1),opacity .45s ease}
  body.home .tile.playing .mtile .m-logo{opacity:.95;transform:translateY(-22%) scale(.5)}
  /* play coin */
  body.home .mtile .m-play{position:absolute;top:10px;right:10px;z-index:6;width:27px;height:27px;
    display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .4s ease;filter:drop-shadow(0 1px 4px rgba(0,0,0,.4))}
  body.home .tile.playing .mtile .m-play{opacity:1}
  body.home .mtile .m-ring{position:absolute;inset:0;border-radius:50%;
    background:conic-gradient(from 0deg,rgba(255,255,255,0) 0deg,rgba(255,255,255,.95) 70deg,rgba(255,255,255,.95) 360deg);
    -webkit-mask:radial-gradient(farthest-side,#0000 calc(100% - 1.6px),#000 calc(100% - 1.6px));
            mask:radial-gradient(farthest-side,#0000 calc(100% - 1.6px),#000 calc(100% - 1.6px))}
  body.home .tile.playing .mtile .m-ring{animation:m-spin 2.4s linear infinite}
  body.home .mtile .m-play i{position:relative;z-index:1;width:0;height:0;display:block;margin-left:2px;
    border-style:solid;border-width:5px 0 5px 8px;border-color:transparent transparent transparent var(--tungsten);
    filter:drop-shadow(0 1px 1px rgba(0,0,0,.45))}
}

/* ============================================================
   JOB PAGE — approved "Who You Got?" layout (build V.34)
   All rules scoped under body.job so other pages are untouched.
   Page renders in Archivo (var(--mono)) to match the signed-off mockup.
   ============================================================ */
body.job{font-family:var(--mono)}
.job img{display:block;max-width:100%}
.job main{display:block;padding-top:clamp(3rem,6.5vw,6rem)}
.job main>:first-child{padding-top:0}
.job .wrapx{max-width:1180px;margin:0 auto;padding:0 clamp(1rem,4vw,2rem)}
.job .sechead{font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:var(--tungsten);margin:0 0 1.3rem;display:flex;align-items:center;gap:.8rem}
.job .sechead::after{content:"";flex:1;height:1px;background:var(--line)}

/* hero — burned-in slate frame + site chrome */
.job .jhero{position:relative;height:90vh;min-height:460px;background:#000;overflow:hidden}
.job .jhero>img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center}
.job .jhero.contain>img.bg{object-fit:contain}
.job .jhero video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .45s ease;z-index:1}
.job .jhero.contain video{object-fit:contain}
.job .jhero.playing video{opacity:1}
.job .jhero::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.5),transparent 16%,transparent 86%,rgba(0,0,0,.5));z-index:2;pointer-events:none}
.job .jbar{position:fixed;top:0;left:0;right:0;transform:none;max-width:none;width:100%;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:1.2rem 2rem;z-index:40;background:rgba(0,0,0,.5);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}
.job .jwm{justify-self:start}
.job .jnav{grid-column:2;justify-self:center;display:flex;gap:1.3rem;font-size:.62rem;letter-spacing:.18em;text-transform:uppercase}
.job .jnav .nl{color:var(--text);opacity:.92}.job .jnav .nl.here{color:var(--tungsten)}.job .jnav .nl:hover{opacity:1;color:var(--tungsten)}
.job .jtc{justify-self:end;font-size:.62rem;letter-spacing:.12em;color:var(--muted);font-variant-numeric:tabular-nums}
.job .jwatch{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:.85rem;z-index:4;padding-bottom:clamp(2rem,7vh,5rem)}
.job .wbtn{appearance:none;width:94px;height:94px;border-radius:50%;border:1px solid rgba(234,230,222,.6);background:rgba(10,10,11,.22);color:var(--text);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.25rem;backdrop-filter:blur(5px);transition:transform .25s,background .25s,border-color .25s}
.job .wbtn:hover{transform:scale(1.06);background:rgba(234,230,222,.14);border-color:#fff}
.job .wlabel{font-size:.64rem;letter-spacing:.34em;text-transform:uppercase}
.job .jscroll{position:absolute;right:1.6rem;bottom:1.3rem;z-index:5;font-size:.6rem;letter-spacing:.24em;text-transform:uppercase;opacity:.85}

/* the campaign — four films */
.job .jfilms{padding:clamp(2rem,5vw,3.4rem) 0 clamp(1.6rem,4vw,2.6rem)}
.job .filmgrid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.job .filmgrid.n3{grid-template-columns:repeat(3,1fr)}
@media(max-width:680px){.job .filmgrid,.job .filmgrid.n3{grid-template-columns:1fr}}
.job .filmcell{display:flex;flex-direction:column;gap:.55rem}
.job .film{position:relative;appearance:none;border:1px solid var(--line);background:none;padding:0;cursor:pointer;overflow:hidden;aspect-ratio:2100/1107;border-radius:4px;outline:2px solid transparent;outline-offset:-2px;transition:outline-color .25s}
.job .film img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.job .film::after{content:"";position:absolute;inset:0;background:rgba(10,10,11,.18);transition:background .3s}
.job .film:hover{outline-color:#fff}.job .film:hover img{transform:scale(1.03)}.job .film:hover::after{background:rgba(10,10,11,0)}
.job .film-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:54px;height:54px;border-radius:50%;border:1px solid rgba(234,230,222,.7);background:rgba(10,10,11,.3);display:flex;align-items:center;justify-content:center;font-size:.85rem;color:#fff;opacity:0;transition:opacity .25s;backdrop-filter:blur(4px)}
.job .film:hover .film-play{opacity:1}
.job .film-cap{font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text)}
.job .fnum{color:var(--tungsten);margin-right:.6em;font-variant-numeric:tabular-nums}

/* job description — two columns */
.job .jabout{padding:clamp(1rem,3vw,1.8rem) 0 clamp(1.4rem,4vw,2rem)}
.job .jabout-grid{columns:2;column-gap:2.6rem}
.job .jabout-grid p{font-size:.94rem;line-height:1.78;color:#d6d1c7;margin:0 0 1rem;break-inside:avoid}

/* logo lockup */
.job .lockup{text-align:center;padding:clamp(1.4rem,4vw,2.4rem) 0}
.job .plogo{width:min(50%,560px);height:auto;margin:0 auto}
/* Mobile title-card variant — logo + Watch centred on the portrait hero; logo band hidden so content pulls up. Desktop unaffected. */
.job .jhero.titlecard .jwatch .plogo{display:none}
@media(max-width:760px){
  .job .jhero.titlecard.has-portrait .jwatch{justify-content:flex-end;gap:.5rem;padding:0 0 12%}
  .job .jhero.titlecard.has-portrait .jwatch::before{content:"";position:absolute;inset:0;z-index:0;background:radial-gradient(74% 64% at 50% 52%,rgba(0,0,0,.5),rgba(0,0,0,0) 72%);pointer-events:none}
  .job .jhero.titlecard.has-portrait .jwatch>*{position:relative;z-index:1}
  .job .jhero.titlecard.has-portrait .jwatch .plogo{display:block;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:min(66%,300px);height:auto;margin:0;filter:drop-shadow(0 2px 16px rgba(0,0,0,.6));z-index:1}
  .job .tc-hide-m{display:none}
}

/* credits */
.job .jcredits{padding:0 0 clamp(2.2rem,5vw,3rem)}
.job .cbar{display:flex;align-items:center;gap:1rem;border-top:1px solid var(--line);padding-top:1.4rem;margin-bottom:1.3rem}
.job .cbig{font-weight:900;font-size:clamp(1.3rem,3vw,1.8rem);letter-spacing:.04em;text-transform:uppercase}
.job .chips{display:inline-flex;gap:.5rem}.job .chip{width:34px;height:18px;border-radius:2px}
.job .cslate{height:48px;width:auto;margin-left:auto;max-width:72%;object-fit:contain;object-position:right;opacity:.95}
.job .cgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:0 2.4rem}
.job .crcol .cr:first-child{border-top:0}
.job .cr{display:grid;grid-template-columns:1fr 1.25fr;gap:1rem;padding:.5rem 0;border-top:1px solid var(--line)}
.job .cr-l{font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);align-self:center}
.job .cr-v{font-size:.76rem;font-weight:500;color:var(--text);overflow-wrap:anywhere}

/* stills carousel — one frame at a time, 2.40:1 */
.job .jstills{padding:0 0 clamp(2.2rem,5vw,3.2rem)}
.job .carousel{position:relative;aspect-ratio:24/10;border:1px solid var(--line);border-radius:4px;overflow:hidden;background:#000}
.job .stillimg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .6s ease;cursor:zoom-in}
.job .stillimg.is-active{opacity:1}
.job .arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:46px;height:46px;border-radius:50%;border:1px solid rgba(234,230,222,.5);background:rgba(10,10,11,.4);color:#fff;font-size:1.05rem;cursor:pointer;backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;transition:background .2s,border-color .2s}
.job .arrow:hover{background:rgba(10,10,11,.72);border-color:#fff}
.job .arrow.prev{left:.8rem}.job .arrow.next{right:.8rem}
.job .dots{position:absolute;bottom:.85rem;left:50%;transform:translateX(-50%);z-index:3;display:flex;gap:.5rem}
.job .dot{width:7px;height:7px;border-radius:50%;background:rgba(234,230,222,.35);border:0;padding:0;cursor:pointer;transition:background .2s}
.job .dot.on{background:var(--tungsten)}

/* prev / next project nav */
.job .jpn{display:flex;justify-content:space-between;align-items:center;gap:1rem;border-top:1px solid var(--line);padding:1.6rem 0;font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.job .jpn a:hover{color:var(--text)}.job .jpn .idx{color:var(--text)}

/* footer masthead with hover rollover */
.job .jmast{border-top:1px solid var(--line);text-align:center;padding:clamp(2.4rem,6vw,4rem) 1.2rem clamp(1.6rem,4vw,2.4rem)}
.job .mlink{display:block;max-width:1100px;margin:0 auto 1.4rem}.job .mstack{position:relative;display:block}
.job .mh{width:100%;height:auto;display:block;transition:opacity .35s ease}.job .mh.s2{position:absolute;inset:0;opacity:0}
.job .mlink:hover .s2{opacity:1}.job .mlink:hover .s1{opacity:0}
.job .jfine{font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);display:flex;gap:.4rem 1.4rem;justify-content:center;flex-wrap:wrap;align-items:center}
.job .jfine .email{font-weight:600;font-size:.62rem;letter-spacing:.14em;flex-basis:100%;text-align:center}
.job .jfine a:hover{color:var(--text)}

/* video lightbox + stills fullscreen */
.job .lb,.job .sb{position:fixed;inset:0;background:rgba(3,3,4,.94);display:none;align-items:center;justify-content:center;z-index:60;padding:3vw}
.job .lb.on,.job .sb.on{display:flex}.job .lb-inner{width:min(1000px,92vw)}
.job .lb-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:.7rem}
.job .lb-bar .l{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.job .lb-x,.job .sb-x{appearance:none;background:none;border:1px solid var(--line);color:var(--text);font-family:var(--mono);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;border-radius:30px;padding:.5em 1em;cursor:pointer}.job .lb-x:hover,.job .sb-x:hover{border-color:#fff}
.job .lb-player{position:relative;aspect-ratio:16/9;background:#000;border:1px solid var(--line);overflow:hidden}
.job .lb-player iframe{position:absolute;inset:0;width:100%;height:100%;border:0;background:#000}
.job .lb-player video{position:absolute;inset:0;width:100%;height:100%;border:0;background:#000;object-fit:contain}
.job .sb{z-index:70;flex-direction:column;gap:.7rem}
.job .sb .sb-arrow{position:static;top:auto;left:auto;right:auto;transform:none}.job .sb img#sbImg{max-width:96vw;max-height:78vh;width:auto;height:auto;border:1px solid var(--line)}
.job .sb-x{position:absolute;top:1.2rem;right:1.4rem}
.job .sb-arrow{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;border:1px solid rgba(234,230,222,.5);background:rgba(10,10,11,.5);color:#fff;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center}
.job .sb-arrow:hover{border-color:#fff}.job .sb-prev{left:1.6rem}.job .sb-next{right:1.6rem}

/* job-page mobile: keep the in-hero nav tidy on phones */
@media(max-width:760px){
  .job .jtc{display:none}
  .job .jbar{grid-template-columns:auto minmax(0,1fr);column-gap:.8rem;padding:.8rem 1.1rem}
  .job .jwm{grid-column:1;justify-self:start}
  .job .jnav{grid-column:2;justify-self:end;justify-content:flex-end;flex-wrap:wrap;gap:.5rem .9rem}
  .job .cgrid{grid-template-columns:1fr}
  .job .cbar{flex-wrap:wrap}
  .job .cslate{flex-basis:100%;width:100%;max-width:100%;height:auto;margin:.9rem 0 0;object-position:left}
}

/* ---- About page · V.35 (Irwin hero + overlaid copy, job chrome) ---- */
.job.about main{padding-top:0}
.about-hero{position:relative;min-height:100vh;background:#0a0a0b;overflow:hidden;display:flex;align-items:center}
.about-hero>img.abg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:38% top}
.about-hero::before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(90deg,rgba(10,10,11,.28) 0%,rgba(10,10,11,0) 42%,rgba(10,10,11,.62) 100%),linear-gradient(180deg,rgba(10,10,11,.6),transparent 16%,transparent 80%,rgba(10,10,11,.66))}
.about-wrap{position:relative;z-index:2;width:100%;max-width:var(--site-max);margin:0 auto;padding:clamp(7rem,12vw,9.5rem) clamp(1.2rem,5vw,3.2rem) clamp(3rem,6vw,4.5rem);display:flex;justify-content:flex-end}
.about-copy{width:min(50ch,88%);text-align:right}
.about-eyebrow{font-family:var(--mono);font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:var(--tungsten);margin:0 0 1.7rem}
.about-copy p.body{font-family:var(--mono);font-weight:400;font-size:clamp(1rem,1.45vw,1.14rem);line-height:1.95;letter-spacing:.004em;color:#f2efe9;margin:0 0 1.5rem;text-shadow:0 1px 20px rgba(0,0,0,.5)}
.about-copy p.body:last-of-type{margin-bottom:0}
.about-credit{position:absolute;z-index:2;left:0;right:0;bottom:clamp(2rem,5vw,3.6rem);max-width:var(--site-max);margin:0 auto;padding:0 clamp(1.2rem,5vw,3.2rem);text-align:right;font-family:var(--mono);font-size:.72rem;letter-spacing:.04em;color:var(--muted);text-shadow:0 1px 14px rgba(0,0,0,.55)}
.about-credit b{font-family:var(--display);font-weight:900;color:var(--text);letter-spacing:.03em;font-size:.92rem}
@media(max-width:760px){
 .about-hero>img.abg{object-position:32% top}
 .about-hero::before{background:linear-gradient(180deg,rgba(10,10,11,.52),rgba(10,10,11,.32) 28%,rgba(10,10,11,.74))}
 .about-wrap{justify-content:flex-end;padding-top:6.8rem}
 .about-copy{width:min(54ch,94%)}
}

/* ---- Showreel page · V.35 (slate cover + WATCH -> Vimeo lightbox) ---- */
.job.reel main{padding-top:0}
.reel-hero{position:relative;min-height:100vh;background:#000;overflow:hidden;cursor:pointer}
.reel-hero>img.rbg{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;object-position:center}
.reel-hero::before{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;background:linear-gradient(180deg,rgba(0,0,0,.55),transparent 18%,transparent 82%,rgba(0,0,0,.55));transition:opacity .35s ease}
.reel-hero:hover::before{opacity:.8}
.reel-hero:focus-visible{outline:2px solid #fff;outline-offset:-5px}
.reel-hero:hover .wm-f{transform:rotateY(180deg)}.reel-hero:hover .wm-b{transform:rotateY(360deg)}

/* ===== top-left monogram icon (replaces wordmark) ===== */
@media(min-width:761px){header{padding-top:.62rem;padding-bottom:.62rem}.job .jbar{padding-top:.62rem;padding-bottom:.62rem}}
.wm-ico{position:relative;display:inline-block;width:50px;height:50px;perspective:460px;opacity:1;transition:opacity .35s ease}
.wordmark .wm-ico{opacity:0}
header.scrolled .wm-ico{opacity:1}
body.stills .wm-ico,.jwm .wm-ico{opacity:1}
.wm-coin{position:absolute;inset:0;transform-style:preserve-3d}
.wm-face{position:absolute;inset:0;width:100%;height:100%;backface-visibility:hidden;transition:transform .6s cubic-bezier(.2,.75,.2,1)}
.job .jwm .wm-face{width:100%;height:100%}
.wm-b{transform:rotateY(180deg)}
.wordmark:hover .wm-f,.jwm:hover .wm-f{transform:rotateY(180deg)}
.wordmark:hover .wm-b,.jwm:hover .wm-b{transform:rotateY(360deg)}
.wm-ring{position:absolute;inset:-3px;border:2px solid #bea76c;border-radius:13px;opacity:0;transform:scale(.7);pointer-events:none}
.wm-press .wm-coin{animation:wmStamp .26s cubic-bezier(.2,.8,.2,1)}
.wm-press .wm-ring{animation:wmRip .46s ease-out}
@keyframes wmStamp{0%{transform:scale(1)}35%{transform:scale(.82)}70%{transform:scale(1.1)}100%{transform:scale(1)}}
@keyframes wmRip{0%{opacity:.85;transform:scale(.62)}100%{opacity:0;transform:scale(1.55)}}
@media(max-width:760px){.wm-ico{width:38px;height:38px}}
@media(prefers-reduced-motion:reduce){.wm-face{transition:none}.wm-press .wm-coin,.wm-press .wm-ring{animation:none}}

/* ig credit links + carousel coin-flip arrows */
.cgrid a.ig{color:var(--tungsten);text-decoration:none}
.cgrid a.ig:hover{text-decoration:underline}
.job .arrow{border:0}
.job .arrow .wm-ico.ar{width:24px;height:24px;perspective:200px;opacity:1}
.job .arrow .wm-ring{border-radius:50%;inset:-4px;border-color:#bea76c}
.job .arrow:hover .wm-f{transform:rotateY(180deg)}
.job .arrow:hover .wm-b{transform:rotateY(360deg)}

/* hero autoplay background loop + play-button coin-flip */
.job .jhero video.hbg{opacity:1;z-index:0;object-fit:cover}
.job .wbtn .wm-ico.pb{width:80px;height:80px;perspective:220px;opacity:1}
.job .wbtn .pbf{display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:var(--text);line-height:1;padding-left:3px}
.job .wbtn .wm-ring{border-radius:50%;inset:-6px;border-color:#bea76c}
.job .wbtn:hover .wm-f{transform:rotateY(180deg)}
.job .wbtn:hover .wm-b{transform:rotateY(360deg)}

/* slate sits in front of the hero video; stillbox popout arrows */
.sb-arrow .wm-ico{width:38px;height:38px;perspective:240px;opacity:1}
.sb-arrow .wm-ring{border-radius:50%;border-color:#bea76c}
.sb-arrow:hover .wm-f{transform:rotateY(180deg)}
.sb-arrow:hover .wm-b{transform:rotateY(360deg)}

/* hide the slate once the hover video reveals (nothing showing through) */
.job .jhero.playing>img.bg{opacity:0;transition:opacity .45s ease}
.job .jhero.playing video{object-fit:contain}
/* play button: drop the circle, keep just the (bigger) arrow */
.job .jhero .wbtn,.job .reel-hero .wbtn{border:0;background:none;backdrop-filter:none;border-radius:0;width:auto;height:auto;padding:0}
.job .jhero .wbtn:hover,.job .reel-hero .wbtn:hover{background:none;border-color:transparent;transform:none}
.job .jhero .wbtn .wm-ring,.job .reel-hero .wbtn .wm-ring{inset:-8px}
/* stills popout arrows: drop the circle, just the (bigger) arrow */
.job .sb-arrow{border:0;background:none;width:auto;height:auto}
.job .sb-arrow:hover{border-color:transparent}

/* mobile rollover layer hidden on desktop */
.mtile{display:none}
@keyframes m-spin{to{transform:rotate(360deg)}}

/* ===== mobile portrait job hero (V.37.2) ===== */
.job .jhero>img.bg-m{display:none}
@media(max-width:760px){
  .job .jhero.has-portrait{height:auto;min-height:0;aspect-ratio:2/3}
  .job .jhero.has-portrait>img.bg{display:none}
  .job .jhero.has-portrait>video{display:none}
  .job .jhero.has-portrait>img.bg-m{display:block;position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;z-index:0}
  .job .jhero.has-portrait .jscroll{display:none}
  .job .lockup .plogo{width:min(72%,420px)}
}

/* Stacked stills (mobile) — vertical run with scroll-reveal; tap opens the existing popup */
.job .jstills .stillstack{display:none;flex-direction:column;gap:.7rem;margin-top:1rem}
.job .jstills .stillframe{width:100%;height:auto;display:block;border:1px solid var(--line);border-radius:4px;background:#000;cursor:zoom-in;opacity:0;transform:translateY(34px);transition:opacity .8s ease,transform .8s cubic-bezier(.2,.7,.2,1);will-change:opacity,transform}
.job .jstills .stillframe.is-in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.job .jstills .stillframe{opacity:1;transform:none;transition:none}}
@media(max-width:760px){.job .jstills .carousel{display:none}.job .jstills .stillstack{display:flex}}

/* Metadata slate — MOBILE ONLY: centred band between the hero image and the copy (75% width). Desktop unchanged. */
.job .jslate-m{display:none}
@media(max-width:760px){
  .job .jslate-m{display:block;margin-top:calc(-1 * clamp(3rem,6.5vw,6rem));padding:clamp(1.5rem,6vw,2.2rem) 0}
  .job .jslate-m .wrapx{display:flex;justify-content:center}
  .job .jslate-m .metaslate{display:block;width:100%;height:auto;object-fit:contain;opacity:.95}
  .job .jslate-m + .jabout{padding-top:0}
  .job .cbar .cslate{display:none}
}

/* Mobile copy: mirror the two columns — left flush-left, right flush-right */
@media(max-width:760px){
  .job .jabout-grid{display:grid;grid-template-columns:1fr 1fr;column-gap:2.6rem}
  .job .jabout-grid p:first-child{text-align:left}
  .job .jabout-grid p:last-child{text-align:right}
  .job .jabout-grid p:only-child{grid-column:1 / -1;text-align:left}
}

/* ===== V.38.2 — homepage masthead band + W-coin ticker (desktop only) ===== */
@media(min-width:761px){
  body.home .masthead{position:relative;top:auto;left:auto;transform:none;width:100%;max-width:var(--site-max);margin:0 auto;z-index:6;padding:4.2rem 2rem 1.2rem}
  .home .stage{position:relative;max-width:none;width:100%;margin:0}
  body.home .hero{height:auto;aspect-ratio:2/1;min-height:0;display:block;background:#000;max-width:none;margin:0}
  .home .hero-vid,.home .hero-still{object-fit:cover}
  .home .hero .scroll-cue{display:none}
  .home .hero-frame{position:absolute;inset:0;pointer-events:none;background:linear-gradient(to top,rgba(0,0,0,.6),rgba(0,0,0,0) 26%)}
  /* ticker over the bottom of the video, raised ~7% */
  .home .ticker-strip{position:absolute;left:0;right:0;bottom:7%;z-index:9;display:flex;flex-direction:column;align-items:center;gap:.55rem;pointer-events:none}
  .home .ticker-label{font-family:var(--mono);font-size:.56rem;letter-spacing:.24em;text-transform:uppercase;color:var(--text);text-shadow:0 1px 10px rgba(0,0,0,.6)}
  .home .ticker{pointer-events:auto;display:flex;align-items:center;gap:clamp(.5rem,1.3vw,1rem);padding:clamp(.36rem,.75vw,.62rem) clamp(.75rem,1.5vw,1.25rem);background:rgba(10,10,11,.24);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border:1.75px solid rgba(255,255,255,.85);border-radius:999px;perspective:520px}
  .home .ticker .coin{appearance:none;-webkit-appearance:none;background:none;border:0;cursor:pointer;padding:0;width:clamp(22px,2vw,32px);height:clamp(22px,2vw,32px);display:block;filter:grayscale(1) opacity(.5);transition:filter .3s,transform .55s cubic-bezier(.2,.7,.2,1)}
  .home .ticker .coin img{width:100%;height:100%;display:block}
  .home .ticker .coin:hover{filter:grayscale(.15) opacity(.9);transform:rotateY(180deg)}
  .home .ticker .coin.is-on{filter:drop-shadow(0 0 6px rgba(190,167,108,.5))}
  .home .ticker .coin.go{animation:coin-flip .65s}
  @keyframes coin-flip{from{transform:rotateY(0)}to{transform:rotateY(360deg)}}
}
/* homepage showreel stage is desktop-only; keep it hidden on the tiles-only mobile homepage */
@media(max-width:760px){ .home .stage{display:none} }

/* ===== V.38.5 — job hero drops below the nav bar + watch button centred (desktop) ===== */
@media(min-width:761px){
  /* push the hero so the top of the still/video meets the bottom of the nav's black bar */
  body.job{padding-top:77px}
  /* watch button centred in the middle of the still/video, not pinned to the bottom */
  .job .jhero .jwatch{justify-content:center;padding-bottom:0}
}
/* homepage: leave a small black gap above the top tile row when WORK scrolls in */
#work{scroll-margin-top:58px}

/* === snag list (V.39.6) === */
/* footer: mail icon replaces the email text, with rollover */
a.email.mailto{position:relative;display:inline-block;width:46px;height:46px;line-height:0;font-size:0}
a.email.mailto .mi{position:absolute;inset:0;width:100%;height:100%;transition:opacity .4s ease,transform .55s cubic-bezier(.34,1.4,.64,1)}
a.email.mailto .mi-2{opacity:0;transform:scale(.96)}
a.email.mailto:hover .mi-1,a.email.mailto:focus-visible .mi-1{opacity:0;transform:scale(1.04)}
a.email.mailto:hover .mi-2,a.email.mailto:focus-visible .mi-2{opacity:1;transform:scale(1)}
a.email.mailto:focus-visible{outline:2px solid currentColor;outline-offset:5px;border-radius:6px}
/* showreel: portrait hero on mobile + watch button centred in frame */
.reel-hero>img.rbg-m{display:none}
body.reel .jwatch{justify-content:center;padding-bottom:0}
@media(max-width:760px){
  .reel-hero>img.rbg{display:none}
  .reel-hero>img.rbg-m{display:block;position:absolute;inset:0;width:100%;height:100%;object-fit:contain;object-position:center 42%}
}
/* Leeds metadata slate: stretch across like the other pages (tall club badge) */
.job .cslate.cslate-wide{height:auto;width:auto;max-width:82%;max-height:70px}
/* stills (white footer): keep the mail diamond visible */
body.stills a.email.mailto .mi-1{filter:drop-shadow(0 0 1.1px rgba(10,10,11,.7))}
