@charset "UTF-8";

/* CSS Document */

/*--------------------
01.共通
共通チェックマーク箇所
数字と横並び
02.ヘッダー
03.フッター
--------------------*/

/*----------
01.共通
----------*/

:root {
  /*オリジナルの色#22A56E;*/
  /* --main-color: #00A968; */
  --main-color: #0087aa;
  --accent-color: linear-gradient(45deg, #ffbb1e 0, #ff9966 100%);
  --text-color: #4b4b4b;
}

* {
  box-sizing: border-box;
}

ul {
  margin: 0;
}

img {
  display: block;
  width: 100%;
  height: auto;
}

body {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-weight: 500;
  color: #2e2e2e;
}

main {
  display: block;
  /* margin-top: 120px; */
}

li {
  list-style: none;
}

a:visited {
  color: inherit;
}

.heebo {
  font-family: "Heebo", sans-serif;
}

.cnt_in_big {
  margin: 0 auto;
  max-width: 1280px;
}

.cnt_in {
  margin: 0 auto;
  max-width: 1080px;
  width: 96%;
}

.pc {
  display: block;
}

.sp {
  display: none;
}

.tablet {
  display: none;
}

.m_sp {
  display: none !important;
}

.m_pc {
  display: block;
}

.flex_box {
  display: flex;
}

.font_green {
  color: var(--main-color);
}

.font_2e {
  color: #2e2e2e;
}

a:hover {
  /*opacity: 0.9;*/
  opacity: 0.7;
}

.bg_green {
  background-color: var(--main-color);
  /* background-color: var(--main-color); */
}

.bg_black {
  background-color: #000;
}

.pan li,
.pan a {
  font-size: 13px;
  font-weight: 400;
  letter-spacing: 0.06em;
}

.pan li::after {
  content: ">";
  display: inline-block;
  margin: 0 10px;
  color: #9d9d9d;
}

.pan li:last-of-type::after {
  content: none;
}

.breadcrumb li a {
  color: #9d9d9d;
}

.pan {
  max-width: 1080px;
  margin: 0 auto;
  padding: 18px 0;
}

.main_ptn > .flex_box {
  margin: 0 0 120px auto;
  justify-content: space-between;
}

.main_ptn > .flex_box:nth-of-type(odd) {
  margin: 0 auto 120px 0;
  flex-direction: row-reverse;
}

.main_ptn > .flex_box:last-of-type {
  margin-bottom: 0;
}

.main_ptn picture {
  display: block;
  width: 51%;
  max-width: 600px;
}

.main_ptn .text_area {
  width: calc(49% - 5%);
}

.main_ptn h2 {
  margin: 0 0 23.5px;
  font-size: 16px;
  letter-spacing: 0.06em;
  line-height: 24px;
}

.main_ptn h2 span {
  display: block;
  font-size: 28px;
  font-weight: 900;
  line-height: 41px;
  text-transform: uppercase;
}

.main_ptn h3 {
  margin: 0 0 33px;
  font-size: 32px;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1.4;
}

.main_ptn p {
  font-weight: 400;
  letter-spacing: 0.08em;
  line-height: 2;
}

.title_ptn01 {
  position: relative;
  margin: 0 auto;
  max-width: 1190px;
  width: 92%;
  padding-bottom: 21.252%;
  /* background-image: url(../img/tensyoku/bg.jpg); */
  background-size: cover;
}

.breadcrumb {
  max-width: 1080px;
  font-size: 0.8em;
  margin: 110px auto 0;
  padding: 16px;
  letter-spacing: 0.06em;
}

.breadcrumb li {
  display: inline;
}

.breadcrumb li + li:before {
  content: ">";
  /* margin-right: .3em; */
  display: inline-block;
  margin: 0 10px;
  color: #9d9d9d;
}

@media (min-width: 1240px) {
  .title_ptn01.title_section .title {
    left: 10%;
  }
}

@media (min-width: 1312px) {
  .title_ptn01 {
    padding-bottom: 275px;
  }
}

.title_ptn01 .title {
  padding: 8px 27px;
  position: absolute;
  font-size: 34px;
  letter-spacing: 0.06em;
  color: #fff;
  z-index: 1;
  top: 64%;
  left: 4.64%;
  transform: translateY(-50%);
}

.title_ptn01 .heebo {
  text-transform: uppercase;
  font-weight: 500;
}

.title_ptn01 .heebo span {
  display: inline-block;
  margin: 0 0 0 13px;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 14px;
  vertical-align: middle;
}

.title_ptn01 .title::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: var(--main-color);
  transform: skewX(-15deg);
  z-index: -1;
}

.yellow {
  text-decoration: underline;
  background: linear-gradient(
    to top,
    rgba(255, 255, 255, 0) 10%,
    rgba(253, 238, 85, 1) 0%
  );
  background: -moz-linear-gradient(
    bottom,
    rgba(255, 255, 255, 0) 10%,
    rgba(253, 238, 85, 1) 0%
  );
  background: -webkit-linear-gradient(
    bottom,
    rgba(255, 255, 255, 0) 10%,
    rgba(253, 238, 85, 1) 0%
  );
  font-weight: 700;
}

/*----------
数字と横並び
----------*/

.num_area {
  display: flex;
  justify-content: space-between;
  padding-bottom: 56px;
  border-bottom: 1px solid #dbdbdb;
}

.num_area_h2,
.check_area_h2 {
  font-size: 32px;
  line-height: 48px;
  letter-spacing: 0.06em;
  font-weight: 800;
  margin-bottom: 75.7px;
}

.num_area_h2 span,
.check_area_h2 span {
  display: block;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  line-height: 24px;
  margin-bottom: 2.5px;
  /* color: #000; */
  font-weight: 500;
}

.num_area .cnt_img {
  width: 27.77%;
}

.num_area:first-of-type .cnt_text_nm {
  width: 60.52px;
}

.num_area:last-of-type {
  padding-bottom: 0;
  border-bottom: none;
}

.num_area .flex_box_sm {
  width: 68.24%;
}

.num_area .box_sm_in {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  margin-bottom: 25px;
}

.num_area .cnt_text_nm {
  max-width: 69.54px;
  position: relative;
  padding-top: 6.754px;
}

.num_area .cnt_text_nm::after {
  content: "";
  display: block;
  height: 58px;
  width: 1px;
  background-color: #000;
  position: absolute;
  right: -32px;
  top: 0;
}

.num_area .box_sm_in .cnt_text {
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 32px;
  margin-left: 64px;
}

.num_area:nth-of-type(2),
.num_area:nth-of-type(3) {
  padding-top: 56px;
}

.num_area p {
  font-size: 15px;
  line-height: 28px;
  letter-spacing: 0.08em;
  font-weight: 400;
}

/*----------
MOREボタン
----------*/

.cnt_btn {
  font-size: 14px;
  letter-spacing: 0.1em;
  line-height: 21px;
  font-weight: 700;
  padding-bottom: 16px;
  max-width: 150px;
  margin-left: auto;
  position: relative;
}

.cnt_btn a {
  display: block;
  width: 100%;
  height: 100%;
  text-align: right;
}

.cnt_btn::after {
  content: "";
  display: block;
  width: 150px;
  height: 2px;
  background-color: #000000;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
}

/*----------
共通チェックマーク箇所
----------*/

.check_area {
  padding: 48px 0;
  position: relative;
}

.check_area .cnt_in {
  background-color: #fff;
  padding-top: 51.1px;
}

.check_area_h2 {
  text-align: center;
}

/*.check_area .common_h2 span {
display: block;
font-size: 16px;
font-family: 'Noto Sans JP', sans-serif;
letter-spacing: 0.06em;
line-height: 24px;
color: #000;
font-weight: 500;
}*/

.check_area::before {
  content: "";
  display: block;
  width: 100%;
  height: 310px;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  position: absolute;
  top: 0;
  z-index: -1;
}

.check_area ul {
  max-width: 960px;
  margin: 0 auto 89.3px;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 39px;
}

.check_area li {
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  position: relative;
  padding-left: 44px;
}

.check_area li::before {
  display: block;
  content: "";
  width: 24px;
  height: 24px;
  /* background-image: url("../img/common/icon_check.png");
  background-repeat: no-repeat;
  background-size: contain; */
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  margin: auto;
}

/*----------
ページネーション
----------*/

ul.pagenation {
  display: flex;
  align-items: center;
  justify-content: center;
}

ul.pagenation li {
  width: 52px;
  height: 52px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #adadad;
  border-bottom: 4px solid #adadad;
}

ul.pagenation li.current {
  color: #000;
  border-bottom: 4px solid #000;
}

ul.pagenation li a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}

ul.pagenation li.prev,
ul.pagenation li.next {
  position: relative;
  border: none;
  text-indent: -9999px;
}

ul.pagenation li.prev::before,
ul.pagenation li.next::before,
ul.pagenation li.prev::after,
ul.pagenation li.next::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 0;
  height: 0;
  border-top: 5.5px solid transparent;
  border-bottom: 5.5px solid transparent;
}

ul.pagenation li.prev::before {
  border-right: 7px solid #000;
}

ul.pagenation li.next::before {
  border-left: 7px solid #000;
}

ul.pagenation li.prev::after {
  border-right: 7px solid #fff;
  padding-left: 3.5px;
}

ul.pagenation li.next::after {
  border-left: 7px solid #fff;
  padding-right: 3.5px;
}

/*----------
2カラム
----------*/

.main_wrap {
  padding: 40px 0 140px;
}

.main_wrap article {
  width: 72.9%;
  margin-right: 60px;
}

.main_wrap aside {
  flex: 1;
}

.main_wrap aside .entry_btn {
  position: relative;
  display: block;
  margin: 29px auto 40.9px;
  z-index: 100;
}

.main_wrap aside .widget {
  margin-bottom: 45px;
}

.main_wrap aside .widget .widget_title {
  font-weight: 700;
  letter-spacing: 0.06em;
  padding-bottom: 10px;
  border-bottom: 2px solid #000;
  margin-bottom: 15px;
}

.main_wrap aside .widget li a {
  font-size: 14px;
  font-weight: 400;
  letter-spacing: 0.08em;
  line-height: 1.57;
  text-decoration: underline;
}

.main_wrap aside .widget li a span {
  display: block;
  font-size: 12px;
  font-weight: 500;
}

.main_wrap aside .widget li + li {
  margin-top: 15px;
}

.main_wrap aside .widget .rank_box + .rank_box {
  margin-top: 15px;
}

.main_wrap aside .widget .rank_img {
  width: 31%;
  margin-right: 8px;
  position: relative;
}

.main_wrap aside .widget .rank_no {
  position: absolute;
  top: 0;
  left: 0;
  width: 22px;
  height: 22px;
  background: #000;
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
}

.main_wrap aside .widget .rank_title {
  flex: 1;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.57;
  letter-spacing: 0.08em;
}

.main_wrap aside .widget:first-of-type li a {
  display: block;
}

.title_ptn01.title_section {
  position: relative;
  margin-bottom: 248px;
}

.title_ptn01 picture {
  height: 270px;
  width: 100%;
  position: absolute;
}

.title_ptn01 picture img {
  height: 270px;
  width: 100%;
  object-fit: cover;
}

.title_bottom_container {
  position: relative;
  position: absolute;
  top: 82%;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
}

.title_bottom_grid {
  position: relative;
  margin: 0 auto;
  max-width: 1080px;
  width: 96%;
  background: rgba(242, 246, 245, 0.9);
  padding: 50px 45px 42px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-column-gap: 30px;
}

.title_bottom_block {
  position: relative;
  margin: 0 auto;
  max-width: 1080px;
  background: rgba(242, 246, 245, 0.9);
  padding: 50px 20px 42px;
  display: block;
  width: 85%;
  text-align: center;
}

.title_bottom_container .text01 {
  position: relative;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: bold;
  color: #0d0d0d;
  font-size: 18px;
  letter-spacing: 0.08em;
  line-height: 39px;
  text-align: center;
}

.title_bottom_container .text01 em {
  position: relative;
  z-index: 1;
}

.title_bottom_container .text01::before {
  /*content: "";
  display: block;
  width: 70.8%;
  height: 7.58px;
  background: repeating-linear-gradient(-45deg, #fff 0, #fff 4px, #22A56E 4px, #22A56E 5px);
  background: -webkit-repeating-linear-gradient(-45deg, #fff 0, #fff 4px, #22A56E 4px, #22A56E 5px);
  background: -o-repeating-linear-gradient(-45deg, #fff 0, #fff 4px, #22A56E 4px, #22A56E 5px);
  position: absolute;
  z-index: 0;
  bottom: 7.58px;*/
}

.title_bottom_container .text02 {
  position: relative;
  display: flex;
  align-items: flex-end;
  font-family: "Noto Sans JP";
  font-weight: normal;
  font-size: 18px;
  letter-spacing: 0.08em;
  line-height: 39px;
  text-align: left;
  color: #000;
}

.title_bottom_container .text03 {
  font-size: 22px;
  font-weight: 600;
  letter-spacing: 0.06em;
  line-height: 1.6;
  text-align: left;
  color: #000;
}

@media (min-width: 1240px) {
  .title_bottom_grid {
    padding: 57px 56px 55px;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-column-gap: 83px;
  }
  .title_bottom_block {
    /*padding: 57px 56px 53px;*/
    padding: 57px 20px 53px;
  }
}

/*----------
見出し他
----------*/

.detail_h2 {
  font-size: 28px;
  font-weight: 700;
  padding-bottom: 18px;
  margin: 60px auto 25px;
  position: relative;
}

.detail_h2::before {
  content: "";
  width: 115px;
  height: 6px;
  background: url(../img/consultant/consultant_detail/line.svg) center center
    no-repeat;
  background-size: contain;
  position: absolute;
  bottom: 0;
  left: 0;
}

.detail_h3 {
  font-size: 18px;
  font-weight: 500;
  margin: 25px 0 20px;
  padding-left: 28px;
  position: relative;
}

.detail_h3::before {
  content: "";
  width: 14px;
  height: 1px;
  background: #000000;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
}

p + h3.detail_h2 {
  margin-top: 121px;
}

.yellow_tag {
  background: #fdee55;
  padding: 0 4px;
  border-radius: 3px;
  margin-right: 8px;
  font-size: 14px;
}

/*----------
02.ヘッダー
----------*/

header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 999;
}

header .header_contact_wrap {
  text-align: center;
  /* border: 1px solid var(--main-color); */
  color: #333;
  font-size: 14px;
}

header .header_contact_wrap p {
  padding: 4px 12px;
}

header .cnt_g {
  border-bottom: 1px solid #ebebeb;
  background-color: #fff;
}

header .g01 .cnt_box.flex_box {
  justify-content: space-between;
  padding: 0 0 0 3.5%;
}

header .logo {
  padding: 2px 0;
  width: 160px;
}

header .logo a:hover {
  opacity: 0.9;
}

header .g01 .user,
header .g01 .client {
  justify-content: center;
  align-items: center;
  width: 144px;
  height: 48px;
}

header .g01 a {
  /* font-size: 14px; */
  font-weight: 600;
}

header .bg_green:hover {
  opacity: 0.7;
}

header .bg_black:hover {
  opacity: 0.8;
}

.g01 a {
  text-decoration: none;
}

.g01 .flex_box {
  align-items: center;
}

.g01 .flex_box.user {
  background-color: var(--main-color);
  color: #fff;
}

.g01 .flex_box.client {
  background-color: #333;
  color: #fff;
}

.g01 .header_contact_wrap img {
  width: 16px;
  height: 16px;
  margin-right: 6px;
  display: inline-block;
  vertical-align: middle;
}

header .g02 .cnt_in {
  width: 100%;
}

header .g02 nav {
  padding: 15px 0;
}

header .g02 .flex_box {
  justify-content: center;
  margin: 0 auto;
}

header .g02 .flex_box li {
  border-right: 1px solid #000;
}

header .g02 .flex_box li:last-of-type {
  border: none;
}

header .g02 .flex_box .parent,
header .g02 .flex_box li a {
  display: block;
  padding: 7px 17px;
  font-size: 14px;
  letter-spacing: 0.05em;
  text-decoration: none;
  color: var(--main-color);
}

header .g02 .flex_box .parent {
  position: relative;
}

header .g02 .flex_box .parent ul {
  display: none;
  position: absolute;
  width: 164px;
  left: 50%;
  top: 50px;
  transform: translateX(-50%);
}

header .g02 .flex_box .parent::before {
  content: "";
  display: block;
  position: absolute;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 7px 10px 7px;
  border-color: transparent transparent #22a56f transparent;
  left: 50%;
  top: 40px;
  transform: translateX(-50%);
  opacity: 0;
  transition: 0.3s;
}

header .g02 .flex_box .parent.open::before {
  opacity: 1;
}

header .g02 .flex_box .parent li {
  border-right: none;
  border-bottom: 2px solid #fff;
  background-color: var(--main-color);
}

header .g02 .flex_box .parent a {
  padding: 13px 0;
  color: #fff;
  text-align: center;
}

header .g02 .flex_box .parent span,
header .g02 .flex_box li a span {
  display: none;
}

/*----------
03.フッター
----------*/

footer .top {
  position: relative;
}

footer .top::before,
footer .top::after {
  content: "";
  display: block;
  position: absolute;
  height: 100%;
  width: 50%;
  top: 0;
  left: 0;
  background-color: var(--main-color);
  z-index: -1;
}

footer .top::after {
  background-color: #000;
  left: auto;
  right: 0;
}

footer .top li {
  display: flex;
  flex-direction: column;
  justify-content: center;
  width: 50%;
  text-align: center;
  color: #fff;
  padding: 0 16px 16px;
}

footer .top .bg_green {
  padding: 60.5px 0 70px;
}

footer .top .cnt_img {
  margin: 0 auto 18px;
  width: 30px;
}

footer .top p {
  margin: 16px 0;
  font-size: 22px;
  font-weight: 700;
  line-height: 1.4;
}

footer .top span {
  display: block;
  font-size: 14px;
  line-height: 20px;
}

footer .top .bg_green a {
  /*display: block;*/
  display: inline-block;
  margin: 0 0 30px;
  font-size: 45px;
  font-weight: 700;
  text-align: center;
  color: #fff;
}

footer .heebo {
  margin: 0 auto;
  width: 315px;
}

footer .heebo {
  text-decoration: none;
  transition: 0.3s ease-in-out;
}

footer .heebo:hover {
  background: #fff;
  transition: 0.3s ease-in-out;
  opacity: inherit;
}

footer .heebo:hover .btn {
  color: #000;
  transition: 0.3s ease-in-out;
}

footer .heebo:hover .btn i {
  border-top: 2px solid #000;
  border-right: 2px solid #000;
  transition: 0.3s ease-in-out;
}

footer .heebo .btn {
  display: block;
  border: 1px solid #fff;
  padding: 16px 0;
  color: #fff;
  text-transform: uppercase;
}

footer .heebo .btn i {
  content: "";
  display: inline-block;
  width: 8px;
  height: 8px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  margin: 0 0 2px 8px;
  transform: rotate(45deg);
}

footer .middle {
  padding: 45px 0 39px;
}

footer .sns_logo_wrap {
  display: flex;
  justify-content: center;
  margin: 8px 0 0;
}

footer .sns_logo {
  width: 28px;
  height: 28px;
  margin: 0 4px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

footer .sns_logo.twitter {
  background: #00acee;
}

footer .sns_logo.facebook {
  background: #395195;
}

footer .sns_logo img {
  width: 24px;
  height: 24px;
  object-fit: cover;
}

footer .middle .cnt_in {
  justify-content: space-between;
  padding: 0 3%;
}

footer .middle .logo {
  width: 200px;
}

footer .middle .logo .logo_image {
  width: 180px;
  height: 34px;
}

footer .middle .logo .logo_image img {
  width: 180px;
  height: 34px;
  object-fit: cover;
}

footer .middle span {
  font-weight: 700;
  color: #272727;
  border-bottom: 2px solid var(--main-color);
}

footer .middle a {
  font-size: 14px;
  font-weight: 400;
  color: #272727;
  text-decoration: none;
}

footer .middle a:hover {
  opacity: 0.8;
}

footer .end a:hover {
  color: #525050;
}

footer .middle .cnt_area {
  max-width: 365px;
  width: 30%;
  text-align: center;
}

footer .middle .cnt_area ul {
  text-align: left;
  padding: 8px 0 0 36%;
}

footer .middle .cnt_area ul li {
  padding: 4px 0;
}

footer .end {
  padding: 21px 0;
  background-color: #efefef;
}

footer .end .cnt_in {
  justify-content: center;
}

footer .end li {
  margin: 0 10px;
}

footer .end a {
  font-size: 14px;
  font-weight: 400;
  text-decoration: underline;
  color: #272727;
}
@media screen and (max-width: 820px) {
  footer .top p {
    font-size: 18px;
  }
  footer .top .bg_green a {
    font-size: 32px;
    text-underline-offset: 6px;
  }
}
@media only screen and (max-width: 1100px) {
  /*----------
02.ヘッダー
----------*/
  header .g02 .flex_box .parent,
  header .g02 .flex_box li a {
    padding: 7px 16px;
    letter-spacing: 0;
  }
}

@media only screen and (max-width: 1024px) {
  .m_pc {
    display: none !important;
  }
  .m_sp {
    display: block !important;
  }
  /*----------
01.共通
----------*/
  .main_ptn .cnt_in_middle {
    width: 90%;
    margin: 0 auto;
  }
  .main_ptn .text_area {
    width: calc(49% - 3%);
  }
  .main_ptn h3 {
    font-size: 24px;
    line-height: 36px;
  }
  .main_ptn p {
    line-height: 30px;
  }
  .title_bottom_grid {
    display: grid;
    grid-template-columns: 100%;
    grid-row-gap: 18px;
  }
  .title_bottom_container .text01 {
    text-align: center;
    font-size: 18px;
    line-height: 28px;
    letter-spacing: 0.06em;
  }
  .title_bottom_container .text02 {
    display: block;
    font-size: 14px;
    letter-spacing: 0.06em;
    line-height: 28px;
    text-align: center;
    align-items: unset;
  }
  .title_bottom_container .text01::before {
    width: 237px;
    z-index: 0;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
  }
  .title_ptn01.title_section .title {
    left: 22%;
    transform: translate(-50%, -50%);
    font-size: 28px;
  }
  /*----------
数字と横並び
----------*/
  .num_area .box_sm_in .cnt_text {
    font-size: 20px;
  }
  .num_area .flex_big_box p {
    font-size: 12px;
  }
  .check_area ul {
    width: 82.96%;
    font-size: 18px;
  }
}

@media only screen and (max-width: 950px) {
  /*----------
02.ヘッダー
----------*/
  header .g02 .flex_box .parent,
  header .g02 .flex_box li a {
    /* padding: 7px 10px; */
    font-size: 14px;
  }
}

@media only screen and (max-width: 875px) {
  /*----------
02.ヘッダー
----------*/
  footer .middle .cnt_in {
    padding: 0;
  }
  .num_area_h2,
  .check_area_h2 {
    font-size: 36px;
    margin-bottom: 32.7px;
  }
  .main_ptn p {
    line-height: 28px;
  }
  /*----------
03.フッター
----------*/
  .check_area {
    padding: 40px 0;
  }
  footer .middle .area01 {
    max-width: 337px;
  }
  footer .middle .area01 .flex_box {
    width: calc(100% - 85px);
  }
  footer .middle .logo {
    width: 180px;
  }
  footer .middle .logo .logo_image,
  footer .middle .logo .logo_image img {
    width: 160px;
    height: 30px;
  }
  footer .middle .cnt_area ul {
    padding: 8px 0 0 34%;
  }
}

@media only screen and (max-width: 750px) {
  /*----------
01.共通
----------*/
  /* .tablet {
        display: block;
    } */
  main {
    margin-top: 50px;
  }
  .cnt_in {
    width: 89%;
  }
  /* .pc {
        display: none;
    }
    .sp {
        display: block;
    } */
  .main_ptn > .flex_box,
  .main_ptn > .flex_box:nth-of-type(odd) {
    margin: 0 auto 100px;
    flex-direction: column;
  }
  header .g01 .bg_green a {
    font-size: 0;
  }
  .main_ptn picture {
    width: 100%;
  }
  .main_ptn .text_area {
    margin: 0 auto;
    width: 89%;
  }
  .main_ptn h2 {
    margin: 0 0 20px;
  }
  .main_ptn h2 span {
    font-size: 25px;
    line-height: 37px;
  }
  .main_ptn h3 {
    margin: 0 0 22px;
    font-size: 24px;
    line-height: 33px;
  }
  .main_ptn p {
    margin: 0 0 35px;
    line-height: 30px;
  }
  .title_ptn01 {
    padding: 74.98px 0;
  }
  .pan {
    width: 89.33%;
  }
  .title_ptn01 .title {
    font-size: 22px;
    line-height: 1;
    padding: 5.38px 43.3px 5.38px 15.3px;
    width: fit-content;
  }
  .title_ptn01.title_section {
    /* height: 280px; */
  }
  .title_ptn01.title_section .title {
    top: 43%;
  }
  .title_ptn01.title_section .title_bottom_container {
    top: 82%;
  }
  .title_ptn01 .heebo span {
    font-size: 8px;
  }
  .title_bottom_grid {
    display: grid;
    grid-template-columns: 100%;
    grid-row-gap: 15px;
  }
  .title_bottom_grid,
  .title_bottom_block {
    padding: 30px 17px 17px;
  }
  .title_bottom_block {
    width: 96%;
  }
  .title_bottom_container .text01::before {
    bottom: 2px;
  }
  .title_ptn01.title_section {
    position: relative;
    margin-bottom: 240px;
  }
  /*----------
数字と横並び
----------*/
  .num_area_h2,
  .check_area_h2 {
    font-size: 30px;
    line-height: 44px;
    letter-spacing: 0.06em;
    font-weight: 800;
    margin: 0 auto 30px;
    max-width: 335px;
  }
  .num_area_h2 span,
  .check_area_h2 span {
    display: block;
    font-size: 14px;
    line-height: 20px;
    margin-bottom: 0.5px;
  }
  .num_area {
    display: block;
    padding-bottom: 26px;
  }
  .num_area .box_sm_in {
    margin-bottom: 6px;
  }
  .num_area .cnt_img {
    width: 100%;
    max-width: 335px;
    margin: 0 auto 20px;
  }
  .num_area .flex_box_sm {
    width: 100%;
    max-width: 335px;
    margin: 0 auto;
  }
  .num_area .cnt_text_nm {
    max-width: 40.41px;
  }
  .num_area .box_sm_in .cnt_text {
    font-size: 16px;
    line-height: 24px;
    margin-left: 48px;
  }
  .num_area .cnt_text_nm::after {
    height: 69px;
    bottom: 0;
    margin: auto;
    right: -24px;
  }
  .num_area .flex_big_box {
    padding-bottom: 26px;
  }
  .num_area p {
    font-size: 14px;
    line-height: 28px;
    margin-top: 6px;
    margin-bottom: 0;
  }
  .num_area:nth-of-type(2),
  .num_area:nth-of-type(3) {
    padding-top: 30px;
  }
  /*----------
共通チェックマーク箇所
----------*/
  .check_area {
    padding-top: 74.2px;
  }
  .check_area_h2 {
    padding-top: 33.8px;
  }
  .check_area::before {
    /* background-image: url("../img/corporation_service/bg02_sp.jpg"); */
    height: 198px;
    background-position: center top;
    background-size: cover;
  }
  .check_area .common_h2 {
    margin-bottom: 27.9px;
    padding-top: 33.8px;
  }
  .check_area .common_h2 {
    font-size: 30px;
    line-height: 44px;
    margin-bottom: 30px;
  }
  .check_area .cnt_in {
    width: 100%;
    max-width: 372px;
    padding-top: 0;
  }
  .check_area ul {
    max-width: 310.91px;
    margin: 0 auto 88.3px;
    line-height: 24px;
    width: 92.8%;
  }
  .check_area li {
    margin-bottom: 28.5px;
  }
  .check_area li:last-child {
    margin-bottom: 0;
  }
  /*----------
2カラム
----------*/
  .main_wrap {
    display: block;
    padding-bottom: 48px;
  }
  .main_wrap article {
    width: 100%;
    margin-bottom: 106px;
  }
  .main_wrap article select {
    width: 100%;
    height: 40px;
    margin-bottom: 30px;
    border-radius: 0;
    border: 1px solid #000;
  }
  .main_wrap article select option {
    text-align: center;
    background: #fff;
  }
  .main_wrap aside .entry_btn {
    position: fixed;
    bottom: 5px;
    left: 0;
    right: 0;
    margin: auto;
    width: 89%;
  }
  .main_wrap aside .widget {
    margin-bottom: 35px;
  }
  .main_wrap aside .widget .rank_img {
    width: 21.5%;
  }
  .main_wrap aside .widget .widget_title {
    font-size: 14px;
  }
  /*----------
見出し他
----------*/
  .detail_h2 {
    font-size: 18px;
    line-height: 1.66;
    margin: 0 auto 17px;
    padding-bottom: 14px;
  }
  .detail_h3 {
    font-size: 16px;
    line-height: 2.5;
    margin-top: 35px;
    margin-bottom: 35px;
  }
  p + h3.detail_h2 {
    margin-top: 35px;
  }
  /*----------
02.ヘッダー
----------*/
  header .logo {
    padding: 0;
    /* width: 97px; */
  }
  .g01 .flex_box {
    font-size: 12px;
  }
  header .g01 li {
    width: 112px;
  }
  header .g01 li a::before {
    margin: 0;
  }
  header .g01 li a::after {
    content: none;
  }
  header .g01 .bg_black a::after {
    content: none;
  }
  header .g01 li.hum {
    position: relative;
    width: 65px;
  }
  header .hum span {
    position: absolute;
    width: 27px;
    height: 2px;
    top: 50%;
    left: 50%;
    background-color: var(--main-color);
    transform: translate(-50%, -50%);
    transition: 0.5s;
  }
  header .hum span::before,
  header .hum span::after {
    content: "";
    display: block;
    position: absolute;
    background-color: var(--main-color);
    width: 27px;
    height: 2px;
    top: -8px;
    transition: 0.5s;
  }
  header .hum span::after {
    top: 8px;
  }
  header .g01 .bg_green,
  header .g01 .bg_black {
    transition: 0.5s;
  }
  header .g01 .bg_green,
  header .g01 .bg_black {
    position: relative;
  }
  header .g01 .bg_green::after {
    content: "";
    display: block;
    width: 100%;
    height: 1px;
    background-color: var(--main-color);
    position: absolute;
    bottom: -1px;
    left: 0;
    right: 0;
    margin: auto;
  }
  header .g01 .bg_black::after {
    content: "";
    display: block;
    width: 100%;
    height: 1px;
    background-color: #000;
    position: absolute;
    bottom: -1px;
    left: 0;
    right: 0;
    margin: auto;
  }
  .act .g01 {
    border: none;
  }
  .act .g01 .bg_green,
  .act .g01 .bg_black {
    opacity: 0;
    pointer-events: none;
  }
  .act .hum span {
    background-color: rgba(0, 0, 0, 0);
  }
  .act .hum span::before {
    top: 0;
    transform: rotate(45deg);
  }
  .act .hum span::after {
    top: 0;
    transform: rotate(-45deg);
  }
  header .g02 .flex_box:nth-of-type(1) li:nth-of-type(2) a,
  header .g02 .flex_box:nth-of-type(1) li:nth-of-type(3) a,
  header .g02 .flex_box:nth-of-type(1) li:nth-of-type(4) a,
  header .g02 .flex_box:nth-of-type(1) li:nth-of-type(5) a,
  header .g02 .flex_box:nth-of-type(1) li:nth-of-type(6) a,
  header .g02 .flex_box:nth-of-type(1) li:nth-of-type(7) a {
    margin: 0 2px 0 0;
    font-weight: 600;
  }
  header .g02 .flex_box:nth-of-type(1) li.bg_black:nth-of-type(2) a {
    margin: 0;
    font-size: 14px;
  }
  header .g02 .flex_box .text::after {
    content: "";
    display: inline-block;
    margin: 0 0 0 100px;
    width: 11px;
    height: 7px;
    background-image: url(../img/common/parts_accordion.svg);
    background-size: contain;
    background-repeat: no-repeat;
    transform: translateY(-2px) rotate(180deg);
    transition: 0.5s;
  }
  header .g02 .flex_box .open .text::after {
    transform: translateY(-2px) rotate(360deg);
  }
  header .g02 .flex_box > li,
  header .g02 .flex_box .parent .text {
    /* padding: 0 0 0 20px; */
  }
  header .g02 .flex_box .parent::before {
    content: none;
  }
  header .g02 .flex_box .parent ul {
    position: static;
    margin: 24px 0 0;
    padding: 19px 0 19px 38px;
    background-color: #f2f7f6;
    width: 100%;
    transform: none;
  }
  header .g02 .flex_box .parent li {
    border: none;
    background-color: rgba(0, 0, 0, 0);
  }
  header .g02 .flex_box .parent li:first-of-type {
    margin: 0 0 15px;
  }
  header .g02 .flex_box .parent li a {
    padding: 0;
    font-weight: 400;
    line-height: 20px;
    color: #000;
    text-align: left;
  }
  header .g02 .flex_box > .sp {
    padding: 0;
  }
  header .g02 .flex_box > .last .flex_box {
    display: flex;
    width: 89%;
  }
  header .g02 .flex_box > .last li {
    margin: 0;
    padding: 0;
    width: 50%;
  }
  header .g02 .flex_box > .last a {
    padding: 24px 0;
    color: #fff;
    text-align: center;
  }
  header .g02 .flex_box > .last a::before {
    content: "";
    display: inline-block;
    margin: 0 7.5px 0 0;
    width: 20px;
    height: 18px;
    background-image: url(../img/common/parts_tel.svg);
    background-repeat: no-repeat;
    background-size: contain;
    vertical-align: middle;
  }
  header .g02 .flex_box > .last .bg_black a::before {
    background-image: url(../img/common/parts_enpitsu.svg);
  }
  /*----------
03.フッター
----------*/
  footer .top .flex_box {
    display: block;
  }
  footer .top li {
    width: 100%;
  }
  footer .top .bg_green {
    padding: 21px 0;
  }
  footer .top .cnt_img {
    margin: 0 auto 15px;
    width: 24px;
  }
  footer .top p {
    margin: 0 0 24px;
    font-size: 18px;
  }
  footer .top .bg_green a {
    margin: 0 0 24px;
    font-size: 32px;
  }
  footer .top span {
    font-size: 12px;
    line-height: 1;
  }
  footer .top .bg_black {
    padding: 25px 0;
  }
  footer .top .bg_black .cnt_img {
    margin: 0 auto 6px;
  }
  footer .top .bg_black p {
    margin: 0 0 26px;
  }
  footer .top .btn a {
    font-size: 14px;
  }
  footer .middle {
    padding: 115px 0 38px;
  }
  footer .middle .cnt_in {
    /* flex-direction: column; */
  }
  footer .middle span,
  footer .middle .cnt_g span {
    margin: 0 0 17px;
    border-bottom: 1px solid #000;
    padding: 0 0 7px;
    width: 100%;
  }
  footer .middle .area01 {
    margin: 0 0 38px;
    flex-wrap: wrap;
    width: 100%;
    max-width: none;
  }
  footer .middle .area01 .flex_box {
    width: 100%;
  }
  footer .middle .area01 li {
    max-width: none;
  }
  footer .middle .cnt_g {
    margin: 0 0 38px;
    flex-wrap: wrap;
  }
  footer .middle .cnt_g ul {
    display: flex;
    flex-wrap: wrap;
    width: 100%;
  }
  footer .middle .cnt_g li {
    margin: 0;
    width: 50%;
  }
  footer .end {
    /*margin: 0 0 61px;*/
    padding: 27px 0;
  }
  footer .end .cnt_in {
    flex-wrap: wrap;
    justify-content: center;
    width: 100%;
  }
  footer .end li {
    margin: 0 15px 25px;
  }
  footer .end li:last-of-type {
    margin-bottom: 0;
  }
  footer .middle .logo {
    margin-bottom: 30px;
    width: 97px;
  }
}

.no_data_text {
  font-size: 18px;
  font-weight: 700;
  line-height: 1.66;
  letter-spacing: 0.08em;
  text-align: center;
}

.wp-pagenavi {
  display: flex;
  align-items: center;
  justify-content: center;
}

.wp-pagenavi a,
.wp-pagenavi span {
  width: 52px;
  height: 52px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #000;
  border-bottom: 4px solid #adadad;
  margin: 0;
}

.wp-pagenavi a.previouspostslink,
.wp-pagenavi a.nextpostslink {
  position: relative;
  border: none;
  text-indent: -9999px;
  font-size: 0;
}

.wp-pagenavi a.previouspostslink::before,
.wp-pagenavi a.nextpostslink::before,
.wp-pagenavi a.previouspostslink::after,
.wp-pagenavi a.nextpostslink::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 0;
  height: 0;
  border-top: 5.5px solid transparent;
  border-bottom: 5.5px solid transparent;
}

.wp-pagenavi a.previouspostslink::before {
  border-right: 7px solid #000;
}

.wp-pagenavi a.previouspostslink::after {
  border-right: 7px solid #fff;
  padding-left: 3.5px;
}

.wp-pagenavi a.nextpostslink::before {
  border-left: 7px solid #000;
}

.wp-pagenavi a.nextpostslink::after {
  border-left: 7px solid #fff;
  padding-right: 3.5px;
}

.wp-pagenavi span.pages {
  display: none;
}

.wp-pagenavi a.first,
.wp-pagenavi a.last {
  display: none;
}

.wp-pagenavi .current {
  color: #000;
  border-bottom: 4px solid #000;
}

button {
  cursor: pointer;
  outline: none;
}

input[type="button"],
input[type="submit"],
input[type="file"] {
  cursor: pointer;
  outline: none;
}

#job_information .job_slider .arrow {
  cursor: pointer;
}

#verification .form_required::after {
  display: none !important;
}

#verification .form_select_mark {
  display: none;
}

#verification .form_select_suffix {
  margin: 0 !important;
}

#verification .form_select_mark_forarea {
  display: none;
}

#verification .form_item_phone .form_hyphen_pc {
  display: none;
}

#verification .mw-wp-form_file a {
  display: inline-block;
  font-weight: 300;
  font-size: 14px;
  color: #000;
  margin-top: 20px;
  text-decoration: underline;
}

#verification .form_filename {
  display: none !important;
}

#verification .form_file_label > span {
  display: none;
}

header .g01 li.bg_green a::after {
  display: none;
}

.text_center {
  text-align: center !important;
}

.no_underline {
  text-decoration: none !important;
}

@media screen and (max-width: 640px) {
  .parent,
  header .g02 .flex_box li a {
    padding: 7px 8px;
    font-size: 12px;
  }
}

@media screen and (max-width: 480px) {
  header .header_contact_wrap p {
    padding: 4px 8px;
  }
  .parent,
  header .g02 .flex_box li a {
    font-size: 10px;
  }
  header .g01 .cnt_box.flex_box {
    padding: 0 0 0 2%;
    box-shadow: 0 0 4px rgb(0 0 0 / 20%);
  }
  header .logo {
    padding: 4px 0;
    width: 88px;
  }
  .g01 .flex_box {
    font-size: 10px;
  }
  .g01 .header_contact_wrap img {
    width: 12px;
    height: 12px;
  }
  header .g01 .user,
  header .g01 .client {
    width: 100px;
    height: 40px;
  }
  header .header_contact_wrap {
    border: none;
  }
  header .g02 nav {
    padding: 6px 0;
  }
  .breadcrumb {
    margin: 74px auto 0;
    font-size: 0.6em;
  }
  /* ヘッダー右側のハンバーガーメニューっぽいやつ */
  .header_nav .menu_circle {
    width: 32px;
    height: 32px;
    position: absolute;
    top: 50%;
    right: 5%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    -webkit-transition: -webkit-transform 0.3s
      cubic-bezier(0.175, 0.885, 0.32, 1.275);
    transition: -webkit-transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275),
      -webkit-transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    user-select: none;
  }
  .header_nav .menu_circle::before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 50%;
    background-color: var(--main-color);
    -webkit-transition: -webkit-transform 0.3s
      cubic-bezier(0.175, 0.885, 0.32, 1.275);
    transition: -webkit-transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275),
      -webkit-transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  }
  .menu_bar {
    width: 15px;
    height: 15px;
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    -webkit-transition: -webkit-transform 0.2s
      cubic-bezier(0.39, 0.575, 0.565, 1);
    transition: -webkit-transform 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
    transition: transform 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
    transition: transform 0.2s cubic-bezier(0.39, 0.575, 0.565, 1),
      -webkit-transform 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
  }
  .menu_bar span {
    width: 15px;
    display: block;
    position: absolute;
    left: 0;
    height: 2px;
    border-radius: 2px;
    background-color: #fff;
    -webkit-transition: -webkit-transform 0.3s
      cubic-bezier(0.39, 0.575, 0.565, 1);
    transition: -webkit-transform 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
    transition: transform 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
    transition: transform 0.3s cubic-bezier(0.39, 0.575, 0.565, 1),
      -webkit-transform 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
  }
  .menu_bar span:nth-of-type(1) {
    top: 0px;
  }
  .menu_bar span:nth-of-type(2) {
    top: 50%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
  }
  .menu_bar span:nth-of-type(3) {
    bottom: 0px;
  }
  .span_transform1 {
    transform: translate(0px, 6px) rotate(45deg);
  }
  .span_transform2 {
    transform: translate(0px, -7px) rotate(-45deg);
  }
  .dis_no {
    display: none !important;
  }
  .hamburger_menu {
    position: absolute;
    top: 56px;
    right: 2%;
    width: 180px;
    /* margin-right: -18px; */
    padding: 24px 16px;
    /* padding: 32px 24px; */
    display: none;
    border: 2px solid #000;
    border-radius: 10px;
    background-color: #fff;
  }
  .hamburger_menu::before {
    content: "";
    position: absolute;
    right: 26px;
    bottom: 100%;
    width: 0;
    height: 0;
    margin-right: -14px;
    border-bottom: 18px solid #000;
    border-right: 14px solid transparent;
    border-left: 14px solid transparent;
  }
  .hamburger_menu::after {
    content: "";
    position: absolute;
    right: 26px;
    bottom: 100%;
    width: 0;
    height: 0;
    margin-right: -11px;
    border-bottom: 15px solid #fff;
    border-right: 11px solid transparent;
    border-left: 11px solid transparent;
    user-select: none;
  }
  ul.nav-items {
    text-align: left;
  }
  .nav-link {
    font-size: 18px;
    padding: 12px 0;
    text-align: center;
    cursor: pointer;
  }
  .nav-link span {
    padding-left: 4px;
  }
  .nav-link svg {
    margin: 0 16px 0 auto;
  }
  .nav-item:hover {
    background: #efefef;
    border-radius: 24px;
    /* padding: 0 16px; */
    transition: 0.2s;
  }
  #headerMask {
    display: none;
    position: fixed;
    top: 43px;
    left: 0;
    width: 100vw;
    height: 100vh;
    background: rgba(0, 0, 0, 0.3);
  }
  /* ハンバーガーメニューっぽいやつここまで */
  .nav-link i {
    content: "";
    display: inline-block;
    width: 6px;
    height: 6px;
    border-top: 2px solid #333;
    border-right: 2px solid #333;
    margin: 0 auto 1px 8px;
    transform: rotate(45deg);
  }
  main {
    margin-top: 0;
  }
  footer .top p {
    margin: 0 0 12px;
  }
  footer .top .bg_black p {
    margin: 24px 0 12px;
  }
  footer .top .bg_black {
    padding: 8px 0 32px;
  }
  footer .middle {
    padding: 40px 0 0;
  }
  footer .middle .cnt_in {
    flex-wrap: wrap;
  }
  footer .middle .logo {
    width: 100%;
    display: flex;
    align-items: center;
  }
  footer .sns_logo_wrap {
    margin: 0 0 0 16px;
  }
  footer .middle .cnt_in .cnt_area {
    width: calc((100% / 2) - 32px);
    text-align: left;
    margin: 0 0 24px 32px;
  }
  footer .middle .cnt_in .cnt_area:nth-of-type(3) {
    margin: 0 16px 24px 0px;
  }
  footer .middle .cnt_in .cnt_area:nth-of-type(4) {
    margin: 0 0 32px 32px;
  }
  footer .middle .cnt_area ul {
    padding: 16px 0 0 8px;
  }
}
