@import url('https://fonts.googleapis.com/css2?family=Cutive+Mono&family=UnifrakturCook:wght@700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Bona+Nova:wght@400;700&family=Cabin+Sketch:wght@400;700&family=Special+Elite&display=swap');

:root {
  --bg: #050007;
  --pink: #ff2bd6;
  --acid: #b6ff00;
  --cyan: #00f7ff;
  --purple: #7a00ff;
  --paper: #f7f2e8;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  background:
    radial-gradient(circle at top left, rgba(255,43,214,.28), transparent 30%),
    radial-gradient(circle at bottom right, rgba(0,247,255,.2), transparent 35%),
    linear-gradient(180deg, #050007, #110015 55%, #030003);
  color: var(--paper);
  font-family: "Cutive Mono", monospace;
  overflow-x: hidden;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    repeating-linear-gradient(
      to bottom,
      rgba(255,255,255,.04),
      rgba(255,255,255,.04) 1px,
      transparent 1px,
      transparent 4px
    );
  mix-blend-mode: overlay;
  z-index: 999;
}

a {
  color: var(--cyan);
  text-decoration: none;
}

a:hover {
  color: var(--acid);
  text-shadow: 0 0 12px var(--acid);
}

.marquee {
  background: var(--acid);
  color: #000;
  font-weight: 700;
  padding: 8px 0;
  border-bottom: 3px solid var(--pink);
  white-space: nowrap;
  overflow: hidden;
}

.marquee span {
  display: inline-block;
  padding-left: 100%;
  animation: scroll 18s linear infinite;
}

@keyframes scroll {
  to {
    transform: translateX(-100%);
  }
}

nav {
  position: sticky;
  top: 0;
  z-index: 99;
  background: rgba(5,0,7,.9);
  border-top: 2px solid var(--pink);
  border-bottom: 2px solid var(--cyan);
  backdrop-filter: blur(8px);
}

nav ul {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 18px;
  margin: 0;
  padding: 14px;
  list-style: none;
}

nav a {
  text-transform: uppercase;
  font-weight: 700;
  font-size: .9rem;
}

nav a.active {
  color: var(--acid);
  text-shadow: 0 0 12px var(--acid);
}

header {
  min-height: 80vh;
  display: grid;
  place-items: center;
  text-align: center;
  position: relative;
  padding: 40px 20px;
}

.logo {
  font-family: "UnifrakturCook", serif;
  font-size: clamp(4rem, 14vw, 12rem);
  line-height: .8;
  color: var(--pink);
  text-shadow:
    4px 4px 0 var(--cyan),
    -4px -4px 0 var(--purple),
    0 0 30px var(--pink);
  animation: glitch 1.8s infinite;
}

@keyframes glitch {
  0%, 90%, 100% {
    transform: translate(0);
  }

  92% {
    transform: translate(4px, -3px);
  }

  94% {
    transform: translate(-5px, 2px);
  }

  96% {
    transform: translate(3px, 3px);
  }
}

.subtitle {
  max-width: 750px;
  margin: 25px auto;
  font-size: 1rem;
  color: #ddd;
  background: rgba(0,0,0,.65);
  border: 1px solid var(--cyan);
  padding: 14px;
  box-shadow: 0 0 20px rgba(0,247,255,.35);
  font-family: "Cutive Mono", monospace;
}

.tag {
  display: inline-block;
  background: var(--pink);
  color: #000;
  font-weight: 700;
  padding: 3px 7px;
  margin: 3px;
  font-size: .75rem;
  transform: rotate(-2deg);
}

.container {
  width: min(1250px, 94%);
  margin: 40px auto;
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: 25px;
}

main,
aside {
  min-width: 0;
}

main {
  grid-column: 1;
  grid-row: 1;
}

aside {
  grid-column: 2;
  grid-row: 1 / span 2;
}

.submit-tip {
  grid-column: 1;
  grid-row: 2;
}

 .story-card,
.submit-tip,
.date-feature {
  border: 2px solid var(--pink);
  background:
    linear-gradient(135deg, rgba(255,43,214,.15), rgba(0,247,255,.08)),
    rgba(0,0,0,.75);
  padding: 24px;
  box-shadow: 0 0 28px rgba(255,43,214,.25);
}

.story-card,
.submit-tip {
  font-family: "Special Elite", "Cutive Mono", monospace;
}

.date-feature {
  font-family: "Cutive Mono", monospace;
}

.story-card h2,
.submit-tip h2 {
  font-family: "Special Elite", "Cutive Mono", monospace;
  font-weight: 400;
  font-size: clamp(2.2rem, 5.5vw, 4.4rem);
  line-height: .95;
  margin: 0 0 14px;
  color: var(--cyan);
  text-shadow: 2px 2px 0 rgba(255,43,214,.55);
}

.date-feature h2 {
  font-family: "Cutive Mono", monospace;
  font-weight: 400;
  font-size: clamp(1.75rem, 4.4vw, 3.2rem);
  line-height: 1;
  margin: 0 0 12px;
  color: var(--cyan);
  text-transform: uppercase;
}

.story-card p,
.submit-tip p {
  font-size: 1.02rem;
  line-height: 1.58;
  letter-spacing: .01em;
}

.date-feature p {
  font-size: 1rem;
  line-height: 1.5;
}

.story-card a,
.submit-tip a,
.date-feature a {
  font-family: "Cutive Mono", monospace;
  font-size: .85rem;
  font-weight: 700;
  text-transform: uppercase;
}


.date,
.board-kicker {
  color: var(--cyan);
  font-family: "Cutive Mono", monospace;
  font-size: .8rem;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.date-feature {
  margin-top: 25px;
  border: 0;
  background:
    radial-gradient(circle at 12% 18%, rgba(182,255,0,.18), transparent 25%),
    radial-gradient(circle at 88% 76%, rgba(255,43,214,.2), transparent 30%),
    rgba(0,0,0,.72);
  box-shadow:
    0 0 28px rgba(0,247,255,.16),
    inset 0 0 35px rgba(255,43,214,.08);
  position: relative;
  overflow: hidden;
}

.date-feature::before {
  content: "";
  position: absolute;
  inset: 12px;
  border: 1px dashed rgba(182,255,0,.5);
  pointer-events: none;
}

.date-feature::after {
  content: "date board";
  position: absolute;
  top: 16px;
  right: -38px;
  background: var(--acid);
  color: #000;
  padding: 5px 42px;
  font-family: "Cutive Mono", monospace;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  transform: rotate(32deg);
}

.date-feature-inner {
  display: grid;
  grid-template-columns: minmax(190px, 250px) 1fr;
  gap: 24px;
  align-items: center;
  position: relative;
  z-index: 1;
}

.calendar-card {
  min-height: 260px;
  color: #050007;
  background:
    linear-gradient(135deg, rgba(255,255,255,.85), rgba(247,242,232,.96)),
    #f7f2e8;
  display: grid;
  grid-template-rows: auto 1fr auto;
  text-align: center;
  position: relative;
  overflow: visible;
  transform: rotate(-2.2deg);
  clip-path: polygon(0 3%, 8% 0, 18% 3%, 30% 0, 45% 2%, 58% 0, 70% 3%, 84% 0, 100% 4%, 98% 100%, 87% 97%, 74% 100%, 61% 97%, 48% 100%, 35% 97%, 22% 100%, 10% 97%, 0 100%);
  box-shadow:
    12px 12px 0 rgba(255,43,214,.2),
    0 0 0 2px var(--acid);
}

.calendar-card::before {
  content: "";
  position: absolute;
  top: -16px;
  left: 50%;
  width: 92px;
  height: 34px;
  background: rgba(0,247,255,.5);
  border: 1px solid rgba(255,255,255,.45);
  transform: translateX(-50%) rotate(5deg);
  box-shadow: 0 0 18px rgba(0,247,255,.32);
}

.calendar-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(circle, rgba(0,0,0,.2) 0 2px, transparent 2px),
    linear-gradient(rgba(0,0,0,.04) 1px, transparent 1px);
  background-size: 36px 36px, 100% 11px;
  mix-blend-mode: multiply;
  pointer-events: none;
}

.calendar-month {
  margin: 22px auto 0;
  width: max-content;
  max-width: calc(100% - 28px);
  padding: 7px 13px 6px;
  background: #111;
  color: var(--acid);
  font-family: "Cutive Mono", monospace;
  font-size: .82rem;
  font-weight: 700;
  letter-spacing: .16em;
  text-transform: uppercase;
  transform: rotate(1.5deg);
}

.calendar-day {
  display: grid;
  place-items: center;
  font-family: "Special Elite", "Cutive Mono", monospace;
  font-size: clamp(5rem, 10vw, 7.6rem);
  font-weight: 400;
  line-height: .8;
  color: #080808;
  text-shadow: 3px 3px 0 rgba(255,43,214,.35);
}

.calendar-caption {
  margin: 0 18px 20px;
  padding: 10px 9px 8px;
  border: 1px dashed #050007;
  background: rgba(182,255,0,.35);
  font-family: "Cutive Mono", monospace;
  font-size: .7rem;
  line-height: 1.3;
  text-transform: uppercase;
}

.date-feature-copy {
  min-width: 0;
  align-self: center;
}

.countdown-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(66px, 1fr));
  gap: 9px;
  margin: 18px 0 16px;
}

.countdown-box {
  padding: 11px 8px;
  border: 1px solid rgba(255,255,255,.22);
  background:
    linear-gradient(180deg, rgba(255,255,255,.06), transparent),
    rgba(0,0,0,.58);
  text-align: center;
  transform: rotate(var(--count-tilt, 0deg));
}

.countdown-box:nth-child(1) { --count-tilt: -1deg; }
.countdown-box:nth-child(2) { --count-tilt: .8deg; }
.countdown-box:nth-child(3) { --count-tilt: -1.2deg; }
.countdown-box:nth-child(4) { --count-tilt: 1deg; }

.countdown-box strong {
  display: block;
  color: var(--acid);
  font-family: "Special Elite", "Cutive Mono", monospace;
  font-size: clamp(1.45rem, 4vw, 2.35rem);
  font-weight: 400;
  line-height: 1;
}

.countdown-box span {
  display: block;
  margin-top: 7px;
  color: #eee;
  font-family: "Cutive Mono", monospace;
  font-size: .66rem;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.pubmag-widget {
  width: min(1160px, calc(100% - 28px));
  margin: 0 auto 34px;
  color: #f2f2f2;
  font-family: "Bona Nova", serif;
}

.pubmag-widget * {
  box-sizing: border-box;
}

.pubmag-frame {
  position: relative;
  padding: clamp(14px, 2vw, 22px);
  background:
    radial-gradient(circle at 15% 10%, rgba(255, 0, 204, 0.18), transparent 30%),
    radial-gradient(circle at 85% 80%, rgba(0, 229, 255, 0.13), transparent 32%),
    linear-gradient(135deg, #050505, #111 48%, #050505);
  box-shadow:
    0 0 35px rgba(170, 255, 0, 0.16),
    10px 10px 0 rgba(255, 0, 204, 0.14);
  overflow: hidden;
}

.pubmag-frame::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    repeating-linear-gradient(
      0deg,
      rgba(255,255,255,0.035) 0px,
      rgba(255,255,255,0.035) 1px,
      transparent 1px,
      transparent 4px
    );
  pointer-events: none;
  mix-blend-mode: screen;
  z-index: 1;
}

.pubmag-frame > * {
  position: relative;
  z-index: 2;
}

.pubmag-top {
  display: grid;
  grid-template-columns: 0.72fr 1.28fr;
  gap: 18px;
  align-items: end;
  margin-bottom: 16px;
}

.pubmag-kicker {
  margin: 0 0 8px;
  font-family: "Cutive Mono", monospace;
  color: #aaff00;
  font-size: 0.75rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.pubmag-top h2 {
  width: fit-content;
  margin: 0;
  padding: 5px 10px 6px;
  border: 1px solid #00e5ff;
  background: rgba(0,0,0,0.42);
  font-family: "Cutive Mono", monospace;
  font-size: clamp(1.5rem, 3.6vw, 3.4rem);
  font-weight: 400;
  letter-spacing: -0.03em;
  line-height: 0.92;
  color: #fff;
  text-transform: uppercase;
  text-shadow:
    1.5px 1.5px 0 #ff00cc,
    -1.5px -1.5px 0 #00e5ff;
}

.pubmag-deck {
  margin: 0;
  padding: 12px 14px;
  border: 1px solid #ff00cc;
  background: rgba(0,0,0,0.58);
  color: #e7e7e7;
  line-height: 1.42;
  font-size: 0.96rem;
}

.pubmag-controls {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 14px;
  font-family: "Cutive Mono", monospace;
}

.pubmag-tab,
.pubmag-arrow {
  border: 1px solid #777;
  background: #080808;
  color: #f2f2f2;
  padding: 10px 13px;
  font-family: "Cutive Mono", monospace;
  font-size: 0.75rem;
  text-transform: uppercase;
  cursor: pointer;
  transition: transform 0.2s ease, background 0.2s ease, border-color 0.2s ease;
}

.pubmag-tab:hover,
.pubmag-arrow:hover {
  transform: translateY(-2px);
  border-color: #ff00cc;
  background: #ff00cc;
  color: #000;
}

.pubmag-tab.active {
  background: #aaff00;
  border-color: #aaff00;
  color: #000;
}

.pubmag-book-wrap {
  perspective: 1600px;
}

.pubmag-book {
  min-height: 560px;
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  border: 1px solid #333;
  background: #111;
  transform-style: preserve-3d;
}

.pubmag-book.flipping {
  animation: pubmagBookFlip 0.55s ease;
}

@keyframes pubmagBookFlip {
  0% {
    transform: rotateY(0deg);
  }

  38% {
    transform: rotateY(-3deg) rotateX(1deg);
  }

  100% {
    transform: rotateY(0deg);
  }
}

.pubmag-cover-page,
.pubmag-content-page {
  position: relative;
  min-width: 0;
  color: #080808;
  overflow-wrap: break-word;
}

.pubmag-cover-page {
  min-height: 560px;
  padding: clamp(22px, 3vw, 34px);
  padding-bottom: 128px;
  border-right: 1px solid rgba(0,0,0,0.35);
  background:
    linear-gradient(90deg, rgba(0,0,0,0.12), transparent 22%),
    radial-gradient(circle at top right, rgba(255,0,204,0.12), transparent 35%),
    #efe2c8;
}

.pubmag-content-page {
  min-height: 560px;
  padding: clamp(24px, 3vw, 36px);
  background:
    linear-gradient(270deg, rgba(0,0,0,0.1), transparent 20%),
    #f2e6ce;
}

.pubmag-cover-page::before,
.pubmag-content-page::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(0,0,0,0.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,0,0,0.045) 1px, transparent 1px);
  background-size: 18px 18px;
  pointer-events: none;
}

.pubmag-cover-page > *,
.pubmag-content-page > * {
  position: relative;
  z-index: 1;
}

.pubmag-folio-row {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 20px;
  border-bottom: 2px solid #111;
  padding-bottom: 8px;
  font-family: "Cutive Mono", monospace;
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.pubmag-mini-masthead {
  margin: 0 0 20px;
  font-family: "Cutive Mono", monospace;
  font-size: 0.75rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: #b00083;
}

.pubmag-cover-page h3,
.pubmag-standard-page h3 {
  margin: 0;
  font-family: "Cabin Sketch", system-ui, sans-serif;
  text-transform: uppercase;
  overflow-wrap: break-word;
}

.pubmag-cover-page h3 {
  font-size: clamp(2.8rem, 5.8vw, 5.45rem);
  line-height: 0.8;
}

.pubmag-cover-page h3.pubmag-one-line-title {
  white-space: nowrap;
  font-size: clamp(2.65rem, 5.15vw, 4.85rem);
  letter-spacing: -0.04em;
}

.pubmag-standard-page h3 {
  margin-bottom: 16px;
  font-size: clamp(2.3rem, 5vw, 4.8rem);
  line-height: .82;
}

.pubmag-cover-tag {
  display: inline-block;
  margin: 18px 0;
  padding: 8px 10px;
  max-width: 100%;
  border: 1px solid #111;
  background: #aaff00;
  color: #000;
  font-family: "Cutive Mono", monospace;
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  line-height: 1.25;
  text-transform: uppercase;
  transform: rotate(-1deg);
  overflow-wrap: break-word;
}

.pubmag-cover-summary {
  margin: 0;
  max-width: 100%;
  font-size: clamp(0.95rem, 1.2vw, 1.04rem);
  line-height: 1.4;
  overflow-wrap: break-word;
}


.pubmag-barcode {
  position: absolute;
  left: clamp(22px, 3vw, 34px);
  right: clamp(22px, 3vw, 34px);
  bottom: 24px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
  align-items: end;
  border-top: 2px solid #111;
  padding-top: 10px;
}

.pubmag-bars {
  height: 48px;
  width: 120px;
  background:
    repeating-linear-gradient(
      90deg,
      #111 0px,
      #111 3px,
      transparent 3px,
      transparent 7px,
      #111 7px,
      #111 9px,
      transparent 9px,
      transparent 14px
    );
}

.pubmag-barcode span {
  font-family: "Cutive Mono", monospace;
  font-size: 0.68rem;
  text-transform: uppercase;
  line-height: 1.25;
  overflow-wrap: break-word;
}

.pubmag-page-label {
  margin: 0 0 12px;
  font-family: "Cutive Mono", monospace;
  color: #b00083;
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.pubmag-page-text {
  margin: 0;
  max-width: 100%;
  font-size: clamp(1rem, 1.3vw, 1.12rem);
  line-height: 1.52;
  overflow-wrap: break-word;
}

.pubmag-dropcap::first-letter {
  float: left;
  font-family: "Cabin Sketch", system-ui, sans-serif;
  font-size: 4.35rem;
  line-height: 0.75;
  margin: 8px 8px 0 0;
  color: #b00083;
}

.pubmag-pullquote {
  margin: 22px 0 0;
  padding: 14px;
  border-left: 5px solid #ff00cc;
  background: rgba(255,255,255,0.35);
  font-family: "Cutive Mono", monospace;
  font-size: clamp(0.74rem, 1vw, 0.84rem);
  line-height: 1.42;
  text-transform: uppercase;
  overflow-wrap: break-word;
}

.pubmag-link {
  display: inline-block;
  margin-top: 18px;
  color: #000;
  font-family: "Cutive Mono", monospace;
  font-size: 0.8rem;
  font-weight: 700;
  text-decoration: none;
  border-bottom: 2px solid #ff00cc;
  overflow-wrap: break-word;
}

.pubmag-link:hover {
  background: #aaff00;
  color: #000;
  text-shadow: none;
}

.pubmag-book.artist-mode {
  grid-template-columns: 1fr;
}

.pubmag-book.artist-mode .pubmag-cover-page {
  display: none;
}

.pubmag-book.artist-mode .pubmag-content-page {
  min-height: 560px;
  padding: clamp(18px, 2.4vw, 30px);
  background:
    radial-gradient(circle at 15% 15%, rgba(255,0,204,.16), transparent 32%),
    radial-gradient(circle at 85% 75%, rgba(0,229,255,.16), transparent 34%),
    #efe2c8;
}

.pubmag-artist-feature {
  display: none;
  min-height: 500px;
}

.pubmag-artist-shell {
  min-height: 500px;
  display: grid;
  grid-template-columns: minmax(230px, .8fr) 1.2fr;
  gap: clamp(18px, 3vw, 34px);
  align-items: stretch;
}

.pubmag-artist-poster {
  position: relative;
  min-height: 420px;
  border: 2px solid #111;
  background:
    radial-gradient(circle at 25% 18%, rgba(255,0,204,0.34), transparent 28%),
    radial-gradient(circle at 80% 72%, rgba(0,229,255,0.28), transparent 34%),
    repeating-linear-gradient(
      -45deg,
      rgba(0,0,0,0.12) 0 8px,
      rgba(255,255,255,0.2) 8px 16px
    ),
    #d8ccb2;
  display: grid;
  place-items: center;
  overflow: hidden;
  box-shadow: 10px 10px 0 rgba(0,0,0,0.18);
}

.pubmag-artist-poster::before {
  content: "FEATURED";
  position: absolute;
  top: 12px;
  left: 12px;
  z-index: 2;
  padding: 6px 9px;
  background: #aaff00;
  border: 1px solid #111;
  font-family: "Cutive Mono", monospace;
  font-size: .7rem;
  letter-spacing: .13em;
  text-transform: uppercase;
}

.pubmag-artist-poster img {
  width: 100%;
  height: 100%;
  min-height: 420px;
  object-fit: cover;
  display: block;
}

.pubmag-artist-placeholder {
  padding: 10px 13px;
  border: 1px dashed #111;
  background: rgba(255,255,255,0.74);
  font-family: "Cutive Mono", monospace;
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  line-height: 1.3;
  text-align: center;
  text-transform: uppercase;
}

.pubmag-artist-copy {
  min-width: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.pubmag-artist-copy .pubmag-page-label {
  margin-bottom: 12px;
}

.pubmag-artist-copy h3 {
  margin: 0 0 10px;
  font-family: "Cabin Sketch", system-ui, sans-serif;
  font-size: clamp(3rem, 7vw, 6.6rem);
  line-height: .76;
  text-transform: uppercase;
  overflow-wrap: break-word;
}

.pubmag-artist-role {
  width: fit-content;
  max-width: 100%;
  margin: 0 0 18px;
  padding: 7px 9px;
  border: 1px solid #111;
  background: #ff00cc;
  color: #000;
  font-family: "Cutive Mono", monospace;
  font-size: 0.76rem;
  line-height: 1.3;
  text-transform: uppercase;
  transform: rotate(-1deg);
}

.pubmag-artist-bio {
  margin: 0;
  max-width: 680px;
  font-size: clamp(1.02rem, 1.5vw, 1.22rem);
  line-height: 1.45;
  overflow-wrap: break-word;
}

.pubmag-artist-meta {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-top: 22px;
  font-family: "Cutive Mono", monospace;
  font-size: 0.72rem;
  line-height: 1.3;
  text-transform: uppercase;
}

.pubmag-artist-meta span {
  border: 1px solid #111;
  background: rgba(255,255,255,.36);
  padding: 10px;
  overflow-wrap: break-word;
}

.missing-ad,
.sidebar-box,
aside {
  font-family: "Cutive Mono", monospace;
}

.missing-ad {
  background:
    repeating-linear-gradient(
      -45deg,
      #111,
      #111 8px,
      #1d001f 8px,
      #1d001f 16px
    );
  border: 2px dashed var(--acid);
  padding: 20px;
  margin-bottom: 20px;
  text-align: center;
  min-height: 220px;
  display: grid;
  place-items: center;
  position: relative;
  overflow: hidden;
  animation: pulse 2s infinite alternate;
}

.missing-ad::before {
  content: "VACANT";
  position: absolute;
  top: 12px;
  right: -35px;
  background: var(--pink);
  color: #000;
  font-weight: 700;
  padding: 4px 40px;
  transform: rotate(35deg);
  font-size: .7rem;
}

.missing-label {
  font-size: 4rem;
  font-weight: 700;
  color: var(--pink);
  text-shadow:
    2px 2px 0 var(--cyan),
    -2px -2px 0 var(--purple),
    0 0 20px var(--pink);
  line-height: 1;
}

.missing-icon {
  font-size: 2rem;
  color: var(--acid);
  animation: glitch 2s infinite;
}

.missing-ad h3 {
  color: var(--acid);
  margin: 10px 0;
  font-size: 1rem;
}

.missing-ad p {
  color: #ccc;
  font-size: .8rem;
  margin-bottom: 15px;
}

.missing-ad a {
  display: inline-block;
  padding: 8px 14px;
  border: 1px solid var(--cyan);
  color: var(--cyan);
  font-weight: 700;
  transition: .25s;
}

.missing-ad a:hover {
  background: var(--cyan);
  color: #000;
  box-shadow: 0 0 15px var(--cyan);
  text-shadow: none;
}

@keyframes pulse {
  from {
    box-shadow: 0 0 8px rgba(182,255,0,.3);
  }

  to {
    box-shadow: 0 0 25px rgba(255,43,214,.5);
  }
}

.sidebar-box {
  background: rgba(0,0,0,.82);
  border: 1px solid var(--cyan);
  padding: 15px;
  margin-bottom: 20px;
}

.sidebar-box h3 {
  color: var(--cyan);
  margin-top: 0;
}


footer {
  margin-top: 60px;
  padding: 35px 20px;
  text-align: center;
  background: #000;
  border-top: 3px solid var(--pink);
  color: #aaa;
  font-family: "Cutive Mono", monospace;
}

.floating {
  position: fixed;
  font-size: 1.6rem;
  pointer-events: none;
  opacity: .55;
  animation: drift 9s linear infinite;
  z-index: 1;
}

@keyframes drift {
  from {
    transform: translateY(110vh) rotate(0deg);
  }

  to {
    transform: translateY(-20vh) rotate(360deg);
  }
}

@media (max-width: 1050px) {
  .pubmag-book {
    grid-template-columns: 1fr;
  }

  .pubmag-cover-page {
    min-height: auto;
    border-right: 0;
    border-bottom: 1px solid rgba(0,0,0,0.35);
  }

  .pubmag-content-page {
    min-height: auto;
  }

  .pubmag-artist-shell,
  .pubmag-artist-meta {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 850px) {
  .container {
    grid-template-columns: 1fr;
    gap: 22px;
    margin: 28px auto;
  }

  main {
    grid-column: 1;
    grid-row: auto;
    order: 1;
  }

  aside {
    grid-column: 1;
    grid-row: auto;
    order: 2;
  }

  .submit-tip {
    grid-column: 1;
    grid-row: auto;
    order: 3;
  }

  .pubmag-top,
  .date-feature-inner,
  .countdown-grid {
    grid-template-columns: 1fr;
  }

  .calendar-card {
    min-height: 230px;
    transform: rotate(-1deg);
  }
}

@media (max-width: 560px) {
  header {
    min-height: auto;
    padding: 56px 14px;
  }

  .logo {
    font-size: clamp(3.4rem, 22vw, 5.8rem);
  }

  .subtitle {
    font-size: 0.86rem;
    padding: 12px;
  }

  .container {
    width: calc(100% - 20px);
    margin: 24px auto;
  }

  .story-card,
  .submit-tip,
  .date-feature {
    padding: 18px;
  }

  .pubmag-widget {
    width: 100%;
    margin: 0 auto 24px;
  }

  .pubmag-frame {
    padding: 10px;
  }

  .pubmag-top {
    gap: 14px;
    margin-bottom: 16px;
  }

  .pubmag-deck {
    padding: 13px;
    font-size: 0.98rem;
  }

  .pubmag-controls {
    flex-direction: column;
    gap: 7px;
  }

  .pubmag-tab,
  .pubmag-arrow {
    width: 100%;
  }

  .pubmag-book {
    min-height: auto;
  }

  .pubmag-cover-page,
  .pubmag-content-page {
    padding: 18px;
  }

  .pubmag-cover-page {
    padding-bottom: 118px;
  }

  .pubmag-cover-page h3 {
    font-size: clamp(2.75rem, 13vw, 4.7rem);
  }

  .pubmag-cover-page h3.pubmag-one-line-title {
    font-size: clamp(1.8rem, 12vw, 4.35rem);
  }

  .pubmag-page-text {
    font-size: 0.96rem;
  }

  .pubmag-dropcap::first-letter {
    font-size: 3.7rem;
  }

  .pubmag-pullquote {
    font-size: 0.72rem;
  }

  .pubmag-barcode {
    left: 18px;
    right: 18px;
    bottom: 18px;
    grid-template-columns: 1fr auto;
  }

  .pubmag-bars {
    width: 84px;
  }

  .pubmag-artist-poster,
  .pubmag-artist-poster img {
    min-height: 250px;
  }

  .pubmag-book.artist-mode .pubmag-content-page {
    padding: 16px;
  }
}

header.page-hero {
  min-height: 38vh;
  display: grid;
  place-items: center;
  text-align: center;
  padding: 55px 20px 35px;
  border-bottom: 2px dashed rgba(255,43,214,.65);
}

.mini-logo {
  font-family: "UnifrakturCook", serif;
  font-size: clamp(3.2rem, 10vw, 7rem);
  line-height: .82;
  color: var(--pink);
  text-shadow:
    4px 4px 0 var(--cyan),
    -4px -4px 0 var(--purple),
    0 0 30px var(--pink);
  animation: glitch 1.8s infinite;
}

.page-deck {
  max-width: 780px;
  margin: 25px auto;
  font-size: 1rem;
  line-height: 1.5;
  color: #ddd;
  background: rgba(0,0,0,.65);
  border: 1px solid var(--cyan);
  padding: 14px;
  box-shadow: 0 0 20px rgba(0,247,255,.35);
  font-family: "Cutive Mono", monospace;
}

.single-column {
  width: min(1050px, 94%);
  margin: 40px auto;
}

.section-title {
  color: var(--acid);
  border-bottom: 2px dashed var(--pink);
  margin: 40px 0 20px;
  text-transform: uppercase;
  letter-spacing: 2px;
  font-family: "Cutive Mono", monospace;
}

.featured,
.panel {
  border: 2px solid var(--pink);
  background:
    linear-gradient(135deg, rgba(255,43,214,.15), rgba(0,247,255,.08)),
    rgba(0,0,0,.75);
  padding: 24px;
  box-shadow: 0 0 28px rgba(255,43,214,.25);
  font-family: "Special Elite", "Cutive Mono", monospace;
}

.featured h1,
.featured h2,
.panel h2 {
  font-family: "Special Elite", "Cutive Mono", monospace;
  font-weight: 400;
  font-size: clamp(2.1rem, 5vw, 4rem);
  line-height: .98;
  margin: 0 0 12px;
  color: var(--cyan);
  text-shadow: 2px 2px 0 rgba(255,43,214,.55);
}

.panel h2 {
  font-size: clamp(1.8rem, 4vw, 3.2rem);
}

.featured p,
.panel p,
.notice,
.neocities-form {
  font-size: 1.02rem;
  line-height: 1.58;
}

.grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 18px;
}

.card {
  background: rgba(0,0,0,.78);
  border: 1px solid rgba(255,255,255,.2);
  padding: 16px;
  position: relative;
  min-height: 230px;
  transition: .25s;
  font-family: "Cutive Mono", monospace;
}

.card:hover {
  transform: translateY(-5px) rotate(-.5deg);
  border-color: var(--acid);
  box-shadow: 0 0 20px rgba(182,255,0,.25);
}

.card h3 {
  color: var(--pink);
  margin-top: 8px;
  font-family: "Special Elite", "Cutive Mono", monospace;
  font-weight: 400;
  font-size: 1.6rem;
}

.date,
.eyebrow {
  color: var(--cyan);
  font-family: "Cutive Mono", monospace;
  font-size: .8rem;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.muted {
  color: #b9b0be;
}

.button,
button.button {
  display: inline-block;
  border: 1px solid var(--cyan);
  color: var(--cyan);
  padding: 9px 13px;
  background: rgba(0,0,0,.45);
  font-family: "Cutive Mono", monospace;
  font-size: .82rem;
  font-weight: 700;
  text-transform: uppercase;
  cursor: pointer;
}

.button:hover,
button.button:hover {
  background: var(--cyan);
  color: #000;
  box-shadow: 0 0 16px var(--cyan);
  text-shadow: none;
}

.article-list {
  display: grid;
  gap: 18px;
}

.article-list article {
  border: 1px solid rgba(255,255,255,.22);
  background: rgba(0,0,0,.78);
  padding: 18px;
  box-shadow: 6px 6px 0 rgba(255,43,214,.12);
  transition: .25s;
}

.article-list article:hover {
  transform: translateX(6px) rotate(-.2deg);
  border-color: var(--acid);
}

.article-list h2 {
  margin: 4px 0 8px;
  color: var(--pink);
  font-family: "Special Elite", "Cutive Mono", monospace;
  font-weight: 400;
  font-size: clamp(1.6rem, 4vw, 3rem);
  line-height: 1;
}

.info-table {
  width: 100%;
  border-collapse: collapse;
  background: rgba(0,0,0,.78);
  border: 1px solid var(--cyan);
  font-family: "Cutive Mono", monospace;
}

.info-table th,
.info-table td {
  border: 1px solid rgba(255,255,255,.22);
  padding: 12px;
  vertical-align: top;
}

.info-table th {
  color: #000;
  background: var(--acid);
  text-align: left;
  text-transform: uppercase;
}

.notice {
  margin-top: 22px;
  padding: 16px;
  border: 1px dashed var(--acid);
  background: rgba(0,0,0,.72);
  color: #ddd;
  font-family: "Cutive Mono", monospace;
}

.neocities-form {
  display: grid;
  gap: 14px;
  padding: 18px;
  border: 2px solid var(--cyan);
  background: rgba(0,0,0,.75);
  font-family: "Cutive Mono", monospace;
}

.neocities-form label {
  display: grid;
  gap: 7px;
  color: var(--acid);
  text-transform: uppercase;
  font-size: .85rem;
}

.neocities-form input,
.neocities-form select,
.neocities-form textarea {
  width: 100%;
  border: 1px solid rgba(255,255,255,.35);
  background: #050007;
  color: var(--paper);
  padding: 10px;
  font: inherit;
  text-transform: none;
}

.neocities-form textarea {
  min-height: 160px;
  resize: vertical;
}

.pixel-img {
  height: 120px;
  background:
    linear-gradient(45deg, var(--pink), transparent),
    repeating-linear-gradient(
      90deg,
      rgba(0,247,255,.6) 0 6px,
      rgba(0,0,0,.8) 6px 12px
    );
  border: 1px solid var(--cyan);
  margin-bottom: 12px;
}

.pixel-img.food {
  background:
    radial-gradient(circle at 30% 35%, rgba(182,255,0,.85), transparent 24%),
    linear-gradient(45deg, rgba(255,43,214,.9), transparent),
    repeating-linear-gradient(90deg, rgba(0,247,255,.45) 0 6px, rgba(0,0,0,.8) 6px 12px);
}

.pixel-img.venue {
  background:
    linear-gradient(135deg, rgba(0,247,255,.65), transparent),
    repeating-linear-gradient(0deg, rgba(255,43,214,.55) 0 8px, rgba(0,0,0,.85) 8px 16px);
}

.flyer-wall {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
  gap: 12px;
}

.flyer {
  min-height: 180px;
  padding: 10px;
  color: #000;
  font-weight: 700;
  transform: rotate(var(--r));
  border: 2px solid #000;
  box-shadow: 6px 6px 0 rgba(0,0,0,.6);
}

.flyer:nth-child(1) { background: var(--pink); --r: -2deg; }
.flyer:nth-child(2) { background: var(--acid); --r: 3deg; }
.flyer:nth-child(3) { background: var(--cyan); --r: -4deg; }
.flyer:nth-child(4) { background: #fff; --r: 2deg; }

@media (max-width: 850px) {
  header.page-hero {
    min-height: auto;
    padding: 48px 14px 32px;
  }

  .single-column {
    width: calc(100% - 20px);
    margin: 28px auto;
  }
}


.tag.alt { background: var(--acid); }
.tag.blue { background: var(--cyan); }

.image-flyer-wall {
  align-items: start;
}

.flyer-img {
  display: block;
  background: rgba(0,0,0,.78);
  border: 2px solid rgba(255,255,255,.24);
  padding: 8px;
  box-shadow: 8px 8px 0 rgba(255,43,214,.15);
  transform: rotate(var(--r, -1deg));
  transition: transform .25s ease, border-color .25s ease, box-shadow .25s ease;
}

.flyer-img:nth-child(2) { --r: 1.5deg; }
.flyer-img:nth-child(3) { --r: -2.5deg; }
.flyer-img:nth-child(4) { --r: 2deg; }
.flyer-img:nth-child(5) { --r: -.75deg; }

.flyer-img img {
  display: block;
  width: 100%;
  aspect-ratio: 3 / 4;
  object-fit: cover;
  border: 1px solid #000;
}

.flyer-img:hover {
  transform: rotate(0deg) translateY(-8px) scale(1.03);
  border-color: var(--acid);
  box-shadow: 0 0 22px rgba(182,255,0,.24);
}

.submit-flyer {
  display: grid;
  place-items: center;
  min-height: 220px;
  background: var(--acid);
  color: #000;
  text-align: center;
  font-family: "Cutive Mono", monospace;
  text-transform: uppercase;
  line-height: 1.15;
}

/* Publishing-ready shared systems */
.article-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}

.article-actions a {
  display: inline-block;
  width: fit-content;
  border: 1px solid var(--cyan);
  padding: 8px 12px;
  font-family: "Cutive Mono", monospace;
  font-size: .78rem;
  font-weight: 700;
  text-transform: uppercase;
}

.article-actions a:hover {
  background: var(--cyan);
  color: #000;
  text-shadow: none;
}

.archive-intro,
.flyer-control-panel,
.article-shell {
  margin-bottom: 24px;
}

.archive-notice code,
.flyer-control-panel code,
.notice code {
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.18);
  padding: 2px 5px;
  color: var(--acid);
}

.pager {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  margin: 24px 0 0;
  padding: 16px;
  border: 1px dashed var(--cyan);
  background: rgba(0,0,0,.72);
  font-family: "Cutive Mono", monospace;
}

.pager-link {
  display: inline-block;
  padding: 7px 9px;
  color: var(--cyan);
  font-weight: 700;
  text-transform: uppercase;
}

.pager-link.active,
.pager-link:hover {
  background: var(--acid);
  color: #000;
  text-shadow: none;
}

.full-flyer-page {
  width: min(1240px, 94%);
}

.full-flyer-grid {
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 24px;
  padding: 22px;
  border: 2px solid rgba(182,255,0,.75);
  background:
    radial-gradient(circle at 14% 20%, rgba(255,43,214,.16), transparent 28%),
    radial-gradient(circle at 80% 85%, rgba(0,247,255,.12), transparent 32%),
    rgba(0,0,0,.72);
  box-shadow: 0 0 30px rgba(182,255,0,.16);
}

.flyer-card {
  position: relative;
  overflow: hidden;
  min-height: 320px;
}

.flyer-card-caption {
  display: grid;
  gap: 3px;
  padding: 10px 8px 6px;
  background: #050007;
  border-top: 1px solid rgba(255,255,255,.22);
  font-family: "Cutive Mono", monospace;
  text-transform: uppercase;
}

.flyer-card-caption strong {
  color: var(--acid);
  font-size: .9rem;
  line-height: 1.1;
}

.flyer-card-caption small {
  color: #ddd;
  font-size: .68rem;
  line-height: 1.25;
}

.flyer-pager {
  justify-content: center;
}

.flyer-hero .mini-logo {
  font-size: clamp(3.4rem, 11vw, 8rem);
}

.article-page {
  max-width: 920px;
}

.countdown-done {
  border: 2px solid var(--acid);
  box-shadow:
    0 0 30px rgba(182,255,0,.28),
    inset 0 0 35px rgba(255,43,214,.08);
}

.countdown-done .calendar-card {
  box-shadow:
    12px 12px 0 rgba(0,247,255,.22),
    0 0 0 2px var(--acid),
    0 0 28px rgba(182,255,0,.35);
}

.confetti-piece {
  position: fixed;
  top: -30px;
  z-index: 10000;
  pointer-events: none;
  color: var(--acid);
  font-size: 1.2rem;
  text-shadow: 0 0 10px var(--pink);
  animation: confettiDrop linear forwards;
}

.confetti-piece:nth-child(3n) { color: var(--pink); }
.confetti-piece:nth-child(4n) { color: var(--cyan); }

@keyframes confettiDrop {
  0% {
    transform: translateY(-40px) rotate(0deg);
    opacity: 1;
  }

  100% {
    transform: translateY(110vh) rotate(var(--spin));
    opacity: 0;
  }
}

@media (max-width: 850px) {
  .full-flyer-grid {
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 14px;
    padding: 14px;
  }

  .flyer-card {
    min-height: auto;
  }

  .pager {
    justify-content: center;
  }
}


/* ------------------------------------------------------------
   404 CULTURE FORUM PUBLISHING SYSTEM
   ------------------------------------------------------------ */
.forum-container {
  align-items: start;
}

.forum-board-notice,
.forum-search-panel,
.tag-cloud-panel,
.author-profile-small,
.article-thread-box,
.article-footer-tools {
  border: 2px solid rgba(0,247,255,.45);
  background: rgba(0,0,0,.76);
  box-shadow: 10px 10px 0 rgba(255,43,214,.14);
  padding: clamp(18px, 3vw, 30px);
  margin-bottom: 24px;
}

.forum-board-notice h1,
.forum-feature h1,
.forum-feature h2,
.article-forum-header h1 {
  font-family: "Cabin Sketch", system-ui;
  letter-spacing: .02em;
}

.quick-search,
.forum-filter-grid {
  display: grid;
  gap: 12px;
}

.quick-search {
  grid-template-columns: 1fr auto;
  margin-top: 16px;
}

.quick-search input,
.forum-filter-grid input,
.forum-filter-grid select {
  width: 100%;
  border: 1px solid rgba(0,247,255,.55);
  background: #07010a;
  color: var(--paper);
  padding: 11px 12px;
  font-family: "Cutive Mono", monospace;
}

.quick-search button,
.forum-filter-grid button {
  border: 1px solid var(--acid);
  background: var(--acid);
  color: #000;
  padding: 11px 14px;
  font-family: "Cutive Mono", monospace;
  font-weight: 700;
  text-transform: uppercase;
  cursor: pointer;
}

.forum-filter-grid {
  grid-template-columns: repeat(5, minmax(120px, 1fr)) auto;
  align-items: end;
}

.forum-filter-grid.compact {
  grid-template-columns: 1.4fr 1fr 1fr 1fr auto;
}

.forum-filter-grid label {
  display: grid;
  gap: 6px;
  font-size: .76rem;
  color: var(--acid);
  text-transform: uppercase;
}

.result-count,
.thread-kicker {
  font-size: .78rem;
  color: var(--acid);
  text-transform: uppercase;
  letter-spacing: .08em;
}

.forum-thread-list {
  display: grid;
  gap: 13px;
}

.forum-thread {
  display: grid;
  grid-template-columns: 95px minmax(0, 1fr) 150px;
  gap: 16px;
  align-items: stretch;
  border: 1px solid rgba(255,255,255,.18);
  background: linear-gradient(90deg, rgba(255,255,255,.045), rgba(0,0,0,.38));
  padding: 12px;
  position: relative;
}

.forum-thread:hover {
  border-color: var(--cyan);
  box-shadow: 0 0 22px rgba(0,247,255,.12);
}

.thread-status {
  display: grid;
  place-items: center;
  border: 1px dashed rgba(182,255,0,.7);
  background: rgba(182,255,0,.08);
  color: var(--acid);
  font-size: .72rem;
  font-weight: 700;
  text-align: center;
  padding: 10px;
  text-transform: uppercase;
}

.thread-main h2 {
  margin: 2px 0 8px;
  font-size: clamp(1.2rem, 2vw, 1.8rem);
}

.thread-main p {
  margin: 0 0 10px;
}

.thread-author {
  display: grid;
  gap: 8px;
  align-content: center;
  justify-items: center;
  border-left: 1px solid rgba(255,255,255,.16);
  padding-left: 12px;
  font-size: .78rem;
  text-align: center;
}

.thread-author img,
.mini-author img,
.author-tile img,
.author-profile-small img,
.author-mini-card img {
  width: 72px;
  height: 72px;
  object-fit: cover;
  border: 2px solid var(--cyan);
  background: #050007;
  box-shadow: 5px 5px 0 rgba(255,43,214,.22);
}

.thread-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.forum-tag {
  display: inline-block;
  border: 1px solid rgba(0,247,255,.55);
  background: rgba(0,247,255,.08);
  color: var(--cyan);
  padding: 4px 7px;
  font-size: .72rem;
  text-transform: lowercase;
}

.forum-tag:hover {
  background: var(--cyan);
  color: #000;
  text-shadow: none;
}

.forum-empty {
  border: 1px dashed rgba(255,255,255,.3);
  padding: 20px;
  color: #ddd;
}

.forum-sidebar .sidebar-box,
.article-side-rail .sidebar-box,
.author-mini-card {
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(0,0,0,.66);
  padding: 16px;
  margin-bottom: 18px;
}

.forum-ad {
  margin-bottom: 18px;
}

.author-grid {
  display: grid;
  gap: 16px;
}

.author-tile,
.author-profile-small {
  display: grid;
  grid-template-columns: 96px 1fr;
  gap: 18px;
  align-items: start;
}

.author-tile {
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(0,0,0,.72);
  padding: 16px;
}

.author-profile-small img {
  width: 110px;
  height: 110px;
}

.article-forum-shell {
  width: min(1180px, 94%);
  margin: 32px auto;
  display: grid;
  grid-template-columns: minmax(0, 780px) 320px;
  gap: 24px;
  align-items: start;
}

.article-thread-box {
  margin-bottom: 0;
}

.article-forum-header {
  border-bottom: 1px solid rgba(255,255,255,.18);
  padding-bottom: 18px;
  margin-bottom: 20px;
}

.article-forum-header h1 {
  font-size: clamp(2.2rem, 7vw, 5.8rem);
  line-height: .92;
  margin: 8px 0 14px;
}

.article-deck {
  font-size: clamp(1rem, 2vw, 1.35rem);
  color: #f1e9dc;
  line-height: 1.45;
}

.article-byline-row,
.breadcrumb-links {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.mini-author {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.mini-author img {
  width: 42px;
  height: 42px;
}

.breadcrumb-links {
  margin-bottom: 16px;
}

.breadcrumb-links a,
.article-footer-tools a {
  border: 1px solid rgba(0,247,255,.55);
  padding: 7px 10px;
  font-size: .78rem;
  text-transform: uppercase;
}

.article-copy {
  font-family: "Bona Nova", Georgia, serif;
  font-size: clamp(1.05rem, 2vw, 1.23rem);
  line-height: 1.72;
  color: #f6efe5;
}

.article-copy p,
.article-copy ul,
.article-copy ol,
.article-copy figure,
.article-copy blockquote {
  margin-bottom: 1.25em;
}

.article-copy code,
.article-footer-tools code {
  font-family: "Cutive Mono", monospace;
  background: rgba(255,255,255,.09);
  border: 1px solid rgba(255,255,255,.14);
  padding: 1px 5px;
  color: var(--acid);
}

.article-copy blockquote {
  font-family: "Cutive Mono", monospace;
  border-left: 4px solid var(--pink);
  background: rgba(255,43,214,.08);
  padding: 16px 18px;
  color: var(--paper);
}

.article-image img,
.postcard-slide img {
  width: 100%;
  display: block;
  border: 2px solid rgba(255,255,255,.22);
  background: #000;
}

.article-image figcaption,
.postcard-slide figcaption {
  font-family: "Cutive Mono", monospace;
  font-size: .82rem;
  color: #d9d0c5;
  margin-top: 8px;
}

.article-side-rail > aside {
  width: 100%;
}

.article-side-rail #ads {
  position: sticky;
  top: 12px;
}

.author-mini-card img {
  width: 88px;
  height: 88px;
  margin-bottom: 10px;
}

.postcard-gallery {
  position: relative;
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 12px;
  align-items: center;
  margin: 28px 0;
}

.postcard-gallery button {
  border: 1px solid var(--acid);
  background: var(--acid);
  color: #000;
  font-family: "Cutive Mono", monospace;
  font-size: 1.4rem;
  font-weight: 700;
  cursor: pointer;
  padding: 10px 13px;
}

.postcard-slide {
  display: none;
  transform: rotate(-1deg);
  background: #f7f2e8;
  color: #000;
  padding: 14px;
  box-shadow: 12px 12px 0 rgba(255,43,214,.24);
}

.postcard-slide.active {
  display: block;
  animation: postcardIn .28s ease both;
}

.postcard-slide figcaption {
  color: #000;
  background: #f7f2e8;
}

@keyframes postcardIn {
  from { opacity: 0; transform: translateY(12px) rotate(1.2deg); }
  to { opacity: 1; transform: translateY(0) rotate(-1deg); }
}

.no-public-nav {
  margin-top: 24px;
}

@media (max-width: 980px) {
  .forum-filter-grid,
  .forum-filter-grid.compact,
  .article-forum-shell {
    grid-template-columns: 1fr;
  }

  .forum-thread {
    grid-template-columns: 1fr;
  }

  .thread-author {
    border-left: 0;
    border-top: 1px solid rgba(255,255,255,.16);
    padding-left: 0;
    padding-top: 10px;
    justify-items: start;
    text-align: left;
    grid-template-columns: auto 1fr;
  }

  .quick-search {
    grid-template-columns: 1fr;
  }

  .article-side-rail #ads {
    position: static;
  }

  .author-tile,
  .author-profile-small {
    grid-template-columns: 1fr;
  }

  .postcard-gallery {
    grid-template-columns: 1fr;
  }
}


/* ------------------------------------------------------------
   FINAL STRUCTURE OVERRIDES — flyer wall on Events, authors on Contact,
   grid sections, ad-heavy rails, text-first forum articles.
   ------------------------------------------------------------ */
.wide-banner-zone {
  width: min(1250px, 100%);
  margin: 22px auto;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.wide-banner-zone.inside-flow {
  width: 100%;
}

.banner-ad {
  min-height: 90px;
  display: grid;
  align-content: center;
}

.sticky-ad-rail {
  align-self: stretch;
}

.forum-sidebar {
  display: block;
}

.forum-sidebar .missing-ad,
.article-side-rail .missing-ad {
  min-height: 170px;
}

.missing-ad .missing-label {
  letter-spacing: .08em;
}

.submit-aside {
  border-color: var(--acid) !important;
  box-shadow: 6px 6px 0 rgba(182,255,0,.14);
}

.submit-aside h3 {
  margin-top: 0;
  color: var(--acid);
  text-transform: uppercase;
}

.section-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 16px;
  margin-bottom: 26px;
}

.section-grid-card {
  border: 1px solid rgba(255,255,255,.2);
  background: rgba(0,0,0,.74);
  padding: 18px;
  box-shadow: 8px 8px 0 rgba(255,43,214,.12);
  min-height: 240px;
}

.section-grid-card h2 {
  font-family: "Cabin Sketch", system-ui;
  font-size: clamp(1.45rem, 3vw, 2.35rem);
  line-height: 1;
  margin: 8px 0 10px;
}

.grid-byline {
  color: #d8d0c7;
  font-size: .82rem;
  border-top: 1px dashed rgba(255,255,255,.18);
  padding-top: 10px;
}

.contact-author-grid {
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
}

.compact-author {
  grid-template-columns: 76px 1fr;
}

.compact-author img {
  width: 72px;
  height: 72px;
}

.flyer-wall.full-flyer-grid {
  display: grid;
}

.article-note-box {
  font-family: "Cutive Mono", monospace;
  border: 1px dashed var(--acid);
  background: rgba(182,255,0,.08);
  padding: 16px;
}

.postcard-gallery-expanded {
  grid-template-columns: 1fr;
}

.postcard-toolbar {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  font-family: "Cutive Mono", monospace;
  margin-bottom: 12px;
}

.postcard-toolbar button,
.postcard-toolbar span {
  border: 1px solid var(--acid);
  background: var(--acid);
  color: #000;
  padding: 10px 13px;
  text-transform: uppercase;
  font-weight: 700;
}

.postcard-gallery-expanded .postcard-slide {
  padding: clamp(14px, 3vw, 24px);
  box-shadow: 16px 16px 0 rgba(255,43,214,.22);
}

.postcard-gallery-expanded .postcard-slide img {
  max-height: 68vh;
  object-fit: contain;
  background: #050007;
}

.postcard-blurb {
  color: #000;
  background: rgba(0,0,0,.04);
  border-top: 2px dashed #000;
  margin-top: 14px;
  padding-top: 12px;
}

.postcard-blurb h2 {
  font-family: "Cutive Mono", monospace;
  font-size: 1rem;
  margin: 0 0 6px;
  text-transform: uppercase;
}

.postcard-blurb p {
  font-family: "Bona Nova", Georgia, serif;
  margin: 0;
}

@media (max-width: 850px) {
  .wide-banner-zone {
    grid-template-columns: 1fr;
  }
  .compact-author {
    grid-template-columns: 1fr;
  }
  .postcard-toolbar {
    flex-direction: column;
    align-items: stretch;
  }
}
