main{
    width: 100vw;
    height: 100vh;
    overflow: scroll;
    scroll-snap-type: mandatory;
    scroll-snap-points-y: repeat(100vh);
    scroll-snap-type: y mandatory;
}

h1 {
    font-family: var(--font-family);
    font-weight: normal;
    font-size: var(--title-font-size);
    line-height: 1;
    text-indent: 0;
    margin: 0;
}

h2 {
    font-family: var(--font-family);
    font-weight: normal;
    font-size:  2rem;
    margin: 0px;
    margin-bottom: var(--margin);
    padding: 0px;
}

p {
    line-height: var(--line-height);
    padding: 0px;
    margin: 0;
    margin-bottom: var(--margin);
}


li {
    margin: 0;
    padding: 0;
} 

figure {
  margin: 0;
  padding: 0;
}

img {
  width: 100%;
}

a:link {
  text-decoration: none;
}

a:visited {
  text-decoration: none;
}

a:hover {
  text-decoration: none;
  cursor: pointer;
}

a:active {
  text-decoration: none;
}

/* bandeau nav */
nav {
  position: sticky;
  top: 0px;
  left: 0;
  height: 60px;
  width: 100vw;
  padding: var(--margin);
  background-color: white;
  font-size: var(--font-size);
  z-index: 99;
}

.fr nav {
  border-top: 1px solid var(--color-fr-1);
  border-bottom: 1px solid var(--color-fr-1);
}

.en nav {
  border-top: 1px solid var(--color-en-1);
  border-bottom: 1px solid var(--color-en-1);
}

nav ul {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  line-height: 1;
}

nav li{
    width: fit-content;
}

nav #about-link {
  justify-self: end;
}
/* Languages buttons */
#buttons {
    position: fixed;
    bottom: calc(var(--margin)*2);
    right: calc(var(--margin)*2);
    z-index: 100;
    font-size: var(--font-size);
}

.fr #button-fr,
.fr #button-fr a{
    background-color: var(--color-fr-2);
    color: white;
}

.fr #button-en {
  background-color: white;
  color: var(--color-fr-2);
}

.en #button-en, 
.en #button-en a {
  background-color: var(--color-en-2);
  color: white;
}
.en #button-fr {
  background-color: white;
  color: var(--color-en-2);
}

button {
  background-color: white;
  border: 1px solid;
  font-family: 'Karrik';
  display: block;
  margin: var(--mini-margin) 0;
  padding: var(--mini-margin) 0;
}

button > a{
    text-transform: uppercase;
    padding: var(--mini-margin) var(--margin);
}

button:hover {
  cursor: pointer;
}

/* Home page */
#home, #about {
    min-height: 100vh;
    display: grid;
    grid-template-columns: 40% 60%;
    grid-gap: var(--margin);
}
#left-container{
    width: 100%;
    padding: calc(var(--margin)* 2);
    padding-right: 0;
}
#right-container{
    width: 98%;
    padding: calc(var(--margin)* 2);
    background: linear-gradient(
                90deg, rgba(67, 112, 112, 1) 0%, 
                rgba(180, 198, 198, 0) 4%, 
                rgba(255, 255, 255, 0) 23%);
}

#right-container article{
    z-index: 2;
    width: 60%;
    padding-right: 0 calc(var(--margin)*4);
    mix-blend-mode: color-burn;
    transform: rotate(0.5deg);
}

#home figure, #about figure {
    width: 80%;
    margin-bottom: var(--margin);
}

#home figcaption, #about figcaption{
    padding-top: calc(var(--margin)/2);
    background-color: white;
}

#home img, #about img{
    display: block; 
    width: 100%;
    height: auto;
    opacity: .8;
    mix-blend-mode: screen;
    -webkit-filter: grayscale(100%) contrast(150%);
    filter: grayscale(100%) contrast(150%); 
}

/* Page about */
#about article{
    position: relative;
    left: var(--margin);
}
#about h2{
    margin-top: calc(var(--margin)*2);
}
#about article{
    padding-bottom: calc(var(--margin)*2);
}

#about ul {
  margin-bottom: var(--margin);
  list-style-type: "– ";
  font-family: var(--font-text);
  margin-left: 16px;
}

.colophon p,
.colophon li,
.colophon {
    font-size: calc(var(--font-size) - 2px);
    line-height: calc(var(--font-size) - 2px);
    font-family: var(--font-text);
}

.colophon {
    margin-bottom: 0px;
}

.printonly {
    display: none;
}

.screenonly {
    display: block;
}

.boiteimg {
    width: 100%;
    margin-bottom: 1em;
}


.title {
    position: relative;
}

/* Publication styling */
#publication{
    padding: calc(var(--margin)*2);
    display: grid;
    grid-gap: calc(var(--margin)*4);
    grid-template-columns: 1fr 2fr;
}
.infos p{
    margin-bottom:calc(var(--margin)/ 2);
}

.infos .desc{
    margin-top: calc(var(--margin)*2);
}

.infos .title{ 
    margin-bottom: calc(var(--margin)*2);
}
.infos{
    position: sticky; 
    bottom: var(--margin);
}

.infos .label{
    font-family: var(--font-family);
}

.medias figure{
    margin-bottom: var(--margin);
}



@media screen {
    .page {
        position: fixed;
        width: 58%;
        height: 100%;
        left: 42%;
        top: 0;
        z-index: 10;
        pointer-events: none;
    }
}