/* 全局样式重置 */
* {
margin: 0;
/* 移除所有HTML元素的默认外边距,消除不同浏览器间的默认样式差异 */
padding: 0;
/* 移除所有HTML元素的默认内边距,确保布局起点一致 */
box-sizing: border-box;
/* 改变盒模型:元素的 width 和 height 包含内容(content)、内边距(padding)和边框(border),使尺寸计算更直观、布局更可控 */
}
/* CSS变量定义 */
:root {
--primary: #4361ee;
/* 主色调 */
--secondary: #3f37c9;
/* 辅助色 */
--accent: #4cc9f0;
/* 强调色 */
--light: #f8f9fa;
/* 浅色背景 */
--dark: #212529;
/* 深色背景 */
--success: #4CAF50;
/* 成功状态色 */
--warning: #ff9800;
/* 警告状态色 */
--danger: #f44336;
/* 危险状态色 */
--shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
/* 阴影效果 */
}
/* 页面基础样式 */
body {
font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
/* 设置页面的默认字体族。优先使用 'Segoe UI',若不可用则依次回退到 Tahoma, Geneva, Verdana,最后是系统默认的无衬线字体(sans-serif)。 */
line-height: 1.6;
/* 设置文本的行高为字体大小的1.6倍。合适的行高能提高文本的可读性和美观度,避免文字过于紧凑。 */
color: #333;
/* 设置页面的默认文字颜色为深灰色(#333),比纯黑色(#000)更柔和,阅读体验更好。 */
background: linear-gradient(135deg, #f5f7fa 0%, #c3cfe2 100%);
/* 设置页面背景为一个135度角的线性渐变。从左上角(#f5f7fa,一种极浅灰蓝)平滑过渡到右下角(#c3cfe2,一种浅灰蓝),营造出清新、现代的视觉效果。 */
min-height: 100vh;
/* 设置body的最小高度为视口(viewport)高度的100%。这确保了即使内容很少,页面也能填满整个浏览器窗口,避免背景色或背景图出现中断。 */
padding: 20px;
/* 在body元素四周设置20像素的内边距。为页面内容与浏览器窗口边缘之间提供空间,提升视觉舒适度,防止内容紧贴边缘。 */
}
/* 容器样式 - 用于内容居中 */
.container {
max-width: 1200px;
/* 设置容器的最大宽度为 1200 像素。当视口(viewport)宽度大于 1200px 时,容器宽度不会超过此值,防止内容在宽屏上过度拉伸影响阅读。 */
margin: 0 auto;
/* 设置外边距:上下为 0,左右为 auto。浏览器会自动计算并分配左右边距,使容器在其父元素内水平居中。 */
padding: 0 20px;
/* 设置内边距:上下为 0,左右为 20 像素。这为容器内的内容(如文本、图片)提供了左右边距,在窄屏(视口宽度小于 1200px)时,防止内容紧贴屏幕边缘,提升可读性和美观度。 */
}
/* 页头样式 */
header {
background: var(--primary);
/* 设置页头的背景颜色为名为 --primary 的 CSS 自定义属性(变量)所定义的值(例如,主色调) */
color: white;
/* 设置页头内所有元素的默认文字颜色为白色 */
padding: 1rem 0;
/* 设置页头的内边距:上下为 1rem,左右为 0。这会在页头顶部和底部创造空间,使其内容不紧贴边缘 */
border-radius: 10px;
/* 为页头添加 10px 的圆角,使其四个角变得圆润 */
box-shadow: var(--shadow);
/* 为页头添加阴影效果,阴影的具体样式(颜色、模糊度、偏移等)由 --shadow 变量定义 */
margin-bottom: 2rem;
/* 在页头下方设置 2rem 的外边距,与页面后续内容(如主体内容)保持距离 */
}
/* 页头内容布局 */
.header-content {
display: flex;
/* 将 .header-content 元素设置为弹性容器(flex container),使其子元素可以使用 Flexbox 布局 */
justify-content: space-between;
/* 将子元素沿主轴(默认是水平轴)分布:第一个子元素靠左,最后一个靠右,中间如果有多个子元素则平均分配剩余空间 */
align-items: center;
/* 将子元素在交叉轴(默认是垂直轴)上居中对齐。这确保了不同高度的子元素在垂直方向上视觉居中 */
}
/* Logo样式 */
.logo {
font-size: 1.8rem;
/* 设置Logo文字的字体大小为1.8倍于根元素(通常是html)的字体大小。例如,如果根字体大小是16px,则此处字体大小为 1.8 * 16 = 28.8px。使用rem单位确保在不同设备上能根据用户设置或响应式设计进行缩放。 */
font-weight: bold;
/* 设置字体粗细为粗体(等同于数值700),使Logo文字更加醒目和突出。 */
}
/* 导航菜单样式 */
nav ul {
display: flex;
/* 将此元素设置为弹性容器(flex container),使其子元素成为弹性项目(flex items),并启用 Flexbox 布局模式 */
list-style: none;
/* 移除此元素(通常用于 ul 或 ol 列表)的项目符号或编号 */
}
nav ul li {
margin-left: 1.5rem;
/* 给