/* ===========================================================================
   Calendrier Couleur Tempo — feuille de style (direction « V1 Officiel / Clair »)
   Registre service public : sobre, structuré, très lisible. Public peu à l'aise
   avec le web. La couleur Tempo (bleu/blanc/rouge) ne sert qu'à montrer la
   DONNÉE ; les boutons d'action utilisent une couleur distincte (vert), jamais
   une couleur Tempo. Police : Public Sans. Icônes : SVG inline (pas de CDN).
   =========================================================================== */

:root{
  --ink:#16202c; --muted:#5c6b7a; --line:#dde3ea; --bg:#eef2f6; --card:#fff;
  --brand:#16314f; --brand-d:#0f2438;
  --cta:#0b7a63; --cta-d:#096552; --cta-soft:#e6f3ef;
  --blue:#1d4ed8; --blue-soft:#e6efff; --red:#d92d20; --red-soft:#fbe8e6;
  --white-d:#1f2937; --white-bd:#cfd6df; --white-soft:#f1f4f8;
  --radius:14px;
  --shadow:0 1px 2px rgba(16,32,48,.06),0 8px 24px -12px rgba(16,32,48,.18);
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--bg);color:var(--ink);font-family:'Public Sans',system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;font-size:17px;line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3{line-height:1.2;margin:0}
a{color:var(--brand)}
a:hover{text-decoration:underline}
.muted{color:var(--muted)}
strong{font-weight:700}
.wrap{max-width:1080px;margin:0 auto;padding:0 20px}
.wrap--reading{max-width:760px}
svg{display:inline-block;vertical-align:middle}

/* --- En-tête (blanc, institutionnel) ------------------------------------- */
.site-header{background:var(--card);border-bottom:1px solid var(--line)}
.site-header__row{display:flex;align-items:center;gap:16px;min-height:68px;padding:10px 0}
.brand{display:flex;align-items:center;gap:11px;font-weight:800;font-size:1.18rem;color:var(--ink);text-decoration:none}
.brand:hover{text-decoration:none}
.brand .mk{width:38px;height:38px;border-radius:10px;background:var(--brand);color:#fff;display:grid;place-items:center;flex:0 0 auto}
.brand .mk svg{width:20px;height:20px}
.site-nav{margin-left:auto;display:flex;gap:6px}
.site-nav a{padding:9px 14px;border-radius:9px;font-weight:600;text-decoration:none;color:var(--muted);font-size:.98rem}
.site-nav a:hover{background:var(--bg);text-decoration:none}
.site-nav a.is-active{background:var(--bg);color:var(--ink)}
.trust{display:none;align-items:center;gap:7px;color:var(--muted);font-size:.85rem;font-weight:600}
.trust svg{width:16px;height:16px;color:var(--cta)}
@media(min-width:760px){.trust{display:flex}}
.tagline{margin:0;color:var(--muted);font-size:.95rem}

main{display:block;padding:26px 0 40px}
.lead{font-size:1.05rem;color:var(--muted);margin:0 0 20px;max-width:70ch}
.section{margin-top:34px}
.section-title{font-size:1.25rem;font-weight:800;margin:0 0 14px;display:flex;align-items:center;gap:9px;overflow-wrap:break-word}
.section-title svg{width:20px;height:20px;color:var(--brand);flex:0 0 auto}

/* --- Statut : aujourd'hui + demain --------------------------------------- */
.status{display:grid;gap:16px;grid-template-columns:1fr}
@media(min-width:760px){.status{grid-template-columns:1.3fr 1fr}}
.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px 24px}
.panel .when{font-size:.82rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.daychip{display:inline-flex;align-items:center;gap:14px;margin:10px 0 4px}
.swatch{width:54px;height:54px;border-radius:12px;flex:0 0 auto;box-shadow:inset 0 0 0 1px rgba(0,0,0,.07)}
.sw-blue{background:var(--blue)} .sw-red{background:var(--red)} .sw-white{background:#fff;box-shadow:inset 0 0 0 1.5px var(--white-bd)}
.sw-empty{background:#e5eaf0}
.daychip h1{font-size:2.1rem;font-weight:800}
.daychip h2{font-size:1.7rem;font-weight:800}
.dateline{color:var(--muted);font-size:.97rem;text-transform:capitalize}
.panel--tom{display:flex;flex-direction:column;justify-content:center}
.tom-note{margin-top:12px;display:inline-flex;align-items:center;gap:8px;background:var(--red-soft);color:#9a221a;font-weight:700;padding:9px 13px;border-radius:9px;font-size:.95rem}
.tom-note svg{width:18px;height:18px;flex:0 0 auto}
.tom-wait{margin-top:10px;display:flex;gap:9px;align-items:center;color:var(--muted);font-size:.95rem}
.tom-wait svg{width:20px;height:20px;color:var(--cta);flex:0 0 auto}

/* --- Inscription (mise en avant) ----------------------------------------- */
.signup{margin-top:18px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.signup-top{padding:20px 24px;border-bottom:1px solid var(--line);display:flex;gap:14px;align-items:flex-start}
.signup-top .ic{width:42px;height:42px;border-radius:11px;background:var(--cta);color:#fff;display:grid;place-items:center;flex:0 0 auto}
.signup-top .ic svg{width:22px;height:22px}
.signup-top h2{font-size:1.3rem;font-weight:800}
.signup-top p{margin:3px 0 0;color:var(--muted);font-size:.97rem}
.signup-grid{display:grid;grid-template-columns:1fr}
@media(min-width:720px){.signup-grid{grid-template-columns:1fr 1fr}}
.su{padding:20px 24px}
.su+.su{border-top:1px solid var(--line)}
@media(min-width:720px){.su+.su{border-top:0;border-left:1px solid var(--line)}}
.su h3{font-size:1.02rem;font-weight:700;display:flex;align-items:center;gap:8px;margin-bottom:10px}
.su h3 svg{width:18px;height:18px;flex:0 0 auto}

/* --- Formulaires (réutilisés par d'autres pages) ------------------------- */
.field{margin-bottom:6px}
.field label{display:block;font-size:.85rem;font-weight:700;margin-bottom:5px;color:var(--ink)}
.field input{width:100%;padding:13px 14px;border:1.5px solid var(--line);border-radius:10px;font-size:1.05rem;font-family:inherit}
.field input:focus{outline:none;border-color:var(--cta);box-shadow:0 0 0 3px var(--cta-soft)}
.consent-note{font-size:.82rem;color:var(--muted);margin:9px 0 14px}
.consent-note a{color:var(--brand)}
.hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;opacity:0}
.btn{display:flex;align-items:center;justify-content:center;gap:9px;width:100%;border:0;border-radius:10px;padding:14px;font-size:1.05rem;font-weight:700;color:#fff;background:var(--brand);cursor:pointer;font-family:inherit}
.btn:hover{text-decoration:none;filter:brightness(1.05)}
.btn svg{width:19px;height:19px;flex:0 0 auto}
.btn--primary,.btn--mail{background:var(--cta)} .btn--primary:hover,.btn--mail:hover{background:var(--cta-d)}
.btn--wa{background:#1faf54} .btn--wa:hover{background:#1a9849}
.form__msg{margin:.75rem 0 0;font-size:.97rem;font-weight:600;min-height:1.2em}
.form__msg.is-ok{color:#15803d}
.form__msg.is-err{color:#b91c1c}

/* --- Quotas (tuiles) ------------------------------------------------------ */
.tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.tile{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px 12px;text-align:center;min-width:0}
.tile .dot{width:14px;height:14px;border-radius:50%;display:inline-block}
.tile .n{font-size:2.4rem;font-weight:800;line-height:1;margin:6px 0 2px}
.tile .l{font-size:.92rem;font-weight:600}
.tile .s{font-size:.78rem;color:var(--muted);margin-top:3px}

/* --- Calendrier ----------------------------------------------------------- */
.cal{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px}
.cal-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;gap:10px;flex-wrap:wrap}
.cal-h .m{font-weight:700;font-size:1.05rem;text-transform:capitalize}
.cal-nav{display:flex;gap:8px}
.cal-nav button{width:40px;height:40px;border:1.5px solid var(--line);background:#fff;border-radius:9px;cursor:pointer;color:var(--ink);font-size:1rem}
.cal-nav button:hover{background:var(--bg)}
.calendar__grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cal-dow{text-align:center;font-size:.72rem;font-weight:700;color:var(--muted);text-transform:uppercase;padding-bottom:4px}
.cal-day{aspect-ratio:1;border-radius:9px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-weight:700;font-size:.95rem;border:1px solid var(--line);color:#33414f;background:#f7f9fb}
.cal-day small{font-size:.56rem;font-weight:600;opacity:.85;margin-top:1px}
.cal-day--empty{background:transparent!important;border:none}
.cal-day--today{outline:3px solid var(--cta);outline-offset:1px}
.calendar__legend{display:flex;gap:18px;flex-wrap:wrap;margin-top:12px;font-size:.88rem;color:var(--muted)}
.lg{display:inline-flex;align-items:center;gap:7px}
.dot,.calendar__legend i{width:13px;height:13px;border-radius:4px;display:inline-block}

/* --- Notes / éditorial / FAQ --------------------------------------------- */
.cols{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:760px){.cols{grid-template-columns:1fr 1fr}}
.note,.editorial__block{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:20px 22px;box-shadow:var(--shadow)}
.editorial__block{margin-bottom:16px}
.note h3{font-size:1.1rem;font-weight:800;margin-bottom:8px}
.note p,.editorial__block p,.editorial__block ul{margin:.4rem 0;color:#3a4a59;font-size:.99rem}
.editorial__block ul{padding-left:1.2rem}
.faq__item{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:2px 18px;margin-bottom:10px;box-shadow:var(--shadow)}
.faq__item summary{cursor:pointer;font-weight:700;padding:15px 0;list-style:none;font-size:1.05rem}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{content:"+";float:right;color:var(--cta);font-weight:700;font-size:1.3rem;line-height:1}
.faq__item[open] summary::after{content:"\2212"}
.faq__a{padding:0 0 15px;color:#3a4a59}
.faq__a p{margin:.3rem 0}

/* --- Cartes centrées (confirm / désinscription / opt-in) ----------------- */
.optin{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow)}
.optin .btn{width:auto;display:inline-flex;margin-top:6px}

/* --- Blog ----------------------------------------------------------------- */
.blog-hero{margin:6px 0 24px}
.blog-hero h1{font-size:2rem;font-weight:800;margin:0 0 .2em}
.blog-list{display:grid;grid-template-columns:1fr;gap:18px}
@media(min-width:640px){.blog-list{grid-template-columns:1fr 1fr}}
@media(min-width:940px){.blog-list{grid-template-columns:1fr 1fr 1fr}}
.blog-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column}
.blog-card__top{height:8px}
.blog-card__link{display:flex;flex-direction:column;flex:1;padding:20px;color:var(--ink)}
.blog-card__link:hover{text-decoration:none;background:#fafcff}
.blog-card__tag{align-self:flex-start;font-size:.74rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--cta);margin-bottom:7px}
.blog-card__title{font-size:1.18rem;font-weight:800;margin:0 0 8px}
.blog-card__excerpt{color:#3a4a59;font-size:.95rem;margin:0 0 14px;flex:1}
.blog-card__meta{color:var(--muted);font-size:.84rem;font-weight:600}
.breadcrumb{font-size:.92rem;color:var(--muted);margin:6px 0 14px}
.breadcrumb span{color:var(--ink)}
.article{max-width:760px}
.article__tag{display:inline-block;font-size:.76rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--cta);margin-bottom:10px}
.article__title{font-size:2.1rem;font-weight:800;line-height:1.15;margin:0 0 .3em}
.article__meta{display:flex;gap:18px;flex-wrap:wrap;color:var(--muted);font-size:.92rem;margin:0 0 20px;font-weight:600}
.article__body{font-size:1.08rem}
.article__body h2{font-size:1.5rem;font-weight:800;margin:1.5em 0 .5em}
.article__body h3{font-size:1.2rem;font-weight:800;margin:1.2em 0 .4em}
.article__body p{margin:.75em 0}
.article__body ul,.article__body ol{margin:.75em 0;padding-left:1.4rem}
.article__cta{background:var(--cta-soft);border:1px solid #bfe2d8;border-radius:var(--radius);padding:24px;text-align:center;margin:28px 0}
.article__cta h2{font-size:1.3rem;font-weight:800;margin:0 0 .3em}
.article__cta p{color:var(--muted);margin:0 0 16px}
.article__cta .btn{width:auto;display:inline-flex}

/* --- Pied de page (navy) -------------------------------------------------- */
.site-footer{background:var(--brand);color:#cdd9e6;margin-top:44px;padding:28px 0}
.disclaimer{display:flex;gap:9px;align-items:flex-start;font-size:.9rem;margin:0}
.disclaimer svg{width:17px;height:17px;flex:0 0 auto;margin-top:2px;color:#7fb6ff}
.footer-nav{margin:14px 0 10px;display:flex;gap:18px;flex-wrap:wrap;font-size:.92rem}
.footer-nav a{color:#fff;text-decoration:none;font-weight:600}
.copyright{font-size:.85rem;color:#9fb3c8;margin:0}

@media(max-width:480px){
  .section-title{font-size:1.15rem}
  .tile .n{font-size:2rem}
  .tile .l{font-size:.85rem}
  .daychip h1{font-size:1.8rem}
}
