/* ==========================================================================
   dbzy — 大气现代版（宽容器 / 大字号 / 精致阴影 / 流畅动效）
   ========================================================================== */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
img,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:all .2s}
button{font:inherit;cursor:pointer;border:0;background:transparent;color:inherit}
input,textarea,select{font:inherit;color:inherit}

:root{
  /* —— 浅色现代 —— */
  --bg:          #f3f6fb;       /* 主底 */
  --bg-gradient: radial-gradient(1200px 600px at 10% -10%, rgba(30,136,229,.08), transparent 60%),
                 radial-gradient(900px 500px at 95% 5%, rgba(233,30,99,.06), transparent 60%);
  --bg-card:     #ffffff;
  --bg-soft:     #eef3fa;
  --border:      #e1e7f0;
  --border-strong:#c6cfdd;

  --text:        #0f172a;        /* 墨蓝黑 */
  --text-dim:    #475569;
  --text-subtle: #8b93a5;

  --primary:       #2563eb;     /* 现代蓝 */
  --primary-hover: #1d4ed8;
  --primary-dark:  #1e40af;
  --primary-soft:  #dbeafe;
  --primary-grad:  linear-gradient(135deg,#3b82f6,#1d4ed8);

  --red:         #ef4444;
  --red-hover:   #dc2626;
  --red-soft:    #fee2e2;

  --amber:       #f59e0b;
  --green:       #10b981;
  --purple:      #8b5cf6;
  --pink:        #ec4899;

  --radius:      8px;
  --radius-md:   12px;
  --radius-lg:   16px;
  --container:   1400px;

  --shadow-xs:   0 1px 2px rgba(15,23,42,.04);
  --shadow-sm:   0 2px 8px rgba(15,23,42,.06);
  --shadow:      0 8px 24px rgba(15,23,42,.08);
  --shadow-lg:   0 20px 50px rgba(15,23,42,.12);
}

body{
  font-family:"Inter","PingFang SC","Noto Sans SC","Microsoft YaHei",system-ui,sans-serif;
  font-size:15px;line-height:1.6;
  background:var(--bg);
  background-image:var(--bg-gradient);
  background-attachment:fixed;
  color:var(--text);
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  transition:background-color .2s, color .2s;
}

/* ==========================================================================
   暗色模式 — data-theme="dark" 时覆盖变量
   ========================================================================== */
html[data-theme="dark"]{
  color-scheme:dark;
}
html[data-theme="dark"] body{
  --bg:          #0b1220;
  --bg-gradient: radial-gradient(1200px 600px at 10% -10%, rgba(99,102,241,.10), transparent 60%),
                 radial-gradient(900px 500px at 95% 5%, rgba(168,85,247,.06), transparent 60%);
  --bg-card:     #141b2d;
  --bg-soft:     #111827;
  --border:      #1f2a44;
  --border-strong:#2d3c5a;
  --text:        #e5ecf5;
  --text-dim:    #9aa7bc;
  --text-subtle: #64748b;
  /* 暗色模式整体降低主色饱和度，避免"发光条"刺眼 */
  --primary:       #818cf8;        /* indigo-400，轻柔 */
  --primary-hover: #a5b4fc;
  --primary-dark:  #6366f1;
  --primary-soft:  rgba(129,140,248,.14);
  --primary-grad:  linear-gradient(135deg, rgba(99,102,241,.18), rgba(139,92,246,.14));
  --red-soft:    rgba(239,68,68,.15);
}
/* 暗色下的主导航：不再是亮蓝色发光条，而是玻璃质感深色面板 + 渐变描边 */
html[data-theme="dark"] .main-nav-inner{
  background:linear-gradient(180deg, rgba(30,41,59,.9), rgba(20,27,45,.85));
  border:1px solid rgba(129,140,248,.22);
  box-shadow:0 6px 20px rgba(0,0,0,.35),
             inset 0 1px 0 rgba(255,255,255,.04);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
html[data-theme="dark"] .main-nav a{color:rgba(229,236,245,.85)}
html[data-theme="dark"] .main-nav a:hover,
html[data-theme="dark"] .nav-item:hover > a{
  color:#fff;background:rgba(129,140,248,.12);
}
html[data-theme="dark"] .main-nav a.active{
  color:#fff;background:rgba(129,140,248,.18);
}
html[data-theme="dark"] .main-nav a.active::after{
  background:linear-gradient(90deg, transparent, #a5b4fc, transparent);
}
/* 暗色下的 Logo 立方体：渐变柔和化 */
html[data-theme="dark"] .logo-mark{
  background:linear-gradient(135deg,#6366f1,#8b5cf6);
  box-shadow:0 6px 20px rgba(99,102,241,.25),inset 0 1px 0 rgba(255,255,255,.18);
}
/* 暗色 play-source-card 适配 */
html[data-theme="dark"] .play-source-card .play-source-head{
  background:var(--bg-soft);
  border-bottom:1px solid var(--border);
}
html[data-theme="dark"] .play-source-card .src-copy-all{
  background:rgba(129,140,248,.14);color:#a5b4fc;
}
html[data-theme="dark"] .play-source-card .src-copy-all:hover{
  background:#6366f1;color:#fff;
}
/* 暗色 source-tab 激活态：换成柔和渐变 + 柔光，不再突兀 */
html[data-theme="dark"] .source-tab{
  background:transparent;color:var(--text-dim);
  border:1px solid var(--border);
}
html[data-theme="dark"] .source-tab:hover{
  background:rgba(129,140,248,.10);color:#e5ecf5;border-color:rgba(129,140,248,.3);
}
html[data-theme="dark"] .source-tab.active{
  background:linear-gradient(135deg,#4f46e5,#7c3aed);
  color:#fff;border-color:transparent;
  box-shadow:0 4px 14px rgba(79,70,229,.35);
}
/* 暗色 episode 集号按钮 */
html[data-theme="dark"] .episode,
html[data-theme="dark"] .episode-item{
  background:var(--bg-soft);border:1px solid var(--border);color:var(--text-dim);
}
html[data-theme="dark"] .episode:hover,
html[data-theme="dark"] .episode-item:hover{
  background:rgba(129,140,248,.10);border-color:rgba(129,140,248,.3);color:#e5ecf5;
}
html[data-theme="dark"] .episode.active,
html[data-theme="dark"] .episode-item.active{
  background:linear-gradient(135deg,#4f46e5,#7c3aed);
  color:#fff;border-color:transparent;
  box-shadow:0 4px 14px rgba(79,70,229,.35);
}
/* 暗色下 m3u8-text 颜色柔和 */
html[data-theme="dark"] .m3u8-row .m3u8-text{color:#a5b4fc}
html[data-theme="dark"] .m3u8-row .btn-play{
  background:transparent;border-color:#f87171;color:#f87171;
}
html[data-theme="dark"] .m3u8-row .btn-play:hover{background:#dc2626;color:#fff;border-color:#dc2626}
html[data-theme="dark"] .m3u8-row .m3u8-copy{
  background:transparent;border-color:rgba(129,140,248,.3);color:#a5b4fc;
}
html[data-theme="dark"] .m3u8-row .m3u8-copy:hover{background:#6366f1;border-color:#6366f1;color:#fff}
/* 暗色 header-stats 红字稍柔和 */
html[data-theme="dark"] .header-stats .num{color:#f87171}
/* 暗色 badge-episode / status val 红字柔化 */
html[data-theme="dark"] .badge-episode,
html[data-theme="dark"] .status-val,
html[data-theme="dark"] .vod-attrs .val{color:#f87171}

html[data-theme="dark"] .nav-dropdown{
  background:var(--bg-card);
  border-color:var(--border);
}
html[data-theme="dark"] .nav-dropdown::before{
  background:var(--bg-card);
}
html[data-theme="dark"] .logo-text{
  background:linear-gradient(135deg,#e5ecf5,#a5b4fc);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
html[data-theme="dark"] mark{background:rgba(251,191,36,.25);color:#fbbf24;padding:0 2px;border-radius:2px}

/* 关键词高亮默认样式 */
mark{
  background:#fef3c7;color:#b45309;padding:0 3px;border-radius:3px;
  font-weight:inherit;
}

/* 暗色切换按钮 */
.theme-toggle{
  width:36px;height:36px;border-radius:10px;
  background:var(--bg-soft);border:1px solid var(--border);
  display:inline-flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all .2s;font-size:18px;line-height:1;
  flex-shrink:0;
}
.theme-toggle:hover{background:var(--primary-soft);border-color:var(--primary)}
.theme-toggle .icon-dark,.theme-toggle .icon-light{display:none}
html:not([data-theme="dark"]) .theme-toggle .icon-dark{display:inline}
html[data-theme="dark"] .theme-toggle .icon-light{display:inline}

.container{max-width:var(--container);margin:0 auto;padding:0 32px}
@media(max-width:768px){.container{padding:0 16px}}

::selection{background:var(--primary);color:#fff}

/* ==========================================================================
   Header — 大气留白 + 蓝色 Logo 立体块
   ========================================================================== */
.site-header{
  background:var(--bg-card);
  border-bottom:1px solid var(--border);
  box-shadow:0 1px 0 rgba(15,23,42,.02);
}
.site-header .container{
  display:grid;grid-template-columns:280px 1fr 240px;
  gap:32px;align-items:center;
  padding-top:22px;padding-bottom:22px;
}

.logo-box{display:flex;align-items:center;gap:14px}
.logo-mark{
  width:58px;height:58px;border-radius:14px;
  background:var(--primary-grad);
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-weight:800;font-size:28px;
  box-shadow:0 8px 24px rgba(37,99,235,.28),inset 0 1px 0 rgba(255,255,255,.2);
  flex-shrink:0;position:relative;overflow:hidden;
}
.logo-img{
  width:58px;height:58px;border-radius:14px;
  object-fit:cover;flex-shrink:0;
  box-shadow:0 4px 14px rgba(15,23,42,.12);
}
.logo-mark::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg,transparent 40%,rgba(255,255,255,.15) 50%,transparent 60%);
  transform:translateX(-100%);transition:transform .6s;
}
.logo-box:hover .logo-mark::after{transform:translateX(100%)}

.logo-text-wrap{display:flex;flex-direction:column;line-height:1.1;gap:4px}
.logo-text{
  font-size:28px;font-weight:800;color:var(--text);letter-spacing:-0.025em;
  background:linear-gradient(135deg,#0f172a,#334155);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.logo-sub{
  font-size:12px;color:var(--text-subtle);
  font-family:"SF Mono",ui-monospace,Menlo,monospace;letter-spacing:0.05em;
}

/* 搜索框 — 大号 + 内嵌按钮 */
.search-box{
  display:flex;align-items:stretch;
  background:var(--bg-soft);border:2px solid transparent;
  border-radius:var(--radius-md);overflow:hidden;
  max-width:640px;width:100%;
  transition:all .2s;
}
.search-box:focus-within{
  background:var(--bg-card);
  border-color:var(--primary);
  box-shadow:0 0 0 4px var(--primary-soft);
}
.search-box input{
  flex:1;padding:14px 22px;border:0;outline:0;
  font-size:15px;background:transparent;color:var(--text);
}
.search-box input::placeholder{color:var(--text-subtle)}
.search-box button{
  background:var(--primary-grad);color:#fff;
  padding:0 40px;font-size:15px;font-weight:600;letter-spacing:0.02em;
  transition:all .2s;
  box-shadow:0 4px 14px rgba(37,99,235,.25);
  margin:4px;border-radius:8px;
}
.search-box button:hover{
  box-shadow:0 6px 18px rgba(37,99,235,.4);
  transform:translateY(-1px);
}

/* 大号统计 */
.header-stats{
  display:flex;flex-direction:column;gap:8px;align-items:flex-end;
  white-space:nowrap;
}
.header-stats > div{display:flex;align-items:baseline;gap:10px;font-size:14px;color:var(--text-dim);font-weight:500}
.header-stats .num{
  color:var(--red);font-weight:800;font-size:26px;
  font-variant-numeric:tabular-nums;line-height:1;letter-spacing:-0.02em;
}
.header-stats .num::after{content:"+";font-size:18px;margin-left:2px;opacity:.6}

/* ==========================================================================
   主导航 — 对齐容器（不再满宽）
   ========================================================================== */
/* 主导航（分区展开式）——每行一主分区 + 子分类胶囊，色彩丰富 */
.main-nav{
  background:transparent;
  margin:20px auto 16px;max-width:var(--container);
  padding:0 32px;position:relative;z-index:5;
}
.main-nav-inner{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  box-shadow:0 4px 16px rgba(15,23,42,.06), 0 1px 2px rgba(15,23,42,.04);
  overflow:hidden;
  position:relative;
}
.nav-row{
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  padding:14px 22px;
  border-bottom:1px solid var(--border);
  position:relative;
  transition:background .18s;
}
.nav-row:last-child{border-bottom:0}
.nav-row:hover{background:var(--bg-soft)}

/* 每行色调变量（仅用于按钮/胶囊着色） */
.nav-row:nth-child(1){--row-accent:#3b82f6}
.nav-row:nth-child(2){--row-accent:#8b5cf6}
.nav-row:nth-child(3){--row-accent:#ec4899}
.nav-row:nth-child(4){--row-accent:#10b981}
.nav-row:nth-child(5){--row-accent:#f59e0b}
.nav-row:nth-child(6){--row-accent:#06b6d4}

.nav-top-link{
  display:inline-flex;align-items:center;gap:6px;
  font-size:15.5px;font-weight:700;color:#fff;
  padding:8px 18px;border-radius:10px;
  background:linear-gradient(135deg, var(--row-accent, #6366f1), color-mix(in srgb, var(--row-accent, #6366f1) 70%, #000 30%));
  box-shadow:0 4px 14px color-mix(in srgb, var(--row-accent, #6366f1) 35%, transparent);
  white-space:nowrap;letter-spacing:0.02em;
  position:relative;flex-shrink:0;
  transition:transform .15s, box-shadow .15s, filter .15s;
  min-width:108px;justify-content:center;
}
.nav-row::after + .nav-top-link, .nav-row .nav-top-link{
  /* 确保读取父级 --row-accent */
}
.nav-top-link:hover{
  color:#fff;transform:translateY(-2px);
  box-shadow:0 6px 20px color-mix(in srgb, var(--row-accent, #6366f1) 50%, transparent);
  filter:brightness(1.08);
}
.nav-top-link.active{
  outline:2px solid rgba(255,255,255,.6);outline-offset:-3px;
}
.nav-top-link::before{
  content:"";width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,.8);
  box-shadow:0 0 6px rgba(255,255,255,.7);
}

.nav-sub{
  display:flex;align-items:center;gap:6px;flex-wrap:wrap;flex:1;
}
.nav-sub a{
  display:inline-flex;align-items:center;
  font-size:13.5px;color:var(--text);font-weight:600;
  padding:5px 13px;border-radius:999px;
  background:color-mix(in srgb, var(--row-accent, #6366f1) 10%, var(--bg-card) 90%);
  border:1px solid color-mix(in srgb, var(--row-accent, #6366f1) 35%, transparent);
  transition:all .15s;white-space:nowrap;
  position:relative;
}
.nav-sub a::before{
  content:"";display:inline-block;width:5px;height:5px;border-radius:50%;
  background:var(--row-accent, var(--primary));
  margin-right:7px;opacity:.9;transition:all .15s;
  box-shadow:0 0 4px color-mix(in srgb, var(--row-accent, #6366f1) 60%, transparent);
}
.nav-sub a:hover{
  background:color-mix(in srgb, var(--row-accent, #6366f1) 22%, var(--bg-card) 78%);
  border-color:var(--row-accent, var(--primary));
  color:var(--text);
  transform:translateY(-1px);
  box-shadow:0 4px 12px color-mix(in srgb, var(--row-accent, #6366f1) 25%, transparent);
}
.nav-sub a:hover::before{opacity:1;transform:scale(1.6)}

/* 暗色适配 */
html[data-theme="dark"] .main-nav-inner{
  background:var(--bg-card);border-color:var(--border);
  box-shadow:0 4px 16px rgba(0,0,0,.35);
}
html[data-theme="dark"] .nav-row:hover{background:rgba(129,140,248,.05)}
html[data-theme="dark"] .nav-row-top{
  background:linear-gradient(90deg, rgba(129,140,248,.08), transparent 60%);
}
html[data-theme="dark"] .nav-sub a{
  background:color-mix(in srgb, var(--row-accent, #818cf8) 14%, #111827 86%);
  border-color:color-mix(in srgb, var(--row-accent, #818cf8) 40%, transparent);
  color:#f1f5f9;
}
html[data-theme="dark"] .nav-sub a:hover{
  background:color-mix(in srgb, var(--row-accent, #818cf8) 28%, #111827 72%);
  color:#fff;
  border-color:var(--row-accent, #818cf8);
  box-shadow:0 4px 12px color-mix(in srgb, var(--row-accent, #818cf8) 35%, transparent);
}

@media(max-width:768px){
  .main-nav{padding:0 16px;margin:12px auto}
  .nav-row{padding:12px 16px;gap:10px}
  .nav-top-link{padding:6px 14px;font-size:14px;min-width:90px}
  .nav-sub a{padding:4px 10px;font-size:12px}
}

/* 二级链接条：对齐容器宽度，不再全屏铺满 */
.sub-links{
  max-width:var(--container);
  margin:0 auto 10px;padding:0 32px;
  font-size:13px;
}
.sub-links .container{
  max-width:none;margin:0;            /* 覆盖 .container 默认 max-width 和居中 */
  padding:13px 22px;                  /* 覆盖 .container 默认 padding */
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  display:flex;gap:28px;flex-wrap:wrap;color:var(--text-dim);
  box-shadow:var(--shadow-xs);
}
.sub-links a{color:var(--text-dim);display:inline-flex;align-items:center;gap:6px;transition:color .15s}
.sub-links a:hover{color:var(--primary)}
.sub-links a::before{
  content:"";width:4px;height:4px;border-radius:50%;background:var(--primary);
}

/* ==========================================================================
   Main
   ========================================================================== */
.site-main{padding:28px 0 60px}

/* ==========================================================================
   API Cards — 大气浮动卡
   ========================================================================== */
.api-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:28px;
}
.api-card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius-md);padding:22px 24px;
  transition:all .25s;
  box-shadow:var(--shadow-xs);
  position:relative;overflow:hidden;
}
.api-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--primary-grad);
  transform:scaleX(0);transform-origin:left;transition:transform .3s;
}
.api-card:hover{
  border-color:transparent;
  box-shadow:0 12px 32px rgba(37,99,235,.15);
  transform:translateY(-3px);
}
.api-card:hover::before{transform:scaleX(1)}
.api-card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.api-title{
  font-size:14.5px;font-weight:700;color:var(--text);
  letter-spacing:-0.005em;
}
.api-copy{
  padding:5px 14px;font-size:12.5px;color:var(--primary);
  border:1px solid var(--primary-soft);background:var(--primary-soft);border-radius:6px;
  cursor:pointer;transition:all .15s;font-weight:600;
}
.api-copy:hover{background:var(--primary);color:#fff;border-color:var(--primary)}
.api-url{
  font-size:12.5px;color:var(--text-dim);word-break:break-all;
  font-family:"SF Mono",ui-monospace,Menlo,monospace;line-height:1.65;
  padding:8px 12px;background:var(--bg-soft);border-radius:6px;
}

/* ==========================================================================
   Card — 立体浮动
   ========================================================================== */
.card{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius-md);margin-bottom:20px;overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:box-shadow .3s;
}
.card:hover{box-shadow:var(--shadow)}
.card-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 28px;
  border-bottom:1px solid var(--border);
  background:linear-gradient(180deg,rgba(37,99,235,.03),transparent);
}
.card-header h3,.card-header .title{
  font-size:18px;font-weight:700;color:var(--text);
  letter-spacing:-0.015em;
  display:inline-flex;align-items:center;gap:12px;
}
.card-header h3::before,.card-header .title::before{
  content:"";width:4px;height:22px;border-radius:2px;
  background:var(--primary-grad);
}
.card-header .sub{
  font-size:13px;color:var(--text-subtle);font-weight:500;
  padding:4px 12px;background:var(--primary-soft);color:var(--primary);border-radius:999px;
}
.card-body{padding:20px 28px}

/* ==========================================================================
   Vod List — 大气清单
   ========================================================================== */
.vod-list-head{
  display:grid;grid-template-columns:1fr 160px 180px;gap:24px;
  padding:14px 28px;font-size:12px;font-weight:600;color:var(--text-subtle);
  background:var(--bg-soft);border-bottom:1px solid var(--border);
  text-transform:uppercase;letter-spacing:0.1em;
}
.vod-list-head .col-type{text-align:center}
.vod-list-head .col-time{text-align:right}

.vod-line{
  display:grid;grid-template-columns:1fr 160px 180px;gap:24px;
  padding:18px 28px;align-items:center;
  border-bottom:1px solid var(--border);
  transition:all .2s;position:relative;
}
.vod-line:last-child{border-bottom:0}

/* 左侧 hover 色条 */
.vod-line::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;
  background:var(--primary-grad);
  transform:scaleY(0);transform-origin:center;transition:transform .25s;
}
.vod-line:hover{background:linear-gradient(90deg,var(--primary-soft),transparent 30%);padding-left:36px}
.vod-line:hover::before{transform:scaleY(1)}
.vod-line:hover .vod-info .vod-name{color:var(--primary)}

.vod-info{min-width:0;overflow:hidden}
.vod-info .vod-name{
  font-size:15.5px;font-weight:600;color:var(--text);
  display:inline-flex;align-items:baseline;gap:10px;flex-wrap:wrap;
  letter-spacing:-0.01em;line-height:1.3;
}
.vod-info .vod-sub{
  margin-top:6px;font-size:12.5px;color:var(--text-subtle);
}
.vod-info .vod-sub .dot{margin:0 7px;color:var(--border-strong)}

/* Badges */
.badge-episode{
  display:inline-flex;align-items:center;padding:2px 10px;border-radius:5px;
  background:var(--red-soft);color:var(--red);
  font-size:11.5px;font-weight:700;letter-spacing:0.02em;
  border:1px solid rgba(239,68,68,.2);
}
.badge-score{
  display:inline-flex;align-items:center;gap:3px;
  padding:2px 10px;border-radius:5px;
  background:#fef3c7;color:#b45309;
  font-size:11.5px;font-weight:700;
  border:1px solid rgba(217,119,6,.2);
  font-variant-numeric:tabular-nums;
}
.badge-score::before{content:"★";font-size:10px}

/* 分类多色（5 色轮转） */
.col-type{text-align:center}
.vod-type-tag{
  display:inline-flex;align-items:center;padding:5px 16px;border-radius:6px;
  font-size:12.5px;font-weight:600;letter-spacing:0.02em;
  transition:all .2s;
}
.vod-type-tag.t1{background:#fff3e0;color:#ea580c;border:1px solid #fed7aa}
.vod-type-tag.t2{background:#dbeafe;color:#1d4ed8;border:1px solid #bfdbfe}
.vod-type-tag.t3{background:#dcfce7;color:#15803d;border:1px solid #bbf7d0}
.vod-type-tag.t4{background:#f3e8ff;color:#7e22ce;border:1px solid #e9d5ff}
.vod-type-tag.t5{background:#fce7f3;color:#be185d;border:1px solid #fbcfe8}

/* 时间列 */
.vod-time{
  text-align:right;font-size:13px;color:var(--red);
  font-weight:600;font-family:"SF Mono",ui-monospace,Menlo,monospace;
  font-variant-numeric:tabular-nums;letter-spacing:-0.005em;
}

/* ==========================================================================
   Breadcrumb
   ========================================================================== */
.breadcrumb{
  padding:24px 0 16px;font-size:14px;color:var(--text-subtle);
}
.breadcrumb a{color:var(--text-dim);transition:color .15s}
.breadcrumb a:hover{color:var(--primary)}
.breadcrumb span.sep{color:var(--border-strong);margin:0 10px;font-weight:300}
.breadcrumb span:not(.sep){color:var(--text);font-weight:600}

/* ==========================================================================
   Filter
   ========================================================================== */
.filter-box{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius-md);padding:18px 24px;margin-bottom:20px;
  box-shadow:var(--shadow-xs);
}
.filter-row{
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:7px 0;
  border-bottom:1px dashed var(--border);
}
.filter-row:last-child{border-bottom:0}
.filter-label{
  min-width:60px;font-size:13px;color:var(--text-subtle);font-weight:600;
}
.filter-row a{
  padding:6px 16px;font-size:13.5px;color:var(--text-dim);
  border-radius:6px;transition:all .15s;border:1px solid transparent;
}
.filter-row a:hover{color:var(--primary);background:var(--primary-soft)}
.filter-row a.active{
  background:var(--primary-grad);color:#fff;font-weight:600;
  box-shadow:0 4px 12px rgba(37,99,235,.3);
}

/* ==========================================================================
   Detail
   ========================================================================== */
.vod-detail{
  display:grid;grid-template-columns:220px 1fr;gap:32px;
  padding:32px;background:var(--bg-card);
  border:1px solid var(--border);border-radius:var(--radius-md);
  margin-bottom:20px;box-shadow:var(--shadow-sm);
  position:relative;overflow:hidden;
}
.vod-detail::before{
  content:"";position:absolute;top:0;right:0;width:400px;height:400px;
  background:radial-gradient(circle,rgba(37,99,235,.06),transparent 70%);
  pointer-events:none;
}
.vod-poster{
  aspect-ratio:2/3;border-radius:var(--radius);overflow:hidden;
  background:var(--bg-soft);box-shadow:var(--shadow);
  position:relative;z-index:1;
}
.vod-poster img{width:100%;height:100%;object-fit:cover}

.vod-info-detail{display:flex;flex-direction:column;gap:16px;position:relative;z-index:1}
.vod-info-detail h1{
  font-size:28px;font-weight:800;color:var(--text);
  letter-spacing:-0.02em;display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;
  line-height:1.2;
}

.vod-attrs{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:10px 28px;
  font-size:14px;color:var(--text);line-height:1.9;
}
.vod-attrs .attr{display:inline-flex;align-items:baseline;gap:8px}
.vod-attrs .attr b{color:var(--text-subtle);font-weight:500;min-width:40px}
.vod-attrs .attr span.val{color:var(--primary);font-weight:500}
.vod-attrs .status-val{color:var(--red);font-weight:600}

.vod-blurb{
  font-size:14px;color:var(--text-dim);line-height:1.9;
  padding:18px 0 0;border-top:1px solid var(--border);margin-top:8px;
}

/* ==========================================================================
   Play sources
   ========================================================================== */
.play-source-card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius-md);margin-bottom:16px;overflow:hidden;
  box-shadow:var(--shadow-xs);
}
.play-source-head{
  padding:16px 24px;font-size:15px;font-weight:700;
  background:linear-gradient(180deg,rgba(37,99,235,.05),transparent);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:10px;
  color:var(--text);letter-spacing:-0.005em;
}
.play-source-head::before{
  content:"";width:4px;height:20px;border-radius:2px;
  background:var(--primary-grad);
}
.play-source-body{padding:18px 24px}

.episode-grid{
  display:grid;gap:10px;
  grid-template-columns:repeat(auto-fill,minmax(90px,1fr));
}
.episode,.episode-item{
  display:flex;align-items:center;justify-content:center;
  padding:11px 8px;font-size:13px;
  background:var(--bg-soft);border:1px solid transparent;
  border-radius:8px;color:var(--text-dim);
  transition:all .15s;text-align:center;font-weight:500;
}
.episode:hover,.episode-item:hover{
  background:var(--primary-soft);color:var(--primary);
  transform:translateY(-2px);
  box-shadow:0 4px 10px rgba(37,99,235,.15);
}
.episode.active,.episode-item.active{
  background:var(--primary-grad);color:#fff;font-weight:700;
  box-shadow:0 6px 16px rgba(37,99,235,.35);
}

/* ==========================================================================
   Buttons
   ========================================================================== */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 24px;border-radius:8px;
  font-size:14px;font-weight:600;white-space:nowrap;
  transition:all .2s;cursor:pointer;letter-spacing:0.01em;
}
.btn-primary{
  background:var(--primary-grad);color:#fff;
  box-shadow:0 4px 14px rgba(37,99,235,.3);
}
.btn-primary:hover{box-shadow:0 6px 20px rgba(37,99,235,.45);transform:translateY(-2px)}
.btn-outline{
  border:1px solid var(--border-strong);color:var(--text-dim);background:var(--bg-card);
}
.btn-outline:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-soft)}

/* ==========================================================================
   Play page
   ========================================================================== */
.player-wrap{
  background:#000;
  border-radius:var(--radius-md);
  overflow:hidden;margin:0 auto 16px;
  box-shadow:var(--shadow-lg);
  max-width:960px;           /* 限制最大宽度，保持影院感 */
  width:100%;
  aspect-ratio:16/9;          /* 强制 16:9，避免过高 */
}
.player-wrap > div,
.player-wrap iframe,
#dplayer{width:100%;height:100%}
#dplayer{min-height:0}
/* 仅播放页（存在 .player-wrap）时，让"正在播放"和播放源卡片对齐到 960 */
/* 详情页没有 .player-wrap，播放源卡片保持容器全宽，和顶部影片信息卡对齐 */
.player-wrap ~ .now-playing,
.player-wrap ~ .play-source-card{max-width:960px;margin-left:auto;margin-right:auto}

.now-playing{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius-md);padding:18px 24px;margin-bottom:16px;
  display:flex;align-items:center;justify-content:space-between;
  box-shadow:var(--shadow-xs);
}
.now-playing .title{font-size:17px;font-weight:700;letter-spacing:-0.01em}
.now-playing .sub{font-size:13px;color:var(--text-subtle);margin-top:4px}

.source-tabs{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}
.source-tab{
  padding:8px 20px;font-size:13px;border-radius:999px;
  background:var(--bg-soft);color:var(--text-dim);border:1px solid transparent;
  transition:all .15s;
}
.source-tab:hover{background:var(--primary-soft);color:var(--primary)}
.source-tab.active{background:var(--primary-grad);color:#fff;font-weight:600;box-shadow:0 4px 12px rgba(37,99,235,.3)}

/* ==========================================================================
   Footer
   ========================================================================== */
.site-footer{
  background:var(--bg-card);border-top:1px solid var(--border);
  margin-top:60px;padding:36px 0 28px;
  font-size:13px;color:var(--text-subtle);text-align:center;line-height:1.9;
}
.site-footer a{color:var(--text-dim);margin:0 14px;transition:color .15s}
.site-footer a:hover{color:var(--primary)}
.site-footer .copy{border-top:1px dashed var(--border);padding-top:18px;margin-top:18px}

/* Pager */
.pager{
  display:flex;justify-content:center;gap:6px;flex-wrap:wrap;
  margin:32px 0;font-size:14px;
}
.pager a,.pager span{
  padding:8px 14px;background:var(--bg-card);
  border:1px solid var(--border);border-radius:8px;
  color:var(--text-dim);min-width:40px;text-align:center;
  font-variant-numeric:tabular-nums;transition:all .15s;
}
.pager a:hover{border-color:var(--primary);color:var(--primary);box-shadow:0 4px 10px rgba(37,99,235,.15)}
.pager .current{background:var(--primary-grad);color:#fff;border-color:var(--primary);font-weight:700;box-shadow:0 4px 12px rgba(37,99,235,.3)}

/* ==========================================================================
   Mobile
   ========================================================================== */
@media(max-width:1024px){
  .site-header .container{grid-template-columns:240px 1fr 200px;gap:20px}
  .vod-list-head,.vod-line{grid-template-columns:1fr 140px 150px;gap:16px}
}

@media(max-width:768px){
  .site-header .container{grid-template-columns:1fr;gap:16px;padding:16px 16px}
  .logo-box{justify-content:center}
  .logo-mark{width:48px;height:48px;font-size:22px}
  .logo-text{font-size:22px}
  .logo-sub{font-size:11px}
  .header-stats{flex-direction:row;gap:24px;justify-content:center;align-items:baseline}
  .header-stats .num{font-size:22px}
  .search-box{max-width:none}
  .search-box button{padding:0 24px;margin:3px}

  .main-nav .container{padding:0 16px}
  .main-nav a{padding:14px 18px;font-size:13.5px}

  .sub-links .container{gap:16px;font-size:12px}

  .api-grid{grid-template-columns:1fr;gap:12px;margin-bottom:20px}
  .api-card{padding:18px 20px}

  .vod-list-head{display:none}
  .vod-line{
    grid-template-columns:1fr auto;gap:6px 12px;padding:14px 20px 14px 24px;
    grid-template-areas:"info time" "info type";
  }
  .vod-line:hover{padding-left:28px}
  .vod-info{grid-area:info}
  .col-type{grid-area:type;text-align:right;justify-self:end}
  .col-time{grid-area:time;text-align:right;font-size:11.5px}
  .vod-info .vod-name{font-size:14.5px}

  .vod-detail{grid-template-columns:130px 1fr;gap:16px;padding:18px}
  .vod-info-detail h1{font-size:20px}
  .vod-attrs{grid-template-columns:1fr;gap:4px;font-size:13px}

  .player-wrap{max-width:100%}
  #dplayer{min-height:0}
  .episode-grid{grid-template-columns:repeat(5,1fr);gap:8px}

  .card-header{padding:16px 20px}
  .card-header h3,.card-header .title{font-size:16px}
  .card-body{padding:16px 20px}

  .site-footer{margin-top:40px;padding:28px 0 20px}
}

/* ==========================================================================
   热门搜索词云
   ========================================================================== */
.hot-search{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  padding:14px 20px;background:var(--bg-card);
  border:1px solid var(--border);border-radius:var(--radius-md);
  margin-bottom:20px;box-shadow:var(--shadow-xs);
}
.hot-search-label{
  font-size:13px;color:var(--text-subtle);font-weight:600;
  display:inline-flex;align-items:center;gap:6px;flex-shrink:0;
}
.hot-search-label::before{content:"🔥"}
.hot-search a{
  font-size:13px;color:var(--text-dim);
  padding:4px 12px;border-radius:999px;
  background:var(--bg-soft);transition:all .15s;
}
.hot-search a:hover{background:var(--primary-soft);color:var(--primary)}
.hot-search a.hot{background:var(--red-soft);color:var(--red)}

/* ==========================================================================
   搜索建议下拉
   ========================================================================== */
.search-suggest{
  position:absolute;top:calc(100% + 8px);left:0;right:0;
  background:var(--bg-card);border-radius:var(--radius-md);
  box-shadow:0 20px 48px rgba(15,23,42,.15), 0 4px 12px rgba(15,23,42,.06);
  border:1px solid var(--border);
  opacity:0;visibility:hidden;transform:translateY(-6px);
  transition:all .15s;overflow:hidden;z-index:200;
}
.search-suggest.show{opacity:1;visibility:visible;transform:translateY(0)}
.search-suggest-item{
  display:flex;align-items:center;gap:12px;padding:10px 16px;
  cursor:pointer;transition:background .1s;
  border-bottom:1px solid var(--border);
}
.search-suggest-item:last-child{border-bottom:0}
.search-suggest-item:hover,.search-suggest-item.active{background:var(--primary-soft)}
.search-suggest-item img{
  width:36px;height:50px;object-fit:cover;border-radius:4px;flex-shrink:0;background:var(--bg-soft);
}
.search-suggest-info{flex:1;min-width:0}
.search-suggest-info .name{
  font-size:14px;font-weight:600;color:var(--text);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.search-suggest-info .meta{
  margin-top:3px;font-size:11.5px;color:var(--text-subtle);
}
.search-suggest-item .remark{
  font-size:11px;color:var(--red);padding:2px 8px;background:var(--red-soft);
  border-radius:3px;font-weight:600;flex-shrink:0;
}

/* 搜索框容器需要 relative 以承载建议下拉 */
.search-box-wrap{position:relative;flex:1}

/* ==========================================================================
   骨架屏
   ========================================================================== */
.skeleton{
  background:linear-gradient(90deg,var(--bg-soft) 0%,var(--bg-card) 50%,var(--bg-soft) 100%);
  background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite;
  border-radius:4px;
}
@keyframes skeleton-shimmer{
  0%{background-position:200% 0}
  100%{background-position:-200% 0}
}
.skeleton-line{height:14px;margin:8px 0}
.skeleton-line.w-60{width:60%}
.skeleton-line.w-40{width:40%}
.skeleton-line.w-80{width:80%}

/* ==========================================================================
   集数折叠（>= 50 集时收起）
   ========================================================================== */
.episode-grid.collapsed{
  max-height:260px;overflow:hidden;position:relative;
}
.episode-grid.collapsed::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:80px;
  background:linear-gradient(transparent,var(--bg-card));pointer-events:none;
}
.episode-expand-btn{
  display:inline-flex;align-items:center;gap:6px;
  margin-top:10px;padding:8px 20px;
  background:var(--primary-soft);color:var(--primary);
  border-radius:999px;cursor:pointer;font-size:13px;font-weight:600;
  transition:all .15s;
}
.episode-expand-btn:hover{background:var(--primary);color:#fff}
.episode-expand-btn.expanded .icon-down{transform:rotate(180deg)}
.episode-expand-btn .icon-down{transition:transform .2s}

/* ==========================================================================
   m3u8 原始地址列表（播放页/详情页附带）
   ========================================================================== */
.m3u8-block{
  margin-top:14px;padding:14px 18px;
  background:var(--bg-soft);border-radius:var(--radius);
  border:1px dashed var(--border-strong);
}
.m3u8-block-title{
  font-size:12px;color:var(--text-subtle);font-weight:600;margin-bottom:8px;
  display:flex;align-items:center;gap:6px;
}
.m3u8-block-title::before{content:"🔗"}
.m3u8-line{
  display:flex;align-items:center;gap:10px;padding:6px 0;
  font-family:"SF Mono",ui-monospace,Menlo,monospace;font-size:11.5px;
  border-bottom:1px dashed var(--border);
}
.m3u8-line:last-child{border:0}
.m3u8-line .m3u8-label{
  color:var(--text-dim);min-width:56px;flex-shrink:0;
  font-family:"Inter",sans-serif;font-size:12px;font-weight:600;
}
.m3u8-line .m3u8-url{
  flex:1;color:var(--primary);overflow:hidden;text-overflow:ellipsis;
  white-space:nowrap;user-select:all;
}
.m3u8-line .m3u8-copy{
  padding:3px 10px;font-size:11px;color:var(--primary);
  border:1px solid var(--primary-soft);background:var(--bg-card);
  border-radius:4px;cursor:pointer;font-weight:600;font-family:"Inter",sans-serif;
}
.m3u8-line .m3u8-copy:hover{background:var(--primary);color:#fff}

/* ==========================================================================
   采集站风格：每集一行 "集名$m3u8 + 复制 + 播放"
   ========================================================================== */
.play-source-card .play-source-head{
  display:flex;align-items:center;gap:12px;
}
.play-source-card .src-name{font-weight:700;font-size:14px;color:var(--text)}
.play-source-card .src-count{
  font-size:12px;color:var(--text-subtle);font-weight:500;
  padding:2px 8px;border-radius:999px;background:var(--bg-soft);
}
.play-source-card .src-copy-all{
  margin-left:auto;padding:5px 14px;font-size:12px;
  background:var(--primary-soft);color:var(--primary);
  border:1px solid transparent;border-radius:6px;cursor:pointer;font-weight:600;
}
.play-source-card .src-copy-all:hover{background:var(--primary);color:#fff}

.m3u8-list{display:flex;flex-direction:column}
.m3u8-row{
  display:flex;align-items:center;gap:10px;
  padding:10px 14px;border-bottom:1px solid var(--border);
  font-family:"SF Mono",ui-monospace,Menlo,Consolas,monospace;
  font-size:12.5px;
}
.m3u8-row:last-child{border-bottom:0}
.m3u8-row:hover{background:var(--bg-soft)}
.m3u8-row .m3u8-text{
  flex:1;min-width:0;color:var(--primary);
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
  user-select:all;
}
.m3u8-row .m3u8-copy{
  flex-shrink:0;padding:4px 12px;font-size:12px;
  background:var(--bg-card);color:var(--primary);
  border:1px solid var(--primary-soft);border-radius:4px;
  cursor:pointer;font-weight:600;font-family:"Inter",sans-serif;
}
.m3u8-row .m3u8-copy:hover{background:var(--primary);color:#fff;border-color:var(--primary)}
.m3u8-row .btn-play{
  flex-shrink:0;padding:4px 14px;font-size:12px;
  background:var(--bg-card);color:var(--red);
  border:1px solid var(--red);border-radius:4px;
  font-weight:600;font-family:"Inter",sans-serif;
  transition:all .15s;
}
.m3u8-row .btn-play:hover{background:var(--red);color:#fff}

/* 集号 badge */
.m3u8-row .m3u8-idx{
  flex-shrink:0;min-width:36px;
  font-size:11px;font-weight:700;color:var(--text-subtle);
  font-family:"Inter",sans-serif;text-align:right;
  padding-right:4px;
}

/* 工具条：范围复制 / 跳转 */
.m3u8-toolbar{
  display:flex;gap:20px;flex-wrap:wrap;
  padding:10px 16px;background:var(--bg-soft);
  border-bottom:1px solid var(--border);
  font-family:"Inter",sans-serif;
}
.m3u8-toolbar .tb-group{display:flex;align-items:center;gap:6px}
.m3u8-toolbar .tb-label{
  font-size:12px;color:var(--text-subtle);font-weight:600;margin-right:2px;
}
.m3u8-toolbar .tb-input{
  width:70px;padding:5px 8px;font-size:12px;
  background:var(--bg-card);color:var(--text);
  border:1px solid var(--border);border-radius:4px;
}
.m3u8-toolbar .tb-input:focus{outline:none;border-color:var(--primary)}
.m3u8-toolbar .tb-sep{color:var(--text-subtle);font-weight:600}
.m3u8-toolbar .tb-btn{
  padding:5px 14px;font-size:12px;font-weight:600;
  background:var(--primary-soft);color:var(--primary);
  border:1px solid transparent;border-radius:4px;cursor:pointer;
}
.m3u8-toolbar .tb-btn:hover{background:var(--primary);color:#fff}

/* 大量集数自动折叠（>= 40） */
.m3u8-list.folded{max-height:540px;overflow:hidden;position:relative}
.m3u8-list.folded::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:100px;
  background:linear-gradient(transparent,var(--bg-card));pointer-events:none;
}
.m3u8-fold-btn{
  display:flex;align-items:center;justify-content:center;gap:6px;
  width:100%;padding:10px;
  background:var(--primary-soft);color:var(--primary);
  border:0;border-top:1px solid var(--border);
  cursor:pointer;font-size:13px;font-weight:600;
  font-family:"Inter",sans-serif;transition:all .15s;
}
.m3u8-fold-btn:hover{background:var(--primary);color:#fff}

/* 跳转定位高亮 */
.m3u8-row.hit{
  background:linear-gradient(90deg,var(--primary-soft),transparent);
  animation:hit-flash 1.2s ease-out;
}
@keyframes hit-flash{
  0%{background:var(--primary);}
  30%{background:var(--primary-soft);}
  100%{background:transparent;}
}

/* ==========================================================================
   留言本 /gbook/
   ========================================================================== */
.gbook-notice{margin-bottom:16px}
.gbook-login-tip{
  padding:24px;text-align:center;color:var(--text-dim);
  background:var(--bg-soft);border-radius:var(--radius);
  border:1px dashed var(--border);
}
.gbook-form{display:flex;flex-direction:column;gap:14px}
.gbook-row{display:flex;align-items:flex-start;gap:14px}
.gbook-row label{
  flex-shrink:0;width:88px;padding-top:8px;
  color:var(--text-dim);font-size:13.5px;font-weight:600;text-align:right;
}
.gbook-row input, .gbook-row textarea{
  flex:1;padding:10px 14px;
  background:var(--bg-card);border:1px solid var(--border-strong);
  border-radius:var(--radius-sm);color:var(--text);font-size:14px;
  font-family:inherit;transition:border-color .15s, box-shadow .15s;
}
.gbook-row input:focus, .gbook-row textarea:focus{
  outline:0;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft);
}
.gbook-row textarea{resize:vertical;min-height:90px;line-height:1.6}
.gbook-foot{
  display:flex;justify-content:space-between;align-items:center;
  padding-left:102px;margin-top:4px;flex-wrap:wrap;gap:10px;
}
.gbook-hint{font-size:12px;color:var(--text-subtle)}
.gbook-msg{
  margin-left:102px;padding:10px 14px;border-radius:var(--radius-sm);
  font-size:13px;display:none;font-weight:500;
}
.gbook-msg.ok{display:block;background:rgba(16,185,129,.1);color:#059669;border:1px solid rgba(16,185,129,.3)}
.gbook-msg.err{display:block;background:rgba(239,68,68,.1);color:#dc2626;border:1px solid rgba(239,68,68,.3)}

.gbook-list{display:flex;flex-direction:column;gap:14px}
.gbook-item{
  padding:16px 18px;
  background:var(--bg-soft);border:1px solid var(--border);
  border-radius:var(--radius);
  transition:border-color .15s;
}
.gbook-item:hover{border-color:var(--primary-border)}
.gbook-head{
  display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;
}
.gbook-user{display:flex;align-items:center;gap:10px;color:var(--text)}
.gbook-user .avatar{
  width:32px;height:32px;border-radius:50%;
  background:var(--primary-grad);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:14px;flex-shrink:0;
}
.gbook-user strong{font-weight:600;font-size:14px}
.gbook-time{font-size:12px;color:var(--text-subtle);font-variant-numeric:tabular-nums}
.gbook-content{
  color:var(--text-dim);font-size:14px;line-height:1.7;
  word-break:break-word;white-space:pre-wrap;
  margin-left:42px;
}
.gbook-reply{
  margin:10px 0 0 42px;padding:10px 14px;
  background:var(--primary-soft);border-radius:var(--radius-sm);
  border-left:3px solid var(--primary);
}
.gbook-reply .reply-head{
  font-size:12px;color:var(--primary);font-weight:600;margin-bottom:4px;
}
.gbook-reply .reply-body{
  font-size:13.5px;color:var(--text);line-height:1.6;white-space:pre-wrap;
}

@media(max-width:640px){
  .gbook-row{flex-direction:column;gap:6px}
  .gbook-row label{width:auto;text-align:left;padding-top:0}
  .gbook-foot, .gbook-msg{padding-left:0;margin-left:0}
  .gbook-content, .gbook-reply{margin-left:0}
}

/* 减动效 */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;transition-duration:.01ms !important}
}
