:root{
  --paper:#ede8d4;--ink:#13110c;--ink-soft:#857d6c;--line:#d8d0bb;--accent:#c0291b;
  --maxw:1280px;--pad:clamp(18px,4.5vw,54px);
  --serif:'Newsreader',Georgia,serif;
  --sans:'Archivo',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--paper);color:var(--ink);font-family:var(--sans);font-optical-sizing:auto;-webkit-font-smoothing:antialiased;overflow-x:hidden;min-height:100vh;display:flex;flex-direction:column}
a{color:inherit;text-decoration:none}
body::before{content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.10;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.68' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

header{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:baseline;justify-content:space-between;
  padding:20px var(--pad);background:var(--paper)}
.wordmark{font-family:var(--sans);font-weight:500;font-size:16px;letter-spacing:0;display:inline-flex;align-items:center;gap:11px}
.wordmark .brand-mark{width:28px;height:28px;display:block;flex:0 0 auto}
nav{display:flex;gap:clamp(14px,2.2vw,30px)}
nav a{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);transition:color .3s}
nav a:hover{color:var(--ink)} nav a.ig:hover{color:var(--accent)}
nav a.active{color:var(--accent)}

main{padding-top:clamp(96px,14vh,160px);flex:1 1 auto}
.block{max-width:var(--maxw);margin:0 auto;padding:clamp(26px,4vw,52px) var(--pad)}

.row{display:flex;gap:var(--gap,14px);margin-bottom:var(--gap,14px)}
.rows.stream{display:flex;flex-direction:column;gap:clamp(52px,7vw,100px);align-items:center}
.rows.stream figure{--ar:1;width:min(100%,calc(86vh*var(--ar)));aspect-ratio:var(--ar);cursor:zoom-in;background:#e3dcc8}
.rows.stream figure::after{content:"+";display:flex;align-items:center;justify-content:center;color:#fff;font-size:clamp(36px,5vw,64px);font-weight:200;background:rgba(20,18,15,.38);text-shadow:0 2px 16px rgba(0,0,0,.5);line-height:1}

/* Copyright: prevent drag / long-press save */
img{-webkit-user-drag:none;user-select:none;-webkit-touch-callout:none}

/* Lightbox */
.lightbox{position:fixed;inset:0;z-index:1000;background:rgba(8,7,5,.96);display:flex;align-items:center;justify-content:center;animation:lbFade .22s ease;padding-bottom:72px}
@keyframes lbFade{from{opacity:0}to{opacity:1}}
.lb-img{max-width:96vw;max-height:calc(100vh - 92px);object-fit:contain;display:block;animation:lbImg .35s ease}
@keyframes lbImg{from{opacity:0;transform:scale(.98)}to{opacity:1;transform:none}}
.lb-close,.lb-prev,.lb-next{position:absolute;background:transparent;border:0;color:rgba(255,255,255,.72);cursor:pointer;transition:color .25s,transform .25s;line-height:1;font-family:var(--sans);font-weight:200}
.lb-close:hover,.lb-prev:hover,.lb-next:hover{color:#fff}
.lb-close{top:16px;right:22px;font-size:34px;padding:8px 12px}
.lb-prev,.lb-next{top:calc(50% - 36px);transform:translateY(-50%);font-size:54px;padding:18px 22px}
.lb-prev{left:12px}
.lb-next{right:12px}
.lb-prev:hover{transform:translate(-4px,-50%)}
.lb-next:hover{transform:translate(4px,-50%)}
.lb-counter{position:absolute;bottom:80px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.55);font-size:11px;letter-spacing:.06em;font-variant-numeric:tabular-nums}
.lb-strip{position:absolute;bottom:0;left:0;right:0;height:72px;display:flex;align-items:center;gap:4px;overflow-x:auto;overflow-y:hidden;padding:0 18px;background:rgba(8,7,5,.88);scrollbar-width:none}
.lb-strip::-webkit-scrollbar{display:none}
.lb-thumb{height:50px;width:auto;flex:0 0 auto;cursor:pointer;opacity:.38;transition:opacity .2s;-webkit-user-drag:none;user-select:none;-webkit-touch-callout:none}
.lb-thumb:hover{opacity:.72}
.lb-thumb.active{opacity:1;outline:2px solid rgba(255,255,255,.85);outline-offset:1px}
body[data-mode="recent"] .block,body[data-mode="series"] .block{max-width:min(1600px,92vw)}
body[data-mode="recent"] main,body[data-mode="work"] main{padding-top:clamp(62px,8vh,76px)}
body[data-mode="recent"] .block,body[data-mode="work"] .block{padding-top:clamp(14px,1.8vw,22px)}
body[data-mode="series"] main{padding-top:0}
body[data-mode="series"] .block{display:grid;grid-template-columns:clamp(150px,14vw,200px) 1fr;padding:0;max-width:100%;align-items:start}
body[data-mode="series"] .series-detail-head{position:sticky;top:68px;height:calc(100vh - 68px);padding:clamp(16px,2.4vh,24px) clamp(14px,2vw,22px);display:flex;flex-direction:column;gap:6px;border-right:1px solid var(--line)}
body[data-mode="series"] .series-detail-head .back-link{margin-bottom:18px;color:var(--ink);font-size:12px;letter-spacing:.02em;text-transform:none}
.series-sidenav{display:flex;flex-direction:column;gap:0;margin-top:6px}
.series-sidenav a{font-size:12px;font-weight:400;color:var(--ink-soft);padding:4px 0;transition:color .2s;line-height:1.5}
.series-sidenav a:hover{color:var(--ink)}
.series-sidenav a.active{color:var(--accent);font-weight:600}
/* series viewer */
.series-viewer{position:relative;height:calc(100vh - 68px);display:flex;flex-direction:column;min-width:0}
.viewer-stage{flex:1;min-height:0;display:flex;align-items:center;justify-content:center;padding:clamp(12px,1.8vh,20px) clamp(40px,5vw,80px) 0;overflow:hidden}
.viewer-img{display:block;max-width:100%;max-height:100%;min-height:0;width:auto;height:auto;object-fit:contain;opacity:0;transition:opacity .25s ease;-webkit-user-drag:none;user-select:none;-webkit-touch-callout:none}
.viewer-prev,.viewer-next{position:absolute;top:50%;transform:translateY(calc(-50% - 38px));background:transparent;border:0;color:var(--ink);opacity:.18;font-size:30px;font-weight:300;cursor:pointer;padding:14px 12px;transition:opacity .2s;line-height:1;z-index:2}
.viewer-prev:hover,.viewer-next:hover{opacity:.65}
.viewer-prev{left:0}
.viewer-next{right:0}
.viewer-counter{text-align:center;font-size:11px;color:var(--ink-soft);letter-spacing:.06em;padding:6px 0 5px;font-variant-numeric:tabular-nums;flex-shrink:0}
.viewer-strip{height:66px;display:flex;align-items:center;gap:4px;overflow-x:auto;overflow-y:hidden;padding:0 clamp(10px,1.5vw,20px);border-top:1px solid var(--line);flex-shrink:0;scrollbar-width:none}
.viewer-strip::-webkit-scrollbar{display:none}
.viewer-thumb{height:44px;width:auto;flex:0 0 auto;cursor:pointer;opacity:.32;transition:opacity .2s;-webkit-user-drag:none;user-select:none;-webkit-touch-callout:none}
.viewer-thumb:hover{opacity:.68}
.viewer-thumb.active{opacity:1;outline:2px solid var(--ink);outline-offset:1px}
@media(max-width:640px){
  body[data-mode="series"] main{padding-top:clamp(64px,9vh,80px)}
  body[data-mode="series"] .block{grid-template-columns:1fr}
  body[data-mode="series"] .series-detail-head{position:static;height:auto;border-right:0;padding:0 0 16px}
}

/* ── work index (3-col series grid) ── */
.work-index{padding-top:clamp(20px,3vw,40px)}
body[data-mode="work"] .block.work-index{max-width:min(1500px,92vw)}
.series-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(36px,4.5vw,64px)}
.series-card{display:block;text-decoration:none;color:inherit;cursor:pointer}
.series-cover{position:relative;aspect-ratio:3/2;overflow:hidden;background:#e3dcc8}
.series-cover img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.1s cubic-bezier(.16,1,.3,1)}
.series-card:hover .series-cover img{transform:scale(1.03)}
.series-card-meta{padding:12px 0 0;display:flex;justify-content:space-between;align-items:baseline;gap:12px}
.series-card-name{font-family:var(--sans);font-size:clamp(13px,1.1vw,15px);font-weight:400;letter-spacing:0;color:var(--ink)}
@media(max-width:700px){.series-grid{grid-template-columns:1fr;gap:40px}}

/* ── series detail head ── */
.series-detail-head{padding-bottom:clamp(20px,3vw,36px)}
.series-detail-head .back-link{display:inline-block;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:clamp(18px,3vw,32px);transition:color .3s}
.series-detail-head .back-link:hover{color:var(--ink)}
.series-detail-head p{margin-top:14px;font-size:11.5px;letter-spacing:.04em;color:var(--ink-soft)}

/* ── landing (index.html) ── */
body[data-mode="landing"]{overflow:hidden;height:100vh}
.landing-stage{position:fixed;inset:0;display:block;background:#0a0908;overflow:hidden}
.landing-cover{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;opacity:0;transition:opacity 1.2s ease;pointer-events:none}
.landing-cover.loaded{opacity:1}
.landing-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,9,8,.42) 0%,rgba(10,9,8,.08) 22%,rgba(10,9,8,0) 55%,rgba(10,9,8,.62) 100%);pointer-events:none;z-index:2}
.landing-meta{position:absolute;left:var(--pad);bottom:clamp(28px,5vw,56px);color:#fff;z-index:3;text-shadow:0 1px 22px rgba(0,0,0,.45);pointer-events:none}
.landing-meta h1{font-family:var(--sans);font-weight:400;font-size:clamp(30px,5vw,68px);letter-spacing:-.02em;line-height:1.05}
.landing-meta p{margin-top:12px;font-size:11px;letter-spacing:.08em;text-transform:uppercase;opacity:.88}
.landing-enter{position:absolute;right:var(--pad);bottom:clamp(28px,5vw,56px);color:#fff;font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;z-index:4;opacity:.8;transition:opacity .3s;text-decoration:none;padding:10px 4px 10px 14px;cursor:pointer}
.landing-enter .arrow{display:inline-block;margin-left:8px;transition:transform .3s ease}
.landing-enter:hover{opacity:1}
.landing-enter:hover .arrow{transform:translateX(6px)}
.landing-nav{position:fixed;top:24px;right:var(--pad);display:flex;gap:clamp(14px,2.2vw,30px);z-index:10}
.landing-nav a{color:rgba(255,255,255,.85);font-size:11px;letter-spacing:.08em;text-transform:uppercase;transition:color .3s}
.landing-nav a:hover{color:#fff}
.landing-nav a.ig:hover{color:var(--accent)}
figure{position:relative;overflow:hidden;background:#e3dcc8;cursor:pointer}
figure img{display:block;width:100%;height:100%;object-fit:cover}
figure .cap{position:absolute;left:0;right:0;bottom:0;z-index:3;padding:26px 16px 13px;font-size:10.5px;letter-spacing:.06em;
  text-transform:none;color:#fff;background:linear-gradient(0deg,rgba(0,0,0,.55),transparent);opacity:0;transform:translateY(6px);transition:.45s}
figure:hover .cap{opacity:1;transform:none}
figure::after{content:"";position:absolute;inset:0;background:rgba(20,18,15,.05);opacity:0;transition:.45s}
figure:hover::after{opacity:1}
.lead{width:100vw;position:relative;left:50%;transform:translateX(-50%);margin-bottom:clamp(26px,4vw,52px);background:#e3dcc8}
.lead img{display:block;width:100%;height:auto;max-height:88vh;object-fit:cover}
.lead .cap{position:absolute;left:var(--pad);bottom:22px;color:#fff;font-size:10.5px;letter-spacing:.04em;text-shadow:0 1px 12px rgba(0,0,0,.6)}

footer.page-foot{max-width:var(--maxw);margin:clamp(24px,3vw,44px) auto 0;border-top:1px solid var(--line);padding:11px var(--pad) 13px;text-align:center}
.copy{font-size:10px;letter-spacing:.06em;color:var(--ink-soft);text-transform:uppercase}

/* Contact page */
.contact-block{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(48px,7vw,120px);max-width:min(1400px,92vw);margin:0 auto;padding:clamp(20px,4vh,60px) var(--pad) clamp(40px,6vw,80px)}
.contact-intro h1{font-family:var(--sans);font-weight:400;font-size:clamp(28px,4vw,52px);letter-spacing:-.02em;line-height:1.08;margin-bottom:clamp(20px,3vw,36px)}
.contact-intro .lead-text{font-size:clamp(14.5px,1.3vw,17px);line-height:1.6;color:var(--ink-soft);max-width:38em;margin-bottom:clamp(28px,4vw,48px)}
.contact-direct{display:flex;flex-direction:column;gap:10px}
.contact-direct a{display:inline-block;font-size:12px;letter-spacing:.04em;color:var(--ink-soft);width:fit-content;transition:color .25s;text-decoration:none}
.contact-direct a:hover{color:var(--ink)}

.contact-form{display:flex;flex-direction:column;gap:clamp(22px,2.6vw,34px)}
.form-row.two{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,2.4vw,32px)}
.form-field{display:flex;flex-direction:column;gap:8px}
.form-field label{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft)}
.form-field .req{color:var(--accent)}
.form-field input,.form-field textarea{font:inherit;border:0;border-bottom:1px solid var(--line);background:transparent;padding:9px 0;transition:border-color .2s;color:var(--ink);width:100%}
.form-field input:focus,.form-field textarea:focus{outline:none;border-color:var(--ink)}
.form-field textarea{resize:vertical;min-height:90px;font-family:var(--sans)}
.form-submit{font:inherit;font-weight:400;border:1px solid var(--ink);background:var(--ink);color:var(--paper);padding:12px 28px;cursor:pointer;letter-spacing:.04em;text-transform:uppercase;font-size:11px;transition:opacity .2s;align-self:flex-start;margin-top:6px}
.form-submit:hover{opacity:.88}
.form-note{font-size:11px;color:var(--ink-soft);margin-top:-6px;letter-spacing:.04em}

@media(max-width:780px){.contact-block{grid-template-columns:1fr;gap:48px;padding-top:clamp(80px,12vh,140px)}.form-row.two{grid-template-columns:1fr}}

figure,.lead{opacity:0;transform:translateY(20px);transition:opacity .8s ease,transform .8s cubic-bezier(.16,1,.3,1)}
figure.in,.lead.in{opacity:1;transform:none}
@media(max-width:640px){nav a:not(.ig){display:none}.head .note{text-align:left}}
