/*
 * Custom CSS
 */

@import url('//maxcdn.bootstrapcdn.com/font-awesome/4.2.0/css/font-awesome.min.css');

@font-face {
  font-family: 'PP Pangram Sans';
  src: url("./fonts/Pangram-Black.otf") format("truetype");
  font-display: swap;
}
@font-face {
  font-family: 'PP Pangram Sans Bold';
  src: url("./fonts/Pangram-Bold.otf") format("truetype");
  font-display: swap;
}
@font-face {
  font-family: 'PP Pangram Sans ExtraBold';
  src: url("./fonts/Pangram-ExtraBold.otf") format("truetype");
  font-display: swap;
}
@font-face {
  font-family: 'PP Pangram Sans ExtraLight';
  src: url("./fonts/Pangram-ExtraLight.otf") format("truetype");
  font-display: swap;
}
@font-face {
  font-family: 'PP Pangram Sans Light';
  src: url("./fonts/Pangram-Light.otf") format("truetype");
  font-display: swap;
}
@font-face {
  font-family: 'PP Pangram Sans Medium';
  src: url("./fonts/Pangram-Medium.otf") format("truetype");
  font-display: swap;
}
@font-face {
  font-family: 'PP Pangram Sans Regular';
  src: url("./fonts/Pangram-Regular.otf") format("truetype");
  font-display: swap;
}

:root {
  --bs-body-bg: var(--bs-gray-100);
}

.gs-row {
  margin-bottom: 50px;
}

.gs-block {
  margin-bottom: 30px;
}

.sample-img {
  text-align: center;
  height: 200px;
  width: 100%;
  padding-top: 15%;
}

body {
  font-family: 'PP Pangram Sans Regular', serif;
  background: #E9E9E9;
}

h1{
  font-family: 'PP Pangram Sans Bold', serif;
  font-size: 42px;
  color: #000000;
}

h3{
  font-size: 18px;
  color: #000000;
}

h2 {
  font-family: 'PP Pangram Sans Bold', serif;
  font-size: 29px;
  color: #000000;
}

.block-goodstock-information {
  justify-content: center;
  align-items: center;
  display: flex;
}

.block-yellow {
  background: #FFD601;
}

.block-white {
  background: #FFFFFF;
}

html {
  scroll-padding-top: 100px; /* height of sticky header */
}

.container-xxl {
  max-width: 1200px;
}

/* HEADER */
header {
  position: sticky;
  background-color: #E9E9E9;
  top: 0;
  box-shadow: 0 6px 4px -4px #dddada;
}
.block-header {
  display: flex;
  align-items: stretch;
}

.header-logo-title .brand-title {
  margin-top: 10px;
}

.brand-title {
  display: flex;
  align-items: center;
}

.header-logo {
  margin-right: .5rem;
  margin-bottom: .5rem;
}

.header-menu {
  width: 85%;
  padding: 0;
}

.header-navbar-items {
  width: 100%;
  display: grid;
  justify-content: space-evenly;
  list-style: none;
  margin: 0;
  padding: 0;
  grid-template-columns: repeat(3,1fr);
}

.navbar-collapse.stroke ul li a {
  position: relative;
}
.navbar-collapse.stroke ul li a:after {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 0%;
  content: '.';
  color: transparent;
  background: #FFD601;
  height: 2px;
  transition: all .5s;
}
.navbar-collapse.stroke ul li a:hover:after {
  width: 70%;
}

.link-menu {
  display: flex;
  justify-content: center;
  color: #000000;
  text-decoration: none;
  cursor: pointer;
  padding: 10px;
  align-items: center;
}

.btn-contact-header {
  display: grid;
  align-items: center;
  width: 15%;
}

#scroll-back-to-top {
  display: none;
  width: 50px;
  height: 50px;
  border-radius: 100%;
  background-color: #FFD601;
  position: fixed;
  bottom: 20px;
  right: 30px;
  z-index: 99;
  border: none;
  outline: none;
  cursor: pointer;
}

.scroll-top-arrow {
  filter: invert();
  padding: 5px;
}


/* BLOCK VENDRE PLUS */

.block-sell-more {
  margin-top: 20px;
  margin-bottom: 60px;
  display: grid;
  grid-template-columns: 1fr 1fr;
}

.block-logo-goodstock {
  border-radius: 24px 0 0 24px;
  padding-top: 60px;
  padding-bottom: 60px;
}

.block-description-goodstock {
  border-radius: 0 24px 24px 0;
  flex-direction: column;
}

.block-description-form {
  padding: 0 95px;
}

.title-sell-more {
  padding-bottom: 10px;
}

.description {
  font-style: normal;
  font-weight: 600;
  font-size: 18px;
  line-height: 24px;
  color: #000000;
  padding-bottom: 20px;
}

.form-contact {
  display: flex;
  flex-direction: column;
  width: 90%;
}

.form-contact-input {
  background: #ECECEC;
  border-radius: 12px;
  border: none;
  padding: 10px;
  margin-bottom: 10px;
}

.form-contact-input::placeholder {
  color: #000000;
}

.btn-contact {
  background: #000000;
  border-radius: 12px;
  color: white;
  padding: 10px;
  border: none;
  width: 100%;
}

/****BLOCK 4 ITEMS*****/
.block-four-key-points {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-gap: 15px;
  margin-bottom: 60px;
}

.block-key-point {
  display: grid;
  grid-template-rows: 1fr 2fr;
}

.bottom-key-point {
  grid-template-rows: 2fr 1fr;
}

.block-description-key-point {
  border-radius: 24px 24px 0 0px;
  padding: 25px;
  flex-direction: column;
  text-align: center;
}

.description-key-point {
  width: 70%;
}

.block-img-key-point {
  border-radius: 0px 0 24px 24px;
  padding-top: 30px;
  padding-bottom: 30px;
}

.grey-text{
  font-size: 16px;
  color: #747474;
}

.bottom-img-key-point {
  border-radius: 24px 24px 0px 0px;
}

.bottom-description-key-point {
  border-radius: 0px 0px 24px 24px;
}
/****FIN BLOCK 4 ITEMS*****/

/*COMMENT CA MARCHE ?*/
.block-how-work {
  flex-direction: column;
  border-radius: 24px;
  padding: 30px;
  text-align: center;
  margin-bottom: 60px;
}

.block-bubbles-line {
  margin: 20px 0px;
}

.bubble-icon:not(:last-child) {
  margin-right: 10px;
}

.img-dots-mobile {
  display: none;
}

.how-work-description {
  width: 50%;
  margin-top: 10px;
}

/*FORCES DE GS*/
.block-strengths {
  display: grid;
  grid-template-columns: 1fr 1fr;
  margin-bottom: 60px;
}

.block-description-strength {
  border-radius: 24px 0px 0px 24px;
  padding: 0 60px;
}

.strength-title {
  margin: 20px 0;
}

.description-lines {
 display: flex;
  flex-direction: column;
  margin-bottom: 20px;
}

.description-strength {
  margin-top: 15px;
}

.yellow-line {
  width: 15%;
  border-top: 5px solid #FFD601;
}

.block-icon-strength {
  border-radius: 0px 24px 24px 0;
  padding-top: 60px;
  padding-bottom: 60px;
}


/*BLOCK EXPÉRIENCE*/
.block-four-features {
  display: grid;
  grid-template-rows: repeat(4, 1fr);
  row-gap: 50px;
  margin-bottom: 60px;
}

.block-feature {
  display: flex;
}

.block-feature-description {
  flex-direction: column;
  width: 50%;
}

.block-feature-title {
  display: flex;
  flex-direction: column;
}

.block-feature-title-reverse {
  align-items: center;
}

.title-feature, .description-feature{
  width: 60%;
}

.title-feature {
  margin-bottom: 20px;
}

.block-icon-feature {
  width: 50%;
  background: #F5F5F5;
  box-shadow: 0px 0px 17px rgba(0, 0, 0, 0.1);
  border-radius: 24px;
  padding: 20px 0
;
}

/*BLOCK TEAM*/
.block-team-contact {
  display: grid;
  grid-template-columns: 2fr 1fr;
  grid-gap: 20px;
  margin-bottom: 60px;
}

.block-team {
  flex-direction: column;
  padding: 30px 60px;
  border-radius: 24px;
  text-align: center;
}

.block-team-members {
  display: grid;
  text-align: center;
  grid-template-columns: repeat(2, 1fr);
  grid-gap: 10px;
  margin-top: 10px;
}

.members-info:not(:last-child) {
  margin-bottom: 10px;
}

.team-img {
  border-radius: 50%;
  width: 110px;
  height: 110px;
}

.member-description {
  text-align: justify;
  text-align-last: center;
  padding: 0 10px;
}

.block-contact {
  flex-direction: column;
  border-radius: 24px;
  align-items: flex-start;
  padding: 30px 40px;
}

/*BLOCK CONFIANCE*/
.block-trust {
  display: flex;
  justify-content: center;
  text-align: center;
  margin-bottom: 60px;
}

.block-trust-description {
  width: 50%;
}

/*BLOCK OPINIONS*/
.block-opinions-customer {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-gap: 20px;
  margin-bottom: 60px;
}

.quote-infos-customer {
  border-radius: 24px;
  padding: 20px;
}

.quote-customer {
  font-style: italic;
}

.block-infos-customer {
  display: flex;
  align-items: center;
  margin-top: 20px;
}

.img-customer {
  display: flex;
  justify-content: center;
  width: 20%;
}

.customer-ecommerce {
  width: 50px;
  border-radius: 50%;
}

.customer-infos {
  display: flex;
  flex-direction: column;
  border-left: 2px solid #D9D9D9;
  padding-left: 15px;
  width: 80%;
}

/*FOOTER*/
.block-footer-logo {
  flex-direction: column;
}

.brand-title {
  text-transform: uppercase;
  margin-top: 20px;
}

.brand-title h1 {
  font-family: 'PP Pangram Sans ExtraBold';
  letter-spacing: 2px;
}

.footer{
  display: flex;
  justify-content: center;
}

.block-footer {
  display: flex;
  justify-content: center;
  align-items: center;
}

.block-footer-legal-notice {
  margin-left: 10px;
}

.link-legal-notice {
  text-decoration: none;
  color: var(--bs-body-color);
}

/* Legal Notice page */
.legal-notice {
  color: #747474;
  text-align: justify;
}

.legal-notice-title {
  text-align: center;
  margin-top: 20px;
  text-transform: uppercase;
}

.block-website-presentation {
  margin-bottom: 20px;
}

.legal-notice-subtitle {
  font-size: 22px;
  text-transform: uppercase;
}

.website-informations {
  display: grid;
  grid-template-columns: 1fr 1fr;
}

.website-information-title {
  margin-bottom: 10px;
}

.website-information-title,
.informations-bold {
  font-weight: bold;
}

.informations-bold {
  margin-right: 5px;
}

.legal-notice-update .informations-bold {
  margin-left: 5px;
}


/* For mobile phones: */
@media only screen and (max-width: 991px) {

  /* HEADER */

  .block-header {
    display: block;
    padding: 0 12px 10px 12px;
    margin: 0;
  }

  .header-menu {
    width: 100%;
  }

  .header-logo {
    display: none;
    margin: 0;
  }

  .header-navbar-items {
    grid-template-columns: 1fr;
  }

 .btn-contact-header {
    width: 100%;
  }

  /* BLOCK VENDRE PLUS */

  .block-sell-more {
    display: block;
  }

  .block-logo-goodstock {
    border-radius: 24px 24px 0 0;
  }

  .logo-goodstock {
    width: 146.5px;
  }

  .block-description-goodstock {
    border-radius: 0 0 24px 24px;
    flex-direction: column;
  }

  .block-description-form {
    padding: 20px 20px
  }

  /****BLOCK 4 ITEMS*****/
  .block-four-key-points {
    display: block;
  }

  .block-key-point {
    grid-template-rows: 2fr;
    margin-bottom: 15px;
  }

  .bottom-key-point {
    display: flex;
    flex-direction: column-reverse;
  }

  .bottom-img-key-point {
    border-radius: 0 0 24px 24px;
  }

  .bottom-description-key-point {
    border-radius: 24px 24px 0px 0px;
  }

  .icon-cash-flow-box {
    width: 186px;
  }

  .icon-flying-box {
    width: 220px;
  }

  /*COMMENT CA MARCHE ?*/

  .block-bubbles-line {
    flex-direction: column;
    margin: 20px 0px;
  }

  .bubble-icon:not(:last-child) {
    margin-bottom: 10px;
    margin-right: 0;
  }

  .img-dots {
    display: none;
  }

  .img-dots-mobile {
    display: block;
  }

  .how-work-description {
    width: 100%;
    margin-top: 10px;
  }

  /*FORCES DE GS*/
  .block-strengths {
    display: block;
  }

  .block-description-strength {
    border-radius: 24px 24px 0px 0px;
  }

  .block-icon-strength {
    border-radius: 0px 0px 24px 24px;
  }

  .icon-goodstock-punch {
    width: 162.5px;
  }

  /*BLOCK EXPÉRIENCE*/
  .block-four-features {
    display: block;
  }

  .block-feature {
    flex-direction: column;
    margin-top: 20px;
  }

  .block-feature-reverse {
    flex-direction: column-reverse;
  }

  .block-icon-feature {
    padding: 20px;
    width: 100%;
  }

  .img-feature {
    width: 100%;
    height: 320px;
  }

  .block-feature-title {
    margin-bottom: 0;
  }

  .title-feature {
    width: 100%;
    margin-bottom: 0;
  }

  .block-feature-title h1 {
    margin-bottom: 0px;
  }

  .description-feature {
    width: 100%;
  }

  .block-feature-description {
    width: 100%;
  }

  /*BLOCK TEAM*/
  .block-team-contact {
    display: block;
  }

  .block-team {
    margin-bottom: 15px;
  }

  .block-team-members {
    grid-template-columns: 1fr;
  }

  /*BLOCK CONFIANCE*/
  .block-trust {
    margin-bottom: 50px;
  }

  .block-trust-description {
    width: 100%;
  }

  /*BLOCK OPINIONS*/
  .block-opinions-customer {
    display: block;
  }

  .quote-infos-customer {
    margin-bottom: 15px;
  }

  .customer-infos {
    border-left: none;
  }

  /*FOOTER*/
  .block-footer-logo {
    flex-direction: column;
  }

  .block-footer {
    flex-direction: column;
  }

  .block-footer-legal-notice {
    margin-left: 0;
  }

}

/*LOADER*/
.cs-loader {
  height: 44px;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.cs-loader-inner {
  position: absolute;
  color: #FFF;
  text-align: center;
}

.cs-loader-inner label {
  font-size: 20px;
  opacity: 0;
  display:inline-block;
}

@keyframes lol {
  0% {
    opacity: 0;
    transform: translateX(-100px);
  }
  33% {
    opacity: 1;
    transform: translateX(0px);
  }
  66% {
    opacity: 1;
    transform: translateX(0px);
  }
  100% {
    opacity: 0;
    transform: translateX(100px);
  }
}

@-webkit-keyframes lol {
  0% {
    opacity: 0;
    -webkit-transform: translateX(-100px);
  }
  33% {
    opacity: 1;
    -webkit-transform: translateX(0px);
  }
  66% {
    opacity: 1;
    -webkit-transform: translateX(0px);
  }
  100% {
    opacity: 0;
    -webkit-transform: translateX(100px);
  }
}

.cs-loader-inner label:nth-child(6) {
  -webkit-animation: lol 3s infinite ease-in-out;
  animation: lol 3s infinite ease-in-out;
}

.cs-loader-inner label:nth-child(5) {
  -webkit-animation: lol 3s 100ms infinite ease-in-out;
  animation: lol 3s 100ms infinite ease-in-out;
}

.cs-loader-inner label:nth-child(4) {
  -webkit-animation: lol 3s 200ms infinite ease-in-out;
  animation: lol 3s 200ms infinite ease-in-out;
}

.cs-loader-inner label:nth-child(3) {
  -webkit-animation: lol 3s 300ms infinite ease-in-out;
  animation: lol 3s 300ms infinite ease-in-out;
}

.cs-loader-inner label:nth-child(2) {
  -webkit-animation: lol 3s 400ms infinite ease-in-out;
  animation: lol 3s 400ms infinite ease-in-out;
}

.cs-loader-inner label:nth-child(1) {
  -webkit-animation: lol 3s 500ms infinite ease-in-out;
  animation: lol 3s 500ms infinite ease-in-out;
}

/*MESSAGES*/
.success-msg,
.error-msg {
  margin: 10px 0;
  padding: 10px;
  border-radius: 3px 3px 3px 3px;
}

.success-msg {
  color: #270;
  background-color: #DFF2BF;
  text-align: center;
}

.error-msg {
  color: #D8000C;
  background-color: #FFBABA;
  text-align: center;
}