/* ═══════════════════════════════════════════════════
   WLESS PRO — shared.css  v3.2
   Основа для всех страниц сайта
═══════════════════════════════════════════════════ */

/* ── Reset ───────────────────────────────────────── */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0; padding: 0;
}
html {
  scroll-behavior: smooth;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ══ ПЕРЕМЕННЫЕ ══════════════════════════════════════ */
:root {
  /* Фоны */
  --bg:   #020208;
  --bg-1: #06060f;
  --bg-2: #0a0a1a;

  /* Поверхности */
  --s0: #07071a;
  --s1: #0d0d22;
  --s2: #131330;
  --s3: #1a1a3d;
  --s4: #22224a;

  /* Границы */
  --b0: rgba(255,255,255,.07);
  --b1: rgba(255,255,255,.12);

  /* Текст */
  --t1: #f0f0ff;
  --t2: #8888b0;
  --t3: #4d4d70;

  /* Акценты */
  --c1: #22d3ee;   /* cyan */
  --c2: #a855f7;   /* purple */
  --c3: #10b981;   /* green */
  --c4: #f59e0b;   /* amber */

  /* Тени / свечения */
  --glow-c: 0 0 35px rgba(34,211,238,.28), 0 0 80px rgba(34,211,238,.08);
  --glow-p: 0 0 35px rgba(168,85,247,.28), 0 0 80px rgba(168,85,247,.08);
  --glow-g: 0 0 35px rgba(16,185,129,.28), 0 0 80px rgba(16,185,129,.08);

  /* Радиусы */
  --r1: 8px;
  --r2: 12px;
  --r3: 18px;
  --r4: 28px;

  /* Алиасы (для privacy/terms/login) */
  --text:      var(--t1);
  --text-2:    var(--t2);
  --text-3:    var(--t3);
  --border:    var(--b0);
  --accent:    var(--c1);
  --surface-1: var(--s1);
  --surface-2: var(--s2);
  --radius:    var(--r2);
  --transition: .22s cubic-bezier(.4,0,.2,1);
}

/* ══ БАЗОВЫЕ СТИЛИ ТЕЛА ══════════════════════════════ */
body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont,
               'Segoe UI', sans-serif;
  background: var(--bg);          /* ← тёмный фон */
  background-image:
    radial-gradient(ellipse 80% 50% at 50% -10%,
      rgba(34,211,238,.06) 0%, transparent 60%),
    radial-gradient(ellipse 50% 40% at 90% 80%,
      rgba(168,85,247,.05) 0%, transparent 60%);
  background-attachment: fixed;
  color: var(--t1);               /* ← белый текст */
  min-height: 100vh;
  overflow-x: hidden;
  line-height: 1.65;
}

/* ══ КОНТЕЙНЕРЫ ══════════════════════════════════════ */
.container {
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 28px;
}
.container-sm {
  max-width: 720px;
  margin: 0 auto;
  padding: 0 24px;
}
.container-xs {
  max-width: 480px;
  margin: 0 auto;
  padding: 0 20px;
}

/* ══ ТИПОГРАФИКА ═════════════════════════════════════ */
.sec-title {
  font-family: 'Unbounded', sans-serif;
  font-size: clamp(1.8rem, 3vw, 2.8rem);
  font-weight: 800;
  letter-spacing: -.045em;
  line-height: 1.1;
  color: var(--t1);
  margin-bottom: 16px;
}
.sec-sub {
  font-size: .95rem;
  color: var(--t2);
  line-height: 1.8;
  max-width: 520px;
}
.tc  { text-align: center; }
.ma  { margin-left: auto; margin-right: auto; }
.d-block { display: block; }

/* ══ РАЗДЕЛИТЕЛЬ ═════════════════════════════════════ */
.divider {
  border: none;
  height: 1px;
  background: linear-gradient(90deg,
    transparent, rgba(255,255,255,.07), transparent);
}

/* ══ ЧИП / ПИЛЮЛЯ ═══════════════════════════════════ */
.chip {
  display: inline-flex;
  align-items: center; gap: 7px;
  padding: 5px 14px;
  border: 1px solid rgba(34,211,238,.22);
  background: rgba(34,211,238,.06);
  border-radius: 40px;
  font-size: .66rem; font-weight: 700;
  color: var(--c1);
  letter-spacing: .12em; text-transform: uppercase;
  font-family: 'JetBrains Mono', monospace;
  margin-bottom: 18px;
}
.chip-purple {
  border-color: rgba(168,85,247,.25);
  background: rgba(168,85,247,.07);
  color: var(--c2);
}
.chip-green {
  border-color: rgba(16,185,129,.22);
  background: rgba(16,185,129,.06);
  color: var(--c3);
}
.chip-amber {
  border-color: rgba(245,158,11,.22);
  background: rgba(245,158,11,.06);
  color: var(--c4);
}

/* ══ БЕЙДЖ ═══════════════════════════════════════════ */
.badge {
  display: inline-flex; align-items: center;
  padding: 3px 9px; border-radius: 7px;
  font-size: .6rem; font-weight: 700;
  letter-spacing: .08em; text-transform: uppercase;
  background: rgba(34,211,238,.1);
  color: var(--c1);
  border: 1px solid rgba(34,211,238,.2);
  font-family: 'JetBrains Mono', monospace;
}
.badge-purple { background:rgba(168,85,247,.1); color:var(--c2); border-color:rgba(168,85,247,.2); }
.badge-green  { background:rgba(16,185,129,.1);  color:var(--c3); border-color:rgba(16,185,129,.2); }
.badge-red    { background:rgba(239,68,68,.1);   color:#f87171;   border-color:rgba(239,68,68,.2);  }
.badge-amber  { background:rgba(245,158,11,.1);  color:var(--c4); border-color:rgba(245,158,11,.2); }

/* ══ КНОПКИ ══════════════════════════════════════════ */
.btn {
  display: inline-flex;
  align-items: center; justify-content: center; gap: 8px;
  padding: 11px 24px;
  border-radius: 12px; border: none; cursor: pointer;
  font-family: 'Inter', sans-serif;
  font-size: .86rem; font-weight: 600;
  text-decoration: none;
  transition: all .22s cubic-bezier(.4,0,.2,1);
  position: relative; overflow: hidden;
  white-space: nowrap;
  -webkit-user-select: none; user-select: none;
  outline: none;
  /* ↓ ВАЖНО: без этого кнопки могут не нажиматься */
  pointer-events: auto;
  z-index: 1;
}
.btn-primary {
  background: linear-gradient(135deg, #22d3ee 0%, #a855f7 100%);
  color: #fff;
  box-shadow: 0 8px 28px rgba(34,211,238,.3),
              inset 0 1px 0 rgba(255,255,255,.2);
}
.btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 45px rgba(34,211,238,.45),
              inset 0 1px 0 rgba(255,255,255,.2);
  filter: brightness(1.08);
}
.btn-primary:active { transform: translateY(0) scale(.98); }

.btn-outline {
  background: rgba(255,255,255,.03);
  color: var(--t1);
  border: 1px solid rgba(255,255,255,.1);
  backdrop-filter: blur(6px);
}
.btn-outline:hover {
  border-color: rgba(34,211,238,.4);
  color: var(--c1);
  background: rgba(34,211,238,.06);
  transform: translateY(-2px);
}
.btn-outline:active { transform: translateY(0); }

.btn-ghost {
  background: transparent; color: var(--t2);
  border: 1px solid transparent;
}
.btn-ghost:hover {
  background: rgba(255,255,255,.05);
  border-color: var(--b0); color: var(--t1);
}

.btn-danger {
  background: rgba(239,68,68,.1);
  color: #f87171;
  border: 1px solid rgba(239,68,68,.2);
}
.btn-danger:hover {
  background: rgba(239,68,68,.18);
  border-color: rgba(239,68,68,.4);
}

.btn-success {
  background: rgba(16,185,129,.1);
  color: var(--c3);
  border: 1px solid rgba(16,185,129,.2);
}
.btn-success:hover {
  background: rgba(16,185,129,.2);
  border-color: rgba(16,185,129,.4);
}

/* Размеры кнопок */
.btn-xs   { padding: 6px 14px;  font-size: .72rem; border-radius: 8px;  }
.btn-sm   { padding: 8px 18px;  font-size: .78rem; border-radius: 10px; }
.btn-lg   { padding: 14px 32px; font-size: .94rem; border-radius: 14px; }
.btn-xl   { padding: 17px 42px; font-size: 1rem;   border-radius: 16px; }
.btn-full { width: 100%; }

/* Состояния кнопок */
.btn:disabled,
.btn.loading {
  opacity: .5;
  cursor: not-allowed;
  pointer-events: none;
  transform: none !important;
}
.btn.loading::after {
  content: '';
  width: 14px; height: 14px;
  border: 2px solid rgba(255,255,255,.3);
  border-top-color: #fff;
  border-radius: 50%;
  animation: spin .7s linear infinite;
  margin-left: 4px;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ══ ПОЛЯ ВВОДА ══════════════════════════════════════ */
.input-wrap {
  position: relative;
  width: 100%;
}
.input-wrap .input-icon {
  position: absolute;
  left: 16px; top: 50%; transform: translateY(-50%);
  color: var(--t3); font-size: .82rem;
  pointer-events: none;
  transition: color .22s;
  z-index: 2;
}
.input-wrap:focus-within .input-icon { color: var(--c1); }

.field {
  width: 100%;
  background: var(--s2);
  border: 1px solid var(--b0);
  border-radius: 12px;
  padding: 14px 18px;
  font-family: 'JetBrains Mono', monospace;
  font-size: .88rem;
  color: var(--t1);
  outline: none;
  transition: border-color .22s, box-shadow .22s, background .22s;
  -webkit-appearance: none;
  /* ↓ ВАЖНО */
  pointer-events: auto;
  position: relative;
  z-index: 1;
}
.field::placeholder { color: var(--t3); font-family: 'Inter', sans-serif; }
.field:hover  { border-color: rgba(255,255,255,.14); }
.field:focus  {
  border-color: rgba(34,211,238,.45);
  box-shadow: 0 0 0 3px rgba(34,211,238,.1);
  background: var(--s3);
}
.field-with-icon { padding-left: 46px; }
.field-lg    { padding: 16px 20px; font-size: .94rem; border-radius: 14px; }
.field-error { border-color: rgba(239,68,68,.45) !important; }
.field-error:focus {
  box-shadow: 0 0 0 3px rgba(239,68,68,.1) !important;
}

/* Метка поля */
.field-label {
  display: block;
  font-size: .74rem; font-weight: 600;
  color: var(--t2); letter-spacing: .05em;
  text-transform: uppercase;
  margin-bottom: 8px;
  font-family: 'JetBrains Mono', monospace;
}

/* Сообщение об ошибке */
.error-msg {
  display: flex; align-items: center; gap: 6px;
  font-size: .74rem; color: #f87171;
  margin-top: 7px;
}
.success-msg {
  display: flex; align-items: center; gap: 6px;
  font-size: .74rem; color: var(--c3);
  margin-top: 7px;
}

/* ══ КАРТОЧКИ ════════════════════════════════════════ */
.card {
  background: var(--s1);
  border: 1px solid var(--b0);
  border-radius: var(--r3);
  padding: 24px;
  transition: border-color .25s, box-shadow .25s;
}
.card:hover {
  border-color: rgba(34,211,238,.15);
  box-shadow: 0 8px 32px rgba(0,0,0,.4);
}

.glass {
  background: rgba(13,13,34,.75);
  backdrop-filter: blur(24px) saturate(1.5);
  -webkit-backdrop-filter: blur(24px) saturate(1.5);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--r3);
}

/* ══ ОРБ — AMBIENT GLOW ══════════════════════════════ */
.orb {
  position: absolute; border-radius: 50%;
  filter: blur(80px); pointer-events: none;
}
.orb-c { background: radial-gradient(circle,rgba(34,211,238,.35) 0%,transparent 70%); }
.orb-p { background: radial-gradient(circle,rgba(168,85,247,.35) 0%,transparent 70%); }
.orb-g { background: radial-gradient(circle,rgba(16,185,129,.35) 0%,transparent 70%); }

/* ══ ХЕДЕР ═══════════════════════════════════════════ */
.site-header {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 1000;
  transition: background .3s, border-color .3s, backdrop-filter .3s;
  border-bottom: 1px solid transparent;
}
.site-header.scrolled {
  background: rgba(2,2,8,.9);
  backdrop-filter: blur(24px) saturate(1.6);
  -webkit-backdrop-filter: blur(24px) saturate(1.6);
  border-bottom-color: var(--b0);
  box-shadow: 0 4px 30px rgba(0,0,0,.5);
}
.header-inner {
  display: flex;
  align-items: center; justify-content: space-between;
  padding-top: 16px; padding-bottom: 16px;
  gap: 16px;
}

/* Логотип */
.logo {
  display: flex; align-items: center; gap: 9px;
  text-decoration: none; flex-shrink: 0;
}
.logo-img { width: 28px; height: 28px; object-fit: contain; }
.logo-text {
  font-family: 'Unbounded', sans-serif;
  font-size: .9rem; font-weight: 800;
  color: var(--t1); letter-spacing: -.03em;
  white-space: nowrap;
}
.logo-bolt { color: var(--c1); }

/* Навигация */
.nav-links {
  display: flex; align-items: center; gap: 4px;
  list-style: none;
}
.nav-links a {
  padding: 7px 13px;
  font-size: .8rem; font-weight: 500; color: var(--t2);
  text-decoration: none; border-radius: 9px;
  transition: color .2s, background .2s;
  white-space: nowrap;
}
.nav-links a:hover { color: var(--t1); background: rgba(255,255,255,.05); }
.nav-links a.active { color: var(--t1); }
.nav-dashboard {
  background: rgba(34,211,238,.07) !important;
  border: 1px solid rgba(34,211,238,.18) !important;
  color: var(--c1) !important;
}
.nav-dashboard:hover {
  background: rgba(34,211,238,.14) !important;
  border-color: rgba(34,211,238,.35) !important;
}
.nav-cta {
  background: linear-gradient(135deg,
    rgba(34,211,238,.12), rgba(168,85,247,.1)) !important;
  border: 1px solid rgba(34,211,238,.22) !important;
  color: var(--t1) !important;
}
.nav-cta:hover {
  background: linear-gradient(135deg,
    rgba(34,211,238,.22), rgba(168,85,247,.18)) !important;
}

/* Мобильное меню */
.menu-toggle { display: none; }
.menu-icon {
  display: none; cursor: pointer;
  width: 38px; height: 38px;
  border: 1px solid var(--b0); border-radius: 9px;
  background: var(--s1);
  align-items: center; justify-content: center;
  color: var(--t2); font-size: .95rem;
  transition: all .2s;
  flex-shrink: 0;
}
.menu-icon:hover { border-color: rgba(34,211,238,.25); color: var(--c1); }

/* ══ REVEAL ANIMATION ════════════════════════════════ */
.reveal {
  opacity: 0;
  transform: translateY(26px);
  transition: opacity .65s cubic-bezier(.4,0,.2,1),
              transform .65s cubic-bezier(.4,0,.2,1);
}
.reveal.visible { opacity: 1; transform: none; }
.d1 { transition-delay: .08s !important; }
.d2 { transition-delay: .16s !important; }
.d3 { transition-delay: .24s !important; }
.d4 { transition-delay: .32s !important; }

/* ══ ПОЛОСЫ ПРОКРУТКИ ════════════════════════════════ */
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--s3); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--s4); }

/* ══ ВЫДЕЛЕНИЕ ═══════════════════════════════════════ */
::selection {
  background: rgba(34,211,238,.22);
  color: var(--t1);
}

/* ══ МОБИЛЬНАЯ АДАПТАЦИЯ ═════════════════════════════ */
@media (max-width: 768px) {
  .menu-icon   { display: flex; }
  .nav-links {
    position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(2,2,8,.97);
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    flex-direction: column;
    justify-content: center; align-items: center;
    gap: 8px; padding: 40px 24px;
    transform: translateX(105%);
    transition: transform .35s cubic-bezier(.4,0,.2,1);
    z-index: 999;
  }
  .menu-toggle:checked ~ .nav-links { transform: none; }
  .nav-links a {
    font-size: .95rem; padding: 12px 28px;
    width: 100%; text-align: center;
    border-radius: 12px;
  }
  .menu-toggle:checked ~ label.menu-icon { color: var(--c1); }
}
@media (max-width: 480px) {
  .container { padding: 0 16px; }
  .btn-lg { padding: 13px 24px; font-size: .88rem; }
}