@font-face {
  font-family: RussoOne;
  src: url("assets/RussoOne-Regular.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

:root {
  --font-base: Arial, Helvetica, sans-serif;
  --font-title: RussoOne, Arial, Helvetica, sans-serif;
  --landscape-min: 75rem;
  --section-width: 120rem;
  --section-content-width: 92rem;
  --section-x: clamp(1.5rem, calc((100vw - var(--section-content-width)) / 2), 14rem);
  --panel-pad-y: 2rem;
  --panel-pad-x: 2.5rem;
  --topbar-height: 4.125rem;
  --topbar-pad-x: 1.375rem;
  --topbar-icon-size: 3rem;
  --topbar-font-size: 1.375rem;
  --nav-gap: 4rem;
  --first-screen-height: 100vh;
  --text: #dff7ff;
  --panel-text: #d6f0fb;
  --cyan: #19d4ff;
}

@supports (height: 100lvh) {
  :root {
    --first-screen-height: 100lvh;
  }
}

* {
  box-sizing: border-box;
}

html {
  font-size: 1.4815vh;
  scroll-behavior: smooth;
}

[id] {
  scroll-margin-top: calc(var(--topbar-height) + 1.375rem);
}

body {
  min-width: min(100%, var(--landscape-min));
  margin: 0;
  background: #000;
  color: var(--text);
  font-family: var(--font-base);
}

.page {
  width: 100%;
  min-width: min(100%, var(--landscape-min));
  overflow: hidden;
  background: #020912 url("assets/ref/battlefield-bg.webp") center top/100% auto repeat-y;
}

.icon {
  object-fit: contain;
}

.nav a,
.lang,
.langDropdown a,
.chips article,
.hero h1,
.lead,
.play,
.navPlay {
  font-family: var(--font-title);
  font-weight: 400;
  font-synthesis: none;
  letter-spacing: .1em;
  -webkit-font-smoothing: antialiased;
}

.nav a,
.lang,
.langDropdown a,
.navPlay {
  color: #ddd;
  text-decoration: none;
  text-shadow: none;
}

.nav a,
.lang {
  font-size: var(--topbar-font-size);
  line-height: 1;
  white-space: nowrap;
}

.topbar {
  position: fixed;
  left: 0;
  right: 0;
  top: 0;
  z-index: 10;
  min-width: min(100%, var(--landscape-min));
  height: var(--topbar-height);
  display: flex;
  align-items: center;
  padding: 0 var(--topbar-pad-x);
  background: #030304aa;
  border-bottom: 1px solid #7fdcff30;
  backdrop-filter: blur(.5rem);
  -webkit-backdrop-filter: blur(.5rem);
}

.nav {
  position: absolute;
  left: 50%;
  display: flex;
  justify-content: center;
  gap: var(--nav-gap);
  transform: translateX(-50%);
}

.menuToggle {
  display: none;
}

.nav a {
  color: #c8edf8;
  transition: color .18s ease, text-shadow .18s ease;
}

.nav a:hover,
.nav a:focus-visible {
  color: #62e8ff;
  text-shadow: 0 0 .75rem #00dfff;
}

.topbarLogo,
.languageMenu,
.menuToggle {
  position: absolute;
  top: 50%;
  z-index: 4;
  transform: translateY(-50%);
}

.topbarLogo {
  left: var(--topbar-pad-x);
  display: flex;
  align-items: center;
  line-height: 0;
  text-decoration: none;
}

.topbarLogo img {
  display: block;
  filter: none;
}

.topbarGameIcon {
  width: var(--topbar-icon-size);
  height: var(--topbar-icon-size);
  border-radius: .5rem;
  object-fit: contain;
}

.languageMenu {
  right: var(--topbar-pad-x);
  width: 5rem;
  text-align: right;
}

.lang {
  width: 100%;
  padding: 0;
  border: 0;
  background: none;
  cursor: pointer;
  text-align: right;
}

.langDropdown {
  position: absolute;
  right: 0;
  top: calc(100% + .75rem);
  min-width: 5rem;
  padding: .5rem 0;
  border: 1px solid #0884a7;
  border-radius: .25rem;
  background: #030b12f2;
  box-shadow: 0 0 .75rem #00ccff44;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-.375rem);
  transition: opacity .2s ease, transform .2s ease, visibility 0s .2s;
}

.languageMenu.is-open .langDropdown {
  opacity: 1;
  visibility: visible;
  transform: none;
  transition: opacity .2s ease, transform .2s ease;
}

.langDropdown a {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: .625rem;
  padding: .625rem .75rem;
  font-size: 1.125rem;
  line-height: 1;
  white-space: nowrap;
}

.langDropdown a[hidden] {
  display: none;
}

.langDropdown a:hover,
.langDropdown a:focus {
  background: #0a334dcc;
  color: white;
}

.langFlag {
  width: 1.5rem;
  height: 1rem;
  display: block;
  flex: none;
  border: 1px solid #ffffff55;
  border-radius: .125rem;
  object-fit: cover;
  box-shadow: 0 0 .25rem #0008;
}

.play,
.navPlay {
  align-items: center;
  justify-content: center;
  color: white;
  white-space: nowrap;
}

.play {
  display: flex;
  gap: 1.125rem;
  width: max-content;
  min-width: 23rem;
  height: 4.875rem;
  padding: 0 1.875rem;
  border: 2px solid #00d9ff;
  border-radius: .3125rem;
  background: linear-gradient(#064e69, #05283b);
  box-shadow: 0 0 .75rem #00ccff88, inset 0 0 1.125rem #4edcff33;
  text-decoration: none;
  font-size: 1.75rem;
}

.play .playIcon {
  width: 2.875rem;
  height: 2.875rem;
  filter: drop-shadow(0 0 .375rem #00dfff);
}

.navPlay {
  position: absolute;
  right: 6rem;
  display: inline-flex;
  gap: .75rem;
  min-width: 11.12rem;
  height: 3.125rem;
  padding: 0 1.25rem;
  border: 2px solid #5dff40;
  border-radius: .3125rem;
  background: linear-gradient(#23b93f, #0b5f27);
  box-shadow: 0 0 .75rem #5dff4088, inset 0 0 1rem #b9ff6f55;
  font-size: 1.125rem;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-.375rem);
  transition: opacity .35s ease, transform .35s ease, visibility 0s .35s;
}

.navPlay .playIcon {
  width: 1.875rem;
  height: 1.875rem;
  filter: none;
}

.topbar.is-scrolled .navPlay {
  opacity: 1;
  visibility: visible;
  transform: none;
  transition: opacity .35s ease, transform .35s ease;
}

.menuToggle {
  right: var(--topbar-pad-x);
  width: 4.4rem;
  height: 4.4rem;
  align-items: center;
  justify-content: center;
  gap: .35rem;
  padding: 0;
  border: 1px solid #3e96b8;
  border-radius: .25rem;
  background: #041321e6;
  box-shadow: inset 0 0 .75rem #00c8ff22;
  color: #c8edf8;
  cursor: pointer;
}

.menuToggle span {
  width: 1.8rem;
  height: 2px;
  display: block;
  background: currentColor;
  box-shadow: 0 0 .4rem #00dfff88;
  transition: transform .18s ease, opacity .18s ease;
}

.topbar.is-menu-open .menuToggle span:nth-child(1) {
  transform: translateY(.7rem) rotate(45deg);
}

.topbar.is-menu-open .menuToggle span:nth-child(2) {
  opacity: 0;
}

.topbar.is-menu-open .menuToggle span:nth-child(3) {
  transform: translateY(-.7rem) rotate(-45deg);
}

.hero {
  --hero-gap: 2.5rem;
  --preview-height: 32vh;
  position: relative;
  height: max(38.75rem, calc(100vh - 6rem));
  overflow: hidden;
  background: #020912;
  border-bottom: 1px solid #07344d;
}

.hero::before,
.hero::after {
  content: "";
  position: absolute;
  inset: 0;
}

.hero::before {
  z-index: 0;
  background: url("assets/hero-header.webp") center top/cover no-repeat;
  transform: translateX(5%);
}

.hero::after {
  z-index: 1;
  background: linear-gradient(90deg, #000 0 30%, #0000 100%) left top/60vw 100% no-repeat;
  pointer-events: none;
}

.heroText {
  position: absolute;
  z-index: 2;
  left: 3.75rem;
  bottom: calc(var(--preview-height) + 5rem);
  display: flex;
  flex-direction: column;
  gap: var(--hero-gap);
  align-items: flex-start;
}

.hero h1 {
  display: contents;
  margin: 0;
  line-height: 0;
}

.heroLogo {
  width: auto;
  height: 4rem;
  display: block;
  filter: drop-shadow(0 0 1.125rem #00dfff);
}

.lead {
  position: relative;
  z-index: 0;
  width: fit-content;
  margin: 0;
  color: #62e8ff;
  font-size: 2.625rem;
  line-height: 1.05;
  white-space: pre-line;
  text-shadow: 0 .5rem 3rem rgb(0 0 0);
}

.heroDesc {
  position: relative;
  z-index: 0;
  width: fit-content;
  max-width: 51.25rem;
  margin: 0;
  color: #d8edf5;
  font-family: var(--font-title);
  font-size: 1.25rem;
  line-height: 1.3;
  letter-spacing: .07em;
  text-shadow: 0 .25rem 1.25rem #000;
}

.heroDesc .textBackdrop {
  position: relative;
  z-index: 0;
  padding: .05em .15em;
  border-radius: .25rem;
  color: transparent;
  background: rgb(0 0 0 / 58%);
  filter: blur(.75rem);
  text-shadow: none;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
  pointer-events: none;
  user-select: none;
}

.heroDesc .textContent {
  position: absolute;
  inset: 0 auto auto 0;
  z-index: 1;
  width: 100%;
  color: inherit;
}

.devicePreview {
  position: absolute;
  z-index: 2;
  left: 3.75rem;
  bottom: 0;
  width: auto;
  height: var(--preview-height);
  display: flex;
  align-items: flex-end;
}

.devicePreview img {
  height: 100%;
  width: auto;
  display: block;
}

.chips {
  position: relative;
  width: min(var(--section-width), 100%);
  height: 6rem;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1.125rem;
  margin: 0 auto;
  padding: .375rem 2.125rem .875rem;
}

.chips::before {
  content: "";
  position: absolute;
  z-index: 0;
  left: 50%;
  top: 0;
  width: max(100vw, var(--section-width));
  height: 100%;
  border-bottom: 1px solid #2f5468;
  background: linear-gradient(180deg, #052136dd, #020912ee), url("assets/ref/down.webp") left top/100% auto no-repeat;
  transform: translateX(-50%);
}

.chips article {
  position: relative;
  z-index: 1;
  min-width: 0;
  height: 4.688rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.375rem;
  padding: 0 1.5rem;
  color: #ddd;
  font-size: 1.625rem;
  line-height: 1.05;
}

.chips span {
  color: #ddddddad;
  font-size: .92em;
  text-transform: uppercase;
  white-space: pre-line;
}

.chips .icon {
  width: 3.75rem;
  height: 3.75rem;
  opacity: .8;
}

.gallery {
  padding: 1rem 0 3rem;
}

.galleryLogo {
  width: auto;
  height: 2rem;
  display: block;
  margin: 0 auto .25rem;
  transform: translateY(2.5rem);
}

.galleryFrame {
  position: relative;
  width: min(92.8125rem, 92vw);
  aspect-ratio: 1485/899;
  margin: 0 auto;
  touch-action: pan-y pinch-zoom;
}

.galleryFrame::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  background: url("assets/icons/gallery-frame.webp") center/100% 100% no-repeat;
  pointer-events: none;
}

.galleryScroller {
  position: absolute;
  inset: 0;
  overflow: hidden;
  font-size: 0;
  white-space: nowrap;
  -webkit-mask: url("assets/icons/gallery-mask.webp") center/100% 100% no-repeat;
  mask: url("assets/icons/gallery-mask.webp") center/100% 100% no-repeat;
}

.galleryScroller img {
  position: static;
  width: 100%;
  height: 100%;
  display: inline-block;
  object-fit: cover;
  user-select: none;
  -webkit-user-drag: none;
  vertical-align: top;
}

.galleryArrow {
  position: absolute;
  top: 43.5%;
  z-index: 3;
  width: 6.5%;
  height: 13%;
  border: 0;
  background: none;
  cursor: pointer;
}

.galleryArrow.left {
  left: 0;
}

.galleryArrow.right {
  right: 0;
}

.galleryDots {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 2.7%;
  z-index: 3;
  display: flex;
  justify-content: center;
  gap: .75rem;
}

.galleryDots i {
  width: 1.25rem;
  height: 1.25rem;
  border: 0;
  border-radius: 50%;
  background: #1e4068;
}

.galleryDots i.is-active {
  background: #3995d8;
}

.duo {
  width: 100%;
  max-width: var(--section-width);
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.125rem;
  margin: 0 auto;
  padding: 1.5rem var(--section-x) 1.375rem;
}

.panel {
  position: relative;
  min-height: 22.5rem;
  display: grid;
  grid-template-columns: auto 1fr;
  column-gap: 1.375rem;
  align-content: start;
  align-items: center;
  padding: var(--panel-pad-y) var(--panel-pad-x);
  border: 0;
  border-radius: 0;
  background: linear-gradient(135deg, #051626ee, #020712f2);
  box-shadow: inset 0 0 1.25rem #00b4ff33;
}

.panel:not(.rankText),
.ranked,
.mapList {
  --frame-corner: 1.75rem;
  --frame-line: 1px;
  --frame-color: #5fa9d0;
  --frame-length: calc(100% - var(--frame-corner) - var(--frame-corner));
  clip-path: polygon(var(--frame-corner) 0, calc(100% - var(--frame-corner)) 0, 100% var(--frame-corner), 100% calc(100% - var(--frame-corner)), calc(100% - var(--frame-corner)) 100%, var(--frame-corner) 100%, 0 calc(100% - var(--frame-corner)), 0 var(--frame-corner));
}

.panel:not(.rankText)::after,
.ranked::after,
.mapList::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
  background:
    linear-gradient(var(--frame-color), var(--frame-color)) var(--frame-corner) 0/var(--frame-length) var(--frame-line) no-repeat,
    linear-gradient(var(--frame-color), var(--frame-color)) var(--frame-corner) 100%/var(--frame-length) var(--frame-line) no-repeat,
    linear-gradient(var(--frame-color), var(--frame-color)) 0 var(--frame-corner)/var(--frame-line) var(--frame-length) no-repeat,
    linear-gradient(var(--frame-color), var(--frame-color)) 100% var(--frame-corner)/var(--frame-line) var(--frame-length) no-repeat,
    linear-gradient(135deg, transparent calc(50% - var(--frame-line)), var(--frame-color) 0 calc(50% + var(--frame-line)), transparent 0) 0 0/var(--frame-corner) var(--frame-corner) no-repeat,
    linear-gradient(45deg, transparent calc(50% - var(--frame-line)), var(--frame-color) 0 calc(50% + var(--frame-line)), transparent 0) 100% 0/var(--frame-corner) var(--frame-corner) no-repeat,
    linear-gradient(45deg, transparent calc(50% - var(--frame-line)), var(--frame-color) 0 calc(50% + var(--frame-line)), transparent 0) 0 100%/var(--frame-corner) var(--frame-corner) no-repeat,
    linear-gradient(135deg, transparent calc(50% - var(--frame-line)), var(--frame-color) 0 calc(50% + var(--frame-line)), transparent 0) 100% 100%/var(--frame-corner) var(--frame-corner) no-repeat;
}

.panel > .icon,
.maps .icon,
.customHeader .icon {
  width: 4rem;
  height: 4rem;
  filter: drop-shadow(0 0 .375rem #00dfff);
}

.panel > .icon {
  grid-column: 1;
  grid-row: 1;
}

.panel h2,
.custom h2 {
  margin: 0;
  color: var(--cyan);
  font-size: 2.25rem;
  line-height: 1.05;
  font-weight: 900;
  letter-spacing: 0;
}

.panel h2 {
  grid-column: 2;
  grid-row: 1;
}

.panel p {
  grid-column: 1/3;
  max-width: 53rem;
  margin: 1.5rem 0 0;
  color: var(--panel-text);
  font-size: 1.5rem;
  line-height: 1.35;
  font-weight: 700;
}

.gameplay,
.mobile {
  min-height: 27rem;
  background-blend-mode: multiply;
}

.gameplay {
  background: #041522dd url("assets/ref/gallery-14.webp") right center/cover no-repeat;
}

.mobile {
  background: #05243ccc url("assets/ref/mobile-bg.webp") right center/cover no-repeat;
}

.steps {
  grid-column: 1/3;
  position: absolute;
  left: var(--panel-pad-x);
  right: var(--panel-pad-x);
  bottom: var(--panel-pad-y);
  height: 7.5rem;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  align-items: start;
  text-align: center;
}

.steps span {
  display: flex;
  flex-direction: column;
  align-items: center;
  color: var(--text);
  font-size: .9375rem;
  line-height: 1.4;
  font-weight: 900;
}

.steps b {
  font: inherit;
  font-weight: inherit;
  white-space: pre-line;
}

.steps .icon {
  display: block;
  width: 3.75rem;
  height: 3.75rem;
  margin: 0 auto .625rem;
}

.ranked {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 34fr) minmax(0, 66fr);
  gap: 1.5rem;
  width: min(var(--section-content-width), calc(100% - var(--section-x) * 2));
  min-height: 27.5rem;
  margin: 0 auto 1.375rem;
  padding: 1.75rem 2rem;
  border: 0;
  border-radius: 0;
  background: linear-gradient(90deg, #041522df, #05243ccc), url("assets/ref/title-bg.webp") center/cover no-repeat;
  box-shadow: inset 0 0 1.25rem #00b4ff33;
}

.rankText {
  min-height: 23.75rem;
  padding: 0;
  border: 0;
  background: none;
  box-shadow: none;
  clip-path: none;
}

.rankText h2,
.rankText p {
  white-space: pre-line;
}

.leaderboard {
  align-self: center;
}

.leaderboard img {
  width: 100%;
  height: auto;
  display: block;
}

.maps {
  display: grid;
  grid-template-columns: minmax(0, 34.8fr) minmax(0, 65.2fr);
  gap: 1rem;
  width: min(var(--section-content-width), calc(100% - var(--section-x) * 2));
  min-height: 16.25rem;
  margin: 0 auto 1.375rem;
  padding: var(--panel-pad-y) var(--panel-pad-x);
}

.maps > div {
  position: relative;
  z-index: 2;
}

.maps > div:first-child {
  display: grid;
  grid-template-columns: auto 1fr;
  column-gap: 1.25rem;
  align-content: start;
  align-items: center;
}

.maps p {
  margin-top: 1.5rem;
}

.mapList {
  position: relative;
  width: 100%;
  aspect-ratio: 2.876;
  display: flex;
  align-items: center;
  align-self: center;
  justify-self: stretch;
  padding: 2.23%;
  border: 0;
  border-radius: 0;
  background: #051b2bd9;
  box-shadow: inset 0 0 1.25rem #00b4ff33;
}

.mapList img {
  width: 100%;
  height: auto;
  aspect-ratio: 3.152;
  display: block;
  object-fit: cover;
}

.lower {
  grid-template-columns: 31rem 1fr;
  gap: 1.375rem;
  padding: 0 var(--section-x) 1.5rem;
}

.lower > .panel {
  min-width: 0;
}

.maps,
.pvp,
.custom {
  overflow: hidden;
  background: linear-gradient(90deg, #041522f7 0, #041522f0 44%, #04152266 78%, #041522e8 100%);
  box-shadow: inset 0 0 1.25rem #00b4ff33;
}

.maps::before,
.pvp::before,
.custom::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background: url("assets/ref/title-bg.webp") center/cover no-repeat;
  opacity: .32;
  pointer-events: none;
}

.pvp,
.custom {
  min-height: 31.25rem;
}

.pvp > .icon,
.pvp h2,
.pvp p {
  position: relative;
  z-index: 2;
}

.pvpArt {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
  height: 22rem;
  overflow: hidden;
}

.pvpArt img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: left top;
  filter: saturate(1.15);
}

.custom {
  display: block;
  padding: 1.75rem var(--panel-pad-x) 1.5rem;
}

.customContent {
  position: relative;
  z-index: 2;
  width: 100%;
}

.customHeader {
  display: grid;
  grid-template-columns: auto 1fr;
  column-gap: 1.25rem;
  align-items: center;
  margin-bottom: 1.75rem;
}

.customHeader > div {
  display: contents;
}

.customGroup {
  margin-top: 1rem;
}

.customGroup h3 {
  margin: 0 0 .375rem;
  color: var(--panel-text);
  font-size: 1rem;
  line-height: 1.1;
  font-weight: 900;
}

.customGroup > div {
  display: flex;
  gap: .75rem;
}

.flagColors i,
.emblems span,
.avatarList span {
  width: 3.25rem;
  height: 3.25rem;
  display: grid;
  place-items: center;
  border: 2px solid #07a3c6;
  border-radius: .25rem;
  background: #061321;
  box-shadow: 0 0 .5rem #00c8ff55;
}

.flagColors i {
  border-color: #143445;
  box-shadow: 0 0 .5rem #0008;
}

.flagColors i:nth-child(1) { background: #f51a1a; }
.flagColors i:nth-child(2) { background: #111dff; }
.flagColors i:nth-child(3) { background: #05d60d; }
.flagColors i:nth-child(4) { background: #ffe918; }
.flagColors i:nth-child(5) { background: #b600b8; }
.flagColors i:nth-child(6) { background: #ff6b0d; }

.emblems img {
  width: 2.25rem;
  height: 2.25rem;
  object-fit: contain;
  filter: brightness(0) invert(1);
}

.avatarList span {
  overflow: hidden;
}

.avatarList img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.glowColors i {
  width: 3.25rem;
  height: 3.25rem;
  border: 4px solid currentColor;
  border-radius: 50%;
  background: currentColor;
  box-shadow: 0 0 .75rem currentColor, inset 0 0 0 8px #071323;
}

.glowColors i:nth-child(1) { color: #0849ff; }
.glowColors i:nth-child(2) { color: #11df14; }
.glowColors i:nth-child(3) { color: #f51a1a; }
.glowColors i:nth-child(4) { color: #ffe018; }
.glowColors i:nth-child(5) { color: #b318d1; }
.glowColors i:nth-child(6) { color: #19d6d9; }

.vehicleArt {
  position: absolute;
  right: 0;
  bottom: 0;
  z-index: 1;
  width: 31rem;
  height: 23.25rem;
  object-fit: cover;
  object-position: right top;
}

.download {
  --download-bg-y: 0rem;
  --download-bg-scale: 1;
  --download-content-unit: calc(.833vw * var(--download-bg-scale));
  position: relative;
  min-height: calc(23.66vw * var(--download-bg-scale) + 28 * var(--download-content-unit));
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: calc(4 * var(--download-content-unit)) 2rem calc(5 * var(--download-content-unit));
  overflow: hidden;
  background: url("assets/ref/down.webp") center top/calc(100% * var(--download-bg-scale)) auto no-repeat;
  text-align: center;
}

.downloadContent {
  width: 100%;
  max-width: var(--section-width);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: calc(1.25 * var(--download-content-unit));
  transform: translateY(calc(-2.25 * var(--download-content-unit) + var(--download-bg-y)));
}

.downloadLogo {
  width: calc(23.9 * var(--download-content-unit));
  height: auto;
  display: block;
  filter: drop-shadow(0 0 .75rem #00dfff);
}

.downloadSlogan {
  margin: calc(1 * var(--download-content-unit)) 0 calc(-1 * var(--download-content-unit));
  color: #18d9ff;
  font-family: var(--font-title);
  font-size: calc(1.5 * var(--download-content-unit));
  line-height: 1.15;
  letter-spacing: .1em;
}

.download .play {
  width: max-content;
  max-width: 100%;
  gap: calc(1.125 * var(--download-content-unit));
  min-width: calc(23 * var(--download-content-unit));
  height: calc(4.875 * var(--download-content-unit));
  padding: 0 calc(1.875 * var(--download-content-unit));
  font-size: calc(1.75 * var(--download-content-unit));
  margin-top: calc(2.5 * var(--download-content-unit));
}

.download .play .playIcon {
  width: calc(2.875 * var(--download-content-unit));
  height: calc(2.875 * var(--download-content-unit));
}

.joinBlock {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: var(--section-width);
  margin: calc(4.5 * var(--download-content-unit)) auto 0;
}

.joinBlock h2 {
  margin: 0 0 calc(1.125 * var(--download-content-unit));
  color: #20d8ff;
  font-size: calc(1.65 * var(--download-content-unit));
  line-height: 1.15;
  letter-spacing: calc(.125 * var(--download-content-unit));
  transform: translateY(calc(-.75 * var(--download-content-unit)));
}

.socials {
  display: flex;
  justify-content: center;
  gap: calc(1.5 * var(--download-content-unit));
  transform: translateY(calc(.375 * var(--download-content-unit)));
}

.socials a {
  position: relative;
  width: calc(6 * var(--download-content-unit));
  height: calc(5.25 * var(--download-content-unit));
  display: grid;
  place-items: center;
  color: white;
  text-decoration: none;
  filter: drop-shadow(0 0 .5rem #00c8ff55);
}

html:not([lang="ru"]) .vkSocial {
  display: none;
}

.socials a::before,
.socials a::after {
  content: "";
  position: absolute;
  clip-path: polygon(24% 0, 76% 0, 100% 50%, 76% 100%, 24% 100%, 0 50%);
  pointer-events: none;
}

.socials a::before {
  inset: 0;
  background: #047899;
}

.socials a::after {
  inset: 2px;
  background: #040b16;
  box-shadow: inset 0 0 1.125rem #00c8ff30;
}

.socials .icon,
.socialText {
  position: relative;
  z-index: 1;
}

.socials .icon {
  max-width: calc(2.375 * var(--download-content-unit));
  max-height: calc(2.375 * var(--download-content-unit));
  width: auto;
  height: auto;
  display: block;
}

.socialText {
  font-family: var(--font-title);
  font-size: calc(1.25 * var(--download-content-unit));
  letter-spacing: .08em;
}

.footBottom {
  position: relative;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: calc(1.5 * var(--download-content-unit));
  align-items: center;
  justify-content: center;
  margin: calc(6 * var(--download-content-unit)) auto 0;
  padding: 0 calc(2 * var(--download-content-unit));
  color: #8eb7c4;
  font-size: calc(1.65 * var(--download-content-unit));
}

.footerLinks {
  display: flex;
  justify-content: center;
  gap: calc(2 * var(--download-content-unit));
  align-items: center;
}

.footerLinks a {
  display: block;
  color: inherit;
  text-decoration: none;
}

.footBottom a:hover,
.footBottom a:focus {
  color: white;
}

.footBottom b {
  color: white;
  text-align: left;
}

.ageBlock {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: calc(.75 * var(--download-content-unit));
  color: #527b89;
  text-align: center;
  white-space: nowrap;
}

.ageBlock strong {
  padding: calc(.5 * var(--download-content-unit));
  border: 1px solid #6d8790;
  border-radius: .25rem;
  color: #a8c4cc;
  font-size: inherit;
}

.ageBlock span {
  font-size: inherit;
  line-height: 1.25;
}

@media (orientation: portrait) {
  :root {
    --topbar-height: 4.8rem;
    --chips-height: 6rem;
    --section-x: 1rem;
    --panel-pad-y: 1.5rem;
    --panel-pad-x: 1.25rem;
    --topbar-pad-x: 1rem;
    --topbar-icon-size: 3.2rem;
    --topbar-font-size: 1.375rem;
  }

  html {
    font-size: clamp(10px, 2.2vw, 20px);
  }

  [id] {
    scroll-margin-top: calc(var(--topbar-height) + 1rem);
  }

  .navPlay {
    right: calc(var(--topbar-pad-x) + 9.4rem);
    gap: .5rem;
    min-width: 0;
    height: 3.2rem;
    padding: 0 .8rem;
    font-size: .9rem;
  }

  .navPlay .playIcon {
    width: 1.6rem;
    height: 1.6rem;
  }

  .topbar::before {
    content: "";
    position: fixed;
    inset: var(--topbar-height) 0 0;
    background: #0009;
    opacity: 0;
    pointer-events: none;
    transition: opacity .18s ease;
  }

  .topbar.is-menu-open::before {
    opacity: 1;
    pointer-events: auto;
  }

  .languageMenu {
    right: calc(var(--topbar-pad-x) + 5.2rem);
    width: 4rem;
  }

  .menuToggle {
    display: flex;
    flex-direction: column;
    border: 0;
    background: none;
    box-shadow: none;
  }

  .nav {
    position: fixed;
    left: 1rem;
    right: 1rem;
    top: calc(var(--topbar-height) + .75rem);
    z-index: 3;
    display: grid;
    grid-template-columns: 1fr;
    gap: .6rem;
    padding: 1rem;
    border: 1px solid #1f86a8;
    border-radius: .5rem;
    background: #030b12f5;
    box-shadow: 0 1.25rem 3rem #000b, inset 0 0 1.25rem #00b4ff22;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(-.75rem);
    transition: opacity .18s ease, transform .18s ease, visibility 0s .18s;
  }

  .topbar.is-menu-open .nav {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: none;
    transition: opacity .18s ease, transform .18s ease;
  }

  .nav a {
    min-height: 4.4rem;
    display: flex;
    align-items: center;
    justify-content: center;
    outline: 0;
    border-radius: .25rem;
    background: #061321e6;
    font-size: 1.35rem;
  }

  .nav a:hover,
  .nav a:focus-visible {
    background: #08324bcc;
  }

  .hero {
    height: calc(var(--first-screen-height) - var(--chips-height));
    min-height: 0;
    display: grid;
    grid-template-rows: auto .75fr auto 1fr auto 1fr auto 1fr auto;
    align-content: stretch;
    row-gap: 0;
    padding: calc(var(--topbar-height) + 11vh) 1.6vh 0;
    justify-items: center;
  }

  .hero::before {
    background-position: 58% top;
    transform: none;
  }

  .hero::after {
    background: linear-gradient(90deg, rgb(0 0 0 / 80%), rgb(0 0 0 / 70%));
  }

  .heroText {
    display: contents;
    text-align: center;
  }

  .hero h1,
  .heroLogo,
  .lead,
  .heroDesc,
  .hero .play,
  .devicePreview {
    position: relative;
    z-index: 2;
  }

  .hero h1 {
    display: contents;
  }

  .heroLogo {
    grid-row: 1;
    width: 47.64vh;
    max-width: calc(100vw - 6.4vh);
    height: auto;
    margin: 0 auto;
  }

  .lead {
    grid-row: 3;
    max-width: 100%;
    font-size: 2.256vh;
  }

  .heroDesc {
    grid-row: 5;
    max-width: 80vw;
    font-size: 1.608vh;
    line-height: 1.35;
  }

  .play {
    width: 39.96vh;
    max-width: 100%;
    min-width: 0;
    height: 6.72vh;
    gap: 1.32vh;
    padding: 0 1.92vh;
    font-size: 1.92vh;
  }

  .hero .play {
    grid-row: 7;
    margin-top: 0;
  }

  .play .playIcon {
    width: 3.6vh;
    height: 3.6vh;
  }

  .devicePreview {
    grid-row: 9;
    position: relative;
    left: auto;
    bottom: auto;
    width: 51.48vh;
    max-width: 100%;
    height: auto;
    justify-content: center;
    margin: 0;
    padding: 0;
  }

  .devicePreview img {
    width: 100%;
    height: auto;
  }

  .chips {
    height: var(--chips-height);
    min-height: 0;
    gap: .35rem;
    padding: .5rem;
  }

  .chips article {
    min-height: 5rem;
    height: auto;
    gap: .25rem;
    padding: .35rem .2rem;
    font-size: clamp(.75rem, 2vw, .9rem);
  }

  .chips .icon {
    width: 2.2rem;
    height: 2.2rem;
  }

  .gallery {
    padding: 1rem 0 1.5rem;
  }

  .galleryFrame {
    width: 100%;
  }

  .galleryArrow {
    top: 28%;
    width: 18%;
    height: 44%;
  }

  .galleryLogo {
    height: 4.1vw;
    margin-bottom: 1.28vw;
    transform: translateY(3.6vw);
  }

  .galleryDots {
    bottom: 5.65%;
    gap: 1.28%;
    transform: translateY(50%);
  }

  .galleryDots i {
    width: 2.31%;
    height: auto;
    aspect-ratio: 1;
  }

  .duo,
  .lower {
    grid-template-columns: 1fr;
    gap: 1rem;
    padding: 1rem var(--section-x);
  }

  .panel {
    min-height: 0;
    grid-template-columns: 3.2rem 1fr;
    column-gap: 1rem;
    padding: var(--panel-pad-y) var(--panel-pad-x);
  }

  .panel:not(.rankText),
  .ranked,
  .mapList {
    --frame-corner: 1.25rem;
  }

  .panel > .icon,
  .maps .icon,
  .customHeader .icon {
    width: 3.2rem;
    height: 3.2rem;
  }

  .panel h2,
  .custom h2 {
    font-size: 1.9rem;
  }

  .panel p {
    max-width: none;
    margin-top: 1.1rem;
    font-size: 1.3rem;
    line-height: 1.35;
  }

  .gameplay,
  .mobile {
    min-height: 0;
    background-position: center;
  }

  .steps {
    position: relative;
    left: auto;
    right: auto;
    bottom: auto;
    height: auto;
    margin-top: 1.5rem;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
  }

  .gameplay .steps span,
  .mobile .steps span,
  .steps span {
    font-size: clamp(.7rem, 2.3vw, .9rem);
  }

  .gameplay .steps .icon,
  .mobile .steps .icon,
  .steps .icon {
    width: 3.2rem;
    height: 3.2rem;
  }

  .ranked,
  .maps {
    width: calc(100% - var(--section-x) * 2);
    margin: 0 auto 1rem;
    transform: none;
  }

  .ranked {
    min-height: 0;
    grid-template-columns: 1fr;
    gap: 1.25rem;
    padding: 1.5rem 1.25rem;
  }

  .rankText {
    min-height: 0;
  }

  .maps {
    min-height: 0;
    grid-template-columns: 1fr;
    padding: 1.5rem 1.25rem;
  }

  .maps > div:first-child,
  .customHeader {
    grid-template-columns: 3.2rem 1fr;
    column-gap: 1rem;
  }

  .pvp,
  .custom {
    min-height: 0;
  }

  .pvpArt {
    left: 50%;
    right: auto;
    top: calc(50% + 5rem);
    height: 15rem;
    transform: translate(-50%, -50%) scale(1.4);
    transform-origin: center;
  }

  .pvp {
    min-height: 27.3rem;
  }

  .custom {
    padding: 1.5rem 1.25rem;
  }

  .customHeader {
    margin-bottom: 1.25rem;
  }

  .customGroup {
    margin-top: .85rem;
  }

  .customGroup > div {
    flex-wrap: wrap;
    gap: .6rem;
    max-width: 24rem;
  }

  .flagColors i,
  .emblems span,
  .avatarList span,
  .glowColors i {
    width: 2.75rem;
    height: 2.75rem;
  }

  .emblems img {
    width: 1.9rem;
    height: 1.9rem;
  }

  .glowColors i {
    box-shadow: 0 0 .75rem currentColor, inset 0 0 0 6px #071323;
  }

  .vehicleArt {
    width: min(28rem, 80vw);
    height: 18rem;
  }

  .download {
    --download-bg-scale: 1.6625;
    padding: calc(4 * var(--download-content-unit)) 1.5rem;
  }

  .joinBlock {
    width: max-content;
    margin: calc(4.5 * var(--download-content-unit)) auto calc(1 * var(--download-content-unit));
  }

  .footBottom,
  .footerLinks {
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  .footBottom {
    gap: calc(1.5 * var(--download-content-unit));
  }

  .footerLinks {
    gap: calc(.9 * var(--download-content-unit));
  }
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  *,
  *::before,
  *::after {
    transition-duration: .01ms !important;
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
  }
}
