/*
 * ComDesMariés — Single Article CSS
 * Lecture immersive · EEAT · CLS optimisé
 */

/* ─── Layout ──────────────────────────────────────────────────────────── */

.single-main { padding-bottom: 4rem; }

.single-container {
  max-width: 720px;
  margin-inline: auto;
  padding: 2rem 1.25rem 0;
}

@media (min-width: 768px) {
  .single-container { padding-inline: 2rem; }
}

/* ─── Header article ──────────────────────────────────────────────────── */

.single-header { margin-bottom: 1.75rem; }

.single-cat {
  display: inline-block;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--c-accent);
  margin-bottom: .75rem;
}
.single-cat:hover { color: var(--c-accent-h); }

.single-title {
  font-family: var(--font-serif);
  font-size: clamp(1.875rem, 5vw, 3rem);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -.02em;
  color: var(--c-text);
  margin-bottom: 1.25rem;
}

.single-excerpt {
  font-size: clamp(.9375rem, 2.5vw, 1.0625rem);
  color: var(--c-text-soft);
  line-height: 1.7;
  border-left: 3px solid var(--c-accent);
  padding-left: 1rem;
  margin-bottom: 1.5rem;
  font-style: normal;
}

/* ─── Méta EEAT ───────────────────────────────────────────────────────── */

.single-meta {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1rem 0;
  border-top: 1px solid var(--c-border);
  border-bottom: 1px solid var(--c-border);
  flex-wrap: wrap;
}

.meta-author {
  display: flex;
  align-items: center;
  gap: .625rem;
  text-decoration: none;
  flex-shrink: 0;
}

.meta-avatar .cdm-avatar {
  width: 40px !important;
  height: 40px !important;
  border-radius: 50% !important;
  border: 2px solid var(--c-border);
  object-fit: cover;
}

.meta-author-info {
  display: flex;
  flex-direction: column;
  gap: .05rem;
}

.meta-author-role {
  font-size: .62rem;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--c-accent);
}

.meta-author-name {
  font-size: .875rem;
  font-weight: 600;
  color: var(--c-text);
}

.meta-right {
  display: flex;
  align-items: center;
  gap: .4rem;
  flex-wrap: wrap;
}

.meta-date,
.meta-reading,
.meta-updated {
  font-size: .78rem;
  color: var(--c-text-mute);
}

.meta-sep { color: var(--c-border); font-size: .875rem; }

/* Bouton partage */
.share-btn {
  display: inline-flex;
  align-items: center;
  gap: .375rem;
  font-size: .78rem;
  font-weight: 500;
  color: var(--c-text-soft);
  background: none;
  border: 1px solid var(--c-border);
  padding: .35rem .875rem;
  border-radius: 20px;
  margin-left: auto;
  transition: all var(--tr);
  font-family: var(--font-sans);
}
.share-btn:hover { border-color: var(--c-text); color: var(--c-text); }

/* ─── Image à la une — CLS = 0 ────────────────────────────────────────── */

.single-hero {
  margin: 1.75rem 0;
  /* CLS : aspect-ratio réserve l'espace AVANT chargement de l'image */
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border-radius: 6px;
  background: var(--c-surface-2);
}

.single-hero-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.single-hero-caption {
  margin-top: .5rem;
  font-size: .78rem;
  color: var(--c-text-mute);
  text-align: center;
  font-style: italic;
}

/* ─── Barre de lecture ────────────────────────────────────────────────── */

.read-progress {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--c-surface-2);
  z-index: 200;
  /* will-change évite le repaint = meilleur INP */
  will-change: opacity;
}

.read-progress-bar {
  height: 100%;
  background: var(--c-accent);
  width: 0%;
  transition: width .1s linear;
  will-change: width;
}

/* ─── Contenu éditorial ───────────────────────────────────────────────── */

.single-content {
  font-size: clamp(.9375rem, 2vw, 1.0625rem);
  line-height: 1.8;
  color: var(--c-text-soft);
  padding: 2rem 0;
}

/* Conteneur texte limité pour la lisibilité */
.single-content > p,
.single-content > ul,
.single-content > ol,
.single-content > blockquote,
.single-content > h2,
.single-content > h3,
.single-content > h4 {
  max-width: 68ch;
}

/* Titres dans le contenu */
.single-content h2 {
  font-family: var(--font-serif);
  font-size: clamp(1.35rem, 3.5vw, 1.875rem);
  font-weight: 700;
  line-height: 1.25;
  color: var(--c-text);
  margin: 2.5rem 0 .875rem;
  letter-spacing: -.01em;
}

.single-content h3 {
  font-family: var(--font-serif);
  font-size: clamp(1.1rem, 2.5vw, 1.375rem);
  font-weight: 700;
  color: var(--c-text);
  margin: 2rem 0 .625rem;
}

.single-content h4 {
  font-size: .9375rem;
  font-weight: 700;
  color: var(--c-text);
  letter-spacing: .04em;
  text-transform: uppercase;
  margin: 1.5rem 0 .5rem;
}

/* Paragraphes */
.single-content p { margin-bottom: 1.5rem; }

/* Listes */
.single-content ul,
.single-content ol {
  padding-left: 1.5rem;
  margin-bottom: 1.5rem;
}

.single-content ul { list-style: none; padding-left: 0; }

.single-content ul li {
  padding-left: 1.375rem;
  position: relative;
  margin-bottom: .5rem;
}

.single-content ul li::before {
  content: '';
  position: absolute;
  left: .375rem;
  top: .75rem;
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--c-accent);
}

.single-content ol li { margin-bottom: .5rem; }

/* Liens */
.single-content a {
  color: var(--c-accent);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
  text-decoration-color: rgba(200,100,90,.4);
  transition: text-decoration-color var(--tr);
}
.single-content a:hover { text-decoration-color: var(--c-accent); }

/* Strong */
.single-content strong { color: var(--c-text); font-weight: 700; }

/* Blockquote */
.single-content blockquote {
  border-left: 3px solid var(--c-accent);
  margin: 2rem 0;
  padding: 1.25rem 1.5rem;
  background: var(--c-surface);
  border-radius: 0 6px 6px 0;
}

.single-content blockquote p {
  font-family: var(--font-serif);
  font-size: clamp(1rem, 2.5vw, 1.2rem);
  font-style: italic;
  color: var(--c-text);
  margin: 0;
}

.single-content blockquote cite {
  display: block;
  font-size: .78rem;
  color: var(--c-text-mute);
  margin-top: .75rem;
  font-style: normal;
}

/* Images dans contenu — CLS */
.single-content img {
  max-width: 100%;
  height: auto;
  border-radius: 6px;
  display: block;
}

.single-content figure { margin: 2rem 0; }

.single-content figcaption {
  font-size: .78rem;
  color: var(--c-text-mute);
  text-align: center;
  margin-top: .5rem;
  font-style: italic;
}

/* Tableau */
.single-content table {
  width: 100%;
  border-collapse: collapse;
  font-size: .875rem;
  margin: 1.5rem 0;
  overflow-x: auto;
  display: block;
}

.single-content th,
.single-content td {
  padding: .625rem .875rem;
  border: 1px solid var(--c-border);
  text-align: left;
}

.single-content th {
  background: var(--c-surface);
  font-weight: 600;
  font-size: .75rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--c-text-mute);
}

/* Code */
.single-content code {
  background: var(--c-surface-2);
  padding: .15em .4em;
  font-size: .875em;
  border-radius: 3px;
  border: 1px solid var(--c-border);
}

/* ─── Tags ────────────────────────────────────────────────────────────── */

.single-tags {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
  padding: 1.25rem 0;
  border-top: 1px solid var(--c-border);
}

.tag-pill {
  font-size: .72rem;
  font-weight: 500;
  padding: .3rem .75rem;
  border: 1px solid var(--c-border);
  border-radius: 20px;
  color: var(--c-text-soft);
  transition: all var(--tr);
}
.tag-pill:hover { border-color: var(--c-accent); color: var(--c-accent); }

/* ─── Bloc auteur EEAT ────────────────────────────────────────────────── */

.author-box {
  display: flex;
  gap: 1.25rem;
  padding: 1.5rem;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-left: 4px solid var(--c-accent);
  border-radius: 0 6px 6px 0;
  margin: 2.5rem 0;
  align-items: flex-start;
}

.author-box-avatar .cdm-avatar {
  width: 72px !important;
  height: 72px !important;
  border-radius: 50% !important;
  object-fit: cover;
  border: 2px solid var(--c-border);
  flex-shrink: 0;
}

.author-box-info { flex: 1; min-width: 0; }

.author-box-top { margin-bottom: .375rem; }

.author-box-role {
  display: block;
  font-size: .62rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--c-accent);
  margin-bottom: .2rem;
}

.author-box-name {
  font-family: var(--font-serif);
  font-size: 1.25rem;
  font-weight: 700;
  margin-bottom: .5rem;
}
.author-box-name a { color: var(--c-text); }
.author-box-name a:hover { color: var(--c-accent); }

.author-box-bio {
  font-size: .875rem;
  color: var(--c-text-soft);
  line-height: 1.6;
  margin-bottom: .75rem;
}

.author-box-link {
  font-size: .8rem;
  font-weight: 500;
  color: var(--c-accent);
}
.author-box-link:hover { color: var(--c-accent-h); }

@media (max-width: 480px) {
  .author-box { flex-direction: column; gap: .875rem; }
  .author-box-avatar .cdm-avatar { width: 52px !important; height: 52px !important; }
}

/* ─── Navigation précédent/suivant ────────────────────────────────────── */

.single-nav {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  padding: 2rem 0;
  border-top: 1px solid var(--c-border);
}

.single-nav-link {
  display: flex;
  flex-direction: column;
  gap: .25rem;
  padding: 1rem;
  border: 1px solid var(--c-border);
  border-radius: 6px;
  transition: all var(--tr);
  text-decoration: none;
}

.single-nav-link:hover {
  border-color: var(--c-accent);
  background: rgba(200,100,90,.04);
}

.single-nav-link--next { text-align: right; }

.single-nav-dir {
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--c-text-mute);
}

.single-nav-title {
  font-size: .875rem;
  font-weight: 500;
  color: var(--c-text);
  line-height: 1.35;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* ─── Articles liés ───────────────────────────────────────────────────── */

.related-section {
  padding: 2.5rem 0;
  border-top: 1px solid var(--c-border);
}

.related-title {
  font-family: var(--font-serif);
  font-size: 1.35rem;
  font-weight: 700;
  margin-bottom: 1.5rem;
  color: var(--c-text);
}

.related-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
}

@media (min-width: 560px) {
  .related-grid { grid-template-columns: repeat(3, 1fr); }
}

/* ─── Commentaires ────────────────────────────────────────────────────── */

.comments-wrap { padding: 2.5rem 0; }

.comments-section { border-top: 1px solid var(--c-border); padding-top: 2rem; }

.comments-title {
  font-family: var(--font-serif);
  font-size: 1.35rem;
  font-weight: 700;
  margin-bottom: 1.5rem;
  color: var(--c-text);
}

.comments-list { list-style: none; display: flex; flex-direction: column; gap: 1.25rem; }

.comment-item { padding-bottom: 1.25rem; border-bottom: 1px solid var(--c-border); }

.comment-body { display: flex; gap: .875rem; align-items: flex-start; }

.comment-avatar img {
  width: 40px !important;
  height: 40px !important;
  border-radius: 50%;
  border: 1px solid var(--c-border);
  flex-shrink: 0;
}

.comment-content { flex: 1; }

.comment-meta {
  display: flex;
  align-items: center;
  gap: .625rem;
  margin-bottom: .5rem;
}

.comment-author { font-size: .875rem; font-weight: 600; color: var(--c-text); }

.comment-date { font-size: .75rem; color: var(--c-text-mute); }

.comment-text { font-size: .9rem; color: var(--c-text-soft); line-height: 1.65; }
.comment-text p { margin-bottom: .5rem; }

.comment-actions { margin-top: .5rem; }
.comment-actions a {
  font-size: .78rem;
  font-weight: 500;
  color: var(--c-text-mute);
}
.comment-actions a:hover { color: var(--c-accent); }

/* Formulaire commentaires */
.comment-form { margin-top: 2rem; }

.comment-form label {
  display: block;
  font-size: .82rem;
  font-weight: 600;
  color: var(--c-text);
  margin-bottom: .375rem;
}

.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea {
  width: 100%;
  border: 1px solid var(--c-border);
  padding: .625rem .875rem;
  font-size: .9rem;
  font-family: var(--font-sans);
  border-radius: 4px;
  background: var(--c-surface);
  outline: none;
  transition: border-color var(--tr);
  /* CLS : height explicite */
}

.comment-form input:focus,
.comment-form textarea:focus { border-color: var(--c-accent); background: #fff; }

.comment-form textarea { min-height: 130px; resize: vertical; }

.comment-form .comment-form-comment,
.comment-form .comment-form-author,
.comment-form .comment-form-email { margin-bottom: 1rem; }

.comment-form .form-submit { margin-top: 1.25rem; }
