/* ============================================================
   Terra Trove — 主样式表  v1.2.0
   原生 WordPress 主题，无父主题依赖。

   容器规则（全站统一）：
     外层全宽元素  → padding: 0 var(--gutter)   负责视口留白
     内层 .shell   → max-width + margin: 0 auto  负责内容宽度上限
   nav / footer / section / cta / page-head 均遵循此规则，
   保证内容边缘在任何屏幕宽度下与 header、footer 严格对齐。
   ============================================================ */

/* ── 设计令牌 ─────────────────────────────────────────────── */
:root {
  /* 颜色 */
  --ink:        #15170f;
  --ink-2:      #2a2c22;
  --ink-3:      #6a6b5e;
  --ink-4:      #9a9b8e;
  --paper:      #f7f5ef;
  --paper-2:    #efece3;
  --stone:      #e5dfd2;
  --stone-deep: #d3c9b3;
  --moss:       #2d4030;
  --moss-2:     #3a5240;
  --line:       rgba(21,23,15,0.12);
  --line-soft:  rgba(21,23,15,0.06);

  /* 字体 */
  --font-serif: "Cormorant Garamond","Noto Serif",Georgia,serif;
  --font-sans:  "Geist","Inter",-apple-system,BlinkMacSystemFont,"Helvetica Neue",Arial,sans-serif;
  --font-mono:  "Geist Mono","JetBrains Mono","SF Mono",ui-monospace,monospace;

  /* 布局 */
  --max-content: 1280px;
  --gutter:      clamp(24px,4.4vw,56px);
  --nav-h:       72px;
  --section-pad: clamp(72px,9vw,132px);
  --section-pad-tight: clamp(56px,6vw,88px);

  /* 产品列表 */
  --pcols:    4;
  --pgap-col: clamp(16px,2vw,24px);
  --pgap-row: clamp(28px,3.4vw,44px);
}

/* ── 全局重置 ─────────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; }
html,body { margin:0;padding:0;background:var(--paper);color:var(--ink);font-family:var(--font-sans);font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden; }
img     { max-width:100%;display:block; }
a       { color:inherit;text-decoration:none; }
button  { font:inherit;color:inherit;background:none;border:0;cursor:pointer;padding:0; }
ul      { list-style:none;margin:0;padding:0; }
h1,h2,h3,h4,h5,h6 { margin:0; }
p       { margin:0; }

/* ── 布局骨架 ─────────────────────────────────────────────── */
/* 内层居中容器：只限制最大宽度并水平居中，不承担视口留白 */
.shell {
  max-width:var(--max-content);
  margin:0 auto;
  width:100%;
}
/* 外层区块：上下间距 + 左右视口留白，与 nav / footer 对齐 */
.section        { padding:var(--section-pad) var(--gutter); }
.section--tight { padding:var(--section-pad-tight) var(--gutter); }

/* 背景修饰工具类 */
.bg-paper-2 { background:var(--paper-2); }
.bg-stone   { background:var(--stone); }
.divider    { height:1px;background:var(--line);width:100%; }

/* ── 排版 ────────────────────────────────────────────────── */
.eyebrow {
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--ink-3);font-weight:400;
}
.eyebrow .dash { color:var(--ink-4);margin-right:10px; }
.eyebrow .num  { color:var(--ink);margin-right:18px; }
.mono { font-family:var(--font-mono);font-size:12px;letter-spacing:0.04em; }

.h-display {
  font-family:var(--font-serif);font-weight:300;letter-spacing:-0.02em;
  line-height:0.95;font-size:clamp(56px,9vw,132px);margin:0;
}
.h-1 {
  font-family:var(--font-serif);font-weight:300;letter-spacing:-0.015em;
  line-height:1.0;font-size:clamp(40px,5.2vw,72px);margin:0;
}
.h-2 {
  font-family:var(--font-serif);font-weight:300;letter-spacing:-0.012em;
  line-height:1.05;font-size:clamp(32px,4vw,52px);margin:0;
}
.h-3 {
  font-family:var(--font-serif);font-weight:400;letter-spacing:-0.005em;
  line-height:1.18;font-size:clamp(22px,2vw,30px);margin:0;
}
.italic  { font-style:italic;font-weight:300; }
.lede    { font-family:var(--font-serif);font-style:italic;font-weight:300;font-size:clamp(18px,1.5vw,24px);line-height:1.45;color:var(--ink-2); }
.body-lg { font-size:clamp(16px,1.1vw,17px);line-height:1.65;color:var(--ink-2); }
.body    { font-size:15.5px;line-height:1.65;color:var(--ink-2); }
.small   { font-size:13px;line-height:1.55;color:var(--ink-3); }

/* ── 按钮 & 链接 ─────────────────────────────────────────── */
.btn {
  display:inline-flex;align-items:center;gap:14px;
  padding:14px 26px;
  border:1px solid var(--ink);background:var(--ink);color:var(--paper);
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;
  transition:background 200ms ease,color 200ms ease,border-color 200ms ease;
  cursor:pointer;
}
.btn:hover          { background:var(--moss);border-color:var(--moss); }
.btn--ghost         { background:transparent;color:var(--ink); }
.btn--ghost:hover   { background:var(--ink);color:var(--paper); }
.btn .arrow         { width:18px;height:1px;background:currentColor;position:relative; }
.btn .arrow::after  {
  content:"";position:absolute;right:0;top:-3px;
  width:7px;height:7px;border-top:1px solid currentColor;border-right:1px solid currentColor;
  transform:rotate(45deg);
}
.link {
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:0.16em;
  color:var(--ink);padding-bottom:4px;border-bottom:1px solid var(--ink);
  transition:gap 200ms ease,color 200ms ease,border-color 200ms ease;
}
.link:hover { gap:16px;color:var(--moss);border-color:var(--moss); }

/* ── 导航 ────────────────────────────────────────────────── */
/* 外层 .nav 提供视口留白，内层 .nav__inner 负责居中 */
.nav {
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--gutter);
  background:rgba(247,245,239,0.94);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line-soft);color:var(--ink);
  transition:background 300ms ease,border-color 300ms ease,color 300ms ease;
}
.nav__inner {
  width:100%;max-width:var(--max-content);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
}
.nav__logo img  { height:32px;width:auto; }
.nav__links     { display:flex;align-items:center;gap:clamp(20px,2.4vw,38px); }
.nav__link {
  font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:0.16em;
  color:inherit;opacity:0.85;position:relative;padding:6px 0;
  transition:opacity 200ms ease;
}
.nav__link::after {
  content:"";position:absolute;left:0;bottom:0;width:0;height:1px;
  background:currentColor;transition:width 220ms ease;
}
.nav__link:hover,.nav__link[aria-current="page"]::after { width:100%; }
.nav__link:hover { opacity:1; }
.nav__cta {
  font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:0.16em;
  padding:10px 18px;border:1px solid currentColor;
  transition:background 200ms ease,color 200ms ease;
}
.nav__cta:hover { background:var(--ink);color:var(--paper); }
.nav__burger { display:none;flex-direction:column;justify-content:space-between;width:28px;height:18px; }
.nav__burger span { display:block;height:1px;background:currentColor; }

/* 移动端抽屉导航 */
.nav-drawer {
  position:fixed;inset:0;z-index:99;background:var(--paper);
  padding:90px var(--gutter) 40px;
  display:none;flex-direction:column;gap:8px;
}
.nav-drawer.is-open { display:flex; }
.nav-drawer a {
  font-family:var(--font-serif);font-size:36px;font-weight:300;
  padding:14px 0;border-bottom:1px solid var(--line);
}

/* ── Hero / Banner ───────────────────────────────────────── */
/* 外层 .banner 提供视口留白，内层 .banner__inner 负责居中 */
.banner { position:relative;margin-top:var(--nav-h);padding:0 var(--gutter); }
.banner__inner {
  position:relative;max-width:var(--max-content);margin:0 auto;
  height:clamp(420px,56vw,640px);overflow:hidden;background:var(--stone);
}
.banner__media         { position:absolute;inset:0; }
.banner__media img     { width:100%;height:100%;object-fit:cover; }
.banner__media::after  {
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(15,16,10,0.25) 0%,rgba(15,16,10,0.05) 35%,rgba(15,16,10,0.55) 100%);
}
.banner__content {
  position:relative;height:100%;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  color:var(--paper);text-align:center;padding:0 var(--gutter);
}
.banner__eyebrow {
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.24em;text-transform:uppercase;
  margin-bottom:24px;opacity:0.92;display:inline-flex;align-items:center;gap:14px;
}
.banner__eyebrow .dot { width:6px;height:6px;border-radius:50%;background:currentColor; }
.banner__title {
  font-family:var(--font-serif);font-weight:300;
  font-size:clamp(56px,9vw,132px);line-height:0.95;letter-spacing:0.06em;
  margin:0 0 22px;text-transform:uppercase;
}
.banner__sub {
  font-family:var(--font-serif);font-style:italic;font-weight:300;
  font-size:clamp(20px,2vw,30px);line-height:1.35;max-width:720px;opacity:0.95;
}

/* ── 区块标题 ────────────────────────────────────────────── */
.sec-title          { text-align:center;margin-bottom:clamp(48px,6vw,80px); }
.sec-title__main {
  font-family:var(--font-serif);font-weight:300;
  font-size:clamp(34px,4.4vw,60px);line-height:1.05;letter-spacing:-0.012em;margin:0 0 14px;
}
.sec-title__sub {
  font-family:var(--font-serif);font-style:italic;font-weight:300;
  font-size:clamp(22px,2.6vw,36px);line-height:1.25;letter-spacing:-0.005em;
  color:var(--ink-2);margin:0;
}
.sec-title--left  { text-align:left; }
.sec-title__meta  {
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.2em;
  text-transform:uppercase;color:var(--ink-3);display:block;margin-bottom:24px;
}
.sec-actions { text-align:center;margin-top:clamp(40px,5vw,64px); }

/* ── 精选产品 Carousel ───────────────────────────────────── */
.carousel { position:relative; }
.carousel__track {
  display:grid;grid-auto-flow:column;
  grid-auto-columns:calc((100% - (var(--pcols) - 1) * var(--pgap-col)) / var(--pcols));
  gap:var(--pgap-col);overflow-x:auto;scroll-snap-type:x mandatory;
  scrollbar-width:none;padding-bottom:16px;
}
.carousel__track::-webkit-scrollbar { display:none; }
.carousel__nav    { display:flex;align-items:center;justify-content:center;gap:14px;margin-top:40px; }
.carousel__btn {
  width:48px;height:48px;border:1px solid var(--line);
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--ink);transition:background 200ms ease,color 200ms ease,border-color 200ms ease;
}
.carousel__btn:hover          { background:var(--ink);color:var(--paper);border-color:var(--ink); }
.carousel__btn:disabled       { opacity:0.35;cursor:not-allowed; }
.carousel__btn:disabled:hover { background:transparent;color:var(--ink);border-color:var(--line); }
.carousel__count {
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.16em;
  color:var(--ink-3);margin:0 12px;
}
/* 产品卡片（carousel 内） */
.product-card           { scroll-snap-align:start;display:block; }
.product-card__img      { position:relative;aspect-ratio:3/4;background:var(--stone);overflow:hidden;margin-bottom:18px; }
.product-card__img img  { width:100%;height:100%;object-fit:cover;transition:transform 400ms ease; }
.product-card:hover .product-card__img img { transform:scale(1.04); }
.product-card__title {
  font-family:var(--font-serif);font-weight:400;
  font-size:clamp(20px,1.6vw,24px);line-height:1.2;letter-spacing:-0.005em;
  color:var(--ink);margin:0;transition:color 200ms ease;
}
.product-card:hover .product-card__title { color:var(--moss); }

/* ── 关于简介 · 图文分栏 ─────────────────────────────────── */
.split {
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(40px,5vw,80px);align-items:center;
}
.split--right .split__media { order:2; }
.split__media     { aspect-ratio:4/5;background:var(--stone);overflow:hidden; }
.split__media img { width:100%;height:100%;object-fit:cover; }
.split__body      { max-width:540px; }
.split__stats {
  display:grid;grid-template-columns:1fr 1fr;gap:24px;
  margin-top:48px;padding-top:32px;border-top:1px solid var(--line);
}
.split__stat .num {
  font-family:var(--font-serif);font-weight:300;
  font-size:clamp(36px,4vw,52px);line-height:1;letter-spacing:-0.015em;margin-bottom:6px;
}
.split__stat .lbl { font-family:var(--font-mono);font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-3); }

/* ── 首页博客预览（2列） ─────────────────────────────────── */
.blog-row             { display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,3.5vw,48px); }
.blog-card            { display:block; }
.blog-card__img       { aspect-ratio:4/3;background:var(--stone);overflow:hidden;margin-bottom:24px; }
.blog-card__img img   { width:100%;height:100%;object-fit:cover;transition:transform 400ms ease; }
.blog-card:hover .blog-card__img img { transform:scale(1.03); }
.blog-card__meta      { display:flex;align-items:center;gap:14px;margin-bottom:14px; }
.blog-card__meta .date{ font-family:var(--font-mono);font-size:11px;letter-spacing:0.16em;color:var(--ink-3);text-transform:uppercase; }
.blog-card__meta .cat { font-family:var(--font-mono);font-size:10px;letter-spacing:0.18em;color:var(--ink-4);text-transform:uppercase; }
.blog-card__title {
  font-family:var(--font-serif);font-weight:400;
  font-size:clamp(22px,2.2vw,32px);line-height:1.2;letter-spacing:-0.005em;
  margin:0 0 14px;transition:color 200ms ease;
}
.blog-card:hover .blog-card__title { color:var(--moss); }
.blog-card__excerpt { color:var(--ink-3);font-size:15px;line-height:1.6;max-width:480px; }
.blog-card__excerpt--1line { display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden; }
.blog-card__excerpt--2lines { display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden; }

/* ── 推荐语 ──────────────────────────────────────────────── */
/* 外层 .testimonial 提供视口留白，内层 .testimonial__inner 负责居中 */
.testimonial           { background:var(--stone);padding:clamp(72px,10vw,132px) var(--gutter); }
.testimonial__inner    { max-width:920px;margin:0 auto;text-align:center; }
.testimonial .sec-title{ margin-bottom:40px; }
.testimonial__quote {
  font-family:var(--font-serif);font-weight:300;font-style:italic;
  font-size:clamp(24px,3vw,42px);line-height:1.3;letter-spacing:-0.01em;
  color:var(--ink);margin:0 0 40px;
}
.testimonial__author      { font-family:var(--font-mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-2); }
.testimonial__author .sep { margin:0 12px;color:var(--ink-4); }

/* ── CTA 行动区 ──────────────────────────────────────────── */
/* 外层 .cta 提供视口留白，内层 .cta__inner 负责居中 */
.cta { background:var(--ink);color:var(--paper);padding:clamp(56px,7vw,88px) var(--gutter); }
.cta__inner { max-width:var(--max-content);margin:0 auto;text-align:center; }
.cta__title {
  font-family:var(--font-serif);font-weight:300;
  font-size:clamp(36px,4.8vw,64px);line-height:1.05;letter-spacing:-0.015em;margin:0 0 18px;
}
.cta__sub {
  font-family:var(--font-serif);font-style:italic;font-weight:300;
  font-size:clamp(22px,2.4vw,34px);margin:0 0 40px;color:var(--stone);
}
.cta__actions { display:inline-flex;gap:14px;align-items:center;flex-wrap:wrap;justify-content:center; }
.cta .btn     { background:var(--paper);color:var(--ink);border-color:var(--paper); }
.cta .btn:hover { background:var(--stone);border-color:var(--stone); }
.cta__phone-row {
  margin-top:40px;padding-top:36px;position:relative;
  display:flex;flex-direction:column;align-items:center;gap:12px;
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.2em;
  text-transform:uppercase;color:rgba(247,245,239,0.55);
}
.cta__phone-row::before {
  content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:64px;height:1px;background:rgba(247,245,239,0.28);
}
.cta__phone {
  font-family:var(--font-serif);font-style:italic;font-weight:300;
  font-size:clamp(28px,3vw,42px);letter-spacing:-0.01em;color:var(--paper);text-transform:none;
}
.cta__phone:hover { color:var(--stone); }

/* ── 页脚 ────────────────────────────────────────────────── */
/* 外层 .footer 提供视口留白，内层 .footer__inner 负责居中 */
.footer { background:var(--ink);color:var(--paper);padding:0 var(--gutter) 28px; }
.footer__inner {
  max-width:var(--max-content);margin:0 auto;
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:clamp(32px,4vw,56px);
  padding:clamp(56px,7vw,80px) 0 56px;
  border-top:1px solid rgba(247,245,239,0.14);
}
.footer__brand img { height:36px;margin-bottom:22px; }
.footer__brand p   { color:rgba(247,245,239,0.65);font-size:14px;line-height:1.6;max-width:300px;margin:0; }
.footer__col h4 {
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.18em;
  text-transform:uppercase;color:rgba(247,245,239,0.55);margin:0 0 18px;font-weight:400;
}
.footer__col li      { margin-bottom:11px; }
.footer__col a       { color:var(--paper);font-size:14.5px;opacity:0.85;transition:opacity 200ms ease; }
.footer__col a:hover { opacity:1; }
.footer__col p       { color:rgba(247,245,239,0.85);font-size:14.5px;margin:0 0 10px;line-height:1.55; }
.footer-reach        { display:grid;gap:12px; }
.footer-reach__item  { margin:0; }
.footer-reach__link  {
  display:grid;grid-template-columns:20px 1fr;gap:10px;align-items:start;
  color:rgba(247,245,239,0.86);font-size:14.5px;line-height:1.55;opacity:1;
}
.footer-reach a.footer-reach__link { transition:color 200ms ease,opacity 200ms ease; }
.footer-reach a.footer-reach__link:hover { color:var(--stone);opacity:1; }
.footer-reach__icon {
  width:20px;height:20px;margin-top:1px;color:rgba(247,245,239,0.62);
  display:inline-flex;align-items:center;justify-content:center;
}
.footer-reach__icon svg { width:17px;height:17px; }
.footer__bottom {
  max-width:var(--max-content);margin:0 auto;
  display:flex;justify-content:space-between;align-items:center;
  padding-top:24px;border-top:1px solid rgba(247,245,239,0.14);
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.16em;
  text-transform:uppercase;color:rgba(247,245,239,0.55);
}
.footer__social   { display:flex;gap:14px; }
.footer__social a {
  width:36px;height:36px;border:1px solid rgba(247,245,239,0.24);border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  transition:background 200ms ease,color 200ms ease;
}
.footer__social a:hover { background:var(--paper);color:var(--ink); }
.footer__social svg     { width:14px;height:14px; }

/* ── 子页面头部 ──────────────────────────────────────────── */
/* 外层 .page-head 提供视口留白，内层 .page-head__inner 负责居中 */
.page-head {
  padding:calc(var(--nav-h) + clamp(40px,5.5vw,72px)) var(--gutter) clamp(40px,5.5vw,72px);
  background:var(--paper-2);
}
.page-head__inner { max-width:var(--max-content);margin:0 auto;text-align:center; }
.page-head__crumbs {
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.2em;text-transform:uppercase;
  color:var(--ink-3);margin-bottom:24px;display:inline-flex;align-items:center;gap:12px;
}
.page-head__crumbs a:hover { color:var(--ink); }
.page-head__crumbs .sep    { color:var(--ink-4); }
.page-head__title {
  font-family:var(--font-serif);font-weight:300;
  font-size:clamp(48px,7vw,96px);line-height:0.98;letter-spacing:-0.015em;margin:0 0 18px;
}
.page-head__sub {
  font-family:var(--font-serif);font-style:italic;font-weight:300;
  font-size:clamp(20px,2.2vw,30px);line-height:1.35;color:var(--ink-2);
  max-width:700px;margin:0 auto;
}

/* ── 产品分类落地页 ──────────────────────────────────────── */
.cat-grid { display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,2.4vw,32px); }
.cat-tile {
  position:relative;aspect-ratio:4/5;overflow:hidden;display:block;background:var(--stone);
}
.cat-tile img       { width:100%;height:100%;object-fit:cover;transition:transform 450ms ease; }
.cat-tile:hover img { transform:scale(1.04); }
.cat-tile::after {
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(15,16,10,0.1) 0%,rgba(15,16,10,0.65) 100%);
  pointer-events:none;
}
.cat-tile__body {
  position:absolute;inset:0;z-index:1;padding:clamp(28px,4vw,48px);
  display:flex;flex-direction:column;justify-content:end;color:var(--paper);
}
.cat-tile__eyebrow { font-family:var(--font-mono);font-size:11px;letter-spacing:0.2em;text-transform:uppercase;opacity:0.85;margin-bottom:12px; }
.cat-tile__name {
  font-family:var(--font-serif);font-weight:300;
  font-size:clamp(32px,3.6vw,52px);line-height:1.05;letter-spacing:-0.012em;margin:0 0 16px;
}
.cat-tile__desc { font-size:14.5px;line-height:1.55;opacity:0.88;max-width:360px;margin:0 0 24px; }
.cat-tile__link {
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;
  border-bottom:1px solid currentColor;padding-bottom:4px;align-self:start;
  transition:gap 200ms ease;
}
.cat-tile:hover .cat-tile__link { gap:16px; }

/* ── 产品列表网格 ─────────────────────────────────────────── */
.product-grid {
  display:grid;grid-template-columns:repeat(var(--pcols),1fr);
  column-gap:var(--pgap-col);row-gap:var(--pgap-row);
}
.cat-toolbar {
  display:flex;align-items:baseline;justify-content:space-between;
  gap:16px;flex-wrap:wrap;margin-bottom:clamp(32px,4vw,56px);
  padding-bottom:18px;border-bottom:1px solid var(--line);
}
.cat-toolbar__label { font-family:var(--font-mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink); }
.cat-toolbar__count { font-family:var(--font-mono);font-size:11px;letter-spacing:0.16em;color:var(--ink-3); }

/* ── 产品详情页 ──────────────────────────────────────────── */
/* 外层 .pd-back / .pd-main / .pd-related 提供视口留白，
   内层由插件输出的 .shell 负责居中 */
.pd-back {
  background:var(--paper-2);
  padding:calc(var(--nav-h) + clamp(28px,4vw,48px)) var(--gutter) clamp(24px,3vw,36px);
}
.pd-back .shell { display:flex;justify-content:space-between;align-items:center;gap:clamp(16px,2vw,24px);flex-wrap:wrap; }
.pd-back .page-head__crumbs { margin-bottom:0; }
.pd-meta-nav {
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--ink-3);display:inline-flex;align-items:center;gap:clamp(10px,1.4vw,18px);
}
.pd-meta-nav a:hover { color:var(--ink); }
.pd-main    { padding:var(--section-pad-tight) var(--gutter); }
.pd-grid    { display:grid;grid-template-columns:1.15fr 1fr;gap:clamp(32px,4.4vw,72px);align-items:start; }
.pd-gallery__main     { aspect-ratio:4/5;background:var(--stone);overflow:hidden; }
.pd-gallery__main img { width:100%;height:100%;object-fit:cover; }
.pd-info              { position:sticky;top:calc(var(--nav-h) + 24px); }
.pd-info__eyebrow {
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.2em;text-transform:uppercase;
  color:var(--ink-3);margin-bottom:18px;display:inline-flex;align-items:center;
  gap:clamp(10px,1.2vw,14px);flex-wrap:wrap;
}
.pd-info__code { color:var(--ink); }
.pd-info__name {
  font-family:var(--font-serif);font-weight:300;
  font-size:clamp(36px,4.8vw,64px);line-height:1.02;letter-spacing:-0.015em;margin:0 0 20px;
}
.pd-info__desc {
  font-family:var(--font-serif);font-style:italic;font-weight:300;
  font-size:clamp(17px,1.4vw,22px);line-height:1.5;color:var(--ink-2);
  margin:0 0 clamp(28px,3.4vw,40px);max-width:540px;
}
.pd-specs   { border-top:1px solid var(--line);margin-top:clamp(24px,3vw,32px); }
.pd-spec {
  display:grid;grid-template-columns:1fr 1.4fr;
  padding:clamp(14px,1.5vw,18px) 0;border-bottom:1px solid var(--line);align-items:baseline;
}
.pd-spec dt { font-family:var(--font-mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-3); }
.pd-spec dd { margin:0;font-size:15px;color:var(--ink);font-family:var(--font-sans); }
.pd-cta-row { display:flex;gap:12px;margin-top:clamp(32px,4vw,48px);flex-wrap:wrap; }
.pd-app-grid     { display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,24px); }
.pd-app-item     { aspect-ratio:1;overflow:hidden;background:var(--stone); }
.pd-app-item img { width:100%;height:100%;object-fit:cover;transition:transform 400ms ease; }
.pd-app-item:hover img { transform:scale(1.04); }
.pd-related { background:var(--paper-2);padding:var(--section-pad-tight) var(--gutter); }

/* ── 博客归档列表 ─────────────────────────────────────────── */
.blog-list { display:flex;flex-direction:column; }
.blog-row-item {
  display:grid;grid-template-columns:170px 1fr 320px;
  gap:clamp(24px,4vw,56px);padding:clamp(32px,4vw,48px) 0;
  border-top:1px solid var(--line);align-items:start;
}
.blog-row-item:last-child   { border-bottom:1px solid var(--line); }
.blog-row-item__date {
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.16em;
  text-transform:uppercase;color:var(--ink-3);padding-top:6px;
}
.blog-row-item__body h3 {
  font-family:var(--font-serif);font-weight:400;
  font-size:clamp(24px,2.4vw,36px);letter-spacing:-0.005em;line-height:1.2;
  margin:0 0 14px;transition:color 200ms ease;
}
.blog-row-item:hover .blog-row-item__body h3 { color:var(--moss); }
.blog-row-item__body p { color:var(--ink-3);max-width:520px;line-height:1.6;margin:0;font-size:15px; }
.blog-row-item__img    { aspect-ratio:4/3;overflow:hidden;background:var(--stone); }
.blog-row-item__img img{ width:100%;height:100%;object-fit:cover;transition:transform 400ms ease; }
.blog-row-item:hover .blog-row-item__img img { transform:scale(1.04); }

/* ── 联系页面 ────────────────────────────────────────────── */
.contact-grid { display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,5vw,80px); }
.contact-info dt {
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.16em;text-transform:uppercase;
  color:var(--ink-3);margin-top:28px;margin-bottom:8px;
}
.contact-info dt:first-of-type { margin-top:0; }
.contact-info dd {
  margin:0;font-family:var(--font-serif);font-size:clamp(22px,2vw,28px);
  font-weight:300;line-height:1.3;letter-spacing:-0.005em;
}
.contact-info dd a:hover { color:var(--moss); }
.contact-info__muted {
  font-size:15px !important;color:var(--ink-3);font-family:var(--font-sans) !important;
  line-height:1.7 !important;letter-spacing:0 !important;font-weight:400 !important;
}

/* ── 法律页面 ────────────────────────────────────────────── */
.legal-content {
  max-width:860px;margin:0 auto;
  font-family:var(--font-sans);font-size:16px;line-height:1.75;color:var(--ink-2);
}
.legal-content h2 {
  font-family:var(--font-serif);font-weight:400;font-size:clamp(24px,2.5vw,34px);
  line-height:1.2;letter-spacing:-0.005em;color:var(--ink);margin:2.2em 0 0.55em;
}
.legal-content h2:first-child { margin-top:0; }
.legal-content p { margin:0 0 1.1em; }
.legal-content ul { list-style:disc;margin:0 0 1.4em 1.2em;padding:0; }
.legal-content li { margin:0 0 0.55em;padding-left:0.15em; }
.legal-content a { color:var(--moss);border-bottom:1px solid currentColor; }
/* 联系表单（外观由主题控制，插件负责逻辑和 AJAX 提交） */
.tt-form-wrap { display:grid;gap:20px; }
.tt-form-wrap .form-row      { display:grid;gap:8px; }
.tt-form-wrap .form-row--two { grid-template-columns:1fr 1fr;gap:20px; }
.tt-form-wrap label {
  font-family:var(--font-mono);font-size:10px;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--ink-3);
}
.tt-form-wrap input,
.tt-form-wrap textarea,
.tt-form-wrap select {
  border:0;border-bottom:1px solid var(--ink);background:transparent;
  padding:10px 0;font-family:var(--font-sans);font-size:16px;color:var(--ink);width:100%;
}
.tt-form-wrap input:focus,
.tt-form-wrap textarea:focus,
.tt-form-wrap select:focus { outline:none;border-bottom-color:var(--moss); }
.tt-form-wrap textarea { resize:vertical;min-height:110px; }

/* ── About 关于页面 ──────────────────────────────────────── */
.values-grid {
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:clamp(28px,4vw,48px);margin-top:clamp(40px,5vw,56px);
}
.value__num   { font-family:var(--font-mono);font-size:11px;letter-spacing:0.16em;color:var(--ink-4);margin-bottom:24px; }
.value__title { font-family:var(--font-serif);font-weight:400;font-size:clamp(22px,2.2vw,28px);letter-spacing:-0.005em;margin:0 0 14px;line-height:1.2; }
.value__body  { color:var(--ink-3);line-height:1.6;font-size:15px; }
.timeline     { display:grid;grid-template-columns:180px 1fr; }
.timeline__row { display:contents; }
.timeline__year {
  font-family:var(--font-serif);font-weight:300;
  font-size:clamp(40px,4.4vw,56px);line-height:1;letter-spacing:-0.015em;
  padding:clamp(36px,4vw,48px) 0;border-top:1px solid var(--line);
}
.timeline__body {
  padding:clamp(40px,4.4vw,56px) 0 clamp(36px,4vw,48px);border-top:1px solid var(--line);
}
.timeline__row:last-child .timeline__year,
.timeline__row:last-child .timeline__body { border-bottom:1px solid var(--line); }
.timeline__body h4 { font-family:var(--font-serif);font-weight:400;font-size:clamp(20px,2vw,26px);margin:0 0 12px;letter-spacing:-0.005em; }
.timeline__body p  { color:var(--ink-3);max-width:620px;line-height:1.6;margin:0;font-size:15px; }

/* ── 博客单文 ────────────────────────────────────────────── */
/* 外层 .tt-blog-hero 提供视口留白，内层 .tt-blog-hero-inner 负责居中 */
.tt-blog-single { padding-top:var(--nav-h); }
.tt-blog-hero {
  min-height:60vh;display:flex;align-items:flex-end;
  background-size:cover;background-position:center;position:relative;
  padding:0 var(--gutter);
}
.tt-blog-hero::after {
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(15,16,10,0.2) 0%,rgba(15,16,10,0.65) 100%);
}
.tt-blog-hero-inner {
  position:relative;z-index:1;
  padding:clamp(48px,6vw,80px) 0;
  max-width:var(--max-content);margin:0 auto;width:100%;
}
.tt-blog-hero-title {
  font-family:var(--font-serif);font-weight:300;
  font-size:clamp(40px,6vw,80px);line-height:1;letter-spacing:-0.015em;
  color:var(--paper);margin:0 0 16px;
}
.tt-blog-hero-date {
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.2em;
  text-transform:uppercase;color:rgba(247,245,239,0.7);
}
/* 博客正文：阅读列宽 720px，自带 gutter 兼容窄屏，与全宽容器规则不冲突 */
.tt-blog-content {
  max-width:720px;margin:0 auto;padding:clamp(56px,8vw,96px) var(--gutter);
  font-family:var(--font-serif);font-size:clamp(17px,1.4vw,20px);
  line-height:1.65;color:var(--ink-2);
}
.tt-blog-content h2,.tt-blog-content h3 {
  font-weight:300;letter-spacing:-0.01em;margin-top:2em;margin-bottom:0.5em;color:var(--ink);
}
.tt-blog-content h2  { font-size:clamp(28px,3vw,40px); }
.tt-blog-content h3  { font-size:clamp(22px,2.2vw,30px); }
.tt-blog-content p   { margin-bottom:1.4em; }
.tt-blog-content img { width:100%;height:auto;margin:2em 0; }
.tt-blog-content a   { border-bottom:1px solid var(--moss);color:var(--moss); }
/* 博客单文底部"返回博客"链接行 */
.tt-back-row { padding:0 var(--gutter) clamp(56px,8vw,96px); }

/* ── 404 页面 ────────────────────────────────────────────── */
.tt-404        { min-height:80vh;display:flex;align-items:center;justify-content:center;padding:var(--nav-h) var(--gutter) 0; }
.tt-404__inner { text-align:center;max-width:600px; }
.tt-404__code  { font-family:var(--font-serif);font-weight:300;font-size:clamp(80px,15vw,180px);line-height:1;letter-spacing:-0.03em;color:var(--stone-deep); }
.tt-404__title { font-family:var(--font-serif);font-weight:300;font-size:clamp(28px,4vw,48px);margin:0 0 20px; }
.tt-404__body  { font-size:16px;color:var(--ink-3);line-height:1.6;margin-bottom:40px; }

/* ── 响应式断点 ──────────────────────────────────────────── */
/* 平板（960px 以下）*/
@media (max-width:960px) {
  .nav__links,.nav__cta { display:none; }
  .nav__burger          { display:flex; }

  :root { --pcols:3;--pgap-col:clamp(14px,1.8vw,20px);--pgap-row:clamp(24px,3vw,36px); }

  .split                      { grid-template-columns:1fr;gap:36px; }
  .split--right .split__media { order:0; }
  .split__body                { max-width:none; }

  .blog-row            { grid-template-columns:1fr; }
  .blog-row-item       { grid-template-columns:1fr;gap:20px; }
  .blog-row-item__date { padding-top:0; }
  .blog-row-item__img  { aspect-ratio:16/9; }

  .footer__inner { grid-template-columns:1fr 1fr; }
  .footer__brand { grid-column:span 2; }

  .pd-grid          { grid-template-columns:1fr;gap:clamp(28px,4vw,40px); }
  .pd-gallery__main { aspect-ratio:3/4;max-width:640px;margin:0 auto; }
  .pd-info          { position:static; }
  .pd-app-grid      { grid-template-columns:repeat(2,1fr); }

  .values-grid  { grid-template-columns:1fr;gap:28px; }
  .timeline     { grid-template-columns:100px 1fr; }
  .timeline__year { font-size:32px; }
  .cat-grid     { grid-template-columns:1fr; }
  .contact-grid { grid-template-columns:1fr;gap:40px; }
}

/* 移动端（720px 以下）*/
@media (max-width:720px) {
  :root { --nav-h:64px;--pcols:2;--pgap-col:14px;--pgap-row:clamp(22px,4vw,28px); }

  .banner__inner { height:clamp(380px,70vw,480px); }
  .banner__title { font-size:clamp(44px,12vw,72px);letter-spacing:0.04em; }
  .banner__sub   { font-size:clamp(16px,4vw,22px); }

  .footer__inner  { grid-template-columns:1fr; }
  .footer__brand  { grid-column:span 1; }
  .footer__bottom { flex-direction:column;gap:18px;align-items:flex-start; }

  .tt-form-wrap .form-row--two { grid-template-columns:1fr;gap:20px; }
  .cta__phone-row { flex-direction:column;gap:8px; }

  .pd-back .shell   { flex-direction:column;align-items:flex-start;gap:14px; }
  .pd-gallery__main { aspect-ratio:3/4;max-width:none; }
  .pd-cta-row .btn  { flex:1 1 160px;justify-content:center; }
  .pd-app-grid      { grid-template-columns:repeat(2,1fr);gap:14px; }
  .timeline         { grid-template-columns:1fr; }
  .timeline__year   { padding-bottom:0;border-bottom:0; }
  .timeline__body   { padding-top:12px;border-top:0; }
  .timeline__row:last-child .timeline__year { border-bottom:0; }

  .blog-row-item { grid-template-columns:1fr; }
}

/* 小屏（480px 以下）*/
@media (max-width:480px) {
  .pd-app-grid              { grid-template-columns:1fr;gap:12px; }
  .pd-app-grid .pd-app-item { aspect-ratio:4/3; }
  .pd-info__name            { font-size:clamp(32px,9vw,44px); }
}
