#info{
  display: flex;
  align-items: center;
  margin-top: 5vh;
  margin-right: 10%;
}

@media (max-width: 1000px) {
  #info{
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    justify-items: center; 
    align-items: center; 
    gap: 20px;
    margin-right: 0%;
  }
  #info img 
  {
    max-width: 80%;
    width: 80%;
  }
}

#info
{
  justify-content: center;
  text-align: center;
  justify-self: center;
  justify-items: center;
}

@media (max-width: 600px) {
  #info h2 {
    font-size: 30px;
  }
}
section
{
margin: 0 auto;
justify-content: center;
justify-items: center;
justify-self: center;
text-align: center;
}

section img {
  margin: 0 auto; 
  display: block; 
  max-width: 60%;
  aspect-ratio: 16/9;
  border-radius: 30px;
  box-shadow: var(--Schaduw);
  border: 5px solid white;
}

#Productinfo
{
  width: fit-content;
  display: flex;
  justify-items: center;
  flex-direction: column;
  gap: 10px;
  width: min(400px, 100%);
  align-self: start;
  text-align: center;
}

section h2
{
  font-size: 50px;
  margin-bottom: 0px;
  display: inline;
}

section h3
{
  font-size: 20px;
  margin-top: 5px;
}

section .Prijs
{
  font-size: 30px;
  margin: 0;
}

section select, main select
{
  background-color: rgb(255, 132, 94);
  border: none;
  border-radius: 50px;
  padding-left: 10px;
  padding-right: 10px;
  color: white;
  text-decoration: none;
  font-weight: bold;
  padding: 10px;
  width: 50%;
}

section .ProductSelect
{
  padding: 10px;
}

section select option, main select option
{
  font-weight: bold;
}

section button, main button
{
  cursor: pointer;
  border-width: 0px;
  border-radius: 10px;
  background-color: #e26039;
  padding: 10px;
  word-spacing: 5px;
  color: white;
  width: max-content;
}

section span, main span
{
  display: flex;
  justify-content: space-around;
  align-items: center;
  margin-top: 10%;
  
}

section ul
{
  list-style-type: none;
  text-align: left;
}

section ul li {
  position: relative;
  padding-left: 1.5em;
  font-size: 20px;
}

section ul li::before
{
  content: "✓";
  color: var(--Knop-Achtergrond);
  font-weight: bold;
  position: absolute;
  left: 0;
  top: 0.1em;
}

#upload 
{
  display: flex;
  flex-direction: column;
  text-align: center;
  margin-top: 20px;
}

main
{
  margin-top: 10vh;
  justify-content: center;
  justify-items: center;
  justify-self: center;
  display: flex;
  flex-direction: row;
  text-align: center;
}

@media (max-width: 1000px) {
  main {
    display: flex;
    flex-direction: column;
    justify-items: center; 
    align-items: center; 
    gap: 20px;
  }
}

main h3
{
  font-size: 30px;
  margin-bottom: 0px;
}

main #Beschrijving 
{
  justify-content: center;
  font-size: 20px;
  width: min(90%, 500px);
  justify-self: center;
  margin-top: 20px;
  background-color: var(--Alinea-Achtergrond);
  padding: 30px;
  border-radius: 30px;
  box-shadow: var(--Schaduw);
}

main #Beschrijving ul
{
  background-color: var(--Achtergrond);
  list-style: none;
  text-align: center;
  padding-left: 0;
  border-radius: 20px;
  padding: 10px;
}

main div
{
  justify-self: center;
}

main h6
{
  font-size: 20px;
  font-weight: bold;
  text-align: center;
}

table
{
  width: min(500px, 90%);
}

table tr 
{
  text-align: center;

}

table tr td
{
  width: 100px;
  text-align: center;
}

table tr:first-child > *
{
  margin-top: 20px;
  background-color: var(--Knop-Achtergrond);
  padding: 10px;
  color: white;
}

table tr td
{
  background-color: var(--Achtergrond);
  padding: 5px;
  width: 150px;
}

table
{
  justify-self: center;
  border-collapse: separate;
  border-spacing: 20px 15px;
  text-align: center;
  background-color: var(--Alinea-Achtergrond);
  border-radius: 30px;
  border: 2px solid rgb(255, 255, 255);
}

table tr, table td
{
  border-radius: 20px;
}

textarea
{
  display: block;
  margin-top: 50px;
  width: 100%;
  height: 150px;
  border-radius: 20px;
  padding: 10px;
  font-size: 16px;
  resize: vertical;
  border: 2px solid rgb(200, 200, 200);
}

#Schuin
{
  margin-top: 10px;
  width: min(400px, 90%);
  justify-self: center;
}


main
{
  margin-top: 100px;
}

main h2
{
  text-align: center;
  color: white;
}

main .Product
{
  justify-self: center;
  margin-top: 5vh;
  display: flex;
  flex-direction: column;
  text-align: center;
  width: min(250px, 90%);
  background-color: var(--Alinea-Achtergrond);
  padding: 20px;
  color: white;
  border-radius: 30px;
}

main .Prijs
{
  width: fit-content;
  background-color: transparent;
  box-shadow: none;
  padding: 0;
}
main div li .ProductSelect
{
  cursor: pointer;
  word-spacing: 5px;
  color: white;
  width: max-content;
  padding: 10px;
}

main li div div
{
  display: flex;
  flex-direction: row;
  justify-content: space-between;
}


.Carousel {
  position: relative;
}

.CarouselBtn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 42px;
  height: 42px;
  border: 0;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.5);
  color: #fff;
  font-size: 24px;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 1;
}

.CarouselBtn:hover {
  background: rgba(0, 0, 0, 0.7);
}

.CarouselPrev { left: 8px; }
.CarouselNext { right: 8px; }

/* Mobile centering overrides */
@media (max-width: 1000px) {
  /* Center product info card */
  #Product {
    align-self: center;
    width: min(500px, 90%);
    text-align: center;
  }

  /* Center headings on mobile */
  section h2,
  section h3,
  main h3,
  main h6 {
    text-align: center;
  }

  /* Center action row (select + button) */
  section span,
  main span {
    justify-content: center;
    gap: 12px;
  }

  /* Center selects and buttons */
  section select,
  main select,
  section button,
  main button {
    margin-left: auto;
    margin-right: auto;
  }

  /* Center description text and make it wider on mobile */
  main p {
    width: 90%;
    margin-left: auto;
    margin-right: auto;
    text-align: center;
  }

  /* Center tables */
  table {
    margin-left: auto;
    margin-right: auto;
  }

  /* Center suggested product cards */
  main li {
    margin-left: auto;
    margin-right: auto;
  }
}

.Aanbevolenproducten
{
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
}

.Aanbevolenproducten li
{
  width: min(300px, 100%);
  position: relative;
}

.Aanbevolenproducten li select
{
  padding: 5px;
}

.Aanbevolenproducten li img
{
  margin-bottom: 10px;
  border-radius: 10px;
  border: #fff solid 3px;
}

#team1
{
  font-size: 20px;
  display: inline-block;
  background-color: blue;
  padding: 10px;
  border-radius: 40px;
  width: max-content;
  color: white;
  position: absolute;
  left: 5%;
  top: -40px;
}

@media (min-width: 1000px) {
  #team1
  {
    left: 18%;
  }
}

#team
{
  font-size: 20px;
  display: inline-block;
  background-color: blue;
  padding: 10px;
  border-radius: 40px;
  width: max-content;
  color: white;
  position: absolute;
  left: -10px;
  top: -40px;
}

#extra
{
  font-size: 20px;
  display: block;
  background-color: red;
  padding: 10px;
  border-radius: 40px;
  width: max-content;
  color: white;
  position: absolute;
  right: -10px;
  top: -40px;
}