/* ============================================================
   style.css — Сайт-подарок для Лизы
   ------------------------------------------------------------
   СТРУКТУРА ФАЙЛА:
     1. ДИЗАЙН-СИСТЕМА (:root) — единый источник всех значений
        1.1 Цветовая палитра
        1.2 Типографика
        1.3 Отступы (spacing scale)
        1.4 Скругления
        1.5 Тени
        1.6 Анимации (длительности + easing)
        1.7 Контейнер / слои
     2. СБРОС И БАЗА
     3. ФОН (градиент + свет + частицы)
     4. КОМПОНЕНТЫ (контейнер, типографика, кнопки, карточки)
     5. КАРКАС СЦЕН
     6. СТИЛИ СЦЕН (каждая отдельным блоком)
     7. АДАПТИВНОСТЬ И ДОСТУПНОСТЬ

   ГЛАВНОЕ ПРАВИЛО: чтобы изменить внешний вид всего сайта,
   правь ТОЛЬКО переменные в блоке :root ниже.
   ============================================================ */


/* ============================================================
   1. ДИЗАЙН-СИСТЕМА
   ============================================================ */
:root {

  /* ----------------------------------------------------------
     1.1 ЦВЕТОВАЯ ПАЛИТРА
     Спокойные пастельные тона: молочный, кремовый, бежевый,
     персиковый, пыльно-розовый. Акценты — мягкое золото и
     графит. Никакого чистого чёрного и кислотных цветов.
     ---------------------------------------------------------- */
  --color-bg:            #F8F6F2;  /* основной фон — молочный        */
  --color-bg-secondary:  #F1ECE4;  /* вторичный фон — светло-бежевый */
  --color-surface:       #FFFFFF;  /* поверхность карточек — тёплый белый */
  --color-surface-glass: rgba(255, 255, 255, 0.62); /* стеклянная карточка */

  --color-text:          #3B3833;  /* основной текст — глубокий графит */
  --color-text-secondary:#8A857D;  /* вторичный текст — тёплый серый   */

  --color-accent:        #C9A96A;  /* акцент — мягкое золото           */
  --color-accent-soft:   #E7D9BC;  /* светлое золото для фонов/границ  */
  --color-peach:         #F3DCD0;  /* нежно-персиковый                 */
  --color-rose:          #E4C4C0;  /* пыльно-розовый                   */

  --color-button:        #C9A96A;  /* фон кнопки                       */
  --color-button-hover:  #B8975A;  /* фон кнопки при наведении/нажатии */
  --color-button-text:   #FFFFFF;  /* текст на кнопке                  */

  --color-border:        rgba(59, 56, 51, 0.10); /* мягкие границы     */
  --color-shadow:        rgba(80, 70, 55, 0.16);  /* тон теней (тёплый) */


  /* ----------------------------------------------------------
     1.2 ТИПОГРАФИКА
     Заголовки — serif (Cormorant Garamond), тело — sans-serif
     (Inter). Размеры заданы через clamp() для плавного
     масштабирования на любом экране (min, предпочт., max).
     Для каждого уровня: размер / высота строки / насыщенность.
     ---------------------------------------------------------- */
  --font-display: "Cormorant Garamond", Georgia, serif; /* заголовки */
  --font-body:    "Inter", -apple-system, BlinkMacSystemFont, sans-serif; /* текст */

  /* Display — самый крупный (имя на вступлении) */
  --fs-display:   clamp(3.25rem, 12vw, 5rem);
  --lh-display:   1.05;
  --fw-display:   500;

  /* H1 */
  --fs-h1:        clamp(2.25rem, 8vw, 3.25rem);
  --lh-h1:        1.15;
  --fw-h1:        500;

  /* H2 */
  --fs-h2:        clamp(1.75rem, 6vw, 2.5rem);
  --lh-h2:        1.2;
  --fw-h2:        500;

  /* H3 */
  --fs-h3:        clamp(1.375rem, 5vw, 1.75rem);
  --lh-h3:        1.3;
  --fw-h3:        500;

  /* Body Large — крупный текст сцен (мысли, атмосфера) */
  --fs-body-lg:   clamp(1.25rem, 4.6vw, 1.5rem);
  --lh-body-lg:   1.6;
  --fw-body-lg:   400;

  /* Body — основной текст (письмо) */
  --fs-body:      clamp(1.0625rem, 4vw, 1.1875rem);
  --lh-body:      1.75;
  --fw-body:      400;

  /* Small — вспомогательный */
  --fs-small:     clamp(0.9375rem, 3.4vw, 1rem);
  --lh-small:     1.5;
  --fw-small:     400;

  /* Caption — подсказки, мелкий текст */
  --fs-caption:   0.8125rem;
  --lh-caption:   1.4;
  --fw-caption:   500;

  /* Межбуквенные интервалы */
  --ls-tight:    -0.02em;  /* для крупных заголовков */
  --ls-normal:    0;
  --ls-wide:      0.08em;   /* для подписей капсом    */


  /* ----------------------------------------------------------
     1.3 ОТСТУПЫ (единая шкала)
     Все paddings/margins/gap берутся ТОЛЬКО отсюда.
     ---------------------------------------------------------- */
  --space-1:  4px;
  --space-2:  8px;
  --space-3:  12px;
  --space-4:  16px;
  --space-5:  24px;
  --space-6:  32px;
  --space-7:  48px;
  --space-8:  64px;


  /* ----------------------------------------------------------
     1.4 СКРУГЛЕНИЯ
     ---------------------------------------------------------- */
  --radius-sm:   12px;  /* маленький — мелкие элементы      */
  --radius-md:   16px;  /* средний — карточки, кнопки       */
  --radius-lg:   24px;  /* большой — крупные блоки          */
  --radius-full: 999px; /* полное — пилюли-кнопки           */


  /* ----------------------------------------------------------
     1.5 ТЕНИ (три уровня глубины, тёплый тон)
     ---------------------------------------------------------- */
  --shadow-sm: 0 2px 8px var(--color-shadow);
  --shadow-md: 0 8px 24px var(--color-shadow);
  --shadow-lg: 0 20px 50px var(--color-shadow);


  /* ----------------------------------------------------------
     1.6 АНИМАЦИИ (длительности + easing)
     Спокойные движения. Все переходы используют эти значения.
     ---------------------------------------------------------- */
  --dur-instant: 0.15s; /* очень быстрая — отклик нажатия   */
  --dur-fast:    0.3s;  /* быстрая                          */
  --dur-normal:  0.7s;  /* стандартная                      */
  --dur-slow:    1.3s;  /* медленная — переходы сцен, появление */

  --ease-out:  cubic-bezier(0.22, 0.61, 0.36, 1);  /* мягкое торможение */
  --ease-soft: cubic-bezier(0.45, 0, 0.15, 1);      /* плавный вход-выход */


  /* ----------------------------------------------------------
     1.7 КОНТЕЙНЕР И СЛОИ
     Единая ширина контента и боковые отступы для всех сцен.
     ---------------------------------------------------------- */
  --container-width: 560px;               /* макс. ширина контента */
  --container-pad:   var(--space-5);       /* боковые отступы       */

  --z-bg:      0;   /* фон           */
  --z-scene:   1;   /* сцены         */
  --z-overlay: 10;  /* конфетти и т.п.*/

  /* Реальная высота экрана (уточняется в script.js для iOS) */
  --app-height: 100dvh;
}


/* ============================================================
   2. СБРОС И БАЗА
   ============================================================ */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html,
body {
  height: 100%;
}

body {
  background: var(--color-bg);
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  -webkit-tap-highlight-color: transparent;
  overflow-x: hidden;             /* нет горизонтального скролла */
  overscroll-behavior: none;
}

button {
  font: inherit;
  color: inherit;
  cursor: pointer;
  border: none;
  background: none;
}


/* ============================================================
   3. ФОН
   Мягкий градиент + два световых пятна + слой частиц (canvas
   в script.js рисует edва заметные точки). Не отвлекает от текста.
   ============================================================ */
.background {
  position: fixed;
  inset: 0;
  z-index: var(--z-bg);
  pointer-events: none;
  overflow: hidden;
  background:
    radial-gradient(120% 90% at 50% 0%, var(--color-bg-secondary) 0%, var(--color-bg) 55%);
}

/* Мягкие световые пятна — создают глубину слоями */
.background__glow {
  position: absolute;
  border-radius: 50%;
  filter: blur(90px);
  opacity: 0.55;
}
.background__glow--peach {
  width: 70vw; height: 70vw;
  max-width: 520px; max-height: 520px;
  top: -10%; left: -15%;
  background: var(--color-peach);
}
.background__glow--rose {
  width: 60vw; height: 60vw;
  max-width: 460px; max-height: 460px;
  bottom: -12%; right: -18%;
  background: var(--color-rose);
  opacity: 0.4;
}

/* Частицы — очень лёгкие, поверх свечения */
#particles {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: 0.5;
}


/* ============================================================
   4. КОМПОНЕНТЫ
   ============================================================ */

/* ----- 4.1 Контейнер страницы (единый для всех сцен) ----- */
.container {
  width: 100%;
  max-width: var(--container-width);
  margin: 0 auto;
  padding-left: var(--container-pad);
  padding-right: var(--container-pad);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--space-6);
}

/* ----- 4.2 Типографика (классы-роли) ----- */
.text-display {
  font-family: var(--font-display);
  font-size: var(--fs-display);
  line-height: var(--lh-display);
  font-weight: var(--fw-display);
  letter-spacing: var(--ls-tight);
}
.text-h2 {
  font-family: var(--font-display);
  font-size: var(--fs-h2);
  line-height: var(--lh-h2);
  font-weight: var(--fw-h2);
}
.text-body-lg {
  font-family: var(--font-body);
  font-size: var(--fs-body-lg);
  line-height: var(--lh-body-lg);
  font-weight: var(--fw-body-lg);
  color: var(--color-text-secondary);
}
.text-caption {
  font-size: var(--fs-caption);
  line-height: var(--lh-caption);
  font-weight: var(--fw-caption);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--color-text-secondary);
}

/* ----- 4.3 Кнопка (единый компонент для всего сайта) -----
   Состояния: обычное, hover, active (нажатие), focus, disabled. */
.btn {
  /* размеры — крупная, удобная для пальца */
  min-height: 56px;
  padding: var(--space-4) var(--space-7);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);

  /* вид — дорогой, скруглённый, с мягкой тенью */
  background: var(--color-button);
  color: var(--color-button-text);
  font-size: var(--fs-small);
  font-weight: 600;
  letter-spacing: 0.01em;
  border-radius: var(--radius-full);
  box-shadow: var(--shadow-sm);

  /* плавные переходы всех состояний */
  transition:
    transform var(--dur-instant) var(--ease-out),
    background var(--dur-fast) var(--ease-out),
    box-shadow var(--dur-fast) var(--ease-out),
    opacity var(--dur-fast) var(--ease-out);
}
/* наведение (десктоп) */
@media (hover: hover) {
  .btn:hover {
    background: var(--color-button-hover);
    box-shadow: var(--shadow-md);
    transform: translateY(-1px);
  }
}
/* нажатие — лёгкое уменьшение */
.btn:active {
  transform: scale(0.97);
  box-shadow: var(--shadow-sm);
}
/* фокус — видимая рамка для доступности */
.btn:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 3px;
}
/* неактивная */
.btn:disabled {
  opacity: 0.45;
  cursor: default;
  transform: none;
  box-shadow: none;
}
/* вторичная (прозрачная) кнопка */
.btn--ghost {
  background: transparent;
  color: var(--color-text-secondary);
  box-shadow: none;
  border: 1px solid var(--color-border);
}
@media (hover: hover) {
  .btn--ghost:hover {
    background: var(--color-surface-glass);
    color: var(--color-text);
    box-shadow: none;
    transform: none;
  }
}

/* ----- 4.4 Карточка (единый компонент) -----
   Эффект светлой бумаги / полупрозрачного стекла.
   Используется для сообщений, мыслей, блоков. */
.card {
  width: 100%;
  padding: var(--space-7) var(--space-6);
  background: var(--color-surface-glass);
  border: 1px solid rgba(255, 255, 255, 0.7);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  backdrop-filter: blur(14px) saturate(1.1);
  -webkit-backdrop-filter: blur(14px) saturate(1.1);
}


/* ----------------------------------------------------------
   Анимация появления (Blur -> Sharp + Fade + Slide)
   Класс .reveal ставит стартовое состояние, .reveal--show —
   конечное. Используется во всех сценах единообразно.
   ---------------------------------------------------------- */
.reveal {
  opacity: 0;
  transform: translateY(16px) scale(0.99);
  filter: blur(8px);
  transition:
    opacity var(--dur-slow) var(--ease-out),
    transform var(--dur-slow) var(--ease-out),
    filter var(--dur-slow) var(--ease-out);
}
.reveal--show {
  opacity: 1;
  transform: translateY(0) scale(1);
  filter: blur(0);
}


/* ============================================================
   5. КАРКАС СЦЕН
   Все сцены лежат друг на друге; видна только активная.
   Переход между сценами — плавный fade.
   ============================================================ */
.scene {
  position: fixed;
  inset: 0;
  z-index: var(--z-scene);
  display: flex;
  align-items: center;
  justify-content: center;

  /* вертикальные отступы + безопасные зоны iPhone */
  padding-top:    calc(var(--space-6) + env(safe-area-inset-top));
  padding-bottom: calc(var(--space-6) + env(safe-area-inset-bottom));
  padding-left:   env(safe-area-inset-left);
  padding-right:  env(safe-area-inset-right);

  /* Плавный «кинематографический» переход: сцена не просто
     гаснет, а мягко всплывает снизу и приближается.
     Это создаёт ощущение путешествия, а не смены слайдов. */
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(24px) scale(0.985);
  transition:
    opacity var(--dur-slow) var(--ease-soft),
    transform var(--dur-slow) var(--ease-soft),
    visibility var(--dur-slow) var(--ease-soft);
}
.scene--active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0) scale(1);
}
/* Сцена, которая уходит — чуть вглубь и вверх (ощущение глубины) */
.scene--leaving {
  transform: translateY(-24px) scale(0.985);
}

/* Сцена с прокруткой (письмо) */
.scene--scroll {
  align-items: stretch;
}
.scene--scroll .container {
  max-height: 100%;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  justify-content: flex-start;
  padding-top: var(--space-7);
  padding-bottom: var(--space-7);
  scrollbar-width: none;
}
.scene--scroll .container::-webkit-scrollbar { display: none; }


/* ============================================================
   6. СТИЛИ СЦЕН (каждая — отдельным блоком)
   ============================================================ */

/* ----- Сцена 1: Вступление ----- */
.intro__subtitle { color: var(--color-text-secondary); }

/* ----- Сцены 2,3: сообщение и мысли (карточки) ----- */
.lines {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}
.lines .card p {
  font-family: var(--font-display);
  font-size: var(--fs-h3);
  line-height: var(--lh-h3);
  color: var(--color-text);
}

/* ----- Сцена 4: Атмосфера ----- */
.atmosphere__line {
  font-family: var(--font-display);
  font-size: var(--fs-h2);
  line-height: var(--lh-h2);
  color: var(--color-text);
  max-width: 20ch;
}

/* ----- Сцена 5: Конверт (главный объект) ----- */
.envelope-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-6);
}
.envelope {
  position: relative;
  width: min(76vw, 320px);
  aspect-ratio: 3 / 2;
  perspective: 1400px;
  transition: transform var(--dur-normal) var(--ease-out);
}
@media (hover: hover) {
  .envelope:hover { transform: translateY(-4px); }
}
.envelope:active { transform: scale(0.99); }
.envelope:focus-visible { outline: 2px solid var(--color-accent); outline-offset: 8px; border-radius: var(--radius-md); }

/* тень под конвертом — объём */
.envelope__shadow {
  position: absolute;
  left: 50%; bottom: -8%;
  width: 78%; height: 14%;
  transform: translateX(-50%);
  background: radial-gradient(ellipse at center, var(--color-shadow), transparent 72%);
  filter: blur(10px);
}
/* корпус конверта — плотная бумага */
.envelope__body {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(160deg, #FBF7EF 0%, #F0E7D6 100%);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-md), inset 0 0 40px rgba(160, 140, 105, 0.10);
}
/* лист письма внутри (выезжает при открытии) */
.envelope__letter {
  position: absolute;
  inset: 8% 8% auto 8%;
  height: 84%;
  background: linear-gradient(180deg, #FFFFFF 0%, #FBF7EF 100%);
  border-radius: var(--radius-sm);
  box-shadow: 0 4px 14px rgba(120, 100, 70, 0.14);
  transform: translateY(0);
  transition: transform var(--dur-slow) var(--ease-out);
  z-index: 1;
}
/* передняя стенка (карман) — прячет нижнюю часть листа */
.envelope__front {
  position: absolute;
  inset: 0;
  z-index: 2;
  background: linear-gradient(160deg, #F4EBD9 0%, #E8DCC4 100%);
  clip-path: polygon(0 34%, 50% 100%, 100% 34%, 100% 100%, 0 100%);
  border-radius: var(--radius-sm);
  box-shadow: inset 0 6px 20px rgba(160, 140, 105, 0.14);
}
/* клапан сверху — открывается */
.envelope__flap {
  position: absolute;
  inset: 0;
  z-index: 4;
  transform-origin: top center;
  background: linear-gradient(160deg, #F7F0E1 0%, #ECE0C9 100%);
  clip-path: polygon(0 0, 100% 0, 50% 62%);
  border-radius: var(--radius-sm) var(--radius-sm) 0 0;
  box-shadow: 0 2px 6px rgba(160, 140, 105, 0.12);
  transition: transform var(--dur-slow) var(--ease-out);
  backface-visibility: hidden;
}
/* печать */
.envelope__seal {
  position: absolute;
  top: 42%; left: 50%;
  transform: translate(-50%, -50%);
  width: 22%; aspect-ratio: 1;
  z-index: 5;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: radial-gradient(circle at 38% 32%, #D7B583, var(--color-accent) 68%, #A6884E 100%);
  color: #fff;
  font-family: var(--font-display);
  font-size: clamp(1rem, 5vw, 1.4rem);
  box-shadow: 0 3px 10px rgba(120, 90, 40, 0.35), inset 0 1px 3px rgba(255,255,255,0.4);
  transition: opacity var(--dur-fast) var(--ease-out), transform var(--dur-fast) var(--ease-out);
}
/* состояние "открыт" (класс ставит script.js) */
.envelope.is-open .envelope__flap  { transform: rotateX(176deg); }
.envelope.is-open .envelope__seal  { opacity: 0; transform: translate(-50%, -50%) scale(0.85); }
.envelope.is-open .envelope__letter { transform: translateY(-55%); }

.envelope__hint {
  animation: hintPulse 3s var(--ease-soft) infinite;
}
@keyframes hintPulse {
  0%, 100% { opacity: 0.5; }
  50%      { opacity: 1; }
}

/* ----- Сцена 6: Письмо (лист бумаги) ----- */
.letter {
  width: 100%;
  padding: var(--space-7) var(--space-6);
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  /* лёгкая текстура бумаги — едва заметные полосы света */
  background-image:
    linear-gradient(var(--color-surface), var(--color-surface)),
    repeating-linear-gradient(0deg, rgba(160,140,105,0.015) 0 28px, transparent 28px 29px);
  text-align: left;
}
.letter__salutation {
  font-family: var(--font-display);
  font-size: var(--fs-h1);
  line-height: var(--lh-h1);
  font-weight: var(--fw-h1);
  font-style: italic;
  color: var(--color-text);
  margin-bottom: var(--space-5);
}
.letter__body {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}
.letter__paragraph {
  font-family: var(--font-body);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  color: var(--color-text);
}
.letter__signature {
  margin-top: var(--space-6);
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-h3);
  color: var(--color-accent);
}
#letterButton {
  margin-top: var(--space-7);
  align-self: center;
}

/* ----- Сцена 7: Финал ----- */
.final__lines {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}
.final__lines p {
  font-family: var(--font-display);
  font-size: var(--fs-h2);
  line-height: var(--lh-h2);
  color: var(--color-text);
}
.final__lines p:last-child {
  color: var(--color-accent);
}

/* Слой конфетти поверх всего */
#confetti {
  position: fixed;
  inset: 0;
  z-index: var(--z-overlay);
  pointer-events: none;
}


/* ============================================================
   7. АДАПТИВНОСТЬ И ДОСТУПНОСТЬ
   ============================================================ */

/* Компактные экраны — уменьшаем боковые отступы контейнера */
@media (max-width: 360px) {
  :root { --container-pad: var(--space-4); }
}

/* Уважаем настройку «уменьшить движение» */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    transition-duration: var(--dur-fast) !important;
    animation: none !important;
  }
  .reveal { filter: none; }
}


/* ============================================================
   8. НОВЫЕ СЦЕНЫ И ЭЛЕМЕНТЫ (концепция "коробка воспоминаний")
   Все стили используют переменные дизайн-системы из :root.
   ============================================================ */

/* ----------------------------------------------------------
   8.1 ФОТО и ПЛЕЙСХОЛДЕРЫ
   Если фото нет — показывается красивая заглушка с именем
   файла. Заменишь файл в assets/images/ — появится фото.
   ---------------------------------------------------------- */
.photo {
  width: 100%;
  max-width: 300px;
  aspect-ratio: 4 / 5;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  background: var(--color-bg-secondary);
}
.photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
/* Плейсхолдер (когда фото ещё не загружено) */
.photo--placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  border: 1.5px dashed var(--color-accent-soft);
  background:
    linear-gradient(135deg, var(--color-peach) 0%, var(--color-rose) 100%);
  color: var(--color-text-secondary);
  text-align: center;
  padding: var(--space-5);
}
.photo--placeholder .photo__icon { font-size: 2rem; opacity: 0.8; }
.photo--placeholder .photo__name {
  font-size: var(--fs-caption);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  font-weight: 500;
}
.photo--placeholder .photo__hint {
  font-size: var(--fs-caption);
  opacity: 0.7;
}

/* ----------------------------------------------------------
   8.2 Сцена «Маленькие мысли» (фраза + фото)
   ---------------------------------------------------------- */
.thoughts {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-7);
  width: 100%;
}
.thought {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-5);
  width: 100%;
}
.thought__text {
  font-family: var(--font-display);
  font-size: var(--fs-h3);
  line-height: var(--lh-h3);
  color: var(--color-text);
  max-width: 22ch;
}

/* ----------------------------------------------------------
   8.4 Сцена «Собака»
   ---------------------------------------------------------- */
.dog-emoji {
  font-size: 3.5rem;
  animation: wave 2.2s var(--ease-soft) infinite;
  transform-origin: 70% 70%;
}
@keyframes wave {
  0%, 100% { transform: rotate(-6deg); }
  50%      { transform: rotate(6deg); }
}
.dog-text {
  font-family: var(--font-display);
  font-size: var(--fs-h3);
  line-height: var(--lh-h3);
  color: var(--color-text);
  max-width: 24ch;
}

/* ----------------------------------------------------------
   8.5 Сцена «Факты и статистика»
   ---------------------------------------------------------- */
.facts-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  text-align: left;
}
.facts-list li {
  list-style: none;
  font-size: var(--fs-body);
  color: var(--color-text);
  line-height: 1.5;
}
.stats-title {
  font-family: var(--font-display);
  font-size: var(--fs-h3);
  margin-bottom: var(--space-4);
  color: var(--color-text);
}
.stats-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.stats-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--space-4);
  padding-bottom: var(--space-2);
  border-bottom: 1px solid var(--color-border);
}
.stats-row:last-child { border-bottom: none; }
.stats-row__label {
  font-size: var(--fs-small);
  color: var(--color-text-secondary);
  text-align: left;
}
.stats-row__value {
  font-family: var(--font-display);
  font-size: var(--fs-h3);
  color: var(--color-accent);
  white-space: nowrap;
}

/* ----------------------------------------------------------
   8.6 Сцена «Инструкция по использованию Лизы»
   Стилизована как аккуратная карточка-документ.
   ---------------------------------------------------------- */
.manual {
  width: 100%;
  padding: var(--space-7) var(--space-6);
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  border: 1px solid var(--color-border);
  text-align: left;
}
.manual__title {
  font-family: var(--font-display);
  font-size: var(--fs-h3);
  line-height: var(--lh-h3);
  color: var(--color-text);
  text-align: center;
}
.manual__subtitle {
  font-size: var(--fs-caption);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--color-text-secondary);
  text-align: center;
  margin-top: var(--space-2);
  margin-bottom: var(--space-5);
}
.manual__divider {
  height: 1px;
  background: var(--color-border);
  margin-bottom: var(--space-5);
}
.manual__list {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.manual__list li {
  list-style: none;
  font-size: var(--fs-body);
  line-height: 1.5;
  color: var(--color-text);
}

/* ----------------------------------------------------------
   8.7 Фото внутри письма
   ---------------------------------------------------------- */
.letter__photo {
  margin: var(--space-2) auto;
}
.letter__photo .photo {
  max-width: 240px;
  aspect-ratio: 4 / 3;
}

/* ----------------------------------------------------------
   8.8 БОЛЬШОЙ ФИНАЛ
   ---------------------------------------------------------- */
.final-heart {
  font-size: 4rem;
  animation: heartBeat 1.6s var(--ease-soft) infinite;
}
@keyframes heartBeat {
  0%, 100% { transform: scale(1); }
  15%      { transform: scale(1.15); }
  30%      { transform: scale(1); }
}
.final-title {
  font-family: var(--font-display);
  font-size: var(--fs-h1);
  line-height: var(--lh-h1);
  font-weight: var(--fw-h1);
  color: var(--color-text);
  white-space: pre-line;
}
.final-subtitle {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-h3);
  color: var(--color-accent);
}

/* ----------------------------------------------------------
   8.9 ЗАТЕМНЕНИЕ (финальное завершение)
   Тёмная сцена — единственная во всём проекте.
   ---------------------------------------------------------- */
.scene--dark {
  background: #1A1714;  /* тёплый графит, не чистый чёрный */
}
.scene--dark .goodbye-text {
  font-family: var(--font-display);
  font-size: var(--fs-h2);
  line-height: var(--lh-h2);
  color: #F3ECE0;
  max-width: 20ch;
}
.goodbye-heart {
  font-size: 2rem;
  margin-top: var(--space-5);
  animation: heartBeat 1.8s var(--ease-soft) infinite;
}

/* ----------------------------------------------------------
   8.10 КОТИКИ-СЮРПРИЗЫ (сквозные)
   Появляются только когда получают класс is-visible.
   ---------------------------------------------------------- */
.cat {
  position: fixed;
  z-index: 5;
  font-size: 2.4rem;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--dur-slow) var(--ease-out),
              transform var(--dur-slow) var(--ease-out);
}
/* котёнок выглядывает из-за правого края */
.cat--peek {
  right: -10px;
  bottom: 22%;
  transform: translateX(40px) rotate(8deg);
}
.cat--peek.is-visible {
  opacity: 0.95;
  transform: translateX(0) rotate(8deg);
}
/* котёнок «спит» в левом нижнем углу */
.cat--sleep {
  left: calc(var(--space-4) + env(safe-area-inset-left));
  bottom: calc(var(--space-5) + env(safe-area-inset-bottom));
  font-size: 1.8rem;
  transform: translateY(20px);
}
.cat--sleep.is-visible {
  opacity: 0.8;
  transform: translateY(0);
}

/* ----------------------------------------------------------
   8.11 ИНТЕРЛЮДИЯ (мини-пауза с котёнком)
   ---------------------------------------------------------- */
.interlude {
  position: fixed;
  inset: 0;
  z-index: var(--z-overlay);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-5);
  background: var(--color-bg);
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--dur-normal) var(--ease-soft),
              visibility var(--dur-normal) var(--ease-soft);
  padding: var(--space-6);
  text-align: center;
}
.interlude.is-visible { opacity: 1; visibility: visible; }
.interlude__cat {
  font-size: 3rem;
  animation: catBob 1.2s var(--ease-soft) infinite;
}
@keyframes catBob {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-8px); }
}
.interlude__text {
  font-family: var(--font-display);
  font-size: var(--fs-h3);
  color: var(--color-text-secondary);
  max-width: 24ch;
}

/* ----------------------------------------------------------
   8.12 ПАСХАЛКА при бездействии (всплывающая подсказка)
   ---------------------------------------------------------- */
.idle-toast {
  position: fixed;
  left: 50%;
  bottom: calc(var(--space-7) + env(safe-area-inset-bottom));
  transform: translateX(-50%) translateY(20px);
  z-index: var(--z-overlay);
  max-width: 80%;
  padding: var(--space-3) var(--space-5);
  background: var(--color-surface);
  color: var(--color-text);
  font-size: var(--fs-small);
  border-radius: var(--radius-full);
  box-shadow: var(--shadow-md);
  border: 1px solid var(--color-border);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity var(--dur-normal) var(--ease-out),
              transform var(--dur-normal) var(--ease-out),
              visibility var(--dur-normal) var(--ease-out);
  text-align: center;
}
.idle-toast.is-visible {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
}

/* Компактные экраны: карточки интересов в один столбец не нужны,
   но фото и текст чуть уже */
@media (max-width: 360px) {
  .photo { max-width: 260px; }
}


/* ============================================================
   9. ОБНОВЛЕНИЯ (welcome, декор, финальная галерея)
   ============================================================ */

/* ----------------------------------------------------------
   9.1 Сцена «Инструкция по прохождению» (задаёт настроение)
   ---------------------------------------------------------- */
.welcome-card {
  width: 100%;
  padding: var(--space-7) var(--space-6);
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  border: 1px solid var(--color-border);
  text-align: center;
}
.welcome-card__emoji { font-size: 2.6rem; margin-bottom: var(--space-4); }
.welcome-card__title {
  font-family: var(--font-display);
  font-size: var(--fs-h2);
  line-height: var(--lh-h2);
  color: var(--color-text);
  margin-bottom: var(--space-5);
}
.welcome-card__list {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  text-align: left;
  max-width: 22rem;
  margin: 0 auto;
}
.welcome-card__list li {
  list-style: none;
  font-size: var(--fs-body);
  line-height: 1.5;
  color: var(--color-text);
  /* каждый пункт мягко проявляется по очереди (класс из JS) */
  opacity: 0;
  transform: translateX(-8px);
  transition: opacity var(--dur-slow) var(--ease-out),
              transform var(--dur-slow) var(--ease-out);
}
.welcome-card__list li.is-in {
  opacity: 1;
  transform: translateX(0);
}

/* ----------------------------------------------------------
   9.2 ПЛАВАЮЩИЙ ДЕКОР (сердечки, звёзды, цветы)
   Единый стиль (SVG-спрайты). Появляется умеренно, медленно
   плывёт вверх и мягко покачивается. Не отвлекает.
   ---------------------------------------------------------- */
.decor-layer {
  position: absolute;
  inset: 0;
  overflow: hidden;
}
.decor {
  position: absolute;
  color: var(--color-accent);       /* цвет задаётся индивидуально в JS */
  opacity: 0;
  animation:
    decorFloat var(--decor-dur, 16s) linear infinite,
    decorFade 2s var(--ease-out) forwards;
  animation-delay: var(--decor-delay, 0s);
  will-change: transform, opacity;
}
.decor svg { display: block; }
@keyframes decorFloat {
  0%   { transform: translateY(0) translateX(0) rotate(0deg); }
  50%  { transform: translateY(-50vh) translateX(12px) rotate(8deg); }
  100% { transform: translateY(-100vh) translateX(0) rotate(0deg); }
}
@keyframes decorFade {
  to { opacity: var(--decor-opacity, 0.5); }
}

/* Небольшой статичный декор рядом с карточками (акценты) */
.decor-accent {
  display: inline-flex;
  color: var(--color-rose);
  vertical-align: middle;
}

/* ----------------------------------------------------------
   9.3 ФИНАЛЬНАЯ ГАЛЕРЕЯ (коллаж из фото в финале)
   ---------------------------------------------------------- */
.final-gallery {
  display: flex;
  gap: var(--space-4);
  justify-content: center;
  flex-wrap: wrap;
  width: 100%;
}
.final-gallery .photo {
  max-width: 150px;
  aspect-ratio: 3 / 4;
  /* лёгкий наклон для «живого» коллажа */
  box-shadow: var(--shadow-md);
}
.final-gallery .photo:nth-child(odd)  { transform: rotate(-3deg); }
.final-gallery .photo:nth-child(even) { transform: rotate(3deg); }

/* ----------------------------------------------------------
   9.4 Декоративная рамка-уголки у плейсхолдеров фото
   (делает пустые места нарядными, а не «пустыми»)
   ---------------------------------------------------------- */
.photo--placeholder .photo__deco {
  position: absolute;
  color: var(--color-accent);
  opacity: 0.5;
}
.photo--placeholder { position: relative; }
