/* -------------------------- GÉNÉRAL -------------------------- */
*,
a::after,
*::before {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html{
  overflow-x: hidden;
  scroll-behavior: smooth;
}

body {
  font-size: 20px;
  background-color: #fff;
  font-family: 'Field_Gothic_No_43_Med_Cond';
  /* overflow-x: hidden; */
}

.overflowDisabled{
  overflow-y: hidden;  
}

@media (min-width: 1201px){
  .desktopDisplayNone{
    display: none !important;
  }
}

@media (max-width: 1200px){
  .mobileDisplayNone{
    display: none !important;
  }
}

main{
  min-height: 50vh;
}

/* ---------------- VARIABLES ---------------- */

:root {
  --purpleDark: #450e33;
  --purpleMedium: #680044;
  --purpleLight: #7b005a;

  --pinkMedium: #d3aecd;
  --pinkLight: #dbc0d3;

  --goldMedium: #e1b77f;
  --goldLight: #fabd6b;

  --blueDark: #002e5d;

  --grey: #54585a;
}

/* ---------------- TITRES ---------------- */

/* --- H1 --- */

.h1{
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 35px;
    text-align: center;
    color: var(--purpleDark);
    font-size: 2.8125rem;
    line-height: 3.4375rem;
    position: relative;
    font-family: "Schabo";
    text-transform: uppercase;
}

@media (max-width: 1500px){
  .h1{
    font-size: 2.1875rem;
    line-height: 2.8125rem;
  }
}

@media (max-width: 992px){
  .h1{
    font-size: 1.75rem;
    line-height: 2.125rem;
  }
}

/* --- H2 --- */

.h2{
  font-size: 2.8125rem;
  line-height: 2.8125rem;
  color: var(--purpleDark);
  text-transform: uppercase;
  font-family: "Schabo";
}

@media (max-width: 1500px){
  .h2{
    font-size: 2.1875rem;
    line-height: 2.1875rem;
  }
}

@media (max-width: 992px){
  .h2{
    font-size: 1.75rem;
    line-height: 2.125rem;
  }
}

/* ---------------- BOUTON ---------------- */

.btn{
  font-size: 1.125rem;
  line-height: 1.375rem;
  text-transform: uppercase;
  padding: 11px 45px;
  border-radius: 10px;
  font-family: 'Field_Gothic_No_44_Demi_Cond';
  outline: 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
  border: 1px solid;
  border-color: transparent;
}

.footer .navigation .links .btn::after{
    display: block;
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
}

/* ---------------- CONTAINER ---------------- */

.container{
  width: 100%;
  max-width: 1800px;
  margin-inline: auto;
  padding-inline: 80px;
  position: relative;
}

@media (max-width: 1600px) {
  .container{
    max-width: 1500px;
  }
}

@media (max-width: 992px) {
  .container{
    padding-inline: 20px;
  }
}

/* ---------------- 404 ---------------- */

.page404 ~ #footer .h2,
.page404 ~ #footer .partners{
  display: none;
}

.page404 ~ #footer,
.page404 ~ #footer .navigation{
  margin-top: 0px;
}

.page404{
  min-height: 70vh;
  position: relative;
  padding-inline: 36px;
  margin: 0px !important;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.page404 > div{
  transform: translate(-50%, -35%);
  position: absolute;
  top: 50%;
  left: 50%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
}

.page404 h1 span,
.page404 h1{
  font-size: 80px;
  line-height: 80px;
  margin-bottom: 20px;
  text-transform: uppercase;
  color: var(--purpleMedium);
  text-align: center;
  font-weight: 700;
  font-family: "Schabo";
  letter-spacing: 1px;
}

.page404 h1 span{
  color: var(--goldMedium);
}

.page404 h2{
  font-size: 30px;
  line-height: 40px;
  margin-bottom: 25px;
  text-transform: uppercase;
  text-align: center;
}

.page404 .btn{
  background-color: var(--goldMedium);
  color: #fff;
}

.page404 .btn:hover{
  background-color: var(--purpleMedium);
}

@media (max-width: 992px){
  .page404{
    min-height: 60vh;
  }
  .page404 h1,
  .page404 h1 span{
    font-size: 40px;
    line-height: 40px;
  }
  .page404 h2{
    font-size: 20px;
    line-height: 20px;
  }
}

/* ---------------- BREADCRUMBS ---------------- */

.breadcrumbs li *,
.breadcrumbs{
  color: var(--purpleDark);
  font-size: 13px;
  line-height: 20px;
}

.breadcrumbs li.active *{
  font-weight: bold;
}

.breadcrumb li::after{
  content: "" !important;
  width: 5px;
  height: 9px;
  display: inline-block;
  margin-inline: 8px !important;
  background-repeat: no-repeat;
  background-position: center;
  background-image: url("data:image/svg+xml,%3Csvg id='next' xmlns='http://www.w3.org/2000/svg' width='4.566' height='8.455' viewBox='0 0 4.566 8.455'%3E%3Cg id='Groupe_7' data-name='Groupe 7' transform='translate(0 0)'%3E%3Cpath id='Tracé_19' data-name='Tracé 19' d='M4.47,4,.559.1A.328.328,0,0,0,.1.56L3.774,4.228.1,7.9a.328.328,0,0,0,.463.464L4.47,4.46A.328.328,0,0,0,4.47,4Z' transform='translate(0 0)' fill='%230f2858'/%3E%3C/g%3E%3C/svg%3E%0A");
}
