/* 德庭花园 · 东方雅致风 · 设计系统 */

:root {
  /* 天青 / 霁蓝 —— 基础中性色（深青瓷蓝系） */
  --paper: #F0F6FA;              /* 主背景 · 极淡蓝白 */
  --paper-warm: #D8E8F0;         /* 次背景 · 微雾蓝 */
  --paper-soft: #F8FBFD;         /* 近白 */
  --ink: #0F2A3F;                /* 墨黑正文 · 深靛 */
  --ink-2: #1E3E56;              /* 次级正文 */
  --ink-3: #547991;              /* 辅助文字 */
  --ink-4: #8abcd1;              /* 占位 / 分隔 */
  --line: rgba(15,42,63,0.08);   /* 细线 */
  --line-2: rgba(15,42,63,0.14);

  /* 主色 —— 霁蓝(2026-04-28 加深以提升 jade-soft 上文字对比度) */
  --jade: #1b6f9f;               /* 霁蓝 · 主色 */
  --jade-deep: #114d72;          /* 靛蓝 · 主色加深(WCAG AA on jade-soft) */
  --jade-soft: #8abcd1;          /* 天青 · 主色淡化 */

  /* 碧蓝 —— 次要点缀 */
  --brass: #5698c3;              /* 碧蓝 · 次色 */
  --brass-soft: #8abcd1;         /* 天青 · 次色淡化 */
  --brass-deep: #2775b6;         /* 靛蓝 · 次色加深 */

  /* 朱砂 —— 警示/价格 */
  --cinnabar: #B23A29;

  /* 会员等级色 */
  --tier-zhi: #8abcd1;           /* 知庭 天青 */
  --tier-yun: #1b6f9f;           /* 云庭 霁蓝(同 --jade) */
  --tier-yu:  #0F2A3F;           /* 御德 靛黑 */

  /* 字体 */
  --serif: "Songti SC", "STSong", "Noto Serif SC", "Source Han Serif", serif;
  --sans: -apple-system, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", system-ui, sans-serif;
  --mono: "SF Mono", ui-monospace, Menlo, monospace;

  /* 尺度 */
  --radius-s: 6px;
  --radius-m: 10px;
  --radius-l: 16px;
}

* { box-sizing: border-box; }

.phone {
  width: 390px;
  height: 810px;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 14px;
  line-height: 1.5;
  position: relative;
  overflow: hidden;
  border-radius: 44px;
  box-shadow:
    inset 0 0 0 1px rgba(0,0,0,0.08),
    0 30px 60px -20px rgba(15,42,63,0.25),
    0 10px 20px -10px rgba(15,42,63,0.15);
  border: 10px solid #0F2A3F;
}

/* —— iOS 状态栏 —— */
.status-bar {
  position: absolute; top: 0; left: 0; right: 0;
  height: 44px;
  padding: 0 28px;
  display: flex; align-items: center; justify-content: space-between;
  font-family: -apple-system, sans-serif;
  font-weight: 600;
  font-size: 14px;
  color: var(--ink);
  z-index: 20;
  padding-top: 14px;
}
.status-bar.light { color: #fff; }
.status-bar .icons { display: flex; gap: 5px; align-items: center; }
.status-bar svg { display: block; }

/* —— 小程序胶囊按钮 —— */
.capsule {
  position: absolute;
  top: 14px; right: 14px;
  width: 87px; height: 32px;
  border-radius: 16px;
  background: rgba(255,255,255,0.65);
  backdrop-filter: blur(10px);
  border: 0.5px solid rgba(0,0,0,0.1);
  display: flex; align-items: center; justify-content: space-around;
  z-index: 21;
}
.capsule.dark {
  background: rgba(0,0,0,0.35);
  border-color: rgba(255,255,255,0.15);
  color: #fff;
}
.capsule .dot { width: 20px; height: 20px; display: grid; place-items: center; color: inherit; }
.capsule .div { width: 1px; height: 16px; background: currentColor; opacity: 0.2; }

/* —— 底部 tab —— */
.tabbar {
  position: absolute; left: 0; right: 0; bottom: 0;
  height: 78px;
  background: rgba(248,251,253,0.92);
  backdrop-filter: blur(20px);
  border-top: 1px solid var(--line);
  display: grid; grid-template-columns: repeat(4,1fr);
  padding-bottom: 20px;
  z-index: 10;
}
.tabbar .tab {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 2px;
  color: var(--ink-3);
  font-size: 10px;
}
.tabbar .tab.active { color: var(--jade); }
.tabbar .tab svg { width: 22px; height: 22px; }

.screen-body {
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  overflow: hidden;
}
.screen-body.with-tab { bottom: 78px; }

/* —— 通用字体 —— */
.serif { font-family: var(--serif); }
.mono  { font-family: var(--mono); }

/* —— 占位图 —— */
.ph {
  background:
    repeating-linear-gradient(135deg,
      rgba(27,111,159,0.08) 0 6px,
      rgba(27,111,159,0.03) 6px 12px),
    linear-gradient(160deg, #D8E8F0, #8abcd1);
  color: var(--ink-3);
  display: grid; place-items: center;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  user-select: none;
}
.ph.dark {
  background:
    repeating-linear-gradient(135deg,
      rgba(255,255,255,0.04) 0 6px,
      rgba(255,255,255,0) 6px 12px),
    linear-gradient(160deg, #1E3E56, #0F2A3F);
  color: rgba(255,255,255,0.4);
}
.ph.jade {
  background:
    repeating-linear-gradient(135deg,
      rgba(17,77,114,0.14) 0 6px,
      rgba(17,77,114,0.05) 6px 12px),
    linear-gradient(160deg, #8abcd1, #5698c3);
  color: #FFFFFF;
}

/* —— 通用小件 —— */
.chip {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 8px;
  border-radius: 999px;
  font-size: 11px;
  border: 1px solid var(--line-2);
  color: var(--ink-2);
  background: var(--paper-soft);
}
.chip.jade { background: var(--jade-soft); border-color: transparent; color: var(--jade-deep); }
.chip.brass { background: var(--brass-soft); border-color: transparent; color: var(--brass-deep); }
.chip.dark { background: var(--ink); color: var(--paper-soft); border-color: transparent; }

.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  padding: 10px 18px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 500;
  border: 1px solid var(--line-2);
  background: var(--paper-soft);
  color: var(--ink);
  cursor: pointer;
}
.btn.primary { background: var(--jade-deep); color: #fff; border-color: var(--jade-deep); }
.btn.ghost { background: transparent; }
.btn.brass { background: var(--brass-deep); color: #fff; border-color: var(--brass-deep); }

hr.rule {
  border: none; border-top: 1px solid var(--line); margin: 0;
}

.divider-ornament {
  display: flex; align-items: center; gap: 10px;
  color: var(--brass);
  font-size: 10px; letter-spacing: 0.4em;
  font-family: var(--serif);
}
.divider-ornament::before, .divider-ornament::after {
  content: ''; flex: 1; height: 1px;
  background: linear-gradient(90deg, transparent, var(--brass), transparent);
}

/* —— 小红点 / 徽标 —— */
.badge {
  display: inline-grid; place-items: center;
  min-width: 16px; height: 16px; padding: 0 4px;
  background: var(--cinnabar); color: #fff;
  border-radius: 999px;
  font-size: 10px; font-weight: 600;
}

/* —— 滚动条隐藏 —— */
.screen-body *::-webkit-scrollbar { display: none; }
