/* ══ 纹样图鉴 Wényàng · 站点样式 (app.css) ══════════════════════════════
   建立在 styles.css 令牌之上。图录留白 · 发丝线 · 宋体题名 · 三处克制彩。 */

*,*::before,*::after{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}
body{
  margin:0;background:var(--bg-grad) fixed;color:var(--ink-2);
  font-family:var(--font-serif-body);font-size:var(--fs-body);line-height:var(--lh-body);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  transition:color var(--dur-slow) var(--ease-standard);
}
body::before{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:var(--grain);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer;padding:0;}
:focus-visible{outline:2px solid var(--ink);outline-offset:2px;border-radius:2px;}
::selection{background:var(--celadon);color:var(--paper);}

.wrap{max-width:var(--container);margin:0 auto;padding-inline:var(--pad);}
.hair{height:0;border:0;border-top:var(--hair) solid var(--hairline);margin:0;}
.cn{font-family:var(--font-serif-sc);}
.eyebrow{font-family:var(--font-garamond);font-size:var(--fs-eyebrow);letter-spacing:var(--ls-eyebrow);
  text-transform:uppercase;color:var(--ink-3);font-weight:500;}
.lat-it{font-family:var(--font-garamond);font-style:italic;color:var(--ink-3);letter-spacing:.02em;}
.meta{font-family:var(--font-sans);font-size:var(--fs-meta);color:var(--ink-3);}
.mono{font-family:var(--font-mono);font-size:var(--fs-mono);letter-spacing:var(--ls-mono);
  color:var(--ink-3);font-variant-numeric:tabular-nums;}

/* ── 顶栏 ───────────────────────────────────────────── */
.site-head{position:sticky;top:0;z-index:50;background:var(--paper);border-bottom:var(--hair) solid var(--hairline);
  transition:background var(--dur-slow) var(--ease-standard);}
.site-head .row{display:flex;align-items:center;gap:var(--s-5);height:72px;}
.brand{display:flex;align-items:center;gap:12px;}
.brand-logo{flex:none;width:56px;height:56px;object-fit:contain;display:block;transition:transform .7s var(--ease-standard);}
.brand:hover .brand-logo{transform:rotate(360deg);}
.brand-logo.spin{animation:logoSpin .8s var(--ease-standard);}
@keyframes logoSpin{from{transform:rotate(0)}to{transform:rotate(360deg)}}
.icon-link{display:grid;place-items:center;width:32px;height:32px;color:var(--ink-3);border-radius:var(--r-control);
  transition:color var(--dur),background var(--dur);}
.icon-link svg{width:17px;height:17px;}
.icon-link:hover{color:var(--ink);background:var(--paper-sink);}
[data-theme=dark] .icon-link:hover{color:var(--celadon);}
.brand .mark{font-family:var(--font-serif-sc);font-weight:600;font-size:1.05rem;color:var(--ink);letter-spacing:.05em;white-space:nowrap;}
.brand .mark-lat{font-family:var(--font-garamond);font-style:italic;font-size:.92rem;color:var(--ink-3);}
.nav{margin-left:auto;display:flex;align-items:center;gap:var(--s-2);}
.nav .seg{display:flex;align-items:center;gap:2px;}
.nav-btn{font-family:var(--font-sans);font-size:var(--fs-meta);color:var(--ink-3);padding:7px 11px;border-radius:var(--r-control);
  transition:color var(--dur) var(--ease-standard),background var(--dur) var(--ease-standard);white-space:nowrap;position:relative;}
.nav-btn:hover{color:var(--celadon-deep);background:var(--paper-sink);}
[data-theme=dark] .nav-btn:hover{color:var(--celadon);}
.nav-btn.on{color:var(--ink);}
.nav-btn.on::after{content:"";position:absolute;left:11px;right:11px;bottom:2px;height:1.5px;background:var(--gold);border-radius:1px;}
.nav-sep{width:1px;height:20px;background:var(--hairline);margin-inline:4px;}

/* 主题三段控制 青瓷 / 宣纸 / 墨夜 (对应交接包 A·B·C) */
.theme-seg{display:inline-flex;border:var(--hair) solid var(--hairline);border-radius:var(--r-chip);overflow:hidden;}
.seg-btn{font-family:var(--font-sans);font-size:var(--fs-meta);color:var(--ink-3);padding:6px 12px;
  transition:color var(--dur),background var(--dur);white-space:nowrap;}
.seg-btn+.seg-btn{border-left:var(--hair) solid var(--hairline);}
.seg-btn:hover{color:var(--celadon-deep);background:var(--paper-sink);}
[data-theme=dark] .seg-btn:hover{color:var(--celadon);}
.seg-btn.on{background:var(--ink);color:var(--paper);}

/* 搜索框 */
.search{display:flex;align-items:center;gap:8px;background:var(--paper-sink);border:var(--hair) solid transparent;
  border-radius:var(--r-control);padding:6px 11px;transition:border-color var(--dur);min-width:46px;position:relative;cursor:text;}
.search:focus-within{border-color:var(--celadon);}
.search svg{width:15px;height:15px;color:var(--ink-3);flex:none;}
.search input{border:none;background:none;outline:none;font-family:var(--font-sans);font-size:var(--fs-meta);
  color:var(--ink);width:0;opacity:0;transition:width var(--dur) var(--ease-standard),opacity var(--dur);}
.search.open input,.search:focus-within input{width:158px;opacity:1;}
.search input::placeholder{color:var(--ink-3);}
.search-kbd{flex:none;font-family:var(--font-mono);font-size:.66rem;color:var(--ink-3);border:var(--hair) solid var(--hairline);
  border-radius:3px;padding:1px 6px;line-height:1.5;opacity:.8;transition:opacity var(--dur);}
.search.open .search-kbd,.search:focus-within .search-kbd{display:none;}
.search-x:not([hidden])~.search-kbd{display:none;}
.search input[type=search]::-webkit-search-cancel-button,
.search input[type=search]::-webkit-search-decoration{-webkit-appearance:none;appearance:none;display:none;}
.search input[type=search]::-ms-clear{display:none;}
.search-x{flex:none;width:16px;height:16px;display:grid;place-items:center;border-radius:50%;color:var(--ink-3);font-size:11px;line-height:1;opacity:.7;}
.search-x[hidden]{display:none;}
.search-x:hover{opacity:1;color:var(--cinnabar);}
.search-pop{position:absolute;top:calc(100% + 9px);right:0;width:344px;max-width:78vw;
  background:var(--paper);border:var(--hair) solid var(--hairline);border-radius:var(--r-control);
  box-shadow:var(--lift);overflow:hidden;z-index:70;}
.search-pop[hidden]{display:none;}
.sg-item{display:flex;align-items:center;gap:11px;padding:9px 12px;border-bottom:var(--hair) solid var(--hairline);}
.sg-item img{width:32px;aspect-ratio:var(--card-ratio);object-fit:cover;flex:none;border:var(--hair) solid var(--frame);border-radius:2px;background:var(--paper-deep);}
.sg-item.on,.sg-item:hover{background:var(--paper-sink);}
.sg-tx{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px;}
.sg-cn{font-family:var(--font-serif-sc);color:var(--ink);font-size:.96rem;}
.sg-en{font-family:var(--font-garamond);font-style:italic;color:var(--ink-3);font-size:.76rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sg-cat{flex:none;font-family:var(--font-sans);font-size:.68rem;color:var(--ink-3);}
.sg-all{width:100%;text-align:left;padding:10px 12px;font-family:var(--font-sans);font-size:.8rem;color:var(--gold);background:var(--paper-deep);transition:color var(--dur);}
.sg-all b{font-family:var(--font-serif-sc);color:var(--ink);}
.sg-all:hover{color:var(--celadon-deep);}
[data-theme=dark] .sg-all:hover{color:var(--celadon);}
.sg-empty{padding:14px 13px;font-family:var(--font-sans);font-size:.85rem;color:var(--ink-3);}

/* ── 区块通用 ──────────────────────────────────────── */
main{min-height:60vh;}
.view{animation:viewIn var(--dur-page) var(--ease-standard);}
@keyframes viewIn{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:none;}}

/* ── 首页 Hero ─────────────────────────────────────── */
.hero{padding-block:clamp(40px,7vw,86px) var(--s-7);position:relative;overflow:hidden;}
.hero .wrap{position:relative;z-index:1;}
.hero::after{content:"\7eb9";position:absolute;right:-1.5vw;top:50%;transform:translateY(-50%);
  font-family:var(--font-serif-sc);font-weight:900;font-size:clamp(220px,34vw,470px);line-height:1;
  color:var(--ink);opacity:.045;pointer-events:none;user-select:none;}
.hero .eyebrow{display:block;margin-bottom:var(--s-5);}
.hero h1{font-family:var(--font-serif-sc);font-weight:900;font-size:var(--fs-display);line-height:1.04;
  letter-spacing:.02em;color:var(--ink);margin:0;text-wrap:balance;}
.hero .sub{font-family:var(--font-garamond);font-style:italic;font-size:clamp(1.1rem,2vw,1.5rem);
  color:var(--ink-3);margin:.5rem 0 0;}
.hero .count{margin-top:var(--s-6);font-family:var(--font-sans);font-size:var(--fs-meta);color:var(--ink-3);letter-spacing:.02em;}
.hero .count b{color:var(--ink-2);font-weight:500;}

/* ── 筛选条 ────────────────────────────────────────── */
.filter{position:sticky;top:72px;z-index:40;background:var(--paper-deep);padding-block:var(--s-4);
  border-top:var(--hair) solid var(--hairline);border-bottom:var(--hair) solid var(--hairline);transition:background var(--dur-slow);}
.filter .inner{display:flex;align-items:center;gap:var(--s-4);}
.chips{display:flex;gap:var(--s-2);overflow-x:auto;scrollbar-width:none;padding:2px 2px 4px;
  scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;
  -webkit-mask-image:linear-gradient(90deg,transparent 0,#000 14px,#000 calc(100% - 26px),transparent 100%);
          mask-image:linear-gradient(90deg,transparent 0,#000 14px,#000 calc(100% - 26px),transparent 100%);}
.chips::-webkit-scrollbar{display:none;}
.chip{scroll-snap-align:start;}
.chip{font-family:var(--font-sans);font-size:var(--fs-meta);color:var(--ink-2);white-space:nowrap;
  border:var(--hair) solid var(--hairline);border-radius:var(--r-chip);padding:6px 15px;
  transition:all var(--dur) var(--ease-standard);}
.chip:hover{border-color:var(--celadon);color:var(--celadon-deep);}
[data-theme=dark] .chip:hover{color:var(--celadon);}
.chip.on{background:var(--ink);color:var(--paper);border-color:var(--ink);}

/* 画廊工具条: 计数 (左) + 换一换 (右) —— 从分类气泡中移出 */
.gallery-bar{display:flex;align-items:center;justify-content:space-between;gap:var(--s-4);
  padding:var(--s-6) 0 var(--s-3);border-bottom:var(--hair) solid var(--hairline);}
.gcount{font-family:var(--font-sans);font-size:var(--fs-meta);color:var(--ink-3);}
.gcount b{color:var(--ink);font-weight:600;font-family:var(--font-serif-sc);}
.gtools{display:flex;align-items:center;gap:var(--s-3);flex:none;}
.gsep{width:1px;height:14px;background:var(--hairline);}
.shuffle-btn{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-sans);font-size:var(--fs-meta);
  color:var(--ink-2);border:var(--hair) solid var(--hairline);border-radius:var(--r-chip);padding:6px 14px;transition:all var(--dur) var(--ease-standard);}
.shuffle-btn svg{width:14px;height:14px;}
.shuffle-btn:hover{border-color:var(--celadon);color:var(--celadon-deep);background:var(--paper-sink);}
[data-theme=dark] .shuffle-btn:hover{color:var(--celadon);}
.link-btn{font-family:var(--font-sans);font-size:var(--fs-meta);color:var(--ink-3);transition:color var(--dur);}
.link-btn:hover{color:var(--celadon-deep);}
[data-theme=dark] .link-btn:hover{color:var(--celadon);}

/* —— 首页落地页 —— */
.hero-cta{margin-top:var(--s-7);display:flex;gap:var(--s-3);flex-wrap:wrap;}
.hero-cta .btn.primary{font-size:.9rem;padding:13px 22px;}
.home-sec{padding-block:var(--s-9);border-top:var(--hair) solid var(--hairline);}
.home-sec:first-of-type{border-top:0;}
.sec-head{margin-bottom:var(--s-6);}
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gutter);}
.cat-card{position:relative;display:flex;flex-direction:column;gap:6px;min-height:144px;padding:var(--s-6);
  border:var(--hair) solid var(--hairline);border-radius:var(--r-card);overflow:hidden;
  background:color-mix(in srgb,var(--paper) 50%,transparent);
  transition:transform var(--dur) var(--ease-standard),box-shadow var(--dur),border-color var(--dur);}
.cat-card:hover{transform:translateY(-2px);box-shadow:var(--lift);border-color:var(--gold);}
.cat-card::after{content:"";position:absolute;left:var(--s-6);bottom:0;height:2px;width:0;background:var(--gold);transition:width var(--dur) var(--ease-standard);}
.cat-card:hover::after{width:34px;}
.cc-cn{font-family:var(--font-serif-sc);font-weight:500;font-size:1.45rem;color:var(--ink);letter-spacing:.04em;position:relative;z-index:1;}
.cc-en{font-family:var(--font-garamond);font-style:italic;color:var(--ink-3);font-size:.95rem;position:relative;z-index:1;}
.cc-n{margin-top:auto;font-family:var(--font-sans);font-size:.78rem;color:var(--ink-3);position:relative;z-index:1;}
.cc-wm{position:absolute;right:-6px;bottom:-26px;font-family:var(--font-serif-sc);font-weight:700;font-size:122px;line-height:1;
  color:var(--ink);opacity:.05;pointer-events:none;user-select:none;z-index:0;transition:opacity var(--dur) var(--ease-standard),color var(--dur),transform var(--dur-slow) var(--ease-standard);}
.cat-card:hover .cc-wm{opacity:.1;color:var(--celadon);transform:translateY(-4px);}
.today{display:grid;grid-template-columns:minmax(0,280px) 1fr;align-items:stretch;
  border:var(--hair) solid var(--hairline);border-radius:var(--r-card);overflow:hidden;
  background:color-mix(in srgb,var(--paper) 50%,transparent);transition:box-shadow var(--dur) var(--ease-standard);}
.today:hover{box-shadow:var(--lift);}
.today-img{position:relative;aspect-ratio:var(--card-ratio);border-right:var(--hair) solid var(--hairline);background:var(--paper-deep);}
.today-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.today-info{padding:var(--s-8);display:flex;flex-direction:column;justify-content:center;}
.today-info h3{font-family:var(--font-serif-sc);font-weight:700;font-size:clamp(1.8rem,3vw,2.4rem);color:var(--ink);margin:0;letter-spacing:.04em;}
.today-info .lat-it{margin:6px 0 0;font-size:1.02rem;}
.today-sum{margin:var(--s-5) 0 var(--s-6);color:var(--ink-2);max-width:46ch;}
.more{display:inline-flex;align-items:center;gap:7px;color:var(--gold);font-family:var(--font-sans);font-size:var(--fs-meta);transition:gap var(--dur);}
.more svg{width:15px;height:15px;}
.today:hover .more{gap:12px;}
.mean-chips{display:flex;flex-wrap:wrap;gap:var(--s-3);}
.mean-chip{font-family:var(--font-serif-sc);font-size:1.08rem;color:var(--ink);
  border:var(--hair) solid var(--hairline);border-radius:var(--r-chip);padding:9px 22px;
  transition:all var(--dur) var(--ease-standard);}
.mean-chip:hover{border-color:var(--celadon);color:var(--celadon-deep);background:var(--paper-sink);transform:translateY(-1px);}
[data-theme=dark] .mean-chip:hover{color:var(--celadon);}
/* 纹样库精简页头 */
.lib-head{padding-block:var(--s-7) var(--s-3);}
.lib-head .wrap{display:flex;align-items:center;gap:var(--s-5);flex-wrap:wrap;}
.lib-head .back{margin:0;}
.lib-title{font-family:var(--font-serif-sc);font-weight:700;font-size:clamp(1.7rem,3.2vw,2.4rem);color:var(--ink);margin:0;letter-spacing:.04em;}

/* —— 专题展 / 策展 —— */
.sec-head-row{display:flex;align-items:baseline;justify-content:space-between;gap:var(--s-4);}
.sec-more{font-family:var(--font-sans);font-size:var(--fs-meta);color:var(--gold);display:inline-flex;align-items:center;gap:6px;transition:gap var(--dur);}
.sec-more svg{width:14px;height:14px;}
.sec-more:hover{gap:11px;}
.topic-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gutter);}
.topic-grid.wide{grid-template-columns:repeat(2,1fr);gap:var(--s-6);}
.topic-card{display:flex;flex-direction:column;border:var(--hair) solid var(--hairline);border-radius:var(--r-card);
  overflow:hidden;background:color-mix(in srgb,var(--paper) 50%,transparent);
  transition:transform var(--dur) var(--ease-standard),box-shadow var(--dur),border-color var(--dur);}
.topic-card:hover{transform:translateY(-3px);box-shadow:var(--lift);border-color:var(--tc);}
.tc-thumbs{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1px;background:var(--hairline);aspect-ratio:3/1.55;}
.tc-thumbs img{width:100%;height:100%;object-fit:cover;background:var(--paper-deep);}
.tc-thumbs img:first-child{grid-column:span 1;}
.tc-body{padding:var(--s-6);display:flex;flex-direction:column;gap:5px;position:relative;}
.tc-body::before{content:"";position:absolute;left:var(--s-6);top:0;width:26px;height:2px;background:var(--tc);}
.tc-body h3{font-family:var(--font-serif-sc);font-weight:700;font-size:1.4rem;color:var(--ink);margin:6px 0 0;letter-spacing:.04em;}
.tc-body .lat-it{font-size:.92rem;}
.tc-dao{color:var(--ink-2);font-size:.98rem;margin:8px 0 0;line-height:1.55;}
.tc-meta{margin-top:14px;font-family:var(--font-sans);font-size:var(--fs-meta);color:var(--ink-3);display:inline-flex;align-items:center;gap:8px;}
.tc-arr svg{width:14px;height:14px;color:var(--tc);}
.topics-intro{font-family:var(--font-garamond);font-style:italic;font-size:1.2rem;color:var(--ink-3);margin:0 0 var(--s-7);max-width:50ch;}
/* 专题详情 */
.topic-hero{padding-block:var(--s-7) var(--s-8);border-bottom:var(--hair) solid var(--hairline);}
.topic-hero .back{margin-bottom:var(--s-6);}
.th-grid{display:grid;grid-template-columns:1fr minmax(220px,300px);gap:clamp(28px,5vw,72px);align-items:center;}
.th-text .eyebrow{display:block;margin-bottom:var(--s-4);}
.th-text h1{font-family:var(--font-serif-sc);font-weight:900;font-size:clamp(2.4rem,5vw,3.8rem);color:var(--ink);margin:0;letter-spacing:.03em;line-height:1.06;}
.th-en{font-size:1.3rem;margin:10px 0 0;}
.th-dao{color:var(--ink-2);font-size:1.16rem;line-height:1.6;margin:var(--s-5) 0 0;max-width:46ch;border-left:2px solid var(--tc);padding-left:var(--s-5);}
.th-count{display:inline-block;margin-top:var(--s-6);font-family:var(--font-sans);font-size:var(--fs-meta);color:var(--ink-3);}
.th-img{display:block;aspect-ratio:var(--card-ratio);border:var(--hair) solid var(--frame);border-radius:var(--r-card);overflow:hidden;box-shadow:var(--lift);background:var(--paper-deep);
  transition:transform var(--dur-slow) var(--ease-standard);}
.th-img:hover{transform:translateY(-3px);}
.th-img img{width:100%;height:100%;object-fit:cover;}
.topic-essay{max-width:760px;padding-block:var(--s-9);}
.topic-essay h3,.topic-members h3{display:flex;align-items:center;gap:12px;font-family:var(--font-sans);font-weight:600;font-size:var(--fs-h3);color:var(--ink);margin:0 0 var(--s-5);letter-spacing:.02em;}
.topic-essay h3::before,.topic-members h3::before{content:"";width:18px;height:1px;background:var(--tc);flex:none;}
.topic-essay h3 .en,.topic-members h3 .en{font-family:var(--font-garamond);font-style:italic;font-weight:400;color:var(--ink-3);font-size:.98rem;}
.essay-zh{font-family:var(--font-serif-body);font-size:1.18rem;line-height:1.85;color:var(--ink);margin:0;text-indent:2em;}
.essay-en{font-family:var(--font-garamond);font-style:italic;font-size:1.04rem;color:var(--ink-3);margin:var(--s-5) 0 0;line-height:1.7;}
.topic-members{padding-bottom:var(--s-8);}
.topic-next{display:flex;flex-direction:column;gap:6px;border-top:var(--hair) solid var(--hairline);padding:var(--s-7) 0 var(--s-11);transition:opacity var(--dur);}
.topic-next:hover{opacity:.66;}
.tn-l{font-family:var(--font-sans);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);}
.tn-cn{font-family:var(--font-serif-sc);font-weight:700;font-size:1.7rem;color:var(--ink);display:inline-flex;align-items:center;gap:12px;}
.tn-arr svg{width:20px;height:20px;color:var(--tc);}
@media (max-width:860px){
  .topic-grid,.topic-grid.wide{grid-template-columns:1fr;}
  .th-grid{grid-template-columns:1fr;}
  .th-img{max-width:280px;}
}
@media (max-width:760px){
  .cat-grid{grid-template-columns:repeat(2,1fr);}
  .today{grid-template-columns:1fr;}
  .today-img{aspect-ratio:16/10;border-right:0;border-bottom:var(--hair) solid var(--hairline);}
  .today-info{padding:var(--s-6);}
}
@media (max-width:440px){ .cat-grid{grid-template-columns:1fr;} }

/* —— 纹样长卷 marquee (首屏缓慢横向漂移) —— */
.marquee-wrap{margin:var(--s-6) 0 var(--s-3);overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);}
.marquee{display:flex;flex-direction:column;gap:var(--gutter);}
.mq-row{display:flex;gap:var(--gutter);width:max-content;will-change:transform;}
.mq-a{animation:mqA 72s linear infinite;}
.mq-b{animation:mqB 94s linear infinite;}
@keyframes mqA{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes mqB{from{transform:translateX(-50%)}to{transform:translateX(0)}}
.marquee-wrap:hover .mq-row{animation-play-state:paused;}
.mq-card{flex:none;width:148px;display:block;}
.mq-card img{width:148px;aspect-ratio:var(--card-ratio);object-fit:cover;
  border:var(--hair) solid var(--frame);border-radius:var(--r-card);background:var(--paper-deep);
  transition:transform var(--dur-slow) var(--ease-standard),box-shadow var(--dur-slow) var(--ease-standard);}
.mq-card:hover img{transform:translateY(-4px);box-shadow:var(--lift);}
@media (max-width:600px){ .mq-card,.mq-card img{width:120px;} }
@media (prefers-reduced-motion:reduce){
  .mq-row{animation:none!important;transform:none!important;}
  .marquee-wrap{overflow-x:auto;scrollbar-width:none;}
  .marquee-wrap::-webkit-scrollbar{display:none;}
}

/* —— 即将上线预告 —— */
.coming-bar{max-width:680px;margin-bottom:var(--s-6);}
.cb-text{font-family:var(--font-serif-body);color:var(--ink-2);margin:0 0 12px;}
.cb-text b{font-family:var(--font-serif-sc);color:var(--ink);font-size:1.12em;}
.cb-total{font-family:var(--font-serif-sc);color:var(--gold);}
.cb-track{height:3px;background:var(--paper-sink);border-radius:2px;overflow:hidden;}
.cb-fill{display:block;height:100%;width:12.5%;background:var(--gold);}
.coming-chips{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:var(--s-5);}
.soon-chip{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-serif-sc);font-size:.98rem;color:var(--ink-3);border:var(--hair) dashed var(--hairline);border-radius:var(--r-chip);padding:7px 8px 7px 15px;cursor:default;transition:border-color var(--dur),color var(--dur);}
.soon-chip:hover{border-color:var(--gold);color:var(--ink-2);}
.soon-dot{font-family:var(--font-sans);font-size:.6rem;color:var(--paper);background:var(--cinnabar);opacity:.72;border-radius:50%;width:16px;height:16px;display:grid;place-items:center;flex:none;}
.coming-groups{font-family:var(--font-sans);font-size:.82rem;color:var(--ink-3);line-height:1.95;max-width:780px;margin:0;}
/* —— 关于·维护者 —— */
.author{margin-top:var(--s-9);padding-top:var(--s-7);border-top:var(--hair) solid var(--hairline);}
.author-name{font-family:var(--font-serif-sc);font-weight:700;font-size:1.5rem;color:var(--ink);margin:0 0 14px;letter-spacing:.03em;}
.author-name .lat-it{font-size:.92rem;margin-left:8px;}
.author p{color:var(--ink-2);margin:0 0 12px;max-width:60ch;}
.author-links{font-family:var(--font-sans);font-size:.85rem;color:var(--ink-3);}
/* —— 页脚维护者名 —— */
.foot-name{font-family:var(--font-serif-sc);font-size:.82rem;color:var(--ink-2);transition:color var(--dur);white-space:nowrap;}
.foot-name:hover{color:var(--gold);}
.sort{display:flex;align-items:center;gap:var(--s-3);flex:none;}
.sort button{font-family:var(--font-sans);font-size:var(--fs-meta);color:var(--ink-3);display:inline-flex;align-items:center;gap:5px;
  transition:color var(--dur);}
.sort button:hover{color:var(--celadon-deep);}
[data-theme=dark] .sort button:hover{color:var(--celadon);}
.sort .sep{width:1px;height:14px;background:var(--hairline);}

/* ── 网格 + 卡片 ───────────────────────────────────── */
.grid{display:grid;grid-template-columns:repeat(var(--cols),1fr);gap:var(--gutter) var(--gutter);
  padding-block:var(--s-7) var(--s-10);}
.card{display:block;}
.card .frame{position:relative;aspect-ratio:var(--card-ratio);border:var(--hair) solid var(--frame);border-radius:var(--r-card);
  overflow:hidden;background:var(--paper-deep);
  transition:transform var(--dur-slow) var(--ease-standard),box-shadow var(--dur-slow) var(--ease-standard),border-color var(--dur);}
.card .frame img{width:100%;height:100%;object-fit:cover;opacity:0;clip-path:inset(0 100% 0 0);transition:opacity .55s var(--ease-standard),clip-path .8s var(--ease-standard);}
.card .frame img.ready{opacity:1;clip-path:inset(0 0 0 0);}
.card:hover .frame{transform:translateY(-3px);box-shadow:var(--lift);border-color:var(--hairline);}
.card:focus-visible .frame{outline:2px solid var(--ink);outline-offset:2px;}
/* image-error / loading 占位 */
.card .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-family:var(--font-serif-sc);color:var(--ink-3);font-size:1.1rem;letter-spacing:.1em;}
.fav{position:absolute;top:10px;right:10px;width:32px;height:32px;border-radius:var(--r-chip);
  display:grid;place-items:center;background:color-mix(in srgb,var(--paper) 78%,transparent);
  opacity:0;transform:translateY(-2px);transition:opacity var(--dur),transform var(--dur),background var(--dur);}
.card:hover .fav,.fav.is-fav,.fav:focus-visible{opacity:1;transform:none;}
.fav svg{width:17px;height:17px;color:var(--ink-2);transition:color var(--dur);}
.fav.is-fav svg{color:var(--cinnabar);fill:var(--cinnabar);}
.fav:hover svg{color:var(--cinnabar);}
.fav.pop{animation:pop 1.4s var(--ease-standard);}
@keyframes pop{0%{transform:scale(1);}18%{transform:scale(1.18);}40%{transform:scale(1);}}
.card .cap{display:flex;align-items:baseline;justify-content:space-between;gap:10px;padding-top:11px;}
.card .cap .nm{font-family:var(--font-serif-sc);font-weight:500;color:var(--ink);font-size:1rem;letter-spacing:.03em;}
.card .cap .no{font-family:var(--font-garamond);font-style:italic;color:var(--ink-3);font-size:.9rem;}

/* 入场交错 */
.stagger>*{opacity:0;animation:cardIn .5s var(--ease-standard) forwards;}
@keyframes cardIn{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}

/* ── 详情页 ────────────────────────────────────────── */
.detail{padding-block:var(--s-6) var(--s-11);}
.back{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-sans);font-size:var(--fs-meta);
  color:var(--ink-3);margin-bottom:var(--s-7);transition:color var(--dur);}
.back:hover{color:var(--celadon-deep);}
[data-theme=dark] .back:hover{color:var(--celadon);}
.back .lat-it{font-size:.85rem;}
.detail-grid{display:grid;grid-template-columns:minmax(280px,420px) 1fr;gap:clamp(32px,5vw,80px);align-items:start;}
.detail-img{position:sticky;top:100px;}
.detail-img .frame{border:var(--hair) solid var(--frame);border-radius:var(--r-card);overflow:hidden;background:var(--paper-deep);
  aspect-ratio:var(--card-ratio);cursor:zoom-in;box-shadow:var(--lift);}
.detail-img .frame img{width:100%;height:100%;object-fit:cover;}
.actions{display:flex;flex-wrap:wrap;gap:var(--s-3);margin-top:var(--s-5);}
.btn{font-family:var(--font-sans);font-size:var(--fs-meta);border:var(--hair) solid var(--hairline);border-radius:var(--r-control);
  padding:11px 16px;color:var(--ink-2);display:inline-flex;align-items:center;gap:8px;
  transition:all var(--dur) var(--ease-standard);}
.btn svg{width:15px;height:15px;}
.btn:hover{border-color:var(--celadon);color:var(--celadon-deep);background:var(--paper-sink);}
[data-theme=dark] .btn:hover{color:var(--celadon);}
.btn.primary{background:var(--celadon-deep);color:var(--paper);border-color:var(--celadon-deep);}
[data-theme=dark] .btn.primary{color:#15140e;background:var(--celadon);border-color:var(--celadon);}
.btn.primary:hover{filter:brightness(1.06);background:var(--celadon-deep);color:var(--paper);}
.btn.is-fav{color:var(--cinnabar);border-color:color-mix(in srgb,var(--cinnabar) 50%,var(--hairline));}
.btn.is-fav svg{fill:var(--cinnabar);}

.detail-cat{display:inline-block;font-family:var(--font-sans);font-size:var(--fs-meta);color:var(--celadon-deep);margin-bottom:var(--s-3);}
[data-theme=dark] .detail-cat{color:var(--celadon);}
.detail h2{font-family:var(--font-serif-sc);font-weight:700;font-size:var(--fs-h2);line-height:var(--lh-tight);
  color:var(--ink);margin:0;letter-spacing:var(--ls-cjk-title);}
.detail .title-lat{font-family:var(--font-garamond);font-style:italic;font-size:1.3rem;color:var(--ink-3);margin-top:8px;}
.detail .title-lat .py{font-style:normal;font-family:var(--font-sans);font-size:.85rem;letter-spacing:.06em;margin-left:10px;}
.lead{border-left:2px solid var(--gold);padding-left:var(--s-5);margin:var(--s-7) 0;}
.lead .zh{font-family:var(--font-serif-sc);font-size:var(--fs-lead);line-height:1.5;color:var(--ink);margin:0;}
.lead .en{font-family:var(--font-garamond);font-style:italic;font-size:1.06rem;color:var(--ink-3);margin:.6rem 0 0;}

.block{margin-top:var(--s-8);}
.block h3{display:flex;align-items:center;gap:12px;font-family:var(--font-sans);font-weight:600;font-size:var(--fs-h3);
  color:var(--ink);margin:0 0 var(--s-4);letter-spacing:.02em;}
.block h3::before{content:"";width:18px;height:1px;background:var(--gold);flex:none;}
.block h3 .en{font-family:var(--font-garamond);font-style:italic;font-weight:400;color:var(--ink-3);font-size:.98rem;letter-spacing:.02em;}
.block h3 .hint{margin-left:auto;font-family:var(--font-sans);font-weight:400;font-size:.76rem;color:var(--ink-3);}
.block p.body{margin:0;color:var(--ink-2);}
.block p.body .en{display:block;font-family:var(--font-garamond);font-style:italic;color:var(--ink-3);font-size:1rem;margin-top:6px;}

/* 色卡 */
.swatches{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s-3);}
.swatch{border:var(--hair) solid var(--hairline);border-radius:var(--r-control);overflow:hidden;text-align:left;
  transition:transform var(--dur) var(--ease-standard),box-shadow var(--dur);}
.swatch:hover{transform:translateY(-2px);box-shadow:var(--lift);}
.swatch .blk{height:56px;}
.swatch .info{background:var(--paper-deep);padding:8px 10px;}
.swatch .info .nm{font-family:var(--font-serif-sc);font-size:.86rem;color:var(--ink);display:block;}
.swatch .info .hx{font-family:var(--font-mono);font-size:var(--fs-mono);letter-spacing:var(--ls-mono);color:var(--ink-3);
  text-transform:uppercase;display:flex;align-items:center;gap:6px;margin-top:2px;}
.swatch.copied .hx::after{content:"✓ 已复制";color:var(--celadon-deep);}
[data-theme=dark] .swatch.copied .hx::after{color:var(--celadon);}
/* 降级态: 无 hex 的色名 */
.swatch.degraded{cursor:default;border-style:dashed;}
.swatch.degraded:hover{transform:none;box-shadow:none;}
.swatch.degraded .blk{display:none;}
.swatch.degraded .info{background:transparent;}
.swatch.degraded .hx{color:var(--ink-3);}
.swatch.degraded .hx::before{content:"未入词表 · label only";}

/* 关联 / 标签 */
.related{display:flex;flex-wrap:wrap;gap:var(--s-2);}
.rel{font-family:var(--font-serif-sc);font-size:.95rem;color:var(--ink);border:var(--hair) solid var(--hairline);
  border-radius:var(--r-chip);padding:6px 14px;transition:all var(--dur) var(--ease-standard);}
.rel:hover{border-color:var(--celadon);color:var(--celadon-deep);}
[data-theme=dark] .rel:hover{color:var(--celadon);}
.rel.plain{color:var(--ink-3);border-style:dashed;cursor:default;}
.rel.plain:hover{border-color:var(--hairline);color:var(--ink-3);}
.tags{display:flex;flex-wrap:wrap;gap:14px;}
.tag{font-family:var(--font-sans);font-size:var(--fs-meta);color:var(--ink-3);}
.tag::before{content:"#";color:var(--gold);}

.attribution{margin-top:var(--s-9);padding-top:var(--s-5);border-top:var(--hair) solid var(--hairline);
  font-family:var(--font-sans);font-size:.8rem;color:var(--ink-3);line-height:1.6;}

/* —— 详情档案面板 (藏品档案式) —— */
.dossier{position:relative;border:var(--hair) solid var(--hairline);border-radius:var(--r-card);
  background:color-mix(in srgb,var(--paper) 55%,transparent);box-shadow:var(--lift);
  padding:clamp(20px,2.8vw,38px);}
.dossier::before{content:"";position:absolute;inset:6px;border:1px solid var(--frame);border-radius:2px;pointer-events:none;opacity:.55;}
.dossier>*{position:relative;}
.seal-stamp{position:absolute;top:clamp(20px,2.8vw,38px);right:clamp(20px,2.8vw,38px);z-index:2;
  width:58px;height:58px;border:1.5px solid var(--cinnabar);border-radius:5px;
  display:grid;grid-template-columns:1fr 1fr;place-items:center;padding:6px;
  color:var(--cinnabar);font-family:var(--font-serif-sc);font-weight:600;font-size:.94rem;line-height:1;
  background:color-mix(in srgb,var(--cinnabar) 8%,transparent);}
.dossier-head{padding-right:76px;}
.meta-list{display:grid;gap:8px;margin-top:18px;padding-top:16px;border-top:var(--hair) solid var(--hairline);}
.meta-list>div{display:grid;grid-template-columns:86px 1fr;gap:14px;align-items:baseline;}
.meta-list dt{margin:0;font-family:var(--font-sans);font-size:.78rem;color:var(--ink-3);letter-spacing:.04em;}
.meta-list dd{margin:0;font-family:var(--font-serif-body);font-size:.93rem;color:var(--ink-2);line-height:1.5;}
.meta-list dd.mono{font-family:var(--font-mono);letter-spacing:.04em;}
.dossier-body{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-7);margin-top:var(--s-7);}
.dossier-body .block{margin-top:0;}
.block.span2{grid-column:1 / -1;}
ul.feat{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:8px;}
ul.feat li{position:relative;padding-left:16px;color:var(--ink-2);font-size:1rem;line-height:1.5;}
ul.feat li::before{content:"";position:absolute;left:0;top:.62em;width:5px;height:5px;background:var(--celadon);border-radius:1px;}

/* 上一则 / 下一则 */
.pager{display:flex;justify-content:space-between;gap:var(--s-5);margin-top:var(--s-10);
  border-top:var(--hair) solid var(--hairline);padding-top:var(--s-6);}
.pager a{display:flex;align-items:center;gap:14px;flex:1;transition:opacity var(--dur);}
.pager a.next{flex-direction:row-reverse;text-align:right;}
.pager a:hover{opacity:.66;}
.pager .pthumb{width:54px;aspect-ratio:var(--card-ratio);border:var(--hair) solid var(--frame);border-radius:2px;object-fit:cover;flex:none;background:var(--paper-deep);}
.pager .pl{font-family:var(--font-sans);font-size:.72rem;color:var(--ink-3);letter-spacing:.12em;text-transform:uppercase;}
.pager .pn{font-family:var(--font-serif-sc);color:var(--ink);font-size:1rem;}
.pager a.disabled{opacity:.3;pointer-events:none;}
.kbd-hint{margin:var(--s-5) 0 0;font-family:var(--font-sans);font-size:.78rem;color:var(--ink-3);text-align:center;}
.kbd-hint kbd{font-family:var(--font-mono);font-size:.72rem;color:var(--ink-2);border:var(--hair) solid var(--hairline);
  border-radius:3px;padding:1px 7px;margin:0 1px;background:var(--paper-deep);}

/* ── 空状态 / 关于 ─────────────────────────────────── */
.empty{text-align:center;padding-block:var(--s-12);}
.empty .seal{margin:0 auto var(--s-6);}
.empty .big{font-family:var(--font-serif-sc);font-size:1.4rem;color:var(--ink);margin:0 0 8px;}
.empty .small{font-family:var(--font-garamond);font-style:italic;color:var(--ink-3);}
.about{padding-block:var(--s-9) var(--s-12);max-width:680px;}
.about h2{font-family:var(--font-serif-sc);font-weight:700;font-size:var(--fs-h2);color:var(--ink);margin:0 0 var(--s-3);}
.about .sub{font-family:var(--font-garamond);font-style:italic;color:var(--ink-3);font-size:1.2rem;margin:0 0 var(--s-7);}
.about p{color:var(--ink-2);margin:0 0 var(--s-5);}
.about .lic{margin-top:var(--s-7);padding-top:var(--s-5);border-top:var(--hair) solid var(--hairline);}
.about a.link{color:var(--gold);border-bottom:1px solid color-mix(in srgb,var(--gold) 45%,transparent);}
.about a.link:hover{color:var(--celadon-deep);}

/* 印章 */
.seal{width:54px;height:54px;border:1.5px solid var(--cinnabar);border-radius:5px;display:grid;place-items:center;
  color:var(--cinnabar);font-family:var(--font-serif-sc);font-weight:600;font-size:1.7rem;
  background:color-mix(in srgb,var(--cinnabar) 7%,transparent);}

/* ── 页脚 ──────────────────────────────────────────── */
.site-foot{border-top:var(--hair) solid var(--hairline);padding-block:var(--s-7);margin-top:var(--s-6);background:var(--paper-deep);}
.site-foot .row{display:flex;align-items:center;justify-content:space-between;gap:var(--s-5);flex-wrap:wrap;}
.site-foot .meta{font-size:.78rem;}
.foot-end{display:flex;align-items:center;gap:var(--s-5);flex-wrap:wrap;}
.foot-social{display:inline-flex;gap:4px;}
.site-foot .brandline{font-family:var(--font-serif-sc);color:var(--ink-2);letter-spacing:.06em;}

/* ── Toast ─────────────────────────────────────────── */
.toast-host{position:fixed;left:50%;bottom:34px;transform:translateX(-50%);z-index:90;display:flex;flex-direction:column;gap:10px;align-items:center;pointer-events:none;}
.toast{background:var(--paper-deep);color:var(--ink);border:var(--hair) solid var(--hairline);box-shadow:var(--lift);
  border-radius:var(--r-control);padding:11px 18px;font-family:var(--font-sans);font-size:var(--fs-meta);
  display:flex;align-items:center;gap:10px;animation:toastIn .3s var(--ease-standard);}
.toast .dot{width:13px;height:13px;border-radius:3px;flex:none;border:1px solid var(--frame);}
.toast .hx{font-family:var(--font-mono);font-size:var(--fs-mono);letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3);}
@keyframes toastIn{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}
.toast.out{animation:toastOut .3s var(--ease-exit) forwards;}
@keyframes toastOut{to{opacity:0;transform:translateY(8px);}}

/* ── Lightbox ──────────────────────────────────────── */
.lightbox{position:fixed;inset:0;z-index:100;background:var(--scrim);display:grid;place-items:center;padding:5vh;
  opacity:0;animation:fadeIn var(--dur) var(--ease-standard) forwards;cursor:zoom-out;}
@keyframes fadeIn{to{opacity:1;}}
.lightbox img{max-height:90vh;max-width:90vw;border-radius:var(--r-card);box-shadow:0 30px 80px rgba(0,0,0,.5);}
.lightbox .x{position:absolute;top:24px;right:28px;color:#F4E9DC;font-size:1.6rem;}

/* ── 共享元素转场 ──────────────────────────────────── */
::view-transition-old(pattern-img),::view-transition-new(pattern-img){
  animation-duration:var(--dur-page);animation-timing-function:var(--ease-standard);}

/* ── 加载更多（画廊分组加载）── */
.load-more{display:flex;flex-direction:column;align-items:center;gap:12px;padding:36px 0 12px;}
.load-more .lm-count{font-family:var(--font-sans);font-size:var(--fs-meta);color:var(--ink-3);letter-spacing:.05em;}
.load-more .lm-btn{min-width:160px;justify-content:center;}

/* ── 响应式 ────────────────────────────────────────── */
@media (max-width:860px){
  .detail-grid{grid-template-columns:1fr;}
  .detail-img{position:static;max-width:360px;}
  .swatches{grid-template-columns:repeat(2,1fr);}
  .dossier-body{grid-template-columns:1fr;}
  .dossier{padding:22px 18px;}
  .dossier-head{padding-right:66px;}
}
@media (max-width:600px){
  .hero{padding-block:36px var(--s-6);}
  .nav .hide-sm{display:none;}              /* 隐藏 首页/专题/收藏/关于 文字链；GitHub·X 已显示 */
  .nav .search{display:none;}               /* 手机端去掉搜索框（避免拥挤）；如需可改回放大镜图标点开 */
  .brand{min-width:0;}
  .brand .mark-lat{display:none;}
  .brand .mark{display:none;}   /* 手机端仅留 LOGO，站名见下方大标题 */
  .brand-logo{width:44px;height:44px;}
  /* 顶栏单行：LOGO+站名 在左，语言/主题/GitHub/X 一排在右 */
  .site-head .row{height:62px;gap:var(--s-3);}
  .nav{flex:none;gap:7px;}
  .seg-btn{padding:6px 9px;}
  .filter{position:static;top:auto;}        /* 顶栏定高，筛选带随内容滚动，避免错位 */
  .site-foot .row{flex-direction:column;align-items:flex-start;gap:12px;}
}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.001ms!important;}
  .reveal{opacity:1!important;transform:none!important;}
}

/* 滚动入场 reveal */
.reveal{opacity:0;transform:translateY(24px);
  transition:opacity .6s var(--ease-standard),transform .7s var(--ease-standard);}
.reveal.in{opacity:1;transform:none;}
