:root{
  --ink:#16151a;        /* gallery charcoal */
  --ink-2:#1d1c22;
  --paper:#ece7dd;
  --paper-dim:#9b968d;
  --hair:rgba(236,231,221,.13);
  --maxw:1240px;
  --pad-x:clamp(1.4rem,5vw,5rem);
  --serif:"Newsreader",Georgia,serif;
  --grotesk:"Schibsted Grotesk",system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font-family:var(--grotesk);background:var(--ink);color:var(--paper);
  -webkit-font-smoothing:antialiased;line-height:1.6;overflow-x:hidden;
  background-image:radial-gradient(120% 80% at 50% -10%,rgba(236,231,221,.05),transparent 60%);
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
em{font-style:italic}
.eyebrow{font-family:var(--grotesk);text-transform:uppercase;letter-spacing:.32em;
  font-size:.72rem;font-weight:500;color:var(--paper-dim)}

/* reveal */
.js .reveal{opacity:0;transform:translateY(18px);transition:opacity 1s ease,transform 1s cubic-bezier(.2,.7,.2,1)}
.js .reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.js .reveal{opacity:1!important;transform:none!important;transition:none!important}}

/* top bar */
.top{position:fixed;top:0;left:0;right:0;z-index:30;display:flex;justify-content:space-between;
  align-items:center;padding:clamp(1rem,2vw,1.5rem) var(--pad-x);
  font-family:var(--grotesk);font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--paper);mix-blend-mode:difference}
.top__meta{color:var(--paper)}

/* intro */
.intro{max-width:var(--maxw);margin:0 auto;padding:clamp(8rem,18vh,14rem) var(--pad-x) clamp(4rem,8vh,7rem)}
.intro .eyebrow{margin-bottom:clamp(1.6rem,4vh,2.6rem)}
.intro__title{font-family:var(--serif);font-weight:300;line-height:1.04;
  font-size:clamp(2.6rem,7vw,6.4rem);letter-spacing:-.01em;color:var(--paper)}
.intro__title em{font-weight:400}
.intro__lede{margin-top:clamp(2rem,5vh,3.4rem);max-width:46ch;font-size:clamp(1rem,1.15vw,1.18rem);
  color:#cdc7bc}

/* gallery */
.gallery{max-width:1500px;margin:0 auto;padding:0 var(--pad-x) clamp(5rem,10vh,9rem);
  display:flex;flex-direction:column;gap:clamp(3rem,7vh,7rem)}
.card{position:relative;display:grid;grid-template-columns:1.15fr .85fr;
  border-top:1px solid var(--hair);padding-top:clamp(2rem,4vh,3.4rem);
  align-items:center;gap:clamp(1.6rem,4vw,4rem);isolation:isolate}
.card:nth-child(even){grid-template-columns:.85fr 1.15fr}
.card:nth-child(even) .card__media{order:2}
.card__media{position:relative;aspect-ratio:16/10;overflow:hidden;border-radius:2px;
  background:var(--bg)}
.card__media img{width:100%;height:100%;object-fit:cover;
  transition:transform 1.1s cubic-bezier(.2,.7,.2,1),filter 1.1s ease;
  filter:saturate(.96)}
.card__media::after{content:"";position:absolute;inset:0;
  box-shadow:inset 0 0 0 1px var(--hair);border-radius:2px;pointer-events:none}
.card__body{padding:0 clamp(0,2vw,2rem)}
.card__index{font-family:var(--serif);font-style:italic;font-size:1.1rem;color:var(--accent)}
.card__theme{display:block;margin-top:.4rem;font-size:.7rem;letter-spacing:.28em;
  text-transform:uppercase;color:var(--paper-dim)}
.card__name{font-family:var(--serif);font-weight:400;line-height:1;
  font-size:clamp(2.4rem,4.6vw,4.4rem);margin-top:clamp(1rem,2vh,1.6rem);letter-spacing:-.01em;
  color:var(--paper);display:flex;align-items:baseline;gap:.5em;flex-wrap:wrap}
.card__rom{font-size:.34em;letter-spacing:.3em;color:var(--paper-dim);font-style:normal;
  transform:translateY(-.15em)}
.card__desc{margin-top:clamp(1rem,2vh,1.4rem);max-width:42ch;font-size:1.02rem;color:#cdc7bc}
.card__desc em{color:var(--accent);font-style:italic}
.card__go{display:inline-flex;align-items:center;gap:.5em;margin-top:clamp(1.4rem,3vh,2rem);
  font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;color:var(--paper);
  position:relative;padding-bottom:3px}
.card__go span{transition:transform .5s cubic-bezier(.2,.7,.2,1)}
.card__go::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:1px;
  background:var(--accent);transition:right .5s cubic-bezier(.2,.7,.2,1)}
.card:hover .card__media img{transform:scale(1.045);filter:saturate(1.05)}
.card:hover .card__go::after{right:0}
.card:hover .card__go span{transform:translateX(5px)}
.card:focus-visible{outline:2px solid var(--accent);outline-offset:8px}

/* footer */
.foot{border-top:1px solid var(--hair);max-width:var(--maxw);margin:0 auto;
  padding:clamp(3rem,7vh,6rem) var(--pad-x) clamp(4rem,8vh,7rem)}
.foot__line{font-family:var(--serif);font-style:italic;font-size:clamp(1.6rem,3vw,2.4rem);color:var(--paper)}
.foot__note{margin-top:1.2rem;max-width:54ch;color:#cdc7bc;font-size:.98rem}
.foot__small{margin-top:1.4rem;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--paper-dim)}

/* mobile */
@media (max-width:820px){
  .card,.card:nth-child(even){grid-template-columns:1fr;gap:1.4rem}
  .card:nth-child(even) .card__media{order:0}
  .card__media{aspect-ratio:16/11}
  .card__body{padding:0}
  .top__meta{display:none}
}

/* large monitors / 4K: keep content composed, scale type with restraint */
@media (min-width:2000px){
  :root{--maxw:1500px}
  .gallery{max-width:1860px}
  .intro__lede,.card__desc,.foot__note{font-size:1.32rem;max-width:52ch}
  .card__desc{max-width:46ch}
  .top{font-size:1rem}
}
