/* =========================================================
   Madinah Noor — main stylesheet
   A modern, youthful theme inspired by Al-Madinah Al-Munawwarah
   ========================================================= */

/* ---------- Design tokens ---------- */
:root {
    /* Sacred green — inspired by the dome and walls of Al-Masjid An-Nabawi */
    --mn-green-900: #0a3d28;
    --mn-green-800: #0f5e3c;
    --mn-green-700: #157047;
    --mn-green-600: #1f8a5a;
    --mn-green-500: #2ea374;
    --mn-green-50:  #ecf6f1;

    /* Gold — calligraphy & ornament */
    --mn-gold-700: #9a7320;
    --mn-gold-600: #c8932e;
    --mn-gold-500: #e0b048;
    --mn-gold-300: #f3d784;
    --mn-gold-100: #fbecc5;

    /* Sand / cream / clay */
    --mn-sand-50:  #fbf7ef;
    --mn-sand-100: #f6efe0;
    --mn-sand-200: #ece1c8;
    --mn-clay-700: #6b4a2a;

    /* Neutrals */
    --mn-ink-900: #0e1a14;
    --mn-ink-700: #2b3a32;
    --mn-ink-500: #5b6b62;
    --mn-ink-300: #9caaa2;
    --mn-ink-100: #d6ddd8;
    --mn-paper:   #ffffff;

    /* Semantic */
    --bg:           var(--mn-sand-50);
    --bg-elevated:  var(--mn-paper);
    --bg-soft:      var(--mn-sand-100);
    --fg:           var(--mn-ink-900);
    --fg-muted:     var(--mn-ink-500);
    --fg-soft:      var(--mn-ink-700);
    --border:       rgba(15, 94, 60, 0.12);
    --border-strong:rgba(15, 94, 60, 0.22);
    --primary:      var(--mn-green-800);
    --primary-deep: var(--mn-green-900);
    --primary-soft: var(--mn-green-50);
    --accent:       var(--mn-gold-600);
    --accent-soft:  var(--mn-gold-100);

    /* Typography */
    --font-sans:    'Inter', 'Tajawal', system-ui, -apple-system, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
    --font-display: 'Reem Kufi', 'Tajawal', Georgia, serif;
    --font-arabic:  'Tajawal', 'Reem Kufi', system-ui, sans-serif;
    --font-quote:   'Amiri', 'Reem Kufi', Georgia, serif;

    /* Sizing */
    --container: 1180px;
    --container-narrow: 780px;
    --radius-sm: 8px;
    --radius:    14px;
    --radius-lg: 22px;
    --radius-xl: 32px;

    /* Shadows */
    --shadow-sm: 0 1px 2px rgba(10, 30, 20, 0.06);
    --shadow:    0 8px 24px rgba(10, 60, 40, 0.08), 0 2px 6px rgba(10, 60, 40, 0.05);
    --shadow-lg: 0 24px 48px rgba(10, 60, 40, 0.14), 0 6px 14px rgba(10, 60, 40, 0.08);

    /* Motion */
    --ease:       cubic-bezier(0.22, 1, 0.36, 1);
    --ease-bounce:cubic-bezier(0.34, 1.56, 0.64, 1);
    --t-fast: 180ms;
    --t-med:  320ms;
    --t-slow: 600ms;

    --header-h: 76px;
}

[data-theme="dark"] {
    --bg:          #0a1410;
    --bg-elevated: #0f1d18;
    --bg-soft:     #122621;
    --fg:          #e8f0ec;
    --fg-muted:    #95a89e;
    --fg-soft:     #c2cdc7;
    --border:      rgba(224, 176, 72, 0.14);
    --border-strong: rgba(224, 176, 72, 0.28);
    --primary:     var(--mn-green-500);
    --primary-deep: var(--mn-green-600);
    --primary-soft: rgba(46, 163, 116, 0.12);
    --accent:      var(--mn-gold-500);
    --accent-soft: rgba(224, 176, 72, 0.12);
    --shadow-sm:   0 1px 2px rgba(0, 0, 0, 0.35);
    --shadow:      0 10px 28px rgba(0, 0, 0, 0.5);
    --shadow-lg:   0 28px 60px rgba(0, 0, 0, 0.6);
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
    margin: 0;
    background: var(--bg);
    color: var(--fg);
    font-family: var(--font-sans);
    font-size: 17px;
    line-height: 1.7;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
    overflow-x: hidden;
    transition: background-color var(--t-med) var(--ease), color var(--t-med) var(--ease);
}

img, svg, video { max-width: 100%; height: auto; display: block; }
a { color: var(--primary); text-decoration: none; transition: color var(--t-fast) var(--ease); }
a:hover { color: var(--accent); }

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-display);
    color: var(--fg);
    line-height: 1.25;
    letter-spacing: -0.01em;
    font-weight: 600;
    margin: 0 0 0.6em;
}
h1 { font-size: clamp(2rem, 4vw + 1rem, 3.4rem); }
h2 { font-size: clamp(1.6rem, 2vw + 1rem, 2.4rem); }
h3 { font-size: 1.35rem; }
p  { margin: 0 0 1em; }

button, input, select, textarea {
    font: inherit;
    color: inherit;
}
button { cursor: pointer; background: none; border: 0; padding: 0; }

::selection { background: var(--accent); color: #fff; }

/* Layout */
.container { max-width: var(--container); margin: 0 auto; padding: 0 1.25rem; }
.screen-reader-text { position: absolute; clip: rect(1px,1px,1px,1px); width: 1px; height: 1px; overflow: hidden; }
.skip-link { position: absolute; left: -9999px; top: 0; padding: .75rem 1rem; background: var(--primary); color: #fff; z-index: 999; }
.skip-link:focus { left: 1rem; top: 1rem; border-radius: var(--radius-sm); }

/* RTL */
[dir="rtl"] body { font-family: var(--font-arabic); }
[dir="rtl"] h1, [dir="rtl"] h2, [dir="rtl"] h3, [dir="rtl"] h4 { font-family: var(--font-display); letter-spacing: 0; }

/* ---------- Buttons ---------- */
.btn {
    display: inline-flex; align-items: center; gap: .55rem;
    padding: .85rem 1.5rem;
    border-radius: 999px;
    font-weight: 600;
    font-size: 0.95rem;
    line-height: 1;
    transition: transform var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease), background-color var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
    cursor: pointer;
    border: 1px solid transparent;
    text-decoration: none;
}
.btn-primary {
    background: linear-gradient(135deg, var(--primary), var(--primary-deep));
    color: #fff;
    box-shadow: 0 6px 18px rgba(15, 94, 60, 0.3);
}
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 12px 26px rgba(15, 94, 60, 0.38); color: #fff; }
.btn-ghost {
    background: transparent;
    color: var(--fg);
    border-color: var(--border-strong);
}
.btn-ghost:hover { background: var(--primary-soft); color: var(--primary); border-color: var(--primary); }

/* ---------- Reading progress ---------- */
.reading-progress {
    position: fixed; top: 0; left: 0;
    height: 3px; width: 0%;
    background: linear-gradient(90deg, var(--primary), var(--accent));
    z-index: 1000;
    transition: width 80ms linear;
    box-shadow: 0 0 12px rgba(224, 176, 72, 0.55);
}

/* ---------- Site header ---------- */
.site-header {
    position: sticky; top: 0; z-index: 50;
    background: color-mix(in srgb, var(--bg-elevated) 86%, transparent);
    backdrop-filter: saturate(160%) blur(14px);
    -webkit-backdrop-filter: saturate(160%) blur(14px);
    border-bottom: 1px solid var(--border);
    transition: box-shadow var(--t-med) var(--ease), background-color var(--t-med) var(--ease);
}
.site-header.is-scrolled { box-shadow: var(--shadow); }
.header-decor {
    position: absolute; left: 0; right: 0; bottom: -1px;
    color: var(--accent); opacity: .6; pointer-events: none;
    height: 8px;
}
.header-decor svg { width: 100%; height: 100%; }

.header-inner {
    display: flex; align-items: center; gap: 1.5rem;
    min-height: var(--header-h);
}
.site-brand {
    display: flex; align-items: center; gap: .85rem;
    margin-inline-end: auto;
}
.site-logo img { width: 44px; height: 44px; border-radius: 50%; object-fit: cover; }
.site-title { margin: 0; font-family: var(--font-display); font-size: 1.35rem; font-weight: 700; letter-spacing: -0.01em; }
.site-title a { color: var(--fg); }
.site-title a:hover { color: var(--primary); }
.site-tagline { margin: 0; font-size: 0.82rem; color: var(--fg-muted); }

.primary-nav { display: flex; }
.primary-menu {
    list-style: none; padding: 0; margin: 0;
    display: flex; gap: .25rem; align-items: center;
}
.primary-menu a {
    display: inline-flex; align-items: center;
    padding: .55rem .9rem;
    color: var(--fg-soft);
    font-weight: 500;
    border-radius: 999px;
    position: relative;
    transition: background-color var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
}
.primary-menu a::after {
    content: ''; position: absolute; left: 50%; bottom: 6px;
    width: 0; height: 2px; background: var(--accent);
    transform: translateX(-50%); transition: width var(--t-med) var(--ease);
    border-radius: 2px;
}
.primary-menu a:hover { color: var(--primary); background: var(--primary-soft); }
.primary-menu .current-menu-item > a,
.primary-menu .current_page_item > a { color: var(--primary); }
.primary-menu .current-menu-item > a::after,
.primary-menu .current_page_item > a::after { width: 18px; }

.primary-menu .sub-menu {
    list-style: none; padding: .5rem; margin: 0;
    position: absolute;
    background: var(--bg-elevated);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    min-width: 200px;
    opacity: 0; visibility: hidden; transform: translateY(8px);
    transition: opacity var(--t-fast) var(--ease), transform var(--t-fast) var(--ease), visibility var(--t-fast);
}
.primary-menu li { position: relative; }
.primary-menu li:hover > .sub-menu,
.primary-menu li:focus-within > .sub-menu { opacity: 1; visibility: visible; transform: translateY(0); }
.primary-menu .sub-menu a { display: block; padding: .5rem .75rem; }

.header-actions { display: flex; align-items: center; gap: .25rem; }
.search-toggle, .theme-toggle {
    width: 42px; height: 42px;
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: 50%;
    color: var(--fg-soft);
    transition: background-color var(--t-fast) var(--ease), color var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);
}
.search-toggle:hover, .theme-toggle:hover {
    background: var(--primary-soft); color: var(--primary);
}
.theme-toggle .icon-moon { display: none; }
[data-theme="dark"] .theme-toggle .icon-sun { display: none; }
[data-theme="dark"] .theme-toggle .icon-moon { display: block; }

.menu-toggle {
    display: none;
    width: 42px; height: 42px;
    align-items: center; justify-content: center;
    border-radius: 50%;
    color: var(--fg-soft);
}
.menu-toggle-bars { width: 22px; height: 16px; position: relative; display: inline-block; }
.menu-toggle-bars span {
    position: absolute; left: 0; right: 0; height: 2px; background: currentColor; border-radius: 2px;
    transition: transform var(--t-med) var(--ease), opacity var(--t-fast) var(--ease), top var(--t-med) var(--ease);
}
.menu-toggle-bars span:nth-child(1) { top: 0; }
.menu-toggle-bars span:nth-child(2) { top: 7px; }
.menu-toggle-bars span:nth-child(3) { top: 14px; }
.menu-toggle[aria-expanded="true"] .menu-toggle-bars span:nth-child(1) { top: 7px; transform: rotate(45deg); }
.menu-toggle[aria-expanded="true"] .menu-toggle-bars span:nth-child(2) { opacity: 0; }
.menu-toggle[aria-expanded="true"] .menu-toggle-bars span:nth-child(3) { top: 7px; transform: rotate(-45deg); }

/* ---------- Search overlay ---------- */
.search-overlay {
    position: fixed; inset: 0;
    background: color-mix(in srgb, var(--bg) 94%, transparent);
    backdrop-filter: blur(16px);
    z-index: 100;
    display: flex; align-items: center; justify-content: center;
    opacity: 0; visibility: hidden;
    transition: opacity var(--t-med) var(--ease), visibility var(--t-med);
}
.search-overlay.is-open { opacity: 1; visibility: visible; }
.search-overlay .container { width: 100%; max-width: 720px; position: relative; }
.search-close {
    position: absolute; top: -3rem; right: 0;
    width: 42px; height: 42px;
    border-radius: 50%; color: var(--fg);
    display: inline-flex; align-items: center; justify-content: center;
}
.search-close:hover { background: var(--primary-soft); color: var(--primary); }

/* ---------- Breadcrumbs ---------- */
.breadcrumbs {
    padding: 1rem 0 0;
    font-size: 0.85rem;
    color: var(--fg-muted);
}
.breadcrumbs ol {
    list-style: none; padding: 0; margin: 0;
    display: flex; flex-wrap: wrap; gap: .5rem;
}
.breadcrumbs li:not(:last-child)::after {
    content: '/'; margin-inline-start: .5rem; opacity: .5;
}
.breadcrumbs a { color: var(--fg-muted); }
.breadcrumbs a:hover { color: var(--primary); }
.breadcrumbs [aria-current="page"] { color: var(--fg); }

/* ---------- Hero / page-hero ---------- */
.page-hero {
    position: relative;
    padding: 4.5rem 0 3rem;
    overflow: hidden;
    background: linear-gradient(180deg, var(--bg) 0%, var(--bg-soft) 100%);
}
.page-hero--front {
    padding: 5.5rem 0 4rem;
    background:
        radial-gradient(circle at 20% 0%, rgba(46, 163, 116, 0.12), transparent 60%),
        radial-gradient(circle at 90% 30%, rgba(224, 176, 72, 0.14), transparent 55%),
        linear-gradient(180deg, var(--bg) 0%, var(--bg-soft) 100%);
}
.hero-pattern {
    position: absolute; inset: 0;
    color: var(--primary);
    opacity: .07;
    pointer-events: none;
    animation: drift 60s linear infinite;
}
.hero-pattern svg { width: 100%; height: 100%; }
@keyframes drift {
    from { transform: translate(0, 0); }
    to   { transform: translate(-40px, -40px); }
}

.hero-eyebrow {
    font-size: 0.85rem; font-weight: 600;
    text-transform: uppercase; letter-spacing: 0.16em;
    color: var(--accent);
    margin: 0 0 .5rem;
    display: inline-flex; align-items: center; gap: .5rem;
}
.hero-eyebrow::before, .hero-eyebrow::after {
    content: ''; height: 1px; width: 28px; background: var(--accent); opacity: .6;
}
.hero-title {
    font-family: var(--font-display);
    margin: 0 0 .85rem;
    font-weight: 700;
    color: var(--fg);
    max-width: 22ch;
}
.hero-title em { color: var(--accent); font-style: normal; }
.hero-sub {
    color: var(--fg-muted);
    max-width: 60ch;
    font-size: 1.1rem;
    margin: 0 0 1.5rem;
}
.hero-actions { display: flex; flex-wrap: wrap; gap: .75rem; }
.hero-search { margin-top: 1.25rem; max-width: 520px; }

/* ---------- Posts grid ---------- */
.posts-wrap { padding: 3rem 1.25rem 5rem; }
.posts-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 1.75rem;
}
.post-card {
    background: var(--bg-elevated);
    border-radius: var(--radius-lg);
    overflow: hidden;
    border: 1px solid var(--border);
    transition: transform var(--t-med) var(--ease), box-shadow var(--t-med) var(--ease), border-color var(--t-med) var(--ease);
    position: relative;
    isolation: isolate;
}
.post-card::before {
    content: '';
    position: absolute; inset: 0;
    border-radius: inherit;
    background: linear-gradient(135deg, rgba(46, 163, 116, 0.08), rgba(224, 176, 72, 0.06));
    opacity: 0;
    transition: opacity var(--t-med) var(--ease);
    pointer-events: none;
    z-index: -1;
}
.post-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-lg);
    border-color: var(--border-strong);
}
.post-card:hover::before { opacity: 1; }

.post-card-link { display: block; color: inherit; height: 100%; }
.post-card-link:hover { color: inherit; }
.post-card-media {
    position: relative;
    aspect-ratio: 16 / 10;
    background: var(--bg-soft);
    overflow: hidden;
}
.post-card-media img {
    width: 100%; height: 100%; object-fit: cover;
    transition: transform var(--t-slow) var(--ease);
}
.post-card:hover .post-card-media img { transform: scale(1.06); }
.post-card-media--placeholder { color: var(--primary); display: grid; place-items: center; height: 100%; }
.post-card-media--placeholder svg { width: 100%; height: 100%; }

.post-card-cats {
    position: absolute; top: 1rem; left: 1rem;
    display: flex; gap: .35rem; flex-wrap: wrap;
}
.post-cat {
    display: inline-flex; align-items: center;
    padding: .25rem .65rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.92);
    color: var(--primary-deep);
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    backdrop-filter: blur(8px);
    border: 1px solid rgba(15, 94, 60, 0.1);
    transition: background-color var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
}
.post-cat:hover { background: var(--accent); color: #fff; }
[data-theme="dark"] .post-cat { background: rgba(15, 29, 24, 0.85); color: var(--accent); border-color: rgba(224, 176, 72, 0.25); }

.post-card-body { padding: 1.4rem 1.5rem 1.5rem; }
.post-card-title {
    margin: 0 0 .6rem;
    font-size: 1.3rem;
    line-height: 1.3;
    color: var(--fg);
    transition: color var(--t-fast) var(--ease);
}
.post-card:hover .post-card-title { color: var(--primary); }
.post-card-excerpt {
    color: var(--fg-muted);
    font-size: 0.95rem;
    margin: 0 0 1rem;
}
.post-card-meta {
    display: flex; align-items: center; gap: .5rem;
    color: var(--fg-muted);
    font-size: 0.8rem;
}

/* Featured card — first card on home spans 2 cols */
@media (min-width: 880px) {
    .post-card--featured {
        grid-column: span 2;
        display: grid;
        grid-template-columns: 1.15fr 1fr;
        align-items: stretch;
    }
    .post-card--featured .post-card-link { display: grid; grid-template-columns: 1.15fr 1fr; height: 100%; }
    .post-card--featured .post-card-media { aspect-ratio: auto; height: 100%; min-height: 320px; }
    .post-card--featured .post-card-body { padding: 2.25rem 2.5rem; display: flex; flex-direction: column; justify-content: center; }
    .post-card--featured .post-card-title { font-size: 1.85rem; }
    .post-card--featured .post-card-excerpt { font-size: 1.05rem; }
    .post-card--featured::after {
        content: ''; position: absolute; top: 1.25rem; right: 1.25rem;
        width: 60px; height: 60px;
        background: var(--accent); color: #fff;
        border-radius: 50%;
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white' width='24' height='24'%3E%3Cpath d='M12 2l2.39 7.36H22l-6.18 4.49L18.21 22 12 17.27 5.79 22l2.39-8.15L2 9.36h7.61z'/%3E%3C/svg%3E");
        background-repeat: no-repeat; background-position: center; background-size: 22px;
        z-index: 2;
    }
}

/* ---------- Pagination ---------- */
.pagination, .navigation.pagination {
    margin-top: 3rem;
    display: flex; justify-content: center;
}
.pagination .nav-links, .navigation.pagination .nav-links {
    display: inline-flex; gap: .35rem; align-items: center;
    background: var(--bg-elevated);
    padding: .35rem;
    border-radius: 999px;
    border: 1px solid var(--border);
    box-shadow: var(--shadow-sm);
}
.pagination .page-numbers,
.navigation.pagination .page-numbers {
    display: inline-flex; align-items: center; justify-content: center;
    min-width: 40px; height: 40px;
    padding: 0 1rem;
    border-radius: 999px;
    color: var(--fg-soft);
    font-weight: 600;
    transition: all var(--t-fast) var(--ease);
}
.pagination .page-numbers:hover { background: var(--primary-soft); color: var(--primary); }
.pagination .page-numbers.current { background: var(--primary); color: #fff; }
.pagination .dots { background: transparent; }

/* ---------- Single post ---------- */
.single-post .single-hero {
    position: relative;
    padding: 4rem 0 3rem;
    overflow: hidden;
    color: var(--fg);
}
.single-post.has-thumbnail .single-hero { color: #fff; min-height: 60vh; display: flex; align-items: flex-end; }
.single-hero-media { position: absolute; inset: 0; z-index: -1; }
.single-hero-media img { width: 100%; height: 100%; object-fit: cover; }
.single-hero-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(10, 30, 20, 0.0) 0%, rgba(10, 30, 20, 0.6) 50%, rgba(10, 30, 20, 0.92) 100%);
}
.single-hero-pattern { position: absolute; inset: 0; color: var(--primary); opacity: .06; z-index: -1; }
.single-hero-inner { position: relative; }

.single-cats { display: flex; gap: .35rem; flex-wrap: wrap; margin-bottom: 1rem; }
.has-featured .single-cats .post-cat { background: rgba(255, 255, 255, 0.92); color: var(--primary-deep); }

.single-title {
    font-family: var(--font-display);
    font-size: clamp(2rem, 4.2vw + 0.6rem, 3.6rem);
    line-height: 1.15;
    max-width: 24ch;
    margin: 0 0 1.25rem;
}
.has-featured .single-title { color: #fff; text-shadow: 0 4px 24px rgba(0, 0, 0, 0.35); }

.single-meta {
    display: flex; flex-wrap: wrap; gap: .5rem 1rem;
    align-items: center;
    font-size: 0.9rem;
    color: var(--fg-muted);
}
.has-featured .single-meta { color: rgba(255, 255, 255, 0.92); }
.meta-author { display: inline-flex; align-items: center; gap: .5rem; }
.meta-avatar { border-radius: 50%; }
.meta-sep { opacity: .5; }

.single-body { max-width: var(--container-narrow); padding-top: 3rem; padding-bottom: 3rem; }

/* ---------- Article content typography ---------- */
.single-content {
    font-size: 1.125rem;
    line-height: 1.85;
    color: var(--fg-soft);
}
.single-content > * { margin-bottom: 1.4em; }
.single-content h2, .single-content h3, .single-content h4 {
    color: var(--fg);
    margin-top: 2.5em;
    position: relative;
}
.single-content h2 {
    font-size: 1.85rem;
    padding-bottom: 0.4em;
}
.single-content h2::after {
    content: '';
    position: absolute;
    bottom: 0; left: 0;
    width: 60px; height: 3px;
    background: linear-gradient(90deg, var(--primary), var(--accent));
    border-radius: 2px;
}
[dir="rtl"] .single-content h2::after { left: auto; right: 0; }
.single-content h3 { font-size: 1.45rem; }

.single-content a {
    color: var(--primary);
    background-image: linear-gradient(transparent 70%, var(--accent-soft) 70%);
    background-size: 100% 100%;
    transition: background-size var(--t-med) var(--ease), color var(--t-fast) var(--ease);
    padding-bottom: 1px;
}
.single-content a:hover {
    color: var(--primary-deep);
    background-size: 100% 100%;
    background-image: linear-gradient(transparent 0%, var(--accent-soft) 0%);
}

.single-content blockquote {
    margin: 2.2em 0;
    padding: 1.5em 2em;
    border: 0;
    background: var(--primary-soft);
    border-radius: var(--radius-lg);
    position: relative;
    font-family: var(--font-quote);
    font-size: 1.25rem;
    line-height: 1.7;
    color: var(--fg);
    font-style: italic;
}
.single-content blockquote::before {
    content: '"';
    position: absolute;
    top: -0.1em; left: 0.2em;
    font-size: 5rem;
    font-family: var(--font-display);
    color: var(--accent);
    opacity: .35;
    line-height: 1;
}
.single-content blockquote p:last-child { margin-bottom: 0; }
.single-content blockquote cite {
    display: block;
    margin-top: 0.5em;
    font-style: normal;
    font-size: 0.9rem;
    color: var(--fg-muted);
    font-family: var(--font-sans);
}

.single-content img,
.single-content figure {
    border-radius: var(--radius);
    overflow: hidden;
}
.single-content figure { margin: 2em 0; }
.single-content figcaption {
    margin-top: .6em;
    font-size: 0.88rem;
    color: var(--fg-muted);
    text-align: center;
    font-style: italic;
}

.single-content pre {
    background: var(--mn-ink-900);
    color: #f6efe0;
    padding: 1.5em;
    border-radius: var(--radius);
    overflow-x: auto;
    font-size: 0.9rem;
    line-height: 1.6;
}
.single-content code {
    background: var(--bg-soft);
    color: var(--primary-deep);
    padding: 0.15em 0.45em;
    border-radius: 4px;
    font-size: 0.9em;
    font-family: 'Menlo', 'Monaco', monospace;
}
.single-content pre code { background: transparent; color: inherit; padding: 0; }

.single-content ul, .single-content ol {
    padding-inline-start: 1.5em;
}
.single-content li { margin-bottom: 0.5em; }
.single-content ul li::marker { color: var(--accent); }
.single-content hr {
    border: 0;
    margin: 3em auto;
    text-align: center;
    height: 1.5em;
    position: relative;
}
.single-content hr::before {
    content: '✦ ✦ ✦';
    position: absolute;
    left: 50%; top: 0;
    transform: translateX(-50%);
    color: var(--accent);
    letter-spacing: 0.5em;
    font-size: 0.9em;
}

.single-content .wp-block-pullquote {
    border-top: 3px solid var(--accent);
    border-bottom: 3px solid var(--accent);
    background: transparent;
    text-align: center;
    padding: 2em 1em;
}
.single-content .wp-block-quote.is-style-large p { font-size: 1.5rem; }

/* Drop cap on first paragraph */
.single-content > p:first-of-type::first-letter {
    font-family: var(--font-display);
    font-size: 3.6em;
    line-height: 0.9;
    float: left;
    margin: 0.05em 0.15em 0 0;
    color: var(--primary);
    font-weight: 700;
}
[dir="rtl"] .single-content > p:first-of-type::first-letter { float: right; margin: 0.05em 0 0 0.15em; }

/* ---------- Single footer ---------- */
.single-footer {
    margin-top: 3rem;
    padding-top: 2rem;
    border-top: 1px solid var(--border);
    display: flex;
    flex-wrap: wrap;
    gap: 1.5rem;
    justify-content: space-between;
    align-items: center;
}
.single-tags { display: flex; gap: .5rem; flex-wrap: wrap; align-items: center; }
.single-tags-label { font-size: 0.85rem; color: var(--fg-muted); margin-inline-end: .25rem; }
.single-tags a {
    padding: .3rem .7rem;
    border-radius: 999px;
    background: var(--bg-soft);
    color: var(--fg-soft);
    font-size: 0.85rem;
    transition: all var(--t-fast) var(--ease);
}
.single-tags a:hover { background: var(--primary); color: #fff; }

.single-share { display: flex; align-items: center; gap: .35rem; }
.single-share-label { font-size: 0.85rem; color: var(--fg-muted); margin-inline-end: .35rem; }
.share-btn {
    width: 38px; height: 38px;
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: 50%;
    background: var(--bg-soft);
    color: var(--fg-soft);
    transition: all var(--t-fast) var(--ease);
}
.share-btn:hover { background: var(--primary); color: #fff; transform: translateY(-2px); }
.share-btn.copied { background: var(--accent); color: #fff; }

/* ---------- Author card ---------- */
.author-card {
    margin: 3rem 0 0;
    padding: 2rem;
    background: var(--bg-elevated);
    border-radius: var(--radius-lg);
    border: 1px solid var(--border);
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 1.5rem;
    align-items: start;
    position: relative;
    overflow: hidden;
}
.author-card::before {
    content: '';
    position: absolute; right: -40px; top: -40px;
    width: 160px; height: 160px;
    background: radial-gradient(circle, var(--accent-soft), transparent 70%);
    border-radius: 50%;
}
.author-card-avatar img { width: 88px; height: 88px; border-radius: 50%; border: 3px solid var(--accent); }
.author-card-eyebrow { font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.14em; color: var(--accent); margin: 0 0 .25rem; font-weight: 600; }
.author-card-name { margin: 0 0 .5rem; font-size: 1.35rem; }
.author-card-bio { margin: 0 0 .75rem; color: var(--fg-muted); }
.author-card-link { color: var(--primary); font-weight: 600; }
.author-card-link:hover { color: var(--accent); }

/* ---------- Post nav ---------- */
.post-nav {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    margin: 3rem 0 0;
}
.post-nav-prev, .post-nav-next {
    display: flex; flex-direction: column;
    padding: 1.25rem 1.5rem;
    background: var(--bg-elevated);
    border-radius: var(--radius);
    border: 1px solid var(--border);
    transition: all var(--t-fast) var(--ease);
    color: var(--fg);
}
.post-nav-next { text-align: right; }
.post-nav-prev:hover, .post-nav-next:hover {
    border-color: var(--primary);
    background: var(--primary-soft);
    transform: translateY(-2px);
}
.post-nav-eyebrow { font-size: 0.8rem; color: var(--accent); font-weight: 600; margin-bottom: .35rem; }
.post-nav-title { font-family: var(--font-display); font-weight: 600; }

/* ---------- Related posts ---------- */
.related-posts {
    padding: 4rem 0;
    background: linear-gradient(180deg, transparent, var(--bg-soft));
    margin-top: 3rem;
}
.section-title { text-align: center; margin: 0 0 2.5rem; position: relative; }
.section-title span { position: relative; display: inline-block; padding: 0 1.5rem; background: var(--bg); }
.section-title::before {
    content: ''; position: absolute; left: 0; right: 0; top: 50%;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--border-strong), transparent);
    z-index: -1;
}
.related-posts .section-title span { background: var(--bg-soft); }
.related-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 1.5rem;
}
.related-card {
    background: var(--bg-elevated);
    border-radius: var(--radius);
    overflow: hidden;
    border: 1px solid var(--border);
    transition: all var(--t-med) var(--ease);
}
.related-card:hover { transform: translateY(-4px); box-shadow: var(--shadow); border-color: var(--border-strong); }
.related-card-link { display: block; color: inherit; }
.related-card-img { aspect-ratio: 16/10; background: var(--bg-soft); overflow: hidden; }
.related-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--t-slow) var(--ease); }
.related-card:hover .related-card-img img { transform: scale(1.05); }
.related-card-img--placeholder { display: grid; place-items: center; color: var(--primary); }
.related-card-body { padding: 1.25rem; }
.related-card-title { margin: .5rem 0 0; font-size: 1.1rem; line-height: 1.35; }

/* ---------- Comments ---------- */
.comments-wrap { max-width: var(--container-narrow); padding: 1rem 1.25rem 0; }
.comments-area {
    margin-top: 3rem;
    padding-top: 2rem;
    border-top: 1px solid var(--border);
}
.comments-title { font-size: 1.6rem; margin-bottom: 2rem; }
.comment-list { list-style: none; padding: 0; margin: 0 0 2rem; }
.comment-list .comment { padding: 1rem 0; border-bottom: 1px solid var(--border); }
.comment-list .children { list-style: none; padding-inline-start: 1.5rem; margin-top: 1rem; border-inline-start: 2px solid var(--accent-soft); padding-inline-start: 1.5rem; }
.comment-author { display: flex; align-items: center; gap: .75rem; margin-bottom: .5rem; }
.comment-author .avatar { border-radius: 50%; }
.comment-author cite { font-style: normal; font-weight: 600; font-family: var(--font-display); }
.comment-metadata { font-size: 0.82rem; color: var(--fg-muted); }
.comment-body p { margin: 0; }
.comment-reply-link {
    display: inline-block;
    margin-top: .5rem;
    padding: .25rem .75rem;
    font-size: 0.85rem;
    border-radius: 999px;
    background: var(--bg-soft);
    color: var(--primary);
    font-weight: 600;
}
.comment-reply-link:hover { background: var(--primary); color: #fff; }

.comment-respond { margin-top: 2rem; }
.comment-reply-title { font-size: 1.3rem; }
.comment-form { display: grid; gap: 1rem; }
.comment-form p { margin: 0; }
.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea {
    width: 100%;
    padding: .85rem 1rem;
    background: var(--bg-elevated);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: var(--fg);
    transition: border-color var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
}
.comment-form input:focus,
.comment-form textarea:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px var(--primary-soft);
}
.comment-form textarea { min-height: 140px; resize: vertical; }
.comment-form label { font-size: 0.85rem; color: var(--fg-muted); display: inline-block; margin-bottom: .35rem; }
.comment-notes { font-size: 0.85rem; color: var(--fg-muted); }

/* ---------- Search form ---------- */
.search-form-field {
    position: relative;
    display: flex;
    align-items: center;
    background: var(--bg-elevated);
    border: 1px solid var(--border);
    border-radius: 999px;
    padding: .35rem .35rem .35rem 1.25rem;
    transition: border-color var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
}
[dir="rtl"] .search-form-field { padding: .35rem 1.25rem .35rem .35rem; }
.search-form-field:focus-within {
    border-color: var(--primary);
    box-shadow: 0 0 0 4px var(--primary-soft);
}
.search-form-icon { color: var(--fg-muted); flex-shrink: 0; }
.search-form-input {
    flex: 1;
    border: 0;
    background: transparent;
    padding: .75rem .75rem;
    font-size: 1.05rem;
    outline: none;
}
.search-form-submit {
    padding: .65rem 1.5rem;
    background: var(--primary);
    color: #fff;
    border-radius: 999px;
    font-weight: 600;
    transition: background-color var(--t-fast) var(--ease);
}
.search-form-submit:hover { background: var(--primary-deep); }
.search-count { color: var(--fg-muted); margin-bottom: 1.5rem; }

/* ---------- Newsletter CTA ---------- */
.newsletter-cta {
    position: relative;
    padding: 5rem 1.25rem;
    background: linear-gradient(135deg, var(--primary-deep), var(--primary));
    color: #fff;
    text-align: center;
    overflow: hidden;
    margin-top: 4rem;
}
.newsletter-cta::before, .newsletter-cta::after {
    content: '';
    position: absolute;
    width: 240px; height: 240px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(224, 176, 72, 0.2), transparent 70%);
}
.newsletter-cta::before { top: -100px; left: -80px; }
.newsletter-cta::after { bottom: -120px; right: -80px; }
.newsletter-decor {
    color: var(--accent);
    margin: 0 auto 1.25rem;
    width: 80px; height: 80px;
    opacity: .85;
}
.newsletter-decor svg { animation: slowspin 22s linear infinite; }
@keyframes slowspin { to { transform: rotate(360deg); } }
.newsletter-title { color: #fff; font-size: clamp(1.6rem, 2vw + 1rem, 2.4rem); margin-bottom: .5rem; }
.newsletter-sub { color: rgba(255, 255, 255, 0.85); max-width: 50ch; margin: 0 auto 2rem; }
.newsletter-form { max-width: 480px; margin: 0 auto; position: relative; z-index: 1; }
.newsletter-fields {
    display: flex;
    background: rgba(255, 255, 255, 0.12);
    backdrop-filter: blur(10px);
    border-radius: 999px;
    padding: .35rem;
    border: 1px solid rgba(255, 255, 255, 0.2);
}
.newsletter-fields input {
    flex: 1;
    background: transparent;
    border: 0;
    padding: .85rem 1.25rem;
    color: #fff;
    font-size: 1rem;
    outline: none;
}
.newsletter-fields input::placeholder { color: rgba(255, 255, 255, 0.6); }
.newsletter-fields button {
    padding: .85rem 1.6rem;
    background: var(--accent);
    color: var(--primary-deep);
    border-radius: 999px;
    font-weight: 700;
    transition: all var(--t-fast) var(--ease);
}
.newsletter-fields button:hover { background: var(--mn-gold-300); transform: scale(1.04); }
.newsletter-thanks { color: var(--mn-gold-300); font-weight: 600; }

/* ---------- Footer ---------- */
.site-footer {
    position: relative;
    background: var(--mn-ink-900);
    color: rgba(255, 255, 255, 0.85);
    padding-top: 0;
    margin-top: 0;
    overflow: hidden;
}
.footer-skyline {
    color: var(--mn-green-800);
    height: 110px;
    line-height: 0;
    position: relative;
}
.footer-skyline .mosque-silhouette {
    width: 100%;
    height: 100%;
    display: block;
    color: var(--primary-deep);
    opacity: .55;
}
[data-theme="dark"] .footer-skyline .mosque-silhouette { color: var(--mn-green-700); opacity: .65; }

.footer-grid {
    display: grid;
    grid-template-columns: 1.4fr 1fr 1fr;
    gap: 3rem;
    padding: 3rem 1.25rem 2rem;
}
.footer-brand .footer-title { color: var(--accent); font-size: 1.4rem; margin: 1rem 0 .5rem; }
.footer-desc { color: rgba(255, 255, 255, 0.7); margin: 0 0 1rem; }
.footer-quote {
    font-family: var(--font-quote);
    font-style: italic;
    border-inline-start: 3px solid var(--accent);
    padding-inline-start: 1rem;
    color: rgba(255, 255, 255, 0.85);
    line-height: 1.6;
}
.footer-nav h4, .footer-widgets h4, .footer-widgets .widget-title {
    color: var(--accent);
    font-size: 1rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    margin: 0 0 1rem;
}
.footer-menu { list-style: none; padding: 0; margin: 0; display: grid; gap: .5rem; }
.footer-menu a { color: rgba(255, 255, 255, 0.78); }
.footer-menu a:hover { color: var(--accent); padding-inline-start: .3rem; }

.footer-bottom { border-top: 1px solid rgba(255, 255, 255, 0.08); padding: 1.5rem 0; }
.footer-bottom .container { display: flex; flex-wrap: wrap; gap: 1rem; justify-content: space-between; align-items: center; }
.footer-bottom p { margin: 0; font-size: 0.88rem; color: rgba(255, 255, 255, 0.6); }
.footer-ornament { display: inline-flex; align-items: center; gap: .5rem; color: var(--accent); }
.footer-ornament .dot { width: 4px; height: 4px; background: currentColor; border-radius: 50%; }
.footer-ornament .diamond { width: 8px; height: 8px; background: currentColor; transform: rotate(45deg); }

/* ---------- Back to top ---------- */
.back-to-top {
    position: fixed;
    bottom: 1.5rem; right: 1.5rem;
    width: 48px; height: 48px;
    background: var(--primary);
    color: #fff;
    border-radius: 50%;
    display: inline-flex; align-items: center; justify-content: center;
    box-shadow: var(--shadow);
    opacity: 0; visibility: hidden; transform: translateY(20px);
    transition: all var(--t-med) var(--ease);
    z-index: 40;
}
[dir="rtl"] .back-to-top { right: auto; left: 1.5rem; }
.back-to-top.is-visible { opacity: 1; visibility: visible; transform: translateY(0); }
.back-to-top:hover { background: var(--primary-deep); transform: translateY(-4px); }

/* ---------- No results ---------- */
.no-results {
    text-align: center;
    padding: 4rem 1.25rem;
    max-width: 580px;
    margin: 0 auto;
}
.no-results-art { width: 120px; height: 120px; margin: 0 auto 1.5rem; color: var(--primary); opacity: .8; }
.no-results-title { margin-bottom: .75rem; }
.no-results-sub { color: var(--fg-muted); margin-bottom: 1.5rem; }
.no-results .search-form { margin-bottom: 1.5rem; }

/* ---------- 404 ---------- */
.error-404 {
    padding: 5rem 1.25rem 6rem;
    text-align: center;
    background: linear-gradient(180deg, var(--bg), var(--bg-soft));
}
.error-404-art { width: 320px; max-width: 100%; margin: 0 auto 1rem; color: var(--primary); }
.error-title { font-size: clamp(2rem, 3vw + 1rem, 3rem); margin-bottom: .75rem; }
.error-sub { color: var(--fg-muted); max-width: 50ch; margin: 0 auto 2rem; }
.error-actions { display: flex; gap: .75rem; justify-content: center; flex-wrap: wrap; margin-bottom: 3rem; }
.error-recent { margin-top: 3rem; max-width: 540px; margin-inline: auto; text-align: left; }
[dir="rtl"] .error-recent { text-align: right; }
.error-recent-list { list-style: none; padding: 0; margin: 0; display: grid; gap: .5rem; }
.error-recent-list a {
    display: flex; justify-content: space-between; align-items: center;
    padding: 1rem 1.25rem;
    background: var(--bg-elevated);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    color: var(--fg);
    transition: all var(--t-fast) var(--ease);
}
.error-recent-list a:hover { border-color: var(--primary); background: var(--primary-soft); }
.rp-date { font-size: 0.82rem; color: var(--fg-muted); }

/* ---------- Widgets ---------- */
.widget { margin-bottom: 2rem; }
.widget-title { color: var(--fg); margin-bottom: 1rem; }
.widget ul { list-style: none; padding: 0; margin: 0; }
.widget li { padding: .5rem 0; border-bottom: 1px solid var(--border); }
.widget li:last-child { border-bottom: 0; }

/* Tag cloud */
.tagcloud a {
    display: inline-block;
    padding: .35rem .75rem;
    margin: .15rem;
    background: var(--bg-soft);
    color: var(--fg-soft);
    border-radius: 999px;
    font-size: 0.85rem !important;
}
.tagcloud a:hover { background: var(--primary); color: #fff; }

/* ---------- Animations on scroll ---------- */
.reveal {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity var(--t-slow) var(--ease), transform var(--t-slow) var(--ease);
}
.reveal.is-visible { opacity: 1; transform: translateY(0); }

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.001ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.001ms !important;
        scroll-behavior: auto !important;
    }
    .reveal { opacity: 1; transform: none; }
}

/* ---------- Responsive ---------- */
@media (max-width: 880px) {
    body { font-size: 16px; }
    .menu-toggle { display: inline-flex; }
    .site-tagline { display: none; }
    .primary-nav {
        position: fixed;
        top: var(--header-h);
        left: 0; right: 0;
        background: var(--bg-elevated);
        border-bottom: 1px solid var(--border);
        padding: 1rem 1.25rem 1.5rem;
        flex-direction: column;
        align-items: stretch;
        max-height: 0;
        overflow: hidden;
        transition: max-height var(--t-med) var(--ease);
        box-shadow: var(--shadow);
    }
    .primary-nav.is-open { max-height: 80vh; overflow-y: auto; }
    .primary-menu { flex-direction: column; align-items: stretch; gap: 0; }
    .primary-menu a { padding: .85rem 1rem; border-radius: var(--radius-sm); }
    .primary-menu .sub-menu {
        position: static; opacity: 1; visibility: visible; transform: none;
        background: transparent; border: 0; box-shadow: none;
        padding-inline-start: 1.5rem;
    }
    .footer-grid { grid-template-columns: 1fr; gap: 2rem; }
    .post-nav { grid-template-columns: 1fr; }
    .single-content > p:first-of-type::first-letter { font-size: 3em; }
    .author-card { grid-template-columns: 1fr; text-align: center; }
    .author-card-avatar img { margin: 0 auto; }
}

@media (max-width: 540px) {
    .container { padding: 0 1rem; }
    .page-hero { padding: 3rem 0 2rem; }
    .hero-title { font-size: 2rem; }
    .posts-grid { grid-template-columns: 1fr; gap: 1.25rem; }
    .single-body { padding-top: 2rem; }
    .newsletter-fields { flex-direction: column; border-radius: var(--radius); padding: .5rem; gap: .5rem; }
    .newsletter-fields input { text-align: center; }
    .single-footer { flex-direction: column; align-items: flex-start; }
}

/* ---------- Print ---------- */
@media print {
    .site-header, .site-footer, .newsletter-cta, .related-posts, .back-to-top, .reading-progress, .single-share, .search-overlay { display: none !important; }
    body { background: #fff; color: #000; }
    .single-content { font-size: 12pt; line-height: 1.5; }
}
