/* ====================================================================
   KNICKS 2026 — picture book
   Retro Y2K fan-site energy (stars, marquee, ALL CAPS) but mobile-first
   and readable. Knicks orange + blue.
   ==================================================================== */

:root {
  --knicks-blue: #006bb6;
  --knicks-blue-dk: #00477a;
  --knicks-orange: #f58426;
  --knicks-orange-dk: #e06a0a;
  --ink: #0d1b2a;
  --paper: #fdf6ec;
  --paper-2: #fffdf8;
  --line: #0d1b2a;
  --silver: #bcc4cc;
  --shadow: 4px 4px 0 var(--ink);
  --shadow-sm: 2px 2px 0 var(--ink);
  --maxw: 1180px;
}

* { box-sizing: border-box; }

[hidden] { display: none !important; }

html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  font-family: "Space Grotesk", system-ui, sans-serif;
  color: var(--ink);
  background:
    radial-gradient(circle at 12% 0%, rgba(245,132,38,0.10), transparent 40%),
    radial-gradient(circle at 88% 8%, rgba(0,107,182,0.12), transparent 42%),
    var(--paper);
  background-attachment: fixed;
}

.skip {
  position: absolute; left: -999px; top: 0; z-index: 100;
  background: var(--knicks-orange); color: #fff; padding: 10px 16px;
  font-weight: 700; border: 3px solid var(--ink);
}
.skip:focus { left: 8px; top: 8px; }

/* ---------- HERO ---------- */
.hero {
  border-bottom: 6px solid var(--ink);
  background:
    repeating-linear-gradient(
      45deg, transparent, transparent 22px,
      rgba(0,107,182,0.05) 22px, rgba(0,107,182,0.05) 44px),
    linear-gradient(180deg, var(--paper-2), var(--paper));
  overflow: hidden;
}

.marquee {
  display: flex;
  gap: 0;
  white-space: nowrap;
  background: var(--knicks-blue);
  color: var(--knicks-orange);
  font-family: "VT323", monospace;
  font-size: 1.15rem;
  letter-spacing: 1px;
  border-bottom: 4px solid var(--ink);
  padding: 4px 0;
}
.marquee span {
  display: inline-block;
  animation: scroll 28s linear infinite;
  text-shadow: 1px 1px 0 #000;
}
@keyframes scroll { from { transform: translateX(0); } to { transform: translateX(-100%); } }

.hero-inner {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 26px 18px 30px;
  text-align: center;
}

.kicker {
  font-family: "VT323", monospace;
  font-size: 1.1rem;
  letter-spacing: 2px;
  color: var(--knicks-blue);
  margin: 0 0 10px;
}

h1 {
  margin: 0 auto;
  font-family: "Anton", "Space Grotesk", sans-serif;
  line-height: 1.0;
  text-transform: uppercase;
}
h1 .line-2 { margin-top: 2px; }
h1 .line-1 {
  display: block;
  font-size: clamp(2.2rem, 11vw, 5.5rem);
  color: var(--knicks-blue);
  -webkit-text-stroke: 2px var(--ink);
  letter-spacing: 1px;
}
h1 .line-2 {
  display: block;
  font-size: clamp(1.7rem, 8.5vw, 4.3rem);
  color: var(--knicks-orange);
  -webkit-text-stroke: 2px var(--ink);
  text-shadow: var(--shadow-sm);
}
h1 .line-2 em { font-style: normal; color: var(--knicks-blue); }

.subtitle {
  margin: 16px auto 14px;
  max-width: 540px;
  font-size: 1.05rem;
  line-height: 1.5;
  font-weight: 500;
}

.stamp {
  display: inline-block;
  font-family: "VT323", monospace;
  font-size: 1.15rem;
  letter-spacing: 2px;
  color: #fff;
  background: var(--knicks-orange);
  border: 3px solid var(--ink);
  box-shadow: var(--shadow-sm);
  padding: 4px 14px;
  transform: rotate(-2deg);
}

/* ---------- FILTERS ---------- */
.filters {
  position: sticky;
  top: 0;
  z-index: 30;
  background: var(--knicks-blue);
  border-bottom: 5px solid var(--ink);
  padding: 10px 14px;
  box-shadow: 0 4px 0 rgba(0,0,0,0.15);
}
.filters-row { max-width: var(--maxw); margin: 0 auto; }
.filters-row + .filters-row { margin-top: 8px; }

#q {
  width: 100%;
  font-family: "Space Grotesk", sans-serif;
  font-size: 1rem;
  padding: 11px 14px;
  border: 3px solid var(--ink);
  border-radius: 0;
  box-shadow: var(--shadow-sm);
  background: var(--paper-2);
}
#q:focus { outline: 3px solid var(--knicks-orange); outline-offset: 1px; }

.chips { display: flex; gap: 8px; flex-wrap: wrap; }
.chip {
  font-family: "VT323", monospace;
  font-size: 1.05rem;
  letter-spacing: 1px;
  padding: 5px 14px;
  border: 3px solid var(--ink);
  background: var(--paper-2);
  color: var(--ink);
  cursor: pointer;
  box-shadow: var(--shadow-sm);
  transition: transform .05s ease;
}
.chip:active { transform: translate(2px, 2px); box-shadow: none; }
.chip.is-on { background: var(--knicks-orange); color: #fff; }
.chip-filters { margin-left: auto; background: var(--knicks-blue-dk); color: #fff; }
.chip-filters.is-open { background: var(--knicks-orange); color: #fff; }

/* On phones, keep all four buttons on one row by shrinking them to fit. */
@media (max-width: 560px) {
  .chips { flex-wrap: nowrap; gap: 5px; }
  .chips .chip {
    font-size: 0.78rem; padding: 5px 6px; letter-spacing: 0;
    white-space: nowrap; border-width: 2px;
  }
}

.selects {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
}
.selects label {
  display: flex;
  flex-direction: column;
  gap: 3px;
  font-family: "VT323", monospace;
  font-size: 0.92rem;
  letter-spacing: 1px;
  color: #cfe6ff;
}
.selects select {
  font-family: "Space Grotesk", sans-serif;
  font-size: 0.95rem;
  padding: 8px 9px;
  border: 3px solid var(--ink);
  background: var(--paper-2);
  box-shadow: var(--shadow-sm);
  width: 100%;
}

.statusbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  font-family: "VT323", monospace;
  font-size: 1.1rem;
  color: #fff;
  letter-spacing: 1px;
}
.link-btn {
  background: none; border: none; color: var(--knicks-orange);
  font-family: "VT323", monospace; font-size: 1.1rem; cursor: pointer;
  text-decoration: underline; padding: 0;
}

/* ---------- BOOK (masonry) ---------- */
.book {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 22px 14px 10px;
  column-count: 1;
  column-gap: 16px;
}
@media (min-width: 560px) { .book { column-count: 2; } }
@media (min-width: 900px) { .book { column-count: 3; } }
@media (min-width: 1180px) { .book { column-count: 4; } }

.card {
  break-inside: avoid;
  margin: 0 0 16px;
  background: var(--paper-2);
  border: 3px solid var(--ink);
  box-shadow: var(--shadow);
  cursor: pointer;
  transition: transform .08s ease, box-shadow .08s ease;
}
.card:hover { transform: translate(-2px, -2px); box-shadow: 6px 6px 0 var(--ink); }
.card:active { transform: translate(2px, 2px); box-shadow: var(--shadow-sm); }

.card-media { position: relative; line-height: 0; background: var(--knicks-blue-dk); }
.card-media img { width: 100%; height: auto; display: block; }
.card-media.no-img {
  aspect-ratio: 4 / 3;
  display: flex; align-items: center; justify-content: center;
  background:
    repeating-linear-gradient(45deg, var(--knicks-blue), var(--knicks-blue) 14px,
      var(--knicks-blue-dk) 14px, var(--knicks-blue-dk) 28px);
}
.card-media.no-img .emoji { font-size: 3rem; filter: drop-shadow(2px 2px 0 #000); }

.badge {
  position: absolute; top: 8px; left: 8px;
  font-family: "VT323", monospace; font-size: 0.85rem; letter-spacing: 1px;
  color: #fff; padding: 2px 8px; border: 2px solid #fff;
  background: rgba(0,0,0,0.62);
}
.badge.x { background: #000; }
.badge.ig { background: linear-gradient(45deg,#f58529,#dd2a7b,#8134af); }
.fest-tag {
  position: absolute; top: 8px; right: 8px;
  font-size: 0.78rem; font-family: "VT323", monospace; letter-spacing: 1px;
  background: var(--knicks-orange); color:#fff; border:2px solid #fff;
  padding: 2px 7px;
}
.type-tag {
  position: absolute; bottom: 8px; left: 8px;
  font-size: 0.78rem; font-family: "VT323", monospace; letter-spacing: 1px;
  background: #8134af; color:#fff; border:2px solid #fff; padding: 2px 7px;
}
.tag.kw { background: #d8f5dd; }

.card-body { padding: 10px 12px 12px; }
.card-handle {
  font-weight: 700; font-size: 0.9rem; color: var(--knicks-blue-dk);
  display: flex; align-items: center; gap: 5px; margin-bottom: 4px;
}
.card-text {
  font-size: 0.92rem; line-height: 1.42; margin: 0 0 8px;
  display: -webkit-box; -webkit-line-clamp: 4; -webkit-box-orient: vertical; overflow: hidden;
}
.card-meta {
  display: flex; justify-content: space-between; align-items: center;
  font-family: "VT323", monospace; font-size: 0.9rem; color: #5a6672; letter-spacing: .5px;
}
.taglist { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 8px; }
.tag {
  font-family: "VT323", monospace; font-size: 0.78rem; letter-spacing: .5px;
  border: 2px solid var(--ink); padding: 1px 6px; background: var(--paper);
}
.tag.player { background: #ffe8d2; }
.tag.celeb { background: #d7ecff; }
.tag.game { background: #fff3bf; }

/* ---------- EMPTY ---------- */
.empty {
  max-width: 480px; margin: 30px auto 50px; text-align: center;
  font-family: "VT323", monospace; font-size: 1.3rem; color: var(--knicks-blue-dk);
}

/* ---------- FOOTER ---------- */
.footer {
  border-top: 6px solid var(--ink);
  background: var(--knicks-blue);
  color: #eaf4ff;
  text-align: center;
  padding: 22px 16px 40px;
  margin-top: 20px;
}
.footer .divider { color: var(--knicks-orange); font-size: 1.1rem; margin: 0 0 12px; overflow: hidden; }
.footer .fine { max-width: 620px; margin: 8px auto; font-size: 0.85rem; line-height: 1.5; color: #cfe6ff; }
.footer .fine a { color: var(--knicks-orange); text-decoration: underline; font-weight: 700; }
.footer .bestviewed { font-family: "VT323", monospace; font-size: 1.2rem; color: var(--knicks-orange); margin-top: 14px; }
#generated { font-family: "VT323", monospace; letter-spacing: 1px; font-size: 1rem; }

/* ---------- LIGHTBOX ---------- */
.lightbox {
  position: fixed; inset: 0; z-index: 100;
  background: rgba(7,12,20,0.94);
  display: flex; align-items: center; justify-content: center;
  padding: 16px;
}
.lb-stage {
  max-width: 760px; width: 100%; max-height: 92vh; overflow-y: auto;
  background: var(--paper-2); border: 4px solid var(--ink); box-shadow: 8px 8px 0 #000;
}
.lb-stage img { width: 100%; display: block; border-bottom: 4px solid var(--ink); }
.lb-body { padding: 16px 18px 20px; }
.lb-body .card-handle { font-size: 1.05rem; }
.lb-body .lb-text { font-size: 1.02rem; line-height: 1.55; white-space: pre-wrap; }
.lb-source {
  display: inline-block; margin-top: 14px;
  font-family: "VT323", monospace; font-size: 1.1rem; letter-spacing: 1px;
  background: var(--knicks-orange); color: #fff; text-decoration: none;
  padding: 7px 16px; border: 3px solid var(--ink); box-shadow: var(--shadow-sm);
}
.lb-close, .lb-nav {
  position: fixed; z-index: 101;
  background: var(--knicks-orange); color: #fff; border: 3px solid #fff;
  font-size: 1.6rem; line-height: 1; width: 48px; height: 48px; cursor: pointer;
}
.lb-close { top: 14px; right: 14px; }
.lb-nav { top: 50%; transform: translateY(-50%); width: 44px; height: 64px; font-size: 2rem; }
.lb-prev { left: 10px; }
.lb-next { right: 10px; }

@media (max-width: 560px) {
  .lb-nav { top: auto; bottom: 14px; transform: none; height: 48px; }
  .lb-prev { left: 14px; } .lb-next { right: 14px; }
}

@media (prefers-reduced-motion: reduce) {
  .marquee span { animation: none; }
  .card { transition: none; }
}
