/* ========================================
   响应式设计 - Responsive Styles
   ======================================== */

/* ========== 平板设备 (768px - 1023px) ========== */
@media (max-width: 1023px) {
  /* 字体大小调整 */
  .hero-title {
    font-size: var(--font-size-3xl);
  }

  .title-highlight {
    font-size: var(--font-size-3xl);
  }

  .section-title {
    font-size: var(--font-size-2xl);
  }

  /* 时间轴调整 */
  .timeline::before {
    left: 30px;
  }

  .timeline-item {
    padding-left: 70px;
    padding-right: 0;
  }

  .timeline-item:nth-child(odd) .timeline-content,
  .timeline-item:nth-child(even) .timeline-content {
    width: 100%;
    text-align: left;
    margin: 0;
  }

  .timeline-marker {
    left: 30px;
    transform: translateX(-50%);
  }

  /* 互动网格调整 */
  .interactive-grid {
    grid-template-columns: 1fr;
  }

  /* 角色网格调整 */
  .characters-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  /* 画廊网格调整 */
  .gallery-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* ========== 手机设备 (最大 767px) ========== */
@media (max-width: 767px) {
  /* 导航栏调整 */
  .hamburger {
    display: flex;
  }

  .nav-menu {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    flex-direction: column;
    background: var(--color-white);
    box-shadow: var(--shadow-card);
    padding: var(--spacing-md);
    gap: var(--spacing-sm);
    display: none;
    opacity: 0;
    transform: translateY(-10px);
    transition: all var(--transition-base) var(--ease-out);
  }

  .nav-menu.active {
    display: flex;
    opacity: 1;
    transform: translateY(0);
  }

  .nav-link {
    padding: var(--spacing-sm);
    border-radius: var(--radius-sm);
  }

  .nav-link::after {
    display: none;
  }

  .nav-link:hover,
  .nav-link.active {
    background: var(--color-primary-pink);
    color: var(--color-white);
  }

  /* Hero区域调整 */
  .hero-section {
    padding: var(--spacing-2xl) var(--spacing-md);
    min-height: auto;
  }

  .hero-title {
    font-size: var(--font-size-2xl);
  }

  .title-highlight {
    font-size: var(--font-size-2xl);
  }

  .hero-subtitle {
    font-size: var(--font-size-base);
  }

  .cta-button {
    padding: var(--spacing-sm) var(--spacing-lg);
    font-size: var(--font-size-base);
  }

  /* Section通用调整 */
  section {
    padding: var(--spacing-xl) 0;
  }

  .section-title {
    font-size: var(--font-size-xl);
  }

  .section-subtitle {
    font-size: var(--font-size-base);
  }

  /* 角色网格 */
  .characters-grid {
    grid-template-columns: 1fr;
    gap: var(--spacing-md);
  }

  .character-image {
    height: 250px;
  }

  .character-placeholder {
    font-size: 5rem;
  }

  /* 时间轴调整 */
  .timeline {
    padding: var(--spacing-md) 0;
  }

  .timeline-item {
    margin-bottom: var(--spacing-lg);
  }

  .timeline-content {
    padding: var(--spacing-md);
  }

  /* 画廊调整 */
  .gallery-filter {
    gap: var(--spacing-xs);
  }

  .filter-button {
    padding: var(--spacing-xs) var(--spacing-md);
    font-size: var(--font-size-sm);
  }

  .gallery-grid {
    grid-template-columns: 1fr;
    gap: var(--spacing-sm);
  }

  /* 灯箱调整 */
  .lightbox-close,
  .lightbox-prev,
  .lightbox-next {
    width: 40px;
    height: 40px;
    font-size: var(--font-size-2xl);
  }

  .lightbox-close {
    top: var(--spacing-sm);
    right: var(--spacing-sm);
  }

  .lightbox-prev {
    left: var(--spacing-sm);
  }

  .lightbox-next {
    right: var(--spacing-sm);
  }

  .lightbox-image-wrapper {
    min-width: 200px;
    min-height: 200px;
    font-size: 4rem;
    padding: var(--spacing-lg);
  }

  .lightbox-caption {
    font-size: var(--font-size-base);
  }

  /* 互动区域调整 */
  .wishing-tree {
    height: 300px;
  }

  .magic-circle-wrapper {
    width: 250px;
    height: 250px;
  }

  .wish-input-container {
    flex-direction: column;
  }

  .wish-button {
    width: 100%;
  }

  /* Footer调整 */
  .footer-content {
    grid-template-columns: 1fr;
    gap: var(--spacing-lg);
  }

  /* 容器调整 */
  .container {
    padding: 0 var(--spacing-sm);
  }
}

/* ========== 大屏设备 (1280px+) ========== */
@media (min-width: 1280px) {
  /* 角色网格 */
  .characters-grid {
    grid-template-columns: repeat(4, 1fr);
  }

  /* 画廊网格 */
  .gallery-grid {
    grid-template-columns: repeat(4, 1fr);
  }

  /* Hero标题 */
  .hero-title {
    font-size: 5rem;
  }

  .title-highlight {
    font-size: 5rem;
  }
}

/* ========== 超大屏设备 (1920px+) ========== */
@media (min-width: 1920px) {
  /* 容器最大宽度 */
  .container {
    max-width: 1400px;
  }

  /* Hero区域 */
  .hero-title {
    font-size: 6rem;
  }

  .title-highlight {
    font-size: 6rem;
  }

  /* Section标题 */
  .section-title {
    font-size: var(--font-size-4xl);
  }
}

/* ========== 横屏手机优化 ========== */
@media (max-width: 767px) and (orientation: landscape) {
  .hero-section {
    min-height: auto;
    padding: var(--spacing-lg) var(--spacing-md);
  }

  .wishing-tree {
    height: 250px;
  }

  .magic-circle-wrapper {
    width: 200px;
    height: 200px;
  }
}

/* ========== 打印样式 ========== */
@media print {
  .sticky-header,
  .scroll-indicator,
  .interactive-section,
  .lightbox {
    display: none !important;
  }

  body {
    background: var(--color-white);
  }

  .hero-section {
    min-height: auto;
    padding: var(--spacing-lg);
  }

  section {
    page-break-inside: avoid;
  }

  .character-card,
  .gallery-item {
    page-break-inside: avoid;
    break-inside: avoid;
  }
}

/* ========== 可访问性：减少动画 ========== */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

/* ========== 高对比度模式 ========== */
@media (prefers-contrast: high) {
  :root {
    --color-text: #000000;
    --color-border: #000000;
  }

  .character-card,
  .card,
  .timeline-content {
    border: 2px solid var(--color-text);
  }
}

/* ========== 深色模式支持（可选） ========== */
@media (prefers-color-scheme: dark) {
  /* 可以在这里添加深色模式样式 */
  /* 当前设计以浅色为主，如需深色模式可在此扩展 */
}
