/* ============================================================
   MON GR20 — Granite & Braise : habillage des pages "article"
   (guides pratiques + pages légales). S'appuie sur les tokens de
   granite-braise.css. Le HTML existant (.article-*, .breadcrumb)
   n'est PAS modifié — seul l'habillage change.
   ============================================================ */

/* ---------- Fil d'Ariane (dégage la nav fixe) ---------- */
.breadcrumb{
  width:min(980px,calc(100% - 40px));margin:0 auto;
  padding:clamp(96px,13vh,132px) 0 0;
  font-size:12px;letter-spacing:.04em;color:var(--bone-dim);
}
.breadcrumb ol{list-style:none;display:flex;flex-wrap:wrap;align-items:center;gap:9px}
.breadcrumb li{display:flex;align-items:center;gap:9px}
.breadcrumb li + li::before{content:"/";color:var(--line-strong)}
.breadcrumb a{color:var(--bone-dim);transition:color .25s var(--ease-out)}
.breadcrumb a:hover,.breadcrumb a:focus-visible{color:var(--ember)}
.breadcrumb [aria-current="page"]{color:var(--bone)}

/* ---------- Page + conteneur ---------- */
.article-page{
  background:
    radial-gradient(120% 56% at 50% -8%, rgba(226,104,60,.03), transparent 60%),
    var(--granite);
  color:var(--bone);
  padding:clamp(24px,4vw,40px) 0 clamp(82px,10vw,140px);
  font-family:var(--font-body);
}
/* si la page n'a PAS de fil d'Ariane, c'est .article-page qui dégage la nav */
body > main.article-page:first-of-type:not(.breadcrumb + main),
.skip-link + .article-page,
.gb-prog + .article-page{padding-top:clamp(100px,13vh,132px)}
.article-shell{width:min(980px,calc(100% - 40px));margin:0 auto}

/* ---------- Hero éditorial (sans photo) ---------- */
.article-hero{margin-bottom:clamp(34px,5vw,62px);padding:0;border:0;background:none;box-shadow:none}
.article-eyebrow{
  margin:0 0 18px;color:var(--ember);
  font-size:12px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;
}
.article-hero h1{
  font-family:var(--font-disp);font-weight:300;
  font-size:clamp(2.6rem,7vw,5.4rem);line-height:.96;letter-spacing:-.03em;
  color:var(--bone);max-width:17ch;
}
.article-hero h1 em{font-style:italic;color:var(--ember)}
.article-lead{
  max-width:62ch;margin:26px 0 0;color:var(--bone-dim);
  font-size:clamp(1.06rem,1.6vw,1.28rem);line-height:1.72;
}
.article-meta{display:flex;flex-wrap:wrap;gap:10px;margin-top:30px}
.article-meta span{
  display:inline-flex;min-height:34px;align-items:center;
  border:1px solid var(--line);border-radius:999px;padding:0 14px;
  color:var(--bone-dim);font-size:.82rem;letter-spacing:.02em;font-weight:400;
}

/* ---------- Sections ---------- */
.article-section{
  margin-top:clamp(20px,3vw,28px);
  padding:clamp(24px,4vw,42px);
  border:1px solid var(--line);border-radius:22px;
  background:var(--stone);
  scroll-margin-top:96px;
}
.article-section + .article-section{margin-top:clamp(18px,2.4vw,24px)}
.article-section__kicker{
  margin:0 0 12px;color:var(--ember);
  font-size:11px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;
}
.article-section h2{
  font-family:var(--font-disp);font-weight:300;
  font-size:clamp(1.7rem,3.4vw,2.7rem);line-height:1.06;letter-spacing:-.02em;
  color:var(--bone);margin:0 0 18px;
}
.article-section h2 em{font-style:italic;color:var(--ember)}
.article-section h3{
  font-family:var(--font-disp);font-weight:500;
  font-size:1.22rem;line-height:1.3;color:var(--bone);margin:24px 0 8px;
}
.article-section p,.article-section li{
  color:var(--bone-dim);font-size:1.04rem;line-height:1.75;
}
.article-section p{margin:0 0 14px}
.article-section p:last-child{margin-bottom:0}
.article-section strong{color:var(--bone);font-weight:600}
/* Liens DANS LE TEXTE uniquement (prose) — surtout pas les boutons/pills,
   sinon border-bottom écrase la bordure basse des pills (effet 3 côtés). */
.article-section p a,.article-section li a,.article-callout a,.article-lead a{
  color:var(--ember);font-weight:500;text-decoration:underline;
  text-decoration-color:rgba(226,104,60,.45);text-underline-offset:3px;text-decoration-thickness:1px;
  transition:text-decoration-color .25s var(--ease-out);
}
.article-section p a:hover,.article-section li a:hover,.article-callout a:hover,.article-lead a:hover,
.article-section p a:focus-visible,.article-section li a:focus-visible{text-decoration-color:var(--ember)}
.article-section ul,.article-section ol{margin:0 0 14px;padding-left:1.35em}
.article-section li{margin:7px 0}

/* ---------- Grille + cartes ---------- */
.article-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-top:20px}
.article-card{padding:22px;border:1px solid var(--line);border-radius:16px;background:rgba(0,0,0,.18)}
.article-card h3,.article-card h2{margin-top:0}
.article-card h2{font-family:var(--font-disp);font-weight:500;font-size:1.22rem;line-height:1.3;margin-bottom:12px}
.article-card p,.article-card ul{margin:0}

/* ---------- Badge + montant (scénarios) ---------- */
.article-badge{display:inline-flex;align-items:center;min-height:26px;border:1px solid rgba(226,104,60,.4);border-radius:999px;padding:0 11px;color:var(--ember);font-size:.68rem;font-weight:600;letter-spacing:.09em;text-transform:uppercase}
.article-amount{display:block;margin:14px 0 8px;color:var(--ember);font-family:var(--font-disp);font-weight:300;font-size:2rem;line-height:1}

/* ---------- Encadré (callout) ---------- */
.article-callout{
  margin-top:22px;padding:22px 24px;
  border:1px solid rgba(226,104,60,.28);border-radius:14px;
  background:rgba(226,104,60,.09);
}
.article-callout:first-child{margin-top:0}
.article-callout p{color:var(--bone)}
.article-callout p:last-child{margin-bottom:0}

/* ---------- Sommaire ---------- */
.article-toc{margin:24px 0 0;padding:18px clamp(18px,3vw,24px);border:1px solid var(--line);border-radius:14px;background:rgba(0,0,0,.18)}
.article-toc strong{display:block;font-family:var(--font-disp);font-weight:500;font-size:1.05rem;color:var(--bone);margin:0 0 12px}
.article-toc nav{display:flex;flex-wrap:wrap;gap:8px}
.article-toc a{font-size:.85rem;color:var(--bone-dim);border:1px solid var(--line);border-radius:999px;padding:6px 13px;transition:color .2s,border-color .2s}
.article-toc a:hover{color:var(--ember);border-color:var(--ember)}
.article-toc a.is-active{background:rgba(226,104,60,.14);border-color:var(--ember);color:var(--bone)}

/* ---------- Figure ---------- */
.article-figure{margin:28px 0}
.article-figure img{width:100%;height:auto;border-radius:16px;border:1px solid var(--line)}
.article-figure figcaption{margin-top:10px;font-size:.85rem;color:var(--bone-dim);font-style:italic}


/* ---------- Profil altimétrique ---------- */
.gb-profile{margin:0 0 22px;border:1px solid var(--line);border-radius:14px;background:rgba(0,0,0,.2);padding:14px clamp(12px,2vw,20px)}
.gb-profile .gp-svg{display:block;width:100%;height:auto}
.gb-profile figcaption{margin-top:8px;color:var(--bone-dim);font-size:.82rem;line-height:1.5}
.gb-profile figcaption b{color:var(--bone);font-weight:600}

/* ---------- Tableaux ---------- */
.article-table-wrap{width:100%;overflow-x:auto;margin-top:20px;border:1px solid var(--line);border-radius:16px;background:rgba(0,0,0,.16)}
.article-table{width:100%;min-width:640px;border-collapse:collapse}
.article-table th,.article-table td{padding:15px 18px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top;color:var(--bone-dim);line-height:1.6;font-size:1rem}
.article-table th{background:rgba(241,235,224,.045);color:var(--bone);font-size:.72rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase}
.article-table tr:last-child td{border-bottom:0}


/* difficulté colorée + totaux */
.gb-diff{font-weight:600}
.gb-diff--3{color:var(--bone-dim)}
.gb-diff--4{color:#e8b06a}
.gb-diff--5{color:var(--ember)}
.article-table tfoot td{background:rgba(226,104,60,.07);color:var(--bone);border-top:1px solid var(--line-strong)}

/* ---------- Boutons / actions ---------- */
.article-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:26px}
.article-button{
  display:inline-flex;align-items:center;justify-content:center;min-height:46px;
  padding:0 22px;border:1px solid var(--line-strong);border-radius:999px;
  background:transparent;color:var(--bone);font-family:var(--font-body);
  font-size:.92rem;font-weight:500;letter-spacing:.02em;text-decoration:none;
  transition:border-color .25s var(--ease-out),background .25s var(--ease-out),color .25s var(--ease-out);
}
.article-button:hover,.article-button:focus-visible{border-color:var(--bone);background:rgba(241,235,224,.06)}
.article-button--primary{background:var(--ember);border-color:var(--ember);color:var(--granite);font-weight:600}
.article-button--primary:hover,.article-button--primary:focus-visible{background:#ef7a4e;border-color:#ef7a4e;color:var(--granite)}

/* ---------- Listes spécifiques ---------- */
.source-list{display:grid;gap:10px;margin:18px 0 0;padding-left:20px}
.source-list a{color:var(--ember);border-bottom:1px solid transparent;transition:border-color .25s}
.source-list a:hover,.source-list a:focus-visible{border-color:var(--ember)}
.related-links{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.related-links a{
  display:inline-flex;min-height:42px;align-items:center;border:1px solid var(--line);
  border-radius:999px;padding:0 16px;color:var(--bone-dim);font-weight:500;text-decoration:none;
  transition:border-color .25s var(--ease-out),color .25s var(--ease-out);
}
.related-links a:hover,.related-links a:focus-visible{border-color:var(--ember);color:var(--ember)}
.check-list{display:grid;gap:11px;margin:16px 0 0;padding:0;list-style:none}
.check-list li{position:relative;padding-left:32px;color:var(--bone-dim)}
.check-list li::before{content:"";position:absolute;left:0;top:.45em;width:15px;height:15px;border:1px solid var(--ember);border-radius:4px;background:rgba(226,104,60,.12)}
.article-grid--checklist{grid-template-columns:repeat(2,minmax(0,1fr))}
.article-cta{padding:24px;border:1px solid rgba(226,104,60,.4);border-radius:18px;background:linear-gradient(145deg,rgba(226,104,60,.12),rgba(241,235,224,.03))}

/* ---------- Vidéo (embed vertical / short) ---------- */
.gb-videowrap{display:grid;grid-template-columns:1fr minmax(0,300px);gap:clamp(24px,4vw,52px);align-items:center;margin-top:4px}
.gb-video{position:relative;width:100%;aspect-ratio:9/16;border-radius:18px;overflow:hidden;border:1px solid var(--line);background:#000}
.gb-video iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block}

/* ---------- Responsive ---------- */
@media (max-width:760px){
  .breadcrumb{width:min(100% - 28px,980px);padding-top:clamp(82px,11vh,108px)}
  .article-shell{width:min(100% - 28px,980px)}
  .article-grid,.article-grid--checklist{grid-template-columns:1fr}
  .article-actions{flex-direction:column}
  .article-button{width:100%}
  .gb-videowrap{grid-template-columns:1fr;justify-items:center}
  .gb-video{max-width:300px}
  /* Tables -> cartes empilées sur mobile (libellés via data-label) */
  .article-table-wrap{border:0;background:transparent;overflow:visible}
  .article-table{min-width:0;display:block}
  .article-table thead{display:none}
  .article-table tbody,.article-table tfoot{display:block}
  .article-table tr{display:block;border:1px solid var(--line);border-radius:14px;background:rgba(0,0,0,.18);margin-bottom:12px;padding:2px}
  .article-table td{display:flex;justify-content:space-between;align-items:baseline;gap:14px;text-align:right;border:0;border-bottom:1px solid var(--line);padding:9px 15px;min-width:0}
  .article-table tr td:last-child{border-bottom:0}
  .article-table td::before{content:attr(data-label);color:var(--bone-dim);font-family:var(--font-body);font-size:.7rem;letter-spacing:.05em;text-transform:uppercase;font-weight:600;text-align:left;flex:none}
  .article-table td:not([data-label])::before{display:none}
}

/* ---------- Reduced-motion ---------- */
@media (prefers-reduced-motion:reduce){
  .article-button,.related-links a,.breadcrumb a,.article-section a,.source-list a{transition:none}
}
