@charset "utf-8";
/* pc */
br.pc{
  display: inline;
}
br.sp{
  display: none;
}
/* スマートフォン */
@media screen and (min-width: 320px) and (max-width: 767px)
{
  br.pc{
    display: none;
  }
  br.sp{
    display: inline;
  }
}


.free-trial-index{
  min-height: 1000px;
}
/*article web-form*/
.web-form{
  width: 760px;
  margin: 0 auto 300px;
}
.centered-page-title{
  margin-bottom: 20px;
}

/*section flow*/
.step-remain{
	margin-bottom:20px;
}
.step-remain .remaining{
	/*表示*/
	display: inline-block;
	/*配置*/
	/*margin→border→padding→width→height*/
	border-radius: 33px;
	padding: 15px;
	width: 66px;
	height: 66px;
	/*背景*/
	background-color: #00317D;
	/*文字*/
	color: #fff;
	font-size: 5.0rem;
	font-weight: bold;
	line-height: 0.8em;
}
.flow-step{
	/*表示*/
	/*配置*/
	/*margin→border→padding→width→height*/
	margin: 0 auto;
	width: 560px;
	/*背景*/
	/*文字*/
}

.flow-1,
.flow-2,
.flow-3{
  width: 160px;
  /*height:340px;*/
}
.flow-arrow1,
.flow-arrow2{
  padding-top: calc(80px - 26px / 2);
}
.fukidashi-active {
  position: relative;
  top:-27px;
  display: inline-block;
  text-align: center;
  margin: 1.5em 0 0;
  padding: 7px 10px;
  width: 100%;
  color: #333;
  font-size: 1.6rem;
  font-weight: bold;
  background: #FFF;
  border: solid 3px #00317D;
  border-radius: 5px;
  box-sizing: border-box;
}

.fukidashi-active:before{
  content: "";
  position: absolute;
  top: -24px;
  left: 50%;
  margin-left: -15px;
  border: 12px solid transparent;
  border-bottom: 12px solid #FFF;
  z-index: 2;
}

.fukidashi-active:after{
  content: "";
  position: absolute;
  top: -30px;
  left: 50%;
  margin-left: -17px;
  border: 14px solid transparent;
  border-bottom: 14px solid #00317D;
  z-index: 1;
}
.fukidashi-done {
  position: relative;
  top:-27px;
  display: inline-block;
  text-align: center;
  margin: 1.5em 0 0;
  padding: 7px 10px;
  width: 100%;
  color: #333;
  font-size: 1.6rem;
  font-weight: bold;
  background: #FFF;
  border: solid 3px #999;
  border-radius: 5px;
  box-sizing: border-box;
}

.fukidashi-done .fukidashi-name span{
  display: block;
}

.fukidashi-done:before{
  content: "";
  position: absolute;
  top: -24px;
  left: 50%;
  margin-left: -15px;
  border: 12px solid transparent;
  border-bottom: 12px solid #FFF;
  z-index: 2;
}

.fukidashi-done:after{
  content: "";
  position: absolute;
  top: -30px;
  left: 50%;
  margin-left: -17px;
  border: 14px solid transparent;
  border-bottom: 14px solid #999;
  z-index: 1;
}
.fukidashi-button a {
  /*表示*/
  display: block;
  /*配置*/
  position: relative;
  /*margin→border→padding→width→height*/
  margin-bottom: 2px;
  border-radius: 5px;
  padding: 5px 0px 3px 0px;
  width: 96%;
  /*背景*/
  background-color: #F6810D;
  box-shadow: 3px 3px 0 #C06407;
  /*文字*/
  font-size: 1.6rem;
  font-weight: bold;
  text-align: center;
  color: #fff;
  text-decoration: none;
  transition: 0.1s;
}
.fukidashi-button a span{
    background: url('../_img/free-trial/icon_arrow3.png') no-repeat left center #F6810D;
    padding-left: 15px;
}
.fukidashi-button a:hover{
  margin-left:2px;
  margin-top:2px;
  margin-bottom: 0;
  box-shadow: 1px 1px 0 #C06407;
}
@media screen and (min-width: 320px)  and (max-width: 560px)
{
  .flow-arrow1,
  .flow-arrow2{
    padding: 5px;
    padding-top: calc(13% - 5px);
  }
}
@media screen and (min-width: 320px)  and (max-width: 767px)
{
  .centered-pcci-logo{
    width: 96%;
    margin: 1rem auto 0;
  }
  .centered-page-title{
    width: 96%;
    margin: 0 auto;
    font-size: 2.5rem
  }
  .web-form{
    width: 96%;
    margin: 0 auto 300px;
  }
  .web-form>.centered-description-bold{
    font-size: 1.4rem;
  }
  .web-form>.centered-text{
    font-size: 1.4rem;
  }
  .web-form>.centered-text-bold.tel{
    font-size: 3rem;
  }
  .flow-step{
    width: 100%;
  }
  .fukidashi-active,
  .fukidashi-done {
    top:-19px;
    font-size: 1.3rem;
  }
  .fukidashi-button a {
    font-size: 1.3rem;
  }

}
/*section step1-choose*/
.step1-choose{
  position: relative;
}
.step1-choose>h1{
  font-size: 2.5rem;
  margin-bottom: 10px;
}
.to-start a{
    display: block;
    position: absolute;
    top: 5px;
    right: 10px;
    border-radius: 5px;
    border: none;
    width: 160px;
    background-color: #F6810D;
    box-shadow: 3px 3px 0 #C06407;
    font-size: 1.6rem;
    font-weight: bold;
    text-align: center;
    color: #fff;
    text-decoration: none;
    line-height: 1.8em;
    transition: 0.1s;
}
@media screen and (min-width: 320px)  and (max-width: 767px)
{
  .step1-choose>h1{
    font-size: 2.0rem;
    margin-bottom: 1.5em;
  }
.to-start a{
    top: 1.5em;
    right: 10px;
  }
}

/*section choose-area*/
.choose-area{
  overflow: hidden;
  transition-property:height,opacity;
  transition-duration:0.2s;
  transition-delay:0.1s;
}
.choose-area.height0{
  height: 0;
}
.choose-area.vanish{
  opacity: 0;
}
.choose-area>h1{
	/*表示*/
	display: inline-block;
	/*配置*/
	position: relative;
	z-index: 10;
	left: 20px;
	/*margin→border→padding→width→height*/
	margin: 0 auto -1.5rem;
	border-radius: 10px;
	padding:3px 10px 0;
	/*背景*/
	background-color: #00317D;
	/*文字*/
	color: #fff;
	font-size: 2.0rem;
	font-weight: bold;
}
.area-map{
	/*表示*/
	/*配置*/
  position: relative;
  top:-1.5rem;
	z-index: 1;
	/*margin→border→padding→width→height*/
	margin: 0 auto;
	border:3px solid #00317D;
	border-radius: 10px;
  width: 100%;
  height: 360px;
	/*背景*/
  background: no-repeat center url('../_img/school/img_school_map.png');
	/*文字*/
}

.area-map ul li a{
	/*表示*/
  display: block;
	/*配置*/
  position: absolute;
	/*margin→border→padding→width→height*/
  border:1px solid  #00317D;
  border-radius: 5px;
  padding-top: 3px;
  padding-left: 10px;
	/*背景*/
  background:no-repeat 10px center url('../_img/common/icon_arrow01.png') #fff;
  background-size: 4px 5px;
	/*文字*/
  font-size: 1.2rem;
  text-align: center;
  text-decoration: none;
}
.area-map ul li a:hover{
  margin-top: 2px;
}
.area-map ul li a.active{
  border:1px solid #0079A2;
  background:no-repeat 10px center url('../_img/common/icon_arrow02.png') #00317D;
  background-size: 4px 5px;
  font-weight: bold;
  color: #fff;
}
.area-map .area-map-tohoku a{
	left: 595px;
	top: 143px;
	width: 60px;
}
.area-map .area-map-kanto a{
  left: 574px;
  top: 230px;
  width: 60px;
}
.area-map .area-map-chubu a{
  left: 441px;
  top: 187px;
  width: 90px;
}
.area-map .area-map-kinki a{
  left: 355px;
  top: 220px;
  width: 60px;
}
.area-map .area-map-chugoku a{
  left:230px;
  top: 245px;
  width: 90px;
}
.area-map .area-map-kyushu a{
  left: 75px;
  top: 240px;
  width: 90px;
}

/*section choose-pref*/
/*地図エリア基本*/
.choose-pref{
  overflow: hidden;
  transition-property:height,opacity;
  transition-duration:0.2s;
  transition-delay:0.1s;
  margin-bottom: 30px;
}
.choose-pref.height0{
  height: 0;
}
.choose-pref.vanish{
  opacity: 0;
}
.choose-pref>h1{
  padding-top: 10px;
  padding-bottom: 10px;
  font-size: 1.9rem;
  font-weight: bold;
}

.pref-map{
	/*表示*/
	/*配置*/
  position: relative;
	/*margin→border→padding→width→height*/
  margin-top: 20px;
  width: 329px;
  height: 300px;
	/*背景*/
	/*文字*/
}
.choose-pref.area_0 .pref-map{
    left: 40px;
}
.choose-pref.area_1 .pref-map{
  left: 40px;
}
.choose-pref.area_5 .pref-map{
  width: 349px;
}
/*.choose-pref.area_5 .pref-list{
  width: 360px;
}*/
.pref-map li{
  position: absolute;
}
.pref-map .map_type_0{
  width: 100px;
  height: 50px;
}
.pref-map .map_type_1{
  width: 185px;
  height: 50px;
}
.pref-map .map_type_2{
  width: 122px;
  height: 105px;
}
.pref-map .pref_active__name{
	/*表示*/
  display: block;
	/*配置*/
  position: absolute;
  left:10px;
  bottom: 13px;
  z-index: 1;
	/*margin→border→padding→width→height*/
  border:1px solid  #00317D;
  border-radius: 5px;
  padding-left: 10px;
  padding-top: 3px;
  width: 72px;
	/*背景*/
  background:no-repeat 10px center url('../_img/common/icon_arrow01.png') #fff;
  background-size: 4px 5px;
	/*文字*/
  font-size: 1.2rem;
  text-align: center;
  text-decoration: none;
}

.pref-map a:hover .pref_active__name{bottom:11px;}
.pref-map a.active .pref_active__name{
  border:1px solid #0079A2;
  background:no-repeat 10px center url('../_img/common/icon_arrow02.png') #00317D;
  background-size: 4px 5px;
  font-weight: bold;
  color: #fff;
}
.pref-map .pref_active .pref_active__img{z-index: 2}

/*東北*/
.pref-map .pref_id_1{display: none;}/*北海道*/
.pref-map .pref_id_2{top:0;left:66px;}/*青森*/
.pref-map .pref_id_3{top:55px;left:44px;}/*秋田*/
.pref-map .pref_id_5{top:55px;left:129px;}/*宮城*/
.pref-map .pref_id_6{top:110px;left:22px;}/*秋田*/
.pref-map .pref_id_4{top:110px;left:107px;}/*宮城*/
.pref-map .pref_id_7{top:165px;left:0px;}/*福島*/

/*関東*/
.pref-map .pref_id_10{top:0;left:66px;}
.pref-map .pref_id_11{top:55px;left:44px;}
.pref-map .pref_id_13{top:110px;left:22px;}
.pref-map .pref_id_14{top:165px;left:0px;}
.pref-map .pref_id_12{top:110px;left:85px;}
.pref-map .pref_id_9{top:0;left:151px;}
.pref-map .pref_id_8{top:55px;left:129px;}

/*中部・北陸*/
.pref-map .pref_id_15{top:0px;left:192px;}/*新潟*/
.pref-map .pref_id_21{top:55px;left:63px;}/*岐阜*/
.pref-map .pref_id_22{top:220px;left:104px;}/*静岡*/
.pref-map .pref_id_16{top:0px;left:107px;}/*富山*/
.pref-map .pref_id_17{top:0px;left:22px;}/*石川*/
.pref-map .pref_id_18{top:55px;left:0px;}/*福井*/
.pref-map .pref_id_19{top:165px;left:126px;}/*山梨*/
.pref-map .pref_id_20{top:55px;left:148px;}/*長野*/
.pref-map .pref_id_23{top:165px;left:41px;}/*愛知*/

/*近畿*/
.pref-map .pref_id_27{top:55px;left:22px;}
.pref-map .pref_id_28{top:0;left:44px;}
.pref-map .pref_id_25{top:0;left: 214px;}
.pref-map .pref_id_26{top:0;left:129px;}
.pref-map .pref_id_24{top:55px;left: 192px;}
.pref-map .pref_id_29{top:55px;left: 107px;}
.pref-map .pref_id_30{left: 0;top: 110px;}

/*中国・四国*/
.pref-map .pref_id_35{top:0;left:0px;}
.pref-map .pref_id_32{top:0;left:107px;}
.pref-map .pref_id_31{top:0;left:192px;}
.pref-map .pref_id_34{top:55px;left:85px;}
.pref-map .pref_id_33{top:55px;left:170px;}
.pref-map .pref_id_37{top:115px;left:145px;}
.pref-map .pref_id_36{top:170px;left:123px;}
.pref-map .pref_id_38{top:115px;left:60px;}
.pref-map .pref_id_39{top:170px;left:38px;}

/*中国・四国*/
.pref-map .pref_id_40{top:0px;left:240px;}/*福岡*/
.pref-map .pref_id_42{top:0px;left:70px;}/*長崎*/
.pref-map .pref_id_45{top:110px;left:196px;}/*宮崎*/
.pref-map .pref_id_46{top:110px;left:110px;}/*鹿児島*/
.pref-map .pref_id_47{top:175px;left:0px;}/*沖縄*/
.pref-map .pref_id_41{top:0px;left:155px;}/*佐賀*/
.pref-map .pref_id_43{top:55px;left:133px;}/*熊本*/
.pref-map .pref_id_44{top:55px;left:218px;}/*大分*/

.pref-list{
  border-left: 1px dashed #666;
  padding-top: 20px;
  padding-left: 20px;
  width: 380px;
}
.pref-list li a{
  display: block;
  margin-bottom: 10px;
  border:1px solid #0191C2;
  padding :5px 10px;
  background: url("../_img/school/icon_arrow4.png") no-repeat right 10px center;
  font-weight: bold;
  text-decoration: none;
}
.pref-list li a:hover{
  text-decoration: underline;
}
.pref-list li a.active{
  border:1px solid #0079A2;
  background: url("../_img/school/icon_arrow3.png") no-repeat right 10px center #00317D;
  color: #fff;
}


.right__prefName{
  font-size: 1.8rem;
}
.right__classCount{
  font-weight: normal;
  text-decoration: none;
}

/*都道府県リスト*/
#container #sub_area .left_school h2{
  clear: both;
}
#container #sub_area .left_school .school{

}
#container #sub_area .left_school .inner_lower{
  clear: both;
}
#container #sub_area .left_school .inner_lower .total_school{
  display: none;
}


/*section choose-school*/
/*|||||||||||||||| 左カラム  ||||||||||||||||||||||*/

/* スマートフォン 
@media screen and (min-width: 320px) and (max-width: 767px)
{
  #container #main_area {
      width: 100%;
      margin: 0;
      height: auto;
  }
  #container #main_area #sub_area{
    width: 100%;
    margin:0;
    padding: 0;
  }
  #container #sub_area .left_school h2 {
      width: calc(98% - 40px);
      padding: 0 0 0 40px;
  }
  #container #sub_area .left_school h2:after {
    border-width: 13px;
  }
}*/
.choose-school{
  overflow: hidden;
  transition-property:height,opacity;
  transition-duration:0.2s;
  transition-delay:0.1s;
}
.choose-school.height0{
  height: 0;
}
.choose-school.vanish{
  opacity: 0;
}
.choose-school>h1 {

    border: 1px solid #ccc;
    background:linear-gradient(#fff,#ddd);
    font-weight: bold;
    font-size: 1.8rem;
    padding: 4px 10px 2px 10px;

}
/* スマートフォン */
@media screen and (min-width: 320px) and (max-width: 767px)
{
  .area-map{
    width:96%;
    margin: 0 2%;
    padding:0;
    height: 30vh;
    margin: 0 auto;
    background: no-repeat left top url('../_img/school/img_school_map.png');
    background-size: 100%;
    background-position: center;
  }
  .area-map ul li a{
    background-color: rgba(255,255,255,0.8);
  }
  .area-map ul li a:hover{
    margin-top: 2px;
  }
  .area-map .area-map-tohoku a{
    left: 80%;
    top: 40px;
  }
  .area-map .area-map-kanto a{
    left: 80%;
    top: 100px;
  }
  .area-map .area-map-chubu a{
    left: 52%;
    top: 70px;
  }
  .area-map .area-map-kinki a{
    left: 43%;
    top: 100px;
  }
  .area-map .area-map-chugoku a{
    left:20%;
    top: 70px;
  }
  .area-map .area-map-kyushu a{
    left: 0;
    top: 100px;
  }
  @media screen and (orientation: landscape) {
     /* 横向きの場合のスタイル */
    #schoolList .left_school .inner_upper{
      height: 20rem;
    }
    .area-map{
      height: 80vh;
    }
    .area-map .area-map-tohoku a{
      top: 80px;
    }
    .area-map .area-map-kanto a{
      top: 150px;
    }
    .area-map .area-map-chubu a{
      top: 120px;
    }
    .area-map .area-map-kinki a{
      top: 150px;
    }
    .area-map .area-map-chugoku a{
      top: 120px;
    }
    .area-map .area-map-kyushu a{
      top: 150px;
    }
  }

  /*section choose-pref*/
  /*地図エリア基本*/
/*  .choose-pref{
    overflow: hidden;
    transition-property:height,opacity;
    transition-duration:0.2s;
    transition-delay:0.1s;
    margin-bottom: 30px;
  }*/
  .choose-pref>.flexbox{
    flex-direction: column;
  }
  .choose-pref.height0{
    height: 0;
  }
  .choose-pref.vanish{
    opacity: 0;
  }
  .choose-pref>h1{
    font-size: 1.5rem;
  }



  .pref-list{
    border:none;
    padding-top: 0px;
    padding-left: 0px;
    width: 100%;
  }
  .pref-list li a{
    display: block;
    margin-bottom: 10px;
    border:1px solid #0191C2;
    padding :5px 10px;
    background: url("../_img/school/icon_arrow4.png") no-repeat right 10px center;
    font-weight: bold;
    text-decoration: none;
    font-size: 1.3rem;
  }
  .pref-list li a:hover{
    text-decoration: underline;
  }
  .pref-list li a.active{
    border:1px solid #0079A2;
    background: url("../_img/school/icon_arrow3.png") no-repeat right 10px center #00317D;
    color: #fff;
  }


  .right__prefName{
    font-size: 1.3rem;
  }
  .right__classCount{
    font-weight: normal;
    text-decoration: none;
  }

}

/* 教室一覧 */
.school-name-list{
  position: relative;
  margin-top: 20px;
  border:2px solid #3FACD1;
  padding: 10px 0;
  background-color: #F2ECDF;
}
.school-name-list::before {
    content: "";
    position: absolute;
    left: 50%;
    top: 10px;
    z-index: 1;
    border-left: 1px dotted #000;
    width: 1px;
    height: calc(100% - 20px);
}
.school-name-list li{
	/*表示*/
	/*配置*/
	/*margin→border→padding→width→height*/
	margin-left: 10px;
  padding-top: 3px;
  padding-left: 15px;
  width: 368px;
	/*背景*/
  background: rgba(0, 0, 0, 0) url("../_img/school/icon_circle2.png") no-repeat scroll left center;
	/*文字*/
  line-height: 1.8em;
  font-size: 1.3rem;
}
.school-name-list li a{
  text-decoration:underline;
}
.school-name-list li a:hover{
  text-decoration:none;
}
.school-name-list li span{
	/*表示*/
  display: inline-block;
	/*配置*/
	/*margin→border→padding→width→height*/
  margin-left:5px;
  border:1px solid #3FACD1;
  padding: 2px 5px 0;
	/*背景*/
  background-color:#fff;
	/*文字*/
  text-decoration: none;
  color: #3FACD1;
  font-weight: bold;
  font-size: 90%;
}
/* スマートフォン  */
@media screen and (min-width: 320px) and (max-width: 767px)
{
  .school-name-list::before {
      display: none;
  }
  .school-name-list{
    width: 100%;
    float: none;
  }
  .school-name-list span{
    display: inline-block;
  }
}

/*教室情報*/
.school-list{
	margin-top: 20px;
}
.school-solo{
  padding: 0 10px 0px;
  border-bottom: 1px solid #ccc;
  margin-bottom: 20px;
}
.school-photo{
  width: 150px;
  margin-right: 10px;
}
.school-info{
  width: 390px;
}
.school-info>h2>a{
	display: block;
  font-size: 2.0rem;
  font-weight: bold;
  text-decoration: underline;
}
.school-info>h2>a:hover{
  text-decoration: none;
}
.school-info>h2>a>span{
  display:inline-block;
}
.school-info-address{
  margin: 15px 0;
  font-size: 1.4rem;
  color: #666;
}
.info-address-zip{
  display: block;
  line-height: 1.2em;
}
.info-address-address1,
.info-address-address2{
  display: inline-block;
}
.school-moyori{
  margin-bottom: 10px;
}
.moyori-title{
	/*表示*/
	/*配置*/
  position: relative;
	/*margin→border→padding→width→height*/
  margin-right: 20px;
  padding: 6px 10px 4px;
	/*背景*/
  background-color: #C8B6A7;
	/*文字*/
  font-size: 1.5rem;
  font-weight: bold;
  color: #fff;
  line-height: 1em;
}
.moyori-title:after {
	/*表示*/
  content: "";
	/*配置*/
  position: absolute;
  right: -0.8em;
  top: 50%;
	/*margin→border→padding→width→height*/
  margin-top: -0.9em;
  border-bottom: 0.9em solid transparent;
  border-left: 0.9em solid #C8B6A7;
  border-top: 0.9em solid transparent;
	/*背景*/
	/*文字*/
}
.moyori-text>li{
  margin-bottom: 5px;
  border:1px solid #666;
  padding: 0 5px;
  width: 274px;
  font-size: 1.3rem;
  color: #666;
}
.school-choice a{
  display: block;
  position: relative;
	width: 178px;
  border-radius: 10px;
  font-size: 2.0rem;
  font-weight: bold;
  text-align: center;
  color: #fff;
  padding: 31px 0px 30px 0px;
  margin-top: 10px;
  text-decoration: none;
  box-shadow: 3px 3px 0 #C06407;
  background-color: #F6810D;
  transition: 0.1s;
}
.school-choice a:hover{
	margin-left:2px;
	margin-top:12px;
  box-shadow: 1px 1px 0 #C06407;
}
.school-choice.active a{
  left:1px;
  top:1px;
  box-shadow: 2px 2px 0 #C06407 inset;
}
.school-choice a span{
  background: url('../_img/free-trial/icon_arrow3.png') no-repeat left center #F6810D;
  padding-left: 15px;
}
@media screen and (min-width: 320px) and (max-width: 767px)
{
  .school-solo{
    flex-direction: column;
    padding: 20px 0;
  }
  .school-photo{
    width: 100%;
    margin-right: 0;
  }
  .school-info{
    width: 100%;
  }
  .moyori-title{
    width: 80px;
  }
  .moyori-text{
    width: calc(100% - 100px);
  }
  .moyori-text>li{
    width: 100%;
  }
  .school-choice a{
    padding:10px;
    width: 100%;
  }

}

/*step1-chosen*/
.step1-chosen{
  padding-top: 30px;
  overflow: hidden;
  transition-property:height,opacity;
  transition-duration:0.2s;
  transition-delay:0.1s;
}
.step1-chosen.height0{
  height: 0;
}
.step1-chosen.vanish{
  opacity: 0;
}
.step1-chosen>h1{
	font-size: 2.5rem;
	margin-bottom: 30px;
}

/*section choose-trial-dat*/

.choose-trial-date{
  overflow: hidden;
  transition-property:height,opacity;
  transition-duration:0.2s;
  transition-delay:0.1s;
  margin-bottom: 30px;
}
.choose-trial-date.height0{
  height: 0;
}
.choose-trial-date.vanish{
  opacity: 0;
}

.choose-trial-date>h1{
	font-size: 2.5rem;
	margin-bottom: 30px;
  margin-top: 30px;
}
.trial-dates{
  margin-bottom: 30px;
}
.date{
	/*表示*/
	display: block;
	/*配置*/
  position: relative;
  z-index: 1;
  /*margin→border→padding→width→height*/
  margin-right: 10px;
  margin-bottom: 10px;
  border:1px solid #333;
  border-radius: 10px;
  padding: 10px 0;
  width: 116px;
  box-shadow: 3px 3px 0 #666;
  /*背景*/
  background-color: #fff;
  /*文字*/
  text-align: center;
  line-height: 1.5em;
  font-family: "ヒラギノ角ゴ ProN W3","Hiragino Kaku Gothic ProN","メイリオ",Meiryo,sans-serif;
  transition: 0.1s;
  cursor: pointer;
}
.date.checked:after{
  content: "";
}
.date:hover{
  transform: translate(2px,2px);
	box-shadow: 1px 1px 0 #666;
}
.date.unreservable{
  transform: translate(2px,2px);
  box-shadow: 1px 1px 0 #666;
	background-color: #ccc;
  cursor: auto;
}
.date.checked{
  transform: translate(2px,2px);
	margin-bottom: 80px;
	border:solid 1px #22624A;
	box-shadow: 1px 1px 0 #22634A;
	background-color: #32936F;
	color: #fff;
  transition: 0.2s 0.1s;
}
.tuesday:first-child{
  margin-left: 126px;
}
.wednesday:first-child{
  margin-left: 252px;
}
.thursday:first-child{
  margin-left: 378px;
}
.friday:first-child{
  margin-left: 504px;
}
.saturday:first-child{
  margin-left: 630px;
}
.date>.month-date{
	display:inline-block;
	font-size: 1.6rem;
	font-weight: bold;
}
.date>.weekday{
	display:inline-block;
	font-size: 1.6rem;
	font-weight: bold;
}
.date>.reservable{
	display:block;
	font-size: 1.6rem;
}
.two-weeks-later{
	margin-top: 20px;
  overflow: hidden;
  transition-property:height,opacity;
  transition-duration:0.2s;
  transition-delay:0.1s;
}
.two-weeks-later.height0{
  height: 0;
}
.two-weeks-later.vanish{
  opacity: 0;
}
.centered-text-bold.tel{
	line-height: 1em;
	font-size: 4.0rem;
	color: #00317D;
}
/*section choose-trial-time*/
.trial-times{
  /*表示*/
  display: flex;
  /*配置*/
  position: absolute;
  top:80px;
  z-index: 100;
  /*margin→border→padding→width→height*/
  border: 1px solid #22624A;
  border-radius: 10px;
  width: calc(600% + 60px);
  /*背景*/
  background-color: #a1e0c8;
  /*文字*/
  transition: 0.2s opacity;
  cursor: default;
}

.trial-times:before{
  /*表示*/
  content: "";
  /*配置*/
  box-sizing: border-box;
  position: absolute;
  top: -12px;
  z-index: 1;
  /*margin→border→padding→width→height*/
  border-left: 1px solid #22624A;
  border-top: 1px solid #22624A;
  padding:10px;
  /*背景*/
  background-color: #a1e0c8;
  /*文字*/
  transform: rotate(45deg);
}
.monday.checked .trial-times:before{
  left:calc(7.5% - 12px);
}
.tuesday.checked .trial-times{
  left: -126px;
}
.tuesday.checked .trial-times:before{
  left:calc(24.5% - 12px);
}
.wednesday.checked .trial-times{
  left: -252px;
}
.wednesday.checked .trial-times:before{
  left:calc(41.5% - 12px);
}
.thursday.checked .trial-times{
  left: -378px;
}
.thursday.checked .trial-times:before{
  left:calc(58.5% - 12px);
}
.friday.checked .trial-times{
  left: -507px;
}
.friday.checked .trial-times:before{
  left: calc(75.5% - 12px);
}
.saturday.checked .trial-times{
  left: -630px;
}
.saturday.checked .trial-times:before{
  left:calc(92.5% - 12px);
}
.time{
	/*表示*/
	display: block;
	/*配置*/
  position: relative;
  z-index: 3;
	/*margin→border→padding→width→height*/
  margin: 5px;
	border:1px solid #333;
	border-radius: 10px;
	padding: 5px 0;
	width: 175px;
	box-shadow: 3px 3px 0 #666;
	/*背景*/
	background-color: #fff;
	/*文字*/
  font-family: "ヒラギノ角ゴ ProN W3","Hiragino Kaku Gothic ProN","メイリオ",Meiryo,sans-serif;
	transition: 0.1s;
  line-height: 1.2em;
  color: #333;
}
.time:hover{
  transform: translate(2px,2px);
	box-shadow: 1px 1px 0 #666;
  text-decoration: none;
}
.time.is-few-in-stock{
  background-color: #ffbaba;
}
.time.unreservable{
  transform: translate(2px,2px);
	box-shadow: 1px 1px 0 #666;
	background-color: #ccc;
  cursor: default;
}
.time.checked{
	border:solid 1px #22624A;
  transform: translate(2px,2px);
	box-shadow: 1px 1px 0 #22634A;
	background-color: #32936F;
	color: #fff;
}
.time.only_daytime{
  overflow: hidden;
  height: 0;
  padding: 0;
  border:0;
}
.time>.hour-minute{
	font-size: 1.6rem;
	font-weight: bold;
	line-height: 1.2em;
}
.time>.hour-minute{
  display: block;
}


@media screen and (min-width: 320px) and (max-width: 767px)
{
  .choose-trial-date>h1{
    font-size: 2rem;
  }
  .trial-dates{
    flex-direction: column;
  }
  .date{
    width: 99.2%;
    position: relative;
    text-align: left;
    padding-left: 4%;
  }
  .date:first-child{
    margin-left: 0;
  }
  .date>.reservable{
    position: absolute;
    right: 1em;
    top: 0.5em;
  }
  .date.checked{
    margin-bottom: 20rem;
  }
  .trial-times{
    flex-direction: column;
    padding: 0 2%;
    width: 100%;
    top: 53px;
  }
  .date.checked .trial-times{
    left:0 !important;
  }
  .date.checked .trial-times:before{
    left: calc(50% - 12px);
  }
  .time{
    width: 100%;
    margin: 5px 0;
  }
  .time>.hour-minute {
      display: inline-block;
      padding-left: 4%;
  }
  .time>.reservable{
    font-size: 1.2rem;
  }

}

/*section step3*/
.step3{
	margin-top: 40px;
  overflow: hidden;
  transition-property:height,opacity;
  transition-duration:0.2s;
  transition-delay:0.1s;
  margin-bottom: 30px;
}
.step3.height0{
  height: 0;
}
.step3.vanish{
  opacity: 0;
}


.step3>h1{
	font-size: 2.5rem;
	margin-bottom: 30px;
}
.input-area{
	width: 560px;
	margin: 0 auto;
	padding-bottom: 10px;
}
.input-area label {
	display: block;
	margin-bottom: 8px;
	font-weight: 600;
	color: #2c3e50;
	font-size: 16px;
	position: relative; /* 追加 */
}
/* 入力フィールドのマージンを調整 */
.input-area input[type="text"],
.input-area input[type="tel"],
.input-area input[type="email"],
.input-area textarea {
	width: 100%;
	padding: 14px 18px;
	border: 2px solid #e1e8ed;
	border-radius: 8px;
	font-size: 16px;
	transition: all 0.3s ease;
	background-color: #ffffff;
	margin-bottom: 8px; /* 20px から 8px に変更（エラーメッセージ分を考慮） */
	font-family: inherit;
}

/* エラーがある場合の入力フィールドのスタイル */
.input-area input.error-field,
.input-area textarea.error-field {
	border-color: #e74c3c;
	background-color: #fdf2f2;
}
.step3 label{
  position: relative;
	display: block;
	font-size: 2.5rem;
}
.step3 .label-mail-check{
	font-size: 2.1rem;
}
.step3 .label-wish{
	font-size: 1.9rem;
}
.must{
	display: inline-block;
	padding: 5px 5px 3px;
	border-radius: 5px;
	background-color: #DA3915;
	color: #fff;
	font-size: 1.4rem;
	font-weight: bold;
	line-height: 1em;
	vertical-align: middle;
}
.supplement{
	font-size: 1.6rem;
}
.step3 input{
	display:block;
	margin-bottom: 1em;
	border:1px solid #333;
	border-radius: 10px;
	padding: 0.5em 10px;
	width: 100%;
	font-size: 2.0rem;
	line-height: 1em;
}

.error, .error2 {
	display: block;
	position: relative; /* absolute から relative に変更 */
	margin: 8px 0 16px 0; /* マージンを調整 */
	border-radius: 5px;
	padding: 8px 12px;
	width: 100%;
	box-sizing: border-box;
	background: #e74c3c;
	color: #fff;
	font-size: 1.4rem;
	font-weight: bold;
	transition: 0.3s ease;
	opacity: 0;
}

	.error.on, .error2.on {
		opacity: 1;
		transform: none; /* transform を削除してレイアウトの破綻を防ぐ */
	}

		.error.on.off, .error2.on.off {
			opacity: 0;
		}

	/* 吹き出しの矢印は削除（レイアウトを複雑にするため） */
	.error:after, .error2:after {
		display: none;
	}


.step3 textarea{
	display:block;
	margin-bottom: 1em;
	border:1px solid #333;
	border-radius: 10px;
	padding: 0.5em 10px;
	width: 100%;
	font-size: 2.0rem;
	line-height: 1em;
  overflow: auto;
}
.error, .error2 {
	display: block;
	position: relative; /* absolute から relative に変更 */
	margin: 8px 0 16px 0; /* マージンを調整 */
	border-radius: 5px;
	padding: 8px 12px;
	width: 100%;
	box-sizing: border-box;
	background: #e74c3c;
	color: #fff;
	font-size: 1.4rem;
	font-weight: bold;
	transition: 0.3s ease;
	opacity: 0;
}

	.error.on, .error2.on {
		opacity: 1;
		transform: none; /* transform を削除してレイアウトの破綻を防ぐ */
	}

		.error.on.off, .error2.on.off {
			opacity: 0;
		}

	/* 吹き出しの矢印は削除（レイアウトを複雑にするため） */
	.error:after, .error2:after {
		display: none;
	}
.div-to-confirm{
}
.to-confirm{
	/*表示*/
	display: block;
	/*配置*/
	/*margin→border→padding→width→height*/
	border:solid 1px #22624A;
	border-radius: 10px;
	padding: 5px 20px;
	box-shadow: 3px 3px 0 #22634A;
	/*背景*/
	background-color: #32936F;
	/*文字*/
  font-family: "ヒラギノ角ゴ ProN W3","Hiragino Kaku Gothic ProN","メイリオ",Meiryo,sans-serif;
	font-size: 2.5rem;
	text-align: center;
	transition: 0.1s;
	color: #fff;

  transition-property:opacity;
  transition-duration:0.2s;
  transition-delay:0.1s;
  margin-bottom: 30px;
}
.to-confirm.vanish{
  opacity: 0;
}
.to-confirm:hover{
  margin-top: 2px;
  margin-left: 4px;
  border:solid 1px #22624A;
  box-shadow: 1px 1px 0 #22634A;
  background-color: #32936F;
  color: #fff;
  text-decoration: none;
}
.to-confirm[disabled]{
  margin-top: 2px;
  margin-left: 4px;
  border:solid 1px #666;
  box-shadow: 1px 1px 0 #666;
  background-color: #ccc;
  cursor: default;
}

@media screen and (min-width: 320px) and (max-width: 767px)
{
  .step3>h1{
    font-size: 2rem;
  }
  .supplement{
    display: block;
  }
  .input-area{
    width: 100%;
  }
  .error ,.error2 {
    font-size: 1.3rem;
    padding:2%;
  }
}
/*||||||||||||||||||||||||||||||||||||||||CONFIRM||||||||||||||||||||||||||||||||||||||||*/
/*section step2-chosen*/
.chosen-trial-date{
	margin-top: 40px;
}
.chosen-trial-date>h1{
	font-size: 2.5rem;
	width: 40%;
}
.trial-date{
	margin-left: 3%;
	width: 57%;
	height: 3.0rem;
	font-size: 2.5rem;
	border-bottom: 1px solid #333;
}
.trial-date-chosen{
	height: 1em;
	font-size: 2.0rem;
  padding-left: 10px;
}
.modify{
	/*表示*/
  display: block;
	/*配置*/
	position: relative;
	bottom: 5px;
	right: 10px;
	/*margin→border→padding→width→height*/
  border-radius: 5px;
  border:none;
  width: 80px;
	/*背景*/
  background-color: #F6810D;
  box-shadow: 3px 3px 0 #C06407;
	/*文字*/
  font-size: 1.6rem;
  font-weight: bold;
  text-align: center;
  color: #fff;
  text-decoration: none;
  line-height: 1.8em;
  transition: 0.1s;
}
.modify:hover{
	bottom: 3px;
	right: 8px;
  box-shadow: 1px 1px 0 #C06407;
}
.input{
	margin-top: 10px;
	margin-bottom: 60px;
}
.input-chosen{
	font-size: 2.5rem;
	border-bottom: 1px solid #333;
}
.textarea-chosen>.input-text{
  width:80%;
}
.input-modify>.modify{
  width: 18%;
  line-height: 1.4em;
}
.input-chosen>.modify{
  /*width: 18%;*/
  /*display: none;*/
}
.input-text{
  font-size: 2.0rem;
  padding-left: 10px;
  width:calc(100% - 100px);
}
.textarea-chosen{
  font-size: 2.5rem;
  border-bottom: 1px solid #333;
}
.textarea-modify>.modify{
  /*width: 18%;*/
  line-height: 1.5em;
}
.textarea-chosen>.modify{
  width: 80px;
  /*display: none;*/
}
.textarea-text{
  padding-right: 20px;
  padding-left: 10px;
  line-height: 1.5em;
  word-break: break-all;
  word-wrap: break-word;
  overflow-wrap: break-word;
  display: block;
  width: 80%;
}
.input-text-mail{
  font-size: 1.6rem;
  word-break: break-all;
  word-wrap: break-word;
  overflow-wrap: break-word;
  display: block;
}
.input-modify{
  visibility: hidden;
  height: 0;
  margin: 0;
  padding: 0;
  line-height: 0;
  overflow: hidden;
}
.input-modify input{
  /*width: 85%;*/
  margin-bottom: 0.5em;
  font-size: 1.6rem;
}
.fix-button>.modify{
  width: auto;
  display: inline-block;
  margin-left: 20px;
}
.fix-button{
  text-align: right;
}
.fix-button>.fix{
  background-color: #417BA6;
  box-shadow: 3px 3px 0 #305D7D;
}
.fix-button>.fix:hover{
  box-shadow: 1px 1px 0 #305D7D;
}
.fix-button>.cancel{
  background-color: #91959C;
  box-shadow: 3px 3px 0 #62666D;
}
.fix-button>.cancel:hover{
  box-shadow: 1px 1px 0 #62666D;
}

.textarea-modify{
  visibility: hidden;
  height: 0;
  margin: 0;
  padding: 0;
  line-height: 0;
  overflow: hidden;
}
.textarea-modify textarea{
  margin-bottom: 0.5em;
  font-size: 1.6rem;
}

.to-confirm span{
	display: block;
	font-size: 1.6rem;
}

/* スマートフォン対応 */
@media screen and (min-width: 320px) and (max-width: 767px) {
	.error, .error2 {
		font-size: 1.2rem;
		padding: 6px 10px;
		margin: 6px 0 12px 0;
	}
}
@media screen and (min-width: 320px) and (max-width: 767px)
{
  .chosen-trial-date{
    flex-direction: column;
  }
  .chosen-trial-date>h1{
    width: 100%;
  }
  .trial-date{
    width: 100%;
    margin-left: 0;
  }
}
/*||||||||||||||||||||||||||||||||||||||||COMPLETE||||||||||||||||||||||||||||||||||||||||*/
.free-trial-complete strong{
  background-color: #ff0;
  color: #f00;
  font-weight: bold;
}
.notice{
	position: relative;
	margin-top: 50px;
	margin-bottom: 50px;
	border:3px solid #F6810D;
	border-radius: 5px;
	padding-left: 40px;
	padding-right: 40px;
	padding-bottom: 20px;
}
.notice .strong{
  font-size: 3rem;
  color: #f00;
}
.notice > h1 {
	/*表示*/
  display: block;
	/*配置*/
	position:absolute;
	left: 50%;
	top: -1em;
  z-index: 10;
	/*margin→border→padding→width→height*/
	margin-left: -60px;
  border-radius: 10px;
  padding: 3px 10px 0;
  width: 120px;
	/*背景*/
  background-color: #F6810D;
	/*文字*/
  color: #fff;
  text-align: center;
  font-size: 2.0rem;
  font-weight: bold;
}
.notice-steps{
	padding-bottom: 20px;
}
.notice-text{
	padding-top: 30px;
	padding-bottom: 30px;
	font-size: 1.9rem;
}
.notice-step{
	width: 200px;
}
.notice-step img{
	width: 200px;
	padding: 0 20px;
}
.notice-step span{
	display: block;
	font-size: 1.4rem;
}
.notice-arrow{
	padding-bottom: 43px;
}
 .notice-bikou{
 	font-size: 1.4rem;
 }
@media screen and (min-width: 320px) and (max-width: 767px)
{
  .notice{
    padding: 2%;
  }
  .notice-steps{
    align-items: flex-start;
  }

  }
  .notice-step img{
    width: 100%;
  }
  .notice-arrow{
    padding: 5px;
    padding-top: calc(9% - 12px);
  }

}