@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;300;400;500;700;900&family=Roboto:wght@400;500;700&family=Shippori+Mincho:wght@400;500;600;700&display=swap');

*{
  margin:0;
  padding:0;
  list-style: none;
  box-sizing: border-box;
  text-decoration: none;
  background-size: cover;
  background-position: center;
  -webkit-font-smoothing: antialiased;
}

*::before,
*::after{
  background-size: cover;
  background-position: center;
}

img{
  display: block;
}


body{
  font-size: 16px;
  font-family: 'Roboto','Noto Sans JP', 'Noto Sans CJK JP' , sans-serif;
  color: #1d1d1d;
  position: relative;
}

body::before{
  content:"";
  width:100%;
  height:100%;
  background-color:#F7F7F7;
  position: absolute;
  top:0;
  left:0;
  z-index:-10;
}

.container{
  max-width:1080px;
  margin:0 auto;
  padding:0 20px;
}

.hide{
  display: none!important;
}

.hover-opa{
  transition-duration: 0.3s;
}

.hover-opa:hover{
  opacity: 0.7;
}


.main-view-area{
  position: relative;
  overflow: hidden;
}

.main-view-area::before{
  content:"";
  width:100%;
  height:100%;
  background-color:#000000;
  position: absolute;
  top:0;
  left:0;
  z-index:-5;
}

.main-view-area .flex{
  display: flex;
}

.main-view-area .flex .left{
  width:640px;
  height:360px;
  position: relative;
}

.main-view-area .flex .left img{
  width:auto;
  height:100%;
  position: absolute;
  top:0;
  left:0;
  z-index:-3;
}

.main-view-area .flex .right{
  width:400px;
  height:360px;
  display:flex;
  align-items:center;
}

.main-view-area .flex .right h1{
  font-family: 'Shippori Mincho', serif;
  font-weight: normal;
  font-size: 32px;
  letter-spacing: 0.04em;
  line-height: 1;
  text-align: center;
  color: #fff;
  margin-bottom: 18px;
}

.main-view-area .flex .right p{
  font-family: 'Shippori Mincho', serif;
  font-weight: normal;
  letter-spacing: 0.04em;
  line-height: 1;
  text-align: center;
  color: #fff;
}


.contact-section{
  padding-top: 60px;
  padding-bottom: 80px;
}

.contact-section .movie-thumb{
  max-width:800px;
  height:450px;
  margin:0 auto 60px;
}

.contact-section .movie-thumb iframe{
  display: block;
  width:100%;
  height:100%;
}

.contact-section p.top-text{
  max-width: 900px;
  margin: 0 auto 64px;
  font-size: 15px;
  letter-spacing: 0.04em;
  line-height: 1.9;
}

.contact-section .finish-area{
  max-width: 900px;
}

.contact-section .finish-area p{
  font-weight: normal;
  font-size: 15px;
  letter-spacing: 0.04em;
  line-height: 1.9;
}

.contact-section .finish-area p span{
  color:#CC1228;
}

.contact-section .finish-area p a{
  color:#1d1d1d;
}

.contact-section h2{
  font-family: "Noto Sans JP";
  font-weight: normal;
  font-size: 22px;
  letter-spacing: 0.2em;
  line-height: 1;
  text-align: center;
  color: #111;
  margin-bottom: 32px;
}


.white-box{
  background-color:#fff;
  padding:60px 70px;
  margin-bottom: 32px;
}

.white-box .form-list{
  margin-bottom: 40px;
}

.white-box .form-list .line{
  display: flex;
  justify-content: space-between;
  padding:16px 0;
  border-bottom:1px solid #D6DADB;
}

.white-box .form-list .line.no-border{
  border-bottom:none;
  padding:16px 0 0;
}

.white-box .form-list .line:last-child{
  border-bottom:none;
  padding:16px 0 0;
}

.white-box .form-list .line .left{
  width:220px;
  display: flex;
  justify-content: space-between;
  padding-top: 8px;
}

.white-box .form-list .line .left .title{
  font-size: 15px;
  letter-spacing: 0.04em;
  line-height: 1;
  color: #111;
  padding-top: 4px;
}

.white-box .form-list .line .left .free{
  font-size: 11px;
  letter-spacing: 0.08em;
  line-height: 1;
  color: #fff;
  width: 42px;
  height: 21px;
  border-radius: 10.5px;
  background: #bcc2cc;
  display: flex;
  align-items: center;
  justify-content: center;
}

.white-box .form-list .line .left .must{
  font-size: 11px;
  letter-spacing: 0.08em;
  line-height: 1;
  color: #fff;
  width: 42px;
  height: 21px;
  border-radius: 10.5px;
  background: #cc1228;
  display: flex;
  align-items: center;
  justify-content: center;
}

.white-box .form-list .line .left p{
  display: none;
}

.white-box .form-list .line .right{
  width:calc(100% - 240px);
}

.white-box .form-list .line .right.pay-area{
  padding-top: 6px;
}

.white-box .form-list .line .right.pay-area label{
  cursor: pointer;
}

.white-box .form-list .line .right input[type = "text"]{
  border:none;
  background:none;
  display: block;
  width: 100%;
  height: 38px;
  background: #f6f6f6;
  padding:0 16px;
  font-size: 15px;
}

.white-box .form-list .line.err-line .right input[type = "text"]{
  background: #FAE6E9;
}

.white-box .form-list .line .right input[type = "text"].w-200{
  width:200px;
}

.white-box .form-list .line .right input[type = "text"].w-300{
  width:300px;
}

.white-box .form-list .line .right .adress-text{
  font-size: 13px;
  letter-spacing: 0.04em;
  line-height: 20px;
  margin-top: 6px;
  color: #111;
}

.white-box .form-list .course-area{

}

.white-box .form-list .course-block{
  display: flex;
  padding:14px;
  background-color:#F6F6F6;
  cursor:pointer;
  margin-top: 12px;
}

.white-box .form-list .course-block.recommend-block{
  background-color:#F5F1E1;
  margin-top: 0;
}

.white-box .form-list .course-block .min-left{
  width:20px;
  padding-top: 2px;
}

.white-box .form-list .course-block.recommend-block .min-left{
  padding-top: 4px;
}

.white-box .form-list .course-block .min-left input{
  display: block;
  width:13px;
  height:13px;
}

.white-box .form-list .course-block .min-left label span{
  display: none;
}

.white-box .form-list .course-block .min-right{

}

.white-box .form-list .course-block .price-flex{
  display: flex;
  align-items: center;
  margin-bottom: 10px;
}

.white-box .form-list .course-block .price-flex .price{
  margin-right: 12px;
  font-weight: bold;
  letter-spacing: 0.04em;
  line-height: 1;
  color: #111;
}

.white-box .form-list .course-block .price-flex .recommend{
  width: 54px;
  height: 20px;
  border-radius: 3px;
  background: #a3915b;
  display: flex;
  align-items:center;
  justify-content:center;
  font-weight: bold;
  font-size: 11px;
  line-height: 1;
  color: #fff;
}

.white-box .form-list .course-block ul{

}

.white-box .form-list .course-block ul li{
  font-size: 13px;
  letter-spacing: 0.04em;
  line-height: 20px;
  color: #111;
}

.white-box .rule-box{
  padding:12px 20px;
  background-color:#A3915B;
  margin-bottom: 28px;
}

.white-box .rule-box .flex{
  display: flex;
  flex-wrap: wrap;
}

.white-box .rule-box .flex p.p1{
  font-size: 18px;
  letter-spacing: 0.2em;
  line-height: 1;
  color: #fff;
  margin-right: 32px;
}

.white-box .rule-box .flex p.p2{
  font-size: 15px;
  letter-spacing: 0.04em;
  line-height: 1;
  padding-top: 2.5px;
  color: #fff;
}

.white-box .privacy-box{
  height: 360px;
  border: 2px solid #f6f6f6;
  padding:24px 48px 24px 24px;
  overflow-y: scroll;
  margin-bottom: 16px;
}

.white-box .privacy-box .text{
  font-size: 15px;
  letter-spacing: 0.04em;
  line-height:1.5;
}

.white-box .privacy-box .text .p1{
  padding-left: 16px;
}

.white-box .agree-box{
  padding:18px;
  background-color: #F5F1E1;
  display: flex;
  align-items: center;
}

.white-box .agree-box.rock{
  background-color: #EBEBEB;
}

.white-box .agree-box .must{
  width: 42px;
  height: 21px;
  border-radius: 10.5px;
  background: #cc1228;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  letter-spacing: 0.08em;
  line-height: 1;
  color: #fff;
  margin-right: 14px;
}

.white-box .agree-box .center{
  margin-right: 22px;
}

.white-box .agree-box .center label{
  display: flex;
  align-items: center;
}

.white-box .agree-box.rock .center label{
  pointer-events: none;
}

.white-box .agree-box .center label input{
  border:none;
  background:none;
  margin-right: 16px;
  display: block;
  width: 28px;
  height: 28px;
  background: #fff;
  border: 1px solid #d6dadb;
}

.white-box .agree-box .center  span{
  letter-spacing: 0.04em;
  line-height: 1;
  color: #111;
}

.white-box .agree-box.rock .center  span{
  color:#9D9D9D;
}

.white-box .agree-box .must-text{
  font-size: 15px;
  letter-spacing: 0.04em;
  line-height: 1;
  color: #cc1228;
  display: none;
}

.white-box .agree-box.rock .must-text{
  display: block;
}

.contact-block .submit-area{
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.contact-block .submit-frame{
  width: 336px;
  margin:0 auto;
  position: relative;
}

.contact-block .submit-frame::after{
  content:"";
  width:14px;
  height:14px;
  background-image: url('../img/arrow.png');
  position: absolute;
  top:0;
  bottom:0;
  right:24px;
  margin:auto;
  pointer-events: none;
}

.contact-block .submit-frame input{
  appearance: none;
  -webkit-appearance: none;
  border:none;
  background:none;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 60px;
  border-radius: 30px;
  background: #cc1228;
  cursor: pointer;
  font-weight: bold;
  font-size: 14px;
  letter-spacing: 0.04em;
  line-height: 1;
  color: #fff;
}

.contact-block .submit-frame input.rock{
  pointer-events: none;
  cursor: not-allowed;
  background: #9D9D9D;
}


/*
------------------------------------------------------------
確認画面
------------------------------------------------------------
*/

.mw_wp_form_confirm .white-box .form-list .line .left{
  padding-top: 0;
}

.mw_wp_form_confirm .white-box .form-list .line .left .free{
  display:none;
}

.mw_wp_form_confirm .white-box .form-list .line .left .must{
  display:none;
}

.mw_wp_form_confirm .white-box .form-list .line .right .adress-text {
  display:none;
}

.mw_wp_form_confirm .white-box .form-list .line .right.pay-area {
  padding-top: 0;
}

.mw_wp_form_confirm .white-box .form-list .course-block{
  margin-top: 0;
}


.mw_wp_form_confirm .white-box .form-list .course-block .min-left{
  display:none;
}

.mw_wp_form_confirm .white-box .rule-box .flex p.p2 {
  display:none;
}

.mw_wp_form_confirm .white-box .privacy-box{
  display:none;
}

.mw_wp_form_confirm .white-box .agree-box .must{
  display:none;
}

.mw_wp_form_confirm .white-box .agree-box.rock .must-text{
  display:none;
}

.contact-block .mw_wp_form_confirm .submit-frame input.rock {
  pointer-events: auto;
  cursor:pointer;
  background: #cc1228;
}

.contact-block .mw_wp_form_confirm .return-frame{
  width: 336px;
  height: 60px;
  margin-top: 16px;
}

.contact-block .mw_wp_form_confirm .return-frame .relative{
  width:100%;
  height:100%;
  position: relative;
}

.contact-block .mw_wp_form_confirm .return-frame .relative::after{
  content:"";
  width:14px;
  height:14px;
  background-image: url('../img/red-arrow.png');
  position: absolute;
  top:0;
  bottom:0;
  left:24px;
  margin:auto;
  pointer-events: none;
}

.contact-block .mw_wp_form_confirm .return{
  appearance: none;
  -webkit-appearance: none;
  border:none;
  background:none;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height:100%;
  border-radius: 30px;
  border:1px solid #cc1228;
  cursor: pointer;
  font-weight: bold;
  font-size: 14px;
  letter-spacing: 0.04em;
  line-height: 1;
  color: #cc1228;
}

footer{

}

footer p.p1{
  margin-bottom: 18px;
  font-size: 11px;
  letter-spacing: 0.04em;
  line-height: 1;
  text-align: center;
  color: #222;
}

footer p.p2{
  padding:12px 0;
  background-color:#222222;
  font-family: 'Shippori Mincho', serif;
  letter-spacing: 0.04em;
  line-height: 1;
  text-align: center;
  color: #fff;


}
