/* ============================================================
   anam · 设计令牌(紫罗兰系) — 派生自 docs/design/anam-ds/tokens
   品牌名 anam(永远小写)。渐变只给主操作,禁大面积铺。
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600&family=Noto+Sans+SC:wght@400;500;700;900&display=swap');

:root {
  /* ---- 品牌紫梯 ---- */
  --violet-50:  #F3EFFF;
  --violet-100: #E8DEFF;
  --violet-200: #D4C2FF;
  --violet-300: #B89BFF;
  --violet-400: #9B6BFF;
  --violet-500: #7C5CFC;
  --violet-600: #6D4AFF;  /* 核心品牌色 */
  --violet-700: #5733E6;
  --violet-800: #4426B4;
  --violet-900: #2F1A7A;

  /* ---- 中性色(带紫调,不用纯黑纯灰) ---- */
  --ink-900: #1A1726;
  --ink-800: #2A2640;
  --ink-700: #423D5C;
  --ink-600: #5C5675;
  --ink-500: #7B7593;
  --ink-400: #9C97B0;
  --ink-300: #C3BFD2;
  --ink-200: #E2DEEE;
  --ink-100: #EFECF7;
  --ink-50:  #F7F5FC;
  --white:   #FFFFFF;

  /* ---- 面 ---- */
  --lavender:   #F4F3FA;
  --lavender-2: #ECEAF6;
  --cream:      #F8F6F1;
  --cream-2:    #F2EFE6;

  /* ---- 粉彩 blob(仅 hero 装饰) ---- */
  --blob-pink:   #F8C4DD;
  --blob-mint:   #B8E8CD;
  --blob-peach:  #FCE0AE;
  --blob-blue:   #BFD6FF;
  --blob-violet: #D4C2FF;

  /* ---- 状态 ---- */
  --success: #2FB67A;
  --warning: #F2A33C;
  --danger:  #F0544F;

  /* ---- 渐变(只给主操作/品牌卡/用户气泡) ---- */
  --grad-violet: linear-gradient(135deg, #7C5CFC 0%, #6D4AFF 50%, #5733E6 100%);
  --grad-wonder: linear-gradient(135deg, #9B6BFF 0%, #6D4AFF 45%, #F8C4DD 130%);

  /* ---- 阴影(紫调) ---- */
  --shadow-sm: 0 4px 14px rgba(76, 54, 160, 0.08);
  --shadow-md: 0 10px 30px rgba(76, 54, 160, 0.09);
  --shadow-lg: 0 18px 44px rgba(76, 54, 160, 0.16);
  --shadow-brand: 0 8px 20px rgba(109, 74, 255, 0.35);

  /* ---- 字体 ---- */
  --font-sans: "Plus Jakarta Sans", "Noto Sans SC", -apple-system, "PingFang SC", sans-serif;
  --font-mono: "JetBrains Mono", ui-monospace, monospace;

  /* ---- 动效 ---- */
  --ease-out: cubic-bezier(0.22, 1, 0.36, 1);
}

/* ---- 基础 ---- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background: var(--lavender);
  color: var(--ink-900);
  font-family: var(--font-sans);
  font-size: 16px; line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}
::selection { background: var(--violet-100); }
button { font-family: inherit; cursor: pointer; }
a { color: inherit; text-decoration: none; }
img { display: block; }

/* ---- 通用组件 ---- */
.btn-primary {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--grad-violet);
  color: #fff; font-size: 15px; font-weight: 700;
  border: 0; border-radius: 999px;
  padding: 12px 24px;
  box-shadow: var(--shadow-brand);
  transition: transform 0.2s var(--ease-out), box-shadow 0.2s var(--ease-out);
}
.btn-primary:hover { transform: translateY(-1px); box-shadow: 0 12px 26px rgba(109, 74, 255, 0.42); }
.btn-ghost {
  display: inline-flex; align-items: center; gap: 6px;
  background: #fff; color: var(--ink-800);
  font-size: 15px; font-weight: 700;
  border: 1.5px solid var(--ink-200); border-radius: 999px;
  padding: 11px 22px;
  transition: all 0.2s var(--ease-out);
}
.btn-ghost:hover { border-color: var(--violet-300); color: var(--violet-700); }

/* 浮动药丸导航 */
.nav {
  position: fixed; top: 18px; left: 50%; transform: translateX(-50%);
  z-index: 50;
  width: min(1160px, calc(100% - 32px));
  display: flex; align-items: center; justify-content: space-between;
  background: rgba(255, 255, 255, 0.88);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  border-radius: 999px;
  padding: 12px 14px 12px 26px;
  box-shadow: 0 10px 32px rgba(76, 54, 160, 0.13);
  transition: box-shadow 0.25s var(--ease-out);
}
.nav.scrolled { box-shadow: 0 14px 38px rgba(76, 54, 160, 0.18); }
.nav .logo img { height: 30px; }
.nav-links { display: flex; gap: 30px; font-size: 15px; font-weight: 700; color: var(--ink-600); }
.nav-links a { transition: color 0.2s var(--ease-out); }
.nav-links a:hover, .nav-links a.active { color: var(--violet-700); }
.nav-right { display: flex; align-items: center; gap: 10px; }
.btn-login { background: transparent; border: 0; font-size: 15px; font-weight: 700; color: var(--ink-600); padding: 12px 14px; }
.btn-login:hover { color: var(--ink-900); }

/* 滚动渐显 */
.reveal { opacity: 0; transform: translateY(26px); transition: opacity 0.7s var(--ease-out), transform 0.7s var(--ease-out); }
.reveal.in { opacity: 1; transform: translateY(0); }
@media (prefers-reduced-motion: reduce) { .reveal { opacity: 1; transform: none; transition: none; } }

/* 入场 */
@keyframes rise { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
.rise { opacity: 0; animation: rise 0.8s var(--ease-out) forwards; }
.d1 { animation-delay: 0.05s; } .d2 { animation-delay: 0.15s; }
.d3 { animation-delay: 0.25s; } .d4 { animation-delay: 0.35s; } .d5 { animation-delay: 0.45s; }
