
* {
  box-sizing: border-box;
}

html {
  font-size: 10px;
  font-weight: 300;
  font-family: "Roboto", sans-serif;
  margin: 0;
}

body {
  width: 90vw;
  margin: auto;
}

#lagenDrager {
  display: grid;
  grid-template-columns: 50rem;
  width: 50rem;
  margin: auto;
}

#basisLaag {
  margin: 0 auto;
  grid-area: 1/1 / span 1 / span 1;
  width: 47rem;
  height: 45rem;
  z-index: 0;
  background-color: var(--cBasis);
  border-radius: 0 0 1.4rem 1.4rem;
}

button {
  padding: 0.2rem;
  height: 2.5rem;
  background-color: var(--cKnop);
  border-radius: .4rem;
  font-size: 1.4rem;
  cursor: pointer;
}

button:hover {
  background-color: var(--cKnopHover);
}

button:active {
  background-color: var(--cKnopAct);
}
button:disabled {
  cursor: default;
}

.maskeer {
  grid-area: 1/1/ span 1/span 1;
  background-color: var(--cMasker);
}
/*************************************** RADEN-LAAG **************************************/
.radenContainer {
  margin: 0 auto;
  display: grid;
  grid-area: 1/1 / span 1 / span 1;
  grid-template-columns: 33.3% 16.6% 16% 34%;
  grid-template-rows: 9.3rem 3rem 15rem auto auto auto;
  width: 44.4rem;
  height: 44.5rem;
  z-index: 1;
}
.lift {
  display: grid;
  grid-template-columns: 1fr;
  width: 22.2rem;
  height: 22.2rem;
  transition: transform 2s;
}
#liftVoorzetsels {
  grid-area: 1/1 / span 1 / span 2;
}

#liftBijwoorden {
  position: relative;
  grid-area: 1/1 / span 1 / span 2;
  top: -22rem;
}

#liftWerkwoorden {
  grid-area: 1/3 / span 1 / span 2;
}

#liftActies {
  position: relative;
  grid-area: 1/3 / span 1 / span 2;
  top: -22rem;
}

.rad {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 2.2rem 1fr;
  width: 22.2rem;
  height: 22.2rem;
  border-radius: 50%;
  background-color: white;
  transition: transform 2s;
  grid-area: 1/1 / span 1 / span 1;
}

.woord {
  top: 11.1rem;
  left: 11.1rem;
  width: 11.1rem;
  height: 2.2rem;
  font-size: 1.3rem;
}

.doorkijk {
  background-color: var(--cDoorkijk);
  z-index: 2;
}
#dvN {
  grid-area: 1/1 / span 1 / span 4;
}
#dvW {
  grid-area: 2/1 / span 1 / span 1;
}

#dvKader {
  grid-area: 2/2 / span 1 / span 2;
  border: 1px black;
  border-radius: 0.4rem;
  box-shadow: 1px 1px 2px 2px rgba(90, 116, 146, 1) inset;
  outline: var(--cDoorkijk) solid 0.15rem;
  z-index: 2;
}

#dvO {
  grid-area: 2/4 / span 1 / span 1;
}

#dvZ {
  display: flex;
  align-items: center;
  justify-content: center;
  grid-area: 3/1 / span 1 / span 4;
}

#knpDraai {
  width: 7rem;
  margin-top: 10rem;
}

.hint {
  grid-column: 1 / span 4;
  padding-top: 2rem;
  font-size: 1.2rem;
  padding: 0.5rem;
  color: white;
  background-color: var(--cControle);
}

.melding {
  color: red;
  background-color: white;
  outline: solid 1px red;
}

#txtInvoer {
  height: 10rem;
  grid-column: 1 / span 4;
  padding: 1.3rem;
  border: solid 1px var(--cControle);
  border-radius: 0.3rem;
  background-color: var(--cInhoudTxt);
  color: var(--cInhoudAg);
}
#txtInvoer:focus {
  outline: steelblue;
  border: solid 2px var(--cControle);
}

::placeholder {
  color: grey;
}

#controle {
  display: grid;
  grid-template-columns: auto auto auto;
  grid-column: 1 / span 4;
  height: 4.3rem;
  margin-bottom: .7rem;
  background-color: var(--cControle);
  border-radius: 0 0 10px 10px;
}

#controle button {
  margin: 1rem;
  background-color: var(--cKnop);
}
#controle button:hover {
  background-color: var(--cKnopHover);
}
#controle button:active {
  background-color: var(--cKnopAct);
}
/********************************* RADKEUZEKNOPPEN *****************************/
#dvKeuzeBijwoord {
  grid-area: 3/1 / span 1 / span 1;
  margin-top: 11rem;
  position: relative;
  top: 0.6rem;
  left: 5rem;
  width: fit-content;
  height: fit-content;
  z-index: 2;
}

#dvKeuzeWerkwoord {
  grid-area: 3/4 / span 1 / span 1;
  margin-top: 11rem;
  position: relative;
  top: 0.6rem;
  left: 2.4rem;
  width: fit-content;
  height: fit-content;
  z-index: 2;
}

.ovaal {
  position: absolute;
  left: 3.5rem;
  top: -0.2rem;
  width: 3rem;
  height: 1.9rem;
  background-color: var(--cKnop);
  border: solid 1px var(--cInhoud);
  border-radius: 1rem;
}
.gleuf {
  position: absolute;
  display: block;
  top: 0.65rem;
  left: 3.5rem;
  width: 2rem;
  height: 0.2rem;
  background-color: rgb(0, 0, 124);
  margin: 0 0.5rem 0 0.5rem;
}
.pijltje {
  position: absolute;
  left: 3.6rem;
  top: 0rem;
  width: 0;
  height: 0;
  border-top: 0.8rem solid transparent;
  border-bottom: 0.8rem solid transparent;
  border-right: 1rem solid var(--cControle);
  transition: left 1s, transform 1s;
}

.sp-optie {
  position: absolute;
  top: 0.2rem;
  display: block;
  width: 2.4rem;
  font-size: 1.1rem;
}
#spLinks {
  left: 0.2rem;
  text-align: right;
  padding-right: 2rem;
}
#spRechts {
  left: 6.7rem;
}

.klikvanger {
  position: absolute;
  left: 0rem;
  top: -0.9rem;
  width: 8rem;
  height: 3rem;
  background-color: rgba(255, 255, 255, 0.01); 
  cursor: pointer;
}

/************************************ LIJST **************************************/
#lijstContainer {
  grid-area: 1/1/ span 1/span 1;
}
#lijstVenster {
  position: relative;
  top: -50rem;
  display: grid;
  grid-template-rows: 44.5rem 1fr;
  margin: auto;
  width: 50rem;
  height: 50rem;
  background-color: var(--cBasis);
  color: var(--cBasisTxt);
  font-size: 1.5rem;
  z-index: 4;
  border-radius: 0 0 1.4rem 1.4rem;
  transition: transform 1s;
}

#inhoud {
  display: grid;
  background-color: var(--cInhoud);
  color: var(--cInhoudTxt);
  font-size: 1.4rem;
  border: solid .1rem var(--cInhoudTxt);
  grid-template-columns: 11rem 1fr;
  width: 44rem;
  height: 40rem;
  padding: 0.7rem;
  margin: 4rem auto;
  overflow-y: auto;
}
.inhdiv {
  padding: 0.4rem;
  user-select: none;
}
.inhdiv-select {
  outline: var(--cInhoudTxt) solid 0.2rem;
}
.inhbtn {
  all: unset;
  padding: 0.4rem;
  display: inline-flex;
  align-items: flex-start;
  cursor: pointer;
}
.inhbtn:hover {
  background-color: var(--cInhbtnHover);
}
.inhbtn-select {
  background-color: var(--cInhbtn-select);
  border: var(--cInhoudTxt) solid 0.2rem;
  border-right: none;
  outline: var(--cInhoudTxt) solid 0.2rem;
}
#lijstHint {
  padding-left: 0.4rem;
  margin: 0;
  grid-column: 1 / span 4;
  font-size: 1.1rem;
  color: white;
}
#lijstControle {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  padding: 4px;
  background-color: var(--Controle);
  border-radius: 0 0 1.4rem 1.4rem;
}
.lijstknop {
  margin: 0.3rem;
  font-size: 1.1rem;
  padding: 0.2rem;
  background-color: var(--cKnop);
  border-radius: 0.4rem;
}

.lijstknop:active {
  background-color: var(--cKnopAct);
}
.lijstknop:hover {
  background-color: var(--cKnopHover);
}

#xKnpLijst {
  background-color: var(--cXknp);
  color: var(--cInhoudTxt);
}
#xKnpLijst:hover {
  background-color: var(--cXknpHover);
}
#xKnpLijst:active {
  background-color: var(--cXknpAct);
}

/******************************** Wijzigen ******************************/
#wijzigContainer {
  grid-area: 1/1/ span 1/span 1;
}

#wijzigMasker {
  display: none;
  width: 45.5rem;
  height: 50rem;
  border-radius: 0 0 1.4rem 1.4rem;
  z-index: 5;
}

#wijzigVenster {
  display: grid;
  position: relative;
  top: -42rem;
  margin: auto;
  grid-template-rows: 8rem 1fr 4rem;
  width: 40rem;
  height: 40rem;
  border-radius: 0 0 0.8rem 0.8rem;
  background-color: var(--cDialoog);
  transition: transform 1s;
  z-index: 6;
  box-shadow: 0 .4rem .9rem .8rem var(--cInhoud) ;
}

#termHint {
  padding-left: 1rem;
  margin-top: 5rem;
  margin-bottom: 0.1rem;
  color: var(--cInhoudTxt);
  font-size: 1.3rem;
}

#wijzigTxt {
  grid-row: 2;
  margin: 0.2rem 1rem;
  padding: 1rem;
  border: solid 1px var(--cControle);
  border-radius: 0.3rem;
  background-color: var(--cInhoudTxt);
  color: var(--cInhoudAg);
}
#wijzigTxt:focus {
  outline: steelblue;
  border: solid 2px var(--cControle);
}

#wijzigCtrl {
  display: grid;
  grid-row: 3;
  grid-template-columns: 1fr 1fr;
  margin: 0.2rem 1rem;
  background-color: var(--cControle);
}
#wijzigCtrl button {
  margin: .8rem .5rem;
  padding: 0 .6rem;
}

/************************************* INTRO *****************************************/

#introMasker {
  width: 44.4rem;
  height: 45rem;
  display: block;
  z-index: 6;
}
#introContainer {
  grid-area: 1/1/ span 1/span 1;
  display: block;
  width: 100%;
}

#introVenster {
  grid-area: 1/1 / span 1 / span 1;
  position: relative;
  display: grid;
  grid-template-columns: 1fr;
  top: -39rem;
  width: 45rem;
  margin: 0 auto;
  z-index: 6;
  transition: transform 2s;
}
#introDoek {
  grid-area: 1/1 / span 1 / span 1;
  width: 50rem;
  margin: 0;
}
#introInhoud {
  grid-area: 1/1 / span 1 / span 1;
  font-size: 1.25rem;
  color: var(--cInhoudTxt);
}

#introInhoud p {
  margin-top: 0;
}
.ellips {
  width: 8rem;
  height: 40rem;
  margin: 0rem 2rem 0 -4rem;
  float: left;
  shape-outside: border-box ellipse();
  /*            clip-path:  ellipse(80px 300px); */
  border-radius: 50%;
}
.veelhoek {
  width: 5rem;
  height: 40rem;
  float: right;
  shape-outside: border-box polygon(0 0, 100% 0, 100% 100%, 0 100%, 25% 75%, 25% 25%);
  clip-path: polygon(
    0 0,
    100% 0,
    100% 100%,
    0 100%,
    50% 75%,
    68% 50%,
    50% 25%
  );
  margin-left: 1rem;
}
svg {
  width: 50rem;
  height: 43rem;
}
svg path {
  fill: hsl(220, 80%, 55%);
  stroke: none;
}

.kop {
  text-align: center;
  font-size: 1.5rem;
  font-weight: bold;
  margin-top: 0;
  margin-bottom: 0;
}

#xKnpIntro {
  grid-area: 1/1 / span 1 / span 1;
  width: 4rem;
  height: 4rem;
  margin: 37.5rem 0 0 20.5rem;
  border-radius: 50%;
  border: outset 0.2rem white;
  background-color: var(--cKnop);
  color: var(--cBasisTxt);
}

.intropijl {
  width: 0; 
  height: 0; 
  border-left: 1.4rem solid transparent;
  border-right: 1.4rem solid transparent;
  border-bottom: 1.4rem solid white;
  margin: 0 auto .2rem auto;
  transform: rotate(180deg);
  transition: transform 2s;
}

.infospan {
  display: inline-block;
  width: 1.5rem;
  background-color: yellow;
  border-radius: 50%;
  cursor: pointer;
  color: blue;
  text-align: center;
  border: solid 0.1 blue;
  font-size: 1.2rem;
  font-weight: 600;
}
.infospan:hover {
  font-weight: 800;
  background-color: chartreuse;
  border-color: white;
  font-size: 0.98rem;
}

.info {
  display: none;
  position: absolute;
  grid-area: 1/1 / span 1 / span 1;
  top: 0rem;
  left: 0rem;
  font-size: 1rem;
  background-color: yellow;
  color: blue;
  border: solid 0.1rem blue;
  border-radius: 0.5rem;
  padding: 0.4rem;
  width: 17rem;
  height: max-content;
  z-index: 7;
}
