﻿.lang-switcher button {
  border: 1px solid var(--color-border);
  background: rgba(255, 255, 255, 0.84);
  color: var(--color-text-muted);
  min-width: 2.35rem;
  min-height: 2.1rem;
  border-radius: 999px;
  font-size: 0.78rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  font-weight: 700;
  transition: background-color var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast);
}

.lang-switcher button:hover,
.lang-switcher button.is-active {
  background: linear-gradient(90deg, rgba(0, 87, 184, 0.18), rgba(0, 154, 192, 0.15));
  border-color: var(--color-border-strong);
  color: var(--color-text);
}

.phone-shell {
  width: min(344px, 100%);
  margin-inline: auto;
  background:
    radial-gradient(circle at 16% 9%, rgba(78, 183, 255, 0.44), transparent 54%),
    radial-gradient(circle at 84% 5%, rgba(71, 209, 127, 0.28), transparent 52%),
    linear-gradient(180deg, rgba(210, 228, 244, 0.95), rgba(189, 214, 238, 0.95));
  border: 1px solid rgba(0, 87, 184, 0.24);
  border-radius: 34px;
  padding: 0.72rem;
  box-shadow: 0 24px 46px rgba(18, 48, 91, 0.22);
  position: relative;
  transform: translateZ(0);
  transform-origin: center center;
  will-change: transform, box-shadow;
  transition:
    transform 300ms cubic-bezier(0.2, 0.8, 0.2, 1),
    box-shadow 300ms cubic-bezier(0.2, 0.8, 0.2, 1);
}

@media (hover: hover) and (pointer: fine) {
  .phone-shell:hover {
    transform: translateY(-10px) scale(1.1);
    box-shadow: 0 38px 66px rgba(18, 48, 91, 0.38);
  }
}

.phone-shell::before {
  content: "";
  position: absolute;
  inset: 0.42rem;
  border-radius: 29px;
  border: 1px solid rgba(255, 255, 255, 0.85);
  pointer-events: none;
}

.phone-shell--compact {
  width: min(360px, 100%);
}

.phone-notch {
  width: 32%;
  height: 0.44rem;
  margin: 0.08rem auto 0.58rem;
  border-radius: 999px;
  background: rgba(8, 30, 72, 0.16);
}

.phone-screen {
  position: relative;
  border-radius: 27px;
  overflow: hidden;
  border: 1px solid rgba(0, 87, 184, 0.22);
  background: linear-gradient(176deg, rgba(6, 18, 46, 0.86), rgba(5, 15, 38, 0.82));
  padding: 0.9rem;
  min-height: 25.5rem;
}

.phone-screen__real {
  position: absolute;
  inset: 0;
  z-index: 0;
  display: none;
}

.phone-screen__real::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(8, 16, 38, 0.06), rgba(8, 16, 38, 0.04));
}

.phone-screen__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
}

.phone-screen--has-shot .phone-screen__image {
  filter: brightness(1.16) saturate(1.2) contrast(0.92);
}

.phone-screen__fallback {
  position: relative;
  z-index: 2;
  isolation: isolate;
  padding-top: 0.72rem;
}

.phone-screen__fallback::before,
.phone-screen__fallback::after {
  content: "";
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
  z-index: 0;
  filter: none;
}

.phone-screen__fallback::before {
  width: 176%;
  aspect-ratio: 1 / 1;
  left: -102%;
  top: -34%;
  background: rgba(78, 183, 255, 0.44);
}

.phone-screen__fallback::after {
  width: 102%;
  aspect-ratio: 1 / 1;
  right: -46%;
  top: 38%;
  background: rgba(245, 140, 164, 0.32);
}

.phone-screen__fallback > * {
  position: relative;
  z-index: 2;
}

.phone-screen--has-shot {
  padding: 0;
  background: linear-gradient(176deg, rgba(6, 18, 46, 0.86), rgba(5, 15, 38, 0.82));
}

.phone-screen--has-shot .phone-screen__real {
  display: block;
  opacity: 0;
  pointer-events: none;
}

.phone-screen--has-shot .phone-screen__fallback {
  display: block;
  padding: 1.08rem 0.92rem 0.94rem;
}

.phone-screen::before,
.phone-screen::after {
  content: "";
  position: absolute;
  border-radius: 999px;
  pointer-events: none;
}

.phone-screen::before {
  width: 134%;
  aspect-ratio: 1 / 1;
  bottom: -62%;
  right: -18%;
  background: rgba(71, 209, 127, 0.3);
  z-index: 1;
}

.phone-screen::after {
  width: 78%;
  aspect-ratio: 1 / 1;
  top: 34%;
  right: -42%;
  background: rgba(248, 182, 79, 0.26);
  z-index: 1;
}

.app-screen-head {
  position: relative;
  padding-right: 2.35rem;
  margin-bottom: 0.86rem;
}

.app-screen-brand {
  position: absolute;
  top: 0;
  right: 0.02rem;
  width: 2rem;
  height: 2rem;
  padding: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
}

.app-screen-brand__logo {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: contain;
  border-radius: 0;
  filter: drop-shadow(0 3px 8px rgba(3, 11, 31, 0.32));
}

.app-screen-title {
  margin-top: 0.34rem;
  font-family: var(--font-heading);
  font-size: 1.66rem;
  color: #f5f9ff;
}

.app-screen-subtitle {
  margin-top: 0.34rem;
  color: rgba(221, 235, 255, 0.84);
  font-size: 0.8rem;
}

.preview-card {
  position: relative;
  margin-top: 0.64rem;
  padding: 0.78rem;
  border-radius: 1rem;
  border: 1px solid rgba(171, 211, 255, 0.28);
  background: linear-gradient(160deg, rgba(33, 65, 125, 0.66), rgba(24, 47, 96, 0.64));
  backdrop-filter: none;
  box-shadow: 0 10px 18px rgba(3, 11, 31, 0.2);
  transition: border-color var(--transition-fast), transform var(--transition-fast);
}

.preview-card:hover {
  border-color: rgba(192, 230, 255, 0.62);
  transform: translateY(-1px);
}

.preview-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.4rem;
}

.preview-label {
  color: rgba(191, 216, 255, 0.9);
  letter-spacing: 0.11em;
  text-transform: uppercase;
  font-size: 0.67rem;
}

.preview-badge,
.preview-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.22rem 0.56rem;
  border-radius: 999px;
  border: 1px solid rgba(182, 220, 255, 0.4);
  background: rgba(13, 31, 73, 0.56);
  color: #ecf6ff;
  font-size: 0.72rem;
}

.preview-pill--live {
  border-color: rgba(99, 230, 132, 0.58);
  color: #d5ffe1;
}

.preview-title {
  margin-top: 0.36rem;
  color: #f4f9ff;
  font-size: 1.02rem;
}

.preview-muted,
.preview-caption,
.preview-note {
  margin-top: 0.5rem;
  color: rgba(215, 231, 255, 0.86);
  font-size: 0.76rem;
}

.option-list,
.status-list,
.vote-list,
.challenge-grid,
.predict-grid,
.ugc-feed,
.rule-list,
.module-grid,
.mini-stat-grid,
.metrics-row {
  margin-top: 0.58rem;
  display: grid;
  gap: 0.5rem;
}

.option-item,
.status-item,
.vote-item,
.challenge-item,
.predict-item,
.ugc-item,
.rule-item,
.module-tile,
.mini-stat,
.metric-chip {
  border-radius: 12px;
  border: 1px solid rgba(182, 220, 255, 0.38);
  background: rgba(28, 56, 113, 0.9);
  color: #e9f4ff;
  padding: 0.55rem 0.62rem;
  font-size: 0.77rem;
}

.option-item--active {
  background: rgba(35, 110, 132, 0.92);
  border-color: rgba(99, 230, 132, 0.56);
}

.status-item,
.ugc-item,
.predict-item,
.mini-stat,
.module-tile {
  display: grid;
  gap: 0.16rem;
}

.status-item strong,
.challenge-item strong,
.predict-item strong,
.ugc-meta strong,
.module-tile strong,
.mini-stat strong {
  font-family: var(--font-heading);
  font-size: 0.82rem;
}

.status-item span,
.challenge-item span,
.predict-item span,
.ugc-meta span,
.module-tile span,
.mini-stat span {
  color: rgba(200, 223, 255, 0.84);
  font-size: 0.72rem;
}

.mini-stat-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.module-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  list-style: none;
}

.predict-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.vote-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.vote-meter {
  margin-top: 0.35rem;
  width: 100%;
  height: 0.38rem;
  border-radius: 999px;
  background: rgba(7, 24, 58, 0.62);
  overflow: hidden;
}

.vote-fill {
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--color-accent-cyan), var(--color-accent-green));
}

.stadium-map {
  margin-top: 0.6rem;
  min-height: 10.8rem;
  border-radius: 14px;
  border: 1px solid rgba(180, 221, 255, 0.3);
  background:
    radial-gradient(circle at 16% 20%, rgba(46, 173, 112, 0.3), transparent 48%),
    radial-gradient(circle at 84% 18%, rgba(0, 154, 192, 0.34), transparent 46%),
    linear-gradient(180deg, rgba(15, 56, 104, 0.66), rgba(11, 37, 75, 0.76));
  position: relative;
  overflow: hidden;
}

.stadium-map::before {
  content: "";
  position: absolute;
  inset: -18% -10%;
  background:
    radial-gradient(circle at 50% 54%, rgba(92, 202, 255, 0.2), transparent 52%),
    radial-gradient(circle at 50% 54%, rgba(91, 235, 178, 0.12), transparent 68%);
  pointer-events: none;
}

.stadium-map__arena {
  position: absolute;
  inset: 8% 6%;
  border-radius: 16px;
  border: 1px solid rgba(179, 222, 255, 0.24);
  background: linear-gradient(180deg, rgba(13, 39, 84, 0.34), rgba(8, 28, 63, 0.38));
}

.stadium-map__ring {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  border-radius: 999px;
  border: 1px solid rgba(170, 220, 255, 0.25);
  background: rgba(9, 34, 75, 0.16);
}

.stadium-map__ring--outer {
  width: 90%;
  height: 82%;
}

.stadium-map__ring--mid {
  width: 75%;
  height: 66%;
}

.stadium-map__ring--inner {
  width: 60%;
  height: 50%;
}

.stadium-map__pitch {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 46%;
  height: 42%;
  transform: translate(-50%, -50%);
  border-radius: 11px;
  border: 1px solid rgba(176, 230, 206, 0.46);
  background:
    radial-gradient(circle at 50% 50%, rgba(52, 196, 142, 0.2), transparent 62%),
    repeating-linear-gradient(
      0deg,
      rgba(20, 101, 75, 0.74) 0 10px,
      rgba(15, 88, 66, 0.76) 10px 20px
    );
  overflow: hidden;
}

.stadium-map__line {
  position: absolute;
  border: 1px solid rgba(214, 246, 234, 0.36);
}

.stadium-map__line--mid {
  left: 50%;
  top: 0;
  height: 100%;
  width: 0;
  border-left: 1px solid rgba(214, 246, 234, 0.36);
  border-top: 0;
  border-right: 0;
  border-bottom: 0;
  transform: translateX(-50%);
}

.stadium-map__line--box-top {
  left: 26%;
  right: 26%;
  top: 0;
  height: 18%;
  border-top: 0;
  border-radius: 0 0 6px 6px;
}

.stadium-map__line--box-bottom {
  left: 26%;
  right: 26%;
  bottom: 0;
  height: 18%;
  border-bottom: 0;
  border-radius: 6px 6px 0 0;
}

.stadium-map__circle {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 24%;
  height: 24%;
  border-radius: 999px;
  border: 1px solid rgba(214, 246, 234, 0.4);
  transform: translate(-50%, -50%);
}

.stadium-sector {
  position: absolute;
  transform: translate(-50%, -50%);
  border-radius: 999px;
  border: 1px dashed rgba(178, 223, 255, 0.36);
  background: rgba(10, 32, 70, 0.32);
  color: rgba(209, 232, 255, 0.82);
  font-size: 0.57rem;
  padding: 0.14rem 0.34rem;
  z-index: 2;
}

.stadium-sector--north {
  left: 50%;
  top: 14%;
}

.stadium-sector--east {
  left: 84%;
  top: 50%;
}

.stadium-sector--south {
  left: 50%;
  top: 86%;
}

.stadium-sector--west {
  left: 16%;
  top: 50%;
}

.map-node {
  position: absolute;
  transform: translate(-50%, -50%);
  display: inline-flex;
  align-items: center;
  gap: 0.2rem;
  padding: 0.18rem 0.42rem;
  border-radius: 999px;
  border: 1px solid rgba(185, 224, 255, 0.46);
  background: rgba(8, 26, 62, 0.62);
  color: #ebf5ff;
  font-size: 0.66rem;
  box-shadow: 0 5px 12px rgba(4, 13, 36, 0.28);
  white-space: nowrap;
  z-index: 4;
}

.map-node::before {
  content: "";
  width: 0.28rem;
  height: 0.28rem;
  border-radius: 999px;
  background: rgba(180, 221, 255, 0.8);
}

.map-node--gate {
  border-color: rgba(46, 173, 112, 0.72);
}

.map-node--gate::before {
  background: rgba(89, 236, 156, 0.9);
}

.map-node--sector::before {
  background: rgba(92, 202, 255, 0.9);
}

.map-node--food::before {
  background: rgba(255, 206, 126, 0.92);
}

.map-node--wc::before {
  background: rgba(200, 172, 255, 0.9);
}

.map-node--medic::before {
  background: rgba(255, 141, 178, 0.9);
}

.route-pill {
  margin-top: 0.54rem;
  display: inline-flex;
  padding: 0.34rem 0.62rem;
  border-radius: 999px;
  background: rgba(8, 26, 62, 0.42);
  border: 1px solid rgba(184, 222, 255, 0.28);
  color: rgba(224, 240, 255, 0.9);
  font-size: 0.72rem;
}

.fantasy-pitch {
  margin-top: 0.6rem;
  min-height: 10.8rem;
  border-radius: 14px;
  border: 1px solid rgba(180, 221, 255, 0.3);
  background:
    radial-gradient(circle at 50% 50%, rgba(46, 173, 112, 0.28), transparent 58%),
    repeating-linear-gradient(
      0deg,
      rgba(19, 92, 66, 0.72) 0 20px,
      rgba(16, 78, 57, 0.78) 20px 40px
    );
  position: relative;
  overflow: hidden;
}

.fantasy-pitch::before {
  content: "";
  position: absolute;
  inset: 9% 12%;
  border: 1px solid rgba(205, 239, 228, 0.35);
  border-radius: 10px;
}

.fantasy-player-dot {
  position: absolute;
  transform: translate(-50%, -50%);
  width: 26px;
  height: 26px;
  border-radius: 999px;
  border: 1px solid rgba(195, 229, 255, 0.52);
  background: rgba(10, 35, 66, 0.96);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1;
  box-shadow: 0 3px 8px rgba(3, 11, 31, 0.35);
}

.fantasy-player-dot span {
  font-size: 0.62rem;
  font-weight: 700;
  color: rgba(233, 246, 255, 0.96);
  line-height: 1;
}

.fantasy-bench {
  margin-top: 0.62rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.34rem;
}

.bench-dot {
  width: 26px;
  height: 26px;
  border-radius: 999px;
  border: 1px solid rgba(195, 229, 255, 0.5);
  background: rgba(10, 35, 66, 0.94);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 3px 7px rgba(3, 11, 31, 0.34);
}

.bench-dot span {
  font-size: 0.62rem;
  font-weight: 700;
  color: rgba(233, 246, 255, 0.94);
  line-height: 1;
}

.fantasy-meta {
  margin-top: 0.52rem;
  display: grid;
  gap: 0.32rem;
}

.fantasy-meta__line {
  margin: 0;
  display: flex;
  align-items: baseline;
  gap: 0.38rem;
  border-radius: 8px;
  border: 1px solid rgba(182, 220, 255, 0.28);
  background: rgba(16, 45, 98, 0.62);
  padding: 0.28rem 0.4rem;
}

.fantasy-meta__line span {
  font-size: 0.59rem;
  color: rgba(200, 223, 255, 0.82);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  white-space: nowrap;
}

.fantasy-meta__line strong {
  font-size: 0.62rem;
  color: rgba(233, 246, 255, 0.95);
  font-weight: 700;
  text-align: right;
  min-width: 0;
  flex: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.fantasy-core {
  border-radius: 8px;
  border: 1px solid rgba(182, 220, 255, 0.28);
  background: rgba(16, 45, 98, 0.62);
  padding: 0.3rem 0.4rem 0.34rem;
}

.fantasy-core__label {
  margin: 0;
  font-size: 0.59rem;
  color: rgba(200, 223, 255, 0.82);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.fantasy-core__list {
  margin: 0.24rem 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 0.18rem;
}

.fantasy-core__item {
  display: flex;
  align-items: baseline;
  gap: 0.34rem;
  min-width: 0;
}

.fantasy-core__item strong {
  font-size: 0.61rem;
  color: rgba(226, 241, 255, 0.95);
  font-weight: 700;
  min-width: 1.65rem;
}

.fantasy-core__item span {
  font-size: 0.61rem;
  color: rgba(226, 241, 255, 0.92);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.collect-grid {
  margin-top: 0.58rem;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.34rem;
}

.collect-card {
  border-radius: 10px;
  border: 1px solid rgba(184, 222, 255, 0.42);
  background: linear-gradient(158deg, rgba(20, 53, 108, 0.88), rgba(14, 35, 84, 0.84));
  padding: 0.28rem 0.28rem 0.34rem;
  display: grid;
  gap: 0.24rem;
  box-shadow: 0 4px 10px rgba(3, 11, 31, 0.32);
  overflow: hidden;
}

.collect-card--icon {
  border-color: rgba(255, 210, 120, 0.65);
  background: linear-gradient(162deg, rgba(80, 52, 20, 0.92), rgba(26, 37, 84, 0.86));
}

.collect-card--elite {
  border-color: rgba(103, 240, 182, 0.62);
  background: linear-gradient(162deg, rgba(17, 73, 86, 0.9), rgba(16, 41, 93, 0.84));
}

.collect-card--rare {
  border-color: rgba(166, 166, 255, 0.62);
  background: linear-gradient(162deg, rgba(50, 46, 112, 0.9), rgba(19, 39, 93, 0.84));
}

.collect-card__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.24rem;
}

.collect-card__head span {
  font-size: 0.5rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: rgba(230, 244, 255, 0.86);
}

.collect-card__head strong {
  font-size: 0.58rem;
  color: rgba(247, 252, 255, 0.96);
}

.collect-card__media {
  border-radius: 8px;
  border: 1px solid rgba(196, 231, 255, 0.42);
  overflow: hidden;
  aspect-ratio: 5 / 8;
  background: rgba(8, 24, 63, 0.78);
}

.collect-card__image {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center;
}

.collect-card__avatar {
  height: 68px;
  border-radius: 9px;
  border: 1px solid rgba(194, 231, 255, 0.4);
  background: radial-gradient(circle at 38% 26%, rgba(107, 205, 255, 0.6), rgba(9, 24, 63, 0.9));
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.66rem;
  font-weight: 700;
  color: rgba(238, 248, 255, 0.96);
}

.collect-card__meta {
  display: grid;
  gap: 0.12rem;
  min-width: 0;
}

.collect-card__name,
.collect-card__club {
  margin: 0;
  line-height: 1.15;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.collect-card__name {
  font-size: 0.54rem;
  font-weight: 700;
  color: rgba(238, 248, 255, 0.96);
}

.collect-card__club {
  font-size: 0.5rem;
  color: rgba(205, 228, 255, 0.82);
}

.collect-pack {
  margin-top: 0.46rem;
  border-radius: 999px;
  border: 1px solid rgba(184, 222, 255, 0.32);
  background: rgba(8, 26, 62, 0.42);
  padding: 0.26rem 0.52rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.4rem;
}

.collect-pack span {
  font-size: 0.67rem;
  color: rgba(214, 235, 255, 0.86);
}

.collect-pack strong {
  font-size: 0.69rem;
  color: rgba(244, 250, 255, 0.97);
}

.collect-progress {
  margin-top: 0.56rem;
}

.collect-progress__track {
  width: 100%;
  height: 0.42rem;
  border-radius: 999px;
  background: rgba(7, 24, 58, 0.62);
  border: 1px solid rgba(182, 220, 255, 0.28);
  overflow: hidden;
}

.collect-progress__track span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #52d0ff, #6fe39a, #ffd177);
}

.collect-set-list {
  margin-top: 0.52rem;
  display: grid;
  gap: 0.28rem;
}

.collect-set-row {
  border-radius: 9px;
  border: 1px solid rgba(182, 220, 255, 0.34);
  background: rgba(20, 47, 98, 0.62);
  color: rgba(228, 242, 255, 0.92);
  font-size: 0.7rem;
  padding: 0.36rem 0.5rem;
}

.factor-grid {
  margin-top: 0.52rem;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.32rem;
}

.factor-chip {
  border-radius: 999px;
  border: 1px solid rgba(184, 222, 255, 0.32);
  background: rgba(8, 26, 62, 0.42);
  padding: 0.22rem 0.46rem;
  font-size: 0.65rem;
  text-align: center;
}

.qr-block {
  margin-top: 0.62rem;
  border-radius: 12px;
  border: 1px solid rgba(182, 220, 255, 0.32);
  background: rgba(9, 28, 62, 0.54);
  padding: 0.58rem;
  display: grid;
  justify-items: center;
  gap: 0.4rem;
}

.qr-image {
  width: 126px;
  height: 126px;
  display: block;
  border-radius: 8px;
  border: 1px solid rgba(182, 220, 255, 0.36);
  background: #ffffff;
  object-fit: contain;
  padding: 3px;
  image-rendering: auto;
  box-shadow: 0 6px 14px rgba(5, 15, 38, 0.28);
}

.qr-code {
  color: #eff7ff;
  font-family: var(--font-heading);
  letter-spacing: 0.04em;
}

.rule-list {
  list-style: none;
}

.flow-steps {
  margin-top: 0.6rem;
  display: flex;
  align-items: center;
  gap: 0.3rem;
  flex-wrap: wrap;
}

.flow-step {
  padding: 0.3rem 0.5rem;
  border-radius: 999px;
  border: 1px solid rgba(184, 222, 255, 0.32);
  background: rgba(8, 26, 62, 0.42);
  font-size: 0.7rem;
}

.flow-arrow {
  color: rgba(224, 240, 255, 0.84);
  font-size: 0.78rem;
}

.metrics-row {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.metric-chip {
  text-align: center;
  font-weight: 700;
}

.ugc-item {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 0.5rem;
}

.ugc-media {
  width: 42px;
  height: 42px;
  border-radius: 10px;
  border: 1px solid rgba(180, 220, 255, 0.32);
  background:
    linear-gradient(140deg, rgba(0, 154, 192, 0.36), rgba(46, 173, 112, 0.28));
}

.ugc-meta {
  min-width: 0;
  display: grid;
  gap: 0.12rem;
}

.like-pill {
  border-radius: 999px;
  border: 1px solid rgba(181, 220, 255, 0.36);
  background: rgba(9, 28, 62, 0.42);
  padding: 0.22rem 0.5rem;
  font-size: 0.68rem;
}

@media (max-width: 420px) {
  .phone-shell {
    width: min(320px, 100%);
  }

  .mini-stat-grid,
  .module-grid,
  .predict-grid,
  .metrics-row,
  .factor-grid {
    grid-template-columns: 1fr;
  }

  .fantasy-bench {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
