/* import font from google fonts */
@import url('https://fonts.googleapis.com/css2?family=Abel&family=Rammetto+One&display=swap');

/* reset and base styles */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    font-family: var(--font-family-default);
    font-size: var(--font-md);
    line-height: var(--line-height-default);
    color: var(--text-clr);
    transition: all var(--transition-duration) var(--transition-timing-function);
}

/** 
   CSS Variables: Color Palette & Spacing
**/

:root {
    /* Neutrals */
    --primary-clr: hsl(210 12.2% 16.1%);      /* Deep grey-black */
    --primary-clr-light: rgb(43, 49, 55);      /* Slightly lighter dark */
    --text-clr: rgb(250, 251, 252);  /* Almost pure white */
    --tertiary-clr:   rgb(255, 255, 255);  /* White */

    /* Accent */
    --accent-clr: rgb(45, 186, 78);     /* Green accent */

    /*Heading Color*/
    --heading-clr: rgb(80, 153, 227);

    /* Blue Gradient Color */
    --gradient-blue: linear-gradient(90deg, rgb(80, 153, 227), var(--accent-clr));



    /* Spacing variables */
    /*--spacing-xxs: 0.25rem;
    --spacing-xs:  0.5rem;
    --spacing-sm:  0.75rem;
    --spacing-md:  1rem;
    --spacing-lg:  1.5rem;
    --spacing-xl:  2rem;
    --spacing-xxl: 3rem;*/

    /* Font sizes */
    /*--font-xs: 0.75rem;
    --font-sm: 0.875rem;
    --font-md: 1rem;
    --font-lg: 1.5rem;
    --font-xl: 2rem;
    --font-xxl: 3rem;*/

      /* Helper: linear fluid formula
         clamp(min, calc(min + (max - min) * ((100vw - minVW) / range)), max)
      */

    /* Spacing scale with clamp(min, preferred, max) */
      --spacing-xxs: clamp(0.2rem, 0.2rem + 0.1vw, 0.25rem);
      --spacing-xs:  clamp(0.4rem, 0.4rem + 0.2vw, 0.5rem);
      --spacing-sm:  clamp(0.6rem, 0.6rem + 0.3vw, 0.75rem);
      --spacing-md:  clamp(0.8rem, 0.8rem + 0.4vw, 1rem);
      --spacing-lg:  clamp(1.2rem, 1.2rem + 0.8vw, 1.5rem);
      --spacing-xl:  clamp(1.6rem, 1.6rem + 1vw, 2rem);
      --spacing-xxl: clamp(2.4rem, 2.4rem + 1.5vw, 3rem);

      /* Font sizes */
      --font-xs:  clamp(0.7rem, 0.6rem + 0.2vw, 0.75rem);
      --font-sm:  clamp(0.8rem, 0.7rem + 0.3vw, 0.875rem);
      --font-md:  clamp(0.9rem, 0.8rem + 0.4vw, 1rem);
      --font-lg:  clamp(1.2rem, 1rem + 0.8vw, 1.5rem);
      --font-xl:  clamp(1.6rem, 1.2rem + 1vw, 2rem);
      --font-xxl: clamp(2.4rem, 1.8rem + 1.2vw, 3rem);

    /* Font weights */
    --font-normal: 400;
    --font-medium: 500;
    --font-bold: 700;
    --font-hard: 900;

    /* Border radius */
    --border-radius-sm: 0.25rem;
    --border-radius-md: 0.5rem;
    --border-radius-lg: 1rem;

    /*font-family*/
    --font-family-default: 'Able', sans-serif;

    /*line-height*/
    --line-height-default: 1.5;

    /*transition*/
    --transition-duration: 0.3s;
    --transition-timing-function: ease;

    transition: all .5s ease-in-out;
}

/* Global styles */
body {
    background-color: var(--primary-clr);
    color: var(--text-clr);
    scroll-behavior: smooth;
}

.d-none {
    display: none;
}

li, ul, a {
    list-style: none;
    text-decoration: none;
    color: var(--text-clr);
    transition: all var(--transition-duration) var(--transition-timing-function);
    &:hover {
        color: var(--accent-clr);
    }
}

section {
    padding: 100px 200px;
}

input {
    background: none;
    outline: none;
    border: none;
}

.d-md-none {
    display: none;
}

.text-gradient {
    background: var(--gradient-blue);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    color: transparent;
    display: inline-block;
}

button {
    all: unset;
}

h1, h2, h3, h4 {
    text-box-trim: trim-both;
}

.heading {
    text-align: center;
    text-transform: uppercase;
    font-size: var(--font-xl);
    font-family: 'Rammetto One', sans-serif;
    color: var(--accent-clr);
    margin-bottom: var(--spacing-xxl);
}

.btn {
    background-color: var(--accent-clr);
    color: var(--primary-clr);
    border: 1px solid var(--accent-clr);
    border-radius: var(--border-radius-md);
    padding: var(--spacing-md) var(--spacing-lg);
    font-size: var(--font-sm);
    font-weight: var(--font-bold);
    cursor: pointer;
    transition: all var(--transition-duration) var(--transition-timing-function);
    cursor: pointer;
    &:hover {
        background-color: var(--primary-clr);
        color: var(--accent-clr);
        border: 1px solid var(--accent-clr);
    }
}


/*ANIMATION*/

.scroll__bar {
    position: fixed;
    top: 90px;
    left: 0;
    width: 0px;
    height: 3px;
    background: transparent;
    z-index: 1;
}

.scroll__animation {
    animation: progress__bar both;
    animation-timeline: scroll(nearest);
}

@keyframes progress__bar {
    from {
        width: 0%;
        background: var(--gradient-blue);
    }

    to {
        width: 100%;
        background: var(--gradient-blue);
    }
}


/* Navigation styles */
.nav__bar {
    background-color: transparent;
    backdrop-filter: blur(20px);
    color: var(--text-clr);
    padding: var(--spacing-md) var(--spacing-xxl);
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: fixed;
    width: 100%;
    height: 90px;
    z-index: 1000;

    & .nav__items {
        display: flex;
        gap: var(--spacing-lg);
        justify-content: center;
        align-items: center;
        transition: all var(--transition-duration) var(--transition-timing-function);

        & .nav__links {
            position: relative;
            font-weight: var(--font-bold);
            letter-spacing: 2px;
            font-size: var(--font-sm);
            text-transform: uppercase;

            &::after {
                content: '';
                position: absolute;
                display: block;
                width: 0px;
                height: 2px;
                left: 0;
                bottom: -3px;
                background: var(--gradient-blue);
                transition: width 0.3s ease-in-out allow-discrete;
            }

            &:hover::after {
                width: 100%;
            }
        }
        & li .nav__links.current {
            color: var(--accent-clr);
        }
    }

    & .toggle__theme {
        cursor: pointer;
        & .toggle__icons {
            padding: var(--spacing-sm);
            font-size: var(--font-xl);
            transition: all .3s;

            & .light__icon {
                display: none;
            }

            & .dark__icon.activated .light__icon {
                display: none;
            }

            & .light__icon.activated .dark__icon {
                display: none;
            }
        }
    }
    
}

/*Home banner*/

.banner {
    position: relative;
    min-height: 100vh;

    &::before {
        content: '';
        position: absolute;
        display: block;
        width: 300px;
        height: 200px;
        background: var(--gradient-blue);
        top: 0;
        left: 0;
        border-radius: 0 0 100% 100%;
        filter: blur(150px);
        opacity: 0.78;
    }

    &::after {
        content: '';
        position: absolute;
        display: block;
        width: 300px;
        height: 200px;
        background: var(--gradient-blue);
        bottom: 0;
        right: 0;
        /*translate: 85%;*/
        border-radius: 0 0 100% 100%;
        filter: blur(150px);
        opacity: 0.78;
    }


    & .banner__container {
        display: flex;
        align-items: center;
        justify-content: center;
        flex-direction: column;
        min-height: 70vh;

        & .dev__img {
            width: 150px;
            box-shadow: 2px 2px 2px 2px var(--accent-clr);
            border-radius: var(--border-radius-lg);
            rotate: 0deg;
            transition: .5s;
            margin-bottom: 16px;

            &:hover {
                rotate: -8deg;
                scale: 1.2;
            }

            & img {
                width: 100%;
                border-radius: inherit;
                cursor: pointer;
            }
        }


        & .content__desc {
            margin-top: 32px;
            text-align: center;

            & .b__heading {
                font-size: var(--font-md);
                font-family: var(font-family);
                letter-spacing: var(--spacing-xs);
                text-transform: uppercase;
                font-weight: var(--font-normal);
            }

            & .tag__line span {
                font-size: var(--font-xl);
                font-family: "Rammetto One", sans-serif;
                text-transform: uppercase;         

            }

            & .sub-heading {
                padding-block: var(--spacing-xxs);
                font-size: var(--font-xs);
                letter-spacing: var(--spacing-xxs);
                text-transform: uppercase;
            }

            & .b__social-icons {
                position: absolute;
                bottom: 0px;
                left: 0;
                left: var(--spacing-xxl);
                display: inline-flex;
                margin-top: var(--spacing-xs);
                gap: var(--spacing-md);
                transition: .3s;

                & a i {
                    font-size: var(--font-md);
                }

                & a:hover {
                    margin-top: -4px;
                }

                & a:hover i {
                    color: var(--accent-clr);
                }

            }
        }

        & .skill {
            position: relative;
            display: flex;
            justify-content: center;
            align-items: center;
            margin-block-start: var(--spacing-md);
            max-width: 480px;
            flex-wrap: wrap;
            gap: var(--spacing-xs);

            & .skill__icon {
                display: inline-flex;
                justify-content: center;
                background: var(--primary-clr-light);
                padding: var(--spacing-xs);
                width: 105px;
                border-radius: var(--border-radius-sm);
                cursor: pointer;
                transition: border-left var(--transition-duration) var(--transition-timing-function);

                &:hover {
                    border-left: 1.5px solid var(--accent-clr);
                }

                & i {
                    width: 50%;
                    font-size: var(--font-md);
                    background: transparent;
                }

                & p {
                    width: calc(100% - 30%);
                    font-size: var(--font-xs);
                    background: transparent;
                   
                 }
            
            }  
        
        }
    
    }

}

/*ABOUT ME*/
.about__me {
    position: relative;

    & .about__me-wrapper {
        gap: var(--spacing-xl);
        display: flex;
        align-items: center;
        justify-content: center;

        & .about__me-content {
            position: relative;
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(min(530px, 100%), 1fr));
            grid-template-rows: auto auto;
            justify-items: center;
            max-width: 1110px;
            gap: var(--spacing-xxl);
            & .about__me-description {
                padding: var(--spacing-sm);
                font-size: var(--font-md);
                line-height: 1.8;
                max-width: 550px;
            }

            & .about__niche {
                display: flex;
                flex-wrap: wrap;
                padding: var(--spacing-xs);
                gap: var(--spacing-sm);
                justify-content: center;
                width: 500px;

                & .niche__list {
                    display: flex;
                    flex-wrap: wrap;
                    justify-content: center;
                    max-width: 550px;
                    gap: var(--spacing-md);

                    & li {
                        max-width: 140px;
                        text-wrap: wrap;
                        text-transform: capitalize;
                        font-size: var(--font-sm);
                        cursor: pointer;
                        padding: var(--spacing-md);
                        background-color: var(--primary-clr-light);
                        border-radius: var(--border-radius-md);
                        transition: all .3s;

                        &:hover{
                            margin-top: -5px;
                            border-bottom: 1px solid var(--accent-clr);
                        }
                    }
                }
            }

            & .about__me-cta {
                max-width: 550px;
                padding: var(--spacing-sm);

                & h1 {
                    color: var(--accent-clr);
                    font-size: var(--font-xl);
                    font-family: var(--font-family-default);
                    margin-bottom: var(--spacing-lg);
                }

                & .points {
                    h2 {
                        font-size: var(--font-sm);
                        color: var(--tertiary-clr);
                        text-transform: uppercase;
                        padding-block-end: var(--spacing-sm);
                    }

                    & p {
                        padding-block-end: var(--spacing-md);
                        color: hsl(from var(--text-clr) h s 75%);
                    }
                }
            }
        }
    }
}

/*Services*/

.offers__container {
    position: relative;
    & .offers__wrapper {
        position: relative;
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        gap: var(--spacing-xl);

        & .offer__card {
            width: 380px;
            padding: var(--spacing-xl);
            border-radius: var(--border-radius-md);
            background-color: var(--primary-clr-light);
            line-height: 2;
            transition: all .5s;

            & .card__title {
                font-size: var(--font-md);
                text-transform: uppercase;
                font-weight: var(--font-bold);
                letter-spacing: 2px;
                color: var(--accent-clr);
                padding-block-end: var(--spacing-lg);

            }

            & span {
                font-family: "Rammetto One", sans-serif;
                text-shadow: 3px 3px 3px var(--accent-clr);
                font-size: var(--font-lg);
                padding-block: var(--spacing-lg);
            }

            & .card__text {
                padding-block: var(--spacing-lg);

                & li {
                    list-style: circle;
                    font-size: var(--font-sm);
                    line-height: 2;
                    list-style-position: inside;
                    list-style-image: url("../images/web__assest/icons/check-square.svg");
                }
            }

            &:hover {
                margin-top: -8px;
                scale: 1.05;
                border-bottom: 1px solid var(--accent-clr);
            } 
        }
    }
}


/*Projects*/

.projects {
    position: relative;

    & .projects__container {
        display: grid;
        grid-template-columns: repeat(auto-fill, minmax(350px, 1fr));
        gap: var(--spacing-lg);
        justify-content: center;

        & .project__card {
            min-height: 400px;
            border-radius: var(--border-radius-lg);
            overflow: hidden;

            & .project__img {
                max-width: 100%;
                height: 325px;


                & img {
                    width: 100%;
                    object-fit: center;

                }
            }

            & .project__text {
                display: flex;
                justify-content: space-around;
                padding-top: var(--spacing-lg);
                background: var(--primary-clr-light);
                backdrop-filter: blur(80px);
                width: 100%;
                height: 75px;
                border-top: 1px solid var(--accent-clr);

                & p {
                    font-weight: var(--font-bold);
                    letter-spacing: 1.23px;
                    color: var(--accent-clr);
                    text-transform: capitalize;
                }

                & a {
                    text-transform: capitalize;

                    &:hover {
                        scale: 1.03;
                    }
                }
            }
        }
    }
}

/*Testinomial*/

.testinomials {
    position: relative;

    & .testinomials__slides {
        display: flex;
        justify-content: center;
        gap: var(--spacing-xxl);
        max-width: 1024px;
        border-radius: var(--border-radius-md);
        background: var(--primary-clr-light);
        padding: var(--spacing-xxl);
        cursor: pointer;
        z-index: -1;

        & .swiper-wrapper {
            position: relative;
            display: flex;
            align-items: center;
            gap: var(--spacing-xxl);

            & .swiper-slide {
                border: 1px dashed var(--accent-clr);
                padding: var(--spacing-md);
                border-radius: var(--border-radius-md);
                text-align: center;

                & .bi-quote {
                    font-size: var(--font-xl);
                    color: var(--accent-clr);
                }

                & .client__fb {
                    font-size: var(--font-md);
                    margin-bottom: var(--spacing-md);
                }

                & .client__detail {
                    padding: var(--spacing-md);

                    & .client__name {
                        font-size: var(--font-lg);
                        color: var(--accent-clr);
                        font-weight: var(--font-hard);
                        text-transform: capitalize;
                    }

                    & .client__origin {
                        font-size: var(--font-sm);
                        text-transform: capitalize;
                        color: hsl(from var(--text-clr) h s 60%);
                    }
                }
            }
        }

    }
}

/*Actions*/

.actions {
    position: relative;
    display: flex;
    justify-content: center;

    &::after {
        content: '';
        position: absolute;
        display: block;
        width: 700px;
        height: 200px;
        background: var(--gradient-blue);
        top: 0;
        right: 550px;
        /*translate: 85%;*/
        z-index: -1;
        border-radius: 0 0 100% 100%;
        filter: blur(150px);
        opacity: 0.78;
    }
    & .action {
        position: relative;
        text-wrap: wrap;
        width: 60%;
        & .side__divder {
            width: 100%;
            height: 2px;
            background: var(--accent-clr);
            margin-bottom: var(--spacing-md);
        }

        & .text__data {
            font-size: var(--font-xl);
            text-transform: uppercase;
            color: hsl(from var(--text-clr) h s 50%);
        }

    }
}

/*FAQs*/

.faqs {
    position: relative;
    & .faqs__clients {
        display: flex;
        justify-content: center;
        flex-direction: column;
        align-items: center;
        padding: var(--spacing-sm);
        gap: var(--spacing-xl);

        & .heading {
            font-weight: var(--font-normal);
            max-width: 550px;
            text-align: left;
        }

        & .faqs__list {
            max-width: 650px;

            & .faqs__dropdown {
                position: relative;
                border-bottom: 1px solid hsl(from var(--text-clr) h s 20%);
                padding-block: var(--spacing-xs);

                & .faq__menu {
                    display: flex;
                    align-items: center;
                    justify-content: space-between;
                    flex-direction: row-reverse;
                    width: 550px;
                    padding: var(--spacing-sm);

                    & .faq__toggle {
                        position: relative;
                        cursor: pointer;
                        display: inline-flex;
                        align-items: center;
                        gap: var(--spacing-xxs);
                        color: var(--accent-clr);

                        & .add__btn,
                        & .minimize__btn {
                            font-size: var(--font-lg);
                            color: var(--accent-clr);
                        }

                        & .minimize__btn {
                            display: none;
                        }
                    }

                    & h4 {
                        color: var(--text-clr);
                        text-transform: capitalize;
                        margin-bottom: var(--spacing-sm);
                        text-box-trim: trim-both;
                    }
                }

                & .faq__items {
                    font-size: var(--font-md);
                    width: 540px;
                    padding: 0 var(--spacing-sm) var(--spacing-sm);
                    display: none;
                    transition: all .3s;
                    
                }

                /* Open state */
                &.open .faq__items {
                    display: block;
                    color: hsl(from var(--text-clr) h s 55%);
                    transition: all .3s;
                }

                &.open .faq__toggle .add__btn {
                    display: none;
                }

                &.open .faq__toggle .minimize__btn {
                    display: inline-block;
                }
            }

        }
    }
}

/*contact me*/

.contact__me {
    position: relative;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--spacing-xl);

    & .text__data {
        position: relative;
        display: grid;
        grid-template-columns: repeat(1, 1fr);
        width: 350px;
        & .heading {
            position: relative;
            font-size: calc(1.2 * var(--font-xxl));
            text-align: right;
            text-box-trim: trim-both;

            & span {
                color: var(--text-clr);
                font-size: var(--font-xxl);
                font-weight: var(--font-hard);
            }
        }

        & .sub__heading {
            font-size: var(--font-md);
            line-height: 1.2;
            padding: var(--spacing-md);
            color: hsl(from var(--text-clr) h s 70%);
        }
    }

    form {
        display: flex;
        justify-content: center;
        align-items: center;
        flex-wrap: wrap;
        gap: var(--spacing-md);
        max-width: 550px;
        padding: var(--spacing-md);

        & input[type='text'] {
            flex: 0 0 250px;
            border: 1px solid var(--accent-clr);
            border-radius: var(--border-radius-md);
            padding: var(--spacing-md);
        }

        & input[type='email'] {
            flex: 0 0 250px;
            border: 1px solid var(--accent-clr);
            border-radius: var(--border-radius-md);
            padding: var(--spacing-md);
        }

        & textarea {
            width: 100%;
            background: none;
            border: 1px solid var(--accent-clr);
            outline: none;
            resize: none;
            padding: var(--spacing-md);
            border-radius: var(--border-radius-md);

        }

        & .form__btn {
            display: flex;
            align-items: center;
            width: 100%;
        }
    }
}


/*Footer*/

footer {
    position: relative;

    &::after {
        content: '';
        position: absolute;
        display: block;
        width: 700px;
        height: 200px;
        background: var(--gradient-blue);
        bottom: 0;
        left: 0;
        border-radius: 0 0 100% 100%;
        filter: blur(150px);
        opacity: 0.78;
    }

    & .ft__main {
        display: flex;
        justify-content: center;
        gap: var(--spacing-xxl);
        margin-block-end: var(--spacing-md);

        & .ft__row {
            position: relative;

            & .ft__heading {
                text-transform: capitalize;
                font-weight: var(--font-bold);
                padding-block-end: var(--spacing-md);
                letter-spacing: 1.5px;
            }

            & .ft__links {
                line-height: 2;
                text-transform: capitalize;
                font-size: var(--font-sm);
                color: hsl(from var(--text-clr) h s 70%);
                transition: all .3s;

                &:hover {
                    color: var(--accent-clr);
                }
            }

            & .ft__social {
                display: flex;
                align-items: center;
                gap: var(--spacing-sm);
                line-height: 2;

                & a {
                    color: hsl(from var(--text-clr) h s 70%);
                    transition: all .3s;
                    margin-bottom: var(--spacing-sm);

                    &:hover {
                        color: var(--accent-clr);
                        margin-top: -3px;
                    }
                }
            }
            & .ft__info {
                display: flex;
                flex-direction: column;
                & span {
                    font-size: var(--font-sm);
                    cursor: pointer;
                    color: hsl(from var(--text-clr) h s 70%);
                    line-height: 2;
                    & i {
                        margin-right: var(--spacing-xsm);
                        color: var(--accent-clr);
                    }
                }
            }
        }
    }

    & .copyrights {
        text-align: center;
        padding: var(--spacing-sm);
        background: var(--accent-clr);
    }
}


/*RESPONSIVE*/

@media (max-width: 990px) {

    .scroll__bar {
        top: 90px;
    }

    section {
        padding: 50px 100px;
    }

    .toggle__theme {
        display: none;
    }

    .nav__bar {
        
        height: 90px;
        & .toggle__menu {
            
            display: block;
            transition: all .3s ease-in-out;

            & .toggle__icons {
                font-size: var(--font-xl);
                transition: all .3s ease-in-out;

                & .close__menu {
                    display: none;
                }

                &.activated .close__menu {
                    display: block;
                }

                &.activated .open__menu {
                    display: none;
                }
            }

            & .toggle__icons i {
                font-size: var(--font-xl);
            }
        }
    }

    #menu {
        display: none;
        position: absolute;
        top: 95px;
        right: 5px;
        width: 20rem;
        text-align: center;
        padding: var(--spacing-md);
        background: var(--primary-clr-light);
        padding-block: var(--spacing-xxl);
        border-radius: 0 0 var(--border-radius-md) var(--border-radius-md);
        border-bottom: 5px solid var(--accent-clr);
        transition: display .3s ease-in-out;

        & li .nav__links {
            color: red;
            font-size: var(--font-xl);

        }

        &.activated {
            display: inline-block;
        }
    }

    .banner {
        min-height: 0;
    }

    .banner .banner__container .content__desc .b__social-icons {
        transform: translateX(200%);
    }

    .banner .banner__container {
        min-height: 30vh;
    }

    .offers__container .offers__wrapper .offer__card {
        width: 350px;
    }

    .contact__me .text__data .heading {
        width: 100%;
        text-align: center;
        justify-content: center;
    } 
}
