.main-img {
  position: relative;
}
.main-img .logo {
  position: absolute;
  width: 340px;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
}
.main-img .sns {
  position: absolute;
  bottom: 20px;
  right: 20px;
  width: 246px;
}
.main-img .sns .list .item + .item {
  margin: 12px 0 0;
}
@media screen and (min-width: 768px) {
	.main-img .sns {
	  top: 69px;
	  right: 108px;
	}
}
.intro {
  position: relative;
}
.intro .bg {
  overflow: hidden;
  position: relative;
  padding: 100px 0 0;
  background: url(../img/top/bg01_sp.png) no-repeat 0 0;
  background-size: cover;
}
.intro .img01 {
  position: absolute;
  width: 300px;
  top: 0;
  left: -150px;
}
.intro .title01 {
  width: 164px;
  margin: 0 auto;
}
.intro .area-img {
  position: relative;
  margin: 0 0 312px;
}
.intro .area-img .img02 {
  position: absolute;
  width: 500px;
  top: 0;
  right: -120px;
  margin: -140px 0 0;
}
.intro .area-text .text {
  font-size: 16px;
  line-height: 1.75;
  color: #000;
}
.intro .area-text .text + .text {
 margin-top: 0.8em;
}
.intro .area-img02 {
  position: relative;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: 3;
}
.intro .area-img02 .img01 {
  position: relative;
  width: 300px;
  top: -110px;
  left: 50%;
  margin: 0 0px 0 -20px;
  transform: translateX(-50%);
  z-index: 6;
}
.intro .area-img02 .img02 {
  position: absolute;
  width: 350px;
  top: 220px;
  margin: 0 0 0 70px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 5;
}
.intro .area-img02 .img03 {
  position: absolute;
  width: 460px;
  top: 220px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 4;
}
.intro .appeal {
  display: block;
  padding: 150px 0 0;
}
.intro .appeal .bg {
  position: relative;
  overflow: initial;
  margin: 0;
  padding: 0 15px 48px;
  background: url(../img/top/bg02_sp.png) no-repeat;
  background-size: cover;
  background-position: top;
}
.intro .appeal .bg .area-text {
  position: relative;
  display: flex;
  flex-direction: row-reverse;
  justify-content: center;
  gap: 0 30px;
  z-index: 6;
  margin: 160px 0 0;
}
.intro .appeal .bg .area-text .title01 {
  width: 36.8%;
  max-width: 200px;
  margin: 0;
  z-index: 6;
}
.intro .appeal .bg .area-text .area-text-vertical {
	text-align: left;
	width: fit-content;
	min-height: 700px;
	writing-mode: vertical-rl;
}
.intro .appeal .bg .area-text .area-text-vertical .text {
  display: block;
  margin: 0 0 0 0.5em;
  font-weight: 500;
  color: #fff;
}
.intro .appeal .bg .area-text .area-text-vertical .text:last-child {
  margin: 0;
}
@media screen and (min-width: 768px) {
  .intro .bg {
    overflow: hidden;
    position: relative;
    padding: 280px 0 0;
    background: url(../img/top/bg01_pc.png) no-repeat 0 0;
    background-size: cover;
  }
  .intro .bg .content01 {
    position: relative;
    padding: 0 0 240px;
  }
  .intro .bg .content01 .title01 {
    position: absolute;
    width: 230px;
    right: 0;
    top: -155px;
  }
  .intro .bg .content01 .area-img {
    position: absolute;
    margin: 0;
    right: 0;
    bottom: 0;
  }
  .intro .bg .content01 .area-img .img02 {
    position: absolute;
    width: 900px;
    top: -400px;
    right: -160px;
    margin: 0;
  }
  .intro .bg .content01 .area-text {
    text-align: center;
  }
  .intro .bg .content01 .area-text .text {
    font-size: 18px;
  }
  .intro .img01 {
    position: absolute;
    width: 500px;
    top: -260px;
    left: -270px;
  }
  .intro .title01 {
    width: 164px;
    margin: 0 auto;
  }
  .intro .area-img02 {
    z-index: 3;
  }
  .intro .area-img02 .img01 {
    position: relative;
    width: 300px;
    top: -50px;
    left: 50%;
    margin: 0 0px 0 -20px;
    transform: translateX(-50%);
    z-index: 6;
  }
  .intro .area-img02 .img02 {
    position: absolute;
    width: 520px;
    top: 370px;
    margin: 0 0 0 120px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 5;
  }
  .intro .area-img02 .img03 {
    position: absolute;
    width: 700px;
    top: 120px;
    margin: 0 0 0 110px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 4;
  }
  .intro .appeal {
    display: block;
    padding: 100px 0 0;
  }
  .intro .appeal .bg {
    margin: 0;
    padding: 120px 0 350px;
    background: url(../img/top/bg02_pc.png) no-repeat;
    background-size: cover;
    background-position: top center;
  }
  .intro .appeal .bg .content02 .area-img02 {
    position: absolute;
    top: 0;
    left: auto;
    transform: none;
  }
  .intro .appeal .bg .content02 .area-img02 .img01 {
    width: 400px;
    top: auto;
    left: auto;
    transform: none;
  }
  .intro .appeal .bg .content02 .area-text {
    position: relative;
    display: flex;
    flex-direction: row-reverse;
    justify-content: end;
    gap: 0 64px;
    z-index: 6;
    margin: 160px 0 0;
  }
  .intro .appeal .bg .content02 .area-text .title01 {
    width: 50%;
    max-width: 200px;
    margin: 0;
    padding: 0 0 150px;
    z-index: 6;
  }
  .intro .appeal .bg .content02 .area-text .area-text-vertical {
    text-align: left;
  }
  .intro .appeal .bg .content02 .area-text .area-text-vertical .text {
    font-size: 18px;
  }
  .intro .appeal .bg .content02 .area-text .area-text-vertical .text:last-child {
    margin: 0;
  }
}

.recommend .bg {
  padding: 100px 0 0;
  background: url(../img/top/bg03.png) no-repeat 0 0;
  background-size: cover;
  background-position: top;
}
.recommend .bg .title01 {
  width: 320px;
  margin: 0 auto 32px;
}
.recommend .bg .recommend-desc {
  margin: 0 0 32px;
}
.recommend .bg .recommend-desc .text + .text {
  margin: 1em 0 0;
}
.recommend .bg .recommend-list {
  margin: 0 0 64px;
}
.recommend .bg .recommend-list .recommend-item + .recommend-item {
  margin: 40px 0 0;
}
.recommend .bg .recommend-list .recommend-item .img {
  width: 320px;
  margin: 0 auto 16px;
}

.recommend .bg .recommend-list .recommend-item.recommend-item02 .img {
  width: 340px;
}

.recommend .bg .recommend-list .recommend-item .title02 {
  margin: 0 0 20px;
  text-align: center;
  font-size: 26px;
  letter-spacing: -0.54px;
  line-height: 1.1851851852;
}
.recommend .bg .recommend-list .recommend-item .title02 span {
  display: block;
  margin: 12px 0 0;
  line-height: 1.2;
  font-size: 20px;
  letter-spacing: -0.04px;
}
.recommend .bg .recommend-list .recommend-item .title03 {
  text-align: center;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: -0.38px;
  line-height: 1.2105263158;
}
.recommend .bg .recommend-list .recommend-item .title03 span {
  color: #E11F26;
}
.recommend .bg .recommend-list .recommend-item .text + .text {
  margin: 1em 0 0;
}
.recommend .bg .btn {
  text-align: center;
}
.recommend .bg .btn a {
  width: 290px;
  padding: 16px 0;
  line-height: 1;
  font-size: 20px;
  background: #842928;
}
.recommend .inside {
  display: block;
  margin: 48px 0 0;
}
.recommend .inside .bg {
  padding: 70% 0 120px;
  background: url(../img/top/bg04_sp.png) no-repeat top center;
  background-size: cover;
}
.recommend .inside .bg .inside-title01 {
  margin: 0 0 40px;
  text-align: center;
  font-size: 40px;
  font-weight: 700;
  line-height: 1.2093023256;
}
.recommend .inside .bg .intro {
  margin: 0 0 32px;
}
.recommend .inside .bg .intro .intro-bg {
	    padding: 32px 14px;
  background: rgba(0, 0, 0, 0.59);
}
.recommend .inside .bg .intro .intro-bg .text{
	font-size:13px;
	letter-spacing:-.01em;
}
.recommend .inside .bg .intro .intro-bg .text + .text {
  margin: 1em 0 0;
}
.recommend .inside .bg .inside-img {
  width: 80%;
  margin: 0 0 -10%;
}
.recommend .inside .bg .insode-list .inside-item + .inside-item {
  margin: 64px 0 0;
}
.recommend .inside .bg .insode-list .inside-item.reverse .img {
  margin: 0 0 8px auto;
}
.recommend .inside .bg .insode-list .inside-item .img {
  width: 80%;
  margin: 0 0 8px;
}
.recommend .inside .bg .insode-list .inside-item .area-text {
  padding: 20px 24px;
  background: #000;
}
.recommend .inside .bg .insode-list .inside-item .area-text .inside-title02 {
  margin: 0 0 8px;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.6px;
  line-height: 1.25;
}
.recommend .inside .bg .insode-list .inside-item .area-text .desc .text + .text {
  margin: 1em 0 0;
}
@media screen and (min-width: 768px) {
  .recommend .bg {
    padding: 116px 0 0;
  }
  .recommend .bg .title01 {
    width: 740px;
    margin: 0 auto 80px;
  }
  .recommend .bg .recommend-desc {
    text-align: center;
    margin: 0 0 80px;
  }
  .recommend .bg .recommend-desc .text {
    font-size: 18px;
    font-weight: 500;
  }
  .recommend .bg .recommend-desc .text + .text {
    margin: 0;
  }
  .recommend .bg .recommend-list {
    margin: 0 0 40px;
  }
  .recommend .bg .recommend-list .recommend-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .recommend .bg .recommend-list .recommend-item.reverse {
    flex-direction: row-reverse;
  }
  .recommend .bg .recommend-list .recommend-item + .recommend-item {
    margin: 140px 0 0;
  }
  .recommend .bg .recommend-list .recommend-item .img {
    max-width: 632px;
    width: calc(48% - 60px);
    margin: 0;
  }
  .recommend .bg .recommend-list .recommend-item.recommend-item02 .img {
	  width: calc(51% - 60px);
	}
  .recommend .bg .recommend-list .recommend-item .area-text {
    width: 52%;
  }
  .recommend .bg .recommend-list .recommend-item .area-text .title02 {
    margin: 0 0 38px;
    text-align: left;
    font-size: 64px;
    letter-spacing: -2.02px;
    line-height: 1.198019802;
  }
  .recommend .bg .recommend-list .recommend-item .area-text .title02 span {
    margin: 18px 0 0;
    line-height: 1.2037037037;
    font-size: 32px;
    letter-spacing: -1.08px;
  }
  .recommend .bg .recommend-list .recommend-item .area-text .text {
    font-size: 18px;
  }
  .recommend .bg .recommend-list .recommend-item .area-text .title03 {
    text-align: center;
    font-size: 18px;
    font-weight: 700;
    letter-spacing: -0.38px;
    line-height: 1.2105263158;
  }
  .recommend .bg .recommend-list .recommend-item .area-text .title03 span {
    color: #E11F26;
  }
  .recommend .bg .recommend-list .recommend-item .area-text .desc .text-img {
    width: 100%;
  }
  .recommend .bg .btn {
    text-align: center;
  }
  .recommend .bg .btn a {
    width: 350px;
    padding: 24px 0;
    line-height: 1;
    font-size: 24px;
  }
  .recommend .inside {
    display: block;
    margin: 48px 0 0;
  }
  .recommend .inside .bg {
    padding: 30% 0 120px;
    background: url(../img/top/bg04_pc.png) no-repeat top center;
    background-size: cover;
  }
  .recommend .inside .bg .inside-title01 {
    margin: 0 0 56px;
    text-align: center;
    font-size: 58px;
  }
  .recommend .inside .bg .intro {
    width: 90%;
    margin: 0 auto 72px;
  }
  .recommend .inside .bg .intro .intro-bg {
    padding: 54px 56px;
    background: rgba(0, 0, 0, 0.59);
  }
  .recommend .inside .bg .intro .intro-bg .text {
    font-size: 16px;
    letter-spacing: -0.88px;
    line-height: 1.4545454546;
  }
  .recommend .inside .bg .intro .intro-bg .text + .text {
    margin: 1em 0 0;
  }
  .recommend .inside .bg .inside-img {
    width: 80%;
    margin: 0 0 48px;
  }
  .recommend .inside .bg .insode-list .inside-item {
    position: relative;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .recommend .inside .bg .insode-list .inside-item.reverse {
    flex-direction: row-reverse;
  }
  .recommend .inside .bg .insode-list .inside-item + .inside-item {
    margin: 24px 0 0;
  }
  .recommend .inside .bg .insode-list .inside-item.edge:before {
    content: "";
    position: absolute;
    display: block;
    width: 500px;
    height: 510px;
    background: url(../img/top/bg-edge02.png) no-repeat 0 0;
    background-size: 100%;
    top: 50%;
    right: 0;
    transform: translateY(-70%);
    z-index: 1;
  }
  .recommend .inside .bg .insode-list .inside-item.reverse .img {
    position: relative;
    width: 48.5%;
    margin: -30% 0 0 0;
    z-index: 2;
  }
  .recommend .inside .bg .insode-list .inside-item.reverse .area-text {
    position: initial;
    width: 49%;
    margin: 0 0;
  }
  .recommend .inside .bg .insode-list .inside-item .img {
    width: 50%;
    margin: 0 0 0;
    left: 0;
  }
  .recommend .inside .bg .insode-list .inside-item .area-text {
    position: relative;
    width: 45.5%;
    margin: 0 0 0 auto;
    padding: 32px 36px;
    z-index: 2;
  }
  .recommend .inside .bg .insode-list .inside-item .area-text .inside-title02 {
    margin: 0 0 24px;
    font-size: 36px;
    letter-spacing: 0;
    line-height: 1.25;
  }
  .recommend .inside .bg .insode-list .inside-item .area-text .desc .text {
    font-size: 16px;
    line-height: 1.45;
    letter-spacing: 0.0345em;
  }
  .recommend .inside .bg .insode-list .inside-item .area-text .desc .text + .text {
    margin: 1em 0 0;
  }
}

.info .bg {
  padding: 80px 0 64px;
  background: url(../img/top/bg01_sp.png) no-repeat top center;
  background-size: cover;
}
.info .bg .title02 {
  margin: 0 0 16px;
  font-size: 38px;
  font-weight: 700;
  text-align: center;
  color: #000;
  line-height: 1;
}
.info .bg .text {
  margin: 0 0 32px;
  text-align: center;
  color: #000;
}
.info .bg .list {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 24px 9px;
  margin: 0 0 32px;
}
.info .bg .list .item {
  width: calc(50% - 8px);
}
.info .bg .list .item .img {
  margin: 0 0 8px;
}
.info .bg .list .item .title03 {
  text-align: center;
  color: #000;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: -0.14px;
}
.info .bg .caution {
  color: #000;
  letter-spacing: 0.025px;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .info .bg {
    padding: 90px 0 94px;
    background: url(../img/top/bg01_pc.png) no-repeat top center;
    background-size: cover;
  }
  .info .bg .title02 {
    margin: 0 0 32px;
    font-size: 58px;
  }
  .info .bg .text {
    margin: 0 0 28px;
    font-size: 16px;
  }
  .info .bg .list {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 0 18px;
    margin: 0 0 18px;
  }
  .info .bg .list .item {
    width: calc(25% - 18px);
  }
  .info .bg .list .item .img {
    margin: 0 0 8px;
  }
  .info .bg .list .item .title03 {
    font-size: 19px;
    letter-spacing: -0.26px;
  }
  .info .bg .caution {
    font-size: 12px;
    letter-spacing: 0;
    text-align: right;
  }
}/*# sourceMappingURL=top.css.map */