/* --- 全局及页面设置 --- */
@page {
  size: letter portrait;
  margin: 0;
}

/* CSS 变量定义 - 核心风格设定 */
:root {
  /* 布局尺寸 */
  --container-max-width: 960px; /* 整体最大宽度 */
  --sidebar-width: 300px;       /* 左侧边栏宽度 */
  --main-content-width: calc(var(--container-max-width) - var(--sidebar-width)); /* 右侧内容区宽度 */
  --sidebar-padding: 30px;      /* 左侧边栏内边距 */
  --main-padding: 40px;         /* 右侧内容区内边距 */

  /* 字体设置 */
  --font-family-primary: 'Microsoft YaHei', 'PingFang SC', 'Hiragino Sans GB', 'Segoe UI', sans-serif; /* 主要中文字体 */
  --font-family-code: 'Source Code Pro', Consolas, monospace; /* 代码/等宽字体 */

  /* 色彩主题 (参考图片风格) */
  --color-primary: #333;          /* 深灰色 (主要标题) */
  --color-secondary: #555;        /* 中等灰色 (副标题/分类标题) */
  --color-text: #444;             /* 主文本颜色 */
  --color-muted: #777;            /* 柔和文本颜色 (年龄, 邮箱等) */
  --color-accent: #0088cc;        /* 蓝色 (链接, 图标, 圆点等强调色) */
  --color-accent-light: #99ccf3;  /* 浅蓝色 */
  --color-border: #eee;           /* 浅灰色边框 */
  --color-background-sidebar: #e8f5e9; /* 淡绿色背景 */
  --color-background-page: #f9f9f9;  /* 整体页面背景色 */
  --color-card-shadow: rgba(0, 0, 0, 0.05); /* 卡片阴影 */
  --color-skill-bar-bg: #e0f2f7;  /* 技能条背景色 */
  --color-skill-bar-fill: #4dd0e1; /* 技能条填充色 */

  /* 间距设置 */
  --spacing-xlarge: 40px;
  --spacing-large: 25px;
  --spacing-medium: 15px;
  --spacing-small: 10px;
  --spacing-tiny: 5px;
  --spacing-xxsmall: 3px;

  /* 装饰线和圆点 */
  --decorator-line-width: 2px;
  --decorator-point-size: 12px;
  --decorator-point-offset-left: -6px; /* 圆点相对于装饰线左侧的位置 */
  --decorator-point-border-width: 2px; /* 圆点边框宽度 */
  --decorator-point-offset-top: 8px;   /* 圆点垂直偏移，使其与标题对齐 */
}

/* --- 基础样式重置与全局设置 --- */
* {
  box-sizing: border-box;
}

body {
  font-family: var(--font-family-primary);
  font-weight: 300; /* 基础字体细体 */
  line-height: 1.7; /* 增大行高，提升阅读舒适度 */
  color: var(--color-text);
  background-color: var(--color-background-page);
  margin: 0;
  overflow-x: hidden; /* 避免水平滚动条 */
}

h1, h2, h3, h4, h5, h6 {
  margin: 0;
  color: var(--color-primary);
  font-weight: 600;
}

h1 { font-size: 36pt; font-weight: 700; } /* 主标题 */
h2 { font-size: 20pt; color: var(--color-secondary); margin-bottom: var(--spacing-medium); font-weight: 600; } /* 分类标题 */
h3 { font-size: 16pt; color: var(--color-primary); margin-bottom: var(--spacing-xxsmall); font-weight: 600; } /* 公司/项目名称 */
h4 { font-size: 13pt; color: var(--color-muted); font-weight: 400; } /* 职位/地点等 */

ul {
  padding: 0;
  list-style: none;
}

li {
  margin-bottom: var(--spacing-small);
  line-height: 1.8; /* 列表项行高 */
}

/* --- 整体容器与双栏布局 --- */
.container {
  display: flex;
  width: 100%;
  max-width: var(--container-max-width);
  margin: 40px auto; /* 上下边距，居中 */
  background-color: #ffffff;
  box-shadow: 0 10px 30px var(--color-card-shadow);
  border-radius: 12px; /* 圆角 */
  overflow: hidden; /* 避免内容溢出圆角 */
}

/* --- 左侧边栏样式 --- */
#sidebar {
  width: var(--sidebar-width);
  padding: var(--sidebar-padding);
  background-color: var(--color-background-sidebar); /* 淡绿色背景 */
  display: flex;
  flex-direction: column;
  border-right: 1px solid var(--color-border); /* 分隔线 */
}

.sidebar-content {
  display: flex;
  flex-direction: column;
  height: 100%; /* 使内部元素撑开 */
  flex-grow: 1; /* 让侧边栏内容区域伸展 */
}

/* 个人资料卡片 */
.profile-card {
  background-color: white; /* 卡片背景 */
  border-radius: 8px;
  padding: var(--spacing-medium);
  text-align: center;
  margin-bottom: var(--spacing-large);
  box-shadow: 0 4px 15px var(--color-card-shadow);
}

.profile-header h1 {
  font-size: 36pt; /*姓名大字 */
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: 5px;
}

.profile-meta {
  margin-top: -10px; /* 微调副标题位置 */
}

.profile-meta .subtitle {
  font-size: 14pt;
  color: var(--color-muted);
  font-weight: 300;
}

.profile-details ul {
  text-align: left;
  padding-left: 20px; /* 为图标和文本留出空间 */
}

.profile-details ul li {
  margin-bottom: var(--spacing-xxsmall);
  line-height: 1.8;
}

.profile-details i {
  display: inline-block;
  width: 25px;
  text-align: center;
  margin-right: var(--spacing-tiny);
  color: var(--color-accent);
  font-size: 13pt;
}

/* 侧边栏区块通用样式 */
.side-block {
  margin-bottom: var(--spacing-large);
}

.side-block:last-child {
  margin-bottom: 0;
}

#sidebar h1 {
  font-size: 20pt;
  font-weight: 700;
  color: var(--color-primary);
  border-bottom: 2px solid var(--color-accent);
  padding-bottom: var(--spacing-small);
  margin-bottom: var(--spacing-medium);
}

#contact ul li,
#skills ul li,
#personal-eval ul li {
  margin-bottom: var(--spacing-xxsmall);
}

#contact i {
  margin-right: var(--spacing-tiny);
  color: var(--color-accent);
  font-size: 13pt;
}

/* 技能列表样式 */
#skills ul li {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  margin-bottom: var(--spacing-medium);
}

#skills ul li:not(:last-child) {
  margin-bottom: var(--spacing-medium);
}

#skills ul li strong {
  display: inline-block;
  color: var(--color-secondary);
  font-weight: 600;
  margin-bottom: var(--spacing-tiny);
  min-width: 180px;
}

/* 技能进度条样式 */
.skill-bar-container {
  width: 100%;
  height: 10px;
  background-color: var(--color-skill-bar-bg);
  border-radius: 5px;
  overflow: hidden;
  margin-top: 5px;
}

.skill-bar {
  height: 100%;
  background-color: var(--color-skill-bar-fill);
  border-radius: 5px;
  transition: width 0.5s ease-in-out;
}

/* 页脚样式 */
#site-footer {
  text-align: center;
  margin-top: auto;
  padding-top: var(--spacing-medium);
  font-size: 9pt;
  color: var(--color-muted);
  font-style: italic;
  border-top: 1px solid var(--color-border);
  flex-shrink: 0;
}

/* --- 右侧主内容区样式 --- */
#main {
  width: var(--main-content-width);
  padding: var(--main-padding);
  background-color: #fff;
}

/* 主内容标题 */
#main-title {
  text-align: left;
  padding-top: 20px;
  margin-bottom: var(--spacing-large);
  padding-bottom: 15px;
  border-bottom: 1px solid var(--color-border);
}

#main-title h1 {
  font-size: 38pt;
  font-weight: 700;
  color: var(--color-primary);
}

.profile-meta-main {
  margin-top: 5px;
}

.profile-meta-main .subtitle {
  font-size: 14pt;
  color: var(--color-muted);
  font-weight: 300;
}

/* 主内容区块通用样式 */
.main-block {
  margin-bottom: var(--spacing-xlarge);
}

.main-block:last-child {
  margin-bottom: 0;
}

/* 分类标题样式 */
.main-block h2 {
  position: relative;
  padding-left: 40px;
  margin-bottom: var(--spacing-medium);
  color: var(--color-secondary);
  font-weight: 600;
  border-bottom: 2px solid var(--color-accent);
  padding-bottom: 8px;
}

.main-block h2 i {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  font-size: 18px;
  color: var(--color-accent);
  width: 30px;
  text-align: center;
}

/* --- 条目（日期-装饰-详情）布局 --- (默认样式，用于工作经历、教育背景等) */
.blocks {
  display: flex;
  flex-flow: row nowrap;
  align-items: flex-start;
  margin-bottom: var(--spacing-medium);
}

.blocks:last-child {
  margin-bottom: 0;
}

/* 日期区域 */
.date-block {
  flex: 0 0 230px;
  padding-right: 15px;
  text-align: right;
  font-size: 11pt;
  color: var(--color-muted);
  line-height: 1.6;
  font-family: var(--font-family-code);
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-end;
  margin-top: 8px;
}

.date-start,
.date-end,
.date-maintenance {
  display: block;
  margin-bottom: 0.2em;
}

.date-maintenance {
  font-style: italic;
  opacity: 0.8;
  font-size: 9pt;
}

/* 装饰线 */
.decorator {
  flex: 0 0 var(--decorator-line-width);
  position: relative;
  background-color: var(--color-border);
  margin: 0 15px;
  min-height: 80px;
}

/* 装饰点 */
.decorator::before {
  content: '';
  position: absolute;
  top: var(--decorator-point-offset-top);
  left: var(--decorator-point-offset-left);
  width: var(--decorator-point-size);
  height: var(--decorator-point-size);
  background-color: white;
  border: var(--decorator-point-border-width) solid var(--color-accent);
  border-radius: 50%;
  z-index: 1;
}

/* 详情区域 */
.details {
  flex: 1;
  padding-top: 5px;
}

.details header {
  margin-bottom: var(--spacing-small);
}

.details h3 {
  margin-bottom: 5px;
}

.details .place {
  display: block;
  font-size: 13pt;
  color: var(--color-muted);
  margin-top: 3px;
}

.details div ul {
  margin-top: var(--spacing-small);
  padding-left: 30px;
}

.details div li {
  position: relative;
  margin-bottom: var(--spacing-xxsmall);
}

.details div li::before {
  content: '•';
  position: absolute;
  left: -20px;
  top: 0;
  color: var(--color-accent);
  font-size: 16px;
  font-weight: bold;
  line-height: 1.8;
}

.details div ul li strong {
  color: var(--color-secondary);
  font-weight: 600;
  display: block;
  margin-bottom: 5px;
}

/* 教育背景的日期样式调整 */
.main-block h2 > i.fa-graduation-cap {
  color: #f57c00;
}
.main-block .blocks:nth-child(3) .date-block {
  margin-top: 2px;
}
.main-block .blocks:nth-child(3) .decorator {
  min-height: 60px;
}
.main-block .blocks:nth-child(3) .decorator::before {
  top: 8px;
}

/* --- 最终修正：项目经验的垂直时间轴样式 (对齐版本) --- */

/* 1. 给项目经验区块添加相对定位，作为时间线的容器 */
.main-block.project-timeline {
  position: relative;
}

/* 2. 用伪元素绘制一条贯穿所有项目的、与内容对齐的垂直线 */
.main-block.project-timeline::before {
  content: '';
  position: absolute;
  /* 精确计算线条的左边距，使其与 .decorator 的中心对齐 */
  /* 计算公式: date-block宽度(230px) + decorator左边距(15px) + 线宽一半(1px) = 246px */
  left: 246px; 
  top: 65px; /* 从标题下方开始，可以微调 */
  bottom: 15px; /* 在末尾留出一些空间 */
  width: var(--decorator-line-width);
  background-color: var(--color-border);
  z-index: 0; /* 确保在内容下方 */
}

/* 3. 保持项目区块原有的flex布局，这是对齐的关键！ */
.project-timeline .blocks {
  /* 此处无需任何新样式，它会继承默认的 .blocks 样式，从而保证对齐 */
}

/* 4. 将每个项目自己的装饰线变透明，让下方贯穿的线显示出来 */
.project-timeline .decorator {
  background-color: transparent;
}

/* 5. 每个项目的圆点会自然地绘制在贯穿线上，因为它的位置是相对于.decorator的 */
.project-timeline .decorator::before {
  /* 此处也无需任何新样式，它会继承默认的 .decorator::before 样式 */
}

/* 6. 在打印时，隐藏下载PDF和页脚 */
@media print {
  #download-pdf,
  #site-footer {
    display: none !important;
  }


}


/* ==============微信 ============*/
    /* 整体微信项 */
    .wechat-item {
      position: relative;
      display: inline-block;
      font-size: 16px;
      color: #333;
      cursor: default;
    }

    /* 悬浮二维码框 */
    .wechat-tooltip {
      position: absolute;
      top: -150px;
      left: 0;
      background-color: #2dbd3a;
      color: white;
      padding: 8px 12px;
      border-radius: 6px;
      white-space: nowrap;
      box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25);
      opacity: 0;
      visibility: hidden;
      transition: opacity 0.3s ease, visibility 0.3s ease;
      z-index: 999;
    }

    .wechat-tooltip .qr-code-container {
      margin-top: 8px;
      background-color: #fff;
      padding: 4px;
      border-radius: 4px;
      line-height: 0;
    }

    .wechat-tooltip .qr-code-container canvas {
      display: block;
      margin: 0 auto;
    }

    /* 显示 tooltip 的触发 */
    .wechat-item:hover .wechat-tooltip {
      opacity: 1;
      visibility: visible;
    }

/* === End of 微信二维码弹窗补充 === */
