/* ============================================
   MIND-BLOWING ENHANCED STYLES
   ============================================ */

/* Advanced Animations */
@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(40px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes slideInRight {
    from {
        opacity: 0;
        transform: translateX(30px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes slideInLeft {
    from {
        opacity: 0;
        transform: translateX(-30px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes scaleIn {
    from {
        opacity: 0;
        transform: scale(0.9);
    }
    to {
        opacity: 1;
        transform: scale(1);
    }
}

@keyframes pulse {
    0%, 100% {
        transform: scale(1);
    }
    50% {
        transform: scale(1.05);
    }
}

/* Scroll Animation Classes */
.animate-on-scroll {
    opacity: 0;
    transform: translateY(30px);
    transition: all 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.animate-on-scroll.animated {
    opacity: 1;
    transform: translateY(0);
}

.in-view {
    animation: fadeInUp 0.8s ease-out forwards;
}

.fade-in-up {
    animation: fadeInUp 1s ease-out;
}

/* Service Cards & Stats with Enhanced Animations */
.service-card,
.stat-item {
    animation: fadeIn 0.6s ease-out;
    transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.service-card:hover,
.stat-item:hover {
    transform: translateY(-10px) scale(1.02);
    box-shadow: 0 15px 40px rgba(0, 0, 0, 0.15);
}

/* ============================================
   MIND-BLOWING NAVIGATION STYLES
   ============================================ */

/* Enhanced Menu Alignment */
.main-menu {
    display: flex !important;
}

/* Mobile Menu Override */
@media (max-width: 768px) {
    .main-menu {
        display: none !important;
    }
    
    .main-menu.active,
    .main-navigation.active .main-menu {
        display: flex !important;
        flex-direction: column !important;
    }
    flex-direction: row !important;
    align-items: center !important;
    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.main-menu li {
    display: inline-flex !important;
    vertical-align: middle !important;
    position: relative;
}

.main-menu a {
    display: inline-flex !important;
    align-items: center !important;
    vertical-align: middle !important;
    position: relative;
    overflow: hidden;
}

/* Menu Item Hover Effect with Underline Animation */
.main-menu a::before {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    width: 0;
    height: 3px;
    background: var(--accent-color);
    transform: translateX(-50%);
    transition: width 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    z-index: 1;
}

.main-menu a:hover::before,
.main-menu a.hover-effect::before {
    width: 80%;
}

.main-menu .current-menu-item > a::before {
    width: 80%;
}

/* Enhanced Menu Item Hover */
.main-menu a:hover,
.main-menu a.hover-effect {
    color: var(--primary-color) !important;
    transform: translateY(-2px);
}

/* Sticky Header Enhancements */
.site-header {
    transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    will-change: transform, box-shadow;
}

.site-header.scrolled {
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.12);
    backdrop-filter: blur(10px);
    background: rgba(255, 255, 255, 0.98);
}

.header-main.scrolled {
    padding: 10px 0;
}

.header-main.scrolled .site-logo img {
    height: 50px;
    transition: height 0.3s ease;
}

/* ============================================
   ENHANCED RTL STYLES
   ============================================ */

body.rtl {
    direction: rtl;
    text-align: right;
}

/* Default state: Show English, hide Arabic */
.lang-en {
    display: inline-block;
}

.lang-ar {
    display: none;
}

/* When Arabic is active: Hide English, show Arabic */
body.rtl .lang-en,
body[dir="rtl"] .lang-en,
body.lang-ar-active .lang-en {
    display: none !important;
    visibility: hidden !important;
}

body.rtl .lang-ar,
body[dir="rtl"] .lang-ar,
body.lang-ar-active .lang-ar {
    display: inline-block !important;
    visibility: visible !important;
}

/* When English is active (default): Show English, hide Arabic */
body:not(.rtl):not(.lang-ar-active) .lang-en {
    display: inline-block !important;
    visibility: visible !important;
}

body:not(.rtl):not(.lang-ar-active) .lang-ar {
    display: none !important;
    visibility: hidden !important;
}

/* Ensure menu items don't flash */
body.rtl .main-menu .lang-en,
body[dir="rtl"] .main-menu .lang-en,
body.rtl .footer-menu .lang-en,
body[dir="rtl"] .footer-menu .lang-en {
    display: none !important;
}

body.rtl .main-menu .lang-ar,
body[dir="rtl"] .main-menu .lang-ar,
body.rtl .footer-menu .lang-ar,
body[dir="rtl"] .footer-menu .lang-ar {
    display: inline-block !important;
}

/* Additional class-based hiding for instant switch */
body.lang-ar-active .lang-en {
    display: none !important;
    visibility: hidden !important;
}

body.lang-ar-active .lang-ar {
    display: inline-block !important;
    visibility: visible !important;
}

/* Force service-card content to respect language switcher - MORE SPECIFIC */
body.lang-ar-active .service-card .lang-en,
body.rtl .service-card .lang-en,
body[dir="rtl"] .service-card .lang-en,
body.lang-ar-active .service-card-enhanced .lang-en,
body.rtl .service-card-enhanced .lang-en,
body[dir="rtl"] .service-card-enhanced .lang-en,
body.lang-ar-active .service-content .lang-en,
body.rtl .service-content .lang-en,
body[dir="rtl"] .service-content .lang-en {
    display: none !important;
    visibility: hidden !important;
}

body.lang-ar-active .service-card .lang-ar,
body.rtl .service-card .lang-ar,
body[dir="rtl"] .service-card .lang-ar,
body.lang-ar-active .service-card-enhanced .lang-ar,
body.rtl .service-card-enhanced .lang-ar,
body[dir="rtl"] .service-card-enhanced .lang-ar,
body.lang-ar-active .service-content .lang-ar,
body.rtl .service-content .lang-ar,
body[dir="rtl"] .service-content .lang-ar {
    display: inline-block !important;
    visibility: visible !important;
}

/* Even more specific - target all possible containers */
body.lang-ar-active h3 .lang-en,
body.lang-ar-active p .lang-en,
body.lang-ar-active a .lang-en,
body.rtl h3 .lang-en,
body.rtl p .lang-en,
body.rtl a .lang-en {
    display: none !important;
    visibility: hidden !important;
}

body.lang-ar-active h3 .lang-ar,
body.lang-ar-active p .lang-ar,
body.lang-ar-active a .lang-ar,
body.rtl h3 .lang-ar,
body.rtl p .lang-ar,
body.rtl a .lang-ar {
    display: inline-block !important;
    visibility: visible !important;
}

/* Force phone numbers to display LTR even in RTL context */
.lang-ar[dir="ltr"],
span[dir="ltr"] .lang-ar,
.lang-ar span[dir="ltr"],
a[dir="ltr"] .lang-ar,
.lang-ar a[dir="ltr"],
body[dir="rtl"] .lang-ar[dir="ltr"],
body[dir="rtl"] span[dir="ltr"],
body.rtl .lang-ar[dir="ltr"],
body.rtl span[dir="ltr"] {
    direction: ltr !important;
    text-align: left !important;
    unicode-bidi: embed !important;
    display: inline-block !important;
}

/* Force all phone number spans in Arabic sections to be LTR */
body[dir="rtl"] a[href^="tel:"] .lang-ar,
body.rtl a[href^="tel:"] .lang-ar,
body[dir="rtl"] .lang-ar[dir="ltr"],
body.rtl .lang-ar[dir="ltr"] {
    direction: ltr !important;
    unicode-bidi: embed !important;
    display: inline-block !important;
    text-align: left !important;
}
    text-align: right;
}

body.rtl .header-top-left,
body.rtl .main-menu {
    flex-direction: row-reverse;
}

body.rtl .main-menu a::before {
    left: auto;
    right: 50%;
    transform: translateX(50%);
}

@media (max-width: 768px) {
    body.rtl .main-menu {
        transform: translateX(100%);
    }
    
    body.rtl .main-menu a {
        border-left: none;
        border-right: 4px solid transparent;
    }
    
    body.rtl .main-menu a:hover,
    body.rtl .main-menu .current-menu-item > a {
        border-right-color: var(--accent-color);
        padding-right: 30px;
        padding-left: 25px;
        transform: translateX(-5px);
    }
}

/* ============================================
   ENHANCED INTERACTIVE ELEMENTS
   ============================================ */

/* Department Filter with Enhanced Animations */
.filter-btn {
    transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    position: relative;
    overflow: hidden;
}

.filter-btn::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 0;
    height: 0;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.3);
    transform: translate(-50%, -50%);
    transition: width 0.6s, height 0.6s;
}

.filter-btn:hover::before {
    width: 300px;
    height: 300px;
}

.filter-btn:hover {
    transform: translateY(-3px) scale(1.05);
    box-shadow: 0 8px 20px rgba(0, 168, 168, 0.3);
}

.filter-btn.active {
    background: var(--accent-brown) !important;
    color: white !important;
    border-color: var(--accent-brown) !important;
    box-shadow: 0 4px 15px rgba(0, 168, 168, 0.4);
    animation: pulse 2s infinite;
}

/* Enhanced Search Interface - IMC Style */
#doctor-name-search:focus,
#department-search:focus {
    outline: none;
    border-color: var(--accent-color);
    box-shadow: 0 0 0 3px rgba(0, 168, 168, 0.1);
}

#doctor-name-search:hover,
#department-search:hover {
    border-color: var(--primary-color);
}

/* Enhanced Service Cards - Professional Design */
.service-card-enhanced {
    transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.service-card-enhanced:hover {
    transform: translateY(-10px) scale(1.02);
    box-shadow: 0 20px 60px rgba(0,0,0,0.15) !important;
}

.service-card-enhanced::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--accent-color), var(--primary-color));
    transform: scaleX(0);
    transition: transform 0.4s ease;
    z-index: 1;
}

.service-card-enhanced:hover::before {
    transform: scaleX(1);
}

/* Enhanced Value Cards */
.value-card {
    transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.value-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 15px 40px rgba(0,0,0,0.15) !important;
}

.value-card:hover > div:first-child {
    transform: scale(1.1);
}

/* Enhanced Contact Cards */
.contact-card-enhanced {
    transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.contact-card-enhanced:hover {
    transform: translateY(-10px);
    box-shadow: 0 20px 60px rgba(0,0,0,0.15) !important;
}

.contact-card-enhanced:hover > div:first-child {
    opacity: 1 !important;
}

.contact-card-enhanced:hover > div:last-child > div:first-child {
    transform: scale(1.1) rotate(5deg);
}

/* Enhanced Facility Cards */
.facility-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 15px 40px rgba(0,0,0,0.15) !important;
    border-color: var(--accent-color);
}

.facility-card:hover > div:first-child {
    transform: scale(1.15);
    box-shadow: 0 12px 35px rgba(0,168,168,0.4) !important;
}

/* Enhanced Doctor Cards - Mind-Blowing Design */
.doctor-card,
.doctor-card-enhanced {
    opacity: 1;
    transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    transform: translateY(0);
    position: relative;
    overflow: hidden;
}

.doctor-card::before,
.doctor-card-enhanced::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--accent-color), var(--primary-color));
    transform: scaleX(0);
    transition: transform 0.4s ease;
    z-index: 1;
}

.doctor-card:hover::before,
.doctor-card-enhanced:hover::before {
    transform: scaleX(1);
}

.doctor-card:hover,
.doctor-card-enhanced:hover {
    transform: translateY(-12px) scale(1.03);
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.2);
    border-color: var(--accent-color);
}

.doctor-card.hidden {
    display: none !important;
    opacity: 0;
    transform: scale(0.8);
}

/* Doctor Card Image Hover Effect */
.doctor-card-enhanced img {
    transition: all 0.4s ease;
}

.doctor-card-enhanced:hover img {
    transform: scale(1.1);
    box-shadow: 0 15px 50px rgba(0, 0, 0, 0.3);
}

/* Page Load Animation */
body:not(.page-loaded) {
    overflow: hidden;
}

body.page-loaded {
    animation: fadeIn 0.5s ease-out;
}

/* Button Enhancements */
.btn {
    position: relative;
    overflow: hidden;
    transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.btn::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 0;
    height: 0;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.3);
    transform: translate(-50%, -50%);
    transition: width 0.6s, height 0.6s;
}

.btn:hover::before {
    width: 400px;
    height: 400px;
}

.btn:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
}

.btn:active {
    transform: translateY(-1px);
}

/* ============================================
   ADDITIONAL ENHANCEMENTS
   ============================================ */

/* Smooth Scrolling */
html {
    scroll-behavior: smooth;
}

/* Selection Color */
::selection {
    background: var(--accent-color);
    color: white;
}

::-moz-selection {
    background: var(--accent-color);
    color: white;
}

/* Focus Styles for Accessibility */
a:focus,
button:focus,
input:focus,
select:focus,
textarea:focus {
    outline: 3px solid var(--accent-color);
    outline-offset: 2px;
}

/* Loading State */
.loading {
    opacity: 0.6;
    pointer-events: none;
}

/* Print Styles */
@media print {
    .site-header,
    .site-footer,
    .hero-buttons {
        display: none;
    }
    
    .animate-on-scroll {
        opacity: 1;
        transform: none;
    }
}

