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

* {
    cursor: url('../img/mouse/mouse.png') 0 0, auto;
  }

:root {
    --margin-grid: 2rem;
    font-family: 'ABCStefan', Arial, Helvetica, sans-serif;
}

@font-face {
    font-family: 'ABCStefan';
    src: url('fonts/ABCStefan-Simple-Trial.woff2') format('woff2');
    font-weight: normal;
    font-style: normal;
}

@media (max-width: 992px) {
    :root {
        --margin-grid: 1.5rem;
    }
}

@media (max-width: 576px) {
    :root {
        --margin-grid: 1rem;
    }
}

.container-fluid {
    padding-left: var(--margin-grid);
    padding-right: var(--margin-grid);
}

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

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

body {
    color: #FFFFFF;
    background-color: #0043FF;
    font-family: "quasimoda", sans-serif;
}

body.white-background {
    color: #0043FF;
    background-color: white;
    cursor: url('../img/mouse/mouse.png') 0 0, auto;
}

body.white-background * {
    cursor: url('../img/mouse/mouse-blue.png') 0 0, auto !important;
  }
/* ================ HEADER ================ */

header {
    position: fixed;
    width: 100%;
    top: 0;
    left: 0;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    height: 4rem;
    padding: 0 var(--margin-grid);
    z-index: 100;
}

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

header nav a {
    font-family: "quasimoda", sans-serif;
    transition: font-family 0.3s ease;
}

header nav a:hover {
    font-family: "ABCStefan", Arial, Helvetica, sans-serif;
}

header.with-logo {
    justify-content: space-between;
    padding-left: var(--margin-grid);
    padding-right: var(--margin-grid);
}

header .logo {
    display: flex;
    align-items: center;
}

header .logo img {
    width: 5.5rem;
    height: auto;
    display: block;
}

/* ================ MAIN ================ */
main {
    margin-top: 4rem;
    min-height: calc (100dvh - 4rem);
}

/* ================ HOME ================ */
main.home {
    display: flex;
    justify-content: center;
    align-items: flex-end;
    padding: var(0 0 --margin-grid);
    height: calc(100dvh - 4rem);
}

main.home .home-image {
    width: 100%;
}

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

/* ================ WORK ================ */


main.list {  
    display: flex;
    align-items: flex-end;
    min-height: calc(100dvh - 4rem);
    padding-bottom: 1.5rem;
}

main.list .card {
    padding-bottom: 1rem;
    margin-bottom: 1rem;
    border-bottom: 1px solid #0043FF;
}

main.list .card .row {
    display: flex;
    align-items: center;
}

main.list .card .card-title {
    font-family: "quasimoda", sans-serif;
    font-weight: 600;
    font-size: 2rem;
}

main.list .card .card-type {
    font-size: 0.8rem;
}

main.list .card .card-date {
    font-size: 0.8rem;
    text-align: right;
}

@media (max-width: 576px) {
    main.list .card .card-title {
        margin-bottom: 0.5rem;
        font-size: 1.5rem;
    }
}

/* ================ PROJECTS ================ */
main.project .card {
    border: none;
    padding-top: 6rem;
    align-items: flex-end;
}

main.project .info-row {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
}

main.project .card-title {
    font-size: 2rem;
    font-weight: 600;
    color: #0043FF;
    font-family: "quasimoda", sans-serif;
}

main.project .card-meta {
    font-size: 0.9rem;
    color: #0043FF;
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
}

@media (max-width: 768px) {
    main.project .info-row {
        flex-direction: column;
    }
}

@media (max-width: 768px) {
    .project .row>div {
        margin-bottom: 2rem;
    }
}

/* ================ SINGLE ================ */

main.project .single-images {
    max-width: 1800px;
    margin: 0 auto;
    padding-top: 1.5rem;
    padding-bottom: 1.5rem;
}

main.project .single-images img {
    display: block;
    width: 100%;
    margin: 0 auto 1rem auto;
    height: auto;
}

main.project .single-slideshow {
  position: relative;
  width: 100%;
  aspect-ratio: 4/2.5;
  overflow: hidden;
  margin-bottom: 1.5rem;
}

main.project .single-slideshow img {
  position: absolute;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transition: opacity 0.1s ease-in-out;
}

main.project .single-slideshow img.active {
  opacity: 1;
}
/* ================ ABOUT ================ */
main.about {
    display: flex;
    align-items: flex-end;
    min-height: calc(100dvh - 4rem);
    padding-bottom: 2rem;
}

main.about .container-fluid {
    font-size: 2.5rem;
}

main.about .about-intro {
    margin-bottom: 4rem;
}

main.about .about-bottom {
    font-size: 1rem;
    margin-top: 2rem;
}

@media (max-width: 576px) {
    .about-bottom {
        flex-direction: column;
    }
}

main.about .about-contact {
    font-size: 1rem;
    line-height: 1.6;
}

@media (max-width: 768px) {
    main.about .container-fluid {
        margin-bottom: 0.5rem;
        font-size: 1.5rem;
    }
}

@media (max-width: 576px) {
    main.about .about-contact {
        font-size: 0.9rem;
    }
}

main.about .about-intro {
    margin-bottom: 2rem;
}

main.about-socials a {
    font-family: "quasimoda", sans-serif;
    transition: font-family 0.3s ease;
    text-decoration: none;
    color: inherit;
}

main.about .about-socials a:hover {
    font-family: "ABCStefan", Arial, Helvetica, sans-serif;
}

@media (max-width: 576px) {
    .about-intro {
        margin-bottom: 3rem;
    }

    .about-bottom>div {
        margin-bottom: 2rem;
    }
}