@view-transition{
  navigation: auto;
}

html{
  overflow: hidden;
}

body{
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
}

.fundo_paisagem{
  background: url('../images/beach.png') no-repeat center center;
  perspective: 800px;
  background-size: 250px 500px;
}

.porta{
  width: 250px;
  position: relative;
  background: url('../images/porta.jpg') no-repeat center center;
  background-size: contain;
  display: grid;
  font-size: 30px;
  font-family: sans-serif;
  place-items: center;
  height: 500px;
  transition: 1s ease-in-out;
  backface-visibility: hidden;
  transform-origin: left;

}
.wrapper-porta{
  cursor: grab;
  transform-style: preserve-3d;
  border: 1px solid black;
}

.wrapper-porta:hover >*{
  transform: rotateY(.40turn);
}


/* --------- Selection -------------- */

.selection{
  z-index: 100;
  display: flex;
  gap: 5px;
  position: fixed;
  top: 40px;
  left: 40px;
  background-color: #ccc;
  padding: 10px;
  filter: drop-shadow(2px 2px 1px #686868);
}

.selection button{
  cursor: pointer;
  box-sizing: border-box;
  padding: 10px 10px;
  color: #fff;
  background-color: rgb(0, 204, 255);
  font-size: 15px;
  font-weight: 600;
  text-shadow: 1px 1px 2px black;
  box-shadow: 1px 1px 15px 1px #2053e0 inset;
    background-color: rgb(161, 159, 159);
    box-shadow: 1px 1px 15px 1px #393a3f inset;
  border: 2px solid rgba(48, 47, 47, 0.589);
  border-radius: 5px;
}

.selection button.active{
  background-color: rgb(0, 204, 255);
  box-shadow: 1px 1px 15px 1px #2053e0 inset;
}


/* ------------ Message ------------- */

.message{
  display: none;
}