@charset "UTF-8";
/*
Description: LP Original
Author: Ann Tachibana
Version: 2.0
*/
/*======================================
layout
/*======================================*/
html {
  /*font-size: 62.5%;*/
  font-size: calc(100vw * 14 / 375);
  letter-spacing: 3px;
}
@media (min-width: 768px) {
  html {
    font-size: calc(100vw * 14 / 768);
  }
}
@media (min-width: 980px) {
  html {
    font-size: 16px;
  }
}
body {
  font-size: 1rem;
}
h1, h2, h3, h4, h5, h6 {
  font-weight: bold;
}
a {
  cursor: pointer;
}
a span {
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
  display: none;
}
p {
  text-align: left;
  line-height: 1.6em;
}
p a {
  text-decoration: underline;
  color: rgba(15, 20, 75, 1);
}
a.block span {
  text-indent: 0;
  display: block;
  line-height: 1em;
}
.txt-bold {
  font-weight: bold;
}
em.num {
  font-size: 130%;
  vertical-align: -0.05em;
}
.wrap {
  position: relative;
  text-align: center;
  width: 90%;
  margin: 0 auto;
  z-index: 1;
}
@media screen and (min-width:768px) {
  .wrap-wide {
    width: calc(100% - 10% - 54px - 1em);
  }
} /*END query*/
.iframe-wrap iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100% !important;
  height: 100% !important;
}
.video-wrap {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
  margin: 0 auto;
}
.center-img {
  overflow: hidden;
  position: relative;
}
.center-img img {
  width: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  max-width: none;
  height: 100%;
  width: auto;
}
@media screen and (min-width:768px) {
  .center-img img {
    height: auto;
    width: 100%;
  }
} /*END query*/
.block-center {
  text-align: center;
}
.block-center p {
  text-align: center;
}
.sp {
  display: block;
}
.pc {
  display: none;
}
.tab {
  display: none;
}
.sp-tab {
  display: block;
}
.pc-only {
  display: none;
}
.bg {
  padding: 4em 0;
}
.bg-top {
  padding-top: 4em;
}
.bg-bottom {
  padding-bottom: 4em;
}
.bg-min {
  padding: 2em 0;
}
.bg-top-min {
  padding-top: 2em;
}
.bg-bottom-min {
  padding-bottom: 2em;
}
.flex-SP, .flex-SP-rest {
  display: flex;
  flex-wrap: wrap;
}
.flex-SB {
  justify-content: space-between;
}
.flex-RE {
  flex-direction: row-reverse;
}
.flex-center {
  justify-content: center;
}
.flex-end {
  justify-content: flex-end;
}
.flex-middle {
  align-items: center;
}
.flex-stretch {
  align-items: stretch;
}
.flex-bottom {
  align-items: flex-end;
}
.flex-start {
  justify-content: start;
}
.max-wrap {
  width: 100%;
  max-width: 767px;
  margin: 0 auto;
}
.max-wrap-100 {
  max-width: 100px;
}
.max-wrap-150 {
  max-width: 150px;
}
.max-wrap-200 {
  max-width: 200px;
}
.max-wrap-250 {
  max-width: 250px;
}
.max-wrap-300 {
  max-width: 300px;
}
.max-wrap-350 {
  max-width: 350px;
}
.max-wrap-400 {
  max-width: 400px;
}
.max-wrap-450 {
  max-width: 450px;
}
.max-wrap-500 {
  max-width: 500px;
}
.max-wrap-550 {
  max-width: 550px;
}
.max-wrap-600 {
  max-width: 600px;
}
.max-wrap-650 {
  max-width: 650px;
}
.max-wrap-700 {
  max-width: 700px;
}
.max-wrap-800 {
  max-width: 800px;
}
.max-wrap-850 {
  max-width: 850px;
}
.max-wrap-900 {
  max-width: 900px;
}
.max-wrap-950 {
  max-width: 950px;
}
.max-wrap-1000 {
  max-width: 1000px;
}
.max-wrap-1024 {
  max-width: 1024px;
}
.max-wrap-1100 {
  max-width: 1100px;
}
.max-wrap-1200 {
  max-width: 1200px;
}
.max-wrap-1300 {
  max-width: 1300px;
}
/*responsible=============*/
@media screen and (min-width: 768px) { /*768px〜1023px*/
  .sp {
    display: none;
  }
  .pc {
    display: block;
  }
  .tab {
    display: block;
  }
  .sp-tab {
    display: block;
  }
  .bg {
    padding: 6em 0;
  }
  .bg-top {
    padding-top: 6em;
  }
  .bg-bottom {
    padding-bottom: 6em;
  }
  .bg-min {
    padding: 3em 0;
  }
  .bg-top-min {
    padding-top: 3em;
  }
  .bg-bottom-min {
    padding-bottom: 3em;
  }
  .flex {
    display: flex;
    flex-wrap: wrap;
  }
  .flex2 {
    width: calc((100% - 3em)/2);
    margin-right: 3em;
  }
  .flex3 {
    width: calc((100% - 3em*2)/3);
    margin-right: 3em;
  }
  .flex4 {
    width: calc((100% - 4%em*3)/4);
    margin: 0 4% 0 0;
  }
  .flex5 {
    width: calc((100% - 3%em*4)/5);
    margin: 0 3% 0 0;
  }
  .flex2:nth-of-type(2n), .flex3:nth-of-type(3n), .flex4:nth-of-type(4n), .flex5:nth-of-type(5n) {
    margin-right: 0;
  }
  .flex-re .flex2:first-of-type {
    margin-right: 0;
  }
  .flex-re .flex2:last-of-type {
    margin-right: 3em;
  }
}
@media screen and (min-width: 1024px) { /*1024px〜*/
  .sp-tab {
    display: none;
  }
  .tab {
    display: none;
  }
  .pc-only {
    display: block;
  }
}
/*======================================
submitBtn
/*======================================*/
@keyframes reflection {
  0% {
    transform: scale(0) rotate(45deg);
    opacity: 0;
  }
  85% {
    transform: scale(0) rotate(45deg);
    opacity: 0.5;
  }
  86% {
    transform: scale(4) rotate(45deg);
    opacity: 1;
  }
  100% {
    transform: scale(50) rotate(45deg);
    opacity: 0;
  }
}
.reflection {
  position: relative;
  overflow: hidden;
}
.reflection:after {
  position: absolute;
  content: "";
  height: 100%;
  width: 30px;
  top: -180px;
  left: 0;
  background-color: rgba(255, 255, 255, .5);
  opacity: 0;
  transform: rotate(45deg);
  animation: reflection 3s ease-in-out infinite;
}
/*======================================
.list-style
/*======================================*/
.list-style {
  text-align: center;
}
.list-style.list-style-left {
  text-align: left;
}
.list-style ul {
  display: inline-block;
}
.list-style ul li {
  position: relative;
  text-align: justify;
  line-height: 1.6em;
  margin-left: 1em;
}
.list-style ul li:not(:last-of-type) {
  margin-bottom: 0.5em;
}
.list-style ul li:before {
  display: block;
  position: absolute;
  margin-left: -1em;
}
.list-style.list-style01 ul li:before {
  content: "※";
}
.list-style.list-style02 ul li:before {
  content: "◎";
}
.list-style.list-style03 ul li, .list-style.list-style05 ul li {
  position: relative;
  text-align: left;
  padding-left: 2em;
  line-height: 1.5em;
  margin-left: 0;
}
.list-style.list-style03 ul li:not(:last-of-type), .list-style.list-style05 ul li:not(:last-of-type) {
  margin-bottom: 1em;
}
.list-style.list-style03 ul li:before, .list-style.list-style03 ul li:after, .list-style.list-style05 ul li:before, .list-style.list-style05 ul li:after {
  position: absolute;
  content: "";
  font-size: .9em;
  line-height: .9em;
}
.list-style.list-style03 ul li:before, .list-style.list-style05 ul li:before {
  margin: 0;
  background: rgba(180, 140, 100, .15);
  border: none;
  width: 1.8em;
  height: 1.8em;
  top: -0.1em;
  left: 0;
}
.list-style.list-style03 ul li:after, .list-style.list-style05 ul li:after {
  border-left: 2px solid rgba(220, 160, 50, 1);
  border-bottom: 2px solid rgba(220, 160, 50, 1);
  width: 0.9em;
  height: 0.45em;
  transform: rotate(-45deg);
  left: 0.5em;
  top: 0.45em;
}
.list-style.list-style04 ul li {
  text-align: left;
  margin-bottom: 1em;
  margin: 0 0 0 2em;
}
.list-style.list-style04 ul li:before {
  position: absolute;
  content: "";
  margin: 0;
  background: url(../img/check.png) no-repeat center;
  background-size: 100%;
  width: 1.7em;
  height: 1.7em;
  left: -2em;
  top: 0;
}
.list-style.list-style04 ul li:not(:last-of-type) {
  margin-bottom: 1em;
}
.check-list {
  display: inline-block;
}
.check-list li {
  position: relative;
  text-align: left;
  padding-left: 2em;
  line-height: 1.5em;
}
.check-list li:before, .check-list li:after {
  position: absolute;
  content: "";
  font-size: 1em;
  line-height: 1em;
}
.check-list li:before {
  background: #fff;
  border: 1px solid rgba(120, 145, 130, .3);
  width: 1.2em;
  height: 1.2em;
  width: 1.5em;
  height: 1.5em;
  font-size: 1em;
  line-height: 1em;
  top: -0.1em;
  left: 0;
}
.check-list li:after {
  border-left: 2px solid rgba(120, 145, 130, 1);
  border-bottom: 2px solid rgba(120, 145, 130, 1);
  width: 0.8em;
  height: 0.4em;
  transform: rotate(-45deg);
  left: 0.35em;
  top: 0.35em;
}
.check-list li:not(:last-of-type) {
  margin-bottom: 1em;
}