/* ============================================
   AlhunainNew – Complete Site Styles
   Arabic RTL-first · No Red · Brand Colors
   ============================================ */

/* ── CSS Variables ── */
:root {
    /* Brand palette (old site – NO RED) */
    --color-primary: #b8ac93;
    --color-primary-dark: #9e8f72;
    --color-primary-light: #d4ccba;
    --color-secondary: #073c4c;
    --color-accent: #06637b;
    --color-accent-light: #0a8fad;
    --color-nav-bg: #b8ac93;
    --color-body-bg: #ffffff;
    --color-text: #555555;
    --color-text-light: #888888;
    --color-heading: #073c4c;
    --color-dark-section: #073c4c;
    --color-gray-bg: #f7f6f3;
    --color-border: #e8e4dc;
    --color-white: #ffffff;

    --font-arabic: 'Droid Arabic Kufi', 'Tajawal', 'Segoe UI', sans-serif;

    --section-padding: 60px 0;
    --section-padding-sm: 40px 0;

    --shadow-sm: 0 2px 8px rgba(0,0,0,.05);
    --shadow-md: 0 4px 20px rgba(0,0,0,.08);
    --shadow-lg: 0 8px 30px rgba(0,0,0,.12);
    --shadow-hover: 0 10px 40px rgba(7,60,76,.15);

    --transition-fast: .2s ease;
    --transition-base: .3s ease;
    --transition-slow: .5s ease;

    --radius-sm: 6px;
    --radius-md: 10px;
    --radius-lg: 16px;
    --radius-xl: 24px;
}

/* ── Base / Typography ── */
body {
    font-family: var(--font-arabic) !important;
    direction: rtl;
    text-align: right;
    color: var(--color-text);
    background: var(--color-body-bg);
    line-height: 1.8;
}

h1, h2, h3, h4, h5, h6,
.title, .footer-title, .nav, .navbar-nav {
    font-family: var(--font-arabic) !important;
    color: var(--color-heading);
}

a {
    color: var(--color-accent);
    transition: color var(--transition-fast);
    text-decoration: none;
}
a:hover { color: var(--color-accent-light); text-decoration: none; }

/* ── Section Utilities ── */
.section-full { padding: var(--section-padding); }
.content-inner { padding: 40px 0; }
.content-inner-1 { padding: 50px 0 30px; }
.bg-gray { background-color: var(--color-gray-bg) !important; }
.bg-brand { background-color: var(--color-secondary) !important; }
.bg-brand-light { background-color: var(--color-primary) !important; }

.section-head {
    margin-bottom: 40px;
}
.section-head .title {
    font-size: 1.7rem;
    font-weight: 700;
    color: var(--color-heading);
    position: relative;
    display: inline-block;
    padding-bottom: 12px;
}
.section-head .title::after {
    content: '';
    position: absolute;
    bottom: 0;
    right: 0;
    width: 60px;
    height: 3px;
    background: var(--color-primary);
    border-radius: 2px;
}
.text-center .section-head .title::after,
.section-head.text-center .title::after {
    right: 50%;
    transform: translateX(50%);
}

/* ── Buttons ── */
.site-button {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 10px 24px;
    font-family: var(--font-arabic) !important;
    font-size: .9rem;
    font-weight: 600;
    border-radius: var(--radius-sm);
    border: 2px solid var(--color-accent);
    background: var(--color-accent);
    color: #fff !important;
    cursor: pointer;
    transition: all var(--transition-base);
    text-decoration: none !important;
    line-height: 1.5;
}
.site-button:hover {
    background: var(--color-accent-light);
    border-color: var(--color-accent-light);
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
    color: #fff !important;
}
.site-button.outline {
    background: transparent;
    color: var(--color-accent) !important;
}
.site-button.outline:hover {
    background: var(--color-accent);
    color: #fff !important;
}
.site-button.white {
    background: #fff;
    border-color: #fff;
    color: var(--color-secondary) !important;
}
.site-button.white:hover {
    background: transparent;
    color: #fff !important;
    border-color: #fff;
}
.site-button.btn-sm, .site-button.sm {
    padding: 6px 16px;
    font-size: .82rem;
}
.site-button svg, .site-button i {
    font-size: 1rem;
    flex-shrink: 0;
}

/* ── SVG Icon Base ── */
.icon-svg {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.icon-svg svg {
    width: 1em;
    height: 1em;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

/* ── Header Image Area ── */
.headerimg {
    /* background: var(--color-gray-bg); */
    text-align: center;
    padding: 18px 10px 14px;
    font-family: var(--font-arabic);
    color: var(--color-heading);
    border-bottom: 3px solid var(--color-primary);
}
.headerimg-title {
    display: block;
    font-size: .85rem;
    color: var(--color-text-light);
    margin-bottom: 4px;
}
.headerimg .logo-dark img {
    width: 280px !important;
    max-width: 100%;
}
.headerimg label {
    font-size: .78rem;
    display: block;
    color: var(--color-text-light);
    margin-top: 2px;
}

/* ── Navigation ── */
.main-bar {
    background-color: var(--color-nav-bg) !important;
}
.header-nav .nav > li > a {
    font-family: var(--font-arabic) !important;
    font-size: .88rem;
    font-weight: 600;
    transition: color var(--transition-fast), background var(--transition-fast);
}
.header-nav .nav > li > a:hover,
.header-nav .nav > li.active > a {
    background: rgba(255,255,255,.15);
}

.search-link {
    color: #fff !important;
    text-decoration: none;
    transition: opacity var(--transition-fast);
    display: flex;
    align-items: center;
}
.search-link:hover { opacity: .75; }

/* ── Hero Slider (pure CSS version, kept as fallback alongside revslider) ── */
.hero-slider-section {
    position: relative;
    overflow: hidden;
}

/* ── Hub Quick-Access Cards ── */
.hub-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 28px 15px 22px;
    text-align: center;
    transition: all var(--transition-base);
    text-decoration: none !important;
    color: var(--color-heading);
    box-shadow: var(--shadow-sm);
    min-height: 140px;
}
.hub-card:hover {
    border-color: var(--color-primary);
    box-shadow: var(--shadow-hover);
    transform: translateY(-6px);
    color: var(--color-heading);
}
.hub-card-inner {
    direction: rtl;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
}
.hub-card-icon {
    width: 52px;
    height: 52px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-gray-bg);
    border-radius: 50%;
    color: var(--color-accent);
    font-size: 1.4rem;
    transition: all var(--transition-base);
}
.hub-card:hover .hub-card-icon {
    background: var(--color-accent);
    color: #fff;
}
.hub-card h5 {
    margin: 0;
    font-size: .95rem;
    font-weight: 700;
}

/* ── Biography CTA ── */
.bio-cta {
    background: linear-gradient(135deg, var(--color-secondary) 0%, var(--color-accent) 100%);
    padding: 28px 0;
}
.bio-cta h4 {
    color: #fff;
    margin: 0;
    font-size: 1.15rem;
    font-weight: 600;
}

/* ── Content Cards ── */
.content-card {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    overflow: hidden;
    transition: all var(--transition-base);
    height: 100%;
    display: flex;
    flex-direction: column;
}
.content-card:hover {
    box-shadow: var(--shadow-hover);
    transform: translateY(-4px);
}
.content-card .card-body {
    padding: 20px;
    flex: 1;
    display: flex;
    flex-direction: column;
}
.content-card .card-title {
    font-size: 1rem;
    font-weight: 700;
    color: var(--color-heading);
    margin-bottom: 8px;
    line-height: 1.6;
}
.content-card .card-title a { color: var(--color-heading); }
.content-card .card-title a:hover { color: var(--color-accent); }
.content-card .card-text {
    color: var(--color-text-light);
    font-size: .85rem;
    line-height: 1.7;
    flex: 1;
}
.content-card .card-meta {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: .78rem;
    color: var(--color-text-light);
    margin-top: auto;
    padding-top: 12px;
    border-top: 1px solid var(--color-border);
}

/* ── Video Card ── */
.video-card {
    position: relative;
    border-radius: var(--radius-md);
    overflow: hidden;
    background: var(--color-secondary);
    transition: all var(--transition-base);
    height: 100%;
}
.video-card:hover {
    box-shadow: var(--shadow-hover);
    transform: translateY(-4px);
}
.video-card .video-thumb {
    position: relative;
    padding-top: 56.25%;
    overflow: hidden;
    background: #000;
}
.video-card .video-thumb img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-slow);
}
.video-card:hover .video-thumb img {
    transform: scale(1.05);
}
.video-card .video-play-icon {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 56px;
    height: 56px;
    background: rgba(255,255,255,.9);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-accent);
    font-size: 1.4rem;
    transition: all var(--transition-base);
    z-index: 2;
}
.video-card:hover .video-play-icon {
    background: var(--color-accent);
    color: #fff;
    transform: translate(-50%, -50%) scale(1.1);
}
.video-card .card-body {
    padding: 16px;
}
.video-card .card-title {
    color: #fff;
    font-size: .92rem;
    margin: 0;
    font-weight: 600;
}
.video-card .card-title a { color: #fff; }

/* ── Book Card ── */
.book-card {
    text-align: center;
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 20px 15px;
    transition: all var(--transition-base);
    height: 100%;
}
.book-card:hover {
    box-shadow: var(--shadow-hover);
    transform: translateY(-4px);
}
.book-card img {
    max-height: 180px;
    width: auto;
    margin-bottom: 12px;
    border-radius: var(--radius-sm);
}
.book-card h6 {
    font-size: .88rem;
    font-weight: 700;
    color: var(--color-heading);
    margin-bottom: 10px;
}
.book-card h6 a { color: var(--color-heading); }
.book-card h6 a:hover { color: var(--color-accent); }

/* ── Internal Page Header (Compact) ── */
.page-header-compact {
    background: linear-gradient(135deg, var(--color-secondary) 0%, var(--color-accent) 100%);
    padding: 20px 0;
}
.page-header-compact h1 {
    color: #fff;
    font-size: 1.3rem;
    font-weight: 700;
    margin: 0 0 6px;
}

/* ── Breadcrumb (Arabic, no "ood") ── */
.breadcrumb-clean {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    font-size: .82rem;
    direction: rtl;
}
.breadcrumb-clean li {
    display: flex;
    align-items: center;
    gap: 4px;
}
.breadcrumb-clean li + li::before {
    content: '\203A';
    color: rgba(255,255,255,.5);
    margin: 0 2px;
}
.breadcrumb-clean li a {
    color: rgba(255,255,255,.85);
    text-decoration: none;
    transition: color var(--transition-fast);
}
.breadcrumb-clean li a:hover { color: #fff; }
.breadcrumb-clean li.active {
    color: rgba(255,255,255,.6);
}

/* ── Internal Layout: Sidebar RIGHT (RTL natural) ── */
.internal-layout {
    padding: 30px 0;
}

/* ── Sidebar Widget ── */
.sidebar-widget-card {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 20px;
    margin-bottom: 20px;
}
.sidebar-widget-card .widget-title {
    font-size: .95rem;
    font-weight: 700;
    color: var(--color-heading);
    padding-bottom: 10px;
    margin-bottom: 14px;
    border-bottom: 2px solid var(--color-primary);
    display: flex;
    align-items: center;
    gap: 6px;
}
.sidebar-hub-list {
    list-style: none;
    padding: 0;
    margin: 0;
}
.sidebar-hub-list li {
    margin-bottom: 2px;
}
.sidebar-hub-list li a {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 12px;
    color: var(--color-heading);
    text-decoration: none;
    border-radius: var(--radius-sm);
    font-size: .88rem;
    transition: all var(--transition-fast);
}
.sidebar-hub-list li a:hover,
.sidebar-hub-list li a.active {
    background: var(--color-gray-bg);
    color: var(--color-accent);
    padding-right: 16px;
}
.sidebar-hub-list li a svg {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    color: var(--color-primary-dark);
    transition: color var(--transition-fast);
}
.sidebar-hub-list li a:hover svg,
.sidebar-hub-list li a.active svg {
    color: var(--color-accent);
}

/* ── Filters ── */
.filter-container {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 18px 20px;
    margin-bottom: 24px;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
}
.filter-container .filter-label {
    font-weight: 600;
    font-size: .85rem;
    color: var(--color-heading);
    margin-left: 10px;
}
.filter-btn {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 6px 16px;
    font-size: .82rem;
    font-family: var(--font-arabic);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    background: #fff;
    color: var(--color-text);
    cursor: pointer;
    transition: all var(--transition-fast);
}
.filter-btn:hover {
    border-color: var(--color-primary);
    color: var(--color-heading);
}
.filter-btn.active {
    background: var(--color-accent) !important;
    color: #fff !important;
    border-color: var(--color-accent) !important;
}

/* ── Audio Table ── */
.audio-table {
    width: 100%;
    overflow-x: auto;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: #fff;
}
.audio-table table {
    width: 100%;
    border-collapse: collapse;
    margin: 0;
}
.audio-table thead th {
    background: var(--color-secondary);
    color: #fff;
    padding: 14px 16px;
    font-size: .85rem;
    font-weight: 600;
    white-space: nowrap;
}
.audio-table tbody td {
    padding: 12px 16px;
    border-bottom: 1px solid var(--color-border);
    vertical-align: middle;
    font-size: .88rem;
}
.audio-table tbody tr {
    transition: background var(--transition-fast);
}
.audio-table tbody tr:hover {
    background: var(--color-gray-bg);
}
.audio-table tbody tr:last-child td { border-bottom: none; }

/* Action Icons */
.action-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--color-gray-bg);
    color: var(--color-accent);
    transition: all var(--transition-fast);
    border: none;
    cursor: pointer;
    text-decoration: none !important;
}
.action-icon:hover {
    background: var(--color-accent);
    color: #fff;
    transform: scale(1.1);
}
.action-icon svg {
    width: 18px;
    height: 18px;
}

/* ── Item List Cards (Hub listings) ── */
.item-list-card {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 20px;
    margin-bottom: 16px;
    transition: all var(--transition-base);
    display: flex;
    gap: 16px;
    align-items: flex-start;
}
.item-list-card:hover {
    box-shadow: var(--shadow-md);
    border-color: var(--color-primary-light);
}
.item-list-card .item-icon {
    flex-shrink: 0;
    width: 44px;
    height: 44px;
    background: var(--color-gray-bg);
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-accent);
}
.item-list-card .item-icon svg {
    width: 22px;
    height: 22px;
}
.item-list-card .item-body { flex: 1; min-width: 0; }
.item-list-card .item-body h5 {
    font-size: 1rem;
    font-weight: 700;
    margin-bottom: 6px;
}
.item-list-card .item-body h5 a { color: var(--color-heading); }
.item-list-card .item-body h5 a:hover { color: var(--color-accent); }
.item-list-card .item-body p {
    color: var(--color-text-light);
    font-size: .85rem;
    margin-bottom: 8px;
    line-height: 1.7;
}
.item-list-card .item-meta {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: .78rem;
    color: var(--color-text-light);
}
.item-list-card .item-meta .badge {
    background: var(--color-gray-bg);
    color: var(--color-text);
    font-weight: 600;
    padding: 3px 10px;
    border-radius: var(--radius-xl);
    font-size: .75rem;
}

/* ── Article Detail ── */
.article-details {
    line-height: 2;
}
.article-details img {
    max-width: 100%;
    height: auto;
    margin-bottom: 15px;
    border-radius: var(--radius-sm);
}
.article-details .entry-content {
    font-size: .95rem;
    line-height: 2.1;
    color: var(--color-text);
}

/* ── Search Page ── */
.search-page .form-control {
    border-radius: var(--radius-sm);
    border: 2px solid var(--color-border);
    padding: 12px 16px;
    font-family: var(--font-arabic);
    font-size: .95rem;
    transition: border-color var(--transition-fast);
}
.search-page .form-control:focus {
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px rgba(6,99,123,.12);
    outline: none;
}

/* ── Pagination ── */
.pagination .page-link {
    font-family: var(--font-arabic);
    color: var(--color-heading);
    border-color: var(--color-border);
    transition: all var(--transition-fast);
}
.pagination .page-item.active .page-link {
    background-color: var(--color-accent);
    border-color: var(--color-accent);
    color: #fff;
}
.pagination .page-link:hover {
    background-color: var(--color-gray-bg);
    color: var(--color-accent);
}

/* ── Footer ── */
.site-footer {
    background: var(--color-secondary);
    color: rgba(255,255,255,.85);
}
.site-footer .footer-top {
    padding: 50px 0 30px;
}
.site-footer h5.footer-title {
    color: #fff !important;
    font-size: 1rem;
    font-weight: 700;
    margin-bottom: 18px;
    position: relative;
    padding-bottom: 10px;
}
.site-footer h5.footer-title::after {
    content: '';
    position: absolute;
    bottom: 0;
    right: 0;
    width: 40px;
    height: 2px;
    background: var(--color-primary);
}
.site-footer ul { list-style: none; padding: 0; margin: 0; }
.site-footer ul li { padding: 0; border: none; }
.site-footer ul li a {
    color: rgba(255,255,255,.7);
    transition: color var(--transition-fast), padding var(--transition-fast);
    font-size: .88rem;
    display: block;
    padding: 5px 0;
    text-decoration: none;
}
.site-footer ul li a:hover {
    color: var(--color-primary-light);
    padding-right: 6px;
}
.site-footer .widget_getintuch ul li {
    display: flex;
    gap: 10px;
    margin-bottom: 12px;
    color: rgba(255,255,255,.7);
    font-size: .88rem;
}
.site-footer .widget_getintuch ul li i {
    color: var(--color-primary);
    margin-top: 3px;
}
.footer-bottom {
    border-top: 1px solid rgba(255,255,255,.1);
    padding: 16px 0;
    font-size: .82rem;
    color: rgba(255,255,255,.5);
}

/* ── Scroll-to-top ── */
.scroltop {
    background: var(--color-accent) !important;
    border-color: var(--color-accent) !important;
}

/* ── Featured Banner (Books) ── */
.featured-banner {
    background: linear-gradient(135deg, var(--color-secondary) 0%, var(--color-accent) 100%);
    border-radius: var(--radius-lg);
    padding: 30px;
    color: #fff;
    display: flex;
    align-items: center;
    gap: 30px;
    flex-wrap: wrap;
}
.featured-banner h3 {
    color: #fff;
    margin-bottom: 8px;
}
.featured-banner p {
    color: rgba(255,255,255,.8);
    margin-bottom: 16px;
}

/* ── Entrance Animations ── */
.animate-on-scroll {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity .6s ease, transform .6s ease;
}
.animate-on-scroll.is-visible {
    opacity: 1;
    transform: translateY(0);
}
.stagger-children .animate-on-scroll:nth-child(1) { transition-delay: 0s; }
.stagger-children .animate-on-scroll:nth-child(2) { transition-delay: .08s; }
.stagger-children .animate-on-scroll:nth-child(3) { transition-delay: .16s; }
.stagger-children .animate-on-scroll:nth-child(4) { transition-delay: .24s; }
.stagger-children .animate-on-scroll:nth-child(5) { transition-delay: .32s; }
.stagger-children .animate-on-scroll:nth-child(6) { transition-delay: .4s; }
.stagger-children .animate-on-scroll:nth-child(7) { transition-delay: .48s; }
.stagger-children .animate-on-scroll:nth-child(8) { transition-delay: .56s; }
.stagger-children .animate-on-scroll:nth-child(9) { transition-delay: .64s; }

/* ── Reduced Motion ── */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
    .animate-on-scroll {
        opacity: 1 !important;
        transform: none !important;
    }
}

/* ── Override theme red → teal ── */
.bg-primary { background-color: var(--color-accent) !important; }
.text-primary { color: var(--color-accent) !important; }
.btn-primary { background-color: var(--color-accent) !important; border-color: var(--color-accent) !important; }
.btn-primary:hover { background-color: var(--color-accent-light) !important; border-color: var(--color-accent-light) !important; }
.btn-outline-primary { color: var(--color-accent) !important; border-color: var(--color-accent) !important; }
.btn-outline-primary:hover { background-color: var(--color-accent) !important; color: #fff !important; }
.badge-primary { background-color: var(--color-accent) !important; }
.badge-secondary { background-color: var(--color-gray-bg) !important; color: var(--color-text) !important; }
.border-primary { border-color: var(--color-accent) !important; }

/* ── Modal ── */
.modal-header {
    background: var(--color-secondary);
    color: #fff;
    border-bottom: none;
}
.modal-header .modal-title {
    font-family: var(--font-arabic);
    color: #fff;
}
.modal-header .close {
    color: #fff;
    text-shadow: none;
}

/* ── Stats Section (الموقع في أرقام) ── */
.stats-section {
    background: var(--color-secondary);
    padding: var(--section-padding);
    position: relative;
    overflow: hidden;
}
.stats-section::before {
    content: '';
    position: absolute; inset: 0;
    background: 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='%23ffffff' fill-opacity='0.03'%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");
    pointer-events: none;
}
.stat-card {
    background: rgba(255,255,255,.07);
    border: 1px solid rgba(255,255,255,.1);
    border-radius: var(--radius-md);
    padding: 22px 14px;
    text-align: center;
    transition: var(--transition-base);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
}
.stat-card:hover {
    background: rgba(255,255,255,.14);
    transform: translateY(-4px);
    box-shadow: 0 8px 30px rgba(0,0,0,.2);
}
.stat-icon {
    font-size: 2.4rem;
    line-height: 1;
    filter: grayscale(0);
}
.stat-number {
    font-size: clamp(1.6rem, 2.5vw, 2rem);
    font-weight: 700;
    color: #fff;
    letter-spacing: -0.02em;
    font-feature-settings: 'tnum';
}
.stat-label {
    font-size: clamp(.75rem, 1.3vw, .88rem);
    color: rgba(255,255,255,.65);
    font-weight: 500;
}

/* ── Slider Responsive Typography ── */
.slider-title {
    font-size: clamp(1.5rem, 4vw, 3rem) !important;
    line-height: 1.3 !important;
    text-shadow: 0 2px 12px rgba(0,0,0,.4);
}
.slider-subtitle {
    font-size: clamp(.875rem, 2vw, 1.25rem) !important;
    line-height: 1.5 !important;
    text-shadow: 0 1px 8px rgba(0,0,0,.3);
}

/* ── Menu Centering ── */
.header-nav.justify-content-center .nav.navbar-nav {
    display: flex;
    justify-content: center;
    width: 100%;
}

/* ── Footer Social Links ── */
.footer-social {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}
.footer-social .social-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background: rgba(255,255,255,.1);
    color: rgba(255,255,255,.7);
    transition: var(--transition-base);
    border: 1px solid rgba(255,255,255,.15);
}
.footer-social .social-icon:hover {
    background: var(--color-accent);
    color: #fff;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(6,99,123,.3);
}

/* ── Footer Visitor Counter ── */
.visitor-counter {
    color: rgba(255,255,255,.7);
    font-size: .85rem;
}
.visitor-counter strong {
    color: var(--color-primary-light);
}

/* ── Responsive ── */
@media (max-width: 991px) {
    .featured-banner { flex-direction: column; text-align: center; }
}

@media (max-width: 767px) {
    .headerimg .logo-dark img { width: 200px !important; }
    .section-full { padding: 36px 0; }
    .hub-card { padding: 20px 12px; min-height: auto; }
    .item-list-card { flex-direction: column; }
    .filter-container { padding: 14px; }
    .page-header-compact h1 { font-size: 1.1rem; }
    .stat-card { padding: 16px 10px; }
    .stat-icon { font-size: 2rem; }
}

@media (max-width: 576px) {
    .filter-btn { padding: 5px 12px; font-size: .78rem; }
    .audio-table thead th,
    .audio-table tbody td { padding: 10px 12px; font-size: .82rem; }
    .stat-card { padding: 14px 8px; }
    .stat-number { font-size: 1.3rem; }
    .stat-icon { font-size: 1.6rem; }
}

/* ══════════════════════════════════════════════
   Hub Controls – Toolbar, Pagination, Views
   ══════════════════════════════════════════════ */

/* ── Toolbar ── */
.hub-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 10px;
    padding: 10px 16px;
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    margin-bottom: 16px;
}
.hub-toolbar-start, .hub-toolbar-end { display: flex; align-items: center; gap: 10px; }
.hub-count { font-size: .82rem; color: var(--color-text-light); }
.pp-label {
    font-size: .82rem; color: var(--color-text); display: flex;
    align-items: center; gap: 6px; margin: 0; white-space: nowrap;
}
.pp-select {
    padding: 4px 8px; border: 1px solid var(--color-border);
    border-radius: var(--radius-sm); font-family: var(--font-arabic);
    font-size: .82rem; background: #fff; cursor: pointer;
}
.view-toggle {
    display: inline-flex; border: 1px solid var(--color-border);
    border-radius: var(--radius-sm); overflow: hidden;
}
.view-toggle-btn {
    padding: 6px 10px; background: #fff; border: none;
    cursor: pointer; color: var(--color-text-light);
    transition: all var(--transition-fast); display: inline-flex; align-items: center;
}
.view-toggle-btn + .view-toggle-btn { border-right: 1px solid var(--color-border); }
.view-toggle-btn.active { background: var(--color-accent); color: #fff; }
.view-toggle-btn svg { width: 16px; height: 16px; }

/* ── Hub Table Header ── */
.hub-table-header {
    display: grid;
    grid-template-columns: 1fr 120px 80px 80px;
    background: var(--color-secondary);
    color: #fff;
    padding: 12px 16px;
    font-size: .85rem;
    font-weight: 600;
    border-radius: var(--radius-md) var(--radius-md) 0 0;
    gap: 12px;
}
.hub-table-header span:nth-child(3),
.hub-table-header span:nth-child(4) { text-align: center; }

/* ══ AUDIO HUB: Table View ══ */
.hub-audio.view-table .hub-items-wrap {
    border: 1px solid var(--color-border);
    border-top: none;
    border-radius: 0 0 var(--radius-md) var(--radius-md);
    background: #fff;
}
.hub-audio.view-table .hub-item {
    display: grid;
    grid-template-columns: 1fr 120px 80px 80px;
    padding: 11px 16px;
    border-bottom: 1px solid var(--color-border);
    align-items: center;
    gap: 12px;
    transition: background var(--transition-fast);
}
.hub-audio.view-table .hub-item:last-child { border-bottom: none; }
.hub-audio.view-table .hub-item:hover { background: var(--color-gray-bg); }
.hub-audio.view-table .hi-title a { color: var(--color-heading); font-weight: 600; font-size: .88rem; }
.hub-audio.view-table .hi-title a:hover { color: var(--color-accent); }
.hub-audio.view-table .hi-cat { font-size: .82rem; color: var(--color-text-light); }
.hub-audio.view-table .hi-listen,
.hub-audio.view-table .hi-download { text-align: center; }
.hub-audio.view-table .hi-icon { display: none; }

/* ══ AUDIO HUB: Cards View ══ */
.hub-audio.view-cards .hub-table-header { display: none !important; }
.hub-audio.view-cards .hub-items-wrap {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 16px;
}
.hub-audio.view-cards .hub-item {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 20px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    transition: all var(--transition-base);
}
.hub-audio.view-cards .hub-item:hover {
    box-shadow: var(--shadow-md);
    border-color: var(--color-primary-light);
}
.hub-audio.view-cards .hi-icon {
    width: 44px; height: 44px;
    background: var(--color-gray-bg);
    border-radius: var(--radius-sm);
    display: flex; align-items: center; justify-content: center;
    color: var(--color-accent); flex-shrink: 0;
}
.hub-audio.view-cards .hi-title a {
    color: var(--color-heading); font-size: 1rem; font-weight: 700;
}
.hub-audio.view-cards .hi-title a:hover { color: var(--color-accent); }
.hub-audio.view-cards .hi-cat {
    display: inline-block; background: var(--color-gray-bg);
    padding: 2px 10px; border-radius: var(--radius-xl); font-size: .78rem;
    color: var(--color-text); width: fit-content;
}
.hub-audio.view-cards .hi-listen,
.hub-audio.view-cards .hi-download { display: inline-flex; }
.hub-audio.view-cards .hub-item .hi-actions-row {
    display: flex; gap: 8px; margin-top: auto;
}

/* ══ TEXT HUB (Articles, Fatwas, Benefits, LessonsText): List View ══ */
.hub-text.view-list .hub-items-wrap {
    display: flex; flex-direction: column; gap: 16px;
}
.hub-text.view-list .hub-item {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 20px;
    display: flex;
    gap: 16px;
    align-items: flex-start;
    transition: all var(--transition-base);
}
.hub-text.view-list .hub-item:hover {
    box-shadow: var(--shadow-md); border-color: var(--color-primary-light);
}
.hub-text.view-list .hi-icon {
    flex-shrink: 0; width: 44px; height: 44px;
    background: var(--color-gray-bg); border-radius: var(--radius-sm);
    display: flex; align-items: center; justify-content: center;
    color: var(--color-accent);
}
.hub-text.view-list .hi-icon svg { width: 22px; height: 22px; }
.hub-text.view-list .hi-body { flex: 1; min-width: 0; }
.hub-text.view-list .hi-title { margin-bottom: 4px; }
.hub-text.view-list .hi-title a { color: var(--color-heading); font-size: 1rem; font-weight: 700; }
.hub-text.view-list .hi-title a:hover { color: var(--color-accent); }
.hub-text.view-list .hi-excerpt {
    color: var(--color-text-light); font-size: .85rem; line-height: 1.7; margin-top: 4px;
}
.hub-text.view-list .hi-meta {
    display: flex; align-items: center; gap: 12px; margin-top: 8px;
    font-size: .78rem; color: var(--color-text-light);
}
.hub-text.view-list .hi-meta svg { width: 14px; height: 14px; flex-shrink: 0; }
.hub-text.view-list .hi-cover { display: none; }

/* ══ TEXT HUB: Cards View ══ */
.hub-text.view-cards .hub-items-wrap {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 16px;
}
.hub-text.view-cards .hub-item {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 0;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    transition: all var(--transition-base);
}
.hub-text.view-cards .hub-item:hover {
    box-shadow: var(--shadow-md); border-color: var(--color-primary-light);
    transform: translateY(-2px);
}
.hub-text.view-cards .hi-icon { display: none; }
.hub-text.view-cards .hi-body { padding: 16px; flex: 1; display: flex; flex-direction: column; }
.hub-text.view-cards .hi-title a { color: var(--color-heading); font-size: .95rem; font-weight: 700; }
.hub-text.view-cards .hi-title a:hover { color: var(--color-accent); }
.hub-text.view-cards .hi-excerpt {
    color: var(--color-text-light); font-size: .82rem; line-height: 1.7; margin-top: 6px;
    display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden;
}
.hub-text.view-cards .hi-meta {
    display: flex; align-items: center; gap: 10px; margin-top: auto; padding-top: 10px;
    font-size: .78rem; color: var(--color-text-light);
}
.hub-text.view-cards .hi-meta svg { width: 14px; height: 14px; }
.hub-text.view-cards .hi-cover { display: none; }

/* ══ GRID HUB (Books, Research): Cards View ══ */
.hub-grid.view-cards .hub-items-wrap {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 20px;
}
.hub-grid.view-cards .hub-item {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 16px;
    text-align: center;
    transition: all var(--transition-base);
}
.hub-grid.view-cards .hub-item:hover {
    box-shadow: var(--shadow-md); transform: translateY(-3px);
}
.hub-grid.view-cards .hi-cover img {
    width: 750%; height: 126px; object-fit: cover;
    border-radius: var(--radius-sm); margin-bottom: 12px;
}
.hub-grid.view-cards .hi-title { margin-bottom: 8px; }
.hub-grid.view-cards .hi-title a { color: var(--color-heading); font-size: .9rem; font-weight: 700; }
.hub-grid.view-cards .hi-title a:hover { color: var(--color-accent); }

/* ══ GRID HUB: List View ══ */
.hub-grid.view-list .hub-items-wrap {
    display: flex; flex-direction: column; gap: 12px;
}
.hub-grid.view-list .hub-item {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 12px 16px;
    display: flex;
    gap: 16px;
    align-items: center;
    transition: all var(--transition-base);
}
.hub-grid.view-list .hub-item:hover { box-shadow: var(--shadow-md); }
.hub-grid.view-list .hi-cover img {
    width: 60px; height: 80px; object-fit: cover; border-radius: var(--radius-sm);
}
.hub-grid.view-list .hi-body { flex: 1; }
.hub-grid.view-list .hi-title a { color: var(--color-heading); font-weight: 600; font-size: .9rem; }
.hub-grid.view-list .hi-title a:hover { color: var(--color-accent); }

/* ══ VIDEO HUB: Cards View ══ */
.hub-video.view-cards .hub-items-wrap {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 20px;
}
.hub-video.view-cards .hub-item { transition: all var(--transition-base); }

/* ══ VIDEO HUB: List View ══ */
.hub-video.view-list .hub-items-wrap {
    display: flex; flex-direction: column; gap: 12px;
}
.hub-video.view-list .hub-item .video-card {
    display: flex; flex-direction: row; gap: 16px; background: var(--color-secondary);
}
.hub-video.view-list .hub-item .video-thumb {
    width: 180px; flex-shrink: 0; height: 110px;
}
.hub-video.view-list .hub-item .card-body { padding: 12px 16px; }

/* ══════════════════════════════════════
   Sticky Audio Player Bar
   ══════════════════════════════════════ */
#audioPlayerBar {
    position: fixed;
    bottom: 0; left: 0; right: 0;
    background: var(--color-secondary);
    color: #fff;
    padding: 10px 20px;
    display: flex;
    align-items: center;
    gap: 16px;
    z-index: 10000;
    transform: translateY(100%);
    transition: transform .3s ease;
    box-shadow: 0 -4px 20px rgba(0,0,0,.25);
}
#audioPlayerBar.active { transform: translateY(0); }
.apb-title {
    font-weight: 600; font-size: .9rem;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    max-width: 250px; flex-shrink: 0;
}
#audioPlayerBar audio {
    flex: 1; height: 36px; min-width: 200px;
}
.apb-close {
    background: none; border: none; color: rgba(255,255,255,.7);
    cursor: pointer; padding: 6px; font-size: 1.4rem; line-height: 1;
    transition: color .2s; flex-shrink: 0;
}
.apb-close:hover { color: #fff; }

/* ══════════════════════════════════════
   Responsive – Hub Controls
   ══════════════════════════════════════ */
@media (max-width: 991px) {
    .hub-audio.view-table .hub-table-header,
    .hub-audio.view-table .hub-item {
        grid-template-columns: 1fr 80px 60px 60px;
    }
}
@media (max-width: 767px) {
    .hub-toolbar { padding: 8px 12px; }
    .hub-text.view-list .hub-item { flex-direction: column; }
    .hub-text.view-list .hi-icon { display: none; }
    .hub-grid.view-cards .hub-items-wrap {
        grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 12px;
    }
    .hub-grid.view-cards .hi-cover img { height: 180px; }
    .hub-video.view-list .hub-item .video-thumb { width: 120px; height: 80px; }

    #audioPlayerBar { flex-wrap: wrap; padding: 8px 12px; gap: 8px; }
    .apb-title { max-width: 100%; flex-basis: calc(100% - 40px); order: 1; font-size: .82rem; }
    #audioPlayerBar audio { order: 2; flex-basis: 100%; min-width: 0; height: 32px; }
    .apb-close { order: 1; }

    .hub-audio.view-table .hub-table-header { display: none !important; }
    .hub-audio.view-table .hub-item {
        display: flex; flex-direction: column; gap: 8px;
        padding: 14px; border-bottom: 1px solid var(--color-border);
    }
    .hub-audio.view-table .hub-items-wrap {
        border: 1px solid var(--color-border); border-radius: var(--radius-md); background: #fff;
    }
    .hub-audio.view-table .hi-listen,
    .hub-audio.view-table .hi-download { text-align: right; display: inline-flex; }
}
@media (max-width: 576px) {
    .hub-audio.view-cards .hub-items-wrap { grid-template-columns: 1fr; }
    .hub-text.view-cards .hub-items-wrap { grid-template-columns: 1fr; }
    .hub-video.view-cards .hub-items-wrap { grid-template-columns: 1fr; }
    .hub-toolbar-end { flex-wrap: wrap; }
    .view-toggle-btn { padding: 5px 8px; }
}

/* ══════════════════════════════════════
   Star Rating Widget
   ══════════════════════════════════════ */
.star-rating-widget {
    user-select: none;
}
.rating-star {
    color: var(--color-border);
    font-size: 1.8rem;
    transition: color .15s, transform .15s;
    line-height: 1;
}
.rating-star.filled {
    color: #f5a623;
}
.rating-star.hover {
    color: #f5c518;
    transform: scale(1.15);
}
.rating-star[style*="cursor: pointer"]:hover {
    transform: scale(1.2);
}

/* ══════════════════════════════════════
   Survey Components
   ══════════════════════════════════════ */
.survey-card:hover {
    box-shadow: var(--shadow-hover);
    transform: translateY(-2px);
}
.survey-tab.active {
    color: var(--color-accent) !important;
    border-bottom-color: var(--color-accent) !important;
    font-weight: 600;
}
.survey-tab:hover {
    color: var(--color-heading);
}
.survey-question {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 20px;
    margin-bottom: 16px;
    transition: all var(--transition-base);
}
.survey-option:hover {
    border-color: var(--color-primary) !important;
    background: var(--color-gray-bg) !important;
}
.surveys-grid .survey-card {
    display: flex;
    flex-direction: column;
}

/* Survey icon in header */
.survey-link {
    color: var(--color-heading);
    display: inline-flex;
    align-items: center;
    transition: color var(--transition-fast);
}
.survey-link:hover {
    color: var(--color-accent);
}

@media (max-width: 576px) {
    .surveys-grid {
        grid-template-columns: 1fr !important;
    }
    .survey-question {
        padding: 14px;
    }
}
