:root {
  --bg: #0f0f13;
  --card: rgba(21,25,34,.82);
  --muted: #c4c9d4;
  --text: #f4f6fb;
  --accent: #f4c34a; /* золото */
  --accent-2: #ffd86a;
  --border: rgba(255,255,255,.12);
  --shadow: 0 12px 30px rgba(0,0,0,.35);
}

html.tg-theme {
  --bg: var(--tg-theme-bg-color, #0f0f13);
  --text: var(--tg-theme-text-color, #f4f6fb);
  --card: color-mix(in oklab, var(--tg-theme-secondary-bg-color) 90%, transparent);
  --muted: var(--tg-theme-hint-color, #c4c9d4);
  --accent: #f4c34a;
  --accent-2: #ffd86a;
  --border: rgba(255,255,255,.14);
}

* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0;
  font-family: "Inter", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  color: var(--text);
  background: var(--bg);
}

/* === ФОН (изображение + затемнение + лёгкое «дыхание») === */
body::before {
  content: "";
  position: fixed; inset: 0;
  background-image:
    radial-gradient(1200px 500px at 70% -10%, rgba(244,195,74,.25), transparent 60%),
    linear-gradient(180deg, rgba(0,0,0,.35), rgba(0,0,0,.65)),
    url('bg.v2.webp');   /* ✅ новая версия картинки: легче и быстрее грузится */
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  background-attachment: fixed;
  filter: saturate(1.05);
  z-index: -1;

  /* параллакс-анимация */
  animation: bgMove 18s ease-in-out infinite;
  transform-origin: center;
}

@keyframes bgMove {
  0%   { background-position: 50% 50%; transform: scale(1); }
  50%  { background-position: 48% 52%; transform: scale(1.02); }
  100% { background-position: 50% 50%; transform: scale(1); }
}

/* HERO */
.hero {
  display: flex; gap: 14px; align-items: center;
  padding: 16px 18px 8px;
}
.logo {
  width: 44px; height: 44px; border-radius: 12px; object-fit: cover;
  box-shadow: var(--shadow);
}
.hero-text h1 { 
  margin: 0 0 2px; 
  font-size: 20px; 
  font-weight: 800; 
  letter-spacing: .2px;
  background: linear-gradient(90deg, var(--accent), var(--accent-2));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.hero-text p { 
  margin: 0; 
  font-size: 13px; 
  font-weight: 600;
  color: var(--accent-2);
  text-shadow: 0 0 10px rgba(244,195,74,.3);
}

/* LAYOUT */
.container { padding: 10px 16px 92px; }

.card {
  position: relative;
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
  background: rgba(30, 30, 35, 0.35);
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: 20px;
  padding: 20px;
  margin-bottom: 18px;
  overflow: hidden;
  box-shadow:
    0 12px 40px rgba(0, 0, 0, 0.35),
    inset 0 0 25px rgba(255, 255, 255, 0.05);
  transition: all 0.4s ease-in-out;
}

/* золотое свечение по краям */
.card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 20px;
  padding: 1px;
  background: linear-gradient(135deg, rgba(244,195,74,0.55), rgba(255,216,106,0.45), rgba(244,195,74,0.55));
  -webkit-mask: 
    linear-gradient(#fff 0 0) content-box, 
    linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  transition: opacity .4s ease;
  opacity: 0.35;
}

.card:hover::before {
  opacity: 0.9;
  filter: drop-shadow(0 0 12px rgba(244,195,74,0.6));
}

.card:hover {
  background: rgba(35, 35, 45, 0.45);
  transform: translateY(-2px);
  box-shadow:
    0 18px 45px rgba(0, 0, 0, 0.45),
    inset 0 0 30px rgba(255, 255, 255, 0.07);
}

.card.profile {
  isolation: isolate;
  backdrop-filter: blur(24px) saturate(145%);
  -webkit-backdrop-filter: blur(24px) saturate(145%);
  background:
    linear-gradient(180deg, rgba(20, 24, 31, 0.78), rgba(14, 18, 24, 0.74)),
    linear-gradient(135deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.01));
  border: 1px solid rgba(255, 255, 255, 0.16);
  box-shadow:
    0 18px 48px rgba(0, 0, 0, 0.42),
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    inset 0 0 26px rgba(255, 255, 255, 0.03);
}

.card.profile::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  background:
    radial-gradient(120% 90% at 10% 0%, rgba(255, 255, 255, 0.08), transparent 40%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0) 42%, rgba(0, 0, 0, 0.10));
  opacity: 1;
}

.card.profile > * {
  position: relative;
  z-index: 1;
}

.card-head {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  margin-bottom: 10px;
}
.card h2 { margin: 0; font-size: 18px; font-weight: 800; }

.badge {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 68px; height: 34px; padding: 0 14px;
  background: linear-gradient(90deg, var(--accent), var(--accent-2));
  color: #2e2100; border-radius: 999px; font-weight: 800;
  font-size: 18px; line-height: 1; box-shadow: 0 4px 10px rgba(0,0,0,.25);
}

#discount-badge {
  min-width: 84px;
  height: 40px;
  padding: 0 16px;
  font-size: 24px;
  font-weight: 900;
  letter-spacing: -.02em;
  box-shadow: 0 8px 18px rgba(0,0,0,.28);
}

.grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px 14px; }
@media (max-width: 430px) { .grid { grid-template-columns: 1fr; } }

.field { display: flex; flex-direction: column; gap: 6px; }
.label { font-size: 12px; color: #f0f0f0; text-transform: uppercase; letter-spacing: .4px; }
.value { font-size: 16px; font-weight: 700; }

/* 🩶 Выравнивание телефона по центру строки */
#phone {
  display: inline-flex;
  align-items: center;
  line-height: 1.2;
  margin-top: 1px;
  position: relative;
  top: -1px; /* чуть приподнимаем */
}

.like-input {
  width: 100%;
  background: rgba(255,255,255,.03);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 11px 12px;
  font-size: 14px;
  color: var(--text);
  white-space: pre-wrap;
}

.card.profile #terms.like-input {
  position: relative;
  overflow: hidden;
  background: rgba(255,255,255,.03) !important;
  border: 1px solid var(--border) !important;
  -webkit-backdrop-filter: none;
  backdrop-filter: none;
  box-shadow: none;
}

.card.profile #terms.like-input::before {
  display: none;
}

.card.profile #terms.like-input > * {
  position: relative;
  z-index: 1;
}

.actions { display: flex; gap: 10px; margin-top: 12px; flex-wrap: wrap; }
.btn {
  appearance: none; border: none; cursor: pointer; text-decoration: none;
  padding: 12px 14px; border-radius: 12px; font-weight: 800; font-size: 14px;
  transition: transform .08s ease, filter .2s ease, box-shadow .2s ease;
}
.btn:active { transform: translateY(1px) scale(.995); }

.btn.primary {
  background: linear-gradient(90deg, var(--accent), var(--accent-2));
  color: #2e2100;
  box-shadow: 0 8px 20px rgba(244,195,74,.25);
}
.btn.primary:hover {
  box-shadow: 0 0 20px rgba(244,195,74,.45), 0 0 50px rgba(255,216,106,.35);
}

.btn.ghost {
  background: transparent; color: var(--text); border: 1px solid var(--border);
}
.btn.ghost:hover {
  border-color: var(--accent);
  box-shadow: 0 0 12px rgba(244,195,74,.35);
}

.hint { color: var(--muted); font-size: 12px; margin-top: 12px; }

/* Нижний фиксированный футер */
.footer {
  position: fixed; left: 0; right: 0; bottom: 0;
  display: flex; justify-content: center; padding: 12px 16px;
  background: linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,.45));
  backdrop-filter: blur(6px);
}
.support {
  background: rgba(255,255,255,.06); border: 1px solid var(--border); color: var(--text);
  padding-left: 18px; padding-right: 18px;
}
/* 🌌 Плавное дыхание фона (параллакс-эффект) */
@keyframes bgMove {
  0% { background-position: 50% 50%; transform: scale(1); }
  50% { background-position: 48% 52%; transform: scale(1.02); }
  100% { background-position: 50% 50%; transform: scale(1); }
}

.bg {
  animation: bgMove 18s ease-in-out infinite;
  transform-origin: center;
}

/* ==== FORCE LIGHT TEXT INSIDE THE CARD ==== */
.card,
.card h2,
.card .label,
.card .value,
.card .like-input,
.card .like-input *,
.card a:not(.btn) {
  color: #ffffff !important;
}

/* значения (имя, телефон и т.п.) */
.card .value { color: #ffffff !important; }

/* поля-плашки "Умови/Нотатки" */
.like-input { color: #ffffff !important; }

/* ссылки внутри карточки (например, если телефон стал ссылкой) */
.card a:not(.btn) { color: #ffffff !important; text-decoration: none; }

/* при этом у жёлтых кнопок текст остаётся тёмным */
.btn.primary { color: #2e2100 !important; }

/* у "прозрачной" кнопки текст белый */
.btn.ghost { color: #ffffff !important; }

/* ==== Цвет текста для кнопки підтримка ==== */
.btn.support,
.footer .btn.support {
  color: #ffffff !important;
  border-color: rgba(255,255,255,0.25) !important;
}

.btn.support:hover {
  border-color: var(--accent);
  box-shadow: 0 0 12px rgba(244,195,74,.35);
}

/* Fix: видимий текст у випадаючому списку тільки на Desktop */
@media (hover: hover) and (pointer: fine) {
  /* лише в десктопних середовищах із мишею */
  .card select option,
  .card select optgroup {
    color: #111 !important;            /* темний текст */
    background-color: #fff !important; /* світлий фон у випадаючому меню */
  }

  /* якщо десь було вимкнено «меню» вигляд, повернемо для desktop */
  .card select {
    appearance: menulist;
    -webkit-appearance: menulist;
  }
}

/* --- Forced light select only where we add the class --- */
.light-select {
  appearance: menulist;
  -webkit-appearance: menulist;
  background: #fff !important;
  color: #111 !important;
  border: 1px solid rgba(0,0,0,.2);
  border-radius: 10px;
}

.light-select option {
  background: #fff !important;
  color: #111 !important;
}

/* =========================
   CINEMATIC SPLASH (Premium)
   ========================= */

.splash{
  position:fixed;
  inset:0;
  z-index:99999;
  background:#050505;
  overflow:hidden;
  opacity:1;
  pointer-events:auto;
  transition:opacity .55s ease;
}

.splash.is-hiding{
  opacity:0;
  pointer-events:none;
}

.splash__vignette{
  position:absolute; inset:-30%;
  background:radial-gradient(closest-side, rgba(0,0,0,.15), rgba(0,0,0,.85) 65%, rgba(0,0,0,.98));
  filter:blur(0px);
}

.splash__grain{
  position:absolute; inset:0;
  opacity:.12;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='140' height='140' filter='url(%23n)' opacity='.35'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}

.splash__flare{
  position:absolute; inset:-20%;
  opacity:.35;
  background:
    radial-gradient(circle at 30% 20%, rgba(255,210,120,.55), rgba(255,210,120,0) 45%),
    radial-gradient(circle at 70% 35%, rgba(255,200,90,.30), rgba(255,200,90,0) 55%),
    radial-gradient(circle at 50% 80%, rgba(255,180,80,.18), rgba(255,180,80,0) 60%);
  filter:blur(6px);
  animation:splashFlare 3.2s ease-in-out infinite alternate;
}

@keyframes splashFlare{
  from{ transform:translate3d(-1.5%, -1%, 0) scale(1.02); opacity:.28; }
  to  { transform:translate3d(1.5%,  1%, 0) scale(1.06); opacity:.40; }
}

.splash__brand{
  position:absolute;
  left:50%; top:22%;
  transform:translateX(-50%);
  text-align:center;
  color:rgba(255,230,170,.92);
  letter-spacing:.06em;
}

.splash__logo{
  width:90px;
  height:auto;
  filter:drop-shadow(0 10px 28px rgba(0,0,0,.65));
  opacity:.92;
}

.splash__title{
  margin-top:10px;
  font-weight:700;
  font-size:18px;
  text-transform:uppercase;
}

.splash__sub{
  margin-top:6px;
  font-size:12px;
  opacity:.78;
}

.splash__tools{
  position:absolute; inset:0;
  transform:translateZ(0);
}

.splash__tool{
  position:absolute;
  top:-30vh;
  width:46px;
  height:360px;
  background-repeat:no-repeat;
  background-position:center;
  background-size:contain;
  opacity:.0;
  filter:
    drop-shadow(0 18px 34px rgba(0,0,0,.55))
    saturate(1.05)
    contrast(1.05);
  transform-origin:center;
  will-change:transform, opacity;
  animation: toolFall var(--dur) cubic-bezier(.18,.72,.12,.99) forwards;
}

.splash__tool::after{
  content:"";
  position:absolute; inset:-18%;
  background:linear-gradient(120deg, rgba(255,210,120,0), rgba(255,210,120,.22), rgba(255,210,120,0));
  mix-blend-mode:screen;
  opacity:.55;
  transform:translateX(-30%) rotate(12deg);
  animation: sweep var(--dur) ease-in-out forwards;
  pointer-events:none;
}

@keyframes sweep{
  0%   { opacity:0; transform:translateX(-65%) rotate(12deg); }
  20%  { opacity:.65; }
  80%  { opacity:.25; transform:translateX(85%) rotate(12deg); }
  100% { opacity:0; }
}

@keyframes toolFall{
  0%{
    opacity:0;
    transform:translate3d(var(--x), -15vh, 0) rotate(var(--r)) scale(var(--s));
  }
  10%{ opacity:1; }
  100%{
    opacity:0.02;
    transform:translate3d(calc(var(--x) + var(--drift)), 115vh, 0)
      rotate(calc(var(--r) + 360deg)) scale(var(--s));
  }
}

@media (prefers-reduced-motion: reduce){
}

/* === SPLASH FORCE VISIBILITY (iOS safe) === */
#splash { position: fixed !important; inset: 0 !important; z-index: 2147483647 !important; }
#splashTools { position: absolute !important; inset: 0 !important; z-index: 2147483647 !important; pointer-events:none; }

.splash__tool{
  position: absolute !important;
  top: -35vh !important;
  left: 0 !important;

  width: 60px !important;
  height: 240px !important;

  background-repeat: no-repeat !important;
  background-position: center !important;
  background-size: contain !important;

  opacity: 0.95 !important;

  transform: translate3d(var(--x), -35vh, 0) rotate(var(--r)) scale(var(--s)) !important;
  animation: splashFall var(--dur) ease-in forwards !important;
  will-change: transform, opacity !important;
}

@keyframes splashFall{
  0%   { transform: translate3d(var(--x), -35vh, 0) rotate(var(--r)) scale(var(--s)); opacity: 0; }
  10%  { opacity: 1; }
  100% { transform: translate3d(calc(var(--x) + var(--drift)), 110vh, 0) rotate(calc(var(--r) + 60deg)) scale(var(--s)); opacity: 0; }
}

/* ===== SPLASH FORCE MODE (override iOS Reduce Motion) ===== */
.splash .splash__tool{
  opacity: 1 !important;
  animation: toolFall var(--dur) cubic-bezier(.18,.72,.12,.99) forwards !important;
}
/* (не обязательно) пусть flare тоже живёт */
.splash .splash__flare{
  animation: flareMove 2.2s ease-in-out infinite alternate !important;
}

/* =========================
   SPLASH (FINAL OVERRIDE)
   вставить в самый конец styles.css
========================= */

#splash.splash{
  position: fixed !important;
  inset: 0 !important;
  z-index: 999999 !important;
  background: #050505 !important;
  overflow: hidden !important;
  opacity: 1 !important;
  pointer-events: auto !important;
  transition: opacity .55s ease !important;
}

#splash.splash.is-hiding{
  opacity: 0 !important;
  pointer-events: none !important;
}

#splash .splash__vignette{
  position:absolute; inset:-30%;
  background: radial-gradient(circle at 50% 35%,
    rgba(255,210,120,.12),
    rgba(0,0,0,.92) 55%,
    rgba(0,0,0,1) 100%);
}

#splash .splash__grain{
  position:absolute; inset:0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='220' height='220' filter='url(%23n)' opacity='.18'/%3E%3C/svg%3E");
  opacity:.25;
  mix-blend-mode: overlay;
  pointer-events:none;
}

#splash .splash__brand{
  position:absolute;
  left:50%; top:22%;
  transform:translateX(-50%);
  text-align:center;
  color:rgba(255,230,170,.92);
  letter-spacing:.08em;
}

#splash .splash__logo{
  width:90px;
  height:auto;
  opacity:.95;
  filter: drop-shadow(0 12px 28px rgba(0,0,0,.75));
}

#splash .splash__title{
  margin-top:10px;
  font-weight:700;
  font-size:18px;
}

#splash .splash__sub{
  margin-top:6px;
  font-size:12px;
  opacity:.75;
}

#splash .splash__tools{
  position:absolute !important;
  inset:0 !important;
}

#splash .splash__tool{
  position:absolute !important;
  left:0 !important;
  top:0 !important;

  width: 64px !important;
  height: 260px !important;

  background-repeat:no-repeat !important;
  background-position:center !important;
  background-size:contain !important;

  opacity: 1 !important;
  filter: drop-shadow(0 18px 34px rgba(0,0,0,.55)) !important;

  transform: translate3d(var(--x), -30vh, 0) rotate(var(--r)) scale(var(--s)) !important;
  animation: toolFallFinal var(--dur) cubic-bezier(.18,.72,.12,.99) forwards !important;
  will-change: transform, opacity;
}

@keyframes toolFallFinal{
  0%{
    opacity:0;
    transform:translate3d(var(--x), -30vh, 0) rotate(var(--r)) scale(var(--s));
  }
  12%{ opacity:1; }
  100%{
    opacity:.06;
    transform:translate3d(calc(var(--x) + var(--drift)), 115vh, 0)
      rotate(calc(var(--r) + 360deg)) scale(var(--s));
  }
}

/* === FORCE FALL START (must be at the very end) === */
#splash .splash__tool{
  animation-play-state: paused !important;
}

#splash.is-animating .splash__tool{
  animation-play-state: running !important;
}

/* === SPLASH: force JS animations (iOS safe) === */
#splash .splash__tool{
  top: 0 !important;
  left: 0 !important;
  animation: none !important;  /* отключаем CSS keyframes */
}

.splash-video{
  position: fixed;
  inset: 0;
  z-index: 999999;
  background: #000;
  display:flex;
  align-items:center;
  justify-content:center;
}

.splash-video video{
  width:100%;
  height:100%;
  object-fit: cover;
}

.hero{
  position: relative;
  padding: 18px;
}

.hero::before{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(90deg, rgba(0,0,0,.55), rgba(0,0,0,0));
  pointer-events:none;
  border-radius: 0;
}

.hero-text{
  position: relative;
  width: 100%;
  text-align: left;
  max-width: 520px;
}

.hero-text h1{
  margin:0;
  line-height: 1.15;
}

.hero-text p{
  margin: 8px 0 0 0;
  opacity: .9;
}

/* === HARD KILL logo everywhere === */
.logo,
img.logo,
.hero .logo {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  width: 0 !important;
  height: 0 !important;
}

/* TEMP: hide constructor button (keep in code) */
#constructorBtn{
  display: none !important;
}
