@font-face {
  font-family: 'mariannebold';
  src: url(../../assets/fonts/marianne-bold-webfont.woff2) format(woff2),
    url(../../assets/fonts/marianne-bold-webfont.woff) format(woff);
  font-weight: normal;
  font-style: normal;
}

@font-face {
  font-family: 'mariannebold_italic';
  src: url(../../assets/fonts/marianne-bolditalic-webfont.woff2) format(woff2),
    url(../../assets/fonts/marianne-bolditalic-webfont.woff) format(woff);
  font-weight: normal;
  font-style: normal;
}

@font-face {
  font-family: 'marianneextrabold';
  src: url(../../assets/fonts/marianne-extrabold-webfont.woff2) format(woff2),
    url(../../assets/fonts/marianne-extrabold-webfont.woff) format(woff);
  font-weight: normal;
  font-style: normal;
}

@font-face {
  font-family: 'marianneextrabold_italic';
  src: url(../../assets/fonts/marianne-extrabolditalic-webfont.woff2) format(woff2),
    url(../../assets/fonts/marianne-extrabolditalic-webfont.woff) format(woff);
  font-weight: normal;
  font-style: normal;
}

@font-face {
  font-family: 'mariannelight';
  src: url(../../assets/fonts/marianne-light-webfont.woff2) format(woff2),
    url(../../assets/fonts/marianne-light-webfont.woff) format(woff);
  font-weight: normal;
  font-style: normal;
}

@font-face {
  font-family: 'mariannelight_italic';
  src: url(../../assets/fonts/marianne-lightitalic-webfont.woff2) format(woff2),
    url(../../assets/fonts/marianne-lightitalic-webfont.woff) format(woff);
  font-weight: normal;
  font-style: normal;
}

@font-face {
  font-family: 'mariannemedium';
  src: url(../../assets/fonts/marianne-medium-webfont.woff2) format(woff2),
    url(../../assets/fonts/marianne-medium-webfont.woff) format(woff);
  font-weight: normal;
  font-style: normal;
}

@font-face {
  font-family: 'mariannemedium_italic';
  src: url(../../assets/fonts/marianne-mediumitalic-webfont.woff2) format(woff2),
    url(../../assets/fonts/marianne-mediumitalic-webfont.woff) format(woff);
  font-weight: normal;
  font-style: normal;
}

@font-face {
  font-family: 'marianneregular';
  src: url(../../assets/fonts/marianne-regular-webfont.woff2) format(woff2),
    url(../../assets/fonts/marianne-regular-webfont.woff) format(woff);
  font-weight: normal;
  font-style: normal;
}

@font-face {
  font-family: 'marianneitalic';
  src: url(../../assets/fonts/marianne-regularitalic-webfont.woff2) format(woff2),
    url(../../assets/fonts/marianne-regularitalic-webfont.woff) format(woff);
  font-weight: normal;
  font-style: normal;
}

@font-face {
  font-family: 'mariannethin';
  src: url(../../assets/fonts/marianne-thin-webfont.woff2) format(woff2),
    url(../../assets/fonts/marianne-thin-webfont.woff) format(woff);
  font-weight: normal;
  font-style: normal;

}

@font-face {
  font-family: 'mariannethin_italic';
  src: url(../../assets/fonts/marianne-thinitalic-webfont.woff2) format(woff2),
    url(../../assets/fonts/marianne-thinitalic-webfont.woff) format(woff);
  font-weight: normal;
  font-style: normal;
}

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

.window {
  max-width: 100%;
  height: 85%;
  display: flex;
}

.open .main_content {
  position: relative;
  width: 100%;
}

.main_content {
  position: relative;
  width: 100%;
  height: 100%;
}

p {
  font-size: 12px;
  font-weight: normal;
}

body {
  max-height: 100%;
  max-width: 100%;
}

/* html {
  font-size: 16px;
} */

.logo {
  top: 0;
  left: 0;
  max-width: 75%;
  max-height: 100%;
  position: relative;
  padding-right: 1vh;
}

.brand {
  top: 0;
  left: 0;
  max-width: 100%;
  max-height: 100%;
  display: none;
}

.open .brand {
  display: block;
}

.brand_e {
  display: block;
  position: relative;
  top: 2%;
  left: 1rem;
  height: 3rem;
  padding-right: 1vh;
}

.open .brand_e {
  display: none;
}

h1 {
  font-size: 16px;
  font-weight: normal;
  margin: 0;
}

h2 {
  font-size: 14px;
  font-weight: normal;
}

/* h3 {
  font-style: italic;
  color: #ffffff;
  text-shadow: 1px 1px #454545;
  font-size: 1.75em;
} 

h4 {
  font-weight: bolder;
  font-size: 1.25em;
} */

a {
  color: #ffffff;
}


/******* Navbar ******/
.navbar .brand {
  display: none;
}

#search {
  cursor: pointer;
}

.searchbar {
  position: relative;
  display: flex;
  height: 20%;
  min-width: 35%;
  align-items: center;
  justify-content: flex-end;
}

.open_search #search-form {
  visibility: visible;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 2px solid #ffffff;
  border-radius: 30px;
  background-color: #ffffff;
  color: #000000;
  width: 90%;
  margin-right: 1em;
}

#search-form {
  visibility: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 2px solid #ffffff;
  border-radius: 30px;
  background-color: #ffffff;
  color: #000000;
  width: 90%;
  margin-right: 1em;
}

#search-box {
  width: 70%;
  border-color: transparent;
  border-radius: 30px;
  font-family: 'marianneitalic';
  font-size: 12px;
  cursor: text;
  padding: 1%;
}

#search-btn {
  width: 35%;
  border: 2px solid #000000;
  border-radius: 30px;
  background-color: #000000;
  color: #ffffff;
  font-family: 'mariannemedium';
  font-size: 16px;
  cursor: pointer;
}

#search-btn:hover {
  background-color: #ffffff;
  color: #000000;
}

.open .bouton_logo {
  position: relative;
  left: 2%;
  display: flex;
  justify-content: space-evenly;
}

.bouton_logo {
  padding-top: 2vh;
  padding-right: 2vh;
  position: relative;
  left: 2%;
  display: flex;
  justify-content: space-evenly;
}

.toggle {
  top: 2%;
  right: 2%;
  cursor: pointer;
  z-index: 20;
  position: relative;
  align-items: left;
  margin-left: 2%;
}

.toggle span {
  font-size: 3rem;
}

.menu {
  background-color: #000000;
  position: sticky;
  top: 0;
  left: 0;
  max-width: 8%;
  display: flex;
  flex-direction: column;
  list-style: none;
  padding: 0;

}

.row_menu {
  max-width: 100%;
  display: none;
}

.open .row_menu {
  display: flex;
  position: relative;
  padding-right: 1rem;
  padding-left: 1rem;
  padding-bottom: 1rem;
  margin-top: 1.5rem;
  flex-direction: column;
}


.open .menu {
  max-width: 20%;
  justify-content: start;
}

.menu li a {
  color: #ffffff;
  text-decoration: none;
  width: 85%;
}

.space_block {
  padding-top: 2rem;
}

.navbar-default {
  background-color: #000000;
  width: 100%;
  height: 80%;
  /* background-image: none;
  background-repeat: no-repeat; */
}

.navbar {
  position: relative;
  width: 100%;
  max-height: 6%;
  padding-left: 5%;
  padding-bottom: 1.2em;
  padding-top: 1.2em;
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: #ffffff;
  flex-direction: row;
}

/* .navbar a {
  letter-spacing: 1px;
  font-size: 1.5em;
  text-shadow: 1px 1px #ffffff;
} */

#ouvrir {
  display: block;
}

#fermer {
  display: none;
}

.open #ouvrir {
  display: none;
}

.open #fermer {
  display: block;
}

/******* Menu user ******/
.toggle_user {
  padding-left: 1em;
}

#toggle_utilisateur {
  cursor: pointer;
  display: flex;
  padding-right: 2%;
}

#toggle_utilisateur p {
  align-self: center;
  align-items: center;
}

#user_ouvrir {
  display: block;
}

.open_user #user_ouvrir {
  display: none;
}

#user_fermer {
  display: none;
}

.open_user #user_fermer {
  display: block;
}

.menu_user {
  display: none;
}

.open_user .menu_user {
  padding: 1em;
  display: flex;
  flex-direction: column;
  background-color: #000000;
  color: #ffffff;
  position: absolute;
  right: 0;
  top: 100%;
  width: 30%;
  align-items: start;
  list-style: none;
  z-index: 10;
}

.row_menu_user {
  margin-bottom: 2vh;
}

.row_menu_user li a {
  text-decoration: none;
}

.row_menu_user li a h2:hover {
  text-decoration: underline;
  font-weight: bold;
  color: #ffffff;
}

.titre_sous_menu_user {
  display: flex;
  justify-content: flex-start;
  align-items: center;
}

.titre_sous_menu_user .icone {
  font-size: 20px;
}

.titre_sous_menu_user a {
  padding-left: 1.5vh;
  padding-right: 1.5vh;
  width: 100%;
}

/******* Sous-menu ******/
#toggle_personnalisation {
  cursor: pointer;
}

#toggle_annu {
  cursor: pointer;
}

#toggle_med {
  cursor: pointer;
}

#toggle_pub {
  cursor: pointer;
}

#toggle_assist {
  cursor: pointer;
}

.titre_sous_menu {
  display: flex;
  justify-content: flex-start;
  align-items: center;
}

.titre_sous_menu h1 {
  padding-left: 1.5vh;
  padding-right: 1.5vh;
  color: #ffffff;
  width: 85%;
}

.titre_sous_menu a h1:hover {
  text-decoration: underline;
  font-weight: bold;
  color: #ffffff;
}

.titre_sous_menu .icone {
  font-size: 20px;
}

.sous_menu {
  display: none;
}

.sous_menu a {
  padding-bottom: 0.25rem;
  padding-top: 0.25rem;
}

.sous_menu div {
  display: flex;
  flex-direction: row;
}

.sous_menu span {
  font-size: 110%;
  align-self: center;
  padding-top: 0.25rem;
}

.sous_menu a h2:hover {
  text-decoration: underline;
  font-weight: bold;
  color: #ffffff;
}

.open_menu .sous_menu {
  position: relative;
  display: flex;
  padding-top: 0.5rem;
  padding-left: 2rem;
  flex-direction: column
}

.open_menu .sous_menu a {
  display: list-item;
  list-style: none;
}

#perso_ouvrir {
  display: block;
}

.open_menu #perso_ouvrir {
  display: none;
}

#perso_fermer {
  display: none;
}

.open_menu #perso_fermer {
  display: block;
}

/* .toggle_perso {
  margin-left: 20%;
} */

#annuaire_ouvrir {
  display: block;
}

.open_menu #annuaire_ouvrir {
  display: none;
}

#annuaire_fermer {
  display: none;
}

.open_menu #annuaire_fermer {
  display: block;
}

/* .toggle_annuaire {
  margin-left: 20%;
} */

#media_ouvrir {
  display: block;
}

.open_menu #media_ouvrir {
  display: none;
}

#media_fermer {
  display: none;
}

.open_menu #media_fermer {
  display: block;
}

/* .toggle_media {
  margin-left: 20%;
} */

#publique_ouvrir {
  display: block;
}

.open_menu #publique_ouvrir {
  display: none;
}

#publique_fermer {
  display: none;
}

.open_menu #publique_fermer {
  display: block;
}

/* 
.toggle_publique {
  margin-left: 20%;
} */

#assistance_ouvrir {
  display: block;
}

.open_menu #assistance_ouvrir {
  display: none;
}

#assistance_fermer {
  display: none;
}

.open_menu #assistance_fermer {
  display: block;
}

/* .toggle_assistance {
  margin-left: 20%;
} */

/******* Responsive ******/
@media screen and (max-width: 750px) {
  .open .menu {
    max-width: 35%;
  }

  /* .regular-content-size p {} */
}

@media screen and (max-width: 1000px) {
  .titre_sous_menu {
    display: flex;
    justify-content: flex-start;
    align-items: center;
  }

  .titre_sous_menu p {
    padding-left: 1.5vh;
    padding-right: 1.5vh;
  }

  .titre_sous_menu .icone {
    font-size: 16px;
  }

  /* .open_menu .sous_menu {
  } */

  .toggle_perso {
    display: none;
  }

  .toggle_annuaire {
    display: none;
  }

  .toggle_media {
    display: none;
  }

  .toggle_publique {
    display: none;
  }

  .toggle_assistance {
    display: none;
  }
}

@media screen and (min-width: 701px) {
  #footer1 {
    max-width: 15%;
  }

  #footer2 {
    left: 5%;
    max-width: 30%;
  }

  #footer3 {
    left: 35%;
    max-width: 15%;
  }
}

@media screen and (max-width: 701px) {
  #footer1 {
    max-width: 20%;
  }

  #footer2 {
    left: 15%;
    max-width: 35%;
  }

  #footer3 {
    left: 20%;
    max-width: 20%;
  }
}

/******* Sections ******/
section {
  height: 100%;
}

/* header {
  height: 5%;
  background-color: #e67e22;
}

.below-navbar {
  margin-top: 6em;
} */

.row-padding {
  padding: 2em 0em 0em 0em;
}

.table-header {
  background-color: #e67e22;
  border-radius: 5px;
  color: #ffffff;
  letter-spacing: 1px;
  text-shadow: 1px 1px #888888;
}

table a {
  color: #2C3E50;
}

tr td:nth-child(1) {
  width: 20%;
}

.new-header {
  font-style: normal;
  color: black;
  padding: 0.5em 0em 2em 0em;
}

.pagination>li>a {
  color: #e67e22;
}

.pagination>.active>a {
  background-color: #e67e22;
  border-color: #e67e22;
}

.box-style {
  background-color: #ECF0F1;
  border-radius: 5px;
  padding: 2em 2em 2em 2em;
}

/******* Footer ******/

footer {
  height: 15%;
  width: 100%;
  bottom: 0;
  position: relative;
}

.footer-text {
  margin: 0;
  width: 75%;
  text-align: left;
  color: #ffffff;
}

.footer-color-grey {
  background-color: #9f9f9f;
  padding: 0.5vh;
  position: relative;
}

.footer-color-one {
  background-color: #000000;
  height: 99%;
  padding: 2.25em 0em 2.5em 0em;
  color: #ffffff;
  margin-bottom: 0;
  position: relative;
}

.footer-brand {
  align-items: right;
  max-width: 100%;
  max-height: 100%;
}

.footer-color-three {
  background-color: #382010;
  height: 1.5em;
  padding: 1em 0em 2em 0em;
  color: #ffffff;
}

.footer-links-block {
  padding: 1em 0em 0.5em 0em;
}

.footer-links li {
  list-style: none;
  display: flex;
  flex-direction: column;
}

.footer-links li a h1:hover {
  text-decoration: underline;
  font-weight: bold;
  color: #ffffff;
}

.footer-links a {
  list-style: none;
  text-decoration: none;
}

#footer1 {
  left: 3.5%;
  top: 0px;
  max-height: 100%;
  position: relative;
}

#footer1 li a {
  margin-bottom: 1.5vh;
}

#footer2 {
  top: 0px;
  max-height: 100%;
  position: relative;
}

#footer2 li a {
  margin-bottom: 1.5vh;
}

#footer3 {
  top: 0px;
  height: 30%;
  position: relative;
  align-self: flex-start;
}

#footer3 h1 {
  text-align: end;
  padding-top: 1em;
}

/******* Ride full view ******/

.underscore {
  border-bottom: 2px solid #E67E22;
}

.box-ride {
  border: 3px solid #E67E22;
  border-radius: 5px;
}

.special-number {
  color: #000000;
  font-style: normal;
  font-weight: bolder;
  text-align: center;
  margin: 10px;
}

/******* Modals ******/

hr {
  border-top: 1px solid #107360;
}

.caption {
  position: absolute;
  width: 90.5%;
  height: 100%;
  opacity: 0;
  background: rgba(255, 255, 255, 0.9);
  border-radius: 10px;
  font-weight: bold;
  -webkit-transition: all ease .5s;
  -moz-transition: all ease .5s;
  -ms-transform: all ease .5s;
  transition: all ease .5s;
}

.caption:hover {
  opacity: 1;
}

.caption .caption-content {
  position: absolute;
  top: 30%;
  width: 100%;
  height: 20px;
  text-align: center;
  font-size: 20px;
  color: #fff;
}

/******* Helpers ******/

.center {
  text-align: center;
  margin: 0 auto;
}

.bottom {
  padding-bottom: 0.5em;
}

.bottom-extra {
  margin-bottom: 1em;
}

.bottom-plus {
  padding-bottom: 1.25em;
}

.shadow {
  text-shadow: 1px 1px #454545;
  letter-spacing: 1px;
}

.strong {
  font-weight: bold;
}

.blue-text {
  color: #2980B9;
}

.regular-content-size {
  width: 100%;
  height: 92%;
  margin: 0 auto;
  bottom: 0;
}

.regular-footer-size {
  width: 100%;
  height: 100%;
  margin: 0 auto;
  bottom: 0;
  position: relative;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
}

.padding-box {
  padding: 1em 0em;
}

.pre-small {
  font-size: 0.9em;
}

.small {
  font-size: 0.8em;
}

.img-responsive {
  width: 100%;
}

.ezimage-field {
  margin: 0;
}

.extra-padding-left {
  padding-left: 1em;
}