@charset "UTF-8";
/*
Description: LP Original
Author: Ann Tachibana
Version: 2.0
*/
/*======================================
layout
/*======================================*/
html, body { /*〜567px*/
  font-size: 4vw;
  letter-spacing: 1px;
}
@media screen and (min-width: 768px) { /*768px〜1023px*/
  html, body {
    font-size: 18px;
  }
}
h1, h2, h3, h4, h5, h6 {
  font-weight: bold;
  line-height: 1.3em;
}
p {
  line-height: 1.6em;
}
.desc p {
  text-align: justify;
  line-height: 1.8em;
}
.desc p:not(:last-of-type) {
  margin-bottom: .7em;
}
.txt-bold {
  font-weight: bold;
}
em.num {
  font-size: 130%;
  vertical-align: -0.05em;
}
.wrap {
  position: relative;
  width: 90%;
  max-width: 960px;
  margin: 0 auto;
  z-index: 1;
}
.video-wrap {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
  margin: 0 auto;
  box-shadow: 0 0 15px rgba(0, 0, 0, .7);
}
.video-wrap iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100% !important;
  height: 100% !important;
}
.center-img {
  overflow: hidden;
  position: relative;
}
.center-img img {
  width: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.block-center {
  text-align: center;
}
.block-center .desc {
  display: inline-block;
}
.sp {
  display: block;
}
.pc {
  display: none;
}
.tab {
  display: none;
}
.pc-only {
  display: none;
}
.bg {
  padding: 3em 0;
}
.bg-top {
  padding-top: 3em;
}
.bg-bottom {
  padding-bottom: 3em;
}
.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;
  }
  .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 {
    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〜*/
  .tab {
    display: none;
  }
  .pc-only {
    display: block;
  }
}
/*======================================
background color
/*======================================*/
.bg-White {
  background: #fff;
}
.bgGR-White-bottom {
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 1) 100%);
}
.bgGR-White-top {
  background: linear-gradient(to bottom, rgba(255, 255, 255, .5) 0%, rgba(255, 255, 255, 0) 100%);
}
.bgGR-Gray-top {
  background: linear-gradient(to bottom, rgba(245, 245, 245, 1) 80%, rgba(255, 255, 255, 1) 100%);
}
.bgGR-mainColor {
  /* Permalink - use to edit and share this gradient: https://colorzilla.com/gradient-editor/#ffcbe1+0,8ad2de+100 */
  background: linear-gradient(45deg, #ffcbe1 0%, #8ad2de 100%);
}
/*======================================
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 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;
  font-size: 110%;
}
.list-style.list-style04 ul li:before {
  position: absolute;
  content: "";
  margin: 0;
  background: url(../img/check-pink.png) no-repeat center;
  background-size: 100%;
  width: 2em;
  height: 2em;
  left: -2em;
  top: -0.35em;
}
.list-style.list-style04 ul li:not(:last-of-type) {
  margin-bottom: 1em;
}
/*======================================
footer
/*======================================*/
footer {
  position: relative;
  text-align: center;
  font-size: 14px;
  background: #fff;
}
footer .footer-CMN ul {
  font-weight: bold;
  padding: 1em 0 0;
}
footer .footer-CMN ul li {
  position: relative;
  font-size: 110%;
  padding: 0 1em;
  margin: 0;
  line-height: 1em;
}
foote .footer-CMN ul li:not(:last-of-type):after {
  position: absolute;
  content: "";
  top: 0;
  right: 0;
  height: 1em;
  width: 1px;
  background: #383838;
}
footer #copy-right p {
  font-size: 12px;
  text-align: center;
  line-height: 1.4em;
  padding: 1em;
  margin: 0 auto;
}
footer #copy-right span {
  display: inline-block;
}
footer #copy-right span:last-of-type {
  display: block;
}
footer .footer-CMN table {
  border-collapse: separate;
  border-spacing: 0 5px;
  font-size: 14px;
  line-height: 1.3em;
  margin: 0 auto;
}
footer .footer-CMN th {
  width: 25%;
  vertical-align: middle;
  font-weight: bold;
  padding: 1em .5em;
  margin-bottom: 5px;
}
footer .footer-CMN td {
  width: 75%;
  vertical-align: middle;
  text-align: justify;
  padding: .5em 0 .5em .5em;
  margin-bottom: 5px;
}
@media screen and (min-width: 768px) { /*768px〜1023px*/
  footer {
    font-size: 16px;
  }
  footer .footer-CMN ul li {
    font-size: 100%;
  }
}