/* =========================================================================
   ФЛОРИДИЗ · концепт «живой холст» (v11)
   Сайт-холст, который декорируется по мере скролла.
   Палитра и шрифты — в тон проекту (Prata + Manrope).
   ВАЖНО: состояние «по умолчанию» в CSS = финальное (декор и текст видны).
   JS прячет элементы и анимирует их «из спрятанного» — так без JS/при
   reduce-motion страница выглядит уже украшенной, а не сломанной.
   ========================================================================= */

:root {
  --paper:      #F4F0E8;
  --paper-deep: #ECE6DA;
  --ink:        #1B1A17;
  --ink-soft:   #4A4640;
  --ink-mute:   #837B6E;
  --sage:       #7F8A6B;
  --sage-deep:  #5E6A4C;
  --passe:      #D8CEC0;
  --wine:       #6E3F35;
  --brass:      #B7A36F;

  --font-title: 'Prata', Georgia, 'Times New Roman', serif;
  --font-body:  'Manrope', -apple-system, 'Segoe UI', Roboto, Arial, sans-serif;

  --maxw-text: 760px;
  --ease-soft: cubic-bezier(.4, 0, .2, 1);
}

* { margin: 0; padding: 0; box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  font-family: var(--font-body);
  color: var(--ink);
  background: var(--paper);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

img { display: block; max-width: 100%; }

/* ===================== Полоса прогресса скролла ===================== */
.scroll-progress {
  position: fixed; inset: 0 0 auto 0; height: 3px; z-index: 60;
  background: transparent; pointer-events: none;
}
.scroll-progress span {
  display: block; height: 100%; width: 100%;
  transform: scaleX(0); transform-origin: left center;
  background: linear-gradient(90deg, var(--sage), var(--brass), var(--wine));
}

/* ===================== Шапка ===================== */
.header {
  position: fixed; inset: 0 0 auto 0; z-index: 50;
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px; padding: 18px clamp(20px, 5vw, 56px);
  transition: background .4s var(--ease-soft), backdrop-filter .4s, box-shadow .4s;
}
.header.is-solid {
  background: color-mix(in srgb, var(--paper) 86%, transparent);
  backdrop-filter: blur(10px) saturate(1.1);
  box-shadow: 0 1px 0 color-mix(in srgb, var(--passe) 70%, transparent);
}
.brand { display: inline-flex; align-items: center; gap: 12px; text-decoration: none; color: var(--ink); }
.brand__mark { width: 38px; height: 38px; }
.brand__txt { display: flex; flex-direction: column; line-height: 1.05; }
.brand__name { font-family: var(--font-title); font-size: 1.18rem; letter-spacing: .2px; }
.brand__tag { font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-mute); }

/* ===================== Кнопки ===================== */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--font-body); font-weight: 600; font-size: .82rem;
  letter-spacing: .04em; text-decoration: none; cursor: pointer;
  padding: 12px 22px; border-radius: 999px; border: 1px solid transparent;
  transition: transform .25s var(--ease-soft), background .25s, color .25s, border-color .25s;
}
.btn:hover { transform: translateY(-2px); }
.btn--primary { background: var(--wine); color: #fff; }
.btn--primary:hover { background: var(--wine); box-shadow: 0 10px 24px color-mix(in srgb, var(--wine) 35%, transparent); }
.btn--ghost { border-color: color-mix(in srgb, var(--ink) 28%, transparent); color: var(--ink); background: transparent; }
.btn--ghost:hover { border-color: var(--ink); }

/* ===================== Сцена (общий холст) ===================== */
.scene {
  position: relative;
  min-height: 100vh; min-height: 100svh;
  display: grid; place-items: center;
  padding: clamp(110px, 16vh, 200px) clamp(22px, 6vw, 80px);
  overflow: hidden;                 /* обрезает декор, наезжающий с краёв */
  isolation: isolate;
}

/* Градиентные холсты под смысл блока */
.scene--hero {
  background:
    radial-gradient(120% 90% at 50% 8%, #FBF8F1 0%, var(--paper) 42%, #E7E8DC 100%);
}
.scene--green {
  background:
    linear-gradient(170deg, #EAEDDF 0%, #DFE6CF 50%, #E9E4D6 100%);
}
.scene--event {
  background:
    linear-gradient(160deg, #F3ECE2 0%, #EFE0D2 48%, #E7D6CC 100%);
}
.scene--end {
  background: linear-gradient(180deg, #ECE6DA 0%, #E2DBCB 100%);
  min-height: 80vh; min-height: 80svh;
}

/* Контент поверх декора */
.scene__inner {
  position: relative; z-index: 2;
  max-width: var(--maxw-text);
  text-align: center;
}

/* ===================== Типографика сцен ===================== */
.eyebrow {
  font-size: .76rem; letter-spacing: .2em; text-transform: uppercase;
  color: var(--sage-deep); font-weight: 600; margin-bottom: 22px;
}
.eyebrow .num {
  font-family: var(--font-title); margin-right: 8px; color: var(--brass);
  letter-spacing: 0; text-transform: none;
}
.scene__title {
  font-family: var(--font-title); font-weight: 400;
  font-size: clamp(2rem, 5.2vw, 3.8rem); line-height: 1.12;
  color: var(--ink); letter-spacing: .2px;
}
.scene__title--hero { font-size: clamp(2.4rem, 7vw, 5.4rem); line-height: 1.08; }
.scene__title--sm { font-size: clamp(1.7rem, 4vw, 2.8rem); }
.scene__title .em { color: var(--wine); }

.scene__lead {
  margin-top: 26px; font-size: clamp(1rem, 1.6vw, 1.22rem);
  color: var(--ink-soft); max-width: 56ch; margin-inline: auto;
}
.scene__note {
  margin-top: 18px; font-size: .8rem; color: var(--ink-mute);
  max-width: 48ch; margin-inline: auto;
}

/* Подсказка «листайте» в hero */
.scene__cue {
  margin-top: 48px; display: inline-flex; flex-direction: column; align-items: center; gap: 12px;
  font-size: .72rem; letter-spacing: .24em; text-transform: uppercase; color: var(--ink-mute);
}
.scene__cue-line { width: 1px; height: 46px; background: linear-gradient(var(--ink-mute), transparent); }

/* Эко-список */
.eco-list {
  margin: 34px auto 0; max-width: 60ch; text-align: left;
  list-style: none; display: grid; gap: 14px;
}
.eco-list li {
  position: relative; padding-left: 26px;
  color: var(--ink-soft); font-size: clamp(.98rem, 1.4vw, 1.12rem);
}
.eco-list li::before {
  content: ""; position: absolute; left: 0; top: .62em;
  width: 9px; height: 9px; border-radius: 50%;
  background: var(--sage); box-shadow: 0 0 0 4px color-mix(in srgb, var(--sage) 22%, transparent);
}
.eco-list__k { color: var(--ink); font-weight: 600; }

/* ===================== Декорации ===================== */
.decor {
  position: absolute; z-index: 1; pointer-events: none;
  will-change: transform, opacity;
}
/* До инициализации JS (только при разрешённом движении) прячем, чтобы не мигнуло */
.js-anim .decor,
.js-anim [data-rise] { opacity: 0; }
.decor__img {
  width: 100%; height: auto;
  filter: drop-shadow(0 14px 24px rgba(40, 36, 28, .16));
  will-change: transform;
}

/* Hero bloom — canvas с живой розой (распускание из кадров видео) */
.bloom {
  position: absolute; z-index: 1; pointer-events: none;
  will-change: opacity;
}
.bloom__canvas {
  display: block; width: 100%; height: auto;
  filter: drop-shadow(0 16px 30px rgba(40, 36, 28, .20));
}

/* ===================== Подвал ===================== */
.footer {
  display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between;
  gap: 12px; padding: 28px clamp(22px, 6vw, 80px);
  background: var(--ink); color: color-mix(in srgb, #fff 80%, transparent);
  font-size: .82rem;
}
.footer__tag { color: var(--brass); letter-spacing: .08em; }

/* ===================== Мобильная адаптация ===================== */
@media (max-width: 720px) {
  .header { padding: 14px 18px; }
  .brand__tag { display: none; }
  .scene { padding-inline: 20px; }
  /* На мобильном декор компактнее, чтобы не наезжал на текст */
  .scene--hero .decor[data-decor="grow"] { width: min(26vw, 120px) !important; }
  .decor[data-decor="corner"] { width: min(58vw, 300px) !important; }
  .decor[data-decor="drift"] { width: min(26vw, 130px) !important; }
  /* Живая роза — крупнее и по центру низа, это смысловой акцент hero */
  .bloom { width: min(46vw, 230px) !important; }
}

/* ===================== Доступность ===================== */
:where(a, button):focus-visible {
  outline: 2px solid var(--wine); outline-offset: 3px; border-radius: 4px;
}

/* Если пользователь просит меньше движения — показываем украшенный статичный холст */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .decor, [data-rise] { opacity: 1 !important; transform: none !important; }
  .scroll-progress span { transform: scaleX(0); }
}
