/* ============================================================
   Almanach du Jardin - Single article styles
   Layout : TOC sidebar (240px) + body (720px) + right rail (240px)
   Total : 1360px desktop
   ============================================================ */

.adj-single-hero {
  padding: 64px 24px 32px;
  text-align: center;
}
.adj-single-eyebrow {
  font-family: var(--adj-font-mono);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--adj-muted);
}
.adj-single-meta {
  margin-bottom: 24px;
}
.adj-single-title {
  font-family: var(--adj-font-title);
  font-size: clamp(40px, 5.4vw, 64px);
  font-weight: 600;
  line-height: 1.05;
  letter-spacing: -0.025em;
  color: var(--adj-ink);
  margin: 12px 0 20px;
}
.adj-single-subtitle {
  font-family: var(--adj-font-title);
  font-style: italic;
  font-size: clamp(18px, 2vw, 22px);
  color: var(--adj-ink-soft);
  line-height: 1.45;
  max-width: 640px;
  margin: 0 auto;
}

/* ============================================================
   Layout 3 colonnes desktop (1024+)
   ============================================================ */
.adj-single-layout { padding: 48px 0 64px; }
.adj-single-grid {
  display: grid;
  grid-template-columns: 240px minmax(0, 720px) 240px;
  gap: 40px;
  justify-content: center;
  max-width: var(--adj-container-article-3col);
  margin: 0 auto;
  padding: 0 24px;
  align-items: flex-start;
}

.adj-single-toc-rail,
.adj-single-rail-right {
  position: sticky;
  top: 96px;
  align-self: start;
}

/* ---------- TOC sidebar (gauche) ---------- */
.adj-toc {
  font-family: var(--adj-font-body);
  font-size: 14px;
  line-height: 1.5;
}
.adj-toc__title {
  font-family: var(--adj-font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--adj-muted);
  margin: 0 0 16px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--adj-base-deep);
}
.adj-toc__list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.adj-toc__item {
  margin-bottom: 10px;
  padding-left: 14px;
  border-left: 2px solid transparent;
  transition: border-color 0.18s ease, color 0.18s ease;
}
.adj-toc__item--sub { padding-left: 28px; font-size: 13px; }
.adj-toc__item a {
  color: var(--adj-ink-soft);
  text-decoration: none;
  display: block;
  padding: 2px 0;
}
.adj-toc__item a:hover { color: var(--adj-accent); }
.adj-toc__item.is-active {
  border-left-color: var(--adj-accent);
}
.adj-toc__item.is-active a { color: var(--adj-accent-deep); font-weight: 600; }

/* Mobile TOC (collapsible) */
.adj-toc-mobile {
  display: none;
  margin: 24px 24px 32px;
  background: var(--adj-base-soft);
  border-radius: var(--adj-radius-card);
  padding: 16px 20px;
}
.adj-toc-mobile summary {
  font-family: var(--adj-font-mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--adj-accent-deep);
  cursor: pointer;
  list-style: none;
}
.adj-toc-mobile summary::after {
  content: " ▼";
  font-size: 10px;
}
.adj-toc-mobile[open] summary::after { content: " ▲"; }

/* ---------- Right rail ---------- */
.adj-single-rail-right {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.adj-rail-card {
  background: var(--adj-base-soft);
  border-radius: 12px;
  padding: 18px 20px;
}
.adj-rail-card .adj-eyebrow {
  margin: 0 0 10px;
  font-size: 11px;
}

/* ============================================================
   Article body
   ============================================================ */
.adj-article {
  max-width: 720px;
  margin: 0 auto;
  font-family: var(--adj-font-body);
  font-size: 17px;
  line-height: 1.7;
  color: var(--adj-ink-soft);
}
.adj-article > * { margin: 0 0 1.4em; }
.adj-article h2 {
  font-family: var(--adj-font-title);
  font-size: clamp(28px, 3.2vw, 36px);
  font-weight: 600;
  color: var(--adj-ink);
  margin: 2em 0 0.6em;
  letter-spacing: -0.015em;
  scroll-margin-top: 100px;
}
.adj-article h2::before {
  content: "";
  display: block;
  width: 32px;
  height: 3px;
  background: var(--adj-accent);
  margin-bottom: 16px;
  border-radius: 2px;
}
.adj-article h3 {
  font-family: var(--adj-font-title);
  font-size: clamp(20px, 2.2vw, 24px);
  font-weight: 600;
  color: var(--adj-ink);
  margin: 1.8em 0 0.5em;
  scroll-margin-top: 100px;
}
.adj-article p { margin: 0 0 1.2em; }
.adj-article a {
  color: var(--adj-accent);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}
.adj-article ul, .adj-article ol { padding-left: 1.4em; margin-bottom: 1.4em; }
.adj-article li { margin-bottom: 0.4em; }

/* Drop cap vert mousse sur 1er paragraphe */
.adj-article .adj-drop-cap,
.adj-article > p:first-of-type::first-letter {
  font-family: var(--adj-font-title);
  font-weight: 700;
  font-size: 4.2em;
  line-height: 0.9;
  color: var(--adj-accent);
  float: left;
  margin: 0.05em 0.12em 0 0;
}
.adj-article .adj-drop-cap {
  display: block;
  float: left;
  font-size: 4.2em;
  line-height: 0.9;
}

/* Blockquote / pull quote */
.adj-article blockquote {
  border-left: 3px solid var(--adj-accent);
  padding: 8px 24px;
  margin: 32px 0;
  font-family: var(--adj-font-title);
  font-style: italic;
  font-size: 22px;
  color: var(--adj-ink);
  line-height: 1.4;
}
.adj-article blockquote cite {
  display: block;
  margin-top: 12px;
  font-family: var(--adj-font-mono);
  font-style: normal;
  font-size: 12px;
  color: var(--adj-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* Figures + images */
.adj-article figure { margin: 32px 0; }
.adj-article figure img { border-radius: 10px; }
.adj-article figcaption {
  font-family: var(--adj-font-body);
  font-style: italic;
  font-size: 14px;
  color: var(--adj-muted);
  margin-top: 8px;
  text-align: center;
}

/* ============================================================
   Nav prev / next
   ============================================================ */
.adj-prevnext {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
}
.adj-prevnext .adj-prevnext__link a {
  font-family: var(--adj-font-body);
  font-size: 14px;
  font-weight: 600;
  color: var(--adj-accent-deep);
  text-decoration: none;
}
.adj-prevnext .adj-prevnext__link a:hover { color: var(--adj-accent); }
.adj-prevnext .adj-prevnext__link--next { margin-left: auto; text-align: right; }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 1024px) {
  .adj-single-grid {
    grid-template-columns: 1fr;
    max-width: 760px;
  }
  .adj-single-toc-rail,
  .adj-single-rail-right {
    position: static;
    width: 100%;
  }
  .adj-single-rail-right {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 12px;
  }
  .adj-rail-card { flex: 1 1 220px; }
  .adj-toc-mobile { display: block; }
  .adj-single-toc-rail { display: none; }
}
@media (max-width: 640px) {
  .adj-single-hero { padding: 40px 20px 24px; }
  .adj-article { font-size: 16px; padding: 0 20px; }
  .adj-article .adj-drop-cap,
  .adj-article > p:first-of-type::first-letter { font-size: 3.6em; }
}
