/* ============================================================
   zazhi v1 — 杂志 Editorial 设计系统
   配色：纯白 + 墨黑 + 勃艮第酒红 + 米白
   字体：Playfair Display + Inter + Noto Serif SC
   排版：1480px 容器 / 大字号对比 / 编号系统 / 1px hairline
   ============================================================ */

/* ---------- 0. 设计令牌 ---------- */
:root {
    /* 纸 */
    --zz-paper:        #ffffff;
    --zz-paper-2:      #f8f4ed;       /* 米白 cream */
    --zz-paper-3:      #f0ebe1;       /* 浅米白 */

    /* 墨 */
    --zz-ink:          #0a0a0a;
    --zz-ink-2:        #1a1a1a;
    --zz-ink-3:        #4a4a4a;
    --zz-ink-4:        #8a8a8a;
    --zz-ink-5:        #c8c4be;       /* 米色调灰 */

    /* 线 */
    --zz-line:         #1a1a1a;       /* 编辑风的"墨线" */
    --zz-line-2:       #e8e4dc;       /* 淡米线 */

    /* 强调：勃艮第酒红 */
    --zz-burgundy:     #6B0F1A;
    --zz-burgundy-2:   #8B2C36;
    --zz-cream:        #F8F4ED;

    /* 字体 */
    --zz-font-serif:   'Playfair Display', 'Noto Serif SC', Georgia, 'Times New Roman', serif;
    --zz-font-sans:    'Inter', -apple-system, BlinkMacSystemFont, 'PingFang SC', 'Hiragino Sans GB', 'Microsoft YaHei', 'Helvetica Neue', Arial, sans-serif;

    /* 间距（基于 8pt 栅格） */
    --zz-s1: 4px;
    --zz-s2: 8px;
    --zz-s3: 16px;
    --zz-s4: 24px;
    --zz-s5: 32px;
    --zz-s6: 48px;
    --zz-s7: 64px;
    --zz-s8: 96px;
    --zz-s9: 128px;
    --zz-s10: 160px;

    /* 容器 */
    --zz-container: 1480px;
    --zz-radius: 0;     /* 杂志风无圆角 */
}

/* ---------- 1. Reset & Base ---------- */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { font-size: 16px; -webkit-text-size-adjust: 100%; }
body {
    font-family: var(--zz-font-sans);
    font-size: 16px;
    line-height: 1.65;
    color: var(--zz-ink);
    background: var(--zz-paper);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    overflow-x: hidden;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; transition: color .2s ease, opacity .2s ease; }
a:hover { color: var(--zz-burgundy); opacity: 1; }
button, input, select, textarea { font: inherit; color: inherit; }
button { background: none; border: 0; padding: 0; cursor: pointer; }
ul, ol { margin: 0; padding: 0; list-style: none; }
h1, h2, h3, h4, h5, h6, p { margin: 0; }
hr { border: 0; border-top: 1px solid var(--zz-line); margin: 0; }
::selection { background: var(--zz-burgundy); color: var(--zz-paper); }

/* 通用容器 */
.zz-container { max-width: var(--zz-container); margin: 0 auto; padding: 0 var(--zz-s5); }
.zz-container--narrow { max-width: 1080px; }
.zz-container--wide { max-width: 1680px; }

/* 通用栅格 */
.zz-grid { display: grid; gap: var(--zz-s5); min-width: 0; }
.zz-grid > * { min-width: 0; }
.zz-row { display: flex; flex-wrap: wrap; gap: var(--zz-s5); min-width: 0; }
.zz-row > * { min-width: 0; flex: 0 0 auto; }

/* 通用工具 */
.zz-mt-0{margin-top:0} .zz-mt-1{margin-top:var(--zz-s1)} .zz-mt-2{margin-top:var(--zz-s2)} .zz-mt-3{margin-top:var(--zz-s3)}
.zz-mt-4{margin-top:var(--zz-s4)} .zz-mt-5{margin-top:var(--zz-s5)} .zz-mt-6{margin-top:var(--zz-s6)} .zz-mt-7{margin-top:var(--zz-s7)}
.zz-mb-0{margin-bottom:0} .zz-mb-1{margin-bottom:var(--zz-s1)} .zz-mb-2{margin-bottom:var(--zz-s2)} .zz-mb-3{margin-bottom:var(--zz-s3)}
.zz-mb-4{margin-bottom:var(--zz-s4)} .zz-mb-5{margin-bottom:var(--zz-s5)} .zz-mb-6{margin-bottom:var(--zz-s6)} .zz-mb-7{margin-bottom:var(--zz-s7)}
.zz-flex { display: flex; }
.zz-flex-center { display: flex; align-items: center; justify-content: center; }
.zz-flex-between { display: flex; align-items: center; justify-content: space-between; }
.zz-truncate { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.zz-clamp-2 { display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.zz-clamp-3 { display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.zz-clamp-4 { display: -webkit-box; -webkit-line-clamp: 4; -webkit-box-orient: vertical; overflow: hidden; }
.zz-number {
    font-family: var(--zz-font-serif);
    font-style: italic;
    font-weight: 400;
    color: var(--zz-burgundy);
}
.zz-divider { height: 1px; background: var(--zz-line); border: 0; margin: var(--zz-s6) 0; }
.zz-divider-thin { height: 1px; background: var(--zz-line-2); border: 0; margin: var(--zz-s4) 0; }

/* ---------- 2. 排版（杂志衬线大标题）---------- */
.zz-display {
    font-family: var(--zz-font-serif);
    font-size: clamp(56px, 9vw, 128px);
    font-weight: 700;
    line-height: 0.95;
    letter-spacing: -0.03em;
    color: var(--zz-ink);
}
.zz-h1 { font-family: var(--zz-font-serif); font-size: 48px; font-weight: 700; line-height: 1.05; letter-spacing: -0.02em; }
.zz-h2 { font-family: var(--zz-font-serif); font-size: 36px; font-weight: 700; line-height: 1.1; letter-spacing: -0.015em; }
.zz-h3 { font-family: var(--zz-font-serif); font-size: 28px; font-weight: 600; line-height: 1.2; letter-spacing: -0.01em; }
.zz-h4 { font-family: var(--zz-font-serif); font-size: 22px; font-weight: 600; line-height: 1.3; }
.zz-h5 { font-family: var(--zz-font-sans); font-size: 18px; font-weight: 600; line-height: 1.4; }
.zz-h6 { font-family: var(--zz-font-sans); font-size: 14px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.12em; }
.zz-text-meta { font-size: 13px; color: var(--zz-ink-3); line-height: 1.5; }
.zz-text-meta-2 { font-size: 12px; color: var(--zz-ink-4); text-transform: uppercase; letter-spacing: 0.1em; }
.zz-text-body { font-size: 16px; color: var(--zz-ink-2); line-height: 1.7; }
.zz-text-body-lg { font-size: 18px; color: var(--zz-ink-2); line-height: 1.7; }
.zz-italic { font-family: var(--zz-font-serif); font-style: italic; }

/* ---------- 3. 顶部 Header ---------- */
.zz-header {
    background: var(--zz-paper);
    border-bottom: 2px solid var(--zz-line);
    position: sticky; top: 0; z-index: 100;
}
.zz-header__top {
    border-bottom: 1px solid var(--zz-line-2);
    padding: var(--zz-s2) 0;
    text-align: center;
    font-size: 11px;
    color: var(--zz-ink-3);
    text-transform: uppercase;
    letter-spacing: 0.15em;
}
.zz-header__inner {
    display: grid; grid-template-columns: 1fr auto 1fr; align-items: center;
    padding: var(--zz-s4) 0;
    gap: var(--zz-s5);
}
.zz-header__brand {
    font-family: var(--zz-font-serif);
    font-size: 32px;
    font-weight: 700;
    line-height: 1;
    letter-spacing: -0.01em;
    color: var(--zz-ink);
    text-decoration: none;
}
.zz-header__brand-dot { color: var(--zz-burgundy); }
.zz-header__nav { display: flex; gap: var(--zz-s5); align-items: center; justify-content: center; }
.zz-header__nav-link {
    font-family: var(--zz-font-sans);
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--zz-ink-2);
    padding: 8px 0;
    position: relative;
}
.zz-header__nav-link:hover { color: var(--zz-burgundy); opacity: 1; }
.zz-header__nav-link.is-active { color: var(--zz-burgundy); }
.zz-header__nav-link.is-active::after {
    content: ''; position: absolute; left: 0; right: 0; bottom: -1px;
    height: 2px; background: var(--zz-burgundy);
}
.zz-header__actions { display: flex; align-items: center; justify-content: flex-end; gap: var(--zz-s3); }
.zz-header__search {
    width: 36px; height: 36px;
    display: flex; align-items: center; justify-content: center;
    border: 1px solid var(--zz-line); border-radius: 50%;
    color: var(--zz-ink);
    transition: all .15s ease;
}
.zz-header__search:hover { background: var(--zz-burgundy); color: var(--zz-paper); border-color: var(--zz-burgundy); opacity: 1; }
.zz-header__search svg { width: 14px; height: 14px; stroke: currentColor; fill: none; stroke-width: 2; }

/* 移动端汉堡 */
.zz-header__burger { display: none; width: 36px; height: 36px; align-items: center; justify-content: center; }
.zz-header__burger span { display: block; width: 18px; height: 1.5px; background: var(--zz-ink); position: relative; }
.zz-header__burger span::before, .zz-header__burger span::after { content: ''; position: absolute; left: 0; width: 18px; height: 1.5px; background: var(--zz-ink); }
.zz-header__burger span::before { top: -6px; }
.zz-header__burger span::after { top: 6px; }

/* 移动端抽屉 */
.zz-drawer {
    position: fixed; inset: 0; z-index: 200;
    background: var(--zz-paper);
    display: none; flex-direction: column;
    padding: var(--zz-s4);
}
.zz-drawer.is-open { display: flex; }
.zz-drawer__top { display: flex; justify-content: space-between; align-items: center; height: 56px; border-bottom: 1px solid var(--zz-line); }
.zz-drawer__close { width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; font-size: 24px; }
.zz-drawer__nav { display: flex; flex-direction: column; padding: var(--zz-s4) 0; }
.zz-drawer__nav-link {
    font-family: var(--zz-font-serif);
    font-size: 28px; font-weight: 600; color: var(--zz-ink);
    padding: var(--zz-s3) 0;
    border-bottom: 1px solid var(--zz-line-2);
}
.zz-drawer__nav-link:hover { color: var(--zz-burgundy); opacity: 1; }

/* ---------- 4. Footer 底栏（杂志版权页风）---------- */
.zz-footer {
    background: var(--zz-paper);
    border-top: 2px solid var(--zz-line);
    padding: var(--zz-s9) 0 var(--zz-s5);
    margin-top: var(--zz-s9);
}
.zz-footer__brand {
    font-family: var(--zz-font-serif);
    font-size: 64px;
    font-weight: 700;
    line-height: 1;
    letter-spacing: -0.02em;
    color: var(--zz-ink);
    margin-bottom: var(--zz-s3);
}
.zz-footer__brand-dot { color: var(--zz-burgundy); }
.zz-footer__desc {
    font-family: var(--zz-font-serif);
    font-style: italic;
    font-size: 18px;
    color: var(--zz-ink-3);
    max-width: 560px;
    margin-bottom: var(--zz-s6);
}
.zz-footer__cols {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--zz-s5);
    padding: var(--zz-s5) 0;
    border-top: 1px solid var(--zz-line);
    border-bottom: 1px solid var(--zz-line);
}
.zz-footer__col h4 {
    font-family: var(--zz-font-sans);
    font-size: 11px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.15em;
    color: var(--zz-ink-3);
    margin-bottom: var(--zz-s3);
}
.zz-footer__col li { padding: 4px 0; font-size: 14px; color: var(--zz-ink-2); }
.zz-footer__col li a:hover { color: var(--zz-burgundy); opacity: 1; }
.zz-footer__bottom {
    padding-top: var(--zz-s4);
    display: flex; flex-wrap: wrap;
    gap: var(--zz-s3) var(--zz-s5);
    font-size: 13px;
    color: var(--zz-ink-4);
}
.zz-footer__bottom a { color: var(--zz-ink-3); }
.zz-footer__bottom a:hover { color: var(--zz-burgundy); opacity: 1; }
.zz-footer__friend {
    display: flex; flex-wrap: wrap; gap: 4px var(--zz-s3);
    font-size: 13px; color: var(--zz-ink-3);
    padding-top: var(--zz-s4);
    border-top: 1px solid var(--zz-line-2);
}
.zz-footer__friend strong { color: var(--zz-ink); font-weight: 600; margin-right: var(--zz-s2); }
.zz-footer__friend a { color: var(--zz-ink-3); }
.zz-footer__friend a:hover { color: var(--zz-burgundy); opacity: 1; }

/* ---------- 5. Button ---------- */
.zz-btn {
    display: inline-flex; align-items: center; justify-content: center; gap: var(--zz-s2);
    height: 48px; padding: 0 var(--zz-s5);
    font-family: var(--zz-font-sans);
    font-size: 12px; font-weight: 600;
    text-transform: uppercase; letter-spacing: 0.12em;
    border: 1px solid var(--zz-ink); border-radius: 0;
    background: var(--zz-ink); color: var(--zz-paper);
    transition: all .2s ease;
    cursor: pointer;
    white-space: nowrap;
}
.zz-btn:hover { background: var(--zz-burgundy); color: var(--zz-paper); border-color: var(--zz-burgundy); opacity: 1; }
.zz-btn--accent { background: var(--zz-burgundy); color: var(--zz-paper); border-color: var(--zz-burgundy); }
.zz-btn--accent:hover { background: var(--zz-ink); border-color: var(--zz-ink); }
.zz-btn--ghost { background: transparent; color: var(--zz-ink); }
.zz-btn--ghost:hover { background: var(--zz-ink); color: var(--zz-paper); }
.zz-btn--lg { height: 56px; padding: 0 var(--zz-s6); font-size: 13px; }
.zz-btn--sm { height: 36px; padding: 0 var(--zz-s3); font-size: 11px; }
.zz-btn--block { display: flex; width: 100%; }

/* ---------- 6. Tag / 标签 ---------- */
.zz-tag {
    display: inline-block; padding: 4px 12px;
    font-family: var(--zz-font-sans);
    font-size: 11px; font-weight: 600;
    text-transform: uppercase; letter-spacing: 0.08em;
    color: var(--zz-ink-2);
    border: 1px solid var(--zz-line); border-radius: 0;
    transition: all .15s ease;
}
.zz-tag:hover { background: var(--zz-burgundy); color: var(--zz-paper); border-color: var(--zz-burgundy); opacity: 1; }
.zz-tag--dark { background: var(--zz-ink); color: var(--zz-paper); border-color: var(--zz-ink); }
.zz-tag--accent { background: var(--zz-burgundy); color: var(--zz-paper); border-color: var(--zz-burgundy); }

/* ---------- 7. Section 通用 ---------- */
.zz-section { padding: var(--zz-s9) 0; }
.zz-section--tight { padding: var(--zz-s7) 0; }
.zz-section__head {
    display: flex; align-items: flex-end; justify-content: space-between;
    gap: var(--zz-s5); margin-bottom: var(--zz-s7);
    padding-bottom: var(--zz-s4);
    border-bottom: 2px solid var(--zz-line);
}
.zz-section__title-wrap { min-width: 0; }
.zz-section__eyebrow {
    font-family: var(--zz-font-sans);
    font-size: 11px; font-weight: 600;
    text-transform: uppercase; letter-spacing: 0.15em;
    color: var(--zz-burgundy);
    margin-bottom: var(--zz-s2);
    display: flex; align-items: center; gap: var(--zz-s2);
}
.zz-section__eyebrow::before {
    content: ''; display: inline-block;
    width: 24px; height: 1px; background: var(--zz-burgundy);
}
.zz-section__title {
    font-family: var(--zz-font-serif);
    font-size: clamp(32px, 4vw, 48px);
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: -0.015em;
    color: var(--zz-ink);
}
.zz-section__more {
    font-family: var(--zz-font-sans);
    font-size: 12px; font-weight: 600;
    text-transform: uppercase; letter-spacing: 0.1em;
    color: var(--zz-ink-3);
    display: inline-flex; align-items: center; gap: 4px;
}
.zz-section__more::after { content: '→'; transition: transform .2s ease; }
.zz-section__more:hover { color: var(--zz-burgundy); opacity: 1; }
.zz-section__more:hover::after { transform: translateX(3px); }

/* ---------- 8. 首页 Hero（大特写 + 编辑推荐）---------- */
.zz-hero {
    padding: var(--zz-s9) 0 var(--zz-s8);
    position: relative;
}
.zz-hero__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--zz-s7);
    align-items: center;
}
.zz-hero__eyebrow {
    font-family: var(--zz-font-sans);
    font-size: 12px; font-weight: 600;
    text-transform: uppercase; letter-spacing: 0.15em;
    color: var(--zz-burgundy);
    margin-bottom: var(--zz-s3);
    display: flex; align-items: center; gap: var(--zz-s2);
}
.zz-hero__eyebrow::before {
    content: ''; display: inline-block;
    width: 32px; height: 1px; background: var(--zz-burgundy);
}
.zz-hero__title {
    font-family: var(--zz-font-serif);
    font-size: clamp(48px, 7vw, 96px);
    font-weight: 700;
    line-height: 0.95;
    letter-spacing: -0.025em;
    color: var(--zz-ink);
    margin-bottom: var(--zz-s4);
}
.zz-hero__title em {
    font-style: italic; font-weight: 400;
    color: var(--zz-burgundy);
}
.zz-hero__lede {
    font-family: var(--zz-font-serif);
    font-style: italic;
    font-size: 20px;
    color: var(--zz-ink-3);
    line-height: 1.5;
    max-width: 540px;
    margin-bottom: var(--zz-s5);
}
.zz-hero__meta {
    display: flex; gap: var(--zz-s5);
    padding-top: var(--zz-s4);
    border-top: 1px solid var(--zz-line-2);
    color: var(--zz-ink-3);
    font-size: 13px;
}
.zz-hero__meta strong {
    display: block;
    font-family: var(--zz-font-serif);
    font-size: 32px; font-weight: 700;
    line-height: 1;
    color: var(--zz-ink);
    margin-top: 4px;
}
.zz-hero__featured {
    aspect-ratio: 3/4;
    background: var(--zz-paper-2);
    overflow: hidden;
    position: relative;
    border: 1px solid var(--zz-line);
}
.zz-hero__featured-img {
    position: absolute; inset: 0;
    width: 100%; height: 100%;
    object-fit: cover;
}
.zz-hero__featured-overlay {
    position: absolute; left: 0; right: 0; bottom: 0;
    background: linear-gradient(transparent 50%, rgba(255,255,255,.95) 100%);
    padding: var(--zz-s5);
    display: flex; flex-direction: column; gap: var(--zz-s2);
}
.zz-hero__featured-eyebrow {
    font-family: var(--zz-font-sans);
    font-size: 11px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.15em;
    color: var(--zz-paper);
    background: var(--zz-burgundy);
    padding: 4px 10px;
    align-self: flex-start;
}
.zz-hero__featured-title {
    font-family: var(--zz-font-serif);
    font-size: 28px; font-weight: 700; line-height: 1.15;
    color: var(--zz-ink);
}
.zz-hero__featured-author { font-size: 14px; color: var(--zz-ink-3); }
.zz-hero__featured-desc {
    font-size: 14px; color: var(--zz-ink-3); line-height: 1.6;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}

/* ---------- 9. 书籍卡（杂志 4 列网格）---------- */
.zz-book-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--zz-s5) var(--zz-s4);
}
.zz-book-grid--3 { grid-template-columns: repeat(3, 1fr); }
.zz-book-grid--6 { grid-template-columns: repeat(6, 1fr); gap: var(--zz-s4) var(--zz-s3); }
.zz-book-grid--8 { grid-template-columns: repeat(8, 1fr); gap: var(--zz-s3) var(--zz-s2); }

.zz-book-card { display: flex; flex-direction: column; gap: var(--zz-s3); }
.zz-book-card__cover {
    aspect-ratio: 3/4;
    background: var(--zz-paper-2);
    overflow: hidden;
    border: 1px solid var(--zz-line);
    position: relative;
    transition: transform .3s ease;
}
.zz-book-card__cover:hover { transform: translateY(-4px); }
.zz-book-card__cover img { width: 100%; height: 100%; object-fit: cover; }
.zz-book-card__num {
    position: absolute; top: 0; left: 0;
    font-family: var(--zz-font-serif);
    font-style: italic; font-weight: 700;
    font-size: 14px;
    color: var(--zz-paper);
    background: var(--zz-ink);
    padding: 4px 10px;
}
.zz-book-card__title {
    font-family: var(--zz-font-serif);
    font-size: 17px; font-weight: 600;
    line-height: 1.35;
    color: var(--zz-ink);
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.zz-book-card__author { font-size: 13px; color: var(--zz-ink-4); font-style: italic; }
.zz-book-card__meta { display: flex; gap: var(--zz-s2); font-size: 11px; color: var(--zz-ink-4); text-transform: uppercase; letter-spacing: 0.1em; }

/* 横排小卡（侧栏） */
.zz-book-mini { display: flex; gap: var(--zz-s3); padding: var(--zz-s3) 0; border-bottom: 1px solid var(--zz-line-2); }
.zz-book-mini:last-child { border-bottom: 0; }
.zz-book-mini__cover { flex: 0 0 60px; width: 60px; height: 80px; background: var(--zz-paper-2); overflow: hidden; border: 1px solid var(--zz-line); }
.zz-book-mini__cover img { width: 100%; height: 100%; object-fit: cover; }
.zz-book-mini__body { flex: 1; min-width: 0; }
.zz-book-mini__title { font-family: var(--zz-font-serif); font-size: 15px; font-weight: 600; line-height: 1.4; margin-bottom: 4px; }
.zz-book-mini__author { font-size: 12px; color: var(--zz-ink-4); font-style: italic; }

/* 文字列表（侧栏） */
.zz-text-list { display: flex; flex-direction: column; }
.zz-text-list__item {
    display: flex; justify-content: space-between; align-items: center; gap: var(--zz-s3);
    padding: var(--zz-s3) 0; border-bottom: 1px solid var(--zz-line-2);
    font-size: 14px;
}
.zz-text-list__item:last-child { border-bottom: 0; }
.zz-text-list__rank {
    flex: 0 0 32px;
    font-family: var(--zz-font-serif);
    font-style: italic; font-size: 16px; font-weight: 700;
    color: var(--zz-ink-4);
    text-align: center;
}
.zz-text-list__item:nth-child(1) .zz-text-list__rank,
.zz-text-list__item:nth-child(2) .zz-text-list__rank,
.zz-text-list__item:nth-child(3) .zz-text-list__rank {
    color: var(--zz-burgundy);
    font-size: 20px;
}
.zz-text-list__title { flex: 1; min-width: 0; color: var(--zz-ink-2); }
.zz-text-list__title:hover { color: var(--zz-burgundy); opacity: 1; }
.zz-text-list__meta { flex: 0 0 auto; font-size: 11px; color: var(--zz-ink-4); text-transform: uppercase; letter-spacing: 0.1em; font-family: var(--zz-font-sans); }

/* ---------- 10. 风云榜（双列文字榜）---------- */
.zz-ranking {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0 var(--zz-s6);
    border-top: 2px solid var(--zz-line);
    padding-top: var(--zz-s4);
}
.zz-ranking__col { display: flex; flex-direction: column; }

/* ---------- 11. 分类 tab（编号系统）---------- */
.zz-tabs { margin-bottom: var(--zz-s6); border-bottom: 1px solid var(--zz-line-2); }
.zz-tabs__list {
    display: flex; gap: var(--zz-s6);
    overflow-x: auto;
    scrollbar-width: none; -ms-overflow-style: none;
}
.zz-tabs__list::-webkit-scrollbar { display: none; }
.zz-tabs__btn {
    padding: var(--zz-s3) 0;
    font-family: var(--zz-font-sans);
    font-size: 12px; font-weight: 600;
    text-transform: uppercase; letter-spacing: 0.1em;
    color: var(--zz-ink-3);
    white-space: nowrap;
    position: relative;
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
    transition: all .15s ease;
}
.zz-tabs__btn::before {
    content: counter(zz-tab); counter-increment: zz-tab;
    font-family: var(--zz-font-serif);
    font-style: italic; font-weight: 400;
    color: var(--zz-burgundy);
    margin-right: var(--zz-s2);
}
.zz-tabs__list { counter-reset: zz-tab; }
.zz-tabs__btn:hover { color: var(--zz-ink); opacity: 1; }
.zz-tabs__btn.is-active { color: var(--zz-ink); border-bottom-color: var(--zz-burgundy); font-weight: 700; }
.zz-tabs__panel { display: none; }
.zz-tabs__panel.is-active { display: block; }

/* ---------- 12. 面包屑 ---------- */
.zz-crumb {
    display: flex; flex-wrap: wrap; align-items: center; gap: var(--zz-s2);
    font-size: 13px;
    color: var(--zz-ink-4);
    padding: var(--zz-s5) 0 var(--zz-s4);
    text-transform: uppercase; letter-spacing: 0.05em;
}
.zz-crumb a { color: var(--zz-ink-3); }
.zz-crumb a:hover { color: var(--zz-burgundy); opacity: 1; }
.zz-crumb__sep { color: var(--zz-ink-5); }
.zz-crumb__current { color: var(--zz-ink); font-weight: 600; }

/* ---------- 13. 详情页（书详情）---------- */
.zz-detail { padding: var(--zz-s7) 0 var(--zz-s9); }

/* Head: cover + info */
.zz-detail__head {
    display: grid;
    grid-template-columns: 360px 1fr;
    gap: var(--zz-s7);
    padding-bottom: var(--zz-s7);
    border-bottom: 1px solid var(--zz-line);
    margin-bottom: var(--zz-s7);
}
.zz-detail__cover {
    aspect-ratio: 3/4;
    background: var(--zz-paper-2);
    overflow: hidden;
    border: 1px solid var(--zz-line);
    display: block;
}
.zz-detail__cover img { width: 100%; height: 100%; object-fit: cover; display: block; }

.zz-detail__info {
    display: flex; flex-direction: column;
    gap: var(--zz-s3);
    min-width: 0;
}

.zz-detail__eyebrow {
    font-family: var(--zz-font-sans);
    font-size: 11px; font-weight: 600;
    text-transform: uppercase; letter-spacing: 0.15em;
    color: var(--zz-burgundy);
    display: flex; align-items: center; gap: var(--zz-s2);
}
.zz-detail__eyebrow::before {
    content: ''; display: inline-block;
    width: 24px; height: 1px; background: var(--zz-burgundy);
}
.zz-detail__title {
    font-family: var(--zz-font-serif);
    font-size: clamp(40px, 5vw, 64px);
    font-weight: 700;
    line-height: 1.05;
    letter-spacing: -0.02em;
    color: var(--zz-ink);
}
.zz-detail__meta {
    display: flex; flex-wrap: wrap;
    gap: var(--zz-s2) var(--zz-s5);
    color: var(--zz-ink-3);
    font-size: 14px;
    padding-bottom: var(--zz-s3);
    border-bottom: 1px solid var(--zz-line-2);
}
.zz-detail__meta strong { color: var(--zz-ink); font-weight: 600; }
.zz-detail__meta strong.zz-italic { font-family: var(--zz-font-serif); font-style: italic; font-weight: 400; }

.zz-detail__desc {
    font-family: var(--zz-font-serif);
    font-size: 17px;
    line-height: 1.7;
    color: var(--zz-ink-2);
    display: -webkit-box; -webkit-line-clamp: 4; -webkit-box-orient: vertical; overflow: hidden;
}
.zz-detail__desc.is-expanded {
    display: block;
    -webkit-line-clamp: unset;
    -webkit-box-orient: unset;
    overflow: visible;
}
.zz-detail__excerpt-toggle {
    display: inline-flex; align-items: center; gap: 4px;
    align-self: flex-start;
    margin-top: var(--zz-s2);
    font-family: var(--zz-font-sans);
    font-size: 12px; font-weight: 600;
    text-transform: uppercase; letter-spacing: 0.1em;
    color: var(--zz-ink-3);
    padding: 8px 0;
    border: 0; border-bottom: 1px solid var(--zz-line);
    background: transparent;
    cursor: pointer;
}
.zz-detail__excerpt-toggle::after { content: ' ↓'; }
.zz-detail__excerpt-toggle.is-expanded::after { content: ' ↑'; }
.zz-detail__excerpt-toggle:hover { color: var(--zz-burgundy); border-color: var(--zz-burgundy); }

.zz-detail__tags { display: flex; flex-wrap: wrap; gap: var(--zz-s2); }

.zz-detail__actions { display: flex; gap: var(--zz-s3); margin-top: var(--zz-s3); }
.zz-detail__actions .zz-btn { flex: 1; }

/* 主体 + 侧栏 */
.zz-detail__body {
    display: grid;
    grid-template-columns: 1fr 360px;
    gap: var(--zz-s8);
    align-items: flex-start;
}
.zz-detail__main { min-width: 0; }
.zz-detail__side { display: flex; flex-direction: column; gap: var(--zz-s6); }

/* ---------- 14. 章节列表（杂志 4 列满）---------- */
.zz-chapter-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
    border-top: 1px solid var(--zz-line);
    border-left: 1px solid var(--zz-line);
}
.zz-chapter-grid a {
    padding: var(--zz-s3) var(--zz-s2);
    font-size: 13px;
    color: var(--zz-ink-2);
    border-bottom: 1px solid var(--zz-line);
    border-right: 1px solid var(--zz-line);
    display: block;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    transition: all .15s ease;
}
.zz-chapter-grid a:hover { background: var(--zz-cream); color: var(--zz-burgundy); opacity: 1; }
.zz-chapter-grid a::before {
    content: counter(zz-ch) ". ";
    counter-increment: zz-ch;
    font-family: var(--zz-font-serif);
    font-style: italic;
    color: var(--zz-ink-4);
    margin-right: 4px;
}
.zz-chapter-grid { counter-reset: zz-ch; }

/* ---------- 15. 精彩节选 ---------- */
.zz-detail__excerpt {
    font-size: 15px;
    line-height: 1.85;
    color: var(--zz-ink-2);
    max-height: 12em;
    overflow: hidden;
    position: relative;
}
.zz-detail__excerpt::after {
    content: '';
    position: absolute; left: 0; right: 0; bottom: 0; height: 3em;
    background: linear-gradient(transparent, var(--zz-paper));
    pointer-events: none;
}
.zz-detail__excerpt.is-expanded { max-height: none; }
.zz-detail__excerpt.is-expanded::after { display: none; }
.zz-detail__excerpt-toggle.zz-detail__excerpt-toggle--excerpt {
    display: inline-flex; align-items: center; gap: 4px;
    margin-top: var(--zz-s3);
    font-size: 12px; font-weight: 600;
    text-transform: uppercase; letter-spacing: 0.1em;
    color: var(--zz-ink-3);
    padding: 8px 0;
    border: 0; border-bottom: 1px solid var(--zz-line);
    background: transparent;
    cursor: pointer;
}
.zz-detail__excerpt-toggle.zz-detail__excerpt-toggle--excerpt::after { content: ' ↓'; }
.zz-detail__excerpt-toggle.zz-detail__excerpt-toggle--excerpt.is-expanded::after { content: ' ↑'; }

/* ---------- 16. 详情页内 section（block）---------- */
.zz-block { margin-bottom: var(--zz-s8); }
.zz-block__head {
    display: flex; align-items: baseline; justify-content: space-between;
    margin-bottom: var(--zz-s5);
    padding-bottom: var(--zz-s3);
    border-bottom: 1px solid var(--zz-line);
}
.zz-block__title {
    font-family: var(--zz-font-serif);
    font-size: 28px; font-weight: 700;
    letter-spacing: -0.01em;
    margin: 0;
    display: flex; align-items: baseline; gap: var(--zz-s2);
}
.zz-block__title-num {
    font-family: var(--zz-font-serif);
    font-style: italic; font-size: 16px; font-weight: 400;
    color: var(--zz-burgundy);
}
.zz-block__more {
    font-family: var(--zz-font-sans);
    font-size: 12px; font-weight: 600;
    text-transform: uppercase; letter-spacing: 0.1em;
    color: var(--zz-ink-3);
}
.zz-block__more:hover { color: var(--zz-burgundy); opacity: 1; }
.zz-block__body { padding: 0; }

/* ---------- 17. 侧栏模块（编辑推荐风）---------- */
.zz-side-block {
    padding-bottom: var(--zz-s5);
    border-bottom: 1px solid var(--zz-line);
}
.zz-side-block:last-child { border-bottom: 0; }
.zz-side-block__head {
    margin-bottom: var(--zz-s4);
    padding-bottom: var(--zz-s2);
    border-bottom: 1px solid var(--zz-line);
}
.zz-side-block__title {
    font-family: var(--zz-font-serif);
    font-size: 20px; font-weight: 700;
    letter-spacing: -0.01em;
    margin: 0;
    display: flex; align-items: baseline; gap: var(--zz-s2);
}
.zz-side-block__more {
    font-size: 11px; font-weight: 600;
    text-transform: uppercase; letter-spacing: 0.1em;
    color: var(--zz-ink-3);
}
.zz-side-block__more:hover { color: var(--zz-burgundy); opacity: 1; }

/* ---------- 18. 阅读页（bookChapter）---------- */
.zz-reader { padding: var(--zz-s6) 0 var(--zz-s10); background: var(--zz-paper); }
.zz-reader__head { text-align: center; margin-bottom: var(--zz-s7); padding-bottom: var(--zz-s5); border-bottom: 1px solid var(--zz-line); }
.zz-reader__book { font-size: 13px; color: var(--zz-ink-3); margin-bottom: var(--zz-s2); text-transform: uppercase; letter-spacing: 0.1em; }
.zz-reader__book a { color: var(--zz-ink-3); }
.zz-reader__book a:hover { color: var(--zz-burgundy); }
.zz-reader__title {
    font-family: var(--zz-font-serif);
    font-size: clamp(28px, 4vw, 40px);
    font-weight: 700;
    line-height: 1.2;
    letter-spacing: -0.01em;
}
.zz-reader__meta { font-size: 12px; color: var(--zz-ink-4); margin-top: var(--zz-s2); }

.zz-reader__content {
    margin: 0 auto;
    max-width: 760px;
    font-size: 18px;
    line-height: 1.85;
    color: var(--zz-ink-2);
}
.zz-reader__content p { margin-bottom: 1.3em; text-indent: 2em; }
.zz-reader__content h1, .zz-reader__content h2, .zz-reader__content h3 { text-indent: 0; margin: 1.5em 0 .8em; font-weight: 700; }
.zz-reader__content img { margin: 1em auto; max-width: 100%; }

/* 阅读页导航 */
.zz-reader__nav {
    margin: var(--zz-s7) auto 0; max-width: 760px;
    display: flex; gap: var(--zz-s3);
    padding-top: var(--zz-s6);
    border-top: 1px solid var(--zz-line);
}
.zz-reader__nav .zz-btn { flex: 1; }

/* 进度条 */
.zz-progress {
    position: fixed; left: 0; right: 0; bottom: 0;
    height: 3px; background: var(--zz-line-2);
    z-index: 50;
}
.zz-progress__bar {
    height: 100%; background: var(--zz-burgundy);
    width: 0%;
    transition: width .1s linear;
}

/* 浮动工具条 */
.zz-tb {
    position: fixed; right: var(--zz-s5); bottom: var(--zz-s6); z-index: 60;
    display: flex; flex-direction: column; gap: 6px;
    background: var(--zz-paper); border: 1px solid var(--zz-line);
    padding: 6px;
}
.zz-tb__btn {
    width: 36px; height: 36px;
    display: flex; align-items: center; justify-content: center;
    color: var(--zz-ink-2);
    position: relative;
    transition: all .15s ease;
}
.zz-tb__btn:hover { background: var(--zz-burgundy); color: var(--zz-paper); }
.zz-tb__btn svg { width: 16px; height: 16px; }
.zz-tb__tip {
    position: absolute; right: 100%; top: 50%; transform: translateY(-50%);
    margin-right: var(--zz-s2);
    padding: 4px 10px;
    font-size: 12px;
    color: var(--zz-paper);
    background: var(--zz-ink);
    white-space: nowrap;
    opacity: 0; pointer-events: none;
    transition: opacity .15s ease;
}
.zz-tb__btn:hover .zz-tb__tip { opacity: 1; }

/* 字号/主题弹窗 */
.zz-popup {
    position: fixed; right: var(--zz-s5); bottom: calc(var(--zz-s6) + 60px);
    z-index: 60;
    background: var(--zz-paper);
    border: 1px solid var(--zz-line);
    padding: var(--zz-s4);
    min-width: 240px;
    display: none;
}
.zz-popup.is-open { display: block; }
.zz-popup__title {
    font-family: var(--zz-font-sans);
    font-size: 11px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.15em;
    color: var(--zz-ink-3);
    margin-bottom: var(--zz-s3);
    padding-bottom: var(--zz-s2);
    border-bottom: 1px solid var(--zz-line-2);
}
.zz-popup__opts { display: flex; gap: 4px; margin-bottom: var(--zz-s3); }
.zz-popup__opt {
    flex: 1; height: 36px;
    display: flex; align-items: center; justify-content: center;
    border: 1px solid var(--zz-line-2);
    font-family: var(--zz-font-sans);
    font-size: 12px; font-weight: 500;
    color: var(--zz-ink-2);
    cursor: pointer;
    transition: all .15s ease;
}
.zz-popup__opt:hover { border-color: var(--zz-ink); color: var(--zz-ink); }
.zz-popup__opt.is-active { background: var(--zz-ink); border-color: var(--zz-ink); color: var(--zz-paper); }

/* 目录抽屉 */
.zz-toc {
    position: fixed; inset: 0; z-index: 150;
    background: var(--zz-paper);
    display: none; flex-direction: column;
}
.zz-toc.is-open { display: flex; }
.zz-toc__top {
    display: flex; align-items: center; justify-content: space-between;
    padding: var(--zz-s4);
    border-bottom: 1px solid var(--zz-line);
}
.zz-toc__title { font-family: var(--zz-font-serif); font-size: 20px; font-weight: 700; }
.zz-toc__close { width: 36px; height: 36px; font-size: 22px; }
.zz-toc__list { flex: 1; overflow-y: auto; padding: var(--zz-s2) 0; }
.zz-toc__item a {
    display: flex; gap: var(--zz-s2); align-items: baseline;
    padding: var(--zz-s3) var(--zz-s4);
    font-size: 14px; color: var(--zz-ink-2);
    border-bottom: 1px solid var(--zz-line-2);
}
.zz-toc__item a::before {
    content: counter(zz-toc) ". ";
    counter-increment: zz-toc;
    font-family: var(--zz-font-serif);
    font-style: italic;
    color: var(--zz-ink-4);
    min-width: 32px;
}
.zz-toc__list { counter-reset: zz-toc; }
.zz-toc__item a:hover { background: var(--zz-cream); color: var(--zz-burgundy); opacity: 1; }
.zz-toc__item.is-current a { background: var(--zz-cream); color: var(--zz-burgundy); font-weight: 600; }
.zz-toc__list::-webkit-scrollbar { display: none; }
.zz-toc__list { scrollbar-width: none; -ms-overflow-style: none; }

/* 阅读器主题 */
.zz-reader--dark { background: #0a0a0a; }
.zz-reader--dark .zz-reader__head { border-color: #2a2a2a; }
.zz-reader--dark .zz-reader__title { color: #ececec; }
.zz-reader--dark .zz-reader__book, .zz-reader--dark .zz-reader__book a, .zz-reader--dark .zz-reader__meta { color: #8a8a8a; }
.zz-reader--dark .zz-reader__content { color: #c0c0c0; }
.zz-reader--dark .zz-reader__nav { border-color: #2a2a2a; }
.zz-reader--dark .zz-tb { background: #1a1a1a; border-color: #2a2a2a; }
.zz-reader--dark .zz-tb__btn { color: #c0c0c0; }
.zz-reader--dark .zz-tb__btn:hover { background: var(--zz-burgundy); color: var(--zz-paper); }
.zz-reader--dark .zz-popup { background: #1a1a1a; border-color: #2a2a2a; }
.zz-reader--dark .zz-popup__title { color: #8a8a8a; border-color: #2a2a2a; }
.zz-reader--dark .zz-popup__opt { border-color: #2a2a2a; color: #c0c0c0; }
.zz-reader--dark .zz-popup__opt.is-active { background: var(--zz-burgundy); border-color: var(--zz-burgundy); color: var(--zz-paper); }
.zz-reader--dark .zz-progress { background: #2a2a2a; }
.zz-reader--dark .zz-progress__bar { background: var(--zz-burgundy); }
.zz-reader--dark .zz-toc { background: #0a0a0a; }
.zz-reader--dark .zz-toc__top { border-color: #2a2a2a; }
.zz-reader--dark .zz-toc__title { color: #ececec; }
.zz-reader--dark .zz-toc__item a { color: #c0c0c0; border-color: #2a2a2a; }
.zz-reader--dark .zz-toc__item a:hover { background: #1a1a1a; color: var(--zz-burgundy); }
.zz-reader--dark .zz-toc__item.is-current a { background: var(--zz-burgundy); color: var(--zz-paper); }

.zz-reader--sepia { background: #f4ecd8; }
.zz-reader--sepia .zz-reader__content { color: #5b4636; }
.zz-reader--sepia .zz-reader__head { border-color: #d8c8a8; }
.zz-reader--sepia .zz-reader__title { color: #2c1810; }
.zz-reader--sepia .zz-reader__book, .zz-reader--sepia .zz-reader__book a, .zz-reader--sepia .zz-reader__meta { color: #8a7355; }
.zz-reader--sepia .zz-reader__nav { border-color: #d8c8a8; }

.zz-reader--forest { background: #f0f4ed; }
.zz-reader--forest .zz-reader__content { color: #2a3a1e; }
.zz-reader--forest .zz-reader__head { border-color: #c8d4be; }
.zz-reader--forest .zz-reader__title { color: #1a2410; }
.zz-reader--forest .zz-reader__book, .zz-reader--forest .zz-reader__book a, .zz-reader--forest .zz-reader__meta { color: #5a6a4e; }
.zz-reader--forest .zz-reader__nav { border-color: #c8d4be; }

/* 阅读页字号档 */
.zz-reader[data-size="1"] .zz-reader__content { font-size: 16px; max-width: 660px; }
.zz-reader[data-size="2"] .zz-reader__content { font-size: 18px; max-width: 760px; }
.zz-reader[data-size="3"] .zz-reader__content { font-size: 20px; max-width: 860px; }
.zz-reader[data-size="4"] .zz-reader__content { font-size: 22px; max-width: 960px; }
.zz-reader[data-line="1"] .zz-reader__content { line-height: 1.7; }
.zz-reader[data-line="2"] .zz-reader__content { line-height: 1.85; }
.zz-reader[data-line="3"] .zz-reader__content { line-height: 2.0; }

/* ---------- 19. 文章列表（杂志版）---------- */
.zz-article-list { display: flex; flex-direction: column; }
.zz-article-item {
    display: grid;
    grid-template-columns: 240px 1fr;
    gap: var(--zz-s5);
    padding: var(--zz-s5) 0;
    border-bottom: 1px solid var(--zz-line);
}
.zz-article-item:last-child { border-bottom: 0; }
.zz-article-item__cover { aspect-ratio: 4/3; background: var(--zz-paper-2); overflow: hidden; }
.zz-article-item__cover img { width: 100%; height: 100%; object-fit: cover; }
.zz-article-item__body { min-width: 0; }
.zz-article-item__title {
    font-family: var(--zz-font-serif);
    font-size: 22px; font-weight: 700; line-height: 1.25;
    margin-bottom: var(--zz-s2);
}
.zz-article-item__title:hover { color: var(--zz-burgundy); opacity: 1; }
.zz-article-item__desc { font-size: 14px; color: var(--zz-ink-3); line-height: 1.6; margin-bottom: var(--zz-s3); }
.zz-article-item__meta { display: flex; gap: var(--zz-s3); font-size: 12px; color: var(--zz-ink-4); text-transform: uppercase; letter-spacing: 0.1em; }

/* ---------- 20. 文章详情 ---------- */
.zz-article { padding: var(--zz-s7) 0; }
.zz-article__head { text-align: center; margin-bottom: var(--zz-s7); padding-bottom: var(--zz-s5); border-bottom: 1px solid var(--zz-line); }
.zz-article__title {
    font-family: var(--zz-font-serif);
    font-size: clamp(32px, 5vw, 56px);
    font-weight: 700;
    line-height: 1.15;
    letter-spacing: -0.015em;
    margin-bottom: var(--zz-s3);
}
.zz-article__meta { display: flex; flex-wrap: wrap; justify-content: center; gap: var(--zz-s4); font-size: 13px; color: var(--zz-ink-3); text-transform: uppercase; letter-spacing: 0.1em; }
.zz-article__body {
    max-width: 760px;
    margin: 0 auto;
    font-family: var(--zz-font-serif);
    font-size: 17px;
    line-height: 1.85;
    color: var(--zz-ink-2);
}
.zz-article__body p { margin-bottom: 1.2em; }
.zz-article__body h1, .zz-article__body h2, .zz-article__body h3 { margin: 1.5em 0 .8em; font-weight: 700; }
.zz-article__body img { margin: 1.5em auto; }

/* ---------- 21. 搜索页 ---------- */
.zz-search-hero { padding: var(--zz-s9) 0 var(--zz-s6); text-align: center; }
.zz-search-form {
    display: flex; max-width: 720px; margin: 0 auto var(--zz-s4);
    border: 1px solid var(--zz-ink);
}
.zz-search-form__input {
    flex: 1; height: 64px; padding: 0 var(--zz-s5);
    border: 0; outline: 0;
    font-family: var(--zz-font-serif);
    font-size: 20px; font-style: italic;
    background: var(--zz-paper);
}
.zz-search-form__btn {
    width: 64px; background: var(--zz-ink); color: var(--zz-paper);
    display: flex; align-items: center; justify-content: center;
    border: 0; cursor: pointer;
    transition: all .15s ease;
}
.zz-search-form__btn:hover { background: var(--zz-burgundy); }
.zz-search-form__btn svg { width: 20px; height: 20px; stroke: currentColor; fill: none; stroke-width: 2; }
.zz-search-keywords { display: flex; flex-wrap: wrap; gap: var(--zz-s2); justify-content: center; max-width: 760px; margin: 0 auto; }
.zz-search-keywords__item {
    font-size: 13px; color: var(--zz-ink-3);
    padding: 6px 14px;
    border: 1px solid var(--zz-line-2);
    transition: all .15s ease;
}
.zz-search-keywords__item:hover { color: var(--zz-burgundy); border-color: var(--zz-burgundy); opacity: 1; }
.zz-search-empty { text-align: center; padding: var(--zz-s9) 0; }
.zz-search-empty img { width: 80px; margin: 0 auto var(--zz-s3); opacity: .5; }
.zz-search-empty p { color: var(--zz-ink-3); font-family: var(--zz-font-serif); font-style: italic; font-size: 18px; }

/* ---------- 22. 分页 ---------- */
.zz-pagination {
    display: flex; flex-wrap: wrap; gap: 4px; justify-content: center;
    padding: var(--zz-s6) 0;
}
.zz-pagination a, .zz-pagination span {
    min-width: 40px; height: 40px; padding: 0 var(--zz-s3);
    display: inline-flex; align-items: center; justify-content: center;
    font-family: var(--zz-font-sans);
    font-size: 13px;
    color: var(--zz-ink-2);
    border: 1px solid var(--zz-line);
    transition: all .15s ease;
}
.zz-pagination a:hover { border-color: var(--zz-ink); color: var(--zz-ink); }
.zz-pagination .current {
    background: var(--zz-burgundy);
    border-color: var(--zz-burgundy);
    color: var(--zz-paper);
}

/* ---------- 23. sitemap 列表 ---------- */
.zz-sitemap-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: var(--zz-s3);
}
.zz-sitemap-grid a {
    display: block; padding: var(--zz-s3);
    font-size: 14px; color: var(--zz-ink-2);
    border: 1px solid var(--zz-line-2);
    word-break: break-all;
    transition: all .15s ease;
}
.zz-sitemap-grid a:hover { border-color: var(--zz-ink); color: var(--zz-ink); opacity: 1; }

/* ---------- 24. 友链申请 ---------- */
.zz-form { display: flex; flex-direction: column; gap: var(--zz-s4); max-width: 640px; margin: 0 auto; }
.zz-form__field { display: flex; flex-direction: column; gap: var(--zz-s2); }
.zz-form__label {
    font-family: var(--zz-font-sans);
    font-size: 11px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.12em;
    color: var(--zz-ink-3);
}
.zz-form__input, .zz-form__textarea {
    height: 48px; padding: 0 var(--zz-s3);
    border: 1px solid var(--zz-line-2);
    background: var(--zz-paper);
    font-family: var(--zz-font-sans);
    font-size: 15px;
    transition: border-color .15s ease;
}
.zz-form__textarea { height: auto; padding: var(--zz-s3); min-height: 120px; resize: vertical; }
.zz-form__input:focus, .zz-form__textarea:focus { border-color: var(--zz-ink); outline: 0; }

/* ---------- 25. 响应式 ---------- */
@media (max-width: 1200px) {
    body { font-size: 15px; }
    .zz-container { padding: 0 var(--zz-s4); }
    .zz-book-grid { grid-template-columns: repeat(3, 1fr); }
    .zz-book-grid--6 { grid-template-columns: repeat(4, 1fr); }
    .zz-book-grid--8 { grid-template-columns: repeat(6, 1fr); }
    .zz-detail__head { grid-template-columns: 280px 1fr; gap: var(--zz-s6); }
    .zz-detail__body { grid-template-columns: 1fr 300px; gap: var(--zz-s6); }
    .zz-footer__brand { font-size: 48px; }
}
@media (max-width: 992px) {
    .zz-header__inner { grid-template-columns: 1fr auto; gap: var(--zz-s3); }
    .zz-header__brand { font-size: 24px; white-space: nowrap; }
    .zz-header__nav { display: none; }
    .zz-header__burger { display: flex; }
    .zz-hero { padding: var(--zz-s7) 0 var(--zz-s6); }
    .zz-hero__grid { grid-template-columns: 1fr; gap: var(--zz-s6); }
    .zz-book-grid, .zz-book-grid--3 { grid-template-columns: repeat(2, 1fr); }
    .zz-book-grid--6 { grid-template-columns: repeat(3, 1fr); }
    .zz-book-grid--8 { grid-template-columns: repeat(4, 1fr); }
    .zz-detail__head { grid-template-columns: 220px 1fr; gap: var(--zz-s5); }
    .zz-detail__body { grid-template-columns: 1fr; gap: var(--zz-s7); }
    .zz-detail__side { order: 2; }
    .zz-chapter-grid { grid-template-columns: repeat(3, 1fr); }
    .zz-article-item { grid-template-columns: 1fr; }
    .zz-article-item__cover { aspect-ratio: 16/9; }
    .zz-ranking { grid-template-columns: 1fr; gap: 0; }
    .zz-footer__cols { grid-template-columns: 1fr 1fr; }
    .zz-footer__brand { font-size: 40px; }
}
@media (max-width: 640px) {
    body { font-size: 14px; }
    .zz-container { padding: 0 var(--zz-s3); }
    .zz-book-grid, .zz-book-grid--3 { grid-template-columns: repeat(2, 1fr); }
    .zz-book-grid--6 { grid-template-columns: repeat(2, 1fr); }
    .zz-book-grid--8 { grid-template-columns: repeat(2, 1fr); }
    .zz-section { padding: var(--zz-s6) 0; }
    .zz-section__head { flex-direction: column; align-items: flex-start; gap: var(--zz-s3); }
    .zz-section__title { font-size: 32px; }
    .zz-hero { padding: var(--zz-s6) 0; }
    .zz-hero__title { font-size: 40px; }
    .zz-detail__head {
        grid-template-columns: 120px 1fr;
        gap: var(--zz-s3);
        padding-bottom: var(--zz-s5);
    }
    .zz-detail__info { display: contents; }
    .zz-detail__cover { grid-row: 1 / span 3; width: 120px; }
    .zz-detail__eyebrow { grid-column: 2; grid-row: 1; }
    .zz-detail__title { grid-column: 2; grid-row: 2; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; font-size: 20px; }
    .zz-detail__meta { grid-column: 2; grid-row: 3; display: grid; grid-template-columns: 1fr 1fr; gap: 4px; font-size: 11px; }
    .zz-detail__meta span:nth-child(1) { grid-column: 1 / 3; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .zz-detail__meta span:nth-child(2), .zz-detail__meta span:nth-child(3) { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .zz-detail__desc { grid-column: 1 / 3; grid-row: 4; font-size: 14px; }
    .zz-detail__excerpt-toggle { grid-column: 1 / 3; grid-row: 5; }
    .zz-detail__tags { grid-column: 1 / 3; grid-row: 6; }
    .zz-detail__actions { grid-column: 1 / 3; grid-row: 7; gap: var(--zz-s2); }
    .zz-detail__actions .zz-btn { font-size: 11px; padding: 0 var(--zz-s3); }
    .zz-chapter-grid { grid-template-columns: repeat(2, 1fr); }
    .zz-footer { padding: var(--zz-s6) 0 var(--zz-s4); margin-top: var(--zz-s7); }
    .zz-footer__brand { font-size: 32px; }
    .zz-footer__cols { grid-template-columns: 1fr; gap: var(--zz-s5); padding: var(--zz-s4) 0; }
    .zz-tabs__list { gap: var(--zz-s4); }
    .zz-tb { right: var(--zz-s3); bottom: var(--zz-s4); }
    .zz-popup { right: var(--zz-s3); bottom: calc(var(--zz-s4) + 60px); }
    .zz-detail__title { font-size: 24px; }
    .zz-article__title { font-size: 28px; }
    .zz-display { font-size: 48px; }
    .zz-search-form { max-width: 100%; }
}

/* ============================================================
   zazhi v4.0 — 杂志 Editorial 首页 7 段激进重做
   真正 spread：全屏大图轮播 + magazine spread + 单栏 essay + 3 列榜 + 6 类堆叠
   4 段共用 hot 30 本（HERO 5 轮播 + 当月 5 + 视点 5 + 风云 15 = 30）
   ============================================================ */

/* ============================================================
   1. HERO：全屏大图轮播（hot 1-5）
   5 张大图 80vh 切换 + 文字浮在图上 + 5 圆点 + 2 箭头
   ============================================================ */
.zz-hero {
    position: relative;
    height: 70vh;
    min-height: 500px;
    max-height: 720px;
    background: var(--zz-ink);
    overflow: hidden;
}
.zz-hero__track {
    position: relative;
    width: 100%; height: 100%;
}
.zz-hero__slide {
    position: absolute; inset: 0;
    opacity: 0; visibility: hidden;
    transition: opacity 1s ease, visibility 1s ease;
    text-decoration: none;
    color: inherit;
    display: block;
}
.zz-hero__slide.is-active { opacity: 1; visibility: visible; z-index: 1; }
.zz-hero__slide-img {
    position: absolute; inset: 0;
    width: 100%; height: 100%;
    object-fit: cover;
    object-position: center top;
    transform: scale(1.08);
    filter: brightness(0.45) contrast(1.1) saturate(0.9);
}
.zz-hero__slide-overlay {
    position: absolute;
    left: 0; bottom: 0;
    padding: var(--zz-s9) var(--zz-s7);
    z-index: 2;
    color: var(--zz-paper);
    max-width: 900px;
}
.zz-hero__slide-meta {
    display: flex; gap: var(--zz-s3); align-items: center;
    margin-bottom: var(--zz-s4);
}
.zz-hero__slide-eyebrow {
    font-family: var(--zz-font-sans);
    font-size: 12px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.3em;
    color: var(--zz-burgundy);
}
.zz-hero__slide-num {
    font-family: var(--zz-font-serif);
    font-style: italic; font-weight: 700;
    font-size: 18px; color: var(--zz-paper);
}
.zz-hero__slide-title {
    font-family: var(--zz-font-serif);
    font-size: clamp(48px, 6vw, 96px);
    font-weight: 700;
    line-height: 1;
    letter-spacing: -0.025em;
    color: var(--zz-paper);
    margin-bottom: var(--zz-s4);
}
.zz-hero__slide-author {
    font-size: 18px; color: rgba(255,255,255,0.7);
    font-style: italic; margin-bottom: var(--zz-s3);
}
.zz-hero__slide-desc {
    font-family: var(--zz-font-serif);
    font-size: 17px;
    line-height: 1.6;
    color: rgba(255,255,255,0.75);
    max-width: 600px;
    margin-bottom: var(--zz-s5);
    display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden;
}
.zz-hero__slide-cta {
    display: inline-block;
    padding: 14px 36px;
    background: var(--zz-paper);
    color: var(--zz-ink);
    font-family: var(--zz-font-sans);
    font-size: 12px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.25em;
    text-decoration: none;
    transition: all .2s ease;
}
.zz-hero__slide-cta:hover { background: var(--zz-burgundy); color: var(--zz-paper); opacity: 1; }
.zz-hero__slide-cta::after { content: ' \2192'; }

.zz-hero__arrow {
    position: absolute;
    top: 50%; transform: translateY(-50%);
    z-index: 3;
    width: 56px; height: 56px;
    background: rgba(0,0,0,0.4);
    border: 1px solid rgba(255,255,255,0.3);
    color: var(--zz-paper);
    font-family: var(--zz-font-serif);
    font-size: 24px;
    cursor: pointer;
    transition: all .2s ease;
    display: flex; align-items: center; justify-content: center;
}
.zz-hero__arrow:hover { background: var(--zz-burgundy); border-color: var(--zz-burgundy); }
.zz-hero__arrow--prev { left: var(--zz-s5); }
.zz-hero__arrow--next { right: var(--zz-s5); }

.zz-hero__dots {
    position: absolute;
    bottom: var(--zz-s5);
    left: 50%; transform: translateX(-50%);
    z-index: 3;
    display: flex; gap: 12px;
}
.zz-hero__dot {
    width: 40px; height: 2px;
    background: rgba(255,255,255,0.3);
    border: 0; padding: 0; cursor: pointer;
    transition: background .2s ease;
}
.zz-hero__dot.is-active { background: var(--zz-burgundy); }

@media (max-width: 768px) {
    .zz-hero { height: auto; min-height: 0; max-height: none; }
    .zz-hero__slide-overlay { padding: var(--zz-s7) var(--zz-s4); }
}

/* ============================================================
   2. 当月精选：真正的 magazine spread（hot 6-10）
   左 1 大图 + 右 4 小图 2x2 = 跨页 spread
   ============================================================ */
.zz-feature {
    padding: var(--zz-s8) 0;
    border-bottom: 1px solid var(--zz-line);
}
.zz-feature__head {
    margin-bottom: var(--zz-s7);
    padding-bottom: var(--zz-s4);
    border-bottom: 2px solid var(--zz-ink);
}
.zz-feature__eyebrow {
    font-family: var(--zz-font-sans);
    font-size: 12px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.3em;
    color: var(--zz-burgundy);
    margin-bottom: var(--zz-s3);
}
.zz-feature__title {
    font-family: var(--zz-font-serif);
    font-size: clamp(48px, 5vw, 72px);
    font-weight: 700;
    line-height: 1;
    letter-spacing: -0.025em;
    color: var(--zz-ink);
}
.zz-feature__spread {
    display: grid;
    grid-template-columns: 1.1fr 1fr;
    gap: var(--zz-s7);
    align-items: start;
}
.zz-feature__main {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--zz-s5);
    align-items: start;
    text-decoration: none;
    color: inherit;
}
.zz-feature__main-cover {
    aspect-ratio: 3/4;
    background: var(--zz-paper-2);
    overflow: hidden;
    border: 1px solid var(--zz-line);
    max-width: 280px;
    width: 100%;
    margin: 0 auto;
    position: relative;
}
.zz-feature__main-cover img { width: 100%; height: 100%; object-fit: cover; }
.zz-feature__main-num {
    position: absolute; top: 0; left: 0;
    font-family: var(--zz-font-serif);
    font-style: italic; font-weight: 700;
    font-size: 16px; color: var(--zz-paper);
    background: var(--zz-ink);
    padding: 4px 12px;
    z-index: 2;
}
.zz-feature__main-body {
    padding-top: var(--zz-s3);
}
.zz-feature__main-title {
    font-family: var(--zz-font-serif);
    font-size: clamp(28px, 3vw, 42px);
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: -0.02em;
    color: var(--zz-ink);
    margin-bottom: var(--zz-s3);
}
.zz-feature__main:hover .zz-feature__main-title { color: var(--zz-burgundy); }
.zz-feature__main-author { font-size: 14px; color: var(--zz-ink-3); font-style: italic; margin-bottom: var(--zz-s3); }
.zz-feature__main-desc {
    font-family: var(--zz-font-serif);
    font-size: 16px; line-height: 1.7;
    color: var(--zz-ink-2);
    display: -webkit-box; -webkit-line-clamp: 5; -webkit-box-orient: vertical; overflow: hidden;
    margin-bottom: var(--zz-s4);
}
.zz-feature__main-cta {
    display: inline-block;
    font-family: var(--zz-font-sans);
    font-size: 11px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.25em;
    color: var(--zz-paper);
    background: var(--zz-burgundy);
    padding: 12px 28px;
    text-decoration: none;
    transition: all .2s ease;
}
.zz-feature__main-cta:hover { background: var(--zz-ink); opacity: 1; }
.zz-feature__main-cta::after { content: ' \2192'; }

.zz-feature__row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 1fr 1fr;
    gap: var(--zz-s4);
}
.zz-feature__cell {
    display: flex; flex-direction: column; gap: var(--zz-s2);
    text-decoration: none; color: inherit;
}
.zz-feature__cover {
    aspect-ratio: 3/4;
    background: var(--zz-paper-2);
    overflow: hidden;
    border: 1px solid var(--zz-line-2);
    max-width: 150px; margin: 0 auto; width: 100%;
    transition: transform .3s ease, border-color .2s ease;
    position: relative;
}
.zz-feature__cover:hover { transform: translateY(-4px); border-color: var(--zz-burgundy); }
.zz-feature__cover img { width: 100%; height: 100%; object-fit: cover; }
.zz-feature__cover-num {
    position: absolute; top: 0; left: 0;
    font-family: var(--zz-font-serif);
    font-style: italic; font-weight: 700;
    font-size: 12px; color: var(--zz-paper);
    background: var(--zz-ink);
    padding: 3px 8px; z-index: 2;
}
.zz-feature__cell-title {
    font-family: var(--zz-font-serif);
    font-size: 14px; font-weight: 600;
    line-height: 1.3; color: var(--zz-ink);
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
    text-align: center; margin-top: var(--zz-s2);
}
.zz-feature__cell:hover .zz-feature__cell-title { color: var(--zz-burgundy); }
.zz-feature__cell-author { font-size: 11px; color: var(--zz-ink-4); font-style: italic; text-align: center; }

@media (max-width: 992px) {
    .zz-feature__spread { grid-template-columns: 1fr; }
    .zz-feature__main { grid-template-columns: 130px 1fr; gap: var(--zz-s4); }
    .zz-feature__main-body { min-width: 0; }
    .zz-feature__main-title { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .zz-feature__main-desc { -webkit-line-clamp: 2; }
    .zz-feature__main-cover { max-width: 130px; }
}

/* ============================================================
   3. 编辑视点：单栏大字 essay（hot 11-15）"Editor's Letter"
   大引号 + 大段引文 + 5 本书横排纯文字
   ============================================================ */
.zz-lede {
    padding: var(--zz-s10) 0;
    border-bottom: 1px solid var(--zz-line);
    background: var(--zz-paper-2);
}
.zz-lede__inner {
    max-width: 1080px;
    margin: 0 auto;
}
.zz-lede__head { text-align: center; margin-bottom: var(--zz-s7); }
.zz-lede__eyebrow {
    font-family: var(--zz-font-sans);
    font-size: 12px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.3em;
    color: var(--zz-burgundy);
    margin-bottom: var(--zz-s3);
}
.zz-lede__title {
    font-family: var(--zz-font-serif);
    font-size: clamp(48px, 5vw, 72px);
    font-weight: 700;
    line-height: 1;
    letter-spacing: -0.025em;
    color: var(--zz-ink);
}
.zz-lede__essay {
    font-family: var(--zz-font-serif);
    font-size: clamp(20px, 2vw, 24px);
    line-height: 1.7;
    color: var(--zz-ink-2);
    text-align: center;
    margin-bottom: var(--zz-s7);
    padding: 0 var(--zz-s5);
}
.zz-lede__essay::before {
    content: '\201C';
    display: block;
    font-size: 2.5em;
    color: var(--zz-burgundy);
    line-height: 0.5;
    margin-bottom: var(--zz-s4);
}
.zz-lede__essay::after {
    content: '\201D';
    display: block;
    font-size: 2.5em;
    color: var(--zz-burgundy);
    line-height: 0.1;
    margin-top: var(--zz-s2);
}
.zz-lede__author {
    text-align: center;
    font-family: var(--zz-font-serif);
    font-size: 16px; font-style: italic;
    color: var(--zz-ink-3);
    margin-bottom: var(--zz-s8);
}
.zz-lede__author::before { content: '\2014\2014  '; color: var(--zz-burgundy); }
.zz-lede__row {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: var(--zz-s4);
    border-top: 1px solid var(--zz-line);
    padding-top: var(--zz-s5);
}
.zz-lede__cell {
    text-decoration: none; color: inherit;
    text-align: center;
    display: flex; flex-direction: column; gap: var(--zz-s2);
}
.zz-lede__num {
    font-family: var(--zz-font-serif);
    font-style: italic; font-weight: 700;
    font-size: 48px; line-height: 1;
    color: var(--zz-burgundy);
    margin-bottom: var(--zz-s2);
}
.zz-lede__book-title {
    font-family: var(--zz-font-serif);
    font-size: 18px; font-weight: 700;
    line-height: 1.3;
    color: var(--zz-ink);
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.zz-lede__cell:hover .zz-lede__book-title { color: var(--zz-burgundy); }
.zz-lede__book-author {
    font-size: 12px; color: var(--zz-ink-4);
    text-transform: uppercase; letter-spacing: 0.1em;
    font-style: italic;
}
@media (max-width: 1200px) { .zz-lede__row { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 768px) { .zz-lede__row { grid-template-columns: repeat(2, 1fr); } }

/* ============================================================
   4. 风云榜：3 列 × 5 行 = 15 杂志"Top 15"（hot 16-30）
   ============================================================ */
.zz-rank {
    padding: var(--zz-s10) 0;
    border-bottom: 1px solid var(--zz-line);
}
.zz-rank__head {
    display: flex; align-items: baseline; justify-content: space-between;
    margin-bottom: var(--zz-s7);
    padding-bottom: var(--zz-s4);
    border-bottom: 2px solid var(--zz-ink);
}
.zz-rank__eyebrow {
    font-family: var(--zz-font-sans);
    font-size: 12px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.3em;
    color: var(--zz-burgundy);
    margin-bottom: var(--zz-s3);
}
.zz-rank__title {
    font-family: var(--zz-font-serif);
    font-size: clamp(48px, 5vw, 72px);
    font-weight: 700;
    line-height: 1;
    letter-spacing: -0.025em;
    color: var(--zz-ink);
}
.zz-rank__list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0 var(--zz-s7);
}
.zz-rank__row {
    display: grid;
    grid-template-columns: 80px 1fr;
    gap: var(--zz-s3);
    align-items: baseline;
    padding: var(--zz-s4) 0;
    border-bottom: 1px solid var(--zz-line-2);
    transition: background .2s ease;
    text-decoration: none; color: inherit;
}
.zz-rank__row:hover { background: var(--zz-paper-2); opacity: 1; }
.zz-rank__num {
    font-family: var(--zz-font-serif);
    font-style: italic; font-weight: 700;
    font-size: 48px; line-height: 1;
    color: var(--zz-ink-4);
    text-align: right;
}
.zz-rank__row:nth-child(-n+3) .zz-rank__num { color: var(--zz-burgundy); font-size: 64px; }
.zz-rank__body { min-width: 0; }
.zz-rank__rtitle {
    font-family: var(--zz-font-serif);
    font-size: 20px; font-weight: 700;
    line-height: 1.3;
    color: var(--zz-ink);
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
    margin-bottom: 4px;
}
.zz-rank__row:hover .zz-rank__rtitle { color: var(--zz-burgundy); }
.zz-rank__rauthor {
    font-size: 12px; color: var(--zz-ink-4);
    text-transform: uppercase; letter-spacing: 0.1em;
    font-style: italic;
}
@media (max-width: 768px) {
    .zz-rank__list { grid-template-columns: 1fr; }
    .zz-rank__num { font-size: 32px; }
    .zz-rank__row:nth-child(-n+3) .zz-rank__num { font-size: 40px; }
    .zz-rank__rtitle { font-size: 16px; }
}

/* ============================================================
   5. 本月新书：5 列 × 6 行 = 30 本 杂志"目录"（每张更大 ~185px）
   ============================================================ */
.zz-shelf {
    padding: var(--zz-s10) 0;
    border-bottom: 1px solid var(--zz-line);
}
.zz-shelf__head {
    margin-bottom: var(--zz-s7);
    padding-bottom: var(--zz-s4);
    border-bottom: 2px solid var(--zz-ink);
}
.zz-shelf__eyebrow {
    font-family: var(--zz-font-sans);
    font-size: 12px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.3em;
    color: var(--zz-burgundy);
    margin-bottom: var(--zz-s3);
}
.zz-shelf__title {
    font-family: var(--zz-font-serif);
    font-size: clamp(48px, 5vw, 72px);
    font-weight: 700;
    line-height: 1;
    letter-spacing: -0.025em;
    color: var(--zz-ink);
}
.zz-shelf__grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: var(--zz-s5) var(--zz-s4);
}
.zz-shelf__cell {
    display: flex; flex-direction: column; gap: var(--zz-s2);
    text-align: center;
    text-decoration: none; color: inherit;
}
.zz-shelf__cover {
    aspect-ratio: 3/4;
    background: var(--zz-paper-2);
    overflow: hidden;
    border: 1px solid var(--zz-line-2);
    max-width: 185px; margin: 0 auto; width: 100%;
    transition: transform .3s ease, border-color .2s ease;
    position: relative;
}
.zz-shelf__cover:hover { transform: translateY(-4px); border-color: var(--zz-burgundy); }
.zz-shelf__cover img { width: 100%; height: 100%; object-fit: cover; }
.zz-shelf__cell-title {
    font-family: var(--zz-font-serif);
    font-size: 14px; font-weight: 600;
    line-height: 1.3; color: var(--zz-ink);
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
    margin-top: var(--zz-s2);
}
.zz-shelf__cell:hover .zz-shelf__cell-title { color: var(--zz-burgundy); }
.zz-shelf__cell-author { font-size: 11px; color: var(--zz-ink-4); font-style: italic; }
@media (max-width: 1200px) { .zz-shelf__grid { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 768px)  { .zz-shelf__grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 480px)  { .zz-shelf__grid { grid-template-columns: repeat(2, 1fr); } }

/* ============================================================
   6. 分类书架：6 类 1 列堆叠（每类独立 1 段）杂志"索引"
   不再 2x3 网格 - 每类独占 1 段
   ============================================================ */
.zz-catalog {
    padding: var(--zz-s10) 0;
}
.zz-catalog__head {
    margin-bottom: var(--zz-s7);
    padding-bottom: var(--zz-s4);
    border-bottom: 2px solid var(--zz-ink);
}
.zz-catalog__eyebrow {
    font-family: var(--zz-font-sans);
    font-size: 12px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.3em;
    color: var(--zz-burgundy);
    margin-bottom: var(--zz-s3);
}
.zz-catalog__title {
    font-family: var(--zz-font-serif);
    font-size: clamp(48px, 5vw, 72px);
    font-weight: 700;
    line-height: 1;
    letter-spacing: -0.025em;
    color: var(--zz-ink);
}
.zz-catalog__list {
    display: flex; flex-direction: column;
    gap: var(--zz-s9);
}
.zz-catalog__cat {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: var(--zz-s7);
    align-items: start;
    padding-bottom: var(--zz-s7);
    border-bottom: 1px solid var(--zz-line);
}
.zz-catalog__cat:last-child { border-bottom: 0; }
.zz-catalog__info { display: flex; flex-direction: column; gap: var(--zz-s3); }
.zz-catalog__num {
    font-family: var(--zz-font-serif);
    font-style: italic; font-weight: 400;
    font-size: 14px; color: var(--zz-burgundy);
}
.zz-catalog__name {
    font-family: var(--zz-font-serif);
    font-size: 48px; font-weight: 700;
    line-height: 1;
    letter-spacing: -0.02em;
    color: var(--zz-ink);
    margin: var(--zz-s2) 0;
}
.zz-catalog__view {
    font-family: var(--zz-font-sans);
    font-size: 12px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.15em;
    color: var(--zz-ink-3);
    text-decoration: none;
    display: inline-block;
    margin-top: var(--zz-s3);
    padding-top: var(--zz-s3);
    border-top: 1px solid var(--zz-line);
}
.zz-catalog__view:hover { color: var(--zz-burgundy); opacity: 1; }
.zz-catalog__view::after { content: ' \2192'; }
.zz-catalog__row {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: var(--zz-s3);
}
.zz-catalog__cell {
    display: flex; flex-direction: column; gap: var(--zz-s2);
    text-decoration: none; color: inherit;
    text-align: center;
}
.zz-catalog__cover {
    aspect-ratio: 3/4;
    background: var(--zz-paper-2);
    overflow: hidden;
    border: 1px solid var(--zz-line-2);
    max-width: 150px; margin: 0 auto; width: 100%;
    transition: transform .3s ease, border-color .2s ease;
    position: relative;
}
.zz-catalog__cover:hover { transform: translateY(-2px); border-color: var(--zz-ink); }
.zz-catalog__cover img { width: 100%; height: 100%; object-fit: cover; }
.zz-catalog__cell-title {
    font-family: var(--zz-font-serif);
    font-size: 13px; font-weight: 600;
    line-height: 1.3; color: var(--zz-ink);
    display: -webkit-box; -webkit-line-clamp: 1; -webkit-box-orient: vertical; overflow: hidden;
    margin-top: var(--zz-s2);
}
.zz-catalog__cell:hover .zz-catalog__cell-title { color: var(--zz-burgundy); }
.zz-catalog__cell-author { font-size: 11px; color: var(--zz-ink-4); font-style: italic; }
@media (max-width: 1200px) {
    .zz-catalog__row { grid-template-columns: repeat(4, 1fr); }
}
@media (max-width: 768px) {
    .zz-catalog__cat { grid-template-columns: 1fr; }
    .zz-catalog__row { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 480px) {
    .zz-catalog__row { grid-template-columns: repeat(2, 1fr); }
}

/* ============================================================
   7. 编辑寄语：杂志"版权页"大字大引号
   ============================================================ */
.zz-colophon {
    padding: var(--zz-s10) 0;
    text-align: center;
    background: var(--zz-ink);
    color: var(--zz-paper);
    border-top: 4px solid var(--zz-burgundy);
}
.zz-colophon__eyebrow {
    font-family: var(--zz-font-sans);
    font-size: 12px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.3em;
    color: var(--zz-burgundy);
    margin-bottom: var(--zz-s5);
}
.zz-colophon__quote {
    font-family: var(--zz-font-serif);
    font-size: clamp(40px, 5vw, 72px);
    font-style: italic; font-weight: 700;
    line-height: 1.1;
    letter-spacing: -0.02em;
    color: var(--zz-paper);
    max-width: 900px;
    margin: 0 auto var(--zz-s5);
}
.zz-colophon__quote::before,
.zz-colophon__quote::after {
    color: var(--zz-burgundy);
    margin: 0 var(--zz-s2);
}
.zz-colophon__quote::before { content: '\201C'; }
.zz-colophon__quote::after { content: '\201D'; }
.zz-colophon__author {
    font-family: var(--zz-font-serif);
    font-size: 18px; font-style: italic;
    color: var(--zz-ink-5);
}
.zz-colophon__author::before { content: '\2014\2014  '; color: var(--zz-burgundy); }
/* ============================================================
   zazhi v4.12 — 视点 1: 顶部段头 + 5 张大 cover 同步轮播 + 5 项目录全显示
   修复 v4.11 布局 bug: 改用 flex column + .zz-hero__body 包容器（2 列 grid）
   ============================================================ */
.zz-hero {
    display: flex;
    flex-direction: column;
    background: var(--zz-paper);
    overflow: hidden;
    padding-top: 0;
}
.zz-hero__body {
    display: grid;
    grid-template-columns: 1.5fr 1fr;
    min-height: 440px;
    flex: 1;
}
.zz-hero__cover {
    position: relative;
    overflow: hidden;
    background: var(--zz-ink);
    min-height: 440px;
}
.zz-hero__cover-link {
    position: absolute; inset: 0;
    display: block;
    text-decoration: none;
    color: inherit;
    opacity: 0;
    pointer-events: none;
    animation: zz-hero-cover-cycle 25s infinite;
}
.zz-hero__cover-link:nth-child(1) { animation-delay: 0s; }
.zz-hero__cover-link:nth-child(2) { animation-delay: -5s; }
.zz-hero__cover-link:nth-child(3) { animation-delay: -10s; }
.zz-hero__cover-link:nth-child(4) { animation-delay: -15s; }
.zz-hero__cover-link:nth-child(5) { animation-delay: -20s; }
@keyframes zz-hero-cover-cycle {
    0%, 16% { opacity: 1; pointer-events: auto; }
    20%, 100% { opacity: 0; pointer-events: none; }
}
.zz-hero__cover:hover .zz-hero__cover-link { animation-play-state: paused; }
.zz-hero__cover-img {
    width: 100%; height: 100%;
    object-fit: cover;
    opacity: 0.85;
    transition: opacity .4s ease, transform .6s ease;
}
.zz-hero__cover-link:hover .zz-hero__cover-img { opacity: 0.95; transform: scale(1.02); }
.zz-hero__cover-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(180deg,
        rgba(10,10,10,0.25) 0%,
        rgba(10,10,10,0.05) 35%,
        rgba(10,10,10,0.5) 75%,
        rgba(10,10,10,0.92) 100%);
    z-index: 1;
}
.zz-hero__cover-mag {
    position: absolute;
    top: var(--zz-s2); left: var(--zz-s4);
    z-index: 2;
    font-family: var(--zz-font-serif);
    font-style: italic; font-weight: 700;
    font-size: clamp(96px, 11vw, 176px);
    line-height: 0.85;
    color: var(--zz-paper);
    letter-spacing: -0.04em;
    pointer-events: none;
    user-select: none;
}
.zz-hero__cover-info {
    position: absolute;
    left: var(--zz-s4); bottom: var(--zz-s4); right: var(--zz-s4);
    z-index: 2;
    color: var(--zz-paper);
    max-height: calc(100% - var(--zz-s9));
    overflow: hidden;
    display: flex; flex-direction: column; gap: var(--zz-s2);
}
.zz-hero__cover-tagline {
    font-family: var(--zz-font-sans);
    font-size: 11px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.3em;
    color: var(--zz-paper);
    background: var(--zz-burgundy);
    padding: 4px 10px;
    display: inline-block;
    align-self: flex-start;
    margin-bottom: var(--zz-s1);
}
.zz-hero__cover-cat {
    font-family: var(--zz-font-sans);
    font-size: 10px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.2em;
    color: var(--zz-burgundy-2);
    border: 1px solid var(--zz-burgundy-2);
    padding: 3px 8px;
    display: inline-block;
    align-self: flex-start;
    margin-bottom: var(--zz-s1);
}
.zz-hero__cover-desc {
    font-family: var(--zz-font-serif);
    font-size: 13px; line-height: 1.55;
    color: rgba(255,255,255,0.75);
    max-width: 95%;
    display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden;
    margin-top: var(--zz-s1);
}
.zz-hero__cover-tagline {
    font-family: var(--zz-font-sans);
    font-size: 11px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.3em;
    color: var(--zz-paper);
    background: var(--zz-burgundy);
    padding: 5px 12px;
    display: inline-block;
    margin-bottom: var(--zz-s3);
}
.zz-hero__cover-title {
    font-family: var(--zz-font-serif);
    font-size: clamp(24px, 2.5vw, 36px);
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: -0.02em;
    color: var(--zz-paper);
    margin: 0;
    max-width: 95%;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.zz-hero__cover-author {
    font-family: var(--zz-font-serif);
    font-size: 12px; font-style: italic;
    color: rgba(255,255,255,0.7);
}
.zz-hero__cover-author::before {
    content: '——  ';
    color: var(--zz-burgundy-2);
}

.zz-hero__index {
    padding: var(--zz-s3) var(--zz-s3) var(--zz-s4);
    background: var(--zz-paper-2);
    display: flex;
    flex-direction: column;
    border-left: 1px solid var(--zz-line);
}
.zz-hero__index-list {
    flex: 1;
    display: flex;
    flex-direction: column;
}
.zz-hero__index-item {
    flex: 1;
}

/* 顶部段头 (从 .zz-hero__index 内部移到 .zz-hero 顶部,横跨两半) */
.zz-hero__head {
    padding: var(--zz-s3) 0 var(--zz-s3);
    text-align: center;
    background: var(--zz-paper);
    border-bottom: 1px solid var(--zz-line-2);
}
.zz-hero__head-eyebrow {
    font-family: var(--zz-font-sans);
    font-size: 10px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.3em;
    color: var(--zz-burgundy);
    margin-bottom: var(--zz-s1);
    display: inline-flex; align-items: center; gap: var(--zz-s2);
}
.zz-hero__head-eyebrow::before, .zz-hero__head-eyebrow::after {
    content: '';
    display: inline-block;
    width: 24px; height: 1px;
    background: var(--zz-burgundy);
}
.zz-hero__head-title {
    font-family: var(--zz-font-serif);
    font-size: 22px; font-weight: 700;
    line-height: 1.1;
    color: var(--zz-ink);
    margin: 0;
}
.zz-hero__index-item {
    display: grid;
    grid-template-columns: 48px 1fr 20px;
    gap: var(--zz-s3);
    align-items: center;
    padding: var(--zz-s1) 0;
    border-bottom: 1px solid var(--zz-line);
    text-decoration: none;
    color: inherit;
    transition: padding .2s ease, background .2s ease;
    opacity: 0.5;
    animation: zz-hero-index-cycle 25s infinite;
}
.zz-hero__index-item:last-child { border-bottom: 0; }
.zz-hero__index-item:nth-child(1) { animation-delay: 0s; }
.zz-hero__index-item:nth-child(2) { animation-delay: -5s; }
.zz-hero__index-item:nth-child(3) { animation-delay: -10s; }
.zz-hero__index-item:nth-child(4) { animation-delay: -15s; }
.zz-hero__index-item:nth-child(5) { animation-delay: -20s; }
@keyframes zz-hero-index-cycle {
    0%, 16% { opacity: 1; }
    20%, 100% { opacity: 0.5; }
}
.zz-hero__index-item:hover { opacity: 1; animation-play-state: paused; }
.zz-hero__index-num {
    font-family: var(--zz-font-serif);
    font-style: italic; font-weight: 700;
    font-size: 24px;
    color: var(--zz-ink-4);
    line-height: 1;
    text-align: right;
    transition: color .2s ease, font-size .2s ease;
}
@keyframes zz-hero-num-cycle {
    0%, 16% { color: var(--zz-burgundy); transform: scale(1.28); }
    20%, 100% { color: var(--zz-ink-4); transform: scale(1); }
}
.zz-hero__index-item:nth-child(1) .zz-hero__index-num { animation: zz-hero-num-cycle 25s infinite; animation-delay: 0s; }
.zz-hero__index-item:nth-child(2) .zz-hero__index-num { animation: zz-hero-num-cycle 25s infinite; animation-delay: -5s; }
.zz-hero__index-item:nth-child(3) .zz-hero__index-num { animation: zz-hero-num-cycle 25s infinite; animation-delay: -10s; }
.zz-hero__index-item:nth-child(4) .zz-hero__index-num { animation: zz-hero-num-cycle 25s infinite; animation-delay: -15s; }
.zz-hero__index-item:nth-child(5) .zz-hero__index-num { animation: zz-hero-num-cycle 25s infinite; animation-delay: -20s; }
.zz-hero__index-body { min-width: 0; }
.zz-hero__index-item-title {
    font-family: var(--zz-font-serif);
    font-size: 14px; font-weight: 600;
    line-height: 1.2;
    color: var(--zz-ink);
    display: -webkit-box; -webkit-line-clamp: 1; -webkit-box-orient: vertical; overflow: hidden;
    margin-bottom: 2px;
}
.zz-hero__index-item:hover .zz-hero__index-item-title { color: var(--zz-burgundy); }
.zz-hero__index-item-author {
    font-size: 11px; font-style: italic;
    color: var(--zz-ink-4);
    text-transform: uppercase; letter-spacing: 0.05em;
}
.zz-hero__index-item-arrow {
    color: var(--zz-burgundy);
    font-size: 16px;
    text-align: right;
    transition: transform .2s ease;
    opacity: 0.3;
}
.zz-hero__index-item:hover .zz-hero__index-item-arrow {
    transform: translateX(4px);
    opacity: 1;
}

@media (max-width: 992px) {
    .zz-hero { height: auto; min-height: 0; max-height: none; }
    .zz-hero__body { grid-template-columns: 1fr; min-height: 0; }
    .zz-hero__cover { min-height: 350px; }
    .zz-hero__index { border-left: 0; border-top: 1px solid var(--zz-line); padding: var(--zz-s2) var(--zz-s3) var(--zz-s3); }
    .zz-hero__cover-mag { font-size: 72px; top: var(--zz-s3); left: var(--zz-s4); }
    .zz-hero__cover-title { font-size: 24px; }
    .zz-hero__cover-info { left: var(--zz-s4); bottom: var(--zz-s4); right: var(--zz-s4); }
    .zz-hero__index-item { padding: var(--zz-s3) 0; gap: var(--zz-s4); }
    .zz-hero__index-num { font-size: 20px; }
    .zz-hero__index-item-title { font-size: 13px; }
    .zz-hero__head-title { font-size: 18px; }
    .zz-hero__head { padding: var(--zz-s2) 0; }
    .zz-hero__cover-desc { -webkit-line-clamp: 2; }
}
@media (max-width: 480px) {
    .zz-hero__cover { min-height: 320px; }
    .zz-hero__cover-mag { font-size: 56px; top: var(--zz-s2); }
    .zz-hero__cover-title { font-size: 20px; }
    .zz-hero__index { padding: var(--zz-s3) var(--zz-s2); }
    .zz-hero__index-item { padding: var(--zz-s2) 0; gap: var(--zz-s3); }
    .zz-hero__index-num { font-size: 20px; }
    .zz-hero__index-item-title { font-size: 13px; }
    .zz-hero__index-item-author { font-size: 10px; }
    .zz-hero__head-title { font-size: 16px; }
    .zz-hero__head { padding: var(--zz-s2) 0; }
    .zz-hero__cover-desc { -webkit-line-clamp: 1; font-size: 12px; }
}

