/* ========================================
   RESET
======================================== */

*,
*::before,
*::after{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

html{
    scroll-behavior:smooth;
}

body{
    font-family:'Inter',sans-serif;
    background:#ffffff;
    color:#0B1220;
    overflow-x:hidden;
    line-height:1.6;
}

img{
    max-width:100%;
    display:block;
}

ul{
    list-style:none;
}

a{
    text-decoration:none;
    color:inherit;
}

button,
input,
textarea{
    font:inherit;
}

/* ========================================
   VARIABLES
======================================== */

:root{

    --primary:#5B5FFB;
    --primary-dark:#4347f5;

    --navy:#0B1220;

    --slate:#64748B;

    --light:#F8FAFC;

    --white:#FFFFFF;

    --border:#E2E8F0;

    --radius:24px;

    --transition:.35s ease;

    --shadow:
    0 10px 30px rgba(0,0,0,.08);

}



/* ========================================
   CONTAINER
======================================== */

.container{
    width:min(90%,1300px);
    margin:auto;
}

/* ========================================
   SECTION SPACING
======================================== */

section{
    padding:100px 0;
}

/* ========================================
   TYPOGRAPHY
======================================== */

h1,h2,h3,h4,h5,h6{
    font-weight:700;
    line-height:1.1;
}

h1{
    font-size:clamp(3rem,6vw,5rem);
}

h2{
    font-size:clamp(2rem,4vw,3.5rem);
}

h3{
    font-size:1.5rem;
}

p{
    color:var(--slate);
}




/* ========================================
   BUTTONS
======================================== */

.btn-primary{

    display:inline-flex;

    align-items:center;

    justify-content:center;

    padding:14px 28px;

    background:var(--primary);

    color:#fff;

    border-radius:999px;

    font-weight:600;

    transition:var(--transition);

}

.btn-primary:hover{

    background:var(--primary-dark);

    transform:translateY(-2px);

}

.btn-secondary{

    display:inline-flex;

    align-items:center;

    justify-content:center;

    padding:14px 28px;

    border:1px solid var(--border);

    border-radius:999px;

    font-weight:600;

    transition:var(--transition);

}

.btn-secondary:hover{

    background:#f5f5f5;

}




/* ========================================
   NAVBAR
======================================== */

.navbar{

    position:fixed;

    top:0;

    left:0;

    width:100%;

    z-index:999;

    transition:.3s ease;

    background:transparent;

}

.navbar.scrolled{

    background:rgba(255,255,255,.85);

    backdrop-filter:blur(20px);

    -webkit-backdrop-filter:blur(20px);

    box-shadow:
    0 8px 30px rgba(0,0,0,.05);

}


.navbar .container{

    height:85px;

    display:flex;

    align-items:center;

    justify-content:space-between;

}

.logo{

    font-size:1.5rem;

    font-weight:800;

    color:var(--navy);

}

.menu{

    display:flex;

    gap:35px;

    align-items:center;

}

.menu a{

    font-weight:500;

    transition:var(--transition);

}

.menu a:hover{

    color:var(--primary);

}




/* ========================================
   MEGA MENU
======================================== */

.mega-parent{

    position:relative;

}

.mega-menu{

    position:absolute;

    top:100%;

    left:-150px;

    width:700px;

    background:#fff;

    border-radius:20px;

    padding:30px;

    box-shadow:var(--shadow);

    display:none;

    grid-template-columns:1fr 1fr;

    gap:40px;

}

.mega-column{

    display:flex;

    flex-direction:column;

    gap:12px;

}

.mega-column h4{

    margin-bottom:10px;

}

.mega-parent:hover .mega-menu{

    display:grid;

}





/* ========================================
   MOBILE TOGGLE
======================================== */

.mobile-toggle{

    display:none;

    flex-direction:column;

    gap:5px;

    background:none;

    border:none;

    cursor:pointer;

}

.mobile-toggle span{

    width:26px;

    height:2px;

    background:var(--navy);

    transition:.3s;

}





/* ========================================
   FOOTER
======================================== */

.footer{

    background:var(--navy);

    color:#fff;

    padding:100px 0 40px;

}

.footer-grid{

    display:grid;

    grid-template-columns:
    2fr
    1fr
    1fr
    1fr
    1fr
    2fr;

    gap:40px;

}

.footer-logo{

    font-size:1.8rem;

    font-weight:800;

    color:#fff;

    display:inline-block;

    margin-bottom:20px;

}

.footer-company p{

    color:#CBD5E1;

    margin-bottom:30px;

}

.footer-column h4{

    margin-bottom:20px;

    color:#fff;

}

.footer-column ul{

    display:flex;

    flex-direction:column;

    gap:12px;

}

.footer-column a{

    color:#CBD5E1;

    transition:.3s;

}

.footer-column a:hover{

    color:#fff;

}

.social-links{

    display:flex;

    gap:12px;

}

.social-links a{

    width:42px;

    height:42px;

    display:flex;

    align-items:center;

    justify-content:center;

    border-radius:50%;

    background:
    rgba(255,255,255,.08);

    color:#fff;

    transition:.3s;

}

.social-links a:hover{

    background:var(--primary);

    transform:translateY(-3px);

}


.newsletter-form{

    margin-top:20px;

    display:flex;

    flex-direction:column;

    gap:12px;

}

.newsletter-form input{

    padding:14px;

    border:none;

    border-radius:12px;

    outline:none;

}

.newsletter-form button{

    padding:14px;

    border:none;

    border-radius:12px;

    background:var(--primary);

    color:#fff;

    cursor:pointer;

    transition:.3s;

}

.newsletter-form button:hover{

    background:var(--primary-dark);

}


.footer-bottom{

    margin-top:70px;

    padding-top:30px;

    border-top:
    1px solid rgba(255,255,255,.1);

    display:flex;

    justify-content:space-between;

    align-items:center;

    gap:20px;

}

.footer-bottom p{

    color:#94A3B8;

}

.footer-bottom-links{

    display:flex;

    gap:20px;

}

.footer-bottom-links a{

    color:#94A3B8;

}

.footer-bottom-links a:hover{

    color:#fff;

}







/* ========================================
   TABLET
======================================== */

@media(max-width:992px){

    .menu{
        gap:20px;
    }

    .footer-grid{
        grid-template-columns:1fr 1fr;
    }

}

/* ========================================
   MOBILE
======================================== */

@media(max-width:768px){

    .nav-menu{

        position:fixed;

        top:85px;

        left:0;

        width:100%;

        background:#ffffff;

        padding:25px;

        box-shadow:
        0 15px 40px rgba(0,0,0,.08);

        display:none;

        z-index:998;

    }

    .nav-menu.active{

        display:block;

    }

    .menu{

        flex-direction:column;

        align-items:flex-start;

        gap:20px;

    }

    .mobile-toggle{

        display:flex;

    }

    .navbar .btn-primary{

        display:none;

    }
    
    .mega-menu{

    position:static;

    width:100%;

    display:block;

    box-shadow:none;

    padding:15px 0 0;

    background:transparent;

}

.mega-column{

    margin-bottom:20px;

}

    .btn-primary{
        display:none;
    }

    .footer-grid{
        grid-template-columns:1fr;
    }

    section{
        padding:70px 0;
    }

}

.footer-grid{

    grid-template-columns:1fr;

}

.footer-bottom{

    flex-direction:column;

    text-align:center;

}


main{
    padding-top:85px;
}


/* ========================================
   HERO SECTION
======================================== */

.hero{

    position:relative;

    overflow:hidden;

    min-height:100vh;

    display:flex;

    align-items:center;

}

.hero-grid{

    display:grid;

    grid-template-columns:1fr 1fr;

    align-items:center;

    gap:80px;

}

.hero-content{

    position:relative;

    z-index:2;

}

.hero-badge{

    display:inline-flex;

    align-items:center;

    padding:10px 18px;

    border-radius:999px;

    background:
    rgba(91,95,251,.1);

    color:var(--primary);

    font-weight:600;

    margin-bottom:25px;

}

.hero-content p{

    font-size:1.15rem;

    max-width:600px;

    margin-top:25px;

}

.hero-buttons{

    display:flex;

    gap:15px;

    margin-top:35px;

}

.hero-stats{

    display:flex;

    gap:20px;

    margin-top:50px;

}

.stat-card{

    background:#fff;

    padding:20px;

    border-radius:20px;

    box-shadow:var(--shadow);

    min-width:120px;

}

.stat-card h3{

    color:var(--primary);

}

.hero-visual{

    display:flex;

    justify-content:center;

    align-items:center;

    position:relative;

}


/* ========================================
   MESH GRADIENT
======================================== */

.mesh-gradient{

    position:absolute;

    inset:0;

    z-index:0;

    background:

    radial-gradient(
        circle at 20% 20%,
        rgba(91,95,251,.35),
        transparent 40%
    ),

    radial-gradient(
        circle at 80% 20%,
        rgba(0,183,255,.25),
        transparent 35%
    ),

    radial-gradient(
        circle at 50% 90%,
        rgba(131,56,236,.25),
        transparent 35%
    );

    filter:blur(80px);

    animation:floatGradient 10s ease infinite alternate;

}

@keyframes floatGradient{

    from{
        transform:translateY(0);
    }

    to{
        transform:translateY(-40px);
    }

}



@media(max-width:768px){

    .hero-grid{

        grid-template-columns:1fr;

        text-align:center;

        gap:40px;

    }

    .hero-buttons{

        justify-content:center;

    }

    .hero-stats{

        flex-direction:column;

        align-items:center;

    }

    #three-container{

        height:350px;

    }

}


/* ========================================
   TRUSTED BY
======================================== */

.trusted-section{

    padding:60px 0;

    border-top:1px solid #eef2f7;

    border-bottom:1px solid #eef2f7;

}

.section-heading{

    text-align:center;

    margin-bottom:40px;

}

.section-heading span{

    color:var(--slate);

    font-size:.9rem;

    font-weight:700;

    letter-spacing:2px;

}

.logo-slider{

    overflow:hidden;

}

.logo-item{

    display:flex;

    align-items:center;

    justify-content:center;

    height:80px;

    font-size:1.25rem;

    font-weight:700;

    color:#94A3B8;

    transition:.3s;

}

.logo-item:hover{

    color:var(--primary);

}



/* ========================================
   FEATURES SECTION
======================================== */

.features-section{

    background:#F8FAFC;

}

.section-title{

    text-align:center;

    max-width:800px;

    margin:0 auto 70px;

}

.section-title h2{

    margin-top:20px;

}

.section-title p{

    margin-top:20px;

    font-size:1.1rem;

}

.section-tag{

    display:inline-flex;

    padding:10px 18px;

    border-radius:999px;

    background:
    rgba(91,95,251,.1);

    color:var(--primary);

    font-weight:600;

}

.features-grid{

    display:grid;

    grid-template-columns:
    repeat(3,1fr);

    gap:30px;

}


.feature-card{

    background:
    rgba(255,255,255,.65);

    backdrop-filter:blur(20px);

    -webkit-backdrop-filter:blur(20px);

    border:
    1px solid rgba(255,255,255,.5);

    padding:35px;

    border-radius:24px;

    box-shadow:
    0 10px 30px rgba(0,0,0,.06);

    transition:
    transform .35s ease,
    box-shadow .35s ease;

}

.feature-card:hover{

    transform:
    translateY(-10px);

    box-shadow:
    0 20px 50px rgba(0,0,0,.12);

}


.feature-icon{

    width:70px;

    height:70px;

    border-radius:18px;

    display:flex;

    align-items:center;

    justify-content:center;

    font-size:2rem;

    background:
    linear-gradient(
        135deg,
        var(--primary),
        #7C3AED
    );

    color:white;

    margin-bottom:25px;

}

.feature-card h3{

    margin-bottom:15px;

}


@media(max-width:992px){

    .features-grid{

        grid-template-columns:
        repeat(2,1fr);

    }

}


@media(max-width:768px){

    .features-grid{

        grid-template-columns:1fr;

    }

}


/* ========================================
   PRODUCT SHOWCASE
======================================== */

.showcase-section{

    background:#ffffff;

}

.showcase-row{

    display:grid;

    grid-template-columns:1fr 1fr;

    gap:80px;

    align-items:center;

    margin-bottom:120px;

}

.showcase-row:last-child{

    margin-bottom:0;

}

.reverse .showcase-content{

    order:2;

}

.reverse .showcase-image{

    order:1;

}

.showcase-content h2{

    margin-top:20px;

    margin-bottom:20px;

}

.showcase-content p{

    font-size:1.1rem;

}

.showcase-list{

    margin-top:30px;

}

.showcase-list li{

    margin-bottom:12px;

    font-weight:500;

}


.showcase-image{

    position:relative;

}

.showcase-image img{

    width:100%;

    border-radius:24px;

    box-shadow:
    0 30px 60px rgba(0,0,0,.12);

    transition:.4s ease;

}

.showcase-image img:hover{

    transform:translateY(-10px);

}


@media(max-width:992px){

    .showcase-row{

        grid-template-columns:1fr;

        gap:40px;

    }

    .reverse .showcase-content,
    .reverse .showcase-image{

        order:unset;

    }

}



/* ========================================
   TESTIMONIALS
======================================== */

.testimonials-section{

    background:#F8FAFC;

}

.testimonials-slider{

    margin-top:60px;

}

.testimonial-card{

    background:#fff;

    padding:40px;

    border-radius:24px;

    box-shadow:
    0 15px 40px rgba(0,0,0,.08);

    height:100%;
    
    transition:
    transform .35s ease,
    box-shadow .35s ease;

}


.testimonial-card:hover{

    transform:translateY(-8px);

    box-shadow:

    0 25px 60px rgba(0,0,0,.12);

}





.stars{

    color:#F59E0B;

    font-size:1.3rem;

    margin-bottom:20px;

}

.testimonial-card p{

    font-size:1.05rem;

    margin-bottom:30px;

}

.testimonial-author h4{

    margin-bottom:5px;

}

.testimonial-author span{

    color:var(--slate);

}


/* ========================================
   CTA SECTION
======================================== */

.cta-section{

    background:#ffffff;

}

.cta-box{

    text-align:center;

    padding:80px;

    border-radius:32px;

    background:
    linear-gradient(
        135deg,
        #5B5FFB,
        #7C3AED
    );

    color:#fff;

    position:relative;

    overflow:hidden;

}

.cta-box h2{

    margin-top:20px;

    margin-bottom:20px;

}

.cta-box p{

    max-width:700px;

    margin:0 auto;

    color:
    rgba(255,255,255,.85);

    font-size:1.1rem;

}

.cta-buttons{

    margin-top:40px;

    display:flex;

    justify-content:center;

    gap:20px;

    flex-wrap:wrap;

}


.cta-box .btn-primary{

    background:#fff;

    color:var(--primary);

}

.cta-box .btn-primary:hover{

    background:#f3f4f6;

}

.cta-box .btn-secondary{

    border:1px solid rgba(255,255,255,.3);

    color:#fff;

}

.cta-box .btn-secondary:hover{

    background:
    rgba(255,255,255,.1);

}


.cta-box::before{

    content:"";

    position:absolute;

    width:400px;

    height:400px;

    background:
    rgba(255,255,255,.15);

    border-radius:50%;

    top:-200px;

    right:-100px;

    filter:blur(40px);

}

.cta-box::after{

    content:"";

    position:absolute;

    width:300px;

    height:300px;

    background:
    rgba(255,255,255,.1);

    border-radius:50%;

    bottom:-150px;

    left:-100px;

    filter:blur(40px);

}


.cta-box{

    padding:50px 25px;

}


/* ========================================
   SOFTWARE PRODUCTS PAGE
======================================== */

.products-hero{

    text-align:center;

    padding:140px 0 100px;

    background:#F8FAFC;

}

.products-hero-content{

    max-width:900px;

    margin:auto;

}

.products-hero-content p{

    max-width:700px;

    margin:25px auto 0;

    font-size:1.1rem;

}

.software-grid-section{

    background:#fff;

}

.software-grid{

    display:grid;

    grid-template-columns:
    repeat(3,1fr);

    gap:30px;

}


.software-card{

    background:#fff;

    border-radius:24px;

    padding:35px;

    box-shadow:
    0 10px 30px rgba(0,0,0,.06);

    transition:
    transform .35s ease,
    box-shadow .35s ease;

}

.software-card:hover{

    transform:
    translateY(-10px);

    box-shadow:
    0 25px 60px rgba(0,0,0,.12);

}

.software-icon{

    width:70px;

    height:70px;

    border-radius:18px;

    display:flex;

    align-items:center;

    justify-content:center;

    font-size:2rem;

    background:
    linear-gradient(
        135deg,
        var(--primary),
        #7C3AED
    );

    color:white;

    margin-bottom:25px;

}

.software-card h3{

    margin-bottom:15px;

}

.software-card a{

    display:inline-block;

    margin-top:20px;

    color:var(--primary);

    font-weight:600;

}


@media(max-width:992px){

    .software-grid{

        grid-template-columns:
        repeat(2,1fr);

    }

}

@media(max-width:768px){

    .software-grid{

        grid-template-columns:1fr;

    }

}

/* ========================================
   COMPARISON TABLE
======================================== */

.comparison-section{

    background:#F8FAFC;

}

.comparison-table-wrapper{

    overflow-x:auto;

    margin-top:50px;

}

.comparison-table{

    width:100%;

    border-collapse:collapse;

    background:#fff;

    border-radius:24px;

    overflow:hidden;

    box-shadow:
    0 10px 30px rgba(0,0,0,.08);

}

.comparison-table th{

    background:var(--primary);

    color:#fff;

    padding:20px;

    text-align:center;

}

.comparison-table td{

    padding:20px;

    border-bottom:
    1px solid #eef2f7;

    text-align:center;

}

.comparison-table td:first-child{

    text-align:left;

    font-weight:600;

}


/* ========================================
   BENEFITS
======================================== */

.benefits-grid{

    display:grid;

    grid-template-columns:
    repeat(4,1fr);

    gap:30px;

}

.benefit-item{

    background:#fff;

    padding:35px;

    border-radius:24px;

    box-shadow:
    0 10px 30px rgba(0,0,0,.06);

}

.benefit-item h3{

    margin-bottom:15px;

}


@media(max-width:992px){

    .benefits-grid{

        grid-template-columns:
        repeat(2,1fr);

    }

}

@media(max-width:768px){

    .benefits-grid{

        grid-template-columns:1fr;

    }

}

/* ========================================
   CUSTOM PRODUCT PAGE
======================================== */

.product-hero{

    padding:140px 0 100px;

    background:#F8FAFC;

}

.product-hero-grid{

    display:grid;

    grid-template-columns:1fr 1fr;

    gap:80px;

    align-items:center;

}

.product-content p{

    margin-top:25px;

    font-size:1.1rem;

}

.product-actions{

    margin-top:35px;

    display:flex;

    gap:15px;

    flex-wrap:wrap;

}

.product-image img{

    width:100%;

    max-width:600px;

    margin-left:auto;

}


/* ========================================
   PRODUCT GALLERY
======================================== */

.gallery-section{

    background:#fff;

}

.product-gallery img{

    width:100%;

    border-radius:24px;

    box-shadow:
    0 20px 50px rgba(0,0,0,.1);

}

/* ========================================
   SPECIFICATIONS
======================================== */

.specs-section{

    background:#F8FAFC;

}

.specs-grid{

    display:grid;

    grid-template-columns:
    repeat(3,1fr);

    gap:30px;

}

.spec-item{

    background:#fff;

    padding:30px;

    border-radius:20px;

    box-shadow:
    0 10px 30px rgba(0,0,0,.06);

}

.spec-item strong{

    display:block;

    margin-bottom:10px;

}

/* ========================================
   INQUIRY FORM
======================================== */

.inquiry-section{

    background:#fff;

}

.product-form{

    max-width:700px;

    margin:auto;

    display:flex;

    flex-direction:column;

    gap:20px;

}

.product-form input,
.product-form textarea{

    padding:16px;

    border:1px solid #E2E8F0;

    border-radius:14px;

}

.product-form button{

    align-self:flex-start;

}


@media(max-width:992px){

    .product-hero-grid,
    .specs-grid{

        grid-template-columns:1fr;

    }

}









