/* ============================================================
   Сказия — светлый атлас живых сказок
   Шрифты — системные macOS (работает офлайн, без CDN)
   ============================================================ */

:root {
  /* Атлас */
  --skazia-bg: #fff8e8;
  --skazia-bg-soft: #f6ebcf;
  --skazia-sky: #d9edf1;
  --skazia-primary: #366f92;
  /* Тёплые акценты */
  --skazia-sun:    #de982c;
  --skazia-sun-soft:  #f5c96c;
  --skazia-coral:   #eb8b68;
  --skazia-story:    #d86d86;
  --skazia-leaf:    #5fa36f;
  /* Бумага для чтения */
  --skazia-paper:   #fbf2e0;
  --skazia-paper-soft: #f4e6cd;
  --skazia-paper-ink:     #2c2740;
  --skazia-paper-ink-soft:#5b5470;
  /* Текст */
  --skazia-ink:      #2a3646;
  --skazia-muted:  rgba(42,54,70,.70);
  --skazia-line:    rgba(55,89,108,.20);

  --font-script: "Snell Roundhand", "Apple Chancery", "Segoe Script", cursive;
  --font-display: "Iowan Old Style", "Palatino Linotype", Palatino, Georgia, serif;
  --font-read: "Iowan Old Style", Georgia, "Times New Roman", serif;
  --font-ui: "Avenir Next", "Avenir", "Segoe UI", system-ui, sans-serif;

  --r-lg: 26px;
  --r-md: 16px;
  --r-sm: 10px;
  --skazia-shadow-soft: 0 24px 60px -28px rgba(70,50,20,.30);
  --skazia-shadow-glow: 0 0 48px -16px rgba(222,152,44,.30);
  --maxw: 940px;
}

* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0;
  font-family: var(--font-ui);
  color: var(--skazia-ink);
  background: var(--skazia-bg);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

/* ---------- Светлая сцена атласа ---------- */
.sky { position: fixed; inset: 0; z-index: -2; overflow: hidden;
  background:
    linear-gradient(115deg, rgba(217,237,241,.90) 0%, rgba(255,248,232,.86) 42%, rgba(246,235,207,.92) 100%),
    url("assets/brand/lumos-og-background.png") center right / min(980px, 78vw) auto no-repeat;
}
.haze { position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(255,255,255,.60), rgba(255,248,232,.16)),
    repeating-linear-gradient(0deg, rgba(54,111,146,.035) 0 1px, transparent 1px 5px); }

.stars { display: none; }
.stars--far {
  background-image:
    radial-gradient(1px 1px at 20px 30px, rgba(253,246,227,.9), transparent),
    radial-gradient(1px 1px at 130px 80px, rgba(253,246,227,.7), transparent),
    radial-gradient(1px 1px at 80px 160px, rgba(253,246,227,.8), transparent),
    radial-gradient(1px 1px at 200px 120px, rgba(253,246,227,.6), transparent),
    radial-gradient(1px 1px at 260px 40px, rgba(253,246,227,.75), transparent);
  background-size: 300px 300px;
  animation: drift 220s linear infinite;
  opacity: .8;
}
.stars--near {
  background-image:
    radial-gradient(1.6px 1.6px at 60px 50px, #fff, transparent),
    radial-gradient(1.4px 1.4px at 180px 200px, var(--skazia-sun-soft), transparent),
    radial-gradient(1.4px 1.4px at 320px 100px, #fff, transparent);
  background-size: 420px 420px;
  animation: drift 140s linear infinite reverse;
  opacity: .9;
}
@keyframes drift { to { transform: translate3d(40px, -60px, 0); } }

.twinkles span {
  position: absolute; width: 3px; height: 3px; border-radius: 50%;
  background: var(--skazia-leaf); box-shadow: 0 0 8px 2px rgba(253,246,227,.8);
  animation: tw 4s ease-in-out infinite;
}
.twinkles span:nth-child(1){ left:12%; top:22%; animation-delay:.2s }
.twinkles span:nth-child(2){ left:28%; top:64%; animation-delay:1.1s }
.twinkles span:nth-child(3){ left:46%; top:18%; animation-delay:2.0s }
.twinkles span:nth-child(4){ left:67%; top:52%; animation-delay:.6s }
.twinkles span:nth-child(5){ left:82%; top:30%; animation-delay:1.6s }
.twinkles span:nth-child(6){ left:90%; top:70%; animation-delay:2.6s }
@keyframes tw { 0%,100%{ opacity:.15; transform:scale(.6) } 50%{ opacity:1; transform:scale(1.2) } }

/* Месяц */
.twinkles, .moon, .moon__glow { display: none; }

/* ---------- Шапка ---------- */
.topbar { position: sticky; top: 0; z-index: 5;
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px clamp(18px, 5vw, 48px);
  backdrop-filter: blur(12px);
  background: rgba(255,248,232,.72);
  border-bottom: 1px solid rgba(55,89,108,.12);
}
.brand { display: flex; align-items: baseline; gap: 12px; }
.brand__mark { font-family: var(--font-display); font-size: 40px; color: var(--skazia-ink);
  text-shadow: none; line-height: 1; font-weight: 700; }
.brand__sub { font-family: var(--font-ui); font-size: 12px; letter-spacing: .28em;
  text-transform: uppercase; color: var(--skazia-muted); }
.ghost-btn { font-family: var(--font-ui); font-size: 13px; color: var(--skazia-ink);
  background: rgba(255,255,255,.50); border: 1px solid var(--skazia-line);
  padding: 9px 14px; border-radius: 999px; cursor: pointer; transition: .2s; }
.ghost-btn:hover { background: rgba(246,217,138,.14); border-color: var(--skazia-sun); }
.ghost-btn--sm { padding: 5px 10px; font-size: 12px; }

/* ---------- Сцена / экраны ---------- */
.stage { max-width: var(--maxw); margin: 0 auto; padding: clamp(20px,5vw,52px) clamp(18px,5vw,40px) 90px; }
.screen { animation: rise .6s cubic-bezier(.2,.7,.2,1) both; }
.screen > * { animation: rise .7s cubic-bezier(.2,.7,.2,1) both; }
.screen > *:nth-child(2){ animation-delay:.07s } .screen > *:nth-child(3){ animation-delay:.14s }
.screen > *:nth-child(4){ animation-delay:.21s } .screen > *:nth-child(5){ animation-delay:.28s }
@keyframes rise { from{ opacity:0; transform: translateY(16px) } to{ opacity:1; transform:none } }

/* ---------- Landing ---------- */
.hero { text-align: left; padding: 26px 0 8px; }
.hero--landing { position: relative; min-height: 520px; padding: clamp(34px, 6vw, 72px);
  border: 1px solid rgba(55,89,108,.16); border-radius: 24px; overflow: hidden;
  background:
    linear-gradient(90deg, rgba(255,248,232,.98) 0%, rgba(255,248,232,.90) 42%, rgba(255,248,232,.28) 67%, rgba(255,248,232,0) 100%),
    url("assets/brand/lumos-hero-atlas-v2.png") center right / auto 100% no-repeat;
  box-shadow: var(--skazia-shadow-soft); }
.eyebrow { font-size: 12px; letter-spacing:.18em; text-transform:uppercase; color: var(--skazia-primary); font-weight: 700; }
.hero h1 { font-family: var(--font-display); font-weight: 600; line-height: 1.05;
  font-size: clamp(34px, 6vw, 64px); margin: 14px 0 0; max-width: 650px; text-wrap: balance; }
.hero h1 em { font-style: italic; color: var(--skazia-primary); }
.hero p.lead { max-width: 560px; margin: 18px 0 0; font-size: 18px; color: var(--skazia-muted); line-height: 1.6; text-wrap: pretty; }

.cta-row { display: flex; gap: 14px; justify-content: flex-start; flex-wrap: wrap; margin-top: 30px; }
.btn { font-family: var(--font-ui); font-weight: 600; font-size: 16px; cursor: pointer;
  border: none; border-radius: 999px; padding: 15px 30px; transition: transform .15s, box-shadow .2s, filter .2s; }
.btn:active { transform: translateY(1px) scale(.99); }
.btn--gold { color: #3a2c0c;
  background: linear-gradient(180deg, var(--skazia-sun-soft), var(--skazia-sun));
  box-shadow: 0 14px 30px -10px rgba(246,217,138,.6), inset 0 1px 0 rgba(255,255,255,.6); }
.btn--gold:hover { filter: brightness(1.05); box-shadow: 0 18px 40px -10px rgba(246,217,138,.75); }
.btn--ghost { color: var(--skazia-ink); background: rgba(255,255,255,.56); border: 1px solid var(--skazia-line); }
.btn--ghost:hover { border-color: var(--skazia-sun); }
.btn--block { width: 100%; }
.btn[disabled]{ opacity:.5; cursor: not-allowed; }
.btn-note { margin-top: 12px; font-size: 13px; color: var(--skazia-muted); }

.steps { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; margin: 48px 0 0; }
.step { background: rgba(255,255,255,.64); border: 1px solid var(--skazia-line); border-radius: var(--r-md);
  padding: 22px; }
.step .num { font-family: var(--font-display); font-size: 30px; color: var(--skazia-primary); }
.step h3 { margin: 8px 0 6px; font-size: 16px; }
.step p { margin: 0; color: var(--skazia-muted); font-size: 14px; line-height: 1.55; }

.feature-row { display:flex; gap:10px; flex-wrap:wrap; justify-content:flex-start; margin-top:30px; }
.chip { font-size: 13px; color: var(--skazia-ink); background: rgba(255,255,255,.58);
  border: 1px solid var(--skazia-line); padding: 8px 14px; border-radius: 999px; }

/* ---------- Бумажная карточка чтения ---------- */
.paper { position: relative; background: linear-gradient(180deg, var(--skazia-paper), var(--skazia-paper-soft));
  color: var(--skazia-paper-ink); border-radius: var(--r-lg); padding: clamp(26px,5vw,52px);
  box-shadow: var(--skazia-shadow-soft), var(--skazia-shadow-glow);
  border: 1px solid rgba(255,255,255,.5); }
.paper::before { content:""; position:absolute; inset:-2px; border-radius: inherit; z-index:-1;
  background: radial-gradient(60% 40% at 50% 0%, rgba(246,217,138,.5), transparent 70%); filter: blur(8px); }
.paper h2 { font-family: var(--font-display); font-weight:600; font-size: clamp(24px,4vw,34px);
  margin: 0 0 4px; color: var(--skazia-paper-ink); }
.paper .meta { color: var(--skazia-paper-ink-soft); font-size: 13px; margin-bottom: 22px; }
.story { font-family: var(--font-read); font-size: 19px; line-height: 1.85; color: #38324d; }
.story p { margin: 0 0 16px; }
.story .end { text-align: center; color: var(--skazia-sun); font-style: italic; }

.mock-banner { display:flex; gap:10px; align-items:flex-start;
  background: rgba(255,181,154,.16); border: 1px dashed rgba(255,140,110,.6);
  color: #7a3b28; border-radius: var(--r-sm); padding: 10px 14px; font-size: 13px; margin-bottom: 20px; }
/* честная плашка на проде (вместо тех-деталей мока) — спокойный золотой тон */
.mock-banner--soft { background: rgba(246,217,138,.16); border: 1px solid rgba(176,106,53,.35);
  color: #7a5a23; }

/* ---------- Пример сказки на лендинге (та же «бумага», что и читалка) ---------- */
.example { margin: 32px 0 0; text-align: left; }
.ex-eyebrow { font-size: 12px; letter-spacing: .22em; text-transform: uppercase;
  color: #b06a35; margin-bottom: 8px; }
.example .story { font-size: 18px; }
.example .ex-fade { color: var(--skazia-paper-ink-soft); text-align: center; letter-spacing: .35em; margin: 2px 0 0; }
.example .ex-more { margin: 16px 0 0; color: var(--skazia-paper-ink-soft); font-size: 15px; font-style: italic; }

/* переключатель тизеров: «Василиса, 3 года · сон» / «Егор, 5 лет · стоматолог» / ... */
.ex-tabs { display: flex; flex-wrap: wrap; gap: 8px; margin: 0 0 18px; }
.ex-tab { font-family: var(--font-ui); font-size: 13px; line-height: 1.3; color: var(--skazia-paper-ink-soft);
  background: rgba(255,255,255,.55); border: 1px solid var(--skazia-line); border-radius: 999px;
  padding: 7px 14px; cursor: pointer; transition: .15s; }
.ex-tab:hover { border-color: var(--skazia-sun); color: var(--skazia-paper-ink); }
.ex-tab.sel { background: var(--skazia-sun-soft); border-color: var(--skazia-sun); color: var(--skazia-paper-ink); font-weight: 600; }

/* ---------- Ритуал: «сегодня», отметки вечеров, финал серии ---------- */
.today-card { background: linear-gradient(180deg, rgba(255,255,255,.74), rgba(246,235,207,.50));
  border: 1px solid var(--skazia-sun); border-radius: var(--r-md); padding: 18px 20px; margin-bottom: 18px;
  box-shadow: var(--skazia-shadow-glow); }
.today-eyebrow { font-size: 12px; letter-spacing: .22em; text-transform: uppercase; color: var(--skazia-sun-soft); }
.today-row { display:flex; align-items:center; justify-content:space-between; gap:14px; margin-top:8px; flex-wrap:wrap; }
.today-n { font-family: var(--font-display); font-size: 22px; }
.today-t { color: var(--skazia-muted); font-size: 14px; margin-top: 2px; }
.today-bar { height: 6px; border-radius: 999px; background: rgba(42,54,70,.10); margin-top: 14px; overflow:hidden; }
.today-bar span { display:block; height:100%; border-radius:999px;
  background: linear-gradient(90deg, var(--skazia-sun), var(--skazia-sun-soft)); transition: width .4s; }
.today-meta { font-size: 12px; color: var(--skazia-muted); margin-top: 8px; }

.ep-item.done { opacity: .82; }
.ep-item.done .ep-num { color: #9be29b; }
.ep-item.done .go { color: var(--skazia-muted); }

.finale { text-align: center; margin-bottom: 18px; }
.finale h2 { font-size: clamp(24px,4vw,32px); }
.finale .fin-next { margin: 14px 0 0; color: var(--skazia-paper-ink-soft); font-size: 15px; }

/* ---------- Форма ---------- */
.form-card { background: rgba(255,255,255,.74); border: 1px solid var(--skazia-line);
  border-radius: var(--r-lg); padding: clamp(24px,5vw,40px); }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.field { display: flex; flex-direction: column; gap: 7px; }
.field.full { grid-column: 1 / -1; }
.field label { font-size: 13px; color: var(--skazia-muted); letter-spacing:.02em; }
.field input, .field select {
  font-family: var(--font-ui); font-size: 16px; color: var(--skazia-ink);
  background: rgba(255,255,255,.86); border: 1px solid var(--skazia-line); border-radius: var(--r-sm);
  padding: 13px 15px; transition: border-color .2s, box-shadow .2s; }
.field input:focus, .field select:focus { outline: none; border-color: var(--skazia-sun);
  box-shadow: 0 0 0 3px rgba(246,217,138,.18); }
.field input::placeholder { color: rgba(42,54,70,.42); }
.seg { display: flex; gap: 8px; }
.seg button { flex:1; font-family: var(--font-ui); font-size:15px; color: var(--skazia-ink);
  background: rgba(255,255,255,.74); border: 1px solid var(--skazia-line); border-radius: var(--r-sm);
  padding: 12px; cursor: pointer; transition:.2s; }
.seg button.sel { background: linear-gradient(180deg, var(--skazia-sun-soft), var(--skazia-sun)); color:#3a2c0c; border-color: transparent; font-weight:600; }
.voices { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.voices button { font-family: var(--font-ui); font-size:14px; color: var(--skazia-ink); text-align:left;
  background: rgba(255,255,255,.74); border: 1px solid var(--skazia-line); border-radius: var(--r-sm);
  padding: 10px 12px; cursor: pointer; transition:.2s; }
.voices button b { display:block; font-weight:600; }
.voices button small { display:block; opacity:.7; font-size:12px; margin-top:2px; }
.voices button.sel { background: linear-gradient(180deg, var(--skazia-sun-soft), var(--skazia-sun)); color:#3a2c0c; border-color: transparent; }
.voices button.sel small { opacity:.85; }
.form-actions { margin-top: 26px; }

/* ---------- Генерация ---------- */
.generating { text-align: center; padding: 60px 0; }
.gen-moon { width: 120px; height: 120px; margin: 0 auto 30px; border-radius: 50%;
  background: conic-gradient(from 0deg, var(--skazia-primary), var(--skazia-sun), var(--skazia-leaf), var(--skazia-coral), var(--skazia-primary));
  filter: blur(1px); animation: spin 3.2s linear infinite; box-shadow: 0 0 60px rgba(246,217,138,.5); }
@keyframes spin { to { transform: rotate(360deg); } }
.generating h2 { font-family: var(--font-display); font-size: 26px; margin: 0 0 8px; }
.generating p { color: var(--skazia-muted); }
.gen-steps { list-style: none; padding: 0; margin: 26px auto 0; max-width: 360px; text-align: left; }
.gen-steps li { padding: 9px 0 9px 30px; position: relative; color: var(--skazia-muted); transition:.3s; }
.gen-steps li::before { content:"○"; position:absolute; left:6px; color: var(--skazia-line); }
.gen-steps li.done { color: var(--skazia-ink); }
.gen-steps li.done::before { content:"✦"; color: var(--skazia-sun-soft); }

/* ---------- Аудио-бар ---------- */
.audiobar { display:flex; align-items:center; gap:14px; flex-wrap:wrap;
  background: rgba(255,255,255,.70); border:1px solid var(--skazia-line); border-radius: 999px;
  padding: 10px 14px; margin: 22px 0 4px; }
.play-btn { width:46px; height:46px; border-radius:50%; border:none; cursor:pointer; flex:0 0 auto;
  background: linear-gradient(180deg, var(--skazia-sun-soft), var(--skazia-sun)); color:#3a2c0c; font-size:18px;
  box-shadow: 0 8px 20px -8px rgba(246,217,138,.7); transition: transform .15s; }
.play-btn:active{ transform: scale(.94); }
.audiobar .vlabel { font-size:13px; color: var(--skazia-muted); }
.audiobar select { font-family: var(--font-ui); font-size:14px; color: var(--skazia-ink);
  background: rgba(255,255,255,.84); border:1px solid var(--skazia-line); border-radius: var(--r-sm); padding:8px 10px; max-width: 220px; }
.audiobar .speaking { color: var(--skazia-sun-soft); font-size: 13px; }

/* ---------- Чекаут (мок ЮKassa) ---------- */
.checkout { display: grid; grid-template-columns: 1.1fr .9fr; gap: 22px; }
.pay-card { background: #fff; color:#1b1b2b; border-radius: var(--r-lg); padding: 28px;
  box-shadow: var(--skazia-shadow-soft); }
.pay-card .yk { display:flex; align-items:center; gap:8px; font-weight:700; color:#111; }
.pay-card .yk b { color:#7b61ff; }
.pay-card .ymock { margin-left:auto; font-size:11px; background:#f1eefc; color:#7b61ff; padding:3px 8px; border-radius:999px; }
.pay-card label { display:block; font-size:12px; color:#6b6b80; margin: 16px 0 6px; }
.pay-card input { width:100%; font-size:16px; padding:12px 14px; border:1px solid #e3e3ee; border-radius:10px; color:#1b1b2b; background:#fafaff; }
.pay-row { display:flex; gap:12px; }
.order { background: rgba(255,255,255,.70); border:1px solid var(--skazia-line); border-radius: var(--r-lg); padding: 24px; }
.order h3 { margin:0 0 14px; font-family: var(--font-display); font-size: 20px; }
.order .li { display:flex; justify-content:space-between; padding:9px 0; border-bottom:1px dashed var(--skazia-line); color: var(--skazia-muted); font-size:14px; }
.order .li.total { color: var(--skazia-ink); font-weight:700; border-bottom:none; font-size:18px; padding-top:14px; }

/* ---------- Серия ---------- */
.series-head { text-align:center; margin-bottom: 26px; }
.series-head h2 { font-family: var(--font-display); font-size: clamp(26px,5vw,40px); margin:0; }
.series-head p { color: var(--skazia-muted); }
.ep-list { display: grid; gap: 12px; }
.ep-item { display:flex; align-items:center; gap:16px; text-align:left; width:100%;
  background: rgba(255,255,255,.70); border:1px solid var(--skazia-line); border-radius: var(--r-md);
  padding: 16px 18px; cursor:pointer; color: var(--skazia-ink); transition:.2s; }
.ep-item:hover { background: rgba(246,235,207,.84); border-color: var(--skazia-sun); transform: translateX(3px); }
.ep-num { font-family: var(--font-display); font-size: 26px; color: var(--skazia-primary); width: 38px; text-align:center; }
.ep-item .t { font-size: 16px; font-weight:600; }
.ep-item .d { font-size: 13px; color: var(--skazia-muted); }
.ep-item .go { margin-left:auto; color: var(--skazia-primary); }

.toolbar { display:flex; gap:10px; align-items:center; margin-bottom: 18px; flex-wrap:wrap; }
.toolbar .back { cursor:pointer; }
.toolbar .spacer{ flex:1; }

/* ---------- Апселл ---------- */
.upsell { display:grid; grid-template-columns: 1fr 1fr; gap:16px; margin-top: 26px; }
.up-card { background: rgba(255,255,255,.70); border:1px solid var(--skazia-line); border-radius: var(--r-md); padding: 22px; }
.up-card .ic { font-size: 26px; }
.up-card h4 { margin: 8px 0 6px; font-size: 16px; }
.up-card p { margin: 0 0 14px; color: var(--skazia-muted); font-size: 14px; line-height:1.5; }
.up-card .price { color: var(--skazia-primary); font-weight:700; }

/* ---------- Иллюстративные сцены Brand v0.2 ---------- */
.story-scene { display:flex; align-items:center; gap:16px;
  border: 1px solid rgba(55,89,108,.18); border-radius: var(--r-md);
  background:
    linear-gradient(135deg, rgba(255,255,255,.78), rgba(246,235,207,.54)),
    radial-gradient(circle at 18% 20%, rgba(217,237,241,.70), transparent 34%);
  color: var(--skazia-ink); padding: 14px 16px; overflow:hidden;
  box-shadow: 0 16px 36px -30px rgba(42,54,70,.42); }
.scene-copy { display:flex; flex-direction:column; gap:4px; min-width:0; }
.scene-copy b { font-size: 14px; line-height:1.25; }
.scene-copy span { color: var(--skazia-muted); font-size: 13px; line-height:1.45; text-wrap: pretty; }
.scene-map, .scene-stage { position:relative; flex:0 0 136px; width:136px; height:92px;
  border-radius: 14px; background: linear-gradient(160deg, var(--skazia-paper), #fffdf6);
  border: 1px solid rgba(55,89,108,.16); box-shadow: inset 0 0 0 1px rgba(255,255,255,.56); }
.scene-map::before { content:""; position:absolute; inset:12px 15px;
  background:
    linear-gradient(90deg, rgba(54,111,146,.10) 1px, transparent 1px),
    linear-gradient(0deg, rgba(54,111,146,.08) 1px, transparent 1px);
  background-size: 24px 22px; border-radius: 10px; }
.scene-route { position:absolute; left:21px; top:52px; width:82px; height:28px;
  border-top: 3px solid rgba(54,111,146,.35); border-right: 3px solid rgba(54,111,146,.28);
  border-radius: 50% 42% 40% 30%; transform: rotate(-10deg); }
.scene-pin { position:absolute; width:13px; height:13px; border-radius:50%;
  border:2px solid rgba(255,255,255,.85); box-shadow:0 4px 10px rgba(42,54,70,.18); }
.scene-pin--sun { left:27px; top:47px; background:var(--skazia-sun); }
.scene-pin--leaf { left:68px; top:24px; background:var(--skazia-leaf); }
.scene-pin--coral { left:96px; top:60px; background:var(--skazia-coral); }
.scene-compass { position:absolute; right:14px; top:12px; width:38px; height:38px; border-radius:50%;
  background: radial-gradient(circle, #fff 0 28%, var(--skazia-sun-soft) 29% 43%, var(--skazia-primary) 44% 47%, transparent 48%);
  border:1px solid rgba(54,111,146,.34); }
.scene-compass::before { content:""; position:absolute; left:17px; top:5px; width:5px; height:27px;
  background: linear-gradient(180deg, var(--skazia-coral) 0 48%, var(--skazia-primary) 49%);
  clip-path: polygon(50% 0, 100% 50%, 50% 100%, 0 50%); transform: rotate(32deg); }
.scene-stage { background:
    linear-gradient(180deg, rgba(255,255,255,.78), rgba(251,242,224,.92)),
    linear-gradient(90deg, rgba(216,109,134,.18), transparent 26%, transparent 74%, rgba(216,109,134,.18));
  overflow:hidden; }
.scene-stage::after { content:""; position:absolute; left:16px; right:16px; bottom:17px; height:7px;
  border-radius:999px; background:rgba(54,111,146,.18); }
.scene-curtain { position:absolute; top:0; bottom:0; width:35px; background:linear-gradient(180deg, rgba(216,109,134,.32), rgba(235,139,104,.16)); }
.scene-curtain--left { left:0; border-radius:14px 0 45% 14px; }
.scene-curtain--right { right:0; border-radius:0 14px 14px 45%; }
.scene-toy { position:absolute; left:50%; bottom:22px; width:36px; height:42px; transform:translateX(-50%);
  background:linear-gradient(180deg, var(--skazia-sun-soft), var(--skazia-coral)); border-radius:50% 50% 42% 42%;
  box-shadow:0 10px 18px rgba(42,54,70,.16); }
.scene-toy::before, .scene-toy::after { content:""; position:absolute; top:-6px; width:14px; height:14px;
  border-radius:50%; background:var(--skazia-sun-soft); }
.scene-toy::before { left:-5px; }
.scene-toy::after { right:-5px; }
.scene-name-tag { position:absolute; left:50%; bottom:10px; width:46px; height:12px; transform:translateX(-50%) rotate(-2deg);
  border-radius:4px; background:#fffdf7; border:1px solid rgba(55,89,108,.16); }

/* ---------- Адаптив ---------- */
@media (max-width: 760px) {
  .steps, .checkout, .upsell { grid-template-columns: 1fr; }
  .form-grid { grid-template-columns: 1fr; }
  .brand__sub { display:none; }
  .hero--landing { min-height: 0; padding: 30px 22px;
    background:
      linear-gradient(180deg, rgba(255,248,232,.96), rgba(255,248,232,.82)),
      url("assets/brand/lumos-hero-atlas-v2.png") center bottom / 125% auto no-repeat; }
  .hero--landing::after { content:""; display:block; height: 210px; }
  .moon { width:62px; height:62px; top:54px; }
  .story-scene { align-items:flex-start; gap:12px; padding:12px; }
  .scene-map, .scene-stage { flex-basis:104px; width:104px; height:78px; }
  .scene-compass { width:32px; height:32px; }
  .scene-copy span { font-size: 12px; }
}
@media (prefers-reduced-motion: reduce) {
  .stars, .twinkles span, .gen-moon, .screen, .screen > * { animation: none !important; }
}
