/* =============================================================================
   Home page (M2). Home-specific layout: hero + the cinematic phone-frame demo
   reel + value-strip grid. Shared components (cards, steps, bands, section
   headers) live in components.css. Reduced-motion handled at the end.
   ========================================================================== */

/* =============================================================================
   HERO
   ========================================================================== */
.hero {
  position: relative;
  overflow: hidden;
  padding-block: clamp(72px, 12vw, 140px);
}
.hero__grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  align-items: center;
  gap: clamp(var(--space-8), 6vw, var(--space-24));
}
.hero__wordmark {
  font-size: clamp(3.4rem, 11vw, 7rem);
  letter-spacing: 0.12em;
  margin: 0 0 var(--space-2);
  background: linear-gradient(180deg, var(--star-light), var(--gold) 70%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.hero__tagline {
  font-family: var(--font-display);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--gold-light);
  font-size: clamp(1.05rem, 2.4vw, 1.5rem);
  margin-bottom: var(--space-6);
}
.hero__sub { max-width: 46ch; }
.hero__cta { display: flex; gap: var(--space-4); flex-wrap: wrap; margin-top: var(--space-8); }
.hero__trust { font-size: 0.85rem; margin-top: var(--space-6); letter-spacing: 0.02em; }
.hero__media { display: flex; justify-content: center; }

@media (max-width: 920px) {
  .hero__grid { grid-template-columns: 1fr; text-align: center; }
  .hero__sub { margin-inline: auto; }
  .hero__cta { justify-content: center; }
  .hero__media { order: -1; }
}

/* =============================================================================
   PHONE FRAME + DEMO REEL
   ========================================================================== */
.phone {
  position: relative;
  width: clamp(240px, 62vw, 300px);
  aspect-ratio: 9 / 18;
  background: #05070f;
  border-radius: 38px;
  padding: 10px;
  border: 1px solid var(--gold-hairline);
  box-shadow:
    0 0 0 2px rgba(0, 0, 0, 0.6),
    0 30px 80px -30px rgba(0, 0, 0, 0.9),
    0 0 80px -30px var(--ember-glow);
}
.phone__notch {
  position: absolute;
  top: 14px;
  left: 50%;
  transform: translateX(-50%);
  width: 38%;
  height: 18px;
  background: #05070f;
  border-radius: 0 0 12px 12px;
  z-index: 4;
}
.reel-stage {
  position: relative;
  width: 100%;
  height: 100%;
  border-radius: 30px;
  overflow: hidden;
  background: var(--bg);
}
.reel-video { width: 100%; height: 100%; object-fit: cover; }

.reel-scene {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  animation: reel-cycle 12s var(--ease-cine) infinite;
  will-change: opacity, transform;
}
.reel-scene--2 { animation-delay: 4s; }
.reel-scene--3 { animation-delay: 8s; }
@keyframes reel-cycle {
  0%   { opacity: 0; transform: scale(1.04); }
  6%   { opacity: 1; }
  28%  { opacity: 1; transform: scale(1.12); }
  34%  { opacity: 0; }
  100% { opacity: 0; }
}

.reel-grain {
  position: absolute;
  inset: 0;
  z-index: 2;
  opacity: 0.10;
  pointer-events: none;
  background-image: radial-gradient(rgba(255, 255, 255, 0.7) 0.5px, transparent 0.6px);
  background-size: 3px 3px;
  mix-blend-mode: overlay;
}
.reel-letterbox { position: absolute; left: 0; right: 0; height: 9%; background: #05070f; z-index: 3; }
.reel-letterbox--top { top: 0; }
.reel-letterbox--bottom { bottom: 0; }

.reel-title {
  position: absolute;
  inset: 0;
  z-index: 3;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  text-align: center;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.9), 0 2px 20px rgba(0, 0, 0, 0.7);
  /* soft dark wash behind the text so pale Cinzel reads over bright skies */
  background: radial-gradient(58% 36% at 50% 50%,
    rgba(5, 7, 15, 0.66) 0%, rgba(5, 7, 15, 0.34) 55%, rgba(5, 7, 15, 0) 78%);
  animation: reel-title 12s var(--ease-cine) infinite;
}
.reel-title__eyebrow {
  font-family: var(--font-display);
  font-size: 0.7rem;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--star-light);
}
.reel-title__main {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.35rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--cream);
}
@keyframes reel-title {
  0%, 70% { opacity: 0; transform: translateY(8px); }
  80%, 96% { opacity: 1; transform: translateY(0); }
  100% { opacity: 0; }
}

.reel-progress {
  position: absolute;
  left: 12px;
  right: 12px;
  bottom: 14px;
  height: 2px;
  z-index: 4;
  background: rgba(255, 255, 255, 0.2);
  border-radius: 2px;
  overflow: hidden;
}
.reel-progress span {
  display: block;
  height: 100%;
  width: 100%;
  transform-origin: left;
  background: var(--gold-light);
  animation: reel-progress 12s linear infinite;
}
@keyframes reel-progress {
  0% { transform: scaleX(0); }
  100% { transform: scaleX(1); }
}

/* =============================================================================
   VALUE STRIP (uses shared .feature-card from components.css)
   ========================================================================== */
.showcase__more { text-align: center; margin-top: var(--space-12); }

.value-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: var(--space-4); }
@media (max-width: 980px) { .value-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .value-grid { grid-template-columns: 1fr; } }

/* =============================================================================
   Reduced motion — freeze the reel on a representative frame
   ========================================================================== */
@media (prefers-reduced-motion: reduce) {
  .reel-scene,
  .reel-title,
  .reel-progress span { animation: none !important; }
  .reel-scene--1 { opacity: 1; }
  .reel-scene--2,
  .reel-scene--3 { opacity: 0; }
  .reel-title { opacity: 1; transform: none; }
  .reel-progress span { transform: scaleX(0.4); }
}
