解决方案 资源

一套带有纸张质感、杂志排版和东方留白气质的长文阅读主题,适合知识库、文档站、笔记应用和个人内容空间。

一套面向长文阅读与知识整理的编辑部杂志风网页主题。它以温润的米白纸色为底,搭配深墨色正文、朱红色强调、低饱和金色标签和 1px 细线网格,营造出类似纸本文档、文学杂志与档案工作台之间的安静气质。

它不追求炫技式动效,也不使用常见的蓝紫渐变和卡片堆叠,而是通过衬线字体、大字号标题、舒展行高、杂志式编号、轻微纸张噪点和克制的方形工具控件,让界面更适合阅读、写作、批注、知识库和个人文档管理。

墨读视觉风格说明

这套页面风格可以描述为:

纸本文档感、编辑部杂志排版、东方留白、细线网格、墨色正文、朱红点睛、低饱和金色辅助的阅读型界面。

它适合文档阅读器、知识库、个人笔记、作品集、内容管理后台、出版类网站、研究资料库等需要“安静、可信、耐读、有审美”的页面。

给 AI 的设计提示词

可以直接这样说:

请设计一个网页界面,视觉风格参考高端纸本文档、文学杂志和编辑部工作台。

整体要有温润纸张质感,不要现代 SaaS 的蓝紫渐变,也不要卡片堆叠式 AI 风格。使用米白纸色背景、深墨色文字、朱红色作为强调色、低饱和金色作为辅助色、细边线作为结构分隔。页面应该像一本被摊开的文档杂志:大标题有杂志封面感,正文排版舒展耐读,工具栏克制、清晰、安静。

字体搭配使用优雅衬线英文字体作为标题,例如 Playfair Display;中文正文使用 Noto Serif SC 或类似宋体/明朝风格字体。标题可以非常大,使用斜体或朱红色强调局部文字;正文行高较大,段落之间留足呼吸感。

布局使用明确的细线网格:顶部粘性栏、左侧目录或文档库、中间主阅读区、右侧工具面板。不要使用大圆角卡片,不要使用发光渐变背景,不要使用装饰性气泡。所有面板通过 1px 边线、淡色背景和留白形成层次。

交互状态要克制:hover 时轻微位移、边框变朱红、背景只淡淡染色。按钮保持方正,图标按钮用正方形细边框。页面可以叠加极轻微纸张噪点纹理。

关键词:editorial magazine layout, paper texture, refined serif typography, Chinese literary interface, ink and vermilion, thin rule grid, calm reading experience, restrained tools, archival document reader.

风格关键词

  • 基调:安静、克制、文学性、档案感、出版物感。
  • 材质:旧纸、宣纸、杂志内页、印刷墨迹。
  • 颜色:米白纸色、深棕黑墨色、朱红强调、低饱和金色、灰棕辅助文字。
  • 排版:大标题、衬线字体、舒展行高、窄正文栏、杂志式编号。
  • 结构:细线分隔、三栏布局、粘性工具栏、少圆角或无圆角。
  • 交互:轻微位移、边框变色、淡色背景,不做夸张动画。

核心颜色

:root {
  --ink: #1a1410;
  --paper: #f5f0e8;
  --paper-deep: #eee4d5;
  --accent: #c0392b;
  --gold: #b8975a;
  --muted: #7a6e62;
  --border: #d4c9b8;
  --shadow: rgba(26, 20, 16, 0.12);
}

深色模式不要换成纯黑,而是保留温度:

body.dark {
  --ink: #efe6d8;
  --paper: #18130f;
  --paper-deep: #211a15;
  --muted: #b5a797;
  --border: #41362d;
  --shadow: rgba(0, 0, 0, 0.28);
}

字体配方

<link href="https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;1,400&family=Noto+Serif+SC:wght@300;400;600&display=swap" rel="stylesheet" />
body {
  font-family: 'Noto Serif SC', serif;
  font-weight: 300;
  line-height: 1.8;
}

h1,
.brand-main,
.hero-stat strong {
  font-family: 'Playfair Display', serif;
}

纸张噪点

这是这套风格很关键的一层。它让页面不像普通纯色网页,而像纸面。

body::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.86' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.045'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 1000;
  opacity: 0.7;
}

页面骨架

这套页面最好用“细线分区”,而不是卡片堆叠。

.topbar {
  position: sticky;
  top: 0;
  z-index: 100;
  display: grid;
  grid-template-columns: 1fr minmax(18rem, 38rem) 1fr;
  align-items: center;
  gap: 2rem;
  padding: 1.15rem 2rem;
  border-bottom: 1px solid var(--border);
  background: color-mix(in srgb, var(--paper) 92%, transparent);
  backdrop-filter: blur(10px);
}

.reader-shell {
  display: grid;
  grid-template-columns: 18rem minmax(0, 1fr) 16rem;
  min-height: calc(100vh - 4.9rem);
}

.library,
.tools {
  position: sticky;
  top: 4.9rem;
  height: calc(100vh - 4.9rem);
  overflow: auto;
  background: color-mix(in srgb, var(--paper-deep) 56%, transparent);
}

.library { border-right: 1px solid var(--border); }
.tools { border-left: 1px solid var(--border); }

杂志式标题区

大标题、期刊标签、淡编号,是这个风格最容易被记住的部分。

.document-hero {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 14rem;
  gap: 2rem;
  padding: 5rem 5vw 3.5rem;
  border-bottom: 1px solid var(--border);
  overflow: hidden;
}

.document-hero::after {
  content: attr(data-mark);
  position: absolute;
  right: 3vw;
  bottom: -2.4rem;
  color: color-mix(in srgb, var(--ink) 6%, transparent);
  font-family: 'Playfair Display', serif;
  font-size: clamp(7rem, 14vw, 14rem);
  font-weight: 700;
  line-height: 1;
  pointer-events: none;
}

.issue-tag {
  display: flex;
  align-items: center;
  gap: 0.8rem;
  margin-bottom: 1.6rem;
  color: var(--gold);
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.issue-tag::before {
  content: '';
  width: 2rem;
  height: 1px;
  background: var(--gold);
}

h1 {
  max-width: 11ch;
  margin-bottom: 1.25rem;
  font-family: 'Playfair Display', serif;
  font-size: clamp(3.1rem, 7vw, 6.2rem);
  line-height: 1.02;
  font-weight: 700;
  letter-spacing: 0;
  text-wrap: balance;
}

h1 em {
  color: var(--accent);
  font-style: italic;
}

正文阅读区

正文的重点是耐读,不要太密。

.article-wrap {
  max-width: 58rem;
  margin: 0 auto;
  padding: 4rem 5vw 7rem;
}

.reader-article {
  font-size: 19px;
  line-height: 1.92;
}

.reader-article h2 {
  margin: 3.2rem 0 1rem;
  padding-top: 1.2rem;
  border-top: 1px solid var(--border);
  font-family: 'Playfair Display', 'Noto Serif SC', serif;
  font-size: clamp(1.65rem, 3vw, 2.45rem);
  line-height: 1.25;
  font-weight: 700;
}

.reader-article p {
  margin: 1.15rem 0;
}

.reader-article blockquote {
  margin: 2rem 0;
  padding: 1.2rem 1.4rem;
  border-left: 3px solid var(--accent);
  background: color-mix(in srgb, var(--paper-deep) 70%, transparent);
  color: var(--muted);
  font-style: italic;
}

按钮和工具控件

按钮要方正、克制、像编辑工具,不要大圆角。

.icon-btn,
.text-btn {
  min-height: 2.55rem;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--paper) 82%, transparent);
  transition: background 0.2s, border-color 0.2s, color 0.2s, transform 0.2s;
}

.icon-btn {
  width: 2.55rem;
  display: inline-grid;
  place-items: center;
}

.text-btn {
  padding: 0 1rem;
  color: var(--paper);
  background: var(--ink);
  border-color: var(--ink);
  font-size: 0.76rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.icon-btn:hover,
.text-btn:hover {
  transform: translateY(-1px);
  border-color: var(--accent);
  color: var(--paper);
  background: var(--accent);
}

设计禁忌

为了保持这套味道,尽量避免:

  • 大面积蓝紫渐变。
  • 玻璃拟态卡片堆叠。
  • 过大的圆角。
  • Hero 区使用抽象 SVG 插画。
  • 过多阴影和发光。
  • 纯黑纯白高反差。
  • 太现代的无衬线字体作为主视觉。
  • 密集按钮和强烈彩色状态。

一句话版本

如果只能给 AI 一句话,可以说:

做成一套“高端纸本文档阅读器”的视觉:米白纸张、墨色正文、朱红点睛、低饱和金色标签、细线网格、杂志式大标题、衬线字体、舒展正文、克制方形工具按钮,不要现代 SaaS 渐变和卡片堆叠。
<!DOCTYPE html>
<html lang="zh">
<head>
  <meta charset="UTF-8" />
  <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  <title>光·影 — 个人主页</title>
  <link href="https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;1,400&family=Noto+Serif+SC:wght@300;400&display=swap" rel="stylesheet" />
  <style>
    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

    :root {
      --ink: #1a1410;
      --paper: #f5f0e8;
      --accent: #c0392b;
      --gold: #b8975a;
      --muted: #7a6e62;
      --border: #d4c9b8;
    }

    html { scroll-behavior: smooth; }

    body {
      background: var(--paper);
      color: var(--ink);
      font-family: 'Noto Serif SC', serif;
      font-weight: 300;
      line-height: 1.8;
      overflow-x: hidden;
    }

    /* Noise texture overlay */
    body::before {
      content: '';
      position: fixed;
      inset: 0;
      background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");
      pointer-events: none;
      z-index: 1000;
      opacity: 0.6;
    }

    /* ── HEADER ── */
    header {
      display: grid;
      grid-template-columns: 1fr auto 1fr;
      align-items: center;
      padding: 2rem 4rem;
      border-bottom: 1px solid var(--border);
      position: sticky;
      top: 0;
      background: rgba(245, 240, 232, 0.92);
      backdrop-filter: blur(8px);
      z-index: 100;
    }

    .logo {
      font-family: 'Playfair Display', serif;
      font-size: 1.4rem;
      letter-spacing: 0.05em;
      color: var(--ink);
      text-decoration: none;
    }
    .logo span { color: var(--accent); }

    nav {
      display: flex;
      gap: 2.5rem;
      font-size: 0.78rem;
      letter-spacing: 0.15em;
      text-transform: uppercase;
    }
    nav a {
      color: var(--muted);
      text-decoration: none;
      transition: color 0.25s;
      position: relative;
    }
    nav a::after {
      content: '';
      position: absolute;
      bottom: -2px;
      left: 0; right: 0;
      height: 1px;
      background: var(--accent);
      transform: scaleX(0);
      transition: transform 0.3s;
    }
    nav a:hover { color: var(--ink); }
    nav a:hover::after { transform: scaleX(1); }

    .header-right {
      display: flex;
      justify-content: flex-end;
    }
    .cta-btn {
      font-size: 0.75rem;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--paper);
      background: var(--ink);
      border: none;
      padding: 0.6rem 1.4rem;
      cursor: pointer;
      transition: background 0.25s;
      font-family: inherit;
    }
    .cta-btn:hover { background: var(--accent); }

    /* ── HERO ── */
    .hero {
      display: grid;
      grid-template-columns: 1fr 1fr;
      min-height: 88vh;
      border-bottom: 1px solid var(--border);
    }

    .hero-text {
      padding: 6rem 5rem 6rem 4rem;
      display: flex;
      flex-direction: column;
      justify-content: center;
      border-right: 1px solid var(--border);
      animation: fadeUp 1s ease both;
    }

    .issue-tag {
      font-size: 0.7rem;
      letter-spacing: 0.2em;
      text-transform: uppercase;
      color: var(--gold);
      margin-bottom: 2rem;
      display: flex;
      align-items: center;
      gap: 0.8rem;
    }
    .issue-tag::before {
      content: '';
      display: block;
      width: 2rem;
      height: 1px;
      background: var(--gold);
    }

    h1 {
      font-family: 'Playfair Display', serif;
      font-size: clamp(3rem, 5vw, 5.5rem);
      line-height: 1.1;
      font-weight: 700;
      margin-bottom: 1.5rem;
      letter-spacing: -0.01em;
    }
    h1 em {
      font-style: italic;
      color: var(--accent);
    }

    .hero-desc {
      font-size: 1.05rem;
      color: var(--muted);
      max-width: 38ch;
      margin-bottom: 3rem;
      line-height: 1.9;
    }

    .hero-actions {
      display: flex;
      align-items: center;
      gap: 2rem;
    }

    .btn-primary {
      background: var(--accent);
      color: var(--paper);
      padding: 0.9rem 2.2rem;
      font-family: inherit;
      font-size: 0.8rem;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      border: none;
      cursor: pointer;
      transition: transform 0.2s, box-shadow 0.2s;
    }
    .btn-primary:hover {
      transform: translateY(-2px);
      box-shadow: 0 6px 20px rgba(192, 57, 43, 0.3);
    }

    .btn-ghost {
      font-size: 0.8rem;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--muted);
      background: none;
      border: none;
      cursor: pointer;
      font-family: inherit;
      display: flex;
      align-items: center;
      gap: 0.5rem;
      transition: color 0.2s;
    }
    .btn-ghost:hover { color: var(--ink); }
    .btn-ghost::after { content: '→'; }

    /* Hero image panel */
    .hero-visual {
      position: relative;
      overflow: hidden;
      background: var(--ink);
      animation: fadeIn 1.2s ease both;
    }
    .hero-visual-inner {
      position: absolute;
      inset: 3rem;
      border: 1px solid rgba(245,240,232,0.15);
    }
    .hero-visual-inner::before {
      content: '';
      position: absolute;
      inset: 0;
      background: 
        radial-gradient(ellipse at 30% 40%, rgba(184,151,90,0.2) 0%, transparent 60%),
        radial-gradient(ellipse at 75% 70%, rgba(192,57,43,0.15) 0%, transparent 55%);
    }

    .hero-number {
      position: absolute;
      bottom: 5rem;
      left: 5rem;
      font-family: 'Playfair Display', serif;
      font-size: 8rem;
      font-weight: 700;
      color: rgba(245,240,232,0.06);
      line-height: 1;
      pointer-events: none;
      user-select: none;
    }

    .hero-caption {
      position: absolute;
      bottom: 3rem;
      right: 3rem;
      color: rgba(245,240,232,0.5);
      font-size: 0.7rem;
      letter-spacing: 0.15em;
      text-transform: uppercase;
      writing-mode: vertical-rl;
    }

    /* Floating decorative lines */
    .deco-line {
      position: absolute;
      background: var(--gold);
      opacity: 0.4;
    }
    .deco-line-h { width: 4rem; height: 1px; top: 3rem; left: 50%; }
    .deco-line-v { width: 1px; height: 4rem; bottom: 50%; right: 3rem; }

    /* ── STATS ── */
    .stats {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      border-bottom: 1px solid var(--border);
    }
    .stat {
      padding: 2.5rem 3rem;
      border-right: 1px solid var(--border);
      animation: fadeUp 0.8s ease both;
    }
    .stat:last-child { border-right: none; }
    .stat-num {
      font-family: 'Playfair Display', serif;
      font-size: 2.4rem;
      font-weight: 700;
      color: var(--ink);
      display: block;
      line-height: 1;
      margin-bottom: 0.4rem;
    }
    .stat-num span { color: var(--accent); font-style: italic; }
    .stat-label {
      font-size: 0.72rem;
      letter-spacing: 0.15em;
      text-transform: uppercase;
      color: var(--muted);
    }

    /* ── FEATURES ── */
    .features {
      padding: 6rem 4rem;
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 0;
    }
    .feature {
      padding: 3rem;
      border-right: 1px solid var(--border);
      border-bottom: 1px solid var(--border);
      transition: background 0.3s;
      animation: fadeUp 0.9s ease both;
    }
    .feature:nth-child(3) { border-right: none; }
    .feature:hover { background: rgba(26,20,16,0.03); }

    .feature-icon {
      width: 3rem;
      height: 3rem;
      border: 1px solid var(--border);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1.2rem;
      margin-bottom: 1.5rem;
      transition: border-color 0.3s, background 0.3s;
    }
    .feature:hover .feature-icon {
      border-color: var(--accent);
      background: var(--accent);
    }

    .feature h3 {
      font-family: 'Playfair Display', serif;
      font-size: 1.3rem;
      margin-bottom: 1rem;
    }
    .feature p { font-size: 0.9rem; color: var(--muted); line-height: 1.9; }

    /* ── FOOTER ── */
    footer {
      border-top: 1px solid var(--border);
      padding: 2rem 4rem;
      display: flex;
      align-items: center;
      justify-content: space-between;
      font-size: 0.75rem;
      color: var(--muted);
      letter-spacing: 0.05em;
    }
    footer a { color: var(--muted); text-decoration: none; transition: color 0.2s; }
    footer a:hover { color: var(--accent); }

    /* ── ANIMATIONS ── */
    @keyframes fadeUp {
      from { opacity: 0; transform: translateY(24px); }
      to   { opacity: 1; transform: translateY(0); }
    }
    @keyframes fadeIn {
      from { opacity: 0; }
      to   { opacity: 1; }
    }

    /* Stagger delays */
    .hero-text { animation-delay: 0.1s; }
    .hero-visual { animation-delay: 0.3s; }
    .stat:nth-child(1) { animation-delay: 0.4s; }
    .stat:nth-child(2) { animation-delay: 0.55s; }
    .stat:nth-child(3) { animation-delay: 0.7s; }
    .stat:nth-child(4) { animation-delay: 0.85s; }
    .feature:nth-child(1) { animation-delay: 0.2s; }
    .feature:nth-child(2) { animation-delay: 0.35s; }
    .feature:nth-child(3) { animation-delay: 0.5s; }

    @media (max-width: 900px) {
      header { padding: 1.5rem 2rem; grid-template-columns: 1fr 1fr; }
      nav { display: none; }
      .hero { grid-template-columns: 1fr; }
      .hero-visual { min-height: 40vh; }
      .hero-text { padding: 3rem 2rem; }
      .stats { grid-template-columns: 1fr 1fr; }
      .features { grid-template-columns: 1fr; padding: 3rem 2rem; }
      .feature:nth-child(3) { border-right: 1px solid var(--border); }
      footer { flex-direction: column; gap: 1rem; text-align: center; }
    }
  </style>
</head>
<body>

  <header>
    <a class="logo" href="#">光<span>·</span>影</a>
    <nav>
      <a href="#">作品</a>
      <a href="#">关于</a>
      <a href="#">服务</a>
      <a href="#">日志</a>
    </nav>
    <div class="header-right">
      <button class="cta-btn">联系我</button>
    </div>
  </header>

  <section class="hero">
    <div class="hero-text">
      <div class="issue-tag">创意 · 设计 · 探索</div>
      <h1>以光为笔<br><em>以影绘世</em></h1>
      <p class="hero-desc">
        在喧嚣与静谧之间,寻找那一缕独属于你的光。
        用视觉语言,讲述每一个值得被记住的故事。
      </p>
      <div class="hero-actions">
        <button class="btn-primary">浏览作品集</button>
        <button class="btn-ghost">了解更多</button>
      </div>
    </div>

    <div class="hero-visual">
      <div class="hero-visual-inner">
        <div class="deco-line deco-line-h"></div>
        <div class="deco-line deco-line-v"></div>
      </div>
      <div class="hero-number">01</div>
      <div class="hero-caption">光影之间 · 2026</div>
    </div>
  </section>

  <section class="stats">
    <div class="stat">
      <span class="stat-num">8<span>+</span></span>
      <span class="stat-label">年创作经验</span>
    </div>
    <div class="stat">
      <span class="stat-num">240<span>+</span></span>
      <span class="stat-label">完成项目</span>
    </div>
    <div class="stat">
      <span class="stat-num">96<span>%</span></span>
      <span class="stat-label">客户满意度</span>
    </div>
    <div class="stat">
      <span class="stat-num">18</span>
      <span class="stat-label">所获奖项</span>
    </div>
  </section>

  <section class="features">
    <div class="feature">
      <div class="feature-icon">◈</div>
      <h3>视觉叙事</h3>
      <p>每一帧都是一句话,每一组画面都是一篇故事。从概念到成品,让视觉成为你最有力的语言。</p>
    </div>
    <div class="feature">
      <div class="feature-icon">◎</div>
      <h3>品牌设计</h3>
      <p>深入理解你的品牌基因,提炼出独特的视觉语言体系,让品牌在市场中拥有不可被复制的辨识度。</p>
    </div>
    <div class="feature">
      <div class="feature-icon">◇</div>
      <h3>交互体验</h3>
      <p>在美学与功能之间寻找完美平衡。每一次点击、每一个过渡,都应当带来愉悦与惊喜。</p>
    </div>
  </section>

  <footer>
    <span>© 2026 光·影工作室 — 版权所有</span>
    <div style="display:flex;gap:2rem;">
      <a href="#">隐私政策</a>
      <a href="#">使用条款</a>
      <a href="#">联系我们</a>
    </div>
    <span>以诚意创作,以热爱坚守</span>
  </footer>

</body>
</html>
# 墨读视觉风格说明

这套页面风格可以描述为:

**纸本文档感、编辑部杂志排版、东方留白、细线网格、墨色正文、朱红点睛、低饱和金色辅助的阅读型界面。**

它适合文档阅读器、知识库、个人笔记、作品集、内容管理后台、出版类网站、研究资料库等需要“安静、可信、耐读、有审美”的页面。

## 给 AI 的设计提示词

可以直接这样说:

```text
请设计一个网页界面,视觉风格参考高端纸本文档、文学杂志和编辑部工作台。

整体要有温润纸张质感,不要现代 SaaS 的蓝紫渐变,也不要卡片堆叠式 AI 风格。使用米白纸色背景、深墨色文字、朱红色作为强调色、低饱和金色作为辅助色、细边线作为结构分隔。页面应该像一本被摊开的文档杂志:大标题有杂志封面感,正文排版舒展耐读,工具栏克制、清晰、安静。

字体搭配使用优雅衬线英文字体作为标题,例如 Playfair Display;中文正文使用 Noto Serif SC 或类似宋体/明朝风格字体。标题可以非常大,使用斜体或朱红色强调局部文字;正文行高较大,段落之间留足呼吸感。

布局使用明确的细线网格:顶部粘性栏、左侧目录或文档库、中间主阅读区、右侧工具面板。不要使用大圆角卡片,不要使用发光渐变背景,不要使用装饰性气泡。所有面板通过 1px 边线、淡色背景和留白形成层次。

交互状态要克制:hover 时轻微位移、边框变朱红、背景只淡淡染色。按钮保持方正,图标按钮用正方形细边框。页面可以叠加极轻微纸张噪点纹理。

关键词:editorial magazine layout, paper texture, refined serif typography, Chinese literary interface, ink and vermilion, thin rule grid, calm reading experience, restrained tools, archival document reader.
```

## 风格关键词

- **基调**:安静、克制、文学性、档案感、出版物感。
- **材质**:旧纸、宣纸、杂志内页、印刷墨迹。
- **颜色**:米白纸色、深棕黑墨色、朱红强调、低饱和金色、灰棕辅助文字。
- **排版**:大标题、衬线字体、舒展行高、窄正文栏、杂志式编号。
- **结构**:细线分隔、三栏布局、粘性工具栏、少圆角或无圆角。
- **交互**:轻微位移、边框变色、淡色背景,不做夸张动画。

## 核心颜色

```css
:root {
  --ink: #1a1410;
  --paper: #f5f0e8;
  --paper-deep: #eee4d5;
  --accent: #c0392b;
  --gold: #b8975a;
  --muted: #7a6e62;
  --border: #d4c9b8;
  --shadow: rgba(26, 20, 16, 0.12);
}
```

深色模式不要换成纯黑,而是保留温度:

```css
body.dark {
  --ink: #efe6d8;
  --paper: #18130f;
  --paper-deep: #211a15;
  --muted: #b5a797;
  --border: #41362d;
  --shadow: rgba(0, 0, 0, 0.28);
}
```

## 字体配方

```html
<link href="https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;1,400&family=Noto+Serif+SC:wght@300;400;600&display=swap" rel="stylesheet" />
```

```css
body {
  font-family: 'Noto Serif SC', serif;
  font-weight: 300;
  line-height: 1.8;
}

h1,
.brand-main,
.hero-stat strong {
  font-family: 'Playfair Display', serif;
}
```

## 纸张噪点

这是这套风格很关键的一层。它让页面不像普通纯色网页,而像纸面。

```css
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.86' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.045'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 1000;
  opacity: 0.7;
}
```

## 页面骨架

这套页面最好用“细线分区”,而不是卡片堆叠。

```css
.topbar {
  position: sticky;
  top: 0;
  z-index: 100;
  display: grid;
  grid-template-columns: 1fr minmax(18rem, 38rem) 1fr;
  align-items: center;
  gap: 2rem;
  padding: 1.15rem 2rem;
  border-bottom: 1px solid var(--border);
  background: color-mix(in srgb, var(--paper) 92%, transparent);
  backdrop-filter: blur(10px);
}

.reader-shell {
  display: grid;
  grid-template-columns: 18rem minmax(0, 1fr) 16rem;
  min-height: calc(100vh - 4.9rem);
}

.library,
.tools {
  position: sticky;
  top: 4.9rem;
  height: calc(100vh - 4.9rem);
  overflow: auto;
  background: color-mix(in srgb, var(--paper-deep) 56%, transparent);
}

.library { border-right: 1px solid var(--border); }
.tools { border-left: 1px solid var(--border); }
```

## 杂志式标题区

大标题、期刊标签、淡编号,是这个风格最容易被记住的部分。

```css
.document-hero {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 14rem;
  gap: 2rem;
  padding: 5rem 5vw 3.5rem;
  border-bottom: 1px solid var(--border);
  overflow: hidden;
}

.document-hero::after {
  content: attr(data-mark);
  position: absolute;
  right: 3vw;
  bottom: -2.4rem;
  color: color-mix(in srgb, var(--ink) 6%, transparent);
  font-family: 'Playfair Display', serif;
  font-size: clamp(7rem, 14vw, 14rem);
  font-weight: 700;
  line-height: 1;
  pointer-events: none;
}

.issue-tag {
  display: flex;
  align-items: center;
  gap: 0.8rem;
  margin-bottom: 1.6rem;
  color: var(--gold);
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.issue-tag::before {
  content: '';
  width: 2rem;
  height: 1px;
  background: var(--gold);
}

h1 {
  max-width: 11ch;
  margin-bottom: 1.25rem;
  font-family: 'Playfair Display', serif;
  font-size: clamp(3.1rem, 7vw, 6.2rem);
  line-height: 1.02;
  font-weight: 700;
  letter-spacing: 0;
  text-wrap: balance;
}

h1 em {
  color: var(--accent);
  font-style: italic;
}
```

## 正文阅读区

正文的重点是耐读,不要太密。

```css
.article-wrap {
  max-width: 58rem;
  margin: 0 auto;
  padding: 4rem 5vw 7rem;
}

.reader-article {
  font-size: 19px;
  line-height: 1.92;
}

.reader-article h2 {
  margin: 3.2rem 0 1rem;
  padding-top: 1.2rem;
  border-top: 1px solid var(--border);
  font-family: 'Playfair Display', 'Noto Serif SC', serif;
  font-size: clamp(1.65rem, 3vw, 2.45rem);
  line-height: 1.25;
  font-weight: 700;
}

.reader-article p {
  margin: 1.15rem 0;
}

.reader-article blockquote {
  margin: 2rem 0;
  padding: 1.2rem 1.4rem;
  border-left: 3px solid var(--accent);
  background: color-mix(in srgb, var(--paper-deep) 70%, transparent);
  color: var(--muted);
  font-style: italic;
}
```

## 按钮和工具控件

按钮要方正、克制、像编辑工具,不要大圆角。

```css
.icon-btn,
.text-btn {
  min-height: 2.55rem;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--paper) 82%, transparent);
  transition: background 0.2s, border-color 0.2s, color 0.2s, transform 0.2s;
}

.icon-btn {
  width: 2.55rem;
  display: inline-grid;
  place-items: center;
}

.text-btn {
  padding: 0 1rem;
  color: var(--paper);
  background: var(--ink);
  border-color: var(--ink);
  font-size: 0.76rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.icon-btn:hover,
.text-btn:hover {
  transform: translateY(-1px);
  border-color: var(--accent);
  color: var(--paper);
  background: var(--accent);
}
```

## 设计禁忌

为了保持这套味道,尽量避免:

- 大面积蓝紫渐变。
- 玻璃拟态卡片堆叠。
- 过大的圆角。
- Hero 区使用抽象 SVG 插画。
- 过多阴影和发光。
- 纯黑纯白高反差。
- 太现代的无衬线字体作为主视觉。
- 密集按钮和强烈彩色状态。

## 一句话版本

如果只能给 AI 一句话,可以说:

```text
做成一套“高端纸本文档阅读器”的视觉:米白纸张、墨色正文、朱红点睛、低饱和金色标签、细线网格、杂志式大标题、衬线字体、舒展正文、克制方形工具按钮,不要现代 SaaS 渐变和卡片堆叠。
```

发表回复