/*
 * article.css — article detail (single.php)
 *
 * Phase 7 rewrite. Typography-tuned for Arabic reading (line-height
 * ~1.85). Wrapper maxes at 760px; .alignwide breaks out to 900px.
 * Related grid reuses blog.css primitives — blog.css is enqueued on
 * singular posts via inc/enqueue.php.
 */

/* -- Layout ------------------------------------------------------- */

.bushraa-article__wrapper {
  max-width: 760px;
  margin-inline: auto;
  padding-inline: var(--bushraa-gap-4);
}

/* -- Breadcrumb (Rank Math-driven) -------------------------------- */

.bushraa-article__breadcrumb {
  max-width: 760px;
  margin: 0 auto var(--bushraa-gap-4);
  padding-inline: var(--bushraa-gap-4);
  font-size: 13px;
  color: var(--bushraa-text-muted);
  line-height: 1.6;
}

.bushraa-article__breadcrumb a {
  color: var(--bushraa-text-muted);
  text-decoration-color: rgba(79, 79, 79, 0.4);
  text-decoration-thickness: 1px;
  text-underline-offset: 0.16em;
}

.bushraa-article__breadcrumb a:hover,
.bushraa-article__breadcrumb a:focus-visible {
  color: var(--bushraa-brand-primary);
  text-decoration-color: currentColor;
  text-decoration-thickness: 2px;
}

/* -- Hero --------------------------------------------------------- */

.bushraa-article__hero {
  margin-block-end: var(--bushraa-gap-6);
}

.bushraa-article__category {
  display: inline-flex;
  margin-block-end: var(--bushraa-gap-3);
}

.bushraa-article__title {
  margin: 0;
  font-size: 24px;
  font-weight: 700;
  line-height: 1.3;
  color: var(--bushraa-text-strong);
}

@media (min-width: 720px) {
  .bushraa-article__title {
    font-size: 28px;
  }
}

.bushraa-article__deck {
  margin: var(--bushraa-gap-3) 0 0;
  font-size: 18px;
  font-weight: 500;
  line-height: 1.6;
  color: var(--bushraa-text-muted);
}

.bushraa-article__meta {
  margin-block-start: var(--bushraa-gap-3);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--bushraa-gap-2);
  font-size: 14px;
  line-height: 1.4;
  color: var(--bushraa-text-muted);
}

.bushraa-article__meta > * + * {
  padding-inline-start: var(--bushraa-gap-2);
  border-inline-start: 1px solid var(--bushraa-border-subtle);
}

.bushraa-article__featured {
  margin: var(--bushraa-gap-6) 0 0;
  border-radius: var(--bushraa-radius-lg);
  overflow: hidden;
  background-color: var(--bushraa-surface-muted);
}

.bushraa-article__featured img {
  width: 100%;
  height: auto;
  display: block;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}

/* -- Body typography --------------------------------------------- */

.bushraa-article__body {
  font-size: 16px;
  line-height: 1.85;
  color: var(--bushraa-text-default);
  /* Long Arabic/English URL tokens inside article body would otherwise
   * push parent width past the viewport on narrow screens. */
  overflow-wrap: anywhere;
  word-break: break-word;
}

.bushraa-article__body > * {
  max-width: 100%;
}

/* Legacy Elementor widget wrappers still embedded in ~10 posts may carry
 * fixed pixel widths. Constrain them so they never exceed the article
 * wrapper and never push mobile width. */
.bushraa-article__body [class*="elementor-widget-"],
.bushraa-article__body [class*="elementor-widget-"] * {
  max-width: 100%;
}

.bushraa-article__body p {
  margin-block: var(--bushraa-gap-4);
}

.bushraa-article__body h2,
.bushraa-article__body h3,
.bushraa-article__body h4 {
  color: var(--bushraa-text-strong);
  font-weight: 700;
  line-height: 1.35;
}

.bushraa-article__body h2 {
  font-size: 22px;
  margin-block: var(--bushraa-gap-8) var(--bushraa-gap-3);
}

.bushraa-article__body h3 {
  font-size: 18px;
  margin-block: var(--bushraa-gap-6) var(--bushraa-gap-3);
}

.bushraa-article__body h4 {
  font-size: 16px;
  margin-block: var(--bushraa-gap-5) var(--bushraa-gap-2);
}

.bushraa-article__body ul,
.bushraa-article__body ol {
  margin-block: var(--bushraa-gap-4);
  padding-inline-start: var(--bushraa-gap-8);
}

.bushraa-article__body li {
  margin-block: var(--bushraa-gap-2);
}

.bushraa-article__body li::marker {
  color: var(--bushraa-text-muted);
}

.bushraa-article__body blockquote {
  margin: var(--bushraa-gap-6) 0;
  padding: var(--bushraa-gap-4) var(--bushraa-gap-5);
  border-inline-start: 4px solid var(--bushraa-brand-accent);
  background-color: var(--bushraa-surface-muted);
  border-radius: var(--bushraa-radius-md);
  color: var(--bushraa-text-strong);
  font-style: normal;
}

.bushraa-article__body blockquote p {
  margin-block: var(--bushraa-gap-2);
}

.bushraa-article__body a {
  color: var(--bushraa-brand-primary);
  text-decoration-color: rgba(2, 48, 71, 0.45);
  text-decoration-thickness: 1.5px;
  text-underline-offset: 0.2em;
  transition: color 160ms ease, text-decoration-color 160ms ease,
    text-decoration-thickness 160ms ease;
}

.bushraa-article__body a:hover,
.bushraa-article__body a:focus-visible {
  color: var(--bushraa-brand-primary-dark);
  text-decoration-color: currentColor;
  text-decoration-thickness: 2px;
}

.bushraa-article__body a:visited {
  color: var(--bushraa-brand-primary);
}

/* Images, figures, captions */
.bushraa-article__body img,
.bushraa-article__body figure.wp-caption,
.bushraa-article__body .wp-block-image,
.bushraa-article__body .wp-block-image img {
  max-width: 100%;
  height: auto;
}

.bushraa-article__body figure,
.bushraa-article__body .wp-caption,
.bushraa-article__body .wp-block-image {
  margin: var(--bushraa-gap-6) auto;
}

.bushraa-article__body img {
  border-radius: var(--bushraa-radius-md);
  display: block;
}

.bushraa-article__body figcaption,
.bushraa-article__body .wp-caption-text,
.bushraa-article__body .wp-block-image figcaption {
  margin-block-start: var(--bushraa-gap-2);
  font-size: 14px;
  line-height: 1.5;
  color: var(--bushraa-text-muted);
  text-align: center;
}

/* Content width breakouts (Gutenberg + core theme support) */
.bushraa-article__body .alignwide {
  max-width: 900px;
  margin-inline: calc((760px - 900px) / 2);
}

.bushraa-article__body .alignfull {
  max-width: 100%;
  margin-inline: 0;
}

.bushraa-article__body .aligncenter {
  margin-inline: auto;
}

.bushraa-article__body .alignleft {
  float: inline-start;
  margin-inline-end: var(--bushraa-gap-4);
  margin-block-end: var(--bushraa-gap-3);
  max-width: 50%;
}

.bushraa-article__body .alignright {
  float: inline-end;
  margin-inline-start: var(--bushraa-gap-4);
  margin-block-end: var(--bushraa-gap-3);
  max-width: 50%;
}

/* Fallback for narrow viewports where .alignwide negative margins would overflow */
@media (max-width: 940px) {
  .bushraa-article__body .alignwide {
    max-width: 100%;
    margin-inline: 0;
  }
}

/* YouTube oEmbed responsive wrapper (WP core emits bare iframes) */
.bushraa-article__body iframe {
  max-width: 100%;
  display: block;
  margin: var(--bushraa-gap-6) auto;
  border-radius: var(--bushraa-radius-md);
}

.bushraa-article__body iframe[src*="youtube.com"],
.bushraa-article__body iframe[src*="youtu.be"],
.bushraa-article__body iframe[src*="youtube-nocookie.com"] {
  width: 100%;
  aspect-ratio: 16 / 9;
  height: auto;
}

/* YouTube click-to-load facade (Phase 11 Step 5). Rendered in place
 * of the raw iframe; swapped for the real iframe in site.js on click.
 * Same 16:9 aspect + radius as the live iframe above so the swap
 * produces zero layout shift. */
.bushraa-article__body .bushraa-youtube-facade {
  position: relative;
  display: block;
  max-width: 100%;
  width: 100%;
  aspect-ratio: 16 / 9;
  margin: var(--bushraa-gap-6) auto;
  border-radius: var(--bushraa-radius-md);
  overflow: hidden;
  background: #000;
}

.bushraa-youtube-facade__play {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  padding: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: filter 160ms ease;
}

.bushraa-youtube-facade__play:hover,
.bushraa-youtube-facade__play:focus-visible {
  filter: brightness(0.92);
}

.bushraa-youtube-facade__play:focus-visible {
  outline: 3px solid var(--bushraa-brand-accent, #9C7039);
  outline-offset: -3px;
}

.bushraa-youtube-facade__thumb {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.bushraa-youtube-facade__icon {
  position: relative;
  width: clamp(48px, 14%, 80px);
  height: auto;
  filter: drop-shadow(0 2px 6px rgba(0, 0, 0, 0.4));
  transition: transform 160ms ease;
}

.bushraa-youtube-facade__play:hover .bushraa-youtube-facade__icon,
.bushraa-youtube-facade__play:focus-visible .bushraa-youtube-facade__icon {
  transform: scale(1.06);
}

.bushraa-youtube-facade iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  margin: 0;
  border-radius: 0;
}

/* Tables (rare but possible) — scroll horizontally on overflow. The
 * `display: block` override lets `overflow-x: auto` engage; visible
 * borders still come through because <thead>/<tbody> stay inline-table.
 */
.bushraa-article__body table {
  display: block;
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  border-collapse: collapse;
  margin-block: var(--bushraa-gap-6);
  font-size: 15px;
}

.bushraa-article__body table th,
.bushraa-article__body table td {
  padding: var(--bushraa-gap-2) var(--bushraa-gap-3);
  border: 1px solid var(--bushraa-border-subtle);
  text-align: inherit;
}

.bushraa-article__body table th {
  background-color: var(--bushraa-surface-muted);
  font-weight: 700;
  color: var(--bushraa-text-strong);
}

/* Pre / code */
.bushraa-article__body pre,
.bushraa-article__body code {
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 14px;
}

.bushraa-article__body code {
  padding: 2px 6px;
  background-color: var(--bushraa-surface-muted);
  border-radius: var(--bushraa-radius-sm);
}

.bushraa-article__body pre {
  padding: var(--bushraa-gap-4);
  background-color: var(--bushraa-surface-muted);
  border-radius: var(--bushraa-radius-md);
  overflow-x: auto;
  line-height: 1.5;
}

.bushraa-article__body pre code {
  padding: 0;
  background-color: transparent;
}

/* Multi-page post navigation (wp_link_pages) */
.bushraa-article__pages {
  margin-block-start: var(--bushraa-gap-6);
  display: flex;
  flex-wrap: wrap;
  gap: var(--bushraa-gap-2);
  font-size: 14px;
  color: var(--bushraa-text-muted);
}

.bushraa-article__pages a,
.bushraa-article__pages > span {
  padding: 4px 10px;
  border: 1px solid var(--bushraa-border-subtle);
  border-radius: var(--bushraa-radius-sm);
  text-decoration: none;
}

/* -- Inline CTA card --------------------------------------------- */

.bushraa-article__cta {
  margin-block: var(--bushraa-gap-10) 0;
  padding: 22px;
  border: 1px solid rgba(2, 48, 71, 0.14);
  border-radius: 22px;
  background:
    radial-gradient(circle at 88% 12%, rgba(156, 112, 57, 0.16), transparent 30%),
    linear-gradient(135deg, rgba(2, 48, 71, 0.08), rgba(247, 248, 249, 0.96));
  box-shadow: 0 18px 48px rgba(2, 48, 71, 0.08);
  display: grid;
  gap: var(--bushraa-gap-4);
  align-items: center;
}
@media (min-width: 720px) {
  .bushraa-article__cta {
    grid-template-columns: minmax(0, 1fr) auto;
    padding: 26px 28px;
  }
}

.bushraa-article__cta__content {
  display: grid;
  gap: var(--bushraa-gap-2);
}

.bushraa-article__cta__eyebrow {
  margin: 0;
  width: fit-content;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(156, 112, 57, 0.12);
  color: var(--bushraa-brand-accent);
  font-size: 12px;
  font-weight: 700;
  line-height: 1.4;
}

.bushraa-article__cta__title {
  margin: 0;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.45;
  color: var(--bushraa-brand-primary);
}

.bushraa-article__cta__text {
  margin: 0;
  font-size: 15px;
  line-height: 1.85;
  color: var(--bushraa-text-default);
}

.bushraa-article__cta__chips {
  display: flex;
  flex-wrap: wrap;
  gap: var(--bushraa-gap-2);
  margin: var(--bushraa-gap-2) 0 0;
  padding: 0;
  list-style: none;
}

.bushraa-article__cta__chips li {
  margin: 0;
  padding: 6px 10px;
  border: 1px solid rgba(2, 48, 71, 0.12);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  color: var(--bushraa-brand-primary);
  font-size: 12px;
  font-weight: 700;
  line-height: 1.3;
}

.bushraa-article__cta__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--bushraa-gap-2);
  min-height: 48px;
  padding: 13px 22px;
  border-radius: 14px;
  background: var(--bushraa-brand-primary);
  color: #ffffff;
  font-size: 15px;
  font-weight: 700;
  line-height: 1.3;
  text-decoration: none;
  text-align: center;
  box-shadow: 0 14px 30px rgba(2, 48, 71, 0.18);
  transition: background-color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
}
.bushraa-article__cta__button:hover,
.bushraa-article__cta__button:focus-visible {
  background: var(--bushraa-brand-primary-dark);
  color: #ffffff;
  text-decoration: none;
  transform: translateY(-1px);
  box-shadow: 0 18px 36px rgba(2, 48, 71, 0.22);
}

.bushraa-article__cta__button-icon {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

/* -- Related grid ------------------------------------------------- */

.bushraa-article__related {
  margin-block-start: var(--bushraa-gap-10);
  padding-block-start: var(--bushraa-gap-8);
  border-block-start: 1px solid var(--bushraa-border-subtle);
}

.bushraa-article__related-title {
  margin: 0 0 var(--bushraa-gap-6);
  font-size: 22px;
  font-weight: 700;
  line-height: 1.3;
  color: var(--bushraa-text-strong);
}
