/* ============================================================
   心之地形 · Animus Loci —— 功能宣传页共用样式
   设计系统见 DESIGN.md（鼠尾草绿 + 奶油纸 + 近黑 + 玫粉点缀）
   三页 talk/map/me 共用本文件，零硬编码颜色。
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+SC:wght@400;500;600&family=Noto+Sans+SC:wght@300;400;500&display=swap');

:root{
  --sage-600:#515B41; --sage-500:#6B7558; --sage-400:#889177;
  --sage-300:#AAB39E; --sage-200:#C7CEBE; --sage-100:#DFE3D9;
  --paper:#EDEFE8; --canvas:#F6F7F1; --white:#FFFFFF;
  --ink:#2A2D26; --ink-soft:#4A4E44; --muted:#6E7268;
  --rose:#B5707A; --rose-deep:#8E4F5A; --rose-soft:#EADADC;

  --font-serif:'Signifier','Noto Serif SC','Songti SC','STSong',serif;
  --font-sans:'Sohne','Noto Sans SC','PingFang SC','Hiragino Sans GB','Microsoft YaHei',ui-sans-serif,system-ui,sans-serif;

  --radius-card:22px; --radius-pill:999px;
  --page-max:1180px;
  --shadow-subtle:0 0 0 1px rgba(42,45,38,.05), 0 14px 22px -8px rgba(0,0,0,.06);
  --shadow-soft:0 24px 60px -24px rgba(42,45,38,.20);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-sans);
  color:var(--ink);
  background:var(--canvas);
  line-height:1.78;
  letter-spacing:.02em;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
::selection{background:var(--rose-soft);color:var(--rose-deep)}
.serif{font-family:var(--font-serif)}
.wrap{max-width:var(--page-max);margin:0 auto;padding:0 24px}
img{max-width:100%;display:block}

/* 柔和氛围背景 */
.ambient{position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(680px 520px at 84% -6%, rgba(199,206,190,.5), transparent 60%),
    radial-gradient(620px 600px at 4% 98%, rgba(223,227,217,.55), transparent 60%),
    var(--canvas);
}

/* 滚动渐入 */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s ease, transform .9s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}

/* ---------------- 导航 ---------------- */
.nav{position:sticky;top:0;z-index:50;backdrop-filter:saturate(180%) blur(14px);
  background:rgba(246,247,241,.78);border-bottom:1px solid rgba(42,45,38,0);transition:border-color .3s,padding .3s}
.nav.scrolled{border-bottom-color:rgba(42,45,38,.08)}
.nav-inner{max-width:var(--page-max);margin:0 auto;padding:16px 24px;display:flex;align-items:center;justify-content:space-between}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--ink)}
.logo .mark{width:26px;height:26px;flex-shrink:0;
  background:url(nav-logo.png) center/contain no-repeat}
.logo .zh{font-size:17px;font-weight:500;letter-spacing:.04em}
.logo .en{font-size:11px;color:var(--sage-500);letter-spacing:.16em;text-transform:uppercase}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{color:var(--muted);text-decoration:none;font-size:15px;transition:color .2s}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-links a.active{font-weight:500}
/* 导航里的实心/玫粉按钮文字必须为白（覆盖 .nav-links a 的灰色） */
.nav-links a.btn-rose,.nav-links a.btn-rose:hover,
.nav-links a.btn-fill,.nav-links a.btn-fill:hover{color:#fff}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:6px}
.nav-toggle span{width:22px;height:1.5px;background:var(--ink);display:block;transition:.3s}

/* ---------------- 按钮 ---------------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:var(--radius-pill);
  font-size:15px;font-weight:450;text-decoration:none;cursor:pointer;border:none;font-family:inherit;
  transition:transform .18s ease,background .2s,box-shadow .2s,color .2s;white-space:nowrap}
.btn:focus-visible{outline:2px solid var(--sage-600);outline-offset:3px}
.btn-fill{background:var(--ink);color:#fff;padding:13px 28px}
.btn-fill:hover{transform:translateY(-2px);box-shadow:0 12px 24px -10px rgba(42,45,38,.5)}
.btn-fill:active{transform:translateY(0)}
.btn-rose{background:var(--rose);color:#fff;padding:13px 28px}
.btn-rose:hover{background:var(--rose-deep);transform:translateY(-2px);box-shadow:0 12px 26px -10px rgba(142,79,90,.5)}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--ink);padding:12px 27px}
.btn-ghost:hover{background:var(--ink);color:#fff}

/* ---------------- Hero ---------------- */
.fhero{position:relative;overflow:hidden;padding:96px 0 88px}
.fhero::before{content:"";position:absolute;inset:0;z-index:-1;background:
  radial-gradient(820px 520px at 60% 30%, rgba(223,227,217,.6), transparent 70%),
  radial-gradient(720px 560px at 12% 80%, rgba(199,206,190,.45), transparent 72%)}
.fhero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-serif);font-style:italic;
  font-size:12px;letter-spacing:.42em;text-transform:uppercase;color:var(--rose-deep);
  background:var(--rose-soft);padding:7px 16px;border-radius:var(--radius-pill);margin-bottom:26px}
.eyebrow.sage{color:var(--sage-600);background:var(--sage-100)}
.fhero h1{font-family:var(--font-serif);font-weight:400;font-size:clamp(34px,5vw,58px);line-height:1.2;letter-spacing:-.01em;color:var(--ink)}
.fhero h1 em{font-style:normal;color:var(--sage-600)}
.fhero h1 .rose{color:var(--rose-deep);font-style:normal}
.fhero-sub{margin-top:24px;font-size:17px;line-height:1.85;color:var(--ink-soft);max-width:30em}
.fhero-cta{margin-top:34px;display:flex;gap:14px;flex-wrap:wrap}

/* ---------------- 区块标题 ---------------- */
section{position:relative}
.band{padding:104px 0}
.band.paper{background:linear-gradient(180deg,transparent,rgba(237,239,232,.7)18%,rgba(237,239,232,.7) 82%,transparent)}
.sec-head{max-width:640px}
.sec-head.center{margin:0 auto;text-align:center}
.sec-eyebrow{font-family:var(--font-serif);font-style:italic;font-size:11px;letter-spacing:.5em;text-transform:uppercase;color:var(--sage-500)}
.sec-head h2{font-family:var(--font-serif);font-weight:400;font-size:clamp(27px,3.6vw,40px);line-height:1.3;margin-top:14px;color:var(--ink)}
.sec-head p{margin-top:16px;font-size:16px;line-height:1.85;color:var(--ink-soft)}

/* ---------------- 三步 ---------------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:56px}
.step{background:var(--white);border:1px solid var(--sage-200);border-radius:var(--radius-card);padding:30px 26px;box-shadow:var(--shadow-subtle);transition:transform .25s,box-shadow .25s}
.step:hover{transform:translateY(-3px);box-shadow:var(--shadow-soft)}
.step .num{font-family:var(--font-serif);font-size:13px;letter-spacing:.3em;color:var(--rose-deep)}
.step h3{font-size:18px;font-weight:500;margin:14px 0 10px;color:var(--ink)}
.step p{font-size:14.5px;line-height:1.8;color:var(--muted)}

/* ---------------- 特性交替图文 ---------------- */
.feature-row{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;padding:56px 0;border-top:1px solid rgba(42,45,38,.08)}
.feature-row:first-of-type{border-top:none}
.feature-row.flip .f-text{order:2}
.f-text h3{font-family:var(--font-serif);font-size:25px;font-weight:400;line-height:1.4;color:var(--ink)}
.f-text p{margin-top:14px;font-size:15.5px;line-height:1.85;color:var(--ink-soft)}
.f-text .tag{display:inline-block;margin-top:18px;font-family:var(--font-serif);font-style:italic;font-size:13px;color:var(--sage-600);border-bottom:1px solid var(--sage-300);padding-bottom:2px}
.f-visual{display:flex;justify-content:center}

/* ---------------- 手机设备框 ---------------- */
.phone{width:280px;border:9px solid var(--ink);border-radius:42px;background:var(--white);
  box-shadow:var(--shadow-soft);overflow:hidden;position:relative}
.phone::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:96px;height:20px;background:var(--ink);border-radius:0 0 14px 14px;z-index:3}
.screen{height:560px;overflow:hidden;display:flex;flex-direction:column;background:var(--canvas)}
.screen-top{padding:26px 18px 10px;text-align:center;flex-shrink:0}
.screen-top .t{font-family:var(--font-serif);font-size:15px;color:var(--ink)}
.screen-top .s{font-size:10px;color:var(--muted);letter-spacing:.2em;margin-top:3px}

/* 聊天气泡 */
.chat{flex:1;overflow:hidden;padding:8px 14px;display:flex;flex-direction:column;gap:9px}
.day{align-self:center;font-size:9.5px;color:var(--muted);letter-spacing:.18em;margin:4px 0}
.bub{max-width:80%;padding:10px 13px;font-size:12.5px;line-height:1.7;border-radius:15px}
.bub.loci{align-self:flex-start;background:var(--white);border:1px solid var(--sage-200);color:var(--ink);border-bottom-left-radius:5px}
.bub.me{align-self:flex-end;background:var(--rose-soft);color:var(--rose-deep);border-bottom-right-radius:5px}
.bub .quote-back{color:var(--sage-600);font-style:italic;font-family:var(--font-serif)}
.screen-input{flex-shrink:0;margin:8px 14px 16px;border:1px solid var(--sage-200);border-radius:var(--radius-pill);
  padding:9px 16px;font-size:11.5px;color:var(--muted);background:var(--white);display:flex;justify-content:space-between;align-items:center}
.screen-input .mic{width:14px;height:14px;border-radius:50%;background:var(--rose);flex-shrink:0}

/* ---------------- 真实 App 嵌入设备框 ---------------- */
/* iframe 以 392px 逻辑宽渲染真实移动端布局，再整体缩放到 280px 设备视口，
   既清晰又像真手机。viewport 与 iframe 尺寸严格按 0.7143 比例对应。 */
.device{width:300px;max-width:100%;margin:0 auto}
.device .glass{position:relative;border:10px solid var(--ink);border-radius:44px;background:#000;
  overflow:hidden}
/* 不做刘海：之前的刘海黑条会压住 App 顶部居中的标题（如「Loci」），故移除。 */
.device .vp{width:280px;height:572px;overflow:hidden;position:relative;background:var(--canvas)}
.device iframe{width:392px;height:801px;border:0;display:block;transform:scale(.7143);transform-origin:0 0}
.device .cap{text-align:center;margin-top:16px;font-size:12.5px;color:var(--muted);font-family:var(--font-serif);font-style:italic}
.device .cap b{color:var(--sage-600);font-weight:500;font-style:normal}

/* ---------------- 卡片 / chip ---------------- */
.card{background:var(--white);border:1px solid var(--sage-200);border-radius:var(--radius-card);padding:26px;box-shadow:var(--shadow-subtle)}
.chip{display:inline-flex;align-items:center;gap:6px;font-size:12px;padding:5px 12px;border-radius:var(--radius-pill);background:var(--sage-100);color:var(--sage-600)}
.chip.rose{background:var(--rose-soft);color:var(--rose-deep)}

/* ---------------- 金句 ---------------- */
.quote-band{padding:120px 0;text-align:center}
.quote-band blockquote{font-family:var(--font-serif);font-size:clamp(24px,3.4vw,36px);line-height:1.6;color:var(--ink);max-width:18em;margin:0 auto}
.quote-band cite{display:block;margin-top:26px;font-style:normal;font-size:13px;letter-spacing:.3em;color:var(--sage-500);text-transform:uppercase}

/* ---------------- 转化点 ---------------- */
.cta{padding:104px 0}
.cta-card{background:var(--ink);color:var(--paper);border-radius:32px;padding:64px 48px;text-align:center;position:relative;overflow:hidden}
.cta-card::after{content:"";position:absolute;inset:0;background:radial-gradient(520px 320px at 80% 10%, rgba(181,112,122,.22), transparent 60%);pointer-events:none}
.cta-card h2{font-family:var(--font-serif);font-weight:400;font-size:clamp(26px,3.4vw,38px);line-height:1.3;position:relative}
.cta-card p{margin-top:16px;color:rgba(237,239,232,.7);font-size:16px;position:relative}
.cta-form{margin-top:30px;display:flex;gap:10px;justify-content:center;flex-wrap:wrap;position:relative}
.cta-form input{background:rgba(255,255,255,.1);border:1px solid rgba(237,239,232,.25);border-radius:var(--radius-pill);
  padding:13px 22px;color:#fff;font-size:15px;font-family:inherit;min-width:240px}
.cta-form input::placeholder{color:rgba(237,239,232,.5)}
.cta-form input:focus{outline:none;border-color:var(--rose)}

/* ---------------- 页脚 ---------------- */
footer{padding:64px 0 48px;border-top:1px solid rgba(42,45,38,.08)}
.foot-grid{display:flex;justify-content:space-between;flex-wrap:wrap;gap:40px}
.foot-brand{max-width:320px}
.foot-brand p{margin-top:14px;font-size:14px;color:var(--muted);line-height:1.7}
.foot-cols{display:flex;gap:60px;flex-wrap:wrap}
.foot-col h5{font-size:12px;color:var(--sage-500);text-transform:uppercase;letter-spacing:.14em;margin-bottom:14px}
.foot-col a{display:block;color:var(--muted);text-decoration:none;font-size:14.5px;margin-bottom:11px;transition:color .2s}
.foot-col a:hover{color:var(--ink)}
.foot-bottom{margin-top:48px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  font-size:12px;color:var(--muted);border-top:1px solid rgba(42,45,38,.07);padding-top:24px}

/* ---------------- 响应式 ---------------- */
@media(max-width:920px){
  .fhero-grid{grid-template-columns:1fr;gap:44px}
  .steps{grid-template-columns:1fr;gap:18px}
  .feature-row,.feature-row.flip{grid-template-columns:1fr;gap:30px}
  .feature-row.flip .f-text{order:0}
}
@media(max-width:600px){
  .nav-links{position:fixed;inset:64px 0 auto;flex-direction:column;background:var(--canvas);
    padding:24px;gap:20px;border-bottom:1px solid rgba(42,45,38,.1);transform:translateY(-130%);transition:transform .35s;z-index:40}
  .nav-links.open{transform:translateY(0)}
  .nav-toggle{display:flex}
  .band,.cta{padding:72px 0}
  .quote-band{padding:84px 0}
  .cta-card{padding:48px 26px}
  .foot-grid{flex-direction:column}
  .foot-bottom{flex-direction:column}
}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  *{scroll-behavior:auto}
}
