/*
 Theme Name:   GeneratePress Child — Crossword Challenge Answers
 Theme URI:    https://generatepress.com
 Description:  Default GeneratePress child theme
 Author:       Tom Usborne
 Author URI:   https://tomusborne.com
 Template:     generatepress
 Version:      0.1
*/

/* ================== VARIABLES / THEME ================== */
:root{
  /* ▼ Update brand colors to match the Crossword Challenge palette (logo): */
  /* --brand: #5E35B1;     Purple (example) */
  /* --brand-2: #4527A0;   Darker purple (hover) */
  /* --panel-head-fg: #4527A0;  Heading color inside panels */

  --bg:#ffffff;
  --text:#1a1a1a;
  --muted:#5a6470;
  --brand:#1e88e5;      /* bleu principal */
  --brand-2:#1565c0;    /* bleu hover */
  --card:#f5f7fa;
  --border:#d8dee6;
  --radius:14px;
  --shadow:0 6px 18px rgba(0,0,0,.06);
  --maxw:1100px;
  --focus:#ffbf47;
  --font-ui: system-ui, -apple-system, Segoe UI, Roboto, Inter, "Helvetica Neue", Arial, "Noto Sans", sans-serif;

  /* couleur titre panneau */
  --panel-head-fg:#1565c0;
}

/* Forcer le thème CLAIR partout */
:root{ color-scheme: light; }

/* ================== BASE ================== */
html,body{
  background:var(--bg);
  color:var(--text);
  margin:0; padding:0;
  font-family:var(--font-ui);
  font-size:18px;
  font-weight:400;
  -webkit-text-size-adjust:100%;
  text-size-adjust:100%;
}

.page-home, .home main, .site-main{
  max-width:var(--maxw);
  margin:0 auto;
  padding:24px 18px 56px;
}

/* ================== TYPO ================== */
h1{
  font-size:32px;
  line-height:1.15;
  margin:0 0 10px;
  font-weight:700;
}
h2{
  font-size:26px;
  margin:28px 0 14px;
  font-weight:700;
}
h3{ font-size:24px; font-weight:700; }
p{ line-height:1.65; margin:0 0 14px; }
em, strong{ color:inherit; }

/* ================== RECHERCHE ================== */
.cmh-search-wrap{
  margin:14px 0 28px;
  background: linear-gradient(180deg, rgba(30,136,229,.10), rgba(30,136,229,.03));
  border: 1px solid rgba(30,136,229,.25);
  border-radius: var(--radius);
  padding: 16px;
  box-shadow: 0 8px 24px rgba(30,136,229,.10), var(--shadow);
}

.cmh-search{
  display:flex; align-items:center;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:10px;
  box-shadow:var(--shadow);
}

.cmh-search input[type="search"]{
  flex:1;
  border:0; background:transparent; color:var(--text);
  font-size:1.5rem;
  font-weight:600;
  padding:10px 8px; outline:none;
  min-height:44px;
}

.cmh-search button{
  background:var(--brand); color:#fff; border:0;
  padding:10px 16px; border-radius:10px; cursor:pointer;
  font-weight:600; min-height:44px;
  transition:background .2s ease, box-shadow .2s ease;
}
.cmh-search button:hover{ background:var(--brand-2); }

/* focus clavier accessible */
.cmh-search input[type="search"]:focus-visible,
.cmh-search button:focus-visible,
a:focus-visible{
  outline:2px solid rgba(255,191,71,.75);
  outline-offset:2px;
  box-shadow:none;
}

/* ================== NIVEAUX ================== */
.level-grid{
  display:flex;
  flex-direction:column;
  align-items:center;
}
h2 + .level-grid{ margin-top:18px; }
.level-grid a{
  display:block; width:100%; max-width:320px; text-align:center;
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--radius); padding:10px 14px; color:var(--text);
  font-weight:600; text-decoration:none; box-shadow:var(--shadow);
  transition:transform .08s ease, border-color .1s ease, box-shadow .1s ease, background-color .1s ease;
}
.level-grid a + a{ margin-top:6px; }
.level-grid a:hover{
  transform:translateY(-2px);
  border-color:var(--brand);
  background-color:rgba(30,136,229,0.08);
  box-shadow:0 6px 16px rgba(0,0,0,.06);
}

/* ================== FAQ ================== */
.faq details{
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--radius); margin:8px 0; box-shadow:var(--shadow);
}
.faq summary{ cursor:pointer; font-weight:700; padding:12px 14px; list-style:none; }
.faq summary::-webkit-details-marker{ display:none; }
.faq details[open] summary{ border-bottom:1px solid var(--border); }
.faq p{ padding:12px 14px; margin:0; }

/* ================== LIENS ================== */
a{ color:var(--brand); font-weight:400; }
a:hover{ text-decoration:underline; }

.cmh-breadcrumbs{
  font-size:.92rem; color:var(--muted); margin:0 0 8px;
}
.cmh-breadcrumbs a{ color:var(--muted); text-decoration:none; }
.cmh-breadcrumbs a:hover{ text-decoration:underline; }
.cmh-breadcrumbs .breadcrumb_last,[aria-current="page"]{ font-weight:700; color:var(--text); }
.cmh-breadcrumbs .cmh-bc-sep{ color:var(--muted); font-weight:700; }

/* ================== DIVERS ================== */
.updated-note{ color:var(--muted); margin-top:24px; font-size:.95rem; }

.section-card{
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--radius); padding:16px; box-shadow:var(--shadow);
}

.screen-reader-text{
  position:absolute!important; height:1px; width:1px; overflow:hidden; clip:rect(1px,1px,1px,1px);
}

/* ================== RÉDUCTION DES MOUVEMENTS ================== */
@media (prefers-reduced-motion: reduce){
  *{ transition:none !important; animation:none !important; }
  .level-grid a:hover{ transform:none; }
}

/* ====== Listes / icônes ====== */
.cmh-list{ list-style:none; margin:0; padding:0; }
.cmh-list li{ display:flex; align-items:center; flex-wrap:wrap; gap:8px; margin-bottom:10px; }
.cmh-answer.hidden{ display:none; }
.reveal-btn{
  background: var(--brand); color:#fff; border:0; padding: 8px 12px;
  border-radius: 8px; cursor:pointer; font-size: .95rem;
}
.reveal-btn:hover{ background: var(--brand-2); }
.cmh-icon{ width:22px; height:22px; object-fit:contain; vertical-align:text-bottom; }
.alignleft  .cmh-icon, .cmh-icon.alignleft  { margin-right:6px; }
.alignright .cmh-icon, .cmh-icon.alignright { margin-left:6px; }

/* ====== Panneaux crossword ====== */
.cmh-crossword-panel{
  border-radius: var(--radius);
  border: 1px solid rgba(30,136,229,.35);
  background: linear-gradient(180deg, rgba(30,136,229,.12), rgba(30,136,229,.04));
  box-shadow: 0 10px 24px rgba(30,136,229,.10), var(--shadow);
  overflow: hidden;
}
.cmh-panel-head{
  padding: 12px 16px;
  background: linear-gradient(90deg, rgba(30,136,229,.20), rgba(30,136,229,.05));
  border-bottom: 1px solid rgba(30,136,229,.30);
}
.cmh-panel-head h2{ margin:0; font-size:22px; line-height:1.2; color: var(--panel-head-fg); }
.cmh-panel-head h2::after{
  content:""; display:block; width:56px; height:3px; background: currentColor;
  opacity:.6; border-radius:9999px; margin-top:6px;
}
.cmh-panel-body{
  padding:14px 16px;
  /* damier OFF */
  background-color: var(--card);
  background-image: none;
  /* (background-size n'a plus d'effet sans image) */
  border-top:1px solid rgba(255,255,255,.35);
}

/* Index / pills */
.cmh-jumps { margin: 0 0 12px; color: var(--muted); }
.cmh-jumps a{ text-decoration:none; }
.cmh-jumps a:hover{ text-decoration:underline; }
.cmh-index{ list-style:none; margin:8px 0 18px; padding:0; display:flex; flex-wrap:wrap; gap:8px; }
.cmh-index a{
  position:relative; display:inline-block; min-width:40px; text-align:center;
  padding:6px 10px; border-radius:10px; background:var(--card);
  border:1px solid var(--border); color:var(--text); text-decoration:none; font-weight:600;
  box-shadow:var(--shadow); transition:transform .08s ease, border-color .1s ease, background-color .1s ease;
}
.cmh-index a:hover{ transform:translateY(-2px); border-color:var(--brand); background-color:rgba(30,136,229,.08); }
.cmh-index a{ padding-left:30px; }
.cmh-index a::before{
  content:""; position:absolute; left:8px; top:50%; transform:translateY(-50%);
  width:16px; height:16px; background: url('https://www.crosswordchallengeanswers.com/wp-content/uploads/2025/09/Crossword-Challenge-Answers.png') center/contain no-repeat;
  opacity:.95;
}

/* Chips */
.cmh-chips{ display:flex; flex-wrap:wrap; gap:8px; }
.cmh-chip{
  display:inline-block; padding:6px 10px; border-radius:9999px;
  background:var(--card); border:1px solid var(--border); box-shadow:var(--shadow); font-weight:700;
}

/* Sticky note */
.updated-note{
  --note-bg:#fffbe6; --note-border:#f2e6a6; --note-text:#3b2f07; --note-pin:#ef4444;
  position:relative; display:block; margin:1.25rem 0; padding:1rem 1.1rem 1rem 1.25rem;
  background:var(--note-bg); color:var(--note-text); border:1px solid var(--note-border);
  border-radius:.55rem .55rem .8rem .55rem;
  box-shadow: 0 12px 20px -12px rgba(0,0,0,.25), 0 1px 0 rgba(255,255,255,.6) inset;
  transform:rotate(-.4deg); font:500 .97rem/1.55 system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
}
.updated-note::after{
  content:""; position:absolute; right:.25rem; top:.25rem; width:0; height:0;
  border-left:.65rem solid transparent; border-top:.65rem solid rgba(0,0,0,.08);
}
.updated-note a{ text-decoration:underline; text-underline-offset:2px; }
.updated-note strong{ font-weight:700; }

/* ================================
   MOBILE: gouttières
   ================================ */
@media (max-width: 768px){
  .grid-container, .site-content, .content-area, .site-main, .home main, .page-home{
    padding-left: 8px !important;
    padding-right: 8px !important;
    max-width: 100% !important;
  }
  .separate-containers .site-main .inside-article,
  .inside-article{
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
}
@media (max-width: 480px){
  .grid-container, .site-content, .content-area, .site-main, .home main, .page-home{
    padding-left: 6px !important;
    padding-right: 6px !important;
  }
}
@media (max-width: 360px){
  .grid-container, .site-content, .content-area, .site-main, .home main, .page-home{
    padding-left: 4px !important;
    padding-right: 4px !important;
  }
}

/* =======================================================
   MOBILE SEARCH — bouton déplacé
   ======================================================= */
@media (max-width:560px){
  .cmh-search-wrap{
    padding: 6px 8px !important;
    border-radius: 8px !important;
    margin-bottom: 8px !important;
    background: linear-gradient(180deg, rgba(30,136,229,.06), rgba(30,136,229,.02));
    border: 1px solid rgba(30,136,229,.18);
    box-shadow: 0 3px 8px rgba(0,0,0,.04);
  }
  .wp-block-search{ width:100%; margin:0 !important; }
  .wp-block-search__inside-wrapper{ display:block !important; }
  .wp-block-search__input,
  .cmh-search input[type="search"]{
    width:100%; min-width:0; margin:0 !important;
    padding:10px 12px; min-height:40px; font-size:1.05rem; box-sizing:border-box;
  }
  .cmh-search{ padding:8px 10px !important; }
  .cmh-search-btn-row{ margin-top: 6px !important; margin-bottom: 14px !important; }
  .cmh-search-btn-row .wp-block-search__button,
  .cmh-search-btn-row .wp-element-button,
  .cmh-search-btn-row button[type="submit"],
  .cmh-search-btn-row input[type="submit"],
  .cmh-search-btn-row .button{
    display:block; width:100%; margin:0; padding:10px 12px;
    line-height:1.1; border-radius:10px; white-space:nowrap; box-sizing:border-box;
    background: var(--brand) !important; color:#fff !important; border:0 !important; text-decoration:none !important; box-shadow:none !important;
    -webkit-appearance:none; appearance:none;
  }
  .cmh-search-btn-row .wp-block-search__button:hover,
  .cmh-search-btn-row .wp-element-button:hover,
  .cmh-search-btn-row button[type="submit"]:hover,
  .cmh-search-btn-row input[type="submit"]:hover,
  .cmh-search-btn-row .button:hover{ background: var(--brand-2) !important; }
}

/* MOBILE: placeholder */
@media (max-width:560px){
  .wp-block-search__input::placeholder,
  .cmh-search input[type="search"]::placeholder{
    font-size: .95em !important;
    opacity: .9;
  }
  .wp-block-search__input::-webkit-input-placeholder,
  .cmh-search input[type="search"]::-webkit-input-placeholder{ font-size:.9em !important; }
  .wp-block-search__input::-moz-placeholder,
  .cmh-search input[type="search"]::-moz-placeholder{ font-size:.9em !important; }
  .wp-block-search__input:-ms-input-placeholder,
  .cmh-search input[type="search"]:-ms-input-placeholder{ font-size:.9em !important; }
  .wp-block-search__input::-ms-input-placeholder,
  .cmh-search input[type="search"]::-ms-input-placeholder{ font-size:.9em !important; }
}

/* ============ Search results list ============ */
.cmh-results{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.cmh-result{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:12px;
  padding:12px 14px;
  box-shadow:var(--shadow);
}
.cmh-result-title{
  margin:0 0 4px 0;
  font-size:1.08rem;
  line-height:1.25;
}
.cmh-result-title a{
  text-decoration:none;
  color:var(--text);
}
.cmh-result-title a:hover{
  text-decoration:underline;
}
.cmh-result-meta{
  color:var(--muted);
  font-size:.9rem;
  margin-bottom:6px;
}
.cmh-result-excerpt{
  margin:0;
}

/* Mise en évidence du match */
.cmh-result mark{
  background:#fff59d;
  padding:0 .2em;
  border-radius:.2em;
}

/* Mobile: resserrer un peu les cartes */
@media (max-width:560px){
  .cmh-result{ padding:10px 12px; }
  .cmh-result-title{ font-size:1.02rem; }
}

/* Reset: annule le highlight de la 1ère carte en page de recherche */
body.search .cmh-results > article.cmh-result:first-of-type{
  border: 1px solid var(--border) !important;
  background: var(--card) !important;
  box-shadow: var(--shadow) !important;
}

/* Encadré bleu UNIQUEMENT dans l'EXCERPT du puzzle vedette */
body.search article.cmh-result--featured > p.cmh-result-excerpt{
  background: rgba(30,136,229,.14) !important;
  border: 1px solid rgba(30,136,229,.45) !important;
  border-radius: 12px !important;
  padding: 10px 12px !important;
  margin-top: 8px !important;
  background-clip: padding-box;
}
body.search article.cmh-result--featured > p.cmh-result-excerpt .cmh-more{
  font-weight: 600 !important;
  text-decoration: underline !important;
}

/* ===== Clues du puzzle vedette : panneau + "chips" ===== */
body.search article.cmh-result--featured .cmh-result-clues{
  margin-top: 10px !important;
  padding: 12px 14px !important;
  border: 1px solid rgba(30,136,229,.45) !important;
  border-radius: 12px !important;
  background: linear-gradient(180deg, rgba(30,136,229,.10), rgba(30,136,229,.03)) !important;
  box-shadow: 0 10px 24px rgba(30,136,229,.10), var(--shadow) !important;
}
body.search article.cmh-result--featured .cmh-result-clues > strong{
  display:block;
  color: var(--panel-head-fg);
  font-weight: 800;
  font-size: 1rem;
  margin: 2px 0 8px;
}
body.search article.cmh-result--featured .cmh-result-clues > strong::after{
  content:"";
  display:block;
  width:56px; height:3px;
  background: currentColor; opacity:.6;
  border-radius:9999px; margin-top:6px;
}
body.search article.cmh-result--featured .cmh-result-clues .cmh-list{
  list-style:none !important;
  padding:0 !important;
  margin:8px 0 0 !important;
  display:grid !important;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)) !important;
  gap: 8px 10px !important;
}
body.search article.cmh-result--featured .cmh-result-clues .cmh-list li{
  margin:0 !important;
  display:block !important;
}
body.search article.cmh-result--featured .cmh-result-clues .cmh-list a.cmh-clue{
  display:inline-flex;
  align-items:center;
  gap:8px;
  width:100%;
  padding:8px 10px;
  border-radius: 9999px;
  background: var(--card);
  border:1px solid var(--border);
  text-decoration:none;
  color: var(--text);
  font-weight: 700;
  line-height:1.2;
  box-shadow: var(--shadow);
  transition: transform .08s ease, border-color .1s ease, background-color .1s ease;
}
body.search article.cmh-result--featured .cmh-result-clues .cmh-list a.cmh-clue:hover{
  transform: translateY(-1px);
  border-color: var(--brand);
  background-color: rgba(30,136,229,.08);
}
body.search article.cmh-result--featured .cmh-result-clues .cmh-list a.cmh-clue:focus-visible{
  outline:2px solid var(--focus);
  outline-offset:2px;
}
body.search article.cmh-result--featured .cmh-result-clues .cmh-list a.cmh-clue::before{
  content:"";
  width:16px; height:16px; flex:0 0 16px;
  background: url('https://www.crosswordchallengeanswers.com/wp-content/uploads/2025/09/Crossword-Challenge-Answers.png') center/contain no-repeat;
  opacity:.95;
}
body.search article.cmh-result--featured .cmh-result-clues > div a{
  display:inline-block;
  margin-top: 8px;
  font-weight:700;
  text-decoration:underline;
}

/* Style des cartes "clue" listées sous la vedette */
body.search .cmh-results--clues article.cmh-result{
  border-left: 4px solid var(--brand) !important;
  background: linear-gradient(180deg, rgba(30,136,229,.06), rgba(30,136,229,.015)) !important;
  border-radius: 14px !important;
  box-shadow: 0 8px 18px rgba(30,136,229,.08), var(--shadow) !important;
}

/* Did you mean – typo helper */
.cmh-dym{
  margin: 8px 0 14px;
  padding: 10px 12px;
  border: 1px solid rgba(255,193,7,.45);
  background: linear-gradient(180deg, rgba(255,193,7,.18), rgba(255,193,7,.08));
  border-radius: 10px;
  font-size: .98rem;
  box-shadow: 0 6px 16px rgba(0,0,0,.05);
}
.cmh-dym strong{ color:#7a5900; margin-right:.25em; }
.cmh-dym-link{
  font-weight:700;
  text-decoration:underline;
}
.cmh-dym-link:hover{ text-decoration:none; }
.cmh-dym-detail{
  color: var(--muted);
  margin-left: 6px;
  font-size: .93em;
}
/* Empty-state amélioré */
.cmh-empty h2{
  margin-top: 0;
  font-size: 1.25rem;
}
.cmh-suggest{ 
  margin: 8px 0 12px; 
  padding: 10px 12px; 
  border: 1px solid var(--border); 
  background: var(--card); 
  border-radius: 10px; 
  box-shadow: var(--shadow);
}
.cmh-suggest-title{
  margin: 0 0 6px;
  font-weight: 700;
  color: var(--panel-head-fg);
}
.cmh-suggest-list{
  list-style: none;
  margin: 0; padding: 0;
  display: grid; gap: 6px;
}
.cmh-suggest-list a{
  text-decoration: none;
  color: var(--text);
  border-bottom: 1px dashed rgba(0,0,0,.25);
}
.cmh-suggest-list a:hover{ text-decoration: underline; }

.cmh-tips-title{ margin: 6px 0 6px; font-weight: 700; }
.cmh-quick{ display:flex; flex-wrap:wrap; gap:8px; margin: 0 0 8px; }
.cmh-help{ color: var(--muted); font-size: .95rem; margin: 4px 0 0; }
/* ===== CMH — Contact page ===== */
.cmh-contact{
  background: var(--base-3, #fff);
  border: 1px solid var(--border, #d8dee6);
  border-radius: var(--radius, 14px);
  padding: 18px;
  box-shadow: var(--shadow, 0 6px 18px rgba(0,0,0,.06));
  max-width: var(--maxw, 1100px);
  margin: 0 auto;
}
.cmh-contact h1{
  margin: 0 0 8px;
  font-size: 28px;
}
.cmh-contact .muted{ color: var(--muted, #5a6470); }
.cmh-contact .small{ font-size: .92rem; }

.cmh-contact-form{
  margin-top: 14px;
}
.cmh-contact-form .hp{ position:absolute !important; left:-9999px; width:1px; height:1px; overflow:hidden; }

.cmh-contact-form .fields-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 12px;
}
@media (max-width: 640px){
  .cmh-contact-form .fields-grid{ grid-template-columns: 1fr; }
}

.cmh-contact-form .field{ display:flex; flex-direction:column; }
.cmh-contact-form label{ font-weight:700; margin-bottom:6px; }
.cmh-contact-form input[type="text"],
.cmh-contact-form input[type="email"],
.cmh-contact-form select,
.cmh-contact-form textarea{
  background: var(--card, #f5f7fa);
  border: 1px solid var(--border, #d8dee6);
  border-radius: 10px;
  padding: 10px 12px;
  font: inherit;
}
.cmh-contact-form textarea{ resize: vertical; }

.cmh-contact-form .consent{ margin: 10px 0; }
.cmh-contact-form .consent label{ font-weight: 500; }

.cmh-contact-form .actions{
  margin-top: 8px;
  display:flex; align-items:center; gap:10px; flex-wrap:wrap;
}
.cmh-contact-form .button{
  background: var(--brand, #1e88e5); color:#fff; border:0;
  padding: 10px 14px; border-radius:10px; cursor:pointer; font-weight:700;
}
.cmh-contact-form .button:hover{ background: var(--brand-2, #1565c0); }

/* Alerts */
.cmh-contact-alert{
  border-radius: 10px;
  padding: 10px 12px;
  margin: 10px 0 14px;
  border: 1px solid;
}
.cmh-contact-alert.success{
  background: linear-gradient(180deg, rgba(76,175,80,.12), rgba(76,175,80,.04));
  border-color: rgba(76,175,80,.35);
}
.cmh-contact-alert.error{
  background: linear-gradient(180deg, rgba(244,67,54,.12), rgba(244,67,54,.04));
  border-color: rgba(244,67,54,.35);
}
/* ============ CMH — Mobile Drawer (étroit, ne couvre pas l'écran) ============ */
@media (max-width: 768px){
  /* bouton hamburger compact et visible */
  .main-navigation .menu-toggle{
    display:flex; align-items:center; justify-content:center; gap:8px;
    width:auto;
    background:#fff; color:var(--text);
    border:1px solid var(--border); border-radius:12px; padding:8px 10px;
    box-shadow: 0 2px 8px rgba(0,0,0,.06);
    font-weight:700; font-size:1rem;
  }
  .main-navigation .menu-toggle:hover{ background:#fff; }

  /* Drawer à droite (86vw, max 360px) */
  .main-navigation .main-nav{ position: static; }
  .main-navigation .main-nav > ul{
    position: fixed;
    top: 0; right: 0;
    height: 100vh;
    width: 86vw; max-width: 360px;
    background: var(--base-3, #fff);
    padding: 14px 16px; margin:0;
    border-left: 1px solid var(--border);
    box-shadow: -14px 0 28px rgba(0,0,0,.14);
    overflow-y: auto;
    transform: translateX(100%);
    transition: transform .18s ease-in-out;
    z-index: 10001;
  }
  .main-navigation.toggled .main-nav > ul{
    transform: translateX(0);
  }

  /* Pas d'overlay plein écran */
  body.cmh-menu-open::before{ display:none !important; }

  /* Liens “cartes” confortables */
  .main-navigation .main-nav > ul > li + li{ margin-top: 8px; }
  .main-navigation .main-nav a{
    display:block;
    padding:12px 12px;
    background: var(--card);
    border:1px solid var(--border);
    border-radius:12px;
    box-shadow: var(--shadow);
    font-weight:800; font-size:1.02rem;
    color: var(--text); text-decoration:none;
  }
  .main-navigation .main-nav a:hover{
    background: rgba(30,136,229,.08);
    border-color: var(--brand);
  }
  .main-navigation .main-nav a:focus-visible{
    outline:2px solid var(--focus); outline-offset:2px;
  }

  /* Contact = pas bleu, pas gras (comme demandé) */
  .main-navigation .main-nav li:last-child a{
    background: var(--card);
    border-color: var(--border);
    color: var(--text) !important;
    font-weight: 400;
  }
  .main-navigation .main-nav li:last-child a:hover{
    background: rgba(30,136,229,.08);
    border-color: var(--brand);
  }
}
/* ==========================
   CMH — Header Search Sheet
   ========================== */

/* Masquer le trigger de la recherche GeneratePress pour éviter le doublon */
.menu-bar-items [data-gpmodal-trigger="gp-search"],
.navigation-search { display:none !important; }

/* Bouton loupe */
.cmh-search-toggle{
  display:inline-flex; align-items:center; justify-content:center;
  gap:8px; padding:8px 12px;
  border:0; border-radius:10px;
  background: var(--card); color: var(--text);
  box-shadow: var(--shadow);
  font: 700 .98rem/1 var(--font-ui);
  cursor:pointer;
}
.cmh-search-toggle:hover{ background: rgba(30,136,229,.08); }
.cmh-search-toggle:focus-visible{ outline:2px solid var(--focus); outline-offset:2px; }

/* Panneau qui glisse sous le header */
.cmh-search-sheet{
  position: fixed; left:0; right:0; top:0;
  padding: 8px 10px 10px;
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(255,255,255,.92));
  backdrop-filter: blur(8px) saturate(120%);
  border-bottom: 1px solid var(--border);
  z-index: 1001;
  transform: translateY(-16px);
  opacity: 0; pointer-events: none;
  transition: transform .18s ease, opacity .18s ease;
}
.cmh-search-sheet.is-open{
  transform: translateY(0);
  opacity: 1; pointer-events: auto;
}

/* Overlay doux derrière le panneau */
body.cmh-search-open::before{
  content:""; position:fixed; inset:0;
  background: rgba(0,0,0,.35);
  z-index: 1000;
}
/* ==========================
   CMH — Mobile menu: 2-cols buttons
   ========================== */
@media (max-width: 768px){
  /* Le conteneur UL devient une grille 2 colonnes */
  .main-navigation .main-nav > ul{
    display: grid;
    grid-template-columns: repeat(2, minmax(0,1fr));
    gap: 8px; /* espace horizontal + vertical entre cartes */
  }
  /* On annule l'ancien espacement vertical au profit du gap */
  .main-navigation .main-nav > ul > li{ margin: 0 !important; }

  /* Les cartes gardent leur style mais s’ajustent au demi-largeur */
  .main-navigation .main-nav > ul > li > a{
    justify-content: center; /* centrer le libellé/emoji dans la carte */
    min-height: 52px;
  }

  /* Comme il y a 5 liens, on évite un “trou” en faisant
     occuper la dernière carte toute la ligne */
  .main-navigation .main-nav > ul > li:last-child{
    grid-column: 1 / -1; /* span 2 cols */
  }
}
/* Cacher la bannière en desktop */
.cmh-menu-banner-li{ display:none; }

@media (max-width: 768px){
  /* Le panneau du menu reste fixe (tes règles existantes),
     on le passe en colonne pour pouvoir "pousser" la bannière en bas
     et lui faire occuper l'espace restant. */
  .main-navigation .main-nav > ul{
    display: flex;
    flex-direction: column;
    gap: 8px;                 /* espace entre les boutons */
    overflow: auto;           /* scroll si la liste déborde */
  }

  /* La bannière : visible uniquement en mobile */
  .cmh-menu-banner-li{
    display: block;
    flex: 1 1 auto;           /* prend tout l'espace restant */
    min-height: 120px;        /* pour rester visible même si peu d’espace */
    margin-top: 8px;
  }

  .cmh-menu-search-banner{
    display: block;
    width: 100%;
    height: 100%;
    padding: 8px;
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: 16px;
    box-shadow: var(--shadow);
    cursor: pointer;
  }
  .cmh-menu-search-banner:hover{
    background: rgba(30,136,229,.06);
    border-color: var(--brand);
  }
  .cmh-menu-search-banner:focus-visible{
    outline: 2px solid var(--focus);
    outline-offset: 2px;
  }
  .cmh-menu-search-banner > img{
    display:block;
    width: 100%;
    height: 100%;
    object-fit: contain;      /* l’image s’adapte sans être rognée */
  }
}
/* CMH — Inline solution badge (style "Last checked", version inline) */
.cmh-inline-solution{
  display:inline-block;
  background:#fffbe6;               /* jaune doux */
  color:#3b2f07;                     /* texte foncé lisible */
  border:1px solid #f2e6a6;
  border-radius:.45rem;
  padding:.12em .45em;
  box-shadow:0 1px 0 rgba(255,255,255,.6) inset, 0 6px 12px rgba(0,0,0,.06);
  font-weight:800;
}
/* CMH — badge jaune inline pour la solution "All Variants" */
.cmh-hero-answer .cmh-chip.cmh-inline-solution{
  display:inline-block;
  background:#fffbe6;
  color:#3b2f07;
  border:1px solid #f2e6a6;
  border-radius:.45rem;
  padding:.12em .45em;
  font-weight:800;
  box-shadow:0 1px 0 rgba(255,255,255,.6) inset, 0 6px 12px rgba(0,0,0,.06);
}
/* Option 1 : tout remettre en normal */
.cmh-hero-answer .cmh-chip,
.cmh-inline-solution {
  font-weight: 400; /* ou 500 si tu veux un léger semi-bold */
}

/* Si quelque chose l’emporte, force : */
.cmh-inline-solution { font-weight: 400 !important; }

:root {
  /* Couleurs principales */
  --brand: #F24962;       /* primaire corail/rose */
  --brand-2: #C13A4E;     /* variation sombre (hover) */
  --panel-head-fg: #574E4C;/* titres des panneaux */

  /* Couleurs d'accent (pour badges, liens secondaires, etc.) */
  --accent-green: #88BF78;
  --accent-yellow: #F8B40D;

  /* Couleurs neutres */
  --text: #222222;
  --muted: #6B7280;
  --bg: #FFFFFF;
  --card: #F5EDED;
  --border: #FAFAFA;
}


/* Cacher le H1 du post "clue" quand il est embarqué sous une page puzzle */
.cmh-is-puzzle .site-main > article.category-clue .entry-header,
.cmh-is-puzzle .site-main > article.category-clue .entry-header .entry-title{
  display: none !important;
}
