/* Home 页面专用样式 - 基于 API 页面设计风格 */

/* 仅作用于 home 文件夹下的文章内容，避免污染全局样式 */
.story-wrap {
  max-width: 900px;
  margin: 80px auto;
  padding: var(--spacing-xl);
  background: var(--color-white-light);
  border-radius: var(--border-radius);
  border: 0.5px solid var(--color-border);
  box-shadow: var(--shadow-sm);
  overflow-y: auto;
  
  /* 背景渐显动画 */
  opacity: 0;
  animation: contentBackgroundFadeIn 0.8s cubic-bezier(0.4, 0, 0.2, 1) 0.1s forwards;
}

/* 内容区背景渐显动画关键帧 */
@keyframes contentBackgroundFadeIn {
  0% { opacity: 0; }
  100% { opacity: 1; }
}

.story-header {
  text-align: center;
  margin-bottom: var(--spacing-xxl);
}

.story-title {
  font-size: var(--font-size-xlarge);
  font-weight: var(--font-weight-bold);
  margin: var(--spacing-xxl) 0 var(--spacing-xl);
  color: var(--color-primary);
  letter-spacing: -0.02em;
  line-height: 1.1;
  padding-bottom: var(--spacing-xxl);
  border-bottom: 1px solid var(--color-border);
  scroll-margin-top: calc(var(--header-height) + var(--spacing-lg));
  position: relative;
}

.story-meta {
  color: var(--color-secondary);
  font-size: var(--font-size-medium);
  font-weight: var(--font-weight-normal);
  line-height: 1.4;
}

.story-toc {
  margin: var(--spacing-md) 0;
  padding: var(--spacing-sm);
  background: linear-gradient(135deg, rgba(0, 122, 255, 0.03), rgba(0, 122, 255, 0.08));
  border-radius: var(--border-radius-md);
  border: 1px dashed var(--color-border);
  font-size: var(--font-size-small);
  color: var(--color-secondary);
}

.story-article {
  max-width: 800px;
  margin: 0 auto;
}

.story-article p {
  line-height: 1.7;
  font-size: var(--font-size-base);
  margin-bottom: var(--spacing-md);
  color: var(--color-secondary);
}

.story-article h2 {
  font-size: var(--font-size-large);
  font-weight: var(--font-weight-semibold);
  color: var(--color-primary);
  margin: var(--spacing-xxl) 0 var(--spacing-lg);
  padding-bottom: var(--spacing-sm);
  scroll-margin-top: calc(var(--header-height) + var(--spacing-lg));
}

.story-article h3 {
  font-size: var(--font-size-slarge);
  font-weight: var(--font-weight-medium);
  color: var(--color-primary);
  margin: var(--spacing-xl) 0 var(--spacing-md);
  scroll-margin-top: calc(var(--header-height) + var(--spacing-lg));
}

.story-figure {
  margin: var(--spacing-md) 0;
  text-align: center;
}

.story-img-ph {
  width: 100%;
  height: 220px;
  border-radius: var(--border-radius-md);
  border: 2px dashed var(--color-border);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-secondary);
  background: linear-gradient(180deg, var(--color-white-light), var(--color-white));
}

.story-figure img {
  max-width: 100%;
  height: auto;
  display: block;
  margin: 0 auto;
  border-radius: var(--border-radius-md);
}

.story-caption {
  font-size: var(--font-size-small);
  color: var(--color-secondary);
  margin-top: var(--spacing-xs);
}

.story-footer {
  border-top: 1px solid var(--color-border);
  padding-top: var(--spacing-sm);
  margin-top: var(--spacing-lg);
  font-size: var(--font-size-small);
  color: var(--color-secondary);
}

.story-note {
  font-size: var(--font-size-small);
  color: var(--color-secondary);
}

.story-quote {
  border-left: 1px solid var(--color-accent);
  background: linear-gradient(135deg, rgba(0, 122, 255, 0.03), rgba(0, 122, 255, 0.08));
  padding: var(--spacing-md) var(--spacing-lg);
  margin: var(--spacing-lg) 0;
  border-radius: 0 var(--border-radius-md) var(--border-radius-md) 0;
  position: relative;
}

.story-quote::before {
  content: '"';
  position: absolute;
  top: var(--spacing-sm);
  left: var(--spacing-sm);
  font-size: var(--font-size-large);
  color: var(--color-accent);
  font-weight: var(--font-weight-bold);
  opacity: 0.3;
}

.story-quote p {
  margin: 0;
  color: var(--color-primary);
}

.user-profile {
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.08), rgba(59, 130, 246, 0.12));
  color: var(--color-primary);
  padding: var(--spacing-lg);
  border-radius: var(--border-radius-md);
  margin: var(--spacing-lg) 0;
  text-align: center;
  font-weight: var(--font-weight-bold);
  font-size: var(--font-size-medium);
  border: 1px solid rgba(59, 130, 246, 0.2);
  box-shadow: var(--shadow-sm);
  display: flex;
  align-items: center;
  gap: var(--spacing-lg);
}

.user-avatar {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  object-fit: cover;
  border: 3px solid var(--color-white);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  flex-shrink: 0;
}

.user-info {
  flex: 1;
  text-align: left;
}

.highlight-box {
  background: linear-gradient(135deg, rgba(34, 197, 94, 0.08), rgba(34, 197, 94, 0.12));
  border: 1px solid rgba(34, 197, 94, 0.2);
  border-left: 1px solid #22c55e;
  padding: var(--spacing-lg);
  margin: var(--spacing-lg) 0;
  border-radius: 0 var(--border-radius-md) var(--border-radius-md) 0;
  position: relative;
  box-shadow: var(--shadow-sm);
}

.highlight-number {
  font-size: var(--font-size-large);
  font-weight: var(--font-weight-bold);
  color: #16a34a;
  display: block;
}

.highlight-label {
  font-size: var(--font-size-small);
  color: var(--color-secondary);
  margin-top: var(--spacing-xs);
}

.scenario-box {
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.08), rgba(59, 130, 246, 0.12));
  border: 1px solid rgba(59, 130, 246, 0.2);
  border-left: 1px solid var(--color-accent);
  padding: var(--spacing-lg);
  margin: var(--spacing-lg) 0;
  border-radius: 0 var(--border-radius-md) var(--border-radius-md) 0;
  position: relative;
  box-shadow: var(--shadow-sm);
}

.scenario-title {
  font-size: var(--font-size-medium);
  font-weight: var(--font-weight-bold);
  color: var(--color-accent);
  margin-bottom: var(--spacing-sm);
}

.comparison-table {
  width: 100%;
  border-collapse: collapse;
  margin: var(--spacing-xl) 0;
  font-size: var(--font-size-base);
  background: var(--color-white);
  border-radius: var(--border-radius-md);
  border: 0.5px solid var(--color-border);
  overflow: visible;
  box-shadow: var(--shadow-sm);
}

.comparison-table th,
.comparison-table td {
  border: 1px solid var(--color-border);
  padding: var(--spacing-sm) var(--spacing-md);
  text-align: left;
}

.comparison-table th {
  background: var(--color-white-light);
  font-weight: var(--font-weight-semibold);
  color: var(--color-primary);
}

.comparison-table td {
  color: var(--color-secondary);
}

.testimonial {
  background: linear-gradient(135deg, rgba(251, 191, 36, 0.08), rgba(251, 191, 36, 0.12));
  border: 1px solid rgba(251, 191, 36, 0.2);
  border-left: 1px solid #f59e0b;
  padding: var(--spacing-lg);
  margin: var(--spacing-lg) 0;
  border-radius: 0 var(--border-radius-md) var(--border-radius-md) 0;
  font-style: italic;
  position: relative;
  box-shadow: var(--shadow-sm);
}

.testimonial::before {
  content: "💬";
  font-size: var(--font-size-large);
  position: absolute;
  top: -10px;
  left: var(--spacing-lg);
  background: linear-gradient(135deg, rgba(251, 191, 36, 0.08), rgba(251, 191, 36, 0.12));
  padding: 0 var(--spacing-sm);
}

.success-story {
  background: linear-gradient(135deg, rgba(34, 197, 94, 0.08), rgba(34, 197, 94, 0.12));
  border: 1px solid rgba(34, 197, 94, 0.2);
  border-left: 1px solid #22c55e;
  padding: var(--spacing-lg);
  margin: var(--spacing-lg) 0;
  border-radius: 0 var(--border-radius-md) var(--border-radius-md) 0;
  position: relative;
  box-shadow: var(--shadow-sm);
}

.success-title {
  font-size: var(--font-size-medium);
  font-weight: var(--font-weight-bold);
  color: #16a34a;
  margin-bottom: var(--spacing-sm);
}

.usage-stats-table {
  margin: var(--spacing-lg) 0;
}

.usage-stats-table h3 {
  font-size: var(--font-size-medium);
  font-weight: var(--font-weight-bold);
  color: var(--color-primary);
  margin-bottom: var(--spacing-md);
  text-align: center;
}

.usage-stats-table table {
  width: 100%;
  border-collapse: collapse;
  margin: var(--spacing-md) 0;
  font-size: var(--font-size-base);
  background: var(--color-white);
  /* border-radius: var(--border-radius-md); */
  border: 1px solid var(--color-border);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

.usage-stats-table th,
.usage-stats-table td {
  border: 1px solid var(--color-border);
  padding: var(--spacing-sm) var(--spacing-md);
  text-align: left;
}

.usage-stats-table th {
  background: var(--color-white-light);
  font-weight: var(--font-weight-semibold);
  color: var(--color-primary);
}

.usage-stats-table td {
  color: var(--color-secondary);
}

.usage-stats-table tr:nth-child(even) {
  background: var(--color-white-light);
}

.usage-stats-table tr:hover {
  background: rgba(59, 130, 246, 0.05);
}

.stats-title {
  font-size: var(--font-size-medium);
  font-weight: var(--font-weight-bold);
  color: var(--color-accent);
  margin-bottom: var(--spacing-md);
}

.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--spacing-md);
}

.stats-item {
  text-align: center;
  padding: var(--spacing-sm);
  background: var(--color-white);
  border-radius: var(--border-radius);
  border: 1px solid var(--color-border);
}

.stats-value {
  font-size: var(--font-size-large);
  font-weight: var(--font-weight-bold);
  color: var(--color-accent);
  display: block;
}

.stats-label {
  font-size: var(--font-size-small);
  color: var(--color-secondary);
  margin-top: var(--spacing-xs);
}

.price-suggestion {
  background: linear-gradient(135deg, rgba(168, 85, 247, 0.08), rgba(168, 85, 247, 0.12));
  border: 1px solid rgba(168, 85, 247, 0.2);
  border-left: 1px solid #a855f7;
  padding: var(--spacing-lg);
  margin: var(--spacing-lg) 0;
  border-radius: 0 var(--border-radius-md) var(--border-radius-md) 0;
  position: relative;
  box-shadow: var(--shadow-sm);
}

.price-title {
  font-size: var(--font-size-medium);
  font-weight: var(--font-weight-bold);
  color: #9333ea;
  margin-bottom: var(--spacing-md);
}

.price-tiers {
  display: flex;
  justify-content: space-around;
  flex-wrap: wrap;
  gap: var(--spacing-md);
}

.price-tier {
  background: var(--color-white);
  padding: var(--spacing-md);
  border-radius: var(--border-radius);
  text-align: center;
  min-width: 120px;
  border: 1px solid var(--color-border);
}

.price-amount {
  font-size: var(--font-size-large);
  font-weight: var(--font-weight-bold);
  color: #9333ea;
  display: block;
}

.price-period {
  font-size: var(--font-size-small);
  color: var(--color-secondary);
}

/* 响应式设计 */
@media screen and (max-width: 1024px) {
  .story-wrap {
    margin: var(--spacing-lg);
    padding: var(--spacing-lg);
  }
}

@media screen and (max-width: 767px) {
  .story-wrap {
    margin: var(--spacing-md);
    padding: var(--spacing-md);
  }
  
  .story-title {
    font-size: var(--font-size-large);
  }
  
  .story-article h2 {
    font-size: var(--font-size-slarge);
  }
  
  .story-article h3 {
    font-size: var(--font-size-medium);
  }
  
  .comparison-table {
    font-size: var(--font-size-small);
  }
  
  .comparison-table th,
  .comparison-table td {
    padding: var(--spacing-xs) var(--spacing-sm);
  }
}

/* ===== 页面特定样式 ===== */

/* bestpaper.html 样式 */
.celebration {
  background: linear-gradient(135deg, #ff6b6b, #ffa500);
  color: white;
  padding: var(--spacing-lg);
  border-radius: var(--border-radius-md);
  margin: var(--spacing-lg) 0;
  text-align: center;
  font-weight: var(--font-weight-bold);
  font-size: var(--font-size-medium);
  box-shadow: var(--shadow-sm);
}

.paper-link {
  background: var(--color-white-light);
  border: 1px solid var(--color-border);
  padding: var(--spacing-sm);
  border-radius: var(--border-radius-md);
  margin: var(--spacing-sm) 0;
  font-family: monospace;
  font-size: var(--font-size-small);
  word-break: break-all;
}

/* 新的统计数据容器样式 */
.stats-container {
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.08), rgba(59, 130, 246, 0.12));
  border: 1px solid rgba(59, 130, 246, 0.2);
  border-left: 1px solid var(--color-accent);
  padding: var(--spacing-lg);
  margin: var(--spacing-lg) 0;
  border-radius: 0 var(--border-radius-md) var(--border-radius-md) 0;
  position: relative;
  box-shadow: var(--shadow-sm);
}

.stats-row {
  display: flex;
  gap: var(--spacing-lg);
  margin-bottom: var(--spacing-md);
}

.stats-row:last-child {
  margin-bottom: 0;
}

.stats-item {
  flex: 1;
  text-align: center;
  background: var(--color-white);
  padding: var(--spacing-md);
  border-radius: var(--border-radius);
  border: 1px solid var(--color-border);
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.stats-item:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
}

.stats-number {
  font-size: var(--font-size-large);
  font-weight: var(--font-weight-bold);
  color: var(--color-accent);
  display: block;
  margin-bottom: var(--spacing-xs);
}

.stats-label {
  font-size: var(--font-size-small);
  color: var(--color-secondary);
  line-height: 1.3;
}

/* 响应式设计 */
@media screen and (max-width: 768px) {
  .stats-row {
    flex-direction: column;
    gap: var(--spacing-sm);
  }
  
  .stats-item {
    padding: var(--spacing-sm);
  }
  
  .stats-number {
    font-size: var(--font-size-medium);
  }
  
  .stats-label {
    font-size: var(--font-size-xs);
  }
}

/* 保留原有的stats-box样式以兼容其他页面 */
.stats-box {
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.08), rgba(59, 130, 246, 0.12));
  border: 1px solid rgba(59, 130, 246, 0.2);
  border-left: 1px solid var(--color-accent);
  padding: var(--spacing-lg);
  margin: var(--spacing-lg) 0;
  border-radius: 0 var(--border-radius-md) var(--border-radius-md) 0;
  position: relative;
  box-shadow: var(--shadow-sm);
}

.stats-box .stats-number {
  font-size: var(--font-size-large);
  font-weight: var(--font-weight-bold);
  color: var(--color-accent);
  display: block;
}

.stats-box .stats-label {
  font-size: var(--font-size-small);
  color: var(--color-secondary);
  margin-top: var(--spacing-xs);
}

/* gsdp.html 样式 */
.innovation {
  background: linear-gradient(135deg, #1a1a2e, #16213e, #0f3460);
  color: white;
  padding: var(--spacing-lg);
  border-radius: var(--border-radius-md);
  margin: var(--spacing-lg) 0;
  text-align: center;
  font-weight: var(--font-weight-bold);
  font-size: var(--font-size-medium);
  border: 1px solid rgba(74, 144, 226, 0.3);
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.5);
  box-shadow: var(--shadow-sm);
}

.method-box {
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.08), rgba(59, 130, 246, 0.12));
  border: 1px solid rgba(59, 130, 246, 0.2);
  border-left: 1px solid var(--color-accent);
  padding: var(--spacing-lg);
  margin: var(--spacing-lg) 0;
  border-radius: 0 var(--border-radius-md) var(--border-radius-md) 0;
  position: relative;
  box-shadow: var(--shadow-sm);
}

.method-title {
  font-size: var(--font-size-medium);
  font-weight: var(--font-weight-bold);
  color: var(--color-accent);
  margin-bottom: var(--spacing-sm);
}

/* news.html 样式 */
.timeline-container {
  position: relative;
  max-width: 800px;
  margin: 0 auto;
}

.timeline-line {
  position: absolute;
  left: 30px;
  top: 0;
  bottom: 0;
  width: 2px;
  background: linear-gradient(to bottom, #d2d2d7, #e5e5ea, #d2d2d7);
  border-radius: 1px;
}

.timeline-item {
  position: relative;
  margin-bottom: 60px;
  padding-left: 80px;
}

.timeline-item:last-child {
  margin-bottom: 0;
}

.timeline-dot {
  position: absolute;
  left: 20px;
  top: 8px;
  width: 20px;
  height: 20px;
  background: var(--color-primary);
  border-radius: 50%;
  border: 4px solid var(--color-white);
  box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.08), 0 4px 12px rgba(0, 0, 0, 0.08);
}

.timeline-year {
  position: relative;
  margin-bottom: 60px;
  padding-left: 80px;
}

.timeline-year-dot {
  position: absolute;
  left: 20px;
  top: 2px;
  width: 20px;
  height: 20px;
  background: var(--color-primary);
  border-radius: 50%;
  border: 4px solid var(--color-white);
  box-shadow: 0 0 0 2px var(--color-primary), 0 4px 12px rgba(29, 29, 31, 0.3);
}

.news-item {
  margin: 0;
  padding: 0;
  border: none;
  transition: transform 0.2s ease, background-color 0.2s ease;
}

.timeline-item:hover .news-item {
  transform: translateX(2px);
  background-color: var(--color-white-light);
}

.news-date {
  color: var(--color-secondary);
  font-weight: var(--font-weight-light);
  font-size: var(--font-size-base);
  margin-bottom: var(--spacing-xs);
  letter-spacing: -0.01em;
}

.news-content {
  color: var(--color-primary);
  line-height: 1.6;
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-normal);
  margin: 0;
}

.year-section {
  margin: 0;
  padding: 0;
  background: transparent;
}

.year-title {
  font-size: var(--font-size-large);
  font-weight: var(--font-weight-semibold);
  color: var(--color-primary);
  margin: 0 0 0;
  letter-spacing: -0.01em;
  line-height: 1.1;
}

.news-grid {
  display: grid;
  gap: 0;
}

/* education-interview.html 样式 */
.writing-quality {
  background: linear-gradient(135deg, rgba(168, 85, 247, 0.08), rgba(168, 85, 247, 0.12));
  border: 1px solid rgba(168, 85, 247, 0.2);
  border-left: 1px solid #a855f7;
  padding: var(--spacing-lg);
  margin: var(--spacing-lg) 0;
  border-radius: 0 var(--border-radius-md) var(--border-radius-md) 0;
  position: relative;
  box-shadow: var(--shadow-sm);
}

.quality-title {
  font-size: var(--font-size-medium);
  font-weight: var(--font-weight-bold);
  color: #9333ea;
  margin-bottom: var(--spacing-md);
}

.quality-features {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: var(--spacing-sm);
}

.quality-item {
  background: var(--color-white);
  padding: var(--spacing-sm);
  border-radius: var(--border-radius);
  text-align: center;
  font-size: var(--font-size-small);
  color: #9333ea;
  font-weight: var(--font-weight-bold);
  border: 1px solid var(--color-border);
}

.platform-usage {
  background: linear-gradient(135deg, rgba(34, 197, 94, 0.08), rgba(34, 197, 94, 0.12));
  border: 1px solid rgba(34, 197, 94, 0.2);
  border-left: 1px solid #22c55e;
  padding: var(--spacing-lg);
  margin: var(--spacing-lg) 0;
  border-radius: 0 var(--border-radius-md) var(--border-radius-md) 0;
  position: relative;
  box-shadow: var(--shadow-sm);
}

.platform-title {
  font-size: var(--font-size-medium);
  font-weight: var(--font-weight-bold);
  color: #16a34a;
  margin-bottom: var(--spacing-md);
}

.platform-list {
  display: flex;
  justify-content: space-around;
  flex-wrap: wrap;
  gap: var(--spacing-md);
}

.platform-item {
  background: var(--color-white);
  padding: var(--spacing-md);
  border-radius: var(--border-radius);
  text-align: center;
  min-width: 120px;
  border: 1px solid var(--color-border);
}

.platform-name {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-bold);
  color: #16a34a;
  display: block;
}

.platform-desc {
  font-size: var(--font-size-small);
  color: var(--color-secondary);
  margin-top: var(--spacing-xs);
}

/* metastone-s1.html 样式 */
.highlight-box {
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.08), rgba(59, 130, 246, 0.12));
  border: 1px solid rgba(59, 130, 246, 0.2);
  border-left: 1px solid var(--color-accent);
  padding: var(--spacing-lg);
  margin: var(--spacing-lg) 0;
  border-radius: 0 var(--border-radius-md) var(--border-radius-md) 0;
  position: relative;
  box-shadow: var(--shadow-sm);
}

.highlight-title {
  font-size: var(--font-size-medium);
  font-weight: var(--font-weight-bold);
  color: var(--color-accent);
  margin-bottom: var(--spacing-sm);
}

.tech-feature {
  background: linear-gradient(135deg, rgba(34, 197, 94, 0.08), rgba(34, 197, 94, 0.12));
  border: 1px solid rgba(34, 197, 94, 0.2);
  border-left: 1px solid #22c55e;
  padding: var(--spacing-lg);
  margin: var(--spacing-lg) 0;
  border-radius: 0 var(--border-radius-md) var(--border-radius-md) 0;
  position: relative;
  box-shadow: var(--shadow-sm);
}

.tech-title {
  font-size: var(--font-size-medium);
  font-weight: var(--font-weight-bold);
  color: #16a34a;
  margin-bottom: var(--spacing-sm);
}

.comparison-stats {
  background: linear-gradient(135deg, rgba(168, 85, 247, 0.08), rgba(168, 85, 247, 0.12));
  border: 1px solid rgba(168, 85, 247, 0.2);
  border-left: 1px solid #a855f7;
  padding: var(--spacing-lg);
  margin: var(--spacing-lg) 0;
  border-radius: 0 var(--border-radius-md) var(--border-radius-md) 0;
  position: relative;
  box-shadow: var(--shadow-sm);
}

.stats-title {
  font-size: var(--font-size-medium);
  font-weight: var(--font-weight-bold);
  color: #9333ea;
  margin-bottom: var(--spacing-md);
}

.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--spacing-md);
}

.stats-item {
  text-align: center;
  padding: var(--spacing-sm);
  background: var(--color-white);
  border-radius: var(--border-radius);
  border: 1px solid var(--color-border);
}

.stats-value {
  font-size: var(--font-size-large);
  font-weight: var(--font-weight-bold);
  color: #9333ea;
  display: block;
}

.stats-label {
  font-size: var(--font-size-small);
  color: var(--color-secondary);
  margin-top: var(--spacing-xs);
}

.paper-links {
  background: var(--color-white-light);
  border: 1px solid var(--color-border);
  padding: var(--spacing-sm);
  border-radius: var(--border-radius-md);
  margin: var(--spacing-sm) 0;
  font-family: monospace;
  font-size: var(--font-size-small);
  word-break: break-all;
}

.image-placeholder {
  width: 100%;
  height: 300px;
  border-radius: var(--border-radius-md);
  border: 2px dashed var(--color-border);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-secondary);
  background: linear-gradient(180deg, var(--color-white-light), var(--color-white));
  margin: var(--spacing-md) 0;
}

/* 图片容器样式 */
.image-container {
  margin: var(--spacing-lg) 0;
  text-align: center;
  width: 100%;
  overflow: hidden;
  border-radius: var(--border-radius-md);
  background: var(--color-white);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow-sm);
}

.story-image {
  max-width: 100%;
  height: auto;
  display: block;
  margin: 0 auto;
  border-radius: var(--border-radius-md);
  transition: transform 0.3s ease;
}

.story-image:hover {
  transform: scale(1.02);
}

.image-caption {
  font-size: var(--font-size-small);
  color: var(--color-secondary);
  margin-top: var(--spacing-sm);
  padding: var(--spacing-sm) var(--spacing-md);
  background: var(--color-white-light);
  border-top: 1px solid var(--color-border);
  line-height: 1.4;
}

/* 响应式设计 */
@media screen and (max-width: 1024px) {
  .story-wrap {
    margin: var(--spacing-lg);
    padding: var(--spacing-lg);
  }
}

@media screen and (max-width: 767px) {
  .story-wrap {
    margin: var(--spacing-md);
    padding: var(--spacing-md);
  }
  
  .story-title {
    font-size: var(--font-size-large);
  }
  
  .story-article h2 {
    font-size: var(--font-size-slarge);
  }
  
  .story-article h3 {
    font-size: var(--font-size-medium);
  }
  
  .comparison-table {
    font-size: var(--font-size-small);
  }
  
  .comparison-table th,
  .comparison-table td {
    padding: var(--spacing-xs) var(--spacing-sm);
  }
}

@media screen and (max-width: 480px) {
  .story-wrap {
    margin: var(--spacing-sm);
    padding: var(--spacing-sm);
  }
  
  .story-title {
    font-size: var(--font-size-medium);
  }
  
  .story-article h2 {
    font-size: var(--font-size-base);
  }
  
  .story-article h3 {
    font-size: var(--font-size-small);
  }
  
  /* news.html 响应式 */
  .timeline-line {
    left: 20px;
  }
  
  .timeline-item {
    padding-left: 60px;
    margin-bottom: 40px;
  }
  
  .timeline-dot {
    left: 10px;
    width: 16px;
    height: 16px;
  }
  
  .timeline-year {
    padding-left: 60px;
    margin-bottom: 40px;
  }
  
  .timeline-year-dot {
    left: 10px;
    width: 16px;
    height: 16px;
  }
  
  .year-title {
    font-size: var(--font-size-slarge);
    margin: 0 0 0;
  }
  
  .news-date {
    font-size: var(--font-size-base);
  }
  
  .news-content {
    font-size: var(--font-size-base);
  }
}

@media (max-width: 768px) {
  .timeline-line {
    left: 20px;
  }
  
  .timeline-item {
    padding-left: 60px;
    margin-bottom: 40px;
  }
  
  .timeline-dot {
    left: 10px;
    width: 16px;
    height: 16px;
  }
  
  .timeline-year {
    padding-left: 60px;
    margin-bottom: 40px;
  }
  
  .timeline-year-dot {
    left: 10px;
    width: 16px;
    height: 16px;
  }
  
  .year-title {
    font-size: var(--font-size-slarge);
    margin: 0 0 0;
  }
  
  .news-date {
    font-size: var(--font-size-base);
  }
  
  .news-content {
    font-size: var(--font-size-base);
  }
}

@media (max-width: 480px) {
  .timeline-line {
    left: 15px;
  }
  
  .timeline-item {
    padding-left: 50px;
    margin-bottom: 30px;
  }
  
  .timeline-dot {
    left: 5px;
    width: 14px;
    height: 14px;
  }
  
  .timeline-year {
    padding-left: 50px;
    margin-bottom: 30px;
  }
  
  .timeline-year-dot {
    left: 5px;
    width: 14px;
    height: 14px;
  }
  
  .year-title {
    font-size: var(--font-size-medium);
    margin: 0 0 0;
  }
  
  .news-date {
    font-size: var(--font-size-small);
  }
  
  .news-content {
    font-size: var(--font-size-small);
  }
}

/* 图片响应式样式 */
@media screen and (max-width: 1024px) {
  .image-container {
    margin: var(--spacing-md) 0;
  }
  
  .story-image {
    max-width: 100%;
    height: auto;
  }
}

@media screen and (max-width: 767px) {
  .image-container {
    margin: var(--spacing-sm) 0;
  }
  
  .story-image {
    max-width: 100%;
    height: auto;
  }
  
  .image-caption {
    font-size: var(--font-size-xs);
    padding: var(--spacing-xs) var(--spacing-sm);
  }
}

@media screen and (max-width: 480px) {
  .image-container {
    margin: var(--spacing-xs) 0;
  }
  
  .story-image {
    max-width: 100%;
    height: auto;
  }
  
  .image-caption {
    font-size: var(--font-size-xs);
    padding: var(--spacing-xs);
  }
  
  /* 用户头像响应式样式 */
  .user-profile {
    flex-direction: column;
    text-align: center;
    gap: var(--spacing-md);
  }
  
  .user-avatar {
    width: 60px;
    height: 60px;
  }
  
  .user-info {
    text-align: center;
  }
}

/* 成本对比表格样式 */
.cost-comparison-table {
  margin: 20px 0;
  overflow-x: auto;
}

.cost-comparison-table table {
  width: 100%;
  border-collapse: collapse;
  background: white;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}

.cost-comparison-table th,
.cost-comparison-table td {
  padding: 12px 16px;
  text-align: left;
  border-bottom: 1px solid #e5e7eb;
}

.cost-comparison-table th {
  background-color: #f8fafc;
  font-weight: 600;
  color: #374151;
  font-size: 14px;
}

.cost-comparison-table td {
  color: #6b7280;
  font-size: 14px;
}

.cost-comparison-table tr.highlighted {
  background-color: #eafff1;
}

.cost-comparison-table tr.highlighted td {
  color: #18b84d;
  font-weight: 600;
}

.cost-comparison-table tr:hover:not(.highlighted) {
  background-color: #f9fafb;
}
