/* Shared article styles — used by all polished blog articles in /blog/ */

/* Hero cover image (full-width, sits above the .ar-hero text block) */
.ar-cover { background: var(--cream); padding-block-start: var(--nav-h); }
.ar-cover-inner { max-width: 1180px; margin: 0 auto; padding-inline: var(--gutter); }
.ar-cover img { display: block; width: 100%; height: auto; aspect-ratio: 16/9; object-fit: cover; border-radius: 0; }
@media (min-width: 769px) {
  .ar-cover { padding-block-start: calc(var(--nav-h) + 24px); }
  .ar-cover img { border-radius: 14px; max-height: 560px; }
}

/* When .ar-cover precedes .ar-hero, reduce the hero's top padding (image already fills the space) */
.ar-cover + .ar-hero { padding-block-start: clamp(28px, 4vw, 48px); }

.ar-hero { background: var(--cream); padding-block: calc(var(--nav-h) + clamp(40px, 5vw, 64px)) clamp(28px, 4vw, 44px); }
.ar-hero-inner { max-width: 720px; margin: 0 auto; }
.ar-breadcrumb { display: flex; gap: 6px; align-items: center; font-size: 12px; color: var(--text-soft); margin-block-end: 18px; flex-wrap: wrap; }
.ar-breadcrumb a { color: var(--text-soft); text-decoration: none; }
.ar-breadcrumb a:hover { color: var(--olive-dark); }
.ar-breadcrumb svg { width: 10px; height: 10px; opacity: 0.5; }
.ar-category-pill { display: inline-block; background: var(--olive-dark); color: var(--white); font-size: 11px; font-weight: 600; padding: 4px 12px; border-radius: 999px; letter-spacing: 0.04em; margin-block-end: 14px; }
.ar-hero h1 { font-size: clamp(28px, 4.2vw, 44px); font-weight: 600; line-height: 1.2; letter-spacing: -0.02em; margin-block-end: 18px; }
.ar-lede { font-size: clamp(16px, 1.5vw, 19px); line-height: 1.75; color: var(--text-soft); margin-block-end: 24px; }
.ar-byline { display: flex; gap: 20px; flex-wrap: wrap; padding-block: 18px; border-block: 1px solid var(--border); font-size: 13px; color: var(--text-soft); }
.ar-byline-item { display: inline-flex; align-items: center; gap: 8px; }
.ar-byline svg { width: 16px; height: 16px; color: var(--olive-dark); }
.ar-byline strong { color: var(--text); font-weight: 600; }

.ar-body { background: var(--white); padding-block: clamp(40px, 5vw, 72px); }
.ar-layout { max-width: 1180px; margin: 0 auto; display: grid; grid-template-columns: 1fr; gap: clamp(28px, 4vw, 48px); padding-inline: var(--gutter); }
@media (min-width: 1024px) { .ar-layout { grid-template-columns: 240px 1fr; } }

.ar-toc { font-size: 13.5px; }
.ar-toc-title { font-size: 12px; font-weight: 600; color: var(--text); text-transform: uppercase; letter-spacing: 0.06em; margin-block-end: 12px; padding-block-end: 8px; border-block-end: 1px solid var(--border); }
.ar-toc ol { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 2px; counter-reset: toc; }
.ar-toc li { counter-increment: toc; }
.ar-toc a { display: block; padding: 8px 12px; color: var(--text-soft); text-decoration: none; border-radius: 8px; line-height: 1.5; transition: background 160ms var(--ease-out-quart), color 160ms var(--ease-out-quart); position: relative; padding-inline-start: 32px; }
.ar-toc a::before { content: counter(toc, arabic-indic); position: absolute; inset-inline-start: 12px; top: 8px; color: var(--olive-dark); font-weight: 600; font-feature-settings: "tnum"; }
.ar-toc a:hover { background: var(--bg-section); color: var(--olive-dark); }
@media (min-width: 1024px) { .ar-toc { position: sticky; top: calc(var(--nav-h) + 24px); align-self: start; max-height: calc(100vh - var(--nav-h) - 48px); overflow-y: auto; } }

.ar-content { max-width: 680px; }
.ar-content > p { font-size: 16px; line-height: 1.95; color: var(--text); margin-block-end: 18px; }
/* Quiet Luxury · h2 uses olive-darker color directly · no side-stripe chrome (D-023 · 2026-05-20) */
.ar-content h2 { font-size: clamp(22px, 2.6vw, 28px); font-weight: 600; line-height: 1.3; margin-block: 44px 14px; color: var(--olive-darker); scroll-margin-top: calc(var(--nav-h) + 20px); }
.ar-content h2:first-of-type { margin-block-start: 0; }
.ar-content h3 { font-size: 18px; font-weight: 600; margin-block: 24px 10px; color: var(--text); }
.ar-content ul, .ar-content ol { padding-inline-start: 24px; margin-block-end: 18px; }
.ar-content li { font-size: 15.5px; line-height: 1.9; color: var(--text); margin-block-end: 8px; }
.ar-content strong { color: var(--text); font-weight: 600; }
.ar-content a { color: var(--olive-dark); font-weight: 600; text-decoration: none; border-block-end: 1px solid var(--olive); }
.ar-content a:hover { background: var(--olive-tint); }
.ar-content sup a { font-size: 11px; padding: 0 4px; background: var(--olive-tint); color: var(--olive-dark); border-radius: 4px; border-block-end: none; font-weight: 600; }
.ar-content sup a:hover { background: var(--olive); color: var(--white); }

.ar-callout { background: var(--bg-soft); border-block-start: 3px solid var(--olive); border-radius: 12px; padding: 22px 24px; margin-block: 24px; }
.ar-callout h4 { font-size: 13px; font-weight: 600; color: var(--olive-dark); text-transform: uppercase; letter-spacing: 0.06em; margin-block-end: 10px; }
.ar-callout p { font-size: 14.5px; margin: 0; line-height: 1.8; color: var(--text); }
.ar-callout.warn { background: #FFF8E7; border-block-start-color: var(--warning); }
.ar-callout.warn h4 { color: #8A6018; }
.ar-callout.saudi { background: var(--olive-tint); border-block-start: 3px solid var(--olive-dark); }
.ar-callout.saudi h4 { color: var(--olive-dark); }

.ar-pullquote { border-inline-start: none; background: var(--cream); border-radius: 14px; padding: 28px 32px; margin-block: 32px; font-size: clamp(18px, 2vw, 22px); line-height: 1.55; font-weight: 500; color: var(--text); position: relative; }
.ar-pullquote::before { content: '"'; position: absolute; top: -8px; inset-inline-end: 18px; font-size: 64px; line-height: 1; color: var(--olive); opacity: 0.4; font-family: serif; }

.ar-data-table { margin-block: 28px; overflow-x: auto; }
.ar-data-table table { width: 100%; border-collapse: collapse; background: var(--white); border: 1px solid var(--border); border-radius: 12px; overflow: hidden; font-size: 14px; font-feature-settings: "tnum"; }
.ar-data-table th, .ar-data-table td { padding: 12px 14px; text-align: start; border-block-end: 1px solid var(--border); }
.ar-data-table th { background: var(--bg-soft); font-weight: 600; color: var(--text); font-size: 13px; }
.ar-data-table tr:last-child td { border-block-end: none; }
.ar-data-table caption { font-size: 12px; color: var(--text-soft); margin-block-end: 8px; text-align: start; caption-side: top; }

.ar-cta-box { background: var(--olive-dark); color: var(--white); border-radius: 20px; padding: clamp(28px, 4vw, 40px); margin-block: 40px; text-align: center; }
.ar-cta-box h3 { font-size: clamp(20px, 2.4vw, 26px); font-weight: 600; color: var(--white); margin-block-end: 10px; line-height: 1.3; padding: 0; }
.ar-cta-box h3::before { display: none; }
.ar-cta-box p { font-size: 15px; line-height: 1.7; color: rgba(255,255,255,0.85); margin-block-end: 20px; max-width: 480px; margin-inline: auto; }
.ar-cta-actions { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; }
.ar-cta-box .btn-white { background: var(--white); color: var(--olive-dark); }
.ar-cta-box .btn-ghost-w { background: transparent; color: var(--white); border: 1.5px solid rgba(255,255,255,0.6); display: inline-flex; align-items: center; gap: 8px; padding: 12px 20px; border-radius: 12px; font: inherit; font-size: 14px; font-weight: 600; text-decoration: none; }
.ar-cta-box .btn-ghost-w:hover { background: rgba(255,255,255,0.1); border-color: var(--white); }

.ar-refs { background: var(--bg-section); padding-block: clamp(40px, 5vw, 56px); }
.ar-refs-inner { max-width: 720px; margin: 0 auto; padding-inline: var(--gutter); }
.ar-refs h2 { font-size: clamp(20px, 2.4vw, 24px); font-weight: 600; margin-block-end: 16px; padding-block-end: 12px; border-block-end: 1px solid var(--border); }
.ar-refs ol { padding-inline-start: 24px; counter-reset: ref; list-style: none; }
.ar-refs li { font-size: 13.5px; line-height: 1.7; color: var(--text); margin-block-end: 12px; counter-increment: ref; position: relative; padding-inline-start: 32px; }
.ar-refs li::before { content: '[' counter(ref) ']'; position: absolute; inset-inline-start: 0; color: var(--olive-dark); font-weight: 600; font-feature-settings: "tnum"; font-family: var(--font-en); }
.ar-refs a { color: var(--olive-dark); font-weight: 500; text-decoration: none; word-break: break-all; }
.ar-refs a:hover { text-decoration: underline; }

.ar-author { background: var(--white); padding-block: clamp(40px, 5vw, 56px); }
.ar-author-card { max-width: 720px; margin: 0 auto; padding: 24px 28px; background: var(--cream); border: 1px solid var(--border); border-radius: 16px; display: flex; gap: 18px; align-items: start; flex-wrap: wrap; }
.ar-author-avatar { width: 56px; height: 56px; background: var(--olive-dark); color: var(--white); border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; font-weight: 600; font-size: 18px; flex-shrink: 0; }
.ar-author-body { flex: 1; min-width: 240px; }
.ar-author-name { font-size: 15px; font-weight: 600; color: var(--text); }
.ar-author-role { font-size: 13px; color: var(--text-soft); margin-block: 2px 10px; }
.ar-author-bio { font-size: 13.5px; line-height: 1.7; color: var(--text-soft); }

/* === G2 · "ما ستعرفه" Summary Box (top of article) ============================== */
.ar-summary { background: var(--olive-tint); border-radius: 14px; padding: 22px 26px; margin-block: 28px; border-inline-start: 3px solid var(--olive-dark); }
.ar-summary-label { font-size: 11px; font-weight: 600; color: var(--olive-dark); letter-spacing: 0.08em; text-transform: uppercase; margin-block-end: 10px; }
.ar-summary ul { list-style: none; padding: 0; margin: 0; }
.ar-summary li { font-size: 14.5px; line-height: 1.75; color: var(--text); padding-inline-start: 22px; position: relative; margin-block-end: 8px; }
.ar-summary li:last-child { margin-block-end: 0; }
.ar-summary li::before { content: ""; position: absolute; inset-inline-start: 4px; top: 11px; width: 6px; height: 6px; background: var(--olive-dark); border-radius: 50%; }

/* === G3 · "الخلاصة" Key Takeaways Box (end of article) =========================== */
.ar-takeaways { background: var(--cream); border: 1px solid var(--border); border-radius: 16px; padding: 26px 28px; margin-block: 32px; }
.ar-takeaways-label { font-size: 11px; font-weight: 600; color: var(--olive-darker); letter-spacing: 0.08em; text-transform: uppercase; margin-block-end: 8px; }
.ar-takeaways h3 { font-size: 19px; font-weight: 600; color: var(--text); margin-block-end: 16px; line-height: 1.3; }
.ar-takeaways ul { list-style: none; padding: 0; margin: 0; counter-reset: tk; }
.ar-takeaways li { counter-increment: tk; font-size: 14.5px; line-height: 1.8; color: var(--text); padding-inline-start: 38px; position: relative; margin-block-end: 10px; }
.ar-takeaways li:last-child { margin-block-end: 0; }
.ar-takeaways li::before { content: counter(tk, arabic-indic); position: absolute; inset-inline-start: 0; top: 0; width: 26px; height: 26px; background: var(--olive-dark); color: var(--white); border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 600; font-feature-settings: "tnum"; }

/* === G1 · Enhanced Author Card with photo + credentials ========================== */
.ar-author-card.enhanced { padding: 28px 32px; gap: 22px; }
.ar-author-photo { width: 96px; height: 96px; border-radius: 50%; overflow: hidden; flex-shrink: 0; background: var(--bg-section); border: 2px solid var(--olive-tint); }
.ar-author-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.ar-author-credentials { display: flex; flex-wrap: wrap; gap: 8px; margin-block: 8px 12px; }
.ar-author-cred { display: inline-flex; align-items: center; gap: 5px; font-size: 11px; padding: 3px 9px; background: var(--white); border: 1px solid var(--border); border-radius: 999px; color: var(--text-soft); font-feature-settings: "tnum"; }
.ar-author-cred svg { width: 11px; height: 11px; color: var(--olive-dark); }
.ar-author-cred strong { color: var(--text); font-weight: 600; }

/* === G5 · "هل أفادك هذا المقال؟" Feedback Widget ================================== */
.ar-feedback { background: var(--bg-soft); border: 1px solid var(--border); border-radius: 14px; padding: 22px 26px; margin-block: 32px; text-align: center; }
.ar-feedback-q { font-size: 14.5px; font-weight: 600; color: var(--text); margin-block-end: 14px; }
.ar-feedback-btns { display: inline-flex; gap: 10px; }
.ar-feedback-btn { background: var(--white); border: 1px solid var(--border); padding: 10px 22px; border-radius: 999px; font: inherit; font-size: 13.5px; cursor: pointer; display: inline-flex; align-items: center; gap: 8px; color: var(--text); transition: border-color 160ms, background 160ms, color 160ms; }
.ar-feedback-btn:hover { border-color: var(--olive); background: var(--olive-tint); color: var(--olive-darker); }
.ar-feedback-btn svg { width: 16px; height: 16px; }
.ar-feedback-btn.active { background: var(--olive-dark); border-color: var(--olive-dark); color: var(--white); }
.ar-feedback-thanks { font-size: 13.5px; color: var(--olive-dark); margin-block-start: 10px; display: none; }
.ar-feedback-thanks.show { display: block; }

/* === G6 · Print Button + Print Stylesheet ======================================== */
.ar-tools { display: flex; gap: 10px; margin-block: 18px 0; flex-wrap: wrap; }
.ar-tool-btn { background: transparent; border: 1px solid var(--border); padding: 8px 16px; border-radius: 999px; font: inherit; font-size: 12.5px; color: var(--text-soft); cursor: pointer; display: inline-flex; align-items: center; gap: 6px; transition: border-color 160ms, color 160ms; }
.ar-tool-btn:hover { border-color: var(--olive); color: var(--olive-dark); }
.ar-tool-btn svg { width: 14px; height: 14px; }

@media print {
  .nav, .footer, .olive-close, .nav-cta, .skip-link,
  .ar-toc, .ar-feedback, .ar-tools, .ar-cta-box, .ar-related,
  .vd-check-actions, .vd-scale-input button, .vd-faq-icon,
  .bl-card-link { display: none !important; }
  body { background: white !important; color: black !important; font-size: 11pt; }
  .ar-cover img { max-height: 280px !important; }
  .ar-hero, .ar-body, .ar-refs, .ar-author { padding-block: 16pt !important; background: white !important; }
  .ar-content > p, .ar-content li { font-size: 11pt !important; line-height: 1.7 !important; }
  .ar-content h2 { page-break-after: avoid; font-size: 16pt !important; margin-block: 20pt 8pt !important; }
  .ar-content h3 { page-break-after: avoid; font-size: 13pt !important; }
  .ar-data-table, .vd-myth, .ar-callout, .ar-summary, .ar-takeaways { page-break-inside: avoid; }
  a { color: black !important; text-decoration: underline !important; }
  .ar-content sup a { background: none !important; padding: 0 !important; }
  .ar-refs a::after { content: " (" attr(href) ")"; font-size: 9pt; color: #555; }
  .vd-faq-a { max-height: none !important; }
}

.ar-related { background: var(--bg-section); padding-block: clamp(40px, 5vw, 56px); }
.ar-related-inner { max-width: 1180px; margin: 0 auto; padding-inline: var(--gutter); }
.ar-related h2 { font-size: clamp(20px, 2.4vw, 26px); font-weight: 600; margin-block-end: 20px; text-align: center; }
.ar-related-grid { display: grid; grid-template-columns: 1fr; gap: 16px; }
@media (min-width: 640px) { .ar-related-grid { grid-template-columns: 1fr 1fr 1fr; } }
.ar-related-card { background: var(--white); border: 1px solid var(--border); border-radius: 14px; padding: 20px; text-decoration: none; color: var(--text); display: flex; flex-direction: column; transition: transform 200ms var(--ease-out-quart), box-shadow 200ms var(--ease-out-quart), border-color 200ms var(--ease-out-quart); }
.ar-related-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); border-color: var(--olive); }
.ar-related-card .cat { font-size: 10px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--olive-dark); margin-block-end: 8px; }
.ar-related-card h3 { font-size: 15px; font-weight: 600; line-height: 1.4; margin-block-end: 6px; }
.ar-related-card .read-time { font-size: 12px; color: var(--text-soft); margin-block-start: auto; padding-block-start: 12px; font-feature-settings: "tnum"; }
