html,
body {
  margin: 0;
  width: var(--design-width);
  height: var(--design-height);
  background: #f4f4f4;
  overflow-x: hidden;
  overscroll-behavior-x: none;
}

:root {
  /* 与下方 html[data-fold-mode] 联动；JS 会设置 data-fold-mode */
  --design-base-width: 750;
  --design-base-height: 1448;

  /* page1 */
  --home-image-width-scale: 0.8;
  --rotating-image-width-scale: 0.1;
  --rotating-image-margin-top-scale: 0.1;

  /* page2 */
  --p2-return-width: 56;
  --p2-return-left: 36;
  --p2-return-top: 32;

  --p2-icon-width: 260;
  --p2-icon-top: 120;

  --p2-green-width: 240.5;
  --p2-green-right: 0;
  --p2-green-top: 200;

  --p2-yellow-width: 146.5;
  --p2-yellow-left: 0;
  --p2-yellow-top: 410;

  --p2-blue-width: 346;
  --p2-blue-right: 0;
  --p2-blue-top: 835;

  --p2-red-width: 382;
  --p2-red-left: 0;
  --p2-red-bottom: 0;

  --p2-heatmap-width: 529;
  --p2-heatmap-top: 293;
  --p2-heatmap-margin-top: 100;
  --p2-marker-6-left: 72;
  --p2-marker-6-width: 85;

  --p2-ranking-width: 529;
  --p2-ranking-top: 533;
  --p2-ranking-margin-top: 36;
  --p2-marker-5-left: 72;
  --p2-marker-5-width: 85;

  --p2-easter-width: 529;
  --p2-easter-top: 771;
  --p2-easter-margin-top: 36;
  --p2-marker-4-left: 62;
  --p2-marker-4-width: 92;
  --p2-flow-offset-x: 0;

  /* page3 热力图装饰（page2-green1/2/3，右-左-右） */
  --p3-green1-width: 158.5;
  --p3-green1-right: 0;
  --p3-green1-top: 200;
  --p3-green2-width: 181.5;
  --p3-green2-left: 0;
  --p3-green2-top: 380;
  --p3-green3-width: 242.5;
  --p3-green3-right: 0;
  --p3-green3-bottom: 0;
  --p3-map-left: 60;
  --p3-map-top: 120;
  --p3-map-width: 630;
  --p3-map-height: 1220;
  --p3-map-radius: 48;
  --p3-map-rotate-deg: 0deg;
  --p3-tip-width: 549;

  /* page5（留空占位，后续你自行填写） */
  --p5-icon-width: 750;
  --p5-icon-left: 450;
  --p5-icon-top: 120;
  --p5-icon-offset-x: -80;
  /* page5 地图点位参数：默认值=当前页面表现（相对 .page5-map-wrapper 百分比坐标） */
  --p5-map-point-68-left: 49;
  --p5-map-point-68-top: 57.5;
  --p5-map-point-68-width: 28;
  --p5-map-point-69-left: 54;
  --p5-map-point-69-top: 42;
  --p5-map-point-69-width: 185.5;
  --p5-map-point-70-left: 80;
  --p5-map-point-70-top: 55;
  --p5-map-point-70-width: 148.5;
  --p5-map-point-71-left: 30;
  --p5-map-point-71-top: 60;
  --p5-map-point-71-width: 148.5;
  --p5-map-point-72-left: 77;
  --p5-map-point-72-top: 23;
  --p5-map-point-72-width: 117.5;
  --p5-map-point-73-left: 72;
  --p5-map-point-73-top: 42;
  --p5-map-point-73-width: 23;
  --p5-map-point-74-left: 27;
  --p5-map-point-74-top: 27;
  --p5-map-point-74-width: 160.5;
  --p5-entry-gap: 10;
  --p5-entry-title-size: 32;
  --p5-entry-subtitle-size: 16;
  --p5-entry-subtitle-margin-top: 4;
  --p3-entry-left: 112;
  --p3-entry-top: 28;
  --p3-entry-width: 600;
  --p3-entry-gap: 10;
  --p4-entry-left: 112;
  --p4-entry-top: 28;
  --p4-entry-width: 600;
  --p4-entry-gap: 10;
  --p5-entry-left: 112;
  --p5-entry-top: 35;
  --p5-entry-width: 600;
  --p5-title-icon-width: 66;
  --p5-card-height-ratio: 191;
  /* 与 page5-map-wrapper 内地图一致：设计稿 750×533 */
  --p5-map-design-w: 750;
  --p5-map-design-h: 533;
  /**
   * 热力图顶边相对「地图顶」的垂直偏移，单位为地图稿高度方向 0～533（与点位 top 同一套）。
   * 实际像素 = 地图显示高度 × (本值 / 533)，等价于下列第二项。
   * 原全页 --p5-heatmap-top:650（1448 稿）在常见宽度下约对应 275，可按效果微调。
   */
  --p5-heatmap-top-from-map: 500;
  --p5-heatmap-width: 728;
  --p5-heatmap-left: 392;
  --p5-heatmap-offset-x: -20;
  /* 与 .page5-map-wrapper 同一参照：顶 = 地图顶 + 地图坐标系内下移 */
  --p5-heatmap-top-px: calc(
    calc(var(--design-height) / var(--design-base-height) * var(--p5-icon-top)) +
    calc(
      var(--design-width) / var(--design-base-width) * var(--p5-icon-width) * var(--p5-heatmap-top-from-map) / var(--p5-map-design-w)
    )
  );
  --p5-marker-6-left: 65;
  --p5-marker-6-width: 70;
  --p5-ranking-width: 728;
  --p5-ranking-left: 392;
  --p5-ranking-offset-x: -20;
  --p5-marker-5-left: 65;
  --p5-marker-5-width: 70;
  --p5-easter-width: 728;
  --p5-easter-left: 392;
  --p5-easter-offset-x: -20;
  --p5-ranking-easter-gap: -20;
  --p5-marker-4-left: 65;
  --p5-marker-4-width: 70;
  --p5-yellow-width: 154;
  --p5-yellow-left: 0;
  --p5-yellow-top: 70;
  --p5-blue-width: 200;
  --p5-blue-left: 0;
  --p5-blue-top: 870;
  --p5-green-width: 246.5;
  --p5-green-left: 0;
  --p5-green-top: 0;

  /* page6 */
  --p6-bg-width: 672;
  --p6-bg-left: 39;
  --p6-bg-top: 120;
  --p6-input-gap-top: 20;
  --p6-input-width: 672;
  --p6-input-shell-height: 100;
  --p6-input-shell-radius: 375;
  --p6-input-inner-gap: 12;
  --p6-input-inner-radius: 375;
  --p6-input-font-size: 28;
  --p6-input-padding-x: 28;
  --p6-action-gap-top: 20;
  --p6-send-width: 200;
  --p6-send-height: 72;
  --p6-send-radius: 36;
  --p6-send-font-size: 28;
  --p6-suggestion-gap: 18;
  --p6-suggestion-item-height: 64;
  --p6-suggestion-item-radius: 48;
  --p6-suggestion-font-size: 28;
  --p6-suggestion-padding-x: 26;
  --p6-suggestion-panel-radius: 24;
  --p6-suggestion-panel-padding-x: 30;
  --p6-suggestion-panel-padding-y: 30;
  --p6-suggestion-panel-blur: 16;
  --p6-danmu-font-size: 30;
  --p6-danmu-color: #111111;
  --p6-danmu-shadow-alpha: 0.35;
  --p6-danmu-bg: #ffe500;
  --p6-danmu-radius: 999;
  --p6-danmu-padding-x: 20;
  --p6-danmu-padding-y: 10;
  --p6-danmu-tail-width: 16;
  --p6-danmu-tail-height: 20;
  --p6-danmu-emoji-size: 120;
  --p6-danmu-emoji-gap: -10;

  /* page4 */
  --p4-red-left: 0;
  --p4-red-top: 120;
  --p4-red-width: 670;
  --p4-red-height: 630;
  --p4-red-border-width: 3;
  --p4-red-radius: 48;
  --p4-red-col-left: 1fr;
  --p4-red-col-center: 1fr;
  --p4-red-col-right: 1fr;
  --p4-red-col-gap: 0;
  --p4-red-col-padding-x: 40;
  --p4-red-col-padding-y: 20;
  --p4-red-card-gap-bottom: 16;
  --p4-red-avatar-size: 120;
  --p4-red-avatar-main-size: 160;
  --p4-red-crown-size: 45;
  --p4-red-name-font: 24;
  --p4-red-name-main-font: 28;
  --p4-red-name-width: 160;
  --p4-red-name-main-width: 160;
  --p4-red-count-font: 24;
  --p4-red-count-main-font: 28;
  --p4-red-count-icon-size: 24;
  --p4-red-step-radius: 24;
  --p4-red-step-overlap-x: 2;
  --p4-frosted-left: 24;
  --p4-frosted-top: 700;
  --p4-frosted-width: 680;
  --p4-frosted-height: 700;
  --p4-frosted-radius: 48;
  --p4-corner-rt-width: 335;
  --p4-corner-rt-top: 0;
  --p4-corner-rt-right: 0;
  --p4-corner-lb-width: 296;
  --p4-corner-lb-left: 0;
  --p4-corner-lb-bottom: 0;
  --p4-yellow1-width: 271.5;
  --p4-yellow1-left: 0;
  --p4-yellow1-top: 70;
  --p4-yellow2-width: 283;
  --p4-yellow2-right: 0;
  --p4-yellow2-top: 520;
  --p4-yellow3-width: 232.5;
  --p4-yellow3-left: 0;
  --p4-yellow3-bottom: 0;
  --p4-panel-padding-top: 18;
  --p4-panel-padding-x: 16;
  --p4-panel-padding-bottom: 12;
  --p4-panel-header-height: 56;
  --p4-panel-header-radius: 10;
  --p4-panel-col-rank: 100;
  --p4-panel-col-name: 320;
  --p4-panel-col-count: 180;
  --p4-panel-col-gap-x: 20;
  --p4-panel-header-font: 30;
  --p4-header-rank-font: 24;
  --p4-header-name-font: 24;
  --p4-header-count-font: 24;
  --p4-header-count-offset-left: 4;
  --p4-panel-list-margin-top: 14;
  --p4-row-height: 120;
  --p4-row-margin-bottom: 24;
  --p4-row-radius: 100;
  --p4-row-first-border: 2;
  --p4-row-first-shadow-y: 6;
  --p4-row-first-shadow-blur: 14;
  --p4-row-rest-shadow-y: 4;
  --p4-row-rest-shadow-blur: 10;
  --p4-row-rest-border: 1;
  --p4-row-rank-font: 24;
  --p4-row-name-font: 28;
  --p4-row-count-font: 24;
  --p4-panel-footer-height: 48;
  --p4-panel-footer-margin-top: 8;
  --p4-panel-footer-radius: 8;
  --p4-panel-footer-font: 24;
  --p4-header-icon-size: 26;
  --p4-header-icon-gap: 8;
  --p4-row-rank-icon-size: 28;
  --p4-row-count-icon-size: 26;
  --p4-row-icon-gap: 8;
  --p4-col-gap-left-middle: 12;
  --p4-row-name-progress-gap: 10;
  --p4-row-progress-height: 12;
  --p4-row-progress-radius: 6;
  --p4-row-count-unit-gap: 6;
  --p4-row-count-unit-font: 24;

  /* float entry */
  --float-entry-bottom: 227;
  --float-entry-width: 157;
}

/* 单屏参数覆盖层（恢复入口）：按需覆盖上面的变量值 */
html[data-fold-mode="single"] {
  --fold-mode-name: single;
  --design-base-width: 750;
  --design-base-height: 1448;
}

/* 双折叠参数覆盖层（foldableDouble）：按需覆盖上面的变量值 */
html[data-fold-mode="dualFold"] {
  --fold-mode-name: foldableDouble;
  --design-base-width: 750;
  --design-base-height: 1448;
}

/* 三折叠参数覆盖层（foldableTriple）：按需覆盖上面的变量值 */
html[data-fold-mode="triFold"] {
  --fold-mode-name: foldableTriple;
  --design-base-width: 750;
  --design-base-height: 1448;
}

#app {
  width: var(--design-width);
  height: var(--design-height);
  position: relative;
  overflow: hidden;
}

.page {
  width: var(--design-width);
  height: var(--design-height);
  display: none;
  position: absolute;
  inset: 0;
  background: #f4f4f4;
}

.page.is-active {
  display: block;
}

/* page1 */

.page-home {
  display: none;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.page-home.is-active {
  display: flex;
}

.page-home.is-preloading {
  cursor: wait;
}

.home-image {
  width: calc(var(--design-width) * var(--home-image-width-scale));
  object-fit: contain;
  display: block;
}

.rotating-image {
  width: calc(var(--design-width) * var(--rotating-image-width-scale));
  margin-top: calc(var(--design-width) * var(--rotating-image-margin-top-scale));
  object-fit: contain;
  display: block;
  animation: spin-360 1s linear infinite;
  transform-origin: center center;
}

@keyframes spin-360 {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}




/* page2 */

.page2-return {
  position: absolute;
  width: calc(var(--design-width) / var(--design-base-width) * var(--p2-return-width));
  left: calc(var(--design-width) / var(--design-base-width) * var(--p2-return-left));
  top: calc(var(--design-height) / var(--design-base-height) * var(--p2-return-top));
  z-index: 9999;
}

.page2-icon {
  position: relative;
  width: calc(var(--design-width) / var(--design-base-width) * var(--p2-icon-width));
  left: auto;
  top: auto;
  transform: none;
  display: block;
}

.page2-green {
  position: absolute;
  width: calc(var(--design-width) / var(--design-base-width) * var(--p2-green-width));
  right: calc(var(--design-width) / var(--design-base-width) * var(--p2-green-right));
  top: calc(var(--design-height) / var(--design-base-height) * var(--p2-green-top));
}

.page2-yellow {
  position: absolute;
  width: calc(var(--design-width) / var(--design-base-width) * var(--p2-yellow-width));
  left: calc(var(--design-width) / var(--design-base-width) * var(--p2-yellow-left));
  top: calc(var(--design-height) / var(--design-base-height) * var(--p2-yellow-top));
}

.page2-blue {
  position: absolute;
  width: calc(var(--design-width) / var(--design-base-width) * var(--p2-blue-width));
  right: calc(var(--design-width) / var(--design-base-width) * var(--p2-blue-right));
  top: calc(var(--design-height) / var(--design-base-height) * var(--p2-blue-top));
}

.page2-red {
  position: absolute;
  width: calc(var(--design-width) / var(--design-base-width) * var(--p2-red-width));
  left: calc(var(--design-width) / var(--design-base-width) * var(--p2-red-left));
  bottom: calc(var(--design-height) / var(--design-base-height) * var(--p2-red-bottom));
}

.page2-flow {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-top: calc(var(--design-height) / var(--design-base-height) * var(--p2-icon-top));
  transform: translateX(calc(var(--design-width) / var(--design-base-width) * var(--p2-flow-offset-x)));
}

.page2-heatmap {
  position: relative;
  width: calc(var(--design-width) / var(--design-base-width) * var(--p2-heatmap-width));
  margin-top: calc(var(--design-height) / var(--design-base-height) * var(--p2-heatmap-margin-top));
  left: auto;
  top: auto;
  transform: none;
  cursor: pointer;
}

.page2-ranking {
  position: relative;
  width: calc(var(--design-width) / var(--design-base-width) * var(--p2-ranking-width));
  margin-top: calc(var(--design-height) / var(--design-base-height) * var(--p2-ranking-margin-top));
  left: auto;
  top: auto;
  transform: none;
  cursor: pointer;
}

.page2-easter {
  position: relative;
  width: calc(var(--design-width) / var(--design-base-width) * var(--p2-easter-width));
  margin-top: calc(var(--design-height) / var(--design-base-height) * var(--p2-easter-margin-top));
  left: auto;
  top: auto;
  transform: none;
  cursor: pointer;
}

.page2-heatmap-image,
.page2-ranking-image,
.page2-easter-image {
  width: 100%;
  display: block;
}

.page2-marker-6,
.page2-marker-5,
.page2-marker-4 {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}

.page2-marker-6 {
  left: calc(var(--design-width) / var(--design-base-width) * var(--p2-marker-6-left));
  width: calc(var(--design-width) / var(--design-base-width) * var(--p2-marker-6-width));
}

.page2-marker-5 {
  left: calc(var(--design-width) / var(--design-base-width) * var(--p2-marker-5-left));
  width: calc(var(--design-width) / var(--design-base-width) * var(--p2-marker-5-width));
}

.page2-marker-4 {
  left: calc(var(--design-width) / var(--design-base-width) * var(--p2-marker-4-left));
  width: calc(var(--design-width) / var(--design-base-width) * var(--p2-marker-4-width));
}

.page2-map {
  position: absolute;
  z-index: 1;
  left: calc(var(--design-width) / var(--design-base-width) * var(--p3-map-left));
  top: calc(var(--design-height) / var(--design-base-height) * var(--p3-map-top));
  width: calc(var(--design-width) / var(--design-base-width) * var(--p3-map-width));
  height: calc(var(--design-height) / var(--design-base-height) * var(--p3-map-height));
  border-radius: calc(var(--design-width) / var(--design-base-width) * var(--p3-map-radius));
  overflow: hidden;
  touch-action: none;
  transform-origin: center center;
  will-change: transform;
}

.page2-map-frame {
  position: absolute;
  left: 50%;
  top: 50%;
  width: calc(var(--design-width) / var(--design-base-width) * var(--p3-map-width));
  height: calc(var(--design-height) / var(--design-base-height) * var(--p3-map-height));
  border: 0;
  display: block;
  background: rgba(255, 255, 255, 0.65);
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
  transform: translate(-50%, -50%) rotate(var(--p3-map-rotate-deg));
  transform-origin: center center;
  pointer-events: none;
}

.page2-tip {
  position: fixed;
  z-index: 99999;
  left: 50%;
  top: 50%;
  width: calc(var(--design-width) / var(--design-base-width) * var(--p3-tip-width));
  transform: translate(-50%, -50%);
  display: block;
  opacity: 1;
  visibility: visible;
  will-change: transform, opacity;
  animation: page2-tip-breathe 3s ease-in-out infinite;
  transition: opacity 220ms ease, visibility 220ms ease;
}

.page2-tip.is-hidden {
  opacity: 0;
  visibility: hidden;
  animation: none;
  pointer-events: none;
}

@keyframes page2-tip-breathe {
  0% {
    transform: translate(-50%, -50%) scale(1);
  }
  50% {
    transform: translate(-50%, -50%) scale(0.92);
  }
  100% {
    transform: translate(-50%, -50%) scale(1);
  }
}

/* page3 热力图装饰背景（对应 index.html page2-green1/2/3） */
.page .page2-green1,
.page .page2-green2,
.page .page2-green3 {
  position: fixed;
  z-index: 0;
  display: block;
  pointer-events: none;
}

.page .page2-green1 {
  width: calc(var(--design-width) / var(--design-base-width) * var(--p3-green1-width));
  right: calc(var(--design-width) / var(--design-base-width) * var(--p3-green1-right));
  top: calc(var(--design-height) / var(--design-base-height) * var(--p3-green1-top));
  left: auto;
  bottom: auto;
}

.page .page2-green2 {
  width: calc(var(--design-width) / var(--design-base-width) * var(--p3-green2-width));
  left: calc(var(--design-width) / var(--design-base-width) * var(--p3-green2-left));
  top: calc(var(--design-height) / var(--design-base-height) * var(--p3-green2-top));
  right: auto;
  bottom: auto;
}

.page .page2-green3 {
  width: calc(var(--design-width) / var(--design-base-width) * var(--p3-green3-width));
  right: calc(var(--design-width) / var(--design-base-width) * var(--p3-green3-right));
  bottom: calc(var(--design-height) / var(--design-base-height) * var(--p3-green3-bottom));
  left: auto;
  top: auto;
}

/* page4 */
.page-four .page4-red-block {
  position: absolute;
  z-index: 1;
  left: 50%;
  top: calc(var(--design-height) / var(--design-base-height) * var(--p4-red-top));
  width: calc(var(--design-width) / var(--design-base-width) * var(--p4-red-width));
  min-height: calc(var(--design-height) / var(--design-base-height) * var(--p4-red-height));
  border: calc(var(--design-width) / var(--design-base-width) * var(--p4-red-border-width)) solid rgba(255, 255, 255, 0.6);
  border-radius: calc(var(--design-width) / var(--design-base-width) * var(--p4-red-radius));
  background: linear-gradient(180deg, #FF6E6E 0%, #F93530 100%);
  overflow: visible;
  display: flex;
  transform: translateX(-50%);
}

.page-four .page4-red-grid {
  width: 100%;
  flex: 1 0 auto;
  min-height: 100%;
  display: grid;
  grid-template-columns: minmax(0, var(--p4-red-col-left)) minmax(0, var(--p4-red-col-center)) minmax(0, var(--p4-red-col-right));
  column-gap: calc(var(--design-width) / var(--design-base-width) * var(--p4-red-col-gap));
  padding: calc(var(--design-height) / var(--design-base-height) * var(--p4-red-col-padding-y)) calc(var(--design-width) / var(--design-base-width) * var(--p4-red-col-padding-x));
  box-sizing: border-box;
}

.page-four .page4-red-col {
  min-height: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
}

.page-four .page4-podium-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: calc(var(--design-height) / var(--design-base-height) * var(--p4-red-card-gap-bottom));
}

.page-four .page4-podium-avatar {
  width: calc(var(--design-width) / var(--design-base-width) * var(--p4-red-avatar-size));
  height: calc(var(--design-width) / var(--design-base-width) * var(--p4-red-avatar-size));
  object-fit: contain;
}

.page-four .page4-podium-avatar-main {
  width: calc(var(--design-width) / var(--design-base-width) * var(--p4-red-avatar-main-size));
  height: calc(var(--design-width) / var(--design-base-width) * var(--p4-red-avatar-main-size));
}

.page-four .page4-podium-crown {
  width: calc(var(--design-width) / var(--design-base-width) * var(--p4-red-crown-size));
  height: calc(var(--design-width) / var(--design-base-width) * var(--p4-red-crown-size));
  object-fit: contain;
}

.page-four .page4-podium-name {
  margin-top: calc(var(--design-height) / var(--design-base-height) * 6);
  width: calc(var(--design-width) / var(--design-base-width) * var(--p4-red-name-width));
  color: #fff;
  font-family: 'HuaweiSans', 'FZLanTing', sans-serif;
  font-size: calc(var(--design-width) / var(--design-base-width) * var(--p4-red-name-font));
  font-weight: 500;
  text-align: center;
}

.page-four .page4-podium-name-main {
  width: calc(var(--design-width) / var(--design-base-width) * var(--p4-red-name-main-width));
  font-size: calc(var(--design-width) / var(--design-base-width) * var(--p4-red-name-main-font));
}

.page-four #page4-podium-name-1 {
  font-size: calc(var(--design-width) / var(--design-base-width) * var(--p4-red-name-main-font));
}

.page-four .page4-podium-count {
  margin-top: calc(var(--design-height) / var(--design-base-height) * 6);
  display: flex;
  align-items: center;
  gap: calc(var(--design-width) / var(--design-base-width) * 6);
  color: #fff;
  font-family: 'HuaweiSans', 'FZLanTing', sans-serif;
  font-size: calc(var(--design-width) / var(--design-base-width) * var(--p4-red-count-font));
}

.page-four .page4-podium-count-main {
  color: #ffe7e7;
}

.page-four #page4-podium-count-1 {
  color: #ffe7e7;
  font-size: calc(var(--design-width) / var(--design-base-width) * var(--p4-red-count-main-font));
}

.page-four .page4-podium-count-icon {
  width: calc(var(--design-width) / var(--design-base-width) * var(--p4-red-count-icon-size));
  height: calc(var(--design-width) / var(--design-base-width) * var(--p4-red-count-icon-size));
  object-fit: contain;
}

.page-four .page4-podium-step {
  width: calc(100% + calc(var(--design-width) / var(--design-base-width) * var(--p4-red-step-overlap-x) * 2));
  margin-left: calc(var(--design-width) / var(--design-base-width) * var(--p4-red-step-overlap-x) * -1);
  border-radius: calc(var(--design-width) / var(--design-base-width) * var(--p4-red-step-radius)) calc(var(--design-width) / var(--design-base-width) * var(--p4-red-step-radius)) 0 0;
  display: block;
  object-fit: fill;
}

.page-four .page4-frosted-block {
  position: absolute;
  z-index: 2;
  left: 50%;
  top: calc(var(--design-height) / var(--design-base-height) * var(--p4-frosted-top));
  bottom: 0;
  width: calc(var(--design-width) / var(--design-base-width) * var(--p4-frosted-width));
  height: calc(var(--design-height) / var(--design-base-height) * var(--p4-frosted-height));
  border-radius: calc(var(--design-width) / var(--design-base-width) * var(--p4-frosted-radius));
  overflow: hidden;
  background: rgba(255, 255, 255, 1);
  transform: translateX(-50%);
}

.page-four .page4-panel {
  position: relative;
  z-index: 2;
  height: 100%;
  display: flex;
  flex-direction: column;
  padding: calc(var(--design-height) / var(--design-base-height) * var(--p4-panel-padding-top)) calc(var(--design-width) / var(--design-base-width) * var(--p4-panel-padding-x)) calc(var(--design-height) / var(--design-base-height) * var(--p4-panel-padding-bottom));
  box-sizing: border-box;
}

.page-four .page4-panel-header {
  height: calc(var(--design-height) / var(--design-base-height) * var(--p4-panel-header-height));
  border-radius: calc(var(--design-width) / var(--design-base-width) * var(--p4-panel-header-radius));
  display: grid;
  grid-template-columns: calc(var(--design-width) / var(--design-base-width) * var(--p4-panel-col-rank)) calc(var(--design-width) / var(--design-base-width) * var(--p4-panel-col-name)) calc(var(--design-width) / var(--design-base-width) * var(--p4-panel-col-count));
  align-items: center;
  padding: 0 calc(var(--design-width) / var(--design-base-width) * var(--p4-panel-col-gap-x));
  box-sizing: border-box;
  color: #5E5E5E;
  font-family: 'HuaweiSans', 'FZLanTing', sans-serif;
  font-weight: 400;
}

.page-four .page4-col-rank {
  font-size: calc(var(--design-width) / var(--design-base-width) * var(--p4-header-rank-font));
}

.page-four .page4-col-name {
  font-size: calc(var(--design-width) / var(--design-base-width) * var(--p4-header-name-font));
}

.page-four .page4-col-rank,
.page-four .page4-col-count {
  display: flex;
  align-items: center;
  gap: calc(var(--design-width) / var(--design-base-width) * var(--p4-header-icon-gap));
}

.page-four .page4-col-rank-icon,
.page-four .page4-col-count-icon {
  width: calc(var(--design-width) / var(--design-base-width) * var(--p4-header-icon-size));
  height: calc(var(--design-width) / var(--design-base-width) * var(--p4-header-icon-size));
  flex: 0 0 auto;
  object-fit: contain;
}

.page-four .page4-col-count {
  font-size: calc(var(--design-width) / var(--design-base-width) * var(--p4-header-count-font));
  justify-content: flex-end;
  margin-right: calc(var(--design-width) / var(--design-base-width) * var(--p4-header-count-offset-left));
}

.page-four .page4-col-name {
  margin-left: calc(var(--design-width) / var(--design-base-width) * var(--p4-col-gap-left-middle));
}

.page-four .page4-panel-list {
  flex: 1;
  margin-top: calc(var(--design-height) / var(--design-base-height) * var(--p4-panel-list-margin-top));
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

.page-four .page4-row {
  height: calc(var(--design-height) / var(--design-base-height) * var(--p4-row-height));
  margin-bottom: calc(var(--design-height) / var(--design-base-height) * var(--p4-row-margin-bottom));
  border-radius: calc(var(--design-width) / var(--design-base-width) * var(--p4-row-radius));
  display: grid;
  grid-template-columns: calc(var(--design-width) / var(--design-base-width) * var(--p4-panel-col-rank)) calc(var(--design-width) / var(--design-base-width) * var(--p4-panel-col-name)) calc(var(--design-width) / var(--design-base-width) * var(--p4-panel-col-count));
  align-items: center;
  padding: 0 calc(var(--design-width) / var(--design-base-width) * var(--p4-panel-col-gap-x));
  box-sizing: border-box;
}

/* No.1 冠军行 */
.page-four .page4-row--first {
  background: rgba(255, 255, 255, 0.95);
  border: none;
  border-radius: calc(var(--design-height) / var(--design-base-height) * var(--p4-row-height) / 2);
  padding: 0 calc(var(--design-width) / var(--design-base-width) * var(--p4-panel-col-gap-x));
  box-shadow: 0 calc(var(--design-height) / var(--design-base-height) * var(--p4-row-first-shadow-y)) calc(var(--design-height) / var(--design-base-height) * var(--p4-row-first-shadow-blur)) rgba(249, 53, 48, 0.12);
}

.page-four .page4-row--first .page4-row-rank {
  color: #FF574B;
}

.page-four .page4-row--first .page4-row-count {
  color: #FF574B;
}

.page-four .page4-row--first .page4-row-progress-fill {
  background: #FF574B;
}

/* No.2 及以下 */
.page-four .page4-row--rest {
  background: rgba(255, 255, 255, 0.95);
  border: calc(var(--design-width) / var(--design-base-width) * var(--p4-row-rest-border)) solid rgba(0, 0, 0, 0.06);
  box-shadow: 0 calc(var(--design-height) / var(--design-base-height) * var(--p4-row-rest-shadow-y)) calc(var(--design-height) / var(--design-base-height) * var(--p4-row-rest-shadow-blur)) rgba(0, 0, 0, 0.08);
}

.page-four .page4-row--rest .page4-row-progress-fill {
  background: #FFC200;
}

.page-four .page4-row-rank-wrap,
.page-four .page4-row-count-wrap {
  display: flex;
  align-items: center;
  gap: calc(var(--design-width) / var(--design-base-width) * var(--p4-row-icon-gap));
}

.page-four .page4-row-rank-wrap {
  flex-direction: column;
  justify-content: center;
}

.page-four .page4-row-rank-icon {
  width: calc(var(--design-width) / var(--design-base-width) * var(--p4-row-rank-icon-size));
  height: calc(var(--design-width) / var(--design-base-width) * var(--p4-row-rank-icon-size));
}

.page-four .page4-row-count-icon {
  width: calc(var(--design-width) / var(--design-base-width) * var(--p4-row-count-icon-size));
  height: calc(var(--design-width) / var(--design-base-width) * var(--p4-row-count-icon-size));
}

.page-four .page4-row-rank {
  color: #A2A1A1;
  font-size: calc(var(--design-width) / var(--design-base-width) * var(--p4-row-rank-font));
  font-family: 'HuaweiSans', 'FZLanTing', sans-serif;
  font-weight: 500;
}

.page-four .page4-row-name {
  color: #111;
  font-size: calc(var(--design-width) / var(--design-base-width) * var(--p4-row-name-font));
  font-family: 'HuaweiSans', 'FZLanTing', sans-serif;
  font-weight: 500;
}

.page-four .page4-row-main {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: calc(var(--design-height) / var(--design-base-height) * var(--p4-row-name-progress-gap));
  grid-column: 2 / 4;
  margin-left: calc(var(--design-width) / var(--design-base-width) * var(--p4-col-gap-left-middle));
}

.page-four .page4-row-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.page-four .page4-row-progress {
  width: 100%;
  height: calc(var(--design-height) / var(--design-base-height) * var(--p4-row-progress-height));
  border-radius: calc(var(--design-width) / var(--design-base-width) * var(--p4-row-progress-radius));
  background: #E5E5E5;
  overflow: hidden;
}

.page-four .page4-row-progress-fill {
  display: block;
  height: 100%;
  border-radius: inherit;
  transform-origin: left center;
  transform: scaleX(0);
  animation: page4-row-progress-fill-grow var(--p4-row-progress-duration, 900ms) linear forwards;
  will-change: transform;
}

@keyframes page4-row-progress-fill-grow {
  from {
    transform: scaleX(0);
  }
  to {
    transform: scaleX(1);
  }
}

.page-four .page4-row-count {
  color: #A2A1A1;
  font-size: calc(var(--design-width) / var(--design-base-width) * var(--p4-row-count-font));
  font-family: 'HuaweiSans', 'FZLanTing', sans-serif;
  font-weight: 500;
}

.page-four .page4-row-top .page4-row-count-wrap {
  justify-content: flex-end;
}

.page-four .page4-row-count-unit {
  margin-left: calc(var(--design-width) / var(--design-base-width) * var(--p4-row-count-unit-gap));
  color: #A2A1A1;
  font-size: calc(var(--design-width) / var(--design-base-width) * var(--p4-row-count-unit-font));
  font-family: 'HuaweiSans', 'FZLanTing', sans-serif;
  font-weight: 400;
}

.page-four .page4-panel-footer {
  height: calc(var(--design-height) / var(--design-base-height) * var(--p4-panel-footer-height));
  margin-top: calc(var(--design-height) / var(--design-base-height) * var(--p4-panel-footer-margin-top));
  border-radius: calc(var(--design-width) / var(--design-base-width) * var(--p4-panel-footer-radius));
  color: #b1b1b1;
  font-size: calc(var(--design-width) / var(--design-base-width) * var(--p4-panel-footer-font));
  font-family: 'HuaweiSans', 'FZLanTing', sans-serif;
  display: flex;
  align-items: center;
  justify-content: center;
}

.page-four .page4-frosted-block .page4-corner-rt,
.page-four .page4-frosted-block .page4-corner-lb {
  position: absolute;
  display: block;
  z-index: 1;
}

.page-four .page4-frosted-block .page4-corner-rt {
  top: calc(var(--design-height) / var(--design-base-height) * var(--p4-corner-rt-top));
  right: calc(var(--design-width) / var(--design-base-width) * var(--p4-corner-rt-right));
  width: calc(var(--design-width) / var(--design-base-width) * var(--p4-corner-rt-width));
}

.page-four .page4-frosted-block .page4-corner-lb {
  left: calc(var(--design-width) / var(--design-base-width) * var(--p4-corner-lb-left));
  bottom: calc(var(--design-height) / var(--design-base-height) * var(--p4-corner-lb-bottom));
  width: calc(var(--design-width) / var(--design-base-width) * var(--p4-corner-lb-width));
}

.page-four .page4-yellow1 {
  position: absolute;
  z-index: 0;
  width: calc(var(--design-width) / var(--design-base-width) * var(--p4-yellow1-width));
  left: calc(var(--design-width) / var(--design-base-width) * var(--p4-yellow1-left));
  top: calc(var(--design-height) / var(--design-base-height) * var(--p4-yellow1-top));
}

.page-four .page4-yellow2 {
  position: absolute;
  z-index: 0;
  width: calc(var(--design-width) / var(--design-base-width) * var(--p4-yellow2-width));
  right: calc(var(--design-width) / var(--design-base-width) * var(--p4-yellow2-right));
  top: calc(var(--design-height) / var(--design-base-height) * var(--p4-yellow2-top));
}

.page-four .page4-yellow3 {
  position: absolute;
  z-index: 0;
  width: calc(var(--design-width) / var(--design-base-width) * var(--p4-yellow3-width));
  left: calc(var(--design-width) / var(--design-base-width) * var(--p4-yellow3-left));
  bottom: calc(var(--design-height) / var(--design-base-height) * var(--p4-yellow3-bottom));
}

/* page5 */

.page-five {
  background: linear-gradient(to bottom, #deecee 0%, #faf0d8 100%);
}

.page5-flow {
  position: relative;
  z-index: 2;
  width: 100%;
  height: 100%;
}

.page5-icon {
  position: absolute;
  left: calc(var(--design-width) / var(--design-base-width) * var(--p5-icon-left));
  top: calc(var(--design-height) / var(--design-base-height) * var(--p5-icon-top));
  width: calc(var(--design-width) / var(--design-base-width) * var(--p5-icon-width));
  margin-left: 0;
  transform: translateX(calc(-50% + calc(var(--design-width) / var(--design-base-width) * var(--p5-icon-offset-x))));
  display: block;
}

/* page5 - 地图 wrapper：给坐标点提供一个“相对地图图片”的坐标系 */
.page5-map-wrapper {
  position: absolute;
  left: calc(var(--design-width) / var(--design-base-width) * var(--p5-icon-left));
  top: calc(var(--design-height) / var(--design-base-height) * var(--p5-icon-top));
  width: calc(var(--design-width) / var(--design-base-width) * var(--p5-icon-width));
  pointer-events: none;
  z-index: 3;
  transform: translateX(calc(-50% + calc(var(--design-width) / var(--design-base-width) * var(--p5-icon-offset-x))));
}

.page5-map-icon {
  width: 100%;
  height: auto;
  display: block;
}

.page5-entry {
  position: absolute;
  z-index: 1;
  display: flex;
  align-items: center;
}

.page5-entry--page3 {
  left: calc(var(--design-width) / var(--design-base-width) * var(--p3-entry-left));
  top: calc(var(--design-height) / var(--design-base-height) * var(--p3-entry-top));
  width: calc(var(--design-width) / var(--design-base-width) * var(--p3-entry-width));
  gap: calc(var(--design-width) / var(--design-base-width) * var(--p3-entry-gap));
}

.page5-entry--page4 {
  left: calc(var(--design-width) / var(--design-base-width) * var(--p4-entry-left));
  top: calc(var(--design-height) / var(--design-base-height) * var(--p4-entry-top));
  width: calc(var(--design-width) / var(--design-base-width) * var(--p4-entry-width));
  gap: calc(var(--design-width) / var(--design-base-width) * var(--p4-entry-gap));
}

.page5-entry--page5 {
  left: calc(var(--design-width) / var(--design-base-width) * var(--p5-entry-left));
  top: calc(var(--design-height) / var(--design-base-height) * var(--p5-entry-top));
  width: calc(var(--design-width) / var(--design-base-width) * var(--p5-entry-width));
  gap: calc(var(--design-width) / var(--design-base-width) * var(--p5-entry-gap));
}

.page5-titlt-icon {
  position: relative;
  left: auto;
  top: auto;
  width: calc(var(--design-width) / var(--design-base-width) * var(--p5-title-icon-width));
  display: block;
  flex-shrink: 0;
}

.page5-entry-text {
  position: relative;
  left: auto;
  top: auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.page5-entry-title {
  font-family: 'HuaweiSans', 'FZLanTing', sans-serif;
  font-weight: 500;
  font-size: calc(var(--design-width) / var(--design-base-width) * var(--p5-entry-title-size));
  line-height: 1;
  color: #000;
  white-space: nowrap;
}

.page5-entry-subtitle {
  font-family: 'HuaweiSans', 'FZLanTing', sans-serif;
  font-weight: 500;
  margin-top: calc(var(--design-height) / var(--design-base-height) * var(--p5-entry-subtitle-margin-top));
  font-size: calc(var(--design-width) / var(--design-base-width) * var(--p5-entry-subtitle-size));
  line-height: 1;
  color: #000;
  white-space: nowrap;
}

.page5-heatmap {
  position: absolute;
  left: calc(var(--design-width) / var(--design-base-width) * var(--p5-heatmap-left));
  top: var(--p5-heatmap-top-px);
  width: calc(var(--design-width) / var(--design-base-width) * var(--p5-heatmap-width));
  height: calc(var(--design-width) / var(--design-base-width) * var(--p5-heatmap-width) * var(--p5-card-height-ratio) / 728);
  margin: 0;
  transform: translateX(calc(-50% + calc(var(--design-width) / var(--design-base-width) * var(--p5-heatmap-offset-x))));
}

.page5-ranking {
  position: absolute;
  left: calc(var(--design-width) / var(--design-base-width) * var(--p5-ranking-left));
  top: calc(
    var(--p5-heatmap-top-px) +
    calc(var(--design-width) / var(--design-base-width) * var(--p5-heatmap-width) * var(--p5-card-height-ratio) / 728) +
    calc(var(--design-height) / var(--design-base-height) * var(--p5-ranking-easter-gap))
  );
  width: calc(var(--design-width) / var(--design-base-width) * var(--p5-ranking-width));
  height: calc(var(--design-width) / var(--design-base-width) * var(--p5-ranking-width) * var(--p5-card-height-ratio) / 728);
  margin: 0;
  transform: translateX(calc(-50% + calc(var(--design-width) / var(--design-base-width) * var(--p5-ranking-offset-x))));
}

.page5-easter {
  position: absolute;
  left: calc(var(--design-width) / var(--design-base-width) * var(--p5-easter-left));
  top: calc(
    calc(
      var(--p5-heatmap-top-px) +
      calc(var(--design-width) / var(--design-base-width) * var(--p5-heatmap-width) * var(--p5-card-height-ratio) / 728) +
      calc(var(--design-height) / var(--design-base-height) * var(--p5-ranking-easter-gap))
    ) +
    calc(var(--design-width) / var(--design-base-width) * var(--p5-ranking-width) * var(--p5-card-height-ratio) / 728) +
    calc(var(--design-height) / var(--design-base-height) * var(--p5-ranking-easter-gap))
  );
  width: calc(var(--design-width) / var(--design-base-width) * var(--p5-easter-width));
  height: calc(var(--design-width) / var(--design-base-width) * var(--p5-easter-width) * var(--p5-card-height-ratio) / 728);
  margin: 0;
  transform: translateX(calc(-50% + calc(var(--design-width) / var(--design-base-width) * var(--p5-easter-offset-x))));
}

.page5-heatmap-image,
.page5-ranking-image,
.page5-easter-image {
  width: 100%;
  height: 100%;
  object-fit: fill;
  display: block;
}

.page5-marker-6,
.page5-marker-5,
.page5-marker-4 {
  position: absolute;
  top: 50%;
  transform: translateY(-60%);
}

.page5-marker-6 {
  left: calc(var(--design-width) / var(--design-base-width) * var(--p5-marker-6-left));
  width: calc(var(--design-width) / var(--design-base-width) * var(--p5-marker-6-width));
}

.page5-marker-5 {
  left: calc(var(--design-width) / var(--design-base-width) * var(--p5-marker-5-left));
  width: calc(var(--design-width) / var(--design-base-width) * var(--p5-marker-5-width));
}

.page5-marker-4 {
  left: calc(var(--design-width) / var(--design-base-width) * var(--p5-marker-4-left));
  width: calc(var(--design-width) / var(--design-base-width) * var(--p5-marker-4-width));
}

.page5-yellow {
  position: absolute;
  width: calc(var(--design-width) / var(--design-base-width) * var(--p5-yellow-width));
  left: calc(var(--design-width) / var(--design-base-width) * var(--p5-yellow-left));
  top: calc(var(--design-height) / var(--design-base-height) * var(--p5-yellow-top));
}

.page5-blue {
  position: absolute;
  width: calc(var(--design-width) / var(--design-base-width) * var(--p5-blue-width));
  right: calc(var(--design-width) / var(--design-base-width) * var(--p5-blue-left));
  top: calc(var(--design-height) / var(--design-base-height) * var(--p5-blue-top));
}

.page5-green {
  position: absolute;
  width: calc(var(--design-width) / var(--design-base-width) * var(--p5-green-width));
  left: calc(var(--design-width) / var(--design-base-width) * var(--p5-green-left));
  bottom: calc(var(--design-height) / var(--design-base-height) * var(--p5-green-top));
}

.page5-map-point {
  position: absolute;
  display: block;
  width: calc(var(--design-width) / var(--design-base-width) * var(--p5-map-point-width, 100));
  /* left/top：使用父组件（.page5-map-wrapper）的百分比坐标（0~100） */
  left: calc(var(--p5-map-point-left, 0) * 1%);
  top: calc(var(--p5-map-point-top, 0) * 1%);
  height: auto;
  /* -50%：让 left/top 作为“中心点”，同时减去自身宽高的一半 */
  transform: translate(-50%, -50%);
}

/* 你需要自行填：left/top/width
   - left/top：父组件百分比坐标（0~100）
   - width：仍按设计稿像素体系（和其它 page5 参数一致）
*/
.page5-map-point--68 {
  --p5-map-point-left: var(--p5-map-point-68-left);
  --p5-map-point-top: var(--p5-map-point-68-top);
  --p5-map-point-width: var(--p5-map-point-68-width);
  z-index: 1;
  animation: page5-map-point-68-in 1000ms ease-out forwards;
}
.page5-map-point--69 {
  --p5-map-point-left: var(--p5-map-point-69-left);
  --p5-map-point-top: var(--p5-map-point-69-top);
  --p5-map-point-width: var(--p5-map-point-69-width);
}
.page5-map-point--70 {
  --p5-map-point-left: var(--p5-map-point-70-left);
  --p5-map-point-top: var(--p5-map-point-70-top);
  --p5-map-point-width: var(--p5-map-point-70-width);
}
.page5-map-point--71 {
  --p5-map-point-left: var(--p5-map-point-71-left);
  --p5-map-point-top: var(--p5-map-point-71-top);
  --p5-map-point-width: var(--p5-map-point-71-width);
}
.page5-map-point--72 {
  --p5-map-point-left: var(--p5-map-point-72-left);
  --p5-map-point-top: var(--p5-map-point-72-top);
  --p5-map-point-width: var(--p5-map-point-72-width);
}
.page5-map-point--73 {
  --p5-map-point-left: var(--p5-map-point-73-left);
  --p5-map-point-top: var(--p5-map-point-73-top);
  --p5-map-point-width: var(--p5-map-point-73-width);
}
.page5-map-point--74 {
  --p5-map-point-left: var(--p5-map-point-74-left);
  --p5-map-point-top: var(--p5-map-point-74-top);
  --p5-map-point-width: var(--p5-map-point-74-width);
}

@keyframes page5-map-point-68-in {
  0% {
    opacity: 0;
    transform: translate(-50%, -50%) scale(0) rotate(0deg);
  }
  40% {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1) rotate(0deg);
  }
  100% {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1) rotate(1080deg);
  }
}

/* page6 */

.page6-bg-block {
  position: absolute;
  left: calc(var(--design-width) / var(--design-base-width) * var(--p6-bg-left));
  top: calc(var(--design-height) / var(--design-base-height) * var(--p6-bg-top));
  width: calc(var(--design-width) / var(--design-base-width) * var(--p6-bg-width));
  background: none;
  border-radius: calc(var(--design-width) / var(--design-base-width) * 24);
  overflow: visible;
}

.page6-bg-block-ratio {
  display: block;
  width: 100%;
  height: auto;
  opacity: 0;
  pointer-events: none;
}

.page6-bg-media {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  border-radius: inherit;
  pointer-events: none;
}

.page6-bg-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transform: scale(1);
  transform-origin: center center;
  border-radius: inherit;
  pointer-events: none;
  background-color: transparent !important;
}

video.page6-bg-video::-webkit-media-controls {
  display: none !important;
}

.page6-danmu-layer {
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
  z-index: 1;
  border-radius: inherit;
}

.page6-danmu-item {
  position: absolute;
  left: 0;
  bottom: calc(var(--design-height) / var(--design-base-height) * -40);
  white-space: nowrap;
  line-height: 1;
  /* 必须有非 0 时长：默认 0s 时部分 WebView 会在 JS 写入 animationDuration 前就结束动画并触发移除 */
  animation-duration: 9s;
  animation-name: page6-danmu-rise;
  animation-timing-function: linear;
  animation-fill-mode: forwards;
}

.page6-danmu-bubble {
  display: inline-block;
  position: relative;
  color: var(--p6-danmu-color);
  background: var(--p6-danmu-bg);
  border-radius: calc(var(--design-width) / var(--design-base-width) * var(--p6-danmu-radius));
  padding: calc(var(--design-height) / var(--design-base-height) * var(--p6-danmu-padding-y))
    calc(var(--design-width) / var(--design-base-width) * var(--p6-danmu-padding-x));
  font-size: calc(var(--design-width) / var(--design-base-width) * var(--p6-danmu-font-size));
  font-family: 'HuaweiSans', 'FZLanTing', sans-serif;
  font-weight: 400;
  text-shadow: none;
  box-shadow: none;
  transform: scale(0);
  transform-origin: center center;
  opacity: 0;
  animation: page6-danmu-bubble-in 1000ms ease-out forwards;
  animation-delay: 1200ms;
}

.page6-danmu-text {
  display: inline-block;
  opacity: 1;
}

.page6-danmu-bubble::after {
  content: "";
  position: absolute;
  left: 50%;
  top: calc(100% - calc(var(--design-height) / var(--design-base-height) * 2));
  width: calc(var(--design-width) / var(--design-base-width) * var(--p6-danmu-tail-width));
  height: calc(var(--design-height) / var(--design-base-height) * var(--p6-danmu-tail-height));
  transform: translateX(-50%);
  background: var(--p6-danmu-bg);
  -webkit-clip-path: polygon(var(--p6-danmu-tail-tip-x, 50%) 100%, 0% 0%, 100% 0%);
  clip-path: polygon(var(--p6-danmu-tail-tip-x, 50%) 100%, 0% 0%, 100% 0%);
}

.page6-danmu-item::before {
  content: "";
  position: absolute;
  left: var(--p6-danmu-emoji-left-x, 50%);
  top: calc(
    100% +
    calc(var(--design-height) / var(--design-base-height) * var(--p6-danmu-tail-height)) +
    calc(var(--design-height) / var(--design-base-height) * var(--p6-danmu-emoji-gap)) +
    calc(var(--design-height) / var(--design-base-height) * var(--p6-danmu-emoji-offset-y, 0))
  );
  width: calc(var(--design-width) / var(--design-base-width) * var(--p6-danmu-emoji-size));
  height: calc(var(--design-width) / var(--design-base-width) * var(--p6-danmu-emoji-size));
  transform: translateX(-50%);
  background: var(--p6-danmu-emoji-url, url("./static/6/资源 53.png")) no-repeat center/contain;
}

@keyframes page6-danmu-rise {
  0% {
    transform: translate(0, 0);
  }
  32% {
    transform: translate(
      var(--p6-danmu-path-x1, 0px),
      calc(var(--design-height) / var(--design-base-height) * -320)
    );
  }
  68% {
    transform: translate(
      var(--p6-danmu-path-x2, 0px),
      calc(var(--design-height) / var(--design-base-height) * -680)
    );
  }
  100% {
    transform: translate(
      var(--p6-danmu-path-x3, 0px),
      calc(var(--design-height) / var(--design-base-height) * -980)
    );
  }
}

@keyframes page6-danmu-bubble-in {
  0% {
    transform: scale(0);
    opacity: 0;
  }
  100% {
    transform: scale(1);
    opacity: 1;
  }
}

.page6-input-shell {
  position: absolute;
  top: calc(100% + calc(var(--design-height) / var(--design-base-height) * var(--p6-input-gap-top)));
  left: 50%;
  transform: translateX(-50%);
  width: calc(var(--design-width) / var(--design-base-width) * var(--p6-input-width));
  height: calc(var(--design-height) / var(--design-base-height) * var(--p6-input-shell-height));
  background: #ffffff;
  border-radius: calc(var(--design-width) / var(--design-base-width) * var(--p6-input-shell-radius));
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
}

.page6-input-inner {
  width: calc(100% - calc(var(--design-width) / var(--design-base-width) * var(--p6-input-inner-gap) * 2));
  height: calc(100% - calc(var(--design-height) / var(--design-base-height) * var(--p6-input-inner-gap) * 2));
  background: #f9f9f9;
  border-radius: calc(var(--design-width) / var(--design-base-width) * var(--p6-input-inner-radius));
  display: flex;
  align-items: center;
}

.page6-input {
  width: 100%;
  height: 100%;
  border: 0;
  outline: none;
  background: transparent;
  padding: 0 calc(var(--design-width) / var(--design-base-width) * var(--p6-input-padding-x));
  font-size: calc(var(--design-width) / var(--design-base-width) * var(--p6-input-font-size));
  color: #000000;
  font-family: 'HuaweiSans', 'FZLanTing', sans-serif;
  font-weight: 400;
  box-sizing: border-box;
}

.page6-input::placeholder {
  color: #333333;
}

.page6-action-row {
  position: absolute;
  top: calc(
    100% +
    calc(var(--design-height) / var(--design-base-height) * var(--p6-input-gap-top)) +
    calc(var(--design-height) / var(--design-base-height) * var(--p6-input-shell-height)) +
    calc(var(--design-height) / var(--design-base-height) * var(--p6-action-gap-top))
  );
  left: 50%;
  transform: translateX(-50%);
  width: calc(var(--design-width) / var(--design-base-width) * var(--p6-input-width));
  z-index: 2;
}

.page6-send-btn {
  display: none;
  width: calc(var(--design-width) / var(--design-base-width) * var(--p6-send-width));
  height: calc(var(--design-height) / var(--design-base-height) * var(--p6-send-height));
  margin: 0 auto;
  border: 0;
  border-radius: calc(var(--design-width) / var(--design-base-width) * var(--p6-send-radius));
  background: #ffffff;
  color: #000000;
  font-size: calc(var(--design-width) / var(--design-base-width) * var(--p6-send-font-size));
  font-family: 'HuaweiSans', 'FZLanTing', sans-serif;
  font-weight: 400;
}

.page6-suggestions {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: calc(var(--design-height) / var(--design-base-height) * var(--p6-suggestion-gap));
  padding: calc(var(--design-height) / var(--design-base-height) * var(--p6-suggestion-panel-padding-y))
    calc(var(--design-width) / var(--design-base-width) * var(--p6-suggestion-panel-padding-x));
  border-radius: calc(var(--design-width) / var(--design-base-width) * var(--p6-suggestion-panel-radius));
  background: rgba(255, 255, 255, 0.68);
  -webkit-backdrop-filter: blur(calc(var(--design-width) / var(--design-base-width) * var(--p6-suggestion-panel-blur)));
  backdrop-filter: blur(calc(var(--design-width) / var(--design-base-width) * var(--p6-suggestion-panel-blur)));
  box-sizing: border-box;
}

.page6-suggestions.is-guarded {
  pointer-events: none;
}

.page6-suggestion-item {
  border: 0;
  background: transparent;
  color: #000000;
  height: auto;
  border-radius: calc(var(--design-width) / var(--design-base-width) * var(--p6-suggestion-item-radius));
  padding: 0;
  font-size: calc(var(--design-width) / var(--design-base-width) * var(--p6-suggestion-font-size));
  font-family: 'HuaweiSans', 'FZLanTing', sans-serif;
  font-weight: 400;
  max-width: 100%;
  text-align: left;
}

.page6-bg-block.has-input .page6-send-btn {
  display: block;
}

.page6-bg-block.has-input .page6-suggestions {
  display: none;
}

/* 发送成功轻提示：由 showPage6SendSuccess() 控制显隐 */
.page6-send-toast {
  position: absolute;
  left: 50%;
  top: calc(
    100% +
    calc(var(--design-height) / var(--design-base-height) * var(--p6-input-gap-top)) +
    calc(var(--design-height) / var(--design-base-height) * var(--p6-input-shell-height)) +
    calc(var(--design-height) / var(--design-base-height) * var(--p6-action-gap-top)) +
    calc(var(--design-height) / var(--design-base-height) * var(--p6-send-height)) +
    calc(var(--design-height) / var(--design-base-height) * 18)
  );
  transform: translateX(-50%) translateY(6px);
  padding: calc(var(--design-height) / var(--design-base-height) * 8) calc(var(--design-width) / var(--design-base-width) * 14);
  border-radius: calc(var(--design-width) / var(--design-base-width) * 18);
  background: rgba(0, 0, 0, 0.72);
  color: #ffffff;
  font-size: calc(var(--design-width) / var(--design-base-width) * 22);
  line-height: 1.2;
  opacity: 0;
  pointer-events: none;
  z-index: 3;
  transition: opacity 160ms ease, transform 160ms ease;
}

.page6-send-toast.is-visible {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

/* 浮球按钮 */

.global-float-entry {
  position: fixed;
  right: 0;
  bottom: calc(var(--design-height) / var(--design-base-height) * var(--float-entry-bottom));
  width: calc(var(--design-width) / var(--design-base-width) * var(--float-entry-width));
  display: none;
  z-index: 999;
  user-select: none;
  touch-action: none;
  cursor: grab;
}

.global-float-entry.is-visible {
  display: block;
}

.global-float-entry.is-dragging {
  cursor: grabbing;
}

