/* ============================================================
   THE DREAM STATE — Homepage
   A guided scroll story. The background field resolves from
   scattered traffic into an engineered journey as you read.
   ============================================================ */

/* ---------- Fixed living background ---------- */
#home-field{ position:fixed; inset:0; z-index:0; pointer-events:none; }
.home-aura{ position:fixed; inset:0; z-index:0; pointer-events:none; transition:background 1.2s ease;
  background:
    radial-gradient(60vw 60vw at 16% 6%, color-mix(in srgb, var(--home-glow,#57156E) 55%, transparent), transparent 60%),
    radial-gradient(50vw 50vw at 88% 90%, color-mix(in srgb, var(--home-glow,#270030) 40%, transparent), transparent 62%); }
.bg-grain{ z-index:1; }

/* ---------- Shared act rhythm ---------- */
.act{ position:relative; min-height:88svh; display:flex; align-items:center; padding:var(--s-7) 0; }
.act.short{ min-height:auto; padding:var(--s-7) 0; }
.act .wrap{ width:100%; }
.act-center{ max-width:920px; margin:0 auto; text-align:center; }

.kicker{ display:inline-flex; align-items:center; gap:.6em; font-family:var(--mono); font-size:.72rem;
  letter-spacing:.26em; text-transform:uppercase; color:var(--gold-2); margin-bottom:var(--s-3); }
.kicker::before,.kicker::after{ content:""; width:24px; height:1px; background:var(--gold); opacity:.6; }

/* Big editorial statements (the memorable moments) */
.statement{ font-family:var(--display); font-weight:320; color:var(--white);
  font-size:clamp(2.1rem,5.6vw,4.3rem); line-height:1.04; letter-spacing:-.015em; }
.statement em{ font-style:italic; color:var(--gold-2); }
.statement .shine{ }
.support{ font-size:clamp(1.08rem,1.7vw,1.4rem); line-height:1.6; color:var(--cream);
  max-width:60ch; margin:var(--s-4) auto 0; }
.support.tight{ max-width:54ch; }

/* ---------- Hero ---------- */
.home-hero{ position:relative; min-height:100svh; display:flex; align-items:center; text-align:center; padding:6rem 0 3rem; }
.home-hero .wrap{ max-width:940px; margin:0 auto; }
.home-hero h1{ font-size:clamp(2.9rem,8vw,6.4rem); line-height:.98; letter-spacing:-.02em; }
.home-hero h1 em{ font-style:italic; color:var(--gold-2); }
.home-hero .hsub{ font-size:clamp(1.1rem,1.9vw,1.5rem); color:var(--cream); max-width:50ch; margin:var(--s-4) auto 0; line-height:1.55; }
.home-cta{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-top:var(--s-5); }
.home-micro{ font-family:var(--mono); font-size:.74rem; letter-spacing:.06em; color:var(--mist-2); margin-top:16px; }
.scrollcue{ position:absolute; left:50%; bottom:26px; transform:translateX(-50%); display:flex; flex-direction:column;
  align-items:center; gap:8px; font-family:var(--mono); font-size:.6rem; letter-spacing:.22em; text-transform:uppercase; color:var(--mist-2); }
.scrollcue .m{ width:22px; height:34px; border:1px solid var(--line); border-radius:12px; position:relative; }
.scrollcue .m::after{ content:""; position:absolute; left:50%; top:7px; transform:translateX(-50%); width:3px; height:7px;
  border-radius:3px; background:var(--gold); animation:cueDrop 1.8s ease-in-out infinite; }
@keyframes cueDrop{ 0%,100%{ opacity:0; top:7px } 40%{ opacity:1 } 70%{ opacity:0; top:18px } }

/* ---------- Mega proof ---------- */
.proof .num{ font-family:var(--display); font-weight:300; line-height:.9; letter-spacing:-.03em;
  font-size:clamp(3.6rem,15vw,12rem);
  background:linear-gradient(100deg,var(--gold-deep),var(--gold-3) 42%,var(--gold) 60%,var(--gold-deep));
  background-size:200% auto; -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent;
  color:transparent; animation:shineMove 7s linear infinite; }
.proof-stats{ display:flex; flex-wrap:wrap; gap:var(--s-5); justify-content:center; margin-top:var(--s-5); }
.proof-stats .ps{ text-align:center; }
.proof-stats .ps b{ font-family:var(--display); font-size:clamp(1.8rem,4vw,2.6rem); color:var(--white); display:block; line-height:1; }
.proof-stats .ps span{ font-family:var(--mono); font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; color:var(--mist-2); margin-top:.6rem; display:block; }
.proof-stats .ps .sep{ }

/* ---------- Pillars (compact, readable) ---------- */
.pillars{ display:grid; gap:16px; grid-template-columns:1fr; }
@media(min-width:640px){ .pillars{ grid-template-columns:repeat(2,1fr); } }
@media(min-width:980px){ .pillars{ grid-template-columns:repeat(4,1fr); } }
.pillar{ border:1px solid var(--line-2); border-radius:16px; padding:var(--s-4);
  background:linear-gradient(165deg, rgba(19,14,26,.7), rgba(10,8,14,.7)); backdrop-filter:blur(4px);
  transition:transform .4s var(--ease), border-color .4s; }
.pillar:hover{ transform:translateY(-5px); border-color:var(--line); }
.pillar .pk{ font-family:var(--mono); font-size:.62rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); }
.pillar h4{ margin:.5rem 0 .5rem; font-size:1.08rem; }
.pillar p{ font-size:.9rem; color:var(--mist); }

/* ---------- Who-for checklist ---------- */
.fitlist{ display:grid; gap:14px; max-width:680px; margin:var(--s-4) auto 0; text-align:left; }
.fitrow{ display:flex; align-items:flex-start; gap:14px; padding:1rem 1.2rem; border:1px solid var(--line-2);
  border-radius:14px; background:rgba(19,14,26,.55); backdrop-filter:blur(4px); }
.fitrow .ck{ flex:0 0 auto; width:26px; height:26px; border-radius:8px; background:linear-gradient(135deg,var(--gold),var(--gold-deep));
  color:#1c0024; display:flex; align-items:center; justify-content:center; font-size:.9rem; }
.fitrow b{ color:#fff; } .fitrow span{ color:var(--mist); }

/* ---------- Reviews ---------- */
.home-reviews{ display:grid; gap:18px; grid-template-columns:1fr; }
@media(min-width:860px){ .home-reviews{ grid-template-columns:repeat(3,1fr); } }

/* ---------- Final CTA ---------- */
.home-final{ text-align:center; }
.home-final h2{ font-size:clamp(2.6rem,8vw,6rem); line-height:.98; }

/* ---------- Reveal ---------- */
.up{ opacity:0; transform:translateY(40px); transition:opacity 1s var(--ease), transform 1s var(--ease); }
.up.in{ opacity:1; transform:none; }
.up.d1{ transition-delay:.08s } .up.d2{ transition-delay:.16s } .up.d3{ transition-delay:.24s } .up.d4{ transition-delay:.32s }

/* readability over the art-journey background */
.home-hero h1, .home-hero .hsub, .statement, .support, .proof .num, .home-final h2,
.kicker, .pillar, .fitrow, .review{ text-shadow:0 2px 26px rgba(8,6,12,.55); }
.pillar, .fitrow, .review{ text-shadow:none; }

@media (prefers-reduced-motion: reduce){
  #home-field{ opacity:.7; }
  .up{ opacity:1; transform:none; }
  .scrollcue .m::after{ animation:none; }
  .proof .num{ animation:none; }
}
