@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&display=swap');

:root {
  --bg:           #07060f;
  --bg-2:         #0e0c1a;
  --bg-3:         #161426;
  --surface:      #131122;
  --surface-2:    #1c1930;
  --surface-3:    #242040;
  --border:       rgba(139,92,246,0.10);
  --border-2:     rgba(139,92,246,0.22);
  --border-glow:  rgba(139,92,246,0.45);
  --accent:       #a855f7;
  --accent-dim:   rgba(168,85,247,0.15);
  --accent-glow:  rgba(168,85,247,0.40);
  --accent-dark:  #7c3aed;
  --gold:         #f0b429;
  --gold-dim:     rgba(240,180,41,0.15);
  --gold-glow:    rgba(240,180,41,0.35);
  --text:         #f0eeff;
  --text-2:       #9b93c4;
  --text-3:       #4e4870;
  --font-display: 'Bebas Neue', sans-serif;
  --font-body:    'DM Sans', sans-serif;
  --radius:       10px;
  --radius-lg:    16px;
  --radius-xl:    24px;
  --nav-h:        64px;
  --shadow:       0 4px 24px rgba(0,0,0,0.6);
  --shadow-lg:    0 8px 48px rgba(0,0,0,0.8);
  --shadow-purple:0 8px 32px rgba(168,85,247,0.25);
  --transition:   0.22s cubic-bezier(0.4,0,0.2,1);
  --transition-slow: 0.45s cubic-bezier(0.4,0,0.2,1);
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body { background:var(--bg); color:var(--text); font-family:var(--font-body); font-size:15px; line-height:1.6; min-height:100vh; overflow-x:hidden; -webkit-font-smoothing:antialiased; }
a { color:inherit; text-decoration:none; }
img { max-width:100%; display:block; }
button { cursor:pointer; font-family:var(--font-body); border:none; background:none; }
select, input { font-family:var(--font-body); }

::-webkit-scrollbar { width:5px; height:5px; }
::-webkit-scrollbar-track { background:var(--bg-2); }
::-webkit-scrollbar-thumb { background:var(--surface-3); border-radius:3px; }
::-webkit-scrollbar-thumb:hover { background:var(--accent); }

@keyframes shimmer { 0%{background-position:-800px 0} 100%{background-position:800px 0} }
@keyframes spin { to{transform:rotate(360deg)} }
@keyframes fadeIn { from{opacity:0} to{opacity:1} }
@keyframes fadeInUp { from{opacity:0;transform:translateY(24px)} to{opacity:1;transform:translateY(0)} }
@keyframes fadeInDown { from{opacity:0;transform:translateY(-14px)} to{opacity:1;transform:translateY(0)} }
@keyframes pulseGlow { 0%,100%{box-shadow:0 0 12px var(--accent-glow)} 50%{box-shadow:0 0 30px var(--accent-glow),0 0 56px var(--accent-glow)} }

.page-enter { animation:fadeInUp 0.42s cubic-bezier(0.4,0,0.2,1) both; }
.reveal { opacity:0; transform:translateY(20px); transition:opacity 0.5s ease,transform 0.5s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }

.container { max-width:1400px; margin:0 auto; padding:0 24px; }

/* NAVBAR */
.navbar {
  position:fixed; top:0; left:0; right:0; height:var(--nav-h); z-index:1000;
  display:flex; align-items:center; padding:0 32px; gap:24px;
  background:rgba(7,6,15,0.82);
  backdrop-filter:blur(20px) saturate(1.4);
  -webkit-backdrop-filter:blur(20px) saturate(1.4);
  border-bottom:1px solid var(--border);
  transition:background var(--transition),transform 0.3s ease,box-shadow 0.3s ease;
}
.navbar::after { content:''; position:absolute; bottom:0; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent,var(--accent),var(--gold),transparent); opacity:0.35; }
.navbar--hidden { transform:translateY(-100%); }
.navbar--scrolled { background:rgba(7,6,15,0.97); box-shadow:0 4px 32px rgba(0,0,0,0.6); }

.nav-logo { display:flex; align-items:center; text-decoration:none; flex-shrink:0; transition:opacity var(--transition),transform var(--transition); }
.nav-logo:hover { opacity:0.88; transform:scale(1.03); }
.nav-logo__img { height:60px; width:auto; max-width:140px; object-fit:contain; border-radius:16px; display:block; filter:drop-shadow(0 0 8px rgba(168,85,247,0.3)); }

.nav-links { display:flex; align-items:center; gap:2px; list-style:none; }
.nav-link { padding:7px 14px; border-radius:var(--radius); font-size:14px; font-weight:500; color:var(--text-2); transition:color var(--transition),background var(--transition); white-space:nowrap; position:relative; }
.nav-link::after { content:''; position:absolute; bottom:2px; left:14px; right:14px; height:2px; background:var(--accent); border-radius:1px; transform:scaleX(0); transition:transform var(--transition); }
.nav-link:hover { color:var(--text); background:var(--surface); }
.nav-link--active { color:var(--accent) !important; }
.nav-link--active::after { transform:scaleX(1); }

.nav-search { position:relative; margin-left:auto; display:flex; align-items:center; background:var(--surface); border:1px solid var(--border-2); border-radius:12px; overflow:visible; width:280px; transition:border-color var(--transition),box-shadow var(--transition); }
.nav-search:focus-within { border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-dim); }
.nav-search-input { background:none; border:none; outline:none; padding:10px 14px; color:var(--text); font-size:14px; width:100%; }
.nav-search-input::placeholder { color:var(--text-3); }
.nav-search-btn { padding:8px 14px; color:var(--text-2); flex-shrink:0; transition:color var(--transition),transform var(--transition); border-radius:0 12px 12px 0; }
.nav-search-btn:hover { color:var(--accent); transform:scale(1.1); }
.nav-search-btn svg { width:17px; height:17px; stroke:currentColor; fill:none; stroke-width:2; }

.suggest-box { position:absolute; top:calc(100% + 8px); left:0; right:0; background:var(--surface-2); border:1px solid var(--border-2); border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-lg); max-height:420px; overflow-y:auto; opacity:0; pointer-events:none; transform:translateY(-8px) scale(0.97); transition:opacity 0.18s,transform 0.18s; z-index:9999; }
.suggest-box--open { opacity:1; pointer-events:all; transform:translateY(0) scale(1); }
.suggest-item { display:flex; align-items:center; gap:12px; padding:10px 14px; cursor:pointer; transition:background var(--transition); border-bottom:1px solid var(--border); }
.suggest-item:last-child { border-bottom:none; }
.suggest-item:hover { background:var(--bg-3); }
.suggest-item img { width:38px; height:54px; object-fit:cover; border-radius:6px; flex-shrink:0; }
.suggest-meta { display:flex; flex-direction:column; gap:2px; min-width:0; }
.suggest-title { font-size:13px; font-weight:500; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.suggest-sub { font-size:11px; color:var(--text-3); }

.burger { display:none; flex-direction:column; gap:5px; padding:8px; }
.burger span { display:block; width:22px; height:2px; background:var(--text-2); border-radius:2px; transition:transform 0.3s,opacity 0.3s,background 0.3s; }
.burger--open span { background:var(--accent); }
.burger--open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.burger--open span:nth-child(2) { opacity:0; transform:scaleX(0); }
.burger--open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

#main-content { min-height:calc(100vh - var(--nav-h)); padding-top:var(--nav-h); }

/* BUTTONS */
.btn { display:inline-flex; align-items:center; gap:8px; padding:11px 22px; border-radius:var(--radius); font-size:14px; font-weight:600; transition:all var(--transition); position:relative; overflow:hidden; }
.btn:active { transform:scale(0.97) !important; }
.btn svg { width:16px; height:16px; fill:currentColor; flex-shrink:0; }
.btn--primary { background:linear-gradient(135deg,var(--accent-dark),var(--accent)); color:#fff; box-shadow:0 4px 20px var(--accent-glow); }
.btn--primary:hover { transform:translateY(-2px); box-shadow:0 8px 28px var(--accent-glow); }
.btn--gold { background:linear-gradient(135deg,#c98a10,var(--gold)); color:#000; box-shadow:0 4px 20px var(--gold-glow); }
.btn--gold:hover { transform:translateY(-2px); box-shadow:0 8px 28px var(--gold-glow); }
.btn--ghost { background:rgba(255,255,255,0.06); color:var(--text); border:1px solid var(--border-2); }
.btn--ghost:hover { background:rgba(255,255,255,0.12); border-color:var(--accent); transform:translateY(-1px); }

/* BADGES */
.badge { display:inline-flex; align-items:center; padding:2px 7px; border-radius:5px; font-size:10px; font-weight:700; letter-spacing:0.6px; text-transform:uppercase; }
.badge--sub { background:rgba(139,92,246,0.25); color:#c084fc; border:1px solid rgba(139,92,246,0.4); }
.badge--dub { background:rgba(240,180,41,0.2); color:var(--gold); border:1px solid rgba(240,180,41,0.35); }
.badge--eps { background:rgba(255,255,255,0.07); color:var(--text-2); }
.badge--type { background:var(--accent-dim); color:var(--accent); }
.badge--score { background:var(--gold-dim); color:var(--gold); }

/* CARDS */
.anime-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(155px,1fr)); gap:14px; }
.card { display:flex; flex-direction:column; border-radius:var(--radius-lg); overflow:hidden; background:var(--surface); border:1px solid var(--border); transition:transform 0.3s cubic-bezier(0.34,1.56,0.64,1),box-shadow 0.3s ease,border-color 0.25s ease; position:relative; cursor:pointer; }
.card:hover { transform:translateY(-6px) scale(1.02); box-shadow:0 16px 40px rgba(0,0,0,0.7),0 0 0 1px var(--border-2); border-color:var(--border-2); }
.card__poster-wrap { position:relative; aspect-ratio:2/3; overflow:hidden; background:var(--surface-2); }
.card__poster { width:100%; height:100%; object-fit:cover; transition:transform 0.5s cubic-bezier(0.4,0,0.2,1); }
.card:hover .card__poster { transform:scale(1.08); }
.card__overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(7,6,15,0.85) 0%,rgba(7,6,15,0.2) 50%,transparent 100%); display:flex; align-items:center; justify-content:center; opacity:0; transition:opacity 0.3s ease; }
.card:hover .card__overlay { opacity:1; }
.card__play-btn { width:52px; height:52px; background:linear-gradient(135deg,var(--accent-dark),var(--accent)); border-radius:50%; display:flex; align-items:center; justify-content:center; box-shadow:0 0 32px var(--accent-glow); transform:scale(0.8); transition:transform 0.3s cubic-bezier(0.34,1.56,0.64,1); }
.card:hover .card__play-btn { transform:scale(1); animation:pulseGlow 2s infinite; }
.card__play-btn svg { width:20px; height:20px; fill:#fff; margin-left:3px; }
.card__badges { position:absolute; bottom:6px; left:6px; display:flex; gap:4px; flex-wrap:wrap; }
.card__type { position:absolute; top:8px; right:8px; background:rgba(7,6,15,0.75); backdrop-filter:blur(6px); color:var(--text-2); font-size:10px; font-weight:700; padding:3px 7px; border-radius:5px; letter-spacing:0.5px; text-transform:uppercase; }
.card__info { padding:10px 11px 13px; }
.card__title { font-size:12px; font-weight:500; line-height:1.45; color:var(--text); display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; transition:color var(--transition); }
.card:hover .card__title { color:var(--accent); }

/* SKELETON */
.skeleton-box, .card--skeleton .card__poster-wrap, .skeleton-line { background:linear-gradient(90deg,var(--surface) 0%,var(--surface-2) 40%,var(--surface-3) 60%,var(--surface) 100%); background-size:1600px 100%; animation:shimmer 1.8s infinite linear; border-radius:var(--radius); }
.skeleton-line { height:11px; margin:6px 0; }
.skeleton-line--80 { width:80%; }
.skeleton-line--50 { width:50%; }

/* SECTIONS */
.home-section { padding:40px 32px; max-width:1400px; margin:0 auto; }
.section-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:50px; }
.section-title { font-family:var(--font-display); font-size:22px; letter-spacing:1.5px; display:flex; align-items:center; gap:12px; background:linear-gradient(90deg,var(--text),var(--text-2)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.section-accent { display:inline-block; width:4px; height:22px; background:linear-gradient(to bottom,var(--accent),var(--gold)); border-radius:2px; box-shadow:0 0 10px var(--accent-glow); -webkit-text-fill-color:initial; flex-shrink:0; }
.section-more { display:flex; align-items:center; gap:4px; font-size:12px; font-weight:600; color:var(--text-3); letter-spacing:0.5px; text-transform:uppercase; padding:6px 12px; border-radius:20px; border:1px solid var(--border); transition:all var(--transition); }
.section-more:hover { color:var(--accent); border-color:var(--border-2); background:var(--accent-dim); }
.section-more svg { width:14px; height:14px; stroke:currentColor; fill:none; stroke-width:2.5; }

/* SPOTLIGHT */
.spotlight { position:relative; overflow:hidden; }
.spotlight__inner { position:relative; height:90vh; min-height:540px; background-size:cover; background-position:center top; transition:background-image 0.6s ease; }
.spotlight__gradient { position:absolute; inset:0; background:linear-gradient(110deg,rgba(7,6,15,0.97) 0%,rgba(7,6,15,0.72) 45%,rgba(7,6,15,0.15) 100%),linear-gradient(to top,rgba(7,6,15,1) 0%,rgba(7,6,15,0.3) 35%,transparent 65%); }
.spotlight__gradient::after { content:''; position:absolute; inset:0; background:linear-gradient(135deg,rgba(168,85,247,0.08) 0%,transparent 60%); }
.spotlight__content { position:absolute; bottom:90px; left:64px; max-width:580px; z-index:2; animation:fadeInUp 0.6s ease both; }
.spotlight__rank { font-family:var(--font-display); font-size:13px; letter-spacing:3px; color:var(--gold); margin-bottom:10px; display:flex; align-items:center; gap:8px; }
.spotlight__rank::before { content:''; display:inline-block; width:24px; height:2px; background:var(--gold); border-radius:1px; }
.spotlight__meta { display:flex; align-items:center; gap:8px; margin-bottom:14px; flex-wrap:wrap; }
.spotlight__tag { font-size:11px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--text-2); padding:3px 9px; background:rgba(255,255,255,0.07); border:1px solid rgba(255,255,255,0.1); border-radius:5px; }
.spotlight__tag--accent { color:var(--accent); background:var(--accent-dim); border-color:rgba(168,85,247,0.3); }
.spotlight__tag--gold { color:var(--gold); background:var(--gold-dim); border-color:rgba(240,180,41,0.3); }
.spotlight__title { font-family:var(--font-display); font-size:clamp(34px,4.5vw,62px); line-height:1.02; letter-spacing:1.5px; margin-bottom:14px; background:linear-gradient(135deg,#fff 0%,rgba(240,224,255,0.85) 100%); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.spotlight__desc { font-size:14px; color:var(--text-2); line-height:1.75; margin-bottom:26px; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }
.spotlight__actions { display:flex; gap:12px; flex-wrap:wrap; }
.spotlight__dots { position:absolute; bottom:30px; left:64px; display:flex; gap:6px; z-index:3; }
.spotlight__dot { width:6px; height:6px; border-radius:3px; background:rgba(255,255,255,0.2); transition:all 0.4s cubic-bezier(0.4,0,0.2,1); cursor:pointer; }
.spotlight__dot--active { background:var(--accent); width:24px; box-shadow:0 0 10px var(--accent-glow); }
.spotlight__dot:hover:not(.spotlight__dot--active) { background:rgba(255,255,255,0.4); }
.spotlight__nav { position:absolute; top:50%; transform:translateY(-50%); width:46px; height:46px; border-radius:50%; background:rgba(13,11,25,0.6); backdrop-filter:blur(10px); border:1px solid var(--border-2); display:flex; align-items:center; justify-content:center; color:var(--text); transition:all var(--transition); z-index:3; }
.spotlight__nav:hover { background:var(--accent); border-color:var(--accent); box-shadow:0 0 20px var(--accent-glow); transform:translateY(-50%) scale(1.08); }
.spotlight__nav svg { width:20px; height:20px; stroke:currentColor; fill:none; stroke-width:2.5; }
.spotlight__nav--prev { left:20px; }
.spotlight__nav--next { right:20px; }

/* TRENDING */
.trending-row { display:grid; grid-template-columns:repeat(auto-fill,minmax(190px,1fr)); gap:10px; }
.trending-card { display:flex; align-items:center; gap:12px; padding:10px 12px; background:var(--surface); border-radius:var(--radius-lg); border:1px solid var(--border); transition:all var(--transition); overflow:hidden; cursor:pointer; position:relative; }
.trending-card::before { content:''; position:absolute; inset:0; background:linear-gradient(135deg,var(--accent-dim),transparent); opacity:0; transition:opacity var(--transition); border-radius:inherit; }
.trending-card:hover { border-color:var(--border-2); transform:translateY(-2px); box-shadow:var(--shadow-purple); }
.trending-card:hover::before { opacity:1; }
.trending-num { font-family:var(--font-display); font-size:30px; color:var(--text-3); min-width:34px; line-height:1; transition:color var(--transition); }
.trending-card:hover .trending-num { color:var(--accent); }
.trending-card img { width:42px; height:58px; object-fit:cover; border-radius:8px; flex-shrink:0; }
.trending-info { min-width:0; }
.trending-title { font-size:12px; font-weight:500; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; color:var(--text-2); transition:color var(--transition); }
.trending-card:hover .trending-title { color:var(--text); }
.trending-card--skel { height:78px; }

/* ANIME PAGE */
.anime-hero { position:relative; min-height:480px; padding-top:var(--nav-h); overflow:hidden; }
.anime-hero::before { content:''; position:absolute; inset:0; background-size:cover; background-position:center; filter:blur(48px) saturate(0.3); opacity:0.3; z-index:0; transform:scale(1.1); }
.anime-hero__blur { position:absolute; inset:0; background:linear-gradient(to bottom,rgba(7,6,15,0.65) 0%,var(--bg) 100%); z-index:1; }
.anime-hero__content { position:relative; z-index:2; max-width:1400px; margin:0 auto; padding:48px 32px; display:flex; gap:44px; align-items:flex-start; animation:fadeInUp 0.5s ease both; }
.anime-poster-wrap { flex-shrink:0; }
.anime-poster { width:220px; border-radius:var(--radius-lg); box-shadow:0 16px 56px rgba(0,0,0,0.8),0 0 0 1px var(--border-2); transition:transform var(--transition),box-shadow var(--transition); }
.anime-poster:hover { transform:scale(1.02); box-shadow:0 20px 64px rgba(0,0,0,0.9),0 0 0 1px var(--accent); }
.anime-meta { flex:1; padding-top:8px; }
.anime-meta__badges { display:flex; gap:8px; margin-bottom:14px; flex-wrap:wrap; }
.anime-meta__title { font-family:var(--font-display); font-size:clamp(26px,3.5vw,46px); letter-spacing:1px; line-height:1.05; margin-bottom:6px; background:linear-gradient(135deg,#fff 0%,#ddd6fe 100%); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.anime-meta__jtitle { font-size:14px; color:var(--text-3); margin-bottom:16px; }
.anime-meta__genres { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:18px; }
.genre-tag { padding:4px 12px; background:var(--surface); border:1px solid var(--border-2); border-radius:20px; font-size:12px; font-weight:500; color:var(--text-2); transition:all var(--transition); }
.genre-tag:hover { border-color:var(--accent); color:var(--accent); background:var(--accent-dim); transform:translateY(-1px); }
.anime-meta__overview { font-size:14px; color:var(--text-2); line-height:1.8; margin-bottom:26px; max-width:680px; }
.anime-meta__actions { display:flex; gap:12px; flex-wrap:wrap; }
.anime-body { padding:32px 32px 64px; }
.anime-body__main { max-width:920px; }
.sub-title { font-family:var(--font-display); font-size:18px; letter-spacing:1.5px; margin-bottom:16px; background:linear-gradient(90deg,var(--text),var(--text-2)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.info-table { width:100%; border-collapse:collapse; margin-bottom:32px; }
.info-table th, .info-table td { padding:10px 14px; border-bottom:1px solid var(--border); font-size:13px; text-align:left; }
.info-table th { color:var(--text-3); font-weight:500; width:130px; }
.info-table td { color:var(--text); }
.info-table tr:last-child th, .info-table tr:last-child td { border-bottom:none; }
.info-table tr { transition:background var(--transition); }
.info-table tr:hover td, .info-table tr:hover th { background:var(--surface); }
.episodes-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; gap:12px; }
.ep-search { background:var(--surface); border:1px solid var(--border); border-radius:8px; padding:8px 12px; color:var(--text); font-size:13px; outline:none; width:200px; transition:border-color var(--transition); }
.ep-search:focus { border-color:var(--accent); box-shadow:0 0 0 2px var(--accent-dim); }
.ep-count { font-size:14px; color:var(--text-3); }
.ep-grid { display:flex; flex-wrap:wrap; gap:8px; }
.ep-btn { width:54px; height:42px; background:var(--surface); border:1px solid var(--border); border-radius:8px; color:var(--text-2); font-size:13px; font-weight:500; display:flex; align-items:center; justify-content:center; transition:all var(--transition); }
.ep-btn:hover { border-color:var(--accent); color:var(--accent); background:var(--accent-dim); transform:translateY(-2px); box-shadow:0 4px 12px var(--accent-glow); }
.seasons { margin-bottom:32px; }
.seasons-list { display:flex; gap:12px; flex-wrap:wrap; }
.season-card { display:flex; flex-direction:column; align-items:center; gap:8px; padding:8px; background:var(--surface); border:2px solid var(--border); border-radius:var(--radius); width:100px; text-align:center; font-size:11px; color:var(--text-2); transition:all var(--transition); }
.season-card img { width:84px; height:120px; object-fit:cover; border-radius:6px; }
.season-card:hover { border-color:var(--accent); color:var(--text); transform:translateY(-2px); }
.season-card--active { border-color:var(--accent); color:var(--accent); }

/* WATCH PAGE */
.watch-page { display:grid; grid-template-columns:1fr 360px; min-height:calc(100vh - var(--nav-h)); animation:fadeIn 0.3s ease; }
.player-area { display:flex; flex-direction:column; background:#000; min-height:calc(100vh - var(--nav-h)); }
.player-wrap { position:relative; flex:1; background:#000; display:flex; align-items:center; justify-content:center; min-height:480px; }
.video-player { width:100%; height:100%; max-height:calc(100vh - var(--nav-h) - 56px); background:#000; }
.player-loader { display:flex; flex-direction:column; align-items:center; justify-content:center; width:100%; min-height:360px; gap:16px; }
.player-loader p { color:var(--text-3); font-size:13px; }
.player-err { color:var(--text-2); text-align:center; padding:48px; }
.player-err p { font-size:15px; margin-bottom:8px; }
.player-err small { font-size:12px; color:var(--text-3); }
.player-toolbar { height:56px; background:var(--surface); border-top:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; padding:0 16px; gap:12px; flex-shrink:0; }
.player-toolbar__left, .player-toolbar__right { display:flex; align-items:center; gap:10px; }
.tool-btn { width:34px; height:34px; border-radius:8px; background:var(--bg-3); display:flex; align-items:center; justify-content:center; color:var(--text-2); transition:all var(--transition); }
.tool-btn:hover { background:var(--accent); color:#fff; box-shadow:0 0 12px var(--accent-glow); transform:scale(1.08); }
.tool-btn svg { width:16px; height:16px; stroke:currentColor; fill:none; stroke-width:2.5; }
.ep-label { font-size:13px; font-weight:500; color:var(--text-2); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:280px; }
.type-toggle { display:flex; background:var(--bg-3); border-radius:8px; overflow:hidden; border:1px solid var(--border); }
.type-btn { padding:5px 14px; font-size:11px; font-weight:700; color:var(--text-3); letter-spacing:0.8px; text-transform:uppercase; transition:all var(--transition); }
.type-btn--active { background:linear-gradient(135deg,var(--accent-dark),var(--accent)); color:#fff; }
.type-btn:not(.type-btn--active):hover { color:var(--text); }
.server-select { background:var(--bg-3); border:1px solid var(--border); border-radius:8px; padding:6px 10px; color:var(--text); font-size:12px; font-weight:600; outline:none; cursor:pointer; transition:border-color var(--transition); }
.server-select:focus { border-color:var(--accent); }
.watch-sidebar { background:var(--bg-2); border-left:1px solid var(--border); display:flex; flex-direction:column; height:calc(100vh - var(--nav-h)); position:sticky; top:var(--nav-h); overflow:hidden; }
.sidebar-anime-info { padding:16px; border-bottom:1px solid var(--border); flex-shrink:0; }
.sidebar-anime-card { display:flex; gap:12px; align-items:flex-start; }
.sidebar-anime-card img { width:52px; height:74px; object-fit:cover; border-radius:8px; flex-shrink:0; border:1px solid var(--border-2); }
.sidebar-anime-title { font-size:13px; font-weight:600; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.sidebar-anime-type { font-size:11px; color:var(--text-3); margin-top:4px; }
.sidebar-eps { display:flex; flex-direction:column; flex:1; overflow:hidden; }
.sidebar-eps__header { padding:12px 16px; border-bottom:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; font-size:13px; font-weight:600; flex-shrink:0; }
.ep-search--sm { width:110px; padding:5px 10px; }
.ep-list { overflow-y:auto; flex:1; padding:6px; display:flex; flex-direction:column; gap:2px; }
.ep-item { display:flex; align-items:center; gap:10px; padding:9px 12px; border-radius:8px; cursor:pointer; transition:all var(--transition); border:1px solid transparent; }
.ep-item:hover { background:var(--surface); border-color:var(--border); }
.ep-item--active { background:var(--accent-dim); border-color:rgba(168,85,247,0.4); }
.ep-item__num { font-size:12px; font-weight:700; color:var(--text-3); min-width:28px; flex-shrink:0; }
.ep-item--active .ep-item__num { color:var(--accent); }
.ep-item__title { font-size:12px; color:var(--text-2); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ep-item--active .ep-item__title { color:var(--text); }
.ep-item--skel { height:42px; }

/* SEARCH / PAGES */
.search-page, .category-page, .filter-page, .schedule-page { padding:32px 0 64px; }
.page-header { margin-bottom:28px; }
.page-title { font-family:var(--font-display); font-size:clamp(26px,3vw,40px); letter-spacing:2px; background:linear-gradient(135deg,var(--text),var(--text-2)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.search-hero { text-align:center; padding:60px 0 48px; }
.search-hero__title { font-family:var(--font-display); font-size:clamp(32px,5vw,64px); letter-spacing:2px; margin-bottom:24px; background:linear-gradient(135deg,var(--accent),var(--gold)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.search-hero__bar { display:flex; max-width:520px; margin:0 auto; background:var(--surface); border:1px solid var(--border-2); border-radius:var(--radius-lg); overflow:hidden; transition:box-shadow var(--transition),border-color var(--transition); }
.search-hero__bar:focus-within { border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-dim); }
.hero-search-input { flex:1; background:none; border:none; outline:none; padding:14px 20px; color:var(--text); font-size:16px; }
.hero-search-input::placeholder { color:var(--text-3); }
.search-bar-wrap { margin-bottom:32px; }
.inline-search { display:flex; gap:12px; max-width:600px; }
.inline-search__input { flex:1; background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); padding:10px 16px; color:var(--text); font-size:15px; outline:none; transition:border-color var(--transition),box-shadow var(--transition); }
.inline-search__input:focus { border-color:var(--accent); box-shadow:0 0 0 2px var(--accent-dim); }
.results-count { font-size:14px; color:var(--text-3); margin-bottom:20px; }
.results-count em { color:var(--accent); font-style:normal; }

/* SCHEDULE */
.sched-tabs { display:flex; gap:8px; overflow-x:auto; padding-bottom:4px; margin-bottom:24px; scrollbar-width:none; }
.sched-tabs::-webkit-scrollbar { display:none; }
.sched-tab { padding:8px 18px; border-radius:20px; font-size:13px; font-weight:600; background:var(--surface); color:var(--text-2); border:1px solid var(--border); white-space:nowrap; transition:all var(--transition); }
.sched-tab:hover { border-color:var(--border-2); color:var(--text); }
.sched-tab--active { background:var(--accent-dim); color:var(--accent); border-color:rgba(168,85,247,0.4); }
.sched-item { display:flex; align-items:center; gap:16px; padding:14px 18px; background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg); margin-bottom:8px; transition:all var(--transition); cursor:pointer; }
.sched-item:hover { border-color:var(--border-2); transform:translateX(4px); background:var(--surface-2); box-shadow:var(--shadow-purple); }
.sched-item__time { font-size:13px; font-weight:700; color:var(--gold); min-width:56px; font-family:var(--font-display); letter-spacing:1px; }
.sched-item__title { flex:1; font-size:14px; font-weight:500; }
.sched-item__ep { font-size:12px; color:var(--text-3); white-space:nowrap; }
.sched-item__arrow { width:16px; height:16px; stroke:var(--text-3); fill:none; stroke-width:2.5; flex-shrink:0; transition:stroke var(--transition),transform var(--transition); }
.sched-item:hover .sched-item__arrow { stroke:var(--accent); transform:translateX(3px); }
.sched-item--skel { height:54px; margin-bottom:8px; }

/* FILTER */
.filter-panel { background:var(--surface); border:1px solid var(--border-2); border-radius:var(--radius-xl); padding:24px; margin-bottom:32px; }
.filter-row { display:flex; flex-wrap:wrap; gap:16px; margin-bottom:16px; }
.filter-row:last-child { margin-bottom:0; }
.filter-group { display:flex; flex-direction:column; gap:6px; }
.filter-group label { font-size:11px; font-weight:700; color:var(--text-3); letter-spacing:0.8px; text-transform:uppercase; }
.filter-group--wide { width:100%; }
.filter-select { background:var(--bg-3); border:1px solid var(--border); border-radius:8px; padding:9px 32px 9px 12px; color:var(--text); font-size:13px; outline:none; min-width:140px; cursor:pointer; transition:border-color var(--transition); appearance:none; -webkit-appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239b93c4' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 10px center; }
.filter-select:focus { border-color:var(--accent); box-shadow:0 0 0 2px var(--accent-dim); }
.genre-chips { display:flex; flex-wrap:wrap; gap:8px; }
.genre-chip { padding:5px 14px; background:var(--bg-3); border:1px solid var(--border); border-radius:20px; font-size:12px; font-weight:500; color:var(--text-2); transition:all var(--transition); cursor:pointer; }
.genre-chip:hover { border-color:var(--border-2); color:var(--text); transform:translateY(-1px); }
.genre-chip--active { background:var(--accent-dim); border-color:rgba(168,85,247,0.5); color:var(--accent); }
.filter-actions { display:flex; gap:12px; padding-top:8px; }

/* PAGINATION */
.pagination { display:flex; align-items:center; justify-content:center; gap:6px; padding:40px 0 20px; flex-wrap:wrap; }
.page-btn { min-width:38px; height:38px; padding:0 10px; border-radius:10px; background:var(--surface); border:1px solid var(--border); color:var(--text-2); font-size:13px; font-weight:600; display:flex; align-items:center; justify-content:center; transition:all var(--transition); }
.page-btn:hover { border-color:var(--accent); color:var(--accent); background:var(--accent-dim); transform:translateY(-1px); }
.page-btn--active { background:linear-gradient(135deg,var(--accent-dark),var(--accent)); border-color:var(--accent); color:#fff; box-shadow:0 4px 14px var(--accent-glow); }
.page-btn svg { width:16px; height:16px; stroke:currentColor; fill:none; stroke-width:2.5; }
.page-ellipsis { color:var(--text-3); padding:0 4px; }

/* STATES */
.loading-state, .error-state, .empty-state { display:flex; flex-direction:column; align-items:center; justify-content:center; padding:80px 20px; text-align:center; min-height:400px; }
.loading-msg { color:var(--text-3); margin-top:16px; font-size:14px; }
.error-icon { font-size:52px; font-family:var(--font-display); color:var(--accent); margin-bottom:16px; text-shadow:0 0 24px var(--accent-glow); }
.error-state h2 { font-family:var(--font-display); font-size:28px; margin-bottom:8px; letter-spacing:1px; }
.error-state p, .empty-state p { color:var(--text-2); margin-bottom:20px; }
.empty-icon { font-size:52px; margin-bottom:12px; }
.empty-state h3 { font-size:18px; margin-bottom:8px; }
.empty-state h3 em { font-style:normal; color:var(--text-2); }
.error-text { color:var(--accent); padding:20px; }
.spinner { width:42px; height:42px; border:3px solid var(--surface-2); border-top-color:var(--accent); border-radius:50%; animation:spin 0.7s linear infinite; box-shadow:0 0 16px var(--accent-glow); }

/* TOAST */
#toast-container { position:fixed; bottom:24px; right:24px; z-index:9999; display:flex; flex-direction:column; gap:8px; }
.toast { padding:12px 20px; border-radius:var(--radius-lg); font-size:13px; font-weight:500; box-shadow:var(--shadow-lg); opacity:0; transform:translateX(24px) scale(0.95); transition:all 0.28s cubic-bezier(0.4,0,0.2,1); backdrop-filter:blur(10px); }
.toast--show { opacity:1; transform:translateX(0) scale(1); }
.toast--info { background:rgba(28,25,48,0.9); color:var(--text); border:1px solid var(--border-2); }
.toast--error { background:rgba(42,10,10,0.9); color:#ff8080; border:1px solid rgba(255,0,0,0.3); }
.toast--success { background:rgba(10,42,18,0.9); color:#6bff8f; border:1px solid rgba(0,255,100,0.2); }

/* FOOTER */
.footer { background:var(--bg-2); border-top:1px solid var(--border); padding:40px 32px 32px; text-align:center; position:relative; }
.footer::before { content:''; position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent,var(--accent),var(--gold),transparent); opacity:0.4; }
.footer-image-container { display:flex; justify-content:center; margin-bottom:20px; }
.footer-art { max-width:100%; width:600px; height:auto; object-fit:contain; opacity:0.9; filter:drop-shadow(0 0 24px rgba(168,85,247,0.25)); transition:opacity var(--transition),filter var(--transition); }
.footer-art:hover { opacity:1; filter:drop-shadow(0 0 32px rgba(168,85,247,0.5)); }
.footer p { font-size:12px; color:var(--text-3); }
.footer a { color:var(--accent); transition:color var(--transition); }
.footer a:hover { color:var(--gold); }

/* ── TABLET ── */
@media (max-width:1100px) {
  .watch-page { grid-template-columns:1fr; }
  .watch-sidebar { height:auto; position:static; border-left:none; border-top:1px solid var(--border); max-height:480px; }
  .ep-list { max-height:320px; }
}
@media (max-width:900px) {
  .spotlight__content { left:36px; }
  .spotlight__dots { left:36px; }
  .anime-hero__content { flex-direction:column; padding:28px 24px; }
  .anime-poster { width:170px; }
}

/* ── MOBILE ── */
@media (max-width:768px) {
  :root { --nav-h:56px; }
  .navbar { padding:0 14px; gap:10px; }
  .nav-logo__img { height:80px; max-width:160px; }
  .nav-links { position:fixed; top:var(--nav-h); left:0; right:0; background:rgba(7,6,15,0.97); backdrop-filter:blur(20px); border-bottom:1px solid var(--border-2); flex-direction:column; align-items:flex-start; padding:10px; gap:3px; display:none; z-index:999; box-shadow:0 16px 40px rgba(0,0,0,0.7); animation:fadeInDown 0.2s ease; }
  .nav-links--open { display:flex; }
  .nav-link { width:100%; padding:12px 16px; font-size:15px; border-radius:10px; }
  .nav-link::after { display:none; }
  .burger { display:flex; }
  .nav-search { width:55px; overflow:hidden; transition:width 0.3s ease; border-radius:10px; }
  .nav-search:focus-within { width:250px; }
  .nav-search-input { padding:10px 11px; font-size:14px; }
  .spotlight__inner { height:70vh; min-height:400px; }
  .spotlight__content { left:18px; right:18px; max-width:none; bottom:64px; }
  .spotlight__title { font-size:clamp(24px,7vw,38px); }
  .spotlight__desc { -webkit-line-clamp:2; font-size:13px; }
  .spotlight__dots { left:18px; bottom:20px; }
  .spotlight__nav { width:38px; height:38px; }
  .spotlight__nav--prev { left:10px; }
  .spotlight__nav--next { right:10px; }
  .spotlight__actions { gap:8px; }
  .spotlight__actions .btn { padding:9px 16px; font-size:13px; }
  .home-section { padding:22px 16px; }
  .section-title { font-size:18px; }
  .anime-grid { grid-template-columns:repeat(auto-fill,minmax(110px,1fr)); gap:10px; }
  .trending-row { grid-template-columns:repeat(2,1fr); }
  .container { padding:0 16px; }
  .anime-body { padding:18px 16px 56px; }
  .anime-hero__content { gap:20px; padding:22px 16px; }
  .anime-poster { width:130px; }
  .anime-meta__title { font-size:clamp(22px,6vw,36px); }
  .info-table { font-size:12px; }
  .info-table th { width:100px; }
  .watch-page { grid-template-columns:1fr; }
  .player-wrap { min-height:220px; }
  .video-player { max-height:56vw; }
  .player-toolbar { flex-wrap:wrap; height:auto; padding:8px 12px; gap:8px; }
  .ep-label { max-width:160px; font-size:12px; }
  .watch-sidebar { max-height:420px; border-left:none; border-top:1px solid var(--border); }
  .sched-item { padding:12px 14px; gap:12px; }
  .filter-panel { padding:16px; border-radius:var(--radius-lg); }
  .filter-row { gap:10px; }
  .filter-select { min-width:120px; }
  .genre-chips { gap:6px; }
  .genre-chip { font-size:11px; padding:4px 10px; }
  .pagination { gap:4px; padding:24px 0 16px; }
  .page-btn { min-width:34px; height:34px; font-size:12px; border-radius:8px; }
  .footer { padding:32px 20px 24px; }
  .footer-art { width:100%; max-width:380px; }
}

/* ── SMALL PHONES ── */
@media (max-width:480px) {
  :root { --nav-h:52px; }
  .navbar { padding:0 12px; }
  .nav-logo__img { height:30px; max-width:110px; }
  .spotlight__inner { height:62vh; min-height:320px; }
  .spotlight__content { bottom:52px; }
  .spotlight__title { font-size:clamp(20px,8vw,30px); }
  .spotlight__desc, .spotlight__rank { display:none; }
  .anime-grid { grid-template-columns:repeat(3,1fr); gap:8px; }
  .card__info { padding:7px 8px 10px; }
  .card__title { font-size:11px; }
  .card:hover { transform:translateY(-3px) scale(1.01); }
  .trending-row { grid-template-columns:1fr 1fr; }
  .home-section { padding:16px 12px; }
  .section-title { font-size:16px; }
  .player-wrap { min-height:200px; }
  .video-player { max-height:56vw; }
  .ep-label { display:none; }
  .player-toolbar { justify-content:center; }
  .watch-sidebar { max-height:360px; }
  .ep-item { padding:8px 10px; }
  .btn { padding:9px 16px; font-size:13px; }
  .anime-poster { width:110px; }
  .sched-tabs { gap:6px; }
  .sched-tab { padding:7px 14px; font-size:12px; }
  .page-title { font-size:24px; }
  .filter-row { flex-direction:column; }
  .filter-select { width:100%; }
  #toast-container { bottom:16px; right:12px; left:12px; }
  .toast { text-align:center; }
}

/* ── TINY ── */
@media (max-width:360px) {
  .anime-grid { grid-template-columns:repeat(2,1fr); }
  .nav-search:focus-within { width:160px; }
  .spotlight__actions { flex-direction:column; }
  .spotlight__actions .btn { width:100%; justify-content:center; }
  .trending-row { grid-template-columns:1fr; }
}

/* Sidebar info ID selector (watch page) */
#sidebar-info { flex:1; }

/* Page title wrapper used in category/search/schedule */
.page-wrap { padding:0 32px; max-width:1400px; margin:0 auto; }

/* Genre page heading */
.genre-page { padding:32px 0 64px; }

/* AZ list */
.azlist-nav { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:28px; }
.azlist-btn { padding:6px 12px; background:var(--surface); border:1px solid var(--border); border-radius:8px; font-size:13px; font-weight:600; color:var(--text-2); transition:all var(--transition); }
.azlist-btn:hover { border-color:var(--accent); color:var(--accent); background:var(--accent-dim); }
.azlist-btn--active { background:var(--accent-dim); border-color:rgba(168,85,247,0.4); color:var(--accent); }

/* Producer page */
.producer-page { padding:32px 0 64px; }
.producer-header { display:flex; align-items:center; gap:20px; margin-bottom:32px; }
.producer-name { font-family:var(--font-display); font-size:clamp(24px,3vw,42px); letter-spacing:2px; background:linear-gradient(135deg,var(--text),var(--text-2)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }

/* Utility classes */
.text-accent { color:var(--accent); }
.text-gold   { color:var(--gold); }
.text-muted  { color:var(--text-3); }
.mt-8  { margin-top:8px; }
.mt-16 { margin-top:16px; }
.mt-24 { margin-top:24px; }
.mb-8  { margin-bottom:8px; }
.mb-16 { margin-bottom:16px; }
.mb-24 { margin-bottom:24px; }
.flex  { display:flex; }
.flex-center { display:flex; align-items:center; justify-content:center; }
.gap-8  { gap:8px; }
.gap-12 { gap:12px; }
.gap-16 { gap:16px; }
.wrap { flex-wrap:wrap; }

/* Divider */
.divider { height:1px; background:var(--border); margin:24px 0; }

/* Info badge row (used on anime detail page) */
.info-badges { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:16px; }

/* No-results within a grid */
.no-results { grid-column:1/-1; text-align:center; padding:60px 20px; color:var(--text-3); font-size:14px; }
.no-results strong { display:block; font-family:var(--font-display); font-size:22px; color:var(--text-2); letter-spacing:1px; margin-bottom:8px; }
