﻿/* wwwroot/css/site.css */

/* =========================================
   Theme / Brand
========================================= */
:root {
    --mrsaak: #0097b2;
    --mrsaak-strong: #00849b;
    --mrsaak-soft: rgba(0,151,178,.10);
    --mrsaak-soft-2: rgba(0,151,178,.16);
    /* Bootstrap theme overrides */
    --bs-primary: var(--mrsaak);
    --bs-primary-rgb: 0,151,178;
    --bs-link-color: var(--mrsaak);
    --bs-link-hover-color: var(--mrsaak-strong);
}

/* =========================================
   Global Bootstrap Color Overrides
========================================= */
.navbar.bg-dark,
.bg-dark {
    background-color: var(--mrsaak) !important;
}

.navbar-dark .navbar-brand,
.navbar-dark .nav-link {
    color: #fff !important;
}

    .navbar-dark .nav-link:hover,
    .navbar-dark .nav-link:focus {
        color: #fff !important;
    }

/* Buttons */
.btn-dark {
    --bs-btn-bg: var(--mrsaak);
    --bs-btn-border-color: var(--mrsaak);
    --bs-btn-hover-bg: var(--mrsaak);
    --bs-btn-hover-border-color: var(--mrsaak);
    --bs-btn-active-bg: var(--mrsaak);
    --bs-btn-active-border-color: var(--mrsaak);
    --bs-btn-disabled-bg: var(--mrsaak);
    --bs-btn-disabled-border-color: var(--mrsaak);
    color: #fff;
}

.btn-primary {
    --bs-btn-bg: var(--mrsaak);
    --bs-btn-border-color: var(--mrsaak);
    --bs-btn-hover-bg: var(--mrsaak);
    --bs-btn-hover-border-color: var(--mrsaak);
    --bs-btn-active-bg: var(--mrsaak);
    --bs-btn-active-border-color: var(--mrsaak);
    --bs-btn-disabled-bg: var(--mrsaak);
    --bs-btn-disabled-border-color: var(--mrsaak);
}

.btn-outline-dark,
.btn-outline-primary {
    --bs-btn-color: var(--mrsaak);
    --bs-btn-border-color: var(--mrsaak);
    --bs-btn-hover-bg: var(--mrsaak);
    --bs-btn-hover-border-color: var(--mrsaak);
    --bs-btn-active-bg: var(--mrsaak);
    --bs-btn-active-border-color: var(--mrsaak);
}

.badge.bg-dark,
.badge.bg-primary {
    background-color: var(--mrsaak) !important;
}

/* Links */
a {
    color: var(--mrsaak);
}

    a:hover {
        color: var(--mrsaak-strong);
    }

/* Forms focus */
.form-control:focus,
.form-select:focus {
    border-color: var(--mrsaak);
    box-shadow: 0 0 0 .25rem rgba(0,151,178,.25);
}

.form-check-input:checked {
    background-color: var(--mrsaak);
    border-color: var(--mrsaak);
}

.form-check-input:focus {
    border-color: var(--mrsaak);
    box-shadow: 0 0 0 .25rem rgba(0,151,178,.25);
}

/* Headings */
h1, h2, h3, h4, .h1, .h2, .h3, .h4 {
    color: var(--mrsaak);
}

/* =========================================
   Header / Navbar (Professional)
========================================= */
.site-header {
    z-index: 1030;
}

.site-navbar {
    background-color: var(--mrsaak) !important;
    border-bottom: 1px solid rgba(255,255,255,.14);
    box-shadow: 0 .45rem 1.25rem rgba(0,0,0,.10);
}

/* Desktop layout balance */
.desktop-nav-grid {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: 1rem;
}

.desktop-brand-slot {
    justify-self: start;
}

.desktop-center-slot {
    justify-self: center;
}

.desktop-meta-slot {
    justify-self: end;
}

/* Brand */
.site-brand {
    display: inline-flex;
    align-items: center;
    color: #fff !important;
    text-decoration: none;
    font-weight: 700;
    letter-spacing: .2px;
}

    .site-brand:hover {
        color: #fff !important;
    }

.brand-text {
    font-size: 1.25rem;
    line-height: 1;
    font-weight: 700;
}

/* Meta pill */
.header-meta-pill {
    display: inline-flex;
    align-items: center;
    background-color: rgba(255,255,255,.12);
    border: 1px solid rgba(255,255,255,.22);
    color: #fff;
    border-radius: 999px;
    padding: .5rem .9rem;
    font-size: .87rem;
    line-height: 1;
    white-space: nowrap;
    font-weight: 500;
}

/* Main desktop menu links */
.site-nav-link {
    border-radius: 999px;
    border: 1px solid transparent;
    color: rgba(255,255,255,.98) !important;
    padding: .65rem 1rem !important;
    font-weight: 600;
    line-height: 1;
    transition: background-color .15s ease, color .15s ease, border-color .15s ease;
}

    /* Hover */
    .site-nav-link:hover,
    .site-nav-link:focus {
        background-color: rgba(255,255,255,.14);
        color: #fff !important;
        border-color: transparent;
    }

    /* Active بدون تلوين */
    .site-nav-link.active {
        background-color: transparent;
        color: rgba(255,255,255,.98) !important;
        border-color: transparent;
        box-shadow: none;
    }

        /* ✅ إصلاح: حتى لو Active لازم الهوفر يشتغل */
        .site-nav-link.active:hover,
        .site-nav-link.active:focus {
            background-color: rgba(255,255,255,.14);
            color: #fff !important;
            border-color: transparent;
        }

/* Desktop dropdown */
.site-dropdown {
    min-width: 20rem;
    margin-top: .7rem;
    padding: .55rem;
    border-radius: 1rem;
    background-color: #fff;
    box-shadow: 0 1rem 2rem rgba(0,0,0,.12) !important;
}

.site-dropdown-header {
    color: #6c757d;
    font-size: .76rem;
    font-weight: 700;
    padding: .35rem .8rem .2rem;
    margin: 0;
}

.site-dropdown .dropdown-item {
    border-radius: .75rem;
    padding: .75rem .9rem;
    color: #1f2937;
    font-weight: 500;
    border: 1px solid transparent;
    transition: background-color .12s ease, color .12s ease, border-color .12s ease;
}

    .site-dropdown .dropdown-item:hover,
    .site-dropdown .dropdown-item:focus {
        background-color: var(--mrsaak-soft);
        color: var(--mrsaak-strong);
        border-color: rgba(0,151,178,.12);
    }

    /* بدون تمييز للصفحة الحالية داخل القائمة */
    .site-dropdown .dropdown-item.active {
        background-color: #fff;
        color: #1f2937;
        border-color: transparent;
        box-shadow: none;
    }

    /* ضغط/نقرة */
    .site-dropdown .dropdown-item:active {
        background-color: var(--mrsaak-soft);
        color: var(--mrsaak-strong);
        border-color: rgba(0,151,178,.12);
    }

.site-dropdown .dropdown-divider {
    margin: .45rem 0;
    opacity: .12;
}

/* Mobile top bar */
.mobile-toggler {
    border-radius: .8rem;
    background-color: rgba(255,255,255,.12);
    transition: background-color .15s ease, transform .12s ease;
}

    .mobile-toggler:hover,
    .mobile-toggler:focus {
        background-color: rgba(255,255,255,.18);
    }

    .mobile-toggler:active {
        transform: translateY(1px);
    }

/* =========================================
   Mobile Fullscreen Menu
========================================= */
.mobile-nav-panel {
    height: 100dvh !important;
    max-height: none !important;
    border: 0 !important;
    background-color: #f8f9fa;
}

.mobile-nav-header {
    position: relative;
    background-color: var(--mrsaak);
    color: #fff;
    border-bottom: 1px solid rgba(255,255,255,.14);
    padding: 1rem 1rem;
    padding-left: 3.25rem; /* مساحة لزر X */
    box-shadow: 0 .35rem .9rem rgba(0,0,0,.07);
}

    .mobile-nav-header .offcanvas-title {
        color: #fff;
        font-size: 1.1rem;
        line-height: 1;
    }

.mobile-nav-subtitle {
    color: rgba(255,255,255,.86);
    font-size: .84rem;
}

/* نفس مسافة البوكسات (مثل بين الرئيسية و PDF) داخل الأكوردين */
.mobile-nav-accordion .accordion-item + .accordion-item {
    margin-top: .85rem;
}

/* ✅ زر الإغلاق أقصى اليسار */
.mobile-close-btn {
    position: absolute;
    left: 1rem;
    top: 1rem;
    margin: 0 !important;
    opacity: .95;
}

.mobile-nav-body {
    padding: 1rem;
    overflow-y: auto;
}

.mobile-nav-container {
    width: 100%;
    max-width: 700px;
    display: grid;
    gap: .85rem;
}

/* ✅ عنصر موحد للرئيسية + زر خدمات PDF */
.mobile-menu-item {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    text-align: right;
    text-decoration: none;
    color: #1f2937;
    background-color: #fff;
    border: 1px solid rgba(0,0,0,.06);
    border-radius: 1rem !important;
    padding: 1rem 1.05rem;
    min-height: 58px;
    font-weight: 700;
    box-shadow: 0 .2rem .65rem rgba(0,0,0,.04);
    transition: background-color .12s ease, border-color .12s ease, color .12s ease, box-shadow .12s ease;
}

    /* Hover موحد */
    .mobile-menu-item:hover {
        color: var(--mrsaak-strong);
        border-color: rgba(0,151,178,.20);
        background-color: rgba(0,151,178,.04);
        box-shadow: 0 .35rem .9rem rgba(0,151,178,.07);
    }

    /* بدون تمييز للصفحة الحالية */
    .mobile-menu-item.active {
        color: #1f2937;
        background-color: #fff;
        border-color: rgba(0,0,0,.06);
        box-shadow: 0 .2rem .65rem rgba(0,0,0,.04);
    }

        /* ✅ خلي التفاعل يشتغل حتى لو العنصر Active (مثل الرئيسية) */
        .mobile-menu-item.active:hover,
        .mobile-menu-item.active:focus,
        .mobile-menu-item.active:active {
            color: var(--mrsaak-strong);
            border-color: rgba(0,151,178,.20);
            background-color: rgba(0,151,178,.04);
            box-shadow: 0 .35rem .9rem rgba(0,151,178,.07);
        }

    /* ✅ دعم لمسة الجوال */
    .mobile-menu-item:active,
    .mobile-menu-item:focus {
        color: var(--mrsaak-strong);
        border-color: rgba(0,151,178,.20);
        background-color: rgba(0,151,178,.04);
        box-shadow: 0 .35rem .9rem rgba(0,151,178,.07);
    }

/* Accordion wrapper */
.mobile-nav-accordion .accordion-item {
    border: 0;
    background: transparent;
    border-radius: 1rem !important; /* احتياط */
}

/* إزالة تأثيرات Bootstrap الافتراضية اللي تخرب التساوي */
.mobile-nav-accordion .accordion-button {
    box-shadow: none;
}

    /* ✅ نفس شكل/طول/حواف الرئيسية */
    .mobile-nav-accordion .accordion-button.mobile-menu-item {
        position: relative;
        padding-left: 3.1rem; /* مساحة للسهم يسار */
        background-color: #fff !important;
        box-shadow: 0 .2rem .65rem rgba(0,0,0,.04) !important;
        /* تثبيت الانحناء */
        border-top-left-radius: 1rem !important;
        border-top-right-radius: 1rem !important;
        border-bottom-left-radius: 1rem !important;
        border-bottom-right-radius: 1rem !important;
    }

        /* ✅ سهم PDF أقصى اليسار (ثابت) */
        .mobile-nav-accordion .accordion-button.mobile-menu-item::after {
            position: absolute;
            left: 1.05rem;
            margin: 0 !important;
            opacity: .9;
        }

        /* إذا القسم مفتوح */
        .mobile-nav-accordion .accordion-button.mobile-menu-item:not(.collapsed) {
            background-color: #fff !important;
            color: var(--mrsaak) !important;
            border-color: rgba(0,151,178,.28) !important;
            box-shadow: 0 .35rem .9rem rgba(0,151,178,.10) !important;
            /* تثبيت الانحناء حتى وهو مفتوح */
            border-top-left-radius: 1rem !important;
            border-top-right-radius: 1rem !important;
            border-bottom-left-radius: 1rem !important;
            border-bottom-right-radius: 1rem !important;
        }

/* Body */
.mobile-nav-accordion .accordion-body {
    padding: .7rem .2rem .15rem;
}

.mobile-section-label {
    font-size: .78rem;
    color: #6c757d;
    font-weight: 700;
    margin: .15rem .2rem .45rem;
}

/* Sub links */
.mobile-sub-link {
    display: block;
    text-decoration: none;
    color: #1f2937;
    background-color: #fff;
    border: 1px solid rgba(0,0,0,.06);
    border-radius: .9rem;
    padding: .9rem .95rem;
    font-weight: 500;
    box-shadow: 0 .12rem .35rem rgba(0,0,0,.02);
    transition: background-color .12s ease, border-color .12s ease, color .12s ease, box-shadow .12s ease;
}

    .mobile-sub-link:hover {
        color: var(--mrsaak-strong);
        border-color: rgba(0,151,178,.20);
        background-color: rgba(0,151,178,.04);
        box-shadow: 0 .35rem .9rem rgba(0,151,178,.07);
    }

    /* بدون تمييز للصفحة الحالية */
    .mobile-sub-link.active {
        color: #1f2937;
        background-color: #fff;
        border-color: rgba(0,0,0,.06);
        box-shadow: 0 .12rem .35rem rgba(0,0,0,.02);
    }

/* =========================================
   Service Cards (Clickable)
========================================= */
a.service-link .card {
    position: relative;
    overflow: hidden;
    transition: transform .15s ease, box-shadow .15s ease;
    box-shadow: 0 .25rem .75rem rgba(0,0,0,.08);
}

    a.service-link .card::before {
        content: "";
        position: absolute;
        inset-inline: 0;
        top: 0;
        height: 4px;
        background: transparent;
    }

a.service-link:hover .card {
    transform: translateY(-2px);
    box-shadow: 0 .9rem 1.8rem rgba(0,151,178,.18);
}

    a.service-link:hover .card::before {
        background: var(--mrsaak);
    }

/* =========================================
   Accessibility / Focus
========================================= */
.btn:focus-visible,
.nav-link:focus-visible,
.dropdown-item:focus-visible,
.mobile-menu-item:focus-visible,
.mobile-sub-link:focus-visible,
.accordion-button:focus-visible {
    outline: none;
    box-shadow: 0 0 0 .25rem rgba(0,151,178,.22);
}

/* =========================================
   Responsive refinements
========================================= */
@media (max-width: 991.98px) {
    .brand-text {
        font-size: 1.1rem;
    }

    .site-navbar {
        box-shadow: 0 .35rem .95rem rgba(0,0,0,.10);
    }

    .mobile-nav-body {
        padding: .9rem;
    }
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce) {
    * {
        transition: none !important;
        animation: none !important;
    }
}
