@font-face {
  font-family: Pretendard;
  src: url('./fonts/Pretendard-Regular.woff');
}

@font-face {
  font-family: Pretendard;
  src: url('./fonts/Pretendard-Bold.woff');
  font-weight: 700;
}
@font-face {
  font-family: Pretendard;
  src: url('./fonts/Pretendard-ExtraBold.woff');
  font-weight: 900;
}
:root {
  --content-width: 1440px;
  --ink: #171925;
  --sub: #6d7180;
  --purple: #7957f4;
  --pink: #ed5d9c;
  --orange: #ff9d5c;
  --yellow: #ffce57;
  --line: #e9e7ef;
  --cream: #fbfaff;
  --radius: 28px;
}
* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}
html {
  scroll-behavior: smooth;
}
body {
  overflow-x: hidden;
  color: var(--ink);
  background: #fff;
  font-family:
    Pretendard,
    -apple-system,
    BlinkMacSystemFont,
    'Segoe UI',
    sans-serif;
  word-break: keep-all;
}
a {
  color: inherit;
  text-decoration: none;
}
img {
  display: block;
  max-width: 100%;
}
.site-header {
  position: fixed;
  z-index: 50;
  top: 0;
  left: 0;
  width: 100%;
  height: 72px;
  padding: 0 max(24px, calc((100vw - var(--content-width)) / 2));
  display: flex;
  align-items: center;
  gap: 44px;
  border-bottom: 1px solid rgba(23, 25, 37, 0.05);
  background: rgba(255, 255, 255, 0.85);
  backdrop-filter: blur(18px);
  transition: 0.25s;
}
.site-header.scrolled {
  height: 64px;
  box-shadow: 0 10px 40px rgba(39, 29, 75, 0.07);
}
.brand {
  display: flex;
  align-items: center;
  gap: 9px;
  font-size: 20px;
  font-weight: 900;
}
.brand img {
  width: 36px;
  height: 36px;
  object-fit: contain;
}
.desktop-nav {
  display: flex;
  gap: 30px;
  margin-right: auto;
  color: #555968;
  font-size: 14px;
  font-weight: 700;
}
.desktop-nav a:hover {
  color: var(--purple);
}
.header-cta {
  padding: 11px 18px;
  border-radius: 12px;
  color: #fff;
  background: var(--ink);
  font-size: 13px;
  font-weight: 800;
}
.hero {
  min-height: 860px;
  position: relative;
  display: flex;
  align-items: center;
  padding: 112px 24px 52px;
  isolation: isolate;
  background: linear-gradient(135deg, #fff 0%, #fbf9ff 48%, #f7f4ff 100%);
}
.hero-art {
  position: absolute;
  z-index: -2;
  inset: 0;
  background: url('./images/reward-arcade-hero.png') 70% center/cover no-repeat;
  opacity: 0.62;
}
.hero::after {
  content: '';
  position: absolute;
  z-index: -1;
  inset: 0;
  background: linear-gradient(
    90deg,
    rgba(255, 255, 255, 0.98) 0%,
    rgba(255, 255, 255, 0.92) 36%,
    rgba(255, 255, 255, 0.15) 68%,
    rgba(255, 255, 255, 0.2) 100%
  );
}
.hero-inner {
  width: 100%;
  max-width: var(--content-width);
  margin: auto;
  display: grid;
  grid-template-columns: 1fr 560px;
  align-items: center;
  gap: 50px;
}
.eyebrow {
  width: max-content;
  margin-bottom: 28px;
  padding: 10px 15px;
  border: 1px solid #e7e0ff;
  border-radius: 50px;
  color: #65577f;
  background: rgba(255, 255, 255, 0.8);
  font-size: 13px;
  font-weight: 800;
}
.live-dot {
  display: inline-block;
  width: 7px;
  height: 7px;
  margin-right: 6px;
  border-radius: 50%;
  background: #52c98d;
  box-shadow: 0 0 0 5px rgba(82, 201, 141, 0.13);
}
.hero h1 {
  font-size: clamp(52px, 5.4vw, 78px);
  line-height: 1.08;
  letter-spacing: -0.065em;
}
.hero h1 em {
  color: transparent;
  background: linear-gradient(90deg, #7957f4, #ed5d9c 48%, #ff9d5c);
  background-clip: text;
  font-style: normal;
}
.hero-copy > p {
  margin: 28px 0 34px;
  color: #5f6370;
  font-size: 18px;
  line-height: 1.75;
}
.hero-actions {
  display: flex;
  gap: 12px;
}
.store-button {
  min-width: 166px;
  padding: 12px 18px;
  display: flex;
  align-items: center;
  gap: 11px;
  border-radius: 15px;
  color: #fff;
  background: #171925;
  box-shadow: 0 12px 30px rgba(23, 25, 37, 0.13);
  transition: 0.25s;
}
.store-button:hover {
  transform: translateY(-3px);
  box-shadow: 0 17px 36px rgba(23, 25, 37, 0.18);
}
.store-button img {
  width: 27px;
  height: 27px;
  object-fit: contain;
}
.store-button span {
  font-size: 15px;
  font-weight: 800;
  line-height: 1.05;
}
.store-button small {
  display: block;
  margin-bottom: 4px;
  font-size: 8px;
  font-weight: 500;
  opacity: 0.68;
}
.hero-proof {
  margin-top: 22px;
  display: flex;
  gap: 18px;
  color: #777b88;
  font-size: 12px;
}
.hero-proof b {
  color: #7b5ce1;
}

.phone {
  width: 340px;
  height: 650px;
  padding: 8px;
  position: relative;
  border-radius: 50px;
  background: #171925;
  box-shadow:
    0 45px 90px rgba(59, 37, 116, 0.28),
    0 15px 35px rgba(45, 31, 84, 0.16);
  transform: rotate(2deg);
}
.phone-speaker {
  width: 105px;
  height: 26px;
  position: absolute;
  z-index: 5;
  top: 7px;
  left: 50%;
  transform: translateX(-50%);
  border-radius: 0 0 16px 16px;
  background: #171925;
}
.phone-screen {
  height: 100%;
  overflow: hidden;
  border-radius: 42px;
  background: #f7f7fa;
}
.app-head {
  height: 105px;
  padding: 39px 17px 16px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: #fff;
  background: #111;
}
.mini-brand {
  display: flex;
  align-items: center;
  gap: 9px;
}
.mini-brand img {
  width: 38px;
  height: 38px;
  padding: 2px;
  border-radius: 12px;
  background: #fff;
}
.mini-brand div {
  display: flex;
  flex-direction: column;
}
.mini-brand small {
  color: #a6a6ad;
  font-size: 8px;
}
.mini-brand strong {
  font-size: 14px;
}
.wallet {
  padding: 7px 10px;
  display: flex;
  align-items: center;
  gap: 5px;
  border-radius: 50px;
  background: #292932;
}
.wallet img {
  width: 15px;
}
.wallet b {
  font-size: 9px;
}
.today-card {
  height: 116px;
  margin: 14px 14px 17px;
  padding: 18px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  overflow: hidden;
  border-radius: 22px;
  color: #fff;
  background: linear-gradient(135deg, #7455ee, #b25ce5 55%, #ee739c);
  box-shadow: 0 12px 22px rgba(119, 84, 226, 0.22);
}
.today-card span {
  display: block;
  font-size: 8px;
  opacity: 0.75;
}
.today-card strong {
  display: block;
  margin-top: 7px;
  font-size: 17px;
  line-height: 1.25;
}
.today-card > img {
  width: 80px;
  height: 80px;
  object-fit: contain;
  filter: drop-shadow(0 8px 12px rgba(40, 25, 85, 0.25));
  transform: rotate(8deg);
}
.quick-title {
  padding: 0 15px;
  display: flex;
  justify-content: space-between;
}
.quick-title strong {
  font-size: 11px;
}
.quick-title span {
  color: #a2a4ae;
  font-size: 7px;
}
.quick-grid {
  padding: 10px 14px 16px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 7px;
}
.quick-grid > div {
  text-align: center;
}
.quick-grid b {
  display: block;
  margin-top: 5px;
  font-size: 6px;
}
.quick-icon {
  height: 52px;
  display: grid;
  place-items: center;
  border-radius: 16px;
}
.quick-icon img {
  width: 33px;
  height: 33px;
  object-fit: contain;
}
.lilac {
  background: #eee9ff;
}
.mint {
  background: #e4f7ee;
}
.peach {
  background: #fff0e6;
}
.yellow {
  background: #fff7d8;
}
.game-preview {
  padding-top: 3px;
}
.preview-row {
  padding: 10px 14px;
  display: flex;
  gap: 8px;
}
.preview-game {
  min-width: 89px;
  padding: 9px 7px;
  border-radius: 15px;
  background: #fff;
  box-shadow: 0 6px 18px rgba(27, 25, 45, 0.06);
  text-align: center;
}
.preview-game img {
  width: 45px;
  height: 45px;
  margin: auto;
  object-fit: contain;
}
.preview-game span {
  display: block;
  margin-top: 5px;
  font-size: 7px;
  font-weight: 800;
}
.phone-nav {
  height: 51px;
  position: absolute;
  right: 8px;
  bottom: 8px;
  left: 8px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  align-items: center;
  border-radius: 0 0 40px 40px;
  color: #9b9da7;
  background: #171717;
}
.phone-nav span {
  display: flex;
  flex-direction: column;
  align-items: center;
  font-size: 14px;
}
.phone-nav b {
  margin-top: 2px;
  font-size: 6px;
}
.phone-nav .active {
  color: #fff;
}
.float-chip {
  position: absolute;
  z-index: 4;
  padding: 12px 15px;
  display: flex;
  align-items: center;
  gap: 8px;
  border: 1px solid rgba(255, 255, 255, 0.7);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 18px 40px rgba(70, 45, 130, 0.17);
  font-size: 11px;
  font-weight: 900;
  animation: float 3.6s ease-in-out infinite;
}
.float-chip img {
  width: 28px;
  height: 28px;
  object-fit: contain;
}
.chip-candy {
  top: 120px;
  left: 5px;
  transform: rotate(-6deg);
}
.chip-point {
  right: 5px;
  bottom: 140px;
  animation-delay: -1.5s;
  color: #7254e9;
}
@keyframes float {
  50% {
    translate: 0 -12px;
  }
}
.ticker {
  padding: 22px 24px;
  overflow: hidden;
  color: #fff;
  background: var(--ink);
}
.ticker-track {
  width: max-content;
  display: flex;
  align-items: center;
  animation: ticker-flow 24s linear infinite;
}
.ticker-group {
  width: 100vw;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  justify-content: space-around;
  gap: 24px;
  padding: 0 32px;
}
.ticker-step {
  display: flex;
  align-items: center;
  gap: 12px;
}
.ticker-step b {
  width: 34px;
  height: 34px;
  flex: 0 0 34px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 50%;
  color: #bdaaff;
  background: rgba(123, 89, 228, 0.14);
  font-size: 10px;
  font-weight: 900;
}
.ticker-step span {
  font-size: 13px;
  font-weight: 800;
  line-height: 1.3;
  white-space: nowrap;
}
.ticker-step small {
  display: block;
  margin-bottom: 2px;
  color: #918c9d;
  font-size: 8px;
  font-weight: 900;
  letter-spacing: 0.14em;
}
.ticker-group > i {
  color: #625d6d;
  font-size: 14px;
  font-style: normal;
}
@keyframes ticker-flow {
  to {
    transform: translateX(-50%);
  }
}
.section {
  max-width: var(--content-width);
  margin: auto;
  padding: 130px 24px;
}
.section-heading {
  max-width: 690px;
  margin: 0 auto 58px;
  text-align: center;
}
.section-heading.left {
  max-width: none;
  margin-left: 0;
  text-align: left;
}
.kicker {
  display: block;
  margin-bottom: 15px;
  color: #8b6cf4;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.18em;
}
.section-heading h2,
.shop-copy h2,
.rank-copy h2 {
  font-size: clamp(36px, 4vw, 56px);
  line-height: 1.16;
  letter-spacing: -0.05em;
}
.section-heading p,
.shop-copy p,
.rank-copy > p {
  margin-top: 20px;
  color: var(--sub);
  font-size: 16px;
  line-height: 1.7;
}
.benefit-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
.benefit-card {
  min-height: 390px;
  padding: 38px;
  position: relative;
  overflow: hidden;
  border-radius: var(--radius);
}
.benefit-card.large {
  grid-row: span 2;
  min-height: 800px;
}
.benefit-card.purple {
  color: #fff;
  background: linear-gradient(145deg, #7151e8, #a45bda 56%, #e7769d);
}
.benefit-card.mint {
  background: #e8f8f0;
}
.benefit-card.orange {
  background: #fff1e7;
}
.card-copy {
  position: relative;
  z-index: 2;
}
.card-copy > span {
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 0.18em;
  opacity: 0.65;
}
.card-copy h3 {
  margin: 13px 0 15px;
  font-size: 34px;
  line-height: 1.18;
  letter-spacing: -0.04em;
}
.card-copy p {
  font-size: 14px;
  line-height: 1.6;
  opacity: 0.7;
}
.game-stack {
  height: 490px;
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
}
.game-stack img {
  width: 190px;
  height: 190px;
  position: absolute;
  object-fit: contain;
  filter: drop-shadow(0 25px 35px rgba(55, 26, 105, 0.3));
}
.game-stack img:nth-child(1) {
  top: 50px;
  left: 45px;
  transform: rotate(-13deg);
}
.game-stack img:nth-child(2) {
  top: 190px;
  right: 45px;
  transform: rotate(12deg);
}
.game-stack img:nth-child(3) {
  bottom: 0;
  left: 80px;
  transform: rotate(-4deg);
}
.solo-art {
  position: absolute;
  object-fit: contain;
  filter: drop-shadow(0 18px 24px rgba(40, 100, 75, 0.18));
}
.walk-art {
  width: 190px;
  right: 35px;
  bottom: 20px;
}
.orbit-art {
  width: 240px;
  height: 240px;
  position: absolute;
  right: 0;
  bottom: -30px;
  border: 1px solid rgba(255, 130, 66, 0.2);
  border-radius: 50%;
}
.orbit-art img {
  width: 135px;
  height: 135px;
  position: absolute;
  top: 30px;
  left: 35px;
  object-fit: contain;
  filter: drop-shadow(0 15px 24px rgba(185, 89, 38, 0.2));
}
.orbit-art i {
  width: 16px;
  height: 16px;
  position: absolute;
  border-radius: 50%;
  background: #ffaf69;
}
.orbit-art i:nth-child(2) {
  top: 20px;
  right: 44px;
}
.orbit-art i:nth-child(3) {
  right: 30px;
  bottom: 55px;
  background: #ef6f9f;
}
.orbit-art i:nth-child(4) {
  bottom: 25px;
  left: 25px;
  background: #835fe8;
}
.games-section {
  max-width: none;
  padding-bottom: 80px;
  padding-right: 0;
  padding-left: 0;
  background: #faf9fd;
}
.games-section .section-heading {
  max-width: var(--content-width);
  margin-right: auto;
  margin-left: auto;
  padding-right: 24px;
  padding-left: 24px;
}
.mySwiper {
  width: 100%;
  padding: 15px 0 65px;
  overflow: hidden;
}
.mySwiper .swiper-slide {
  width: 300px;
  height: 450px;
  position: relative;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border: 1px solid #eeecf3;
  border-radius: 26px;
  background: #fff;
  box-shadow: 0 15px 35px rgba(45, 34, 84, 0.08);
  opacity: 0.48;
  transform: scale(0.9);
  transition:
    opacity 0.3s,
    transform 0.3s,
    box-shadow 0.3s;
}
.mySwiper .swiper-slide-active {
  opacity: 1;
  transform: scale(1);
  box-shadow: 0 28px 55px rgba(100, 70, 175, 0.18);
}
.slide-img-box {
  height: 270px;
  display: grid;
  place-items: center;
  background: linear-gradient(145deg, #f6f3ff, #fff7fa);
}
.slide-img-box img {
  width: 170px;
  height: 170px;
  object-fit: contain;
  filter: drop-shadow(0 16px 25px rgba(70, 45, 130, 0.15));
  transition: transform 0.35s;
}
.swiper-slide-active .slide-img-box img {
  transform: scale(1.08);
}
.slide-content {
  flex: 1;
  padding: 24px;
  position: relative;
  text-align: center;
}
.slide-content h3 {
  font-size: 21px;
}
.slide-content p {
  height: 42px;
  margin: 9px 0 15px;
  display: -webkit-box;
  overflow: hidden;
  color: #8a8d99;
  font-size: 12px;
  line-height: 1.6;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
}
.slide-content > b {
  display: inline-block;
  padding: 9px 18px;
  border-radius: 50px;
  color: #fff;
  background: linear-gradient(90deg, #7957f4, #ed5d9c);
  font-size: 10px;
  opacity: 0;
  transform: translateY(6px);
  transition: 0.3s;
}
.swiper-slide-active .slide-content > b {
  opacity: 1;
  transform: none;
}
.slide-badge {
  position: absolute;
  z-index: 2;
  top: 15px;
  right: 15px;
  padding: 6px 9px;
  border-radius: 7px;
  color: #fff;
  font-size: 8px;
  font-weight: 900;
}
.tag-PICK {
  background: #7957f4;
}
.tag-BEST {
  background: #ed5d9c;
}
.tag-NEW {
  background: #38bb82;
}
.tag-UPDATE {
  background: #ff9d5c;
}
.mySwiper .swiper-pagination-bullet-active {
  width: 22px;
  border-radius: 5px;
  background: #7957f4;
}
.mySwiper .swiper-pagination {
  bottom: 80px;
}
.reward-flow {
  max-width: none;
  background: #fff;
}
.flow-grid {
  max-width: 1392px;
  margin: auto;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 15px;
}
.flow-card {
  min-height: 330px;
  padding: 24px;
  position: relative;
  border: 1px solid var(--line);
  border-radius: 24px;
}
.flow-card > b {
  color: #b3acbe;
  font-size: 11px;
  letter-spacing: 0.1em;
}
.flow-icon {
  width: 110px;
  height: 110px;
  margin: 32px auto 25px;
  display: grid;
  place-items: center;
  border-radius: 30px;
  background: #f7f4ff;
  font-size: 60px;
}
.flow-icon img {
  width: 70px;
  height: 70px;
  object-fit: contain;
}
.flow-card h3 {
  font-size: 20px;
  text-align: center;
}
.flow-card p {
  margin-top: 10px;
  color: #858894;
  font-size: 12px;
  line-height: 1.6;
  text-align: center;
}
.flow-note {
  margin-top: 20px;
  color: #aaa7b1;
  font-size: 10px;
  text-align: center;
}
.shop-section {
  max-width: none;
  padding-right: max(24px, calc((100vw - var(--content-width)) / 2));
  padding-left: max(24px, calc((100vw - var(--content-width)) / 2));
  background: #171925;
}
.shop-shell {
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: 70px;
  align-items: center;
}
.shop-copy {
  color: #fff;
}
.shop-copy p {
  color: #a9abb6;
}
.category-pills {
  margin-top: 28px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.category-pills span {
  padding: 9px 13px;
  border: 1px solid #3a3b47;
  border-radius: 50px;
  color: #d1d2d8;
  font-size: 11px;
}
.product-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 13px;
  transform: rotate(2deg);
}
.product-grid article {
  min-height: 205px;
  padding: 18px;
  border-radius: 22px;
  background: #fff;
  box-shadow: 0 18px 35px rgba(0, 0, 0, 0.18);
}
.product-emoji {
  height: 90px;
  display: grid;
  place-items: center;
  border-radius: 16px;
  background: #f6f3fb;
  font-size: 48px;
}
.product-grid article > span {
  display: block;
  margin-top: 12px;
  color: #9995a2;
  font-size: 9px;
}
.product-grid strong {
  display: block;
  margin: 4px 0 10px;
  font-size: 14px;
}
.product-grid small {
  display: flex;
  align-items: center;
  gap: 4px;
  color: #7658df;
  font-size: 9px;
  font-weight: 800;
}
.product-grid small img {
  width: 14px;
}
.ranking-section {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 90px;
  align-items: center;
}
.rank-copy ul {
  margin-top: 34px;
  display: grid;
  gap: 11px;
}
.rank-copy li {
  padding: 15px 17px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-radius: 14px;
  background: #f7f6fa;
}
.rank-copy li b {
  font-size: 13px;
}
.rank-copy li span {
  color: #91939c;
  font-size: 11px;
}
.podium {
  padding: 28px;
  border-radius: 30px;
  background: linear-gradient(150deg, #f0ebff, #fff5f8);
  box-shadow: 0 30px 60px rgba(75, 53, 133, 0.13);
}
.rank-label {
  display: flex;
  justify-content: space-between;
  font-size: 16px;
  font-weight: 900;
}
.rank-label span {
  padding: 5px 8px;
  border-radius: 6px;
  color: #8e77d8;
  background: #fff;
  font-size: 8px;
}
.podium-top {
  height: 300px;
  display: flex;
  justify-content: center;
  align-items: flex-end;
  gap: 10px;
}
.podium-user {
  width: 31%;
  padding: 22px 8px;
  display: flex;
  flex-direction: column;
  align-items: center;
  border-radius: 20px 20px 10px 10px;
  background: rgba(255, 255, 255, 0.8);
}
.podium-user.first {
  height: 245px;
  background: linear-gradient(#fff, #f2eaff);
}
.podium-user.second {
  height: 195px;
}
.podium-user.third {
  height: 165px;
}
.podium-user > span {
  font-size: 25px;
}
.podium-user i {
  width: 50px;
  height: 50px;
  margin: 10px 0;
  display: grid;
  place-items: center;
  border-radius: 50%;
  color: #fff;
  background: #9679ed;
  font-style: normal;
  font-weight: 900;
}
.podium-user b {
  font-size: 10px;
}
.podium-user small {
  margin-top: 5px;
  color: #8c8995;
  font-size: 8px;
}
.my-rank {
  margin-top: 12px;
  padding: 15px;
  display: flex;
  justify-content: space-between;
  border-radius: 12px;
  background: #fff;
  font-size: 10px;
}
.my-rank b {
  color: #7658df;
}
.faq-section {
  max-width: 980px;
}
.faq-list {
  border-top: 1px solid var(--line);
}
.faq-list details {
  border-bottom: 1px solid var(--line);
}
.faq-list summary {
  padding: 25px 4px;
  display: flex;
  justify-content: space-between;
  cursor: pointer;
  list-style: none;
  font-size: 16px;
  font-weight: 800;
}
.faq-list summary i {
  font-style: normal;
  font-weight: 400;
  transition: 0.2s;
}
.faq-list details[open] summary i {
  transform: rotate(45deg);
}
.faq-list details p {
  padding: 0 40px 25px 4px;
  color: #737681;
  font-size: 13px;
  line-height: 1.7;
}
.download-section {
  width: calc(100% - 48px);
  max-width: var(--content-width);
  margin: 0 auto 24px;
  padding: 110px 24px;
  position: relative;
  overflow: hidden;
  border-radius: 36px;
  color: #fff;
  background: linear-gradient(135deg, #6f4fdf, #a552d1 52%, #e86d93);
  text-align: center;
}
.download-inner {
  position: relative;
  z-index: 2;
}
.download-inner > img {
  width: 80px;
  height: 80px;
  margin: 0 auto 24px;
  padding: 4px;
  border-radius: 24px;
  background: #fff;
}
.download-inner > span {
  font-size: 12px;
  font-weight: 800;
  opacity: 0.75;
}
.download-inner h2 {
  margin: 14px 0 17px;
  font-size: clamp(40px, 5vw, 66px);
  line-height: 1.1;
  letter-spacing: -0.05em;
}
.download-inner > p {
  margin-bottom: 30px;
  opacity: 0.8;
}
.hero-actions.center {
  justify-content: center;
}
.store-button.light {
  color: #171925;
  background: #fff;
}
.download-orb {
  position: absolute;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.1);
}
.orb-one {
  width: 350px;
  height: 350px;
  top: -100px;
  left: -80px;
}
.orb-two {
  width: 500px;
  height: 500px;
  right: -100px;
  bottom: -300px;
}
footer {
  padding: 55px 24px;
  color: #8d8f99;
  background: #171925;
}
.footer-inner {
  max-width: 1392px;
  margin: auto;
}
.footer-brand {
  display: flex;
  align-items: center;
  gap: 8px;
  color: #fff;
}
.footer-brand img {
  width: 35px;
  height: 35px;
  padding: 2px;
  border-radius: 10px;
  background: #fff;
}
.company {
  margin: 22px 0;
  font-size: 11px;
  line-height: 1.8;
}
.footer-links {
  display: flex;
  gap: 18px;
  margin-bottom: 28px;
  color: #c3c4ca;
  font-size: 11px;
}
footer small {
  font-size: 9px;
}
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition:
    opacity 0.7s ease,
    transform 0.7s ease;
}
.reveal.visible {
  opacity: 1;
  transform: none;
}
@media (max-width: 980px) {
  .desktop-nav {
    display: none;
  }
  .hero {
    padding-top: 125px;
  }
  .hero-inner {
    grid-template-columns: 1fr;
    text-align: center;
  }
  .hero-copy {
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  .hero::after {
    background: rgba(255, 255, 255, 0.72);
  }

  .benefit-grid {
    grid-template-columns: 1fr;
  }
  .benefit-card.large {
    grid-row: auto;
    min-height: 650px;
  }
  .flow-grid {
    grid-template-columns: 1fr 1fr;
  }
  .shop-shell,
  .ranking-section {
    grid-template-columns: 1fr;
  }
  .shop-copy,
  .rank-copy {
    text-align: center;
  }
  .category-pills {
    justify-content: center;
  }
  .ranking-section {
    gap: 45px;
  }
}
@media (max-width: 640px) {
  .site-header {
    height: 62px;
    padding: 0 16px;
  }
  .brand span {
    font-size: 17px;
  }
  .brand img {
    width: 32px;
    height: 32px;
  }
  .header-cta {
    padding: 9px 12px;
    font-size: 11px;
  }
  .hero {
    min-height: auto;
    padding: 105px 18px 40px;
  }
  .hero h1 {
    font-size: 43px;
  }
  .hero-copy > p {
    font-size: 15px;
  }
  .hero-actions {
    width: 100%;
    gap: 8px;
  }
  .store-button {
    min-width: 0;
    flex: 1;
    padding: 11px 12px;
  }
  .store-button img {
    width: 23px;
    height: 23px;
  }
  .store-button span {
    font-size: 12px;
  }
  .hero-proof {
    gap: 8px;
    flex-wrap: wrap;
    justify-content: center;
  }

  .phone {
    height: 620px;
  }
  .ticker {
    padding: 14px 0;
  }
  .ticker-track {
    animation-duration: 18s;
  }
  .ticker-group {
    width: max-content;
    min-width: 100vw;
    justify-content: flex-start;
    gap: 18px;
    padding: 0 18px;
  }
  .ticker-step {
    gap: 9px;
  }
  .ticker-step b {
    width: 27px;
    height: 27px;
    flex-basis: 27px;
    font-size: 8px;
  }
  .ticker-step span {
    font-size: 10px;
  }
  .ticker-step small {
    font-size: 7px;
  }
  .ticker-group > i {
    font-size: 10px;
  }
  .section {
    padding: 90px 18px;
  }
  .section-heading {
    margin-bottom: 38px;
  }
  .section-heading h2,
  .shop-copy h2,
  .rank-copy h2 {
    font-size: 36px;
  }
  .section-heading p,
  .shop-copy p,
  .rank-copy > p {
    font-size: 14px;
  }
  .benefit-card {
    min-height: 350px;
    padding: 28px;
  }
  .benefit-card.large {
    min-height: 580px;
  }
  .game-stack img {
    width: 150px;
    height: 150px;
  }
  .game-stack img:nth-child(1) {
    left: 20px;
  }
  .game-stack img:nth-child(2) {
    right: 20px;
  }
  .flow-grid {
    grid-template-columns: 1fr 1fr;
    gap: 9px;
  }
  .flow-card {
    min-height: 270px;
    padding: 16px;
  }
  .flow-icon {
    width: 80px;
    height: 80px;
    margin: 25px auto 20px;
  }
  .flow-icon img {
    width: 55px;
    height: 55px;
  }
  .flow-card h3 {
    font-size: 16px;
  }
  .shop-section {
    padding: 90px 18px;
  }
  .shop-shell {
    gap: 45px;
  }
  .product-grid {
    gap: 8px;
    transform: none;
  }
  .product-grid article {
    min-height: 180px;
    padding: 11px;
  }
  .product-emoji {
    height: 76px;
    font-size: 40px;
  }
  .ranking-section {
    padding: 90px 18px;
  }
  .rank-copy li {
    align-items: flex-start;
    flex-direction: column;
    gap: 4px;
  }
  .podium {
    padding: 18px 12px;
  }
  .podium-top {
    height: 260px;
  }
  .download-section {
    width: auto;
    margin: 0 12px 12px;
    padding: 80px 18px;
    border-radius: 28px;
  }
  .download-inner h2 {
    font-size: 39px;
  }
  .footer-links {
    flex-wrap: wrap;
  }
  .reveal {
    transform: translateY(15px);
  }
}

/* Centered hero */
.hero {
  min-height: 760px;
  justify-content: center;
  background: #fff;
}
.hero-art,
.hero::after {
  display: none;
}
.hero-art {
  display: block;
  background:
    radial-gradient(circle at 18% 34%, rgba(121, 87, 244, 0.09) 0 110px, transparent 112px),
    radial-gradient(circle at 82% 28%, rgba(237, 93, 156, 0.08) 0 145px, transparent 147px),
    radial-gradient(circle at 72% 78%, rgba(255, 157, 92, 0.07) 0 95px, transparent 97px);
  opacity: 1;
}
html body .games-section,
html body .earn-section,
html body .shop-section,
html body .ranking-section {
  background: #fff;
}
.hero-inner {
  max-width: 1320px;
  grid-template-columns: 1fr;
  text-align: center;
}
.hero-copy {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.hero h1 {
  width: max-content;
  font-size: clamp(52px, 6vw, 78px);
  text-align: left;
}
.hero h1 > span,
.hero h1 > em {
  display: block;
  width: max-content;
  min-height: 1.08em;
  position: relative;
  white-space: nowrap;
}
.hero h1 .typing-measure {
  position: static;
  visibility: hidden;
}
.hero h1 .typing-output {
  position: absolute;
  inset: 0 auto auto 0;
  white-space: nowrap;
}
.hero h1 em .typing-output {
  color: transparent;
  background: linear-gradient(90deg, #7957f4, #ed5d9c 48%, #ff9d5c);
  background-clip: text;
  -webkit-background-clip: text;
}
.hero h1 > span:nth-child(2) {
  transform: translateX(1em);
}
.hero h1 em {
  margin-top: 8px;
  color: transparent;
  background: linear-gradient(90deg, #7957f4, #ed5d9c 48%, #ff9d5c);
  background-clip: text;
  -webkit-background-clip: text;
  font-style: normal;
  transform: translateX(1.5em);
}
.hero-copy > p {
  text-align: center;
}
.hero-copy.is-typing.reveal {
  opacity: 1;
  transform: none;
}
.hero-copy.is-typing h1 > * {
  visibility: hidden;
}
.hero-copy.is-typing h1 > *.typing-active,
.hero-copy.is-typing h1 > *.typing-complete {
  visibility: visible;
}
.hero-copy.is-typing h1 > *.typing-active .typing-output::after {
  content: '';
  width: 0.075em;
  height: 0.88em;
  margin-left: 0.08em;
  display: inline-block;
  vertical-align: -0.05em;
  background: #7957f4;
  animation: hero-caret-blink 0.72s steps(1) infinite;
}
.hero-copy.is-typing > p,
.hero-copy.is-typing > .hero-actions,
.hero-copy.is-typing > .hero-proof {
  opacity: 0;
  transform: translateY(30px);
}
.hero-copy.intro-complete > p,
.hero-copy.intro-complete > .hero-actions,
.hero-copy.intro-complete > .hero-proof {
  opacity: 1;
  transform: translateY(0);
  transition:
    opacity 0.7s ease,
    transform 0.7s cubic-bezier(0.2, 0.75, 0.25, 1);
}
.hero-copy.intro-complete > .hero-actions {
  transition-delay: 0.12s;
}
.hero-copy.intro-complete > .hero-proof {
  transition-delay: 0.22s;
}
.hero-scroll-down {
  width: 48px;
  height: 64px;
  position: absolute;
  bottom: 24px;
  left: 50%;
  z-index: 3;
  display: grid;
  place-items: center;
  border: 1px solid rgba(121, 87, 244, 0.18);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 10px 30px rgba(65, 45, 120, 0.08);
  transform: translateX(-50%);
  backdrop-filter: blur(10px);
}
.hero-scroll-down span {
  width: 13px;
  height: 13px;
  border-right: 2px solid #7957f4;
  border-bottom: 2px solid #7957f4;
  transform: translateY(-5px) rotate(45deg);
  animation: hero-arrow-down 1.5s ease-in-out infinite;
}
.hero-scroll-down:hover {
  border-color: rgba(121, 87, 244, 0.38);
  background: #fff;
}
@keyframes hero-caret-blink {
  50% {
    opacity: 0;
  }
}
@keyframes hero-arrow-down {
  0%,
  100% {
    opacity: 0.35;
    transform: translateY(-6px) rotate(45deg);
  }
  50% {
    opacity: 1;
    transform: translateY(7px) rotate(45deg);
  }
}
@media (min-width: 981px) {
  .hero {
    min-height: 100vh;
    padding-top: 72px;
    padding-bottom: 72px;
  }
  .hero h1 > span {
    display: block;
  }
  .hero h1 {
    display: grid;
    grid-template-columns: max-content max-content;
    column-gap: 0.18em;
    align-items: start;
    font-size: clamp(52px, 4.8vw, 72px);
  }
  .hero h1 > span:nth-child(2) {
    margin-left: 0;
    transform: translateY(0.5em);
  }
  .hero h1 > em {
    grid-column: 1 / -1;
    margin-top: 0.82em;
    transform: translateX(1.15em);
  }
}
@media (max-width: 640px) {
  .hero {
    min-height: 100svh;
    padding: 88px 16px 82px;
  }
  .hero h1 {
    width: auto;
    font-size: clamp(32px, 9vw, 42px);
  }
  .hero h1 > span:nth-child(2) {
    transform: translateX(0.65em);
  }
  .hero h1 em {
    transform: translateX(0.35em);
  }
  .hero-scroll-down {
    width: 42px;
    height: 54px;
    bottom: 14px;
    display: grid;
  }
}
@media (max-width: 980px) {
  .site-header {
    gap: 20px;
  }
  .header-cta {
    margin-left: auto;
  }
  .hero {
    min-height: 100svh;
    padding-bottom: 82px;
  }
  .hero-inner,
  .hero-copy {
    width: 100%;
    min-width: 0;
  }
  .hero-copy {
    min-height: 0;
    justify-content: center;
  }
  .hero h1 {
    display: block;
    width: max-content !important;
    max-width: 100%;
    min-width: 0 !important;
    font-size: clamp(44px, 7.8vw, 60px);
  }
  .hero h1 > span,
  .hero h1 > em {
    max-width: 100%;
  }
  .hero-copy > p {
    width: 100%;
    max-width: 620px;
    margin-top: 28px;
    margin-bottom: 0;
  }
  .hero-actions {
    width: min(100%, 400px);
    margin-top: clamp(56px, 8svh, 82px);
    justify-content: center;
  }
  .hero-actions .store-button {
    min-width: 0;
    flex: 1;
    max-width: none;
    justify-content: center;
  }
  .hero-scroll-down {
    display: grid;
  }
}
@media (max-width: 640px) {
  .hero-copy {
    min-height: 0;
  }
  .hero h1 {
    font-size: clamp(38px, 8vw, 48px);
  }
  .hero-art {
    background:
      radial-gradient(circle at 8% 31%, rgba(121, 87, 244, 0.08) 0 74px, transparent 76px),
      radial-gradient(circle at 92% 38%, rgba(237, 93, 156, 0.07) 0 92px, transparent 94px),
      radial-gradient(circle at 70% 78%, rgba(255, 157, 92, 0.06) 0 62px, transparent 64px);
  }
}
@media (prefers-reduced-motion: reduce) {
  .hero-copy.is-typing h1 > * {
    visibility: visible;
  }
  .hero-copy.is-typing h1 > *.typing-active .typing-output::after {
    display: none;
  }
  .hero-copy.is-typing > p,
  .hero-copy.is-typing > .hero-actions,
  .hero-copy.is-typing > .hero-proof {
    opacity: 1;
    transform: none;
  }
  .hero-scroll-down span {
    animation: none;
    transform: rotate(45deg);
  }
}

/* Compact app introduction and real exchange catalogue */
.intro {
  padding-top: 105px;
  padding-bottom: 110px;
}
.app-intro-head {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 70px;
  align-items: end;
  margin-bottom: 40px;
}
.app-intro-head h2 {
  font-size: clamp(36px, 4vw, 54px);
  line-height: 1.18;
  letter-spacing: -0.05em;
}
.app-intro-head > p {
  padding-bottom: 4px;
  color: var(--sub);
  font-size: 15px;
  line-height: 1.8;
}
.feature-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  margin-bottom: 58px;
  border: 1px solid var(--line);
  border-radius: 22px;
  background: #fff;
  box-shadow: 0 14px 38px rgba(41, 33, 71, 0.05);
}
.feature-strip > div {
  min-width: 0;
  padding: 20px;
  display: flex;
  align-items: center;
  gap: 13px;
  border-right: 1px solid var(--line);
}
.feature-strip > div:last-child {
  border-right: 0;
}
.feature-strip img {
  width: 42px;
  height: 42px;
  flex: 0 0 42px;
  object-fit: contain;
}
.feature-strip span {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.feature-strip b {
  font-size: 13px;
}
.feature-strip small {
  overflow: hidden;
  color: #8b8e99;
  font-size: 10px;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.screen-showcase {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 34px;
  align-items: start;
}
.screen-slot {
  text-align: center;
}
.screen-slot.featured {
  margin-top: -22px;
}
.screen-frame {
  max-width: 270px;
  aspect-ratio: 9/19.5;
  margin: auto;
  padding: 9px;
  border-radius: 35px;
  background: #171925;
  box-shadow: 0 24px 48px rgba(30, 25, 55, 0.14);
}
.screen-placeholder {
  height: 100%;
  padding: 24px 18px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  border: 1px dashed #d7cffa;
  border-radius: 27px;
  background: linear-gradient(160deg, #faf8ff, #f2effb);
  color: #76669e;
}
.screen-placeholder span {
  margin-bottom: 14px;
  padding: 6px 9px;
  border-radius: 50px;
  background: #e9e3fb;
  font-size: 8px;
  font-weight: 900;
  letter-spacing: 0.14em;
}
.screen-placeholder strong {
  color: #322b43;
  font-size: 18px;
}
.screen-placeholder small {
  margin-top: 12px;
  color: #8c849d;
  font-size: 10px;
  line-height: 1.6;
}
.screen-slot figcaption {
  margin-top: 19px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.screen-slot figcaption b {
  font-size: 15px;
}
.screen-slot figcaption span {
  color: #8a8d97;
  font-size: 11px;
}
.shot-guide {
  margin-top: 42px;
  padding: 15px 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  border-radius: 13px;
  color: #777481;
  background: #f7f6f9;
  font-size: 10px;
}
.shot-guide b {
  margin-right: 4px;
  color: #34313b;
}
.shot-guide code {
  padding: 5px 7px;
  border-radius: 5px;
  color: #7056cc;
  background: #ebe7f6;
}
.shot-guide span {
  margin-left: 5px;
}
.shop-section {
  max-width: none;
  padding-right: max(24px, calc((100vw - var(--content-width)) / 2));
  padding-left: max(24px, calc((100vw - var(--content-width)) / 2));
  color: var(--ink);
  background: #f7f7fa;
}
.shop-shell {
  grid-template-columns: 0.72fr 1.28fr;
  gap: 64px;
}
.shop-copy {
  color: var(--ink);
}
.shop-copy p {
  color: var(--sub);
}
.shop-copy h2 span {
  white-space: nowrap;
}
.provider-row {
  margin-top: 27px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.provider-row span {
  padding: 9px 12px;
  display: flex;
  align-items: center;
  gap: 7px;
  border: 1px solid #e3e1e8;
  border-radius: 10px;
  background: #fff;
  font-size: 10px;
  font-weight: 800;
}
.provider-row b {
  width: 18px;
  height: 18px;
  display: grid;
  place-items: center;
  border-radius: 6px;
  color: #171925;
  background: #fee500;
  font-size: 9px;
}
.provider-row span:last-child b {
  color: #fff;
  background: #7a5ae5;
}
.category-pills span {
  border-color: #e3e1e8;
  color: #6f707a;
  background: #fff;
}
.product-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  transform: none;
}
.product-grid article {
  min-width: 0;
  min-height: 0;
  padding: 12px;
  border: 1px solid #ebe9ef;
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 10px 28px rgba(32, 27, 48, 0.05);
}
.product-image {
  height: 126px;
  display: grid;
  place-items: center;
  overflow: hidden;
  border-radius: 12px;
  background: #f7f7f9;
}
.product-image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  transition: transform 0.25s;
}
.product-grid article:hover .product-image img {
  transform: scale(1.04);
}
.product-grid article > span {
  display: block;
  margin-top: 11px;
  color: #8d8996;
  font-size: 8px;
}
.product-grid strong {
  display: block;
  margin: 4px 0 7px;
  overflow: hidden;
  font-size: 12px;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.product-grid small {
  color: #775bd7;
  font-size: 8px;
  font-weight: 700;
}
.product-note {
  margin-top: 22px;
  color: #9b98a3;
  font-size: 9px;
  text-align: right;
}
.product-wall {
  min-width: 0;
  padding: 24px 18px 5px;
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 14px;
  overflow: hidden;
  border-radius: 30px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.9), rgba(255, 255, 255, 0.25));
  perspective: 900px;
  mask-image: none;
  -webkit-mask-image: none;
}
.product-wall-row {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 12px;
  transform: rotateX(8deg);
  transform-origin: center top;
}
.product-wall-row:nth-child(2) {
  transform: translateX(-18px) rotateX(10deg) scale(0.96);
}
.product-wall-row:nth-child(3) {
  opacity: 0.72;
  transform: translateX(10px) rotateX(13deg) scale(0.9);
}
.product-wall-row:nth-child(4) {
  opacity: 1;
  margin-top: 0;
  transform: translateX(-12px) rotateX(15deg) scale(0.84);
  mask-image: linear-gradient(180deg, #000 0%, #000 35%, transparent 72%, transparent 100%);
  -webkit-mask-image: linear-gradient(180deg, #000 0%, #000 35%, transparent 72%, transparent 100%);
}
@media (min-width: 981px) {
  .product-wall {
    height: auto;
    min-height: 620px;
  }
}
.product-wall-row span {
  aspect-ratio: 1 / 1.04;
  min-width: 0;
  padding: 3px;
  display: grid;
  place-items: center;
  overflow: hidden;
  border: 1px solid rgba(235, 232, 241, 0.9);
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 13px 25px rgba(42, 34, 66, 0.09);
}
.product-wall-row img {
  width: 100%;
  height: 100%;
  transform: scale(1.1);
  object-fit: contain;
}
@media (max-width: 980px) {
  .product-wall {
    min-height: 430px;
  }
}
@media (max-width: 640px) {
  .product-wall {
    min-height: 350px;
    padding: 18px 10px 0;
    gap: 9px;
    border-radius: 24px;
  }
  .product-wall-row {
    gap: 7px;
  }
  .product-wall-row span {
    padding: 5px;
    border-radius: 12px;
  }
}
.rank-screen-wrap {
  text-align: center;
}
.rank-screen-frame {
  max-width: 280px;
}
.rank-screen-wrap code {
  display: inline-block;
  margin-top: 17px;
  padding: 6px 9px;
  border-radius: 6px;
  color: #7056cc;
  background: #f0ecfa;
  font-size: 9px;
}
@media (max-width: 980px) {
  .app-intro-head {
    grid-template-columns: 1fr;
    gap: 18px;
    text-align: center;
  }
  .feature-strip {
    grid-template-columns: 1fr 1fr;
  }
  .feature-strip > div:nth-child(2) {
    border-right: 0;
  }
  .feature-strip > div:nth-child(-n + 2) {
    border-bottom: 1px solid var(--line);
  }
  .screen-showcase {
    gap: 18px;
  }
  .screen-frame {
    max-width: 240px;
  }
  .shop-shell {
    grid-template-columns: 1fr;
  }
  .product-grid {
    max-width: 720px;
    margin: auto;
  }
}
@media (max-width: 640px) {
  .intro {
    padding-top: 80px;
    padding-bottom: 85px;
  }
  .feature-strip {
    margin-bottom: 42px;
  }
  .feature-strip > div {
    padding: 14px 11px;
    gap: 8px;
  }
  .feature-strip img {
    width: 34px;
    height: 34px;
    flex-basis: 34px;
  }
  .feature-strip small {
    display: none;
  }
  .screen-showcase {
    grid-template-columns: 1fr;
    gap: 44px;
  }
  .screen-slot.featured {
    margin-top: 0;
  }
  .screen-frame {
    max-width: 235px;
  }
  .shot-guide {
    align-items: flex-start;
    flex-direction: column;
  }
  .shot-guide code {
    width: 100%;
  }
  .shop-section {
    padding: 85px 18px;
  }
  .product-grid {
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }
  .product-image {
    height: 105px;
  }
  .provider-row,
  .category-pills {
    justify-content: center;
  }
  .product-note {
    text-align: center;
  }
}

/* Live ranking */
.live-ranking {
  padding: 26px;
  border: 1px solid #e8e5ee;
  border-radius: 28px;
  background: #fff;
  box-shadow: 0 25px 55px rgba(44, 34, 75, 0.1);
}
.ranking-tabs {
  padding: 4px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-radius: 13px;
  background: #f1eff5;
}
.ranking-tab {
  padding: 11px;
  border: 0;
  border-radius: 10px;
  color: #85818d;
  background: transparent;
  font-family: inherit;
  font-size: 12px;
  font-weight: 800;
  cursor: pointer;
}
.ranking-tab.active {
  color: #fff;
  background: #171925;
  box-shadow: 0 5px 13px rgba(23, 25, 37, 0.16);
}
.ranking-period {
  margin: 20px 0 8px;
  color: #8b8793;
  font-size: 10px;
  text-align: center;
}
.tier-panel {
  margin: 14px 0 -4px;
  padding: 16px;
  position: relative;
  overflow: hidden;
  border: 1px solid #e5ddfb;
  border-radius: 18px;
  background:
    radial-gradient(circle at 95% 0, rgba(232, 98, 155, 0.1), transparent 30%),
    linear-gradient(135deg, #faf8ff, #fff);
  box-shadow: inset 0 1px rgba(255, 255, 255, 0.8);
}
.tier-live-line {
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.tier-live-line > span {
  padding: 5px 7px;
  display: flex;
  align-items: center;
  gap: 6px;
  border-radius: 50px;
  color: #6e4fd2;
  background: #eee9ff;
  font-size: 7px;
  font-weight: 900;
  letter-spacing: 0.12em;
}
.tier-live-line > span i {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #7b59e4;
  box-shadow: 0 0 0 0 rgba(123, 89, 228, 0.45);
  animation: live-pulse 1.5s infinite;
}
.tier-live-line .ranking-period {
  margin: 0;
  color: #7d758b;
  font-size: 9px;
  font-style: normal;
  font-weight: 700;
  text-align: center;
  white-space: nowrap;
}
.tier-live-line > b {
  margin-left: auto;
  color: #8b8497;
  font-size: 8px;
  opacity: 0.7;
  text-align: right;
  white-space: nowrap;
  transition:
    opacity 0.2s,
    transform 0.2s;
}
.tier-live-line > b.show {
  opacity: 1;
  transform: translateY(0);
}
.tier-panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.tier-panel-head span {
  font-size: 13px;
  font-weight: 900;
}
.tier-panel-head span i {
  font-style: normal;
}
.tier-panel-head b {
  color: #7659d7;
  font-size: 12px;
  font-weight: 800;
}
.tier-panel-head b i {
  font-style: normal;
}
.ranking-secret {
  display: inline-block;
  filter: blur(5px);
  user-select: none;
}
.tier-progress {
  height: 14px;
  margin: 14px 0 8px;
  position: relative;
  overflow: hidden;
  border-radius: 14px;
  background: #e9e6ef;
  box-shadow: inset 0 2px 4px rgba(43, 32, 70, 0.08);
}
.tier-progress > i {
  display: block;
  width: 0;
  height: 100%;
  position: relative;
  overflow: visible;
  border-radius: inherit;
  background: linear-gradient(90deg, #7957f4, #bd5fe3 50%, #ff8269 100%);
  box-shadow: 0 0 18px rgba(237, 93, 156, 0.36);
}
.tier-progress > i::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(
    105deg,
    transparent 20%,
    rgba(255, 255, 255, 0.65) 45%,
    transparent 70%
  );
  background-size: 80px 100%;
  animation: progress-shine 1.5s linear infinite;
}
.tier-progress-copy {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  color: #a09aa9;
  font-size: 7px;
}
.tier-progress-copy b {
  color: #755fc0;
  font-size: 8px;
}
.tier-progress-copy span:last-child {
  text-align: right;
}
@keyframes live-pulse {
  70% {
    box-shadow: 0 0 0 7px rgba(123, 89, 228, 0);
  }
}
@keyframes progress-shine {
  to {
    background-position: 80px 0;
  }
}
.tier-reward-preview {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 7px;
}
.tier-reward-preview > span {
  margin-right: auto;
  color: #8d8995;
  font-size: 8px;
}
.tier-reward-preview > b {
  padding: 6px 8px;
  display: flex;
  align-items: center;
  gap: 4px;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 4px 12px rgba(50, 39, 78, 0.06);
}
.tier-reward-preview img {
  width: 16px;
  height: 16px;
  object-fit: contain;
}
.tier-reward-preview em {
  color: #5f4aa8;
  font-size: 9px;
  font-style: normal;
}
.ranking-podium {
  min-height: 330px;
  margin-top: -28px;
  padding: 30px 12px 0;
  position: relative;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  gap: 10px;
  overflow: hidden;
  border-radius: 22px;
  background:
    radial-gradient(circle at 50% 22%, rgba(255, 215, 96, 0.2), transparent 24%),
    linear-gradient(180deg, #f9f7ff 0%, #f1edf9 100%);
}
.ranking-podium::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    115deg,
    transparent 35%,
    rgba(255, 255, 255, 0.55) 50%,
    transparent 65%
  );
  pointer-events: none;
}
.ranking-loading {
  width: 100%;
  margin: auto;
  color: #96929d;
  font-size: 12px;
  text-align: center;
}
.live-rank {
  width: 31%;
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.live-rank.rank-1 {
  z-index: 3;
}
.rank-crown {
  height: 28px;
  margin-bottom: 3px;
  color: #e6aa24;
  font-size: 29px;
  line-height: 1;
  text-shadow: 0 5px 12px rgba(197, 139, 20, 0.2);
}
.rank-avatar {
  width: 64px;
  height: 64px;
  position: relative;
  display: grid;
  place-items: center;
  overflow: visible;
  border: 4px solid #c4c8d0;
  border-radius: 50%;
  color: #fff;
  background: linear-gradient(135deg, #7a5ae5, #e9679a);
  box-shadow: 0 12px 25px rgba(60, 45, 100, 0.18);
  font-size: 20px;
  font-weight: 900;
}
.rank-1 .rank-avatar {
  width: 82px;
  height: 82px;
  border-color: #f2be3f;
  box-shadow:
    0 0 0 6px rgba(242, 190, 63, 0.13),
    0 16px 32px rgba(116, 77, 16, 0.2);
}
.rank-2 .rank-avatar {
  border-color: #b9c2d1;
}
.rank-3 .rank-avatar {
  border-color: #c8895f;
}
.rank-avatar img {
  width: 100%;
  height: 100%;
  overflow: hidden;
  border-radius: 50%;
  object-fit: cover;
}
.rank-avatar > span {
  display: grid;
  place-items: center;
}
.rank-avatar i {
  width: 25px;
  height: 25px;
  position: absolute;
  right: -7px;
  bottom: -5px;
  display: grid;
  place-items: center;
  border: 3px solid #fff;
  border-radius: 50%;
  color: #fff;
  background: #9da6b6;
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
}
.rank-1 .rank-avatar i {
  color: #6c4b00;
  background: #f5c84d;
}
.rank-3 .rank-avatar i {
  background: #bc7951;
}
.rank-player {
  width: 100%;
  min-height: 62px;
  padding: 14px 3px 10px;
  text-align: center;
}
.rank-player b {
  display: block;
  overflow: hidden;
  font-size: 10px;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.rank-player strong {
  display: block;
  margin-top: 5px;
  color: #6045bc;
  font-size: 12px;
}
.rank-player strong small {
  color: #a39dac;
  font-size: 6px;
  letter-spacing: 0.08em;
}
.podium-block {
  width: 100%;
  min-height: 92px;
  padding: 14px 5px;
  display: flex;
  flex-direction: column;
  align-items: center;
  border-radius: 15px 15px 0 0;
  background: linear-gradient(180deg, #d7dbe4, #aeb6c5);
  box-shadow:
    inset 0 1px rgba(255, 255, 255, 0.7),
    0 14px 25px rgba(49, 39, 75, 0.12);
}
.rank-1 .podium-block {
  min-height: 140px;
  color: #654500;
  background: linear-gradient(180deg, #ffe388, #e9b72f);
}
.rank-3 .podium-block {
  min-height: 72px;
  color: #fff;
  background: linear-gradient(180deg, #d49a72, #aa6741);
}
.podium-block > span {
  font-size: 27px;
  font-weight: 900;
  line-height: 1;
}
.podium-block > small {
  margin-top: 8px;
  font-size: 6px;
  font-weight: 900;
  letter-spacing: 0.1em;
  opacity: 0.7;
}
.ranking-foot {
  margin-top: 13px;
  padding: 13px 15px;
  display: flex;
  justify-content: space-between;
  border-radius: 12px;
  background: #f7f6f9;
  font-size: 9px;
}
.ranking-foot span {
  color: #96929d;
}
.ranking-foot b {
  color: #625377;
}
@media (max-width: 640px) {
  .live-ranking {
    padding: 17px 10px;
  }
  .ranking-podium {
    min-height: 295px;
    padding: 22px 6px 0;
    gap: 5px;
  }
  .rank-avatar {
    width: 49px;
    height: 49px;
  }
  .rank-1 .rank-avatar {
    width: 62px;
    height: 62px;
  }
  .rank-player {
    min-height: 57px;
  }
  .rank-player b {
    font-size: 8px;
  }
  .rank-player strong {
    font-size: 9px;
  }
  .podium-block {
    min-height: 84px;
  }
  .rank-1 .podium-block {
    min-height: 125px;
  }
  .rank-3 .podium-block {
    min-height: 65px;
  }
}

/* Compact reward path using only real in-app assets. */
.reward-flow {
  padding-top: 100px;
  padding-bottom: 105px;
  background: #f8f7fa;
}
.reward-flow .section-heading {
  margin-bottom: 42px;
}
.flow-grid {
  position: relative;
  gap: 14px;
}
.flow-grid::before {
  content: '';
  height: 2px;
  position: absolute;
  z-index: 0;
  top: 87px;
  right: 11%;
  left: 11%;
  background: linear-gradient(90deg, #dcd4f8, #c9baf4 45%, #f1bfd4 75%, #ffd1b6);
}
.flow-card {
  min-height: 238px;
  padding: 21px 18px 23px;
  z-index: 1;
  border-color: #e8e5ee;
  border-radius: 20px;
  background: #fff;
  box-shadow: 0 12px 28px rgba(45, 34, 73, 0.05);
}
.flow-card > b {
  display: block;
  color: #8d75da;
  font-size: 8px;
  letter-spacing: 0.14em;
}
.flow-icon {
  width: 82px;
  height: 82px;
  margin: 17px auto;
  position: relative;
  border: 7px solid #f8f7fa;
  border-radius: 25px;
  background: #f0ebff;
  box-shadow: 0 8px 18px rgba(50, 35, 91, 0.09);
}
.flow-icon img {
  width: 54px;
  height: 54px;
  border-radius: 12px;
  object-fit: contain;
}
.flow-icon.score {
  background: #edf2ff;
}
.flow-icon.point {
  background: #fff6da;
}
.flow-icon.products {
  display: flex;
  gap: 0;
  overflow: visible;
  background: #fff1e9;
}
.flow-icon.products img {
  width: 48px;
  height: 48px;
  position: absolute;
  border: 3px solid #fff;
  border-radius: 13px;
  background: #fff;
  box-shadow: 0 6px 12px rgba(40, 32, 60, 0.12);
}
.flow-icon.products img:first-child {
  left: 4px;
  transform: rotate(-7deg);
}
.flow-icon.products img:last-child {
  right: 4px;
  transform: rotate(7deg);
}
.flow-card h3 {
  font-size: 17px;
}
.flow-card p {
  margin-top: 8px;
  font-size: 10px;
  line-height: 1.65;
}
@media (max-width: 980px) {
  .flow-grid::before {
    display: none;
  }
}
@media (max-width: 640px) {
  .reward-flow {
    padding-top: 80px;
    padding-bottom: 85px;
  }
  .flow-grid {
    grid-template-columns: 1fr 1fr;
  }
  .flow-card {
    min-height: 220px;
    padding: 17px 10px;
  }
  .flow-icon {
    width: 72px;
    height: 72px;
  }
  .flow-icon img {
    width: 47px;
    height: 47px;
  }
  .flow-card h3 {
    font-size: 15px;
  }
}

/* Dense benefit bento: many non-game earning paths, no tutorial steps. */
.earn-section {
  padding-top: 105px;
  padding-bottom: 105px;
}
.earn-heading {
  margin-bottom: 42px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 70px;
  align-items: end;
}
.earn-heading h2 {
  font-size: clamp(38px, 4vw, 56px);
  line-height: 1.15;
  letter-spacing: -0.05em;
}
.earn-heading > p {
  padding-bottom: 5px;
  color: var(--sub);
  font-size: 15px;
  line-height: 1.75;
}
.benefit-mosaic {
  height: 570px;
  position: relative;
}
.benefit-tile {
  min-width: 0;
  padding: 22px;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  overflow: hidden;
  border-radius: 24px;
  background: #f5f3fb;
}
.benefit-tile div {
  position: relative;
  z-index: 2;
}
.benefit-tile span {
  display: block;
  margin-bottom: 8px;
  color: #8268d8;
  font-size: 8px;
  font-weight: 900;
  letter-spacing: 0.13em;
}
.benefit-tile h3 {
  font-size: 19px;
  letter-spacing: -0.035em;
}
.benefit-tile p {
  margin-top: 7px;
  color: #777481;
  font-size: 10px;
  line-height: 1.55;
}
.benefit-tile img {
  max-width: 110px;
  max-height: 110px;
  position: relative;
  z-index: 1;
  object-fit: contain;
  filter: drop-shadow(0 14px 18px rgba(47, 35, 76, 0.14));
}
.benefit-tile::after {
  content: '';
  width: 130px;
  height: 130px;
  position: absolute;
  right: -42px;
  bottom: -55px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.45);
}
.benefit-tile {
  position: absolute;
  box-shadow: 0 18px 40px rgba(39, 30, 66, 0.07);
  transition:
    transform 0.25s,
    box-shadow 0.25s;
}
.benefit-tile:hover {
  z-index: 5 !important;
  transform: translateY(-6px) rotate(0) !important;
  box-shadow: 0 26px 50px rgba(39, 30, 66, 0.13);
}
.benefit-tile.attendance {
  width: 340px;
  height: 180px;
  top: 24px;
  left: 0;
  background: linear-gradient(135deg, #edf2ff, #f6f4ff);
  transform: rotate(-1.2deg);
}
.benefit-tile.walking {
  width: 290px;
  height: 140px;
  top: 0;
  left: 370px;
  background: linear-gradient(135deg, #eaf9f1, #f5fbf8);
  transform: rotate(1.1deg);
}
.benefit-tile.touch {
  width: 320px;
  height: 180px;
  top: 30px;
  right: 0;
  background: linear-gradient(135deg, #fff0ed, #fff8f4);
  transform: rotate(1.4deg);
}
.benefit-tile.wheel {
  width: 230px;
  height: 150px;
  top: 230px;
  left: 90px;
  flex-direction: column;
  justify-content: center;
  text-align: center;
  background: #f6f2ff;
  transform: rotate(1.6deg);
}
.benefit-tile.wheel img {
  width: 78px;
  height: 78px;
  margin-bottom: 4px;
}
.benefit-tile.ox {
  width: 190px;
  height: 155px;
  top: 178px;
  left: 375px;
  flex-direction: column;
  justify-content: center;
  text-align: center;
  background: #fff1f2;
  transform: rotate(-1.3deg);
}
.benefit-tile.ox img {
  width: 65px;
  height: 65px;
  margin-bottom: 7px;
}
.benefit-tile.number {
  width: 315px;
  height: 150px;
  top: 240px;
  right: 210px;
  background: linear-gradient(135deg, #e9f8f4, #f4fbf9);
  transform: rotate(-0.8deg);
}
.benefit-tile.fortune {
  width: 280px;
  height: 140px;
  bottom: 12px;
  left: 0;
  background: linear-gradient(135deg, #fff5df, #fffaf1);
  transform: rotate(0.9deg);
}
.benefit-tile.fortune img {
  width: 75px;
  height: 75px;
}
.benefit-tile.mission {
  width: 390px;
  height: 145px;
  bottom: 18px;
  left: 325px;
  background: linear-gradient(135deg, #eaf3ff, #f5f9ff);
  transform: rotate(-0.7deg);
}
.benefit-tile.video {
  width: 305px;
  height: 135px;
  right: 0;
  bottom: 8px;
  background: linear-gradient(135deg, #f3f3f5, #fafafa);
  transform: rotate(1.2deg);
}
.benefit-tile.video img {
  width: 68px;
  height: 68px;
}
.earn-note {
  margin-top: 18px;
  color: #aaa6b0;
  font-size: 9px;
  text-align: right;
}
@media (max-width: 1180px) and (min-width: 981px) {
  .benefit-mosaic {
    transform: scale(0.88);
    transform-origin: top center;
    margin-bottom: -55px;
  }
}
@media (max-width: 980px) {
  .earn-heading {
    grid-template-columns: 1fr;
    gap: 17px;
    text-align: center;
  }
  .benefit-mosaic {
    height: auto;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }
  .benefit-tile,
  .benefit-tile.attendance,
  .benefit-tile.walking,
  .benefit-tile.touch,
  .benefit-tile.wheel,
  .benefit-tile.ox,
  .benefit-tile.number,
  .benefit-tile.fortune,
  .benefit-tile.mission,
  .benefit-tile.video {
    width: auto;
    height: 145px;
    position: relative;
    inset: auto;
    transform: none;
  }
  .benefit-tile.attendance,
  .benefit-tile.number,
  .benefit-tile.mission {
    grid-column: span 2;
  }
}
@media (max-width: 640px) {
  .earn-section {
    padding-top: 82px;
    padding-bottom: 85px;
  }
  .benefit-mosaic {
    gap: 9px;
  }
  .benefit-tile,
  .benefit-tile.attendance,
  .benefit-tile.walking,
  .benefit-tile.touch,
  .benefit-tile.wheel,
  .benefit-tile.ox,
  .benefit-tile.number,
  .benefit-tile.fortune,
  .benefit-tile.mission,
  .benefit-tile.video {
    height: 135px;
    padding: 15px;
    border-radius: 19px;
  }
  .benefit-tile h3 {
    font-size: 15px;
  }
  .benefit-tile p {
    font-size: 9px;
  }
  .benefit-tile img {
    max-width: 78px;
    max-height: 78px;
  }
  .earn-note {
    text-align: center;
  }
}

/* Benefit directory */
.benefit-directory {
  display: grid;
  grid-template-columns: 0.82fr 1.18fr;
  gap: 58px;
  align-items: center;
}
.benefit-directory .earn-heading {
  margin: 0;
  display: block;
  text-align: left;
}
.benefit-copy-stack {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.benefit-copy-stack .kicker {
  margin-bottom: 18px;
}
.benefit-directory .earn-heading p {
  max-width: 430px;
  margin-top: 24px;
  color: var(--sub);
  font-size: 16px;
  line-height: 1.8;
}
.benefit-directory .earn-heading h2 span {
  white-space: nowrap;
}
.benefit-click-guide {
  margin-top: 18px;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: #7659d7;
  font-size: 12px;
  font-weight: 800;
}
.benefit-click-guide::before {
  content: '';
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #7659d7;
  box-shadow: 0 0 0 5px rgba(118, 89, 215, 0.1);
}
.benefit-directory .earn-heading .earn-note {
  margin-top: 10px;
  padding: 0;
  font-size: 11px;
  line-height: 1.6;
  text-align: left;
}
@media (max-width: 980px) {
  .benefit-directory {
    grid-template-columns: 1fr;
    gap: 42px;
  }
  .benefit-directory .earn-heading {
    text-align: center;
  }
  .benefit-copy-stack {
    align-items: center;
  }
  .benefit-directory .earn-heading .earn-note {
    text-align: center;
  }
}

/* Reward cloud final lock. */
html body #benefits .benefit-app-grid {
  height: 500px;
  overflow: hidden;
  border: none;
  border-radius: 36px;
  background: #fff;
  box-shadow: none;
}
html body #benefits .benefit-app-grid::before {
  display: none;
}
html body #benefits .benefit-app-grid::after {
  display: none;
}
.benefit-rails {
  height: 100%;
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 20px;
  overflow: hidden;
  mask-image: linear-gradient(90deg, transparent, #000 16%, #000 84%, transparent);
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 16%, #000 84%, transparent);
}
.benefit-rail {
  width: max-content;
  display: flex;
  will-change: transform;
}
.benefit-rail-group {
  display: flex;
  gap: 20px;
  padding-right: 20px;
}
.benefit-rail-card {
  width: 160px;
  height: 190px;
  flex: 0 0 160px;
  padding: 17px 12px 14px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  border: 1px solid rgba(255, 255, 255, 0.9);
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.76);
  box-shadow: none;
}
.benefit-rail-card img {
  width: 108px;
  height: 108px;
  object-fit: contain;
}
.benefit-rail-card b {
  color: #2b2734;
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
}
.benefit-rail-card.fortune {
  position: relative;
}
.benefit-rail-icon-shine {
  width: 108px;
  height: 108px;
  position: relative;
  display: block;
  overflow: hidden;
  border-radius: 24px;
}
.benefit-rail-icon-shine::after {
  content: '';
  width: 38px;
  height: 150%;
  position: absolute;
  top: -25%;
  left: -70px;
  z-index: 2;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.48), transparent);
  transform: rotate(18deg);
  animation: benefit-fortune-shine 2.8s ease-in-out infinite;
  pointer-events: none;
}
.benefit-rail-card.featured > img {
  transform-origin: 50% 84%;
  animation: luckybox-jingle 3.2s ease-in-out infinite;
}
@keyframes benefit-fortune-shine {
  0%,
  30% {
    left: -70px;
  }
  65%,
  100% {
    left: calc(100% + 35px);
  }
}
.touchpang-stage {
  width: 108px;
  height: 108px;
  position: relative;
  display: block;
}
.benefit-rail-card .touchpang-stage > img {
  width: 124px;
  height: 124px;
  max-width: none;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.touchpang-idle {
  animation: touchpang-idle-frame 3.6s steps(1) infinite;
}
.touchpang-open {
  opacity: 0;
  animation: touchpang-open-frame 3.6s steps(1) infinite;
}
.touchpang-stage i {
  --x: -48px;
  --y: -28px;
  --s: 0.55;
  width: 16px;
  height: 16px;
  position: absolute;
  top: 62%;
  left: 50%;
  z-index: 3;
  display: grid;
  place-items: center;
  border-radius: 50%;
  color: #fff;
  background: #ffbd22;
  box-shadow: 0 3px 7px rgba(185, 119, 0, 0.24);
  font-size: 8px;
  font-style: normal;
  font-weight: 900;
  opacity: 0;
  animation: touchpang-point-in 3.6s ease-in infinite;
}
.touchpang-stage i::before {
  content: 'P';
}
.touchpang-stage i:nth-of-type(2) {
  --x: 47px;
  --y: -30px;
  --s: 0.7;
  animation-delay: 0.05s;
}
.touchpang-stage i:nth-of-type(3) {
  --x: -52px;
  --y: 4px;
  --s: 0.8;
  animation-delay: 0.1s;
}
.touchpang-stage i:nth-of-type(4) {
  --x: 52px;
  --y: 7px;
  --s: 0.5;
  animation-delay: 0.15s;
}
.touchpang-stage i:nth-of-type(5) {
  --x: -38px;
  --y: 36px;
  --s: 0.65;
  animation-delay: 0.2s;
}
.touchpang-stage i:nth-of-type(6) {
  --x: 40px;
  --y: 35px;
  --s: 0.85;
  animation-delay: 0.25s;
}
.touchpang-stage i:nth-of-type(7) {
  --x: -15px;
  --y: -48px;
  --s: 0.5;
  animation-delay: 0.3s;
}
.touchpang-stage i:nth-of-type(8) {
  --x: 20px;
  --y: -50px;
  --s: 0.72;
  animation-delay: 0.35s;
}
.touchpang-stage i:nth-of-type(9) {
  --x: -56px;
  --y: -12px;
  --s: 0.56;
  animation-delay: 0.4s;
}
.touchpang-stage i:nth-of-type(10) {
  --x: 57px;
  --y: -9px;
  --s: 0.66;
  animation-delay: 0.45s;
}
.touchpang-stage i:nth-of-type(11) {
  --x: 3px;
  --y: 47px;
  --s: 0.48;
  animation-delay: 0.5s;
}
@keyframes touchpang-idle-frame {
  0%,
  39%,
  82%,
  100% {
    opacity: 1;
  }
  40%,
  81% {
    opacity: 0;
  }
}
@keyframes touchpang-open-frame {
  0%,
  39%,
  82%,
  100% {
    opacity: 0;
  }
  40%,
  81% {
    opacity: 1;
  }
}
@keyframes touchpang-point-in {
  0%,
  41% {
    opacity: 0;
    transform: translate(var(--x), var(--y)) scale(var(--s));
  }
  47% {
    opacity: 1;
    transform: translate(var(--x), var(--y)) scale(var(--s));
  }
  72% {
    opacity: 1;
    transform: translate(0, 5px) scale(0.25);
  }
  76%,
  100% {
    opacity: 0;
    transform: translate(0, 5px) scale(0);
  }
}
.benefit-rail-runner {
  width: 108px;
  height: 108px;
  position: relative;
  display: block;
  animation: benefit-rail-runner-hop 0.42s ease-in-out infinite alternate;
}
.benefit-rail-card .benefit-rail-runner img {
  position: absolute;
  inset: 0;
  animation: benefit-rail-runner-frame-one 0.32s steps(1) infinite;
}
.benefit-rail-card .benefit-rail-runner img + img {
  opacity: 0;
  animation-name: benefit-rail-runner-frame-two;
}
@keyframes benefit-rail-runner-hop {
  from {
    transform: translateY(4px) rotate(-2deg);
  }
  to {
    transform: translateY(-5px) rotate(2deg);
  }
}
@keyframes benefit-rail-runner-frame-one {
  0%,
  49% {
    opacity: 1;
  }
  50%,
  100% {
    opacity: 0;
  }
}
@keyframes benefit-rail-runner-frame-two {
  0%,
  49% {
    opacity: 0;
  }
  50%,
  100% {
    opacity: 1;
  }
}
.benefit-rail-forward {
  animation: benefit-rail-forward 30s linear infinite;
}
.benefit-rail-reverse {
  animation: benefit-rail-reverse 32s linear infinite;
}
@keyframes benefit-rail-forward {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}
@keyframes benefit-rail-reverse {
  from {
    transform: translateX(-50%);
  }
  to {
    transform: translateX(0);
  }
}
@media (max-width: 640px) {
  html body #benefits .benefit-app-grid {
    height: 380px;
    border-radius: 28px;
  }
  .benefit-rails {
    gap: 14px;
  }
  .benefit-rail-group {
    gap: 11px;
    padding-right: 11px;
  }
  .benefit-rail-card {
    width: 104px;
    height: 145px;
    flex-basis: 104px;
    padding: 12px 8px 11px;
    border-radius: 22px;
  }
  .benefit-rail-card img {
    width: 80px;
    height: 80px;
  }
  .benefit-rail-runner {
    width: 80px;
    height: 80px;
  }
  .benefit-rail-icon-shine {
    width: 80px;
    height: 80px;
    border-radius: 18px;
  }
  .touchpang-stage {
    width: 80px;
    height: 80px;
  }
  .benefit-rail-card .touchpang-stage > img {
    width: 92px;
    height: 92px;
  }
  .benefit-rail-card b {
    font-size: 10px;
  }
}
@media (min-width: 981px) {
  #benefits .benefit-directory {
    grid-template-columns: 0.82fr 1.18fr;
    gap: 58px;
  }
  #benefits .benefit-app-grid {
    height: 530px;
    isolation: isolate;
    overflow: visible;
    border: 0;
    background: transparent;
    box-shadow: none;
  }
  #benefits .benefit-app-grid::before {
    display: none;
  }
  #benefits .benefit-app-grid::after {
    display: none;
  }
}
