/* ══════════════════════════════════════════════════════════════════════════
   Музоныч — лендинг. Арт-направление: тёмная сцена (реф: Suno, Udio),
   дисплейная типографика Unbounded, glow-градиенты фиолет→янтарь.
   ══════════════════════════════════════════════════════════════════════════ */
:root {
  --bg: #0b0812;
  --bg-2: #130e1f;
  --panel: rgba(255, 255, 255, .04);
  --panel-2: rgba(255, 255, 255, .07);
  --line: rgba(255, 255, 255, .09);
  --ink: #f3effc;
  --muted: #a89dc2;
  --vio: #8b5cf6;
  --vio-2: #a78bfa;
  --amber: #fbbf24;
  --grad: linear-gradient(93deg, #a78bfa 0%, #f0abfc 45%, #fbbf24 100%);
  --grad-btn: linear-gradient(93deg, #7c3aed, #c026d3 55%, #f59e0b);
  --r: 22px;
  --disp: 'Unbounded', system-ui, sans-serif;
  --text: 'Manrope', 'Segoe UI', system-ui, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--text);
  font-size: 17px;
  line-height: 1.65;
  background: var(--bg);
  color: var(--ink);
  overflow-x: hidden;
}
img { max-width: 100%; display: block; }
a { color: var(--vio-2); }
.wrap { max-width: 1120px; margin: 0 auto; padding: 0 24px; }

h1, h2, .disp { font-family: var(--disp); font-weight: 700; line-height: 1.15; letter-spacing: -.01em; }
h2 { font-size: clamp(1.5rem, 3.6vw, 2.4rem); margin: 0 0 14px; }
.grad-text { background: var(--grad); -webkit-background-clip: text; background-clip: text; color: transparent; }
.kicker {
  font-family: var(--disp); font-size: .72rem; font-weight: 600; letter-spacing: .22em;
  text-transform: uppercase; color: var(--amber); margin-bottom: 14px;
}
.section-sub { color: var(--muted); max-width: 640px; font-size: 1.08rem; margin: 0 0 44px; }

/* ── Кнопки ── */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  border: 0; border-radius: 16px; padding: 18px 34px; cursor: pointer;
  font: 700 1.05rem var(--text); text-decoration: none; color: #fff;
  transition: transform .15s, box-shadow .25s, filter .25s;
}
.btn:active { transform: scale(.97); }
.btn-glow {
  background: var(--grad-btn);
  box-shadow: 0 8px 40px rgba(168, 85, 247, .45), 0 2px 12px rgba(245, 158, 11, .3), inset 0 1px 0 rgba(255,255,255,.25);
}
.btn-glow:hover { filter: brightness(1.12); box-shadow: 0 10px 55px rgba(168, 85, 247, .65), 0 2px 16px rgba(245, 158, 11, .4); }
.btn-line { background: transparent; border: 1px solid var(--line); color: var(--ink); }
.btn-line:hover { border-color: var(--vio); background: rgba(139, 92, 246, .08); }

/* ── Навигация ── */
.topnav {
  position: sticky; top: 0; z-index: 40;
  background: rgba(11, 8, 18, .72);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--line);
}
.topnav .wrap { display: flex; align-items: center; gap: 26px; height: 68px; }
.logo { font-family: var(--disp); font-size: 1.05rem; font-weight: 700; color: var(--ink); text-decoration: none; letter-spacing: .01em; }
.logo span { background: var(--grad); -webkit-background-clip: text; background-clip: text; color: transparent; }
.topnav nav { margin-left: auto; display: flex; gap: 26px; align-items: center; }
.topnav nav a:not(.btn) { color: var(--muted); text-decoration: none; font-weight: 600; font-size: .95rem; transition: color .15s; }
.topnav nav a:not(.btn):hover { color: var(--ink); }
.topnav .btn { padding: 11px 22px; font-size: .92rem; border-radius: 12px; }
@media (max-width: 800px) { .topnav nav a:not(.btn) { display: none; } }

/* ── Hero ── */
.hero { position: relative; padding: 90px 0 70px; }
.hero::before {
  content: ''; position: absolute; inset: -40% -20% auto;  height: 130%;
  background:
    radial-gradient(46% 55% at 68% 38%, rgba(139, 92, 246, .34), transparent 70%),
    radial-gradient(30% 40% at 22% 25%, rgba(192, 38, 211, .22), transparent 70%),
    radial-gradient(26% 34% at 82% 72%, rgba(245, 158, 11, .16), transparent 70%);
  filter: blur(10px);
  pointer-events: none;
}
.hero .wrap { position: relative; display: grid; grid-template-columns: 1.08fr .92fr; gap: 60px; align-items: center; }
.hero h1 { font-size: clamp(2rem, 4.6vw, 3.4rem); margin: 0 0 22px; }
.hero .sub { color: var(--muted); font-size: 1.18rem; margin: 0 0 34px; max-width: 480px; }
.hero .cta-row { display: flex; gap: 14px; flex-wrap: wrap; align-items: center; }
.hero .cta-note { margin-top: 16px; color: #7ee2a0; font-weight: 700; font-size: .95rem; }
.hero-stats { display: flex; gap: 38px; margin-top: 46px; flex-wrap: wrap; }
.hero-stats b { display: block; font-family: var(--disp); font-size: 1.5rem; background: var(--grad); -webkit-background-clip: text; background-clip: text; color: transparent; }
.hero-stats span { color: var(--muted); font-size: .88rem; }

/* Живой плеер в hero */
.hero-player { position: relative; }
.hero-player::before {
  content: ''; position: absolute; inset: 8% -6%;
  background: radial-gradient(50% 50% at 50% 50%, rgba(139, 92, 246, .4), transparent 70%);
  filter: blur(30px); z-index: 0;
}
.player-card {
  position: relative; z-index: 1;
  background: linear-gradient(160deg, rgba(255,255,255,.09), rgba(255,255,255,.03));
  border: 1px solid rgba(255, 255, 255, .14);
  border-radius: 26px; padding: 22px;
  backdrop-filter: blur(20px);
  box-shadow: 0 30px 80px rgba(0, 0, 0, .5);
  transform: rotate(1.6deg);
}
.player-card .pc-cover { border-radius: 16px; aspect-ratio: 16/10; object-fit: cover; width: 100%; }
.player-card .pc-title { font-family: var(--disp); font-size: .95rem; margin: 16px 0 2px; }
.player-card .pc-sub { color: var(--muted); font-size: .85rem; margin-bottom: 14px; }
.player-card .pc-row { display: flex; align-items: center; gap: 14px; }
.play-btn {
  width: 54px; height: 54px; min-width: 54px; border-radius: 50%; border: 0; cursor: pointer;
  background: var(--grad-btn); color: #fff; font-size: 1.15rem;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 6px 24px rgba(168, 85, 247, .5);
  transition: transform .15s;
}
.play-btn:hover { transform: scale(1.07); }
.eq { display: flex; align-items: flex-end; gap: 3px; height: 34px; flex: 1; }
.eq i {
  flex: 1; background: linear-gradient(180deg, var(--vio-2), var(--vio));
  border-radius: 2px; height: 20%; opacity: .5;
  transition: height .18s;
}
.eq.playing i { animation: eqjump 1s infinite ease-in-out; opacity: 1; }
.eq i:nth-child(3n) { animation-delay: .12s; }
.eq i:nth-child(3n+1) { animation-delay: .27s; }
.eq i:nth-child(5n) { animation-delay: .4s; }
@keyframes eqjump { 0%, 100% { height: 18%; } 50% { height: 95%; } }
.player-card .pc-time { color: var(--muted); font-size: .8rem; font-variant-numeric: tabular-nums; min-width: 40px; text-align: right; }
.pc-badge {
  position: absolute; top: -14px; right: 22px; z-index: 2;
  background: var(--amber); color: #1a1206; font-weight: 800; font-size: .78rem;
  border-radius: 999px; padding: 6px 14px; transform: rotate(2deg);
  box-shadow: 0 6px 18px rgba(245, 158, 11, .4);
}
.mascot-hero {
  position: absolute; z-index: 0; width: 62%; top: -19%; right: -4%;
  transform: rotate(-3deg);
  filter: drop-shadow(0 14px 34px rgba(0, 0, 0, .45));
  animation: mascot-bob 5s ease-in-out infinite;
}
@keyframes mascot-bob { 0%, 100% { transform: rotate(-3deg) translateY(0); } 50% { transform: rotate(-2deg) translateY(-10px); } }
@media (max-width: 900px) {
  .hero .wrap { grid-template-columns: 1fr; gap: 44px; }
  .hero-player { max-width: 440px; margin: 30px auto 0; }
}

/* ── Блок Музоныча ── */
.mascot-grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: 56px; align-items: center; }
.mascot-pic { position: relative; }
.mascot-pic::before {
  content: ''; position: absolute; inset: 10%;
  background: radial-gradient(50% 50% at 50% 50%, rgba(139, 92, 246, .35), transparent 70%);
  filter: blur(28px);
}
.mascot-pic img { position: relative; transform: rotate(-2deg); }
.mascot-bubbles { display: flex; flex-direction: column; gap: 12px; margin-top: 24px; max-width: 520px; }
.mascot-bubbles .bubble { border-radius: 4px 18px 18px 18px; }
@media (max-width: 860px) { .mascot-grid { grid-template-columns: 1fr; gap: 30px; } .mascot-pic { max-width: 380px; margin: 0 auto; } }

/* ── Бегущая строка ── */
.ticker { border-block: 1px solid var(--line); padding: 16px 0; overflow: hidden; background: var(--bg-2); }
.ticker-inner { display: flex; gap: 48px; width: max-content; animation: ticker 36s linear infinite; }
.ticker-inner span { color: var(--muted); font-family: var(--disp); font-size: .8rem; font-weight: 600; white-space: nowrap; }
.ticker-inner span::before { content: '♪'; color: var(--amber); margin-right: 12px; }
@keyframes ticker { to { transform: translateX(-50%); } }

section { padding: 96px 0; }

/* ── Шаги ── */
.steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; border: 1px solid var(--line); border-radius: var(--r); overflow: hidden; }
.step {
  padding: 34px 28px; background: var(--panel); position: relative;
  border-left: 1px solid var(--line); transition: background .25s;
}
.step:first-child { border-left: 0; }
.step:hover { background: var(--panel-2); }
.step .n {
  font-family: var(--disp); font-size: 2.6rem; font-weight: 700; line-height: 1;
  color: transparent; -webkit-text-stroke: 1.5px rgba(167, 139, 250, .55); margin-bottom: 18px;
}
.step h3 { font-family: var(--disp); font-size: .98rem; margin: 0 0 10px; font-weight: 600; }
.step p { margin: 0; color: var(--muted); font-size: .95rem; }
@media (max-width: 900px) { .steps { grid-template-columns: 1fr 1fr; } .step { border-top: 1px solid var(--line); } }
@media (max-width: 520px) { .steps { grid-template-columns: 1fr; } }

/* ── Поводы: полароиды ── */
.occasions { display: grid; grid-template-columns: repeat(3, 1fr); gap: 26px; }
.occ {
  background: #17121f; border: 1px solid var(--line); border-radius: 18px;
  padding: 14px 14px 20px; transition: transform .3s, box-shadow .3s;
}
.occ:nth-child(odd) { transform: rotate(-1.3deg); }
.occ:nth-child(even) { transform: rotate(1.2deg); }
.occ:hover { transform: rotate(0) translateY(-8px); box-shadow: 0 24px 60px rgba(139, 92, 246, .25); }
.occ img { border-radius: 10px; aspect-ratio: 4/3; object-fit: cover; width: 100%; }
.occ h3 { font-family: var(--disp); font-size: .92rem; font-weight: 600; margin: 16px 4px 6px; }
.occ p { margin: 0 4px; color: var(--muted); font-size: .92rem; }
@media (max-width: 860px) { .occasions { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .occasions { grid-template-columns: 1fr; } }

/* ── Лента примеров ── */
#examples { background: var(--bg-2); border-block: 1px solid var(--line); }
.feed-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.feed-card {
  display: flex; align-items: center; gap: 16px;
  background: var(--panel); border: 1px solid var(--line); border-radius: 18px; padding: 14px 18px;
  transition: border-color .2s, background .2s;
}
.feed-card:hover { border-color: rgba(167, 139, 250, .4); background: var(--panel-2); }
.feed-card img { width: 58px; height: 58px; border-radius: 12px; object-fit: cover; }
.feed-card .fc-body { flex: 1; min-width: 0; }
.feed-card .fc-t { font-weight: 800; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.feed-card .fc-s { color: var(--muted); font-size: .85rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.feed-card .play-btn { width: 46px; height: 46px; min-width: 46px; font-size: 1rem; }
@media (max-width: 720px) { .feed-grid { grid-template-columns: 1fr; } }

/* ── Тарифы ── */
.price-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; align-items: stretch; }
.price-card {
  position: relative; display: flex; flex-direction: column;
  background: var(--panel); border: 1px solid var(--line); border-radius: var(--r);
  padding: 32px 26px; text-align: left; transition: transform .25s, border-color .25s;
}
.price-card:hover { transform: translateY(-6px); border-color: rgba(167, 139, 250, .35); }
.price-card.hit {
  background: linear-gradient(170deg, rgba(139, 92, 246, .16), rgba(245, 158, 11, .07));
  border: 1px solid transparent;
  background-clip: padding-box;
  box-shadow: 0 0 0 1.5px rgba(167, 139, 250, .6), 0 20px 60px rgba(139, 92, 246, .25);
}
.price-card .flag {
  position: absolute; top: -13px; left: 26px;
  background: var(--grad-btn); color: #fff; font-size: .72rem; font-weight: 800;
  border-radius: 999px; padding: 5px 14px; letter-spacing: .04em;
}
.price-card .n { font-family: var(--disp); font-size: .9rem; font-weight: 600; color: var(--muted); }
.price-card .p { font-family: var(--disp); font-size: 2rem; font-weight: 700; margin: 10px 0 2px; }
.price-card .per { color: var(--muted); font-size: .88rem; min-height: 1.4em; }
.price-card .save { color: #7ee2a0; font-weight: 700; font-size: .9rem; margin: 10px 0 20px; min-height: 1.3em; }
.price-card .btn { margin-top: auto; padding: 13px; font-size: .95rem; }
.price-free { text-align: center; font-size: 1.1rem; margin: 0 0 40px; color: var(--muted); }
.price-free b { color: var(--amber); }
@media (max-width: 900px) { .price-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 520px) { .price-grid { grid-template-columns: 1fr; } }

/* ── Отзывы: мессенджер ── */
.reviews { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; align-items: start; }
.review { display: flex; flex-direction: column; gap: 10px; }
.bubble {
  background: #1d1729; border: 1px solid var(--line);
  border-radius: 18px 18px 18px 4px; padding: 16px 18px; font-size: .97rem;
}
.bubble.voice { display: flex; align-items: center; gap: 10px; color: var(--muted); font-size: .85rem; }
.bubble.voice .mini-eq { display: flex; gap: 2px; align-items: flex-end; height: 16px; }
.bubble.voice .mini-eq i { width: 3px; background: var(--vio-2); border-radius: 2px; }
.review .who { color: var(--muted); font-size: .85rem; padding-left: 6px; }
.review .who b { color: var(--ink); }
@media (max-width: 860px) { .reviews { grid-template-columns: 1fr; max-width: 520px; margin: 0 auto; } }

/* ── FAQ ── */
.faq { max-width: 760px; margin: 0 auto; }
.faq details { border-bottom: 1px solid var(--line); }
.faq summary {
  font-family: var(--disp); font-weight: 600; font-size: .98rem; padding: 22px 8px;
  cursor: pointer; list-style: none; display: flex; justify-content: space-between; align-items: center; gap: 20px;
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: '+'; font-size: 1.5rem; color: var(--vio-2); transition: transform .2s; }
.faq details[open] summary::after { transform: rotate(45deg); }
.faq details p { margin: 0 8px 22px; color: var(--muted); }

/* ── Финальный CTA ── */
.final-cta {
  position: relative; overflow: hidden; text-align: center;
  border: 1px solid rgba(167, 139, 250, .3); border-radius: 30px; padding: 84px 30px;
  background:
    linear-gradient(180deg, rgba(11, 8, 18, .82), rgba(11, 8, 18, .6)),
    url('../img/hero-dark.jpg') center 65% / cover no-repeat,
    var(--bg-2);
}
.final-cta h2 { font-size: clamp(1.7rem, 4vw, 2.6rem); }
.final-cta p { color: var(--muted); max-width: 520px; margin: 0 auto 34px; font-size: 1.1rem; }

footer { padding: 46px 0 64px; color: var(--muted); font-size: .88rem; text-align: center; }
footer a { color: var(--muted); }

/* появление секций */
.reveal { opacity: 0; transform: translateY(26px); transition: opacity .7s, transform .7s; }
.reveal.on { opacity: 1; transform: none; }
