@import url('https://fonts.googleapis.com/css2?family=Lexend:wght@100..900&family=Alexandria:ital,wght@0,300..900;1,300..900&display=swap');

@import url('./colors.css');
@import url('./text.css');

:root {
    padding: 0;
    margin: 0;
}

* {
    font-family: 'Alexandria', sans-serif;
}

body {
    background-color: var(--background-color);
    color: var(--text-color);
    transition-duration: 150ms;
    padding: 32px 20%;
}

body > *+* {
    margin-top: 32px;
}


nav {
    padding: 0;
    margin: 0;
}

.grow {
    flex-grow: 1;
}


/************ NAVBARS ************/

nav#navbar {
    position: sticky;
    top: 32px;
    background-color: var(--block-color-faded);
    backdrop-filter: blur(16px);
    border: solid 2px var(--block-border-color);
    border-radius: 16px;
    user-select: none;
    height: 64px;
    z-index: 100;
}

#navbar ul {
    display: flex;
    padding: 0 16px;
    margin: 0;
}

#navbar ul li {
    display: inline-block;
    height: 64px;
}

#navbar ul li a {
    color: var(--block-text-color);
    font-weight: 600;
    text-decoration: underline 2px transparent;
    padding: 0 16px;
    height: 64px;
    line-height: 64px;
    vertical-align: top;
    transition-duration: 150ms;
}

#navbar ul li img {
    height: 24px;
    width: auto;
    margin: 20px;
}

#navbar ul li.navTitle a {
    font-weight: 700;
}

#navbar ul li:hover a {
    text-decoration-color: var(--color-primary);
}


/************ HEADER ************/

header {
    display: flex;
    text-align: left;
    user-select: none;
    box-sizing: border-box;
}

header > div {
    align-items: stretch;
    align-self: center;
    height: fit-content;
}

header > *+* {
    margin-left: 48px;
}

header > #profilePictureContainer {
    display: flex;
    justify-content: center;
    background-color: green;
    border-radius: 16px;
    aspect-ratio: 5 / 6;
    width: 25%;
    overflow: hidden;
}

header img#profilePicture {
    height: 100%;
    max-width: none;
    border-radius: 0;
}

header h1 {
    text-align: left
}

header .subtitle {
    color: var(--text-tertiary-color);
    font-size: 1em;
    font-weight: 500;
}


header .buttons {
    padding: 0;
}

.buttons li {
    display: inline-block;
    padding: 0;
    box-sizing: border-box;
    transition-duration: 300ms;
}

.buttons > *+* {
    margin-left: 12px;
}

.buttons li a {
    cursor: pointer;
    color: var(--text-color);
    font-size: 14px;
    font-weight: 500;
    text-decoration: underline 2px transparent;
    line-height: 48px;
    box-sizing: border-box;
    transition-duration: 300ms;
}

.buttons li.main {
    background-color: var(--color-primary);
    border-color: var(--color-primary);
    border-radius: 24px;
}

.buttons li.main a {
    color: white;
    font-weight: 600;
    padding: 4px 24px;
}

.buttons li:not(.main) a:hover {
    text-decoration-color: var(--color-primary);
}


/************ MAIN ************/


#content {
    flex-grow: 1;
    padding: 0;
    text-align: center;
}


#content > *+* {
    margin-top: 24px;
}

section:not(.columns, .grid) > *+* {
    margin-top: 24px;
}

.scroll > * {
    opacity: 0;
    transform: translateY(100px);
    transition: all .5s ease-out;
}

.animated {
    opacity: 1;
    transform: translateY(0);
}


section ul, section ol {
    border: solid 2px var(--block-border-color);
    border-radius: 12px;
    text-align: left;
    padding: 16px;
}

section ul li {
    font-size: 15px;
    list-style-type: '➜ ';
    list-style-position: inside;
}

section ol li {
    list-style-position: inside;
}


.grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 12px;
}

.grid > * {
    flex: 1 1 calc(33.333% - 12px);
    text-align: center;
    user-select: none;
    box-sizing: border-box;
}

.grid > *:not(img, video, iframe) {
    background-color: var(--block-color);
    border: 2px solid var(--block-border-color);
    border-radius: 16px;
    padding: 24px;
}

.grid-2 > * {
    flex: 1 1 calc(50% - 12px);
}

.grid-4 > * {
    flex: 1 1 calc(25% - 12px);
}

.grid > .no-padding {
    padding: 0;
}

.grid * {
    margin: 0;
    overflow: hidden;
}

.grid > * > *+* {
    margin: 0;
    margin-top: 8px;
}

.grid img:not(.icon, .skillicons) {
    height: 100%;
    width: auto;
}

.grid ul {
    text-align: left;
    border: none;
    padding: 0;
}

.grid ul li {
    list-style-type: disc;
}


.gallery {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.gallery > * {
    flex: 1 1 33.333%;
    background-color: var(--block-color);
    text-align: center;
    user-select: none;
    box-sizing: border-box;
}

.gallery > *:not(img) {
    padding: 24px;
}

.gallery > img {
    border-radius: 0;
}

.gallery-2 > * {
    flex: 1 1 50%;
}

.gallery > .no-padding {
    padding: 0;
}

.gallery * {
    margin: 0;
    overflow: hidden;
}

.gallery > * > *+* {
    margin: 0;
    margin-top: 8px;
}

.gallery img:not(.icon, .skillicons) {
    height: 100%;
    width: auto;
}

.gallery ul {
    text-align: left;
    border: none;
    padding: 0;
}

.gallery ul li {
    list-style-type: disc;
}


.columns {
    display: flex;
    align-items: stretch;
    gap: 24px;
    text-align: left;
}

.columns > *:not(hr) {
    flex: 1 1 calc(50% - 24px);
}

.columns > hr {
    background-color: var(--block-border-color);
    border: none;
    width: 2px;
    align-self: stretch;
}

.columns > * > *+* {
    margin: 0;
    margin-top: 16px;
}

.columns h2 {
    color: var(--text-tertiary-color);
    text-transform: none;
    text-align: center;
}

.description {
    text-align: left;
    font-style: italic;
}

.box {
    background-color: var(--block-color);
    border: 2px solid var(--block-border-color);
    border-radius: 16px;
    text-align: left;
    user-select: none;
    box-sizing: border-box;
    padding: 8px 24px;
}



/************ FOOTER ************/

footer {
    background-color: var(--block-color);
    border: solid 2px var(--block-border-color);
    border-radius: 16px;
    padding: 32px;
}

footer h3 {
    margin-top: 0;
}

footer ul {
    padding: 0;
}

footer ul li {
    list-style-type: none;
}


/************ ELEMENTS ************/

select {
    background-color: var(--button-color);
    color: var(--button-text-color);
    border: none;
    border-radius: 24px;
    outline: none;
    height: 48px;
    padding: 0 20px;
    appearance: none;
    -moz-appearance: none;
    -webkit-appearance: none;
}

iframe, video {
    border-radius: 16px;
    width: 100%;
    height: auto;
}

iframe.video, video.video {
    aspect-ratio: 1 / 0.5625;
}

#photos .gallery {
    background-image: url('../assets/pf_img/voiture.jpg');
    background-position: center;
    background-size: cover;
    padding: 96px 128px;
}

#photos .gallery > * {
    background-color: var(--block-color-faded);
    font-size: .8em;
}


.magnify {
    cursor: pointer;
    transition-duration: 300ms;
}

.magnify:hover {
    box-shadow: 0 10px 15px -3px #0000001a;
    scale: 105%;
}

.gallery .magnify:hover {
    border-radius: 24px;
    z-index: 500;
}


@keyframes magnify {
    0% {
        scale: 100%;
    }

    100% {
        scale: 105%;
    }
}

@keyframes focus {
    0% {
        scale: 100%;
    }

    66.66% {
        scale: 95%;
    }

    100% {
        scale: 97.5%;
    }
}

@keyframes unfocus {
    0% {
        scale: 97.5%;
    }

    100% {
        scale: 100%;
    }
}



/***********************************/

@media screen and (max-width: 960px) {
    body {
        padding: 16px;
    }

    #content:not(.mainPage) {
        padding: 0;
    }

    #photos .gallery {
        padding: 32px;
    }
}

@media screen and (max-width: 560px) {
    body > *+* {
        margin-top: 16px;
    }

    #navbar ul li:not(.stayOnMobile, .grow) {
        display: none;
    }

    header {
        flex-wrap: wrap;
        text-align: center;
    }

    header h1, header .description {
        text-align: center;
    }

    header > *+* {
        margin-left: 0;
        margin-top: 24px;
    }

    header > #profilePictureContainer {
        width: 100%;
    }


    .buttons li {
        display: block;
        width: fit-content;
        margin-inline: auto;
    }


    main.scroll {
        display: block;
    }

    #content > *+* {
        margin-top: 32px;
    }

    #content:not(.mainPage) {
        padding: 0;
    }

    .scroll #content > * {
        padding: 0;
    }

    .columns {
        display: block;
    }

    .grid > *, #photos .gallery > * {
        flex: 1 1 100%;
    }

    .grid-4 > * {
        flex: 1 1 calc(50% - 12px);
    }
}