/* ========================================================================
   #/me 我的中心 —— 极简设置中心版（2026-05-24 落地自 preview）
   仅由 viewMeCartoon() / viewMeLuxe() 渲染 .view-me-new[.cartoon|.luxe]
   两套主题在同一文件里 scope 切换：
     .view-me-new:not(.luxe)  → 卡通正版（薄荷绿 + 暖奶油 + 紫/天蓝/橙液态玻璃装饰）
     .view-me-new.luxe     → 夜间金箔（黑底金 + shimmer + glassring）
   luxe.css 关闭了全局 @keyframes，金箔下的 shimmer 动效由 JS WAAPI 启动。
   ======================================================================== */

/* 兜底：即便 class 错乱没匹配到 .cartoon 或 .luxe，也有合理默认（卡通色板） */
.view-me-new{
  --me-paper:#fff8ee;
  --me-paper-2:#fcefd4;
  --me-ink:#1a1611;
  --me-ink-2:#544a3a;
  --me-ink-3:#8a7d65;
  --me-ink-4:#c9bc9f;
  --me-hair:rgba(26,22,17,.08);
  --me-hair-2:rgba(26,22,17,.18);
  --me-accent:#58cc02;
  --me-accent-2:#3ea500;
  --me-display:'Fredoka','Noto Sans SC','PingFang SC','Microsoft YaHei',sans-serif;
  --me-sans:'Nunito','Noto Sans SC','PingFang SC','Microsoft YaHei',sans-serif;
  --me-mono:'JetBrains Mono',ui-monospace,monospace;
  --me-display-tracking:-.015em;
  --me-display-weight:700;
  /* 背景跟随父容器（main / #view），避免与侧栏出现颜色断层 */
}

/* ─── 卡通正版 tokens ─── */
.view-me-new.cartoon{
  --me-paper:#fff8ee;
  --me-paper-2:#fcefd4;
  --me-ink:#1a1611;
  --me-ink-2:#544a3a;
  --me-ink-3:#8a7d65;
  --me-ink-4:#c9bc9f;
  --me-hair:rgba(26,22,17,.08);
  --me-hair-2:rgba(26,22,17,.18);
  --me-accent:#58cc02;
  --me-accent-2:#3ea500;
  --me-display:'Fredoka','Noto Sans SC','PingFang SC','Microsoft YaHei',sans-serif;
  --me-sans:'Nunito','Noto Sans SC','PingFang SC','Microsoft YaHei',sans-serif;
  --me-display-tracking:-.015em;
  --me-display-weight:700;
}

/* ─── 夜间金箔 tokens ─── */
.view-me-new.luxe{
  --me-paper:#0a0907;
  --me-paper-2:#15120c;
  --me-ink:#f2efe8;
  --me-ink-2:#b8b0a0;
  --me-ink-3:#7a7268;
  --me-ink-4:#4a4540;
  --me-hair:rgba(255,239,180,.09);
  --me-hair-2:rgba(255,239,180,.22);
  --me-accent:#ffd84d;
  --me-accent-2:#d4af37;
  --me-display:'Manrope','Noto Sans SC','PingFang SC','Microsoft YaHei',sans-serif;
  --me-sans:'Manrope','Noto Sans SC','PingFang SC','Microsoft YaHei',sans-serif;
  --me-display-tracking:-.04em;
  --me-display-weight:800;
}

/* ─── 容器：在主区域内贴满显示，内容居中并限宽 ─── */
.view-me-new{
  background:var(--me-paper);
  color:var(--me-ink);
  min-height:calc(100vh - 80px);
  padding:64px 48px 80px;
  font-family:var(--me-sans);
  font-size:15px;line-height:1.5;
  -webkit-font-smoothing:antialiased;
  transition:background-color .4s ease,color .4s ease;
}

/* ─── 全页 wash：me 页打开时把 body / sidebar / aside-right / main 都铺上主题底色，
       避免"奶油主区 + 白侧栏"的色块割裂。仅当 .view-me-new 存在时生效，不影响其他页面 ─── */
body:has(.view-me-new:not(.luxe)){
  background:#fff8ee !important;
}
body:has(.view-me-new.luxe){
  background:#0a0907 !important;
}
body:has(.view-me-new) .app,
body:has(.view-me-new) .main,
body:has(.view-me-new) .sidebar,
body:has(.view-me-new) .aside-right,
body:has(.view-me-new) .mobile-header,
body:has(.view-me-new) .mobile-tabbar{
  background:transparent !important;
}
body:has(.view-me-new) .main-footer{
  background:transparent !important;
}
.view-me-new .me-wrap{max-width:840px;margin:0 auto;}

/* ════════ HERO ════════ */
.view-me-new .me-hero{
  display:grid;grid-template-columns:auto 1fr;gap:36px;align-items:center;margin-bottom:72px;
}
.view-me-new .me-avatar{position:relative;width:160px;height:160px;flex-shrink:0;}

/* ─── 卡通头像 ─── */
.view-me-new:not(.luxe) .me-avatar-skin{
  position:absolute;inset:0;border-radius:50%;
  background:radial-gradient(circle at 32% 28%,#fefbe8 0%,#f3fbe0 55%,#dff5c2 100%);
  box-shadow:
    0 18px 36px -10px rgba(88,204,2,.32),
    0 4px 8px rgba(26,22,17,.10),
    inset 0 -10px 22px rgba(88,204,2,.18),
    inset 0 10px 22px rgba(255,255,255,.7);
  animation:menew-bob 3.4s ease-in-out infinite;
}
.view-me-new:not(.luxe) .me-avatar-letter{
  position:absolute;inset:0;display:grid;place-items:center;
  font-family:'Fredoka',sans-serif;font-weight:700;font-size:112px;color:#58cc02;
  line-height:1;
  text-shadow:0 4px 0 #3ea500, 0 6px 12px rgba(62,165,0,.22);
}
.view-me-new:not(.luxe) .me-deco{position:absolute;}
.view-me-new:not(.luxe) .me-deco.purple{
  top:12%;left:13%;width:22px;height:22px;border-radius:50%;
  background:rgba(206,130,255,.55);
  backdrop-filter:blur(10px) saturate(180%);
  -webkit-backdrop-filter:blur(10px) saturate(180%);
  box-shadow:
    0 6px 14px rgba(132,68,180,.45),
    inset 0 2px 2.5px rgba(255,255,255,.85),
    inset 0 -3px 6px rgba(132,68,180,.55),
    inset 0 0 0 0.5px rgba(255,255,255,.5);
  animation:menew-float 4.4s ease-in-out infinite;
}
.view-me-new:not(.luxe) .me-deco.sky{
  top:19%;right:13%;width:22px;height:20px;
  background:linear-gradient(180deg,rgba(180,230,255,.85) 0%,rgba(28,176,246,.55) 50%,rgba(15,140,210,.7) 100%);
  backdrop-filter:blur(10px) saturate(180%);
  -webkit-backdrop-filter:blur(10px) saturate(180%);
  clip-path:polygon(50% 0%,0% 100%,100% 100%);
  filter:drop-shadow(0 5px 10px rgba(28,176,246,.48));
  animation:menew-spin 7s linear infinite;
}
.view-me-new:not(.luxe) .me-deco.orange{
  bottom:17%;right:17%;width:20px;height:7px;border-radius:4px;
  background:rgba(255,150,0,.58);
  backdrop-filter:blur(10px) saturate(180%);
  -webkit-backdrop-filter:blur(10px) saturate(180%);
  box-shadow:
    0 5px 10px rgba(200,100,0,.45),
    inset 0 1.5px 1.5px rgba(255,255,255,.75),
    inset 0 -2px 3px rgba(200,100,0,.55),
    inset 0 0 0 0.5px rgba(255,255,255,.4);
  animation:menew-wobble 2.8s ease-in-out infinite;
}
@keyframes menew-bob{0%,100%{transform:translateY(0);}50%{transform:translateY(-5px);}}
@keyframes menew-float{0%,100%{transform:translate(0,0);}50%{transform:translate(4px,-6px);}}
@keyframes menew-spin{0%{transform:rotate(0);}100%{transform:rotate(360deg);}}
@keyframes menew-wobble{0%,100%{transform:rotate(0);}50%{transform:rotate(-14deg);}}

/* ─── 金箔头像 ─── */
.view-me-new.luxe .me-avatar-skin{
  position:absolute;inset:0;border-radius:50%;overflow:hidden;
  background:radial-gradient(circle at 32% 28%,#3a3220 0%,#191510 60%,#0a0807 100%);
  box-shadow:
    0 0 0 1.5px #d4af37,
    0 0 0 2.5px rgba(212,175,55,.22),
    0 0 0 4px rgba(255,216,77,.45),
    0 24px 48px -12px rgba(0,0,0,.7),
    inset 0 -18px 36px rgba(0,0,0,.45),
    inset 0 14px 28px rgba(212,175,55,.18);
}
.view-me-new.luxe .me-avatar-letter{
  position:absolute;inset:0;display:grid;place-items:center;
  font-family:'Manrope',sans-serif;font-weight:800;font-size:108px;
  background:linear-gradient(135deg,#fff1c5 0%,#ffd84d 35%,#d4af37 65%,#8c7325 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  letter-spacing:-.055em;line-height:1;
  filter:drop-shadow(0 2px 0 rgba(0,0,0,.4));
}
.view-me-new.luxe .me-shimmer{
  position:absolute;inset:-10%;
  background:linear-gradient(135deg,
    transparent 38%,
    rgba(255,232,150,.0) 44%,
    rgba(255,232,150,.7) 50%,
    rgba(255,232,150,.0) 56%,
    transparent 62%);
  mix-blend-mode:overlay;
  /* luxe 全局禁 @keyframes，动效由 _meNewStartShimmer() WAAPI 启动 */
}
.view-me-new.luxe .me-grain{
  position:absolute;inset:0;border-radius:50%;
  background-image:
    radial-gradient(circle at 25% 30%,rgba(212,175,55,.18) 0.5px,transparent 1px),
    radial-gradient(circle at 70% 80%,rgba(255,216,77,.12) 0.5px,transparent 1px),
    radial-gradient(circle at 55% 25%,rgba(212,175,55,.14) 0.5px,transparent 1px);
  background-size:7px 7px,11px 11px,9px 9px;
  opacity:.6;mix-blend-mode:screen;
}
.view-me-new.luxe .me-glassring{
  position:absolute;inset:13%;border-radius:50%;
  background:rgba(255,232,150,.05);
  backdrop-filter:blur(16px) saturate(160%);
  -webkit-backdrop-filter:blur(16px) saturate(160%);
  box-shadow:
    inset 0 2px 3px rgba(255,232,150,.45),
    inset 0 -3px 8px rgba(255,232,150,.2),
    inset 0 0 0 0.5px rgba(255,232,150,.42);
  pointer-events:none;
}

/* ─── HELLO 文案 ─── */
.view-me-new .me-hello h1{
  font-family:var(--me-display);
  font-weight:var(--me-display-weight);
  font-size:54px;letter-spacing:var(--me-display-tracking);
  line-height:1.02;color:var(--me-ink);
  margin:0 0 10px 0;
}
.view-me-new .me-hello h1 em{font-style:normal;color:var(--me-accent);font-weight:inherit;}
.view-me-new .me-hello p{
  font-size:15px;color:var(--me-ink-3);font-family:var(--me-sans);
  font-weight:500;letter-spacing:.01em;margin:0;
}
.view-me-new .me-hello p .me-dot{
  display:inline-block;width:3px;height:3px;border-radius:50%;
  background:var(--me-ink-4);vertical-align:middle;margin:0 10px;transform:translateY(-2px);
}
.view-me-new .me-hello p .me-pro{color:var(--me-accent-2);font-weight:600;}

/* ─── 设置 ─── */
.view-me-new .me-settings{display:flex;flex-direction:column;}
.view-me-new .me-row{
  display:grid;grid-template-columns:160px 1fr auto;gap:24px;align-items:center;
  padding:24px 0;cursor:pointer;
  border-top:1px solid var(--me-hair);
  transition:padding-left .3s cubic-bezier(.5,0,.2,1);
  position:relative;
}
.view-me-new .me-row:last-of-type{border-bottom:1px solid var(--me-hair);}
.view-me-new .me-row::before{
  content:"";position:absolute;left:-20px;top:50%;width:8px;height:8px;border-radius:50%;
  background:var(--me-accent);transform:translateY(-50%) scale(0);opacity:0;
  transition:transform .3s cubic-bezier(.5,0,.2,1.4),opacity .25s;
}
.view-me-new .me-row:hover{padding-left:20px;}
.view-me-new .me-row:hover::before{transform:translateY(-50%) scale(1);opacity:1;}
.view-me-new .me-row .me-label{
  font-size:16px;color:var(--me-ink-3);font-family:var(--me-sans);
  font-weight:600;letter-spacing:0;
}
.view-me-new .me-row .me-value{
  font-family:var(--me-sans);font-size:20px;font-weight:700;color:var(--me-ink);
  letter-spacing:-.005em;
  transition:color .25s;
}
.view-me-new .me-row:hover .me-value{color:var(--me-accent);}
.view-me-new .me-row .me-caret{
  font-family:var(--me-sans);font-size:22px;color:var(--me-ink-4);font-weight:300;
  transition:transform .3s cubic-bezier(.5,0,.2,1.2),color .25s;
}
.view-me-new .me-row:hover .me-caret{color:var(--me-accent);}
.view-me-new .me-row.is-open .me-caret{transform:rotate(90deg);color:var(--me-accent);}

.view-me-new .me-panel{
  grid-column:1 / -1;max-height:0;overflow:hidden;
  transition:max-height .5s cubic-bezier(.4,0,.2,1);
}
.view-me-new .me-panel-inner{padding:8px 0 18px 184px;}
.view-me-new .me-panel-hint{
  font-size:15px;color:var(--me-ink-3);margin-bottom:14px;
  font-family:var(--me-sans);font-weight:500;line-height:1.6;
}
.view-me-new .me-opts{display:flex;flex-wrap:wrap;gap:8px;}
.view-me-new .me-opt{
  font-size:15px;font-weight:600;padding:10px 18px;
  background:var(--me-hair);color:var(--me-ink-2);
  border-radius:999px;cursor:pointer;
  transition:background .2s,color .2s,transform .2s;
}
.view-me-new .me-opt:hover{background:var(--me-hair-2);color:var(--me-accent);transform:translateY(-1px);}
.view-me-new .me-opt.is-active{background:var(--me-accent);color:#fff;}
.view-me-new.luxe .me-opt.is-active{color:#0a0907;}

.view-me-new .me-toggle-row{display:flex;align-items:center;gap:14px;}
.view-me-new .me-toggle{
  position:relative;width:44px;height:26px;background:var(--me-hair-2);border-radius:999px;cursor:pointer;
  transition:background .25s;
}
.view-me-new .me-toggle.is-on{background:var(--me-accent);}
.view-me-new .me-toggle::after{
  content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;background:#fff;border-radius:50%;
  transition:transform .3s cubic-bezier(.5,0,.2,1.4);box-shadow:0 2px 6px rgba(0,0,0,.22);
}
.view-me-new .me-toggle.is-on::after{transform:translateX(18px);}
.view-me-new.luxe .me-toggle.is-on::after{background:#0a0907;}
.view-me-new .me-toggle-label{font-size:15px;color:var(--me-ink-2);font-weight:500;}

/* ─── 底部入口 ─── */
.view-me-new .me-ports{margin-top:64px;display:flex;gap:32px;align-items:center;flex-wrap:wrap;}
.view-me-new .me-port{
  font-size:16px;color:var(--me-ink-3);cursor:pointer;
  position:relative;padding:8px 0;transition:color .25s;
  background:none;border:0;font-family:inherit;font-weight:500;
}
.view-me-new .me-port::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:1.5px;background:var(--me-accent);
  transform:scaleX(0);transform-origin:left;transition:transform .3s cubic-bezier(.5,0,.2,1);
}
.view-me-new .me-port:hover{color:var(--me-accent);}
.view-me-new .me-port:hover::after{transform:scaleX(1);}
.view-me-new .me-port.is-danger:hover{color:#d04545;}
.view-me-new .me-port.is-danger:hover::after{background:#d04545;}

/* ─── 响应式 ─── */
@media (max-width: 720px){
  .view-me-new{padding:48px 24px 64px;}
  .view-me-new .me-hero{grid-template-columns:1fr;gap:24px;}
  .view-me-new .me-avatar{width:128px;height:128px;}
  .view-me-new:not(.luxe) .me-avatar-letter{font-size:88px;}
  .view-me-new.luxe .me-avatar-letter{font-size:80px;}
  .view-me-new .me-hello h1{font-size:38px;}
  .view-me-new .me-row{grid-template-columns:1fr auto;gap:8px;}
  .view-me-new .me-row .me-label{grid-column:1 / -1;}
  .view-me-new .me-panel-inner{padding-left:0;}
}

/* ════════════════════════════════════════════════════════════════════════
   #/favorites 我的词本 — 与 me-new 同款 token，独立 scope
   双主题：.view-favs.cartoon / .view-favs.luxe
   ════════════════════════════════════════════════════════════════════════ */
.view-favs{
  --me-paper:#fff8ee;
  --me-paper-2:#fcefd4;
  --me-ink:#1a1611;
  --me-ink-2:#544a3a;
  --me-ink-3:#8a7d65;
  --me-ink-4:#c9bc9f;
  --me-hair:rgba(26,22,17,.08);
  --me-hair-2:rgba(26,22,17,.18);
  --me-accent:#58cc02;
  --me-accent-2:#3ea500;
  --me-display:'Fredoka','Noto Sans SC','PingFang SC','Microsoft YaHei',sans-serif;
  --me-sans:'Nunito','Noto Sans SC','PingFang SC','Microsoft YaHei',sans-serif;
  --me-mono:'JetBrains Mono',ui-monospace,monospace;
  background:var(--me-paper);
  color:var(--me-ink);
  min-height:calc(100vh - 80px);
  padding:48px 48px 80px;
  font-family:var(--me-sans);
  font-size:15px;line-height:1.5;
  -webkit-font-smoothing:antialiased;
  transition:background-color .4s ease,color .4s ease;
}
.view-favs.luxe{
  --me-paper:#0a0907;
  --me-paper-2:#15120c;
  --me-ink:#f2efe8;
  --me-ink-2:#b8b0a0;
  --me-ink-3:#7a7268;
  --me-ink-4:#4a4540;
  --me-hair:rgba(255,239,180,.09);
  --me-hair-2:rgba(255,239,180,.22);
  --me-accent:#ffd84d;
  --me-accent-2:#d4af37;
  --me-display:'Manrope','Noto Sans SC','PingFang SC','Microsoft YaHei',sans-serif;
  --me-sans:'Manrope','Noto Sans SC','PingFang SC','Microsoft YaHei',sans-serif;
}

/* 整页 wash（同 me-new）让侧栏跟 favs 一同换底色 */
body:has(.view-favs:not(.luxe)){ background:#fff8ee !important; }
body:has(.view-favs.luxe){ background:#0a0907 !important; }
body:has(.view-favs) .app,
body:has(.view-favs) .main,
body:has(.view-favs) .sidebar,
body:has(.view-favs) .aside-right,
body:has(.view-favs) .mobile-header,
body:has(.view-favs) .mobile-tabbar,
body:has(.view-favs) .main-footer{ background:transparent !important; }

.view-favs .favs-wrap{max-width:1100px;margin:0 auto;}

/* ─── 头部 ─── */
.view-favs .favs-head{margin-bottom:36px;}
.view-favs .favs-back{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--me-sans);font-size:15px;font-weight:500;letter-spacing:0;
  color:var(--me-ink-3);background:transparent;border:0;padding:8px 0;cursor:pointer;
  transition:color .25s;margin-bottom:18px;
}
.view-favs .favs-back::before{content:"←  ";font-family:var(--me-mono);}
.view-favs .favs-back:hover{color:var(--me-accent);}
.view-favs .favs-head h1{
  font-family:var(--me-display);font-weight:700;font-size:48px;letter-spacing:-.015em;
  line-height:1.05;color:var(--me-ink);margin:0 0 10px;
}
.view-favs.luxe .favs-head h1{font-weight:800;letter-spacing:-.04em;}

/* ─── Count：大数字 odometer + 副文 ─── */
.view-favs .favs-count{
  display:flex;align-items:baseline;gap:8px;margin:0;
  font-family:var(--me-sans);font-size:15px;color:var(--me-ink-3);
  font-weight:500;letter-spacing:0;
}
.view-favs .favs-count-n{
  font-family:var(--me-display);font-weight:700;font-size:32px;color:var(--me-accent-2);
  letter-spacing:-.02em;line-height:1;font-variant-numeric:tabular-nums;
}
.view-favs .favs-count-sep{color:var(--me-ink-4);}

/* ─── 工具栏 ─── */
.view-favs .favs-tools{
  display:flex;align-items:center;gap:16px;margin-bottom:28px;flex-wrap:wrap;
  padding-bottom:14px;border-bottom:1px solid var(--me-hair);
}

/* tab 列表 + 滑动 indicator hairline */
.view-favs .favs-tabs{
  position:relative;display:flex;gap:0;flex-wrap:wrap;
}
.view-favs .favs-tab{
  position:relative;font-family:var(--me-sans);font-size:17px;font-weight:600;
  padding:12px 22px;background:transparent;color:var(--me-ink-3);
  border:0;cursor:pointer;letter-spacing:0;
  transition:color .25s ease,transform .2s;
  z-index:2;
}
.view-favs .favs-tab:hover{color:var(--me-ink);transform:translateY(-1px);}
.view-favs .favs-tab.is-on{color:var(--me-accent);}
.view-favs.luxe .favs-tab.is-on{color:var(--me-accent-2);}
.view-favs .favs-tab-ind{
  position:absolute;bottom:-1px;left:0;width:0;height:2px;
  background:var(--me-accent);border-radius:2px;z-index:1;
  transition:left .42s cubic-bezier(.5,0,.2,1), width .42s cubic-bezier(.5,0,.2,1);
}

/* 搜索框 + 放大镜图标 */
.view-favs .favs-search-wrap{
  display:flex;align-items:center;gap:10px;flex:1;min-width:200px;max-width:320px;margin-left:auto;
  padding:0 4px 0 12px;border-bottom:1px solid var(--me-hair-2);
  transition:border-color .25s;
}
.view-favs .favs-search-wrap:focus-within{border-bottom-color:var(--me-accent);}
.view-favs .favs-search-ic{
  width:14px;height:14px;color:var(--me-ink-4);flex-shrink:0;
  transition:color .25s;
}
.view-favs .favs-search-wrap:focus-within .favs-search-ic{color:var(--me-accent);}
.view-favs .favs-search{
  flex:1;font-family:var(--me-sans);font-size:16px;color:var(--me-ink);
  background:transparent;border:0;padding:11px 0;outline:none;font-weight:500;
}
.view-favs .favs-search::placeholder{color:var(--me-ink-4);}
.view-favs .favs-search::-webkit-search-cancel-button{display:none;}

/* ─── 卡片墙 ─── */
.view-favs .favs-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:18px;
}
.view-favs .fav-card{
  position:relative;display:flex;flex-direction:column;gap:8px;
  padding:18px 18px 16px;background:rgba(255,255,255,.6);
  border-radius:14px;overflow:hidden;
  box-shadow:0 1px 0 var(--me-hair),0 8px 20px -12px rgba(26,22,17,.12);
  transform-style:preserve-3d;
  transition:box-shadow .35s ease, background .35s ease;
  will-change:transform;
}
.view-favs.luxe .fav-card{
  background:rgba(255,239,180,.035);
  box-shadow:0 1px 0 var(--me-hair),inset 0 0 0 1px rgba(255,216,77,.08);
}
.view-favs .fav-card:hover{
  box-shadow:
    0 2px 0 color-mix(in srgb, var(--me-accent) 70%, transparent),
    0 22px 40px -16px rgba(88,204,2,.32),
    0 8px 20px -12px rgba(26,22,17,.18);
  background:rgba(255,255,255,.9);
}
.view-favs.luxe .fav-card:hover{
  background:rgba(255,239,180,.06);
  box-shadow:
    0 0 0 1px var(--me-accent),
    0 24px 48px -16px rgba(255,216,77,.18);
}
.view-favs .fav-card.is-removing{opacity:0;transform:scale(.94);}

/* 鼠标跟随光斑（用 --tx --ty 由 JS 注入） */
.view-favs .fav-card-glow{
  position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(circle 180px at var(--tx,50%) var(--ty,50%),
    rgba(88,204,2,.18), transparent 70%);
  opacity:0;transition:opacity .35s ease;
}
.view-favs.luxe .fav-card-glow{
  background:radial-gradient(circle 180px at var(--tx,50%) var(--ty,50%),
    rgba(255,216,77,.16), transparent 70%);
}
.view-favs .fav-card:hover .fav-card-glow{opacity:1;}
.view-favs .fav-card[data-kind="mark"]:hover .fav-card-glow{
  background:radial-gradient(circle 180px at var(--tx,50%) var(--ty,50%),
    rgba(232,100,58,.2), transparent 70%);
}
.view-favs .fav-card[data-kind="idiom"]:hover .fav-card-glow{
  background:radial-gradient(circle 180px at var(--tx,50%) var(--ty,50%),
    rgba(90,154,240,.2), transparent 70%);
}

/* 卡片左侧 彩色 hairline rail（hover 时露出） */
.view-favs .fav-card-rail{
  position:absolute;left:0;top:18px;bottom:18px;width:2px;
  background:var(--me-accent);border-radius:2px;
  opacity:0;transform:translateX(-3px);
  transition:opacity .3s, transform .3s cubic-bezier(.5,0,.2,1);
}
.view-favs .fav-card[data-kind="mark"] .fav-card-rail{background:#e8643a;}
.view-favs .fav-card[data-kind="idiom"] .fav-card-rail{background:#5a9af0;}
.view-favs .fav-card:hover .fav-card-rail{opacity:1;transform:translateX(0);}

.view-favs .fav-card-h{
  display:flex;justify-content:space-between;align-items:center;position:relative;z-index:1;
}
.view-favs .fav-card-kind{
  font-family:var(--me-sans);font-size:13px;font-weight:600;letter-spacing:0;
  color:var(--me-accent-2);
}
.view-favs .fav-card[data-kind="mark"] .fav-card-kind{color:#e8643a;}
.view-favs.luxe .fav-card[data-kind="mark"] .fav-card-kind{color:#ff9c5a;}
.view-favs .fav-card[data-kind="idiom"] .fav-card-kind{color:#5a9af0;}
.view-favs.luxe .fav-card[data-kind="idiom"] .fav-card-kind{color:#7eb6ff;}

.view-favs .fav-card-x{
  width:26px;height:26px;border:0;background:transparent;cursor:pointer;
  color:var(--me-ink-4);font-size:20px;line-height:1;padding:0;border-radius:50%;
  opacity:0;transform:scale(.8);
  transition:opacity .2s, transform .25s cubic-bezier(.5,0,.2,1.4), background .2s, color .2s;
}
.view-favs .fav-card:hover .fav-card-x{opacity:1;transform:scale(1);}
.view-favs .fav-card-x:hover{background:rgba(208,69,69,.14);color:#d04545;transform:rotate(90deg) scale(1.06);}

.view-favs .fav-card-w{
  font-family:var(--me-display);font-weight:700;font-size:26px;color:var(--me-ink);
  margin:0;line-height:1.15;letter-spacing:-.005em;position:relative;z-index:1;
}
.view-favs.luxe .fav-card-w{font-weight:800;letter-spacing:-.02em;}
.view-favs .fav-card-w mark{
  background:linear-gradient(transparent 60%, color-mix(in srgb, var(--me-accent) 50%, transparent) 60%);
  color:inherit;padding:0 2px;border-radius:2px;
}
.view-favs .fav-card-def{
  font-size:16px;font-weight:500;color:var(--me-ink-2);line-height:1.5;margin:0;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  position:relative;z-index:1;
}
.view-favs .fav-card-meta{
  font-family:var(--me-sans);font-size:13px;font-weight:500;letter-spacing:0;
  color:var(--me-ink-3);
  margin-top:4px;position:relative;z-index:1;
}
.view-favs .fav-card:hover .fav-card-meta{color:var(--me-accent-2);}

/* 空态 / 无匹配 */
.view-favs .favs-empty{text-align:center;padding:80px 24px;}
.view-favs .favs-empty p{font-size:17px;font-weight:500;color:var(--me-ink-3);margin-bottom:24px;}
.view-favs .favs-empty-cta{
  font-family:var(--me-sans);font-size:16px;font-weight:600;
  background:var(--me-accent);color:#fff;
  border:0;border-radius:999px;padding:14px 28px;cursor:pointer;
  transition:transform .2s,background .2s,box-shadow .25s;
}
.view-favs.luxe .favs-empty-cta{color:#0a0907;}
.view-favs .favs-empty-cta:hover{
  transform:translateY(-2px);background:var(--me-accent-2);
  box-shadow:0 10px 22px -10px var(--me-accent);
}
.view-favs .favs-noresult{
  grid-column:1 / -1;text-align:center;padding:48px 12px;
  font-size:16px;font-weight:500;color:var(--me-ink-3);
}
.view-favs .hide{display:none;}

/* ─── 撤销 snackbar ─── */
.view-favs .favs-snack{
  position:fixed;left:50%;bottom:24px;transform:translate(-50%, 80px);
  display:flex;align-items:center;gap:16px;padding:12px 16px 12px 20px;
  background:var(--me-ink);color:var(--me-paper);
  border-radius:999px;
  box-shadow:0 12px 32px -10px rgba(0,0,0,.45);
  font-size:15px;font-family:var(--me-sans);font-weight:500;
  opacity:0;pointer-events:none;
  transition:opacity .35s ease, transform .42s cubic-bezier(.5,0,.2,1.2);
  z-index:200;
}
.view-favs .favs-snack.is-on{
  opacity:1;transform:translate(-50%, 0);pointer-events:auto;
}
.view-favs.luxe .favs-snack{
  background:#1a1610;color:#fff1c5;
  box-shadow:0 12px 32px -10px rgba(0,0,0,.7),inset 0 0 0 1px rgba(255,216,77,.22);
}
.view-favs .favs-snack-msg{color:inherit;opacity:.92;}
.view-favs .favs-snack-undo{
  background:transparent;border:0;cursor:pointer;
  color:var(--me-accent);font-weight:700;font-size:15px;letter-spacing:0;
  padding:4px 10px;border-radius:6px;transition:background .2s;
}
.view-favs .favs-snack-undo:hover{background:rgba(255,255,255,.1);}

@media (max-width: 720px){
  .view-favs{padding:32px 20px 64px;}
  .view-favs .favs-head h1{font-size:32px;}
  .view-favs .favs-count-n{font-size:24px;}
  .view-favs .favs-tools{gap:8px;}
  .view-favs .favs-tab{padding:8px 12px;}
  .view-favs .favs-search-wrap{margin-left:0;min-width:100%;max-width:none;}
  .view-favs .favs-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px;}
  .view-favs .fav-card{padding:14px;}
  .view-favs .fav-card-w{font-size:18px;}
  .view-favs .fav-card-x{opacity:1;} /* 移动端没 hover，按钮常驻 */
}
