/* ============================================================
   CodebyCarter — vision.css
   "Picture this" buying-state section.
   Bold deep-emerald palette · lime / yellow / magenta accents.
   Designed to break the visual rhythm of the rest of the site.
   ============================================================ */

.vision{
  background:
    radial-gradient(900px 500px at 25% 25%, rgba(163,230,53,.18), transparent 60%),
    radial-gradient(700px 500px at 80% 80%, rgba(236,72,153,.18), transparent 60%),
    linear-gradient(165deg, #0F2A22 0%, #163F37 45%, #0A1F1B 100%);
  color:#F5F5F7;
  padding:clamp(120px,14vw,200px) 0;
  position:relative;overflow:hidden;
  --vision-lime:#A3E635;
  --vision-yellow:#FACC15;
  --vision-magenta:#EC4899;
  --vision-teal:#22D3EE;
}

/* Subtle film-grain layer on top of the gradient */
.vision::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 .03 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  opacity:.7;
}

/* Floating dots that drift slowly across the background */
.vision-dot{
  position:absolute;border-radius:50%;pointer-events:none;
  filter:blur(40px);opacity:.3;
}
.vision-dot--1{width:340px;height:340px;background:var(--vision-lime);top:10%;left:-5%;animation:visionDrift1 18s ease-in-out infinite}
.vision-dot--2{width:280px;height:280px;background:var(--vision-magenta);bottom:15%;right:-5%;animation:visionDrift2 22s ease-in-out infinite}
.vision-dot--3{width:220px;height:220px;background:var(--vision-yellow);top:60%;left:30%;animation:visionDrift3 26s ease-in-out infinite}
@keyframes visionDrift1{0%,100%{transform:translate(0,0)}50%{transform:translate(60px,40px)}}
@keyframes visionDrift2{0%,100%{transform:translate(0,0)}50%{transform:translate(-50px,-30px)}}
@keyframes visionDrift3{0%,100%{transform:translate(0,0)}50%{transform:translate(40px,-60px) scale(1.2)}}

.vision .shell{position:relative;z-index:2}

/* ---------- Eyebrow ---------- */
.vision-eyebrow{
  display:inline-flex;align-items:center;gap:12px;
  font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--vision-lime);font-weight:700;
  padding:8px 16px;border:1px solid rgba(163,230,53,.40);border-radius:99px;
  background:rgba(163,230,53,.08);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
.vision-eyebrow::before{
  content:"";width:8px;height:8px;border-radius:50%;background:var(--vision-lime);
  box-shadow:0 0 16px var(--vision-lime);animation:pulse 2s ease-in-out infinite;
}

/* ---------- Big aspirational headline ---------- */
.vision-h{
  font-size:clamp(40px,8vw,110px);
  line-height:.98;letter-spacing:-.04em;font-weight:600;
  margin:28px 0 56px;
  color:#F5F5F7;max-width:15ch;
}
.vision-h .ital{
  font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;
  background:linear-gradient(135deg,var(--vision-lime),var(--vision-yellow) 50%,var(--vision-magenta));
  background-size:200% 200%;animation:hue 6s linear infinite;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  letter-spacing:-.025em;
}
.vision-word{display:inline}

/* ---------- Scenario list — each line reveals on scroll ---------- */
.vision-list{
  list-style:none;display:flex;flex-direction:column;gap:20px;
  margin-bottom:72px;max-width:32ch;
}
.vision-list li{
  font-size:clamp(20px,2.6vw,32px);line-height:1.35;font-weight:500;
  color:#C7E8DA;
  opacity:0;transform:translateX(-32px);
  transition:opacity .9s cubic-bezier(.16,1,.3,1), transform .9s cubic-bezier(.16,1,.3,1);
  padding-left:36px;position:relative;
}
.vision-list li::before{
  content:"→";position:absolute;left:0;top:0;
  color:var(--vision-lime);font-weight:700;
  font-family:'JetBrains Mono',monospace;
}
.vision-list li.in{opacity:1;transform:translateX(0)}
.vision-list li b{color:#F5F5F7;font-weight:700}

.vision-list li.bold{
  color:var(--vision-yellow);
  font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;
  font-size:clamp(26px,3.6vw,46px);
  margin-top:6px;
  padding-left:0;
}
.vision-list li.bold::before{display:none}

/* ---------- Big closing CTA ---------- */
.vision-close{
  display:flex;flex-direction:column;align-items:flex-start;gap:28px;
  padding-top:50px;border-top:1px solid rgba(163,230,53,.30);
  position:relative;
}
.vision-close-h{
  font-size:clamp(32px,5vw,64px);font-weight:600;line-height:1.04;
  color:#F5F5F7;letter-spacing:-.03em;max-width:18ch;
}
.vision-close-h .ital{
  font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;
  background:linear-gradient(135deg,var(--vision-lime),var(--vision-yellow));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}

.vision-cta{
  display:inline-flex;align-items:center;gap:14px;
  padding:22px 36px;border-radius:99px;
  background:linear-gradient(135deg,var(--vision-lime) 0%, var(--vision-yellow) 35%, var(--vision-magenta) 70%, var(--vision-teal) 100%);
  background-size:300% 300%;animation:hue 5s linear infinite;
  color:#0A0A0F;font-weight:700;font-size:clamp(16px,1.6vw,20px);letter-spacing:-.005em;
  position:relative;cursor:none;
  box-shadow:0 22px 60px rgba(163,230,53,.40), 0 0 0 1px rgba(255,255,255,.20) inset;
  transition:transform .3s cubic-bezier(.16,1,.3,1);
}
.vision-cta::before{
  content:"";position:absolute;inset:-8px;border-radius:inherit;
  background:linear-gradient(135deg,var(--vision-lime),var(--vision-yellow),var(--vision-magenta));
  background-size:300% 300%;animation:hue 4s linear infinite;
  z-index:-1;filter:blur(28px);opacity:.65;
}
.vision-cta:hover{transform:translateY(-3px) scale(1.04)}
.vision-cta svg{transition:transform .35s cubic-bezier(.16,1,.3,1)}
.vision-cta:hover svg{transform:translate(5px,-5px) rotate(-45deg)}

.vision-meta{
  margin-top:18px;font-size:13px;color:#7BAA94;
  font-family:'JetBrains Mono',monospace;letter-spacing:.04em;
}
.vision-meta b{color:var(--vision-lime);font-weight:700}

/* ---------- Section eyebrow override for personalities.css ---------- */
.vision .vision-eyebrow::before{
  /* Override the generic eyebrow dot styling from elsewhere */
  width:8px;height:8px;background:var(--vision-lime);box-shadow:0 0 16px var(--vision-lime);
}

/* ---------- Mobile ---------- */
@media (max-width:680px){
  .vision-h{font-size:clamp(38px,10vw,68px)}
  .vision-list li{font-size:clamp(18px,4.5vw,24px);padding-left:28px}
  .vision-list li.bold{font-size:clamp(24px,6vw,36px)}
  .vision-close-h{font-size:clamp(28px,7vw,42px)}
  .vision-cta{padding:18px 28px;font-size:16px}
}
