*{
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    font-size: 100%;
    cursor: url(../img/cursor.svg) 10 10, auto;
}

body{
    font-family: "tenon", sans-serif;
    font-style: normal;
}

@font-face {
    font-family: kranafata;
    src: url("fonts/kranafatdemo-a.woff2");
}

@font-face{
    font-family: kranafatb;
    src: url("fonts/kranafatdemo-b.woff2");
}
 
@media (max-width: 992px){
    :root{
        font-size: 15px;
    }
}

@media (max-width: 576px){
    :root{
        font-size: 14px;
    }
}

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

:root{
    --primary-color: #FFFFFF;
    --secondary-color: #0062E3;
}

/* ======== Grid ======== */

.container-fluid{
    padding-left: 2rem;
    padding-right: 2rem;
}

.row{
    --bs-gutter-x: 1rem
}

@media (max-width:992px){
    .container-fluid {
        padding-left: 1.5rem;
        padding-right: 1.5rem;
    }
}

/* ======== Header ======== */

header{
    position: fixed;
    width: 100%;
    top: 0;
    left: 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 5rem;
    padding: 0 2rem;
    font-size: 1.5rem;
    color: var(--secondary-color);
    background-color: var(--primary-color);
    z-index: 10;
}

@media (max-width:992px){
    header {
        padding: 0 1.5rem;
    }
}

header nav ul{
    display: flex;
    list-style: none;
}

header nav ul li{
    margin-left: 1.5rem;
}

@media (max-width: 576px){
    header nav ul li{
        margin-left: 1rem;
    }
}

/* ======== Main ======== */

main {
    margin-top: 5rem;
}

main.home{
    margin-top: 25rem;
}

main.work{
    padding-top: 2rem 0;
}

main.about{
    padding: 2rem;
}

main.single{
    padding: 2rem 0;
}

@media (max-width:992px){
    main.home{
        margin-top: 55rem;
    }

    main.work {
        padding-top: 1.5rem;
    }

    main.about{
        padding: 1.5rem 0;
    }

    main.single{
        padding: 1.5rem 0;
    }

}

@media (max-width:576px){
    main.home{
        margin-top: 50rem;
    }
}

/* ======== Main * intro ======== */

.main-intro{
    line-height: 0.95;
    width: 100%;
    height: auto;
    display: block;
}

.main-intro .type-a{
    font-family: kranafata;
    font-size: 12.3vw;
    color: var(--secondary-color);
}

.main-intro .type-b{
    font-family: kranafatb;
    font-size: 12.3vw;
    color: var(--secondary-color);

}

@media (max-width:992px){

    .main-intro {
        margin-top: 8rem;
        line-height: 0.80;
    }

    .main-intro .type-a {
        font-size: 12.8vw;
    }

    .main-intro .type-b {
        font-size: 12.8vw;
    }
}

@media (max-width:576px){

    .main-intro {
        line-height: 0.80;
    }

    .main-intro .type-a {
        font-size: 13vw;
    }

    .main-intro .type-b {
        font-size: 13vw;
    }
}

.main-intro span{
    display: inline-block;
    transition: transform .2s ease;

}

.main-intro span:hover{
    transform: translateY(-1rem);
}

/* ======== About ======== */

.about section + section{
    padding-top: 2rem;
    margin-top: 2rem;
    color: var(--secondary-color);
}

@media (max-width:992px){
    .about section + section{
        padding-top: 1.5rem;
        margin-top: 1.5rem;
    }
}

.about-text{
    font-size: 2.5rem;
    color: var(--secondary-color);
}

.about-subtitle{
    font-size: 1.25rem;
}

@media (max-width:992px){
    .about-text{
        font-size: 1.75rem;
        line-height: 1.3;
        margin-left: 2rem;
        margin-right: 2rem;
    }
}

@media (max-width:992px){
    .about-subtitle{
        margin-bottom: 1rem;
        margin-left: 2rem;
        margin-right: 2rem;
    }
}

.about-list{
    list-style: none;
    font-size: 1.25rem;
    line-height: 1.4;
}

.about-list + .about-list{
    margin-top: 1.25rem;
}

.about-experience{
    border-top: 1px solid var(--secondary-color);
}

.about-formation{
    border-top: 1px solid var(--secondary-color);
}

.about-courses{
    border-top: 1px solid var(--secondary-color);
}

@media (max-width:992px){
    
    .about-list{
        font-size: 1rem;
        margin-left: 2rem;
        margin-right: 2rem;
    }

}

/* ======== Work * Card ======== */

.work .card{
    margin-bottom: 2rem;
}

@media (max-width:992px){
    .work .card{
        margin-bottom: 1.5rem;
    }
}

.work .card-image{
    width: 100%;
    padding-bottom: 60%;
    background-size: cover;
    background-position: center;
    margin-bottom: 0.5rem;
}


@media (max-width:992px){
    .work .card-image{
        margin-bottom: 1rem;
    }
}

.work .card-title{
    font-size: 1.25rem;
    font-weight:bold;
    line-height: 1.3;
    margin-bottom: 0.2rem;
    color: var(--secondary-color);
}

.work .card-headline{
    color: var(--secondary-color);
}

.work .card-text{
    font-size: 1rem;
    line-height: 1.4;
}
/* ======== Single ======== */

.single-info{
    position: sticky;
    top: 7rem;
}

@media (max-width: 992px){
    .single-info{
        top: 6.5rem;
    }
}

@media (max-width: 576px){
    .single-info{
        position: static;
    }
}

.single-title{
    font-weight: 600;
    font-size:2rem;
    line-height: 1;
    margin-bottom: 0.5rem;
    color: var(--secondary-color);
}

@media (max-width: 992px){
    .single-title{
        font-size: 2rem;
        margin-bottom: 2rem;
        line-height: 1.2;
    }
}

.single-tagline{
    font-size:1.4rem;
    margin-top: 1.5rem;
    margin-bottom: 2rem;
    color: var(--secondary-color);
    list-style: none;
}

.single-text{
    color: var(--secondary-color);
    font-size: 1.4rem;
}

.single-text-2{
    color: var(--secondary-color);
    font-size: 1.4rem;
    margin-top: 1rem;
}

@media (max-width: 576px){
    .single-tagline{
        margin-bottom: 1.5rem;
    }

    .single-text-2{
        margin-bottom: 2.5rem;
    }
}

.single-images{
    list-style:none;
    padding: 0;
}

.single-image + .single-image{
    margin-top: 1rem;
}

.single-image img{
    width: 100%;
    height: auto;
    display:block
}

@media (max-width: 576px){
    .single-image img{
        margin-bottom: 1.5rem;
        margin-left: 0;
    }
}

/* ======== Footer ======== */

footer{
    background-color: var(--secondary-color);
    font-size: 1.5rem;
    color: var(--primary-color);
    padding-bottom: 1rem;
}

footer ul{
    margin-top: 1rem;
    list-style: none;
}

footer .text-end{
    text-align: right;
}

.socials{
    text-align: end;
}

@media (max-width: 576px){
    footer {
        font-size: 1rem;
    }

    .socials{
        text-align: left;
    }
}
