:root {
  --paper: #fff6ef;
  --paper-deep: #f7dccb;
  --paper-pink: #ffd8e8;
  --paper-blue: #d9f4ff;
  --ink: #241325;
  --ink-soft: #5e405d;
  --night: #110b13;
  --violet: #4b1765;
  --purple: #7d3aa9;
  --hot-pink: #f45c9f;
  --pink: #f7a7c4;
  --blue: #46bfe2;
  --sky: #95def4;
  --cream: #fff0b8;
  --leaf: #497b56;
  --line: rgba(36, 19, 37, 0.22);
  --shadow-hard: 10px 10px 0 var(--ink);
  --shadow-soft: 0 28px 90px rgba(74, 22, 73, 0.18);
  --radius-weird: 2rem 0.75rem 2.4rem 0.85rem;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: "Manrope", system-ui, sans-serif;
  color: var(--ink);
  background:
    radial-gradient(circle at 12% 8%, rgba(244, 92, 159, .35), transparent 24rem),
    radial-gradient(circle at 88% 10%, rgba(70, 191, 226, .35), transparent 24rem),
    radial-gradient(circle at 55% 88%, rgba(125, 58, 169, .22), transparent 28rem),
    linear-gradient(135deg, #fff9f2 0%, #fde4ef 38%, #e7f8fd 70%, #fff3df 100%);
  overflow-x: hidden;
}
body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -4;
  background-image:
    linear-gradient(rgba(36, 19, 37, .035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(36, 19, 37, .03) 1px, transparent 1px);
  background-size: 34px 34px;
  mask-image: linear-gradient(to bottom, black, transparent 86%);
}
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; }
::selection { background: var(--blue); color: var(--ink); }

.skip-link {
  position: fixed;
  left: 1rem;
  top: 1rem;
  z-index: 100;
  padding: .75rem 1rem;
  border: 2px solid var(--ink);
  background: var(--cream);
  transform: translateY(-170%);
  transition: transform .2s ease;
}
.skip-link:focus { transform: translateY(0); }

.grain {
  pointer-events: none;
  position: fixed;
  inset: 0;
  z-index: 50;
  opacity: .18;
  mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 220 220' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.78' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='.55'/%3E%3C/svg%3E");
}
.wash {
  pointer-events: none;
  position: fixed;
  z-index: -3;
  border-radius: 999px;
  filter: blur(18px);
  opacity: .62;
}
.wash-a { width: 24rem; height: 24rem; left: -8rem; top: 24rem; background: var(--pink); }
.wash-b { width: 30rem; height: 30rem; right: -12rem; top: 42rem; background: var(--blue); }

.topbar {
  position: sticky;
  top: 0;
  z-index: 40;
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 1.25rem;
  padding: .8rem 4.5vw;
  background: rgba(255, 246, 239, .78);
  backdrop-filter: blur(18px) saturate(170%);
  border-bottom: 2px solid var(--line);
}
.brand {
  display: inline-flex;
  align-items: center;
  gap: .8rem;
  transform: rotate(-1.5deg);
}
.brand img { width: 4rem; aspect-ratio: 1; border-radius: 1rem; box-shadow: 4px 4px 0 rgba(36,19,37,.16); }
.brand span {
  font-family: "Archivo Black", Impact, sans-serif;
  font-size: clamp(.98rem, 1.5vw, 1.28rem);
  line-height: .86;
  text-transform: uppercase;
}
.nav { display: flex; flex-wrap: wrap; justify-content: flex-end; gap: .62rem; }
.nav a {
  display: inline-flex;
  align-items: center;
  min-height: 2.5rem;
  padding: .55rem .92rem;
  border: 1.75px solid var(--line);
  border-radius: 999px;
  background: rgba(255,255,255,.55);
  font-size: .8rem;
  font-weight: 950;
  letter-spacing: .04em;
  text-transform: uppercase;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}
.nav a:hover, .nav a:focus-visible { transform: translate(-2px,-2px) rotate(-1deg); box-shadow: 5px 5px 0 rgba(36,19,37,.22); background: var(--cream); }
.nav .nav-cta { background: var(--hot-pink); border-color: var(--ink); }
.menu-toggle { display: none; }

main { overflow: hidden; }
section { position: relative; }
.hero, .manifesto, .work, .gallery, .donation, .contact { padding: clamp(4rem, 7vw, 7.5rem) 4.5vw; }

.hero {
  min-height: calc(100svh - 84px);
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(340px, 1.05fr);
  gap: clamp(2rem, 5vw, 5.4rem);
  align-items: center;
}
.hero::before {
  content: "";
  position: absolute;
  left: 4.5vw;
  right: 4.5vw;
  top: 1.4rem;
  height: .9rem;
  border: 2px solid var(--ink);
  box-shadow: 5px 5px 0 rgba(36,19,37,.18);
  background: linear-gradient(90deg, var(--sky) 0 22%, #fff 22% 36%, var(--pink) 36% 58%, var(--cream) 58% 77%, var(--purple) 77% 100%);
}
.issue-row {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin-bottom: 1.5rem;
}
.issue-row span, .eyebrow, .section-label, .sticker, .breb-card span, .qr-card p {
  font-size: .78rem;
  font-weight: 950;
  letter-spacing: .1em;
  text-transform: uppercase;
}
.issue-row span {
  padding: .48rem .68rem;
  border: 1.5px solid var(--ink);
  background: var(--paper);
  box-shadow: 3px 3px 0 rgba(36,19,37,.12);
}
.issue-row span:nth-child(1) { background: var(--pink); }
.issue-row span:nth-child(2) { background: var(--sky); }
.issue-row span:nth-child(3) { background: var(--cream); }
.eyebrow, .section-label { margin: 0 0 1rem; color: var(--violet); }

.hero h1, .manifesto h2, .section-heading h2, .donation h2, .contact h2 {
  margin: 0;
  font-family: "Fraunces", Georgia, serif;
  font-weight: 900;
  line-height: .86;
  letter-spacing: -.06em;
  text-wrap: balance;
}
.hero h1 { max-width: 10.7ch; font-size: clamp(4rem, 9vw, 8.6rem); }
.hero h1::after {
  content: "";
  display: block;
  width: min(26rem, 78vw);
  height: 1rem;
  margin-top: .8rem;
  border: 2px solid var(--ink);
  background: linear-gradient(90deg, var(--hot-pink), var(--sky), #fff, var(--hot-pink));
  transform: rotate(-1.8deg);
}
.lead, .manifesto-card p, .manifesto-copy p, .work-card p, .donation-copy p, .contact-card p {
  color: var(--ink-soft);
  line-height: 1.72;
  font-size: clamp(1rem, 1.18vw, 1.12rem);
}
.lead { max-width: 43rem; margin: 1.4rem 0 0; font-weight: 700; }
.hero-actions { display: flex; flex-wrap: wrap; gap: .9rem; margin-top: 2rem; }
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 3.35rem;
  padding: .95rem 1.2rem;
  border: 2px solid var(--ink);
  border-radius: .7rem 1.55rem .7rem 1.55rem;
  font-weight: 950;
  letter-spacing: .04em;
  text-transform: uppercase;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}
.button:hover, .button:focus-visible { transform: translate(-3px,-3px) rotate(-1deg); box-shadow: 8px 8px 0 var(--ink); }
.button.primary { background: var(--hot-pink); }
.button.ghost { background: var(--sky); }

.hero-collage { position: relative; min-height: min(47rem, 74vw); }
.photo-tape {
  position: absolute;
  margin: 0;
  border: 2px solid var(--ink);
  background: var(--paper);
  box-shadow: var(--shadow-hard);
  overflow: hidden;
}
.photo-tape::before {
  content: "";
  position: absolute;
  z-index: 2;
  width: 7rem;
  height: 2rem;
  left: 50%;
  top: -.8rem;
  transform: translateX(-50%) rotate(-4deg);
  background: rgba(255,240,184,.78);
  border: 1px solid rgba(36,19,37,.16);
}
.photo-tape img { width: 100%; height: 100%; object-fit: cover; filter: saturate(1.08) contrast(1.04); }
.photo-main {
  width: min(88%, 39rem);
  height: min(41rem, 62vw);
  right: 0;
  top: 2rem;
  border-radius: 2rem .75rem 2.3rem .8rem;
  transform: rotate(2deg);
}
.photo-small {
  width: min(46%, 18rem);
  height: 22rem;
  left: 0;
  bottom: 1rem;
  border-radius: .85rem 2rem .75rem 2rem;
  transform: rotate(-5deg);
}
.hero-logo {
  position: absolute;
  z-index: 4;
  width: min(34%, 13rem);
  left: 8%;
  top: 1.5rem;
  border-radius: 50%;
  filter: drop-shadow(0 14px 20px rgba(36,19,37,.22));
}
.sticker {
  position: absolute;
  z-index: 5;
  margin: 0;
  padding: .72rem .88rem;
  border: 2px solid var(--ink);
  box-shadow: 6px 6px 0 rgba(36,19,37,.24);
}
.sticker-one { right: 3%; bottom: 4rem; background: var(--cream); transform: rotate(5deg); }
.sticker-two { left: 3%; top: 16rem; background: var(--sky); transform: rotate(-7deg); max-width: 15rem; }
.sticker-three { right: 16%; top: 0; background: var(--pink); transform: rotate(-3deg); }

.phrase-strip {
  border-block: 2px solid var(--ink);
  background: var(--night);
  color: var(--paper);
  overflow: hidden;
  transform: rotate(-1deg) scale(1.02);
}
.phrase-strip div { display: flex; width: max-content; animation: marquee 28s linear infinite; }
.phrase-strip span {
  padding: 1rem 1.5rem;
  font-family: "Archivo Black", Impact, sans-serif;
  font-size: clamp(1.35rem, 4vw, 3.1rem);
  text-transform: uppercase;
  white-space: nowrap;
}
.phrase-strip span:nth-child(odd) { color: var(--hot-pink); }
.phrase-strip span:nth-child(even) { color: var(--sky); }

.manifesto {
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(0, 1.05fr);
  gap: clamp(2rem, 5vw, 5rem);
}
.manifesto::before, .work::before, .gallery::before, .donation::before, .contact::before {
  content: "";
  position: absolute;
  left: 4.5vw;
  right: 4.5vw;
  top: 0;
  border-top: 2px dashed rgba(36,19,37,.25);
}
.manifesto-card, .contact-card {
  position: relative;
  padding: clamp(1.4rem, 3vw, 2.4rem);
  border: 2px solid var(--ink);
  border-radius: var(--radius-weird);
  background:
    linear-gradient(135deg, rgba(255,255,255,.72), rgba(255,216,232,.58)),
    var(--paper);
  box-shadow: var(--shadow-hard);
}
.manifesto-card::after, .contact-card::after {
  content: "";
  position: absolute;
  width: 7rem;
  height: 2rem;
  top: -1rem;
  right: 12%;
  background: rgba(70,191,226,.55);
  border: 1px solid rgba(36,19,37,.18);
  transform: rotate(6deg);
}
.manifesto h2, .section-heading h2, .donation h2, .contact h2 { font-size: clamp(3rem, 6.7vw, 6.8rem); }
.manifesto-copy {
  columns: 2 17rem;
  column-gap: 2rem;
  padding-top: 1rem;
}
.manifesto-copy p { break-inside: avoid; margin: 0 0 1.2rem; }
.manifesto-copy p:first-child::first-letter {
  float: left;
  margin: .08em .12em 0 0;
  font-family: "Fraunces", Georgia, serif;
  font-size: 4.8rem;
  line-height: .72;
  color: var(--hot-pink);
}

.section-heading { max-width: 74rem; margin-bottom: 2.6rem; }
.work-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}
.work-card {
  position: relative;
  min-height: 20rem;
  padding: 1.3rem;
  border: 2px solid var(--ink);
  background: rgba(255,255,255,.62);
  box-shadow: 6px 6px 0 rgba(36,19,37,.18);
  transform: rotate(var(--tilt, -1deg));
  transition: transform .18s ease, box-shadow .18s ease;
}
.work-card:nth-child(2) { --tilt: 1.7deg; }
.work-card:nth-child(3) { --tilt: -2deg; }
.work-card:nth-child(4) { --tilt: 1deg; }
.work-card:hover { transform: translate(-3px,-3px) rotate(0); box-shadow: 10px 10px 0 var(--ink); }
.work-card::before {
  content: "";
  position: absolute;
  inset: .7rem;
  border: 1px solid rgba(36,19,37,.15);
  pointer-events: none;
}
.work-card span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.8rem;
  height: 2.8rem;
  border: 2px solid var(--ink);
  border-radius: 50%;
  background: var(--cream);
  font-weight: 950;
}
.work-card h3 {
  margin: 1rem 0 .85rem;
  font-family: "Archivo Black", Impact, sans-serif;
  font-size: clamp(1.8rem, 2.5vw, 2.6rem);
  line-height: .9;
  letter-spacing: -.04em;
  text-transform: uppercase;
}
.work-card.featured { background: linear-gradient(135deg, var(--pink), var(--sky)); }

.gallery-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  grid-auto-rows: 18rem;
  gap: 1rem;
}
.gallery-item {
  position: relative;
  margin: 0;
  border: 2px solid var(--ink);
  background: var(--paper);
  box-shadow: 6px 6px 0 rgba(36,19,37,.17);
  overflow: hidden;
  transform: rotate(var(--tilt, -.8deg));
}
.gallery-item:nth-child(2) { --tilt: 1.2deg; }
.gallery-item:nth-child(3) { --tilt: -1.6deg; }
.gallery-item:nth-child(4) { --tilt: 1deg; }
.gallery-item.tall { grid-row: span 2; }
.gallery-item.wide { grid-column: span 2; }
.gallery-item img { width: 100%; height: 100%; object-fit: cover; filter: saturate(1.06); }
.gallery-item figcaption {
  position: absolute;
  left: .8rem;
  right: .8rem;
  bottom: .8rem;
  padding: .65rem .75rem;
  border: 1.5px solid var(--ink);
  background: rgba(255,246,239,.88);
  font-family: "IBM Plex Mono", monospace;
  font-size: .82rem;
  font-weight: 700;
}

.hr {
  display: block;
  margin-top: 0.5em;
  margin-bottom: 0.5em;
  margin-left: auto;
  margin-right: auto;
  border-style: inset;
  border-width: 1px;
}

.donation {
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(320px, 1.1fr);
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
}
.donation-copy p:not(.section-label) { max-width: 43rem; }
.breb-card {
  position: relative;
  display: grid;
  gap: .6rem;
  max-width: 39rem;
  margin-top: 1.6rem;
  padding: 1.2rem;
  border: 2px solid var(--ink);
  border-radius: .8rem 2rem .8rem 2rem;
  background: linear-gradient(135deg, var(--paper-blue), var(--paper-pink));
  box-shadow: 7px 7px 0 rgba(36,19,37,.2);
}
.breb-card::after {
  content: "";
  position: absolute;
  width: 6.5rem;
  height: 1.8rem;
  top: -.9rem;
  left: 12%;
  background: rgba(255,240,184,.78);
  border: 1px solid rgba(36,19,37,.18);
  transform: rotate(-4deg);
}
.breb-key {
  font-family: "IBM Plex Mono", monospace;
  font-size: clamp(1.1rem, 2.8vw, 2rem);
  word-break: break-word;
}
.copy-breb {
  justify-self: start;
  padding: .72rem .95rem;
  border: 2px solid var(--ink);
  border-radius: 999px;
  background: var(--cream);
  font-weight: 950;
  cursor: pointer;
}
.copy-status { color: var(--ink-soft); font-weight: 800; }
.donation-visual {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  align-items: start;
}
.qr-card {
  position: relative;
  padding: 1rem;
  border: 2px solid var(--ink);
  background: rgba(255,255,255,.72);
  box-shadow: var(--shadow-hard);
  transform: rotate(var(--tilt, 1.2deg));
}
.qr-card:nth-child(2) { --tilt: -2deg; margin-top: 3rem; }
.qr-card p { margin: 0 0 .7rem; color: var(--violet); }
.qr-card img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: contain;
  border: 1.5px dashed rgba(36,19,37,.25);
  background: #fff;
}
.qr-card span {
  display: block;
  margin-top: .7rem;
  font-family: "IBM Plex Mono", monospace;
  font-size: .85rem;
  font-weight: 700;
  color: var(--ink-soft);
}
.poster-break {
  margin: 0 4.5vw clamp(4rem, 7vw, 7rem);
  border: 2px solid var(--ink);
  border-radius: 1.8rem .8rem 2.2rem .8rem;
  overflow: hidden;
  box-shadow: var(--shadow-hard);
  background: var(--paper);
}
.poster-break img { width: 100%; max-height: 76rem; object-fit: cover; }

.contact-card { max-width: 78rem; }
.contact-card h2 { max-width: 13ch; }

.footer {
  padding: 3rem 4.5vw 4rem;
  border-top: 2px solid var(--ink);
  background: var(--night);
  color: var(--paper);
  text-align: center;
}
.footer img { width: min(8rem, 38vw); margin: 0 auto 1.2rem; filter: drop-shadow(0 12px 22px rgba(255,255,255,.12)); }
.footer p {
  max-width: 58rem;
  margin: 0 auto 1rem;
  font-family: "Archivo Black", Impact, sans-serif;
  font-size: clamp(1.1rem, 3.4vw, 2.6rem);
  line-height: 1.05;
  color: var(--pink);
}
.footer small { color: rgba(255,246,239,.7); }

.reveal { opacity: 0; transform: translateY(34px); transition: opacity .75s ease, transform .75s cubic-bezier(.2,.8,.2,1); }
.reveal.is-visible { opacity: 1; transform: translateY(0) rotate(var(--tilt, 0deg)); }

@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
  .reveal { opacity: 1; transform: none; }
}

@media (max-width: 1120px) {
  .hero, .manifesto, .donation { grid-template-columns: 1fr; }
  .hero h1 { max-width: 12ch; }
  .hero-collage { min-height: 40rem; }
  .work-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .gallery-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 760px) {
  .topbar { grid-template-columns: 1fr auto; padding-inline: 1rem; }
  .brand img { width: 3.35rem; }
  .menu-toggle {
    display: inline-flex;
    align-items: center;
    gap: .6rem;
    padding: .65rem .8rem;
    border: 2px solid var(--ink);
    border-radius: 999px;
    background: var(--cream);
    font-weight: 950;
    text-transform: uppercase;
    box-shadow: 4px 4px 0 rgba(36,19,37,.18);
  }
  .menu-toggle i, .menu-toggle i::before, .menu-toggle i::after { display: block; width: 1.1rem; height: 2px; background: var(--ink); content: ""; }
  .menu-toggle i { position: relative; }
  .menu-toggle i::before { position: absolute; top: -6px; }
  .menu-toggle i::after { position: absolute; top: 6px; }
  .nav { grid-column: 1 / -1; display: none; justify-content: flex-start; padding-top: .5rem; }
  .nav.is-open { display: flex; }

  .hero, .manifesto, .work, .gallery, .donation, .contact { padding-inline: 1.1rem; }
  .hero { min-height: auto; padding-top: 4.3rem; }
  .hero::before, .manifesto::before, .work::before, .gallery::before, .donation::before, .contact::before { left: 1.1rem; right: 1.1rem; }
  .hero h1 { max-width: 100%; font-size: clamp(3.1rem, 16vw, 5.4rem); }
  .hero-collage { min-height: 34rem; }
  .photo-main { width: 96%; height: 28rem; }
  .photo-small { width: 52%; height: 16rem; }
  .hero-logo { width: 7rem; }
  .sticker-two { top: 13rem; }
  .manifesto-copy { columns: 1; }
  .work-grid, .gallery-grid, .donation-visual { grid-template-columns: 1fr; }
  .gallery-grid { grid-auto-rows: 22rem; }
  .gallery-item.tall, .gallery-item.wide { grid-row: auto; grid-column: auto; }
  .qr-card:nth-child(2) { margin-top: 0; }
  .poster-break { margin-inline: 1.1rem; }
}
