/* =============================================================================
 * Arabdown Child — Single Article (Neo-Noir Editorial)
 * -----------------------------------------------------------------------------
 * v2.0.0 — Full rewrite. RTL-first, 65ch reading width, @layer components.
 * لا !important داخل الـ layer — overrides parent تُحَلّ في overrides.css.
 *
 * البنية:
 *   ① Article header (hero image + title + meta)
 *   ② Article layout (TOC sidebar + main)
 *   ③ Article body (typography 17-19px / 1.75)
 *   ④ Byline (author card)
 *   ⑤ Tags + share footer
 *   ⑥ Related (uses .hp-cat__list-link from homepage.css)
 *   ⑦ Newsletter CTA
 *   ⑧ Comments
 * ============================================================================= */
@layer components {


/* ============================================================
 *  Single article wrapper
 * ============================================================ */
.single-article {
  display: block;
  inline-size: 100%;
  max-inline-size: 100%;
  background: var(--ad-bg);
  color: var(--ad-text);
}


/* ============================================================
 *  ① ARTICLE HEADER (hero + meta)
 * ============================================================ */
.article-header {
  margin-block-end: var(--ad-space-7);
  position: relative;
}
.article-header__hero {
  aspect-ratio: 16 / 9;
  background: var(--ad-surface-high);
  overflow: hidden;
  position: relative;
  border-radius: 0;
}
.article-header__hero img {
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
}
.article-header__hero--no-image {
  aspect-ratio: 21 / 9;
  background: linear-gradient(135deg, var(--ad-surface) 0%, var(--ad-bg-alt) 100%);
}
/* Gradient overlay يضمن قراءة العنوان فوق الصورة */
.article-header__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    var(--ad-bg) 0%,
    rgba(18, 20, 20, 0.7) 30%,
    transparent 60%
  );
  pointer-events: none;
}

.article-header__inner {
  max-inline-size: 820px;
  margin-inline: auto;
  padding-inline: var(--ad-container-px);
  padding-block: var(--ad-space-6) var(--ad-space-4);
  position: relative;
  z-index: 2;
}
/* عنوان فوق الصورة (overlay) */
.article-header__hero + .article-header__inner {
  margin-block-start: -120px;
}
@media (max-width: 767.98px) {
  .article-header__hero + .article-header__inner {
    margin-block-start: -80px;
  }
}

.article-header__category {
  align-self: flex-start;
  display: inline-block;
  padding: var(--ad-space-1) var(--ad-space-3);
  background: var(--ad-primary);
  color: var(--ad-on-primary);
  font-family: var(--ad-font-latin);
  font-size: var(--ad-fs-label);
  font-weight: var(--ad-fw-bold);
  text-transform: uppercase;
  letter-spacing: var(--ad-tracking-wide);
  text-decoration: none;
  border-radius: var(--ad-radius-sharp);
  margin-block-end: var(--ad-space-3);
}
.article-header__title {
  font-size: var(--ad-fs-h1);
  font-weight: var(--ad-fw-bold);
  line-height: var(--ad-lh-display);
  color: var(--ad-text);
  margin: 0 0 var(--ad-space-3);
  max-inline-size: 28ch;
  overflow-wrap: break-word;
  word-break: break-word;
}
.article-header__lead {
  font-size: var(--ad-fs-body-lg);
  line-height: var(--ad-lh-body);
  color: var(--ad-text-variant);
  margin: 0 0 var(--ad-space-4);
  max-inline-size: 60ch;
}
.article-header__meta {
  display: flex;
  align-items: center;
  gap: var(--ad-space-3);
  flex-wrap: wrap;
  font-size: var(--ad-fs-meta);
  color: var(--ad-text-muted);
  padding-block-start: var(--ad-space-3);
  border-block-start: 1px solid var(--ad-outline);
}
.article-header__meta a {
  color: var(--ad-primary);
  text-decoration: none;
}
.article-header__meta a:hover { text-decoration: underline; }


/* ============================================================
 *  ② ARTICLE LAYOUT (TOC + main)
 * ============================================================ */
.single-layout {
  max-inline-size: var(--ad-container);
  margin-inline: auto;
  padding-inline: var(--ad-container-px);
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--ad-space-6);
}
@media (min-width: 1024px) {
  .single-layout--with-toc {
    grid-template-columns: 240px minmax(0, 1fr);
    gap: var(--ad-space-7);
  }
}
.single-layout__toc-col {
  display: contents;
}
@media (min-width: 1024px) {
  .single-layout--with-toc .single-layout__toc-col {
    display: block;
    grid-column: 1;
  }
  .single-layout--with-toc .single-layout__main {
    grid-column: 2;
  }
}

.single-layout__main {
  min-inline-size: 0;
}


/* ============================================================
 *  ③ ARTICLE BODY (typography + spacing)
 * ============================================================ */
.article-body {
  font-size: var(--ad-fs-body-lg);     /* 17-19px reading */
  line-height: var(--ad-lh-body);      /* 1.75 — عربي مريح */
  color: var(--ad-text);
  max-inline-size: 65ch;               /* optimal readability */
  margin-inline: auto;
}

/* Paragraphs */
.article-body p {
  margin-block: 0 1.25rem;
}
.article-body p:last-child { margin-block-end: 0; }

/* Headings — H2 يستخدم accent border-inline-start (لا blockquote-look) */
.article-body h2 {
  font-size: var(--ad-fs-h2);
  font-weight: var(--ad-fw-bold);
  line-height: var(--ad-lh-heading);
  color: var(--ad-text);
  margin-block: var(--ad-space-7) var(--ad-space-3);
  padding-inline-start: var(--ad-space-3);
  border-inline-start: 3px solid var(--ad-primary);
  /* لا background. لا padding-block-end. لا border-block-end. */
  background: none;
}
.article-body h3 {
  font-size: var(--ad-fs-h3);
  font-weight: var(--ad-fw-semibold);
  line-height: var(--ad-lh-heading);
  color: var(--ad-text);
  margin-block: var(--ad-space-6) var(--ad-space-3);
}
.article-body h4 {
  font-size: var(--ad-fs-h4);
  font-weight: var(--ad-fw-semibold);
  line-height: var(--ad-lh-heading);
  color: var(--ad-text);
  margin-block: var(--ad-space-5) var(--ad-space-2);
}

.article-body :where(h2, h3, h4):first-child {
  margin-block-start: 0;
}

/* Links */
.article-body a {
  color: var(--ad-primary);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 4px;
  transition: color var(--ad-dur-base);
}
.article-body a:hover {
  color: var(--ad-primary-fixed);
}

/* Lists */
.article-body :where(ul, ol) {
  margin-block: 0 1.25rem;
  padding-inline-start: var(--ad-space-5);
}
.article-body li {
  margin-block: var(--ad-space-2) 0;
}
.article-body ul li::marker { color: var(--ad-primary); }

/* Blockquote — تصميم quote حقيقي */
.article-body blockquote {
  border-inline-start: 4px solid var(--ad-primary);
  background: var(--ad-surface);
  padding: var(--ad-space-5);
  margin-block: var(--ad-space-6);
  color: var(--ad-text-variant);
  font-style: italic;
  font-size: var(--ad-fs-body-lg);
  line-height: var(--ad-lh-body);
  border-radius: 0 var(--ad-radius-base) var(--ad-radius-base) 0;
}
.article-body blockquote p:last-child { margin-block-end: 0; }
.article-body blockquote cite {
  display: block;
  font-style: normal;
  font-size: var(--ad-fs-meta);
  color: var(--ad-text-muted);
  margin-block-start: var(--ad-space-2);
}
.article-body blockquote cite::before { content: "— "; }

/* Drop cap (desktop only) */
@media (min-width: 992px) {
  .article-body > p:first-of-type::first-letter {
    font-family: var(--ad-font-display);
    font-size: 2.4em;
    font-weight: var(--ad-fw-extra);
    line-height: 1;
    float: inline-start;
    margin-inline-end: var(--ad-space-2);
    margin-block-start: 0.05em;
    color: var(--ad-primary);
  }
}

/* Figures + images */
.article-body figure,
.article-body .wp-block-image {
  margin-block: var(--ad-space-6);
  max-inline-size: 100%;
}
.article-body figure.alignwide,
.article-body figure.alignfull,
.article-body .wp-block-image.alignwide,
.article-body .wp-block-image.alignfull {
  /* تخرج عن 65ch container */
  max-inline-size: min(900px, calc(100vw - 32px));
  margin-inline-start: 50%;
  transform: translateX(50%);
}
[dir="rtl"] .article-body figure.alignwide,
[dir="rtl"] .article-body figure.alignfull,
[dir="rtl"] .article-body .wp-block-image.alignwide,
[dir="rtl"] .article-body .wp-block-image.alignfull {
  transform: translateX(-50%);
}
.article-body figcaption,
.article-body .wp-caption-text {
  margin-block-start: var(--ad-space-2);
  font-size: var(--ad-fs-meta);
  color: var(--ad-text-muted);
  text-align: center;
  line-height: var(--ad-lh-tight);
}
.article-body img,
.article-body .wp-block-image img {
  max-inline-size: 100%;
  block-size: auto;
  border-radius: var(--ad-radius-base);
  background: var(--ad-surface-high);
}

/* HR */
.article-body hr {
  border: 0;
  block-size: 1px;
  background: var(--ad-outline);
  margin-block: var(--ad-space-7);
}

/* Code + pre */
.article-body code {
  background: var(--ad-surface-high);
  color: var(--ad-primary);
  padding: 2px 6px;
  border-radius: var(--ad-radius-base);
  font-family: var(--ad-font-mono);
  font-size: 0.9em;
}
.article-body pre {
  background: var(--ad-bg-alt);
  border: 1px solid var(--ad-outline);
  padding: var(--ad-space-4);
  border-radius: var(--ad-radius-md);
  overflow-x: auto;
  margin-block: var(--ad-space-5);
  font-family: var(--ad-font-mono);
  font-size: var(--ad-fs-meta);
  line-height: 1.6;
}
.article-body pre code {
  background: none;
  padding: 0;
  color: var(--ad-text);
}

/* Tables */
.article-body table {
  inline-size: 100%;
  border-collapse: collapse;
  margin-block: var(--ad-space-5);
  font-size: var(--ad-fs-body);
}
.article-body th,
.article-body td {
  padding: var(--ad-space-3);
  border: 1px solid var(--ad-outline);
  text-align: start;
}
.article-body thead {
  background: var(--ad-surface);
}


/* ============================================================
 *  ④ ARTICLE BYLINE (author card)
 * ============================================================ */
.article-byline {
  display: grid;
  grid-template-columns: 60px 1fr auto;
  align-items: center;
  gap: var(--ad-space-4);
  padding: var(--ad-space-4);
  background: var(--ad-surface);
  border: var(--ad-border);
  border-radius: var(--ad-radius-md);
  margin-block: var(--ad-space-6);
  max-inline-size: 65ch;
  margin-inline: auto;
  container-type: inline-size;
  container-name: byline;
}
.article-byline__avatar {
  inline-size: 60px;
  block-size: 60px;
  border-radius: 50%;
  border: 2px solid var(--ad-primary);
  object-fit: cover;
  background: var(--ad-surface-high);
}
.article-byline__info {
  min-inline-size: 0;
}
.article-byline__name {
  font-size: var(--ad-fs-body);
  font-weight: var(--ad-fw-bold);
  color: var(--ad-text);
  margin: 0 0 2px;
}
.article-byline__name a {
  color: inherit;
  text-decoration: none;
}
.article-byline__name a:hover { color: var(--ad-primary); }
.article-byline__meta {
  font-size: var(--ad-fs-meta);
  color: var(--ad-text-muted);
  margin: 0;
}
.article-byline__bio {
  font-size: var(--ad-fs-meta);
  color: var(--ad-text-variant);
  margin: var(--ad-space-1) 0 0;
  line-height: var(--ad-lh-tight);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.article-byline__follow {
  padding: var(--ad-space-2) var(--ad-space-4);
  background: transparent;
  color: var(--ad-primary);
  border: 1px solid var(--ad-primary);
  border-radius: var(--ad-radius-base);
  font-size: var(--ad-fs-meta);
  font-weight: var(--ad-fw-semibold);
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
  transition: all var(--ad-dur-base);
}
.article-byline__follow:hover {
  background: var(--ad-primary);
  color: var(--ad-on-primary);
}

/* Mobile: stacked */
@container byline (max-width: 480px) {
  .article-byline {
    grid-template-columns: 48px 1fr;
    gap: var(--ad-space-3);
    padding: var(--ad-space-3);
  }
  .article-byline__avatar {
    inline-size: 48px;
    block-size: 48px;
  }
  .article-byline__follow {
    grid-column: 1 / -1;
    inline-size: 100%;
    text-align: center;
  }
  .article-byline__bio { display: none; }
}


/* ============================================================
 *  ⑤ TAGS + SHARE FOOTER
 * ============================================================ */
.article-tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--ad-space-2);
  padding-block: var(--ad-space-5);
  border-block: 1px solid var(--ad-outline);
  margin-block: var(--ad-space-6);
  max-inline-size: 65ch;
  margin-inline: auto;
}
.article-tags__label {
  color: var(--ad-text-muted);
  font-size: var(--ad-fs-meta);
  margin-inline-end: var(--ad-space-2);
}
.article-tag {
  display: inline-block;
  padding: var(--ad-space-1) var(--ad-space-3);
  background: var(--ad-surface);
  border: 1px solid var(--ad-outline);
  color: var(--ad-text-variant);
  font-size: var(--ad-fs-meta);
  text-decoration: none;
  border-radius: var(--ad-radius-pill);
  transition: all var(--ad-dur-base);
}
.article-tag:hover {
  border-color: var(--ad-primary);
  color: var(--ad-primary);
}


/* ============================================================
 *  ⑥ RELATED (uses .hp-cat__list-link from homepage.css)
 * ============================================================ */
.article-related {
  margin-block-start: var(--ad-space-8);
  padding-block-start: var(--ad-space-6);
  border-block-start: 1px solid var(--ad-outline);
  max-inline-size: var(--ad-container);
  margin-inline: auto;
  padding-inline: var(--ad-container-px);
}
.article-related__header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-block-end: var(--ad-space-5);
  padding-block-end: var(--ad-space-3);
  border-block-end: 1px solid var(--ad-outline);
}
.article-related__title {
  font-size: var(--ad-fs-h2);
  font-weight: var(--ad-fw-bold);
  color: var(--ad-text);
  margin: 0;
}
/* Note: .hp-cat__list (homepage.css) used as items list */
/* Backward-compat: قواعد .article-related__grid القديمة */
.article-related__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--ad-space-4);
}
@media (min-width: 768px) {
  .article-related__grid {
    grid-template-columns: repeat(auto-fill, minmax(min(280px, 100%), 1fr));
  }
}


/* ============================================================
 *  ⑦ NEWSLETTER CTA (in-article)
 * ============================================================ */
.article-cta-newsletter {
  background: linear-gradient(
    135deg,
    var(--ad-surface) 0%,
    var(--ad-bg-alt) 100%
  );
  border: 1px solid var(--ad-primary);
  padding: var(--ad-space-6);
  margin-block: var(--ad-space-7);
  border-radius: var(--ad-radius-md);
  text-align: center;
  max-inline-size: 65ch;
  margin-inline: auto;
}
.article-cta-newsletter__title {
  font-size: var(--ad-fs-h3);
  font-weight: var(--ad-fw-bold);
  color: var(--ad-text);
  margin: 0 0 var(--ad-space-2);
}
.article-cta-newsletter__subtitle {
  color: var(--ad-text-variant);
  margin: 0 0 var(--ad-space-4);
}
.article-cta-newsletter__form {
  display: flex;
  gap: var(--ad-space-2);
}
.article-cta-newsletter__input {
  flex: 1;
  padding: var(--ad-space-3) var(--ad-space-4);
  background: var(--ad-bg);
  border: 1px solid var(--ad-outline);
  color: var(--ad-text);
  font-family: var(--ad-font-body);
  border-radius: var(--ad-radius-base);
  min-inline-size: 0;
}
.article-cta-newsletter__input:focus {
  outline: none;
  border-color: var(--ad-primary);
  box-shadow: 0 0 0 3px var(--ad-glow);
}
.article-cta-newsletter__submit {
  padding: var(--ad-space-3) var(--ad-space-5);
  background: var(--ad-primary);
  color: var(--ad-on-primary);
  border: none;
  font-weight: var(--ad-fw-bold);
  border-radius: var(--ad-radius-base);
  cursor: pointer;
  white-space: nowrap;
}
@media (max-width: 480px) {
  .article-cta-newsletter__form { flex-direction: column; }
}


/* ============================================================
 *  ⑧ COMMENTS WRAPPER
 * ============================================================ */
.article-comments {
  margin-block-start: var(--ad-space-8);
  padding-block-start: var(--ad-space-6);
  border-block-start: 1px solid var(--ad-outline);
  max-inline-size: 65ch;
  margin-inline: auto;
  padding-inline: var(--ad-container-px);
}


/* ============================================================
 *  ⑨ MOBILE TWEAKS
 * ============================================================ */
@media (max-width: 767.98px) {
  .article-header {
    margin-block-end: var(--ad-space-5);
  }
  .article-header__hero {
    aspect-ratio: 16 / 10;
  }
  .article-header__inner {
    padding-block: var(--ad-space-4) var(--ad-space-3);
  }
  .article-header__title {
    font-size: var(--ad-fs-h2);
    line-height: var(--ad-lh-heading);
  }
  .article-header__lead {
    font-size: var(--ad-fs-body);
  }
  .article-body {
    font-size: var(--ad-fs-body);
    line-height: 1.7;
  }
  .article-body h2 {
    font-size: var(--ad-fs-h3);
    margin-block: var(--ad-space-6) var(--ad-space-2);
  }
  .article-body h3 {
    font-size: var(--ad-fs-h4);
  }
  /* drop-cap — مُعطَّل في overrides.css على الجوال */
}


} /* end @layer components */
