/* Karla — 300 */
@font-face{font-family:'Karla';font-style:normal;font-weight:300;font-display:swap;
  src:url('../fonts/karla-300-latin-ext.woff2') format('woff2');
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Karla';font-style:normal;font-weight:300;font-display:swap;
  src:url('../fonts/karla-300-latin.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
/* Karla — 400 */
@font-face{font-family:'Karla';font-style:normal;font-weight:400;font-display:swap;
  src:url('../fonts/karla-400-latin-ext.woff2') format('woff2');
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Karla';font-style:normal;font-weight:400;font-display:swap;
  src:url('../fonts/karla-400-latin.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#fafaf7;--cream:#f0f0eb;--ink:#351e28;--mid:#8a7780;
  --rule:rgba(53,30,40,0.14);
  --red:#ff5c34;       /* Orange Topaze */
  --blue:#2563eb;      /* Electric cobalt */
  --yellow:#e9f056;    /* Wasabi */
  --sage:#aeb8a0;      /* Vert Sauge — available accent */
  --ls-tight:0.08em;--ls-normal:0.14em;--ls-wide:0.20em;
  --ease:cubic-bezier(.25,.46,.45,.94);
  --ease-out:cubic-bezier(.22,1,.36,1);
  --ease-soft:cubic-bezier(.4,0,.2,1);
}
html{scroll-behavior:smooth}
body{font-family:'Karla',sans-serif;background:var(--bg);color:var(--ink);font-weight:400;letter-spacing:-.005em;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
/* Subtle paper grain — tactile warmth on the cream bg */
body::before{content:'';position:fixed;inset:0;pointer-events:none;z-index:50;opacity:.035;mix-blend-mode:multiply;background-image:url("data:image/svg+xml;utf8,<svg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.6'/></svg>");}

/* PAGE LOADER */
.page-loader{position:fixed;inset:0;z-index:500;background:var(--bg);display:flex;align-items:center;justify-content:center;gap:14px;transition:opacity .5s var(--ease-soft);}
.page-loader.gone{opacity:0;pointer-events:none}
.pl-dot{width:11px;height:11px;border-radius:50%;animation:plBounce 1.1s var(--ease-soft) infinite;}
.pl-dot:nth-child(2){animation-delay:.16s}
.pl-dot:nth-child(3){animation-delay:.32s}
@keyframes plBounce{0%,100%{transform:translateY(0);opacity:.45}50%{transform:translateY(-12px);opacity:1}}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;justify-content:space-between;align-items:center;padding:22px 56px;background:var(--bg);border-bottom:1px solid var(--rule);}
.logo{font-family:'DM Sans',sans-serif;font-size:1rem;font-weight:600;letter-spacing:-.005em;text-transform:uppercase;color:var(--ink);background:none;border:none;cursor:pointer;opacity:0.75;transition:opacity .25s,color .35s ease;}
.logo:hover{opacity:1;color:var(--red)}
.nav-links{display:flex;gap:36px;list-style:none;align-items:center}
.nav-links li{display:flex;align-items:center;gap:6px}
.nav-btn{font-family:'DM Sans',sans-serif;font-size:0.72rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;background:none;border:none;cursor:pointer;color:var(--ink);opacity:0.75;padding:0;transition:opacity .22s,color .35s ease;}
.nav-btn:hover{opacity:1}.nav-btn.on{opacity:1}
nav .nav-links li:nth-child(1) .nav-btn:hover{color:var(--red)}
nav .nav-links li:nth-child(2) .nav-btn:hover{color:var(--blue)}
nav .nav-links li:nth-child(3) .nav-btn:hover{color:var(--yellow)}
.npip{width:6px;height:6px;border-radius:50%;opacity:0;transition:opacity .25s;flex-shrink:0}
.nav-btn.on~.npip{opacity:1}

/* PAGE SYSTEM */
.page{display:none;min-height:100vh}
.page.on{display:block;animation:pin .6s var(--ease-out) both}
@keyframes pin{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}

/* View Transitions API — smooth crossfade between pages on supported browsers */
@media(prefers-reduced-motion: no-preference){
  ::view-transition-old(root),::view-transition-new(root){animation-duration:.55s;animation-timing-function:var(--ease-out)}
}

/* HOME — no page switch, just scrollable */
#page-home{display:block}

/* HERO */
.hero{position:relative;width:100%;height:100vh;overflow:hidden;display:flex;align-items:center;justify-content:center;}
.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse 70% 50% at 25% 65%,rgba(255,92,52,.05) 0%,transparent 65%),radial-gradient(ellipse 50% 70% at 76% 25%,rgba(37,99,235,.06) 0%,transparent 58%),linear-gradient(155deg,#fcfcfa 0%,#f7f7f3 50%,#f2f2ee 100%);}
.hero-name{position:relative;z-index:1;text-align:center;pointer-events:none;animation:heroFade 1s .1s ease both;}
.hero-name h1{font-family:'DM Sans',sans-serif;font-size:clamp(4rem,11vw,11rem);font-weight:600;line-height:.9;color:var(--ink);letter-spacing:-.035em;transition:color .35s ease;pointer-events:auto;cursor:default;}
.hero-name h1:hover{color:var(--red);}
.hero-name p{margin-top:28px;font-size:clamp(.85rem,1.1vw,1.1rem);letter-spacing:var(--ls-wide);text-transform:uppercase;color:var(--ink);opacity:.65;}

/* NAV DOTS — animate the whole wrapper so label moves with circle */
.hero-dot{position:absolute;z-index:3;cursor:pointer;display:flex;align-items:center;gap:14px;animation:heroFade 1.6s ease both,bob 6s ease-in-out infinite;}
.hero-dot .circle{border-radius:50%;flex-shrink:0;transition:transform .35s ease;}
.hero-dot:hover .circle{transform:scale(1.08);}
.hero-dot .dlabel{font-family:'DM Sans',sans-serif;font-size:clamp(.85rem,1vw,1.05rem);font-weight:500;letter-spacing:.04em;color:var(--ink);opacity:.78;white-space:nowrap;transition:color .35s ease,opacity .25s;}
.hero-dot:hover .dlabel{opacity:1;}
.hd-film:hover .dlabel{color:var(--red);}
.hd-art:hover .dlabel{color:var(--blue);}
.hd-about:hover .dlabel{color:var(--yellow);}
.hd-film{top:15%;right:10%;flex-direction:row-reverse;animation-delay:.9s,0s}
.hd-art{bottom:20%;left:8%;animation-delay:1.1s,1.3s}
.hd-about{top:22%;left:9%;animation-delay:1.0s,.7s}
.hd-film .circle{width:68px;height:68px;background:var(--red)}
.hd-art .circle{width:54px;height:54px;background:var(--blue)}
.hd-about .circle{width:46px;height:46px;background:var(--yellow)}
@keyframes heroFade{from{opacity:0}to{opacity:1}}
/* skip intro animations on subsequent home visits (e.g. returning from CV) */
.no-intro .hero-name,.no-intro .explore-cue,.no-intro .scroll-down{animation:none}
.no-intro .hero-dot{animation-name:none,bob}
.no-intro .kw{animation-name:none,kwfloat}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-11px)}}

/* KEYWORD DOTS */
.kw{position:absolute;z-index:2;display:flex;align-items:center;gap:8px;pointer-events:none;animation:heroFade 1.5s ease both,kwfloat 7s ease-in-out infinite;}
.kw .kc{border-radius:50%;flex-shrink:0}
.kw .kl{font-size:clamp(.78rem,.9vw,.95rem);letter-spacing:var(--ls-tight);color:var(--ink);opacity:.5;white-space:nowrap;}
.kw-1{top:37%;right:7%;animation-delay:1.0s,0s;animation-duration:1.5s,7.2s}
.kw-2{top:62%;right:20%;animation-delay:1.1s,1.4s;animation-duration:1.5s,8.1s;flex-direction:row-reverse}
.kw-3{top:52%;left:19%;animation-delay:1.0s,2.8s;animation-duration:1.5s,6.8s}
.kw-4{top:22%;left:44%;animation-delay:1.15s,3.6s;animation-duration:1.5s,8.4s}
.kw-6{top:75%;left:32%;animation-delay:1.05s,2s;animation-duration:1.5s,9s}
.kw-7{top:82%;right:14%;animation-delay:1.2s,4.2s;animation-duration:1.5s,7s}
.kw-9{top:12%;right:32%;animation-delay:1.1s,5s;animation-duration:1.5s,7.4s}
.kw-1 .kc{width:27px;height:27px;background:var(--red)}
.kw-2 .kc{width:17px;height:17px;background:var(--blue)}
.kw-3 .kc{width:22px;height:22px;background:var(--yellow)}
.kw-4 .kc{width:20px;height:20px;background:var(--red)}
.kw-6 .kc{width:13px;height:13px;background:var(--yellow)}
.kw-7 .kc{width:25px;height:25px;background:var(--red)}
.kw-9 .kc{width:15px;height:15px;background:var(--yellow)}
@keyframes kwfloat{0%,100%{transform:translateY(0) translateX(0)}33%{transform:translateY(-10px) translateX(4px)}66%{transform:translateY(-5px) translateX(-4px)}}

/* Wide desktop — scale hero dots up so they fill the viewport (labels handled via clamp above) */
@media(min-width:1200px){
  .hero-dot{gap:14px}
  .hd-film .circle{width:88px;height:88px}
  .hd-art .circle{width:70px;height:70px}
  .hd-about .circle{width:60px;height:60px}
  .kw{gap:11px}
  .kw-1 .kc{width:34px;height:34px}
  .kw-2 .kc{width:21px;height:21px}
  .kw-3 .kc{width:28px;height:28px}
  .kw-4 .kc{width:25px;height:25px}
  .kw-6 .kc{width:17px;height:17px}
  .kw-7 .kc{width:32px;height:32px}
  .kw-9 .kc{width:19px;height:19px}
}

/* EXPLORE CUE — top, horizontal */
.explore-cue{position:absolute;top:29px;left:50%;transform:translateX(-50%);z-index:4;display:flex;align-items:center;gap:8px;pointer-events:none;animation:heroFade 0.8s .3s ease both;}
.explore-cue .ex-label{font-size:.56rem;letter-spacing:var(--ls-wide);text-transform:uppercase;color:var(--ink);opacity:.32;}
.explore-cue .ex-line{width:28px;height:1px;background:var(--ink);opacity:.22;animation:lineGrow 2s ease-in-out 3;}
.explore-cue .ex-arrow svg{opacity:.28;animation:nudge 1.8s ease-in-out 3;}
@keyframes lineGrow{0%{transform:scaleX(0);transform-origin:left}50%{transform:scaleX(1);transform-origin:left}51%{transform:scaleX(1);transform-origin:right}100%{transform:scaleX(0);transform-origin:right}}
@keyframes nudge{0%,100%{transform:translateX(0)}50%{transform:translateX(4px)}}

/* SCROLL CUE — bottom of hero, points down toward about */
.scroll-down{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);z-index:4;display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;pointer-events:all;transition:opacity .2s;animation:heroFade 0.8s .3s ease both;}
.scroll-down:hover{opacity:.6}
.scroll-down .sd-label{font-size:.54rem;letter-spacing:var(--ls-wide);text-transform:uppercase;color:var(--ink);opacity:.32;}
.scroll-down .sd-line{width:1px;height:32px;background:var(--ink);opacity:.2;animation:lineDown 2s ease-in-out 3;}
.scroll-down .sd-arrow{opacity:.25;animation:bounceDown 1.8s ease-in-out 3;}
@keyframes lineDown{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}
@keyframes bounceDown{0%,100%{transform:translateY(0)}50%{transform:translateY(4px)}}

/* ABOUT SECTION — lives below the hero on the home page */
.about-section{background:var(--bg);}
.about-section .ph{padding:90px 56px 48px;display:flex;align-items:flex-end;justify-content:space-between;border-bottom:1px solid var(--rule);}
.about-section .ph-left h2{font-family:'DM Sans',sans-serif;font-size:clamp(2.6rem,5vw,4rem);font-weight:600;letter-spacing:-.03em;color:var(--ink);line-height:1;}
.about-section .ph-left .sub{font-size:.6rem;letter-spacing:var(--ls-wide);text-transform:uppercase;color:var(--mid);margin-bottom:10px;}
.about-section .ph-right{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:6px}
.ph-dot{width:16px;height:16px;border-radius:50%}
.ph-range{font-size:.59rem;letter-spacing:var(--ls-normal);text-transform:uppercase;color:var(--mid)}
.about-spread{display:grid;grid-template-columns:1fr 1fr;min-height:70vh;}
.about-left{padding:64px 56px 80px;border-right:1px solid var(--rule);display:flex;flex-direction:column;justify-content:space-between;}
.about-portrait{width:220px;height:220px;border-radius:50%;margin:40px 0 0 auto;background:var(--cream);border:1px dashed rgba(53,30,40,.28);position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;}
.about-portrait::before{content:'Photo';font-family:'DM Sans',sans-serif;font-weight:500;font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--mid);}
.about-portrait img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 20%;display:block;filter:grayscale(.4);z-index:1;border-radius:50%;}
.about-intro{font-family:'DM Sans',sans-serif;font-size:clamp(1.6rem,2.6vw,2.2rem);font-weight:500;letter-spacing:-.02em;color:var(--ink);line-height:1.3;margin-bottom:40px;}
.about-bio p{font-size:.9rem;font-weight:400;line-height:1.7;color:rgba(26,24,21,.72);margin-bottom:16px;}
.about-dots-row{display:flex;gap:8px;align-items:center;margin-top:40px}
.about-dots-row span{border-radius:50%}
.about-right{padding:64px 48px 80px}
.info-block{padding-bottom:32px;margin-bottom:32px;border-bottom:1px solid var(--rule);}
.info-block:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.ibl{font-size:.57rem;letter-spacing:var(--ls-wide);text-transform:uppercase;color:var(--mid);margin-bottom:8px;}
.ibv{font-size:.9rem;font-weight:400;color:var(--ink);line-height:1.6}
.ibv a{color:var(--ink);text-decoration:none;border-bottom:1px solid var(--rule);transition:border-color .2s}
.ibv a:hover{border-color:var(--ink)}
.ibv small{display:block;font-size:.78rem;opacity:.5;margin-top:3px}
.cv-btn{display:inline-flex;align-items:center;gap:8px;margin-top:36px;padding:11px 22px;font-size:.66rem;letter-spacing:var(--ls-normal);text-transform:uppercase;color:var(--ink);text-decoration:none;border:1px solid rgba(26,24,21,.2);transition:background .22s,color .22s,border-color .22s;}
.cv-btn:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}

/* INNER PAGE HEADER (film/art) */
.ph{padding:90px 56px 48px;display:flex;align-items:flex-end;justify-content:space-between;border-bottom:1px solid var(--rule);}
.ph-left h2{font-family:'DM Sans',sans-serif;font-size:clamp(2.6rem,5vw,4rem);font-weight:600;letter-spacing:-.03em;color:var(--ink);line-height:1;}
.ph-left .sub{font-size:.6rem;letter-spacing:var(--ls-wide);text-transform:uppercase;color:var(--mid);margin-bottom:10px;}
.ph-right{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:6px}

/* FILM */
.film-grid{padding:0 56px 110px}
.film-hero-card{position:relative;overflow:hidden;cursor:pointer;width:100%;aspect-ratio:21/8;background:var(--cream);transition:transform .55s var(--ease-out),box-shadow .55s var(--ease-out);}
.film-hero-card:hover{transform:translateY(-4px);box-shadow:0 14px 36px rgba(26,24,21,.12)}
.film-row{display:grid;grid-template-columns:repeat(3,1fr);gap:3px;padding:3px 0;}
.film-pair{display:grid;grid-template-columns:2fr 1fr;gap:3px;padding:3px 0 0;}
.film-pair .pc:first-child{aspect-ratio:4/3}.film-pair .pc:last-child{aspect-ratio:3/4}
.film-pair .pc:only-child{grid-column:1/-1;aspect-ratio:21/9}
.film-pair.twin{grid-template-columns:1fr 1fr}
.film-pair.twin .pc:first-child,.film-pair.twin .pc:last-child{aspect-ratio:21/16}
@keyframes up{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
/* Reveal-on-scroll for cards and info blocks (driven by IntersectionObserver in app.js) */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .85s var(--ease-soft),transform .85s var(--ease-out);}
.reveal.in{opacity:1;transform:translateY(0);}
@media (prefers-reduced-motion: reduce){.reveal{opacity:1;transform:none;transition:none}}
.pc{position:relative;overflow:hidden;cursor:pointer;aspect-ratio:4/5;background:var(--cream);transition:transform .55s var(--ease-out),box-shadow .55s var(--ease-out);}
.pc:hover{transform:translateY(-4px);box-shadow:0 14px 36px rgba(26,24,21,.12)}
.pc img,.film-hero-card img{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(.65);transition:transform .85s var(--ease-out),filter .7s var(--ease-soft);}
.pc:hover img,.film-hero-card:hover img{transform:scale(1.04);filter:saturate(1)}
.pm{position:absolute;bottom:0;left:0;right:0;padding:20px 22px 18px;background:linear-gradient(to top,rgba(18,14,11,.85) 0%,rgba(18,14,11,.45) 45%,transparent 100%);}
.pt{font-family:'DM Sans',sans-serif;font-size:1.2rem;font-weight:600;letter-spacing:-.015em;color:#f4efe8;line-height:1.1}
.py{font-size:.6rem;letter-spacing:var(--ls-normal);color:rgba(244,239,232,.7);margin-top:4px}
.pdot{position:absolute;top:14px;right:14px;width:8px;height:8px;border-radius:50%}

/* ART */
.art-grid{padding:3px 56px 110px;display:grid;grid-template-columns:repeat(3,1fr);gap:3px;margin-top:3px;}
.art-grid .pc:nth-child(1){aspect-ratio:4/3;grid-column:span 2}
.art-grid .pc:nth-child(2){grid-column:span 1;aspect-ratio:unset;align-self:stretch}
.art-grid .pc:nth-child(3),.art-grid .pc:nth-child(4),.art-grid .pc:nth-child(5){grid-column:span 1}

/* CV PAGE */
.cv-page{padding:96px 56px 60px;display:flex;flex-direction:column;align-items:center;gap:36px;background:var(--bg);animation:up .5s .06s ease both;}
.cv-page img{max-width:600px;width:100%;height:auto;display:block;box-shadow:0 4px 24px rgba(26,24,21,.08);}
.cv-actions{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;}
.cv-back{display:inline-flex;align-items:center;font-family:'Karla',sans-serif;font-size:.66rem;letter-spacing:var(--ls-normal);text-transform:uppercase;color:var(--ink);text-decoration:none;background:none;border:1px solid rgba(26,24,21,.2);padding:11px 22px;cursor:pointer;transition:background .22s,color .22s,border-color .22s;}
.cv-back:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}
@media(max-width:768px){
  .cv-page{padding:48px 20px 40px;gap:24px}
  .cv-page img{max-width:100%}
}

/* MODAL */
.mbkg{position:fixed;inset:0;background:rgba(22,19,16,.78);z-index:200;display:flex;align-items:flex-start;justify-content:center;opacity:0;pointer-events:none;transition:opacity .5s var(--ease-soft);backdrop-filter:blur(6px);overflow:hidden;padding:48px 0 60px;}
.mbkg.on{opacity:1;pointer-events:all}
.mbox{background:var(--bg);width:92vw;max-width:1100px;max-height:calc(100vh - 108px);overflow-y:auto;overscroll-behavior:contain;transform:translateY(28px) scale(.985);transition:transform .65s var(--ease-out);}
.mbkg.on .mbox{transform:translateY(0) scale(1)}
.mclose{position:sticky;top:0;background:var(--bg);z-index:10;display:flex;justify-content:flex-end;padding:13px 18px;border-bottom:1px solid var(--rule);}
.mclose button{background:none;border:none;cursor:pointer;font-size:.6rem;letter-spacing:var(--ls-normal);text-transform:uppercase;color:var(--mid);transition:color .2s;}
.mclose button:hover{color:var(--ink)}
.minner{padding:40px 56px 48px;position:relative;z-index:1;background:var(--bg)}
.mimg-wrap{position:relative;z-index:0;background:var(--bg)}
.mimg{width:100%;aspect-ratio:16/7;object-fit:cover;display:block;transform:scale(1.04);opacity:.6;transition:transform .95s var(--ease-out) .08s,opacity .7s var(--ease-soft) .08s;}
.mbkg.on .mimg{transform:scale(1);opacity:1}
/* Staggered inner content reveal */
.minner > *{opacity:0;transform:translateY(14px);transition:opacity .65s var(--ease-soft),transform .65s var(--ease-out);}
.mbkg.on .minner > .mpill{transition-delay:.24s;opacity:1;transform:translateY(0)}
.mbkg.on .minner > .mtitle{transition-delay:.32s;opacity:1;transform:translateY(0)}
.mbkg.on .minner > .mcredits{transition-delay:.4s;opacity:1;transform:translateY(0)}
.mbkg.on .minner > .mbody{transition-delay:.48s;opacity:1;transform:translateY(0)}
.mbkg.on .minner > .mcoming-soon{transition-delay:.48s;opacity:1;transform:translateY(0)}
@media (prefers-reduced-motion: reduce){
  .mbox,.mbkg.on .mbox{transform:none;transition:none}
  .mimg,.mbkg.on .mimg,.minner > *,.mbkg.on .minner > *{transform:none;opacity:1;transition:none}
}
.mpill{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.mpill-dot{width:7px;height:7px;border-radius:50%}
.mpill span{font-size:.58rem;letter-spacing:var(--ls-wide);text-transform:uppercase;color:var(--mid)}
.mtitle{font-family:'DM Sans',sans-serif;font-size:clamp(2.2rem,4vw,3.2rem);font-weight:600;letter-spacing:-.03em;color:var(--ink);line-height:1;margin-bottom:22px;}
.mcredits{display:grid;grid-template-columns:repeat(4,1fr);gap:14px 28px;margin-bottom:24px;padding-bottom:28px;border-bottom:1px solid var(--rule);}
@media(max-width:1024px){.mcredits{grid-template-columns:repeat(2,1fr)}}
.mcredits div .cl{font-size:.56rem;letter-spacing:var(--ls-normal);text-transform:uppercase;color:var(--mid);margin-bottom:3px}
.mcredits div .cv{font-size:.83rem;color:var(--ink)}
.mbody{font-size:.89rem;font-weight:400;line-height:1.7;color:rgba(26,24,21,.72)}
.mgallery{padding:0 56px 60px;display:grid;grid-template-columns:repeat(3,1fr);gap:3px;align-items:start;background:var(--bg);}
.mgallery.g2{grid-template-columns:repeat(2,1fr)}
.mgallery .gi{overflow:hidden;display:block;cursor:pointer;position:relative;}
.mgallery .gi img,.mgallery .gi video{width:100%;height:auto;display:block;transition:transform .6s var(--ease-out);}
.mgallery .gi:hover img{transform:scale(1.01)}
.mgallery .gi.video{background:#000}
/* hero-grid: first item spans full width; trailing items fall naturally into the left columns */
.mgallery.hero-grid .gi:first-child{grid-column:1/-1}
/* center lone last item in 2-col */
/* square-grid keeps cover crop */
.mgallery.square-grid .gi{aspect-ratio:1/1}
.mgallery.square-grid .gi img,.mgallery.square-grid .gi video{width:100%;height:100%;object-fit:cover}
/* uniform-grid — true 3-col grid with 4:3 cells, images cover-crop to fit (no gaps, ever) */
.mgallery.uniform-grid .gi{aspect-ratio:4/3}
.mgallery.uniform-grid .gi img,.mgallery.uniform-grid .gi video{width:100%;height:100%;object-fit:cover}
/* stack: narrow 2-col */
.mgallery.stack{padding:0 20% 60px;grid-template-columns:repeat(2,1fr)}
/* masonry: tight column-packed flow for varied aspect ratios */
.mgallery.masonry{display:block;column-count:3;column-gap:3px;}
.mgallery.masonry .gi{break-inside:avoid;margin-bottom:3px;}
.mgallery.masonry .gi:first-child{column-span:all;margin-bottom:3px;}
.mcoming-soon{margin:24px 0 0;padding:8px 0;background:transparent;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;}
.mcoming-soon .mcs-line{font-family:'DM Sans',sans-serif;font-weight:500;font-size:1.2rem;letter-spacing:-.015em;color:var(--ink);opacity:.78;}
.mcoming-soon .mcs-sub{font-size:.58rem;letter-spacing:var(--ls-wide);text-transform:uppercase;color:var(--mid);}
#mgallery-slot{position:relative;z-index:1;background:var(--bg)}
.mgallery-label{padding:56px 56px 16px;font-size:.58rem;letter-spacing:var(--ls-wide);text-transform:uppercase;color:var(--mid);border-top:1px solid var(--rule);background:var(--bg);}
.mbox::-webkit-scrollbar{width:3px}.mbox::-webkit-scrollbar-track{background:transparent}.mbox::-webkit-scrollbar-thumb{background:rgba(26,24,21,.1);border-radius:2px}
/* MODAL PROJECT NAV */
.mnav{display:flex;justify-content:space-between;align-items:stretch;border-bottom:1px solid var(--rule);background:var(--bg);padding:0;position:relative;z-index:2;}
.mnav:empty{display:none}
.mnav-btn{flex:1;background:none;border:none;cursor:pointer;padding:18px 56px;display:flex;align-items:center;gap:18px;color:var(--ink);transition:background .22s;}
.mnav-btn:hover{background:rgba(26,24,21,.04)}
.mnav-prev{justify-content:flex-start;text-align:left;border-right:1px solid var(--rule)}
.mnav-next{justify-content:flex-end;text-align:right}
.mnav-arrow{font-size:1.2rem;color:var(--mid);transition:transform .22s,color .22s;}
.mnav-prev:hover .mnav-arrow{transform:translateX(-3px);color:var(--ink)}
.mnav-next:hover .mnav-arrow{transform:translateX(3px);color:var(--ink)}
.mnav-meta{display:flex;flex-direction:column;gap:4px;}
.mnav-label{font-size:.56rem;letter-spacing:var(--ls-wide);text-transform:uppercase;color:var(--mid)}
.mnav-title{font-family:'DM Sans',sans-serif;font-size:1rem;font-weight:600;letter-spacing:-.015em;color:var(--ink);line-height:1.1}

/* LIGHTBOX */
.lb{position:fixed;inset:0;z-index:300;background:rgba(10,8,6,.92);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .4s var(--ease-soft);backdrop-filter:blur(8px);}
.lb.on{opacity:1;pointer-events:all}
.lb-img{max-width:90vw;max-height:85vh;object-fit:contain;display:block;transition:opacity .2s;}
.lb-close,.lb-prev,.lb-next{background:none;border:none;cursor:pointer;color:rgba(255,255,255,.5);transition:color .2s;padding:18px;display:flex;align-items:center;justify-content:center;}
.lb-close{position:absolute;top:14px;right:20px;z-index:1}
.lb-prev,.lb-next{position:absolute;top:50%;transform:translateY(-50%);z-index:1;width:64px;height:64px}
.lb-prev{left:24px}.lb-next{right:24px}
.lb-close:hover,.lb-prev:hover,.lb-next:hover{color:#fff}
.lb-counter{position:absolute;top:18px;left:24px;font-family:'Karla',sans-serif;font-weight:400;font-size:.7rem;letter-spacing:var(--ls-wide);color:rgba(255,255,255,.55);font-variant-numeric:tabular-nums;}

/* FOOTER */
.site-footer{border-top:1px solid var(--rule);padding:56px 56px 40px;display:grid;grid-template-columns:1fr auto 1fr;gap:32px;align-items:center;}
.ftl{display:flex;flex-direction:column;gap:6px}
.ftl .fn{font-family:'DM Sans',sans-serif;font-size:1.1rem;font-weight:600;letter-spacing:-.01em;color:var(--ink);opacity:.85;}
.ftl .fmeta{font-size:.6rem;letter-spacing:var(--ls-wide);text-transform:uppercase;color:var(--mid);}
.ftc{text-align:center;font-family:'DM Sans',sans-serif;font-size:.7rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--mid);}
.ftr{display:flex;align-items:center;justify-content:flex-end;gap:20px}
.flink{font-size:.6rem;letter-spacing:var(--ls-normal);text-transform:uppercase;color:var(--mid);text-decoration:none;border-bottom:1px solid var(--rule);transition:color .2s,border-color .2s;}.flink:hover{color:var(--ink);border-color:var(--ink)}
.fdots{display:flex;gap:7px;align-items:center}
.fdots span{width:9px;height:9px;border-radius:50%}

@media(max-width:768px){
  nav{padding:18px 20px}.nav-links{gap:18px}
  .ph{padding:80px 20px 36px;flex-direction:column;align-items:flex-start;gap:10px}
  .about-section .ph{padding:80px 20px 36px;flex-direction:column;align-items:flex-start;gap:10px}
  .film-grid,.art-grid{padding-left:20px;padding-right:20px}
  .film-row{grid-template-columns:1fr}.film-pair{grid-template-columns:1fr}
  .film-hero-card{aspect-ratio:4/3}
  .art-grid{grid-template-columns:1fr}.art-grid .pc{grid-column:span 1!important;aspect-ratio:4/3!important}
  .about-spread{grid-template-columns:1fr}
  .about-left{padding:32px 20px 40px;border-right:none;border-bottom:1px solid var(--rule)}
  .about-right{padding:32px 20px 48px}
  .about-bio p{font-size:.95rem}
  .kw-2,.kw-4,.kw-6,.kw-7,.kw-9{display:none}
  .minner{padding:22px 18px 0}.mgallery{padding:0 18px 40px;grid-template-columns:repeat(2,1fr)}.mgallery.g2{grid-template-columns:repeat(2,1fr)}.mgallery.stack{padding:0 18px 40px;grid-template-columns:1fr}.mgallery.stack .gi:last-child:nth-child(2n+1){grid-column:auto;justify-self:auto;width:100%}.mgallery.masonry{column-count:2}
  .mgallery-label{padding:40px 18px 12px}
  .site-footer{grid-template-columns:1fr;text-align:center;gap:18px;padding:36px 20px}
  .ftr{justify-content:center}
  .ftl{align-items:center}
  .about-portrait{width:160px;height:160px;aspect-ratio:auto;margin:28px 0 0 auto}
  .mcoming-soon{margin:24px 0 0;padding:24px 0 4px}
  .ph-right{align-self:flex-end}
  .kw-3{top:30%}
  .mnav-btn{padding:16px 18px;gap:10px}.mnav-title{font-size:.85rem}.mnav-label{font-size:.52rem}.mnav-arrow{font-size:1rem}
}
@media(max-width:480px){
  .mnav-label{display:none}
  .mnav-btn{padding:14px 14px;gap:8px}
  .mnav-title{font-size:.78rem}
}
