/**
 * TeenSerie Interactions & Components
 * Additional styles for interactive elements
 * 
 * @package TeenSerie
 */

/* ========================================
   BANNER ADV SECTION
   ======================================== */

.banner-adv {
  position: relative;
  background: linear-gradient(to right, rgba(163, 230, 53, 0.2), rgba(139, 92, 246, 0.2));
  border-radius: var(--radius-2xl);
  height: 6rem;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--color-slate-700);
}

body.dark-mode .banner-adv {
  color: var(--color-slate-300);
}

.banner-adv .shimmer {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent);
  background-size: 200% 100%;
  animation: shimmer 2.5s infinite;
}

@keyframes shimmer {
  0% {
    background-position: 200% 0;
  }
  100% {
    background-position: -200% 0;
  }
}

/* ========================================
   SERIE HERO SECTION
   ======================================== */

.serie-hero {
  position: relative;
  border-radius: var(--radius-3xl, 1.5rem);
  overflow: hidden;
  box-shadow: var(--shadow-2xl);
}

.serie-hero-bg {
  position: absolute;
  inset: 0;
  background-color: var(--color-slate-900);
}

body.dark-mode .serie-hero-bg {
  background-color: var(--color-slate-900);
}

.serie-hero-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.serie-hero-bg img.loaded {
  opacity: 1;
}

.serie-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(15, 23, 42, 0.7) 0%, rgba(0, 0, 0, 0.5) 50%, rgba(0, 0, 0, 0.2) 100%);
}

.serie-hero-content {
  position: relative;
  z-index: 10;
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 2rem;
  align-items: center;
}

@media (min-width: 1024px) {
  .serie-hero-content {
    flex-direction: row;
    padding: 2rem 3rem 3rem;
    align-items: flex-start;
    padding-top: 6rem;
  }
}

.serie-poster {
  width: 100%;
  max-width: 200px;
  flex-shrink: 0;
}

@media (min-width: 1024px) {
  .serie-poster {
    width: 16rem;
    max-width: none;
  }
}

.serie-poster img {
  width: 100%;
  border-radius: var(--radius-2xl);
  box-shadow: var(--shadow-2xl);
}

.serie-info {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  text-align: center;
}

@media (min-width: 1024px) {
  .serie-info {
    text-align: left;
  }
}

.serie-title {
  font-size: 1.875rem;
  font-weight: var(--font-weight-black);
  color: var(--color-slate-900);
  margin-bottom: 0.75rem;
  line-height: 1.2;
}

body.dark-mode .serie-title {
  color: white;
}

@media (min-width: 768px) {
  .serie-title {
    font-size: 3rem;
    color: white;
  }
}

.serie-year {
  font-weight: var(--font-weight-normal);
  color: var(--color-slate-500);
  font-size: 1.5rem;
  vertical-align: middle;
}

body.dark-mode .serie-year {
  color: var(--color-slate-400);
}

@media (min-width: 768px) {
  .serie-year {
    font-size: 1.875rem;
    color: var(--color-slate-300);
  }
}

.serie-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  justify-content: center;
  margin-bottom: 1rem;
}

@media (min-width: 1024px) {
  .serie-badges {
    justify-content: flex-start;
  }
}

.badge-type {
  padding: 0.375rem 0.75rem;
  border-radius: var(--radius-full);
  font-size: 0.875rem;
  font-weight: var(--font-weight-bold);
  background: linear-gradient(135deg, #8b5cf6, #7c3aed);
  color: white;
}

.badge-status {
  padding: 0.375rem 0.75rem;
  border-radius: var(--radius-full);
  font-size: 0.875rem;
  font-weight: var(--font-weight-bold);
  background: linear-gradient(135deg, var(--color-accent-teal), #0d9488);
  color: white;
}

.badge-age {
  padding: 0.375rem 0.75rem;
  border-radius: var(--radius-full);
  font-size: 0.875rem;
  font-weight: var(--font-weight-bold);
  background: linear-gradient(135deg, #f59e0b, #d97706);
  color: white;
}

/* Serie meta item - for runtime, etc. without badge background */
.serie-meta-item {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  font-size: 0.875rem;
  color: white;
}

.serie-meta-item svg {
  flex-shrink: 0;
}

/* Network Badge - text only with dynamic colors */
.badge-network {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.375rem 0.75rem;
  border-radius: var(--radius-full);
  font-size: 0.875rem;
  color: white;
  /* Default color - grey/slate (overridden by inline style) */
  background-color: #64748b;
  white-space: nowrap;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.badge-network:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

/* "Su" prefix */
.badge-network-prefix {
  font-weight: var(--font-weight-normal);
  opacity: 0.9;
}

/* Network name */
.badge-network-name {
  font-weight: var(--font-weight-bold);
}

/* Netflix */
.badge-network[data-network="netflix"] {
  background: linear-gradient(135deg, #e50914, #b20710);
}

/* Disney+ / Disney Plus */
.badge-network[data-network="disney"],
.badge-network[data-network="disney-plus"],
.badge-network[data-network="disney-channel"] {
  background: linear-gradient(135deg, #113ccf, #0d2d9e);
}

/* Amazon Prime Video */
.badge-network[data-network="amazon-prime-video"],
.badge-network[data-network="prime-video"],
.badge-network[data-network="amazon"] {
  background: linear-gradient(135deg, #00a8e1, #007eb0);
}

/* HBO / Max */
.badge-network[data-network="hbo"],
.badge-network[data-network="hbo-max"],
.badge-network[data-network="max"] {
  background: linear-gradient(135deg, #5822b4, #3d1880);
}

/* Apple TV+ */
.badge-network[data-network="apple-tv"],
.badge-network[data-network="apple-tv-plus"] {
  background: linear-gradient(135deg, #555555, #333333);
}

/* Hulu */
.badge-network[data-network="hulu"] {
  background: linear-gradient(135deg, #1ce783, #17b869);
  color: #0b3016;
}

/* Paramount+ */
.badge-network[data-network="paramount"],
.badge-network[data-network="paramount-plus"] {
  background: linear-gradient(135deg, #0064ff, #0050cc);
}

/* Peacock */
.badge-network[data-network="peacock"] {
  background: linear-gradient(135deg, #f7c31f, #d4a617);
  color: #1a1a1a;
}

/* Showtime */
.badge-network[data-network="showtime"] {
  background: linear-gradient(135deg, #c1112c, #960b22);
}

/* FX */
.badge-network[data-network="fx"],
.badge-network[data-network="fxx"] {
  background: linear-gradient(135deg, #f7941d, #d4790f);
  color: #1a1a1a;
}

/* NBC */
.badge-network[data-network="nbc"] {
  background: linear-gradient(135deg, #ff6600, #cc5200);
}

/* CBS */
.badge-network[data-network="cbs"] {
  background: linear-gradient(135deg, #1a1aff, #1313cc);
}

/* ABC */
.badge-network[data-network="abc"] {
  background: linear-gradient(135deg, #39b54a, #2d903b);
}

/* FOX */
.badge-network[data-network="fox"] {
  background: linear-gradient(135deg, #ffd200, #ccaa00);
  color: #1a1a1a;
}

/* The CW */
.badge-network[data-network="the-cw"],
.badge-network[data-network="cw"] {
  background: linear-gradient(135deg, #00a651, #008542);
}

/* AMC */
.badge-network[data-network="amc"] {
  background: linear-gradient(135deg, #d32f2f, #a82828);
}

/* Starz */
.badge-network[data-network="starz"] {
  background: linear-gradient(135deg, #ffd600, #ccab00);
  color: #1a1a1a;
}

/* Nickelodeon */
.badge-network[data-network="nickelodeon"],
.badge-network[data-network="nick"] {
  background: linear-gradient(135deg, #ff6600, #e55b00);
}

/* Cartoon Network */
.badge-network[data-network="cartoon-network"] {
  background: linear-gradient(135deg, #00bcd4, #0097a7);
}

/* MTV */
.badge-network[data-network="mtv"] {
  background: linear-gradient(135deg, #ffcc00, #cca300);
  color: #1a1a1a;
}

/* USA Network */
.badge-network[data-network="usa-network"],
.badge-network[data-network="usa"] {
  background: linear-gradient(135deg, #0057b8, #004693);
}

/* TBS */
.badge-network[data-network="tbs"] {
  background: linear-gradient(135deg, #ff0000, #cc0000);
}

/* TNT */
.badge-network[data-network="tnt"] {
  background: linear-gradient(135deg, #d71920, #ab141a);
}

/* Freeform */
.badge-network[data-network="freeform"] {
  background: linear-gradient(135deg, #8e44ad, #713688);
}

/* A&E */
.badge-network[data-network="ae"],
.badge-network[data-network="a-e"] {
  background: linear-gradient(135deg, #ffc107, #d9a306);
  color: #1a1a1a;
}

/* History */
.badge-network[data-network="history"] {
  background: linear-gradient(135deg, #c69c2e, #9e7d25);
}

/* Syfy */
.badge-network[data-network="syfy"] {
  background: linear-gradient(135deg, #ffca05, #d9ab04);
  color: #1a1a1a;
}

/* Comedy Central */
.badge-network[data-network="comedy-central"] {
  background: linear-gradient(135deg, #f9a825, #c78e1e);
  color: #1a1a1a;
}

/* Discovery */
.badge-network[data-network="discovery"],
.badge-network[data-network="discovery-plus"] {
  background: linear-gradient(135deg, #0077cc, #005fa3);
}

/* BBC */
.badge-network[data-network="bbc"],
.badge-network[data-network="bbc-one"],
.badge-network[data-network="bbc-two"],
.badge-network[data-network="bbc-america"],
.badge-network[data-network="bbc-iplayer"] {
  background: linear-gradient(135deg, #bb1919, #961414);
}

/* ITV */
.badge-network[data-network="itv"],
.badge-network[data-network="itv1"],
.badge-network[data-network="itv2"] {
  background: linear-gradient(135deg, #00a0d2, #0080a8);
}

/* Channel 4 */
.badge-network[data-network="channel-4"] {
  background: linear-gradient(135deg, #2f2f2f, #1a1a1a);
}

/* Sky */
.badge-network[data-network="sky"],
.badge-network[data-network="sky-atlantic"],
.badge-network[data-network="sky-one"] {
  background: linear-gradient(135deg, #0072c6, #005a9e);
}

/* Netflix anime-style networks */
.badge-network[data-network="crunchyroll"] {
  background: linear-gradient(135deg, #f47521, #c35e1a);
}

.badge-network[data-network="funimation"] {
  background: linear-gradient(135deg, #5b0bb5, #490991);
}

/* RAI (Italian) */
.badge-network[data-network="rai"],
.badge-network[data-network="rai-1"],
.badge-network[data-network="rai-2"],
.badge-network[data-network="rai-3"] {
  background: linear-gradient(135deg, #004aad, #003b8a);
}

/* Mediaset (Italian) */
.badge-network[data-network="mediaset"],
.badge-network[data-network="canale-5"],
.badge-network[data-network="italia-1"],
.badge-network[data-network="rete-4"] {
  background: linear-gradient(135deg, #ff0066, #cc0052);
}

/* Network inline - next to title */
.network-inline {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 1rem;
  color: var(--color-slate-500);
  margin-left: 0.75rem;
  font-weight: 500;
  vertical-align: middle;
}

.network-name {
  font-weight: var(--font-weight-bold);
  color: var(--color-slate-800);
  position: relative;
}

.network-name::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 100%;
  height: 2px;
  background: linear-gradient(90deg, var(--color-primary-lime), var(--color-accent-teal));
  border-radius: 1px;
}

body.dark-mode .network-inline {
  color: var(--color-slate-400);
}

body.dark-mode .network-name {
  color: white;
}

@media (min-width: 768px) {
  .network-inline {
    font-size: 1.25rem;
    color: var(--color-slate-300);
  }
  
  .network-name {
    color: white;
  }
}

.serie-genres {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  justify-content: center;
}

@media (min-width: 1024px) {
  .serie-genres {
    justify-content: flex-start;
  }
}

.genre-badge {
  padding: 0.375rem 0.75rem;
  border-radius: var(--radius-full);
  font-size: 0.875rem;
  font-weight: var(--font-weight-bold);
  background-color: var(--color-slate-200);
  color: var(--color-slate-800);
}

body.dark-mode .genre-badge {
  background: rgba(30,41,59,0.6);
  color: white !important;
  border: 1px solid rgba(255,255,255,0.08);
}
}
}

@media (min-width: 768px) {
  .genre-badge {
    border: 1px solid rgba(203, 213, 225, 0.5);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    background: rgba(241, 245, 249, 0.7);
    border-color: rgba(203, 213, 225, 0.5);
  }
  
  body.dark-mode .genre-badge {
    background: rgba(255, 255, 255, 0.1);
    color: white;
    border-color: rgba(255, 255, 255, 0.2);
  }
}

.serie-overview {
  text-align: left;
  background-color: rgba(226, 232, 240, 0.8);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-radius: var(--radius-xl);
  padding: 1rem;
}

body.dark-mode .serie-overview {
  background-color: rgba(30, 41, 59, 0.8);
}

@media (min-width: 768px) {
  .serie-overview {
    background-color: rgba(241, 245, 249, 0.7);
    padding: 1.5rem;
  }
  
  body.dark-mode .serie-overview {
    background-color: rgba(0, 0, 0, 0.4);
  }
}

.serie-overview h2 {
  font-weight: var(--font-weight-bold);
  font-size: 1.25rem;
  color: var(--color-slate-900);
  margin-bottom: 0.5rem;
}

body.dark-mode .serie-overview h2 {
  color: white;
}

.serie-overview p {
  color: var(--color-slate-700);
  line-height: 1.6;
}

body.dark-mode .serie-overview p {
  color: var(--color-slate-300);
}

.serie-hero-fade {
  display: none;
}

@media (min-width: 768px) {
  .serie-hero-fade {
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 10rem;
    background: linear-gradient(to top, var(--color-slate-50), transparent);
  }
  
  body.dark-mode .serie-hero-fade {
    background: linear-gradient(to top, var(--color-slate-900), transparent);
  }
}

/* ========================================
   REACTIONS SECTION
   ======================================== */

.reactions-container {
  border-radius: var(--radius-2xl);
  padding: 1.5rem;
}

.reactions-grid {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: 0.5rem;
  flex-wrap: wrap;
}

@media (min-width: 640px) {
  .reactions-grid {
    gap: 1rem;
  }
}

.reaction-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  width: 5rem;
  text-align: center;
}

.reaction-btn {
  width: 4rem;
  height: 4rem;
  font-size: 2.5rem;
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition-base);
  border: 2px solid var(--color-slate-200);
  background-color: white;
  cursor: pointer;
}

body.dark-mode .reaction-btn {
  background-color: var(--color-slate-700);
  border-color: var(--color-slate-600);
}

.reaction-btn:hover {
  transform: scale(1.1);
  border-color: var(--color-primary-lime);
}

.reaction-btn:active {
  transform: scale(0.95);
}

.reaction-btn.active {
  border-color: var(--color-primary-lime);
  border-width: 3px;
  transform: scale(1.05);
}

.reaction-count {
  font-weight: var(--font-weight-bold);
  font-size: 0.875rem;
  color: var(--color-slate-700);
}

body.dark-mode .reaction-count {
  color: var(--color-slate-300);
}

/* ========================================
   SECTION HEADERS
   ======================================== */

.section-header {
  position: relative;
  display: inline-block;
  font-size: 1.5rem;
  font-weight: 900;
  padding: 0.75rem 1.5rem;
  clip-path: polygon(0 0, 95% 0, 100% 100%, 0% 100%);
}

@media (min-width: 768px) {
  .section-header {
    font-size: 1.875rem;
  }
}

.section-header svg {
  display: inline-block;
  width: 1.5rem;
  height: 1.5rem;
  margin-right: 0.5rem;
  vertical-align: middle;
}

/* ========================================
   CAST SECTION
   ======================================== */

.section-header.teal {
  background-color: var(--color-accent-teal);
  color: white;
}

.section-header.purple {
  background-color: var(--color-secondary-purple);
  color: white;
}

.section-header.pink {
  background-color: var(--color-accent-pink);
  color: white;
}

.section-header.orange {
  background-color: var(--color-accent-orange);
  color: white;
}

.section-header.lime {
  background-color: var(--color-primary-lime);
  color: var(--color-slate-900);
}

.cast-scroll-wrapper {
  position: relative;
}

 .cast-scroll-btn {
  position: absolute;
  top: 35%;
  transform: translateY(-35%);
  z-index: 20;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: var(--radius-full);
  background-color: rgba(0, 0, 0, 0.3);
  color: white;
  border: none;
  cursor: pointer;
  display: none; /* Hidden by default on mobile */
  align-items: center;
  justify-content: center;
  transition: all var(--transition-base);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

@media (min-width: 640px) {
  .cast-scroll-btn {
    width: 3rem;
    height: 3rem;
  }
}

/* Show buttons only on desktop (>= 1024px) */
@media (min-width: 1024px) {
  .cast-scroll-btn {
    display: flex;
  }
}

.cast-scroll-btn:hover {
  background-color: rgba(0, 0, 0, 0.5);
}

.cast-scroll-btn.hidden {
  opacity: 0;
  pointer-events: none;
}

.cast-scroll-left {
  left: -0.5rem;
}

.cast-scroll-right {
  right: -0.5rem;
}

@media (min-width: 640px) {
  .cast-scroll-left {
    left: 0;
  }
  .cast-scroll-right {
    right: 0;
  }
}

.cast-container {
  display: flex;
  gap: 1.5rem;
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding: 0 2.5rem 1rem 0;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  touch-action: pan-x;
  overscroll-behavior-x: contain;
}

@media (min-width: 640px) {
  .cast-container {
    padding: 0 0 1rem 0;
  }
}

.cast-container::-webkit-scrollbar {
  display: none;
}

@media (min-width: 768px) {
  .cast-container {
    gap: 2rem;
  }
}

.cast-member {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  flex-shrink: 0;
  width: 8rem;
}

.cast-member img {
  width: 6rem;
  height: 6rem;
  border-radius: var(--radius-full);
  object-fit: cover;
  box-shadow: var(--shadow-lg);
  margin-bottom: 0.75rem;
}

.cast-member h3 {
  font-weight: var(--font-weight-bold);
  font-size: 1rem;
  color: var(--color-slate-900);
  margin-bottom: 0.25rem;
}

body.dark-mode .cast-member h3 {
  color: white;
}

.cast-member p {
  font-size: 0.875rem;
  color: var(--color-slate-500);
}

body.dark-mode .cast-member p {
  color: var(--color-slate-400);
}

.cast-placeholder {
  width: 6rem;
  height: 6rem;
  border-radius: var(--radius-full);
  background-color: #1e293b;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-lg);
  margin-bottom: 0.75rem;
}

body.dark-mode .cast-placeholder {
  background-color: rgba(30, 41, 59, 0.8);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.cast-placeholder-icon {
  color: #475569;
  opacity: 0.5;
}

/* ========================================
   EPISODES SECTION
   ======================================== */

.season-item {
  background-color: white;
  border-radius: 0.75rem;
  overflow: hidden;
  box-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
  transition: all 0.3s;
}

body.dark-mode .season-item {
  background-color: rgba(30, 41, 59, 0.8);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.season-toggle {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem;
  text-align: left;
  font-weight: 700;
  color: #0f172a;
  font-size: 1.125rem;
  line-height: 1.75rem;
  border: none;
  cursor: pointer;
  background: transparent;
  transition: background-color 0.15s;
}

body.dark-mode .season-toggle {
  color: white;
}

.season-toggle:hover {
  background-color: #f8fafc;
}

body.dark-mode .season-toggle:hover {
  background-color: rgba(255, 255, 255, 0.05);
}

.season-chevron {
  width: 1.5rem;
  height: 1.5rem;
  transition: transform 0.3s;
  transform: rotate(-180deg);
}

.season-item.collapsed .season-chevron {
  transform: rotate(0deg);
}

.season-content {
  display: grid;
  grid-template-rows: 1fr;
  opacity: 1;
  transition: all 0.3s ease-in-out;
}

.season-item.collapsed .season-content {
  grid-template-rows: 0fr;
  opacity: 0;
}

.season-content > div {
  overflow: hidden;
}

.seasons-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.episodes-container {
  padding: 1rem;
  border-top: 1px solid #e2e8f0;
}

body.dark-mode .episodes-container {
  border-top-color: rgba(255, 255, 255, 0.1);
}

.episodes-list {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.episodes-empty {
  color: #94a3b8;
  text-align: center;
  padding: 2rem 0;
}

/* Episode cards */
.episode-item {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  align-items: flex-start;
}

@media (min-width: 640px) {
  .episode-item {
    flex-direction: row;
  }
}

.episode-thumb {
  width: 100%;
  border-radius: 0.5rem;
  box-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1);
  aspect-ratio: 16 / 9;
  object-fit: cover;
}

@media (min-width: 640px) {
  .episode-thumb {
    width: 12rem;
  }
}

.episode-placeholder {
  width: 100%;
  border-radius: 0.5rem;
  box-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1);
  aspect-ratio: 16 / 9;
  background-color: #1e293b;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
}

@media (min-width: 640px) {
  .episode-placeholder {
    width: 12rem;
  }
}

.episode-placeholder-icon {
  color: #475569;
  opacity: 0.5;
}

.episode-placeholder-badge {
  font-size: 0.75rem;
  font-weight: 600;
  color: #94a3b8;
  background: rgba(0, 0, 0, 0.3);
  padding: 0.25rem 0.5rem;
  border-radius: 0.25rem;
}

.episode-info {
  flex: 1;
}

.episode-title {
  font-weight: 700;
  font-size: 1.125rem;
  line-height: 1.75rem;
  color: #0f172a;
}

body.dark-mode .episode-title {
  color: white;
}

.episode-overview {
  color: #475569;
  font-size: 0.875rem;
  margin-top: 0.25rem;
  margin-bottom: 0.75rem;
}

body.dark-mode .episode-overview {
  color: #94a3b8;
}

.episode-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1rem 1rem;
  font-size: 0.75rem;
  color: #64748b;
}

body.dark-mode .episode-meta {
  color: #94a3b8;
}

.episode-meta-item {
  display: flex;
  align-items: center;
  gap: 0.25rem;
}

/* Binge Watch Info Box */
.binge-watch-info {
  margin-top: 2rem;
  padding: 1.5rem 1rem;
  text-align: center;
}

.binge-watch-main {
  font-size: 1.125rem;
  color: var(--color-slate-600);
  margin: 0 0 0.75rem 0;
  line-height: 1.6;
}

body.dark-mode .binge-watch-main {
  color: var(--color-slate-400);
}

.binge-watch-main .binge-time {
  color: var(--color-primary-lime);
  font-weight: 600;
}

.binge-watch-main .binge-title {
  color: var(--color-slate-900);
  font-weight: 600;
}

body.dark-mode .binge-watch-main .binge-title {
  color: white;
}

.binge-watch-stats {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  font-size: 0.875rem;
  color: var(--color-slate-500);
  margin: 0;
}

.binge-watch-stats span {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
}

.binge-watch-stats svg {
  opacity: 0.6;
}

.binge-separator {
  opacity: 0.3;
}

@media (min-width: 640px) {
  .episode-thumb {
    width: 12rem;
  }
}

.episode-info {
  flex: 1;
}

.episode-title {
  font-weight: var(--font-weight-bold);
  font-size: 1.125rem;
  color: var(--color-slate-900);
  margin-bottom: 0.25rem;
}

body.dark-mode .episode-title {
  color: white;
}

.episode-overview {
  color: var(--color-slate-600);
  font-size: 0.875rem;
  margin-top: 0.25rem;
  margin-bottom: 0.75rem;
  line-height: 1.5;
}

body.dark-mode .episode-overview {
  color: var(--color-slate-400);
}

.episode-meta {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.75rem;
  color: var(--color-slate-500);
}

body.dark-mode .episode-meta {
  color: var(--color-slate-400);
}

.no-episodes {
  padding: 2rem;
  text-align: center;
  color: var(--color-slate-500);
}

body.dark-mode .no-episodes {
  color: var(--color-slate-400);
}

/* ========================================
   ACTION BUTTONS
   ======================================== */

.action-btn {
  width: 36px;
  height: 36px;
  border-radius: var(--radius-full);
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.2);
  cursor: pointer;
  transition: all var(--transition-base);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-slate-100);
  padding: 0;
}

.action-btn:hover {
  background: rgba(255, 255, 255, 0.2);
  transform: scale(1.1);
}

.action-btn.active {
  background: var(--color-primary-lime);
  border-color: var(--color-primary-lime);
  color: var(--color-slate-900);
}

.action-btn svg {
  width: 20px;
  height: 20px;
  transition: all var(--transition-base);
}

.favorite-btn.active svg {
  fill: var(--color-slate-900);
}

.watchlist-btn.active svg {
  transform: rotate(45deg);
}

/* ========================================
   SCROLL CONTROLS
   ======================================== */

.scroll-btn:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}

.scroll-btn:disabled:hover {
  transform: none;
  background: rgba(163, 230, 53, 0.1);
}

/* ========================================
   POLL STYLES
   ======================================== */

.poll-option.active {
  background: linear-gradient(135deg, var(--color-primary-lime), var(--color-secondary-purple));
  color: white;
  transform: scale(1.05);
  box-shadow: var(--shadow-xl);
  border-color: transparent;
}

.poll-option .check-icon {
  margin-left: 0.5rem;
  animation: checkmark 0.3s ease-in-out;
}

@keyframes checkmark {
  0% {
    opacity: 0;
    transform: scale(0);
  }
  50% {
    transform: scale(1.2);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}

/* ========================================
   CONTENT CARD ENHANCEMENTS
   ======================================== */

.content-card-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, transparent 0%, rgba(0, 0, 0, 0.9) 100%);
  opacity: 0;
  transition: opacity var(--transition-base);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: var(--spacing-md);
  border-radius: var(--radius-lg);
}

.content-card:hover .content-card-overlay {
  opacity: 1;
}

.content-card-actions {
  display: flex;
  gap: 0.5rem;
  justify-content: flex-end;
}

.content-card-body {
  padding: var(--spacing-sm) 0;
}

.content-card-title {
  font-size: 0.875rem;
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
  margin-bottom: 0.25rem;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.content-card-meta {
  font-size: 0.75rem;
  color: var(--color-text-secondary);
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
}

.content-card-meta .year {
  font-weight: var(--font-weight-semibold);
}

.content-card-meta .genres {
  opacity: 0.8;
}

.content-card-link {
  text-decoration: none;
  color: inherit;
  display: block;
}

/* ========================================
   BADGE STYLES
   ======================================== */

.badge {
  display: inline-block;
  padding: 0.25rem 0.5rem;
  font-size: 0.625rem;
  font-weight: var(--font-weight-black);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  border-radius: var(--radius-sm);
  line-height: 1;
}

.badge.age-rating {
  background-color: var(--color-accent-orange);
  color: white;
  position: absolute;
  top: var(--spacing-sm);
  right: var(--spacing-sm);
  z-index: 10;
  box-shadow: var(--shadow-md);
}

/* ========================================
   CTA SECTION
   ======================================== */

.cta-section {
  text-align: center;
  margin-top: var(--spacing-2xl);
  padding-top: var(--spacing-2xl);
  border-top: 1px solid var(--color-slate-200);
}

body.dark-mode .cta-section {
  border-top-color: var(--color-slate-700);
}

.cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.875rem 2rem;
  font-size: 0.875rem;
  font-weight: var(--font-weight-bold);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-slate-900);
  background: var(--color-primary-lime);
  border: none;
  border-radius: var(--radius-full);
  cursor: pointer;
  transition: all var(--transition-base);
  text-decoration: none;
  box-shadow: var(--shadow-lg);
}

.cta-btn:hover {
  background: var(--color-primary-lime-dark, #8fd614);
  transform: translateY(-2px);
  box-shadow: var(--shadow-2xl);
}

/* ========================================
   BLOG CARD STYLES
   ======================================== */

.blog-card-image {
  width: 100%;
  height: 200px;
  object-fit: cover;
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}

.blog-card-content {
  padding: var(--spacing-md);
}

.blog-card-title a {
  color: var(--color-text-primary);
  text-decoration: none;
  transition: color var(--transition-base);
}

.blog-card-title a:hover {
  color: var(--color-primary-lime);
}

.blog-card-meta {
  font-size: 0.75rem;
  color: var(--color-text-secondary);
  margin-top: 0.5rem;
}

/* ========================================
   RESPONSIVE ADJUSTMENTS
   ======================================== */

@media (max-width: 767px) {
  .content-card-overlay {
    opacity: 1;
    background: linear-gradient(to bottom, transparent 50%, rgba(0, 0, 0, 0.9) 100%);
  }
  
  .content-card-actions {
    opacity: 0;
    transition: opacity var(--transition-base);
  }
  
  .content-card:active .content-card-actions {
    opacity: 1;
  }
}


.action-btn {
  width: 36px;
  height: 36px;
  border-radius: var(--radius-full);
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.2);
  cursor: pointer;
  transition: all var(--transition-base);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-slate-100);
  padding: 0;
}

.action-btn:hover {
  background: rgba(255, 255, 255, 0.2);
  transform: scale(1.1);
}

.action-btn.active {
  background: var(--color-primary-lime);
  border-color: var(--color-primary-lime);
  color: var(--color-slate-900);
}

.action-btn svg {
  width: 20px;
  height: 20px;
  transition: all var(--transition-base);
}

.favorite-btn.active svg {
  fill: var(--color-slate-900);
}

.watchlist-btn.active svg {
  transform: rotate(45deg);
}

/* ========================================
   SCROLL CONTROLS
   ======================================== */

.scroll-btn:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}

.scroll-btn:disabled:hover {
  transform: none;
  background: rgba(163, 230, 53, 0.1);
}

/* ========================================
   POLL STYLES
   ======================================== */

.poll-option.active {
  background: linear-gradient(135deg, var(--color-primary-lime), var(--color-secondary-purple));
  color: white;
  transform: scale(1.05);
  box-shadow: var(--shadow-xl);
  border-color: transparent;
}

.poll-option .check-icon {
  margin-left: 0.5rem;
  animation: checkmark 0.3s ease-in-out;
}

@keyframes checkmark {
  0% {
    opacity: 0;
    transform: scale(0);
  }
  50% {
    transform: scale(1.2);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}

/* ========================================
   CONTENT CARD ENHANCEMENTS
   ======================================== */

.content-card-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, transparent 0%, rgba(0, 0, 0, 0.9) 100%);
  opacity: 0;
  transition: opacity var(--transition-base);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: var(--spacing-md);
  border-radius: var(--radius-lg);
}

.content-card:hover .content-card-overlay {
  opacity: 1;
}

.content-card-actions {
  display: flex;
  gap: 0.5rem;
  justify-content: flex-end;
}

.content-card-body {
  padding: var(--spacing-sm) 0;
}

.content-card-title {
  font-size: 0.875rem;
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
  margin-bottom: 0.25rem;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.content-card-meta {
  font-size: 0.75rem;
  color: var(--color-text-secondary);
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
}

.content-card-meta .year {
  font-weight: var(--font-weight-semibold);
}

.content-card-meta .genres {
  opacity: 0.8;
}

.content-card-link {
  text-decoration: none;
  color: inherit;
  display: block;
}

/* ========================================
   BADGE STYLES
   ======================================== */

.badge {
  display: inline-block;
  padding: 0.25rem 0.5rem;
  font-size: 0.625rem;
  font-weight: var(--font-weight-black);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  border-radius: var(--radius-sm);
  line-height: 1;
}

.badge.age-rating {
  background-color: var(--color-accent-orange);
  color: white;
  position: absolute;
  top: var(--spacing-sm);
  right: var(--spacing-sm);
  z-index: 10;
  box-shadow: var(--shadow-md);
}

/* ========================================
   CTA SECTION
   ======================================== */

.cta-section {
  text-align: center;
  margin-top: var(--spacing-2xl);
  padding-top: var(--spacing-2xl);
  border-top: 1px solid var(--color-slate-200);
}

body.dark-mode .cta-section {
  border-top-color: var(--color-slate-700);
}

.cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.875rem 2rem;
  font-size: 0.875rem;
  font-weight: var(--font-weight-bold);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-slate-900);
  background: var(--color-primary-lime);
  border: none;
  border-radius: var(--radius-full);
  cursor: pointer;
  transition: all var(--transition-base);
  text-decoration: none;
  box-shadow: var(--shadow-lg);
}

.cta-btn:hover {
  background: var(--color-primary-lime-dark, #8fd614);
  transform: translateY(-2px);
  box-shadow: var(--shadow-2xl);
}

/* ========================================
   BLOG CARD STYLES
   ======================================== */

.blog-card-image {
  width: 100%;
  height: 200px;
  object-fit: cover;
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}

.blog-card-content {
  padding: var(--spacing-md);
}

.blog-card-title a {
  color: var(--color-text-primary);
  text-decoration: none;
  transition: color var(--transition-base);
}

.blog-card-title a:hover {
  color: var(--color-primary-lime);
}

.blog-card-meta {
  font-size: 0.75rem;
  color: var(--color-text-secondary);
  margin-top: 0.5rem;
}

/* ========================================
   RESPONSIVE ADJUSTMENTS
   ======================================== */

@media (max-width: 767px) {
  .content-card-overlay {
    opacity: 1;
    background: linear-gradient(to bottom, transparent 50%, rgba(0, 0, 0, 0.9) 100%);
  }
  
  .content-card-actions {
    opacity: 0;
    transition: opacity var(--transition-base);
  }
  
  .content-card:active .content-card-actions {
    opacity: 1;
  }
}

/* ========================================
   CONTENT SECTIONS
   ======================================== */

.content-section {
  background-color: var(--color-slate-50);
  border-radius: var(--radius-2xl);
  box-shadow: var(--shadow-lg);
}

body.dark-mode .content-section {
  background-color: var(--color-slate-800);
}

.content-section .container {
  max-width: 100%;
}

/* ========================================
   HOMEPAGE STYLES
   ======================================== */

.hero-banner {
  position: relative;
  min-height: 300px;
  background: linear-gradient(135deg, var(--color-slate-900), var(--color-slate-800));
  border-radius: var(--radius-2xl);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

.hero-placeholder {
  text-align: center;
  padding: 4rem 2rem;
}

.hero-title {
  font-size: 3rem;
  font-weight: 800;
  color: white;
  margin-bottom: 1rem;
}

.hero-title .logo-accent {
  color: var(--color-lime);
}

.hero-subtitle {
  font-size: 1.25rem;
  color: var(--color-slate-400);
}

.section-header-wrapper {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1.5rem;
}

.view-all-link {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-lime);
  text-decoration: none;
  transition: color 0.2s ease;
}

.view-all-link:hover {
  color: #bef264;
}

/* Header Language Switcher alignment */
.header-lang-switcher {
  margin-left: 0.5rem;
}

.header-lang-switcher .teenlang-list {
  gap: 0.25rem;
}

.header-lang-switcher .teenlang-link {
  padding: 0.25rem 0.5rem;
  font-size: 0.75rem;
}
