@font-face {
  font-family: "Inter";
  src: url("/assets/fonts/Inter-cyrillic-a10feb6d.woff2") format("woff2");
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}

.adminPage {
  min-height: 100svh;
  display: grid;
  place-items: center;
  padding: 40px 20px;
  background: var(--paper);
}

.adminShell {
  width: min(100%, 720px);
  padding: 48px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.72);
}

.adminShell h1 {
  margin: 0;
  font-size: clamp(42px, 7vw, 78px);
}

.adminShell p:last-child {
  margin: 24px 0 0;
  color: var(--muted);
  font-size: 18px;
}

@font-face {
  font-family: "Inter";
  src: url("/assets/fonts/Inter-latin-496a588b.woff2") format("woff2");
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC,
    U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212,
    U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: "Inter";
  src: url("/assets/fonts/Inter-italic-cyrillic-c6e5a17f.woff2") format("woff2");
  font-style: italic;
  font-weight: 100 900;
  font-display: swap;
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}

@font-face {
  font-family: "Inter";
  src: url("/assets/fonts/Inter-italic-latin-80cac1ae.woff2") format("woff2");
  font-style: italic;
  font-weight: 100 900;
  font-display: swap;
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC,
    U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212,
    U+2215, U+FEFF, U+FFFD;
}

:root {
  --paper: #f5f2ec;
  --paper-deep: #e8e1d6;
  --ink: #171717;
  --muted: #6c665e;
  --line: rgba(23, 23, 23, 0.14);
  --accent: #1d4ed8;
  --accent-dark: #102f7a;
  --sage: #738476;
  --clay: #b86f52;
  --radius: 8px;
  --max: 1180px;
  --text-xs: 13px;
  --text-sm: 14px;
  --text-md: 16px;
  --text-lg: 18px;
  --text-xl: 21px;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family:
    Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI",
    sans-serif;
  font-size: var(--text-md);
  line-height: 1.55;
  font-feature-settings: "kern";
  text-rendering: geometricPrecision;
}

body.gameOpen {
  overflow: hidden;
}

a {
  color: inherit;
  text-decoration: none;
}

button,
input,
select,
textarea {
  font: inherit;
}

main {
  position: relative;
  overflow: hidden;
}

.page {
  min-height: 100svh;
}

.hero {
  position: relative;
  min-height: 100svh;
  padding: 28px clamp(20px, 5vw, 72px);
  display: grid;
  grid-template-rows: auto 1fr auto;
  isolation: isolate;
}

.pageHero {
  position: relative;
  min-height: 64svh;
  padding: 28px clamp(20px, 5vw, 72px) 80px;
  display: grid;
  grid-template-rows: auto 1fr;
  isolation: isolate;
}

.compactPageHero {
  min-height: 52svh;
}

.hero,
.pageHero,
.section {
  position: relative;
  z-index: 1;
}

.hero::before,
.pageHero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(23, 23, 23, 0.04) 1px, transparent 1px),
    linear-gradient(0deg, rgba(23, 23, 23, 0.04) 1px, transparent 1px);
  background-size: 80px 80px;
  mask-image: linear-gradient(to bottom, black, transparent 82%);
  z-index: -2;
}

.nav {
  position: relative;
  z-index: 3;
  width: min(100%, var(--max));
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

.brand {
  font-size: var(--text-sm);
  font-weight: 750;
  line-height: 1;
}

.navLinks {
  display: flex;
  align-items: center;
  gap: clamp(12px, 2vw, 28px);
  color: var(--muted);
  font-size: var(--text-sm);
  line-height: 1;
}

.language {
  display: inline-grid;
  width: 40px;
  height: 40px;
  place-items: center;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--ink);
}

.heroContent {
  position: relative;
  z-index: 2;
  width: min(100%, var(--max));
  margin: 0 auto;
  align-self: center;
  padding: 80px 0 60px;
}

.pageHeroContent {
  position: relative;
  z-index: 2;
  width: min(100%, var(--max));
  margin: 0 auto;
  align-self: end;
  padding: 96px 0 0;
}

.eyebrow {
  margin: 0 0 16px;
  color: var(--accent);
  font-size: var(--text-xs);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0;
  line-height: 1.25;
}

h1,
h2,
h3,
p {
  text-wrap: pretty;
}

h1 {
  max-width: 980px;
  margin: 0;
  font-size: clamp(48px, 6.2vw, 84px);
  line-height: 1;
  letter-spacing: 0;
}

h2 {
  max-width: 760px;
  margin: 0;
  font-size: clamp(31px, 3.6vw, 52px);
  line-height: 1.06;
  letter-spacing: 0;
}

h3 {
  margin: 0;
  font-size: clamp(20px, 1.8vw, 24px);
  line-height: 1.18;
  letter-spacing: 0;
}

.heroLead {
  max-width: 720px;
  margin: 26px 0 0;
  color: var(--muted);
  font-size: clamp(19px, 1.7vw, 22px);
  line-height: 1.5;
}

.heroActions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 36px;
}

.button {
  min-height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 0 20px;
  background: transparent;
  color: var(--ink);
  cursor: pointer;
  font-size: 15px;
  font-weight: 700;
  line-height: 1;
}

.button.primary {
  border-color: var(--ink);
  background: var(--ink);
  color: var(--paper);
}

.button.ghost {
  background: rgba(245, 242, 236, 0.62);
  backdrop-filter: blur(12px);
}

.button:disabled {
  cursor: wait;
  opacity: 0.72;
}

.heroStats {
  position: relative;
  z-index: 2;
  width: min(100%, var(--max));
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-top: 1px solid var(--line);
}

.heroStats div {
  padding: 24px 24px 24px 0;
}

.heroStats strong,
.heroStats span {
  display: block;
}

.heroStats strong {
  margin-bottom: 8px;
  font-size: var(--text-xl);
  line-height: 1.15;
}

.heroStats span {
  color: var(--muted);
  font-size: var(--text-sm);
  line-height: 1.35;
}

.geometry {
  position: absolute;
  inset: 0;
  z-index: -1;
  perspective: 900px;
  pointer-events: none;
}

.pageGeometry {
  position: absolute;
  inset: 0;
  z-index: 0;
  min-height: 100%;
  pointer-events: none;
  perspective: 1200px;
}

.ambientShape {
  position: absolute;
  opacity: 0.5;
  filter: saturate(0.94);
  animation: ambientFloat 18s ease-in-out infinite;
  box-shadow: 0 28px 90px rgba(23, 23, 23, 0.08);
}

.ambientCircle {
  width: clamp(80px, 10vw, 170px);
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle at 32% 28%, rgba(255, 255, 255, 0.9), rgba(196, 209, 226, 0.48) 48%, rgba(129, 147, 176, 0.34));
}

.ambientRing {
  width: clamp(74px, 9vw, 150px);
  aspect-ratio: 1;
  border: clamp(12px, 1.5vw, 22px) solid rgba(29, 78, 216, 0.16);
  border-radius: 50%;
  box-shadow: none;
}

.ambientTriangle {
  width: clamp(92px, 11vw, 180px);
  aspect-ratio: 1;
  background: linear-gradient(135deg, rgba(238, 244, 236, 0.72), rgba(115, 132, 118, 0.2));
  clip-path: polygon(50% 4%, 96% 92%, 4% 92%);
}

.ambientDiamond {
  width: clamp(82px, 10vw, 160px);
  aspect-ratio: 1;
  background: linear-gradient(135deg, rgba(245, 242, 236, 0.84), rgba(184, 111, 82, 0.2));
  transform: rotate(45deg);
}

.ambientOne {
  top: 92vh;
  right: 7vw;
  animation-delay: -3s;
}

.ambientTwo {
  top: 128vh;
  left: 6vw;
  animation-delay: -8s;
}

.ambientThree {
  top: 178vh;
  right: 16vw;
  animation-delay: -1s;
}

.ambientFour {
  top: 218vh;
  left: 12vw;
  animation-delay: -11s;
}

.ambientFive {
  top: 274vh;
  right: 10vw;
  animation-delay: -6s;
}

.ambientSix {
  top: 320vh;
  left: 10vw;
  animation-delay: -14s;
}

.ambientSeven {
  top: 372vh;
  right: 24vw;
  animation-delay: -4s;
}

.ambientEight {
  top: 426vh;
  left: 18vw;
  animation-delay: -10s;
}

.ambientNine {
  top: 484vh;
  right: 6vw;
  animation-delay: -2s;
}

.ambientTen {
  top: 536vh;
  left: 8vw;
  animation-delay: -15s;
}

.shape {
  position: absolute;
  opacity: 0.58;
  animation: drift linear infinite;
  box-shadow: 0 32px 90px rgba(23, 23, 23, 0.1);
}

.shapeCircle {
  width: clamp(120px, 14vw, 210px);
  aspect-ratio: 1;
  right: 14vw;
  top: 18svh;
  border-radius: 50%;
  background: radial-gradient(circle at 32% 28%, #ffffff, #c9d2e2 42%, #7a8cb1);
  animation-duration: 18s;
}

.shapeTriangle {
  width: clamp(100px, 11vw, 180px);
  aspect-ratio: 1;
  right: 5vw;
  bottom: 18svh;
  background: linear-gradient(135deg, rgba(238, 244, 236, 0.78), rgba(115, 132, 118, 0.28));
  clip-path: polygon(50% 3%, 97% 92%, 3% 92%);
  transform: rotate(12deg);
  animation-duration: 24s;
}

.shapeRing {
  width: clamp(90px, 10vw, 160px);
  aspect-ratio: 1;
  left: 6vw;
  bottom: 24svh;
  border: clamp(16px, 1.8vw, 26px) solid rgba(29, 78, 216, 0.18);
  border-radius: 50%;
  box-shadow: none;
  animation-duration: 20s;
}

.shapeDiamond {
  width: clamp(100px, 11vw, 180px);
  aspect-ratio: 1;
  right: 28vw;
  bottom: 10svh;
  background: linear-gradient(135deg, rgba(245, 242, 236, 0.84), rgba(184, 111, 82, 0.24));
  transform: rotate(45deg);
  animation-duration: 16s;
}

@keyframes drift {
  0% {
    translate: 0 0;
    rotate: 0deg;
  }
  50% {
    translate: 0 -24px;
    rotate: 6deg;
  }
  100% {
    translate: 0 0;
    rotate: 0deg;
  }
}

@keyframes ambientFloat {
  0% {
    translate: 0 0;
    rotate: 0deg;
  }
  50% {
    translate: 0 -28px;
    rotate: 5deg;
  }
  100% {
    translate: 0 0;
    rotate: 0deg;
  }
}

.section {
  width: min(100% - 40px, var(--max));
  margin: 0 auto;
  padding: 104px 0;
}

.sectionHeader {
  display: block;
  max-width: 860px;
  margin-bottom: 42px;
}

.sectionHeader > p:last-child,
.about > p {
  color: var(--muted);
  font-size: var(--text-lg);
  line-height: 1.62;
  max-width: 560px;
  margin: 24px 0 0;
}

.sectionHeader > p:last-child {
  margin-top: 24px;
}

.intro {
  padding-top: 80px;
}

.serviceGrid,
.priceGrid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
}

.detailSection {
  padding-top: 0;
}

.detailList {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  border: 1px solid var(--line);
  background: var(--line);
}

.detailList article {
  min-height: 220px;
  padding: 30px;
  background: rgba(245, 242, 236, 0.92);
}

.detailList p {
  margin: 18px 0 0;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.58;
}

.factorList {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  margin: 0;
  padding: 0;
  border: 1px solid var(--line);
  background: var(--line);
  list-style: none;
}

.factorList li {
  min-height: 108px;
  padding: 26px 30px;
  background: rgba(245, 242, 236, 0.92);
  color: var(--muted);
  font-size: 16px;
  line-height: 1.55;
}

.serviceCard,
.priceCard,
.caseItem {
  min-height: 248px;
  padding: 30px;
  background: rgba(245, 242, 236, 0.92);
}

.serviceCard span,
.caseItem p,
.priceCard p {
  color: var(--muted);
  font-size: var(--text-sm);
  line-height: 1.35;
  margin: 0;
}

.serviceCard h3,
.priceCard h3 {
  margin: 38px 0 16px;
}

.serviceCard p,
.priceCard span,
.caseItem span {
  color: var(--muted);
  font-size: 15px;
  line-height: 1.58;
}

.caseRail {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.caseItem {
  border: 1px solid var(--line);
  min-height: 190px;
}

.caseItem h3 {
  margin: 26px 0 12px;
}

.citySection {
  width: 100%;
  max-width: none;
  padding-inline: max(20px, calc((100vw - var(--max)) / 2));
  background: #e9ece4;
}

.city {
  margin-top: 42px;
}

.cityToolbar {
  display: flex;
  align-items: center;
  gap: 18px;
  margin-bottom: 16px;
}

.cityToolbar span {
  color: var(--muted);
  font-size: 15px;
  line-height: 1.35;
}

.cityPreview {
  position: relative;
  height: 560px;
  min-height: 560px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background:
    radial-gradient(circle at 50% 46%, rgba(29, 78, 216, 0.12), transparent 23%),
    radial-gradient(circle at 50% 52%, #dfe7d8 0 26%, transparent 26.5%),
    linear-gradient(135deg, #eef1eb, #d8ded5);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.48);
}

.cityPreview::before,
.cityPreview::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  border-radius: 999px;
  transform: translate(-50%, -50%) rotateX(62deg);
}

.cityPreview::before {
  width: min(520px, 72vw);
  height: min(520px, 72vw);
  border: 42px solid rgba(23, 23, 23, 0.12);
}

.cityPreview::after {
  width: min(380px, 52vw);
  height: min(380px, 52vw);
  border: 28px solid rgba(29, 78, 216, 0.12);
  transform: translate(-50%, -50%) rotateX(62deg) rotateZ(48deg);
}

.cityPreview span {
  position: absolute;
  left: 24px;
  bottom: 22px;
  color: var(--muted);
  font-size: var(--text-sm);
  font-weight: 700;
  text-transform: uppercase;
}

.gameOverlay {
  position: fixed;
  inset: 0;
  z-index: 100;
  background: #eef1eb;
  isolation: isolate;
}

.gameCanvas2d {
  display: block;
  width: 100% !important;
  height: 100% !important;
  image-rendering: pixelated;
  image-rendering: crisp-edges;
}

.gameTopbar,
.gameHud {
  position: absolute;
  z-index: 3;
  border: 1px solid rgba(23, 23, 23, 0.12);
  border-radius: var(--radius);
  background: rgba(245, 242, 236, 0.78);
  backdrop-filter: blur(18px);
}

.gameTopbar {
  top: 22px;
  left: 22px;
  right: 22px;
  min-height: 64px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  padding: 12px 14px 12px 18px;
}

.gameTopbar strong,
.gameTopbar span,
.gameHud p,
.gameHud strong,
.gameHud span {
  display: block;
}

.gameTopbar strong {
  font-size: 16px;
  line-height: 1.2;
}

.gameTopbar span {
  margin-top: 4px;
  color: var(--muted);
  font-size: var(--text-sm);
  line-height: 1.3;
}

.gameHud {
  left: 22px;
  bottom: 22px;
  width: min(380px, calc(100% - 44px));
  padding: 22px;
}

.gameHud p {
  margin: 0 0 14px;
  color: var(--accent);
  font-size: var(--text-xs);
  font-weight: 800;
  text-transform: uppercase;
}

.gameHud strong {
  margin-bottom: 10px;
  font-size: 24px;
  line-height: 1.15;
}

.gameHud span {
  color: var(--muted);
  font-size: 15px;
  line-height: 1.5;
}

.pricing {
  width: min(100% - 40px, var(--max));
}

.priceGrid {
  grid-template-columns: repeat(3, 1fr);
}

.priceCard strong {
  display: block;
  margin: 0 0 18px;
  font-size: clamp(22px, 2vw, 27px);
  line-height: 1.15;
}

.about {
  display: grid;
  grid-template-columns: 0.9fr 1fr;
  gap: clamp(32px, 8vw, 96px);
  align-items: start;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}

.leadForm {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}

.contactMethods {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  border: 1px solid var(--line);
  background: var(--line);
}

.contactMethods a {
  min-height: 160px;
  padding: 30px;
  display: grid;
  align-content: space-between;
  background: rgba(245, 242, 236, 0.92);
}

.contactMethods span {
  color: var(--muted);
  font-size: var(--text-sm);
  line-height: 1.35;
}

.contactMethods strong {
  font-size: clamp(22px, 2.4vw, 32px);
  line-height: 1.12;
  overflow-wrap: anywhere;
}

.leadForm label {
  display: grid;
  gap: 8px;
}

.leadForm span {
  color: var(--muted);
  font-size: var(--text-sm);
  line-height: 1.35;
}

.leadForm input,
.leadForm select,
.leadForm textarea {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.4);
  padding: 15px 16px;
  color: var(--ink);
  outline: none;
}

.leadForm input:focus,
.leadForm select:focus,
.leadForm textarea:focus {
  border-color: var(--accent);
}

.wide,
.leadForm button,
.formStatus {
  grid-column: 1 / -1;
}

.formStatus {
  margin: 0;
  color: var(--accent-dark);
  font-size: 15px;
  line-height: 1.5;
}

.formStatus.error {
  color: #9b2c2c;
}

.homePage {
  background:
    linear-gradient(115deg, rgba(66, 169, 241, 0.18) 0 12%, transparent 26%),
    linear-gradient(65deg, transparent 62%, rgba(83, 134, 255, 0.2) 76%, rgba(83, 134, 255, 0.08) 100%),
    #ffffff;
}

.homePage .nav {
  --nav-blue: #2ea8ff;
  align-items: center;
}

.homePage .brand {
  width: 58px;
  height: 58px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 2px solid rgba(46, 168, 255, 0.78);
  border-radius: 999px;
  color: var(--nav-blue);
  font-size: 10px;
  font-weight: 900;
  line-height: 1.05;
  text-align: center;
  text-transform: uppercase;
}

.homePage .brand::before {
  content: "VK";
}

.homePage .brand {
  font-size: 0;
}

.homePage .brand::before {
  font-size: 16px;
  line-height: 1;
  transform: translateY(1px);
}

.homePage .navLinks {
  gap: 18px;
}

.homePage .navLinks a:not(.language) {
  color: var(--ink);
}

.homePage .navLinks .navContact {
  min-height: 48px;
  padding: 0 22px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  border: 2px solid var(--nav-blue);
  border-radius: 999px;
  color: var(--nav-blue);
  font-size: 14px;
  font-weight: 800;
  text-transform: uppercase;
}

.homePage .navLinks .navContact img {
  width: 14px;
  height: 13px;
  display: block;
}

.homePage .language {
  width: 32px;
  height: 32px;
  border: 0;
  border-radius: 0;
  color: var(--ink);
}

.homeHero {
  min-height: 980px;
  padding-top: 32px;
  padding-bottom: clamp(72px, 8vh, 118px);
  background:
    radial-gradient(ellipse at 23% 33%, rgba(53, 99, 255, 0.68), rgba(92, 167, 255, 0.22) 18%, transparent 37%),
    radial-gradient(ellipse at 74% 40%, rgba(49, 100, 255, 0.56), rgba(239, 88, 205, 0.3) 20%, transparent 42%),
    #ffffff;
  grid-template-rows: auto 1fr;
}

.homeHero::before {
  display: none;
}

.homeHeroGrid {
  width: min(100%, var(--max));
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  gap: clamp(40px, 9vw, 140px);
  align-items: start;
  padding-top: clamp(72px, 10vh, 128px);
}

.homeHeroContent {
  width: auto;
  margin: 0;
  padding: 0;
}

.homeHeroContent .eyebrow {
  color: var(--ink);
  font-size: 0;
  margin: 0;
}

.homeHeroContent h1 {
  max-width: 860px;
  font-size: clamp(58px, 7.8vw, 118px);
  font-weight: 900;
  line-height: 0.94;
  text-transform: uppercase;
}

.homeHeroContent .heroLead {
  max-width: 640px;
  margin-top: 32px;
  color: var(--ink);
  font-size: clamp(28px, 3.2vw, 46px);
  font-weight: 300;
  line-height: 1.18;
  text-transform: uppercase;
}

.homeHeroText {
  max-width: 650px;
  margin: 20px 0 0;
  color: #171717;
  font-size: clamp(17px, 1.25vw, 22px);
  line-height: 1.45;
}

.inlineHeroStats {
  width: 100%;
  margin: 62px 0 0;
  border: 0;
  grid-template-columns: repeat(3, minmax(120px, 1fr));
  gap: 28px;
}

.inlineHeroStats div {
  padding: 0;
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 12px;
}

.inlineHeroStats strong {
  margin: 0;
  color: #050505;
  font-size: clamp(34px, 3.4vw, 50px);
  font-weight: 900;
}

.inlineHeroStats span {
  max-width: 120px;
  color: #171717;
  font-size: 12px;
  line-height: 1.22;
}

.heroOrb {
  width: min(260px, 26vw);
  aspect-ratio: 1;
  margin-top: 28px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(23, 23, 23, 0.8);
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.08);
  color: var(--ink);
  text-align: center;
}

.heroOrb span {
  max-width: 150px;
  font-size: 14px;
  line-height: 1.35;
}

.homeSection {
  width: min(100% - 40px, 1060px);
  margin: 0 auto;
  padding: 96px 0;
}

.homeSection h2,
.launchText h2,
.statementSection h2 {
  max-width: none;
  font-size: clamp(34px, 4vw, 56px);
  font-weight: 850;
  line-height: 1.05;
}

.featuredCases {
  padding-top: 70px;
}

.featuredCaseGrid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  margin-top: 44px;
}

.featuredCase {
  min-height: 232px;
  padding: 0;
  display: grid;
  place-items: center;
  border-radius: 8px;
  color: #ffffff;
  text-align: center;
}

.featuredCase img {
  width: 100%;
  height: 100%;
  min-height: 232px;
  padding: 34px;
  display: block;
  object-fit: contain;
  border-radius: 8px;
}

.featuredCase span,
.featuredCase small {
  font-size: 13px;
  line-height: 1.3;
  opacity: 0.82;
}

.featuredCase strong {
  font-size: clamp(22px, 2.4vw, 32px);
  font-weight: 720;
  line-height: 1.08;
}

.tone1,
.tone4 {
  background: #2b3043;
}

.tone2,
.tone3 {
  background: #9cb2d1;
}

.tone3 {
  color: #22304a;
  background: #c3d7ee;
}

.tone2 small,
.tone3 small {
  color: rgba(255, 255, 255, 0.9);
}

.outlineBlue {
  border-color: #2ea8ff;
  color: #2ea8ff;
  background: rgba(255, 255, 255, 0.72);
}

.centeredButton {
  width: fit-content;
  margin: 58px auto 0;
  text-transform: uppercase;
}

.homeServices {
  width: min(100% - 40px, 1060px);
}

.homeServiceGrid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  margin-top: 44px;
}

.homeServiceCard {
  position: relative;
  min-height: 360px;
  overflow: hidden;
  padding: 34px;
  display: grid;
  align-content: end;
  border-radius: 8px;
  background:
    linear-gradient(135deg, #121722 0%, #202638 100%);
  color: #ffffff;
}

.homeServiceCard::before,
.homeServiceCard::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
}

.homeServiceCard::before {
  background:
    linear-gradient(90deg, rgba(9, 12, 19, 0.98) 0%, rgba(9, 12, 19, 0.9) 36%, rgba(9, 12, 19, 0.2) 64%, rgba(9, 12, 19, 0) 100%),
    linear-gradient(180deg, rgba(12, 16, 25, 0.02) 0%, rgba(9, 12, 19, 0.08) 58%, rgba(9, 12, 19, 0.34) 100%);
}

.homeServiceCard::after {
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: inherit;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.homeServiceImage {
  position: absolute;
  top: -10px;
  right: -34px;
  bottom: -10px;
  z-index: 0;
  width: 72%;
  height: calc(100% + 20px);
  object-fit: cover;
  object-position: center;
  opacity: 1;
  filter: saturate(1.02) contrast(1.08) brightness(1.12);
  transform: translateX(8px) scale(1);
  transition: transform 420ms ease, filter 420ms ease, opacity 420ms ease;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 24%, #000 100%);
  mask-image: linear-gradient(90deg, transparent 0%, #000 24%, #000 100%);
}

.homeServiceCard:hover .homeServiceImage {
  filter: saturate(1.08) contrast(1.12) brightness(1.16);
  transform: translateX(0) scale(1.035);
}

.homeServiceCard h3 {
  position: relative;
  z-index: 2;
  max-width: 285px;
  margin: 8px 0 12px;
  font-size: clamp(21px, 2vw, 28px);
  font-weight: 650;
  text-transform: uppercase;
}

.homeServiceCard p {
  position: relative;
  z-index: 2;
  max-width: 292px;
  margin: 0;
  color: rgba(255, 255, 255, 0.76);
  font-size: 14px;
  line-height: 1.45;
}

.homeServiceIndex,
.cardArrow {
  position: relative;
  z-index: 2;
}

.cardArrow {
  position: absolute;
  top: 22px;
  right: 26px;
  width: 20px;
  height: 19px;
}

.quickContact {
  text-align: center;
}

.quickContactHeader {
  max-width: 760px;
  margin: 0 auto 38px;
}

.quickContactHeader h2 em,
.launchText em,
.statementSection em {
  color: #5d83ff;
  font-style: italic;
}

.quickContactHeader p {
  margin: 18px auto 0;
  color: var(--muted);
  font-size: 17px;
}

.quickContactLinks {
  width: min(100%, 760px);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.quickContactLinks a {
  min-height: 92px;
  padding: 18px 22px;
  display: grid;
  align-content: center;
  border: 1px solid rgba(46, 168, 255, 0.8);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.66);
  text-align: left;
}

.quickContactLinks span {
  color: var(--muted);
  font-size: 13px;
}

.quickContactLinks strong {
  color: #171717;
  font-size: clamp(18px, 2vw, 24px);
  overflow-wrap: anywhere;
}

.qrPage {
  min-height: 100svh;
}

.qrHero {
  min-height: 100svh;
  padding: 32px clamp(20px, 5vw, 72px) 76px;
  display: grid;
  grid-template-rows: auto 1fr;
  background:
    radial-gradient(ellipse at 18% 28%, rgba(53, 99, 255, 0.48), rgba(92, 167, 255, 0.18) 17%, transparent 38%),
    radial-gradient(ellipse at 82% 32%, rgba(49, 100, 255, 0.38), rgba(239, 88, 205, 0.18) 18%, transparent 40%),
    #ffffff;
}

.qrCardShell {
  width: min(100%, 1060px);
  margin: 0 auto;
  align-self: center;
  padding: clamp(72px, 11vh, 130px) 0 0;
}

.qrDigitalCard {
  position: relative;
  overflow: hidden;
  min-height: 560px;
  padding: clamp(28px, 5vw, 64px);
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 380px);
  gap: clamp(34px, 7vw, 86px);
  align-items: center;
  border: 1px solid rgba(46, 168, 255, 0.34);
  border-radius: 8px;
  background:
    linear-gradient(140deg, rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.7)),
    linear-gradient(115deg, rgba(66, 169, 241, 0.12), transparent 48%);
  box-shadow: 0 28px 90px rgba(23, 23, 23, 0.08);
}

.qrDigitalCard::before {
  content: "VK";
  position: absolute;
  left: clamp(20px, 4vw, 56px);
  bottom: -0.26em;
  color: rgba(46, 168, 255, 0.1);
  font-size: clamp(150px, 20vw, 290px);
  font-weight: 900;
  line-height: 0.8;
  pointer-events: none;
}

.qrCardContent {
  position: relative;
  z-index: 1;
}

.qrCardContent h1 {
  max-width: 620px;
  font-size: clamp(46px, 6vw, 86px);
  font-weight: 900;
  line-height: 0.96;
  text-transform: uppercase;
}

.qrCardLead {
  max-width: 620px;
  margin: 28px 0 0;
  color: #171717;
  font-size: clamp(18px, 1.5vw, 22px);
  line-height: 1.5;
}

.qrContactGrid {
  width: min(100%, 460px);
  margin-top: 42px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}

.qrContactGrid a {
  min-height: 82px;
  padding: 18px 20px;
  display: grid;
  align-content: center;
  border: 1px solid rgba(46, 168, 255, 0.72);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.68);
}

.qrContactGrid span {
  color: var(--muted);
  font-size: 13px;
  line-height: 1.35;
}

.qrContactGrid strong {
  color: #171717;
  font-size: clamp(17px, 1.5vw, 21px);
  overflow-wrap: anywhere;
}

.qrPanel {
  position: relative;
  z-index: 1;
  display: grid;
  justify-items: center;
  gap: 18px;
}

.qrFrame {
  width: min(100%, 360px);
  aspect-ratio: 1;
  padding: clamp(16px, 2.2vw, 24px);
  display: grid;
  place-items: center;
  border: 1px solid rgba(23, 23, 23, 0.12);
  border-radius: 8px;
  background: #ffffff;
  box-shadow: 0 18px 54px rgba(23, 23, 23, 0.1);
}

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

.qrPanel p {
  max-width: 320px;
  margin: 0;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.45;
  text-align: center;
}

.businessCardActions {
  margin-top: 24px;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
}

.whyStack {
  display: grid;
  gap: 16px;
  margin-top: 44px;
}

.whyCard {
  position: relative;
  min-height: 238px;
  overflow: hidden;
  padding: 46px clamp(28px, 7vw, 120px);
  display: grid;
  grid-template-columns: minmax(260px, 1fr) minmax(260px, 420px);
  align-items: center;
  border-radius: 8px;
  color: #273043;
}

.whyNumber {
  position: absolute;
  left: clamp(24px, 8vw, 130px);
  bottom: -68px;
  color: rgba(255, 255, 255, 0.9);
  font-size: clamp(160px, 19vw, 270px);
  font-weight: 250;
  line-height: 0.8;
  letter-spacing: 0;
}

.whyCard:nth-child(even) {
  grid-template-columns: minmax(260px, 420px) minmax(260px, 1fr);
}

.whyCard:nth-child(even) .whyNumber {
  left: auto;
  right: clamp(24px, 8vw, 130px);
}

.whyCard h3 {
  margin: 0 0 20px;
  font-size: clamp(20px, 2vw, 27px);
  text-transform: uppercase;
}

.whyCard p {
  margin: 0;
  font-size: 15px;
  line-height: 1.55;
}

.whyCard > div {
  position: relative;
  z-index: 1;
  grid-column: 2;
}

.whyCard:nth-child(even) > div {
  grid-column: 1;
}

.whyTone1 {
  background: #c9d6e9;
}

.whyTone2 {
  background: #80a2d5;
  color: #ffffff;
}

.whyTone3 {
  background: #38aef2;
  color: #ffffff;
}

.whyTone4 {
  background: #2b3043;
  color: #ffffff;
}

.clientsSection {
  width: min(100% - 40px, 1180px);
  padding: 112px 0 130px;
  background: #ffffff;
}

.clientGrid {
  display: grid;
  grid-template-columns: repeat(5, minmax(120px, 1fr));
  gap: 72px 80px;
  margin-top: 92px;
  align-items: center;
}

.clientGrid img {
  width: 100%;
  height: 72px;
  display: block;
  object-fit: contain;
  filter: grayscale(1);
}

.launchBanner {
  position: relative;
  min-height: 500px;
  display: grid;
  place-items: center;
  overflow: hidden;
  background: #e7eaf6;
}

.launchText {
  position: relative;
  z-index: 2;
  width: min(100% - 40px, 620px);
  text-align: center;
}

.launchText p {
  margin: 18px 0 0;
  color: #30364b;
  font-size: 18px;
}

.rocketScene {
  position: absolute;
  inset: 0;
}

.star {
  position: absolute;
  width: 30px;
  height: 30px;
}

.star::before,
.star::after {
  content: "";
  position: absolute;
  background: #ffffff;
}

.star::before {
  left: 13px;
  top: 0;
  width: 4px;
  height: 30px;
}

.star::after {
  left: 0;
  top: 13px;
  width: 30px;
  height: 4px;
}

.starOne {
  left: 22%;
  top: 30%;
}

.starTwo {
  right: 28%;
  top: 44%;
}

.rocket,
.cloud {
  display: none;
}

.rocketComposite {
  position: absolute;
  right: max(2vw, calc((100vw - 1180px) / 2));
  bottom: -2px;
  width: min(48vw, 560px);
  height: auto;
  z-index: 1;
}

.statementSection {
  text-align: center;
}

.statementSection h2 {
  max-width: 920px;
  margin: 0 auto;
  line-height: 1.18;
}

.statementQuote {
  width: min(100%, 830px);
  margin: 52px auto 0;
  display: grid;
  grid-template-columns: 76px 1fr;
  gap: 28px;
  align-items: center;
}

.avatar {
  width: 76px;
  aspect-ratio: 1;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: linear-gradient(145deg, #2b3043, #7fa8ff);
  color: #ffffff;
  font-weight: 850;
}

.statementQuote p {
  margin: 0;
  padding: 24px 30px;
  border-radius: 8px;
  background: #e7eaf6;
  color: #30364b;
  text-align: left;
  font-size: 18px;
}

.homeFooter {
  background: #3daef4;
  color: #ffffff;
}

.homeFooterInner {
  width: min(100% - 40px, 1060px);
  min-height: 250px;
  margin: 0 auto;
  padding: 58px 0;
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr auto;
  gap: 40px;
  align-items: center;
}

.homeFooter strong {
  display: block;
  margin-bottom: 16px;
  font-size: clamp(34px, 4vw, 58px);
  line-height: 1;
  text-transform: uppercase;
}

.homeFooter span,
.homeFooter a {
  display: block;
}

.homeFooter span {
  margin-bottom: 12px;
  font-size: 16px;
  font-weight: 800;
  text-transform: uppercase;
}

.homeFooter a {
  color: #ffffff;
  font-size: 16px;
}

.homeFooter .footerButton {
  border-color: rgba(255, 255, 255, 0.9);
  color: #ffffff;
  min-width: 360px;
  min-height: 96px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  text-align: center;
  font-size: 28px;
  line-height: 1;
}

.homeFooter .footerButton img {
  width: 14px;
  height: 13px;
  filter: brightness(0) invert(1);
}

.notFoundPage {
  min-height: 100svh;
  display: grid;
  grid-template-rows: 1fr auto;
  background: #ffffff;
  color: #171717;
}

.notFoundHero {
  position: relative;
  min-height: 72svh;
  overflow: hidden;
  padding: 32px clamp(20px, 5vw, 72px) 84px;
  display: grid;
  grid-template-rows: auto 1fr;
  background:
    linear-gradient(115deg, rgba(66, 169, 241, 0.12) 0 10%, transparent 24%),
    linear-gradient(65deg, transparent 67%, rgba(83, 134, 255, 0.16) 82%, rgba(83, 134, 255, 0.08) 100%),
    #ffffff;
}

.notFoundPage .nav {
  --nav-blue: #2ea8ff;
}

.notFoundPage .brand {
  width: 58px;
  height: 58px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 2px solid rgba(46, 168, 255, 0.78);
  border-radius: 999px;
  color: var(--nav-blue);
  font-size: 0;
  font-weight: 900;
  line-height: 1;
}

.notFoundPage .brand::before {
  content: "VK";
  font-size: 16px;
  transform: translateY(1px);
}

.notFoundPage .navLinks {
  gap: 18px;
}

.notFoundPage .navLinks .navContact {
  min-height: 48px;
  padding: 0 22px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  border: 2px solid var(--nav-blue);
  border-radius: 999px;
  color: var(--nav-blue);
  font-size: 14px;
  font-weight: 800;
  text-transform: uppercase;
}

.notFoundPage .navLinks .navContact img {
  width: 14px;
  height: 13px;
  display: block;
}

.notFoundPage .language {
  width: 32px;
  height: 32px;
  border: 0;
  border-radius: 0;
}

.notFoundContent {
  position: relative;
  z-index: 2;
  width: min(100%, 760px);
  margin: 0 auto;
  align-self: center;
  padding: clamp(96px, 13vh, 170px) 0 clamp(54px, 8vh, 96px);
  display: grid;
  justify-items: center;
  text-align: center;
}

.notFoundCode {
  width: min(100%, 620px);
  height: auto;
  display: block;
}

.notFoundContent h1 {
  margin: clamp(34px, 5vh, 54px) 0 10px;
  font-size: clamp(28px, 3vw, 44px);
  font-weight: 850;
  line-height: 1.05;
  text-transform: uppercase;
}

.notFoundHomeLink {
  color: #303030;
  font-size: clamp(16px, 1.2vw, 19px);
  line-height: 1.3;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.notFoundCable {
  position: absolute;
  z-index: 1;
  height: auto;
  pointer-events: none;
  user-select: none;
}

.notFoundCableLeft {
  left: max(-12px, calc((100vw - 1440px) / 2 - 32px));
  bottom: -2px;
  width: clamp(300px, 34vw, 542px);
}

.notFoundCableRight {
  right: max(-2px, calc((100vw - 1440px) / 2 - 24px));
  top: -12px;
  width: clamp(280px, 30vw, 467px);
}

@media (max-width: 920px) {
  .nav {
    align-items: flex-start;
  }

  .navLinks {
    justify-content: flex-end;
    flex-wrap: wrap;
  }

  .heroStats,
  .sectionHeader,
  .about,
  .leadForm,
  .contactMethods {
    grid-template-columns: 1fr;
  }

  .sectionHeader > p:last-child,
  .about > p {
    margin-top: 0;
  }

  .serviceGrid,
  .priceGrid,
  .caseRail,
  .detailList,
  .factorList {
    grid-template-columns: repeat(2, 1fr);
  }

  .shapeCircle {
    right: -8vw;
  }

  .ambientShape {
    opacity: 0.48;
  }

  .homeHero {
    min-height: auto;
  }

  .homeHeroGrid {
    grid-template-columns: 1fr;
    padding-top: 90px;
  }

  .heroOrb {
    display: none;
  }

  .inlineHeroStats,
  .clientGrid,
  .homeFooterInner,
  .qrDigitalCard {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .qrDigitalCard {
    grid-template-columns: 1fr;
  }

  .notFoundHero {
    min-height: 68svh;
  }

  .whyCard {
    grid-template-columns: 1fr;
  }

  .whyCard:nth-child(even) {
    grid-template-columns: 1fr;
  }

  .whyCard > div {
    grid-column: 1;
  }

  .whyCard:nth-child(even) > div {
    grid-column: 1;
  }

  .whyNumber {
    left: auto;
    right: 24px;
  }
}

@media (max-width: 640px) {
  .hero {
    min-height: auto;
  }

  .pageHero {
    min-height: auto;
    padding-bottom: 64px;
  }

  .nav {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .navLinks {
    width: 100%;
    justify-content: flex-start;
    overflow-x: auto;
    padding-bottom: 2px;
  }

  .homePage .nav {
    display: flex;
    grid-template-columns: none;
    align-items: center;
  }

  .homePage .navLinks a:not(.navContact):not(.language) {
    display: none;
  }

  .homePage .navLinks {
    width: auto;
    margin-left: auto;
    overflow: visible;
  }

  .notFoundPage .nav {
    display: flex;
    grid-template-columns: none;
    align-items: center;
  }

  .notFoundPage .navLinks {
    width: auto;
    margin-left: auto;
    overflow: visible;
  }

  .homePage .navLinks .navContact {
    min-height: 42px;
    padding: 0 16px;
    font-size: 12px;
  }

  .notFoundPage .navLinks .navContact {
    min-height: 42px;
    padding: 0 16px;
    font-size: 12px;
  }

  .heroContent {
    padding: 96px 0 64px;
  }

  .pageHeroContent {
    padding-top: 84px;
  }

  h1 {
    font-size: 40px;
    line-height: 1.04;
  }

  h2 {
    font-size: 31px;
    line-height: 1.08;
  }

  h3 {
    font-size: 21px;
  }

  .heroStats,
  .serviceGrid,
  .priceGrid,
  .caseRail,
  .detailList,
  .factorList {
    grid-template-columns: 1fr;
  }

  .section {
    padding: 72px 0;
  }

  .sectionHeader {
    margin-bottom: 30px;
  }

  .sectionHeader > p:last-child,
  .about > p,
  .heroLead {
    font-size: 17px;
  }

  .serviceCard,
  .priceCard,
  .caseItem {
    min-height: auto;
  }

  .cityPreview {
    height: 440px;
    min-height: 440px;
  }

  .gameTopbar {
    align-items: flex-start;
  }

  .gameHud {
    padding: 18px;
  }

  .homeHero {
    padding: 22px 20px 88px;
  }

  .homeHeroGrid {
    padding-top: 58px;
  }

  .homeHeroContent h1 {
    font-size: 44px;
  }

  .homeHeroContent .heroLead {
    font-size: 24px;
  }

  .inlineHeroStats,
  .featuredCaseGrid,
  .homeServiceGrid,
  .quickContactLinks,
  .clientGrid,
  .statementQuote,
  .homeFooterInner,
  .qrContactGrid {
    grid-template-columns: 1fr;
  }

  .inlineHeroStats div {
    grid-template-columns: 96px 1fr;
  }

  .homeSection {
    padding: 70px 0;
  }

  .clientsSection {
    padding: 72px 0 88px;
  }

  .clientGrid {
    gap: 34px 28px;
    margin-top: 48px;
  }

  .clientGrid img {
    height: 58px;
  }

  .featuredCase {
    min-height: 190px;
  }

  .homeServiceCard {
    min-height: 300px;
  }

  .homeServiceCard::before {
    background:
      linear-gradient(180deg, rgba(12, 16, 25, 0.08) 0%, rgba(12, 16, 25, 0.28) 42%, rgba(9, 12, 19, 0.9) 100%),
      linear-gradient(90deg, rgba(9, 12, 19, 0.78) 0%, rgba(9, 12, 19, 0.18) 58%, rgba(9, 12, 19, 0.3) 100%);
  }

  .homeServiceImage {
    inset: 0;
    width: 100%;
    height: 100%;
    border-radius: 0;
    transform: scale(1.01);
  }

  .homeServiceCard:hover .homeServiceImage {
    transform: scale(1.035);
  }

  .homeServiceCard h3,
  .homeServiceCard p {
    max-width: 320px;
  }

  .quickContact {
    text-align: left;
  }

  .qrHero {
    padding: 22px 20px 66px;
  }

  .qrCardShell {
    padding-top: 64px;
  }

  .qrDigitalCard {
    min-height: auto;
    padding: 26px;
  }

  .qrDigitalCard::before {
    right: 18px;
    left: auto;
    bottom: -28px;
    font-size: 134px;
  }

  .qrCardContent h1 {
    font-size: 42px;
  }

  .qrFrame {
    width: min(100%, 300px);
  }

  .whyCard {
    min-height: 260px;
    padding: 34px 26px;
    align-items: end;
  }

  .whyNumber {
    right: 12px;
    bottom: -36px;
    font-size: 150px;
  }

  .launchBanner {
    min-height: 430px;
  }

  .rocketComposite {
    right: 7%;
    width: 330px;
  }

  .statementQuote p {
    text-align: center;
  }

  .homeFooterInner {
    align-items: start;
  }

  .notFoundHero {
    min-height: 620px;
    padding: 22px 20px 66px;
  }

  .notFoundContent {
    padding: 96px 0 92px;
  }

  .notFoundCode {
    width: min(100%, 420px);
  }

  .notFoundCableLeft {
    left: -62px;
    width: 340px;
  }

  .notFoundCableRight {
    right: -88px;
    top: -24px;
    width: 330px;
  }

}

@media print {
  body {
    background: #ffffff;
  }

  [data-print-hidden],
  .qrPage .nav,
  .qrPage .homeFooter {
    display: none !important;
  }

  .qrPage,
  .qrHero {
    min-height: auto;
    overflow: visible;
    padding: 0;
    background: #ffffff;
  }

  .qrCardShell {
    width: 100%;
    padding: 0;
  }

  .qrDigitalCard {
    min-height: 100vh;
    border: 0;
    box-shadow: none;
    break-inside: avoid;
  }
}
