/* ============================================================
   Shared Layout Styles — Header, Navigation, Side Menu, Marquee
   ============================================================ */

/* ====== شريط أخبار متحرك (Marquee) ====== */
@keyframes marquee-left {
    0% {
        transform: translateX(-38%);
    }

    100% {
        transform: translateX(100%);
    }
}

.animate-marquee-left {
    display: inline-block;
    white-space: nowrap;
    animation: marquee-left 40s linear infinite;
}

/* ====== روابط التنقل ====== */
.nav-link {
    position: relative;
    padding-bottom: 2px;
    display: inline-block;
}

.nav-link.is-active {
    border-bottom: 2px solid #0d2321;
}

.nav-link.active::after {
    content: "";
    position: absolute;
    bottom: -4px;
    left: 0;
    right: 0;
    height: 2px;
    background-color: #fff;
}

/* ====== القائمة الجانبية (Side Menu) ====== */
.side-menu {
    position: fixed;
    top: 0;
    right: -300px;
    width: 300px;
    max-width: 86vw;
    height: 100vh;
    background: #fff;
    z-index: 1000;
    padding: 20px;
    overflow-y: auto;
    box-shadow: -4px 0 16px rgba(0, 0, 0, .12);
    transition: right .3s ease;
}

.side-menu.active {
    right: 0;
}

/* ====== أنماط التنقل الرسبونسف ====== */
@media (max-width: 1299px) {

    .desktop-nav,
    .desktop-login {
        display: none !important;
    }

    #menuToggle {
        display: block !important;
    }
}

@media (min-width: 1300px) {

    .desktop-nav,
    .desktop-login {
        display: flex !important;
    }

    #menuToggle {
        display: none !important;
    }
}

.logo {
    display: block !important;
}

/* ====== تحسين تموضع النافبار في الشاشات الصغيرة ====== */
@media (max-width: 767px) {
    nav.absolute {
        top: 1.5rem !important;
    }
}

/* ====== ماركيه (نسخة قديمة للتوافق) ====== */
@keyframes marquee {
    100% {
        transform: translateX(100%);
    }

    0% {
        transform: translateX(-100%);
    }
}

.animate-marquee {
    animation: marquee 30s linear infinite;
}