/* ============================================================
   PYNG · HOME — expressive layer (lush, dynamic, motion)
   Loaded after pyng.css + pages.css to elevate the homepage.
   Hero is untouched. Reduced-motion safe.
   ============================================================ */

/* ---------- continuous atmospheric page background -------- */
/* never a flat panel: a fixed gradient field shows through every section */
body.home { background: transparent; }
body.home::before {
  content: ""; position: fixed; inset: 0; z-index: -10; pointer-events: none;
}
[data-theme="dark"] body.home::before {
  background:
    radial-gradient(72% 55% at 80% -8%, rgba(124,92,255,.22), transparent 58%),
    radial-gradient(60% 50% at 2% 16%, rgba(91,140,255,.16), transparent 56%),
    radial-gradient(60% 48% at 92% 96%, rgba(69,214,182,.13), transparent 58%),
    linear-gradient(180deg, #0A1322 0%, #080E1A 60%, #060B15 100%);
}
[data-theme="light"] body.home::before {
  background:
    radial-gradient(70% 52% at 82% -10%, rgba(91,77,209,.12), transparent 56%),
    radial-gradient(55% 45% at 0% 18%, rgba(124,92,255,.09), transparent 56%),
    radial-gradient(55% 45% at 95% 98%, rgba(14,158,128,.08), transparent 58%),
    linear-gradient(180deg, #EEF1F8 0%, #E9EDF6 100%);
}
/* let the atmosphere show through formerly-flat bands */
.home .section--band { background: transparent; border-block: 0; }
.home .foot { background: color-mix(in srgb, var(--surface) 50%, transparent); backdrop-filter: blur(6px); }
.home .nav { background: color-mix(in srgb, var(--bg) 70%, transparent); }

/* ---------- atmospheric backgrounds (no more flat) -------- */
.fx { position: relative; isolation: isolate; overflow: clip; }
.aurora { position: absolute; inset: -25% -10% -10%; z-index: -1; pointer-events: none; }
.aurora::before, .aurora::after {
  content: ""; position: absolute; inset: 0; border-radius: 50%;
  filter: blur(70px); opacity: .55;
}
.aurora::before {
  background:
    radial-gradient(38% 46% at 22% 30%, color-mix(in srgb, var(--accent) 42%, transparent), transparent 70%),
    radial-gradient(34% 42% at 82% 22%, color-mix(in srgb, #7C5CFF 40%, transparent), transparent 70%);
  animation: drift1 22s ease-in-out infinite alternate;
}
.aurora::after {
  background:
    radial-gradient(40% 48% at 72% 82%, color-mix(in srgb, var(--warm) 34%, transparent), transparent 70%),
    radial-gradient(30% 40% at 12% 88%, color-mix(in srgb, var(--cold) 32%, transparent), transparent 70%);
  animation: drift2 26s ease-in-out infinite alternate;
}
[data-theme="dark"] .aurora::before, [data-theme="dark"] .aurora::after { opacity: .42; }
@keyframes drift1 { to { transform: translate3d(4%, -4%, 0) scale(1.12) rotate(6deg); } }
@keyframes drift2 { to { transform: translate3d(-5%, 3%, 0) scale(1.1) rotate(-5deg); } }

/* fine dot-grid wash on top of aurora for texture */
.dotgrid::after {
  content: ""; position: absolute; inset: 0; z-index: -1; pointer-events: none;
  background-image: radial-gradient(var(--line-strong) 1px, transparent 1.4px);
  background-size: 30px 30px;
  -webkit-mask-image: radial-gradient(120% 90% at 50% 40%, #000, transparent 78%);
          mask-image: radial-gradient(120% 90% at 50% 40%, #000, transparent 78%);
  opacity: .5;
}

/* ---------- dark standout band (heyreach-style) ----------- */
.section--dark {
  --surface: #121E33;
  --surface-2: #0E1830;
  --line: rgba(255,255,255,.09);
  --line-strong: rgba(255,255,255,.16);
  --ink: #ECF1FB;
  --ink-2: #C4D0E6;
  --muted: #98A8C6;
  --faint: #6B7C99;
  --accent-ink: #A9B5FF;
  --shadow-2: 0 2px 6px rgba(0,0,0,.4), 0 24px 60px -24px rgba(0,0,0,.7);
  background:
    radial-gradient(120% 130% at 50% -10%, #182747 0%, #0B1426 55%, #080F1E 100%);
  color: var(--ink);
  border-block: 1px solid rgba(255,255,255,.07);
  position: relative; overflow: clip;
}
.section--dark .h2, .section--dark h3, .section--dark h4 { color: var(--ink); }
.section--dark .lead { color: var(--muted); }
.section--dark::before {
  content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(50% 60% at 18% 12%, rgba(124,92,255,.28), transparent 70%),
    radial-gradient(46% 56% at 86% 90%, rgba(69,214,182,.18), transparent 70%);
  opacity: .9;
}
.section--dark > * { position: relative; z-index: 1; }

/* ---------- glow cards ------------------------------------ */
.glow-card {
  position: relative; background: var(--surface);
  border: 1px solid var(--line); border-radius: var(--r-lg);
  padding: clamp(22px, 2.6vw, 32px);
  box-shadow: var(--shadow-2);
  transition: transform .28s cubic-bezier(.2,.7,.3,1), box-shadow .28s, border-color .28s;
  overflow: hidden;
}
.glow-card::after {
  content: ""; position: absolute; inset: 0; border-radius: inherit; padding: 1px;
  background: linear-gradient(135deg, color-mix(in srgb, var(--cat, var(--accent)) 65%, transparent), transparent 42%);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  opacity: .7; pointer-events: none;
}
.glow-card > .glow-spot {
  position: absolute; width: 220px; height: 220px; border-radius: 50%; top: -90px; right: -60px;
  background: radial-gradient(circle, color-mix(in srgb, var(--cat, var(--accent)) 36%, transparent), transparent 70%);
  filter: blur(20px); opacity: .55; pointer-events: none; transition: opacity .28s;
}
.glow-card:hover {
  transform: translateY(-5px);
  border-color: color-mix(in srgb, var(--cat, var(--accent)) 40%, var(--line-strong));
  box-shadow: var(--shadow-3), 0 30px 70px -34px color-mix(in srgb, var(--cat, var(--accent)) 70%, transparent);
}
.glow-card:hover > .glow-spot { opacity: .85; }
.glow-ic {
  width: 50px; height: 50px; border-radius: 14px; display: grid; place-items: center;
  color: #fff; margin-bottom: var(--s5);
  background: linear-gradient(150deg, color-mix(in srgb, var(--cat, var(--accent)) 96%, #fff), var(--cat, var(--accent)));
  box-shadow: 0 8px 20px -8px color-mix(in srgb, var(--cat, var(--accent)) 80%, transparent), inset 0 1px 0 rgba(255,255,255,.3);
}
.glow-ic svg { width: 24px; height: 24px; }

/* ---------- gradient text accent (used sparingly) -------- */
.grad-text {
  background: linear-gradient(100deg, var(--cold), #7C5CFF 50%, var(--accent));
  -webkit-background-clip: text; background-clip: text; color: transparent;
}

/* ---------- stat strip ----------------------------------- */
.stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s5); }
.stat { position: relative; padding: var(--s5) var(--s5) var(--s5) var(--s6); }
.stat::before { content:""; position:absolute; left:0; top:8px; bottom:8px; width:2px; border-radius:2px; background: linear-gradient(var(--cold), var(--hot)); }
.stat .num { font-family: var(--font-display); font-weight: 800; font-size: clamp(2.4rem, 5vw, 3.4rem); letter-spacing: -0.03em; line-height: 1; color: var(--ink); }
.stat .num .suf { color: var(--accent-ink); }
.stat .cap { margin-top: var(--s3); color: var(--muted); font-size: .98rem; max-width: 34ch; }
@media (max-width: 760px){ .stats { grid-template-columns: 1fr; gap: var(--s4); } }

/* ---------- animated inbox (problem) --------------------- */
.inbox { display: grid; gap: 12px; perspective: 1000px; }
.mail {
  display: flex; align-items: center; gap: var(--s3);
  border: 1px solid var(--line); border-radius: var(--r-md);
  background: var(--surface); padding: 14px 16px; font-size: .94rem; color: var(--muted);
  box-shadow: var(--shadow-1); transition: transform .3s;
}
.mail .av { width: 32px; height: 32px; border-radius: 50%; background: var(--surface-3); color: var(--faint); display:grid; place-items:center; font-family:var(--font-mono); font-size:.7rem; flex:0 0 auto; }
.mail--dim { opacity: .46; }
.mail--dim:nth-child(2){ opacity:.32; } .mail--dim:nth-child(3){ opacity:.2; }
.mail--live {
  position: relative; border: 0; color: var(--ink); font-weight: 500;
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 16%, var(--surface)), var(--surface));
  box-shadow: var(--shadow-2), 0 0 0 1px color-mix(in srgb, var(--accent) 45%, transparent);
  animation: livepulse 3s ease-in-out infinite;
}
.mail--live .av { background: var(--accent); color: #fff; }
.mail--live .ping-badge { margin-left:auto; display:inline-flex; align-items:center; gap:6px; font-family:var(--font-mono); font-size:.74rem; color: var(--hot); white-space:nowrap; }
@keyframes livepulse {
  0%,100% { box-shadow: var(--shadow-2), 0 0 0 1px color-mix(in srgb, var(--accent) 45%, transparent); transform: translateY(0); }
  50% { box-shadow: var(--shadow-2), 0 0 0 1px color-mix(in srgb, var(--accent) 70%, transparent), 0 18px 50px -18px color-mix(in srgb, var(--accent) 70%, transparent); transform: translateY(-2px); }
}

/* ---------- animated pipeline (how it works) ------------- */
.pipe { position: relative; }
.pipe-track { position: absolute; left: 8%; right: 8%; top: 33px; height: 3px; border-radius: 3px;
  background: linear-gradient(to right, var(--cold), var(--warm) 52%, var(--hot)); opacity: .65; }
.pipe-pulse { position: absolute; top: 28px; left: 8%; width: 13px; height: 13px; border-radius: 50%;
  background: #fff; box-shadow: 0 0 0 5px color-mix(in srgb, var(--accent) 35%, transparent), 0 0 18px 4px var(--accent);
  animation: travel 4.5s cubic-bezier(.6,.1,.4,.9) infinite; }
@keyframes travel { 0%{ left:8%; } 45%{ left:84%; } 50%{ left:84%; } 95%{ left:8%; } 100%{ left:8%; } }
.pipe-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: var(--s4); position: relative; }
.pnode {
  width: 68px; height: 68px; border-radius: 18px; display: grid; place-items: center;
  background: var(--surface); border: 1px solid var(--line-strong);
  color: var(--accent-ink); box-shadow: var(--shadow-2); position: relative; z-index: 1;
  transition: transform .25s, box-shadow .25s;
}
.pnode svg { width: 28px; height: 28px; }
.pstep:hover .pnode { transform: translateY(-4px) scale(1.04); }
.pstep:nth-child(1) .pnode { color: var(--cold); }
.pstep:nth-child(3) .pnode { color: #fff; background: linear-gradient(150deg, #7C5CFF, var(--accent)); border-color: transparent; box-shadow: var(--shadow-2), 0 12px 30px -10px color-mix(in srgb,var(--accent) 70%, transparent); }
.pstep:nth-child(5) .pnode { color: var(--hot); border-color: color-mix(in srgb, var(--hot) 50%, transparent); }
.pstep .k { font-family: var(--font-mono); font-size: .72rem; color: var(--faint); margin: var(--s4) 0 4px; letter-spacing: .05em; }
.pstep h4 { font-size: 1.02rem; margin-bottom: 4px; }
.pstep p { font-size: .86rem; color: var(--muted); line-height: 1.5; }
.pstep .gate { display:inline-flex; align-items:center; gap:.4em; margin-top:6px; font-family:var(--font-mono); font-size:.66rem; text-transform:uppercase; letter-spacing:.06em; color:var(--accent-ink); }
@media (max-width: 860px){ .pipe-grid{ grid-template-columns: 1fr 1fr; gap: var(--s5);} .pipe-track,.pipe-pulse{ display:none; } }
@media (max-width: 520px){ .pipe-grid{ grid-template-columns: 1fr; } }

/* ---------- product mock chrome (control) ---------------- */
.mock {
  border-radius: var(--r-lg); border: 1px solid var(--line-strong);
  background: var(--surface); box-shadow: var(--shadow-3); overflow: hidden;
  position: relative;
}
.mock::before {
  content:""; position:absolute; inset:-40% -20% auto; height:60%; z-index:0; pointer-events:none;
  background: radial-gradient(50% 100% at 70% 0%, color-mix(in srgb, var(--accent) 26%, transparent), transparent 70%);
  filter: blur(30px); opacity:.7;
}
.mock-bar { position:relative; z-index:1; display:flex; align-items:center; gap:7px; padding:12px 16px; border-bottom:1px solid var(--line); background: var(--surface-2); }
.mock-bar i { width:11px; height:11px; border-radius:50%; background: var(--line-strong); }
.mock-bar i:nth-child(1){ background:#FF6058; } .mock-bar i:nth-child(2){ background:#FFBD2E; } .mock-bar i:nth-child(3){ background:#28C840; }
.mock-bar .tab { margin-left:12px; font-family:var(--font-mono); font-size:.72rem; color:var(--faint); }
.mock-body { position:relative; z-index:1; padding: clamp(18px,2.4vw,26px); }
.meter-fill { transition: none; }
.in-view .meter-fill { animation: fillbar 1.1s .2s cubic-bezier(.3,.8,.3,1) forwards; }
@keyframes fillbar { from { width:0; } }

/* ---------- vivid CTA band ------------------------------- */
.cta-vivid {
  position: relative; overflow: clip; text-align: center; border: 0;
  background: linear-gradient(135deg, #5B8CFF 0%, #6E5CF0 48%, #8B5CF6 100%);
  color: #fff;
}
.cta-vivid::before {
  content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(40% 60% at 15% 20%, rgba(255,255,255,.28), transparent 60%),
    radial-gradient(50% 70% at 88% 90%, rgba(69,214,182,.4), transparent 60%);
  mix-blend-mode: screen; opacity:.9;
}
.cta-vivid::after {
  content:""; position:absolute; inset:0; z-index:0; pointer-events:none; opacity:.5;
  background-image: radial-gradient(rgba(255,255,255,.5) 1px, transparent 1.4px); background-size: 26px 26px;
  -webkit-mask-image: radial-gradient(120% 90% at 50% 50%, #000, transparent 75%);
          mask-image: radial-gradient(120% 90% at 50% 50%, #000, transparent 75%);
}
.cta-vivid > * { position: relative; z-index: 1; }
.cta-vivid .h2, .cta-vivid .lead { color: #fff; }
.cta-vivid .lead { color: rgba(255,255,255,.86); }
.cta-vivid .label { color: rgba(255,255,255,.85); }
.cta-vivid .label .tick { background:#fff; box-shadow:0 0 0 3px rgba(255,255,255,.25); }
.cta-vivid .cta-form input { background: rgba(255,255,255,.14); border-color: rgba(255,255,255,.32); color:#fff; }
.cta-vivid .cta-form input::placeholder { color: rgba(255,255,255,.7); }
.cta-vivid .btn-primary { background:#fff; color: var(--accent); box-shadow: 0 8px 24px -8px rgba(0,0,0,.3); }
.cta-vivid .btn-primary:hover { background:#fff; transform: translateY(-1px); }
.cta-vivid .cta-fine { color: rgba(255,255,255,.75); }

/* ---- AI-drafting / typewriter on the review message ---- */
.gen-line { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-mono); font-size: .82rem; color: var(--accent-ink); }
.gen-line .gen-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 0 0 color-mix(in srgb, var(--accent) 60%, transparent); animation: gen-pulse 1.1s ease-in-out infinite; }
@keyframes gen-pulse { 0%,100% { transform: scale(.8); opacity:.6; } 50% { transform: scale(1.25); opacity:1; box-shadow: 0 0 0 6px color-mix(in srgb, var(--accent) 0%, transparent); } }
[data-type].typing::after { content: "▌"; color: var(--accent); animation: caret .8s steps(1) infinite; margin-left: 1px; }
@keyframes caret { 50% { opacity: 0; } }

/* reveal: add a touch of scale + stagger */
.reveal { opacity: 0; transform: translateY(22px) scale(.99); transition: opacity .65s cubic-bezier(.2,.7,.3,1), transform .65s cubic-bezier(.2,.7,.3,1); }
.reveal.in { opacity: 1; transform: none; }
.reveal-2 { transition-delay: .08s; } .reveal-3 { transition-delay: .16s; } .reveal-4 { transition-delay: .24s; }

/* ============================================================
   LIVE PRODUCT-FLOW BOARD (signals → scored → approved → outreach → booked)
   ============================================================ */
.flow { padding: 0; }
.flow .flow-live { margin-left: auto; display: inline-flex; align-items: center; gap: 6px; font-family: var(--font-mono); font-size: .72rem; color: var(--success); }
.flow .flow-live::before { content:""; width: 7px; height: 7px; border-radius: 50%; background: var(--success); box-shadow: 0 0 0 3px color-mix(in srgb, var(--success) 24%, transparent); animation: blink 1.8s ease-in-out infinite; }
@keyframes blink { 0%,100%{ opacity:1; } 50%{ opacity:.35; } }

.flow-board { position: relative; z-index: 1; padding: clamp(20px,2.6vw,30px) clamp(14px,2vw,26px) clamp(26px,3vw,38px); }
.flow-cols { display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px; }
.flow-col { text-align: center; display: flex; flex-direction: column; align-items: center; gap: 6px; }
.flow-ic { width: 44px; height: 44px; border-radius: 13px; display: grid; place-items: center;
  background: var(--surface-2); border: 1px solid var(--line-strong); color: var(--accent-ink); }
.flow-ic svg { width: 22px; height: 22px; }
.flow-ic.cold { color: var(--cold); border-color: color-mix(in srgb, var(--cold) 45%, transparent); background: color-mix(in srgb, var(--cold) 12%, var(--surface)); }
.flow-ic.hot { color: var(--hot); border-color: color-mix(in srgb, var(--hot) 50%, transparent); background: color-mix(in srgb, var(--hot) 12%, var(--surface)); }
.flow-col b { font-size: .96rem; color: var(--ink); }
.flow-col small { font-family: var(--font-mono); font-size: .68rem; color: var(--faint); letter-spacing: .02em; }
.flow-col small b { color: var(--hot); font-family: var(--font-display); font-size: 1rem; }

/* the travel lane sits under the column headers */
.flow-lane { position: relative; height: 96px; margin-top: 14px; }
.flow-track { position: absolute; left: 7%; right: 8%; top: 50%; height: 2px; transform: translateY(-50%);
  background: linear-gradient(to right, var(--cold) 0%, var(--warm) 50%, var(--hot) 100%); opacity: .45; border-radius: 2px; }
.flow-track::before, .flow-track::after { content:""; position:absolute; top:50%; width:7px; height:7px; border-radius:50%; transform:translateY(-50%); }
.flow-track::before { left:-2px; background: var(--cold); }
.flow-track::after { right:-2px; background: var(--hot); box-shadow: 0 0 0 4px color-mix(in srgb, var(--hot) 22%, transparent); }

.flow-chip {
  position: absolute; top: 50%; left: 7%;
  display: inline-flex; align-items: center; gap: 8px;
  padding: 7px 13px 7px 8px; border-radius: 999px;
  background: var(--surface); border: 1.5px solid var(--cold);
  box-shadow: var(--shadow-2); white-space: nowrap; font-size: .8rem; color: var(--ink);
  transform: translate(-50%,-50%) scale(1); opacity: 0;
  animation: flowmove 11s cubic-bezier(.55,.05,.45,.95) infinite;
  animation-delay: var(--d, 0s);
}
.flow-chip .fav { width: 24px; height: 24px; border-radius: 50%; flex:0 0 auto; display:grid; place-items:center;
  font-family: var(--font-mono); font-size: .64rem; color:#fff; background: var(--cold); }
.flow-chip .fsig { font-family: var(--font-mono); font-size: .72rem; color: var(--muted); }
@keyframes flowmove {
  0%   { left: 7%;  opacity: 0; border-color: var(--cold);  transform: translate(-50%,-50%) scale(.86); }
  5%   { opacity: 1; transform: translate(-50%,-50%) scale(1); }
  26%  { left: 30%; border-color: var(--cold); }
  30%  { transform: translate(-50%,-50%) scale(1.07); }     /* scored pulse */
  34%  { transform: translate(-50%,-50%) scale(1); }
  50%  { left: 50%; border-color: var(--warm); }
  54%  { transform: translate(-50%,-50%) scale(1.07); }     /* approved pulse */
  58%  { transform: translate(-50%,-50%) scale(1); }
  72%  { left: 70%; border-color: #8C9CFF; }
  88%  { left: 90%; border-color: var(--hot); opacity: 1; }
  95%  { left: 90%; opacity: 0; transform: translate(-50%,-50%) scale(.8); }
  100% { left: 90%; opacity: 0; }
}
/* chip avatar warms with the chip */
.flow-chip.c1{ --d:0s; } .flow-chip.c2{ --d:2.2s; } .flow-chip.c3{ --d:4.4s; } .flow-chip.c4{ --d:6.6s; } .flow-chip.c5{ --d:8.8s; }

/* the booked column gets a "pop" when count ticks */
.flow-col[data-bookedcol] { position: relative; }
.booked-pop { position:absolute; top:-6px; left:50%; transform:translateX(-50%); white-space:nowrap;
  font-family:var(--font-mono); font-size:.66rem; color:var(--success);
  background: color-mix(in srgb, var(--success) 14%, var(--surface)); border:1px solid color-mix(in srgb,var(--success) 35%,transparent);
  border-radius:999px; padding:3px 8px; opacity:0; pointer-events:none; }
.booked-pop.show { animation: pop 1.5s ease forwards; }
@keyframes pop { 0%{ opacity:0; transform:translate(-50%,4px);} 14%{opacity:1; transform:translate(-50%,-8px);} 80%{opacity:1; transform:translate(-50%,-8px);} 100%{opacity:0; transform:translate(-50%,-14px);} }

@media (max-width: 760px){
  .flow-cols { grid-template-columns: repeat(5, 1fr); gap: 4px; }
  .flow-col b { font-size: .76rem; } .flow-col small { display:none; }
  .flow-ic { width: 36px; height: 36px; } .flow-ic svg { width:18px; height:18px; }
  .flow-chip { font-size: .72rem; padding: 5px 10px 5px 6px; }
  .flow-chip .fsig { display: none; }
}

@media (prefers-reduced-motion: reduce){
  .aurora::before, .aurora::after, .mail--live, .pipe-pulse { animation: none !important; }
  .in-view .meter-fill { animation: none; width: var(--w, 90%); }
  .reveal { opacity: 1; transform: none; transition: none; }
  .flow-chip { animation: none; opacity: 1; }
  .flow-chip.c1{ left:7%; border-color:var(--cold);} .flow-chip.c2{ left:30%; border-color:var(--cold);} .flow-chip.c3{ left:50%; border-color:var(--warm);} .flow-chip.c4{ left:70%; border-color:#8C9CFF;} .flow-chip.c5{ left:90%; border-color:var(--hot);}
  .flow .flow-live::before { animation: none; }
}
