@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

/* Clean Cinematic Design System — built on your current React structure */

:root {
  --bg-primary: #070707;
  --bg-elevated: #0d0d0e;
  --bg-card: #111112;
  --bg-surface: #171719;

  --text-primary: #f7f7f5;
  --text-secondary: rgba(247, 247, 245, 0.58);
  --text-tertiary: rgba(247, 247, 245, 0.34);

  --accent: #ffffff;
  --accent-hover: #e8e8e4;
  --accent-muted: rgba(255, 255, 255, 0.075);
  --accent-border: rgba(255, 255, 255, 0.12);
  --accent-glow: rgba(255, 255, 255, 0.12);

  /* Compatibility aliases for existing components */
  --bg-overlay: rgba(0, 0, 0, 0.72);
  --bg-overlay-mid: rgba(0, 0, 0, 0.5);
  --bg-overlay-end: rgba(0, 0, 0, 0.18);

  --glass-bg: rgba(10, 10, 10, 0.74);
  --glass-border: rgba(255, 255, 255, 0.075);
  --glass-border-hover: rgba(255, 255, 255, 0.16);
  --glass-highlight: inset 0 1px 0 rgba(255, 255, 255, 0.045);

  --font-display: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-body: var(--font-display);
  --font-mono: 'SF Mono', 'Fira Code', 'Cascadia Code', monospace;

  --ease-out-expo: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-spring: cubic-bezier(0.32, 0.72, 0, 1);
  --ease-smooth: cubic-bezier(0.25, 0.1, 0.25, 1);
  --duration-fast: 0.18s;
  --duration-normal: 0.32s;
  --duration-slow: 0.62s;
  --duration-reveal: 0.8s;

  --space-xs: 0.5rem;
  --space-sm: 1rem;
  --space-md: 1.5rem;
  --space-lg: clamp(2rem, 4vw, 3.5rem);
  --space-xl: clamp(3rem, 7vw, 5.5rem);
  --space-2xl: clamp(4rem, 10vw, 8rem);

  --radius-sm: 10px;
  --radius-md: 14px;
  --radius-lg: 20px;
  --radius-xl: 28px;
  --radius-full: 9999px;

  --shadow-sm: 0 4px 16px rgba(0, 0, 0, 0.28);
  --shadow-md: 0 12px 36px rgba(0, 0, 0, 0.36);
  --shadow-lg: 0 24px 70px rgba(0, 0, 0, 0.5);
  --shadow-glow: 0 16px 55px rgba(255, 255, 255, 0.065);

  --gradient-accent: linear-gradient(135deg, #ffffff, #d7d7d2);
  --bg-dark: var(--bg-primary);
  --bg-darker: var(--bg-elevated);
  --text-main: var(--text-primary);

  --content-max-width: 1440px;
  --header-height: 4.75rem;
  --mobile-nav-height: 4.25rem;

  --z-base: 1;
  --z-header: 1000;
  --z-drawer: 50;
  --z-modal: 60;
  --z-toast: 80;

  --player-control-size: 2.75rem;
  --player-control-size-mobile: 3rem;
  --player-overlay-z: 20;
  --gradient-player-top: linear-gradient(180deg, rgba(0,0,0,0.78), transparent);
  --gradient-player-bottom: linear-gradient(0deg, rgba(0,0,0,0.88), transparent);
  --gradient-page: var(--bg-primary);
}

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

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; background: var(--bg-primary); }

body {
  font-family: var(--font-display);
  background:
    radial-gradient(circle at 50% -12%, rgba(255,255,255,0.085), transparent 30%),
    linear-gradient(180deg, #0b0b0b 0%, var(--bg-primary) 42%, #050505 100%);
  color: var(--text-primary);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
  position: relative;
}

body::before {
  content: '';
  position: fixed;
  inset: 0;
  z-index: -2;
  pointer-events: none;
  background:
    linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.018) 1px, transparent 1px);
  background-size: 72px 72px;
  -webkit-mask-image: linear-gradient(to bottom, transparent 0%, black 18%, black 72%, transparent 100%);
  mask-image: linear-gradient(to bottom, transparent 0%, black 18%, black 72%, transparent 100%);
  opacity: 0.28;
}

body::after {
  content: '';
  position: fixed;
  top: auto;
  bottom: -25%;
  left: auto;
  right: -10%;
  width: 48vw;
  height: 48vw;
  z-index: -1;
  pointer-events: none;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(255,255,255,0.045), transparent 62%);
  filter: blur(80px);
}

a { color: inherit; text-decoration: none; transition: color var(--duration-fast) var(--ease-spring); }

button { cursor: pointer; border: none; background: none; font-family: inherit; transition: all var(--duration-normal) var(--ease-spring); }

img { display: block; max-width: 100%; }

.glass, .glass-strong {
  background: var(--glass-bg);
  backdrop-filter: blur(26px) saturate(145%);
  -webkit-backdrop-filter: blur(26px) saturate(145%);
  border: 1px solid var(--glass-border);
  box-shadow: var(--glass-highlight), var(--shadow-sm);
}

.container { max-width: 1440px; margin: 0 auto; padding: 0 4%; }

::-webkit-scrollbar { width: 5px; height: 5px; }

::-webkit-scrollbar-track { background: transparent; }

::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.12); border-radius: var(--radius-full); }

::-webkit-scrollbar-thumb:hover { background: rgba(255,255,255,0.22); }

#root { display: flex; flex-direction: column; min-height: 100vh; }

.main-content { flex: 1; padding-top: 0; }

@media (max-width: 1024px) { .main-content { padding-bottom: var(--mobile-nav-height); } }

.btn, .btn-primary, .btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.55rem;
  min-height: 48px;
  padding: 0.76rem 1.35rem;
  border-radius: var(--radius-full);
  font-weight: 700;
  letter-spacing: -0.015em;
}

.btn-primary {
  color: #060606;
  background: #f5f5f1;
  border: 1px solid rgba(255,255,255,0.2);
  box-shadow: 0 18px 46px rgba(255,255,255,0.08);
}

.btn-primary:hover { transform: translateY(-2px); background: #fff; }

.btn-secondary {
  color: var(--text-primary);
  background: rgba(255,255,255,0.055);
  border: 1px solid rgba(255,255,255,0.085);
}

.btn-secondary:hover { background: rgba(255,255,255,0.09); transform: translateY(-2px); }

.skeleton {
  background: linear-gradient(90deg, rgba(255,255,255,0.035), rgba(255,255,255,0.08), rgba(255,255,255,0.035));
  background-size: 240% 100%;
  animation: skeletonShimmer 1.5s ease-in-out infinite;
}

@keyframes skeletonShimmer { from { background-position: 100% 0; } to { background-position: -100% 0; } }

@keyframes revealUp { from { opacity: 0; transform: translateY(24px); } to { opacity: 1; transform: translateY(0); } }

@keyframes revealScale { from { opacity: 0; transform: scale(0.98); } to { opacity: 1; transform: scale(1); } }

@keyframes pulseGlow { 0%,100% { opacity: 0.55; } 50% { opacity: 1; } }

.animate-fade-in { animation: revealUp 0.72s var(--ease-out-expo) both; }
/* Azu — Premium Separated Navbar */
.navbar {
  position: sticky;
  top: 0;
  left: auto;
  transform: none;
  width: 100%;
  z-index: var(--z-header);
  display: flex;
  justify-content: center;
  padding: 0.75rem 0 0.55rem;
  background: linear-gradient(180deg, rgba(7,7,7,0.98), rgba(7,7,7,0.86) 68%, rgba(7,7,7,0.3));
  transition:
    padding var(--duration-normal) var(--ease-spring),
    background var(--duration-normal) var(--ease-spring);
}

.navbar-container {
  position: relative;
  width: min(94%, 1220px);
  min-height: 64px;
  padding: 0.55rem 1.2rem 0.55rem 0.72rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.8rem;
  border: 1px solid rgba(255,255,255,0.085);
  border-radius: 999px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.07), rgba(255,255,255,0.02)),
    rgba(7,7,7,0.78);
  backdrop-filter: blur(30px) saturate(150%);
  -webkit-backdrop-filter: blur(30px) saturate(150%);
  box-shadow:
    0 18px 60px rgba(0,0,0,0.34),
    inset 0 1px 0 rgba(255,255,255,0.065),
    inset 0 -1px 0 rgba(255,255,255,0.025);
  overflow: visible;
}

.navbar-container::before {
  content: '';
  position: absolute;
  inset: 1px;
  border-radius: inherit;
  pointer-events: none;
  background: linear-gradient(90deg, rgba(255,255,255,0.06), transparent 32%, rgba(255,255,255,0.035));
  opacity: 0.75;
}

.navbar.scrolled {
  padding: 0.45rem 0 0.42rem;
  background: linear-gradient(180deg, rgba(7,7,7,0.98), rgba(7,7,7,0.9));
}

.navbar.scrolled .navbar-container {
  min-height: 58px;
  background: rgba(7,7,7,0.9);
  box-shadow:
    0 12px 46px rgba(0,0,0,0.52),
    inset 0 1px 0 rgba(255,255,255,0.06);
}

.brand {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  gap: 0.72rem;
  color: white;
  flex-shrink: 0;
  padding-right: 0.85rem;
}

.brand-logo {
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  background: linear-gradient(180deg, #fff, #dcdcd7);
  box-shadow:
    0 10px 28px rgba(255,255,255,0.08),
    inset 0 1px 0 rgba(255,255,255,0.65);
  overflow: hidden;
  animation: logoPopIn 0.8s cubic-bezier(0.175, 0.885, 0.32, 1.275) forwards, logoPulse 4s infinite ease-in-out 1.5s;
}

@keyframes logoPopIn {
  0% { transform: scale(0) rotate(-45deg); opacity: 0; }
  60% { transform: scale(1.12) rotate(10deg); opacity: 1; }
  100% { transform: scale(1) rotate(0); opacity: 1; }
}

@keyframes logoPulse {
  0% { transform: scale(1); box-shadow: 0 10px 28px rgba(255,255,255,0.08), inset 0 1px 0 rgba(255,255,255,0.65); }
  50% { transform: scale(1.08); box-shadow: 0 14px 38px rgba(255,255,255,0.25), inset 0 1px 0 rgba(255,255,255,0.9); }
  100% { transform: scale(1); box-shadow: 0 10px 28px rgba(255,255,255,0.08), inset 0 1px 0 rgba(255,255,255,0.65); }
}

.brand-logo svg {
  width: 40px;
  height: 40px;
}

.brand-logo svg rect {
  fill: transparent;
}

.brand-logo svg path {
  fill: #050505;
}

.brand-text {
  font-size: 1.1rem;
  font-weight: 800;
  letter-spacing: -0.055em;
}

.brand-text::after {
  content: 'stream';
  margin-left: 0.18rem;
  color: rgba(255,255,255,0.4);
  font-weight: 600;
  letter-spacing: -0.045em;
}

.nav-links {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0.22rem 0.35rem;
  border-radius: var(--radius-full);
  background: rgba(255,255,255,0.026);
  border: 1px solid rgba(255,255,255,0.035);
  margin-right: 1.2rem;
}

.nav-links a {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  color: rgba(247,247,245,0.58);
  font-size: 0.82rem;
  font-weight: 650;
  padding: 0.55rem 0.82rem;
  border-radius: var(--radius-full);
  transition:
    color var(--duration-fast) var(--ease-spring),
    background var(--duration-fast) var(--ease-spring),
    transform var(--duration-fast) var(--ease-spring);
}

.nav-links a:hover {
  color: #fff;
  background: rgba(255,255,255,0.075);
  transform: translateY(-1px);
}

.search-form {
  position: relative;
  width: 190px;
  transition: width var(--duration-normal) var(--ease-spring);
}

.search-form:focus-within {
  width: 285px;
}

.search-input-wrapper {
  position: relative;
  width: 100%;
}

.search-input-wrapper input {
  width: 100%;
  height: 42px;
  padding: 0 2.1rem 0 2.45rem;
  border-radius: var(--radius-full);
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.048);
  color: var(--text-primary);
  outline: none;
  font-size: 0.84rem;
  font-family: var(--font-display);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.035);
}

.search-input-wrapper input::placeholder {
  color: rgba(255,255,255,0.32);
}

.search-input-wrapper input:focus {
  border-color: rgba(255,255,255,0.2);
  background: rgba(255,255,255,0.075);
  box-shadow:
    0 0 0 4px rgba(255,255,255,0.035),
    inset 0 1px 0 rgba(255,255,255,0.05);
}

.search-icon {
  position: absolute;
  left: 0.9rem;
  top: 50%;
  transform: translateY(-50%);
  color: rgba(255,255,255,0.38);
}

.clear-search-btn {
  position: absolute;
  right: 0.7rem;
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-tertiary);
  width: 24px;
  height: 24px;
  padding: 4px;
  display: grid;
  place-items: center;
  border-radius: 50%;
}

.clear-search-btn:hover {
  color: var(--text-primary);
  background: rgba(255,255,255,0.08);
}

.navbar-actions {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  gap: 0.6rem;
}

.search-mobile {
  display: none;
}

.mobile-menu-btn {
  display: none;
  width: 42px;
  height: 42px;
  place-items: center;
  border-radius: 999px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.09);
  color: var(--text-primary);
}

.search-suggestions {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  width: min(390px, 92vw);
  background: rgba(12,12,12,0.96);
  backdrop-filter: blur(34px) saturate(150%);
  -webkit-backdrop-filter: blur(34px) saturate(150%);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 24px;
  overflow: hidden;
  box-shadow:
    0 28px 90px rgba(0,0,0,0.66),
    inset 0 1px 0 rgba(255,255,255,0.06);
  z-index: 100;
  display: flex;
  flex-direction: column;
  animation: revealScale 0.18s var(--ease-spring);
}

.suggestion-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 11px 12px;
  cursor: pointer;
  border-bottom: 1px solid rgba(255,255,255,0.045);
  transition: background var(--duration-fast) var(--ease-spring);
}

.suggestion-item:hover {
  background: rgba(255,255,255,0.06);
}

.suggestion-img {
  width: 38px;
  height: 56px;
  object-fit: cover;
  border-radius: 10px;
  flex-shrink: 0;
}

.suggestion-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.suggestion-title {
  font-size: 0.86rem;
  font-weight: 700;
  color: var(--text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.suggestion-type {
  font-size: 0.72rem;
  color: var(--text-tertiary);
}

.suggestion-view-all {
  padding: 13px;
  text-align: center;
  color: var(--text-primary);
  font-weight: 700;
  font-size: 0.82rem;
  background: rgba(255,255,255,0.04);
}

.suggestion-view-all:hover {
  background: rgba(255,255,255,0.075);
}

@media (max-width: 1120px) {
  .nav-links a { padding-inline: 0.62rem; }
  .search-form { width: 168px; }
  .search-form:focus-within { width: 230px; }
}

@media (max-width: 992px) {
  .navbar {
    padding: 0.5rem 0 0.45rem;
  }

  .navbar.scrolled {
    padding: 0.38rem 0 0.38rem;
  }

  .navbar-container {
    width: calc(100% - 1.5rem);
    min-height: 58px;
    padding: 0.48rem 0.55rem;
    border-radius: 22px;
    gap: 0.55rem;
  }

  .brand {
    gap: 0.5rem;
    padding-right: 0;
  }

  .brand-logo,
  .brand-logo svg {
    width: 36px;
    height: 36px;
  }

  .brand-text {
    font-size: 1rem;
  }

  .nav-links {
    position: fixed;
    top: 4.35rem;
    left: 0.75rem;
    right: 0.75rem;
    bottom: auto;
    display: grid;
    grid-template-columns: 1fr;
    align-items: stretch;
    justify-content: start;
    gap: 0.35rem;
    padding: 0.75rem;
    border-radius: 24px;
    border: 1px solid rgba(255,255,255,0.09);
    background: rgba(8,8,8,0.94);
    backdrop-filter: blur(34px) saturate(150%);
    -webkit-backdrop-filter: blur(34px) saturate(150%);
    box-shadow: 0 28px 80px rgba(0,0,0,0.58), inset 0 1px 0 rgba(255,255,255,0.055);
    transform: translateY(-12px) scale(0.98);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition:
      opacity var(--duration-normal) var(--ease-spring),
      visibility var(--duration-normal) var(--ease-spring),
      transform var(--duration-normal) var(--ease-spring);
    z-index: 998;
  }

  .nav-links.mobile-open {
    transform: translateY(0) scale(1);
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }

  .nav-links a {
    width: 100%;
    min-height: 46px;
    justify-content: space-between;
    padding: 0.75rem 0.95rem;
    font-size: 0.98rem;
    font-weight: 750;
    color: rgba(255,255,255,0.76);
    background: rgba(255,255,255,0.035);
    border: 1px solid rgba(255,255,255,0.04);
    border-radius: 16px;
  }

  .nav-links a:hover {
    color: #fff;
    background: rgba(255,255,255,0.075);
    transform: none;
  }

  .search-pc {
    display: none;
  }

  .navbar-actions {
    flex: 1;
    min-width: 0;
  }

  .search-mobile {
    display: block;
    width: 100%;
    max-width: 260px;
    margin-left: auto;
    margin-top: 0;
  }

  .search-mobile:focus-within {
    width: 100%;
  }

  .search-mobile .search-input-wrapper input {
    height: 40px;
    font-size: 0.82rem;
    padding-left: 2.25rem;
  }

  .mobile-menu-btn {
    display: grid;
    flex-shrink: 0;
    position: relative;
    z-index: 999;
    width: 40px;
    height: 40px;
  }
}

@media (max-width: 480px) {
  .navbar-container {
    padding: 0.5rem 0.6rem;
  }

  .brand-text::after {
    display: none;
  }

  .search-suggestions {
    right: auto;
    left: 0;
    width: min(330px, calc(100vw - 2rem));
  }
}
/* Clean Mobile Bottom Navigation */
.mobile-nav { display: none; }
@media (max-width: 1024px) {
  .mobile-nav { position: fixed; left: 0; right: 0; bottom: 0; z-index: var(--z-header); display: grid; grid-template-columns: repeat(4, 1fr); height: var(--mobile-nav-height); padding-bottom: env(safe-area-inset-bottom, 0); border-top: 1px solid rgba(255,255,255,0.075); background: rgba(8,8,8,0.88); backdrop-filter: blur(24px) saturate(150%); -webkit-backdrop-filter: blur(24px) saturate(150%); }
  .mobile-nav__item { position: relative; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 0.22rem; color: var(--text-tertiary); text-decoration: none; font-size: 0.62rem; font-weight: 650; letter-spacing: 0.02em; padding: 0.4rem 0; min-height: 44px; -webkit-tap-highlight-color: transparent; }
  .mobile-nav__item:hover { color: var(--text-primary); background: rgba(255,255,255,0.04); }
  .mobile-nav__item.is-active { color: var(--text-primary); }
  .mobile-nav__item.is-active::after { content: ''; position: absolute; top: 0; left: 50%; transform: translateX(-50%); width: 24px; height: 2px; border-radius: 0 0 2px 2px; background: #fff; box-shadow: 0 0 12px rgba(255,255,255,0.14); }
}
/* Azu — Premium Clean Cinematic Hero */
.hero {
  position: relative;
  min-height: min(880px, 100dvh);
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  background: #050505;
  isolation: isolate;
}

.hero::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 6;
  pointer-events: none;
  background:
    radial-gradient(circle at 18% 70%, rgba(255,255,255,0.075), transparent 22%),
    radial-gradient(circle at 72% 28%, rgba(255,255,255,0.035), transparent 26%),
    linear-gradient(90deg, rgba(0,0,0,0.55), transparent 48%, rgba(0,0,0,0.4));
  mix-blend-mode: screen;
  opacity: 0.68;
}

.hero::after {
  content: '';
  position: absolute;
  left: 4%;
  right: 4%;
  bottom: 0;
  height: 1px;
  z-index: 14;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.16), transparent);
}

.hero-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 1.05s var(--ease-smooth);
  pointer-events: none;
}

.hero-slide.active {
  opacity: 1;
  pointer-events: auto;
  z-index: 1;
}

.hero-backdrop {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
}

.hero-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 20%;
  opacity: 0.82;
  transform: scale(1.02);
  filter: saturate(0.82) contrast(1.12) brightness(0.78);
  transition:
    opacity 1.4s var(--ease-smooth),
    transform 13s var(--ease-smooth),
    filter 1.4s var(--ease-smooth);
}

.hero-slide.active .hero-image {
  transform: scale(1.085);
}

.hero-image.idle-fade {
  opacity: 0;
}

.hero-overlay {
  position: absolute;
  inset: 0;
  z-index: 5;
  background:
    linear-gradient(to top,
      #070707 0%,
      rgba(7,7,7,0.98) 10%,
      rgba(7,7,7,0.82) 29%,
      rgba(7,7,7,0.35) 57%,
      rgba(7,7,7,0.58) 100%
    ),
    linear-gradient(to right,
      rgba(7,7,7,0.9) 0%,
      rgba(7,7,7,0.54) 30%,
      rgba(7,7,7,0.1) 62%,
      rgba(7,7,7,0.45) 100%
    );
  transition: opacity 1.4s var(--ease-smooth);
}

.hero-overlay.idle-fade {
  opacity: 0;
}

.hero-content {
  position: relative;
  z-index: 9;
  width: 100%;
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 4% clamp(5.8rem, 10dvh, 8rem);
  transition: opacity 1s var(--ease-spring);
}

.hero-content::before {
  content: 'AZU ORIGINAL';
  display: inline-flex;
  margin-bottom: 1.05rem;
  color: rgba(255,255,255,0.42);
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}

.hero-content.idle-fade {
  opacity: 0;
  pointer-events: none;
}

.hero-tags {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  margin-bottom: 1rem;
}

.hero-badge,
.hero-type-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.42rem;
  padding: 0.48rem 0.82rem;
  border-radius: var(--radius-full);
  font-size: 0.66rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
}

.hero-badge {
  color: #060606;
  background: linear-gradient(180deg, #ffffff, #d9d9d3);
  box-shadow: 0 18px 45px rgba(255,255,255,0.11), inset 0 1px 0 rgba(255,255,255,0.7);
}

.hero-badge::before {
  content: '';
  width: 5px;
  height: 5px;
  border-radius: 999px;
  background: currentColor;
  animation: pulseGlow 2s ease-in-out infinite;
}

.hero-type-badge {
  color: rgba(255,255,255,0.68);
  background: rgba(255,255,255,0.055);
  border: 1px solid rgba(255,255,255,0.09);
}

.hero-title {
  max-width: 820px;
  margin-bottom: 1.05rem;
  color: #fff;
  font-size: clamp(3.35rem, 7.6vw, 7rem);
  font-weight: 800;
  line-height: 0.9;
  letter-spacing: -0.075em;
  text-wrap: balance;
  text-shadow: 0 22px 70px rgba(0,0,0,0.62);
}

.hero-title::first-letter {
  letter-spacing: -0.12em;
}

.hero-meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 1.08rem;
}

.hero-meta-item {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0.34rem 0.72rem;
  border-radius: var(--radius-full);
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.075);
  color: rgba(247,247,245,0.62);
  font-size: 0.76rem;
  font-weight: 700;
}

.hero-meta-item.rating {
  color: #fff;
  background: rgba(255,255,255,0.12);
  border-color: rgba(255,255,255,0.18);
}

.hero-overview {
  max-width: 590px;
  margin-bottom: 1.9rem;
  color: rgba(247,247,245,0.68);
  font-size: clamp(0.94rem, 1.02vw, 1.04rem);
  line-height: 1.76;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.hero-actions {
  display: flex;
  align-items: center;
  gap: 0.82rem;
}

.hero-actions .btn {
  min-height: 52px;
  padding: 0.82rem 1.72rem;
  font-size: 0.9rem;
  border-radius: var(--radius-full);
}

.hero-actions .btn-primary {
  color: #050505;
  background: linear-gradient(180deg, #fff, #e5e5de);
  box-shadow: 0 20px 52px rgba(255,255,255,0.13), inset 0 1px 0 rgba(255,255,255,0.75);
}

.hero-actions .btn-primary:hover,
.hero-actions .btn-secondary:hover {
  transform: translateY(-3px) scale(1.015);
}

.hero-actions .btn-primary svg {
  color: #050505;
  fill: #050505;
}

.hero-actions .btn-secondary {
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.11);
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
}

.hero-video-container {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  z-index: 1;
  pointer-events: none;
  opacity: 0.42;
  transition: opacity 1.5s var(--ease-smooth);
}

.hero-video {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100vw;
  height: 56.25vw;
  min-height: 100%;
  min-width: 177.77%;
  transform: translate(-50%, -50%) scale(1.12);
  pointer-events: none;
  border: none;
}

.hero-slider-controls {
  position: absolute;
  right: 4%;
  bottom: clamp(4.8rem, 9dvh, 6.6rem);
  z-index: 12;
  display: flex;
  gap: 0.4rem;
  padding: 0.5rem;
  border-radius: var(--radius-full);
  background: rgba(10,10,10,0.56);
  border: 1px solid rgba(255,255,255,0.09);
  backdrop-filter: blur(22px) saturate(150%);
  -webkit-backdrop-filter: blur(22px) saturate(150%);
  box-shadow: 0 16px 42px rgba(0,0,0,0.38);
}

.hero-indicators {
  display: flex;
  align-items: center;
  gap: 0.42rem;
}

.indicator {
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: rgba(255,255,255,0.25);
  cursor: pointer;
  transition: all var(--duration-normal) var(--ease-spring);
  border: none;
}

.indicator.active {
  width: 34px;
  background: #fff;
  box-shadow: 0 0 18px rgba(255,255,255,0.22);
}

.indicator:hover:not(.active) {
  background: rgba(255,255,255,0.58);
  transform: scale(1.12);
}

.hero-progress-track {
  position: absolute;
  left: 4%;
  right: 4%;
  bottom: 0;
  z-index: 15;
  height: 2px;
  background: rgba(255,255,255,0.055);
  overflow: hidden;
}

.hero-progress-bar {
  height: 100%;
  background: linear-gradient(90deg, rgba(255,255,255,0.45), #fff);
  transform-origin: left;
}

.hero-progress-bar.playing {
  animation: heroProgress 10s linear both;
}

.hero-progress-bar.idle {
  animation-play-state: paused;
  opacity: 0.25;
}

@keyframes heroProgress {
  from { transform: scaleX(0); }
  to { transform: scaleX(1); }
}

@media (max-width: 768px) {
  .hero-video-container { display: none !important; }
  .hero-image.idle-fade { opacity: 0.85; } /* Prevent fade out on mobile */
  .hero-content.idle-fade { opacity: 1; pointer-events: auto; }
  .hero { min-height: 65dvh; }
  .hero-image { object-position: center 20%; opacity: 0.85; }
  .hero::before { opacity: 0.3; }
  .hero-overlay {
    background:
      linear-gradient(to top, #070707 0%, rgba(7,7,7,0.85) 15%, rgba(7,7,7,0.4) 40%, rgba(7,7,7,0.1) 60%),
      linear-gradient(to right, rgba(7,7,7,0.5), transparent 80%);
  }
  .hero-content { padding: 0 1rem clamp(2.5rem, 6dvh, 3.5rem); }
  .hero-content::before { font-size: 0.58rem; margin-bottom: 0.8rem; }
  .hero-tags { margin-bottom: 0.78rem; gap: 0.42rem; }
  .hero-badge, .hero-type-badge { font-size: 0.56rem; padding: 0.34rem 0.58rem; }
  .hero-title { font-size: clamp(2rem, 9vw, 2.8rem); margin-bottom: 0.6rem; letter-spacing: -0.04em; }
  .hero-meta { margin-bottom: 0.6rem; gap: 0.38rem; }
  .hero-meta-item { min-height: 24px; font-size: 0.65rem; padding: 0.2rem 0.5rem; }
  .hero-overview { font-size: 0.8rem; -webkit-line-clamp: 3; margin-bottom: 1rem; max-width: 95vw; line-height: 1.4; color: rgba(255,255,255,0.75); }
  .hero-actions { gap: 0.4rem; flex-wrap: wrap; }
  .hero-actions .btn { min-height: 40px; padding: 0.5rem 0.9rem; font-size: 0.75rem; }
  .hero-slider-controls { right: auto; left: 50%; bottom: 1rem; transform: translateX(-50%); }
}

@media (max-width: 420px) {
  .hero-title { font-size: clamp(2.2rem, 13vw, 3.35rem); }
  .hero-actions .btn { flex: 1 1 auto; min-width: 132px; }
  .hero-tags { max-width: 100%; overflow: hidden; }
}
/* Clean Poster Card — supports current JSX class names */
.media-card { position: relative; display: flex; flex-direction: column; height: 100%; border-radius: 22px; overflow: hidden; cursor: pointer; isolation: isolate; background: rgba(255,255,255,0.035); border: 1px solid rgba(255,255,255,0.075); box-shadow: none; transition: transform var(--duration-normal) var(--ease-spring), background var(--duration-normal) var(--ease-spring), border-color var(--duration-normal) var(--ease-spring); }
.media-card:hover { transform: translateY(-6px); background: rgba(255,255,255,0.055); border-color: rgba(255,255,255,0.14); z-index: 2; }
.card-image-wrapper, .media-card-poster { position: relative; aspect-ratio: 2/3; overflow: hidden; background: #111; }
.card-image, .media-card-poster img { width: 100%; height: 100%; object-fit: cover; filter: saturate(0.9) contrast(1.04); transition: transform var(--duration-slow) var(--ease-spring), filter var(--duration-slow) var(--ease-spring); }
.media-card:hover .card-image, .media-card:hover .media-card-poster img { transform: scale(1.045); filter: saturate(1) contrast(1.06); }
.card-image-wrapper::after, .media-card-poster::after { content: ''; position: absolute; inset: auto 0 0; height: 58%; background: linear-gradient(to top, rgba(0,0,0,0.82), transparent); pointer-events: none; }
.card-image-placeholder { width: 100%; height: 100%; display: grid; place-items: center; color: var(--text-tertiary); background: linear-gradient(145deg, #151515, #090909); font-size: 0.86rem; }
.card-overlay { position: absolute; inset: 0; z-index: 3; display: grid; place-items: center; background: rgba(0,0,0,0.14); opacity: 0; transition: opacity var(--duration-normal) var(--ease-spring); }
.media-card:hover .card-overlay { opacity: 1; }
.play-btn { width: 50px; height: 50px; display: grid; place-items: center; border-radius: 999px; background: #fff; color: #050505; box-shadow: 0 18px 50px rgba(0,0,0,0.32); transform: scale(0.92); transition: transform var(--duration-normal) var(--ease-spring); }
.play-btn svg { fill: #050505; color: #050505; }
.media-card:hover .play-btn { transform: scale(1); }
.card-rating, .media-card-rating-badge { position: absolute; top: 0.75rem; right: 0.75rem; z-index: 5; display: flex; align-items: center; gap: 0.28rem; min-height: 28px; padding: 0.3rem 0.58rem; border-radius: var(--radius-full); background: rgba(8,8,8,0.62); backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); border: 1px solid rgba(255,255,255,0.1); color: #fff; font-size: 0.7rem; font-weight: 700; }
.card-rating svg, .media-card-rating-badge svg { fill: #fff; color: #fff; }
.card-info, .media-card-info { padding: 0.9rem 0.95rem 1rem; display: flex; flex-direction: column; flex-grow: 1; }
.card-title, .media-card-title { margin: 0; color: var(--text-primary); font-size: 0.94rem; font-weight: 650; line-height: 1.2; letter-spacing: -0.025em; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.card-meta, .media-card-meta { display: flex; align-items: center; justify-content: space-between; gap: 0.5rem; margin-top: auto; padding-top: 0.55rem; font-size: 0.74rem; color: var(--text-tertiary); font-weight: 600; }
.card-type { padding: 0.2rem 0.48rem; border-radius: var(--radius-full); background: rgba(255,255,255,0.055); color: var(--text-secondary); }
.media-card-rating { color: var(--text-primary); font-weight: 700; }
/* Azu — editorial cinematic shelves */
.media-slider {
  position: relative;
  width: min(94%, 1220px);
  margin: 0 auto;
  padding: clamp(1.05rem, 2.2vw, 1.55rem) 0 clamp(0.85rem, 1.9vw, 1.35rem);
  border-radius: 32px;
  isolation: isolate;
  overflow: hidden;
}

.media-slider::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background:
    linear-gradient(135deg, rgba(255,255,255,0.042), rgba(255,255,255,0.006) 46%, rgba(255,255,255,0.028)),
    radial-gradient(circle at 7% 0%, rgba(255,255,255,0.06), transparent 18rem);
  border: 1px solid rgba(255,255,255,0.055);
  opacity: 0;
  transform: scaleX(0.985);
  transition:
    opacity var(--duration-normal) var(--ease-spring),
    transform var(--duration-normal) var(--ease-spring);
  z-index: -1;
}

.media-slider:hover::before {
  opacity: 1;
  transform: scaleX(1);
}

.media-slider::after {
  position: absolute;
  right: clamp(1rem, 2.4vw, 1.6rem);
  top: 0.55rem;
  font-size: clamp(2.8rem, 7vw, 6.6rem);
  line-height: 0.85;
  font-weight: 950;
  letter-spacing: -0.09em;
  color: rgba(255,255,255,0.028);
  pointer-events: none;
  z-index: -1;
}

.content-sliders .media-slider:nth-child(1)::after { content: 'TRENDING'; }
.content-sliders .media-slider:nth-child(2)::after { content: 'MOVIES'; }
.content-sliders .media-slider:nth-child(3)::after { content: 'TV SHOWS'; }
.content-sliders .media-slider:nth-child(4)::after { content: 'TOP RATED'; }

.media-slider-header {
  width: auto;
  padding: 0 clamp(1rem, 2vw, 1.35rem);
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: clamp(0.9rem, 1.6vw, 1.2rem);
}

.media-slider-header .section-title {
  position: relative;
  display: flex;
  align-items: center;
  gap: 0.7rem;
  font-size: clamp(1.35rem, 2.2vw, 2.25rem);
  font-weight: 850;
  line-height: 0.95;
  letter-spacing: -0.07em;
  color: var(--text-primary);
}

.media-slider-header .section-title::before {
  content: '';
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #f6f3ea;
  box-shadow:
    0 0 0 6px rgba(255,255,255,0.055),
    0 0 28px rgba(255,255,255,0.24);
  flex-shrink: 0;
}

.media-slider-header .section-title::after {
  position: absolute;
  left: 1.12rem;
  top: -1.02rem;
  color: rgba(255,255,255,0.38);
  font-size: 0.64rem;
  font-weight: 850;
  line-height: 1;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.content-sliders .media-slider:nth-child(1) .section-title::after { content: 'Live signals'; }
.content-sliders .media-slider:nth-child(2) .section-title::after { content: 'Feature films'; }
.content-sliders .media-slider:nth-child(3) .section-title::after { content: 'Episode picks'; }
.content-sliders .media-slider:nth-child(4) .section-title::after { content: 'Critic pulse'; }

.media-slider-nav {
  display: flex;
  gap: 0.4rem;
  padding: 0.25rem;
  border-radius: var(--radius-full);
  background: rgba(255,255,255,0.035);
  border: 1px solid rgba(255,255,255,0.075);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

.media-slider-nav button {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: transparent;
  border: 1px solid transparent;
  color: rgba(255,255,255,0.58);
  display: grid;
  place-items: center;
  transition:
    transform var(--duration-normal) var(--ease-spring),
    background var(--duration-normal) var(--ease-spring),
    color var(--duration-normal) var(--ease-spring);
}

.media-slider-nav button:hover {
  background: #f6f3ea;
  border-color: transparent;
  color: #050505;
  transform: scale(1.06);
  box-shadow: 0 14px 34px rgba(255,255,255,0.08);
}

.media-slider-track {
  display: flex;
  gap: clamp(1rem, 1.65vw, 1.45rem);
  overflow-x: auto;
  padding: 0.28rem clamp(1rem, 2vw, 1.35rem) 1.2rem;
  scroll-behavior: smooth;
  scroll-snap-type: x proximity;
  -ms-overflow-style: none;
  scrollbar-width: none;
  mask-image: linear-gradient(to right, black 92%, transparent);
  -webkit-mask-image: linear-gradient(to right, black 92%, transparent);
}

.media-slider-track::-webkit-scrollbar {
  display: none;
}

.media-slider-track > * {
  flex-shrink: 0;
  scroll-snap-align: start;
}

.media-slider-track .media-card {
  width: clamp(162px, 14.1vw, 216px);
}

.content-sliders .media-slider:nth-child(1) .media-slider-track .media-card:nth-child(5n + 1),
.content-sliders .media-slider:nth-child(4) .media-slider-track .media-card:nth-child(4n + 2) {
  width: clamp(184px, 15.7vw, 238px);
}

.content-sliders .media-slider:nth-child(2) .media-slider-track .media-card {
  width: clamp(170px, 14.8vw, 224px);
}

.content-sliders .media-slider:nth-child(3) .media-slider-track .media-card:nth-child(3n + 1) {
  width: clamp(176px, 15.2vw, 230px);
}

@media (max-width: 768px) {
  .media-slider {
    width: calc(100% - 1rem);
    padding: 1rem 0 0.85rem;
    border-radius: 26px;
  }

  .media-slider::before {
    opacity: 0.68;
    transform: none;
  }

  .media-slider::after {
    display: none;
  }

  .media-slider-header {
    align-items: center;
    margin-bottom: 0.9rem;
    padding-inline: 0.85rem;
  }

  .media-slider-header .section-title {
    font-size: 1.25rem;
    gap: 0.55rem;
  }

  .media-slider-header .section-title::before {
    width: 7px;
    height: 7px;
  }

  .media-slider-header .section-title::after {
    display: none;
  }

  .media-slider-track {
    padding: 0.18rem 0.85rem 0.95rem;
    gap: 0.85rem;
  }

  .media-slider-track .media-card,
  .content-sliders .media-slider:nth-child(1) .media-slider-track .media-card:nth-child(5n + 1),
  .content-sliders .media-slider:nth-child(2) .media-slider-track .media-card,
  .content-sliders .media-slider:nth-child(3) .media-slider-track .media-card:nth-child(3n + 1),
  .content-sliders .media-slider:nth-child(4) .media-slider-track .media-card:nth-child(4n + 2) {
    width: 150px;
  }

  .media-slider-nav {
    display: none;
  }
}

@media (max-width: 480px) {
  .media-slider-track .media-card,
  .content-sliders .media-slider:nth-child(1) .media-slider-track .media-card:nth-child(5n + 1),
  .content-sliders .media-slider:nth-child(2) .media-slider-track .media-card,
  .content-sliders .media-slider:nth-child(3) .media-slider-track .media-card:nth-child(3n + 1),
  .content-sliders .media-slider:nth-child(4) .media-slider-track .media-card:nth-child(4n + 2) {
    width: 142px;
  }
}
.rec-section {
  position: relative;
  z-index: 2;
  margin: clamp(1.4rem, 3.4vw, 3rem) 0 0.5rem;
  padding: clamp(1.1rem, 2vw, 1.5rem) 0 clamp(0.8rem, 1.6vw, 1.25rem);
  overflow: hidden;
}

.rec-section::before {
  content: '';
  position: absolute;
  left: 4%;
  right: 4%;
  top: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.11), transparent);
}

.rec-section::after {
  content: 'AZU CURATION';
  position: absolute;
  left: 4%;
  top: 0.9rem;
  color: rgba(255,255,255,0.035);
  font-size: clamp(3.4rem, 9vw, 8.8rem);
  line-height: 0.82;
  letter-spacing: -0.09em;
  font-weight: 950;
  pointer-events: none;
  z-index: -1;
}

/* ── Header ── */
.rec-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: clamp(1rem, 2vw, 1.45rem);
  gap: 1rem;
  flex-wrap: wrap;
}

.rec-header-left {
  display: flex;
  align-items: flex-start;
  gap: 0.82rem;
  min-width: 0;
}

.rec-icon {
  width: 30px;
  height: 30px;
  padding: 7px;
  color: #050505;
  background: linear-gradient(180deg, #f8f4e8, #d9d3c5);
  border-radius: 50%;
  flex-shrink: 0;
  box-shadow:
    0 14px 34px rgba(255,255,255,0.08),
    inset 0 1px 0 rgba(255,255,255,0.72);
  animation: recPulse 3.4s var(--ease-spring) infinite;
}

@keyframes recPulse {
  0%, 100% { transform: scale(1); opacity: 1; }
  50% { transform: scale(1.08); opacity: 0.82; }
}

.rec-title-group {
  display: flex;
  flex-direction: column;
  gap: 0.38rem;
  min-width: 0;
}

.rec-title {
  font-size: clamp(1.45rem, 2.45vw, 2.6rem);
  font-weight: 850;
  letter-spacing: -0.075em;
  line-height: 0.95;
  color: var(--text-primary);
  white-space: nowrap;
}

.rec-source-title {
  display: inline-flex;
  width: fit-content;
  max-width: min(460px, 70vw);
  padding: 0.32rem 0.68rem;
  border-radius: var(--radius-full);
  border: 1px solid rgba(255,255,255,0.09);
  background: rgba(255,255,255,0.045);
  color: rgba(255,255,255,0.66);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: -0.015em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.rec-source-title::before {
  content: 'Based on ';
  color: rgba(255,255,255,0.38);
  font-weight: 650;
}

.rec-header-right {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-shrink: 0;
}

/* ── Refresh button ── */
.rec-refresh-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  min-height: 36px;
  font-size: 0.74rem;
  font-weight: 800;
  color: rgba(255,255,255,0.62);
  padding: 0.48rem 0.86rem;
  border-radius: var(--radius-full);
  border: 1px solid rgba(255,255,255,0.085);
  background: rgba(255,255,255,0.038);
  cursor: pointer;
  transition: all var(--duration-normal) var(--ease-spring);
  font-family: inherit;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

.rec-refresh-btn:hover:not(:disabled) {
  color: #050505;
  border-color: transparent;
  background: #f6f3ea;
  transform: translateY(-1px);
}

.rec-refresh-btn:disabled {
  opacity: 0.5;
  cursor: default;
}

.spinning {
  animation: spin 0.8s linear infinite;
}

@keyframes spin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

/* ── Nav Buttons ── */
.rec-nav-btns {
  display: flex;
  gap: 0.4rem;
  padding: 0.24rem;
  border-radius: var(--radius-full);
  background: rgba(255,255,255,0.035);
  border: 1px solid rgba(255,255,255,0.07);
}

.rec-nav-btn {
  background: transparent;
  border: 1px solid transparent;
  color: rgba(255,255,255,0.55);
  width: 34px;
  height: 34px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all var(--duration-normal) var(--ease-spring);
  font-family: inherit;
}

.rec-nav-btn:hover {
  background: #f6f3ea;
  border-color: transparent;
  color: #050505;
  transform: scale(1.06);
}

/* ── Slider ── */
.rec-slider-wrapper {
  position: relative;
  mask-image: linear-gradient(to right, transparent, black 4%, black 94%, transparent);
  -webkit-mask-image: linear-gradient(to right, transparent, black 4%, black 94%, transparent);
}

.rec-track {
  display: flex;
  gap: clamp(1rem, 1.8vw, 1.6rem);
  overflow-x: auto;
  padding: 0.4rem 4% 2.5rem 4%;
  scroll-behavior: smooth;
  scroll-snap-type: x proximity;
  -ms-overflow-style: none;
  scrollbar-width: none;
}

.rec-track::-webkit-scrollbar {
  display: none;
}

/* ── Skeleton ── */
.rec-skeleton {
  width: clamp(168px, 14.3vw, 218px);
  flex-shrink: 0;
  aspect-ratio: 2/3;
  border-radius: 24px;
}

/* ── Cards ── */
.rec-card-wrap {
  flex-shrink: 0;
  width: clamp(168px, 14.3vw, 218px);
  scroll-snap-align: start;
  transition:
    transform var(--duration-normal) var(--ease-spring),
    filter var(--duration-normal) var(--ease-spring);
}

.rec-card-wrap:nth-child(4n + 1) {
  width: clamp(180px, 15.4vw, 232px);
}

.rec-card-wrap:hover {
  transform: translateY(-8px);
  filter: drop-shadow(0 26px 44px rgba(0,0,0,0.34));
}

@media (max-width: 768px) {
  .rec-section {
    margin-top: 1rem;
    padding-top: 1rem;
  }

  .rec-section::after {
    display: none;
  }

  .rec-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.85rem;
  }

  .rec-header-right {
    width: 100%;
    justify-content: space-between;
  }

  .rec-title {
    font-size: 1.35rem;
  }

  .rec-source-title {
    max-width: calc(100vw - 2rem);
  }

  .rec-track {
    padding: 0.25rem 4% 1.5rem 4%;
    gap: 0.85rem;
  }

  .rec-card-wrap,
  .rec-card-wrap:nth-child(4n + 1),
  .rec-skeleton {
    width: 150px;
  }
}

@media (max-width: 480px) {
  .rec-icon {
    width: 26px;
    height: 26px;
    padding: 6px;
  }

  .rec-nav-btns {
    display: none;
  }

  .rec-card-wrap,
  .rec-card-wrap:nth-child(4n + 1),
  .rec-skeleton {
    width: 142px;
  }
}
/* Azu Home — cinematic shelves inspired by Apple TV+, HBO Max, and Letterboxd */
.home-page {
  position: relative;
  overflow-x: hidden;
  background:
    radial-gradient(circle at 12% 18%, rgba(255, 255, 255, 0.035), transparent 28rem),
    radial-gradient(circle at 86% 34%, rgba(87, 64, 255, 0.055), transparent 32rem),
    transparent;
}

.home-page::before {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(255,255,255,0.018) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.014) 1px, transparent 1px);
  background-size: 72px 72px;
  mask-image: linear-gradient(to bottom, transparent, black 14%, transparent 82%);
  -webkit-mask-image: linear-gradient(to bottom, transparent, black 14%, transparent 82%);
  opacity: 0.34;
  z-index: 0;
}

.home-loading {
  min-height: 100dvh;
  padding: 7rem 4% 0;
}

.hero-skeleton {
  width: 100%;
  min-height: 76dvh;
  border-radius: 0 0 32px 32px;
}

.content-sliders {
  position: relative;
  z-index: 2;
  margin-top: clamp(1rem, 3vw, 2.5rem);
  display: flex;
  flex-direction: column;
  gap: clamp(1.15rem, 2.8vw, 2.4rem);
}

.recently-section {
  position: relative;
  z-index: 2;
  width: min(94%, 1220px);
  margin: clamp(1.3rem, 3vw, 2.6rem) auto 0;
  padding: clamp(1rem, 2vw, 1.4rem) 0 clamp(0.35rem, 1vw, 0.7rem);
  border-radius: 34px;
  background:
    linear-gradient(135deg, rgba(255,255,255,0.075), rgba(255,255,255,0.022) 42%, rgba(255,255,255,0.045)),
    rgba(10,10,10,0.58);
  border: 1px solid rgba(255,255,255,0.075);
  box-shadow:
    0 26px 80px rgba(0,0,0,0.28),
    inset 0 1px 0 rgba(255,255,255,0.055);
  overflow: hidden;
}

.recently-section::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 10% 0%, rgba(255,255,255,0.09), transparent 19rem),
    linear-gradient(90deg, rgba(255,255,255,0.055), transparent 30%, transparent 70%, rgba(255,255,255,0.035));
  opacity: 0.72;
}

.recently-section::after {
  content: 'CONTINUE';
  position: absolute;
  right: clamp(1.3rem, 3vw, 2.2rem);
  top: 0.8rem;
  color: rgba(255,255,255,0.035);
  font-size: clamp(2.8rem, 8vw, 6.6rem);
  font-weight: 900;
  letter-spacing: -0.08em;
  line-height: 1;
  pointer-events: none;
}

.recently-header {
  position: relative;
  z-index: 2;
  width: auto;
  padding: 0 clamp(1rem, 2.3vw, 1.6rem);
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: 1rem;
  gap: 1rem;
}

.recently-title-group {
  display: grid;
  grid-template-columns: auto auto auto;
  align-items: center;
  gap: 0.55rem;
}

.recently-icon {
  width: 28px;
  height: 28px;
  padding: 6px;
  color: #050505;
  background: #f6f3ea;
  border-radius: 50%;
  flex-shrink: 0;
  box-shadow: 0 12px 30px rgba(255,255,255,0.08);
}

.recently-title {
  font-size: clamp(1.35rem, 2.2vw, 2.25rem);
  font-weight: 820;
  letter-spacing: -0.065em;
  line-height: 0.95;
  color: var(--text-primary);
}

.recently-count {
  align-self: center;
  font-size: 0.72rem;
  font-weight: 800;
  background: rgba(255,255,255,0.08);
  color: rgba(255,255,255,0.7);
  border: 1px solid rgba(255,255,255,0.085);
  border-radius: var(--radius-full);
  padding: 0.22rem 0.58rem;
}

.clear-history-btn {
  position: relative;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  min-height: 36px;
  font-size: 0.74rem;
  font-weight: 750;
  color: rgba(255,255,255,0.58);
  padding: 0.5rem 0.88rem;
  border-radius: var(--radius-full);
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(0,0,0,0.24);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  transition:
    transform var(--duration-normal) var(--ease-spring),
    background var(--duration-normal) var(--ease-spring),
    color var(--duration-normal) var(--ease-spring),
    border-color var(--duration-normal) var(--ease-spring);
}

.clear-history-btn:hover {
  color: #050505;
  border-color: transparent;
  background: #f6f3ea;
  transform: translateY(-1px);
}

.recently-track {
  position: relative;
  z-index: 2;
  display: flex;
  gap: clamp(1rem, 1.6vw, 1.45rem);
  overflow-x: auto;
  padding: 0.35rem clamp(1rem, 2.3vw, 1.6rem) 1.25rem;
  scroll-behavior: smooth;
  scroll-snap-type: x proximity;
  -ms-overflow-style: none;
  scrollbar-width: none;
  mask-image: linear-gradient(to right, black 92%, transparent);
  -webkit-mask-image: linear-gradient(to right, black 92%, transparent);
}

.recently-track::-webkit-scrollbar {
  display: none;
}

.recently-card-wrap {
  position: relative;
  flex-shrink: 0;
  width: clamp(168px, 14.3vw, 218px);
  scroll-snap-align: start;
  transition:
    transform var(--duration-normal) var(--ease-spring),
    filter var(--duration-normal) var(--ease-spring);
}



.recently-card-wrap:hover {
  transform: translateY(-8px);
  filter: drop-shadow(0 24px 42px rgba(0,0,0,0.36));
}

.remove-history-btn {
  position: absolute;
  top: 0.68rem;
  left: 0.68rem;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: rgba(0,0,0,0.62);
  border: 1px solid rgba(255,255,255,0.12);
  color: rgba(255,255,255,0.68);
  font-size: 0.72rem;
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: all var(--duration-normal) var(--ease-spring);
  z-index: 9;
  opacity: 0;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

.recently-card-wrap:hover .remove-history-btn {
  opacity: 1;
}

.remove-history-btn:hover {
  background: #f6f3ea;
  color: #050505;
  border-color: transparent;
  transform: scale(1.06);
}

@media (max-width: 768px) {
  .content-sliders {
    margin-top: 0.75rem;
  }

  .recently-section {
    width: calc(100% - 1rem);
    border-radius: 26px;
    margin-top: 1rem;
    padding-top: 0.95rem;
  }

  .recently-section::after {
    display: none;
  }

  .recently-header {
    align-items: center;
    padding-inline: 0.85rem;
  }

  .recently-title {
    font-size: 1.25rem;
  }

  .recently-icon {
    width: 25px;
    height: 25px;
    padding: 5px;
  }

  .clear-history-btn {
    min-height: 32px;
    padding: 0.42rem 0.7rem;
    font-size: 0.68rem;
  }

  .recently-track {
    padding: 0.25rem 0.85rem 1rem;
    gap: 0.85rem;
  }

  .recently-card-wrap {
    width: 150px;
  }



  .remove-history-btn {
    opacity: 1;
  }
}

@media (max-width: 480px) {
  .recently-header {
    gap: 0.7rem;
  }

  .recently-title-group {
    gap: 0.42rem;
  }

  .recently-count {
    display: none;
  }

  .recently-card-wrap {
    width: 142px;
  }
}
.search-page {
  min-height: calc(100vh - 80px);
}

.search-header {
  margin-bottom: 2rem;
}

.search-header h1 {
  font-size: 2rem;
  font-weight: 700;
}

.search-header .accent {
  color: var(--accent);
}

.search-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 1.5rem;
  padding-bottom: 4rem;
}

@media (min-width: 768px) {
  .search-grid {
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 2rem;
  }
}

.search-loading,
.search-empty {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 40vh;
  color: var(--text-tertiary);
  font-size: 1.2rem;
}
.azu-custom-player {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  background: #000;
  overflow: hidden;
  border-radius: 24px;
  box-shadow: 0 40px 120px rgba(0, 0, 0, 0.75);
  display: flex;
  align-items: center;
  justify-content: center;
}

.azu-video {
  width: 100%;
  height: 100%;
  object-fit: contain;
  background: #000;
  cursor: pointer;
}

.azu-custom-player::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(to top, rgba(0, 0, 0, 0.8), transparent 45%),
    linear-gradient(to right, rgba(0, 0, 0, 0.35), transparent 45%);
  z-index: 2;
  transition: opacity 0.25s ease;
}

.azu-custom-player.hide-ui {
  cursor: none;
}

.azu-custom-player.hide-ui::before {
  opacity: 0;
}

.azu-splash-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.5;
  filter: blur(8px);
}

.azu-custom-player.splash, .azu-custom-player.loading, .azu-custom-player.error {
  cursor: pointer;
}

.azu-spinner {
  animation: azu-spin 1s linear infinite;
  color: var(--accent);
  z-index: 5;
}

@keyframes azu-spin {
  100% { transform: rotate(360deg); }
}

.azu-error-text {
  color: var(--accent);
  font-size: 18px;
  font-weight: bold;
  z-index: 5;
}

.azu-checker-box {
  position: absolute;
  z-index: 10;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
  background: rgba(10, 10, 10, 0.85);
  padding: 24px 32px;
  border-radius: 16px;
  backdrop-filter: blur(24px);
  border: 1px solid rgba(255, 255, 255, 0.1);
  box-shadow: 0 20px 60px rgba(0,0,0,0.8);
  max-width: 80%;
}

.azu-checker-text h4 {
  margin: 0 0 12px;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: white;
  text-align: center;
}

.azu-scrolling-logs {
  display: flex;
  flex-direction: column;
  gap: 6px;
  width: 100%;
}

.azu-scrolling-logs p {
  margin: 0;
  font-size: 12px;
  font-family: monospace;
  transition: opacity 0.3s ease;
}

.azu-scrolling-logs p.log-normal { color: rgba(255,255,255,0.6); }
.azu-scrolling-logs p.log-success { color: #00ff88; }
.azu-scrolling-logs p.log-sys {
  color: #ff9800;
  font-weight: 500;
}

.log-error {
  color: #ff3333;
  font-weight: 600;
}

.azu-scrolling-logs p.pulse {
  animation: pulse-log 1s infinite alternate;
}

@keyframes pulse-log {
  from { opacity: 1; }
  to { opacity: 0.4; }
}

.azu-title-overlay {
  position: absolute;
  left: 32px;
  top: 32px;
  bottom: auto;
  z-index: 3;
  color: white;
  pointer-events: none;
  transition: opacity 0.25s ease, transform 0.25s ease;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  text-shadow: 0 4px 20px rgba(0,0,0,0.8);
}

.azu-title-overlay.hide {
  opacity: 0;
  transform: translateY(-12px);
}

.azu-title-overlay.show {
  opacity: 1;
  transform: translateY(0);
}

.player-brand-text {
  font-family: var(--font-display);
  font-size: clamp(14px, 1.8vw, 20px);
  letter-spacing: -0.02em;
  margin-bottom: 6px;
  display: flex;
  align-items: center;
  gap: 4px;
}

.brand-azu {
  font-weight: 800;
  color: #ffffff;
}

.brand-stream {
  font-weight: 500;
  color: rgba(255, 255, 255, 0.45);
}

.azu-title-overlay h1 {
  margin: 0;
  font-size: clamp(24px, 4vw, 48px);
  line-height: 1.1;
  font-weight: 800;
  letter-spacing: -0.02em;
  text-shadow: 0 4px 24px rgba(0, 0, 0, 0.9);
}

.azu-season-info {
  margin: 6px 0 0;
  font-size: clamp(13px, 1.5vw, 15px);
  font-weight: 500;
  color: rgba(255, 255, 255, 0.7);
  letter-spacing: 0.05em;
  display: flex;
  align-items: center;
  gap: 6px;
}

.azu-season-info span {
  color: rgba(255, 255, 255, 0.3);
}

.azu-center-play {
  position: absolute;
  left: 50%;
  top: 50%;
  z-index: 5;
  transform: translate(-50%, -50%);
  width: 84px;
  height: 84px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: rgba(255, 255, 255, 0.12);
  border: 2px solid rgba(255, 255, 255, 0.45);
  backdrop-filter: blur(14px);
  cursor: pointer;
  transition: 0.2s ease;
}

.azu-center-play:hover {
  transform: translate(-50%, -50%) scale(1.08);
  background: var(--accent);
  border-color: var(--accent);
}

.azu-controls {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 6;
  padding: 48px 28px 24px;
  background: linear-gradient(to top, rgba(0,0,0,0.95) 0%, rgba(0,0,0,0.5) 60%, transparent 100%);
  transition: opacity 0.3s cubic-bezier(0.4, 0, 0.2, 1), transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.azu-controls.hide {
  opacity: 0;
  transform: translateY(20px);
  pointer-events: none;
}

.azu-controls.show {
  opacity: 1;
  transform: translateY(0);
}

.azu-progress {
  width: 100%;
  height: 4px;
  accent-color: var(--accent);
  cursor: pointer;
  transition: height 0.2s ease;
  border-radius: 4px;
}
.azu-progress:hover {
  height: 8px;
}

.azu-control-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 18px;
}

.azu-left-controls,
.azu-right-controls {
  display: flex;
  align-items: center;
  gap: 14px;
}

.azu-control-row button {
  background: transparent;
  border: none;
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  opacity: 0.86;
  transition: 0.15s ease;
}

.azu-control-row button:hover {
  opacity: 1;
  transform: scale(1.12);
}

.azu-next-ep {
  white-space: nowrap;
}

.azu-volume {
  width: 0;
  opacity: 0;
  accent-color: var(--accent);
  transition: width 0.3s ease, opacity 0.3s ease;
}

.azu-left-controls:hover .azu-volume {
  width: 80px;
  opacity: 1;
}

.azu-control-row button {
  background: transparent;
  border: none;
  color: white;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 8px;
  border-radius: 50%;
  transition: background 0.2s, transform 0.2s;
}
.azu-control-row button:hover {
  background: rgba(255,255,255,0.15);
  transform: scale(1.1);
}
.azu-time {
  color: rgba(255, 255, 255, 0.85);
  font-size: 13px;
  font-weight: 500;
  font-variant-numeric: tabular-nums;
  margin-left: 8px;
}

::cue {
  background: rgba(0, 0, 0, 0.75);
  color: white;
  font-size: 1.15em;
  padding: 4px 8px;
  line-height: 1.5;
}

/* Elevate subtitles so they don't sit at the extreme bottom edge */
video::-webkit-media-text-track-display {
  transform: translateY(-60px) !important;
}

.azu-popup-menu {
  position: absolute;
  right: 24px;
  bottom: 96px;
  z-index: 10;
  background: rgba(15, 15, 15, 0.9);
  backdrop-filter: blur(20px);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 12px;
  padding: 12px;
  display: flex;
  flex-direction: column;
  min-width: 180px;
  max-height: 250px;
  overflow-y: auto;
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.8);
}

/* Custom scrollbar for popup menus */
.azu-popup-menu::-webkit-scrollbar {
  width: 6px;
}
.azu-popup-menu::-webkit-scrollbar-track {
  background: transparent;
}
.azu-popup-menu::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.2);
  border-radius: 6px;
}
.azu-popup-menu::-webkit-scrollbar-thumb:hover {
  background: rgba(255, 255, 255, 0.4);
}

.azu-popup-menu h4 {
  margin: 0 0 12px;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(255, 255, 255, 0.5);
  padding: 0 8px;
}

.azu-popup-menu button {
  background: transparent;
  border: none;
  color: white;
  text-align: left;
  padding: 10px 12px;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: 0.15s;
}

.azu-popup-menu button:hover {
  background: rgba(255, 255, 255, 0.1);
}

.azu-popup-menu button.active {
  color: var(--accent);
  background: rgba(229, 9, 20, 0.1);
}

.azu-tap-area {
  position: absolute;
  top: 0;
  bottom: 0;
  width: 40%;
  z-index: 4;
}
.azu-tap-area.left { left: 0; }
.azu-tap-area.right { right: 0; }

@media (max-width: 768px) {
  .azu-custom-player {
    border-radius: 14px;
  }
  .azu-top-right {
    top: 12px;
    right: 12px;
    transform: scale(0.85);
    transform-origin: top right;
  }
  .azu-title-overlay {
    left: 12px;
    top: 12px;
    bottom: auto;
  }
  .azu-title-overlay h1 {
    font-size: 18px;
  }
  .player-brand-text {
    font-size: 12px;
    margin-bottom: 2px;
  }
  .azu-volume, .azu-mute-btn {
    display: none;
  }
  .azu-time {
    font-size: 11px;
    white-space: nowrap;
    margin-left: 4px;
  }
  .azu-left-controls,
  .azu-right-controls {
    gap: 4px;
  }
  .azu-control-row button {
    padding: 8px;
  }
  .azu-control-row button svg {
    width: 20px;
    height: 20px;
  }
  .azu-progress {
    height: 6px;
  }
  .azu-next-ep {
    font-size: 12px !important;
  }
  .azu-controls {
    padding: 30px 12px 16px;
  }
  .azu-popup-menu {
    position: fixed;
    right: 0;
    left: 0;
    bottom: 0;
    width: 100%;
    max-height: 50vh;
    border-radius: 24px 24px 0 0;
    padding: 24px 16px 16px;
    background: rgba(15, 15, 15, 0.98);
    backdrop-filter: blur(30px);
    border: none;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    box-shadow: 0 -10px 40px rgba(0,0,0,0.8);
  }
  .azu-popup-header {
    background: transparent;
    border-bottom: 1px solid rgba(255,255,255,0.1);
    padding: 0 0 16px 0;
    margin-bottom: 8px;
  }
  .azu-popup-menu h4 {
    font-size: 15px;
    color: white;
  }
  .azu-popup-menu button {
    padding: 16px 12px;
    font-size: 15px;
  }
}

/* Toast */
.azu-toast {
  position: absolute;
  top: 24px;
  right: 24px;
  background: rgba(0, 0, 0, 0.85);
  color: #fff;
  padding: 12px 20px;
  border-radius: 12px;
  font-size: 14px;
  display: flex;
  align-items: center;
  z-index: 100;
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,0.1);
  box-shadow: 0 10px 30px rgba(0,0,0,0.5);
  animation: slideInRight 0.3s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

@keyframes slideInRight {
  from { opacity: 0; transform: translateX(20px); }
  to { opacity: 1; transform: translateX(0); }
}

@keyframes spin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}


/* --- New UI Styles --- */
.azu-checker-box {
  background: rgba(10, 10, 12, 0.85);
  padding: 32px 40px;
  border-radius: 24px;
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 30px 80px rgba(0,0,0,0.8), inset 0 1px 1px rgba(255,255,255,0.05);
  max-width: 600px;
  width: 90%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
}
.azu-checker-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}
.azu-checker-header h4 {
  margin: 0;
  font-size: 16px;
  font-weight: 600;
  color: rgba(255,255,255,0.9);
  letter-spacing: 0.02em;
  text-transform: none;
}
.azu-checker-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: center;
  width: 100%;
}
.azu-server-badge {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.05);
  border-radius: 12px;
  transition: all 0.3s;
}
.azu-server-badge.checking {
  opacity: 0.6;
  animation: pulse-glow 1.5s infinite;
}
.azu-server-badge.online {
  background: rgba(16, 185, 129, 0.1);
  border-color: rgba(16, 185, 129, 0.3);
}
.azu-server-badge.online .azu-server-name { color: #10b981; }
.azu-server-badge.offline {
  background: rgba(239, 68, 68, 0.1);
  border-color: rgba(239, 68, 68, 0.2);
  opacity: 0.5;
}
.azu-server-name {
  font-size: 13px;
  font-weight: 600;
  color: rgba(255,255,255,0.8);
}
.azu-server-quality {
  font-size: 11px;
  font-weight: 700;
  background: rgba(255,255,255,0.1);
  padding: 2px 6px;
  border-radius: 4px;
  color: rgba(255,255,255,0.7);
}

.azu-popup-menu {
  padding: 0;
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: 0 20px 50px rgba(0,0,0,0.6);
  min-width: 240px;
}
.azu-settings-sub {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 10px;
}

.azu-settings-header {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 4px 6px;
}

.azu-back-btn {
  background: rgba(255,255,255,0.08) !important;
  border: none;
  color: rgba(255,255,255,0.9) !important;
  font-size: 20px !important;
  width: 28px !important;
  height: 28px !important;
  padding: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 50% !important;
  cursor: pointer;
  line-height: 1 !important;
  transition: 0.2s;
}
.azu-back-btn:hover {
  background: rgba(255,255,255,0.15) !important;
  transform: translateX(-2px);
}
.azu-settings-header h4 {
  margin: 0;
  font-size: 14px;
  font-weight: 600;
  color: #fff;
  padding: 0;
}

.azu-popup-scroll {
  max-height: 240px;
  overflow-y: auto;
}
.azu-popup-scroll::-webkit-scrollbar { width: 4px; }
.azu-popup-scroll::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.1); border-radius: 4px; }

/* Sub-list item active state */
.azu-settings-list-item.active {
  background: rgba(255, 255, 255, 0.1);
}
.azu-settings-list-item.active .list-right {
  color: #fff;
}

.azu-popup-menu button {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 10px;
  width: 100%;
  font-family: inherit;
}
.azu-menu-item-row {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
}
.azu-menu-row-label {
  font-size: 13px;
  font-weight: 600;
  color: rgba(255,255,255,0.9);
}
.azu-menu-row-value {
  font-size: 12px;
  color: rgba(255,255,255,0.5);
  display: flex;
  align-items: center;
  gap: 8px;
}
.azu-menu-chevron {
  font-size: 16px;
  line-height: 1;
  opacity: 0.5;
}
.azu-popup-menu button:hover {
  background: rgba(255,255,255,0.06);
}
.azu-popup-menu button.active {
  background: rgba(255,255,255,0.08);
  color: #fff;
  border: 1px solid rgba(255,255,255,0.05);
}
.azu-menu-icon {
  color: rgba(255,255,255,0.4);
}
.azu-popup-menu button.active .azu-menu-icon {
  color: var(--accent);
}
.azu-menu-text {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  flex: 1;
  gap: 2px;
}
.azu-menu-title {
  font-size: 13px;
  font-weight: 600;
  color: rgba(255,255,255,0.9);
}
.azu-menu-quality {
  font-size: 11px;
  color: rgba(255,255,255,0.5);
}
.azu-menu-check {
  color: var(--accent);
  filter: drop-shadow(0 0 4px var(--accent-glow));
}


/* --- Subtitle Styling Panel --- */
.azu-popup-divider {
  height: 1px;
  background: rgba(255,255,255,0.06);
  margin: 4px 0;
}
.azu-style-grid {
  padding: 8px 16px 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.azu-style-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.azu-style-row > span {
  font-size: 12px;
  color: rgba(255,255,255,0.6);
  font-weight: 500;
}
.azu-style-toggles {
  display: flex;
  gap: 4px;
  background: rgba(255,255,255,0.03);
  border-radius: 8px;
  padding: 3px;
  border: 1px solid rgba(255,255,255,0.05);
}
.azu-popup-menu button.azu-style-toggles-btn,
.azu-style-toggles button {
  width: auto !important;
  padding: 4px 12px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  border-radius: 6px !important;
  color: rgba(255,255,255,0.4) !important;
  justify-content: center;
  background: transparent !important;
  border: none !important;
}
.azu-style-toggles button:hover {
  background: rgba(255,255,255,0.05) !important;
  color: rgba(255,255,255,0.8) !important;
}
.azu-style-toggles button.active {
  background: rgba(255,255,255,0.12) !important;
  color: #fff !important;
  box-shadow: 0 2px 8px rgba(0,0,0,0.2);
}
.color-dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.2);
}


/* --- Top Right Server Dropdown --- */
.azu-top-right {
  position: absolute;
  top: 32px;
  right: 32px;
  z-index: 50;
  display: flex;
  align-items: center;
  gap: 12px;
  transition: opacity 0.3s ease, transform 0.3s ease;
}

.azu-top-right.hide {
  opacity: 0;
  transform: translateY(-10px);
  pointer-events: none;
}

.azu-server-dropdown-container {
  position: relative;
}

.azu-top-server-btn {
  background: rgba(0, 0, 0, 0.4);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255, 255, 255, 0.1);
  padding: 6px 12px;
  border-radius: 8px;
  color: white;
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: background 0.2s, border-color 0.2s;
}

.azu-top-server-btn:hover {
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.2);
}

/* Adjust popup menu for top right so it drops DOWN */
.top-right-menu {
  bottom: auto;
  top: 100%;
  right: 0;
  margin-top: 8px;
  transform-origin: top right;
  min-width: 220px;
}

.azu-next-countdown-overlay {
  position: absolute;
  right: 24px;
  bottom: 120px;
  background: rgba(15, 15, 15, 0.95);
  backdrop-filter: blur(20px);
  border: 1px solid rgba(255, 255, 255, 0.1);
  padding: 16px 20px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  gap: 16px;
  z-index: 10;
  box-shadow: 0 10px 40px rgba(0,0,0,0.8);
  animation: slideUpIn 0.3s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

@keyframes slideUpIn {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}

.azu-next-countdown-overlay span {
  color: rgba(255, 255, 255, 0.9);
  font-size: 14px;
}

.azu-next-countdown-overlay strong {
  color: var(--accent);
  font-size: 16px;
}

.azu-next-now-btn {
  background: var(--accent);
  color: white;
  border: none;
  padding: 8px 16px;
  border-radius: 6px;
  font-weight: 600;
  cursor: pointer;
  transition: 0.2s;
}

.azu-next-now-btn:hover {
  background: #b20710;
  transform: scale(1.05);
}

.azu-next-cancel-btn {
  background: transparent;
  color: rgba(255, 255, 255, 0.5);
  border: 1px solid rgba(255, 255, 255, 0.2);
  padding: 8px 16px;
  border-radius: 6px;
  font-weight: 500;
  cursor: pointer;
  transition: 0.2s;
}

.azu-next-cancel-btn:hover {
  color: white;
  background: rgba(255, 255, 255, 0.1);
}

@media (max-width: 768px) {
  .azu-next-countdown-overlay {
    bottom: 90px;
    left: 12px;
    right: 12px;
    flex-wrap: wrap;
    justify-content: center;
  }
}

/* --- Splash Screen Logo & Overview --- */
.azu-custom-player.splash .azu-title-overlay {
  top: 50%;
  left: 64px;
  transform: translateY(-50%);
  max-width: 600px;
  justify-content: center;
}

.now-watching-badge {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.6);
  margin-bottom: 12px;
}

.azu-splash-logo {
  max-width: 400px;
  max-height: 140px;
  object-fit: contain;
  margin-bottom: 16px;
  filter: drop-shadow(0 4px 12px rgba(0,0,0,0.6));
  transform-origin: left center;
}

.azu-splash-overview {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 15px;
  line-height: 1.5;
  color: rgba(255, 255, 255, 0.85);
  margin: 0;
  text-shadow: 0 2px 8px rgba(0,0,0,0.9);
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

@media (max-width: 768px) {
  .azu-custom-player.splash .azu-title-overlay {
    left: 24px;
    right: 24px;
    bottom: 32px;
    top: auto;
    transform: none;
  }
  .azu-splash-logo {
    max-width: 250px;
    max-height: 100px;
  }
  .azu-splash-overview {
    font-size: 13px;
    -webkit-line-clamp: 2;
  }
}

.azu-active-logo {
  max-width: 250px;
  max-height: 60px;
  object-fit: contain;
  margin-top: 2px;
  margin-bottom: 2px;
  filter: drop-shadow(0 2px 8px rgba(0,0,0,0.8));
  transform-origin: left center;
}

/* --- Apple TV Style Settings Menu --- */
.azu-popup-menu {
  background: rgba(24, 24, 28, 0.75) !important;
  backdrop-filter: blur(30px) saturate(180%) !important;
  -webkit-backdrop-filter: blur(30px) saturate(180%) !important;
  width: 320px;
}

.azu-settings-main {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 10px;
}

/* Grid Top Section */
.azu-settings-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.azu-settings-card {
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid transparent;
  border-radius: 12px;
  padding: 12px 14px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 6px;
  cursor: pointer;
  transition: background 0.2s, transform 0.1s;
  width: 100%;
}

.azu-settings-card:hover {
  background: rgba(255, 255, 255, 0.12);
}
.azu-settings-card:active {
  transform: scale(0.97);
}

.card-label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 10px;
  text-transform: uppercase;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: rgba(255, 255, 255, 0.45);
}

.card-value {
  font-size: 15px;
  font-weight: 600;
  color: #fff;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  width: 100%;
  text-align: left;
}

.azu-settings-divider {
  display: none; 
}

/* List Items Section */
.azu-settings-list {
  display: flex;
  flex-direction: column;
  background: rgba(255, 255, 255, 0.04);
  border-radius: 12px;
  overflow: hidden;
}

.azu-settings-list.azu-popup-scroll {
  overflow-y: auto;
  max-height: 240px;
}

.azu-settings-list-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 16px;
  background: transparent;
  border: none;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
  color: white;
  cursor: pointer;
  transition: background 0.2s;
  width: 100%;
}

.azu-settings-list-item:last-child {
  border-bottom: none;
}

.azu-settings-list-item:hover {
  background: rgba(255, 255, 255, 0.12);
}

.list-left {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 14px;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.9);
}

.list-right {
  color: rgba(255, 255, 255, 0.3);
  font-size: 18px;
  font-weight: 300;
}
/* Ã¢â€â‚¬Ã¢â€â‚¬ Player accent uses global --accent tokens from index.css Ã¢â€â‚¬Ã¢â€â‚¬ */
:root {
  --pc: var(--accent);
  --pc-hover: var(--accent-hover);
  --pc-glow: var(--accent-glow);
  --pc-muted: var(--accent-muted);
  --pc-border: var(--accent-border);
  --panel: rgba(12, 16, 25, 0.88);
  --glass: rgba(255, 255, 255, 0.05);
  --border: rgba(255, 255, 255, 0.09);
}

::cue {
  background: rgba(0,0,0,0.72);
  color: #fff;
  font-size: 1.05em;
  padding: 2px 5px;
  border-radius: 3px;
}

/* Ã¢â€â‚¬Ã¢â€â‚¬ Outer wrapper Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬ */
.player-outer-wrapper {
  margin-top: clamp(2rem, 3.5vw, 3rem);
  padding: clamp(1.5rem, 2.5vw, 2rem);
  border-radius: 20px;
  background:
    linear-gradient(135deg, rgba(255,255,255,0.08), rgba(255,255,255,0.02) 48%, rgba(255,255,255,0.04)),
    rgba(10,10,10,0.48);
  border: 1.5px solid rgba(255,255,255,0.12);
  box-shadow:
    0 28px 80px rgba(0,0,0,0.28),
    inset 0 1px 0 rgba(255,255,255,0.08);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
}

/* ── Premium Tab Bar ────────────────────────────────────────────── */
.premium-tab-bar {
  display: flex;
  justify-content: flex-start;
  margin-bottom: 1.5rem;
}
.premium-tab-track {
  display: inline-flex;
  gap: 8px;
  background: rgba(255,255,255,0.05);
  padding: 6px;
  border-radius: 99px;
  border: 1px solid rgba(255,255,255,0.05);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  box-shadow: inset 0 2px 10px rgba(0,0,0,0.1);
}
.premium-tab {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 24px;
  background: transparent;
  border: none;
  border-radius: 99px;
  color: rgba(255,255,255,0.6);
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.2, 0.8, 0.2, 1);
  position: relative;
  overflow: hidden;
}
.premium-tab::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,0.1), transparent);
  opacity: 0;
  transition: opacity 0.3s;
}
.premium-tab:hover {
  color: rgba(255,255,255,0.9);
  background: rgba(255,255,255,0.05);
}
.premium-tab:hover::before { opacity: 1; }
.premium-tab.active {
  background: rgba(255, 255, 255, 0.15);
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.3);
  box-shadow: 0 4px 20px rgba(255, 255, 255, 0.1);
}
.pt-icon {
  transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}
.premium-tab.active .pt-icon {
  transform: scale(1.15) rotate(-5deg);
  filter: drop-shadow(0 0 4px rgba(255,255,255,0.6));
}
.pt-text {
  letter-spacing: 0.03em;
}
/* Ã¢â€â‚¬Ã¢â€â‚¬ Player shell Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬ */
.player-shell {
  width: 100%;
  aspect-ratio: 16/9;
  background: #000;
  border-radius: 16px;
  overflow: hidden;
  box-shadow:
    0 32px 80px rgba(0,0,0,0.6),
    inset 0 1px 0 rgba(255,255,255,0.08);
  position: relative;
  border: 1px solid rgba(255,255,255,0.08);
}

/* Ã¢â€â‚¬Ã¢â€â‚¬ Pro wrapper Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬ */
.pro-wrapper {
  width: 100%;
  height: 100%;
  position: relative;
  background: #000;
}
.pro-video {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

/* Ã¢â€â‚¬Ã¢â€â‚¬ Splash Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬ */
.pro-splash {
  width: 100%;
  height: 100%;
  position: relative;
  cursor: pointer;
  overflow: hidden;
}
.splash-bg {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.7s ease;
}
.pro-splash:hover .splash-bg { transform: scale(1.04); }
.splash-veil {
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 50% 50%, rgba(0,0,0,0.35) 0%, rgba(0,0,0,0.78) 100%);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 24px;
}
.splash-play-ring {
  width: 84px;
  height: 84px;
  border-radius: 50%;
  background: rgba(255,255,255,0.1);
  backdrop-filter: blur(12px);
  border: 2px solid rgba(255,255,255,0.18);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  transition: all 0.35s cubic-bezier(0.175,0.885,0.32,1.275);
}
.pro-splash:hover .splash-play-ring {
  transform: scale(1.12);
  background: var(--pc);
  border-color: var(--pc);
  box-shadow: 0 0 40px var(--pc-glow);
}
.splash-text { text-align: center; color: #fff; }
.splash-text h2 { margin: 0 0 6px; font-size: 1.6rem; font-weight: 700; }
.splash-text p  { margin: 0; font-size: 0.9rem; color: rgba(255,255,255,0.55); }

/* Ã¢â€â‚¬Ã¢â€â‚¬ Loading Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬ */
.pro-loading {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 18px;
  color: #fff;
  background: rgba(0,0,0,0.6);
  backdrop-filter: blur(6px);
  z-index: 20;
}
.pro-spinner-wrap { position: relative; display: flex; align-items: center; justify-content: center; }
.pro-spinner { animation: spin 1.1s linear infinite; color: var(--pc); filter: drop-shadow(0 0 8px var(--pc-glow)); }
.pro-spinner-glow {
  position: absolute;
  width: 90px; height: 90px;
  background: radial-gradient(circle, var(--pc) 0%, transparent 70%);
  opacity: 0.25;
  animation: pulse-glow 2s var(--ease-spring) infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
@keyframes pulse-glow { 0%,100% { transform: scale(0.8); opacity: 0.2; } 50% { transform: scale(1.2); opacity: 0.4; } }

/* Ã¢â€â‚¬Ã¢â€â‚¬ Error Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬ */
.pro-error {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 14px;
  color: #fff;
  background: rgba(0,0,0,0.75);
  z-index: 20;
  text-align: center;
  padding: 20px;
}
.pro-error p { margin: 0; font-size: 0.95rem; color: rgba(255,255,255,0.7); }
.pro-retry-btn, .pro-switch-btn {
  padding: 9px 22px;
  border-radius: 8px;
  font-size: 0.85rem;
  font-weight: 600;
  cursor: pointer;
  border: none;
  transition: all 0.2s;
}
.pro-retry-btn  { background: var(--pc); color: #fff; }
.pro-switch-btn { background: rgba(255,255,255,0.1); color: #fff; border: 1px solid var(--border); }
.pro-retry-btn:hover  { background: var(--pc-hover); }
.pro-switch-btn:hover { background: rgba(255,255,255,0.18); }

/* Ã¢â€â‚¬Ã¢â€â‚¬ Top bar Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬ */
.pro-topbar {
  position: absolute;
  top: 0; left: 0; right: 0;
  padding: 36px 28px 20px;
  background: var(--gradient-player-top);
  display: flex;
  align-items: center;
  gap: 16px;
  opacity: 0;
  transition: opacity 0.35s;
  z-index: 50;
}
.pro-topbar.vis { opacity: 1; }
.pro-back {
  background: rgba(255,255,255,0.1);
  border: none;
  color: #fff;
  cursor: pointer;
  padding: 8px;
  border-radius: 50%;
  display: flex;
  transition: background 0.2s;
}
.pro-back:hover { background: rgba(255,255,255,0.2); }
.pro-title-wrap { flex: 1; }
.pro-title { display: block; font-size: 1.1rem; font-weight: 700; color: #fff; }
.pro-ep    { font-size: 0.8rem; color: rgba(255,255,255,0.55); }
.pro-source-badge {
  font-size: 0.72rem;
  font-weight: 700;
  padding: 4px 10px;
  background: rgba(255,255,255,0.1);
  border: 1px solid var(--border);
  border-radius: 20px;
  color: rgba(255,255,255,0.7);
  letter-spacing: 0.04em;
}

/* Ã¢â€â‚¬Ã¢â€â‚¬ Side panel (sources) Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬ */
.side-panel {
  position: absolute;
  top: 0; right: -300px; bottom: 0;
  width: 300px;
  background: var(--panel);
  backdrop-filter: blur(28px);
  border-left: 1px solid var(--border);
  z-index: 80;
  display: flex;
  flex-direction: column;
  transition: right 0.4s cubic-bezier(0.4,0,0.2,1);
}
.side-panel.open { right: 0; }
.side-panel-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 20px 14px;
  font-size: 0.95rem;
  font-weight: 700;
  color: #fff;
  border-bottom: 1px solid var(--border);
}
.side-panel-head button { background: none; border: none; color: rgba(255,255,255,0.5); cursor: pointer; }
.badge-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px; height: 20px;
  background: var(--pc);
  border-radius: 50%;
  font-size: 0.7rem;
  margin-left: 6px;
}
.side-panel-body { flex: 1; overflow-y: auto; padding: 14px; }
.src-group { margin-bottom: 16px; }
.src-group-label {
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--pc);
  font-weight: 700;
  margin-bottom: 8px;
}
.src-item {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  background: var(--glass);
  border: 1px solid var(--border);
  border-radius: 10px;
  color: rgba(255,255,255,0.8);
  font-size: 0.82rem;
  cursor: pointer;
  margin-bottom: 6px;
  transition: all 0.2s;
  text-align: left;
}
.src-item:hover { background: rgba(255,255,255,0.09); }
.src-item.active { background: var(--pc-border); border-color: var(--pc); color: var(--pc); }
.src-quality {
  background: rgba(255,255,255,0.1);
  padding: 2px 6px;
  border-radius: 4px;
  font-size: 0.68rem;
  font-weight: 700;
}
.src-name { flex: 1; }

/* Ã¢â€â‚¬Ã¢â€â‚¬ Float panels (subtitle / settings) Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬ */
.float-panel {
  position: absolute;
  bottom: 110px;
  right: 24px;
  width: 320px;
  background: var(--panel);
  backdrop-filter: blur(28px);
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 18px;
  z-index: 75;
  display: flex;
  flex-direction: column;
  gap: 12px;
  box-shadow: 0 20px 50px rgba(0,0,0,0.6);
}
@keyframes slide-up { from { opacity:0; transform:translateY(12px); } to { opacity:1; transform:translateY(0); } }
.animate-slide-up { animation: slide-up 0.25s ease-out; }

.float-panel-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.float-panel-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.95rem;
  font-weight: 700;
  color: #fff;
}
.float-panel-head button { background: none; border: none; color: rgba(255,255,255,0.45); cursor: pointer; }

/* subtitle search */
.sub-search-wrap { position: relative; }
.sub-search-icon { position: absolute; left: 12px; top: 50%; transform: translateY(-50%); color: rgba(255,255,255,0.3); }
.sub-search {
  width: 100%;
  background: var(--glass);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 10px 14px 10px 38px;
  color: #fff;
  font-size: 0.85rem;
  outline: none;
  box-sizing: border-box;
}
.upload-sub {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 10px;
  background: var(--accent-muted);
  border: 1px dashed var(--accent-border);
  border-radius: 10px;
  color: rgba(255,255,255,0.7);
  font-size: 0.82rem;
  cursor: pointer;
  transition: all 0.2s;
}
.upload-sub:hover { background: var(--pc-border); border-color: var(--pc); }
.sub-list { max-height: 260px; overflow-y: auto; display: flex; flex-direction: column; gap: 5px; }
.sub-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 9px 10px;
  background: var(--glass);
  border: 1px solid transparent;
  border-radius: 10px;
  cursor: pointer;
  transition: all 0.18s;
  width: 100%;
  text-align: left;
}
.sub-row:hover { background: rgba(255,255,255,0.08); }
.sub-row.active { background: var(--pc-muted); border-color: var(--pc-border); }
.sub-flag-box {
  width: 30px; height: 20px;
  background: rgba(255,255,255,0.08);
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,0.5);
  flex-shrink: 0;
}
.sub-flag-img { width: 30px; height: 20px; border-radius: 4px; object-fit: cover; flex-shrink: 0; }
.sub-label { flex: 1; font-size: 0.85rem; color: rgba(255,255,255,0.85); }
.sub-check-icon { color: var(--pc); flex-shrink: 0; }
.sub-list::-webkit-scrollbar { width: 4px; }
.sub-list::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.1); border-radius: 4px; }

/* settings */
.settings-section { display: flex; flex-direction: column; gap: 10px; }
.settings-label { font-size: 0.78rem; color: rgba(255,255,255,0.45); font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em; }
.speed-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 7px; }
.speed-btn {
  padding: 8px 4px;
  background: var(--glass);
  border: 1px solid var(--border);
  border-radius: 8px;
  color: rgba(255,255,255,0.75);
  font-size: 0.8rem;
  cursor: pointer;
  transition: all 0.18s;
}
.speed-btn.active { background: var(--pc-border); border-color: var(--pc); color: var(--pc); font-weight: 700; }
.speed-btn:hover:not(.active) { background: rgba(255,255,255,0.09); }

/* Ã¢â€â‚¬Ã¢â€â‚¬ Bottom controls Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬ */
.pro-controls {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 48px 24px 22px;
  background: linear-gradient(transparent, rgba(0,0,0,0.92));
  opacity: 0;
  transition: opacity 0.35s;
  z-index: 60;
}
.pro-controls.vis { opacity: 1; }

.pro-progress-wrap { margin-bottom: 12px; }
.pro-progress {
  width: 100%;
  height: 4px;
  -webkit-appearance: none;
  appearance: none;
  background: linear-gradient(to right, var(--pc) var(--pct, 0%), rgba(255,255,255,0.2) var(--pct, 0%));
  border-radius: 4px;
  outline: none;
  cursor: pointer;
  transition: height 0.15s;
}
.pro-progress:hover { height: 6px; }
.pro-progress::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 14px; height: 14px;
  background: #fff;
  border-radius: 50%;
  box-shadow: 0 0 8px rgba(0,0,0,0.5);
  cursor: pointer;
}
.pro-time {
  display: flex;
  justify-content: space-between;
  color: rgba(255,255,255,0.5);
  font-size: 0.78rem;
  margin-top: 6px;
}

.pro-ctrl-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.ctrl-left, .ctrl-right { display: flex; align-items: center; gap: 20px; }
.ctrl-btn {
  background: none;
  border: none;
  color: rgba(255,255,255,0.85);
  cursor: pointer;
  padding: 0;
  display: flex;
  transition: color 0.15s, transform 0.15s;
}
.ctrl-btn:hover { color: #fff; transform: scale(1.12); }
.ctrl-btn.active { color: var(--pc); }
.play-btn { color: #fff; }

.vol-wrap { display: flex; align-items: center; gap: 8px; }
.vol-slider {
  width: 0;
  height: 3px;
  -webkit-appearance: none;
  appearance: none;
  background: rgba(255,255,255,0.25);
  border-radius: 3px;
  outline: none;
  opacity: 0;
  transition: width 0.25s, opacity 0.25s;
}
.vol-wrap:hover .vol-slider { width: 72px; opacity: 1; }
.vol-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 10px; height: 10px;
  background: #fff;
  border-radius: 50%;
}

/* Ã¢â€â‚¬Ã¢â€â‚¬ Iframe tab Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬ */
/* ── Iframe Tab & Premium Server Overlay ─────────────────────── */
.iframe-tab-wrapper {
  width: 100%;
  height: 100%;
  position: relative;
}
.iframe-main {
  width: 100%;
  height: 100%;
  background: #000;
}
.iframe-player {
  width: 100%;
  height: 100%;
  border: none;
  display: block;
}

.server-overlay {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  justify-content: center;
  align-items: center;
  pointer-events: none;
  opacity: 0;
  visibility: hidden;
  transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}
.server-overlay.show {
  pointer-events: auto;
  opacity: 1;
  visibility: visible;
}
.server-overlay-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.6);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.server-overlay-content {
  position: relative;
  width: 90%;
  max-width: 700px;
  max-height: 85%;
  background: rgba(14, 16, 21, 0.85);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 20px;
  box-shadow: 0 30px 80px rgba(0,0,0,0.8), inset 0 1px 1px rgba(255,255,255,0.1);
  display: flex;
  flex-direction: column;
  transform: translateY(20px) scale(0.96);
  transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}
.server-overlay.show .server-overlay-content {
  transform: translateY(0) scale(1);
}

.server-overlay-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 24px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.server-overlay-header h2 {
  margin: 0;
  font-size: 1.1rem;
  font-weight: 700;
  color: #fff;
  display: flex;
  align-items: center;
  gap: 10px;
}
.server-overlay-header h2 svg { color: var(--pc); }
.btn-close-overlay {
  background: rgba(255,255,255,0.05);
  border: none;
  color: rgba(255,255,255,0.6);
  width: 32px;
  height: 32px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.2s;
}
.btn-close-overlay:hover {
  background: rgba(255,50,50,0.2);
  color: #ff6b6b;
  transform: rotate(90deg);
}

.server-overlay-body {
  padding: 24px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.server-overlay-body::-webkit-scrollbar { width: 6px; }
.server-overlay-body::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.1); border-radius: 6px; }

.server-group-block {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.server-group-title {
  margin: 0;
  font-size: 0.75rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(255,255,255,0.4);
}
.server-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 12px;
}
.server-card {
  display: flex;
  align-items: center;
  gap: 12px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.05);
  padding: 14px;
  border-radius: 12px;
  cursor: pointer;
  text-align: left;
  transition: all 0.25s cubic-bezier(0.2, 0.8, 0.2, 1);
  position: relative;
}
.server-card:hover {
  background: rgba(255,255,255,0.07);
  border-color: rgba(255,255,255,0.15);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.3);
}
.server-card.active {
  background: rgba(59, 130, 246, 0.15);
  border-color: var(--pc);
  box-shadow: 0 4px 20px var(--pc-glow);
}
.server-card-icon {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: rgba(255,255,255,0.06);
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,0.7);
  transition: all 0.3s;
}
.server-card.active .server-card-icon {
  background: var(--pc);
  color: #fff;
}
.server-card-info {
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex: 1;
}
.server-name {
  font-size: 0.9rem;
  font-weight: 600;
  color: rgba(255,255,255,0.9);
}
.server-card.active .server-name {
  color: var(--pc);
}
.server-ping {
  font-size: 0.7rem;
  font-weight: 700;
  color: #10b981;
}
.server-active-check {
  color: var(--pc);
  position: absolute;
  top: 14px;
  right: 14px;
  filter: drop-shadow(0 0 4px var(--pc-glow));
}
/* Ã¢â€â‚¬Ã¢â€â‚¬ Responsive Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬Ã¢â€â‚¬ */
@media (max-width: 768px) {
  .player-shell { aspect-ratio: 16/9; border-radius: 10px; }
  .pro-topbar .pro-title { font-size: 0.9rem; }
  .side-panel { width: 100%; right: -100%; }
  .player-tab-bar {
    gap: 0.6rem;
    padding: 0.5rem;
    flex-wrap: wrap;
  }
  .ptab {
    padding: 0.65rem 1.1rem;
    font-size: 0.8rem;
    min-height: 40px;
  }
  .pro-wrapper {
    width: 100%;
    height: 100%;
  }
  .float-panel { width: calc(100% - 32px); left: 16px; right: 16px; bottom: 100px; }
  .ctrl-left, .ctrl-right { gap: 14px; }
  .iframe-sidebar { width: 160px; }
  .iframe-srv-btn { font-size: 0.74rem; padding: 7px 8px; }
  .iframe-group-header { font-size: 0.72rem; padding: 9px 12px; }
}
@media (max-width: 480px) {
  .iframe-tab-wrapper {
    position: relative;
    flex-direction: column;
  }

  .iframe-sidebar {
    position: fixed;
    left: 0;
    top: 0;
    width: 280px;
    height: 100vh;
    max-height: 100vh;
    flex-direction: column;
    overflow-y: auto;
    overflow-x: hidden;
    border-right: 1px solid var(--border);
    border-bottom: none;
    background: rgba(8, 8, 8, 0.98);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    z-index: 1000;
    transform: translateX(-100%);
    transition: transform 0.3s var(--ease-spring);
    box-shadow: 0 0 40px rgba(0, 0, 0, 0.6);
  }

  .iframe-tab-wrapper.show-servers .iframe-sidebar {
    transform: translateX(0);
  }

  .iframe-tab-wrapper::before {
    content: '';
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s, visibility 0.3s;
    z-index: 999;
    pointer-events: none;
  }

  .iframe-tab-wrapper.show-servers::before {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }

  .iframe-sidebar-title {
    display: block;
    padding: 1rem;
    font-size: 0.9rem;
    font-weight: 700;
    border-bottom: 1px solid var(--border);
  }

  .iframe-sidebar-note {
    display: block;
    margin-top: auto;
    padding: 1rem;
    font-size: 0.7rem;
    border-top: 1px solid var(--border);
  }

  .iframe-group {
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
    border-right: none;
  }

  .iframe-group-header {
    padding: 0.75rem 1rem;
    white-space: normal;
    font-size: 0.8rem;
  }

  .iframe-group-items {
    flex-direction: column;
    padding: 0.5rem 0;
  }

  .iframe-srv-btn {
    font-size: 0.78rem;
    padding: 0.7rem 1rem;
    border-radius: 0;
  }

  .iframe-main {
    flex: 1;
    min-height: 0;
    width: 100%;
  }
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   VIDSTACK PRO PLAYER â€“ Netflix-style theme
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

/* Player positioning â€” fills the pro-wrapper */
media-player.pro-vidstack-player {
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0;
  background: #000;
  border-radius: 0;
  z-index: 1;
}

/* Netflix accent */
media-player.netflix-player {
  --media-brand: var(--accent);
  --media-brand-dim: rgba(229, 9, 20, 0.25);
  --media-font-family: 'Inter', sans-serif;
}

/* Cinematic gradient overlay */
.media-player.netflix-player::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.6) 0%,
    transparent 30%,
    transparent 70%,
    rgba(0, 0, 0, 0.7) 100%
  );
  pointer-events: none;
  z-index: 10;
}

/* Title overlay â€” visible when paused, hidden on play */
.netflix-title-overlay {
  position: absolute;
  bottom: 140px;
  left: 32px;
  z-index: 55;
  pointer-events: none;
  display: flex;
  flex-direction: column;
  gap: 6px;
  max-width: 600px;
}
.netflix-badge {
  display: inline-flex;
  align-items: center;
  background: var(--accent);
  color: #fff;
  font-size: 0.68rem;
  font-weight: 800;
  padding: 3px 10px;
  border-radius: 4px;
  letter-spacing: 0.06em;
  width: fit-content;
  text-transform: uppercase;
}
.netflix-title-overlay h1 {
  margin: 0;
  font-size: 2rem;
  font-weight: 800;
  color: #fff;
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.7);
  letter-spacing: -0.02em;
  line-height: 1.15;
}
.netflix-title-overlay p {
  margin: 0;
  font-size: 0.88rem;
  color: rgba(255, 255, 255, 0.6);
  font-weight: 500;
}

/* Hide title overlay when playing */
.media-player.netflix-player[data-playing] .netflix-title-overlay {
  opacity: 0;
  transform: translateY(10px);
  transition: all 0.35s ease;
}

/* Seek slider accent */
.media-player.netflix-player [role="slider"] {
  accent-color: #e50914;
}

/* Controls z-index */
.media-player.netflix-player .vds-controls {
  z-index: 20;
}

/* Cinematic captions */
.media-player.netflix-player .vds-captions {
  font-size: 1.08rem;
  text-shadow: 0 1px 6px rgba(0, 0, 0, 0.6);
}

/* â”€â”€ Custom subtitle / source buttons â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.pro-custom-buttons {
  position: absolute;
  bottom: 80px;
  right: 24px;
  display: flex;
  gap: 12px;
  z-index: 65;
}
.pro-btn {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.8);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  padding: 0;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  transition: all 0.2s ease;
}
.pro-btn:hover {
  background: rgba(255, 255, 255, 0.16);
  color: #fff;
  transform: scale(1.08);
}
.pro-btn.active {
  color: #e50914;
  background: rgba(229, 9, 20, 0.15);
  border-color: rgba(229, 9, 20, 0.4);
}

/* â”€â”€ Netflix Responsive â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
@media (max-width: 768px) {
  .netflix-title-overlay {
    bottom: 120px;
    left: 18px;
    max-width: 85%;
  }
  .netflix-title-overlay h1 {
    font-size: 1.4rem;
  }
  .netflix-title-overlay p {
    font-size: 0.8rem;
  }
  .pro-custom-buttons {
    bottom: 60px;
    right: 16px;
    gap: 10px;
  }
  .pro-btn {
    width: 34px;
    height: 34px;
  }
}
@media (max-width: 480px) {
  .netflix-title-overlay {
    bottom: 110px;
    left: 14px;
  }
  .netflix-title-overlay h1 {
    font-size: 1.15rem;
  }
}

 . a n i m e - d u b - s e l e c t o r   { 
     d i s p l a y :   f l e x ; 
     a l i g n - i t e m s :   c e n t e r ; 
     j u s t i f y - c o n t e n t :   f l e x - e n d ; 
     g a p :   1 0 p x ; 
     m a r g i n - b o t t o m :   1 2 p x ; 
     p a d d i n g :   0   1 0 p x ; 
 } 
 . d u b - l a b e l   { 
     c o l o r :   # 9 c a 3 a f ; 
     f o n t - s i z e :   0 . 9 r e m ; 
     f o n t - w e i g h t :   5 0 0 ; 
 } 
 . d u b - s e l e c t   { 
     b a c k g r o u n d :   r g b a ( 2 5 5 ,   2 5 5 ,   2 5 5 ,   0 . 0 5 ) ; 
     b o r d e r :   1 p x   s o l i d   r g b a ( 2 5 5 ,   2 5 5 ,   2 5 5 ,   0 . 1 ) ; 
     c o l o r :   # f f f ; 
     p a d d i n g :   6 p x   1 2 p x ; 
     b o r d e r - r a d i u s :   6 p x ; 
     f o n t - s i z e :   0 . 9 r e m ; 
     o u t l i n e :   n o n e ; 
     c u r s o r :   p o i n t e r ; 
     t r a n s i t i o n :   a l l   0 . 2 s   e a s e ; 
 } 
 . d u b - s e l e c t : h o v e r   { 
     b a c k g r o u n d :   r g b a ( 2 5 5 ,   2 5 5 ,   2 5 5 ,   0 . 1 ) ; 
     b o r d e r - c o l o r :   r g b a ( 2 5 5 ,   2 5 5 ,   2 5 5 ,   0 . 2 ) ; 
 } 
 . d u b - s e l e c t   o p t i o n   { 
     b a c k g r o u n d :   # 1 1 1 ; 
     c o l o r :   # f f f ; 
 } 
  
 .trailer-modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background-color: rgba(0, 0, 0, 0.85);
  backdrop-filter: blur(5px);
  z-index: 9999;
  display: flex;
  justify-content: center;
  align-items: center;
  animation: modalFadeIn var(--duration-normal) var(--ease-spring);
}

@keyframes modalFadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

.trailer-modal-content {
  position: relative;
  width: 90%;
  max-width: 900px;
  background: #000;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.5);
  animation: modalScaleUp var(--duration-normal) var(--ease-spring);
}

@keyframes modalScaleUp {
  from { transform: scale(0.95); opacity: 0; }
  to { transform: scale(1); opacity: 1; }
}

.close-modal-btn {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 10;
  background: rgba(0, 0, 0, 0.5);
  border: none;
  color: white;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
  transition: all 0.2s;
}

.close-modal-btn:hover {
  background: var(--primary-color, var(--accent));
  transform: rotate(90deg);
}

.video-responsive {
  overflow: hidden;
  padding-bottom: 56.25%; /* 16:9 aspect ratio */
  position: relative;
  height: 0;
}

.video-responsive iframe {
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
  position: absolute;
}
/* Azu Cast List — Premium Editorial */
.cast-section {
  margin: clamp(2.5rem, 4vw, 3.5rem) 0;
}

.cast-container {
  position: relative;
  display: flex;
  align-items: center;
}

.cast-list {
  display: flex;
  overflow-x: auto;
  gap: clamp(1.2rem, 2vw, 1.8rem);
  padding: 0.5rem 0;
  scroll-behavior: smooth;
  scroll-snap-type: x proximity;
  scrollbar-width: none;
  -ms-overflow-style: none;
  mask-image: linear-gradient(to right, black 92%, transparent);
  -webkit-mask-image: linear-gradient(to right, black 92%, transparent);
}

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

.cast-card {
  flex: 0 0 auto;
  width: 140px;
  text-align: center;
  transition: all var(--duration-normal) var(--ease-spring);
  scroll-snap-align: start;
  position: relative;
}

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

.cast-card:hover {
  transform: translateY(-8px);
}

.cast-img-wrapper {
  width: 140px;
  height: 140px;
  border-radius: 50%;
  overflow: hidden;
  margin-bottom: 1rem;
  box-shadow:
    0 20px 50px rgba(0, 0, 0, 0.4),
    inset 0 1px 0 rgba(255,255,255,0.1);
  border: 2px solid rgba(255,255,255,0.08);
  transition: all var(--duration-normal) var(--ease-spring);
  position: relative;
  background: rgba(255,255,255,0.035);
}

.cast-card:hover .cast-img-wrapper {
  border-color: #f6f3ea;
  box-shadow:
    0 28px 64px rgba(246,243,234,0.16),
    inset 0 1px 0 rgba(255,255,255,0.15);
  transform: scale(1.04);
}

.cast-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(0.95) contrast(1.05);
  transition: filter var(--duration-normal) var(--ease-spring);
}

.cast-card:hover .cast-img {
  filter: brightness(1) contrast(1.1);
}

.cast-img-placeholder {
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, rgba(255,255,255,0.08), rgba(255,255,255,0.02));
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.2rem;
  font-weight: bold;
  color: rgba(255,255,255,0.32);
}

.cast-name {
  font-size: 0.95rem;
  font-weight: 800;
  margin: 0 0 0.35rem 0;
  color: var(--text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  letter-spacing: -0.02em;
}

.cast-character {
  font-size: 0.8rem;
  color: rgba(255,255,255,0.62);
  margin: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-weight: 600;
}

.cast-scroll-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  background: rgba(255,255,255,0.065);
  border: 1.5px solid rgba(255,255,255,0.12);
  color: rgba(255,255,255,0.68);
  width: 42px;
  height: 42px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all var(--duration-normal) var(--ease-spring);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  box-shadow: 0 12px 32px rgba(0,0,0,0.2);
}

.cast-scroll-btn:hover {
  background: #f6f3ea;
  border-color: #f6f3ea;
  color: #050505;
  transform: translateY(-50%) scale(1.08);
  box-shadow: 0 16px 48px rgba(246,243,234,0.16);
}

.cast-scroll-btn.left {
  left: -20px;
}

.cast-scroll-btn.right {
  right: -20px;
}

@media (max-width: 768px) {
  .cast-card {
    width: 120px;
  }

  .cast-img-wrapper {
    width: 120px;
    height: 120px;
    margin-bottom: 0.8rem;
  }

  .cast-name {
    font-size: 0.85rem;
  }

  .cast-character {
    font-size: 0.75rem;
  }

  .cast-scroll-btn {
    width: 36px;
    height: 36px;
  }

  .cast-scroll-btn.left {
    left: -10px;
  }

  .cast-scroll-btn.right {
    right: -10px;
  }
}

@media (max-width: 480px) {
  .cast-card {
    width: 100px;
  }

  .cast-img-wrapper {
    width: 100px;
    height: 100px;
    margin-bottom: 0.6rem;
  }

  .cast-name {
    font-size: 0.78rem;
  }

  .cast-character {
    font-size: 0.7rem;
  }
}
/* Azu Season Episodes — Premium Cinematic Cards */
.season-episodes-container {
  margin-top: clamp(2.5rem, 4vw, 3.5rem);
  margin-bottom: clamp(3rem, 5vw, 4rem);
}

.season-episodes-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: clamp(1.5rem, 2.5vw, 2rem);
  gap: 1rem;
}

.season-controls {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.btn-sort {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  background: rgba(255,255,255,0.055);
  color: rgba(255,255,255,0.78);
  border: 1px solid rgba(255,255,255,0.1);
  padding: 0.6rem 1.2rem;
  border-radius: 12px;
  font-size: 0.85rem;
  font-weight: 750;
  cursor: pointer;
  transition: all var(--duration-normal) var(--ease-spring);
  font-family: inherit;
}

.btn-sort:hover {
  background: rgba(255,255,255,0.1);
  border-color: rgba(255,255,255,0.15);
  color: #f6f3ea;
}

.season-dropdown {
  position: relative;
}

.season-dropdown-btn {
  display: flex;
  align-items: center;
  gap: 0.8rem;
  background: rgba(255,255,255,0.055);
  color: rgba(255,255,255,0.78);
  border: 1px solid rgba(255,255,255,0.1);
  padding: 0.6rem 1.2rem;
  border-radius: 12px;
  font-size: 0.85rem;
  font-weight: 750;
  cursor: pointer;
  transition: all var(--duration-normal) var(--ease-spring);
  min-width: 140px;
  justify-content: space-between;
  font-family: inherit;
}

.season-dropdown-btn:hover, .season-dropdown-btn:focus {
  background: rgba(255,255,255,0.1);
  border-color: rgba(255,255,255,0.15);
  color: #f6f3ea;
}

.dropdown-icon {
  transition: transform var(--duration-normal) var(--ease-spring);
}

.dropdown-icon.open {
  transform: rotate(180deg);
}

.season-dropdown-menu {
  position: absolute;
  top: 100%;
  right: 0;
  margin-top: 0.8rem;
  background: rgba(10,10,10,0.92);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 14px;
  width: 220px;
  max-height: 320px;
  overflow-y: auto;
  z-index: 100;
  box-shadow: 0 20px 60px rgba(0,0,0,0.5);
  display: flex;
  flex-direction: column;
  padding: 0.5rem 0;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}

.season-dropdown-menu::-webkit-scrollbar {
  width: 6px;
}

.season-dropdown-menu::-webkit-scrollbar-track {
  background: transparent;
}

.season-dropdown-menu::-webkit-scrollbar-thumb {
  background-color: rgba(255,255,255,0.2);
  border-radius: 10px;
}

.season-dropdown-item {
  background: none;
  border: none;
  color: rgba(255,255,255,0.68);
  padding: 0.75rem 1.2rem;
  text-align: left;
  font-size: 0.85rem;
  font-weight: 650;
  cursor: pointer;
  transition: all var(--duration-normal) var(--ease-spring);
  font-family: inherit;
}

.season-dropdown-item:hover {
  background: rgba(255,255,255,0.08);
  color: #f6f3ea;
}

.season-dropdown-item.active {
  color: #f6f3ea;
  background: rgba(246,243,234,0.12);
  font-weight: 800;
}

.episodes-list-wrapper {
  position: relative;
  display: flex;
  align-items: center;
}

.scroll-btn {
  position: absolute;
  top: 40%;
  transform: translateY(-50%);
  z-index: 10;
  background: rgba(255,255,255,0.065);
  color: rgba(255,255,255,0.68);
  border: 1.5px solid rgba(255,255,255,0.12);
  border-radius: 50%;
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  transition: all var(--duration-normal) var(--ease-spring);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.2);
}

.scroll-btn:hover {
  background: #f6f3ea;
  border-color: #f6f3ea;
  color: #050505;
  transform: translateY(-50%) scale(1.08);
  box-shadow: 0 16px 48px rgba(246,243,234,0.16);
}

.scroll-left {
  left: -20px;
}

.scroll-right {
  right: -20px;
}

.episodes-list {
  display: flex;
  gap: clamp(1.2rem, 2vw, 1.8rem);
  overflow-x: auto;
  padding-bottom: 1.5rem;
  scroll-behavior: smooth;
  scroll-snap-type: x proximity;
  scrollbar-width: none;
  -ms-overflow-style: none;
  width: 100%;
  mask-image: linear-gradient(to right, black 92%, transparent);
  -webkit-mask-image: linear-gradient(to right, black 92%, transparent);
}

.episodes-list::-webkit-scrollbar {
  display: none;
}

.episode-card {
  min-width: 320px;
  max-width: 320px;
  border-radius: 16px;
  background: rgba(255,255,255,0.035);
  cursor: pointer;
  transition: all var(--duration-normal) var(--ease-spring);
  opacity: 0.72;
  scroll-snap-align: start;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.065);
  box-shadow: 0 16px 40px rgba(0,0,0,0.24);
}

.episode-card:hover {
  opacity: 1;
  transform: translateY(-8px);
  border-color: rgba(255,255,255,0.12);
  box-shadow: 0 24px 60px rgba(0,0,0,0.32);
}

.episode-card.active {
  opacity: 1;
  border-color: #f6f3ea;
  box-shadow: 0 24px 60px rgba(246,243,234,0.12);
}

.episode-thumbnail-container {
  position: relative;
  width: 100%;
  aspect-ratio: 16/9;
  border-radius: 12px;
  overflow: hidden;
  margin-bottom: 1rem;
  border: 1px solid rgba(255,255,255,0.08);
}

.episode-thumbnail {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(0.92) contrast(1.05);
  transition: all var(--duration-normal) var(--ease-spring);
}

.episode-card:hover .episode-thumbnail {
  transform: scale(1.06);
  filter: brightness(1) contrast(1.1);
}

.episode-badges-top {
  position: absolute;
  top: 0.8rem;
  left: 0.8rem;
  right: 0.8rem;
  display: flex;
  justify-content: space-between;
  gap: 0.6rem;
}

.badge-s-e, .badge-date {
  background: rgba(0, 0, 0, 0.72);
  color: #f6f3ea;
  padding: 0.4rem 0.8rem;
  border-radius: 6px;
  font-size: 0.75rem;
  font-weight: 800;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,0.1);
}

.episode-badges-bottom {
  position: absolute;
  bottom: 0.8rem;
  left: 0.8rem;
  right: 0.8rem;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 0.6rem;
}

.badge-rating {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  background: rgba(0, 0, 0, 0.72);
  color: #f6f3ea;
  padding: 0.4rem 0.8rem;
  border-radius: 6px;
  font-size: 0.75rem;
  font-weight: 800;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,0.1);
}

.badge-runtime {
  background: rgba(0, 0, 0, 0.72);
  color: rgba(255,255,255,0.78);
  padding: 0.4rem 0.8rem;
  border-radius: 6px;
  font-size: 0.75rem;
  font-weight: 700;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,0.1);
  margin-left: auto;
}

.episode-info {
  padding: 0 0.5rem 1rem;
}

.episode-title {
  font-size: 0.95rem;
  font-weight: 800;
  margin: 0 0 0.6rem 0;
  color: var(--text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  letter-spacing: -0.02em;
}

.episode-desc {
  font-size: 0.8rem;
  color: rgba(255,255,255,0.62);
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  line-height: 1.5;
  font-weight: 500;
}

.no-episodes {
  color: rgba(255,255,255,0.52);
  font-style: italic;
  padding: 2rem 0;
  text-align: center;
}

@media (max-width: 768px) {
  .episodes-list {
    gap: 1rem;
  }

  .episode-card {
    min-width: 280px;
    max-width: 280px;
  }

  .episode-title {
    font-size: 0.9rem;
  }

  .episode-desc {
    font-size: 0.75rem;
  }

  .scroll-btn {
    width: 38px;
    height: 38px;
  }
}

@media (max-width: 480px) {
  .episode-card {
    min-width: 240px;
    max-width: 240px;
  }

  .episode-title {
    font-size: 0.85rem;
  }

  .episode-desc {
    font-size: 0.7rem;
    -webkit-line-clamp: 1;
  }
}

/* Force cache invalidation 1 */
.dummy-class { display: none; }
/* ── Card Base ── */
.next-ep-card {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid rgba(229, 9, 20, 0.25);
  background: rgba(12, 12, 24, 0.85);
  backdrop-filter: blur(20px);
  margin-top: 2rem;
  margin-bottom: 0.5rem;
  transition: all var(--duration-normal) var(--ease-spring);
}

.next-ep-card:hover {
  border-color: rgba(229, 9, 20, 0.5);
  box-shadow: 0 8px 40px rgba(0, 0, 0, 0.5), 0 0 0 1px rgba(229, 9, 20, 0.15);
}

.next-ep-today {
  border-color: rgba(234, 179, 8, 0.4);
  box-shadow: 0 0 30px rgba(234, 179, 8, 0.1);
}

.next-ep-today:hover {
  border-color: rgba(234, 179, 8, 0.7);
  box-shadow: 0 0 50px rgba(234, 179, 8, 0.15);
}

/* ── Glow BG ── */
.next-ep-glow {
  position: absolute;
  top: -60px;
  right: -60px;
  width: 300px;
  height: 300px;
  background: radial-gradient(circle, rgba(229, 9, 20, 0.15) 0%, transparent 70%);
  pointer-events: none;
  z-index: 0;
}

.next-ep-today .next-ep-glow {
  background: radial-gradient(circle, rgba(234, 179, 8, 0.12) 0%, transparent 70%);
}

/* ── Episode Still image ── */
.next-ep-still {
  position: absolute;
  top: 0;
  right: 0;
  width: 45%;
  height: 100%;
  z-index: 0;
}

.next-ep-still img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.25;
}

.next-ep-still-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, rgba(12, 12, 24, 1) 0%, rgba(12, 12, 24, 0.3) 100%);
}

/* ── Content ── */
.next-ep-content {
  position: relative;
  z-index: 1;
  padding: 1.5rem 1.75rem;
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  max-width: 70%;
}

.next-ep-eyebrow {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #fca5a5;
}

.next-ep-today .next-ep-eyebrow {
  color: #fbbf24;
}

.next-ep-epnum {
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  color: var(--text-tertiary);
  font-family: var(--font-mono, monospace);
}

.next-ep-title {
  font-size: 1.35rem;
  font-weight: 800;
  color: var(--text-primary);
  letter-spacing: -0.02em;
  line-height: 1.2;
}

.next-ep-overview {
  font-size: 0.85rem;
  color: var(--text-tertiary);
  line-height: 1.6;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.next-ep-date {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  font-size: 0.82rem;
  color: var(--text-tertiary);
  font-weight: 500;
}

/* ── Countdown ── */
.next-ep-countdown {
  margin-top: 0.25rem;
}

.countdown-units {
  display: flex;
  align-items: center;
  gap: 0.4rem;
}

.countdown-unit {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.3rem;
}

.countdown-value {
  font-size: 2.2rem;
  font-weight: 900;
  font-family: var(--font-mono, monospace);
  letter-spacing: -0.02em;
  line-height: 1;
  color: var(--accent);
  min-width: 2.8ch;
  text-align: center;
}

.next-ep-today .countdown-value {
  color: #fbbf24;
}

.countdown-label {
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-tertiary);
}

.countdown-sep {
  font-size: 1.8rem;
  font-weight: 700;
  color: var(--text-tertiary);
  margin-bottom: 1.1rem;
  opacity: 0.4;
  align-self: flex-end;
}

/* ── Aired badge ── */
.next-ep-aired-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: rgba(16, 185, 129, 0.12);
  border: 1px solid rgba(16, 185, 129, 0.3);
  color: #6ee7b7;
  padding: 0.45rem 1rem;
  border-radius: var(--radius-full);
  font-size: 0.85rem;
  font-weight: 600;
}

/* ── Mobile ── */
@media (max-width: 640px) {
  .next-ep-content {
    max-width: 100%;
    padding: 1.25rem;
  }

  .next-ep-still {
    display: none;
  }

  .countdown-value {
    font-size: 1.7rem;
  }

  .next-ep-title {
    font-size: 1.1rem;
  }
}
.collection-banner {
  display: flex;
  align-items: center;
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-lg);
  border: 1px solid var(--accent-border);
  margin: 2rem 0;
  min-height: 110px;
  text-decoration: none;
  transition: all var(--duration-normal) var(--ease-spring);
  cursor: pointer;
}

.collection-banner:hover {
  border-color: var(--accent);
  transform: translateY(-3px);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.5), 0 0 20px var(--accent-glow);
}

.collection-banner-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.18;
  transition: opacity 0.4s ease;
}

.collection-banner:hover .collection-banner-bg {
  opacity: 0.28;
}

.collection-banner-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to right,
    rgba(8, 8, 16, 0.95) 0%,
    rgba(8, 8, 16, 0.7) 60%,
    rgba(8, 8, 16, 0.4) 100%
  );
}

.collection-banner-content {
  position: relative;
  z-index: 1;
  padding: 1.25rem 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.collection-banner-eyebrow {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--accent);
}

.collection-banner-name {
  font-size: 1.3rem;
  font-weight: 800;
  color: white;
  letter-spacing: -0.02em;
  line-height: 1.2;
}

.collection-banner-cta {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--text-tertiary);
  transition: color 0.2s;
  margin-top: 0.15rem;
}

.collection-banner:hover .collection-banner-cta {
  color: var(--accent-hover);
}

@media (max-width: 640px) {
  .collection-banner-name {
    font-size: 1.1rem;
  }
}/* Azu Details — Cinematic Premium Editorial */
.details-page {
  min-height: 100vh;
  padding-bottom: 4rem;
  background:
    radial-gradient(circle at 12% 18%, rgba(255, 255, 255, 0.035), transparent 28rem),
    radial-gradient(circle at 86% 34%, rgba(87, 64, 255, 0.055), transparent 32rem),
    transparent;
}

.details-loading {
  height: 100vh;
  width: 100%;
}

/* ── CINEMATIC BACKDROP ── */
.details-backdrop {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 75vh;
  z-index: -1;
}

.backdrop-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top;
}

.backdrop-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to top,
      var(--bg-primary) 0%,
      rgba(6, 8, 15, 0.88) 35%,
      rgba(6, 8, 15, 0.52) 65%,
      rgba(6, 8, 15, 0.18) 100%
    );
}

.details-content {
  position: relative;
  z-index: 2;
  width: min(94%, 1220px);
  margin: 0 auto;
  padding-top: clamp(2.5rem, 8vh, 5rem);
}

/* ── MAIN LAYOUT ── */
.details-main {
  display: grid;
  grid-template-columns: 300px minmax(0, 1fr);
  align-items: flex-start;
  gap: 4rem;
  margin-top: 2rem;
  margin-bottom: 4rem;
}

.details-poster-container {
  width: 300px;
  max-width: 100%;
  position: relative;
}

.poster-glow {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 90%;
  height: 90%;
  filter: blur(80px);
  opacity: 0.25;
  z-index: -1;
  border-radius: 16px;
}

.details-poster-wrapper {
  width: 100%;
  border-radius: 20px;
  overflow: hidden;
  box-shadow:
    0 28px 80px rgba(0,0,0,0.6),
    inset 0 1px 0 rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.08);
  position: relative;
  z-index: 1;
}

.details-poster {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

/* ── INFO SECTION ── */
.details-info {
  min-width: 0; /* Prevents flex/grid blowout */
}

.details-logo {
  max-width: 400px;
  max-height: 100px;
  width: 100%;
  object-fit: contain;
  object-position: left center;
  margin-bottom: 1.2rem;
  filter: drop-shadow(0 4px 12px rgba(0,0,0,0.6));
}

.details-title {
  font-size: 3.2rem;
  font-weight: 950;
  margin-bottom: 1.2rem;
  line-height: 1.05;
  text-shadow: 0 4px 16px rgba(0,0,0,0.6);
  letter-spacing: -0.08em;
}

.details-meta {
  display: flex;
  align-items: center;
  gap: 1.8rem;
  margin-bottom: 1.8rem;
  flex-wrap: wrap;
}

.meta-item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  color: rgba(255,255,255,0.72);
  font-weight: 600;
  font-size: 0.95rem;
}

.meta-badge {
  background: rgba(255, 255, 255, 0.05);
  padding: 0.35rem 0.85rem;
  border-radius: 4px;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  border: 1px solid rgba(255,255,255,0.15);
  color: #f6f3ea;
}

/* ── GENRES ── */
.details-genres {
  display: flex;
  gap: 0.85rem;
  margin-bottom: 2.2rem;
  flex-wrap: wrap;
}

.genre-pill {
  background: transparent;
  border: 1px solid rgba(255,255,255,0.2);
  color: rgba(255,255,255,0.85);
  padding: 0.35rem 1rem;
  border-radius: var(--radius-full);
  font-size: 0.8rem;
  font-weight: 600;
  backdrop-filter: blur(8px);
  transition: all var(--duration-normal) var(--ease-spring);
}

.genre-pill:hover {
  background: rgba(255,255,255,0.1);
  border-color: rgba(255,255,255,0.3);
  color: #ffffff;
}

/* ── ACTIONS ── */
.details-actions {
  display: flex;
  gap: 1rem;
  margin-bottom: 2.5rem;
  margin-top: 1.5rem;
  flex-wrap: wrap;
  align-items: center;
}

.action-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.85rem 1.6rem;
  border-radius: 12px;
  border: none;
  font-weight: 800;
  font-size: 0.95rem;
  cursor: pointer;
  transition: all var(--duration-normal) var(--ease-spring);
  font-family: inherit;
}

.play-btn {
  background: #f6f3ea;
  color: #050505;
  box-shadow: 0 16px 48px rgba(246,243,234,0.2);
}

.play-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 20px 60px rgba(246,243,234,0.28);
}

.watchlist-btn {
  background: rgba(255,255,255,0.08);
  border: 1.5px solid rgba(255,255,255,0.15);
  color: rgba(255,255,255,0.78);
}

.watchlist-btn:hover {
  background: rgba(255,255,255,0.15);
  border-color: rgba(255,255,255,0.25);
  color: #f6f3ea;
}

.watchlist-btn.added {
  background: rgba(246,243,234,0.12);
  border-color: #f6f3ea;
  color: #f6f3ea;
}

.share-btn {
  padding: 0.85rem;
  background: rgba(255,255,255,0.08);
  border: 1.5px solid rgba(255,255,255,0.15);
  color: rgba(255,255,255,0.68);
  border-radius: 10px;
}

.share-btn:hover {
  background: rgba(255,255,255,0.15);
  border-color: rgba(255,255,255,0.25);
  color: #f6f3ea;
}

@keyframes toastIn {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

.share-toast {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  background: rgba(16, 185, 129, 0.15);
  border: 1px solid rgba(16, 185, 129, 0.3);
  color: #6ee7b7;
  padding: 0.6rem 1.2rem;
  border-radius: var(--radius-full);
  font-size: 0.9rem;
  font-weight: 700;
  margin-bottom: 1.2rem;
  animation: toastIn var(--duration-normal) var(--ease-spring);
}

/* ── OVERVIEW ── */
.details-overview {
  font-size: 1.1rem;
  line-height: 1.7;
  color: rgba(255,255,255,0.82);
  max-width: 900px;
  margin-bottom: 2.5rem;
  font-weight: 500;
}

/* ── TV CONTROLS ── */
.tv-controls {
  display: flex;
  gap: 2.2rem;
  margin-bottom: 2.5rem;
  background: rgba(255,255,255,0.045);
  border: 1px solid rgba(255,255,255,0.08);
  padding: 1.5rem 2rem;
  border-radius: 16px;
  display: inline-flex;
  backdrop-filter: blur(12px);
}

.control-group {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.control-group label {
  font-size: 0.8rem;
  color: rgba(255,255,255,0.52);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.details-select {
  background: rgba(255,255,255,0.08);
  color: white;
  border: 1px solid rgba(255,255,255,0.12);
  padding: 0.65rem 1.2rem;
  border-radius: 8px;
  font-family: inherit;
  font-size: 0.95rem;
  font-weight: 700;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%23ffffff%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E");
  background-repeat: no-repeat;
  background-position: right 0.7rem top 50%;
  background-size: 0.65rem auto;
  padding-right: 2.2rem;
  transition: all var(--duration-normal) var(--ease-spring);
}

.details-select:hover {
  background-color: rgba(255,255,255,0.12);
  border-color: rgba(255,255,255,0.18);
}

.details-select:focus {
  outline: none;
  border-color: #f6f3ea;
  background-color: rgba(255,255,255,0.15);
}

.player-section {
  margin-bottom: 4rem;
}

/* ── Mobile ── */
@media (max-width: 768px) {
  .hidden-mobile {
    display: none;
  }

  .details-backdrop {
    height: 50vh;
  }

  .details-content {
    padding-top: 1.5rem;
  }

  .details-main {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
    align-items: center;
  }

  .details-poster-container {
    width: 220px;
    max-width: 100%;
    margin: 0 auto;
  }

  .details-info {
    width: 100%;
  }

  .details-title {
    font-size: clamp(1.6rem, 7vw, 2.4rem);
    margin-bottom: 0.9rem;
  }

  .details-logo {
    max-height: 70px;
  }

  .details-meta {
    gap: 1rem;
    margin-bottom: 1.2rem;
  }

  .meta-item {
    font-size: 0.85rem;
  }

  .details-genres {
    gap: 0.6rem;
    margin-bottom: 1.5rem;
  }

  .genre-pill {
    font-size: 0.78rem;
    padding: 0.35rem 0.8rem;
  }

  .details-actions {
    gap: 0.8rem;
    margin-bottom: 1.8rem;
  }

  .action-btn {
    padding: 0.7rem 1.2rem;
    font-size: 0.85rem;
  }

  .details-overview {
    font-size: 0.95rem;
    line-height: 1.6;
    margin-bottom: 1.8rem;
  }

  .tv-controls {
    flex-wrap: wrap;
    gap: 1.2rem;
    width: 100%;
    padding: 1rem;
  }

  .control-group {
    width: 100%;
  }

  .player-section {
    margin-bottom: 2.5rem;
  }
}

@media (max-width: 480px) {
  .details-poster-container {
    width: 45vw;
    max-width: 180px;
  }

  .details-meta {
    gap: 0.7rem;
  }

  .meta-item {
    font-size: 0.75rem;
  }

  .details-actions {
    width: 100%;
  }

  .action-btn {
    flex: 1;
    justify-content: center;
  }
}
.custom-select-container {
  position: relative;
  width: 100%;
  min-width: 120px;
}

.custom-select-trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.6rem;
  padding: 0;
  cursor: pointer;
  color: rgba(255, 255, 255, 0.78);
  font-size: 0.85rem;
  font-weight: 750;
  transition: color var(--duration-normal) var(--ease-spring);
}

.custom-select-trigger:hover,
.custom-select-trigger.open {
  color: #f6f3ea;
}

.custom-select-label {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.custom-select-icon {
  flex-shrink: 0;
  transition: transform 0.3s var(--ease-spring);
}

.custom-select-trigger.open .custom-select-icon {
  transform: rotate(180deg);
}

.custom-select-dropdown {
  position: absolute;
  top: calc(100% + 14px);
  left: -8px;
  min-width: 200px;
  background: rgba(12, 12, 16, 0.98);
  backdrop-filter: blur(32px);
  -webkit-backdrop-filter: blur(32px);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 16px;
  box-shadow: 0 16px 50px rgba(0, 0, 0, 0.6);
  z-index: 100;
  overflow: hidden;
}

.custom-select-options {
  max-height: 300px;
  overflow-y: auto;
  padding: 0.4rem;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.custom-select-options::-webkit-scrollbar {
  width: 6px;
}
.custom-select-options::-webkit-scrollbar-track {
  background: transparent;
}
.custom-select-options::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.15);
  border-radius: 99px;
}
.custom-select-options::-webkit-scrollbar-thumb:hover {
  background: rgba(255, 255, 255, 0.25);
}

.custom-select-option {
  padding: 0.6rem 0.85rem;
  font-size: 0.84rem;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.75);
  border-radius: 10px;
  cursor: pointer;
  transition: all var(--duration-normal) var(--ease-spring);
}

.custom-select-option:hover {
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
}

.custom-select-option.selected {
  background: rgba(255, 255, 255, 0.14);
  color: #fff;
  font-weight: 750;
}
/* Azu Explore — Premium Cinematic Discovery */
.explore-page {
  position: relative;
  min-height: calc(100vh - 80px);
  background:
    radial-gradient(circle at 14% 22%, rgba(255, 255, 255, 0.035), transparent 30rem),
    radial-gradient(circle at 88% 38%, rgba(87, 64, 255, 0.045), transparent 34rem),
    transparent;
}

.explore-page::before {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(255,255,255,0.016) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.012) 1px, transparent 1px);
  background-size: 72px 72px;
  mask-image: linear-gradient(to bottom, transparent, black 12%, transparent 80%);
  -webkit-mask-image: linear-gradient(to bottom, transparent, black 12%, transparent 80%);
  opacity: 0.32;
  z-index: 0;
}

/* ── Hero Header ── */
.explore-hero-header {
  position: relative;
  z-index: 50;
  width: min(94%, 1220px);
  margin: 0 auto;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1.5rem;
  padding: clamp(1.8rem, 3.2vw, 2.8rem) 0 clamp(1.2rem, 2.4vw, 1.8rem);
  flex-wrap: wrap;
}

.explore-title-group {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}

.explore-eyebrow {
  font-size: 0.68rem;
  font-weight: 850;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.48);
}

.explore-title {
  font-size: clamp(2.2rem, 5.2vw, 3.8rem);
  font-weight: 950;
  color: var(--text-primary);
  letter-spacing: -0.08em;
  line-height: 0.92;
}

.explore-subtitle {
  font-size: 0.82rem;
  color: rgba(255,255,255,0.52);
  margin-top: 0.35rem;
  font-weight: 500;
}

.explore-subtitle-accent {
  color: #f6f3ea;
  font-weight: 750;
}

/* ── PREMIUM FILTERS ── */
.explore-filters {
  display: flex;
  align-items: center;
  gap: 0.8rem;
  flex-wrap: wrap;
  padding: 0;
  background: transparent;
  border: none;
  box-shadow: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

.filter-group {
  display: flex;
  align-items: center;
  gap: 0;
  background: rgba(255, 255, 255, 0.055);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 999px;
  padding: 0.5rem 1rem;
  transition: all var(--duration-normal) var(--ease-spring);
  position: relative;
}

.filter-group::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(135deg, rgba(255,255,255,0.06), rgba(255,255,255,0.01));
  opacity: 0;
  transition: opacity var(--duration-normal) var(--ease-spring);
  pointer-events: none;
}

.filter-group:hover {
  border-color: rgba(255,255,255,0.2);
  background: rgba(255, 255, 255, 0.085);
  box-shadow: 0 0 0 1px rgba(255,255,255,0.1), inset 0 1px 0 rgba(255,255,255,0.1);
}

.filter-group:hover::before {
  opacity: 1;
}

.filter-group:focus-within {
  border-color: #f6f3ea;
  background: rgba(255, 255, 255, 0.12);
  box-shadow: 0 0 0 3px rgba(246,243,234,0.12), inset 0 1px 0 rgba(255,255,255,0.15);
}



.filter-select {
  background: transparent;
  border: none;
  color: rgba(255,255,255,0.78);
  font-family: inherit;
  font-size: 0.85rem;
  font-weight: 750;
  cursor: pointer;
  outline: none;
  -webkit-appearance: none;
  appearance: none;
  background-image: url("data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%23ffffff%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E");
  background-repeat: no-repeat;
  background-position: right 0.1rem top 50%;
  background-size: 0.55rem auto;
  max-width: 145px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  transition: all var(--duration-normal) var(--ease-spring);
  position: relative;
  z-index: 1;
  padding-right: 1.2rem;
}

.filter-select:hover {
  color: #f6f3ea;
}

.filter-select:focus {
  color: #f6f3ea;
}

.filter-select option {
  background: #0f0f1a;
  color: white;
  padding: 0.6rem;
  font-weight: 600;
}

.filter-select option:checked {
  background: linear-gradient(#f6f3ea, #f6f3ea);
  background-color: #f6f3ea !important;
  color: #050505 !important;
}

/* ── PREMIUM GENRE SECTION ── */
.genre-section {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  gap: 0;
  margin: clamp(1.6rem, 3.2vw, 2.8rem) 0 clamp(2rem, 3.6vw, 3rem);
}

.genre-section::before,
.genre-section::after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  width: 100px;
  z-index: 2;
  pointer-events: none;
}

.genre-section::before {
  left: 48px;
  background: linear-gradient(to right, var(--bg-primary), transparent);
}

.genre-section::after {
  right: 48px;
  background: linear-gradient(to left, var(--bg-primary), transparent);
}

.genre-nav-btn {
  flex-shrink: 0;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: rgba(255,255,255,0.065);
  border: 1.5px solid rgba(255,255,255,0.12);
  color: rgba(255,255,255,0.68);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all var(--duration-normal) var(--ease-spring);
  z-index: 3;
  box-shadow: 0 8px 24px rgba(0,0,0,0.16);
}

.genre-nav-left {
  margin-left: 5%;
}

.genre-nav-right {
  margin-right: 5%;
}

.genre-nav-btn:hover {
  background: #f6f3ea;
  border-color: #f6f3ea;
  color: #050505;
  box-shadow: 0 16px 40px rgba(255,255,255,0.12);
  transform: scale(1.08);
}

.genre-track {
  display: flex;
  gap: 1rem;
  overflow-x: auto;
  scroll-behavior: smooth;
  scroll-snap-type: x proximity;
  padding: 0.5rem 5%;
  -ms-overflow-style: none;
  scrollbar-width: none;
  flex: 1;
}

.genre-track::-webkit-scrollbar {
  display: none;
}

.genre-card {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.65rem 1.25rem;
  border-radius: 999px;
  background: transparent;
  border: 1px solid rgba(255,255,255,0.15);
  color: rgba(255,255,255,0.75);
  cursor: pointer;
  transition: all var(--duration-normal) var(--ease-spring);
  font-family: inherit;
  flex-shrink: 0;
  position: relative;
  overflow: hidden;
  scroll-snap-align: start;
  box-shadow: 0 12px 32px rgba(0,0,0,0.2);
}

.genre-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,0.1), rgba(255,255,255,0.02));
  opacity: 0;
  transition: opacity var(--duration-normal) var(--ease-spring);
}

.genre-card:hover {
  border-color: rgba(255,255,255,0.2);
  color: #f6f3ea;
  transform: translateY(-6px);
  box-shadow: 0 20px 48px rgba(0,0,0,0.32);
}

.genre-card:hover::before {
  opacity: 1;
}

.genre-card.active {
  border-color: #f6f3ea;
  color: #050505;
  background:
    linear-gradient(135deg, #f6f3ea, #e8e4d8),
    #f6f3ea;
  box-shadow: 0 16px 48px rgba(246,243,234,0.16), inset 0 1px 0 rgba(255,255,255,0.4);
  transform: translateY(-6px);
}

.genre-card.active::before {
  opacity: 0;
}



.genre-card-name {
  font-size: 0.78rem;
  font-weight: 800;
  text-align: center;
  white-space: nowrap;
  letter-spacing: 0.02em;
  position: relative;
  z-index: 1;
}

/* ── Grid ── */
.explore-grid {
  position: relative;
  z-index: 2;
  width: min(94%, 1220px);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: clamp(1rem, 1.8vw, 1.6rem);
  padding-bottom: clamp(2rem, 4vw, 3.5rem);
}

/* ── Loading ── */
.explore-loading {
  position: relative;
  z-index: 2;
  display: flex;
  justify-content: center;
  padding: 2.5rem;
}

.loading-dots {
  display: flex;
  gap: 10px;
  align-items: center;
}

.loading-dots span {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #f6f3ea;
  animation: dotBounce 1.2s var(--ease-spring) infinite;
}

.loading-dots span:nth-child(2) { animation-delay: 0.2s; }
.loading-dots span:nth-child(3) { animation-delay: 0.4s; }

@keyframes dotBounce {
  0%, 80%, 100% { transform: scale(0.6); opacity: 0.4; }
  40% { transform: scale(1); opacity: 1; }
}

.load-more-container {
  position: relative;
  z-index: 2;
  display: flex;
  justify-content: center;
  padding-bottom: 4rem;
}

/* ── Mobile ── */
@media (max-width: 768px) {
  .explore-hero-header {
    width: calc(100% - 1rem);
    padding-top: 1.3rem;
    padding-bottom: 1rem;
    align-items: flex-start;
    flex-direction: column;
    gap: 0.9rem;
  }

  .explore-title {
    font-size: 1.8rem;
  }

  .explore-filters {
    width: 100%;
    gap: 0.5rem;
    padding: 0.5rem 0.6rem;
  }

  .filter-group {
    padding: 0.5rem 0.85rem;
    border-radius: 18px;
  }

  .filter-select {
    font-size: 0.78rem;
    max-width: 120px;
  }

  .genre-nav-left { margin-left: 3%; }
  .genre-nav-right { margin-right: 3%; }

  .genre-track {
    padding: 0.5rem 3%;
    gap: 0.8rem;
  }

  .genre-section::before { left: 43px; width: 50px; }
  .genre-section::after { right: 43px; width: 50px; }

  .genre-card {
    padding: 0.6rem 1.1rem;
  }

  .genre-card-name { font-size: 0.72rem; }

  .explore-grid {
    width: calc(100% - 1rem);
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: 0.9rem;
  }
}

@media (max-width: 480px) {
  .explore-grid {
    grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
    gap: 0.75rem;
  }

  .genre-card {
    padding: 0.55rem 1rem;
  }

  .genre-card-name { font-size: 0.68rem; }
}
/* ── Watchlist Page ── */
.watchlist-page {
  min-height: 100vh;
  padding-bottom: 5rem;
}

/* ── Header ── */
.watchlist-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1.5rem;
  padding-top: 2.5rem;
  padding-bottom: 2rem;
  flex-wrap: wrap;
}

.watchlist-title-group {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.watchlist-eyebrow {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--accent);
  opacity: 0.8;
}

.watchlist-title {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  font-size: clamp(2rem, 5vw, 3.2rem);
  font-weight: 900;
  color: var(--text-primary);
  letter-spacing: -0.04em;
  line-height: 1;
}

.watchlist-title-icon {
  color: var(--accent);
  flex-shrink: 0;
}

.watchlist-subtitle {
  font-size: 0.9rem;
  color: var(--text-tertiary);
  margin-top: 0.25rem;
}

/* ── Sort ── */
.watchlist-sort-group {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--glass-border-hover);
  border-radius: var(--radius-full);
  padding: 0.45rem 1rem 0.45rem 0.75rem;
  backdrop-filter: blur(10px);
  transition: all var(--duration-normal) var(--ease-spring);
}

.watchlist-sort-group:focus-within {
  border-color: var(--accent-border);
  background: var(--accent-muted);
}

.sort-icon {
  color: var(--text-tertiary);
  flex-shrink: 0;
}

.watchlist-sort-select {
  background: transparent;
  border: none;
  color: var(--text-tertiary);
  font-family: inherit;
  font-size: 0.85rem;
  font-weight: 500;
  cursor: pointer;
  outline: none;
  -webkit-appearance: none;
  appearance: none;
}

.watchlist-sort-select:focus {
  color: var(--text-primary);
}

.watchlist-sort-select option {
  background: #0f0f1a;
  color: white;
}

/* ── Tabs ── */
.watchlist-tabs {
  display: flex;
  gap: 0.5rem;
  margin-bottom: 2.5rem;
  flex-wrap: wrap;
}

.watchlist-tab {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.6rem 1.25rem;
  border-radius: var(--radius-full);
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--text-tertiary);
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--glass-border);
  cursor: pointer;
  transition: all var(--duration-normal) var(--ease-spring);
  font-family: inherit;
}

.watchlist-tab:hover {
  color: var(--text-primary);
  background: var(--accent-muted);
  border-color: var(--accent-border);
}

.watchlist-tab.active {
  background: var(--accent);
  color: white;
  border-color: transparent;
  box-shadow: 0 4px 15px var(--accent-glow);
}

/* ── Grid ── */
.watchlist-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(145px, 1fr));
  gap: 1.5rem;
  padding-bottom: 1.5rem;
}

@media (min-width: 768px) {
  .watchlist-grid {
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 2rem;
  }
}

/* ── Item ── */
.watchlist-item {
  position: relative;
  border-radius: var(--radius-md);
  overflow: visible;
  transition: all var(--duration-normal) var(--ease-spring);
}

.watchlist-item:hover .watchlist-remove-btn {
  opacity: 1;
  transform: scale(1);
}

.watchlist-item-link {
  display: block;
  text-decoration: none;
  color: inherit;
}

.watchlist-poster-wrap {
  position: relative;
  width: 100%;
  aspect-ratio: 2/3;
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--bg-surface);
}

.watchlist-poster {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
  display: block;
}

.watchlist-item:hover .watchlist-poster {
  transform: scale(1.06);
}

.watchlist-poster-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-tertiary);
}

.watchlist-poster-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity var(--duration-normal) var(--ease-spring);
}

.watchlist-item:hover .watchlist-poster-overlay {
  opacity: 1;
}

.watchlist-play-btn {
  font-size: 2rem;
  color: white;
  filter: drop-shadow(0 0 10px rgba(0,0,0,0.5));
}

.watchlist-rating {
  position: absolute;
  top: 0.5rem;
  right: 0.5rem;
  background: rgba(0, 0, 0, 0.8);
  backdrop-filter: blur(8px);
  padding: 0.2rem 0.45rem;
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  gap: 0.2rem;
  font-size: 0.75rem;
  font-weight: 700;
  color: #fbbf24;
}

.watchlist-type-badge {
  position: absolute;
  bottom: 0.5rem;
  left: 0.5rem;
  background: var(--accent);
  color: white;
  font-size: 0.6rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  padding: 0.15rem 0.4rem;
  border-radius: 3px;
}

.watchlist-item-info {
  padding: 0.7rem 0.25rem 0;
}

.watchlist-item-title {
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-bottom: 0.2rem;
}

.watchlist-item-year {
  font-size: 0.75rem;
  color: var(--text-tertiary);
}

/* ── Remove Button ── */
.watchlist-remove-btn {
  position: absolute;
  top: 0.5rem;
  left: 0.5rem;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.8);
  border: 1px solid rgba(255, 255, 255, 0.15);
  color: #fca5a5;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  opacity: 0;
  transform: scale(0.8);
  transition: all var(--duration-fast) var(--ease-spring);
  z-index: 5;
  backdrop-filter: blur(4px);
}

.watchlist-remove-btn:hover {
  background: rgba(220, 38, 38, 0.8);
  color: white;
  border-color: rgba(220, 38, 38, 0.5);
}

/* ── Empty State ── */
.watchlist-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 6rem 2rem;
  min-height: 50vh;
}

.watchlist-empty-icon {
  font-size: 4rem;
  margin-bottom: 1.5rem;
  filter: grayscale(0.3);
}

.watchlist-empty-title {
  font-size: 1.6rem;
  font-weight: 800;
  color: var(--text-primary);
  margin-bottom: 0.75rem;
}

.watchlist-empty-desc {
  font-size: 0.95rem;
  color: var(--text-tertiary);
  max-width: 380px;
  line-height: 1.6;
  margin-bottom: 2rem;
}

.watchlist-empty-cta {
  text-decoration: none;
}

/* ── Mobile ── */
@media (max-width: 768px) {
  .watchlist-header {
    flex-direction: column;
    align-items: flex-start;
    padding-top: 1.5rem;
    gap: 1rem;
  }
  .watchlist-tabs {
    overflow-x: auto;
    flex-wrap: nowrap;
    padding-bottom: 0.5rem;
    -ms-overflow-style: none;
    scrollbar-width: none;
  }
  .watchlist-tabs::-webkit-scrollbar { display: none; }
  .watchlist-tab { white-space: nowrap; }
}
.newrel-page {
  min-height: 100vh;
  padding-bottom: 5rem;
}

/* ── Header ── */
.newrel-header {
  padding-top: 2.5rem;
  padding-bottom: 2rem;
}

.newrel-title-group {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.newrel-eyebrow {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--accent);
  opacity: 0.8;
}

.newrel-title {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  font-size: clamp(2rem, 5vw, 3.2rem);
  font-weight: 900;
  color: var(--accent);
  letter-spacing: -0.04em;
  line-height: 1;
}

.newrel-title-icon {
  flex-shrink: 0;
  color: var(--accent);
  -webkit-text-fill-color: unset;
}

.newrel-subtitle {
  font-size: 0.9rem;
  color: var(--text-tertiary);
  margin-top: 0.25rem;
}

/* ── Tabs ── */
.newrel-tabs {
  display: flex;
  gap: 0.5rem;
  margin-bottom: 2.5rem;
  flex-wrap: wrap;
}

.newrel-tab {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.6rem 1.25rem;
  border-radius: var(--radius-full);
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--text-tertiary);
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--glass-border);
  cursor: pointer;
  transition: all var(--duration-normal) var(--ease-spring);
  font-family: inherit;
}

.newrel-tab:hover {
  color: var(--text-primary);
  background: var(--accent-muted);
  border-color: var(--accent-border);
}

.newrel-tab.active {
  background: var(--gradient-accent);
  color: white;
  border-color: transparent;
  box-shadow: 0 4px 15px var(--accent-glow);
}

/* ── Grid ── */
.newrel-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(145px, 1fr));
  gap: 1.25rem;
  padding-bottom: 1.5rem;
}

@media (min-width: 768px) {
  .newrel-grid {
    grid-template-columns: repeat(auto-fill, minmax(185px, 1fr));
    gap: 1.75rem;
  }
}

/* ── Card with NEW badge ── */
.newrel-card-wrap {
  position: relative;
}

.newrel-new-badge {
  position: absolute;
  top: 0.55rem;
  left: 0.55rem;
  z-index: 5;
  background: var(--gradient-accent);
  color: white;
  font-size: 0.62rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  padding: 0.2rem 0.5rem;
  border-radius: 4px;
  box-shadow: 0 2px 8px var(--accent-glow);
  pointer-events: none;
}

/* ── Skeleton ── */
.newrel-skeleton {
  aspect-ratio: 2/3;
  border-radius: var(--radius-md);
}

/* ── Loading / Load More ── */
.newrel-loading,
.newrel-load-more {
  display: flex;
  justify-content: center;
  padding: 2rem 0;
}

.loading-dots {
  display: flex;
  gap: 8px;
  align-items: center;
}

.loading-dots span {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--accent);
  animation: dotBounce 1.2s var(--ease-spring) infinite;
}

.loading-dots span:nth-child(2) { animation-delay: 0.2s; }
.loading-dots span:nth-child(3) { animation-delay: 0.4s; }

@keyframes dotBounce {
  0%, 80%, 100% { transform: scale(0.6); opacity: 0.4; }
  40% { transform: scale(1); opacity: 1; }
}

@media (max-width: 768px) {
  .newrel-tabs {
    overflow-x: auto;
    flex-wrap: nowrap;
    padding-bottom: 0.5rem;
    -ms-overflow-style: none;
    scrollbar-width: none;
  }
  .newrel-tabs::-webkit-scrollbar { display: none; }
  .newrel-tab { white-space: nowrap; }
}
.collection-page {
  min-height: 100vh;
  padding-bottom: 5rem;
}

/* ── Hero ── */
.collection-hero {
  position: relative;
  height: 55vh;
  min-height: 400px;
  display: flex;
  align-items: flex-end;
  margin-bottom: 3rem;
  overflow: hidden;
}

.collection-hero-skeleton {
  height: 55vh;
  min-height: 400px;
  width: 100%;
  border-radius: 0;
}

.collection-card-skeleton {
  aspect-ratio: 2/3;
  border-radius: var(--radius-md);
}

.collection-hero-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
}

.collection-hero-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to right, rgba(8,8,16,0.97) 0%, rgba(8,8,16,0.5) 60%, rgba(8,8,16,0.2) 100%),
    linear-gradient(to top, rgba(8,8,16,1) 0%, rgba(8,8,16,0.4) 35%, transparent 65%);
}

.collection-hero-content {
  position: relative;
  z-index: 1;
  padding-bottom: 2.5rem;
  max-width: 700px;
}

/* ── Back Button ── */
.collection-back-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--text-tertiary);
  margin-bottom: 1.25rem;
  transition: all var(--duration-normal) var(--ease-spring);
  padding: 0.35rem 0.75rem;
  border-radius: var(--radius-full);
  background: rgba(255,255,255,0.05);
  border: 1px solid var(--glass-border);
}

.collection-back-btn:hover {
  color: var(--text-primary);
  background: rgba(255,255,255,0.1);
  transform: translateX(-3px);
}

/* ── Meta Row ── */
.collection-meta-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.82rem;
  color: var(--text-tertiary);
  font-weight: 500;
  margin-bottom: 0.75rem;
}

.collection-meta-icon { color: #fca5a5; }
.collection-meta-dot { opacity: 0.4; }

/* ── Title ── */
.collection-title {
  font-size: clamp(2rem, 5vw, 3.8rem);
  font-weight: 900;
  letter-spacing: -0.04em;
  line-height: 1.05;
  margin-bottom: 1rem;
  color: white;
  text-shadow: 0 2px 20px rgba(0,0,0,0.5);
}

.collection-overview {
  font-size: 0.95rem;
  color: rgba(255,255,255,0.55);
  line-height: 1.7;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  max-width: 580px;
}

/* ── Content ── */
.collection-content {
  padding-top: 1rem;
}

.collection-section-title {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  font-size: 1.35rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  margin-bottom: 1.75rem;
  color: var(--text-primary);
}

.collection-section-line {
  width: 3px;
  height: 1.3em;
  background: var(--gradient-accent);
  border-radius: var(--radius-full);
  flex-shrink: 0;
}

/* ── Grid ── */
.collection-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(155px, 1fr));
  gap: 1.5rem;
}

@media (min-width: 768px) {
  .collection-grid {
    grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
    gap: 2rem;
  }
}

/* ── Card Wrap ── */
.collection-card-wrap {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.collection-part-badge {
  position: absolute;
  top: 0.55rem;
  left: 0.55rem;
  z-index: 5;
  background: rgba(0,0,0,0.75);
  backdrop-filter: blur(8px);
  color: #fecaca;
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.05em;
  padding: 0.2rem 0.55rem;
  border-radius: 5px;
  border: 1px solid rgba(229, 9, 20, 0.4);
  pointer-events: none;
}

.collection-card-year {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--text-tertiary);
  text-align: center;
  letter-spacing: 0.03em;
  padding-top: 0.1rem;
}

@media (max-width: 640px) {
  .collection-hero {
    height: 45vh;
    min-height: 320px;
  }
  .collection-title {
    font-size: 1.8rem;
  }
}
/* ── Person Page ── */
.person-page {
  min-height: 100vh;
  padding-bottom: 5rem;
}

/* ── Back Button ── */
.person-back-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--text-tertiary);
  margin: 2rem 0 1.5rem;
  padding: 0.4rem 0.9rem;
  border-radius: var(--radius-full);
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--glass-border);
  transition: all var(--duration-normal) var(--ease-spring);
}

.person-back-btn:hover {
  color: var(--text-primary);
  background: rgba(255, 255, 255, 0.1);
  transform: translateX(-3px);
}

/* ── Hero ── */
.person-hero {
  display: flex;
  gap: 3rem;
  align-items: flex-start;
  margin-bottom: 3rem;
}

/* ── Photo ── */
.person-photo-wrap {
  flex-shrink: 0;
}

.person-photo {
  width: 240px;
  border-radius: var(--radius-lg);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.6);
  border: 1px solid var(--glass-border);
  display: block;
}

.person-photo-placeholder {
  width: 240px;
  height: 360px;
  border-radius: var(--radius-lg);
  background: var(--bg-surface);
  border: 1px solid var(--glass-border);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-tertiary);
}

/* ── Info ── */
.person-info {
  flex: 1;
  padding-top: 0.5rem;
}

.person-eyebrow {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 0.5rem;
}

.person-name {
  font-size: clamp(2rem, 4vw, 3.2rem);
  font-weight: 900;
  letter-spacing: -0.03em;
  line-height: 1.05;
  color: var(--text-primary);
  margin-bottom: 1.25rem;
}

.person-meta {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-bottom: 1.5rem;
}

.person-meta-item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
  color: var(--text-tertiary);
}

/* ── Stats ── */
.person-stats {
  display: flex;
  gap: 1.5rem;
  margin-bottom: 1.5rem;
}

.person-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-md);
  padding: 0.75rem 1.25rem;
  min-width: 80px;
}

.person-stat-num {
  font-size: 1.6rem;
  font-weight: 900;
  color: var(--accent);
  line-height: 1;
}

.person-stat-label {
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--text-tertiary);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-top: 0.25rem;
}

/* ── Bio ── */
.person-bio {
  max-width: 700px;
}

.person-bio p {
  font-size: 0.95rem;
  line-height: 1.75;
  color: rgba(255, 255, 255, 0.65);
}

.person-bio-toggle {
  background: none;
  border: none;
  color: var(--accent);
  font-size: 0.875rem;
  font-weight: 600;
  cursor: pointer;
  padding: 0.5rem 0;
  transition: all var(--duration-normal) var(--ease-spring);
}

.person-bio-toggle:hover {
  opacity: 0.8;
}

/* ── Filmography ── */
.person-filmography {
  padding-top: 1rem;
}

/* ── Tabs ── */
.person-tabs {
  display: flex;
  gap: 0.5rem;
  margin-bottom: 2rem;
  flex-wrap: wrap;
}

.person-tab {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.6rem 1.25rem;
  border-radius: var(--radius-full);
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--text-tertiary);
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--glass-border);
  cursor: pointer;
  transition: all var(--duration-normal) var(--ease-spring);
  font-family: inherit;
}

.person-tab:hover {
  color: var(--text-primary);
  background: var(--accent-muted);
  border-color: var(--accent-border);
}

.person-tab.active {
  background: var(--accent);
  color: white;
  border-color: transparent;
  box-shadow: 0 4px 15px var(--accent-glow);
}

/* ── Grid ── */
.person-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(145px, 1fr));
  gap: 1.25rem;
  padding-bottom: 1.5rem;
}

@media (min-width: 768px) {
  .person-grid {
    grid-template-columns: repeat(auto-fill, minmax(185px, 1fr));
    gap: 1.75rem;
  }
}

.person-empty {
  text-align: center;
  padding: 3rem;
  color: var(--text-tertiary);
}

/* ── Loading ── */
.person-loading {
  padding: 2rem 5%;
}

.person-loading-header {
  height: 300px;
  border-radius: var(--radius-lg);
  margin-bottom: 2rem;
}

.person-loading-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(145px, 1fr));
  gap: 1.25rem;
}

.person-card-skeleton {
  aspect-ratio: 2/3;
  border-radius: var(--radius-md);
}

/* ── Mobile ── */
@media (max-width: 768px) {
  .person-hero {
    flex-direction: column;
    gap: 1.5rem;
  }

  .person-photo,
  .person-photo-placeholder {
    width: 140px;
    height: 210px;
    border-radius: var(--radius-md);
  }

  .person-name {
    font-size: 1.8rem;
  }
}
.not-found-page {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 70vh;
  text-align: center;
}

.not-found-content {
  max-width: 600px;
  padding: 40px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 20px;
  backdrop-filter: blur(10px);
}

.error-code {
  font-size: 8rem;
  font-weight: 800;
  margin: 0;
  line-height: 1;
  color: var(--accent);
  text-shadow: 0 10px 30px rgba(229, 9, 20, 0.3);
}

.error-title {
  font-size: 2.5rem;
  margin: 10px 0;
  color: var(--text-primary);
}

.error-desc {
  font-size: 1.1rem;
  color: var(--text-primary);
  margin-bottom: 30px;
}

.btn-home {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 24px;
  font-size: 1.1rem;
}
/* Clean Footer */
.footer { padding: var(--space-xl) 0 var(--space-lg); border-top: 1px solid rgba(255,255,255,0.055); margin-top: var(--space-xl); background: rgba(255,255,255,0.015); }
.footer-content { display: grid; grid-template-columns: 1.4fr auto; align-items: start; gap: clamp(2rem, 4vw, 4rem); }
.footer-brand { display: flex; flex-direction: column; gap: 0.7rem; }
.footer-brand .brand { display: inline-flex; align-items: center; gap: 0.6rem; text-decoration: none; }
.footer-brand .brand-logo { width: 24px; height: 24px; filter: none; }
.footer-brand .brand-text { font-size: 1.2rem; font-weight: 700; letter-spacing: -0.04em; color: var(--text-primary); }
.footer-brand-desc { font-size: 0.84rem; color: var(--text-tertiary); max-width: 330px; line-height: 1.7; }
.footer-links { display: grid; grid-template-columns: repeat(3, auto); gap: clamp(2rem, 4vw, 3.5rem); }
.footer-links-group {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.footer-links-group h3 { 
  font-size: 0.75rem; 
  font-weight: 700; 
  text-transform: uppercase; 
  letter-spacing: 0.08em; 
  color: var(--text-tertiary); 
  margin-bottom: 0.8rem; 
}
.footer-links-group a { 
  display: block; 
  font-size: 0.83rem; 
  color: var(--text-secondary); 
  padding: 0.25rem 0; 
  transition: color var(--duration-fast) var(--ease-spring), transform var(--duration-fast) var(--ease-spring); 
}
.footer-links-group a:hover { 
  color: var(--text-primary); 
  transform: translateX(3px); 
}
.footer-bottom { margin-top: var(--space-lg); padding-top: var(--space-md); border-top: 1px solid rgba(255,255,255,0.05); text-align: center; font-size: 0.72rem; color: var(--text-tertiary); display: flex; flex-direction: column; gap: 0.5rem;}
@media (max-width: 768px) { .footer-content { grid-template-columns: 1fr; gap: 2rem; } .footer-links { grid-template-columns: repeat(2, 1fr); gap: 1.5rem; } }
@media (max-width: 480px) { .footer-links { grid-template-columns: 1fr; } }

