/* Editorial workshop report stylesheet. */

*,*::before,*::after{box-sizing:border-box}

@font-face{
  font-family:"Tsanger JinKai";
  src:url("TsangerJinKai02-W04.ttf") format("truetype");
  font-weight:400 700;
  font-style:normal;
  font-display:swap;
}

:root{
  --brand:#e8662f;
  --brand-soft:#fff0e4;
  --brand-pale:#ffd8bd;
  --paper:#f6f1e8;
  --paper-2:#fbf7ef;
  --sheet:#fffaf3;
  --ink:#171512;
  --ink-2:#34302b;
  --muted:#756c61;
  --faint:#9a8f81;
  --line:#e8dccb;
  --line-strong:#d8c8b3;
  --red:#8b4513;
  --shadow:0 24px 70px rgba(54,42,28,.08);
  --serif:"Tsanger JinKai","LXGW WenKai","Kaiti SC","KaiTi","STKaiti","Source Han Serif SC","Noto Serif CJK SC",serif;
  --sans:var(--serif);
  --preheat-bg-image:url("image5.webp");
  --outcome-bg-image:url("image28.webp");
}

html{scroll-behavior:smooth}
body{
  color:var(--ink);
  background:
    linear-gradient(180deg,rgba(255,255,255,.5),rgba(255,255,255,0) 26rem),
    radial-gradient(circle at 12% 8%,rgba(232,102,47,.075),transparent 23rem),
    var(--paper);
  font-family:var(--serif);
  line-height:1.66;
  letter-spacing:.015em;
}

body::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:-1;
  pointer-events:none;
  background:
    linear-gradient(90deg,rgba(23,21,18,.025) 1px,transparent 1px),
    linear-gradient(rgba(23,21,18,.018) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:linear-gradient(180deg,rgba(0,0,0,.52),transparent 62%);
}

img{max-width:100%}
strong{font-weight:600;color:var(--ink)}
section{position:relative;padding:6.5rem clamp(1.25rem,4vw,3.5rem)}
.container{max-width:1160px;margin:0 auto}

.site-logo{
  box-shadow:none;
  background:rgba(251,247,239,.88);
  border-bottom:1px solid rgba(232,220,203,.78);
}

.brand-logo{
  width:min(300px,50vw);
  filter:brightness(0) saturate(100%) invert(43%) sepia(89%) saturate(1350%) hue-rotate(343deg) brightness(98%) contrast(94%);
}

.hero{
  min-height:100svh;
  display:grid;
  grid-template-columns:minmax(330px,.82fr) minmax(520px,1.18fr);
  align-items:center;
  gap:clamp(2.5rem,6vw,6.2rem);
  padding:7.4rem clamp(1.25rem,5vw,5.5rem) 4.2rem;
  border-bottom:1px solid var(--line);
  overflow:hidden;
}

.hero::after{
  content:"";
  position:absolute;
  right:0;
  top:0;
  bottom:0;
  width:38vw;
  background:linear-gradient(90deg,transparent,rgba(232,102,47,.05));
  pointer-events:none;
}

.hero-content,.hero-visual{position:relative;z-index:1}

.hero-badge,
.s-tag,
.dp-title,
.vc-num,
.oc-type,
.ov-title,
.pp-label,
.sc-num{
  font-family:var(--sans);
  font-size:.72rem;
  font-weight:500;
  letter-spacing:.17em;
  text-transform:uppercase;
  color:var(--brand);
}

.hero-badge,.s-tag{
  display:inline-block;
  border:1px solid var(--brand-pale);
  background:rgba(255,240,228,.72);
  border-radius:999px;
  padding:.28rem .7rem;
}

.hero-badge{margin-bottom:1.55rem}

.hero-title{
  font-size:clamp(54px,7vw,104px);
  font-weight:500;
  line-height:1.03;
  letter-spacing:.035em;
  color:var(--ink);
  margin-bottom:.7rem;
  white-space:nowrap;
}

.hero-title em{font-style:normal;color:var(--brand)}
.hero-en{
  color:var(--muted);
  font-size:clamp(12px,1.2vw,15px);
  letter-spacing:.22em;
  text-transform:uppercase;
  margin-bottom:2rem;
}

.hero-sub{
  color:var(--ink-2);
  font-size:clamp(20px,2.2vw,29px);
  font-weight:500;
  margin-bottom:.55rem;
}

.hero-meta{
  color:var(--muted);
  font-size:.96rem;
  margin-bottom:2.4rem;
}

.hero-journey{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:.5rem .6rem;
}

.j-node{
  min-height:38px;
  display:inline-flex;
  align-items:center;
  padding:.42rem .72rem;
  border:1px solid var(--line);
  border-radius:999px;
  background:rgba(255,250,243,.72);
  color:var(--ink-2);
  font-size:.9rem;
  line-height:1.3;
}

.j-node.hi{
  border-color:var(--brand);
  color:var(--brand);
  background:var(--brand-soft);
}

.j-arrow{color:var(--faint)}

.hero-visual{
  border:1px solid var(--line-strong);
  border-radius:12px;
  overflow:hidden;
  background:var(--sheet);
  box-shadow:var(--shadow);
}

.hero-visual::before{
  content:"";
  position:absolute;
  inset:10px;
  border:1px solid rgba(255,250,243,.52);
  pointer-events:none;
  z-index:1;
}

.hero-visual img{
  display:block;
  width:100%;
  aspect-ratio:1920/956;
  height:auto;
  object-fit:contain;
}

.scroll-hint{
  position:absolute;
  left:clamp(1.25rem,5vw,5.5rem);
  bottom:1.65rem;
  color:var(--muted);
  font-size:.7rem;
  letter-spacing:.18em;
}

.scroll-hint::after{
  content:"";
  display:block;
  width:46px;
  height:1px;
  margin-top:.42rem;
  background:var(--brand);
}

.reveal{opacity:1;transform:none;transition:opacity .65s ease,transform .65s ease}
.reveal.visible{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .reveal,.reveal.visible{opacity:1;transform:none;transition:none}
}

.s-title{
  color:var(--ink);
  font-size:clamp(30px,4.4vw,54px);
  font-weight:500;
  line-height:1.15;
  letter-spacing:.025em;
  margin:.65rem 0 .8rem;
}

.s-desc{
  max-width:820px;
  color:var(--muted);
  font-size:1rem;
  line-height:1.8;
}

.divider{
  width:64px;
  height:1px;
  background:var(--brand);
  margin:1.15rem 0 2rem;
}

.stats-bg{
  background:linear-gradient(180deg,var(--paper),var(--paper-2));
  border-bottom:1px solid var(--line);
}

.stats-hdr{
  max-width:900px;
  margin:0 auto 3rem;
  text-align:center;
}

.stats-hdr .s-desc{margin-left:auto;margin-right:auto}

.stats-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--line-strong);
  border-bottom:1px solid var(--line-strong);
  margin-bottom:2.5rem;
}

.stat-card{
  padding:1.6rem 1.25rem;
  border-right:1px solid var(--line);
  background:rgba(255,250,243,.38);
}

.stat-card:last-child{border-right:0}
.stat-num{
  color:var(--brand);
  font-size:clamp(42px,6vw,68px);
  font-weight:500;
  line-height:1;
  margin-bottom:.55rem;
}

.stat-lbl{color:var(--muted);font-size:.9rem}

.ceo-quote{
  max-width:960px;
  margin:0 auto;
  padding:2rem 0 0;
  border-top:1px solid var(--line);
  color:var(--ink-2);
}

.ceo-quote p{
  font-size:clamp(18px,2vw,23px);
  line-height:1.75;
}

.ceo-quote cite{
  display:block;
  margin-top:1rem;
  color:var(--brand);
  font-style:normal;
  font-size:.95rem;
}

.red-photo{
  position:relative;
  border:1px solid var(--line-strong);
  border-radius:12px;
  overflow:hidden;
  background:var(--sheet);
  box-shadow:var(--shadow);
}

.red-photo img{
  display:block;
  width:100%;
  height:auto;
  object-fit:contain;
}

.preheat-bg{
  background:var(--sheet);
  border-bottom:1px solid var(--line);
}

.preheat-bg::before,
.outcome-bg::before{
  content:"";
  position:absolute;
  inset:0;
  background:var(--preheat-bg-image) center/cover no-repeat;
  opacity:.035;
  filter:grayscale(1);
  pointer-events:none;
}

.preheat-bg .container,.outcome-bg .container{position:relative}

.nanhu-feature{
  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(360px,.95fr);
  gap:clamp(1.4rem,3.5vw,3rem);
  align-items:start;
  margin:2.4rem 0 1.9rem;
}

.nanhu-copy{
  border-top:1px solid var(--line-strong);
  border-bottom:1px solid var(--line);
  padding:1.35rem 0 1.45rem;
}

.nanhu-eyebrow{
  color:var(--brand);
  font-size:.78rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  margin-bottom:.55rem;
}

.nanhu-copy h3{
  color:var(--ink);
  font-size:clamp(28px,3.5vw,46px);
  font-weight:500;
  line-height:1.16;
  letter-spacing:.025em;
  margin-bottom:.95rem;
}

.nanhu-copy p{
  color:var(--ink-2);
  font-size:clamp(16px,1.05vw,18px);
  line-height:1.74;
  margin:0 0 .72rem;
}

.spirit-block{
  margin:.85rem 0;
  padding:.78rem 0 .82rem;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}

.spirit-block + .spirit-block{
  margin-top:-.3rem;
  border-top:0;
}

.spirit-heading{
  color:var(--brand)!important;
  font-size:.9rem!important;
  line-height:1.5!important;
  letter-spacing:.08em;
  margin-bottom:.52rem!important;
}

.spirit-lines{
  display:grid;
  gap:.32rem;
}

.spirit-lines p{
  display:grid;
  grid-template-columns:auto auto 1fr;
  gap:.62rem;
  align-items:baseline;
  margin:0!important;
  line-height:1.45!important;
}

.spirit-lines span{
  color:var(--brand);
  font-size:clamp(19px,1.45vw,24px);
  font-weight:600;
  letter-spacing:.04em;
  white-space:nowrap;
}

.spirit-lines em{
  color:var(--ink);
  font-style:normal;
  font-size:clamp(17px,1.2vw,21px);
}

.spirit-lines i{
  color:var(--faint);
  font-style:normal;
  font-size:clamp(17px,1.2vw,21px);
}

.spirit-source{
  display:grid;
  gap:.34rem;
}

.spirit-source p{
  color:var(--ink);
  font-size:clamp(16px,1.12vw,19px);
  font-weight:500;
  line-height:1.58;
  margin:0!important;
}

.spirit-meaning{
  background:linear-gradient(90deg,rgba(232,102,47,.07),transparent 76%);
  padding-left:1rem;
  border-left:3px solid var(--brand);
}

.nanhu-copy .nanhu-closing{
  color:var(--brand);
  font-weight:600;
  font-size:clamp(16px,1.05vw,18px);
  line-height:1.74;
  margin-top:.7rem;
}

.atags,.tag-cloud,.conv-values{
  display:flex;
  flex-wrap:wrap;
  gap:.55rem;
}

.atags{margin:1.8rem 0 2rem}
.atag,.vtag{
  display:inline-flex;
  align-items:center;
  min-height:30px;
  border:1px solid var(--line);
  border-radius:999px;
  background:var(--paper-2);
  color:var(--ink-2);
  padding:.3rem .62rem;
  font-size:.86rem;
  line-height:1.35;
}

.vtag.hot{border-color:var(--brand-pale);background:var(--brand-soft);color:var(--brand)}
.vtag.vhot{border-color:var(--brand);background:var(--brand);color:var(--sheet)}

.mosaic{
  display:grid;
  grid-template-columns:1.12fr .88fr;
  gap:1rem;
}

.mosaic .pi,
.photo-strip,
.oc-photo,
.pp-photo{
  position:relative;
  overflow:hidden;
  border:1px solid var(--line);
  border-radius:10px;
  background:var(--paper);
}

.mosaic .pi:first-child{grid-column:1/-1}
.mosaic img,
.photo-strip img,
.oc-photo img{
  display:block;
  width:100%;
  height:auto;
  object-fit:contain;
}

.mosaic .pi img{background:var(--paper)}

.mosaic .pi:not(:first-child){
  display:flex;
  flex-direction:column;
}

.mosaic .pi:not(:first-child) img{
  height:360px;
  object-fit:cover;
}

.mosaic .pi:not(:first-child) .pcap{
  flex:1;
}

.wide-photo{margin-top:1rem}
.wide-photo > div{
  position:relative;
  overflow:hidden;
  border:1px solid var(--line);
  border-radius:10px;
  background:var(--paper);
}
.wide-photo img{
  display:block;
  width:100%;
  height:auto;
  object-fit:contain;
}

.pcap{
  border-top:1px solid var(--line);
  background:rgba(255,250,243,.9);
  color:var(--muted);
  padding:.62rem .78rem;
  font-size:.84rem;
  line-height:1.45;
}

.day-hdr{
  display:flex;
  align-items:center;
  gap:1rem;
  margin-bottom:1.5rem;
}

.day-badge{
  border:1px solid var(--brand);
  color:var(--brand);
  border-radius:999px;
  padding:.32rem .62rem;
  font-size:.75rem;
  letter-spacing:.12em;
}

.day-theme{color:var(--muted);font-size:1rem}

.timeline-item{
  display:grid;
  grid-template-columns:88px minmax(0,1fr);
  gap:2rem;
  padding:2.6rem 0;
  border-top:1px solid var(--line);
}

.timeline-item:last-child{border-bottom:1px solid var(--line)}

.t-marker{position:relative}
.t-dot{
  width:54px;
  height:54px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  border:1px solid var(--brand);
  background:var(--brand-soft);
  color:var(--brand);
  font-size:.82rem;
  font-weight:500;
}
.t-line{display:none}
.t-content{padding-top:.15rem}
.t-title{
  color:var(--ink);
  font-size:clamp(24px,3vw,36px);
  font-weight:500;
  line-height:1.2;
}
.t-sub{
  color:var(--muted);
  font-size:.95rem;
  margin:.35rem 0 1.5rem;
}

.data-panels{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1rem;
  margin:1.2rem 0;
}

.dp{
  border:1px solid var(--line);
  border-radius:10px;
  background:rgba(255,250,243,.72);
  padding:1.15rem;
}

.dp-title{
  padding-bottom:.55rem;
  margin-bottom:.8rem;
  border-bottom:1px solid var(--line);
}

.di{margin-bottom:.75rem}
.di-lbl{
  display:flex;
  justify-content:space-between;
  gap:1rem;
  color:var(--ink-2);
  font-size:.88rem;
}
.di-pct{color:var(--brand)}
.dbar{
  height:5px;
  margin-top:.34rem;
  overflow:hidden;
  border-radius:999px;
  background:#eadfd1;
}
.dbar-fill{
  width:0;
  height:100%;
  background:var(--brand);
  border-radius:999px;
  transition:width 1.1s cubic-bezier(.4,0,.2,1);
}

.front-mid-back,
.mission-blk,
.vision-blk,
.conv-box,
.pressure,
.pp-wrap{
  border:1px solid var(--line);
  border-radius:10px;
  background:rgba(255,250,243,.72);
  padding:1.3rem;
  margin:1.2rem 0;
}

.role-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1rem;
  margin-top:.95rem;
}

.role-card{
  border-top:3px solid var(--brand);
  background:var(--paper-2);
  padding:1rem;
}

.role-name{
  color:var(--brand);
  font-size:1.35rem;
  font-weight:600;
  line-height:1.2;
}

.role-sub{
  color:var(--muted);
  font-size:.84rem;
  margin:.15rem 0 .8rem;
}

.role-card p{
  color:var(--ink-2);
  font-size:.88rem;
  line-height:1.62;
  margin:.46rem 0;
}

.role-summary,
.insight,
.overnight,
.conv-note{
  margin-top:1rem;
  border-left:3px solid var(--brand);
  background:var(--brand-soft);
  color:var(--ink-2);
  padding:.9rem 1rem;
  font-size:.92rem;
  line-height:1.66;
}

.mission-blk{
  background:var(--ink);
  border-color:var(--ink);
  color:var(--sheet);
}

.m-lbl{color:var(--brand-pale);font-size:.74rem;letter-spacing:.17em;text-transform:uppercase;margin-bottom:.8rem}
.m-text{
  color:var(--sheet);
  font-size:clamp(28px,4vw,46px);
  line-height:1.2;
  font-weight:500;
  letter-spacing:.06em;
}

.m-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1px;
  margin-top:1.7rem;
  background:rgba(255,250,243,.16);
}

.m-card{
  background:var(--ink);
  padding:1rem;
}

.m-card h4{
  color:var(--ink);
  font-size:.96rem;
  font-weight:600;
  margin-bottom:.45rem;
}

.m-card h4{color:var(--sheet)}
.m-card p{color:rgba(255,250,243,.72);font-size:.84rem;line-height:1.62}

.vision-blk{background:var(--sheet)}
.v-text{
  color:var(--ink);
  font-size:clamp(26px,3.4vw,42px);
  font-weight:500;
  line-height:1.25;
  margin:.6rem 0 1rem;
}
.v-text span{color:var(--brand)}

.vision-lead{
  max-width:720px;
  color:var(--muted);
  font-size:.9rem;
  line-height:1.7;
  margin-bottom:1.55rem;
}

.v-persp{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1rem;
}

.vp-card{
  border-top:1px solid var(--line);
  padding:1rem 1rem .2rem 0;
  position:relative;
}

.vp-num{
  color:var(--brand);
  font-size:.72rem;
  letter-spacing:.14em;
  margin-bottom:.45rem;
}

.vp-card h4{
  color:var(--ink);
  font-size:1.05rem;
  font-weight:600;
  margin-bottom:.45rem;
}

.vp-card p{
  color:var(--muted);
  font-size:.88rem;
  line-height:1.66;
}

.v-interp{
  margin-top:1.35rem;
  display:grid;
  grid-template-columns:180px 1fr;
  gap:1.25rem;
  align-items:start;
  border-top:1px solid var(--line-strong);
  padding-top:1rem;
}

.vi-label{
  color:var(--brand);
  font-size:.76rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  line-height:1.5;
}

.vi-list{
  display:grid;
  gap:.65rem;
}

.vi-item{
  display:grid;
  grid-template-columns:6.5em 1fr;
  gap:1rem;
  align-items:baseline;
}

.vi-item h4{
  color:var(--ink);
  font-size:.98rem;
  font-weight:600;
}

.vi-item p{
  color:var(--muted);
  font-size:.88rem;
  line-height:1.62;
}

.day2-bg{
  background:linear-gradient(180deg,var(--paper-2),var(--paper));
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}

.conv-box p,
.pressure p,
.pp-text p{
  color:var(--muted);
  font-size:.92rem;
  line-height:1.72;
}

.conv-values{
  align-items:center;
  margin:1rem 0;
}

.value-basis{
  margin:1rem 0 1.2rem;
  border:1px solid var(--brand-pale);
  border-left:4px solid var(--brand);
  background:var(--brand-soft);
  padding:1rem 1.1rem;
}

.basis-label{
  color:var(--brand);
  font-size:.72rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  margin-bottom:.25rem;
}

.basis-name{
  color:var(--ink);
  font-size:clamp(26px,3vw,40px);
  font-weight:500;
  line-height:1.2;
}

.value-basis p{
  max-width:840px;
  margin-top:.5rem;
}

.conv-v{
  color:var(--ink);
  font-size:clamp(23px,3vw,36px);
  font-weight:500;
}
.conv-v.hi{color:var(--brand)}
.conv-sep{color:var(--faint)}

.values-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1rem;
  margin:1.2rem 0;
}

.vc{
  border:1px solid var(--line);
  border-radius:10px;
  background:var(--sheet);
  overflow:hidden;
}

.vc-hdr{
  background:var(--sheet)!important;
  color:var(--ink);
  padding:1.2rem 1.25rem 1rem;
  border-top:4px solid var(--brand);
  border-bottom:1px solid var(--line);
}

.vc-name{
  color:var(--ink);
  font-size:1.7rem;
  font-weight:600;
  line-height:1.2;
  margin:.2rem 0 .48rem;
}

.vc-def{
  color:var(--muted);
  font-size:.88rem;
  line-height:1.58;
}

.vc-body{padding:1.15rem 1.25rem}
.bg-group{margin-bottom:1rem}
.bg-title{
  display:flex;
  align-items:center;
  gap:.44rem;
  color:var(--brand)!important;
  font-size:.77rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  margin-bottom:.42rem;
}
.bdot{width:6px;height:6px;border-radius:50%;background:var(--brand)!important}
.blist{list-style:none;margin:0;padding:0}
.blist li{
  color:var(--ink-2);
  font-size:.85rem;
  line-height:1.62;
  padding:.23rem 0 .23rem .75rem;
  border-left:1px solid var(--line);
}
.vc-foot{
  border-top:1px solid var(--line);
  background:var(--paper-2);
  color:var(--muted);
  padding:.85rem 1.25rem;
  font-size:.8rem;
  line-height:1.55;
}

.pressure{
  background:var(--ink);
  border-color:var(--ink);
  color:var(--sheet);
}
.pressure h3{font-size:1.28rem;font-weight:500;margin-bottom:.45rem}
.pressure p{color:rgba(255,250,243,.7)}
.sc-grid{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:1px;
  background:rgba(255,250,243,.18);
  margin-top:1rem;
}
.sc{
  background:var(--ink);
  padding:.9rem;
}
.sc-num{color:var(--brand-pale);margin-bottom:.35rem}
.sc-text{color:var(--sheet);font-size:.86rem;line-height:1.55}

.photo-strip{margin-top:1.2rem}
.photo-strip img{background:var(--paper)}

.pp-wrap{
  display:grid;
  grid-template-columns:.72fr 1.28fr;
  gap:1.4rem;
  align-items:center;
}
.pp-text h3{
  color:var(--ink);
  font-size:1.38rem;
  font-weight:600;
  margin-bottom:.55rem;
}
.pp-photo img{
  display:block;
  width:100%;
  height:auto;
  object-fit:contain;
}

.outcome-bg{
  background:var(--ink);
  color:var(--sheet);
  overflow:hidden;
}
.outcome-bg::before{
  background:var(--outcome-bg-image) center/cover no-repeat;
  opacity:.13;
  filter:grayscale(1) contrast(.9);
}
.outcome-bg .s-title{color:var(--sheet)}
.outcome-bg .s-tag{background:rgba(232,102,47,.14);border-color:rgba(255,216,189,.45);color:var(--brand-pale)}
.outcome-bg .divider{background:var(--brand-pale)}
.oc-grid,.ov-grid{
  display:grid;
  gap:1px;
  background:rgba(255,250,243,.18);
}
.oc-grid{grid-template-columns:1fr 1fr;margin-bottom:2rem}
.ov-grid{grid-template-columns:repeat(3,1fr)}
.oc,.ov-item{
  background:rgba(23,21,18,.9);
  padding:1.2rem;
}
.oc-type,.ov-title{color:var(--brand-pale)}
.oc-text{
  color:var(--sheet);
  font-size:clamp(22px,2.8vw,34px);
  font-weight:500;
  line-height:1.28;
}
.ov-title{margin-bottom:.8rem}
.foundation-card{
  background:rgba(232,102,47,.16);
  border:1px solid rgba(255,216,189,.42);
  padding:1.2rem;
  margin-bottom:1.6rem;
}
.ov-item{text-align:center}
.ov-name{color:var(--sheet);font-size:1.32rem;font-weight:500;margin-bottom:.35rem}
.ov-def{color:rgba(255,250,243,.7);font-size:.82rem;line-height:1.45}
.oc-photo{
  margin-top:2.4rem;
  border-color:rgba(255,250,243,.2);
}
.oc-overlay{
  padding:1rem 0 0;
  color:var(--sheet);
}
.oc-overlay h3{font-size:1.22rem;font-weight:500;margin-bottom:.25rem}
.oc-overlay p{color:rgba(255,250,243,.7);font-size:.88rem}

.album-link-wrap{display:flex;justify-content:center;margin-top:2rem}
.album-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:44px;
  padding:.65rem 1.05rem;
  border:1px solid var(--brand-pale);
  border-radius:999px;
  background:var(--brand);
  color:var(--sheet);
  text-decoration:none;
  font-size:.94rem;
  line-height:1.35;
  transition:transform .2s ease,background .2s ease;
}
.album-link:hover{transform:translateY(-1px);background:#cf5520}

footer{
  background:var(--ink);
  border-top:1px solid rgba(255,250,243,.16);
  color:rgba(255,250,243,.62);
  text-align:center;
  padding:1.8rem 1rem;
  font-size:.82rem;
  line-height:1.8;
}

@media(max-width:980px){
  .hero{grid-template-columns:1fr;min-height:auto}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .stat-card:nth-child(2){border-right:0}
  .stat-card:nth-child(-n+2){border-bottom:1px solid var(--line)}
  .nanhu-feature{grid-template-columns:1fr}
  .data-panels,.role-grid,.v-persp,.v-interp,.pp-wrap{grid-template-columns:1fr}
  .vi-list{gap:.8rem}
  .m-grid{grid-template-columns:repeat(2,1fr)}
  .values-grid{grid-template-columns:1fr}
  .sc-grid{grid-template-columns:1fr 1fr}
  .ov-grid{grid-template-columns:repeat(2,1fr)}
}

@media(max-width:640px){
  section{padding:4.5rem 1.15rem}
  .site-logo{padding:.65rem 1rem}
  .brand-logo{width:min(220px,62vw)}
  .hero{padding:6.2rem 1.15rem 3.4rem;gap:2rem}
  .hero-title{font-size:clamp(42px,13vw,58px)}
  .hero-en{letter-spacing:.14em}
  .hero-meta{font-size:.88rem}
  .j-node{white-space:normal}
  .nanhu-feature{margin:2rem 0 1.5rem}
  .nanhu-copy{padding:1.45rem 0}
  .nanhu-copy p{font-size:.94rem}
  .spirit-lines p{grid-template-columns:auto auto 1fr;gap:.38rem}
  .spirit-lines span{font-size:1.28rem}
  .spirit-lines em{font-size:1rem}
  .spirit-lines i{font-size:1rem}
  .spirit-meaning{padding-left:.85rem}
  .vi-item{grid-template-columns:1fr;gap:.12rem}
  .mosaic{grid-template-columns:1fr}
  .mosaic .pi:first-child{grid-column:auto}
  .mosaic .pi:not(:first-child) img{height:auto;object-fit:contain}
  .day-hdr{align-items:flex-start;flex-direction:column;gap:.55rem}
  .timeline-item{grid-template-columns:1fr;gap:1rem}
  .t-marker{display:none}
  .stats-grid,.oc-grid,.ov-grid,.m-grid,.sc-grid{grid-template-columns:1fr}
  .stat-card{border-right:0;border-bottom:1px solid var(--line)}
  .stat-card:last-child{border-bottom:0}
}
