:root{
  --bg:#05060a;
  --panel:#0b0f16;
  --card:#0e1420;
  --text:#e9f0ff;
  --muted:#95a3c1;
  --accent:#6fe3ff;
  --accent-2:#8a7dff;
  --accent-3:#16f2a4;
  --stroke:rgba(255,255,255,0.08);
  --blur:14px;
  --radius:18px;
  --radius-lg:26px;
  --shadow:0 10px 30px rgba(0,0,0,0.35), inset 0 0 0 1px var(--stroke);
  --speed:300ms;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font:16px/1.55 system-ui, -apple-system, Segoe UI, Roboto, Inter, "SF Pro Text", Arial, sans-serif;
  color:var(--text);
  background:var(--bg);
  overflow-x:hidden;
}

/* живой фон */
#bg{
  position:fixed; inset:0;
  z-index:-1;
  background:radial-gradient(1200px 800px at 10% 10%, rgba(111,227,255,0.06), transparent 60%),
             radial-gradient(1000px 700px at 90% 20%, rgba(138,125,255,0.07), transparent 55%),
             radial-gradient(900px 900px at 50% 100%, rgba(22,242,164,0.06), transparent 60%);
}

/* header */
.site-header{
  position:sticky; top:0; z-index:10;
  display:flex; align-items:center; gap:16px;
  justify-content:space-between;
  padding:14px clamp(16px, 3vw, 40px);
  backdrop-filter:saturate(120%) blur(10px);
  background:linear-gradient(to bottom, rgba(5,6,10,0.75), rgba(5,6,10,0.35) 60%, transparent);
  border-bottom:1px solid var(--stroke);
}
.brand{display:flex; align-items:center; gap:12px; text-decoration:none; color:var(--text)}
.logo-slot{
  width:36px; height:36px; border-radius:12px;
  background:linear-gradient(135deg, var(--accent), var(--accent-2));
  display:grid; place-items:center; font-weight:800; letter-spacing:1px; color:#041018;
  filter:url(#soft-glow);
}
.brand .logo{
  width:36px; height:36px; border-radius:12px;
  display:block; object-fit:contain;
  filter: drop-shadow(0 0 10px rgba(111,227,255,0.35));
}
.brand-text{font-weight:700}

.nav{display:flex; gap:20px}
.nav a{color:var(--muted); text-decoration:none}
.nav a:hover{color:var(--text)}

.cta-wrap{display:flex; gap:10px; align-items:center}

.burger{display:none; background:none; border:0; padding:8px; margin-left:8px}
.burger span{display:block; width:22px; height:2px; margin:5px 0; background:var(--text); border-radius:2px}

/* hero */
.hero{
  display:grid; grid-template-columns:1.1fr 0.9fr; gap:40px;
  padding:clamp(32px, 5vw, 80px) clamp(16px, 4vw, 56px);
  align-items:center; min-height:78vh;
}
.hero-text h1{font-size:clamp(32px, 5vw, 64px); line-height:1.05; margin:0 0 10px}
.hero-text .grad{
  background:linear-gradient(90deg, var(--accent), var(--accent-2), var(--accent-3));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.lead{color:var(--muted); font-size:1.125rem; margin:10px 0 22px; max-width:60ch}
.hero-cta{display:flex; flex-wrap:wrap; gap:12px; margin:10px 0 18px}
.mini-badges{display:flex; gap:8px; flex-wrap:wrap}
.mini-badges > div{
  border:1px solid var(--stroke); color:var(--muted);
  padding:6px 10px; border-radius:999px; backdrop-filter:blur(6px);
  background:rgba(255,255,255,0.02);
}

/* 3D карточка устройства */
.hero-visual{display:grid; place-items:center}
.device{
  width:min(420px, 80vw); aspect-ratio:10/16; border-radius:28px;
  background:linear-gradient(180deg, #0f1726, #0b1220);
  box-shadow:var(--shadow);
  position:relative; transform-style:preserve-3d; perspective:1200px;
}
.device-screen{
  position:absolute; inset:12px; border-radius:22px;
  background:radial-gradient(80% 110% at 50% 0%, rgba(111,227,255,0.08), transparent),
             linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01));
  overflow:hidden;
}
.device-shadow{
  position:absolute; inset:auto -12% -10% -12%; height:30%; border-radius:50%;
  filter:blur(30px); background:linear-gradient(90deg, rgba(111,227,255,0.12), rgba(138,125,255,0.12));
  transform:translateZ(-200px) scale(0.9);
}
.ui{position:absolute; left:0; right:0; padding:16px}
.ui-top{top:0; display:flex; gap:8px; align-items:center}
.ui-center{top:28%; display:grid; place-items:center}
.ui-bottom{bottom:0; display:flex; align-items:center; justify-content:space-between}
.ui-signal, .ui-ping, .ui-dot{
  width:10px; height:10px; border-radius:50%;
  background:radial-gradient(circle at 30% 30%, #fff, #8be6ff 80%);
  box-shadow:0 0 16px rgba(111,227,255,0.7), inset 0 0 8px rgba(111,227,255,0.5);
}
.ui-globe{
  width:160px; aspect-ratio:1; border-radius:50%;
  background:
    radial-gradient(40% 60% at 30% 30%, rgba(138,125,255,0.45), transparent 60%),
    radial-gradient(40% 60% at 70% 70%, rgba(22,242,164,0.45), transparent 60%),
    radial-gradient(60% 80% at 50% 50%, rgba(111,227,255,0.35), rgba(0,0,0,0) 70%);
  filter:url(#soft-glow);
  animation: float 6s ease-in-out infinite;
}
@keyframes float{
  0%,100%{transform:translateY(-4px)}
  50%{transform:translateY(6px)}
}
.ui-wave{
  width:80%; height:3px; border-radius:3px; margin-top:22px;
  background:linear-gradient(90deg, rgba(111,227,255,0), rgba(111,227,255,0.7), rgba(111,227,255,0));
  animation: wave 2.2s linear infinite;
}
@keyframes wave{
  0%{background-position:-200% 0; background-size:200% 100%}
  100%{background-position:200% 0}
}
.ui-toggle{
  width:64px; height:34px; border-radius:999px; position:relative; background:#0b1220; border:1px solid var(--stroke);
}
.ui-toggle::after{
  content:""; position:absolute; top:3px; left:3px; width:28px; height:28px; border-radius:50%;
  background:linear-gradient(135deg, var(--accent), var(--accent-2));
  transition:left var(--speed) ease;
}
.device:hover .ui-toggle::after{left:33px}
.ui-stats{
  width:46%; height:10px; border-radius:6px; background:rgba(255,255,255,0.06);
  box-shadow:inset 0 0 0 1px var(--stroke);
}

/* trust */
.trust{padding:40px clamp(16px, 4vw, 56px)}
.kicker{color:var(--muted); text-transform:uppercase; letter-spacing:0.2em; font-size:0.75rem}
.trust-logos{display:flex; gap:10px; flex-wrap:wrap; margin-top:12px; filter:url(#goo)}
.chip{
  padding:10px 14px; border-radius:999px;
  background:linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.02));
  border:1px solid var(--stroke);
  backdrop-filter:blur(6px);
}

/* features */
.features{
  display:grid; grid-template-columns:repeat(4,1fr); gap:16px;
  padding:20px clamp(16px, 4vw, 56px) 60px;
}
.card{
  background:linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.02));
  border:1px solid var(--stroke); border-radius:var(--radius); padding:20px;
  box-shadow:var(--shadow); position:relative; overflow:hidden;
  transition:transform var(--speed) ease, box-shadow var(--speed) ease;
}
.card:hover{transform:translateY(-4px)}
.pill{position:absolute; top:14px; right:14px; font-size:0.75rem; color:#051018;
  background:linear-gradient(135deg, var(--accent), var(--accent-2)); padding:6px 10px; border-radius:999px; font-weight:700}

/* why */
.why{display:grid; grid-template-columns:1.1fr .9fr; gap:24px; padding:40px clamp(16px, 4vw, 56px)}
.why-list{display:grid; gap:10px; color:var(--muted)}
.why-viz{display:grid; place-items:center}
.orbital{position:relative; width:min(520px, 90vw); aspect-ratio:1; border-radius:50%;
  background:radial-gradient(60% 60% at 50% 50%, rgba(138,125,255,0.08), rgba(111,227,255,0.02));
  box-shadow:inset 0 0 0 1px var(--stroke);
}
.orb{position:absolute; width:18%; aspect-ratio:1; border-radius:50%;
  background:radial-gradient(circle at 30% 30%, #fff, #8be6ff 70%);
  box-shadow:0 0 22px rgba(111,227,255,0.7), inset 0 0 12px rgba(111,227,255,0.35);
  animation: orbit 12s linear infinite;
}
.o1{top:2%; left:41%}
.o2{top:34%; left:82%; animation-duration:14s}
.o3{top:64%; left:6%; animation-duration:16s}
.o4{top:84%; left:54%; animation-duration:18s}
@keyframes orbit{
  0%{transform:rotate(0deg) translateX(8px) rotate(0deg)}
  100%{transform:rotate(360deg) translateX(8px) rotate(-360deg)}
}

/* pricing (базовые стили) */
.pricing{padding:40px clamp(16px, 4vw, 56px)}
.pricing h2{text-align:center; margin-bottom:16px}

/* responsive grid */
.plans{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));
  gap:20px;
  align-items:stretch;
}

.plan.card{
  background:linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.02));
  border:1px solid var(--stroke); border-radius:var(--radius);
  padding:20px; box-shadow:var(--shadow); position:relative; overflow:hidden;
  transition:transform var(--speed) ease, box-shadow var(--speed) ease;
  display:flex; flex-direction:column; justify-content:flex-start; min-height:300px;
}
.plan.card h3{
  font-size:1.25rem; font-weight:700; margin:0 0 8px; line-height:1.3;
}
.plan.card .price{
  font-size:2.4rem; font-weight:800; line-height:1.2; margin:0 0 12px;
  font-variant-numeric: tabular-nums lining-nums;
}
.price .currency{
  font-size:1.15rem; opacity:.8; margin-right:6px; position:relative; top:-2px;
}
.plan.card ul{
  list-style:disc; margin:0 0 16px 18px; padding:0; flex:1;
}
.plan.card ul li{ margin-bottom:6px; font-size:0.95rem; line-height:1.45; }
.plan.card .btn{ margin-top:auto; }

.plan.highlight{ outline:2px solid rgba(138,125,255,0.45); }
.plan.highlight.outline{ outline:2px solid rgba(111,227,255,0.45); }
.plan.lifetime{ outline:1.5px dashed rgba(255,255,255,0.25); }

.plan .flag{
  position:absolute; top:-10px; left:12px;
  background:linear-gradient(135deg, var(--accent-2), var(--accent));
  color:#041018; font-weight:800; padding:6px 10px; border-radius:8px;
  box-shadow:0 6px 18px rgba(0,0,0,.35); white-space:nowrap; font-size:.85rem;
}

/* download */
.download{padding:40px clamp(16px, 4vw, 56px)}
.stores{display:grid; grid-template-columns:repeat(4,1fr); gap:12px}
.store{display:grid; place-items:center; min-height:90px; text-decoration:none; color:var(--text)}

/* faq */
.faq{padding:40px clamp(16px, 4vw, 56px) 80px}
.faq details{background:rgba(255,255,255,0.03); border:1px solid var(--stroke); border-radius:var(--radius); padding:0; margin:6px 0}
.faq summary{cursor:pointer; font-weight:700; padding:16px}

/* footer */
.site-footer{border-top:1px solid var(--stroke); padding:24px clamp(16px, 4vw, 56px); background:rgba(255,255,255,0.02); backdrop-filter:blur(6px)}
.foot-grid{display:grid; grid-template-columns:2fr 1fr 1fr; gap:16px}
.muted{color:var(--muted)}

/* кнопки */
.btn{
  --btn-bg:rgba(255,255,255,0.06);
  --btn-fg:var(--text);
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:10px 16px; border-radius:999px; text-decoration:none; border:1px solid var(--stroke);
  background:var(--btn-bg); color:var(--btn-fg);
  transition:transform var(--speed) ease, background var(--speed) ease, border-color var(--speed) ease, box-shadow var(--speed) ease;
  will-change:transform;
}
.btn:hover{transform:translateY(-2px); box-shadow:0 10px 24px rgba(0,0,0,0.25)}
.btn.primary{
  --btn-bg:linear-gradient(135deg, var(--accent), var(--accent-2));
  --btn-fg:#041018;
  border-color:transparent; font-weight:800;
}
.btn.ghost{background:rgba(255,255,255,0.02)}
.btn.xl{padding:14px 22px; font-size:1.05rem}
.btn.sm{ padding:8px 12px; font-size:.9rem; }

/* появления при скролле */
.observe{opacity:0; transform:translateY(14px); transition:opacity 600ms ease, transform 600ms ease}
.observe.in{opacity:1; transform:none}

/* FAQ улучшения */
.faq .qa { border:1px solid var(--stroke); border-radius:var(--radius); background:rgba(255,255,255,0.03); overflow:hidden; }
.faq .qa + .qa { margin-top:8px; }
.faq summary{
  list-style:none; cursor:pointer; font-weight:700; padding:16px;
  position:relative; display:flex; align-items:center; gap:8px;
}
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{
  content:""; width:10px; height:10px; margin-left:auto;
  border-right:2px solid var(--text); border-bottom:2px solid var(--text);
  transform:rotate(-45deg) translateY(-2px);
  transition:transform var(--speed) ease, opacity var(--speed) ease;
  opacity:.8;
}
.faq .qa[open] summary::after{ transform:rotate(45deg) translateY(2px); }
.faq .answer{
  padding:0 16px 16px 16px;
  max-height:0; overflow:hidden;
  transition:max-height 500ms ease;
}
.faq .qa[open] .answer{ max-height:600px; }
.faq .answer p { color:var(--text); margin:10px 0; }
.faq .answer ul, .faq .answer ol { color:var(--muted); margin:8px 0 0 18px; }
.faq .answer li { margin:4px 0; }
.faq .faq-actions{ display:flex; gap:8px; flex-wrap:wrap; margin-top:8px; }

/* hover тень */
.card:hover{ box-shadow:0 18px 40px rgba(0,0,0,.38), inset 0 0 0 1px var(--stroke); }

/* адаптив */
@media (max-width:1080px){
  .features{grid-template-columns:repeat(2,1fr)}
  .stores{grid-template-columns:repeat(2,1fr)}
  .why{grid-template-columns:1fr}
  .hero{grid-template-columns:1fr; text-align:left}
}
@media (max-width:860px){
  .nav{display:none}
  .burger{display:block}
}

/* доступность */
@media (prefers-reduced-motion: reduce){
  *{animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition:none !important}
}

/* ===== CTA modal — полный стиль ===== */

/* затемнение фона */
#cta-modal::backdrop{
  background: rgba(0,0,0,.70);
  backdrop-filter: blur(6px);
}

/* контейнер dialog */
#cta-modal{
  border: none;
  padding: 0;
  background: transparent;
}

/* карточка модалки */
.modal-card{
  position: relative;            /* нужно для неон-обводки */
  overflow: hidden;              /* прячем свечение по краям */
  max-width: min(560px, 92vw);
  margin: auto;
  padding: 24px 24px 18px;
  border-radius: 20px;
  background: linear-gradient(180deg, rgba(18,22,33,.98), rgba(12,16,27,.98));
  border: 1px solid rgba(255,255,255,.06);
  box-shadow: 0 18px 50px rgba(0,0,0,.5);
  color: #fff;
  animation: modal-in .25s ease;
}
@keyframes modal-in{
  from{ opacity:0; transform: translateY(12px) }
  to  { opacity:1; transform: none }
}

/* неоновая «текущая» кайма */
.modal-card::before{
  content:"";
  position:absolute; inset:-2px;
  border-radius:22px;
  padding:2px;
  background: linear-gradient(130deg,
    var(--accent, #6fe3ff),
    var(--accent-2, #8a7dff),
    #38b6ff, #8a7dff);
  background-size: 400% 400%;
  animation: neon-flow 6s ease infinite;
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  z-index: 0;
}
@keyframes neon-flow{
  0%{ background-position:   0% 50% }
  50%{ background-position: 100% 50% }
  100%{ background-position:  0% 50% }
}
/* контент поверх каймы */
.modal-card > *{ position:relative; z-index:1; }

/* шапка и бейдж */
.modal-head{
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  margin-bottom:10px;
}
.modal-head h3{
  margin:0; font-size:1.4rem; font-weight:800; letter-spacing:.2px;
}
.modal-head .grad{
  background: linear-gradient(90deg, var(--accent, #6fe3ff), var(--accent-2, #8a7dff));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}

.badge{
  padding:6px 10px; border-radius:999px;
  font-weight:800; font-size:.85rem; color:#041018;
  background: linear-gradient(135deg, var(--accent, #6fe3ff), var(--accent-2, #8a7dff));
  box-shadow:0 6px 18px rgba(0,0,0,.35);
  animation: pulse-bonus 1.6s ease-in-out infinite;
}
@keyframes pulse-bonus{
  0%,100%{ transform:scale(1);   box-shadow:0 0 12px rgba(111,227,255,.5) }
  50%    { transform:scale(1.08); box-shadow:0 0 20px rgba(138,125,255,.65) }
}

/* основной текст и пункты */
.modal-lead{
  margin:6px 0 10px;
  color: rgba(255,255,255,.92);
  line-height:1.55;
}
.modal-points{
  margin:8px 0 14px 0; padding:0; list-style:none;
}
.modal-points li{
  position:relative; padding-left:22px; margin:6px 0;
  color: var(--text, #e9f0ff); opacity:.95;
}
.modal-points li::before{
  content:""; position:absolute; left:0; top:.45em;
  width:12px; height:12px; border-radius:50%;
  background: linear-gradient(135deg, var(--accent, #6fe3ff), var(--accent-2, #8a7dff));
  box-shadow:0 0 10px rgba(111,227,255,.5);
}

/* кнопки */
.modal-actions{
  display:flex; gap:10px; flex-wrap:wrap; margin-top:4px;
}
.modal-actions .btn{
  padding:12px 18px; border-radius:14px; font-weight:800; text-align:center;
}

/* Telegram — главная синяя */
.btn.btn-telegram{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  background: linear-gradient(90deg, #38b6ff, #8a7dff);
  color:#fff; border:none;
  box-shadow:0 10px 26px rgba(0,0,0,.35);
  transition: transform .15s ease, filter .2s ease;
}
.btn.btn-telegram:hover{ transform:translateY(-1px); filter:brightness(1.05); }
.tg-ico{ width:18px; height:18px; flex:0 0 18px; }

/* Вторичная — «Закрыть» */
.modal-actions .btn.ghost{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  color:#fff; font-weight:700;
}
.modal-actions .btn.ghost:hover{ background: rgba(255,255,255,.12); }

/* маленькая приписка */
.modal-small{
  margin:10px 2px 0;
  font-size:.82rem;
  color: rgba(255,255,255,.55);
}

/* адаптив */
@media (max-width:520px){
  .modal-actions .btn{ flex:1 1 100%; }
  .modal-card{ padding:20px 18px 14px; }
  .modal-head h3{ font-size:1.25rem; }
}

/* === Fix: responsive features grid & text wrapping === */
.features{
  /* auto-fit ensures it collapses to 1 column naturally on narrow screens */
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
}
.features .card h3,
.features .card p{
  overflow-wrap: anywhere;
  word-break: break-word;
  hyphens: auto;
  -webkit-hyphens: auto;
}
@media (max-width: 900px){
  .features{ grid-template-columns: 1fr; }
}
@media (max-width: 768px){
  .pill{ transform: scale(.92); right: 10px; top: 10px; }
}
