/* ============================================================
   Cryman 前台 · 组件库(web.css)
   所有公开页面(about / research / blog / gallery)共用
   依赖 tokens.css 的 CSS 变量
   ============================================================ */

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
::selection{background:rgba(31,78,95,.16)}

/* ---------- 顶部公开站导航(贯通各页) ---------- */
.topnav{
  display:flex;align-items:center;gap:26px;
  padding:0 60px;height:58px;
  border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:5;
  background:rgba(255,255,255,.85);backdrop-filter:blur(10px);
}
.topnav .brand{font-family:var(--title);font-weight:600;font-size:17px;color:var(--accent);margin-right:auto;letter-spacing:.02em;text-decoration:none}
.topnav a{color:var(--muted);text-decoration:none;font-size:14px;position:relative;padding:4px 0}
.topnav a.on{color:var(--accent);font-weight:500}
.topnav a:hover{color:var(--accent)}
.topnav .login{
  border:1px solid var(--line-strong);border-radius:7px;
  padding:5px 13px;font-size:13px;color:var(--accent);
}

/* ---------- 布局骨架:左固定身份栏 + 右分区(整页一起滚) ---------- */
.shell{
  display:grid;
  grid-template-columns:360px 1fr;
  min-height:100vh;
  width:100%;
  background:var(--card);
}
/* 单列布局(无左栏的页面,如 research/blog/gallery 可不用 .shell) */
.page{width:100%;background:var(--card);min-height:100vh}

/* ===================== 左 · 身份栏 ===================== */
.rail{
  background:linear-gradient(160deg,var(--rail),var(--rail-2));
  color:var(--cream);
  padding:38px 32px 48px;
}
.avatar{
  width:128px;height:128px;border-radius:50%;
  margin:0 auto 22px;
  border:3px solid rgba(238,241,240,.28);
  background:repeating-linear-gradient(45deg,rgba(255,255,255,.04) 0 10px,rgba(255,255,255,.07) 10px 20px);
  display:flex;align-items:center;justify-content:center;
  color:var(--cream-dim);font-size:12px;letter-spacing:.08em;text-align:center;
}
.name{font-family:var(--title);font-size:30px;font-weight:600;text-align:center;letter-spacing:.01em;margin-bottom:6px}
.role{text-align:center;font-size:13px;color:var(--cream-dim);letter-spacing:.04em;margin-bottom:26px}
.role b{color:var(--cream);font-weight:600}
.rail h3{
  font-family:var(--title);font-size:15px;font-weight:600;
  margin:26px 0 14px;padding-bottom:8px;
  border-bottom:1px solid rgba(238,241,240,.16);
  display:flex;align-items:center;gap:8px;
}
.rail h3 .dot{width:6px;height:6px;border-radius:50%;background:#6fb3c4}
.info-row{display:flex;gap:10px;font-size:13px;color:var(--cream-dim);margin-bottom:9px;line-height:1.5}
.info-row .k{color:var(--cream);min-width:52px;flex:none}
.skill{margin-bottom:13px}
.skill .lab{display:flex;justify-content:space-between;font-size:12.5px;color:var(--cream-dim);margin-bottom:5px}
.skill .lab b{color:var(--cream);font-weight:500}
.bar{height:4px;border-radius:3px;background:rgba(238,241,240,.14);overflow:hidden}
.bar i{display:block;height:100%;border-radius:3px;background:linear-gradient(90deg,#4f93a6,#6fb3c4)}
.tags{display:flex;flex-wrap:wrap;gap:7px}
.tag{font-size:12px;color:var(--cream-dim);border:1px solid rgba(238,241,240,.2);border-radius:20px;padding:3px 11px}

/* ===================== 右 · 内容区 ===================== */
.main{padding:0}
.hero{
  height:200px;
  background:linear-gradient(180deg,rgba(31,78,95,.03),rgba(31,78,95,.07)),
    repeating-linear-gradient(135deg,rgba(31,78,95,.025) 0 14px,transparent 14px 28px);
  border-bottom:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  color:var(--faint);font-size:13px;letter-spacing:.06em;position:relative;
}
.hero .badge{
  position:absolute;left:48px;bottom:-1px;
  background:var(--card);border:1px solid var(--line);border-bottom:none;
  border-radius:8px 8px 0 0;padding:8px 16px;font-size:12px;color:var(--muted);letter-spacing:.06em;
}
.body{padding:50px 60px 80px}

/* ---------- 区块标题 ---------- */
section{margin-bottom:46px}
.sec-head{display:flex;align-items:center;gap:11px;margin-bottom:22px}
.sec-head .ic{
  width:30px;height:30px;border-radius:8px;background:rgba(31,78,95,.09);
  display:flex;align-items:center;justify-content:center;color:var(--accent);font-size:15px;
}
.sec-head h2{font-family:var(--title);font-size:21px;font-weight:600;color:var(--accent)}
.sec-head .line{flex:1;height:1px;background:var(--line)}

/* ---------- 通用排版 ---------- */
.lead{font-size:16px;color:var(--ink);line-height:1.85;max-width:74ch}
.lead .hl{color:var(--accent);font-weight:500;border-bottom:1.5px solid rgba(31,78,95,.25)}

/* ---------- 经历条目 ---------- */
.item{margin-bottom:26px;padding-left:20px;border-left:2px solid var(--line-strong);position:relative}
.item::before{content:"";position:absolute;left:-6px;top:6px;width:10px;height:10px;border-radius:50%;background:var(--card);border:2px solid var(--accent)}
.item .top{display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:6px;margin-bottom:5px}
.item .ttl{font-size:16px;font-weight:600;font-family:var(--title)}
.item .place{font-size:13px;color:var(--accent-soft);font-weight:500}
.item .when{font-size:12.5px;color:var(--faint);font-family:var(--sans);letter-spacing:.02em}
.item ul{list-style:none;margin-top:8px}
.item li{font-size:14.5px;color:var(--muted);line-height:1.75;padding-left:16px;position:relative;margin-bottom:4px}
.item li::before{content:"";position:absolute;left:2px;top:11px;width:4px;height:4px;border-radius:50%;background:var(--accent-soft)}

/* ---------- 卡片网格 ---------- */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(min-width:1280px){.grid2{grid-template-columns:repeat(4,1fr)}}
.rcard{border:1px solid var(--line);border-radius:12px;padding:18px 20px;background:var(--paper)}
.rcard h4{font-family:var(--title);font-size:15.5px;font-weight:600;margin-bottom:7px;color:var(--ink)}
.rcard p{font-size:13.5px;color:var(--muted);line-height:1.7}
.rcard .pill{display:inline-block;margin-top:11px;font-size:11.5px;color:var(--accent);background:rgba(31,78,95,.08);border-radius:20px;padding:3px 10px}

/* ---------- 数字概览 ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:8px}
.stat{border:1px solid var(--line);border-radius:12px;padding:18px 20px;background:var(--paper)}
.stat .num{font-family:var(--title);font-size:28px;font-weight:600;color:var(--accent);line-height:1.1}
.stat .lab{font-size:12.5px;color:var(--muted);margin-top:5px}

/* ---------- 近期动态 / 列表行 ---------- */
.now-list{display:flex;flex-direction:column}
.now-row{display:grid;grid-template-columns:108px 1fr;gap:18px;padding:13px 0;border-bottom:1px solid var(--line);font-size:14.5px}
.now-row:last-child{border-bottom:none}
.now-row .date{color:var(--faint);font-size:12.5px;letter-spacing:.02em;padding-top:1px}
.now-row .what{color:var(--muted)}
.now-row .what b{color:var(--ink);font-weight:600}

/* ---------- 荣誉 ---------- */
.awards{display:grid;grid-template-columns:1fr 1fr;gap:10px 28px}
.award{display:flex;gap:10px;font-size:14px;color:var(--muted);padding:6px 0}
.award .yr{color:var(--accent-soft);font-weight:600;font-size:13px;flex:none;min-width:38px}

/* ---------- 读书片段 ---------- */
.reads{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.read{border:1px solid var(--line);border-radius:12px;padding:18px 20px;background:var(--card)}
.read .quote{font-family:var(--title);font-style:italic;font-size:15px;color:var(--ink);line-height:1.7;margin-bottom:10px}
.read .from{font-size:12.5px;color:var(--faint)}
.read .from b{color:var(--accent-soft);font-weight:600;font-style:normal}

/* ---------- 时间线 ---------- */
.timeline{position:relative;padding-left:24px}
.timeline::before{content:"";position:absolute;left:5px;top:4px;bottom:4px;width:2px;background:var(--line-strong)}
.tl-row{position:relative;padding:8px 0 16px}
.tl-row::before{content:"";position:absolute;left:-23px;top:13px;width:10px;height:10px;border-radius:50%;background:var(--card);border:2px solid var(--accent)}
.tl-row .yr{font-family:var(--title);font-weight:600;font-size:15px;color:var(--accent)}
.tl-row .txt{font-size:14px;color:var(--muted);margin-top:2px}

/* ---------- 工具卡 ---------- */
.tools{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:12px}
.tool{display:flex;align-items:center;gap:12px;border:1px solid var(--line);border-radius:11px;padding:13px 16px;background:var(--paper);text-decoration:none;color:var(--ink);transition:border-color .15s,background .15s}
.tool:hover{border-color:var(--accent-soft);background:rgba(31,78,95,.04)}
.tool .ti{width:34px;height:34px;border-radius:9px;flex:none;background:rgba(31,78,95,.1);display:flex;align-items:center;justify-content:center;font-size:16px}
.tool .tn{font-weight:600;font-size:14px}
.tool .td{font-size:11.5px;color:var(--faint);margin-top:1px}

/* ---------- 友链 ---------- */
.friends{display:flex;flex-wrap:wrap;gap:10px}
.friends a{text-decoration:none;font-size:13.5px;color:var(--accent);border:1px solid var(--line-strong);border-radius:8px;padding:7px 15px;transition:background .15s}
.friends a:hover{background:rgba(31,78,95,.07)}

/* ---------- 联系块 ---------- */
.contact{
  margin:0 60px 18px;
  border:1px solid var(--line);border-radius:14px;
  background:linear-gradient(135deg,rgba(31,78,95,.05),rgba(31,78,95,.02));
  padding:30px 34px;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;
}
.contact h3{font-family:var(--title);font-size:19px;color:var(--accent);margin-bottom:5px}
.contact p{font-size:13.5px;color:var(--muted)}
.contact .links{display:flex;gap:10px;flex-wrap:wrap}
.contact .links a{text-decoration:none;font-size:13.5px;color:var(--accent);border:1px solid var(--line-strong);border-radius:8px;padding:8px 16px;transition:background .15s}
.contact .links a:hover{background:rgba(31,78,95,.07)}

/* ---------- 占位提示(开发期可见,上线可删) ---------- */
.placeholder-note{margin:0 60px 36px;font-size:12px;color:var(--faint);border:1px dashed var(--line-strong);border-radius:8px;padding:10px 14px;background:rgba(31,78,95,.02)}
.placeholder-note b{color:var(--accent-soft)}

footer{text-align:center;padding:30px;font-family:var(--title);font-style:italic;font-size:14px;color:var(--faint);border-top:1px solid var(--line)}

/* ---------- 文章/列表通用(research / blog) ---------- */
.feed{display:flex;flex-direction:column;gap:0}
.post{padding:22px 0;border-bottom:1px solid var(--line);display:block;text-decoration:none;color:inherit;transition:padding-left .15s}
.post:hover{padding-left:8px}
.post .meta{display:flex;gap:12px;align-items:center;font-size:12.5px;color:var(--faint);margin-bottom:7px}
.post .meta .cat{color:var(--accent);font-weight:600}
.post h3{font-family:var(--title);font-size:19px;font-weight:600;color:var(--ink);margin-bottom:7px;line-height:1.4}
.post p{font-size:14.5px;color:var(--muted);line-height:1.7;max-width:80ch}
.post .ptags{margin-top:9px;display:flex;gap:7px;flex-wrap:wrap}
.post .ptags span{font-size:11.5px;color:var(--accent);background:rgba(31,78,95,.08);border-radius:20px;padding:2px 10px}

/* ---------- 画廊 ---------- */
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}
.gcard{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--paper)}
.gcard .ph{aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;color:var(--faint);font-size:12px;
  background:repeating-linear-gradient(135deg,rgba(31,78,95,.03) 0 12px,transparent 12px 24px)}
.gcard .cap{padding:11px 14px;font-size:13px;color:var(--muted);border-top:1px solid var(--line)}

/* ---------- 文章详情 ---------- */
.article{max-width:740px;margin:0 auto;padding:54px 32px 90px}
.article .back{display:inline-block;text-decoration:none;color:var(--accent);font-size:13.5px;margin-bottom:26px}
.article .back:hover{text-decoration:underline}
.article .art-meta{display:flex;gap:12px;align-items:center;font-size:12.5px;color:var(--faint);margin-bottom:12px}
.article .art-meta .cat{color:var(--accent);font-weight:600}
.article h1{font-family:var(--title);font-size:32px;font-weight:600;line-height:1.3;color:var(--ink);margin-bottom:14px}
.article .art-tags{margin-bottom:30px}
.article .art-body{font-size:16.5px;line-height:1.9;color:#2c3134}
.article .art-body h2{font-family:var(--title);font-size:22px;color:var(--accent);margin:38px 0 14px}
.article .art-body h3{font-family:var(--title);font-size:18px;color:var(--ink);margin:28px 0 10px}
.article .art-body p{margin-bottom:18px}
.article .art-body ul{margin:0 0 18px 22px}
.article .art-body li{margin-bottom:7px}
.article .art-body a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}
.article .art-body code{font-family:"JetBrains Mono",monospace;font-size:.88em;background:rgba(31,78,95,.08);padding:1px 6px;border-radius:5px}
.article .art-body pre{background:var(--paper);border:1px solid var(--line);border-radius:10px;padding:16px 18px;overflow:auto;margin-bottom:18px}
.article .art-body pre code{background:none;padding:0}
.article .art-body blockquote,.article .art-body > p:has(> em:only-child){color:var(--muted)}

/* ===================== 响应式 ===================== */
@media(max-width:880px){
  .shell{grid-template-columns:1fr}
  .topnav{flex-wrap:wrap;height:auto;padding:12px 24px;gap:16px}
  .body,.hero{padding-left:24px;padding-right:24px}
  .placeholder-note,.contact{margin-left:24px;margin-right:24px}
  .grid2,.stats,.awards,.reads{grid-template-columns:1fr}
}
