/* ════════════════════════════════════════════════════════════════
   元燼界誌 · 小說索引(Codex / 索引)— 沿用 novel.css 深色 token
   視覺升級(elevation):典籍卷宗質感 — 宋體 · 朱印分類 · 細金界線 · 留白。
   ★ 與 atlas.html 共用:.cx-detail / .cx-hero* / .cx-* 詳情面板(由 codex-card.js 建)、
     .xcard(閱讀頁 X-Ray 浮卡,read.html 共用)。本檔重塑這些的視覺,兩頁一致受益。
     索引頁專屬(atlas 不用):.cx-head / .cx-search / .cx-chips / .cx-card / .cx-grid / .cx-empty。
   ════════════════════════════════════════════════════════════════ */
:root{ --zhu:#743029; --zhu-line:rgba(176,84,66,.26); --zhu-ink:#e2cdbd; }

/* —— 9 大分類印色(handoff §④,沿用品牌副色,非彩虹;keyed 到真實 codex.js 分類 key)——
   設計 label → 真實 key: history→world(史) · geo→geography(地) · faction→faction(勢)
   · rite→system(儀) · cultiv→cultivation(修) · artifact→artifact(器)
   · art→technique(術) · person→character(人) · chapter→chapter(卷) */
.cat-world      {--cat:#f0b454}
.cat-geography  {--cat:#7fd3a8}
.cat-faction    {--cat:#e0512f}
.cat-system     {--cat:#a8d6ff}
.cat-cultivation{--cat:#caa15f}
.cat-artifact   {--cat:#c6bfae}
.cat-technique  {--cat:#d2673f}
.cat-character  {--cat:#c2705f}
.cat-chapter    {--cat:#8b8576}

/* ════ 索引頁版面(sticky 標頭 + 卡片 grid;桌機內容置中)════ */
body.codex-page{ background:radial-gradient(140% 90% at 50% 0%,#0b0e16 0%,#06080e 70%) fixed; }

/* —— sticky 標頭:站標 + 搜尋 + 分類印 chip 列 —— */
.cx-head{position:sticky;top:0;z-index:30;padding:22px 30px 16px;
  background:rgba(8,11,20,.62);border-bottom:1px solid rgba(240,180,84,.06);
  transition:background .4s var(--ease),backdrop-filter .4s var(--ease),border-color .4s var(--ease)}
.cx-head.solid{background:rgba(8,11,20,.86);backdrop-filter:blur(14px);
  border-bottom-color:rgba(240,180,84,.1)}
.cx-head-inner{max-width:1140px;margin:0 auto;display:flex;align-items:flex-end;justify-content:space-between;gap:18px}
.cx-brand{display:flex;align-items:center;gap:13px;min-width:0}
.cx-brand-seal{width:30px;height:30px;flex:none;border-radius:5px;
  background:linear-gradient(150deg,#7d322a,#561f1a);box-shadow:inset 0 0 0 1px rgba(226,205,189,.3);
  display:grid;place-items:center;font-family:var(--serif);font-size:15px;color:var(--zhu-ink)}
.cx-brand-txt{display:flex;flex-direction:column;gap:2px;min-width:0}
.cx-brand-name{font-family:var(--serif);font-size:20px;letter-spacing:.18em;color:var(--paper);line-height:1}
.cx-brand-back{font-family:var(--sans);font-size:10px;letter-spacing:.34em;color:var(--gold-dim);
  text-transform:uppercase;text-decoration:none;transition:color .25s}
.cx-brand-back:hover{color:var(--gold)}
.cx-head-count{margin:0;font-family:var(--sans);font-size:12px;letter-spacing:.12em;color:var(--paper-dim);
  white-space:nowrap;flex:none}

/* 搜尋:CSS 畫的放大鏡(無圖檔);輸入非受控 */
.cx-search{max-width:1140px;margin:16px auto 0;display:flex;align-items:center;gap:11px;
  padding:11px 16px;border-radius:8px;border:1px solid rgba(236,231,219,.12);background:rgba(236,231,219,.03);
  transition:border-color .3s var(--ease),box-shadow .3s var(--ease)}
.cx-search:focus-within{border-color:rgba(240,180,84,.5);box-shadow:0 0 24px rgba(240,180,84,.1)}
.cx-search-icn{position:relative;display:inline-block;width:15px;height:15px;color:var(--gold-dim);flex:none}
.cx-search-icn::before{content:"";position:absolute;top:0;left:0;width:11px;height:11px;
  border:1.5px solid currentColor;border-radius:50%}
.cx-search-icn::after{content:"";position:absolute;bottom:0;right:0;width:5px;height:1.5px;
  background:currentColor;transform:rotate(45deg);transform-origin:right}
.cx-search input{flex:1;min-width:0;border:none;background:transparent;outline:none;
  font-family:var(--serif);font-size:15px;letter-spacing:.04em;color:var(--paper)}
.cx-search input::placeholder{color:rgba(139,133,118,.7)}
.cx-search input::-webkit-search-cancel-button{-webkit-appearance:none}

/* 分類印 chip 列:active = 金填色 */
.cx-chips{max-width:1140px;margin:14px auto 0;display:flex;gap:9px;overflow-x:auto;padding-bottom:2px;
  scrollbar-width:none}
.cx-chips::-webkit-scrollbar{height:0}
.cx-chip{flex:none;cursor:pointer;display:inline-flex;align-items:center;gap:7px;
  padding:7px 13px;border-radius:999px;font-family:var(--sans);font-size:12px;letter-spacing:.1em;
  color:var(--paper-soft);background:rgba(236,231,219,.03);border:1px solid rgba(236,231,219,.12);
  transition:color .2s var(--ease),background .2s var(--ease),border-color .2s var(--ease)}
.cx-chip:hover{color:var(--paper);border-color:rgba(236,231,219,.22)}
.cx-chip:focus-visible{outline:1px solid var(--gold);outline-offset:2px}
.cx-chip-dot{width:6px;height:6px;border-radius:50%;background:var(--cat,var(--gold))}
.cx-chip.on{color:#1c1305;background:linear-gradient(160deg,#ffd089,#f0b454);border-color:rgba(255,208,137,.6)}
.cx-chip.on .cx-chip-dot{background:rgba(28,19,5,.55)}

/* —— 3 欄卡片 grid(手機 1 欄)—— */
.cx-main{max-width:1140px;margin:0 auto;padding:0 30px}
.cx-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;align-items:start;padding:24px 0 56px}
.cx-empty{text-align:center;color:var(--paper-dim);font-family:var(--sans);letter-spacing:.2em;
  padding:80px 0;font-size:13px}

/* 卡片:分類印 + 分類 + 狀態 → 標題 → 摘要(2 行)→ 首見 */
.cx-card{display:flex;flex-direction:column;gap:12px;cursor:pointer;
  background:linear-gradient(165deg,#0f1626,#0a111d);border:1px solid rgba(236,231,219,.07);
  border-radius:10px;padding:17px 18px;
  transition:border-color .2s var(--ease),transform .2s var(--ease),box-shadow .2s var(--ease)}
.cx-card:hover{border-color:rgba(240,180,84,.3);transform:translateY(-2px);
  box-shadow:0 16px 32px -18px rgba(0,0,0,.75)}
.cx-card:focus-visible{outline:1px solid var(--gold);outline-offset:2px;border-color:rgba(240,180,84,.3)}
.cx-card-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.cx-card-lead{display:flex;align-items:center;gap:10px;min-width:0}
.cx-card-seal{width:34px;height:34px;flex:none;border-radius:5px;display:grid;place-items:center;
  font-family:var(--serif);font-size:18px;font-weight:600;
  color:var(--cat,var(--gold));
  border:1px solid color-mix(in srgb,var(--cat,#f0b454) 40%,transparent);
  background:color-mix(in srgb,var(--cat,#f0b454) 10%,transparent)}
.cx-card-cat{font-family:var(--sans);font-size:11px;letter-spacing:.14em;color:var(--paper-dim);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cx-card-status{display:inline-flex;align-items:center;gap:6px;flex:none;
  font-family:var(--sans);font-size:10.5px;letter-spacing:.08em;color:var(--paper-dim)}
.cx-card-statusdot{width:6px;height:6px;border-radius:50%;background:#6f6a5d}
.cx-card-title{margin:0;font-family:var(--serif);font-size:22px;font-weight:600;letter-spacing:.04em;color:var(--paper)}
.cx-card-sum{margin:0;font-family:var(--serif);font-size:14px;line-height:1.7;color:var(--paper-dim);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.cx-card-seen{margin-top:2px;font-family:var(--sans);font-size:11px;letter-spacing:.08em;color:var(--gold-dim)}

/* 人物卡:頂部去背立繪槽(暖暈 + 底部羽化遮罩);真圖填入,無圖則 .ph 佔位 */
.cx-card.char{padding-top:0}
.cx-card-por{position:relative;height:158px;margin:0 -18px 2px;border-radius:10px 10px 0 0;overflow:hidden;
  background:radial-gradient(58% 78% at 50% 32%,rgba(194,112,95,.30),transparent 64%),
    radial-gradient(50% 60% at 50% 84%,rgba(240,180,84,.10),transparent 70%),
    linear-gradient(180deg,#1b1620 0%,#0e1019 100%)}
.cx-card-por img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:50% 6%;
  transform:scale(1.04);filter:saturate(.96) brightness(.96);
  -webkit-mask-image:linear-gradient(to bottom,#000 58%,transparent);
  mask-image:linear-gradient(to bottom,#000 58%,transparent)}
/* 佔位態:無真圖時,中央淡光暈呼應「立繪」,維持暖場;羽化同上由槽底漸層帶出 */
.cx-card-por.ph::before{content:"";position:absolute;inset:0;
  -webkit-mask-image:linear-gradient(to bottom,#000 58%,transparent);
  mask-image:linear-gradient(to bottom,#000 58%,transparent);
  background:radial-gradient(34% 64% at 50% 40%,rgba(236,231,219,.12),transparent 62%)}
.cx-card-portag{position:absolute;top:11px;z-index:2;display:inline-flex;align-items:center;gap:6px;
  padding:4px 8px;background:rgba(8,11,20,.4)}
.cx-card-portag.mono{left:12px;font-family:ui-monospace,'SF Mono',monospace;font-size:9px;letter-spacing:.05em;
  color:rgba(226,205,189,.62);border:1px dashed rgba(226,205,189,.28);border-radius:4px}
.cx-card-portag.turn{right:12px;font-family:var(--sans);font-size:9.5px;letter-spacing:.1em;
  color:var(--paper-soft);border:1px solid rgba(236,231,219,.2);border-radius:999px}
.cx-card-portag.turn .d{width:5px;height:5px;border-radius:50%;background:var(--gold)}

/* ════════════════════════════════════════════════════════════════
   詳情面板(由 codex-card.js 建;索引頁右抽屜 / 手機全螢幕,atlas 共用)
   handoff §④:分區皆有 section 標頭 + 細金線;玄樞註金框 pull-quote;原文左金邊引文;關聯膠囊
   ════════════════════════════════════════════════════════════════ */
.cx-scrim{position:fixed;inset:0;z-index:60;background:rgba(4,6,12,.66);backdrop-filter:blur(5px);
  opacity:0;pointer-events:none;transition:opacity .32s var(--ease);
  display:flex;align-items:stretch;justify-content:flex-end}
.cx-scrim.on{opacity:1;pointer-events:auto}
.cx-detail{position:relative;z-index:61;width:560px;max-width:100%;height:100%;overflow-y:auto;padding:0;
  background:radial-gradient(130% 50% at 50% 0%,#111a2d,#0b1120 58%,#080c15);
  border-left:1px solid rgba(240,180,84,.16);box-shadow:-30px 0 60px -20px rgba(0,0,0,.7);
  transform:translateX(32px);opacity:0;
  transition:transform .36s var(--ease),opacity .36s var(--ease)}
.cx-detail.open{transform:none;opacity:1}
.cx-detail::-webkit-scrollbar{width:8px}
.cx-detail::-webkit-scrollbar-thumb{background:rgba(240,180,84,.18);border-radius:4px}
.cx-detail .grab{display:none}
.cx-detail .close{position:absolute;top:20px;right:20px;z-index:6;width:32px;height:32px;border-radius:50%;
  border:1px solid rgba(236,231,219,.18);color:var(--paper-soft);background:rgba(8,11,20,.5);cursor:pointer;
  display:flex;align-items:center;justify-content:center;font-size:15px;transition:color .25s,border-color .25s}
.cx-detail .close:hover{color:var(--gold-bright);border-color:var(--gold)}

/* 統一 hero(媒體頂):人物=ambient 模糊填底 + 羽化清晰立繪(輪播);地點=16:9 全景 */
.cx-hero{position:relative;overflow:hidden;background:#0a0e1a}
.cx-hero-blur{position:absolute;inset:-12%;width:124%;height:124%;object-fit:cover;
  filter:blur(48px) brightness(.95) saturate(1.06)}
.cx-hero-stage{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.cx-slide{position:absolute;inset:0;opacity:0;transition:opacity .9s var(--ease)}
.cx-slide.on{opacity:1}
.cx-hero-sharp{height:100%;width:62%;object-fit:contain;display:block;margin:0 auto;
  -webkit-mask-image:linear-gradient(90deg,transparent 0,#000 16%,#000 84%,transparent 100%);
  mask-image:linear-gradient(90deg,transparent 0,#000 16%,#000 84%,transparent 100%)}
.cx-hero-sharp.cut{width:72%;-webkit-mask-image:none;mask-image:none;
  filter:drop-shadow(0 18px 30px rgba(0,0,0,.5)) drop-shadow(0 3px 8px rgba(0,0,0,.35))}
.cx-hero-wide{width:100%;height:100%;object-fit:cover}
.cx-hero-video{position:absolute;top:0;left:50%;transform:translateX(-50%);height:100%;width:auto}
.cx-cap{position:absolute;left:0;right:0;bottom:0;z-index:4;padding:11px 18px;
  background:linear-gradient(0deg,rgba(6,9,16,.88),transparent);display:flex;align-items:center;gap:9px}
.cx-cap::before{content:"";width:4px;height:14px;border-radius:1px;background:var(--gold);flex:none}
.cx-cap span{font-family:var(--serif);font-size:13px;color:var(--paper-soft);letter-spacing:.02em}
.cx-dots{position:absolute;left:0;right:0;top:14px;z-index:4;display:flex;justify-content:center;gap:7px}
.cx-dot{width:7px;height:7px;border-radius:99px;cursor:pointer;background:rgba(255,255,255,.36);
  box-shadow:0 1px 4px rgba(0,0,0,.5);transition:all .3s var(--ease)}
.cx-dot:hover{background:rgba(255,255,255,.6)}
.cx-dot.vid{width:15px;border-radius:4px}
.cx-dot.on{background:var(--gold,#f0b454);width:20px;border-radius:99px}
.cx-axis{display:flex;gap:8px;padding:11px 26px 0;flex-wrap:wrap}
.cx-thumb{height:60px;border-radius:6px;overflow:hidden;border:1px solid var(--line-soft);cursor:pointer;
  position:relative;background:rgba(20,28,46,.6);transition:border-color .2s;flex:0 0 auto}
.cx-thumb.por{width:48px}
.cx-thumb.wide{width:104px}
.cx-thumb.on{border-color:var(--gold)}
.cx-thumb img{width:100%;height:100%;object-fit:cover}
.cx-thumb.por img{object-position:50% 5%}
.cx-thumb.wide img{object-position:50% 42%}
.cx-thumb .vb{position:absolute;inset:0;display:grid;place-items:center;color:#fff;font-size:15px;
  text-shadow:0 1px 4px #000;background:rgba(8,11,20,.2)}
.cx-thumb.soon{opacity:.4;cursor:default}
.cx-thumb .pl{position:absolute;inset:0;display:grid;place-items:center;color:var(--paper-dim);font-size:11px}

/* —— 詳情本文區 —— */
.cx-body{padding:30px 34px 60px}

/* ① 標頭:分類印 + 分類 + 狀態 + 首見 → 大標題 36px */
.cx-detail .d-tags{display:flex;align-items:center;gap:11px;margin-bottom:0}
.cx-detail .d-seal{width:40px;height:40px;flex:none;border-radius:6px;display:grid;place-items:center;
  font-family:var(--serif);font-size:21px;font-weight:600;
  color:var(--cat,var(--gold));
  border:1px solid color-mix(in srgb,var(--cat,#f0b454) 40%,transparent);
  background:color-mix(in srgb,var(--cat,#f0b454) 10%,transparent)}
/* 分類印旁的雙行 meta(分類名 / 揭露狀態點 · 首見) */
.cx-detail .d-meta{display:flex;flex-direction:column;gap:4px;min-width:0}
.cx-detail .d-meta .d-catlabel{font-family:var(--sans);font-size:11px;letter-spacing:.18em;
  color:var(--paper-dim);text-transform:uppercase}
.cx-detail .d-meta .d-sub{display:flex;align-items:center;gap:9px;flex-wrap:wrap;
  font-family:var(--sans);font-size:11px;letter-spacing:.06em;color:var(--paper-dim)}
.cx-detail .d-meta .d-status{display:inline-flex;align-items:center;gap:6px}
/* 狀態點:已知=金;其餘(資料含「初見」)=青,呼應「部分揭露」#a8d6ff */
.cx-detail .d-meta .d-status .sd{width:6px;height:6px;border-radius:50%;background:#a8d6ff}
.cx-detail .d-meta .d-status .sd.known{background:#f0b454}
.cx-detail .d-meta .d-bar{width:1px;height:11px;background:rgba(198,191,174,.25)}
.cx-detail h2{margin:18px 0 0;font-family:var(--serif);font-size:38px;font-weight:600;letter-spacing:.06em;
  color:var(--paper);padding-right:0;line-height:1.18}
.cx-detail .d-first{display:none}

/* 通用 section 標頭:小金字 + 細金線 */
.cx-sec{margin-top:30px;display:flex;align-items:center;gap:11px}
.cx-sec span{font-family:var(--sans);font-size:10.5px;letter-spacing:.24em;color:var(--gold-dim);text-transform:uppercase;flex:none}
.cx-sec i{flex:1;height:1px;background:rgba(240,180,84,.16)}

/* ② 摘要 */
.cx-detail h4{margin:0}
.cx-detail .d-summary{margin:13px 0 0;font-family:var(--serif);font-size:16px;line-height:1.95;letter-spacing:.02em;
  color:var(--paper-soft)}

/* ③ 已知事實:金菱形 marker */
.cx-detail .d-known{list-style:none;margin:14px 0 0;padding:0;display:flex;flex-direction:column;gap:12px}
.cx-detail .d-known li{position:relative;padding-left:18px;
  font-family:var(--serif);font-size:15px;line-height:1.8;color:var(--paper-soft)}
.cx-detail .d-known li::before{content:"";position:absolute;left:0;top:.62em;width:6px;height:6px;
  background:var(--gold);transform:rotate(45deg)}

/* ④ 玄樞註:金框 pull-quote + 左上角朱印「樞」+ 金亮字 */
.cx-detail .d-note{position:relative;margin:11px 0 0;padding:24px 26px;border-radius:10px;
  border:1px solid rgba(240,180,84,.2);
  background:linear-gradient(160deg,rgba(240,180,84,.07),rgba(240,180,84,.01));
  font-family:var(--serif);font-size:19px;font-style:normal;line-height:1.8;letter-spacing:.04em;
  color:var(--gold-bright)}
.cx-detail .d-note::before{content:"樞";position:absolute;left:20px;top:-12px;width:26px;height:26px;
  border-radius:5px;background:linear-gradient(150deg,#7d322a,#561f1a);display:grid;place-items:center;
  font-family:var(--serif);font-size:13px;font-style:normal;color:var(--zhu-ink)}

/* ⑤ 原文引用:左金邊引文 + 「↪ <章節錨點>」連結 */
.cx-detail .d-srcs{margin:14px 0 0;display:flex;flex-direction:column;gap:16px}
.cx-detail .src{display:block;padding:0 0 0 16px;border-left:2px solid rgba(240,180,84,.35);
  text-decoration:none;background:none;border-radius:0;cursor:pointer}
.cx-detail .src span{display:block;font-family:var(--serif);font-size:16px;line-height:1.9;color:var(--paper);letter-spacing:0}
.cx-detail .src b{display:inline-flex;align-items:center;gap:6px;margin-top:9px;font-weight:400;
  font-family:var(--sans);font-size:11.5px;letter-spacing:.1em;color:var(--gold-dim);transition:color .2s}
.cx-detail .src b::before{content:"↪"}
.cx-detail .src:hover b{color:var(--gold-bright)}

/* ⑥ 關聯條目:膠囊 chips */
.cx-detail .d-related{margin:14px 0 0;display:flex;flex-wrap:wrap;gap:9px}
.cx-detail .rel{font-family:var(--serif);font-size:14px;letter-spacing:.04em;color:var(--paper-soft);
  border:1px solid rgba(236,231,219,.15);border-bottom-style:solid;border-radius:999px;padding:7px 15px;cursor:pointer;
  transition:border-color .2s,color .2s}
.cx-detail .rel:hover{color:var(--gold-bright);border-color:rgba(240,180,84,.4)}

/* —— 正文內嵌 X-Ray:可點名詞(閱讀頁 read.html)—— */
.chapter-body .xray{color:var(--gold);border-bottom:1px dashed rgba(240,180,84,.42);cursor:pointer;
  border-radius:2px;padding:0 1px;transition:background .2s,border-color .2s}
.chapter-body .xray:hover{background:rgba(240,180,84,.13);border-color:var(--gold)}
.chapter-body p.solo .xray{border-bottom-color:rgba(240,180,84,.5)}
.chapter-body .xray.cx-active{background:rgba(240,180,84,.13);border-color:var(--gold)}

/* —— X-Ray 就地輕浮卡(閱讀頁:點名詞就地浮現,不壓暗整頁)—— */
.xcard{position:absolute;z-index:62;width:330px;max-width:92vw;
  background:linear-gradient(180deg,rgba(14,20,35,.975),rgba(8,11,20,.975));
  border:1px solid var(--line);border-radius:5px;overflow:hidden;
  box-shadow:0 26px 64px rgba(0,0,0,.62);
  opacity:0;transform:translateY(6px);transition:opacity .2s var(--ease),transform .2s var(--ease)}
.xcard.in{opacity:1;transform:none}
.xcard::before{content:"";position:absolute;top:-7px;left:var(--caret,46px);width:13px;height:13px;
  background:rgba(14,20,35,.975);border-left:1px solid var(--line);border-top:1px solid var(--line);
  transform:rotate(45deg)}
.xcard.below::before{top:auto;bottom:-7px;
  border:0;border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
.xcard .x-body{position:relative;z-index:2;padding:15px 17px 13px}
.xcard.char .x-body{max-width:63%}
.xcard .x-meta{display:flex;align-items:center;gap:9px;margin-bottom:10px}
.xcard .seal{width:22px;height:22px;flex:none;border-radius:3px;background:var(--zhu);
  border:1px solid var(--zhu-line);display:grid;place-items:center;
  font-family:var(--serif);font-size:13px;color:var(--zhu-ink)}
.xcard .reveal-tag{font-family:var(--sans);font-size:10px;letter-spacing:.16em;color:var(--paper-dim);
  border:1px solid var(--line-soft);border-radius:99px;padding:2px 9px}
.xcard .reveal-tag.known{color:var(--gold);border-color:rgba(240,180,84,.32)}
.xcard h3{font-family:var(--serif);font-size:22px;font-weight:400;letter-spacing:.07em;color:#fff;margin:0}
.xcard .x-first{font-family:var(--sans);font-size:10.5px;letter-spacing:.1em;color:var(--paper-dim);margin-top:7px}
.xcard .x-sum{font-family:var(--serif);font-size:13px;line-height:1.82;color:var(--paper-soft);
  letter-spacing:.02em;margin-top:11px;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.xcard .x-more{display:flex;align-items:center;justify-content:flex-end;gap:6px;
  margin-top:13px;padding-top:11px;border-top:1px solid rgba(240,180,84,.1);
  font-family:var(--sans);font-size:11px;letter-spacing:.14em;color:var(--gold);cursor:pointer}
.xcard .x-more:hover{color:var(--gold-bright)}
.xcard .x-more .arr{transition:transform .25s}
.xcard .x-more:hover .arr{transform:translateX(3px)}
.xcard.char .por{position:absolute;right:0;top:0;bottom:0;width:56%;z-index:1}
.xcard.char .por img{width:100%;height:100%;object-fit:cover;object-position:50% 8%;
  filter:saturate(.94) brightness(.9) contrast(1.02);
  -webkit-mask-image:linear-gradient(90deg, transparent 0%, #000 70%), linear-gradient(180deg, transparent 0%, #000 16%, #000 80%, transparent 100%);
  -webkit-mask-composite:source-in;
  mask-image:linear-gradient(90deg, transparent 0%, #000 70%), linear-gradient(180deg, transparent 0%, #000 16%, #000 80%, transparent 100%);
  mask-composite:intersect}
.xcard.char .por::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(270deg, rgba(8,11,20,.6) 0%, rgba(8,11,20,.12) 34%, transparent 60%),
    linear-gradient(180deg, rgba(8,11,20,.5) 0%, transparent 26%, transparent 72%, rgba(8,11,20,.55) 100%)}

/* ════ 響應式:680 斷點;手機 grid 1 欄、詳情面板全螢幕 ════ */
@media(max-width:680px){
  .cx-head{padding:calc(env(safe-area-inset-top,0px) + 16px) 20px 14px}
  .cx-head-inner,.cx-search,.cx-chips,.cx-main{padding-left:0;padding-right:0}
  .cx-main{padding:0 18px}
  .cx-brand-seal{width:26px;height:26px;font-size:13px}
  .cx-brand-name{font-size:18px;letter-spacing:.16em}
  .cx-grid{grid-template-columns:1fr;gap:13px;padding:18px 0 48px}
  .cx-card{padding:16px;gap:11px}
  .cx-card.char{padding-top:0}
  .cx-card-por{height:150px;margin:0 -16px 2px}
  .cx-card-title{font-size:19px}
  .cx-card-sum{font-size:13px;line-height:1.65}

  .cx-scrim{align-items:stretch}
  .cx-detail{width:100%;border-left:none;transform:translateY(24px)}
  .cx-detail.open{transform:none}
  .cx-detail .close{top:calc(env(safe-area-inset-top,0px) + 16px)}
  .cx-body{padding:28px 22px 60px}
  .cx-detail h2{font-size:30px;letter-spacing:.05em}
  .cx-detail .d-note{font-size:17px;padding:20px 22px}
  .cx-axis{padding-left:18px;padding-right:18px}
}

@media(prefers-reduced-motion:reduce){
  .cx-detail,.cx-scrim,.xcard,.cx-card,.cx-head{transition:none}
  .cx-card:hover{transform:none}
}
