一套面向长文阅读与知识整理的编辑部杂志风网页主题。它以温润的米白纸色为底,搭配深墨色正文、朱红色强调、低饱和金色标签和 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 渐变和卡片堆叠。
```