/* ════════════════════════════════════════════════════════════════
   xxyang · 统一设计系统 v3「深色未来感 · 毛玻璃」(D044 · 2026-06-03)
   ──────────────────────────────────────────────────────────────
   · 神似 Perplexity personal-computer 的「风格 / 手法」· 自己手写 · 不抄码
   · 全 9 面同 1 套 token(本文件为唯一真理源)
   · 深色 near-black 底 + 半透明毛玻璃表面 + 青色电压 accent
   · 字体:Space Grotesk 自托管(pplxSans 开源平替 · D048)→ Latin/数字 · 中文回落 CJK 栈(禁 pplxSans 本体 / 禁外链字体)· 大号 display 标题
   · 圆角 pill + 16/12/8/6/4 · 间距 4px 基数
   · 动效统一 GSAP(本地自托管 frontend/vendor/gsap/)· 守 prefers-reduced-motion
   · chat.html 因后端以单文件 HTMLResponse 服务 → 内联本套 token(不 link 本文件)
   ════════════════════════════════════════════════════════════════ */

/* ════════════════════════════════════════════════════════════════
   字体自托管 · Space Grotesk(D048 · 2026-06-05)
   ──────────────────────────────────────────────────────────────
   · pplxSans 的【开源平替】(几何 grotesque · 气质最近 FK Grotesk Neue)
   · 仅本地自托管 frontend/vendor/fonts/(禁 CDN / 禁外链字体 · 同 GSAP 模式)
   · 可变字重轴 wght 300–700(单 woff2 · latin 子集)· license 见同目录 OFL.txt
   · 只作 Latin / 数字字形;中文回落系统 CJK 栈(PingFang / 鸿蒙 / 雅黑)
   · pplxSans 本体全程不引入(守 D044 法律边界第 3 条)
   ════════════════════════════════════════════════════════════════ */
@font-face{
  font-family:"Space Grotesk";
  font-style:normal;
  font-weight:300 700;                 /* 可变字重 · ≥700 自动夹到 700(无伪粗体) */
  font-display:swap;                    /* 字体未到先用回落栈 · 0 阻塞首屏(守铁律 1 秒开) */
  src:url("../vendor/fonts/space-grotesk/space-grotesk-latin-variable-wght-normal.woff2") format("woff2");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,
    U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}

:root{
  /* —— 底色 · near-black —— */
  --bg:#06070B;            /* 主底:近黑、极微偏蓝 */
  --bg-1:#090B11;          /* 次底 */
  --bg-2:#0E1119;          /* 抬升底 */
  --bg-3:#141826;          /* 实心卡片底(非透明场景) */

  /* —— 毛玻璃表面(半透明 + backdrop-blur)—— */
  --glass:rgba(19,23,33,.55);
  --glass-2:rgba(26,31,44,.62);
  --glass-3:rgba(34,40,56,.70);
  --glass-hi:rgba(255,255,255,.04);   /* 表面顶部内高光 */

  /* —— 描边 —— */
  --line:rgba(255,255,255,.09);
  --line-2:rgba(255,255,255,.14);
  --line-3:rgba(255,255,255,.22);

  /* —— 文字 —— */
  --text-1:#ECF1FA;        /* 主文 */
  --text-2:#99A3B8;        /* 次文 */
  --text-3:#5B6478;        /* 弱文 / 占位 */
  --text-inv:#05070A;      /* 反色(铺在 accent 上)*/

  /* —— 青色电压 accent(定调 · 不混金 / 紫)—— */
  --accent:#22D3EE;        /* 主 accent · 电压青 */
  --accent-2:#3B82F6;      /* 配:电压蓝(渐变用)*/
  --accent-3:#67E8F9;      /* 亮:高光青 */
  --accent-deep:#0E7490;   /* 深:压暗青 */
  --accent-soft:rgba(34,211,238,.12);
  --accent-line:rgba(34,211,238,.34);
  --accent-glow:rgba(34,211,238,.40);
  --grad-accent:linear-gradient(135deg,#22D3EE 0%,#3B82F6 100%);
  --grad-accent-soft:linear-gradient(135deg,rgba(34,211,238,.18),rgba(59,130,246,.10));

  /* —— 语义色 —— */
  --ok:#34D399;     --ok-soft:rgba(52,211,153,.12);
  --warn:#FBBF24;   --warn-soft:rgba(251,191,36,.12);
  --danger:#FB7185; --danger-soft:rgba(251,113,133,.12);

  /* —— 背景辉光(铺在 body 最底层)—— */
  --bg-glow:
    radial-gradient(1100px circle at 16% -4%,rgba(34,211,238,.10),transparent 46%),
    radial-gradient(900px circle at 88% 6%,rgba(59,130,246,.08),transparent 44%),
    radial-gradient(700px circle at 50% 116%,rgba(34,211,238,.06),transparent 50%);

  /* —— 圆角 pill + 16/12/8/6/4 —— */
  --r-pill:999px;
  --r-1:16px; --r-2:12px; --r-3:8px; --r-4:6px; --r-5:4px;

  /* —— 间距 · 4px 基数 —— */
  --s1:4px; --s2:8px; --s3:12px; --s4:16px; --s5:20px; --s6:24px;
  --s7:32px; --s8:40px; --s9:48px; --s10:64px; --s11:80px; --s12:96px; --s13:128px;

  /* —— 阴影 / 辉光 —— */
  --shadow-1:0 1px 0 var(--glass-hi) inset,0 10px 30px rgba(0,0,0,.45);
  --shadow-2:0 1px 0 var(--glass-hi) inset,0 24px 70px rgba(0,0,0,.60);
  --glow-accent:0 0 0 1px var(--accent-line),0 10px 44px var(--accent-glow);
  --glow-soft:0 8px 40px rgba(34,211,238,.18);

  /* —— 毛玻璃模糊量 —— */
  --blur:18px; --blur-strong:28px;

  /* —— 缓动 —— */
  --ease:cubic-bezier(.22,1,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --ease-inout:cubic-bezier(.65,0,.35,1);

  /* —— 字体:Space Grotesk 自托管(pplxSans 开源平替)→ Latin/数字;中文回落 CJK 栈(0 外链字体)—— */
  --font-sans:"Space Grotesk",ui-sans-serif,system-ui,-apple-system,"Segoe UI Variable","Segoe UI",
    "PingFang SC","HarmonyOS Sans SC","Microsoft YaHei","Hiragino Sans GB",Roboto,sans-serif;
  --font-display:var(--font-sans);   /* display 同栈 · 超大字号 + 紧字距 + 重字重(Space Grotesk 上限 700) */
  --font-mono:ui-monospace,"SF Mono","Cascadia Code","JetBrains Mono",Consolas,"Liberation Mono",monospace;

  /* —— 排版尺度 —— */
  --fs-display:clamp(2.6rem,7vw,5.2rem);
  --fs-h1:clamp(2rem,4.6vw,3.4rem);
  --fs-h2:clamp(1.5rem,3.4vw,2.4rem);
  --fs-h3:clamp(1.15rem,2vw,1.45rem);
  --fs-body:1rem;
  --fs-sm:.875rem;
  --fs-xs:.75rem;

  --maxw:1180px;
  --topbar-h:64px;
}

/* ===== 浅色(默认基调 · 白)· 切深色时此块不生效,回落 :root 深色 =====
   包1 #1 主题统一:全站默认浅色,统一键 _theme_v010,跨页同步。*/
html[data-theme="day"]{
  --bg:#F5F8FC; --bg-1:#FFFFFF; --bg-2:#EEF3F9; --bg-3:#FFFFFF;
  --glass:rgba(255,255,255,.72); --glass-2:rgba(255,255,255,.66); --glass-3:rgba(255,255,255,.84);
  --glass-hi:rgba(255,255,255,.9);
  --line:rgba(13,22,44,.10); --line-2:rgba(13,22,44,.15); --line-3:rgba(13,22,44,.22);
  --text-1:#0D1424; --text-2:#46506A; --text-3:#7B8499; --text-inv:#FFFFFF;
  --accent:#0891B2; --accent-2:#2563EB; --accent-3:#06B6D4; --accent-deep:#0E7490;
  --accent-soft:rgba(8,145,178,.10); --accent-line:rgba(8,145,178,.30); --accent-glow:rgba(8,145,178,.22);
  --grad-accent:linear-gradient(135deg,#06B6D4 0%,#2563EB 100%);
  --grad-accent-soft:linear-gradient(135deg,rgba(6,182,212,.16),rgba(37,99,235,.08));
  --ok:#0EA371; --ok-soft:rgba(14,163,113,.12);
  --warn:#D97706; --warn-soft:rgba(217,119,6,.12);
  --danger:#E11D48; --danger-soft:rgba(225,29,72,.10);
  --bg-glow:
    radial-gradient(1000px circle at 16% -4%,rgba(8,145,178,.10),transparent 46%),
    radial-gradient(820px circle at 88% 6%,rgba(37,99,235,.07),transparent 44%),
    radial-gradient(680px circle at 50% 116%,rgba(8,145,178,.05),transparent 50%);
  --shadow-1:0 1px 0 var(--glass-hi) inset,0 10px 30px rgba(15,30,60,.10);
  --shadow-2:0 1px 0 var(--glass-hi) inset,0 24px 60px rgba(15,30,60,.16);
  --glow-accent:0 0 0 1px var(--accent-line),0 12px 40px var(--accent-glow);
  --glow-soft:0 8px 36px rgba(8,145,178,.16);
}

/* ===== 基础 reset ===== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-sans);
  background:var(--bg);
  color:var(--text-1);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  font-feature-settings:"cv11","ss01";
}
a{color:inherit;text-decoration:none}
ul{list-style:none}
img,svg{display:block;max-width:100%}
button{font:inherit;color:inherit;cursor:pointer;background:none;border:0}
::selection{background:var(--accent-soft);color:var(--accent-3)}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:var(--r-4)}

/* ===== 背景辉光层(固定铺底)===== */
.bg-field{position:fixed;inset:0;z-index:0;pointer-events:none;background:var(--bg-glow)}
.bg-grid{position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.5;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(120% 80% at 50% 0%,#000 0%,transparent 70%);
  mask-image:radial-gradient(120% 80% at 50% 0%,#000 0%,transparent 70%)}

/* ===== 滚动条 ===== */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:999px;border:2px solid transparent;background-clip:content-box}
::-webkit-scrollbar-thumb:hover{background:var(--line-3)}

/* ===== 毛玻璃工具类 ===== */
.glass{background:var(--glass);backdrop-filter:blur(var(--blur)) saturate(150%);
  -webkit-backdrop-filter:blur(var(--blur)) saturate(150%);border:1px solid var(--line)}
.glass-2{background:var(--glass-2);backdrop-filter:blur(var(--blur)) saturate(150%);
  -webkit-backdrop-filter:blur(var(--blur)) saturate(150%);border:1px solid var(--line)}
.glass-strong{background:var(--glass-3);backdrop-filter:blur(var(--blur-strong)) saturate(160%);
  -webkit-backdrop-filter:blur(var(--blur-strong)) saturate(160%);border:1px solid var(--line-2)}

/* ===== 通用容器 ===== */
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* ===== 徽标 / pill ===== */
.eyebrow{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border-radius:var(--r-pill);
  font-size:var(--fs-xs);font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--accent-3);background:var(--accent-soft);border:1px solid var(--accent-line)}
.eyebrow .spark{width:6px;height:6px;border-radius:999px;background:var(--accent);
  box-shadow:0 0 10px 2px var(--accent-glow)}
.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 11px;border-radius:var(--r-pill);
  font-size:var(--fs-xs);font-weight:600;color:var(--text-2);background:var(--glass-2);border:1px solid var(--line)}

/* ===== 按钮 ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;
  min-height:44px;padding:0 22px;border-radius:var(--r-pill);font-weight:600;font-size:var(--fs-sm);
  border:1px solid var(--line-2);color:var(--text-1);background:var(--glass-2);
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),border-color .25s,background .25s;
  will-change:transform}
.btn:hover{transform:translateY(-2px);border-color:var(--line-3)}
.btn:active{transform:translateY(0) scale(.985)}
.btn svg{width:18px;height:18px}
.btn-primary{position:relative;color:var(--text-inv);background:var(--grad-accent);border:0;
  box-shadow:0 8px 30px var(--accent-glow);overflow:hidden;font-weight:700}
.btn-primary::after{content:"";position:absolute;inset:0;
  background:linear-gradient(120deg,transparent 38%,rgba(255,255,255,.45) 50%,transparent 62%);
  transform:translateX(-130%);transition:transform .7s var(--ease)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 14px 46px var(--accent-glow)}
.btn-primary:hover::after{transform:translateX(130%)}
.btn-ghost{background:transparent;border:1px solid var(--line)}
.btn-ghost:hover{background:var(--glass);border-color:var(--accent-line);color:var(--accent-3)}
.btn-lg{min-height:54px;padding:0 32px;font-size:1.05rem}

/* ===== 卡片 ===== */
.card{position:relative;background:var(--glass);backdrop-filter:blur(var(--blur)) saturate(150%);
  -webkit-backdrop-filter:blur(var(--blur)) saturate(150%);border:1px solid var(--line);
  border-radius:var(--r-1);box-shadow:var(--shadow-1);transition:transform .35s var(--ease),border-color .35s,box-shadow .35s}
.card:hover{transform:translateY(-4px);border-color:var(--accent-line);box-shadow:var(--glow-accent)}

/* ===== 区块标题 ===== */
.section-eyebrow{display:block;text-align:center;font-size:var(--fs-xs);font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;color:var(--accent-3);margin-bottom:14px}
.section-title{font-size:var(--fs-h2);font-weight:800;letter-spacing:-.025em;text-align:center;line-height:1.12}
.section-sub{text-align:center;color:var(--text-2);max-width:54ch;margin:14px auto 0;font-size:1.05rem;line-height:1.7;text-wrap:balance}
.accent-text{background:var(--grad-accent);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ===== 滚动入场(GSAP 驱动;无 JS / reduced-motion 时直接可见)===== */
[data-reveal]{opacity:0;transform:translateY(34px)}
.no-gsap [data-reveal],.is-revealed [data-reveal]{opacity:1;transform:none}

/* ===== reduced-motion 全静默 ===== */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important}
  [data-reveal]{opacity:1!important;transform:none!important}
}
