/* ============================================================
   DMLfoto — "Contact Sheet" · editorial-minimal, neutral grey
   Display/body: Jost (light)   ·   Meta/index: IBM Plex Mono
   ============================================================ */
:root{
  --bg:#ececec;            /* neutral light grey */
  --bg-2:#e4e4e3;          /* slightly deeper grey for bands */
  --surface:#f6f6f5;
  --ink:#1b1c20;           /* dark grey / ink */
  --ink-soft:#3a3b40;
  --muted:#74747c;
  --accent:#9e3b2e;        /* dark red */
  --accent-2:#b75a3c;      /* logo rust */
  --line:#d6d6d4;
  --line-strong:#c4c4c1;
  --maxw:1200px;
  --sans:'Jost',ui-sans-serif,system-ui,-apple-system,"Segoe UI",sans-serif;
  --mono:'IBM Plex Mono',ui-monospace,"SFMono-Regular",Menlo,monospace;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{background:var(--bg);color:var(--ink);font-family:var(--sans);font-weight:300;line-height:1.62;-webkit-font-smoothing:antialiased;
  /* faint paper texture for atmosphere */
  background-image:radial-gradient(rgba(0,0,0,.015) 1px,transparent 1px);background-size:4px 4px}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,4vw,36px);width:100%}
.sr-only{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}
.skip{position:fixed;left:14px;top:-60px;z-index:200;background:var(--ink);color:#fff;padding:10px 16px;border-radius:5px;font-size:14px;transition:top .2s}
.skip:focus{top:14px}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
.mono{font-family:var(--mono)}
.empty{color:var(--muted);padding:48px 0;font-size:17px}
.empty a{color:var(--accent);border-bottom:1px solid var(--accent)}

/* ---------- aperture motif ---------- */
.ap-mark{width:46px;height:46px;color:var(--ink);flex:none}
.ap-hero{position:absolute;color:var(--ink);opacity:.05;pointer-events:none}

/* ---------- header / nav ---------- */
.site-head{position:sticky;top:0;z-index:60;background:rgba(236,236,236,.82);backdrop-filter:blur(12px) saturate(1.1);border-bottom:1px solid var(--line);transition:transform .35s var(--ease)}
.site-head.hide{transform:translateY(-100%)}
.nav{display:flex;align-items:center;justify-content:space-between;height:76px}
.logo img{height:34px}
nav ul{display:flex;gap:36px;list-style:none;align-items:center}
nav a{font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);transition:color .25s;position:relative;padding:6px 0}
nav a span{position:relative}
nav a span::after{content:"";position:absolute;left:0;bottom:-3px;width:100%;height:1px;background:var(--accent);transform:scaleX(0);transform-origin:right;transition:transform .3s var(--ease)}
nav a:hover{color:var(--ink)}
nav a:hover span::after{transform:scaleX(1);transform-origin:left}
nav a.active{color:var(--ink)}
nav a.active span::after{transform:scaleX(1)}
.social{display:flex;gap:16px}
.social a{color:var(--muted);display:inline-flex}
.social svg{width:18px;height:18px;transition:.2s}
.social a:hover svg{color:var(--accent);transform:translateY(-1px)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.burger span{width:24px;height:1.5px;background:var(--ink);transition:.25s var(--ease)}
body.nav-open .burger span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
body.nav-open .burger span:nth-child(2){opacity:0}
body.nav-open .burger span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* ---------- crop-mark frame (signature graphic) ---------- */
.cropframe{position:relative}
.cropframe::before,.cropframe::after{content:"";position:absolute;inset:-9px;pointer-events:none;z-index:2}
.cropframe::before{
  background:
    linear-gradient(var(--accent),var(--accent)) left top/15px 1.5px no-repeat,
    linear-gradient(var(--accent),var(--accent)) left top/1.5px 15px no-repeat,
    linear-gradient(var(--accent),var(--accent)) right top/15px 1.5px no-repeat,
    linear-gradient(var(--accent),var(--accent)) right top/1.5px 15px no-repeat}
.cropframe::after{
  background:
    linear-gradient(var(--accent),var(--accent)) left bottom/15px 1.5px no-repeat,
    linear-gradient(var(--accent),var(--accent)) left bottom/1.5px 15px no-repeat,
    linear-gradient(var(--accent),var(--accent)) right bottom/15px 1.5px no-repeat,
    linear-gradient(var(--accent),var(--accent)) right bottom/1.5px 15px no-repeat}

/* ---------- hero ---------- */
.hero{position:relative;padding:clamp(64px,11vw,118px) 0 clamp(40px,6vw,60px);text-align:center;border-bottom:1px solid var(--line);overflow:hidden}
.hero.hero-slim{padding:clamp(56px,8vw,84px) 0 clamp(30px,4vw,44px)}
.hero .ap-hero{width:min(58vw,560px);height:min(58vw,560px);left:50%;top:46%;transform:translate(-50%,-50%)}
.hero .eyebrow{font-family:var(--mono);font-weight:400;font-size:12px;letter-spacing:.42em;text-transform:uppercase;color:var(--accent);margin-bottom:22px}
.hero h1{font-weight:200;font-size:clamp(40px,7.4vw,82px);line-height:1.02;letter-spacing:-.015em;position:relative}
.hero h1 em{font-style:normal;color:var(--accent)}
.hero p{max-width:540px;margin:24px auto 0;color:var(--muted);font-size:clamp(16px,2vw,18px);position:relative}
.hero .place{font-family:var(--mono);font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--muted);margin-top:30px;position:relative}
/* staggered load */
.hero .eyebrow,.hero h1,.hero p,.hero .place{opacity:0;animation:rise .9s var(--ease) forwards}
.hero h1{animation-delay:.08s}
.hero p{animation-delay:.18s}
.hero .place{animation-delay:.26s}
@keyframes rise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}

/* ---------- filter pills ---------- */
.filter,.gallery-filter{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap;padding:30px 0;border-bottom:1px solid var(--line)}
.pill{font-family:var(--mono);font-size:12px;letter-spacing:.04em;padding:7px 15px;border:1px solid var(--line-strong);border-radius:30px;color:var(--muted);background:transparent;cursor:pointer;transition:.22s var(--ease)}
.pill:hover{border-color:var(--ink);color:var(--ink);transform:translateY(-1px)}
.pill.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.pill .ct{opacity:.55;margin-left:6px;font-size:11px}
.filter .sep{width:1px;height:18px;background:var(--line-strong);margin:0 6px}

/* ---------- journal ---------- */
.journal{padding:clamp(48px,7vw,72px) 0 20px;counter-reset:entry}
.month-label{display:flex;align-items:baseline;gap:16px;margin:0 0 8px}
.month-label h2{font-weight:300;font-size:clamp(22px,3vw,28px);letter-spacing:.01em}
.month-label .yr{font-family:var(--mono);color:var(--accent);font-size:13px;letter-spacing:.12em}
.month-label .rule{flex:1;height:1px;background:var(--line)}

.entry{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,62px);align-items:center;padding:clamp(44px,6vw,76px) 0;counter-increment:entry;position:relative}
.entry+.entry{border-top:1px solid var(--line)}
.entry:nth-child(even) .ph{order:2}
.entry .ph{position:relative}
.entry .ph .img-wrap{position:relative;overflow:hidden;background:var(--bg-2);aspect-ratio:4/3}
.entry .ph img{width:100%;height:100%;object-fit:cover;filter:grayscale(.16);transition:transform 1s var(--ease),filter .6s}
.entry:hover .ph img{transform:scale(1.045);filter:grayscale(0)}
.entry .ph-empty{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--muted);font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase}
.entry .txt{position:relative}
.entry .txt::before{content:counter(entry,decimal-leading-zero);font-family:var(--mono);font-weight:300;position:absolute;right:0;top:-46px;font-size:clamp(60px,9vw,104px);color:var(--ink);opacity:.05;line-height:1;pointer-events:none}
.entry .meta{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.entry .meta .frame-no{font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--accent)}
.entry .meta .date{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.entry .meta .tick{width:22px;height:1px;background:var(--line-strong)}
.entry h3{font-weight:300;font-size:clamp(24px,3.4vw,34px);line-height:1.12;margin-bottom:14px;letter-spacing:-.01em}
.entry h3 a{background-image:linear-gradient(var(--accent),var(--accent));background-size:0 1px;background-repeat:no-repeat;background-position:left bottom;transition:background-size .35s var(--ease)}
.entry h3 a:hover{background-size:100% 1px}
.entry p{color:var(--muted);font-size:16px;max-width:46ch}
.entry .more{display:inline-flex;align-items:center;gap:9px;margin-top:22px;font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink)}
.entry .more::after{content:"";width:26px;height:1px;background:var(--accent);transition:width .3s var(--ease)}
.entry .more:hover::after{width:44px}

/* ---------- single entry ---------- */
.single{padding:clamp(36px,5vw,52px) 0 40px}
.single .crumb{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.single .crumb:hover{color:var(--accent)}
.single .s-meta{display:flex;align-items:center;gap:12px;margin:28px 0 12px}
.single .s-meta .date{font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent)}
.single .s-meta .tick{width:30px;height:1px;background:var(--line-strong)}
.single h1{font-weight:200;font-size:clamp(30px,5vw,56px);line-height:1.06;letter-spacing:-.01em}
.single-photo{margin:clamp(32px,5vw,52px) auto;max-width:1100px;padding:0 clamp(20px,4vw,40px)}
.single-photo .cropframe{display:block}
.single-photo img{width:100%;background:var(--bg-2)}
.single-body{max-width:680px}
.single-body p{font-size:clamp(17px,2.2vw,19px);color:var(--ink-soft);line-height:1.85}
.single-share{display:flex;gap:18px;margin-top:34px;font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase}
.single-share a{color:var(--muted);border-bottom:1px solid var(--line-strong);padding-bottom:3px;transition:.2s}
.single-share a:hover{color:var(--accent);border-color:var(--accent)}
.entry-nav{display:flex;justify-content:space-between;gap:20px;border-top:1px solid var(--line);margin-top:46px;padding-top:26px}
.entry-nav a{max-width:46%}
.entry-nav .lbl{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:6px}
.entry-nav .ttl{font-size:17px;color:var(--ink);transition:.2s}
.entry-nav a:hover .ttl{color:var(--accent)}
.entry-nav .next{text-align:right;margin-left:auto}

/* ---------- gallery (masonry) ---------- */
.gallery-intro{display:flex;align-items:baseline;gap:14px;padding-top:34px}
.grid{column-count:3;column-gap:18px;padding:40px 0 10px}
.tile{break-inside:avoid;margin:0 0 18px;position:relative;overflow:hidden;background:var(--bg-2);cursor:zoom-in;display:block}
.tile img{width:100%;display:block;filter:grayscale(.12);transition:transform .8s var(--ease),filter .5s}
.tile:hover img{transform:scale(1.05);filter:grayscale(0)}
.tile .tile-no{position:absolute;top:10px;left:12px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:#fff;mix-blend-mode:difference;opacity:.85;z-index:2}
.tile figcaption{position:absolute;left:0;right:0;bottom:0;padding:34px 14px 14px;color:#fff;font-size:14px;background:linear-gradient(transparent,rgba(18,18,20,.74));opacity:0;transform:translateY(8px);transition:.3s var(--ease);display:flex;flex-direction:column;gap:4px}
.tile:hover figcaption{opacity:1;transform:none}
.tile .tag{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent-2)}
.tile.hide{display:none}

/* ---------- lightbox ---------- */
.lightbox{position:fixed;inset:0;z-index:120;background:rgba(16,16,18,.95);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s var(--ease)}
.lightbox.open{opacity:1}
.lightbox[hidden]{display:none}
.lb-stage{max-width:92vw;max-height:84vh;display:flex;align-items:center;justify-content:center}
.lb-stage img{max-width:92vw;max-height:84vh;object-fit:contain;border:1px solid rgba(255,255,255,.1);box-shadow:0 30px 80px -30px rgba(0,0,0,.7)}
.lightbox .lb-bar{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:20px 24px;color:#e6e6e6;font-family:var(--mono);font-size:12px;letter-spacing:.1em}
.lightbox .lb-count{color:var(--accent-2)}
.lightbox .lb-caption{position:absolute;bottom:0;left:0;right:0;text-align:center;color:#ccc;padding:18px;font-size:14px;letter-spacing:.03em}
.lightbox button{background:none;border:0;color:#fff;cursor:pointer;font-weight:200;transition:.2s}
.lb-close{position:absolute;top:14px;right:20px;font-size:34px;line-height:1}
.lb-close:hover{color:var(--accent-2);transform:rotate(90deg)}
.lb-prev,.lb-next{position:absolute;top:50%;transform:translateY(-50%);font-size:52px;padding:0 22px;opacity:.65}
.lb-prev:hover,.lb-next:hover{opacity:1;color:var(--accent-2)}
.lb-prev{left:6px}.lb-next{right:6px}

/* ---------- about ---------- */
.about{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(34px,6vw,64px);padding:clamp(48px,7vw,72px) 0 40px;align-items:start}
.about-photo .cropframe{display:block}
.about-photo img,.portrait-placeholder{width:100%;aspect-ratio:4/5;object-fit:cover;background:var(--surface)}
.portrait-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--muted);gap:8px;border:1px solid var(--line)}
.portrait-placeholder span{font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase}
.portrait-placeholder small{font-size:11px;color:#a4a4aa;font-family:var(--mono)}
.about-text .eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.32em;text-transform:uppercase;color:var(--accent);margin-bottom:16px}
.about-text h2{font-weight:300;font-size:clamp(28px,4vw,40px);margin-bottom:20px;letter-spacing:-.01em}
.about-text .lead{font-size:clamp(18px,2.2vw,20px);color:var(--ink);margin-bottom:18px}
.about-text p{color:var(--muted);font-size:16px;margin-bottom:16px;max-width:60ch}
.about-kit{margin-top:30px;border-top:1px solid var(--line);padding-top:22px}
.about-kit .foot-h{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:12px}
.about-kit ul{list-style:none;display:grid;grid-template-columns:repeat(2,1fr);gap:8px 24px}
.about-kit li{font-size:14px;color:var(--ink-soft);display:flex;justify-content:space-between;border-bottom:1px dotted var(--line-strong);padding-bottom:6px}
.about-kit li span{font-family:var(--mono);font-size:12px;color:var(--muted)}
.about-social{margin-top:28px;display:flex;gap:24px}
.about-social a{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;border-bottom:1px solid var(--accent);padding-bottom:3px}

/* ---------- footer ---------- */
.site-foot{background:var(--bg-2);border-top:1px solid var(--line);margin-top:60px;padding:clamp(44px,6vw,64px) 0 30px;color:var(--muted)}
.foot-top{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap}
.foot-brand{display:flex;align-items:center;gap:18px}
.foot-brand .ap-mark{color:var(--ink);opacity:.85}
.foot-brand .logo img{height:28px}
.foot-tag{font-family:var(--mono);font-size:12px;letter-spacing:.04em;margin-top:8px}
.foot-h{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink);display:block;margin-bottom:14px}
.foot-archive ul,.foot-links ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.foot-archive ul{flex-flow:row wrap;max-width:220px;gap:9px 16px}
.foot-archive a,.foot-links a{font-size:14px;transition:.2s}
.foot-archive a:hover,.foot-links a:hover{color:var(--accent)}
.foot-base{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;border-top:1px solid var(--line);margin-top:36px;padding-top:22px;font-size:13px}
.foot-mono{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase}

/* ---------- scroll reveal (only hides when JS is active) ---------- */
.js [data-reveal]{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.js [data-reveal].is-in{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media(max-width:980px){ .grid{column-count:2} }
@media(max-width:760px){
  .nav{height:62px}
  .burger{display:flex}
  nav{position:fixed;inset:62px 0 auto 0;background:var(--surface);border-bottom:1px solid var(--line);transform:translateY(-130%);transition:transform .35s var(--ease);z-index:55}
  body.nav-open nav{transform:translateY(0)}
  nav ul{flex-direction:column;gap:0;align-items:stretch}
  nav ul li{border-bottom:1px solid var(--line)}
  nav ul li a{display:block;padding:18px 28px;letter-spacing:.18em}
  nav a span::after{display:none}
  .social{padding:16px 28px;gap:26px}
  .social svg{width:22px;height:22px}
  .entry{grid-template-columns:1fr;gap:22px;padding:42px 0}
  .entry:nth-child(even) .ph{order:0}
  .entry .txt::before{top:-40px;font-size:64px}
  .entry-nav{flex-direction:column;gap:18px}
  .entry-nav a,.entry-nav .next{max-width:100%;text-align:left;margin:0}
  .about{grid-template-columns:1fr;gap:30px}
  .about-kit ul{grid-template-columns:1fr}
  .foot-top{gap:28px}
  .foot-base{flex-direction:column;align-items:flex-start}
  .lb-prev,.lb-next{font-size:38px;padding:0 10px}
}
@media(max-width:460px){ .grid{column-count:1} }

@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .js [data-reveal]{opacity:1;transform:none}
  .hero .eyebrow,.hero h1,.hero p,.hero .place{opacity:1}
}
