/* =================================================================
   Anime Sync Pro — anime-single.css  v18.5
   對應 single-anime.php v14.0
   深藍灰毛玻璃主題 / Hero 三欄 / 內容區 7:3
   2026-04-19
   ================================================================= */

/* ================================================================
   0. Blocksy 全域干擾清除
   ================================================================ */
html, body {
  background: #1E242B !important;
  background-color: #1E242B !important;
}
body:has(.asd-wrap),
html:has(.asd-wrap) {
  background: #1E242B !important;
  color: #D0D7E0 !important;
}
body:has(.asd-wrap) .site,
body:has(.asd-wrap) #page,
body:has(.asd-wrap) #content,
body:has(.asd-wrap) .site-content,
body:has(.asd-wrap) .content-area,
body:has(.asd-wrap) .entry-content,
body:has(.asd-wrap) main,
body:has(.asd-wrap) main.site-main,
body:has(.asd-wrap) article,
body:has(.asd-wrap) article.post,
body:has(.asd-wrap) .ct-main,
body:has(.asd-wrap) .ct-container,
body:has(.asd-wrap) .ct-main-content-area,
body:has(.asd-wrap) .ct-section,
body:has(.asd-wrap) .ct-section-inner-container,
body:has(.asd-wrap) .ct-single-post-content,
body:has(.asd-wrap) .singular-entry-content,
body:has(.asd-wrap) .wp-block-group,
body:has(.asd-wrap) .wp-block-post-content,
body:has(.asd-wrap) .entry-content > *:not(.asd-wrap) {
  background: transparent !important;
  background-color: transparent !important;
}
.asd-wrap h2.asd-section-title {
  padding-left: 0 !important;
  border-left: none !important;
}
.asd-wrap img { max-width: 100% !important; }
.asd-poster-img { max-width: none !important; }
.asd-wrap h2::after { display: none !important; }
.asd-wrap h2.asd-section-title::after { display: none !important; }

/* ================================================================
   1. CSS 變數
   ================================================================ */
:root {
  --asd-primary:        #63A8FF;
  --asd-primary-dark:   #4080D0;
  --asd-primary-glow:   rgba(99,168,255,.25);

  --asd-bg:             #1E242B;
  --asd-bg-card:        #242C35;
  --asd-bg-hover:       #2A3340;

  --asd-text:           #D0D7E0;
  --asd-text-muted:     rgba(208,215,224,.55);
  --asd-text-dim:       rgba(208,215,224,.35);
  --asd-text-soft:      rgba(208,215,224,.75);
  --asd-text-faint:     rgba(208,215,224,.25);

  --asd-border:         rgba(255,255,255,.08);

  --asd-shadow-sm:      0 2px  6px rgba(0,0,0,.28);
  --asd-shadow-md:      0 4px 14px rgba(0,0,0,.35);
  --asd-shadow-lg:      0 8px 28px rgba(0,0,0,.45);

  --asd-score-al:       #63A8FF;
  --asd-score-mal:      #8F6BFF;
  --asd-score-bgm:      #FB7185;

  --asd-radius-sm:      6px;
  --asd-radius-md:      10px;
  --asd-radius-lg:      16px;
  --asd-radius-xl:      22px;
  --asd-radius-pill:    50px;

  --asd-container:      1200px;
  --asd-gap:            24px;
  --asd-content-gap:    20px;

  --asd-poster-w:       300px;
  --asd-hero-side-w:    220px;

  --glass-blur:         14px;
  --glass-bg:           rgba(255,255,255,0.055);
  --glass-border:       rgba(255,255,255,0.08);

  --trans-smooth:       all .22s ease;
}

/* ================================================================
   2. Reset / 基礎
   ================================================================ */
.asd-wrap * { box-sizing: border-box; margin: 0; padding: 0; }
.asd-wrap a   { color: inherit; text-decoration: none; }
.asd-wrap img { display: block; }

/* ================================================================
   3. 外層容器
   ================================================================ */
.asd-wrap {
  max-width: var(--asd-container);
  margin: 0 auto;
  padding: var(--asd-gap);
  font-family: 'Noto Sans TC', sans-serif;
  font-size: .95rem;
  color: var(--asd-text);
  background: transparent !important;
}

/* ================================================================
   4. Banner — 真全寬 + 底部漸層
   ================================================================ */
.asd-banner {
  position: relative !important;
  left: 50% !important;
  right: 50% !important;
  margin-left: -50vw !important;
  margin-right: -50vw !important;
  width: 100vw !important;
  height: 320px !important;
  background-size: cover !important;
  background-position: center top !important;
  background-attachment: local !important;
  border-radius: 0 !important;
  margin-bottom: var(--asd-gap) !important;
  box-shadow: none !important;
  overflow: hidden !important;
}
.asd-banner--fallback {
  background: linear-gradient(135deg, #1a2535, #1E242B) !important;
  display: block !important;
}
.asd-banner-fade {
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(
    to bottom,
    rgba(30,36,43,0)    0%,
    rgba(30,36,43,0)   35%,
    rgba(30,36,43,.55) 65%,
    rgba(30,36,43,.88) 85%,
    rgba(30,36,43,1)  100%
  ) !important;
}

/* ================================================================
   5. Hero 三欄
   ================================================================ */
.asd-wrap .asd-hero-new {
  display: grid !important;
  grid-template-columns: var(--asd-poster-w) minmax(0,1fr) var(--asd-hero-side-w) !important;
  gap: var(--asd-gap) !important;
  align-items: start !important;
  margin: 0 0 var(--asd-gap) 0 !important;
  padding: var(--asd-gap) 0 !important;
  border-radius: 0 !important;
  border: none !important;
  background: transparent !important;
  background-image: none !important; 
  box-shadow: none !important;
  overflow: visible !important;
}

/* ── 海報 ── */
.asd-hero-poster {
  width: 100%;
  max-width: var(--asd-poster-w);
  align-self: start !important;
}
.asd-poster-img {
  width: 100% !important;
  height: 424px !important;
  object-fit: cover !important;
  border-radius: var(--asd-radius-xl) !important;
  box-shadow: var(--asd-shadow-lg) !important;
  display: block !important;
  max-width: none !important;
  background: rgba(255,255,255,.05);
}
.asd-poster-fallback {
  width: 100%;
  height: 424px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--asd-radius-xl);
  background:
    radial-gradient(circle at 30% 20%, rgba(124,92,255,.35), transparent 34%),
    linear-gradient(135deg, #182d53, #10213d);
  color: #fff;
  font-size: 3.5rem;
  font-weight: 800;
  overflow: hidden;
}

/* ── Hero 中欄 ── */
.asd-hero-body {
  min-width: 0;
  display: grid;
  align-content: start;
  gap: 16px;
  align-self: start !important;
}
.asd-hero-breadcrumb {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  color: var(--asd-text-muted);
  font-size: .9rem;
}
.asd-hbc-sep { color: var(--asd-text-faint); }

.asd-hero-title {
  margin: 0 !important;
  font-size: clamp(1.9rem, 2.3vw, 2.7rem) !important;
  font-weight: 700 !important;
  line-height: 1.15 !important;
  color: #fff !important;
  word-break: break-word;
}
.asd-hero-native {
  margin: 0;
  color: var(--asd-text-soft);
  line-height: 1.6;
  font-size: 1rem;
  word-break: break-word;
}
.asd-hero-romaji { color: var(--asd-text-muted); font-size: .94rem; }

.asd-series-entry-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 12px;
  background: rgba(99,168,255,.12);
  border: 1px solid rgba(99,168,255,.28);
  border-radius: var(--asd-radius-pill);
  font-size: .75rem;
  color: var(--asd-primary);
  text-decoration: none;
  transition: var(--trans-smooth);
  width: fit-content;
}
.asd-series-entry-badge:hover { background: rgba(99,168,255,.22); }

/* Hero badges */
.asd-hero-badges { display: flex; flex-wrap: wrap; gap: 10px; }
.asd-hbadge {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 14px;
  border-radius: var(--asd-radius-pill);
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  color: #fff;
  font-size: .84rem;
  font-weight: 700;
  line-height: 1.2;
}
.asd-hbadge--s-fin {
  background: rgba(52,211,153,.14);
  border-color: rgba(52,211,153,.28);
}
.asd-hbadge--s-rel {
  background: rgba(76,201,240,.14);
  border-color: rgba(76,201,240,.26);
}
.asd-hbadge--s-pre {
  background: rgba(251,191,36,.14);
  border-color: rgba(251,191,36,.28);
}
.asd-hbadge--s-can,
.asd-hbadge--s-hia {
  background: rgba(251,113,133,.14);
  border-color: rgba(251,113,133,.26);
}
.asd-hbadge--genre {
  background: rgba(124,92,255,.12);
  border-color: rgba(124,92,255,.24);
}

/* ── 評分 Pills ── */
.asd-hero-scores-new { display: flex; flex-wrap: wrap; gap: 12px; }
.asd-score-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 12px;
  border-radius: var(--asd-radius-pill);
  border: 1px solid rgba(255,255,255,.10);
  background: var(--asd-bg-card);
  font-size: .80rem;
  font-weight: 600;
  color: var(--asd-text);
  transition: var(--trans-smooth);
}
.asd-sp-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
  display: inline-block;
}
.asd-sp-label { font-size: .65rem; color: var(--asd-text-dim); }

.asd-wrap .asd-score-pill--al .asd-sp-dot {
  background: #63A8FF !important;
  box-shadow: 0 0 4px 1px rgba(99,168,255,.60), 0 0 8px 2px rgba(99,168,255,.30) !important;
}
.asd-wrap .asd-score-pill--al .asd-sp-val { color: #63A8FF !important; }

.asd-wrap .asd-score-pill--mal .asd-sp-dot {
  background: #8F6BFF !important;
  box-shadow: 0 0 4px 1px rgba(143,107,255,.60), 0 0 8px 2px rgba(143,107,255,.30) !important;
}
.asd-wrap .asd-score-pill--mal .asd-sp-val { color: #8F6BFF !important; }

.asd-wrap .asd-score-pill--bgm .asd-sp-dot {
  background: #FB7185 !important;
  box-shadow: 0 0 4px 1px rgba(251,113,133,.60), 0 0 8px 2px rgba(251,113,133,.30) !important;
}
.asd-wrap .asd-score-pill--bgm .asd-sp-val { color: #FB7185 !important; }

/* Action 按鈕 */
.asd-hero-actions { display: flex; flex-wrap: wrap; gap: 10px; }
.asd-action-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 18px;
  border-radius: var(--asd-radius-md);
  font-size: .85rem;
  font-weight: 600;
  cursor: pointer;
  border: 1px solid transparent;
  transition: var(--trans-smooth);
  text-decoration: none;
}
.asd-action-btn--primary { background: var(--asd-primary); color: #fff; }
.asd-action-btn--primary:hover { background: var(--asd-primary-dark); }
.asd-action-btn--ghost {
  background: rgba(255,255,255,.06);
  border-color: var(--asd-border);
  color: var(--asd-text-muted);
}
.asd-action-btn--ghost:hover { background: rgba(255,255,255,.10); color: var(--asd-text); }

/* ── Hero 右欄 ── */
.asd-hero-sidebar {
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
  min-width: 0 !important;
  width: var(--asd-hero-side-w) !important;
  align-self: start !important;
  margin: 0 !important;
  padding: 0 !important;
}
.asd-hside-block {
  padding: 14px;
  border-radius: var(--asd-radius-md);
  background: rgba(255,255,255,.06);
  border: 1px solid var(--asd-border);
  margin: 0 !important;
  width: 100%;
  box-sizing: border-box;
  overflow: hidden;
  word-break: break-word;
}
.asd-hside-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--asd-text-dim);
  text-transform: uppercase;
  letter-spacing: .5px;
  margin-bottom: 10px;
}
.asd-hside-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 4px 0;
}
.asd-hside-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.asd-hside-key { font-size: 12px; color: var(--asd-text-muted); flex: 1; }
.asd-hside-val { font-size: 15px; color: var(--asd-text); font-weight: 700; }
.asd-hside-info-row {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 5px 0;
  border-bottom: 1px solid var(--asd-border);
}
.asd-hside-info-row:last-child { border-bottom: none; }
.asd-hside-info-key { font-size: 12px; color: var(--asd-text-dim); min-width: 40px; flex-shrink: 0; }
.asd-hside-info-val { font-size: 12px; color: var(--asd-text); font-weight: 700; word-break: break-word; }

/* ================================================================
   6. Tabs 導覽列
   ================================================================ */
.asd-tabs-wrap {
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  box-sizing: border-box !important;
  overflow: hidden !important;
}
nav.asd-tabs {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 2px !important;
  padding: 6px 8px !important;
  border-radius: var(--asd-radius-md) !important;
  border: 1px solid var(--glass-border) !important;
  background: var(--glass-bg) !important;
  box-shadow: var(--asd-shadow-sm) !important;
  backdrop-filter: blur(var(--glass-blur)) !important;
  -webkit-backdrop-filter: blur(var(--glass-blur)) !important;
  margin-bottom: var(--asd-gap) !important;
  width: 100% !important;
  box-sizing: border-box !important;
}
nav.asd-tabs a.asd-tab {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  height: 34px !important;
  padding: 0 12px !important;
  margin: 0 !important;
  line-height: 1 !important;
  vertical-align: middle !important;
  border-radius: var(--asd-radius-sm) !important;
  font-size: .78rem !important;
  font-weight: 600 !important;
  color: rgba(208,215,224,.75) !important;  
  background: transparent !important;
  border: none !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  cursor: pointer !important;
  position: relative !important;
  transition: var(--trans-smooth) !important;
  box-sizing: border-box !important;
}
nav.asd-tabs a.asd-tab:hover {
  color: var(--asd-text) !important;
  background: rgba(99,168,255,.08) !important;
}
nav.asd-tabs a.asd-tab.is-active {
  color: var(--asd-primary) !important;
  background: rgba(99,168,255,.12) !important;
  font-weight: 700 !important;
}
nav.asd-tabs a.asd-tab.is-active::after {
  content: '' !important;
  position: absolute !important;
  bottom: 0 !important;
  left: 8px !important;
  right: 8px !important;
  height: 2px !important;
  border-radius: 2px !important;
  background: var(--asd-primary) !important;
  display: block !important;
}

/* ================================================================
   7. 內容主區
   ================================================================ */
.asd-container { display: block; }
.asd-container.asd-container--has-sidebar {
  display: grid;
  grid-template-columns: minmax(0,1fr) 300px;
  gap: var(--asd-gap);
  align-items: start;
}
.asd-main    { min-width: 0; display: flex; flex-direction: column; gap: var(--asd-content-gap); }
.asd-sidebar { display: flex; flex-direction: column; gap: var(--asd-content-gap); }

/* ================================================================
   8. Section 通用 Shared Glass
   ================================================================ */
.asd-section,
.asd-side-section,
.asd-info-row,
.asd-staff-card-v2,
.asd-cast-card,
.asd-music-card-v2,
.asd-stream-region,
.asd-faq-item,
.asd-ext-link-card {
  border: 1px solid var(--glass-border) !important;
  background: var(--glass-bg) !important;
  box-shadow: var(--asd-shadow-md) !important;
  backdrop-filter: blur(var(--glass-blur)) !important;
  -webkit-backdrop-filter: blur(var(--glass-blur)) !important;
}
.asd-section {
  padding: var(--asd-gap);
  border-radius: var(--asd-radius-lg);
}

/* 玻璃分隔線 */
.asd-glass-divider {
  display: block !important;
  width: 100% !important;
  height: 1px !important;
  min-height: 1px !important;
  max-height: 1px !important;
  line-height: 0 !important;
  font-size: 0 !important;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255,255,255,.15) 20%,
    rgba(255,255,255,.30) 50%,
    rgba(255,255,255,.15) 80%,
    transparent
  ) !important;
  margin: 0 0 16px 0 !important;
  border: none !important;
  opacity: 1 !important;
  visibility: visible !important;
  overflow: visible !important;
  flex-shrink: 0 !important;
}

/* Section 標題 */
.asd-wrap h2.asd-section-title {
  font-size: 1.05rem !important;
  font-weight: 700 !important;
  color: var(--asd-text) !important;
  margin-bottom: 12px !important;
  display: block !important;
  padding-bottom: 10px !important;
  border-bottom: 1px solid rgba(255,255,255,.15) !important;
}

/* ================================================================
   9. 基本資訊 Grid
   ================================================================ */
.asd-info-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}
.asd-info-grid .asd-info-row:last-child:nth-child(3n - 1) {
  grid-column: span 2;
}
.asd-info-grid .asd-info-row:last-child:nth-child(3n - 2) {
  grid-column: span 3;
}
.asd-info-row {
  display: flex;
  flex-direction: column;
  gap: 3px;
  padding: 10px 12px;
  border-radius: var(--asd-radius-sm);
}
.asd-info-label { font-size: .70rem; color: var(--asd-text-dim); text-transform: uppercase; letter-spacing: .5px; }
.asd-info-val   { font-size: .88rem; color: var(--asd-text); font-weight: 600; }
.asd-airing-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 12px;
  padding: 8px 14px;
  border-radius: var(--asd-radius-sm);
  background: rgba(99,168,255,.08);
  border: 1px solid rgba(99,168,255,.20);
  font-size: .82rem;
  color: var(--asd-text-muted);
}
.asd-countdown { color: var(--asd-primary); font-weight: 700; }

/* ================================================================
   10. 劇情簡介
   ================================================================ */
.asd-synopsis { font-size: .92rem; line-height: 1.85; color: var(--asd-text-muted); }
.asd-synopsis p { margin-bottom: .8em; }

/* ================================================================
   11. 預告片
   ================================================================ */
.asd-trailer-wrap {
  position: relative;
  width: 100%;
  padding-bottom: 56.25%;
  height: 0;
  border-radius: var(--asd-radius-md);
  overflow: hidden;
  box-shadow: var(--asd-shadow-lg);
  background: #000;
}
.asd-trailer-wrap iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

/* ================================================================
   12. 集數列表
   ================================================================ */
.asd-ep-list { display: flex; flex-direction: column; gap: 6px; }
.asd-ep-row {
  display: grid;
  grid-template-columns: 48px 1fr auto;
  gap: 10px;
  align-items: center;
  padding: 8px 12px;
  border-radius: var(--asd-radius-sm);
  background: var(--asd-bg-card);
  border: 1px solid var(--asd-border);
  transition: var(--trans-smooth);
}
.asd-ep-row:hover { background: var(--asd-bg-hover); }
.asd-ep-hidden  { display: none !important; }
.asd-ep-num     { font-size: .78rem; color: var(--asd-primary); font-weight: 700; }
.asd-ep-body    { display: flex; flex-direction: column; gap: 2px; }
.asd-ep-title   { font-size: .85rem; color: var(--asd-text); }
.asd-ep-title-ja { font-size: .75rem; color: var(--asd-text-dim); }
.asd-ep-date    { font-size: .72rem; color: var(--asd-text-dim); white-space: nowrap; }

/* 展開按鈕共用 */
.asd-ep-toggle,
.asd-staff-toggle,
.asd-cast-toggle {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 6px 18px !important;
  font-size: .78rem !important;
  font-weight: 600 !important;
  border-radius: var(--asd-radius-pill) !important;
  border: 1px solid var(--asd-border) !important;
  color: var(--asd-text-muted) !important;
  background: rgba(255,255,255,.04) !important;
  cursor: pointer !important;
  transition: var(--trans-smooth) !important;
  margin-top: 12px !important;
}
.asd-ep-toggle:hover,
.asd-staff-toggle:hover,
.asd-cast-toggle:hover {
  background: rgba(99,168,255,.10) !important;
  border-color: rgba(99,168,255,.30) !important;
  color: var(--asd-primary) !important;
}

/* ================================================================
   13. Staff（純文字，職位上、名字下）
   ================================================================ */
.asd-staff-grid-v2 {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 10px;
}
.asd-staff-card-v2 {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 14px 10px;
  border-radius: var(--asd-radius-md);
  text-align: center;
  transition: var(--trans-smooth);
}
.asd-staff-card-v2:hover { background: rgba(255,255,255,.10) !important; transform: translateY(-2px); }
.asd-staff-hidden { display: none !important; }
.asd-staff-role { font-size: .70rem; color: var(--asd-text-dim); letter-spacing: .3px; }
.asd-staff-name { font-size: .82rem; font-weight: 700; color: var(--asd-text); margin-top: 2px; }

/* ================================================================
   14. Cast
   ================================================================ */
.asd-cast-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 10px;
}
.asd-cast-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 12px 8px;
  border-radius: var(--asd-radius-md);
  text-align: center;
  transition: var(--trans-smooth);
}
.asd-cast-card:hover { background: rgba(255,255,255,.10) !important; transform: translateY(-2px); }
.asd-cast-hidden { display: none !important; }

.asd-cast-avatar-wrap {
  width: 100%;
  aspect-ratio: 3 / 4;
  border-radius: var(--asd-radius-sm);
  overflow: hidden;
  border: 1px solid var(--asd-border);
  flex-shrink: 0;
  position: relative;
}
.asd-cast-avatar-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
}
.asd-cast-avatar-fb {
  width: 100%;
  aspect-ratio: 3 / 4;
  border-radius: var(--asd-radius-sm);
  background: var(--asd-bg);
  border: 1px solid var(--asd-border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
  color: var(--asd-text-dim);
}
.asd-cast-info { display: flex; flex-direction: column; gap: 2px; width: 100%; }
.asd-cast-char        { font-size: .78rem; font-weight: 700; color: var(--asd-text); }
.asd-cast-char-native { font-size: .68rem; color: var(--asd-text-dim); }
.asd-cast-role        { font-size: .65rem; color: var(--asd-primary); }

.asd-cast-va {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 4px;
  padding-top: 6px;
  border-top: 1px solid var(--asd-border);
  width: 100%;
}
.asd-cast-va-info  { display: flex; flex-direction: column; gap: 1px; text-align: center; }
.asd-cast-va-name   { font-size: .70rem; color: var(--asd-text-muted); }
.asd-cast-va-native { font-size: .63rem; color: var(--asd-text-dim); }

/* ================================================================
   15. 主題曲
   ================================================================ */
.asd-music-group { margin-bottom: 20px; }
.asd-music-group:last-child { margin-bottom: 0; }
.asd-music-group-title {
  font-size: .82rem;
  font-weight: 700;
  color: var(--asd-text-muted);
  text-transform: uppercase;
  letter-spacing: .5px;
  margin: 0 0 10px 0;
  padding: 0;
  border: none;
}
.asd-music-card-v2 {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px 10px;
  padding: 12px 14px;
  border-radius: var(--asd-radius-md);
  margin-bottom: 8px;
  transition: var(--trans-smooth);
}
.asd-music-card-v2:hover { background: rgba(255,255,255,.08) !important; }
.asd-music-type-badge {
  order: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  font-size: .70rem;
  font-weight: 700;
  flex-shrink: 0;
}
.asd-music-type-badge--op { background: rgba(99,168,255,.22); color: var(--asd-primary); }
.asd-music-type-badge--ed { background: rgba(143,107,255,.22); color: #A78BFA; }
.asd-music-body {
  order: 2;
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1;
  min-width: 0;
}
.asd-music-title  { font-size: .90rem; font-weight: 700; color: var(--asd-text); }
.asd-music-native { font-size: .75rem; color: var(--asd-text-dim); }
.asd-music-artist { font-size: .78rem; color: var(--asd-text-muted); }
.asd-music-player-wrap {
  order: 3;
  width: 100%;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  border-radius: var(--asd-radius-pill);
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
}
.asd-music-play-btn {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 1px solid rgba(99,168,255,.40);
  background: rgba(99,168,255,.12);
  font-size: 0;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: var(--trans-smooth);
}
.asd-music-play-btn::before { font-size: .75rem; content: '▶'; color: var(--asd-primary); }
.asd-music-play-btn.is-playing::before { content: '⏸'; }
.asd-music-play-btn:hover { background: var(--asd-primary); border-color: var(--asd-primary); }
.asd-music-play-btn:hover::before { color: #fff; }
.asd-music-progress-wrap {
  flex: 1;
  height: 3px;
  border-radius: 3px;
  background: rgba(255,255,255,.12);
  cursor: pointer;
  position: relative;
  overflow: hidden;
}
.asd-music-progress-bar {
  height: 100%;
  width: 0%;
  border-radius: 3px;
  background: linear-gradient(90deg, var(--asd-primary), #a0c8ff);
  transition: width .1s linear;
  pointer-events: none;
}
.asd-music-time {
  font-size: .68rem;
  color: var(--asd-text-dim);
  white-space: nowrap;
  flex-shrink: 0;
  min-width: 36px;
  text-align: right;
}

/* ================================================================
   16. 串流平台
   ================================================================ */
.asd-stream-region {
  padding: 14px;
  border-radius: var(--asd-radius-md);
  margin-bottom: 14px;
}
.asd-stream-region:last-child { margin-bottom: 0; }
.asd-stream-region-head {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 12px;
  font-size: .82rem;
  font-weight: 600;
  color: var(--asd-text-muted);
}
.asd-stream-dot       { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.asd-stream-dot--tw   { background: #EF4444; box-shadow: 0 0 6px rgba(239,68,68,.60); }
.asd-stream-dot--intl { background: #3B82F6; box-shadow: 0 0 6px rgba(59,130,246,.60); }
.asd-stream-list { display: flex; flex-wrap: wrap; gap: 10px; }
.asd-stream-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 52px;
  padding: 10px 14px;
  border-radius: 16px;
  border: 1px solid rgba(99,168,255,.30);
  background: rgba(99,168,255,.06);
  color: var(--asd-primary);
  font-size: .84rem;
  font-weight: 600;
  line-height: 1.4;
  text-decoration: none;
  transition: var(--trans-smooth);
}
.asd-stream-btn:hover { background: rgba(99,168,255,.16); border-color: rgba(99,168,255,.55); }
.asd-stream-icon {
  width: 28px;
  height: 28px;
  object-fit: contain;
  flex-shrink: 0;
  border-radius: 8px;
  background: rgba(255,255,255,.90);
  padding: 3px;
}
.asd-stream-label {
  display: inline-block;
  color: var(--asd-text);
}
.asd-stream-btn--icon-only {
  justify-content: center;
  min-width: 52px;
  padding: 10px;
  gap: 0;
}
.asd-stream-btn--icon-only .asd-stream-icon {
  width: 30px;
  height: 30px;
}
.asd-stream-btn--auto {
  border-color: rgba(244,117,33,.45);
  background: rgba(244,117,33,.10);
}
.asd-stream-btn--no-link { opacity: .72; cursor: default; pointer-events: none; }

/* ================================================================
   17. FAQ（靜態展示）
   ================================================================ */
.asd-faq-list { display: flex; flex-direction: column; gap: 12px; }
.asd-faq-item {
  padding: 16px;
  border-radius: var(--asd-radius-md);
  overflow: hidden;
}
.asd-faq-q {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  margin-bottom: 10px;
}
.asd-faq-q-label {
  font-size: .88rem;
  font-weight: 800;
  color: var(--asd-primary);
  flex-shrink: 0;
  line-height: 1.5;
}
.asd-faq-q-text {
  font-size: .90rem;
  font-weight: 700;
  color: var(--asd-text);
  line-height: 1.5;
}
.asd-faq-a {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding-top: 8px;
  border-top: 1px solid var(--asd-border);
}
.asd-faq-a-label {
  font-size: .88rem;
  font-weight: 800;
  color: var(--asd-text-muted);
  flex-shrink: 0;
  line-height: 1.75;
}
.asd-faq-a-text {
  font-size: .88rem;
  line-height: 1.75;
  color: var(--asd-text-muted);
}
.asd-faq-a-text p { margin-bottom: .5em; }
.asd-faq-a-text p:last-child { margin-bottom: 0; }

/* ================================================================
   18. 外部連結
   ================================================================ */
.asd-ext-links-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 10px;
}
.asd-ext-link-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 10px 14px;
  border-radius: var(--asd-radius-md);
  color: var(--asd-text-muted);
  font-size: .82rem;
  font-weight: 600;
  transition: var(--trans-smooth);
}
.asd-ext-link-card:hover { background: rgba(255,255,255,.10) !important; color: var(--asd-text); }
.asd-ext-site  { flex: 1; }
.asd-ext-arrow { font-size: .80rem; color: var(--asd-text-dim); }
.asd-ext--al:hover  { border-color: rgba(99,168,255,.40) !important;  color: #63A8FF; }
.asd-ext--mal:hover { border-color: rgba(143,107,255,.40) !important; color: #8F6BFF; }
.asd-ext--bgm:hover { border-color: rgba(251,113,133,.40) !important; color: #FB7185; }

/* ================================================================
   19. 留言
   ================================================================ */
.asd-wrap .comment-respond,
.asd-wrap #comments { color: var(--asd-text); }
.asd-wrap .comment-form input,
.asd-wrap .comment-form textarea {
  background: var(--asd-bg-card);
  border: 1px solid var(--asd-border);
  border-radius: var(--asd-radius-sm);
  color: var(--asd-text);
  padding: 8px 12px;
  width: 100%;
}
.asd-wrap .comment-form input:focus,
.asd-wrap .comment-form textarea:focus { border-color: var(--asd-primary); outline: none; }
.asd-wrap .submit {
  background: var(--asd-primary);
  color: #fff;
  border: none;
  padding: 8px 20px;
  border-radius: var(--asd-radius-sm);
  cursor: pointer;
  font-weight: 600;
  transition: var(--trans-smooth);
}
.asd-wrap .submit:hover { background: var(--asd-primary-dark); }

/* ================================================================
   20. Sidebar 區塊
   ================================================================ */
.asd-side-section {
  padding: 16px;
  border-radius: var(--asd-radius-lg);
}
.asd-side-section__head { margin-bottom: 12px; }
.asd-side-section__head h3 {
  font-size: .90rem !important;
  font-weight: 700 !important;
  color: var(--asd-text) !important;
  margin: 0 0 12px 0 !important;
  padding: 0 0 10px 0 !important;
  border: none !important;
  border-bottom: 1px solid rgba(255,255,255,.15) !important;
}
.asd-side-empty {
  font-size: .80rem;
  color: var(--asd-text-dim);
  text-align: center;
  padding: 16px 0;
  margin: 0;
}

/* ── 作品標籤 ── */
.asd-tags-wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  max-height: calc(2 * 28px + 6px);
  overflow: hidden;
}
.asd-tag-item {
  padding: 3px 10px;
  border-radius: var(--asd-radius-pill);
  font-size: .72rem;
  background: rgba(255,255,255,.06);
  border: 1px solid var(--asd-border);
  color: var(--asd-text-muted);
  text-decoration: none;
  transition: var(--trans-smooth);
}
.asd-tag-item:hover { color: var(--asd-text); border-color: rgba(255,255,255,.18); }
.asd-tag-item--season {
  background: rgba(99,168,255,.08);
  border-color: rgba(99,168,255,.20);
  color: var(--asd-primary);
}
.asd-tag-item--season:hover { background: rgba(99,168,255,.16); }
.asd-tag-item--studio {
  background: rgba(251,191,36,.08);
  border-color: rgba(251,191,36,.25);
  color: #FBBF24;
}
.asd-tag-item--studio:hover { background: rgba(251,191,36,.16); }

/* ── 相關新聞 ── */
.asd-side-news { display: flex; flex-direction: column; gap: 6px; }
.asd-news-card {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: var(--asd-radius-sm);
  background: rgba(255,255,255,.04);
  border: 1px solid var(--asd-border);
  text-decoration: none;
  color: var(--asd-text-muted);
  transition: var(--trans-smooth);
}
.asd-news-card:hover { background: rgba(255,255,255,.08); color: var(--asd-text); }
.asd-news-card__title {
  font-size: .78rem;
  flex: 1;
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  word-break: break-word;
}

/* ── 相關作品 ── */
.asd-side-cards { display: flex; flex-direction: column; gap: 8px; }
.asd-mini-card {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  border-radius: var(--asd-radius-sm);
  background: rgba(255,255,255,.04);
  border: 1px solid var(--asd-border);
  text-decoration: none;
  color: var(--asd-text);
  transition: var(--trans-smooth);
}
.asd-mini-card:hover { background: rgba(255,255,255,.08); }
.asd-mini-card__thumb {
  width: 44px; height: 58px;
  border-radius: var(--asd-radius-sm);
  overflow: hidden;
  flex-shrink: 0;
  border: 1px solid var(--asd-border);
  background: var(--asd-bg);
}
.asd-mini-card__thumb img { width: 100%; height: 100%; object-fit: cover; }
.asd-mini-card__body { display: flex; flex-direction: column; gap: 3px; flex: 1; min-width: 0; }
.asd-mini-card__rel {
  font-size: .65rem;
  color: var(--asd-primary);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .3px;
}
.asd-mini-card__title {
  font-size: .78rem;
  color: var(--asd-text);
  line-height: 1.35;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  word-break: break-word;
}
.asd-mini-card__native {
  font-size: .68rem;
  color: var(--asd-text-dim);
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
  word-break: break-word;
}

/* ── 贊助區塊 ── */
.asd-sponsor-block {
  padding: 20px 16px;
  border-radius: var(--asd-radius-lg);
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: center;
}
.asd-sponsor-title {
  font-size: .95rem;
  font-weight: 700;
  color: var(--asd-text);
}
.asd-sponsor-desc {
  font-size: .80rem;
  color: var(--asd-text-muted);
  line-height: 1.6;
}
.asd-sponsor-h {
  color: var(--asd-primary);
  font-weight: 700;
}
.asd-sponsor-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 9px 22px;
  border-radius: var(--asd-radius-pill);
  background: linear-gradient(135deg, #3B82F6, #2563EB);
  color: #fff;
  font-size: .85rem;
  font-weight: 700;
  text-decoration: none;
  border: none;
  cursor: pointer;
  transition: var(--trans-smooth);
  box-shadow: 0 4px 14px rgba(59,130,246,.35);
}
.asd-sponsor-btn:hover {
  background: linear-gradient(135deg, #2563EB, #1D4ED8);
  box-shadow: 0 4px 20px rgba(59,130,246,.55);
  color: #fff;
}
.asd-sponsor-note {
  font-size: .72rem;
  color: var(--asd-text-dim);
}

/* ================================================================
   21. RWD
   ================================================================ */
@media (max-width: 1024px) {
  :root {
    --asd-poster-w:      260px;
    --asd-hero-side-w:   180px;
  }
}

@media (max-width: 900px) {
  .asd-wrap .asd-hero-new {
    grid-template-columns: 200px minmax(0,1fr) !important;
  }
  .asd-hero-sidebar { display: none !important; }
  .asd-poster-img,
  .asd-poster-fallback { height: 280px !important; }
}

@media (max-width: 768px) {
  .asd-wrap .asd-hero-new {
    grid-template-columns: 1fr !important;
    padding: 16px !important;
  }
  .asd-hero-poster { max-width: 180px; margin: 0 auto; }
  .asd-poster-img,
  .asd-poster-fallback { height: 240px !important; }
  .asd-container.asd-container--has-sidebar {
    grid-template-columns: 1fr;
  }
  .asd-cast-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 480px) {
  :root { --asd-gap: 14px; }
  .asd-hero-poster { max-width: 140px; }
  .asd-poster-img,
  .asd-poster-fallback { height: 200px !important; }
  .asd-cast-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  nav.asd-tabs { gap: 1px !important; }
  nav.asd-tabs a.asd-tab { padding: 0 8px !important; font-size: .72rem !important; }
}
.asd-section,
#comments {
  scroll-margin-top: 72px;
}
/* ================================================================
   Anime Sync Pro — compatibility patch
   不改設計語言，優先修 Firefox / 滾動定位 / 版面穩定性
   ================================================================ */

/* 1) Anchor 捲動定位更穩，避免標題被導覽列蓋住 */
.asd-section,
#comments {
  scroll-margin-top: 72px;
}

/* 2) Grid / Flex 子元素避免在 Firefox 或窄版被撐爆 */
.asd-hero-body,
.asd-main,
.asd-sidebar,
.asd-staff-card-v2,
.asd-cast-card,
.asd-music-card-v2,
.asd-mini-card,
.asd-mini-card__body,
.asd-info-row,
.asd-ext-link-card {
  min-width: 0;
}

/* 3) 長文字避免撐爆卡片 */
.asd-hero-title,
.asd-hero-native,
.asd-hero-romaji,
.asd-info-val,
.asd-hside-info-val,
.asd-staff-name,
.asd-staff-native,
.asd-cast-char,
.asd-cast-char-native,
.asd-cast-va-name,
.asd-cast-va-native,
.asd-music-title,
.asd-music-native,
.asd-music-artist,
.asd-news-card__title,
.asd-mini-card__title,
.asd-mini-card__native,
.asd-ext-site {
  overflow-wrap: anywhere;
  word-break: break-word;
}

/* 4) Tabs 容器避免某些瀏覽器陰影/內容被裁切 */
.asd-tabs-wrap {
  overflow: visible !important;
}

/* 5) Hero 區塊避免 Firefox 對 overflow + grid 裁切過度 */
.asd-wrap .asd-hero-new {
  min-width: 0;
}

/* 6) 讓海報、角色圖、縮圖在 Firefox 更穩 */
.asd-poster-img,
.asd-cast-avatar-wrap img,
.asd-mini-card__thumb img {
  image-rendering: auto;
}

/* 7) 按鈕/連結字體與行高一致，避免 Firefox 原生樣式差異 */
.asd-action-btn,
.asd-ep-toggle,
.asd-staff-toggle,
.asd-cast-toggle,
.asd-music-play-btn,
.asd-stream-btn,
.asd-ext-link-card,
nav.asd-tabs a.asd-tab {
  line-height: 1.2;
}

/* 8) 音樂播放器在不同瀏覽器避免內容擠壓 */
.asd-music-player-wrap {
  min-width: 0;
}
.asd-music-progress-wrap {
  min-width: 0;
}

/* 9) 留言表單在 Firefox 避免被 reset 後高度怪異 */
.asd-wrap .comment-form input,
.asd-wrap .comment-form textarea,
.asd-wrap .submit,
.asd-music-play-btn,
.asd-ep-toggle,
.asd-staff-toggle,
.asd-cast-toggle {
  font: inherit;
}

/* 11) 窄螢幕下 tabs 間距再柔和一點，避免換行過度擠壓 */
@media (max-width: 768px) {
  nav.asd-tabs {
    row-gap: 6px !important;
  }
}

/* 12) 超窄螢幕下外部連結與資訊卡更穩 */
@media (max-width: 480px) {
  .asd-ext-links-grid,
  .asd-info-grid {
    grid-template-columns: 1fr !important;
  }

  .asd-stream-list,
  .asd-hero-actions,
  .asd-hero-badges,
  .asd-hero-scores-new {
    gap: 8px;
  }
}
/* =================================================================
   FF-FIX — Firefox 相容性修正
   加在 anime-single.css 最底部
   ================================================================= */

/* Firefox backdrop-filter 降級 */
@supports not (backdrop-filter: blur(1px)) {
  .asd-section,
  .asd-side-section,
  .asd-info-row,
  .asd-staff-card-v2,
  .asd-cast-card,
  .asd-music-card-v2,
  .asd-stream-region,
  .asd-faq-item,
  .asd-ext-link-card,
  nav.asd-tabs,
  .asd-hside-block {
    background: rgba(36, 44, 53, 0.88) !important;
  }
}

/* 字型修正 */
.asd-wrap, .asd-wrap * {
  font-family: 'Noto Sans TC', 'PingFang TC', 'Microsoft JhengHei', sans-serif !important;
}
.asd-wrap code, .asd-wrap pre {
  font-family: 'Courier New', Courier, monospace !important;
}
/* ── 留言區對齊修正 ── */
.asd-comments {
  width: 100%;
  box-sizing: border-box;
}
.asd-comments-inner {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}
.asd-comments #comments,
.asd-comments .comments-area {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  box-sizing: border-box !important;
  background: transparent !important;
  border: none !important;
}
.asd-comments .comment-list {
  width: 100% !important;
  padding: 0 !important;
  margin: 0 0 16px 0 !important;
  list-style: none !important;
}
.asd-comments #respond,
.asd-comments .comment-respond {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  box-sizing: border-box !important;
  background: transparent !important;
  border: none !important;
}
.asd-comments .wpd-thread-list,
.asd-comments .wpd-primary,
.asd-comments #wpcomm {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  box-sizing: border-box !important;
}
.asd-comments #disqus_thread {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  box-sizing: border-box !important;
}

/* ================================================================
   21. WeixiaoACG+ 評分系統
   ================================================================ */

/* 右欄限高 — 防止評分 block 撐破 Hero Grid */
.asd-hero-sidebar {
  max-height: 424px !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  scrollbar-width: thin !important;
  scrollbar-color: rgba(255,255,255,.15) transparent !important;
}
.asd-hero-sidebar::-webkit-scrollbar {
  width: 3px !important;
}
.asd-hero-sidebar::-webkit-scrollbar-track {
  background: transparent !important;
}
.asd-hero-sidebar::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,.20) !important;
  border-radius: 3px !important;
}

/* 評分分隔線 */
.wacg-rating-divider {
  width: 100%;
  height: 1px;
  background: var(--asd-border);
  margin: 8px 0;
}

/* WeixiaoACG+ 圓點 */
.wacg-dot-site {
  background: #34D399;
  box-shadow: 0 0 4px 1px rgba(52,211,153,.60), 0 0 8px 2px rgba(52,211,153,.30);
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}

/* 統計區 */
.wacg-rating-stats { width: 100%; box-sizing: border-box; }

.wacg-score-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 2px 0;
}

.wacg-vote-count {
  font-size: 10px;
  color: var(--asd-text-dim);
  padding: 1px 0 4px 0;
  text-align: center;
}

/* 四項分類 — 兩欄並排 */
.wacg-cats {
  width: 100%;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2px 6px;
  margin: 4px 0;
}
.wacg-cat-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1px 0;
}
.wacg-cat-label { font-size: 10px; color: var(--asd-text-dim); }
.wacg-cat-val   { font-size: 11px; font-weight: 700; color: var(--asd-text); }

/* 評分表單 */
.wacg-rating-form {
  width: 100%;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  gap: 5px;
  margin-top: 6px;
  padding-top: 6px;
  border-top: 1px solid var(--asd-border);
}
.wacg-slider-row {
  display: flex;
  align-items: center;
  gap: 4px;
  width: 100%;
}
.wacg-slider-label {
  font-size: 10px;
  color: var(--asd-text-dim);
  width: 24px;
  flex-shrink: 0;
}
.wacg-slider {
  flex: 1;
  min-width: 0;
  height: 3px;
  -webkit-appearance: none;
  appearance: none;
  background: rgba(255,255,255,.12);
  border-radius: 3px;
  outline: none;
  cursor: pointer;
}
.wacg-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: #34D399;
  box-shadow: 0 0 4px rgba(52,211,153,.60);
  cursor: pointer;
  transition: transform .15s ease;
}
.wacg-slider::-webkit-slider-thumb:hover { transform: scale(1.25); }
.wacg-slider::-moz-range-thumb {
  width: 12px;
  height: 12px;
  border: none;
  border-radius: 50%;
  background: #34D399;
  cursor: pointer;
}
.wacg-slider-val {
  font-size: 11px;
  font-weight: 700;
  color: #34D399;
  width: 24px;
  text-align: right;
  flex-shrink: 0;
}

.wacg-submit-btn {
  width: 100%;
  padding: 6px 0;
  border-radius: var(--asd-radius-sm);
  border: none;
  background: linear-gradient(135deg, #34D399, #63A8FF);
  color: #fff;
  font-size: .78rem;
  font-weight: 700;
  cursor: pointer;
  transition: opacity .2s ease;
  margin-top: 2px;
}
.wacg-submit-btn:hover    { opacity: .85; }
.wacg-submit-btn:disabled { opacity: .5; cursor: not-allowed; }

/* 未登入提示 */
.wacg-login-prompt {
  display: block;
  width: 100%;
  padding: 6px 0;
  margin-top: 6px;
  border-top: 1px solid var(--asd-border);
  text-align: center;
  font-size: .75rem;
  color: var(--asd-primary);
  text-decoration: none;
  transition: var(--trans-smooth);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.wacg-login-prompt:hover { color: #fff; }

/* Hero Pill — WeixiaoACG+ */
.asd-wrap .asd-score-pill--site .asd-sp-dot {
  background: #34D399 !important;
  box-shadow: 0 0 4px 1px rgba(52,211,153,.60), 0 0 8px 2px rgba(52,211,153,.30) !important;
}
.asd-wrap .asd-score-pill--site .asd-sp-val { color: #34D399 !important; }

/* Toast */
.wacg-toast {
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%) translateY(20px);
  padding: 10px 24px;
  border-radius: var(--asd-radius-pill);
  font-size: .85rem;
  font-weight: 600;
  color: #fff;
  z-index: 9999;
  opacity: 0;
  transition: opacity .3s ease, transform .3s ease;
  pointer-events: none;
  white-space: nowrap;
}
.wacg-toast--success { background: #34D399; }
.wacg-toast--error   { background: #FB7185; }
.wacg-toast--show {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

/* ================================================================
   22. 追蹤列 SMACG Track Bar  v2 — 對齊圖1
   ================================================================ */
.smacg-track-bar {
  margin: 0 0 var(--asd-gap) 0;
  padding: 14px 20px;
  border-radius: var(--asd-radius-lg);
  border: 1px solid var(--glass-border);
  background: var(--glass-bg);
  box-shadow: var(--asd-shadow-md);
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  position: relative;
}

/* 主橫列：狀態 | 進度（彈性） | 動作 */
.smacg-track-main {
  display: flex;
  align-items: center;
  gap: 24px;
  flex-wrap: nowrap;
}

/* 不再使用直線分隔（圖1沒有） */
.smacg-track-sep { display: none; }

/* ── 狀態按鈕群組 ── */
.smacg-status-group {
  display: flex;
  gap: 8px;
  flex-shrink: 0;
}
.smacg-status-btn {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  width: 64px;
  height: 56px;
  padding: 0;
  border-radius: 14px;
  border: 1px solid var(--asd-border);
  background: rgba(255,255,255,.04);
  color: var(--asd-text-muted);
  font-size: .72rem;
  font-weight: 600;
  cursor: pointer;
  transition: var(--trans-smooth);
  line-height: 1;
}
.smacg-status-btn i {
  font-size: .95rem;
  margin-bottom: 2px;
}
.smacg-status-btn span {
  font-size: .72rem;
  white-space: nowrap;
}
.smacg-status-btn:hover {
  background: rgba(99,168,255,.10);
  border-color: rgba(99,168,255,.30);
  color: var(--asd-primary);
}
.smacg-status-btn.is-active {
  background: var(--asd-primary);
  border-color: var(--asd-primary);
  color: #fff;
  box-shadow: 0 4px 14px rgba(99,168,255,.35);
}

/* ── 進度條群組 ── */
.smacg-progress-group {
  flex: 1;
  min-width: 0;
  display: grid;
  grid-template-rows: auto auto auto;
  gap: 4px;
  max-width: 520px;
  margin: 0 auto;
}
.smacg-prog-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: .75rem;
  color: var(--asd-text-muted);
  min-height: 16px;
}
.smacg-prog-label {
  color: var(--asd-text-muted);
  font-weight: 500;
}
.smacg-prog-pct {
  color: var(--asd-primary);
  font-weight: 700;
  font-size: .78rem;
}

.smacg-prog-bar-wrap {
  width: 100%;
  height: 4px;
  background: rgba(255,255,255,.08);
  border-radius: 4px;
  overflow: hidden;
}
.smacg-prog-bar {
  height: 100%;
  background: linear-gradient(90deg, var(--asd-primary), #34D399);
  border-radius: 4px;
  transition: width .35s ease;
}

.smacg-prog-controls {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  margin-top: 2px;
}
.smacg-prog-btn {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 1px solid var(--asd-border);
  background: rgba(255,255,255,.06);
  color: var(--asd-text);
  font-size: 1rem;
  font-weight: 700;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: var(--trans-smooth);
  line-height: 1;
}
.smacg-prog-btn:hover {
  background: var(--asd-primary);
  border-color: var(--asd-primary);
  color: #fff;
}
.smacg-prog-display {
  font-size: .85rem;
  color: var(--asd-text);
  font-weight: 600;
  white-space: nowrap;
}
.smacg-prog-current { color: var(--asd-text); font-weight: 700; }
.smacg-prog-sep,
.smacg-prog-total,
.smacg-prog-unit { color: var(--asd-text-muted); font-weight: 500; }

/* ── 動作按鈕群組 ── */
.smacg-action-group {
  display: flex;
  gap: 8px;
  flex-shrink: 0;
}
.smacg-icon-btn {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  border: 1px solid var(--asd-border);
  background: rgba(255,255,255,.04);
  color: var(--asd-text-muted);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: .9rem;
  transition: var(--trans-smooth);
}
.smacg-icon-btn:hover {
  background: rgba(99,168,255,.12);
  border-color: rgba(99,168,255,.35);
  color: var(--asd-primary);
  transform: translateY(-1px);
}
.smacg-fav-btn.is-active {
  background: rgba(251,191,36,.18);
  border-color: rgba(251,191,36,.45);
  color: #FBBF24;
}
.smacg-clear-btn.is-active {
  background: rgba(52,211,153,.18);
  border-color: rgba(52,211,153,.45);
  color: #34D399;
}

/* ── Toast ── */
.smacg-point-toast {
  position: absolute;
  top: -8px;
  right: 16px;
  padding: 4px 12px;
  border-radius: var(--asd-radius-pill);
  background: #34D399;
  color: #fff;
  font-size: .72rem;
  font-weight: 700;
  opacity: 0;
  transform: translateY(0);
  pointer-events: none;
  transition: opacity .3s ease, transform .3s ease;
}
.smacg-point-toast.is-show {
  opacity: 1;
  transform: translateY(-6px);
}

/* ── 分享浮窗 ── */
.smacg-share-modal {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.65);
  z-index: 9998;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.smacg-share-inner {
  position: relative;
  width: 100%;
  max-width: 360px;
  padding: 24px;
  border-radius: var(--asd-radius-lg);
  background: var(--asd-bg-card);
  border: 1px solid var(--glass-border);
  box-shadow: var(--asd-shadow-lg);
  text-align: center;
}
.smacg-share-title {
  font-size: 1rem;
  font-weight: 700;
  color: var(--asd-text);
  margin: 0 0 16px 0;
}
.smacg-share-btns {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.smacg-share-link {
  display: block;
  width: 100%;
  padding: 10px 16px;
  border-radius: var(--asd-radius-md);
  border: 1px solid var(--asd-border);
  background: rgba(255,255,255,.04);
  color: var(--asd-text);
  font-size: .85rem;
  font-weight: 600;
  text-decoration: none;
  cursor: pointer;
  transition: var(--trans-smooth);
}
.smacg-share-link:hover {
  background: rgba(99,168,255,.12);
  border-color: rgba(99,168,255,.35);
  color: var(--asd-primary);
}
.smacg-share-x:hover  { color: #fff; background: #000; border-color: #000; }
.smacg-share-fb:hover { color: #fff; background: #1877F2; border-color: #1877F2; }
.smacg-share-close {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: none;
  background: transparent;
  color: var(--asd-text-muted);
  font-size: 1rem;
  cursor: pointer;
}
.smacg-share-close:hover { color: var(--asd-text); }

/* ── RWD ── */
@media (max-width: 900px) {
  .smacg-track-main {
    gap: 14px;
    flex-wrap: wrap;
  }
  .smacg-status-group {
    width: 100%;
    justify-content: space-between;
  }
  .smacg-status-btn {
    flex: 1;
  }
  .smacg-progress-group {
    width: 100%;
    max-width: none;
  }
  .smacg-action-group {
    width: 100%;
    justify-content: center;
  }
}
@media (max-width: 480px) {
  .smacg-track-bar {
    padding: 12px 14px;
  }
  .smacg-status-btn {
    width: auto;
    height: 50px;
  }
  .smacg-status-btn span {
    font-size: .68rem;
  }
}
/* =========================================================
   23. PV Tabs（多支預告片切換）
   ========================================================= */
.asd-pv-count {
    color: var(--asd-text-muted);
    font-size: .85em;
    font-weight: 500;
}

.asd-pv-box {
    border-radius: var(--asd-radius-lg);
    overflow: hidden;
}

.asd-pv-tabs {
    display: flex;
    gap: 6px;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 4px 2px 10px;
    scrollbar-width: thin;
    -webkit-overflow-scrolling: touch;
}
.asd-pv-tabs::-webkit-scrollbar { height: 4px; }
.asd-pv-tabs::-webkit-scrollbar-thumb { background: rgba(255,255,255,.15); border-radius: 4px; }

.asd-pv-tab {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    border-radius: var(--asd-radius-pill, 999px);
    border: 1px solid var(--asd-border);
    background: rgba(255,255,255,.04);
    color: var(--asd-text-muted);
    font-size: .85rem;
    font-weight: 600;
    line-height: 1;
    cursor: pointer;
    white-space: nowrap;
    flex-shrink: 0;
    transition: all .2s ease;
}
.asd-pv-tab:hover {
    background: rgba(99,168,255,.10);
    border-color: rgba(99,168,255,.30);
    color: var(--asd-primary, #63A8FF);
}
.asd-pv-tab.is-active {
    background: linear-gradient(135deg, rgba(99,168,255,.22), rgba(99,168,255,.10));
    border-color: rgba(99,168,255,.55);
    color: var(--asd-primary, #63A8FF);
    box-shadow: 0 2px 8px rgba(99,168,255,.20);
}
.asd-pv-tab-icon {
    font-size: .7rem;
    opacity: .85;
    transform: translateY(-1px);
}

/* Panel */
.asd-pv-panels { position: relative; }
.asd-pv-panel  { display: none; animation: asdPvFadeIn .25s ease; }
.asd-pv-panel.is-active { display: block; }

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

/* 縮圖佔位（非首張 PV） */
.asd-pv-placeholder {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    background-color: #000;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}
.asd-pv-placeholder::before {
    content: "";
    position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(0,0,0,.10) 0%, rgba(0,0,0,.55) 100%);
}
.asd-pv-play {
    position: relative;
    width: 72px; height: 72px;
    border-radius: 50%;
    border: 0;
    background: rgba(255,0,0,.92);
    color: #fff;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 6px 24px rgba(0,0,0,.35);
    transition: transform .2s ease, background .2s ease;
}
.asd-pv-play:hover { transform: scale(1.08); background: #ff1a1a; }
.asd-pv-play-icon { font-size: 1.6rem; transform: translateX(2px); }

/* 響應式 */
@media (max-width: 768px) {
    .asd-pv-tab { padding: 7px 12px; font-size: .78rem; }
    .asd-pv-play { width: 60px; height: 60px; }
    .asd-pv-play-icon { font-size: 1.4rem; }
}
@media (max-width: 480px) {
    .asd-pv-tab-label { max-width: 9em; overflow: hidden; text-overflow: ellipsis; }
}
/* SMACG 圖示通用（emoji 版） */
.smacg-status-btn .smacg-ico,
.smacg-icon-btn .smacg-ico {
    font-style: normal;
    line-height: 1;
}
.smacg-status-btn .smacg-ico {
    font-size: 1.05rem;
    margin-bottom: 2px;
}
.smacg-icon-btn .smacg-ico {
    font-size: 1rem;
}
/* 圖示按鈕：加文字標籤 */
.smacg-track-bar .smacg-icon-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2px;
    min-width: 56px;
    padding: 8px 10px;
}

.smacg-track-bar .smacg-icon-btn .smacg-ico {
    font-size: 18px;
    line-height: 1;
}

.smacg-track-bar .smacg-icon-label {
    font-size: 11px;
    line-height: 1.2;
    color: inherit;
    opacity: 0.85;
    white-space: nowrap;
}

.smacg-track-bar .smacg-icon-btn.is-active .smacg-icon-label {
    opacity: 1;
    font-weight: 600;
}

