:root{
  --concrete:#EEEAE2;
  --concrete-dim:#E2DDD2;
  --ink:#141217;
  --ink-soft:#211E24;
  --pink:#DF43B0;
  --pink-deep:#A82C82;
  --cream:#F5EBE4;
  --teal:#3E9CA1;
  --sun:#D3AE3B;
  --steel:#6B6870;
  --line:rgba(20,18,23,0.14);
  --line-light:rgba(245,235,228,0.22);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto;}
  *{animation-duration:0.01ms !important; transition-duration:0.01ms !important;}
}

body{
  margin:0;
  background:var(--concrete);
  color:var(--ink);
  font-family:'Fraunces', serif;
  -webkit-font-smoothing:antialiased;
}

/* subtle concrete grain, layered under content */
body::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:0;
  pointer-events:none;
  opacity:0.5;
  mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='matrix' values='0 0 0 0 0.08  0 0 0 0 0.07  0 0 0 0 0.09  0 0 0 0.045 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

h1,h2,h3,.stencil{
  font-family:'Anton', sans-serif;
  font-weight:400;
  text-transform:uppercase;
  letter-spacing:0.01em;
  margin:0;
}
.mono{
  font-family:'IBM Plex Mono', monospace;
  text-transform:uppercase;
  letter-spacing:0.08em;
}
a{color:inherit;}
img{max-width:100%;display:block;}
a:focus-visible, button:focus-visible, input:focus-visible{
  outline:3px solid var(--pink);
  outline-offset:3px;
}

.wrap{
  max-width:1180px;
  margin:0 auto;
  padding:0 32px;
  position:relative;
  z-index:1;
}

/* ---------- NAV ---------- */
header.site-nav{
  position:fixed;
  top:0; left:0; right:0;
  z-index:100;
  padding:18px 32px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  background:rgba(238,234,226,0.0);
  border-bottom:1px solid transparent;
  transition:background 0.3s ease, border-color 0.3s ease, padding 0.3s ease;
}
header.site-nav.scrolled{
  background:rgba(238,234,226,0.92);
  backdrop-filter:blur(6px);
  border-bottom:1px solid var(--line);
  padding:12px 32px;
}
header.site-nav.on-dark:not(.scrolled) .nav-mark img{filter:none;}
.nav-mark{display:flex; align-items:center;}
.nav-mark img{height:30px; width:auto; display:block;}
.nav-links{
  display:flex;
  gap:30px;
  list-style:none;
  margin:0; padding:0;
  align-items:center;
}
.nav-links a{
  font-family:'IBM Plex Mono', monospace;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:0.1em;
  text-decoration:none;
  opacity:0.82;
  padding-bottom:3px;
  border-bottom:1px solid transparent;
  transition:opacity 0.2s ease, border-color 0.2s ease;
}
.nav-links a:hover, .nav-links a.active{opacity:1; border-color:var(--pink);}
.nav-links .pill{
  background:var(--pink);
  color:var(--cream);
  padding:7px 14px;
  border-radius:2px;
  opacity:1;
  border-bottom:none;
}
.nav-links .pill:hover{background:var(--pink-deep);}
.nav-toggle{display:none;}

/* text color swap depending on section under the nav */
.on-light .nav-links a{color:var(--ink);}
.on-dark .nav-links a{color:var(--cream);}
header.site-nav.scrolled .nav-links a{color:var(--ink) !important;}

/* ---------- SECTION LABELS ---------- */
.section{padding:110px 0; position:relative;}
.section-tag{display:flex; align-items:center; gap:14px; margin-bottom:26px;}
.section-tag .mono{font-size:12px; color:var(--pink-deep);}
.section-tag .rule{flex:1; height:1px; background:var(--line);}

/* ---------- BUTTONS / LINKS ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family:'IBM Plex Mono', monospace;
  font-size:12px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  text-decoration:none;
  color:var(--ink);
  border-bottom:1px solid var(--pink);
  padding-bottom:3px;
}
.btn:hover{color:var(--pink-deep);}
.btn.on-dark{color:var(--cream);}
.btn.on-dark:hover{color:var(--pink);}

.stamp{
  font-family:'IBM Plex Mono', monospace;
  font-size:11px;
  letter-spacing:0.1em;
  text-transform:uppercase;
  border:1px solid var(--line);
  padding:8px 14px;
  border-radius:2px;
  white-space:nowrap;
}
.stamp.pink{
  background:var(--pink);
  border-color:var(--pink);
  color:var(--cream);
}

/* ---------- HERO ---------- */
.hero{
  position:relative;
  min-height:100svh;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  overflow:hidden;
  background:var(--ink);
}
.hero-photo{
  position:absolute;
  inset:0;
  width:100%; height:100%;
  object-fit:cover;
  object-position:60% 35%;
}
.hero-scrim{
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(15,13,17,0.55) 0%, rgba(15,13,17,0.25) 35%, rgba(15,13,17,0.75) 100%);
}
.hero-inner{
  position:relative;
  z-index:2;
  padding:150px 32px 60px;
}
.hero-eyebrow{
  display:flex; align-items:center; gap:12px;
  color:var(--cream);
  opacity:0.9;
  font-size:12px;
  margin-bottom:22px;
}
.hero-eyebrow .dot{width:7px; height:7px; border-radius:50%; background:var(--pink);}
.hero-logo{
  width:min(560px, 68vw);
  margin-bottom:20px;
}
.hero-sub{
  max-width:520px;
  font-style:italic;
  font-size:clamp(17px,2.1vw,21px);
  color:var(--cream);
  line-height:1.55;
  margin-bottom:30px;
}
.hero-badges{display:flex; flex-wrap:wrap; gap:12px;}
.hero-badges .stamp{color:var(--cream); border-color:rgba(245,235,228,0.4);}
.scroll-cue{
  position:absolute;
  bottom:24px; right:32px; z-index:2;
  font-family:'IBM Plex Mono', monospace;
  font-size:11px; color:var(--cream);
  writing-mode:vertical-rl;
  display:flex; align-items:center; gap:10px;
  letter-spacing:0.15em;
}
.scroll-cue::after{content:""; width:1px; height:40px; background:rgba(245,235,228,0.6); display:block;}

/* ---------- ABOUT ---------- */
.about-grid{display:grid; grid-template-columns:1.3fr 1fr; gap:70px; align-items:start;}
.about-grid h2{font-size:clamp(36px,4.6vw,54px); line-height:1.03; margin-bottom:24px;}
.about-grid p{font-size:18px; line-height:1.65; max-width:54ch;}
.about-grid p + p{margin-top:16px;}
.about-grid .lede{font-weight:500; font-size:21px; line-height:1.5;}

.manifest{
  background:var(--ink);
  color:var(--cream);
  padding:32px 28px;
  position:relative;
}
.manifest::before{
  content:"";
  position:absolute; inset:11px;
  border:1px dashed rgba(245,235,228,0.28);
  pointer-events:none;
}
.manifest .mono.title{font-size:12px; color:var(--pink); margin-bottom:18px; display:block;}
.manifest dl{margin:0; display:grid; grid-template-columns:auto 1fr; gap:11px 18px;}
.manifest dt{font-family:'IBM Plex Mono', monospace; font-size:11px; letter-spacing:0.08em; text-transform:uppercase; color:#B8B2AC; white-space:nowrap;}
.manifest dd{margin:0; font-family:'IBM Plex Mono', monospace; font-size:13px;}
.manifest .stamp-corner{margin-top:24px; display:inline-block; transform:rotate(-3deg);}

/* ---------- ARTIST GRID (home, light) ---------- */
#artists{background:var(--concrete-dim);}
.artists-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  flex-wrap:wrap;
  gap:20px;
  margin-bottom:44px;
}
.artists-head h2{font-size:clamp(34px,4.6vw,52px);}
.artist-list-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:26px;
}
.artist-tile{
  background:var(--concrete);
  border:1px solid var(--line);
  text-decoration:none;
  color:var(--ink);
  display:flex;
  flex-direction:column;
  transition:transform 0.2s ease, box-shadow 0.2s ease;
}
.artist-tile:hover{transform:translateY(-3px); box-shadow:0 14px 30px rgba(20,18,23,0.12);}
.img-slot{
  aspect-ratio:4/3;
  background:
    repeating-linear-gradient(135deg, rgba(20,18,23,0.06) 0 2px, transparent 2px 14px),
    var(--concrete-dim);
  border-bottom:1px solid var(--line);
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
}
.img-slot img{width:100%; height:100%; object-fit:cover; display:block;}
.img-slot .corner{position:absolute; width:14px; height:14px; border:1.5px solid var(--steel); opacity:0.5;}
.img-slot .corner.tl{top:10px; left:10px; border-right:none; border-bottom:none;}
.img-slot .corner.tr{top:10px; right:10px; border-left:none; border-bottom:none;}
.img-slot .corner.bl{bottom:10px; left:10px; border-right:none; border-top:none;}
.img-slot .corner.br{bottom:10px; right:10px; border-left:none; border-top:none;}
.img-slot span{
  font-family:'IBM Plex Mono', monospace;
  font-size:10.5px;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--steel);
}
.tile-body{padding:22px 22px 24px;}
.tile-body h3{font-size:24px; margin-bottom:4px;}
.tile-body .medium{
  font-family:'IBM Plex Mono', monospace;
  font-size:10.5px;
  text-transform:uppercase;
  letter-spacing:0.08em;
  color:var(--steel);
  margin-bottom:14px;
}
.tile-body .site-link{
  font-family:'IBM Plex Mono', monospace;
  font-size:11.5px;
  letter-spacing:0.06em;
  text-transform:uppercase;
  border-bottom:1px solid var(--pink);
  padding-bottom:2px;
}
.artist-tile:hover .site-link{color:var(--pink-deep);}

/* ---------- VISIT ---------- */
#visit{background:var(--concrete);}
.visit-grid{display:grid; grid-template-columns:1fr 1fr; gap:70px; align-items:start;}
#visit h2{font-size:clamp(36px,4.6vw,54px); line-height:1.03; margin-bottom:26px;}
.visit-lines{list-style:none; margin:0 0 10px; padding:0;}
.visit-lines li{display:grid; grid-template-columns:120px 1fr; gap:20px; padding:17px 0; border-top:1px solid var(--line); font-size:16.5px;}
.visit-lines li:last-child{border-bottom:1px solid var(--line);}
.visit-lines .k{font-family:'IBM Plex Mono', monospace; font-size:11px; letter-spacing:0.1em; text-transform:uppercase; color:var(--steel); padding-top:2px;}
.visit-lines .v a{text-decoration:none; border-bottom:1px solid var(--pink);}
.dock-graphic{background:var(--ink); aspect-ratio:4/3.1; overflow:hidden;}
.dock-graphic svg{width:100%; height:100%; display:block;}
.dock-caption{margin-top:12px; font-family:'IBM Plex Mono', monospace; font-size:11px; color:var(--steel); display:flex; justify-content:space-between;}

/* ---------- ARTISTS PAGE ---------- */
.page-header{
  padding:150px 0 60px;
  background:var(--ink);
  color:var(--cream);
}
.page-header h1{font-size:clamp(46px,8vw,90px); line-height:0.95; margin-bottom:20px;}
.page-header p{max-width:60ch; font-style:italic; color:#CFC8C2; font-size:18px; line-height:1.6;}

.bio-list{display:flex; flex-direction:column;}
.bio-row{
  display:grid;
  grid-template-columns:280px 1fr;
  gap:50px;
  padding:52px 0;
  border-top:1px solid var(--line);
}
.bio-list .bio-row:last-child{border-bottom:1px solid var(--line);}
.bio-row .img-slot{aspect-ratio:3/4;}
.bio-copy .code{font-family:'IBM Plex Mono', monospace; font-size:11px; color:var(--pink-deep); letter-spacing:0.1em; margin-bottom:10px; display:block;}
.bio-copy h3{font-size:clamp(28px,3.6vw,40px); margin-bottom:4px;}
.bio-copy .medium{font-family:'IBM Plex Mono', monospace; font-size:11px; text-transform:uppercase; letter-spacing:0.08em; color:var(--steel); margin-bottom:18px;}
.bio-copy p{font-size:17px; line-height:1.7; max-width:62ch; margin-bottom:18px;}
.bio-copy .site-link{
  font-family:'IBM Plex Mono', monospace;
  font-size:12px; letter-spacing:0.06em; text-transform:uppercase;
  text-decoration:none;
  border-bottom:1px solid var(--pink);
  padding-bottom:2px;
}
.bio-copy .site-link:hover{color:var(--pink-deep);}

/* ---------- FOOTER ---------- */
footer{background:var(--ink); color:var(--cream); padding:90px 0 36px;}
.footer-top{display:grid; grid-template-columns:1.2fr 1fr; gap:60px; padding-bottom:56px; border-bottom:1px solid var(--line-light);}
footer h2{font-size:clamp(32px,4.6vw,50px); line-height:1.03; margin-bottom:18px; max-width:14ch;}
footer .foot-copy{color:#CFC8C2; font-size:16.5px; line-height:1.6; max-width:44ch; margin-bottom:26px;}
.subscribe{display:flex; max-width:420px; border-bottom:1px solid #7B7670;}
.subscribe input{flex:1; background:transparent; border:none; color:var(--cream); font-family:'IBM Plex Mono', monospace; font-size:13px; padding:12px 0;}
.subscribe input::placeholder{color:#8B8680;}
.subscribe button{background:none; border:none; color:var(--pink); font-family:'IBM Plex Mono', monospace; font-size:12px; letter-spacing:0.1em; text-transform:uppercase; cursor:pointer; padding:12px 4px;}
.subscribe button:hover{color:var(--cream);}
.foot-note{font-family:'IBM Plex Mono', monospace; font-size:11px; color:#8B8680; margin-top:12px;}
.foot-links .label{font-family:'IBM Plex Mono', monospace; font-size:11px; letter-spacing:0.1em; color:#8B8680; margin-bottom:14px; display:block;}
.foot-links ul{list-style:none; margin:0 0 30px; padding:0;}
.foot-links li{margin-bottom:9px;}
.foot-links a{text-decoration:none; font-size:14px; color:var(--cream); opacity:0.85;}
.foot-links a:hover{opacity:1; color:var(--pink);}
.footer-bottom{display:flex; justify-content:space-between; align-items:center; padding-top:24px; font-family:'IBM Plex Mono', monospace; font-size:11px; color:#8B8680; flex-wrap:wrap; gap:10px;}

/* ---------- RESPONSIVE ---------- */
@media (max-width: 980px){
  .artist-list-grid{grid-template-columns:repeat(2, 1fr);}
}
@media (max-width: 900px){
  .about-grid, .visit-grid, .footer-top{grid-template-columns:1fr; gap:38px;}
  .bio-row{grid-template-columns:1fr; gap:22px;}
  .bio-row .img-slot{max-width:260px;}
  .nav-links{
    position:fixed; top:0; right:0; height:100vh; width:78vw; max-width:320px;
    background:var(--ink);
    flex-direction:column; justify-content:center; align-items:flex-start;
    padding:0 40px; gap:24px;
    transform:translateX(100%);
    transition:transform 0.32s ease;
  }
  .nav-links.open{transform:translateX(0);}
  .nav-links a{color:var(--cream) !important; font-size:14px;}
  .nav-toggle{
    display:block; background:none; border:1px solid currentColor; color:inherit;
    font-family:'IBM Plex Mono', monospace; font-size:11px; letter-spacing:0.1em; text-transform:uppercase;
    padding:8px 12px; cursor:pointer; z-index:101; position:relative;
  }
  header.site-nav.scrolled .nav-toggle{color:var(--ink);}
  .section{padding:76px 0;}
  .visit-lines li{grid-template-columns:90px 1fr;}
}
@media (max-width: 640px){
  .artist-list-grid{grid-template-columns:1fr;}
}
@media (max-width: 560px){
  .wrap{padding:0 20px;}
  header.site-nav{padding:14px 20px;}
  .hero-inner{padding:130px 20px 44px;}
}
