|
|
@@ -0,0 +1,177 @@
|
|
|
+/* --- 全局与变量定义 (新拟物风格) --- */
|
|
|
+@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;700&display=swap');
|
|
|
+
|
|
|
+:root {
|
|
|
+ /* 色彩方案 - 白天模式 */
|
|
|
+ --primary-color: #5b86e5;
|
|
|
+ --background-color: #e0e5ec;
|
|
|
+ --text-color: #555e67;
|
|
|
+ --text-muted-color: #9ba1a8;
|
|
|
+
|
|
|
+ /* 字体 */
|
|
|
+ --font-family-sans-serif: 'Inter', sans-serif;
|
|
|
+
|
|
|
+ /* 新拟物阴影 */
|
|
|
+ --neumorph-shadow-light: inset -5px -5px 10px #ffffff, inset 5px 5px 10px #bec3c9;
|
|
|
+ --neumorph-shadow-dark: -5px -5px 10px #ffffff, 5px 5px 10px #bec3c9;
|
|
|
+ --neumorph-shadow-dark-active: inset -3px -3px 7px #ffffff, inset 3px 3px 7px #bec3c9;
|
|
|
+
|
|
|
+ /* 圆角 */
|
|
|
+ --border-radius: 20px;
|
|
|
+}
|
|
|
+
|
|
|
+body.dark-mode {
|
|
|
+ /* 色彩方案 - 黑夜模式 */
|
|
|
+ --primary-color: #6a82fb;
|
|
|
+ --background-color: #2c2f35;
|
|
|
+ --text-color: #e2e2e2;
|
|
|
+ --text-muted-color: #8f9297;
|
|
|
+
|
|
|
+ /* 新拟物阴影 - 黑夜模式 */
|
|
|
+ --neumorph-shadow-light: inset -5px -5px 10px #35393f, inset 5px 5px 10px #232529;
|
|
|
+ --neumorph-shadow-dark: -5px -5px 10px #35393f, 5px 5px 10px #232529;
|
|
|
+ --neumorph-shadow-dark-active: inset -3px -3px 7px #35393f, inset 3px 3px 7px #232529;
|
|
|
+}
|
|
|
+
|
|
|
+* { margin: 0; padding: 0; box-sizing: border-box; }
|
|
|
+
|
|
|
+body {
|
|
|
+ font-family: var(--font-family-sans-serif);
|
|
|
+ background-color: var(--background-color);
|
|
|
+ color: var(--text-color);
|
|
|
+ line-height: 1.6;
|
|
|
+ transition: background-color 0.4s ease, color 0.4s ease;
|
|
|
+ -webkit-font-smoothing: antialiased;
|
|
|
+}
|
|
|
+
|
|
|
+.container { max-width: 980px; margin: 0 auto; padding: 0 20px; }
|
|
|
+
|
|
|
+/* --- 页头与导航 (新拟物风格) --- */
|
|
|
+header {
|
|
|
+ background-color: transparent; /* 背景透明以融入页面 */
|
|
|
+ padding: 1.5rem 0;
|
|
|
+ position: sticky; top: 0; z-index: 1000;
|
|
|
+}
|
|
|
+header .container { display: flex; align-items: center; justify-content: space-between; }
|
|
|
+.logo { font-size: 1.8rem; font-weight: 700; color: var(--text-color); text-decoration: none; flex-shrink: 0; }
|
|
|
+.main-nav { flex-grow: 1; }
|
|
|
+.main-nav ul { list-style: none; display: flex; justify-content: center; }
|
|
|
+.main-nav li { margin: 0 5px; }
|
|
|
+.main-nav a { text-decoration: none; color: var(--text-muted-color); font-weight: 500; padding: 10px 20px; border-radius: 15px; transition: all 0.3s ease; }
|
|
|
+.main-nav a:hover { color: var(--primary-color); }
|
|
|
+.main-nav a.active { color: var(--primary-color); font-weight: 700; box-shadow: var(--neumorph-shadow-dark-active); }
|
|
|
+.header-controls { display: flex; align-items: center; flex-shrink: 0; gap: 15px; }
|
|
|
+
|
|
|
+/* --- 统一控制按钮样式 --- */
|
|
|
+.control-btn {
|
|
|
+ background: var(--background-color);
|
|
|
+ border: none;
|
|
|
+ width: 45px;
|
|
|
+ height: 45px;
|
|
|
+ border-radius: 50%;
|
|
|
+ cursor: pointer;
|
|
|
+ display: flex;
|
|
|
+ align-items: center;
|
|
|
+ justify-content: center;
|
|
|
+ box-shadow: var(--neumorph-shadow-dark);
|
|
|
+ transition: box-shadow 0.2s ease, color 0.2s ease;
|
|
|
+ color: var(--text-muted-color);
|
|
|
+}
|
|
|
+.control-btn:hover { color: var(--primary-color); }
|
|
|
+.control-btn:active, .control-btn.active { box-shadow: var(--neumorph-shadow-dark-active); }
|
|
|
+#theme-switcher { font-size: 1.2rem; }
|
|
|
+.hamburger { padding-top: 2px; } /* 微调汉堡图标位置 */
|
|
|
+
|
|
|
+/* --- 轮播图 (新拟物风格) --- */
|
|
|
+.carousel { position: relative; width: 100%; margin: 2rem 0 3rem; border-radius: var(--border-radius); overflow: hidden; box-shadow: var(--neumorph-shadow-dark); }
|
|
|
+.carousel-inner { position: relative; width: 100%; aspect-ratio: 16 / 7; }
|
|
|
+.carousel-item { position: absolute; top: 0; left: 0; width: 100%; height: 100%; opacity: 0; visibility: hidden; transition: opacity 0.7s ease-in-out; }
|
|
|
+.carousel-item.active { opacity: 1; visibility: visible; z-index: 2; }
|
|
|
+.carousel-item img { width: 100%; height: 100%; object-fit: cover; display: block; }
|
|
|
+.carousel-control { position: absolute; top: 50%; transform: translateY(-50%); z-index: 10; opacity: 0.8; }
|
|
|
+.carousel-control.prev { left: 15px; }
|
|
|
+.carousel-control.next { right: 15px; }
|
|
|
+
|
|
|
+/* --- 主体内容 (新拟物风格) --- */
|
|
|
+main { padding: 2rem 0; }
|
|
|
+h1 { font-size: 2.5rem; text-align: center; margin-bottom: 3rem; color: var(--text-color); }
|
|
|
+.article-list { display: grid; gap: 2.5rem; }
|
|
|
+.article-card { background-color: var(--background-color); border-radius: var(--border-radius); padding: 2.5rem; box-shadow: var(--neumorph-shadow-dark); transition: box-shadow 0.3s ease; }
|
|
|
+.article-card:hover { box-shadow: var(--neumorph-shadow-dark-active); }
|
|
|
+.article-card h2 { font-size: 1.5rem; margin-bottom: 0.75rem; color: var(--text-color); }
|
|
|
+.article-card .meta { font-size: 0.9rem; color: var(--text-muted-color); margin-bottom: 1rem; }
|
|
|
+.article-card p { margin-bottom: 1.5rem; }
|
|
|
+
|
|
|
+/* --- 按钮与表单 (新拟物风格) --- */
|
|
|
+.btn { display: inline-block; background-color: var(--primary-color); color: #fff; padding: 14px 28px; border-radius: 15px; text-decoration: none; font-weight: 500; border: none; cursor: pointer; transition: all 0.2s ease; box-shadow: -3px -3px 7px rgba(255,255,255,0.1), 3px 3px 7px rgba(0,0,0,0.2); }
|
|
|
+.btn:hover { filter: brightness(1.1); }
|
|
|
+.btn:active { transform: scale(0.98); box-shadow: inset -3px -3px 7px rgba(255,255,255,0.1), inset 3px 3px 7px rgba(0,0,0,0.2); }
|
|
|
+
|
|
|
+/* --- 联系我页面 - 社交链接样式 --- */
|
|
|
+.social-links-container {
|
|
|
+ display: flex;
|
|
|
+ justify-content: center;
|
|
|
+ align-items: center;
|
|
|
+ flex-wrap: wrap; /* 在小屏幕上自动换行 */
|
|
|
+ gap: 2.5rem; /* 链接之间的间距 */
|
|
|
+ margin-top: 4rem; /* 与标题的间距 */
|
|
|
+ text-align: center;
|
|
|
+}
|
|
|
+
|
|
|
+.social-link-card {
|
|
|
+ display: flex;
|
|
|
+ flex-direction: column; /* 图标和文字垂直排列 */
|
|
|
+ align-items: center;
|
|
|
+ justify-content: center;
|
|
|
+ width: 150px;
|
|
|
+ height: 150px;
|
|
|
+ text-decoration: none;
|
|
|
+ background-color: var(--background-color);
|
|
|
+ border-radius: var(--border-radius);
|
|
|
+ box-shadow: var(--neumorph-shadow-dark);
|
|
|
+ transition: all 0.3s ease;
|
|
|
+ color: var(--text-color); /* 统一卡片文字颜色 */
|
|
|
+}
|
|
|
+
|
|
|
+.social-link-card:hover {
|
|
|
+ transform: translateY(-10px); /* 悬停时向上浮动 */
|
|
|
+ box-shadow: var(--neumorph-shadow-dark-active);
|
|
|
+ color: var(--primary-color);
|
|
|
+}
|
|
|
+
|
|
|
+.social-icon {
|
|
|
+ font-size: 3rem; /* 图标大小 */
|
|
|
+ margin-bottom: 1rem; /* 图标和文字的间距 */
|
|
|
+ color: var(--primary-color);
|
|
|
+ transition: color 0.3s ease;
|
|
|
+}
|
|
|
+
|
|
|
+.social-link-card:hover .social-icon {
|
|
|
+ color: inherit; /* 继承父元素 a 的颜色 */
|
|
|
+}
|
|
|
+
|
|
|
+.social-text {
|
|
|
+ font-size: 1rem;
|
|
|
+ font-weight: 500;
|
|
|
+ transition: color 0.3s ease;
|
|
|
+ color: inherit; /* 继承父元素 a 的颜色 */
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+/* --- 页脚 --- */
|
|
|
+footer { text-align: center; padding: 3rem 0; margin-top: 3rem; color: var(--text-muted-color); font-size: 0.9rem; }
|
|
|
+footer p { margin: 0.5rem 0; }
|
|
|
+
|
|
|
+/* --- 响应式设计 --- */
|
|
|
+.hamburger span { display: block; width: 22px; height: 2px; background-color: var(--text-muted-color); margin: 5px 0; transition: all 0.3s ease-in-out; border-radius: 2px; }
|
|
|
+@media (max-width: 768px) {
|
|
|
+ .main-nav { display: none; position: fixed; top: 0; left: -100%; width: 280px; height: 100%; background-color: var(--background-color); transition: left 0.4s ease; z-index: 1000; box-shadow: 10px 0 20px -5px rgba(0,0,0,0.1); }
|
|
|
+ .main-nav.active { left: 0; }
|
|
|
+ .main-nav ul { flex-direction: column; align-items: flex-start; padding: 80px 30px; }
|
|
|
+ .main-nav li { margin: 15px 0; width: 100%; }
|
|
|
+ .main-nav a { font-size: 1.2rem; }
|
|
|
+ .hamburger.active span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
|
|
|
+ .hamburger.active span:nth-child(2) { opacity: 0; }
|
|
|
+ .hamburger.active span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
|
|
|
+ .header-controls { position: relative; z-index: 1001; }
|
|
|
+}
|