/* ============================================================
   NECC — Page article (single post) redesign « Éditorial ».
   Scopé .nccx-single → n'affecte que la page article ; restyle
   les classes .single-* existantes + nouveaux éléments (byline, TOC).
   2026-06-24.
   ============================================================ */
.nccx-single{
  --orange:#DA673B; --orange-ink:#A04A2A; --orange-hover:#c25530; --orange-tint:#FBEEE6;
  --ink:#272322; --body:#4F4843; --muted:#8C8077;
  --line:#E7DFD7; --line2:#D4CBC6; --bg:#FBF9F7; --warm:#F4F1EF; --paper:#fff; --green:#1A6B1A;
  --r:20px; --r-sm:14px;
  --shadow:0 22px 50px -34px rgba(39,35,34,.4);
  --shadow-lg:0 36px 70px -34px rgba(39,35,34,.45);
  --symbol:url('https://groupe-necc.com/wp-content/uploads/2026/05/SYMBOL_RVB_ORANGE.png');
  background:var(--bg);
}
.nccx-single h1,.nccx-single h2,.nccx-single h3,.nccx-single h4{font-family:'Outfit',sans-serif;color:var(--ink);font-weight:700;line-height:1.18;letter-spacing:-.015em}
.nccx-single .single-article-content,.nccx-single p{font-family:'Outfit',sans-serif}

/* reading progress */
.nc-progress{position:fixed;top:0;left:0;height:3px;background:var(--orange);width:0;z-index:1000;transition:width .1s}

/* ---------- HERO ---------- */
.nccx-single .single-hero-section{position:relative;overflow:hidden;background:var(--bg);padding:40px 0 22px}
.nccx-single .single-hero-section::after{content:"";position:absolute;width:300px;height:130px;border-radius:999px;border:1.6px solid var(--orange);opacity:.12;top:-46px;right:-70px;transform:rotate(-22deg);pointer-events:none}
.nccx-single .single-hero-content{position:relative;z-index:1;max-width:820px}
.nccx-single .single-breadcrumb{display:flex;gap:8px;align-items:center;font-size:13px;color:var(--muted);margin-bottom:18px;flex-wrap:wrap}
.nccx-single .single-breadcrumb a:hover{color:var(--orange-ink)}
.nccx-single .breadcrumb-separator{opacity:.5}
.nccx-single .single-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:16px}
.nccx-single .single-category-pill{display:inline-flex;align-items:center;font-size:12px;font-weight:700;letter-spacing:.03em;color:var(--orange-ink);background:var(--orange-tint);padding:5px 13px;border-radius:999px}
.nccx-single .single-meta-date,.nccx-single .single-meta-reading-time{display:inline-flex;align-items:center;gap:6px;font-size:13.5px;color:var(--muted)}
.nccx-single .single-title{font-size:clamp(31px,4.2vw,48px);font-weight:800;max-width:20ch;margin:0 0 18px}
.nccx-single .single-excerpt{font-size:19px;line-height:1.6;color:var(--body);max-width:62ch;margin:0 0 24px}
/* byline (nouveau) */
.nccx-single .single-byline{display:flex;align-items:center;gap:13px}
.nccx-single .single-byline img{width:52px;height:52px;border-radius:50%;object-fit:cover;flex:none;background:var(--warm)}
.nccx-single .single-byline-name{display:block;font-weight:700;font-size:15.5px;color:var(--ink)}
.nccx-single .single-byline-role{display:block;font-size:13px;color:var(--muted)}

/* ---------- FEATURED IMAGE ---------- */
.nccx-single .single-featured-image-section{padding:18px 0 0}
.nccx-single .single-featured-image img{width:100%;max-height:460px;object-fit:cover;border-radius:40px 8px 40px 8px;display:block;box-shadow:var(--shadow)}

/* ---------- LAYOUT 2 cols ---------- */
.nccx-single .single-content-section{padding:40px 0 10px}
.nccx-single .single-layout{display:grid;grid-template-columns:260px minmax(0,1fr);gap:54px;align-items:start}
.nccx-single .single-sidebar{order:-1}            /* TOC à gauche */
.nccx-single .single-article{max-width:740px;min-width:0}

/* ---------- TOC ---------- */
.nccx-single .single-toc{position:sticky;top:84px}
.nccx-single .single-toc .toc-h{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:14px;display:flex;align-items:center;gap:8px}
.nccx-single .single-toc .toc-h svg{width:15px;height:15px;color:var(--orange)}
.nccx-single .single-toc ol{list-style:none;counter-reset:t;border-left:2px solid var(--line);margin:0;padding:0}
.nccx-single .single-toc li{counter-increment:t;margin:0}
.nccx-single .single-toc a{display:block;padding:8px 0 8px 16px;margin-left:-2px;border-left:2px solid transparent;font-size:13.5px;color:var(--muted);transition:color .2s,border-color .2s;line-height:1.4}
.nccx-single .single-toc a::before{content:counter(t,decimal-leading-zero) " ";color:var(--line2);font-weight:700;font-size:12px;margin-right:4px}
.nccx-single .single-toc a:hover{color:var(--ink)}
.nccx-single .single-toc a.active{color:var(--orange-ink);border-left-color:var(--orange);font-weight:600}
.nccx-single .single-toc a.active::before{color:var(--orange)}
.nccx-single .toc-cta{margin-top:22px;background:var(--ink);color:#EDE7E1;border-radius:var(--r-sm);padding:18px 18px 20px;position:relative;overflow:hidden}
.nccx-single .toc-cta::after{content:"";position:absolute;width:140px;height:64px;border-radius:999px;border:1.5px solid var(--orange);opacity:.4;right:-30px;bottom:-24px;transform:rotate(16deg)}
.nccx-single .toc-cta p{position:relative;z-index:1;font-size:13.5px;color:#CFC4BA;margin:0 0 12px;line-height:1.45}
.nccx-single .toc-cta a{position:relative;z-index:1;display:inline-flex;align-items:center;gap:7px;font-weight:600;font-size:13.5px;color:#fff;background:var(--orange);border-radius:999px;padding:9px 16px}

/* ---------- PROSE (the_content) ---------- */
.nccx-single .single-article-content{font-size:17px;line-height:1.75;color:var(--body)}
.nccx-single .single-article-content > *:first-child{margin-top:0}
.nccx-single .single-article-content h2{font-size:clamp(23px,2.5vw,29px);margin:42px 0 15px;scroll-margin-top:84px;padding-top:6px}
.nccx-single .single-article-content h3{font-size:20px;margin:28px 0 11px;color:var(--ink)}
.nccx-single .single-article-content p{margin:0 0 18px}
.nccx-single .single-article-content a{color:var(--orange-ink);font-weight:600;text-decoration:underline;text-underline-offset:3px;text-decoration-color:rgba(218,103,59,.4)}
.nccx-single .single-article-content strong{color:var(--ink);font-weight:700}
.nccx-single .single-article-content ul,.nccx-single .single-article-content ol{margin:0 0 18px;padding-left:4px;list-style:none}
.nccx-single .single-article-content ul li,.nccx-single .single-article-content ol li{position:relative;padding-left:28px;margin-bottom:10px;line-height:1.6}
.nccx-single .single-article-content ul li::before{content:"";position:absolute;left:6px;top:11px;width:7px;height:7px;border-radius:50%;background:var(--orange)}
.nccx-single .single-article-content ol{counter-reset:li}
.nccx-single .single-article-content ol li{counter-increment:li}
.nccx-single .single-article-content ol li::before{content:counter(li);position:absolute;left:0;top:1px;width:20px;height:20px;border-radius:50%;background:var(--orange-tint);color:var(--orange-ink);font-size:11px;font-weight:700;display:grid;place-items:center}
.nccx-single .single-article-content blockquote{margin:24px 0;padding:18px 24px;border-left:4px solid var(--orange);background:var(--warm);border-radius:0 var(--r-sm) var(--r-sm) 0;font-size:18px;color:var(--ink);font-weight:500}
.nccx-single .single-article-content img{max-width:100%;height:auto;border-radius:var(--r-sm);margin:24px 0}
.nccx-single .single-article-content h2 + p{margin-top:0}
/* tables (wrappées en .nc-tablewrap par JS) */
.nccx-single .nc-tablewrap{overflow-x:auto;margin:22px 0;border:1px solid var(--line);border-radius:var(--r-sm)}
.nccx-single .single-article-content table{width:100%;border-collapse:collapse;font-size:15px;min-width:520px;margin:0}
.nccx-single .single-article-content table th{text-align:left;padding:13px 18px;font-weight:700;color:#fff;background:var(--ink);font-size:14px}
.nccx-single .single-article-content table td{padding:12px 18px;border-top:1px solid var(--line);vertical-align:top;line-height:1.5}
.nccx-single .single-article-content table td:first-child{border-right:1px solid var(--line)}
.nccx-single .single-article-content table tr:nth-child(even) td{background:var(--warm)}

/* ---------- TAGS ---------- */
.nccx-single .single-article-tags{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin:34px 0 0}
.nccx-single .single-tags-label{font-size:13px;font-weight:600;color:var(--muted)}
.nccx-single .single-tag-pill{font-size:12.5px;font-weight:600;color:var(--body);background:var(--warm);border:1px solid var(--line);padding:5px 12px;border-radius:999px}
.nccx-single .single-tag-pill:hover{border-color:var(--orange);color:var(--orange-ink)}

/* ---------- AUTHOR BOX ---------- */
.nccx-single .single-article-author{display:flex;gap:20px;align-items:flex-start;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:26px;margin:34px 0 0;box-shadow:var(--shadow)}
.nccx-single .single-author-avatar{flex:none}
.nccx-single .single-author-avatar img,.nccx-single .single-author-img{width:74px;height:74px;border-radius:50%;object-fit:cover;display:block;background:var(--warm)}
.nccx-single .single-author-label{font-size:11.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--orange-ink);display:block;margin-bottom:3px}
.nccx-single .single-author-name{font-family:'Outfit';font-size:18px;font-weight:700;color:var(--ink);display:block}
.nccx-single .single-author-role{font-size:13.5px;color:var(--muted);display:block;margin-bottom:9px}
.nccx-single .single-author-bio{font-size:14.5px;color:var(--body);line-height:1.6;margin:0}

/* ---------- SHARE ---------- */
.nccx-single .single-article-share{display:flex;align-items:center;flex-wrap:wrap;gap:10px;margin:28px 0 0}
.nccx-single .single-share-label{font-size:13px;font-weight:600;color:var(--muted)}
.nccx-single .single-share-btn{display:inline-flex;align-items:center;gap:7px;font-family:'Outfit';font-weight:600;font-size:13.5px;color:var(--body);background:var(--paper);border:1px solid var(--line2);border-radius:999px;padding:8px 15px;cursor:pointer;transition:all .2s}
.nccx-single .single-share-btn:hover{border-color:var(--orange);color:var(--orange-ink)}

/* ---------- CTA band (fin d'article) ---------- */
.nccx-single .single-cta-section{padding:46px 0 0}
.nccx-single .single-cta-box{position:relative;overflow:hidden;background:var(--ink);color:#EDE7E1;border-radius:var(--r);padding:40px 42px;display:flex;align-items:center;justify-content:space-between;gap:28px;flex-wrap:wrap}
.nccx-single .single-cta-box::before{content:"";position:absolute;width:380px;height:150px;border-radius:999px;border:1.6px solid var(--orange);opacity:.35;left:-80px;top:-50px;transform:rotate(-20deg)}
.nccx-single .single-cta-box::after{content:"";position:absolute;width:220px;height:100px;border-radius:999px;border:1.6px solid #6a5f57;opacity:.5;right:60px;bottom:-44px;transform:rotate(15deg)}
.nccx-single .single-cta-content{position:relative;z-index:1;flex:1;min-width:240px}
.nccx-single .single-cta-title{color:#fff;font-size:clamp(22px,2.6vw,30px);margin:0 0 8px}
.nccx-single .single-cta-text{color:#B7AB9C;font-size:15px;line-height:1.55;margin:0;max-width:52ch}
.nccx-single .single-cta-button{position:relative;z-index:1;display:inline-flex;align-items:center;gap:9px;font-family:'Outfit';font-weight:600;font-size:15.5px;color:#fff;background:var(--orange);border-radius:999px;padding:15px 28px;white-space:nowrap;transition:background .2s,transform .15s}
.nccx-single .single-cta-button:hover{background:var(--orange-hover);transform:translateY(-1px);color:#fff}

/* ---------- RELATED ---------- */
.nccx-single .single-related-section{padding:54px 0 10px}
.nccx-single .single-related-title{font-size:clamp(24px,3vw,32px);text-align:center;margin:0 0 28px}
.nccx-single .single-related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.nccx-single .single-related-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s,border-color .2s}
.nccx-single .single-related-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--line2)}
.nccx-single .single-related-card-thumb{display:block;aspect-ratio:16/10;overflow:hidden;background:var(--warm)}
.nccx-single .single-related-card-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.nccx-single .single-related-card-body{padding:20px}
.nccx-single .single-related-card-meta{font-size:11.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:8px}
.nccx-single .single-related-card-title{font-family:'Outfit';font-size:17px;font-weight:700;color:var(--ink);line-height:1.3;display:block}
.nccx-single .single-related-card:hover .single-related-card-title{color:var(--orange-ink)}

/* ---------- NAV prev/next ---------- */
.nccx-single .single-navigation-section{padding:30px 0 10px}
.nccx-single .single-post-navigation{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}
.nccx-single .single-post-navigation .nav-links{display:flex;justify-content:space-between;gap:16px;width:100%}
.nccx-single .single-post-navigation a{flex:1;min-width:0;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-sm);padding:16px 18px;transition:border-color .2s}
.nccx-single .single-post-navigation a:hover{border-color:var(--orange)}
.nccx-single .single-post-navigation .nav-subtitle{display:block;font-size:12px;font-weight:600;color:var(--orange-ink);margin-bottom:4px}
.nccx-single .single-post-navigation .nav-title{display:block;font-weight:600;color:var(--ink);font-size:15px;line-height:1.3}

/* ---------- RESPONSIVE ---------- */
@media(max-width:920px){
  .nccx-single .single-layout{grid-template-columns:1fr;gap:0}
  .nccx-single .single-sidebar{order:0;margin-bottom:28px}
  .nccx-single .single-toc{position:static;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:18px 22px}
  .nccx-single .toc-cta{display:none}
  .nccx-single .single-related-grid{grid-template-columns:1fr}
  .nccx-single .single-featured-image img{border-radius:24px 6px 24px 6px;max-height:300px}
  .nccx-single .single-cta-box{padding:30px 26px}
}
@media(max-width:560px){
  .nccx-single .single-article-content{font-size:16.5px}
  .nccx-single .single-post-navigation .nav-links{flex-direction:column}
}
