/* ===== YANSHI LABS · 偃师纪元 ===== */
:root{
  --ink:#0b0b0e;          /* 墨底 */
  --ink-2:#121218;        /* 卡片底 */
  --paper:#ece6d8;        /* 纸白 */
  --paper-dim:#a39e92;    /* 次要文字 */
  --cinnabar:#cf4a2e;     /* 朱砂 */
  --cinnabar-soft:#e0603f;
  --line:rgba(236,230,216,.12);
  --surface-pill:rgba(18,18,24,.85);
  --topbar-fade:rgba(11,11,14,.85);
  --glow:rgba(207,74,46,.2);
  --maxw:1100px;
  --serif-zh:"Noto Serif SC",serif;
  --serif-en:"Cormorant Garamond",Georgia,serif;
  --sans:"Space Grotesk",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-snap-type:y mandatory;background:var(--ink)}
body{
  background:var(--ink);
  color:var(--paper);
  font-family:var(--serif-zh);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  scroll-snap-type:y mandatory;   /* body 才是真正的滚动容器（因 overflow-x:hidden） */
  scroll-behavior:smooth;
  transition:opacity .45s ease;
}
/* 字体就绪前先隐藏，避免「先一种字体、再跳变」的闪烁（仅在 JS 生效时；有 1.5s 兜底） */
.js:not(.fonts-ready) body{opacity:0}
::selection{background:var(--cinnabar);color:#fff}

/* ---- 语言显隐（中 / EN 两个独立版本，不混排）---- */
.zh,.en{display:block}
[data-lang="zh"] .en{display:none}
[data-lang="en"] .zh{display:none}
/* 行内并列处（cite / brand）保持 inline */
cite .zh,cite .en,.brand .zh,.brand .en{display:inline}

/* ---- 语言切换 ---- */
.lang-toggle{
  display:flex;gap:2px;padding:3px;flex:none;
  background:var(--surface-pill);backdrop-filter:blur(8px);
  border:1px solid var(--line);border-radius:999px;
}
.lang-toggle button{
  font-family:var(--sans);font-size:12px;letter-spacing:.04em;
  color:var(--paper-dim);background:none;border:0;cursor:pointer;
  padding:5px 11px;border-radius:999px;transition:.2s;
}
.lang-toggle button.active{background:var(--cinnabar);color:#fff}
.lang-toggle button:hover:not(.active){color:var(--paper)}

/* ---- 顶栏 ---- */
.topbar{
  position:fixed;top:0;left:0;right:0;z-index:40;
  display:flex;align-items:center;justify-content:space-between;
  padding:16px clamp(18px,4vw,48px);
  background:linear-gradient(to bottom,var(--topbar-fade),transparent);
}
.topbar-right{display:flex;align-items:center;gap:clamp(14px,3vw,30px)}
/* ---- 字标 lockup 基底 ---- */
.brand{display:inline-flex;align-items:center;text-decoration:none;color:var(--paper)}
.brand-text{display:inline-flex;flex-direction:column;gap:5px;line-height:1.12}
.brand-zh{font-family:var(--serif-zh);font-weight:500;color:var(--paper)}
.brand-en{font-family:var(--sans);font-weight:600;color:var(--paper-dim);white-space:nowrap}
.brand-div{display:none}

/* === 10 种方案（临时，供挑选）=== */
/* 1 · 左对齐·中上英下（自然，不强制等宽） */
.lv1 .brand-text{align-items:flex-start;gap:5px}
.lv1 .brand-zh{font-size:16px;letter-spacing:.12em}
.lv1 .brand-en{font-size:11px;letter-spacing:.22em}

/* 2 · 两端对齐（中文 justify 撑到等宽） */
.lv2 .brand-text{gap:5px}
.lv2 .brand-zh{font-size:15px;text-align:justify;text-align-last:justify;text-justify:inter-character}
.lv2 .brand-en{font-size:11.5px;letter-spacing:.2em;margin-right:-.2em}

/* 3 · 竖线分隔·横排 */
.lv3 .brand-text{flex-direction:row;align-items:center;gap:11px}
.lv3 .brand-zh{font-size:17px;letter-spacing:.08em}
.lv3 .brand-en{font-size:11px;letter-spacing:.18em}
.lv3 .brand-div{display:block;width:1px;height:15px;background:var(--line)}

/* 4 · 朱砂圆点分隔·横排 */
.lv4 .brand-text{flex-direction:row;align-items:center;gap:9px}
.lv4 .brand-zh{font-size:17px;letter-spacing:.08em}
.lv4 .brand-en{font-size:11px;letter-spacing:.18em}
.lv4 .brand-div{display:block;width:4px;height:4px;border-radius:50%;background:var(--cinnabar)}

/* 5 · 英上中下（反转层级） */
.lv5 .brand-text{align-items:flex-start;gap:4px}
.lv5 .brand-en{order:-1;font-size:15px;font-weight:700;letter-spacing:.16em;color:var(--paper)}
.lv5 .brand-zh{font-size:12px;font-weight:400;letter-spacing:.3em;color:var(--paper-dim)}

/* 6 · 英文小标 + 中文主体（kicker） */
.lv6 .brand-text{align-items:flex-start;gap:3px}
.lv6 .brand-en{order:-1;font-size:9px;letter-spacing:.44em;color:var(--cinnabar-soft)}
.lv6 .brand-zh{font-size:21px;letter-spacing:.16em}

/* 7 · 居中·中上英下 */
.lv7 .brand-text{align-items:center;text-align:center;gap:5px}
.lv7 .brand-zh{font-size:16px;letter-spacing:.16em}
.lv7 .brand-en{font-size:10.5px;letter-spacing:.24em}

/* 8 · 左侧朱砂竖条 + 中上英下 */
.lv8{gap:11px}
.lv8::before{content:"";flex:none;width:3px;height:30px;border-radius:2px;background:var(--cinnabar)}
.lv8 .brand-text{align-items:flex-start;gap:4px}
.lv8 .brand-zh{font-size:16px;letter-spacing:.1em}
.lv8 .brand-en{font-size:10.5px;letter-spacing:.22em}

/* 9 · 横排·同基线（中大英小） */
.lv9 .brand-text{flex-direction:row;align-items:baseline;gap:10px}
.lv9 .brand-zh{font-size:19px;letter-spacing:.06em}
.lv9 .brand-en{font-size:10px;letter-spacing:.2em}

/* 10 · 中文主体 + 朱砂下划线 */
.lv10 .brand-text{align-items:flex-start;gap:6px}
.lv10 .brand-zh{font-size:17px;letter-spacing:.14em;padding-bottom:5px;border-bottom:1.5px solid var(--cinnabar)}
.lv10 .brand-en{font-size:10px;letter-spacing:.26em}

/* 临时切换按钮 */
/* === 主题：宣纸（已采用）=== */
[data-theme="paper"]{
  --ink:#e6ddc9;         /* 页面底：暖牛皮纸 */
  --ink-2:#f6f2e8;       /* 独立分块/卡片：近白宣纸 */
  --paper:#2b2722;       /* 墨字 */
  --paper-dim:#796f5e;
  --cinnabar:#bf3a2b;
  --cinnabar-soft:#9c2c20;
  --line:rgba(60,48,36,.16);
  --surface-pill:rgba(255,253,247,.9);
  --topbar-fade:rgba(230,221,201,.92);
  --glow:rgba(191,58,43,.11);
}
.nav{display:flex;gap:clamp(14px,3vw,34px)}
.nav a{
  font-family:var(--serif-zh);font-size:15px;color:var(--paper);
  text-decoration:none;opacity:.78;transition:.2s;
}
.nav a .en{font-family:var(--sans);font-size:13px;letter-spacing:.1em}
.nav a:hover{opacity:1;color:var(--cinnabar-soft)}

/* ---- Hero ---- */
.hero{
  position:relative;min-height:100vh;scroll-snap-align:start;scroll-snap-stop:always;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:120px 24px 80px;overflow:hidden;
}
.hero-glow{
  position:absolute;top:34%;left:50%;transform:translate(-50%,-50%);
  width:min(120vw,900px);height:min(120vw,900px);
  background:radial-gradient(circle,var(--glow),transparent 62%);
  filter:blur(20px);pointer-events:none;animation:breathe 7s ease-in-out infinite;
}
@keyframes breathe{0%,100%{opacity:.65}50%{opacity:1}}
.hero-watermark{
  position:absolute;bottom:-2vw;left:50%;transform:translateX(-50%);
  font-family:var(--serif-zh);font-weight:600;font-size:30vw;line-height:1;
  color:rgba(236,230,216,.04);letter-spacing:.08em;pointer-events:none;user-select:none;white-space:nowrap;
}
.kicker{
  font-family:var(--sans);font-size:13px;letter-spacing:.42em;
  color:var(--cinnabar-soft);text-transform:uppercase;margin-bottom:26px;
}
/* 小标题：偃师造物 · YANSHI LABS（合并一行，适中偏大） */
.wordmark{position:relative;font-weight:500;line-height:1.25;white-space:nowrap}
.wordmark .t-zh{font-family:var(--serif-zh);font-weight:500;font-size:clamp(19px,3vw,28px);letter-spacing:.18em;color:var(--cinnabar)}
.wordmark .dot{color:var(--cinnabar);margin:0 .55em}
.wordmark .t-en{font-family:var(--sans);font-weight:600;font-size:clamp(15px,2.3vw,21px);letter-spacing:.22em;color:var(--cinnabar)}

/* slogan：主角大字 */
.manifesto{margin-top:34px}
.manifesto .zh{font-family:var(--serif-zh);font-weight:400;font-size:clamp(36px,9vw,104px);letter-spacing:.04em;line-height:1.3;color:var(--paper)}
.manifesto .en{font-family:var(--serif-en);font-style:italic;font-size:clamp(30px,6vw,80px);line-height:1.2;color:var(--cinnabar-soft);opacity:.95}
.lede{margin-top:26px;max-width:34ch;margin-inline:auto}
.lede .zh{font-size:clamp(15px,2.2vw,19px);color:var(--paper);opacity:.85;letter-spacing:.04em}
.lede .en{font-family:var(--serif-en);font-size:clamp(15px,2vw,19px);color:var(--paper-dim)}

.scroll-cue{display:block;margin-top:56px;width:24px;height:38px}
.scroll-cue span{
  display:block;width:1px;height:38px;margin:0 auto;background:var(--line);position:relative;overflow:hidden;
}
.scroll-cue span::after{
  content:"";position:absolute;top:-38px;left:0;width:1px;height:38px;
  background:var(--cinnabar);animation:drop 2.1s cubic-bezier(.7,0,.3,1) infinite;
}
@keyframes drop{0%{top:-38px}60%,100%{top:38px}}

/* ---- 通用 section ---- */
/* 板块：每段独立占满一屏（内容居中），整幅交替着色 + 分隔线 + 弦连接 */
.section{
  position:relative;
  min-height:100vh;
  display:grid;grid-template-columns:minmax(0,1fr);align-content:center;   /* 显式整宽列：子项拿到确定宽度，嵌套网格 1fr 不再塌成单字 */
  padding-block:clamp(64px,9vh,120px);
  padding-inline:max(clamp(24px,5vw,48px), calc((100% - var(--maxw)) / 2));
  border-top:1px solid var(--line);
  scroll-snap-align:start;
  scroll-snap-stop:always;
}
.origin,.believe{background:var(--ink-2)}

/* 弦：连接到下一板块（与首页 scroll-cue 同一意象） */
.cue{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);display:block;width:18px;height:38px;z-index:3}
.cue span{display:block;width:1px;height:38px;margin:0 auto;background:var(--line);position:relative;overflow:hidden}
.cue span::after{content:"";position:absolute;top:-38px;left:0;width:1px;height:38px;background:var(--cinnabar);animation:drop 2.1s cubic-bezier(.7,0,.3,1) infinite}
.eyebrow{font-family:var(--sans);font-size:12px;letter-spacing:.34em;text-transform:uppercase;color:var(--cinnabar-soft);margin-bottom:34px}
.eyebrow .zh{font-family:var(--serif-zh);letter-spacing:.34em}
.section-lede{font-size:clamp(17px,2.4vw,22px);font-weight:300;max-width:46ch;color:var(--paper);opacity:.9;margin-bottom:54px}
.section-lede .en{font-family:var(--serif-en);font-style:italic}
.prose p{font-size:clamp(15px,1.9vw,18px);font-weight:300;color:var(--paper);opacity:.86;margin-bottom:1.4em;max-width:62ch}
.prose .en{font-family:var(--serif-en);font-size:clamp(16px,2vw,19px);line-height:1.7}
.prose strong{color:var(--cinnabar-soft);font-weight:500}

/* ---- 源起 ---- */
.liezi{margin-bottom:48px;padding-left:26px;border-left:2px solid var(--cinnabar)}
.liezi .zh{font-family:var(--serif-zh);font-weight:400;font-size:clamp(22px,4vw,38px);letter-spacing:.04em;line-height:1.5}
.liezi .en{font-family:var(--serif-en);font-style:italic;font-size:clamp(20px,3vw,32px);color:var(--paper)}
.liezi cite{display:block;margin-top:18px;font-family:var(--sans);font-style:normal;font-size:13px;letter-spacing:.08em;color:var(--paper-dim)}
.liezi cite i{font-style:italic}

/* ---- 所造 grid ---- */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;width:100%}
.card{
  position:relative;padding:34px 26px 30px;background:var(--ink-2);
  border:1px solid var(--line);border-radius:12px;overflow:hidden;transition:.35s;
}
.card::before{
  content:"";position:absolute;inset:0;border-radius:12px;
  background:radial-gradient(120% 80% at 50% -20%,var(--glow),transparent 60%);
  opacity:0;transition:.35s;
}
.card:hover{transform:translateY(-4px);border-color:rgba(207,74,46,.5)}
.card:hover::before{opacity:1}
.glyph{
  display:block;font-family:var(--serif-zh);font-weight:300;font-size:64px;line-height:1;
  color:var(--cinnabar);margin-bottom:22px;
}
.card h3{font-family:var(--sans);font-weight:500;font-size:21px;letter-spacing:.06em;margin-bottom:6px}
.card-role{font-size:13.5px;color:var(--paper-dim)}
.card-role .en{font-family:var(--serif-en);font-style:italic;font-size:15px}

/* ---- 所信 tenets ---- */
.tenets{list-style:none;display:flex;flex-direction:column;gap:0}
.tenets li{display:flex;gap:clamp(18px,3vw,40px);align-items:flex-start;padding:34px 0;border-bottom:1px solid var(--line)}
.tenets li:first-child{padding-top:0}
.tenets li:last-child{border-bottom:0}
.tenet-no{flex:none;font-family:var(--serif-zh);font-weight:300;font-size:clamp(34px,5vw,58px);color:var(--cinnabar);line-height:1;opacity:.85}
.tenets h3{font-family:var(--serif-zh);font-weight:500;font-size:clamp(20px,2.8vw,27px);letter-spacing:.04em;margin-bottom:10px}
.tenets h3 .en{font-family:var(--serif-en);font-style:italic;font-weight:500;color:var(--cinnabar-soft)}
.tenets p{font-size:clamp(14px,1.8vw,17px);font-weight:300;color:var(--paper);opacity:.82;max-width:60ch}
.tenets p .en{font-family:var(--serif-en);font-size:clamp(15px,1.9vw,18px);line-height:1.6}

/* ---- 纪元 closing ---- */
.epoch-inner{display:grid;grid-template-columns:auto 1fr;gap:clamp(34px,7vw,90px);align-items:center;width:100%}
.big-word{
  font-family:var(--serif-zh);font-weight:500;font-size:clamp(72px,13vw,176px);line-height:.95;
  color:transparent;-webkit-text-stroke:1.2px var(--cinnabar);text-stroke:1.2px var(--cinnabar);
  letter-spacing:.04em;writing-mode:vertical-rl;text-orientation:upright;
}
.epoch-head{font-size:clamp(22px,3.4vw,34px);font-weight:400;margin-bottom:24px;color:var(--paper)}
.epoch-head .en{font-family:var(--serif-en);font-style:italic;color:var(--cinnabar-soft)}

/* ---- 页脚 ---- */
.footer{
  border-top:1px solid var(--line);
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:24px;
  max-width:var(--maxw);margin:0 auto;padding:48px clamp(24px,5vw,48px) 60px;
  scroll-snap-align:end;   /* 页脚作为吸附终点，滑到底不再弹回 */
}
.footer-brand{display:flex;align-items:flex-start;gap:14px;font-size:14px}
.footer-brand strong{font-family:var(--sans);font-weight:600;letter-spacing:.1em}
.footer-sub{color:var(--paper-dim);font-size:13px}
.footer-sub.en{font-family:var(--serif-en);font-style:italic;font-size:14px}
.footer-meta{font-family:var(--sans);font-size:12px;color:var(--paper-dim);text-align:right;display:flex;flex-direction:column;gap:6px}
.footer-note{max-width:30ch}

/* ---- 进场动画 ---- */
.js .reveal{opacity:0;transform:translateY(22px);transition:opacity .9s ease,transform .9s ease}
.js .reveal.in{opacity:1;transform:none}
.reveal[data-delay="1"]{transition-delay:.12s}
.reveal[data-delay="2"]{transition-delay:.24s}
.reveal[data-delay="3"]{transition-delay:.36s}
.reveal[data-delay="4"]{transition-delay:.48s}
@media (prefers-reduced-motion:reduce){
  .js .reveal{opacity:1;transform:none;transition:none}
  .hero-glow,.scroll-cue span::after{animation:none}
}

/* ---- 项目介绍页（/anima/ /soma/ /alice/，复用首页骨架 + 主题）---- */
.project-head{display:flex;align-items:center;gap:clamp(18px,4vw,40px);margin-bottom:36px}
.project-head .glyph{margin-bottom:0;font-size:clamp(72px,12vw,120px)}
.project-name{font-family:var(--sans);font-weight:600;font-size:clamp(34px,6vw,60px);letter-spacing:.04em;line-height:1;margin-bottom:12px;color:var(--paper)}
.project-role{font-size:clamp(15px,2.2vw,19px);color:var(--paper-dim)}
.project-role .en{font-family:var(--serif-en);font-style:italic;font-size:clamp(16px,2.3vw,20px)}
.proj-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:44px}
.proj-actions a{
  display:inline-flex;align-items:center;
  font-family:var(--sans);font-size:14px;letter-spacing:.06em;
  color:var(--paper);text-decoration:none;
  padding:11px 22px;border:1px solid var(--cinnabar);border-radius:999px;transition:.22s;
}
.proj-actions a:hover{background:var(--cinnabar);color:#fff}
.proj-actions a.primary{background:var(--cinnabar);color:#fff}
.proj-actions a.primary:hover{background:var(--cinnabar-soft);border-color:var(--cinnabar-soft)}

/* ---- 响应式 ---- */
@media (max-width:820px){
  .nav{display:none}
  .grid{grid-template-columns:repeat(2,1fr)}
  .epoch-inner{grid-template-columns:1fr;text-align:left}
  .big-word{writing-mode:horizontal-tb}
}
@media (max-width:480px){
  .grid{grid-template-columns:1fr}
  .footer{flex-direction:column}
  .footer-meta{text-align:left}
}
