/* =========================================================
   每行都带中文注释（超详细），并加入暗色模式
   ========================================================= */

/* ----------------------------
   1. 全局 CSS 变量（默认：亮色模式）
   ---------------------------- */
   :root { /* 定义全局变量，让颜色和尺寸可以统一管理 */
    --primary-color: #cc3344; /* 主色（红色） */
    --primary-color2: #1c51b4; /* 链接色/副色 */
    --bg-color: #f5f7fa; /* 页面背景色 */
    --bg-color-sub: #fdfeff; /* 页面次级背景色-主要用于渐变 */
    --card-bg: #ffffff; /* 卡片背景色 */
    --shadow-color: #11111113;/*阴影色 注意给透明度*/
    --text-title: #2e2e2e; /* 标题文字颜色 标题很粗，请注意不要给太高纯度的色*/
    --text-main: #111111; /* 主文字颜色 注意设置为最明显的色*/
    --text-sub: #575757; /* 次级文字颜色 最不明显的色*/
    --border-color: #e0e0e0; /* 边框 */
    --gradient: #ffffff;/*渐变色*/
    --sidebar-width: 13%; /* 左侧边栏宽度 */
    --img-bg: url("../assets/illustration/");/*默认无背景图片*/
  }
  
  /* ----------------------------
     字体引入
     ---------------------------- */
  @font-face {
    font-family: "SourceHanSerifCN-Regular"; /* 定义字体名：思源宋体-Regular */
    src: url("../assets/fonts/SourceHanSerifCN-Regular.otf") format("opentype"); /* 字体文件路径 */
    font-weight: 400; /* 字重为普通 */
  }
  @font-face {
    font-family: "SourceHanSerifCN-Bold"; /* 定义粗体字体名：思源宋体-Bold */
    src: url("../assets/fonts/SourceHanSerifCN-Bold.otf") format("opentype"); /* 字体文件路径 */
    font-weight: 700; /* 字重为粗体 */
  }
  
  /* ----------------------------
     浏览器默认样式清除
     ---------------------------- */
  * { /* 选择所有元素 */
    margin: 0; /* 去掉外边距 */
    padding: 0; /* 去掉内边距 */
    box-sizing: border-box; /* 调整盒模型，让宽度包含 padding */
  }
  
  body { /* 页面主体 */
    font-family: "Microsoft YaHei", "PingFang SC", sans-serif; /* 设定默认字体 */
    background: var(--bg-color); /* 背景颜色 */
    color: var(--text-main); /* 字体颜色 */
    line-height: 1.6; /* 行距设置 */
    display: flex; /* 启用 Flex 布局，让侧边栏与内容并排 */
    min-height: 100vh; /* 整个页面至少占满一屏高度 */
  }
  
  a { /* 链接样式 */
    text-decoration: none; /*取消链接下划线*/
    color: var(--primary-color2);
    font-size: 14px;/*链接字号*/
  } 
  a:hover{/*鼠标移至或者选中*/
    text-decoration:underline; /*显示链接下划线*/
  }

  ul { list-style: none; } /* 清除 ul 的小圆点 */
  
  /* =========================================================
     3. 左侧侧边栏（固定）
     ========================================================= */
  .sidebar { /* 整个左侧菜单栏 */
    width: var(--sidebar-width); /* 宽度固定 */
    background: var(--card-bg); /* 背景色使用变量 */
    border-right: 1px solid var(--border-color); /* 右侧边框 */
    display: flex; /* 垂直布局 */
    flex-direction: column; /* 内容从上到下排列 */
    position: fixed; /* 固定在左侧，不随页面滚动 */
    top: 0; /* 顶部对齐 */
    left: 0; /* 左侧对齐 */
    height: 100%; /* 高度占满整个屏幕 */
    z-index: 100; /* 保证盖在下面内容之上 */
    transition: transform 0.3s ease; /* 方便未来做动画 */
  }
  
  .logo-area { /* 上方 Logo 区域 */
    padding: 30px 20px; /* 上下 30 左右 20 的内边距 */
    text-align: center; /* Logo 居中 */
    border-bottom: 1px solid var(--border-color); /* 底部分隔线 */
  }
  
  .logo { /* Logo 图片 */
    max-width: 80%; /* 最大宽度限制 */
    display: block; /* 变成块级元素 */
    margin: 0 auto 10px; /* 水平居中并向下留白 */
  }
  
  .nav-menu { /* 导航菜单区域 */
    flex: 1; /* 占满剩余高度 */
    padding: 20px 0; /* 上下留空 */
    overflow-y: auto; /* 超出时允许垂直滚动 */
  }
  
  .nav-item { /* 每一项菜单 */
    display: block; /* 占一整行 */
    padding: 15px 30px; /* 内边距让点击区域更大 */
    font-size: 16px; /* 字体大小 */
    color: var(--text-main); /* 文字颜色 */
    border-left: 4px solid transparent; /* 左侧 4px 宽的线：默认透明 */
    transition: 0.2s; /* 悬停动画更柔和 */
  }
  
  .nav-item:hover,
  .nav-item.active { /* 悬停或当前选中菜单 */
    background: color-mix(in srgb, var(--primary-color) 10%, transparent);/* 将原色与透明色混合 */
    color: var(--primary-color); /* 文字变主色 */
    border-left-color: var(--primary-color); /* 左侧变红色线 */
  }
  
  .social-links { /* 底部社交区域 */
    padding: 20px; /* 内边距 */
    background: var(--bg-color-sub); /* 背景色 */
    border-top: 1px solid var(--border-color); /* 顶部分隔线 */
  }
  
  .social-icons { /* 社交图标一排横向 */
    display: flex; /* 横向排列 */
    justify-content: space-around; /* 均分空间 */
    margin-bottom: 10px; /* 与下方留空 */
  }
  
  .social-icons img { /* 每个社交图标 */
    width: 24px; /* 图标大小 */
    opacity: 0.7; /* 默认半透明 */
    transition: 0.2s; /* 悬停动画 */
  }
  
  .social-icons img:hover { opacity: 1; } /* 悬停后变为不透明 */
  
  .contact-email { /* 底部联系方式 */
    font-size: 14px; /* 字号 */
    text-align: center; /* 居中 */
    color: var(--text-sub); /* 颜色稍浅 */
  }
  
  /* =========================================================
     4. 右侧内容大区域（主内容容器）
     ========================================================= */
  .main-wrapper { /* 右侧主体 */
    flex: 1; /* 占满剩余宽度 */
    margin-left: var(--sidebar-width); /* 让出侧边栏的位置 */
    display: flex; /* 垂直排列 */
    flex-direction: column; /* 内容从上往下 */
    min-width: 0; /* 防止内容撑破布局 */
    background-image: /*背景图片，叠加从下往上的渐变，背景色至透明*/
    linear-gradient(to bottom, var(--bg-color), rgba(255, 255, 255, 0)),
    var(--img-bg);
    background-size: cover;/*背景图片的大小*/
    background-position: center;/*固定背景图片*/
  }
  
  /* =========================================================
     5. 顶部导航栏（透明 + 毛玻璃）
     ========================================================= */
  .top-header { /* 顶部栏 */
    height: 45px; /* 高度 */
    background: color-mix(in srgb, var(--card-bg) 85%, transparent);/* 将原色与透明色混合 */
    backdrop-filter: blur(5px); /* 毛玻璃模糊效果 */
    border-bottom: 1px solid var(--border-color); /* 底部分隔线 */
    display: flex; /* 水平布局 */
    align-items: center; /* 垂直居中 */
    justify-content: space-between; /* 左右分散 */
    padding: 0 30px; /* 左右内边距 */
    position: sticky; /* 滚动时吸附在顶部 */
    top: 0; /* 与顶部对齐 */
    z-index: 90; /* 层级 */
  }
  
  .theme-links { /* 顶部主题切换按钮使用flex布局 */
    display: flex;
    align-items: center;
  }
  
  /* 让 themetext 排到最前面 */
  .theme-links .themetext {
    order: -1;
    color: var(--text-sub);
    margin-right: 14px;
  }
  
  .theme-links button { /* 顶部主题切换按钮 */
    background-color: rgba(0,0,0,0); /* 透明背景 */
    border: none; /* 去掉边框 */
    margin-right: 14px; /* 链接之间的间距 */
    font-size: 15px; /* 字号 */
    color: var(--text-sub); /* 次级文字颜色 */
  }
  
  .theme-links .buttondefault{ /*解决汉字与英文高度不对齐的问题*/
    margin-bottom: 1px;
  }

  .theme-links button:hover { /* 悬停或者选择时改变文字颜色 */
    color: var(--primary-color);/* 主题色 */
  }
  
  /* button:hover 时 themetext 跟着变色 */
  .theme-links button:hover ~ .themetext {
    color: var(--primary-color);/* 主题色 */
  }

  .user-actions button { /* 用户操作按钮 */
    margin-left: 15px; /* 两个操作之间留空 */
    font-size: 14px; /* 字体 */
    color: var(--text-usb); /* 次级文字颜色 */
  }
  
  /* =========================================================
     5. 主内容区（网格布局）
     ========================================================= */
  .content-area {
    padding: 30px;
    display: grid;/* 网格布局 */
    grid-template-columns: repeat(12, 1fr); /* 简单的12列系统 */
    gap: 20px;/* 卡片间距 */
  }
  
  /* ==== 每张卡片的基础样式 ==== */
  .card { /*通用卡片样式*/
    background: var(--card-bg);
    border-radius: 8px;
    padding: 20px;
    box-shadow: 0 2px 10px var(--shadow-color);
    background: linear-gradient(to bottom, var(--card-bg) 0%, var(--card-bg) 60%, var(--gradient) 500%);
  }
  
  .card h2 { /*通用卡片样式*/
    color: var(--text-title);
    font-size: 24px;
    margin-bottom: 15px;
    font-family: "SourceHanSerifCN-Bold", sans-serif;
  }

  .card-h2-a { /*介绍卡片的标题有特殊的左侧红条设计）*/
    padding-left: 10px;
    border-left: 4px solid var(--primary-color); /* 左侧红条 */
  }
  
  /*通用卡片样式*/
  .card p { 
    font-size: 14px; 
    margin-bottom: 8px; 
    color: var(--text-main); 
  }
  .card hr {  
    margin-bottom: 15px; 
    border: 0; 
    height: 1px; 
    background: var(--border-color); 
  }
  
  /* ==== 特殊卡片：头图大Banner（占一整行） ==== */
  .card.focus {
    grid-column: span 12;
    height: 200px;
    padding: 0;
    position: relative;
    overflow: hidden;
    background: #333 url("../assets/illustration/yichun-yixuan.jpg") 65% center/cover;
  }
  
  .focus-content {
    position: absolute;
    bottom: 0;
    width: 100%;
    padding: 30px 30px 85px;
    background: linear-gradient(to top, rgba(34,34,34,0.8), transparent);
  }
  
  .focus-content h1 {
    margin-bottom: 4px;
    font-size: 36px;
    text-shadow: 0 2px 4px rgba(0,0,0,0.5);
    padding: 0;
    font-family: "SourceHanSerifCN-Bold", sans-serif;
    color: var(--card-bg);
  }
  .focus-content h4 {
    color: var(--card-bg);
  }
  
  /* 两个按钮：简单白底圆角 */
  .card.focus .button1,
  .card.focus .button2 {
    position: absolute;
    bottom: 24px;
    width: 70px;
    height: 45px;
    background: #fff;
    border-radius: 15px;
    font-size: 18px;
    padding: 10px;
  }
  .card.focus .button1 { left: 29px; }/*对按钮进行定位*/
  .card.focus .button2 { left: 110px; }
  .card.focus .button-text { color: var(--primary-color); font-size: 16px; }

  /* .button-text按钮内文本元素将跟随父元素.button1和.button2的:hover */
  .card.focus .button1:hover .button-text,
  .card.focus .button2:hover .button-text {
    color: var(--primary-color2);/*变为链接色*/
  }
  
  /* ==== 网格布局尺寸：大/中/小列 ==== */
  .col-large { grid-column: span 7; }  /* 左侧主列（约60%） */
  .col-small { grid-column: span 5; }  /* 右侧次列（约40%） */
  .col-half  { grid-column: span 6; }  /* 一半一半 */
  
  
  /* =========================================================
     6. 页脚（最底部）
     ========================================================= */
  footer {
    text-align: center;
    padding: 40px 0;
    color: var(--text-sub);
    font-size: 13px;
    margin-top: auto;   /* 让页脚自动贴到最底 */
  }
  
  
  /* =========================================================
     7. 手机端适配（屏幕 ≤ 900px）
     ========================================================= */
  .mobile-nav { display: none; }
  
  @media screen and (max-width: 900px) {
    /* 隐藏侧边栏 */
    .sidebar { display: none; }
  
    /* 主内容移回全宽 */
    .main-wrapper {
      margin-left: 0;
      margin-bottom: 60px; /* 给底部导航留出空间 */
    }
  
    /* 顶部栏压缩 */
    .top-header { padding: 0 15px; }
    .theme-links { display: none; }
  
    /* 网格全部单列显示 */
    .card.focus,
    .col-large,
    .col-small,
    .col-half {
      grid-column: span 12;
    }

    /* 手机Banner高度略缩 */
    .card.focus { height: 250px; }

    .card h1 {
      font-size: 30px;
    }
  
    /* ==== 手机底部导航栏（类似APP Tab Bar） ==== */
    .mobile-nav {
      display: flex;
      position: fixed;
      bottom: 0;
      left: 0;
      width: 100%;
      height: 60px;
      background: white;
      border-top: 1px solid var(--border-color);
      justify-content: space-around;
      align-items: center;
      z-index: 1000;
    }
  
    .mobile-nav a {
      flex: 1;
      text-align: center;
      padding: 10px 0;
      font-size: 12px;
      color: var(--text-sub);
    }
  
    .mobile-nav a.active { color: var(--primary-color); }
  }
  
  