/* ─────────────────────────────────────────────────────────────
   JUICED REPORT — stylesheet
   Aesthetic: underground tabloid / risograph newsprint
   ───────────────────────────────────────────────────────────── */

:root {
  /* Paper + ink */
  --paper:       #0a0908;
  --paper-warm:  #131210;
  --paper-soft:  #1a1815;
  --ink:         #ece6d7;
  --ink-strong:  #fff8e7;
  --ink-muted:   #7a7368;
  --ink-faint:   #3a3631;

  /* Hot inks */
  --press-red:    #ff3a20;
  --press-yellow: #ffd400;

  /* Rules + frames */
  --rule:        #2a2622;
  --frame:       #ece6d7;

  /* Typography */
  --font-display: "Anton", "Bebas Neue", "Arial Narrow", sans-serif;
  --font-body:    "Instrument Serif", "Georgia", serif;
  --font-mono:    "JetBrains Mono", "SF Mono", "Menlo", monospace;

  /* Spacing */
  --gutter: clamp(0.75rem, 2vw, 1.25rem);
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html, body {
  min-height: 100vh;
}

body {
  background-color: var(--paper);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 17px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
  position: relative;
}

/* Paper grain overlay — subtle noise via inline SVG turbulence */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 10000;
  opacity: 0.06;
  mix-blend-mode: screen;
  background-image: url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' seed='7'/%3E%3CfeColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 0.7 0'/%3E%3C/filter%3E%3Crect width='220' height='220' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* Faint vignette so the edges feel printed */
body::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 9999;
  background: radial-gradient(ellipse at center, transparent 55%, rgba(0,0,0,0.5) 100%);
}

/* ─────────────────────────────────────────────────────────────
   MASTHEAD
   ───────────────────────────────────────────────────────────── */

.masthead {
  padding: clamp(1.25rem, 3vw, 2.5rem) var(--gutter) clamp(0.5rem, 1.2vw, 1rem);
  max-width: 1600px;
  margin: 0 auto;
}

.masthead__top {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: start;
  gap: 1rem;
  margin-bottom: clamp(0.5rem, 1vw, 0.75rem);
}

.masthead__meta {
  font-family: var(--font-mono);
  font-size: clamp(0.6rem, 1vw, 0.7rem);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-muted);
  line-height: 1.6;
  display: flex;
  flex-direction: column;
}

.masthead__meta--right {
  text-align: right;
}

.masthead__meta-row {
  display: flex;
  gap: 0.65rem;
  align-items: baseline;
}

.masthead__meta--right .masthead__meta-row {
  justify-content: flex-end;
}

.masthead__meta-dot {
  color: var(--press-red);
  font-size: 0.85em;
}

.masthead__title-wrap {
  text-align: center;
  position: relative;
}

.masthead__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(3.5rem, 14vw, 10rem);
  line-height: 0.82;
  letter-spacing: -0.01em;
  color: var(--ink-strong);
  text-transform: uppercase;
  text-shadow: 3px 3px 0 var(--press-red);
}

.masthead__title span {
  display: block;
}

.masthead__dek {
  font-family: var(--font-body);
  font-style: italic;
  color: var(--ink-muted);
  font-size: clamp(0.9rem, 1.4vw, 1.2rem);
  margin-top: clamp(0.5rem, 1vw, 0.85rem);
  letter-spacing: 0.005em;
}

.masthead__dek em {
  color: var(--press-red);
  font-style: italic;
}

/* Classic newspaper double-rule divider */
.rule {
  border: 0;
  margin: 0 var(--gutter);
  max-width: 1600px;
  margin-left: auto;
  margin-right: auto;
}

.rule--double {
  border-top: 2px solid var(--ink);
  border-bottom: 1px solid var(--ink);
  height: 6px;
}

/* ─────────────────────────────────────────────────────────────
   MAIN
   ───────────────────────────────────────────────────────────── */

main {
  max-width: 1600px;
  margin: 0 auto;
  padding: clamp(1rem, 2vw, 1.75rem) var(--gutter) clamp(3rem, 6vw, 5rem);
}

/* Section marker — "latest dispatches" type label above grid */
.section-label {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-muted);
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 1.25rem;
}

.section-label::before,
.section-label::after {
  content: "";
  flex: 1;
  height: 1px;
  background: var(--rule);
}

/* ─────────────────────────────────────────────────────────────
   GRID
   ───────────────────────────────────────────────────────────── */

.grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(clamp(220px, 28vw, 300px), 1fr));
  gap: clamp(1rem, 2vw, 1.5rem);
  align-items: start;
}

/* ─────────────────────────────────────────────────────────────
   CARD
   ───────────────────────────────────────────────────────────── */

.card {
  --card-rotate: 0deg;
  --card-shadow-color: var(--press-red);
  --card-shadow-offset: 6px;

  display: block;
  position: relative;
  aspect-ratio: 4 / 3;
  background: var(--paper-warm);
  border: 2px solid var(--frame);
  box-shadow:
    var(--card-shadow-offset) var(--card-shadow-offset) 0 var(--card-shadow-color),
    0 0 0 1px rgba(0, 0, 0, 0.2);
  text-decoration: none;
  color: inherit;
  overflow: hidden;
  transform: rotate(var(--card-rotate));
  transition:
    transform 180ms cubic-bezier(0.2, 0.8, 0.2, 1.2),
    box-shadow 180ms ease,
    border-color 180ms ease;
  will-change: transform;
}

/* Hand-pinned feel — tiny deterministic rotations per position */
.card:nth-child(3n+1) { --card-rotate: -0.45deg; }
.card:nth-child(5n+2) { --card-rotate:  0.4deg; }
.card:nth-child(7n+3) { --card-rotate: -0.25deg; }
.card:nth-child(4n+4) { --card-rotate:  0.3deg; }

/* Placeholder cards skip the rotation: rotating display-font text by a
   fractional degree puts each glyph at sub-pixel coordinates, which
   Firefox rounds inconsistently across characters and produces visible
   baseline drift. Image cards aren't affected because the rotation
   applies to a single bitmap, not to per-character text rendering. */
.card:has(.card__placeholder) { --card-rotate: 0deg; }

/* Accent color cycles by position — feels like a printer ran out of ink */
.card:nth-child(4n+2) { --card-shadow-color: var(--press-yellow); }
.card:nth-child(5n+3) { --card-shadow-color: var(--ink); }
.card:nth-child(7n+5) { --card-shadow-color: var(--press-red); }

.card:hover,
.card:focus-visible {
  --card-shadow-offset: 10px;
  transform: rotate(var(--card-rotate)) translate(-4px, -4px);
  outline: none;
  z-index: 2;
}

.card:active {
  --card-shadow-offset: 3px;
  transform: rotate(var(--card-rotate)) translate(-1px, -1px);
  transition-duration: 60ms;
}

/* ── Media wrap ──────────────────────────────────────────────── */

.card__image-wrap {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.card__image-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: contrast(1.05) saturate(1.02);
}

/* ── Category tag (image-card corner badge OR placeholder filed-under) ─ */

.card__tag {
  font-family: var(--font-mono);
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  background: var(--press-yellow);
  color: var(--paper);
  padding: 4px 8px;
  border: 1.5px solid var(--paper);
  display: inline-flex;
  align-items: center;
  gap: 5px;
  line-height: 1;
  box-shadow: 2px 2px 0 var(--paper);
  pointer-events: none;
  transform: rotate(-3deg);
  align-self: center;
}

/* On image cards the tag floats over the top-left of the photo.
   Placeholder cards do the same so all card types share a tag corner. */
.card__image-wrap .card__tag,
.card__placeholder .card__tag {
  position: absolute;
  top: 10px;
  left: 10px;
}

/* Color variants ----------------------------------------------------- */

.card__tag--video,
.card__tag--footage,
.card__tag--wire-photo {
  background: var(--press-yellow);
  color: var(--paper);
}

.card__tag--forum,
.card__tag--breaking-news,
.card__tag--dispatch {
  background: var(--press-red);
  color: var(--ink-strong);
  border-color: var(--ink-strong);
  box-shadow: 2px 2px 0 var(--ink-strong);
}

.card__tag--the-internet {
  background: var(--ink);
  color: var(--paper);
}

/* Video gets the play arrow; the rest are text-only. */
.card__tag--video::before {
  content: "▶";
  font-size: 0.85em;
}

.card:hover .card__tag {
  transform: rotate(-3deg) scale(1.05);
  transition: transform 180ms ease;
}

/* ── Placeholder plate (for generic links without OG image) ──── */

.card__placeholder {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  padding: 1.25rem;
  background:
    repeating-linear-gradient(
      45deg,
      var(--paper-warm) 0 10px,
      var(--paper-soft) 10px 20px
    );
  text-align: center;
  gap: 0.75rem;
}

.card__placeholder::before {
  /* Literal caps + no text-transform avoids the Firefox letter-spacing
     rendering quirk we saw earlier on the headline. */
  content: "FILED UNDER";
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 0.25em;
  color: var(--press-red);
  border-bottom: 1px solid var(--press-red);
  padding-bottom: 0.35rem;
}

.card__placeholder::after {
  content: "—   —";
  font-family: var(--font-mono);
  font-size: 0.55rem;
  letter-spacing: 0.35em;
  color: var(--ink-muted);
  margin-top: 0.25rem;
}

/* Default kicker = the big domain line on a no-headline placeholder.
   In story mode (kicker + headline), it shrinks into a small label
   above the headline.
   Note: text is upper-cased in the model (headline_kicker) and view,
   not via `text-transform: uppercase` — Firefox falls back to a
   different font when uppercasing display fonts, even though Anton
   has the glyphs. Pre-uppercased source avoids the bug. */
.card__kicker {
  font-family: var(--font-display);
  font-size: clamp(1.3rem, 3.5vw, 2rem);
  color: var(--ink-strong);
  word-break: break-all;
  line-height: 1;
  letter-spacing: -0.01em;
}

.card__placeholder--story .card__kicker {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  color: var(--press-red);
  word-break: normal;
}

.card__headline {
  font-family: var(--font-display);
  font-size: clamp(1.1rem, 2.6vw, 1.8rem);
  color: var(--ink-strong);
  line-height: 1;
  letter-spacing: -0.005em;
  word-break: break-word;
  /* Cap at 4 lines so a long news slug can't blow out the card. */
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Headline overlaid on a BREAKING NEWS image card. White display type
   sitting on a semi-transparent dark scrim so it stays legible over
   any photo. */
.card__overlay-headline {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: calc(100% - 1.25rem);
  padding: 0.6rem 0.75rem;
  background: rgba(0, 0, 0, 0.62);
  font-family: var(--font-display);
  font-size: clamp(1.05rem, 2.4vw, 1.6rem);
  color: var(--ink-strong);
  text-align: center;
  line-height: 1.1;
  word-break: break-word;
  pointer-events: none;
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* ─────────────────────────────────────────────────────────────
   EMPTY / LOADING STATES
   ───────────────────────────────────────────────────────────── */

.empty-state {
  padding: clamp(3rem, 8vw, 6rem) 1rem;
  text-align: center;
  border: 2px solid var(--frame);
  box-shadow: 8px 8px 0 var(--press-red);
  background: var(--paper-warm);
  max-width: 40rem;
  margin: 3rem auto;
  position: relative;
}

.empty-state__eyebrow {
  font-family: var(--font-mono);
  font-size: 0.75rem;
  letter-spacing: 0.3em;
  color: var(--press-red);
  text-transform: uppercase;
  margin-bottom: 1rem;
}

.empty-state__eyebrow::before,
.empty-state__eyebrow::after {
  content: " ※ ";
  color: var(--press-yellow);
}

.empty-state__headline {
  font-family: var(--font-display);
  font-size: clamp(2rem, 6vw, 3.5rem);
  text-transform: uppercase;
  color: var(--ink-strong);
  line-height: 0.9;
  margin-bottom: 1rem;
  text-shadow: 2px 2px 0 var(--press-red);
}

.empty-state__body {
  font-family: var(--font-body);
  font-style: italic;
  color: var(--ink-muted);
  font-size: 1.1rem;
  max-width: 30rem;
  margin: 0 auto;
}

.loading {
  text-align: center;
  padding: 2.5rem 1rem;
  color: var(--ink-muted);
  font-family: var(--font-mono);
  font-size: 0.75rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
}

.loading::before,
.loading::after {
  content: "";
  display: inline-block;
  width: 1.5rem;
  height: 1px;
  background: var(--press-red);
  animation: tickle 1s ease-in-out infinite alternate;
}

.loading::after {
  animation-delay: 0.5s;
}

@keyframes tickle {
  from { transform: translateX(-4px); opacity: 0.4; }
  to   { transform: translateX(4px);  opacity: 1;   }
}

.hidden { display: none; }

/* ─────────────────────────────────────────────────────────────
   COLOPHON
   ───────────────────────────────────────────────────────────── */

.colophon {
  max-width: 1600px;
  margin: 0 auto;
  padding: 1.5rem var(--gutter) 2.5rem;
  font-family: var(--font-mono);
  font-size: 0.65rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-muted);
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 1rem;
  border-top: 1px solid var(--rule);
}

.colophon__sep {
  color: var(--press-red);
  font-family: var(--font-body);
  font-size: 0.9em;
}

/* ─────────────────────────────────────────────────────────────
   RESPONSIVE — mobile
   ───────────────────────────────────────────────────────────── */

@media (max-width: 760px) {
  .masthead {
    padding-top: 1rem;
  }

  .masthead__top {
    grid-template-columns: 1fr;
    gap: 0.25rem;
    text-align: center;
    margin-bottom: 0.75rem;
  }

  .masthead__meta {
    flex-direction: row;
    justify-content: center;
    gap: 0.75rem;
    text-align: center;
    order: 1;
  }

  .masthead__meta-row {
    gap: 0.5rem;
  }

  .masthead__meta--right {
    text-align: center;
    order: 3;
  }

  .masthead__meta--right .masthead__meta-row {
    justify-content: center;
  }

  .masthead__title-wrap {
    order: 2;
    padding: 0.5rem 0;
  }

  .masthead__title {
    text-shadow: 2px 2px 0 var(--press-red);
  }
}

@media (max-width: 480px) {
  .grid {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }

  .card {
    --card-shadow-offset: 5px;
  }

  .card:hover,
  .card:focus-visible {
    --card-shadow-offset: 7px;
  }

  .masthead__meta {
    font-size: 0.55rem;
  }

  .colophon {
    font-size: 0.55rem;
    gap: 0.5rem;
  }
}

/* ─────────────────────────────────────────────────────────────
   MOTION
   ───────────────────────────────────────────────────────────── */

@media (prefers-reduced-motion: reduce) {
  .card { transition: none; }
  .loading::before, .loading::after { animation: none; }
}
