/*
Theme Name: موسوعة المعلقات
Theme URI: https://muallagat.example.com
Author: موسوعة المعلقات العربية
Description: قالب موسوعة المعلقات العشر والشعر الجاهلي — أدبي كلاسيكي فاخر بتصميم تفاعلي حديث
Version: 1.6.3
Requires at least: 6.0
Requires PHP: 8.0
License: GPL-2.0-or-later
Text Domain: muallagat
*/

/* ==========================================================================
   خطوط Lyon Arabic Display
   ========================================================================== */

@font-face {
    font-family: 'Lyon Arabic Display';
    src: url('assets/fonts/lyon-arabic-display-regular.otf') format('opentype');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Lyon Arabic Display';
    src: url('assets/fonts/lyon-arabic-display-bold.otf') format('opentype');
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}

/* ==========================================================================
   متغيرات CSS — الهوية البصرية
   ========================================================================== */

:root {
    --font-primary: 'Lyon Arabic Display', 'Amiri', 'Traditional Arabic', serif;
    --font-body:    'Lyon Arabic Display', 'Amiri', Georgia, serif;

    --radius-sm:  4px;
    --radius-md:  8px;
    --radius-lg:  16px;
    --radius-pill: 999px;

    --transition: 0.25s ease;

    /* نظام الحركة الموحّد */
    --motion-fast:   0.15s;
    --motion-base:   0.25s;
    --motion-slow:   0.38s;
    --ease-out:      cubic-bezier(0.22, 1, 0.36, 1);
    --ease-in:       cubic-bezier(0.4, 0, 1, 1);
    --ease-in-out:   cubic-bezier(0.45, 0, 0.55, 1);
    --motion-slide:  8px;
    --motion-enter:  var(--motion-base) var(--ease-out);
    --motion-leave:  var(--motion-fast) var(--ease-in);
    --motion-expand: var(--motion-slow) var(--ease-out);
    --expand-stagger: 12ms;

    --max-width: 900px;

    --header-height: 62px;
    --btn-height: 2.75rem;
    --btn-min-touch: 44px;
    --safe-bottom: env(safe-area-inset-bottom, 0px);

    --bp-md: 768px;
    --bp-sm: 480px;
}

/* الغداة — النمط الافتراضي (ورق المخطوطة) */
:root,
[data-color-theme="ghada"] {
    --color-bg:          #F5F0E6;
    --color-bg-alt:      #EFE6D2;
    --color-text:        #3B2F2F;
    --color-heading:     #5A3E2B;
    --color-border:      #C9B79C;
    --color-accent:      #8B5E3C;
    --color-accent-dark: #6B4226;
    --color-accent-light:#C9B79C;
    --color-muted:       #7A6652;
    --color-white:       #FDFAF4;
    --color-overlay:     rgba(59, 47, 47, 0.55);
    --color-selected-bg: #fdf6ee;
    --color-hero-mid:    #4a3220;
    --color-header-bg:      #5A3E2B;
    --color-header-text:    #FDFAF4;
    --color-header-muted:   #C9B79C;
    --color-surface:        #FDFAF4;
    --color-surface-alt:    #EFE6D2;
    --color-on-surface:     #3B2F2F;
    --color-on-surface-muted: #7A6652;
    --color-surface-border: #C9B79C;
    --color-header-faint: rgba(201, 183, 156, 0.45);
    --color-header-nav-bg: rgba(0, 0, 0, 0.15);
    --color-header-nav-divider: rgba(201, 183, 156, 0.2);

    --shadow-sm: 0 1px 4px rgba(90, 62, 43, 0.10);
    --shadow-md: 0 4px 16px rgba(90, 62, 43, 0.14);
    --shadow-lg: 0 8px 32px rgba(90, 62, 43, 0.18);

    --paper-pattern: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23C9B79C' fill-opacity='0.06'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}

/* العشيّ — نمط ليلي */
[data-color-theme="ashiy"] {
    color-scheme: dark;

    --color-bg:          #161310;
    --color-bg-alt:      #1f1b17;
    --color-text:        #e6ddd0;
    --color-heading:     #f0e6d6;
    --color-border:      #3d352c;
    --color-accent:      #c9a066;
    --color-accent-dark: #a8844f;
    --color-accent-light:#5a4f42;
    --color-muted:       #a89882;
    --color-white:       #f5f0e8;
    --color-overlay:     rgba(0, 0, 0, 0.65);
    --color-selected-bg: #2e2820;
    --color-hero-mid:    #1a1612;
    --color-header-bg:      #1f1b17;
    --color-header-text:    #f5f0e8;
    --color-header-muted:   #c9a066;
    --color-surface:        #252019;
    --color-surface-alt:    #2e2820;
    --color-on-surface:     #e6ddd0;
    --color-on-surface-muted: #a89882;
    --color-surface-border: #4a4036;
    --color-header-faint: rgba(201, 160, 102, 0.35);
    --color-header-nav-bg: rgba(0, 0, 0, 0.28);
    --color-header-nav-divider: rgba(201, 160, 102, 0.18);

    --shadow-sm: 0 1px 4px rgba(0, 0, 0, 0.25);
    --shadow-md: 0 4px 16px rgba(0, 0, 0, 0.32);
    --shadow-lg: 0 8px 32px rgba(0, 0, 0, 0.4);

    --paper-pattern: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23c9a066' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}

/* ==========================================================================
   إعادة الضبط والأساس
   ========================================================================== */

*,
*::before,
*::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    font-size: 18px;
    scroll-behavior: smooth;
}

body {
    font-family: var(--font-body);
    background-color: var(--color-bg);
    background-image: var(--paper-pattern);
    color: var(--color-text);
    direction: rtl;
    line-height: 1.9;
    min-height: 100vh;
}

body.nav-open {
    overflow: hidden;
}

a:focus-visible,
button:focus-visible,
[tabindex]:focus-visible {
    outline: 2px solid var(--color-accent);
    outline-offset: 2px;
}

@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
}

a {
    color: var(--color-accent);
    text-decoration: none;
    transition: color var(--transition);
}

a:hover {
    color: var(--color-accent-dark);
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

/* ==========================================================================
   التخطيط العام
   ========================================================================== */

.site-wrapper {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

.container {
    width: 100%;
    max-width: var(--max-width);
    margin-inline: auto;
    padding-inline: 1.5rem;
}

.container--wide {
    max-width: 1200px;
}

main {
    flex: 1;
}

/* ==========================================================================
   الترويسة العامة
   ========================================================================== */

.site-header {
    background-color: var(--color-surface);
    color: var(--color-on-surface);
    padding: 1rem 0;
    border-bottom: none;
    position: sticky;
    top: 0;
    z-index: 100;
    transition:
        padding var(--transition),
        box-shadow var(--transition);
}

.site-header.is-scrolled {
    padding: 0.55rem 0;
    box-shadow: var(--shadow-sm);
}

.site-header__inner {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: 1rem;
}

.site-header__brand {
    justify-self: start;
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
    min-width: 0;
}

.site-header__brand-row {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    min-width: 0;
}

.site-header__name {
    font-size: 1.15rem;
    font-weight: 700;
    letter-spacing: 0.01em;
    white-space: nowrap;
    color: var(--color-heading);
    text-decoration: none;
    transition: font-size var(--transition), opacity var(--transition);
}

.site-header__name:hover {
    color: var(--color-heading);
    opacity: 0.85;
}

.site-header__logo {
    display: inline-flex;
    flex-shrink: 0;
    line-height: 0;
}

.site-header__logo .custom-logo-link {
    display: inline-flex;
    line-height: 0;
}

.site-header__logo img,
.site-header__logo .custom-logo {
    width: auto;
    height: 2.5rem;
    max-height: 2.5rem;
    transition: max-height var(--transition), height var(--transition);
}

.site-header.is-scrolled .site-header__logo img,
.site-header.is-scrolled .site-header__logo .custom-logo {
    height: 2.1rem;
    max-height: 2.1rem;
}

.site-header.is-scrolled .site-header__name {
    font-size: 1.05rem;
}

.site-header__subtitle {
    display: none;
    font-size: 0.72rem;
    color: var(--color-on-surface-muted);
    font-weight: 400;
    padding-inline-start: 0.15rem;
}

.site-header__tools {
    justify-self: end;
    display: flex;
    align-items: center;
    gap: 0.65rem;
}

.site-header__search-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    padding: 0;
    border: 1.5px solid var(--color-surface-border);
    border-radius: var(--radius-sm);
    background: transparent;
    color: var(--color-on-surface-muted);
    flex-shrink: 0;
}

.site-header__search-icon {
    display: block;
}

/* مبدّل الغداة / العشيّ */
.color-theme-switcher {
    display: flex;
    gap: 0;
    border: 1.5px solid var(--color-surface-border);
    border-radius: var(--radius-sm);
    overflow: hidden;
    flex-shrink: 0;
}

.color-theme-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2rem;
    padding: 0.35rem 0.65rem;
    font-family: var(--font-body);
    font-size: 0.78rem;
    color: var(--color-on-surface-muted);
    background: transparent;
    border: none;
    cursor: pointer;
    white-space: nowrap;
    transition:
        background-color var(--transition),
        color var(--transition);
}

.color-theme-btn:hover {
    color: var(--color-on-surface);
    background: var(--color-bg-alt);
}

.color-theme-btn[aria-pressed="true"] {
    background: var(--color-bg-alt);
    color: var(--color-heading);
}

.color-theme-btn + .color-theme-btn {
    border-right: 1.5px solid var(--color-surface-border);
}

/* زر قائمة الجوال */
.site-nav-toggle {
    display: none;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    width: var(--btn-min-touch);
    height: var(--btn-min-touch);
    padding: 0;
    border: 1.5px solid var(--color-surface-border);
    border-radius: var(--radius-sm);
    background: transparent;
    cursor: pointer;
    flex-shrink: 0;
    color: var(--color-on-surface);
}

.site-nav-toggle__bar {
    display: block;
    width: 1.25rem;
    height: 2px;
    background: currentColor;
    border-radius: 1px;
    transition: transform var(--transition), opacity var(--transition);
    margin-inline: auto;
}

.site-header.is-nav-open .site-nav-toggle__bar:nth-child(1) {
    transform: translateY(7px) rotate(45deg);
}

.site-header.is-nav-open .site-nav-toggle__bar:nth-child(2) {
    opacity: 0;
}

.site-header.is-nav-open .site-nav-toggle__bar:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg);
}

/* القائمة */
.site-nav--bar {
    justify-self: center;
}

.site-nav__list {
    list-style: none;
    display: flex;
    gap: 1.35rem;
    align-items: center;
    margin: 0;
    padding: 0;
}

.site-nav__link,
.site-nav__dropdown-link {
    color: var(--color-on-surface-muted);
    font-size: 0.92rem;
    font-weight: 400;
    transition:
        color var(--transition),
        box-shadow var(--transition);
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.35rem 0;
    background: none;
    border: none;
    font-family: var(--font-body);
    cursor: pointer;
    text-decoration: none;
    box-shadow: inset 0 -2px 0 transparent;
}

.site-nav__link:hover,
.site-nav__link:focus-visible,
.site-nav__dropdown-link:hover,
.site-nav__dropdown-link:focus-visible {
    color: var(--color-on-surface);
}

.site-nav__link.is-current,
.site-nav__dropdown-link.is-current {
    color: var(--color-heading);
    font-weight: 600;
    box-shadow: inset 0 -2px 0 var(--color-accent);
}

.site-nav__caret {
    font-size: 0.7rem;
    opacity: 0.75;
    line-height: 1;
}

.site-nav__item--dropdown {
    position: relative;
}

.site-nav__dropdown {
    list-style: none;
    margin: 0;
    padding: 0.4rem 0;
    min-width: 9rem;
    position: absolute;
    top: calc(100% + 0.35rem);
    right: 0;
    background: var(--color-surface);
    border: 1px solid var(--color-surface-border);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-md);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-4px);
    transition:
        opacity var(--transition),
        visibility var(--transition),
        transform var(--transition);
    z-index: 110;
}

.site-nav__item--dropdown:hover > .site-nav__dropdown,
.site-nav__item--dropdown:focus-within > .site-nav__dropdown,
.site-nav__item--dropdown.is-open > .site-nav__dropdown {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.site-nav__dropdown-link {
    display: block;
    padding: 0.55rem 1rem;
    box-shadow: none;
    border-right: 3px solid transparent;
}

.site-nav__dropdown-link.is-current {
    box-shadow: none;
    border-right-color: var(--color-accent);
    background: var(--color-bg-alt);
}

.site-nav__dropdown-link:hover,
.site-nav__dropdown-link:focus-visible {
    background: var(--color-bg-alt);
}

/* overlay + drawer */
.site-nav-overlay {
    position: fixed;
    inset: 0;
    background: var(--color-overlay);
    z-index: 120;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition:
        opacity var(--transition),
        visibility var(--transition);
}

.site-header.is-nav-open .site-nav-overlay {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.site-nav-drawer {
    position: fixed;
    top: 0;
    left: 0;
    width: min(85vw, 360px);
    height: 100%;
    height: 100dvh;
    background: var(--color-surface);
    color: var(--color-on-surface);
    z-index: 130;
    display: flex;
    flex-direction: column;
    transform: translateX(-100%);
    transition: transform var(--transition);
    box-shadow: var(--shadow-lg);
}

.site-header.is-nav-open .site-nav-drawer {
    transform: translateX(0);
}

.site-nav-drawer__header {
    display: flex;
    flex-direction: row-reverse;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 1rem 1.15rem;
    border-bottom: 1px solid var(--color-surface-border);
    flex-shrink: 0;
}

.site-nav-drawer__brand {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    min-width: 0;
    flex: 1;
}

.site-nav-drawer__logo {
    line-height: 0;
    flex-shrink: 0;
}

.site-nav-drawer__logo img,
.site-nav-drawer__logo .custom-logo {
    height: 2rem;
    width: auto;
}

.site-nav-drawer__name {
    font-size: 0.95rem;
    font-weight: 700;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    color: var(--color-heading);
    text-decoration: none;
}

.site-nav-drawer__close {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: var(--btn-min-touch);
    height: var(--btn-min-touch);
    padding: 0;
    border: 1.5px solid var(--color-surface-border);
    border-radius: var(--radius-sm);
    background: transparent;
    color: var(--color-on-surface);
    cursor: pointer;
    flex-shrink: 0;
}

.site-nav--drawer {
    flex: 1;
    overflow-y: auto;
    padding: 0.75rem 1.15rem;
}

.site-nav--drawer .site-nav__list {
    flex-direction: column;
    align-items: center;
    gap: 0;
}

.site-nav--drawer .site-nav__link,
.site-nav--drawer .site-nav__dropdown-link {
    width: 100%;
    min-height: var(--btn-min-touch);
    padding: 0.85rem 0.5rem;
    box-shadow: none;
    font-size: 1.08rem;
    justify-content: center;
    text-align: center;
}

.site-nav--drawer .site-nav__item {
    width: 100%;
    text-align: center;
}

.site-nav--drawer .site-nav__link.is-current {
    box-shadow: inset 0 -2px 0 var(--color-accent);
    border-right: none;
    padding-inline: 0.5rem;
}

.site-nav--drawer .site-nav__item + .site-nav__item {
    border-top: 1px solid var(--color-surface-border);
}

.site-nav--drawer .site-nav__dropdown {
    position: static;
    opacity: 1;
    visibility: visible;
    transform: none;
    box-shadow: none;
    border: none;
    border-radius: 0;
    padding: 0;
    min-width: 0;
    display: none;
    background: var(--color-bg-alt);
    margin-top: -0.25rem;
    margin-bottom: 0.35rem;
    border-radius: var(--radius-sm);
}

.site-nav--drawer .site-nav__item--dropdown.is-open > .site-nav__dropdown {
    display: block;
}

.site-nav--drawer .site-nav__dropdown-link {
    padding-inline: 0.5rem;
    font-size: 1rem;
}

.site-nav--drawer .site-nav__dropdown-link.is-current {
    border-right: none;
    box-shadow: inset 0 -2px 0 var(--color-accent);
}

.site-nav-drawer__footer {
    padding: 1rem 1.15rem;
    padding-bottom: calc(1rem + var(--safe-bottom));
    border-top: 1px solid var(--color-surface-border);
    flex-shrink: 0;
}

.site-nav-drawer__footer .color-theme-switcher {
    width: 100%;
    justify-content: center;
}

.color-theme-switcher--drawer .color-theme-btn {
    flex: 1;
    min-height: var(--btn-min-touch);
}

@media (min-width: 769px) {
    .site-header__subtitle {
        display: block;
    }

    .site-header__brand:has(.site-header__logo) .site-header__subtitle {
        padding-inline-start: calc(2.5rem + 0.65rem);
    }

    .site-nav--drawer,
    .site-nav-overlay,
    .site-nav-drawer {
        display: none;
    }
}

@media (max-width: 768px) {
    .site-header__inner {
        grid-template-columns: 1fr auto;
    }

    .site-header__brand {
        grid-column: 1;
        grid-row: 1;
    }

    .site-header__tools {
        grid-column: 2;
        grid-row: 1;
    }

    .site-nav--bar {
        display: none;
    }

    .site-nav-toggle {
        display: flex;
    }

    .color-theme-switcher--text:not(.color-theme-switcher--drawer) {
        display: none;
    }

    .site-header__search-btn {
        display: none;
    }
}

/* ==========================================================================
   التذييل
   ========================================================================== */

.site-footer {
    background-color: var(--color-header-bg);
    color: var(--color-header-muted);
    text-align: center;
    padding: 2rem 1rem;
    font-size: 0.85rem;
    border-top: 3px solid var(--color-border);
    margin-top: 4rem;
}

.site-footer a {
    color: var(--color-header-text);
}

.site-footer__credit {
    margin-top: 0.5rem;
    font-size: 0.8rem;
    opacity: 0.7;
}

/* ==========================================================================
   زر التمرير للأعلى
   ========================================================================== */

.scroll-top-btn {
    position: fixed;
    left: max(1rem, env(safe-area-inset-left, 0px));
    bottom: calc(1.25rem + var(--safe-bottom, 0px));
    z-index: 900;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.75rem;
    height: 2.75rem;
    padding: 0;
    border: 1.5px solid color-mix(in srgb, var(--color-accent) 30%, var(--color-border));
    border-radius: 50%;
    background: var(--color-bg);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    color: var(--color-accent);
    cursor: pointer;
    box-shadow: var(--shadow-md);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(10px);
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
    transition:
        opacity var(--motion-base) var(--ease-out),
        transform var(--motion-base) var(--ease-out),
        visibility var(--motion-base) var(--ease-out),
        background var(--transition),
        border-color var(--transition),
        color var(--transition),
        box-shadow var(--transition);
}

.scroll-top-btn.is-visible {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0);
}

.scroll-top-btn:hover {
    background: var(--color-accent);
    border-color: var(--color-accent);
    color: var(--color-white);
    box-shadow: var(--shadow-lg);
    transform: translateY(-2px);
}

.scroll-top-btn.is-visible:hover {
    transform: translateY(-2px);
}

.scroll-top-btn:focus-visible {
    outline: 2px solid var(--color-accent);
    outline-offset: 3px;
}

body.has-verse-selection .scroll-top-btn {
    bottom: calc(5.25rem + var(--safe-bottom, 0px));
}

@media (max-width: 768px) {
    .scroll-top-btn {
        left: max(0.85rem, env(safe-area-inset-left, 0px));
        bottom: calc(1rem + var(--safe-bottom, 0px));
        width: var(--btn-min-touch, 44px);
        height: var(--btn-min-touch, 44px);
        background: var(--color-bg);
        box-shadow: 0 4px 20px rgba(90, 62, 43, 0.18);
    }

    body.has-verse-selection .scroll-top-btn {
        bottom: calc(5.5rem + var(--safe-bottom, 0px));
    }
}

@supports not (color: color-mix(in srgb, red 10%, blue)) {
    .scroll-top-btn {
        background: var(--color-bg);
        border-color: var(--color-border);
    }
}

@media (prefers-reduced-motion: reduce) {
    .scroll-top-btn {
        transition: none;
    }
}

/* ==========================================================================
   أزرار عامة
   ========================================================================== */

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    min-height: var(--btn-height);
    padding: 0.5rem 1.2rem;
    border-radius: var(--radius-sm);
    border: 1.5px solid transparent;
    font-family: var(--font-body);
    font-size: 0.9rem;
    cursor: pointer;
    transition: background-color var(--transition), border-color var(--transition), color var(--transition), box-shadow var(--transition), transform var(--transition);
    line-height: 1.4;
    text-align: center;
    text-decoration: none;
}

.btn:active {
    transform: scale(0.98);
}

.btn--primary {
    background-color: var(--color-accent);
    color: var(--color-white);
    border-color: var(--color-accent);
}

.btn--primary:hover {
    background-color: var(--color-accent-dark);
    border-color: var(--color-accent-dark);
    color: var(--color-white);
    box-shadow: var(--shadow-sm);
}

.btn--outline {
    background-color: transparent;
    color: var(--color-accent);
    border-color: var(--color-border);
}

.btn--outline:hover {
    background-color: var(--color-bg-alt);
    border-color: var(--color-accent);
}

.btn--ghost {
    background-color: transparent;
    color: var(--color-muted);
    border-color: transparent;
    padding: 0.3rem 0.6rem;
    font-size: 0.82rem;
}

.btn--ghost:hover {
    background-color: var(--color-bg-alt);
    color: var(--color-text);
}

/* ==========================================================================
   أرشيف المعلقات
   ========================================================================== */

.archive-hero {
    background: linear-gradient(
        180deg,
        var(--color-surface) 0%,
        var(--color-bg) 100%
    );
    color: var(--color-on-surface);
    text-align: center;
    padding: clamp(2.75rem, 8vw, 4rem) 1rem clamp(2rem, 5vw, 3rem);
    position: relative;
    overflow: hidden;
    border-bottom: 1px solid var(--color-surface-border);
}

.archive-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--paper-pattern);
    opacity: 0.35;
    pointer-events: none;
}

.archive-hero__title {
    font-size: clamp(2rem, 5vw, 2.8rem);
    font-weight: 700;
    position: relative;
    color: var(--color-heading);
    line-height: 1.3;
}

.archive-hero__subtitle {
    font-size: 1.05rem;
    color: var(--color-on-surface-muted);
    margin-top: 0.75rem;
    font-weight: 400;
    position: relative;
    max-width: 36ch;
    margin-inline: auto;
}

.archive-divider {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin: 3rem 0 2rem;
    color: var(--color-muted);
    font-size: 0.9rem;
}

.archive-divider::before,
.archive-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--color-border);
}

.poems-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 1.5rem;
    padding: 2rem 0 4rem;
}

/* ==========================================================================
   بطاقات غلاف القصائد (الرئيسية + الأرشيف)
   ========================================================================== */

.poem-cover-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 1.25rem;
    padding: 0 0 3rem;
}

.archive-poems-grid {
    padding-top: 2.5rem;
    padding-bottom: 4rem;
}

.poem-cover-card {
    position: relative;
    display: block;
    aspect-ratio: 3 / 4;
    border-radius: var(--radius-lg);
    overflow: hidden;
    background: linear-gradient(145deg, var(--color-header-bg) 0%, var(--color-hero-mid) 50%, var(--color-accent-dark) 100%);
    text-decoration: none;
    color: inherit;
    box-shadow: var(--shadow-sm);
    transition: transform var(--transition), box-shadow var(--transition);
}

.poem-cover-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
    color: inherit;
}

.poem-cover-card__img,
.poem-cover-card__fallback {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.45s ease;
}

.poem-cover-card__fallback {
    background:
        linear-gradient(135deg, rgba(201, 183, 156, 0.12) 25%, transparent 25%) -10px 0 / 20px 20px,
        linear-gradient(225deg, rgba(201, 183, 156, 0.08) 25%, transparent 25%) -10px 0 / 20px 20px,
        linear-gradient(160deg, var(--color-header-bg), var(--color-accent-dark));
}

.poem-cover-card:hover .poem-cover-card__img {
    transform: scale(1.06);
}

.poem-cover-card__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        to top,
        rgba(0, 0, 0, 0.88) 0%,
        rgba(0, 0, 0, 0.45) 38%,
        rgba(0, 0, 0, 0.08) 68%,
        rgba(0, 0, 0, 0.02) 100%
    );
    pointer-events: none;
}

.poem-cover-card__body {
    position: absolute;
    inset-inline: 0;
    bottom: 0;
    padding: 1.15rem 1.1rem 1.2rem;
    z-index: 1;
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
    text-align: right;
}

.poem-cover-card__title {
    font-family: var(--font-primary);
    font-size: 1.05rem;
    font-weight: 700;
    line-height: 1.45;
    color: #fff;
    text-shadow: 0 1px 6px rgba(0, 0, 0, 0.45);
}

.poem-cover-card__count {
    font-size: 0.82rem;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.82);
    letter-spacing: 0.01em;
}

.poem-card {
    background: var(--color-surface);
    border: 1px solid var(--color-surface-border);
    border-radius: var(--radius-lg);
    padding: 1.5rem;
    transition: all var(--transition);
    position: relative;
    overflow: hidden;
}

.poem-card::before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    width: 4px;
    height: 100%;
    background: var(--color-accent);
    transform: scaleY(0);
    transition: transform var(--transition);
}

.poem-card:hover {
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
    border-color: var(--color-accent);
}

.poem-card:hover::before {
    transform: scaleY(1);
}

.poem-card__order {
    font-size: 0.78rem;
    color: var(--color-on-surface-muted);
    font-weight: 400;
    margin-bottom: 0.5rem;
}

.poem-card__title {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--color-on-surface);
    margin-bottom: 0.4rem;
}

.poem-card__poet {
    font-size: 0.9rem;
    color: var(--color-on-surface-muted);
    margin-bottom: 1rem;
}

.poem-card__meta {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
    font-size: 0.8rem;
    color: var(--color-on-surface-muted);
    border-top: 1px solid var(--color-surface-alt);
    padding-top: 0.75rem;
    margin-top: auto;
}

.poem-card__meta-item {
    display: flex;
    align-items: center;
    gap: 0.3rem;
}

/* ==========================================================================
   صفحة الشاعر
   ========================================================================== */

.poet-hero {
    background: var(--color-bg-alt);
    border-bottom: 2px solid var(--color-border);
    padding: 3rem 0;
}

.poet-hero__inner {
    display: flex;
    gap: 2.5rem;
    align-items: flex-start;
}

.poet-hero__image {
    width: 180px;
    height: 180px;
    border-radius: 50%;
    object-fit: cover;
    border: 4px solid var(--color-border);
    flex-shrink: 0;
    box-shadow: var(--shadow-md);
}

.poet-hero__image-placeholder {
    width: 180px;
    height: 180px;
    border-radius: 50%;
    background: var(--color-border);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 4rem;
    color: var(--color-muted);
    flex-shrink: 0;
    border: 4px solid var(--color-bg-alt);
    box-shadow: var(--shadow-md);
}

.poet-hero__content {
    flex: 1;
}

.poet-hero__name {
    font-size: 2.2rem;
    font-weight: 700;
    color: var(--color-heading);
    margin-bottom: 0.5rem;
}

.poet-hero__dates {
    color: var(--color-muted);
    font-size: 0.92rem;
    margin-bottom: 1rem;
}

.poet-hero__nickname {
    font-size: 0.85rem;
    color: var(--color-accent);
    margin-bottom: 0.3rem;
    font-weight: 500;
}

.poet-hero__literary-title {
    font-size: 1rem;
    color: var(--color-accent-dark);
    font-weight: 600;
    margin-bottom: 0.65rem;
}

.poet-hero__meta {
    color: var(--color-muted);
    font-size: 0.92rem;
    line-height: 1.75;
    margin-bottom: 1.25rem;
}

.poet-hero__actions {
    margin-top: 0.25rem;
}

.poet-hero__cta {
    display: inline-flex;
}

/* —— نبذة سريعة —— */

.poet-quick-facts {
    padding: 2.5rem 0;
    border-bottom: 1px solid var(--color-border);
}

.poet-quick-facts__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.85rem 1.5rem;
    margin: 0;
    padding: 1.25rem 1.35rem;
    background: var(--color-surface);
    border: 1px solid var(--color-surface-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    max-width: 720px;
}

.poet-quick-facts__item {
    margin: 0;
    min-width: 0;
}

.poet-quick-facts__term {
    margin: 0 0 0.2rem;
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--color-accent);
    letter-spacing: 0.01em;
}

.poet-quick-facts__value {
    margin: 0;
    font-size: 0.95rem;
    color: var(--color-on-surface);
    line-height: 1.65;
}

.poet-bio {
    padding: 3rem 0;
}

.poet-bio__content {
    max-width: 720px;
}

.poet-bio__content--justify,
.poet-bio__content--justify p,
.poet-bio__content--justify li {
    text-align: justify;
    text-align-last: right;
    text-justify: inter-word;
    line-height: 2;
    hyphens: auto;
    -webkit-hyphens: auto;
}

.poet-bio__content--justify p {
    margin: 0 0 1.1em;
}

.poet-bio__content--justify p:last-child {
    margin-bottom: 0;
}

.poet-bio__placeholder {
    max-width: 720px;
    margin: 0;
    padding: 1.25rem 1.35rem;
    color: var(--color-muted);
    font-style: italic;
    background: var(--color-bg-alt);
    border: 1px dashed var(--color-surface-border);
    border-radius: var(--radius-md);
}

.poet-poem-link {
    padding: 3rem 0 4rem;
    background: var(--color-bg-alt);
    border-top: 1px solid var(--color-border);
}

.poet-poem-link__wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1.15rem;
}

.section-title--center {
    justify-content: center;
    text-align: center;
}

.section-title--center::before {
    display: none;
}

.poet-poem-banner {
    position: relative;
    width: 100%;
    max-width: 820px;
    min-height: clamp(200px, 34vw, 300px);
    border-radius: var(--radius-lg);
    overflow: hidden;
    background: linear-gradient(145deg, var(--color-bg-alt) 0%, var(--color-accent-light) 45%, var(--color-accent) 100%);
    display: flex;
    align-items: flex-end;
    text-align: center;
    box-shadow: var(--shadow-md);
}

.poet-poem-banner--cover {
    background-color: var(--color-header-bg);
    background-size: cover;
    background-position: center;
}

.poet-poem-banner__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        to top,
        rgba(0, 0, 0, 0.88) 0%,
        rgba(0, 0, 0, 0.55) 45%,
        rgba(0, 0, 0, 0.25) 100%
    );
    pointer-events: none;
}

.poet-poem-banner__inner {
    position: relative;
    z-index: 1;
    width: 100%;
    padding: clamp(1.5rem, 4vw, 2.25rem) 1.25rem clamp(1.35rem, 3.5vw, 2rem);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.65rem;
}

.poet-poem-banner__order {
    font-size: 0.78rem;
    letter-spacing: 0.04em;
    color: var(--color-accent);
    margin: 0;
}

.poet-poem-banner--cover .poet-poem-banner__order {
    color: rgba(255, 255, 255, 0.75);
}

.poet-poem-banner__title {
    font-family: var(--font-primary);
    font-size: clamp(1.45rem, 4vw, 2rem);
    font-weight: 700;
    line-height: 1.35;
    color: var(--color-heading);
    margin: 0;
}

.poet-poem-banner--cover .poet-poem-banner__title {
    color: #fff;
    text-shadow: 0 2px 14px rgba(0, 0, 0, 0.45);
}

.poet-poem-banner__meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 0.5rem 1rem;
    font-size: 0.88rem;
    color: var(--color-muted);
}

.poet-poem-banner--cover .poet-poem-banner__meta {
    color: rgba(255, 255, 255, 0.82);
}

.poet-poem-banner__meta-item {
    display: inline-flex;
    align-items: center;
}

.poet-poem-banner__cta {
    margin-top: 0.35rem;
}

.section-title {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--color-heading);
    margin-bottom: 1.5rem;
    padding-bottom: 0.75rem;
    border-bottom: 2px solid var(--color-border);
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.section-title::before {
    content: '';
    width: 4px;
    height: 1.4em;
    background: var(--color-accent);
    border-radius: 2px;
}

/* ==========================================================================
   أدوات مساعدة
   ========================================================================== */

.page-content {
    padding-top: 3rem;
    padding-bottom: 3rem;
}

.empty-state {
    text-align: center;
    padding: 4rem 1rem;
    color: var(--color-muted);
}

.empty-state--lg {
    padding: 5rem 1rem;
}

.empty-state__icon {
    display: block;
    margin: 0 auto 1rem;
    opacity: 0.55;
}

.empty-state__text {
    margin: 0;
}

/* بطاقة شاعر في الأرشيف (legacy) */
.poet-card-mini {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 0.75rem;
}

.poet-card-mini__avatar {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid var(--color-border);
    flex-shrink: 0;
}

.poet-card-mini__avatar--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-border);
    font-size: 1.8rem;
    line-height: 1;
}

.poet-card-mini__title {
    font-size: 1.1rem;
    margin-bottom: 0.2rem;
}

.poet-card-mini__dates {
    font-size: 0.82rem;
}

.poet-card-mini__excerpt {
    font-size: 0.88rem;
    color: var(--color-muted);
    line-height: 1.7;
    margin-top: 0.5rem;
}

.prose {
    line-height: 2;
    color: var(--color-text);
}

.muted-note {
    color: var(--color-muted);
    padding: 2rem 0;
    margin: 0;
}

/* ==========================================================================
   استجابة الهاتف
   ========================================================================== */

@media (max-width: 768px) {
    html { font-size: 16px; }

    .archive-hero__title { font-size: 1.9rem; }

    .poems-grid {
        grid-template-columns: 1fr;
    }

    .poem-cover-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 0.85rem;
    }

    .poet-hero__inner {
        flex-direction: column;
        align-items: center;
        text-align: center;
    }

    .poet-hero__name { font-size: 1.6rem; }

    .poet-quick-facts__grid {
        grid-template-columns: 1fr;
    }

    .btn {
        min-height: var(--btn-min-touch);
    }
}

@media (max-width: 480px) {
    .container { padding-inline: 1rem; }
    .archive-hero { padding: 2.5rem 1rem; }
    .archive-hero__title { font-size: 1.6rem; }

    .poem-cover-grid {
        grid-template-columns: 1fr;
        max-width: 320px;
        margin-inline: auto;
    }
}
