html {
  font-size: calc(10 / 1280 * 100vw);
  font-family: "Noto Sans JP";

}

.main {
  overflow: hidden;
}

.sp_br {
  display: none;
}

/* トップ画像 */
.mainimage {
  font-family: "Noto Sans JP";
  font-weight: bold;
  position: relative;
  background-color: #FFFFFF;
}

.parallax {
  position: fixed;
  top: 0;
  z-index: -9999;
  width: 100vw;
  height: 100vh;
  object-fit: cover;
}

.mainvisual {
  width: 93rem;
  height: 46.8rem;
  object-fit: cover;
  object-position: 50% 0;
  margin: 3rem 3rem 0.9rem 3rem;
}

.mainimage_img_group {
  width: 99rem;
  height: 60.2rem;
  background-color: #036EB4;
  margin-left: auto;
}

.mainimage_text {
  color: white;
  font-size: 3rem;
  margin: 0 auto;
  width: 90rem;
  text-align: center;
}

.mainimage_position_group {
  width: 58.9rem;
  position: absolute;
  top: 6.5rem;
  left: 3rem;
  z-index: 5;
}

.mainimage_title {
  font-size: 6rem;
  color: #036EB4;
  /* -webkit-text-stroke: 0.1rem #FFF; */
  text-shadow:
    0.1rem -0.1rem 0 white,
    /* 右上 */
    0.1rem 0.1rem 0 white,
    /* 左下 */
    0.1rem 0.1rem 0 white,
    /* 右下 */
    0.1rem 0 0 white,
    /* 左 */
    0.1rem 0 0 white,
    /* 右 */
    0 0.1rem 0 white,
    /* 上 */
    0 0.1rem 0 white;
  /* 下 */
  position: relative;
  height: 8.7rem;
  line-height: 8.7rem;
  z-index: 3;
  margin-bottom: 2.5rem;
}

.mainimage_title::after {
  content: '';
  width: 58.3rem;
  height: 2rem;
  position: absolute;
  bottom: 0rem;
  background-color: #FFDC4E;
  z-index: -1;
  display: block;
}

.mainimage_title_accent {
  font-size: 4.3rem;
  color: #036EB4;
}

.mainimage_subtitle {
  font-size: 2.5rem;
  color: white;
  width: 40.4rem;
  height: 7.6rem;
  margin-bottom: 1rem;
  background: linear-gradient(to right, #036EB4, #8BC01F);
  padding-left: 1.3rem;
  line-height: 7.6rem;
}

.mainimage_subtitle2 {
  font-size: 2.5rem;
  color: white;
  width: 26.9rem;
  height: 7.6rem;
  background: linear-gradient(to right, #036EB4, #8BC01F);
  margin-bottom: 2.5rem;
  text-align: center;
  line-height: 7.6rem;
}

.mainimage_subtitle_sp {
  display: none;
}

.mainimage_period {
  width: 24.4rem;
}

.mainimage_period_sp {
  display: none;
}

.mainimage_period_year {
  font-size: 2.2rem;
  color: #036EB4;
}

.mainimage_period_day {
  font-size: 3.3rem;
  color: #036EB4;
  text-wrap: nowrap;
  height: 6.5rem;
  margin-bottom: 1rem;
}

.mainimage_period_day_week {
  font-size: 2rem;
  position: relative;
  left: -1rem;
}

.mainimage_period_day_accent {
  font-size: 2.2rem;
  display: inline-block;
  padding-left: 1.2rem;
  padding-right: 0rem;
  margin-left: -3rem;
}

.mainimage_age {
  font-size: 2rem;
  font-weight: 500;
  color: white;
  background-color: #036EB4;
  width: 23.2rem;
  height: 4.9rem;
  text-align: center;
  line-height: 4.9rem;
  border-radius: 3.3rem;
  margin: 0 auto;
}

/* トップ画像 */
/* グッドポイントテキスト */
.word {
  width: 100%;
  font-family: "Noto Sans JP";
  /* background-image: url(../img/800599.jpg);
  background-size: 100%; */
  height: 27rem;
  padding-top: 6rem;
}

.word_text {
  width: 122rem;
  height: 13.6rem;
  font-size: 1.9rem;
  background-color: rgba(255, 255, 255, 0.6);
  text-align: center;
  margin: 0 auto;
  line-height: 3.6rem;
  padding-top: 2.7rem;
}

.word_accent {
  font-weight: bold;
  font-size: 2.1rem;
}

.accent_size {
  font-size: 1.9rem;
}

/* グッドポイントテキスト */
/* お問い合わせ */
.contact {
  position: relative;
  background-color: #036EB4;
  padding: 3rem 0;
  overflow: hidden;
}

.contact_title {
  font-size: 4rem;
  width: 50rem;
  height: 10rem;
  text-align: center;
  line-height: 10rem;
  margin: 0 auto;
  background-color: #FFFF11;
  color: #036EB4;
  margin-bottom: 2rem;
  border-radius: 5rem;
}

.contact_text {
  font-size: 1.8rem;
  color: white;
  margin-bottom: 4rem;
  text-align: center;
}

.nav_link_wrap {
  display: flex;
  gap: 5rem;
  justify-content: center;
}

.ex_link_wrap {
  position: relative;
}

.ex_link {
  display: block;
  width: 45rem;
  height: 10rem;
  background-color: #FF6600;
  color: white;
  font-size: 3rem;
  font-weight: bold;
  text-align: center;
  line-height: 9rem;
}

.sub_ex_link {
  display: block;
  font-size: 2rem;
  width: 35rem;
  height: 5rem;
  color: #FF0000;
  background-color: white;
  font-weight: bold;
  text-align: center;
  line-height: 5rem;
  border-radius: 2.5rem;
  position: absolute;
  top: -2.6rem;
  left: 5rem;
}

.ex_img {
  position: absolute;
  top: -21.9rem;
  right: 23rem;
  width: 22rem;
}

.contact_link_wrap {
  position: relative;
}

.contact_link {
  display: block;
  width: 45rem;
  height: 10rem;
  background-color: white;
  color: #036EB4;
  font-size: 3rem;
  text-align: center;
  line-height: 9rem;
  font-weight: bold;
}

.sub_contact_link {
  display: block;
  font-size: 2rem;
  width: 35rem;
  height: 5rem;
  color: white;
  background-color: #0000C8;
  text-align: center;
  font-weight: bold;
  text-align: center;
  line-height: 5rem;
  border-radius: 2.5rem;
  position: absolute;
  top: -2.6rem;
  left: 5rem;
}

.co_img {
  position: absolute;
  top: -23.8rem;
  left: 23rem;
  width: 25rem;
}

/* お問い合わせ */
/* 対象学年 */
.target_age {
  background-color: #FFFFFF;
  background-image: linear-gradient(90deg, #d6d6d680 0.1rem, transparent 0.1rem), linear-gradient(#d6d6d680 0.1rem, transparent 0.1rem);
  background-position: 1rem 1rem;
  background-size: 2.1rem 2.1rem;
  font-family: "Noto Sans JP";
  padding-bottom: 8rem;
}

.age_title {
  font-size: 3rem;
  margin: 0 0 4rem;
  padding-top: 8rem;
  text-align: center;
  font-weight: 500;
}

.age_list {
  display: flex;
  gap: 6rem;
  justify-content: center;
}

/* 小学生 */
.elementary_school_student {
  width: 30rem;
  height: 34.3rem;
  background-color: #EFEFEF;
}

.elementary_title {
  font-size: 2rem;
  text-align: center;
  font-weight: 500;
  margin: 1.5rem 0;
}

.elementary_img {
  width: 26rem;
  height: 16.9rem;
  margin: 0 auto;
}

.elementary_img img {
  width: 26rem;
  height: 16.9rem;
  margin: 0 auto;
}

.target_elementary {
  font-size: 1.4rem;
  margin-bottom: 1rem;
  font-weight: 500;
  padding-left: 2rem;
  margin-top: 1.3rem;
  line-height: 1.8rem;
}

.elementary_school_student p:last-child {
  margin-bottom: 2rem;
}

/* 小学生 */
/* 中学生 */
.junior_high_school_student {
  width: 30rem;
  height: 34.3rem;
  background-color: #EFEFEF;
}

.junior_high_title {
  font-size: 2rem;
  text-align: center;
  font-weight: 500;
  margin: 1.5rem 0;
}

.junior_high_img {
  width: 26rem;
  height: 16.9rem;
  margin: 0 auto;
}

.junior_high_img img {
  width: 26rem;
  height: 16.9rem;
  margin: 0 auto;
}

.junior_high_target {
  font-size: 1.4rem;
  margin-bottom: 1rem;
  font-weight: 500;
  padding-left: 2rem;
  margin-top: 1.3rem;
  line-height: 1.8rem;
}

.junior_high_school_student p:last-child {
  margin-bottom: 2rem;
}

/* 中学生 */
/* 高校生 */
.high_school_student {
  width: 30rem;
  height: 34.3rem;
  background-color: #EFEFEF;
}

.high_title {
  font-size: 2rem;
  text-align: center;
  font-weight: 500;
  margin: 1.5rem 0;
}

.high_img {
  width: 26rem;
  height: 16.9rem;
  margin: 0 auto;
}

.high_img img {
  width: 26rem;
  height: 16.9rem;
  margin: 0 auto;
}

.high_target {
  font-size: 1.4rem;
  margin-bottom: 1rem;
  font-weight: 500;
  padding-left: 2rem;
  margin-top: 1.3rem;
  line-height: 1.8rem;
}

.high_school_student p:last-child {
  margin-bottom: 2rem;
}

/* 高校生 */
/* 対象学年 */
/* プロナビの強み */
.swiper {
  overflow: hidden;
}

.swiper2 {
  overflow: hidden;
  position: relative;
}

.strong_point {
  font-family: "Noto Sans JP";
  background-color: #009F97;
  border: 0.2rem solid#000000;
}

.strong_title {
  font-size: 6rem;
  padding-top: 2.3rem;
  margin-bottom: 1.3rem;
  color: white;
  text-align: center;
}

.strong_link_wrap {
  display: flex;
  gap: 4rem;
  justify-content: center;
  padding-bottom: 2rem;
  /* margin-right: 3rem; */
}

.strong_link {
  display: block;
  width: fit-content;
  height: 15rem;
  overflow: hidden;
}

.strong_link img {
  width: 31rem;
  height: auto;
}

.strong_link2 {
  display: block;
  width: fit-content;
  height: 15rem;
  overflow: hidden;
}

.strong_link2 img {
  width: 32rem;
  height: auto;
}

.swiper_img {
  width: 60rem;
  height: 30rem;
  object-fit: cover;
  margin: 0 auto 1.5rem;
}

.swiper_title {
  font-size: 2.2rem;
  margin-bottom: 1.5rem;
  text-align: center;
  color: white;
}

.swiper_text {
  font-size: 1.6rem;
  width: 70.6rem;
  height: auto;
  padding: 2rem 2.8rem 2.8rem;
  border: 0.1rem solid #000000;
  background-color: white;
  margin: 0 auto 4.5rem;
  line-height: 4rem;
}

.swiper_text_weight {
  font-weight: bold;
}

.swiper-button-next.swiper-button-prev {
  position: absolute;
  top: 46rem;
}

.swiper-button-prev {
  width: 7rem;
  height: 7rem;
  left: 19.4rem;
  top: 14rem;
}

.swiper-button-next {
  width: 7rem;
  height: 7rem;
  right: 19.6rem;
  top: 14rem;
}

/* 前へ次への矢印カスタマイズ */
.swiper-button-prev::after,
.swiper-button-next::after {
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  width: 7rem;
  height: 7rem;
  margin: auto;
}

/* 前への矢印カスタマイズ */
.swiper-button-prev::after {
  background-image: url(../img/left_yazirushi.png);
  width: 7rem;
  height: 7rem;
}

/* 次への矢印カスタマイズ */
.swiper-button-next::after {
  background-image: url(../img/right_yazirushi.png);
  width: 7rem;
  height: 7rem;
}

/* プロナビの強み */
.background {
  height: 2.6rem;
  display: none;
  background-color: white;
}

/* 体験　実績　特典 */
.content_group {
  background-color: #FFF6D2;
  position: relative;
  padding-top: 10.3rem;
  /* margin-top: 2.6rem; */
  font-family: "Noto Sans JP";
}

/* 体験 */
.experience {
  width: 102rem;
  margin: 0 auto;
  background-color: #FFDC4E;
  border: 0.2rem solid #000000;
  padding: 2rem 3rem 3.5rem;
  margin-bottom: 13rem;
}

.experience_title {
  font-size: 2rem;
  width: 51.4rem;
  border-bottom: double 0.5rem #000000;
  margin: 0 auto 1.9rem;
  font-weight: 500;
  letter-spacing: 0.05rem;
  padding-bottom: 0.4rem;
}

.experience_content {
  display: flex;
  justify-content: space-between;
}

.experience_img {
  width: 48rem;
  height: 39.2rem;
  object-fit: cover;
  margin-top: 0.5rem;
}

.experience_text_group {
  width: 45.5rem;
}

.experience_text {
  font-size: 1.6rem;
  margin-bottom: 2.8rem;
  height: 24.8rem;
  line-height: 3.2rem;
}

.experience_link_text {
  font-size: 2rem;
  height: 2.9rem;
  margin-bottom: 3.7rem;
  margin-left: 1.3rem;
  font-weight: 500;
  letter-spacing: 0.06rem;
}

.experience_link_text::before {
  content: '';
  display: inline-block;
  border-top: 0.1rem solid #000000;
  width: 8.4rem;
  margin-right: 0.9rem;
  padding-bottom: 0.7rem;
}

.experience_link_text::after {
  content: '';
  display: inline-block;
  border-top: 0.1rem solid #000000;
  width: 8.4rem;
  margin-left: 0.9rem;
  padding-bottom: 0.7rem;
}

.experience_link_group {
  display: flex;
  gap: 3rem;
  justify-content: center;
}

.experience_link {
  display: block;
  width: 19.8rem;
  height: 5.3rem;
  background-color: #000000;
  color: white;
  text-align: center;
  line-height: 5.3rem;
  font-size: 2rem;
  padding-left: 0.5rem;
}

.experience_tel {
  display: block;
  width: 20rem;
  height: 5.3rem;
  background-color: #000000;
  color: white;
  text-align: center;
  line-height: 5.3rem;
  font-size: 2rem;
  padding-bottom: 0.5rem;
  font-weight: 500;
  padding-left: 1rem;
  margin-bottom: 0.4rem;
}

.experience_tel img {
  width: 2.7rem;
  height: 2.8rem;
  margin-top: 1.3rem;
  padding-right: 0.5rem;
}

.experience_time {
  font-size: 1.2rem;
  padding-left: 2.6rem;
  font-weight: 500;
}

.experience_holiday {
  font-size: 1.2rem;
  padding-left: 2.6rem;
  font-weight: 500;
  padding-top: 0.1rem;
}

/* 体験 */
/* 実績 */
/* 中学生 */
.achievement {
  background-color: white;
  position: relative;
  width: 122rem;
  height: 65.1rem;
  margin: 0 auto;
  border-radius: 7.5rem;
  margin-bottom: 5rem;
}

.achievement_img {
  position: absolute;
  top: 37rem;
  left: -3rem;
  width: 44.1rem;
  height: 33.1rem;
  display: block;
}

.achievement_title {
  font-size: 3.5rem;
  margin-bottom: 5.8rem;
  padding-top: 7rem;
  text-align: center;
  position: relative;
}

.achievement_pen {
  position: absolute;
  top: 5rem;
  right: 43rem;
  width: 17.9rem;
  height: 8.3rem;
}

.achievement_list {
  display: flex;
  justify-content: space-between;
  margin: 0 auto;
  margin-bottom: 4rem;
}

.achievement_list_1 {
  width: 26.8rem;
  position: relative;
  margin-left: 13.3rem;
  padding-right: 4.35rem;
}

.achievement_list_1::after {
  content: '';
  display: inline-block;
  border-right: 0.1rem solid#000000;
  height: 18.4rem;
  position: absolute;
  top: 0;
  right: 0;
}

.achievement_junior_high_title {
  font-size: 4rem;
  text-wrap: nowrap;
  margin-bottom: 4rem;
}

.achievement_accent {
  font-size: 3rem;
  margin-left: 1.5rem;
}

.achievement_junior_high_text {
  font-size: 2.2rem;
  text-align: center;
  font-weight: bold;
  line-height: 2.5rem;
  padding-right: 1.4rem;
}

.achievement_high_text {
  font-size: 2.2rem;
  margin-bottom: 3rem;
}

/* 中学生 */
/* 高校生 */
.achievement_list_2 {
  width: 47rem;
  position: relative;
}

.achievement_list_2::after {
  content: '';
  display: inline-block;
  border-right: 0.1rem solid#000000;
  height: 18.4rem;
  position: absolute;
  top: 0;
  right: 0;
}

.achievement_high_title {
  font-size: 4rem;
  margin-bottom: 3.4rem;
  padding-left: 11rem;
}

.achievement_high_text {
  font-size: 2.2rem;
  font-weight: bold;
  width: 24.2rem;
  margin-bottom: 2.1rem;
  margin-left: 10.3rem;
  line-height: 4rem;
}

.achievement_sub_high {
  font-size: 1.6rem;
  width: 33.5rem;
  margin-left: 5.1rem;
  line-height: 3.2rem;
}

/* 高校生 */
/* 大学 */
.achievement_list_3 {
  padding-left: 6.5rem;
  padding-right: 12.4rem;
}

.achievement_university_title {
  font-size: 4rem;
  margin-bottom: 3.5rem;
  padding-left: 0.7rem;
}

.achievement_university_text {
  font-size: 2.2rem;
  margin-bottom: 3.3rem;
  line-height: 3.9rem;
  width: 25rem;
  font-weight: bold;
  margin-left: 0.6rem;
}

.achievement_sub_university {
  font-size: 2rem;
  width: 23.1rem;
  line-height: 3.8rem;
}

/* 大学 */
/* 実績 */
/* 特典 */
.privilege {
  text-align: center;
}

.privilege_img {
  width: 58.1rem;
  height: 36.4rem;
  margin: 0 auto;
  margin-bottom: 5rem;
}

/* 特典 */
/* 三角形 */
.triangle {
  height: 4rem;
  width: 16rem;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  position: absolute;
  bottom: -4rem;
  left: 56rem;
  background-color: #FFF6D2;
}

/* 三角形 */
/* 体験　実績　特典 */
/* 流れ */
.step_wrap {
  background-color: white;
}

.step {
  padding-top: 9rem;
  width: 96rem;
  margin: 0 auto;
  padding-bottom: 9rem;
}

.step_title {
  font-size: 3.5rem;
  text-align: center;
  margin-bottom: 6rem;
}

.step1 {
  margin-bottom: 3.5rem;
}

.step1_title {
  font-size: 2.2rem;
  margin-bottom: 1.1rem;
  height: 7.4rem;
  line-height: 7.4rem;
}

.step_logo {
  width: 9.6rem;
  height: 7.5rem;
  margin-right: 1.4rem;
}

.step1_content {
  display: flex;
  gap: 8.8rem;
  margin-bottom: 1.92rem;
}

.step1_text {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 3.2rem;
}

.step1_img {
  width: 31.7rem;
  height: 21.1rem;
  object-fit: cover;
}

.triangle2 {
  width: 7rem;
  height: 2.9rem;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  background-color: #2A4957;
  margin-left: 1rem;
}

.step2_title {
  font-size: 2.2rem;
  margin-bottom: 1.4rem;
  height: 7.4rem;
  line-height: 7.4rem;
}

.step2_content {
  display: flex;
  gap: 8.8rem;
  margin-bottom: 1.52rem;
}

.step2_text {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 3.2rem;
}

.step2_img {
  width: 31.7rem;
  height: 21.1rem;
  object-fit: cover;
}

/* 流れ */
/* q and a  */
.qa {
  padding-bottom: 17rem;
  background-color: white;
}

.qa_title {
  font-size: 3.5rem;
  text-align: center;
  margin-bottom: 5rem;
}

.qa_box {
  width: 102rem;
  margin: 0 auto 3rem;
  border: 0.2rem solid #009F97;
  border-radius: 1.2rem;
}

.q_logo {
  font-size: 2.5rem;
  font-weight: 500;
  margin-right: 3.1rem
}

.q {
  font-size: 2rem;
  color: #009F97;
  font-weight: 500;
  padding: 3.1rem 0 1.7rem 2.7rem;
  position: relative;
}

.a_logo {
  display: block;
  font-size: 2.5rem;
  color: #FF0000;
  font-weight: 500;
  margin-right: 3.1rem;
  margin-left: 2.9rem;
  line-height: 3rem;
}

.a {
  font-weight: 500;
  display: none;
  font-size: 2rem;
  color: #000000;
  margin-bottom: 3.7rem;
}

.a_text {
  width: 90rem;
}

.a::before {
  display: block;
  content: '';
  border-top: 0.2rem dashed #009F97;
  width: 96.2rem;
  margin: 0 auto;
}

.qa_flex {
  display: flex;
  font-size: 1.8rem;
  padding-top: 2.6rem;
}

.q.active div {
  display: flex;
}

.qa_triangle {
  display: inline-block;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  width: 2.1rem;
  height: 1.8rem;
  background-color: #009F97;
  position: absolute;
  top: 4.6rem;
  right: 2.7rem;
}

.q.active .qa_triangle {
  clip-path: polygon(50% 0, 100% 100%, 0 100%);
}

/* q and a  */
/* 校舎一覧 */
.school_building {
  padding-bottom: 6rem;
  background-color: white;
}

.school_building_title {
  font-size: 3rem;
  margin-bottom: 5.6rem;
  text-align: center;
}

.school_building_map {
  display: flex;
  gap: 9rem;
  justify-content: center;
  font-weight: 500;
}

.school_name {
  width: 50rem;
  height: 5rem;
  border-radius: 0.5rem;
  font-size: 2.5rem;
  font-weight: 500;
  margin-bottom: 2.9rem;
  background-color: #036EB4;
  color: white;
  text-align: center;
  line-height: 5rem;
}

.school_building1_location {
  font-size: 1.8rem;
  margin-bottom: 1rem;
}

.school_building1_transit {
  font-size: 1.8rem;
}

.transit_title {
  font-size: 1.8rem;
  font-weight: 500;
}

.bus {
  margin-bottom: 3.1rem;
}

.map1 {
  width: 50rem;
  height: 30.4rem;
}

/* 校舎一覧 */
/* 固定フッター */
.fixed_footer {
  height: 10rem;
  background: rgba(3, 110, 180, 0.9);
  padding: 0 1rem;
  position: fixed;
  bottom: 0;
  width: 100%;
  display: flex;
  justify-content: center;
  z-index: 1000;
}

.fixed_logo {
  width: 24rem;
  height: 5.8344rem;
  margin-top: 2rem;
}

.fixed_tel {
  display: block;
}

.fixed_tel_img {
  margin-top: 2rem;
  margin-right: 3rem;
  width: 27rem;
}

.fixed_experience {
  display: block;
  width: 22rem;
  height: 5rem;
  background: #009F97;
  font-weight: 700;
  font-size: 1.5rem;
  color: white;
  line-height: 5rem;
  text-align: center;
  border-radius: 3rem;
  margin-top: 2rem;
  margin-right: 3rem;
  position: relative;
}

.fixed_contact_link {
  width: 18rem;
  height: 5rem;
  line-height: 5rem;
  text-align: center;
  background: #8BC01F;
  color: white;
  font-size: 1.5rem;
  border-radius: 3rem;
  margin-top: 2rem;
  font-weight: 700;
  position: relative;
}

.fixed_experience_img {
  width: 2rem;
  margin-top: 1.5rem;
  margin-right: 1rem;
}

.fixed_contact_img {
  width: 2rem;
  margin-top: 1.5rem;
  margin-right: 1rem;
}

.fixed_download_img {
  width: 2.5rem;
  margin-top: 1.5rem;

}

.fixed_download_link {
  width: 18rem;
  height: 5rem;
  line-height: 5rem;
  text-align: center;
  background: #FFDC4E;
  color: white;
  font-size: 1.5rem;
  border-radius: 3rem;
  margin-top: 2rem;
  font-weight: 700;
  margin-left: 3rem;
}

.fixed_footer_sp {
  display: none;
}

/* 固定フッター */
.margin {
  padding-bottom: 10rem;
  background-color: white;
}
.space{
  display:inline-block;
  margin-left:1.trem;
}
@media screen and (max-width:699.98px) {

  .fixed_footer {
    display: none;
  }

  .fixed_footer_sp {
    display: block;
    position: fixed;
    bottom: 0;
    background: rgba(3, 110, 180, 0.9);
    height: 8rem;
    width: 100%;
    display: flex;
    z-index: 1000;
  }

  .fixed_logo_sp {
    width: 17rem;
    height: 4.3rem;
    margin-top: 2rem;
    margin-left: 1rem;
    margin-right: 6.5rem;
  }

  .fixed_download_link_sp {
    text-align: center;
    background: #FFDC4E;
    width: 6.5rem;
    height: 100%;
    font-size: 1rem;
    color: white;
    display: block;
    text-align: center;
  }

  .fixed_download_img_sp {
    width: 4.5rem;
    display: block;
    margin-left: 1rem;
    margin-top: 0.7rem;
  }

  .fixed_tel {
    width: 6.5rem;
    height: 100%;
    background-color: #006834;
    font-size: 1rem;
    color: white;
    display: block;
    text-align: center;
  }

  .fixed_tel_img_sp {
    width: 4.5rem;
    margin: 0.5rem 1rem 0.2rem 1.4rem;
  }

  .fixed_ex {
    width: 6.5rem;
    height: 100%;
    background-color: #009F97;
    font-size: 1rem;
    color: white;
    text-align: center;
  }

  .fixed_ex_img {
    width: 3.8rem;
    margin: 1rem 1rem 0.8rem 1rem;
  }

  .fixed_co {
    width: 6.5rem;
    height: 100%;
    background-color: #8BC01F;
    font-size: 1rem;
    color: white;
    text-align: center;
    display: none;
  }

  .fixed_co_img {
    width: 3.8rem;
    margin: 1rem 1rem 0.3rem 1rem;
  }

  html {
    font-size: calc(10 / 375 * 100vw);
  }

  .pc_br {
    display: none;
  }

  .sp_br {
    display: block;
  }

  .sp_none {
    display: none;
  }

  /* トップ画像 */
  .mainimage_position_group {
    position: static;
    width: auto;
  }

  .mainimage_title {
            font-size: 3rem;
        margin-bottom: 0;
        position: absolute;
        top: -0.9rem;
  }

  .mainimage_title::after {
    width: 29.7rem;
    bottom: 2rem;
  }

  .mainimage_title_accent {
    font-size: 2.5rem;
  }

  .mainimage_subtitle {
    font-size: 1.8rem;
    width: 20rem;
    height: 8rem;
    padding-top: 1rem;
    padding-left: 0;
    line-height: 3rem;
    position: absolute;
    bottom: 33rem;
    left: 0;
    text-align: center;
    display: none;
    background: none;
    background-color: rgba(180, 317, 320, 0.5);
  }

  .mainimage_subtitle2 {
    font-size: 1.8rem;
    width: 25rem;
    height: 8rem;
    padding-top: 1rem;
    padding-left: 0;
    line-height: 3rem;
    text-align: left;
    position: absolute;
    bottom: 21rem;
    left: 0rem;
    text-align: center;
    display: none;
    background: none;
    background-color: rgba(180, 317, 320, 0.5);
  }

  .mainimage_subtitle_sp {
    font-size: 1.8rem;
        width: 100%;
        height: 8rem;
        padding-top: 1rem;
        padding-left: 0;
        line-height: 3rem;
        text-align: left;
        position: absolute;
        bottom: 39.1rem;
        left: 0rem;
        text-align: left;
        display: block;
        color: #3e3e3e;
        -webkit-text-stroke: 0.1rem #ffffff;
        paint-order: stroke;
  }

  .mainimage_img_group {
    width: 100%;
    height: 32.2rem;
  }

  .mainvisual {
    width: 100%;
    margin: 0 0 3rem 0;
    height: 20.8rem;
  }

  .mainimage_text {
    width: 100%;
    font-size: 1.8rem;
    text-align: center;
  }

  .mainimage_period {
    display: none;
  }

  .mainimage_period_sp {
    display: block;
    padding: 2rem;
  }

  .mainimage_period_year {
    width: 20rem;
    margin: 0 auto;
  }

  .mainimage_period_day {
    font-size: 3.4rem;
    width: 25rem;
    margin: 0 auto 1rem;
  }

  /* トップ画像 */
  /* グッドポイントテキスト */
  .word {
    padding-bottom: 6rem;
    height: auto;
  }

  .word_text {
    width: 100%;
    font-size: 1.6rem;
    height: 22rem;
    padding: 2rem;
  }

  .word_accent {
    font-size: 1.8rem;
  }

  .waccent_size {
    font-size: 1.7rem;
  }

  /* グッドポイントテキスト */
  .contact_period_group {
    width: 100%;
    padding: 0 2rem;
  }

  /* お問い合わせ  */
  .contact_title {
    font-size: 2rem;
    height: 5rem;
    line-height: 5rem;
    width: 26rem;
  }

  .contact_text {
    font-size: 1.6rem;
  }

  .nav_link_wrap {
    display: block;
    margin: 0 auto;
    width: 30rem;
  }

  .ex_link {
    margin-bottom: 3rem;
    width: 30rem;
    height: 6rem;
    font-size: 2rem;
    line-height: 6rem;
    margin-bottom: 5rem;
  }

  .sub_ex_link {
    font-size: 1.5rem;
    height: 3rem;
    line-height: 3rem;
    width: 25rem;
    left: 3rem;
    top: -2rem;
  }

  .sub_contact_link {
    font-size: 1.5rem;
    height: 3rem;
    line-height: 3rem;
    width: 25rem;
    left: 3rem;
    top: -2rem;
  }

  .contact_link {
    margin-bottom: 3rem;
    width: 30rem;
    height: 6rem;
    font-size: 2rem;
    line-height: 6rem;
    margin-bottom: 3rem;
  }

  .ex_img {
    display: none;
  }

  .co_img {
    display: none;
  }

  /* お問い合わせ  */
  /* 対象学年 */
  .age_list {
    display: block;
  }

  .elementary_school_student {
    margin: 0 auto 2rem;
  }

  .junior_high_school_student {
    margin: 0 auto 2rem;
  }

  .high_school_student {
    margin: 0 auto;
  }

  /* 対象学年 */
  /* プロナビの強み */
  .strong_title {
    font-size: 3rem;
  }

  /* プロナビの強み */
  .swiper {
    width: 30rem;
  }

  .swiper_img_wrapper {
    width: 100%;
  }

  .swiper_img {
    width: 30rem;
  }

  .swiper_title {
    height: 8rem;
    margin: 0 auto 6.5rem;
    width: 30rem;
  }

  .swiper_text {
    width: 33rem;
    font-size: 1.5rem;
    padding: 1rem 1rem 1rem;
    height: auto;
  }

  .swiper-button-prev {
    top: 10rem;
    left: 2.4rem;
    width: 5rem;
    height: 5rem;
  }

  .swiper-button-next {
    top: 10rem;
    right: 2.4rem;
    width: 5rem;
    height: 5rem;
  }
  .strong_link_wrap{
    flex-flow:column;
    align-items:center;
    gap:1rem;
  }
  .strong_link {
    display: block;
    width: fit-content;
    height: auto;
    overflow: hidden;
    height: 12rem;
  }

  .strong_link img {
    width: 26rem;
    height: auto;
  }

  .strong_link2 {
    display: block;
    width: fit-content;
    height: auto;
    overflow: hidden;
    height: 12rem;
  }

  .strong_link2 img {
    width: 28rem;
    height: auto;
    margin-right:0.6rem;
  }

  /* プロナビの強み */
  /* 体験 */
  .experience {
    width: 33rem;
    padding: 2rem;
  }

  .experience_title {
    width: 23rem;
  }

  .experience_content {
    display: block;
  }

  .experience_img {
    width: 100%;
    margin-bottom: 1rem;
  }

  .experience_text {
    height: auto;
  }

  .experience_text_group {
    width: auto;
  }

  .experience_link_group {
    display: block;
  }

  .experience_link_text {
    margin-left: 0;
  }

  .experience_link_text::before {
    width: 1rem;
  }

  .experience_link_text::after {
    width: 1rem;
  }

  .experience_link {
    margin: 0 auto 2rem;
  }

  .experience_tel {
    margin: 0 auto 0.4rem;
  }

  .experience_time {
    padding-left: 4.6rem;
  }

  .experience_holiday {
    padding-left: 4.6rem;
  }

  /* 体験 */
  /* 実績 */
  .achievement {
    width: auto;
    height: auto;
    padding: 0 2rem 3rem;
  }

  .achievement_list {
    display: block;
  }

  .achievement_list_1 {
    width: auto;
    margin: 0 0 3rem;
    padding: 0;
    text-align: center;
    padding-bottom: 5rem;
  }

  .achievement_list_1::after {
    border-top: 0.1rem solid #000000;
    border-right: none;
    height: 0.1rem;
    width: 32rem;
    top: auto;
    bottom: 0;
    left: 1rem;
    right: auto;
  }

  .achievement_img {
    display: none;
  }

  .achievement_junior_high_text {
    padding: 0;
  }

  .achievement_accent {
    display: block;
    margin: 0;
  }

  .achievement_list_2 {
    width: auto;
    text-align: center;
    padding-bottom: 5rem;
    margin-bottom: 3rem;
  }

  .achievement_list_2::after {
    border-top: 0.1rem solid #000000;
    border-right: none;
    height: 0.1rem;
    width: 32rem;
    top: auto;
    bottom: 0;
    left: 1rem;
    right: auto;
  }

  .achievement_high_title {
    margin: 0 0 1.5rem;
    padding: 0;
  }

  .achievement_high_text {
    margin: 0 0 1.5rem;
    width: auto;
  }

  .achievement_img {
    width: 30rem;
  }

  .achievement_sub_high {
    width: auto;
    margin: 0;
  }

  .privilege_img {
    width: 30rem;
    height: 18.75rem;
  }

  .triangle {
    left: 10rem;
  }

  .achievement_list_3 {
    padding: 0;
    text-align: center;
  }

  .achievement_university_text {
    margin: 0 0 1.5rem;
    width: auto;
  }

  .achievement_university_title {
    padding: 0;
    margin-bottom: 1.5rem;
  }

  .achievement_sub_university {
    width: auto;
  }

  .achievement_pen {
    top: 6rem;
    right: 2rem;
  }

  /* 実績 */
  /* 流れ */
  .step {
    width: auto;
  }

  .step_title {
    font-size: 2.7rem;
  }

  .step1_content {
    display: block;
  }

  .step2_content {
    display: block;
  }

  .step_logo {
    width: 5.6rem;
    height: 3.5rem;
  }

  .step1_title {
    font-size: 1.8rem;
    height: auto;
    line-height: normal;
    width: 30rem;
    text-align: center;
  }

  .step1_text {
    padding: 0 2rem;
  }

  .step1_img {
    width: 100%;
    margin-top: 1rem;
  }

  .triangle2 {
    margin: 0 auto;
  }

  .step2_title {
    font-size: 1.8rem;
    padding-left: 2rem;
    height: auto;
    line-height: normal;
  }

  .step2_text {
    padding: 0 2rem;
  }

  .step2_img {
    width: 100%;
    margin-top: 1rem;
  }

  /* 流れ */
  /* q and a  */
  .qa_box {
    width: auto;
    margin: 0 2rem 3rem;
  }

  .q {
    display: flex;
    padding-bottom: 3.7rem;
  }

  .qa_triangle {
    top: auto;
    right: 15rem;
    bottom: 0.6rem;
  }

  .qa_title {
    font-size: 2.5rem;
    padding: 0 2rem;
  }

  .qa {
    padding-bottom: 10rem;
  }

  .a_logo {
    margin-right: 1.5rem;
  }

  .a_text {
    width: auto;
    padding-right: 2rem;
  }

  .a::before {
    width: 100%;
  }

  /* q and a  */
  /* 校舎 */
  .school_building_map {
    display: block;
  }

  .school_name {
    width: auto;
  }

  .map1 {
    width: 100%;
  }

  .sp_text_wrap {
    padding: 0 2rem;
  }

  .school_building1_location {
    padding: 0 2rem;
  }

  /* 校舎 */
}

/* ===================================================================
/
/ header
/
=================================================================== */
header {}

.h01-01 img {
  width: 12rem;
  margin-top: 1.5rem;
  margin-left: 2rem;
}

header .h01-01 {
  max-width: 295px;
  width: 16vw;
}

header .h02-01 {
  /* color: #B2C997; */
  font-weight: 700;
  padding: 0 30px;
}

header .h02-01 img {
  max-width: 45px;
  width: 100%;
}

header .h02-02 img {
  max-width: 265px;
  width: 100%;
}

header .h03 img {
  width: 18.5px;
  margin-right: 10px;
}

header .h03 .btn p {
  font-size: 1rem;
  font-weight: bold;
}

header .h03 a {
  line-height: 1;
  color: #fff;
  font-size: 15px;
  border-radius: 30px;
  padding: 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  font-size: 1rem;
}

header .h03 .a01 {
  width: 220px;
  background: #009F97;
  margin-right: 10px;
}

header .h03 .a02 {
  width: 180px;
  background: #8BC01F;
}

header nav span {
  display: block;
  line-height: 1.5;
}

header nav .ja {
  font-weight: 700;
  font-size: 17px;
  color: #000;
}

header nav .en {
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0.1rem;
  color: #036892;
  background: linear-gradient(to right, #036892, #6880AA);
  -webkit-background-clip: text;
  display: inline-block;
}

@media all and (-ms-high-contrast: none) {

  /* ここに書く */
  header nav .en {
    background: none;
    font-weight: normal;
  }
}

.site-header {
  background: #fff;
  max-width: 1700px;
  width: 100%;
  margin: auto;
}

.site-header-inner {
  margin: 0 15px 0 50px;
  height: 150px;
  display: none;
}

/* nav */
.header-nav {}

.header-nav.is-hide {
  opacity: 0
}

.header-nav>li {
  margin: 0 15px;
  font-size: 1rem;
  vertical-align: middle;
  list-style: none;
  text-align: center;
  position: relative;
}

.header-nav>li.b_l {
  border-left: none;
}

.header-nav>li img {
  margin: 0 0 12px;
}

.header-nav>li a {
  text-decoration: none;
  color: #000;
  width: 100%;
  height: 100%;
}

.header-nav>li:hover .header-nav-child,
.header-nav>li:active .header-nav-child {
  height: 172px;
}

.header-nav>li.header_contact {
  background: -moz-linear-gradient(top left, #0000C8, #1B1B45);
  background: -webkit-linear-gradient(top left, #0000C8, #1B1B45);
  background: linear-gradient(to bottom right, #0000C8, #1B1B45);
}

.header-nav>li.header_contact a {
  padding: 37px 40px;
}

.header-nav>li.header_contact img {
  width: 25px;
}

.header-nav-child {
  position: absolute;
  height: 0;
  width: 200px;
  top: 40px;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  overflow: hidden;
  -webkit-transition: height .3s .15s;
  transition: height .3s .15s;
  z-index: 9999;
  background-color: #fff;
}

.header-nav-child>ul {
  margin: 0 auto;
  width: 100%;
  /*padding:2%;*/
}

.header-nav-child>ul>li {
  list-style: none;
  margin: 0 0 1px 0;
  padding: 12px 2%;
  border: none;
  width: 100%;
  transform: none;
  /*border-bottom:1px solid rgba(0,0,0,0.6);*/
  color: #000;
}

.header-nav-child>ul>li:first-child {
  padding-top: 14px;
}

.header-nav-child>ul>li:last-child {
  border-bottom: none;
}

.header-nav-child>ul>li:hover {
  background-color: #006834;
  color: #fff;
  transition: 0.3s;
}

.header-nav-child>ul>li>a {
  text-decoration: none;
  position: relative;
  display: block;
  font-size: 0.9rem;
  color: #000;
  padding: 0 5px;
  letter-spacing: 0.14em;
  z-index: 5;
}

.header-nav-child>ul>li:hover a {
  color: #fff;
  transition: 0.3s;
}

/* ===================================================================
/
/ header(ハンバーガー)
/
=================================================================== */
#hamburger {
  display: none;
  position: fixed;
  z-index: 1003;
  right: 13px;
  top: 12px;
  width: 42px;
  height: 42px;
  cursor: pointer;
  text-align: center;
}

#hamburger span {
  display: block;
  position: absolute;
  transition: 0.5s;
  width: 30px;
  height: 2px;
  left: 6px;
  background: #333;
  -webkit-transition: 0.3s ease-in-out;
  -moz-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
}

#hamburger span:nth-child(1) {
  top: 10px;
}

#hamburger span:nth-child(2) {
  top: 20px;
}

#hamburger span:nth-child(3) {
  top: 30px;
}

/* ナビ開いてる時のボタン */
#hamburger.active span:nth-child(1) {
  top: 16px;
  left: 6px;
  -webkit-transform: rotate(-45deg);
  -moz-transform: rotate(-45deg);
  transform: rotate(-45deg);
  background: #fff;
}

#hamburger.active span:nth-child(2),
#hamburger.active span:nth-child(3) {
  top: 16px;
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  transform: rotate(45deg);
  background: #fff;
}

nav#globalMenuSp {
  display: none;
  position: fixed;
  z-index: 1002;
  top: 0;
  left: 0;
  color: #FFFFFF;
  text-align: center;
  transform: translateX(100%);
  transition: all 0.6s;
  width: 100%;
}

nav#globalMenuSp span {
  display: block;
  line-height: 1.5;
}

nav#globalMenuSp .ja {
  font-weight: 700;
  font-size: 15px;
}

nav#globalMenuSp .en {
  font-size: 10px;
  color: #fff;
}

nav#globalMenuSp .nav-taiken {
  background: rgba(0, 159, 151, 0.7);
}

nav#globalMenuSp .nav-mail {
  background: rgba(139, 192, 31, 0.7);
}

nav#globalMenuSp ul {
  margin: 0 auto;
  padding: 0;
  width: 100%;
  height: 100vh;
  background: rgba(3, 110, 180, 0.9);
  overflow: scroll;
}

nav#globalMenuSp ul li {
  list-style-type: none;
  padding: 0;
  width: 100%;
  border-bottom: 1px solid #fff;
}

nav#globalMenuSp ul li.half {
  width: 50%;
}

nav#globalMenuSp ul li.half:nth-child(2n) {
  border-left: 1px solid #fff;
}

nav#globalMenuSp ul li:last-child {
  padding-bottom: 0;
  border-bottom: none;
}

nav#globalMenuSp ul li:hover {
  background: #006834;
}

nav#globalMenuSp ul li a {
  display: block;
  color: #fff;
  padding: 0.8em 0;
  text-decoration: none;
}

/* このクラスを、jQueryで付与・削除する */
nav#globalMenuSp.active {
  transform: translateX(0%);
}

nav#globalMenuSp input {
  display: none;
}

nav#globalMenuSp .accshow {
  height: 0;
  overflow: hidden;
}

nav#globalMenuSp .accshow ul li {
  padding: 1.5rem;
}

nav#globalMenuSp .cssacc:checked+.accshow {
  height: auto;
}

.accordion {
  pointer-events: none;
}

/* ===================================================================
/
/ f_contact
/
=================================================================== */
.f_contact {
  text-align: center;
  color: #fff;
  padding: 60px 0;
}

.f_contact h2 {
  line-height: 60px;
  margin-bottom: 30px;
}

.f_contact .contact_tel_area a {
  color: #fff;
  text-decoration: none;
}

.f_contact .f_contact_inner {
  width: 95%;
  margin: 0 auto;
}

.f_contact .f02-tel01 {
  font-size: 14px;
  letter-spacing: 0.2rem;
  margin-bottom: 15px;
}

.f_contact .f02-tel01 span {
  font-size: 20px;
  margin-left: 5px;
}

.f_contact .f02-tel02 span {
  font-size: 32px;
  margin-right: 10px;
}

.f_contact .f02-tel02 strong {
  font-size: 50px;
  color: #fff;
}

.f_contact .f03 .btn a {
  color: #fff;
  line-height: 1;
  color: #fff;
  font-size: 15px;
  border-radius: 50px;
  padding: 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.f_contact .f03 .f-btn01 a {
  position: relative;
  width: 300px;
  background: #009F97;
  margin-right: 25px;
}

.f_contact .f03 .f-btn01 a::before {
  position: absolute;
  top: -20px;
  left: -20px;
  content: "";
  display: inline-block;
  background-image: url(../images/deco01.png);
  background-size: contain;
  background-repeat: no-repeat;
  width: 35px;
  height: 35px;
}

.f_contact .f03 .f-btn02 a {
  position: relative;
  width: 250px;
  background: #8BC01F;
}

.f_contact .f03 .f-btn02 a::before {
  position: absolute;
  top: -20px;
  left: -20px;
  content: "";
  display: inline-block;
  background-image: url(../images/deco02.png);
  background-size: contain;
  background-repeat: no-repeat;
  width: 35px;
  height: 35px;
}

.f_contact .f03 .btn p {
  font-weight: 700;
  font-size: 1.4rem;
}

.f_contact .f03 .btn a img {
  width: 28px;
  margin-right: 15px;
}

/* ===================================================================
/
/ footer
/
=================================================================== */
footer {
  background-color: #fff;
  padding: 50px 0 30px;
  text-align: center;
  margin-bottom: 90px;
}

footer .f_logo {
  width: 300px;
  margin: 0 auto 30px;
}

footer .copyright {
  padding: 15px 0;
}

footer .copyright p {
  color: #fff;
  font-size: 1rem;
  text-align: center;
  letter-spacing: 1px;
}

footer .f_menu {
  max-width: 1180px;
  width: 90%;
  margin: 0 auto 50px;
}

footer .f_menu ul {}

footer .f_menu ul li {
  text-align: center;
  padding: 0 30px;
  border-left: 1px solid #000;
  margin-bottom: 20px;
  line-height: 1.5;
}

footer .f_menu ul li:last-of-type {
  border-right: 1px solid #000;
}

footer .f_menu ul li a {
  font-size: 1.1rem;
  text-decoration: none;
  color: #000;
}

.footer_fixed {
  height: 100px;
  background: rgba(3, 110, 180, 0.9);
  padding: 0 10px;
  position: fixed;
  bottom: 0;
  width: 100%;
}

.footer_fixed .footer-inner {
  max-width: 1180px;
  margin: auto;
}

.footer_fixed .footer_container {
  max-width: 1180px;
  width: 100%;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.footer_fixed .f01 {
  max-width: 240px;
  width: 18vw;
}

.footer_fixed .f02 {
  margin: 0 70px 0 30px;
}

.footer_fixed .f02 p {
  color: #fff;
}

.footer_fixed .f02-tel01 {
  font-size: 11px;
  letter-spacing: 0.2rem;
}

.footer_fixed .f02-tel01 span {
  font-size: 16px;
  margin-left: 5px;
}

.footer_fixed .f02-tel02 span {
  font-size: 26px;
  margin-right: 10px;
}

.footer_fixed .f02 strong {
  font-size: 42px;
  color: #fff;
}

.footer_fixed .f03 .btn a {
  color: #fff;
  line-height: 1;
  color: #fff;
  font-size: 15px;
  border-radius: 30px;
  padding: 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.footer_fixed .f03 .f-btn01 a {
  position: relative;
  width: 220px;
  background: #009F97;
  margin-right: 25px;
}

.footer_fixed .f03 .f-btn01 a::before {
  position: absolute;
  top: -15px;
  left: -20px;
  content: "";
  display: inline-block;
  background-image: url(../images/deco01.png);
  background-size: contain;
  background-repeat: no-repeat;
  width: 27.5px;
  height: 27.5px;
}

.footer_fixed .f03 .f-btn02 a {
  position: relative;
  width: 180px;
  background: #8BC01F;
}

.footer_fixed .f03 .f-btn02 a::before {
  position: absolute;
  top: -15px;
  left: -20px;
  content: "";
  display: inline-block;
  background-image: url(../images/deco02.png);
  background-size: contain;
  background-repeat: no-repeat;
  width: 27.5px;
  height: 27.5px;
}

.footer_fixed .f03 .btn p {
  font-weight: 700;
  font-size: 1rem;
}

.footer_fixed .f03 .btn a img {
  width: 22px;
  margin-right: 10px;
}

/* pagetop
----------------------------------------------- */
#pageTop {
  display: none;
  position: fixed;
  bottom: 125px;
  right: 50px;
  z-index: 1000;
}

#pageTop a {
  padding: 8px 0 0 0px;
}

#pageTop a:hover {
  text-decoration: none;
  opacity: 0.7;
}

/* ===================================================================
/
/ sp
/
=================================================================== */
@media only screen and (max-width: 1600px) {
  header .h03 {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end;
  }

  header .h03 .a01 {
    margin: 10px 0 0 0;
  }

  header .h03 .a02 {
    width: 196px;
  }
}

@media only screen and (max-width: 1500px) {
  .site-header-inner {
    margin: 0 15px 0 20px;
  }
}

@media only screen and (max-width: 1300px) {
  header .h01-01 {
    width: 180px;
  }

  header .h03 .a01,
  header .h03 .a02 {
    width: auto;
  }

  /*header .h03 .a01 p,
    header .h03 .a02 p{
        display: none;
    }
    header .h03 img{
        margin: 0;
    }*/
}

@media only screen and (max-width: 1250px) {
  header nav .ja {
    font-size: 15px;
  }

  header nav .en {
    font-size: 10px;
  }

  header .h03 a {
    padding: 13px;
  }

  footer .f_menu ul li {
    padding: 0 25px;
    margin-bottom: 10px;
  }

  footer .f_menu ul li a {
    font-size: 0.9rem;
  }
}

@media only screen and (max-width: 1200px) {
  .footer_fixed .f02 {
    margin: 0 40px 0 30px;
  }

  .footer_fixed .f02 strong {
    font-size: 37px;
  }

  .f_contact h2 {
    line-height: 45px;
  }

  .f_contact .contact_tel_area {
    width: 43%;
  }

  .f_contact .contact_tel_area img {
    width: 100% !important;
  }

  .f_contact .f03 .btn a {
    padding: 10px;
  }

  .f_contact .f03 .f-btn01 a {
    width: 250px;
  }

  .f_contact .f03 .f-btn02 a {
    width: 200px;
  }

  .f_contact .f03 .btn p {
    font-size: 1.1rem;
  }

  .f_contact .f03 .f-btn01 a::before,
  .f_contact .f03 .f-btn02 a::before {
    width: 30px;
    height: 30px;
  }

  .footer_fixed .f03 .f-btn01 a {
    width: 200px;
  }

  .footer_fixed .f03 .f-btn02 a {
    width: 160px;
  }

  .footer_fixed .f03 .btn p {
    font-size: 0.9rem;
  }

  .footer_fixed .f03 .f-btn01 a::before,
  .footer_fixed .f03 .f-btn02 a::before {
    top: -10px;
    left: -15px;
    width: 22px;
    height: 22px;
  }
}

@media only screen and (max-width: 1100px) {
  header .h02 {
    display: none;
  }

  header .h03 {
    flex-direction: row;
    margin-right: 8%;
  }

  header .h03 .a01 {
    margin: 0 10px 0 0;
  }

  #hamburger,
  nav#globalMenuSp {
    display: block;
  }

  .site-header-inner {
    height: 65px;
  }

  footer .f_menu {
    display: none;
  }

  .accordion {
    pointer-events: all;
  }

  .toggle {
    height: 0 !important;
    padding: 0 8px;
    transition: .5s;
    overflow: hidden;
  }

  input:checked+.toggle {
    height: auto !important;
    padding: 8px;
  }

  header .h03 .btn p {
    font-size: 0.8rem;
  }

  header .h03 a {
    padding: 7px 13px;
  }
}

@media only screen and (max-width: 1024px) {
  .f_contact {
    padding: 50px 0;
  }

  .f_contact .contact_tel_area {
    width: 40%;
  }

  .footer_fixed {
    height: 110px;
  }

  .footer_fixed .f01 {
    width: 145px;
  }

  /*.footer_fixed .f03 .btn p{
        display: none;
    }
    .footer_fixed .f03 .f-btn01 a,
    .footer_fixed .f03 .f-btn02 a{
        width: auto;
    }
    .footer_fixed .f03 .btn a img{
        margin: 0;
    }*/
  .footer_fixed .f02 {
    width: 240px;
    margin: 0 30px 0 0px;
  }

  .footer_fixed .f02 .ie_img {
    width: 100% !important;
  }

  .footer_fixed .f03 .sp_flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }

  .footer_fixed .f03 .sp_flex .f-btn01 {
    margin-bottom: 12px;
  }

  .footer_fixed .f03 .btn a {
    padding: 5px 10px;
    width: 165px;
    margin-right: 0;
  }

  .footer_fixed .f03 .btn p {
    font-size: 0.8rem;
  }
}

@media only screen and (max-width: 768px) {
  .site-header-inner {
    display: block;
  }

  .f_contact h2 {
    font-size: 1.6rem;
    line-height: 40px;
  }

  .f_contact .contact_tel_area {
    width: 60%;
    margin: 0 auto 50px;
  }

  .f_contact .f03 {
    width: 100%;
  }

  .footer_fixed .f02-tel02 span {
    font-size: 24px;
    margin-right: 0;
  }

  .footer_fixed .f02 strong {
    font-size: 29px;
  }
}

@media only screen and (max-width: 650px) {

  .footer_fixed .f03 .f-btn01 a::before,
  .footer_fixed .f03 .f-btn02 a::before {
    width: 22px;
    height: 22px;
    left: -15px;
  }

  /*.footer_fixed .f03 .btn a{
        padding: 10px;
    }*/
  .footer_fixed .f02-tel02 span,
  .footer_fixed .f02 strong {
    font-size: 22px;
  }

  .footer_fixed .f02 p {
    line-height: 1.5;
  }

  .footer_fixed .f02-tel01 span {
    font-size: 14px;
  }

  .footer_fixed .f03 .sp_flex {
    display: contents;
  }

  .footer_fixed .f03 .sp_flex .f-btn01 {
    margin-bottom: 0;
    margin-top: 15px;
  }

  .footer_fixed .f03 .btn a {
    margin-right: 15px;
  }
}

@media only screen and (max-width: 479px) {
  .site-header-inner {
    margin: 0 15px 0 0;
  }

  header .h03 {
    margin-right: 15%;
    display: none;
  }

  .f_contact {
    padding: 30px 0;
  }

  .f_contact h2 {
    font-size: 1.2rem;
    line-height: 30px;
  }

  .f_contact .contact_tel_area {
    width: 95%;
  }

  .f_contact .f03 .f-btn01 a {
    margin-right: 0;
    margin-bottom: 30px;
  }

  footer {
    padding: 30px 0 0;
  }

  footer .f_logo {
    width: 200px;
    margin: 0 auto 20px;
  }

  footer .copyright {
    padding: 10px 0;
  }

  footer .copyright p {
    font-size: 0.8rem;
  }

  .footer_fixed {
    height: 80px;
    padding: 0;
  }

  .footer_fixed .footer-inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }

  .footer_fixed .footer-inner .f01 {
    width: 40%;
  }

  .footer_fixed .footer-inner .f03 {
    width: 60%;
  }

  .footer_fixed .f02 {
    display: none;
  }

  .footer_fixed .f03 .f-btn00 {
    display: inline-block;
    background: #006834;
    text-align: center;
    margin: 0 auto;
  }

  .footer_fixed .f03 .f-btn00 a {
    position: relative;
    background: #006834;
    margin-right: 0;
  }

  .footer_fixed .f03 .f-btn01 {
    background: #009F97;
  }

  .footer_fixed .f03 .f-btn02 {
    background: #8BC01F;
  }

  .footer_fixed .f03 .f-btn01 a {
    margin-right: 0;
  }

  .footer_fixed .f03 .f-btn00 a::before {
    position: absolute;
    top: -10px;
    left: -10px;
    content: "";
    display: inline-block;
    background-image: url(../images/deco00.png);
    background-size: contain;
    background-repeat: no-repeat;
    width: 18px;
    height: 18px;
    display: none
  }

  .footer_fixed .f03 .f-btn01 a::before,
  .footer_fixed .f03 .f-btn02 a::before {
    width: 18px;
    height: 18px;
    left: -10px;
    display: none;
  }

  .footer_fixed .btn {
    padding: 2% 2.5%;
  }

  .footer_fixed .f03 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }

  .footer_fixed .f03 .btn {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding: 0;
    margin: 0 !important;
    width: calc(100% / 3);
    height: 80px;
  }

  .footer_fixed .f03 .btn p {
    display: none;
  }

  .footer_fixed .f03 .btn a {
    width: auto !important;
    border-radius: 0;
    display: block;
    line-height: unset;
    margin: 0 auto;
    height: 100%;
  }

  .footer_fixed .f03 .btn a img {
    width: 45px;
    margin: 0 auto;
    margin-top: 1vh;
  }

  #pageTop {
    bottom: 90px;
    right: 10px;
  }

  #pageTop img {
    width: 40px;
  }
}

/* IEのみ */
@media all and (-ms-high-contrast: none) {
  .f_contact .f03 {
    margin-top: 2%;
  }

  .footer_fixed .f03 {
    margin-top: 2%;
  }

  .f_contact .f03 a {
    padding: 15px !important;
  }

  header .h03 a,
  .footer_fixed .f03 .btn a {
    padding: 8px !important;
  }

  .f03 p,
  .h03 p {
    padding-top: 5px !important;
  }
}

nav#globalMenuSp .ja {
  color: white;
}

.inline {
  display: inline-block;
}

nav#globalMenuSp ul li a {
  display: inline-block;
}

nav#globalMenuSp ul li.half {
  display: inline-block;
  margin-left: -0.2rem;
  height: 6.2rem;
}

nav#globalMenuSp ul li {
  height: 5.5rem;
}