/* andbass.com — dark editorial (Welf-inspired) */
:root{
  --bg:#0A0A0B;
  --fg:#EDEDED;
  --muted:#8A8A8A;
  --line:#232326;
  --serif:"Instrument Serif",Georgia,serif;
  --sans:"Inter",system-ui,-apple-system,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--bg);color:var(--fg);
  font-family:var(--sans);font-size:15px;line-height:1.6;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
a{color:var(--fg);text-decoration:none}
a:hover{opacity:.7}
.muted{color:var(--muted)}
img{display:block;max-width:100%}

/* ---------- nav ---------- */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:50;
  display:flex;align-items:flex-start;justify-content:space-between;
  padding:1.4rem 1.6rem;pointer-events:none;
  mix-blend-mode:difference;
}
.nav a,.nav .nav-side{pointer-events:auto}
.wordmark{font-family:var(--serif);font-size:1.7rem;line-height:1;letter-spacing:-.02em}
.wm-slash{font-style:italic}
.nav-links{display:flex;flex-direction:column;font-size:.8rem;letter-spacing:.02em;margin-left:2rem;margin-right:auto;padding-left:2rem}
.nav-plus{color:var(--muted)}
.nav-links a.active{border-bottom:1px solid var(--fg);width:max-content}
.nav-side{font-size:.68rem;letter-spacing:.14em;color:var(--muted);writing-mode:vertical-rl;display:none}
@media(min-width:900px){.nav-side{display:block}}

/* ---------- hero ---------- */
.hero{min-height:100svh;position:relative;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden}
.hero-meta{
  position:absolute;top:45%;left:0;right:0;
  display:flex;justify-content:space-between;padding:0 1.6rem;
  font-size:.68rem;letter-spacing:.14em;color:var(--muted);
}
.hero-deck{
  position:absolute;top:8rem;bottom:34svh;left:0;right:0;margin:auto;
  display:flex;align-items:center;justify-content:center;
}
.deck-img{
  position:absolute;height:100%;max-height:52svh;width:auto;max-width:60vw;object-fit:cover;
  box-shadow:0 30px 80px rgba(0,0,0,.65);
  transition:transform .7s cubic-bezier(.2,.8,.2,1);
}
.deck-a{transform:rotate(-7deg) translateX(-16px);filter:brightness(.55) grayscale(.4)}
.deck-b{transform:rotate(6deg) translateX(20px);filter:brightness(.4) grayscale(.6)}
.deck-main{position:relative}
.hero-deck:hover .deck-a{transform:rotate(-11deg) translateX(-46px)}
.hero-deck:hover .deck-b{transform:rotate(10deg) translateX(52px)}
.hero-deck:hover .deck-main{transform:scale(1.015)}
.giant{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(2.6rem,11.2vw,12.5rem);
  line-height:.78;text-align:center;letter-spacing:-.03em;
  transform:translateY(.1em);user-select:none;white-space:nowrap;
}

/* ---------- home sections ---------- */
.hero-deck{cursor:pointer}
.deck-hint{
  position:absolute;bottom:-2.2rem;left:50%;transform:translateX(-50%);
  font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;
  opacity:0;transition:opacity .4s;
}
.hero-deck:hover .deck-hint{opacity:1}
.home-tiles{padding-top:2rem}
.intro{padding:9rem 1.6rem 4rem;max-width:880px;margin:0 auto;text-align:center}
.positioning{font-family:var(--serif);font-size:clamp(1.5rem,3.2vw,2.4rem);line-height:1.25}
.bridge{margin-top:1.6rem;font-size:.85rem;letter-spacing:.05em}
.entries{max-width:1200px;margin:0 auto;padding:2rem 1.6rem 8rem}
.entry{
  display:flex;align-items:baseline;gap:1.4rem;
  border-top:1px solid var(--line);padding:2.2rem .2rem;
}
.entry:last-child{border-bottom:1px solid var(--line)}
.entry-label{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;min-width:11rem}
.entry-title{font-family:var(--serif);font-size:clamp(2.6rem,7vw,5.5rem);line-height:1;letter-spacing:-.02em}
.entry-arrow{margin-left:auto;font-size:1.6rem;transition:transform .4s}
.entry:hover .entry-arrow{transform:translate(6px,-6px)}
.entry:hover{opacity:1}
.entry:hover .entry-title{font-style:italic}

/* ---------- generic page head ---------- */
main{min-height:70svh}
.page-head{padding:11rem 1.6rem 3rem;max-width:1200px;margin:0 auto}
.display{font-family:var(--serif);font-weight:400;font-size:clamp(3rem,9vw,7.5rem);line-height:.95;letter-spacing:-.02em}
.lede{margin-top:1.4rem;max-width:44rem;font-size:1.05rem}
.crumb{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:1rem}
.crumb a{color:var(--muted)}
.cta{margin-top:2.4rem}
.cta a{border-bottom:1px solid var(--fg);padding-bottom:.15em}

/* ---------- images index ---------- */
.tiles{
  max-width:1200px;margin:0 auto;padding:1rem 1.6rem 7rem;
  display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2.4rem 1.6rem;
}
.tile-img{overflow:hidden;aspect-ratio:4/5;background:#111}
.tile-img img{width:100%;height:100%;object-fit:cover;filter:grayscale(.15);transition:transform .8s cubic-bezier(.2,.8,.2,1),filter .8s}
.tile:hover .tile-img img{transform:scale(1.045);filter:grayscale(0)}
.tile:hover{opacity:1}
.tile-row{display:flex;justify-content:space-between;align-items:baseline;margin-top:.8rem}
.tile-title{font-family:var(--serif);font-size:1.6rem}

/* ---------- series gallery ---------- */
.gallery{max-width:1200px;margin:0 auto;padding:1rem 1.6rem 4rem;columns:2;column-gap:1.4rem}
@media(min-width:900px){.gallery{columns:3}}
.g-item{break-inside:avoid;margin-bottom:1.4rem;cursor:zoom-in;overflow:hidden}
.g-item img{width:100%;transition:transform .7s cubic-bezier(.2,.8,.2,1)}
.g-item:hover img{transform:scale(1.03)}
.series-nav{
  max-width:1200px;margin:0 auto;padding:2rem 1.6rem 7rem;
  display:flex;justify-content:space-between;gap:2rem;
  border-top:1px solid var(--line);font-family:var(--serif);font-size:1.5rem;
}
.series-nav .right{text-align:right}
.series-nav .muted{font-family:var(--sans);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase}

/* ---------- about ---------- */
.about{
  max-width:1200px;margin:0 auto;padding:1rem 1.6rem 7rem;
  display:grid;grid-template-columns:1fr;gap:4rem;
}
@media(min-width:900px){.about{grid-template-columns:1.5fr 1fr}}
.bio p{max-width:38rem;margin-bottom:1.3rem;font-size:1.05rem}
.contact dl{display:grid;grid-template-columns:auto 1fr;gap:.5rem 1.6rem;font-size:.95rem;border-top:1px solid var(--line);padding-top:1.6rem}
.contact dt{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;padding-top:.2em}
.qr{margin-top:2.6rem;max-width:150px}
.qr img{width:100%;background:var(--fg);padding:10px}
.qr figcaption{margin-top:.6rem;font-size:.72rem;letter-spacing:.08em}

/* ---------- footer ---------- */
.footer{
  border-top:1px solid var(--line);
  display:flex;flex-wrap:wrap;gap:.4rem 2.5rem;
  padding:2rem 1.6rem 2.6rem;font-size:.78rem;
}
.footer a{border-bottom:1px solid var(--line)}

/* ---------- lightbox ---------- */
.lightbox{
  position:fixed;inset:0;z-index:100;background:rgba(5,5,6,.96);
  display:none;align-items:center;justify-content:center;
}
.lightbox.open{display:flex}
.lightbox img{max-width:88vw;max-height:88svh;box-shadow:0 20px 90px rgba(0,0,0,.8)}
.lightbox button{
  position:absolute;background:none;border:none;color:var(--fg);
  font-size:1.5rem;cursor:pointer;font-family:var(--sans);padding:1rem;
}
.lb-close{top:.8rem;right:1rem;font-size:2rem}
.lb-prev{left:.6rem;top:50%;transform:translateY(-50%)}
.lb-next{right:.6rem;top:50%;transform:translateY(-50%)}
.lb-count{position:absolute;bottom:1.2rem;left:50%;transform:translateX(-50%);font-size:.75rem;color:var(--muted);letter-spacing:.1em}

/* ---------- reveal ---------- */
.reveal{opaci