/* Doosy Photography — design system extracted from the Claude Design source */
:root{
  --bg:#0b0a08;
  --text:#ece5da;
  --bright:#f4efe6;
  --muted:#b7afa3;
  --dim:#8c847a;
  --faint:#5c554d;
  --accent:#d19a5c;
  --hairline:rgba(236,229,218,0.14);
  --hairline-strong:rgba(236,229,218,0.28);
  --mono:'Space Mono',ui-monospace,'SFMono-Regular',monospace;
  --sans:'Hanken Grotesk',system-ui,-apple-system,sans-serif;
  --pad:clamp(20px,5vw,56px);
  --maxw:1440px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--sans);
  font-weight:400;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img,picture{display:block;max-width:100%}
::selection{background:var(--accent);color:#0b0a08}

/* ---------- utilities ---------- */
.mono{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;line-height:1.7}
.accent{color:var(--accent)}
.muted{color:var(--muted)}
.dim{color:var(--dim)}
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
.rule{height:1px;background:var(--hairline);width:100%}

.display{font-family:var(--sans);font-weight:300;line-height:.94;letter-spacing:-.025em;color:var(--bright)}
.display.xl{font-size:clamp(52px,12vw,168px)}
.display.lg{font-size:clamp(44px,9vw,120px)}
.display.md{font-size:clamp(30px,4.4vw,60px)}

/* ---------- nav ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:60;
  display:flex;align-items:center;justify-content:space-between;
  padding:20px var(--pad);
}
.nav::before{
  content:'';position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:linear-gradient(to bottom,rgba(11,10,8,.85),rgba(11,10,8,0));
}
.nav .brand{font-family:var(--mono);font-weight:700;letter-spacing:.34em;font-size:15px;color:var(--bright)}
.nav .links{display:flex;gap:clamp(16px,3vw,34px)}
.nav .links a{font-family:var(--mono);font-size:12px;letter-spacing:.16em;color:var(--muted);transition:color .25s}
.nav .links a:hover{color:var(--text)}
.nav .links a.active{color:var(--text)}
.nav .links a.contact{color:var(--accent)}
.nav .links a.contact:hover{color:var(--bright)}

/* ---------- generic inner page ---------- */
.page{padding-top:clamp(120px,16vh,168px);padding-bottom:120px}
.page-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap}
.page-head .meta{text-align:right;color:var(--accent)}
.back{display:inline-block;font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:34px;transition:color .25s}
.back:hover{color:var(--accent)}

/* ---------- home hero ---------- */
.hero{position:relative;height:100svh;min-height:600px;width:100%;overflow:hidden}
.hero .bg{position:absolute;inset:0}
.hero .bg picture{display:block;width:100%;height:100%}
.hero .bg img{width:100%;height:100%;object-fit:cover}
.hero::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(to bottom,rgba(11,10,8,.5) 0%,rgba(11,10,8,.05) 26%,rgba(11,10,8,.08) 50%,rgba(11,10,8,.62) 84%,rgba(11,10,8,.9) 100%);
}
.hero .hmeta{position:absolute;top:clamp(96px,14vh,150px);right:var(--pad);z-index:3;text-align:right}
.hero .hmeta .coords{color:var(--accent)}
.hero .hmeta .sel{color:var(--muted);margin-top:8px}
.hero .cap{position:absolute;left:0;right:0;bottom:clamp(28px,8vh,80px);z-index:3}
.hero .cap .label{color:var(--accent);margin-bottom:clamp(14px,2.4vh,26px)}
.hero .cap h1{max-width:14ch}
.hero .scroll{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);z-index:3;color:var(--dim);font-family:var(--mono);font-size:10px;letter-spacing:.3em}

/* ---------- index (series list) ---------- */
.series-list{margin-top:clamp(36px,6vh,68px)}
.series-row{
  display:grid;
  grid-template-columns:52px minmax(0,1fr) auto 210px;
  align-items:center;gap:clamp(16px,3vw,40px);
  padding:clamp(24px,3.4vh,40px) 0;
  border-top:1px solid var(--hairline);
  transition:padding-left .4s ease;
}
.series-list .series-row:last-child{border-bottom:1px solid var(--hairline)}
.series-row .num{font-family:var(--mono);color:var(--accent);font-size:13px;letter-spacing:.1em;align-self:start;padding-top:.5em}
.series-row .t{font-family:var(--sans);font-weight:300;font-size:clamp(30px,4.6vw,58px);line-height:1;color:var(--bright);transition:color .3s}
.series-row .loc{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);text-align:right;white-space:nowrap}
.series-row .thumb{width:210px;aspect-ratio:4/3;overflow:hidden;background:#141210;justify-self:end}
.series-row .thumb picture{display:block;width:100%;height:100%}
.series-row .thumb img{width:100%;height:100%;object-fit:cover;transform:scale(1.001);transition:transform .8s cubic-bezier(.2,.7,.2,1),opacity .6s}
.series-row:hover{padding-left:14px}
.series-row:hover .t{color:var(--accent)}
.series-row:hover .thumb img{transform:scale(1.06)}

/* ---------- series detail ---------- */
.series-intro{max-width:640px;margin-top:clamp(18px,3vh,30px)}
.series-intro p{color:var(--muted);font-size:clamp(17px,1.5vw,21px);line-height:1.6}
.frames{margin-top:clamp(44px,8vh,96px);display:flex;flex-direction:column;gap:clamp(40px,9vh,128px)}
.frame{width:100%;max-width:1120px;margin:0 auto;cursor:zoom-in}
.frame .shot{position:relative;background:#141210 var(--lqip) center/cover no-repeat;overflow:hidden}
.frame .shot img{width:100%;height:auto}
.frame .fcap{display:flex;justify-content:space-between;gap:16px;margin-top:14px;font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint)}
.frame .fcap .r{color:var(--dim);text-align:right}

/* ---------- work grid ---------- */
.grid{margin-top:clamp(36px,6vh,64px);column-gap:clamp(12px,1.4vw,20px);columns:3 300px}
.cell{break-inside:avoid;margin-bottom:clamp(12px,1.4vw,20px);cursor:zoom-in;position:relative}
.cell .shot{position:relative;background:#141210 var(--lqip) center/cover no-repeat;overflow:hidden}
.cell .shot img{width:100%;height:auto;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.cell:hover .shot img{transform:scale(1.04)}
.cell .tag{position:absolute;left:12px;bottom:12px;z-index:2;font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--bright);opacity:0;transition:opacity .3s;text-shadow:0 1px 8px rgba(0,0,0,.6)}
.cell:hover .tag{opacity:1}

/* ---------- blur-up loading ---------- */
img.lazyimg{opacity:0;transition:opacity .7s ease}
img.lazyimg.loaded{opacity:1}

/* ---------- about / contact ---------- */
.prose{max-width:620px;margin-top:clamp(30px,5vh,54px)}
.prose p{color:var(--muted);font-size:clamp(17px,1.5vw,21px);line-height:1.7;margin-bottom:1.1em}
.contact-links{margin-top:clamp(30px,5vh,54px);display:flex;flex-direction:column;gap:20px}
.contact-links a{font-family:var(--sans);font-weight:300;font-size:clamp(24px,3.2vw,40px);color:var(--bright);width:fit-content;transition:color .25s}
.contact-links a:hover{color:var(--accent)}
.contact-note{margin-top:34px;color:var(--dim);font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase}

/* ---------- footer ---------- */
.foot{border-top:1px solid var(--hairline);padding:34px var(--pad);display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.foot .mono{color:var(--dim)}

/* ---------- lightbox ---------- */
.lb{position:fixed;inset:0;z-index:100;background:var(--bg);display:none;flex-direction:column;opacity:0;transition:opacity .3s}
.lb.open{display:flex}
.lb.shown{opacity:1}
.lb-top{display:flex;justify-content:space-between;align-items:center;padding:20px var(--pad);font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase}
.lb-top .back{margin:0;cursor:pointer}
.lb-top .count{color:var(--accent)}
.lb-stage{flex:1;position:relative;display:flex;align-items:center;justify-content:center;padding:0 clamp(48px,7vw,120px);min-height:0}
.lb-stage img{max-width:100%;max-height:100%;object-fit:contain;opacity:0;transition:opacity .3s}
.lb-stage img.loaded{opacity:1}
.lb-arrow{position:absolute;top:0;bottom:0;width:clamp(44px,7vw,110px);display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:26px;cursor:pointer;user-select:none;background:transparent;border:0;transition:color .25s}
.lb-arrow:hover{color:var(--bright)}
.lb-prev{left:0}.lb-next{right:0}
.lb-meta{padding:16px var(--pad) 30px;display:flex;gap:clamp(16px,2.4vw,34px);flex-wrap:wrap;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--dim)}
.lb-meta .loc{color:var(--accent)}
.lb-close{cursor:pointer;color:var(--muted)}
.lb-close:hover{color:var(--bright)}

/* ---------- responsive ---------- */
@media(max-width:720px){
  .nav{padding:16px var(--pad)}
  .nav .brand{font-size:13px;letter-spacing:.28em}
  .nav .links{gap:16px}
  .nav .links a{font-size:11px}
  .series-row{grid-template-columns:36px 1fr;grid-template-areas:"num title" "num loc" "thumb thumb";gap:8px 16px}
  .series-row .num{grid-area:num}
  .series-row .t{grid-area:title}
  .series-row .loc{grid-area:loc;text-align:left;margin-top:4px}
  .series-row .thumb{grid-area:thumb;width:100%;aspect-ratio:16/9;margin-top:18px;justify-self:stretch}
  .series-row:hover{padding-left:0}
  .grid{columns:2 150px}
  .lb-meta{font-size:10px}
}
