const WINDOWS_DOWNLOAD_URL = 'https://github.com/mussonking/MotsDits/releases/download/v0.2.0/MotsDits_0.2.0_x64-setup.exe';
const MACOS_DOWNLOAD_URL = 'https://github.com/mussonking/MotsDits/releases/download/v0.2.0/MotsDits_0.2.0_aarch64.dmg';

const TWEAK_DEFAULTS = /*EDITMODE-BEGIN*/{
  "paperWarmth": "#FCF4DC",
  "accentBlue": "#8FB4D9",
  "sketchTilt": -0.5,
  "hatchingOpacity": 0.1
}/*EDITMODE-END*/;

const problems = [
  { kind: 'cloud', title: 'Ils accrochent sur nos tournures, nos noms propres, nos accents.', caption: 'B · Nuage boudeur avec une oreille confuse, style crayon pastel.' },
  { kind: 'ear', title: 'Ta voix part dans le cloud, vers des serveurs étrangers.', caption: "B · Oreille qui écoute mal avec point d'interrogation." },
  { kind: 'gear', title: "Les options plus avancées demandent d'être pas mal geek.", caption: 'B · Engrenage avec petit labyrinthe dessiné au centre.' }
];
const steps = [
  ['1', 'Parle.', "Tiens une touche, dicte normalement.", "Micro qui s'allume doucement, scène 200 × 200 px."],
  ['2', 'MotsDits écoute.', 'La transcription se fait localement sur ton ordinateur.', "Petit cerveau avec une vague sonore dedans."],
  ['3', "Le texte apparaît.", "Direct dans l'app de ton choix.", "Texte qui arrive dans un carnet ouvert."]
];
const audiences = [
  ['Avocats / Notaires', 'Formulations longues, références, noms propres et style plus formel.', 'gavel', 'D · Maillet de juge esquissé, 80 × 80 px.'],
  ['Comptables / Fiscalistes', 'Montants, acronymes, notes de dossier, suivi client.', 'calc', 'D · Calculatrice douce avec ruban de papier.'],
  ['Santé et soins', 'Notes rapides, observations, vocabulaire technique à préserver.', 'stetho', 'D · Stéthoscope pastel, lignes irrégulières.'],
  ['Développeurs', 'Les anglicismes tech comme commit, build et PR restent naturels.', 'laptop', 'D · Portable ouvert avec petites lignes de code.'],
  ['Tout le monde', 'Courriels, notes, idées, messages, textes de tous les jours.', 'mug', 'D · Tasse de café avec bulle de parole.']
];
const faq = [
  ["Ça marche vraiment sans internet?", "Oui. La dictée se fait localement sur ton ordinateur. Tu peux couper le Wi‑Fi et continuer à dicter."],
  ["Quels ordinateurs sont compatibles?", "La première version vise Windows. Les machines récentes donnent une expérience plus fluide, surtout au niveau Précision."],
  ["Et si je parle franglais ou avec un accent fort?", "MotsDits est entraîné pour mieux suivre le français québécois naturel, incluant les mots anglais qu'on garde souvent tels quels."],
  ["Mes transcriptions sont-elles stockées quelque part?", "Non. Elles restent dans tes applications et sur ton appareil. MotsDits ne garde pas de copie sur un serveur."],
  ["Y a-t-il une version Mac / Linux?", "macOS est prévu ensuite. Linux est envisagé, mais pas promis pour le lancement."],
  ["Puis-je l'utiliser pour mon travail professionnel?", "Oui, l'app est pensée pour les pros. Pour les obligations légales précises, valide avec ton ordre ou ton organisation."],
  ["Comment ça se compare à Google Dicte ou Apple Voice?", "MotsDits mise sur le local, la confidentialité et une écoute plus adaptée aux tournures d'ici."]
];

function Logo({ small = false }) { return <div className="logo"><span className="mark" aria-hidden="true"><span className="mic"></span><span className="bubble"></span></span><span className={small ? 'word small' : 'word'}>MotsDits</span></div>; }
function SectionNumber({ n }) { return <span className="section-number" aria-hidden="true">{n}</span>; }
function DoodleIcon({ kind }) { return <span className={`drawn-icon ${kind}`} aria-hidden="true"><i></i><b></b></span>; }
function Placeholder({ label, title, children, className = '', src, alt = '' }) { return <figure className={`placeholder ${src ? 'image-placeholder' : ''} ${className}`}><div className="tape" aria-hidden="true"></div>{src ? <img src={src} alt={alt} loading="lazy" /> : <><strong>[IMAGE PLACEHOLDER {label}]</strong><figcaption><b>{title}</b>{children}</figcaption></>}</figure>; }

function App() {
  return <>
    <style>{css}</style>
    <div className="page">
      <header className="topbar">
        <a className="brand-link" href="#accueil" aria-label="MotsDits accueil"><Logo /></a>
        <nav aria-label="Navigation principale"><a href="#marche">Comment ça marche</a><a href="#pour-qui">Pour qui</a><a className="mobile-hide" href="#prive">Privé</a><a className="mobile-hide" href="#prix">Soutenir</a><a href="#organisations">Entreprises</a></nav>
        <div className="lang" aria-label="Choix de langue"><button className="active">FR</button><span>|</span><button>EN</button></div>
      </header>
      <main id="accueil">
        <section className="hero section-pad">
          <div className="hero-copy reveal"><div className="eyebrow"><span></span> Fait pour le français d'ici</div><h1>La voix au texte, faite pour le Québec.</h1><p className="lead">Une app de dictée qui comprend ton accent, qui reste sur ton ordi, et qui aide les gens d'ici à écrire plus vite sans envoyer leur voix dans le cloud.</p><div className="hero-actions desktop-hero-actions"><a className="btn primary" href={WINDOWS_DOWNLOAD_URL}>Télécharger pour Windows</a><a className="btn secondary" href={MACOS_DOWNLOAD_URL}>Télécharger pour Mac</a><a className="text-link" href="#marche">Voir comment ça marche <span>-></span></a></div><div className="hero-actions mobile-hero-actions"><a className="btn primary" href={WINDOWS_DOWNLOAD_URL}>Télécharger pour Windows</a><a className="btn secondary" href={MACOS_DOWNLOAD_URL}>Télécharger pour Mac</a></div><p className="trust desktop-trust">Gratuit en bêta · Windows et macOS · Données locales · Fait au Québec</p><p className="trust mobile-trust">App pour ordinateur. Données locales. Fait au Québec.</p></div>
          <Placeholder label="A" title="Illustration principale -- " className="hero-art reveal delay-1" src="assets/1.png" alt="Personne a un bureau avec un micro et des mots qui flottent autour." />
        </section>
        <section className="section-pad problem"><div className="section-head"><SectionNumber n="01" /><div><p className="kicker">Le problème</p><h2>On dirait que personne n'a testé ça avec mononc' Réjean.</h2></div></div><div className="problem-grid">{problems.map((item, i) => <article className="sketch-card problem-card" key={item.title}><img className="problem-doodle" src={`assets/problem-${i+1}.png`} alt="" aria-hidden="true" /><p>{item.title}</p></article>)}</div></section>
        <section className="how" id="marche"><div className="how-inner"><div className="section-head"><SectionNumber n="02" /><div><p className="kicker">Comment ça marche</p><h2>Trois gestes simples. Pas besoin d'un manuel.</h2></div></div><div className="steps">{steps.map(([n,title,text,art], i) => <article className="step sketch-card" key={title}><div className="step-image-wrap"><Placeholder label="C" title="Mini scène -- " className="mini-art" src={["assets/3 - 1.png", "assets/3 - 2.png", "assets/3 -3.png"][i]} alt={art} /><span className="step-n">{n}</span></div><h3>{title}</h3><p>{text}</p>{i < 2 && <span className="arrow" aria-hidden="true">-></span>}</article>)}</div><p className="quote-line">"Aucune connexion internet requise. Aucune donnée envoyée à personne."</p></div></section>
        <section className="section-pad audience" id="pour-qui"><div className="section-head"><SectionNumber n="03" /><div><p className="kicker">Pour qui</p><h2>Conçu pour... tout le monde.</h2></div></div><div className="audience-grid">{audiences.map(([title,text,icon,caption], i) => <article className="sketch-card person-card" key={title}><img className="audience-doodle" src={`assets/audience-${i+1}.png`} alt="" aria-hidden="true" /><h3>{title}</h3><p>{text}</p></article>)}</div></section>
        <section className="section-pad quality"><div><div className="section-head compact"><SectionNumber n="04" /><div><p className="kicker">Qualité d'écoute</p><h2>Trois niveaux. Pas besoin de parler GPU.</h2></div></div><div className="slider-card sketch-card"><div className="slider-labels"><span>Vif</span><span>Précision</span></div><div className="slider-line"><span></span><span></span><span></span></div><div className="balanced">▲ Équilibré</div></div><div className="quality-list"><div><h3>Vif</h3><p>Plus rapide. Pour les machines modestes.</p></div><div><h3>Équilibré</h3><p>Le meilleur compromis. Recommandé.</p></div><div><h3>Précision</h3><p>Qualité maximale. Pour les ordis costauds.</p></div></div></div><Placeholder label="E" title="Capture mockup -- " className="app-shot" src="assets/quality-screenshot.png" alt="Capture d'écran de MotsDits montrant le sélecteur de qualité d'écoute." /></section>
        <section className="privacy" id="prive"><div className="privacy-inner"><div className="privacy-copy"><SectionNumber n="05" /><h2>Tes données restent sur ton ordi. Point.</h2><ul className="check-list"><li>La dictée fonctionne localement sur ton appareil.</li><li>Pas besoin de compte pour commencer.</li><li>Pensé pour les réalités de confidentialité au Québec.</li></ul><p className="note">Le post-traitement par IA est optionnel et utilise tes propres clés ou ton propre serveur local.</p></div><Placeholder label="F" title="Illustration privée -- " className="house-art" src="assets/6.png" alt="Maison avec cadenas representant la confidentialite locale." /></div></section>
        <section className="section-pad optional"><div className="optional-text"><SectionNumber n="06" /><p className="kicker">Post-traitement IA (optionnel)</p><h2>Pousser plus loin avec ton modèle d'IA.</h2><p>Si tu veux affiner le résultat, MotsDits peut polir ton texte avec un modèle d'IA. Tu choisis ton modèle, tu choisis quand.</p><ul className="check-list"><li>Cinq prompts pré-faits: juridique, comptable, médical, technique, nettoyage général</li><li>Tes propres clés API ou ton propre serveur local</li><li>Optionnel -- rien n'est activé sans toi</li></ul></div><Placeholder label="G" title="Petit diagramme -- " className="diagram" src="assets/ai-diagram.png" alt="Diagramme du post-traitement IA optionnel." /></section>
        <section className="section-pad pricing" id="prix"><SectionNumber n="07" /><article className="price-card sketch-card"><div className="tape"></div><p className="kicker">Soutenir le projet</p><h2>Gratuit en bêta. Mais pas gratuit à construire.</h2><p>On veut que le monde essaie MotsDits, le critique, puis nous aide à l'améliorer. Si tu t'en sers pour ta job, si ça te sauve du temps, ou si tu veux juste que l'app continue à vivre: participe à la hauteur que ça vaut pour toi.</p><p>On ne te force pas. On ne te surveille pas. On te fait confiance.</p><ul className="check-list"><li>Interac: allo@motsdits.ca</li><li>Paiement par carte ou PayPal: disponible sur la page de soutien</li><li>Versions organisation disponibles sur demande</li></ul><a className="btn primary" href="don/">Contribuer</a></article></section><div className="section-divider" aria-hidden="true"><span></span><span className="ornament">⚜</span><span></span></div><section className="section-pad optional" id="organisations"><div className="optional-text"><SectionNumber n="08" /><p className="kicker">Organisations</p><h2>Besoin d'une version adaptée à ton équipe?</h2><p>Pour les bureaux, cliniques, études, cabinets et équipes qui veulent une solution plus encadrée, on peut adapter MotsDits à votre environnement: vocabulaire spécialisé, prompts sur mesure, serveur central ou déploiement local.</p><p>On peut vous aider à choisir ou monter la machine nécessaire. On ne vend pas du support matériel infini: on vous met sur les rails proprement.</p><a className="btn primary" href="mailto:allo@motsdits.ca?subject=MotsDits%20pour%20mon%20organisation">Parler d'une version organisation</a></div><Placeholder label="H" title="Schéma organisation -- " className="org-art" src="assets/organisations.png" alt="Illustration du déploiement MotsDits pour une organisation." /></section>
        <section className="section-pad faq" id="faq"><div className="section-head"><SectionNumber n="09" /><div><p className="kicker">FAQ</p><h2>Les questions qui reviennent souvent.</h2></div></div><div className="faq-list">{faq.map(([q,a], i) => <details className="faq-item" key={q} open={i===0}><summary>{q}<span>⌄</span></summary><p>{a}</p></details>)}</div></section>
        <section className="final-cta" id="final"><h2>Prêt à parler québécois à ton ordi?</h2><a className="btn final" href={WINDOWS_DOWNLOAD_URL}>Télécharger pour Windows</a><p>Version Windows officielle. macOS suivra plus tard.</p></section>
      </main>
      <footer className="footer"><div><Logo small /><p>La transcription vocale pensée pour le Québec -- privée, locale, et qui comprend vraiment ton accent.</p><p>© 2026 Madera Tools</p></div><div><h3>Liens</h3><a href="#prix">Soutenir</a><a href="#organisations">Organisations</a><a href="#faq">FAQ</a></div><div><h3>Légal</h3><a href="/confidentialite/">Politique de confidentialité</a><a href="/conditions/">Conditions d'utilisation</a></div><div><h3>Contact</h3><p>allo@motsdits.ca</p><span className="fleur" aria-label="fleur de lys">⚜</span></div><p className="made">Fait avec coeur à Mont-Saint-Hilaire, Québec.</p></footer>
    </div>
  </>;
}

const css = `
@import url('https://fonts.googleapis.com/css2?family=Caveat:wght@500;700&family=Quattrocento:wght@400;700&family=Nunito:wght@500;700;800&display=swap');
:root{--paper-warmth:var(--ocd-tweak-paper-warmth,#FCF4DC);--accent-blue:var(--ocd-tweak-accent-blue,#8FB4D9);--sketch-tilt:var(--ocd-tweak-sketch-tilt,-.5);--hatch-opacity:var(--ocd-tweak-hatching-opacity,.1);--primary:#8FB4D9;--sky:#A5C8E1;--deep:#3E6FA0;--cream:#F8EBC8;--pale:#FCF4DC;--bg:#E8EDF5;--charcoal:#5A6478;--paper:#FAFAF7;--moss:#8FB29A;--gold:#F0D88B;--shadow:0 4px 16px rgba(58,64,78,.08)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:var(--bg);color:var(--charcoal);font-family:'Quattrocento',Georgia,serif;font-size:18px;line-height:1.55}a{color:inherit}.page{min-height:100vh;background-image:linear-gradient(45deg,rgba(62,111,160,.045) 25%,transparent 25%,transparent 50%,rgba(62,111,160,.045) 50%,rgba(62,111,160,.045) 75%,transparent 75%);background-size:22px 22px}.section-pad{width:min(1160px,calc(100% - 36px));margin-inline:auto;padding:78px 0}.topbar{position:sticky;top:12px;z-index:20;width:min(1160px,calc(100% - 28px));margin:12px auto 0;display:flex;align-items:center;gap:18px;justify-content:space-between;background:rgba(250,250,247,.86);border:1.8px solid var(--charcoal);border-radius:18px 14px 20px 16px;padding:10px 12px;box-shadow:var(--shadow);backdrop-filter:blur(8px);transform:rotate(-.15deg)}.brand-link{text-decoration:none}.logo{display:flex;align-items:center;gap:10px}.word{font-family:'Caveat',cursive;font-size:34px;font-weight:700;color:var(--deep);line-height:1}.word.small{font-size:29px}.mark{width:38px;height:38px;border:1.8px solid var(--charcoal);border-radius:14px 11px 13px 15px;background:var(--cream);position:relative;display:grid;place-items:center}.mic{width:10px;height:19px;border:2px solid var(--deep);border-radius:8px;position:relative}.mic:after{content:'';position:absolute;left:3px;bottom:-7px;width:2px;height:7px;background:var(--deep)}.bubble{position:absolute;right:-5px;top:3px;width:15px;height:12px;background:#8FB29A;border:1.5px solid var(--charcoal);border-radius:9px 8px 9px 5px}nav{display:flex;gap:18px;font-family:'Nunito',sans-serif;font-size:14px;font-weight:800}nav a{text-decoration:none;padding:7px 8px;border-radius:999px}nav a:hover,nav a:focus-visible{background:var(--cream);outline:2px dashed var(--deep);outline-offset:2px}.lang{display:flex;align-items:center;gap:5px;font-family:'Nunito';font-weight:800}.lang button{border:0;background:transparent;color:var(--charcoal);font:inherit;padding:6px 7px;border-radius:999px;cursor:pointer}.lang .active{background:var(--sky)}h1,h2{font-family:'Caveat',cursive;color:var(--deep);line-height:.95;margin-top:0}h1{font-size:clamp(4rem,10vw,8rem);letter-spacing:-.025em;margin-bottom:24px}h2{font-size:clamp(2.7rem,6vw,5.2rem);margin-bottom:16px}h3{font-family:'Nunito';color:var(--deep);font-size:1.15rem;margin:0 0 8px}.hero{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,520px);gap:42px;align-items:center;padding-top:92px}.eyebrow,.kicker{font-family:'Nunito';text-transform:uppercase;letter-spacing:.08em;font-size:.78rem;font-weight:800;color:var(--deep)}.eyebrow{display:inline-flex;gap:8px;align-items:center;background:var(--cream);border:1.5px solid var(--charcoal);border-radius:999px;padding:7px 12px;margin-bottom:18px}.eyebrow span{width:10px;height:10px;border-radius:50%;background:var(--primary);display:inline-block}.lead{font-size:clamp(1.15rem,2vw,1.5rem);max-width:640px}.hero-actions{display:flex;align-items:center;gap:22px;flex-wrap:wrap;margin:30px 0 12px}.btn{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;border:2px solid var(--charcoal);border-radius:999px;padding:13px 22px;font-family:'Nunito';font-weight:900;box-shadow:var(--shadow);transition:transform .18s ease}.btn.primary{background:var(--accent-blue);color:#26384c}.btn.secondary{background:var(--paper);color:var(--deep)}.btn:hover{transform:rotate(.7deg) translateY(-2px)}.btn:focus-visible,.text-link:focus-visible,summary:focus-visible{outline:3px dashed var(--deep);outline-offset:4px}.text-link{font-family:'Nunito';font-weight:900;color:var(--deep);text-decoration:none}.trust{font-family:'Nunito';font-size:.95rem;font-weight:800}.mobile-hero-actions,.mobile-trust{display:none}.placeholder,.sketch-card,.faq-item{position:relative;background-color:var(--paper);border:1.8px solid var(--charcoal);border-radius:14px 22px 16px 19px;box-shadow:var(--shadow);background-image:linear-gradient(45deg,rgba(90,100,120,var(--hatch-opacity)) 8.33%,transparent 8.33%,transparent 50%,rgba(90,100,120,var(--hatch-opacity)) 50%,rgba(90,100,120,var(--hatch-opacity)) 58.33%,transparent 58.33%);background-size:12px 12px}.placeholder{min-height:280px;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;padding:28px;transform:rotate(.6deg)}.placeholder strong{font-family:'Nunito';color:var(--deep);font-size:.9rem}.tape{position:absolute;top:-13px;left:13%;width:80px;height:24px;background:rgba(240,216,139,.62);border:1px solid rgba(90,100,120,.22);transform:rotate(-3deg)}.hero-art{aspect-ratio:6/5;background-color:var(--cream)}.section-head{display:flex;gap:18px;align-items:flex-start;margin-bottom:28px}.section-number{flex:none;width:48px;height:48px;border:2px solid var(--charcoal);border-radius:50% 45% 54% 43%;display:inline-grid;place-items:center;font-family:'Caveat';font-weight:700;font-size:1.55rem;color:var(--deep);background:var(--paper);transform:rotate(-4deg)}.problem-grid,.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}.problem-card,.person-card{padding:24px}.problem-card{position:relative;padding:22px 22px 22px 124px;min-height:130px;display:flex;align-items:center}.problem-card p{margin:0}.problem-doodle{position:absolute;left:-28px;top:50%;width:130px;height:130px;object-fit:contain;filter:drop-shadow(0 3px 6px rgba(248,235,200,.95)) drop-shadow(0 2px 4px rgba(90,100,120,.18));transform:translateY(-50%) rotate(-3deg)}.problem-card:nth-child(2) .problem-doodle{transform:translateY(-50%) rotate(2deg)}.problem-card:nth-child(3) .problem-doodle{transform:translateY(-50%) rotate(-1.5deg)}.problem-card p{font-size:1.25rem;font-weight:700}.doodle,.profession-icon{width:64px;height:64px;border:1.7px solid var(--charcoal);border-radius:21px 16px 19px 14px;background:var(--cream);display:grid;place-items:center;margin-bottom:15px}.drawn-icon{position:relative;width:42px;height:42px;display:block}.drawn-icon:before,.drawn-icon:after,.drawn-icon i{content:'';position:absolute;display:block;border:2px solid var(--deep)}.cloud:before{left:4px;top:18px;width:31px;height:15px;border-radius:18px 18px 12px 12px}.cloud:after{left:12px;top:9px;width:17px;height:17px;border-radius:50%;background:var(--cream)}.cloud i{right:1px;top:5px;width:10px;height:18px;border-width:0 2px 2px 0;transform:rotate(20deg)}.ear:before{left:11px;top:4px;width:21px;height:29px;border-radius:50%;border-left-width:3px}.ear:after{left:18px;top:14px;width:9px;height:14px;border-radius:50%;border-left:0}.ear i{right:2px;top:2px;width:8px;height:8px;border-radius:50%;border-left:0;border-bottom:0}.gear:before{left:7px;top:7px;width:28px;height:28px;border-radius:50%;background:repeating-linear-gradient(90deg,transparent 0 5px,rgba(62,111,160,.18) 5px 7px)}.gear:after{left:17px;top:17px;width:8px;height:8px;border-radius:50%;background:var(--cream)}.gavel:before{left:7px;top:12px;width:27px;height:10px;border-radius:5px;transform:rotate(-20deg)}.gavel:after{content:'';position:absolute;left:22px;top:19px;width:4px;height:22px;border-radius:4px;background:var(--deep);transform:rotate(-37deg)}.calc:before{left:8px;top:5px;width:27px;height:33px;border-radius:7px}.calc:after{left:13px;top:11px;width:17px;height:7px;border-radius:3px;background:var(--sky)}.calc i{left:13px;top:23px;width:3px;height:3px;box-shadow:9px 0 0 var(--deep),18px 0 0 var(--deep),0 9px 0 var(--deep),9px 9px 0 var(--deep),18px 9px 0 var(--deep);background:var(--deep);border:0}.stetho:before{left:8px;top:5px;width:24px;height:24px;border-top:0;border-radius:0 0 18px 18px}.stetho:after{left:27px;top:25px;width:9px;height:9px;border-radius:50%;background:#8FB29A}.laptop:before{left:7px;top:9px;width:28px;height:20px;border-radius:4px}.laptop:after{left:3px;top:31px;width:36px;height:5px;border-radius:6px;background:var(--sky)}.mug:before{left:9px;top:13px;width:22px;height:20px;border-radius:5px 5px 10px 10px;background:var(--pale)}.mug:after{right:3px;top:17px;width:10px;height:10px;border-radius:50%;border-left:0}.how{width:100%;background:var(--paper-warmth);border-block:2px solid var(--charcoal);padding:78px 0}.how-inner{width:min(1160px,calc(100% - 36px));margin-inline:auto}.step{padding:24px;min-height:auto}.step-image-wrap{position:relative}.step-n{position:absolute;top:10px;right:10px;width:38px;height:38px;border:2px solid var(--charcoal);border-radius:50% 45% 54% 43%;display:grid;place-items:center;font-family:'Caveat';font-weight:700;font-size:1.5rem;line-height:1;color:var(--deep);background:var(--paper);transform:rotate(-4deg);z-index:2;box-shadow:0 2px 4px rgba(58,64,78,.12)}.mini-art{min-height:132px;margin:0 0 16px;padding:16px;background:var(--cream);font-size:.92rem}.mini-art.image-placeholder{background:none;background-image:none;border:none;box-shadow:none;padding:0;min-height:auto;transform:none;margin:6px 0 18px;display:flex;justify-content:center;filter:drop-shadow(0 3px 6px rgba(248,235,200,.95)) drop-shadow(0 2px 4px rgba(90,100,120,.18))}.mini-art.image-placeholder .tape{display:none}.mini-art.image-placeholder img{display:block;width:auto;max-width:100%;max-height:200px;height:auto;object-fit:contain}.arrow{position:absolute;right:-28px;top:48%;font-family:'Caveat';font-size:3rem;color:var(--deep);z-index:2}.quote-line{font-family:'Caveat';font-size:clamp(2rem,4vw,3.6rem);color:var(--deep);text-align:center;margin:34px auto 0;max-width:860px}.audience-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:28px}.person-card{grid-column:span 2;position:relative;padding:22px 22px 22px 116px;min-height:130px;display:flex;flex-direction:column;justify-content:center}.person-card:nth-child(4){grid-column:2/span 2}.person-card:nth-child(5){grid-column:4/span 2}.person-card h3{margin:0 0 6px}.person-card p{margin:0}.audience-doodle{position:absolute;left:-26px;top:50%;width:120px;height:120px;object-fit:contain;filter:drop-shadow(0 3px 6px rgba(248,235,200,.95)) drop-shadow(0 2px 4px rgba(90,100,120,.18));transform:translateY(-50%) rotate(-3deg)}.person-card:nth-child(2) .audience-doodle{transform:translateY(-50%) rotate(2deg)}.person-card:nth-child(3) .audience-doodle{transform:translateY(-50%) rotate(-1.5deg)}.person-card:nth-child(4) .audience-doodle{transform:translateY(-50%) rotate(1deg)}.person-card:nth-child(5) .audience-doodle{transform:translateY(-50%) rotate(-2deg)}.quality{display:grid;grid-template-columns:minmax(0,1fr) minmax(360px,680px);gap:28px;align-items:center}.slider-card{padding:28px;margin:20px 0;background:var(--cream);transform:rotate(-.3deg)}.slider-labels{display:flex;justify-content:space-between;font-family:'Nunito';font-weight:900;color:var(--deep)}.slider-line{height:3px;background:var(--charcoal);margin:24px 30px 10px;position:relative}.slider-line span{position:absolute;top:50%;translate:-50% -50%;width:17px;height:17px;border-radius:50%;background:var(--sky);border:2px solid var(--charcoal)}.slider-line span:first-child{left:0}.slider-line span:nth-child(2){left:50%;background:var(--primary)}.slider-line span:last-child{left:100%}.balanced{text-align:center;font-family:'Caveat';font-size:2rem;color:var(--deep)}.quality-list{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.quality-list div{border-left:2px solid var(--charcoal);padding-left:12px}.app-shot{min-height:360px;background:var(--paper-warmth)}.app-shot.image-placeholder{background:none;background-image:none;border:none;box-shadow:none;padding:0;min-height:auto;transform:none;filter:drop-shadow(0 6px 14px rgba(58,64,78,.18))}.app-shot.image-placeholder .tape{display:none}.app-shot.image-placeholder img{width:100%;height:auto;max-height:none;border-radius:14px 22px 16px 19px;border:1.8px solid var(--charcoal)}.privacy{width:100%;background:var(--paper-warmth);border-block:2px solid var(--charcoal);padding:78px 0}.privacy-inner{width:min(1160px,calc(100% - 36px));margin-inline:auto;display:grid;grid-template-columns:minmax(0,1fr) minmax(380px,560px);gap:44px;align-items:center}.privacy h2{font-size:clamp(3.3rem,7vw,6rem)}.check-list{list-style:none;padding:0;margin:18px 0}.check-list li{margin:12px 0;padding-left:34px;position:relative}.check-list li:before{content:'✓';position:absolute;left:0;top:-2px;width:22px;height:22px;border:1.7px solid var(--charcoal);border-radius:50%;display:grid;place-items:center;background:#8FB29A;font-family:'Caveat';font-weight:700}.optional{display:grid;grid-template-columns:minmax(0,1fr) minmax(420px,640px);gap:34px;align-items:center}.org-art.image-placeholder{background:none;background-image:none;border:none;box-shadow:none;padding:0;min-height:auto;transform:rotate(1.2deg);display:flex;justify-content:center;align-items:center;filter:drop-shadow(0 3px 6px rgba(248,235,200,.95)) drop-shadow(0 2px 4px rgba(90,100,120,.18))}.org-art.image-placeholder .tape{display:none}.org-art.image-placeholder img{display:block;width:auto;max-width:100%;max-height:640px;height:auto;object-fit:contain}.optional-text{font-size:1.25rem}.diagram{min-height:180px;background:var(--cream)}.diagram.image-placeholder{background:none;background-image:none;border:none;box-shadow:none;padding:0;min-height:auto;transform:rotate(-.8deg);display:flex;justify-content:center;align-items:center;filter:drop-shadow(0 3px 6px rgba(248,235,200,.95)) drop-shadow(0 2px 4px rgba(90,100,120,.18))}.diagram.image-placeholder .tape{display:none}.diagram.image-placeholder img{display:block;width:100%;max-width:760px;max-height:none;height:auto;object-fit:contain}.pricing{text-align:center}.pricing>.section-number{margin-bottom:18px}.price-card{width:min(560px,100%);margin:auto;padding:38px;text-align:left;transform:rotate(calc(var(--sketch-tilt)*1deg));background:var(--cream)}.price-card h2{font-size:4.8rem}.price{font-size:1.35rem}.price s{opacity:.67}.price-card .btn{margin:12px 0;width:100%}.faq-list{display:grid;gap:14px}summary{cursor:pointer;list-style:none;padding:20px 22px;font-family:'Nunito';font-weight:900;color:var(--deep);display:flex;justify-content:space-between;gap:12px}summary::-webkit-details-marker{display:none}.faq-item p{padding:0 22px 20px;margin:0}.faq-item[open] summary span{transform:rotate(180deg)}.section-divider{display:flex;align-items:center;justify-content:center;gap:18px;padding:36px 0 4px;width:min(1160px,calc(100% - 36px));margin:0 auto;color:var(--charcoal)}.section-divider span:not(.ornament){flex:0 0 110px;height:0;border-top:1.6px dashed var(--charcoal);opacity:.45}.section-divider .ornament{font-size:1.5rem;color:#0C45A1;opacity:.65;transform:translateY(-2px)}.final-cta{background:var(--accent-blue);border-block:2px solid var(--charcoal);text-align:center;padding:70px 20px}.final-cta h2{color:#26384c;font-size:clamp(3.2rem,7vw,6rem)}.btn.final{background:var(--paper);color:var(--deep);margin:6px 0 12px}.footer{width:min(1160px,calc(100% - 36px));margin:0 auto;padding:46px 0 28px;display:grid;grid-template-columns:1.4fr .9fr .9fr 1fr;gap:26px;font-size:.96rem}.footer a{display:block;text-decoration:none;margin:6px 0}.fleur{font-size:2rem;color:#0C45A1;display:inline-block;margin-top:8px}.made{grid-column:1/-1;border-top:1.5px dashed var(--charcoal);padding-top:16px;text-align:center}.reveal{animation:fadeUp .55s ease both}.delay-1{animation-delay:.12s}@keyframes fadeUp{from{opacity:0;transform:translateY(10px) rotate(.3deg)}to{opacity:1;transform:translateY(0) rotate(.6deg)}}.image-placeholder{overflow:hidden;align-items:center;padding:18px}.image-placeholder img,.asset-strip img{display:block;width:100%;height:100%;object-fit:contain}.hero-art img{max-height:520px}.mini-art{padding:10px}.mini-art img{max-height:150px}.house-art img{max-height:340px}.house-art.image-placeholder{background:none;background-image:none;border:none;box-shadow:none;padding:0;min-height:auto;transform:rotate(-1.5deg);display:flex;justify-content:center;align-items:center;filter:drop-shadow(0 4px 10px rgba(90,100,120,.22))}.house-art.image-placeholder .tape{display:none}.house-art.image-placeholder img{display:block;width:100%;max-width:560px;max-height:none;height:auto;object-fit:contain}.asset-strip{grid-column:1/-1;min-height:260px;padding:18px;background:var(--cream)}.audience-strip{min-height:240px}.asset-strip+article{margin-top:0}@media (prefers-reduced-motion:reduce){*{scroll-behavior:auto!important;animation:none!important;transition:none!important}}@media(max-width:900px){.topbar{align-items:flex-start;flex-wrap:wrap}nav{order:3;width:100%;display:flex;justify-content:space-between;padding-top:10px;margin-top:2px;border-top:1.5px dashed rgba(90,100,120,.45);gap:6px}.mobile-hide{display:none}nav a{white-space:nowrap;text-align:center;background:rgba(248,235,200,.62);border:1px solid rgba(90,100,120,.32);font-size:12px;padding:7px 6px}.hero,.quality,.privacy-inner,.optional{grid-template-columns:1fr}.problem-grid,.steps{grid-template-columns:1fr}.problem-card{padding:22px 22px 22px 108px;min-height:120px}.problem-doodle{left:-18px;width:110px;height:110px}.arrow{display:none}.audience-grid{grid-template-columns:1fr}.person-card,.person-card:nth-child(4),.person-card:nth-child(5){grid-column:auto;padding:22px 22px 22px 104px;min-height:110px}.audience-doodle{left:-18px;width:104px;height:104px}.quality-list{grid-template-columns:1fr}.footer{grid-template-columns:1fr 1fr}.hero{padding-top:58px}}@media(max-width:560px){body{font-size:16px}.section-pad{width:min(100% - 24px,1160px);padding:36px 0}.topbar{top:6px;width:calc(100% - 16px);margin-top:6px}.word{font-size:28px}nav{gap:6px;font-size:13px}.lang{margin-left:auto}.hero-actions{align-items:stretch}.desktop-hero-actions,.desktop-trust{display:none}.mobile-hero-actions,.mobile-trust{display:flex}.mobile-trust{display:block}.btn.primary,.hero-actions .text-link{width:100%;justify-content:center}.placeholder{padding:20px;min-height:220px}h1{font-size:3.4rem;line-height:1.02}h2{font-size:2.6rem}.privacy h2,.final-cta h2{font-size:2.9rem}.section-number{width:42px;height:42px}.price-card{padding:26px}.price-card h2{font-size:3.2rem}.support-card h2{font-size:3rem}.footer{grid-template-columns:1fr}.privacy,.how{padding:36px 0}.optional-text{font-size:1.08rem}.btn.final{width:100%;margin:6px 0}.final-cta{padding:54px 16px}.hero{padding-top:36px}.mobile-hero-actions{margin:20px 0 8px}.mobile-trust{margin:0;font-size:.88rem;opacity:.86;text-align:center}.section-divider span:not(.ornament){flex:0 0 60px}.problem-card{padding:22px 22px 22px 96px;min-height:110px}.problem-doodle{left:-14px;width:96px;height:96px}.person-card,.person-card:nth-child(4),.person-card:nth-child(5){padding:22px 22px 22px 96px}.audience-doodle{left:-14px;width:92px;height:92px}}
`;

ReactDOM.createRoot(document.getElementById('root')).render(<App />);