/**
 * 完整样式表 - 深色渐变风格
 * 依赖：design-tokens.css
 */

/* ========== Reset & Base ========== */

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  font-family: var(--font-system);
  background: var(--bg-primary);
  color: var(--text-primary);
  line-height: var(--line-height-loose);
  overflow-x: hidden;
}

/* ========== Scrollbar ========== */

::-webkit-scrollbar {
  width: 8px;
}

::-webkit-scrollbar-track {
  background: var(--bg-primary);
}

::-webkit-scrollbar-thumb {
  background: var(--border);
  border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
  background: var(--accent-orange);
}

/* ========== Container ========== */

.container {
  max-width: var(--container-max-width);
  margin: 0 auto;
  padding: 0 var(--container-padding);
}

@media (max-width: 768px) {
  .container {
    padding: 0 var(--container-padding-mobile);
  }
}

/* ========== Header ========== */

.header {
  min-height: 100vh;
  display: flex;
  align-items: center;
  position: relative;
  overflow: hidden;
}

.header::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: var(--bg-glow-orange), var(--bg-glow-cyan);
  pointer-events: none;
}

.header-content {
  position: relative;
  z-index: var(--z-base);
  padding: var(--spacing-2xl) 0;
}

/* ========== Badge ========== */

.badge-wrapper {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  margin-bottom: var(--spacing-xl);
}

.badge {
  display: inline-flex;
  align-items: center;
  padding: var(--spacing-xs) var(--spacing-md);
  background: var(--bg-card);
  border: var(--border-thin) solid var(--border);
  border-radius: var(--radius-pill);
  font-size: var(--font-size-small);
  font-weight: var(--font-weight-semibold);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wider);
  color: var(--text-secondary);
  text-decoration: none;
  transition: all var(--transition-fast);
}

.badge:hover {
  border-color: var(--text-primary);
  color: var(--text-primary);
}

/* ========== Title ========== */

.title {
  font-size: var(--font-size-hero);
  font-weight: var(--font-heavy);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--spacing-lg);
}

.title-line-1 {
  background: var(--gradient-primary);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.title-line-2 {
  background: var(--gradient-accent);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ========== Subtitle ========== */

.subtitle {
  font-size: var(--font-size-body);
  color: var(--text-secondary);
  font-weight: var(--font-weight-normal);
  max-width: 700px;
  line-height: var(--line-height-relaxed);
  margin-bottom: var(--spacing-2xl);
}

/* ========== Meta Grid ========== */

.meta-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--spacing-lg);
  max-width: 700px;
  margin-bottom: var(--spacing-xl);
}

.meta-item {
  padding: var(--spacing-md) 0;
  border-top: var(--border-thin) solid var(--border);
}

.meta-label {
  font-size: var(--font-size-tiny);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  color: var(--text-tertiary);
  margin-bottom: var(--spacing-xs);
}

.meta-value {
  font-size: var(--font-size-body);
  color: var(--text-primary);
}

/* ========== CTA Button ========== */

.cta-button {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-sm);
  padding: var(--spacing-md) var(--spacing-xl);
  background: var(--gradient-accent);
  color: #ffffff;
  text-decoration: none;
  border-radius: var(--radius-pill);
  font-weight: var(--font-weight-semibold);
  font-size: var(--font-size-body);
  transition: all var(--transition-fast);
  box-shadow: var(--shadow-sm);
}

.cta-button:hover {
  transform: var(--hover-lift-sm);
  box-shadow: var(--shadow-md);
}

.cta-button svg {
  width: 20px;
  height: 20px;
}

/* ========== Section ========== */

.section {
  padding: var(--section-padding-vertical) 0;
}

@media (max-width: 768px) {
  .section {
    padding: var(--section-padding-vertical-mobile) 0;
  }
}

.section-title {
  font-size: var(--font-size-section);
  font-weight: var(--font-heavy);
  letter-spacing: var(--letter-spacing-normal);
  margin-bottom: var(--spacing-3xl);
}

/* ========== Points Grid ========== */

.points-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
  gap: var(--spacing-lg);
}

@media (max-width: 768px) {
  .points-grid {
    grid-template-columns: 1fr;
  }
}

/* ========== Point Card ========== */

.point-card {
  background: var(--bg-card);
  border: var(--border-thin) solid var(--border);
  padding: var(--card-padding);
  border-radius: var(--radius-lg);
  transition: all var(--transition-fast);
  position: relative;
  overflow: hidden;
}

.point-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--gradient-accent);
  opacity: 0;
  transition: opacity var(--transition-fast);
}

.point-card:hover {
  border-color: var(--accent-orange);
  transform: var(--hover-lift);
  box-shadow: var(--shadow-lg);
}

.point-card:hover::before {
  opacity: 1;
}

.point-number {
  font-size: 48px;
  font-weight: var(--font-heavy);
  color: var(--border);
  margin-bottom: var(--spacing-md);
  line-height: 1;
}

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

.point-desc {
  color: var(--text-secondary);
  font-size: 15px;
  line-height: var(--line-height-relaxed);
}

/* ========== Topic ========== */

.topic {
  margin-bottom: var(--spacing-2xl);
}

/* ========== Topic Header ========== */

.topic-header {
  display: flex;
  align-items: flex-start;
  gap: var(--spacing-xl);
  margin-bottom: var(--spacing-xl);
}

.topic-number {
  font-size: var(--font-size-number);
  font-weight: var(--font-heavy);
  line-height: 1;
  background: var(--gradient-number);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  flex-shrink: 0;
}

.topic-info {
  flex: 1;
  padding-top: var(--spacing-md);
}

.topic-title {
  font-size: var(--font-size-topic);
  font-weight: var(--font-heavy);
  letter-spacing: var(--letter-spacing-normal);
  margin-bottom: var(--spacing-md);
  line-height: var(--line-height-normal);
}

.topic-timestamp {
  display: inline-block;
  padding: 6px var(--spacing-sm);
  background: var(--bg-card);
  border: var(--border-thin) solid var(--border);
  border-radius: var(--radius-sm);
  font-size: 13px;
  font-family: var(--font-mono);
  color: var(--accent-cyan);
}

/* ========== Topic Content ========== */

.topic-content {
  background: var(--bg-card);
  border: var(--border-thin) solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--card-padding);
  margin-left: clamp(40px, 10vw, 120px);
}

@media (max-width: 768px) {
  .topic-content {
    margin-left: 0;
  }
}

.topic-section-title {
  font-size: var(--font-size-small);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wider);
  font-weight: var(--font-weight-bold);
  margin-bottom: var(--spacing-md);
  color: var(--accent-orange);
}

.topic-core-point {
  font-size: var(--font-size-body);
  color: var(--text-primary);
  line-height: var(--line-height-relaxed);
  margin-bottom: var(--spacing-2xl);
  font-weight: var(--font-weight-normal);
}

/* ========== Topic Detail ========== */

.topic-detail {
  padding-left: var(--spacing-lg);
  border-left: var(--border-medium) solid var(--border);
  margin-bottom: var(--spacing-lg);
}

.topic-detail-label {
  font-weight: var(--font-weight-semibold);
  color: var(--text-secondary);
  margin-bottom: var(--spacing-sm);
}

.topic-detail-content {
  color: var(--text-tertiary);
  line-height: var(--line-height-relaxed);
}

/* ========== Quote Block ========== */

.quote-block {
  border-left: var(--border-thick) solid var(--accent-orange);
  padding: var(--spacing-lg);
  background: var(--quote-bg);
  margin: var(--spacing-lg) 0;
  font-style: italic;
  font-size: 17px;
  color: var(--text-primary);
}

/* ========== Thought Block ========== */

.thought-block {
  background: var(--bg-card);
  border: var(--border-thin) solid var(--border);
  padding: var(--spacing-lg);
  border-radius: var(--radius-md);
  margin: var(--spacing-lg) 0;
}

.thought-label {
  font-size: var(--font-size-tiny);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wider);
  color: var(--text-tertiary);
  margin-bottom: var(--spacing-sm);
}

/* ========== Takeaways ========== */

.takeaways-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: var(--spacing-lg);
}

.takeaway-card {
  background: var(--bg-card);
  border: var(--border-thin) solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--spacing-xl);
  transition: all var(--transition-fast);
}

.takeaway-card:hover {
  border-color: var(--accent-cyan);
  transform: var(--hover-lift);
}

.takeaway-emoji {
  font-size: 40px;
  margin-bottom: var(--spacing-md);
}

.takeaway-title {
  font-size: var(--font-size-body);
  font-weight: var(--font-weight-bold);
  margin-bottom: var(--spacing-sm);
}

.takeaway-desc {
  color: var(--text-secondary);
  font-size: 14px;
  line-height: var(--line-height-relaxed);
}

/* ========== Footer ========== */

.footer {
  border-top: var(--border-thin) solid var(--border);
  padding: var(--section-padding-vertical) 0;
  text-align: center;
}

.footer-title {
  font-size: var(--font-size-body);
  font-weight: var(--font-heavy);
  margin-bottom: var(--spacing-md);
}

.footer-desc {
  color: var(--text-secondary);
  max-width: 600px;
  margin: 0 auto var(--spacing-xl);
  line-height: var(--line-height-relaxed);
}

.footer-quote {
  font-size: clamp(28px, 5vw, 48px);
  font-weight: var(--font-heavy);
  background: var(--gradient-accent);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin: var(--spacing-2xl) 0;
  line-height: var(--line-height-normal);
}

.footer-note {
  color: var(--text-tertiary);
  font-size: 14px;
  max-width: 600px;
  margin: 0 auto;
  line-height: var(--line-height-relaxed);
}

/* ========== Divider ========== */

.divider {
  height: var(--border-thin);
  background: var(--border);
  margin: 0;
}

/* ========== Animations ========== */

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.animate-in {
  animation: fadeInUp var(--transition-normal) ease forwards;
  opacity: 0;
}

.delay-1 { animation-delay: var(--delay-1); }
.delay-2 { animation-delay: var(--delay-2); }
.delay-3 { animation-delay: var(--delay-3); }
.delay-4 { animation-delay: var(--delay-4); }
