/**
 * 好奇星人测试 H5 — 结构层布局（容器查询 + 版心）
 *
 * 与 tokens.css 配套：测试流选项随「内容栏宽度」变体。
 * 首页卡片宽度用 clamp + 视口，避免窄屏过挤、宽屏过小「浮岛」。
 */

/* ---------- 测试流：版心 + 容器 ---------- */
.page-with-nav > .flow-test-body {
  container-type: inline-size;
  container-name: flow;
  width: min(100%, var(--flow-shell));
  max-width: var(--h5-content-max);
  margin-left: auto;
  margin-right: auto;
  box-sizing: border-box;
}

.warmup-main,
.test-main {
  container-type: inline-size;
  container-name: card;
}

/* 内容栏较宽时才双列：手机单列优先，首屏尽量露出更多选项 */
@container flow (min-width: 36rem) {
  .warmup-options,
  .test-options {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--space-lg);
    align-items: stretch;
  }

  .warmup-option,
  .test-option {
    min-height: 0;
  }
}

@container flow (min-width: 44rem) {
  .warmup-options,
  .test-options {
    gap: var(--space-xl);
  }
}

/* 先行题：题干区略收紧，把纵向留给选项 + 底栏 */
.warmup-flow-page .warmup-scroll .warmup-q-hud {
  padding: var(--space-lg) var(--space-xl) var(--space-lg);
  margin-bottom: var(--space-md);
}

.warmup-flow-page .warmup-scroll .warmup-q-hud--year {
  padding: var(--space-xl) var(--space-xl) var(--space-lg);
  margin-bottom: var(--space-md);
}

.warmup-flow-page .warmup-ascii-scene--flow {
  max-height: min(10dvh, 4.5rem);
  margin-bottom: var(--space-xs);
}

/* 底栏贴 flex 底：短内容不悬空；长内容仅中间 warmup-scroll 滚动 */
.warmup-flow-page .warmup-footer-cta {
  flex-shrink: 0;
  margin-top: auto;
  padding-top: var(--space-md);
  padding-bottom: max(env(safe-area-inset-bottom, 0px), 10px);
}

.test-flow-page .test-main-dock {
  flex-shrink: 0;
  margin-top: auto;
  padding-top: var(--space-md);
  padding-bottom: max(env(safe-area-inset-bottom, 0px), 10px);
}

.test-flow-page .test-scroll .test-q-hud {
  padding: var(--space-lg) var(--space-xl) var(--space-lg);
  margin-bottom: var(--space-md);
}

.test-flow-page .test-ascii-scene--flow {
  max-height: min(10dvh, 4.5rem);
  margin-bottom: var(--space-xs);
}

@supports not (container-type: inline-size) {
  @media (min-width: 36rem) {
    .warmup-options,
    .test-options {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: var(--space-lg);
      align-items: stretch;
    }
  }
}

/* ---------- 游乐场起始页：护照壳内的 .ppc-play-card（容器查询） ---------- */
#viewIntro.passport-intro-view {
  container-type: inline-size;
  container-name: intro;
}

/*
 * 宽度：下限 ≈ 小屏可读，中间随视口变宽，上限 40rem，避免桌面「过小卡片」。
 * 始终单列：Logo → ASCII → 文案 → 按钮，避免侧栏挤压导致竖排错觉。
 */
#viewIntro.passport-intro-view .ppc-play-card {
  /* 与测试流一致：以手机内容宽为上限，避免桌面过宽 */
  width: min(100%, min(92vw, 100%), var(--h5-content-max));
  max-width: var(--h5-content-max);
  margin-left: auto;
  margin-right: auto;
  box-sizing: border-box;
  padding: clamp(0.85rem, 2.8vw, 1.75rem) clamp(0.85rem, 3.2vw, 1.5rem) clamp(0.75rem, 2.5vw, 1.35rem);
  border-radius: clamp(0.875rem, 2vw, 1.5rem);
  max-height: min(88dvh, 100%);
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

#viewIntro.passport-intro-view .trm-brand-block {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  width: 100%;
  gap: var(--space-sm);
}

#viewIntro.passport-intro-view .trm-logo {
  display: block;
  flex-shrink: 0;
  width: 100%;
  max-width: min(20rem, 100%);
  margin-left: auto;
  margin-right: auto;
  overflow: hidden;
}

#viewIntro.passport-intro-view #trmAsciiStage.trm-ascii-stage {
  width: 100%;
  max-width: min(22rem, 100%);
  height: clamp(4.25rem, 22dvh, 7rem);
  margin-left: auto;
  margin-right: auto;
  margin-top: 0;
  flex-shrink: 0;
}

#viewIntro.passport-intro-view .trm-sub {
  writing-mode: horizontal-tb;
  text-orientation: mixed;
  width: 100%;
  max-width: 22em;
  margin-left: auto;
  margin-right: auto;
  margin-top: 0;
  text-align: center;
  word-break: normal;
  overflow-wrap: break-word;
  font-size: var(--fs-lead);
  line-height: 1.55;
}

#viewIntro.passport-intro-view .trm-btn {
  height: clamp(2.75rem, 10vw, 3.25rem);
  line-height: clamp(2.75rem, 10vw, 3.25rem);
  font-size: var(--fs-body);
  border-radius: 999px;
}

#viewIntro.passport-intro-view .trm-btn--primary {
  margin-top: var(--space-md);
}

#viewIntro.passport-intro-view .trm-btn--multiline {
  height: auto;
  min-height: clamp(2.75rem, 10vw, 3.25rem);
  line-height: 1.35;
  padding: 0.55rem 0.85rem;
  white-space: normal;
  font-size: clamp(0.8125rem, 3.6vw, 0.9375rem);
}

#viewIntro.passport-intro-view .trm-footer {
  margin-top: var(--space-lg);
  font-size: var(--fs-caption);
}

#viewIntro.passport-intro-view .trm-link-last {
  font-size: var(--fs-body);
}

@container intro (min-width: 34rem) {
  #viewIntro.passport-intro-view .ppc-play-card {
    padding: clamp(1.5rem, 2.8vw, 2.75rem) clamp(1.35rem, 3.2vw, 2.5rem) clamp(1.25rem, 2.6vw, 2.25rem);
  }

  #viewIntro.passport-intro-view #trmAsciiStage.trm-ascii-stage {
    height: clamp(7rem, 18cqi + 4rem, 10rem);
    max-width: min(24rem, 100%);
  }
}

@container intro (min-width: 48rem) {
  #viewIntro.passport-intro-view .ppc-play-card {
    box-shadow: 0 1.25rem 3.5rem rgba(15, 23, 42, 0.1), inset 0 1px 0 rgba(255, 255, 255, 0.95),
      inset 0 -1px 0 rgba(148, 163, 184, 0.18);
  }

  #viewIntro.passport-intro-view .trm-logo {
    max-width: min(26rem, 100%);
  }
}
