/* Custom Styles for Software4 Static Site */

/* Base layout safety (prevents horizontal scroll on mobile) */
*, *::before, *::after {
    box-sizing: border-box;
}

html, body {
    margin: 0;
    padding: 0;
    overflow-x: hidden;
}

/* Prevent background scroll when mobile drawer is open */
html.menu-open, body.menu-open {
    overflow: hidden;
}

/* Grid Pattern Background */
.grid-pattern {
    background-image: 
        linear-gradient(rgba(59, 130, 246, 0.03) 1px, transparent 1px),
        linear-gradient(90deg, rgba(59, 130, 246, 0.03) 1px, transparent 1px);
    background-size: 50px 50px;
}

/* Glow Effects */
.glow-blue {
    box-shadow: 0 0 30px rgba(59, 130, 246, 0.4);
}

.glow-cyan {
    box-shadow: 0 0 30px rgba(6, 182, 212, 0.3);
}

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

@keyframes float {
    0%, 100% {
        transform: translateY(0px);
    }
    50% {
        transform: translateY(-10px);
    }
}

.animate-fade-in {
    animation: fade-in 0.8s ease-out forwards;
}

.animate-fade-in-delay {
    animation: fade-in 0.8s ease-out 0.2s forwards;
    opacity: 0;
}

.animate-float {
    animation: float 3s ease-in-out infinite;
}

.animate-float-delay {
    animation: float 3s ease-in-out 0.5s infinite;
}

/* Scrollbar Styles */
::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

::-webkit-scrollbar-track {
    background: #0F172A;
}

::-webkit-scrollbar-thumb {
    background: #334155;
    border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
    background: #475569;
}

/* Selection Color */
::selection {
    background-color: rgba(59, 130, 246, 0.3);
}

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

/* FAQ Accordion */
.faq-item .faq-trigger i {
    transition: transform 0.3s ease;
}

.faq-item.active .faq-trigger i {
    transform: rotate(180deg);
}

/* Testimonial Transitions */
.testimonial {
    transition: opacity 0.4s ease, transform 0.4s ease;
}

.testimonial.hidden {
    display: none;
}

/* Light Mode Overrides */
html:not(.dark) body {
    background-color: #f8fafc;
    color: #0f172a;
}

html:not(.dark) .bg-navy-900 {
    background-color: #ffffff;
}

html:not(.dark) .bg-navy-800 {
    background-color: #f1f5f9;
}

html:not(.dark) .text-white {
    color: #0f172a;
}

html:not(.dark) .text-slate-400 {
    color: #64748b;
}

html:not(.dark) .border-white\/10 {
    border-color: rgba(15, 23, 42, 0.1);
}

html:not(.dark) .bg-white\/5 {
    background-color: rgba(15, 23, 42, 0.03);
}

html:not(.dark) .bg-white\/10 {
    background-color: rgba(15, 23, 42, 0.05);
}

html:not(.dark) #navbar.scrolled {
    background-color: rgba(255, 255, 255, 0.9);
    backdrop-filter: blur(20px);
}

/* Navbar Scrolled State */
#navbar.scrolled {
    background-color: rgba(15, 23, 42, 0.9);
    backdrop-filter: blur(20px);
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
}

/* Mobile drawer helpers */
#mobile-menu[aria-hidden="true"] {
    pointer-events: none;
}

#mobile-menu[aria-hidden="false"] {
    pointer-events: auto;
}

/* Button Hover States */
button, a {
    transition: all 0.2s ease;
}

/* Card Hover */
.group:hover .group-hover\:bg-electric-blue\/20 {
    background-color: rgba(59, 130, 246, 0.2);
}

/* Counter Animation */
.counter {
    display: inline-block;
}
