/* ============================================================
   TCG Radar 卡价雷达 — 样式
   设计语言: 墨渊深蓝底 + 雾玻璃面板 + "闪箔"(holo foil)渐变签名
   红涨绿跌为默认(body.color-cn), body.color-intl 切换为国际配色
   ============================================================ */

:root{
  --bg:#0B0E14;
  --bg-soft:#101522;
  --panel:rgba(255,255,255,.035);
  --panel-strong:rgba(255,255,255,.06);
  --line:rgba(255,255,255,.08);
  --line-soft:rgba(255,255,255,.05);
  --ink:#E8ECF4;
  --ink-dim:#A7B0C3;
  --ink-mute:#8B95AD;   /* a11y: 原 #717C93 仅 4.6:1(勉强), 提亮到 ~6.4:1, 全站弱文本一并达标 */
  --holo-a:#7CF5C8; --holo-b:#5BC0EB; --holo-c:#C77DFF; --holo-d:#FF9DC6;
  --holo:linear-gradient(115deg,var(--holo-a) 0%,var(--holo-b) 38%,var(--holo-c) 72%,var(--holo-d) 100%);
  /* 选中/激活统一用扁平青(=holo-b): 满彩 holo 渐变只留给主操作(btn-holo)+ 突破(badge.brk), 重建层次 */
  --accent:#5BC0EB; --accent-soft:rgba(91,192,235,.14); --accent-line:rgba(91,192,235,.50);
  --buy:#46E3A8; --watch:#5BC0EB; --hold:#8A93A6; --reduce:#FFB45A; --avoid:#FF6478;
  --radius:14px; --radius-s:9px;
  --font-disp:'Rajdhani','Noto Sans SC','Microsoft YaHei',sans-serif;
  --font-mono:'IBM Plex Mono','Rajdhani',monospace;
  --font-body:'Noto Sans SC','PingFang SC','Hiragino Sans GB','Microsoft YaHei','Yu Gothic UI',sans-serif;
}
/* 涨跌色: 中式 红涨绿跌 */
body.color-cn  { --up:#FF5A6E; --down:#2FD08C; }
body.color-intl{ --up:#2FD08C; --down:#FF5A6E; }

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  background:var(--bg) ;
  background-image:
    radial-gradient(900px 500px at 85% -10%, rgba(91,192,235,.10), transparent 60%),
    radial-gradient(800px 600px at -10% 100%, rgba(199,125,255,.07), transparent 55%),
    radial-gradient(600px 400px at 40% 120%, rgba(124,245,200,.05), transparent 60%);
  background-attachment:fixed;
  color:var(--ink); font-family:var(--font-body); font-size:14px; line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
input,select{font-family:inherit;color:var(--ink)}
::-webkit-scrollbar{width:9px;height:9px}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:9px}
::-webkit-scrollbar-track{background:transparent}

.mono{font-family:var(--font-mono)}
.hidden{display:none!important}
.muted{color:var(--ink-mute)}

/* ---------------- 闪箔签名 ---------------- */
.holo-text{
  background:var(--holo); background-size:220% 220%;
  -webkit-background-clip:text; background-clip:text; color:transparent;
  animation:holoShift 9s ease-in-out infinite;
}
@keyframes holoShift{0%,100%{background-position:0% 40%}50%{background-position:100% 60%}}

.btn-holo{
  position:relative; border:none; border-radius:10px; padding:9px 18px;
  font:600 14px var(--font-disp); letter-spacing:.06em; color:#0B0E14;
  background:var(--holo); background-size:200% 200%;
  transition:transform .15s ease, box-shadow .2s ease;
}
.btn-holo:hover{transform:translateY(-1px); box-shadow:0 6px 22px rgba(91,192,235,.30)}
.btn-holo:disabled{opacity:.45; cursor:not-allowed; transform:none; box-shadow:none}

/* ---------------- 布局骨架 ---------------- */
.shell{display:flex; min-height:100vh}
.sidebar{
  width:218px; flex:0 0 218px; padding:22px 14px 16px; position:sticky; top:0; height:100vh;
  display:flex; flex-direction:column; border-right:1px solid var(--line-soft);
  background:linear-gradient(180deg, rgba(255,255,255,.02), transparent 30%);
}
.brand{display:flex; align-items:center; gap:11px; padding:2px 8px 20px}
.brand-mark{width:34px;height:34px}
.brand-name{display:block; font:700 17px/1 var(--font-disp); letter-spacing:.14em}
.brand-sub{display:block; font-size:11px; color:var(--ink-mute); letter-spacing:.34em; margin-top:3px}

.nav{display:flex; flex-direction:column; gap:3px}
.nav a{
  display:flex; align-items:center; gap:10px; padding:9.5px 12px; border-radius:10px;
  color:var(--ink-dim); font-size:14px; border:1px solid transparent; position:relative;
  transition:background .15s,color .15s;
}
.nav a:hover{background:var(--panel); color:var(--ink)}
.nav a.active{
  background:var(--panel-strong); color:var(--ink); border-color:var(--line);
}
.nav a.active::before{
  content:""; position:absolute; left:-1px; top:8px; bottom:8px; width:3px; border-radius:3px;
  background:var(--holo);
}
.nav-ic{width:18px; text-align:center; font-size:13px; opacity:.85}
.nav-badge{margin-left:auto; font:500 11px var(--font-mono); color:var(--holo-b)}

.side-foot{margin-top:auto; padding:12px 10px 0; border-top:1px solid var(--line-soft); font-size:12px; color:var(--ink-mute)}
.data-date{display:flex; justify-content:space-between; margin-bottom:5px}
.data-date b{color:var(--ink-dim); font-weight:500}
.disclaim{margin-top:10px; font-size:11px; line-height:1.7}  /* a11y: 去掉 opacity:.7(原会把对比度压到 ~3.5:1 不及格) */

.main{flex:1; min-width:0; display:flex; flex-direction:column}
.topbar{
  position:sticky; top:0; z-index:30; display:flex; align-items:center; gap:16px;
  padding:14px 26px; backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  background:rgba(11,14,20,.72); border-bottom:1px solid var(--line-soft);
}
.search-wrap{position:relative; flex:1; max-width:430px}
.search{
  width:100%; padding:9px 14px; border-radius:10px; border:1px solid var(--line);
  background:var(--panel); font-size:13.5px; outline:none; transition:border .15s;
}
.search:focus{border-color:rgba(91,192,235,.55)}
.search-drop{
  position:absolute; top:calc(100% + 6px); left:0; right:0; z-index:40;
  background:#131826; border:1px solid var(--line); border-radius:12px; overflow:hidden;
  box-shadow:0 14px 40px rgba(0,0,0,.5);
}
.search-item{display:flex; align-items:center; gap:10px; padding:9px 12px; cursor:pointer}
.search-item:hover{background:var(--panel-strong)}
.search-item img{width:30px;height:42px;object-fit:contain;border-radius:4px;background:rgba(255,255,255,.04)}
.search-item .si-name{font-size:13px}
.search-item .si-sub{font-size:11px;color:var(--ink-mute)}
.search-item .si-price{margin-left:auto;font-family:var(--font-mono);font-size:12.5px}

.top-right{margin-left:auto; display:flex; align-items:center; gap:12px}
.cur-sel{
  background:var(--panel); border:1px solid var(--line); border-radius:9px; padding:8px 10px;
  font-size:13px; outline:none;
}
.cur-sel option{background:#131826}
.run-pill{
  display:flex; align-items:center; gap:8px; padding:7px 13px; border-radius:99px;
  background:rgba(91,192,235,.10); border:1px solid rgba(91,192,235,.35);
  font-size:12.5px; color:#BFE6F7; max-width:440px;
}
#runText{white-space:nowrap; overflow:hidden; text-overflow:ellipsis; min-width:0}
.run-count{flex:none; font-family:var(--font-mono)}   /* 进度计数独立, 不参与省略, 始终可见 */
.spinner{
  width:13px;height:13px;border-radius:50%;flex:0 0 13px;
  border:2px solid rgba(255,255,255,.25); border-top-color:var(--holo-b);
  animation:spin 1s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}

.view{padding:24px 26px 50px; max-width:1480px; width:100%; margin:0 auto}

/* ---------------- 通用面板 / 卡片 ---------------- */
.panel{
  background:var(--panel); border:1px solid var(--line); border-radius:var(--radius);
  backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px);
}
.panel-pad{padding:18px 20px}
.panel-title{
  font:600 13px var(--font-disp); letter-spacing:.12em; color:var(--ink-dim);
  text-transform:uppercase; display:flex; align-items:center; gap:8px; margin-bottom:14px;
}
.panel-title .tip{font-family:var(--font-body); letter-spacing:0; text-transform:none; font-weight:400; color:var(--ink-mute); font-size:12px; margin-left:auto}

.page-head{display:flex; align-items:baseline; gap:14px; margin-bottom:18px; flex-wrap:wrap}
.page-title{font:700 24px var(--font-disp); letter-spacing:.05em}
.page-desc{color:var(--ink-mute); font-size:13px}

/* KPI 区 */
.kpi-grid{display:grid; grid-template-columns:repeat(auto-fit,minmax(190px,1fr)); gap:14px; margin-bottom:18px}
.kpi{padding:16px 18px 14px; position:relative; overflow:hidden}
.kpi-label{font-size:12px; color:var(--ink-mute); letter-spacing:.05em; margin-bottom:7px}
.kpi-value{font:600 27px/1.05 var(--font-disp); letter-spacing:.02em}
.kpi-sub{font-size:12px; color:var(--ink-dim); margin-top:6px; font-family:var(--font-mono)}
/* (移除全局 KPI 扫光动画: 它被 .kpi-cat::after 的角落辉光覆盖 → 只有汇总卡闪、分类卡不闪, 不一致;
   且数据看板上 7s 循环的微动效"看一次有趣、每次疲劳", 一并去掉更克制) */

.up{color:var(--up)} .down{color:var(--down)} .flat{color:var(--ink-dim)}

/* 区块网格 */
.grid-2{display:grid; grid-template-columns:1fr 1fr; gap:16px}
.grid-main{display:grid; grid-template-columns:2.1fr 1fr; gap:16px; margin-bottom:16px}
.section-gap{margin-bottom:16px}

/* ---------------- 涨跌小卡 ---------------- */
.mover-list{display:flex; flex-direction:column}
.mover{
  display:flex; align-items:center; gap:11px; padding:8.5px 8px; border-radius:10px; cursor:pointer;
  border-bottom:1px dashed var(--line-soft);
}
.mover:last-child{border-bottom:none}
.mover:hover{background:var(--panel-strong)}
.mover img{width:34px;height:48px;object-fit:contain;border-radius:5px;background:rgba(255,255,255,.04);flex:0 0 34px}
.mover .m-name{font-size:13px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap}
.mover .m-sub{font-size:11px; color:var(--ink-mute); overflow:hidden; text-overflow:ellipsis; white-space:nowrap}
.mover .m-body{min-width:0; flex:1}
.mover .m-right{text-align:right; flex:0 0 auto}
.mover .m-price{font-family:var(--font-mono); font-size:13px}
.mover .m-chg{font-family:var(--font-mono); font-size:12px}

/* ---------------- 数据表格 ---------------- */
.tbl-wrap{overflow-x:auto}
table.tbl{width:100%; border-collapse:collapse; font-size:13px}
.tbl th{
  text-align:left; font:600 11.5px var(--font-disp); letter-spacing:.1em; color:var(--ink-mute);
  text-transform:uppercase; padding:10px 10px; border-bottom:1px solid var(--line);
  white-space:nowrap; user-select:none;
}
.tbl th.sortable{cursor:pointer}
.tbl th.sortable:hover{color:var(--ink-dim)}
.tbl th .arr{font-size:10px; color:var(--accent)}
.tbl td{padding:9px 10px; border-bottom:1px solid var(--line-soft); vertical-align:middle; white-space:nowrap}
.tbl tbody tr{cursor:pointer; transition:background .12s}
.tbl tbody tr:hover{background:var(--panel-strong)}
.cell-name{display:flex; align-items:center; gap:10px; min-width:230px; white-space:normal}
.cell-name img{width:32px;height:45px;object-fit:contain;border-radius:4px;background:rgba(255,255,255,.04);flex:0 0 32px}
.cn-main{font-size:13px; line-height:1.3}
.cn-sub{font-size:11px; color:var(--ink-mute); margin-top:1px}
td.num{font-family:var(--font-mono); font-size:12.5px; text-align:right}
th.num{text-align:right}
.star{color:var(--ink-mute); font-size:15px; cursor:pointer; padding:0 4px}
.star.on{color:#FFD166}
.spark{width:96px;height:28px;display:block}

/* 徽章 */
.badge{
  display:inline-block; padding:2.5px 9px; border-radius:99px; font:600 11px var(--font-disp);
  letter-spacing:.07em; border:1px solid;
}
.badge.BUY{color:var(--buy); border-color:rgba(70,227,168,.4); background:rgba(70,227,168,.08)}
.badge.WATCH{color:var(--watch); border-color:rgba(91,192,235,.4); background:rgba(91,192,235,.08)}
.badge.HOLD{color:var(--hold); border-color:rgba(138,147,166,.35); background:rgba(138,147,166,.07)}
.badge.REDUCE{color:var(--reduce); border-color:rgba(255,180,90,.4); background:rgba(255,180,90,.08)}
.badge.AVOID{color:#FF5C9E; border-color:rgba(255,92,158,.42); background:rgba(255,92,158,.09)}
.badge.brk{color:#0B0E14; background:var(--holo); border:none}
.rarity-tag{font-size:11px; color:var(--ink-mute)}

/* ---------------- 过滤工具条 ---------------- */
.filterbar{display:flex; flex-wrap:wrap; gap:10px; align-items:center; margin-bottom:14px}
.chip-row{display:flex; gap:7px; flex-wrap:wrap}
.chip{
  padding:6.5px 14px; border-radius:99px; border:1px solid var(--line); background:var(--panel);
  font-size:12.5px; color:var(--ink-dim); transition:all .12s;
}
.chip:hover{color:var(--ink); border-color:rgba(255,255,255,.18)}
.chip.active{color:var(--accent); background:var(--accent-soft); border-color:var(--accent-line); font-weight:600; box-shadow:inset 0 0 0 1px var(--accent-line)}
.filter-cap{font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-mute); margin-right:2px; align-self:center}
/* 多行筛选收进一个面板, caption 右对齐成一列, 三行 chip 不再像散落的band */
.filter-stack{display:flex; flex-direction:column; gap:7px; padding:11px 13px; margin-bottom:14px;
  background:var(--panel); border:1px solid var(--line-soft); border-radius:var(--radius-s)}
.filter-stack .chip-row{margin:0!important}
.filter-stack .filter-cap{min-width:62px; text-align:right; margin-right:8px}
@media (max-width:760px){ .filter-stack .filter-cap{min-width:0; text-align:left; width:100%; margin:0 0 2px} }
.sel,.inp{
  background:var(--panel); border:1px solid var(--line); border-radius:9px; padding:7.5px 11px;
  font-size:12.5px; outline:none; max-width:230px;
}
.sel:focus,.inp:focus{border-color:rgba(91,192,235,.55)}
.sel option{background:#131826}

.pager{display:flex; align-items:center; gap:12px; justify-content:flex-end; padding:13px 4px 2px; font-size:12.5px; color:var(--ink-dim)}
.pager button{
  background:var(--panel); border:1px solid var(--line); color:var(--ink-dim);
  border-radius:8px; padding:6px 13px; font-size:12.5px;
}
.pager button:hover:not(:disabled){color:var(--ink)}
.pager button:disabled{opacity:.35; cursor:not-allowed}

/* ---------------- 信号卡 ---------------- */
.sig-grid{display:grid; grid-template-columns:repeat(auto-fill,minmax(330px,1fr)); gap:14px}
.sig-card{padding:15px 16px; cursor:pointer; transition:transform .15s, border-color .15s; position:relative; overflow:hidden}
.sig-card:hover{transform:translateY(-2px); border-color:rgba(255,255,255,.16)}
.sig-head{display:flex; gap:12px; align-items:flex-start}
.sig-head img{width:46px;height:64px;object-fit:contain;border-radius:6px;background:rgba(255,255,255,.04);flex:0 0 46px}
.sig-name{font-size:13.5px; line-height:1.35; font-weight:600}
.sig-sub{font-size:11.5px; color:var(--ink-mute); margin-top:2px}
.sig-nums{display:flex; gap:16px; margin:10px 0 9px; font-family:var(--font-mono); font-size:12.5px}
.sig-nums b{font-weight:500}
.sig-score{margin-left:auto}
.reasons{display:flex; flex-direction:column; gap:4px}
.reason{font-size:12px; color:var(--ink-dim); padding-left:14px; position:relative}
.reason::before{content:""; position:absolute; left:2px; top:7px; width:5px; height:5px; border-radius:50%; background:var(--accent)}

/* ---------------- 详情页 ---------------- */
.detail-top{display:grid; grid-template-columns:240px 1fr; gap:22px; margin-bottom:16px}
.detail-img{
  width:100%; border-radius:12px; background:rgba(255,255,255,.03); border:1px solid var(--line);
  padding:14px; position:relative; overflow:hidden;
}
.detail-img img{width:100%; height:auto; display:block; border-radius:6px}
.detail-img::after{ /* 卡面闪箔光 */
  content:""; position:absolute; inset:0; pointer-events:none; opacity:.55;
  background:linear-gradient(115deg, transparent 30%, rgba(124,245,200,.10) 44%, rgba(91,192,235,.12) 52%, rgba(199,125,255,.10) 60%, transparent 74%);
  background-size:300% 300%; animation:holoShift 8s ease-in-out infinite;
}
.detail-h1{font:700 23px/1.3 var(--font-disp); margin-bottom:5px}
.detail-meta{color:var(--ink-mute); font-size:13px; margin-bottom:14px}
.detail-meta b{color:var(--ink-dim); font-weight:500}
.ind-grid{display:grid; grid-template-columns:repeat(auto-fit,minmax(118px,1fr)); gap:10px; margin-top:12px}
.ind{background:var(--panel); border:1px solid var(--line-soft); border-radius:10px; padding:10px 12px}
.ind-k{font-size:11px; color:var(--ink-mute); margin-bottom:4px}
.ind-v{font:600 16px var(--font-disp)}
.subtabs{display:flex; gap:7px; margin:4px 0 12px; flex-wrap:wrap}
.chart-box{height:420px; width:100%}
.sig-panel{display:flex; align-items:center; gap:14px; flex-wrap:wrap; margin-top:6px}
.sig-panel .big-badge{font-size:14px; padding:6px 16px}
.fc-note{font-size:12px; color:var(--ink-mute); margin-top:10px; line-height:1.7}

/* 自定义价格源 */
.src-row{display:flex; align-items:center; gap:12px; padding:9px 4px; border-bottom:1px dashed var(--line-soft); font-size:13px}
.src-row:last-child{border-bottom:none}
.src-row .mono{font-size:12px}
.btn-sm{
  background:var(--panel); border:1px solid var(--line); color:var(--ink-dim); border-radius:8px;
  padding:5px 12px; font-size:12px;
}
.btn-sm:hover{color:var(--ink); border-color:rgba(255,255,255,.2)}
.btn-danger{color:var(--avoid); border-color:rgba(255,100,120,.35)}
.form-grid{display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:10px; margin:10px 0}
.form-grid .full{grid-column:1/-1}
.fld label{display:block; font-size:11.5px; color:var(--ink-mute); margin-bottom:5px}
.fld .inp,.fld .sel{width:100%; max-width:none}

/* ---------------- 设置页 ---------------- */
.set-grid{display:grid; grid-template-columns:1fr 1fr; gap:16px; align-items:start}
.set-row{display:flex; align-items:center; gap:12px; padding:10px 0; border-bottom:1px dashed var(--line-soft); font-size:13.5px}
.set-row:last-child{border-bottom:none}
.set-row .lbl{flex:0 0 150px; color:var(--ink-dim)}
.hint{font-size:11.5px; color:var(--ink-mute); margin-top:3px; line-height:1.6}
.set-row .hint{margin-top:3px}
.grp-list{max-height:430px; overflow:auto; border:1px solid var(--line-soft); border-radius:10px; margin-top:10px}
.grp-row{display:flex; align-items:center; gap:10px; padding:7.5px 12px; border-bottom:1px solid var(--line-soft); font-size:12.5px}
.grp-row:hover{background:var(--panel-strong)}
.grp-row .g-date{font-family:var(--font-mono); font-size:11px; color:var(--ink-mute); margin-left:auto}
.switch{position:relative; width:34px; height:19px; flex:0 0 34px}
.switch input{opacity:0; width:0; height:0}
.switch i{
  position:absolute; inset:0; border-radius:99px; background:rgba(255,255,255,.12); transition:.2s; cursor:pointer;
}
.switch i::after{
  content:""; position:absolute; left:2.5px; top:2.5px; width:14px; height:14px; border-radius:50%;
  background:#9AA3B5; transition:.2s;
}
.switch input:checked + i{background:rgba(70,227,168,.35)}
.switch input:checked + i::after{left:17.5px; background:var(--buy)}
.run-log{font-family:var(--font-mono); font-size:12px; line-height:1.9; color:var(--ink-dim)}
.run-log .ok{color:var(--buy)} .run-log .err{color:var(--avoid)}

/* ---------------- 空状态 / 引导 ---------------- */
.empty{
  text-align:center; padding:70px 20px; max-width:520px; margin:40px auto;
}
.empty h2{font:700 22px var(--font-disp); margin:16px 0 10px}
.empty p{color:var(--ink-mute); font-size:13.5px; line-height:1.9; margin-bottom:22px}
.empty .brand-mark{width:60px;height:60px}

/* ---------------- 提示气泡 ---------------- */
.toasts{position:fixed; right:20px; bottom:20px; z-index:99; display:flex; flex-direction:column; gap:9px}
.toast{
  background:#161C2C; border:1px solid var(--line); border-left:3px solid var(--holo-b);
  border-radius:10px; padding:11px 16px; font-size:13px; min-width:230px; max-width:380px;
  box-shadow:0 10px 30px rgba(0,0,0,.45); animation:toastIn .25s ease;
}
.toast.err{border-left-color:var(--avoid)}
.toast.ok{border-left-color:var(--buy)}
@keyframes toastIn{from{opacity:0; transform:translateY(8px)}to{opacity:1; transform:none}}

/* ---------------- 模态 ---------------- */
.modal-mask{position:fixed; inset:0; background:rgba(5,7,12,.66); backdrop-filter:blur(3px); z-index:80; display:flex; align-items:center; justify-content:center; padding:20px}
.modal{background:#11161F; border:1px solid var(--line); border-radius:16px; padding:22px 24px; width:min(560px,94vw); max-height:88vh; overflow:auto}
.modal h3{font:700 17px var(--font-disp); margin-bottom:14px}
.modal-foot{display:flex; justify-content:flex-end; gap:10px; margin-top:18px}

/* ---------------- 响应式 ---------------- */
@media (max-width:1080px){
  .grid-main{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
  .set-grid{grid-template-columns:1fr}
  .detail-top{grid-template-columns:180px 1fr}
}
@media (max-width:760px){
  .sidebar{
    position:fixed; bottom:0; top:auto; height:auto; width:100%; flex-direction:row;
    padding:6px 8px; z-index:50; background:rgba(11,14,20,.92); backdrop-filter:blur(12px);
    border-top:1px solid var(--line); border-right:none;
  }
  .brand,.side-foot{display:none}
  .nav{flex-direction:row; width:100%; justify-content:space-around; gap:0}
  .nav a{flex-direction:column; gap:3px; font-size:10px; padding:6px 6px}
  .nav a.active::before{display:none}
  .nav-badge{display:none}
  .view{padding:16px 14px 90px}
  .topbar{padding:10px 14px; flex-wrap:wrap}
  .detail-top{grid-template-columns:1fr}
  .detail-img{max-width:230px; margin:0 auto}
  .kpi-value{font-size:22px}
}

/* 动效克制: 用户偏好减少动态时全部关闭 */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important; transition:none!important}
}

/* ============================================================
   2.0 升级: 分类主题色系统 / 卡牌种类管理 / 交互细节打磨
   ============================================================ */

/* ---- 分类徽章(列表小标签) ---- */
.cat-tag{display:inline-flex; align-items:center; gap:5px; white-space:nowrap}
.cat-dot{display:inline-block; width:7px; height:7px; border-radius:50%;
  box-shadow:0 0 6px currentColor; flex:none}

/* ---- KPI 分类卡: 顶部主题色光条 ---- */
.kpi-cat{border-top:1px solid color-mix(in srgb, var(--cat) 55%, transparent)}
.kpi-cat::before{content:""; position:absolute; inset:0 auto auto 0; width:100%; height:2px;
  background:linear-gradient(90deg, var(--cat), transparent 75%); opacity:.9}
.kpi-cat::after{content:""; position:absolute; top:-46px; right:-30px; width:120px; height:120px;
  border-radius:50%; background:radial-gradient(circle, color-mix(in srgb, var(--cat) 22%, transparent), transparent 65%);
  pointer-events:none}
.kpi-cat .kpi-label{display:flex; align-items:center; gap:6px}

/* ---- 卡牌种类管理面板 ---- */
.tcg-grid{display:grid; grid-template-columns:repeat(auto-fill,minmax(230px,1fr)); gap:10px}
.tcg-card{
  position:relative; display:flex; align-items:center; gap:10px;
  padding:11px 13px; border-radius:var(--radius-s); cursor:pointer;
  background:var(--panel); border:1px solid var(--line-soft);
  transition:border-color .18s, background .18s, transform .18s, box-shadow .25s;
}
.tcg-card:hover{transform:translateY(-2px); border-color:var(--line);
  box-shadow:0 6px 18px rgba(0,0,0,.35)}
.tcg-card.on{
  background:color-mix(in srgb, var(--cat) 7%, var(--panel-strong));
  border-color:color-mix(in srgb, var(--cat) 45%, transparent);
}
.tcg-card.on::before{content:""; position:absolute; inset:0 auto 0 0; width:3px; border-radius:3px 0 0 3px;
  background:var(--cat); box-shadow:0 0 10px color-mix(in srgb, var(--cat) 60%, transparent)}
.tcg-dot{width:10px; height:10px; border-radius:50%; flex:none;
  background:var(--cat); box-shadow:0 0 8px color-mix(in srgb, var(--cat) 75%, transparent)}
.tcg-names{display:flex; flex-direction:column; min-width:0; flex:1}
.tcg-names b{font-size:13px; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.tcg-names i{font-style:normal; font-size:10.5px; color:var(--ink-mute); white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.tcg-stat{font-size:10.5px; color:var(--ink-mute); flex:none}
.tcg-sw{position:absolute; opacity:0; pointer-events:none}
.sw{width:34px; height:19px; border-radius:19px; flex:none; position:relative;
  background:rgba(255,255,255,.10); border:1px solid var(--line); transition:background .2s, border-color .2s}
.sw::after{content:""; position:absolute; top:2px; left:2px; width:13px; height:13px; border-radius:50%;
  background:var(--ink-dim); transition:transform .2s, background .2s}
.tcg-sw:checked ~ .sw{background:color-mix(in srgb, var(--cat) 45%, rgba(255,255,255,.06));
  border-color:color-mix(in srgb, var(--cat) 60%, transparent)}
.tcg-sw:checked ~ .sw::after{transform:translateX(15px); background:#fff}
.tcg-sw:disabled ~ .sw{opacity:.45}

/* ---- 交互打磨: 面板与行 hover、按钮反馈 ---- */
.panel{transition:border-color .22s, box-shadow .3s, transform .22s}
.mover,.sig-row{transition:background .15s, transform .15s}
.mover:hover,.sig-row:hover{background:rgba(255,255,255,.045); transform:translateX(2px)}
tbody tr{transition:background .12s}
tbody tr:hover{background:rgba(255,255,255,.045)}
.btn-sm,.btn-holo,.chip{transition:transform .12s, filter .15s, background .15s, border-color .15s}
.btn-sm:active,.btn-holo:active,.chip:active{transform:scale(.96)}
.btn-sm:hover{filter:brightness(1.18)}

/* ---- 详情图微动效 ---- */
.detail-img img{transition:transform .3s ease}
.detail-img:hover img{transform:scale(1.03)}

/* ---- 表头吸顶质感 ---- */
thead th{backdrop-filter:blur(6px)}

@media (prefers-reduced-motion:reduce){
  .tcg-card:hover,.mover:hover,.sig-row:hover{transform:none}
}

/* ============================================================
   抽选情报页 + 监控设置
   ============================================================ */
.lt-bar{display:flex; align-items:flex-start; justify-content:space-between; gap:12px 14px;
  margin-bottom:16px; flex-wrap:wrap}
.lt-bar > div:first-child{flex:1 1 300px; min-width:240px}
.lt-bar > div:last-child{flex:0 0 auto}
.lt-tag{font-size:11px; padding:3px 10px; border-radius:20px; letter-spacing:.05em; white-space:nowrap; flex:none}
.lt-done{background:rgba(138,147,166,.13); color:var(--ink-mute); border:1px solid rgba(138,147,166,.3)}
.rt-price.rt-good{color:var(--buy)}    /* 始终绿=定价可购(勿用 .up/.down: CN/INTL 会翻转) */
.rt-price.rt-over{color:var(--reduce)} /* 始终琥珀=溢价 */
.lt-open{background:rgba(70,227,168,.14); color:#46E3A8; border:1px solid rgba(70,227,168,.4)}
.lt-soon{background:rgba(91,192,235,.13); color:#5BC0EB; border:1px solid rgba(91,192,235,.4)}
.lt-member{background:rgba(199,125,255,.13); color:#C77DFF; border:1px solid rgba(199,125,255,.4)}
.lt-stock{background:rgba(255,180,90,.13); color:#FFB45A; border:1px solid rgba(255,180,90,.4)}
.lt-other{background:rgba(255,255,255,.07); color:var(--ink-dim); border:1px solid var(--line)}

.lt-grid{display:grid; grid-template-columns:repeat(auto-fill,minmax(330px,1fr)); gap:12px}
.lt-card{display:flex; gap:12px; padding:13px; border-radius:var(--radius-s);
  background:var(--panel); border:1px solid var(--line-soft); position:relative;
  transition:border-color .18s, transform .18s, box-shadow .25s}
.lt-card:hover{transform:translateY(-2px); border-color:var(--line);
  box-shadow:0 8px 22px rgba(0,0,0,.4)}
.lt-card.is-new{border-color:var(--accent-line);
  background:linear-gradient(180deg, var(--accent-soft), var(--panel))}
.lt-img{width:74px; height:74px; object-fit:contain; border-radius:7px;
  background:rgba(255,255,255,.04); flex:none}
.lt-body{min-width:0; flex:1}
.lt-store{font-size:11.5px; color:var(--accent); display:flex; align-items:center; gap:7px; flex-wrap:wrap}
.lt-src{font-size:9.5px; color:var(--ink-mute); border:1px solid rgba(255,255,255,.34); border-radius:6px; padding:0 6px; font-weight:500}
.lt-new{font-size:9.5px; font-weight:700; letter-spacing:.08em; padding:1px 7px;
  border-radius:10px; background:var(--accent); color:#06121A; animation:ltPulse 2.2s ease-in-out infinite}
@keyframes ltPulse{0%,100%{opacity:1}50%{opacity:.55}}
.lt-prod{font-weight:600; font-size:13.5px; margin-top:2px; line-height:1.35;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden}
.lt-meta{font-size:11.5px; color:var(--ink-mute); margin-top:2px}
.lt-time{font-size:12px; color:var(--ink-dim); margin-top:6px}
.lt-time b{color:var(--ink)}
.lt-cond{font-size:11px; color:var(--ink-mute); margin-top:4px}
.lt-actions{display:flex; gap:8px; margin-top:9px}
.btn-ghost{font-size:12px; padding:5px 12px; border-radius:7px; border:1px solid var(--line);
  background:transparent; color:var(--ink-dim); display:inline-flex; align-items:center;
  transition:border-color .15s, color .15s}
.btn-ghost:hover{border-color:var(--ink-mute); color:var(--ink)}
.lot-grid .set-row .tcg-card{cursor:pointer}

/* ============ v4: 收藏组合 / 愿望单 ============ */

/* 组合切换标签 */
.pf-tabs{display:flex;gap:10px;flex-wrap:wrap;margin:4px 0 18px}
.pf-tab{display:flex;flex-direction:column;gap:3px;min-width:130px;padding:11px 16px;
  border-radius:var(--radius-s);border:1px solid var(--line);background:var(--panel);
  cursor:pointer;transition:border-color .15s,background .15s,transform .1s;text-align:left}
.pf-tab:hover{border-color:var(--ink-mute);background:var(--panel-strong)}
.pf-tab.active{border-color:var(--cat,var(--accent));
  background:color-mix(in srgb,var(--cat,var(--accent)) 12%,transparent);
  box-shadow:0 0 0 1px var(--cat,var(--accent)) inset}
.pf-tab-name{font-size:13px;font-weight:600;color:var(--ink)}
.pf-tab-val{font-family:var(--font-mono);font-size:15px;color:var(--cat,var(--ink))}
.pf-tab.active .pf-tab-val{color:var(--cat,var(--accent))}
.pf-add{align-items:center;justify-content:center;min-width:46px;font-size:22px;
  color:var(--ink-mute);font-weight:300}
.pf-add:hover{color:var(--holo-b)}

/* 组合汇总 KPI 区 */
.pf-summary{display:grid;grid-template-columns:1.4fr 1fr 1fr auto;gap:14px;
  align-items:stretch;margin-bottom:8px}
.pf-kpi{padding:16px 18px;border-radius:var(--radius-s);border:1px solid var(--line);
  background:var(--panel);display:flex;flex-direction:column;gap:4px;justify-content:center}
.pf-kpi.big{background:linear-gradient(135deg,rgba(91,192,235,.08),rgba(199,125,255,.05));
  border-color:rgba(91,192,235,.25)}
.pf-k{font-size:12px;color:var(--ink-mute);letter-spacing:.3px}
.pf-v{font-family:var(--font-mono);font-size:26px;font-weight:600;color:var(--ink);line-height:1.1}
.pf-kpi.big .pf-v{font-size:32px}
.pf-sub{font-size:12.5px;font-family:var(--font-mono)}
.pf-sub.up{color:var(--up)} .pf-sub.down{color:var(--down)} .pf-sub.flat{color:var(--ink-mute)}
.pf-actions{display:flex;flex-direction:column;gap:7px;justify-content:center}
.btn-sm.danger{border-color:rgba(255,100,120,.3);color:#FF8497}
.btn-sm.danger:hover{border-color:#FF6478;background:rgba(255,100,120,.08)}

/* 持仓 / 愿望单表格 */
.pf-table{width:100%;border-collapse:collapse;font-size:13px}
.pf-table thead th{text-align:left;padding:8px 10px;font-size:11.5px;font-weight:600;
  color:var(--ink-mute);border-bottom:1px solid var(--line);white-space:nowrap}
.pf-table thead th:nth-child(n+2){text-align:right}
.pf-table td{padding:9px 10px;border-bottom:1px solid var(--line-soft);vertical-align:middle}
.pf-table td:nth-child(n+2){text-align:right}
.pf-trow:hover{background:var(--panel)}
.pf-table td.mono{font-family:var(--font-mono);white-space:nowrap}
.pf-table td.up,.pf-table .up{color:var(--up)}
.pf-table td.down,.pf-table .down{color:var(--down)}
.pf-table td.flat,.pf-table .flat{color:var(--ink-mute)}
.pf-card{display:flex;align-items:center;gap:10px;cursor:pointer;text-align:left!important;min-width:200px}
.pf-card img{width:34px;height:auto;border-radius:4px;flex:none}
.pf-cn{font-size:12.5px;color:var(--ink);line-height:1.25}
.pf-cm{font-size:10.5px;color:var(--ink-mute);margin-top:2px;display:flex;align-items:center;gap:4px}
.sub-tag{display:inline-block;font-size:10px;padding:1px 6px;border-radius:5px;
  background:var(--panel-strong);color:var(--ink-dim);font-family:var(--font-mono)}
.x-btn{width:22px;height:22px;border-radius:6px;border:1px solid var(--line);
  background:transparent;color:var(--ink-mute);cursor:pointer;font-size:14px;line-height:1;
  transition:border-color .15s,color .15s}
.x-btn:hover{border-color:#FF6478;color:#FF8497}
.btn-xs{font-size:11px;padding:3px 9px;border-radius:6px;border:1px solid var(--line);
  background:transparent;color:var(--holo-b);cursor:pointer;transition:border-color .15s}
.btn-xs:hover{border-color:var(--holo-b)}
.wish-ops{display:flex;gap:6px;align-items:center;justify-content:flex-end}
.empty-sm{padding:24px 8px;text-align:center;color:var(--ink-mute);font-size:13px}
.empty-sm a{color:var(--holo-b)}

/* 详情页操作按钮 */
.detail-acts{display:flex;flex-direction:column;gap:8px;margin-top:12px}
.detail-acts .btn-holo{width:100%;justify-content:center}
.detail-acts .btn-sm{width:100%;justify-content:center;text-align:center}

/* 弹窗 */
.modal-mask{position:fixed;inset:0;background:rgba(5,8,14,.72);backdrop-filter:blur(3px);
  z-index:200;display:flex;align-items:center;justify-content:center;animation:fadeIn .12s}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal{width:min(420px,92vw);background:var(--bg-soft);border:1px solid var(--line);
  border-radius:var(--radius);padding:22px;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.modal-title{font-family:var(--font-disp);font-size:17px;font-weight:600;color:var(--ink);
  margin-bottom:18px;padding-bottom:12px;border-bottom:1px solid var(--line)}
.modal-row{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.modal-row label{width:74px;font-size:13px;color:var(--ink-dim);flex:none}
.modal-row .inp,.modal-row .sel{flex:1}
.modal-btns{display:flex;gap:10px;justify-content:flex-end;margin-top:22px}

/* 侧栏 nav-badge(愿望单♡用) */

/* ============ v4.1: 抽选申请信息档案 ============ */
.prof-card{border:1px solid var(--line);border-radius:var(--radius-s);background:var(--panel);
  padding:14px 16px;margin-bottom:10px}
.prof-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.prof-label{display:inline-block;font-size:11px;padding:2px 9px;border-radius:6px;
  background:color-mix(in srgb,var(--holo-b) 18%,transparent);color:var(--holo-b);
  font-weight:600;margin-right:8px;vertical-align:middle}
.prof-name{font-size:15px;font-weight:600;color:var(--ink);vertical-align:middle}
.prof-kana{font-size:12px;color:var(--ink-mute);margin-left:8px;vertical-align:middle}
.prof-ops{display:flex;gap:6px;align-items:center;flex:none}
.prof-fields{display:flex;flex-wrap:wrap;gap:6px 20px;margin-top:10px}
.prof-f{font-size:12.5px;color:var(--ink-dim)}
.prof-f i{color:var(--ink-mute);font-style:normal;margin-right:6px;font-size:11px}

/* 档案表单(弹窗内网格) */
.prof-form{display:grid;grid-template-columns:1fr 1fr;gap:10px 14px;margin-bottom:6px}
.pf-row{display:flex;flex-direction:column;gap:4px}
.pf-row.full{grid-column:1 / -1}
.pf-row label{font-size:11.5px;color:var(--ink-mute)}
.prof-warn{margin:16px 0 4px;padding:10px 12px;border-radius:var(--radius-s);
  background:rgba(255,180,90,.08);border:1px solid rgba(255,180,90,.25);
  font-size:11.5px;color:#FFC97A;line-height:1.5}

/* ============================================================
   v4.2 易用性 / 显示修复(追加)
   ============================================================ */

/* 长卡名/长系列名统一省略号(避免撑破表格与列表) */
.pf-cn,.m-name,.si-name,.tcg-name{
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}
.pf-cn{max-width:240px}
.m-body,.si-name,.m-name{min-width:0}
.mover .m-body{flex:1; min-width:0}

/* 持仓 / 愿望单表格在窄窗口横向可滚动,不再挤压变形 */
.pf-table-wrap{width:100%; overflow-x:auto; -webkit-overflow-scrolling:touch}
.pf-table-wrap .pf-table{min-width:560px}

/* 键盘可达性:focus-visible 高亮(鼠标点击不显示,键盘 Tab 才显示) */
:focus-visible{outline:2px solid var(--holo-b); outline-offset:2px; border-radius:6px}
.nav a:focus-visible,.btn-holo:focus-visible,.btn-sm:focus-visible,
.cur-sel:focus-visible,.pf-tab:focus-visible{outline-offset:3px}

/* 弹窗内输入框统一外观 + 聚焦反馈(原来缺 .inp/.sel 基础样式) */
.modal .inp,.modal .sel{
  width:100%; padding:8px 11px; border-radius:8px; border:1px solid var(--line);
  background:var(--panel); color:var(--ink); font-size:13.5px; outline:none;
  transition:border-color .15s;
}
.modal .inp:focus,.modal .sel:focus{border-color:rgba(91,192,235,.55)}
.modal .sel option{background:#131826}

/* KPI / 汇总卡数值过长时不溢出(大额日元/换算) */
.pf-v,.kpi-value{overflow-wrap:anywhere}

/* 顶栏在窄窗口允许换行,避免语言/货币/按钮被挤出 */
@media (max-width:720px){
  .topbar{flex-wrap:wrap; gap:10px}
  .search-wrap{order:3; flex-basis:100%; max-width:none}
  .pf-summary{grid-template-columns:1fr 1fr}
  .pf-summary .pf-kpi.big{grid-column:1 / -1}
  .pf-summary .pf-actions{grid-column:1 / -1; flex-direction:row; flex-wrap:wrap}
}

/* ============================================================
   无障碍(a11y)补强: 控件边框对比度 / 点击区域
   ============================================================ */
/* 交互控件边框 ≥3:1(原 --line=rgba(255,255,255,.08) 仅 ~1.2:1, 几乎看不见;
   active 态不动: 它们有高亮填充, 不靠边框辨识) */
.search, .sel, .inp, .cur-sel, .btn-sm, .btn-ghost, .btn-xs, .x-btn,
.pager button, .modal .inp, .modal .sel,
.chip:not(.active), .pf-tab:not(.active){
  border-color: rgba(255,255,255,.38);
}
/* 最小点击区域(原 .x-btn 仅 22px) */
.x-btn{ width:26px; height:26px; }
.star{ padding:4px 7px; }

/* ---------------- 对战 Meta ---------------- */
.meta-list{display:flex; flex-direction:column}
.meta-row{display:flex; align-items:center; gap:10px; padding:7px 8px 7px 6px; border-bottom:1px dashed var(--line-soft); cursor:pointer; border-radius:8px; transition:background .12s}
.meta-row:last-child{border-bottom:none}
.meta-row:hover{background:var(--panel-strong)}
.meta-rank{width:22px; text-align:center; font-family:var(--font-mono); font-size:12px; color:var(--ink-mute); flex:none}
.meta-ic{width:30px; height:30px; object-fit:contain; flex:none; background:rgba(255,255,255,.04); border-radius:5px}
.meta-main{flex:1; min-width:0}
.meta-name{font-size:13px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap}
.meta-bar{height:5px; border-radius:3px; background:var(--panel-strong); margin-top:4px; overflow:hidden}
.meta-bar i{display:block; height:100%; background:var(--accent)}
.meta-list .meta-row:not(.is-card):nth-child(-n+3) .meta-bar i{filter:brightness(1.18)}
/* 整组造价(仅国际架构榜): 主价淡灰, 未计价张数更淡 —— 估算值不抢 share 主视觉 */
.meta-cost{font-family:var(--font-mono); font-size:11px; color:var(--ink-dim); margin-top:3px}
.meta-unpriced{color:var(--ink-mute); opacity:.85}
.meta-share{font-family:var(--font-mono); font-size:12.5px; flex:none; min-width:46px; text-align:right; color:var(--ink-dim)}
.meta-delta{font-family:var(--font-mono); font-size:10px; margin-left:6px; vertical-align:middle; opacity:.92}
/* Tier 榜 top-3 金/银/铜名次, 突出榜首份量 */
.meta-list .meta-row:not(.is-card):nth-child(1) .meta-rank{color:#FFD23E; font-weight:700}
.meta-list .meta-row:not(.is-card):nth-child(2) .meta-rank{color:#C9D2E0; font-weight:700}
.meta-list .meta-row:not(.is-card):nth-child(3) .meta-rank{color:#E8A964; font-weight:700}
/* top-3 圆形奖牌【仅卡组视图】: 单卡视图 .meta-main 有 40px 占位留白, 再叠圆牌会双缩进(回归修复) */
.meta-list .meta-row:not(.is-card):nth-child(-n+3) .meta-rank{
  width:20px; height:20px; line-height:20px; border-radius:50%; font-size:11px;
  background:color-mix(in srgb, currentColor 16%, transparent);
  box-shadow:inset 0 0 0 1px color-mix(in srgb, currentColor 45%, transparent)}
.chip:disabled{opacity:.45; cursor:not-allowed; filter:grayscale(.55)}
/* 单卡/卡组行尾价源提示符: 平时淡, hover/聚焦显青并右移, 暗示"点击查价/看牌表" */
.meta-go{flex:none; min-width:26px; text-align:right; align-self:center;
  font:600 11px var(--font-mono); color:var(--ink-mute); opacity:.5;
  transition:opacity .15s, color .15s, transform .15s}
.meta-row:hover .meta-go{opacity:1; color:var(--accent); transform:translateX(2px)}
.meta-row:focus-visible .meta-go{opacity:1; color:var(--accent)}
/* 单卡视图无图标: 占位保持与卡组视图同一左缩进(30px 图标+10px gap), 切换不跳动 */
.meta-row.is-card .meta-main{margin-left:40px}
/* 无跳转目标的行(如无 deck_url 的架构)不显手型, 免死点击误导 */
.meta-row:not([data-url]):not([data-q]){cursor:default}
@media (prefers-reduced-motion:reduce){.meta-row:hover .meta-go{transform:none}}
