:root {
    --dark-blue: #000026;
    --main-blue: #0b01c5;
    --main-pink: #fe2e7e;
}
/* Custom styles to integrate the provided theme */
body {
    font-family: 'Alexandria', sans-serif;
    background-color: var(--dark-blue);
    color: #ffffff;
    overflow-x: hidden; /* Prevent horizontal scroll */
}
/* Style to prevent scrolling when a modal is open */
body.overflow-hidden {
    overflow: hidden;
}
.bg-dark-blue { background-color: var(--dark-blue); }
.bg-main-blue { background-color: var(--main-blue); }
.text-main-pink { color: var(--main-pink); }
.bg-main-pink { background-color: var(--main-pink); }
.border-main-pink { border-color: var(--main-pink); }

/* Add a subtle glow effect to pink elements */
.glow-pink {
    box-shadow: 0 0 8px var(--main-pink), 0 0 20px var(--main-pink);
}

/* Custom scrollbar for a more modern look */
::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-track { background: var(--dark-blue); }
::-webkit-scrollbar-thumb { background: var(--main-blue); border-radius: 10px; }
::-webkit-scrollbar-thumb:hover { background: var(--main-pink); }
html { scroll-behavior: smooth; }

/* Background styles for sections */
.services-section {
    background-color: var(--dark-blue);
    overflow-x: hidden; /* Fix for horizontal scroll on mobile caused by animations */
}
.project-card img {
    transition: transform 0.3s ease-in-out;
}
.project-card:hover img {
    transform: scale(1.05);
}
.why-us-section {
    background-image: url('assets/images/why-us-bg.jpg');
    background-size: cover;
    background-position: center;
    background-attachment: fixed; /* Parallax effect */
}

/* Social Icon Hover */
.social-icon {
    transition: transform 0.5s ease-in-out, filter 0.3s ease-in-out;
    filter: grayscale(100%) brightness(2);
}
.social-icon:hover {
    transform: scale(1.2) rotate(360deg);
    filter: grayscale(0%) brightness(1);
}

/* Animation for header items */
.animate-header-item {
    opacity: 0;
    transform: translateY(-40px);
    transition: opacity 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94), transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.animate-header-item.animate-in {
    opacity: 1;
    transform: translateY(0);
}

/* Animation for service cards & title */
.services-title-animate {
    opacity: 0;
    transform: translateY(40px);
    transition: opacity 0.7s ease-out, transform 0.7s ease-out;
}

.services-title-animate.is-visible {
    opacity: 1;
    transform: translateY(0);
}

.service-card {
    opacity: 0;
    transition: opacity 0.7s ease-out, transform 0.7s ease-out;
}

.service-card.animate-from-left { transform: translateX(-80px); }
.service-card.animate-from-right { transform: translateX(80px); }
.service-card.animate-from-bottom { transform: translateY(80px); }

.service-card.is-visible {
    opacity: 1;
    transform: translateX(0) translateY(0);
}

/* Service list item styling */
.service-item svg {
    flex-shrink: 0;
}
html[lang="ar"] .service-item svg {
    margin-right: 0.5rem; /* Space between star and text in Arabic */
}
html[lang="en"] .service-item svg {
    margin-right: 0.5rem; /* Space between star and text in English */
}


/* --- Button Hover Effects --- */
.btn-hover-effect {
    position: relative;
    overflow: hidden;
    z-index: 1;
}
.btn-hover-effect::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(120deg, transparent, rgba(255, 255, 255, 0.3), transparent);
    transition: left 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.btn-hover-effect:hover::before {
    left: 100%;
}

/* Mobile menu hide/show */
.mobile-menu-closed {
    opacity: 0;
    transform: translateY(-20px);
    pointer-events: none;
}
.mobile-menu-open {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}

/* Why Us Section Animation */
.why-us-card {
    opacity: 0;
    transform: translateY(50px);
    transition: opacity 0.6s ease-out, transform 0.6s ease-out, box-shadow 0.3s ease-in-out;
}

.why-us-card.is-visible {
    opacity: 1;
    transform: translateY(0);
}

.why-us-card:hover {
    transform: translateY(-10px);
    box-shadow: 0 0 15px rgba(254, 46, 126, 0.5), 0 0 30px rgba(254, 46, 126, 0.3);
}

/* Hero Text Animation */
#hero-animated-text {
    opacity: 0; /* Initially hidden */
    animation: fade-once 4s ease-in-out 2s forwards;
}

@keyframes fade-once {
    0% {
        opacity: 0;
    }
    25% {
        opacity: 1;
    }
    75% {
        opacity: 1;
    }
    100% {
        opacity: 0;
    }
}

/* Clients Slider */
.scrollbar-hide::-webkit-scrollbar {
    display: none;
}
.scrollbar-hide {
    -ms-overflow-style: none;  /* IE and Edge */
    scrollbar-width: none;  /* Firefox */
}
#logo-slider {
    cursor: grab;
}
#logo-slider.active {
    cursor: grabbing;
    cursor: -webkit-grabbing;
}
.client-logo {
    max-height: 50px;
    width: 100%;
    object-fit: contain;
    opacity: 1;
    transition: all 0.3s ease-in-out;
}
.client-logo:hover {
    transform: scale(1.1);
}
.slider-dot.active {
    background-color: var(--main-pink);
}
