@charset 'UTF-8';
html,body{
  overflow-x: hidden;
  line-height: 1.5;
  font-family: "游ゴシック", "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: .5vw;
}
*{
  padding: 0;
  margin: 0;
}
body{
  -ms-overflow-style: none;
  scrollbar-width: none;
}
body::-webkit-scrollbar{
  display:none;
}
.border_bottom{
  border-bottom: 1px solid #000;
}
.unique_font{
  font-family: 'Noto Serif JP', serif!important;
}
.w50{
  width: 50%;
}
.w20{
  width: 20%;
}
.w30{
  width: 30%;
}
.w40{
  width: 40%;
}
.w60{
  width: 60%;
}
.w70{
  width: 70%;
}
.w80{
  width: 80%;
}
.bdtop{
  border-top: 1px solid #000;
  padding-top: 20em;
}
.bdtop_pt2{
  border-top: 1px solid #000;
  padding: 10em 0;
}
.white{
  color: #fff;
}
.inner_pt1{
  width: 38.5vw;
  margin: 0 auto;
}
.inner_pt2{
  width: 78vw;
  margin: 0 auto;
}
.inner_pt3{
  width: 90vw;
  margin: 0 auto;
}
.none{
  display: none;
}
.flex{
  display: flex;
  align-items: flex-start;
}
.inlineblk{
  display: inline-block;
}
.jcsb{
  justify-content: space-between;
}
.center{
  text-align: center;
}
.right{
  text-align: right;
}

.bold{
  font-weight: bold;
}
.unique_input{
  border: none!important;
  padding: 0!important;
}
.underline_design{
  font-weight: bold;
  border-bottom: 5px solid #000;
  display: inline-block;
}

.text_pt1{
  font-size: 5.75em;
}

.text_pt2{
  font-size: 4.95em;
  line-height: 1.35;
}

.text_pt3{
  font-size: 2.52em;
  line-height: 2;
}

.text_pt4{
  font-size: 3.15em;
}

.text_pt5{
  font-size: 3.85em;
  line-height: 1.35;
}

.text_pt6{
  font-size: 2.57em;
}

.right_design{
  width: 89vw;
  border-bottom: 1px solid #000;
  margin-left: auto;
  padding-right: 11vw;
}

.left_design{
  width: 89vw;
  border-bottom: 1px solid #000;
  margin-right: auto;
  padding-left: 11vw;
}

.select_wrapper,
.select_wrapper select,
input[type="text"],
input[type="tel"],
textarea{
  width: 100%;
}
.select_wrapper select,
input[type="text"],
input[type="tel"],
textarea{
  border: 1px solid #000;
  padding: .45em .35em;
}
.confirm_contact_content .select_wrapper select,
.confirm_contact_content input[type="text"],
.confirm_contact_content textarea{
  border: none;
  color: #a6a6a6;
}
.select_wrapper select:focus,
input[type="text"]:focus,
input[type="tel"]:focus,
textarea:focus{
  outline: none;
}

.select_wrapper{
  position: relative;
}
.select_wrapper::after{
  position: absolute;
  content: '\02228';
  right: 5%;
  bottom: 50%;
  transform: scale(1.85, 1) translate(50%, 50%);
}

input[type="submit"]{
  border: 1px solid #000;
  background-color: #fff;
  color: #000;
  font-size: 2.25em;
  padding: .85em 5.25em;
}
input[type="submit"].active{
  background-color: #000;
  color: #fff;
}
.footer_bg{
  position: relative;
}
.footer_bg_pt2{
  padding: 5.25em 0;
  background-color: #000;
}
.footer_bg::after{
  position: absolute;
  top: 50%;
  left: 50%;
  transform-origin: center;
  transform: translate(-50%, -50%) rotate(6deg) scale(7.2,1);
  content: '';
  width: 15%;
  height: 50em;
  background-color: #000;
  z-index: -1;
}
footer .text_pt3 span{
  font-size: 1.2em;
}
.contact_anker{
  border: 1px solid #fff;
  padding: 1em 7.15em;
}

footer{
  padding-bottom: 40em;
}
.footer_pt2{
  padding-bottom: 0;
}
header{
  padding: 3.15em 0;
}
main{
  padding-top: 13.15em;
  padding-bottom: 37.15em;
}

.mgbtm25{
  margin-bottom: 25em!important;
}
.mgbtm20{
  margin-bottom: 20em!important;
}
.mgbtm10{
  margin-bottom: 10em!important;
}
.mgbtm9{
  margin-bottom: 9em!important;
}
.mgbtm8{
  margin-bottom: 8em!important;
}
.mgbtm7{
  margin-bottom: 7em!important;
}
.mgbtm6{
  margin-bottom: 6em!important;
}
.mgbtm5{
  margin-bottom: 5em!important;
}
.mgbtm4{
  margin-bottom: 4em!important;
}
.mgbtm3{
  margin-bottom: 3em!important;
}
.mgbtm2{
  margin-bottom: 2em!important;
}
.mgbtm1{
  margin-bottom: 1em!important;
}
.mgrht1{
  margin-right: 1em!important;
}
.mgrht3{
  margin-right: 3em!important;
}
.pg8{
  padding-top: 8em!important;
  padding-bottom: 8em!important;
}
.pg1{
  padding-top: 1em!important;
  padding-bottom: 1em!important;
}
.footer_item_pg{
  padding-top: 3.65em!important;
}
.bg_gray{
  position: relative;
  padding-top: 3.5em!important;
}
.bg_gray::after{
  position: absolute;
  top: 55%;
  left: 50%;
  transform-origin: center;
  transform: translate(-50%, -50%) rotate(6deg) scale(7.2,1);
  content: '';
  width: 15%;
  height: 77.5em;
  background-color: #f3f3f3;
  z-index: -1;
}
.lineheihgt_unique{
  line-height: 2;
}
.back_to_top{
  position: absolute;
  right: 4em;
  top: -9em;
  color: #000;
  font-size: 2.15em;
  font-weight: bold;
  cursor: pointer;
  transition: .2s;
}
.back_to_top:hover{
  opacity: .5;
}
.anker{
  transition: .2s;
}
.anker:hover{
  opacity: .5;
}
.image01{
  width: 25.15em;
  height: auto;
}
.image02{
  width: 65.15em;
  height: auto;
}
.top_image{
  width: 100%;
}
.top_image_wrapper{
  margin-bottom: 10.85em;
}
.achievement a{
  transition: .2s;
}
.achievement a:hover{
  opacity: .5;
}
.confirm_contact_content .flex{
  display: block;
}
.confirm_contact_content .flex .w30,
.confirm_contact_content .flex .w70{
  width: 100%;
}
input.error,
textarea.error{
  border: 1px solid #eb1a58;
}
.err_msg{
  color: #eb1a58;
}
.unique_height{
  height: 13.5em;
}
.unique_height_pt2{
  height: 33.5em;
}
footer.fixed{
  position: fixed;
  left: 0;
  bottom: 0;
  width: 100vw;
}


/**
 * スマホ sumaho
 */
@media screen and (max-width: 800px){
  html,body{
    font-size: 1.75vw;
  }
  .inner_pt1{
    width: 95vw;
  }
  .inner_pt2{
    width: 95vw;
  }
  .inner_pt3{
    width: 95vw;
  }
  .text_pt1{
    font-size: 4.75em;
  }
  .text_pt2{
    font-size: 3.45em;
  }
  .text_pt3,
  .text_pt6{
    font-size: 2.12em;
  }
  .text_pt5{
    font-size: 3.15em;
  }
  .mgbtm25{
    margin-bottom: 15em;
  }
  .bg_gray::after {
    top: 40em;
    height: 120%;
    width: 20%;
  }
  .right_design .flex,
  .left_design .flex{
    display: block;
  }
  .right_design .flex .text_pt5,
  .left_design .flex .text_pt5,
  .achievement .text_pt5{
    margin-bottom: 1.25em;
  }
  .right_design .flex .w20,
  .left_design .flex .w20,
  .left_design .flex .w80,
  .achievement .flex .w20{
    width: 100%;
  }
  .right_design{
    width: 97.5vw;
    padding-right: 2.5vw;
  }
  .left_design{
    width: 95vw;
    padding-left: 5vw;
  }
  .achievement .flex{
    display: block;
  }
  .image02{
    width: 100%;
  }
  .application_flex{
    display: block;
  }
  .application_flex .w20,
  .application_flex .w80{
    width: 100%;
  }
  .application form .flex{
    display: block;
  }
  .application form .flex .w30,
  .application form .flex .w70{
    width: 100%;
  }
  input[type="submit"]{
    width: 100%;
    text-align: center;
  }
  footer .flex{
    display: block;
  }
  footer .flex .w60,
  footer .flex .w40{
    width: 100%;
  }
  .footer_item_pg{
    padding-top: 0;
  }
  .contact_anker{
    display: block;
    text-align: center;
  }
  .back_to_top{
    right: 2.5vw;
  }
  .footer_bg::after{
    top: 53%;
    transform: translate(-50%, -50%) rotate( 6deg) scale(8.2,1);
  }
  .image01{
    margin-top: 2.75em;
  }
  .application_flex .w20 .unique_font{
    display: none;
  }
  input[type="text"],
  input[type="tel"],
  select,
  textarea{
    font-size: 16px!important;
  }
  .unique_height{
    height: 16em;
  }
  .unique_height_pt2{
    height: 36em;
  }
}


@media screen and (min-width: 1200px){
  .inner_pt1{
    width: 462px;
  }
  .inner_pt2{
    width: 936px;
  }
  .inner_pt3{
    width: 1080px;
  }
  html,body{
    font-size: 6px;
  }
}