*{
  box-sizing: border-box;
}

nav{
  position: fixed;
  top: 0;
  left: 0;
  z-index: 3;

  width: 100%;

  display: flex;
  justify-content: space-between;
  align-items: center;
  text-align: center;

  color: #ffffff;
  background-color: #202024;
  padding: 20px;

  font-size: 16px;
  line-height: 20px;
  font-weight: bold;
}

nav ul{
  gap: 20px;
  text-align: center;
  padding: 0;

  display: flex;
  justify-content: space-evenly;
  align-items: center;
  text-align: center;
}

nav ul li {
  padding: 0;
  color: #ffffff;
  text-decoration: none;
  list-style: none;

}
li:hover{
  color: #d4d4d4;
}

.intro, .wrapper, #padrão , #usando-img-svg-url{
  height: 700px;
  padding-top: 200px;
  
}

.intro{
  margin: 144px auto 10px;
  background-color: aqua;
}

.wrapper{
  background-color: green;
}

#padrão{
  background-color: brown;
}

#usando-img-svg-url{
  background-color: blue;
}



/*
.wrapper{
  display: none;
}
*/


.wrapper input{
  display: none;
}
/**/

.wrapper label::before{
  content: '';

  width: 24px;
  height: 24px;

  border: 1px solid #232020;

  display: block;  /*obrigatorio para exibir o quadrado*/

  border-radius: 8px;
}

.wrapper label{
  display: flex;    /* para colocar um elemento html(label) ao lado de seu ::before é colocar nela display : flex    e um gap nela mesma para ficar distante do seu ::before*/
  gap: 16px;
}

.wrapper{
  margin: 50px auto;
  align-items: center;  /*Eu so tenho um elemento  label + seu before logo n tem como alinhar label + outro ja que ela está soziha  então coloque uma align items dentro da propria label*/
  padding: 10px;
}

.wrapper label{
  margin: 0px;
  padding: 0px;
  align-items: center; 
}

.wrapper input:checked + label::before{
  background-color: #232020;
}

/*---------------------o jeito sem acessibilidade


              #usando-img-svg-url{
                margin-top: 10px;
              }

              #usando-img-svg-url input{
                display: none;
              }

              #usando-img-svg-url label::before{
                content: '';
                border: 1px solid #008000;

                width: 20px;
                height: 20px;

                display: block;

                border-radius: 5px;
              }
colocou a label e seu ::before na mesma linha
              #usando-img-svg-url label{   
                display: flex;
                gap: 16px ;
              }

----------------------------------*/
#usando-img-svg-url{
  margin-top: 10px;
}
/*  tirei para colocar-lo com opacidade 0 e funcionar com a outline tab->
                 <-
#usando-img-svg-url input{
  display: none ;
}
*/
#usando-img-svg-url label::before{
  content: '';
  border: 1px solid #008000;

  width: 24px;
  height: 24px;

  display: block;

  border-radius: 5px;
}
/*colocou a label e seu ::before na mesma linha*/
#usando-img-svg-url label{   
  display: flex;   /* este n funcniona mais pois o ::before esta nom mesmo canto que o invisivel input , Logo eu devo colocar display flex na div pai que tem o input e label como filhos*/
  gap: 16px ;
}
#usando-img-svg-url{
  position: relative;
}
#usando-img-svg-url label::before{   
  position: absolute;
  top: 0;
  left: 0;

}

#usando-img-svg-url input{
  opacity: 0;
}

#usando-img-svg-url{
  display: flex;
  gap: 20px;
}

#usando-img-svg-url input:checked + label::before{ 
  background-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cg clip-path='url(%23clip0_1927_23)'%3E%3Cpath d='M9 16.17L4.83 12L3.41 13.41L9 19L21 7L19.59 5.59L9 16.17Z' fill='%2342D3FF'/%3E%3C/g%3E%3Cdefs%3E%3CclipPath id='clip0_1927_23'%3E%3Crect width='24' height='24' fill='white'/%3E%3C/clipPath%3E%3C/defs%3E%3C/svg%3E%0A");  
}

#usando-img-svg-url input:focus + label::before{ 
  outline: 2px solid #000;  
}
/*
.wrapper2 #usando-img-svg-base64{
  position: relative;
}
.wrapper2 #usando-img-svg-base64 input{
  position:absolute;
  top: 0;
  left: 0;

}

*/