/* algemene stijl; background, text, font-family, etc. */
body {
/* zie https://cssgradient.io/ voor background gradient, height en width nodig voor posities van de blobs, geregeld door de deg*/
  min-height: 100vh;
  width: 100%;
  background: white;
  font-family:"SF Pro Text 1";
}

.text {
  font-size: 20px;
  background: -webkit-linear-gradient(165deg, #1ecb83, #647eff);
  -webkit-background-clip: text; /*Code van https://www.cssgradienttext.com; geen idee waarom het een error geeft maar het werkt*/
  -webkit-text-fill-color: transparent;
  font-family: "SF Pro Text1";
  text-align: center;
}

.textw {
  font-size: 20px;
  color:white;
  font-family: "SF Pro Text1";
  text-align: center;
}

.ontitle {
  font-size: 50px;
  color:white;
  font-family: "SF Pro Text";
  text-align: center;
  margin-top: 0.5vh;
  margin-bottom: 80px;
}

.ontitle-green {
  font-size: 50px;
  background: -webkit-linear-gradient(165deg, #1ecb83, #647eff);
  -webkit-background-clip: text; /*Code van https://www.cssgradienttext.com; geen idee waarom het een error geeft maar het werkt*/
  -webkit-text-fill-color: transparent;
  font-family: "SF Pro Text";
  text-align: center;
  margin-top: 0.5vh;
}

.title {
  font-size: 170px;
  background: -webkit-linear-gradient(165deg, #1ecb83, #647eff);
  -webkit-background-clip: text; /*Code van https://www.cssgradienttext.com; geen idee waarom het een error geeft maar het werkt*/
  -webkit-text-fill-color: transparent;
  font-weight: bold;
  font-family: "SF Pro Text";
  text-align: center;
  margin-top: 13vh;
  margin-bottom: 80px;
}

.indextitle {
  font-size: 170px;
  background: -webkit-linear-gradient(165deg, #1ecb83, #647eff);
  -webkit-background-clip: text; /*Code van https://www.cssgradienttext.com; geen idee waarom het een error geeft maar het werkt*/
  -webkit-text-fill-color: transparent;
  font-weight: bold;
  font-family: "SF Pro Text";
  text-align: center;
  margin-top: 13vh;
  margin-bottom: 80px;
  position: relative;
  animation: fadein;
  animation-duration: 2s;
}

.right {
  text-align: right;
  justify-content: right;
  object-position: right;
  float: right;
}

.center {
  text-align: center;
  justify-content: center;
  object-position: center;
  float: center;
}

.left {
  text-align: left;
  justify-content: left;
  object-position: left;
  float: left;
}

.nomargin {
  margin: 0%;
}

/* Apple fonts sourc: https://gist.github.com/nonaybay/684d1808c0eb9be67063c3f6fb2785c6 */
@font-face {
  font-family: "SF Pro Text";
  font-style: normal;
  font-weight: 900;
  src: url("https://raw.githubusercontent.com/blaisck/sfwin/master/SFPro/TrueType/SFProText-Heavy.ttf");
}

@font-face {
  font-family: "SF Pro Text1";
  font-style: normal;
  font-weight: 500;
  src: url("https://raw.githubusercontent.com/blaisck/sfwin/master/SFPro/TrueType/SFProText-Medium.ttf");
}

/* buttons; met code van W3Schools en websites die ik hiervoor heb gemaakt */
.btn {
  border: 10px solid;
  color: black;
  padding: 14px 28px;
  font-size: 1.2em;
  font-weight: bold;
  cursor: pointer;
  border-radius: 20px;
  transition-duration: 200ms;
  transition-timing-function: ease-in;
  align-items: center;
}

.indexbuttons {
  color: white;
  border-color: rgb(33, 192, 150);
  background-color: transparent;
  padding: 30px 70px;
  margin-top: 30px;
  display: block;
  margin: 50px auto 60px auto;
}

.indexbuttons:hover {
  background: #147850;
  background: linear-gradient(150deg, rgb(24, 204, 132) 0%, rgb(25, 136, 180) 100%);
  border: solid transparent 0px;
  color: white;
  margin: 50px auto 60px auto;
  padding-top: 40px;
  padding-bottom: 40px;
  padding-left: 80px;
  padding-right: 80px;
}

.indexbuttonsexc { /* buttons met nadruk */
  background: #147850;
  background: linear-gradient(150deg, rgb(24, 204, 132) 0%, rgb(25, 136, 180) 100%);
  border: solid transparent 0px;
  color: white;
  padding-top: 40px;
  padding-bottom: 40px;
  padding-left: 80px;
  padding-right: 80px;
  align-self: baseline;
}

.indexbuttonsmand { /* buttons met nadruk */
  background: -webkit-linear-gradient(165deg, #1ecb83, #647eff);
  -webkit-background-clip: text; /*Code van https://www.cssgradienttext.com; geen idee waarom het een error geeft maar het werkt*/
  -webkit-text-fill-color: transparent;
  border-color: rgb(33, 192, 150);
  background-color: transparent;
  padding: 30px 70px;
  margin-top: 0px;
  display: block;
  margin: 50px auto 60px auto;
}

.indexbuttonsmand:hover {
  background: linear-gradient(150deg, rgb(24, 204, 132) 0%, rgb(25, 136, 180) 100%);
  border: solid transparent 0px;
  -webkit-text-fill-color: white;
  margin: 50px auto 60px auto;
  padding-top: 40px;
  padding-bottom: 40px;
  padding-left: 80px;
  padding-right: 80px;
}

/*Producten raster*/
.product-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 60px;
  padding: 100px;
  list-style: none;
  font-family: "SF Pro Text1";
  position: relative;
  animation: fadein;
  animation-duration: 2s;
}
.product-card {
  background: linear-gradient(
    150deg,
    rgba(20, 120, 80, 0.4),
    rgba(29, 88, 112, 0.4)
  );
  border-radius: 30px;
  padding: 40px;
  text-align: center;
  color: white;
  backdrop-filter: blur(10px);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.product-card:hover {
  transform: translateY(-15px);
  box-shadow: 0 30px 60px rgba(0, 0, 0, 0.6);
}
.product-card img {
  width: 100%;
  max-width: 280px;
  margin-bottom: 30px;
}
.product-card h3 {
  font-size: 32px;
  font-family: "SF Pro Text";
  font-weight: bold;
  margin-bottom: 15px;
}

.product-card p {
  font-size: 22px;
  opacity: 0.9;
}

/*Winkelmand*/
.product-list {
  display: block;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  padding: 100px;
  list-style: none;
  font-family: "SF Pro Text1";
}

.product-card-mand {
  background: linear-gradient(
    150deg,
    rgba(20, 120, 80, 0.4),
    rgba(29, 88, 112, 0.4)
  );
  border-radius: 30px;
  padding-top: 40px;
  padding-bottom: 40px;
  color: white;
  backdrop-filter: blur(10px);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  margin-bottom: 30px;
  text-align: left;
  display: flex;
  align-items: center;
  gap: 30px;
}

.product-card-mand:hover {
  transform: translateY(-15px);
  box-shadow: 0 30px 60px rgba(0, 0, 0, 0.6);
}
.product-card-mand img {
  width: 100%;
  max-width: 280px;
  text-align: right;
  margin-bottom: 0px;
}
.product-card-mand h3 {
  font-size: 32px;
  font-family: "SF Pro Text";
  font-weight: bold;
  margin-bottom: 15px;
}

.product-card-mand p {
  font-size: 22px;
  opacity: 0.9;
}

.mandbuttons { /* buttons met nadruk, speciaal aangepast voor de winkelmand */
  background: #147850;
  background: linear-gradient(150deg, rgb(24, 204, 132) 0%, rgb(25, 136, 180) 100%);
  border: solid transparent 0px;
  color: white;
  padding-top: 20px;
  padding-bottom: 20px;
  padding-left: 60px;
  padding-right: 60px;
  align-self: baseline;
}


/*code van https://www.w3schools.com/css/css_navbar_horizontal.asp*/
ul {
  list-style-type: none;
  margin: 0;
  padding: 0;
  background-color: #ffffff;
  display: flex;
  justify-content: right;
}

ul li a {
  display: block;
  color: rgb(0, 0, 0);
  padding: 14px 16px;
  text-decoration: none;
}

ul li a:hover {
  background-color: #111111;
  color:white
}


/*code om divs naast elkaar te kunnen zetten, van https://www.w3schools.com/html/html_div.asp*/
.mycontainer {
  width:100%;
  overflow:auto;
}
.mycontainer div {
  width:40%;
  float:left;
}
.mycontainer img {
  width:100%;
  float:left;
}

/* product aan winkelmand toevoegen animatie, code van https://www.w3schools.com/css/css3_animations.asp */
@keyframes fadein {
  0% {left:0px;top:-100px}
  100% {left:0px;top:0px}
}

/* mobiele weergave winkelmand, met behulp van Stackoverflow */
@media (max-width: 1090px) {

  .product-list {
    padding: 20px;
  }

  .product-card-mand {
    padding: 20px;
    text-align: center;
  }

  .product-card-mand img {
    width: 100%;
    max-width: 200px;
    margin: auto;
    display: block;
  }

  .product-card-mand h3 {
    font-size: 22px;
  }

  .product-card-mand p {
    font-size: 18px;
  }

  .mandbuttons {
    padding: 12px 30px;
  }

  .mycontainer div {
    width: 100%;
    float: none;
    text-align: center;
  }

}
