/* =========================================================================
 * LOUDWIRE DIGITAL COVER — YUNGBLUD
 * Stylesheet. Paired with dogstar-cover.js.
 *
 * All rules are scoped to #lw-cover-dogstar so nothing leaks into the
 * surrounding WordPress theme.
 * ========================================================================= */

#lw-cover-dogstar {
  /* Brand tokens */
  --lw-red: #e1261c;
  --lw-red-deep: #b81e16;
  --ink: #0a0a0a;
  --paper: #f4efe7;
  --paper-dim: #d9d2c4;
  --hot-white: #ffffff;

  /* Type */
  --font-display: 'din-condensed', 'Impact', sans-serif;
  --font-accent: 'Permanent Marker', 'Comic Sans MS', cursive;
  --font-body: 'Inter', system-ui, -apple-system, sans-serif;

  /* Stay inside the WP post column. All inner typography sizes use
     container query units (cqi) so they scale to THIS element's width,
     not the browser viewport. */
  container-type: inline-size;
  container-name: lwcover;
  position: relative;
  width: 100%;
  max-width: 100%;
  overflow: hidden;
  overflow-x: clip; /* harder than `hidden` — never produces a scroll context */
  margin: 0 0 30px;
  border-radius: 0;
  isolation: isolate;

  background: var(--ink);
  color: var(--paper);
  font-family: var(--font-body);
  -webkit-font-smoothing: antialiased;
  line-height: 1.55;
}

#lw-cover-dogstar * { box-sizing: border-box; }
#lw-cover-dogstar img { max-width: 100%; display: block; }
#lw-cover-dogstar a { color: inherit; }
#lw-cover-dogstar mark,
#lw-cover-dogstar em { font-weight: inherit; font-style: inherit; }

/* Kill theme-injected decorations on quote elements (the Townsquare theme
   adds ::before/::after with stylized quotation marks to blockquote/q,
   which clash with our own typography). */
#lw-cover-dogstar blockquote,
#lw-cover-dogstar q,
#lw-cover-dogstar .lw-quote__text {
  margin: 0;
  padding: 0;
  quotes: none;
}
#lw-cover-dogstar blockquote::before,
#lw-cover-dogstar blockquote::after,
#lw-cover-dogstar q::before,
#lw-cover-dogstar q::after,
#lw-cover-dogstar .lw-quote__text::before,
#lw-cover-dogstar .lw-quote__text::after {
  content: none !important;
  display: none !important;
}

/* ---------- Halftone + grain textures (pure CSS) ---------- */
#lw-cover-dogstar .lw-halftone {
  background-image:
    radial-gradient(circle at 1px 1px, rgba(255,255,255,0.18) 1px, transparent 1.5px);
  background-size: 6px 6px;
}
#lw-cover-dogstar .lw-grain::after {
  content: '';
  position: absolute; inset: 0;
  pointer-events: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.5 0'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='0.35'/></svg>");
  opacity: 0.12;
  mix-blend-mode: overlay;
}

/* ---------- HERO ---------- */
#lw-cover-dogstar .lw-hero {
  position: relative;
  width: 100%;
  height: clamp(560px, 115cqi, 820px);
  overflow: hidden;
  background: var(--ink);
}
#lw-cover-dogstar .lw-hero__bg,
#lw-cover-dogstar .lw-hero__scrim,
#lw-cover-dogstar .lw-hero__fg {
  position: absolute; inset: 0;
  will-change: transform;
}
#lw-cover-dogstar .lw-hero__bg {
  /* background-image set via inline style from CONTENT.heroBgImage */
  background-size: cover;
  background-position: center 28%;
  transform: scale(1.08);
}
#lw-cover-dogstar .lw-hero__scrim {
  background:
    linear-gradient(180deg, rgba(10,10,10,0.05) 0%, rgba(10,10,10,0.1) 35%, rgba(10,10,10,0.75) 72%, rgba(10,10,10,0.96) 100%),
    radial-gradient(80% 60% at 50% 40%, transparent 0%, rgba(225,38,28,0.18) 100%);
  pointer-events: none;
}
#lw-cover-dogstar .lw-hero__fg {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: clamp(16px, 4cqi, 36px);
  z-index: 3;
}
#lw-cover-dogstar .lw-eyebrow {
  display: inline-flex; align-items: center; gap: 12px;
  font-family: var(--font-body);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.25em;
  font-size: 12px;
  color: var(--paper);
  background: var(--lw-red);
  padding: 8px 14px;
  align-self: flex-start;
  margin-top: clamp(20px, 5cqi, 48px);
  transform: rotate(-1.5deg);
  box-shadow: 4px 4px 0 var(--ink);
}
#lw-cover-dogstar .lw-eyebrow::before {
  content: '●';
  color: var(--paper);
  font-size: 10px;
}
#lw-cover-dogstar .lw-hero__headline {
  font-family: var(--font-display);
  font-weight: 900;
  font-style: italic;
  font-size: clamp(28px, 6.2cqi, 56px);
  line-height: 0.95;
  letter-spacing: -0.005em;
  text-transform: uppercase;
  margin: auto 0 12px;
  color: var(--paper);
  /* Default: white text with red dropshadow */
  text-shadow: 0 3px 0 var(--lw-red), 0 6px 24px rgba(0,0,0,0.6);
}
#lw-cover-dogstar .lw-hero__headline .ln {
  display: block;
  overflow: hidden;
  padding: 0.04em 0; /* room for descenders + entrance animation */
}
#lw-cover-dogstar .lw-hero__headline .ln span {
  display: inline-block;
}
/* Line 1 (artist name) — dominant; outsized red wordmark anchored at bottom. */
#lw-cover-dogstar .lw-hero__headline .ln:nth-child(1) span {
  font-size: clamp(72px, 18cqi, 168px);
  line-height: 0.85;
  color: var(--lw-red);
  text-shadow: 0 4px 0 var(--lw-red-deep), 0 8px 28px rgba(0,0,0,0.7);
  transform: rotate(-1.5deg);
  letter-spacing: -0.02em;
}

#lw-cover-dogstar .lw-hero__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 14px 28px;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--paper-dim);
}
#lw-cover-dogstar .lw-hero__meta b { color: var(--paper); font-weight: 800; }

@container lwcover (max-width: 560px) {
  #lw-cover-dogstar .lw-eyebrow {
    margin-top: 0;
    font-size: 10px;
    padding: 6px 10px;
    letter-spacing: 0.2em;
  }
  #lw-cover-dogstar .lw-hero__meta {
    line-height: 1.2;
    gap: 4px 16px;
  }
  /* Mobile: scale the band photo up to 165% so it fills the hero. The
     headline + meta sit over the lower portion via the dark scrim gradient,
     with no empty dark space below. */
  #lw-cover-dogstar .lw-hero {
    height: clamp(420px, 110cqi, 500px);
  }
  #lw-cover-dogstar .lw-hero__fg {
    padding-bottom: 16px;
  }
  #lw-cover-dogstar .lw-hero__bg {
    background-size: 165% auto;
    background-position: center top;
    background-repeat: no-repeat;
    transform: none;
  }
}

#lw-cover-dogstar .lw-scroll-hint {
  position: absolute;
  bottom: 18px; left: 50%;
  transform: translateX(-50%);
  z-index: 4;
  font-size: 10px;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--paper-dim);
  animation: lw-bob 2.4s ease-in-out infinite;
}
@keyframes lw-bob {
  0%,100% { transform: translate(-50%, 0); opacity: 0.7; }
  50%     { transform: translate(-50%, 8px); opacity: 1; }
}

/* ---------- SOCIAL SHARE STRIP ---------- */
/* Slot directly under the hero. The WP-rendered .social-share.bignsexy <ul>
   is moved into [data-social-share-target] at boot; section stays hidden
   until that migration succeeds. */
#lw-cover-dogstar .lw-social-share {
  position: relative;
  background: var(--ink);
  color: var(--paper);
  padding: clamp(18px, 2.6cqi, 28px) clamp(16px, 4cqi, 36px);
  text-align: center;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
#lw-cover-dogstar .lw-social-share__inner {
  max-width: 480px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}
#lw-cover-dogstar .lw-social-share__kicker {
  display: inline-block;
  font-family: var(--font-accent);
  color: var(--lw-red);
  font-size: clamp(14px, 2cqi, 18px);
  transform: rotate(-1.5deg);
  letter-spacing: 0.02em;
}
/* Reset and style the migrated <ul> as horizontal pill buttons. */
#lw-cover-dogstar .lw-social-share__slot ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: center;
  align-items: center;
}
#lw-cover-dogstar .lw-social-share__slot li {
  margin: 0;
  padding: 0;
}
#lw-cover-dogstar .lw-social-share__slot a {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 18px;
  background: var(--lw-red);
  color: var(--paper);
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  text-decoration: none;
  box-shadow: 3px 3px 0 var(--paper);
  transition: transform 0.2s, box-shadow 0.2s, background 0.2s;
}
#lw-cover-dogstar .lw-social-share__slot a:hover,
#lw-cover-dogstar .lw-social-share__slot a:focus-visible {
  background: var(--lw-red-deep);
  transform: translate(-2px, -2px);
  box-shadow: 5px 5px 0 var(--paper);
  outline: none;
}
#lw-cover-dogstar .lw-social-share__slot .social-icon-svg-inner {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
#lw-cover-dogstar .lw-social-share__slot svg {
  width: 16px;
  height: 16px;
  fill: currentColor;
  flex-shrink: 0;
}
/* Show the "Share on …" label inline next to each icon. */
#lw-cover-dogstar .lw-social-share__slot .share-title {
  display: inline-block;
  white-space: nowrap;
}

/* ---------- COVER REVEAL ---------- */
#lw-cover-dogstar .lw-cover-reveal {
  position: relative;
  padding: clamp(48px, 8cqi, 96px) clamp(20px, 5cqi, 48px);
  background: var(--ink);
  color: var(--paper);
  overflow: hidden;
}
#lw-cover-dogstar .lw-cover-reveal__bg {
  position: absolute; inset: 0;
  /* background-image set via inline style from CONTENT.coverReveal.image */
  background-size: cover;
  background-position: center;
  filter: blur(40px) brightness(0.4) saturate(1.4);
  transform: scale(1.2);
  z-index: 0;
}
#lw-cover-dogstar .lw-cover-reveal__bg::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(10,10,10,0.65) 0%, rgba(212,0,79,0.25) 50%, rgba(10,10,10,0.85) 100%);
}
#lw-cover-dogstar .lw-cover-reveal__inner {
  position: relative;
  z-index: 1;
  max-width: 560px;
  margin: 0 auto;
  text-align: center;
}
#lw-cover-dogstar .lw-cover-reveal__meta {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  margin-bottom: 28px;
}
#lw-cover-dogstar .lw-cover-reveal__tag {
  font-family: var(--font-body);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.3em;
  font-size: clamp(11px, 1.4cqi, 13px);
  color: var(--lw-red);
}
#lw-cover-dogstar .lw-cover-reveal__issue {
  font-family: var(--font-accent);
  font-size: clamp(16px, 2.4cqi, 22px);
  color: var(--paper);
  transform: rotate(-1deg);
}
#lw-cover-dogstar .lw-cover-reveal__frame {
  position: relative;
  margin: 0 auto;
  max-width: 100%;
  padding: 14px;
  background: #ffffff;
  box-shadow: 0 30px 60px rgba(0,0,0,0.55), 0 0 0 1px rgba(255,255,255,0.08);
  transform: rotate(-1.5deg);
  transition: transform 0.45s cubic-bezier(.2,.8,.2,1);
}
#lw-cover-dogstar .lw-cover-reveal__frame:hover {
  transform: rotate(0deg) scale(1.02);
}
#lw-cover-dogstar .lw-cover-reveal__frame img {
  display: block;
  width: 100%;
  height: auto;
}
#lw-cover-dogstar .lw-cover-reveal__corner {
  position: absolute;
  width: 22px; height: 22px;
  border: 3px solid var(--lw-red);
  pointer-events: none;
}
#lw-cover-dogstar .lw-cover-reveal__corner--tl { top: -6px; left: -6px;  border-right: 0; border-bottom: 0; }
#lw-cover-dogstar .lw-cover-reveal__corner--tr { top: -6px; right: -6px; border-left: 0;  border-bottom: 0; }
#lw-cover-dogstar .lw-cover-reveal__corner--bl { bottom: -6px; left: -6px;  border-right: 0; border-top: 0; }
#lw-cover-dogstar .lw-cover-reveal__corner--br { bottom: -6px; right: -6px; border-left: 0;  border-top: 0; }

#lw-cover-dogstar .lw-cover-reveal__caption {
  margin: 24px 0 0;
  font-size: 13px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--paper-dim);
}

/* ---------- DEK ---------- */
#lw-cover-dogstar .lw-dek {
  position: relative;
  padding: clamp(48px, 7cqi, 80px) clamp(20px, 5cqi, 48px);
  background: var(--paper);
  color: var(--ink);
}
#lw-cover-dogstar .lw-dek::before {
  content: '';
  position: absolute; inset: 0;
  background-image:
    radial-gradient(circle at 1px 1px, rgba(0,0,0,0.18) 1px, transparent 1.6px);
  background-size: 5px 5px;
  opacity: 0.5;
  pointer-events: none;
}
#lw-cover-dogstar .lw-dek__wrap {
  position: relative;
  max-width: 880px;
  margin: 0 auto;
}
#lw-cover-dogstar .lw-dek__subhead {
  font-family: var(--font-display);
  font-weight: 900;
  font-style: italic;
  text-transform: uppercase;
  font-size: clamp(28px, 6cqi, 52px);
  line-height: 1;
  margin: 0 0 28px;
  color: var(--ink);
}
#lw-cover-dogstar .lw-dek__subhead em {
  font-style: italic;
  background: var(--lw-red);
  color: var(--paper);
  padding: 0 0.2em;
  display: inline-block;
  transform: rotate(-1deg);
}
#lw-cover-dogstar .lw-dek p {
  font-size: clamp(16px, 2.2cqi, 19px);
  line-height: 1.65;
  margin: 0 0 1.2em;
  opacity: 0;
  transform: translateY(24px);
}
/* Lede: only the opening summary paragraph reads larger, with a red rule
   separating it from the interview body that follows. */
#lw-cover-dogstar .lw-dek p:first-of-type {
  font-size: clamp(21px, 3.4cqi, 26px);
  line-height: 1.45;
  font-weight: 500;
  color: var(--ink);
  margin-bottom: clamp(28px, 4cqi, 40px);
  padding-bottom: clamp(20px, 3cqi, 32px);
  border-bottom: 3px solid var(--lw-red);
}
/* Inline links in body copy — red, underlined, with a deeper red on hover. */
#lw-cover-dogstar .lw-dek a,
#lw-cover-dogstar .lw-chapter a {
  color: var(--lw-red);
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 3px;
  transition: color 0.2s;
}
#lw-cover-dogstar .lw-dek a:hover,
#lw-cover-dogstar .lw-chapter a:hover {
  color: var(--lw-red-deep);
}
#lw-cover-dogstar .lw-dek em,
#lw-cover-dogstar .lw-chapter em {
  font-style: italic;
}
/* Album title — red italic, wrapped in auto single quotes. */
#lw-cover-dogstar em.lw-album {
  font-style: italic;
  color: var(--lw-red);
  font-weight: 600;
}
#lw-cover-dogstar em.lw-album::before { content: '\2018'; }
#lw-cover-dogstar em.lw-album::after  { content: '\2019'; }
/* Links that wrap an album title keep their underline + red color cohesive. */
#lw-cover-dogstar a > em.lw-album,
#lw-cover-dogstar em.lw-album {
  color: var(--lw-red);
}
#lw-cover-dogstar .lw-dek p:first-of-type::first-letter {
  font-family: var(--font-display);
  font-weight: 900;
  font-style: normal;
  float: left;
  font-size: 4em;
  line-height: 0.82;
  padding: 4px 3px 0 0;
  color: var(--lw-red);
}

/* ---------- CHAPTERS ---------- */
#lw-cover-dogstar .lw-chapter {
  /* Default = paper (tan) theme */
  position: relative;
  padding: clamp(48px, 7cqi, 80px) clamp(20px, 5cqi, 48px);
  background: var(--paper);
  color: var(--ink);
  border-top: 2px dashed rgba(0,0,0,0.15);
  overflow: hidden;
}
#lw-cover-dogstar .lw-chapter::before {
  content: '';
  position: absolute; inset: 0;
  background-image:
    radial-gradient(circle at 1px 1px, rgba(0,0,0,0.18) 1px, transparent 1.6px);
  background-size: 5px 5px;
  opacity: 0.5;
  pointer-events: none;
  z-index: 0;
}
#lw-cover-dogstar .lw-chapter__inner {
  position: relative;
  z-index: 1;
}
#lw-cover-dogstar .lw-chapter--ink {
  background: var(--ink);
  color: var(--paper);
  border-top-color: rgba(255,255,255,0.12);
}
#lw-cover-dogstar .lw-chapter--ink::before {
  display: none; /* no dotted texture on dark sections */
}
#lw-cover-dogstar .lw-chapter__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  max-width: 100%;
  margin: 0 auto;
}
#lw-cover-dogstar .lw-chapter__rail {
  display: none;
}
#lw-cover-dogstar .lw-chapter__kicker {
  font-family: var(--font-accent);
  font-size: 18px;
  color: var(--lw-red);
  margin-top: 12px;
  transform: rotate(-1.5deg);
  display: inline-block;
}
#lw-cover-dogstar .lw-chapter__kicker--mobile {
  margin: -4px 0 18px;
}
@container lwcover (min-width: 640px) {
  #lw-cover-dogstar .lw-chapter__inner {
    grid-template-columns: 180px 1fr;
    gap: 40px;
  }
  #lw-cover-dogstar .lw-chapter__rail {
    display: block;
    position: relative;
  }
  #lw-cover-dogstar .lw-chapter__kicker--mobile {
    display: none;
  }
}
#lw-cover-dogstar .lw-chapter__heading {
  font-family: var(--font-display);
  font-weight: 900;
  font-style: italic;
  font-size: clamp(28px, 6.5cqi, 56px);
  line-height: 0.95;
  text-transform: uppercase;
  margin: 0 0 20px;
  letter-spacing: -0.005em;
}
#lw-cover-dogstar .lw-chapter__heading::after {
  content: '';
  display: block;
  width: 80px; height: 6px;
  background: var(--lw-red);
  margin-top: 16px;
}
#lw-cover-dogstar .lw-chapter p {
  font-size: clamp(16px, 2cqi, 18px);
  line-height: 1.7;
  margin: 0 0 1.1em;
}
/* Only the data-reveal paragraphs start hidden; nested embeds (merch promo,
   etc.) inside a chapter must stay visible regardless of scroll position. */
#lw-cover-dogstar .lw-chapter p[data-reveal] {
  opacity: 0;
  transform: translateY(20px);
}

/* Inline editorial photo within a chapter — tape-secured, tilted polaroid
   that floats next to body copy on wider columns and stacks on narrow. */
#lw-cover-dogstar .lw-chapter__photo {
  position: relative;
  margin: 8px 0 20px;
  padding: 15px 15px 50px;
  background: #ffffff;
  color: var(--ink);
  box-shadow: 0 18px 36px rgba(0,0,0,0.35);
  transform: rotate(-2deg);
  transition: transform 0.45s cubic-bezier(.2,.8,.2,1);
  width: 100%;
  max-width: 100%;
}
#lw-cover-dogstar .lw-chapter__photo::before {
  content: '';
  position: absolute;
  top: -10px; left: 50%;
  width: 90px; height: 22px;
  transform: translateX(-50%) rotate(3deg);
  background: rgba(255,255,255,0.6);
  box-shadow: 0 1px 4px rgba(0,0,0,0.2);
}
#lw-cover-dogstar .lw-chapter__photo:hover { transform: rotate(0deg) scale(1.02); }
#lw-cover-dogstar .lw-chapter__photo img {
  width: 100%;
  aspect-ratio: 3 / 3;
  height: auto;
  object-fit: cover;
  display: block;
  filter: contrast(1.04) saturate(1.08);
}
#lw-cover-dogstar .lw-chapter__photo figcaption {
  margin-top: 10px;
  font-family: var(--font-accent);
  font-size: clamp(16px, 2.8cqi, 22px);
  line-height: 1.2;
  text-align: center;
  color: var(--ink);
  transform: rotate(-1.5deg);
}
@container lwcover (min-width: 560px) {
  #lw-cover-dogstar .lw-chapter__photo {
    max-width: 46%;
    padding: 15px 15px 50px;
  }
  #lw-cover-dogstar .lw-chapter__photo--right {
    float: right;
    margin: 4px 0 16px 28px;
    transform: rotate(2deg);
  }
  #lw-cover-dogstar .lw-chapter__photo--left {
    float: left;
    margin: 4px 28px 16px 0;
    transform: rotate(-2deg);
  }
}

/* ---------- VIDEO EMBED — RETRO TV ---------- */
#lw-cover-dogstar .lw-video {
  position: relative;
  background: var(--ink);
  color: var(--paper);
  padding: clamp(48px, 7cqi, 80px) clamp(20px, 5cqi, 48px);
  overflow: hidden;
}
#lw-cover-dogstar .lw-video__inner {
  max-width: 100%;
  margin: 0 auto;
  text-align: center;
}
#lw-cover-dogstar .lw-video__kicker {
  display: inline-block;
  font-family: var(--font-accent);
  font-size: clamp(14px, 2cqi, 20px);
  color: var(--lw-red);
  margin-bottom: 8px;
  transform: rotate(-1.5deg);
}
#lw-cover-dogstar .lw-video__title {
  font-family: var(--font-display);
  font-weight: 900;
  font-style: italic;
  font-size: clamp(28px, 6cqi, 52px);
  line-height: 1;
  text-transform: uppercase;
  margin: 0 0 24px;
  color: var(--paper);
}

/* TV housing */
#lw-cover-dogstar .lw-tv {
  position: relative;
  max-width: 85%;
  margin: 0 auto;
}
@container lwcover (max-width: 560px) {
  #lw-cover-dogstar .lw-tv {
    max-width: 100%;
  }
}

/* Antenna */
#lw-cover-dogstar .lw-tv__antenna {
  position: relative;
  height: 50px;
  display: flex;
  justify-content: center;
  align-items: flex-end;
}
#lw-cover-dogstar .lw-tv__antenna-l,
#lw-cover-dogstar .lw-tv__antenna-r {
  width: 3px;
  height: 48px;
  background: #555;
  border-radius: 2px 2px 0 0;
  position: absolute;
  bottom: 0;
}
#lw-cover-dogstar .lw-tv__antenna-l {
  transform: rotate(-20deg);
  transform-origin: bottom center;
  left: calc(50% - 24px);
}
#lw-cover-dogstar .lw-tv__antenna-r {
  transform: rotate(20deg);
  transform-origin: bottom center;
  right: calc(50% - 24px);
}
#lw-cover-dogstar .lw-tv__antenna-l::after,
#lw-cover-dogstar .lw-tv__antenna-r::after {
  content: '';
  position: absolute;
  top: -4px; left: 50%;
  transform: translateX(-50%);
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--lw-red);
}
#lw-cover-dogstar .lw-tv__antenna-base {
  width: 20px; height: 6px;
  background: #444;
  border-radius: 3px;
  position: relative;
  z-index: 1;
}

/* TV body */
#lw-cover-dogstar .lw-tv__body {
  position: relative;
  background: #2a2a2a;
  border-radius: 18px;
  padding: clamp(14px, 3cqi, 28px);
  box-shadow: 0 30px 60px rgba(0,0,0,0.6), inset 0 1px 0 rgba(255,255,255,0.06);
  border: 3px solid #333;
}

/* Screen area */
#lw-cover-dogstar .lw-tv__screen {
  position: relative;
  border-radius: 10px;
  overflow: hidden;
  background: #111;
  border: 4px solid #1a1a1a;
  box-shadow: inset 0 0 30px rgba(0,0,0,0.8), inset 0 0 4px rgba(255,255,255,0.03);
  aspect-ratio: 16 / 9;
}

/* Static noise — animated grain overlay */
@keyframes lw-static {
  0%   { background-position: 0 0; }
  10%  { background-position: -5% -10%; }
  20%  { background-position: -15% 5%; }
  30%  { background-position: 7% -25%; }
  40%  { background-position: -15% 25%; }
  50%  { background-position: 15% 10%; }
  60%  { background-position: -5% -10%; }
  70%  { background-position: 15% 5%; }
  80%  { background-position: -15% -25%; }
  90%  { background-position: 5% 25%; }
  100% { background-position: 0 0; }
}
#lw-cover-dogstar .lw-tv__static {
  position: absolute; inset: 0;
  z-index: 2;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
  background-size: 180px 180px;
  opacity: 0.6;
  animation: lw-static 0.15s steps(8) infinite;
  pointer-events: none;
  transition: opacity 0.8s ease;
}
#lw-cover-dogstar .lw-tv__screen:hover .lw-tv__static,
#lw-cover-dogstar .lw-tv__static.is-off {
  opacity: 0;
}

/* Scanlines */
#lw-cover-dogstar .lw-tv__scanlines {
  position: absolute; inset: 0;
  z-index: 3;
  background: repeating-linear-gradient(
    0deg,
    transparent,
    transparent 2px,
    rgba(0,0,0,0.12) 2px,
    rgba(0,0,0,0.12) 4px
  );
  pointer-events: none;
}

/* Video iframe inside the screen */
#lw-cover-dogstar .lw-tv .lw-video__frame {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  z-index: 1;
  background: #000;
  box-shadow: none;
  aspect-ratio: auto;
}
#lw-cover-dogstar .lw-video__frame iframe {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  border: 0;
  display: block;
}
/* Placeholder shown when the YouTube ID hasn't been added yet. */
#lw-cover-dogstar .lw-video__placeholder {
  position: absolute; inset: 0;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #000;
  color: var(--paper);
  font-family: var(--font-display);
  font-weight: 900;
  font-style: italic;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: clamp(20px, 4cqi, 36px);
  text-shadow: 0 2px 0 var(--lw-red), 0 4px 12px rgba(0,0,0,0.6);
}

/* Controls strip below screen */
#lw-cover-dogstar .lw-tv__controls {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(14px, 3cqi, 28px);
  padding: clamp(10px, 2cqi, 18px) 0 0;
}
#lw-cover-dogstar .lw-tv__knob {
  width: clamp(24px, 4cqi, 36px);
  height: clamp(24px, 4cqi, 36px);
  border-radius: 50%;
  background: radial-gradient(circle at 35% 35%, #555 0%, #222 100%);
  border: 2px solid #444;
  box-shadow: 0 2px 6px rgba(0,0,0,0.5), inset 0 1px 0 rgba(255,255,255,0.1);
  position: relative;
}
#lw-cover-dogstar .lw-tv__knob::after {
  content: '';
  position: absolute;
  top: 4px; left: 50%;
  width: 2px; height: 35%;
  background: #888;
  transform: translateX(-50%);
  border-radius: 1px;
}
#lw-cover-dogstar .lw-tv__knob--sm {
  width: clamp(18px, 3cqi, 26px);
  height: clamp(18px, 3cqi, 26px);
}
#lw-cover-dogstar .lw-tv__led {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--lw-red);
  box-shadow: 0 0 6px var(--lw-red), 0 0 12px rgba(225,38,28,0.4);
  animation: lw-led-pulse 2s ease-in-out infinite;
}
@keyframes lw-led-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.5; }
}

/* Feet */
#lw-cover-dogstar .lw-tv__feet {
  display: flex;
  justify-content: center;
  gap: 60%;
}
#lw-cover-dogstar .lw-tv__foot {
  width: 28px; height: 6px;
  background: #333;
  border-radius: 0 0 4px 4px;
}

/* TV branded logo — bottom-right of controls strip */
#lw-cover-dogstar .lw-tv__logo {
  margin-left: auto;
  display: flex;
  align-items: flex-start;
  gap: 5px;
}
#lw-cover-dogstar .lw-tv__logo-lw {
  font-family: var(--font-display);
  font-weight: 900;
  font-style: italic;
  font-size: clamp(14px, 2.5cqi, 20px);
  color: #e1261c;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  transform: skewX(-6deg);
  display: inline-block;
}
#lw-cover-dogstar .lw-tv__logo-label {
  font-family: var(--font-accent);
  font-size: clamp(18px, 3.2cqi, 28px);
  color: #e1261c;
  line-height: 1;
  transform: skewX(-8deg) rotate(-2deg);
  display: inline-block;
  align-self: flex-end;
  margin-bottom: 1px;
}

/* ---------- PODCAST EMBED — RETRO RADIO ---------- */
#lw-cover-dogstar .lw-podcast {
  position: relative;
  background: var(--ink);
  color: var(--paper);
  padding: clamp(48px, 7cqi, 80px) clamp(20px, 5cqi, 48px);
  overflow: hidden;
}
#lw-cover-dogstar .lw-podcast::before {
  display: none;
}
#lw-cover-dogstar .lw-podcast__inner {
  position: relative;
  max-width: 100%;
  margin: 0 auto;
  text-align: center;
}
#lw-cover-dogstar .lw-podcast__kicker {
  display: inline-block;
  font-family: var(--font-accent);
  font-size: clamp(14px, 2cqi, 20px);
  color: var(--lw-red);
  margin-bottom: 8px;
  transform: rotate(-1.5deg);
}
#lw-cover-dogstar .lw-podcast__title {
  font-family: var(--font-display);
  font-weight: 900;
  font-style: italic;
  font-size: clamp(28px, 6cqi, 52px);
  line-height: 1;
  text-transform: uppercase;
  margin: 0 0 24px;
  color: var(--paper);
}

/* Radio housing */
#lw-cover-dogstar .lw-radio {
  position: relative;
  max-width: 85%;
  margin: 0 auto;
}
@container lwcover (max-width: 560px) {
  #lw-cover-dogstar .lw-radio {
    max-width: 100%;
  }
}

/* Antenna */
#lw-cover-dogstar .lw-radio__antenna {
  width: 3px;
  height: 55px;
  background: linear-gradient(to top, #888, #bbb);
  margin: 0 auto -4px;
  border-radius: 2px 2px 0 0;
  transform: rotate(-12deg);
  transform-origin: bottom center;
  position: relative;
}
#lw-cover-dogstar .lw-radio__antenna::after {
  content: '';
  position: absolute;
  top: -5px; left: 50%;
  transform: translateX(-50%);
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--lw-red);
  box-shadow: 0 0 6px rgba(225,38,28,0.5);
}

/* Radio body */
#lw-cover-dogstar .lw-radio__body {
  background: linear-gradient(170deg, #3a3028 0%, #2a221c 60%, #1e1812 100%);
  border-radius: 16px;
  padding: clamp(16px, 3cqi, 24px);
  box-shadow: 0 24px 48px rgba(0,0,0,0.5), inset 0 1px 0 rgba(255,255,255,0.08);
  border: 2px solid #4a4038;
  overflow: hidden;
}

/* Content row: speaker — player — speaker */
#lw-cover-dogstar .lw-radio__content-row {
  display: flex;
  gap: clamp(10px, 2cqi, 20px);
  align-items: center;
}

/* Small speakers on each side */
#lw-cover-dogstar .lw-radio__speaker {
  flex: 0 0 clamp(80px, 14cqi, 140px);
}
#lw-cover-dogstar .lw-radio__grille {
  width: 100%;
  aspect-ratio: 1;
  border-radius: 50%;
  background:
    repeating-radial-gradient(
      circle at 50% 50%,
      transparent 0px,
      transparent 3px,
      rgba(80,70,58,0.6) 3px,
      rgba(80,70,58,0.6) 5px
    );
  border: 3px solid #4a4038;
  box-shadow: inset 0 4px 12px rgba(0,0,0,0.5), 0 1px 0 rgba(255,255,255,0.05);
  position: relative;
}
#lw-cover-dogstar .lw-radio__grille::after {
  content: '';
  position: absolute; inset: 20%;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(225,38,28,0.08) 0%, transparent 70%);
  animation: lw-speaker-pulse 3s ease-in-out infinite;
}
@keyframes lw-speaker-pulse {
  0%, 100% { transform: scale(1); opacity: 0.4; }
  50% { transform: scale(1.1); opacity: 0.8; }
}

/* Player slot — center, takes remaining space */
#lw-cover-dogstar .lw-radio__player-slot {
  flex: 1;
  min-width: 0;
}

/* Radio branded logo — bottom-right */
#lw-cover-dogstar .lw-radio__logo {
  display: flex;
  align-items: flex-start;
  justify-content: flex-end;
  gap: 5px;
  padding: 12px 4px 2px;
}
#lw-cover-dogstar .lw-radio__logo-lw {
  font-family: var(--font-display);
  font-weight: 900;
  font-style: italic;
  font-size: clamp(14px, 2.5cqi, 20px);
  color: #e1261c;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  transform: skewX(-6deg);
  display: inline-block;
}
#lw-cover-dogstar .lw-radio__logo-label {
  font-family: var(--font-accent);
  font-size: clamp(18px, 3.2cqi, 28px);
  color: #e1261c;
  line-height: 1;
  transform: skewX(-8deg) rotate(-2deg);
  display: inline-block;
  align-self: flex-end;
  margin-bottom: 1px;
}

/* --- Townsquare .ondemand-podcast-player inside radio ---
   Transparent background, no red header — content sits directly on radio surface */

#lw-cover-dogstar .ondemand-podcast-player {
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  overflow: visible !important;
  box-shadow: none !important;
  transform: none !important;
}

/* Hide the red banner header entirely */
#lw-cover-dogstar .ondemand-podcast-player .playlist-title {
  display: none !important;
}

#lw-cover-dogstar .ondemand-podcast-player .player {
  background: transparent !important;
}
#lw-cover-dogstar .ondemand-podcast-player .playlist-wrapper {
  background: transparent !important;
}
#lw-cover-dogstar .ondemand-podcast-player .playlist {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
}
#lw-cover-dogstar .ondemand-podcast-player .playlist li {
  background: transparent !important;
  border: none !important;
  padding: 8px 0 !important;
}
#lw-cover-dogstar .ondemand-podcast-player .info {
  background: transparent !important;
}

#lw-cover-dogstar .ondemand-podcast-player .track-meta .date,
#lw-cover-dogstar .ondemand-podcast-player .track-meta .dur-min {
  color: var(--lw-red) !important;
  font-family: var(--font-accent) !important;
  font-size: 11px !important;
  letter-spacing: 0.05em !important;
}

#lw-cover-dogstar .ondemand-podcast-player h3.title {
  color: var(--paper) !important;
  font-family: var(--font-display) !important;
  font-weight: 900 !important;
  font-style: italic !important;
  text-transform: uppercase !important;
  font-size: clamp(14px, 2.8cqi, 20px) !important;
  line-height: 1.2 !important;
  margin: 4px 0 6px !important;
}

#lw-cover-dogstar .ondemand-podcast-player .description {
  color: #8a7e72 !important;
  font-family: var(--font-body) !important;
  font-size: 12px !important;
  line-height: 1.4 !important;
}

#lw-cover-dogstar .ondemand-podcast-player .play-icon {
  width: 44px !important;
  height: 44px !important;
  cursor: pointer;
  transition: transform 0.15s ease !important;
}
#lw-cover-dogstar .ondemand-podcast-player .play-icon .circle {
  fill: var(--lw-red) !important;
}
#lw-cover-dogstar .ondemand-podcast-player .play-icon .inner {
  fill: #fff !important;
}
#lw-cover-dogstar .ondemand-podcast-player .play-icon:hover {
  transform: scale(1.1) !important;
}
#lw-cover-dogstar .ondemand-podcast-player .play-icon:hover .circle {
  fill: #c41e16 !important;
}

/* On mobile, hide speakers to give player full width */
@container lwcover (max-width: 480px) {
  #lw-cover-dogstar .lw-radio__speaker {
    display: none;
  }
}
#lw-cover-dogstar .lw-podcast__fallback {
  font-size: 14px;
  color: var(--ink);
  background: rgba(0,0,0,0.05);
  border: 1px dashed rgba(0,0,0,0.2);
  padding: 16px;
  border-radius: 4px;
  text-align: left;
}
#lw-cover-dogstar .lw-podcast__fallback code {
  background: rgba(0,0,0,0.08);
  padding: 1px 4px;
  border-radius: 3px;
}

/* ---------- PULL QUOTES ---------- */
#lw-cover-dogstar .lw-quote {
  position: relative;
  padding: clamp(48px, 8cqi, 96px) clamp(20px, 5cqi, 48px);
  overflow: hidden;
  text-align: center;
}
/* Highlight quote — text is immediately readable on a dark stage; a pink
   highlighter swatch sweeps across the marked phrase as you scroll in. */
#lw-cover-dogstar .lw-quote--highlight {
  background: var(--ink);
  color: var(--paper);
  text-align: center;
  padding-top: clamp(48px, 7cqi, 88px);
  padding-bottom: clamp(48px, 7cqi, 88px);
}
#lw-cover-dogstar .lw-quote--highlight .lw-quote__mark {
  display: block;
  font-family: Georgia, 'Times New Roman', serif;
  font-size: clamp(48px, 10cqi, 96px);
  line-height: 0.5;
  color: var(--lw-red);
  margin: 0 auto 16px;
  user-select: none;
  font-style: italic;
}
#lw-cover-dogstar .lw-quote--highlight .lw-quote__text {
  font-family: var(--font-display);
  font-weight: 900;
  font-style: italic;
  font-size: clamp(24px, 5.5cqi, 44px);
  line-height: 1.15;
  letter-spacing: -0.005em;
  margin: 0 auto 20px;
  text-transform: none;
  max-width: 88%;
}
#lw-cover-dogstar .lw-hl {
  --hl-w: 0%;
  font-weight: inherit;
  font-style: inherit;
  background:
    linear-gradient(120deg, var(--lw-red) 0%, var(--lw-red-deep) 100%)
    no-repeat;
  background-size: var(--hl-w) 100%;
  background-position: 0 75%;
  color: inherit;
  padding: 0 0.1em;
  transition: background-size 0.05s linear; /* GSAP drives --hl-w */
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
}

#lw-cover-dogstar .lw-quote--typewriter {
  background: var(--ink);
  color: var(--paper);
}
#lw-cover-dogstar .lw-quote--typewriter .lw-quote__text {
  font-family: var(--font-body);
  font-weight: 700;
  font-size: clamp(20px, 3.6cqi, 32px);
  line-height: 1.25;
  max-width: 100%;
  margin: 0 auto;
  letter-spacing: -0.01em;
}
#lw-cover-dogstar .lw-quote--typewriter .lw-quote__text mark {
  background: var(--lw-red);
  color: var(--ink);
  padding: 0 0.15em;
}
#lw-cover-dogstar .lw-quote--typewriter .lw-quote__caret {
  display: inline-block;
  width: 0.5ch;
  background: var(--lw-red);
  margin-left: 4px;
  animation: lw-blink 0.9s steps(1) infinite;
}
@keyframes lw-blink {
  50% { opacity: 0; }
}

#lw-cover-dogstar .lw-quote--ransom {
  background: var(--ink);
  color: var(--paper);
}
#lw-cover-dogstar .lw-quote--ransom .lw-quote__text {
  font-family: var(--font-display);
  font-weight: 900;
  font-style: italic;
  font-size: clamp(28px, 7cqi, 64px);
  line-height: 0.95;
  text-transform: uppercase;
  max-width: 100%;
  margin: 0 auto;
}
#lw-cover-dogstar .lw-quote--ransom .lw-quote__text .w {
  display: inline-block;
  margin: 0.06em 0.1em;
  padding: 0 0.15em;
  transform: rotate(var(--r, 0deg));
}
/* On the dark stage, the "blank" words read in paper; the colored swatches stay punchy. */
#lw-cover-dogstar .lw-quote--ransom .lw-quote__text .w:nth-child(3n)   { background: var(--lw-red); color: var(--paper); --r: -2deg; }
#lw-cover-dogstar .lw-quote--ransom .lw-quote__text .w:nth-child(5n+1) { background: var(--paper); color: var(--ink);   --r: 1.5deg; }
#lw-cover-dogstar .lw-quote--ransom .lw-quote__text .w:nth-child(7n+2) { background: var(--lw-red); color: var(--paper); --r: -1deg; }

#lw-cover-dogstar .lw-quote--ransom .lw-quote__attr { color: var(--paper); }

/* Mobile cleanup: gentler rotations + tighter type so a long ransom quote
   doesn't break the column. */
@container lwcover (max-width: 560px) {
  #lw-cover-dogstar .lw-quote--ransom .lw-quote__text {
    font-size: clamp(22px, 6.4cqi, 32px);
    line-height: 1.15;
  }
  #lw-cover-dogstar .lw-quote--ransom .lw-quote__text .w {
    margin: 0.05em 0.08em;
    padding: 0 0.12em;
  }
  #lw-cover-dogstar .lw-quote--ransom .lw-quote__text .w:nth-child(3n)   { --r: -1.25deg; }
  #lw-cover-dogstar .lw-quote--ransom .lw-quote__text .w:nth-child(5n+1) { --r: 1deg; }
  #lw-cover-dogstar .lw-quote--ransom .lw-quote__text .w:nth-child(7n+2) { --r: -0.75deg; }
}

#lw-cover-dogstar .lw-quote--huge {
  background: var(--lw-red-deep);
  color: var(--paper);
}
#lw-cover-dogstar .lw-quote--huge .lw-quote__text {
  font-family: var(--font-display);
  font-weight: 900;
  font-style: italic;
  font-size: clamp(48px, 13cqi, 112px);
  line-height: 0.9;
  text-transform: uppercase;
  max-width: 100%;
  margin: 0 auto;
}

#lw-cover-dogstar .lw-quote__attr {
  display: block;
  margin-top: 28px;
  font-family: var(--font-accent);
  font-size: 22px;
  letter-spacing: 0.05em;
  transform: rotate(-2deg);
}
/* Marquee was removed; ransom now sits on ink (handled by its own rule above). */

/* ---------- TAPED PHOTO ---------- */
#lw-cover-dogstar .lw-photo {
  position: relative;
  max-width: 720px;
  margin: 60px auto;
  padding: 18px 18px 64px;
  background: var(--paper);
  color: var(--ink);
  box-shadow: 0 30px 60px rgba(0,0,0,0.5);
  transform: rotate(-1.5deg);
  transition: transform 0.4s cubic-bezier(.2,.8,.2,1);
}
#lw-cover-dogstar .lw-photo:hover { transform: rotate(0.5deg) scale(1.02); }
#lw-cover-dogstar .lw-photo::before {
  content: '';
  position: absolute;
  top: -14px; left: 50%;
  transform: translateX(-50%) rotate(-3deg);
  width: 120px; height: 28px;
  background: rgba(255,255,255,0.55);
  box-shadow: 0 1px 4px rgba(0,0,0,0.2);
}
#lw-cover-dogstar .lw-photo img {
  width: 100%;
  filter: contrast(1.05) saturate(1.1);
}
#lw-cover-dogstar .lw-photo figcaption {
  position: absolute;
  bottom: 12px; left: 18px; right: 18px;
  font-family: var(--font-accent);
  font-size: 16px;
}

/* ---------- GALLERY ---------- */
#lw-cover-dogstar .lw-gallery {
  position: relative;
  background: var(--ink);
  padding: clamp(56px, 9cqi, 120px) clamp(20px, 5cqi, 48px);
  overflow: hidden;
}
#lw-cover-dogstar .lw-gallery__header {
  text-align: center;
  margin-bottom: clamp(32px, 5cqi, 56px);
}
#lw-cover-dogstar .lw-gallery__kicker {
  display: inline-block;
  font-family: var(--font-accent);
  font-size: clamp(16px, 2.4cqi, 22px);
  color: var(--lw-red);
  transform: rotate(-1.5deg);
  margin-bottom: 12px;
}
#lw-cover-dogstar .lw-gallery__heading {
  font-family: var(--font-display);
  font-weight: 900;
  font-style: italic;
  font-size: clamp(36px, 8cqi, 72px);
  line-height: 1;
  text-transform: uppercase;
  margin: 0;
  color: var(--paper);
}
#lw-cover-dogstar .lw-gallery__heading::after {
  content: '';
  display: block;
  width: 80px; height: 6px;
  background: var(--lw-red);
  margin: 16px auto 0;
}

/* Polaroid pile — overlapping tilted frames with hover lift. */
#lw-cover-dogstar .lw-gallery__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(20px, 4cqi, 40px);
  max-width: 100%;
  margin: 0 auto;
}
/* 2-col layout: if total item count is odd, center the last orphan
   in the row it sits alone in. */
@container lwcover (min-width: 421px) and (max-width: 639.98px) {
  #lw-cover-dogstar .lw-gallery__item:last-child:nth-child(odd) {
    grid-column: 1 / -1;
    justify-self: center;
    width: calc(50% - clamp(10px, 2cqi, 20px));
  }
}
/* 3-col layout: use a 6-track grid and have items span 2 tracks. That
   lets us shift the last row's orphans inward so 1 orphan centers in
   tracks 3–4, and 2 orphans center as a pair in tracks 2–3 and 4–5. */
@container lwcover (min-width: 640px) {
  #lw-cover-dogstar .lw-gallery__grid {
    grid-template-columns: repeat(6, 1fr);
  }
  #lw-cover-dogstar .lw-gallery__item {
    grid-column: span 2;
  }
  /* 1 orphan (total % 3 == 1) — center the lone last item. */
  #lw-cover-dogstar .lw-gallery__item:last-child:nth-child(3n + 1) {
    grid-column: 3 / span 2;
  }
  /* 2 orphans (total % 3 == 2) — center the pair. */
  #lw-cover-dogstar .lw-gallery__item:nth-last-child(2):nth-child(3n + 1) {
    grid-column: 2 / span 2;
  }
  #lw-cover-dogstar .lw-gallery__item:last-child:nth-child(3n + 2) {
    grid-column: 4 / span 2;
  }
}
@container lwcover (max-width: 420px) {
  #lw-cover-dogstar .lw-gallery__grid {
    grid-template-columns: 1fr;
  }
}
#lw-cover-dogstar .lw-gallery__item {
  position: relative;
  margin: 0;
  padding: 14px 14px 40px;
  background: #ffffff;
  color: var(--ink);
  box-shadow: 0 18px 36px rgba(0,0,0,0.45);
  transform: rotate(var(--r, 0deg));
  transition: transform 0.5s cubic-bezier(.2,.8,.2,1), box-shadow 0.4s, z-index 0s;
  cursor: pointer;
  z-index: 1;
}
#lw-cover-dogstar .lw-gallery__item::before {
  content: '';
  position: absolute;
  top: -10px; left: 50%;
  width: 90px; height: 22px;
  transform: translateX(-50%) rotate(calc(var(--r, 0deg) * -0.5));
  background: rgba(255,255,255,0.6);
  box-shadow: 0 1px 4px rgba(0,0,0,0.2);
}
#lw-cover-dogstar .lw-gallery__item:hover {
  transform: rotate(0deg) scale(1.04);
  box-shadow: 0 32px 60px rgba(0,0,0,0.6);
  z-index: 5;
}
#lw-cover-dogstar .lw-gallery__item img {
  width: 100%;
  aspect-ratio: 3 / 3;
  object-fit: cover;
  filter: contrast(1.05) saturate(1.1);
  display: block;
}
#lw-cover-dogstar .lw-gallery__item figcaption {
  margin: 10px 4px 0;
  font-family: var(--font-accent);
  font-size: clamp(15px, 2.5cqi, 20px);
  line-height: 1.2;
  color: var(--ink);
  text-align: center;
}

#lw-cover-dogstar .lw-gallery__credit {
  margin: clamp(32px, 5cqi, 56px) 0 0;
  text-align: center;
  font-size: 12px;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--paper-dim);
}
#lw-cover-dogstar .lw-gallery__credit a {
  color: var(--lw-red);
  text-decoration: none;
}

/* In-chapter embed wrapper — used when a merch promo is dropped between two
   chapter paragraphs. Escapes the chapter's horizontal padding so the embed
   reads full-bleed across the cover component. */
#lw-cover-dogstar .lw-chapter__break {
  margin-top: clamp(32px, 5cqi, 56px);
  margin-bottom: clamp(32px, 5cqi, 56px);
  margin-left: calc(-1 * clamp(20px, 5cqi, 48px));
  margin-right: calc(-1 * clamp(20px, 5cqi, 48px));
}
#lw-cover-dogstar .lw-chapter__break .lw-merch-promo {
  padding-top: clamp(22px, 3.5cqi, 36px);
  padding-bottom: clamp(22px, 3.5cqi, 36px);
}
@container lwcover (min-width: 640px) {
  #lw-cover-dogstar .lw-chapter__break {
    /* extra -220px on the left to swallow the chapter rail column */
    margin-left: calc(-1 * clamp(20px, 5cqi, 48px) - 220px);
  }
}

/* ---------- MID-ARTICLE PROMO BANNER ---------- */
#lw-cover-dogstar .lw-merch-promo {
  position: relative;
  background: var(--lw-red);
  color: var(--paper);
  padding: clamp(36px, 6cqi, 64px) clamp(20px, 5cqi, 48px);
  overflow: hidden;
}
#lw-cover-dogstar .lw-merch-promo::before {
  content: '';
  position: absolute; inset: 0;
  background-image:
    repeating-linear-gradient(135deg, rgba(0,0,0,0.06) 0 12px, transparent 12px 24px);
  pointer-events: none;
}
#lw-cover-dogstar .lw-merch-promo__inner {
  position: relative;
  max-width: 760px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(16px, 2.5cqi, 24px);
  align-items: center;
  text-align: center;
}
@container lwcover (min-width: 640px) {
  #lw-cover-dogstar .lw-merch-promo__inner {
    grid-template-columns: minmax(180px, 240px) 1fr;
    text-align: left;
    gap: clamp(24px, 3.5cqi, 36px);
  }
}
#lw-cover-dogstar .lw-merch-promo__art {
  display: block;
  position: relative;
  width: clamp(120px, 30cqi, 170px);
  margin: 0 auto;
  aspect-ratio: 1 / 1;
  background: var(--ink);
  box-shadow: 0 14px 28px rgba(0,0,0,0.4), 0 0 0 2px var(--paper);
  transform: rotate(-2deg);
  transition: transform 0.45s cubic-bezier(.2,.8,.2,1);
  text-decoration: none;
}
@container lwcover (min-width: 640px) {
  #lw-cover-dogstar .lw-merch-promo__art {
    width: 100%;
    max-width: 240px;
  }
}
#lw-cover-dogstar .lw-merch-promo__art img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
@media (hover: hover) {
  #lw-cover-dogstar .lw-merch-promo__art:hover {
    transform: rotate(0deg) scale(1.03);
  }
}
#lw-cover-dogstar .lw-merch-promo__body {
  min-width: 0;
}
#lw-cover-dogstar .lw-merch-promo__kicker {
  display: inline-block;
  font-family: var(--font-accent);
  font-size: clamp(14px, 2cqi, 18px);
  color: var(--paper);
  margin-bottom: 4px;
  transform: rotate(-1.5deg);
}
#lw-cover-dogstar .lw-merch-promo__title {
  font-family: var(--font-display);
  font-weight: 900;
  font-style: italic;
  font-size: clamp(24px, 4.6cqi, 40px);
  line-height: 0.95;
  text-transform: uppercase;
  margin: 0 0 10px;
  color: var(--paper);
}
#lw-cover-dogstar .lw-merch-promo__blurb {
  font-size: clamp(14px, 1.8cqi, 16px);
  line-height: 1.45;
  margin: 0 0 clamp(14px, 2cqi, 20px);
  color: var(--paper);
  opacity: 0.92;
  max-width: 44ch;
  text-wrap: pretty; /* avoid lone-word orphans on the last line */
}
#lw-cover-dogstar .lw-merch-promo__row {
  display: flex;
  flex-wrap: wrap;
  gap: 14px 18px;
  align-items: center;
  justify-content: center;
}
#lw-cover-dogstar .lw-merch-promo__code {
  display: inline-block;
  font-family: var(--font-display);
  font-weight: 900;
  font-style: italic;
  font-size: clamp(20px, 3cqi, 28px);
  letter-spacing: 0.06em;
  color: var(--lw-red);
  background: var(--paper);
  padding: 10px 18px;
  border: 2px dashed var(--ink);
  box-shadow: 4px 4px 0 var(--ink);
}
/* The merch CTA is a button-style anchor; it must NOT inherit the chapter
   body's underlined-link treatment when embedded inside a chapter. */
#lw-cover-dogstar a.lw-merch-promo__cta,
#lw-cover-dogstar a.lw-merch-promo__cta:hover {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: var(--font-body);
  font-weight: 800;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--lw-red);
  background: var(--paper);
  padding: 14px 22px;
  text-decoration: none;
  box-shadow: 4px 4px 0 var(--ink);
  transition: transform 0.2s, box-shadow 0.2s;
}
#lw-cover-dogstar .lw-merch-promo__cta-arrow {
  display: inline-block;
  transition: transform 0.25s;
  text-decoration: none;
}
/* Also strip underline from the album-art anchor wrapping the image. */
#lw-cover-dogstar a.lw-merch-promo__art,
#lw-cover-dogstar a.lw-merch-promo__art:hover,
#lw-cover-dogstar a.lw-merch__art,
#lw-cover-dogstar a.lw-merch__art:hover {
  text-decoration: none;
}
@media (hover: hover) {
  #lw-cover-dogstar .lw-merch-promo__cta:hover {
    transform: translate(-2px, -2px);
    box-shadow: 6px 6px 0 var(--ink);
  }
  #lw-cover-dogstar .lw-merch-promo__cta:hover .lw-merch-promo__cta-arrow {
    transform: translateX(4px);
  }
}

/* ---------- MERCH / ALBUM CTA ---------- */
#lw-cover-dogstar .lw-merch {
  position: relative;
  background: var(--ink);
  color: var(--paper);
  padding: clamp(48px, 7cqi, 80px) clamp(20px, 5cqi, 48px);
  overflow: hidden;
}
#lw-cover-dogstar .lw-merch::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(circle at 30% 30%, rgba(225,38,28,0.18) 0%, transparent 55%);
  pointer-events: none;
}
#lw-cover-dogstar .lw-merch__inner {
  position: relative;
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(28px, 4cqi, 48px);
  align-items: center;
  max-width: 880px;
  margin: 0 auto;
  text-align: center;
}
@container lwcover (min-width: 640px) {
  #lw-cover-dogstar .lw-merch__inner {
    grid-template-columns: minmax(180px, 280px) 1fr;
    text-align: left;
  }
}
#lw-cover-dogstar .lw-merch__art {
  display: block;
  position: relative;
  width: clamp(180px, 40cqi, 280px);
  margin: 0 auto;
  aspect-ratio: 1 / 1;
  background: #1a1a1a;
  box-shadow: 0 24px 48px rgba(0,0,0,0.55), 0 0 0 1px rgba(255,255,255,0.06);
  transform: rotate(-2deg);
  transition: transform 0.45s cubic-bezier(.2,.8,.2,1);
  text-decoration: none;
}
#lw-cover-dogstar .lw-merch__art img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
#lw-cover-dogstar .lw-merch__body {
  min-width: 0;
}
#lw-cover-dogstar .lw-merch__kicker {
  display: inline-block;
  font-family: var(--font-accent);
  font-size: clamp(14px, 2cqi, 20px);
  color: var(--lw-red);
  margin-bottom: 8px;
  transform: rotate(-1.5deg);
}
#lw-cover-dogstar .lw-merch__title {
  font-family: var(--font-display);
  font-weight: 900;
  font-style: italic;
  font-size: clamp(32px, 7cqi, 64px);
  line-height: 0.95;
  text-transform: uppercase;
  margin: 0 0 16px;
  color: var(--paper);
}
#lw-cover-dogstar .lw-merch__blurb {
  font-size: clamp(15px, 2.1cqi, 18px);
  line-height: 1.6;
  margin: 0 0 clamp(20px, 3cqi, 28px);
  color: var(--paper-dim);
}
#lw-cover-dogstar .lw-merch__cta {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: var(--font-body);
  font-weight: 800;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--paper);
  background: var(--lw-red);
  padding: 14px 24px;
  text-decoration: none;
  box-shadow: 4px 4px 0 var(--paper);
  transition: transform 0.2s, box-shadow 0.2s;
}
#lw-cover-dogstar .lw-merch__cta-arrow {
  display: inline-block;
  transition: transform 0.25s;
}
@media (hover: hover) {
  #lw-cover-dogstar .lw-merch__art:hover {
    transform: rotate(0deg) scale(1.02);
  }
  #lw-cover-dogstar .lw-merch__cta:hover {
    transform: translate(-2px, -2px);
    box-shadow: 6px 6px 0 var(--paper);
  }
  #lw-cover-dogstar .lw-merch__cta:hover .lw-merch__cta-arrow {
    transform: translateX(4px);
  }
}

/* ---------- Hover micro-interactions ---------- */
#lw-cover-dogstar .lw-glitch {
  display: inline-block;
  position: relative;
  transition: text-shadow 0.15s;
}
#lw-cover-dogstar .lw-glitch:hover {
  text-shadow:
    2px 0 0 var(--lw-red),
    -2px 0 0 #00f2ff,
    0 0 12px rgba(255,26,107,0.4);
  animation: lw-shake 0.3s linear infinite;
}
@keyframes lw-shake {
  0%,100% { transform: translate(0,0); }
  25%     { transform: translate(-1px, 1px); }
  50%     { transform: translate(1px, -1px); }
  75%     { transform: translate(-1px, -1px); }
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion: reduce) {
  #lw-cover-dogstar *,
  #lw-cover-dogstar *::before,
  #lw-cover-dogstar *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
  }
  #lw-cover-dogstar .lw-dek p,
  #lw-cover-dogstar .lw-chapter p {
    opacity: 1 !important;
    transform: none !important;
  }
}

/* ==========================================================================
 * Host page safety — prevent horizontal scroll caused by anything the cover
 * story renders. Scoped via :has() so it only activates on pages that
 * actually contain the component.
 * ========================================================================== */

html:has(#lw-cover-dogstar),
body:has(#lw-cover-dogstar) {
  overflow-x: clip;
  max-width: 100%;
}

#lw-cover-dogstar iframe,
#lw-cover-dogstar video,
#lw-cover-dogstar embed,
#lw-cover-dogstar object {
  max-width: 100%;
}

/* ==========================================================================
 * Townsquare WordPress Specific Styles
 * DO NOT REMOVE — required overrides for the host theme on Townsquare blogs.
 * These rules intentionally target the WP theme (not #lw-cover-dogstar) so
 * they fall outside the component's scope.
 * ========================================================================== */

section, .divider, .footer-inner {
  z-index: 0;
}

/* Primis sticky video ad player — anchor to the bottom of the viewport on
   mobile (default positioning collides with the cover story's hero / sticky
   elements). The Primis/Sekindo script applies inline `top` styling, so we
   need !important to override. The container ID's numeric suffix changes
   per page load, so we match the stable prefix with an attribute selector. */
[id^="primis_container_div_"] > div:first-child {
  bottom: 50px !important;
  top: unset !important;
}

.main-content > .wrapper.post-wrapper .content {
  padding: 0px;
}

.page-header, h1.article, h2.article {
  display: none;
}

.mobile .post .content-wrap, .mobile .main-content > .wrapper.post-wrapper .content, body {
  padding: 0px;
}

.mainContent article {
  background-color: unset;
}

.main-aside.carbon-post-sidebar {
  display: none;
}

.site-content main#main-content {
  border-right: 0;
}

html.layout-clean .container-inner {
  padding: 0px;
}

/* Keep the podcast source div hidden until our JS moves its contents */
#lw-podcast-source {
  display: none !important;
  visibility: hidden !important;
  height: 0 !important;
  overflow: hidden !important;
}

/* ==========================================================================
 * Townsquare Mobile App Specific Styles
 * DO NOT REMOVE — required overrides for the Townsquare mobile app webview.
 * The app wraps content in .mainContent (not .pod-content). It always renders
 * at "mobile" look regardless of webview width. The component's own CSS is
 * scoped to #lw-cover-dogstar and uses container queries (cqi), so it
 * auto-adapts. These rules handle the app's host page environment.
 *
 * See APP-CSS-HANDOFF.md for full documentation on dual-environment CSS.
 * ========================================================================== */

/* Reset the app's content wrapper padding so the component goes edge-to-edge */
.mainContent {
  padding: 0 !important;
}
.mainContent article {
  background-color: unset;
}

/* App view duplicates the lead image as a figure.article-thumbnail at the top
   of the article; the cover hero already serves that role, so hide the first
   one in the app only. The figure sits OUTSIDE .mainContent, so we scope to
   the html.lw-is-app class the cover JS adds when it detects the app webview. */
html.lw-is-app figure.article-thumbnail:first-of-type {
  display: none !important;
}

/* Overflow containment — same as the WP rules but without :has() fallback
   for older webview engines that may not support :has(). The WP :has() rules
   above also cover the app if :has() is supported; these are belt-and-suspenders. */
.mainContent {
  overflow-x: clip;
  max-width: 100%;
}

/* Force the component to fill the app wrapper */
.mainContent #lw-cover-dogstar {
  margin: 0;
  border-radius: 0;
  width: 100%;
  max-width: 100%;
}

/* Hide hovers in the app — touch devices get phantom hover on first tap.
   Wrap in @media (hover: hover) so only real pointer devices get hover effects. */
@media (hover: none) {
  #lw-cover-dogstar .lw-gallery__item:hover {
    transform: rotate(var(--r, 0deg));
    box-shadow: 0 18px 36px rgba(0,0,0,0.45);
    z-index: 1;
  }
  #lw-cover-dogstar .lw-chapter__photo:hover {
    transform: rotate(-2deg);
  }
  #lw-cover-dogstar .lw-glitch:hover {
    text-shadow: none;
    animation: none;
  }
}

/* The TV and radio should always be full-width in the app */
.mainContent #lw-cover-dogstar .lw-tv,
.mainContent #lw-cover-dogstar .lw-radio {
  max-width: 100%;
}

/* Hide speakers on small app webviews to maximize player space */
.mainContent #lw-cover-dogstar .lw-radio__speaker {
  display: none;
}
