// Welcome / pitch step
function StepWelcome({ onStart, state, setState }) {
  const personas = window.PERSONAS;
  const setPersona = (id) => setState(s => ({ ...s, persona: id, favorites: [] }));

  return (
    <div className="welcome-shell">
      <div className="welcome-logos">
        <img src="assets/brunt-logo.png" alt="BRUNT" className="logo-wiha" />
        <span className="sep" />
        <img src="assets/malachyte-logo-gradient.png" alt="Malachyte" className="logo-mal" />
      </div>

      <div style={{ textAlign: 'center', display: 'flex', flexDirection: 'column', gap: 12, alignItems: 'center' }}>
        <div className="welcome-eye">Phase 1 POC · Shop All Workwear</div>
        <h1 className="welcome-title">BRUNT Workwear Demo</h1>
      </div>

      <div className="welcome-compare">
        <div className="compare-card compare-card--before">
          <div className="compare-icon"><img src="assets/brunt-logo.png" alt="" /></div>
          <div>
            <h4>BRUNT today</h4>
            <p>
              One “Shop All Workwear” grid, the same order for everyone — a wall of nearly-identical
              Marin and Bolduc boot colorways up top, pants, tees and hoodies buried pages down.
              Every visitor sees the catalog, not <em>their</em> catalog.
            </p>
          </div>
        </div>
        <div className="compare-card compare-card--after">
          <div className="compare-icon"><img src="assets/malachyte-symbol-gradient.png" alt="" /></div>
          <div>
            <h4>With Malachyte</h4>
            <p>
              Same SKUs, re-ranked per visitor vector — trade · climate · job · prior orders. The
              framer leads with comp-toe waterproof boots and HD pants; the warehouse picker with
              soft-toe comfort boots and breathable tees; the returning pro with hoodies and tech shirts.
            </p>
          </div>
        </div>
      </div>

      <button className="btn btn-mal" onClick={onStart}>Open Shop All Workwear →</button>
    </div>
  );
}

// Shared: circular portrait with 4 signal pills floating at the corners.
function PortraitWithSignals({ persona }) {
  const anchors = ['wp-sig--tl', 'wp-sig--tr', 'wp-sig--bl', 'wp-sig--br'];
  return (
    <div className="wp-portrait-wrap">
      <div className="wp-portrait">
        <img src={persona.img} alt={persona.name} />
      </div>
      {(persona.signals || []).slice(0, 4).map((s, i) => (
        <span key={i} className={`wp-sig ${anchors[i]} wp-sig--${s.tone || 'amber'}`}>
          {s.label}
        </span>
      ))}
    </div>
  );
}

Object.assign(window, { StepWelcome, PortraitWithSignals });
