/* 全局样式重置 */ * { 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; /* 给