@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap');

/* Variables de couleur */
:root {
    --color1: #0F1B12;
    --color2: #A4C520;
    --color3: #A4C520cc;
    --color4: #F8F8FF;
    --color5: #0F1B12;
    --color6: #444444;
    --color7: #F5F2ED;
    --color8: #432121;
    --color9: #1D1D1D;
    --color10: #A8A8A8;
    --color11: #7A7A7A;
    --color12: #2C2C2C;
    --color13: #e2dcd1;
    --color14: #FFFFFF;
    --color15: #000000;
}

* { font-family: "Montserrat", Arial, sans-serif;}

body {     
    display: flex;
    flex-direction: column;
    align-items: center;
    cursor: default;
    background-color: var(--color4);
    margin: 0;
}

h2 { 
    color: var(--color1);
    font-size: 2em;
    font-weight: 400;
}

h2 span { 
    color: var(--color2);
    padding-right: 0.05em;
}

.menu {
    width: 100%;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    height: 2.5em;
    padding: 1em;
    margin: 0.2em 0 1em;
    color: var(--color5);
    position: fixed;
    top: -0.2em;
    background-color: var(--color4);
    backdrop-filter: blur(100px);
    z-index: 1;
    box-shadow: rgba(0, 0, 0, 0.04) 0px 3px 5px;
}

.title a {
    display: flex;
    height: 100%;
    flex-direction: row;
    align-items: center;
    height: 2.5em;
    text-decoration: none;
}

.title a img{
    height: 100%;
    padding: 0 0.6em 0 1em ;
}

.infos {
    display: flex;
    height: 100%;
    flex-direction: row;
    align-items: center;
    justify-content: center;
}

.infos a {
    text-decoration: none;
    color: var(--color5);
    padding: 0.2em 1em;
    font-weight: 600;
}

.infos a:hover { color: var(--color6); }

.infos a span {
    border: var(--color2) 0.15em solid;
    background-color: var(--color2);
    color: var(--color4);
    border-radius: 4em;
    padding: 0.5em 1em 0.5em;
    cursor: not-allowed;
}

.infos a span:hover {
    background-color: var(--color3);
    border: var(--color3) 0.15em solid;
}

.content1 {
    padding: 12em 0 6em 0;
    height: 100%;
    width: 100%;
}

.content1 h1{
    font-size: 4.25em;
    font-weight: 800;
    text-align: center;
    letter-spacing: 0;
    line-height: 1.2; 
}

.content1-infos {
    display: flex;
    flex-direction: row;
    justify-content: center;
}

.content1-infos a {
    padding: 1em 2em 1em;
    margin: 0 1em 5em;
    background-color: inherit;
    border-radius: 5em;
    font-size: 1em;
    font-weight: 600;
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    text-decoration: none;
}

.content1-infos a i {
    padding-right: 0.3em;
    font-size: 1.15em;
}

#executeDiag {
    border: var(--color5) 0.15em solid;
    color: var(--color5);
    cursor:not-allowed;
}

#executeDiag:hover { box-shadow: rgba(50, 50, 93, 0.25) 0px 30px 60px -12px inset, rgba(0, 0, 0, 0.3) 0px 18px 36px -18px inset; }

#more-infos {
    background-color: var(--color2);
    border: var(--color2) 0.15em solid;
    color: var(--color4);
    cursor: pointer;
}

#more-infos:hover {
    background-color: var(--color3);
    border: var(--color3) 0.15em solid;
}

.content2 {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 5em 0 5em 0;
    width: 100%;
    background-color: var(--color7);
}


.content2 p {
    font-size: 1.5em;
    font-weight: 500;
    color: var(--color6);
    text-align: center;
}

.content-video {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding-top: 5em;
    width: 70%;
}

.content-video video {
    width: 100%;
    height: auto;
    border-radius: 1em;
    box-shadow: rgba(0, 0, 0, 0.35) 0px 5px 15px;
}

.content3 {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 4em 0 0 0;
    color: var(--color8);
    height: 36em;
}

.content3 h1 { text-align: center;}

.content3 div{
    display: flex;
    flex-direction: row;
    justify-content: space-around;
    align-items: center;
}

.content3 div .content3-column {
    display: flex;
    flex-direction: column;
    align-items: center;
    height: 100%;
}

.content3 div .content3-column .content3-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 1em 1em 1em 1em;
    margin: 1em;
    border-radius: 1em;
    border: var(--color5) 0.15em solid;
    box-shadow: rgba(100, 100, 111, 0.2) 0px 7px 29px 0px;
    background-color: var(--color4);
    width: 16em;
    height: 100%;
}

.content3 div .content3-column .content3-item div{
    display: flex;
    flex-direction: column;
    align-items: center;
}

.content3-item span {
    font-size: 2.5em;
    text-align: center;
}

.content3-item-title {
    font-weight: 800;
    color: var(--color5);
    text-align: center;
    margin: 0;
    padding: 0;
}

.content3-item-titlebis {
    font-weight: 800;
    color: var(--color5);
    text-align: center;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.content3-item-title i {
    color: var(--color2);
    font-size: 0.9em;
    padding-right: 0.2em;
}

.content3-item-sub {
    font-size: 0.8em;
    font-weight: 400;
    color: var(--color6);
    text-align: center;
}

#content3-item-link:hover {
    box-shadow: rgba(50, 50, 93, 0.25) 0px 30px 60px -12px inset, rgba(0, 0, 0, 0.3) 0px 18px 36px -18px inset;
    cursor: pointer;
}

.content4 {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 5em 0 5em 0;
    color: var(--color5);
}

.content4-types { display: flex; }

.content4-profiles {
    display: flex;
    flex-direction: column;
    justify-content: start;
    border-radius: 1em;
    padding: 1em 1em 0 1em;
    margin: 1em;
    border: var(--color5) 0.15em solid;
    width: 16em;
    background-color: var(--color4);
    box-shadow: rgba(100, 100, 111, 0.2) 0px 7px 29px 0px;
}

.content4-profiles span {
    font-size: 2.5em;
    text-align: center;
}

.content4-profile-title {
    font-weight: 800;
    color: var(--color5);
    text-align: center;
}

.content4-profile-sub {
    font-size: 0.8em;
    font-weight: 400;
    color: var(--color6);
    margin-bottom: 1em;
}

.content4-profile-sub i {
    color: var(--color2);
    font-size: 0.9em;
    padding-right: 0.2em;
}

.title-small {
    color: var(--color1);
    font-weight: 450;
}

.title-small span {
    color: var(--color2);
    font-weight: 700;
}

.content5 { 
    padding: 5em 0 5em 0; 
    display: flex;
    justify-content: center;
}

#contact-form {
    display: flex;
    flex-direction: row;
    justify-content: space-around;
    align-items: center;
    background-color: var(--color15);
    color: var(--color4);
    border-radius: 1em;
    box-shadow: rgba(100, 100, 111, 0.2) 0px 7px 29px 0px;
}

#contact-form div {
    width: 50%;
    padding: 3em;
}

.title-form {
    font-size: 1.2em;
    font-weight: 800;
}

.text-form input {
    width: 92.5%;
    padding: 1em;
    border-radius: 0.8em;
    background-color: var(--color9);
    border: var(--color12) 0.15em solid;
    color: var(--color10);
    font-weight: 600;
    font-size: 1em;
}

.text-form input::placeholder {
    color: var(--color10);
    font-weight: 600;
}

.text-form p {
    color: var(--color11);
    font-weight: 500;
    font-size: 0.69em;
}

.text-form button {
    border: var(--color2) 0.15em solid;
    background-color: var(--color2);
    color: var(--color4);
    border-radius: 4em;
    margin-top: 1em;
    padding: 0.5em 1.5em 0.5em;
    font-size: 1em;
    font-weight: 600;
}

.text-form button:hover {
    background-color: var(--color3);
    border: var(--color3) 0.15em solid;
}

.content6 {
    display: flex;
    flex-direction: row;
    justify-content: space-around;
    background-color: var(--color7);
    color: var(--color5);
    width: 95%;
    margin: 2em 0 0;
    border-radius: 1em;
}

.content6 .img img {
    height: 100%;
    width: 32.5em;
    border-radius: 1em 0 0 1em;
}

.form-contact {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 2em 6em 2em 6em;
}

.form-contact .txt h1 {
    font-size: 2.5em;
    font-weight: 800;
}

.form-contact .txt p {
    font-size: 1em;
    font-weight: 600;
    color: var(--color6);
}

.form-formulaire {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 100%;
}

.form-formulaire .nom-prenom {
    width: 100%;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
}

.form-formulaire .nom-prenom input {
    width: calc(50% - 3em);
    margin: 0.5em 0 0.5em 0;
    padding: 1em;
    border-radius: 0.8em;
    background-color: var(--color4);
    border: var(--color13) 0.15em solid;
    color: var(--color15);
    font-weight: 600;
    font-size: 1em;
}

.form-formulaire input, .form-formulaire select, .form-formulaire textarea {
    width: 100%;
    margin: 0.5em 0 0.5em 0;
    padding: 1em;
    border-radius: 0.8em;
    background-color: var(--color4);
    border: var(--color13) 0.15em solid;
    color: var(--color15);
    font-weight: 600;
    font-size: 1em;
}

.form-formulaire input, .form-formulaire textarea { width: 94.5%; }

.form-formulaire textarea {
    width: 94.5%;
    max-width: 94.5%;
    min-height: 2em;
    max-height: 5em;
    resize: vertical;
}

.form-formulaire .checkbox {
    display: flex;
    flex-direction: row;
    justify-content: start;
    align-items: center;
    width: 100%;
}

.form-formulaire .checkbox label {
    width: 5000%;
    padding-left: 0.5em;
    font-size: 1em;
    font-weight: 700;
    color: var(--color6);
}

.form-formulaire .checkbox label a {
    text-decoration: none;
    color: var(--color6);
}

.form-formulaire .checkbox label a:hover {
    color: var(--color1);
    text-decoration: underline;
}

.form-formulaire button {
    border: var(--color2) 0.15em solid;
    background-color: var(--color2);
    color: var(--color4);
    border-radius: 4em;
    margin: 2em;
    padding: 0.5em 1.5em 0.5em;
    font-size: 1em;
    font-weight: 600;
}

.form-formulaire button:hover {
    background-color: var(--color3);
    border: var(--color3) 0.15em solid;
}

.content7 {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 4em 0 4em 0;
    width: 100%;
    background-color: var(--color7);
}

.content7 .content7-profilestypes {
    display: flex;
    flex-direction: row;
    justify-content: space-around;
    align-items: center;
    width: 90%;
}

.content7-profile {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 1em 1em 1em 1em;
}

.content7-profile img {
    width: 10em;
    height: 10em;
    border-radius: 50%;
    border: var(--color5) 0.15em solid;
    background-color: var(--color4);
    box-shadow: rgba(100, 100, 111, 0.2) 0px 7px 29px 0px;
}

.content7-profile img:hover {
    box-shadow: rgba(50, 50, 93, 0.25) 0px 30px 60px -12px inset, rgba(0, 0, 0, 0.3) 0px 18px 36px -18px inset;
    cursor: pointer;
}

.content7-profile-title {
    font-weight: 800;
    color: var(--color5);
    text-align: center;
    margin: 0.5em;
    padding: 0;
}

.content7-profile-sub {
    font-size: 0.8em;
    color: var(--color6);
    text-align: center;
    margin: 0;
}

.content7-citation {
    display: flex;
    flex-direction: column;
    font-size: 1.5em;
    font-weight: 500;
    color: var(--color6);
    width: 85%;
}

.content7-citationtext {
    text-align: center;
    margin-top: 2em;
}

.content7-citationtext span {
    font-weight: 900;
    color: var(--color2);
}

.content7-citationtitle {
    text-align: end;
    font-weight: 750;
    color: var(--color2);
}

.content8 {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 5em 0 5em 0;
    width: 100%;
}

.content8 h1 {
    font-size: 3em;
    font-weight: 800;
    color: var(--color9);
    text-align: center;
}

.content8 .contact {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    width: 100%;
}

.content8 .contact a {
    padding: 1em 2em 1em;
    margin: 0 1em 0;
    background-color: inherit;
    border-radius: 5em;
    font-size: 1em;
    font-weight: 700;
    text-decoration: none;
    border: var(--color5) 0.15em solid;
    color: var(--color5);
    cursor: pointer;
    box-shadow: rgba(149, 157, 165, 0.2) 0px 8px 24px;
}

.content8 .contact a:first-child { cursor: not-allowed;}
.content8 .contact a:hover { box-shadow: rgba(50, 50, 93, 0.25) 0px 30px 60px -12px inset, rgba(0, 0, 0, 0.3) 0px 18px 36px -18px inset; }

.footer {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    width: 75%;
    color: var(--color4);
    padding: 2em 0 2em 0;
}

.footer a {
    text-decoration: none;
    color: var(--color9);
    font-size: 1em;
    font-weight: 600;
}

.footer a:hover { color: var(--color6); }

#loading-screen {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: var(--color14);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    z-index: 1000;
    transition: opacity 0.5s ease-out;
    opacity: 1;
}

#loading-screen.hidden {
    opacity: 0;
    pointer-events: none;
}

#loading-title {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
}

#loading-title img {
    height: 50px;
    padding-right: 1em;
}

#loading-title h2 {
    color: var(--color1);
    font-size: 4em;
    font-weight: 400;
}

#loading-screen h2 span {
    color: var(--color2);
    padding-right: 0.05em;
}

.content9 {
    display: flex;
    flex-direction: column;
    justify-content: center;
    width: 100%;
    padding: 4em 0 4em 0;
    background-color: var(--color7);
}

.content9 h1 {
    font-size: 3em;
    font-weight: 800;
    color: var(--color9);
    text-align: center;
}

.content9 p, .content9 ul {
    font-size: 0.8em;
    font-weight: 500;
    color: var(--color6);
    width: 60%;
    margin: 0 auto;
    padding: 1em 0 1em 0;
}

#return-to-top {
    position: fixed;
    bottom: 2em;
    right: 2em;
    display: none;
    background-color: var(--color2);
    color: var(--color4);
    border: none;
    border-radius: 50%;
    padding: 0.5em;
    cursor: pointer;
    box-shadow: rgba(0, 0, 0, 0.2) 0px 8px 24px;
    z-index: 100;
}

#return-to-top i {
    font-size: 1.5em;
    padding: 0.2em;
}

#return-to-top:hover { background-color: var(--color3); }

.blinking-cursor { animation: blink 1s steps(2, start) infinite;}

@keyframes blink {
    0% { visibility: visible; }
    50% { visibility: hidden; }
    100% { visibility: visible; }
}