@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Kumbh+Sans:wght@100..900&display=swap');
*{
  margin:0;
  padding:0;
  list-style: none;
  box-sizing: border-box;
  text-decoration: none;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

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

html {
  -ms-text-size-adjust: none;
  -webkit-text-size-adjust: none;
}

body{
  color: #000;
  font-size: 16px;
  letter-spacing: 0.04em;
  line-height: 1.8;
  font-family: 'Noto Sans CJK JP' , 'Noto Sans JP'  ,sans-serif;
  -webkit-font-smoothing: antialiased;
  -ms-text-size-adjust: none;
  -webkit-text-size-adjust: none;
  font-feature-settings: 'palt';
}

input,
textarea,
select{
  color: #000;
  font-family: 'Noto Sans CJK JP' , 'Noto Sans JP'  ,sans-serif;
}

body.fixed {
  width: 100%;
  height: 100%;
  position: fixed;
}

img{
  display: block;
  object-position: center;
}

#body_wrap{
  overflow: hidden;
}

main{
  overflow: hidden;
  padding-top:75px;
}

.grecaptcha-badge { 
  visibility: hidden;
}

a{
  color: #000;
}

@media (any-hover:hover){
  a[href^="tel:"] {
    pointer-events: none;
  }
}

/*
------------------------------------
アニメーション関係
------------------------------------
*/

.common_hover_opa{
  transition: 0.4s;
}


@media (any-hover:hover){
  .common_hover_opa:hover{
    opacity: 0.5;
  }
  
}

/*
------------------------------------
共通パーツ
------------------------------------
*/

.hide{
  display: none!important;
}

.container{
  max-width: 1200px;
  margin:0 auto;
}


.marker_yellow{
  background: linear-gradient(to top, #FCD716 -10%, #FCD716 35%, transparent 35%, transparent 100%);
}

/*
------------------------------------
ヘッダー
------------------------------------
*/

header{
  position: fixed;
  top:0;
  left:0;
  z-index: 20;
  width:100%;
  background-color: #fff;
  font-weight: 700;
}

header .header_inner{
  padding-left: 8px;
  padding-right: 24px;
}

header .header_flex{
  display: flex;
  justify-content: space-between;
  align-items: center;
  height:75px;
}

header .header_left{
  display: flex;
  align-items: center;
}

header .header_logo{
  display: flex;
  align-items: center;
}

header .header_logo img{
  width:166px;
}

header .header_logo p{
  margin-left: 10px;
  
  line-height: 1;

}

header .other_link{
  display: flex;
  justify-content: center;
  align-items: center;
  width: 182px;
  height: 51px;
  border-radius: 4px;
  background-color: #1B2D3F;
  color:#fff;
  
  line-height: 1;
  
  margin-left: 18px;
}

header .header_right{
  display: flex;
  align-items: center;
}

header .header_tel{
  display: flex;
  align-items: center;
  font-size: 22px;
  font-weight: 500;
  line-height:1;
  color:#1B2D3F;
}

header .header_tel::before{
  content:'';
  width: 23px;
  height: 23px;
  background-image: url('../img/common/icon_tel_blue.svg');
  margin-right: 6px;

}

header .button_flex{
  display: flex;
  justify-content: center;
  align-items: center;
  margin-left: 16px;
}

header .button_flex .button{
  width: 282px;
  height: 60px;
  border-radius: 4px;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 18px;
  
  line-height:1;
  
  color:#fff;
  position: relative;
}

header .button_flex .button::after{
  content:'';
  width: 6px;
  height: 13px;
  background-image: url('../img/common/icon_angle_right_white.svg');
  position: absolute;
  right:16px;
  top:0;
  bottom:0;
  margin:auto;
}

header .button_flex .button.line{
  background: linear-gradient(to top, #06C755 0%, #06C755 50%, #0FD15F 50%, #0FD15F 100%);
}

header .button_flex .button.contact{
  margin-left: 10px;
  background: linear-gradient(to top, #FE5900 0%, #FE5900 50%, #FF6C1D 50%, #FF6C1D 100%);
}

header .drawer_open_frame{
  margin-left: 20px;
  min-width:37px;
  height:40px;
  width: fit-content;
  position: relative;
  z-index: 24;
}

header .drawer_open{
  cursor: pointer;
  top:0;
  left:0;
  right:0;
  margin:0 auto;
  z-index: 24;
} 


header .drawer_open p{
  font-family: 'Lato', sans-serif;
  font-size: 12px;
  
  line-height: 1;
  text-align: center;
  color:#1B2D3F;
  margin-top: 6px;
  
}

header .drawer_open_inner{
  display: flex;
  justify-content: space-between;
  flex-direction: column;
  width:34px;
  height:24px;
  margin:0 auto;
}

header .drawer_open .bar{
  height:2px;
  background-color: #1B2D3F;
  transition-duration: 0.5s;
}

@media screen and (max-width:1400px){

  header .header_logo img{
    width:120px;
  }
  
  header .header_logo p{
    margin-left: 10px;
    font-size: 14px;
    line-height: 1;
  
  }
  

  header .button_flex .button{
    width: 242px;
    height: 60px;
    border-radius: 4px;
    font-size: 15px;
  }
  
}/*@media screen and (max-width:1400px){*/


#drawer_menu{
  position: fixed;
  top:0;
  left:0;
  z-index: 30;
  width:100%;
  height:100svh;
  background-color: #FEFBEA;
  overflow:hidden;
  transition-duration: 0.7s;
  pointer-events: none;
  opacity: 0;
}

#drawer_menu a{
  transition: 0.4s;
}


@media (any-hover:hover){
  #drawer_menu a:hover{
    opacity: 0.5;
  }
}



#drawer_menu.show{
  opacity: 1;
  pointer-events: auto;
}

#drawer_menu .drawer_frame{
  position: relative;
  height:100%;
}

#drawer_menu .drawer_close{
  position: absolute;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding:10px;
  cursor: pointer;
  gap:4px 0;
  top:20px;
  right:14px;
}

#drawer_menu .drawer_close::before,
#drawer_menu .drawer_close::after{
  content:'';
  width:40px;
  height:2px;
  background-color:#1B2D3F;
}

#drawer_menu .drawer_close::before{
  transform: translateY(3px) rotate(-45deg);
}

#drawer_menu .drawer_close::after{
  transform: translateY(-3px) rotate(45deg);
}

#drawer_menu .drawer_scroll{
  height:100%;
  overflow-y: scroll;
}

#drawer_menu .drawer_inner{
  max-width: 1200px;
  margin:0 auto;
  padding:100px 0 0;
}

#drawer_menu .drawer_flex{
  display: flex;
  justify-content: flex-end;
  position: relative;
}

#drawer_menu .drawer_deco{
  width:458px;
  /* height:898px; */
  flex-shrink: 0;
}

#drawer_menu .drawer_deco img{
  width:458px;
  position: absolute;
  top:-72px;
  left:calc(50% - 50vw);
}

@media screen and (max-width:1440px){
  #drawer_menu .drawer_deco img{
    left:auto;
    right:calc(50% + 262px);
  }
}

#drawer_menu .drawer_nav{
  display: flex;
  justify-content: flex-end;
  position: relative;
  z-index: 10;
  flex-shrink: 0;
}

#drawer_menu .drawer_nav ul+ul{
  margin-left: 120px;
}

#drawer_menu .drawer_nav li + li{
  margin-top: 50px;
}

#drawer_menu .drawer_nav .parents_link{
  color:#000000;
  font-size: 26px;
  font-weight: 700;
  line-height: 1.3;
  

}

#drawer_menu .button{
  width: 320px;
  height: 60px;
  border-radius: 4px;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 18px;
  line-height:1;
  color:#fff;
  position: relative;
  font-weight: 700;
}

#drawer_menu .button::after{
  content:'';
  width: 6px;
  height: 13px;
  background-image: url('../img/common/icon_angle_right_white.svg');
  position: absolute;
  right:16px;
  top:0;
  bottom:0;
  margin:auto;
}

#drawer_menu .button.line{
  background: linear-gradient(to top, #06C755 0%, #06C755 50%, #0FD15F 50%, #0FD15F 100%);
}

#drawer_menu .button.contact{
  margin-top: 20px;
  background: linear-gradient(to top, #FE5900 0%, #FE5900 50%, #FF6C1D 50%, #FF6C1D 100%);
}

#drawer_menu .drawer_tel{
  display: flex;
  align-items: center;
  width: fit-content;
  color:#000000;
  font-size: 26px;
  font-weight: 500;
  line-height: 1;

}

#drawer_menu .drawer_tel::before{
  content:'';
  width: 23px;
  height: 23px;
  background-image: url('../img/common/icon_tel_black.svg');
  margin-right: 10px;

}

#drawer_menu .other_link{
  display: flex;
  justify-content: center;
  align-items: center;
  min-width: 215px;
  width: fit-content;
  height: 51px;
  border-radius: 4px;
  margin-top: 16px;
  padding:0 16px;
  color: #fff;
  line-height: 1;
  font-weight: 700;
  background-color:#1B2D3F;
}



/*
------------------------------------
トップページ
------------------------------------
*/

body.top_body{
  
}

main.top_main{

}

.top_section{
  position: relative;
}

.top_mv_section{

}

.top_mv_section .top_mv img{
  width: 100%;
}

.top_mv_section .mv_text{
  height:90px;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #FE5900;
  font-size: 30px;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.04em;
  color:#fff;

}

.top_worry_section{
  position: relative;
  z-index: 2;
  padding:110px 0 146px;
  background-image: url('../img/top/worry_bg.png');
  background-position: bottom;
  
}

@media screen and (min-width:1500px){
  .top_worry_section{
    background-size: 100% 100%;
  }
}

.top_worry_section .worry_head{
  display: flex;
  justify-content: center;
  
}

.top_worry_section .worry_head img{
  width:780px;
}

.top_worry_section .card_list{
  display: flex;
  justify-content: center;
  align-items: flex-end;
}

.top_worry_section .card_list li{
  margin:0 16px;
}

.top_worry_section .card_list img{
  width:100%;
}

.top_come_section{
  padding-top: 160px;
  padding-bottom: 110px;
  margin-top: -100px;
  background-image: url('../img/top/come_bg.jpg');
}

.top_come_section .come_head01{
  width:920px;
  margin:0 auto;
  position: relative;
  z-index: 1;
}

.top_come_section .come_head01 .come_head01_img{
  width: 100%;

}

.top_come_section .come_head01::before{
  content:'';
  width: 361px;
  height: 432px;
  background-image: url('../img/top/come_head03.png');
  position: absolute;
  z-index: -1;
  top: -100px;
  right: calc(100% - 40px);
}
  

.top_come_section .come_head02{
  display: flex;
  justify-content: center;
  margin-top: 50px;
}

.top_come_section .come_head02 img{
  width:547px;
}

.top_come_section .come_special{
  margin-top: 72px;
}

.top_come_section .come_special img{
  width:100%;
}

.top_contact_section{
  padding:48px 0;
  background: linear-gradient(81.85deg, #FF9315 8.47%, #FF5715 92.77%);
}

.top_contact_section .white_box{
  width:1344px;
  max-width:92%;
  min-width: 1200px;
  margin:0 auto;
  padding:66px 32px 50px;
  border-radius: 20px;
  background-color: #fff;
}

.top_contact_section .contact_head{
  width: 664px;
  margin:0 auto;
  position: relative;
}

.top_contact_section .contact_head img{
  width:100%;
}

.top_contact_section .contact_head::before{
  content:'';
  width:132px;
  height:132px;
  border-radius: 50%;
  background-image: url('../img/top/contact_head02.png');
  position: absolute;
  top: -36px;
  right:calc(100% + 28px);
  
}

.top_contact_section .tel{
  display: flex;
  justify-content: center;
  align-items: center;
  width:fit-content;
  margin:42px auto 0;
  font-family: 'Kumbh Sans', sans-serif;
  font-size: 58px;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.02em;
  text-align: center;
  color:#1B2D3F;
}

.top_contact_section .tel::before{
  content:'';
  width:60px;
  height:60px;
  border-radius: 50%;
  background-image: url('../img/common/icon_tel_white_blue.svg');
  flex-shrink: 0;
  margin-right: 16px;
}

.top_contact_section .button_flex{
  display: flex;
  justify-content: center;
  margin-top: 36px;
}

.top_contact_section .button{
  display: flex;
  justify-content: center;
  align-items: center;
  width: 500px;
}

.top_contact_section .button img{
  width: 100%;
}

.top_contact_section .button.mail{
  margin-left: 40px;
}

.top_greeting_section{
  padding-top: 120px;
  padding-bottom: 75px;
  background-image: url('../img/top/greeting_bg.png');
  background-position: bottom;
  position: relative;
  z-index: 2;
}

@media screen and (min-width:1441px){
  .top_greeting_section{
    background-size: 100% 100%;
  }
}


.top_greeting_section .head_block{
  padding-left: 515px;
  position: relative;
  z-index: 3;
}

.top_greeting_section .greeting_head01{
  width:635px;
}
.top_greeting_section .greeting_head01 img{
  width: 100%;
}

.top_greeting_section .greeting_head02{
  margin-top: 36px;
  font-size: 26px;
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.02em;
}

.top_greeting_section .greeting_card_list_frame{
  margin-top:80px;
  position: relative;
}

.top_greeting_section .greeting_card_list_frame::before{
  content:'';
  width:478px;
  height:526px;
  background-image: url('../img/top/greeting_deco01.png');
  position: absolute;
  left:0;
  top:-508px;
}

.top_greeting_section .greeting_card_list{
  padding:50px;
  background-color: #FFF6DE;
  position: relative;
  display: flex;
  justify-content: space-between;
  position: relative;
  z-index: 2;
}

.top_greeting_section .greeting_card_list li img{
  width:343px;
}

.top_greeting_section .greeting_text_frame{
  padding-left: 50px;
  margin-top: 60px;
}

.top_greeting_section .greeting_text_frame p{
  font-size: 24px;
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.02em;
}

.top_greeting_section .greeting_text_frame p + p{
  margin-top: 50px;
}

.top_greeting_section .greeting_text_frame li{
  margin-top: 10px;
  width: fit-content;
  padding:6px 10px;
  background-color: #FE5900;
  font-size: 26px;
  font-weight: 500;
  line-height: 1.2;
  letter-spacing: 0.02em;
  color:#fff;
}

.top_greeting_section .greeting_text_frame ul + p{
  margin-top: 10px;
}

.top_greeting_section .greeting_kind_frame{
  position: relative;
  margin-top: 90px;
  padding:90px 50px 40px;
  border: 2px solid #2D3D4D;
  border-radius: 40px;
}

.top_greeting_section .greeting_kind_head{
  position: absolute;
  width:375px;
  left:0;
  right:0;
  top:-30px;
  margin:auto;
}

.top_greeting_section .greeting_kind_frame::before{
  content:'';
  width:596px;
  height:653px;
  background-image: url('../img/top/greeting_deco02.png');
  position: absolute;
  right:0;
  bottom:100%;
}

.top_greeting_section .greeting_kind_list{
  display: flex;
  justify-content: space-between;
}

.top_greeting_section .greeting_kind_list li{
  width:254px;
  position: relative;
}

.top_greeting_section .greeting_kind_list li img{
  width:100%;
}

.top_greeting_section .greeting_kind_list li p{
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  white-space: nowrap;
  padding:0 14px;
  height: 41px;
  background-color: #2D3D4D;
  font-size: 21px;
  font-weight: 500;
  line-height: 1.2;
  letter-spacing: 0.02em;
  color:#fff;
  position: absolute;
  left:0;
  top:-20px;
}

.top_greeting_section .greeting_kind_text{
  margin-top: 30px;
  font-size: 22px;
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.02em;
  text-align: center;
}

.top_greeting_section .greeting_impression_text01{
  margin-top: 60px;
  font-size: 38px;
  font-weight: 700;
  line-height: 1.6;
  letter-spacing: 0.02em;
  text-align: center;
}

.top_greeting_section .greeting_impression_list{
  margin-top: 10px;
  display: flex;
  justify-content: center;
  align-items: flex-start;
}

.top_greeting_section .greeting_impression_list li{
  width:251px;
}

.top_greeting_section .greeting_impression_list li:nth-child(2){
  margin-top: 24px;
  margin-left: 27px;
  margin-right: 13px;
}

.top_greeting_section .greeting_impression_list li img{
  width: 100%;
}

.top_greeting_section .greeting_impression_text02{
  margin-top: 10px;
  font-size: 26px;
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.02em;
  text-align: center;

}

.top_data_section{
  margin-top: -220px;
  padding-top: 295px;
  padding-bottom: 140px;
  background-image: url('../img/top/data_bg01.jpg');
}

.top_data_section .data_head{
  display: flex;
  justify-content: center;
}

.top_data_section .data_head img{
  width:930px;
}

.top_data_section .data_frame{
  max-width: 890px;
  margin: 120px auto 0;
  padding:96px 0 60px;
  border:7px solid #FCD716;
  background-color: #fff;
  border-radius: 24px;
  position: relative;
} 

.top_data_section .data_graph{
  width:483px;
  margin-left: 244px;
}

.top_data_section .data_baloon{
  position: absolute;
  width:946px;
  left:-155px;
  top:-100px;
}

.top_data_section .data_baloon img{
  width:100%;
}

.top_data_bg_section{
  position: relative;
  z-index: 3;
  height:calc(428 / 1440 * 100vw);
  max-height:calc(428 / 1440 * 1920px);
  background-position: top;
  background-image: url('../img/top/data_bg02.png');
  max-width: 1920px;
  margin: -40px auto 0;
}

.top_reason_section01{
  position: relative;
  background-color: #ECF6E8;
  padding-top: 160px;
  padding-bottom: 326px;
}

.top_reason_section01 .reason_sec_head{
  position: absolute;
  z-index: 3;
  width:460px;
  width:min(460px , calc(460 / 1440 * 100vw));
  left:0;
  right:0;
  margin:auto;
  top:max(-380px , calc(-380 / 1440 * 100vw));
}

.top_reason_section01 .reason_sec_head img{
  width:100%;
}

.top_reason_section01 .reason01_head{
  display: flex;
  justify-content: center;
}

.top_reason_section01 .reason01_head img{
  width:562px;
}

.top_reason_section01 .reason_en{
  position: absolute;
  width:105px;
  top:150px;
  left:0;
}

.top_reason_section01 .reason_en img{
  width:100%;
}

.top_reason_section01 .reason01_card_list{
  margin-top: 72px;
  display: flex;
  flex-wrap: wrap;
  gap:40px 32px;
  position: relative;
  z-index: 5;
}

.top_reason_section01 .reason01_card_list li{
  width:270px;
}

.top_reason_section01 .reason01_card_list li img{
  width: 100%;
  border-radius: 16px;
}

.top_reason_section01 .example_frame{
  position: relative;
  margin-top: 180px;
}

.top_reason_section01 .example_frame .reason01_deco{
  width: 532px;
  position: absolute;
  right: 20px;
  bottom: calc(100% - 32px);
  z-index: 0;
}

.top_reason_section01 .example_frame .reason01_deco img{
  width:100%;
}
.top_reason_section01 .example_box{
  position: relative;
  padding:70px 0 40px;
  z-index: 1;
}

.top_reason_section01 .example_box::before{
  content:'';
  width:298px;
  height:37px;
  position: absolute;
  z-index: 4;
  left:0;
  right:0;
  margin:auto;
  top:-35px;
  background-color: #ECF6E8;
}

.top_reason_section01 .example_box::after{
  content:'';
  width:1300px;
  height:100%;
  background-color: #D1ECD8;
  border:2px solid #44B61C;
  border-radius: 40px;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
}

.top_reason_section01 .example_head{
  position: absolute;
  width:198px;
  z-index: 6;
  left:0;
  right:0;
  top:-35px;
  margin:auto;
}

.top_reason_section01 .example_head img{
  width:100%;
}

.top_reason_section01 .example_list{
  display: flex;
  justify-content: space-between;
  position: relative;
  z-index: 4;
}

.top_reason_section01 .example_list li{
  width:372px;
  position: relative;
}

.top_reason_section01 .example_list li.deco::before{
  content:'';
  width: 120px;
  height: 136px;
  background-image: url('../img/top/reason01_example01_deco.png');
  position: absolute;
  top:128px;
  left:-30px;
}

.top_reason_section01 .example_list li img{
  width:100%;
}

.top_reason_section01 .example_text{
  margin-top: 40px;
  font-size: 26px;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.02em;
  text-align: center;
  position: relative;
  z-index: 4;
}

.top_reason_section02{
  position: relative;
  z-index: 1;
  background-color: #fff;
  padding-top: 130px;
  padding-bottom: 330px;
  margin-top: -190px;
  border-radius: 200px 0 0 0;
  overflow: hidden;
}

.top_reason_section02 .reason02_deco{
  position: absolute;
}
.top_reason_section02 .reason02_deco img{
  width:100%;
}
.top_reason_section02 .reason02_deco01{
  width:887px;
  top:514px;
  right:calc(50% - 104px);
}
.top_reason_section02 .reason02_deco02{
  width:315px;
  top:626px;
  left:calc(50% + 226px);
}
.top_reason_section02 .reason02_deco03{
  width:390px;
  top:930px;
  left:calc(50% + 280px);
}

.top_reason_section02 .reason02_head{
  display: flex;
  justify-content: center;
}

.top_reason_section02 .reason02_head img{
  width:725px;
}

.top_reason_section02 .reason_en{
  position: absolute;
  width:105px;
  top:150px;
  right:0;
  z-index: 1;
}

.top_reason_section02 .reason_en img{
  width:100%;
}

.top_reason_section02 .reason_item_list{
  margin-top: 64px;
  display: flex;
  justify-content: center;
  gap:0 20px;
  position: relative;
  z-index: 3;
}

.top_reason_section02 .reason_item_list li{
  width:258px;
}
.top_reason_section02 .reason_item_list li img{
  width:100%;
}

.top_reason_section02 .reason02_text{
  margin-top: 32px;
  font-size: 26px;
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.02em;
  text-align: center;
  position: relative;
  z-index: 3;
}

.top_reason_section02 .reason02_text .orange{
  color:#FB800F;
}

.top_reason_section02 .reason02_text p + p{
  margin-top: 46px;
}


.top_reason_section03{
  position: relative;
  z-index: 2;
  background-color:#FEFBEA;
  padding-top: 130px;
  padding-bottom: 56px;
  margin-top: -190px;
  border-radius: 0 200px 0 0;
}

.top_reason_section03::before{
  content:'';
  width: 326px;
  height: 298px;
  background-image: url('../img/top/reason03_deco02.png');
  position: absolute;
  bottom:-60px;
  right:calc(50% + 456px);
}

.top_reason_section03::after{
  content:'';
  width: 356px;
  height: 325px;
  background-image: url('../img/top/reason03_deco03.png');
  position: absolute;
  bottom:-60px;
  left:calc(50% + 442px);
}

.top_reason_section03 .reason03_deco04{
  width: 240px;
  height: 286px;
  background-image: url('../img/top/reason03_deco04.png');
  position: absolute;
  bottom:223px;
  right:calc(50% + 429px);
}

.top_reason_section03 .reason03_deco05{
  width: 237px;
  height: 233px;
  background-image: url('../img/top/reason03_deco05.png');
  position: absolute;
  bottom:300px;
  left:calc(50% + 428px);

}

.top_reason_section03 .reason03_head{
  display: flex;
  justify-content: center;
}

.top_reason_section03 .reason03_head img{
  width:678px;
}

.top_reason_section03 .reason_en{
  position: absolute;
  width:105px;
  top:150px;
  left:0;
  z-index: 1;
}

.top_reason_section03 .reason_en img{
  width:100%;
}

.top_reason_section03 .item_block{
  max-width: 1100px;
  margin:64px auto 0;
  position: relative;
  z-index: 2;
}

.top_reason_section03 .item_head{
  display: flex;
  justify-content: center;
  align-items: center;
  height: 80px;
  border-radius: 16px 16px 0px 0px;
  background-color: #BD782F;
  font-size: 28px;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: 0.02em;
  color:#fff;
}

.top_reason_section03 .item_body{
  position: relative;
  padding:50px;
  border-radius: 0 0 16px 16px;
  background-color: #fff;;
}

.top_reason_section03 .item_body::before{
  content:'';
  width: 276px;
  height: 199px;
  background-image: url('../img/top/reason03_deco01.png');
  position: absolute;
  right:-12px;
  bottom:100%;
}

.top_reason_section03 .item_body ul{
  display: flex;
  justify-content: space-between;
}

.top_reason_section03 .item_body ul li{
  width:478px;
}

.top_reason_section03 .item_body ul img{
  width:100%;
}

.top_reason_section03 .reason03_sub_head{
  display: flex;
  justify-content: center;
  margin-top: 72px;
}

.top_reason_section03 .reason03_sub_head img{
  width:850px;
}

.top_reason_section03 .special_list{
  display: flex;
  justify-content: center;  
  gap:0 16px;
  margin-top: 32px;
  position: relative;
  z-index: 2;
}

.top_reason_section03 .special_list li{
  width:207px;
}

.top_reason_section03 .special_list li img{
  width:100%;
}

.top_banner_section{
  padding-top: 56px;
  padding-bottom: 128px;
  background-color: #fff;
  clip-path: polygon(100% 0, 100% calc(100% - 100px), 50% 100%, 0 calc(100% - 100px), 0 0);
  position: relative;
  z-index: 3;
} 

.top_banner_section .banner{
  display: block;
  max-width: 900px;
  margin:0 auto;
  box-shadow: 0px 4px 12px 0px #00000052;

}

.top_banner_section .banner img{
  width:100%;
}

.top_program_section{
  padding-top:230px ;
  /* padding-bottom: 164px; */
  margin-top: -180px;
  background-color: #EDF2F5;
}

.top_program_section .program_frame{
  max-width: 1100px;
  margin:0 auto;
}

.top_program_section .program01{

}

.top_program_section .program01 img{
  width:854px;
}

.top_program_section .program02{
  margin-top: -120px;
} 

.top_program_section .program02 img{
  width:1351px;
}

.top_study_flow_section{
  padding-top: 160px;
  padding-bottom: 100px;
  margin-top: -110px;
  z-index: 1;
  background-image: url('../img/top/study_flow_bg.png');
  background-position: top;
}

@media screen and (min-width:1500px){
  .top_study_flow_section{
    /* background-size: 100% 100%; */
  }
}

.top_study_flow_section .study_flow_head{
  display: flex;
  justify-content: center;
}

.top_study_flow_section .study_flow_head img{
  width:220px;
}

.top_study_flow_section .study_list{
  margin-top: 72px;
  position: relative;
} 

.top_study_flow_section .study_list::before{
  content:'';
  width: 2px;
  height: 100%;
  background-color: #4FAD2D;
  position: absolute;
  top:0;
  left:400px;

}

.top_study_flow_section .study_block{
  display: flex;
  align-items: flex-start
}

.top_study_flow_section .study_block + .study_block{
  margin-top: 60px;
}

.top_study_flow_section .study_block .study_thumb{
  flex-shrink: 0;
  margin-right: 20px;
  width: 352px;
}

.top_study_flow_section .study_block .study_thumb img{
  width:100%;
}

.top_study_flow_section .study_block .study_text_area{
  width: 100%;
}

.top_study_flow_section .study_block .study_day{
  width: 226px;
  height: 48px;
  border-radius: 24px;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 26px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.04em;
  color:#fff;
  background-color: #4FAD2D;

}

.top_study_flow_section .study_block .study_name{
  padding-left: 64px;
  margin-top: 12px;
  font-size: 26px;
  font-weight: 700;
  line-height:1.7;
  letter-spacing: 0.04em;
  color:#4FAD2D;

}

.top_study_flow_section .study_block .study_text{
  white-space: nowrap;
  padding-left: 64px;
  margin-top: 10px;
  font-size: 22px;
  font-weight: 400;
  line-height: 1.7;
  letter-spacing: 0.04em;

}

.top_study_flow_section .money_block{
  max-width: 930px;
  margin: 80px auto 0;
}

.top_study_flow_section .money_head{
  width:fit-content;
  display: flex;
  align-items: center;
  padding:14px 28px;
  background-color: #BD782F;
  border-radius: 16px 16px 0 0;
  font-size: 26px;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: 0.02em;
  color:#fff;
}

.top_study_flow_section .money_head::before{
  content:'';
  flex-shrink: 0;
  margin-right: 18px;
  width: 37px;
  height: 37px;
  border-radius: 50%;
  background-image: url('../img/common/icon_money_white.svg');
}

.top_study_flow_section .money_body{
  border:1px solid #D1D1D1;
  padding:32px 40px 40px;
  border-radius: 0 0 16px 16px;
}

.top_study_flow_section .money_body li{
  padding:12px 0;
  font-size: 22px;
  font-weight: 500;
  line-height: 1.7;
  letter-spacing: 0.04em;
  border-bottom:1px dashed #C2C2C2;
}

.top_study_flow_section .money_body li .red{
  color:#E01818;
}

.top_study_flow_section .money_body li .big{
  font-size: 28px;
}

.top_job_flow_section{
  z-index: 1;
  padding-top: 100px;
  padding-bottom: 166px;
  background-image: url('../img/top/job_flow_bg.png');
  background-position: bottom;
}

@media screen and (min-width:1500px){
  .top_job_flow_section{
    background-size: 100% 100%;
  }
}

.top_job_flow_section .job_flow_head{
  display: flex;
  justify-content: center;
}

.top_job_flow_section .job_flow_head img{
  width:524px;
}

.top_job_flow_section .job_flow_list{
  max-width: 980px;
  position: relative;
  margin:72px auto 0;
  display: flex;
  justify-content: space-between;
}

.top_job_flow_section .job_flow_list::after{
  content:'';
  width: 340px;
  height: 320px;
  background-image: url('../img/top/job_flow_deco.png');
  position: absolute;
  right:-84px;
  bottom:100%;
  
}

.top_job_flow_section .job_flow_list li{
  width:478px;
}

.top_job_flow_section .job_flow_list li img{
  width:100%;
  box-shadow: 0px 2px 6px 0px #00000024;
  box-shadow: 0px -1px 8px 0px #0000001A;
}

.top_interview_section{
  padding-top: 130px;
  padding-bottom: 200px;
  background-color: #FF9141;
  margin-top: -96px;
}

.top_interview_section::after{
  content:'';
  width: 1440px;
  height: 1118px;
  background-image: url('../img/top/interview_bg.png');
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
}

.top_interview_section .interview_head{
  display: flex;
  justify-content: center;
}

.top_interview_section .interview_head img{
  width:670px;
}

.top_interview_section .interview_list{
  display: flex;
  justify-content: space-between;
  margin-top: 64px;
} 

.top_interview_section .interview_list .interview_card{
  cursor: zoom-in;
  width:373px;
}

.top_interview_section .interview_list .interview_card img{
  width: 100%;
  border-radius: 20px;
  box-shadow: 0px 2px 14px 0px #00000024;

}

.top_interview_section .msg_box{
  margin-top: 100px;
  border-radius:20px;
  background-image: url('../img/top/interview_msg_bg.png');
  padding:50px;
}

.top_interview_section .msg_area + .msg_area{
  padding-top: 72px;
}

.top_interview_section .js_msg_area{
  display: none;
}

.top_interview_section .msg_head{
  display: flex;
  justify-content: center;
  align-items: center;
}

.top_interview_section .msg_head::before,
.top_interview_section .msg_head::after{
  content:'';
  width: 100%;
  height:2px;
  background-color: #2D3D4D;
}

.top_interview_section .msg_head img{
  flex-shrink: 0;
  margin:0 30px;
  height:38px;
}



.top_interview_section .msg_list{
  margin-top: 44px;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap:30px 0;
}

.top_interview_section .msg_list li{
  width:536px;
}

.top_interview_section .msg_list li img{
  width:100%;
  border: 1px solid #2D3D4D;
  border-radius: 10px;
  box-shadow: 0px 2px 4px 0px #00000029;
}

.top_interview_section .msg_open_button{
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin:50px auto 0;
  cursor: pointer;
  width: 350px;
  height: 54px;
  border-radius: 12px;
  padding-left: 30px;
  padding-right: 22px;
  font-size: 18px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.04em;
  color:#fff;
  background-color: #FE5900;
}

.top_interview_section .msg_open_button::after{
  content:'';
  width: 6px;
  height: 11px;
  background-image: url('../img/common/icon_angle_right_white.svg');
}

.top_interview_section .movie_area{
  margin-top: 104px;
  position: relative;
  z-index: 3;
}

.top_interview_section .movie_head{
  display: flex;
  justify-content: center;
}

.top_interview_section .movie_head img{
  width:497px;
}

.top_interview_section .movie_frame{
  max-width: 1100px;
  margin: 40px auto 0;
  aspect-ratio: 1 / 0.54;
  position: relative;
}

.top_interview_section .movie_thumb{
  position: absolute;
  top: 0;
  left: 0;
  transition-duration: 0.4s;
  width: 100%;
  height: 100%;
  cursor: pointer;
  z-index: 4;
}

.top_interview_section .movie_thumb.vanish{
  opacity: 0;
  pointer-events: none;
}

.top_interview_section .movie_thumb img{
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.top_interview_section .movie_thumb::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 40px 0 40px 69.3px;
  border-color: transparent transparent transparent #FFFFFF;
}

.top_interview_section .movie_frame video {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.interview_popup {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background: rgba(29, 29, 29, 0.4);
  z-index: 50;
  transition-duration: 0.7s;
  pointer-events: none;
  opacity: 0;
  overflow-y: scroll;
  
}

.interview_popup.show {
  pointer-events: auto;
  opacity: 1;
}

.interview_popup .interview_popup_frame{
  padding-top: 160px;
  padding-bottom: 160px;
}

.interview_popup .interview_popup_inner{
  position: relative;
  max-width: 1000px;
  margin:0 auto;
}

.interview_popup .interview_popup_head{
  display: flex;
  justify-content: flex-end;
  min-height:410px;
  position: relative;
  border-radius: 40px 40px 0 0;
  padding-right: 24px;
  padding-top: 40px;
  padding-bottom: 20px;
  background: linear-gradient(120.59deg, #EEF1F3 31.43%, #F7FAFB 44.97%, #EEF1F3 67.53%, #EEF1F3 87.84%);
}

.interview_popup .interview_popup_head::before{
  content:'';
  left:0;
  bottom:0;
  position: absolute;
  z-index: 55;
}

.interview_popup .interview_popup_head .interview_popup_head_contents{
  position: relative;
  z-index: 60;
}

.interview_popup .interview_popup_year{
  width: fit-content;
  padding:8px 20px;
  font-size: 26px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.04em;
  color:#fff;
  white-space: nowrap;
  background-color: #2D3D4D;
}

.interview_popup .interview_popup_title{
  margin-top: 40px;
}

.interview_popup .interview_popup_name{
  display: flex;
  justify-content: flex-end;
  margin-top: 56px;
}

.interview_popup .interview_popup_name p{
  padding:8px 20px;
  font-size: 28px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.04em;
  color:#fff;
  white-space: nowrap;
  background-color: #C71E1A;
}

.interview_popup .interview_popup_body{
  padding:40px 40px 60px;
  background-color: #FF9141;
  border-radius: 0 0 40px 40px;
}

.interview_popup .interview_popup_contents{
  padding:50px 60px 80px;
  background-color: #fff;
  border-radius: 20px;
}

.interview_popup .interview_popup_question span{
  background-color: #C71E1A;
  padding:5px 10px;
  font-size: 28px;
  font-weight: 700;
  line-height:1.2;
  letter-spacing: 0.02em;
  color:#fff;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
}

.interview_popup .interview_popup_answer{
  font-size: 18px;
  line-height: 1.7;
  margin-top: 30px;
}

.interview_popup .interview_popup_answer + .interview_popup_question{
  margin-top: 50px;
}

.interview_popup .interview_popup_close{
  margin:60px auto 0;
  width: fit-content;
  cursor: pointer;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 24px;
  font-weight: 500;
  line-height: 1;
  color:#fff;
}

.interview_popup .interview_popup_close::after{
  content:'';
  width: 15px;
  height: 23px;
  background-image: url('../img/common/icon_angle_right_white.svg');
  flex-shrink: 0;
  margin-left: 24px;

}

.interview01_popup{

}
.interview01_popup .interview_popup_head::before{
  width:464px;
  height:432px;
  background-image: url('../img/top/interview01_pop.png');
}
.interview01_popup .interview_popup_title img{
  width:564px;
}

.interview02_popup{

}
.interview02_popup .interview_popup_head::before{
  width:396px;
  height:432px;
  background-image: url('../img/top/interview02_pop.png');
}
.interview02_popup .interview_popup_title img{
  width:634px;
}

.interview03_popup{

}
.interview03_popup .interview_popup_head::before{
  width:396px;
  height:465px;
  background-image: url('../img/top/interview03_pop.png');
}
.interview03_popup .interview_popup_title img{
  width:570px;
}

.top_model_section{
  background-color: #FFFAF1;
  z-index: 1;
  padding-top: 72px;
} 

.top_model_section::before,
.top_model_section::after{
  content:'';
  width:100%;
  position: absolute;
  left:0;
}

.top_model_section::before{
  background-image: url('../img/top/model_bg01.png');
  background-position: top;
  height:250px;
  top:-80px;
  /* top:0; */
}

.top_model_section::after{
  background-image: url('../img/top/model_bg02.png');
  background-position: bottom;
  height:260px;
  bottom:-166px;
}

.top_model_section .model_area{
  position: relative;
  z-index: 2;
}

.top_model_section .model_area02{
  margin-top: 136px;
}

.top_model_section .model_area .model_head_frame{
  position: relative;
  display: flex;
  align-items: center;
  padding-bottom: 32px;
}

.top_model_section .model_area .model_head_frame img{
  width:100%;
}

.top_model_section .model_head{
  position: relative;
  z-index: 4;
  width:256px;
}
.top_model_section .model_head_sub{
  position: relative;
  z-index: 4;
  width:220px;
  margin-left: 50px;
}

.top_model_section .model_head_en{
  position: absolute;
  z-index: 3;
  width:416px;
  left:0;
  bottom:-1px;
}

.top_model_section .model_area01 .model_head_frame{
  border-bottom:3px solid #FCD716;
}
.top_model_section .model_area02 .model_head_frame{
  border-bottom:3px solid #FE5900;
}

.top_model_section .model_list{
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap:40px 0;
  margin-top: 60px;
}

.top_model_section .model_list li{
  width:373px;
}

.top_model_section .model_list li img{
  width:100%;
  border-radius: 30px;
  box-shadow: 0px 2px 8px 0px #0000001F;
}

.top_step_section{
  padding-top: 236px;
  padding-bottom: 130px;
  background-color: #FF9141;
}

.top_step_section .sec_head{
  display: flex;
  justify-content: center;
  position: relative;
  z-index: 2;
}

.top_step_section .sec_head img{
  width:625px;
}

.top_step_section .step_list{
  position: relative;
  max-width: 1100px;
  margin: 64px auto 0;
}

.top_step_section .step_list::after{
  content:'';
  width: 235px;
  height: 284px;
  background-image: url('../img/top/step_deco.png');
  position: absolute;
  right:0;
  bottom:100%;
}

.top_step_section .step_list .step_arrow{
  display: block;
  width: 42px;
  height: 26px;
  background-image: url('../img/top/step_angle_white.svg');
  margin:30px auto;
}

.top_step_section .step_block{
  padding:40px 80px 40px 24px;
  background-color: #fff;
  border-radius: 10px;
  display: flex;
  position: relative;
}

.top_step_section .step_block .step_num{
  position: absolute;
  top: 28px;
  left: 16px;
}

.top_step_section .step_block .step_num img{
  height:92px;
}

.top_step_section .step_verti{
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  z-index: 3;
  margin-right: 32px;
  flex-shrink: 0;
}

.top_step_section .step_verti::after{
  content:'';
  width:2px;
  height:100%;
  background-color: #2D3D4D;
}

.top_step_section .step_verti img{
  width:12px;
  flex-shrink: 0;
  margin-bottom: 24px;
}

.top_step_section .step_contents{
  width: 100%;
  position: relative;
  z-index: 2;
}

.top_step_section .step_flex{
  margin-top: 36px;
  display: flex;
}

.top_step_section .step_pic{
  flex-shrink: 0;
  width:253px;
  margin-right: 30px;
}

.top_step_section .step_pic img{
  width:100%;
}

.top_step_section .step_text_area{
  width:100%;
}

.top_step_section .step_text_area .red{
  color:#E01818;
}
.top_step_section .step_text_area .blue{
  color:#007DF1;
}
.top_step_section .step_text_area a{
  text-decoration: underline;
  transition-duration: 0.4s;
  color:#007DF1;
}
@media(any-hover:hover){
  .top_step_section .step_text_area a:hover{
    opacity: 0.5;
  }
}

.top_step_section .step_text{
  font-size: 18px;
  line-height: 1.8;
  letter-spacing: 0.04em;
}


.top_step_section .step_block ul{
  margin-top: 20px;
}

.top_step_section .step_block li{
  display: flex;
  align-items: flex-start;
  font-size: 18px;
  line-height: 1.8;
  letter-spacing: 0.04em;
}

.top_step_section .step_block li::before{
  content:'※';font-size: 18px;
  line-height: 1.8;
  letter-spacing: 0.04em;
  flex-shrink: 0;
}

.top_step_section .example_box{
  width: 644px;
  border-radius: 8px;
  background-color: rgba(254, 89, 0, 0.07);
  padding:10px 14px;
  white-space: nowrap;
  font-size: 18px;
  line-height: 1.8;
  letter-spacing: 0.04em;
  margin-top: 20px;
}

.top_step_section .step01_block{

}
.top_step_section .step01_block .step01_head{
  
}
.top_step_section .step01_block .step01_head img{
  width:716px;
}
.top_step_section .step01_block .step_flex{
  align-items: center;
}

.top_step_section .step02_block{

}
.top_step_section .step02_block .step02_head{
  padding-top: 12px;
}
.top_step_section .step02_block .step02_head img{
  width:671px;
}

.top_step_section .step03_block{

}
.top_step_section .step03_block .step03_head{
  padding-top: 12px;
}
.top_step_section .step03_block .step03_head img{
  width:261px;
}

.top_step_section .pay_area{
  max-width: 1100px;
  margin:96px auto 0;
}

.top_step_section .pay_head{
  display: flex;
  justify-content: center;
}

.top_step_section .pay_head img{
  width:442px;
}

.top_step_section .pay_info{
  margin-top: 56px;
  font-size: 26px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.04em;
  text-align: center;
  color:#fff;
} 

.top_step_section .pay_list{
  margin-top: 40px;
  display: flex;
  justify-content: space-between;
}

.top_step_section .pay_block{
  position: relative;
  width: 532px;
  min-height: 183px;
  border-radius: 8px;
  background-color: #fff;
  overflow: hidden;
  padding:80px 22px 32px;
  border: 5px solid #FCD716;
}

.top_step_section .pay_block .pay_sub_head{
  position: absolute;
  top:-5px;
  left:-5px;
  width: 201px;
  height: 57px;
  border-radius: 8px;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #FCD716;
  white-space: nowrap;
}

.top_step_section .pay_block .pay_sub_head img{
  height:35px;
}

.top_step_section .pay_block .pay_text{
  font-size: 20px;
  font-weight: 500;
  line-height: 1.8;
  white-space: nowrap;

}

.top_faq_section{
  z-index: 1;
  padding-top: 136px;
  padding-bottom: 176px;
  background-image: url('../img/top/faq_bg.png');
  background-position: bottom;
} 

.top_faq_section .faq_head{
  display: flex;
  justify-content: center;
}

.top_faq_section .faq_head img{
  width:309px;
}

.top_faq_section .faq_list{
  margin-top: 64px;
  display: flex;
  justify-content: space-between; 
  align-items: flex-start;
  flex-wrap: wrap;
  gap:48px 0;
}

.top_faq_section .faq_block{
  width:580px;
  overflow: hidden;
  border-radius: 10px;
  box-shadow: 0px 2px 8px 0px #0000001F;
}

.top_faq_section .faq_block .faq_question{
  cursor: pointer;
  min-height: 80px;
  padding:8px 16px 8px 12px;
  display: flex;
  align-items: center;
  background-color: #2D3D4D;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.02em;
  color:#fff;
}

.top_faq_section .faq_block .faq_question p{
  width: 100%;
}

.top_faq_section .faq_block .faq_question::before{
  font-family: 'Noto Sans CJK JP' , 'Noto Sans JP'  ,sans-serif;
  content:'Q';
  font-size: 34px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.04em;
  color:#fff;
  flex-shrink: 0;
  margin-right: 12px;
  transform: translateY(-4px);
}

.top_faq_section .faq_block .faq_question::after{
  content:'';
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background-image: url('../img/top/faq_open.svg');
  transition-duration: 0.4s;
  flex-shrink: 0;
  margin-left: 16px;
}

.top_faq_section .faq_block .faq_question.active::after{
  transform: rotateZ(180deg);
}

.top_faq_section .faq_block .faq_answer{
  position: relative;
  background-color: #fff;
  padding:24px 16px 24px 50px;
  font-size: 18px;
  line-height: 1.5;
  display: none;
}

.top_faq_section .faq_block .faq_answer::before{
  font-family: 'Noto Sans CJK JP' , 'Noto Sans JP'  ,sans-serif;
  content:'A';
  font-size: 34px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.04em;
  color:#E01818;
  position: absolute;
  top:14px;
  left:14px;
}

.top_appli_section{
  padding-top: 188px;
  padding-bottom: 110px;
  margin-top: -110px;
  background-color: #FFFAF1;
}

.top_appli_section .appli_head{
  display: flex;
  justify-content: center;
}
.top_appli_section .appli_head img{
  width:175px;
}

.top_appli_section .appli_area{
  margin-top: 64px;
}

.top_appli_section .tab_list{
  display: flex;
  justify-content: center;
}

.top_appli_section .tab{
  display: flex;
  justify-content: center;
  align-items: center;
  width:50%;
  height:100px;
  border-radius: 20px 20px 0 0;
  cursor: pointer;
  position: relative;
}

.top_appli_section .tab::after{
  content:'';
  width:0;
  height:0;
  border-style:solid;
  border-width: 48px 35.5px 0 35.5px;
  position: absolute;
  left:0;
  right:0;
  top:80px;
  margin:auto;
  opacity: 0;
  z-index: 2;
}

.top_appli_section .tab.active::after{
  opacity: 1;
}

.top_appli_section .tab img{
  height:42px;
}

.top_appli_section .tab01{
  background-color: #FE5900;
}
.top_appli_section .tab01::after{
  border-color: #FE5900 transparent transparent transparent;
}

.top_appli_section .tab02{
  background-color: #FCD716;
}
.top_appli_section .tab02::after{
  border-color: #FCD716 transparent transparent transparent;
}



.top_appli_section .appli_block{
  padding:40px 50px 30px;
  background-color: #fff;
  box-shadow: 0px 2px 12px 0px #0000001F;
}

.top_appli_section .appli_line{
  display: flex;
  align-items: flex-start;
  padding:50px 0;
  border-bottom: 1px solid #DCDCDC;
}

.top_appli_section .appli_line:last-child{
  border-bottom: none;
}

.top_appli_section .appli_line .appli_title{
  flex-shrink: 0;
  width:260px;
  padding-right: 16px;
  font-size: 24px;
  font-weight: 700;
  line-height: 1.8;
  letter-spacing: 0.04em;
}

.top_appli_section .appli_line .appli_contents{
  font-size: 20px;
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.04em;
  padding-top: 6px;
}

.top_appli_section .appli_line .appli_contents p + p{
  margin-top: 24px;
}

.top_appli_section .appli_block01 .appli_line .appli_title{
  color:#FE5900;
}
.top_appli_section .appli_block02 .appli_line .appli_title{
  color:#2D3D4D;
}

.top_appli_section .contact_link {
  width: 470px;
  height: 100px;
  border-radius: 4px;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 26px;
  font-weight: 700;
  line-height: 1;
  color: #fff;
  position: relative;
  letter-spacing: 0.04em;
  background: linear-gradient(to top, #FE5900 0%, #FE5900 50%, #FF6C1D 50%, #FF6C1D 100%);
  margin: 70px auto 0;
}

.top_appli_section .contact_link::after {
  content: '';
  width: 8px;
  height: 15px;
  background-image: url('../img/common/icon_angle_right_white.svg');
  position: absolute;
  right: 24px;
  top: 0;
  bottom: 0;
  margin: auto;
}




/*
------------------------------------
採用エントリー
------------------------------------
*/

.contact_mv_section{
  display: flex;
  justify-content: center;
  align-items: center;
  aspect-ratio: 1/0.24;
  min-width: 100%;
  min-height: 188px;
  display: flex;
  justify-content: center;
  align-items: center;
  background-image: url('../img/contact/contact_mv.jpg');
}

main.contact_main{
  background-color: #FFFAF1;
}

.contact_mv_section img{
  width:432px;
}

.contact_info_section{
  padding-top: 90px;
} 

.contact_info_section .white_box{
  padding:60px 84px;
  position: relative;
  background-color: #fff;
  box-shadow: 0px 2px 18px 0px #0000001F;
  text-align: center;
  font-weight: 400;
  max-width: 1100px;
  margin:0 auto;
}

.contact_info_section .white_box p{
  position: relative;
  z-index: 3;
}

.contact_info_section .sec_title{
  display: flex;
  justify-content: center;
}

.contact_info_section .sec_title img{
  width:528px;
}

.contact_info_section .contact_guide{
  margin-top: 40px;
}

.contact_info_section .contact_guide img{
  width:100%;
}

.contact_info_section .p01{
  font-size: 22px;
  margin-top: 50px;
}

.contact_info_section .p02{
  margin-top: 40px;
  font-size: 22px;
  line-height: 1.8;
}

.contact_info_section .p03{
  margin-top: 30px;
  font-size: 22px;
  line-height: 1.8;
}

.contact_info_section .p04{
  margin-top: 30px;
  font-size: 22px;
  line-height: 1.8;
}

.contact_info_section .p05{
  margin-top: 30px;
  font-size: 18px;
  line-height: 1.8;
}

.contact_info_section .contact_deco{
  width:343px;
  position: absolute;
  bottom:0;
  right:-12px;
}

.contact_form_section{
  margin-top: 90px;
  padding-bottom: 160px;
}

.contact_info_section + .contact_form_section{
  margin-top: 70px;
}

.contact_form_section .white_box{
  padding:110px 148px;
  background-color: #fff;
  box-shadow: 0px 2px 18px 0px #0000001F;
  max-width: 1100px;
  margin:0 auto;
}

.contact_form_section .sec_title{
  font-size: 36px;
  text-align: center;
  color:#C71E1A;  
}

.contact_form_section .form_top_text{
  margin-top: 50px;
  font-size: 20px;
  font-weight: 500;
  line-height: 1.6;
  text-align: center;

}

.contact_form_section .form_block{
  margin-top: 30px;
}

.contact_form_section .form_line{
  display: flex;
  align-items: flex-start;
  margin-top: 40px;
}

.contact_form_section .form_left{
  flex-shrink: 0;
  padding-top: 14px;
  width:324px;
}

.contact_form_section .form_title{
  font-size: 20px;
  font-weight: 500;
  line-height: 1;
  display: flex;
  align-items: center;
}

.contact_form_section .form_title::before{
  content:'必須';
  width: 44px;
  height: 24px;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #C71E1A;
  font-size: 12px;
  line-height: 1;
  letter-spacing: 0.02em;
  color:#fff;
  margin-right: 22px;
}

.contact_form_section .form_title.free::before{
  content:'任意';
  background-color: #A9A9A9;
}

.contact_form_section .form_right{
  width:100%;
}

.contact_form_section input[type="text"],
.contact_form_section select{
  border:none;
  background: none;
  border-radius: 0;
  display: block;
  width:100%;
  height:54px;
  border-radius: 5px;
  border:1px solid #C7C7C7;
  padding:0 16px;
  font-size: 20px;
  font-weight: 400;
  line-height: 1;
  color: #000;
}

.contact_form_section textarea{
  border:none;
  background: none;
  border-radius: 0;
  display: block;
  width:100%;
  height:228px;
  border-radius: 5px;
  border:1px solid #C7C7C7;
  padding:16px;
  font-size: 20px;
  font-weight: 400;
  line-height: 1.4;
  color: #000;
}


.contact_form_section input[type="text"]::placeholder,
.contact_form_section textarea::placeholder
{
  color:#C7C7C7;
}

.contact_form_section .form_right.radio{
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap:12px 56px;
  padding-top: 12px;
}

.contact_form_section .form_right.radio.error{
  width: 100%;
}


.contact_form_section .form_right.radio label{
  display: flex;
  align-items: center;
  font-size: 20px;
  font-weight: 400;
  line-height: 1;
  cursor: pointer;

}

.contact_form_section .form_right.radio label input{
  width:23px;
  height:23px;
  margin-right: 12px;
}
.contact_form_section .birth_flex{
  display: flex;
  justify-content: space-between;
}

.contact_form_section .birth_box{
  width:116px;
}

.contact_form_section .birth_box04{
  width:86px;
}

.contact_form_section .agree_flex{
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 72px;
  font-size: 18px;
  font-weight: 500;
  padding-bottom: 30px;
  position: relative;
}


.contact_form_section .agree_flex .error{
  position: absolute;
  text-align: center;
  width:100%;
  bottom:0;
  left:0;
}

.contact_form_section .agree_flex p{
  margin-left: -8px;
}

.contact_form_section .agree_flex a{
  color:#007DF1;
  border-bottom: 1px solid #007DF1;
}

.contact_form_section .agree_flex input{
  width:18px;
  height:18px;
  margin-top: 10px;
}

.contact_form_section .submit_area{
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 60px;
}

.contact_form_section .submit_area .submit_frame{
  position: relative;
}

.contact_form_section .submit_area .submit_frame::after{
  content:'';
  width: 8px;
  height: 15px;
  background-image: url('../img/common/icon_angle_right_white.svg');
  position: absolute;
  right:48px;
  top:0;
  bottom:0;
  margin:auto;
  pointer-events: none;
}

.contact_form_section .submit_area .submit{
  cursor: pointer;
  border: none;
  background: none;
  border-radius: 0;
  width: 436px;
  height: 100px;
  border-radius: 4px;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 20px;
  line-height:1;
  font-weight: 700;
  color:#fff;
  position: relative;
  background: linear-gradient(to top, #FE5900 0%, #FE5900 50%, #FF6C1D 50%, #FF6C1D 100%);
  transition-duration: 0.4s;
}

.contact_form_section .submit_area .return{
  border: none;
  background: none;
  border-radius: 0;
  transition-duration: 0.4s;
  margin-top: 40px;
  color:#007DF1;
  border-bottom:1px solid #007DF1;

  font-size: 18px;
  font-weight: 400;
  line-height:1.6;
  cursor: pointer;

}

@media(any-hover:hover){
  .contact_form_section .submit_area .submit:hover{
    opacity: 0.5;
  }
  .contact_form_section .submit_area .return:hover{
    opacity: 0.5;
  }
}
.contact_form_section .confirm_text{
  margin-top: 80px;
  text-align: center;
  font-size: 18px;
  font-weight: 400;
  text-align: center;
  white-space: nowrap;
  display: none;
}

.contact_form_section .confirm_text p + p{
  margin-top: 32px;
}

.contact_form_section .confirm_text a{
  text-decoration: underline;
  color:#007DF1;
}

/*確認画面*/

.contact_form_section .mw_wp_form_confirm .form_left{
  padding-top: 0;
}

.contact_form_section .mw_wp_form_confirm  .form_right.radio{
  padding-top: 0;
}

.contact_form_section .mw_wp_form_confirm .agree_flex{
  display: none;
}

.contact_form_section .mw_wp_form_confirm .birth_flex{
  display: flex;
  justify-content: flex-start;
  gap:0 8px;

}

.contact_form_section .mw_wp_form_confirm .birth_box{
  width: auto;
}

.contact_form_section .mw_wp_form_confirm .birth_box04{
  width: auto;
}

.contact_form_section .mw_wp_form_confirm .confirm_text{
  display: block;
}


.contact_finish_section .p01{
  font-size: 24px;
  text-align: center;
}


.contact_finish_section .top_link{
  cursor: pointer;
  border: none;
  background: none;
  border-radius: 0;
  width: 436px;
  height: 100px;
  border-radius: 4px;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 20px;
  line-height:1;
  color:#fff;
  position: relative;
  background: linear-gradient(to top, #FE5900 0%, #FE5900 50%, #FF6C1D 50%, #FF6C1D 100%);
  margin:40px auto 0;
}


.contact_finish_section .top_link::after{
  content:'';
  width: 8px;
  height: 15px;
  background-image: url('../img/common/icon_angle_right_white.svg');
  position: absolute;
  right:48px;
  top:0;
  bottom:0;
  margin:auto;
  pointer-events: none;
}
