// Pegpoint card visual - accurate to current pegpoint.io build.
// Cabinet with center CRT + L/R rails + shelf, cycling: attract → mode → levels → power → game → results.
// Uses the real "arcade" palette (NES classic): bg #5C94FC, target #F83800, power-peg #00B800,
// jackpot #A81898, blue peg #0078F8, ball #FCFCFC, ui panel #384878.
// Silkscreen would be ideal - falling back to JetBrains Mono with letter-spacing tightened.
// Total cycle: 9s. Stages overlap by ~120ms for cross-fade feel.

window.PegpointCardV2 = function PegpointCardV2() {
 return (
 <div className="ppx">
 <style>{ppxCSS}</style>
 <div className="cabinet">
 {/* === LEFT RAIL === */}
 <div className="lrail">
 <div className="rp">
 <div className="rt">MODES</div>
 <div className="rrow on">▸ CLASSIC</div>
 <div className="rrow"> ROGUELITE</div>
 <div className="rrow"> DAILY</div>
 <div className="rrow"> CREATE</div>
 </div>
 <div className="rp">
 <div className="rt">RUN</div>
 <div className="rrow"><span>SCORE</span><b>24,180</b></div>
 <div className="rrow"><span>STARS</span><b>★★☆</b></div>
 </div>
 </div>

 {/* === CABINET CRT (center) === */}
 <div className="crt">
 <div className="bezel"></div>

 {/* ─── attract (0 - 1.5s) ─── */}
 <div className="scene attract">
 <div className="logo">
 <span>PEG</span><span>POINT</span>
 </div>
 <div className="tag">PEG-SHOOTER · ARCADE</div>
 <div className="press">▶ PRESS START</div>
 </div>

 {/* ─── mode select (1.5 - 2.7s) - cabinet stays on attract per SCENES.md, ─── */}
 {/* but we add a faint mode-cursor highlight overlay */}
 <div className="scene attract2"></div>

 {/* ─── level select (2.7 - 4.4s): full board showcase ─── */}
 <div className="scene levels">
 <div className="boardchrome">
 <span className="bcn">CH 1 · 02 / 12</span>
 <span className="bcn">CORRIDOR</span>
 </div>
 <div className="board">
 {/* dense peg field - orange targets, blue, green power, purple jackpot */}
 <span className="peg t" style={{left:'18%',top:'22%'}}></span>
 <span className="peg b" style={{left:'34%',top:'18%'}}></span>
 <span className="peg b" style={{left:'50%',top:'24%'}}></span>
 <span className="peg t" style={{left:'66%',top:'18%'}}></span>
 <span className="peg b" style={{left:'82%',top:'22%'}}></span>
 <span className="peg b" style={{left:'24%',top:'34%'}}></span>
 <span className="peg t" style={{left:'40%',top:'38%'}}></span>
 <span className="peg g" style={{left:'56%',top:'34%'}}></span>
 <span className="peg b" style={{left:'72%',top:'38%'}}></span>
 <span className="peg p" style={{left:'88%',top:'34%'}}></span>
 <span className="peg t" style={{left:'18%',top:'50%'}}></span>
 <span className="peg b" style={{left:'34%',top:'54%'}}></span>
 <span className="peg b" style={{left:'50%',top:'50%'}}></span>
 <span className="peg t" style={{left:'66%',top:'54%'}}></span>
 <span className="peg b" style={{left:'82%',top:'50%'}}></span>
 <span className="peg b" style={{left:'24%',top:'66%'}}></span>
 <span className="peg t" style={{left:'40%',top:'70%'}}></span>
 <span className="peg b" style={{left:'56%',top:'66%'}}></span>
 <span className="peg t" style={{left:'72%',top:'70%'}}></span>
 <span className="peg b" style={{left:'88%',top:'66%'}}></span>
 <span className="bumper" style={{left:'10%',top:'82%'}}></span>
 <span className="bumper" style={{left:'90%',top:'82%'}}></span>
 <span className="bucket-static"></span>
 </div>
 </div>

 {/* ─── power select (4.4 - 5.6s): glyph portrait ─── */}
 <div className="scene power">
 <div className="boardchrome">
 <span className="bcn">CH 1 · 02</span>
 <span className="bcn">SELECT POWER</span>
 </div>
 <div className="portrait">
 <div className="glyph">◈</div>
 <div className="pname">MEGA</div>
 <div className="pblurb">+50% HIT · PIERCES 6 PEGS</div>
 </div>
 </div>

 {/* ─── game (5.6 - 8.2s): live shot ─── */}
 <div className="scene game">
 <div className="hudstrip">
 <span>SCORE 24180</span>
 <span className="mult">×3</span>
 <span>BALL 2/10</span>
 </div>
 <div className="board game-board">
 {/* same field but pegs animate-pop as ball passes */}
 <span className="peg t" style={{left:'18%',top:'22%'}}></span>
 <span className="peg b" style={{left:'34%',top:'18%'}}></span>
 <span className="peg b" style={{left:'50%',top:'24%'}}></span>
 <span className="peg t pop pop1" style={{left:'66%',top:'18%'}}></span>
 <span className="peg b" style={{left:'82%',top:'22%'}}></span>
 <span className="peg b" style={{left:'24%',top:'34%'}}></span>
 <span className="peg t pop pop2" style={{left:'40%',top:'38%'}}></span>
 <span className="peg g" style={{left:'56%',top:'34%'}}></span>
 <span className="peg b pop pop3" style={{left:'72%',top:'38%'}}></span>
 <span className="peg p" style={{left:'88%',top:'34%'}}></span>
 <span className="peg t" style={{left:'18%',top:'50%'}}></span>
 <span className="peg b" style={{left:'34%',top:'54%'}}></span>
 <span className="peg b" style={{left:'50%',top:'50%'}}></span>
 <span className="peg t pop pop4" style={{left:'66%',top:'54%'}}></span>
 <span className="peg b" style={{left:'82%',top:'50%'}}></span>
 <span className="peg b" style={{left:'24%',top:'66%'}}></span>
 <span className="peg t" style={{left:'40%',top:'70%'}}></span>
 <span className="peg b" style={{left:'56%',top:'66%'}}></span>
 <span className="peg t" style={{left:'72%',top:'70%'}}></span>
 <span className="peg b" style={{left:'88%',top:'66%'}}></span>
 <span className="bumper" style={{left:'10%',top:'82%'}}></span>
 <span className="bumper" style={{left:'90%',top:'82%'}}></span>
 {/* aim line during early game */}
 <span className="aim"></span>
 {/* the ball */}
 <span className="ball"></span>
 {/* moving bucket */}
 <span className="bucket"></span>
 {/* score popup */}
 <span className="scorepop">+1,500</span>
 {/* combo flash */}
 <span className="combo">×3 HOT</span>
 </div>
 </div>

 {/* ─── results (8.2 - 9s) ─── */}
 <div className="scene results">
 <div className="rline rl1">CLEAR</div>
 <div className="rline rl2">38,720</div>
 <div className="rstars">★ ★ ★</div>
 <div className="rline rl3">ACE</div>
 </div>

 {/* CRT overlay - scanlines + vignette + grain over everything */}
 <div className="scan"></div>
 <div className="vign"></div>
 </div>

 {/* === RIGHT RAIL === */}
 <div className="rrail">
 <div className="rp">
 <div className="rt">SCORE</div>
 <div className="bigscore">24,180</div>
 <div className="rrow"><span>MULT</span><b className="mhud">×3</b></div>
 </div>
 <div className="rp">
 <div className="rt">COMBO</div>
 <div className="combohud">×6 NUKE</div>
 </div>
 <div className="rp">
 <div className="rt">POWER</div>
 <div className="rrow"><span>MEGA</span><b className="pillon">ACTIVE</b></div>
 </div>
 <div className="rp">
 <div className="rt">BALLS</div>
 <div className="balls">
 <span className="bs"></span><span className="bs"></span><span className="bs"></span>
 <span className="bs"></span><span className="bs dim"></span>
 </div>
 </div>
 </div>

 {/* === SHELF (under cabinet) === */}
 <div className="shelf">
 <span className="btn">◀ BACK</span>
 <span className="hint hint1">PRESS START</span>
 <span className="hint hint2">CLASSIC · CH 1</span>
 <span className="hint hint3">◀ FIRST DROP ▶</span>
 <span className="hint hint4">◀ MEGA ▶</span>
 <span className="hint hint5">DRAG TO AIM · SPACE TO LAUNCH</span>
 <span className="hint hint6">RETRY · NEXT</span>
 <span className="btn pri">LAUNCH ▶</span>
 </div>
 </div>
 </div>
 );
};

const ppxCSS = `
 /* === arcade palette (from src/palettes.js) === */
 .ppx{position:absolute;inset:0;background:#1a1a1f;display:flex;align-items:center;justify-content:center;padding:6px;font-family:'Silkscreen','JetBrains Mono',monospace;letter-spacing:.04em;overflow:hidden}
 .ppx .cabinet{position:relative;width:100%;height:100%;background:#0a0a14;display:grid;grid-template-columns:18% 1fr 18%;grid-template-rows:1fr 14px;gap:2px;padding:3px;border:1px solid #1a1a2e}

 /* === rails === */
 .ppx .lrail,.ppx .rrail{display:flex;flex-direction:column;gap:2px;font-size:6px;line-height:1.25;color:#FCFCFC}
 .ppx .rp{background:#384878;border:1px solid #1a2548;padding:2px 3px;flex:1;display:flex;flex-direction:column;gap:1px;color:#FCFCFC;position:relative;overflow:hidden}
 .ppx .rp::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent 0,transparent 1px,rgba(0,0,0,.18) 1px,rgba(0,0,0,.18) 2px);pointer-events:none}
 .ppx .rt{font-size:5.5px;letter-spacing:.18em;color:#5C94FC;font-weight:700;border-bottom:1px solid #1a2548;padding-bottom:1px;margin-bottom:1px;position:relative;z-index:1}
 .ppx .rrow{display:flex;justify-content:space-between;align-items:center;font-size:5.5px;color:#FCFCFC;position:relative;z-index:1}
 .ppx .rrow b{font-weight:700;color:#F8D878}
 .ppx .rrow.on{color:#F8D878}
 .ppx .bigscore{font-size:11px;color:#FCFCFC;font-weight:700;line-height:1;position:relative;z-index:1;animation:ppx-tick 9s linear infinite;letter-spacing:.02em}
 @keyframes ppx-tick{
 0%,62%{color:#FCFCFC}
 65%{color:#F8D878;text-shadow:0 0 4px #F8D878}
 70%{color:#FCFCFC;text-shadow:none}
 75%{color:#F8D878;text-shadow:0 0 4px #F8D878}
 80%{color:#FCFCFC;text-shadow:none}
 100%{color:#FCFCFC}
 }
 .ppx .mhud{animation:ppx-mhud 9s linear infinite}
 @keyframes ppx-mhud{0%,62%{color:#F8D878}65%{color:#F83800}75%{color:#F83800}80%{color:#F8D878}100%{color:#F8D878}}
 .ppx .combohud{font-size:9px;color:#F83800;font-weight:700;text-align:center;letter-spacing:.06em;position:relative;z-index:1;opacity:0;animation:ppx-combohud 9s linear infinite}
 @keyframes ppx-combohud{0%,68%{opacity:0}70%{opacity:1}82%{opacity:1}84%{opacity:0}100%{opacity:0}}
 .ppx .pillon{background:#00B800;color:#000;padding:0 3px;font-size:5px;letter-spacing:.1em}
 .ppx .balls{display:flex;gap:2px;position:relative;z-index:1;padding:1px 0}
 .ppx .bs{width:5px;height:5px;background:#FCFCFC;border-radius:50%;border:1px solid #0a0a14}
 .ppx .bs.dim{background:#384878;border-color:#1a2548}

 /* === center CRT === */
 .ppx .crt{position:relative;background:#5C94FC;overflow:hidden;border:1px solid #1a2548;border-radius:1px}
 .ppx .bezel{position:absolute;inset:0;border:2px solid #0a0a14;box-shadow:inset 0 0 0 1px rgba(255,255,255,.08),inset 0 0 12px rgba(0,0,0,.45);pointer-events:none;z-index:5;border-radius:2px}
 .ppx .scene{position:absolute;inset:0;display:flex;flex-direction:column;opacity:0}

 /* attract */
 .ppx .scene.attract{align-items:center;justify-content:center;gap:6px;color:#FCFCFC;background:#5C94FC;animation:ppx-attract 9s linear infinite}
 @keyframes ppx-attract{0%{opacity:0}2%{opacity:1}16%{opacity:1}19%{opacity:0}100%{opacity:0}}
 .ppx .scene.attract .logo{display:flex;flex-direction:column;align-items:center;font-weight:700;font-size:18px;line-height:.95;letter-spacing:.04em;color:#FCFCFC;text-shadow:2px 2px 0 #F83800,4px 4px 0 #382028}
 .ppx .scene.attract .logo span{display:block}
 .ppx .scene.attract .tag{font-size:6px;letter-spacing:.22em;color:#F8D878;margin-top:6px}
 .ppx .scene.attract .press{font-size:7px;letter-spacing:.16em;color:#FCFCFC;margin-top:14px;animation:ppx-blink .55s steps(2) infinite}
 @keyframes ppx-blink{50%{opacity:0}}

 /* mode-select dwell - same attract image, just a label flicker on right rail timing */
 .ppx .scene.attract2{animation:ppx-attract2 9s linear infinite;background:#5C94FC;align-items:center;justify-content:center}
 @keyframes ppx-attract2{0%,18%{opacity:0}20%{opacity:1}28%{opacity:1}30%{opacity:0}100%{opacity:0}}

 /* levels - board showcase */
 .ppx .scene.levels{animation:ppx-levels 9s linear infinite}
 @keyframes ppx-levels{0%,29%{opacity:0}31%{opacity:1}47%{opacity:1}49%{opacity:0}100%{opacity:0}}
 .ppx .boardchrome{display:flex;justify-content:space-between;background:#384878;color:#FCFCFC;font-size:5px;letter-spacing:.14em;padding:2px 4px;border-bottom:1px solid #1a2548;flex-shrink:0;line-height:1.2}
 .ppx .board{position:relative;flex:1;background:#5C94FC;overflow:hidden}
 .ppx .peg{position:absolute;width:4px;height:4px;border-radius:50%;border:1px solid #1a1a1f;transform:translate(-50%,-50%)}
 .ppx .peg.b{background:#0078F8}
 .ppx .peg.t{background:#F83800;box-shadow:0 0 0 1px #F8D878}
 .ppx .peg.g{background:#00B800;box-shadow:0 0 4px #58F898}
 .ppx .peg.p{background:#A81898}
 .ppx .bumper{position:absolute;width:8px;height:8px;background:#F8D878;border:1px solid #1a1a1f;border-radius:50%;transform:translate(-50%,-50%);box-shadow:inset -1px -1px 0 #382028}
 .ppx .bucket-static{position:absolute;left:50%;bottom:3%;transform:translateX(-50%);width:18%;height:5px;background:#384878;border:1px solid #1a1a1f;border-radius:1px}

 /* power */
 .ppx .scene.power{animation:ppx-power 9s linear infinite;background:#5C94FC}
 @keyframes ppx-power{0%,48%{opacity:0}50%{opacity:1}60%{opacity:1}62%{opacity:0}100%{opacity:0}}
 .ppx .scene.power .portrait{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:#FCFCFC;background:#5C94FC;background-image:radial-gradient(circle at 50% 50%,#7CB4FF 0,#5C94FC 50%,#384878 100%)}
 .ppx .scene.power .glyph{font-size:36px;color:#F8D878;line-height:1;text-shadow:2px 2px 0 #382028;animation:ppx-glyph 1s ease-in-out infinite}
 @keyframes ppx-glyph{50%{transform:scale(1.08);color:#FCFCFC}}
 .ppx .scene.power .pname{font-size:11px;font-weight:700;letter-spacing:.14em;color:#FCFCFC;text-shadow:1px 1px 0 #382028}
 .ppx .scene.power .pblurb{font-size:5.5px;letter-spacing:.12em;color:#F8D878}

 /* game */
 .ppx .scene.game{animation:ppx-game 9s linear infinite}
 @keyframes ppx-game{0%,61%{opacity:0}63%{opacity:1}87%{opacity:1}89%{opacity:0}100%{opacity:0}}
 .ppx .hudstrip{display:flex;justify-content:space-between;background:#384878;color:#FCFCFC;font-size:5.5px;letter-spacing:.1em;padding:2px 4px;border-bottom:1px solid #1a1a1f;flex-shrink:0;line-height:1.2;font-weight:700;animation:ppx-hudfever 9s linear infinite}
 @keyframes ppx-hudfever{0%,79%{background:#384878}81%{background:#F83800}87%{background:#F83800}89%{background:#384878}100%{background:#384878}}
 .ppx .hudstrip .mult{color:#F8D878}
 .ppx .game-board{position:relative}
 .ppx .aim{position:absolute;left:50%;top:6%;width:1px;height:32%;background:repeating-linear-gradient(180deg,#FCFCFC 0 2px,transparent 2px 4px);transform:translateX(-50%) rotate(0deg);transform-origin:50% 0;opacity:0;animation:ppx-aim 9s linear infinite}
 @keyframes ppx-aim{
 0%,63%{opacity:0;transform:translateX(-50%) rotate(0deg)}
 64%{opacity:.85;transform:translateX(-50%) rotate(-22deg)}
 68%{opacity:.85;transform:translateX(-50%) rotate(18deg)}
 71%{opacity:.85;transform:translateX(-50%) rotate(-8deg)}
 73%{opacity:0}
 100%{opacity:0}
 }
 .ppx .ball{position:absolute;width:5px;height:5px;background:#FCFCFC;border:1px solid #1a1a1f;border-radius:50%;left:50%;top:6%;box-shadow:inset 1px 1px 0 #FCFCFC,0 0 6px rgba(255,255,255,.4);transform:translate(-50%,-50%);opacity:0;animation:ppx-ball 9s linear infinite}
 @keyframes ppx-ball{
 0%,72%{opacity:0;left:50%;top:6%}
 73%{opacity:1;left:50%;top:8%}
 76%{left:50%;top:18%}
 77%{left:65%;top:20%}
 79%{left:72%;top:38%}
 80%{left:65%;top:42%}
 81%{left:55%;top:50%}
 82%{left:48%;top:54%}
 83%{left:40%;top:62%}
 84%{left:48%;top:70%}
 85%{left:55%;top:74%}
 86%{left:50%;top:82%}
 88%{opacity:1;left:50%;top:88%}
 89%{opacity:0}
 100%{opacity:0}
 }
 .ppx .bucket{position:absolute;left:50%;bottom:3%;transform:translateX(-50%);width:18%;height:5px;background:#384878;border:1px solid #1a1a1f;border-radius:1px;animation:ppx-bucket 1.6s ease-in-out infinite,ppx-bucketshow 9s linear infinite}
 @keyframes ppx-bucket{0%{margin-left:-22%}50%{margin-left:22%}100%{margin-left:-22%}}
 @keyframes ppx-bucketshow{0%,62%{opacity:0}64%{opacity:1}88%{opacity:1}89%{opacity:0}100%{opacity:0}}
 .ppx .peg.pop{transform-origin:50% 50%}
 .ppx .peg.pop1{animation:ppx-pop 9s linear infinite}
 .ppx .peg.pop2{animation:ppx-pop 9s linear infinite;animation-delay:.2s}
 .ppx .peg.pop3{animation:ppx-pop 9s linear infinite;animation-delay:.4s}
 .ppx .peg.pop4{animation:ppx-pop 9s linear infinite;animation-delay:.6s}
 @keyframes ppx-pop{
 0%,76%{transform:translate(-50%,-50%) scale(1);opacity:1}
 77%{transform:translate(-50%,-50%) scale(1.8);opacity:1;background:#F8D878}
 79%{transform:translate(-50%,-50%) scale(0);opacity:0}
 100%{transform:translate(-50%,-50%) scale(0);opacity:0}
 }
 .ppx .scorepop{position:absolute;left:55%;top:50%;color:#F8D878;font-size:7px;font-weight:700;letter-spacing:.08em;text-shadow:1px 1px 0 #382028;opacity:0;animation:ppx-scorepop 9s linear infinite}
 @keyframes ppx-scorepop{
 0%,80%{opacity:0;transform:translateY(0)}
 82%{opacity:1;transform:translateY(-6px)}
 86%{opacity:1;transform:translateY(-12px)}
 87%{opacity:0;transform:translateY(-16px)}
 100%{opacity:0}
 }
 .ppx .combo{position:absolute;left:50%;top:30%;transform:translateX(-50%);color:#F83800;font-size:8px;font-weight:700;letter-spacing:.16em;text-shadow:1px 1px 0 #FCFCFC;opacity:0;animation:ppx-combohit 9s linear infinite}
 @keyframes ppx-combohit{0%,82%{opacity:0;transform:translateX(-50%) scale(.7)}83%{opacity:1;transform:translateX(-50%) scale(1.2)}86%{opacity:1;transform:translateX(-50%) scale(1)}88%{opacity:0;transform:translateX(-50%) scale(1.2)}100%{opacity:0}}

 /* results */
 .ppx .scene.results{align-items:center;justify-content:center;gap:4px;background:#382028;color:#FCFCFC;animation:ppx-results 9s linear infinite}
 @keyframes ppx-results{0%,89%{opacity:0}91%{opacity:1}99%{opacity:1}100%{opacity:0}}
 .ppx .scene.results .rl1{font-size:9px;letter-spacing:.18em;color:#F8D878}
 .ppx .scene.results .rl2{font-size:18px;font-weight:700;color:#FCFCFC;letter-spacing:.04em;line-height:1;text-shadow:2px 2px 0 #F83800}
 .ppx .scene.results .rstars{font-size:14px;color:#F8D878;letter-spacing:.1em}
 .ppx .scene.results .rl3{font-size:7px;letter-spacing:.22em;color:#F83800;font-weight:700}

 /* CRT overlay */
 .ppx .scan{position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent 0,transparent 1px,rgba(0,0,0,.22) 1px,rgba(0,0,0,.22) 2px);pointer-events:none;z-index:6}
 .ppx .vign{position:absolute;inset:0;background:radial-gradient(ellipse at center,transparent 50%,rgba(0,0,0,.55) 100%);pointer-events:none;z-index:7}

 /* === shelf === */
 .ppx .shelf{grid-column:1/-1;background:#0a0a14;border:1px solid #1a2548;display:flex;align-items:center;gap:4px;padding:0 4px;font-size:5.5px;letter-spacing:.12em;color:#FCFCFC;height:14px;overflow:hidden;position:relative}
 .ppx .shelf .btn{background:#384878;border:1px solid #1a2548;color:#FCFCFC;padding:1px 5px;font-weight:700;font-size:5px;letter-spacing:.12em;line-height:1}
 .ppx .shelf .btn.pri{background:#F8D878;color:#1a1a1f;border-color:#F8D878;margin-left:auto;animation:ppx-pri 1s ease-in-out infinite}
 @keyframes ppx-pri{50%{box-shadow:0 0 4px #F8D878}}
 .ppx .shelf .hint{position:absolute;left:50%;transform:translateX(-50%);font-size:5.5px;color:#F8D878;letter-spacing:.16em;font-weight:700;opacity:0;white-space:nowrap}
 .ppx .shelf .hint1{animation:ppx-h1 9s linear infinite}
 .ppx .shelf .hint2{animation:ppx-h2 9s linear infinite}
 .ppx .shelf .hint3{animation:ppx-h3 9s linear infinite}
 .ppx .shelf .hint4{animation:ppx-h4 9s linear infinite}
 .ppx .shelf .hint5{animation:ppx-h5 9s linear infinite}
 .ppx .shelf .hint6{animation:ppx-h6 9s linear infinite}
 @keyframes ppx-h1{0%{opacity:0}3%{opacity:1}16%{opacity:1}19%{opacity:0}100%{opacity:0}}
 @keyframes ppx-h2{0%,19%{opacity:0}21%{opacity:1}28%{opacity:1}30%{opacity:0}100%{opacity:0}}
 @keyframes ppx-h3{0%,30%{opacity:0}32%{opacity:1}47%{opacity:1}49%{opacity:0}100%{opacity:0}}
 @keyframes ppx-h4{0%,49%{opacity:0}51%{opacity:1}60%{opacity:1}62%{opacity:0}100%{opacity:0}}
 @keyframes ppx-h5{0%,62%{opacity:0}64%{opacity:1}87%{opacity:1}89%{opacity:0}100%{opacity:0}}
 @keyframes ppx-h6{0%,89%{opacity:0}91%{opacity:1}100%{opacity:1}}
`;
