/*-------------------------------
---main
-------------------------------*/

main {
  position: relative;
  overflow: hidden;
}

main::before {
  content: "";
  display: block;
  position: fixed;
  bottom: 0;
  left: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
  background-image: url(../image/bg/home-story.jpg);
  background-size: cover;
  background-position: bottom;
}


/*----- -------------------------
---.hero
----- -------------------------*/

.hero {
  padding: 120px 0;
  margin-bottom: 0;
}

.hero .catch {
  font-size: 2.4rem;
  margin: 25px 0 55px;
}

.hero .text {
  width: 40em;
  margin: 0 auto;
  line-height: 2;
}


/*----- -------------------------
---.contents
----- -------------------------*/

.stories {
  grid-template-columns: 1fr;
  grid-gap: 20px;
  margin-bottom: 60px;
}

.stories .item {
  position: relative;
}

.stories .item img {
  aspect-ratio: 3 / 1;
  object-fit: cover;
  object-position: center;
}

.stories .item a {
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  background-color:	rgba(0,0,0,0.3);
  transition: 0.5s;
}

.stories .item a:hover {
  background-color:	rgba(0,0,0,0);
}

.stories .item a > div {
  width: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
}

.stories .item .num {
  font-size: 2rem;
}

.stories .item .title {
  font-size: 3.6rem;
  letter-spacing: 0.1em;
  margin-top: 30px;
  margin-bottom: 30px;
}

.stories .item .title span {
  display: inline-block;
}

.stories .item .text {
  font-size: 2rem;
  letter-spacing: 0.05em;
}