/* =========================================
   HORROR FIGHT — CLEAN NEON THEME (168 LINES)
   ========================================= */
@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&display=swap');
@import url('https://cdn.jsdelivr.net/npm/swiper@11/swiper-bundle.min.css');

:root {
  --bg: #0B0B0F;
  --surface: #11121A;
  --border: #1B1D27;
  --text: #E8E8EE;
  --muted: #A9A9B6;
  --pink: #FF2E9A;
  --cyan: #4DE2FF;
}

/* BASE */
body, .site, .site-content, .ast-container, .wp-site-blocks {
  background: var(--bg) !important;
  color: var(--text);
  font-family: sans-serif;
  margin: 0;
}
a { color: var(--cyan); text-decoration: none; }
a:hover { color: var(--pink); text-shadow: 0 0 8px rgba(255,46,154,.8); }

/* HEADER */
.main-header-bar, .site-header, .ast-mobile-header-wrap {
  background: var(--surface) !important;
  border-bottom: 1px solid var(--border);
}

/* HEADINGS */
h1, h2, h3, .wp-block-heading, .wp-block-post-title, .hf-title-glow {
  color: #fff !important;
  text-align: center;
  text-shadow:
    0 0 10px rgba(255,46,154,1),
    0 0 22px rgba(255,46,154,.9),
    0 0 34px rgba(255,46,154,.65);
  margin: .5rem 0 1rem;
  font-family: 'Bebas Neue', sans-serif;
  text-transform: uppercase;
  letter-spacing: .05em;
}

/* BUTTONS */
.wp-block-button__link, .more-link, .hf-listen-btn, .btn {
  display: inline-block;
  padding: .6rem 1.2rem;
  border-radius: 12px;
  background: linear-gradient(90deg, var(--cyan), var(--pink));
  color: #fff !important;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  box-shadow: 0 0 12px rgba(77,226,255,.3);
  transition: all .2s ease;
}
.wp-block-button__link:hover, .more-link:hover, .hf-listen-btn:hover, .btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 0 18px rgba(77,226,255,.55), 0 0 22px rgba(255,46,154,.35);
}

/* LATEST EPISODE */
.hf-hero, .hf-clean-hero { text-align: center; margin: 2rem auto; max-width: 620px; }
.hf-hero img, .hero img { width: 100%; max-width: 620px; border-radius: 16px; box-shadow: 0 0 20px rgba(0,0,0,.7); }
.hf-hero h2, .hero h2 { margin: 1rem 0 .5rem; font-size: clamp(1.9rem, 5vw, 2.6rem); }
.hf-hero-meta { color: var(--muted); font-size: .9rem; text-transform: uppercase; }

/* CAROUSEL */
.hf-carousel, .hf-clean-carousel { margin: 2rem auto; padding: 0 1rem; }
.swiper { padding-bottom: 2.5rem; }
.swiper-slide { background: var(--surface); border-radius: 16px; overflow: hidden; box-shadow: 0 8px 20px rgba(0,0,0,.6); }
.card a, .swiper-slide a { display: block; color: inherit; text-decoration: none; }
.card img, .swiper-slide img { width: 100%; height: 180px; object-fit: cover; border-radius: 16px; }
.card h3, .swiper-slide h3 { margin: 1rem; font-size: 1.4rem; text-align: center; color: #fff; }
.card p, .swiper-slide p { margin: 0 1rem 1rem; color: var(--muted); font-size: .9rem; text-align: center; }
.card span, .swiper-slide span { display: block; background: linear-gradient(90deg, var(--cyan), var(--pink)); color: #fff; padding: .7rem; font-weight: bold; text-align: center; }

/* PAGINATION */
.swiper-pagination-bullet { background: #666; }
.swiper-pagination-bullet-active { background: var(--pink); }

/* ICONS */
.hf-icon-links { text-align: center; margin: 2rem auto; }
.hf-icon-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; }
.hf-icon { background: var(--surface); border: 1px solid var(--border); border-radius: 14px; padding: .6rem; text-align: center; }
.hf-icon img { width: 64px; height: 64px; filter: drop-shadow(0 0 6px rgba(77,226,255,.45)); }
.hf-icon:hover img { filter: drop-shadow(0 0 10px rgba(77,226,255,.7)); }

/* RESPONSIVE */
@media (max-width: 768px) {
  .hf-icon-grid { grid-template-columns: repeat(3, 1fr); }
  .swiper-slide img { height: 160px; }
}
/* TEMP TEST PAGE CSS — DARK NEON */
body { background: #0B0B0F; color: #E8E8EE; }
h2 { text-shadow: 0 0 10px #FF2E9A; font-family: 'Bebas Neue', sans-serif; text-transform: uppercase; }
.carousel-card {
    padding: 1.2rem;
    background: #11121A;
    border-radius: 18px;
    box-shadow: 0 10px 25px rgba(0,0,0,.7);
}
.swiper-container { padding: 0 1rem 3rem; }
/* FINAL CAROUSEL POLISH */
.swiper-container {
  padding: 0 1rem 3.5rem !important;
}
.carousel-card {
  background: #11121A;
  border-radius: 20px;
  padding: 1.4rem;
  box-shadow: 0 12px 30px rgba(0,0,0,.7);
  transition: transform .2s ease;
}
.carousel-card:hover {
  transform: translateY(-4px);
}
.swiper-pagination {
  bottom: 8px !important;
}
.swiper-pagination-bullet {
  width: 11px;
  height: 11px;
  background: #555;
}
.swiper-pagination-bullet-active {
  background: #FF2E9A;
  box-shadow: 0 0 12px #FF2E9A;
}
/* ICON WALL — SMALLER ICONS + 4x4 GRID */
.hf-icon-wall { text-align: center; margin: 2rem 0; padding: 0 1rem; }
.icon-grid { 
  display: grid; 
  grid-template-columns: repeat(4, 1fr); 
  gap: 0.8rem; 
  max-width: 800px; 
  margin: 0 auto; 
}
.icon-item { 
  background: #11121A; 
  border: 1px solid #1B1D27; 
  border-radius: 16px; 
  padding: 0.6rem; 
  transition: all .2s ease; 
}
.icon-item img { 
  width: 40px; height: 40px; object-fit: contain; 
  filter: drop-shadow(0 0 6px rgba(77,226,255,.5)); 
}
.icon-item:hover, .icon-item:focus { 
  transform: translateY(-4px); 
  border-color: #4DE2FF; 
  box-shadow: 0 0 20px rgba(77,226,255,.4); 
}
.icon-item:hover img { 
  filter: drop-shadow(0 0 12px #4DE2FF); 
}
.icon-item span { 
  display: none; /* Icons only */
}
/* FINAL GLOW — ALL SECTIONS */
.hf-card-cta, 
.icon-item img,
.swiper-slide .card span {
  filter: drop-shadow(0 0 8px #FF2E9A) !important;
  transition: filter .2s ease !important;
}
.hf-card-cta:hover, 
.icon-item:hover img,
.swiper-slide:hover .card span {
  filter: drop-shadow(0 0 16px #FF2E9A) !important;
}
/* EMAIL SIGNUP */
.hf-email-signup {
  background: #11121A;
  border: 2px solid #1B1D27;
  border-radius: 18px;
  padding: 1.5rem;
  margin: 2rem auto;
  max-width: 500px;
  text-align: center;
  box-shadow: 0 0 30px rgba(255,46,154,.2);
}
.hf-email-signup p {
  color: #E8E8EE;
  margin: 0 0 1rem;
}
.hf-email-signup input {
  width: 70%;
  padding: .8rem;
  border-radius: 12px;
  border: none;
  background: #222;
  color: #fff;
  margin-right: .5rem;
}
.hf-email-signup .btn {
  background: linear-gradient(90deg, #4DE2FF, #FF2E9A);
  padding: .8rem 1.5rem;
  font-weight: bold;
  border: none;
  border-radius: 12px;
  cursor: pointer;
}
.hf-email-signup .note {
  font-size: .8rem;
  color: #ccc;
  margin-top: .5rem;
}
/* SMOOTH SWIPE FIX */
.swiper-wrapper {
  transition-timing-function: linear !important;  // No jerk on right swipe
}
.swiper-slide {
  transition: transform .3s ease;  // Smooth slide movement
}
.swiper-slide img {
  transition: none !important;  // No lag on images
}
.swiper-container { padding-bottom: 2.5rem; }
/* SINGLE POST — BLACK BG */
.single-post,
.single-post .site,
.single-post .site-content,
.single-post .content-area,
.single-post .ast-container,
.single-post .ast-article-single,
.single-post .entry-content,
.single-post .post,
.single-post .wp-site-blocks {
  background: var(--bg, #0B0B0F) !important;
  color: var(--text, #E8E8EE) !important;
}
.single-post .entry-content p,
.single-post .entry-content li {
  color: var(--text, #E8E8EE) !important;
}
.single-post a {
  color: var(--cyan, #4DE2FF) !important;
}
.single-post a:hover {
  color: var(--pink, #FF2E9A) !important;
  text-shadow: 0 0 8px rgba(255,46,154,.8) !important;
}
.single-post .wp-post-image {
  border-radius: 12px;
  box-shadow: 0 0 12px rgba(0,0,0,.6);
}
/* CONTENDER POSTERS — SWIPE-ABLE */
.hf-contenders-row {
  display: flex;
  gap: .8rem;
  overflow-x: auto;
  padding: .2rem .75rem;
  margin: 0 -0.75rem;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
  scroll-snap-type: x mandatory;
}
.hf-contenders-row::-webkit-scrollbar {
  display: none;
}
.hf-contender {
  flex: 0 0 58vw;
  max-width: 58vw;
  background: #11121A;
  border: 1px solid #1B1D27;
  border-radius: 16px;
  box-shadow: 0 0 12px rgba(0,0,0,.55);
  scroll-snap-align: start;
  transition: transform .18s ease;
}
.hf-contender img {
  width: 100%;
  height: auto;
  border-radius: 16px;
  aspect-ratio: 2 / 3;
  object-fit: cover;
}
.hf-contender:hover {
  transform: translateY(-2px);
  border-color: rgba(77,226,255,.45);
}
@media (min-width: 600px) {
  .hf-contender { min-width: 40vw; max-width: 40vw; }
}
@media (min-width: 1024px) {
  .hf-contenders-row { overflow: visible; flex-wrap: wrap; justify-content: center; margin: 0; }
  .hf-contender { min-width: 200px; max-width: 200px; margin: .25rem; }
}