/*
Theme Name: Han Nom Journal
Theme URI: https://hannom.vass.gov.vn
Author: Innocom.vn
Description: Giao diện chính thức của Tạp chí Hán Nôm — Viện Nghiên cứu Hán Nôm. Bộ thẩm mỹ "sách giấy hoá kỹ thuật số": triện son, vàng kim, typography Cormorant + Vollkorn + Noto Serif TC. Tích hợp với các mu-plugins workflow / citations / references / manuscript đã có sẵn.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: Proprietary
Text Domain: han-nom-journal
Tags: academic, journal, vietnamese, classic-editor, custom-colors
*/

/* =================================================================
   Tạp chí Hán Nôm — Design System
   Shared stylesheet cho tất cả mockup pages.
================================================================= */

:root{
  --paper:#F4EAD0;
  --paper-warm:#F8F0DA;
  --paper-dark:#E9DCB6;
  --ink:#1F1812;
  --ink-soft:#3A2F25;
  --muted:#7C6647;
  --wine:#7D2418;
  --wine-bright:#A0312A;
  --wine-deep:#5A1A11;
  --gold:#C29A5B;
  --gold-pale:#E8D49A;
  --gold-deep:#8C6A2E;
  --rule:#D6C49A;
  --rule-soft:#E6D6AF;
  --serif:'Vollkorn', 'Cormorant Garamond', Georgia, serif;
  --display:'Cormorant Garamond', 'Vollkorn', Georgia, serif;
  --cjk:'Noto Serif TC', 'Vollkorn', serif;
  --cjk-cal:'Ma Shan Zheng', 'Noto Serif TC', serif;
  --sans:'Inter', system-ui, sans-serif;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}

/* === Admin bar compatibility — không cho theme phá CSS admin bar === */
#wpadminbar, #wpadminbar *{box-sizing:content-box}
#wpadminbar ul, #wpadminbar ul li{list-style:none !important;margin:0;padding:0;background:transparent}
#wpadminbar a{color:#eee;text-decoration:none}
body.admin-bar{padding-top:0 !important}

body{
  background:var(--paper);
  background-image:
    radial-gradient(circle at 20% 10%, rgba(194,154,91,.04) 0, transparent 50%),
    radial-gradient(circle at 80% 80%, rgba(125,36,24,.03) 0, transparent 50%);
  color:var(--ink);
  font-family:var(--serif);
  font-size:17px;line-height:1.65;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
.container{max-width:1240px;margin:0 auto;padding:0 36px}

/* === TOPBAR === */
.topbar{background:var(--wine-deep);color:#E8D49A;font-family:var(--sans);font-size:12px;letter-spacing:.04em}
.topbar .container{display:flex;justify-content:space-between;align-items:center;height:36px}
.topbar a{color:#E8D49A;opacity:.85;margin-left:22px}
.topbar a:hover{opacity:1;color:#F8E8C8}
.topbar .left span{margin-right:14px;opacity:.7}
.topbar .menu-item{
  float:left;
  list-style:none;
}
/* === MASTHEAD === */
.masthead{padding:36px 0 28px;position:relative}
.masthead:before{content:'';position:absolute;left:0;right:0;bottom:0;height:1px;background:linear-gradient(90deg,transparent 0%,var(--gold) 30%,var(--gold) 70%,transparent 100%)}
.masthead .container{display:grid;grid-template-columns:130px 1fr auto;gap:38px;align-items:center}
.logo-shield{width:130px;height:auto;display:block;object-fit:contain}
.masthead-text h1{font-family:var(--display);font-weight:600;font-style:italic;font-size:54px;line-height:1;margin:0 0 8px;letter-spacing:.01em;color:var(--ink)}
.masthead-text h1 em{font-style:italic;color:var(--wine)}
.masthead-text h1 a{color:inherit}
.masthead-text .han-title{font-family:var(--cjk);font-size:28px;color:var(--wine);letter-spacing:.25em;font-weight:500;margin-bottom:4px;line-height:1}
.masthead-text .subtitle{font-family:var(--sans);font-size:12.5px;color:var(--muted);letter-spacing:.22em;text-transform:uppercase;font-weight:500}
.masthead-meta{text-align:right;font-family:var(--sans);font-size:12.5px;color:var(--muted);line-height:1.7;border-left:1px solid var(--rule);padding-left:28px}
.masthead-meta .issue-no{font-family:var(--display);font-style:italic;font-size:28px;color:var(--wine);font-weight:500;line-height:1}
.masthead-meta strong{color:var(--ink);font-weight:600}

/* === NAV === */
.nav{background:var(--wine);border-bottom:3px solid var(--gold-deep)}
.nav .container{display:flex;justify-content:space-between;align-items:center;height:54px}
.nav-links{display:flex;gap:0;font-family:var(--sans);font-size:13.5px;font-weight:500;letter-spacing:.05em;text-transform:uppercase}
.nav-links li{list-style:none}
.nav-links a{padding:18px 22px;color:#F4E4B5;position:relative;transition:background .15s}
.nav-links a:hover,.nav-links a.active{background:rgba(0,0,0,.18);color:#FFF4DA}
.nav-links a.active:after{content:'';position:absolute;left:22px;right:22px;bottom:-3px;height:3px;background:var(--gold-pale)}
.nav-actions{display:flex;gap:14px;align-items:center}
/* Scope chặt vào .nav để KHÔNG đụng tới body.search (WP body_class) */
.nav .search{display:flex;align-items:center;gap:8px;background:rgba(0,0,0,.18);border:1px solid rgba(232,212,154,.25);border-radius:1px;padding:7px 12px;font-size:13px;width:220px;color:#F4E4B5}
.nav .search input{border:0;background:transparent;outline:none;flex:1;font-family:var(--sans);font-size:13px;color:#F4E4B5}
.nav .search input::placeholder{color:rgba(244,228,181,.5)}

/* === BREADCRUMB === */
.breadcrumb{font-family:var(--sans);font-size:12px;color:var(--muted);letter-spacing:.04em;padding:24px 0 0}
.breadcrumb a{color:var(--muted)}
.breadcrumb a:hover{color:var(--wine)}
.breadcrumb .sep{margin:0 10px;color:var(--rule)}

/* === SECTION === */
.section{padding:56px 0;position:relative}
.section + .section{border-top:1px solid var(--rule-soft)}
.section-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:42px;padding-bottom:18px;border-bottom:2px solid var(--ink)}
.section-title{font-family:var(--display);font-weight:500;font-style:italic;font-size:38px;margin:0;color:var(--ink);letter-spacing:-.005em;display:flex;align-items:baseline;gap:18px}
.section-title .cjk-mark{font-family:var(--cjk-cal);font-style:normal;color:var(--wine);font-size:30px;font-weight:500;letter-spacing:.1em}
.section-link{font-family:var(--sans);font-size:12px;color:var(--wine);font-weight:600;letter-spacing:.16em;text-transform:uppercase;padding-bottom:4px;border-bottom:1px solid var(--wine)}
.section-link:hover{color:var(--wine-deep);border-color:var(--wine-deep)}

/* === BUTTONS === */
.btn{display:inline-flex;align-items:center;gap:8px;padding:11px 22px;font-family:var(--sans);font-size:13px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;border-radius:1px;cursor:pointer;border:0}
.btn-wine{background:var(--wine);color:var(--gold-pale)}
.btn-wine:hover{background:var(--wine-deep)}
.btn-ghost{background:transparent;color:var(--wine);border:1px solid var(--wine)}
.btn-ghost:hover{background:var(--wine);color:var(--gold-pale)}
.btn-gold{background:var(--gold-pale);color:var(--wine-deep);border:1px solid var(--gold-deep)}
.btn-gold:hover{background:#FFEBB8}

/* === CLOUD DIVIDER === */
.cloud-divider{padding:40px 0;display:flex;justify-content:center}
.cloud-divider svg{height:32px;color:var(--gold)}

/* === FOOTER === */
footer{background:#1A130D;color:#C9B894;padding:72px 0 36px;font-family:var(--sans);font-size:13.5px;position:relative;margin-top:80px}
footer:before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--wine) 0%,var(--gold) 50%,var(--wine) 100%)}
footer .footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:56px;margin-bottom:56px}
footer h6{font-family:var(--display);color:#F4E4B5;margin:0 0 18px;font-size:18px;font-weight:600;letter-spacing:.03em}
footer ul{list-style:none;padding:0;margin:0;line-height:2.2}
footer ul a:hover{color:#F4E4B5}
footer .brand .han-mark{font-family:var(--cjk-cal);color:var(--gold-pale);font-size:48px;letter-spacing:.1em;line-height:1;margin-bottom:14px;display:inline-block}
footer .brand p{font-size:13.5px;color:#9C8868;line-height:1.7;margin:8px 0 0;max-width:300px}
footer .bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:28px;display:flex;justify-content:space-between;color:#7E6E55;font-size:12px;letter-spacing:.04em}

/* =================================================================
   ARTICLE PAGE
================================================================= */
.article-hero{padding:56px 0 32px;border-bottom:1px solid var(--rule);background:linear-gradient(180deg,var(--paper) 0%,var(--paper-warm) 100%)}
.article-hero .container{max-width:920px}
.article-eyebrow{font-family:var(--sans);font-size:11.5px;letter-spacing:.32em;text-transform:uppercase;color:var(--wine);font-weight:600;display:flex;align-items:center;gap:14px;margin-bottom:22px}
.article-eyebrow:before{content:'';width:36px;height:1px;background:var(--wine)}
.article-eyebrow .cjk{font-family:var(--cjk-cal);font-size:18px;letter-spacing:.08em;text-transform:none;font-weight:500}
.article-han{font-family:var(--cjk-cal);font-size:34px;color:var(--wine);margin-bottom:24px;letter-spacing:.06em;line-height:1.1}
.article-title{font-family:var(--display);font-weight:500;font-style:italic;font-size:48px;line-height:1.15;margin:0 0 26px;color:var(--ink);letter-spacing:-.005em}
.article-title em{font-style:italic;color:var(--ink-soft)}
.article-byline{font-family:var(--sans);font-size:14px;color:var(--ink-soft);line-height:1.6;padding-top:22px;border-top:1px solid var(--rule)}
.article-byline .authors{color:var(--ink);font-weight:600;font-size:15px;margin-bottom:4px}
.article-byline .meta-row{display:flex;flex-wrap:wrap;gap:18px;color:var(--muted);font-size:12.5px;margin-top:10px}
.article-byline .meta-row strong{color:var(--ink-soft);font-weight:500}
.article-byline .meta-row .sep{color:var(--rule)}

.article-layout{max-width:1240px;margin:0 auto;padding:48px 36px;display:grid;grid-template-columns:240px 1fr 280px;gap:48px;align-items:start}
.article-side{position:sticky;top:24px;font-family:var(--sans);font-size:13px}
.side-block{margin-bottom:36px}
.side-block h5{font-family:var(--sans);font-size:11px;color:var(--muted);letter-spacing:.22em;text-transform:uppercase;font-weight:600;margin:0 0 14px;padding-bottom:10px;border-bottom:1px solid var(--rule)}
.toc-list{list-style:none;padding:0;margin:0;font-size:13.5px;line-height:1.55;color:var(--ink-soft)}
.toc-list li{padding:8px 0;border-bottom:1px dotted var(--rule)}
.toc-list li:last-child{border-bottom:0}
.toc-list a{color:var(--ink-soft);display:flex;gap:10px}
.toc-list a:hover{color:var(--wine)}
.toc-list .num{color:var(--wine);font-family:var(--cjk);font-weight:500;flex-shrink:0;width:20px}
.toc-list .active a{color:var(--wine);font-weight:500}

.share-row{display:flex;gap:8px;margin-top:6px}
.share-row a{width:36px;height:36px;border:1px solid var(--rule);border-radius:1px;display:flex;align-items:center;justify-content:center;color:var(--ink-soft);transition:all .15s}
.share-row a:hover{background:var(--wine);color:var(--gold-pale);border-color:var(--wine)}

/* === Main article body === */
.article-body{font-family:var(--serif);font-size:18px;line-height:1.78;color:var(--ink)}
.article-body > * + *{margin-top:1.2em}
.article-body p{margin:0 0 1.2em;text-align:justify;hyphens:auto}
.article-body p:first-of-type::first-letter{font-family:var(--display);font-weight:600;font-style:normal;font-size:82px;float:left;line-height:.85;padding:8px 14px 0 0;color:var(--wine)}
.article-body h2{font-family:var(--display);font-weight:500;font-style:italic;font-size:32px;margin:48px 0 22px;color:var(--ink);letter-spacing:-.005em;padding-bottom:12px;border-bottom:1px solid var(--rule)}
.article-body h2 .cjk-mark{font-family:var(--cjk-cal);font-style:normal;color:var(--wine);font-size:24px;margin-left:14px;font-weight:500;letter-spacing:.1em}
.article-body h3{font-family:var(--display);font-weight:500;font-size:24px;margin:32px 0 16px;color:var(--ink-soft)}
.article-body blockquote{margin:32px 0;padding:24px 32px;background:var(--paper-warm);border-left:3px solid var(--wine);font-family:var(--display);font-style:italic;font-size:20px;line-height:1.6;color:var(--ink-soft)}
.article-body blockquote.han{font-family:var(--cjk);font-style:normal;font-size:24px;letter-spacing:.15em;text-align:center;color:var(--ink);background:transparent;border:0;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);padding:32px 0;margin:40px 0}
.article-body blockquote.han .trans{display:block;font-family:var(--display);font-style:italic;font-size:16px;color:var(--muted);margin-top:14px;letter-spacing:0}
/* === Cước chú: superscript + popover === */
.article-body sup.fn-ref{display:inline-block;line-height:1}
.article-body sup.fn-ref a{
  display:inline-block;color:var(--wine);font-family:var(--sans);font-weight:700;
  font-size:11px;vertical-align:.45em;padding:0 4px;margin:0 1px;
  border-radius:2px;background:rgba(125,36,24,.08);
  text-decoration:none;cursor:pointer;transition:all .12s;
}
.article-body sup.fn-ref a:hover{background:var(--wine);color:var(--gold-pale)}
.article-body sup.fn-ref a:focus-visible{outline:2px solid var(--wine);outline-offset:1px}

/* In-text parenthetical citation (Pattern B / C) */
.article-body .cite-inline{
  display:inline;color:var(--wine-deep);font-family:var(--sans);font-size:.86em;
  font-weight:500;letter-spacing:.01em;cursor:help;
  border-bottom:1px dotted var(--wine);
}
.article-body .cite-inline:hover{color:var(--wine);background:rgba(125,36,24,.06)}

/* Popover (hiển thị footnote tại chỗ khi hover/click) */
.fn-popover{
  position:absolute;z-index:1000;
  width:340px;max-width:90vw;
  background:#FFFDF7;border:1px solid var(--rule);
  border-top:3px solid var(--wine);
  box-shadow:0 4px 28px rgba(31,24,18,.18), 0 1px 2px rgba(31,24,18,.06);
  padding:16px 20px;
  font-family:var(--serif);font-size:14px;line-height:1.65;color:var(--ink-soft);
  border-radius:2px;
  animation:fnFadeIn .15s ease-out;
}
@keyframes fnFadeIn{
  from{opacity:0;transform:translateY(-4px)}
  to{opacity:1;transform:translateY(0)}
}
.fn-popover:before{
  content:'';position:absolute;top:-7px;left:24px;
  width:10px;height:10px;background:var(--wine);
  transform:rotate(45deg);border-radius:1px;
}
.fn-popover .label{
  font-family:var(--sans);font-size:10.5px;color:var(--wine);
  letter-spacing:.22em;text-transform:uppercase;font-weight:600;
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:10px;padding-bottom:8px;border-bottom:1px dotted var(--rule);
}
.fn-popover .label .han{font-family:var(--cjk);letter-spacing:.12em;text-transform:none}
.fn-popover .body{color:var(--ink-soft)}
.fn-popover .body em{font-style:italic;color:var(--ink)}
.fn-popover .actions{
  margin-top:12px;padding-top:10px;border-top:1px dotted var(--rule);
  display:flex;justify-content:space-between;align-items:center;
  font-family:var(--sans);font-size:11.5px;
}
.fn-popover .actions a{color:var(--wine);letter-spacing:.04em;font-weight:500}
.fn-popover .actions a:hover{text-decoration:underline}
.fn-popover .close{
  background:none;border:0;color:var(--muted);font-size:18px;
  width:20px;height:20px;line-height:1;cursor:pointer;padding:0;
}
.fn-popover .close:hover{color:var(--wine)}

/* Backlink trong footnote */
.footnotes li .back{
  display:inline-block;margin-left:6px;color:var(--wine);
  font-family:var(--sans);font-size:11px;font-weight:600;
  text-decoration:none;letter-spacing:.04em;
}
.footnotes li .back:hover{text-decoration:underline}
.footnotes li:target{background:rgba(232,212,154,.4);transition:background 1.5s ease-out}
.article-body figure{margin:36px 0;padding:0}
.article-body figure img{width:100%;border:1px solid var(--rule);border-radius:2px;display:block}
.article-body figcaption{font-family:var(--sans);font-size:13px;color:var(--muted);line-height:1.55;margin-top:12px;padding-left:18px;border-left:2px solid var(--gold);font-style:italic}
.article-body .han-quote{
  display:block;text-align:center;font-family:var(--cjk-cal);font-size:42px;color:var(--wine);
  letter-spacing:.18em;line-height:1.4;margin:48px 0;
}

/* Abstract box */
.abstract-box{background:#FFFAEC;border:1px solid var(--rule);border-left:4px solid var(--wine);padding:28px 32px;margin:32px 0;font-family:var(--serif);font-size:16px;line-height:1.7}
.abstract-box .label{font-family:var(--sans);font-size:11px;color:var(--wine);font-weight:600;letter-spacing:.22em;text-transform:uppercase;display:flex;align-items:baseline;gap:12px;margin-bottom:12px}
.abstract-box .label .cjk{font-family:var(--cjk);font-size:14px;color:var(--wine);letter-spacing:.15em;text-transform:none}
.abstract-box p{margin:0;color:var(--ink-soft)}
.abstract-box .keywords{margin-top:16px;font-family:var(--sans);font-size:12.5px;color:var(--muted);padding-top:14px;border-top:1px dotted var(--rule)}
.abstract-box .keywords strong{color:var(--ink-soft);font-weight:600;margin-right:8px}
.abstract-box .keywords .tag{display:inline-block;background:var(--paper-warm);border:1px solid var(--rule);padding:2px 10px;border-radius:1px;margin:0 4px 4px 0;color:var(--ink-soft)}

/* Footnotes */
.footnotes{margin-top:64px;padding-top:32px;border-top:2px solid var(--ink);font-family:var(--serif);font-size:14px;line-height:1.7}
.footnotes h3{font-family:var(--display);font-style:italic;font-size:24px;color:var(--ink);margin:0 0 18px}
.footnotes ol{padding-left:0;list-style:none;counter-reset:fn}
.footnotes li{position:relative;padding-left:32px;margin-bottom:12px;color:var(--ink-soft);counter-increment:fn}
.footnotes li:before{content:counter(fn);position:absolute;left:0;top:0;color:var(--wine);font-weight:600;font-family:var(--sans);font-size:12px;width:24px;text-align:right}

/* References */
.references{margin-top:48px;padding-top:32px;border-top:1px solid var(--rule);font-family:var(--serif);font-size:14.5px;line-height:1.75}
.references h3{font-family:var(--display);font-style:italic;font-size:24px;color:var(--ink);margin:0 0 18px}
.references ol{padding-left:24px}
.references li{margin-bottom:14px;color:var(--ink-soft)}
.references em{color:var(--ink-soft)}

/* Right side: citation, related */
.cite-card{background:#fff;border:1px solid var(--rule);border-radius:2px;padding:20px 22px;font-family:var(--sans);font-size:13px;line-height:1.55}
.cite-card h5{margin:0 0 12px;font-family:var(--display);font-style:italic;font-size:18px;color:var(--ink);font-weight:600}
.cite-tabs{display:flex;gap:0;margin-bottom:14px;border-bottom:1px solid var(--rule)}
.cite-tabs a{flex:1;padding:8px 0;text-align:center;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:600;border-bottom:2px solid transparent}
.cite-tabs a.active{color:var(--wine);border-color:var(--wine)}
.cite-text{font-size:12.5px;line-height:1.65;color:var(--ink-soft);font-family:var(--serif);background:var(--paper-warm);padding:14px;border:1px dotted var(--rule);max-height:160px;overflow-y:auto}
.cite-actions{margin-top:12px;display:flex;gap:8px}
.cite-actions a{flex:1;text-align:center;padding:7px;font-size:11px;letter-spacing:.1em;text-transform:uppercase;border:1px solid var(--rule);color:var(--ink-soft)}
.cite-actions a:hover{background:var(--paper-warm)}

.related-card h5{font-family:var(--sans);font-size:11px;color:var(--muted);letter-spacing:.22em;text-transform:uppercase;font-weight:600;margin:0 0 14px;padding-bottom:10px;border-bottom:1px solid var(--rule)}
.related-list{list-style:none;padding:0;margin:0}
.related-list li{padding:12px 0;border-bottom:1px dotted var(--rule);font-size:14px;line-height:1.45}
.related-list li:last-child{border-bottom:0}
.related-list .cat{font-family:var(--sans);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-deep);font-weight:600}
.related-list a{display:block;color:var(--ink-soft);font-family:var(--display);font-weight:500;margin-top:4px}
.related-list a:hover{color:var(--wine)}

/* =================================================================
   ARCHIVE PAGE
================================================================= */
.archive-hero{padding:64px 0 48px;background:linear-gradient(180deg,var(--paper) 0%,var(--paper-warm) 100%);border-bottom:1px solid var(--rule);position:relative;overflow:hidden}
.archive-hero:before{content:'庫';position:absolute;right:-60px;top:-40px;font-family:var(--cjk-cal);font-size:380px;color:var(--wine);opacity:.05;line-height:1;pointer-events:none}
.archive-hero .container{position:relative;max-width:920px}
.archive-hero h1{font-family:var(--display);font-style:italic;font-size:64px;margin:0 0 18px;color:var(--ink);font-weight:500}
.archive-hero .cjk-sub{font-family:var(--cjk-cal);font-size:32px;color:var(--wine);letter-spacing:.1em;margin-bottom:24px}
.archive-hero p{font-size:18px;line-height:1.7;color:var(--ink-soft);max-width:620px;margin:0}
.archive-stats{display:flex;gap:48px;margin-top:36px;padding-top:32px;border-top:1px solid var(--rule);font-family:var(--sans)}
.archive-stats .stat{display:flex;flex-direction:column;gap:4px}
.archive-stats .num{font-family:var(--display);font-style:italic;font-size:48px;color:var(--wine);line-height:1;font-weight:500}
.archive-stats .label{font-size:12px;color:var(--muted);letter-spacing:.16em;text-transform:uppercase;font-weight:600}

/* Timeline */
.timeline-section{padding:48px 0;border-bottom:1px solid var(--rule)}
.timeline-section h3{font-family:var(--display);font-style:italic;font-size:24px;margin:0 0 24px;color:var(--ink);display:flex;align-items:baseline;gap:14px}
.timeline-section h3 .cjk{font-family:var(--cjk-cal);color:var(--wine);font-size:20px;font-style:normal;letter-spacing:.1em}
.timeline{display:flex;gap:6px;align-items:flex-end;overflow-x:auto;padding:8px 0;font-family:var(--sans)}
.timeline-bar{flex:1;min-width:22px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:8px}
.timeline-bar .bar{width:100%;background:var(--gold);min-height:6px;border-radius:1px 1px 0 0;transition:background .15s}
.timeline-bar:hover .bar{background:var(--wine)}
.timeline-bar.active .bar{background:var(--wine)}
.timeline-bar .year{font-size:10px;color:var(--muted);transform:rotate(-50deg);transform-origin:left;white-space:nowrap;margin-top:6px;letter-spacing:.04em}
.timeline-bar.active .year{color:var(--wine);font-weight:600}
.timeline-bar.decade .year{color:var(--ink);font-weight:600}

/* Filters */
.archive-filters{padding:32px 0;border-bottom:1px solid var(--rule);font-family:var(--sans);background:var(--paper-warm)}
.archive-filters .container{display:flex;gap:32px;align-items:center;flex-wrap:wrap}
.filter-label{font-size:11.5px;color:var(--muted);letter-spacing:.22em;text-transform:uppercase;font-weight:600}
.filter-tags{display:flex;gap:8px;flex-wrap:wrap}
.filter-tags a{padding:6px 14px;border:1px solid var(--rule);background:#fff;border-radius:1px;font-size:13px;color:var(--ink-soft);transition:all .15s}
.filter-tags a:hover{border-color:var(--wine);color:var(--wine)}
.filter-tags a.active{background:var(--wine);color:var(--gold-pale);border-color:var(--wine)}
.filter-tags a .han{font-family:var(--cjk);color:var(--gold-deep);margin-right:6px;font-size:12px}
.filter-tags a.active .han{color:var(--gold-pale)}

/* Archive grid */
.archive-grid{padding:56px 0}
.archive-shelf{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;margin-bottom:48px}
.shelf-item{display:flex;flex-direction:column;gap:14px}
.shelf-cover{aspect-ratio:3/4;background:linear-gradient(168deg,#FBF3DC 0%,#E8D29A 100%);border:1px solid var(--gold-deep);border-radius:1px;display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding:24px 18px 20px;position:relative;box-shadow:0 1px 0 var(--gold-deep), 2px 4px 12px rgba(125,36,24,.08);transition:transform .2s}
.shelf-cover:hover{transform:translateY(-4px)}
.shelf-cover:before{content:'';position:absolute;inset:10px;border:1px solid rgba(140,106,46,.4);pointer-events:none}
.shelf-cover:after{content:'';position:absolute;top:16px;bottom:16px;left:50%;width:1px;background:rgba(140,106,46,.25);pointer-events:none}
.shelf-cover .han-vert{font-family:var(--cjk);font-size:22px;color:var(--wine);font-weight:700;letter-spacing:.42em;writing-mode:vertical-rl;flex:1;display:flex;align-items:center;line-height:1.2}
.shelf-cover .num{font-family:var(--display);font-size:24px;color:var(--ink);font-style:italic;font-weight:500}
.shelf-cover .mini-seal{position:absolute;top:18px;right:18px;width:22px;height:22px;background:var(--wine);color:var(--gold-pale);display:flex;align-items:center;justify-content:center;font-family:var(--cjk);font-size:10px;font-weight:700;border-radius:1px;line-height:1}
.shelf-info h6{margin:0 0 4px;font-family:var(--display);font-size:18px;font-weight:600;color:var(--ink)}
.shelf-info .date{font-family:var(--sans);font-size:12.5px;color:var(--muted);margin-bottom:8px;letter-spacing:.04em}
.shelf-info .feature{font-family:var(--serif);font-size:13.5px;line-height:1.45;color:var(--ink-soft);font-style:italic;padding-top:8px;border-top:1px dotted var(--rule)}
.shelf-info .pages{font-family:var(--sans);font-size:11.5px;color:var(--gold-deep);letter-spacing:.14em;text-transform:uppercase;margin-top:8px;font-weight:600}

.pagination{display:flex;justify-content:center;gap:6px;margin-top:48px;font-family:var(--sans);font-size:13.5px}
.pagination a{padding:10px 16px;border:1px solid var(--rule);color:var(--ink-soft);background:#fff;border-radius:1px;font-weight:500}
.pagination a:hover{border-color:var(--wine);color:var(--wine)}
.pagination a.active{background:var(--wine);color:var(--gold-pale);border-color:var(--wine)}
.pagination a.nav{font-weight:600;letter-spacing:.04em}

/* =================================================================
   SUBMIT PAGE
================================================================= */
.submit-hero{padding:64px 0 56px;background:linear-gradient(180deg,var(--paper) 0%,var(--paper-warm) 100%);border-bottom:1px solid var(--rule);position:relative;overflow:hidden}
.submit-hero:before{content:'投稿';position:absolute;right:-60px;top:-30px;font-family:var(--cjk-cal);font-size:300px;color:var(--wine);opacity:.05;line-height:1;pointer-events:none}
.submit-hero .container{max-width:1100px;display:grid;grid-template-columns:1.4fr 1fr;gap:64px;align-items:start;position:relative}
.submit-hero h1{font-family:var(--display);font-style:italic;font-size:54px;margin:0 0 18px;color:var(--ink);font-weight:500}
.submit-hero .cjk-sub{font-family:var(--cjk-cal);font-size:30px;color:var(--wine);letter-spacing:.1em;margin-bottom:24px}
.submit-hero .lead{font-size:18px;line-height:1.7;color:var(--ink-soft);margin:0}
.submit-hero .workflow{background:#fff;border:1px solid var(--rule);padding:24px 28px;font-family:var(--sans);font-size:13.5px}
.submit-hero .workflow h5{font-family:var(--display);font-style:italic;font-size:20px;margin:0 0 16px;color:var(--ink)}
.workflow-steps{list-style:none;padding:0;margin:0;counter-reset:wfs}
.workflow-steps li{position:relative;padding:10px 0 10px 38px;border-bottom:1px dotted var(--rule);counter-increment:wfs;color:var(--ink-soft);line-height:1.5}
.workflow-steps li:last-child{border-bottom:0}
.workflow-steps li:before{content:counter(wfs);position:absolute;left:0;top:10px;width:26px;height:26px;background:var(--wine);color:var(--gold-pale);font-family:var(--cjk);font-weight:700;display:flex;align-items:center;justify-content:center;border-radius:1px;font-size:13px}
.workflow-steps strong{color:var(--ink);font-weight:600;display:block;font-family:var(--display);font-size:16px;font-style:italic}

/* Form */
.submit-section{padding:56px 0}
.submit-section .container{max-width:1100px}

/* Step indicator */
.step-bar{display:flex;justify-content:space-between;margin-bottom:48px;font-family:var(--sans);position:relative}
.step-bar:before{content:'';position:absolute;top:24px;left:48px;right:48px;height:1px;background:var(--rule);z-index:0}
.step{display:flex;flex-direction:column;align-items:center;gap:10px;position:relative;z-index:1;flex:1;max-width:200px}
.step .dot{width:48px;height:48px;border-radius:50%;background:#fff;border:1px solid var(--rule);display:flex;align-items:center;justify-content:center;font-family:var(--display);font-style:italic;font-size:22px;color:var(--muted);font-weight:600}
.step .label{font-size:12px;color:var(--muted);letter-spacing:.14em;text-transform:uppercase;font-weight:600;text-align:center;line-height:1.4}
.step .han{font-family:var(--cjk);color:var(--muted);font-size:13px;margin-top:-4px;letter-spacing:.15em}
.step.done .dot{background:var(--gold-pale);border-color:var(--gold-deep);color:var(--wine-deep)}
.step.done .label, .step.done .han{color:var(--ink-soft)}
.step.active .dot{background:var(--wine);border-color:var(--wine);color:var(--gold-pale)}
.step.active .label{color:var(--wine);font-weight:600}
.step.active .han{color:var(--wine)}

.form-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:56px;align-items:start}
.form-main{background:#fff;border:1px solid var(--rule);padding:40px 44px}
.form-main h2{font-family:var(--display);font-style:italic;font-size:28px;margin:0 0 8px;color:var(--ink);font-weight:500}
.form-main .form-sub{font-family:var(--sans);font-size:13px;color:var(--muted);margin-bottom:32px}
.form-row{margin-bottom:22px}
.form-row label{display:block;font-family:var(--sans);font-size:12px;color:var(--ink-soft);letter-spacing:.12em;text-transform:uppercase;font-weight:600;margin-bottom:8px}
.form-row label .req{color:var(--wine);margin-left:4px}
.form-row label .hint{text-transform:none;letter-spacing:0;color:var(--muted);font-weight:400;font-size:12.5px;margin-left:8px;font-style:italic}
.form-row input,.form-row select,.form-row textarea{
  width:100%;font-family:var(--serif);font-size:16px;
  padding:11px 14px;border:1px solid var(--rule);background:var(--paper-warm);
  color:var(--ink);border-radius:1px;outline:none;transition:all .15s;
}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{border-color:var(--wine);background:#fff;box-shadow:0 0 0 1px var(--wine)}
.form-row textarea{resize:vertical;min-height:120px;line-height:1.6}
.form-cols-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form-upload{border:2px dashed var(--rule);background:var(--paper-warm);padding:32px;text-align:center;font-family:var(--sans);font-size:14px;color:var(--muted);cursor:pointer;transition:all .15s}
.form-upload:hover{border-color:var(--wine);background:#FFFAEC;color:var(--wine)}
.form-upload .dashicons,.form-upload svg{display:block;margin:0 auto 10px;color:var(--gold-deep)}
.form-upload strong{display:block;color:var(--ink);font-size:15px;font-weight:600;margin-bottom:4px}

.form-side h3{font-family:var(--display);font-style:italic;font-size:22px;margin:0 0 16px;color:var(--ink)}
.notice-box{background:var(--paper-warm);border-left:3px solid var(--wine);padding:18px 22px;font-family:var(--sans);font-size:13.5px;line-height:1.6;color:var(--ink-soft);margin-bottom:24px}
.notice-box strong{color:var(--ink);font-weight:600;display:block;margin-bottom:6px}
.checklist{list-style:none;padding:0;margin:0;font-family:var(--sans);font-size:13.5px;line-height:1.6}
.checklist li{padding:8px 0 8px 28px;position:relative;color:var(--ink-soft);border-bottom:1px dotted var(--rule)}
.checklist li:before{content:'✓';position:absolute;left:0;color:var(--wine);font-weight:700}
.checklist li:last-child{border-bottom:0}

.form-actions{display:flex;justify-content:space-between;align-items:center;margin-top:32px;padding-top:24px;border-top:1px solid var(--rule)}
.form-actions .save-draft{font-family:var(--sans);font-size:13px;color:var(--muted)}
.form-actions .save-draft a{color:var(--wine);text-decoration:underline;text-decoration-color:var(--rule)}

/* =================================================================
   ISSUE / TOC PAGE
================================================================= */
.issue-hero{padding:64px 0 48px;background:linear-gradient(180deg,var(--paper) 0%,var(--paper-warm) 100%);border-bottom:1px solid var(--rule);position:relative;overflow:hidden}
.issue-hero:before{content:'';position:absolute;top:-40px;right:-40px;width:360px;height:360px;background:radial-gradient(circle,rgba(125,36,24,.07) 0%,transparent 70%);pointer-events:none}
.issue-hero .container{display:grid;grid-template-columns:1fr 240px;gap:64px;align-items:center;position:relative}
.issue-hero .eyebrow{font-family:var(--sans);font-size:12px;letter-spacing:.32em;text-transform:uppercase;color:var(--wine);font-weight:600;margin-bottom:18px;display:flex;align-items:center;gap:14px}
.issue-hero .eyebrow:before{content:'';width:36px;height:1px;background:var(--wine)}
.issue-hero h1{font-family:var(--display);font-style:italic;font-size:58px;margin:0 0 12px;color:var(--ink);font-weight:500;line-height:1.05}
.issue-hero .han-sub{font-family:var(--cjk-cal);font-size:32px;color:var(--wine);letter-spacing:.15em;margin-bottom:24px}
.issue-hero .meta-row{font-family:var(--sans);font-size:13.5px;color:var(--ink-soft);display:flex;flex-wrap:wrap;gap:24px;padding-top:24px;border-top:1px solid var(--rule)}
.issue-hero .meta-row strong{color:var(--ink);font-weight:600;display:block;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
.issue-cover-big{aspect-ratio:3/4;background:linear-gradient(168deg,#FBF3DC 0%,#E8D29A 100%);border:1px solid var(--gold-deep);border-radius:1px;padding:28px 22px 24px;position:relative;box-shadow:0 1px 0 var(--gold-deep), 4px 6px 18px rgba(125,36,24,.12);display:flex;flex-direction:column;align-items:center;justify-content:space-between}
.issue-cover-big:before{content:'';position:absolute;inset:12px;border:1px solid rgba(140,106,46,.4);pointer-events:none}
.issue-cover-big:after{content:'';position:absolute;top:18px;bottom:18px;left:50%;width:1px;background:rgba(140,106,46,.25);pointer-events:none}
.issue-cover-big .mini-seal{position:absolute;top:18px;right:18px;width:26px;height:26px;background:var(--wine);color:var(--gold-pale);display:flex;align-items:center;justify-content:center;font-family:var(--cjk);font-size:11px;font-weight:700;border-radius:1px;line-height:1}
.issue-cover-big .han-vert{font-family:var(--cjk);font-size:26px;color:var(--wine);font-weight:700;letter-spacing:.5em;writing-mode:vertical-rl;flex:1;display:flex;align-items:center;line-height:1.2}
.issue-cover-big .num{font-family:var(--display);font-size:30px;color:var(--ink);font-style:italic;font-weight:500}

.editorial{padding:56px 0;background:var(--paper-warm);border-bottom:1px solid var(--rule)}
.editorial .container{max-width:900px;text-align:center}
.editorial .label{font-family:var(--sans);font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--wine);font-weight:600;margin-bottom:18px}
.editorial .han{font-family:var(--cjk-cal);font-size:42px;color:var(--wine);letter-spacing:.15em;margin-bottom:24px;line-height:1}
.editorial blockquote{font-family:var(--display);font-style:italic;font-size:26px;line-height:1.5;color:var(--ink);margin:0 0 24px;quotes:'"' '"'}
.editorial blockquote:before{content:'"';font-family:var(--display);font-size:64px;color:var(--gold);line-height:0;margin-right:6px;vertical-align:-18px}
.editorial blockquote:after{content:'"';font-family:var(--display);font-size:64px;color:var(--gold);line-height:0;margin-left:4px;vertical-align:-18px}
.editorial .signer{font-family:var(--sans);font-size:13px;color:var(--muted);letter-spacing:.04em}
.editorial .signer strong{color:var(--ink);font-weight:600;font-size:14px}

.toc-section{padding:64px 0}
.toc-block{margin-bottom:48px}
.toc-block h3{font-family:var(--display);font-style:italic;font-size:30px;margin:0 0 24px;color:var(--ink);font-weight:500;display:flex;align-items:baseline;gap:14px;padding-bottom:14px;border-bottom:2px solid var(--ink)}
.toc-block h3 .han{font-family:var(--cjk-cal);font-style:normal;color:var(--wine);font-size:24px;letter-spacing:.1em}
.toc-block h3 .count{margin-left:auto;font-family:var(--sans);font-size:13px;color:var(--muted);font-style:normal;letter-spacing:.04em;font-weight:500}
.toc-articles{display:flex;flex-direction:column;gap:24px}
.toc-article{display:grid;grid-template-columns:48px 1fr 120px;gap:24px;padding:22px 0;border-bottom:1px solid var(--rule)}
.toc-article:last-child{border-bottom:0}
.toc-article .num{font-family:var(--cjk-cal);font-size:36px;color:var(--wine);line-height:1;text-align:center;font-weight:500}
.toc-article h4{font-family:var(--display);font-weight:500;font-size:22px;line-height:1.3;margin:0 0 8px;color:var(--ink)}
.toc-article h4 a:hover{color:var(--wine)}
.toc-article h4 em{font-style:italic;color:var(--ink-soft)}
.toc-article .abstract{font-size:14.5px;line-height:1.65;color:var(--ink-soft);margin:0 0 10px}
.toc-article .meta{font-family:var(--sans);font-size:12.5px;color:var(--muted);display:flex;flex-wrap:wrap;gap:12px}
.toc-article .meta strong{color:var(--ink-soft);font-weight:600}
.toc-article .meta .sep{color:var(--rule)}
.toc-article .actions{text-align:right;font-family:var(--sans)}
.toc-article .actions .pages{font-size:11px;color:var(--muted);letter-spacing:.14em;text-transform:uppercase;font-weight:600;margin-bottom:8px}
.toc-article .actions .pdf-btn{display:inline-flex;align-items:center;gap:6px;background:var(--wine);color:var(--gold-pale);padding:7px 14px;font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;border-radius:1px}
.toc-article .actions .pdf-btn:hover{background:var(--wine-deep)}

/* =================================================================
   ABOUT PAGE
================================================================= */
.about-hero{padding:80px 0 64px;background:linear-gradient(180deg,var(--paper) 0%,var(--paper-warm) 100%);border-bottom:1px solid var(--rule);position:relative;overflow:hidden;text-align:center}
.about-hero:before{content:'承先啟後';position:absolute;top:-20px;left:50%;transform:translateX(-50%);font-family:var(--cjk-cal);font-size:280px;color:var(--wine);opacity:.05;line-height:1;pointer-events:none;letter-spacing:.08em;white-space:nowrap}
.about-hero .container{position:relative;max-width:820px}
.about-hero .eyebrow{font-family:var(--sans);font-size:11.5px;letter-spacing:.32em;text-transform:uppercase;color:var(--wine);font-weight:600;margin-bottom:18px}
.about-hero h1{font-family:var(--display);font-style:italic;font-size:64px;margin:0 0 18px;color:var(--ink);font-weight:500;line-height:1.05}
.about-hero .han-sub{font-family:var(--cjk-cal);font-size:40px;color:var(--wine);letter-spacing:.15em;margin-bottom:28px}
.about-hero .lead{font-size:20px;line-height:1.65;color:var(--ink-soft);margin:0}

.about-story{padding:80px 0;border-bottom:1px solid var(--rule)}
.about-story .container{max-width:780px}
.about-story h2{font-family:var(--display);font-style:italic;font-size:36px;margin:0 0 28px;color:var(--ink);font-weight:500;display:flex;align-items:baseline;gap:18px;padding-bottom:14px;border-bottom:2px solid var(--ink)}
.about-story h2 .han{font-family:var(--cjk-cal);font-style:normal;color:var(--wine);font-size:28px;letter-spacing:.1em}
.about-story p{font-size:17.5px;line-height:1.85;color:var(--ink-soft);margin:0 0 22px}
.about-story p:first-of-type::first-letter{font-family:var(--display);font-weight:600;font-size:72px;float:left;line-height:.85;padding:6px 12px 0 0;color:var(--wine)}
.about-story p em{font-style:italic;color:var(--ink)}

.about-numbers{padding:64px 0;background:var(--paper-warm);border-bottom:1px solid var(--rule)}
.numbers-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:48px}
.number-cell{text-align:center;padding:0 12px;position:relative}
.number-cell + .number-cell:before{content:'';position:absolute;left:-24px;top:20%;bottom:20%;width:1px;background:var(--rule)}
.number-cell .han{font-family:var(--cjk-cal);font-size:24px;color:var(--gold-deep);margin-bottom:8px;letter-spacing:.08em}
.number-cell .num{font-family:var(--display);font-style:italic;font-size:64px;color:var(--wine);line-height:1;font-weight:500;margin-bottom:8px}
.number-cell .label{font-family:var(--sans);font-size:12px;color:var(--ink-soft);letter-spacing:.18em;text-transform:uppercase;font-weight:600}

.editorial-board{padding:80px 0;border-bottom:1px solid var(--rule)}
.editorial-board .container{max-width:1100px}
.eb-group{margin-bottom:48px}
.eb-group h3{font-family:var(--display);font-style:italic;font-size:28px;margin:0 0 24px;color:var(--ink);font-weight:500;padding-bottom:12px;border-bottom:1px solid var(--rule);display:flex;align-items:baseline;gap:14px}
.eb-group h3 .han{font-family:var(--cjk-cal);font-style:normal;color:var(--wine);font-size:22px;letter-spacing:.1em}
.eb-list{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.eb-person{display:flex;gap:14px;align-items:start}
.eb-avatar{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#F4EAD0 0%,#D6C49A 100%);border:1px solid var(--gold-deep);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:var(--display);font-style:italic;font-size:24px;color:var(--wine);font-weight:500}
.eb-info{flex:1;font-family:var(--sans);font-size:13px;line-height:1.55}
.eb-info .name{font-family:var(--display);font-size:17px;color:var(--ink);font-weight:600;margin-bottom:3px}
.eb-info .role{color:var(--wine);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;margin-bottom:6px}
.eb-info .org{color:var(--muted);font-size:12.5px}

.indexing-strip{padding:56px 0;background:#fff;border-bottom:1px solid var(--rule);text-align:center}
.indexing-strip h3{font-family:var(--display);font-style:italic;font-size:22px;margin:0 0 8px;color:var(--ink);font-weight:500}
.indexing-strip p{font-family:var(--sans);font-size:13px;color:var(--muted);margin:0 0 32px}
.indexing-list{display:flex;justify-content:center;gap:48px;flex-wrap:wrap;align-items:center}
.indexing-list .item{font-family:var(--display);font-style:italic;font-size:24px;color:var(--ink-soft);font-weight:500;letter-spacing:.04em;border:1px solid var(--rule);padding:14px 28px;background:var(--paper-warm);border-radius:2px}

/* =================================================================
   CATEGORY PAGE
================================================================= */
.cat-hero{padding:72px 0 56px;background:linear-gradient(180deg,var(--paper) 0%,var(--paper-warm) 100%);border-bottom:1px solid var(--rule);position:relative;overflow:hidden}
.cat-hero:before{content:'';position:absolute;right:-80px;top:-40px;font-size:340px;font-family:var(--cjk-cal);color:var(--wine);opacity:.06;line-height:1;pointer-events:none}
.cat-hero[data-han]:before{content:attr(data-han)}
.cat-hero .container{position:relative;max-width:920px}
.cat-hero .eyebrow{font-family:var(--sans);font-size:11.5px;letter-spacing:.32em;text-transform:uppercase;color:var(--wine);font-weight:600;margin-bottom:18px}
.cat-hero h1{font-family:var(--display);font-style:italic;font-size:64px;margin:0 0 8px;color:var(--ink);font-weight:500;line-height:1}
.cat-hero .han-sub{font-family:var(--cjk-cal);font-size:38px;color:var(--wine);letter-spacing:.15em;margin-bottom:24px}
.cat-hero .desc{font-size:18px;line-height:1.7;color:var(--ink-soft);margin:0 0 28px;max-width:680px}
.cat-hero .stats{font-family:var(--sans);font-size:13.5px;color:var(--muted);display:flex;gap:32px;padding-top:24px;border-top:1px solid var(--rule)}
.cat-hero .stats strong{color:var(--wine);font-family:var(--display);font-style:italic;font-size:24px;font-weight:500;line-height:1;display:block}

.cat-filter{padding:28px 0;background:var(--paper-warm);border-bottom:1px solid var(--rule)}
.cat-filter .container{display:flex;gap:24px;align-items:center;flex-wrap:wrap;font-family:var(--sans);font-size:13px}
.cat-filter .label{font-size:11.5px;color:var(--muted);letter-spacing:.22em;text-transform:uppercase;font-weight:600}
.cat-filter .years{display:flex;gap:6px;flex-wrap:wrap}
.cat-filter .years a{padding:6px 12px;border:1px solid var(--rule);background:#fff;border-radius:1px;color:var(--ink-soft)}
.cat-filter .years a:hover{border-color:var(--wine);color:var(--wine)}
.cat-filter .years a.active{background:var(--wine);color:var(--gold-pale);border-color:var(--wine)}

.cat-grid{padding:64px 0}
.cat-articles{display:grid;grid-template-columns:repeat(3,1fr);gap:48px}

/* =================================================================
   AUTHOR PAGE
================================================================= */
.author-hero{padding:72px 0 56px;background:linear-gradient(180deg,var(--paper) 0%,var(--paper-warm) 100%);border-bottom:1px solid var(--rule)}
.author-hero .container{max-width:1100px;display:grid;grid-template-columns:180px 1fr;gap:48px;align-items:center}
.author-avatar{width:180px;height:180px;border-radius:50%;background:linear-gradient(135deg,#F4EAD0 0%,#D6C49A 100%);border:1px solid var(--gold-deep);display:flex;align-items:center;justify-content:center;font-family:var(--display);font-style:italic;font-size:72px;color:var(--wine);font-weight:500;box-shadow:0 4px 20px rgba(125,36,24,.12)}
.author-info .eyebrow{font-family:var(--sans);font-size:11.5px;letter-spacing:.32em;text-transform:uppercase;color:var(--wine);font-weight:600;margin-bottom:14px;display:flex;align-items:center;gap:12px}
.author-info .eyebrow:before{content:'';width:30px;height:1px;background:var(--wine)}
.author-info h1{font-family:var(--display);font-style:italic;font-size:50px;margin:0 0 8px;color:var(--ink);font-weight:500;line-height:1.05}
.author-info .org{font-family:var(--sans);font-size:15px;color:var(--ink-soft);margin-bottom:14px}
.author-info .han-sig{font-family:var(--cjk-cal);font-size:30px;color:var(--wine);letter-spacing:.1em;margin-bottom:18px}
.author-info .quick-meta{display:flex;gap:32px;padding-top:16px;border-top:1px solid var(--rule);font-family:var(--sans);font-size:13.5px;color:var(--muted)}
.author-info .quick-meta strong{color:var(--wine);font-family:var(--display);font-style:italic;font-size:22px;font-weight:500;display:block;line-height:1}

.author-bio{padding:56px 0;border-bottom:1px solid var(--rule);background:#fff}
.author-bio .container{max-width:820px}
.author-bio h2{font-family:var(--display);font-style:italic;font-size:28px;margin:0 0 18px;color:var(--ink);font-weight:500;display:flex;align-items:baseline;gap:14px}
.author-bio h2 .han{font-family:var(--cjk-cal);font-style:normal;color:var(--wine);font-size:22px;letter-spacing:.1em}
.author-bio p{font-size:17px;line-height:1.78;color:var(--ink-soft);margin:0 0 18px}
.author-bio .specialties{display:flex;flex-wrap:wrap;gap:8px;margin:24px 0 0}
.author-bio .specialties .tag{padding:6px 14px;background:var(--paper-warm);border:1px solid var(--rule);font-family:var(--sans);font-size:12.5px;color:var(--ink-soft);border-radius:1px}
.author-bio .specialties .tag .han{font-family:var(--cjk);color:var(--wine);margin-right:6px;font-size:12px}

.author-tabs{padding:56px 0 0;background:var(--paper-warm)}
.author-tabs .container{max-width:1100px}
.author-tabs .tabbar{display:flex;border-bottom:1px solid var(--rule);font-family:var(--sans)}
.author-tabs .tabbar a{padding:14px 28px;color:var(--ink-soft);font-size:13.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;border-bottom:3px solid transparent}
.author-tabs .tabbar a:hover{color:var(--wine)}
.author-tabs .tabbar a.active{color:var(--wine);border-color:var(--wine)}
.author-tabs .tabbar .count{margin-left:6px;color:var(--muted);font-weight:500}
.author-works{padding:48px 0 64px}
.work-item{display:grid;grid-template-columns:80px 1fr 140px;gap:32px;padding:24px 0;border-bottom:1px solid var(--rule);font-family:var(--sans)}
.work-item:last-child{border-bottom:0}
.work-item .year-box{text-align:center;font-family:var(--display);font-style:italic;color:var(--wine);font-size:32px;font-weight:500;line-height:1;padding-top:4px}
.work-item .year-box .issue{display:block;font-family:var(--sans);font-style:normal;color:var(--muted);font-size:11px;font-weight:600;letter-spacing:.15em;text-transform:uppercase;margin-top:6px}
.work-item .info h4{font-family:var(--display);font-weight:500;font-size:22px;margin:0 0 8px;color:var(--ink);line-height:1.3}
.work-item .info h4 em{font-style:italic;color:var(--ink-soft)}
.work-item .info h4 a:hover{color:var(--wine)}
.work-item .info .cat{font-family:var(--sans);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-deep);font-weight:600;margin-bottom:6px}
.work-item .info .excerpt{font-family:var(--serif);font-size:14.5px;line-height:1.6;color:var(--ink-soft);margin:0}
.work-item .actions{text-align:right;font-family:var(--sans);font-size:11.5px;color:var(--muted)}
.work-item .actions .citations{font-family:var(--display);font-style:italic;font-size:24px;color:var(--wine);font-weight:500;line-height:1;margin-bottom:4px}
.work-item .actions .citations-label{letter-spacing:.14em;text-transform:uppercase;font-weight:600;margin-bottom:14px}
.work-item .actions a{color:var(--wine);text-decoration:underline;text-decoration-color:var(--rule)}

/* =================================================================
   SEARCH PAGE
================================================================= */
.search-hero{padding:56px 0 40px;background:linear-gradient(180deg,var(--paper) 0%,var(--paper-warm) 100%);border-bottom:1px solid var(--rule)}
.search-hero .container{max-width:920px}
.search-hero .eyebrow{font-family:var(--sans);font-size:11.5px;letter-spacing:.32em;text-transform:uppercase;color:var(--wine);font-weight:600;margin-bottom:14px}
.search-hero h1{font-family:var(--display);font-style:italic;font-size:42px;margin:0 0 24px;color:var(--ink);font-weight:500;line-height:1.1}
.search-hero h1 em{font-style:italic;color:var(--wine)}
.search-hero h1 .han{font-family:var(--cjk-cal);font-style:normal;color:var(--wine);margin:0 4px}
.search-form{display:flex;gap:0;border:1px solid var(--gold-deep);background:#fff;border-radius:2px;overflow:hidden}
.search-form input{flex:1;padding:16px 20px;font-family:var(--serif);font-size:17px;border:0;outline:none;background:transparent;color:var(--ink)}
.search-form button{background:var(--wine);color:var(--gold-pale);border:0;padding:0 32px;font-family:var(--sans);font-size:13px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;cursor:pointer}
.search-form button:hover{background:var(--wine-deep)}
.search-summary{display:flex;justify-content:space-between;align-items:center;margin-top:24px;padding-top:20px;border-top:1px solid var(--rule);font-family:var(--sans);font-size:13.5px;color:var(--muted)}
.search-summary strong{color:var(--ink);font-weight:600}

.search-layout{padding:48px 0;display:grid;grid-template-columns:260px 1fr;gap:48px;max-width:1240px;margin:0 auto;padding-left:36px;padding-right:36px}
.search-filters{font-family:var(--sans);font-size:13.5px}
.search-filters .group{margin-bottom:28px;padding-bottom:24px;border-bottom:1px solid var(--rule)}
.search-filters h5{font-family:var(--sans);font-size:11px;color:var(--muted);letter-spacing:.22em;text-transform:uppercase;font-weight:600;margin:0 0 12px}
.search-filters label{display:flex;align-items:center;gap:8px;padding:5px 0;color:var(--ink-soft);cursor:pointer}
.search-filters label:hover{color:var(--wine)}
.search-filters label input{accent-color:var(--wine)}
.search-filters label .count{margin-left:auto;color:var(--muted);font-size:12px}
.search-filters label .han{font-family:var(--cjk);color:var(--gold-deep);font-size:12px;margin-right:2px}

.search-results{}
.search-sort{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:18px;border-bottom:2px solid var(--ink);font-family:var(--sans);font-size:13px}
.search-sort .count{color:var(--ink-soft);font-weight:500}
.search-sort .count strong{color:var(--wine);font-weight:600}
.search-sort select{padding:7px 14px;border:1px solid var(--rule);background:#fff;font-family:var(--sans);font-size:13px;color:var(--ink-soft);border-radius:1px}

.search-item{padding:22px 0;border-bottom:1px solid var(--rule)}
.search-item:last-of-type{border-bottom:0}
.search-item .cat-row{display:flex;align-items:baseline;gap:10px;margin-bottom:6px;font-family:var(--sans);font-size:11.5px}
.search-item .cat{letter-spacing:.18em;text-transform:uppercase;color:var(--gold-deep);font-weight:600}
.search-item .cat .han{font-family:var(--cjk);color:var(--wine);margin-right:4px;font-size:11px;letter-spacing:.05em}
.search-item .issue{color:var(--muted);font-weight:500}
.search-item .issue .sep{color:var(--rule);margin:0 8px}
.search-item h4{font-family:var(--display);font-weight:500;font-size:24px;margin:0 0 10px;color:var(--ink);line-height:1.25}
.search-item h4 a:hover{color:var(--wine)}
.search-item h4 em{font-style:italic;color:var(--ink-soft)}
.search-item h4 mark, .search-item .snippet mark{background:rgba(232,212,154,.6);color:var(--ink);padding:0 3px;font-weight:600}
.search-item .snippet{font-size:15px;line-height:1.65;color:var(--ink-soft);margin:0 0 10px}
.search-item .meta{font-family:var(--sans);font-size:12.5px;color:var(--muted);display:flex;gap:14px}
.search-item .meta strong{color:var(--ink-soft);font-weight:600}
.search-item .meta .sep{color:var(--rule)}

/* =================================================================
   RESPONSIVE
================================================================= */
@media (max-width:960px){
  .masthead .container{grid-template-columns:80px 1fr;gap:20px}
  .masthead-meta{display:none}
  .logo-shield{width:80px}
  .masthead-text h1{font-size:32px}
  .nav-links{gap:0;overflow-x:auto;flex:1}
  .nav-links a{padding:18px 14px;font-size:12.5px}
  .search{display:none}
  .article-layout{grid-template-columns:1fr;gap:32px;padding:32px 24px}
  .article-side{position:static}
  .article-title{font-size:32px}
  .article-body{font-size:17px}
  .archive-shelf{grid-template-columns:repeat(2,1fr);gap:24px}
  .archive-hero h1{font-size:42px}
  .submit-hero .container{grid-template-columns:1fr;gap:32px}
  .submit-hero h1{font-size:38px}
  .form-grid{grid-template-columns:1fr;gap:32px}
  .form-main{padding:28px 22px}
  .form-cols-2{grid-template-columns:1fr}
  footer .footer-grid{grid-template-columns:1fr 1fr;gap:36px}
  .step-bar{padding:0 12px}
  .step .label{font-size:11px}
}

/* =================================================================
   HOMEPAGE-SPECIFIC STYLES — bóc từ design-proposal/home-v2.html
================================================================= */

/* === HERO === */
.hero{padding:80px 0 72px;position:relative}
.hero .container{display:grid;grid-template-columns:1.25fr 1fr;gap:80px;align-items:center}
.hero-left{position:relative}
.hero-eyebrow{font-family:var(--sans);font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--wine);font-weight:600;margin-bottom:24px;display:flex;align-items:center;gap:14px}
.hero-eyebrow:before{content:'';width:36px;height:1px;background:var(--wine)}
.hero-label{font-family:var(--sans);font-size:11.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--vermillion,var(--wine));font-weight:600;margin-bottom:18px}
.hero-label:before{content:'— ';color:var(--wine)}
.hero-han{font-family:var(--cjk-cal);font-size:32px;color:var(--wine);margin-bottom:20px;letter-spacing:.06em;line-height:1.1}
.hero-cjk{font-family:var(--cjk);font-size:22px;color:var(--wine);margin-bottom:18px;letter-spacing:.1em}
.hero-title{font-family:var(--display);font-weight:500;font-style:italic;font-size:54px;line-height:1.1;margin:0 0 28px;color:var(--ink);letter-spacing:-.005em}
.hero-title a{color:inherit}
.hero-excerpt{font-size:19px;line-height:1.75;color:var(--ink-soft);margin:0 0 32px;max-width:600px}
.hero-excerpt::first-letter{font-family:var(--display);font-weight:600;font-style:normal;font-size:72px;float:left;line-height:.85;padding:6px 12px 0 0;color:var(--wine)}
.hero-byline{font-family:var(--sans);font-size:13px;color:var(--muted);display:flex;gap:18px;align-items:center;padding-top:24px;border-top:1px solid var(--rule)}
.hero-byline strong{color:var(--ink);font-weight:600}
.hero-byline .sep{color:var(--rule)}
.hero-byline .pdf-btn{margin-left:auto;background:var(--wine);color:var(--gold-pale);padding:10px 18px;font-family:var(--sans);font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;border-radius:1px}
.hero-byline .pdf-btn:hover{background:var(--wine-deep)}

/* Manuscript card on right */
.hero-right{position:relative}
.manuscript{background:linear-gradient(165deg,#FBF3DC 0%,#EFDEAB 100%);border:1px solid var(--gold-deep);border-radius:2px;padding:48px 40px;position:relative;box-shadow:inset 0 0 0 1px rgba(140,106,46,.2),inset 0 0 80px rgba(140,106,46,.08);min-height:480px;display:flex;flex-direction:column;justify-content:space-between}
.manuscript:before{content:'';position:absolute;inset:14px;border:1px solid rgba(140,106,46,.3);pointer-events:none}
.manuscript-vertical{writing-mode:vertical-rl;text-orientation:upright;font-family:var(--cjk);font-size:34px;color:var(--ink);font-weight:500;letter-spacing:.55em;margin:0 auto;line-height:1.4}
.manuscript-vertical em{font-style:normal;color:var(--wine)}
.manuscript-foot{font-family:var(--cjk);font-size:14px;color:var(--gold-deep);letter-spacing:.4em;text-align:center;padding-top:14px;border-top:1px dotted var(--gold)}
.seal-stamp{position:absolute;top:36px;right:36px;width:64px;height:64px;background:var(--wine);display:flex;align-items:center;justify-content:center;font-family:var(--cjk);font-weight:700;font-size:18px;color:var(--gold-pale);letter-spacing:0;line-height:1;transform:rotate(-6deg);box-shadow:inset 0 0 0 2px var(--wine-deep),inset 0 0 0 3px var(--gold-pale),inset 0 0 0 5px var(--wine-deep)}
.seal-stamp .stack{display:grid;grid-template-columns:1fr 1fr;gap:2px;line-height:.95}

/* === ARTICLES grid (homepage) === */
.articles{display:grid;grid-template-columns:repeat(3,1fr);gap:48px}
.article-card{position:relative;padding-top:8px}
.article-card:before{content:'';position:absolute;top:0;left:0;width:42px;height:2px;background:var(--wine)}
.article-card .cat-row{display:flex;align-items:baseline;gap:10px;margin-bottom:14px}
.article-card .cjk-mark{font-family:var(--cjk-cal);font-size:20px;color:var(--gold-deep);letter-spacing:.08em;line-height:1}
.article-card .cat{font-family:var(--sans);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);font-weight:600}
.article-card h4{font-family:var(--display);font-weight:500;font-size:25px;line-height:1.22;margin:0 0 16px;color:var(--ink)}
.article-card h4 a{color:inherit}
.article-card h4 a:hover{color:var(--wine)}
.article-card h4 em{font-style:italic;color:var(--ink-soft)}
.article-card .excerpt{font-size:15.5px;line-height:1.65;color:var(--ink-soft);margin:0 0 22px}
.article-card .meta{font-family:var(--sans);font-size:12.5px;color:var(--muted);display:flex;flex-direction:column;gap:4px;padding-top:18px;border-top:1px solid var(--rule)}
.article-card .meta .author{color:var(--ink);font-weight:600}
.article-card .meta .info{display:flex;gap:8px;flex-wrap:wrap}
.article-card .meta .info .sep{color:var(--rule)}

/* === CATEGORIES section background (homepage 6-tile) === */
/* NOTE: renamed từ .cat-grid → .cat-tiles-grid để tránh đụng với .cat-grid của category PAGE section */
.categories{background:var(--paper-warm)}
.cat-tiles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--rule);border:1px solid var(--rule)}
.cat-tile{background:var(--paper-warm);padding:38px 30px 32px;display:flex;flex-direction:column;gap:8px;transition:background .2s;position:relative;overflow:hidden;color:inherit;text-decoration:none}
.cat-tile:hover{background:#FFFAEC}
.cat-tile .han-bg{position:absolute;right:-20px;bottom:-30px;font-family:var(--cjk-cal);font-size:140px;color:var(--wine);opacity:.06;line-height:1;pointer-events:none}
.cat-tile .han{font-family:var(--cjk-cal);font-size:30px;color:var(--wine);font-weight:500;line-height:1;letter-spacing:.08em;margin-bottom:6px}
.cat-tile h5{margin:0;font-family:var(--display);font-weight:500;font-size:24px;color:var(--ink);letter-spacing:-.005em}
.cat-tile p{margin:6px 0 0;font-family:var(--sans);font-size:13px;color:var(--muted);line-height:1.55}
.cat-tile .count{font-family:var(--sans);font-size:11px;color:var(--wine);font-weight:600;letter-spacing:.18em;text-transform:uppercase;margin-top:10px}

/* === ISSUES grid (homepage 5-col) === */
.issues-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:28px}
.issue-card{text-align:center;color:inherit;text-decoration:none;display:block}
.issue-cover{aspect-ratio:3/4;background:linear-gradient(168deg,#FBF3DC 0%,#E8D29A 100%);border:1px solid var(--gold-deep);border-radius:1px;display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding:22px 16px 18px;position:relative;box-shadow:0 1px 0 var(--gold-deep), 2px 4px 12px rgba(125,36,24,.08);transition:transform .2s}
.issue-cover:hover{transform:translateY(-3px)}
.issue-cover:before{content:'';position:absolute;inset:8px;border:1px solid rgba(140,106,46,.4);pointer-events:none}
.issue-cover:after{content:'';position:absolute;top:14px;bottom:14px;left:50%;width:1px;background:rgba(140,106,46,.25);pointer-events:none}
.issue-cover .han-vert{font-family:var(--cjk);font-size:18px;color:var(--wine);font-weight:700;letter-spacing:.4em;writing-mode:vertical-rl;line-height:1.2;flex:1;display:flex;align-items:center}
.issue-cover .num{font-family:var(--display);font-size:22px;color:var(--ink);font-style:italic;font-weight:500}
.issue-cover .mini-seal{position:absolute;top:18px;right:18px;width:22px;height:22px;background:var(--wine);color:var(--gold-pale);display:flex;align-items:center;justify-content:center;font-family:var(--cjk);font-size:10px;font-weight:700;border-radius:1px;line-height:1}
.issue-card h6{margin:16px 0 4px;font-family:var(--display);font-size:18px;color:var(--ink);font-weight:600}
.issue-card .date{font-family:var(--sans);font-size:12px;color:var(--muted)}
.issue-card.current h6{color:var(--wine)}
.issue-card.current .issue-cover{box-shadow:0 0 0 1px var(--wine), 2px 4px 16px rgba(125,36,24,.18)}

/* === ABOUT STRIP === */
.about-strip{background:linear-gradient(180deg,var(--paper) 0%,var(--paper-dark) 100%);padding:96px 0;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);position:relative;overflow:hidden}
.about-strip:before{content:'承先啟後';position:absolute;right:-80px;top:30px;font-family:var(--cjk-cal);font-size:260px;color:var(--wine);opacity:.04;line-height:1;letter-spacing:.08em;pointer-events:none}
.about-strip .container{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;position:relative}
.about-quote .han{display:block;font-family:var(--cjk-cal);font-size:46px;color:var(--wine);margin-bottom:24px;letter-spacing:.15em;line-height:1}
.about-quote em{font-family:var(--display);font-style:italic;font-size:32px;line-height:1.4;color:var(--ink);display:block}
.about-quote .src{display:block;margin-top:22px;font-family:var(--sans);font-size:12.5px;color:var(--muted);letter-spacing:.12em;text-transform:uppercase}
.about-meta{font-family:var(--sans);font-size:14px;color:var(--ink-soft);line-height:1.8}
.about-meta dt{color:var(--muted);font-size:11.5px;letter-spacing:.2em;text-transform:uppercase;margin-top:18px;font-weight:600}
.about-meta dt:first-of-type{margin-top:0}
.about-meta dd{margin:4px 0 0;color:var(--ink);font-weight:500}
.about-meta dd a{color:var(--wine);text-decoration:underline;text-decoration-color:var(--rule)}

/* Responsive */
@media (max-width:960px){
  .hero .container{grid-template-columns:1fr;gap:48px}
  .hero-title{font-size:36px}
  .articles{grid-template-columns:1fr;gap:40px}
  .cat-tiles-grid{grid-template-columns:1fr}
  .issues-grid{grid-template-columns:repeat(2,1fr)}
  .about-strip .container{grid-template-columns:1fr;gap:48px}
}

/* =================================================================
   ARTICLE CARD — thumbnail + equal-height grid
================================================================= */

/* Cards trong grid (homepage .articles + category .cat-articles + tag) cùng cao */
.articles, .cat-articles{align-items:stretch}
.articles .article-card, .cat-articles .article-card{
  display:flex;flex-direction:column;
  background:#fff;border:1px solid var(--rule);border-radius:2px;overflow:hidden;
  padding:0;  /* bỏ padding-top 8px của style cũ */
  transition:box-shadow .2s, transform .2s;
}
.articles .article-card:hover, .cat-articles .article-card:hover{
  box-shadow:0 6px 24px rgba(125,36,24,.1);
  transform:translateY(-2px);
}
.articles .article-card:before, .cat-articles .article-card:before{display:none}  /* bỏ thanh đỏ trên cùng */

/* Thumb area */
.article-card .thumb{
  display:block;aspect-ratio:16/10;
  background:linear-gradient(135deg,#FBF3DC 0%,#E8D29A 100%);
  border-bottom:1px solid var(--gold-deep);
  position:relative;overflow:hidden;
  text-decoration:none;
}
.article-card .thumb img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .4s ease;
}
.article-card:hover .thumb img{transform:scale(1.04)}

/* Thumb placeholder: chữ Hán trên giấy ngà */
.article-card .thumb-placeholder{
  width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
  position:relative;
  background-image:
    radial-gradient(circle at 30% 30%, rgba(140,106,46,.08) 0%, transparent 50%),
    radial-gradient(circle at 70% 70%, rgba(125,36,24,.06) 0%, transparent 50%);
}
.article-card .thumb-placeholder:before{
  content:'';position:absolute;inset:12px;
  border:1px solid rgba(140,106,46,.3);pointer-events:none;
}
.article-card .thumb-placeholder .han{
  font-family:var(--cjk-cal);font-size:78px;color:var(--wine);
  opacity:.32;letter-spacing:.05em;font-weight:500;line-height:1;
  letter-spacing:.1em;
}
.article-card .thumb-placeholder .seal{
  position:absolute;bottom:14px;right:14px;
  width:32px;height:32px;
  background:var(--wine);color:var(--gold-pale);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--cjk);font-size:14px;font-weight:700;
  border-radius:1px;line-height:1;opacity:.85;
  transform:rotate(-4deg);
}

/* Body cards */
.article-card-body{
  padding:20px 22px 22px;
  display:flex;flex-direction:column;flex:1;  /* grow để các card cùng cao */
}
.article-card-body .cat-row{display:flex;align-items:baseline;gap:10px;margin-bottom:10px}
.article-card-body .cat-row .cjk-mark{font-family:var(--cjk-cal);font-size:18px;color:var(--gold-deep);letter-spacing:.08em;line-height:1}
.article-card-body .cat-row .cat{font-family:var(--sans);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);font-weight:600}
.article-card-body h4{font-family:var(--display);font-weight:500;font-size:22px;line-height:1.25;margin:0 0 12px;color:var(--ink)}
.article-card-body h4 a{color:inherit}
.article-card-body h4 a:hover{color:var(--wine)}
.article-card-body h4 em{font-style:italic;color:var(--ink-soft)}
.article-card-body .excerpt{font-size:14.5px;line-height:1.6;color:var(--ink-soft);margin:0 0 16px;flex:1}  /* flex:1 đẩy meta xuống đáy */
.article-card-body .meta{font-family:var(--sans);font-size:12.5px;color:var(--muted);display:flex;flex-direction:column;gap:4px;padding-top:14px;border-top:1px solid var(--rule);margin-top:auto}
.article-card-body .meta .author{color:var(--ink);font-weight:600}
.article-card-body .meta .info{display:flex;gap:8px;flex-wrap:wrap;font-size:12px}
.article-card-body .meta .info .sep{color:var(--rule)}

/* Responsive */
@media (max-width:960px){
  .article-card .thumb-placeholder .han{font-size:56px}
}
