@charset "utf-8";

#lpbox {
    width: 92%;
    max-width: 980px;
    margin: 0 auto;
}
@media screen and (max-width: 869px) {
  #lpbox {
      width: 100%;
      max-width: none;
      margin: 0 auto;
  }
}

.container {
  min-width: 320px;
}

/* base */
*,
*:before,
*:after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}
a {
  display: inline-block;
  width: 100%;
  text-decoration: none;
}
.wrapper {
  overflow: hidden;
}
.pane-landingpage-contents {
  border: 0 none;
  background: #fff;
}
#main {
  margin: 0 auto 30px;
}
#main img {
  max-width: 100%;
}

/*=== PC ===*/
/*html[data-browse-mode="P"] */ .contents_box {
  max-width: 980px;
  width: 100%;
}
/*html[data-browse-mode="P"] */ a[href*="tel:"] {
  pointer-events: none;
  cursor: default;
  text-decoration: none;
  display: block;
}
/*html[data-browse-mode="P"] */ .block-landingpage-login--member,
/*html[data-browse-mode="P"] */ #frmLP {
  width: 980px;
  margin: 0 auto;
}
/*html[data-browse-mode="P"] */ .action {
  margin: 0;
}

/*=== スマホ ===*/
/*html[data-browse-mode="S"] */.block-landingpage-form {
  display: block;
}
/*html[data-browse-mode="S"]*/ a[href*="tel:"] {
  pointer-events: painted;
}

/* 共通 */
.contents_box{
  width: 100%;
  margin: 0 auto;
}
.pc_only{
    display: none;
}
.sp_only{
    display: block;
}
/*--------------------------------------------------
mv 
--------------------------------------------------*/
#mv {
	padding:0;
  background: #fff;
}
.mv_inner{
  position: relative;
}
.mv_btn{
  position: absolute;
  width:16.5%;
  bottom: 14%;
  left: 12%;
  animation:anime1 0.6s ease 0s infinite alternate;
}
@media screen and (max-width: 869px) {
  .mv_btn{
  }
}
#mv h1{
  background: #fff;
  margin: 0 0;
}
.img_box{
  padding-bottom: 20px;
}
.img_box video {
  width: 100%;
  height: auto;
  display: block;
}
sup {
  vertical-align: super;
  font-size: 12px;
}
.note,
.note2{
  font-size: 16px;
}
@media screen and (max-width: 869px) {
  .note,
  .note2{
    font-size: 2.6vw;
  }
}

/* チェックボックス、ラジオボタン
----------------------------------*/
/* ラベルのスタイル　*/
#lpbox .chkbox label ,
#lpbox .radiobox label {
	color:#000;
	font-weight:600;
	font-size:24px;
	line-height:1.2;
	display:block;
	cursor:pointer;
	position:relative;
	margin:0 0 14px 0;
  padding: 24px 20px 24px 65px;
  border: 2px solid #ccc;
  background: #d9eef4;
  box-sizing: border-box;
  border-radius: 6px;
}
#lpbox .chkbox label .note,
#lpbox .radiobox label .note{
  font-weight:normal !important;
}
#lpbox .chkbox input[type=checkbox]:checked + label,
#lpbox .radiobox input[type=radio]:checked + label{
  background: #f96526;
  color: #fff;
}
#lpbox .chkbox label .sup{
  font-weight:normal !important;
  font-size: 16px;
  vertical-align: text-top;
}

/* ボックスのスタイル */
#lpbox .chkbox input[type=checkbox],
#lpbox .radiobox input[type=radio]{
    display: none;
}
#lpbox .chkbox label::before{
    background: #fff;
    border: 2px solid #ccc;
    border-radius: 4px;
    content: '';
    display: block;
    height: 30px;
    left: 15px;
    margin-top: -14px;
    position: absolute;
    top: 50%;
    width: 30px;
}
#lpbox .chkbox label::after{
    border-right: 5px solid #00cccc;
    border-bottom: 5px solid #00cccc;
    content: '';
    display: block;
    height: 26px;
    left: 22px;
    margin-top: -17px;
    opacity: 0;
    position: absolute;
    top: 50%;
    transform: rotate(45deg) translate3d(0,2px,0) scale3d(.7,.7,1);
    transition: transform .2s ease-in-out, opacity .2s ease-in-out;
    width: 19px;
}
#lpbox .radiobox label::before {
    background: #fff;
    border: 2px solid #ccc;
    border-radius: 50%;
    content: '';
    display: block;
    height: 30px;
    margin-top: -14px;
    position: absolute;
    top: 50%;
    left: 16px;
    width: 30px;
}
#lpbox .radiobox label::after {
    background: #00cccc;
    border-radius: 50%;
    content: '';
    display: block;
    height: 16px;
    left: 23px;
    margin-top: -7px;
    opacity: 0;
    position: absolute;
    top: 50%;
    width: 16px;
    -webkit-transition: all 0.2s ease; 
    transition: all 0.2s ease;
}




#lpbox .chkbox input[type=checkbox]:checked + label::before ,
#lpbox .radiobox input[type=radio]:checked + label::before {
    border-color: #666;
}
#lpbox .chkbox input[type=checkbox]:checked + label::after,
#lpbox .radiobox input[type=radio]:checked + label::after{
    opacity: 1;
}
@media screen and (max-width: 869px) {
  #lpbox .chkbox label::before{
      height: 20px;
      margin-top: -10px;
      top: 50%;
      left: 7px;
      width: 20px;
  }
  #lpbox .chkbox label::after {
      border-right: 5px solid #00cccc;
      border-bottom: 5px solid #00cccc;
      height: 18px;
      left: 13px;
      margin-top: -12px;
      top: 50%;
      width: 10px;
  }
  #lpbox .chkbox label{
  	font-size:2.6vw;
	  line-height:1.2;
    padding: 40px 40px 40px 65px;
    border-radius: 10px;
    font-weight:bold;
  }
  #lpbox .chkbox label{
    font-size:4.2vw;
    line-height: 1.4;
    padding: 3.2vw 3.2vw 3.2vw 8.6vw;
  }
  
  #lpbox .radiobox label::before {
      height: 20px;
      margin-top: -10px;
      top: 50%;
      left: 7px;
      width: 20px;
  }
  #lpbox .radiobox label::after {
      height: 10px;
      left: 12px;
      margin-top: -5px;
      top: 50%;
      width: 10px;
  }
  #lpbox .radiobox label {
  	font-size:2.6vw;
	  line-height:1.2;
    padding: 40px 40px 40px 65px;
    border-radius: 10px;
  }
  #lpbox .radiobox label {
    font-size:4.2vw;
    line-height: 1.4;
    padding: 3.2vw 3.2vw 3.2vw 7.2vw;
  }
}

/* 注釈・追加テキスト
----------------------------------*/
strong{
  font-weight:bold;
}
.underline{
  text-decoration:underline;
}
.bg-yellow{
   background: linear-gradient(transparent 50%, #ffff00 50%);
}
.txt-red{
  color:#ff0000;
}
.attbox{
	text-align:left;
	font-size:26px;
	font-weight:600;
	color:#17467c;
	margin:25px 0;
}

.atttxt{
	font-size:12px;
	vertical-align:super;
}

.attlist{
	margin:-40px 0 15px 0 !important;
	padding:0 !important;
	font-size:15px !important;
	font-family:
	"ヒラギノ明朝 ProN",
	"HG明朝E",
	"MS P明朝",
	"MS 明朝",
	serif;
	text-align:right;
	color:#17467c;
}

.ctaattBox{
	font-size:13px;
	margin:20px 0 0 30px;
	line-height:1.5;
	text-align:left;
}
.ctaattBox p{
	margin:0 0 15px 0;
	text-indent:-2.5em;
}
@media screen and (max-width: 869px) {
  .ctaattBox{
    font-size:1.4vw;
  }
}

.campaignBox{
	font-size:25px;
	margin:0 auto;
	line-height:1.5;
}
.campaignBox p{
	font-weight:bold;
	padding:40px 0 20px 0;
	color:#ff0d4d;
}
.box{
  padding: 30px;
}
.box img{
  max-width: 100%;
  height: auto;
}
/*.wrapper02,
.wrapper03,
#contents02{
  display: none;
  opacity: 0;
}*/
.wrapper01.active {
  animation: mv-anime 1s forwards;
}
.wrapper02.active ,
.wrapper03.active ,
#contents02.active{
  animation: wrap-fadein 1s forwards;
}
@keyframes wrap-fadein {
  0% {
    opacity: 0;
    transform: translateY(30px);
  }
  100% {
    opacity: 100;
    transform: translateY(0);
  }
}

@media screen and (max-width: 869px) {
  .box{
    padding: 2vw;
  }
}
.contents .htxt01{
/*  display: flex;
 -webkit-align-items: center;
 align-items: center;
*/
}
.contents .htxt01_icon{
/*  content: '';
  display: inline-block;
  width: 112px;
  height: auto;
  margin-right: 10px;
*/
  vertical-align: middle;
  text-align:center;
  margin-bottom:0.5em;
}
.contents .htxt01_txt{
   flex: 1;
  font-size: 26px;
}
@media screen and (max-width: 869px) {
  .contents .htxt01{
    display: block;
  }
  .contents .htxt01_icon{
    display: block;
    width: 80px;
    height: auto;
    margin: 0 auto 10px;
  }
  .contents .htxt01_txt{
    font-size: 18px;
  }
}
/*--------------------------------------------------
contents01
--------------------------------------------------*/
#contents01 .box{
	padding-bottom:20px;
}

#contents01 ul {
	text-align:left;
}
#chkbox li {
	list-style:none;
	margin-bottom:10px;
	display:block;
}
@media screen and (max-width: 869px) {
  #chkbox li {
    margin-bottom:2vw;
  }
}

#contents01 .wrapper01 ul{
	padding:0 0 40px;
}
#contents01 .wrapper02 ul{
	padding:0 0 40px;
}
#contents01 .wrapper03 ul{
	padding:0 0 10px;
}
/*--------------------------------------------------
check
--------------------------------------------------*/
.check_box{
  display: none;
  opacity: 0;
  margin-bottom: 60px;
}
.check_box.active{
    animation: wrap-fadein 1s forwards;
}
.check_inner{
  padding: 0;
}
.check_inner02{
  padding:0 0 20px;
}
.check_txt{
  font-size: 1.2vw;
  font-weight: normal;
}
.check_htxt{
  width: 100%;
  margin: 0 auto;
  margin-bottom: 10px;
  text-align:center;
}
.check_htxt img{
  margin:0 auto;
}
.check_img{
  margin-bottom: 20px;
  text-align:center;
}
.check_img img{
  margin:0 auto;
}
@media screen and (max-width: 869px) {
  .check_txt{
    font-size: 4.6vw;
  }
  .check_htxt{
    font-size: 4vw;
  }
  .check_htxt span{
    font-size: 5vw;
  } 
}
/*--------------------------------------------------
contents02
--------------------------------------------------*/
#contents02{
  display: none;
  opacity: 0;
}
#contents02.active {
  animation: wrap-fadein 1s forwards;
}
.contents02{
  background: url("../img/bg_arrow01.png") no-repeat;
  background-position: top;
  background-size: cover;
  background-color: #ffc69a;
  padding: 14% 20px 40px 20px;
  position: relative;
}
.contents02::before{
  content: "";
  background: url("../img/bg_arrow.png") no-repeat;
  background-size: 100% auto;
  background-position: top;
  position: absolute;
  top: -1px;
  left: 0;
  width: 100%;
  padding-top: 10%;
}
.contents02_txt01{
  font-size: 30px;
  text-align: center;
}
.contents02_box{
  margin-top: 22px;
  position: relative;
}
.btn{
  position: absolute;
  bottom: 20px;
  left: 0;
  right: 0;
  text-align: center;
}
#main .btn img{
  width:  80%;
  margin: 0 auto;
  animation: anime1 0.6s ease 0s infinite alternate;
  transform-origin:center;
}
@keyframes anime1 {
  from {
    transform: scale(0.9,0.9);
  }
  to {
    transform: scale(1,1);
  }
}
@media screen and (max-width: 869px) {
  .contents02_txt01{
    font-size: 4vw;
    text-align: center;
  }
  .btn{
    bottom: 2%;
  }
}

/*--------------------------------------------------
header
--------------------------------------------------*/
#headerBox{
	margin:0 auto;
	padding:0;
	text-align:center;
}

/*--------------------------------------------------
footer
--------------------------------------------------*/
#footerBox{
	background:#197f9d;
	margin:0 2px 0 3px;
	padding:15px 0;
	color:#fff;
	font-size:15px;
}


/*--------------------------------------------------
住所等
--------------------------------------------------*/
#addressBox{
	font-size:15px;
	font-family:
	"ヒラギノ明朝 ProN",
	"HG明朝E",
	"MS P明朝",
	"MS 明朝",
	serif;
	padding:30px 0;
	line-height:2;
	text-align:center;
	border-top:1px solid #999999;
  background: #fff;
}


