/* ============================================================
   ЛУННЫЙ СОННИК v3 — «Иммерсивная ночь»
   Тёмная тема нативно (не ломается форс-дарком браузеров).
   --bg0 #0A0F1F  глубина        --gold #D9B36A  лунное золото
   --bg1 #121933  ночной индиго  --gold2 #F2E3BC светлое золото
   --tx  #ECEEF7  основной текст --vio  #8E9BFF  сумеречный акцент
   --tx2 #A8AECB  вторичный
   Шрифты: Prata (display) + PT Sans (text)
   ============================================================ */
:root{
  --bg0:#0A0F1F; --bg1:#121933; --tx:#ECEEF7; --tx2:#A8AECB; --tx3:#7D84A6;
  --gold:#D9B36A; --gold2:#F2E3BC; --vio:#8E9BFF;
  --glass:rgba(255,255,255,.045); --glass2:rgba(255,255,255,.07);
  --line:rgba(255,255,255,.10); --line2:rgba(217,179,106,.35);
  --r:18px; --r-sm:12px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth; color-scheme:dark}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0; color:var(--tx);
  font:400 17px/1.75 "PT Sans", system-ui, sans-serif;
  background:
    radial-gradient(1100px 700px at 80% -10%, rgba(142,155,255,.13), transparent 60%),
    radial-gradient(900px 600px at -10% 25%, rgba(217,179,106,.07), transparent 55%),
    radial-gradient(1200px 800px at 50% 115%, rgba(142,155,255,.08), transparent 60%),
    linear-gradient(180deg, var(--bg1) 0%, var(--bg0) 45%, #080C18 100%);
  background-attachment:fixed;
  min-height:100vh;
}
::selection{background:rgba(217,179,106,.35)}
html{scrollbar-color:#39406b var(--bg0)}

.wrap{max-width:880px; margin:0 auto; padding:0 22px}
a{color:var(--vio); text-underline-offset:3px}
a:focus-visible,button:focus-visible,input:focus-visible{outline:2px solid var(--gold); outline-offset:3px; border-radius:4px}
h1,h2,h3{font-family:"Prata", Georgia, serif; font-weight:400; line-height:1.22; color:var(--tx); text-wrap:balance; margin:0}
h1{font-size:clamp(34px,6.4vw,62px)}
h2{font-size:clamp(22px,3.6vw,30px); margin-bottom:14px}
h3{font-size:18.5px; margin-bottom:6px}
.gold{color:transparent; background:linear-gradient(100deg,var(--gold2),var(--gold) 45%,#b78c3f 70%,var(--gold2)); background-size:200% 100%; -webkit-background-clip:text; background-clip:text; animation:shimmer 6s linear infinite}
@keyframes shimmer{to{background-position:200% 0}}
@media (prefers-reduced-motion:reduce){.gold{animation:none}}

/* ---------- звёздный фон (canvas, фиксированный) ---------- */
#sky{position:fixed; inset:0; z-index:-1; display:block; width:100%; height:100%}

/* ---------- шапка ---------- */
.nav{
  display:flex; align-items:center; justify-content:space-between; gap:14px;
  padding:20px 0; flex-wrap:wrap;
}
.logo{font-family:"Prata",serif; font-size:21px; color:var(--tx); text-decoration:none; display:flex; align-items:center; gap:10px}
.logo svg{width:24px; height:24px; fill:var(--gold); filter:drop-shadow(0 0 8px rgba(217,179,106,.65))}
.topnav{display:flex; gap:6px 20px; align-items:center; flex-wrap:wrap}
.topnav a{color:var(--tx2); text-decoration:none; font-size:15px; transition:color .2s}
.topnav a:hover{color:var(--tx)}
.nav-bot{
  border:1px solid var(--line2); border-radius:99px; padding:8px 18px;
  color:var(--gold2) !important; background:rgba(217,179,106,.07);
  transition:background .25s, box-shadow .25s, transform .2s;
}
.nav-bot:hover{background:rgba(217,179,106,.16); box-shadow:0 0 24px rgba(217,179,106,.28); transform:translateY(-1px)}

/* ---------- hero ---------- */
.hero{position:relative; text-align:center; padding:64px 0 56px}
.hero .lead{color:var(--tx2); max-width:620px; margin:18px auto 36px; font-size:clamp(16px,2.4vw,19px)}
.moon-wrap{display:flex; flex-direction:column; align-items:center; gap:10px; margin:0 auto 26px}
#moon-svg{width:clamp(120px,18vw,168px); height:auto; filter:drop-shadow(0 0 34px rgba(242,227,188,.30)) drop-shadow(0 0 90px rgba(217,179,106,.18))}
.moon-label{font-size:14px; color:var(--tx2); letter-spacing:.04em}
.moon-label b{color:var(--gold2); font-weight:700}

/* ---------- поиск ---------- */
.search{position:relative; max-width:560px; margin:0 auto}
.search input{
  width:100%; padding:18px 26px; font:inherit; font-size:17px; color:var(--tx);
  border-radius:99px; border:1px solid var(--line);
  background:rgba(13,18,38,.75); backdrop-filter:blur(14px);
  box-shadow:0 18px 50px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.06);
  transition:border-color .25s, box-shadow .25s;
}
.search input::placeholder{color:var(--tx3)}
.search input:focus{outline:none; border-color:var(--line2); box-shadow:0 18px 50px rgba(0,0,0,.5), 0 0 0 5px rgba(217,179,106,.14)}
.search-results{
  position:absolute; left:0; right:0; top:calc(100% + 10px); z-index:40; text-align:left;
  background:rgba(16,22,44,.92); backdrop-filter:blur(18px);
  border:1px solid var(--line); border-radius:var(--r);
  box-shadow:0 26px 70px rgba(0,0,0,.55); overflow:hidden;
  opacity:0; transform:translateY(-6px); transition:opacity .18s, transform .18s;
}
.search-results.open{opacity:1; transform:none}
.search-results a{display:block; padding:13px 20px; text-decoration:none; color:var(--tx); border-bottom:1px solid rgba(255,255,255,.05)}
.search-results a:last-child{border-bottom:0}
.search-results a small{display:block; color:var(--tx3); font-size:13.5px; line-height:1.5}
.search-results a:hover,.search-results a.sel{background:rgba(217,179,106,.10)}
.search-results .none{padding:15px 20px; color:var(--tx2)}

/* ---------- чипы ---------- */
.chips{display:flex; flex-wrap:wrap; gap:10px}
.hero .chips{justify-content:center; margin-top:22px}
.chip{
  background:var(--glass); border:1px solid var(--line); border-radius:99px;
  padding:8px 17px; text-decoration:none; color:var(--tx2); font-size:15px;
  backdrop-filter:blur(8px);
  transition:border-color .25s, color .25s, transform .2s, box-shadow .25s;
}
.chip:hover{border-color:var(--line2); color:var(--gold2); transform:translateY(-2px); box-shadow:0 8px 22px rgba(0,0,0,.35)}
.trust{display:flex; gap:8px 26px; justify-content:center; flex-wrap:wrap; margin-top:30px; color:var(--tx3); font-size:14.5px}
.trust b{color:var(--gold2); font-weight:700}

/* ---------- бегущая строка символов ---------- */
.marquee{overflow:hidden; padding:6px 0 2px; margin:8px 0 26px; -webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent); mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.marquee-track{display:flex; gap:10px; width:max-content; animation:marquee 46s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
@keyframes marquee{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.marquee-track{animation:none}}

/* ---------- секции / карточки ---------- */
section{margin:54px 0}
.eyebrow{
  font:700 12px/1.2 "PT Sans",sans-serif; letter-spacing:.2em; text-transform:uppercase;
  color:var(--gold); margin:0 0 16px;
}
.card{
  background:var(--glass); border:1px solid var(--line); border-radius:var(--r);
  padding:24px 26px; backdrop-filter:blur(10px);
  transition:transform .3s, border-color .3s, box-shadow .3s, background .3s;
}
.card:hover{transform:translateY(-3px); border-color:rgba(255,255,255,.18); background:var(--glass2); box-shadow:0 18px 44px rgba(0,0,0,.4)}
.grid3{display:grid; grid-template-columns:repeat(3,1fr); gap:16px}
.grid2{display:grid; grid-template-columns:1fr 1fr; gap:16px}
@media (max-width:760px){.grid3{grid-template-columns:1fr}}
@media (max-width:620px){.grid2{grid-template-columns:1fr}}
.card p{margin:6px 0 0; color:var(--tx2); font-size:15.5px}
.card .ph{width:38px; height:38px; border-radius:50%; border:1.5px solid var(--gold); display:grid; place-items:center; margin-bottom:14px}
.card .ph i{width:14px; height:14px; border-radius:50%; display:block}
.grid3 .card:nth-child(1) .ph i{background:linear-gradient(90deg,var(--gold) 50%,transparent 50%)}
.grid3 .card:nth-child(2) .ph i{background:var(--gold); box-shadow:0 0 10px rgba(217,179,106,.7)}
.grid3 .card:nth-child(3) .ph i{background:linear-gradient(270deg,var(--gold) 50%,transparent 50%)}

/* ---------- виджет луны ---------- */
.luna-now{
  display:flex; gap:24px; align-items:center;
  background:linear-gradient(120deg, rgba(217,179,106,.10), rgba(142,155,255,.07) 60%, transparent), var(--glass);
  border:1px solid var(--line2); border-radius:var(--r); padding:24px 28px;
  backdrop-filter:blur(10px);
}
.luna-now .mini-moon{width:84px; flex:none; filter:drop-shadow(0 0 22px rgba(242,227,188,.3))}
.luna-now h2{font-size:21px; margin-bottom:6px}
.luna-now p{margin:0; color:var(--tx2); font-size:15.5px}
.luna-now .more{display:inline-block; margin-top:10px; font-size:14.5px; color:var(--gold2); text-decoration:none; border-bottom:1px dashed var(--line2)}
@media (max-width:560px){.luna-now{flex-direction:column; text-align:center}}

/* ---------- страница символа ---------- */
.page-hero{padding:36px 0 8px}
.crumbs{font-size:14px; color:var(--tx3); margin-bottom:14px}
.crumbs a{color:var(--tx2); text-decoration:none}
.crumbs a:hover{color:var(--tx)}
.crumbs span{margin:0 7px; opacity:.55}
.page-hero .lead{color:var(--tx2); font-size:clamp(16.5px,2.4vw,19px); max-width:720px; margin-top:16px}

.quick{
  position:relative; margin:30px 0 10px; padding:22px 26px;
  background:linear-gradient(120deg, rgba(217,179,106,.13), rgba(142,155,255,.06)), var(--glass);
  border:1px solid var(--line2); border-radius:var(--r); backdrop-filter:blur(10px);
}
.quick .eyebrow{margin-bottom:8px}
.quick p{margin:0; font-size:17px; color:var(--tx)}

.toc{display:flex; flex-wrap:wrap; gap:8px; margin:20px 0 4px}
.toc a{
  font-size:13.5px; text-decoration:none; color:var(--tx2);
  background:var(--glass); border:1px solid var(--line); border-radius:99px; padding:6px 14px;
  transition:color .2s, border-color .2s, transform .2s;
}
.toc a:hover{color:var(--gold2); border-color:var(--line2); transform:translateY(-1px)}

.trad{margin:16px 0; scroll-margin-top:20px}
.trad-head{display:flex; align-items:center; gap:14px; margin-bottom:10px}
.trad-ico{
  width:42px; height:42px; flex:none; border-radius:12px; display:grid; place-items:center;
  background:linear-gradient(135deg, rgba(217,179,106,.22), rgba(142,155,255,.10));
  border:1px solid var(--line2);
}
.trad-ico svg{width:21px; height:21px; fill:none; stroke:var(--gold2); stroke-width:1.6; stroke-linecap:round; stroke-linejoin:round}
.trad h2{font-size:19.5px; margin:0}
.trad > p{margin:0; color:var(--tx2); font-size:16px}
.trad .src{font-size:13px; color:var(--tx3); margin-top:12px; display:block}

.gender h3{color:var(--vio)}
.scenario{border-left:2px solid var(--gold); margin:12px 0}
.scenario h3{font-family:"PT Sans",sans-serif; font-weight:700; font-size:16.5px}

.phases{display:flex; gap:18px; justify-content:center; margin:40px 0 8px}
.phases span{width:10px; height:10px; border-radius:50%; border:1.5px solid var(--gold); opacity:.9}
.phases span:nth-child(2){background:linear-gradient(90deg,var(--gold) 50%,transparent 50%)}
.phases span:nth-child(3){background:var(--gold); box-shadow:0 0 12px rgba(217,179,106,.65)}
.phases span:nth-child(4){background:linear-gradient(270deg,var(--gold) 50%,transparent 50%)}

/* ---------- CTA в бота ---------- */
.cta-bot{
  position:relative; overflow:hidden; border-radius:22px; padding:34px 32px;
  background:
    radial-gradient(700px 320px at 88% -20%, rgba(142,155,255,.22), transparent 60%),
    radial-gradient(500px 300px at 0% 120%, rgba(217,179,106,.16), transparent 60%),
    linear-gradient(135deg, #1A2244, #0E1430);
  border:1px solid var(--line);
}
.cta-inner{position:relative; display:flex; gap:22px; align-items:flex-start}
.cta-moon{width:48px; height:48px; flex:none; fill:var(--gold); filter:drop-shadow(0 0 14px rgba(217,179,106,.7))}
.cta-bot h2{margin-bottom:10px}
.cta-bot p{margin:0 0 20px; color:var(--tx2); max-width:580px}
.btn{
  display:inline-block; background:linear-gradient(135deg,var(--gold2),var(--gold) 55%,#b78c3f);
  color:#161222; text-decoration:none; font-weight:700; font-size:16px;
  padding:14px 26px; border-radius:13px;
  box-shadow:0 10px 30px rgba(217,179,106,.35);
  transition:transform .2s, box-shadow .25s, filter .25s;
}
.btn:hover{transform:translateY(-2px); box-shadow:0 16px 40px rgba(217,179,106,.45); filter:brightness(1.05)}
.btn-ghost{display:inline-block; margin-left:14px; color:var(--tx2); text-decoration:none; font-size:15px; border-bottom:1px dashed var(--line)}
.btn-ghost:hover{color:var(--tx)}
@media (max-width:600px){.cta-inner{flex-direction:column}.btn-ghost{margin:12px 0 0}}

/* ---------- дни недели ---------- */
.days{display:grid; grid-template-columns:repeat(auto-fit,minmax(190px,1fr)); gap:12px}
.day-card{display:block; text-decoration:none; padding:18px 20px}
.day-card .dw{font-family:"Prata",serif; font-size:17px; color:var(--tx); display:block; margin-bottom:4px}
.day-card .pl{font-size:13.5px; color:var(--tx3)}
.day-card .pl b{color:var(--gold2); font-weight:700}
.day-card.veshchiy{border-color:var(--line2); background:linear-gradient(135deg, rgba(217,179,106,.12), transparent 70%), var(--glass)}

/* ---------- лунный календарь ---------- */
.phase-grid{display:grid; grid-template-columns:1fr 1fr; gap:14px}
@media (max-width:680px){.phase-grid{grid-template-columns:1fr}}
.phase-card .pr{font-size:13px; color:var(--tx3); display:block; margin-bottom:8px}
.phase-card.now{border-color:var(--line2); box-shadow:0 0 0 1px var(--line2), 0 14px 40px rgba(217,179,106,.12)}
.phase-card.now::before{content:"сейчас"; float:right; font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:#161222; background:var(--gold); border-radius:99px; padding:3px 10px; font-weight:700}

/* ---------- гайды ---------- */
.guide-card{display:block; text-decoration:none}
.guide-card h3{color:var(--tx); transition:color .2s}
.guide-card:hover h3{color:var(--gold2)}
.article p{color:var(--tx2); font-size:16.5px; margin:.4em 0 1.1em}
.article h2{margin-top:34px}
.faq-item{margin:14px 0}
.faq-item h3{font-family:"PT Sans",sans-serif; font-weight:700; font-size:16.5px; color:var(--gold2)}
.faq-item p{margin:4px 0 0; color:var(--tx2)}

/* ---------- алфавит ---------- */
.letters{display:flex; flex-wrap:wrap; gap:8px; margin-bottom:14px}
.letters a{
  min-width:38px; text-align:center; padding:8px 10px; background:var(--glass);
  border:1px solid var(--line); border-radius:10px; text-decoration:none; font-weight:700; color:var(--tx2);
  transition:border-color .2s, color .2s, transform .15s;
}
.letters a:hover{border-color:var(--line2); color:var(--gold2); transform:translateY(-2px)}
.letter-group h3{color:var(--gold); font-family:"Prata",serif; font-size:27px; margin:28px 0 4px}
.letter-group ul{list-style:none; padding:0; margin:0}
.letter-group li{padding:10px 0; border-bottom:1px solid rgba(255,255,255,.06); font-size:15px; color:var(--tx3); line-height:1.6}
.letter-group li a{font-weight:700; font-size:16.5px; color:var(--tx); text-decoration:none}
.letter-group li a:hover{color:var(--gold2)}

/* ---------- reveal ---------- */
.reveal{opacity:0; transform:translateY(22px); transition:opacity .7s cubic-bezier(.2,.6,.2,1), transform .7s cubic-bezier(.2,.6,.2,1)}
.reveal.in{opacity:1; transform:none}
.grid3 .card,.days .day-card,.phase-grid .card{transition-delay:calc(var(--i,0)*70ms)}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1; transform:none; transition:none}}

/* ---------- реклама / подвал ---------- */
.ad-slot{margin:34px 0; text-align:center}
.footer{border-top:1px solid var(--line); margin-top:72px; padding:38px 0 46px; font-size:14px; color:var(--tx3)}
.footer a{color:var(--tx2)}
.footer .phases{margin:0 0 22px}
.footer .cols{display:flex; gap:14px 40px; flex-wrap:wrap; justify-content:center; margin-bottom:18px}
.footer p{text-align:center; max-width:640px; margin:0 auto 8px}
main{min-height:46vh}

/* ---------- v3.2: глобальный поиск в шапке ---------- */
.nav-search{position:relative; flex:1 1 200px; max-width:260px}
.nav-search input{
  width:100%; padding:9px 16px; font:inherit; font-size:14.5px; color:var(--tx);
  border-radius:99px; border:1px solid var(--line); background:rgba(13,18,38,.6);
  backdrop-filter:blur(10px); transition:border-color .2s;
}
.nav-search input::placeholder{color:var(--tx3)}
.nav-search input:focus{outline:none; border-color:var(--line2)}
.nav-search .search-results{font-size:15px}
@media (max-width:760px){.nav-search{order:10; flex-basis:100%; max-width:none}}

/* ---------- v3.2: форма «опишите сон» ---------- */
.dream-form{margin-top:6px}
.dream-form textarea{
  width:100%; min-height:96px; resize:vertical; padding:14px 18px; font:inherit; font-size:15.5px;
  color:var(--tx); border-radius:var(--r-sm); border:1px solid var(--line);
  background:rgba(10,14,30,.55); margin-bottom:12px;
}
.dream-form textarea::placeholder{color:var(--tx3)}
.dream-form textarea:focus{outline:none; border-color:var(--line2)}
.dream-form .hint{display:block; margin-top:10px; font-size:13.5px; color:var(--tx3)}

/* ---------- v3.2: самопромо в рекламных слотах ---------- */
.promo{
  display:flex; align-items:center; justify-content:center; gap:10px; text-align:center;
  padding:14px 18px; border:1px dashed var(--line2); border-radius:var(--r-sm);
  color:var(--gold2); text-decoration:none; font-size:15px; background:rgba(217,179,106,.05);
  transition:background .25s, box-shadow .25s;
}
.promo:hover{background:rgba(217,179,106,.12); box-shadow:0 8px 24px rgba(0,0,0,.3)}


/* ---------- v5: skip-link для доступности ---------- */
.skip-link{
  position:absolute; left:-999px; top:0; z-index:100;
  background:var(--gold); color:#161222; padding:10px 18px; border-radius:0 0 10px 0;
  font-weight:700; text-decoration:none;
}
.skip-link:focus{left:0}

/* ---------- v6.1: юридические ссылки в подвале ---------- */
.legal-links{margin-top:6px}
.legal-links a{font-size:13px; color:var(--tx3)}
.legal-links a:hover{color:var(--tx2)}
.legal h2{font-size:19px; margin-top:28px}
.legal p{font-size:15.5px}

/* ---------- v6.2: шаринг на странице символа ---------- */
.share{display:flex; align-items:center; gap:12px; flex-wrap:wrap; margin:44px 0 0}
.share-label{font-size:14px; color:var(--tx3)}
.share-btn{
  --c:var(--gold2);
  display:grid; place-items:center; width:44px; height:44px; padding:0;
  border:1px solid var(--line); border-radius:50%;
  background:var(--glass); color:var(--tx2); cursor:pointer; text-decoration:none;
  backdrop-filter:blur(8px); position:relative;
  transition:border-color .25s, color .25s, transform .2s, box-shadow .25s, background .25s;
}
.share-btn svg{width:21px; height:21px; fill:currentColor}
.share-btn:hover{color:var(--c); border-color:var(--line2); transform:translateY(-2px); box-shadow:0 8px 22px rgba(0,0,0,.35)}
.share-btn.vk{--c:#6a93d4}
.share-btn.tg{--c:#54a9eb}
.share-btn.copy.done{color:#161222; background:var(--gold); border-color:var(--gold)}
.share-btn.copy.done::after{
  content:"Скопировано"; position:absolute; bottom:calc(100% + 8px); left:50%; transform:translateX(-50%);
  white-space:nowrap; font-size:12px; padding:4px 9px; border-radius:8px; font-weight:700;
  background:var(--gold); color:#161222; box-shadow:0 6px 18px rgba(0,0,0,.35);
}
