/* ==========================================================================
   Calculateur-France — design system v2 « éditorial tricolore »
   Fraunces (titres) · IBM Plex Sans (texte) · IBM Plex Mono (données/labels)
   Palette bleu/blanc/rouge désaturée, fond crème. Inspiré de mises en page
   éditoriales (sur-titres, grands serifs, respiration, illustrations).
   ========================================================================== */

:root {
  /* Tricolore désaturé */
  --bleu:        #3c5a86;   /* bleu ardoise */
  --bleu-fonce:  #2a3f5f;
  --bleu-pale:   #e7ecf3;
  --rouge:       #bc5a4e;   /* terre de brique */
  --rouge-fonce: #9c463c;
  --rouge-pale:  #f4e6e2;

  /* Neutres chauds */
  --creme:       #f4efe5;   /* fond */
  --papier:      #fbf8f1;   /* cartes */
  --papier-2:    #f0e9da;
  --encre:       #20242e;   /* texte */
  --encre-doux:  #5c6068;
  --ligne:       #e2dac9;
  --ligne-forte: #cdc3ad;

  --ombre:    0 1px 2px rgba(40,35,20,.05);
  --ombre-mg: 0 8px 28px rgba(40,35,20,.10);

  --serif: "Fraunces", Georgia, "Times New Roman", serif;
  --sans:  "IBM Plex Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --mono:  "IBM Plex Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;

  --max: 1140px;
  --rayon: 10px;
}

html[data-theme="dark"] {
  --bleu:        #7b9fd4;
  --bleu-fonce:  #5d80b5;
  --bleu-pale:   #232c3b;
  --rouge:       #d98b80;
  --rouge-pale:  #2c2622;
  --creme:       #14161c;
  --papier:      #1c1f27;
  --papier-2:    #232732;
  --encre:       #ece8df;
  --encre-doux:  #a3a8b3;
  --ligne:       #2f3440;
  --ligne-forte: #3c4250;
  --ombre-mg: 0 8px 28px rgba(0,0,0,.45);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: var(--sans);
  font-size: 17px;
  color: var(--encre);
  background: var(--creme);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* grain papier très léger */
body::before {
  content: ""; position: fixed; inset: 0; pointer-events: none; z-index: 0;
  background-image: radial-gradient(rgba(120,100,60,.025) 1px, transparent 1px);
  background-size: 4px 4px; opacity: .6;
}
body > * { position: relative; z-index: 1; }

a { color: var(--bleu-fonce); text-decoration: none; }
a:hover { text-decoration: underline; }

.contenu { max-width: var(--max); margin: 0 auto; padding: 0 24px; }
.contenu-etroit { max-width: 760px; margin: 0 auto; padding: 0 24px; }

/* ---------- Typo ---------- */
h1, h2, h3, h4 { font-family: var(--serif); font-weight: 500; line-height: 1.12; letter-spacing: -.01em; margin: 0; }
h1 { font-size: clamp(2.4rem, 5vw, 3.9rem); font-optical-sizing: auto; }
h2 { font-size: clamp(1.8rem, 3.4vw, 2.6rem); }
h3 { font-size: 1.3rem; }
.serif-italic { font-style: italic; color: var(--rouge); }

/* Sur-titre (eyebrow) — signature des sites de référence */
.eyebrow {
  font-family: var(--mono); font-size: .76rem; font-weight: 500;
  letter-spacing: .18em; text-transform: uppercase; color: var(--rouge);
  display: inline-flex; align-items: center; gap: 9px; margin-bottom: 14px;
}
.eyebrow::before { content: ""; width: 22px; height: 1px; background: var(--rouge); display: inline-block; }

.mono { font-family: var(--mono); }

/* ---------- En-tête ---------- */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: color-mix(in srgb, var(--creme) 88%, transparent);
  backdrop-filter: saturate(150%) blur(8px);
  border-bottom: 1px solid var(--ligne);
}
.nav { display: flex; align-items: center; gap: 20px; max-width: var(--max); margin: 0 auto; padding: 14px 24px; }
.logo { font-family: var(--serif); font-weight: 600; font-size: 1.2rem; color: var(--encre); display: flex; align-items: center; gap: 9px; white-space: nowrap; }
.logo:hover { text-decoration: none; }
.logo .drapeau { font-size: 1.05rem; }
.nav-links { display: flex; gap: 2px; flex-wrap: wrap; margin-left: auto; }
.nav-links a { font-family: var(--mono); color: var(--encre-doux); font-size: .82rem; letter-spacing: .02em; padding: 7px 12px; border-radius: 7px; }
.nav-links a:hover { background: var(--bleu-pale); color: var(--bleu-fonce); text-decoration: none; }
.theme-toggle { background: var(--papier); border: 1px solid var(--ligne-forte); border-radius: 8px; cursor: pointer; font-size: 1rem; width: 38px; height: 38px; line-height: 1; color: var(--encre); }

/* ---------- Fil d'Ariane ---------- */
.fil { font-family: var(--mono); font-size: .78rem; color: var(--encre-doux); padding: 22px 0 0; letter-spacing: .02em; }
.fil a { color: var(--encre-doux); }

/* ---------- Hero ---------- */
.hero { padding: 56px 0 28px; }
.hero-split { display: grid; grid-template-columns: 1.15fr .85fr; gap: 40px; align-items: center; }
.hero h1 { margin-bottom: 18px; }
.hero .accroche { font-size: 1.18rem; color: var(--encre-doux); max-width: 540px; }
.hero-illus { position: relative; }
.hero-illus img { width: 100%; height: auto; display: block; filter: drop-shadow(0 14px 24px rgba(40,35,20,.12)); }
.hero-illus .pastille {
  position: absolute; bottom: 6%; left: -6%; background: var(--papier);
  border: 1px solid var(--ligne-forte); border-radius: 999px; padding: 9px 16px;
  font-family: var(--mono); font-size: .8rem; box-shadow: var(--ombre-mg); white-space: nowrap;
}
.hero-illus .pastille b { color: var(--rouge); }

.cta-rangee { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 26px; align-items: center; }

/* Bandeau confiance sous hero */
.trust-strip {
  display: flex; flex-wrap: wrap; gap: 10px 26px; align-items: center;
  font-family: var(--mono); font-size: .82rem; color: var(--encre-doux);
  margin-top: 30px; padding-top: 22px; border-top: 1px solid var(--ligne);
}
.trust-strip span { display: inline-flex; align-items: center; gap: 8px; }
.trust-strip .pt { color: var(--bleu); }

/* ---------- Boutons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  font-family: var(--mono); font-weight: 500; font-size: .92rem; letter-spacing: .01em;
  background: var(--bleu); color: #fff; border: 1px solid var(--bleu);
  padding: 13px 22px; border-radius: var(--rayon); cursor: pointer; width: 100%;
  transition: transform .1s ease, background .15s ease;
}
.btn:hover { background: var(--bleu-fonce); border-color: var(--bleu-fonce); text-decoration: none; transform: translateY(-1px); }
.btn-rouge { background: var(--rouge); border-color: var(--rouge); }
.btn-rouge:hover { background: var(--rouge-fonce); border-color: var(--rouge-fonce); }
.btn-ghost { background: transparent; color: var(--bleu-fonce); border: 1px solid var(--ligne-forte); width: auto; }
.btn-ghost:hover { background: var(--bleu-pale); transform: none; }
.btn-sec { background: var(--papier-2); color: var(--encre); border: 1px solid var(--ligne-forte); width: auto; }
.btn-sec:hover { background: var(--bleu-pale); transform: none; }
.lien-fleche { font-family: var(--mono); font-size: .85rem; color: var(--bleu-fonce); display: inline-flex; gap: 6px; align-items: center; }
.lien-fleche:hover .fl { transform: translateX(3px); }
.lien-fleche .fl { transition: transform .15s ease; }

/* ---------- Sections ---------- */
.section { padding: 54px 0; }
.section-titre { max-width: 680px; margin-bottom: 30px; }
.section-titre p { color: var(--encre-doux); margin: 12px 0 0; }
.section--creme2 { background: var(--papier-2); border-top: 1px solid var(--ligne); border-bottom: 1px solid var(--ligne); }
.section--bleu {
  background: var(--bleu-fonce); color: #fff;
  border-top: 1px solid var(--bleu-fonce);
}
.section--bleu h2, .section--bleu h3 { color: #fff; }
.section--bleu .eyebrow { color: #e9b7af; }
.section--bleu .eyebrow::before { background: #e9b7af; }
.section--bleu p { color: rgba(255,255,255,.82); }

/* ---------- Grilles & cartes ---------- */
.grille { display: grid; gap: 18px; }
.col-3 { grid-template-columns: repeat(3, 1fr); }
.col-2 { grid-template-columns: repeat(2, 1fr); }
.col-4 { grid-template-columns: repeat(4, 1fr); }

.carte {
  background: var(--papier); border: 1px solid var(--ligne); border-radius: var(--rayon);
  padding: 24px; display: block; transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease;
}
.carte:hover { transform: translateY(-3px); box-shadow: var(--ombre-mg); border-color: var(--ligne-forte); text-decoration: none; }
.carte .ico { font-size: 1.7rem; line-height: 1; }
.carte h3 { margin: 14px 0 6px; color: var(--encre); font-size: 1.15rem; }
.carte p { margin: 0; color: var(--encre-doux); font-size: .92rem; }
.carte .tag { font-family: var(--mono); font-size: .72rem; color: var(--rouge); letter-spacing: .04em; }

/* Carte calculateur « vedette » avec illustration */
.carte-vedette { display: grid; grid-template-columns: 1fr auto; gap: 16px; align-items: center; }
.carte-vedette img { width: 78px; height: 78px; object-fit: contain; }

/* ---------- Catégorie : titre + compte ---------- */
.cat-head { display: flex; align-items: baseline; gap: 14px; margin: 0 0 18px; }
.cat-head h2 { font-size: 1.7rem; }
.cat-head .compte { font-family: var(--mono); font-size: .8rem; color: var(--encre-doux); }

/* ---------- Étapes (how it works) ---------- */
.etapes { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; }
.etape { padding-top: 18px; border-top: 2px solid var(--bleu); }
.etape .num { font-family: var(--mono); font-size: .8rem; color: var(--rouge); }
.etape h3 { margin: 8px 0 6px; }
.etape p { color: var(--encre-doux); margin: 0; font-size: .95rem; }

/* ---------- Stats ---------- */
.stats { display: grid; grid-template-columns: repeat(4,1fr); gap: 18px; }
.stat { text-align: center; }
.stat .chiffre { font-family: var(--serif); font-size: 2.6rem; line-height: 1; color: var(--bleu); }
.stat .chiffre.r { color: var(--rouge); }
.stat .label { font-family: var(--mono); font-size: .78rem; color: var(--encre-doux); margin-top: 8px; letter-spacing: .03em; }

/* ---------- Réassurance ---------- */
.reassur { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; }
.reassur .item { display: flex; gap: 14px; }
.reassur .b { font-size: 1.5rem; flex-shrink: 0; }
.reassur h3 { font-size: 1.1rem; margin-bottom: 4px; }
.reassur p { margin: 0; color: var(--encre-doux); font-size: .92rem; }

/* Illustration + texte en deux colonnes */
.duo { display: grid; grid-template-columns: 1fr 1fr; gap: 44px; align-items: center; }
.duo img { width: 100%; max-width: 420px; height: auto; }
.duo--rev .txt { order: 2; }

/* ---------- Page calculateur ---------- */
.calc-head { display: grid; grid-template-columns: 1fr auto; gap: 24px; align-items: center; padding: 36px 0 10px; }
.calc-head img { width: 130px; height: 130px; object-fit: contain; }
.calc-card { background: var(--papier); border: 1px solid var(--ligne-forte); border-radius: 14px; padding: 30px; box-shadow: var(--ombre); }
.calc-card h2 { margin-top: 0; }

.champ { margin-bottom: 20px; }
.champ label { display: block; font-family: var(--mono); font-weight: 500; font-size: .82rem; letter-spacing: .03em; text-transform: uppercase; margin-bottom: 8px; color: var(--encre); }
.champ .aide { font-family: var(--sans); text-transform: none; letter-spacing: 0; font-weight: 400; color: var(--encre-doux); font-size: .8rem; }
.champ input, .champ select {
  width: 100%; padding: 13px 14px; font-size: 1.05rem; font-family: var(--mono);
  border: 1px solid var(--ligne-forte); border-radius: var(--rayon);
  background: var(--creme); color: var(--encre);
}
.champ input:focus, .champ select:focus { outline: 2px solid var(--bleu); border-color: var(--bleu); }
.champ-ligne { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }

.input-suffixe { position: relative; }
.input-suffixe .suffixe { position: absolute; right: 14px; top: 50%; transform: translateY(-50%); color: var(--encre-doux); font-family: var(--mono); font-size: .95rem; pointer-events: none; }
.input-suffixe input { padding-right: 42px; }

.radio-groupe { display: flex; gap: 10px; flex-wrap: wrap; }
.radio-groupe label { flex: 1; min-width: 120px; text-align: center; cursor: pointer; border: 1px solid var(--ligne-forte); border-radius: var(--rayon); padding: 11px; font-family: var(--mono); font-size: .85rem; margin: 0; text-transform: none; letter-spacing: 0; }
.radio-groupe input { display: none; }
.radio-groupe label:has(input:checked) { border-color: var(--bleu); background: var(--bleu-pale); color: var(--bleu-fonce); font-weight: 600; }

/* ---------- Résultat ---------- */
.resultat { margin-top: 26px; border-radius: 14px; overflow: hidden; border: 1px solid var(--ligne-forte); }
.resultat-principal { background: linear-gradient(150deg, var(--bleu), var(--bleu-fonce)); color: #fff; padding: 28px; text-align: center; }
.resultat-principal .label { font-family: var(--mono); font-size: .78rem; letter-spacing: .06em; text-transform: uppercase; opacity: .82; }
.resultat-principal .valeur { font-family: var(--serif); font-size: 3rem; font-weight: 500; letter-spacing: -.02em; margin-top: 4px; }
.resultat-detail { background: var(--papier); }
.resultat-detail .ligne { display: flex; justify-content: space-between; gap: 12px; padding: 12px 22px; border-bottom: 1px solid var(--ligne); font-size: .95rem; }
.resultat-detail .ligne:last-child { border-bottom: none; }
.resultat-detail .ligne.total { background: var(--rouge-pale); font-weight: 600; }
.resultat-detail .ligne .montant { font-family: var(--mono); font-weight: 500; }
.actions-pdf { display: flex; gap: 10px; margin-top: 16px; }

/* ---------- Contenu rédactionnel ---------- */
.prose { max-width: 760px; }
.prose h2 { margin: 8px 0 14px; }
.prose h3 { font-size: 1.25rem; margin: 28px 0 8px; }
.prose p { margin: 0 0 16px; }
.prose ul { padding-left: 0; list-style: none; margin: 16px 0; }
.prose ul li { position: relative; padding-left: 26px; margin-bottom: 10px; }
.prose ul li::before { content: "→"; position: absolute; left: 0; color: var(--rouge); font-family: var(--mono); }
.tableau { width: 100%; border-collapse: collapse; margin: 18px 0; font-size: .92rem; }
.tableau th, .tableau td { border: 1px solid var(--ligne); padding: 11px 14px; text-align: left; }
.tableau th { background: var(--papier-2); font-family: var(--mono); font-size: .78rem; text-transform: uppercase; letter-spacing: .04em; }
.tableau td:last-child { font-family: var(--mono); }
.tableau tr:nth-child(even) td { background: color-mix(in srgb, var(--papier) 60%, transparent); }

.encadre { background: var(--bleu-pale); border-left: 3px solid var(--bleu); border-radius: 0 var(--rayon) var(--rayon) 0; padding: 18px 22px; margin: 22px 0; }
.encadre.r { background: var(--rouge-pale); border-color: var(--rouge); }
.encadre p:last-child { margin-bottom: 0; }
.note { font-size: .88rem; color: var(--encre-doux); }

/* Sommaire / table des matières */
.toc { background: var(--papier); border: 1px solid var(--ligne); border-radius: var(--rayon); padding: 18px 22px; margin: 8px 0 28px; }
.toc strong { font-family: var(--mono); font-size: .78rem; text-transform: uppercase; letter-spacing: .06em; color: var(--encre-doux); }
.toc ol { margin: 10px 0 0; padding-left: 20px; }
.toc li { margin-bottom: 5px; }

/* FAQ */
.faq details { border: 1px solid var(--ligne); border-radius: var(--rayon); padding: 2px 20px; margin-bottom: 12px; background: var(--papier); }
.faq summary { cursor: pointer; font-family: var(--serif); font-size: 1.1rem; padding: 16px 0; list-style: none; display: flex; justify-content: space-between; gap: 16px; }
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: "+"; font-family: var(--mono); color: var(--rouge); }
.faq details[open] summary::after { content: "–"; }
.faq details[open] summary { color: var(--bleu-fonce); }
.faq p { margin: 0 0 16px; color: var(--encre-doux); }

/* Avis / réassurance sociale */
.avis { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; }
.avis blockquote { margin: 0; background: var(--papier); border: 1px solid var(--ligne); border-radius: var(--rayon); padding: 22px; }
.avis p { font-family: var(--serif); font-style: italic; font-size: 1.05rem; margin: 0 0 14px; }
.avis cite { font-family: var(--mono); font-style: normal; font-size: .8rem; color: var(--encre-doux); }
.avis .etoiles { color: var(--rouge); letter-spacing: 2px; font-size: .9rem; margin-bottom: 10px; }

/* ---------- Encart pub (AdSense) ---------- */
.pub { margin: 30px auto; text-align: center; min-height: 0; color: var(--encre-doux); font-family: var(--mono); font-size: .78rem; }
.pub ins { display: block; }

/* ---------- CTA final ---------- */
.cta-final { text-align: center; }
.cta-final h2 { max-width: 640px; margin: 0 auto 16px; }
.cta-final p { color: var(--encre-doux); max-width: 520px; margin: 0 auto 24px; }

/* ---------- Pied de page ---------- */
.site-footer { border-top: 1px solid var(--ligne); margin-top: 0; background: var(--papier-2); padding: 48px 0 28px; }
.footer-haut { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 28px; }
.footer-marque .logo { margin-bottom: 12px; }
.footer-marque p { color: var(--encre-doux); font-size: .9rem; max-width: 280px; }
.footer-haut h4 { font-family: var(--mono); font-size: .76rem; text-transform: uppercase; letter-spacing: .06em; color: var(--encre-doux); margin: 0 0 12px; }
.footer-haut ul { list-style: none; padding: 0; margin: 0; }
.footer-haut li { margin-bottom: 8px; }
.footer-haut a { color: var(--encre); font-size: .92rem; }
.footer-bas { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 10px; margin-top: 36px; padding-top: 22px; border-top: 1px solid var(--ligne); font-family: var(--mono); font-size: .78rem; color: var(--encre-doux); }

/* ---------- Bandeau cookies ---------- */
.cookie-banner { position: fixed; bottom: 16px; left: 16px; right: 16px; max-width: 720px; margin: 0 auto; background: var(--papier); border: 1px solid var(--ligne-forte); border-radius: 14px; box-shadow: var(--ombre-mg); padding: 20px 22px; z-index: 100; display: none; }
.cookie-banner.actif { display: block; }
.cookie-banner p { margin: 0 0 14px; font-size: .9rem; color: var(--encre-doux); }
.cookie-banner .boutons { display: flex; gap: 10px; flex-wrap: wrap; }
.cookie-banner button { cursor: pointer; font-family: var(--mono); padding: 10px 18px; border-radius: 8px; font-size: .85rem; border: 1px solid var(--ligne-forte); background: var(--creme); color: var(--encre); }
.cookie-banner button.accepter { background: var(--bleu); color: #fff; border-color: var(--bleu); }

/* ---------- Responsive ---------- */
@media (max-width: 900px) {
  .hero-split, .duo { grid-template-columns: 1fr; gap: 28px; }
  .hero-illus { max-width: 380px; margin: 0 auto; order: -1; }
  .duo--rev .txt { order: 0; }
  .col-3, .col-4, .stats, .reassur, .etapes, .avis { grid-template-columns: repeat(2,1fr); }
  .nav-links { display: none; }
  .footer-haut { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px) {
  body { font-size: 16px; }
  .col-3, .col-2, .col-4, .stats, .reassur, .etapes, .avis { grid-template-columns: 1fr; }
  .champ-ligne { grid-template-columns: 1fr; }
  .calc-head { grid-template-columns: 1fr; }
  .calc-head img { display: none; }
  .footer-haut { grid-template-columns: 1fr 1fr; }
  .resultat-principal .valeur { font-size: 2.3rem; }
}

/* ---------- Impression / PDF ---------- */
@media print {
  body::before, .site-header, .site-footer, .pub, .cookie-banner, .actions-pdf,
  .nav, .theme-toggle, .faq, form .btn, .trust-strip, .cta-final { display: none !important; }
  body { background: #fff; color: #000; }
  .calc-card { box-shadow: none; border: 1px solid #ccc; }
  .resultat-principal { background: var(--bleu) !important; -webkit-print-color-adjust: exact; print-color-adjust: exact; }
  @page { size: A4; margin: 1.5cm; }
}
