:root{
  --bg:#0a0b0d; --ink:#e9e6df;
  --read:rgba(233,230,223,.80); --read-hi:#f3f0e8;
  --dim:rgba(233,230,223,.42); --faint:rgba(233,230,223,.30); --hair:rgba(233,230,223,.14);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{min-height:100%}
body{background:var(--bg);color:var(--ink);font-family:'Jost',system-ui,sans-serif;-webkit-font-smoothing:antialiased;overflow-x:hidden}

/* ---- background stack (fixed behind the whole page) ---- */
#fluid{position:fixed;inset:0;width:100%;height:100%;display:block;z-index:0;opacity:.80;filter:blur(7px)}
#grain{position:fixed;inset:0;width:100%;height:100%;z-index:2;pointer-events:none;mix-blend-mode:overlay;opacity:.07;image-rendering:auto}
#veil{position:fixed;inset:0;z-index:3;pointer-events:none;background:radial-gradient(ellipse at center, rgba(10,11,13,.24) 16%, rgba(6,7,8,.82) 100%)}

/* ---- top bar (wordmark is the way home) ---- */
.topbar{position:fixed;top:0;left:0;right:0;z-index:30;display:flex;align-items:center;justify-content:space-between;padding:1.4rem clamp(1.4rem,5vw,3rem);pointer-events:none}
.mark{pointer-events:auto;font-family:'Cormorant Garamond',serif;font-weight:300;font-size:1.45rem;letter-spacing:.2em;text-indent:.2em;color:var(--ink);text-decoration:none;opacity:.92;transition:opacity .5s ease}
.mark:hover{opacity:1}
.topnav{pointer-events:auto;display:flex;align-items:center;gap:1.4rem}
.tlink{font-weight:300;text-transform:uppercase;letter-spacing:.3em;text-indent:.3em;font-size:.62rem;color:var(--dim);text-decoration:none;background:none;border:none;cursor:pointer;font-family:'Jost',sans-serif;transition:color .5s ease}
.tlink:hover{color:var(--ink)}

/* ---- intro text ---- */
.doc{position:relative;z-index:5;max-width:44rem;margin:0 auto;padding:clamp(7rem,18vh,11rem) clamp(1.6rem,6vw,2rem) clamp(2rem,6vh,3.5rem)}
.kicker{font-weight:300;text-transform:uppercase;letter-spacing:.5em;text-indent:.5em;font-size:1.02rem;color:rgba(233,230,223,.56);margin-bottom:2.3rem}
.lede{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:clamp(1.7rem,4.4vw,2.45rem);line-height:1.32;color:var(--ink);margin-bottom:2.4rem;text-wrap:balance}
.body p{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:clamp(1.45rem,2.9vw,1.68rem);line-height:1.76;color:var(--read);margin-bottom:1.4rem;text-wrap:pretty}
.cue{margin-top:2.4rem;font-family:'Jost',sans-serif;font-weight:300;text-transform:uppercase;letter-spacing:.34em;text-indent:.34em;font-size:.62rem;color:var(--faint);display:flex;align-items:center;gap:.7rem}
.cue .dot{display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--faint);animation:pulse 2.6s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.25}50%{opacity:.85}}

/* ---- the tray (a section below the text) ---- */
.tray{position:relative;z-index:5;height:100vh;min-height:540px}
.stage{position:absolute;inset:0;display:grid;place-items:center;padding:9vh clamp(1rem,5vw,3rem) 12vh}
/* development: paper enters pale & warm, image DARKENS onto it, slowly */
.print{
  grid-area:1/1;max-height:74vh;max-width:88vw;object-fit:contain;cursor:pointer;
  box-shadow:0 18px 80px rgba(0,0,0,.5);
  filter:brightness(2.15) contrast(.12) sepia(.34);
  opacity:0;transform:translateY(10px) scale(.985);
  transition:opacity 1.1s ease, filter 3.8s cubic-bezier(.62,.03,.26,1), transform 2.4s ease;
}
.print.surfaced{filter:brightness(1) contrast(1) sepia(0);opacity:1;transform:translateY(0) scale(1)}
.print.submerge{opacity:0;filter:brightness(1.7) contrast(.4) sepia(.2);transition:opacity .8s ease, filter .8s ease}

/* ---- heads-up: caption, counter, arrows (shown while the tray is in view) ---- */
.hud{position:fixed;left:0;right:0;bottom:0;z-index:10;display:flex;flex-direction:column;align-items:center;gap:.45rem;padding-bottom:2.1rem;opacity:0;transition:opacity .6s ease;pointer-events:none}
.hud.show{opacity:1}
.hud .ttl{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;font-size:clamp(1.1rem,2.4vw,1.32rem);letter-spacing:.03em;color:var(--read-hi);min-height:1.2em}
.hud .num{font-family:'Jost',sans-serif;font-weight:300;text-transform:uppercase;letter-spacing:.34em;text-indent:.34em;font-size:.58rem;color:var(--faint)}
.arrow{position:fixed;top:50%;transform:translateY(-50%);z-index:12;background:none;border:none;color:var(--dim);font-family:'Jost',sans-serif;font-weight:300;font-size:2.6rem;line-height:1;padding:1rem;cursor:pointer;opacity:0;transition:opacity .5s ease,color .35s ease;pointer-events:none}
.arrow.show{opacity:1;pointer-events:auto}
.arrow.hide{opacity:0 !important;pointer-events:none}
.arrow:hover{color:var(--ink)}
.arrow.prev{left:clamp(.3rem,3vw,1.6rem)}
.arrow.next{right:clamp(.3rem,3vw,1.6rem)}
@media(max-width:560px){.arrow{top:auto;bottom:5rem;transform:none}.arrow.prev{left:22%}.arrow.next{right:22%}}

/* ---- closing ---- */
.close{position:relative;z-index:5;max-width:44rem;margin:0 auto;padding:4vh clamp(1.6rem,6vw,2rem) clamp(6rem,14vh,9rem);text-align:center}
.coda{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;font-size:clamp(1.3rem,3vw,1.6rem);line-height:1.5;color:var(--dim);margin-bottom:2.2rem}
.doorways{display:flex;align-items:center;justify-content:center;gap:1.6rem}
.door{font-family:'Jost',sans-serif;font-weight:300;text-transform:uppercase;letter-spacing:.34em;text-indent:.34em;font-size:.72rem;color:var(--read);text-decoration:none;padding-bottom:.35rem;border-bottom:1px solid transparent;transition:border-color .45s ease,color .45s ease}
.door:hover{color:var(--ink);border-color:var(--ink)}
.sep{width:1px;height:1rem;background:var(--hair)}

/* ---- contact sheet (regular gallery) ---- */
.sheet{position:fixed;inset:0;z-index:40;display:none;overflow-y:auto;background:rgba(7,8,10,.94);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px)}
.sheet.open{display:block;animation:vfade .4s ease}
@keyframes vfade{from{opacity:0}to{opacity:1}}
.sheet-head{display:flex;align-items:center;justify-content:space-between;padding:1.4rem clamp(1.4rem,5vw,3rem);position:sticky;top:0}
.sheet-title{font-family:'Jost',sans-serif;font-weight:300;text-transform:uppercase;letter-spacing:.42em;text-indent:.42em;font-size:.72rem;color:rgba(233,230,223,.5)}
.sheet-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px;padding:0 clamp(1.4rem,5vw,3rem) 4rem;max-width:1300px;margin:0 auto}
.thumb{position:relative;aspect-ratio:1/1;overflow:hidden;cursor:pointer;background:#0e0f12}
.thumb img{width:100%;height:100%;object-fit:cover;display:block;filter:brightness(.6) contrast(.92);opacity:.8;transition:filter .4s ease,opacity .4s ease,transform .6s ease}
.thumb:hover img{filter:brightness(1) contrast(1);opacity:1;transform:scale(1.04)}

@media(prefers-reduced-motion:reduce){
  .print{transition:opacity .2s ease}
  .print.surfaced{transform:none;filter:brightness(1) contrast(1) sepia(0)}
}
