:root{
  /* map vers ton thème dark de main.css */
  --color-bg: #0b1220;
  --color-surface: #0f172a;
  --color-border: #334155;
  --color-text: #e5e7eb;
  --color-muted: #94a3b8;
  --color-primary: #2563eb;
  --color-secondary: #3b82f6;
  --radius: 14px;
  --radius-sm: 10px;
  --container: 1100px;
  --shadow: 0 10px 30px rgba(0,0,0,.20);
  --shadow-sm: 0 4px 14px rgba(0,0,0,.12);
}


*{box-sizing:border-box} html,body{height:100%}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Inter,Arial,sans-serif;background:var(--color-bg);color:var(--color-text)}
img{max-width:100%;display:block} a{text-decoration:none;color:inherit}
a:focus-visible,button:focus-visible,select:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}
.container{max-width:var(--container);margin-inline:auto;padding-inline:16px}
.muted{color:var(--color-muted)}

.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{left:16px;top:12px;width:auto;height:auto;padding:8px 10px;background:var(--color-primary);color:#fff;border-radius:var(--radius-sm)}

.site-header{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--color-bg) 92%,transparent);backdrop-filter:blur(8px);border-bottom:1px solid var(--color-border)}
.nav{height:64px;display:flex;align-items:center;gap:16px}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;color:var(--color-primary)}
.brand__logo{aspect-ratio:1}
.nav__menu{margin-left:auto;display:flex;align-items:center;gap:14px}
.nav__link{padding:8px 10px;border-radius:10px}
.nav__link:hover{background:var(--color-surface)}
.nav__select{appearance:none;background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text);padding:8px 10px;border-radius:10px}
.nav__burger{display:none;background:none;border:0;padding:10px;border-radius:10px}
.burger-line{display:block;width:22px;height:2px;background:var(--color-text);margin:4px 0}

@media (max-width:860px){
  .nav__burger{display:inline-flex}
  .nav__menu{position:absolute;top:64px;right:12px;left:12px;display:grid;gap:10px;padding:12px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow);transform-origin:top right;transform:scale(.98);opacity:0;pointer-events:none}
  .nav__menu.is-open{transform:scale(1);opacity:1;pointer-events:auto}
}
.btn{--btn-bg:var(--color-primary);--btn-fg:#fff;background:var(--btn-bg);color:var(--btn-fg);border:1px solid color-mix(in srgb,var(--btn-bg) 85%,black 0%);padding:10px 14px;border-radius:12px;font-weight:600;cursor:pointer;box-shadow:var(--shadow-sm)}
.btn:hover{filter:brightness(.98);transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn--ghost{background:transparent;color:var(--color-text);border:1px solid var(--color-border)}
.btn--outline{background:transparent;color:var(--color-primary);border:1px solid var(--color-primary)}
.btn--lg{padding:12px 18px;border-radius:var(--radius)}
.btn--sm{padding:8px 12px;border-radius:10px;font-size:.92rem}

.hero{display:grid;grid-template-columns:1.1fr .9fr;gap:32px;padding-block:42px;align-items:center}
.hero__title{font-size:var(--step-1);line-height:1.2;margin:0 0 12px}
.hero__subtitle{color:var(--color-muted);margin:0 0 16px}
.hero__cta{display:flex;gap:10px;margin-bottom:12px}
.hero__bullets{list-style:none;padding:0;margin:10px 0 0;display:grid;gap:6px}
.hero__art{display:grid;place-items:center}
.hero-card{background:linear-gradient(180deg,color-mix(in srgb,var(--color-secondary) 12%,transparent),var(--color-surface));border:1px solid var(--color-border);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);transform:rotate(.5deg)}
.hero-card__badge{display:inline-block;background:var(--color-accent);color:#fff;padding:6px 10px;border-radius:999px;font-size:.85rem;margin-bottom:10px}
.hero-card__icon{font-size:32px}
.hero-card__title{font-weight:700;margin-top:6px}
.hero-card__desc{color:var(--color-muted)}

@media (max-width:980px){.hero{grid-template-columns:1fr}}

.features{padding-block:28px;display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:16px;transition:transform .2s ease,box-shadow .2s ease,background .2s ease;outline:none}
.card:hover,.card:focus-visible{transform:translateY(-2px);box-shadow:var(--shadow);background:color-mix(in srgb,var(--color-surface) 60%,var(--color-bg) 40%)}
.card__icon{font-size:24px}
.card__title{margin:6px 0 6px;font-weight:700}
.card__desc{margin:0 0 12px;color:var(--color-muted)}
.card__btn{inline-size:max-content}

@media (max-width:980px){.features{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.features{grid-template-columns:1fr}}

.pricing{padding-block:40px}
.pricing__row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.price-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow-sm)}
.price{font-size:28px;font-weight:800;color:var(--color-primary);margin:6px 0 12px}
.price .unit{font-size:14px;color:var(--color-muted)}
@media (max-width:640px){.pricing__row{grid-template-columns:1fr}}

.faq{padding-block:36px}
.faq details{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:10px 12px}
.faq details+details{margin-top:10px}
.faq summary{cursor:pointer;font-weight:600}

.site-footer{margin-top:42px;border-top:1px solid var(--color-border);padding-block:24px;background:color-mix(in srgb,var(--color-surface) 70%,var(--color-bg) 30%)}
.footer__grid{display:grid;grid-template-columns:1.2fr .8fr .8fr;gap:16px;align-items:start}
.footer__links{list-style:none;padding:0;margin:0;display:grid;gap:6px}
.footer__copy{margin-top:10px;text-align:center;color:var(--color-muted)}
@media (max-width:860px){.footer__grid{grid-template-columns:1fr}}

.modal[hidden]{display:none!important}
.modal__backdrop{position:fixed;inset:0;background:rgba(0,0,0,.4)}
.modal__card{position:fixed;inset:0;margin:auto;width:min(560px,92vw);background:var(--color-bg);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow)}
.modal__header,.modal__footer{padding:12px 16px;border-bottom:1px solid var(--color-border)}
.modal__footer{border-bottom:0;border-top:1px solid var(--color-border)}
.modal__body{padding:16px;color:var(--color-muted)}
.modal__close{background:transparent;border:0;font-size:20px;cursor:pointer}

.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}


/* --- Loader / Progress --- */
.progress-wrap { margin-top: 12px; display: none; }
.progress { height: 8px; border-radius: 999px; background: var(--color-surface); border: 1px solid var(--color-border); overflow: hidden; }
.progress__bar { width: 40%; height: 100%; background: linear-gradient(90deg, var(--color-primary), var(--color-secondary));
  animation: prog 1.2s linear infinite; }
@keyframes prog { 0%{transform: translateX(-100%)} 100%{transform: translateX(200%)} }
.btn[disabled] { opacity: .6; cursor: not-allowed; }









/* === Lisibilité sur fonds clairs === */
.white-box, .info-card, .result-card, .highlight-section {
  background: #fff;
  color: #111 !important;
  border-radius: 12px;
  box-shadow: 0 2px 10px rgba(0,0,0,0.08);
  padding: 1.2rem 1.5rem;
}

/* Texte principal sur fond clair */
.white-box h3, .info-card h3, .result-card h3 {
  color: #0a0a0a;
  font-weight: 600;
}
.white-box p, .info-card p, .result-card p {
  color: #333 !important;
  line-height: 1.6;
  font-size: 0.95rem;
}

/* Titres de section */
.section-title {
  color: #f5f5f5;
  font-size: 1.4rem;
  font-weight: 600;
  margin-bottom: 0.8rem;
}

/* === Boutons === */
.btn-primary {
  background: linear-gradient(90deg, #0066ff, #0099ff);
  color: #fff !important;
  border: none;
  font-weight: 600;
  transition: 0.3s ease;
}
.btn-primary:hover {
  background: linear-gradient(90deg, #0052cc, #007acc);
  transform: translateY(-1px);
}

.btn-outline {
  background: transparent;
  color: #fff !important;
  border: 1px solid rgba(255,255,255,0.3);
  transition: 0.3s;
}
.btn-outline:hover {
  background: rgba(255,255,255,0.1);
}

/* === Détails techniques === */
.tech-details {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  margin-top: 1rem;
}
.tech-details .item {
  flex: 1;
  min-width: 180px;
  background: rgba(255,255,255,0.08);
  border-radius: 10px;
  padding: 0.8rem 1rem;
  color: #fff;
  text-align: center;
  transition: 0.3s ease;
}
.tech-details .item:hover {
  background: rgba(255,255,255,0.15);
}
.tech-details .label {
  font-size: 0.9rem;
  opacity: 0.7;
}
.tech-details .value {
  font-weight: 600;
  font-size: 1.1rem;
}

/* === Zone “Partagez et gagnez” === */
.share-box {
  background: #fff8f0;
  color: #222 !important;
  border-radius: 12px;
  padding: 1.5rem;
  margin-top: 1.5rem;
  text-align: center;
  border: 1px solid #ffe2b6;
}
.share-box h4 {
  color: #ff9800;
  font-weight: 600;
}
.share-box p {
  color: #444;
  margin-bottom: 1rem;
}
.share-box .btn-affiliate {
  background: #ffb74d;
  border: none;
  color: #fff;
  font-weight: 600;
}
.share-box .btn-affiliate:hover {
  background: #ff9800;
}



/* ===== Lisibilité parfaite sur fonds clairs ===== */
.white-box,
.info-card,
.result-card,
.highlight-section,
.cta-banner {
  background: #fff !important;
  color: #0b0b0b !important;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.08);
  padding: 16px 18px;
}

/* Titres et paragraphes sur clair */
.white-box h1, .white-box h2, .white-box h3,
.info-card h1, .info-card h2, .info-card h3,
.result-card h1, .result-card h2, .result-card h3,
.cta-banner h1, .cta-banner h2, .cta-banner h3 {
  color: #0a0a0a !important;
  font-weight: 700;
  margin: 0 0 6px;
}
.white-box p, .info-card p, .result-card p, .cta-banner p {
  color: #2b2b2b !important;
  line-height: 1.6;
  font-size: 0.98rem;
}

/* Neutralise les styles "muted" hérités dans ces blocs */
.white-box .muted, .info-card .muted, .result-card .muted, .cta-banner .muted {
  color: #4a4a4a !important;
  opacity: 1 !important;
}

/* Boutons dans un bloc clair */
.white-box .btn--ghost, .cta-banner .btn--ghost {
  border-color: #d1d5db !important;
  color: #111 !important;
  background: transparent !important;
}
.white-box .btn-primary, .cta-banner .btn-primary {
  background: linear-gradient(90deg, #0066ff, #0099ff) !important;
  color: #fff !important;
  border: none !important;
  font-weight: 700;
}
.white-box .btn-primary:hover, .cta-banner .btn-primary:hover {
  background: linear-gradient(90deg, #0052cc, #007acc) !important;
  transform: translateY(-1px);
}

/* Grille "Détails techniques" assombrie (lisible sur dark) */
.tech-details .item {
  background: rgba(148, 163, 184, 0.12);
  border: 1px solid rgba(148, 163, 184, 0.25);
  color: #f8fafc;
}
.tech-details .item .label { opacity: .9; }
.tech-details .item .value { color: #fff; }

/* Bannière partage (crème) */
.share-box{
  background: #fff8f0 !important;
  border: 1px solid #ffe2b6 !important;
  color: #222 !important;
}
.share-box h4{ color:#ff9800 !important; }
.share-box p{ color:#3f3f3f !important; }
.share-box .btn-affiliate{
  background:#ffb74d !important; color:#fff !important; border:none !important; font-weight:700;
}
.share-box .btn-affiliate:hover{ background:#ff9800 !important; }

/* Bandeau de validation en haut du résultat */
.cta-banner {
  display:flex; align-items:center; gap:12px; justify-content:space-between;
  margin-bottom: 12px;
}
.cta-banner__text {
  display:flex; flex-direction:column; gap:2px;
}
.cta-banner__title { font-size: 1.05rem; }
.cta-banner__subtitle { color:#3b3b3b !important; }



/* ... tout ton CSS précédent ... */


/* === Ajout spécial : Cartes modèles CV sur fond blanc === */
.cv-template-card {
  background: #fff;
  color: #161616 !important;
  border-radius: 14px;
  box-shadow: 0 2px 14px rgba(0,0,0,0.09);
  padding: 1.3rem 1.6rem;
  margin-bottom: 24px;
  border: 1px solid #e5e7eb;
}

/* Titres et sous-titres des modèles */
.cv-template-card h3,
.cv-template-card strong {
  color: #181818 !important;
  font-weight: 700;
  margin-bottom: 6px;
  font-size: 1.25em;
}

.cv-template-card p {
  color: #242424 !important;
  line-height: 1.6;
  font-size: 1.04em;
}

.cv-template-card em {
  color: #555 !important;
  font-style: italic;
  font-size: 0.96em;
  display: block;
  margin-top: 8px;
}

/* Optionnel : animation légère au survol */
.cv-template-card:hover {
  box-shadow: 0 8px 28px rgba(15, 23, 42, 0.13);
  transform: translateY(-2px) scale(1.01);
  transition: box-shadow 0.2s, transform 0.2s;
}

/* Pour éviter l'héritage d'un style trop clair */
.cv-template-card *,
.cv-template-card *:not(em) {
  color: inherit !important;
}

/* ... ton CSS existant continue ... */


<style>
  body {
    background: #f8f9fc;
    font-size: 18px; /* Taille globale augmentée */
    line-height: 1.6;
    font-family: Arial, sans-serif;
  }

  h1 { font-size: 2.4em; }
  h2 { font-size: 2em; }
  h3 { font-size: 1.6em; }

  .form-section input,
  button,
  textarea {
    width: 100%;
    padding: 14px; /* un peu plus grand */
    margin-top: 5px;
    font-size: 1em;
    box-sizing: border-box;
  }

  button {
    background-color: #007bff;
    border: none;
    color: white;
    padding: 14px; /* plus grand pour cliquer facilement */
    border-radius: 8px;
    cursor: pointer;
    font-weight: 500;
    font-size: 1.1em;
  }

  button:hover { background-color: #0056b3; }

  textarea { min-height: 100px; resize: vertical; font-size: 1em; }

  .fade-in { animation: fadeIn 0.8s ease-in-out; }
  @keyframes fadeIn { from {opacity:0;transform:translateY(15px);} to {opacity:1;transform:none;} }

  .cv-template-card {
    background: white; padding: 1.5em; border-radius: 12px;
    box-shadow: 0 4px 10px rgba(0,0,0,0.08); margin-bottom: 1.2em;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    font-size: 1em;
  }

  .cv-template-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 6px 15px rgba(0,0,0,0.12);
  }

  .cv-template-card h3 { margin-bottom: 0.4em; color: #007bff; font-size: 1.3em; }
  .cv-template-card em { color: #555; font-style: italic; display: block; margin-top: 0.4em; font-size: 0.95em; }

  #enhanced-exp, #optimized-skills, #cv-analysis {
    background: #fff; padding: 1.2em; border-radius: 10px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.08); margin-top: 1em;
    font-size: 1em;
  }

  .white-box { background:#f9fafb; padding:12px; border-radius:8px; font-size:1em; }
</style>




<style>
  body {
    background: #f8f9fc;
    font-size: 18px;
    line-height: 1.6;
    font-family: Arial, sans-serif;
  }

  h1 { font-size: 2.4em; text-align:center; }
  h2 { font-size: 2em; margin-top:1.5em; }
  h3 { font-size: 1.6em; }

  form {
    display: flex;
    flex-direction: column;
    gap: 15px;
    background: #fff;
    padding: 20px;
    border-radius: 12px;
    box-shadow: 0 4px 10px rgba(0,0,0,0.08);
    margin-bottom: 2em;
  }

  .form-group {
    display: flex;
    flex-direction: column;
    gap: 5px;
  }

  label {
    font-weight: 600;
    margin-bottom: 5px;
  }

  input, textarea {
    padding: 12px;
    border: 1px solid #ccc;
    border-radius: 8px;
    font-size: 1em;
    width: 100%;
    box-sizing: border-box;
    transition: border 0.2s;
  }

  input:focus, textarea:focus {
    border-color: #007bff;
    outline: none;
  }

  button {
    background-color: #007bff;
    border: none;
    color: white;
    padding: 14px;
    border-radius: 8px;
    cursor: pointer;
    font-weight: 500;
    font-size: 1.1em;
    transition: background 0.2s;
  }

  button:hover { background-color: #0056b3; }

  /* Responsivité */
  @media(min-width: 768px) {
    .form-group {
      flex-direction: row;
      align-items: center;
    }
    .form-group label {
      width: 30%;
      margin-bottom: 0;
    }
    .form-group input, .form-group textarea {
      width: 70%;
    }
  }

  #enhanced-exp, #optimized-skills, #cv-analysis {
    background: #fff; padding: 1.2em; border-radius: 10px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.08); margin-top: 1em;
    font-size: 1em;
  }

  .cv-template-card {
    background: white; padding: 1.5em; border-radius: 12px;
    box-shadow: 0 4px 10px rgba(0,0,0,0.08); margin-bottom: 1.2em;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    font-size: 1em;
  }

  .cv-template-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 6px 15px rgba(0,0,0,0.12);
  }

  .cv-template-card h3 { margin-bottom: 0.4em; color: #007bff; font-size: 1.3em; }
  .cv-template-card em { color: #555; font-style: italic; display: block; margin-top: 0.4em; font-size: 0.95em; }

  .white-box { background:#f9fafb; padding:12px; border-radius:8px; font-size:1em; }
</style>
