/* ═══════════════════════════════════════════════════════════
   Valeriy Proshkin — Videographer · Odessa
   Warm Cinema Design — Premium Cinematic Dark
═══════════════════════════════════════════════════════════ */

:root {
  --bg:        #080604;
  --bg-2:      #0f0c08;
  --bg-3:      #181310;
  --card:      rgba(21,16,11,0.97);
  --text:      #f2e9df;
  --text-2:    #a09278;
  --text-3:    #665849;
  --accent:    #c8912e;
  --accent-2:  #e8c470;
  --accent-bg: rgba(200,145,46,0.12);
  --red:       #e05050;
  --line:      rgba(245,225,195,0.07);
  --line-hi:   rgba(245,225,195,0.13);
  --r-sm: 8px; --r: 14px; --r-lg: 22px;
  --mx: 50%; --my: 40%; --hero-shift: 0px;
}

*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }

body {
  font-family: "Jost", system-ui, sans-serif;
  font-size: 16px;
  line-height: 1.65;
  color: var(--text);
  background: var(--bg);
  overflow-x: hidden;
}

/* ── Film grain ──────────────────────────────────────────── */
body::after {
  content: "";
  position: fixed; inset: 0; z-index: 999; pointer-events: none;
  opacity: 0.028;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 140px 140px;
}

/* ── Grid overlay ────────────────────────────────────────── */
.page-glow {
  position: fixed; inset: 0; pointer-events: none; z-index: -1;
  background-image:
    linear-gradient(rgba(255,255,255,0.012) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.012) 1px, transparent 1px);
  background-size: 60px 60px;
  mask-image: radial-gradient(ellipse 80% 60% at center, black 20%, transparent 100%);
}

.container {
  width: min(1160px, calc(100% - 2.5rem));
  margin: 0 auto;
}

/* ══════════════════════════════════════════════════════════
   NAV
══════════════════════════════════════════════════════════ */
.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  position: fixed;
  top: 0.9rem;
  left: 50%;
  transform: translateX(-50%);
  width: min(1160px, calc(100% - 2.5rem));
  z-index: 120;
  padding: 0.75rem 1.1rem;
  border-radius: 999px;
  backdrop-filter: blur(20px) saturate(1.3);
  background: rgba(8,6,4,0.78);
  border: 1px solid var(--line-hi);
}

.brand {
  text-decoration: none;
  color: #fff;
  font-weight: 800;
  font-size: 0.82rem;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}
.brand__mark { font-size: 0.9rem; }

.nav__links { display: flex; gap: 1.4rem; }
.nav__links a {
  text-decoration: none;
  color: var(--text-2);
  font-size: 0.9rem;
  font-weight: 500;
  transition: color 0.2s;
}
.nav__links a:hover { color: var(--text); }

.nav__cta {
  text-decoration: none;
  color: #0a0500;
  font-weight: 700;
  font-size: 0.9rem;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  padding: 0.55rem 1rem;
  border-radius: 999px;
  transition: opacity 0.2s, transform 0.2s, box-shadow 0.2s;
}
.nav__cta:hover {
  opacity: 0.9;
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(200,145,46,0.38);
}

.lang-switch {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--line-hi);
  border-radius: 999px;
  padding: 0.18rem;
  background: rgba(8,6,4,0.7);
  gap: 0.15rem;
}
.lang-switch__btn {
  border: 0;
  min-width: 40px;
  padding: 0.34rem 0.48rem;
  border-radius: 999px;
  font-weight: 800;
  font-size: 0.7rem;
  color: var(--text-2);
  background: transparent;
  cursor: pointer;
  transition: color 0.15s, background 0.15s;
}
.lang-switch__btn.is-active {
  color: #0a0500;
  background: linear-gradient(95deg, var(--accent), var(--accent-2));
}
.lang-switch--mobile { margin-top: 0.2rem; }

.nav__toggle {
  display: none;
  width: 42px; height: 42px;
  border-radius: 12px;
  border: 1px solid var(--line-hi);
  background: rgba(9,7,5,0.7);
  cursor: pointer;
  align-items: center;
  justify-content: center;
  gap: 4px;
  flex-direction: column;
}
.nav__toggle span {
  width: 16px; height: 2px;
  border-radius: 999px;
  background: var(--text);
}

/* ── Mobile nav ─────────────────────────────────────────── */
.mobile-nav {
  position: fixed; inset: 0; z-index: 145; pointer-events: none;
}
.mobile-nav__backdrop {
  position: absolute; inset: 0;
  background: rgba(4,3,2,0.82);
  opacity: 0;
  transition: opacity 0.2s;
}
.mobile-nav__panel {
  position: absolute;
  top: 0; right: 0;
  width: min(320px, calc(100% - 2rem));
  height: 100%;
  background: var(--bg-2);
  border-left: 1px solid var(--line);
  transform: translateX(104%);
  transition: transform 0.24s ease;
  padding: 1rem 0.9rem 1.2rem;
  display: grid;
  align-content: start;
  gap: 0.5rem;
}
.mobile-nav__panel a {
  color: var(--text);
  text-decoration: none;
  font-weight: 600;
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  padding: 0.7rem 0.85rem;
  background: rgba(15,12,8,0.55);
}
.mobile-nav__close {
  justify-self: end;
  width: 36px; height: 36px;
  border-radius: 999px;
  border: 1px solid var(--line-hi);
  background: var(--bg-3);
  color: var(--text);
  font-size: 1.2rem;
  cursor: pointer;
}
.mobile-nav.is-open { pointer-events: auto; }
.mobile-nav.is-open .mobile-nav__backdrop { opacity: 1; }
.mobile-nav.is-open .mobile-nav__panel { transform: translateX(0); }
body.menu-open { overflow: hidden; }

/* ══════════════════════════════════════════════════════════
   HERO
══════════════════════════════════════════════════════════ */
.hero {
  position: relative;
  isolation: isolate;
  min-height: 100vh;
  padding: 1.4rem 0 4rem;
  overflow: clip;
}

.hero__media {
  position: absolute; inset: 0; z-index: -2;
  background:
    linear-gradient(115deg,
      rgba(8,6,4,0.95) 0%,
      rgba(8,6,4,0.72) 44%,
      rgba(8,6,4,0.90) 100%),
    url("https://images.unsplash.com/photo-1519741497674-611481863552?auto=format&fit=crop&w=1800&q=80")
    center / cover no-repeat;
  transform: translate3d(0, var(--hero-shift), 0) scale(1.04);
  will-change: transform;
}

.hero__veil {
  position: absolute; inset: 0; z-index: -1;
  background: radial-gradient(ellipse 55% 50% at 70% 28%,
    rgba(200,145,46,0.09) 0%, transparent 100%);
  transform: translate3d(0, calc(var(--hero-shift)*-0.3), 0);
  will-change: transform;
}

/* Magic orbs — warm amber, very subtle */
.hero__magic {
  position: absolute; inset: 0; z-index: -1; pointer-events: none;
}
.hero__magic::before {
  content: "";
  position: absolute; inset: -10%;
  background:
    radial-gradient(260px circle at var(--mx) var(--my),
      rgba(200,145,46,0.1) 0%, transparent 65%);
  opacity: 0.8;
}

.magic-orb {
  position: absolute;
  border-radius: 999px;
  filter: blur(48px);
  opacity: 0.16;
  mix-blend-mode: screen;
}
.magic-orb--one {
  width: 300px; height: 300px;
  top: 8%; left: 54%;
  background: rgba(200,145,46,0.55);
  animation: orb-float-1 14s ease-in-out infinite;
}
.magic-orb--two {
  width: 180px; height: 180px;
  bottom: 20%; right: 12%;
  background: rgba(180,90,40,0.45);
  animation: orb-float-2 16s ease-in-out infinite;
}
.magic-orb--three {
  width: 130px; height: 130px;
  top: 30%; left: 14%;
  background: rgba(200,145,46,0.35);
  animation: orb-float-3 12s ease-in-out infinite;
}
.magic-sparkles { position: absolute; inset: 0; }
.sparkle {
  position: absolute;
  left: var(--x); top: var(--y);
  width: var(--size); height: var(--size);
  border-radius: 999px;
  background: rgba(255,240,200,0.8);
  box-shadow: 0 0 6px rgba(255,210,120,0.6);
  opacity: 0.25;
  animation: sparkle-fade var(--dur) ease-in-out var(--delay) infinite;
}

/* ── Hero layout ────────────────────────────────────────── */
.hero__layout {
  display: grid;
  grid-template-columns: 1.15fr 0.85fr;
  gap: 2rem;
  align-items: end;
  margin-top: 6rem;
}

/* ══════════════════════════════════════════════════════════
   TYPOGRAPHY
══════════════════════════════════════════════════════════ */
h1, h2, h3 { margin: 0; line-height: 1.08; }
h1, h2 {
  font-family: "Cormorant Garamond", Georgia, serif;
  letter-spacing: 0.01em;
}
h1 {
  font-size: clamp(2.8rem, 5.4vw, 5rem);
  max-width: 17ch;
  color: #fff;
}
h2 {
  font-size: clamp(2rem, 4vw, 3.6rem);
  max-width: 17ch;
  margin-bottom: 1.4rem;
  color: #fff;
}
h3 {
  font-size: 1.18rem;
  font-weight: 700;
  color: var(--text);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 1.35rem;
  font-weight: 600;
}

.eyebrow, .section__tag {
  color: var(--accent);
  letter-spacing: 0.28em;
  text-transform: uppercase;
  font-size: 0.68rem;
  font-weight: 700;
  margin: 0 0 0.9rem;
}

.hero__headline {
  margin: 1rem 0 0.8rem;
  max-width: 58ch;
  font-size: clamp(1.05rem, 2vw, 1.28rem);
  color: rgba(240,232,220,0.82);
  line-height: 1.6;
}

.hero__subline {
  margin: 0;
  max-width: 56ch;
  color: var(--text-2);
}
.hero__subline--typed {
  min-height: 2.8em;
  display: flex; align-items: center; gap: 0.2rem; width: 100%;
}

.typewriter-text { white-space: normal; display: block; width: 100%; }
.typewriter-caret {
  width: 0.1em; height: 1.1em;
  background: var(--accent);
  border-radius: 2px;
  animation: caret-blink 0.85s steps(1) infinite;
  align-self: center;
}
.typewriter-heading {
  display: flex; align-items: flex-start;
  gap: 0.2rem; min-height: 2.7em; width: 100%;
}

/* ── Hero benefits ──────────────────────────────────────── */
.hero__benefits {
  margin: 1.6rem 0;
  padding: 0;
  list-style: none;
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 0.6rem;
}
.hero__benefits li {
  padding: 0.6rem 0.85rem;
  border-radius: var(--r-sm);
  border: 1px solid var(--line);
  background: rgba(21,16,11,0.55);
  font-weight: 500;
  font-size: 0.9rem;
  color: var(--text);
  position: relative;
  overflow: hidden;
}
.hero__benefits li::before {
  content: "";
  position: absolute; left: 0; top: 0; bottom: 0;
  width: 2px;
  background: var(--accent);
  opacity: 0.5;
}

/* ══════════════════════════════════════════════════════════
   BUTTONS
══════════════════════════════════════════════════════════ */
.hero__actions {
  display: flex; gap: 0.75rem; flex-wrap: wrap; margin-bottom: 1.2rem;
}

.btn {
  border: 0;
  border-radius: var(--r-sm);
  cursor: pointer;
  font-weight: 700;
  font-family: inherit;
  font-size: 0.94rem;
  text-decoration: none;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: 0.4rem;
  padding: 0.9rem 1.5rem;
  transition: transform 0.2s ease, box-shadow 0.2s ease, opacity 0.2s ease;
  letter-spacing: 0.02em;
}
.btn:hover { transform: translateY(-2px); }

.btn--primary {
  color: #0a0600;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  box-shadow: 0 6px 22px rgba(200,145,46,0.30);
}
.btn--primary:hover {
  box-shadow: 0 10px 30px rgba(200,145,46,0.45);
}

.btn--ghost {
  color: var(--text);
  border: 1px solid var(--line-hi);
  background: rgba(15,12,8,0.5);
  backdrop-filter: blur(8px);
}
.btn--ghost:hover {
  border-color: rgba(245,225,195,0.3);
  background: rgba(22,17,12,0.65);
}

.btn--arcade {
  color: var(--accent-2);
  border: 1px solid rgba(200,145,46,0.45);
  background: rgba(22,14,5,0.6);
  backdrop-filter: blur(8px);
}
.btn--arcade:hover {
  background: rgba(30,20,8,0.7);
  border-color: var(--accent);
}

.btn--tiny { padding: 0.5rem 0.85rem; font-size: 0.8rem; }
.btn--full { width: 100%; }

/* ── Hero contact line ──────────────────────────────────── */
.hero__contactline {
  display: flex; flex-wrap: wrap; gap: 0.5rem;
  align-items: center; margin: 0 0 1rem;
}

.phone-link {
  display: inline-flex; align-items: center; gap: 0.38rem;
  padding: 0.32rem 0.72rem;
  border-radius: 999px;
  border: 1px solid var(--line-hi);
  background: rgba(21,16,11,0.5);
  color: var(--text-2);
  font-size: 0.87rem;
  font-weight: 600;
  text-decoration: none;
  transition: color 0.2s, border-color 0.2s, background 0.2s;
}
.phone-link:hover { color: var(--text); border-color: var(--line-hi); background: rgba(28,22,15,0.7); }
.phone-link svg { width: 13px; height: 13px; flex-shrink: 0; }

.phone-link--accent {
  color: var(--accent);
  border-color: rgba(200,145,46,0.3);
  background: var(--accent-bg);
}
.phone-link--accent:hover { color: var(--accent-2); border-color: rgba(200,145,46,0.55); }

.phone-link--gold {
  color: var(--accent-2);
  border-color: rgba(232,196,112,0.3);
  background: rgba(232,196,112,0.07);
}
.phone-link--gold:hover { color: #f0d48a; border-color: rgba(232,196,112,0.5); }

/* ── Hero urgency ───────────────────────────────────────── */
.hero__urgency {
  margin: 0.4rem 0 1rem;
  display: grid; gap: 0.2rem;
  font-size: 0.88rem; color: var(--text-2);
}
.hero__urgency strong { color: var(--accent-2); font-weight: 700; }

/* ── Hero cutout ────────────────────────────────────────── */
.hero__cutout {
  display: block;
  width: clamp(160px, 24vw, 240px);
  max-width: 100%; height: auto;
  margin-left: auto; margin-bottom: 0.6rem;
  filter: drop-shadow(0 20px 36px rgba(0,0,0,0.6));
  pointer-events: auto;
  user-select: none; -webkit-user-select: none;
  touch-action: manipulation;
  cursor: pointer;
  transition: transform 0.22s ease, filter 0.22s ease, opacity 0.22s ease;
}
.hero__cutout:hover { transform: scale(1.02) translateY(-4px); }
.hero__cutout.is-switching { opacity: 0.5; transform: scale(0.96); }
.hero__cutout.is-fun { filter: drop-shadow(0 20px 36px rgba(200,145,46,0.35)) drop-shadow(0 0 16px rgba(200,145,46,0.2)); }

.hero__cutout--mobile { display: none; }
.hero__cutout--desktop { display: block; }
.hero__cutout-hint--mobile { display: none; }
.hero__cutout-hint--desktop {
  text-align: center; color: var(--text-3);
  font-size: 0.75rem; margin-top: -0.3rem; margin-bottom: 0.5rem;
  letter-spacing: 0.05em;
}

/* ── Panel card (hero right side) ───────────────────────── */
.hero__panel { display: grid; align-content: start; gap: 1rem; }

.panel-card {
  border-radius: var(--r);
  border: 1px solid rgba(200,145,46,0.2);
  background: var(--card);
  backdrop-filter: blur(12px);
  padding: 1.2rem;
  position: relative;
  overflow: hidden;
}
.panel-card::before {
  content: "";
  position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(200,145,46,0.4), transparent);
}
.panel-card p { margin: 0 0 0.3rem; color: var(--text-2); font-size: 0.88rem; }
.panel-card h3 { font-size: 1.25rem; margin-bottom: 0.7rem; }
.panel-card ul { margin: 0 0 1rem; padding-left: 1rem; color: var(--text-2); font-size: 0.9rem; }
.panel-card li { margin-bottom: 0.35rem; }

/* ── Stats grid ─────────────────────────────────────────── */
.stats-grid {
  display: grid; grid-template-columns: repeat(2,1fr); gap: 0.6rem;
}
.stats-grid article {
  border-radius: var(--r-sm);
  border: 1px solid var(--line);
  background: rgba(21,16,11,0.7);
  padding: 0.75rem 0.9rem;
  transition: border-color 0.2s, background 0.2s;
}
.stats-grid article:hover { border-color: rgba(200,145,46,0.28); background: rgba(25,20,14,0.8); }
.stats-grid strong {
  display: block;
  font-size: 1.55rem; font-weight: 800;
  color: var(--accent);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 2rem;
}
.stats-grid span { font-size: 0.8rem; color: var(--text-2); }

/* ── Availability strip (was game strip) ─────────────────── */
.game-strip {
  margin-top: 2rem;
  padding: 1rem 1.2rem;
  border-radius: var(--r);
  border: 1px solid var(--line);
  background: var(--card);
  position: relative; overflow: hidden;
}
.game-strip::before {
  content: "";
  position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent 0%, rgba(200,145,46,0.35) 50%, transparent 100%);
}
.game-strip__head {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 0.65rem; gap: 1rem;
}
.game-strip__head strong { font-weight: 700; color: var(--text); font-size: 0.94rem; }
.game-strip__head span { color: var(--accent); font-size: 0.84rem; font-weight: 600; }
.game-strip__bar {
  height: 4px; border-radius: 999px;
  background: rgba(245,225,195,0.08); overflow: hidden; margin-bottom: 0.65rem;
}
.game-strip__bar i {
  display: block; height: 100%;
  background: linear-gradient(90deg, var(--accent), var(--accent-2));
  border-radius: 999px; width: 80%;
}
.game-strip__levels {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 0.5rem;
}
.game-strip__levels span {
  font-size: 0.78rem; color: var(--text-3); font-weight: 600;
}

/* ══════════════════════════════════════════════════════════
   SECTIONS
══════════════════════════════════════════════════════════ */
.section { padding: 5rem 0; }

.section--expedition { background: var(--bg); }
.section--contrast {
  background: var(--bg-2);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.section--reviews { background: var(--bg); }
.section--calculator {
  background: var(--bg-2);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.section--services { background: var(--bg); }
.section--booking { padding-bottom: 5rem; background: var(--bg); }

/* ── Expedition ─────────────────────────────────────────── */
.expedition-block {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  border-radius: var(--r-lg);
  border: 1px solid var(--line);
  background: var(--card);
  overflow: hidden;
}
.expedition-block__content { padding: 2rem 2rem 2rem; }
.expedition-block__content h2 { margin: 0.2rem 0 0.7rem; }
.expedition-block__content p { margin: 0; color: var(--text-2); max-width: 64ch; }

.expedition-list {
  margin: 1rem 0; padding: 0; list-style: none; display: grid; gap: 0.5rem;
}
.expedition-list li {
  border-radius: var(--r-sm);
  border: 1px solid var(--line);
  background: rgba(12,9,6,0.55);
  padding: 0.62rem 0.85rem;
  font-weight: 500; color: var(--text);
  font-size: 0.92rem;
}
.expedition-cta { display: flex; gap: 0.65rem; flex-wrap: wrap; margin-top: 1rem; }

.expedition-badges {
  border-left: 1px solid var(--line);
  background: rgba(8,6,4,0.6);
  padding: 1.5rem 1.2rem;
  display: grid; gap: 0.7rem; align-content: center;
}
.expedition-badges article {
  border-radius: var(--r-sm);
  border: 1px solid var(--line);
  background: rgba(21,16,11,0.7);
  padding: 0.75rem 0.9rem;
}
.expedition-badges strong { display: block; color: var(--text); margin-bottom: 0.25rem; font-weight: 600; }
.expedition-badges span { color: var(--text-2); font-size: 0.88rem; }

.expedition-case__video {
  margin: 0.5rem 0 0.6rem;
  border-radius: var(--r-sm);
  overflow: hidden;
  border: 1px solid var(--line);
  background: #000;
  aspect-ratio: 16/9;
}
.expedition-case__video iframe { width: 100%; height: 100%; border: 0; display: block; }

/* ── Works grid ─────────────────────────────────────────── */
.works-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 0.85rem;
}
.work {
  min-height: 240px;
  border-radius: var(--r);
  overflow: hidden;
  border: 1px solid var(--line);
  position: relative;
  background: var(--bg-3);
  cursor: pointer;
}
.work::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 40%, rgba(4,3,2,0.90) 100%);
}
.work img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.45s ease; }
.work:hover img { transform: scale(1.06); }
.work:hover { border-color: rgba(200,145,46,0.28); }
.work__meta { position: absolute; left: 1rem; right: 1rem; bottom: 0.85rem; z-index: 2; }
.work__meta span {
  display: block; font-size: 1rem; font-weight: 700; color: #fff;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 1.2rem;
}
.work__meta small { color: rgba(240,228,210,0.75); font-size: 0.83rem; }

/* ── Reasons ────────────────────────────────────────────── */
.split { display: grid; grid-template-columns: 1fr 340px; gap: 1.2rem; }
.reasons-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 0.75rem; }
.reason {
  border-radius: var(--r-sm);
  border: 1px solid var(--line);
  padding: 0.9rem 1rem;
  background: rgba(21,16,11,0.55);
  font-weight: 500; color: var(--text);
  transition: border-color 0.2s, background 0.2s;
  font-size: 0.92rem;
  position: relative; overflow: hidden;
}
.reason::before {
  content: "";
  position: absolute; left: 0; top: 0; bottom: 0;
  width: 2px;
  background: rgba(200,145,46,0.4);
  opacity: 0;
  transition: opacity 0.2s;
}
.reason:hover { border-color: rgba(200,145,46,0.22); background: rgba(21,16,11,0.78); }
.reason:hover::before { opacity: 1; }

.promise {
  align-self: end;
  border-radius: var(--r);
  padding: 1.3rem;
  background: rgba(21,16,11,0.8);
  border: 1px solid rgba(200,145,46,0.2);
  position: relative; overflow: hidden;
}
.promise::before {
  content: "";
  position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(200,145,46,0.4), transparent);
}
.promise p { margin-top: 0; color: var(--text); font-size: 1.02rem; line-height: 1.7; }
.promise ul { margin: 0; padding-left: 1.1rem; color: var(--text-2); }
.promise li { margin-bottom: 0.35rem; }

/* ── Reviews ────────────────────────────────────────────── */
.reviews-head {
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: 1rem; margin-bottom: 1.2rem;
}
.reviews-live {
  margin: 0; max-width: 60ch; color: var(--text-2); font-size: 0.96rem;
  display: flex; align-items: center; gap: 0.2rem; min-height: 2em; width: 100%;
}
.reviews-nav { display: flex; gap: 0.5rem; }
.reviews-nav button {
  width: 42px; height: 42px;
  border-radius: var(--r-sm);
  border: 1px solid var(--line-hi);
  background: var(--bg-3);
  color: var(--text);
  cursor: pointer; font-size: 1rem;
  transition: border-color 0.2s;
}
.reviews-nav button:hover { border-color: var(--accent); color: var(--accent); }
.reviews-carousel { position: relative; }
.reviews-track {
  display: flex; gap: 0.9rem; overflow-x: auto;
  scroll-snap-type: x mandatory; scroll-behavior: smooth;
  padding-bottom: 0.4rem;
}
.reviews-track::-webkit-scrollbar { height: 4px; }
.reviews-track::-webkit-scrollbar-thumb { background: rgba(200,145,46,0.25); border-radius: 999px; }
.review {
  flex: 0 0 clamp(260px, 30vw, 360px);
  scroll-snap-align: start;
  border-radius: var(--r);
  border: 1px solid var(--line);
  background: var(--card);
  padding: 1.1rem;
  transition: border-color 0.2s;
}
.review:hover { border-color: rgba(200,145,46,0.22); }
.review p { margin: 0; color: var(--text); line-height: 1.65; font-size: 0.95rem; }
.review span { color: var(--text-2); font-size: 0.88rem; }
.review__head { display: flex; align-items: center; gap: 0.7rem; margin-bottom: 0.7rem; }
.review__avatar {
  width: 48px; height: 48px; border-radius: 999px;
  object-fit: cover; border: 1px solid var(--line-hi);
}
.review__meta strong { display: block; color: var(--text); font-size: 0.93rem; }
.review__meta small { color: var(--text-2); font-size: 0.78rem; }
.review__rating { display: inline-block; margin-top: 0.6rem; color: var(--accent-2); letter-spacing: 0.04em; }

/* ── Section captions ───────────────────────────────────── */
.section__caption, .pricing-note, .pricing-urgent {
  color: var(--text-2); margin: 1rem 0 0;
}
.section__caption--typed, .pricing-note--typed, .pricing-urgent--typed, .booking-live {
  display: flex; align-items: center; gap: 0.2rem; min-height: 2em; width: 100%;
}
.booking-live { margin: 0 0 1rem; color: var(--text-2); max-width: 60ch; }
.pricing-note { font-weight: 600; }
.pricing-urgent { color: var(--text); font-weight: 700; }

/* ══════════════════════════════════════════════════════════
   PRICING
══════════════════════════════════════════════════════════ */
.pricing-grid {
  display: grid; grid-template-columns: repeat(3,minmax(0,1fr));
  gap: 1rem; align-items: stretch;
}
.price-card {
  border-radius: var(--r);
  border: 1px solid var(--line);
  background: var(--card);
  padding: 1.5rem;
  transition: border-color 0.22s, box-shadow 0.22s, transform 0.22s;
  position: relative; overflow: hidden;
}
.price-card::before {
  content: "";
  position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(200,145,46,0.2), transparent);
}
.price-card:hover { border-color: rgba(200,145,46,0.25); }
.price-card--popular {
  border-color: rgba(200,145,46,0.5);
  box-shadow: 0 12px 40px rgba(200,145,46,0.10), 0 0 0 1px rgba(200,145,46,0.18) inset;
}
.price-card--popular::before {
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
  opacity: 0.6;
}
.price-card--main { transform: translateY(-12px) scale(1.02); }
.price-card__name {
  margin: 0; color: var(--text-3);
  text-transform: uppercase; letter-spacing: 0.09em; font-size: 0.68rem; font-weight: 700;
}
.price-card h3 { margin: 0.4rem 0; }
.price {
  color: var(--accent);
  font-size: 2.2rem;
  font-weight: 800;
  margin: 0.5rem 0 0.8rem;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 2.8rem;
}
.price-card ul { margin: 0; padding-left: 1rem; }
.price-card li { margin-bottom: 0.4rem; color: var(--text-2); font-size: 0.92rem; }
.price-card__note { margin: 0.7rem 0 0; color: var(--text-3); font-size: 0.84rem; }
.badge {
  margin: 0 0 0.75rem;
  padding: 0.3rem 0.7rem;
  width: fit-content;
  border-radius: 999px;
  font-size: 0.68rem;
  color: #0a0600;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

/* ══════════════════════════════════════════════════════════
   CALCULATOR
══════════════════════════════════════════════════════════ */
.calc-wrap { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 1rem; }
.calc-form, .calc-result {
  border-radius: var(--r);
  border: 1px solid var(--line);
  background: var(--card);
  padding: 1.2rem;
}
.calc-form { display: grid; gap: 0.65rem; }
.calc-form label {
  display: grid; gap: 0.28rem;
  color: var(--text); font-size: 0.9rem; font-weight: 600;
}
.calc-form select {
  width: 100%;
  border: 1px solid var(--line-hi);
  border-radius: var(--r-sm);
  background: var(--bg-3);
  color: var(--text);
  padding: 0.78rem 0.9rem;
  font: inherit;
  transition: border-color 0.2s;
}
.calc-form select:focus { outline: none; border-color: rgba(200,145,46,0.5); }
.calc-check {
  display: flex; gap: 0.5rem; align-items: center;
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  background: rgba(8,6,4,0.55);
  padding: 0.68rem 0.8rem;
  font-size: 0.9rem; color: var(--text);
  transition: border-color 0.2s;
  cursor: pointer;
}
.calc-check:hover { border-color: rgba(200,145,46,0.22); }
.calc-check input { width: 15px; height: 15px; accent-color: var(--accent); cursor: pointer; }
.calc-result { display: grid; align-content: start; gap: 0.75rem; }
.calc-result p { margin: 0; color: var(--text-2); }
.calc-result strong {
  font-size: clamp(2.4rem, 5vw, 3.4rem);
  color: var(--accent);
  line-height: 1;
  font-family: "Cormorant Garamond", Georgia, serif;
}
.calc-result span, .calc-result small { color: var(--text-2); font-size: 0.88rem; }

/* ══════════════════════════════════════════════════════════
   SERVICES
══════════════════════════════════════════════════════════ */
.services-grid {
  display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 0.85rem;
}
.service-card {
  border-radius: var(--r);
  border: 1px solid var(--line);
  background: var(--card);
  padding: 1.2rem;
  transition: border-color 0.22s, transform 0.22s;
  position: relative; overflow: hidden;
}
.service-card::before {
  content: "";
  position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(200,145,46,0.2), transparent);
  opacity: 0;
  transition: opacity 0.22s;
}
.service-card:hover { border-color: rgba(200,145,46,0.25); transform: translateY(-3px); }
.service-card:hover::before { opacity: 1; }
.service-card h3 { margin-bottom: 0.5rem; font-size: 1.2rem; }
.service-card p { color: var(--text-2); margin: 0 0 0.7rem; font-size: 0.9rem; }
.service-card strong { color: var(--accent); font-weight: 700; }

/* ══════════════════════════════════════════════════════════
   BOOKING
══════════════════════════════════════════════════════════ */
.booking-wrap {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 1.5rem;
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  background: var(--card);
  backdrop-filter: blur(10px);
  padding: 1.8rem;
  position: relative; overflow: hidden;
}
.booking-wrap::before {
  content: "";
  position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent 0%, var(--accent) 50%, transparent 100%);
  opacity: 0.5;
}
.booking-wrap h2 { color: var(--text); }

.quick-form {
  margin: 1rem 0;
  display: grid; gap: 0.6rem;
  padding: 1rem;
  border-radius: var(--r);
  border: 1px solid rgba(200,145,46,0.25);
  background: rgba(12,9,6,0.55);
}
.quick-form label { display: grid; gap: 0.28rem; font-size: 0.9rem; color: var(--text); font-weight: 600; }
.quick-form input {
  width: 100%;
  border: 1px solid var(--line-hi);
  border-radius: var(--r-sm);
  background: var(--bg-3);
  color: var(--text);
  padding: 0.82rem 0.9rem;
  font: inherit;
  transition: border-color 0.2s;
}
.quick-form input:focus { outline: none; border-color: rgba(200,145,46,0.5); }

.booking-details {
  margin-bottom: 1rem;
  border-radius: var(--r-sm);
  border: 1px solid var(--line);
  background: rgba(12,9,6,0.5);
  padding: 0.75rem 0.9rem;
}
.booking-details summary { cursor: pointer; font-weight: 700; color: var(--text-2); }

.booking-form { display: grid; gap: 0.7rem; }
.booking-form label { display: grid; gap: 0.28rem; color: var(--text); font-weight: 600; font-size: 0.9rem; }
.booking-form input, .booking-form textarea {
  width: 100%;
  border: 1px solid var(--line-hi);
  border-radius: var(--r-sm);
  background: var(--bg-3);
  color: var(--text);
  padding: 0.82rem 0.9rem;
  font: inherit;
  transition: border-color 0.2s;
}
.booking-form input:focus, .booking-form textarea:focus {
  outline: none;
  border-color: rgba(200,145,46,0.5);
}
.booking-form--extended { margin-top: 0.8rem; }

.booking-note {
  border-radius: var(--r);
  border: 1px solid var(--line);
  background: rgba(21,16,11,0.65);
  padding: 1.2rem;
}
.booking-note h3 { margin-bottom: 0.6rem; }
.booking-note ul { margin: 0 0 0.8rem; padding-left: 1rem; }
.booking-note li { margin-bottom: 0.4rem; color: var(--text-2); }
.booking-note p { margin: 0; color: var(--text-2); font-size: 0.9rem; }

/* ══════════════════════════════════════════════════════════
   FOOTER
══════════════════════════════════════════════════════════ */
.footer {
  border-top: 1px solid var(--line);
  padding: 1.5rem 0;
  background: var(--bg-2);
}
.footer__inner {
  display: flex; justify-content: space-between;
  align-items: flex-start; gap: 1.5rem;
  color: var(--text-2);
}
.footer__inner a {
  color: var(--text-2); text-decoration: none;
  transition: color 0.2s;
}
.footer__inner a:hover { color: var(--text); }
.footer__fun { max-width: 560px; }
.footer__title { margin: 0 0 0.5rem; color: var(--text); font-weight: 700; }
.footer__fun ul { margin: 0 0 0.65rem; padding-left: 1rem; }
.footer__fun li { margin-bottom: 0.3rem; }
.footer__joke { margin: 0; color: var(--text-2); }
.footer__phones { display: flex; gap: 0.5rem; flex-wrap: wrap; margin: 0.35rem 0 0.65rem; }

/* ── Store badges ───────────────────────────────────────── */
.store-badges { margin-top: 0.8rem; display: flex; gap: 0.55rem; flex-wrap: wrap; }
.store-badge {
  display: inline-flex; align-items: center; gap: 0.5rem;
  border: 1px solid var(--line-hi);
  border-radius: var(--r-sm);
  background: var(--bg-3);
  color: var(--text);
  padding: 0.5rem 0.7rem;
  cursor: pointer;
  transition: border-color 0.2s, transform 0.2s;
}
.store-badge:hover { border-color: var(--accent); transform: translateY(-2px); }
.store-badge small { display: block; color: var(--text-3); font-size: 0.65rem; line-height: 1.1; }
.store-badge strong { font-size: 0.86rem; }
.store-badge__icon {
  width: 26px; height: 26px; border-radius: 7px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--accent-bg);
}
.store-badge__icon svg { width: 16px; height: 16px; }

/* ══════════════════════════════════════════════════════════
   POPUPS
══════════════════════════════════════════════════════════ */
.quick-popup {
  position: fixed; inset: 0; z-index: 170; display: none;
}
.quick-popup.is-open { display: block; }
.quick-popup__backdrop {
  position: absolute; inset: 0;
  background: rgba(4,3,2,0.82);
  backdrop-filter: blur(10px);
}
.quick-popup__dialog {
  position: absolute; left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  width: min(560px, calc(100% - 1.5rem));
  border-radius: var(--r-lg);
  border: 1px solid rgba(200,145,46,0.32);
  background: var(--bg-2);
  box-shadow: 0 24px 60px rgba(0,0,0,0.6);
  padding: 1.4rem;
  position: absolute; left: 50%; top: 50%;
  transform: translate(-50%, -50%);
}
.quick-popup__dialog h3 { margin-bottom: 0.55rem; }
.quick-popup__dialog p { color: var(--text-2); margin-top: 0; }
.quick-popup__close {
  position: absolute; top: 0.7rem; right: 0.7rem;
  width: 34px; height: 34px; border-radius: 999px;
  border: 1px solid var(--line-hi);
  background: var(--bg-3); color: var(--text);
  cursor: pointer; font-size: 1.2rem; line-height: 1;
}

.bonus-roll {
  margin: 0.75rem 0;
  border-radius: var(--r-sm);
  border: 1px solid var(--line);
  background: rgba(12,9,6,0.6);
  padding: 0.8rem;
}
.bonus-roll p { margin-bottom: 0.3rem; color: var(--text-2); }
.bonus-roll strong { display: block; margin-bottom: 0.55rem; color: var(--accent); font-size: 1rem; }

.popup-form { display: grid; gap: 0.6rem; }
.popup-form label { display: grid; gap: 0.28rem; color: var(--text); font-size: 0.9rem; font-weight: 600; }
.popup-form input, .popup-form select {
  width: 100%;
  border: 1px solid var(--line-hi);
  border-radius: var(--r-sm);
  background: var(--bg-3);
  color: var(--text);
  padding: 0.8rem 0.9rem;
  font: inherit;
}
body.popup-open { overflow: hidden; }

.install-popup {
  position: fixed; inset: 0; z-index: 175; display: none;
}
.install-popup.is-open { display: block; }
.install-popup__backdrop {
  position: absolute; inset: 0;
  background: rgba(4,3,2,0.85);
  backdrop-filter: blur(10px);
}
.install-popup__dialog {
  position: absolute; left: 50%; top: 50%;
  transform: translate(-50%,-50%);
  width: min(520px, calc(100% - 1.5rem));
  border-radius: var(--r-lg);
  border: 1px solid rgba(200,145,46,0.32);
  background: var(--bg-2);
  box-shadow: 0 24px 60px rgba(0,0,0,0.6);
  padding: 1.2rem;
}
.install-popup__close {
  position: absolute; top: 0.7rem; right: 0.7rem;
  width: 34px; height: 34px; border-radius: 999px;
  border: 1px solid var(--line-hi);
  background: var(--bg-3); color: var(--text);
  cursor: pointer; font-size: 1.2rem;
}
.install-popup__steps { margin: 0.5rem 0 1rem; padding-left: 1.2rem; color: var(--text-2); }
.install-popup__steps li { margin-bottom: 0.35rem; }
body.install-open { overflow: hidden; }

.video-popup {
  position: fixed; inset: 0; z-index: 182; display: none;
}
.video-popup.is-open { display: block; }
.video-popup__backdrop {
  position: absolute; inset: 0;
  background: rgba(4,3,2,0.92);
  backdrop-filter: blur(8px);
}
.video-popup__dialog {
  position: absolute; left: 50%; top: 50%;
  width: min(1020px, calc(100% - 1.2rem));
  transform: translate(-50%,-50%);
}
.video-popup__frame {
  border-radius: var(--r);
  border: 1px solid rgba(200,145,46,0.28);
  overflow: hidden; background: #000;
  box-shadow: 0 24px 55px rgba(0,0,0,0.65);
  aspect-ratio: 16/9;
}
.video-popup__frame iframe { width: 100%; height: 100%; border: 0; display: block; }
.video-popup__close {
  position: absolute; right: 0; top: -44px;
  width: 36px; height: 36px; border-radius: 9px;
  border: 1px solid var(--line-hi);
  background: var(--bg-3); color: var(--text);
  cursor: pointer; font-size: 1.15rem;
}
body.video-open { overflow: hidden; }

/* ── Hover card lift ────────────────────────────────────── */
.panel-card, .work, .reason, .review, .price-card, .service-card {
  transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
  will-change: transform;
}
.panel-card.tilted, .work.tilted, .reason.tilted,
.review.tilted, .price-card.tilted, .service-card.tilted {
  border-color: rgba(200,145,46,0.32);
  box-shadow: 0 14px 32px rgba(0,0,0,0.3);
}

/* ── Mobile CTA bar ─────────────────────────────────────── */
.mobile-cta {
  position: fixed; left: 0.7rem; right: 0.7rem; bottom: 0.7rem;
  z-index: 30; display: none; gap: 0.55rem;
}
.mobile-cta a {
  flex: 1; text-align: center; text-decoration: none;
  padding: 0.78rem 0.6rem; border-radius: var(--r-sm);
  font-size: 0.9rem; font-weight: 700;
}
.mobile-cta a:first-child {
  color: var(--text);
  border: 1px solid var(--line-hi);
  background: rgba(10,8,5,0.9);
  backdrop-filter: blur(10px);
}
.mobile-cta a:last-child {
  color: #0a0600;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
}

/* ══════════════════════════════════════════════════════════
   REVEAL ANIMATIONS
══════════════════════════════════════════════════════════ */
.reveal { opacity: 1; transform: none; }
.js .reveal {
  opacity: 0; transform: translate3d(0,28px,0);
  transition: opacity 0.7s ease, transform 0.75s cubic-bezier(0.22,1,0.36,1);
  transition-delay: var(--reveal-delay, 0ms);
}
.js .reveal.in-view { opacity: 1; transform: translate3d(0,0,0); }

.work.reveal:nth-child(2), .reason.reveal:nth-child(2), .price-card.reveal:nth-child(2) { --reveal-delay: 110ms; }
.work.reveal:nth-child(3), .reason.reveal:nth-child(3), .price-card.reveal:nth-child(3) { --reveal-delay: 190ms; }
.work.reveal:nth-child(4), .reason.reveal:nth-child(4) { --reveal-delay: 260ms; }
.work.reveal:nth-child(5), .reason.reveal:nth-child(5) { --reveal-delay: 320ms; }
.work.reveal:nth-child(6), .reason.reveal:nth-child(6) { --reveal-delay: 380ms; }

/* ══════════════════════════════════════════════════════════
   KEYFRAMES
══════════════════════════════════════════════════════════ */
@keyframes caret-blink {
  0%,44% { opacity: 1; } 45%,100% { opacity: 0; }
}
@keyframes orb-float-1 {
  0%,100% { transform: translate3d(0,0,0); } 50% { transform: translate3d(0,-20px,0); }
}
@keyframes orb-float-2 {
  0%,100% { transform: translate3d(0,0,0); } 50% { transform: translate3d(-16px,16px,0); }
}
@keyframes orb-float-3 {
  0%,100% { transform: translate3d(0,0,0); } 50% { transform: translate3d(14px,-18px,0); }
}
@keyframes sparkle-fade {
  0%,100% { opacity: 0.08; transform: scale(0.8); } 50% { opacity: 0.7; transform: scale(1.2); }
}

/* ══════════════════════════════════════════════════════════
   RESPONSIVE — TABLET
══════════════════════════════════════════════════════════ */
@media (max-width: 1024px) {
  .hero__layout,
  .split,
  .expedition-block,
  .calc-wrap,
  .pricing-grid,
  .services-grid,
  .booking-wrap { grid-template-columns: 1fr; }

  .expedition-badges {
    border-left: 0;
    border-top: 1px solid var(--line);
  }

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

  .nav__links, .nav__cta { display: none; }
  .nav__toggle { display: inline-flex; }
}

/* ══════════════════════════════════════════════════════════
   RESPONSIVE — MOBILE
══════════════════════════════════════════════════════════ */
@media (max-width: 680px) {
  .container { width: min(1160px, calc(100% - 1.4rem)); }

  .hero { min-height: auto; padding-top: 0.8rem; }

  .nav {
    border-radius: 14px;
    padding: 0.6rem 0.75rem;
    width: calc(100% - 1.4rem);
    top: 0.6rem;
  }
  .lang-switch { margin-left: auto; }

  .hero__layout { margin-top: 4.5rem; }

  .hero__benefits,
  .works-grid,
  .reasons-grid,
  .services-grid { grid-template-columns: 1fr; }

  .hero__content,
  .section__tag,
  .typewriter-heading,
  .section__caption--typed,
  .pricing-note--typed,
  .pricing-urgent--typed,
  .booking-live,
  .reviews-live,
  .expedition-block__content p {
    text-align: center;
    justify-content: center;
    margin-left: auto; margin-right: auto;
  }

  .hero__benefits li,
  .expedition-list li,
  .booking-note h3,
  .booking-note p { text-align: center; }

  .hero__contactline, .expedition-cta { justify-content: center; }
  .reviews-head { align-items: flex-start; flex-direction: column; }

  .hero__cutout--desktop { display: none; }
  .hero__cutout--desktop ~ .hero__cutout-hint--desktop { display: none; }
  .hero__cutout--mobile {
    display: block;
    width: clamp(200px, 68vw, 280px);
    margin: 0.75rem auto 0.6rem;
  }
  .hero__cutout-hint--mobile {
    display: block;
    text-align: center; color: var(--text-3);
    font-size: 0.75rem; margin: -0.2rem auto 0.9rem;
  }

  .game-strip__levels { grid-template-columns: 1fr; }
  .price-card--main { transform: none; }

  .magic-orb { filter: blur(36px); opacity: 0.12; }

  .hero__actions { flex-direction: column; }
  .btn, .btn--full { width: 100%; }

  .section { padding: 3.5rem 0; }

  .footer__inner { flex-direction: column; align-items: flex-start; }
  .store-badge { width: 100%; justify-content: flex-start; }

  .mobile-cta {
    display: flex;
    bottom: calc(0.7rem + env(safe-area-inset-bottom, 0px));
  }
  body { padding-bottom: 0; }
}

/* ══════════════════════════════════════════════════════════
   REDUCED MOTION
══════════════════════════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
  .magic-orb, .sparkle { animation: none; }
  .reveal { opacity: 1; transform: none; transition: none; }
  .panel-card, .work, .reason, .review, .price-card,
  .hero__media, .hero__veil { transition: none; transform: none; }
}
