模板:卡片/Cards.css:修订间差异

来自Hokubu Wiki
无编辑摘要
无编辑摘要
 
(未显示同一用户的13个中间版本)
第1行: 第1行:
/* 首页网格布局 - 自适应卡片数量 */
/* ======================
  基础布局与网格系统(保持不变)
  ====================== */
.home-grid {
.home-grid {
   display: grid;
   display: grid;
   grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
   grid-template-columns: repeat(3, minmax(300px, 1fr));
   gap: 20px;
   gap: 20px;
   padding: 20px;
   padding: 20px;
  box-sizing: border-box;
}
}


/* 活动卡片主体样式 */
@media (min-width: 1200px) {
  .home-grid {
    grid-template-columns: repeat(4, minmax(300px, 1fr));
  }
}
 
@media (max-width: 1024px) {
  .home-grid {
    grid-template-columns: repeat(2, minmax(280px, 1fr));
  }
}
 
@media (max-width: 768px) {
  .home-grid {
    grid-template-columns: 1fr;
    padding: 10px;
  }
  .home-card .transport-card {
    height: 150px; /* 图片高度仍可固定,不影响正文 */
  }
}
 
@media (max-width: 480px) {
  .home-card__header {
    font-size: 1rem;
  }
  .home-card__text,
  .home-link {
    padding: 10px;
  }
}
 
/* ======================
  卡片主体样式(核心修改)
  ====================== */
.home-card {
.home-card {
   overflow: hidden;
   overflow: hidden;
   background: var(--color-surface-2);
   background: #f5f7fa;
   border: 1px solid var(--border-color-base);
   border: 1px solid #dee2e6;
   border-radius: 15px;
   border-radius: 15px;
   box-shadow: var(--box-shadow-card);
   box-shadow: 0 3px 6px rgba(0,0,0,0.04), 0 3px 6px rgba(0,0,0,0.0575);
   transition: all 0.3s ease;
   transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
   display: flex;
   display: flex;
   flex-direction: column;
   flex-direction: column;
  /* 移除 height: 100%,改为默认 auto,让卡片高度随内容自适应 */
  /* height: 100%; 删掉这行 */
}
}


.home-card:hover {
.home-card:hover {
   transform: translateY(-5px);
   transform: translateY(-5px);
   border-color: var(--color-primary);
   border-color: #3498db;
   box-shadow: 0 10px 20px rgba(0,0,0,0.1);
   box-shadow: 0 10px 20px rgba(0,0,0,0.1);
}
}


/* 卡片标题区域 */
/* ======================
  卡片内容区域样式(核心修改)
  ====================== */
.home-card__header {
.home-card__header {
   margin: 0;
   margin: 0;
   padding: 15px 20px;
   padding: 15px 20px;
   background: var(--color-surface-3);
   background: #e9ecef;
   border-bottom: 1px solid var(--border-color-base);
   border-bottom: 1px solid #dee2e6;
   font-size: 1.2rem;
   font-size: 1.2rem;
   font-weight: bold;
   font-weight: bold;
}
}


/* 卡片图片容器 */
.home-card .transport-card {
.home-card .transport-card {
   position: relative;
   position: relative;
   height: 180px;
   height: 180px; /* 图片高度可固定,不影响正文自适应 */
   margin: 0;
   margin: 0;
   border: none !important;
   border: none !important;
第62行: 第102行:
}
}


/* 卡片文本内容 */
/* 文本内容区域:解除高度限制 */
.home-card__text {
.home-card__text {
   margin: 0;
   margin: 0;
   padding: 15px 20px;
   padding: 15px 20px;
   line-height: 1.6;
   line-height: 1.6;
   flex-grow: 1;
   flex-grow: 1; /* 保留flex特性,让文本区域填充剩余空间(但不限制最大高度) */
  /* 删掉以下两行限制,让文本高度随内容自然扩展 */
  /* max-height: 76.8px; */
  /* overflow: hidden; */
  position: relative;
}
 
/* 移除文本区域的渐变遮罩(因为内容不再被隐藏) */
.home-card__text::after {
  display: none; /* 删掉渐变遮罩,避免无意义的覆盖 */
}
}


/* 卡片按钮区域 */
.home-link {
.home-link {
   margin: 0 20px 15px;
   margin: 0 20px 15px;
第79行: 第127行:
   display: inline-block;
   display: inline-block;
   padding: 8px 16px;
   padding: 8px 16px;
   background: var(--color-primary);
   background: #3498db;
   color: white;
   color: white;
   border-radius: 8px;
   border-radius: 8px;
第88行: 第136行:


.home-link__button:hover {
.home-link__button:hover {
   background: var(--color-primary--hover);
   background: #2980b9;
}
 
/* 覆盖按钮内 MediaWiki 链接的默认样式 */
.home-link__button a {
  color: white !important; /* 强制文本为白色,与按钮背景匹配 */
  text-decoration: none !important; /* 移除默认下划线 */
  display: inline-block; /* 确保链接占据按钮完整区域(可选) */
}
 
/* 悬停时保持样式一致(可选) */
.home-link__button a:hover {
  color: white !important;
  text-decoration: none !important;
}
 
/* ======================
  暗色模式适配样式(修改为 skin-citizen-dark 触发)
  ====================== */
html.skin-citizen-dark .home-card {
  background: #1e1e2e; /* 深色背景 */
  border-color: #373747; /* 深色边框 */
  box-shadow: 0 3px 6px rgba(0,0,0,0.2), 0 3px 6px rgba(0,0,0,0.25); /* 深色环境增强阴影 */
}
 
html.skin-citizen-dark .home-card:hover {
  border-color: #4a90e2; /* 暗色模式下悬停边框色调整 */
}
 
html.skin-citizen-dark .home-card__header {
  background: #2d2d3f; /* 标题栏深色背景 */
  border-bottom-color: #373747; /* 标题栏底部边框 */
  color: #e0e0f5; /* 标题文本色(浅色) */
}
 
html.skin-citizen-dark .home-card__text {
  color: #d0d0e0; /* 正文浅色文本,确保在深色背景上可读 */
}
 
html.skin-citizen-dark .home-link__button {
  background: #4a90e2; /* 稍亮的蓝色按钮,增强对比度 */
}
}


/* 响应式布局调整 */
html.skin-citizen-dark .home-link__button:hover {
@media (max-width: 1024px) {
  background: #357abd; /* 悬停时加深 */
  .home-grid {
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  }
}
}


@media (max-width: 768px) {
html.skin-citizen-dark .home-link__button a {
  .home-grid {
  color: #ffffff !important; /* 白色文本,确保清晰 */
    grid-template-columns: 1fr;
  }
}
}

2025年7月26日 (六) 23:53的最新版本

/* ======================
   基础布局与网格系统(保持不变)
   ====================== */
.home-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(300px, 1fr));
  gap: 20px;
  padding: 20px;
  box-sizing: border-box;
}

@media (min-width: 1200px) {
  .home-grid {
    grid-template-columns: repeat(4, minmax(300px, 1fr));
  }
}

@media (max-width: 1024px) {
  .home-grid {
    grid-template-columns: repeat(2, minmax(280px, 1fr));
  }
}

@media (max-width: 768px) {
  .home-grid {
    grid-template-columns: 1fr;
    padding: 10px;
  }
  .home-card .transport-card {
    height: 150px; /* 图片高度仍可固定,不影响正文 */
  }
}

@media (max-width: 480px) {
  .home-card__header {
    font-size: 1rem;
  }
  .home-card__text,
  .home-link {
    padding: 10px;
  }
}

/* ======================
   卡片主体样式(核心修改)
   ====================== */
.home-card {
  overflow: hidden;
  background: #f5f7fa;
  border: 1px solid #dee2e6;
  border-radius: 15px;
  box-shadow: 0 3px 6px rgba(0,0,0,0.04), 0 3px 6px rgba(0,0,0,0.0575);
  transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
  display: flex;
  flex-direction: column;
  /* 移除 height: 100%,改为默认 auto,让卡片高度随内容自适应 */
  /* height: 100%; 删掉这行 */
}

.home-card:hover {
  transform: translateY(-5px);
  border-color: #3498db;
  box-shadow: 0 10px 20px rgba(0,0,0,0.1);
}

/* ======================
   卡片内容区域样式(核心修改)
   ====================== */
.home-card__header {
  margin: 0;
  padding: 15px 20px;
  background: #e9ecef;
  border-bottom: 1px solid #dee2e6;
  font-size: 1.2rem;
  font-weight: bold;
}

.home-card .transport-card {
  position: relative;
  height: 180px; /* 图片高度可固定,不影响正文自适应 */
  margin: 0;
  border: none !important;
}

.home-card .transport-image {
  position: absolute;
  inset: 0;
  margin: 0;
  border-radius: 0;
  overflow: hidden;
}

.home-card .transport-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s cubic-bezier(0, 0.8, 0.2, 1);
}

.home-card .transport-image img:hover {
  transform: scale(1.1);
}

/* 文本内容区域:解除高度限制 */
.home-card__text {
  margin: 0;
  padding: 15px 20px;
  line-height: 1.6;
  flex-grow: 1; /* 保留flex特性,让文本区域填充剩余空间(但不限制最大高度) */
  /* 删掉以下两行限制,让文本高度随内容自然扩展 */
  /* max-height: 76.8px; */
  /* overflow: hidden; */
  position: relative;
}

/* 移除文本区域的渐变遮罩(因为内容不再被隐藏) */
.home-card__text::after {
  display: none; /* 删掉渐变遮罩,避免无意义的覆盖 */
}

.home-link {
  margin: 0 20px 15px;
  text-align: center;
}

.home-link__button {
  display: inline-block;
  padding: 8px 16px;
  background: #3498db;
  color: white;
  border-radius: 8px;
  text-decoration: none;
  transition: background 0.3s ease;
  font-weight: 600;
}

.home-link__button:hover {
  background: #2980b9;
}

/* 覆盖按钮内 MediaWiki 链接的默认样式 */
.home-link__button a {
  color: white !important; /* 强制文本为白色,与按钮背景匹配 */
  text-decoration: none !important; /* 移除默认下划线 */
  display: inline-block; /* 确保链接占据按钮完整区域(可选) */
}

/* 悬停时保持样式一致(可选) */
.home-link__button a:hover {
  color: white !important;
  text-decoration: none !important;
}

/* ======================
   暗色模式适配样式(修改为 skin-citizen-dark 触发)
   ====================== */
html.skin-citizen-dark .home-card {
  background: #1e1e2e; /* 深色背景 */
  border-color: #373747; /* 深色边框 */
  box-shadow: 0 3px 6px rgba(0,0,0,0.2), 0 3px 6px rgba(0,0,0,0.25); /* 深色环境增强阴影 */
}

html.skin-citizen-dark .home-card:hover {
  border-color: #4a90e2; /* 暗色模式下悬停边框色调整 */
}

html.skin-citizen-dark .home-card__header {
  background: #2d2d3f; /* 标题栏深色背景 */
  border-bottom-color: #373747; /* 标题栏底部边框 */
  color: #e0e0f5; /* 标题文本色(浅色) */
}

html.skin-citizen-dark .home-card__text {
  color: #d0d0e0; /* 正文浅色文本,确保在深色背景上可读 */
}

html.skin-citizen-dark .home-link__button {
  background: #4a90e2; /* 稍亮的蓝色按钮,增强对比度 */
}

html.skin-citizen-dark .home-link__button:hover {
  background: #357abd; /* 悬停时加深 */
}

html.skin-citizen-dark .home-link__button a {
  color: #ffffff !important; /* 白色文本,确保清晰 */
}