/* ==========================================================================
   dc-life-sim · 手机端修复补丁
   问题：推演页 (.simulation-screen) 在 <=720px 宽度下被锁成一屏高度，
         角色信息撑满后时间线被挤成 0 高度，玩家看不到人生推演。
   策略：放弃单屏布局，改为整页自然流 + 可滚动，保证每块都有足够可视区。
   适用：编译后的 Pages 部署（源码回归后建议删除此文件，在 src/ 层处理）
   ========================================================================== */

@media (max-width: 720px) {
  /* 1. 解除 .simulation-screen 的一屏高度锁定，让整页可滚 */
  .simulation-screen {
    height: auto !important;
    min-height: auto !important;
    grid-template-rows: auto auto !important;
    gap: 16px !important;
  }

  /* 2. 把生平回放（timeline）挪到最上面，角色信息下移
        —— 手机上一进入推演页就直接看到时间线在滚动 */
  .simulation-screen .timeline-panel {
    order: -1 !important;
  }
  .simulation-screen .simulation-summary {
    order: 1 !important;
  }

  /* 3. 角色信息不再 sticky，保证它不挡住下面内容 */
  .simulation-summary {
    position: static !important;
    align-self: start !important;
  }

  /* 4. 时间线面板改为自然高度 + 足够最小高度，保证推演可见 */
  .timeline-panel {
    height: auto !important;
    min-height: 78vh !important;
    max-height: none !important;
    overflow: visible !important;
  }

  /* 5. 时间线内部滚动容器：让它自己成为独立可滚区 */
  .timeline-scroll {
    max-height: 70vh !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
  }

  /* 6. app-frame 在 simulation phase 去掉 padding-bottom 限制 */
  .app-frame.phase-simulation {
    min-height: auto !important;
    padding-bottom: 24px !important;
  }

  /* 7. body.phase-locked 保持原状（overflow:hidden）
        这是铸卡/结算动画锁定视图的 class，强制改 auto 会破坏动画 */

  /* 8. 角色属性面板紧凑化，节省垂直空间 */
  .simulation-summary .character-grid {
    grid-template-columns: 88px minmax(0, 1fr) !important;
    gap: 12px !important;
  }
  .portrait-medium {
    min-height: 120px !important;
  }
  .route-box {
    padding: 12px 14px !important;
    margin-top: 12px !important;
  }
}

/* ==========================================================================
   结算页 / 卡牌动画 手机适配
   ========================================================================== */
@media (max-width: 720px) {
  /* 结算页 hero 区域已在原 CSS 改为单列，这里补充内容不溢出 */
  .ending-screen {
    padding-bottom: 40px;
  }
  .ending-hero {
    gap: 18px !important;
  }
  .ending-hero h1 {
    font-size: clamp(1.8rem, 8vw, 2.6rem) !important;
  }

  /* 铸卡动画遮罩：手机上确保卡片居中、不被手机状态栏/Home 条遮挡 */
  .mint-overlay,
  .mint-ritual {
    padding: 20px 16px !important;
    box-sizing: border-box !important;
  }
  .mint-overlay .mint-card-wrapper,
  .mint-ritual .mint-card-wrapper {
    max-width: calc(100vw - 48px);
  }

  /* 缩小铸卡仪式里 large 尺寸卡牌，避免在小屏上超出视口 */
  .mint-ritual .tcg-card.size-large,
  .mint-overlay .tcg-card.size-large {
    width: min(280px, 80vw) !important;
  }
  .mint-ritual-seal {
    bottom: 24px !important;
  }
  .mint-ritual-hint {
    bottom: 8px !important;
    font-size: .6rem !important;
  }

  /* 结算页按钮栏：保证按钮换行、全宽、最小高度便于点击 */
  .ending-screen .control-stack,
  .ending-hero .control-stack,
  .ending-screen .hero-actions {
    flex-direction: column !important;
    width: 100% !important;
  }
  .ending-screen .primary-btn,
  .ending-screen .ghost-btn,
  .ending-screen .collection-btn-start {
    width: 100% !important;
    min-height: 52px !important;
  }

  /* 统计卡片在窄屏保持两列而非三列（原 CSS 已处理，这里确保） */
  .metric-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

/* 超窄屏（<=420px）再进一步压缩 */
@media (max-width: 420px) {
  .simulation-summary .character-grid {
    grid-template-columns: 1fr !important;
  }
  .portrait-medium {
    min-height: 160px !important;
  }
  .timeline-panel {
    min-height: 75vh !important;
  }
  .timeline-scroll {
    max-height: 70vh !important;
  }
}

/* ==========================================================================
   结局页顶部 浮动铸造 CTA（Finale Mint CTA）
   由 index.html 里的脚本动态创建，提升"铸造为卡牌"的优先级
   放在 .ending-screen 最顶部，即"最终归档"标题之上，引导玩家先铸造
   ========================================================================== */
.finale-mint-cta {
  position: relative;
  margin: 0 auto 24px;
  padding: 22px 26px;
  max-width: 760px;
  background:
    radial-gradient(120% 140% at 10% 0%, rgba(255, 215, 110, 0.18), transparent 60%),
    linear-gradient(145deg, rgba(22, 26, 38, 0.96), rgba(14, 18, 28, 0.98));
  border: 1.5px solid rgba(255, 195, 90, 0.55);
  border-radius: 20px;
  box-shadow:
    0 10px 36px -6px rgba(255, 170, 50, 0.32),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
  overflow: hidden;
  animation: finale-cta-enter 0.7s cubic-bezier(0.2, 0.9, 0.25, 1.05);
  isolation: isolate;
}

/* 旋转光环描边 */
.finale-mint-cta::before {
  content: "";
  position: absolute;
  inset: -2px;
  border-radius: inherit;
  padding: 2px;
  background: conic-gradient(
    from 0deg,
    transparent 0%,
    rgba(255, 200, 80, 0.95) 22%,
    transparent 45%,
    rgba(120, 200, 255, 0.85) 70%,
    transparent 95%
  );
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  animation: finale-cta-spin 4.5s linear infinite;
  pointer-events: none;
  z-index: 0;
  opacity: 0.75;
}

/* 中心呼吸光晕 */
.finale-mint-cta__aura {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 180%;
  height: 200%;
  transform: translate(-50%, -50%);
  background: radial-gradient(closest-side, rgba(255, 180, 60, 0.22), transparent 70%);
  animation: finale-cta-breath 3s ease-in-out infinite;
  pointer-events: none;
  z-index: 0;
}

.finale-mint-cta__body {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  text-align: center;
}

.finale-mint-cta__kicker {
  font-family: "Orbitron", "JetBrains Mono", monospace;
  font-size: 0.72rem;
  letter-spacing: 0.32em;
  color: rgba(255, 210, 130, 0.88);
  text-transform: uppercase;
}

.finale-mint-cta__title {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-size: 1.38rem;
  font-weight: 800;
  color: #ffe8b5;
  text-shadow: 0 0 20px rgba(255, 180, 60, 0.5);
  line-height: 1.3;
}

.finale-mint-cta__star {
  color: #ffd36f;
  font-size: 0.9em;
  animation: finale-cta-star 1.8s ease-in-out infinite;
}
.finale-mint-cta__star:last-child { animation-delay: 0.6s; }

.finale-mint-cta__hint {
  font-size: 0.78rem;
  color: rgba(240, 220, 190, 0.68);
  letter-spacing: 0.05em;
}

.finale-mint-cta__btn {
  position: relative;
  margin-top: 10px;
  padding: 13px 34px;
  min-height: 50px;
  border: none;
  border-radius: 999px;
  background: linear-gradient(120deg, #ffba3e 0%, #ff8d3c 55%, #ff5e56 100%);
  color: #1b0f05;
  font-weight: 900;
  font-size: 1.02rem;
  letter-spacing: 0.08em;
  cursor: pointer;
  overflow: hidden;
  box-shadow:
    0 8px 26px -4px rgba(255, 140, 50, 0.65),
    inset 0 1px 0 rgba(255, 255, 255, 0.55);
  animation: finale-cta-pulse 1.6s ease-in-out infinite;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.finale-mint-cta__btn:hover:not(:disabled) {
  transform: translateY(-2px) scale(1.035);
  box-shadow:
    0 14px 32px -4px rgba(255, 140, 50, 0.8),
    inset 0 1px 0 rgba(255, 255, 255, 0.7);
}
.finale-mint-cta__btn:disabled {
  cursor: default;
  opacity: 0.92;
  animation: none;
  background: linear-gradient(120deg, #3f8f6a 0%, #2c8a5b 100%);
  color: #e6fbf0;
  box-shadow: 0 5px 16px -4px rgba(40, 140, 85, 0.55);
}

/* 按钮高光扫过 */
.finale-mint-cta__btn-spark {
  position: absolute;
  inset: 0;
  background: linear-gradient(100deg, transparent 35%, rgba(255, 255, 255, 0.7) 50%, transparent 65%);
  transform: translateX(-120%);
  animation: finale-cta-shimmer 2.4s ease-in-out infinite;
  pointer-events: none;
}
.finale-mint-cta__btn-label { position: relative; z-index: 1; }
.finale-mint-cta__btn-arrow {
  position: relative;
  z-index: 1;
  font-size: 1.1em;
  display: inline-block;
  animation: finale-cta-arrow 1.2s ease-in-out infinite;
}
.finale-mint-cta__btn:disabled .finale-mint-cta__btn-spark,
.finale-mint-cta__btn:disabled .finale-mint-cta__btn-arrow {
  display: none;
}

/* "前往我的卡册"次按钮，仅已铸造时显示 */
.finale-mint-cta__collection {
  margin-top: 2px;
  padding: 8px 18px;
  background: transparent;
  border: 1px solid rgba(180, 220, 255, 0.32);
  border-radius: 999px;
  color: rgba(200, 225, 255, 0.82);
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  cursor: pointer;
  display: none;
  transition: all 0.2s ease;
}
.finale-mint-cta__collection:hover {
  background: rgba(120, 180, 255, 0.15);
  border-color: rgba(180, 220, 255, 0.65);
  color: #e6f3ff;
  transform: translateY(-1px);
}
.finale-mint-cta.is-minted .finale-mint-cta__collection {
  display: inline-block;
}

/* 已铸造态：整体转绿色，动效减弱 */
.finale-mint-cta.is-minted {
  border-color: rgba(120, 220, 150, 0.55);
  box-shadow: 0 10px 32px -8px rgba(60, 180, 100, 0.32);
}
.finale-mint-cta.is-minted .finale-mint-cta__kicker,
.finale-mint-cta.is-minted .finale-mint-cta__title {
  color: #c5f5d4;
}
.finale-mint-cta.is-minted .finale-mint-cta__title {
  text-shadow: 0 0 18px rgba(100, 220, 140, 0.42);
}
.finale-mint-cta.is-minted .finale-mint-cta__star {
  color: #86e9a5;
}
.finale-mint-cta.is-minted::before {
  animation-duration: 9s;
  opacity: 0.4;
}
.finale-mint-cta.is-minted .finale-mint-cta__aura {
  background: radial-gradient(closest-side, rgba(80, 200, 130, 0.2), transparent 70%);
}

/* Keyframes */
@keyframes finale-cta-enter {
  0%   { opacity: 0; transform: translateY(-18px) scale(0.95); }
  55%  { opacity: 1; transform: translateY(4px) scale(1.018); }
  100% { opacity: 1; transform: translateY(0)  scale(1); }
}
@keyframes finale-cta-spin {
  to { transform: rotate(360deg); }
}
@keyframes finale-cta-breath {
  0%, 100% { opacity: 0.55; transform: translate(-50%, -50%) scale(1); }
  50%      { opacity: 1;    transform: translate(-50%, -50%) scale(1.1); }
}
@keyframes finale-cta-pulse {
  0%, 100% {
    transform: scale(1);
    box-shadow:
      0 8px 26px -4px rgba(255, 140, 50, 0.65),
      inset 0 1px 0 rgba(255, 255, 255, 0.55);
  }
  50% {
    transform: scale(1.04);
    box-shadow:
      0 14px 36px -2px rgba(255, 140, 50, 0.92),
      inset 0 1px 0 rgba(255, 255, 255, 0.7),
      0 0 0 7px rgba(255, 180, 60, 0.14);
  }
}
@keyframes finale-cta-shimmer {
  0%   { transform: translateX(-120%); }
  45%  { transform: translateX(120%); }
  100% { transform: translateX(120%); }
}
@keyframes finale-cta-arrow {
  0%, 100% { transform: translateX(0);   opacity: 1; }
  50%      { transform: translateX(6px); opacity: 0.5; }
}
@keyframes finale-cta-star {
  0%, 100% { transform: scale(1) rotate(0deg);    opacity: 0.85; }
  50%      { transform: scale(1.35) rotate(180deg); opacity: 1; }
}

/* 手机端 */
@media (max-width: 560px) {
  .finale-mint-cta {
    padding: 18px 14px;
    margin-bottom: 18px;
    border-radius: 16px;
  }
  .finale-mint-cta__kicker {
    font-size: 0.64rem;
    letter-spacing: 0.26em;
  }
  .finale-mint-cta__title {
    font-size: 1.06rem;
    flex-wrap: wrap;
    justify-content: center;
    gap: 8px;
  }
  .finale-mint-cta__hint {
    font-size: 0.72rem;
  }
  .finale-mint-cta__btn {
    width: 100%;
    padding: 14px 18px;
    font-size: 0.95rem;
    justify-content: center;
  }
}

/* 尊重用户减弱动效偏好 */
@media (prefers-reduced-motion: reduce) {
  .finale-mint-cta,
  .finale-mint-cta::before,
  .finale-mint-cta__aura,
  .finale-mint-cta__btn,
  .finale-mint-cta__btn-spark,
  .finale-mint-cta__btn-arrow,
  .finale-mint-cta__star {
    animation: none !important;
  }
}
