/* =====================================================
   TV Commercial section
===================================================== */
.tv-section {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 40px;
  margin: 160px 0 160px;
  align-items: center;
}

.tv-left {
  position: relative;
  display: flex; flex-direction: column; align-items: center;
}

.tv-screen {
  width: 100%;
  aspect-ratio: 4 / 3;
  background:
    /* RGB color bars peeking through */
    linear-gradient(180deg,
      rgba(212,245,55,.08) 0 14%,
      rgba(255,90,31,.07) 14% 28%,
      rgba(176,21,29,.08) 28% 42%,
      rgba(241,233,210,.05) 42% 58%,
      rgba(107,191,89,.06) 58% 72%,
      rgba(0,150,255,.06) 72% 86%,
      rgba(212,245,55,.07) 86% 100%
    ),
    radial-gradient(ellipse at center, #1a1a14 0%, #0A0A07 60%, #000 100%);
  border: 6px solid var(--ink);
  border-radius: 22px;
  box-shadow:
    var(--shadow-sticker-lg),
    inset 0 0 80px rgba(0,0,0,.7),
    inset 0 0 0 6px var(--smoke-500);
  position: relative;
  overflow: hidden;
  transform: rotate(-1.5deg);
  cursor: pointer;
}
.tv-screen::before {
  content: ""; position: absolute; inset: 14px;
  border: 2px solid var(--smoke-500);
  border-radius: 14px; pointer-events: none;
  z-index: 4;
}
/* VHS glitch — horizontal tearing band that drifts */
.tv-screen::after {
  content: ""; position: absolute; inset: 0;
  background:
    /* horizontal tear bar */
    linear-gradient(180deg, transparent 0 38%,
      rgba(241,233,210,.18) 38% 39%,
      rgba(212,245,55,.22) 39% 41%,
      rgba(255,90,31,.18) 41% 42%,
      transparent 42% 64%,
      rgba(176,21,29,.16) 64% 65%,
      rgba(241,233,210,.14) 65% 66%,
      transparent 66% 100%),
    /* fine horizontal interference lines */
    repeating-linear-gradient(180deg,
      transparent 0 6px,
      rgba(241,233,210,.04) 6px 7px,
      transparent 7px 14px);
  mix-blend-mode: screen;
  pointer-events: none;
  z-index: 1;
  animation: tvGlitch 1.6s steps(1) infinite;
}
@keyframes tvGlitch {
  0%   { transform: translate3d(0, 0, 0); opacity: .85; }
  6%   { transform: translate3d(-3px, -42px, 0); opacity: 1; }
  8%   { transform: translate3d(4px, -42px, 0); opacity: .65; }
  10%  { transform: translate3d(0, 18px, 0); opacity: .9; }
  18%  { transform: translate3d(0, 18px, 0); opacity: .9; }
  20%  { transform: translate3d(-2px, 70px, 0); opacity: 1; }
  22%  { transform: translate3d(3px, 70px, 0); opacity: .55; }
  24%  { transform: translate3d(0, -90px, 0); opacity: .9; }
  40%  { transform: translate3d(0, -90px, 0); opacity: .9; }
  42%  { transform: translate3d(-4px, 30px, 0); opacity: 1; }
  44%  { transform: translate3d(2px, 30px, 0); opacity: .6; }
  46%  { transform: translate3d(0, 110px, 0); opacity: .85; }
  68%  { transform: translate3d(0, 110px, 0); opacity: .85; }
  70%  { transform: translate3d(-5px, -20px, 0); opacity: 1; }
  72%  { transform: translate3d(3px, -20px, 0); opacity: .55; }
  74%  { transform: translate3d(0, 50px, 0); opacity: .9; }
  100% { transform: translate3d(0, 50px, 0); opacity: .85; }
}
.tv-noise {
  position: absolute; inset: 0;
  background-image:
    radial-gradient(rgba(241,233,210,.04) 1px, transparent 1px),
    radial-gradient(rgba(212,245,55,.06) 1px, transparent 1px);
  background-size: 3px 3px, 5px 5px;
  background-position: 0 0, 1px 2px;
  mix-blend-mode: screen;
  animation: tvNoise .12s steps(6) infinite;
  z-index: 2;
  pointer-events: none;
}
@keyframes tvNoise {
  0%   { transform: translate(0,0); }
  25%  { transform: translate(-2px,1px); }
  50%  { transform: translate(1px,-2px); }
  75%  { transform: translate(-1px,2px); }
  100% { transform: translate(2px,1px); }
}
.tv-scanlines {
  position: absolute; inset: 0;
  background: repeating-linear-gradient(
    to bottom,
    transparent 0,
    transparent 3px,
    rgba(0,0,0,.32) 3px,
    rgba(0,0,0,.32) 4px
  );
  pointer-events: none;
  z-index: 3;
}
.tv-play {
  position: absolute; left: 50%; top: 50%;
  transform: translate(-50%,-50%);
  width: 96px; height: 96px; border-radius: 50%;
  background: var(--acid); color: var(--ink);
  border: 4px solid var(--ink);
  box-shadow: var(--shadow-sticker);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; z-index: 3;
  transition: transform var(--dur-2) var(--ease-snap);
}
.tv-play:hover { transform: translate(-50%,-50%) scale(1.08) rotate(-6deg); }
.tv-play svg { margin-left: 4px; }

.tv-chrome {
  position: absolute; top: 24px; left: 24px; right: 24px;
  display: flex; justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 12px; letter-spacing: .14em;
  color: var(--acid);
  z-index: 2;
  text-shadow: 0 0 8px rgba(212,245,55,.6);
}
.tv-rec {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--ember);
  text-shadow: 0 0 8px rgba(255,90,31,.6);
  animation: blink 1.2s steps(2) infinite;
}
@keyframes blink {
  0%, 49% { opacity: 1; }
  50%, 100% { opacity: .25; }
}

.tv-caption {
  position: absolute;
  bottom: 56px; left: 50%; transform: translateX(-50%);
  background: var(--ink); color: var(--acid);
  font-family: var(--font-display);
  font-size: clamp(11px, 1.2vw, 16px);
  letter-spacing: .04em;
  text-transform: uppercase;
  padding: 10px 14px;
  text-align: center;
  max-width: 78%;
  line-height: 1.2;
  border: 2px solid var(--acid);
  z-index: 2;
}

.tv-bottom {
  position: absolute; bottom: 24px; left: 24px; right: 24px;
  display: flex; justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 11px; letter-spacing: .12em;
  color: var(--smoke-200);
  z-index: 2;
}

.tv-tape {
  margin-top: -18px;
  background: var(--bone);
  color: var(--ink);
  border: 2px solid var(--ink);
  font-family: var(--font-display);
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: .14em;
  padding: 8px 22px;
  transform: rotate(2deg);
  box-shadow: var(--shadow-sticker-sm);
  position: relative;
  z-index: 4;
}

.tv-right {
  display: flex; flex-direction: column;
  padding: 0 8px;
}
.tv-headline {
  font-family: var(--font-display);
  font-size: clamp(48px, 5.6vw, 96px);
  line-height: .9;
  letter-spacing: -.02em;
  text-transform: uppercase;
  color: var(--bone);
  margin: 18px 0 18px;
  text-shadow:
    4px 4px 0 var(--ember),
    8px 8px 0 var(--ink);
}
.tv-blurb {
  font-family: var(--font-ui);
  font-size: 17px; line-height: 1.6;
  color: var(--fg-2);
  max-width: 520px;
  text-wrap: pretty;
}
.tv-bullets {
  list-style: none; padding: 0; margin: 18px 0 0;
  display: flex; flex-direction: column; gap: 8px;
}
.tv-bullets li {
  font-family: var(--font-ui);
  font-weight: 600;
  font-size: 15px;
  color: var(--bone);
  display: flex; align-items: baseline; gap: 10px;
}
.tv-bullets li span {
  color: var(--acid);
  font-family: var(--font-display);
  font-size: 18px;
}

@media (max-width: 900px) {
  .tv-section { grid-template-columns: 1fr; gap: 32px; }
}

/* =====================================================
   Blog section
===================================================== */
.blog-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr;
  gap: 22px;
  margin: 0 0 96px;
}

.blog-card {
  background: var(--bone);
  color: var(--ink);
  border: 2px solid var(--ink);
  box-shadow: var(--shadow-sticker);
  display: flex; flex-direction: column;
  position: relative;
  transition: transform var(--dur-2) var(--ease-snap),
              box-shadow var(--dur-2) var(--ease-snap);
  cursor: pointer;
  overflow: hidden;
}
.blog-card:nth-child(1) { transform: rotate(-.6deg); }
.blog-card:nth-child(2) { transform: rotate(.8deg); }
.blog-card:nth-child(3) { transform: rotate(-.4deg); }
.blog-card:hover {
  transform: rotate(0deg) translateY(-4px);
  box-shadow: var(--shadow-sticker-lg);
}

.blog-thumb {
  position: relative;
  aspect-ratio: 4 / 3;
  border-bottom: 2px solid var(--ink);
  overflow: hidden;
  display: flex; align-items: center; justify-content: center;
}
.blog-feature .blog-thumb { aspect-ratio: 16 / 10; }

.blog-thumb-1 {
  background:
    repeating-linear-gradient(45deg, var(--acid) 0 24px, var(--acid-deep) 24px 48px);
}
.blog-thumb-2 {
  background:
    radial-gradient(circle at 30% 30%, var(--ember) 0 14%, transparent 14%),
    radial-gradient(circle at 70% 70%, var(--blood) 0 18%, transparent 18%),
    var(--ink);
}
.blog-thumb-3 {
  background:
    repeating-linear-gradient(0deg, var(--ink) 0 6px, transparent 6px 12px),
    var(--bone-warm);
}

.blog-date {
  position: absolute; top: 16px; left: 16px;
  background: var(--ink); color: var(--bone);
  font-family: var(--font-mono);
  font-size: 11px; letter-spacing: .12em;
  padding: 5px 9px;
  z-index: 2;
}
.blog-cat {
  position: absolute; top: 16px; right: 16px;
  background: var(--acid); color: var(--ink);
  border: 2px solid var(--ink);
  font-family: var(--font-display);
  font-size: 11px; letter-spacing: .1em;
  text-transform: uppercase;
  padding: 5px 10px;
  transform: rotate(4deg);
  box-shadow: var(--shadow-sticker-sm);
  z-index: 2;
}

.blog-graphic {
  display: flex; align-items: center; gap: 16px;
  font-family: var(--font-display);
  text-shadow: 4px 4px 0 var(--ink);
  z-index: 1;
}
.blog-num {
  font-size: clamp(48px, 6vw, 88px);
  color: var(--bone);
  -webkit-text-stroke: 2px var(--ink);
  letter-spacing: -.03em;
}
.blog-num-acid { color: var(--acid); }
.blog-arrow {
  font-size: 56px;
  color: var(--ink);
  transform: rotate(-4deg);
}

.blog-quote {
  font-family: var(--font-display);
  font-size: clamp(28px, 3.2vw, 44px);
  line-height: .95;
  color: var(--bone);
  text-transform: uppercase;
  text-align: center;
  text-shadow: 3px 3px 0 var(--ink);
  letter-spacing: -.02em;
  padding: 0 14px;
}

.blog-stack {
  display: flex; flex-direction: column; gap: 6px;
  font-family: var(--font-display);
  font-size: clamp(28px, 3.4vw, 48px);
  line-height: .95;
  color: var(--ink);
  text-transform: uppercase;
  align-items: center;
}
.blog-stack span:nth-child(2) { color: var(--ember); transform: rotate(-2deg); }
.blog-stack span:nth-child(3) { transform: rotate(1deg); }

.blog-body {
  padding: 22px 22px 26px;
  display: flex; flex-direction: column; gap: 8px;
  flex: 1;
}
.blog-readtime {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .14em;
  color: var(--smoke-400);
  text-transform: uppercase;
}
.blog-title {
  font-family: var(--font-display);
  font-size: clamp(20px, 1.6vw, 28px);
  line-height: 1.05;
  text-transform: uppercase;
  color: var(--ink);
  margin: 0;
  letter-spacing: -.01em;
}
.blog-feature .blog-title { font-size: clamp(28px, 2.4vw, 40px); }
.blog-body p {
  font-family: var(--font-ui);
  font-size: 14px;
  line-height: 1.55;
  color: var(--smoke-500);
  margin: 4px 0 0;
  text-wrap: pretty;
}
.blog-feature .blog-body p { font-size: 16px; }
.blog-author {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--smoke-400);
  margin-top: 10px;
}

@media (max-width: 1000px) {
  .blog-grid { grid-template-columns: 1fr 1fr; }
  .blog-feature { grid-column: 1 / -1; }
}
@media (max-width: 640px) {
  .blog-grid { grid-template-columns: 1fr; }
}

/* =====================================================
   Newsletter section
===================================================== */
.newsletter {
  position: relative;
  background: var(--acid);
  color: var(--ink);
  border: 2px solid var(--ink);
  box-shadow: var(--shadow-sticker-lg);
  margin: 0 0 96px;
  overflow: hidden;
  transform: rotate(.6deg);
}
.news-stripes {
  position: absolute; inset: 0;
  background:
    repeating-linear-gradient(-12deg,
      transparent 0 64px,
      rgba(10,10,7,.06) 64px 128px);
  pointer-events: none;
}
.news-inner {
  position: relative;
  padding: 72px 56px 64px;
  text-align: center;
  z-index: 2;
}
.news-stamp {
  display: inline-block;
  background: var(--blood);
  color: var(--bone);
  border: 2px solid var(--ink);
  font-family: var(--font-display);
  font-size: 14px;
  letter-spacing: .18em;
  padding: 8px 18px;
  transform: rotate(-3deg);
  box-shadow: var(--shadow-sticker-sm);
  margin-bottom: 18px;
}
.news-headline {
  font-family: var(--font-display);
  font-size: clamp(64px, 8vw, 144px);
  line-height: .85;
  letter-spacing: -.02em;
  text-transform: uppercase;
  color: var(--ink);
  margin: 0 0 18px;
  text-shadow: 6px 6px 0 var(--bone);
}
.news-sub {
  font-family: var(--font-ui);
  font-weight: 600;
  font-size: 17px;
  line-height: 1.55;
  color: var(--ink);
  max-width: 560px;
  margin: 0 auto 28px;
}
.news-form {
  display: flex; gap: 10px; justify-content: center; flex-wrap: wrap;
  max-width: 560px; margin: 0 auto;
}
.news-form input {
  flex: 1; min-width: 240px;
  background: var(--bone);
  color: var(--ink);
  border: 2px solid var(--ink);
  box-shadow: var(--shadow-sticker-sm);
  padding: 14px 18px;
  font-family: var(--font-mono);
  font-size: 15px;
  outline: none;
}
.news-form input::placeholder {
  color: var(--smoke-400);
  text-transform: lowercase;
}
.news-form input:focus {
  background: var(--bone);
  box-shadow: var(--shadow-sticker), 0 0 0 3px var(--ember);
  transform: translate(-1px,-1px);
}

.news-meta {
  display: flex; gap: 22px; justify-content: center; flex-wrap: wrap;
  margin-top: 22px;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: .14em;
  color: var(--ink);
  text-transform: uppercase;
  font-weight: 700;
}

.news-skull-l, .news-skull-r {
  position: absolute;
  height: 220px;
  opacity: .85;
  filter: drop-shadow(6px 6px 0 var(--ink));
  pointer-events: none;
  z-index: 1;
}
.news-skull-l {
  left: -60px; bottom: -50px;
  transform: rotate(-18deg);
}
.news-skull-r {
  right: -60px; top: -50px;
  transform: rotate(22deg) scaleX(-1);
}

@media (max-width: 720px) {
  .news-inner { padding: 56px 28px 48px; }
  .news-skull-l, .news-skull-r { height: 140px; opacity: .5; }
}


/* =====================================================
   Comic Strip section — replaces former mini-banner
===================================================== */
.comic-strip-section {
  display: grid;
  grid-template-columns: .85fr 1.4fr;
  gap: 48px;
  align-items: center;
  margin: 128px 0 !important;
}
.comic-strip-head { padding-right: 8px; }
.comic-strip-head .sticker-tag {
  display: inline-block;
  transform: rotate(-3deg);
  margin-bottom: 16px;
  font-family: var(--font-ui);
  font-weight: 700;
  font-size: 12px;
  letter-spacing: .14em;
  padding: 6px 12px;
  border: 2px solid var(--ink);
  box-shadow: var(--shadow-sticker-sm);
}
.comic-strip-title {
  font-family: var(--font-display);
  font-size: clamp(48px, 5vw, 88px);
  line-height: .9;
  letter-spacing: -.02em;
  text-transform: uppercase;
  color: var(--bone);
  margin: 8px 0 18px;
  text-shadow:
    4px 4px 0 var(--blood),
    8px 8px 0 var(--ink);
}
.comic-strip-blurb {
  font-family: var(--font-ui);
  font-size: 17px;
  line-height: 1.6;
  color: var(--fg-2);
  max-width: 420px;
  text-wrap: pretty;
}
.comic-strip-blurb em {
  font-style: normal;
  background: var(--acid);
  color: var(--ink);
  padding: 1px 6px;
  font-weight: 700;
}
.comic-strip-meta {
  margin-top: 22px;
  display: grid;
  grid-template-columns: repeat(2, max-content);
  gap: 8px 28px;
  font-family: var(--font-mono);
  font-size: 13px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--bone);
}
.comic-strip-meta strong {
  color: var(--acid);
  font-family: var(--font-display);
  font-weight: 400;
  margin-right: 6px;
}
.comic-strip-frame {
  position: relative;
  background: var(--ink);
  border: 4px solid var(--ink);
  box-shadow:
    10px 10px 0 var(--acid),
    14px 14px 0 var(--ink);
  transform: rotate(-1.2deg);
  padding: 14px;
  background-image: radial-gradient(rgba(241,233,210,.04) 1px, transparent 1px);
  background-size: 4px 4px;
}
.comic-strip-frame img {
  display: block;
  width: 100%;
  height: auto;
  border: 2px solid var(--smoke-500);
  filter: contrast(1.04) saturate(1.05);
}
.comic-strip-stamp {
  position: absolute;
  top: -18px; left: 32px;
  background: var(--acid);
  color: var(--ink);
  border: 2px solid var(--ink);
  font-family: var(--font-display);
  font-size: 12px;
  letter-spacing: .12em;
  padding: 6px 14px;
  transform: rotate(-2deg);
  box-shadow: var(--shadow-sticker-sm);
  z-index: 3;
  white-space: nowrap;
}
.comic-strip-corner {
  position: absolute;
  bottom: -16px; right: 28px;
  background: var(--blood);
  color: var(--bone);
  border: 2px solid var(--ink);
  font-family: var(--font-display);
  font-size: 11px;
  letter-spacing: .14em;
  padding: 5px 10px;
  transform: rotate(3deg);
  box-shadow: var(--shadow-sticker-sm);
  z-index: 3;
}
.comic-strip-tape {
  position: absolute;
  width: 90px; height: 22px;
  background: rgba(241,233,210,.55);
  border: 1px solid rgba(10,10,7,.35);
  pointer-events: none;
  z-index: 2;
}
.comic-strip-tape-tl { top: -8px; left: 50%; transform: translateX(-50%) rotate(-4deg); }
.comic-strip-tape-br { bottom: -10px; left: 18%; transform: rotate(6deg); }
@media (max-width: 960px) {
  .comic-strip-section { grid-template-columns: 1fr; gap: 32px; }
  .comic-strip-head { padding-right: 0; }
}


/* Hero comic tile — replaces skull tile */
.hp-comic {
  padding: 0 !important;
  background: var(--ink) !important;   /* matches the image's dark studio bg so any letterbox blends */
}
.hp-comic .hp-comic-img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: contain;
  object-position: 50% 50%;
  z-index: 1;
  filter: contrast(1.04) saturate(1.05);
}
.hp-comic::before { display: none; }   /* drop the dot pattern \u2014 image already has texture */


/* ===== Blog post page ===== */
.blog-post {
  max-width: 880px;
  margin: 32px auto 80px;
  padding: 0 24px;
  color: var(--bone);
}

.blog-back {
  background: transparent;
  border: 2px solid var(--bone);
  color: var(--bone);
  font-family: var(--font-display);
  font-size: 14px;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 8px 16px;
  border-radius: 999px;
  cursor: pointer;
  margin-bottom: 32px;
  transition: all .15s ease;
}
.blog-back:hover {
  background: var(--bone);
  color: var(--ink);
  transform: translateX(-3px);
}

.blog-post-head {
  margin-bottom: 32px;
  padding-bottom: 32px;
  border-bottom: 2px dashed rgba(245, 240, 230, .25);
}
.blog-post-meta {
  display: flex; align-items: center; gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 24px;
}
.blog-post-cat {
  font-family: var(--font-display);
  font-size: 12px;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 6px 12px;
  border-radius: 999px;
  background: var(--acid);
  color: var(--ink);
}
.blog-post-cat-blood { background: var(--blood); color: var(--bone); }
.blog-post-cat-ink { background: var(--ink); color: var(--acid); border: 1px solid var(--acid); }
.blog-post-date, .blog-post-read {
  font-family: var(--font-display);
  font-size: 12px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(245, 240, 230, .7);
}
.blog-post-read::before { content: '· '; }

.blog-post-title {
  font-family: var(--font-display);
  font-size: clamp(36px, 5.5vw, 68px);
  line-height: .95;
  text-transform: uppercase;
  margin: 0 0 20px;
  color: var(--bone);
  text-wrap: balance;
}

.blog-post-deck {
  font-family: var(--font-body);
  font-size: 20px;
  line-height: 1.45;
  color: rgba(245, 240, 230, .85);
  margin: 0 0 28px;
  text-wrap: pretty;
}

.blog-post-byline {
  display: flex;
  align-items: center;
  gap: 14px;
}
.blog-post-avatar {
  width: 48px; height: 48px;
  border-radius: 50%;
  background: var(--acid);
  color: var(--ink);
  font-family: var(--font-display);
  font-size: 16px;
  display: flex; align-items: center; justify-content: center;
  letter-spacing: .04em;
}
.blog-post-author {
  font-family: var(--font-display);
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--bone);
}
.blog-post-author-role {
  font-family: var(--font-body);
  font-size: 13px;
  color: rgba(245, 240, 230, .6);
}

.blog-post-hero {
  border-radius: 16px;
  aspect-ratio: 16 / 9;
  margin: 0 0 40px;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
  position: relative;
}
.blog-graphic-lg { font-size: clamp(48px, 8vw, 120px) !important; gap: 28px !important; }
.blog-quote-lg { font-size: clamp(40px, 5vw, 72px) !important; }
.blog-stack-lg span { font-size: clamp(48px, 6vw, 88px) !important; }

.blog-post-body {
  font-family: var(--font-body);
  font-size: 18px;
  line-height: 1.65;
  color: rgba(245, 240, 230, .92);
}
.bp-p { margin: 0 0 20px; text-wrap: pretty; }
.bp-h2 {
  font-family: var(--font-display);
  font-size: clamp(24px, 3vw, 32px);
  text-transform: uppercase;
  color: var(--acid);
  letter-spacing: .02em;
  margin: 40px 0 16px;
  line-height: 1.05;
}
.bp-pull {
  margin: 32px 0;
  padding: 24px 28px;
  border-left: 4px solid var(--acid);
  font-family: var(--font-display);
  font-size: clamp(20px, 2.4vw, 28px);
  line-height: 1.25;
  color: var(--bone);
  text-transform: none;
  background: rgba(245, 240, 230, .04);
  border-radius: 0 8px 8px 0;
}
.bp-list {
  margin: 0 0 24px;
  padding: 0;
  list-style: none;
}
.bp-list li {
  position: relative;
  padding: 10px 0 10px 28px;
  border-bottom: 1px dashed rgba(245, 240, 230, .15);
}
.bp-list li::before {
  content: '★';
  position: absolute; left: 0; top: 10px;
  color: var(--acid);
}

.blog-post-footer {
  margin-top: 48px;
  padding-top: 32px;
  border-top: 2px dashed rgba(245, 240, 230, .25);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
}
.blog-post-tags { display: flex; gap: 8px; flex-wrap: wrap; }
.bp-tag {
  font-family: var(--font-mono, monospace);
  font-size: 12px;
  padding: 6px 10px;
  border: 1px solid rgba(245, 240, 230, .3);
  border-radius: 4px;
  color: rgba(245, 240, 230, .75);
}

/* Related */
.blog-post-related {
  margin-top: 80px;
  padding-top: 48px;
  border-top: 2px solid var(--bone);
}
.blog-related-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}
@media (max-width: 720px) {
  .blog-related-grid { grid-template-columns: 1fr; }
}

/* Clickable cursor on cards */
.blog-card-clickable { cursor: pointer; }

/* ---- Social proof toast ---- */
.social-proof-toast {
  position: fixed;
  left: 18px;
  bottom: 18px;
  z-index: 800;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  background: var(--ink-soft, #141410);
  color: var(--bone, #F1E9D2);
  border: 2px solid var(--ink-2, #1E1E18);
  border-radius: 6px;
  box-shadow: 4px 4px 0 rgba(0,0,0,0.6);
  font-family: var(--font-ui, 'Helvetica Neue', Helvetica, Arial, sans-serif);
  max-width: 320px;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity .35s ease, transform .35s ease;
  pointer-events: none;
}
.social-proof-toast.is-visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.social-proof-toast .sp-icon {
  flex: 0 0 auto;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--acid, #D4F537);
  color: var(--ink, #0A0A07);
  border-radius: 4px;
}
.social-proof-toast .sp-icon svg {
  width: 18px;
  height: 18px;
  stroke-width: 2.4;
}
.social-proof-toast .sp-body {
  flex: 1;
  min-width: 0;
  line-height: 1.35;
}
.social-proof-toast .sp-line {
  font-size: 13px;
  font-weight: 700;
  color: var(--bone, #F1E9D2);
}
.social-proof-toast .sp-line-2 {
  font-size: 12px;
  color: var(--fg-2, #D6CFB8);
  margin-top: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.social-proof-toast .sp-meta {
  font-family: var(--font-mono, 'Courier New', monospace);
  font-size: 10px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--smoke-400, #8A8A7A);
  margin-top: 3px;
}
.social-proof-toast .sp-dismiss {
  flex: 0 0 auto;
  align-self: flex-start;
  background: none;
  border: none;
  color: var(--smoke-400, #8A8A7A);
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
  padding: 2px 6px;
  border-radius: 3px;
}
.social-proof-toast .sp-dismiss:hover {
  color: var(--bone, #F1E9D2);
  background: var(--ink, #0A0A07);
}
@media (max-width: 640px) {
  .social-proof-toast {
    left: 12px;
    right: 12px;
    bottom: 12px;
    max-width: none;
  }
}
@media (prefers-reduced-motion: reduce) {
  .social-proof-toast { transition: opacity .15s linear; transform: none !important; }
}
