/* ============================================================
 * Home / index.html — лендинг Gold Apple Studio
 * ============================================================ */

/* ---------- Hero ---------- */
.home-hero {
  position: relative;
  min-height: calc(100dvh - var(--header-height));
  padding: clamp(48px, 8vw, 120px) 0 var(--space-section);
  background: var(--ga-cream);
  overflow: clip;
}

.home-hero__inner {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--space-12);
  align-items: end;
}
.home-hero__inner > * { min-width: 0; }

/* Two-column hero kicks in earlier (≥900px). Visual is the dominant column
   (~1.5× wider) — заказчик хочет акцент на before/after, но title не должен
   биться о soiное-карточкой визуала. */
@media (min-width: 900px) {
  .home-hero__inner {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.5fr);
    gap: var(--space-8);
  }
}
@media (min-width: 1280px) {
  .home-hero__inner {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.3fr);
    gap: var(--space-10);
  }
}

.home-hero__title {
  font-family: var(--ga-display-font);
  font-weight: var(--weight-black);
  /* Меньший базовый шрифт — теперь visual-колонка шире, content-column 1fr на 1080px
     контейнере ≈ 420px. «за 10 минут» (~11 символов nowrap) должно влезать. */
  font-size: clamp(36px, 3.4vw, 52px);
  line-height: 1.06;
  letter-spacing: var(--track-tight);
  text-transform: uppercase;
  color: var(--ga-black);
  display: flex;
  flex-direction: column;
  gap: 0.1em;
}
.home-hero__title .title-line {
  display: block;
  /* Каждая строка остаётся на одной — пары вроде «для каталога» не должны
     рваться. Если column всё-таки уже строки — пусть wrap, без agressive break. */
  white-space: nowrap;
}
@media (max-width: 720px) {
  .home-hero__title .title-line { white-space: normal; }
  /* На узком экране line-height 1.04 слишком плотный — буквы соседних строк
     задевают друг друга. Слегка разжимаем. */
  .home-hero__title {
    line-height: 1.1;
    gap: 0.14em;
    font-size: clamp(36px, 9vw, 56px);
  }
}
.home-hero__title em {
  display: inline-block;
  font-style: normal;
  background: var(--ga-lime);
  padding: 0 0.18em;
  margin: 0 0.04em 0 -0.06em;
  border-radius: var(--radius-xs);
  line-height: 1;
  vertical-align: baseline;
}

.home-hero__sub {
  margin-top: var(--space-8);
  font-size: var(--text-lg);
  max-width: 36ch;
  color: var(--ga-graphite);
  text-transform: lowercase;
}

.home-hero__cta-row {
  margin-top: var(--space-10);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
}

.home-hero__visual {
  position: relative;
  /* Wider aspect (4:3) — теперь это горизонтальная демо-стрипа, а не вертикальная карточка. */
  aspect-ratio: 4 / 3;
  border-radius: var(--radius-2xl);
  overflow: hidden;
  box-shadow: var(--shadow-elevated);
  background: var(--ga-card);
}
/* На мобильном — квадрат, чтобы before/after оба читались. */
@media (max-width: 720px) {
  .home-hero__visual {
    aspect-ratio: 1 / 1;
    margin-top: var(--space-8);
  }
}

/* ---------- Hero before/after split — static side-by-side (v4) ---------- */
.hero-baf {
  position: relative;
  width: 100%;
  height: 100%;
  display: grid;
  grid-template-rows: 1fr 1fr;
}
.hero-baf__before,
.hero-baf__after {
  position: relative;
  overflow: hidden;
  background: var(--ga-cream);
  width: 100%;
  height: 100%;
}
.hero-baf__before img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.hero-baf__after {
  display: block;
  object-fit: cover;
}
video.hero-baf__after {
  object-fit: cover;
}
.hero-baf__label {
  position: absolute;
  top: var(--space-3);
  left: var(--space-3);
  padding: var(--space-1) var(--space-3);
  background: var(--ga-cream);
  color: var(--ga-black);
  border-radius: var(--radius-pill);
  font-size: var(--text-2xs);
  font-weight: var(--weight-medium);
  letter-spacing: var(--track-caps);
  text-transform: uppercase;
  z-index: 2;
}
.hero-baf__label--after {
  background: var(--ga-lime);
  top: auto;
  bottom: var(--space-3);
}
/* Side-by-side at ≥600px viewport */
@media (min-width: 600px) {
  .hero-baf {
    grid-template-rows: none;
    grid-template-columns: 1fr 1fr;
  }
  .hero-baf__label--after {
    top: var(--space-3);
    bottom: auto;
    left: auto;
    right: var(--space-3);
  }
}

.home-hero__visual::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(255, 255, 255, 0.4) 0%, transparent 35%),
    radial-gradient(circle at 80% 75%, rgba(0, 0, 0, 0.08) 0%, transparent 50%);
  pointer-events: none;
}

.home-hero__mascot {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
}

/* CSS-only placeholder mascot — заменим на Spline-канвас позже */
.mascot-orb {
  width: 60%;
  aspect-ratio: 1;
  border-radius: 50%;
  background:
    radial-gradient(circle at 35% 30%, #FFFFA8 0%, var(--ga-lime) 30%, var(--ga-lime-dark) 70%, #6F8800 100%);
  box-shadow:
    inset -20px -30px 60px rgba(0, 0, 0, 0.25),
    inset 12px 18px 40px rgba(255, 255, 255, 0.55),
    0 30px 60px rgba(0, 0, 0, 0.18);
  position: relative;
  animation: orb-float 6s var(--ease-in-out) infinite;
}
.mascot-orb::before,
.mascot-orb::after {
  content: "";
  position: absolute;
  background: var(--ga-black);
  border-radius: 50%;
}
.mascot-orb::before {
  width: 14%;
  aspect-ratio: 1;
  top: 38%;
  left: 30%;
  box-shadow: inset 2px 2px 4px rgba(255, 255, 255, 0.4);
}
.mascot-orb::after {
  width: 14%;
  aspect-ratio: 1;
  top: 38%;
  right: 30%;
  box-shadow: inset 2px 2px 4px rgba(255, 255, 255, 0.4);
}

@keyframes orb-float {
  0%, 100% { transform: translateY(0) rotate(-2deg); }
  50%      { transform: translateY(-2.5%) rotate(2deg); }
}

.mascot-sparkle {
  position: absolute;
  font-family: var(--ga-display-font);
  font-weight: var(--weight-black);
  font-size: 32px;
  color: var(--ga-white);
  opacity: 0.9;
  animation: sparkle 3s var(--ease-in-out) infinite;
}
.mascot-sparkle--a { top: 14%; left: 18%; animation-delay: 0s; }
.mascot-sparkle--b { top: 22%; right: 14%; animation-delay: 0.6s; font-size: 22px; }
.mascot-sparkle--c { bottom: 18%; left: 22%; animation-delay: 1.2s; font-size: 26px; }
.mascot-sparkle--d { bottom: 28%; right: 16%; animation-delay: 1.8s; }

@keyframes sparkle {
  0%, 100% { opacity: 0.4; transform: scale(0.8); }
  50%      { opacity: 1; transform: scale(1.1) rotate(15deg); }
}

@media (prefers-reduced-motion: reduce) {
  .mascot-orb, .mascot-sparkle { animation: none; }
}

/* ---------- Stats row ---------- */
.home-stats {
  background: var(--ga-lime);
  padding-block: clamp(48px, 6vw, 80px);
}
.home-stats__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-8) var(--space-12);
}
@media (min-width: 720px) {
  .home-stats__grid { grid-template-columns: repeat(4, 1fr); }
}

/* ---------- Process / 3-step ---------- */
.home-process {
  padding-block: var(--space-section);
}
.home-process__title {
  font-family: var(--ga-display-font);
  font-weight: var(--weight-black);
  font-size: var(--text-display-md);
  text-transform: uppercase;
  line-height: 0.96;
  letter-spacing: var(--track-tight);
  margin-bottom: var(--space-12);
  text-align: center;
}
.home-process__steps {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}
@media (min-width: 720px) {
  .home-process__steps {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-8);
  }
}
.process-step {
  background: var(--ga-card);
  border-radius: var(--radius-xl);
  padding: var(--card-pad-lg);
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  min-height: 320px;
}
.process-step__num {
  font-family: var(--ga-display-font);
  font-weight: var(--weight-black);
  font-size: var(--text-display-md);
  line-height: 0.85;
  letter-spacing: var(--track-tight);
  color: var(--ga-black);
}
.process-step__title {
  font-size: var(--text-2xl);
  font-weight: var(--weight-medium);
  text-transform: lowercase;
  line-height: var(--leading-snug);
}
.process-step__desc {
  margin-top: auto;
  font-size: var(--text-base);
  color: var(--ga-graphite);
  text-transform: lowercase;
}

/* ---------- Before/After teaser ---------- */
.home-baf {
  padding-block: var(--space-section);
  background: var(--ga-black);
  color: var(--ga-white);
}
.home-baf__title {
  font-family: var(--ga-display-font);
  font-weight: var(--weight-black);
  font-size: clamp(32px, 5vw, 64px);
  text-transform: uppercase;
  line-height: 0.96;
  letter-spacing: var(--track-tight);
  text-align: center;
  margin-bottom: var(--space-12);
  word-break: break-word;
  overflow-wrap: anywhere;
}
.home-baf__title em {
  font-style: normal;
  color: var(--ga-lime);
}

/* baf-slider стили перенесены в components.css (используются на index + pitch) */

/* ---------- CTA section ---------- */
.home-cta {
  padding-block: var(--space-section);
  background: var(--ga-lime);
  text-align: center;
}
.home-cta__title {
  font-family: var(--ga-display-font);
  font-weight: var(--weight-black);
  font-size: clamp(40px, 7vw, 96px);
  text-transform: uppercase;
  line-height: 0.92;
  letter-spacing: var(--track-tight);
  color: var(--ga-black);
  max-width: 16ch;
  margin-inline: auto;
  margin-bottom: var(--space-8);
  word-break: break-word;
}

/* ---------- Reveal animation ----------
 * Безопасный дефолт: контент ВСЕГДА видим. Анимация добавляется
 * JS-ом через `.pre-reveal` (пока не используется в проде, чтобы
 * не словить FOUC если JS не загрузился). */
.reveal {
  opacity: 1;
  transform: none;
  transition:
    opacity var(--duration-cinematic) var(--ease-out-expo),
    transform var(--duration-cinematic) var(--ease-out-expo);
}
.reveal.pre-reveal {
  opacity: 0;
  transform: translateY(24px);
}
@media (prefers-reduced-motion: reduce) {
  .reveal, .reveal.pre-reveal { opacity: 1; transform: none; transition: none; }
}

/* ---------- Mobile safety ---------- */
@media (max-width: 720px) {
  .home-cta__title { font-size: clamp(32px, 9vw, 64px); }
  .home-process__title, .home-baf__title { font-size: clamp(28px, 7vw, 48px); }
  .home-stats__grid { gap: var(--space-6) var(--space-4); }
  /* .stat__value font-size — без override; используем clamp из components.css.
     При прежнем 8vw на узких экранах «видео» в 56px переносилось char-by-char. */
  .baf-slider { aspect-ratio: 1 / 1; }
}
